2. Create a data provider with swizzle
What is swizzle?โ
In some cases, Refine's built-in data providers may not fully meet your API needs, and you may want to edit the existing data provider logic. If that is the case, you should use swizzle
.
The swizzle
is a command in refine-cli
that allows you to customize Refineโs supported components and data providers by letting you eject selected files from the Refine packages and modify them depending on your needs.
This also allows you to use the ejected file code logic as a starting point for your modifications instead of starting from scratch.
How do you use swizzle to create an data provider?โ
Run the
swizzle
command in the project directory:npm run refine swizzle
Select the data provider package of your choice from the list. We are using
@refinedev/simple-rest
in this tutorial so we will choose that.? Which package do you want to swizzle?
Data Provider
โฏ @refinedev/simple-rest
UI Framework
@refinedev/antdswizzle
will copy the necessary files for this package to thesrc/rest-data-provider
folderSuccessfully swizzled Data Provider
Files created:
- src/rest-data-provider/index.ts
- src/rest-data-provider/utils/axios.ts
- src/rest-data-provider/utils/generateFilter.ts
- src/rest-data-provider/utils/generateSort.ts
- src/rest-data-provider/utils/mapOperator.ts
- src/rest-data-provider/utils/index.ts
Warning:
You will also need to add axios to your project dependencies.
Usage
โญ App.tsx โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฎ
โ โ
โ import { dataProvider } from "./rest-data-provider"; โ
โ โ
โ const App = () => { โ
โ return ( โ
โ <Refine โ
โ dataProvider={dataProvider} โ
โ /* ... */ โ
โ /> โ
โ ); โ
โ } โ
โ โ
โฐโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฏTo use the generated data provider, we need to import it in the
App.tsx
file and give it as adataProvider
prop to theRefine
component.
And with that, you are now able to modify and use the ejected data provider however you want. Amount of time saved using swizzle
instead of creating a data provider from scratch is quite substantial.