react-toolkits 2.24.19 → 2.24.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/README.md +14 -0
  3. package/lib/chunk-3VI7KSDA.js +2 -0
  4. package/lib/{chunk-H5Y4DYUL.js.map → chunk-3VI7KSDA.js.map} +1 -1
  5. package/lib/chunk-3ZT3BOPJ.js +3 -0
  6. package/lib/chunk-3ZT3BOPJ.js.map +1 -0
  7. package/lib/{chunk-D75NVCYN.js → chunk-D5OM3OZU.js} +2 -2
  8. package/lib/{chunk-D75NVCYN.js.map → chunk-D5OM3OZU.js.map} +1 -1
  9. package/lib/chunk-F3OT6ENF.js +2 -0
  10. package/lib/{chunk-UPO7NB6O.js.map → chunk-F3OT6ENF.js.map} +1 -1
  11. package/lib/chunk-FD52RBG7.js +2 -0
  12. package/lib/{chunk-ZF7POJAA.js.map → chunk-FD52RBG7.js.map} +1 -1
  13. package/lib/{chunk-ST7VUWJ4.js → chunk-IWPBGSXS.js} +2 -2
  14. package/lib/{chunk-ST7VUWJ4.js.map → chunk-IWPBGSXS.js.map} +1 -1
  15. package/lib/chunk-S4LUEDFA.js +2 -0
  16. package/lib/{chunk-NNXVZIY2.js.map → chunk-S4LUEDFA.js.map} +1 -1
  17. package/lib/chunk-SMBHLRAO.js +2 -0
  18. package/lib/chunk-SMBHLRAO.js.map +1 -0
  19. package/lib/chunk-XX2BCZJU.js +2 -0
  20. package/lib/{chunk-MTRFNFEM.js.map → chunk-XX2BCZJU.js.map} +1 -1
  21. package/lib/{createMenuItem-SXFYDNCW.js → createMenuItem-5DDIEELO.js} +2 -2
  22. package/lib/{createMenuItem-SXFYDNCW.js.map → createMenuItem-5DDIEELO.js.map} +1 -1
  23. package/lib/index.css +1 -1
  24. package/lib/index.d.ts +9 -2
  25. package/lib/index.js +2 -2
  26. package/lib/index.js.map +1 -1
  27. package/lib/{menuItemList-NIBRDRTA.js → menuItemList-4ZLZ7HSG.js} +2 -2
  28. package/lib/{menuItemList-NIBRDRTA.js.map → menuItemList-4ZLZ7HSG.js.map} +1 -1
  29. package/lib/{roleDetail-7HEBW7IS.js → roleDetail-42BOHDFS.js} +2 -2
  30. package/lib/{roleDetail-7HEBW7IS.js.map → roleDetail-42BOHDFS.js.map} +1 -1
  31. package/lib/{roleList-WGLD3HXB.js → roleList-KWWO3IFL.js} +2 -2
  32. package/lib/{roleList-WGLD3HXB.js.map → roleList-KWWO3IFL.js.map} +1 -1
  33. package/lib/updateMenuItem-E5QMBR2S.js +2 -0
  34. package/lib/{updateMenuItem-TECCUD6Z.js.map → updateMenuItem-E5QMBR2S.js.map} +1 -1
  35. package/lib/userDetail-L7Q3C67K.js +2 -0
  36. package/lib/{userDetail-WGQJ7IC5.js.map → userDetail-L7Q3C67K.js.map} +1 -1
  37. package/lib/userList-IU4L5YRJ.js +2 -0
  38. package/lib/{userList-2S2FRAG6.js.map → userList-IU4L5YRJ.js.map} +1 -1
  39. package/locale/context.js +1 -7
  40. package/locale/context.js.map +1 -1
  41. package/locale/en_GB.js +1 -94
  42. package/locale/en_GB.js.map +1 -1
  43. package/locale/hooks.js +1 -18
  44. package/locale/hooks.js.map +1 -1
  45. package/locale/index.js +1 -2
  46. package/locale/ja_JP.js +1 -94
  47. package/locale/ja_JP.js.map +1 -1
  48. package/locale/ko_KR.js +1 -94
  49. package/locale/ko_KR.js.map +1 -1
  50. package/locale/zh_CN.js +1 -94
  51. package/locale/zh_CN.js.map +1 -1
  52. package/package.json +1 -1
  53. package/lib/chunk-7X2LW6EY.js +0 -73
  54. package/lib/chunk-7X2LW6EY.js.map +0 -1
  55. package/lib/chunk-DLTAWT6S.js +0 -2
  56. package/lib/chunk-DLTAWT6S.js.map +0 -1
  57. package/lib/chunk-E6L6VKSV.js +0 -227
  58. package/lib/chunk-E6L6VKSV.js.map +0 -1
  59. package/lib/chunk-ESCBNFWD.js +0 -498
  60. package/lib/chunk-ESCBNFWD.js.map +0 -1
  61. package/lib/chunk-FSXYUF4U.js +0 -276
  62. package/lib/chunk-FSXYUF4U.js.map +0 -1
  63. package/lib/chunk-H5Y4DYUL.js +0 -2
  64. package/lib/chunk-LXMQLSQY.js +0 -46
  65. package/lib/chunk-LXMQLSQY.js.map +0 -1
  66. package/lib/chunk-MTRFNFEM.js +0 -2
  67. package/lib/chunk-NNXVZIY2.js +0 -2
  68. package/lib/chunk-OH74GXG4.js +0 -570
  69. package/lib/chunk-OH74GXG4.js.map +0 -1
  70. package/lib/chunk-P25BHLH3.js +0 -3
  71. package/lib/chunk-P25BHLH3.js.map +0 -1
  72. package/lib/chunk-QACSRYJY.js +0 -147
  73. package/lib/chunk-QACSRYJY.js.map +0 -1
  74. package/lib/chunk-UPO7NB6O.js +0 -2
  75. package/lib/chunk-Z6PDWY44.js +0 -17
  76. package/lib/chunk-Z6PDWY44.js.map +0 -1
  77. package/lib/chunk-ZF7POJAA.js +0 -2
  78. package/lib/chunk-ZOHMJAAX.js +0 -120
  79. package/lib/chunk-ZOHMJAAX.js.map +0 -1
  80. package/lib/createMenuItem-CICLQWU6.js +0 -86
  81. package/lib/createMenuItem-CICLQWU6.js.map +0 -1
  82. package/lib/menuItemList-EHQSS4YZ.js +0 -132
  83. package/lib/menuItemList-EHQSS4YZ.js.map +0 -1
  84. package/lib/roleDetail-JCDOXKAM.js +0 -72
  85. package/lib/roleDetail-JCDOXKAM.js.map +0 -1
  86. package/lib/roleList-4C77ULPK.js +0 -161
  87. package/lib/roleList-4C77ULPK.js.map +0 -1
  88. package/lib/updateMenuItem-K62CKVXP.js +0 -109
  89. package/lib/updateMenuItem-K62CKVXP.js.map +0 -1
  90. package/lib/updateMenuItem-TECCUD6Z.js +0 -2
  91. package/lib/userDetail-WGQJ7IC5.js +0 -2
  92. package/lib/userDetail-WYN52ZJ2.js +0 -116
  93. package/lib/userDetail-WYN52ZJ2.js.map +0 -1
  94. package/lib/userList-2S2FRAG6.js +0 -2
  95. package/lib/userList-AMVG7RCE.js +0 -195
  96. package/lib/userList-AMVG7RCE.js.map +0 -1
@@ -1,498 +0,0 @@
1
- import { useTranslation } from './chunk-Z6PDWY44.js';
2
- import { useAuth } from './chunk-7X2LW6EY.js';
3
- import { __name, useKy } from './chunk-OH74GXG4.js';
4
- import { Form, Spin, Result, Table, theme, Space, Button } from 'antd';
5
- import { forwardRef, useMemo, useRef, useState, useEffect, useCallback, cloneElement, useImperativeHandle, Fragment } from 'react';
6
- import { jsx, jsxs, Fragment as Fragment$1 } from 'react/jsx-runtime';
7
- import { flushSync } from 'react-dom';
8
- import { createRoot } from 'react-dom/client';
9
- import { isEqual } from 'lodash-es';
10
- import { create } from 'zustand';
11
- import { devtools, subscribeWithSelector } from 'zustand/middleware';
12
- import { useQuery } from '@tanstack/react-query';
13
-
14
- var FilterFormWrapper = /* @__PURE__ */ __name((props) => {
15
- const { extras, isConfirming, onConfirm, onReset, children, buttonsAlign = "left", showReset } = props;
16
- const { t } = useTranslation();
17
- const {
18
- token: { colorFillAlter, lineWidth, lineType, colorBorder, borderRadiusLG }
19
- } = theme.useToken();
20
- const style = {
21
- maxWidth: "none",
22
- background: colorFillAlter,
23
- borderWidth: lineWidth,
24
- borderStyle: lineType,
25
- borderColor: colorBorder,
26
- borderRadius: borderRadiusLG,
27
- padding: 24,
28
- marginBottom: 24
29
- };
30
- return /* @__PURE__ */ jsx("div", { style, children: /* @__PURE__ */ jsxs("div", { className: `flex ${buttonsAlign === "bottom" ? "flex-col" : "flex-row"}`, children: [
31
- /* @__PURE__ */ jsx("div", { className: `${buttonsAlign === "left" ? "flex-grow-0" : "flex-1"}`, children }),
32
- /* @__PURE__ */ jsx("div", { className: `${buttonsAlign === "bottom" ? "text-end" : "text-start"} ml-4`, children: /* @__PURE__ */ jsxs(Space, { children: [
33
- /* @__PURE__ */ jsx(Button, { type: "primary", disabled: isConfirming, onClick: onConfirm, children: t("FilterFormWrapper.confirmText") }),
34
- extras?.map((item) => /* @__PURE__ */ jsx(Fragment, { children: item.children }, item.key)),
35
- showReset && /* @__PURE__ */ jsx(Button, { onClick: onReset, children: t("FilterFormWrapper.resetText") })
36
- ] }) })
37
- ] }) });
38
- }, "FilterFormWrapper");
39
- var FilterFormWrapper_default = FilterFormWrapper;
40
- var splitByTags = /* @__PURE__ */ __name((str) => {
41
- const regex = /(<[^>]*>)/;
42
- return str.split(regex).filter((part) => part !== "");
43
- }, "splitByTags");
44
- function renderToString(node) {
45
- const container = document.createElement("div");
46
- const root = createRoot(container);
47
- return new Promise((resolve) => {
48
- setTimeout(() => {
49
- flushSync(() => {
50
- root.render(node);
51
- });
52
- resolve(container.innerHTML);
53
- });
54
- });
55
- }
56
- __name(renderToString, "renderToString");
57
- var Highlight = /* @__PURE__ */ __name((props) => {
58
- const { texts, children } = props;
59
- const [htmlString, setHtmlString] = useState("");
60
- useEffect(() => {
61
- renderToString(children).then((str) => {
62
- const result = splitByTags(str);
63
- for (const text of texts) {
64
- for (let index = 0; index < result.length; index++) {
65
- result[index] = result[index].replace(String(text), `<span style='color: #DC143C;'>${text}</span>`);
66
- }
67
- }
68
- setHtmlString(result.join(""));
69
- });
70
- }, [children, texts]);
71
- return /* @__PURE__ */ jsx("div", { dangerouslySetInnerHTML: { __html: htmlString } });
72
- }, "Highlight");
73
- var Highlight_default = Highlight;
74
- var DEFAULT_PAYLOAD = Object.freeze({
75
- page: 1,
76
- size: 10,
77
- filters: Object.freeze({})
78
- });
79
- var createStore = /* @__PURE__ */ __name(() => create()(
80
- devtools(
81
- subscribeWithSelector((set, get) => ({
82
- instances: /* @__PURE__ */ new Map(),
83
- registerInstance(id, url, queryKey, refetch) {
84
- set((state) => {
85
- const existingInstance = state.instances.get(id);
86
- if (existingInstance) {
87
- if (existingInstance.refetch !== refetch) {
88
- const updatedInstance = {
89
- ...existingInstance,
90
- refetch
91
- };
92
- const newInstances2 = new Map(state.instances);
93
- newInstances2.set(id, updatedInstance);
94
- return { instances: newInstances2 };
95
- }
96
- return state;
97
- }
98
- const instance = {
99
- id,
100
- url,
101
- queryKey,
102
- payload: DEFAULT_PAYLOAD,
103
- refetch
104
- };
105
- const newInstances = new Map(state.instances);
106
- newInstances.set(id, instance);
107
- return { instances: newInstances };
108
- });
109
- },
110
- unregisterInstance(id) {
111
- set((state) => {
112
- const newInstances = new Map(state.instances);
113
- const existed = newInstances.delete(id);
114
- if (existed) {
115
- return { instances: newInstances };
116
- }
117
- return state;
118
- });
119
- },
120
- updatePayload(id, payload) {
121
- set((state) => {
122
- const instance = state.instances.get(id);
123
- if (!instance) return state;
124
- const newPayload = { ...instance.payload, ...payload };
125
- if (!isEqual(instance.payload, newPayload)) {
126
- const updatedInstance = {
127
- ...instance,
128
- payload: newPayload
129
- };
130
- const newInstances = new Map(state.instances);
131
- newInstances.set(id, updatedInstance);
132
- return { instances: newInstances };
133
- }
134
- return state;
135
- });
136
- },
137
- getPayload(id) {
138
- const instance = get().instances.get(id);
139
- return instance?.payload ?? DEFAULT_PAYLOAD;
140
- },
141
- async refetch(id, payload) {
142
- const instance = get().instances.get(id);
143
- if (!instance) {
144
- console.warn(`QueryList instance with id "${id}" not found`);
145
- return;
146
- }
147
- let payloadChanged = false;
148
- if (payload) {
149
- const currentPayload = instance.payload;
150
- const newPayload = { ...currentPayload, ...payload };
151
- if (!isEqual(currentPayload, newPayload)) {
152
- get().updatePayload(id, payload);
153
- payloadChanged = true;
154
- }
155
- }
156
- if (payloadChanged) {
157
- return;
158
- }
159
- try {
160
- await instance.refetch();
161
- } catch (error) {
162
- console.error(`Failed to refetch QueryList instance "${id}":`, error);
163
- throw error;
164
- }
165
- },
166
- getInstance(id) {
167
- return get().instances.get(id);
168
- },
169
- getAllInstances() {
170
- return Array.from(get().instances.values());
171
- }
172
- })),
173
- {
174
- name: "query-list-store"
175
- }
176
- )
177
- ), "createStore");
178
- var store = createStore();
179
- var useQueryListStore = store;
180
- var QueryListAction = /* @__PURE__ */ ((QueryListAction2) => {
181
- QueryListAction2[QueryListAction2["Confirm"] = 0] = "Confirm";
182
- QueryListAction2[QueryListAction2["Reset"] = 1] = "Reset";
183
- QueryListAction2[QueryListAction2["Jump"] = 2] = "Jump";
184
- QueryListAction2[QueryListAction2["Init"] = 3] = "Init";
185
- return QueryListAction2;
186
- })(QueryListAction || {});
187
- var DEFAULT_CACHE_TIME = 5 * 60 * 1e3;
188
- var DEFAULT_STALE_TIME = 30 * 1e3;
189
- var BODYLESS_METHODS = ["GET", "HEAD", "OPTIONS"];
190
- var BODY_SUPPORTED_METHODS = ["POST", "PUT", "PATCH", "DELETE"];
191
- var SPIN_STYLE = {
192
- display: "flex",
193
- justifyContent: "center",
194
- alignItems: "center",
195
- height: 300
196
- };
197
- var identifierCounter = 0;
198
- var generateUniqueIdentifier = /* @__PURE__ */ __name(() => {
199
- return `queryList_${Date.now()}_${++identifierCounter}`;
200
- }, "generateUniqueIdentifier");
201
- var InternalQueryList = /* @__PURE__ */ __name((props, ref) => {
202
- const { t } = useTranslation();
203
- const {
204
- form,
205
- identifier,
206
- code,
207
- onePage,
208
- buttonsAlign,
209
- showReset,
210
- defaultSize = 10,
211
- refreshInterval = 0,
212
- tableExtra,
213
- renderForm,
214
- afterSuccess,
215
- afterError,
216
- footer,
217
- pageSizeOptions,
218
- request,
219
- dataAdapter,
220
- ...tableProps
221
- } = props;
222
- const [formInstance] = Form.useForm(form);
223
- const finalIdentifier = useMemo(() => {
224
- return identifier || generateUniqueIdentifier();
225
- }, [identifier]);
226
- const action = useRef(3 /* Init */);
227
- const { data: accessible, isLoading: isChecking } = useAuth(code);
228
- const [isValid, setIsValid] = useState(false);
229
- const isInitialized = useRef(false);
230
- const isUpdatingFromPayload = useRef(false);
231
- const subscribedPayload = useQueryListStore((s) => s.getPayload(finalIdentifier));
232
- const ky = useKy();
233
- const { page, size = defaultSize, filters } = subscribedPayload;
234
- const payload = { page, size, filters };
235
- const resolvedRequest = typeof request === "function" ? request(payload) : request;
236
- const {
237
- url,
238
- method = "GET",
239
- body,
240
- searchParams,
241
- headers,
242
- cacheTime = DEFAULT_CACHE_TIME,
243
- staleTime = DEFAULT_STALE_TIME
244
- } = resolvedRequest;
245
- const normalizedMethod = method.toUpperCase();
246
- const allSupportedMethods = [...BODYLESS_METHODS, ...BODY_SUPPORTED_METHODS];
247
- if (!allSupportedMethods.includes(normalizedMethod)) {
248
- console.warn(`QueryList: \u4E0D\u652F\u6301\u7684 HTTP \u8BF7\u6C42\u65B9\u6CD5 "${method}"\uFF0C\u5C06\u4F7F\u7528 GET \u65B9\u6CD5`);
249
- }
250
- const isBodylessMethod = BODYLESS_METHODS.includes(normalizedMethod);
251
- const defaultRequestData = { ...filters, ...!onePage && { page, size } };
252
- let requestBody;
253
- let requestSearchParams;
254
- if (body !== void 0) {
255
- requestBody = body;
256
- requestSearchParams = searchParams;
257
- } else if (searchParams !== void 0) {
258
- requestSearchParams = searchParams;
259
- requestBody = void 0;
260
- } else {
261
- if (isBodylessMethod) {
262
- requestSearchParams = defaultRequestData;
263
- requestBody = void 0;
264
- } else {
265
- requestBody = defaultRequestData;
266
- requestSearchParams = void 0;
267
- }
268
- }
269
- const requestHeaders = headers;
270
- const shouldPoll = useRef(false);
271
- const queryKey = [
272
- "queryList",
273
- url,
274
- finalIdentifier,
275
- normalizedMethod,
276
- page,
277
- size,
278
- filters,
279
- requestBody,
280
- requestSearchParams,
281
- requestHeaders
282
- ];
283
- const { data, isLoading, refetch } = useQuery({
284
- queryKey,
285
- queryFn: /* @__PURE__ */ __name(async () => {
286
- try {
287
- const kyOptions = {
288
- method: normalizedMethod,
289
- searchParams: requestSearchParams,
290
- headers: requestHeaders
291
- };
292
- if (requestBody && !isBodylessMethod) {
293
- if (requestBody instanceof FormData) {
294
- kyOptions.body = requestBody;
295
- } else if (typeof requestBody === "string") {
296
- kyOptions.body = requestBody;
297
- } else {
298
- kyOptions.json = requestBody;
299
- }
300
- }
301
- const response = await ky.request({ url, ...kyOptions });
302
- shouldPoll.current = true;
303
- afterSuccess?.(action.current, formInstance, response);
304
- return response;
305
- } catch (err) {
306
- const errorObj = err instanceof Error ? err : new Error(String(err));
307
- afterError?.(errorObj, action.current, formInstance);
308
- throw errorObj;
309
- }
310
- }, "queryFn"),
311
- retry: /* @__PURE__ */ __name((failureCount, retryError) => {
312
- if (failureCount >= 3) return false;
313
- if (retryError?.message?.includes("401")) return false;
314
- return true;
315
- }, "retry"),
316
- retryDelay: /* @__PURE__ */ __name((attemptIndex) => Math.min(1e3 * 2 ** attemptIndex, 3e4), "retryDelay"),
317
- // 指数退避
318
- refetchOnWindowFocus: false,
319
- refetchInterval: shouldPoll.current ? refreshInterval : 0,
320
- // 缓存配置
321
- gcTime: cacheTime,
322
- staleTime,
323
- enabled: accessible && isValid
324
- });
325
- const resolvedDataAdapter = useMemo(() => {
326
- const adapter = dataAdapter;
327
- const defaultAdapter = {
328
- total: data?.total,
329
- items: data?.list
330
- };
331
- if (typeof adapter === "function") {
332
- return {
333
- ...defaultAdapter,
334
- ...adapter(data)
335
- };
336
- }
337
- return {
338
- ...defaultAdapter,
339
- ...adapter
340
- };
341
- }, [dataAdapter, data]);
342
- useEffect(() => {
343
- useQueryListStore.getState().registerInstance(finalIdentifier, url, queryKey, refetch);
344
- return () => {
345
- useQueryListStore.getState().unregisterInstance(finalIdentifier);
346
- };
347
- }, [finalIdentifier, url]);
348
- const dataSource = resolvedDataAdapter.items;
349
- const total = resolvedDataAdapter.total;
350
- const pagination = useMemo(() => {
351
- if (onePage) return false;
352
- return {
353
- pageSizeOptions,
354
- showSizeChanger: true,
355
- showQuickJumper: true,
356
- current: page,
357
- pageSize: size,
358
- total,
359
- onChange: /* @__PURE__ */ __name(async (currentPage, currentSize) => {
360
- action.current = 2 /* Jump */;
361
- useQueryListStore.getState().refetch(finalIdentifier, {
362
- page: currentPage,
363
- size: currentSize
364
- });
365
- }, "onChange")
366
- };
367
- }, [onePage, pageSizeOptions, page, size, total, finalIdentifier]);
368
- const onConfirm = useCallback(async () => {
369
- action.current = 0 /* Confirm */;
370
- try {
371
- await formInstance.validateFields();
372
- setIsValid(true);
373
- useQueryListStore.getState().refetch(finalIdentifier, {
374
- page: 1,
375
- filters: formInstance.getFieldsValue()
376
- });
377
- } catch {
378
- setIsValid(false);
379
- }
380
- }, [formInstance, finalIdentifier]);
381
- const onReset = useCallback(async () => {
382
- action.current = 1 /* Reset */;
383
- formInstance.resetFields();
384
- try {
385
- await formInstance.validateFields({ validateOnly: true });
386
- setIsValid(true);
387
- useQueryListStore.getState().refetch(finalIdentifier, {
388
- page: 1,
389
- filters: formInstance.getFieldsValue()
390
- });
391
- } catch {
392
- setIsValid(false);
393
- }
394
- }, [formInstance, finalIdentifier]);
395
- const formRenderer = typeof renderForm === "function" ? /* @__PURE__ */ jsx(
396
- FilterFormWrapper_default,
397
- {
398
- showReset,
399
- buttonsAlign,
400
- isConfirming: isLoading,
401
- onReset,
402
- onConfirm,
403
- children: cloneElement(renderForm(formInstance), {
404
- onKeyUp: /* @__PURE__ */ __name((e) => {
405
- if (e.key === "Enter") {
406
- onConfirm();
407
- }
408
- }, "onKeyUp")
409
- })
410
- }
411
- ) : (
412
- // 屏蔽 Form 组件的警告(Instance created by `useForm` is not connected to any Form element. Forget to pass `form` prop?)
413
- /* @__PURE__ */ jsx(Form, { form: formInstance })
414
- );
415
- const tableExtraRenderer = typeof tableExtra === "function" ? tableExtra(formInstance, data) : tableExtra;
416
- const renderFooter = footer ? () => /* @__PURE__ */ jsx(Fragment$1, { children: footer(data) }) : void 0;
417
- useEffect(() => {
418
- if (!isInitialized.current || isUpdatingFromPayload.current) {
419
- return;
420
- }
421
- const currentFormValues = formInstance.getFieldsValue();
422
- if (filters && !isEqual(currentFormValues, filters)) {
423
- isUpdatingFromPayload.current = true;
424
- formInstance.setFieldsValue(filters);
425
- setTimeout(() => {
426
- isUpdatingFromPayload.current = false;
427
- }, 0);
428
- }
429
- }, [filters, formInstance]);
430
- useEffect(() => {
431
- if (!accessible || isInitialized.current) {
432
- return;
433
- }
434
- const init = /* @__PURE__ */ __name(async () => {
435
- console.log("QueryList init starting");
436
- try {
437
- formInstance.resetFields();
438
- const value = await formInstance.validateFields({ validateOnly: true });
439
- console.log("QueryList init validation success:", value);
440
- useQueryListStore.getState().updatePayload(finalIdentifier, {
441
- page: 1,
442
- filters: value
443
- });
444
- setIsValid(true);
445
- console.log("QueryList init completed, isValid set to true");
446
- } catch (error) {
447
- console.log("QueryList init validation failed:", error);
448
- setIsValid(false);
449
- } finally {
450
- isInitialized.current = true;
451
- }
452
- }, "init");
453
- const rafId = requestAnimationFrame(() => {
454
- Promise.resolve().then(init);
455
- });
456
- return () => {
457
- if (rafId) {
458
- cancelAnimationFrame(rafId);
459
- }
460
- };
461
- }, [accessible, finalIdentifier, formInstance]);
462
- useImperativeHandle(
463
- ref,
464
- () => ({
465
- data,
466
- dataSource,
467
- form: formInstance,
468
- refetch
469
- }),
470
- [data, dataSource, formInstance, refetch]
471
- );
472
- if (isChecking) {
473
- return /* @__PURE__ */ jsx(Spin, { style: SPIN_STYLE });
474
- }
475
- if (!accessible) {
476
- return /* @__PURE__ */ jsx(Result, { status: 403, subTitle: t("global.noEntitlement") });
477
- }
478
- return /* @__PURE__ */ jsxs("div", { children: [
479
- formRenderer,
480
- tableExtraRenderer,
481
- /* @__PURE__ */ jsx(
482
- Table,
483
- {
484
- ...tableProps,
485
- dataSource,
486
- loading: isLoading,
487
- pagination,
488
- footer: renderFooter
489
- }
490
- )
491
- ] });
492
- }, "InternalQueryList");
493
- var QueryList = forwardRef(InternalQueryList);
494
- var QueryList_default = QueryList;
495
-
496
- export { FilterFormWrapper_default, Highlight_default, QueryListAction, QueryList_default, useQueryListStore };
497
- //# sourceMappingURL=chunk-ESCBNFWD.js.map
498
- //# sourceMappingURL=chunk-ESCBNFWD.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/filterFormWrapper/FilterFormWrapper.tsx","../src/components/highlight/Highlight.tsx","../src/components/queryList/stores.ts","../src/components/queryList/QueryList.tsx"],"names":["jsx","newInstances","QueryListAction","useState","useEffect","Fragment","isEqual","jsxs"],"mappings":"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","file":"chunk-ESCBNFWD.js","sourcesContent":["import { Button, Space, theme } from 'antd'\nimport type { Key, PropsWithChildren, ReactNode } from 'react'\nimport { Fragment } from 'react'\n\nimport { useTranslation } from '@/locale'\n\nexport interface FilterFormWrapperProps extends PropsWithChildren {\n onConfirm?: () => void | Promise<void>\n onReset?: () => void\n extras?: { key: Key; children: ReactNode }[]\n isConfirming?: boolean\n buttonsAlign?: 'left' | 'right' | 'bottom'\n showReset?: boolean\n}\n\nconst FilterFormWrapper = (props: FilterFormWrapperProps) => {\n const { extras, isConfirming, onConfirm, onReset, children, buttonsAlign = 'left', showReset } = props\n const { t } = useTranslation()\n const {\n token: { colorFillAlter, lineWidth, lineType, colorBorder, borderRadiusLG },\n } = theme.useToken()\n\n const style = {\n maxWidth: 'none',\n background: colorFillAlter,\n borderWidth: lineWidth,\n borderStyle: lineType,\n borderColor: colorBorder,\n borderRadius: borderRadiusLG,\n padding: 24,\n marginBottom: 24,\n }\n\n return (\n <div style={style}>\n <div className={`flex ${buttonsAlign === 'bottom' ? 'flex-col' : 'flex-row'}`}>\n <div className={`${buttonsAlign === 'left' ? 'flex-grow-0' : 'flex-1'}`}>{children}</div>\n <div className={`${buttonsAlign === 'bottom' ? 'text-end' : 'text-start'} ml-4`}>\n <Space>\n <Button type=\"primary\" disabled={isConfirming} onClick={onConfirm}>\n {t('FilterFormWrapper.confirmText')}\n </Button>\n {extras?.map(item => <Fragment key={item.key}>{item.children}</Fragment>)}\n {showReset && <Button onClick={onReset}>{t('FilterFormWrapper.resetText')}</Button>}\n </Space>\n </div>\n </div>\n </div>\n )\n}\n\nexport default FilterFormWrapper\n","import type { PropsWithChildren, ReactNode } from 'react'\nimport { useEffect, useState } from 'react'\nimport { flushSync } from 'react-dom'\nimport { createRoot } from 'react-dom/client'\n\nconst splitByTags = (str: string) => {\n const regex = /(<[^>]*>)/\n return str.split(regex).filter(part => part !== '')\n}\n\nfunction renderToString(node: ReactNode): Promise<string> {\n const container = document.createElement('div')\n const root = createRoot(container)\n\n return new Promise(resolve => {\n setTimeout(() => {\n flushSync(() => {\n root.render(node)\n })\n resolve(container.innerHTML)\n })\n })\n}\n\nexport interface HighlightProps extends PropsWithChildren {\n texts: Array<string | number>\n}\n\nconst Highlight = (props: HighlightProps) => {\n const { texts, children } = props\n const [htmlString, setHtmlString] = useState<string>('')\n\n useEffect(() => {\n renderToString(children).then(str => {\n const result = splitByTags(str)\n\n for (const text of texts) {\n for (let index = 0; index < result.length; index++) {\n // TODO: 忽略 HTML tag\n result[index] = result[index].replace(String(text), `<span style='color: #DC143C;'>${text}</span>`)\n }\n }\n\n setHtmlString(result.join(''))\n })\n }, [children, texts])\n\n return <div dangerouslySetInnerHTML={{ __html: htmlString }}></div>\n}\n\nexport default Highlight\n","import { isEqual } from 'lodash-es'\nimport { create } from 'zustand'\nimport { devtools, subscribeWithSelector } from 'zustand/middleware'\n\nimport type { QueryListPayload } from './QueryList'\n\n// Query 更新函数类型\ntype QueryRefetchFunction = () => void | Promise<unknown>\n\n// QueryList 实例信息\ninterface QueryListInstance {\n id: string\n url: string\n queryKey: readonly unknown[]\n payload: QueryListPayload\n refetch: QueryRefetchFunction\n}\n\n// 简化的状态接口\ninterface QueryListState {\n // 实例管理\n instances: Map<string, QueryListInstance>\n\n // 核心方法\n registerInstance(id: string, url: string, queryKey: readonly unknown[], refetch: QueryRefetchFunction): void\n unregisterInstance(id: string): void\n updatePayload(id: string, payload: QueryListPayload): void\n getPayload(id: string): QueryListPayload\n refetch(id: string, payload?: QueryListPayload): Promise<void>\n\n // 工具方法\n getInstance(id: string): QueryListInstance | undefined\n getAllInstances(): QueryListInstance[]\n}\n\n// 稳定的默认 payload 引用,避免未注册时每次返回新对象导致 getSnapshot 无限循环\nconst DEFAULT_PAYLOAD: QueryListPayload = Object.freeze({\n page: 1,\n size: 10,\n filters: Object.freeze({}),\n})\n\n// 创建简化的 store\nconst createStore = () =>\n create<QueryListState>()(\n devtools(\n subscribeWithSelector((set, get) => ({\n instances: new Map(),\n\n registerInstance(id, url, queryKey, refetch) {\n set(state => {\n const existingInstance = state.instances.get(id)\n\n // 如果实例已存在,只更新refetch函数\n if (existingInstance) {\n // 仅当 refetch 变更时才更新,避免无意义 setState\n if (existingInstance.refetch !== refetch) {\n const updatedInstance = {\n ...existingInstance,\n refetch,\n }\n const newInstances = new Map(state.instances)\n newInstances.set(id, updatedInstance)\n return { instances: newInstances }\n }\n return state\n }\n\n // 创建新实例\n const instance: QueryListInstance = {\n id,\n url,\n queryKey,\n payload: DEFAULT_PAYLOAD,\n refetch,\n }\n\n const newInstances = new Map(state.instances)\n newInstances.set(id, instance)\n\n return { instances: newInstances }\n })\n },\n unregisterInstance(id) {\n set(state => {\n const newInstances = new Map(state.instances)\n const existed = newInstances.delete(id)\n\n if (existed) {\n return { instances: newInstances }\n }\n return state\n })\n },\n updatePayload(id, payload) {\n set(state => {\n const instance = state.instances.get(id)\n if (!instance) return state\n\n const newPayload = { ...instance.payload, ...payload }\n\n // 只有当 payload 真正改变时才更新\n if (!isEqual(instance.payload, newPayload)) {\n const updatedInstance = {\n ...instance,\n payload: newPayload,\n }\n\n const newInstances = new Map(state.instances)\n newInstances.set(id, updatedInstance)\n\n return { instances: newInstances }\n }\n\n return state\n })\n },\n getPayload(id) {\n const instance = get().instances.get(id)\n return instance?.payload ?? DEFAULT_PAYLOAD\n },\n async refetch(id, payload) {\n const instance = get().instances.get(id)\n if (!instance) {\n console.warn(`QueryList instance with id \"${id}\" not found`)\n return\n }\n\n let payloadChanged = false\n\n // 更新 payload 如果提供且确实有变化\n if (payload) {\n const currentPayload = instance.payload\n const newPayload = { ...currentPayload, ...payload }\n\n if (!isEqual(currentPayload, newPayload)) {\n get().updatePayload(id, payload)\n payloadChanged = true\n }\n }\n\n // 若 payload 发生变化,queryKey 会变化,React Query 会自动触发请求,此处不再手动 refetch,避免重复请求\n if (payloadChanged) {\n return\n }\n\n // 否则手动触发一次请求\n try {\n await instance.refetch()\n } catch (error) {\n console.error(`Failed to refetch QueryList instance \"${id}\":`, error)\n throw error\n }\n },\n\n getInstance(id) {\n return get().instances.get(id)\n },\n\n getAllInstances() {\n return Array.from(get().instances.values())\n },\n })),\n {\n name: 'query-list-store',\n },\n ),\n )\n\n// 创建 store 实例\nconst store = createStore()\n\nexport const useQueryListStore = store\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { useQuery } from '@tanstack/react-query'\nimport type { FormInstance } from 'antd'\nimport { Form, Result, Spin, Table } from 'antd'\nimport type { AnyObject } from 'antd/es/_util/type'\nimport type { TableProps } from 'antd/es/table'\nimport type { Options as KyOptions } from 'ky'\nimport { isEqual } from 'lodash-es'\nimport type { ReactElement, ReactNode, Ref } from 'react'\nimport { cloneElement, forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState } from 'react'\n\nimport type { FilterFormWrapperProps } from '@/components/filterFormWrapper'\nimport { FilterFormWrapper } from '@/components/filterFormWrapper'\nimport { useKy } from '@/libs'\nimport { useTranslation } from '@/locale'\nimport { useAuth } from '@/services'\n\nimport { useQueryListStore } from './stores'\n\nexport interface ListResponse<T = any> {\n list: T[]\n total: number\n}\n\nexport interface QueryListPayload<Values = any> {\n page?: number\n size?: number\n filters?: Values\n}\n\n// 缓存配置\nexport interface CacheConfig {\n cacheTime?: number // 缓存时间(毫秒)\n staleTime?: number // 数据新鲜时间(毫秒)\n}\n\n// 支持的 HTTP 请求方法类型\nexport type HttpMethod = 'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE' | 'HEAD' | 'OPTIONS'\n\n// 简化的请求配置\nexport interface QueryListRequestConfig extends CacheConfig {\n url: string\n method?: HttpMethod\n body?: FormData | Record<string | number, any>\n searchParams?: Record<string | number, any>\n headers?: Record<string, string>\n}\n\nexport type QueryListRequestConfigType<Values = any> =\n | QueryListRequestConfig\n | ((payload: QueryListPayload<Values>) => QueryListRequestConfig)\n\nexport enum QueryListAction {\n Confirm,\n Reset,\n Jump,\n Init,\n}\n\nexport interface QueryListDataType<Item> {\n dataSource: Item[]\n total: number\n}\n\nexport interface QueryListRef<Item extends AnyObject = AnyObject, Values = AnyObject, Data = any> {\n data: Data | undefined\n dataSource: Item[] | undefined\n form: FormInstance<Values>\n}\n\nexport interface QueryListDataAdapter<Item extends AnyObject = AnyObject> {\n total?: number\n items?: Item[]\n}\n\nexport type QueryListDataAdapterConfig<Item extends AnyObject = AnyObject, Data = any> =\n | QueryListDataAdapter<Item>\n | ((data: Data) => QueryListDataAdapter<Item>)\n\nexport interface QueryListProps<Item extends AnyObject = AnyObject, Values = AnyObject, Data = any>\n extends Omit<TableProps<Item>, 'pagination' | 'dataSource' | 'loading' | 'footer'>,\n Pick<FilterFormWrapperProps, 'buttonsAlign' | 'showReset'> {\n identifier?: string // 可选的标识符,用于标识和外部控制,未提供时自动生成\n code?: string\n form?: FormInstance<Values>\n refreshInterval?: number\n onePage?: boolean // 无分页\n defaultSize?: number\n pageSizeOptions?: number[]\n request: QueryListRequestConfigType<Values> // 必需的请求配置\n tableExtra?: ReactNode | ((form: FormInstance<Values>, data?: Data) => ReactNode)\n renderForm?: (form: FormInstance<Values>) => ReactElement\n afterSuccess?: (action: QueryListAction, form: FormInstance<Values>, data?: Data) => void\n afterError?: (error: Error, action: QueryListAction, form: FormInstance<Values>) => void\n dataAdapter?: QueryListDataAdapterConfig<Item, Data>\n footer?: (data: Data | undefined) => ReactNode\n}\n\n// 常量定义\nconst DEFAULT_CACHE_TIME = 5 * 60 * 1000 // 默认缓存5分钟\nconst DEFAULT_STALE_TIME = 30 * 1000 // 默认30秒内数据新鲜\n\n// 无请求体的 HTTP 方法\nconst BODYLESS_METHODS: HttpMethod[] = ['GET', 'HEAD', 'OPTIONS']\n\n// 支持请求体的 HTTP 方法\nconst BODY_SUPPORTED_METHODS: HttpMethod[] = ['POST', 'PUT', 'PATCH', 'DELETE']\n\nconst SPIN_STYLE: React.CSSProperties = {\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n height: 300,\n}\n\n// 生成唯一 identifier 的计数器\nlet identifierCounter = 0\n\n// 生成唯一 identifier 的函数\nconst generateUniqueIdentifier = (): string => {\n return `queryList_${Date.now()}_${++identifierCounter}`\n}\n\nconst InternalQueryList = <Item extends AnyObject = AnyObject, Values extends AnyObject = any, Data = any>(\n props: QueryListProps<Item, Values, Data>,\n ref: Ref<QueryListRef<Item, Values, Data>>,\n) => {\n const { t } = useTranslation()\n\n const {\n form,\n identifier,\n code,\n onePage,\n buttonsAlign,\n showReset,\n defaultSize = 10,\n refreshInterval = 0,\n tableExtra,\n renderForm,\n afterSuccess,\n afterError,\n footer,\n pageSizeOptions,\n request,\n dataAdapter,\n ...tableProps\n } = props\n\n const [formInstance] = Form.useForm<Values>(form)\n\n // 生成或使用提供的 identifier\n const finalIdentifier = useMemo(() => {\n return identifier || generateUniqueIdentifier()\n }, [identifier])\n const action = useRef<QueryListAction>(QueryListAction.Init)\n const { data: accessible, isLoading: isChecking } = useAuth(code)\n const [isValid, setIsValid] = useState(false)\n const isInitialized = useRef(false)\n const isUpdatingFromPayload = useRef(false) // 防止循环更新的标志\n\n // 仅订阅当前 identifier 的 payload,避免因其它实例变化导致不必要重渲染\n const subscribedPayload = useQueryListStore(s => s.getPayload(finalIdentifier))\n const ky = useKy()\n\n const { page, size = defaultSize, filters } = subscribedPayload\n\n const payload = { page, size, filters }\n\n // 处理 request 配置(对象或函数)\n const resolvedRequest = typeof request === 'function' ? request(payload) : request\n\n const {\n url,\n method = 'GET',\n body,\n searchParams,\n headers,\n cacheTime = DEFAULT_CACHE_TIME,\n staleTime = DEFAULT_STALE_TIME,\n } = resolvedRequest\n\n // 验证请求方法\n const normalizedMethod = method.toUpperCase() as HttpMethod\n const allSupportedMethods: HttpMethod[] = [...BODYLESS_METHODS, ...BODY_SUPPORTED_METHODS]\n\n if (!allSupportedMethods.includes(normalizedMethod)) {\n console.warn(`QueryList: 不支持的 HTTP 请求方法 \"${method}\",将使用 GET 方法`)\n }\n\n // 根据请求方法决定参数传递方式\n const isBodylessMethod = BODYLESS_METHODS.includes(normalizedMethod)\n\n const defaultRequestData = { ...filters, ...(!onePage && { page, size }) }\n\n // 智能参数传递策略:\n // 1. 优先使用用户明确传入的 body 或 searchParams\n // 2. 若用户未指定,根据 HTTP 方法自动选择合适的传递方式\n // 3. 避免同时设置 body 和 searchParams(除非用户明确指定)\n let requestBody: any\n let requestSearchParams: any\n\n if (body !== undefined) {\n // 用户传入了 body,优先使用\n requestBody = body\n requestSearchParams = searchParams\n } else if (searchParams !== undefined) {\n // 用户只传入了 searchParams\n requestSearchParams = searchParams\n requestBody = undefined\n } else {\n // 都未传入,根据方法类型自动选择\n if (isBodylessMethod) {\n requestSearchParams = defaultRequestData\n requestBody = undefined\n } else {\n requestBody = defaultRequestData\n requestSearchParams = undefined\n }\n }\n\n const requestHeaders = headers\n\n const shouldPoll = useRef(false)\n\n // 构建更完整的 queryKey,包含所有影响请求结果的参数\n const queryKey = [\n 'queryList',\n url,\n finalIdentifier,\n normalizedMethod,\n page,\n size,\n filters,\n requestBody,\n requestSearchParams,\n requestHeaders,\n ] as const\n\n const { data, isLoading, refetch } = useQuery({\n queryKey,\n queryFn: async () => {\n try {\n const kyOptions: KyOptions = {\n method: normalizedMethod,\n searchParams: requestSearchParams,\n headers: requestHeaders,\n }\n\n // 只有非无请求体方法才允许有 body\n if (requestBody && !isBodylessMethod) {\n if (requestBody instanceof FormData) {\n // FormData 使用 body 方式传递\n kyOptions.body = requestBody\n } else if (typeof requestBody === 'string') {\n // 字符串直接作为 body\n kyOptions.body = requestBody\n } else {\n // 对象类型使用 .json 方式传递\n kyOptions.json = requestBody\n }\n }\n\n const response = await ky.request<Data>({ url, ...kyOptions })\n shouldPoll.current = true\n afterSuccess?.(action.current, formInstance, response)\n return response\n } catch (err) {\n const errorObj = err instanceof Error ? err : new Error(String(err))\n afterError?.(errorObj, action.current, formInstance)\n throw errorObj\n }\n },\n retry: (failureCount, retryError) => {\n // 自定义重试逻辑\n if (failureCount >= 3) return false\n if (retryError?.message?.includes('401')) return false // 认证错误不重试\n return true\n },\n retryDelay: attemptIndex => Math.min(1000 * 2 ** attemptIndex, 30000), // 指数退避\n refetchOnWindowFocus: false,\n refetchInterval: shouldPoll.current ? refreshInterval : 0,\n // 缓存配置\n gcTime: cacheTime,\n staleTime,\n enabled: accessible && isValid,\n })\n\n // 处理 dataAdapter 配置\n const resolvedDataAdapter = useMemo(() => {\n const adapter = dataAdapter\n const defaultAdapter: QueryListDataAdapter<Item> = {\n total: (data as ListResponse<Item>)?.total,\n items: (data as ListResponse<Item>)?.list,\n }\n\n if (typeof adapter === 'function') {\n return {\n ...defaultAdapter,\n ...adapter(data as Data),\n }\n }\n return {\n ...defaultAdapter,\n ...adapter,\n }\n }, [dataAdapter, data])\n\n // 在组件挂载时注册实例,避免因 queryKey/refetch 身份变化反复注册\n useEffect(() => {\n useQueryListStore.getState().registerInstance(finalIdentifier, url, queryKey, refetch)\n return () => {\n useQueryListStore.getState().unregisterInstance(finalIdentifier)\n }\n }, [finalIdentifier, url])\n\n const dataSource = resolvedDataAdapter.items\n const total = resolvedDataAdapter.total\n\n const pagination = useMemo(() => {\n if (onePage) return false\n\n return {\n pageSizeOptions,\n showSizeChanger: true,\n showQuickJumper: true,\n current: page,\n pageSize: size,\n total,\n onChange: async (currentPage: number, currentSize: number) => {\n action.current = QueryListAction.Jump\n useQueryListStore.getState().refetch(finalIdentifier, {\n page: currentPage,\n size: currentSize,\n })\n },\n }\n }, [onePage, pageSizeOptions, page, size, total, finalIdentifier])\n\n const onConfirm = useCallback(async () => {\n action.current = QueryListAction.Confirm\n try {\n await formInstance.validateFields()\n setIsValid(true)\n useQueryListStore.getState().refetch(finalIdentifier, {\n page: 1,\n filters: formInstance.getFieldsValue(),\n })\n } catch {\n setIsValid(false)\n }\n }, [formInstance, finalIdentifier])\n\n const onReset = useCallback(async () => {\n action.current = QueryListAction.Reset\n formInstance.resetFields()\n\n try {\n await formInstance.validateFields({ validateOnly: true })\n setIsValid(true)\n useQueryListStore.getState().refetch(finalIdentifier, {\n page: 1,\n filters: formInstance.getFieldsValue(),\n })\n } catch {\n setIsValid(false)\n }\n }, [formInstance, finalIdentifier])\n\n const formRenderer =\n typeof renderForm === 'function' ? (\n <FilterFormWrapper\n showReset={showReset}\n buttonsAlign={buttonsAlign}\n isConfirming={isLoading}\n onReset={onReset}\n onConfirm={onConfirm}\n >\n {cloneElement(renderForm(formInstance) as ReactElement<{ onKeyUp?: React.KeyboardEventHandler }>, {\n onKeyUp: (e: React.KeyboardEvent) => {\n if (e.key === 'Enter') {\n onConfirm()\n }\n },\n })}\n </FilterFormWrapper>\n ) : (\n // 屏蔽 Form 组件的警告(Instance created by `useForm` is not connected to any Form element. Forget to pass `form` prop?)\n <Form form={formInstance} />\n )\n\n const tableExtraRenderer = typeof tableExtra === 'function' ? tableExtra(formInstance, data) : tableExtra\n\n const renderFooter: TableProps<Item>['footer'] = footer ? () => <>{footer(data)}</> : undefined\n\n // 监听 payload.filters 变化并同步更新表单实例\n useEffect(() => {\n if (!isInitialized.current || isUpdatingFromPayload.current) {\n return\n }\n\n // 获取当前表单的值\n const currentFormValues = formInstance.getFieldsValue()\n\n // 如果 payload 中的 filters 与当前表单值不同,则更新表单\n if (filters && !isEqual(currentFormValues, filters)) {\n isUpdatingFromPayload.current = true\n formInstance.setFieldsValue(filters)\n // 使用 setTimeout 确保在下一个事件循环中重置标志\n setTimeout(() => {\n isUpdatingFromPayload.current = false\n }, 0)\n }\n }, [filters, formInstance])\n\n // 首次挂载时自动校验表单,校验通过则更新 payload 并允许请求\n useEffect(() => {\n if (!accessible || isInitialized.current) {\n return\n }\n\n const init = async () => {\n console.log('QueryList init starting')\n try {\n formInstance.resetFields()\n const value = await formInstance.validateFields({ validateOnly: true })\n console.log('QueryList init validation success:', value)\n useQueryListStore.getState().updatePayload(finalIdentifier, {\n page: 1,\n filters: value,\n })\n setIsValid(true)\n console.log('QueryList init completed, isValid set to true')\n } catch (error) {\n console.log('QueryList init validation failed:', error)\n setIsValid(false)\n } finally {\n isInitialized.current = true\n }\n }\n\n const rafId = requestAnimationFrame(() => {\n Promise.resolve().then(init)\n })\n\n return () => {\n if (rafId) {\n cancelAnimationFrame(rafId)\n }\n }\n }, [accessible, finalIdentifier, formInstance])\n\n useImperativeHandle(\n ref,\n () => ({\n data,\n dataSource,\n form: formInstance,\n refetch,\n }),\n [data, dataSource, formInstance, refetch],\n )\n\n if (isChecking) {\n return <Spin style={SPIN_STYLE} />\n }\n\n if (!accessible) {\n return <Result status={403} subTitle={t('global.noEntitlement')} />\n }\n\n return (\n <div>\n {formRenderer}\n {tableExtraRenderer}\n <Table\n {...tableProps}\n dataSource={dataSource}\n loading={isLoading}\n pagination={pagination}\n footer={renderFooter}\n />\n </div>\n )\n}\n\nconst QueryList = forwardRef(InternalQueryList) as <\n Item extends AnyObject = AnyObject,\n Values extends object | undefined = undefined,\n Data = any,\n>(\n props: QueryListProps<Item, Values, Data> & { ref?: Ref<QueryListRef<Item, Values, Data>> },\n) => ReactElement\n\nexport default QueryList\n"]}