summaryrefslogtreecommitdiff
path: root/frontend/src/components/QuickAccessVisibleState.tsx
blob: f5c0506154916cbd3fe1403ec34a346a3883409d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
import { FC, ReactNode, createContext, useContext, useState } from 'react';

const QuickAccessVisibleState = createContext<boolean>(false);

export const useQuickAccessVisible = () => useContext(QuickAccessVisibleState);

export const QuickAccessVisibleStateProvider: FC<{ tab: any; children: ReactNode }> = ({ children, tab }) => {
  const initial = tab.initialVisibility;
  const [visible, setVisible] = useState<boolean>(initial);
  // HACK but i can't think of a better way to do this
  tab.qAMVisibilitySetter = (val: boolean) => {
    if (val != visible) setVisible(val);
  };

  return <QuickAccessVisibleState.Provider value={visible}>{children}</QuickAccessVisibleState.Provider>;
};