TypeScript friendly pages and static path generator for Next.js.
Since pathpida >= 0.23.0
, removed Nuxt support.
Since pathpida >= 0.20.0
, removed Sapper support.
- Type safety. Automatically generate type definition files for manipulating internal links in Next.js.
- Zero configuration. No configuration required can be used immediately after installation.
- Zero runtime. Lightweight because runtime code is not included in the bundle.
- Support for static files. Static files in public/ are also supported, so static assets can be safely referenced.
- Support for appDir of Next.js 13 Layout.
-
Using npm:
$ npm install pathpida npm-run-all --save-dev
-
Using Yarn:
$ yarn add pathpida npm-run-all --dev
Option | Type | Description |
---|---|---|
--enableStatic -s |
Generate static files path in $path.ts . |
|
--ignorePath -p |
string |
Specify the ignore pattern file path. |
--output -o |
string |
Specify the output directory for $path.ts . |
--watch -w |
Enable watch mode. Regenerate $path.ts .
|
|
--version -v |
Print pathpida version. |
package.json
{
"scripts": {
"dev": "run-p dev:*",
"dev:next": "next dev",
"dev:path": "pathpida --ignorePath .gitignore --watch",
"build": "pathpida --ignorePath .gitignore && next build"
}
}
pages/index.tsx
pages/post/create.tsx
pages/post/[pid].tsx
pages/post/[...slug].tsx
lib/$path.ts or utils/$path.ts // Generated automatically by pathpida
or
src/pages/index.tsx
src/pages/post/create.tsx
src/pages/post/[pid].tsx
src/pages/post/[...slug].tsx
src/lib/$path.ts or src/utils/$path.ts // Generated automatically by pathpida
pages/index.tsx
import Link from "next/link";
import { pagesPath } from "../lib/$path";
console.log(pagesPath.post.create.$url()); // { pathname: '/post/create' }
console.log(pagesPath.post._pid(1).$url()); // { pathname: '/post/[pid]', query: { pid: 1 }}
console.log(pagesPath.post._slug(["a", "b", "c"]).$url()); // { pathname: '/post//[...slug]', query: { slug: ['a', 'b', 'c'] }}
export default () => {
const onClick = useCallback(() => {
router.push(pagesPath.post._pid(1).$url());
}, []);
return (
<>
<Link href={pagesPath.post._slug(["a", "b", "c"]).$url()} />
<div onClick={onClick} />
</>
);
};
pages/post/create.tsx
export type Query = {
userId: number;
name?: string;
};
export default () => <div />;
pages/post/[pid].tsx
export type OptionalQuery = {
limit: number;
label?: string;
};
export default () => <div />;
pages/index.tsx
import Link from "next/link";
import { pagesPath } from "../lib/$path";
console.log(pagesPath.post.create.$url({ query: { userId: 1 } })); // { pathname: '/post/create', query: { userId: 1 }}
console.log(pagesPath.post.create.$url()); // type error
console.log(pagesPath.post._pid(1).$url()); // { pathname: '/post/[pid]', query: { pid: 1 }}
console.log(pagesPath.post._pid(1).$url({ query: { limit: 10 }, hash: "sample" })); // { pathname: '/post/[pid]', query: { pid: 1, limit: 10 }, hash: 'sample' }
export default () => {
const onClick = useCallback(() => {
router.push(pagesPath.post._pid(1).$url());
}, []);
return (
<>
<Link href={pagesPath.post._slug(["a", "b", "c"]).$url()} />
<div onClick={onClick} />
</>
);
};
package.json
{
"scripts": {
"dev": "run-p dev:*",
"dev:next": "next dev",
"dev:path": "pathpida --enableStatic --watch",
"build": "pathpida --enableStatic && next build"
}
}
pages/index.tsx
pages/post/create.tsx
pages/post/[pid].tsx
pages/post/[...slug].tsx
public/aa.json
public/bb/cc.png
lib/$path.ts or utils/$path.ts // Generated automatically by pathpida
or
src/pages/index.tsx
src/pages/post/create.tsx
src/pages/post/[pid].tsx
src/pages/post/[...slug].tsx
public/aa.json
public/bb/cc.png
src/lib/$path.ts or src/utils/$path.ts // Generated automatically by pathpida
pages/index.tsx
import Link from "next/link";
import { pagesPath, staticPath } from "../lib/$path";
console.log(staticPath.aa_json); // /aa.json
export default () => {
return (
<>
<Link href={pagesPath.post._slug(["a", "b", "c"]).$url()} />
<img src={staticPath.bb.cc_png} />
</>
);
};
pathpida is licensed under a MIT License.