From 35ae41021855e59dee2ce57fc6ddf4ec75abfe80 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期二, 25 三月 2025 23:05:31 +0800
Subject: [PATCH] 首页统计容缺项目数
---
src/components/VisibilityToolbar/index.vue | 161 ++++++++++++++++++++++++++++++++++++++++++++++-------
1 files changed, 139 insertions(+), 22 deletions(-)
diff --git a/src/components/VisibilityToolbar/index.vue b/src/components/VisibilityToolbar/index.vue
index 4f8ff18..9f875e7 100644
--- a/src/components/VisibilityToolbar/index.vue
+++ b/src/components/VisibilityToolbar/index.vue
@@ -1,5 +1,5 @@
<template>
- <div class="top-right-btn" :style="style">
+ <div class="top-right-btn">
<el-row>
<el-tooltip v-if="search" class="item" effect="dark" :content="showSearch ? '闅愯棌鎼滅储' : '鏄剧ず鎼滅储'" placement="top">
<el-button size="small" circle icon="el-icon-search" @click="toggleSearch"></el-button>
@@ -12,31 +12,38 @@
</el-tooltip>
</el-row>
- <el-drawer :visible.sync="table" title="淇℃伅鏄鹃殣绛涢��" size="30%" append-to-body>
+ <el-drawer
+ :visible.sync="table"
+ title="淇℃伅鏄鹃殣绛涢��"
+ size="30%"
+ append-to-body
+ :wrapperCLosable="false"
+ :with-header="true">
<div slot="header">
<span>淇℃伅鏄鹃殣绛涢��</span>
</div>
- <div slot="default">
- <el-table :data="pagedColumns" style="width: 100%; height: 80%">
+ <div slot="default" style="margin-left: 20px;margin-top: 20px">
+ <el-table :row-key="row => { return row.id }" :data="getPage" style="width: 95%; height: 80%;;margin-bottom: 40px;" >
<el-table-column prop="index" label="搴忓彿" width="80"></el-table-column>
<el-table-column prop="label" label="鏁版嵁鍚嶇О"></el-table-column>
- <el-table-column prop="visible" label="鏄惁鏄剧ず">
+ <el-table-column prop="visible" label="鏄惁鏄剧ず" >
<template slot-scope="scope">
<el-switch
v-model="scope.row.visible"
class="ml-2"
- style="--el-switch-on-color: #13ce66; --el-switch-off-color: #ff4949"
+ active-color="#13ce66"
+ inactive-color="#ff4949"
@change="switchChange(scope.row)"
></el-switch>
</template>
</el-table-column>
- <el-table-column prop="date" label="鎺掑簭">
+ <el-table-column prop="sort" label="鎺掑簭">
<template slot-scope="scope">
- <el-input-number v-model="scope.row.serialNumber" :min="0" style="width: 120px" @change="sortChange(scope.row, $event)"></el-input-number>
+ <el-input-number v-model="scope.row.sort" :min="0" style="width: 120px"
+ @change="sortChange(scope.row, $event)"></el-input-number>
</template>
</el-table-column>
</el-table>
-
<el-pagination
v-if="total > pageSize"
:page-size="pageSize"
@@ -46,7 +53,8 @@
@current-change="handlePageChange"
></el-pagination>
</div>
- <div slot="footer">
+ <div style="position: absolute; bottom: 0; left: 0; right: 0; padding: 20px; text-align: right;">
+ <el-button type="primary" @click="save" v-if="isAdmin()">淇� 瀛�</el-button>
<el-button @click="table = false">鍙� 娑�</el-button>
<el-button type="primary" @click="resetSort">閲� 缃�</el-button>
</div>
@@ -55,6 +63,9 @@
</template>
<script>
+import {saveHiddenList} from "@/api/projectEngineering/projectInfo";
+
+import CircularJSON from 'circular-json'
export default {
data() {
@@ -62,6 +73,8 @@
table: false,
currentPage: 1,
columnRef: null,
+ cpList: [],
+ saveList:[],
};
},
props: {
@@ -72,6 +85,10 @@
columns: {
type: Array,
default: () => [],
+ },
+ hiddenTotal:{
+ type: Number,
+ default: 0,
},
search: {
type: Boolean,
@@ -92,15 +109,17 @@
return 10;
},
total() {
- return this.columns.length;
+ return this.hiddenTotal;
},
- pagedColumns() {
- const start = (this.currentPage - 1) * this.pageSize;
- const end = start + this.pageSize;
- return this.columns.slice(start, end);
- },
+ getPage(){
+ return this.columns;
+ }
},
+
methods: {
+ isAdmin(){
+ return this.$auth.hasRole("admin")
+ },
toggleSearch() {
this.$emit('update:showSearch', !this.showSearch);
},
@@ -111,25 +130,113 @@
this.table = true;
},
switchChange(row) {
+ if (row.visible === true){
+ row.display = "1"
+ }else {
+ row.display = "0"
+ }
+ if(this.saveList.length === 0){
+ this.saveList.push(row)
+ }else {
+ let have = true;
+ let index = this.saveList.findIndex(item => item.id === row.id);
+ if (index !== -1){
+ this.saveList[index] = row;
+ have =false;
+ }
+
+ if (have){
+ this.saveList.push(row)
+ }
+ }
+ console
this.$emit('update:columns', row);
},
handlePageChange(page) {
- this.currentPage = page;
+ this.$emit('update:page', page);
+ // this.currentPage = page;
+ // this.queryParams.currentPage = page;
+ // getHiddenList(this.queryParams).then(res =>{
+ // //杞崲
+ // res.data.forEach((item,index)=>{
+ // item.index = index + 1;
+ // item.key = index;
+ // item.serialNumber = index + 1;
+ // item.label = item.name;
+ // if(item.display === '0'){
+ // item.visible = false
+ // }else {
+ // item.visible = true;
+ // }
+ // if(item.columns ==='usedStatus' ){
+ // if(projectPhase !== '6') {
+ // item.visible = false
+ // } else {
+ // item.visible = true
+ // }
+ // }
+ // });
+ // this.columns = res.data;
+ // })
+
+ },
+ save(){
+ //淇濆瓨閫昏緫
+ if (this.saveList.length !== 0){
+ saveHiddenList(CircularJSON.stringify(this.saveList)).then(res =>{
+ this.$modal.msgSuccess("淇濆瓨鎴愬姛");
+ //鍒锋柊椤甸潰
+ this.$emit('update:resetSort');
+ });
+ }
},
sortChange(row, val) {
- this.$emit('update:sort', { key: row.key, serialNumber: val });
+ if (row.visible === true){
+ row.display = "1"
+ }else {
+ row.display = "0"
+ }
+ if(this.saveList.length === 0){
+ this.saveList.push(row)
+ }else {
+ let have = true;
+ let index = this.saveList.findIndex(item => item.id === row.id);
+ if (index !== -1){
+ this.saveList[index] = row;
+ have =false;
+ }
+ if (have){
+ this.saveList.push(row)
+ }
+ }
+ // // 鍒涘缓涓�涓柊鐨刢olumns鏁扮粍锛屼互閬垮厤鐩存帴淇敼鍘熷鏁扮粍
+ // this.cpList = this.columns.map(item => ({ ...item })); // 浣跨敤瑙f瀯鏉ュ垱寤哄璞$殑娴呮嫹璐�
+ //
+ // // 鏇存柊鎸囧畾椤圭殑serialNumber
+ // this.cpList.forEach(item => {
+ // if (item.key === row.key) {
+ // item.serialNumber = row.serialNumber;
+ // }
+ // });
+ //
+ // // 鏍规嵁serialNumber瀵筺ewColumns杩涜鎺掑簭
+ // this.cpList = this.cpList.sort((a, b) => a.serialNumber - b.serialNumber);
+ // // 瑙﹀彂浜嬩欢閫氱煡鐖剁粍浠禼olumns宸叉洿鏂帮紙濡傛灉鐖剁粍浠堕渶瑕佺煡閬撹繖涓彉鍖栵級
+ // this.$emit('update:sort', this.cpList);
+ this.$emit('update:sort', row);
},
resetSort() {
+ //閲嶇疆淇濆瓨闆嗗悎
+ this.currentPage = 1;
+ this.saveList = [];
this.$emit('update:resetSort');
},
},
mounted() {
+
this.columns.forEach((item, index) => {
if (item.visible) {
- // 娉ㄦ剰锛氳繖閲屽亣璁綾olumnRef搴旇鏄竴涓猚heckbox缁勪欢鐨勫紩鐢紝
- // 浣嗗湪Vue 2涓紝鎴戜滑鍙兘闇�瑕佸彟涓�绉嶆柟寮忔潵绠$悊checked鐘舵�侊紝
- // 鍥犱负Vue 2娌℃湁ref鐨勮嚜鍔ㄥ疄渚嬬粦瀹氾紝涓旇繖閲岀殑columnRef閫昏緫浼间箮涓嶅畬鏁存垨閿欒銆�
- // 鍙兘闇�瑕佺Щ闄ゆ垨閲嶅啓杩欓儴鍒嗛�昏緫銆�
+
}
});
},
@@ -157,4 +264,14 @@
.show-btn {
margin-left: 12px;
}
+.drawer-footer {
+ position: absolute;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ padding: 20px;
+ background: #fff;
+ border-top: 1px solid #e8e8e8;
+ text-align: right;
+}
</style>
--
Gitblit v1.8.0