cnhis-design-vue 3.0.6 → 3.0.9

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/es/index.js CHANGED
@@ -1,6 +1,6 @@
1
- import { watch, h as h$1, resolveComponent, defineComponent, inject, computed, nextTick, reactive, createApp, ref, Teleport, createCommentVNode, provide, onMounted, onUnmounted, getCurrentInstance, onBeforeUnmount, onActivated, onDeactivated, createVNode, mergeProps, isVNode, openBlock, createElementBlock, unref, createElementVNode, toDisplayString, withCtx, normalizeClass, renderSlot, createTextVNode, useAttrs, normalizeStyle, withDirectives, vShow, Fragment, createBlock, vModelSelect, vModelText, pushScopeId, popScopeId, vModelCheckbox, withModifiers } from 'vue';
2
- import { SettingsSharp, CaretDown, CaretForward, CopyOutline, SyncOutline, EllipsisVerticalSharp, Reload, ChevronDown } from '@vicons/ionicons5';
3
- import { NTooltip, NInput, NInputNumber, NSelect, NDatePicker, useMessage, NIcon, NPopconfirm, NButton, NInputGroup, NCheckbox, NCheckboxGroup, NSpace, NProgress, NDropdown, NSwitch, NPopover, NSpin, NRadio, NModal, NForm, NGrid, NFormItemGi, NFormItem } from 'naive-ui';
1
+ import { watch, h as h$1, resolveComponent, defineComponent, inject, computed, nextTick, reactive, createApp, ref, Teleport, createCommentVNode, provide, onMounted, onUnmounted, getCurrentInstance, onBeforeUnmount, onActivated, onDeactivated, createVNode, mergeProps, isVNode, openBlock, createElementBlock, unref, createElementVNode, toDisplayString, withCtx, normalizeClass, renderSlot, createTextVNode, useAttrs, normalizeStyle, withDirectives, vShow, Fragment, createBlock, vModelSelect, vModelText, pushScopeId, popScopeId, vModelCheckbox, withModifiers, renderList } from 'vue';
2
+ import { NInput, NInputNumber, NSelect, NDatePicker, NTooltip, useMessage, NIcon, NPopconfirm, NButton, NInputGroup, NCheckbox, NCheckboxGroup, NSpace, NProgress, NDropdown, NSwitch, NPopover, NSpin, NRadio, NModal, NForm, NGrid, NFormItemGi, NFormItem, NTree } from 'naive-ui';
3
+ import { SettingsSharp, CaretDown, CaretForward, CopyOutline, SyncOutline, EllipsisVerticalSharp, Reload, ChevronDown, Search, CloseCircleSharp } from '@vicons/ionicons5';
4
4
  import draggable from 'vuedraggable';
5
5
 
6
6
  var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
@@ -1764,7 +1764,7 @@ var eachTree$1 = eachTree_1;
1764
1764
  * @param {Object} context 上下文
1765
1765
  * @return {Array}
1766
1766
  */
1767
- function filterTree$1 (obj, iterate, options, context) {
1767
+ function filterTree$2 (obj, iterate, options, context) {
1768
1768
  var result = [];
1769
1769
  if (obj && iterate) {
1770
1770
  eachTree$1(obj, function (item, index, items, path, parent, nodes) {
@@ -1776,7 +1776,7 @@ function filterTree$1 (obj, iterate, options, context) {
1776
1776
  return result
1777
1777
  }
1778
1778
 
1779
- var filterTree_1 = filterTree$1;
1779
+ var filterTree_1 = filterTree$2;
1780
1780
 
1781
1781
  var helperCreateTreeFunc = helperCreateTreeFunc_1;
1782
1782
 
@@ -5326,7 +5326,7 @@ var toTreeArray = toTreeArray_1;
5326
5326
  var findTree = findTree_1;
5327
5327
  var eachTree = eachTree_1;
5328
5328
  var mapTree = mapTree_1;
5329
- var filterTree = filterTree_1;
5329
+ var filterTree$1 = filterTree_1;
5330
5330
  var searchTree = searchTree_1;
5331
5331
  var arrayIndexOf = arrayIndexOf_1;
5332
5332
  var arrayLastIndexOf = arrayLastIndexOf_1;
@@ -5518,7 +5518,7 @@ assign(XEUtils, {
5518
5518
  findTree: findTree,
5519
5519
  eachTree: eachTree,
5520
5520
  mapTree: mapTree,
5521
- filterTree: filterTree,
5521
+ filterTree: filterTree$1,
5522
5522
  searchTree: searchTree,
5523
5523
 
5524
5524
  // base
@@ -30877,7 +30877,7 @@ const bigTableState = {
30877
30877
 
30878
30878
  const bigTableProps = {
30879
30879
  data: { type: Array, default: () => [] },
30880
- MAX_CHECK_SIZE: { type: Number, default: 0 },
30880
+ maxCheckSize: { type: Number, default: 0 },
30881
30881
  showFooter: Boolean,
30882
30882
  sumData: { type: Object, default: () => ({}) },
30883
30883
  avgData: { type: Object, default: () => ({}) },
@@ -31033,7 +31033,8 @@ const bigTableEmits = [
31033
31033
  "selectionChangeLocal",
31034
31034
  "switchBtnOnChange",
31035
31035
  "asyncTableChange",
31036
- "formChange"
31036
+ "formChange",
31037
+ "scroll"
31037
31038
  ];
31038
31039
 
31039
31040
  var moment$1 = {exports: {}};
@@ -38412,6 +38413,197 @@ const useNestTable = (props, state, emit) => {
38412
38413
  };
38413
38414
  };
38414
38415
 
38416
+ var script$e = defineComponent({
38417
+ name: "EditInput",
38418
+ inheritAttrs: false,
38419
+ components: {
38420
+ NInput,
38421
+ NInputNumber
38422
+ },
38423
+ props: {
38424
+ type: {
38425
+ type: String,
38426
+ default: "input"
38427
+ },
38428
+ col: {
38429
+ type: Object,
38430
+ default: () => ({})
38431
+ },
38432
+ row: {
38433
+ type: Object,
38434
+ default: () => ({})
38435
+ },
38436
+ index: {
38437
+ type: [Number, Object],
38438
+ default: 0
38439
+ }
38440
+ },
38441
+ emits: ["formChange"],
38442
+ setup(props, { attrs, slots, emit }) {
38443
+ const onUpdateValue = (value) => {
38444
+ emit("formChange", {
38445
+ value,
38446
+ row: props.row,
38447
+ column: props.col,
38448
+ index: props.index
38449
+ });
38450
+ };
38451
+ return () => props.type === "input" ? createVNode(NInput, mergeProps(attrs, {
38452
+ "onUpdateValue": onUpdateValue
38453
+ }), null) : createVNode(NInputNumber, mergeProps(attrs, {
38454
+ "onUpdateValue": onUpdateValue
38455
+ }), null);
38456
+ }
38457
+ });
38458
+
38459
+ script$e.__file = "packages/big-table/src/components/edit-form/edit-input.vue";
38460
+
38461
+ var script$d = defineComponent({
38462
+ name: "EditSelect",
38463
+ inheritAttrs: false,
38464
+ components: {
38465
+ NSelect
38466
+ },
38467
+ props: {
38468
+ col: {
38469
+ type: Object,
38470
+ default: () => ({})
38471
+ },
38472
+ row: {
38473
+ type: Object,
38474
+ default: () => ({})
38475
+ },
38476
+ index: {
38477
+ type: [Number, Object],
38478
+ default: 0
38479
+ }
38480
+ },
38481
+ emits: ["setOptions", "formChange"],
38482
+ setup(props, { attrs, slots, emit }) {
38483
+ const state = reactive({
38484
+ options: []
38485
+ });
38486
+ const setOptions = async () => {
38487
+ if (props.col.options) {
38488
+ state.options = JSON.parse(JSON.stringify(props.col.options));
38489
+ }
38490
+ else {
38491
+ const optionsName = `${props.col.columnName}_options`;
38492
+ state.options = props.row[optionsName] || await props.col.queryOptions();
38493
+ if (!props.row[optionsName]) {
38494
+ emit("setOptions", state.options);
38495
+ }
38496
+ }
38497
+ };
38498
+ setOptions();
38499
+ const onUpdateValue = (value) => {
38500
+ emit("formChange", {
38501
+ value,
38502
+ row: props.row,
38503
+ column: props.col,
38504
+ index: props.index
38505
+ });
38506
+ };
38507
+ console.log(attrs);
38508
+ return () => [createVNode(NSelect, mergeProps(attrs, {
38509
+ "options": state.options,
38510
+ "consistentMenuWidth": false,
38511
+ "clearable": true,
38512
+ "filterable": true,
38513
+ "to": false,
38514
+ "placeholder": "\u8BF7\u9009\u62E9",
38515
+ "onUpdateValue": onUpdateValue
38516
+ }), null)];
38517
+ }
38518
+ });
38519
+
38520
+ script$d.__file = "packages/big-table/src/components/edit-form/edit-select.vue";
38521
+
38522
+ var script$c = defineComponent({
38523
+ name: "EditDate",
38524
+ inheritAttrs: false,
38525
+ components: {
38526
+ NDatePicker
38527
+ },
38528
+ props: {
38529
+ col: {
38530
+ type: Object,
38531
+ default: () => ({})
38532
+ },
38533
+ row: {
38534
+ type: Object,
38535
+ default: () => ({})
38536
+ },
38537
+ index: {
38538
+ type: [Number, Object],
38539
+ default: 0
38540
+ }
38541
+ },
38542
+ emits: ["formChange"],
38543
+ setup(props, { attrs, slots, emit }) {
38544
+ const onConfirm = (value) => {
38545
+ emit("formChange", {
38546
+ value,
38547
+ row: props.row,
38548
+ column: props.col,
38549
+ index: props.index
38550
+ });
38551
+ };
38552
+ const { isStartDate = false, isEndDate = false, connectField } = props.col;
38553
+ const setDateDisabled = (cur, date) => {
38554
+ if (isStartDate && connectField) {
38555
+ return cur > date;
38556
+ }
38557
+ if (isEndDate && connectField) {
38558
+ return cur < date;
38559
+ }
38560
+ return false;
38561
+ };
38562
+ const isDateDisabled = (ts) => {
38563
+ return setDateDisabled(ts, new Date(props.row[connectField]).getTime());
38564
+ };
38565
+ const isTimeDisabled = (ts) => {
38566
+ const date = new Date(props.row[connectField] || ts);
38567
+ const h = date.getHours();
38568
+ const m = date.getMinutes();
38569
+ const s = date.getSeconds();
38570
+ return {
38571
+ isHourDisabled: (hour) => {
38572
+ return setDateDisabled(hour, h);
38573
+ },
38574
+ isMinuteDisabled: (minute) => {
38575
+ return setDateDisabled(minute, m);
38576
+ },
38577
+ isSecondDisabled: (second) => {
38578
+ return setDateDisabled(second, s);
38579
+ }
38580
+ };
38581
+ };
38582
+ const config = {
38583
+ type: props.col.type || "datetime",
38584
+ clearable: props.col.clearable || true,
38585
+ disabled: props.col.disabled || false,
38586
+ valueFormat: props.col.valueFormat || "yyyy-MM-dd HH:mm:ss",
38587
+ to: false,
38588
+ isDateDisabled: props.col.isDateDisabled || isDateDisabled
38589
+ };
38590
+ if (config.type.includes("time")) {
38591
+ config.isTimeDisabled = props.col.isTimeDisabled || isTimeDisabled;
38592
+ }
38593
+ return () => createVNode(NDatePicker, mergeProps(attrs, config, {
38594
+ "onUpdateFormattedValue": onConfirm
38595
+ }), null);
38596
+ }
38597
+ });
38598
+
38599
+ script$c.__file = "packages/big-table/src/components/edit-form/edit-date.vue";
38600
+
38601
+ const comps = {
38602
+ "input": script$e,
38603
+ "number": script$e,
38604
+ "select": script$d,
38605
+ "date": script$c
38606
+ };
38415
38607
  const useEdit = (props, state, emit, xGrid) => {
38416
38608
  const initEditTable = async () => {
38417
38609
  const { isEdit, fieldList = [] } = props.columnConfig;
@@ -38467,14 +38659,35 @@ const useEdit = (props, state, emit, xGrid) => {
38467
38659
  await xGrid.value.insertAt(record, getInsertRecords.at(-1));
38468
38660
  xGrid.value.clearActived();
38469
38661
  };
38470
- const onFormChange = ({ value, row, column }) => {
38471
- emit("formChange", { value, row, column });
38662
+ const getLabel = (opts, value) => {
38663
+ return opts.find((opt) => opt.value === value)?.label || "";
38664
+ };
38665
+ const onFormChange = ({ value, row, column, index }) => {
38666
+ let oldValue = row[column.columnName];
38667
+ if ((column?.formType === "input" || column?.formType === "number") && props.columnConfig?.formValidate) {
38668
+ row[column.columnName] = props.columnConfig?.formValidate({ row, column, current: value, old: row[column.columnName] });
38669
+ }
38670
+ else if (column?.formatMap) {
38671
+ oldValue = {
38672
+ label: row[column.formatMap.label],
38673
+ value: row[column.formatMap.value]
38674
+ };
38675
+ row[column.formatMap.label] = getLabel(row[column.columnName + "_options"] || [], value);
38676
+ row[column.formatMap.value] = value;
38677
+ }
38678
+ else {
38679
+ row[column.columnName] = value;
38680
+ }
38681
+ emit("formChange", { value, row, column, index, oldValue });
38472
38682
  };
38473
38683
  const getDefaultValue = (params, item) => {
38474
38684
  const value = params.row[item.columnName];
38475
38685
  if (item.formType === "select") {
38686
+ if (item.formatMap) {
38687
+ return params.row[item.formatMap.label];
38688
+ }
38476
38689
  if (item.options) {
38477
- return item.options.find((v) => v.value === value)?.label || "";
38690
+ return item.options.find((v) => v.value == value)?.label || "";
38478
38691
  }
38479
38692
  if (item.queryOptions) {
38480
38693
  return params.row[`${item.columnName}_options`]?.find((v) => v.value === value)?.label || "";
@@ -38501,10 +38714,10 @@ var img$4 = "
38501
38714
 
38502
38715
  var img$3 = "";
38503
38716
 
38504
- const _hoisted_1$8 = { class: "no-data-tip NoData-page" };
38505
- const _hoisted_2$7 = ["src"];
38506
- const _hoisted_3$5 = { key: 1 };
38507
- var script$c = /* @__PURE__ */ defineComponent({
38717
+ const _hoisted_1$a = { class: "no-data-tip NoData-page" };
38718
+ const _hoisted_2$9 = ["src"];
38719
+ const _hoisted_3$7 = { key: 1 };
38720
+ var script$b = /* @__PURE__ */ defineComponent({
38508
38721
  props: {
38509
38722
  noDataTip: {
38510
38723
  type: String,
@@ -38552,28 +38765,28 @@ var script$c = /* @__PURE__ */ defineComponent({
38552
38765
  return res;
38553
38766
  });
38554
38767
  return (_ctx, _cache) => {
38555
- return openBlock(), createElementBlock("div", _hoisted_1$8, [
38768
+ return openBlock(), createElementBlock("div", _hoisted_1$a, [
38556
38769
  __props.showImg ? (openBlock(), createElementBlock("img", {
38557
38770
  key: 0,
38558
38771
  src: unref(imgStr),
38559
38772
  alt: ""
38560
- }, null, 8, _hoisted_2$7)) : createCommentVNode("v-if", true),
38773
+ }, null, 8, _hoisted_2$9)) : createCommentVNode("v-if", true),
38561
38774
  createElementVNode("p", null, toDisplayString(__props.noDataTip), 1),
38562
- unref(handleDesc) ? (openBlock(), createElementBlock("span", _hoisted_3$5, toDisplayString(unref(handleDesc)), 1)) : createCommentVNode("v-if", true)
38775
+ unref(handleDesc) ? (openBlock(), createElementBlock("span", _hoisted_3$7, toDisplayString(unref(handleDesc)), 1)) : createCommentVNode("v-if", true)
38563
38776
  ]);
38564
38777
  };
38565
38778
  }
38566
38779
  });
38567
38780
 
38568
- script$c.__scopeId = "data-v-4a4b0812";
38569
- script$c.__file = "packages/big-table/src/components/NoData.vue";
38781
+ script$b.__scopeId = "data-v-4a4b0812";
38782
+ script$b.__file = "packages/big-table/src/components/NoData.vue";
38570
38783
 
38571
- const _hoisted_1$7 = { class: "text-over-tooltip-components" };
38572
- const __default__$8 = {
38784
+ const _hoisted_1$9 = { class: "text-over-tooltip-components" };
38785
+ const __default__$9 = {
38573
38786
  name: "TextOverTooltip"
38574
38787
  };
38575
- var script$b = /* @__PURE__ */ defineComponent({
38576
- ...__default__$8,
38788
+ var script$a = /* @__PURE__ */ defineComponent({
38789
+ ...__default__$9,
38577
38790
  props: {
38578
38791
  content: { type: [String, Number], required: false },
38579
38792
  className: { type: String, required: false },
@@ -38607,7 +38820,7 @@ var script$b = /* @__PURE__ */ defineComponent({
38607
38820
  isDisabledTooltip.value = false;
38608
38821
  };
38609
38822
  return (_ctx, _cache) => {
38610
- return openBlock(), createElementBlock("div", _hoisted_1$7, [
38823
+ return openBlock(), createElementBlock("div", _hoisted_1$9, [
38611
38824
  createVNode(unref(NTooltip), {
38612
38825
  effect: __props.effect,
38613
38826
  show: unref(isDisabledTooltip),
@@ -38640,16 +38853,16 @@ var script$b = /* @__PURE__ */ defineComponent({
38640
38853
  }
38641
38854
  });
38642
38855
 
38643
- script$b.__scopeId = "data-v-6633a934";
38644
- script$b.__file = "packages/big-table/src/components/TextOverTooltip.vue";
38856
+ script$a.__scopeId = "data-v-6633a934";
38857
+ script$a.__file = "packages/big-table/src/components/TextOverTooltip.vue";
38645
38858
 
38646
- const _hoisted_1$6 = { key: 0 };
38647
- const _hoisted_2$6 = ["xlink:href"];
38648
- const __default__$7 = {
38859
+ const _hoisted_1$8 = { key: 0 };
38860
+ const _hoisted_2$8 = ["xlink:href"];
38861
+ const __default__$8 = {
38649
38862
  name: "SvgIcon"
38650
38863
  };
38651
- var script$a = /* @__PURE__ */ defineComponent({
38652
- ...__default__$7,
38864
+ var script$9 = /* @__PURE__ */ defineComponent({
38865
+ ...__default__$8,
38653
38866
  props: {
38654
38867
  iconClass: { type: String, required: true, default: "" },
38655
38868
  title: { type: String, required: true, default: "" },
@@ -38671,166 +38884,15 @@ var script$a = /* @__PURE__ */ defineComponent({
38671
38884
  class: unref(svgClass),
38672
38885
  "aria-hidden": "true"
38673
38886
  }, _ctx.$attrs), [
38674
- __props.title ? (openBlock(), createElementBlock("title", _hoisted_1$6, toDisplayString(__props.title), 1)) : createCommentVNode("v-if", true),
38675
- createElementVNode("use", { "xlink:href": unref(iconName) }, null, 8, _hoisted_2$6)
38887
+ __props.title ? (openBlock(), createElementBlock("title", _hoisted_1$8, toDisplayString(__props.title), 1)) : createCommentVNode("v-if", true),
38888
+ createElementVNode("use", { "xlink:href": unref(iconName) }, null, 8, _hoisted_2$8)
38676
38889
  ], 16);
38677
38890
  };
38678
38891
  }
38679
38892
  });
38680
38893
 
38681
- script$a.__scopeId = "data-v-d1ad5be8";
38682
- script$a.__file = "src/component/svg/index.vue";
38683
-
38684
- var script$9 = defineComponent({
38685
- name: "EditInput",
38686
- inheritAttrs: false,
38687
- components: {
38688
- NInput,
38689
- NInputNumber
38690
- },
38691
- props: {
38692
- type: {
38693
- type: String,
38694
- default: "input"
38695
- },
38696
- col: {
38697
- type: Object,
38698
- default: () => ({})
38699
- },
38700
- row: {
38701
- type: Object,
38702
- default: () => ({})
38703
- },
38704
- index: {
38705
- type: [Number, Object],
38706
- default: 0
38707
- }
38708
- },
38709
- emits: ["formChange"],
38710
- setup(props, { attrs, slots, emit }) {
38711
- const onUpdateValue = (value) => {
38712
- emit("formChange", {
38713
- value,
38714
- row: props.row,
38715
- column: props.col,
38716
- index: props.index
38717
- });
38718
- };
38719
- return () => props.type === "input" ? createVNode(NInput, mergeProps(attrs, {
38720
- "onUpdateValue": onUpdateValue
38721
- }), null) : createVNode(NInputNumber, mergeProps(attrs, {
38722
- "onUpdateValue": onUpdateValue
38723
- }), null);
38724
- }
38725
- });
38726
-
38727
- script$9.__file = "packages/big-table/src/components/edit-form/edit-input.vue";
38728
-
38729
- var script$8 = defineComponent({
38730
- name: "EditSelect",
38731
- inheritAttrs: false,
38732
- components: {
38733
- NSelect
38734
- },
38735
- props: {
38736
- col: {
38737
- type: Object,
38738
- default: () => ({})
38739
- },
38740
- row: {
38741
- type: Object,
38742
- default: () => ({})
38743
- },
38744
- index: {
38745
- type: [Number, Object],
38746
- default: 0
38747
- }
38748
- },
38749
- emits: ["setOptions", "formChange"],
38750
- setup(props, { attrs, slots, emit }) {
38751
- const state = reactive({
38752
- options: []
38753
- });
38754
- const setOptions = async () => {
38755
- if (props.col.options) {
38756
- state.options = JSON.parse(JSON.stringify(props.col.options));
38757
- }
38758
- else {
38759
- const optionsName = `${props.col.columnName}_options`;
38760
- state.options = props.row[optionsName] || await props.col.queryOptions();
38761
- if (!props.row[optionsName]) {
38762
- emit("setOptions", state.options);
38763
- }
38764
- }
38765
- };
38766
- setOptions();
38767
- const onUpdateValue = (value) => {
38768
- emit("formChange", {
38769
- value,
38770
- row: props.row,
38771
- column: props.col,
38772
- index: props.index
38773
- });
38774
- };
38775
- return () => [createVNode(NSelect, mergeProps(attrs, {
38776
- "options": state.options,
38777
- "consistentMenuWidth": false,
38778
- "clearable": true,
38779
- "filterable": true,
38780
- "to": false,
38781
- "placeholder": "\u8BF7\u9009\u62E9",
38782
- "onUpdateValue": onUpdateValue
38783
- }), null)];
38784
- }
38785
- });
38786
-
38787
- script$8.__file = "packages/big-table/src/components/edit-form/edit-select.vue";
38788
-
38789
- var script$7 = defineComponent({
38790
- name: "EditDate",
38791
- inheritAttrs: false,
38792
- components: {
38793
- NDatePicker
38794
- },
38795
- props: {
38796
- col: {
38797
- type: Object,
38798
- default: () => ({})
38799
- },
38800
- row: {
38801
- type: Object,
38802
- default: () => ({})
38803
- },
38804
- index: {
38805
- type: [Number, Object],
38806
- default: 0
38807
- }
38808
- },
38809
- emits: ["formChange"],
38810
- setup(props, { attrs, slots, emit }) {
38811
- const onConfirm = (value, formattedValue) => {
38812
- console.log("\u65F6\u95F4\u9009\u62E9->", value);
38813
- emit("formChange", {
38814
- value,
38815
- row: props.row,
38816
- column: props.col,
38817
- index: props.index
38818
- });
38819
- };
38820
- const config = {
38821
- type: props.col.type || "datetime",
38822
- clearable: props.col.clearable || true,
38823
- disabled: props.col.disabled || false,
38824
- valueFormat: props.col.valueFormat || "yyyy-MM-dd HH:mm:ss",
38825
- to: false
38826
- };
38827
- return () => createVNode(NDatePicker, mergeProps(attrs, config, {
38828
- "onConfirm": onConfirm
38829
- }), null);
38830
- }
38831
- });
38832
-
38833
- script$7.__file = "packages/big-table/src/components/edit-form/edit-date.vue";
38894
+ script$9.__scopeId = "data-v-d1ad5be8";
38895
+ script$9.__file = "src/component/svg/index.vue";
38834
38896
 
38835
38897
  var img$2 = "";
38836
38898
 
@@ -39452,21 +39514,21 @@ var img$1 = "
39452
39514
 
39453
39515
  var img = "";
39454
39516
 
39455
- const _hoisted_1$5 = {
39517
+ const _hoisted_1$7 = {
39456
39518
  key: 0,
39457
39519
  class: "check-wrap"
39458
39520
  };
39459
- const _hoisted_2$5 = /* @__PURE__ */ createElementVNode("span", null, "\u7CFB\u7EDF\u68C0\u6D4B\u5230\u6709\u6570\u636E\u66F4\u65B0,", -1);
39460
- const _hoisted_3$4 = {
39521
+ const _hoisted_2$7 = /* @__PURE__ */ createElementVNode("span", null, "\u7CFB\u7EDF\u68C0\u6D4B\u5230\u6709\u6570\u636E\u66F4\u65B0,", -1);
39522
+ const _hoisted_3$6 = {
39461
39523
  class: "check-wrap"
39462
39524
  };
39463
- const _hoisted_4$4 = {
39525
+ const _hoisted_4$5 = {
39464
39526
  class: "check-wrap-title"
39465
39527
  };
39466
- const _hoisted_5$4 = {
39528
+ const _hoisted_5$5 = {
39467
39529
  key: 0
39468
39530
  };
39469
- const _hoisted_6$4 = {
39531
+ const _hoisted_6$5 = {
39470
39532
  key: 1
39471
39533
  };
39472
39534
  const _hoisted_7$4 = {
@@ -39489,11 +39551,11 @@ const _hoisted_13$1 = {
39489
39551
  function _isSlot(s) {
39490
39552
  return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
39491
39553
  }
39492
- const __default__$6 = create({
39554
+ const __default__$7 = create({
39493
39555
  name: "BigTable"
39494
39556
  });
39495
- var script$6 = /* @__PURE__ */ defineComponent({
39496
- ...__default__$6,
39557
+ var script$8 = /* @__PURE__ */ defineComponent({
39558
+ ...__default__$7,
39497
39559
  props: bigTableProps,
39498
39560
  emits: bigTableEmits,
39499
39561
  setup(__props, { expose, emit }) {
@@ -39516,7 +39578,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
39516
39578
  });
39517
39579
  const visibleCancelCheckAllBtn = computed(() => {
39518
39580
  let isCurrentPageAllCheck = state.currentPageSelectedLength === state.curAbleCheckedLen;
39519
- let isMaxChecked = currentCheckedKeys.value.length === props.MAX_CHECK_SIZE;
39581
+ let isMaxChecked = currentCheckedKeys.value.length === props.maxCheckSize;
39520
39582
  let isCheckedTotal = currentCheckedKeys.value.length === props.pageVO.total;
39521
39583
  return isMaxChecked || !isCurrentPageAllCheck || isCheckedTotal;
39522
39584
  });
@@ -39842,37 +39904,35 @@ var script$6 = /* @__PURE__ */ defineComponent({
39842
39904
  const formatterEdit = (params, col) => {
39843
39905
  let { row, column, $rowIndex, rowIndex } = params;
39844
39906
  let formType = column.formType || col.formType || "";
39907
+ let formatMap = column.formatMap || col.formatMap || null;
39908
+ if (!formType)
39909
+ return null;
39845
39910
  if (formType === "custom") {
39846
39911
  return col.slotFn(params);
39847
39912
  }
39913
+ const Comp = comps[formType] || "";
39914
+ if (!Comp)
39915
+ return null;
39848
39916
  const propsData = {
39849
39917
  col,
39850
39918
  row,
39851
- index: $rowIndex
39919
+ index: $rowIndex,
39920
+ type: formType,
39921
+ onFormChange
39852
39922
  };
39853
- if (formType === "input" || formType === "number") {
39854
- return createVNode(script$9, mergeProps(propsData, {
39855
- "type": formType,
39856
- "value": row[col.columnName],
39857
- "onUpdate:value": ($event) => row[col.columnName] = $event,
39858
- "onFormChange": onFormChange
39859
- }), null);
39923
+ if (formType === "date") {
39924
+ propsData.defaultFormattedValue = row[col.columnName];
39860
39925
  }
39861
- if (formType === "select") {
39862
- return createVNode(script$8, mergeProps(propsData, {
39863
- "value": row[col.columnName],
39864
- "onUpdate:value": ($event) => row[col.columnName] = $event,
39865
- "onSetOptions": (options) => row[`${col.columnName}_options`] = options,
39866
- "onFormChange": onFormChange
39867
- }), null);
39926
+ else if (formatMap) {
39927
+ propsData.defaultValue = row[formatMap.value];
39868
39928
  }
39869
- if (formType === "date") {
39870
- return createVNode(script$7, mergeProps(propsData, {
39871
- "formattedValue": row[col.columnName],
39872
- "onUpdate:formattedValue": ($event) => row[col.columnName] = $event,
39873
- "onFormChange": onFormChange
39874
- }), null);
39929
+ else {
39930
+ propsData.defaultValue = row[col.columnName];
39875
39931
  }
39932
+ if (formType === "select") {
39933
+ propsData.onSetOptions = (options) => row[`${col.columnName}_options`] = options;
39934
+ }
39935
+ return createVNode(Comp, propsData, null);
39876
39936
  };
39877
39937
  const getEditBtn = (row, col, index) => {
39878
39938
  return col.tileBtnList?.map((btn) => {
@@ -39968,7 +40028,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
39968
40028
  return getOrCode(row, own, attrType);
39969
40029
  }
39970
40030
  if (column.property === "operatorColumn") {
39971
- if (props.columnConfig.isEdit) {
40031
+ if (props.columnConfig.isEdit && !row.initRow) {
39972
40032
  return getEditBtn(row, col, $rowIndex);
39973
40033
  }
39974
40034
  if (state.showButtonTop != 0 || props.isBatchEditing)
@@ -40253,13 +40313,13 @@ var script$6 = /* @__PURE__ */ defineComponent({
40253
40313
  isAlias = !!tooltipTitle;
40254
40314
  }
40255
40315
  if (type === "format")
40256
- return createVNode(script$b, {
40316
+ return createVNode(script$a, {
40257
40317
  "tooltipTitle": tooltipTitle,
40258
40318
  "content": name,
40259
40319
  "isAlias": isAlias
40260
40320
  }, null);
40261
40321
  return () => {
40262
- return [createVNode(script$b, {
40322
+ return [createVNode(script$a, {
40263
40323
  "tooltipTitle": tooltipTitle,
40264
40324
  "content": name,
40265
40325
  "isAlias": isAlias
@@ -40303,8 +40363,8 @@ var script$6 = /* @__PURE__ */ defineComponent({
40303
40363
  emit("refreshTable");
40304
40364
  };
40305
40365
  const handleCheckAll = () => {
40306
- if (props.pageVO.total > props.MAX_CHECK_SIZE) {
40307
- let text = `\u5F53\u524D\u5217\u8868\u5171${props.pageVO.total}\u6761\u6570\u636E\uFF0C\u4E3A\u4E86\u786E\u4FDD\u7CFB\u7EDF\u5B89\u5168\uFF0C\u53EA\u80FD\u5355\u6B21\u64CD\u4F5C${props.MAX_CHECK_SIZE}\u6761\uFF0C\u4F60\u53EF\u4EE5\u901A\u8FC7\u9AD8\u7EA7\u7B5B\u9009\u8FC7\u6EE4\u518D\u6B21\u5C1D\u8BD5`;
40366
+ if (props.pageVO.total > props.maxCheckSize) {
40367
+ let text = `\u5F53\u524D\u5217\u8868\u5171${props.pageVO.total}\u6761\u6570\u636E\uFF0C\u4E3A\u4E86\u786E\u4FDD\u7CFB\u7EDF\u5B89\u5168\uFF0C\u53EA\u80FD\u5355\u6B21\u64CD\u4F5C${props.maxCheckSize}\u6761\uFF0C\u4F60\u53EF\u4EE5\u901A\u8FC7\u9AD8\u7EA7\u7B5B\u9009\u8FC7\u6EE4\u518D\u6B21\u5C1D\u8BD5`;
40308
40368
  window.$message.warning(text);
40309
40369
  }
40310
40370
  emit("selectionChangeAll");
@@ -40392,7 +40452,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
40392
40452
  };
40393
40453
  const setChecklist = (list) => {
40394
40454
  return list.map((i) => {
40395
- i["checked"] = false;
40455
+ i["checked"] = i.checked || false;
40396
40456
  if (state.isTree == 2) {
40397
40457
  const treeNodeKey = state.levelLazyLoadSetting.childCountKey;
40398
40458
  const { isTreeOrList = "" } = props.tableParams;
@@ -40682,8 +40742,8 @@ var script$6 = /* @__PURE__ */ defineComponent({
40682
40742
  const addCheckedRows = (rows) => {
40683
40743
  removeCheckedDisabledRows(state);
40684
40744
  let checkedRows = state.checkedRows;
40685
- if (currentCheckedKeys.value.length + rows.length > props.MAX_CHECK_SIZE) {
40686
- window.$message.warning(`\u4E3A\u4E86\u4FDD\u8BC1\u7CFB\u7EDF\u5B89\u5168\uFF0C\u5355\u6B21\u64CD\u4F5C\u6570\u636E\u91CF\u9650\u989D\u4E3A${props.MAX_CHECK_SIZE}\u6761\uFF0C\u4F60\u53EF\u4EE5\u901A\u8FC7\u9AD8\u7EA7\u7B5B\u9009\u8FC7\u6EE4\u540E\u518D\u6B21\u5C1D\u8BD5`);
40745
+ if (currentCheckedKeys.value.length + rows.length > props.maxCheckSize) {
40746
+ window.$message.warning(`\u4E3A\u4E86\u4FDD\u8BC1\u7CFB\u7EDF\u5B89\u5168\uFF0C\u5355\u6B21\u64CD\u4F5C\u6570\u636E\u91CF\u9650\u989D\u4E3A${props.maxCheckSize}\u6761\uFF0C\u4F60\u53EF\u4EE5\u901A\u8FC7\u9AD8\u7EA7\u7B5B\u9009\u8FC7\u6EE4\u540E\u518D\u6B21\u5C1D\u8BD5`);
40687
40747
  return false;
40688
40748
  }
40689
40749
  let newCheckedRows = rows.filter((row) => {
@@ -40752,10 +40812,21 @@ var script$6 = /* @__PURE__ */ defineComponent({
40752
40812
  emit("setNestTableClickSetting", props.isNestTable);
40753
40813
  emit("showDrawer", theads);
40754
40814
  };
40815
+ let scrollEvent = (params) => {
40816
+ emit("scroll", params);
40817
+ };
40818
+ const initScroll = () => {
40819
+ const { throttle = false, throttleTime = 800, throttleOptions = {} } = props.columnConfig?.scrollConfig || {};
40820
+ if (throttle) {
40821
+ scrollEvent = xeUtils.throttle(scrollEvent, throttleTime, throttleOptions);
40822
+ }
40823
+ };
40824
+ initScroll();
40755
40825
  const handlerScroll = (params) => {
40756
40826
  if (params.isX) {
40757
40827
  hideFilterWrap(state, props);
40758
40828
  }
40829
+ scrollEvent(params);
40759
40830
  };
40760
40831
  const handleCellMouseenter = ({ column, $event }) => {
40761
40832
  if (column.showOverflow === "title") {
@@ -40813,7 +40884,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
40813
40884
  return createVNode(NPopconfirm, {
40814
40885
  "onPositiveClick": () => confirmScanMulti(params)
40815
40886
  }, {
40816
- trigger: () => createVNode(script$a, {
40887
+ trigger: () => createVNode(script$9, {
40817
40888
  "class": "scan-multi-delete",
40818
40889
  "iconClass": "shanchu"
40819
40890
  }, null),
@@ -41026,7 +41097,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
41026
41097
  }, [createVNode("img", {
41027
41098
  "class": "bigTable-qr-img",
41028
41099
  "src": src
41029
- }, null), createVNode("span", null, [createVNode(script$a, {
41100
+ }, null), createVNode("span", null, [createVNode(script$9, {
41030
41101
  "iconClass": "fangda"
41031
41102
  }, null)])])];
41032
41103
  };
@@ -41110,7 +41181,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
41110
41181
  }
41111
41182
  else {
41112
41183
  icon = createVNode(NTooltip, null, {
41113
- trigger: () => createVNode(script$a, {
41184
+ trigger: () => createVNode(script$9, {
41114
41185
  "iconClass": btn.icon,
41115
41186
  "style": {
41116
41187
  marginRight: mr
@@ -41121,7 +41192,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
41121
41192
  }
41122
41193
  }
41123
41194
  else if (btn.iconSetting) {
41124
- icon = createVNode(script$a, {
41195
+ icon = createVNode(script$9, {
41125
41196
  "iconClass": JSON.parse(btn.iconSetting).icon,
41126
41197
  "style": {
41127
41198
  marginRight: mr
@@ -41468,18 +41539,18 @@ var script$6 = /* @__PURE__ */ defineComponent({
41468
41539
  style: normalizeStyle({
41469
41540
  height: unref(state).tableHeight
41470
41541
  })
41471
- }, [unref(state).hasRefresh && !props.isNestTable ? (openBlock(), createElementBlock("div", _hoisted_1$5, [createElementVNode("p", {
41542
+ }, [unref(state).hasRefresh && !props.isNestTable ? (openBlock(), createElementBlock("div", _hoisted_1$7, [createElementVNode("p", {
41472
41543
  class: "check-wrap-title"
41473
- }, [_hoisted_2$5, createElementVNode("span", {
41544
+ }, [_hoisted_2$7, createElementVNode("span", {
41474
41545
  class: "check-wrap-btn",
41475
41546
  onClick: refreshTable
41476
- }, "\u70B9\u51FB\u67E5\u770B")])])) : createCommentVNode("v-if", true), createCommentVNode(" \u5168\u9009 \u9009\u62E9\u6846 "), withDirectives(createElementVNode("div", _hoisted_3$4, [createElementVNode("p", _hoisted_4$4, [createElementVNode("span", null, "\u5DF2\u52FE\u9009\u6570\u636E\u5171" + toDisplayString(unref(allSelectedLength)) + "\u6761", 1), withDirectives(createElementVNode("span", null, " \uFF08\u5F53\u524D\u9875" + toDisplayString(unref(state).currentPageSelectedLength) + "\u6761\uFF09 ", 513), [[vShow, unref(state).visibleCheckAllWrapMore]])]), unref(state).visibleCheckAllWrapMore && !props.asyncCount ? (openBlock(), createElementBlock(Fragment, {
41547
+ }, "\u70B9\u51FB\u67E5\u770B")])])) : createCommentVNode("v-if", true), createCommentVNode(" \u5168\u9009 \u9009\u62E9\u6846 "), withDirectives(createElementVNode("div", _hoisted_3$6, [createElementVNode("p", _hoisted_4$5, [createElementVNode("span", null, "\u5DF2\u52FE\u9009\u6570\u636E\u5171" + toDisplayString(unref(allSelectedLength)) + "\u6761", 1), withDirectives(createElementVNode("span", null, " \uFF08\u5F53\u524D\u9875" + toDisplayString(unref(state).currentPageSelectedLength) + "\u6761\uFF09 ", 513), [[vShow, unref(state).visibleCheckAllWrapMore]])]), unref(state).visibleCheckAllWrapMore && !props.asyncCount ? (openBlock(), createElementBlock(Fragment, {
41477
41548
  key: 0
41478
41549
  }, [!unref(visibleCancelCheckAllBtn) ? (openBlock(), createElementBlock("p", {
41479
41550
  key: 0,
41480
41551
  class: "check-wrap-btn",
41481
41552
  onClick: handleCheckAll
41482
- }, [_ctx.pageVO.total > _ctx.MAX_CHECK_SIZE ? (openBlock(), createElementBlock("span", _hoisted_5$4, [createCommentVNode(" {{ `\u6700\u5927\u52FE\u9009\u201C${tableName}\u201D ${MAX_CHECK_SIZE}\u6761\u6570\u636E` }} "), createTextVNode(toDisplayString(`\u52FE\u9009\u5168\u90E8\u9875 ${_ctx.MAX_CHECK_SIZE}\u6761\u6570\u636E`), 1)])) : (openBlock(), createElementBlock("span", _hoisted_6$4, [createCommentVNode(' {{ $t("1.9.598", { name: tableName, total }) }} '), createTextVNode(toDisplayString(`\u52FE\u9009\u5168\u90E8\u9875 ${_ctx.pageVO.total}\u6761\u6570\u636E`), 1)]))])) : (openBlock(), createElementBlock("p", {
41553
+ }, [_ctx.pageVO.total > _ctx.maxCheckSize ? (openBlock(), createElementBlock("span", _hoisted_5$5, [createCommentVNode(" {{ `\u6700\u5927\u52FE\u9009\u201C${tableName}\u201D ${maxCheckSize}\u6761\u6570\u636E` }} "), createTextVNode(toDisplayString(`\u52FE\u9009\u5168\u90E8\u9875 ${_ctx.maxCheckSize}\u6761\u6570\u636E`), 1)])) : (openBlock(), createElementBlock("span", _hoisted_6$5, [createCommentVNode(' {{ $t("1.9.598", { name: tableName, total }) }} '), createTextVNode(toDisplayString(`\u52FE\u9009\u5168\u90E8\u9875 ${_ctx.pageVO.total}\u6761\u6570\u636E`), 1)]))])) : (openBlock(), createElementBlock("p", {
41483
41554
  key: 1,
41484
41555
  class: "check-wrap-btn",
41485
41556
  onClick: handleCancelAllCheck
@@ -41541,6 +41612,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
41541
41612
  iconOpen: "iconfont icon-a-xitongtubiaozhediejian",
41542
41613
  iconClose: "iconfont icon-a-xitongtubiaotianjia"
41543
41614
  },
41615
+ "keyboard-config": _ctx.columnConfig.keyboardConfig || {},
41544
41616
  onCellDblclick: rowdblclick,
41545
41617
  onCellClick: handlerClickRow,
41546
41618
  onCheckboxChange: selectionChange,
@@ -41550,7 +41622,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
41550
41622
  onScroll: handlerScroll,
41551
41623
  onCellMouseenter: handleCellMouseenter
41552
41624
  }, {
41553
- empty: withCtx(() => [unref(state).isShowEmpty ? (openBlock(), createElementBlock("div", _hoisted_9$4, [createVNode(script$c, {
41625
+ empty: withCtx(() => [unref(state).isShowEmpty ? (openBlock(), createElementBlock("div", _hoisted_9$4, [createVNode(script$b, {
41554
41626
  "no-data-img": props.emptyItems.noDataImg,
41555
41627
  "no-data-tip": props.emptyItems.noDataTip,
41556
41628
  "show-img": !props.isNestTable
@@ -41591,7 +41663,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
41591
41663
  }
41592
41664
  })]),
41593
41665
  _: 3
41594
- }, 8, ["seq-config", "tree-config", "row-id", "show-footer", "checkbox-config", "row-style", "edit-config", "expand-config"]), createCommentVNode(" `${refreshRow}\u6761\u66F4\u65B0` "), withDirectives(createElementVNode("div", {
41666
+ }, 8, ["seq-config", "tree-config", "row-id", "show-footer", "checkbox-config", "row-style", "edit-config", "expand-config", "keyboard-config"]), createCommentVNode(" `${refreshRow}\u6761\u66F4\u65B0` "), withDirectives(createElementVNode("div", {
41595
41667
  class: "refresh",
41596
41668
  onClick: hanldeClickRefresh
41597
41669
  }, [createVNode(unref(NIcon), {
@@ -41602,22 +41674,22 @@ var script$6 = /* @__PURE__ */ defineComponent({
41602
41674
  }
41603
41675
  });
41604
41676
 
41605
- script$6.__file = "packages/big-table/src/BigTable.vue";
41677
+ script$8.__file = "packages/big-table/src/BigTable.vue";
41606
41678
 
41607
- script$6.install = function (app) {
41608
- app.component(script$6.name, script$6);
41679
+ script$8.install = function (app) {
41680
+ app.component(script$8.name, script$8);
41609
41681
  };
41610
41682
 
41611
41683
  const _withScopeId$1 = (n) => (pushScopeId("data-v-726261b7"), n = n(), popScopeId(), n);
41612
- const _hoisted_1$4 = { class: "fields-set-content" };
41613
- const _hoisted_2$4 = { class: "fields-table" };
41614
- const _hoisted_3$3 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ createElementVNode("span", {
41684
+ const _hoisted_1$6 = { class: "fields-set-content" };
41685
+ const _hoisted_2$6 = { class: "fields-table" };
41686
+ const _hoisted_3$5 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ createElementVNode("span", {
41615
41687
  class: "width-show",
41616
41688
  style: { "width": "4%" }
41617
41689
  }, null, -1));
41618
- const _hoisted_4$3 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ createElementVNode("span", { class: "width-large" }, "\u6240\u6709\u5B57\u6BB5", -1));
41619
- const _hoisted_5$3 = { class: "width-show" };
41620
- const _hoisted_6$3 = /* @__PURE__ */ createTextVNode(" \u663E\u793A ");
41690
+ const _hoisted_4$4 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ createElementVNode("span", { class: "width-large" }, "\u6240\u6709\u5B57\u6BB5", -1));
41691
+ const _hoisted_5$4 = { class: "width-show" };
41692
+ const _hoisted_6$4 = /* @__PURE__ */ createTextVNode(" \u663E\u793A ");
41621
41693
  const _hoisted_7$3 = { class: "width-show" };
41622
41694
  const _hoisted_8$3 = /* @__PURE__ */ createTextVNode(" \u6392\u5E8F ");
41623
41695
  const _hoisted_9$3 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ createElementVNode("span", { class: "width-showed" }, "\u56FA\u5B9A", -1));
@@ -41654,11 +41726,11 @@ const _hoisted_29 = {
41654
41726
  const _hoisted_30 = { class: "btn-operate" };
41655
41727
  const _hoisted_31 = /* @__PURE__ */ createTextVNode("\u53D6\u6D88");
41656
41728
  const _hoisted_32 = /* @__PURE__ */ createTextVNode("\u4FDD\u5B58");
41657
- const __default__$5 = create({
41729
+ const __default__$6 = create({
41658
41730
  name: "FieldSet"
41659
41731
  });
41660
- var script$5 = /* @__PURE__ */ defineComponent({
41661
- ...__default__$5,
41732
+ var script$7 = /* @__PURE__ */ defineComponent({
41733
+ ...__default__$6,
41662
41734
  props: {
41663
41735
  fields: {
41664
41736
  type: Array,
@@ -41783,22 +41855,22 @@ var script$5 = /* @__PURE__ */ defineComponent({
41783
41855
  style: { "width": "100%", "height": "100%" }
41784
41856
  }, {
41785
41857
  default: withCtx(() => [
41786
- createElementVNode("div", _hoisted_1$4, [
41787
- createElementVNode("div", _hoisted_2$4, [
41858
+ createElementVNode("div", _hoisted_1$6, [
41859
+ createElementVNode("div", _hoisted_2$6, [
41788
41860
  createElementVNode("div", {
41789
41861
  class: normalizeClass(["setting-title", { "seting-title-api": !unref(state).isCustomSearch }])
41790
41862
  }, [
41791
- _hoisted_3$3,
41863
+ _hoisted_3$5,
41792
41864
  createCommentVNode(" \u5B57\u6BB5\u540D\u79F0 "),
41793
- _hoisted_4$3,
41865
+ _hoisted_4$4,
41794
41866
  createCommentVNode(" \u663E\u793A "),
41795
- createElementVNode("span", _hoisted_5$3, [
41867
+ createElementVNode("span", _hoisted_5$4, [
41796
41868
  showCheckBox("isShow") ? (openBlock(), createBlock(unref(NCheckbox), {
41797
41869
  key: 0,
41798
41870
  checked: calculateCheck("isShow"),
41799
41871
  "onUpdate:checked": _cache[0] || (_cache[0] = ($event) => handleAllCheck($event, "isShow"))
41800
41872
  }, null, 8, ["checked"])) : createCommentVNode("v-if", true),
41801
- _hoisted_6$3
41873
+ _hoisted_6$4
41802
41874
  ]),
41803
41875
  createCommentVNode(" \u6392\u5E8F "),
41804
41876
  createElementVNode("span", _hoisted_7$3, [
@@ -41940,22 +42012,22 @@ var script$5 = /* @__PURE__ */ defineComponent({
41940
42012
  }
41941
42013
  });
41942
42014
 
41943
- script$5.__scopeId = "data-v-726261b7";
41944
- script$5.__file = "packages/field-set/src/FieldSet.vue";
42015
+ script$7.__scopeId = "data-v-726261b7";
42016
+ script$7.__file = "packages/field-set/src/FieldSet.vue";
41945
42017
 
41946
- script$5.install = function (app) {
41947
- app.component(script$5.name, script$5);
42018
+ script$7.install = function (app) {
42019
+ app.component(script$7.name, script$7);
41948
42020
  };
41949
42021
 
41950
- const _hoisted_1$3 = { class: "DragFormLeftItem" };
41951
- const _hoisted_2$3 = {
42022
+ const _hoisted_1$5 = { class: "DragFormLeftItem" };
42023
+ const _hoisted_2$5 = {
41952
42024
  key: 0,
41953
42025
  class: "style-box"
41954
42026
  };
41955
- const _hoisted_3$2 = { class: "style-box" };
41956
- const _hoisted_4$2 = { class: "style-box" };
41957
- const _hoisted_5$2 = { class: "style-box" };
41958
- const _hoisted_6$2 = /* @__PURE__ */ createTextVNode("\u7537");
42027
+ const _hoisted_3$4 = { class: "style-box" };
42028
+ const _hoisted_4$3 = { class: "style-box" };
42029
+ const _hoisted_5$3 = { class: "style-box" };
42030
+ const _hoisted_6$3 = /* @__PURE__ */ createTextVNode("\u7537");
41959
42031
  const _hoisted_7$2 = /* @__PURE__ */ createTextVNode("\u5973");
41960
42032
  const _hoisted_8$2 = { class: "style-box" };
41961
42033
  const _hoisted_9$2 = { class: "style-box" };
@@ -41967,22 +42039,22 @@ const _hoisted_11$1 = {
41967
42039
  key: 7,
41968
42040
  class: "style-box"
41969
42041
  };
41970
- const __default__$4 = {
42042
+ const __default__$5 = {
41971
42043
  name: "DragFormLeftItem"
41972
42044
  };
41973
- var script$4 = /* @__PURE__ */ defineComponent({
41974
- ...__default__$4,
42045
+ var script$6 = /* @__PURE__ */ defineComponent({
42046
+ ...__default__$5,
41975
42047
  props: {
41976
42048
  element: { type: null, required: true }
41977
42049
  },
41978
42050
  setup(__props) {
41979
42051
  return (_ctx, _cache) => {
41980
- return openBlock(), createElementBlock("div", _hoisted_1$3, [
42052
+ return openBlock(), createElementBlock("div", _hoisted_1$5, [
41981
42053
  createElementVNode("div", {
41982
42054
  class: normalizeClass(["left-content", [__props.element.extraField ? "blue-border" : "", "item-" + __props.element.html_type]])
41983
42055
  }, [
41984
42056
  createCommentVNode(" \u6587\u672C\u57DF "),
41985
- __props.element.html_type === "TEXTAREA" ? (openBlock(), createElementBlock("div", _hoisted_2$3, [
42057
+ __props.element.html_type === "TEXTAREA" ? (openBlock(), createElementBlock("div", _hoisted_2$5, [
41986
42058
  createVNode(unref(NInput), {
41987
42059
  class: "style-box-input",
41988
42060
  disabled: "",
@@ -41992,7 +42064,7 @@ var script$4 = /* @__PURE__ */ defineComponent({
41992
42064
  }, null, 8, ["placeholder"])
41993
42065
  ])) : __props.element.html_type === "DATE" || __props.element.html_type === "DATE-INPUT" || __props.element.html_type === "DATETIME-INPUT" ? (openBlock(), createElementBlock(Fragment, { key: 1 }, [
41994
42066
  createCommentVNode(" \u65E5\u671F "),
41995
- createElementVNode("div", _hoisted_3$2, [
42067
+ createElementVNode("div", _hoisted_3$4, [
41996
42068
  createVNode(unref(NDatePicker), {
41997
42069
  disabled: "",
41998
42070
  placeholder: __props.element.placeholder || __props.element.name
@@ -42000,7 +42072,7 @@ var script$4 = /* @__PURE__ */ defineComponent({
42000
42072
  ])
42001
42073
  ], 2112)) : __props.element.html_type === "SELECT" || __props.element.html_type === "SEARCH" || __props.element.html_type === "SEARCH_MORE" || __props.element.html_type === "PHONE_TYPE" || __props.element.html_type === "IDCARD_TYPE" || __props.element.html_type === "LABEL" ? (openBlock(), createElementBlock(Fragment, { key: 2 }, [
42002
42074
  createCommentVNode(" \u4E0B\u62C9 \u6807\u7B7E "),
42003
- createElementVNode("div", _hoisted_4$2, [
42075
+ createElementVNode("div", _hoisted_4$3, [
42004
42076
  createVNode(unref(NSelect), {
42005
42077
  disabled: "",
42006
42078
  options: []
@@ -42008,13 +42080,13 @@ var script$4 = /* @__PURE__ */ defineComponent({
42008
42080
  ])
42009
42081
  ], 2112)) : __props.element.html_type === "RADIO" ? (openBlock(), createElementBlock(Fragment, { key: 3 }, [
42010
42082
  createCommentVNode(" \u5355\u9009 "),
42011
- createElementVNode("div", _hoisted_5$2, [
42083
+ createElementVNode("div", _hoisted_5$3, [
42012
42084
  createVNode(unref(NRadio), {
42013
42085
  disabled: "",
42014
42086
  defaultChecked: ""
42015
42087
  }, {
42016
42088
  default: withCtx(() => [
42017
- _hoisted_6$2
42089
+ _hoisted_6$3
42018
42090
  ]),
42019
42091
  _: 1
42020
42092
  }),
@@ -42068,18 +42140,18 @@ var script$4 = /* @__PURE__ */ defineComponent({
42068
42140
  }
42069
42141
  });
42070
42142
 
42071
- script$4.__scopeId = "data-v-55852966";
42072
- script$4.__file = "packages/drag-layout/src/DragFormLeftItem.vue";
42143
+ script$6.__scopeId = "data-v-55852966";
42144
+ script$6.__file = "packages/drag-layout/src/DragFormLeftItem.vue";
42073
42145
 
42074
- const _hoisted_1$2 = { class: "DragFormRightItem" };
42075
- const _hoisted_2$2 = {
42146
+ const _hoisted_1$4 = { class: "DragFormRightItem" };
42147
+ const _hoisted_2$4 = {
42076
42148
  key: 0,
42077
42149
  class: "red"
42078
42150
  };
42079
- const _hoisted_3$1 = { class: "form-btn" };
42080
- const _hoisted_4$1 = /* @__PURE__ */ createTextVNode("\u5FC5\u586B");
42081
- const _hoisted_5$1 = /* @__PURE__ */ createTextVNode("\u4FEE\u6539");
42082
- const _hoisted_6$1 = /* @__PURE__ */ createTextVNode("\u79FB\u9664");
42151
+ const _hoisted_3$3 = { class: "form-btn" };
42152
+ const _hoisted_4$2 = /* @__PURE__ */ createTextVNode("\u5FC5\u586B");
42153
+ const _hoisted_5$2 = /* @__PURE__ */ createTextVNode("\u4FEE\u6539");
42154
+ const _hoisted_6$2 = /* @__PURE__ */ createTextVNode("\u79FB\u9664");
42083
42155
  const _hoisted_7$1 = {
42084
42156
  key: 0,
42085
42157
  class: "red"
@@ -42088,11 +42160,11 @@ const _hoisted_8$1 = { class: "form-btn" };
42088
42160
  const _hoisted_9$1 = /* @__PURE__ */ createTextVNode("\u5FC5\u586B");
42089
42161
  const _hoisted_10$1 = /* @__PURE__ */ createTextVNode("\u4FEE\u6539");
42090
42162
  const _hoisted_11 = /* @__PURE__ */ createTextVNode("\u79FB\u9664");
42091
- const __default__$3 = {
42163
+ const __default__$4 = {
42092
42164
  name: "DragFormRightItem"
42093
42165
  };
42094
- var script$3 = /* @__PURE__ */ defineComponent({
42095
- ...__default__$3,
42166
+ var script$5 = /* @__PURE__ */ defineComponent({
42167
+ ...__default__$4,
42096
42168
  props: {
42097
42169
  fields: { type: null, required: false },
42098
42170
  element: { type: null, required: true },
@@ -42160,7 +42232,7 @@ var script$3 = /* @__PURE__ */ defineComponent({
42160
42232
  }, { immediate: true, deep: true });
42161
42233
  return (_ctx, _cache) => {
42162
42234
  const _component_DragFormRightItem = resolveComponent("DragFormRightItem", true);
42163
- return openBlock(), createElementBlock("div", _hoisted_1$2, [
42235
+ return openBlock(), createElementBlock("div", _hoisted_1$4, [
42164
42236
  __props.element.html_type === "COMBINATION" ? (openBlock(), createElementBlock("div", {
42165
42237
  key: 0,
42166
42238
  class: normalizeClass(["combination-item", {
@@ -42168,9 +42240,9 @@ var script$3 = /* @__PURE__ */ defineComponent({
42168
42240
  }])
42169
42241
  }, [
42170
42242
  createElementVNode("div", null, [
42171
- __props.element.is_null == 0 ? (openBlock(), createElementBlock("span", _hoisted_2$2, "*")) : createCommentVNode("v-if", true),
42243
+ __props.element.is_null == 0 ? (openBlock(), createElementBlock("span", _hoisted_2$4, "*")) : createCommentVNode("v-if", true),
42172
42244
  createTextVNode(" " + toDisplayString(__props.element.name) + " ", 1),
42173
- createElementVNode("div", _hoisted_3$1, [
42245
+ createElementVNode("div", _hoisted_3$3, [
42174
42246
  __props.element.html_type != "TEXT" ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
42175
42247
  __props.element.is_edit == 1 && !isLineType(__props.element.html_type) ? (openBlock(), createBlock(unref(NButton), {
42176
42248
  key: 0,
@@ -42190,7 +42262,7 @@ var script$3 = /* @__PURE__ */ defineComponent({
42190
42262
  onClick: _cache[1] || (_cache[1] = ($event) => handlechangNull(__props.element))
42191
42263
  }, {
42192
42264
  default: withCtx(() => [
42193
- _hoisted_4$1
42265
+ _hoisted_4$2
42194
42266
  ]),
42195
42267
  _: 1
42196
42268
  })) : createCommentVNode("v-if", true),
@@ -42200,7 +42272,7 @@ var script$3 = /* @__PURE__ */ defineComponent({
42200
42272
  onClick: _cache[2] || (_cache[2] = ($event) => handleEdit(__props.element, __props.index, "edit"))
42201
42273
  }, {
42202
42274
  default: withCtx(() => [
42203
- _hoisted_5$1
42275
+ _hoisted_5$2
42204
42276
  ]),
42205
42277
  _: 1
42206
42278
  }, 512), [
@@ -42214,7 +42286,7 @@ var script$3 = /* @__PURE__ */ defineComponent({
42214
42286
  onClick: _cache[3] || (_cache[3] = ($event) => handleDelete(__props.element, __props.index))
42215
42287
  }, {
42216
42288
  default: withCtx(() => [
42217
- _hoisted_6$1
42289
+ _hoisted_6$2
42218
42290
  ]),
42219
42291
  _: 1
42220
42292
  })) : createCommentVNode("v-if", true)
@@ -42335,25 +42407,25 @@ var script$3 = /* @__PURE__ */ defineComponent({
42335
42407
  }
42336
42408
  });
42337
42409
 
42338
- script$3.__scopeId = "data-v-2d9603cc";
42339
- script$3.__file = "packages/drag-layout/src/DragFormRightItem.vue";
42410
+ script$5.__scopeId = "data-v-2d9603cc";
42411
+ script$5.__file = "packages/drag-layout/src/DragFormRightItem.vue";
42340
42412
 
42341
42413
  const _withScopeId = (n) => (pushScopeId("data-v-3b2d7d19"), n = n(), popScopeId(), n);
42342
- const _hoisted_1$1 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createElementVNode("div", { class: "border-box" }, null, -1));
42343
- const _hoisted_2$1 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createElementVNode("div", { class: "info-header" }, "\u5907\u9009\u5B57\u6BB5", -1));
42344
- const _hoisted_3 = { class: "form-area" };
42345
- const _hoisted_4 = { class: "info-header" };
42346
- const _hoisted_5 = /* @__PURE__ */ createTextVNode("\u65B0\u5EFA\u5206\u884C\u7B26");
42347
- const _hoisted_6 = /* @__PURE__ */ createTextVNode("\u65B0\u5EFA\u5206\u7EBF\u680F");
42414
+ const _hoisted_1$3 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createElementVNode("div", { class: "border-box" }, null, -1));
42415
+ const _hoisted_2$3 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createElementVNode("div", { class: "info-header" }, "\u5907\u9009\u5B57\u6BB5", -1));
42416
+ const _hoisted_3$2 = { class: "form-area" };
42417
+ const _hoisted_4$1 = { class: "info-header" };
42418
+ const _hoisted_5$1 = /* @__PURE__ */ createTextVNode("\u65B0\u5EFA\u5206\u884C\u7B26");
42419
+ const _hoisted_6$1 = /* @__PURE__ */ createTextVNode("\u65B0\u5EFA\u5206\u7EBF\u680F");
42348
42420
  const _hoisted_7 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createElementVNode("label", { class: "new-name" }, "\u540D\u79F0", -1));
42349
42421
  const _hoisted_8 = /* @__PURE__ */ createTextVNode(" \u9ED8\u8BA4\u5C55\u5F00 ");
42350
42422
  const _hoisted_9 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createElementVNode("br", null, null, -1));
42351
42423
  const _hoisted_10 = /* @__PURE__ */ createTextVNode(" \u4E0D\u53EF\u6298\u53E0 ");
42352
- const __default__$2 = create({
42424
+ const __default__$3 = create({
42353
42425
  name: "DragLayout"
42354
42426
  });
42355
- var script$2 = /* @__PURE__ */ defineComponent({
42356
- ...__default__$2,
42427
+ var script$4 = /* @__PURE__ */ defineComponent({
42428
+ ...__default__$3,
42357
42429
  props: {
42358
42430
  leftList: { type: Array, required: false, default: () => [] },
42359
42431
  rightList: { type: Array, required: false, default: () => [] },
@@ -42659,14 +42731,14 @@ var script$2 = /* @__PURE__ */ defineComponent({
42659
42731
  ref_key: "dragLayoutContainer",
42660
42732
  ref: dragLayoutContainer
42661
42733
  }, [
42662
- _hoisted_1$1,
42734
+ _hoisted_1$3,
42663
42735
  createCommentVNode(" \u5DE6\u8FB9 "),
42664
42736
  createElementVNode("div", {
42665
42737
  class: "text-area",
42666
42738
  ref_key: "textArea",
42667
42739
  ref: textArea
42668
42740
  }, [
42669
- _hoisted_2$1,
42741
+ _hoisted_2$3,
42670
42742
  createVNode(unref(draggable), {
42671
42743
  class: "min-height text-draggable",
42672
42744
  itemKey: "val_key",
@@ -42680,7 +42752,7 @@ var script$2 = /* @__PURE__ */ defineComponent({
42680
42752
  item: withCtx(({ element }) => [
42681
42753
  createElementVNode("li", null, [
42682
42754
  renderSlot(_ctx.$slots, "leftItem", { itemData: element }, () => [
42683
- createVNode(script$4, { element }, null, 8, ["element"])
42755
+ createVNode(script$6, { element }, null, 8, ["element"])
42684
42756
  ])
42685
42757
  ])
42686
42758
  ]),
@@ -42688,8 +42760,8 @@ var script$2 = /* @__PURE__ */ defineComponent({
42688
42760
  }, 8, ["modelValue"])
42689
42761
  ], 512),
42690
42762
  createCommentVNode(" \u53F3\u8FB9 "),
42691
- createElementVNode("div", _hoisted_3, [
42692
- createElementVNode("div", _hoisted_4, [
42763
+ createElementVNode("div", _hoisted_3$2, [
42764
+ createElementVNode("div", _hoisted_4$1, [
42693
42765
  createVNode(unref(NButton), {
42694
42766
  class: "add-divider",
42695
42767
  dashed: "",
@@ -42697,7 +42769,7 @@ var script$2 = /* @__PURE__ */ defineComponent({
42697
42769
  onClick: handlerAddBranchLine
42698
42770
  }, {
42699
42771
  default: withCtx(() => [
42700
- _hoisted_5
42772
+ _hoisted_5$1
42701
42773
  ]),
42702
42774
  _: 1
42703
42775
  }),
@@ -42708,7 +42780,7 @@ var script$2 = /* @__PURE__ */ defineComponent({
42708
42780
  onClick: handlerAddLine
42709
42781
  }, {
42710
42782
  default: withCtx(() => [
42711
- _hoisted_6
42783
+ _hoisted_6$1
42712
42784
  ]),
42713
42785
  _: 1
42714
42786
  })
@@ -42734,7 +42806,7 @@ var script$2 = /* @__PURE__ */ defineComponent({
42734
42806
  })
42735
42807
  }, [
42736
42808
  renderSlot(_ctx.$slots, "rightItem", { itemData: element }, () => [
42737
- createVNode(script$3, {
42809
+ createVNode(script$5, {
42738
42810
  element,
42739
42811
  index,
42740
42812
  onHandleEdit: handleEdit,
@@ -42996,11 +43068,11 @@ var script$2 = /* @__PURE__ */ defineComponent({
42996
43068
  }
42997
43069
  });
42998
43070
 
42999
- script$2.__scopeId = "data-v-3b2d7d19";
43000
- script$2.__file = "packages/drag-layout/src/DragLayout.vue";
43071
+ script$4.__scopeId = "data-v-3b2d7d19";
43072
+ script$4.__file = "packages/drag-layout/src/DragLayout.vue";
43001
43073
 
43002
- script$2.install = function (app) {
43003
- app.component(script$2.name, script$2);
43074
+ script$4.install = function (app) {
43075
+ app.component(script$4.name, script$4);
43004
43076
  };
43005
43077
 
43006
43078
  function t(t2, e2, r2, n2, o2, i2, a2) {
@@ -45082,13 +45154,13 @@ var qi = "".concat("http://127.0.0.1:11111", "/services/print"), Hi = "".concat(
45082
45154
  } }], i2 && r(o2.prototype, i2), t2;
45083
45155
  }();
45084
45156
 
45085
- const _hoisted_1 = { class: "content" };
45086
- const _hoisted_2 = /* @__PURE__ */ createTextVNode("\u767B\u5F55");
45087
- const __default__$1 = {
45157
+ const _hoisted_1$2 = { class: "content" };
45158
+ const _hoisted_2$2 = /* @__PURE__ */ createTextVNode("\u767B\u5F55");
45159
+ const __default__$2 = {
45088
45160
  name: "IdentityVerificationModal"
45089
45161
  };
45090
- var script$1 = /* @__PURE__ */ defineComponent({
45091
- ...__default__$1,
45162
+ var script$3 = /* @__PURE__ */ defineComponent({
45163
+ ...__default__$2,
45092
45164
  props: {
45093
45165
  verifyUser: { type: Function, required: false, default: () => Promise.resolve() },
45094
45166
  identityVerificationTitle: { type: String, required: false },
@@ -45153,7 +45225,7 @@ var script$1 = /* @__PURE__ */ defineComponent({
45153
45225
  onAfterLeave: handleClickClose
45154
45226
  }, {
45155
45227
  default: withCtx(() => [
45156
- createElementVNode("div", _hoisted_1, [
45228
+ createElementVNode("div", _hoisted_1$2, [
45157
45229
  createVNode(unref(NForm), {
45158
45230
  class: "login-form",
45159
45231
  ref_key: "formRef",
@@ -45191,7 +45263,7 @@ var script$1 = /* @__PURE__ */ defineComponent({
45191
45263
  onClick: handleClickSubmit
45192
45264
  }, {
45193
45265
  default: withCtx(() => [
45194
- _hoisted_2
45266
+ _hoisted_2$2
45195
45267
  ]),
45196
45268
  _: 1
45197
45269
  })
@@ -45209,14 +45281,14 @@ var script$1 = /* @__PURE__ */ defineComponent({
45209
45281
  }
45210
45282
  });
45211
45283
 
45212
- script$1.__scopeId = "data-v-06588d4e";
45213
- script$1.__file = "packages/button-print/src/components/IdentityVerification.vue";
45284
+ script$3.__scopeId = "data-v-06588d4e";
45285
+ script$3.__file = "packages/button-print/src/components/IdentityVerification.vue";
45214
45286
 
45215
- const __default__ = create({
45287
+ const __default__$1 = create({
45216
45288
  name: "ButtonPrint"
45217
45289
  });
45218
- var script = /* @__PURE__ */ defineComponent({
45219
- ...__default__,
45290
+ var script$2 = /* @__PURE__ */ defineComponent({
45291
+ ...__default__$1,
45220
45292
  props: {
45221
45293
  btnText: { type: String, required: false, default: "\u6253\u5370" },
45222
45294
  printText: { type: String, required: false, default: "\u76F4\u63A5\u6253\u5370" },
@@ -45596,7 +45668,7 @@ var script = /* @__PURE__ */ defineComponent({
45596
45668
  ]),
45597
45669
  _: 3
45598
45670
  }, 8, ["show", "options"]),
45599
- createVNode(script$1, mergeProps({
45671
+ createVNode(script$3, mergeProps({
45600
45672
  modelValue: unref(state).identityVerification.visible,
45601
45673
  "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => unref(state).identityVerification.visible = $event)
45602
45674
  }, _ctx.$attrs, { onSuccess: verifiySuccess }), null, 16, ["modelValue"])
@@ -45605,8 +45677,1152 @@ var script = /* @__PURE__ */ defineComponent({
45605
45677
  }
45606
45678
  });
45607
45679
 
45608
- script.__scopeId = "data-v-1e5281d7";
45609
- script.__file = "packages/button-print/src/ButtonPrint.vue";
45680
+ script$2.__scopeId = "data-v-1e5281d7";
45681
+ script$2.__file = "packages/button-print/src/ButtonPrint.vue";
45682
+
45683
+ script$2.install = function (app) {
45684
+ app.component(script$2.name, script$2);
45685
+ };
45686
+
45687
+ const _hoisted_1$1 = {
45688
+ class: "search-tree-wrap"
45689
+ };
45690
+ const _hoisted_2$1 = {
45691
+ style: {
45692
+ "text-align": "center"
45693
+ }
45694
+ };
45695
+ const _hoisted_3$1 = {
45696
+ key: 1,
45697
+ class: "load-more-btn-wrap"
45698
+ };
45699
+ var script$1 = /* @__PURE__ */ defineComponent({
45700
+ props: {
45701
+ visible: {
45702
+ type: Boolean,
45703
+ required: true,
45704
+ default: false
45705
+ },
45706
+ searchNoMore: {
45707
+ type: Boolean,
45708
+ required: false,
45709
+ default: false
45710
+ },
45711
+ loadMorenLoadinng: {
45712
+ type: Boolean,
45713
+ required: false,
45714
+ default: false
45715
+ },
45716
+ formatTreeData: {
45717
+ type: Array,
45718
+ required: false,
45719
+ default: () => []
45720
+ },
45721
+ searchValue: {
45722
+ type: String,
45723
+ required: false
45724
+ },
45725
+ defaultExpandedKeys: {
45726
+ type: Array,
45727
+ required: true
45728
+ },
45729
+ allCheckedKeys: {
45730
+ type: null,
45731
+ required: false
45732
+ },
45733
+ dataListKeys: {
45734
+ type: null,
45735
+ required: false
45736
+ }
45737
+ },
45738
+ emits: ["addCheckedkeysMain", "removeCheckedkeysMain", "addCheckedkeysOther", "removeCheckedkeysOther", "searchOnloadMore"],
45739
+ setup(__props, { expose, emit }) {
45740
+ const props = __props;
45741
+ const state = reactive({
45742
+ expandedKeys: [],
45743
+ autoExpandParent: true,
45744
+ checkedKeys: [],
45745
+ defaultCheckedKeys: {
45746
+ main: [],
45747
+ other: []
45748
+ }
45749
+ });
45750
+ const dataLen = computed(() => props.formatTreeData?.length || 0);
45751
+ const resetData = () => {
45752
+ state.checkedKeys = [];
45753
+ state.expandedKeys = [];
45754
+ state.autoExpandParent = true;
45755
+ state.defaultCheckedKeys.main = [];
45756
+ state.defaultCheckedKeys.other = [];
45757
+ };
45758
+ const emitCheckedkeys = () => {
45759
+ emitCheckedkeysMain();
45760
+ emitCheckedkeysOther();
45761
+ setDefaultCheckedKeys();
45762
+ };
45763
+ const emitCheckedkeysMain = () => {
45764
+ let searchCheckedKeysMain = state.checkedKeys.filter((key) => {
45765
+ return props.dataListKeys.main.includes(key);
45766
+ });
45767
+ let defaultCheckedKeysMain = state.defaultCheckedKeys.main;
45768
+ let { add, remove } = calcChangeKeys(defaultCheckedKeysMain, searchCheckedKeysMain);
45769
+ emit("addCheckedkeysMain", add);
45770
+ emit("removeCheckedkeysMain", remove);
45771
+ };
45772
+ const emitCheckedkeysOther = () => {
45773
+ let searchCheckedKeysOther = state.checkedKeys.filter((key) => {
45774
+ return props.dataListKeys.other.includes(key);
45775
+ });
45776
+ let defaultCheckedKeysOther = state.defaultCheckedKeys.other;
45777
+ let { add, remove } = calcChangeKeys(defaultCheckedKeysOther, searchCheckedKeysOther);
45778
+ emit("addCheckedkeysOther", add);
45779
+ emit("removeCheckedkeysOther", remove);
45780
+ };
45781
+ const calcChangeKeys = (defaultCheckedKeys, currentCheckedKeys) => {
45782
+ let add = [];
45783
+ let remove = [];
45784
+ currentCheckedKeys.forEach((key) => {
45785
+ if (!defaultCheckedKeys.includes(key)) {
45786
+ add.push(key);
45787
+ }
45788
+ });
45789
+ defaultCheckedKeys.forEach((key) => {
45790
+ if (!currentCheckedKeys.includes(key)) {
45791
+ remove.push(key);
45792
+ }
45793
+ });
45794
+ return {
45795
+ add,
45796
+ remove
45797
+ };
45798
+ };
45799
+ const emptyCheckedKeys = () => {
45800
+ state.checkedKeys = [];
45801
+ emitCheckedkeys();
45802
+ };
45803
+ const setDefaultCheckedKeys = () => {
45804
+ setDefaultCheckedKeysMain();
45805
+ setDefaultCheckedKeysOther();
45806
+ setCurrentCheckedKeys();
45807
+ };
45808
+ const setDefaultCheckedKeysMain = () => {
45809
+ state.defaultCheckedKeys.main = props.dataListKeys.main.filter((key) => {
45810
+ return props.allCheckedKeys.main.includes(key);
45811
+ });
45812
+ };
45813
+ const setDefaultCheckedKeysOther = () => {
45814
+ state.defaultCheckedKeys.other = props.dataListKeys.other.filter((key) => {
45815
+ return props.allCheckedKeys.other.includes(key);
45816
+ });
45817
+ };
45818
+ const setCurrentCheckedKeys = () => {
45819
+ let { main, other } = state.defaultCheckedKeys;
45820
+ let res = [... /* @__PURE__ */new Set([...main, ...other])];
45821
+ state.checkedKeys = res;
45822
+ };
45823
+ const onCheck = () => {
45824
+ emitCheckedkeys();
45825
+ };
45826
+ const onExpand = (expandedKeys) => {
45827
+ state.expandedKeys = expandedKeys;
45828
+ state.autoExpandParent = false;
45829
+ };
45830
+ const searchOnloadMore = () => {
45831
+ emit("searchOnloadMore");
45832
+ };
45833
+ const renderLabel = ({ option }) => {
45834
+ return createVNode("div", {
45835
+ "class": "search-tree-item"
45836
+ }, [createVNode("div", {
45837
+ "class": "info-wrap"
45838
+ }, [createVNode(NTooltip, {
45839
+ "trigger": "hover"
45840
+ }, {
45841
+ default: () => `${option.title} ${option.sub_title || ""}`,
45842
+ trigger: () => createVNode("p", {
45843
+ "class": "info-wrap-top",
45844
+ "style": "margin: 0"
45845
+ }, [createVNode("span", {
45846
+ "class": "info-wrap-title"
45847
+ }, [createVNode("span", {
45848
+ "class": "c-title"
45849
+ }, [option.title]), createTextVNode("\u2009"), createVNode("span", {
45850
+ "class": "c-sub-title"
45851
+ }, [option.sub_title])])])
45852
+ })])]);
45853
+ };
45854
+ watch(() => props.defaultExpandedKeys, (val) => {
45855
+ state.expandedKeys = val;
45856
+ }, {
45857
+ immediate: true,
45858
+ deep: true
45859
+ });
45860
+ watch(() => props.visible, (val) => {
45861
+ if (!val) {
45862
+ resetData();
45863
+ return;
45864
+ }
45865
+ setDefaultCheckedKeys();
45866
+ });
45867
+ watch(() => dataLen, (val) => {
45868
+ if (val.value > 0) {
45869
+ setDefaultCheckedKeys();
45870
+ }
45871
+ });
45872
+ expose({
45873
+ setDefaultCheckedKeys,
45874
+ checkedKeys: state.checkedKeys,
45875
+ emptyCheckedKeys
45876
+ });
45877
+ return (_ctx, _cache) => {
45878
+ return withDirectives((openBlock(), createElementBlock("div", _hoisted_1$1, [createVNode(unref(NTree), mergeProps(_ctx.$attrs, {
45879
+ ref: "searchTree",
45880
+ "checked-keys": unref(state).checkedKeys,
45881
+ "onUpdate:checked-keys": _cache[0] || (_cache[0] = ($event) => unref(state).checkedKeys = $event),
45882
+ "onUpdate:expandedKeys": onExpand,
45883
+ "onUpdate:checkedKeys": onCheck,
45884
+ checkable: "",
45885
+ cascade: "",
45886
+ "allow-checking-not-loaded": "",
45887
+ "check-strategy": "all",
45888
+ selectable: false,
45889
+ "expanded-keys": unref(state).expandedKeys,
45890
+ data: __props.formatTreeData,
45891
+ "render-label": renderLabel
45892
+ }), null, 16, ["checked-keys", "expanded-keys", "data"]), withDirectives(createElementVNode("div", _hoisted_2$1, [createCommentVNode(" loadMorenLoadinng "), __props.loadMorenLoadinng ? (openBlock(), createBlock(unref(NSpin), {
45893
+ key: 0
45894
+ })) : (openBlock(), createElementBlock("div", _hoisted_3$1, [createVNode(unref(NIcon), {
45895
+ component: unref(Search),
45896
+ class: "search-input-icon"
45897
+ }, null, 8, ["component"]), createElementVNode("div", {
45898
+ class: "load-more-btn",
45899
+ onClick: searchOnloadMore
45900
+ }, " \u52A0\u8F7D\u66F4\u591A ")]))], 512), [[vShow, !__props.searchNoMore]])], 512)), [[vShow, __props.visible]]);
45901
+ };
45902
+ }
45903
+ });
45904
+
45905
+ script$1.__scopeId = "data-v-3b67e11b";
45906
+ script$1.__file = "packages/select-person/src/search-tree.vue";
45907
+
45908
+ const filterTree = ({ value, data, prop, filter, filterXor, children, visible, filterChildren = true, callback }) => {
45909
+ visible = visible || "visible";
45910
+ children = children || "children";
45911
+ prop = prop || "text";
45912
+ const filterNodeMethod = function(value2, data2) {
45913
+ if (!value2) {
45914
+ return true;
45915
+ }
45916
+ let flag = (data2[prop] || "").indexOf(value2) !== -1;
45917
+ return filterXor ? !flag : flag;
45918
+ };
45919
+ const traverse = function(node) {
45920
+ const childNodes = node[children] || [];
45921
+ childNodes.forEach((child) => {
45922
+ callback && callback(child);
45923
+ child[visible] = !node.root && !filterChildren && node[visible] || filterNodeMethod.call(child, value, child, prop);
45924
+ traverse(child);
45925
+ });
45926
+ if (!node[visible] && childNodes.length) {
45927
+ let allHidden = true;
45928
+ allHidden = !childNodes.some((child) => child[visible]);
45929
+ node[visible] = allHidden === false;
45930
+ }
45931
+ };
45932
+ let totalData = {
45933
+ root: true
45934
+ };
45935
+ totalData[children] = data;
45936
+ traverse(totalData);
45937
+ if (filter) {
45938
+ let copyData = data.slice();
45939
+ let filterHandle = (filterData) => {
45940
+ return filterData.filter((item, index) => {
45941
+ if (item[visible]) {
45942
+ if (item[children]) {
45943
+ item[children] = filterHandle(item[children]);
45944
+ }
45945
+ return true;
45946
+ }
45947
+ return false;
45948
+ });
45949
+ };
45950
+ return filterHandle(copyData);
45951
+ }
45952
+ };
45953
+
45954
+ const _hoisted_1 = {
45955
+ class: "personnel"
45956
+ };
45957
+ const _hoisted_2 = {
45958
+ class: "people-tree"
45959
+ };
45960
+ const _hoisted_3 = {
45961
+ class: "people-tree-item people-tree-left"
45962
+ };
45963
+ const _hoisted_4 = /* @__PURE__ */ createTextVNode("\u5168\u9009");
45964
+ const _hoisted_5 = /* @__PURE__ */ createTextVNode("\u5168\u9009");
45965
+ const _hoisted_6 = {
45966
+ class: "people-tree-item tags-box"
45967
+ };
45968
+ const __default__ = create({
45969
+ name: "SelectPerson"
45970
+ });
45971
+ var script = /* @__PURE__ */ defineComponent({
45972
+ ...__default__,
45973
+ props: {
45974
+ visible: {
45975
+ type: Boolean,
45976
+ required: false,
45977
+ default: false
45978
+ },
45979
+ isDetail: {
45980
+ type: Boolean,
45981
+ required: false,
45982
+ default: false
45983
+ },
45984
+ defaultList: {
45985
+ type: Array,
45986
+ required: false,
45987
+ default: () => []
45988
+ },
45989
+ data: {
45990
+ type: Array,
45991
+ required: false,
45992
+ default: () => []
45993
+ },
45994
+ searchPlaceholder: {
45995
+ type: String,
45996
+ required: false,
45997
+ default: "\u8F93\u5165\u5173\u952E\u5B57\u641C\u7D22"
45998
+ },
45999
+ searchButtonText: {
46000
+ type: String,
46001
+ required: false,
46002
+ default: "\u641C\u7D22"
46003
+ },
46004
+ wordbook: {
46005
+ type: null,
46006
+ required: true,
46007
+ default: () => ({})
46008
+ },
46009
+ wordbookChild: {
46010
+ type: null,
46011
+ required: false,
46012
+ default: () => ({})
46013
+ },
46014
+ SearchLoadMore: {
46015
+ type: Boolean,
46016
+ required: false,
46017
+ default: false
46018
+ },
46019
+ queryMainTreeData: {
46020
+ type: Function,
46021
+ required: false
46022
+ },
46023
+ queryLoadChildData: {
46024
+ type: Function,
46025
+ required: false
46026
+ },
46027
+ queryTreeSearch: {
46028
+ type: Function,
46029
+ required: false
46030
+ }
46031
+ },
46032
+ emits: ["check", "pubCheckedTreeItem", "handleOk", "change", "submitData", "update:visible"],
46033
+ setup(__props, { emit }) {
46034
+ const props = __props;
46035
+ window.$message = useMessage();
46036
+ const FIXEDKEY = "8982eeb4-0439-4100-9805-8cdd12b2256c-front-end-fixed-key";
46037
+ const searchTree = ref(null);
46038
+ const state = reactive({
46039
+ treeData: {
46040
+ main: [],
46041
+ search: []
46042
+ },
46043
+ expandedKeys: [],
46044
+ autoExpandParent: true,
46045
+ dataList: {
46046
+ main: [],
46047
+ other: []
46048
+ },
46049
+ checkedKeys: {
46050
+ main: [],
46051
+ other: []
46052
+ },
46053
+ search: {
46054
+ defaultExpandedKeys: [],
46055
+ status: 0,
46056
+ dataListKeys: {
46057
+ main: [],
46058
+ other: []
46059
+ },
46060
+ records: 0
46061
+ },
46062
+ searchValue: "",
46063
+ searchPage: 1,
46064
+ searchNoMore: false,
46065
+ title: "",
46066
+ checkedLeafKeys: [],
46067
+ spinning: false,
46068
+ loadMorenLoadinng: false,
46069
+ errorMsg: "",
46070
+ defaultShowList: [],
46071
+ checkedKeysMain: [],
46072
+ cacheParentIdObj: {},
46073
+ singleChecked: false,
46074
+ indeterminate: false,
46075
+ searchIndeterminate: false,
46076
+ searchChecked: false
46077
+ });
46078
+ const searchTreeVisable = computed(() => state.search.status == 2);
46079
+ const dataListMainKeys = computed(() => {
46080
+ if (!state.dataList.main.length)
46081
+ return [];
46082
+ return state.dataList.main.map((i) => i.key);
46083
+ });
46084
+ const dataListOtherKeys = computed(() => {
46085
+ if (!state.dataList.other.length)
46086
+ return [];
46087
+ return state.dataList.other.map((i) => i.key);
46088
+ });
46089
+ const checkedTreeItem = computed(() => {
46090
+ let otherItems = state.dataList.other.filter((item) => {
46091
+ return state.checkedKeys.other.includes(item.key);
46092
+ });
46093
+ let mainItems = state.dataList.main.filter((item) => {
46094
+ let { isLeaf, key } = item;
46095
+ let parentId = getParentId(item);
46096
+ let showKeys = [...state.checkedKeys.main, ...otherItems];
46097
+ let checked = showKeys.includes(key);
46098
+ if (isLeaf && parentId && state.checkedKeys.main.some((v) => v == parentId)) {
46099
+ checked = false;
46100
+ }
46101
+ return checked;
46102
+ });
46103
+ let list = uniqArrObj([...mainItems, ...otherItems], "key");
46104
+ return list;
46105
+ });
46106
+ const wordbookConfig = computed(() => {
46107
+ const { parent_id_obj, parent_name_obj } = props.wordbook || {};
46108
+ const { user_id_obj, user_name_obj } = props.wordbookChild || {};
46109
+ return {
46110
+ parent_id_obj,
46111
+ parent_name_obj,
46112
+ user_id_obj,
46113
+ user_name_obj
46114
+ };
46115
+ });
46116
+ const getLoadChildData = computed(() => {
46117
+ if (typeof props.queryLoadChildData == "function") {
46118
+ return onLoadData;
46119
+ }
46120
+ return null;
46121
+ });
46122
+ const renderLabel = ({ option }) => {
46123
+ if (option.isLeaf || !option.children) {
46124
+ return createVNode(NTooltip, {
46125
+ "trigger": "hover"
46126
+ }, {
46127
+ default: () => `${option.title} ${option.sub_title || ""}`,
46128
+ trigger: () => createVNode("span", null, [createVNode("span", {
46129
+ "class": "c-title"
46130
+ }, [option.title || option.key, createTextVNode("\u2009 ")]), createVNode("span", {
46131
+ "class": "c-sub-title"
46132
+ }, [option.sub_title])])
46133
+ });
46134
+ }
46135
+ else {
46136
+ return createVNode("span", {
46137
+ "class": "p-title"
46138
+ }, [createVNode("span", null, [option.title || option.key]), treeCount(option.count)]);
46139
+ }
46140
+ };
46141
+ const initDefault = () => {
46142
+ if (getLoadChildData.value) {
46143
+ getDefaultList();
46144
+ }
46145
+ else {
46146
+ nextTick(() => {
46147
+ state.checkedKeys.main = [...props.defaultList];
46148
+ });
46149
+ }
46150
+ };
46151
+ const getDefaultList = () => {
46152
+ let copy = JSON.parse(JSON.stringify(props.defaultList));
46153
+ if (Array.isArray(copy)) {
46154
+ copy.forEach((v) => {
46155
+ handleDefMapping(v);
46156
+ getuniqKey(v);
46157
+ let pId = getParentId(v);
46158
+ state.cacheParentIdObj[pId] = pId;
46159
+ });
46160
+ state.defaultShowList = copy;
46161
+ }
46162
+ };
46163
+ const handleDefMapping = (v) => {
46164
+ const { parent_id_obj, parent_name_obj, user_id_obj, user_name_obj } = wordbookConfig.value || {};
46165
+ const { parent_id_obj_key, parent_name_obj_key } = props.wordbook;
46166
+ const { user_id_obj_key, user_name_obj_key } = props.wordbookChild;
46167
+ v[parent_id_obj] = v[parent_id_obj_key] || v.parent_id;
46168
+ v[parent_name_obj] = v[parent_name_obj_key] || v.parent_name;
46169
+ v[user_id_obj] = v[user_id_obj_key] || v.user_id;
46170
+ v[user_name_obj] = v[user_name_obj_key] || v.user_name;
46171
+ };
46172
+ const staticDataInit = () => {
46173
+ if (!Array.isArray(props.data) || props.data.length == 0)
46174
+ return;
46175
+ state.treeData.main = JSON.parse(JSON.stringify(props.data));
46176
+ generateDataList(state.treeData.main, state.dataList.main);
46177
+ };
46178
+ const getcheckedKeys = () => {
46179
+ let checkedKeysMain = [], checkedKeysOther = [];
46180
+ let copy = JSON.parse(JSON.stringify(props.defaultList));
46181
+ if (Array.isArray(copy)) {
46182
+ copy.forEach((v) => {
46183
+ handleDefMapping(v);
46184
+ let key = getuniqKey(v);
46185
+ checkedKeysMain.push(key);
46186
+ if (String(key).includes(FIXEDKEY)) {
46187
+ checkedKeysOther.push(key);
46188
+ }
46189
+ });
46190
+ }
46191
+ return {
46192
+ checkedKeysMain,
46193
+ checkedKeysOther
46194
+ };
46195
+ };
46196
+ const loadSelected = async () => {
46197
+ try {
46198
+ let list = await Promise.all(state.treeData.main.map(async (v) => {
46199
+ const { parent_id_obj } = props.wordbook || {};
46200
+ if ([v.key, v[parent_id_obj], String(v[parent_id_obj])].includes(state.cacheParentIdObj[v[parent_id_obj]])) {
46201
+ await onLoadData(v);
46202
+ return v;
46203
+ }
46204
+ }));
46205
+ return list;
46206
+ }
46207
+ catch (error) {
46208
+ return Promise.resolve();
46209
+ }
46210
+ };
46211
+ const onLoadData = (option) => {
46212
+ return new Promise(async (resolve) => {
46213
+ if (option.children) {
46214
+ resolve();
46215
+ return;
46216
+ }
46217
+ option.children = await handleLoadChildData(option.key, option);
46218
+ hanldeFilterDefaultShowList(option.children);
46219
+ nextTick(() => {
46220
+ state.treeData.main = [...state.treeData.main];
46221
+ });
46222
+ addCheckedKeysChildrenMain(option);
46223
+ generateDataList(option.children || [], state.dataList.main);
46224
+ resolve();
46225
+ });
46226
+ };
46227
+ const getUsers = async () => {
46228
+ try {
46229
+ if (typeof props.queryMainTreeData !== "function") {
46230
+ return;
46231
+ }
46232
+ state.spinning = true;
46233
+ const { parent_id_obj } = wordbookConfig.value || {};
46234
+ let rows = await props.queryMainTreeData();
46235
+ let list = uniqArrObj(rows || [], parent_id_obj);
46236
+ state.treeData.main = list;
46237
+ generateDataList(state.treeData.main, state.dataList.main);
46238
+ await loadSelected();
46239
+ let { checkedKeysMain, checkedKeysOther } = getcheckedKeys();
46240
+ state.checkedKeys.main.push(...checkedKeysMain);
46241
+ state.checkedKeys.other = [...checkedKeysOther];
46242
+ state.treeData.main.forEach((f) => {
46243
+ if (f && f.children && f.children.length) {
46244
+ let flag = f.children.every((c) => checkedKeysMain.includes(c.key));
46245
+ if (flag && f.key) {
46246
+ state.checkedKeys.main.push(f.key);
46247
+ }
46248
+ }
46249
+ });
46250
+ state.spinning = false;
46251
+ }
46252
+ catch (error) {
46253
+ state.spinning = false;
46254
+ window.$message.error("\u67E5\u8BE2\u5F02\u5E38");
46255
+ }
46256
+ };
46257
+ const loadMainChildData = (searchResultTreeData) => {
46258
+ return new Promise(async (resolve) => {
46259
+ let promises = searchResultTreeData.map(async (item) => {
46260
+ if (item.users) {
46261
+ let mainTreeItem = state.treeData.main.find((mainItem) => mainItem.key == item.key);
46262
+ if (!mainTreeItem || mainTreeItem && !mainTreeItem.children) {
46263
+ if (!mainTreeItem) {
46264
+ mainTreeItem = {
46265
+ ...item
46266
+ };
46267
+ }
46268
+ mainTreeItem.children = await handleLoadChildData(item.key, mainTreeItem);
46269
+ generateDataList(mainTreeItem.children, state.dataList.main);
46270
+ addCheckedKeysChildrenMain(mainTreeItem);
46271
+ }
46272
+ }
46273
+ });
46274
+ await Promise.all(promises);
46275
+ resolve();
46276
+ });
46277
+ };
46278
+ const handleLoadChildData = async (key, option) => {
46279
+ let rows = props.queryLoadChildData && await props.queryLoadChildData(key, option);
46280
+ let list = rows;
46281
+ return list;
46282
+ };
46283
+ const generateDataList = (data, dataList) => {
46284
+ for (let i = 0; i < data.length; i++) {
46285
+ const node = data[i];
46286
+ dataList.push({
46287
+ parentId: getParentId(node),
46288
+ ...node
46289
+ });
46290
+ if (node.children) {
46291
+ generateDataList(node.children, dataList);
46292
+ }
46293
+ }
46294
+ };
46295
+ const addCheckedKeysChildrenMain = (item) => {
46296
+ if (!item.key)
46297
+ return;
46298
+ if (!state.checkedKeys.main.includes(String(item.key)))
46299
+ return false;
46300
+ if (!Array.isArray(item.children))
46301
+ return false;
46302
+ item.children.forEach(({ key }) => {
46303
+ if (state.checkedKeys.main.includes(key) || !key)
46304
+ return false;
46305
+ state.checkedKeys.main.push(key);
46306
+ });
46307
+ };
46308
+ const hanldeFilterDefaultShowList = (list) => {
46309
+ state.defaultShowList = state.defaultShowList.filter((d) => list.findIndex((l) => getuniqKey(d) == getuniqKey(l)) == -1);
46310
+ };
46311
+ const searchFetch = async (data = {}, config = {}) => {
46312
+ if (typeof props.queryTreeSearch !== "function") {
46313
+ staticDataSearch();
46314
+ state.spinning = false;
46315
+ isSearchAllCheck();
46316
+ return;
46317
+ }
46318
+ if (!state.searchValue) {
46319
+ state.search.status = 0;
46320
+ state.search.defaultExpandedKeys = [];
46321
+ state.expandedKeys = [];
46322
+ state.spinning = false;
46323
+ state.searchNoMore = false;
46324
+ return false;
46325
+ }
46326
+ if (!config.loadMoren) {
46327
+ state.search.status = 1;
46328
+ }
46329
+ else {
46330
+ state.loadMorenLoadinng = true;
46331
+ }
46332
+ let rows = await props.queryTreeSearch(state.searchValue, data);
46333
+ let searchResultTreeData = rows;
46334
+ state.loadMorenLoadinng = false;
46335
+ if (!searchResultTreeData || !searchResultTreeData.length) {
46336
+ if (state.searchPage == 1) {
46337
+ state.search.defaultExpandedKeys = [];
46338
+ state.search.status = 3;
46339
+ }
46340
+ else {
46341
+ state.search.status = 2;
46342
+ state.searchNoMore = true;
46343
+ }
46344
+ state.spinning = false;
46345
+ isSearchAllCheck();
46346
+ return false;
46347
+ }
46348
+ const { parent_id_obj, parent_name_obj, user_count_obj } = props.wordbook || {};
46349
+ props.wordbookChild || {};
46350
+ let pObj = {};
46351
+ searchResultTreeData.forEach((item) => {
46352
+ item[parent_id_obj] && (pObj[item[parent_id_obj]] = {
46353
+ key: item[parent_id_obj],
46354
+ users: []
46355
+ });
46356
+ if (item.users) {
46357
+ insertSearchTreeData(item);
46358
+ }
46359
+ else {
46360
+ insertSearchTreeDataOther(item);
46361
+ }
46362
+ });
46363
+ let pList = [];
46364
+ Object.keys(pObj || {}).forEach((v) => {
46365
+ if (v) {
46366
+ pList.push({
46367
+ ...pObj[v]
46368
+ });
46369
+ }
46370
+ });
46371
+ state.treeData.search.length || 0;
46372
+ if (props.SearchLoadMore) {
46373
+ state.searchNoMore = false;
46374
+ }
46375
+ else {
46376
+ state.searchNoMore = true;
46377
+ }
46378
+ await loadMainChildData(pList);
46379
+ generateSearchDataListKeys(searchResultTreeData);
46380
+ hanldeFilterDefaultShowList(searchResultTreeData);
46381
+ refreshSearchTree();
46382
+ state.search.status = 2;
46383
+ state.spinning = false;
46384
+ isSearchAllCheck();
46385
+ };
46386
+ const refreshSearchTree = () => {
46387
+ if (!searchTreeVisable.value)
46388
+ return false;
46389
+ searchTree.value.setDefaultCheckedKeys();
46390
+ nextTick(() => {
46391
+ isSearchAllCheck();
46392
+ });
46393
+ };
46394
+ const generateSearchDataListKeys = (searchResultTreeData) => {
46395
+ searchResultTreeData.forEach((item) => {
46396
+ if (!dataListMainKeys.value.includes(item.key)) {
46397
+ state.search.dataListKeys.other.push(item.key);
46398
+ item.children && item.children.forEach((childItem) => {
46399
+ state.search.dataListKeys.other.push(childItem.key);
46400
+ });
46401
+ return;
46402
+ }
46403
+ state.search.dataListKeys.main.push(item.key);
46404
+ item.children && item.children.forEach((childItem) => {
46405
+ state.search.dataListKeys.main.push(childItem.key);
46406
+ });
46407
+ });
46408
+ };
46409
+ const insertSearchTreeData = (item) => {
46410
+ const { user_count_obj } = props.wordbook || {};
46411
+ state.search.defaultExpandedKeys.push(item.key);
46412
+ hanldeFilterDefaultShowList(item.children || []);
46413
+ if (item[user_count_obj] == item.children.length) {
46414
+ item.disableCheckbox = false;
46415
+ }
46416
+ state.treeData.search.push(item);
46417
+ };
46418
+ const insertSearchTreeDataOther = (item) => {
46419
+ let formatItem = Object.assign({}, item, {
46420
+ isLeaf: true
46421
+ });
46422
+ state.treeData.search.push(formatItem);
46423
+ if (dataListOtherKeys.value.includes(formatItem.key))
46424
+ return false;
46425
+ generateDataList([formatItem], state.dataList.other);
46426
+ };
46427
+ const isSearchAllCheck = () => {
46428
+ nextTick(() => {
46429
+ let skeyArr = state.treeData.search.map((item) => item.key);
46430
+ let serchCheckedKeys = searchTree.value.checkedKeys;
46431
+ state.searchIndeterminate = !!serchCheckedKeys.length && serchCheckedKeys.length < skeyArr.length;
46432
+ state.searchChecked = serchCheckedKeys.length === skeyArr.length;
46433
+ });
46434
+ };
46435
+ const staticDataSearch = () => {
46436
+ if (!state.title) {
46437
+ state.treeData.main = JSON.parse(JSON.stringify(props.data));
46438
+ return;
46439
+ }
46440
+ let copyData = JSON.parse(JSON.stringify(state.treeData.main));
46441
+ filterTree({
46442
+ value: state.title,
46443
+ data: copyData,
46444
+ prop: "title"
46445
+ });
46446
+ const expandedKeys = [];
46447
+ xeUtils.searchTree(copyData, (item) => {
46448
+ if (item.visible) {
46449
+ expandedKeys.push(item.key);
46450
+ }
46451
+ if (item.children?.length) {
46452
+ item.children = item.children.filter((child) => child.visible);
46453
+ }
46454
+ });
46455
+ state.treeData.main = copyData;
46456
+ state.expandedKeys = expandedKeys;
46457
+ };
46458
+ const onExpand = (expandedKeys) => {
46459
+ state.expandedKeys = expandedKeys;
46460
+ state.autoExpandParent = false;
46461
+ };
46462
+ const searchClick = () => {
46463
+ state.searchValue = state.title;
46464
+ state.treeData.search = [];
46465
+ state.search.dataListKeys.other = [];
46466
+ state.search.dataListKeys.main = [];
46467
+ state.search.defaultExpandedKeys = [];
46468
+ state.spinning = true;
46469
+ state.searchPage = 1;
46470
+ searchFetch();
46471
+ };
46472
+ const isAllCheck = (checkedKeys = []) => {
46473
+ if (!checkedKeys || checkedKeys.length == 0) {
46474
+ state.indeterminate = false;
46475
+ state.singleChecked = false;
46476
+ }
46477
+ else {
46478
+ let keyArr = state.treeData.main.map((item) => item.key);
46479
+ let keyArrTemp = keyArr.filter((item) => checkedKeys.indexOf(item) !== -1);
46480
+ state.indeterminate = !(keyArr.length == keyArrTemp.length);
46481
+ state.singleChecked = keyArr.length == keyArrTemp.length;
46482
+ }
46483
+ };
46484
+ const addCheckedkeysMain = (keys) => {
46485
+ let checkedKeys = state.checkedKeys.main;
46486
+ let filterKey = (keys || {}).filter(Boolean);
46487
+ filterKey.forEach((key) => {
46488
+ checkedKeys.push(key);
46489
+ let _getParentKey = getParentKey(key, state.treeData.main);
46490
+ if (!_getParentKey)
46491
+ return;
46492
+ let parent = state.treeData.main.filter((item) => {
46493
+ return item.key == _getParentKey;
46494
+ });
46495
+ let allCheck = (parent[0]?.children || []).every((item) => {
46496
+ return checkedKeys.includes(item.key);
46497
+ });
46498
+ allCheck && checkedKeys.push(_getParentKey);
46499
+ });
46500
+ };
46501
+ const getParentKey = (key, tree) => {
46502
+ let parentKey;
46503
+ for (let i = 0; i < tree.length; i++) {
46504
+ const node = tree[i];
46505
+ if (node.key == key) {
46506
+ parentKey = node.key;
46507
+ return parentKey;
46508
+ }
46509
+ if (node.children) {
46510
+ if (node.children.some((item) => item.key == key)) {
46511
+ parentKey = node.key;
46512
+ }
46513
+ else if (getParentKey(key, node.children)) {
46514
+ parentKey = getParentKey(key, node.children);
46515
+ }
46516
+ }
46517
+ }
46518
+ return parentKey;
46519
+ };
46520
+ const radioChange = (checked) => {
46521
+ if (searchTreeVisable.value) {
46522
+ state.singleChecked = checked;
46523
+ }
46524
+ else {
46525
+ state.searchChecked = checked;
46526
+ }
46527
+ checkAll(checked ? 1 : 2);
46528
+ };
46529
+ const checkAll = (type) => {
46530
+ if (checkAllSearchTree(type))
46531
+ return false;
46532
+ if (type == 1) {
46533
+ state.expandedKeys = [];
46534
+ state.checkedKeys.main = dataListMainKeys.value;
46535
+ }
46536
+ else if (type == 2) {
46537
+ state.checkedKeys.main = [];
46538
+ state.autoExpandParent = true;
46539
+ }
46540
+ };
46541
+ const checkAllSearchTree = (type) => {
46542
+ if (!searchTreeVisable.value)
46543
+ return false;
46544
+ if (type == 1) {
46545
+ let allSearchkeysMain = state.search.dataListKeys.main.filter((key) => {
46546
+ return !state.search.defaultExpandedKeys.includes(key);
46547
+ });
46548
+ let allSearchkeysOther = state.search.dataListKeys.other;
46549
+ state.checkedKeys.main = xeUtils.uniq([...state.checkedKeys.main, ...allSearchkeysMain]);
46550
+ state.checkedKeys.other = xeUtils.uniq([...state.checkedKeys.other, ...allSearchkeysOther]);
46551
+ state.search.dataListKeys.main.forEach((key) => {
46552
+ let parentKey = getParentKey(key, state.treeData.main);
46553
+ let parent = state.treeData.main.filter((item) => {
46554
+ return item.key == parentKey;
46555
+ });
46556
+ let allCheck = parent[0].children.every((item) => {
46557
+ return state.checkedKeys.main.includes(item.key);
46558
+ });
46559
+ allCheck && state.checkedKeys.main.push(parentKey);
46560
+ });
46561
+ refreshSearchTree();
46562
+ }
46563
+ else if (type == 2) {
46564
+ searchTree.value.emptyCheckedKeys();
46565
+ state.autoExpandParent = true;
46566
+ }
46567
+ isSearchAllCheck();
46568
+ return true;
46569
+ };
46570
+ const removeCheckedkeysMain = (keys) => {
46571
+ let checkedKeysMain = xeUtils.clone(state.checkedKeys.main, true);
46572
+ keys.forEach((key) => {
46573
+ let index = checkedKeysMain.findIndex((mainKey) => mainKey == key);
46574
+ if (index !== -1) {
46575
+ checkedKeysMain.splice(index, 1);
46576
+ state.checkedKeys.main = [...checkedKeysMain];
46577
+ }
46578
+ let parentKey = getParentKey(key, state.treeData.main);
46579
+ let parentIndex = checkedKeysMain.findIndex((mainKey) => mainKey == parentKey);
46580
+ if (parentIndex !== -1) {
46581
+ checkedKeysMain.splice(parentIndex, 1);
46582
+ }
46583
+ });
46584
+ state.checkedKeys.main = [...checkedKeysMain];
46585
+ };
46586
+ const addCheckedkeysOther = (keys) => {
46587
+ state.checkedKeys.other.push(...keys);
46588
+ };
46589
+ const removeCheckedkeysOther = (keys) => {
46590
+ let checkedKeys = state.checkedKeys.other;
46591
+ keys.forEach((key) => {
46592
+ let index = checkedKeys.findIndex((otherKey) => otherKey == key);
46593
+ checkedKeys.splice(index, 1);
46594
+ handleDeldefaultShowList(key);
46595
+ });
46596
+ removeCheckedkeysMain(keys);
46597
+ };
46598
+ const handleDeldefaultShowList = (key) => {
46599
+ let len = state?.defaultShowList?.length || 0;
46600
+ if (len > 0) {
46601
+ for (let i = len - 1; i >= 0; i--) {
46602
+ let d = state.defaultShowList[i];
46603
+ if (`${d.parent_id}_${d.user_id}` == key) {
46604
+ closeDefaultTag(d, i);
46605
+ }
46606
+ }
46607
+ }
46608
+ };
46609
+ const closeDefaultTag = (tag, i) => {
46610
+ state.defaultShowList.splice(i, 1);
46611
+ closeTag({
46612
+ parentId: getParentId(tag),
46613
+ ...tag
46614
+ });
46615
+ };
46616
+ const closeTag = (removedTag) => {
46617
+ removedCheckedkeysMain(removedTag);
46618
+ removedCheckedkeysOther(removedTag);
46619
+ refreshSearchTree();
46620
+ };
46621
+ const removeCheckedkeysIncludeChildren = (parentKey) => {
46622
+ let needRemoveChildKeys = state.dataList.main.filter((i) => {
46623
+ let parentId = getParentId(i);
46624
+ return parentId == parentKey || i.key == parentKey;
46625
+ }).map((i) => {
46626
+ return i.key;
46627
+ });
46628
+ state.checkedKeys.main = state.checkedKeys.main.filter((i) => {
46629
+ return !needRemoveChildKeys.includes(i);
46630
+ });
46631
+ };
46632
+ const removedCheckedkeysMain = (tag) => {
46633
+ let checkedKeys = state.checkedKeys.main;
46634
+ let parentId = getParentId(tag);
46635
+ for (let i = 0; i < checkedKeys.length; i++) {
46636
+ if (tag.key == checkedKeys[i] && tag.key == parentId) {
46637
+ removeCheckedkeysIncludeChildren(tag.key);
46638
+ return false;
46639
+ }
46640
+ else if (tag.key == checkedKeys[i]) {
46641
+ checkedKeys.splice(i, 1);
46642
+ return false;
46643
+ }
46644
+ }
46645
+ };
46646
+ const removedCheckedkeysOther = (tag) => {
46647
+ let checkedKeys = state.checkedKeys.other;
46648
+ if (checkedKeys.includes(tag.key)) {
46649
+ for (let i = 0; i < checkedKeys.length; i++) {
46650
+ if (tag.key == checkedKeys[i]) {
46651
+ checkedKeys.splice(i, 1);
46652
+ return false;
46653
+ }
46654
+ }
46655
+ }
46656
+ else {
46657
+ OtherRemoveCheckedkeysIncludeChildren(tag.key);
46658
+ }
46659
+ };
46660
+ const OtherRemoveCheckedkeysIncludeChildren = (parentKey) => {
46661
+ let needRemoveChildKeys = state.dataList.main.filter((i) => {
46662
+ let parentId = getParentId(i);
46663
+ return parentId == parentKey || i.key == parentKey;
46664
+ }).map((i) => {
46665
+ return i.key;
46666
+ });
46667
+ state.checkedKeys.other = state.checkedKeys.other.filter((i) => {
46668
+ return !needRemoveChildKeys.includes(i);
46669
+ });
46670
+ };
46671
+ const searchOnloadMore = () => {
46672
+ state.searchPage = state.searchPage + 1;
46673
+ searchFetch({
46674
+ page: state.searchPage
46675
+ }, {
46676
+ loadMoren: true
46677
+ });
46678
+ };
46679
+ const treeCount = (count) => {
46680
+ if (!count)
46681
+ return "";
46682
+ return `(${count})`;
46683
+ };
46684
+ const getParentId = (v) => {
46685
+ const { parent_id_obj } = wordbookConfig.value || {};
46686
+ return `${v[parent_id_obj]}`;
46687
+ };
46688
+ const uniqArrObj = (arr, name) => {
46689
+ let obj = {};
46690
+ return arr.reduce((cur, next) => {
46691
+ obj[next[name]] ? "" : obj[next[name]] = cur.push(next);
46692
+ return cur;
46693
+ }, []);
46694
+ };
46695
+ const getuniqKey = (v) => {
46696
+ const { user_id_obj } = wordbookConfig.value || {};
46697
+ return `${getParentId(v)}_${v[user_id_obj]}`;
46698
+ };
46699
+ watch(() => props.defaultList, (val) => {
46700
+ if (!val)
46701
+ return;
46702
+ initDefault();
46703
+ }, {
46704
+ immediate: true
46705
+ });
46706
+ watch(() => state.checkedKeys.main, (val) => {
46707
+ isAllCheck(val);
46708
+ isSearchAllCheck();
46709
+ emit("check", val);
46710
+ }, {
46711
+ immediate: true,
46712
+ deep: true
46713
+ });
46714
+ watch(() => props.data, (val) => {
46715
+ staticDataInit();
46716
+ }, {
46717
+ immediate: true
46718
+ });
46719
+ onMounted(() => {
46720
+ getUsers();
46721
+ });
46722
+ return (_ctx, _cache) => {
46723
+ return openBlock(), createElementBlock("div", _hoisted_1, [createVNode(unref(NSpin), {
46724
+ show: unref(state).spinning
46725
+ }, {
46726
+ default: withCtx(() => [createElementVNode("div", _hoisted_2, [createCommentVNode(" \u6811\u4E3B\u4F53\u4E0E\u68C0\u7D22 "), createElementVNode("div", _hoisted_3, [createVNode(unref(NInputGroup), {
46727
+ style: {
46728
+ "margin-bottom": "12px"
46729
+ }
46730
+ }, {
46731
+ default: withCtx(() => [createVNode(unref(NInput), {
46732
+ style: {
46733
+ "text-align": "left"
46734
+ },
46735
+ clearable: "",
46736
+ value: unref(state).title,
46737
+ "onUpdate:value": _cache[0] || (_cache[0] = ($event) => unref(state).title = $event),
46738
+ placeholder: __props.searchPlaceholder
46739
+ }, null, 8, ["value", "placeholder"]), createVNode(unref(NButton), {
46740
+ type: "primary",
46741
+ onClick: searchClick
46742
+ }, {
46743
+ default: withCtx(() => [createTextVNode(toDisplayString(__props.searchButtonText), 1)]),
46744
+ _: 1
46745
+ })]),
46746
+ _: 1
46747
+ }), unref(searchTreeVisable) ? (openBlock(), createBlock(unref(NCheckbox), {
46748
+ key: 0,
46749
+ checked: unref(state).searchChecked,
46750
+ "onUpdate:checked": [_cache[1] || (_cache[1] = ($event) => unref(state).searchChecked = $event), radioChange],
46751
+ indeterminate: unref(state).searchIndeterminate
46752
+ }, {
46753
+ default: withCtx(() => [_hoisted_4]),
46754
+ _: 1
46755
+ }, 8, ["checked", "indeterminate"])) : (openBlock(), createBlock(unref(NCheckbox), {
46756
+ key: 1,
46757
+ checked: unref(state).singleChecked,
46758
+ "onUpdate:checked": [_cache[2] || (_cache[2] = ($event) => unref(state).singleChecked = $event), radioChange],
46759
+ indeterminate: unref(state).searchIndeterminate
46760
+ }, {
46761
+ default: withCtx(() => [_hoisted_5]),
46762
+ _: 1
46763
+ }, 8, ["checked", "indeterminate"])), createCommentVNode(' <div v-show="state.search.status == 3 || (state.search.status == 0 && state.treeData.main && state.treeData.main.length == 0)" class="no-data-tips">\r\n \u67E5\u65E0\u7ED3\u679C\r\n </div> '), createCommentVNode(" main tree "), withDirectives(createVNode(unref(NTree), {
46764
+ class: "main-tree-container",
46765
+ "checked-keys": unref(state).checkedKeys.main,
46766
+ "onUpdate:checked-keys": _cache[3] || (_cache[3] = ($event) => unref(state).checkedKeys.main = $event),
46767
+ "expanded-keys": unref(state).expandedKeys,
46768
+ checkable: "",
46769
+ cascade: "",
46770
+ "allow-checking-not-loaded": "",
46771
+ selectable: false,
46772
+ data: unref(state).treeData.main,
46773
+ "check-strategy": __props.queryMainTreeData ? "all" : "child",
46774
+ "onUpdate:expandedKeys": onExpand,
46775
+ "on-load": onLoadData,
46776
+ "render-label": renderLabel
46777
+ }, null, 8, ["checked-keys", "expanded-keys", "data", "check-strategy"]), [[vShow, unref(state).search.status == 0]]), createCommentVNode(" search tree "), createVNode(script$1, mergeProps(_ctx.$attrs, {
46778
+ ref_key: "searchTree",
46779
+ ref: searchTree,
46780
+ visible: unref(searchTreeVisable),
46781
+ formatTreeData: unref(state).treeData.search,
46782
+ searchValue: unref(state).searchValue,
46783
+ allCheckedKeys: unref(state).checkedKeys,
46784
+ defaultExpandedKeys: unref(state).search.defaultExpandedKeys,
46785
+ dataListKeys: unref(state).search.dataListKeys,
46786
+ searchNoMore: unref(state).searchNoMore,
46787
+ loadMorenLoadinng: unref(state).loadMorenLoadinng,
46788
+ onAddCheckedkeysMain: addCheckedkeysMain,
46789
+ onRemoveCheckedkeysMain: removeCheckedkeysMain,
46790
+ onAddCheckedkeysOther: addCheckedkeysOther,
46791
+ onRemoveCheckedkeysOther: removeCheckedkeysOther,
46792
+ onSearchOnloadMore: searchOnloadMore
46793
+ }), null, 16, ["visible", "formatTreeData", "searchValue", "allCheckedKeys", "defaultExpandedKeys", "dataListKeys", "searchNoMore", "loadMorenLoadinng"])]), createCommentVNode(" \u6811\u5DF2\u9009\u7684\u6570\u636E "), createElementVNode("div", _hoisted_6, [unref(state).defaultShowList && unref(state).defaultShowList.length ? renderSlot(_ctx.$slots, "default", {
46794
+ key: 0
46795
+ }, () => [(openBlock(true), createElementBlock(Fragment, null, renderList(unref(state).defaultShowList, (tag, i) => {
46796
+ return openBlock(), createElementBlock("div", {
46797
+ class: "tag-item def-item",
46798
+ key: i
46799
+ }, [createTextVNode(toDisplayString(tag.title || tag[__props.wordbookChild.user_name_obj]) + " ", 1), !__props.isDetail ? (openBlock(), createBlock(unref(NIcon), {
46800
+ key: 0,
46801
+ class: "tag-close",
46802
+ component: unref(CloseCircleSharp),
46803
+ onClick: ($event) => closeDefaultTag(tag, i)
46804
+ }, null, 8, ["component", "onClick"])) : createCommentVNode("v-if", true)]);
46805
+ }), 128))]) : createCommentVNode("v-if", true), (openBlock(true), createElementBlock(Fragment, null, renderList(unref(checkedTreeItem), (tag) => {
46806
+ return openBlock(), createElementBlock("div", {
46807
+ class: normalizeClass(["tag-item", {
46808
+ isRoot: !tag.isLeaf
46809
+ }]),
46810
+ key: tag.key
46811
+ }, [createTextVNode(toDisplayString(tag.title || tag.key) + " " + toDisplayString(treeCount(tag.count)) + " ", 1), !__props.isDetail ? (openBlock(), createBlock(unref(NIcon), {
46812
+ key: 0,
46813
+ class: "tag-close",
46814
+ component: unref(CloseCircleSharp),
46815
+ onClick: ($event) => closeTag(tag)
46816
+ }, null, 8, ["component", "onClick"])) : createCommentVNode("v-if", true)], 2);
46817
+ }), 128))])])]),
46818
+ _: 3
46819
+ }, 8, ["show"])]);
46820
+ };
46821
+ }
46822
+ });
46823
+
46824
+ script.__scopeId = "data-v-41061249";
46825
+ script.__file = "packages/select-person/src/SelectPerson.vue";
45610
46826
 
45611
46827
  script.install = function (app) {
45612
46828
  app.component(script.name, script);
@@ -45614,8 +46830,9 @@ script.install = function (app) {
45614
46830
 
45615
46831
  const components = [
45616
46832
  Grid,
45617
- script$6,
45618
- script$5,
46833
+ script$8,
46834
+ script$7,
46835
+ script$4,
45619
46836
  script$2,
45620
46837
  script
45621
46838
  ];
@@ -45629,4 +46846,4 @@ var index = {
45629
46846
  ...components
45630
46847
  };
45631
46848
 
45632
- export { script$6 as CBigTable, script as CButtonPrint, script$2 as CDragLayout, script$5 as CFieldSet, Grid as CGrid, index as default };
46849
+ export { script$8 as CBigTable, script$2 as CButtonPrint, script$4 as CDragLayout, script$7 as CFieldSet, Grid as CGrid, script as CSelectPerson, index as default };