<Show> provides us a layout for displaying the page. It does not contain any logic and just adds extra functionalities like a refresh button or giving title to the page.
We will show what <Show> does using properties with examples.
localhost:3000/posts/show/123
Show Code Hide Code import   React   from   "react" ; import   {  useShow ,  useOne  }   from   "@refinedev/core" ; import   {    Show ,    NumberField ,    TextFieldComponent   as   TextField ,    MarkdownField ,    DateField , }   from   "@refinedev/mui" ; import   {   Stack ,   Typography   }   from   "@mui/material" ; const   ShowPage   =   ( )   =>   {    const   {     result :  product ,     query :   {  isLoading  } ,    }   =   useShow ( ) ;    const   {     result :  category ,     query :   {  isLoading :  categoryIsLoading  } ,    }   =   useOne ( {     resource :   "categories" ,     id :  product ?. category ?. id  ||   "" ,     queryOptions :   {       enabled :   ! ! product ,      } ,    } ) ;    return   (      < Show   isLoading = { isLoading } >        < Stack   gap = { 1 } >          < Typography   variant = " body1 "   fontWeight = " bold " >           Id          </ Typography >          < NumberField   value = { product ?. id  ??   "" }   />          < Typography   variant = " body1 "   fontWeight = " bold " >           Title          </ Typography >          < TextField   value = { product ?. title }   />          < Typography   variant = " body1 "   fontWeight = " bold " >           Content          </ Typography >          < MarkdownField   value = { product ?. content }   />          < Typography   variant = " body1 "   fontWeight = " bold " >           Category          </ Typography >          { categoryIsLoading  ?   < > Loading... </ >   :   < > { category ?. title } </ > }          < Typography   variant = " body1 "   fontWeight = " bold " >           Created At          </ Typography >          < DateField   value = { product ?. createdAt }   />        </ Stack >      </ Show >    ) ; } ; Good to know : 
You can swizzle this component with the Refine CLI 
Properties  title  title allows the addition of titles inside the <Show> component. if you don't pass title props it uses the "Show" prefix and the singular resource name by default. For example, for the "posts" resource, it would be "Show post".
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; import   {   Typography   }   from   "@mui/material" ; const   ShowPage :   React . FC   =   ( )   =>   {    return   (      < Show        title = { < Typography   variant = " h5 " > Custom Title </ Typography > }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; resource  The <Show> component reads the resource information from the route by default. If you want to use a custom resource for the <Show> component, you can use the resource prop.
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; const   CustomPage :   React . FC   =   ( )   =>   {    return   (      < Show   resource = " posts "   recordItemId = { 123 } >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; If you have multiple resources with the same name, you can pass the identifier instead of the name of the resource. It will only be used as the main matching key for the resource, data provider methods will still work with the name of the resource defined in the <Refine/> component.
For more information, refer to the identifier of the <Refine/> component documentation →
canDelete and canEdit  canDelete and canEdit allows us to add the delete and edit buttons inside the <Show> component. If the resource has canDelete or canEdit property Refine adds the buttons by default.
When clicked on, delete button executes the useDeletedataProvider
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; import   {  usePermissions  }   from   "@refinedev/core" ; const   ShowPage :   React . FC   =   ( )   =>   {    const   {  data :  permissionsData  }   =   usePermissions ( ) ;    return   (      < Show        canDelete = { permissionsData ?. includes ( "admin" ) }        canEdit = {         permissionsData ?. includes ( "editor" )   ||         permissionsData ?. includes ( "admin" )        }      >        < p > Rest of your page here </ p >      </ Show >    ) ; } ; For more information, refer to the <DeleteButton> →<EditButton> →usePermission →
If the resource has the canDelete property and you want to customize this button, you can use the deleteButtonProps property like the code below.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; import   {  usePermissions  }   from   "@refinedev/core" ; const   ShowPage :   React . FC   =   ( )   =>   {    const   {  data :  permissionsData  }   =   usePermissions ( ) ;    return   (      < Show        canDelete = { permissionsData ?. includes ( "admin" ) }        deleteButtonProps = { {  size :   "small"   } }        canEdit = {         permissionsData ?. includes ( "editor" )   ||         permissionsData ?. includes ( "admin" )        }      >        < p > Rest of your page here </ p >      </ Show >    ) ; } ; recordItemId  <Show> component reads the id information from the route by default. recordItemId is used when it cannot read from the URL (when used on a custom page, modal or drawer).
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; const   CustomPage :   React . FC   =   ( )   =>   {    return   (      < Show   resource = " posts "   recordItemId = { 123 } >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; <Show> component needs the id information for <RefreshButton>
dataProviderName  If not specified, Refine will use the default data provider. If you have multiple data providers and want to use a different one, you can use the dataProviderName property.
import   {   Refine   }   from   "@refinedev/core" ; import   dataProvider   from   "@refinedev/simple-rest" ; import   {   Show   }   from   "@refinedev/mui" ; const   PostShow   =   ( )   =>   {    return   < Show   dataProviderName = " other " > ... </ Show > ; } ; export   const   App :   React . FC   =   ( )   =>   {    return   (      < Refine        dataProvider = { {          default :   dataProvider ( "https://api.fake-rest.refine.dev/" ) ,         other :   dataProvider ( "https://other-api.fake-rest.refine.dev/" ) ,        } }      >        { }      </ Refine >    ) ; } ; goBack  To customize the back button or to disable it, you can use the goBack property.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; import   {   Button   }   from   "@mui/material" ; import   {  useBack  }   from   "@refinedev/core" ; const   BackButton   =   ( )   =>   {    const  goBack  =   useBack ( ) ;    return   < Button   onClick = { goBack } > BACK! </ Button > ; } ; const   PostShow :   React . FC   =   ( )   =>   {    return   (      < Show        goBack = { < BackButton   /> }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; isLoading  To toggle the loading state of the <Show/> component, you can use the isLoading property.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; const   PostShow :   React . FC   =   ( )   =>   {    const   [ loading ,  setLoading ]   =   React . useState ( true ) ;    return   (      < Show        isLoading = { loading }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; breadcrumb   To customize or disable the breadcrumb, you can use the breadcrumb property. By default it uses the Breadcrumb component from @refinedev/mui package.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show ,   Breadcrumb   }   from   "@refinedev/mui" ; const   PostShow :   React . FC   =   ( )   =>   {    return   (      < Show        breadcrumb = {          < div            style = { {             padding :   "3px 6px" ,             border :   "2px dashed cornflowerblue" ,            } }          >            < Breadcrumb   />          </ div >        }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; For more information, refer to the Breadcrumb documentation →
wrapperProps  If you want to customize the wrapper of the <Show/> component, you can use the wrapperProps property.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; const   PostShow :   React . FC   =   ( )   =>   {    const   [ loading ,  setLoading ]   =   React . useState ( true ) ;    return   (      < Show        wrapperProps = { {         sx :   {           backgroundColor :   "lightsteelblue" ,          } ,        } }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; For more information, refer to the Card documentation from Material UI →
If you want to customize the header of the <Show/> component, you can use the headerProps property.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; const   PostShow :   React . FC   =   ( )   =>   {    const   [ loading ,  setLoading ]   =   React . useState ( true ) ;    return   (      < Show        headerProps = { {         sx :   {           backgroundColor :   "lightsteelblue" ,          } ,        } }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; For more information, refer to the CardHeader documentation from Material UI →
contentProps  If you want to customize the content of the <Show/> component, you can use the contentProps property.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; const   PostShow :   React . FC   =   ( )   =>   {    const   [ loading ,  setLoading ]   =   React . useState ( true ) ;    return   (      < Show        contentProps = { {         sx :   {           backgroundColor :   "lightsteelblue" ,          } ,        } }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; For more information, refer to the CardContent documentation from Material UI →
By default, the <Show/> component has a <ListButton><EditButton><DeleteButton><RefreshButton>
You can customize the buttons at the header by using the headerButtons property. It accepts React.ReactNode or a render function ({ defaultButtons, deleteButtonProps, editButtonProps, listButtonProps, refreshButtonProps }) => React.ReactNode which you can use to keep the existing buttons and add your own.
If "list" resource is not defined, the <ListButton>listButtonProps will be undefined.
If canDeletefalse, the <DeleteButton>deleteButtonProps will be undefined.
If canEditfalse, <EditButton>editButtonProps will be undefined.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; import   {   Button   }   from   "@mui/material" ; const   PostShow :   React . FC   =   ( )   =>   {    const   [ loading ,  setLoading ]   =   React . useState ( true ) ;    return   (      < Show        headerButtons = { ( {  defaultButtons  } )   =>   (          < >            { defaultButtons }            < Button   type = " primary " > Custom Button </ Button >          </ >        ) }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; Or, instead of using the defaultButtons, you can create your own buttons:
localhost:3000/posts/show/123
Show Code Hide Code import   {    Show ,    ListButton ,    EditButton ,    DeleteButton ,    RefreshButton , }   from   "@refinedev/mui" ; import   {   Button   }   from   "@mui/material" ; const   PostShow :   React . FC   =   ( )   =>   {    const   [ loading ,  setLoading ]   =   React . useState ( true ) ;    return   (      < Show       headerButtons = { ( {         deleteButtonProps ,         editButtonProps ,         listButtonProps ,         refreshButtonProps ,        } )   =>   (          < >            < Button   type = " primary " > Custom Button </ Button >            { listButtonProps  &&   (              < ListButton   { ... listButtonProps }   meta = { {  foo :   "bar"   } }   />            ) }            { editButtonProps  &&   (              < EditButton   { ... editButtonProps }   meta = { {  foo :   "bar"   } }   />            ) }            { deleteButtonProps  &&   (              < DeleteButton   { ... deleteButtonProps }   meta = { {  foo :   "bar"   } }   />            ) }            < RefreshButton   { ... refreshButtonProps }   meta = { {  foo :   "bar"   } }   />          </ >        ) }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; You can customize the wrapper element of the buttons at the header by using the headerButtonProps property.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; import   {   Button   }   from   "@mui/material" ; const   PostShow :   React . FC   =   ( )   =>   {    const   [ loading ,  setLoading ]   =   React . useState ( true ) ;    return   (      < Show        headerButtonProps = { {         sx :   {           backgroundColor :   "lightsteelblue" ,          } ,        } }        headerButtons = { ( {  defaultButtons  } )   =>   (          < >            { defaultButtons }            < Button   type = " primary " > Custom Button </ Button >          </ >        ) }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; You can customize the buttons at the footer by using the footerButtons property. It accepts React.ReactNode or a render function ({ defaultButtons }) => React.ReactNode which you can use to keep the existing buttons and add your own.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; import   {   Button   }   from   "@mui/material" ; const   PostShow :   React . FC   =   ( )   =>   {    const   [ loading ,  setLoading ]   =   React . useState ( true ) ;    return   (      < Show        footerButtons = { ( {  defaultButtons  } )   =>   (          < >            { defaultButtons }            < Button   type = " primary " > Custom Button </ Button >          </ >        ) }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; You can customize the wrapper element of the buttons at the footer by using the footerButtonProps property.
localhost:3000/posts/show/123
Show Code Hide Code import   {   Show   }   from   "@refinedev/mui" ; import   {   Button   }   from   "@mui/material" ; const   PostShow :   React . FC   =   ( )   =>   {    const   [ loading ,  setLoading ]   =   React . useState ( true ) ;    return   (      < Show        footerButtonProps = { {         sx :   {           backgroundColor :   "lightsteelblue" ,          } ,        } }        footerButtons = { ( {  defaultButtons  } )   =>   (          < >            { defaultButtons }            < Button   type = " primary " > Custom Button </ Button >          </ >        ) }      >        < span > Rest of your page here </ span >      </ Show >    ) ; } ; For more information, refer to the CardActions documentation from Material UI →
API Reference  Properties  Property Type Description Default resource 
Resource name for API data interactions
Reads :resource from the URL
title 
Title of the edit view
Show {resource.name}
wrapperProps 
Props for the wrapper component of the view
headerProps 
Props for the header component
contentProps 
Props for the content wrapper component
breadcrumb 
Breadcrumb to be displayed in the header
<Breadcrumb/>
goBack 
Back button element at the top left of the page
<ArrowLeft />
headerButtons 
ActionButtonRenderer<{ editButtonProps: EditButtonProps; deleteButtonProps: DeleteButtonProps; refreshButtonProps: RefreshButtonProps
undefined; listButtonProps: ListButtonProps
undefined; }>
Header action buttons to be displayed in the header
ListButtonEditButtonDeleteButtonRefreshButton
headerButtonProps 
Additional props to be passed to the wrapper of the header buttons
footerButtons 
ActionButtonRenderer<Record<string
number
symbol, unknown>>
Footer action buttons to be displayed in the footer
null
footerButtonProps 
Additional props to be passed to the wrapper of the footer buttons
dataProviderName 
To specify a data provider other than default use this property
isLoading 
Loading state of the component
canDelete 
Adds a <DeleteButton />
If the resource has canDelete prop it is true else false
deleteButtonProps 
Adds properties for <DeleteButton />
canEdit 
Adds a <EditButton />
If the resource is passed a edit component, true else false
recordItemId 
The record id for <RefreshButton />