From 74dc8005afe7ff7e78ab90aa2649bd983f9977af Mon Sep 17 00:00:00 2001 From: Radek Podrazky Date: Mon, 9 Oct 2023 19:09:56 +0200 Subject: [PATCH] fix(Datatable): fix column visibility state Closes UXD-1258 --- .../hooks/useColumnVisibility.ts | 22 +++++-------------- 1 file changed, 6 insertions(+), 16 deletions(-) diff --git a/src/components/Datatable/components/ColumnsControls/hooks/useColumnVisibility.ts b/src/components/Datatable/components/ColumnsControls/hooks/useColumnVisibility.ts index 80ac53518..9c322328b 100644 --- a/src/components/Datatable/components/ColumnsControls/hooks/useColumnVisibility.ts +++ b/src/components/Datatable/components/ColumnsControls/hooks/useColumnVisibility.ts @@ -1,5 +1,6 @@ -import { useEffect, useState } from 'react'; +import { useState } from 'react'; import { isEmptyArray } from 'ramda-adjunct'; +import { useDeepCompareEffect } from 'use-deep-compare'; import { DatatableStore } from '../../../Datatable.store'; @@ -11,23 +12,12 @@ export const useColumnVisibility = (): { resetVisisbleColumns: () => void; isInDefaultVisibility: boolean; } => { - const { hiddenColumns } = DatatableStore.useState((s) => ({ - hiddenColumns: s.hiddenColumns, - })); + const hiddenColumns = DatatableStore.useState((s) => s.hiddenColumns); const [localHiddenColumns, setLocalHiddenColumns] = useState(hiddenColumns); - useEffect(() => { - const unsubscribe = DatatableStore.subscribe( - (s) => ({ hidden: s.hiddenColumns }), - ({ hidden }) => { - setLocalHiddenColumns(hidden); - }, - ); - - return () => { - unsubscribe(); - }; - }, []); + useDeepCompareEffect(() => { + setLocalHiddenColumns(hiddenColumns); + }, [hiddenColumns]); const setHiddenColumn = (id, value) => { if (value === true) { setLocalHiddenColumns((prev) => prev.filter((col) => col !== id));