Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More β†’
Socket
Sign inDemoInstall
Socket

generouted

Package Overview
Dependencies
Maintainers
1
Versions
113
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

generouted

Generated client-side file-based routes for Vite

  • 1.15.7
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
23K
increased by123.37%
Maintainers
1
Weekly downloads
Β 
Created
Source

generouted


Generouted

Generated file-based routes for Vite

Motivation

I enjoyed using file-based routing since I tried Next.js (pages directory). After applying the same concept with Vite and client-side applications, I started writing blog posts covering the implementation of client-side file-based routing with React Router which was packaged later as generouted.

Today generouted brings many features, supports multiple frameworks and routers, and inspires ideas and conventions from Next.js, Remix, Expo, Docusaurus, SvelteKit and more.


How does it work?

generouted uses Vite's glob import API to list the routes within the src/pages directory and generates the routes tree and modals based on generouted's conventions.

There are also Vite plugins available for some integrations to provide type-safe components/hooks/utils through code-generation.



Features

  • πŸ“ Client-side file-based routing
  • ⚑ Powered by Vite
  • ✨ React support with react-router-dom or @tanstack/router πŸ§ͺ or @tanstack/react-location 🚨
  • ✨ Solid support with @solidjs/router
  • πŸ” Type-safe navigation
  • πŸš€ Type-safe global modals
  • πŸ’€ Route-based code-splitting and lazy-loading
  • πŸ“„ Route-based data loaders and actions
  • πŸ’£ Route-based error boundary
  • πŸ“‚ Nested layouts
  • πŸ«™ Pathless layout groups
  • ❓ Optional static and dynamic routes
  • πŸ’­ Ignored routes per file or directory

Online explorer

  • ⚑ Visit generouted's interactive playground via StackBlitz
  • 🧩 Explore file-based routing patterns and conventions
  • πŸ”Ž Visualize the routes layouts and the resolved routes paths
  • πŸ“ Update src/pages/ files and see your changes reflecting

Getting started

React Router

React Router

In case you don't have a Vite project with React and TypeScript, check Vite documentation to start a new project.

Installation
pnpm add @generouted/react-router react-router-dom
Setup
// vite.config.ts

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
import generouted from '@generouted/react-router/plugin'

export default defineConfig({ plugins: [react(), generouted()] })
Usage
// src/main.tsx

import { createRoot } from 'react-dom/client'
import { Routes } from '@generouted/react-router'

const app = document.getElementById('app')
createRoot(app).render(<Routes />)
Adding pages

Add the home page by creating a new file src/pages/index.tsx β†’ /, then export a default component:

export default function Home() {
  return <h1>Home</h1>
}

Check the routing conventions section below.

Docs

You can find more details about type-safe navigation and global modals at @generouted/react-router docs.

Examples

Solid Router

Solid Router

In case you don't have a Vite project with Solid and TypeScript, check Vite documentation to start a new project.

Installation
pnpm add @generouted/solid-router @solidjs/router
Setup
// vite.config.ts

import { defineConfig } from 'vite'
import solid from 'vite-plugin-solid'
import generouted from '@generouted/solid-router/plugin'

export default defineConfig({ plugins: [solid(), generouted()] })
Usage
// src/main.tsx

import { render } from 'solid-js/web'
import { Routes } from '@generouted/solid-router'

render(Routes, document.getElementById('app'))
Adding pages

Add the home page by creating a new file src/pages/index.tsx β†’ /, then export a default component:

export default function Home() {
  return <h1>Home</h1>
}

See more about generouted routing conventions below.

Docs

You can find more details about type-safe navigation and global modals at @generouted/solid-router docs.

Examples

TanStack React Router β€” In-progress experimental support πŸ§ͺ

TanStack React Router β€” In-progress experimental support πŸ§ͺ

Check out the docs here

Examples

React Location β€” Deprecated 🚨

React Location β€” Deprecated 🚨

In case you don't have a Vite project with React and TypeScript, check Vite documentation to start a new project.

Installation
pnpm add generouted @tanstack/react-location
Usage
// src/main.tsx

import { createRoot } from 'react-dom/client'
import { Routes } from 'generouted/react-location'

const app = document.getElementById('app')
createRoot(app).render(<Routes />)
Adding pages

Add the home page by creating a new file src/pages/index.tsx β†’ /, then export a default component:

export default function Home() {
  return <h1>Home</h1>
}
Examples


Conventions

File and directories naming and conventions

  • Routes declaration at src/pages
  • Supports .tsx or .jsx extensions
  • Optional src/pages/_app.tsx for an app level layout
  • Optional src/pages/404.tsx for a custom not-found page
Index routes
  • src/pages/index.tsx β†’ /
  • src/pages/posts/index.tsx β†’ /posts
Nested routes
  • src/pages/posts/2022/index.tsx β†’ /posts/2022
  • src/pages/posts/2022/resolutions.tsx β†’ /posts/2022/resolutions
Dynamic routes
  • src/pages/posts/[slug].tsx β†’ /posts/:slug
  • src/pages/posts/[slug]/tags.tsx β†’ /posts/:slug/tags
  • src/pages/posts/[...all].tsx β†’ /posts/*
Nested layouts
  • By defining _layout.tsx in any nested directory β†’ src/pages/posts/_layout.tsx
  • Requires using an <Outlet /> component to render layout children
  • All the files within the src/pages/posts/ directory in this case, will be wrapped with that layout
Nested URLs without nested layouts
  • Route file should be outside of the nested layout directory
  • Include dots . between the segments to be converted to forward slashes
  • src/pages/posts.nested.as.url.not.layout.tsx β†’ /posts/nested/as/url/not/layout
Pathless layouts
  • Similar to nested layouts for layout definition
  • By wrapping the parent directory with parentheses ()
  • src/pages/(auth)/_layout.tsx
  • src/pages/(auth)/login.tsx β†’ /login
  • Layout parent directory name is not included in the routes paths
Global modals
  • By prefixing the file name with a plus sign + (thinking the modal is an extra route overlaying the current route)
  • Modals navigation available via the useModals() hook
  • src/pages/+info.tsx β†’ /info
  • src/pages/+checkout/+details.tsx β†’ /checkout/details
  • src/pages/+checkout/+payment.tsx β†’ /checkout/payment
Optional segments
  • By prefixing a route segment with a minus sign - (thinking the segment can be subtracted or removed from the route path)
  • src/pages/-en/about.tsx β†’ /en?/about β†’ /en/about, /about
  • src/pages/-[lang]/about.tsx β†’ /:lang?/about β†’ /en/about, /fr/about, /about
Ignored routes
  • Any directory or file starts with an underscore _ will be ignored
  • src/pages/_ignored.tsx
  • src/pages/posts/_components/button.tsx
  • src/pages/posts/_components/link.tsx

Page exports

  • Required page component export default Component() {...}
  • Optional page loader function export const Loader = () => {...}
  • Optional page action function export const Action = () => {...}
  • Optional error boundary component export const Catch = () => {...}

Example

Directory structure
src/pages
β”œβ”€β”€ (auth)
β”‚   β”œβ”€β”€ _layout.tsx
β”‚   β”œβ”€β”€ login.tsx
β”‚   └── register.tsx
β”œβ”€β”€ blog
β”‚   β”œβ”€β”€ _components
β”‚   β”‚   β”œβ”€β”€ button.tsx
β”‚   β”‚   └── comments.tsx
β”‚   β”œβ”€β”€ [...all].tsx
β”‚   β”œβ”€β”€ [slug].tsx
β”‚   β”œβ”€β”€ _layout.tsx
β”‚   β”œβ”€β”€ index.tsx
β”‚   └── tags.tsx
β”œβ”€β”€ docs
β”‚   β”œβ”€β”€ -[lang]
β”‚   β”‚   β”œβ”€β”€ index.tsx
β”‚   β”‚   └── resources.tsx
β”‚   └── -en
β”‚       └── contributors.tsx
β”œβ”€β”€ +info.tsx
β”œβ”€β”€ 404.tsx
β”œβ”€β”€ _app.tsx
β”œβ”€β”€ _ignored.tsx
β”œβ”€β”€ about.tsx
β”œβ”€β”€ blog.w.o.layout.tsx
└── index.tsx
Overview
FilePathConvention
(auth)/_layout.tsxPathless Layout group
(auth)/login.tsx/loginRegular route
(auth)/register.tsx/registerRegular route
blog/_components/button.tsxIgnored route by an ignored directory
blog/_components/comments.tsxIgnored route by an ignored directory
blog/[...all].tsx/blog/*Dynamic catch-all route
blog/[slug].tsx/blog/:slugDynamic route
blog/_layout.tsxLayout for /blog routes
blog/index.tsx/blogIndex route
blog/tags.tsx/blog/tagsRegular route
docs/-[lang]/index.tsx/docs/:lang?/indexOptional dynamic route segment
docs/-[lang]/resources.tsx/docs/:lang?/resourcesOptional dynamic route segment
docs/-en/contributors.tsx/docs/en?/contributorsOptional static route segment
+info.tsx/infoModal route
404.tsx*Custom 404 (optional)
_app.tsxCustom app layout (optional)
_ignored.tsxIgnored route
about.tsx/aboutRegular route
blog.w.o.layout.tsx/blog/w/o/layoutRoute without /blog layout
index.tsx/Index route

API

Routing

Via @generouted/react-router or @generouted/solid-router

  • <Routes /> β€” file-based routing component to be render in the app entry
  • <Modals /> β€” optional file-based modals component to be render in the _app.tsx layout
  • routes β€” file-based routes tree/object used by default at <Routes /> component

Routing + code-splitting and lazy-loading

Via @generouted/react-router/lazy or @generouted/solid-router/lazy

  • Used instead of @generouted/react-router or @generouted/solid-router to enable lazy-loading
  • Make sure to replace all imports to lazy imports β€” namely at app entry and src/pages/_app.tsx
  • Provides the same <Routes />, <Modals /> and routes exports

Plugins

Via @generouted/react-router/plugin or @generouted/solid-router/plugin

  • Vite plugin for type generation and initializing type-safe components/hooks/utils
  • Generates src/router.ts file
  • Exports type-safe <Link>, <Navigate>, useModals(), useNavigate(), useParams(), redirect(), etc.
  • Check out @generouted/react-router docs or @generouted/solid-router docs for more details

Core

Via @generouted/react-router/core or @generouted/solid-router/core

  • Available for customization, however it's recommended to use the available integrations directory via the <Routes/> component
  • Check out the custom integration example

License

MIT

Keywords

FAQs

Package last updated on 24 Aug 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚑️ by Socket Inc