generouted
Advanced tools
Comparing version 1.1.1 to 1.1.2
{ | ||
"name": "generouted", | ||
"version": "1.1.1", | ||
"version": "1.1.2", | ||
"description": "Generated file-based routes for React Location and Vite", | ||
@@ -48,3 +48,3 @@ "author": "Omar Elhawary <oedotme@gmail.com> (https://omarelhawary.me)", | ||
}, | ||
"readme": "<br>\n<p align=\"center\">\n <img src=\"./public/assets/icons/logo.svg\" alt=\"Generouted · Generated Routes\" width=\"120\"/>\n</p>\n<p align=\"center\"><em>Generouted - Generated Routes</em></p>\n<br>\n\n# Generouted\n\n**Gene**rate**d** file-based **route**s for [React Location](https://react-location.tanstack.com) and [Vite](https://vitejs.dev)\n\n<br>\n\n## Motivation\n\nI enjoyed working with file-based routing since started using it with Next.js. After trying the same concept with Vite, I started a series of blog posts covering [client-side file-based routing with React Router](https://omarelhawary.me/blog/file-based-routing-with-react-router) inspired by [Next.js](https://nextjs.org). Later, in the last two posts, I replaced React Router with React Location to add more features like data loaders and nested layouts that are inspired by [Remix](https://remix.run). The final version covered in the blog posts is now published as `generouted`, see all the [available features](#features) below.\n\n## How\n\n`generouted` is only one _source code_ file, with **no dependencies or build step**. It uses [Vite's glob import API](https://vitejs.dev/guide/features.html#glob-import) to list the modules within `src/pages` directory to be used as React Location's routes.\n\n## Why\n\n- **Declarative and universal file-based routing** system\n- **Automatically update routes** by adding/removing/renaming files at the `src/pages` directory\n- Can be used with **any Vite project**\n- **Easier to migrate** when switching from or to Next.js\n\n<br>\n\n## Features\n\n- [File-based routing](#file-based-routing)\n- [Route-based code-splitting and pre-loading](#route-based-code-splitting-and-pre-loading)\n- [Route-based data loaders](#route-based-data-loaders)\n- [Nested layouts](#nested-layouts)\n\n### File-based routing\n\n- [Next.js inspired](https://nextjs.org/docs/routing/introduction)\n- Supports `.tsx` extensions\n- Custom app at `src/pages/_app.tsx` _(optional)_\n- Custom 404 page at `src/pages/404.tsx` _(optional)_\n- Navigation between routes using [React Location's `<Link />` component](https://react-location.tanstack.com/docs/api#link)\n\n#### Conventions\n\n##### Index routes\n\n- `src/pages/index.tsx` **→** `/`\n- `src/pages/posts/index.tsx` **→** `/posts`\n\n##### Nested routes\n\n- `src/pages/posts/2022/index.tsx` **→** `/posts/2022`\n- `src/pages/posts/2022/resolutions.tsx` **→** `/posts/2022/resolutions`\n\n##### Dynamic routes\n\n- `src/pages/posts/[slug].tsx` **→** `/posts/:slug`\n- `src/pages/posts/[slug]/tags.tsx` **→** `/posts/:slug/tags`\n- `src/pages/posts/[...all].tsx` **→** `/posts/*`\n\n### Route-based code-splitting and pre-loading\n\n- Includes routes components and data loaders\n\n### Route-based data loaders\n\n- [Remix inspired](https://remix.run/docs/en/v1/guides/data-loading)\n- By exporting a named function `loader` from a page: `export const loader = async () => ({...})`\n- [React Location's route loaders guide](https://react-location.tanstack.com/guides/route-loaders)\n\n### Nested layouts\n\n- [Remix inspired](https://remix.run/docs/en/v1/guides/routing#what-is-nested-routing)\n- Adding a layout for a group of routes by naming a file same as their parent directory\n- Supports data loaders\n- Requires React Location's `<Outlet />` component to render its children\n\n#### Conventions\n\n##### Enable for all directory routes\n\nAdd a layout for all the routes within `src/pages/posts` directory by adding `src/pages/posts.tsx` layout:\n\n- `src/pages/posts/index.tsx` **→** `/posts`\n- `src/pages/posts/2022/index.tsx` **→** `/posts/2022`\n- `src/pages/posts/[slug].tsx` **→** `/posts/:slug`\n\n##### Exclude a route - URL nesting without layout nesting\n\nReplace regular file name with directory nesting by adding dots, it will be converted to forward slashes:\n\n- `src/pages/posts.nested.as.url.not.layout.tsx` **→** `/posts/nested/as/url/not/layout`\n\n<br>\n\n## Getting started\n\nIf you have an existing Vite project setup with React you can skip this section and go to the [installation section](#installation).\n\nOtherwise you can [scaffold a new Vite project](https://vitejs.dev/guide/#scaffolding-your-first-vite-project) with React and TypeScript:\n\n```shell\nnpm create vite@latest react-file-based-routing -- --template react-ts # npm 7+\n```\n\n## Installation\n\n```shell\nnpm install generouted react-location\n```\n\n## Usage\n\nRender the `<Routes />` component from `generouted` at the app entry _(you'd mostly wrap it with other providers/components)_:\n\n```tsx\n// src/main.tsx\n\nimport { render } from 'react-dom'\nimport { Routes } from 'generouted'\n\nconst container = document.getElementById('app')!\nrender(<Routes />, container)\n```\n\n### Adding pages\n\nAdd the home page by creating a new file `src/pages/index.tsx` **→** `/`, then export a default component:\n\n```tsx\nexport default function Home() {\n return <h1>Home</h1>\n}\n```\n\n<br>\n\n## Examples\n\n- [Basic](./examples/basic)\n\n<br>\n\n## API\n\n### `<Routes />`\n\nThat's the only export at the moment. Could add some customization options in the future.\n\n<br>\n\n## License\n\nMIT\n" | ||
"readme": "<br>\n<p align=\"center\">\n <img src=\"./public/assets/icons/logo.svg\" alt=\"Generouted · Generated Routes\" width=\"120\"/>\n</p>\n<p align=\"center\"><em>Generouted - Generated Routes</em></p>\n<br>\n\n# Generouted\n\n**Gene**rate**d** file-based **route**s for [React Location](https://react-location.tanstack.com) and [Vite](https://vitejs.dev)\n\n<br>\n\n## Motivation\n\nI enjoyed working with file-based routing since started using it with Next.js. After trying the same concept with Vite, I started a series of blog posts covering [client-side file-based routing with React Router](https://omarelhawary.me/blog/file-based-routing-with-react-router) inspired by [Next.js](https://nextjs.org). Later, in the last two posts, I replaced React Router with React Location to add more features like data loaders and nested layouts that are inspired by [Remix](https://remix.run). The final version covered in the blog posts is now published as `generouted`, see all the [available features](#features) below.\n\n## How\n\n`generouted` is only one _source code_ file, with **no dependencies or build step**. It uses [Vite's glob import API](https://vitejs.dev/guide/features.html#glob-import) to list the modules within `src/pages` directory to be used as React Location's routes.\n\n## Why\n\n- **Declarative and universal file-based routing** system\n- **Automatically update routes** by adding/removing/renaming files at the `src/pages` directory\n- Can be used with **any Vite project**\n- **Easier to migrate** when switching from or to Next.js\n\n<br>\n\n## Features\n\n- [File-based routing](#file-based-routing)\n- [Route-based code-splitting and pre-loading](#route-based-code-splitting-and-pre-loading)\n- [Route-based data loaders](#route-based-data-loaders)\n- [Nested layouts](#nested-layouts)\n\n### File-based routing\n\n- [Next.js inspired](https://nextjs.org/docs/routing/introduction)\n- Supports `.tsx` extensions\n- Custom app at `src/pages/_app.tsx` _(optional)_\n- Custom 404 page at `src/pages/404.tsx` _(optional)_\n- Navigation between routes using [React Location's `<Link />` component](https://react-location.tanstack.com/docs/api#link)\n\n#### Conventions\n\n##### Index routes\n\n- `src/pages/index.tsx` **→** `/`\n- `src/pages/posts/index.tsx` **→** `/posts`\n\n##### Nested routes\n\n- `src/pages/posts/2022/index.tsx` **→** `/posts/2022`\n- `src/pages/posts/2022/resolutions.tsx` **→** `/posts/2022/resolutions`\n\n##### Dynamic routes\n\n- `src/pages/posts/[slug].tsx` **→** `/posts/:slug`\n- `src/pages/posts/[slug]/tags.tsx` **→** `/posts/:slug/tags`\n- `src/pages/posts/[...all].tsx` **→** `/posts/*`\n\n### Route-based code-splitting and pre-loading\n\n- Includes routes components and data loaders\n\n### Route-based data loaders\n\n- [Remix inspired](https://remix.run/docs/en/v1/guides/data-loading)\n- By exporting a named function `loader` from a page: `export const loader = async () => ({...})`\n- [React Location's route loaders guide](https://react-location.tanstack.com/guides/route-loaders)\n\n### Nested layouts\n\n- [Remix inspired](https://remix.run/docs/en/v1/guides/routing#what-is-nested-routing)\n- Adding a layout for a group of routes by naming a file same as their parent directory\n- Supports data loaders\n- Requires React Location's `<Outlet />` component to render its children\n\n#### Conventions\n\n##### Enable for all directory routes\n\nAdd a layout for all the routes within `src/pages/posts` directory by adding `src/pages/posts.tsx` layout:\n\n- `src/pages/posts/index.tsx` **→** `/posts`\n- `src/pages/posts/2022/index.tsx` **→** `/posts/2022`\n- `src/pages/posts/[slug].tsx` **→** `/posts/:slug`\n\n##### Exclude a route - URL nesting without layout nesting\n\nReplace regular file name with directory nesting by adding dots, it will be converted to forward slashes:\n\n- `src/pages/posts.nested.as.url.not.layout.tsx` **→** `/posts/nested/as/url/not/layout`\n\n<br>\n\n## Getting started\n\nIf you have an existing Vite project setup with React you can skip this section and go to the [installation section](#installation).\n\nOtherwise you can [scaffold a new Vite project](https://vitejs.dev/guide/#scaffolding-your-first-vite-project) with React and TypeScript:\n\n```shell\nnpm create vite@latest react-file-based-routing -- --template react-ts # npm 7+\n```\n\n## Installation\n\n```shell\nnpm install generouted react-location\n```\n\n## Usage\n\nRender the `<Routes />` component from `generouted` at the app entry _(you'd mostly wrap it with other providers/components)_:\n\n```tsx\n// src/main.tsx\n\nimport { render } from 'react-dom'\nimport { Routes } from 'generouted'\n\nconst container = document.getElementById('app')!\nrender(<Routes />, container)\n```\n\n### Adding pages\n\nAdd the home page by creating a new file `src/pages/index.tsx` **→** `/`, then export a default component:\n\n```tsx\nexport default function Home() {\n return <h1>Home</h1>\n}\n```\n\n<br>\n\n## Examples\n\n- [Basic](./examples/basic)\n- [Data loaders](./examples/data-loaders)\n- [Nested layouts](./examples/nested-layouts)\n\n<br>\n\n## API\n\n### `<Routes />`\n\nThat's the only export at the moment. Could add some customization options in the future.\n\n<br>\n\n## License\n\nMIT\n" | ||
} |
@@ -144,2 +144,4 @@ <br> | ||
- [Basic](./examples/basic) | ||
- [Data loaders](./examples/data-loaders) | ||
- [Nested layouts](./examples/nested-layouts) | ||
@@ -146,0 +148,0 @@ <br> |
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
60048
160
0
0