Skip to main content
Version: 3.xx.xx

Text

This field lets you show basic text. It uses Material UI <Typography> component.

Usage

Let's see how to use it in a basic list page:

src/pages/posts/list.tsx
import { useTable, useMany } from "@pankod/refine-core";
import {
Table,
TableBody,
TableCell,
TableHead,
TableRow,
List,
TextFieldComponent,
} from "@pankod/refine-mui";

export const PostList: React.FC = () => {
const { tableQueryResult } = useTable<IPost>({
initialSorter: [
{
field: "id",
order: "asc",
},
],
});

const categoryIds =
tableQueryResult?.data?.data?.map((post) => post.categoryId) || [];

const { data: categoriesData, isLoading } = useMany<ICategory>({
resource: "categories",
ids: categoryIds,
queryOptions: {
enabled: categoryIds.length > 0,
},
});

const { data } = tableQueryResult;

return (
<List>
<Table aria-label="simple table">
<TableHead>
<TableRow>
<TableCell>Title</TableCell>
<TableCell>Category</TableCell>
</TableRow>
</TableHead>
<TableBody>
{data?.data.map((row) => (
<TableRow key={row.title}>
<TableCell component="th" scope="row">
{row.title}
</TableCell>
<TableCell>
<TextFieldComponent
value={
isLoading
? "Loading..."
: categoriesData?.data.find(
(item) => item.id === row.id,
)?.title
}
/>
</TableCell>
</TableRow>
))}
</TableBody>
</Table>
</List>
);
};

interface IPost {
id: number;
title: string;
categoryId: string;
}

interface ICategory {
id: number;
title: string;
}

TagField

API Reference

Properties

External Props

It also accepts all props of Material UI Typography.