import { ReactNode } from 'react'; import { useTheme } from '@emotion/react'; import styled from '@emotion/styled'; import { ObjectMetadataItem } from '@/object-metadata/types/ObjectMetadataItem'; import { useFindManyObjectRecords } from '@/object-record/hooks/useFindManyObjectRecords'; import { Tag } from '@/ui/display/tag/components/Tag'; import { useLazyLoadIcon } from '@/ui/input/hooks/useLazyLoadIcon'; import { TableCell } from '@/ui/layout/table/components/TableCell'; import { TableRow } from '@/ui/layout/table/components/TableRow'; type SettingsObjectItemTableRowProps = { action: ReactNode; objectItem: ObjectMetadataItem; onClick?: () => void; }; export const StyledObjectTableRow = styled(TableRow)` grid-template-columns: 180px 98.7px 98.7px 98.7px 36px; `; const StyledNameTableCell = styled(TableCell)` color: ${({ theme }) => theme.font.color.primary}; gap: ${({ theme }) => theme.spacing(2)}; `; const StyledActionTableCell = styled(TableCell)` justify-content: center; padding-right: ${({ theme }) => theme.spacing(1)}; `; export const SettingsObjectItemTableRow = ({ action, objectItem, onClick, }: SettingsObjectItemTableRowProps) => { const theme = useTheme(); const { objects } = useFindManyObjectRecords({ objectNamePlural: objectItem.namePlural, }); const { Icon } = useLazyLoadIcon(objectItem.icon ?? ''); return ( {!!Icon && } {objectItem.labelPlural} {objectItem.isCustom ? ( ) : ( )} {objectItem.fields.length} {objects.length} {action} ); };