2025-02-01 11:06:10 +00:00
|
|
|
<template>
|
|
|
|
<div class="tree-list-container text-end pt-3 firefox-scrollbar">
|
|
|
|
<!-- <div
|
|
|
|
class="d-flex justify-content-between align-items-center border-bottom"
|
|
|
|
>
|
|
|
|
<h6 class="">فهرست عناوین</h6>
|
|
|
|
<button @click.prevent="closeList" class="btn" type="button">
|
|
|
|
<svg class="icon icon-Component-294--1">
|
|
|
|
<use xlink:href="#icon-Component-294--1"></use>
|
|
|
|
</svg>
|
|
|
|
</button>
|
|
|
|
</div> -->
|
|
|
|
<div style="border-bottom: 1px solid var(--primary-color) !important">
|
|
|
|
<div
|
|
|
|
class="d-flex justify-content-between align-items-center mb-2 header_div"
|
|
|
|
>
|
|
|
|
<h6 style="font-family: sahel-semi-bold" class="m-0">فهرست عناوین</h6>
|
|
|
|
<button @click.prevent="closeList" class="btn" type="button">
|
|
|
|
<svg class="icon icon-Component-21--1">
|
|
|
|
<use xlink:href="#icon-Component-21--1"></use>
|
|
|
|
</svg>
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<template v-if="loading">
|
|
|
|
<the-content-loading
|
|
|
|
:loadingTitle="'در حال دریافت اطلاعات'"
|
|
|
|
class="table-loading mt-3"
|
|
|
|
></the-content-loading>
|
|
|
|
</template>
|
|
|
|
<div class="tree-list-content">
|
|
|
|
<vue3-tree-vue
|
|
|
|
class="mt-3"
|
|
|
|
:isCheckable="true"
|
|
|
|
v-if="localDataTree.length"
|
|
|
|
:items="localDataTree"
|
|
|
|
ref="tree"
|
|
|
|
@onSelect="itemclick"
|
|
|
|
@onCheck="itemclick"
|
|
|
|
@onExpand="itemtoggle"
|
|
|
|
@onCollapse="itemtoggle"
|
|
|
|
>
|
|
|
|
<!-- Applying some simple styling to tree-items -->
|
|
|
|
<template v-slot:item-prepend-icon="treeViewItem">
|
|
|
|
<div
|
|
|
|
style="display: inherit; width: 200px"
|
|
|
|
@click.ctrl="customItemClickWithCtrl"
|
|
|
|
>
|
|
|
|
<svg class="icon-tree icon icon-MyFolder">
|
|
|
|
<use xlink:href="#icon-MyFolder"></use>
|
|
|
|
</svg>
|
|
|
|
{{ treeViewItem.text }}
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</vue3-tree-vue>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import "vue3-tree-vue/dist/style.css"; // remember to add this in your component or maint.[ts/js]
|
|
|
|
|
|
|
|
import entityApi from "@apis/entityApi";
|
|
|
|
|
|
|
|
import { mapActions, mapState } from "pinia";
|
|
|
|
|
2025-02-11 07:09:05 +00:00
|
|
|
import { useEntityStore } from "@search/stores/entityStore";
|
2025-02-01 11:06:10 +00:00
|
|
|
import { useSearchStore } from "~/stores/searchStore";
|
|
|
|
import { useCommonStore } from "~/stores/commonStore";
|
|
|
|
|
|
|
|
export default {
|
|
|
|
props: {
|
|
|
|
dataTree: {
|
|
|
|
default() {
|
|
|
|
return [];
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
mounted() {
|
|
|
|
console.log("localDataTree", this.localDataTree);
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
httpService: undefined,
|
|
|
|
|
|
|
|
selectedItems: [],
|
|
|
|
selectedLabels: [],
|
|
|
|
nodes: [],
|
|
|
|
// newTree: {},
|
|
|
|
dicTreePath: {},
|
|
|
|
searchText: "",
|
|
|
|
loading: false,
|
|
|
|
localDataTree: this.dataTree,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
...mapState(useCommonStore, ["paginationGetter"]),
|
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
closeList() {
|
|
|
|
this.$emit("showListHeadline", {
|
|
|
|
isSearchMode: false,
|
|
|
|
isHeadingMode: false,
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
inputKeyUp: function () {
|
|
|
|
var text = this.searchText;
|
|
|
|
const patt = new RegExp(text);
|
|
|
|
// console.log(this.$refs.tree);
|
|
|
|
this.$refs.tree.handleRecursionNodeChilds(
|
|
|
|
this.$refs.tree,
|
|
|
|
function (node) {
|
|
|
|
if (text !== "" && node.model !== undefined) {
|
|
|
|
const str = node.model.text;
|
|
|
|
if (str.toLowerCase().includes(text)) {
|
|
|
|
node.$el.hidden = false;
|
|
|
|
var parent = node.$parent;
|
|
|
|
while (parent && parent.model) {
|
|
|
|
parent.$el.hidden = false;
|
|
|
|
parent.model.opened = true;
|
|
|
|
parent = parent.$parent;
|
|
|
|
}
|
|
|
|
// node.
|
|
|
|
} else node.$el.hidden = true;
|
|
|
|
} else {
|
|
|
|
node.$el.hidden = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
},
|
|
|
|
UnSelectNode(node_id) {
|
|
|
|
// console.log(node_id);
|
|
|
|
var self = this;
|
|
|
|
this.$refs.tree.handleRecursionNodeChilds(
|
|
|
|
this.$refs.tree,
|
|
|
|
function (node) {
|
|
|
|
if (node.model !== undefined && node.model.id == node_id) {
|
|
|
|
node.model.selected = false;
|
|
|
|
self.onClick(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
},
|
|
|
|
itemclick(node) {
|
|
|
|
// console.log("onClick", node);
|
|
|
|
this.$root.$emit("jump-to-item", {
|
|
|
|
_id: node.model.id,
|
|
|
|
child_order: node.model.order,
|
|
|
|
jumpPage: node.model.jumpPage,
|
|
|
|
});
|
|
|
|
|
|
|
|
if (window.innerWidth < 575) {
|
|
|
|
this.$emit("is-treelist-mode");
|
|
|
|
}
|
|
|
|
|
|
|
|
// if (
|
|
|
|
// typeof node.model != "undefined" &&
|
|
|
|
// node.model.hasOwnProperty("selected") &&
|
|
|
|
// node.model.selected
|
|
|
|
// ) {
|
|
|
|
// this.nodes.push(node.model);
|
|
|
|
|
|
|
|
// this.selectedItems.push(node.model.id);
|
|
|
|
// this.selectedLabels.push(node.model.text);
|
|
|
|
// } else {
|
|
|
|
// this.selectedItems.splice(this.selectedItems.indexOf(node.model.id), 1);
|
|
|
|
// this.selectedLabels.splice(
|
|
|
|
// this.selectedLabels.indexOf(node.model.text),
|
|
|
|
// 1
|
|
|
|
// );
|
|
|
|
// this.nodes.splice(this.nodes.indexOf(node.model.id), 1);
|
|
|
|
// }
|
|
|
|
|
|
|
|
// let page = Math.ceil(node.model.order / this.paginationGetter.limit);
|
|
|
|
// this.$router
|
|
|
|
// .push({
|
|
|
|
// name: this.$route.name,
|
|
|
|
// query: { page: `${page}` },
|
|
|
|
// params: { key: this.$route.params.key, id: this.$route.params.id },
|
|
|
|
// })
|
|
|
|
// .then(() => {})
|
|
|
|
// .catch(() => {});
|
|
|
|
// this.$root.$emit("tree-item-click", this.nodes);
|
|
|
|
},
|
|
|
|
itemtoggle(data) {
|
|
|
|
// console.info(data);
|
|
|
|
},
|
|
|
|
itemdragstart() {
|
|
|
|
// console.info(data);
|
|
|
|
},
|
|
|
|
itemdragend() {
|
|
|
|
// console.info(data);
|
|
|
|
},
|
|
|
|
itemdropbefore() {
|
|
|
|
// console.info(data);
|
|
|
|
},
|
|
|
|
itemdrop() {
|
|
|
|
// console.info(data);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss">
|
|
|
|
.icon-tree {
|
|
|
|
color: #dbc056;
|
|
|
|
font-size: 0.6rem;
|
|
|
|
}
|
|
|
|
.vtl-node-main {
|
|
|
|
padding: 5px 1rem 5px 0 !important;
|
|
|
|
|
|
|
|
.vtl-node-content {
|
|
|
|
// margin-right: 7px;
|
|
|
|
}
|
|
|
|
|
|
|
|
&.vtl-drag-disabled {
|
|
|
|
// background-color: #d0cfcf;
|
|
|
|
background-color: inherit !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
&:hover {
|
|
|
|
cursor: pointer;
|
|
|
|
background-color: #f0f0f0 !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
.vtl-caret {
|
|
|
|
// margin-left: 0;
|
|
|
|
// margin-right: -1rem;
|
|
|
|
// margin-top: 8px;
|
|
|
|
// transform: rotateY(180deg);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.vtl-tree-margin {
|
|
|
|
// margin-right: 2em;
|
|
|
|
// margin-left: auto;
|
|
|
|
}
|
|
|
|
|
|
|
|
.vtl {
|
|
|
|
.vtl-drag-disabled {
|
|
|
|
background-color: #d0cfcf;
|
|
|
|
|
|
|
|
&:hover {
|
|
|
|
background-color: #d0cfcf;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.vtl-disabled {
|
|
|
|
background-color: #d0cfcf;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.vtl {
|
|
|
|
}
|
|
|
|
.tree-icon {
|
|
|
|
background-image: url("") !important;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
.label {
|
|
|
|
position: relative;
|
|
|
|
background-color: #fafafa;
|
|
|
|
// background-color: #fff;
|
|
|
|
padding: 0.3em;
|
|
|
|
border-radius: 0.5em;
|
|
|
|
margin-left: 1.4em;
|
|
|
|
margin-top: 0.5rem;
|
|
|
|
border: 1px solid #9e00b1;
|
|
|
|
span {
|
|
|
|
position: absolute;
|
|
|
|
top: -0.5em;
|
|
|
|
left: -1.2em;
|
|
|
|
display: -webkit-box;
|
|
|
|
display: -ms-flexbox;
|
|
|
|
display: flex;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.icon {
|
|
|
|
&:hover {
|
|
|
|
cursor: pointer;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.muted {
|
|
|
|
color: gray;
|
|
|
|
font-size: 80%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.tree {
|
|
|
|
text-align: right;
|
|
|
|
}
|
|
|
|
|
|
|
|
.tree-list-container {
|
|
|
|
.tree-list-content {
|
|
|
|
width: 100%;
|
|
|
|
height: calc(100vh - 20em);
|
|
|
|
overflow-y: auto;
|
|
|
|
}
|
|
|
|
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
</style>
|