generated from StanfordBDHG/NextJSTemplate
-
-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
258db15
commit d00ede4
Showing
5 changed files
with
160 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
// | ||
// This source file is part of the Stanford Biodesign Digital Health Spezi Web Design System open-source project | ||
// | ||
// SPDX-FileCopyrightText: 2024 Stanford University and the project authors (see CONTRIBUTORS.md) | ||
// | ||
// SPDX-License-Identifier: MIT | ||
// | ||
|
||
import { type Meta, type StoryObj } from '@storybook/react' | ||
import { NotFound } from './NotFound' | ||
|
||
const meta: Meta<typeof NotFound> = { | ||
title: 'Molecules/NotFound', | ||
component: NotFound, | ||
} | ||
|
||
export default meta | ||
|
||
type Story = StoryObj<typeof NotFound> | ||
|
||
export const Generic: Story = { | ||
args: { backPage: { href: '/', name: 'home' }, entityName: 'page' }, | ||
} | ||
|
||
export const UserNotFound: Story = { | ||
args: { | ||
backPage: { href: '/users', name: 'users list' }, | ||
entityName: 'user', | ||
}, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
// | ||
// This source file is part of the Stanford Biodesign Digital Health Spezi Web Design System open-source project | ||
// | ||
// SPDX-FileCopyrightText: 2024 Stanford University and the project authors (see CONTRIBUTORS.md) | ||
// | ||
// SPDX-License-Identifier: MIT | ||
// | ||
|
||
import { screen } from '@testing-library/react' | ||
import { renderWithProviders } from '@/tests/helpers' | ||
import { NotFound } from './' | ||
|
||
describe('NotFound', () => { | ||
it('renders not found error page', () => { | ||
renderWithProviders( | ||
<NotFound | ||
backPage={{ name: 'users', href: '/users' }} | ||
entityName="user" | ||
/>, | ||
) | ||
|
||
const backLink = screen.getByRole('link', { name: /users/ }) | ||
expect(backLink).toBeInTheDocument() | ||
|
||
const title = screen.getByText(`This user doesn't exist`) | ||
expect(title).toBeInTheDocument() | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
// | ||
// This source file is part of the Stanford Biodesign Digital Health Spezi Web Design System open-source project | ||
// | ||
// SPDX-FileCopyrightText: 2024 Stanford University and the project authors (see CONTRIBUTORS.md) | ||
// | ||
// SPDX-License-Identifier: MIT | ||
// | ||
|
||
import { Link } from '@tanstack/react-router' | ||
import { RouteOff } from 'lucide-react' | ||
import { type ComponentProps, type ReactNode } from 'react' | ||
import { Button } from '@/components/Button' | ||
import { cn } from '@/utils/className' | ||
|
||
export const NotFoundIcon = ({ | ||
className, | ||
...props | ||
}: Omit<ComponentProps<'div'>, 'children'>) => ( | ||
<div | ||
className={cn('flex-center mb-2 size-20 rounded-full bg-muted', className)} | ||
{...props} | ||
> | ||
<RouteOff className="size-7" /> | ||
</div> | ||
) | ||
|
||
export const NotFoundContainer = ({ | ||
className, | ||
...props | ||
}: ComponentProps<'div'>) => ( | ||
<div | ||
className={cn('flex-center grow flex-col gap-1', className)} | ||
{...props} | ||
/> | ||
) | ||
|
||
export const NotFoundTitle = ({ | ||
className, | ||
...props | ||
}: ComponentProps<'h1'>) => ( | ||
<h1 className={cn('text-2xl font-medium', className)} {...props} /> | ||
) | ||
|
||
export const NotFoundParagraph = ({ | ||
className, | ||
...props | ||
}: ComponentProps<'p'>) => ( | ||
<p className={cn('text-muted-foreground', className)} {...props} /> | ||
) | ||
|
||
interface NotFoundActionProps extends ComponentProps<typeof Button> {} | ||
|
||
export const NotFoundAction = (props: NotFoundActionProps) => ( | ||
<Button size="sm" className="mt-3" asChild {...props} /> | ||
) | ||
|
||
interface NotFoundProps { | ||
/** | ||
* Configures where user should go instead | ||
* @example { name: "users list", href: "/user" } | ||
* */ | ||
backPage: { | ||
name: ReactNode | ||
href: string | ||
} | ||
/** | ||
* Singular name of accessed entity | ||
* @example "user" | ||
* */ | ||
entityName: ReactNode | ||
className?: string | ||
} | ||
|
||
export const NotFound = ({ | ||
backPage, | ||
entityName, | ||
className, | ||
}: NotFoundProps) => ( | ||
<NotFoundContainer className={className}> | ||
<NotFoundIcon /> | ||
<NotFoundTitle>This {entityName} doesn't exist</NotFoundTitle> | ||
<NotFoundParagraph> | ||
Please check your URL or return to {backPage.name} | ||
</NotFoundParagraph> | ||
<NotFoundAction> | ||
<Link href={backPage.href}>Go to {backPage.name}</Link> | ||
</NotFoundAction> | ||
</NotFoundContainer> | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
// | ||
// This source file is part of the Stanford Biodesign Digital Health Spezi Web Design System open-source project | ||
// | ||
// SPDX-FileCopyrightText: 2024 Stanford University and the project authors (see CONTRIBUTORS.md) | ||
// | ||
// SPDX-License-Identifier: MIT | ||
// | ||
|
||
export * from './NotFound' |