Skip to main content
Version: 3.xx.xx

Inferencer

You can automatically generate views for your resources using @pankod/refine-inferencer. Inferencer exports MantineListInferencer, MantineShowInferencer, MantineCreateInferencer and MantineEditInferencer components.

Usage

Mantine components can be imported from @pankod/refine-inferencer/mantine. You can directly use the components in resources prop of Refine component or you can use them in your custom components by passing the resource prop as the resource name.

import {
Layout,
MantineProvider,
LightTheme,
Global,
} from "@pankod/refine-mantine";
import {
MantineListInferencer,
MantineShowInferencer,
MantineCreateInferencer,
MantineEditInferencer,
} from "@pankod/refine-inferencer/mantine";

const App = () => {
return (
<MantineProvider theme={LightTheme} withNormalizeCSS withGlobalStyles>
<Global styles={{ body: { WebkitFontSmoothing: "auto" } }} />
<Refine
resources={[
{
name: "samples",
list: MantineListInferencer,
show: MantineShowInferencer,
create: MantineCreateInferencer,
edit: MantineEditInferencer,
},
]}
/>
</MantineProvider>
);
};
info

To learn more about @pankod/refine-inferencer package, please check out Docs

Views

MantineListInferencer

Generates a sample list view for your resources according to the API response. It uses List component and from @pankod/refine-mantine and useTable hook from @pankod/refine-react-table.

http://localhost:3000/samples
import { Refine } from "@pankod/refine-core";
import {
Layout,
MantineProvider,
LightTheme,
Global,
} from "@pankod/refine-mantine";
import routerProvider from "@pankod/refine-react-router-v6";
import dataProvider from "@pankod/refine-simple-rest";

import {
MantineListInferencer,
MantineShowInferencer,
MantineCreateInferencer,
MantineEditInferencer,
} from "@pankod/refine-inferencer/mantine";

const API_URL = "https://api.fake-rest.refine.dev";

const App: React.FC = () => {
return (
<MantineProvider theme={LightTheme} withNormalizeCSS withGlobalStyles>
<Global styles={{ body: { WebkitFontSmoothing: "auto" } }} />
<Refine
routerProvider={routerProvider}
dataProvider={dataProvider(API_URL)}
Layout={Layout}
resources={[
{
name: "samples",
list: MantineListInferencer,
show: MantineShowInferencer,
create: MantineCreateInferencer,
edit: MantineEditInferencer,
canDelete: true,
},
{
name: "categories",
list: MantineListInferencer,
show: MantineShowInferencer,
},
{
name: "tags",
list: MantineListInferencer,
show: MantineShowInferencer,
},
]}
/>
</MantineProvider>
);
};

MantineShowInferencer

Generates a sample show view for your resources according to the API response. It uses Show and field components from @pankod/refine-mantine with useShow hook from @pankod/refine-core.

http://localhost:3000/samples/show/123
import { Refine } from "@pankod/refine-core";
import {
Layout,
MantineProvider,
LightTheme,
Global,
} from "@pankod/refine-mantine";
import routerProvider from "@pankod/refine-react-router-v6";
import dataProvider from "@pankod/refine-simple-rest";

import {
MantineListInferencer,
MantineShowInferencer,
MantineCreateInferencer,
MantineEditInferencer,
} from "@pankod/refine-inferencer/mantine";

const API_URL = "https://api.fake-rest.refine.dev";

const App: React.FC = () => {
return (
<MantineProvider theme={LightTheme} withNormalizeCSS withGlobalStyles>
<Global styles={{ body: { WebkitFontSmoothing: "auto" } }} />
<Refine
routerProvider={routerProvider}
dataProvider={dataProvider(API_URL)}
Layout={Layout}
resources={[
{
name: "samples",
list: MantineListInferencer,
show: MantineShowInferencer,
create: MantineCreateInferencer,
edit: MantineEditInferencer,
canDelete: true,
},
{
name: "categories",
list: MantineListInferencer,
show: MantineShowInferencer,
},
{
name: "tags",
list: MantineListInferencer,
show: MantineShowInferencer,
},
]}
/>
</MantineProvider>
);
};

MantineCreateInferencer

Generates a sample create view for your resources according to the first record in list API response. It uses Create component and useForm hook from @pankod/refine-mantine.

http://localhost:3000/samples/create
import { Refine } from "@pankod/refine-core";
import {
Layout,
MantineProvider,
LightTheme,
Global,
} from "@pankod/refine-mantine";
import routerProvider from "@pankod/refine-react-router-v6";
import dataProvider from "@pankod/refine-simple-rest";

import {
MantineListInferencer,
MantineShowInferencer,
MantineCreateInferencer,
MantineEditInferencer,
} from "@pankod/refine-inferencer/mantine";

const API_URL = "https://api.fake-rest.refine.dev";

const App: React.FC = () => {
return (
<MantineProvider theme={LightTheme} withNormalizeCSS withGlobalStyles>
<Global styles={{ body: { WebkitFontSmoothing: "auto" } }} />
<Refine
routerProvider={routerProvider}
dataProvider={dataProvider(API_URL)}
Layout={Layout}
resources={[
{
name: "samples",
list: MantineListInferencer,
show: MantineShowInferencer,
create: MantineCreateInferencer,
edit: MantineEditInferencer,
canDelete: true,
},
{
name: "categories",
list: MantineListInferencer,
show: MantineShowInferencer,
},
{
name: "tags",
list: MantineListInferencer,
show: MantineShowInferencer,
},
]}
/>
</MantineProvider>
);
};

MantineEditInferencer

Generates a sample edit view for your resources according to the API response. It uses Edit component and useForm hook from @pankod/refine-mantine.

http://localhost:3000/samples/edit/123
import { Refine } from "@pankod/refine-core";
import {
Layout,
MantineProvider,
LightTheme,
Global,
} from "@pankod/refine-mantine";
import routerProvider from "@pankod/refine-react-router-v6";
import dataProvider from "@pankod/refine-simple-rest";

import {
MantineListInferencer,
MantineShowInferencer,
MantineCreateInferencer,
MantineEditInferencer,
} from "@pankod/refine-inferencer/mantine";

const API_URL = "https://api.fake-rest.refine.dev";

const App: React.FC = () => {
return (
<MantineProvider theme={LightTheme} withNormalizeCSS withGlobalStyles>
<Global styles={{ body: { WebkitFontSmoothing: "auto" } }} />
<Refine
routerProvider={routerProvider}
dataProvider={dataProvider(API_URL)}
Layout={Layout}
resources={[
{
name: "samples",
list: MantineListInferencer,
show: MantineShowInferencer,
create: MantineCreateInferencer,
edit: MantineEditInferencer,
canDelete: true,
},
{
name: "categories",
list: MantineListInferencer,
show: MantineShowInferencer,
},
{
name: "tags",
list: MantineListInferencer,
show: MantineShowInferencer,
},
]}
/>
</MantineProvider>
);
};

Live StackBlitz Example

Below you'll find a Live StackBlitz Example displaying a fully setup Refine app with @pankod/refine-inferencer/mantine components.