Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/arlac77/svelte-guard-history-router
svelte guarded history router
https://github.com/arlac77/svelte-guard-history-router
router svelte
Last synced: 3 months ago
JSON representation
svelte guarded history router
- Host: GitHub
- URL: https://github.com/arlac77/svelte-guard-history-router
- Owner: arlac77
- License: bsd-2-clause
- Created: 2019-08-07T08:55:22.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-10-18T00:01:49.000Z (3 months ago)
- Last Synced: 2024-10-18T01:35:38.449Z (3 months ago)
- Topics: router, svelte
- Language: JavaScript
- Size: 18.7 MB
- Stars: 11
- Watchers: 3
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![Svelte v5](https://img.shields.io/badge/svelte-v5-orange.svg)](https://svelte.dev)
[![npm](https://img.shields.io/npm/v/svelte-guard-history-router.svg)](https://www.npmjs.com/package/svelte-guard-history-router)
[![License](https://img.shields.io/badge/License-BSD%203--Clause-blue.svg)](https://opensource.org/licenses/BSD-3-Clause)
[![bundlejs](https://deno.bundlejs.com/?q=svelte-guard-history-router\&badge=detailed)](https://bundlejs.com/?q=svelte-guard-history-router)
[![downloads](http://img.shields.io/npm/dm/svelte-guard-history-router.svg?style=flat-square)](https://npmjs.org/package/svelte-guard-history-router)
[![GitHub Issues](https://img.shields.io/github/issues/arlac77/svelte-guard-history-router.svg?style=flat-square)](https://github.com/arlac77/svelte-guard-history-router/issues)
[![Build Status](https://img.shields.io/endpoint.svg?url=https%3A%2F%2Factions-badge.atrox.dev%2Farlac77%2Fsvelte-guard-history-router%2Fbadge\&style=flat)](https://actions-badge.atrox.dev/arlac77/svelte-guard-history-router/goto)
[![Styled with prettier](https://img.shields.io/badge/styled_with-prettier-ff69b4.svg)](https://github.com/prettier/prettier)
[![Commitizen friendly](https://img.shields.io/badge/commitizen-friendly-brightgreen.svg)](http://commitizen.github.io/cz-cli/)
[![Known Vulnerabilities](https://snyk.io/test/github/arlac77/svelte-guard-history-router/badge.svg)](https://snyk.io/test/github/arlac77/svelte-guard-history-router)
[![Coverage Status](https://coveralls.io/repos/arlac77/svelte-guard-history-router/badge.svg)](https://coveralls.io/github/arlac77/svelte-guard-history-router)
[![Tested with TestCafe](https://img.shields.io/badge/tested%20with-TestCafe-2fa4cf.svg)](https://github.com/DevExpress/testcafe)# svelte-guard-history-router
svelte guarded history router
# Features
* Named params `article/:id`
* Guards to act when entering or leaving a route
* Automatic route ranking (more specific routes have higher priority)
* Routes and keys acting as stores
* Nested Routes with relative paths for route composition (Shared Leave Routes)
* Route values
* Object <=> parameter mapping
* Create links from objects
* Standart `Home` elements## Shared Leave Routes
```html
```
# usage
```html
import { Router, Route, Outlet, redirectGuard } from "svelte-guard-history-router";
import About from "./About.svelte";
import Categories from "./Categories.svelte";
import Category from "./Category.svelte";
import Articles from "./Articles.svelte";
import Article from "./Article.svelte";import { enshureSession } from "./main.mjs";
export const enshureSession = redirectGuard("/login", () => !session);
let session = undefined;
Router Example
-
About
-
Articles
-
Categories
```
## Sample code
Check out the code in the [example](/tests/app) folder,
or the [live example](https://svelte-guard-history-router.pages.dev/).
To run the sample, clone the repository, install the dependencies, and start:
```sh
git clone https://github.com/arlac77/svelte-guard-history-router
cd svelte-guard-history-router
npm install
npm start
```
then navigate to [localhost:5000](http://localhost:5173/)
## run tests
```sh
export BROWSER=safari|chrome|...
yarn test
or
npm test
```
# API
### Table of Contents
* [active](#active)
* [Parameters](#parameters)
* [Key](#key)
* [Properties](#properties)
* [BaseRouter](#baserouter)
* [Parameters](#parameters-1)
* [Properties](#properties-1)
* [component](#component)
* [value](#value)
* [path](#path)
* [path](#path-1)
* [Parameters](#parameters-2)
* [replace](#replace)
* [Parameters](#parameters-3)
* [push](#push)
* [Parameters](#parameters-4)
* [finalizePush](#finalizepush)
* [Parameters](#parameters-5)
* [continue](#continue)
* [Parameters](#parameters-6)
* [abort](#abort)
* [Parameters](#parameters-7)
* [subscribe](#subscribe)
* [Parameters](#parameters-8)
* [updateActive](#updateactive)
* [Parameters](#parameters-9)
* [addRoute](#addroute)
* [Parameters](#parameters-10)
* [routeFor](#routefor)
* [Parameters](#parameters-11)
* [pathFor](#pathfor)
* [Parameters](#parameters-12)
* [BaseTransition](#basetransition)
* [searchParams](#searchparams)
* [searchParams](#searchparams-1)
* [Parameters](#parameters-13)
* [nest](#nest)
* [Parameters](#parameters-14)
* [continue](#continue-1)
* [abort](#abort-1)
* [Parameters](#parameters-15)
* [DetailRoute](#detailroute)
* [Properties](#properties-2)
* [master](#master)
* [first](#first)
* [last](#last)
* [previous](#previous)
* [next](#next)
* [Guard](#guard)
* [enter](#enter)
* [Parameters](#parameters-16)
* [leave](#leave)
* [Parameters](#parameters-17)
* [redirectGuard](#redirectguard)
* [Parameters](#parameters-18)
* [sequenceGuard](#sequenceguard)
* [Parameters](#parameters-19)
* [parallelGuard](#parallelguard)
* [Parameters](#parameters-20)
* [MasterRoute](#masterroute)
* [Parameters](#parameters-21)
* [Properties](#properties-3)
* [nullGuard](#nullguard)
* [RootRoute](#rootroute)
* [hasParams](#hasparams)
* [path](#path-2)
* [propertyMapping](#propertymapping)
* [guard](#guard-1)
* [SkeletonRoute](#skeletonroute)
* [Parameters](#parameters-22)
* [Properties](#properties-4)
* [enter](#enter-1)
* [Parameters](#parameters-23)
* [leave](#leave-1)
* [Parameters](#parameters-24)
* [isAcceptable](#isacceptable)
* [Parameters](#parameters-25)
* [propertiesFor](#propertiesfor)
* [Parameters](#parameters-26)
* [commonAncestor](#commonancestor)
* [Parameters](#parameters-27)
* [valueFor](#valuefor)
* [Parameters](#parameters-28)
* [value](#value-1)
* [propertyMapping](#propertymapping-1)
* [objectInstance](#objectinstance)
* [ValueStoreRoute](#valuestoreroute)
* [Transition](#transition)
* [Parameters](#parameters-29)
* [Properties](#properties-5)
* [start](#start)
* [end](#end)
* [redirect](#redirect)
* [Parameters](#parameters-30)
* [abort](#abort-2)
* [Parameters](#parameters-31)
* [findClosestAttribute](#findclosestattribute)
* [Parameters](#parameters-32)
* [dispatchNavigationEvent](#dispatchnavigationevent)
* [Parameters](#parameters-33)
* [nameValueStore](#namevaluestore)
* [Parameters](#parameters-34)
* [Properties](#properties-6)
* [WaitingGuard](#waitingguard)
* [Parameters](#parameters-35)
## active
* **See**: {Router.updateActive}
Keeps the node active state in sync.
### Parameters
* `node` **[Element](https://developer.mozilla.org/docs/Web/API/Element)**
* `router` **Router**
## Key
Keys also act as svelte stores and can be subscribed.
```js
export const article = derived(
[articles, router.keys.article],
([$articles, $id], set) => {
set($articles.find(a => a.id === $id));
return () => {};
}
);
```
Type: [Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)
### Properties
* `name` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
* `value` **any**
* `subscriptions` **[Set](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Set)**
## BaseRouter
**Extends BaseTransition**
key subscriptions:
```js
const aKey = router.keys.aKey;
$aKey // fired if value of aKey changes
```
### Parameters
* `routes` **[Array](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array)\** all managed routes
* `base` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** url (optional, default `new URL("../",import.meta.url).pathname`)
### Properties
* `linkNodes` **[Set](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Set)<[Node](https://developer.mozilla.org/docs/Web/API/Node/nextSibling)>** nodes having their active state updated
* `routes` **[Array](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array)\**
* `keys` **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)** collected keys of all routes
* `params` **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)** value mapping from keys (from current route)
* `route` **Route** current
* `nested` **[Transition](#transition)** ongoing nested transition
* `base` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** url
### component
Current component.
Either from a nested transition or from the current route
Returns **SvelteComponent**
### value
Value if the current route
Returns **any**
### path
Returns **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** url path with fragment & query
### path
Replace current route.
#### Parameters
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
### replace
Replace current route without updating the state.
#### Parameters
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
Returns **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)** former state
### push
Leave current route and enter route for given path.
The work is done by a Transition.
#### Parameters
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** where to go
Returns **[Transition](#transition)** running transition
### finalizePush
Called from a Transition to manifest the new destination.
If path is undefined the Transition has been aborderd.
#### Parameters
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
### continue
Continue a transition to its original destination.
Shortcut for this.transition.continue().
If there is no transition ongoing and a fallbackPath is
present, it will be entered.
Otherwise does nothing.
#### Parameters
* `fallbackPath` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
### abort
Abort a transition.
Shortcut for this.transition.abort()
If there is no transition ongoing and a fallbackPath is
present it will be entered.
Otherwise does nothing.
#### Parameters
* `fallbackPath` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
### subscribe
Router subscription.
Changes in the current route will trigger a update
#### Parameters
* `subscription` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)**
### updateActive
Update the active state of a node.
A node is considered active if it shared the path prefix with the current route.
#### Parameters
* `node` **[Element](https://developer.mozilla.org/docs/Web/API/Element)**
### addRoute
Add a new Route.
#### Parameters
* `route` **Route**
### routeFor
Find Route for a given value.
#### Parameters
* `value` **any**
Returns **Route** able to support given value
### pathFor
Find path for a given value.
#### Parameters
* `value` **any**
* `suffix` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** to be appended
Returns **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** path + suffix
## BaseTransition
### searchParams
Deliver url search params form the current location.
Returns **URLSearchParams** as extracted from the path
### searchParams
Replaces the search part of the path with the given searchParams.
#### Parameters
* `searchParams` **(URLSearchParams | [Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object))**
### nest
Add another transition nesting level.
Starts a transition from the given factory.
#### Parameters
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
* `factory` **[Transition](#transition)**
### continue
Continue a nested route to its original destination.
Does nothing if the transition has not been nested.
### abort
Abort the transition.
#### Parameters
* `error`
Returns **[Promise](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Promise)<[boolean](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean)>** truen in case there was a nesten transition
## DetailRoute
**Extends ValueStoreRoute**
Route to represent a slice of the masters list of values.
### Properties
* `master` **Route** route holding the master records
### master
Route holding the list ov values
Returns **Route** our master
### first
Returns **[Promise](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Promise)\** 1st. entry
### last
Returns **any** last entry
### previous
Returns **any** previous value
### next
Returns **[Promise](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Promise)\** next value
## Guard
Enforces conditions of routes
Like the presents of values in the context
### enter
Called while entering a route (current outlet is not yet set)
#### Parameters
* `transition` **[Transition](#transition)**
### leave
Called before leaving a route
#### Parameters
* `transition` **[Transition](#transition)**
## redirectGuard
Redirects to a given path if condition is met.
### Parameters
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
* `condition` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)** redirects when returning true
## sequenceGuard
Execute guards in a sequence.
### Parameters
* `children` **Iterable<[Guard](#guard)>**
## parallelGuard
Execute guards in a parallel.
### Parameters
* `children` **Iterable<[Guard](#guard)>**
## MasterRoute
**Extends SkeletonRoute**
Route holding a ordered collection of values.
### Parameters
* `path`
* `options`
### Properties
* `value` **[Array](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array)\**
## nullGuard
Default empty guard does nothing.
## RootRoute
Route at the root of the tree.
This route has no parent.
All other routes are below of this one.
### hasParams
Are there parameters in the path.
Returns **[boolean](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean)** true if route has parameters (:key)
### path
Returns **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** empty as we are the root
### propertyMapping
Returns **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)** empty object
### guard
Returns **[Guard](#guard)** empty guard which does nothing
## SkeletonRoute
**Extends RootRoute**
Route
Subscriptions on Routes fire when the route value changes.
### Parameters
* `path`
* `options` (optional, default `{}`)
### Properties
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** full path of the Route including all parents
* `component` **SvelteComponent** target to show
* `linkComponent` **SvelteComponent** content for [ObjectLink](ObjectLink)
* `propertyMapping` **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)** Map properties to object attributes
Keys are the property names and values are the keys in the resulting object.
* `priority` **[number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)**
* `keys` **[Array](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array)<[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)>** as found in the path
* `regex` **RegEx**
* `value` **any**
### enter
Enter the route from a former one.
All parent routes up to the common ancestor are entered first.
#### Parameters
* `transition` **[Transition](#transition)**
* `untilRoute` **Route** the common ancestor with the former route
### leave
Leave the route to a new one.
All parent routes up to the common ancestor are left.
#### Parameters
* `transition` **[Transition](#transition)**
* `untilRoute` **Route** the common ancestor with the future route
### isAcceptable
Check if value and properties are acceptable for the route.
#### Parameters
* `value` **any** to be placed into route
* `properties` **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)** as presented in the route
Returns **[boolean](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean)** true if value can be accepted
### propertiesFor
Extract properties from a value.
All property values must be strings.
#### Parameters
* `value` **any** source of the properties
Returns **([Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object) | [undefined](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined))** properties extracted from given value
### commonAncestor
Find common ancestor with an other Route.
#### Parameters
* `other` **Route**
Returns **(Route | [undefined](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined))** common ancestor Route between receiver and other
### valueFor
Deliver value for a given set of properties of the transition.
Default implemantation asks the parent route.
#### Parameters
* `transition` **[Transition](#transition)**
Returns **any** for matching properties
### value
Deliver route value.
Default implemantation asks the parent route.
Returns **any**
### propertyMapping
Deliver property mapping.
Default implemantation asks the parent route.
Returns **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)** for matching properties
### objectInstance
Default implemantation asks the parent route.
## ValueStoreRoute
**Extends SkeletonRoute**
Route holding a single value
## Transition
**Extends BaseTransition**
Transition between routes.
### Parameters
* `router` **Router**
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** new destination
### Properties
* `router` **Router**
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** new destination
### start
Start the transition
* leave old route
* find matching target route @see matcher()
* enter new route
* set params
* set current route
### end
* **See**: Router.finalizePush
Cleanup transition.
Update Nodes active state
### redirect
Halt current transition and go to another route.
To proceed with the original route call [continue()](continue\(\))
The original transition will keept in place and can be continued afterwards.
#### Parameters
* `path` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)** new route to enter temporary
### abort
Bring back the router into the state before the transition has started.
All nested transitions also will be termniated.
#### Parameters
* `e` **(Exception | [undefined](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined))**
## findClosestAttribute
Walks up the dom tree parents unti a node with a given attribute is found or the root node is reached.
### Parameters
* `element` **[Element](https://developer.mozilla.org/docs/Web/API/Element)**
* `attributeName` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
Returns **([Element](https://developer.mozilla.org/docs/Web/API/Element) | [undefined](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined))**
## dispatchNavigationEvent
Dispatches a NAVIGATION\_EVENT with pathname and hash
### Parameters
* `event` **[Event](https://developer.mozilla.org/docs/Web/API/Event)**
## nameValueStore
Create a named object which also acts as a store.
### Parameters
* `name` **[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)**
* `value` **any** initial value
### Properties
* `value` **any**
Returns **Store**
## WaitingGuard
**Extends Guard**
Shows a component during transition.
### Parameters
* `component` **SvelteComponent** to show up during th transition
* `rampUpTime` **[number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)** initial delay for the componnt to show up (optional, default `300`)
# install
With [npm](http://npmjs.org) do:
```shell
npm install svelte-guard-history-router
```
With [yarn](https://yarnpkg.com) do:
```shell
yarn add svelte-guard-history-router
```
# SPA integrating with a nginx backend
All unresolvable requests are redirected to /sericeBase/index.html
* /deploymantLocation is the location of the frontend in the servers file system
* /serviceBase is the url path as seen from the browser
```nginx.conf
location /serviceBase {
alias /deploymentLocation;
try_files $uri$args $uri$args/ /serviceBase/index.html;
}
```
# SPA integrating with a netlify
publish a \_redirects file into the app root folder
```_redirects
/* /index.html 200
```
# license
BSD-2-Clause