cnhis-design-vue 3.0.5 → 3.0.6
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/CHANGELOG.md +8 -0
- package/es/big-table/index.js +104 -39
- package/es/button-print/index.css +1 -1
- package/es/button-print/index.js +3 -2
- package/es/drag-layout/index.css +1 -1
- package/es/field-set/index.css +1 -1
- package/es/grid/index.css +16 -16
- package/es/index.js +107 -41
- package/package.json +1 -1
- package/packages/big-table/src/BigTable.vue +8 -12
- package/packages/big-table/src/bigTableEmits.ts +1 -2
- package/packages/big-table/src/components/edit-form/edit-date.vue +42 -0
- package/packages/big-table/src/components/edit-form/edit-input.vue +2 -2
- package/packages/big-table/src/components/edit-form/edit-select.vue +12 -3
- package/packages/big-table/src/hooks/useEdit.ts +3 -3
- package/packages/button-print/src/ButtonPrint.vue +2 -1
package/es/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { watch, h as h$1, resolveComponent, defineComponent, inject, computed, nextTick, reactive, createApp, ref, Teleport, createCommentVNode, provide, onMounted, onUnmounted, getCurrentInstance, onBeforeUnmount, onActivated, onDeactivated, createVNode, mergeProps, isVNode, openBlock, createElementBlock, unref, createElementVNode, toDisplayString, withCtx, normalizeClass, renderSlot, createTextVNode, useAttrs, normalizeStyle, withDirectives, vShow, Fragment, createBlock, vModelSelect, vModelText, pushScopeId, popScopeId, vModelCheckbox, withModifiers } from 'vue';
|
|
2
2
|
import { SettingsSharp, CaretDown, CaretForward, CopyOutline, SyncOutline, EllipsisVerticalSharp, Reload, ChevronDown } from '@vicons/ionicons5';
|
|
3
|
-
import { NTooltip, NInput, NInputNumber, NSelect, useMessage, NIcon, NPopconfirm, NButton, NInputGroup, NCheckbox, NCheckboxGroup, NSpace, NProgress, NDropdown, NSwitch, NPopover, NSpin,
|
|
3
|
+
import { NTooltip, NInput, NInputNumber, NSelect, NDatePicker, useMessage, NIcon, NPopconfirm, NButton, NInputGroup, NCheckbox, NCheckboxGroup, NSpace, NProgress, NDropdown, NSwitch, NPopover, NSpin, NRadio, NModal, NForm, NGrid, NFormItemGi, NFormItem } from 'naive-ui';
|
|
4
4
|
import draggable from 'vuedraggable';
|
|
5
5
|
|
|
6
6
|
var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
|
|
@@ -31033,7 +31033,7 @@ const bigTableEmits = [
|
|
|
31033
31033
|
"selectionChangeLocal",
|
|
31034
31034
|
"switchBtnOnChange",
|
|
31035
31035
|
"asyncTableChange",
|
|
31036
|
-
"
|
|
31036
|
+
"formChange"
|
|
31037
31037
|
];
|
|
31038
31038
|
|
|
31039
31039
|
var moment$1 = {exports: {}};
|
|
@@ -38467,8 +38467,8 @@ const useEdit = (props, state, emit, xGrid) => {
|
|
|
38467
38467
|
await xGrid.value.insertAt(record, getInsertRecords.at(-1));
|
|
38468
38468
|
xGrid.value.clearActived();
|
|
38469
38469
|
};
|
|
38470
|
-
const
|
|
38471
|
-
emit("
|
|
38470
|
+
const onFormChange = ({ value, row, column }) => {
|
|
38471
|
+
emit("formChange", { value, row, column });
|
|
38472
38472
|
};
|
|
38473
38473
|
const getDefaultValue = (params, item) => {
|
|
38474
38474
|
const value = params.row[item.columnName];
|
|
@@ -38488,7 +38488,7 @@ const useEdit = (props, state, emit, xGrid) => {
|
|
|
38488
38488
|
activeMethod,
|
|
38489
38489
|
deleteRow,
|
|
38490
38490
|
onClickSelectTable,
|
|
38491
|
-
|
|
38491
|
+
onFormChange,
|
|
38492
38492
|
getDefaultValue
|
|
38493
38493
|
};
|
|
38494
38494
|
};
|
|
@@ -38504,7 +38504,7 @@ var img$3 = "
|
|
|
38504
38504
|
const _hoisted_1$8 = { class: "no-data-tip NoData-page" };
|
|
38505
38505
|
const _hoisted_2$7 = ["src"];
|
|
38506
38506
|
const _hoisted_3$5 = { key: 1 };
|
|
38507
|
-
var script$
|
|
38507
|
+
var script$c = /* @__PURE__ */ defineComponent({
|
|
38508
38508
|
props: {
|
|
38509
38509
|
noDataTip: {
|
|
38510
38510
|
type: String,
|
|
@@ -38565,14 +38565,14 @@ var script$b = /* @__PURE__ */ defineComponent({
|
|
|
38565
38565
|
}
|
|
38566
38566
|
});
|
|
38567
38567
|
|
|
38568
|
-
script$
|
|
38569
|
-
script$
|
|
38568
|
+
script$c.__scopeId = "data-v-4a4b0812";
|
|
38569
|
+
script$c.__file = "packages/big-table/src/components/NoData.vue";
|
|
38570
38570
|
|
|
38571
38571
|
const _hoisted_1$7 = { class: "text-over-tooltip-components" };
|
|
38572
38572
|
const __default__$8 = {
|
|
38573
38573
|
name: "TextOverTooltip"
|
|
38574
38574
|
};
|
|
38575
|
-
var script$
|
|
38575
|
+
var script$b = /* @__PURE__ */ defineComponent({
|
|
38576
38576
|
...__default__$8,
|
|
38577
38577
|
props: {
|
|
38578
38578
|
content: { type: [String, Number], required: false },
|
|
@@ -38640,15 +38640,15 @@ var script$a = /* @__PURE__ */ defineComponent({
|
|
|
38640
38640
|
}
|
|
38641
38641
|
});
|
|
38642
38642
|
|
|
38643
|
-
script$
|
|
38644
|
-
script$
|
|
38643
|
+
script$b.__scopeId = "data-v-6633a934";
|
|
38644
|
+
script$b.__file = "packages/big-table/src/components/TextOverTooltip.vue";
|
|
38645
38645
|
|
|
38646
38646
|
const _hoisted_1$6 = { key: 0 };
|
|
38647
38647
|
const _hoisted_2$6 = ["xlink:href"];
|
|
38648
38648
|
const __default__$7 = {
|
|
38649
38649
|
name: "SvgIcon"
|
|
38650
38650
|
};
|
|
38651
|
-
var script$
|
|
38651
|
+
var script$a = /* @__PURE__ */ defineComponent({
|
|
38652
38652
|
...__default__$7,
|
|
38653
38653
|
props: {
|
|
38654
38654
|
iconClass: { type: String, required: true, default: "" },
|
|
@@ -38678,10 +38678,10 @@ var script$9 = /* @__PURE__ */ defineComponent({
|
|
|
38678
38678
|
}
|
|
38679
38679
|
});
|
|
38680
38680
|
|
|
38681
|
-
script$
|
|
38682
|
-
script$
|
|
38681
|
+
script$a.__scopeId = "data-v-d1ad5be8";
|
|
38682
|
+
script$a.__file = "src/component/svg/index.vue";
|
|
38683
38683
|
|
|
38684
|
-
var script$
|
|
38684
|
+
var script$9 = defineComponent({
|
|
38685
38685
|
name: "EditInput",
|
|
38686
38686
|
inheritAttrs: false,
|
|
38687
38687
|
components: {
|
|
@@ -38706,10 +38706,10 @@ var script$8 = defineComponent({
|
|
|
38706
38706
|
default: 0
|
|
38707
38707
|
}
|
|
38708
38708
|
},
|
|
38709
|
-
emits: ["
|
|
38709
|
+
emits: ["formChange"],
|
|
38710
38710
|
setup(props, { attrs, slots, emit }) {
|
|
38711
38711
|
const onUpdateValue = (value) => {
|
|
38712
|
-
emit("
|
|
38712
|
+
emit("formChange", {
|
|
38713
38713
|
value,
|
|
38714
38714
|
row: props.row,
|
|
38715
38715
|
column: props.col,
|
|
@@ -38724,9 +38724,9 @@ var script$8 = defineComponent({
|
|
|
38724
38724
|
}
|
|
38725
38725
|
});
|
|
38726
38726
|
|
|
38727
|
-
script$
|
|
38727
|
+
script$9.__file = "packages/big-table/src/components/edit-form/edit-input.vue";
|
|
38728
38728
|
|
|
38729
|
-
var script$
|
|
38729
|
+
var script$8 = defineComponent({
|
|
38730
38730
|
name: "EditSelect",
|
|
38731
38731
|
inheritAttrs: false,
|
|
38732
38732
|
components: {
|
|
@@ -38735,16 +38735,18 @@ var script$7 = defineComponent({
|
|
|
38735
38735
|
props: {
|
|
38736
38736
|
col: {
|
|
38737
38737
|
type: Object,
|
|
38738
|
-
default: () => {
|
|
38739
|
-
}
|
|
38738
|
+
default: () => ({})
|
|
38740
38739
|
},
|
|
38741
38740
|
row: {
|
|
38742
38741
|
type: Object,
|
|
38743
|
-
default: () => {
|
|
38744
|
-
|
|
38742
|
+
default: () => ({})
|
|
38743
|
+
},
|
|
38744
|
+
index: {
|
|
38745
|
+
type: [Number, Object],
|
|
38746
|
+
default: 0
|
|
38745
38747
|
}
|
|
38746
38748
|
},
|
|
38747
|
-
emits: ["setOptions"],
|
|
38749
|
+
emits: ["setOptions", "formChange"],
|
|
38748
38750
|
setup(props, { attrs, slots, emit }) {
|
|
38749
38751
|
const state = reactive({
|
|
38750
38752
|
options: []
|
|
@@ -38762,18 +38764,73 @@ var script$7 = defineComponent({
|
|
|
38762
38764
|
}
|
|
38763
38765
|
};
|
|
38764
38766
|
setOptions();
|
|
38767
|
+
const onUpdateValue = (value) => {
|
|
38768
|
+
emit("formChange", {
|
|
38769
|
+
value,
|
|
38770
|
+
row: props.row,
|
|
38771
|
+
column: props.col,
|
|
38772
|
+
index: props.index
|
|
38773
|
+
});
|
|
38774
|
+
};
|
|
38765
38775
|
return () => [createVNode(NSelect, mergeProps(attrs, {
|
|
38766
38776
|
"options": state.options,
|
|
38767
38777
|
"consistentMenuWidth": false,
|
|
38768
38778
|
"clearable": true,
|
|
38769
38779
|
"filterable": true,
|
|
38770
38780
|
"to": false,
|
|
38771
|
-
"placeholder": "\u8BF7\u9009\u62E9"
|
|
38781
|
+
"placeholder": "\u8BF7\u9009\u62E9",
|
|
38782
|
+
"onUpdateValue": onUpdateValue
|
|
38772
38783
|
}), null)];
|
|
38773
38784
|
}
|
|
38774
38785
|
});
|
|
38775
38786
|
|
|
38776
|
-
script$
|
|
38787
|
+
script$8.__file = "packages/big-table/src/components/edit-form/edit-select.vue";
|
|
38788
|
+
|
|
38789
|
+
var script$7 = defineComponent({
|
|
38790
|
+
name: "EditDate",
|
|
38791
|
+
inheritAttrs: false,
|
|
38792
|
+
components: {
|
|
38793
|
+
NDatePicker
|
|
38794
|
+
},
|
|
38795
|
+
props: {
|
|
38796
|
+
col: {
|
|
38797
|
+
type: Object,
|
|
38798
|
+
default: () => ({})
|
|
38799
|
+
},
|
|
38800
|
+
row: {
|
|
38801
|
+
type: Object,
|
|
38802
|
+
default: () => ({})
|
|
38803
|
+
},
|
|
38804
|
+
index: {
|
|
38805
|
+
type: [Number, Object],
|
|
38806
|
+
default: 0
|
|
38807
|
+
}
|
|
38808
|
+
},
|
|
38809
|
+
emits: ["formChange"],
|
|
38810
|
+
setup(props, { attrs, slots, emit }) {
|
|
38811
|
+
const onConfirm = (value, formattedValue) => {
|
|
38812
|
+
console.log("\u65F6\u95F4\u9009\u62E9->", value);
|
|
38813
|
+
emit("formChange", {
|
|
38814
|
+
value,
|
|
38815
|
+
row: props.row,
|
|
38816
|
+
column: props.col,
|
|
38817
|
+
index: props.index
|
|
38818
|
+
});
|
|
38819
|
+
};
|
|
38820
|
+
const config = {
|
|
38821
|
+
type: props.col.type || "datetime",
|
|
38822
|
+
clearable: props.col.clearable || true,
|
|
38823
|
+
disabled: props.col.disabled || false,
|
|
38824
|
+
valueFormat: props.col.valueFormat || "yyyy-MM-dd HH:mm:ss",
|
|
38825
|
+
to: false
|
|
38826
|
+
};
|
|
38827
|
+
return () => createVNode(NDatePicker, mergeProps(attrs, config, {
|
|
38828
|
+
"onConfirm": onConfirm
|
|
38829
|
+
}), null);
|
|
38830
|
+
}
|
|
38831
|
+
});
|
|
38832
|
+
|
|
38833
|
+
script$7.__file = "packages/big-table/src/components/edit-form/edit-date.vue";
|
|
38777
38834
|
|
|
38778
38835
|
var img$2 = "";
|
|
38779
38836
|
|
|
@@ -39451,7 +39508,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
|
|
|
39451
39508
|
const { formatData, htmlToText, getBtnStyle } = useFormat(state);
|
|
39452
39509
|
const { imgs2imgArr, parseDurationValue, parseCombinationValue, formatFieldText } = useTableParse(formatData);
|
|
39453
39510
|
const { allSelectedLength, checkOperateCurrentTable, setRowStatus, resetBatchOperationRowStatus, checkListFormUnionSettingParamsList, handleClickCancelBtnByInline, setAllRowInlineStatus, hideSelectCloumns, handleEditFormLength, resetOperationRowStatus, recordClickBtnInfo, getInlineOpreateRow } = useBatchEditing(props, state, emit, xGrid);
|
|
39454
|
-
const { initEditTable, activeMethod, deleteRow, onClickSelectTable,
|
|
39511
|
+
const { initEditTable, activeMethod, deleteRow, onClickSelectTable, onFormChange, getDefaultValue } = useEdit(props, state, emit, xGrid);
|
|
39455
39512
|
const { isAboutNestTable, isExpandTable, handleRowId, toggleExpandMethod, loadExpandMethod, nestHandleClickRow } = useNestTable(props, state, emit);
|
|
39456
39513
|
const attr = useAttrs();
|
|
39457
39514
|
const currentCheckedKeys = computed(() => {
|
|
@@ -39543,7 +39600,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
|
|
|
39543
39600
|
};
|
|
39544
39601
|
onMounted(() => {
|
|
39545
39602
|
bindDocumentClick();
|
|
39546
|
-
state.tableHeight = handleTableHeight(state, props);
|
|
39603
|
+
state.tableHeight = handleTableHeight(state, props) || "auto";
|
|
39547
39604
|
if (!props.isNestTable)
|
|
39548
39605
|
return;
|
|
39549
39606
|
loadColumn(props.columnConfig);
|
|
@@ -39794,18 +39851,26 @@ var script$6 = /* @__PURE__ */ defineComponent({
|
|
|
39794
39851
|
index: $rowIndex
|
|
39795
39852
|
};
|
|
39796
39853
|
if (formType === "input" || formType === "number") {
|
|
39797
|
-
return createVNode(script$
|
|
39854
|
+
return createVNode(script$9, mergeProps(propsData, {
|
|
39798
39855
|
"type": formType,
|
|
39799
39856
|
"value": row[col.columnName],
|
|
39800
39857
|
"onUpdate:value": ($event) => row[col.columnName] = $event,
|
|
39801
|
-
"
|
|
39858
|
+
"onFormChange": onFormChange
|
|
39802
39859
|
}), null);
|
|
39803
39860
|
}
|
|
39804
39861
|
if (formType === "select") {
|
|
39805
|
-
return createVNode(script$
|
|
39862
|
+
return createVNode(script$8, mergeProps(propsData, {
|
|
39806
39863
|
"value": row[col.columnName],
|
|
39807
39864
|
"onUpdate:value": ($event) => row[col.columnName] = $event,
|
|
39808
|
-
"onSetOptions": (options) => row[`${col.columnName}_options`] = options
|
|
39865
|
+
"onSetOptions": (options) => row[`${col.columnName}_options`] = options,
|
|
39866
|
+
"onFormChange": onFormChange
|
|
39867
|
+
}), null);
|
|
39868
|
+
}
|
|
39869
|
+
if (formType === "date") {
|
|
39870
|
+
return createVNode(script$7, mergeProps(propsData, {
|
|
39871
|
+
"formattedValue": row[col.columnName],
|
|
39872
|
+
"onUpdate:formattedValue": ($event) => row[col.columnName] = $event,
|
|
39873
|
+
"onFormChange": onFormChange
|
|
39809
39874
|
}), null);
|
|
39810
39875
|
}
|
|
39811
39876
|
};
|
|
@@ -40188,13 +40253,13 @@ var script$6 = /* @__PURE__ */ defineComponent({
|
|
|
40188
40253
|
isAlias = !!tooltipTitle;
|
|
40189
40254
|
}
|
|
40190
40255
|
if (type === "format")
|
|
40191
|
-
return createVNode(script$
|
|
40256
|
+
return createVNode(script$b, {
|
|
40192
40257
|
"tooltipTitle": tooltipTitle,
|
|
40193
40258
|
"content": name,
|
|
40194
40259
|
"isAlias": isAlias
|
|
40195
40260
|
}, null);
|
|
40196
40261
|
return () => {
|
|
40197
|
-
return [createVNode(script$
|
|
40262
|
+
return [createVNode(script$b, {
|
|
40198
40263
|
"tooltipTitle": tooltipTitle,
|
|
40199
40264
|
"content": name,
|
|
40200
40265
|
"isAlias": isAlias
|
|
@@ -40748,7 +40813,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
|
|
|
40748
40813
|
return createVNode(NPopconfirm, {
|
|
40749
40814
|
"onPositiveClick": () => confirmScanMulti(params)
|
|
40750
40815
|
}, {
|
|
40751
|
-
trigger: () => createVNode(script$
|
|
40816
|
+
trigger: () => createVNode(script$a, {
|
|
40752
40817
|
"class": "scan-multi-delete",
|
|
40753
40818
|
"iconClass": "shanchu"
|
|
40754
40819
|
}, null),
|
|
@@ -40961,7 +41026,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
|
|
|
40961
41026
|
}, [createVNode("img", {
|
|
40962
41027
|
"class": "bigTable-qr-img",
|
|
40963
41028
|
"src": src
|
|
40964
|
-
}, null), createVNode("span", null, [createVNode(script$
|
|
41029
|
+
}, null), createVNode("span", null, [createVNode(script$a, {
|
|
40965
41030
|
"iconClass": "fangda"
|
|
40966
41031
|
}, null)])])];
|
|
40967
41032
|
};
|
|
@@ -41045,7 +41110,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
|
|
|
41045
41110
|
}
|
|
41046
41111
|
else {
|
|
41047
41112
|
icon = createVNode(NTooltip, null, {
|
|
41048
|
-
trigger: () => createVNode(script$
|
|
41113
|
+
trigger: () => createVNode(script$a, {
|
|
41049
41114
|
"iconClass": btn.icon,
|
|
41050
41115
|
"style": {
|
|
41051
41116
|
marginRight: mr
|
|
@@ -41056,7 +41121,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
|
|
|
41056
41121
|
}
|
|
41057
41122
|
}
|
|
41058
41123
|
else if (btn.iconSetting) {
|
|
41059
|
-
icon = createVNode(script$
|
|
41124
|
+
icon = createVNode(script$a, {
|
|
41060
41125
|
"iconClass": JSON.parse(btn.iconSetting).icon,
|
|
41061
41126
|
"style": {
|
|
41062
41127
|
marginRight: mr
|
|
@@ -41485,7 +41550,7 @@ var script$6 = /* @__PURE__ */ defineComponent({
|
|
|
41485
41550
|
onScroll: handlerScroll,
|
|
41486
41551
|
onCellMouseenter: handleCellMouseenter
|
|
41487
41552
|
}, {
|
|
41488
|
-
empty: withCtx(() => [unref(state).isShowEmpty ? (openBlock(), createElementBlock("div", _hoisted_9$4, [createVNode(script$
|
|
41553
|
+
empty: withCtx(() => [unref(state).isShowEmpty ? (openBlock(), createElementBlock("div", _hoisted_9$4, [createVNode(script$c, {
|
|
41489
41554
|
"no-data-img": props.emptyItems.noDataImg,
|
|
41490
41555
|
"no-data-tip": props.emptyItems.noDataTip,
|
|
41491
41556
|
"show-img": !props.isNestTable
|
|
@@ -45163,7 +45228,8 @@ var script = /* @__PURE__ */ defineComponent({
|
|
|
45163
45228
|
verifyUser: { type: Function, required: false, default: () => Promise.resolve() },
|
|
45164
45229
|
queryPrintFormatByNumber: { type: Function, required: true, default: () => Promise.resolve({}) },
|
|
45165
45230
|
queryTemplateParams: { type: Function, required: false, default: () => Promise.resolve({}) },
|
|
45166
|
-
strategy: { type: String, required: false, default: "MULTI" }
|
|
45231
|
+
strategy: { type: String, required: false, default: "MULTI" },
|
|
45232
|
+
printParams: { type: Array, required: false }
|
|
45167
45233
|
},
|
|
45168
45234
|
emits: ["success", "error"],
|
|
45169
45235
|
setup(__props, { emit }) {
|
|
@@ -45227,7 +45293,7 @@ var script = /* @__PURE__ */ defineComponent({
|
|
|
45227
45293
|
emit("error", error);
|
|
45228
45294
|
};
|
|
45229
45295
|
const getPrintParams = (index = 0) => {
|
|
45230
|
-
const params = state.printParams[index];
|
|
45296
|
+
const params = props.printParams?.length ? props.printParams[index] : state.printParams[index];
|
|
45231
45297
|
return JSON.stringify(params);
|
|
45232
45298
|
};
|
|
45233
45299
|
const getOnceParams = () => {
|
package/package.json
CHANGED
|
@@ -176,9 +176,9 @@ import { SettingsSharp, SyncOutline, CopyOutline, CaretDown, CaretForward } from
|
|
|
176
176
|
import NoData from "./components/NoData.vue";
|
|
177
177
|
import TextOverTooltip from "./components/TextOverTooltip.vue";
|
|
178
178
|
import SvgIcon from '@/component/svg/index.vue';
|
|
179
|
-
import EditSelectTable from './components/edit-form/edit-select-table.vue'
|
|
180
179
|
import EditInput from './components/edit-form/edit-input.vue'
|
|
181
180
|
import EditSelect from './components/edit-form/edit-select.vue'
|
|
181
|
+
import EditDate from './components/edit-form/edit-date.vue'
|
|
182
182
|
import {
|
|
183
183
|
NButton,
|
|
184
184
|
NCheckbox,
|
|
@@ -271,7 +271,7 @@ const {
|
|
|
271
271
|
recordClickBtnInfo,
|
|
272
272
|
getInlineOpreateRow
|
|
273
273
|
}: any = useBatchEditing(props, state, emit, xGrid);
|
|
274
|
-
const { initEditTable, activeMethod, deleteRow, onClickSelectTable,
|
|
274
|
+
const { initEditTable, activeMethod, deleteRow, onClickSelectTable, onFormChange, getDefaultValue } = useEdit(props, state, emit, xGrid)
|
|
275
275
|
|
|
276
276
|
const {
|
|
277
277
|
isAboutNestTable,
|
|
@@ -377,7 +377,7 @@ const unBindDocumentClick = () => {
|
|
|
377
377
|
}
|
|
378
378
|
onMounted(() => {
|
|
379
379
|
bindDocumentClick();
|
|
380
|
-
state.tableHeight = handleTableHeight(state, props);
|
|
380
|
+
state.tableHeight = handleTableHeight(state, props) || 'auto';
|
|
381
381
|
|
|
382
382
|
// // 子列表在mounted后初始化 直接watch无法触发
|
|
383
383
|
if (!props.isNestTable) return;
|
|
@@ -706,13 +706,6 @@ const formatColumns = (map: any) => {
|
|
|
706
706
|
const formatterEdit = (params: any, col: any) => {
|
|
707
707
|
let { row, column, $rowIndex, rowIndex } = params
|
|
708
708
|
let formType = column.formType || col.formType || ''
|
|
709
|
-
// if (formType === 'selectTable') {
|
|
710
|
-
// const propsData = {
|
|
711
|
-
// row,
|
|
712
|
-
// col
|
|
713
|
-
// }
|
|
714
|
-
// return <EditSelectTable {...propsData} v-model={[row[col.columnName], 'value']} onClickSelectTable={onClickSelectTable} />
|
|
715
|
-
// }
|
|
716
709
|
if (formType === 'custom') {
|
|
717
710
|
return col.slotFn(params)
|
|
718
711
|
}
|
|
@@ -722,10 +715,13 @@ const formatterEdit = (params: any, col: any) => {
|
|
|
722
715
|
index: $rowIndex
|
|
723
716
|
}
|
|
724
717
|
if (formType === 'input' || formType === 'number') {
|
|
725
|
-
return <EditInput {...propsData} type={formType} v-model={[row[col.columnName], 'value']}
|
|
718
|
+
return <EditInput {...propsData} type={formType} v-model={[row[col.columnName], 'value']} onFormChange={onFormChange} />
|
|
726
719
|
}
|
|
727
720
|
if (formType === 'select') {
|
|
728
|
-
return <EditSelect {...propsData} v-model={[row[col.columnName], 'value']} onSetOptions={(options: any[]) => row[`${col.columnName}_options`] = options} />
|
|
721
|
+
return <EditSelect {...propsData} v-model={[row[col.columnName], 'value']} onSetOptions={(options: any[]) => row[`${col.columnName}_options`] = options} onFormChange={onFormChange} />
|
|
722
|
+
}
|
|
723
|
+
if (formType === 'date') {
|
|
724
|
+
return <EditDate {...propsData} v-model={[row[col.columnName], 'formattedValue']} onFormChange={onFormChange} />
|
|
729
725
|
}
|
|
730
726
|
}
|
|
731
727
|
const getEditBtn = (row: any, col: any, index: number) => {
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
<script lang="tsx">
|
|
2
|
+
import { defineComponent, ref, reactive, resolveComponent } from 'vue'
|
|
3
|
+
import { NDatePicker } from 'naive-ui'
|
|
4
|
+
|
|
5
|
+
export default defineComponent({
|
|
6
|
+
name: 'EditDate',
|
|
7
|
+
inheritAttrs: false,
|
|
8
|
+
components: {
|
|
9
|
+
NDatePicker
|
|
10
|
+
},
|
|
11
|
+
props: {
|
|
12
|
+
col: {
|
|
13
|
+
type: Object,
|
|
14
|
+
default: () => ({})
|
|
15
|
+
},
|
|
16
|
+
row: {
|
|
17
|
+
type: Object,
|
|
18
|
+
default: () => ({})
|
|
19
|
+
},
|
|
20
|
+
index: {
|
|
21
|
+
type: [Number, Object],
|
|
22
|
+
default: 0
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
emits: ['formChange'],
|
|
26
|
+
setup (props, { attrs, slots, emit }) {
|
|
27
|
+
const onConfirm = (value: number | [number, number] | null, formattedValue: string | [string, string] | null) => {
|
|
28
|
+
console.log('时间选择->', value)
|
|
29
|
+
emit('formChange', { value, row: props.row, column: props.col, index: props.index })
|
|
30
|
+
}
|
|
31
|
+
const config = {
|
|
32
|
+
type: props.col.type || 'datetime',
|
|
33
|
+
clearable: props.col.clearable || true,
|
|
34
|
+
disabled: props.col.disabled || false,
|
|
35
|
+
valueFormat: props.col.valueFormat || 'yyyy-MM-dd HH:mm:ss',
|
|
36
|
+
to: false
|
|
37
|
+
}
|
|
38
|
+
return () => <NDatePicker {...attrs} {...config} onConfirm={onConfirm} />
|
|
39
|
+
}
|
|
40
|
+
})
|
|
41
|
+
</script>
|
|
42
|
+
<style lang="less" scoped></style>
|
|
@@ -27,10 +27,10 @@ export default defineComponent({
|
|
|
27
27
|
default: 0
|
|
28
28
|
}
|
|
29
29
|
},
|
|
30
|
-
emits: ['
|
|
30
|
+
emits: ['formChange'],
|
|
31
31
|
setup (props, { attrs, slots, emit }) {
|
|
32
32
|
const onUpdateValue = (value: number | string | null) => {
|
|
33
|
-
emit('
|
|
33
|
+
emit('formChange', { value, row: props.row, column: props.col, index: props.index })
|
|
34
34
|
}
|
|
35
35
|
return () => props.type === 'input' ? <NInput {...attrs} onUpdateValue={onUpdateValue } /> : <NInputNumber {...attrs} onUpdateValue={onUpdateValue} />
|
|
36
36
|
}
|
|
@@ -11,14 +11,18 @@ export default defineComponent({
|
|
|
11
11
|
props: {
|
|
12
12
|
col: {
|
|
13
13
|
type: Object,
|
|
14
|
-
default: () => {}
|
|
14
|
+
default: () => ({})
|
|
15
15
|
},
|
|
16
16
|
row: {
|
|
17
17
|
type: Object,
|
|
18
|
-
default: () => {}
|
|
18
|
+
default: () => ({})
|
|
19
|
+
},
|
|
20
|
+
index: {
|
|
21
|
+
type: [Number, Object],
|
|
22
|
+
default: 0
|
|
19
23
|
}
|
|
20
24
|
},
|
|
21
|
-
emits: ['setOptions'],
|
|
25
|
+
emits: ['setOptions', 'formChange'],
|
|
22
26
|
setup (props, { attrs, slots, emit }) {
|
|
23
27
|
|
|
24
28
|
const state = reactive({
|
|
@@ -40,6 +44,10 @@ export default defineComponent({
|
|
|
40
44
|
|
|
41
45
|
setOptions()
|
|
42
46
|
|
|
47
|
+
const onUpdateValue = (value: any[] | string | number | null) => {
|
|
48
|
+
emit('formChange', { value, row: props.row, column: props.col, index: props.index })
|
|
49
|
+
}
|
|
50
|
+
|
|
43
51
|
return () => [
|
|
44
52
|
<NSelect
|
|
45
53
|
{...attrs}
|
|
@@ -49,6 +57,7 @@ export default defineComponent({
|
|
|
49
57
|
filterable
|
|
50
58
|
to={false}
|
|
51
59
|
placeholder="请选择"
|
|
60
|
+
onUpdateValue={onUpdateValue}
|
|
52
61
|
/>
|
|
53
62
|
]
|
|
54
63
|
}
|
|
@@ -71,8 +71,8 @@ export const useEdit = (props: any, state: any, emit: any, xGrid: any) => {
|
|
|
71
71
|
xGrid.value.clearActived()
|
|
72
72
|
}
|
|
73
73
|
|
|
74
|
-
const
|
|
75
|
-
emit('
|
|
74
|
+
const onFormChange = ({ value, row, column }: {value: number | string | null, row: any, column: any}) => {
|
|
75
|
+
emit('formChange', { value, row, column })
|
|
76
76
|
}
|
|
77
77
|
|
|
78
78
|
const getDefaultValue = (params: any, item: any) => {
|
|
@@ -94,7 +94,7 @@ export const useEdit = (props: any, state: any, emit: any, xGrid: any) => {
|
|
|
94
94
|
activeMethod,
|
|
95
95
|
deleteRow,
|
|
96
96
|
onClickSelectTable,
|
|
97
|
-
|
|
97
|
+
onFormChange,
|
|
98
98
|
getDefaultValue
|
|
99
99
|
}
|
|
100
100
|
}
|
|
@@ -64,6 +64,7 @@ interface Props {
|
|
|
64
64
|
queryPrintFormatByNumber: Function
|
|
65
65
|
queryTemplateParams?: Function
|
|
66
66
|
strategy?: string
|
|
67
|
+
printParams?: any[]
|
|
67
68
|
}
|
|
68
69
|
const props = withDefaults(defineProps<Props>(), {
|
|
69
70
|
params: () => ([]),
|
|
@@ -138,7 +139,7 @@ const prevFnError = () => {
|
|
|
138
139
|
emit('error', error);
|
|
139
140
|
}
|
|
140
141
|
const getPrintParams = (index: number = 0) => {
|
|
141
|
-
const params = state.printParams[index];
|
|
142
|
+
const params = props.printParams?.length ? props.printParams[index] : state.printParams[index];
|
|
142
143
|
return JSON.stringify(params);
|
|
143
144
|
}
|
|
144
145
|
const getOnceParams = () => {
|