* Put onImport in a context * Refactored RecoilScopeContexts * Refactored naming * Fix tests --------- Co-authored-by: Charles Bochet <charles@twenty.com>
78 lines
3.0 KiB
TypeScript
78 lines
3.0 KiB
TypeScript
import styled from '@emotion/styled';
|
|
import { v4 } from 'uuid';
|
|
|
|
import { useOptimisticEffect } from '@/apollo/optimistic-effect/hooks/useOptimisticEffect';
|
|
import { PeopleTable } from '@/people/table/components/PeopleTable';
|
|
import { SpreadsheetImportProvider } from '@/spreadsheet-import/provider/components/SpreadsheetImportProvider';
|
|
import { DropdownRecoilScopeContext } from '@/ui/dropdown/states/recoil-scope-contexts/DropdownRecoilScopeContext';
|
|
import { IconUser } from '@/ui/icon';
|
|
import { PageAddButton } from '@/ui/layout/components/PageAddButton';
|
|
import { PageBody } from '@/ui/layout/components/PageBody';
|
|
import { PageContainer } from '@/ui/layout/components/PageContainer';
|
|
import { PageHeader } from '@/ui/layout/components/PageHeader';
|
|
import { PageHotkeysEffect } from '@/ui/layout/components/PageHotkeysEffect';
|
|
import { EntityTableActionBar } from '@/ui/table/action-bar/components/EntityTableActionBar';
|
|
import { EntityTableContextMenu } from '@/ui/table/context-menu/components/EntityTableContextMenu';
|
|
import { useUpsertEntityTableItem } from '@/ui/table/hooks/useUpsertEntityTableItem';
|
|
import { useUpsertTableRowId } from '@/ui/table/hooks/useUpsertTableRowId';
|
|
import { TableRecoilScopeContext } from '@/ui/table/states/recoil-scope-contexts/TableRecoilScopeContext';
|
|
import { RecoilScope } from '@/ui/utilities/recoil-scope/components/RecoilScope';
|
|
import { useInsertOnePersonMutation } from '~/generated/graphql';
|
|
|
|
const StyledTableContainer = styled.div`
|
|
display: flex;
|
|
width: 100%;
|
|
`;
|
|
|
|
export function People() {
|
|
const [insertOnePerson] = useInsertOnePersonMutation();
|
|
const upsertEntityTableItem = useUpsertEntityTableItem();
|
|
const upsertTableRowIds = useUpsertTableRowId();
|
|
const { triggerOptimisticEffects } = useOptimisticEffect();
|
|
|
|
async function handleAddButtonClick() {
|
|
const newPersonId: string = v4();
|
|
await insertOnePerson({
|
|
variables: {
|
|
data: {
|
|
id: newPersonId,
|
|
firstName: '',
|
|
lastName: '',
|
|
},
|
|
},
|
|
update: (_cache, { data }) => {
|
|
if (data?.createOnePerson) {
|
|
upsertTableRowIds(data?.createOnePerson.id);
|
|
upsertEntityTableItem(data?.createOnePerson);
|
|
triggerOptimisticEffects('Person', [data?.createOnePerson]);
|
|
}
|
|
},
|
|
});
|
|
}
|
|
|
|
return (
|
|
<SpreadsheetImportProvider>
|
|
<PageContainer>
|
|
<PageHeader title="People" Icon={IconUser}>
|
|
<RecoilScope CustomRecoilScopeContext={DropdownRecoilScopeContext}>
|
|
<PageHotkeysEffect onAddButtonClick={handleAddButtonClick} />
|
|
<PageAddButton onClick={handleAddButtonClick} />
|
|
</RecoilScope>
|
|
</PageHeader>
|
|
<PageBody>
|
|
<RecoilScope
|
|
scopeId="people"
|
|
CustomRecoilScopeContext={TableRecoilScopeContext}
|
|
>
|
|
<StyledTableContainer>
|
|
<PeopleTable />
|
|
</StyledTableContainer>
|
|
<EntityTableActionBar />
|
|
<EntityTableContextMenu />
|
|
</RecoilScope>
|
|
</PageBody>
|
|
</PageContainer>
|
|
</SpreadsheetImportProvider>
|
|
);
|
|
}
|