import { useEffect } from 'react'; import { useNavigate, useParams } from 'react-router-dom'; import styled from '@emotion/styled'; import { SettingsPageContainer } from '@/settings/components/SettingsPageContainer'; import { activeFieldItems, activeObjectItems, disabledFieldItems, } from '@/settings/data-model/constants/mockObjects'; import { SettingsObjectFieldItemTableRow, StyledObjectFieldTableRow, } from '@/settings/data-model/object-details/components/SettingsObjectFieldItemTableRow'; import { AppPath } from '@/types/AppPath'; import { IconMinus, IconPlus, IconSettings } from '@/ui/display/icon'; import { H2Title } from '@/ui/display/typography/components/H2Title'; import { Button } from '@/ui/input/button/components/Button'; import { SubMenuTopBarContainer } from '@/ui/layout/page/SubMenuTopBarContainer'; import { Section } from '@/ui/layout/section/components/Section'; import { Table } from '@/ui/layout/table/components/Table'; import { TableHeader } from '@/ui/layout/table/components/TableHeader'; import { TableSection } from '@/ui/layout/table/components/TableSection'; import { Breadcrumb } from '@/ui/navigation/bread-crumb/components/Breadcrumb'; const StyledSection = styled(Section)` display: flex; flex-direction: column; `; const StyledAddCustomFieldButton = styled(Button)` align-self: flex-end; margin-top: ${({ theme }) => theme.spacing(2)}; `; export const SettingsObjectNewFieldStep1 = () => { const navigate = useNavigate(); const { pluralObjectName = '' } = useParams(); const activeObject = activeObjectItems.find( (activeObject) => activeObject.name.toLowerCase() === pluralObjectName, ); useEffect(() => { if (!activeObject) navigate(AppPath.NotFound); }, [activeObject, navigate]); return ( Name Field type Data type {activeFieldItems.map((fieldItem) => ( ))} {!!disabledFieldItems.length && ( {disabledFieldItems.map((fieldItem) => ( ))} )}
navigate(`/settings/objects/${pluralObjectName}/new-field/step-2`) } />
); };