playbook_ui 14.22.0.pre.alpha.PLAY2292advancedtablepinnedrowsloading8631 → 14.22.0.pre.alpha.PLAY2292advancedtablepinnedrowsloading8632

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: cc8c480032767b70d345545bb050a1a402e25edc0533e7f241d07e8c448eba1b
4
- data.tar.gz: 0b791da24dd14a9e71467272645c86449fde0d2433e72774c8a77db84cf378fb
3
+ metadata.gz: 1a87d5a3b0f1ba4c0e20a6d286acb82d538fb5bd2cb68700d81df41cf44f1449
4
+ data.tar.gz: 507e84e412dc50c8020a636f6c46e1fa326605de6ba7ffbd60499790770d6c54
5
5
  SHA512:
6
- metadata.gz: 7b01d8af55ae4645022e7121aaf51b11f89e0afdd149ab498a18d90fae59942e0da55f049bf6a06d9757c2108a8e1c45baf11cc1d521d4c84db1591374a33580
7
- data.tar.gz: 2c87fbf4597479a6590baa63eb3a06f8789d6f28be225db1347213f381ccfb744d05735c81e6727d548e997f76af5c08782dbc08951bde4225b69a79099a2cec
6
+ metadata.gz: 90f4a2e682d5d0575ea805a1adc4a0bde6aaf65bb592093c4c98a8122eab250960f90547c9c64ac17724331933ba040a5fb4d60b7bab8b800cc87d01af6cbbf5
7
+ data.tar.gz: 2a44d15f9f3d820cd44c807cdaab752bd116b2e0ba30dac1dcfdee66f5e1e47828b9c507008948d2baef396cf5ccb780ae4b0c328bf650081ad2f3c5feaa8c78
@@ -1,4 +1,4 @@
1
- import { useState, useCallback, useMemo, useEffect, useRef } from 'react';
1
+ import { useState, useCallback, useMemo, useEffect } from 'react';
2
2
  import {
3
3
  useReactTable,
4
4
  getCoreRowModel,
@@ -180,19 +180,24 @@ export function useTableState({
180
180
  ...tableOptions,
181
181
  });
182
182
 
183
- // Store a reference to the current data to detect changes
184
- const dataRef = useRef(tableData);
183
+ // Create a stable hash of the data to detect changes
184
+ const dataHash = useMemo(() => {
185
+ if (loading) return '';
186
+ const currentData = virtualizedRows ? dataChunk : tableData;
187
+ return currentData.map(row => row.id).join(',');
188
+ }, [tableData, dataChunk, virtualizedRows, loading]);
185
189
 
186
- // Clear pins when data changes (detected by reference change)
190
+ const [prevDataHash, setPrevDataHash] = useState(dataHash);
191
+
192
+ // Clear pins when data actually changes (by ID composition)
187
193
  useEffect(() => {
188
194
  if (loading) return;
189
195
 
190
- // If the data reference changed, clear pins
191
- if (dataRef.current !== tableData) {
192
- dataRef.current = tableData;
196
+ if (dataHash !== prevDataHash) {
197
+ setPrevDataHash(dataHash);
193
198
  onRowPinningChange({ top: [] });
194
199
  }
195
- }, [tableData, loading, onRowPinningChange]);
200
+ }, [dataHash, prevDataHash, loading, onRowPinningChange]);
196
201
 
197
202
  // Handle row pinning changes
198
203
  useEffect(() => {