documentation/docs/ui-integrations/material-ui/components/buttons/export-button/index.md
<ExportButton> is a Material UI <LoadingButton> with a default export icon and a default text with "Export". It only has presentational value.
For more information, refer to the useExport documentation →
:::simple Good to know
You can swizzle this component with the Refine CLI to customize it.
:::
Use it like any other Ant Design <Button>. You can use it with useExport:
setInitialRoutes(["/posts"]);
// visible-block-start
import { useExport } from "@refinedev/core";
import {
useDataGrid,
List,
// highlight-next-line
ExportButton,
} from "@refinedev/mui";
import { DataGrid, GridColDef } from "@mui/x-data-grid";
const columns: GridColDef[] = [
{ field: "id", headerName: "ID", type: "number" },
{ field: "title", headerName: "Title", minWidth: 400, flex: 1 },
];
const PostsList: React.FC = () => {
const { dataGridProps } = useDataGrid<IPost>();
const { triggerExport, isLoading: exportLoading } = useExport<IPost>();
return (
<List
// highlight-start
headerButtons={
<ExportButton onClick={triggerExport} loading={exportLoading} />
}
// highlight-end
>
<DataGrid {...dataGridProps} columns={columns} />
</List>
);
};
interface IPost {
id: number;
title: string;
}
// visible-block-end
render(
<ReactRouter.BrowserRouter>
<RefineMuiDemo
resources={[
{
name: "posts",
list: "/posts",
},
]}
>
<ReactRouter.Routes>
<ReactRouter.Route path="/posts" element={<ReactRouter.Outlet />}>
<ReactRouter.Route index element={<PostsList />} />
</ReactRouter.Route>
</ReactRouter.Routes>
</RefineMuiDemo>
</ReactRouter.BrowserRouter>,
);
hideText is used to show or hide text of the button. When true, only the button icon is visible.
setInitialRoutes(["/"]);
// visible-block-start
import { ExportButton } from "@refinedev/mui";
const MyExportComponent = () => {
return (
<ExportButton
// highlight-next-line
hideText={true}
/>
);
};
// visible-block-end
render(
<ReactRouter.BrowserRouter>
<RefineMuiDemo
resources={[
{
name: "posts",
list: "/posts",
},
]}
>
<ReactRouter.Routes>
<ReactRouter.Route index element={<MyExportComponent />} />
</ReactRouter.Routes>
</RefineMuiDemo>
</ReactRouter.BrowserRouter>,
);
:::simple External Props
It also accepts all props of Material UI Button.
:::