UNPKG

@versatiledatakit/shared

Version:

Versatile Data Kit Shared library enables reusability of shared features like: NgRx Redux, Error Handlers, Utils, Generic Components, etc.

232 lines • 25 kB
/* * Copyright 2023-2025 Broadcom * SPDX-License-Identifier: Apache-2.0 */ import { SE_LOCATION_CHANGE, SE_NAVIGATE, SystemEventDispatcher } from '../system-events'; /** * ** State Manager for Browser URL. * * - Provides methods for easy appending/retrieving/removing of params and query params to the URL state. * - Provides ability to serialize current state as URL href. */ export class URLStateManager { /** * ** Constructor. */ constructor(baseURL, urlLocation) { this.baseURL = baseURL; this.urlLocation = urlLocation; /** * ** Store value if URL Params State mutated since previous navigation. */ this.isParamsStateMutated = false; /** * ** Store value if URL QueryParams State mutated since previous navigation. */ this.isQueryParamsStateMutated = false; this.params = new Map(); this.queryParams = new Map(); this.locationHref = this.urlLocation.path(); } /** * ** Returns current Browser URL href. */ get URL() { if (this.baseURL) { return `${this.baseURL}${this.getParamsToString()}${this.getQueryParamsToString()}`; } return null; } /** * ** Replace current URL state to Browser URL. */ replaceToUrl() { const browserCurrUrl = window.location.href; if (browserCurrUrl.endsWith(encodeURI(this.URL))) { return; } this.isParamsStateMutated = false; this.urlLocation.replaceState(this.URL); } /** * ** Apply current URL state to Browser URL. */ locationToURL() { const browserCurrUrl = window.location.href; if (browserCurrUrl.endsWith(encodeURI(this.URL))) { return; } this.isParamsStateMutated = false; this._notifyForLocationChange(); this.urlLocation.go(this.URL); } /** * ** Navigate through Angular Router with set URL state. */ navigateToUrl() { const browserCurrUrl = window.location.href; if (browserCurrUrl.endsWith(encodeURI(this.URL))) { return Promise.resolve(false); } this.isQueryParamsStateMutated = false; return SystemEventDispatcher.send(SE_NAVIGATE, { url: this.buildUrlWithParams(), extras: { queryParams: this.getQueryParamsAsMap() } }, 1); } /** * ** Set query param to URL state. */ setQueryParam(key, value, position = 1) { this.isQueryParamsStateMutated = true; if (value) { this.queryParams.set(key, { key, value, position }); } else { this.removeQueryParam(key); } } /** * ** Returns query param value for given key. */ getQueryParam(key) { if (this.queryParams.has(key)) { return this.queryParams.get(key).value; } return null; } /** * ** Removes query param from URL state. */ removeQueryParam(key) { if (this.queryParams.has(key)) { this.isQueryParamsStateMutated = true; this.queryParams.delete(key); } } /** * ** Clear stored queryParams. */ clearQueryParams() { this.queryParams.clear(); } /** * ** Set param to URL state. */ setParam(key, value, position = 1) { this.isParamsStateMutated = true; if (value) { this.params.set(key, { key, value, position }); } else { this.removeParam(key); } } /** * ** Returns param value for given key. */ getParam(key) { if (this.params.has(key)) { return this.params.get(key).value; } return null; } /** * ** Removes query param from URL state. */ removeParam(key) { if (this.params.has(key)) { this.isParamsStateMutated = true; this.params.delete(key); } } /** * ** Clear stored params. */ clearParams() { this.params.clear(); } /** * ** Returns serialized params in string. */ getParamsToString() { let paramString = ''; this.getSortedByPosition(this.params).forEach((p) => { paramString += `/${p.value}`; }); return paramString; } /** * ** Returns serialized queryParams in string. */ getQueryParamsToString() { const sortedParams = this.getSortedByPosition(this.queryParams); let paramString = ''; if (sortedParams.length > 0) { paramString = `?${sortedParams[0].key}=${sortedParams[0].value}`; for (let i = 1; i < sortedParams.length; i++) { const p = sortedParams[i]; paramString += `&${p.key}=${p.value}`; } } return paramString; } /** * ** Returns query params in Map format. */ getQueryParamsAsMap() { const sortedParams = this.getSortedByPosition(this.queryParams); const paramsMap = {}; for (const paramsPair of sortedParams) { paramsMap[paramsPair.key] = paramsPair.value; } return paramsMap; } /** * ** Returns params in Map format. */ getParamsAsMap() { const sortedParams = this.getSortedByPosition(this.params); const paramsMap = {}; for (const paramsPair of sortedParams) { paramsMap[paramsPair.key] = paramsPair.value; } return paramsMap; } /** * ** Build url from base and provided params. */ buildUrlWithParams() { if (this.baseURL) { return `${this.baseURL}${this.getParamsToString()}`; } return null; } /** * ** Change Base url. */ changeBaseUrl(baseUrl) { this.baseURL = baseUrl; } getSortedByPosition(values) { return Array.from(values.entries()) .sort((p1, p2) => p1[1].position - p2[1].position) .map((e) => e[1]); } _notifyForLocationChange() { const paramsMap = this.getParamsAsMap(); const paramsSerialized = this.buildUrlWithParams(); const queryParamsMap = this.getQueryParamsAsMap(); const queryParamsSerialized = this.getQueryParamsToString(); SystemEventDispatcher.post(SE_LOCATION_CHANGE, { url: this.URL, params: paramsMap ? paramsMap : {}, paramsSerialized: paramsSerialized ? paramsSerialized : '', queryParams: queryParamsMap ? queryParamsMap : {}, queryParamsSerialized: queryParamsSerialized ? queryParamsSerialized.replace(/^\?/, '') : '' }); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"url-state.manager.js","sourceRoot":"","sources":["../../../../../../projects/shared/src/lib/core/url-state-manager/url-state.manager.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2023-2025 Broadcom\n * SPDX-License-Identifier: Apache-2.0\n */\n\n/* eslint-disable @typescript-eslint/naming-convention */\n\nimport { Location } from '@angular/common';\n\nimport { SE_LOCATION_CHANGE, SE_NAVIGATE, SystemEventDispatcher } from '../system-events';\n\nexport interface StateManagerParamValue {\n    key: string;\n    value: string;\n    position: number;\n}\n\n/**\n * ** State Manager for Browser URL.\n *\n *   - Provides methods for easy appending/retrieving/removing of params and query params to the URL state.\n *   - Provides ability to serialize current state as URL href.\n */\nexport class URLStateManager {\n    /**\n     * ** Store value if URL Params State mutated since previous navigation.\n     */\n    public isParamsStateMutated = false;\n\n    /**\n     * ** Store value if URL QueryParams State mutated since previous navigation.\n     */\n    public isQueryParamsStateMutated = false;\n\n    private readonly params: Map<string, StateManagerParamValue>;\n    private readonly queryParams: Map<string, StateManagerParamValue>;\n    private readonly locationHref: string;\n\n    /**\n     * ** Constructor.\n     */\n    constructor(\n        public baseURL: string,\n        public urlLocation: Location\n    ) {\n        this.params = new Map<string, StateManagerParamValue>();\n        this.queryParams = new Map<string, StateManagerParamValue>();\n\n        this.locationHref = this.urlLocation.path();\n    }\n\n    /**\n     * ** Returns current Browser URL href.\n     */\n    get URL(): string {\n        if (this.baseURL) {\n            return `${this.baseURL}${this.getParamsToString()}${this.getQueryParamsToString()}`;\n        }\n\n        return null;\n    }\n\n    /**\n     * ** Replace current URL state to Browser URL.\n     */\n    replaceToUrl(): void {\n        const browserCurrUrl = window.location.href;\n\n        if (browserCurrUrl.endsWith(encodeURI(this.URL))) {\n            return;\n        }\n\n        this.isParamsStateMutated = false;\n\n        this.urlLocation.replaceState(this.URL);\n    }\n\n    /**\n     * ** Apply current URL state to Browser URL.\n     */\n    locationToURL(): void {\n        const browserCurrUrl = window.location.href;\n\n        if (browserCurrUrl.endsWith(encodeURI(this.URL))) {\n            return;\n        }\n\n        this.isParamsStateMutated = false;\n\n        this._notifyForLocationChange();\n\n        this.urlLocation.go(this.URL);\n    }\n\n    /**\n     * ** Navigate through Angular Router with set URL state.\n     */\n    navigateToUrl(): Promise<boolean> {\n        const browserCurrUrl = window.location.href;\n\n        if (browserCurrUrl.endsWith(encodeURI(this.URL))) {\n            return Promise.resolve(false);\n        }\n\n        this.isQueryParamsStateMutated = false;\n\n        return SystemEventDispatcher.send(\n            SE_NAVIGATE,\n            {\n                url: this.buildUrlWithParams(),\n                extras: {\n                    queryParams: this.getQueryParamsAsMap()\n                }\n            },\n            1\n        );\n    }\n\n    /**\n     * ** Set query param to URL state.\n     */\n    setQueryParam(key: string, value: string, position = 1): void {\n        this.isQueryParamsStateMutated = true;\n\n        if (value) {\n            this.queryParams.set(key, { key, value, position });\n        } else {\n            this.removeQueryParam(key);\n        }\n    }\n\n    /**\n     * ** Returns query param value for given key.\n     */\n    getQueryParam(key: string): string {\n        if (this.queryParams.has(key)) {\n            return this.queryParams.get(key).value;\n        }\n\n        return null;\n    }\n\n    /**\n     * ** Removes query param from URL state.\n     */\n    removeQueryParam(key: string): void {\n        if (this.queryParams.has(key)) {\n            this.isQueryParamsStateMutated = true;\n\n            this.queryParams.delete(key);\n        }\n    }\n\n    /**\n     * ** Clear stored queryParams.\n     */\n    clearQueryParams(): void {\n        this.queryParams.clear();\n    }\n\n    /**\n     * ** Set param to URL state.\n     */\n    setParam(key: string, value: string, position = 1): void {\n        this.isParamsStateMutated = true;\n\n        if (value) {\n            this.params.set(key, { key, value, position });\n        } else {\n            this.removeParam(key);\n        }\n    }\n\n    /**\n     * ** Returns param value for given key.\n     */\n    getParam(key: string): string {\n        if (this.params.has(key)) {\n            return this.params.get(key).value;\n        }\n\n        return null;\n    }\n\n    /**\n     * ** Removes query param from URL state.\n     */\n    removeParam(key: string): void {\n        if (this.params.has(key)) {\n            this.isParamsStateMutated = true;\n\n            this.params.delete(key);\n        }\n    }\n\n    /**\n     * ** Clear stored params.\n     */\n    clearParams(): void {\n        this.params.clear();\n    }\n\n    /**\n     * ** Returns serialized params in string.\n     */\n    getParamsToString(): string {\n        let paramString = '';\n\n        this.getSortedByPosition(this.params).forEach((p) => {\n            paramString += `/${p.value}`;\n        });\n\n        return paramString;\n    }\n\n    /**\n     * ** Returns serialized queryParams in string.\n     */\n    getQueryParamsToString(): string {\n        const sortedParams = this.getSortedByPosition(this.queryParams);\n\n        let paramString = '';\n\n        if (sortedParams.length > 0) {\n            paramString = `?${sortedParams[0].key}=${sortedParams[0].value}`;\n\n            for (let i = 1; i < sortedParams.length; i++) {\n                const p = sortedParams[i];\n                paramString += `&${p.key}=${p.value}`;\n            }\n        }\n\n        return paramString;\n    }\n\n    /**\n     * ** Returns query params in Map format.\n     */\n    getQueryParamsAsMap(): { [key: string]: string } {\n        const sortedParams = this.getSortedByPosition(this.queryParams);\n        const paramsMap = {};\n\n        for (const paramsPair of sortedParams) {\n            paramsMap[paramsPair.key] = paramsPair.value;\n        }\n\n        return paramsMap;\n    }\n\n    /**\n     * ** Returns params in Map format.\n     */\n    getParamsAsMap(): { [key: string]: string } {\n        const sortedParams = this.getSortedByPosition(this.params);\n        const paramsMap = {};\n\n        for (const paramsPair of sortedParams) {\n            paramsMap[paramsPair.key] = paramsPair.value;\n        }\n\n        return paramsMap;\n    }\n\n    /**\n     * ** Build url from base and provided params.\n     */\n    buildUrlWithParams(): string {\n        if (this.baseURL) {\n            return `${this.baseURL}${this.getParamsToString()}`;\n        }\n\n        return null;\n    }\n\n    /**\n     * ** Change Base url.\n     */\n    changeBaseUrl(baseUrl: string): void {\n        this.baseURL = baseUrl;\n    }\n\n    private getSortedByPosition(values: Map<string, StateManagerParamValue>): StateManagerParamValue[] {\n        return Array.from(values.entries())\n            .sort((p1, p2) => p1[1].position - p2[1].position)\n            .map((e) => e[1]);\n    }\n\n    private _notifyForLocationChange(): void {\n        const paramsMap = this.getParamsAsMap();\n        const paramsSerialized = this.buildUrlWithParams();\n        const queryParamsMap = this.getQueryParamsAsMap();\n        const queryParamsSerialized = this.getQueryParamsToString();\n\n        SystemEventDispatcher.post(SE_LOCATION_CHANGE, {\n            url: this.URL,\n            params: paramsMap ? paramsMap : {},\n            paramsSerialized: paramsSerialized ? paramsSerialized : '',\n            queryParams: queryParamsMap ? queryParamsMap : {},\n            queryParamsSerialized: queryParamsSerialized ? queryParamsSerialized.replace(/^\\?/, '') : ''\n        });\n    }\n}\n"]}