-
Notifications
You must be signed in to change notification settings - Fork 1.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[RFC] Full Next.Js support and UI upgrades #9183
Comments
This looks so good! And adding themes should be a lot easier with this. I think it would be really powerful if Keystone took the Shadcn/ui approach and let people "copy and paste" the whole Admin UI thru a CLI (or using a simple frontend). They could choose a theme, point to their schema, add an adminPath, and the CLI could build the app pages and layout pages. Then people could really hack away at that code and change almost everything. I started doing this for Openship 3 and reusing the Fields component instead of building forms all over again is saving me so much time. The props passed to Fields can easily be manipulated to hide certain fields and error handling and validation are all built-in. I even built a EditItemDrawer that makes it easy to edit items on the fly . Maybe down the line, Apollo client and Prisma can be decoupled and people can plug in React-Query or Drizzle instead thru the CLI and they still get the Admin-UI. |
Hey @gautamsi and @junaid33
I made some decent progress separating Keystone into three packages:
I took a slightly different approach to the AdminUI - I can see the benefits of generating the whole UI files, but I also think this could be daunting for a new-comer or could get unwieldy with large projects especially when it comes to breaking changes that might require some file regeneration. What I have been trying out is using NextJS dynamic routes (you can also use It would be good to have a progressive customisation. For example, a developer could import a page to a custom route or import a form component into a custom page. |
I tried running this @borisno2 but could not run, seems like scrip files missing from cli. |
Is that in the postinstall for each package? I haven't updated all the examples to use the Also make sure |
@borisno2 unfortunately I could not fix them to run properly. I would prefer to give full flexibility. |
I agree composable admin pages are ideal for offering full flexibility. ie it would be awesome to do things like... For a custom create/update form in a page // some/custom/create/page.tsx
import { getSessionContext } from 'keystone/context'
import CustomHeader from 'src/components/CustomHeader'
import CustomHeaderTitle from 'src/components/CustomHeaderTitle'
import CreateForm from '@keystone-6/admin-ui/components/CreateForm'
export default function MyCustomCreatePage() {
const context = getSessionContext()
return (
<>
<CustomHeader>
<CustomHeaderTitle>Create Item</CustomHeaderTitle>
</CustomHeader>
<CreateForm list="Item" context={context} />
</>
)
} Or for a list: import { getSessionContext } from 'keystone/context'
import CustomHeader from 'src/components/CustomHeader'
import CustomHeaderTitle from 'src/components/CustomHeaderTitle'
import List from '@keystone-6/admin-ui/components/CreateForm'
export default function MyCustomCreatePage() {
const context = getSessionContext()
return (
<>
<CustomHeader>
<CustomHeaderTitle>Create Item</CustomHeaderTitle>
</CustomHeader>
<List list="Item" context={context} />
</>
)
} But I think it is also important to offer a progressive customisation approach for easy onboarding. ie you might start with the wildcard route approach to give a full default admin ui. but maybe use the Form approach above to replace certain pages or for more non-admin type pages. |
Full Next.JS support
Currently the frontend is hidden away in
.keystone/admin
folder and generates multiple pages for each list routes. This is not very continent and makes customization very difficult. To overcome this I have proposed use of full Next.Js integration.Some initial poc done in #9181 .
Goals
Using App router will allow theming and customization easily with the Layouts.
Kudos to @junaid33 for initial Next.Js 14 work done in https://github.com/openshiporg/openfront
The text was updated successfully, but these errors were encountered: