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/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, NDatePicker, NRadio, NModal, NForm, NGrid, NFormItemGi, NFormItem } from 'naive-ui';
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
- "updateInput"
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 onUpdateInput = ({ value, row, column }) => {
38471
- emit("updateInput", { value, row, column });
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
- onUpdateInput,
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$b = /* @__PURE__ */ defineComponent({
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$b.__scopeId = "data-v-4a4b0812";
38569
- script$b.__file = "packages/big-table/src/components/NoData.vue";
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$a = /* @__PURE__ */ defineComponent({
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$a.__scopeId = "data-v-6633a934";
38644
- script$a.__file = "packages/big-table/src/components/TextOverTooltip.vue";
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$9 = /* @__PURE__ */ defineComponent({
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$9.__scopeId = "data-v-d1ad5be8";
38682
- script$9.__file = "src/component/svg/index.vue";
38681
+ script$a.__scopeId = "data-v-d1ad5be8";
38682
+ script$a.__file = "src/component/svg/index.vue";
38683
38683
 
38684
- var script$8 = defineComponent({
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: ["updateInput"],
38709
+ emits: ["formChange"],
38710
38710
  setup(props, { attrs, slots, emit }) {
38711
38711
  const onUpdateValue = (value) => {
38712
- emit("updateInput", {
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$8.__file = "packages/big-table/src/components/edit-form/edit-input.vue";
38727
+ script$9.__file = "packages/big-table/src/components/edit-form/edit-input.vue";
38728
38728
 
38729
- var script$7 = defineComponent({
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$7.__file = "packages/big-table/src/components/edit-form/edit-select.vue";
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, onUpdateInput, getDefaultValue } = useEdit(props, state, emit, xGrid);
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$8, mergeProps(propsData, {
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
- "onUpdateInput": onUpdateInput
39858
+ "onFormChange": onFormChange
39802
39859
  }), null);
39803
39860
  }
39804
39861
  if (formType === "select") {
39805
- return createVNode(script$7, mergeProps(propsData, {
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$a, {
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$a, {
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$9, {
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$9, {
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$9, {
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$9, {
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$b, {
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
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "cnhis-design-vue",
3
3
  "private": false,
4
- "version": "3.0.5",
4
+ "version": "3.0.6",
5
5
  "main": "es/index.js",
6
6
  "module": "es/index.js",
7
7
  "scripts": {
@@ -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, onUpdateInput, getDefaultValue } = useEdit(props, state, emit, xGrid)
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']} onUpdateInput={onUpdateInput} />
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) => {
@@ -41,8 +41,7 @@ const bigTableEmits: string[] = [
41
41
  "selectionChangeLocal",
42
42
  "switchBtnOnChange",
43
43
  "asyncTableChange",
44
- // "clickSelectTable"
45
- "updateInput"
44
+ "formChange"
46
45
  ];
47
46
 
48
47
  export default bigTableEmits;
@@ -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: ['updateInput'],
30
+ emits: ['formChange'],
31
31
  setup (props, { attrs, slots, emit }) {
32
32
  const onUpdateValue = (value: number | string | null) => {
33
- emit('updateInput', { value, row: props.row, column: props.col, index: props.index })
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 onUpdateInput = ({ value, row, column }: {value: number | string | null, row: any, column: any}) => {
75
- emit('updateInput', { value, row, column })
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
- onUpdateInput,
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 = () => {