This plugin for solid-start will create a route manifest which provides type-safe routes based on the file-routing.
As solid-start itself this plugin is also router agnostic. So it'll work with any router which is able to include solid-start's Fileroutes
component.
npm i --save-dev solid-start-typesafe-routes-plugin
yarn add -D solid-start-typesafe-routes-plugin
pnpm add -D solid-start-typesafe-routes-plugin
interface PluginProps {
routeDir: string; //default: 'src/routes' - path to the file routes root
outDir: string; // default: './src/RouteManifest' - path where the output files are written to
}
//app.config.ts
import solidStartTypesafeRouterPlugin from 'solid-start-typesafe-routes-plugin';
defineConfig({
vite: {
plugins: [solidStartTypesafeRouterPlugin()],
},
});
The plugin will create an index.js
and index.d.ts
the in src/RouteManifest
.
Layouts will be ignored.
Updates automatically on
pnpm build
pnpm dev
on startup of the dev server and when a file iscreated/moved/deleted
in thesrc/routes
directory
Assuming this routes
src
└─routes
│ index.tsx
│ about.tsx
│
└─posts
│ [slug].tsx
│
└───multiple
│ │
│ └───[first]
│ │
│ └─[second]
│ [third].tsx
│ add.tsx
│
└───auth(layout)
[userId].tsx
You can get the routes like
import routes from '~/RouteManifest';
routes().index; // => '/'
routes().about.index; // => '/about'
routes().posts.slug('hello-world').index; // => '/posts/hello-world'
routes().multiple.first('a').second('b').third('c').index; // => '/multiple/a/b/c'
routes().multiple.first('a').second('b').third('c').add.index; // => '/multiple/a/b/c/add'
routes().auth.userId('xyz').index; // => '/auth/xyz'
// Pass searchparams to routes
routes({ q: 'apples' }).index; // => '/?q=apples'
So use it like
<a href={routes().posts.slug('hello-world').index}> ... </a>
<Link href={routes().posts.slug('hello-world').index} isActive={routes().posts.slug('hello-world').index === location.pathname}>...</Link>
// -----------------------------------------
import {useNavigate} from '@solidjs/router';
const navigate = useNavigate();
navigate(routes({q:"hello"}).posts.index)