Skip to content

Commit

Permalink
Build empty state for remote tables
Browse files Browse the repository at this point in the history
  • Loading branch information
thomtrp committed May 29, 2024
1 parent ebb1aa0 commit bc6ca62
Show file tree
Hide file tree
Showing 5 changed files with 115 additions and 32 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,19 +34,28 @@ export const useFindManyParams = (
return { objectNameSingular, filter, orderBy };
};

export const useLoadRecordIndexTable = (objectNameSingular: string) => {
export const useLoadRecordIndexTable = (
objectNameSingular: string,
recordTableId?: string,
) => {
const { objectMetadataItem } = useObjectMetadataItem({
objectNameSingular,
});

const { setRecordTableData, setIsRecordTableInitialLoading } =
useRecordTable();
const { tableLastRowVisibleState } = useRecordTableStates();
const { setRecordTableData, setIsRecordTableInitialLoading } = useRecordTable(
{
recordTableId,
},
);
const { tableLastRowVisibleState } = useRecordTableStates(recordTableId);
const setLastRowVisible = useSetRecoilState(tableLastRowVisibleState);
const currentWorkspace = useRecoilValue(currentWorkspaceState);
const params = useFindManyParams(objectNameSingular);
const params = useFindManyParams(objectNameSingular, recordTableId);

const recordGqlFields = useRecordTableRecordGqlFields({ objectMetadataItem });
const recordGqlFields = useRecordTableRecordGqlFields({
objectMetadataItem,
recordTableId,
});

const {
records,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,12 @@ import { isDefined } from '~/utils/isDefined';

export const useRecordTableRecordGqlFields = ({
objectMetadataItem,
recordTableId,
}: {
objectMetadataItem: ObjectMetadataItem;
recordTableId?: string;
}) => {
const { visibleTableColumnsSelector } = useRecordTableStates();
const { visibleTableColumnsSelector } = useRecordTableStates(recordTableId);

const { imageIdentifierFieldMetadataItem, labelIdentifierFieldMetadataItem } =
getObjectMetadataIdentifierFields({ objectMetadataItem });
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,10 @@ import { useRecoilValue } from 'recoil';
import { MOBILE_VIEWPORT, RGBA } from 'twenty-ui';

import { useObjectMetadataItem } from '@/object-metadata/hooks/useObjectMetadataItem';
import { useLoadRecordIndexTable } from '@/object-record/record-index/hooks/useLoadRecordIndexTable';
import { RecordTableBody } from '@/object-record/record-table/components/RecordTableBody';
import { RecordTableBodyEffect } from '@/object-record/record-table/components/RecordTableBodyEffect';
import { RecordTableEmptyState } from '@/object-record/record-table/components/RecordTableEmptyState';
import { RecordTableHeader } from '@/object-record/record-table/components/RecordTableHeader';
import { RecordTableContext } from '@/object-record/record-table/contexts/RecordTableContext';
import { useHandleContainerMouseEnter } from '@/object-record/record-table/hooks/internal/useHandleContainerMouseEnter';
Expand Down Expand Up @@ -207,6 +209,14 @@ export const RecordTable = ({

const visibleTableColumns = useRecoilValue(visibleTableColumnsSelector());

const { tableRowIdsState } = useRecordTableStates(recordTableId);
const tableRowIds = useRecoilValue(tableRowIdsState);

const { loading } = useLoadRecordIndexTable(
objectNameSingular,
recordTableId,
);

return (
<RecordTableScope
recordTableScopeId={scopeId}
Expand All @@ -229,8 +239,14 @@ export const RecordTable = ({
<StyledTable className="entity-table-cell">
<RecordTableHeader createRecord={createRecord} />
<RecordTableBodyEffect objectNameSingular={objectNameSingular} />
<RecordTableBody objectNameSingular={objectNameSingular} />
<RecordTableBody
objectNameSingular={objectNameSingular}
tableRowIds={tableRowIds}
/>
</StyledTable>
{!loading && tableRowIds.length === 0 && (
<RecordTableEmptyState objectMetadataItem={objectMetadataItem} />
)}
</RecordTableContext.Provider>
)}
</RecordTableScope>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,34 +1,27 @@
import { useRecoilValue } from 'recoil';

import { RecordTableBodyFetchMoreLoader } from '@/object-record/record-table/components/RecordTableBodyFetchMoreLoader';
import { RecordTablePendingRow } from '@/object-record/record-table/components/RecordTablePendingRow';
import { RecordTableRow } from '@/object-record/record-table/components/RecordTableRow';
import { useRecordTableStates } from '@/object-record/record-table/hooks/internal/useRecordTableStates';

type RecordTableBodyProps = {
objectNameSingular: string;
tableRowIds: string[];
};

export const RecordTableBody = ({
objectNameSingular,
}: RecordTableBodyProps) => {
const { tableRowIdsState } = useRecordTableStates();

const tableRowIds = useRecoilValue(tableRowIdsState);

return (
<>
<tbody>
<RecordTablePendingRow />
{tableRowIds.map((recordId, rowIndex) => (
<RecordTableRow
key={recordId}
recordId={recordId}
rowIndex={rowIndex}
/>
))}
</tbody>
<RecordTableBodyFetchMoreLoader objectNameSingular={objectNameSingular} />
</>
);
};
tableRowIds,
}: RecordTableBodyProps) => (
<>
<tbody>
<RecordTablePendingRow />
{tableRowIds.map((recordId, rowIndex) => (
<RecordTableRow
key={recordId}
recordId={recordId}
rowIndex={rowIndex}
/>
))}
</tbody>
<RecordTableBodyFetchMoreLoader objectNameSingular={objectNameSingular} />
</>
);
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
import { useNavigate } from 'react-router-dom';
import { ThemeProvider, useTheme } from '@emotion/react';
import styled from '@emotion/styled';
import isEmpty from 'lodash.isempty';
import { IconSettings, THEME_LIGHT } from 'twenty-ui';

import { ObjectMetadataItem } from '@/object-metadata/types/ObjectMetadataItem';
import { Button } from '@/ui/input/button/components/Button';
import AnimatedPlaceholder from '@/ui/layout/animated-placeholder/components/AnimatedPlaceholder';
import {
AnimatedPlaceholderEmptyContainer,
AnimatedPlaceholderEmptySubTitle,
AnimatedPlaceholderEmptyTextContainer,
AnimatedPlaceholderEmptyTitle,
} from '@/ui/layout/animated-placeholder/components/EmptyPlaceholderStyled';

const StyledEmptyStateContainer = styled.div`
display: flex;
justify-content: center;
height: 100%;
width: 100%;
margin-top: ${({ theme }) => theme.spacing(8)};
`;

type RecordTableEmptyStateProps = {
objectMetadataItem: ObjectMetadataItem;
};

export const RecordTableEmptyState = ({
objectMetadataItem,
}: RecordTableEmptyStateProps) => {
const theme = useTheme();
const navigate = useNavigate();

// If the object is not remote, we do not show an empty state yet
if (!objectMetadataItem.isRemote) {
return <></>;
}

return (
<StyledEmptyStateContainer>
<ThemeProvider theme={isEmpty(theme) ? THEME_LIGHT : theme}>
<AnimatedPlaceholderEmptyContainer>
<AnimatedPlaceholder type="errorIndex" />
<AnimatedPlaceholderEmptyTextContainer>
<AnimatedPlaceholderEmptyTitle>
No Data Available for Remote Table
</AnimatedPlaceholderEmptyTitle>
<AnimatedPlaceholderEmptySubTitle>
If this is unexpected, please verify your settings.
</AnimatedPlaceholderEmptySubTitle>
</AnimatedPlaceholderEmptyTextContainer>
<Button
Icon={IconSettings}
title="Go to Settings"
variant={'secondary'}
onClick={() => () => navigate('/settings/integrations')}
/>
</AnimatedPlaceholderEmptyContainer>
</ThemeProvider>
</StyledEmptyStateContainer>
);
};

0 comments on commit bc6ca62

Please sign in to comment.