From dc8c8540e5c013082cd6d2dd6384ec82ec675cd8 Mon Sep 17 00:00:00 2001 From: sqzhou Date: Thu, 30 Nov 2023 19:19:49 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=E5=88=B7=E6=96=B0=E8=A1=A8=E6=A0=BC?= =?UTF-8?q?=E6=97=B6=EF=BC=8C=E6=B8=85=E7=A9=BA=E8=A1=A8=E6=A0=BC=E8=A1=8C?= =?UTF-8?q?=E7=8A=B6=E6=80=81=EF=BC=8C=E4=BE=8B=E5=A6=82switch=E9=80=89?= =?UTF-8?q?=E4=B8=AD=E3=80=81select=E9=80=89=E4=B8=AD=E7=AD=89=20=20(#8951?= =?UTF-8?q?)=20(#8966)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * fix: 支持刷新表格时,清空表格状态 * fix: 支持刷新表格时,清空表格状态 --- .../amis/__tests__/renderers/CRUD.test.tsx | 81 +++++++++++++++++++ packages/amis/src/renderers/Table/index.tsx | 12 ++- 2 files changed, 92 insertions(+), 1 deletion(-) diff --git a/packages/amis/__tests__/renderers/CRUD.test.tsx b/packages/amis/__tests__/renderers/CRUD.test.tsx index 1f5aae08cfa..558da689491 100644 --- a/packages/amis/__tests__/renderers/CRUD.test.tsx +++ b/packages/amis/__tests__/renderers/CRUD.test.tsx @@ -21,6 +21,7 @@ * 18. CRUD 事件 * 19. fetchInitData silent 静默请求 * 20. CRUD表头查询字段更新后严格比较场景 + * 21. 通过reUseRow为false强制清空表格状态 */ import { @@ -1315,3 +1316,83 @@ test('20. CRUD filters contain fields that modification inspection should use st await wait(200); expect(keyword).toEqual('0'); }, 7000); + + /** + * 在reUseRow为false情况下,强制刷新表格行状态 + * case:用户每次刷新,调用接口,返回的数据都是一样的,导致updateRows为false,故针对每次返回数据一致的情况,需要强制表格更新 + */ +test('21. CRUD reUseRow set false to reset crud state when api return same data', async () => { + const mockFetcher = jest.fn().mockImplementation(() => { + return new Promise(resolve => + resolve({ + data: { + status: 0, + msg: 'ok', + data: { + count: 0, + items: [ + { + "name": "name1", + "switch": false + }, + { + "name": "name2", + "switch": false + } + ] + } + } + }) + ); + }); + const {container} = render( + amisRender( + { + type: 'page', + body: [ + { + type: 'crud', + api: '/api/mock/sample', + headerToolbar: [ + 'reload' + ], + reUseRow: false, + columns: [ + { + name: 'name', + label: 'name' + }, + { + name: 'switch', + label: 'switch', + type: 'switch' + } + ] + } + ] + }, + {}, + makeEnv({fetcher: mockFetcher}) + ) + ); + + await waitFor(() => { + expect(container.querySelectorAll('tbody>tr').length >= 2).toBeTruthy(); + }); + + // 切换switch + const switchBtn = container.querySelectorAll('.cxd-Switch'); + fireEvent.click(switchBtn[0]); + await wait(200); + + const checks1 = container.querySelectorAll('.is-checked'); + expect(checks1.length).toEqual(1); + + // 刷新 + const btn = container.querySelectorAll('.cxd-Button')!; + fireEvent.click(btn[0]); + await wait(300); + + const checks2 = container.querySelectorAll('.is-checked'); + expect(checks2.length).toEqual(0); +}); diff --git a/packages/amis/src/renderers/Table/index.tsx b/packages/amis/src/renderers/Table/index.tsx index f097f987a26..49d0e451993 100644 --- a/packages/amis/src/renderers/Table/index.tsx +++ b/packages/amis/src/renderers/Table/index.tsx @@ -700,7 +700,17 @@ export default class Table extends React.Component { } } - updateRows && store.initRows(rows, props.getEntryId, props.reUseRow); + if (updateRows) { + store.initRows(rows, props.getEntryId, props.reUseRow); + } else if (props.reUseRow === false) { + /** + * 在reUseRow为false情况下,支持强制刷新表格行状态 + * 适用的情况:用户每次刷新,调用接口,返回的数据都是一样的,导致updateRows为false,故针对每次返回数据一致的情况,需要强制表格更新 + */ + updateRows = true; + store.initRows(value, props.getEntryId, props.reUseRow); + } + Array.isArray(props.selected) && store.updateSelected(props.selected, props.valueField); return updateRows;