* wip * wip * - Added scopes on useHotkeys - Use new EditableCellV2 - Implemented Recoil Scoped State with specific context - Implemented soft focus position - Factorized open/close editable cell - Removed editable relation old components - Broke down entity table into multiple components - Added Recoil Scope by CellContext - Added Recoil Scope by RowContext * First working version * Use a new EditableCellSoftFocusMode * Fixed initialize soft focus * Fixed enter mode * Added TODO * Fix * Fixes * Fix tests * Fix lint * Fixes --------- Co-authored-by: Lucas Bordeau <bordeau.lucas@gmail.com>
37 lines
1.2 KiB
TypeScript
37 lines
1.2 KiB
TypeScript
import { useMemo } from 'react';
|
|
import { useRecoilValue } from 'recoil';
|
|
|
|
import { useRecoilScopedState } from '@/recoil-scope/hooks/useRecoilScopedState';
|
|
import { CellContext } from '@/ui/tables/states/CellContext';
|
|
import { currentColumnNumberScopedState } from '@/ui/tables/states/currentColumnNumberScopedState';
|
|
import { currentRowNumberScopedState } from '@/ui/tables/states/currentRowNumberScopedState';
|
|
import { isSoftFocusOnCellFamilyState } from '@/ui/tables/states/isSoftFocusOnCellFamilyState';
|
|
import { RowContext } from '@/ui/tables/states/RowContext';
|
|
import { TablePosition } from '@/ui/tables/types/TablePosition';
|
|
|
|
export function useIsSoftFocusOnCurrentCell() {
|
|
const [currentRowNumber] = useRecoilScopedState(
|
|
currentRowNumberScopedState,
|
|
RowContext,
|
|
);
|
|
|
|
const [currentColumnNumber] = useRecoilScopedState(
|
|
currentColumnNumberScopedState,
|
|
CellContext,
|
|
);
|
|
|
|
const currentTablePosition: TablePosition = useMemo(
|
|
() => ({
|
|
column: currentColumnNumber,
|
|
row: currentRowNumber,
|
|
}),
|
|
[currentColumnNumber, currentRowNumber],
|
|
);
|
|
|
|
const isSoftFocusOnCell = useRecoilValue(
|
|
isSoftFocusOnCellFamilyState(currentTablePosition),
|
|
);
|
|
|
|
return isSoftFocusOnCell;
|
|
}
|