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.
- package/es/big-table/index.css +3 -3
- package/es/big-table/index.js +299 -1340
- package/es/button-print/index.css +3 -3
- package/es/drag-layout/index.css +3 -3
- package/es/grid/index.css +3 -3
- package/es/index.css +3 -3
- package/es/index.js +280 -1321
- package/package.json +2 -1
- package/packages/big-table/src/BigTable.vue +102 -42
- package/packages/big-table/src/assets/style/table-base.less +6 -0
- package/packages/big-table/src/assets/style/table-global.less +9 -1
- package/packages/big-table/src/bigTableProps.ts +5 -0
- package/packages/big-table/src/bigTableState.ts +1 -0
- package/packages/big-table/src/components/edit-form/edit-input.vue +19 -0
- package/packages/big-table/src/components/edit-form/edit-select-table.vue +127 -0
- package/packages/big-table/src/components/edit-form/edit-select.vue +36 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/EditForm.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-date-picker/edit-date-picker.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-digital/edit-digital.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-input/edit-input.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-input-password/edit-input-password.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-month-picker/edit-month-picker.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-search/edit-search.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-search-more/edit-search-more.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-select/edit-select.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-select-multiple/edit-select-multiple.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-textarea/edit-textarea.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/edit-time-picker/edit-time-picker.vue +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/edit-component/editFormProps.ts +0 -0
- package/packages/big-table/src/components/edit-form3/edit-component/register-com.ts +18 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useConfigData.ts +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useDateType.ts +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useFormCommon.ts +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useItemDefault.ts +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useSearch.ts +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/hooks/useValidateRules.ts +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/interface.ts +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/types.ts +0 -0
- package/packages/big-table/src/components/{edit-form → edit-form3}/utils.ts +0 -0
- package/packages/big-table/src/components/edit-form/edit-component/register-com.ts +0 -18
package/es/big-table/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { inject, computed, watch, defineComponent, openBlock, createElementBlock, unref, createCommentVNode, createElementVNode, toDisplayString, ref, createVNode, withCtx, normalizeClass, renderSlot, createTextVNode, mergeProps,
|
|
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,
|
|
4
|
-
import { NTooltip,
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
13564
|
-
script$
|
|
13568
|
+
script$6.__scopeId = "data-v-4a4b0812";
|
|
13569
|
+
script$6.__file = "packages/big-table/src/components/NoData.vue";
|
|
13565
13570
|
|
|
13566
|
-
const _hoisted_1$
|
|
13567
|
-
const __default__$
|
|
13571
|
+
const _hoisted_1$2 = { class: "text-over-tooltip-components" };
|
|
13572
|
+
const __default__$2 = {
|
|
13568
13573
|
name: "TextOverTooltip"
|
|
13569
13574
|
};
|
|
13570
|
-
var script$
|
|
13571
|
-
...__default__$
|
|
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$
|
|
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$
|
|
13639
|
-
script$
|
|
13643
|
+
script$5.__scopeId = "data-v-6633a934";
|
|
13644
|
+
script$5.__file = "packages/big-table/src/components/TextOverTooltip.vue";
|
|
13640
13645
|
|
|
13641
|
-
const _hoisted_1$
|
|
13646
|
+
const _hoisted_1$1 = { key: 0 };
|
|
13642
13647
|
const _hoisted_2$1 = ["xlink:href"];
|
|
13643
|
-
const __default__$
|
|
13648
|
+
const __default__$1 = {
|
|
13644
13649
|
name: "SvgIcon"
|
|
13645
13650
|
};
|
|
13646
|
-
var script$
|
|
13647
|
-
...__default__$
|
|
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$
|
|
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$
|
|
13677
|
-
script$
|
|
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 =
|
|
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: "
|
|
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
|
-
|
|
41035
|
-
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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":
|
|
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$
|
|
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",
|