Browse Source

档案盘点 新增盘点 树形选择器更换控件

master
x_ying 3 years ago
parent
commit
7815eca92c
  1. 201
      src/views/archivesManage/archivesCheck/module/addCheck.vue
  2. 303
      src/views/components/TreeSelect.vue

201
src/views/archivesManage/archivesCheck/module/addCheck.vue

@ -3,111 +3,112 @@
<el-dialog ref="dialogTable" title="新增盘点" :visible.sync="addFormVisible" class="dialog-table">
<span class="dialog-right-top" />
<span class="dialog-left-bottom" />
<el-form
ref="form"
:model="checkForm"
size="small"
label-width="80px"
>
<el-form-item label="选择区域" prop="selectArea" class="down-select">
<tree-select
:data="selectArea"
:menus-ids="menusIds"
:default-props="defaultProps"
multiple
:node-key="nodeKey"
:checked-keys="defaultCheckedKeys"
@popoverHide="popoverHide"
/>
</el-form-item>
<el-form-item label="选择门类" prop="category" class="down-select">
<el-select
v-model="categoryValue"
style="width: 300px"
multiple
filterable
clearable
placeholder="请选择"
>
<el-option
v-for="item in category"
:key="item.value"
:label="item.label"
:value="item.value"
<div class="setting-dialog">
<el-form
ref="form"
:model="checkForm"
size="small"
label-width="80px"
>
<el-form-item label="选择区域" prop="selectArea" class="down-select">
<treeselect
v-model="selectAreaValue"
:options="selectArea"
multiple
placeholder="请选择"
style="width:245px;height:30px"
/>
</el-select>
</el-form-item>
<el-button type="primary" style="margin:0 0 0 10px;height:32px;" @click="handleBuild">生成盘点单</el-button>
</el-form>
<el-table :data="gridData" style="height:290px">
<el-table-column type="index" align="center" label="序号" width="60" />
<el-table-column prop="fieldCnName" align="center" label="状态" width="80" />
<el-table-column prop="fieldCnName" align="center" label="所属门类" width="100" />
<el-table-column prop="fieldCnName" align="center" label="子条目数" width="100" />
<el-table-column prop="fieldCnName" align="center" label="全宗号" width="100" />
<el-table-column prop="fieldName" align="center" label="档号" width="180" />
<el-table-column prop="fieldCnName" align="center" label="部门名称" width="100" />
<el-table-column label="题名" align="center" width="180" />
<el-table-column label="年度" align="center" width="85" />
<el-table-column label="保管期限" align="center" width="120" />
<el-table-column label="密级" align="center" width="85" />
<el-table-column label="存放位置" align="center" width="150" />
</el-table>
<div slot="footer" class="dialog-footer">
<el-button @click="handleSave">保存</el-button>
</el-form-item>
<el-form-item label="选择门类" prop="category" class="down-select">
<el-select
v-model="categoryValue"
style="width: 245px"
multiple
filterable
clearable
placeholder="请选择"
>
<el-option
v-for="item in category"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-button type="primary" style="margin:0 0 0 10px;height:32px;" @click="handleBuild">生成盘点单</el-button>
</el-form>
<el-table :data="gridData" style="height:341px">
<el-table-column type="index" align="center" label="序号" width="60" />
<el-table-column prop="fieldCnName" align="center" label="状态" width="80" />
<el-table-column prop="fieldCnName" align="center" label="所属门类" width="100" />
<el-table-column prop="fieldCnName" align="center" label="子条目数" width="100" />
<el-table-column prop="fieldCnName" align="center" label="全宗号" width="100" />
<el-table-column prop="fieldName" align="center" label="档号" width="180" />
<el-table-column prop="fieldCnName" align="center" label="部门名称" width="100" />
<el-table-column label="题名" align="center" width="180" />
<el-table-column label="年度" align="center" width="85" />
<el-table-column label="保管期限" align="center" width="120" />
<el-table-column label="密级" align="center" width="85" />
<el-table-column label="存放位置" align="center" width="150" />
</el-table>
<div slot="footer" class="dialog-footer">
<el-button @click="handleSave">保存</el-button>
</div>
</div>
</el-dialog>
</div>
</template>
<script>
import TreeSelect from '@/views/components/TreeSelect.vue'
import Treeselect from '@riophae/vue-treeselect'
import '@riophae/vue-treeselect/dist/vue-treeselect.css'
var menus = [
{
'menuId': 1,
'menuName': '父区域',
'childrenList': [
id: 1,
label: '父区域',
children: [
{
'menuId': 100,
'menuName': '子区域1',
'childrenList': [
id: 100,
label: '子区域1',
children: [
{
'menuId': 1000,
'menuName': '设备1.1'
id: 1000,
label: '设备1.1'
},
{
'menuId': 1001,
'menuName': '设备1.2'
id: 1001,
label: '设备1.2'
},
{
'menuId': 1002,
'menuName': '设备1.3'
id: 1002,
label: '设备1.3'
},
{
'menuId': 1003,
'menuName': '设备1.4'
id: 1003,
label: '设备1.4'
}
]
},
{
'menuId': 101,
'menuName': '子区域2',
'childrenList': [
id: 101,
label: '子区域2',
children: [
{
'menuId': 1006,
'menuName': '设备2.1'
id: 1006,
label: '设备2.1'
},
{
'menuId': 1007,
'menuName': '设备2.2'
id: 1007,
label: '设备2.2'
},
{
'menuId': 1008,
'menuName': '设备2.3'
id: 1008,
label: '设备2.3'
},
{
'menuId': 1011,
'menuName': '设备2.4'
id: 1011,
label: '设备2.4'
}
]
}
@ -115,7 +116,7 @@ var menus = [
}
]
export default {
components: { TreeSelect },
components: { Treeselect },
data() {
return {
menusIds: [],
@ -124,11 +125,8 @@ export default {
addFormVisible: false,
selectAreaValue: [],
selectArea: menus,
defaultProps: {
children: 'childrenList',
label: 'menuName'
},
nodeKey: 'menuId',
defaultProps: { children: 'children', label: 'label' },
nodeKey: 'id',
defaultCheckedKeys: [],
categoryValue: ['选项1'],
category: [
@ -139,37 +137,13 @@ export default {
]
}
},
// ,
// created() {
// this.defaultCheckedKeys = [1000]
// },
// mounted() {
// this.defaultCheckedKeys = [1001]
// },
created() {
this.HandlemenuId()
},
methods: {
handleBuild() {
console.log(this.$refs.dialogTable.$refs)
},
handleSave() {
this.addFormVisible = false
},
popoverHide(checkedIds, checkedData) {
console.log(checkedIds)
console.log(checkedData)
},
HandlemenuId() {
menus.forEach(item => {
if (item.childrenList && item.childrenList) {
item.childrenList.forEach(item2 => {
item2.childrenList.forEach(item3 => {
this.menusIds.push(item3.menuId)
})
})
}
})
}
}
@ -188,4 +162,15 @@ export default {
position: absolute;
right: -155px;
}
::v-deep .el-tag.el-tag--info{
height: 26px;
line-height: 26px;
background-color: #13439E;
border: none;
color: #fff;
}
::v-deep .el-tag.el-tag--info .el-tag__close{
background-color: #fff;
}
</style>

303
src/views/components/TreeSelect.vue

@ -1,303 +0,0 @@
<template>
<div>
<div v-show="isShowSelect" class="mask" @click="isShowSelect = !isShowSelect" />
<el-popover
v-model="isShowSelect"
placement="bottom-start"
:width="width"
trigger="manual"
@hide="popoverHide"
>
<el-tree
ref="tree"
class="common-tree"
:style="style"
:data="data"
:props="defaultProps"
:show-checkbox="multiple"
:node-key="nodeKey"
:check-strictly="checkStrictly"
default-expand-all
:expand-on-click-node="false"
:check-on-click-node="multiple"
:highlight-current="true"
@node-click="handleNodeClick"
@check-change="handleCheckChange"
/>
<el-select
slot="reference"
ref="select"
v-model="selectedData"
:style="selectStyle"
:size="size"
:multiple="multiple"
:clearable="clearable"
:collapse-tags="collapseTags"
class="tree-select"
@click.native="isShowSelect = !isShowSelect"
@remove-tag="removeSelectedNodes"
@clear="removeSelectedNode"
@change="changeSelectedNodes"
>
<el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value" />
</el-select>
</el-popover>
</div>
</template>
<script>
export default {
name: 'TreeSelect',
props: {
//
data: {
type: Array,
default() {
return []
}
},
defaultProps: {
type: Object,
default() {
return {}
}
},
// id
menusIds: {
type: Array,
default() {
return []
}
},
//
multiple: {
type: Boolean,
default() {
return false
}
},
//
clearable: {
type: Boolean,
default() {
return false
}
},
//
collapseTags: {
type: Boolean,
default() {
return false
}
},
nodeKey: {
type: String,
default() {
return 'id'
}
},
//
checkStrictly: {
type: Boolean,
default() {
return false
}
},
// key
checkedKeys: {
type: Array,
default() {
return []
}
},
size: {
type: String,
default() {
return 'small'
}
},
width: {
type: Number,
default() {
return 250
}
},
height: {
type: Number,
default() {
return 300
}
}
},
data() {
return {
isShowSelect: false, //
options: [],
selectedData: [], //
style: 'width:' + this.width + 'px;' + 'height:' + this.height + 'px;',
selectStyle: 'width:' + (this.width + 24) + 'px;',
checkedIds: [],
checkedData: []
}
},
watch: {
isShowSelect(val) {
// select
this.$refs.select.blur()
},
checkedKeys(val) {
if (!val) return
this.checkedKeys = val
this.initCheckedData()
}
},
mounted() {
this.initCheckedData()
},
methods: {
// treeselect
setSelectOption(node) {
const tmpMap = {}
tmpMap.value = node.key
tmpMap.label = node.label
this.options = []
this.options.push(tmpMap)
this.selectedData = node.key
},
//
checkSelectedNode(checkedKeys) {
var item = checkedKeys[0]
this.$refs.tree.setCurrentKey(item)
var node = this.$refs.tree.getNode(item)
this.setSelectOption(node)
},
//
checkSelectedNodes(checkedKeys) {
this.$refs.tree.setCheckedKeys(checkedKeys)
},
//
clearSelectedNode() {
this.selectedData = ''
this.$refs.tree.setCurrentKey(null)
},
//
clearSelectedNodes() {
var checkedKeys = this.$refs.tree.getCheckedKeys() // key
for (let i = 0; i < checkedKeys.length; i++) {
this.$refs.tree.setChecked(checkedKeys[i], false)
}
},
initCheckedData() {
if (this.multiple) {
//
if (this.checkedKeys.length > 0) {
this.checkSelectedNodes(this.checkedKeys)
} else {
this.clearSelectedNodes()
}
} else {
//
if (this.checkedKeys.length > 0) {
this.checkSelectedNode(this.checkedKeys)
} else {
this.clearSelectedNode()
}
}
},
popoverHide() {
if (this.multiple) {
this.checkedIds = this.$refs.tree.getCheckedKeys() // key
this.checkedData = this.$refs.tree.getCheckedNodes() //
} else {
this.checkedIds = this.$refs.tree.getCurrentKey()
this.checkedData = this.$refs.tree.getCurrentNode()
}
this.$emit('popoverHide', this.checkedIds, this.checkedData)
},
// ,
handleNodeClick(data, node) {
console.log(node, 'node')
if (!this.multiple) {
this.setSelectOption(node)
this.isShowSelect = !this.isShowSelect
this.$emit('change', this.selectedData)
}
},
//
handleCheckChange() {
var checkedKeys = this.$refs.tree.getCheckedKeys() // key
this.options = checkedKeys.map((item) => {
var node = this.$refs.tree.getNode(item) // node
const tmpMap = {}
tmpMap.value = node.key
tmpMap.label = node.label
return tmpMap
})
// this.selectedData = this.options.map((item) => {
// return item.value
// })
this.selectedData = this.menusIds.filter(item => this.options.some(v => v.value === item))
this.$emit('change', this.selectedData)
},
// ,select
removeSelectedNodes(val) {
this.$refs.tree.setChecked(val, false)
var node = this.$refs.tree.getNode(val)
if (!this.checkStrictly && node.childNodes.length > 0) {
this.treeToList(node).map(item => {
if (item.childNodes.length <= 0) {
this.$refs.tree.setChecked(item, false)
}
})
this.handleCheckChange()
}
this.$emit('change', this.selectedData)
},
treeToList(tree) {
var queen = []
var out = []
queen = queen.concat(tree)
while (queen.length) {
var first = queen.shift()
if (first.childNodes) {
queen = queen.concat(first.childNodes)
}
out.push(first)
}
return out
},
// ,select
removeSelectedNode() {
this.clearSelectedNode()
this.$emit('change', this.selectedData)
},
// select
changeSelectedNodes(selectedData) {
// ,select
if (this.multiple && selectedData.length <= 0) {
this.clearSelectedNodes()
}
this.$emit('change', this.selectedData)
}
}
}
</script>
<style scoped>
.mask{
width: 100%;
height: 100%;
position: fixed;
top: 0;
left: 0;
opacity: 0;
z-index: 11;
}
.common-tree{
overflow: auto;
}
.tree-select{
z-index: 111;
}
</style>
Loading…
Cancel
Save