From bfd87d12adb1d511334cd91cf6c7ff3608fae8b9 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期三, 09 十月 2024 16:30:38 +0800 Subject: [PATCH] 最新版本 --- admin/src/components/common/Tree.vue | 77 ++++++++++++++++++++++++-------------- 1 files changed, 48 insertions(+), 29 deletions(-) diff --git a/admin/src/components/common/Tree.vue b/admin/src/components/common/Tree.vue index 432a1a6..5d6fd7b 100644 --- a/admin/src/components/common/Tree.vue +++ b/admin/src/components/common/Tree.vue @@ -2,13 +2,16 @@ <div class="tree"> <div v-for="(item, index) of list" :key="index" @click.stop="clickIten(item)"> <div class="tree_item"> - <i class="el-icon-caret-bottom" :class="{ 'activeColor': item[defaultProps.status] }" v-show="item[defaultProps.status] && item[defaultProps.children]"></i> - <i class="el-icon-caret-right color" v-show="item[defaultProps.children] && !item[defaultProps.status]"></i> - <div class="tree_item_label long-title-style" :title="item[defaultProps.name]" :class="{ 'activeColor': item[defaultProps.status] && !item[defaultProps.children] }">{{ item[defaultProps.name] }}</div> + <i class="el-icon-caret-bottom" :class="{ 'activeColor': item.fsStatus === 1 }" v-show="item.fsStatus === 1 && item.childList.length > 0"></i> + <i class="el-icon-caret-right color" v-show="item.childList.length > 0 && (item.fsStatus === 0 || !item.fsStatus)"></i> + <div class="tree_item_label long-title-style" :title="item.name" :class="{ 'activeColor': item.fsDate === 1 && item.childList.length === 0 }">{{ item.name }}</div> + <!-- <i class="el-icon-caret-bottom" :class="{ 'activeColor': item[defaultProps.status] }" v-show="item[defaultProps.status] && item[defaultProps.children]"></i>--> +<!-- <i class="el-icon-caret-right color" v-show="item[defaultProps.children] && !item[defaultProps.status]"></i>--> +<!-- <div class="tree_item_label long-title-style" :title="item[defaultProps.name]" :class="{ 'activeColor': item[defaultProps.status] && !item[defaultProps.children] }">{{ item[defaultProps.name] }}</div>--> </div> - <div class="tree_childern" v-show="item[defaultProps.status]"> + <div class="tree_childern" v-show="item.fsStatus === 1"> <tree - :list="item[defaultProps.children]" + :list="item.childList" :defaultProps="defaultProps" @callback="callback" /> @@ -36,7 +39,8 @@ name: 'name', status: 'status', children: 'children', - id: 'id' + id: 'id', + erpId: 'erpId' } } } @@ -45,41 +49,56 @@ return { tempItem: { id: null, - name: null + name: null, + erpId: null } } }, methods: { // 鐐瑰嚮褰撳墠椤� clickIten (item) { - item[this.defaultProps.status] = !item[this.defaultProps.status] - this.list.forEach(subItem => { - if ((subItem[this.defaultProps.id] !== item[this.defaultProps.id] && subItem[this.defaultProps.status]) || (this.list.length === 1 && subItem[this.defaultProps.status] === false)) { - subItem[this.defaultProps.status] = false - if (subItem[this.defaultProps.children]) { - this.recursion(subItem[this.defaultProps.children]) - } - } + // item[this.defaultProps.status] = !item[this.defaultProps.status] + // this.list.forEach(subItem => { + // if ((subItem[this.defaultProps.id] !== item[this.defaultProps.id] && subItem[this.defaultProps.status]) || (this.list.length === 1 && subItem[this.defaultProps.status] === false)) { + // subItem[this.defaultProps.status] = false + // if (subItem[this.defaultProps.children]) { + // this.recursion(subItem[this.defaultProps.children]) + // } + // } + // }) + // if (this.tempItem['id'] === item[this.defaultProps.id]) { + // this.tempItem = { + // id: null, + // name: null, + // erpId: null + // } + // } else { + // this.tempItem.id = item[this.defaultProps.id] + // this.tempItem.name = item[this.defaultProps.name] + // this.tempItem.erpId = item['erpId'] + // } + // item.fsDate === 0 || !item.fsDate ? item.fsDate = 1 : item.fsDate = 0 + const fsDate = item.fsDate === 0 || !item.fsDate ? 1 : 0 + this.list.forEach(i => { + i.fsDate = 0 }) - if (this.tempItem['id'] === item[this.defaultProps.id]) { - this.tempItem = { - id: null, - name: null - } - } else { - this.tempItem.id = item[this.defaultProps.id] - this.tempItem.name = item[this.defaultProps.name] + item.fsDate = fsDate + if (item.childList.length > 0) { + item.fsStatus === 0 || !item.fsStatus ? item.fsStatus = 1 : item.fsStatus = 0 } - - this.$emit('callback', this.tempItem, item) + this.$emit('callback', item, item) }, // 閫掑綊鏂规硶 recursion (children) { children.forEach(item => { - item[this.defaultProps.status] = false - if (item[this.defaultProps.children]) { - this.recursion(item[this.defaultProps.children]) + item.fsDate = 0 + if (item.childList.length > 0) { + this.recursion(item.childList) } + // item[this.defaultProps.status] = false + // if (item[this.defaultProps.children]) { + // this.recursion(item[this.defaultProps.children]) + // } }) }, callback (data, item) { @@ -89,7 +108,7 @@ this.tempItem.id = data.id this.tempItem.name = data.name } - this.$emit('callback', this.tempItem, item) + this.$emit('callback', data, item) } } } -- Gitblit v1.9.3