bkui-vue 0.0.1-beta.75 → 0.0.1-beta.78

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.esm.js CHANGED
@@ -8818,6 +8818,7 @@ const buttonProps = {
8818
8818
  loadingMode: PropTypes.commonType(Object.values(BkLoadingMode)),
8819
8819
  outline: PropTypes.bool,
8820
8820
  text: PropTypes.bool,
8821
+ circle: PropTypes.bool,
8821
8822
  nativeType: {
8822
8823
  type: String
8823
8824
  }
@@ -8844,6 +8845,7 @@ var Component$u = defineComponent({
8844
8845
  "is-disabled": props.disabled,
8845
8846
  "is-outline": props.outline,
8846
8847
  "is-text": isText.value,
8848
+ "is-circle": props.circle,
8847
8849
  [`${btnClsPrefix}-${props.size}`]: props.size && btnSizes.includes(props.size),
8848
8850
  "no-slot": !showSlot
8849
8851
  }, `${themeCls} ${btnClsPrefix} ${hoverTheme}`);
@@ -9947,7 +9949,7 @@ var permissions = "
9947
9949
  var notFound = "";
9948
9950
  var maintain = "";
9949
9951
  var Building = "";
9950
- var empty$1 = "";
9952
+ var empty = "";
9951
9953
  var login = "";
9952
9954
  var searchEmpty = "";
9953
9955
  var Component$n = defineComponent({
@@ -9974,7 +9976,7 @@ var Component$n = defineComponent({
9974
9976
  404: notFound,
9975
9977
  500: maintain,
9976
9978
  building: Building,
9977
- empty: empty$1,
9979
+ empty,
9978
9980
  "search-empty": searchEmpty,
9979
9981
  login
9980
9982
  };
@@ -12737,6 +12739,34 @@ var Component$a = defineComponent({
12737
12739
  });
12738
12740
  const BkVirtualRender = withInstall(Component$a);
12739
12741
  const BORDER_OPRIONS = ["none", "row", "col", "outer"];
12742
+ var EVENTS$1 = /* @__PURE__ */ ((EVENTS2) => {
12743
+ EVENTS2["ON_SORT_BY_CLICK"] = "onSortByClick";
12744
+ EVENTS2["ON_FILTER_CLICK"] = "onFilterClick";
12745
+ EVENTS2["ON_SETTING_CHANGE"] = "onSettingChange";
12746
+ return EVENTS2;
12747
+ })(EVENTS$1 || {});
12748
+ var EMITEVENTS = /* @__PURE__ */ ((EMITEVENTS2) => {
12749
+ EMITEVENTS2["COLUMN_PICK"] = "columnPick";
12750
+ EMITEVENTS2["COLUMN_SORT"] = "columnSort";
12751
+ EMITEVENTS2["COLUMN_FILTER"] = "columnFilter";
12752
+ EMITEVENTS2["ROW_CLICK"] = "rowClick";
12753
+ EMITEVENTS2["ROW_DBL_CLICK"] = "rowDblClick";
12754
+ EMITEVENTS2["PAGE_LIMIT_CHANGE"] = "pageLimitChange";
12755
+ EMITEVENTS2["PAGE_VALUE_CHANGE"] = "pageValueChange";
12756
+ EMITEVENTS2["SETTING_CHANGE"] = "settingChange";
12757
+ return EMITEVENTS2;
12758
+ })(EMITEVENTS || {});
12759
+ const EMPTY$1 = (..._args) => true;
12760
+ const EMIT_EVENT_TYPES = {
12761
+ ["columnPick"]: EMPTY$1,
12762
+ ["columnFilter"]: EMPTY$1,
12763
+ ["columnSort"]: EMPTY$1,
12764
+ ["rowClick"]: EMPTY$1,
12765
+ ["rowDblClick"]: EMPTY$1,
12766
+ ["pageLimitChange"]: EMPTY$1,
12767
+ ["pageValueChange"]: EMPTY$1,
12768
+ ["settingChange"]: EMPTY$1
12769
+ };
12740
12770
  const resolvePropVal = (prop, key, args) => {
12741
12771
  if (Object.prototype.hasOwnProperty.call(prop, key)) {
12742
12772
  if (typeof prop[key] === "function") {
@@ -13120,6 +13150,7 @@ var userPagination = (props) => {
13120
13150
  current: 1
13121
13151
  });
13122
13152
  pagination2 = resolvePaginationOption(props.pagination, pagination2);
13153
+ const localPagination = ref(null);
13123
13154
  const resetStartEndIndex = () => {
13124
13155
  if (!props.pagination || props.remotePagination) {
13125
13156
  startIndex.value = 0;
@@ -13148,17 +13179,18 @@ var userPagination = (props) => {
13148
13179
  };
13149
13180
  const watchEffectFn = (filterFn, sortFn) => {
13150
13181
  pagination2 = resolvePaginationOption(props.pagination, pagination2);
13182
+ resolveLocalPagination();
13151
13183
  resetStartEndIndex();
13152
13184
  resolvePageData(filterFn, sortFn);
13153
13185
  };
13154
- const localPagination = computed(() => {
13186
+ const resolveLocalPagination = () => {
13155
13187
  if (!props.pagination) {
13156
- return null;
13188
+ return;
13157
13189
  }
13158
- return props.remotePagination ? pagination2 : __spreadProps(__spreadValues({}, pagination2), {
13190
+ localPagination.value = props.remotePagination ? pagination2 : __spreadProps(__spreadValues({}, pagination2), {
13159
13191
  count: props.data.length
13160
13192
  });
13161
- });
13193
+ };
13162
13194
  return {
13163
13195
  pageData,
13164
13196
  localPagination,
@@ -13184,14 +13216,22 @@ const tableProps = {
13184
13216
  PropTypes.bool,
13185
13217
  PropTypes.commonType(["left", "right"], "fixed")
13186
13218
  ]).def(false),
13187
- sort: PropTypes.oneOfType([PropTypes.shape({
13188
- sortFn: PropTypes.func.def(void 0),
13189
- sortScope: PropTypes.commonType(Object.values(SortScope)).def("current")
13190
- }), PropTypes.bool]).def(false),
13191
- filter: PropTypes.oneOfType([PropTypes.shape({
13192
- list: PropTypes.arrayOf(PropTypes.any).def([]),
13193
- filterFn: PropTypes.func.def(void 0)
13194
- }), PropTypes.bool]).def(false)
13219
+ sort: PropTypes.oneOfType([
13220
+ PropTypes.shape({
13221
+ sortFn: PropTypes.func.def(void 0),
13222
+ sortScope: PropTypes.commonType(Object.values(SortScope)).def("current")
13223
+ }),
13224
+ PropTypes.bool,
13225
+ PropTypes.string
13226
+ ]).def(false),
13227
+ filter: PropTypes.oneOfType([
13228
+ PropTypes.shape({
13229
+ list: PropTypes.arrayOf(PropTypes.any).def([]),
13230
+ filterFn: PropTypes.func.def(void 0)
13231
+ }),
13232
+ PropTypes.bool,
13233
+ PropTypes.string
13234
+ ]).def(false)
13195
13235
  })),
13196
13236
  activeColumn: PropTypes.oneOfType([PropTypes.number.def(-1), PropTypes.arrayOf(PropTypes.number.def(-1))]),
13197
13237
  columnPick: PropTypes.commonType(["multi", "single", "disabled"], "columnPick").def("disabled"),
@@ -13738,6 +13778,11 @@ var HeadFilter = defineComponent({
13738
13778
  });
13739
13779
  const filterFn = typeof column.filter.filterFn === "function" ? (checked, row, index, data2) => column.filter.filterFn(checked, row, props.column, index, data2) : (checked, row) => checked.length ? checked.includes(getRowText(row, resolvePropVal(column, "field", [column, row]), column)) : true;
13740
13780
  const handleBtnSaveClick = () => {
13781
+ if (props.column.filter === "custom") {
13782
+ emit("change", [...state.checked], null);
13783
+ isShow.value = false;
13784
+ return;
13785
+ }
13741
13786
  emit("change", [...state.checked], filterFn);
13742
13787
  isShow.value = false;
13743
13788
  };
@@ -13818,6 +13863,10 @@ var HeadSort = defineComponent({
13818
13863
  e.stopPropagation();
13819
13864
  e.preventDefault();
13820
13865
  sortType.value = type;
13866
+ if (props.column.sort === "custom") {
13867
+ emit("change", null, type);
13868
+ return;
13869
+ }
13821
13870
  const fieldName = props.column.field;
13822
13871
  const getVal = (row) => getRowText(row, fieldName, props.column);
13823
13872
  const sortFn0 = (a2, b2) => {
@@ -14016,12 +14065,6 @@ var Settings = defineComponent({
14016
14065
  });
14017
14066
  }
14018
14067
  });
14019
- let EVENTS$1;
14020
- (function(EVENTS2) {
14021
- EVENTS2["ON_SORT_BY_CLICK"] = "onSortByClick";
14022
- EVENTS2["ON_FILTER_CLICK"] = "onFilterClick";
14023
- EVENTS2["ON_SETTING_CHANGE"] = "onSettingChange";
14024
- })(EVENTS$1 || (EVENTS$1 = {}));
14025
14068
  class TableRender {
14026
14069
  constructor(props, ctx, reactiveProp, colgroups) {
14027
14070
  __publicField(this, "getRowHeight", (row, rowIndex) => {
@@ -14394,7 +14437,7 @@ const useClass = (props, root, reactiveProp) => {
14394
14437
  var Component$8 = defineComponent({
14395
14438
  name: "Table",
14396
14439
  props: tableProps,
14397
- emits: ["columnPick", "rowClick", "rowDblClick", "pageLimitChange", "pageValueChange"],
14440
+ emits: EMIT_EVENT_TYPES,
14398
14441
  setup(props, ctx) {
14399
14442
  const colgroups = reactive(props.columns.map((col) => __spreadProps(__spreadValues({}, col), {
14400
14443
  calcWidth: null,
@@ -14439,6 +14482,7 @@ var Component$8 = defineComponent({
14439
14482
  contentStyle,
14440
14483
  headStyle,
14441
14484
  updateBorderClass,
14485
+ resetTableHeight,
14442
14486
  hasFooter
14443
14487
  } = useClass(props, root, reactiveProp);
14444
14488
  const {
@@ -14446,32 +14490,62 @@ var Component$8 = defineComponent({
14446
14490
  fixedWrapperClass
14447
14491
  } = useFixedColumn(props, colgroups);
14448
14492
  const tableRender = new TableRender(props, ctx, reactiveProp, colgroups);
14449
- watch(() => [props.data], () => {
14493
+ watch(() => [props.data, props.pagination], () => {
14450
14494
  watchEffectFn(columnFilterFn, columnSortFn);
14451
- nextTick(() => updateBorderClass(root.value));
14495
+ nextTick(() => {
14496
+ resetTableHeight(root.value);
14497
+ updateBorderClass(root.value);
14498
+ });
14452
14499
  }, {
14453
14500
  immediate: true,
14454
14501
  deep: true
14455
14502
  });
14456
14503
  tableRender.on(EVENTS$1.ON_SORT_BY_CLICK, (args) => {
14457
14504
  const {
14458
- sortFn
14505
+ sortFn,
14506
+ column,
14507
+ index,
14508
+ type
14459
14509
  } = args;
14460
- columnSortFn = sortFn;
14461
- pageData.sort(columnSortFn);
14510
+ if (typeof sortFn === "function") {
14511
+ columnSortFn = sortFn;
14512
+ pageData.sort(columnSortFn);
14513
+ }
14514
+ ctx.emit(EMITEVENTS.COLUMN_SORT, {
14515
+ column,
14516
+ index,
14517
+ type
14518
+ });
14462
14519
  }).on(EVENTS$1.ON_FILTER_CLICK, (args) => {
14463
14520
  const {
14464
- filterFn
14521
+ filterFn,
14522
+ checked,
14523
+ column,
14524
+ index
14465
14525
  } = args;
14466
- columnFilterFn = filterFn;
14467
- resolvePageData(columnFilterFn, columnSortFn);
14526
+ if (typeof filterFn === "function") {
14527
+ columnFilterFn = filterFn;
14528
+ resolvePageData(columnFilterFn, columnSortFn);
14529
+ }
14530
+ ctx.emit(EMITEVENTS.COLUMN_FILTER, {
14531
+ checked,
14532
+ column,
14533
+ index
14534
+ });
14468
14535
  }).on(EVENTS$1.ON_SETTING_CHANGE, (args) => {
14469
14536
  var _a, _b;
14470
14537
  const {
14471
- checked = []
14538
+ checked = [],
14539
+ size,
14540
+ height
14472
14541
  } = args;
14473
14542
  checked.length && resolveColumnWidth(root.value, colgroups, 20);
14474
14543
  (_b = (_a = refVirtualRender.value) == null ? void 0 : _a.reset) == null ? void 0 : _b.call(_a);
14544
+ ctx.emit(EMITEVENTS.SETTING_CHANGE, {
14545
+ checked,
14546
+ size,
14547
+ height
14548
+ });
14475
14549
  });
14476
14550
  const handleScrollChanged = (args) => {
14477
14551
  const pagination2 = args[1];
@@ -21065,12 +21139,11 @@ var EVENTS = /* @__PURE__ */ ((EVENTS2) => {
21065
21139
  EVENTS2["NODE_EXPAND"] = "nodeExpand";
21066
21140
  return EVENTS2;
21067
21141
  })(EVENTS || {});
21068
- const empty = () => {
21069
- };
21142
+ const EMPTY = (..._args) => true;
21070
21143
  const TreeEmitEventsType = {
21071
- ["nodeClick"]: empty,
21072
- ["nodeCollapse"]: empty,
21073
- ["nodeExpand"]: empty
21144
+ ["nodeClick"]: EMPTY,
21145
+ ["nodeCollapse"]: EMPTY,
21146
+ ["nodeExpand"]: EMPTY
21074
21147
  };
21075
21148
  var NODE_ATTRIBUTES = /* @__PURE__ */ ((NODE_ATTRIBUTES2) => {
21076
21149
  NODE_ATTRIBUTES2["DEPTH"] = "__depth";
@@ -21081,7 +21154,7 @@ var NODE_ATTRIBUTES = /* @__PURE__ */ ((NODE_ATTRIBUTES2) => {
21081
21154
  NODE_ATTRIBUTES2["PATH"] = "__path";
21082
21155
  NODE_ATTRIBUTES2["IS_ROOT"] = "__is_root";
21083
21156
  NODE_ATTRIBUTES2["ORDER"] = "__order";
21084
- NODE_ATTRIBUTES2["IS_OPENED"] = "__is_open";
21157
+ NODE_ATTRIBUTES2["IS_OPEN"] = "__is_open";
21085
21158
  NODE_ATTRIBUTES2["IS_CHECKED"] = "__is_checked";
21086
21159
  NODE_ATTRIBUTES2["IS_SELECTED"] = "__is_selected";
21087
21160
  NODE_ATTRIBUTES2["IS_ASYNC_INIT"] = "__is_async_init";
@@ -21090,6 +21163,7 @@ var NODE_ATTRIBUTES = /* @__PURE__ */ ((NODE_ATTRIBUTES2) => {
21090
21163
  NODE_ATTRIBUTES2["IS_CACHED"] = "__is_cached";
21091
21164
  NODE_ATTRIBUTES2["IS_ASYNC"] = "__is_async";
21092
21165
  NODE_ATTRIBUTES2["IS_LOADING"] = "__is_loading";
21166
+ NODE_ATTRIBUTES2["TREE_NODE_ATTR"] = "__attr__";
21093
21167
  return NODE_ATTRIBUTES2;
21094
21168
  })(NODE_ATTRIBUTES || {});
21095
21169
  const NODE_SOURCE_ATTRS = {
@@ -21099,7 +21173,8 @@ const NODE_SOURCE_ATTRS = {
21099
21173
  ["__has_child"]: "hasChild",
21100
21174
  ["__is_checked"]: "checked",
21101
21175
  ["__is_async"]: "async",
21102
- ["__is_loading"]: "loading"
21176
+ ["__is_loading"]: "loading",
21177
+ ["__is_root"]: "isRoot"
21103
21178
  };
21104
21179
  const treeProps = {
21105
21180
  data: PropTypes.arrayOf(PropTypes.any).def([]),
@@ -21148,8 +21223,7 @@ const treeProps = {
21148
21223
  dragSort: PropTypes.bool.def(false),
21149
21224
  selectable: PropTypes.bool.def(true),
21150
21225
  selected: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.object]).def(null),
21151
- autoCheckChildren: PropTypes.bool.def(true),
21152
- syncAction: PropTypes.bool.def(false)
21226
+ autoCheckChildren: PropTypes.bool.def(true)
21153
21227
  };
21154
21228
  var useEmpty = (props, {
21155
21229
  slots
@@ -21164,6 +21238,103 @@ var useEmpty = (props, {
21164
21238
  }
21165
21239
  })
21166
21240
  });
21241
+ var useNodeAttribute = (flatData, props) => {
21242
+ const getSchemaVal2 = (key) => flatData.schema.get(key);
21243
+ const getNodeAttr2 = (node, attr) => {
21244
+ var _a;
21245
+ return (_a = getSchemaVal2(node[NODE_ATTRIBUTES.UUID])) == null ? void 0 : _a[attr];
21246
+ };
21247
+ const setNodeAttr = (node, attr, val) => {
21248
+ flatData.schema.set(node[NODE_ATTRIBUTES.UUID], __spreadProps(__spreadValues({}, getSchemaVal2(node[NODE_ATTRIBUTES.UUID])), {
21249
+ [attr]: val
21250
+ }));
21251
+ };
21252
+ const getNodePath = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.PATH);
21253
+ const getNodeId = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.UUID);
21254
+ const isRootNode = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_ROOT);
21255
+ const isNodeOpened = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_OPEN);
21256
+ const hasChildNode = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.HAS_CHILD);
21257
+ const isNodeMatched = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_MATCH);
21258
+ const isNodeChecked = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_CHECKED);
21259
+ const getNodeParentId = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.PARENT_ID);
21260
+ const getNodeParentIdById = (id) => getNodeAttr2({
21261
+ [NODE_ATTRIBUTES.UUID]: id
21262
+ }, NODE_ATTRIBUTES.PARENT_ID);
21263
+ const isNodeLoading = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_LOADING);
21264
+ const setTreeNodeLoading = (node, value) => {
21265
+ setNodeAttr(node, NODE_ATTRIBUTES.IS_LOADING, value);
21266
+ };
21267
+ const deleteNodeSchema = (id) => flatData.schema.delete(id);
21268
+ const isItemOpen = (item) => {
21269
+ var _a;
21270
+ if (typeof item === "object") {
21271
+ return isNodeOpened(item);
21272
+ }
21273
+ if (typeof item === "string") {
21274
+ return (_a = getSchemaVal2(item)) == null ? void 0 : _a[NODE_ATTRIBUTES.IS_OPEN];
21275
+ }
21276
+ return false;
21277
+ };
21278
+ const checkNodeIsOpen = (node) => isRootNode(node) || isItemOpen(node) || isItemOpen(getNodeAttr2(node, NODE_ATTRIBUTES.PARENT_ID));
21279
+ const getSourceNodeByPath = (path) => {
21280
+ const paths = path.split("-");
21281
+ return paths.reduce((pre, nodeIndex) => {
21282
+ const index = Number(nodeIndex);
21283
+ return Array.isArray(pre) ? pre[index] : pre[props.children][index];
21284
+ }, props.data);
21285
+ };
21286
+ const getSourceNodeByUID = (uid) => getSourceNodeByPath(getNodePath({
21287
+ [NODE_ATTRIBUTES.UUID]: uid
21288
+ }));
21289
+ const getParentNodeData = (uid) => {
21290
+ if (isRootNode({
21291
+ [NODE_ATTRIBUTES.UUID]: uid
21292
+ })) {
21293
+ return {
21294
+ [props.children]: props.data
21295
+ };
21296
+ }
21297
+ return getSourceNodeByUID(getNodeParentIdById(uid));
21298
+ };
21299
+ const resolveScopedSlotParam = (item) => ({
21300
+ [NODE_SOURCE_ATTRS[NODE_ATTRIBUTES.IS_LOADING]]: getNodeAttr2(item, NODE_ATTRIBUTES.IS_LOADING),
21301
+ [NODE_SOURCE_ATTRS[NODE_ATTRIBUTES.HAS_CHILD]]: hasChildNode(item),
21302
+ [NODE_SOURCE_ATTRS[NODE_ATTRIBUTES.IS_MATCH]]: isNodeMatched(item),
21303
+ [NODE_SOURCE_ATTRS[NODE_ATTRIBUTES.IS_CHECKED]]: isNodeChecked(item),
21304
+ [NODE_SOURCE_ATTRS[NODE_ATTRIBUTES.IS_OPEN]]: isNodeOpened(item),
21305
+ [NODE_SOURCE_ATTRS[NODE_ATTRIBUTES.IS_ROOT]]: isRootNode(item),
21306
+ fullPath: getNodeAttr2(item, NODE_ATTRIBUTES.PATH),
21307
+ uuid: getNodeId(item),
21308
+ parentId: getNodeAttr2(item, NODE_ATTRIBUTES.PARENT_ID)
21309
+ });
21310
+ const extendNodeAttr = (item) => __spreadProps(__spreadValues({}, item), {
21311
+ [NODE_ATTRIBUTES.TREE_NODE_ATTR]: resolveScopedSlotParam(item)
21312
+ });
21313
+ return {
21314
+ getSchemaVal: getSchemaVal2,
21315
+ getNodeAttr: getNodeAttr2,
21316
+ getNodeId,
21317
+ getNodeParentId,
21318
+ getNodeParentIdById,
21319
+ getParentNodeData,
21320
+ setNodeAttr,
21321
+ getNodePath,
21322
+ isRootNode,
21323
+ isNodeOpened,
21324
+ hasChildNode,
21325
+ isItemOpen,
21326
+ isNodeChecked,
21327
+ isNodeMatched,
21328
+ isNodeLoading,
21329
+ checkNodeIsOpen,
21330
+ getSourceNodeByPath,
21331
+ getSourceNodeByUID,
21332
+ deleteNodeSchema,
21333
+ resolveScopedSlotParam,
21334
+ setTreeNodeLoading,
21335
+ extendNodeAttr
21336
+ };
21337
+ };
21167
21338
  const DEFAULT_LEVLE_LINE = "1px dashed #c3cdd7";
21168
21339
  const getPropsOneOfBoolValueWithDefault = (props, key, item = null, defaultTrueValue = null, defaultFalseValue = null, args = []) => {
21169
21340
  const prop = props[key];
@@ -21261,136 +21432,32 @@ const resolveNodeItem = (node) => {
21261
21432
  console.error("setNodeAction Error: node id cannot found");
21262
21433
  return node;
21263
21434
  };
21264
- var useNodeAttribute = (flatData, props) => {
21265
- const getSchemaVal2 = (key) => flatData.schema.get(key);
21266
- const getNodeAttr2 = (node, attr) => {
21267
- var _a;
21268
- return (_a = getSchemaVal2(node[NODE_ATTRIBUTES.UUID])) == null ? void 0 : _a[attr];
21269
- };
21270
- const setNodeAttr = (node, attr, val) => {
21271
- if (props.syncAction && NODE_SOURCE_ATTRS[attr] !== void 0) {
21272
- updateTreeNode(getNodePath(node), props.data, props.children, NODE_SOURCE_ATTRS[attr], val);
21273
- }
21274
- flatData.schema.set(node[NODE_ATTRIBUTES.UUID], __spreadProps(__spreadValues({}, getSchemaVal2(node[NODE_ATTRIBUTES.UUID])), {
21275
- [attr]: val
21276
- }));
21277
- };
21278
- const getNodePath = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.PATH);
21279
- const getNodeId = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.UUID);
21280
- const isRootNode = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_ROOT);
21281
- const isNodeOpened = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_OPENED);
21282
- const hasChildNode = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.HAS_CHILD);
21283
- const isNodeMatched = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_MATCH);
21284
- const isNodeChecked = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_CHECKED);
21285
- const getNodeParentId = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.PARENT_ID);
21286
- const getNodeParentIdById = (id) => getNodeAttr2({
21287
- [NODE_ATTRIBUTES.UUID]: id
21288
- }, NODE_ATTRIBUTES.PARENT_ID);
21289
- const isNodeLoading = (node) => getNodeAttr2(node, NODE_ATTRIBUTES.IS_LOADING);
21290
- const setTreeNodeLoading = (node, value) => {
21291
- setNodeAttr(node, NODE_ATTRIBUTES.IS_LOADING, value);
21292
- if (!props.syncAction) {
21293
- updateTreeNode(getNodePath(node), props.data, props.children, NODE_ATTRIBUTES.IS_LOADING, value);
21294
- }
21295
- };
21296
- const deleteNodeSchema = (id) => flatData.schema.delete(id);
21297
- const isItemOpen = (item) => {
21298
- var _a;
21299
- if (typeof item === "object") {
21300
- return isNodeOpened(item);
21301
- }
21302
- if (typeof item === "string") {
21303
- return (_a = getSchemaVal2(item)) == null ? void 0 : _a[NODE_ATTRIBUTES.IS_OPENED];
21304
- }
21305
- return false;
21306
- };
21307
- const checkNodeIsOpen = (node) => isRootNode(node) || isItemOpen(node) || isItemOpen(getNodeAttr2(node, NODE_ATTRIBUTES.PARENT_ID));
21308
- const getSourceNodeByPath = (path) => {
21309
- const paths = path.split("-");
21310
- return paths.reduce((pre, nodeIndex) => {
21311
- const index = Number(nodeIndex);
21312
- return Array.isArray(pre) ? pre[index] : pre[props.children][index];
21313
- }, props.data);
21314
- };
21315
- const getSourceNodeByUID = (uid) => getSourceNodeByPath(getNodePath({
21316
- [NODE_ATTRIBUTES.UUID]: uid
21317
- }));
21318
- const getParentNodeData = (uid) => {
21319
- if (isRootNode({
21320
- [NODE_ATTRIBUTES.UUID]: uid
21321
- })) {
21322
- return {
21323
- [props.children]: props.data
21324
- };
21325
- }
21326
- return getSourceNodeByUID(getNodeParentIdById(uid));
21327
- };
21328
- const resolveScopedSlotParam = (item) => __spreadProps(__spreadValues({}, item), {
21329
- loading: getNodeAttr2(item, NODE_ATTRIBUTES.IS_LOADING),
21330
- hasChildNode: hasChildNode(item),
21331
- isMatched: isNodeMatched(item),
21332
- isChecked: isNodeChecked(item),
21333
- isOpened: isNodeOpened(item),
21334
- isRoot: isRootNode(item),
21335
- fullPath: getNodeAttr2(item, NODE_ATTRIBUTES.PATH),
21336
- uuid: getNodeId(item),
21337
- parentId: getNodeAttr2(item, NODE_ATTRIBUTES.PARENT_ID)
21338
- });
21339
- return {
21340
- getSchemaVal: getSchemaVal2,
21341
- getNodeAttr: getNodeAttr2,
21342
- getNodeId,
21343
- getNodeParentId,
21344
- getNodeParentIdById,
21345
- getParentNodeData,
21346
- setNodeAttr,
21347
- getNodePath,
21348
- isRootNode,
21349
- isNodeOpened,
21350
- hasChildNode,
21351
- isItemOpen,
21352
- isNodeChecked,
21353
- isNodeMatched,
21354
- isNodeLoading,
21355
- checkNodeIsOpen,
21356
- getSourceNodeByPath,
21357
- getSourceNodeByUID,
21358
- deleteNodeSchema,
21359
- resolveScopedSlotParam,
21360
- setTreeNodeLoading
21361
- };
21362
- };
21363
21435
  var useNodeAsync = (props, flatData) => {
21364
21436
  const {
21365
21437
  setNodeAttr,
21366
21438
  getNodePath,
21367
21439
  getNodeAttr: getNodeAttr2,
21368
- isNodeOpened,
21369
21440
  resolveScopedSlotParam,
21370
21441
  setTreeNodeLoading
21371
21442
  } = useNodeAttribute(flatData, props);
21372
21443
  const setNodeRemoteLoad = (resp, item) => {
21373
21444
  if (typeof resp === "object" && resp !== null) {
21374
- setNodeAttr(item, NODE_ATTRIBUTES.IS_OPENED, true);
21445
+ setNodeAttr(item, NODE_ATTRIBUTES.IS_OPEN, true);
21375
21446
  const nodeValue = Array.isArray(resp) ? resp : [resp];
21376
21447
  updateTreeNode(getNodePath(item), props.data, props.children, props.children, nodeValue);
21377
21448
  return Promise.resolve(resp);
21378
21449
  }
21379
- return Promise.reject(resp);
21450
+ return Promise.resolve(resp);
21380
21451
  };
21381
21452
  const asyncNodeClick = (item) => {
21382
21453
  const {
21383
21454
  callback = null,
21384
21455
  cache = true
21385
21456
  } = props.async || {};
21386
- if (typeof callback === "function" && getNodeAttr2(item, NODE_ATTRIBUTES.IS_ASYNC) !== false) {
21387
- const isAsyncInit = getNodeAttr2(item, NODE_ATTRIBUTES.IS_ASYNC_INIT);
21457
+ if (typeof callback === "function" && getNodeAttr2(item, NODE_ATTRIBUTES.IS_ASYNC)) {
21388
21458
  setNodeAttr(item, NODE_ATTRIBUTES.IS_ASYNC_INIT, true);
21389
21459
  if (!getNodeAttr2(item, NODE_ATTRIBUTES.IS_CACHED)) {
21390
21460
  setNodeAttr(item, NODE_ATTRIBUTES.IS_CACHED, cache);
21391
- if (isNodeOpened(item) && isAsyncInit) {
21392
- return Promise.resolve(true);
21393
- }
21394
21461
  const dataAttr = resolveScopedSlotParam(item);
21395
21462
  const callbackResult = callback(item, (resp) => setNodeRemoteLoad(resp, item), dataAttr);
21396
21463
  if (typeof callbackResult === "object" && callbackResult !== null) {
@@ -21411,7 +21478,7 @@ var useNodeAsync = (props, flatData) => {
21411
21478
  return Promise.resolve(true);
21412
21479
  };
21413
21480
  const deepAutoOpen = () => {
21414
- const autoOpenNodes = flatData.data.filter((item) => getNodeAttr2(item, NODE_ATTRIBUTES.IS_ASYNC) && item.isOpen && !getNodeAttr2(item, NODE_ATTRIBUTES.IS_ASYNC_INIT));
21481
+ const autoOpenNodes = flatData.data.filter((item) => getNodeAttr2(item, NODE_ATTRIBUTES.IS_ASYNC) && item[NODE_SOURCE_ATTRS[NODE_ATTRIBUTES.IS_OPEN]] && !getNodeAttr2(item, NODE_ATTRIBUTES.IS_ASYNC_INIT));
21415
21482
  if (autoOpenNodes.length) {
21416
21483
  Promise.all(autoOpenNodes.map((item) => asyncNodeClick(item))).then(() => {
21417
21484
  deepAutoOpen();
@@ -21438,7 +21505,8 @@ var useNodeAction = (props, ctx, flatData, renderData, schemaValues, initOption)
21438
21505
  isItemOpen,
21439
21506
  isNodeOpened,
21440
21507
  isNodeLoading,
21441
- resolveScopedSlotParam
21508
+ resolveScopedSlotParam,
21509
+ extendNodeAttr
21442
21510
  } = useNodeAttribute(flatData, props);
21443
21511
  const {
21444
21512
  registerNextLoop
@@ -21475,18 +21543,18 @@ var useNodeAction = (props, ctx, flatData, renderData, schemaValues, initOption)
21475
21543
  };
21476
21544
  const getLoadingIcon = (item) => {
21477
21545
  var _a, _b, _c;
21478
- return ((_c = (_b = (_a = ctx.slots).nodeLoading) == null ? void 0 : _b.call(_a, resolveScopedSlotParam(item))) != null ? _c : isNodeLoading(item)) ? createVNode(spinner, null, null) : "";
21546
+ return ((_c = (_b = (_a = ctx.slots).nodeLoading) == null ? void 0 : _b.call(_a, extendNodeAttr(item))) != null ? _c : isNodeLoading(item)) ? createVNode(spinner, null, null) : "";
21479
21547
  };
21480
21548
  const getActionIcon = (item) => {
21481
21549
  if (ctx.slots.nodeAction) {
21482
- return ctx.slots.nodeAction(resolveScopedSlotParam(item));
21550
+ return ctx.slots.nodeAction(extendNodeAttr(item));
21483
21551
  }
21484
21552
  let prefixFnVal = null;
21485
21553
  if (isNodeLoading(item)) {
21486
21554
  return getLoadingIcon(item);
21487
21555
  }
21488
21556
  if (typeof props.prefixIcon === "function") {
21489
- prefixFnVal = props.prefixIcon(resolveScopedSlotParam(item), "node_action");
21557
+ prefixFnVal = props.prefixIcon(extendNodeAttr(item), "node_action");
21490
21558
  if (prefixFnVal !== "default") {
21491
21559
  return renderPrefixVal(prefixFnVal);
21492
21560
  }
@@ -21500,11 +21568,11 @@ var useNodeAction = (props, ctx, flatData, renderData, schemaValues, initOption)
21500
21568
  };
21501
21569
  const getNodePrefixIcon = (item) => {
21502
21570
  if (ctx.slots.nodeType) {
21503
- return ctx.slots.nodeType(resolveScopedSlotParam(item));
21571
+ return ctx.slots.nodeType(extendNodeAttr(item));
21504
21572
  }
21505
21573
  let prefixFnVal = null;
21506
21574
  if (typeof props.prefixIcon === "function") {
21507
- prefixFnVal = props.prefixIcon(resolveScopedSlotParam(item), "node_type");
21575
+ prefixFnVal = props.prefixIcon(extendNodeAttr(item), "node_type");
21508
21576
  if (prefixFnVal !== "default") {
21509
21577
  return renderPrefixVal(prefixFnVal);
21510
21578
  }
@@ -21518,15 +21586,15 @@ var useNodeAction = (props, ctx, flatData, renderData, schemaValues, initOption)
21518
21586
  };
21519
21587
  const setNodeOpened = (item, isOpen = null, e = null, fireEmit = true) => {
21520
21588
  const newVal = isOpen === null ? !isItemOpen(item) : !!isOpen;
21521
- setNodeAttr(item, NODE_ATTRIBUTES.IS_OPENED, newVal);
21589
+ setNodeAttr(item, NODE_ATTRIBUTES.IS_OPEN, newVal);
21522
21590
  if (fireEmit) {
21523
21591
  const emitEvent = isItemOpen(item) ? EVENTS.NODE_EXPAND : EVENTS.NODE_COLLAPSE;
21524
- ctx.emit(emitEvent, resolveScopedSlotParam(item), getSchemaVal2(item[NODE_ATTRIBUTES.UUID]), e);
21592
+ ctx.emit(emitEvent, [item, resolveScopedSlotParam(item), getSchemaVal2(item[NODE_ATTRIBUTES.UUID]), e]);
21525
21593
  }
21526
21594
  if (newVal) {
21527
21595
  return;
21528
21596
  }
21529
- renderData.value.filter((node) => String.prototype.startsWith.call(getNodePath(node), getNodePath(item))).forEach((filterNode) => setNodeAttr(filterNode, NODE_ATTRIBUTES.IS_OPENED, newVal));
21597
+ renderData.value.filter((node) => String.prototype.startsWith.call(getNodePath(node), getNodePath(item))).forEach((filterNode) => setNodeAttr(filterNode, NODE_ATTRIBUTES.IS_OPEN, newVal));
21530
21598
  };
21531
21599
  const setNodeAction = (args, action, value) => {
21532
21600
  if (Array.isArray(args)) {
@@ -21542,7 +21610,7 @@ var useNodeAction = (props, ctx, flatData, renderData, schemaValues, initOption)
21542
21610
  }
21543
21611
  if (autoOpenParents) {
21544
21612
  if (isOpen) {
21545
- setNodeAction(resolvedItem, NODE_ATTRIBUTES.IS_OPENED, isOpen);
21613
+ setNodeAction(resolvedItem, NODE_ATTRIBUTES.IS_OPEN, isOpen);
21546
21614
  if (!isRootNode(resolvedItem)) {
21547
21615
  const parentId = getNodeAttr2(resolvedItem, NODE_ATTRIBUTES.PARENT_ID);
21548
21616
  setOpen(parentId, true, true);
@@ -21551,11 +21619,15 @@ var useNodeAction = (props, ctx, flatData, renderData, schemaValues, initOption)
21551
21619
  setNodeOpened(resolvedItem, false, null, false);
21552
21620
  }
21553
21621
  } else {
21554
- setNodeAction(resolvedItem, NODE_ATTRIBUTES.IS_OPENED, isOpen);
21622
+ setNodeAction(resolvedItem, NODE_ATTRIBUTES.IS_OPEN, isOpen);
21555
21623
  }
21556
21624
  };
21557
21625
  const hanldeTreeNodeClick = (item, e) => {
21558
21626
  const isOpen = isNodeOpened(item);
21627
+ if (isOpen) {
21628
+ setNodeOpened(item, false, e);
21629
+ return;
21630
+ }
21559
21631
  asyncNodeClick(item).finally(() => {
21560
21632
  if (getNodeAttr2(item, NODE_ATTRIBUTES.IS_LOADING)) {
21561
21633
  registerNextLoop("setNodeOpenedAfterLoading", {
@@ -21610,7 +21682,8 @@ var useNodeAction = (props, ctx, flatData, renderData, schemaValues, initOption)
21610
21682
  if (!isNodeOpened(item)) {
21611
21683
  hanldeTreeNodeClick(item, e);
21612
21684
  }
21613
- ctx.emit(EVENTS.NODE_CLICK, resolveScopedSlotParam(item), getSchemaVal2(item[NODE_ATTRIBUTES.UUID]), e);
21685
+ const eventName = EVENTS.NODE_CLICK;
21686
+ ctx.emit(eventName, item, resolveScopedSlotParam(item), getSchemaVal2(item[NODE_ATTRIBUTES.UUID]), e);
21614
21687
  };
21615
21688
  const filterNextNode = (depth, node) => {
21616
21689
  if (isRootNode(node)) {
@@ -21657,7 +21730,7 @@ var useNodeAction = (props, ctx, flatData, renderData, schemaValues, initOption)
21657
21730
  "class": resolveClassName("node-content")
21658
21731
  }, [[getNodePrefixIcon(item)], createVNode("span", {
21659
21732
  "class": resolveClassName("node-text")
21660
- }, [(_c = (_b = (_a = ctx.slots).node) == null ? void 0 : _b.call(_a, resolveScopedSlotParam(item))) != null ? _c : [getLabel(item, props)]]), (_e = (_d = ctx.slots).nodeAppend) == null ? void 0 : _e.call(_d, resolveScopedSlotParam(item))]), getVirtualLines(item)])]);
21733
+ }, [(_c = (_b = (_a = ctx.slots).node) == null ? void 0 : _b.call(_a, extendNodeAttr(item))) != null ? _c : [getLabel(item, props)]]), (_e = (_d = ctx.slots).nodeAppend) == null ? void 0 : _e.call(_d, extendNodeAttr(item))]), getVirtualLines(item)])]);
21661
21734
  };
21662
21735
  return {
21663
21736
  renderTreeNode,
@@ -22018,7 +22091,7 @@ var useTreeInit = (props) => {
22018
22091
  return result;
22019
22092
  }
22020
22093
  function isCachedTreeNodeOpened(uuid2, node) {
22021
- return getCachedTreeNodeAttr(uuid2, node, NODE_ATTRIBUTES.IS_OPENED, false);
22094
+ return getCachedTreeNodeAttr(uuid2, node, NODE_ATTRIBUTES.IS_OPEN, false);
22022
22095
  }
22023
22096
  function isCachedTreeNodeChecked(uuid2, node) {
22024
22097
  return getCachedTreeNodeAttr(uuid2, node, NODE_ATTRIBUTES.IS_CHECKED, false);
@@ -22042,7 +22115,7 @@ var useTreeInit = (props) => {
22042
22115
  return getCachedTreeNodeAttr(uuid2, node, NODE_ATTRIBUTES.IS_LOADING, false);
22043
22116
  }
22044
22117
  function validateIsOpenLoopFn(target) {
22045
- return !target[NODE_ATTRIBUTES.IS_OPENED];
22118
+ return !target[NODE_ATTRIBUTES.IS_OPEN];
22046
22119
  }
22047
22120
  function flatten(array, depth = 0, parent = null, path = null) {
22048
22121
  const arrLength = array.length;
@@ -22066,7 +22139,7 @@ var useTreeInit = (props) => {
22066
22139
  [NODE_ATTRIBUTES.ORDER]: order2,
22067
22140
  [NODE_ATTRIBUTES.IS_SELECTED]: props2.selectable ? isCachedTreeNodeSelected(uuid2, item) : false,
22068
22141
  [NODE_ATTRIBUTES.IS_MATCH]: isCachedTreeNodeMatch(uuid2, item),
22069
- [NODE_ATTRIBUTES.IS_OPENED]: isCachedTreeNodeOpened(uuid2, item),
22142
+ [NODE_ATTRIBUTES.IS_OPEN]: isCachedTreeNodeOpened(uuid2, item),
22070
22143
  [NODE_ATTRIBUTES.IS_CHECKED]: isCachedTreeNodeChecked(uuid2, item),
22071
22144
  [NODE_ATTRIBUTES.IS_CACHED]: isCachedTreeNodeHasCached(uuid2, item),
22072
22145
  [NODE_ATTRIBUTES.IS_ASYNC]: isCachedTreeNodeAsync(uuid2, item),
@@ -22081,8 +22154,8 @@ var useTreeInit = (props) => {
22081
22154
  outputData.push(__spreadProps(__spreadValues({}, item), {
22082
22155
  [children]: null
22083
22156
  }));
22084
- if (attrs[NODE_ATTRIBUTES.IS_OPENED] || attrs[NODE_ATTRIBUTES.IS_SELECTED]) {
22085
- loopUpdateNodeAttr(parent, NODE_ATTRIBUTES.IS_OPENED, true, validateIsOpenLoopFn);
22157
+ if (attrs[NODE_ATTRIBUTES.IS_OPEN]) {
22158
+ loopUpdateNodeAttr(parent, NODE_ATTRIBUTES.IS_OPEN, true, validateIsOpenLoopFn);
22086
22159
  }
22087
22160
  if (Object.prototype.hasOwnProperty.call(item, children)) {
22088
22161
  flatten(item[children] || [], depth + 1, uuid2, currentPath);
@@ -22165,6 +22238,7 @@ var useTreeInit = (props) => {
22165
22238
  };
22166
22239
  watch(() => [props.data], (newData) => {
22167
22240
  var _a2, _b;
22241
+ console.log("watch data changed");
22168
22242
  const formatData2 = getFlatdata(props, newData, schemaValues.value);
22169
22243
  flatData.data = formatData2[0];
22170
22244
  flatData.schema = formatData2[1];
@@ -22177,6 +22251,7 @@ var useTreeInit = (props) => {
22177
22251
  });
22178
22252
  if (props.selectable) {
22179
22253
  watch(() => props.selected, (newData) => {
22254
+ console.log("watch selected changed");
22180
22255
  afterSelectWatch.length = 0;
22181
22256
  afterSelectEvents.forEach((event) => {
22182
22257
  Reflect.apply(event, globalThis, [newData]);