Skip to content

Commit

Permalink
remove authenticatedItem from @keystone-6/core/admin-ui
Browse files Browse the repository at this point in the history
  • Loading branch information
dcousens committed Aug 20, 2024
1 parent 812dbc7 commit b7d26a3
Show file tree
Hide file tree
Showing 38 changed files with 356 additions and 469 deletions.
5 changes: 5 additions & 0 deletions .changeset/admin-ui-navigation.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@keystone-6/core": major
---

Removes `authenticatedItem` from `@keystone-6/core/admin-ui/components` exports
5 changes: 5 additions & 0 deletions .changeset/remove-end-session.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@keystone-6/core": major
---

Removes the `EndSession` GraphQL mutation addition when `context.session.end` is defined, extend this yourself if required
1 change: 1 addition & 0 deletions docs/content/docs/config/auth.md
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,7 @@ The following elements will be added to the GraphQL API.
```graphql
type Mutation {
authenticateUserWithPassword(email: String!, password: String!): UserAuthenticationWithPasswordResult!
endSession: Boolean!
}

type Query {
Expand Down
101 changes: 36 additions & 65 deletions docs/content/docs/guides/custom-admin-ui-navigation.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ Reference your custom Navigation component in the export as so.

```ts
// /admin/config.ts
import type { AdminConfig } from '@keystone-6/core/types';
import { CustomNavigation } from './components/CustomNavigation';
import type { AdminConfig } from '@keystone-6/core/types'
import { CustomNavigation } from './components/CustomNavigation'

export const components: AdminConfig['components'] = {
Navigation: CustomNavigation
Expand All @@ -36,8 +36,8 @@ Here we'll export our `CustomNavigation` component as a named export.
```tsx
// admin/components/CustomNavigation.tsx

import type { NavigationProps } from '@keystone-6/core/admin-ui/components';
export function CustomNavigation({ authenticatedItem, lists }: NavigationProps) {
import type { NavigationProps } from '@keystone-6/core/admin-ui/components'
export function CustomNavigation({ lists }: NavigationProps) {
return (
{/* ... */}
)
Expand All @@ -48,8 +48,7 @@ Keystone will pass the following props to this component.

```tsx
type NavigationProps = {
lists: ListMeta[];
authenticatedItem: AuthenticatedItem
lists: ListMeta[]
}
```
Expand All @@ -62,21 +61,20 @@ For more information on the props, please see the [Navigation Props](#navigation
Next we'll want to import some components that Keystone provides to help us build our custom Navigation.
```tsx
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components';
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components'
```

The `NavigationContainer` component provides a container around your navigation links, as well as the different states of the `authenticatedItem` prop. We'll need this to:
The `NavigationContainer` component provides a container around your navigation links.

- Make our `CustomNavigation` component look and feel like the default Admin UI Navigation component.
- Render out the hamburger menu with additional options should a user session be in progress via the `authenticatedItem` prop.

```tsx
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components';
import type { NavigationProps } from '@keystone-6/core/admin-ui/components';
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components'
import type { NavigationProps } from '@keystone-6/core/admin-ui/components'

export function CustomNavigation({ authenticatedItem, lists }: NavigationProps) {
export function CustomNavigation({ lists }: NavigationProps) {
return (
<NavigationContainer authenticatedItem={authenticatedItem}>
<NavigationContainer>
{/* ... */}
</NavigationContainer>
)
Expand All @@ -92,12 +90,12 @@ For more information on the `NavigationContainer` see the [NavigationContainer](
The `ListNavItems` component takes the provided Array of `lists` and renders a list of NavItems. We'll use this component to help us easily create NavItems from Keystone lists.

```tsx
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components';
import type { NavigationProps } from '@keystone-6/core/admin-ui/components';
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components'
import type { NavigationProps } from '@keystone-6/core/admin-ui/components'

export function CustomNavigation({ authenticatedItem, lists }: NavigationProps) {
export function CustomNavigation({ lists }: NavigationProps) {
return (
<NavigationContainer authenticatedItem={authenticatedItem}>
<NavigationContainer>
<ListNavItems lists={lists}/>
{/* ... */}
</NavigationContainer>
Expand All @@ -114,12 +112,12 @@ For more information on the `ListNavItems` component, see the [ListNavItems](#li
The `NavItem` component is a thin styling and accessibility wrapper around the `Link` component from Next.js. We'll use this component to render our custom route as well as the `Dashboard` route.

```tsx
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components';
import type { NavigationProps } from '@keystone-6/core/admin-ui/components';
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components'
import type { NavigationProps } from '@keystone-6/core/admin-ui/components'

export function CustomNavigation({ authenticatedItem, lists }: NavigationProps) {
export function CustomNavigation({ lists }: NavigationProps) {
return (
<NavigationContainer authenticatedItem={authenticatedItem}>
<NavigationContainer>
<NavItem href="/">Dashboard</NavItem>
<ListNavItems lists={lists}/>
<NavItem href="https://keystonejs.com/">
Expand All @@ -144,12 +142,12 @@ With all that done, your Custom Navigation component should be good to go, and y

```tsx
// admin/components/CustomNavigation.tsx
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components';
import type { NavigationProps } from '@keystone-6/core/admin-ui/components';
import { NavigationContainer, NavItem, ListNavItems } from '@keystone-6/core/admin-ui/components'
import type { NavigationProps } from '@keystone-6/core/admin-ui/components'

export function CustomNavigation({ authenticatedItem, lists }: NavigationProps) {
export function CustomNavigation({ lists }: NavigationProps) {
return (
<NavigationContainer authenticatedItem={authenticatedItem}>
<NavigationContainer>
<NavItem href="/">Dashboard</NavItem>
<ListNavItems lists={lists}/>
<NavItem href="https://keystonejs.com/">
Expand All @@ -161,11 +159,11 @@ export function CustomNavigation({ authenticatedItem, lists }: NavigationProps)


// admin/config.ts
import { AdminConfig } from '@keystone-6/core/types';
import { CustomNavigation } from './components/CustomNavigation';
import { AdminConfig } from '@keystone-6/core/types'
import { CustomNavigation } from './components/CustomNavigation'
export const components: AdminConfig['components'] = {
Navigation: CustomNavigation
};
}
```

Start up your Keystone project, and you should see Custom Navigation with a route to the KeystoneJS docs in the Admin UI.
Expand All @@ -180,15 +178,14 @@ The rest of this guide will elaborate on some of the details around the helper c
This section is to provide more granular information around the props that Keystone passes to your Custom Navigation component.

```tsx
export const CustomNavigation = ({ lists, authenticatedItem }) => {}
export const CustomNavigation = ({ lists }) => {}
```

Keystone passes the following props to your custom Navigation component:

```ts
type NavigationProps {
lists: ListMeta[];
authenticatedItem: AuthenticatedItem;
lists: ListMeta[]
}
```

Expand All @@ -197,33 +194,17 @@ type NavigationProps {
```typescript
type ListMeta = {
/** Used for optimising the generated list of NavItems in React */
key: string;
key: string
/** href to the list route in the Admin UI. */
path: string;
path: string
/** Used as the label for each list generated NavItem */
label: string;
label: string
/** Other properties exists, but these are the ones that are relevant to the Navigation implementation */
};

type Lists = ListMeta[];
```

`authenticatedItem` is a union of potential authentication states, expanded on below:
}

```ts
type AuthenticatedItem =
| { state: 'unauthenticated' }
| { state: 'authenticated'; label: string; id: string; listKey: string }
| { state: 'loading' }
| { state: 'error'; error: Error | readonly [GraphQLError, ...GraphQLError[]] };
type Lists = ListMeta[]
```
The `authenticatedItem` props is rendered automatically when you pass it into the `NavigationContainer` component.

{% hint kind="warn" %}
If you render the `authenticatedItem` yourself, make sure you handle all of the possible states.
{% /hint %}

## Components
Keystone exposes a variety of helper components to make building out your custom Admin UI Navigation component easier. These are:
Expand All @@ -234,24 +215,14 @@ Keystone exposes a variety of helper components to make building out your custom
### NavigationContainer
This component renders containing markup around your navigation links, as well as as the different states of the `authenticatedItem` prop.

```typescript
type NavigationContainerProps = {
authenticatedItem?: AuthenticatedItem;
}
```
{% hint kind="tip" %}
For the shape of the `authenticatedItem` prop, please see the [Navigation Props](#navigation-props) section above.
{% /hint %}
This component renders containing markup around your navigation links.
```tsx
import { NavigationContainer} from '@keystone-6/core/admin-ui/components'

export const CustomNavigation = ({ lists, authenticatedItem }) => {
export function CustomNavigation ({ lists }) {
return (
<NavigationContainer authenticatedItem={authenticatedItem}>
<NavigationContainer>
{/* ... */}
</NavigationContainer>
)
Expand Down
40 changes: 20 additions & 20 deletions docs/content/docs/guides/custom-admin-ui-pages.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ The default export of every file in this directory is expected to be a valid Rea

```tsx
// admin/pages/custom-page.tsx
import Link from 'next/link';
import Link from 'next/link'

export default function CustomPage () {
return (
Expand Down Expand Up @@ -43,8 +43,8 @@ This `header` prop is rendered out as the page title at the top of the page.

```tsx
// admin/pages/custom-page.tsx
import Link from 'next/link';
import { PageContainer } from '@keystone-6/core/admin-ui/components';
import Link from 'next/link'
import { PageContainer } from '@keystone-6/core/admin-ui/components'

export default function CustomPage () {
return (
Expand All @@ -66,8 +66,8 @@ Keystone pages leverage the `Heading` component from the `@keystone-ui/core` pac

```tsx
// admin/pages/custom-page.tsx.
import { PageContainer } from '@keystone-6/core/admin-ui/components';
import { Heading } from '@keystone-ui/core';
import { PageContainer } from '@keystone-6/core/admin-ui/components'
import { Heading } from '@keystone-ui/core'

export default function CustomPage () {
return (
Expand All @@ -91,20 +91,20 @@ First add the following files to the `/admin` directory in the root of your Keys

```tsx
// admin/config.ts
import type { AdminConfig } from '@keystone-6/core/types';
import { CustomNavigation } from './components/CustomNavigation';
import type { AdminConfig } from '@keystone-6/core/types'
import { CustomNavigation } from './components/CustomNavigation'
export const components: AdminConfig['components']= {
Navigation: CustomNavigation
};
}
```

```tsx
// admin/components/CustomNavigation.tsx
import { NavigationContainer, ListNavItems, NavItem } from '@keystone-6/core/admin-ui/components';
import type { NavigationProps } from '@keystone-6/core/admin-ui/components';
export function CustomNavigation({ lists, authenticatedItem }: NavigationProps) {
import { NavigationContainer, ListNavItems, NavItem } from '@keystone-6/core/admin-ui/components'
import type { NavigationProps } from '@keystone-6/core/admin-ui/components'
export function CustomNavigation({ lists }: NavigationProps) {
return (
<NavigationContainer authenticatedItem={authenticatedItem}>
<NavigationContainer>
<NavItem href="/">Dashboard</NavItem>
<ListNavItems lists={lists} />
</NavigationContainer>
Expand All @@ -124,11 +124,11 @@ Lastly we'll add our new route to the newly created `CustomNavigation` component

```tsx
// admin/components/CustomNavigation.tsx
import { NavigationContainer, ListNavItems, NavItem } from '@keystone-6/core/admin-ui/components';
import type { NavigationProps } from '@keystone-6/core/admin-ui/components';
export function CustomNavigation({ lists, authenticatedItem }: NavigationProps) {
import { NavigationContainer, ListNavItems, NavItem } from '@keystone-6/core/admin-ui/components'
import type { NavigationProps } from '@keystone-6/core/admin-ui/components'
export function CustomNavigation({ lists }: NavigationProps) {
return (
<NavigationContainer authenticatedItem={authenticatedItem}>
<NavigationContainer>
<NavItem href="/">Dashboard</NavItem>
<ListNavItems lists={lists} />
<NavItem href="/custom-page">Custom Page</NavItem>
Expand All @@ -155,10 +155,10 @@ The snippet below uses the emotion `jsx` runtime exported from `@keystone-ui/cor
// admin/pages/custom-page.tsx
/** @jsxRuntime classic */

import Link from 'next/link';
import { jsx } from '@keystone-ui/core';
import { PageContainer } from '@keystone-6/core/admin-ui/components';
import { Heading } from '@keystone-ui/core';
import Link from 'next/link'
import { jsx } from '@keystone-ui/core'
import { PageContainer } from '@keystone-6/core/admin-ui/components'
import { Heading } from '@keystone-ui/core'

export default function CustomPage () {
return (
Expand Down
Loading

0 comments on commit b7d26a3

Please sign in to comment.