| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  | <template> | 
					
						
							| 
									
										
										
										
											2022-07-27 09:05:31 +00:00
										 |  |  |  |   <div class="top-right-btn" :style="style"> | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |     <el-row> | 
					
						
							| 
									
										
										
										
											2022-07-27 09:05:31 +00:00
										 |  |  |  |       <el-tooltip class="item" effect="dark" :content="showSearch ? '隐藏搜索' : '显示搜索'" placement="top" v-if="search"> | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |         <el-button size="mini" circle icon="el-icon-search" @click="toggleSearch()" /> | 
					
						
							|  |  |  |  |       </el-tooltip> | 
					
						
							|  |  |  |  |       <el-tooltip class="item" effect="dark" content="刷新" placement="top"> | 
					
						
							|  |  |  |  |         <el-button size="mini" circle icon="el-icon-refresh" @click="refresh()" /> | 
					
						
							|  |  |  |  |       </el-tooltip> | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |       <el-tooltip class="item" effect="dark" content="显隐列" placement="top" v-if="columns"> | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |         <el-button size="mini" circle icon="el-icon-menu" @click="showColumn()" v-if="showColumnsType == 'transfer'"/> | 
					
						
							|  |  |  |  |         <el-dropdown trigger="click" :hide-on-click="false" style="padding-left: 12px" v-if="showColumnsType == 'checkbox'"> | 
					
						
							|  |  |  |  |           <el-button size="mini" circle icon="el-icon-menu" /> | 
					
						
							|  |  |  |  |           <el-dropdown-menu slot="dropdown"> | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |             <!-- 全选/反选 按钮 --> | 
					
						
							|  |  |  |  |             <el-dropdown-item> | 
					
						
							|  |  |  |  |               <el-checkbox :indeterminate="isIndeterminate" v-model="isChecked" @change="toggleCheckAll"> 列展示 </el-checkbox> | 
					
						
							|  |  |  |  |             </el-dropdown-item> | 
					
						
							|  |  |  |  |             <div class="check-line"></div> | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |             <template v-for="item in columns"> | 
					
						
							|  |  |  |  |               <el-dropdown-item :key="item.key"> | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |                 <el-checkbox v-model="item.visible" @change="checkboxChange($event, item.label)" :label="item.label" /> | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |               </el-dropdown-item> | 
					
						
							|  |  |  |  |             </template> | 
					
						
							|  |  |  |  |           </el-dropdown-menu> | 
					
						
							|  |  |  |  |         </el-dropdown> | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |       </el-tooltip> | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |     </el-row> | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |     <el-dialog :title="title" :visible.sync="open" append-to-body> | 
					
						
							|  |  |  |  |       <el-transfer | 
					
						
							|  |  |  |  |         :titles="['显示', '隐藏']" | 
					
						
							|  |  |  |  |         v-model="value" | 
					
						
							|  |  |  |  |         :data="columns" | 
					
						
							|  |  |  |  |         @change="dataChange" | 
					
						
							|  |  |  |  |       ></el-transfer> | 
					
						
							|  |  |  |  |     </el-dialog> | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |   </div> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | <script> | 
					
						
							|  |  |  |  | export default { | 
					
						
							|  |  |  |  |   name: "RightToolbar", | 
					
						
							|  |  |  |  |   data() { | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |     return { | 
					
						
							|  |  |  |  |       // 显隐数据
 | 
					
						
							|  |  |  |  |       value: [], | 
					
						
							|  |  |  |  |       // 弹出层标题
 | 
					
						
							|  |  |  |  |       title: "显示/隐藏", | 
					
						
							|  |  |  |  |       // 是否显示弹出层
 | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |       open: false | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  |   props: { | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |     /* 是否显示检索条件 */ | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |     showSearch: { | 
					
						
							|  |  |  |  |       type: Boolean, | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |       default: true | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |     /* 显隐列信息 */ | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |     columns: { | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |       type: Array | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |     /* 是否显示检索图标 */ | 
					
						
							| 
									
										
										
										
											2022-07-27 09:05:31 +00:00
										 |  |  |  |     search: { | 
					
						
							|  |  |  |  |       type: Boolean, | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |       default: true | 
					
						
							| 
									
										
										
										
											2022-07-27 09:05:31 +00:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |     /* 显隐列类型(transfer穿梭框、checkbox复选框) */ | 
					
						
							|  |  |  |  |     showColumnsType: { | 
					
						
							|  |  |  |  |       type: String, | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |       default: "checkbox" | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |     /* 右外边距 */ | 
					
						
							| 
									
										
										
										
											2022-07-27 09:05:31 +00:00
										 |  |  |  |     gutter: { | 
					
						
							|  |  |  |  |       type: Number, | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |       default: 10 | 
					
						
							| 
									
										
										
										
											2022-07-27 09:05:31 +00:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |   }, | 
					
						
							|  |  |  |  |   computed: { | 
					
						
							|  |  |  |  |     style() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |       const ret = {} | 
					
						
							| 
									
										
										
										
											2022-07-27 09:05:31 +00:00
										 |  |  |  |       if (this.gutter) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |         ret.marginRight = `${this.gutter / 2}px` | 
					
						
							| 
									
										
										
										
											2022-07-27 09:05:31 +00:00
										 |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |       return ret | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |     isChecked: { | 
					
						
							|  |  |  |  |       get() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |         return this.columns.every((col) => col.visible) | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |       }, | 
					
						
							|  |  |  |  |       set() {} | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     isIndeterminate() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |       return this.columns.some((col) => col.visible) && !this.isChecked | 
					
						
							| 
									
										
										
										
											2022-07-27 09:05:31 +00:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2021-03-24 15:46:37 +08:00
										 |  |  |  |   created() { | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |     if (this.showColumnsType == 'transfer') { | 
					
						
							|  |  |  |  |       // 显隐列初始默认隐藏列
 | 
					
						
							|  |  |  |  |       for (let item in this.columns) { | 
					
						
							|  |  |  |  |         if (this.columns[item].visible === false) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |           this.value.push(parseInt(item)) | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-03-24 15:46:37 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |     // 搜索
 | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |     toggleSearch() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |       this.$emit("update:showSearch", !this.showSearch) | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |     // 刷新
 | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |     refresh() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |       this.$emit("queryTable") | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |     // 右侧列表元素变化
 | 
					
						
							|  |  |  |  |     dataChange(data) { | 
					
						
							| 
									
										
										
										
											2021-11-22 18:06:44 +08:00
										 |  |  |  |       for (let item in this.columns) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |         const key = this.columns[item].key | 
					
						
							|  |  |  |  |         this.columns[item].visible = !data.includes(key) | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     // 打开显隐列dialog
 | 
					
						
							|  |  |  |  |     showColumn() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |       this.open = true | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |     // 单勾选
 | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |     checkboxChange(event, label) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |       this.columns.filter(item => item.label == label)[0].visible = event | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |     // 切换全选/反选
 | 
					
						
							|  |  |  |  |     toggleCheckAll() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  |       const newValue = !this.isChecked | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  |       this.columns.forEach((col) => (col.visible = newValue)) | 
					
						
							| 
									
										
										
										
											2023-12-01 11:20:12 +08:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-08-10 10:12:39 +08:00
										 |  |  |  | </script> | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  |  | ::v-deep .el-transfer__button { | 
					
						
							|  |  |  |  |   border-radius: 50%; | 
					
						
							|  |  |  |  |   padding: 12px; | 
					
						
							|  |  |  |  |   display: block; | 
					
						
							|  |  |  |  |   margin-left: 0px; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | ::v-deep .el-transfer__button:first-child { | 
					
						
							|  |  |  |  |   margin-bottom: 10px; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-04-21 15:21:51 +08:00
										 |  |  |  | .check-line { | 
					
						
							|  |  |  |  |   width: 90%; | 
					
						
							|  |  |  |  |   height: 1px; | 
					
						
							|  |  |  |  |   background-color: #ccc; | 
					
						
							|  |  |  |  |   margin: 3px auto; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-01-06 17:30:39 +08:00
										 |  |  |  | </style> |