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
package/es/index.js CHANGED
@@ -1,7 +1,7 @@
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, isVNode, openBlock, createElementBlock, unref, createElementVNode, toDisplayString, withCtx, normalizeClass, renderSlot, createTextVNode, mergeProps, Fragment, renderList, createBlock, resolveDynamicComponent, useAttrs, normalizeStyle, withDirectives, vShow, pushScopeId, popScopeId, vModelCheckbox, withModifiers } from 'vue';
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, isVNode, openBlock, createElementBlock, unref, createElementVNode, toDisplayString, withCtx, normalizeClass, renderSlot, createTextVNode, mergeProps, useAttrs, normalizeStyle, withDirectives, vShow, Fragment, createBlock, pushScopeId, popScopeId, vModelCheckbox, withModifiers } from 'vue';
2
2
  import axios from 'axios';
3
- import { CaretDown, CaretForward, SyncOutline, SettingsSharp, CopyOutline, EllipsisVerticalSharp, Reload, ChevronDown } from '@vicons/ionicons5';
4
- import { NTooltip, useMessage, NForm, NFormItem, NInputGroup, NInput, NButton, NCheckbox, NCheckboxGroup, NSpace, NIcon, NPopconfirm, NDropdown, NSwitch, NPopover, NProgress, NDatePicker, NSelect, NRadio, NModal, NGrid, NFormItemGi, NInputNumber } from 'naive-ui';
3
+ import { SettingsSharp, CaretDown, CaretForward, SyncOutline, CopyOutline, EllipsisVerticalSharp, Reload, ChevronDown } from '@vicons/ionicons5';
4
+ import { NTooltip, NSelect, NPagination, NEmpty, NSpin, NSpace, NInput, useMessage, NIcon, NInputGroup, NButton, NCheckbox, NCheckboxGroup, NPopconfirm, NDropdown, NSwitch, NPopover, NProgress, NDatePicker, NRadio, NModal, NForm, NGrid, NFormItemGi, NInputNumber, NFormItem } from 'naive-ui';
5
5
  import draggable from 'vuedraggable';
6
6
 
7
7
  var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
@@ -30974,7 +30974,8 @@ const bigTableState = {
30974
30974
  editColumnMap: {},
30975
30975
  fieldLength: 0,
30976
30976
  originFormatList: [],
30977
- isSaveForm: false
30977
+ isSaveForm: false,
30978
+ editConfig: { trigger: "manual", mode: "cell", autoClear: false, showIcon: false }
30978
30979
  };
30979
30980
 
30980
30981
  const bigTableProps = {
@@ -31089,7 +31090,11 @@ const bigTableProps = {
31089
31090
  batchError: Boolean,
31090
31091
  batchFormData: { type: Object, default: () => ({}) },
31091
31092
  resetInlineBatchEdit: Function,
31092
- resetBatchEditRowStatus: Function
31093
+ resetBatchEditRowStatus: Function,
31094
+ querySelectTableList: {
31095
+ type: Function,
31096
+ default: () => Promise.resolve({ rows: [], pageCount: 0 })
31097
+ }
31093
31098
  };
31094
31099
 
31095
31100
  const bigTableEmits = [
@@ -38663,10 +38668,10 @@ var img$4 = "
38663
38668
 
38664
38669
  var img$3 = "";
38665
38670
 
38666
- const _hoisted_1$8 = { class: "no-data-tip NoData-page" };
38671
+ const _hoisted_1$7 = { class: "no-data-tip NoData-page" };
38667
38672
  const _hoisted_2$6 = ["src"];
38668
38673
  const _hoisted_3$4 = { key: 1 };
38669
- var script$9 = /* @__PURE__ */ defineComponent({
38674
+ var script$b = /* @__PURE__ */ defineComponent({
38670
38675
  props: {
38671
38676
  noDataTip: {
38672
38677
  type: String,
@@ -38714,7 +38719,7 @@ var script$9 = /* @__PURE__ */ defineComponent({
38714
38719
  return res;
38715
38720
  });
38716
38721
  return (_ctx, _cache) => {
38717
- return openBlock(), createElementBlock("div", _hoisted_1$8, [
38722
+ return openBlock(), createElementBlock("div", _hoisted_1$7, [
38718
38723
  __props.showImg ? (openBlock(), createElementBlock("img", {
38719
38724
  key: 0,
38720
38725
  src: unref(imgStr),
@@ -38727,15 +38732,15 @@ var script$9 = /* @__PURE__ */ defineComponent({
38727
38732
  }
38728
38733
  });
38729
38734
 
38730
- script$9.__scopeId = "data-v-4a4b0812";
38731
- script$9.__file = "packages/big-table/src/components/NoData.vue";
38735
+ script$b.__scopeId = "data-v-4a4b0812";
38736
+ script$b.__file = "packages/big-table/src/components/NoData.vue";
38732
38737
 
38733
- const _hoisted_1$7 = { class: "text-over-tooltip-components" };
38734
- const __default__$8 = {
38738
+ const _hoisted_1$6 = { class: "text-over-tooltip-components" };
38739
+ const __default__$7 = {
38735
38740
  name: "TextOverTooltip"
38736
38741
  };
38737
- var script$8 = /* @__PURE__ */ defineComponent({
38738
- ...__default__$8,
38742
+ var script$a = /* @__PURE__ */ defineComponent({
38743
+ ...__default__$7,
38739
38744
  props: {
38740
38745
  content: { type: [String, Number], required: false },
38741
38746
  className: { type: String, required: false },
@@ -38769,7 +38774,7 @@ var script$8 = /* @__PURE__ */ defineComponent({
38769
38774
  isDisabledTooltip.value = false;
38770
38775
  };
38771
38776
  return (_ctx, _cache) => {
38772
- return openBlock(), createElementBlock("div", _hoisted_1$7, [
38777
+ return openBlock(), createElementBlock("div", _hoisted_1$6, [
38773
38778
  createVNode(unref(NTooltip), {
38774
38779
  effect: __props.effect,
38775
38780
  show: unref(isDisabledTooltip),
@@ -38802,16 +38807,16 @@ var script$8 = /* @__PURE__ */ defineComponent({
38802
38807
  }
38803
38808
  });
38804
38809
 
38805
- script$8.__scopeId = "data-v-6633a934";
38806
- script$8.__file = "packages/big-table/src/components/TextOverTooltip.vue";
38810
+ script$a.__scopeId = "data-v-6633a934";
38811
+ script$a.__file = "packages/big-table/src/components/TextOverTooltip.vue";
38807
38812
 
38808
- const _hoisted_1$6 = { key: 0 };
38813
+ const _hoisted_1$5 = { key: 0 };
38809
38814
  const _hoisted_2$5 = ["xlink:href"];
38810
- const __default__$7 = {
38815
+ const __default__$6 = {
38811
38816
  name: "SvgIcon"
38812
38817
  };
38813
- var script$7 = /* @__PURE__ */ defineComponent({
38814
- ...__default__$7,
38818
+ var script$9 = /* @__PURE__ */ defineComponent({
38819
+ ...__default__$6,
38815
38820
  props: {
38816
38821
  iconClass: { type: String, required: true, default: "" },
38817
38822
  title: { type: String, required: true, default: "" },
@@ -38833,1284 +38838,195 @@ var script$7 = /* @__PURE__ */ defineComponent({
38833
38838
  class: unref(svgClass),
38834
38839
  "aria-hidden": "true"
38835
38840
  }, _ctx.$attrs), [
38836
- __props.title ? (openBlock(), createElementBlock("title", _hoisted_1$6, toDisplayString(__props.title), 1)) : createCommentVNode("v-if", true),
38841
+ __props.title ? (openBlock(), createElementBlock("title", _hoisted_1$5, toDisplayString(__props.title), 1)) : createCommentVNode("v-if", true),
38837
38842
  createElementVNode("use", { "xlink:href": unref(iconName) }, null, 8, _hoisted_2$5)
38838
38843
  ], 16);
38839
38844
  };
38840
38845
  }
38841
38846
  });
38842
38847
 
38843
- script$7.__scopeId = "data-v-372ca5c1";
38844
- script$7.__file = "packages/big-table/src/components/SvgIcon.vue";
38845
-
38846
- const configData = {
38847
- comTypeMap: {
38848
- "INPUT": "editInput",
38849
- "DIGITAL": "editDigital",
38850
- "TEXTAREA": "editTextarea",
38851
- "RADIO": "editSelect",
38852
- "RADIO_BLOCK": "editSelect",
38853
- "CHECKBOX_BLOCK": "editSelectMultiple",
38854
- "CHECKBOX": "editSelectMultiple",
38855
- "SEARCH": "editSearch",
38856
- "SEARCH_MORE": "editSearchMore",
38857
- "DATE": "editDatePicker",
38858
- "DATE-INPUT": "editDatePicker",
38859
- "TIME-INPUT": "editDatePicker",
38860
- "DATETIME-INPUT": "editDatePicker",
38861
- "SELECT": "editSelect",
38862
- "PHONE_TYPE": "editSelect",
38863
- "IDCARD_TYPE": "editSelect",
38864
- "editMonthPicker": "editMonthPicker",
38865
- "editTimePicker": "editTimePicker",
38866
- "editDatePicker": "editDatePicker",
38867
- "editSelect": "editSelect",
38868
- "editInputPassword": "editInputPassword",
38869
- "editSelectMultiple": "editSelectMultiple",
38870
- "MAP": "editInput",
38871
- "ICON": "editInput",
38872
- "UPPICTURE": "editInput",
38873
- "LEVEL_SEARCH_CASCADE2": "editInput",
38874
- "LABEL": "editInput",
38875
- "GUAGE": "editInput",
38876
- "SLIDER_COMPONENT": "editInput",
38877
- "SWITCH_COMPONENT": "editInput",
38878
- "AGE_JSON": "editInput",
38879
- "AGE": "editInput"
38848
+ script$9.__scopeId = "data-v-372ca5c1";
38849
+ script$9.__file = "packages/big-table/src/components/SvgIcon.vue";
38850
+
38851
+ var script$8 = defineComponent({
38852
+ name: "EditSelectTable",
38853
+ inheritAttrs: false,
38854
+ components: {
38855
+ NSelect,
38856
+ CGrid,
38857
+ NPagination,
38858
+ NEmpty,
38859
+ NSpin,
38860
+ NSpace
38880
38861
  },
38881
- getComName(v) {
38882
- const { isMonthPicker_com, isDate_com, isTimePicker_com, isSelect_com, isPassword_com, comTypeMap } = this;
38883
- if (isDate_com(v.html_type)) {
38884
- if (isMonthPicker_com(v))
38885
- return "editMonthPicker";
38886
- if (isTimePicker_com(v))
38887
- return "editTimePicker";
38888
- return "editDatePicker";
38889
- }
38890
- if (isSelect_com(v))
38891
- return "editSelect";
38892
- if (isPassword_com(v))
38893
- return "editInputPassword";
38894
- const res = comTypeMap[v.html_type];
38895
- if (res) {
38896
- return res;
38862
+ props: {
38863
+ row: {
38864
+ type: Object,
38865
+ default: {}
38866
+ },
38867
+ col: {
38868
+ type: Object,
38869
+ default: {}
38870
+ },
38871
+ value: {
38872
+ type: String,
38873
+ default: ""
38897
38874
  }
38898
- return "editInput";
38899
- },
38900
- isMonthPicker_com(v) {
38901
- return v.date_format && v.date_format.replace(/yyyy-MM/gi, "YYYY-MM") == "YYYY-MM";
38902
- },
38903
- isDate_com(key) {
38904
- return key === "DATE" || key === "DATE-INPUT" || key === "DATETIME-INPUT";
38905
38875
  },
38906
- isTimePicker_com(v) {
38907
- return String(v.html_type) == "TIME-INPUT" || v.date_format == "HH:mm:ss" || v.date_format == "HH:mm";
38908
- },
38909
- isSelect_com(v) {
38910
- return ["SELECT", "PHONE_TYPE", "IDCARD_TYPE"].includes(v.html_type);
38911
- },
38912
- isPassword_com(v) {
38913
- return (v?.validate?.obj_type || "") === "password";
38914
- }
38915
- };
38916
-
38917
- const handleSysParams = (str, obj) => {
38918
- let p = {
38919
- form: { ...obj.defaultValue },
38920
- sys: obj.userInfo?.map?.sysParams || {},
38921
- db: { ...obj.dbParams || {} }
38922
- };
38923
- const getVal = (t, r, k) => {
38924
- return t.replace(r, function () {
38925
- let pKey = arguments[1];
38926
- let pls = pKey.split("!");
38927
- let plsList = pls.slice(1);
38928
- let l = [];
38929
- plsList.forEach((v) => {
38930
- let c = v;
38931
- if (v.includes(".")) {
38932
- let [_k, _v] = v.split(".");
38933
- c = typeof p[_k] === "object" ? p[_k][_v] : "";
38934
- }
38935
- if (c || +c == 0) {
38936
- l.push(c);
38937
- }
38938
- });
38939
- let f = l.find((v) => v || +v == 0);
38940
- let res = p[k][pls[0]];
38941
- res = xeUtils.notEmpty(res) ? res : "";
38942
- if (pls.length > 1) {
38943
- return res || f;
38944
- }
38945
- return res;
38876
+ emits: ["update:value"],
38877
+ setup(props, { attrs, slots, emit }) {
38878
+ const state = reactive({
38879
+ value: props.value,
38880
+ row: JSON.parse(JSON.stringify(props.row)),
38881
+ page: 1,
38882
+ pageCount: 0,
38883
+ keyword: "",
38884
+ data: [],
38885
+ columns: JSON.parse(JSON.stringify(props.col.tableColumn)),
38886
+ loading: false,
38887
+ show: true
38946
38888
  });
38947
- };
38948
- if (typeof str === "string") {
38949
- if (str.includes("form")) {
38950
- str = getVal(str, /\${form.(.*?)\}/g, "form");
38951
- }
38952
- if (str.includes("sys")) {
38953
- str = getVal(str, /\${sys.(.*?)\}/g, "sys");
38954
- }
38955
- if (str.includes("db")) {
38956
- str = getVal(str, /\${db.(.*?)\}/g, "db");
38957
- }
38958
- }
38959
- if (!str && +str != 0 || ["undefined", "null"].includes(String(str))) {
38960
- str = "";
38961
- }
38962
- return str;
38963
- };
38964
- const handlerGetDateType = (data) => {
38965
- let dateType;
38966
- switch (data.html_type) {
38967
- case "DATETIME-INPUT":
38968
- dateType = "yyyy-MM-dd HH:mm:ss";
38969
- break;
38970
- case "DATE-INPUT":
38971
- dateType = "yyyy-MM-dd";
38972
- break;
38973
- case "TIME-INPUT":
38974
- dateType = "HH:mm:ss";
38975
- break;
38976
- case "DATE":
38977
- data.date_format = data.date_format && data.date_format.replace(/yyyy/gi, "yyyy");
38978
- 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");
38979
- break;
38980
- default:
38981
- dateType = data.date_format || "yyyy-MM-dd";
38982
- break;
38983
- }
38984
- return dateType;
38985
- };
38986
- const handleGetJsonStr = (str) => {
38987
- let resObj = {};
38988
- if (xeUtils.isJSON(str)) {
38989
- resObj = JSON.parse(str);
38990
- }
38991
- else {
38992
- resObj = typeof str === "string" ? {} : str;
38993
- }
38994
- if (resObj && !resObj.objs && resObj.value) {
38995
- if (xeUtils.isJSON(resObj.value)) {
38996
- resObj = JSON.parse(resObj.value);
38997
- if (resObj.type === "jsonb") {
38998
- resObj = handleGetJsonStr(resObj);
38999
- }
39000
- }
39001
- }
39002
- return resObj;
39003
- };
39004
-
39005
- const useFormCommon = (props, state, userInfo, computedData) => {
39006
- const paramsObj = { defaultValue: state.defaultValue, userInfo, dbParams: state.dbParams };
39007
- computed(() => {
39008
- return function (item) {
39009
- let res = item.is_null == "0" && props.styleSetting.formBoldOpen;
39010
- return res;
38889
+ const selectTableFocus = () => {
38890
+ state.show = true;
38891
+ state.page = 1;
38892
+ state.keyword = "";
38893
+ state.pageCount = 0;
38894
+ querySelectTableList();
39011
38895
  };
39012
- });
39013
- computed(() => {
39014
- return function (item) {
39015
- let { combinationList = [] } = item || {};
39016
- if (!combinationList.length)
39017
- return false;
39018
- let showCombination = combinationList.filter((v) => !v.isCombinationHide);
39019
- return showCombination?.length > 1;
38896
+ const querySelectTableList = async () => {
38897
+ state.loading = true;
38898
+ const obj = {
38899
+ page: state.page,
38900
+ keyword: state.keyword
38901
+ };
38902
+ const { data, pageCount } = await props.col.querySelectTableList(obj);
38903
+ state.data = data;
38904
+ state.pageCount = pageCount;
38905
+ state.loading = false;
39020
38906
  };
39021
- });
39022
- const handleGetcheckboxDef = (item) => {
39023
- let optionsList = item.option;
39024
- let valList = [];
39025
- let checkboxVal = state.defaultValue[item.name] || item.default_val;
39026
- let checkboxList = [];
39027
- checkboxVal = handleSysParams(checkboxVal, paramsObj);
39028
- if (typeof checkboxVal === "string") {
39029
- if (xeUtils.isJSON(checkboxVal)) {
39030
- checkboxList = JSON.parse(checkboxVal);
39031
- }
39032
- else {
39033
- checkboxList = checkboxVal ? checkboxVal.split(",") : [];
39034
- }
39035
- }
39036
- else if (Array.isArray(checkboxVal)) {
39037
- checkboxList = checkboxVal;
39038
- }
39039
- checkboxList = Array.isArray(checkboxList) ? checkboxList : [];
39040
- checkboxList.forEach((v) => {
39041
- optionsList.forEach((j) => {
39042
- if (j.text == v || j.value == v) {
39043
- valList.push(String(v));
39044
- }
39045
- });
39046
- });
39047
- return valList || [];
39048
- };
39049
- const transformStr = (item) => {
39050
- var def = state.defaultValue[item.name];
39051
- var propsDef = def || def !== "" && def == 0 ? def : item.default_val;
39052
- let defVal = propsDef || propsDef == 0 ? propsDef : "";
39053
- defVal = String(defVal);
39054
- return defVal;
39055
- };
39056
- const handlerFormatTextarea = (data) => {
39057
- let defVal = state.defaultValue[data.name] || data.default_val || "";
39058
- defVal = handleSysParams(defVal, paramsObj);
39059
- if (!defVal) {
39060
- return "";
39061
- }
39062
- else if (defVal instanceof Object) {
39063
- return JSON.stringify(defVal);
39064
- }
39065
- return defVal;
39066
- };
39067
- const handleGetTextDef = (item) => {
39068
- let defVal = "";
39069
- var def = state.defaultValue[item.name];
39070
- var propsDef = def || def !== "" && def === 0 ? def : handleSysParams(item.data_value || item.default_val, paramsObj);
39071
- defVal = propsDef || propsDef === 0 ? propsDef : void 0;
39072
- if (item.html_type === "DIGITAL") {
39073
- defVal = defVal ? +defVal : defVal;
39074
- }
39075
- return defVal;
39076
- };
39077
- const handleDateCondition = (item) => {
39078
- let { condition, attr, unit = "DAY", default_val } = item;
39079
- let format = handlerGetDateType(item);
39080
- let useTime, count = Number(default_val) || 0;
39081
- let getUnit = unit.toLowerCase();
39082
- let useUnit = getUnit + "s";
39083
- if (condition == "IN_THE_PAST") {
39084
- useTime = moment().subtract(count, useUnit);
39085
- }
39086
- else {
39087
- useTime = moment().add(count, useUnit);
39088
- }
39089
- let res = useTime.format(format);
39090
- if (attr == "startDate") {
39091
- res = useTime.startOf("day").format(format);
39092
- }
39093
- else if (attr == "endDate") {
39094
- res = useTime.endOf("day").format(format);
39095
- }
39096
- return res;
39097
- };
39098
- const handleGetdateTypeDef = (item) => {
39099
- var propsDate = state.defaultValue[item.name] || item.default_val;
39100
- if (item.condition === "IN_THE_PAST" || item.condition === "IN_THE_FUTURE") {
39101
- propsDate = handleDateCondition(item);
39102
- }
39103
- else {
39104
- propsDate = handleSysParams(propsDate, paramsObj);
39105
- }
39106
- let dateType = handlerGetDateType(item);
39107
- if (dateType == "HH:mm:ss" || dateType == "HH:mm") {
39108
- return propsDate && moment(propsDate, dateType).isValid() ? moment(propsDate, dateType) : null;
39109
- }
39110
- else {
39111
- if (dateType === "YYYY-MM-DD HH:mm:ss" && propsDate) {
39112
- if (typeof propsDate === "string") {
39113
- let [, h] = propsDate.split(" ");
39114
- if (!h) {
39115
- propsDate = `${propsDate} 00:00:00`;
39116
- }
39117
- }
39118
- }
39119
- return propsDate && moment(new Date(propsDate), dateType).isValid() ? moment(new Date(propsDate), dateType) : null;
39120
- }
39121
- };
39122
- const transformDefStr = (item) => {
39123
- var def = state.defaultValue[item.name];
39124
- var propsDef = def || def !== "" && def == 0 ? def : item.default_val;
39125
- let defVal = propsDef || propsDef == 0 ? propsDef : "";
39126
- defVal = String(defVal);
39127
- return defVal;
39128
- };
39129
- const getSelectVal = (data) => {
39130
- let targetStr = transformDefStr(data) || "";
39131
- if (["SELECT", "PHONE_TYPE", "IDCARD_TYPE"].includes(data.html_type)) {
39132
- targetStr = String(targetStr);
39133
- targetStr = handleSysParams(targetStr, paramsObj);
39134
- if (!Array.isArray(data.option))
39135
- return targetStr;
39136
- let f = data.option.find((o) => o.value == targetStr);
39137
- if (f) {
39138
- return targetStr;
39139
- }
39140
- else {
39141
- const curVal = data.option[0] && data.option[0].value;
39142
- return curVal;
39143
- }
39144
- }
39145
- else {
39146
- return targetStr;
39147
- }
39148
- };
39149
- const handlerDefaultUpload = (data, type = "default") => {
39150
- let currentData;
39151
- let fileList;
39152
- if (xeUtils.isJSON(data)) {
39153
- currentData = JSON.parse(data);
39154
- }
39155
- else {
39156
- currentData = data;
39157
- }
39158
- if (currentData instanceof Array) {
39159
- currentData.forEach((item) => {
39160
- item.thumbUrl = item.url;
39161
- item.uid = (-Math.random()).toString();
39162
- item.status = "done";
39163
- });
39164
- fileList = currentData;
39165
- }
39166
- else if (typeof currentData === "string" && currentData.length > 0) {
39167
- const currentList = currentData.split(",");
39168
- fileList = [];
39169
- currentList.forEach((v) => {
39170
- if (v) {
39171
- fileList.push({
39172
- url: v,
39173
- thumbUrl: v,
39174
- uid: (-Math.random()).toString(),
39175
- name: "name",
39176
- status: "done"
39177
- });
39178
- }
39179
- });
39180
- }
39181
- else {
39182
- fileList = [];
39183
- }
39184
- if (type === "default") {
39185
- return fileList;
39186
- }
39187
- else {
39188
- return { fileList };
39189
- }
39190
- };
39191
- const getCascaderDef = (v) => {
39192
- try {
39193
- const is_multi = v.is_multi == "1";
39194
- let defaultValue = state.defaultValue[v.name] || v.default_val;
39195
- if (typeof defaultValue === "string") {
39196
- defaultValue = handleSysParams(defaultValue, paramsObj);
39197
- if (!xeUtils.isJSON(defaultValue)) {
39198
- return [];
39199
- }
39200
- }
39201
- if (!defaultValue)
39202
- return [];
39203
- if (defaultValue.includes("objStr")) {
39204
- if (is_multi) {
39205
- const multiData = handleGetJsonStr(defaultValue);
39206
- const objs = multiData["objs"] || [];
39207
- const objStrList = [];
39208
- objs.forEach((e) => {
39209
- objStrList.push(e.objStr.split("/"));
39210
- });
39211
- return [...objStrList];
39212
- }
39213
- else {
39214
- defaultValue = handleGetJsonStr(defaultValue).objStr;
39215
- }
39216
- }
39217
- if (typeof defaultValue == "string") {
39218
- if (defaultValue.includes("_")) {
39219
- defaultValue = defaultValue.split("_");
39220
- }
39221
- else {
39222
- defaultValue = defaultValue.split("/");
39223
- }
39224
- }
39225
- if (!Array.isArray(defaultValue)) {
39226
- defaultValue = [];
39227
- }
39228
- else {
39229
- defaultValue = defaultValue.filter(Boolean);
39230
- }
39231
- return is_multi ? [] : defaultValue || [];
39232
- }
39233
- catch (error) {
39234
- console.log(error);
39235
- return [];
39236
- }
39237
- };
39238
- const getInitializeDef = (item) => {
39239
- return handleSysParams(state.defaultValue[item.name] || item.default_val || "", paramsObj);
39240
- };
39241
- const transformNumber = (val) => {
39242
- if (val) {
39243
- let resVal = +val;
39244
- return isNaN(resVal) ? 0 : resVal;
39245
- }
39246
- return void 0;
39247
- };
39248
- const handleGetdef = (item) => {
39249
- let defVal;
39250
- switch (item.html_type) {
39251
- case "CHECKBOX_BLOCK":
39252
- case "CHECKBOX":
39253
- defVal = handleGetcheckboxDef(item);
39254
- break;
39255
- case "RADIO_BLOCK":
39256
- case "RADIO":
39257
- defVal = transformStr(item);
39258
- defVal = handleSysParams(defVal, paramsObj);
39259
- if (!defVal && +defVal != 0) {
39260
- defVal = void 0;
39261
- }
39262
- break;
39263
- case "MAP":
39264
- defVal = state.defaultValue[item.name] || item.default_val || "";
39265
- defVal = handleSysParams(defVal, paramsObj);
39266
- break;
39267
- case "TEXTAREA":
39268
- defVal = handlerFormatTextarea(item) || "";
39269
- break;
39270
- case "INPUT":
39271
- case "DIGITAL":
39272
- case "ICON":
39273
- defVal = handleGetTextDef(item);
39274
- break;
39275
- case "DATE":
39276
- case "DATE-INPUT":
39277
- case "DATETIME-INPUT":
39278
- defVal = handleGetdateTypeDef(item);
39279
- break;
39280
- case "SELECT":
39281
- case "PHONE_TYPE":
39282
- case "IDCARD_TYPE":
39283
- defVal = getSelectVal(item);
39284
- break;
39285
- case "UPPICTURE":
39286
- var def = state.defaultValue[item.name] || item.default_val;
39287
- if (typeof def === "string") {
39288
- def = handleSysParams(def, paramsObj);
39289
- }
39290
- defVal = handlerDefaultUpload(def, "values");
39291
- break;
39292
- case "SEARCH":
39293
- defVal = handleSysParams(item.default_val, paramsObj) || state.defaultValue[item.name] || void 0;
39294
- break;
39295
- case "SEARCH_MORE":
39296
- defVal = [];
39297
- break;
39298
- case "LEVEL_SEARCH_CASCADE2":
39299
- defVal = getCascaderDef(item);
39300
- break;
39301
- case "LABEL":
39302
- defVal = [];
39303
- break;
39304
- case "GUAGE":
39305
- defVal = state.defaultValue[item.name];
39306
- break;
39307
- case "SLIDER_COMPONENT":
39308
- defVal = getInitializeDef(item);
39309
- defVal = transformNumber(defVal);
39310
- break;
39311
- case "SWITCH_COMPONENT":
39312
- defVal = getInitializeDef(item);
39313
- break;
39314
- case "AGE_JSON":
39315
- let d = String(getInitializeDef(item) || {});
39316
- if (xeUtils.isJSON(d)) {
39317
- d = JSON.parse(d);
39318
- }
39319
- if (typeof d == "object") {
39320
- Object.keys(d).forEach((v) => {
39321
- d[v] = [-1, "-1"].includes(d[v]) ? "" : d[v];
39322
- });
39323
- defVal = Object.assign({ year: "", month: "", day: "", days: "" }, d);
39324
- }
39325
- else {
39326
- defVal = { year: "", month: "", day: "", days: "" };
39327
- }
39328
- break;
39329
- case "AGE":
39330
- defVal = state.defaultValue[item.name] || handleSysParams(item.default_val || "", paramsObj);
39331
- break;
39332
- }
39333
- if (item.html_type === "ICON") {
39334
- state.defaultValue[item.name] = defVal;
39335
- }
39336
- return defVal;
39337
- };
39338
- const RandomId = (len) => {
39339
- return Math.random().toString(36).slice(3, len) + new Date().getTime();
39340
- };
39341
- return {
39342
- handleGetdef,
39343
- RandomId
39344
- };
39345
- };
39346
-
39347
- const useValidateRules = () => {
39348
- const checkLenght = (rule, value, item) => {
39349
- try {
39350
- const { validate = {}, is_null, html_type } = item || {};
39351
- let { min_length, max_length } = validate || {};
39352
- let curval = value + "";
39353
- if (html_type === "INPUT") {
39354
- max_length = max_length ? +max_length : 300;
39355
- }
39356
- else if (html_type === "TEXTAREA") {
39357
- max_length = max_length ? +max_length : 500;
39358
- }
39359
- else if (html_type === "RICH_TEXT") {
39360
- const div = document.createElement("div");
39361
- div.innerHTML = value;
39362
- curval = div.innerText;
39363
- }
39364
- const strlen = curval.length;
39365
- let max = strlen > max_length, min = min_length > strlen;
39366
- if (is_null == 0 && !value && value != 0) {
39367
- return new Error(`\u8BF7\u8F93\u5165${min_length || 0}-${max_length}\u4E2A\u5B57\u7B26`);
39368
- }
39369
- if (is_null == 1 && !value) {
39370
- return true;
39371
- }
39372
- if ((min_length || String(min_length) === "0") && max_length && (max || min)) {
39373
- return new Error(`\u8BF7\u8F93\u5165${min_length || 0}-${max_length}\u4E2A\u5B57\u7B26`);
39374
- }
39375
- else if (min_length && min) {
39376
- return new Error(`\u81F3\u5C11\u8F93\u5165${min_length}\u4E2A\u5B57\u7B26`);
39377
- }
39378
- else if (max_length && max) {
39379
- return new Error(`\u6700\u591A\u53EA\u80FD\u8F93\u5165${max_length}\u4E2A\u5B57\u7B26`);
39380
- }
39381
- return true;
39382
- }
39383
- catch (error) {
39384
- console.log(error, "------checkLenght");
39385
- return true;
39386
- }
39387
- };
39388
- const getInputCheck = (validate = void 0) => {
39389
- if (!validate)
39390
- return false;
39391
- const isInteger = validate == "integer";
39392
- return {
39393
- pattern: isInteger ? /^-?[0-9]+$/ : /^(-?[0-9]+)(\\.[0-9]+)?$/,
39394
- message: isInteger ? "\u53EA\u80FD\u8F93\u5165\u6570\u5B57" : "\u53EA\u80FD\u8F93\u5165\u6570\u5B57\u548C\u5C0F\u6570"
38907
+ let selectTableSearch = (value) => {
38908
+ console.log("keyword", value);
38909
+ state.keyword = value;
38910
+ querySelectTableList();
39395
38911
  };
39396
- };
39397
- const handlerSetIdCarInfoValidate = (rule, value, item) => {
39398
- try {
39399
- const { validate = {} } = item || {};
39400
- if (validate.vali_obj == "id_card") {
39401
- 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}))$/;
39402
- if (!pat.test(value)) {
39403
- return new Error(`\u8BF7\u8F93\u5165\u6B63\u786E\u7684\u8EAB\u4EFD\u8BC1\u53F7\u7801`);
39404
- }
39405
- }
39406
- return true;
39407
- }
39408
- catch (error) {
39409
- console.log(error, "------handlerSetIdCarInfoValidate");
39410
- return true;
39411
- }
39412
- };
39413
- const checkinputBlank = (rule, value, item) => {
39414
- try {
39415
- const { is_null, delete_before_after_spaces } = item;
39416
- if (typeof value === "string" && delete_before_after_spaces == 1) {
39417
- let val = value.trim();
39418
- if (!val && is_null == 0) {
39419
- return new Error(`\u4E0D\u53EF\u4E3A\u7A7A`);
39420
- }
39421
- }
39422
- return true;
39423
- }
39424
- catch (error) {
39425
- console.log(error, "------checkinputBlank");
39426
- return true;
39427
- }
39428
- };
39429
- const checkDigital = (rule, value, item) => {
39430
- try {
39431
- const { validate, is_null, decimal_length, alias, name } = item;
39432
- const { min_value, max_value } = validate || {};
39433
- let showName = alias || name;
39434
- if (isNaN(+value)) {
39435
- return new Error(`\u53EA\u80FD\u8F93\u5165\u6570\u5B57`);
39436
- }
39437
- if (is_null == 0 && !value && value != 0) {
39438
- return new Error(`\u8BF7\u8F93\u5165${showName}\u6709\u6548\u8303\u56F4`);
39439
- }
39440
- if (!value && value !== 0) {
39441
- if (is_null == 0) {
39442
- return new Error(`\u8BF7\u8F93\u5165${showName}\u6709\u6548\u8303\u56F4`);
39443
- }
39444
- return true;
39445
- }
39446
- const decimalLen = decimal_length || validate.decimal_length;
39447
- const valList = (value + "").trim().split(".");
39448
- if (decimalLen && decimalLen != 0) {
39449
- if (valList[1] && valList[1].length > decimalLen) {
39450
- return new Error(`\u5C0F\u6570\u6700\u591A${decimalLen}\u4F4D`);
39451
- }
39452
- }
39453
- else {
39454
- const flag = /^-?[0-9]+$/.test(value);
39455
- if (!flag) {
39456
- return new Error(`\u8BF7\u8F93\u5165\u6574\u6570`);
39457
- }
39458
- }
39459
- let max = +value > +max_value, min = +min_value > +value;
39460
- if ((min_value || max_value) && (value || value == 0)) {
39461
- if ((min_value || String(min_value) === "0") && max_value && (max || min)) {
39462
- return new Error(`\u8BF7\u8F93\u5165${min_value}~${max_value}`);
39463
- }
39464
- else if (min_value && min || max_value && max) {
39465
- return new Error(`\u8BF7\u8F93\u5165${showName}\u6709\u6548\u8303\u56F4`);
39466
- }
39467
- return true;
39468
- }
39469
- return true;
39470
- }
39471
- catch (error) {
39472
- console.log(error, "------checkDigital");
39473
- return true;
39474
- }
39475
- };
39476
- const checkAgeJson = (rule, value, item) => {
39477
- try {
39478
- const { is_null, alias, name } = item;
39479
- const { year, month, day, days } = value;
39480
- const c = (val) => String(val) === "0" || val > 0;
39481
- const checkval = () => !(c(year) || c(month) || c(day));
39482
- if (is_null == 0) {
39483
- if (checkval()) {
39484
- return new Error(`\u8BF7\u8F93\u5165${alias || name}`);
39485
- }
39486
- else if (days > 73e3) {
39487
- return new Error(`\u8D85\u51FA\u5E74\u9F84\u8303\u56F40~200\u5C81`);
39488
- }
39489
- }
39490
- return true;
39491
- }
39492
- catch (error) {
39493
- console.log(error, "------checkAgeJson");
39494
- return true;
39495
- }
39496
- };
39497
- const checkAge = (rule, value, item) => {
39498
- try {
39499
- let { is_null, name, alias } = item;
39500
- if (!value && is_null == 0) {
39501
- return new Error(`${alias || name}\u4E0D\u80FD\u4E3A\u7A7A`);
39502
- }
39503
- if (!item.val_key_unit) {
39504
- return true;
39505
- }
39506
- const curVal = item?.useFormValue;
39507
- let k = typeof curVal === "string" && curVal.toLowerCase();
39508
- const o = {
39509
- year: 200,
39510
- month: 2400,
39511
- day: 73e3
38912
+ selectTableSearch = xeUtils.debounce(selectTableSearch, 800);
38913
+ const getSelectTableGrid = () => {
38914
+ const config = {
38915
+ border: "outer",
38916
+ resizable: true,
38917
+ autoResize: true,
38918
+ showOverflow: true,
38919
+ showHeaderOverflow: true,
38920
+ highlightHoverRow: true,
38921
+ highlightCurrentRow: true,
38922
+ maxHeight: "500",
38923
+ align: "center",
38924
+ columns: state.columns,
38925
+ data: state.data
39512
38926
  };
39513
- if (k) {
39514
- if (value > o[k]) {
39515
- return new Error(`\u8D85\u51FA\u5E74\u9F84\u8303\u56F40~200\u5C81`);
39516
- }
39517
- }
39518
- return true;
39519
- }
39520
- catch (error) {
39521
- console.log(error, "------checkAge");
39522
- return true;
39523
- }
39524
- };
39525
- const handleUploadValidator = (rule, value, item) => {
39526
- try {
39527
- let curval = value;
39528
- const { is_null, name, validate, html_type } = item;
39529
- let { min_length, max_length } = validate || {};
39530
- let unit = html_type === "UPPICTURE" ? "\u5F20" : "\u4E2A";
39531
- if (html_type === "UPPICTURE") {
39532
- curval = curval.split(",").filter(Boolean);
39533
- }
39534
- else if (xeUtils.isJSON(value || "")) {
39535
- curval = JSON.parse(curval);
39536
- }
39537
- let len = curval?.length || 0;
39538
- if (is_null == 1 && len === 0) {
39539
- return true;
39540
- }
39541
- else if (is_null == 0 && (!curval || len === 0)) {
39542
- return new Error(`\u8BF7\u4E0A\u4F20${name}`);
39543
- }
39544
- else if (len > 0) {
39545
- if (len < min_length) {
39546
- return new Error(`\u6700\u5C11\u4E0A\u4F20${min_length}${unit}`);
39547
- }
39548
- else if (len > max_length) {
39549
- return new Error(`\u6700\u591A\u53EA\u80FD\u4E0A\u4F20${max_length}${unit}`);
39550
- }
39551
- }
39552
- return true;
39553
- }
39554
- catch (error) {
39555
- console.log(error, "------handleUploadValidator");
39556
- return true;
39557
- }
39558
- };
39559
- const checkMultipleChoice = (rule, value, item) => {
39560
- try {
39561
- const { multi_select, multi_select_value, is_null, alias, name } = item;
39562
- if (Array.isArray(value)) {
39563
- if (is_null == 0) {
39564
- if (value.length === 0) {
39565
- return new Error(`\u8BF7\u9009\u62E9${alias || name}`);
39566
- }
39567
- }
39568
- if (is_null == 1 && value.length === 0) {
39569
- return true;
39570
- }
39571
- if (multi_select_value) {
39572
- if (value.length > multi_select_value) {
39573
- return new Error(`\u6700\u591A\u53EA\u80FD\u9009\u62E9${multi_select_value}\u9879`);
39574
- }
39575
- }
39576
- }
39577
- return true;
39578
- }
39579
- catch (error) {
39580
- console.log(error, "------checkMultipleChoice");
39581
- return true;
39582
- }
39583
- };
39584
- const checkcandidate = (rule, value, item) => {
39585
- try {
39586
- let curval = value;
39587
- const { is_null, name, validate, check_max_val, check_min_val } = item;
39588
- if (is_null == 0 && !curval) {
39589
- return new Error(`\u8BF7\u9009${name}`);
39590
- }
39591
- if (xeUtils.isJSON(value || "")) {
39592
- curval = JSON.parse(curval);
39593
- }
39594
- if (is_null != 0 && !Array.isArray(curval)) {
39595
- return true;
39596
- }
39597
- let len = curval?.length || 0;
39598
- if (is_null == 1 && len === 0) {
39599
- return true;
39600
- }
39601
- else if (is_null == 0 && (!curval || len === 0)) {
39602
- return new Error(`\u8BF7\u9009${name}`);
39603
- }
39604
- else if (len > 0) {
39605
- if (len < check_min_val) {
39606
- return new Error(`\u81F3\u5C11\u8981\u9009${check_min_val}\u9879`);
39607
- }
39608
- else if (len > check_max_val) {
39609
- return new Error(`\u6700\u591A\u53EF\u9009${check_max_val}\u9879`);
39610
- }
39611
- }
39612
- return true;
39613
- }
39614
- catch (error) {
39615
- console.log(error, "------checkcandidate");
39616
- return true;
39617
- }
39618
- };
39619
- const handleGetRules = (item) => {
39620
- const initRules = [];
39621
- const { validate = {}, is_null } = item;
39622
- let { vali_obj } = validate;
39623
- if (item.is_show == 0 && item.useType != "intercept") {
39624
- return initRules;
39625
- }
39626
- if (item.lineBarCheck || item.is_hide_field) {
39627
- return [];
39628
- }
39629
- switch (item.html_type) {
39630
- case "INPUT":
39631
- case "TEXTAREA":
39632
- case "RICH_TEXT":
39633
- initRules.push({
39634
- required: item.is_null == 0,
39635
- message: `\u8BF7\u8F93\u5165${item.name}`,
39636
- trigger: "change"
39637
- });
39638
- if (vali_obj != "mobile") {
39639
- initRules.push({
39640
- validator: (rule, value) => checkLenght(rule, value, item),
39641
- trigger: "change"
39642
- });
39643
- }
39644
- if (["integer", "number"].includes(vali_obj)) {
39645
- const rule = getInputCheck(vali_obj);
39646
- rule && initRules.push(rule);
39647
- }
39648
- if (vali_obj == "id_card") {
39649
- initRules.push({
39650
- validator: (rule, value) => handlerSetIdCarInfoValidate(rule, value, item),
39651
- trigger: "change"
39652
- });
39653
- }
39654
- initRules.push({
39655
- validator: (rule, value) => checkinputBlank(rule, value, item),
39656
- trigger: "change"
39657
- });
39658
- break;
39659
- case "DIGITAL":
39660
- initRules.push({
39661
- validator: (rule, value) => checkDigital(rule, value, item)
39662
- });
39663
- break;
39664
- case "AGE_JSON":
39665
- initRules.push({
39666
- validator: (rule, value) => checkAgeJson(rule, value, item),
39667
- trigger: "change"
39668
- });
39669
- break;
39670
- case "AGE":
39671
- initRules.push({
39672
- validator: (rule, value) => checkAge(rule, value, item),
39673
- trigger: "change"
39674
- }, {
39675
- required: item.is_null == 0,
39676
- message: `\u8BF7\u8F93\u5165${item.name}`
39677
- });
39678
- break;
39679
- case "UPPICTURE":
39680
- case "UPFILE":
39681
- case "VEDIO":
39682
- initRules.push({
39683
- validator: (rule, value) => handleUploadValidator(rule, value, item),
39684
- trigger: "change"
39685
- });
39686
- break;
39687
- case "CHECKBOX_BLOCK":
39688
- case "CHECKBOX":
39689
- case "SEARCH_MORE":
39690
- initRules.push({
39691
- required: item.is_null == 0,
39692
- message: `\u8BF7\u9009\u62E9${item.name}`,
39693
- trigger: "change"
39694
- }, {
39695
- validator: (rule, value) => checkMultipleChoice(rule, value, item),
39696
- trigger: "change"
39697
- });
39698
- break;
39699
- case "CANDIDATE_COMPONENTS":
39700
- initRules.push({
39701
- validator: (rule, value) => checkcandidate(rule, value, item),
39702
- trigger: "change"
39703
- });
39704
- break;
39705
- default:
39706
- initRules.push({
39707
- required: item.is_null == 0,
39708
- message: `\u8BF7\u9009\u62E9${item.name}`,
39709
- trigger: "change"
39710
- });
39711
- break;
39712
- }
39713
- if (validate && vali_obj == "mobile" && !validate.phone_idcard_type && is_null == 0) {
39714
- initRules.push({
39715
- pattern: /(^[0-9]{11,11}$)/,
39716
- message: "\u8BF7\u8F93\u5165\u6B63\u786E\u7684\u7535\u8BDD\u53F7\u7801",
39717
- trigger: "change"
38927
+ return /* @__PURE__ */ vueJsxCompat(CGrid, {
38928
+ ...config,
38929
+ onCellClick: (data) => onCellClick(data)
38930
+ }, {
38931
+ empty: () => /* @__PURE__ */ vueJsxCompat(NEmpty, {
38932
+ description: "\u65E0\u6570\u636E"
38933
+ })
39718
38934
  });
39719
- }
39720
- if (initRules.length) {
39721
- initRules[0].key = item.val_key;
39722
- }
39723
- return initRules;
39724
- };
39725
- return {
39726
- handleGetRules
39727
- };
39728
- };
38935
+ };
38936
+ const onCellClick = (data) => {
38937
+ emit("update:value", data.row?.[props.col.columnName]);
38938
+ state.show = false;
38939
+ };
38940
+ const getPagination = () => {
38941
+ const pagination = () => {
38942
+ return /* @__PURE__ */ vueJsxCompat(NPagination, {
38943
+ "v-model": [state.page, "page"],
38944
+ pageCount: state.pageCount,
38945
+ onUpdatePage: (page) => querySelectTableList()
38946
+ });
38947
+ };
38948
+ return /* @__PURE__ */ vueJsxCompat(NSpace, {
38949
+ justify: "space-between",
38950
+ align: "center",
38951
+ style: "margin-top: 5px"
38952
+ }, [`\u5171${state.pageCount}\u6761`, pagination()]);
38953
+ };
38954
+ return () => [
38955
+ /* @__PURE__ */ vueJsxCompat(NSelect, {
38956
+ class: "form-select-table",
38957
+ options: [],
38958
+ consistentMenuWidth: false,
38959
+ clearable: true,
38960
+ filterable: true,
38961
+ to: false,
38962
+ show: state.show,
38963
+ loading: state.loading,
38964
+ onFocus: selectTableFocus,
38965
+ onBlur: () => state.show = false,
38966
+ onSearch: selectTableSearch
38967
+ }, {
38968
+ action: () => state.loading ? /* @__PURE__ */ vueJsxCompat(NSpace, {
38969
+ justify: "center"
38970
+ }, /* @__PURE__ */ vueJsxCompat(NSpin, {
38971
+ class: "spin",
38972
+ size: "small"
38973
+ })) : [getSelectTableGrid(), state.pageCount ? getPagination() : null]
38974
+ })
38975
+ ];
38976
+ }
38977
+ });
39729
38978
 
39730
- const requireComponent = import.meta.globEager("./edit.*?.(vue|ts)$/");
39731
- let cmps = {};
39732
- Object.values(requireComponent).forEach((cmp) => {
39733
- cmps[cmp.name] = cmp;
39734
- });
39735
- console.log(cmps, "cmps");
39736
- var registerCom = {
39737
- data() {
39738
- return {};
38979
+ script$8.__scopeId = "data-v-464c5a9c";
38980
+ script$8.__file = "packages/big-table/src/components/edit-form/edit-select-table.vue";
38981
+
38982
+ var script$7 = defineComponent({
38983
+ name: "EditInput",
38984
+ inheritAttrs: false,
38985
+ components: {
38986
+ NInput
39739
38987
  },
39740
- computed: {},
39741
- methods: {},
39742
- components: cmps
39743
- };
38988
+ setup(props, { attrs, slots, emit }) {
38989
+ return () => [
38990
+ /* @__PURE__ */ vueJsxCompat(NInput, {
38991
+ ...attrs
38992
+ })
38993
+ ];
38994
+ }
38995
+ });
39744
38996
 
39745
- const _hoisted_1$5 = { class: "editForm-page" };
39746
- const __default__$6 = {
39747
- name: "EditForm",
39748
- mixins: [registerCom]
39749
- };
39750
- var script$6 = /* @__PURE__ */ defineComponent({
39751
- ...__default__$6,
38997
+ script$7.__file = "packages/big-table/src/components/edit-form/edit-input.vue";
38998
+
38999
+ var script$6 = defineComponent({
39000
+ name: "EditSelect",
39001
+ inheritAttrs: false,
39002
+ components: {
39003
+ NSelect
39004
+ },
39752
39005
  props: {
39753
- defaultForm: { type: null, required: true },
39754
- isPure: { type: Boolean, required: true },
39755
- cacheUniqueKey: { type: null, required: false, default: {} },
39756
- banRequest: { type: Boolean, required: false, default: false },
39757
- propsDelSetting: { type: Boolean, required: false, default: false },
39758
- propsFormBtn: { type: Boolean, required: false, default: false },
39759
- parentConfig: { type: null, required: false, default: {} },
39760
- configuration: { type: null, required: false, default: {} },
39761
- isOpenShortcut: { type: Boolean, required: false, default: true },
39762
- formPrimaryKey: { type: [Number, String], required: true },
39763
- styleSetting: { type: null, required: false }
39006
+ col: {
39007
+ type: Object,
39008
+ default: {}
39009
+ }
39764
39010
  },
39765
- emits: ["banSubmit", "handleSubmit"],
39766
- setup(__props, { expose, emit }) {
39767
- const props = __props;
39768
- window.$message = useMessage();
39011
+ setup(props, { attrs, slots, emit }) {
39769
39012
  const state = reactive({
39770
- defaultValue: {},
39771
- editForm: {
39772
- formFieldList: []
39773
- },
39774
- editRules: {},
39775
- formFieldList: [],
39776
- theUniqueKeyListObj: {},
39777
- formType: {},
39778
- defaultFieldList: [],
39779
- dbParams: {},
39780
- searchObj: {},
39781
- searchAddObj: {},
39782
- multipleSelected: {},
39783
- formFieldObj: {},
39784
- selectedDefValueObj: {},
39785
- fieldTypeList: []
39786
- });
39787
- const editForm = ref(null);
39788
- const userInfo = computed(() => {
39789
- const { userInfo: userInfo2 } = props.configuration || {};
39790
- return userInfo2 || {};
39013
+ options: JSON.parse(JSON.stringify(props.col.options || []))
39791
39014
  });
39792
- computed(() => !props.isPure);
39793
- const { RandomId, handleGetdef } = useFormCommon(props, state, userInfo.value);
39794
- const { handleGetRules } = useValidateRules();
39795
- provide("state", state);
39796
- provide("userInfo", userInfo);
39797
- const handleConvertData = (target) => {
39798
- let transmitParams = {};
39799
- let transmitKeys = Object.keys(target || {});
39800
- if (transmitKeys && transmitKeys.length) {
39801
- transmitKeys.forEach((v) => {
39802
- if (typeof target[v] == "object") {
39803
- transmitParams[v] = JSON.stringify(target[v]);
39804
- }
39805
- else {
39806
- transmitParams[v] = target[v];
39807
- }
39808
- if (xeUtils.isString(target[v])) {
39809
- if (target[v] && target[v].includes("###{")) {
39810
- let temp = JSON.parse(target[v].replace("###", ""));
39811
- transmitParams[v] = temp.value;
39812
- }
39813
- }
39814
- });
39815
- }
39816
- return transmitParams;
39817
- };
39818
- const handleGetformType = (list) => {
39819
- state.theUniqueKeyListObj = {};
39820
- let myformType = {};
39821
- let mySearchObj = {};
39822
- let searchAddObj = {};
39823
- state.formType = null;
39824
- let fieldObj = /* @__PURE__ */ Object.create(null);
39825
- let defaList = Object.keys(state.defaultValue);
39826
- list?.forEach((item) => {
39827
- myformType[item.val_key] = item;
39828
- let curKey = `${item.val_key}_${item.name}`;
39829
- item.wordbook && (item?.wordbook?.type || "") != "WORDBOOK";
39830
- item.selectOptions = [];
39831
- item.popoverVisible = false;
39832
- item.otherval = "";
39833
- item.otherFlag = false;
39834
- if (item.html_type == "SEARCH") {
39835
- mySearchObj[curKey] = [];
39836
- searchAddObj[curKey] = false;
39837
- if (defaList.includes(item.name)) {
39838
- mySearchObj[curKey] = [
39839
- {
39840
- [item.wordbook.value_key]: state.defaultValue[item.name]
39841
- }
39842
- ];
39843
- }
39844
- }
39845
- else if (item.html_type == "SEARCH_MORE") {
39846
- mySearchObj[curKey] = [];
39847
- searchAddObj[curKey] = false;
39848
- if (!state.multipleSelected[curKey]) {
39849
- state.multipleSelected[curKey] = [];
39850
- }
39851
- }
39852
- else {
39853
- state.defaultValue[item.name] || item.default_val;
39854
- }
39855
- if (item.val_key) {
39856
- fieldObj[item.val_key] = {
39857
- ...item
39858
- };
39859
- }
39860
- });
39861
- state.formType = myformType;
39862
- state.searchObj = mySearchObj;
39863
- state.searchAddObj = searchAddObj;
39864
- state.formFieldObj = fieldObj;
39865
- };
39866
- const getSelecteddefValueObj = () => {
39867
- let obj = {
39868
- multipleSelected: {
39869
- ...state.multipleSelected
39870
- }
39871
- };
39872
- state.selectedDefValueObj = obj;
39873
- };
39874
- const hanlderInitFieldList = (fieldList = []) => {
39875
- if (!fieldList.length)
39876
- return;
39877
- handleGetformType(fieldList);
39878
- getSelecteddefValueObj();
39879
- let fieldTypeList = [];
39880
- for (let index = 0; index < fieldList.length; index++) {
39881
- const element = fieldList[index];
39882
- element.isPure = props.isPure;
39883
- let randomId = RandomId();
39884
- let com_name = configData.getComName(element);
39885
- element["com_name"] = com_name;
39886
- element["RandomId"] = randomId;
39887
- let useFormValue = handleGetdef(element);
39888
- element["useFormValue"] = useFormValue;
39889
- element["isVisible"] = false;
39890
- let mid_is_edit = [0, 1, "0", "1"].includes(element.mid_is_edit) ? element.mid_is_edit : element.is_edit;
39891
- element.is_edit = mid_is_edit;
39892
- if (element.html_type.includes("CHECKBOX")) {
39893
- element["indeterminate"] = false;
39894
- element["checkAll"] = false;
39895
- }
39896
- if (element.html_type.includes("CHECKBOX") || element.html_type.includes("RADIO")) {
39897
- let imgFlag = element?.option?.some((v) => v.imageBase64);
39898
- element.is_contain_images = imgFlag ? 1 : 0;
39899
- }
39900
- fieldTypeList.push({
39901
- columnName: element.val_key,
39902
- fieldType: "TEXT"
39903
- });
39904
- element["isShowComponent"] = true;
39905
- }
39906
- state.defaultFieldList = fieldList;
39907
- state.fieldTypeList = fieldTypeList;
39908
- state.editForm.formFieldList = fieldList;
39909
- };
39910
- const initForm = (m = {}) => {
39911
- let { defaultCombinationForm = {}, fieldList = [] } = m;
39912
- let tempForm = {};
39913
- if (Object.keys(defaultCombinationForm).length) {
39914
- tempForm = { ...defaultCombinationForm };
39915
- }
39916
- let transmitParams = handleConvertData(tempForm);
39917
- state.defaultValue = { ...transmitParams };
39918
- hanlderInitFieldList(fieldList);
39919
- };
39920
- const getValueChange = (v, i) => {
39921
- let cacheKey = `${i.val_key}_${i.name}`;
39922
- if (i.html_type == "SEARCH_MORE") {
39923
- state.multipleSelected[cacheKey] = [...v];
39924
- }
39925
- getSelecteddefValueObj();
39926
- };
39927
- const getObjs = (str) => {
39928
- let resObj = null;
39929
- if (xeUtils.isJSON(str)) {
39930
- resObj = JSON.parse(str);
39931
- if (resObj.type === "jsonb") {
39932
- resObj = resObj.value;
39933
- if (resObj.includes("jsonb")) {
39934
- resObj = getObjs(resObj);
39935
- }
39936
- return resObj;
39937
- }
39938
- else {
39939
- return str;
39940
- }
39941
- }
39942
- else {
39943
- return str;
39944
- }
39945
- };
39946
- const handleGetSearMoreSubmit = (item, formdata) => {
39947
- const { formType, multipleSelected } = state;
39948
- const curItem = formType[item];
39949
- const defaultVal = JSON.stringify({ objs: [], objStr: "" });
39950
- let valueList = [];
39951
- let showList = [];
39952
- let keyName = `${curItem.val_key}_${curItem.name}`;
39953
- if (!curItem.wordbook)
39954
- return defaultVal;
39955
- let value_key = curItem.wordbook.value_key;
39956
- let render_key = curItem.wordbook.render_key || [];
39957
- let defVal = state.defaultValue[curItem.name] || curItem.default_val;
39958
- if (curItem.isOnchange !== "00" && defVal) {
39959
- defVal = curItem.filtration_val || handleSysParams(defVal, { defaultValue: state.defaultValue, userInfo: userInfo.value, dbParams: state.dbParams });
39960
- defVal = getObjs(defVal);
39961
- return defVal || defaultVal;
39962
- }
39963
- const targetList = JSON.parse(JSON.stringify(multipleSelected[keyName] || []));
39964
- if (Array.isArray(formdata[item]) && formdata[item].length) {
39965
- formdata[item].forEach((ele) => {
39966
- targetList.forEach((v) => {
39967
- let [curValue_key] = typeof ele.key === "string" ? ele.key.split("-") : [""];
39968
- if (`${v[value_key]}-${v["myUniqueKey"]}` == ele.key || curValue_key == v[value_key]) {
39969
- delete v.setting;
39970
- delete v.showLabel;
39971
- if (v["myUniqueKey"] && v.myUniqueLabel) {
39972
- var item2 = {
39973
- [v.myUniqueLabel]: v["myUniqueKey"],
39974
- [value_key]: v[value_key]
39975
- };
39976
- render_key.forEach((k) => {
39977
- item2[k] = v[k];
39978
- });
39979
- valueList.push(item2);
39980
- }
39981
- else {
39982
- let { myUniqueKey, myUniqueLabel, ...rest } = v;
39983
- valueList.push(rest);
39984
- }
39985
- showList.push(v[value_key]);
39986
- }
39987
- });
39988
- });
39989
- }
39990
- return JSON.stringify({
39991
- objs: valueList,
39992
- objStr: showList.join(",")
39993
- });
39994
- };
39995
- const handleFormatSubmit = (copy) => {
39996
- let formdata = xeUtils.clone(copy, true);
39997
- Object.keys(formdata).forEach((item) => {
39998
- switch (state.formType[item]?.html_type) {
39999
- case "INPUT":
40000
- case "TEXTAREA":
40001
- if (state.formType[item]?.delete_before_after_spaces == 1) {
40002
- formdata[item] = xeUtils.handleClearStrBlank(formdata[item]);
40003
- }
40004
- break;
40005
- case "DIGITAL":
40006
- case "SELECT":
40007
- case "RADIO":
40008
- case "RADIO_BLOCK":
40009
- break;
40010
- case "SEARCH":
40011
- formdata[item] = typeof formdata[item] === "string" ? formdata[item].split(">>>")[0] : formdata[item] && formdata[item].label && formdata[item].label.trim();
40012
- break;
40013
- case "SEARCH_MORE":
40014
- formdata[item] = handleGetSearMoreSubmit(item, formdata);
40015
- break;
40016
- case "CHECKBOX":
40017
- case "CHECKBOX_BLOCK":
40018
- formdata[item] = Array.isArray(formdata[item]) ? formdata[item].join(",") : formdata[item];
40019
- break;
40020
- case "DATETIME-INPUT":
40021
- case "DATE-INPUT":
40022
- case "TIME-INPUT":
40023
- case "DATE":
40024
- if (typeof formdata[item] == "string") {
40025
- formdata[item] = formdata[item] || null;
40026
- }
40027
- else {
40028
- formdata[item] = formdata[item] ? formdata[item].format(handlerGetDateType(state.formType[item])) : null;
40029
- }
40030
- break;
40031
- }
40032
- });
40033
- return formdata;
40034
- };
40035
- const handleSubmitForm = () => {
40036
- editForm.value?.validate((errors) => {
40037
- if (errors) {
40038
- emit("banSubmit", {
40039
- rowKey: props.formPrimaryKey
40040
- });
40041
- let message = errors[0].message || "";
40042
- message && window.$message.error(message);
40043
- }
40044
- else {
40045
- let submData = {};
40046
- state.editForm.formFieldList.forEach((item) => {
40047
- submData[item.val_key] = item.useFormValue;
40048
- });
40049
- submData = handleFormatSubmit(submData);
40050
- if (submData) {
40051
- submData = JSON.parse(JSON.stringify(submData));
40052
- }
40053
- let formObj = {
40054
- rowKey: props.formPrimaryKey,
40055
- formData: submData
40056
- };
40057
- emit("handleSubmit", formObj);
40058
- }
40059
- });
40060
- };
40061
- watch(() => props.defaultForm, (val) => {
40062
- if (!val || !Object.keys(val).length)
40063
- return;
40064
- let tempVal = JSON.parse(JSON.stringify(val));
40065
- initForm(tempVal);
40066
- }, { deep: true, immediate: true });
40067
- expose({
40068
- handleSubmitForm
40069
- });
40070
- return (_ctx, _cache) => {
40071
- return openBlock(), createElementBlock("div", _hoisted_1$5, [
40072
- createVNode(unref(NForm), {
40073
- ref_key: "editForm",
40074
- ref: editForm,
40075
- model: unref(state).editForm,
40076
- rules: unref(state).editRules
40077
- }, {
40078
- default: withCtx(() => [
40079
- (openBlock(true), createElementBlock(Fragment, null, renderList(unref(state).editForm.formFieldList, (item, index) => {
40080
- return openBlock(), createBlock(unref(NFormItem), {
40081
- key: index,
40082
- label: "",
40083
- path: `formFieldList.${index}.useFormValue`,
40084
- rule: unref(handleGetRules)(item),
40085
- class: normalizeClass("editeForm-item-" + item.html_type)
40086
- }, {
40087
- default: withCtx(() => [
40088
- item.isShowComponent ? (openBlock(), createBlock(resolveDynamicComponent(item.com_name), mergeProps({
40089
- key: 0,
40090
- key: item.RandomId,
40091
- class: item.html_type,
40092
- ref_for: true,
40093
- ref: item.html_type + item.val_key,
40094
- item,
40095
- defaultValue: unref(state).defaultValue
40096
- }, _ctx.$attrs, {
40097
- form: editForm.value,
40098
- onValueOnChange: getValueChange
40099
- }), null, 16, ["class", "item", "defaultValue", "form"])) : createCommentVNode("v-if", true)
40100
- ]),
40101
- _: 2
40102
- }, 1032, ["path", "rule", "class"]);
40103
- }), 128))
40104
- ]),
40105
- _: 1
40106
- }, 8, ["model", "rules"])
40107
- ]);
40108
- };
39015
+ return () => [
39016
+ /* @__PURE__ */ vueJsxCompat(NSelect, {
39017
+ ...attrs,
39018
+ options: state.options,
39019
+ consistentMenuWidth: false,
39020
+ clearable: true,
39021
+ filterable: true,
39022
+ to: false,
39023
+ placeholder: "\u8BF7\u9009\u62E9"
39024
+ })
39025
+ ];
40109
39026
  }
40110
39027
  });
40111
39028
 
40112
- script$6.__scopeId = "data-v-0e238fc2";
40113
- script$6.__file = "packages/big-table/src/components/edit-form/EditForm.vue";
39029
+ script$6.__file = "packages/big-table/src/components/edit-form/edit-select.vue";
40114
39030
 
40115
39031
  var img$2 = "";
40116
39032
 
@@ -40538,14 +39454,6 @@ const getRowStyle = ({ row }) => {
40538
39454
  }
40539
39455
  return null;
40540
39456
  };
40541
- const handleTableHeight = (state, props) => {
40542
- if (!props.isNestTable)
40543
- return props.height;
40544
- let tableHeight = props.styleSetting?.tableHeight || "table-simple";
40545
- let dataLen = props.data?.length || 1;
40546
- let height = state.checkWidth[tableHeight] * dataLen + 90;
40547
- return `${height}px`;
40548
- };
40549
39457
  const handleName = (item, key = "name") => {
40550
39458
  return item.alias || item[key];
40551
39459
  };
@@ -40854,7 +39762,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
40854
39762
  };
40855
39763
  onMounted(() => {
40856
39764
  bindDocumentClick();
40857
- state.tableHeight = handleTableHeight(state, props);
39765
+ state.tableHeight = "520px";
40858
39766
  if (!props.isNestTable)
40859
39767
  return;
40860
39768
  loadColumn(props.columnConfig);
@@ -40887,7 +39795,6 @@ var script$5 = /* @__PURE__ */ defineComponent({
40887
39795
  setTableConfig(config, state);
40888
39796
  let columns = formatColumns(config);
40889
39797
  columns = handleGroupColums(columns, props);
40890
- console.log("columns--------------", columns);
40891
39798
  xGrid.value && xGrid.value.reloadColumn(columns);
40892
39799
  setGroupTreeExpand();
40893
39800
  resetTableInlineEditStatus();
@@ -40895,7 +39802,6 @@ var script$5 = /* @__PURE__ */ defineComponent({
40895
39802
  const loadData = async (data) => {
40896
39803
  state.isShowEmpty = !data?.length;
40897
39804
  const list = JSON.parse(JSON.stringify(data));
40898
- console.log("list--------------", list);
40899
39805
  let table = xGrid.value;
40900
39806
  if (!table)
40901
39807
  return;
@@ -40907,6 +39813,13 @@ var script$5 = /* @__PURE__ */ defineComponent({
40907
39813
  if (!props.isNestTable) {
40908
39814
  await handleFormTheUniqueKey();
40909
39815
  }
39816
+ formatList = formatList.map((v) => {
39817
+ return {
39818
+ ...v,
39819
+ selectTableShow: false,
39820
+ selectTableDisable: false
39821
+ };
39822
+ });
40910
39823
  console.log("table--------------", formatList);
40911
39824
  await table.loadData(formatList);
40912
39825
  table.setCurrentRow({});
@@ -40948,7 +39861,13 @@ var script$5 = /* @__PURE__ */ defineComponent({
40948
39861
  };
40949
39862
  const formatColumns = (map) => {
40950
39863
  let { selectType } = getOtherConfigInit() || {};
40951
- let { isBatchSelect, fieldList, showButtonTop, isScanMultiTable: isScanMultiTable2 } = map;
39864
+ let { isBatchSelect, fieldList, showButtonTop, isScanMultiTable: isScanMultiTable2, isEdit = false, editConfig = {} } = map;
39865
+ if (isEdit) {
39866
+ state.editConfig = Object.assign(state.editConfig, editConfig, {
39867
+ mode: "cell",
39868
+ autoClear: true
39869
+ });
39870
+ }
40952
39871
  if (selectType) {
40953
39872
  isBatchSelect = 1;
40954
39873
  }
@@ -40960,17 +39879,28 @@ var script$5 = /* @__PURE__ */ defineComponent({
40960
39879
  state.selectType = selectType;
40961
39880
  let tableHeight = props.styleSetting?.tableHeight || "table-simple";
40962
39881
  let checkMinWidth = state.checkWidth[tableHeight] || "30";
39882
+ const checkboxSlot = {
39883
+ default: (data) => {
39884
+ return checkMethod(data) ? null : /* @__PURE__ */ vueJsxCompat(NTooltip, {
39885
+ placement: "right",
39886
+ trigger: "hover"
39887
+ }, {
39888
+ default: () => data.row.forbiddenBatchSelectReason,
39889
+ trigger: () => /* @__PURE__ */ vueJsxCompat("i", {
39890
+ class: "disabled-checked-tips"
39891
+ })
39892
+ });
39893
+ }
39894
+ };
40963
39895
  let checkVisible = isBatchSelect == 1 && !props.isNestTable && !isScanMultiTable2 || false;
40964
39896
  let columns = [
40965
39897
  {
40966
39898
  fixed: "left",
40967
39899
  align: "center",
40968
39900
  visible: isScanMultiTable2 || false,
40969
- width: "50",
39901
+ width: "60",
40970
39902
  slots: {
40971
- header: () => {
40972
- return "\u64CD\u4F5C";
40973
- },
39903
+ header: () => "\u64CD\u4F5C",
40974
39904
  default: scanMultiOperate
40975
39905
  }
40976
39906
  },
@@ -41001,9 +39931,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
41001
39931
  visible: checkVisible,
41002
39932
  resizable: false,
41003
39933
  width: checkMinWidth,
41004
- slots: selectType === "checkbox" ? {
41005
- checkbox: "tooltip_checkbox"
41006
- } : null,
39934
+ slots: selectType === "checkbox" ? checkboxSlot : null,
41007
39935
  showOverflow: true
41008
39936
  }
41009
39937
  ];
@@ -41031,12 +39959,12 @@ var script$5 = /* @__PURE__ */ defineComponent({
41031
39959
  showOverflow: "title",
41032
39960
  treeNode,
41033
39961
  type,
41034
- slots: {
41035
- default: (params) => {
41036
- return formatter(params, item);
41037
- }
39962
+ slots: isEdit ? {
39963
+ edit: (params) => formatterEdit(params, item)
39964
+ } : {
39965
+ default: (params) => formatter(params, item)
41038
39966
  },
41039
- editRender: generateEditRender(item)
39967
+ editRender: isEdit ? {} : generateEditRender(item)
41040
39968
  });
41041
39969
  if (filterField && !props.isNestTable && !isScanMultiTable2) {
41042
39970
  state.filterFields[item.columnName] = Object.assign({}, xeUtils.clone(item, true), {
@@ -41069,6 +39997,34 @@ var script$5 = /* @__PURE__ */ defineComponent({
41069
39997
  state.columnLen = currentColumns.filter((item) => item.visible).length;
41070
39998
  return columns;
41071
39999
  };
40000
+ const formatterEdit = (params, col) => {
40001
+ let { row, column, $rowIndex, rowIndex } = params;
40002
+ let formType = column.formType || col.formType;
40003
+ if (formType === "selectTable") {
40004
+ const propsData = {
40005
+ row,
40006
+ col
40007
+ };
40008
+ return /* @__PURE__ */ vueJsxCompat(script$8, {
40009
+ ...propsData,
40010
+ "v-model": [row[col.columnName], "value"]
40011
+ });
40012
+ }
40013
+ if (formType === "input") {
40014
+ return /* @__PURE__ */ vueJsxCompat(script$7, {
40015
+ "v-model": [row[col.columnName], "value"]
40016
+ });
40017
+ }
40018
+ if (formType === "select") {
40019
+ const propsData = {
40020
+ col
40021
+ };
40022
+ return /* @__PURE__ */ vueJsxCompat(script$6, {
40023
+ ...propsData,
40024
+ "v-model": [row[col.columnName], "value"]
40025
+ });
40026
+ }
40027
+ };
41072
40028
  const formatter = (params, col) => {
41073
40029
  let { row, column, $rowIndex } = params;
41074
40030
  let own = column?._own || column?.own || col;
@@ -41078,14 +40034,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
41078
40034
  let dynamicProps = initBatchDynamicProps(formUnionItem, row, column, $rowIndex);
41079
40035
  if (dynamicProps) {
41080
40036
  emit("setWaitEditKeys", column.property);
41081
- return [
41082
- /* @__PURE__ */ vueJsxCompat(script$6, {
41083
- class: `js-inlineEditForm`,
41084
- key: row[props.primaryKey] + $rowIndex + column.property,
41085
- "data-key": row[props.primaryKey] + $rowIndex + column.property,
41086
- ...dynamicProps
41087
- })
41088
- ];
40037
+ return null;
41089
40038
  }
41090
40039
  }
41091
40040
  if (xeUtils.has(row, GROUP_TITLE_KEY)) {
@@ -41398,14 +40347,14 @@ var script$5 = /* @__PURE__ */ defineComponent({
41398
40347
  isAlias = !!tooltipTitle;
41399
40348
  }
41400
40349
  if (type === "format")
41401
- return /* @__PURE__ */ vueJsxCompat(script$8, {
40350
+ return /* @__PURE__ */ vueJsxCompat(script$a, {
41402
40351
  tooltipTitle,
41403
40352
  content: name,
41404
40353
  isAlias
41405
40354
  });
41406
40355
  return () => {
41407
40356
  return [
41408
- /* @__PURE__ */ vueJsxCompat(script$8, {
40357
+ /* @__PURE__ */ vueJsxCompat(script$a, {
41409
40358
  tooltipTitle,
41410
40359
  content: name,
41411
40360
  isAlias
@@ -41686,8 +40635,12 @@ var script$5 = /* @__PURE__ */ defineComponent({
41686
40635
  }
41687
40636
  updateAddCheckedRows(row);
41688
40637
  };
40638
+ const getFormType = (field) => {
40639
+ const obj = props.columnConfig.fieldList.find((v) => v.columnName === field);
40640
+ return obj ? obj.formType || "" : "";
40641
+ };
41689
40642
  const handlerClickRow = (data) => {
41690
- console.log("data");
40643
+ console.log("data.", data);
41691
40644
  if (isScanMultiTable.value || props.isInlineOperating)
41692
40645
  return false;
41693
40646
  if (xeUtils.has(data?.row, GROUP_TITLE_KEY))
@@ -41695,6 +40648,11 @@ var script$5 = /* @__PURE__ */ defineComponent({
41695
40648
  if (state.isTriggerSelectionChange && state.isTree == 0)
41696
40649
  return false;
41697
40650
  let table = xGrid.value;
40651
+ const formType = getFormType(data.column.field);
40652
+ console.log("formType---", formType);
40653
+ if (formType === "selectTable") {
40654
+ table.setActiveCell(data.row, data.column.field);
40655
+ }
41698
40656
  isAboutNestTable.value && emit("resetNestLastClickTable", table);
41699
40657
  let { row, $event = {}, $rowIndex } = data;
41700
40658
  let { className } = $event.target || {};
@@ -41928,7 +40886,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
41928
40886
  return /* @__PURE__ */ vueJsxCompat(NPopconfirm, {
41929
40887
  onPositiveClick: () => confirmScanMulti(params)
41930
40888
  }, {
41931
- trigger: () => /* @__PURE__ */ vueJsxCompat(script$7, {
40889
+ trigger: () => /* @__PURE__ */ vueJsxCompat(script$9, {
41932
40890
  class: "scan-multi-delete",
41933
40891
  iconClass: "shanchu"
41934
40892
  }),
@@ -42145,7 +41103,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42145
41103
  }, /* @__PURE__ */ vueJsxCompat("img", {
42146
41104
  class: "bigTable-qr-img",
42147
41105
  src
42148
- }), /* @__PURE__ */ vueJsxCompat("span", null, /* @__PURE__ */ vueJsxCompat(script$7, {
41106
+ }), /* @__PURE__ */ vueJsxCompat("span", null, /* @__PURE__ */ vueJsxCompat(script$9, {
42149
41107
  iconClass: "fangda"
42150
41108
  })))
42151
41109
  ];
@@ -42174,7 +41132,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42174
41132
  class: "btn-custom-class row-btn",
42175
41133
  size: "small",
42176
41134
  text: true
42177
- }, "\u4FDD\u5B58"), /* @__PURE__ */ vueJsxCompat(NButton, {
41135
+ }, { default: () => "\u4FDD\u5B58" }), /* @__PURE__ */ vueJsxCompat(NButton, {
42178
41136
  style: { display: row.__isInlineEditing ? "inline-block" : "none" },
42179
41137
  onClick: (e) => {
42180
41138
  e.stopPropagation();
@@ -42183,7 +41141,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42183
41141
  class: "btn-custom-class row-btn",
42184
41142
  size: "small",
42185
41143
  text: true
42186
- }, "\u53D6\u6D88"))
41144
+ }, { default: () => "\u53D6\u6D88" }))
42187
41145
  ];
42188
41146
  };
42189
41147
  const getTileBtnList = (row, index) => {
@@ -42202,7 +41160,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42202
41160
  disabled: row.__isDisableInlineEdit,
42203
41161
  ghost: btn.showStyle == "white_bg",
42204
41162
  size: "small"
42205
- }, getBtnIcon(btn), btn.showStyle === "only_icon" ? "" : handleName(btn));
41163
+ }, { default: () => [getBtnIcon(btn), btn.showStyle === "only_icon" ? "" : handleName(btn)] });
42206
41164
  }) || ""
42207
41165
  ];
42208
41166
  };
@@ -42224,7 +41182,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42224
41182
  }
42225
41183
  else {
42226
41184
  icon = /* @__PURE__ */ vueJsxCompat(NTooltip, null, {
42227
- trigger: () => /* @__PURE__ */ vueJsxCompat(script$7, {
41185
+ trigger: () => /* @__PURE__ */ vueJsxCompat(script$9, {
42228
41186
  iconClass: btn.icon,
42229
41187
  style: { marginRight: mr }
42230
41188
  }),
@@ -42233,7 +41191,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42233
41191
  }
42234
41192
  }
42235
41193
  else if (btn.iconSetting) {
42236
- icon = /* @__PURE__ */ vueJsxCompat(script$7, {
41194
+ icon = /* @__PURE__ */ vueJsxCompat(script$9, {
42237
41195
  iconClass: JSON.parse(btn.iconSetting).icon,
42238
41196
  style: {
42239
41197
  marginRight: mr
@@ -42264,7 +41222,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42264
41222
  }, /* @__PURE__ */ vueJsxCompat(NButton, {
42265
41223
  size: "small",
42266
41224
  style: "margin-left: 8px"
42267
- }, "\u66F4\u591A ...")) || ""
41225
+ }, { default: () => "\u66F4\u591A ..." })) || ""
42268
41226
  ];
42269
41227
  };
42270
41228
  const switchBtnOnChange = (e, r, i, index) => {
@@ -42591,7 +41549,8 @@ var script$5 = /* @__PURE__ */ defineComponent({
42591
41549
  clearChecked,
42592
41550
  setCurrentRow,
42593
41551
  loadColumn,
42594
- removeInsert
41552
+ removeInsert,
41553
+ xGrid
42595
41554
  });
42596
41555
  return (_ctx, _cache) => {
42597
41556
  return openBlock(), createElementBlock("div", {
@@ -42688,7 +41647,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42688
41647
  "scroll-x": { enabled: false },
42689
41648
  "scroll-y": { gt: 50 },
42690
41649
  "row-style": unref(getRowStyle),
42691
- "edit-config": { trigger: "manual", mode: "row", autoClear: false, showIcon: false },
41650
+ "edit-config": unref(state).editConfig,
42692
41651
  "expand-config": {
42693
41652
  lazy: true,
42694
41653
  accordion: _ctx.columnConfig && _ctx.columnConfig.accordion,
@@ -42708,7 +41667,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42708
41667
  }, {
42709
41668
  empty: withCtx(() => [
42710
41669
  unref(state).isShowEmpty ? (openBlock(), createElementBlock("div", _hoisted_9$3, [
42711
- createVNode(script$9, {
41670
+ createVNode(script$b, {
42712
41671
  "no-data-img": props.emptyItems.noDataImg,
42713
41672
  "no-data-tip": props.emptyItems.noDataTip,
42714
41673
  "show-img": !props.isNestTable
@@ -42760,7 +41719,7 @@ var script$5 = /* @__PURE__ */ defineComponent({
42760
41719
  })
42761
41720
  ]),
42762
41721
  _: 3
42763
- }, 8, ["seq-config", "tree-config", "row-id", "show-footer", "checkbox-config", "row-style", "expand-config"]),
41722
+ }, 8, ["seq-config", "tree-config", "row-id", "show-footer", "checkbox-config", "row-style", "edit-config", "expand-config"]),
42764
41723
  createCommentVNode(" `${refreshRow}\u6761\u66F4\u65B0` "),
42765
41724
  withDirectives(createElementVNode("div", {
42766
41725
  class: "refresh",