@aplus-frontend/ui 7.19.6 → 7.19.7

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.
@@ -1,21 +1,21 @@
1
- import { defineComponent as G, useSlots as U, ref as g, onMounted as W, watch as $, unref as r, createElementBlock as q, openBlock as J, Fragment as Q, createVNode as f, mergeProps as h, withCtx as C, createSlots as X, renderList as Y, renderSlot as Z, normalizeProps as ee, guardReactiveProps as oe } from "vue";
2
- import { cloneDeep as u, isEqual as te, omit as ae } from "lodash-unified";
1
+ import { defineComponent as W, useSlots as $, ref as g, onMounted as q, watch as J, unref as r, createElementBlock as Q, openBlock as X, Fragment as Y, createVNode as f, mergeProps as h, withCtx as C, createSlots as Z, renderList as ee, renderSlot as oe, normalizeProps as te, guardReactiveProps as ae } from "vue";
2
+ import { cloneDeep as u, isEqual as ne, omit as le } from "lodash-unified";
3
3
  import { ApForm as R } from "../../ap-form/index.mjs";
4
- import { useInjectForm as ne } from "../../ap-form/context.mjs";
5
- import { useWatch as le } from "../../ap-form/hooks/use-watch.mjs";
6
- import { getModelValue as re } from "../../ap-form/utils/get.mjs";
7
- import { transformValues as se } from "../../ap-form/utils/transform.mjs";
4
+ import { useInjectForm as re } from "../../ap-form/context.mjs";
5
+ import { useWatch as se } from "../../ap-form/hooks/use-watch.mjs";
6
+ import { getModelValue as ie } from "../../ap-form/utils/get.mjs";
7
+ import { transformValues as me } from "../../ap-form/utils/transform.mjs";
8
8
  import "../../config-provider/index.mjs";
9
- import { useGetEditableColumns as ie } from "../hooks/use-editable-columns.mjs";
10
- import { useEditableFormItemApi as me } from "../hooks/use-editable-form-item-api.mjs";
9
+ import { useGetEditableColumns as ue } from "../hooks/use-editable-columns.mjs";
10
+ import { useEditableFormItemApi as de } from "../hooks/use-editable-form-item-api.mjs";
11
11
  import "../index.vue2.mjs";
12
- import ue from "../style/editable.mjs";
13
- import { getShadowName as de } from "../utils.mjs";
14
- import { getColumnTransformOptions as pe, arrayToObject as b, getRowKey as fe } from "./utils.mjs";
15
- import { useNamespace as ce } from "../../config-provider/hooks/use-namespace.mjs";
16
- import { useGlobalConfig as we } from "../../config-provider/hooks/use-global-config.mjs";
17
- import ye from "../index.vue.mjs";
18
- const Ke = /* @__PURE__ */ G({
12
+ import pe from "../style/editable.mjs";
13
+ import { getShadowName as fe } from "../utils.mjs";
14
+ import { getColumnTransformOptions as ce, arrayToObject as b, getRowKey as we } from "./utils.mjs";
15
+ import { useNamespace as ye } from "../../config-provider/hooks/use-namespace.mjs";
16
+ import { useGlobalConfig as ge } from "../../config-provider/hooks/use-global-config.mjs";
17
+ import he from "../index.vue.mjs";
18
+ const ke = /* @__PURE__ */ W({
19
19
  name: "EditableGrid",
20
20
  __name: "form-item",
21
21
  props: {
@@ -142,50 +142,52 @@ const Ke = /* @__PURE__ */ G({
142
142
  name: {},
143
143
  formItem: {}
144
144
  },
145
- setup(v, {
146
- expose: B
145
+ setup(B, {
146
+ expose: v
147
147
  }) {
148
- const x = U(), t = v, {
148
+ const x = $(), t = B, {
149
149
  b: S
150
- } = ce("editable-aggrid"), I = ue("editable-aggrid"), m = g(), {
150
+ } = ye("editable-aggrid"), I = pe("editable-aggrid"), m = g(), {
151
151
  internalInstance: n
152
- } = ne();
152
+ } = re();
153
153
  function F(e) {
154
- const o = pe(t.columns || []);
154
+ const o = ce(t.columns || []);
155
155
  if (!Object.keys(o).length || !e?.length)
156
156
  return e;
157
157
  let a = [];
158
158
  for (const i of e)
159
- a.push(se(i, o));
159
+ a.push(me(i, o));
160
160
  return a;
161
161
  }
162
- const s = de(t.name);
162
+ const s = fe(t.name);
163
163
  let c = [];
164
- W(() => {
165
- const e = t.formItem?.initialValue ?? re(n?.getInitialValues() ?? {}, t.name);
166
- e && (n?.updateInitialModel(s, b(u(e), t.rowKey)), c = u(e), l.value || j(u(e), "suffix", !0));
164
+ q(() => {
165
+ const e = t.formItem?.initialValue ?? ie(n?.getInitialValues() ?? {}, t.name);
166
+ e && (n?.updateInitialModel(s, b(u(e), t.rowKey)), c = u(e), l.value || _(u(e), "suffix", !0));
167
167
  });
168
- const l = g([]), T = le(t.name);
169
- $(() => T.value, (e) => {
170
- te(e, l.value) || w(e ?? u(c));
168
+ const l = g([]), T = se(t.name);
169
+ J(() => T.value, (e) => {
170
+ ne(e, l.value) || w(e ?? u(c));
171
171
  }, {
172
172
  deep: !0,
173
173
  flush: "post",
174
174
  immediate: !0
175
175
  });
176
- const E = we("valueTypeMap"), V = ie(t, E, s), {
177
- add: N,
178
- addMultiple: _,
179
- __addMultiple: j,
180
- remove: K,
181
- removeByKey: k,
182
- getRowData: D,
176
+ const E = ge("valueTypeMap"), V = ue(t, E, s), {
177
+ add: K,
178
+ addMultiple: N,
179
+ __addMultiple: _,
180
+ remove: D,
181
+ removeByKey: j,
182
+ getRowData: k,
183
183
  getRowsData: O,
184
- setRowData: z,
185
- clear: H,
184
+ getRowDataByKey: z,
185
+ setRowData: H,
186
+ setRowDataByKey: L,
187
+ clear: M,
186
188
  refreshRowIds: d
187
- } = me(t, n, l, s);
188
- function L() {
189
+ } = de(t, n, l, s);
190
+ function P() {
189
191
  const e = m.value?._internalGridApi;
190
192
  if (!d.value?.length || !e)
191
193
  return;
@@ -204,34 +206,36 @@ const Ke = /* @__PURE__ */ G({
204
206
  const a = e === "end" ? l.value.length - 1 : e;
205
207
  m.value?.scrollToRow(a, o);
206
208
  }
207
- function M(e, o) {
209
+ function A(e, o) {
208
210
  m.value?.scrollToColumn(e, o);
209
211
  }
210
- function P(e, o) {
212
+ function G(e, o) {
211
213
  const a = [s, String(e), o].flat();
212
214
  return n?.validateFields([a]);
213
215
  }
214
- function A(e) {
215
- const a = r(l).map((i, p) => [s, String(fe(i, p, t.rowKey)), e].flat());
216
+ function U(e) {
217
+ const a = r(l).map((i, p) => [s, String(we(i, p, t.rowKey)), e].flat());
216
218
  return n?.validateFields(a);
217
219
  }
218
- return B({
219
- add: N,
220
- addMultiple: _,
221
- remove: K,
222
- removeByKey: k,
223
- getRowData: D,
220
+ return v({
221
+ add: K,
222
+ addMultiple: N,
223
+ remove: D,
224
+ removeByKey: j,
225
+ getRowData: k,
224
226
  getRowsData: O,
225
- setRowData: z,
226
- clear: H,
227
+ getRowDataByKey: z,
228
+ setRowData: H,
229
+ clear: M,
227
230
  setTableData: w,
228
231
  scrollTo: y,
229
232
  scrollToRow: y,
230
- scrollToColumn: M,
231
- validateCell: P,
232
- validateColumn: A,
233
+ scrollToColumn: A,
234
+ validateCell: G,
235
+ validateColumn: U,
236
+ setRowDataByKey: L,
233
237
  table: m
234
- }), (e, o) => (J(), q(Q, null, [f(r(R).FormItem, {
238
+ }), (e, o) => (X(), Q(Y, null, [f(r(R).FormItem, {
235
239
  hidden: "",
236
240
  name: e.name,
237
241
  "initial-value": e.formItem?.initialValue,
@@ -239,7 +243,7 @@ const Ke = /* @__PURE__ */ G({
239
243
  }, null, 8, ["name", "initial-value"]), f(r(R).FormItem, h({
240
244
  label: e.label
241
245
  }, e.formItem), {
242
- default: C(() => [f(ye, h(r(ae)(t, ["name", "maxLength", "onChange", "defaultValue", "formItem"]), {
246
+ default: C(() => [f(he, h(r(le)(t, ["name", "maxLength", "onChange", "defaultValue", "formItem"]), {
243
247
  ref_key: "tableRef",
244
248
  ref: m,
245
249
  class: [r(S)(), r(I)],
@@ -247,17 +251,17 @@ const Ke = /* @__PURE__ */ G({
247
251
  columns: r(V),
248
252
  "data-source": l.value,
249
253
  "search-form": !1,
250
- onUpdate: L
251
- }), X({
254
+ onUpdate: P
255
+ }), Z({
252
256
  _: 2
253
- }, [Y(x, (a, i) => ({
257
+ }, [ee(x, (a, i) => ({
254
258
  name: i,
255
- fn: C((p) => [Z(e.$slots, i, ee(oe(p || {})))])
259
+ fn: C((p) => [oe(e.$slots, i, te(ae(p || {})))])
256
260
  }))]), 1040, ["class", "columns", "data-source"])]),
257
261
  _: 3
258
262
  }, 16, ["label"])], 64));
259
263
  }
260
264
  });
261
265
  export {
262
- Ke as default
266
+ ke as default
263
267
  };
@@ -1,18 +1,18 @@
1
- import { defineComponent as M, useSlots as $, ref as h, watch as q, unref as l, createBlock as J, openBlock as Q, withCtx as m, createVNode as b, mergeProps as X, createSlots as Y, renderList as Z, renderSlot as ee, normalizeProps as oe, guardReactiveProps as ae } from "vue";
2
- import { isEqual as te, isArray as v, omit as ne } from "lodash-unified";
1
+ import { defineComponent as q, useSlots as J, ref as h, watch as Q, unref as l, createBlock as X, openBlock as Y, withCtx as m, createVNode as b, mergeProps as Z, createSlots as ee, renderList as oe, renderSlot as ae, normalizeProps as te, guardReactiveProps as ne } from "vue";
2
+ import { isEqual as le, isArray as v, omit as re } from "lodash-unified";
3
3
  import { ApForm as c } from "../../ap-form/index.mjs";
4
4
  import "../../config-provider/index.mjs";
5
5
  import "../../hooks/index.mjs";
6
- import { useEditableApi as le } from "../hooks/use-editable-api.mjs";
7
- import { useGetEditableColumns as re } from "../hooks/use-editable-columns.mjs";
6
+ import { useEditableApi as se } from "../hooks/use-editable-api.mjs";
7
+ import { useGetEditableColumns as ie } from "../hooks/use-editable-columns.mjs";
8
8
  import "../index.vue2.mjs";
9
- import se from "../style/editable.mjs";
10
- import { arrayToObject as f, getRowKey as ie } from "./utils.mjs";
11
- import { useNamespace as de } from "../../config-provider/hooks/use-namespace.mjs";
12
- import { useControllableValue as ue } from "../../hooks/useControllableValue.mjs";
13
- import { useGlobalConfig as pe } from "../../config-provider/hooks/use-global-config.mjs";
14
- import me from "../index.vue.mjs";
15
- const Fe = /* @__PURE__ */ M({
9
+ import de from "../style/editable.mjs";
10
+ import { arrayToObject as f, getRowKey as ue } from "./utils.mjs";
11
+ import { useNamespace as pe } from "../../config-provider/hooks/use-namespace.mjs";
12
+ import { useControllableValue as me } from "../../hooks/useControllableValue.mjs";
13
+ import { useGlobalConfig as ce } from "../../config-provider/hooks/use-global-config.mjs";
14
+ import fe from "../index.vue.mjs";
15
+ const Ke = /* @__PURE__ */ q({
16
16
  name: "EditableGrid",
17
17
  __name: "index",
18
18
  props: {
@@ -146,30 +146,32 @@ const Fe = /* @__PURE__ */ M({
146
146
  expose: x,
147
147
  emit: B
148
148
  }) {
149
- const S = $(), a = C, {
149
+ const S = J(), a = C, {
150
150
  b: T
151
- } = de("editable-aggrid"), F = se("editable-aggrid"), _ = B, i = h(), {
151
+ } = pe("editable-aggrid"), F = de("editable-aggrid"), _ = B, i = h(), {
152
152
  value: s,
153
153
  updateValue: y
154
- } = ue(a, _), r = h(), E = c.useWatch(a.name, r);
155
- q(s, (e) => {
154
+ } = me(a, _), r = h(), K = c.useWatch(a.name, r);
155
+ Q(s, (e) => {
156
156
  const o = f(e, a.rowKey);
157
- te(o, l(E)) || r.value?.setFieldValue(a.name, o);
157
+ le(o, l(K)) || r.value?.setFieldValue(a.name, o);
158
158
  }, {
159
159
  deep: !0
160
160
  });
161
- const K = pe("valueTypeMap"), k = re(a, K), {
161
+ const E = ce("valueTypeMap"), k = ie(a, E), {
162
162
  add: A,
163
- addMultiple: N,
164
- remove: j,
165
- removeByKey: I,
166
- getRowData: V,
167
- getRowsData: D,
168
- setRowData: z,
169
- clear: H,
163
+ addMultiple: D,
164
+ remove: N,
165
+ removeByKey: j,
166
+ getRowData: I,
167
+ getRowsData: V,
168
+ getRowDataByKey: z,
169
+ setRowData: H,
170
+ setRowDataByKey: O,
171
+ clear: U,
170
172
  refreshRowIds: d
171
- } = le(a, r, s, y);
172
- function O() {
173
+ } = se(a, r, s, y);
174
+ function L() {
173
175
  const e = i.value?._internalGridApi;
174
176
  if (!d.value?.length || !e)
175
177
  return;
@@ -179,7 +181,7 @@ const Fe = /* @__PURE__ */ M({
179
181
  force: !0
180
182
  }), d.value = [];
181
183
  }
182
- function U() {
184
+ function P() {
183
185
  r.value?.resetFields();
184
186
  }
185
187
  function w(e) {
@@ -187,21 +189,21 @@ const Fe = /* @__PURE__ */ M({
187
189
  }
188
190
  function g(e) {
189
191
  try {
190
- const o = Object.keys(e), t = s.value.map((n) => ie(n, void 0, a.rowKey));
192
+ const o = Object.keys(e), t = s.value.map((n) => ue(n, void 0, a.rowKey));
191
193
  return o.sort((n, u) => t.findIndex((p) => String(p) === n) - t.findIndex((p) => String(p) === u)), o.map((n) => e[n]);
192
194
  } catch {
193
195
  return e;
194
196
  }
195
197
  }
196
- async function L(e, o) {
198
+ async function G(e, o) {
197
199
  const n = (await r.value?.validateFields(w(e), o))?.[a.name];
198
200
  return g(n);
199
201
  }
200
- async function P(e, o) {
202
+ async function W(e, o) {
201
203
  const n = (await r.value?.validateFieldsReturnTransformed(w(e), o))?.[a.name];
202
204
  return g(n);
203
205
  }
204
- function G(e) {
206
+ function M(e) {
205
207
  y(e);
206
208
  const o = f(e, a.rowKey);
207
209
  r.value?.setFieldValue(a.name, o);
@@ -210,27 +212,29 @@ const Fe = /* @__PURE__ */ M({
210
212
  const t = e === "end" ? s.value.length - 1 : e;
211
213
  i.value?.scrollToRow(t, o);
212
214
  }
213
- function W(e, o) {
215
+ function $(e, o) {
214
216
  i.value?.scrollToColumn(e, o);
215
217
  }
216
218
  return x({
217
- resetFields: U,
218
- validateFields: L,
219
- validateFieldsReturnTransformed: P,
219
+ resetFields: P,
220
+ validateFields: G,
221
+ validateFieldsReturnTransformed: W,
220
222
  add: A,
221
- addMultiple: N,
222
- remove: j,
223
- removeByKey: I,
224
- getRowData: V,
225
- getRowsData: D,
226
- setRowData: z,
227
- clear: H,
228
- setTableData: G,
223
+ addMultiple: D,
224
+ remove: N,
225
+ removeByKey: j,
226
+ getRowData: I,
227
+ getRowsData: V,
228
+ setRowData: H,
229
+ clear: U,
230
+ setTableData: M,
229
231
  scrollTo: R,
230
232
  scrollToRow: R,
231
- scrollToColumn: W,
232
- table: i
233
- }), (e, o) => (Q(), J(l(c), {
233
+ scrollToColumn: $,
234
+ table: i,
235
+ getRowDataByKey: z,
236
+ setRowDataByKey: O
237
+ }), (e, o) => (Y(), X(l(c), {
234
238
  ref_key: "formRef",
235
239
  ref: r,
236
240
  "initial-values": {
@@ -244,7 +248,7 @@ const Fe = /* @__PURE__ */ M({
244
248
  name: e.name,
245
249
  "no-style": ""
246
250
  }, {
247
- default: m(() => [b(me, X(l(ne)(a, ["name", "value", "onUpdate:value", "maxLength", "onChange", "defaultValue"]), {
251
+ default: m(() => [b(fe, Z(l(re)(a, ["name", "value", "onUpdate:value", "maxLength", "onChange", "defaultValue"]), {
248
252
  ref_key: "tableRef",
249
253
  ref: i,
250
254
  class: [l(T)(), l(F)],
@@ -252,12 +256,12 @@ const Fe = /* @__PURE__ */ M({
252
256
  columns: l(k),
253
257
  "data-source": l(s),
254
258
  "search-form": !1,
255
- onUpdate: O
256
- }), Y({
259
+ onUpdate: L
260
+ }), ee({
257
261
  _: 2
258
- }, [Z(S, (t, n) => ({
262
+ }, [oe(S, (t, n) => ({
259
263
  name: n,
260
- fn: m((u) => [ee(e.$slots, n, oe(ae(u || {})))])
264
+ fn: m((u) => [ae(e.$slots, n, te(ne(u || {})))])
261
265
  }))]), 1040, ["class", "columns", "data-source"])]),
262
266
  _: 3
263
267
  }, 8, ["name"])]),
@@ -266,5 +270,5 @@ const Fe = /* @__PURE__ */ M({
266
270
  }
267
271
  });
268
272
  export {
269
- Fe as default
273
+ Ke as default
270
274
  };
@@ -95,6 +95,15 @@ export type EditableAgGridExpose<RecordType = any, ModelType = RecordType[]> = O
95
95
  remove: (data: RecordType | RecordType[]) => void;
96
96
  validateFieldsReturnTransformed: EditableTableExpose<ModelType, RecordType>['validateFields'];
97
97
  table: AgGridExpose;
98
+ getRowDataByKey: (key: string | number) => RecordType | undefined;
99
+ /**
100
+ * 设置表格行数据(通过行key)
101
+ * @param key
102
+ * @param data
103
+ * @param merge 是否进行数据的浅层合并(默认为true)
104
+ * @returns
105
+ */
106
+ setRowDataByKey: (key: any, data: Partial<RecordType>, merge?: boolean) => void;
98
107
  };
99
108
  export type EditableAgGridFormItemExpose<RecordType = any, ModelType = RecordType[]> = Omit<EditableAgGridExpose<RecordType, ModelType>, 'resetFields' | 'validateFields' | 'validateFieldsReturnTransformed'> & {
100
109
  /**
@@ -9,6 +9,7 @@ export declare const useEditableApi: <RecordType>(props: EditableAgGridProps<Rec
9
9
  removeByKey: (key: Key | Key[]) => void;
10
10
  getRowData: (index: number) => RecordType;
11
11
  getRowsData: () => RecordType[];
12
+ setRowDataByKey: (key: any, payload: any, merge?: boolean) => void;
12
13
  setRowData: (index: string | number, payload: any, merge?: boolean) => void;
13
14
  clear: () => void;
14
15
  refreshRowIds: ShallowRef<string[], string[]>;
@@ -1,157 +1,175 @@
1
- import { isFunction as h, isUndefined as S, isNumber as K, cloneDeep as z, isArray as x, isString as A } from "lodash-unified";
2
- import { shallowRef as E, computed as N, unref as d, isRef as U } from "vue";
1
+ import { isFunction as h, isUndefined as z, isNumber as m, cloneDeep as A, isArray as x, isString as E } from "lodash-unified";
2
+ import { shallowRef as N, computed as U, unref as d, isRef as $ } from "vue";
3
3
  import "../../utils/index.mjs";
4
- import { arrayToObject as $ } from "../editable/utils.mjs";
4
+ import { arrayToObject as q } from "../editable/utils.mjs";
5
5
  import { isDef as R } from "../../utils/is.mjs";
6
- let q = 0;
7
- function I() {
8
- return `_ag_grid${q++}`;
6
+ let C = 0;
7
+ function F() {
8
+ return `_ag_grid${C++}`;
9
9
  }
10
- const Q = (u, m, i, g) => {
11
- const w = E([]), y = N(() => U(m) ? d(m) : m);
12
- function F(n, t) {
13
- const l = d(i)?.length || 0;
14
- if (R(u.maxLength) && l >= u.maxLength || !n && h(u.rowKey))
10
+ const W = (i, K, f, g) => {
11
+ const w = N([]), y = U(() => $(K) ? d(K) : K);
12
+ function I(n, o) {
13
+ const r = d(f)?.length || 0;
14
+ if (R(i.maxLength) && r >= i.maxLength || !n && h(i.rowKey))
15
15
  return;
16
- const o = {
17
- ...n || { [u.rowKey]: I() }
16
+ const u = {
17
+ ...n || { [i.rowKey]: F() }
18
18
  };
19
19
  y.value?.setFieldValue?.(
20
- u.name,
21
- o,
20
+ i.name,
21
+ u,
22
22
  !0,
23
- (r, c) => {
24
- const e = s(o, void 0, u.rowKey);
25
- if (r[c] ? r[c][e] = o : r[c] = { [e]: o }, !i.value) {
26
- i.value = [o];
23
+ (t, s) => {
24
+ const e = c(u, void 0, i.rowKey);
25
+ if (t[s] ? t[s][e] = u : t[s] = { [e]: u }, !f.value) {
26
+ f.value = [u];
27
27
  return;
28
28
  }
29
- S(t) ? i.value.push(o) : (w.value = i.value.map(
30
- (f, v) => v < t ? null : s(f, v, u.rowKey)
31
- ).filter(Boolean), i.value.splice(t, 0, o));
29
+ z(o) ? f.value.push(u) : (w.value = f.value.map(
30
+ (l, v) => v < o ? null : c(l, v, i.rowKey)
31
+ ).filter(Boolean), f.value.splice(o, 0, u));
32
32
  }
33
33
  );
34
34
  }
35
- function j(n, t = "suffix") {
36
- const l = d(i)?.length || 0, o = K(n) ? n : n.length;
37
- if (R(u.maxLength) && l + o > u.maxLength || K(n) && h(u.rowKey))
35
+ function j(n, o = "suffix") {
36
+ const r = d(f)?.length || 0, u = m(n) ? n : n.length;
37
+ if (R(i.maxLength) && r + u > i.maxLength || m(n) && h(i.rowKey))
38
38
  return;
39
- const r = K(n) ? new Array(n).fill(0).map(() => ({ [u.rowKey]: I() })) : z(n), c = $(r, u.rowKey);
39
+ const t = m(n) ? new Array(n).fill(0).map(() => ({ [i.rowKey]: F() })) : A(n), s = q(t, i.rowKey);
40
40
  y.value?.setFieldValue?.(
41
- u.name,
42
- r,
41
+ i.name,
42
+ t,
43
43
  !0,
44
- (e, f) => {
45
- if (e[f] ? Object.assign(e[f], c) : e[f] = c, !i.value) {
46
- i.value = [...r];
44
+ (e, l) => {
45
+ if (e[l] ? Object.assign(e[l], s) : e[l] = s, !f.value) {
46
+ f.value = [...t];
47
47
  return;
48
48
  }
49
- t === "suffix" ? i.value.push(...r) : (w.value = i.value.map(
50
- (v, _) => s(v, _, u.rowKey)
51
- ), i.value.unshift(...r));
49
+ o === "suffix" ? f.value.push(...t) : (w.value = f.value.map(
50
+ (v, S) => c(v, S, i.rowKey)
51
+ ), f.value.unshift(...t));
52
52
  }
53
53
  );
54
54
  }
55
- function k(n) {
56
- const t = x(n) ? n : [n];
55
+ function O(n) {
56
+ const o = x(n) ? n : [n];
57
57
  y.value?.setFieldValue?.(
58
- u.name,
58
+ i.name,
59
59
  void 0,
60
60
  !0,
61
- (l, o) => {
62
- for (const e of t) {
63
- const f = s(e, void 0, u.rowKey);
64
- delete l[o][f];
61
+ (r, u) => {
62
+ for (const e of o) {
63
+ const l = c(e, void 0, i.rowKey);
64
+ delete r[u][l];
65
65
  }
66
- const r = i.value.filter(
67
- (e) => !t.includes(e)
68
- ), c = i.value.findIndex(
69
- (e) => t.includes(e)
66
+ const t = f.value.filter(
67
+ (e) => !o.includes(e)
68
+ ), s = f.value.findIndex(
69
+ (e) => o.includes(e)
70
70
  );
71
- w.value = i.value.map(
72
- (e, f) => f <= c ? null : s(e, f, u.rowKey)
73
- ).filter(Boolean), g?.(r);
71
+ w.value = f.value.map(
72
+ (e, l) => l <= s ? null : c(e, l, i.rowKey)
73
+ ).filter(Boolean), g?.(t);
74
74
  }
75
75
  );
76
76
  }
77
- function s(n, t, l) {
78
- if (l)
79
- return A(l) ? n[l] : l(n, t);
77
+ function c(n, o, r) {
78
+ if (r)
79
+ return E(r) ? n[r] : r(n, o);
80
80
  }
81
- function B(n) {
82
- const t = new Set(x(n) ? n : [n]);
83
- t.size !== 0 && y.value?.setFieldValue?.(
84
- u.name,
81
+ function k(n) {
82
+ const o = new Set(x(n) ? n : [n]);
83
+ o.size !== 0 && y.value?.setFieldValue?.(
84
+ i.name,
85
85
  void 0,
86
86
  !0,
87
- (l, o) => {
88
- for (const e of t)
89
- delete l[o][e];
90
- const r = i.value.filter(
91
- (e, f) => !t.has(s(e, f, u.rowKey))
92
- ), c = i.value.findIndex(
93
- (e, f) => t.has(s(e, f, u.rowKey))
87
+ (r, u) => {
88
+ for (const e of o)
89
+ delete r[u][e];
90
+ const t = f.value.filter(
91
+ (e, l) => !o.has(c(e, l, i.rowKey))
92
+ ), s = f.value.findIndex(
93
+ (e, l) => o.has(c(e, l, i.rowKey))
94
94
  );
95
- w.value = i.value.map(
96
- (e, f) => f <= c ? null : s(e, f, u.rowKey)
97
- ).filter(Boolean), g?.(r);
95
+ w.value = f.value.map(
96
+ (e, l) => l <= s ? null : c(e, l, i.rowKey)
97
+ ).filter(Boolean), g?.(t);
98
98
  }
99
99
  );
100
100
  }
101
- function L(n) {
102
- return d(i)?.[n];
101
+ function B(n) {
102
+ return d(f)?.[n];
103
103
  }
104
- function O(n) {
105
- return i.value?.find(
106
- (t, l) => s(t, l, u.rowKey) === n
104
+ function V(n) {
105
+ return f.value?.find(
106
+ (o, r) => c(o, r, i.rowKey) === n
107
107
  );
108
108
  }
109
- function V() {
110
- return d(i);
109
+ function a() {
110
+ return d(f);
111
111
  }
112
- function a(n, t, l = !0) {
112
+ function L(n, o, r = !0) {
113
113
  y.value?.setFieldValue?.(
114
- u.name,
114
+ i.name,
115
115
  void 0,
116
116
  !0,
117
- (o, r) => {
118
- const c = i.value.findIndex(
119
- (f, v) => n === v
117
+ (u, t) => {
118
+ const s = f.value.findIndex(
119
+ (l, v) => n === v
120
120
  );
121
- if (!~c)
121
+ if (!~s)
122
122
  return;
123
- const e = s(
124
- i.value[c],
125
- c,
126
- u.rowKey
123
+ const e = c(
124
+ f.value[s],
125
+ s,
126
+ i.rowKey
127
127
  );
128
- if (e && !(!o[r] || !o[r][e])) {
129
- if (!l) {
130
- const f = Object.keys(o[r][e]);
131
- for (const v of f)
132
- v !== u.rowKey && delete o[r][e][v];
128
+ if (e && !(!u[t] || !u[t][e])) {
129
+ if (!r) {
130
+ const l = Object.keys(u[t][e]);
131
+ for (const v of l)
132
+ v !== i.rowKey && delete u[t][e][v];
133
+ }
134
+ Object.assign(u[t][e], { ...o });
135
+ }
136
+ }
137
+ );
138
+ }
139
+ function T(n, o, r = !0) {
140
+ y.value?.setFieldValue?.(
141
+ i.name,
142
+ void 0,
143
+ !0,
144
+ (u, t) => {
145
+ if (!(!u[t] || !u[t][n])) {
146
+ if (!r) {
147
+ const s = Object.keys(u[t][n]);
148
+ for (const e of s)
149
+ e !== i.rowKey && delete u[t][e][e];
133
150
  }
134
- Object.assign(o[r][e], { ...t });
151
+ Object.assign(u[t][n], { ...o });
135
152
  }
136
153
  }
137
154
  );
138
155
  }
139
- function T() {
140
- y.value?.setFieldValue?.(u.name, {}), g?.([]);
156
+ function _() {
157
+ y.value?.setFieldValue?.(i.name, {}), g?.([]);
141
158
  }
142
159
  return {
143
- add: F,
160
+ add: I,
144
161
  addMultiple: j,
145
- remove: k,
146
- removeByKey: B,
147
- getRowData: L,
148
- getRowsData: V,
149
- setRowData: a,
150
- clear: T,
162
+ remove: O,
163
+ removeByKey: k,
164
+ getRowData: B,
165
+ getRowsData: a,
166
+ setRowDataByKey: T,
167
+ setRowData: L,
168
+ clear: _,
151
169
  refreshRowIds: w,
152
- getRowDataByKey: O
170
+ getRowDataByKey: V
153
171
  };
154
172
  };
155
173
  export {
156
- Q as useEditableApi
174
+ W as useEditableApi
157
175
  };
@@ -10,6 +10,7 @@ export declare const useEditableFormItemApi: <RecordType>(props: EditableAgGridP
10
10
  removeByKey: (key: Key | Key[]) => void;
11
11
  getRowData: (index: number) => RecordType;
12
12
  getRowsData: () => RecordType[];
13
+ setRowDataByKey: (key: any, payload: any, merge?: boolean) => void;
13
14
  setRowData: (index: number, payload: any, merge?: boolean) => void;
14
15
  clear: () => void;
15
16
  refreshRowIds: ShallowRef<string[], string[]>;
@@ -1,187 +1,205 @@
1
- import { isFunction as V, isUndefined as R, isNumber as F, cloneDeep as $, isArray as I } from "lodash-unified";
2
- import { shallowRef as q, unref as h } from "vue";
1
+ import { isFunction as V, isUndefined as R, isNumber as F, cloneDeep as q, isArray as j } from "lodash-unified";
2
+ import { shallowRef as C, unref as h } from "vue";
3
3
  import "../../utils/index.mjs";
4
- import { getRowKey as y, arrayToObject as C } from "../editable/utils.mjs";
5
- import { isDef as j } from "../../utils/is.mjs";
6
- let G = 0;
7
- function k() {
8
- return `_ag_grid${G++}`;
4
+ import { getRowKey as y, arrayToObject as G } from "../editable/utils.mjs";
5
+ import { isDef as O } from "../../utils/is.mjs";
6
+ let H = 0;
7
+ function B() {
8
+ return `_ag_grid${H++}`;
9
9
  }
10
- const X = (f, c, u, w) => {
11
- const d = q([]);
12
- function B(i, l) {
13
- const v = h(u)?.length || 0;
14
- if (j(f.maxLength) && v >= f.maxLength || !i && V(f.rowKey))
10
+ const Y = (l, r, i, w) => {
11
+ const d = C([]);
12
+ function I(u, t) {
13
+ const v = h(i)?.length || 0;
14
+ if (O(l.maxLength) && v >= l.maxLength || !u && V(l.rowKey))
15
15
  return;
16
- const t = {
17
- ...i || { [f.rowKey]: k() }
16
+ const n = {
17
+ ...u || { [l.rowKey]: B() }
18
18
  };
19
- c?.setFieldValue(
19
+ r?.setFieldValue(
20
20
  w,
21
- t,
21
+ n,
22
22
  !1,
23
- (o, s) => {
24
- const e = y(t, void 0, f.rowKey);
25
- o[s] ? o[s][e] = t : o[s] = { [e]: t }, u.value ? R(l) ? u.value.push(t) : (d.value = u.value.map(
26
- (n, r) => r < l ? null : y(n, r, f.rowKey)
27
- ).filter(Boolean), u.value.splice(l, 0, t)) : u.value = [t], c?.setFieldValue(
28
- f.name,
29
- t,
23
+ (s, o) => {
24
+ const e = y(n, void 0, l.rowKey);
25
+ s[o] ? s[o][e] = n : s[o] = { [e]: n }, i.value ? R(t) ? i.value.push(n) : (d.value = i.value.map(
26
+ (f, c) => c < t ? null : y(f, c, l.rowKey)
27
+ ).filter(Boolean), i.value.splice(t, 0, n)) : i.value = [n], r?.setFieldValue(
28
+ l.name,
29
+ n,
30
30
  !0,
31
- (n, r) => {
32
- if (!n[r]) {
33
- n[r] = [t];
31
+ (f, c) => {
32
+ if (!f[c]) {
33
+ f[c] = [n];
34
34
  return;
35
35
  }
36
- R(l) ? n[r].push(t) : n[r].splice(l, 0, t);
36
+ R(t) ? f[c].push(n) : f[c].splice(t, 0, n);
37
37
  }
38
38
  );
39
39
  }
40
40
  );
41
41
  }
42
- function x(i, l = "suffix", v = !1) {
43
- if (!i)
42
+ function x(u, t = "suffix", v = !1) {
43
+ if (!u)
44
44
  return;
45
- const t = h(u)?.length || 0, o = F(i) ? i : i.length;
46
- if (j(f.maxLength) && t + o > f.maxLength || F(i) && V(f.rowKey))
45
+ const n = h(i)?.length || 0, s = F(u) ? u : u.length;
46
+ if (O(l.maxLength) && n + s > l.maxLength || F(u) && V(l.rowKey))
47
47
  return;
48
- const s = F(i) ? new Array(i).fill(0).map(() => ({ [f.rowKey]: k() })) : $(i), e = C(s, f.rowKey);
49
- c?.setFieldValue(
48
+ const o = F(u) ? new Array(u).fill(0).map(() => ({ [l.rowKey]: B() })) : q(u), e = G(o, l.rowKey);
49
+ r?.setFieldValue(
50
50
  w,
51
51
  e,
52
52
  !1,
53
- (n, r) => {
54
- n[r] ? Object.assign(n[r], e) : n[r] = e, u.value ? l === "suffix" ? u.value.push(...s) : (d.value = u.value.map(
55
- (g, K) => y(g, K, f.rowKey)
56
- ), u.value.unshift(...s)) : u.value = [...s], c?.setFieldValue(
57
- f.name,
58
- s,
53
+ (f, c) => {
54
+ f[c] ? Object.assign(f[c], e) : f[c] = e, i.value ? t === "suffix" ? i.value.push(...o) : (d.value = i.value.map(
55
+ (K, g) => y(K, g, l.rowKey)
56
+ ), i.value.unshift(...o)) : i.value = [...o], r?.setFieldValue(
57
+ l.name,
58
+ o,
59
59
  !0,
60
- (g, K) => {
61
- if (!g[K] || v) {
62
- g[K] = [...s];
60
+ (K, g) => {
61
+ if (!K[g] || v) {
62
+ K[g] = [...o];
63
63
  return;
64
64
  }
65
- l === "suffix" ? g[K].push(...s) : g[K].unshift(...s);
65
+ t === "suffix" ? K[g].push(...o) : K[g].unshift(...o);
66
66
  }
67
67
  );
68
68
  }
69
69
  );
70
70
  }
71
- function L(i, l = "suffix") {
72
- x(i, l, !1);
71
+ function _(u, t = "suffix") {
72
+ x(u, t, !1);
73
73
  }
74
- function O(i) {
75
- const l = I(i) ? i : [i];
76
- c?.setFieldValue(
74
+ function k(u) {
75
+ const t = j(u) ? u : [u];
76
+ r?.setFieldValue(
77
77
  w,
78
78
  void 0,
79
79
  !1,
80
- (v, t) => {
81
- for (const e of l) {
82
- const n = y(e, void 0, f.rowKey);
83
- delete v[t][n];
80
+ (v, n) => {
81
+ for (const e of t) {
82
+ const f = y(e, void 0, l.rowKey);
83
+ delete v[n][f];
84
84
  }
85
- const o = u.value.filter(
86
- (e) => !l.includes(e)
87
- ), s = u.value.findIndex(
88
- (e) => l.includes(e)
85
+ const s = i.value.filter(
86
+ (e) => !t.includes(e)
87
+ ), o = i.value.findIndex(
88
+ (e) => t.includes(e)
89
89
  );
90
- d.value = u.value.map(
91
- (e, n) => n <= s ? null : y(e, n, f.rowKey)
92
- ).filter(Boolean), o.length ? u.value = o : u.value.splice(0, u.value.length), c.setFieldValue(
93
- f.name,
90
+ d.value = i.value.map(
91
+ (e, f) => f <= o ? null : y(e, f, l.rowKey)
92
+ ).filter(Boolean), s.length ? i.value = s : i.value.splice(0, i.value.length), r.setFieldValue(
93
+ l.name,
94
94
  void 0,
95
95
  !0,
96
- (e, n) => {
97
- e[n] = [...o];
96
+ (e, f) => {
97
+ e[f] = [...s];
98
98
  }
99
99
  );
100
100
  }
101
101
  );
102
102
  }
103
- function T(i) {
104
- const l = new Set(I(i) ? i : [i]);
105
- l.size !== 0 && c?.setFieldValue(
103
+ function L(u) {
104
+ const t = new Set(j(u) ? u : [u]);
105
+ t.size !== 0 && r?.setFieldValue(
106
106
  w,
107
107
  void 0,
108
108
  !1,
109
- (v, t) => {
110
- for (const e of l)
111
- delete v[t][e];
112
- const o = u.value.filter(
113
- (e, n) => !l.has(y(e, n, f.rowKey))
114
- ), s = u.value.findIndex(
115
- (e, n) => l.has(y(e, n, f.rowKey))
109
+ (v, n) => {
110
+ for (const e of t)
111
+ delete v[n][e];
112
+ const s = i.value.filter(
113
+ (e, f) => !t.has(y(e, f, l.rowKey))
114
+ ), o = i.value.findIndex(
115
+ (e, f) => t.has(y(e, f, l.rowKey))
116
116
  );
117
- d.value = u.value.map(
118
- (e, n) => n <= s ? null : y(e, n, f.rowKey)
119
- ).filter(Boolean), o.length ? u.value = o : u.value.splice(0, u.value.length), c.setFieldValue(
120
- f.name,
117
+ d.value = i.value.map(
118
+ (e, f) => f <= o ? null : y(e, f, l.rowKey)
119
+ ).filter(Boolean), s.length ? i.value = s : i.value.splice(0, i.value.length), r.setFieldValue(
120
+ l.name,
121
121
  void 0,
122
122
  !0,
123
- (e, n) => {
124
- e[n] = [...o];
123
+ (e, f) => {
124
+ e[f] = [...s];
125
125
  }
126
126
  );
127
127
  }
128
128
  );
129
129
  }
130
- function _(i) {
131
- return h(u)?.[i];
130
+ function T(u) {
131
+ return h(i)?.[u];
132
132
  }
133
- function z(i) {
134
- return u.value?.find(
135
- (l, v) => y(l, v, f.rowKey) === i
133
+ function z(u) {
134
+ return i.value?.find(
135
+ (t, v) => y(t, v, l.rowKey) === u
136
136
  );
137
137
  }
138
138
  function E() {
139
- return h(u);
139
+ return h(i);
140
140
  }
141
- function S(i, l, v = !0) {
142
- c?.setFieldValue?.(
141
+ function S(u, t, v = !0) {
142
+ r?.setFieldValue?.(
143
143
  w,
144
144
  void 0,
145
145
  !1,
146
- (t, o) => {
147
- const s = u.value.findIndex(
148
- (n, r) => i === r
146
+ (n, s) => {
147
+ const o = i.value.findIndex(
148
+ (f, c) => u === c
149
149
  );
150
- if (!~s)
150
+ if (!~o)
151
151
  return;
152
152
  const e = y(
153
- u.value[s],
154
- s,
155
- f.rowKey
153
+ i.value[o],
154
+ o,
155
+ l.rowKey
156
156
  );
157
- if (e && !(!t[o] || !t[o][e])) {
157
+ if (e && !(!n[s] || !n[s][e])) {
158
158
  if (!v) {
159
- const n = Object.keys(t[o][e]);
160
- for (const r of n)
161
- r !== f.rowKey && delete t[o][e][r];
159
+ const f = Object.keys(n[s][e]);
160
+ for (const c of f)
161
+ c !== l.rowKey && delete n[s][e][c];
162
162
  }
163
- Object.assign(t[o][e], { ...l });
163
+ Object.assign(n[s][e], { ...t });
164
164
  }
165
165
  }
166
166
  );
167
167
  }
168
- function U() {
169
- c?.setFieldValue(w, {}), c?.setFieldValue(f.name, []);
168
+ function U(u, t, v = !0) {
169
+ r?.setFieldValue?.(
170
+ w,
171
+ void 0,
172
+ !1,
173
+ (n, s) => {
174
+ if (!(!n[s] || !n[s][u])) {
175
+ if (!v) {
176
+ const o = Object.keys(n[s][u]);
177
+ for (const e of o)
178
+ e !== l.rowKey && delete n[s][u][e];
179
+ }
180
+ Object.assign(n[s][u], { ...t });
181
+ }
182
+ }
183
+ );
184
+ }
185
+ function $() {
186
+ r?.setFieldValue(w, {}), r?.setFieldValue(l.name, []);
170
187
  }
171
188
  return {
172
- add: B,
173
- addMultiple: L,
189
+ add: I,
190
+ addMultiple: _,
174
191
  __addMultiple: x,
175
- remove: O,
176
- removeByKey: T,
177
- getRowData: _,
192
+ remove: k,
193
+ removeByKey: L,
194
+ getRowData: T,
178
195
  getRowsData: E,
196
+ setRowDataByKey: U,
179
197
  setRowData: S,
180
- clear: U,
198
+ clear: $,
181
199
  refreshRowIds: d,
182
200
  getRowDataByKey: z
183
201
  };
184
202
  };
185
203
  export {
186
- X as useEditableFormItemApi
204
+ Y as useEditableFormItemApi
187
205
  };
@@ -1,2 +1,2 @@
1
- declare const _default: "7.19.6";
1
+ declare const _default: "7.19.7";
2
2
  export default _default;
@@ -1,4 +1,4 @@
1
- const e = "7.19.6";
1
+ const e = "7.19.7";
2
2
  export {
3
3
  e as default
4
4
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const o=require("vue"),i=require("lodash-unified"),y=require("../../ap-form/index.js"),k=require("../../ap-form/context.js"),A=require("../../ap-form/hooks/use-watch.js"),z=require("../../ap-form/utils/get.js"),H=require("../../ap-form/utils/transform.js");require("../../config-provider/index.js");const L=require("../hooks/use-editable-columns.js"),G=require("../hooks/use-editable-form-item-api.js");require("../index.vue2.js");const U=require("../style/editable.js"),W=require("../utils.js"),c=require("./utils.js"),$=require("../../config-provider/hooks/use-namespace.js"),J=require("../../config-provider/hooks/use-global-config.js"),Q=require("../index.vue.js"),X=o.defineComponent({name:"EditableGrid",__name:"form-item",props:{dropdownPrefixCls:{},bordered:{type:Boolean},locale:{},onResizeColumn:{},getPopupContainer:{},scroll:{},sortDirections:{},showSorterTooltip:{type:[Boolean,Object]},prefixCls:{},rowKey:{type:[String,Function],default:"key"},tableLayout:{},title:{},id:{},showHeader:{type:Boolean},components:{},customHeaderRow:{},direction:{},expandFixed:{type:[String,Boolean]},expandColumnWidth:{},expandedRowKeys:{},defaultExpandedRowKeys:{},expandedRowRender:{},expandRowByClick:{type:Boolean},expandIcon:{},onExpand:{},onExpandedRowsChange:{},defaultExpandAllRows:{type:Boolean},indentSize:{},expandIconColumnIndex:{},showExpandColumn:{type:Boolean},expandedRowClassName:{},childrenColumnName:{},rowExpandable:{},transformCellText:{},rowHoverable:{type:Boolean},rowSelection:{type:[Boolean,Object]},onLoadingChange:{},onShownColumnsChange:{},pagination:{type:[Boolean,Object],default:!1},searchFormWrapperStyle:{},tableWrapperStyle:{},wrapperStyle:{},tableStyle:{},adaptive:{type:Boolean},columnResizable:{type:Boolean,default:!1},loading:{type:Boolean,default:void 0},summary:{},rowHeight:{default:66},getRowHeight:{},advanceRenderer:{type:Boolean},browserTooltips:{type:Boolean},virtual:{type:[Boolean,Object],default:void 0},onRowClicked:{},onScrollEnd:{},rowClassName:{},rowClassRules:{},autoHeight:{type:Boolean},onUpdate:{},customRow:{},theme:{},emptyComponent:{},emptyText:{},onColumnResized:{},animateRows:{type:Boolean},plugins:{},columns:{},defaultValue:{},onChange:{},maxLength:{},onFieldChange:{},supressForceRowUpdate:{type:Boolean,default:!1},label:{},name:{},formItem:{}},setup(h,{expose:b}){const C=o.useSlots(),n=h,{b:R}=$.useNamespace("editable-aggrid"),v=U.default("editable-aggrid"),d=o.ref(),{internalInstance:l}=k.useInjectForm();function B(e){const t=c.getColumnTransformOptions(n.columns||[]);if(!Object.keys(t).length||!e?.length)return e;let a=[];for(const u of e)a.push(H.transformValues(u,t));return a}const s=W.getShadowName(n.name);let f=[];o.onMounted(()=>{const e=n.formItem?.initialValue??z.getModelValue(l?.getInitialValues()??{},n.name);e&&(l?.updateInitialModel(s,c.arrayToObject(i.cloneDeep(e),n.rowKey)),f=i.cloneDeep(e),r.value||_(i.cloneDeep(e),"suffix",!0))});const r=o.ref([]),x=A.useWatch(n.name);o.watch(()=>x.value,e=>{i.isEqual(e,r.value)||g(e??i.cloneDeep(f))},{deep:!0,flush:"post",immediate:!0});const S=J.useGlobalConfig("valueTypeMap"),q=L.useGetEditableColumns(n,S,s),{add:F,addMultiple:I,__addMultiple:_,remove:T,removeByKey:E,getRowData:N,getRowsData:V,setRowData:j,clear:D,refreshRowIds:m}=G.useEditableFormItemApi(n,l,r,s);function O(){const e=d.value?._internalGridApi;if(!m.value?.length||!e)return;const t=m.value.map(a=>e.getRowNode(a)).filter(a=>!!a);n.supressForceRowUpdate||e.refreshCells({rowNodes:t,force:!0}),m.value=[]}function g(e){r.value=[...e];const t=c.arrayToObject(e,n.rowKey);l?.setFieldValue(n.name,[...e]),l?.setFieldValue(s,t)}function w(e,t){const a=e==="end"?r.value.length-1:e;d.value?.scrollToRow(a,t)}function K(e,t){d.value?.scrollToColumn(e,t)}function M(e,t){const a=[s,String(e),t].flat();return l?.validateFields([a])}function P(e){const a=o.unref(r).map((u,p)=>[s,String(c.getRowKey(u,p,n.rowKey)),e].flat());return l?.validateFields(a)}return b({add:F,addMultiple:I,remove:T,removeByKey:E,getRowData:N,getRowsData:V,setRowData:j,clear:D,setTableData:g,scrollTo:w,scrollToRow:w,scrollToColumn:K,validateCell:M,validateColumn:P,table:d}),(e,t)=>(o.openBlock(),o.createElementBlock(o.Fragment,null,[o.createVNode(o.unref(y.ApForm).FormItem,{hidden:"",name:e.name,"initial-value":e.formItem?.initialValue,transform:B},null,8,["name","initial-value"]),o.createVNode(o.unref(y.ApForm).FormItem,o.mergeProps({label:e.label},e.formItem),{default:o.withCtx(()=>[o.createVNode(Q.default,o.mergeProps(o.unref(i.omit)(n,["name","maxLength","onChange","defaultValue","formItem"]),{ref_key:"tableRef",ref:d,class:[o.unref(R)(),o.unref(v)],size:"mini",columns:o.unref(q),"data-source":r.value,"search-form":!1,onUpdate:O}),o.createSlots({_:2},[o.renderList(C,(a,u)=>({name:u,fn:o.withCtx(p=>[o.renderSlot(e.$slots,u,o.normalizeProps(o.guardReactiveProps(p||{})))])}))]),1040,["class","columns","data-source"])]),_:3},16,["label"])],64))}});exports.default=X;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const o=require("vue"),i=require("lodash-unified"),y=require("../../ap-form/index.js"),z=require("../../ap-form/context.js"),H=require("../../ap-form/hooks/use-watch.js"),L=require("../../ap-form/utils/get.js"),G=require("../../ap-form/utils/transform.js");require("../../config-provider/index.js");const U=require("../hooks/use-editable-columns.js"),W=require("../hooks/use-editable-form-item-api.js");require("../index.vue2.js");const $=require("../style/editable.js"),J=require("../utils.js"),c=require("./utils.js"),Q=require("../../config-provider/hooks/use-namespace.js"),X=require("../../config-provider/hooks/use-global-config.js"),Y=require("../index.vue.js"),Z=o.defineComponent({name:"EditableGrid",__name:"form-item",props:{dropdownPrefixCls:{},bordered:{type:Boolean},locale:{},onResizeColumn:{},getPopupContainer:{},scroll:{},sortDirections:{},showSorterTooltip:{type:[Boolean,Object]},prefixCls:{},rowKey:{type:[String,Function],default:"key"},tableLayout:{},title:{},id:{},showHeader:{type:Boolean},components:{},customHeaderRow:{},direction:{},expandFixed:{type:[String,Boolean]},expandColumnWidth:{},expandedRowKeys:{},defaultExpandedRowKeys:{},expandedRowRender:{},expandRowByClick:{type:Boolean},expandIcon:{},onExpand:{},onExpandedRowsChange:{},defaultExpandAllRows:{type:Boolean},indentSize:{},expandIconColumnIndex:{},showExpandColumn:{type:Boolean},expandedRowClassName:{},childrenColumnName:{},rowExpandable:{},transformCellText:{},rowHoverable:{type:Boolean},rowSelection:{type:[Boolean,Object]},onLoadingChange:{},onShownColumnsChange:{},pagination:{type:[Boolean,Object],default:!1},searchFormWrapperStyle:{},tableWrapperStyle:{},wrapperStyle:{},tableStyle:{},adaptive:{type:Boolean},columnResizable:{type:Boolean,default:!1},loading:{type:Boolean,default:void 0},summary:{},rowHeight:{default:66},getRowHeight:{},advanceRenderer:{type:Boolean},browserTooltips:{type:Boolean},virtual:{type:[Boolean,Object],default:void 0},onRowClicked:{},onScrollEnd:{},rowClassName:{},rowClassRules:{},autoHeight:{type:Boolean},onUpdate:{},customRow:{},theme:{},emptyComponent:{},emptyText:{},onColumnResized:{},animateRows:{type:Boolean},plugins:{},columns:{},defaultValue:{},onChange:{},maxLength:{},onFieldChange:{},supressForceRowUpdate:{type:Boolean,default:!1},label:{},name:{},formItem:{}},setup(h,{expose:b}){const C=o.useSlots(),a=h,{b:R}=Q.useNamespace("editable-aggrid"),v=$.default("editable-aggrid"),d=o.ref(),{internalInstance:l}=z.useInjectForm();function B(e){const t=c.getColumnTransformOptions(a.columns||[]);if(!Object.keys(t).length||!e?.length)return e;let n=[];for(const u of e)n.push(G.transformValues(u,t));return n}const s=J.getShadowName(a.name);let f=[];o.onMounted(()=>{const e=a.formItem?.initialValue??L.getModelValue(l?.getInitialValues()??{},a.name);e&&(l?.updateInitialModel(s,c.arrayToObject(i.cloneDeep(e),a.rowKey)),f=i.cloneDeep(e),r.value||_(i.cloneDeep(e),"suffix",!0))});const r=o.ref([]),x=H.useWatch(a.name);o.watch(()=>x.value,e=>{i.isEqual(e,r.value)||w(e??i.cloneDeep(f))},{deep:!0,flush:"post",immediate:!0});const S=X.useGlobalConfig("valueTypeMap"),q=U.useGetEditableColumns(a,S,s),{add:F,addMultiple:I,__addMultiple:_,remove:T,removeByKey:E,getRowData:N,getRowsData:V,getRowDataByKey:D,setRowData:j,setRowDataByKey:K,clear:O,refreshRowIds:m}=W.useEditableFormItemApi(a,l,r,s);function M(){const e=d.value?._internalGridApi;if(!m.value?.length||!e)return;const t=m.value.map(n=>e.getRowNode(n)).filter(n=>!!n);a.supressForceRowUpdate||e.refreshCells({rowNodes:t,force:!0}),m.value=[]}function w(e){r.value=[...e];const t=c.arrayToObject(e,a.rowKey);l?.setFieldValue(a.name,[...e]),l?.setFieldValue(s,t)}function g(e,t){const n=e==="end"?r.value.length-1:e;d.value?.scrollToRow(n,t)}function P(e,t){d.value?.scrollToColumn(e,t)}function k(e,t){const n=[s,String(e),t].flat();return l?.validateFields([n])}function A(e){const n=o.unref(r).map((u,p)=>[s,String(c.getRowKey(u,p,a.rowKey)),e].flat());return l?.validateFields(n)}return b({add:F,addMultiple:I,remove:T,removeByKey:E,getRowData:N,getRowsData:V,getRowDataByKey:D,setRowData:j,clear:O,setTableData:w,scrollTo:g,scrollToRow:g,scrollToColumn:P,validateCell:k,validateColumn:A,setRowDataByKey:K,table:d}),(e,t)=>(o.openBlock(),o.createElementBlock(o.Fragment,null,[o.createVNode(o.unref(y.ApForm).FormItem,{hidden:"",name:e.name,"initial-value":e.formItem?.initialValue,transform:B},null,8,["name","initial-value"]),o.createVNode(o.unref(y.ApForm).FormItem,o.mergeProps({label:e.label},e.formItem),{default:o.withCtx(()=>[o.createVNode(Y.default,o.mergeProps(o.unref(i.omit)(a,["name","maxLength","onChange","defaultValue","formItem"]),{ref_key:"tableRef",ref:d,class:[o.unref(R)(),o.unref(v)],size:"mini",columns:o.unref(q),"data-source":r.value,"search-form":!1,onUpdate:M}),o.createSlots({_:2},[o.renderList(C,(n,u)=>({name:u,fn:o.withCtx(p=>[o.renderSlot(e.$slots,u,o.normalizeProps(o.guardReactiveProps(p||{})))])}))]),1040,["class","columns","data-source"])]),_:3},16,["label"])],64))}});exports.default=Z;
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const o=require("vue"),i=require("lodash-unified"),m=require("../../ap-form/index.js");require("../../config-provider/index.js");require("../../hooks/index.js");const P=require("../hooks/use-editable-api.js"),G=require("../hooks/use-editable-columns.js");require("../index.vue2.js");const L=require("../style/editable.js"),d=require("./utils.js"),M=require("../../config-provider/hooks/use-namespace.js"),W=require("../../hooks/useControllableValue.js"),$=require("../../config-provider/hooks/use-global-config.js"),J=require("../index.vue.js"),Q=o.defineComponent({name:"EditableGrid",__name:"index",props:{dropdownPrefixCls:{},bordered:{type:Boolean},locale:{},onResizeColumn:{},getPopupContainer:{},scroll:{},sortDirections:{},showSorterTooltip:{type:[Boolean,Object]},prefixCls:{},rowKey:{type:[String,Function],default:"key"},tableLayout:{},title:{},id:{},showHeader:{type:Boolean},components:{},customHeaderRow:{},direction:{},expandFixed:{type:[String,Boolean]},expandColumnWidth:{},expandedRowKeys:{},defaultExpandedRowKeys:{},expandedRowRender:{},expandRowByClick:{type:Boolean},expandIcon:{},onExpand:{},onExpandedRowsChange:{},defaultExpandAllRows:{type:Boolean},indentSize:{},expandIconColumnIndex:{},showExpandColumn:{type:Boolean},expandedRowClassName:{},childrenColumnName:{},rowExpandable:{},transformCellText:{},rowHoverable:{type:Boolean},rowSelection:{type:[Boolean,Object]},onLoadingChange:{},onShownColumnsChange:{},pagination:{type:[Boolean,Object],default:!1},searchFormWrapperStyle:{},tableWrapperStyle:{},wrapperStyle:{},tableStyle:{},adaptive:{type:Boolean},columnResizable:{type:Boolean,default:!1},loading:{type:Boolean,default:void 0},summary:{},rowHeight:{default:66},getRowHeight:{},advanceRenderer:{type:Boolean},browserTooltips:{type:Boolean},virtual:{type:[Boolean,Object],default:void 0},onRowClicked:{},onScrollEnd:{},rowClassName:{},rowClassRules:{},autoHeight:{type:Boolean},onUpdate:{},customRow:{},theme:{},emptyComponent:{},emptyText:{},onColumnResized:{},animateRows:{type:Boolean},plugins:{},columns:{},value:{},defaultValue:{},"onUpdate:value":{},onChange:{},maxLength:{},name:{default:"ap-editable-table-inner-name"},onFieldChange:{},supressForceRowUpdate:{type:Boolean,default:!1}},emits:["update:value"],setup(v,{expose:h,emit:R}){const C=o.useSlots(),t=v,{b:x}=M.useNamespace("editable-aggrid"),B=L.default("editable-aggrid"),T=R,u=o.ref(),{value:s,updateValue:y}=W.useControllableValue(t,T),l=o.ref(),_=m.ApForm.useWatch(t.name,l);o.watch(s,e=>{const a=d.arrayToObject(e,t.rowKey);i.isEqual(a,o.unref(_))||l.value?.setFieldValue(t.name,a)},{deep:!0});const F=$.useGlobalConfig("valueTypeMap"),S=G.useGetEditableColumns(t,F),{add:q,addMultiple:A,remove:E,removeByKey:j,getRowData:N,getRowsData:K,setRowData:V,clear:k,refreshRowIds:c}=P.useEditableApi(t,l,s,y);function O(){const e=u.value?._internalGridApi;if(!c.value?.length||!e)return;const a=c.value.map(n=>e.getRowNode(n)).filter(n=>!!n);t.supressForceRowUpdate||e.refreshCells({rowNodes:a,force:!0}),c.value=[]}function I(){l.value?.resetFields()}function w(e){return e?(i.isArray(e)?e:[e]).map(n=>i.isArray(n)?[t.name,...n]:[t.name,n]):void 0}function b(e){try{const a=Object.keys(e),n=s.value.map(r=>d.getRowKey(r,void 0,t.rowKey));return a.sort((r,p)=>n.findIndex(f=>String(f)===r)-n.findIndex(f=>String(f)===p)),a.map(r=>e[r])}catch{return e}}async function D(e,a){const r=(await l.value?.validateFields(w(e),a))?.[t.name];return b(r)}async function U(e,a){const r=(await l.value?.validateFieldsReturnTransformed(w(e),a))?.[t.name];return b(r)}function z(e){y(e);const a=d.arrayToObject(e,t.rowKey);l.value?.setFieldValue(t.name,a)}function g(e,a){const n=e==="end"?s.value.length-1:e;u.value?.scrollToRow(n,a)}function H(e,a){u.value?.scrollToColumn(e,a)}return h({resetFields:I,validateFields:D,validateFieldsReturnTransformed:U,add:q,addMultiple:A,remove:E,removeByKey:j,getRowData:N,getRowsData:K,setRowData:V,clear:k,setTableData:z,scrollTo:g,scrollToRow:g,scrollToColumn:H,table:u}),(e,a)=>(o.openBlock(),o.createBlock(o.unref(m.ApForm),{ref_key:"formRef",ref:l,"initial-values":{[t.name]:o.unref(d.arrayToObject)(o.unref(s),t.rowKey)},style:{height:"100%"}},{default:o.withCtx(()=>[o.createVNode(o.unref(m.ApForm).FormItem,{name:e.name,"no-style":""},{default:o.withCtx(()=>[o.createVNode(J.default,o.mergeProps(o.unref(i.omit)(t,["name","value","onUpdate:value","maxLength","onChange","defaultValue"]),{ref_key:"tableRef",ref:u,class:[o.unref(x)(),o.unref(B)],size:"mini",columns:o.unref(S),"data-source":o.unref(s),"search-form":!1,onUpdate:O}),o.createSlots({_:2},[o.renderList(C,(n,r)=>({name:r,fn:o.withCtx(p=>[o.renderSlot(e.$slots,r,o.normalizeProps(o.guardReactiveProps(p||{})))])}))]),1040,["class","columns","data-source"])]),_:3},8,["name"])]),_:3},8,["initial-values"]))}});exports.default=Q;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const a=require("vue"),i=require("lodash-unified"),m=require("../../ap-form/index.js");require("../../config-provider/index.js");require("../../hooks/index.js");const L=require("../hooks/use-editable-api.js"),M=require("../hooks/use-editable-columns.js");require("../index.vue2.js");const W=require("../style/editable.js"),d=require("./utils.js"),$=require("../../config-provider/hooks/use-namespace.js"),J=require("../../hooks/useControllableValue.js"),Q=require("../../config-provider/hooks/use-global-config.js"),X=require("../index.vue.js"),Y=a.defineComponent({name:"EditableGrid",__name:"index",props:{dropdownPrefixCls:{},bordered:{type:Boolean},locale:{},onResizeColumn:{},getPopupContainer:{},scroll:{},sortDirections:{},showSorterTooltip:{type:[Boolean,Object]},prefixCls:{},rowKey:{type:[String,Function],default:"key"},tableLayout:{},title:{},id:{},showHeader:{type:Boolean},components:{},customHeaderRow:{},direction:{},expandFixed:{type:[String,Boolean]},expandColumnWidth:{},expandedRowKeys:{},defaultExpandedRowKeys:{},expandedRowRender:{},expandRowByClick:{type:Boolean},expandIcon:{},onExpand:{},onExpandedRowsChange:{},defaultExpandAllRows:{type:Boolean},indentSize:{},expandIconColumnIndex:{},showExpandColumn:{type:Boolean},expandedRowClassName:{},childrenColumnName:{},rowExpandable:{},transformCellText:{},rowHoverable:{type:Boolean},rowSelection:{type:[Boolean,Object]},onLoadingChange:{},onShownColumnsChange:{},pagination:{type:[Boolean,Object],default:!1},searchFormWrapperStyle:{},tableWrapperStyle:{},wrapperStyle:{},tableStyle:{},adaptive:{type:Boolean},columnResizable:{type:Boolean,default:!1},loading:{type:Boolean,default:void 0},summary:{},rowHeight:{default:66},getRowHeight:{},advanceRenderer:{type:Boolean},browserTooltips:{type:Boolean},virtual:{type:[Boolean,Object],default:void 0},onRowClicked:{},onScrollEnd:{},rowClassName:{},rowClassRules:{},autoHeight:{type:Boolean},onUpdate:{},customRow:{},theme:{},emptyComponent:{},emptyText:{},onColumnResized:{},animateRows:{type:Boolean},plugins:{},columns:{},value:{},defaultValue:{},"onUpdate:value":{},onChange:{},maxLength:{},name:{default:"ap-editable-table-inner-name"},onFieldChange:{},supressForceRowUpdate:{type:Boolean,default:!1}},emits:["update:value"],setup(R,{expose:v,emit:h}){const C=a.useSlots(),t=R,{b:x}=$.useNamespace("editable-aggrid"),B=W.default("editable-aggrid"),T=h,u=a.ref(),{value:s,updateValue:y}=J.useControllableValue(t,T),l=a.ref(),_=m.ApForm.useWatch(t.name,l);a.watch(s,e=>{const o=d.arrayToObject(e,t.rowKey);i.isEqual(o,a.unref(_))||l.value?.setFieldValue(t.name,o)},{deep:!0});const F=Q.useGlobalConfig("valueTypeMap"),S=M.useGetEditableColumns(t,F),{add:q,addMultiple:A,remove:E,removeByKey:K,getRowData:j,getRowsData:N,getRowDataByKey:V,setRowData:k,setRowDataByKey:D,clear:O,refreshRowIds:c}=L.useEditableApi(t,l,s,y);function I(){const e=u.value?._internalGridApi;if(!c.value?.length||!e)return;const o=c.value.map(n=>e.getRowNode(n)).filter(n=>!!n);t.supressForceRowUpdate||e.refreshCells({rowNodes:o,force:!0}),c.value=[]}function U(){l.value?.resetFields()}function w(e){return e?(i.isArray(e)?e:[e]).map(n=>i.isArray(n)?[t.name,...n]:[t.name,n]):void 0}function g(e){try{const o=Object.keys(e),n=s.value.map(r=>d.getRowKey(r,void 0,t.rowKey));return o.sort((r,p)=>n.findIndex(f=>String(f)===r)-n.findIndex(f=>String(f)===p)),o.map(r=>e[r])}catch{return e}}async function z(e,o){const r=(await l.value?.validateFields(w(e),o))?.[t.name];return g(r)}async function H(e,o){const r=(await l.value?.validateFieldsReturnTransformed(w(e),o))?.[t.name];return g(r)}function P(e){y(e);const o=d.arrayToObject(e,t.rowKey);l.value?.setFieldValue(t.name,o)}function b(e,o){const n=e==="end"?s.value.length-1:e;u.value?.scrollToRow(n,o)}function G(e,o){u.value?.scrollToColumn(e,o)}return v({resetFields:U,validateFields:z,validateFieldsReturnTransformed:H,add:q,addMultiple:A,remove:E,removeByKey:K,getRowData:j,getRowsData:N,setRowData:k,clear:O,setTableData:P,scrollTo:b,scrollToRow:b,scrollToColumn:G,table:u,getRowDataByKey:V,setRowDataByKey:D}),(e,o)=>(a.openBlock(),a.createBlock(a.unref(m.ApForm),{ref_key:"formRef",ref:l,"initial-values":{[t.name]:a.unref(d.arrayToObject)(a.unref(s),t.rowKey)},style:{height:"100%"}},{default:a.withCtx(()=>[a.createVNode(a.unref(m.ApForm).FormItem,{name:e.name,"no-style":""},{default:a.withCtx(()=>[a.createVNode(X.default,a.mergeProps(a.unref(i.omit)(t,["name","value","onUpdate:value","maxLength","onChange","defaultValue"]),{ref_key:"tableRef",ref:u,class:[a.unref(x)(),a.unref(B)],size:"mini",columns:a.unref(S),"data-source":a.unref(s),"search-form":!1,onUpdate:I}),a.createSlots({_:2},[a.renderList(C,(n,r)=>({name:r,fn:a.withCtx(p=>[a.renderSlot(e.$slots,r,a.normalizeProps(a.guardReactiveProps(p||{})))])}))]),1040,["class","columns","data-source"])]),_:3},8,["name"])]),_:3},8,["initial-values"]))}});exports.default=Y;
@@ -95,6 +95,15 @@ export type EditableAgGridExpose<RecordType = any, ModelType = RecordType[]> = O
95
95
  remove: (data: RecordType | RecordType[]) => void;
96
96
  validateFieldsReturnTransformed: EditableTableExpose<ModelType, RecordType>['validateFields'];
97
97
  table: AgGridExpose;
98
+ getRowDataByKey: (key: string | number) => RecordType | undefined;
99
+ /**
100
+ * 设置表格行数据(通过行key)
101
+ * @param key
102
+ * @param data
103
+ * @param merge 是否进行数据的浅层合并(默认为true)
104
+ * @returns
105
+ */
106
+ setRowDataByKey: (key: any, data: Partial<RecordType>, merge?: boolean) => void;
98
107
  };
99
108
  export type EditableAgGridFormItemExpose<RecordType = any, ModelType = RecordType[]> = Omit<EditableAgGridExpose<RecordType, ModelType>, 'resetFields' | 'validateFields' | 'validateFieldsReturnTransformed'> & {
100
109
  /**
@@ -9,6 +9,7 @@ export declare const useEditableApi: <RecordType>(props: EditableAgGridProps<Rec
9
9
  removeByKey: (key: Key | Key[]) => void;
10
10
  getRowData: (index: number) => RecordType;
11
11
  getRowsData: () => RecordType[];
12
+ setRowDataByKey: (key: any, payload: any, merge?: boolean) => void;
12
13
  setRowData: (index: string | number, payload: any, merge?: boolean) => void;
13
14
  clear: () => void;
14
15
  refreshRowIds: ShallowRef<string[], string[]>;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const v=require("lodash-unified"),d=require("vue");require("../../utils/index.js");const V=require("../editable/utils.js"),m=require("../../utils/is.js");let S=0;function x(){return`_ag_grid${S++}`}const T=(u,K,i,h)=>{const g=d.shallowRef([]),w=d.computed(()=>d.isRef(K)?d.unref(K):K);function R(n,t){const l=d.unref(i)?.length||0;if(m.isDef(u.maxLength)&&l>=u.maxLength||!n&&v.isFunction(u.rowKey))return;const r={...n||{[u.rowKey]:x()}};w.value?.setFieldValue?.(u.name,r,!0,(o,s)=>{const e=c(r,void 0,u.rowKey);if(o[s]?o[s][e]=r:o[s]={[e]:r},!i.value){i.value=[r];return}v.isUndefined(t)?i.value.push(r):(g.value=i.value.map((f,y)=>y<t?null:c(f,y,u.rowKey)).filter(Boolean),i.value.splice(t,0,r))})}function a(n,t="suffix"){const l=d.unref(i)?.length||0,r=v.isNumber(n)?n:n.length;if(m.isDef(u.maxLength)&&l+r>u.maxLength||v.isNumber(n)&&v.isFunction(u.rowKey))return;const o=v.isNumber(n)?new Array(n).fill(0).map(()=>({[u.rowKey]:x()})):v.cloneDeep(n),s=V.arrayToObject(o,u.rowKey);w.value?.setFieldValue?.(u.name,o,!0,(e,f)=>{if(e[f]?Object.assign(e[f],s):e[f]=s,!i.value){i.value=[...o];return}t==="suffix"?i.value.push(...o):(g.value=i.value.map((y,L)=>c(y,L,u.rowKey)),i.value.unshift(...o))})}function F(n){const t=v.isArray(n)?n:[n];w.value?.setFieldValue?.(u.name,void 0,!0,(l,r)=>{for(const e of t){const f=c(e,void 0,u.rowKey);delete l[r][f]}const o=i.value.filter(e=>!t.includes(e)),s=i.value.findIndex(e=>t.includes(e));g.value=i.value.map((e,f)=>f<=s?null:c(e,f,u.rowKey)).filter(Boolean),h?.(o)})}function c(n,t,l){if(l)return v.isString(l)?n[l]:l(n,t)}function I(n){const t=new Set(v.isArray(n)?n:[n]);t.size!==0&&w.value?.setFieldValue?.(u.name,void 0,!0,(l,r)=>{for(const e of t)delete l[r][e];const o=i.value.filter((e,f)=>!t.has(c(e,f,u.rowKey))),s=i.value.findIndex((e,f)=>t.has(c(e,f,u.rowKey)));g.value=i.value.map((e,f)=>f<=s?null:c(e,f,u.rowKey)).filter(Boolean),h?.(o)})}function j(n){return d.unref(i)?.[n]}function O(n){return i.value?.find((t,l)=>c(t,l,u.rowKey)===n)}function k(){return d.unref(i)}function q(n,t,l=!0){w.value?.setFieldValue?.(u.name,void 0,!0,(r,o)=>{const s=i.value.findIndex((f,y)=>n===y);if(!~s)return;const e=c(i.value[s],s,u.rowKey);if(e&&!(!r[o]||!r[o][e])){if(!l){const f=Object.keys(r[o][e]);for(const y of f)y!==u.rowKey&&delete r[o][e][y]}Object.assign(r[o][e],{...t})}})}function B(){w.value?.setFieldValue?.(u.name,{}),h?.([])}return{add:R,addMultiple:a,remove:F,removeByKey:I,getRowData:j,getRowsData:k,setRowData:q,clear:B,refreshRowIds:g,getRowDataByKey:O}};exports.useEditableApi=T;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const v=require("lodash-unified"),w=require("vue");require("../../utils/index.js");const S=require("../editable/utils.js"),a=require("../../utils/is.js");let T=0;function m(){return`_ag_grid${T++}`}const A=(u,K,f,h)=>{const g=w.shallowRef([]),d=w.computed(()=>w.isRef(K)?w.unref(K):K);function x(n,r){const s=w.unref(f)?.length||0;if(a.isDef(u.maxLength)&&s>=u.maxLength||!n&&v.isFunction(u.rowKey))return;const i={...n||{[u.rowKey]:m()}};d.value?.setFieldValue?.(u.name,i,!0,(t,l)=>{const e=c(i,void 0,u.rowKey);if(t[l]?t[l][e]=i:t[l]={[e]:i},!f.value){f.value=[i];return}v.isUndefined(r)?f.value.push(i):(g.value=f.value.map((o,y)=>y<r?null:c(o,y,u.rowKey)).filter(Boolean),f.value.splice(r,0,i))})}function R(n,r="suffix"){const s=w.unref(f)?.length||0,i=v.isNumber(n)?n:n.length;if(a.isDef(u.maxLength)&&s+i>u.maxLength||v.isNumber(n)&&v.isFunction(u.rowKey))return;const t=v.isNumber(n)?new Array(n).fill(0).map(()=>({[u.rowKey]:m()})):v.cloneDeep(n),l=S.arrayToObject(t,u.rowKey);d.value?.setFieldValue?.(u.name,t,!0,(e,o)=>{if(e[o]?Object.assign(e[o],l):e[o]=l,!f.value){f.value=[...t];return}r==="suffix"?f.value.push(...t):(g.value=f.value.map((y,L)=>c(y,L,u.rowKey)),f.value.unshift(...t))})}function F(n){const r=v.isArray(n)?n:[n];d.value?.setFieldValue?.(u.name,void 0,!0,(s,i)=>{for(const e of r){const o=c(e,void 0,u.rowKey);delete s[i][o]}const t=f.value.filter(e=>!r.includes(e)),l=f.value.findIndex(e=>r.includes(e));g.value=f.value.map((e,o)=>o<=l?null:c(e,o,u.rowKey)).filter(Boolean),h?.(t)})}function c(n,r,s){if(s)return v.isString(s)?n[s]:s(n,r)}function j(n){const r=new Set(v.isArray(n)?n:[n]);r.size!==0&&d.value?.setFieldValue?.(u.name,void 0,!0,(s,i)=>{for(const e of r)delete s[i][e];const t=f.value.filter((e,o)=>!r.has(c(e,o,u.rowKey))),l=f.value.findIndex((e,o)=>r.has(c(e,o,u.rowKey)));g.value=f.value.map((e,o)=>o<=l?null:c(e,o,u.rowKey)).filter(Boolean),h?.(t)})}function I(n){return w.unref(f)?.[n]}function O(n){return f.value?.find((r,s)=>c(r,s,u.rowKey)===n)}function k(){return w.unref(f)}function B(n,r,s=!0){d.value?.setFieldValue?.(u.name,void 0,!0,(i,t)=>{const l=f.value.findIndex((o,y)=>n===y);if(!~l)return;const e=c(f.value[l],l,u.rowKey);if(e&&!(!i[t]||!i[t][e])){if(!s){const o=Object.keys(i[t][e]);for(const y of o)y!==u.rowKey&&delete i[t][e][y]}Object.assign(i[t][e],{...r})}})}function V(n,r,s=!0){d.value?.setFieldValue?.(u.name,void 0,!0,(i,t)=>{if(!(!i[t]||!i[t][n])){if(!s){const l=Object.keys(i[t][n]);for(const e of l)e!==u.rowKey&&delete i[t][e][e]}Object.assign(i[t][n],{...r})}})}function q(){d.value?.setFieldValue?.(u.name,{}),h?.([])}return{add:x,addMultiple:R,remove:F,removeByKey:j,getRowData:I,getRowsData:k,setRowDataByKey:V,setRowData:B,clear:q,refreshRowIds:g,getRowDataByKey:O}};exports.useEditableApi=A;
@@ -10,6 +10,7 @@ export declare const useEditableFormItemApi: <RecordType>(props: EditableAgGridP
10
10
  removeByKey: (key: Key | Key[]) => void;
11
11
  getRowData: (index: number) => RecordType;
12
12
  getRowsData: () => RecordType[];
13
+ setRowDataByKey: (key: any, payload: any, merge?: boolean) => void;
13
14
  setRowData: (index: number, payload: any, merge?: boolean) => void;
14
15
  clear: () => void;
15
16
  refreshRowIds: ShallowRef<string[], string[]>;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("lodash-unified"),R=require("vue");require("../../utils/index.js");const v=require("../editable/utils.js"),x=require("../../utils/is.js");let S=0;function V(){return`_ag_grid${S++}`}const U=(l,c,u,w)=>{const h=R.shallowRef([]);function I(i,t){const y=R.unref(u)?.length||0;if(x.isDef(l.maxLength)&&y>=l.maxLength||!i&&g.isFunction(l.rowKey))return;const f={...i||{[l.rowKey]:V()}};c?.setFieldValue(w,f,!1,(r,s)=>{const e=v.getRowKey(f,void 0,l.rowKey);r[s]?r[s][e]=f:r[s]={[e]:f},u.value?g.isUndefined(t)?u.value.push(f):(h.value=u.value.map((n,o)=>o<t?null:v.getRowKey(n,o,l.rowKey)).filter(Boolean),u.value.splice(t,0,f)):u.value=[f],c?.setFieldValue(l.name,f,!0,(n,o)=>{if(!n[o]){n[o]=[f];return}g.isUndefined(t)?n[o].push(f):n[o].splice(t,0,f)})})}function F(i,t="suffix",y=!1){if(!i)return;const f=R.unref(u)?.length||0,r=g.isNumber(i)?i:i.length;if(x.isDef(l.maxLength)&&f+r>l.maxLength||g.isNumber(i)&&g.isFunction(l.rowKey))return;const s=g.isNumber(i)?new Array(i).fill(0).map(()=>({[l.rowKey]:V()})):g.cloneDeep(i),e=v.arrayToObject(s,l.rowKey);c?.setFieldValue(w,e,!1,(n,o)=>{n[o]?Object.assign(n[o],e):n[o]=e,u.value?t==="suffix"?u.value.push(...s):(h.value=u.value.map((K,d)=>v.getRowKey(K,d,l.rowKey)),u.value.unshift(...s)):u.value=[...s],c?.setFieldValue(l.name,s,!0,(K,d)=>{if(!K[d]||y){K[d]=[...s];return}t==="suffix"?K[d].push(...s):K[d].unshift(...s)})})}function j(i,t="suffix"){F(i,t,!1)}function O(i){const t=g.isArray(i)?i:[i];c?.setFieldValue(w,void 0,!1,(y,f)=>{for(const e of t){const n=v.getRowKey(e,void 0,l.rowKey);delete y[f][n]}const r=u.value.filter(e=>!t.includes(e)),s=u.value.findIndex(e=>t.includes(e));h.value=u.value.map((e,n)=>n<=s?null:v.getRowKey(e,n,l.rowKey)).filter(Boolean),r.length?u.value=r:u.value.splice(0,u.value.length),c.setFieldValue(l.name,void 0,!0,(e,n)=>{e[n]=[...r]})})}function T(i){const t=new Set(g.isArray(i)?i:[i]);t.size!==0&&c?.setFieldValue(w,void 0,!1,(y,f)=>{for(const e of t)delete y[f][e];const r=u.value.filter((e,n)=>!t.has(v.getRowKey(e,n,l.rowKey))),s=u.value.findIndex((e,n)=>t.has(v.getRowKey(e,n,l.rowKey)));h.value=u.value.map((e,n)=>n<=s?null:v.getRowKey(e,n,l.rowKey)).filter(Boolean),r.length?u.value=r:u.value.splice(0,u.value.length),c.setFieldValue(l.name,void 0,!0,(e,n)=>{e[n]=[...r]})})}function k(i){return R.unref(u)?.[i]}function q(i){return u.value?.find((t,y)=>v.getRowKey(t,y,l.rowKey)===i)}function B(){return R.unref(u)}function L(i,t,y=!0){c?.setFieldValue?.(w,void 0,!1,(f,r)=>{const s=u.value.findIndex((n,o)=>i===o);if(!~s)return;const e=v.getRowKey(u.value[s],s,l.rowKey);if(e&&!(!f[r]||!f[r][e])){if(!y){const n=Object.keys(f[r][e]);for(const o of n)o!==l.rowKey&&delete f[r][e][o]}Object.assign(f[r][e],{...t})}})}function _(){c?.setFieldValue(w,{}),c?.setFieldValue(l.name,[])}return{add:I,addMultiple:j,__addMultiple:F,remove:O,removeByKey:T,getRowData:k,getRowsData:B,setRowData:L,clear:_,refreshRowIds:h,getRowDataByKey:q}};exports.useEditableFormItemApi=U;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("lodash-unified"),h=require("vue");require("../../utils/index.js");const v=require("../editable/utils.js"),V=require("../../utils/is.js");let U=0;function x(){return`_ag_grid${U++}`}const E=(f,y,i,w)=>{const R=h.shallowRef([]);function j(u,s){const c=h.unref(i)?.length||0;if(V.isDef(f.maxLength)&&c>=f.maxLength||!u&&g.isFunction(f.rowKey))return;const n={...u||{[f.rowKey]:x()}};y?.setFieldValue(w,n,!1,(l,o)=>{const e=v.getRowKey(n,void 0,f.rowKey);l[o]?l[o][e]=n:l[o]={[e]:n},i.value?g.isUndefined(s)?i.value.push(n):(R.value=i.value.map((t,r)=>r<s?null:v.getRowKey(t,r,f.rowKey)).filter(Boolean),i.value.splice(s,0,n)):i.value=[n],y?.setFieldValue(f.name,n,!0,(t,r)=>{if(!t[r]){t[r]=[n];return}g.isUndefined(s)?t[r].push(n):t[r].splice(s,0,n)})})}function F(u,s="suffix",c=!1){if(!u)return;const n=h.unref(i)?.length||0,l=g.isNumber(u)?u:u.length;if(V.isDef(f.maxLength)&&n+l>f.maxLength||g.isNumber(u)&&g.isFunction(f.rowKey))return;const o=g.isNumber(u)?new Array(u).fill(0).map(()=>({[f.rowKey]:x()})):g.cloneDeep(u),e=v.arrayToObject(o,f.rowKey);y?.setFieldValue(w,e,!1,(t,r)=>{t[r]?Object.assign(t[r],e):t[r]=e,i.value?s==="suffix"?i.value.push(...o):(R.value=i.value.map((K,d)=>v.getRowKey(K,d,f.rowKey)),i.value.unshift(...o)):i.value=[...o],y?.setFieldValue(f.name,o,!0,(K,d)=>{if(!K[d]||c){K[d]=[...o];return}s==="suffix"?K[d].push(...o):K[d].unshift(...o)})})}function O(u,s="suffix"){F(u,s,!1)}function I(u){const s=g.isArray(u)?u:[u];y?.setFieldValue(w,void 0,!1,(c,n)=>{for(const e of s){const t=v.getRowKey(e,void 0,f.rowKey);delete c[n][t]}const l=i.value.filter(e=>!s.includes(e)),o=i.value.findIndex(e=>s.includes(e));R.value=i.value.map((e,t)=>t<=o?null:v.getRowKey(e,t,f.rowKey)).filter(Boolean),l.length?i.value=l:i.value.splice(0,i.value.length),y.setFieldValue(f.name,void 0,!0,(e,t)=>{e[t]=[...l]})})}function B(u){const s=new Set(g.isArray(u)?u:[u]);s.size!==0&&y?.setFieldValue(w,void 0,!1,(c,n)=>{for(const e of s)delete c[n][e];const l=i.value.filter((e,t)=>!s.has(v.getRowKey(e,t,f.rowKey))),o=i.value.findIndex((e,t)=>s.has(v.getRowKey(e,t,f.rowKey)));R.value=i.value.map((e,t)=>t<=o?null:v.getRowKey(e,t,f.rowKey)).filter(Boolean),l.length?i.value=l:i.value.splice(0,i.value.length),y.setFieldValue(f.name,void 0,!0,(e,t)=>{e[t]=[...l]})})}function T(u){return h.unref(i)?.[u]}function _(u){return i.value?.find((s,c)=>v.getRowKey(s,c,f.rowKey)===u)}function k(){return h.unref(i)}function q(u,s,c=!0){y?.setFieldValue?.(w,void 0,!1,(n,l)=>{const o=i.value.findIndex((t,r)=>u===r);if(!~o)return;const e=v.getRowKey(i.value[o],o,f.rowKey);if(e&&!(!n[l]||!n[l][e])){if(!c){const t=Object.keys(n[l][e]);for(const r of t)r!==f.rowKey&&delete n[l][e][r]}Object.assign(n[l][e],{...s})}})}function L(u,s,c=!0){y?.setFieldValue?.(w,void 0,!1,(n,l)=>{if(!(!n[l]||!n[l][u])){if(!c){const o=Object.keys(n[l][u]);for(const e of o)e!==f.rowKey&&delete n[l][u][e]}Object.assign(n[l][u],{...s})}})}function S(){y?.setFieldValue(w,{}),y?.setFieldValue(f.name,[])}return{add:j,addMultiple:O,__addMultiple:F,remove:I,removeByKey:B,getRowData:T,getRowsData:k,setRowDataByKey:L,setRowData:q,clear:S,refreshRowIds:R,getRowDataByKey:_}};exports.useEditableFormItemApi=E;
@@ -1,2 +1,2 @@
1
- declare const _default: "7.19.6";
1
+ declare const _default: "7.19.7";
2
2
  export default _default;
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e="7.19.6";exports.default=e;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e="7.19.7";exports.default=e;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aplus-frontend/ui",
3
- "version": "7.19.6",
3
+ "version": "7.19.7",
4
4
  "main": "./lib/index.js",
5
5
  "type": "module",
6
6
  "typings": "./lib/index.d.ts",