import React from "react"; import { Box, Card, Group, ActionIcon, Stack, Title, LoadingOverlay, } from "@mantine/core"; import { ResourceRouterParams, useNavigation, useRefineContext, useResourceWithRoute, userFriendlyResourceName, useRouterContext, useTranslate, } from "@pankod/refine-core"; import { IconArrowLeft } from "@tabler/icons"; import { SaveButton, Breadcrumb } from "@components"; import { CreateProps } from "../types"; export const Create: React.FC = (props) => { const { children, saveButtonProps, isLoading, resource: resourceFromProps, footerButtons: footerButtonsFromProps, footerButtonProps, headerButtons: headerButtonsFromProps, headerButtonProps, wrapperProps, contentProps, headerProps, goBack: goBackFromProps, breadcrumb: breadcrumbFromProps, title, } = props; const translate = useTranslate(); const { goBack } = useNavigation(); const { useParams } = useRouterContext(); const { resource: routeResourceName, action: routeFromAction } = useParams(); const resourceWithRoute = useResourceWithRoute(); const resource = resourceWithRoute(resourceFromProps ?? routeResourceName); const { options } = useRefineContext(); const breadcrumb = typeof breadcrumbFromProps === "undefined" ? options?.breadcrumb : breadcrumbFromProps; const breadcrumbComponent = typeof breadcrumb !== "undefined" ? ( <>{breadcrumb} ?? undefined ) : ( ); const loadingOverlayVisible = isLoading ?? saveButtonProps?.disabled ?? false; const defaultFooterButtons = ( ); const buttonBack = goBackFromProps === (false || null) ? null : ( {typeof goBackFromProps !== "undefined" ? ( goBackFromProps ) : ( )} ); const headerButtons = headerButtonsFromProps ? typeof headerButtonsFromProps === "function" ? headerButtonsFromProps({ defaultButtons: null, }) : headerButtonsFromProps : null; const footerButtons = footerButtonsFromProps ? typeof footerButtonsFromProps === "function" ? footerButtonsFromProps({ defaultButtons: defaultFooterButtons }) : footerButtonsFromProps : defaultFooterButtons; return ( {breadcrumbComponent} {buttonBack} {title ?? ( {translate( `${resource.name}.titles.create`, `Create ${userFriendlyResourceName( resource.label ?? resource.name, "singular", )}`, )} )} {headerButtons} {children} {footerButtons} ); };