documentation/docs/ui-integrations/ant-design/components/buttons/export-button/index.md
<ExportButton> is an Ant Design <Button> with a default export icon and a "Export" text. It only has presentational value.
For more information, refer to the
useExportdocumentation →
:::simple Good to know
You can swizzle this component to customize it with the Refine CLI
:::
You can use it like any other Ant Design <Button>.
For example, you can use it with useExport:
setInitialRoutes(["/posts"]);
// visible-block-start
import { useExport } from "@refinedev/core";
import {
List,
useTable,
// highlight-next-line
ExportButton,
} from "@refinedev/antd";
import { Table } from "antd";
const PostList: React.FC = () => {
const { tableProps } = useTable<IPost>();
const { triggerExport, isLoading: exportLoading } = useExport<IPost>();
return (
<List
headerButtons={
// highlight-start
<ExportButton onClick={triggerExport} loading={exportLoading} />
// highlight-end
}
>
<Table {...tableProps} rowKey="id">
<Table.Column dataIndex="id" title="ID" />
<Table.Column dataIndex="title" title="Title" />
</Table>
</List>
);
};
interface IPost {
id: number;
title: string;
}
// visible-block-end
render(
<ReactRouter.BrowserRouter>
<RefineAntdDemo
resources={[
{
name: "posts",
list: "/posts",
},
]}
>
<ReactRouter.Routes>
<ReactRouter.Route
path="/posts"
element={
<div style={{ padding: 16 }}>
<ReactRouter.Outlet />
</div>
}
>
<ReactRouter.Route index element={<PostList />} />
</ReactRouter.Route>
</ReactRouter.Routes>
</RefineAntdDemo>
</ReactRouter.BrowserRouter>,
);
hideText is used to hide the text of the button. When its true, only the button icon will be visible.
setInitialRoutes(["/posts"]);
// visible-block-start
import { ExportButton } from "@refinedev/antd";
const MyExportComponent = () => {
return (
<ExportButton
// highlight-next-line
hideText={true}
/>
);
};
// visible-block-end
render(
<ReactRouter.BrowserRouter>
<RefineAntdDemo
resources={[
{
name: "posts",
list: "/posts",
},
]}
>
<ReactRouter.Routes>
<ReactRouter.Route
path="/posts"
element={
<div style={{ padding: 16 }}>
<ReactRouter.Outlet />
</div>
}
>
<ReactRouter.Route index element={<MyExportComponent />} />
</ReactRouter.Route>
</ReactRouter.Routes>
</RefineAntdDemo>
</ReactRouter.BrowserRouter>,
);
:::simple External Props
It also accepts all props of Ant Design Button.
:::