Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tomokimiyauci/react-router
Next generation React router
https://github.com/tomokimiyauci/react-router
navigation-api react router url-pattern
Last synced: 8 days ago
JSON representation
Next generation React router
- Host: GitHub
- URL: https://github.com/tomokimiyauci/react-router
- Owner: TomokiMiyauci
- License: mit
- Created: 2024-03-29T07:31:59.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-05-08T03:03:57.000Z (8 months ago)
- Last Synced: 2024-11-24T20:54:00.571Z (about 1 month ago)
- Topics: navigation-api, react, router, url-pattern
- Language: TypeScript
- Homepage: https://jsr.io/@miyauci/react-router
- Size: 59.6 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Security: .github/SECURITY.md
Awesome Lists containing this project
README
# react-router
[![JSR](https://jsr.io/badges/@miyauci/react-router)](https://jsr.io/@miyauci/react-router)
[![GitHub](https://img.shields.io/github/license/TomokiMiyauci/react-router)](https://github.com/TomokiMiyauci/react-router/blob/main/LICENSE)[![release](https://github.com/TomokiMiyauci/react-router/actions/workflows/release.yml/badge.svg?branch=main)](https://github.com/TomokiMiyauci/react-router/actions/workflows/release.yml)
[![standard-readme compliant](https://img.shields.io/badge/readme%20style-standard-brightgreen.svg)](https://github.com/RichardLitt/standard-readme)Next generation React router.
A minimal router based on
[URLPattern](https://developer.mozilla.org/en-US/docs/Web/API/URL_Pattern_API)
API and
[Navigation](https://developer.mozilla.org/en-US/docs/Web/API/Navigation_API)
API. No more `` or ``.## Table of Contents
- [Install](#install)
- [Usage](#usage)
- [Client Side Navigation](#client-side-navigation)
- [Polyfill](#polyfill)
- [Documentation](#documentation)
- [Remarks](#remarks)
- [URLPatternList](#urlpatternlist)
- [API](#api)
- [Contributing](#contributing)
- [License](#license)## Install
deno:
```bash
deno add @miyauci/react-router
```npm:
```bash
npx jsr add @miyauci/react-router
```## Usage
The basic exclusive routing is as follows:
```tsx
import {
Route,
Router,
Switch,
useURL,
useURLPatternResult,
} from "@miyauci/react-router";
import { type ReactNode } from "react";function Home(): ReactNode {
const url = useURL();
const result = useURLPatternResult();return Home;
}
declare const About: () => ReactNode;
declare const NotFound: () => ReactNode;function App(props: { url?: string | URL }): ReactNode {
return (
}>
);
}
```It is best practice to specify the `url` on the server side and nothing on the
client side.### Client Side Navigation
Intercept the `navigate` event on client side navigation.
Add your client entry point:
```ts
globalThis.navigation.addEventListener("navigate", (e) => {
// if (shouldNotIntercept(e)) return;
e.intercept({
async handler() {},
});
});
```This ensures that navigation is done only for URL changes. The `Router` will
also subscribe to URL changes and route them reactively.See
[Modern client-side routing: the Navigation API](https://developer.chrome.com/docs/web-platform/navigation-api)
about `shouldNotIntercept`.This script may be provided by this project in the future.
### Polyfill
This project relies on a relatively new API.
The API and Polyfill are as follows:
| API | Polyfill |
| ------------------------------------------------------------------------------ | ---------------------------------------------------------------------- |
| [URLPattern](https://developer.mozilla.org/en-US/docs/Web/API/URL_Pattern_API) | [urlpattern-polyfill](https://github.com/kenchris/urlpattern-polyfill) |
| [Navigation](https://developer.mozilla.org/en-US/docs/Web/API/Navigation_API) | [@virtualstate/navigation](https://github.com/virtualstate/navigation) |## Documentation
- [Router](./docs/router.md)
- [Switch](./docs/switch.md)
- [Route](./docs/route.md)
- [Hooks](./docs/hooks.md)## Remarks
This chapter supplements the project.
### URLPatternList
This project is based on the
[`URLPatternList`](https://pr-preview.s3.amazonaws.com/lucacasonato/urlpattern/pull/166.html#urlpatternlist-class)
interface. This API is still Draft, but will be replaced when it is generalized.
This should further reduce the bundle size.## API
See [jsr doc](https://jsr.io/@miyauci/react-router) for all APIs.
## Contributing
See [contributing](CONTRIBUTING.md).
## License
[MIT](LICENSE) © 2024 Tomoki Miyauchi