2022-11-14 03:59:26 +00:00
|
|
|
import { w as withInstall } from "../badge/index2.js";
|
|
|
|
import { defineComponent, useSlots, computed, resolveComponent, openBlock, createElementBlock, Fragment, renderList, normalizeClass, createElementVNode, createVNode, unref, withModifiers, createBlock, createCommentVNode, renderSlot, createTextVNode, toDisplayString, withCtx, createSlots, ref, watch, onMounted, nextTick } from "vue";
|
|
|
|
import { _ as _sfc_main$2E, a as _sfc_main$2 } from "../checkbox/index2.js";
|
|
|
|
import { _ as _sfc_main$3 } from "../transition/index2.js";
|
|
|
|
const _hoisted_1 = ["onClick"];
|
|
|
|
const _hoisted_2 = { class: "layui-tree-main" };
|
|
|
|
const _hoisted_3 = ["onClick"];
|
|
|
|
const _hoisted_4 = {
|
|
|
|
key: 0,
|
|
|
|
class: "layui-tree-pack layui-tree-showLine",
|
|
|
|
style: { "display": "block" }
|
|
|
|
};
|
|
|
|
const __default__$1 = {
|
|
|
|
name: "TreeNode"
|
|
|
|
};
|
|
|
|
const _sfc_main$1 = defineComponent({
|
|
|
|
...__default__$1,
|
|
|
|
props: {
|
|
|
|
tree: null,
|
|
|
|
nodeList: null,
|
|
|
|
showCheckbox: { type: Boolean },
|
|
|
|
showLine: { type: Boolean },
|
|
|
|
selectedKey: null,
|
|
|
|
checkStrictly: { type: [Boolean, String] },
|
|
|
|
collapseTransition: { type: Boolean },
|
2023-04-25 01:25:44 +00:00
|
|
|
onlyIconControl: { type: Boolean },
|
2023-05-12 07:56:44 +00:00
|
|
|
hideicon: { type: Boolean },
|
|
|
|
selectParent: { type: Boolean }
|
2022-11-14 03:59:26 +00:00
|
|
|
},
|
|
|
|
emits: ["node-click"],
|
|
|
|
setup(__props, { emit }) {
|
|
|
|
const props = __props;
|
|
|
|
useSlots();
|
|
|
|
function renderLineShort(node) {
|
|
|
|
return !node.hasNextSibling && node.parentNode && (!node.parentNode.hasNextSibling || node.parentNode.hasNextSibling && !node.parentNode.children);
|
|
|
|
}
|
|
|
|
const nodeIconType = (node) => {
|
|
|
|
if (!props.showLine) {
|
|
|
|
if (node.children.length > 0) {
|
|
|
|
return "layui-tree-iconArrow ";
|
|
|
|
}
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
if (node.children.length !== 0) {
|
|
|
|
return !node.isLeaf ? "layui-icon-addition" : "layui-icon-subtraction";
|
|
|
|
}
|
2023-04-25 01:25:44 +00:00
|
|
|
if (props.hideicon) {
|
|
|
|
return "";
|
|
|
|
}
|
2022-11-14 03:59:26 +00:00
|
|
|
return "layui-icon-file";
|
|
|
|
};
|
|
|
|
function recursiveNodeClick(node) {
|
|
|
|
emit("node-click", node);
|
|
|
|
}
|
|
|
|
function handleChange(checked, node) {
|
2023-05-15 02:08:06 +00:00
|
|
|
props.tree.setCheckedKeys(checked, props.checkStrictly || props.selectParent, node);
|
2022-11-14 03:59:26 +00:00
|
|
|
}
|
|
|
|
function handleIconClick(node) {
|
|
|
|
node.isLeaf = !node.isLeaf;
|
|
|
|
}
|
|
|
|
function handleTitleClick(node) {
|
|
|
|
if (!props.onlyIconControl) {
|
|
|
|
handleIconClick(node);
|
|
|
|
}
|
|
|
|
if (!node.isDisabled) {
|
|
|
|
emit("node-click", node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function handleRowClick(node) {
|
|
|
|
if (!props.showLine) {
|
|
|
|
handleTitleClick(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
const isChildAllSelected = computed(() => {
|
|
|
|
function _isChildAllSelected(node) {
|
|
|
|
let childSelectNum = 0;
|
|
|
|
let res = false;
|
|
|
|
for (const item of node.children) {
|
|
|
|
if (item.isChecked)
|
|
|
|
childSelectNum++;
|
|
|
|
}
|
2023-05-15 03:34:14 +00:00
|
|
|
if (!props.selectParent) {
|
|
|
|
if (childSelectNum > 0)
|
|
|
|
node.isChecked = true;
|
|
|
|
}
|
2022-11-14 03:59:26 +00:00
|
|
|
if (childSelectNum == node.children.length) {
|
|
|
|
for (const item of node.children) {
|
|
|
|
res = _isChildAllSelected(item);
|
|
|
|
if (res)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
res = true;
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
return (node) => {
|
2023-05-12 08:22:05 +00:00
|
|
|
console.log(props.selectParent);
|
2022-11-14 03:59:26 +00:00
|
|
|
if (props.checkStrictly) {
|
|
|
|
return false;
|
2023-05-12 07:56:44 +00:00
|
|
|
} else if (props.selectParent) {
|
2022-11-14 03:59:26 +00:00
|
|
|
let res = _isChildAllSelected(node);
|
|
|
|
return res;
|
2023-05-12 07:56:44 +00:00
|
|
|
} else {
|
|
|
|
return false;
|
2022-11-14 03:59:26 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
});
|
|
|
|
return (_ctx, _cache) => {
|
|
|
|
const _component_tree_node = resolveComponent("tree-node", true);
|
|
|
|
return openBlock(true), createElementBlock(Fragment, null, renderList(__props.nodeList, (node, nodeIndex) => {
|
|
|
|
return openBlock(), createElementBlock("div", {
|
|
|
|
key: nodeIndex,
|
|
|
|
class: normalizeClass({
|
|
|
|
"layui-tree-set": true,
|
2023-04-25 00:42:38 +00:00
|
|
|
"layui-tree-setLineShort": renderLineShort(node),
|
|
|
|
"layui-tree-setHide": node.isRoot
|
2022-11-14 03:59:26 +00:00
|
|
|
})
|
|
|
|
}, [
|
|
|
|
createElementVNode("div", {
|
|
|
|
class: "layui-tree-entry",
|
|
|
|
onClick: ($event) => handleRowClick(node)
|
|
|
|
}, [
|
|
|
|
createElementVNode("div", _hoisted_2, [
|
|
|
|
createElementVNode("span", {
|
|
|
|
class: normalizeClass([
|
|
|
|
__props.showLine && node.children.length > 0 ? "layui-tree-icon" : "",
|
|
|
|
{ "layui-tree-iconClick": true }
|
|
|
|
])
|
|
|
|
}, [
|
|
|
|
createVNode(unref(_sfc_main$2E), {
|
|
|
|
type: nodeIconType(node),
|
|
|
|
onClick: withModifiers(($event) => handleIconClick(node), ["stop"])
|
|
|
|
}, null, 8, ["type", "onClick"])
|
|
|
|
], 2),
|
|
|
|
__props.showCheckbox ? (openBlock(), createBlock(_sfc_main$2, {
|
|
|
|
key: 0,
|
|
|
|
value: "",
|
|
|
|
skin: "primary",
|
|
|
|
modelValue: node.isChecked,
|
|
|
|
disabled: node.isDisabled,
|
|
|
|
isIndeterminate: unref(isChildAllSelected)(node),
|
|
|
|
onChange: (checked) => handleChange(checked, node)
|
|
|
|
}, null, 8, ["modelValue", "disabled", "isIndeterminate", "onChange"])) : createCommentVNode("", true),
|
|
|
|
createElementVNode("span", {
|
|
|
|
class: normalizeClass({
|
|
|
|
"layui-tree-txt": true,
|
|
|
|
"layui-disabled": node.isDisabled,
|
2023-05-18 00:17:29 +00:00
|
|
|
"layui-this": __props.selectedKey === node.id || node.isChecked
|
2022-11-14 03:59:26 +00:00
|
|
|
}),
|
|
|
|
onClick: withModifiers(($event) => handleTitleClick(node), ["stop"])
|
|
|
|
}, [
|
|
|
|
renderSlot(_ctx.$slots, "title", { data: node }, () => [
|
|
|
|
createTextVNode(toDisplayString(node.title), 1)
|
|
|
|
])
|
|
|
|
], 10, _hoisted_3)
|
|
|
|
])
|
|
|
|
], 8, _hoisted_1),
|
|
|
|
createVNode(_sfc_main$3, { enable: __props.collapseTransition }, {
|
|
|
|
default: withCtx(() => [
|
|
|
|
node.isLeaf ? (openBlock(), createElementBlock("div", _hoisted_4, [
|
|
|
|
createVNode(_component_tree_node, {
|
|
|
|
tree: __props.tree,
|
|
|
|
"node-list": node.children,
|
|
|
|
"show-checkbox": __props.showCheckbox,
|
|
|
|
"show-line": __props.showLine,
|
|
|
|
"selected-key": __props.selectedKey,
|
|
|
|
"collapse-transition": __props.collapseTransition,
|
|
|
|
checkStrictly: __props.checkStrictly,
|
|
|
|
"only-icon-control": __props.onlyIconControl,
|
2023-04-25 01:25:44 +00:00
|
|
|
hideicon: props.hideicon,
|
2023-05-12 07:56:44 +00:00
|
|
|
"select-parent": props.selectParent,
|
2022-11-14 03:59:26 +00:00
|
|
|
onNodeClick: recursiveNodeClick
|
|
|
|
}, createSlots({ _: 2 }, [
|
|
|
|
_ctx.$slots.title ? {
|
|
|
|
name: "title",
|
|
|
|
fn: withCtx((slotProp) => [
|
|
|
|
renderSlot(_ctx.$slots, "title", {
|
|
|
|
data: slotProp.data
|
|
|
|
})
|
|
|
|
]),
|
|
|
|
key: "0"
|
|
|
|
} : void 0
|
2023-05-12 07:56:44 +00:00
|
|
|
]), 1032, ["tree", "node-list", "show-checkbox", "show-line", "selected-key", "collapse-transition", "checkStrictly", "only-icon-control", "hideicon", "select-parent"])
|
2022-11-14 03:59:26 +00:00
|
|
|
])) : createCommentVNode("", true)
|
|
|
|
]),
|
|
|
|
_: 2
|
|
|
|
}, 1032, ["enable"])
|
|
|
|
], 2);
|
|
|
|
}), 128);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
class Tree {
|
|
|
|
constructor(config, origin) {
|
|
|
|
this.config = config;
|
|
|
|
this.treeData = [];
|
|
|
|
this.init(origin);
|
|
|
|
}
|
|
|
|
init(origin) {
|
|
|
|
const tree = this.createTree(origin);
|
|
|
|
this.treeData = tree;
|
|
|
|
}
|
|
|
|
createTree(origin, parentKey = "") {
|
|
|
|
let data;
|
|
|
|
if (!Array.isArray(origin)) {
|
|
|
|
data = Array.of(Object.assign({}, origin));
|
|
|
|
} else {
|
|
|
|
data = origin;
|
|
|
|
}
|
|
|
|
const nodeList = [];
|
|
|
|
const { children } = this.config.replaceFields;
|
|
|
|
const len = data.length;
|
|
|
|
for (let i = 0; i < len; i++) {
|
|
|
|
const node = this.getNode(data[i], parentKey, i < len - 1);
|
|
|
|
const nodeChildren = Reflect.get(node, children);
|
|
|
|
const nodeHasChildren = !!Reflect.get(node, children);
|
|
|
|
if (nodeHasChildren) {
|
|
|
|
Reflect.set(node, children, this.createTree(nodeChildren, node.id));
|
|
|
|
}
|
|
|
|
nodeList.push(node);
|
|
|
|
}
|
|
|
|
return nodeList;
|
|
|
|
}
|
|
|
|
getNode(origin, parentKey, hasNextSibling) {
|
|
|
|
const {
|
|
|
|
nodeMap,
|
|
|
|
originMap,
|
|
|
|
checkedKeys,
|
|
|
|
expandKeys,
|
|
|
|
checkStrictly,
|
|
|
|
replaceFields: { children, id, title }
|
|
|
|
} = this.config;
|
2023-05-15 01:44:23 +00:00
|
|
|
console.log(origin, "origin");
|
2022-11-14 03:59:26 +00:00
|
|
|
const nodeKey = Reflect.get(origin, id);
|
|
|
|
const nodeTitle = Reflect.get(origin, title);
|
|
|
|
const nodeChildren = Reflect.get(origin, children);
|
|
|
|
const nodeDisabled = !!Reflect.get(origin, "disabled");
|
|
|
|
const nodeIsLeaf = !!Reflect.get(origin, "spread");
|
|
|
|
const parentNode = nodeMap.get(parentKey);
|
|
|
|
const node = Object.assign({}, origin, {
|
|
|
|
id: nodeKey,
|
|
|
|
title: nodeTitle,
|
|
|
|
children: nodeChildren ? nodeChildren : [],
|
|
|
|
parentKey,
|
|
|
|
isRoot: parentKey === "",
|
|
|
|
isDisabled: false,
|
|
|
|
isChecked: false,
|
|
|
|
isLeaf: false,
|
|
|
|
hasNextSibling,
|
2023-05-15 01:51:49 +00:00
|
|
|
parentNode: parentNode || null
|
2022-11-14 03:59:26 +00:00
|
|
|
});
|
|
|
|
node.isDisabled = nodeDisabled;
|
|
|
|
node.isChecked = checkedKeys.includes(nodeKey);
|
|
|
|
node.isLeaf = parentNode ? parentNode.isLeaf : expandKeys.includes(nodeKey);
|
|
|
|
node.isLeaf = nodeIsLeaf;
|
|
|
|
if (!nodeMap.has(nodeKey)) {
|
|
|
|
nodeMap.set(nodeKey, node);
|
|
|
|
}
|
|
|
|
if (!originMap.has(nodeKey)) {
|
|
|
|
originMap.set(nodeKey, origin);
|
|
|
|
}
|
|
|
|
return node;
|
|
|
|
}
|
|
|
|
treeForeach(tree, func) {
|
|
|
|
tree.forEach((data) => {
|
|
|
|
data.children && this.treeForeach(data.children, func);
|
|
|
|
func(data);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
setChildrenChecked(checked, nodes) {
|
2023-05-15 03:02:44 +00:00
|
|
|
console.log("\u8D70\u8D4B\u503C\u5B50\u8282\u70B9\u4E86");
|
2022-11-14 03:59:26 +00:00
|
|
|
var ableCount = 0;
|
|
|
|
var checkCount = 0;
|
|
|
|
const len = nodes.length;
|
|
|
|
this.treeForeach(nodes, (node) => {
|
|
|
|
if (!node.isDisabled) {
|
|
|
|
ableCount = ableCount + 1;
|
|
|
|
if (node.isChecked) {
|
|
|
|
checkCount = checkCount + 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
checkCount < ableCount ? checked = true : checked = false;
|
|
|
|
for (let i = 0; i < len; i++) {
|
|
|
|
if (!nodes[i].isDisabled || nodes[i].isDisabled && nodes[i].children.length > 0) {
|
|
|
|
nodes[i].isChecked = checked;
|
|
|
|
}
|
|
|
|
nodes[i].children && nodes[i].children.length > 0 && this.setChildrenChecked(checked, nodes[i].children);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
setParentChecked(checked, parent) {
|
2023-05-15 03:02:44 +00:00
|
|
|
console.log("\u8D70\u8D4B\u503C\u7236\u8282\u70B9\u4E86");
|
2022-11-14 03:59:26 +00:00
|
|
|
if (!parent) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
parent.isChecked = checked;
|
|
|
|
const pChild = parent.children;
|
|
|
|
const pChildChecked = pChild.some((c) => c.isChecked);
|
|
|
|
if (pChildChecked) {
|
|
|
|
parent.isChecked = true;
|
|
|
|
}
|
|
|
|
if (parent.parentNode) {
|
|
|
|
this.setParentChecked(checked, parent.parentNode);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
setCheckedKeys(checked, checkStrictly, node) {
|
|
|
|
node.isChecked = checked;
|
2023-05-15 02:13:10 +00:00
|
|
|
console.log(node, checkStrictly, 186);
|
2022-11-14 03:59:26 +00:00
|
|
|
if (!checkStrictly) {
|
|
|
|
if (node.parentNode) {
|
|
|
|
this.setParentChecked(checked, node.parentNode);
|
|
|
|
}
|
|
|
|
if (node.children) {
|
|
|
|
this.setChildrenChecked(checked, node.children);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
getData() {
|
|
|
|
return this.treeData;
|
|
|
|
}
|
|
|
|
getKeys() {
|
|
|
|
const checkedKeys = [];
|
|
|
|
const expandKeys = [];
|
|
|
|
const iterator = this.config.nodeMap[Symbol.iterator]();
|
|
|
|
let next = iterator.next();
|
|
|
|
while (!next.done) {
|
|
|
|
const [, node] = next.value;
|
|
|
|
const id = Reflect.get(node, this.config.replaceFields.id);
|
|
|
|
if (node.isChecked) {
|
|
|
|
checkedKeys.push(id);
|
|
|
|
}
|
|
|
|
if (node.isLeaf) {
|
|
|
|
expandKeys.push(id);
|
|
|
|
}
|
|
|
|
next = iterator.next();
|
|
|
|
}
|
|
|
|
return { checkedKeys, expandKeys };
|
|
|
|
}
|
|
|
|
getOriginData(key) {
|
|
|
|
return this.config.originMap.get(key);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
const useTree = (props, emit) => {
|
|
|
|
var _a, _b, _c, _d;
|
|
|
|
const tree = new Tree({
|
|
|
|
nodeMap: /* @__PURE__ */ new Map(),
|
|
|
|
originMap: /* @__PURE__ */ new Map(),
|
|
|
|
replaceFields: {
|
|
|
|
id: "id",
|
|
|
|
title: "title",
|
|
|
|
children: "children"
|
|
|
|
},
|
|
|
|
showCheckbox: (_a = props.showCheckbox) != null ? _a : false,
|
|
|
|
checkedKeys: (_b = props.checkedKeys) != null ? _b : [],
|
|
|
|
expandKeys: (_c = props.expandKeys) != null ? _c : [],
|
|
|
|
checkStrictly: (_d = props.checkStrictly) != null ? _d : false
|
|
|
|
}, props.data);
|
|
|
|
const nodeList = computed(() => {
|
|
|
|
const nodes = tree.getData();
|
|
|
|
return nodes;
|
|
|
|
});
|
|
|
|
return {
|
|
|
|
tree,
|
|
|
|
nodeList
|
|
|
|
};
|
|
|
|
};
|
2022-12-12 01:08:28 +00:00
|
|
|
var index = /* @__PURE__ */ (() => '.layui-checkbox[size=lg]{height:18px;line-height:18px}.layui-checkbox[size=lg] .layui-form-checkbox[lay-skin=primary] .layui-icon{width:18px;height:18px;font-size:16px}.layui-checkbox[size=lg] .layui-form-checkbox[lay-skin=primary] .layui-checkbox-label{height:18px;line-height:18px;font-size:16px}.layui-checkbox[size=md]{height:16px;line-height:16px}.layui-checkbox[size=md] .layui-form-checkbox[lay-skin=primary] .layui-icon{width:16px;height:16px;font-size:14px}.layui-checkbox[size=md] .layui-form-checkbox[lay-skin=primary] .layui-checkbox-label{height:16px;line-height:16px;font-size:14px}.layui-checkbox[size=sm]{height:14px;line-height:14px}.layui-checkbox[size=sm] .layui-form-checkbox[lay-skin=primary] .layui-icon{width:14px;height:14px;font-size:12px}.layui-checkbox[size=sm] .layui-form-checkbox[lay-skin=primary] .layui-checkbox-label{height:14px;line-height:14px;font-size:12px}.layui-checkbox[size=xs]{height:12px;line-height:12px}.layui-checkbox[size=xs] .layui-form-checkbox[lay-skin=primary] .layui-icon{width:12px;height:12px;font-size:10px}.layui-checkbox[size=xs] .layui-form-checkbox[lay-skin=primary] .layui-checkbox-label{height:12px;line-height:12px;font-size:10px}.layui-checkbox input[type=checkbox]{display:none}.layui-form-checkbox{position:relative;height:30px;line-height:30px;margin-right:10px;padding-right:30px;cursor:pointer;font-size:0;-webkit-transition:.1s linear;transition:.1s linear;box-sizing:border-box}.layui-form-checkbox span{padding:0 10px;height:100%;font-size:14px;border-radius:2px 0 0 2px;background-color:var(--global-neutral-color-6);color:#fff;overflow:hidden}.layui-form-checkbox:hover span{background-color:var(--global-neutral-color-8)}.layui-form-checkbox i{top:0;right:0;width:29px;height:28px;position:absolute;border-top:1px solid var(--global-neutral-color-6);border-bottom:1px solid var(--global-neutral-color-6);border-right:1px solid var(--global-neutral-color-6);border-radius:0 2px 2px 0;color:#fff;font-size:20px;text-align:center}.layui-form-checkbox:hover i{border-color:var(--global-neutral-color-8);color:var(--global-neutral-color-8)}.layui-form-checkbox[lay-skin=primary]{height:auto!important;line-height:normal!important;min-width:18px;min-height:18px;border:none!important;margin-right:0;padding-left:28px;padding-right:0;background:0 0}.layui-form-checkbox[lay-skin=primary] span{padding-left:0;padding-right:15px;line-height:18px;background:0 0;color:#666}.layui-form-checkbox[lay-skin=primary] i{right:auto;left:0;width:16px;height:16px;line-height:16px;border:1px solid var(--global-neutral-color-6);font-size:12px;border-radius:2px;background-color:#fff;-webkit-transition:.1s linear;transition:.1s linear}.layui-form-checkbox[lay-skin=primary]:hover i{border-color:var(--global-checked-color);color:#fff}.layui-form-checked,.layui-form-checked:hover{border-color:var(--global-checked-color)}.layui-form-checked i,.layui-form-checked:hover i{color:var(--global-checked-color)}.layui-form-checked span,.layui-form-checked:hover span{background-color:var(--global-checked-color)}.layui-form-checked[lay-skin=primary] i{border-color:var(--global-checked-color);background-color:var(--global-checked-color);color:#fff}.layui-form-checked[lay-skin=primary] span{background:0 0!important}.layui-checkbox-disabled[lay-skin=primary] span{background:0 0!important;color:var(--global-neutral-color-8)!important}.layui-checkbox-disabled[lay-skin=primary]:hover i{border-color:var(--global-neutral-color-6)}.layui-checkbox-disabled,.layui-checkbox-disabled i{border-color:var(--global-neutral-color-3)!important}.layui-checkbox-disabled span{background-color:var(--global-neutral-color-3)!important}.layui-checkbox-disabled em{color:var(--global-neutral-color-6)!important}.layui-checkbox-disabled:hover i{color:#fff!important}.layui-checkbox-disabled .layui-icon-ok,.layui-checkbox-disabled .layui-icon-subtraction{background-color:var(--global-neutral-color-3)!important;border-color:var(--global-neutral-color-3)!important}.layui-tree{line-height:22px}.layui-tree .layui-form-checkbox
|
2022-11-14 03:59:26 +00:00
|
|
|
const __default__ = {
|
|
|
|
name: "LayTree"
|
|
|
|
};
|
|
|
|
const _sfc_main = defineComponent({
|
|
|
|
...__default__,
|
|
|
|
props: {
|
|
|
|
data: null,
|
|
|
|
disabled: { type: Boolean, default: false },
|
|
|
|
edit: { default: false },
|
|
|
|
checkedKeys: { default: () => {
|
|
|
|
return [];
|
|
|
|
} },
|
|
|
|
checkStrictly: { type: [Boolean, String], default: false },
|
|
|
|
collapseTransition: { type: Boolean, default: true },
|
|
|
|
onlyIconControl: { type: Boolean, default: false },
|
|
|
|
selectedKey: null,
|
|
|
|
showLine: { type: Boolean, default: true },
|
|
|
|
showCheckbox: { type: Boolean, default: false },
|
|
|
|
replaceFields: { default: () => {
|
|
|
|
return {
|
|
|
|
id: "id",
|
|
|
|
children: "children",
|
|
|
|
title: "title"
|
|
|
|
};
|
2023-04-25 01:25:44 +00:00
|
|
|
} },
|
2023-05-12 07:56:44 +00:00
|
|
|
hideicon: { type: Boolean },
|
2023-05-15 01:12:50 +00:00
|
|
|
selectParent: { type: Boolean, default: false }
|
2022-11-14 03:59:26 +00:00
|
|
|
},
|
|
|
|
emits: ["update:checkedKeys", "update:expandKeys", "node-click"],
|
|
|
|
setup(__props, { emit }) {
|
|
|
|
const props = __props;
|
|
|
|
useSlots();
|
|
|
|
const className = computed(() => {
|
|
|
|
return {
|
|
|
|
"layui-tree": true,
|
|
|
|
"layui-form": props.showCheckbox,
|
|
|
|
"layui-tree-line": props.showLine
|
|
|
|
};
|
|
|
|
});
|
|
|
|
let tree = ref();
|
|
|
|
let nodeList = ref();
|
|
|
|
const unWatch = ref(false);
|
|
|
|
const initStatus = ref(false);
|
|
|
|
const loadNodeList = () => {
|
|
|
|
let { tree: _tree, nodeList: _nodeList } = useTree(props);
|
|
|
|
tree.value = _tree;
|
|
|
|
nodeList.value = _nodeList.value;
|
|
|
|
};
|
|
|
|
watch(() => props.data, () => {
|
|
|
|
loadNodeList();
|
|
|
|
}, { deep: true, immediate: true });
|
|
|
|
watch(() => props.checkedKeys, () => {
|
|
|
|
if (!unWatch.value) {
|
|
|
|
loadNodeList();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
watch(tree, () => {
|
|
|
|
if (initStatus.value) {
|
|
|
|
const { checkedKeys } = tree.value.getKeys();
|
|
|
|
unWatch.value = true;
|
|
|
|
emit("update:checkedKeys", checkedKeys);
|
|
|
|
setTimeout(() => {
|
|
|
|
unWatch.value = false;
|
|
|
|
}, 0);
|
|
|
|
}
|
|
|
|
}, { deep: true });
|
|
|
|
onMounted(() => {
|
|
|
|
nextTick(() => {
|
|
|
|
initStatus.value = true;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
function handleClick(node) {
|
|
|
|
const originNode = tree.value.getOriginData(node.id);
|
|
|
|
emit("node-click", originNode);
|
|
|
|
}
|
|
|
|
return (_ctx, _cache) => {
|
|
|
|
return openBlock(), createElementBlock("div", {
|
|
|
|
class: normalizeClass(unref(className))
|
|
|
|
}, [
|
|
|
|
createVNode(_sfc_main$1, {
|
|
|
|
tree: unref(tree),
|
|
|
|
"node-list": unref(nodeList),
|
|
|
|
"show-checkbox": __props.showCheckbox,
|
|
|
|
"show-line": __props.showLine,
|
|
|
|
selectedKey: __props.selectedKey,
|
|
|
|
"check-strictly": __props.checkStrictly,
|
|
|
|
"collapse-transition": __props.collapseTransition,
|
|
|
|
"only-icon-control": __props.onlyIconControl,
|
2023-04-25 01:25:44 +00:00
|
|
|
onNodeClick: handleClick,
|
2023-05-12 07:56:44 +00:00
|
|
|
hideicon: props.hideicon,
|
|
|
|
selectParent: props.selectParent
|
2022-11-14 03:59:26 +00:00
|
|
|
}, createSlots({ _: 2 }, [
|
|
|
|
_ctx.$slots.title ? {
|
|
|
|
name: "title",
|
|
|
|
fn: withCtx(({ data }) => [
|
|
|
|
renderSlot(_ctx.$slots, "title", { data })
|
|
|
|
]),
|
|
|
|
key: "0"
|
|
|
|
} : void 0
|
2023-05-12 07:56:44 +00:00
|
|
|
]), 1032, ["tree", "node-list", "show-checkbox", "show-line", "selectedKey", "check-strictly", "collapse-transition", "only-icon-control", "hideicon", "selectParent"])
|
2022-11-14 03:59:26 +00:00
|
|
|
], 2);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
const component = withInstall(_sfc_main);
|
|
|
|
export { component as default };
|