web/elements: add new API to store attributes in URL, use for table and tabs
Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
This commit is contained in:
		| @ -1,5 +1,6 @@ | ||||
| import { TemplateResult } from "lit"; | ||||
|  | ||||
| import { ROUTE_SEPARATOR } from "../../constants"; | ||||
| import { Route } from "./Route"; | ||||
|  | ||||
| export class RouteMatch { | ||||
| @ -22,3 +23,44 @@ export class RouteMatch { | ||||
|         )}>`; | ||||
|     } | ||||
| } | ||||
|  | ||||
| export function getURLParam<T>(key: string, fallback: T): T { | ||||
|     const params = getURLParams(); | ||||
|     if (key in params) { | ||||
|         return params[key] as T; | ||||
|     } | ||||
|     return fallback; | ||||
| } | ||||
|  | ||||
| export function getURLParams(): { [key: string]: unknown } { | ||||
|     const params = {}; | ||||
|     if (window.location.hash.includes(ROUTE_SEPARATOR)) { | ||||
|         const urlParts = window.location.hash.slice(1, Infinity).split(ROUTE_SEPARATOR, 2); | ||||
|         const rawParams = decodeURIComponent(urlParts[1]); | ||||
|         try { | ||||
|             return JSON.parse(rawParams); | ||||
|         } catch { | ||||
|             return params; | ||||
|         } | ||||
|     } | ||||
|     return params; | ||||
| } | ||||
|  | ||||
| export function setURLParams(params: { [key: string]: unknown }, replace = true): void { | ||||
|     const paramsString = JSON.stringify(params); | ||||
|     const currentUrl = window.location.hash.slice(1, Infinity).split(ROUTE_SEPARATOR)[0]; | ||||
|     const newUrl = `#${currentUrl};${encodeURIComponent(paramsString)}`; | ||||
|     if (replace) { | ||||
|         history.replaceState(undefined, "", newUrl); | ||||
|     } else { | ||||
|         history.pushState(undefined, "", newUrl); | ||||
|     } | ||||
| } | ||||
|  | ||||
| export function updateURLParams(params: { [key: string]: unknown }, replace = true): void { | ||||
|     const currentParams = getURLParams(); | ||||
|     for (const key in params) { | ||||
|         currentParams[key] = params[key] as string; | ||||
|     } | ||||
|     setURLParams(currentParams, replace); | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Jens Langhammer
					Jens Langhammer