cnhis-design-vue 0.3.4-beta → 0.3.7-beta

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.
Files changed (40) hide show
  1. package/es/big-table/index.css +3 -3
  2. package/es/big-table/index.js +299 -1340
  3. package/es/button-print/index.css +3 -3
  4. package/es/drag-layout/index.css +3 -3
  5. package/es/grid/index.css +3 -3
  6. package/es/index.css +3 -3
  7. package/es/index.js +280 -1321
  8. package/package.json +2 -1
  9. package/packages/big-table/src/BigTable.vue +102 -42
  10. package/packages/big-table/src/assets/style/table-base.less +6 -0
  11. package/packages/big-table/src/assets/style/table-global.less +9 -1
  12. package/packages/big-table/src/bigTableProps.ts +5 -0
  13. package/packages/big-table/src/bigTableState.ts +1 -0
  14. package/packages/big-table/src/components/edit-form/edit-input.vue +19 -0
  15. package/packages/big-table/src/components/edit-form/edit-select-table.vue +127 -0
  16. package/packages/big-table/src/components/edit-form/edit-select.vue +36 -0
  17. package/packages/big-table/src/components/{edit-form → edit-form3}/EditForm.vue +0 -0
  18. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-date-picker/edit-date-picker.vue +0 -0
  19. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-digital/edit-digital.vue +0 -0
  20. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-input/edit-input.vue +0 -0
  21. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-input-password/edit-input-password.vue +0 -0
  22. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-month-picker/edit-month-picker.vue +0 -0
  23. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-search/edit-search.vue +0 -0
  24. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-search-more/edit-search-more.vue +0 -0
  25. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-select/edit-select.vue +0 -0
  26. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-select-multiple/edit-select-multiple.vue +0 -0
  27. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-textarea/edit-textarea.vue +0 -0
  28. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-time-picker/edit-time-picker.vue +0 -0
  29. package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/editFormProps.ts +0 -0
  30. package/packages/big-table/src/components/edit-form3/edit-component/register-com.ts +18 -0
  31. package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useConfigData.ts +0 -0
  32. package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useDateType.ts +0 -0
  33. package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useFormCommon.ts +0 -0
  34. package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useItemDefault.ts +0 -0
  35. package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useSearch.ts +0 -0
  36. package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useValidateRules.ts +0 -0
  37. package/packages/big-table/src/components/{edit-form → edit-form3}/interface.ts +0 -0
  38. package/packages/big-table/src/components/{edit-form → edit-form3}/types.ts +0 -0
  39. package/packages/big-table/src/components/{edit-form → edit-form3}/utils.ts +0 -0
  40. package/packages/big-table/src/components/edit-form/edit-component/register-com.ts +0 -18
@@ -1,7 +1,7 @@
1
- import { inject, computed, watch, defineComponent, openBlock, createElementBlock, unref, createCommentVNode, createElementVNode, toDisplayString, ref, createVNode, withCtx, normalizeClass, renderSlot, createTextVNode, mergeProps, reactive, provide, Fragment, renderList, createBlock, resolveDynamicComponent, h, resolveComponent, nextTick, createApp, Teleport, onMounted, onUnmounted, getCurrentInstance, onBeforeUnmount, onActivated, onDeactivated, isVNode, useAttrs, normalizeStyle, withDirectives, vShow, pushScopeId, popScopeId } from 'vue';
1
+ import { inject, computed, watch, defineComponent, openBlock, createElementBlock, unref, createCommentVNode, createElementVNode, toDisplayString, ref, createVNode, withCtx, normalizeClass, renderSlot, createTextVNode, mergeProps, h, resolveComponent, nextTick, reactive, createApp, Teleport, provide, onMounted, onUnmounted, getCurrentInstance, onBeforeUnmount, onActivated, onDeactivated, isVNode, useAttrs, normalizeStyle, withDirectives, vShow, Fragment, createBlock, pushScopeId, popScopeId } from 'vue';
2
2
  import axios from 'axios';
3
- import { CaretDown, CaretForward, SyncOutline, SettingsSharp, CopyOutline } from '@vicons/ionicons5';
4
- import { NTooltip, useMessage, NForm, NFormItem, NInputGroup, NInput, NButton, NCheckbox, NCheckboxGroup, NSpace, NIcon, NPopconfirm, NDropdown, NSwitch, NPopover, NProgress } from 'naive-ui';
3
+ import { SettingsSharp, CaretDown, CaretForward, SyncOutline, CopyOutline } from '@vicons/ionicons5';
4
+ import { NTooltip, NSelect, NPagination, NEmpty, NSpin, NSpace, NInput, useMessage, NIcon, NInputGroup, NButton, NCheckbox, NCheckboxGroup, NPopconfirm, NDropdown, NSwitch, NPopover, NProgress } from 'naive-ui';
5
5
 
6
6
  /*!
7
7
  * vue-router v4.0.13
@@ -142,7 +142,8 @@ const bigTableState = {
142
142
  editColumnMap: {},
143
143
  fieldLength: 0,
144
144
  originFormatList: [],
145
- isSaveForm: false
145
+ isSaveForm: false,
146
+ editConfig: { trigger: "manual", mode: "cell", autoClear: false, showIcon: false }
146
147
  };
147
148
 
148
149
  const bigTableProps = {
@@ -257,7 +258,11 @@ const bigTableProps = {
257
258
  batchError: Boolean,
258
259
  batchFormData: { type: Object, default: () => ({}) },
259
260
  resetInlineBatchEdit: Function,
260
- resetBatchEditRowStatus: Function
261
+ resetBatchEditRowStatus: Function,
262
+ querySelectTableList: {
263
+ type: Function,
264
+ default: () => Promise.resolve({ rows: [], pageCount: 0 })
265
+ }
261
266
  };
262
267
 
263
268
  const bigTableEmits = [
@@ -13496,10 +13501,10 @@ var img$4 = "
13496
13501
 
13497
13502
  var img$3 = "";
13498
13503
 
13499
- const _hoisted_1$4 = { class: "no-data-tip NoData-page" };
13504
+ const _hoisted_1$3 = { class: "no-data-tip NoData-page" };
13500
13505
  const _hoisted_2$2 = ["src"];
13501
13506
  const _hoisted_3$1 = { key: 1 };
13502
- var script$4 = /* @__PURE__ */ defineComponent({
13507
+ var script$6 = /* @__PURE__ */ defineComponent({
13503
13508
  props: {
13504
13509
  noDataTip: {
13505
13510
  type: String,
@@ -13547,7 +13552,7 @@ var script$4 = /* @__PURE__ */ defineComponent({
13547
13552
  return res;
13548
13553
  });
13549
13554
  return (_ctx, _cache) => {
13550
- return openBlock(), createElementBlock("div", _hoisted_1$4, [
13555
+ return openBlock(), createElementBlock("div", _hoisted_1$3, [
13551
13556
  __props.showImg ? (openBlock(), createElementBlock("img", {
13552
13557
  key: 0,
13553
13558
  src: unref(imgStr),
@@ -13560,15 +13565,15 @@ var script$4 = /* @__PURE__ */ defineComponent({
13560
13565
  }
13561
13566
  });
13562
13567
 
13563
- script$4.__scopeId = "data-v-4a4b0812";
13564
- script$4.__file = "packages/big-table/src/components/NoData.vue";
13568
+ script$6.__scopeId = "data-v-4a4b0812";
13569
+ script$6.__file = "packages/big-table/src/components/NoData.vue";
13565
13570
 
13566
- const _hoisted_1$3 = { class: "text-over-tooltip-components" };
13567
- const __default__$3 = {
13571
+ const _hoisted_1$2 = { class: "text-over-tooltip-components" };
13572
+ const __default__$2 = {
13568
13573
  name: "TextOverTooltip"
13569
13574
  };
13570
- var script$3 = /* @__PURE__ */ defineComponent({
13571
- ...__default__$3,
13575
+ var script$5 = /* @__PURE__ */ defineComponent({
13576
+ ...__default__$2,
13572
13577
  props: {
13573
13578
  content: { type: [String, Number], required: false },
13574
13579
  className: { type: String, required: false },
@@ -13602,7 +13607,7 @@ var script$3 = /* @__PURE__ */ defineComponent({
13602
13607
  isDisabledTooltip.value = false;
13603
13608
  };
13604
13609
  return (_ctx, _cache) => {
13605
- return openBlock(), createElementBlock("div", _hoisted_1$3, [
13610
+ return openBlock(), createElementBlock("div", _hoisted_1$2, [
13606
13611
  createVNode(unref(NTooltip), {
13607
13612
  effect: __props.effect,
13608
13613
  show: unref(isDisabledTooltip),
@@ -13635,16 +13640,16 @@ var script$3 = /* @__PURE__ */ defineComponent({
13635
13640
  }
13636
13641
  });
13637
13642
 
13638
- script$3.__scopeId = "data-v-6633a934";
13639
- script$3.__file = "packages/big-table/src/components/TextOverTooltip.vue";
13643
+ script$5.__scopeId = "data-v-6633a934";
13644
+ script$5.__file = "packages/big-table/src/components/TextOverTooltip.vue";
13640
13645
 
13641
- const _hoisted_1$2 = { key: 0 };
13646
+ const _hoisted_1$1 = { key: 0 };
13642
13647
  const _hoisted_2$1 = ["xlink:href"];
13643
- const __default__$2 = {
13648
+ const __default__$1 = {
13644
13649
  name: "SvgIcon"
13645
13650
  };
13646
- var script$2 = /* @__PURE__ */ defineComponent({
13647
- ...__default__$2,
13651
+ var script$4 = /* @__PURE__ */ defineComponent({
13652
+ ...__default__$1,
13648
13653
  props: {
13649
13654
  iconClass: { type: String, required: true, default: "" },
13650
13655
  title: { type: String, required: true, default: "" },
@@ -13666,1284 +13671,15 @@ var script$2 = /* @__PURE__ */ defineComponent({
13666
13671
  class: unref(svgClass),
13667
13672
  "aria-hidden": "true"
13668
13673
  }, _ctx.$attrs), [
13669
- __props.title ? (openBlock(), createElementBlock("title", _hoisted_1$2, toDisplayString(__props.title), 1)) : createCommentVNode("v-if", true),
13674
+ __props.title ? (openBlock(), createElementBlock("title", _hoisted_1$1, toDisplayString(__props.title), 1)) : createCommentVNode("v-if", true),
13670
13675
  createElementVNode("use", { "xlink:href": unref(iconName) }, null, 8, _hoisted_2$1)
13671
13676
  ], 16);
13672
13677
  };
13673
13678
  }
13674
13679
  });
13675
13680
 
13676
- script$2.__scopeId = "data-v-372ca5c1";
13677
- script$2.__file = "packages/big-table/src/components/SvgIcon.vue";
13678
-
13679
- const configData = {
13680
- comTypeMap: {
13681
- "INPUT": "editInput",
13682
- "DIGITAL": "editDigital",
13683
- "TEXTAREA": "editTextarea",
13684
- "RADIO": "editSelect",
13685
- "RADIO_BLOCK": "editSelect",
13686
- "CHECKBOX_BLOCK": "editSelectMultiple",
13687
- "CHECKBOX": "editSelectMultiple",
13688
- "SEARCH": "editSearch",
13689
- "SEARCH_MORE": "editSearchMore",
13690
- "DATE": "editDatePicker",
13691
- "DATE-INPUT": "editDatePicker",
13692
- "TIME-INPUT": "editDatePicker",
13693
- "DATETIME-INPUT": "editDatePicker",
13694
- "SELECT": "editSelect",
13695
- "PHONE_TYPE": "editSelect",
13696
- "IDCARD_TYPE": "editSelect",
13697
- "editMonthPicker": "editMonthPicker",
13698
- "editTimePicker": "editTimePicker",
13699
- "editDatePicker": "editDatePicker",
13700
- "editSelect": "editSelect",
13701
- "editInputPassword": "editInputPassword",
13702
- "editSelectMultiple": "editSelectMultiple",
13703
- "MAP": "editInput",
13704
- "ICON": "editInput",
13705
- "UPPICTURE": "editInput",
13706
- "LEVEL_SEARCH_CASCADE2": "editInput",
13707
- "LABEL": "editInput",
13708
- "GUAGE": "editInput",
13709
- "SLIDER_COMPONENT": "editInput",
13710
- "SWITCH_COMPONENT": "editInput",
13711
- "AGE_JSON": "editInput",
13712
- "AGE": "editInput"
13713
- },
13714
- getComName(v) {
13715
- const { isMonthPicker_com, isDate_com, isTimePicker_com, isSelect_com, isPassword_com, comTypeMap } = this;
13716
- if (isDate_com(v.html_type)) {
13717
- if (isMonthPicker_com(v))
13718
- return "editMonthPicker";
13719
- if (isTimePicker_com(v))
13720
- return "editTimePicker";
13721
- return "editDatePicker";
13722
- }
13723
- if (isSelect_com(v))
13724
- return "editSelect";
13725
- if (isPassword_com(v))
13726
- return "editInputPassword";
13727
- const res = comTypeMap[v.html_type];
13728
- if (res) {
13729
- return res;
13730
- }
13731
- return "editInput";
13732
- },
13733
- isMonthPicker_com(v) {
13734
- return v.date_format && v.date_format.replace(/yyyy-MM/gi, "YYYY-MM") == "YYYY-MM";
13735
- },
13736
- isDate_com(key) {
13737
- return key === "DATE" || key === "DATE-INPUT" || key === "DATETIME-INPUT";
13738
- },
13739
- isTimePicker_com(v) {
13740
- return String(v.html_type) == "TIME-INPUT" || v.date_format == "HH:mm:ss" || v.date_format == "HH:mm";
13741
- },
13742
- isSelect_com(v) {
13743
- return ["SELECT", "PHONE_TYPE", "IDCARD_TYPE"].includes(v.html_type);
13744
- },
13745
- isPassword_com(v) {
13746
- return (v?.validate?.obj_type || "") === "password";
13747
- }
13748
- };
13749
-
13750
- const handleSysParams = (str, obj) => {
13751
- let p = {
13752
- form: { ...obj.defaultValue },
13753
- sys: obj.userInfo?.map?.sysParams || {},
13754
- db: { ...obj.dbParams || {} }
13755
- };
13756
- const getVal = (t, r, k) => {
13757
- return t.replace(r, function () {
13758
- let pKey = arguments[1];
13759
- let pls = pKey.split("!");
13760
- let plsList = pls.slice(1);
13761
- let l = [];
13762
- plsList.forEach((v) => {
13763
- let c = v;
13764
- if (v.includes(".")) {
13765
- let [_k, _v] = v.split(".");
13766
- c = typeof p[_k] === "object" ? p[_k][_v] : "";
13767
- }
13768
- if (c || +c == 0) {
13769
- l.push(c);
13770
- }
13771
- });
13772
- let f = l.find((v) => v || +v == 0);
13773
- let res = p[k][pls[0]];
13774
- res = xeUtils.notEmpty(res) ? res : "";
13775
- if (pls.length > 1) {
13776
- return res || f;
13777
- }
13778
- return res;
13779
- });
13780
- };
13781
- if (typeof str === "string") {
13782
- if (str.includes("form")) {
13783
- str = getVal(str, /\${form.(.*?)\}/g, "form");
13784
- }
13785
- if (str.includes("sys")) {
13786
- str = getVal(str, /\${sys.(.*?)\}/g, "sys");
13787
- }
13788
- if (str.includes("db")) {
13789
- str = getVal(str, /\${db.(.*?)\}/g, "db");
13790
- }
13791
- }
13792
- if (!str && +str != 0 || ["undefined", "null"].includes(String(str))) {
13793
- str = "";
13794
- }
13795
- return str;
13796
- };
13797
- const handlerGetDateType = (data) => {
13798
- let dateType;
13799
- switch (data.html_type) {
13800
- case "DATETIME-INPUT":
13801
- dateType = "yyyy-MM-dd HH:mm:ss";
13802
- break;
13803
- case "DATE-INPUT":
13804
- dateType = "yyyy-MM-dd";
13805
- break;
13806
- case "TIME-INPUT":
13807
- dateType = "HH:mm:ss";
13808
- break;
13809
- case "DATE":
13810
- data.date_format = data.date_format && data.date_format.replace(/yyyy/gi, "yyyy");
13811
- dateType = (data.date_format || "yyyy-MM-dd").replace(/yyyy-MM-dd/gi, "yyyy-MM-dd").replace(/hh:mm:ss/gi, "HH:mm:ss").replace(/hh:mm/gi, "HH:mm");
13812
- break;
13813
- default:
13814
- dateType = data.date_format || "yyyy-MM-dd";
13815
- break;
13816
- }
13817
- return dateType;
13818
- };
13819
- const handleGetJsonStr = (str) => {
13820
- let resObj = {};
13821
- if (xeUtils.isJSON(str)) {
13822
- resObj = JSON.parse(str);
13823
- }
13824
- else {
13825
- resObj = typeof str === "string" ? {} : str;
13826
- }
13827
- if (resObj && !resObj.objs && resObj.value) {
13828
- if (xeUtils.isJSON(resObj.value)) {
13829
- resObj = JSON.parse(resObj.value);
13830
- if (resObj.type === "jsonb") {
13831
- resObj = handleGetJsonStr(resObj);
13832
- }
13833
- }
13834
- }
13835
- return resObj;
13836
- };
13837
-
13838
- const useFormCommon = (props, state, userInfo, computedData) => {
13839
- const paramsObj = { defaultValue: state.defaultValue, userInfo, dbParams: state.dbParams };
13840
- computed(() => {
13841
- return function (item) {
13842
- let res = item.is_null == "0" && props.styleSetting.formBoldOpen;
13843
- return res;
13844
- };
13845
- });
13846
- computed(() => {
13847
- return function (item) {
13848
- let { combinationList = [] } = item || {};
13849
- if (!combinationList.length)
13850
- return false;
13851
- let showCombination = combinationList.filter((v) => !v.isCombinationHide);
13852
- return showCombination?.length > 1;
13853
- };
13854
- });
13855
- const handleGetcheckboxDef = (item) => {
13856
- let optionsList = item.option;
13857
- let valList = [];
13858
- let checkboxVal = state.defaultValue[item.name] || item.default_val;
13859
- let checkboxList = [];
13860
- checkboxVal = handleSysParams(checkboxVal, paramsObj);
13861
- if (typeof checkboxVal === "string") {
13862
- if (xeUtils.isJSON(checkboxVal)) {
13863
- checkboxList = JSON.parse(checkboxVal);
13864
- }
13865
- else {
13866
- checkboxList = checkboxVal ? checkboxVal.split(",") : [];
13867
- }
13868
- }
13869
- else if (Array.isArray(checkboxVal)) {
13870
- checkboxList = checkboxVal;
13871
- }
13872
- checkboxList = Array.isArray(checkboxList) ? checkboxList : [];
13873
- checkboxList.forEach((v) => {
13874
- optionsList.forEach((j) => {
13875
- if (j.text == v || j.value == v) {
13876
- valList.push(String(v));
13877
- }
13878
- });
13879
- });
13880
- return valList || [];
13881
- };
13882
- const transformStr = (item) => {
13883
- var def = state.defaultValue[item.name];
13884
- var propsDef = def || def !== "" && def == 0 ? def : item.default_val;
13885
- let defVal = propsDef || propsDef == 0 ? propsDef : "";
13886
- defVal = String(defVal);
13887
- return defVal;
13888
- };
13889
- const handlerFormatTextarea = (data) => {
13890
- let defVal = state.defaultValue[data.name] || data.default_val || "";
13891
- defVal = handleSysParams(defVal, paramsObj);
13892
- if (!defVal) {
13893
- return "";
13894
- }
13895
- else if (defVal instanceof Object) {
13896
- return JSON.stringify(defVal);
13897
- }
13898
- return defVal;
13899
- };
13900
- const handleGetTextDef = (item) => {
13901
- let defVal = "";
13902
- var def = state.defaultValue[item.name];
13903
- var propsDef = def || def !== "" && def === 0 ? def : handleSysParams(item.data_value || item.default_val, paramsObj);
13904
- defVal = propsDef || propsDef === 0 ? propsDef : void 0;
13905
- if (item.html_type === "DIGITAL") {
13906
- defVal = defVal ? +defVal : defVal;
13907
- }
13908
- return defVal;
13909
- };
13910
- const handleDateCondition = (item) => {
13911
- let { condition, attr, unit = "DAY", default_val } = item;
13912
- let format = handlerGetDateType(item);
13913
- let useTime, count = Number(default_val) || 0;
13914
- let getUnit = unit.toLowerCase();
13915
- let useUnit = getUnit + "s";
13916
- if (condition == "IN_THE_PAST") {
13917
- useTime = moment().subtract(count, useUnit);
13918
- }
13919
- else {
13920
- useTime = moment().add(count, useUnit);
13921
- }
13922
- let res = useTime.format(format);
13923
- if (attr == "startDate") {
13924
- res = useTime.startOf("day").format(format);
13925
- }
13926
- else if (attr == "endDate") {
13927
- res = useTime.endOf("day").format(format);
13928
- }
13929
- return res;
13930
- };
13931
- const handleGetdateTypeDef = (item) => {
13932
- var propsDate = state.defaultValue[item.name] || item.default_val;
13933
- if (item.condition === "IN_THE_PAST" || item.condition === "IN_THE_FUTURE") {
13934
- propsDate = handleDateCondition(item);
13935
- }
13936
- else {
13937
- propsDate = handleSysParams(propsDate, paramsObj);
13938
- }
13939
- let dateType = handlerGetDateType(item);
13940
- if (dateType == "HH:mm:ss" || dateType == "HH:mm") {
13941
- return propsDate && moment(propsDate, dateType).isValid() ? moment(propsDate, dateType) : null;
13942
- }
13943
- else {
13944
- if (dateType === "YYYY-MM-DD HH:mm:ss" && propsDate) {
13945
- if (typeof propsDate === "string") {
13946
- let [, h] = propsDate.split(" ");
13947
- if (!h) {
13948
- propsDate = `${propsDate} 00:00:00`;
13949
- }
13950
- }
13951
- }
13952
- return propsDate && moment(new Date(propsDate), dateType).isValid() ? moment(new Date(propsDate), dateType) : null;
13953
- }
13954
- };
13955
- const transformDefStr = (item) => {
13956
- var def = state.defaultValue[item.name];
13957
- var propsDef = def || def !== "" && def == 0 ? def : item.default_val;
13958
- let defVal = propsDef || propsDef == 0 ? propsDef : "";
13959
- defVal = String(defVal);
13960
- return defVal;
13961
- };
13962
- const getSelectVal = (data) => {
13963
- let targetStr = transformDefStr(data) || "";
13964
- if (["SELECT", "PHONE_TYPE", "IDCARD_TYPE"].includes(data.html_type)) {
13965
- targetStr = String(targetStr);
13966
- targetStr = handleSysParams(targetStr, paramsObj);
13967
- if (!Array.isArray(data.option))
13968
- return targetStr;
13969
- let f = data.option.find((o) => o.value == targetStr);
13970
- if (f) {
13971
- return targetStr;
13972
- }
13973
- else {
13974
- const curVal = data.option[0] && data.option[0].value;
13975
- return curVal;
13976
- }
13977
- }
13978
- else {
13979
- return targetStr;
13980
- }
13981
- };
13982
- const handlerDefaultUpload = (data, type = "default") => {
13983
- let currentData;
13984
- let fileList;
13985
- if (xeUtils.isJSON(data)) {
13986
- currentData = JSON.parse(data);
13987
- }
13988
- else {
13989
- currentData = data;
13990
- }
13991
- if (currentData instanceof Array) {
13992
- currentData.forEach((item) => {
13993
- item.thumbUrl = item.url;
13994
- item.uid = (-Math.random()).toString();
13995
- item.status = "done";
13996
- });
13997
- fileList = currentData;
13998
- }
13999
- else if (typeof currentData === "string" && currentData.length > 0) {
14000
- const currentList = currentData.split(",");
14001
- fileList = [];
14002
- currentList.forEach((v) => {
14003
- if (v) {
14004
- fileList.push({
14005
- url: v,
14006
- thumbUrl: v,
14007
- uid: (-Math.random()).toString(),
14008
- name: "name",
14009
- status: "done"
14010
- });
14011
- }
14012
- });
14013
- }
14014
- else {
14015
- fileList = [];
14016
- }
14017
- if (type === "default") {
14018
- return fileList;
14019
- }
14020
- else {
14021
- return { fileList };
14022
- }
14023
- };
14024
- const getCascaderDef = (v) => {
14025
- try {
14026
- const is_multi = v.is_multi == "1";
14027
- let defaultValue = state.defaultValue[v.name] || v.default_val;
14028
- if (typeof defaultValue === "string") {
14029
- defaultValue = handleSysParams(defaultValue, paramsObj);
14030
- if (!xeUtils.isJSON(defaultValue)) {
14031
- return [];
14032
- }
14033
- }
14034
- if (!defaultValue)
14035
- return [];
14036
- if (defaultValue.includes("objStr")) {
14037
- if (is_multi) {
14038
- const multiData = handleGetJsonStr(defaultValue);
14039
- const objs = multiData["objs"] || [];
14040
- const objStrList = [];
14041
- objs.forEach((e) => {
14042
- objStrList.push(e.objStr.split("/"));
14043
- });
14044
- return [...objStrList];
14045
- }
14046
- else {
14047
- defaultValue = handleGetJsonStr(defaultValue).objStr;
14048
- }
14049
- }
14050
- if (typeof defaultValue == "string") {
14051
- if (defaultValue.includes("_")) {
14052
- defaultValue = defaultValue.split("_");
14053
- }
14054
- else {
14055
- defaultValue = defaultValue.split("/");
14056
- }
14057
- }
14058
- if (!Array.isArray(defaultValue)) {
14059
- defaultValue = [];
14060
- }
14061
- else {
14062
- defaultValue = defaultValue.filter(Boolean);
14063
- }
14064
- return is_multi ? [] : defaultValue || [];
14065
- }
14066
- catch (error) {
14067
- console.log(error);
14068
- return [];
14069
- }
14070
- };
14071
- const getInitializeDef = (item) => {
14072
- return handleSysParams(state.defaultValue[item.name] || item.default_val || "", paramsObj);
14073
- };
14074
- const transformNumber = (val) => {
14075
- if (val) {
14076
- let resVal = +val;
14077
- return isNaN(resVal) ? 0 : resVal;
14078
- }
14079
- return void 0;
14080
- };
14081
- const handleGetdef = (item) => {
14082
- let defVal;
14083
- switch (item.html_type) {
14084
- case "CHECKBOX_BLOCK":
14085
- case "CHECKBOX":
14086
- defVal = handleGetcheckboxDef(item);
14087
- break;
14088
- case "RADIO_BLOCK":
14089
- case "RADIO":
14090
- defVal = transformStr(item);
14091
- defVal = handleSysParams(defVal, paramsObj);
14092
- if (!defVal && +defVal != 0) {
14093
- defVal = void 0;
14094
- }
14095
- break;
14096
- case "MAP":
14097
- defVal = state.defaultValue[item.name] || item.default_val || "";
14098
- defVal = handleSysParams(defVal, paramsObj);
14099
- break;
14100
- case "TEXTAREA":
14101
- defVal = handlerFormatTextarea(item) || "";
14102
- break;
14103
- case "INPUT":
14104
- case "DIGITAL":
14105
- case "ICON":
14106
- defVal = handleGetTextDef(item);
14107
- break;
14108
- case "DATE":
14109
- case "DATE-INPUT":
14110
- case "DATETIME-INPUT":
14111
- defVal = handleGetdateTypeDef(item);
14112
- break;
14113
- case "SELECT":
14114
- case "PHONE_TYPE":
14115
- case "IDCARD_TYPE":
14116
- defVal = getSelectVal(item);
14117
- break;
14118
- case "UPPICTURE":
14119
- var def = state.defaultValue[item.name] || item.default_val;
14120
- if (typeof def === "string") {
14121
- def = handleSysParams(def, paramsObj);
14122
- }
14123
- defVal = handlerDefaultUpload(def, "values");
14124
- break;
14125
- case "SEARCH":
14126
- defVal = handleSysParams(item.default_val, paramsObj) || state.defaultValue[item.name] || void 0;
14127
- break;
14128
- case "SEARCH_MORE":
14129
- defVal = [];
14130
- break;
14131
- case "LEVEL_SEARCH_CASCADE2":
14132
- defVal = getCascaderDef(item);
14133
- break;
14134
- case "LABEL":
14135
- defVal = [];
14136
- break;
14137
- case "GUAGE":
14138
- defVal = state.defaultValue[item.name];
14139
- break;
14140
- case "SLIDER_COMPONENT":
14141
- defVal = getInitializeDef(item);
14142
- defVal = transformNumber(defVal);
14143
- break;
14144
- case "SWITCH_COMPONENT":
14145
- defVal = getInitializeDef(item);
14146
- break;
14147
- case "AGE_JSON":
14148
- let d = String(getInitializeDef(item) || {});
14149
- if (xeUtils.isJSON(d)) {
14150
- d = JSON.parse(d);
14151
- }
14152
- if (typeof d == "object") {
14153
- Object.keys(d).forEach((v) => {
14154
- d[v] = [-1, "-1"].includes(d[v]) ? "" : d[v];
14155
- });
14156
- defVal = Object.assign({ year: "", month: "", day: "", days: "" }, d);
14157
- }
14158
- else {
14159
- defVal = { year: "", month: "", day: "", days: "" };
14160
- }
14161
- break;
14162
- case "AGE":
14163
- defVal = state.defaultValue[item.name] || handleSysParams(item.default_val || "", paramsObj);
14164
- break;
14165
- }
14166
- if (item.html_type === "ICON") {
14167
- state.defaultValue[item.name] = defVal;
14168
- }
14169
- return defVal;
14170
- };
14171
- const RandomId = (len) => {
14172
- return Math.random().toString(36).slice(3, len) + new Date().getTime();
14173
- };
14174
- return {
14175
- handleGetdef,
14176
- RandomId
14177
- };
14178
- };
14179
-
14180
- const useValidateRules = () => {
14181
- const checkLenght = (rule, value, item) => {
14182
- try {
14183
- const { validate = {}, is_null, html_type } = item || {};
14184
- let { min_length, max_length } = validate || {};
14185
- let curval = value + "";
14186
- if (html_type === "INPUT") {
14187
- max_length = max_length ? +max_length : 300;
14188
- }
14189
- else if (html_type === "TEXTAREA") {
14190
- max_length = max_length ? +max_length : 500;
14191
- }
14192
- else if (html_type === "RICH_TEXT") {
14193
- const div = document.createElement("div");
14194
- div.innerHTML = value;
14195
- curval = div.innerText;
14196
- }
14197
- const strlen = curval.length;
14198
- let max = strlen > max_length, min = min_length > strlen;
14199
- if (is_null == 0 && !value && value != 0) {
14200
- return new Error(`\u8BF7\u8F93\u5165${min_length || 0}-${max_length}\u4E2A\u5B57\u7B26`);
14201
- }
14202
- if (is_null == 1 && !value) {
14203
- return true;
14204
- }
14205
- if ((min_length || String(min_length) === "0") && max_length && (max || min)) {
14206
- return new Error(`\u8BF7\u8F93\u5165${min_length || 0}-${max_length}\u4E2A\u5B57\u7B26`);
14207
- }
14208
- else if (min_length && min) {
14209
- return new Error(`\u81F3\u5C11\u8F93\u5165${min_length}\u4E2A\u5B57\u7B26`);
14210
- }
14211
- else if (max_length && max) {
14212
- return new Error(`\u6700\u591A\u53EA\u80FD\u8F93\u5165${max_length}\u4E2A\u5B57\u7B26`);
14213
- }
14214
- return true;
14215
- }
14216
- catch (error) {
14217
- console.log(error, "------checkLenght");
14218
- return true;
14219
- }
14220
- };
14221
- const getInputCheck = (validate = void 0) => {
14222
- if (!validate)
14223
- return false;
14224
- const isInteger = validate == "integer";
14225
- return {
14226
- pattern: isInteger ? /^-?[0-9]+$/ : /^(-?[0-9]+)(\\.[0-9]+)?$/,
14227
- message: isInteger ? "\u53EA\u80FD\u8F93\u5165\u6570\u5B57" : "\u53EA\u80FD\u8F93\u5165\u6570\u5B57\u548C\u5C0F\u6570"
14228
- };
14229
- };
14230
- const handlerSetIdCarInfoValidate = (rule, value, item) => {
14231
- try {
14232
- const { validate = {} } = item || {};
14233
- if (validate.vali_obj == "id_card") {
14234
- const pat = /^\d{6}(((19|20)\d{2}(0[1-9]|1[0-2])(0[1-9]|[1-2][0-9]|3[0-1])\d{3}([0-9]|x|X))|(\d{2}(0[1-9]|1[0-2])(0[1-9]|[1-2][0-9]|3[0-1])\d{3}))$/;
14235
- if (!pat.test(value)) {
14236
- return new Error(`\u8BF7\u8F93\u5165\u6B63\u786E\u7684\u8EAB\u4EFD\u8BC1\u53F7\u7801`);
14237
- }
14238
- }
14239
- return true;
14240
- }
14241
- catch (error) {
14242
- console.log(error, "------handlerSetIdCarInfoValidate");
14243
- return true;
14244
- }
14245
- };
14246
- const checkinputBlank = (rule, value, item) => {
14247
- try {
14248
- const { is_null, delete_before_after_spaces } = item;
14249
- if (typeof value === "string" && delete_before_after_spaces == 1) {
14250
- let val = value.trim();
14251
- if (!val && is_null == 0) {
14252
- return new Error(`\u4E0D\u53EF\u4E3A\u7A7A`);
14253
- }
14254
- }
14255
- return true;
14256
- }
14257
- catch (error) {
14258
- console.log(error, "------checkinputBlank");
14259
- return true;
14260
- }
14261
- };
14262
- const checkDigital = (rule, value, item) => {
14263
- try {
14264
- const { validate, is_null, decimal_length, alias, name } = item;
14265
- const { min_value, max_value } = validate || {};
14266
- let showName = alias || name;
14267
- if (isNaN(+value)) {
14268
- return new Error(`\u53EA\u80FD\u8F93\u5165\u6570\u5B57`);
14269
- }
14270
- if (is_null == 0 && !value && value != 0) {
14271
- return new Error(`\u8BF7\u8F93\u5165${showName}\u6709\u6548\u8303\u56F4`);
14272
- }
14273
- if (!value && value !== 0) {
14274
- if (is_null == 0) {
14275
- return new Error(`\u8BF7\u8F93\u5165${showName}\u6709\u6548\u8303\u56F4`);
14276
- }
14277
- return true;
14278
- }
14279
- const decimalLen = decimal_length || validate.decimal_length;
14280
- const valList = (value + "").trim().split(".");
14281
- if (decimalLen && decimalLen != 0) {
14282
- if (valList[1] && valList[1].length > decimalLen) {
14283
- return new Error(`\u5C0F\u6570\u6700\u591A${decimalLen}\u4F4D`);
14284
- }
14285
- }
14286
- else {
14287
- const flag = /^-?[0-9]+$/.test(value);
14288
- if (!flag) {
14289
- return new Error(`\u8BF7\u8F93\u5165\u6574\u6570`);
14290
- }
14291
- }
14292
- let max = +value > +max_value, min = +min_value > +value;
14293
- if ((min_value || max_value) && (value || value == 0)) {
14294
- if ((min_value || String(min_value) === "0") && max_value && (max || min)) {
14295
- return new Error(`\u8BF7\u8F93\u5165${min_value}~${max_value}`);
14296
- }
14297
- else if (min_value && min || max_value && max) {
14298
- return new Error(`\u8BF7\u8F93\u5165${showName}\u6709\u6548\u8303\u56F4`);
14299
- }
14300
- return true;
14301
- }
14302
- return true;
14303
- }
14304
- catch (error) {
14305
- console.log(error, "------checkDigital");
14306
- return true;
14307
- }
14308
- };
14309
- const checkAgeJson = (rule, value, item) => {
14310
- try {
14311
- const { is_null, alias, name } = item;
14312
- const { year, month, day, days } = value;
14313
- const c = (val) => String(val) === "0" || val > 0;
14314
- const checkval = () => !(c(year) || c(month) || c(day));
14315
- if (is_null == 0) {
14316
- if (checkval()) {
14317
- return new Error(`\u8BF7\u8F93\u5165${alias || name}`);
14318
- }
14319
- else if (days > 73e3) {
14320
- return new Error(`\u8D85\u51FA\u5E74\u9F84\u8303\u56F40~200\u5C81`);
14321
- }
14322
- }
14323
- return true;
14324
- }
14325
- catch (error) {
14326
- console.log(error, "------checkAgeJson");
14327
- return true;
14328
- }
14329
- };
14330
- const checkAge = (rule, value, item) => {
14331
- try {
14332
- let { is_null, name, alias } = item;
14333
- if (!value && is_null == 0) {
14334
- return new Error(`${alias || name}\u4E0D\u80FD\u4E3A\u7A7A`);
14335
- }
14336
- if (!item.val_key_unit) {
14337
- return true;
14338
- }
14339
- const curVal = item?.useFormValue;
14340
- let k = typeof curVal === "string" && curVal.toLowerCase();
14341
- const o = {
14342
- year: 200,
14343
- month: 2400,
14344
- day: 73e3
14345
- };
14346
- if (k) {
14347
- if (value > o[k]) {
14348
- return new Error(`\u8D85\u51FA\u5E74\u9F84\u8303\u56F40~200\u5C81`);
14349
- }
14350
- }
14351
- return true;
14352
- }
14353
- catch (error) {
14354
- console.log(error, "------checkAge");
14355
- return true;
14356
- }
14357
- };
14358
- const handleUploadValidator = (rule, value, item) => {
14359
- try {
14360
- let curval = value;
14361
- const { is_null, name, validate, html_type } = item;
14362
- let { min_length, max_length } = validate || {};
14363
- let unit = html_type === "UPPICTURE" ? "\u5F20" : "\u4E2A";
14364
- if (html_type === "UPPICTURE") {
14365
- curval = curval.split(",").filter(Boolean);
14366
- }
14367
- else if (xeUtils.isJSON(value || "")) {
14368
- curval = JSON.parse(curval);
14369
- }
14370
- let len = curval?.length || 0;
14371
- if (is_null == 1 && len === 0) {
14372
- return true;
14373
- }
14374
- else if (is_null == 0 && (!curval || len === 0)) {
14375
- return new Error(`\u8BF7\u4E0A\u4F20${name}`);
14376
- }
14377
- else if (len > 0) {
14378
- if (len < min_length) {
14379
- return new Error(`\u6700\u5C11\u4E0A\u4F20${min_length}${unit}`);
14380
- }
14381
- else if (len > max_length) {
14382
- return new Error(`\u6700\u591A\u53EA\u80FD\u4E0A\u4F20${max_length}${unit}`);
14383
- }
14384
- }
14385
- return true;
14386
- }
14387
- catch (error) {
14388
- console.log(error, "------handleUploadValidator");
14389
- return true;
14390
- }
14391
- };
14392
- const checkMultipleChoice = (rule, value, item) => {
14393
- try {
14394
- const { multi_select, multi_select_value, is_null, alias, name } = item;
14395
- if (Array.isArray(value)) {
14396
- if (is_null == 0) {
14397
- if (value.length === 0) {
14398
- return new Error(`\u8BF7\u9009\u62E9${alias || name}`);
14399
- }
14400
- }
14401
- if (is_null == 1 && value.length === 0) {
14402
- return true;
14403
- }
14404
- if (multi_select_value) {
14405
- if (value.length > multi_select_value) {
14406
- return new Error(`\u6700\u591A\u53EA\u80FD\u9009\u62E9${multi_select_value}\u9879`);
14407
- }
14408
- }
14409
- }
14410
- return true;
14411
- }
14412
- catch (error) {
14413
- console.log(error, "------checkMultipleChoice");
14414
- return true;
14415
- }
14416
- };
14417
- const checkcandidate = (rule, value, item) => {
14418
- try {
14419
- let curval = value;
14420
- const { is_null, name, validate, check_max_val, check_min_val } = item;
14421
- if (is_null == 0 && !curval) {
14422
- return new Error(`\u8BF7\u9009${name}`);
14423
- }
14424
- if (xeUtils.isJSON(value || "")) {
14425
- curval = JSON.parse(curval);
14426
- }
14427
- if (is_null != 0 && !Array.isArray(curval)) {
14428
- return true;
14429
- }
14430
- let len = curval?.length || 0;
14431
- if (is_null == 1 && len === 0) {
14432
- return true;
14433
- }
14434
- else if (is_null == 0 && (!curval || len === 0)) {
14435
- return new Error(`\u8BF7\u9009${name}`);
14436
- }
14437
- else if (len > 0) {
14438
- if (len < check_min_val) {
14439
- return new Error(`\u81F3\u5C11\u8981\u9009${check_min_val}\u9879`);
14440
- }
14441
- else if (len > check_max_val) {
14442
- return new Error(`\u6700\u591A\u53EF\u9009${check_max_val}\u9879`);
14443
- }
14444
- }
14445
- return true;
14446
- }
14447
- catch (error) {
14448
- console.log(error, "------checkcandidate");
14449
- return true;
14450
- }
14451
- };
14452
- const handleGetRules = (item) => {
14453
- const initRules = [];
14454
- const { validate = {}, is_null } = item;
14455
- let { vali_obj } = validate;
14456
- if (item.is_show == 0 && item.useType != "intercept") {
14457
- return initRules;
14458
- }
14459
- if (item.lineBarCheck || item.is_hide_field) {
14460
- return [];
14461
- }
14462
- switch (item.html_type) {
14463
- case "INPUT":
14464
- case "TEXTAREA":
14465
- case "RICH_TEXT":
14466
- initRules.push({
14467
- required: item.is_null == 0,
14468
- message: `\u8BF7\u8F93\u5165${item.name}`,
14469
- trigger: "change"
14470
- });
14471
- if (vali_obj != "mobile") {
14472
- initRules.push({
14473
- validator: (rule, value) => checkLenght(rule, value, item),
14474
- trigger: "change"
14475
- });
14476
- }
14477
- if (["integer", "number"].includes(vali_obj)) {
14478
- const rule = getInputCheck(vali_obj);
14479
- rule && initRules.push(rule);
14480
- }
14481
- if (vali_obj == "id_card") {
14482
- initRules.push({
14483
- validator: (rule, value) => handlerSetIdCarInfoValidate(rule, value, item),
14484
- trigger: "change"
14485
- });
14486
- }
14487
- initRules.push({
14488
- validator: (rule, value) => checkinputBlank(rule, value, item),
14489
- trigger: "change"
14490
- });
14491
- break;
14492
- case "DIGITAL":
14493
- initRules.push({
14494
- validator: (rule, value) => checkDigital(rule, value, item)
14495
- });
14496
- break;
14497
- case "AGE_JSON":
14498
- initRules.push({
14499
- validator: (rule, value) => checkAgeJson(rule, value, item),
14500
- trigger: "change"
14501
- });
14502
- break;
14503
- case "AGE":
14504
- initRules.push({
14505
- validator: (rule, value) => checkAge(rule, value, item),
14506
- trigger: "change"
14507
- }, {
14508
- required: item.is_null == 0,
14509
- message: `\u8BF7\u8F93\u5165${item.name}`
14510
- });
14511
- break;
14512
- case "UPPICTURE":
14513
- case "UPFILE":
14514
- case "VEDIO":
14515
- initRules.push({
14516
- validator: (rule, value) => handleUploadValidator(rule, value, item),
14517
- trigger: "change"
14518
- });
14519
- break;
14520
- case "CHECKBOX_BLOCK":
14521
- case "CHECKBOX":
14522
- case "SEARCH_MORE":
14523
- initRules.push({
14524
- required: item.is_null == 0,
14525
- message: `\u8BF7\u9009\u62E9${item.name}`,
14526
- trigger: "change"
14527
- }, {
14528
- validator: (rule, value) => checkMultipleChoice(rule, value, item),
14529
- trigger: "change"
14530
- });
14531
- break;
14532
- case "CANDIDATE_COMPONENTS":
14533
- initRules.push({
14534
- validator: (rule, value) => checkcandidate(rule, value, item),
14535
- trigger: "change"
14536
- });
14537
- break;
14538
- default:
14539
- initRules.push({
14540
- required: item.is_null == 0,
14541
- message: `\u8BF7\u9009\u62E9${item.name}`,
14542
- trigger: "change"
14543
- });
14544
- break;
14545
- }
14546
- if (validate && vali_obj == "mobile" && !validate.phone_idcard_type && is_null == 0) {
14547
- initRules.push({
14548
- pattern: /(^[0-9]{11,11}$)/,
14549
- message: "\u8BF7\u8F93\u5165\u6B63\u786E\u7684\u7535\u8BDD\u53F7\u7801",
14550
- trigger: "change"
14551
- });
14552
- }
14553
- if (initRules.length) {
14554
- initRules[0].key = item.val_key;
14555
- }
14556
- return initRules;
14557
- };
14558
- return {
14559
- handleGetRules
14560
- };
14561
- };
14562
-
14563
- const requireComponent = import.meta.globEager("./edit.*?.(vue|ts)$/");
14564
- let cmps = {};
14565
- Object.values(requireComponent).forEach((cmp) => {
14566
- cmps[cmp.name] = cmp;
14567
- });
14568
- console.log(cmps, "cmps");
14569
- var registerCom = {
14570
- data() {
14571
- return {};
14572
- },
14573
- computed: {},
14574
- methods: {},
14575
- components: cmps
14576
- };
14577
-
14578
- const _hoisted_1$1 = { class: "editForm-page" };
14579
- const __default__$1 = {
14580
- name: "EditForm",
14581
- mixins: [registerCom]
14582
- };
14583
- var script$1 = /* @__PURE__ */ defineComponent({
14584
- ...__default__$1,
14585
- props: {
14586
- defaultForm: { type: null, required: true },
14587
- isPure: { type: Boolean, required: true },
14588
- cacheUniqueKey: { type: null, required: false, default: {} },
14589
- banRequest: { type: Boolean, required: false, default: false },
14590
- propsDelSetting: { type: Boolean, required: false, default: false },
14591
- propsFormBtn: { type: Boolean, required: false, default: false },
14592
- parentConfig: { type: null, required: false, default: {} },
14593
- configuration: { type: null, required: false, default: {} },
14594
- isOpenShortcut: { type: Boolean, required: false, default: true },
14595
- formPrimaryKey: { type: [Number, String], required: true },
14596
- styleSetting: { type: null, required: false }
14597
- },
14598
- emits: ["banSubmit", "handleSubmit"],
14599
- setup(__props, { expose, emit }) {
14600
- const props = __props;
14601
- window.$message = useMessage();
14602
- const state = reactive({
14603
- defaultValue: {},
14604
- editForm: {
14605
- formFieldList: []
14606
- },
14607
- editRules: {},
14608
- formFieldList: [],
14609
- theUniqueKeyListObj: {},
14610
- formType: {},
14611
- defaultFieldList: [],
14612
- dbParams: {},
14613
- searchObj: {},
14614
- searchAddObj: {},
14615
- multipleSelected: {},
14616
- formFieldObj: {},
14617
- selectedDefValueObj: {},
14618
- fieldTypeList: []
14619
- });
14620
- const editForm = ref(null);
14621
- const userInfo = computed(() => {
14622
- const { userInfo: userInfo2 } = props.configuration || {};
14623
- return userInfo2 || {};
14624
- });
14625
- computed(() => !props.isPure);
14626
- const { RandomId, handleGetdef } = useFormCommon(props, state, userInfo.value);
14627
- const { handleGetRules } = useValidateRules();
14628
- provide("state", state);
14629
- provide("userInfo", userInfo);
14630
- const handleConvertData = (target) => {
14631
- let transmitParams = {};
14632
- let transmitKeys = Object.keys(target || {});
14633
- if (transmitKeys && transmitKeys.length) {
14634
- transmitKeys.forEach((v) => {
14635
- if (typeof target[v] == "object") {
14636
- transmitParams[v] = JSON.stringify(target[v]);
14637
- }
14638
- else {
14639
- transmitParams[v] = target[v];
14640
- }
14641
- if (xeUtils.isString(target[v])) {
14642
- if (target[v] && target[v].includes("###{")) {
14643
- let temp = JSON.parse(target[v].replace("###", ""));
14644
- transmitParams[v] = temp.value;
14645
- }
14646
- }
14647
- });
14648
- }
14649
- return transmitParams;
14650
- };
14651
- const handleGetformType = (list) => {
14652
- state.theUniqueKeyListObj = {};
14653
- let myformType = {};
14654
- let mySearchObj = {};
14655
- let searchAddObj = {};
14656
- state.formType = null;
14657
- let fieldObj = /* @__PURE__ */ Object.create(null);
14658
- let defaList = Object.keys(state.defaultValue);
14659
- list?.forEach((item) => {
14660
- myformType[item.val_key] = item;
14661
- let curKey = `${item.val_key}_${item.name}`;
14662
- item.wordbook && (item?.wordbook?.type || "") != "WORDBOOK";
14663
- item.selectOptions = [];
14664
- item.popoverVisible = false;
14665
- item.otherval = "";
14666
- item.otherFlag = false;
14667
- if (item.html_type == "SEARCH") {
14668
- mySearchObj[curKey] = [];
14669
- searchAddObj[curKey] = false;
14670
- if (defaList.includes(item.name)) {
14671
- mySearchObj[curKey] = [
14672
- {
14673
- [item.wordbook.value_key]: state.defaultValue[item.name]
14674
- }
14675
- ];
14676
- }
14677
- }
14678
- else if (item.html_type == "SEARCH_MORE") {
14679
- mySearchObj[curKey] = [];
14680
- searchAddObj[curKey] = false;
14681
- if (!state.multipleSelected[curKey]) {
14682
- state.multipleSelected[curKey] = [];
14683
- }
14684
- }
14685
- else {
14686
- state.defaultValue[item.name] || item.default_val;
14687
- }
14688
- if (item.val_key) {
14689
- fieldObj[item.val_key] = {
14690
- ...item
14691
- };
14692
- }
14693
- });
14694
- state.formType = myformType;
14695
- state.searchObj = mySearchObj;
14696
- state.searchAddObj = searchAddObj;
14697
- state.formFieldObj = fieldObj;
14698
- };
14699
- const getSelecteddefValueObj = () => {
14700
- let obj = {
14701
- multipleSelected: {
14702
- ...state.multipleSelected
14703
- }
14704
- };
14705
- state.selectedDefValueObj = obj;
14706
- };
14707
- const hanlderInitFieldList = (fieldList = []) => {
14708
- if (!fieldList.length)
14709
- return;
14710
- handleGetformType(fieldList);
14711
- getSelecteddefValueObj();
14712
- let fieldTypeList = [];
14713
- for (let index = 0; index < fieldList.length; index++) {
14714
- const element = fieldList[index];
14715
- element.isPure = props.isPure;
14716
- let randomId = RandomId();
14717
- let com_name = configData.getComName(element);
14718
- element["com_name"] = com_name;
14719
- element["RandomId"] = randomId;
14720
- let useFormValue = handleGetdef(element);
14721
- element["useFormValue"] = useFormValue;
14722
- element["isVisible"] = false;
14723
- let mid_is_edit = [0, 1, "0", "1"].includes(element.mid_is_edit) ? element.mid_is_edit : element.is_edit;
14724
- element.is_edit = mid_is_edit;
14725
- if (element.html_type.includes("CHECKBOX")) {
14726
- element["indeterminate"] = false;
14727
- element["checkAll"] = false;
14728
- }
14729
- if (element.html_type.includes("CHECKBOX") || element.html_type.includes("RADIO")) {
14730
- let imgFlag = element?.option?.some((v) => v.imageBase64);
14731
- element.is_contain_images = imgFlag ? 1 : 0;
14732
- }
14733
- fieldTypeList.push({
14734
- columnName: element.val_key,
14735
- fieldType: "TEXT"
14736
- });
14737
- element["isShowComponent"] = true;
14738
- }
14739
- state.defaultFieldList = fieldList;
14740
- state.fieldTypeList = fieldTypeList;
14741
- state.editForm.formFieldList = fieldList;
14742
- };
14743
- const initForm = (m = {}) => {
14744
- let { defaultCombinationForm = {}, fieldList = [] } = m;
14745
- let tempForm = {};
14746
- if (Object.keys(defaultCombinationForm).length) {
14747
- tempForm = { ...defaultCombinationForm };
14748
- }
14749
- let transmitParams = handleConvertData(tempForm);
14750
- state.defaultValue = { ...transmitParams };
14751
- hanlderInitFieldList(fieldList);
14752
- };
14753
- const getValueChange = (v, i) => {
14754
- let cacheKey = `${i.val_key}_${i.name}`;
14755
- if (i.html_type == "SEARCH_MORE") {
14756
- state.multipleSelected[cacheKey] = [...v];
14757
- }
14758
- getSelecteddefValueObj();
14759
- };
14760
- const getObjs = (str) => {
14761
- let resObj = null;
14762
- if (xeUtils.isJSON(str)) {
14763
- resObj = JSON.parse(str);
14764
- if (resObj.type === "jsonb") {
14765
- resObj = resObj.value;
14766
- if (resObj.includes("jsonb")) {
14767
- resObj = getObjs(resObj);
14768
- }
14769
- return resObj;
14770
- }
14771
- else {
14772
- return str;
14773
- }
14774
- }
14775
- else {
14776
- return str;
14777
- }
14778
- };
14779
- const handleGetSearMoreSubmit = (item, formdata) => {
14780
- const { formType, multipleSelected } = state;
14781
- const curItem = formType[item];
14782
- const defaultVal = JSON.stringify({ objs: [], objStr: "" });
14783
- let valueList = [];
14784
- let showList = [];
14785
- let keyName = `${curItem.val_key}_${curItem.name}`;
14786
- if (!curItem.wordbook)
14787
- return defaultVal;
14788
- let value_key = curItem.wordbook.value_key;
14789
- let render_key = curItem.wordbook.render_key || [];
14790
- let defVal = state.defaultValue[curItem.name] || curItem.default_val;
14791
- if (curItem.isOnchange !== "00" && defVal) {
14792
- defVal = curItem.filtration_val || handleSysParams(defVal, { defaultValue: state.defaultValue, userInfo: userInfo.value, dbParams: state.dbParams });
14793
- defVal = getObjs(defVal);
14794
- return defVal || defaultVal;
14795
- }
14796
- const targetList = JSON.parse(JSON.stringify(multipleSelected[keyName] || []));
14797
- if (Array.isArray(formdata[item]) && formdata[item].length) {
14798
- formdata[item].forEach((ele) => {
14799
- targetList.forEach((v) => {
14800
- let [curValue_key] = typeof ele.key === "string" ? ele.key.split("-") : [""];
14801
- if (`${v[value_key]}-${v["myUniqueKey"]}` == ele.key || curValue_key == v[value_key]) {
14802
- delete v.setting;
14803
- delete v.showLabel;
14804
- if (v["myUniqueKey"] && v.myUniqueLabel) {
14805
- var item2 = {
14806
- [v.myUniqueLabel]: v["myUniqueKey"],
14807
- [value_key]: v[value_key]
14808
- };
14809
- render_key.forEach((k) => {
14810
- item2[k] = v[k];
14811
- });
14812
- valueList.push(item2);
14813
- }
14814
- else {
14815
- let { myUniqueKey, myUniqueLabel, ...rest } = v;
14816
- valueList.push(rest);
14817
- }
14818
- showList.push(v[value_key]);
14819
- }
14820
- });
14821
- });
14822
- }
14823
- return JSON.stringify({
14824
- objs: valueList,
14825
- objStr: showList.join(",")
14826
- });
14827
- };
14828
- const handleFormatSubmit = (copy) => {
14829
- let formdata = xeUtils.clone(copy, true);
14830
- Object.keys(formdata).forEach((item) => {
14831
- switch (state.formType[item]?.html_type) {
14832
- case "INPUT":
14833
- case "TEXTAREA":
14834
- if (state.formType[item]?.delete_before_after_spaces == 1) {
14835
- formdata[item] = xeUtils.handleClearStrBlank(formdata[item]);
14836
- }
14837
- break;
14838
- case "DIGITAL":
14839
- case "SELECT":
14840
- case "RADIO":
14841
- case "RADIO_BLOCK":
14842
- break;
14843
- case "SEARCH":
14844
- formdata[item] = typeof formdata[item] === "string" ? formdata[item].split(">>>")[0] : formdata[item] && formdata[item].label && formdata[item].label.trim();
14845
- break;
14846
- case "SEARCH_MORE":
14847
- formdata[item] = handleGetSearMoreSubmit(item, formdata);
14848
- break;
14849
- case "CHECKBOX":
14850
- case "CHECKBOX_BLOCK":
14851
- formdata[item] = Array.isArray(formdata[item]) ? formdata[item].join(",") : formdata[item];
14852
- break;
14853
- case "DATETIME-INPUT":
14854
- case "DATE-INPUT":
14855
- case "TIME-INPUT":
14856
- case "DATE":
14857
- if (typeof formdata[item] == "string") {
14858
- formdata[item] = formdata[item] || null;
14859
- }
14860
- else {
14861
- formdata[item] = formdata[item] ? formdata[item].format(handlerGetDateType(state.formType[item])) : null;
14862
- }
14863
- break;
14864
- }
14865
- });
14866
- return formdata;
14867
- };
14868
- const handleSubmitForm = () => {
14869
- editForm.value?.validate((errors) => {
14870
- if (errors) {
14871
- emit("banSubmit", {
14872
- rowKey: props.formPrimaryKey
14873
- });
14874
- let message = errors[0].message || "";
14875
- message && window.$message.error(message);
14876
- }
14877
- else {
14878
- let submData = {};
14879
- state.editForm.formFieldList.forEach((item) => {
14880
- submData[item.val_key] = item.useFormValue;
14881
- });
14882
- submData = handleFormatSubmit(submData);
14883
- if (submData) {
14884
- submData = JSON.parse(JSON.stringify(submData));
14885
- }
14886
- let formObj = {
14887
- rowKey: props.formPrimaryKey,
14888
- formData: submData
14889
- };
14890
- emit("handleSubmit", formObj);
14891
- }
14892
- });
14893
- };
14894
- watch(() => props.defaultForm, (val) => {
14895
- if (!val || !Object.keys(val).length)
14896
- return;
14897
- let tempVal = JSON.parse(JSON.stringify(val));
14898
- initForm(tempVal);
14899
- }, { deep: true, immediate: true });
14900
- expose({
14901
- handleSubmitForm
14902
- });
14903
- return (_ctx, _cache) => {
14904
- return openBlock(), createElementBlock("div", _hoisted_1$1, [
14905
- createVNode(unref(NForm), {
14906
- ref_key: "editForm",
14907
- ref: editForm,
14908
- model: unref(state).editForm,
14909
- rules: unref(state).editRules
14910
- }, {
14911
- default: withCtx(() => [
14912
- (openBlock(true), createElementBlock(Fragment, null, renderList(unref(state).editForm.formFieldList, (item, index) => {
14913
- return openBlock(), createBlock(unref(NFormItem), {
14914
- key: index,
14915
- label: "",
14916
- path: `formFieldList.${index}.useFormValue`,
14917
- rule: unref(handleGetRules)(item),
14918
- class: normalizeClass("editeForm-item-" + item.html_type)
14919
- }, {
14920
- default: withCtx(() => [
14921
- item.isShowComponent ? (openBlock(), createBlock(resolveDynamicComponent(item.com_name), mergeProps({
14922
- key: 0,
14923
- key: item.RandomId,
14924
- class: item.html_type,
14925
- ref_for: true,
14926
- ref: item.html_type + item.val_key,
14927
- item,
14928
- defaultValue: unref(state).defaultValue
14929
- }, _ctx.$attrs, {
14930
- form: editForm.value,
14931
- onValueOnChange: getValueChange
14932
- }), null, 16, ["class", "item", "defaultValue", "form"])) : createCommentVNode("v-if", true)
14933
- ]),
14934
- _: 2
14935
- }, 1032, ["path", "rule", "class"]);
14936
- }), 128))
14937
- ]),
14938
- _: 1
14939
- }, 8, ["model", "rules"])
14940
- ]);
14941
- };
14942
- }
14943
- });
14944
-
14945
- script$1.__scopeId = "data-v-0e238fc2";
14946
- script$1.__file = "packages/big-table/src/components/edit-form/EditForm.vue";
13681
+ script$4.__scopeId = "data-v-372ca5c1";
13682
+ script$4.__file = "packages/big-table/src/components/SvgIcon.vue";
14947
13683
 
14948
13684
  var iconPrefix = 'vxe-icon--';
14949
13685
  var GlobalConfig = {
@@ -40111,6 +38847,186 @@ Grid.install = function (app) {
40111
38847
  };
40112
38848
  const CGrid = Grid;
40113
38849
 
38850
+ var script$3 = defineComponent({
38851
+ name: "EditSelectTable",
38852
+ inheritAttrs: false,
38853
+ components: {
38854
+ NSelect,
38855
+ CGrid,
38856
+ NPagination,
38857
+ NEmpty,
38858
+ NSpin,
38859
+ NSpace
38860
+ },
38861
+ props: {
38862
+ row: {
38863
+ type: Object,
38864
+ default: {}
38865
+ },
38866
+ col: {
38867
+ type: Object,
38868
+ default: {}
38869
+ },
38870
+ value: {
38871
+ type: String,
38872
+ default: ""
38873
+ }
38874
+ },
38875
+ emits: ["update:value"],
38876
+ setup(props, { attrs, slots, emit }) {
38877
+ const state = reactive({
38878
+ value: props.value,
38879
+ row: JSON.parse(JSON.stringify(props.row)),
38880
+ page: 1,
38881
+ pageCount: 0,
38882
+ keyword: "",
38883
+ data: [],
38884
+ columns: JSON.parse(JSON.stringify(props.col.tableColumn)),
38885
+ loading: false,
38886
+ show: true
38887
+ });
38888
+ const selectTableFocus = () => {
38889
+ state.show = true;
38890
+ state.page = 1;
38891
+ state.keyword = "";
38892
+ state.pageCount = 0;
38893
+ querySelectTableList();
38894
+ };
38895
+ const querySelectTableList = async () => {
38896
+ state.loading = true;
38897
+ const obj = {
38898
+ page: state.page,
38899
+ keyword: state.keyword
38900
+ };
38901
+ const { data, pageCount } = await props.col.querySelectTableList(obj);
38902
+ state.data = data;
38903
+ state.pageCount = pageCount;
38904
+ state.loading = false;
38905
+ };
38906
+ let selectTableSearch = (value) => {
38907
+ console.log("keyword", value);
38908
+ state.keyword = value;
38909
+ querySelectTableList();
38910
+ };
38911
+ selectTableSearch = xeUtils.debounce(selectTableSearch, 800);
38912
+ const getSelectTableGrid = () => {
38913
+ const config = {
38914
+ border: "outer",
38915
+ resizable: true,
38916
+ autoResize: true,
38917
+ showOverflow: true,
38918
+ showHeaderOverflow: true,
38919
+ highlightHoverRow: true,
38920
+ highlightCurrentRow: true,
38921
+ maxHeight: "500",
38922
+ align: "center",
38923
+ columns: state.columns,
38924
+ data: state.data
38925
+ };
38926
+ return /* @__PURE__ */ vueJsxCompat(CGrid, {
38927
+ ...config,
38928
+ onCellClick: (data) => onCellClick(data)
38929
+ }, {
38930
+ empty: () => /* @__PURE__ */ vueJsxCompat(NEmpty, {
38931
+ description: "\u65E0\u6570\u636E"
38932
+ })
38933
+ });
38934
+ };
38935
+ const onCellClick = (data) => {
38936
+ emit("update:value", data.row?.[props.col.columnName]);
38937
+ state.show = false;
38938
+ };
38939
+ const getPagination = () => {
38940
+ const pagination = () => {
38941
+ return /* @__PURE__ */ vueJsxCompat(NPagination, {
38942
+ "v-model": [state.page, "page"],
38943
+ pageCount: state.pageCount,
38944
+ onUpdatePage: (page) => querySelectTableList()
38945
+ });
38946
+ };
38947
+ return /* @__PURE__ */ vueJsxCompat(NSpace, {
38948
+ justify: "space-between",
38949
+ align: "center",
38950
+ style: "margin-top: 5px"
38951
+ }, [`\u5171${state.pageCount}\u6761`, pagination()]);
38952
+ };
38953
+ return () => [
38954
+ /* @__PURE__ */ vueJsxCompat(NSelect, {
38955
+ class: "form-select-table",
38956
+ options: [],
38957
+ consistentMenuWidth: false,
38958
+ clearable: true,
38959
+ filterable: true,
38960
+ to: false,
38961
+ show: state.show,
38962
+ loading: state.loading,
38963
+ onFocus: selectTableFocus,
38964
+ onBlur: () => state.show = false,
38965
+ onSearch: selectTableSearch
38966
+ }, {
38967
+ action: () => state.loading ? /* @__PURE__ */ vueJsxCompat(NSpace, {
38968
+ justify: "center"
38969
+ }, /* @__PURE__ */ vueJsxCompat(NSpin, {
38970
+ class: "spin",
38971
+ size: "small"
38972
+ })) : [getSelectTableGrid(), state.pageCount ? getPagination() : null]
38973
+ })
38974
+ ];
38975
+ }
38976
+ });
38977
+
38978
+ script$3.__scopeId = "data-v-464c5a9c";
38979
+ script$3.__file = "packages/big-table/src/components/edit-form/edit-select-table.vue";
38980
+
38981
+ var script$2 = defineComponent({
38982
+ name: "EditInput",
38983
+ inheritAttrs: false,
38984
+ components: {
38985
+ NInput
38986
+ },
38987
+ setup(props, { attrs, slots, emit }) {
38988
+ return () => [
38989
+ /* @__PURE__ */ vueJsxCompat(NInput, {
38990
+ ...attrs
38991
+ })
38992
+ ];
38993
+ }
38994
+ });
38995
+
38996
+ script$2.__file = "packages/big-table/src/components/edit-form/edit-input.vue";
38997
+
38998
+ var script$1 = defineComponent({
38999
+ name: "EditSelect",
39000
+ inheritAttrs: false,
39001
+ components: {
39002
+ NSelect
39003
+ },
39004
+ props: {
39005
+ col: {
39006
+ type: Object,
39007
+ default: {}
39008
+ }
39009
+ },
39010
+ setup(props, { attrs, slots, emit }) {
39011
+ const state = reactive({
39012
+ options: JSON.parse(JSON.stringify(props.col.options || []))
39013
+ });
39014
+ return () => [
39015
+ /* @__PURE__ */ vueJsxCompat(NSelect, {
39016
+ ...attrs,
39017
+ options: state.options,
39018
+ consistentMenuWidth: false,
39019
+ clearable: true,
39020
+ filterable: true,
39021
+ to: false,
39022
+ placeholder: "\u8BF7\u9009\u62E9"
39023
+ })
39024
+ ];
39025
+ }
39026
+ });
39027
+
39028
+ script$1.__file = "packages/big-table/src/components/edit-form/edit-select.vue";
39029
+
40114
39030
  var img$2 = "";
40115
39031
 
40116
39032
  const isJSON = (str) => {
@@ -40537,14 +39453,6 @@ const getRowStyle = ({ row }) => {
40537
39453
  }
40538
39454
  return null;
40539
39455
  };
40540
- const handleTableHeight = (state, props) => {
40541
- if (!props.isNestTable)
40542
- return props.height;
40543
- let tableHeight = props.styleSetting?.tableHeight || "table-simple";
40544
- let dataLen = props.data?.length || 1;
40545
- let height = state.checkWidth[tableHeight] * dataLen + 90;
40546
- return `${height}px`;
40547
- };
40548
39456
  const handleName = (item, key = "name") => {
40549
39457
  return item.alias || item[key];
40550
39458
  };
@@ -40853,7 +39761,7 @@ var script = /* @__PURE__ */ defineComponent({
40853
39761
  };
40854
39762
  onMounted(() => {
40855
39763
  bindDocumentClick();
40856
- state.tableHeight = handleTableHeight(state, props);
39764
+ state.tableHeight = "520px";
40857
39765
  if (!props.isNestTable)
40858
39766
  return;
40859
39767
  loadColumn(props.columnConfig);
@@ -40886,7 +39794,6 @@ var script = /* @__PURE__ */ defineComponent({
40886
39794
  setTableConfig(config, state);
40887
39795
  let columns = formatColumns(config);
40888
39796
  columns = handleGroupColums(columns, props);
40889
- console.log("columns--------------", columns);
40890
39797
  xGrid.value && xGrid.value.reloadColumn(columns);
40891
39798
  setGroupTreeExpand();
40892
39799
  resetTableInlineEditStatus();
@@ -40894,7 +39801,6 @@ var script = /* @__PURE__ */ defineComponent({
40894
39801
  const loadData = async (data) => {
40895
39802
  state.isShowEmpty = !data?.length;
40896
39803
  const list = JSON.parse(JSON.stringify(data));
40897
- console.log("list--------------", list);
40898
39804
  let table = xGrid.value;
40899
39805
  if (!table)
40900
39806
  return;
@@ -40906,6 +39812,13 @@ var script = /* @__PURE__ */ defineComponent({
40906
39812
  if (!props.isNestTable) {
40907
39813
  await handleFormTheUniqueKey();
40908
39814
  }
39815
+ formatList = formatList.map((v) => {
39816
+ return {
39817
+ ...v,
39818
+ selectTableShow: false,
39819
+ selectTableDisable: false
39820
+ };
39821
+ });
40909
39822
  console.log("table--------------", formatList);
40910
39823
  await table.loadData(formatList);
40911
39824
  table.setCurrentRow({});
@@ -40947,7 +39860,13 @@ var script = /* @__PURE__ */ defineComponent({
40947
39860
  };
40948
39861
  const formatColumns = (map) => {
40949
39862
  let { selectType } = getOtherConfigInit() || {};
40950
- let { isBatchSelect, fieldList, showButtonTop, isScanMultiTable: isScanMultiTable2 } = map;
39863
+ let { isBatchSelect, fieldList, showButtonTop, isScanMultiTable: isScanMultiTable2, isEdit = false, editConfig = {} } = map;
39864
+ if (isEdit) {
39865
+ state.editConfig = Object.assign(state.editConfig, editConfig, {
39866
+ mode: "cell",
39867
+ autoClear: true
39868
+ });
39869
+ }
40951
39870
  if (selectType) {
40952
39871
  isBatchSelect = 1;
40953
39872
  }
@@ -40959,17 +39878,28 @@ var script = /* @__PURE__ */ defineComponent({
40959
39878
  state.selectType = selectType;
40960
39879
  let tableHeight = props.styleSetting?.tableHeight || "table-simple";
40961
39880
  let checkMinWidth = state.checkWidth[tableHeight] || "30";
39881
+ const checkboxSlot = {
39882
+ default: (data) => {
39883
+ return checkMethod(data) ? null : /* @__PURE__ */ vueJsxCompat(NTooltip, {
39884
+ placement: "right",
39885
+ trigger: "hover"
39886
+ }, {
39887
+ default: () => data.row.forbiddenBatchSelectReason,
39888
+ trigger: () => /* @__PURE__ */ vueJsxCompat("i", {
39889
+ class: "disabled-checked-tips"
39890
+ })
39891
+ });
39892
+ }
39893
+ };
40962
39894
  let checkVisible = isBatchSelect == 1 && !props.isNestTable && !isScanMultiTable2 || false;
40963
39895
  let columns = [
40964
39896
  {
40965
39897
  fixed: "left",
40966
39898
  align: "center",
40967
39899
  visible: isScanMultiTable2 || false,
40968
- width: "50",
39900
+ width: "60",
40969
39901
  slots: {
40970
- header: () => {
40971
- return "\u64CD\u4F5C";
40972
- },
39902
+ header: () => "\u64CD\u4F5C",
40973
39903
  default: scanMultiOperate
40974
39904
  }
40975
39905
  },
@@ -41000,9 +39930,7 @@ var script = /* @__PURE__ */ defineComponent({
41000
39930
  visible: checkVisible,
41001
39931
  resizable: false,
41002
39932
  width: checkMinWidth,
41003
- slots: selectType === "checkbox" ? {
41004
- checkbox: "tooltip_checkbox"
41005
- } : null,
39933
+ slots: selectType === "checkbox" ? checkboxSlot : null,
41006
39934
  showOverflow: true
41007
39935
  }
41008
39936
  ];
@@ -41030,12 +39958,12 @@ var script = /* @__PURE__ */ defineComponent({
41030
39958
  showOverflow: "title",
41031
39959
  treeNode,
41032
39960
  type,
41033
- slots: {
41034
- default: (params) => {
41035
- return formatter(params, item);
41036
- }
39961
+ slots: isEdit ? {
39962
+ edit: (params) => formatterEdit(params, item)
39963
+ } : {
39964
+ default: (params) => formatter(params, item)
41037
39965
  },
41038
- editRender: generateEditRender(item)
39966
+ editRender: isEdit ? {} : generateEditRender(item)
41039
39967
  });
41040
39968
  if (filterField && !props.isNestTable && !isScanMultiTable2) {
41041
39969
  state.filterFields[item.columnName] = Object.assign({}, xeUtils.clone(item, true), {
@@ -41068,6 +39996,34 @@ var script = /* @__PURE__ */ defineComponent({
41068
39996
  state.columnLen = currentColumns.filter((item) => item.visible).length;
41069
39997
  return columns;
41070
39998
  };
39999
+ const formatterEdit = (params, col) => {
40000
+ let { row, column, $rowIndex, rowIndex } = params;
40001
+ let formType = column.formType || col.formType;
40002
+ if (formType === "selectTable") {
40003
+ const propsData = {
40004
+ row,
40005
+ col
40006
+ };
40007
+ return /* @__PURE__ */ vueJsxCompat(script$3, {
40008
+ ...propsData,
40009
+ "v-model": [row[col.columnName], "value"]
40010
+ });
40011
+ }
40012
+ if (formType === "input") {
40013
+ return /* @__PURE__ */ vueJsxCompat(script$2, {
40014
+ "v-model": [row[col.columnName], "value"]
40015
+ });
40016
+ }
40017
+ if (formType === "select") {
40018
+ const propsData = {
40019
+ col
40020
+ };
40021
+ return /* @__PURE__ */ vueJsxCompat(script$1, {
40022
+ ...propsData,
40023
+ "v-model": [row[col.columnName], "value"]
40024
+ });
40025
+ }
40026
+ };
41071
40027
  const formatter = (params, col) => {
41072
40028
  let { row, column, $rowIndex } = params;
41073
40029
  let own = column?._own || column?.own || col;
@@ -41077,14 +40033,7 @@ var script = /* @__PURE__ */ defineComponent({
41077
40033
  let dynamicProps = initBatchDynamicProps(formUnionItem, row, column, $rowIndex);
41078
40034
  if (dynamicProps) {
41079
40035
  emit("setWaitEditKeys", column.property);
41080
- return [
41081
- /* @__PURE__ */ vueJsxCompat(script$1, {
41082
- class: `js-inlineEditForm`,
41083
- key: row[props.primaryKey] + $rowIndex + column.property,
41084
- "data-key": row[props.primaryKey] + $rowIndex + column.property,
41085
- ...dynamicProps
41086
- })
41087
- ];
40036
+ return null;
41088
40037
  }
41089
40038
  }
41090
40039
  if (xeUtils.has(row, GROUP_TITLE_KEY)) {
@@ -41397,14 +40346,14 @@ var script = /* @__PURE__ */ defineComponent({
41397
40346
  isAlias = !!tooltipTitle;
41398
40347
  }
41399
40348
  if (type === "format")
41400
- return /* @__PURE__ */ vueJsxCompat(script$3, {
40349
+ return /* @__PURE__ */ vueJsxCompat(script$5, {
41401
40350
  tooltipTitle,
41402
40351
  content: name,
41403
40352
  isAlias
41404
40353
  });
41405
40354
  return () => {
41406
40355
  return [
41407
- /* @__PURE__ */ vueJsxCompat(script$3, {
40356
+ /* @__PURE__ */ vueJsxCompat(script$5, {
41408
40357
  tooltipTitle,
41409
40358
  content: name,
41410
40359
  isAlias
@@ -41685,8 +40634,12 @@ var script = /* @__PURE__ */ defineComponent({
41685
40634
  }
41686
40635
  updateAddCheckedRows(row);
41687
40636
  };
40637
+ const getFormType = (field) => {
40638
+ const obj = props.columnConfig.fieldList.find((v) => v.columnName === field);
40639
+ return obj ? obj.formType || "" : "";
40640
+ };
41688
40641
  const handlerClickRow = (data) => {
41689
- console.log("data");
40642
+ console.log("data.", data);
41690
40643
  if (isScanMultiTable.value || props.isInlineOperating)
41691
40644
  return false;
41692
40645
  if (xeUtils.has(data?.row, GROUP_TITLE_KEY))
@@ -41694,6 +40647,11 @@ var script = /* @__PURE__ */ defineComponent({
41694
40647
  if (state.isTriggerSelectionChange && state.isTree == 0)
41695
40648
  return false;
41696
40649
  let table = xGrid.value;
40650
+ const formType = getFormType(data.column.field);
40651
+ console.log("formType---", formType);
40652
+ if (formType === "selectTable") {
40653
+ table.setActiveCell(data.row, data.column.field);
40654
+ }
41697
40655
  isAboutNestTable.value && emit("resetNestLastClickTable", table);
41698
40656
  let { row, $event = {}, $rowIndex } = data;
41699
40657
  let { className } = $event.target || {};
@@ -41927,7 +40885,7 @@ var script = /* @__PURE__ */ defineComponent({
41927
40885
  return /* @__PURE__ */ vueJsxCompat(NPopconfirm, {
41928
40886
  onPositiveClick: () => confirmScanMulti(params)
41929
40887
  }, {
41930
- trigger: () => /* @__PURE__ */ vueJsxCompat(script$2, {
40888
+ trigger: () => /* @__PURE__ */ vueJsxCompat(script$4, {
41931
40889
  class: "scan-multi-delete",
41932
40890
  iconClass: "shanchu"
41933
40891
  }),
@@ -42144,7 +41102,7 @@ var script = /* @__PURE__ */ defineComponent({
42144
41102
  }, /* @__PURE__ */ vueJsxCompat("img", {
42145
41103
  class: "bigTable-qr-img",
42146
41104
  src
42147
- }), /* @__PURE__ */ vueJsxCompat("span", null, /* @__PURE__ */ vueJsxCompat(script$2, {
41105
+ }), /* @__PURE__ */ vueJsxCompat("span", null, /* @__PURE__ */ vueJsxCompat(script$4, {
42148
41106
  iconClass: "fangda"
42149
41107
  })))
42150
41108
  ];
@@ -42173,7 +41131,7 @@ var script = /* @__PURE__ */ defineComponent({
42173
41131
  class: "btn-custom-class row-btn",
42174
41132
  size: "small",
42175
41133
  text: true
42176
- }, "\u4FDD\u5B58"), /* @__PURE__ */ vueJsxCompat(NButton, {
41134
+ }, { default: () => "\u4FDD\u5B58" }), /* @__PURE__ */ vueJsxCompat(NButton, {
42177
41135
  style: { display: row.__isInlineEditing ? "inline-block" : "none" },
42178
41136
  onClick: (e) => {
42179
41137
  e.stopPropagation();
@@ -42182,7 +41140,7 @@ var script = /* @__PURE__ */ defineComponent({
42182
41140
  class: "btn-custom-class row-btn",
42183
41141
  size: "small",
42184
41142
  text: true
42185
- }, "\u53D6\u6D88"))
41143
+ }, { default: () => "\u53D6\u6D88" }))
42186
41144
  ];
42187
41145
  };
42188
41146
  const getTileBtnList = (row, index) => {
@@ -42201,7 +41159,7 @@ var script = /* @__PURE__ */ defineComponent({
42201
41159
  disabled: row.__isDisableInlineEdit,
42202
41160
  ghost: btn.showStyle == "white_bg",
42203
41161
  size: "small"
42204
- }, getBtnIcon(btn), btn.showStyle === "only_icon" ? "" : handleName(btn));
41162
+ }, { default: () => [getBtnIcon(btn), btn.showStyle === "only_icon" ? "" : handleName(btn)] });
42205
41163
  }) || ""
42206
41164
  ];
42207
41165
  };
@@ -42223,7 +41181,7 @@ var script = /* @__PURE__ */ defineComponent({
42223
41181
  }
42224
41182
  else {
42225
41183
  icon = /* @__PURE__ */ vueJsxCompat(NTooltip, null, {
42226
- trigger: () => /* @__PURE__ */ vueJsxCompat(script$2, {
41184
+ trigger: () => /* @__PURE__ */ vueJsxCompat(script$4, {
42227
41185
  iconClass: btn.icon,
42228
41186
  style: { marginRight: mr }
42229
41187
  }),
@@ -42232,7 +41190,7 @@ var script = /* @__PURE__ */ defineComponent({
42232
41190
  }
42233
41191
  }
42234
41192
  else if (btn.iconSetting) {
42235
- icon = /* @__PURE__ */ vueJsxCompat(script$2, {
41193
+ icon = /* @__PURE__ */ vueJsxCompat(script$4, {
42236
41194
  iconClass: JSON.parse(btn.iconSetting).icon,
42237
41195
  style: {
42238
41196
  marginRight: mr
@@ -42263,7 +41221,7 @@ var script = /* @__PURE__ */ defineComponent({
42263
41221
  }, /* @__PURE__ */ vueJsxCompat(NButton, {
42264
41222
  size: "small",
42265
41223
  style: "margin-left: 8px"
42266
- }, "\u66F4\u591A ...")) || ""
41224
+ }, { default: () => "\u66F4\u591A ..." })) || ""
42267
41225
  ];
42268
41226
  };
42269
41227
  const switchBtnOnChange = (e, r, i, index) => {
@@ -42590,7 +41548,8 @@ var script = /* @__PURE__ */ defineComponent({
42590
41548
  clearChecked,
42591
41549
  setCurrentRow,
42592
41550
  loadColumn,
42593
- removeInsert
41551
+ removeInsert,
41552
+ xGrid
42594
41553
  });
42595
41554
  return (_ctx, _cache) => {
42596
41555
  return openBlock(), createElementBlock("div", {
@@ -42687,7 +41646,7 @@ var script = /* @__PURE__ */ defineComponent({
42687
41646
  "scroll-x": { enabled: false },
42688
41647
  "scroll-y": { gt: 50 },
42689
41648
  "row-style": unref(getRowStyle),
42690
- "edit-config": { trigger: "manual", mode: "row", autoClear: false, showIcon: false },
41649
+ "edit-config": unref(state).editConfig,
42691
41650
  "expand-config": {
42692
41651
  lazy: true,
42693
41652
  accordion: _ctx.columnConfig && _ctx.columnConfig.accordion,
@@ -42707,7 +41666,7 @@ var script = /* @__PURE__ */ defineComponent({
42707
41666
  }, {
42708
41667
  empty: withCtx(() => [
42709
41668
  unref(state).isShowEmpty ? (openBlock(), createElementBlock("div", _hoisted_9, [
42710
- createVNode(script$4, {
41669
+ createVNode(script$6, {
42711
41670
  "no-data-img": props.emptyItems.noDataImg,
42712
41671
  "no-data-tip": props.emptyItems.noDataTip,
42713
41672
  "show-img": !props.isNestTable
@@ -42759,7 +41718,7 @@ var script = /* @__PURE__ */ defineComponent({
42759
41718
  })
42760
41719
  ]),
42761
41720
  _: 3
42762
- }, 8, ["seq-config", "tree-config", "row-id", "show-footer", "checkbox-config", "row-style", "expand-config"]),
41721
+ }, 8, ["seq-config", "tree-config", "row-id", "show-footer", "checkbox-config", "row-style", "edit-config", "expand-config"]),
42763
41722
  createCommentVNode(" `${refreshRow}\u6761\u66F4\u65B0` "),
42764
41723
  withDirectives(createElementVNode("div", {
42765
41724
  class: "refresh",