Skip to content

Latest commit

 

History

History
68 lines (54 loc) · 2.1 KB

ListBase.md

File metadata and controls

68 lines (54 loc) · 2.1 KB
layout title
default
The ListBase Component

<ListBase>

<ListBase> is a headless variant of <List>, as it does not render anything. <ListBase> calls useListController, puts the result in a ListContext, then renders its child.

If you want to display a record list in an entirely custom layout, i.e. use only the data fetching part of <List> and not the view layout, use <ListBase>.

Usage

You can use ListBase to create your own custom reusable List component, like this one:

import { 
    ListBase,
    Title,
    ListToolbar,
    Pagination,
    Datagrid,
} from 'react-admin';
import { Card } from '@mui/material';

const MyList = ({ children, actions, filters, title, ...props }) => (
    <ListBase {...props}>
        <Title title={title}/>
        <ListToolbar
            filters={filters}
            actions={actions}
        />
        <Card>
            {children}
        </Card>
        <Pagination />
    </ListBase>
);

const PostList = () => (
    <MyList title="Post List">
        <Datagrid>
            ...
        </Datagrid>
    </MyList>
);

This custom List component has no aside component - it's up to you to add it in pure React.

Props

The <ListBase> component accepts the same props as useListController:

These are a subset of the props accepted by <List> - only the props that change data fetching, and not the props related to the user interface.

In addition, <ListBase> renders its children components inside a ListContext. Check the <List children> documentation for usage examples.