This project demonstrates how to create a custom page in the Admin UI. It builds on the Task Manager starter project.
To run this project, clone the Keystone repository locally, run pnpm
at the root of the repository then navigate to this directory and run:
pnpm dev
This will start the Admin UI at localhost:3000.
You can use the Admin UI to create items in your database.
You can also access a GraphQL Playground at localhost:3000/api/graphql, which allows you to directly run GraphQL queries and mutations.
🚀 Congratulations, you're now up and running with Keystone!
This project leverages the /admin/pages
directory. As elaborated on in the Custom Pages guide, this directory is used to generate additional pages in the Admin UI, a behaviour inherited from Next.js
. The default export of files in this directory are expected to be React Components.
All other exports are ignored
NOTE: The Keystone monorepo leverages a babel config that means we use the old jsx transform (this doesn't have an impact on the code we ship to npm).
This is why there are import React from 'react'
statements in our examples, this is NOT necessary outside of the Keystone repo (unless you have a babel config with the old jsx transform which is currently the default with @babel/preset-react
) as you'll be using Next's babel config which uses the new jsx transform.
In order to ensure that the new page is visible and navigable within the Admin UI, this example also adds a custom Navigation component with the route to the custom page included. For much more detail on adding custom navigation, please see the Custom Admin UI Navigation guide and example.
In order to help us build custom pages that look and feel like part of the Admin UI, Keystone exports the PageContainer
component from
the @keystone-6/core/admin-ui/components
package.
PageContainer has the following types:
type PageContainerProps = {
header: ReactElement;
children: ReactNode;
title?: string;
};
To match the header style applied to all Admin UI standard pages, we use the Heading
component from @keystone-ui/core
as an h3
element.
import { PageContainer } from '@keystone-6/core/admin-ui/component';
import { Heading } from '@keystone-ui/core';
export default () => {
return (
<PageContainer header={<Heading type="h3">Custom Page</Heading>}>{/* ... */}</PageContainer>
);
};
You can play with this example online in a web browser using the free codesandbox.io service. To launch this example, open the URL https://githubbox.com/keystonejs/keystone/tree/main/examples/custom-admin-ui-pages. You can also fork this sandbox to make your own changes.