Skip to content

Commit

Permalink
fix redirects
Browse files Browse the repository at this point in the history
  • Loading branch information
ssalbdivad committed Jan 3, 2025
1 parent 0f5d566 commit 6dde47d
Show file tree
Hide file tree
Showing 5 changed files with 47 additions and 15 deletions.
16 changes: 14 additions & 2 deletions ark/docs/app/docs/[[...slug]]/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,20 @@ import {
DocsPage,
DocsTitle
} from "fumadocs-ui/page"
import { notFound } from "next/navigation"
import { notFound, redirect } from "next/navigation"
import { source } from "../../../lib/source.tsx"

export default async (props: { params: Promise<{ slug?: string[] }> }) => {
const params = await props.params

if (
!params.slug?.length ||
(params.slug?.length === 1 && params.slug[0] === "intro")
)
redirect("/docs/intro/setup")

const page = source.getPage(params.slug)

if (!page) notFound()

const MDX = page.data.body
Expand Down Expand Up @@ -40,7 +48,11 @@ export default async (props: { params: Promise<{ slug?: string[] }> }) => {
)
}

export const generateStaticParams = async () => source.generateParams()
export const generateStaticParams = async () => [
...source.generateParams(),
{ slug: [] },
{ slug: ["intro"] }
]

export const generateMetadata = async (props: {
params: Promise<{ slug?: string[] }>
Expand Down
12 changes: 0 additions & 12 deletions ark/docs/components/snippets/contentsById.ts
Original file line number Diff line number Diff line change
@@ -1,12 +0,0 @@
export default {
betterErrors:
'import { type, type ArkErrors } from "arktype"\n\nconst user = type({\n\tname: "string",\n\tplatform: "\'android\' | \'ios\'",\n\t"versions?": "(number | string)[]"\n})\n\ninterface RuntimeErrors extends ArkErrors {\n\t/**platform must be "android" or "ios" (was "enigma")\nversions[2] must be a number or a string (was bigint)*/\n\tsummary: string\n}\n\nconst narrowMessage = (e: ArkErrors): e is RuntimeErrors => true\n\n// ---cut---\nconst out = user({\n\tname: "Alan Turing",\n\tplatform: "enigma",\n\tversions: [0, "1", 0n]\n})\n\nif (out instanceof type.errors) {\n\t// ---cut-start---\n\tif (!narrowMessage(out)) throw new Error()\n\t// ---cut-end---\n\t// hover summary to see validation errors\n\tconsole.error(out.summary)\n}\n',
clarityAndConcision:
'// @errors: 2322\nimport { type } from "arktype"\n// this file is written in JS so that it can include a syntax error\n// without creating a type error while still displaying the error in twoslash\n// ---cut---\n// hover me\nconst user = type({\n\tname: "string",\n\tplatform: "\'android\' | \'ios\'",\n\t"versions?": "number | string)[]"\n})\n',
deepIntrospectability:
'import { type } from "arktype"\n\nconst user = type({\n\tname: "string",\n\tdevice: {\n\t\tplatform: "\'android\' | \'ios\'",\n\t\t"version?": "number | string"\n\t}\n})\n\n// ---cut---\nuser.extends("object") // true\nuser.extends("string") // false\n// true (string is narrower than unknown)\nuser.extends({\n\tname: "unknown"\n})\n// false (string is wider than "Alan")\nuser.extends({\n\tname: "\'Alan\'"\n})\n',
intrinsicOptimization:
'import { type } from "arktype"\n// prettier-ignore\n// ---cut---\n// all unions are optimally discriminated\n// even if multiple/nested paths are needed\nconst account = type({\n\tkind: "\'admin\'",\n\t"powers?": "string[]"\n}).or({\n\tkind: "\'superadmin\'",\n\t"superpowers?": "string[]"\n}).or({\n\tkind: "\'pleb\'"\n})\n',
unparalleledDx:
'// @noErrors\nimport { type } from "arktype"\n// prettier-ignore\n// ---cut---\nconst user = type({\n\tname: "string",\n\tplatform: "\'android\' | \'ios\'",\n\t"version?": "number | s"\n\t// ^|\n})\n'
}
14 changes: 13 additions & 1 deletion ark/docs/content/docs/scopes/index.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -335,4 +335,16 @@ const rootModule = type.module({

### thunks

🚧 Coming soon ™️🚧
When users are first learning about Scopes, one of the most common mistakes is to reference an alias in a nested `type` call:

```ts
// @noErrors
const myScope = scope({
id: "string#id",
user: type({
id: "id"
})
})
```

It's a very common mistake to reference a scoped keyword
12 changes: 12 additions & 0 deletions ark/docs/next.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,18 @@ const config = {
images: {
unoptimized: true
}
// redirects: async () => [
// {
// source: "/docs",
// destination: "/docs/intro/setup",
// permanent: true
// },
// {
// source: "/docs/intro",
// destination: "/docs/intro/setup",
// permanent: true
// }
// ]
} as const satisfies NextConfig

const mdxConfig = createMDX()(config)
Expand Down
8 changes: 8 additions & 0 deletions ark/repo/scratch.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,11 @@ import { ark, type } from "arktype"
flatMorph(ark.internal.resolutions, (k, v) => [k, v])

console.log(Object.keys(ark.internal.resolutions))

const myScope = type.scope({
id: "string#id",
user: type({
// ParseError: 'id' is not resolvable
id: "id"
})
})

0 comments on commit 6dde47d

Please sign in to comment.