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 { DeleteButton, EditButton, ListButton, RefreshButton, Breadcrumb, } from "@components"; import { ShowProps } from "../types"; export const Show: React.FC = (props) => { const { children, resource: resourceFromProps, recordItemId, canDelete, canEdit, dataProviderName, isLoading, footerButtons: footerButtonsFromProps, footerButtonProps, headerButtons: headerButtonsFromProps, headerButtonProps, wrapperProps, contentProps, headerProps, goBack: goBackFromProps, breadcrumb: breadcrumbFromProps, title, } = props; const translate = useTranslate(); const { goBack, list } = useNavigation(); const resourceWithRoute = useResourceWithRoute(); const { useParams } = useRouterContext(); const { resource: routeResourceName, action: routeFromAction, id: idFromRoute, } = useParams(); const resource = resourceWithRoute(resourceFromProps ?? routeResourceName); const isDeleteButtonVisible = canDelete ?? resource.canDelete; const isEditButtonVisible = canEdit ?? resource.canEdit; const { options } = useRefineContext(); const breadcrumb = typeof breadcrumbFromProps === "undefined" ? options?.breadcrumb : breadcrumbFromProps; const breadcrumbComponent = typeof breadcrumb !== "undefined" ? ( <>{breadcrumb} ?? undefined ) : ( ); const id = recordItemId ?? idFromRoute; const loadingOverlayVisible = isLoading ?? false; const defaultHeaderButtons = ( <> {!recordItemId && ( )} {isEditButtonVisible && ( )} {isDeleteButtonVisible && ( list(resource.route ?? resource.name)} dataProviderName={dataProviderName} /> )} ); const buttonBack = goBackFromProps === (false || null) ? null : ( {typeof goBackFromProps !== "undefined" ? ( goBackFromProps ) : ( )} ); const headerButtons = headerButtonsFromProps ? typeof headerButtonsFromProps === "function" ? headerButtonsFromProps({ defaultButtons: defaultHeaderButtons, }) : headerButtonsFromProps : defaultHeaderButtons; const footerButtons = footerButtonsFromProps ? typeof footerButtonsFromProps === "function" ? footerButtonsFromProps({ defaultButtons: null }) : footerButtonsFromProps : null; return ( {breadcrumbComponent} {buttonBack} {title ?? ( {translate( `${resource.name}.titles.show`, `Show ${userFriendlyResourceName( resource.label ?? resource.name, "singular", )}`, )} )} {headerButtons} {children} {footerButtons} ); };