An open API service indexing awesome lists of open source software.

https://github.com/marmelab/shadcn-admin-kit

Component kit to build your Admin app with shadcn/ui
https://github.com/marmelab/shadcn-admin-kit

Last synced: 27 days ago
JSON representation

Component kit to build your Admin app with shadcn/ui

Awesome Lists containing this project

README

          

# Shadcn Admin Kit

![Screenshot](./public/shadcn-admin-kit.webp)

A component kit to build your Admin app with [shadcn/ui](https://ui.shadcn.com/).

[![Online Demo]][OnlineDemoLink]
[![Documentation]][DocumentationLink]

[Online Demo]: https://img.shields.io/badge/Online_Demo-blue?style=for-the-badge
[Documentation]: https://img.shields.io/badge/Documentation-blueviolet?style=for-the-badge

[OnlineDemoLink]: https://marmelab.com/shadcn-admin-kit/demo 'Online Demo'
[DocumentationLink]: https://marmelab.com/shadcn-admin-kit/docs 'Documentation'

## Features

- CRUD: working List, Show, Edit and Create pages
- Data Table with sorting, filtering, export, bulk actions, column selection, and pagination
- Form components with data binding and validation
- View and edit references (one-to-many, many-to-one)
- Sidebar menu
- Login, auth check & access control (compatible with any authentication backend)
- Dashboard page
- Scaffold the code based on the API response, using *Guessers*
- i18n support
- Light/dark mode
- Responsive
- Accessible
- Compatible with any API (REST, GraphQL, etc.)
- Works with Vite.js, Remix, Netx.js, and more

## Tech Stack

- UI: [shadcn/ui](https://ui.shadcn.com/) & [Radix UI](https://www.radix-ui.com/)
- Styling: [Tailwind CSS](https://tailwindcss.com/)
- Icons: [Lucide](https://lucide.dev/)
- Routing: [React Router](https://reactrouter.com/)
- API calls: [TanStack Query](https://tanstack.com/query/latest/)
- Forms & Validation: [React Hook Form](https://react-hook-form.com/)
- Admin Framework: [Ra-Core](https://marmelab.com/ra-core/)
- Type safety: [TypeScript](https://www.typescriptlang.org/)

## Getting started

Check the [Quick Start Guide](https://marmelab.com/shadcn-admin-kit/docs/quick-start-guide/) for a step-by-step guide to set up your first Admin app with `shadcn-admin-kit`.

## Exploring Components

`shadcn-admin-kit` provides a set of components that you can use to build your Admin app. The components are organized in the [`src/components/admin`](./src/components/admin/) directory, and you can find the documentation for each component in its respective file.

## Usage

Read the [documentation](https://marmelab.com/shadcn-admin-kit/docs/install/) to learn how to use `shadcn-admin-kit` in your project. The following sections provide a brief overview of the main concepts.

### Use `` As Root Component

The entry point of your application is the `` component. It allows to configure the application adapters, routes, and UI.

You'll need to specify a Data Provider to let the Admin know how to fetch data from your API. A Data Provider is an abstraction that allows you to connect your Admin to any API, whether it's REST, GraphQL, or any other protocol. You can choose from any of the [50+ Data Providers](https://marmelab.com/shadcn-admin-kit/docs/dataproviders/#supported-data-provider-backends), and you can even [build your own](https://marmelab.com/ra-core/dataproviderwriting/).

The following example uses a simple REST adapter called `ra-data-simple-rest`:

```tsx
import { Admin } from "@/components/admin/admin";
import simpleRestProvider from 'ra-data-simple-rest';

const dataProvider = simpleRestProvider('http://path.to.my.api');

export const App = () => (

{/* Resources go here */}

);
```

### Declare Resources

Then, you'll need to declare the routes of the application. `shadcn-admin-kit` allows to define CRUD routes (list, edit, create, show), and custom routes. Use the `` component from `ra-core` (which was automatically added to your dependencies) to define CRUD routes.

For each resource, you can specify a `name` (which will map to the API endpoint) and the `list`, `edit`, `create` and `show` components to use.

If you don't know where to start, you can use the built-in **guessers** to configure the admin for you! The guessers will automatically generate code based on the data returned by your API.

```tsx
import { Resource } from "ra-core";
import simpleRestProvider from 'ra-data-simple-rest';
import { Admin } from "@/components/admin/admin";
import { ListGuesser } from "@/components/admin/list-guesser";
import { ShowGuesser } from "@/components/admin/show-guesser";
import { EditGuesser } from "@/components/admin/edit-guesser";

const dataProvider = simpleRestProvider('http://path.to.my.api');

export const App = () => (



);
```

The guessers will print out the guessed component code in the console. You can then copy and paste it into your code to create the components to use as list, edit and show view.

```jsx
// Example output
Guessed List:

import { DataTable } from "@/components/admin/DataTable";
import { List } from "@/components/admin/List";

export const CategoryList = () => (






);
```

### Adding Authentication

You can configure authentication in your Admin by using the `authProvider` prop. There are many [authProviders](https://marmelab.com/shadcn-admin-kit/docs/security/#supported-auth-backends) you can choose from, and you can also [build your own](https://marmelab.com/ra-core/authproviderwriting/).

Once your authProvider is set up, you can pass it to the `authProvider` prop, and the `` component will automatically display the login page when the user is not authenticated.

```tsx
import { Resource } from "ra-core";
import simpleRestProvider from 'ra-data-simple-rest';
import { Admin } from "@/components/admin/admin";
import { ListGuesser } from "@/components/admin/list-guesser";
import { authProvider } from './authProvider';

export const App = () => (



);
```

### Adding a Dashboard

You can add a dashboard to your Admin by using the `dashboard` prop. The dashboard can be any React component.

```tsx
import { Resource } from "ra-core";
import simpleRestProvider from 'ra-data-simple-rest';
import { Admin } from "@/components/admin/admin";
import { ListGuesser } from "@/components/admin/list-guesser";

const Dashboard = () => (


My Dashboard



);

export const App = () => (



);
```

### Filtering the list

You can filter the list of records by using the `filters` prop on the `` component. The `filters` prop needs to be an array of input components.

```tsx
import { AutocompleteInput } from "@/components/admin/autocomplete-input";
import { List } from "@/components/admin/list";
import { ReferenceInput } from "@/components/admin/reference-input";
import { TextInput } from "@/components/admin/text-input";

const filters = [
,


,
];

export const ProductList = () => {
return (

...

);
};
```

### Adding Custom Routes

To register your own routes, pass one or several [``](https://marmelab.com/shadcn-admin-kit/docs/customroutes/) elements as children of ``. Declare as many [react-router](https://reactrouter.com/en/6/start/concepts#defining-routes) `` as you want inside them.

```tsx
// in src/App.tsx
import { Resource, CustomRoutes } from 'ra-core';
import { Route } from "react-router";
import { Admin } from "@/components/admin/admin";

import { dataProvider } from './dataProvider';
import posts from './posts';
import comments from './comments';
import { Settings } from './Settings';
import { Profile } from './Profile';

export const App = () => (




} />
} />


);
```

Now, when a user browses to `/settings` or `/profile`, the components you defined will appear in the main part of the screen.

**Tip:** Custom routes don’t automatically appear in the menu. You'll need to customize the [`` component](https://github.com/marmelab/shadcn-admin-kit/blob/main/src/components/admin/app-sidebar.tsx) if you want custom routes to be accessible from the menu.

## Contributing

This project requires [Node.js](https://nodejs.org/) and [pnpm](https://pnpm.io/).

To install the dependencies, run:

```bash
make install
```

To serve the demo locally, run:

```bash
make run
```

To start the storybook, run:

```bash
make storybook
```

To build the project, run:

```bash
make build
```

To test the UI registry, run:

```bash
make test-registry
```

## License

This project is licensed under the [MIT License](./LICENSE), courtesy of [Marmelab](https://marmelab.com/).