UNPKG

@versatiledatakit/shared

Version:

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

215 lines • 17.8 kB
/* * Copyright 2023-2025 Broadcom * SPDX-License-Identifier: Apache-2.0 */ /* eslint-disable @typescript-eslint/no-explicit-any */ import { extractTaskFromIdentifier, RequestFilterImpl, RequestPageImpl } from '../../../common'; import { ComponentStateImpl, FAILED, IDLE, LOADED, LOADING } from './state'; import { ComponentModelComparable } from './component-model.comparable'; import { AbstractComponentModel } from './component.model.interface'; /** * ** Generic Model for all Components. */ export class ComponentModel extends AbstractComponentModel { /** * ** Constructor. */ constructor(_componentState, _routerState) { super(); this._componentState = _componentState; this._routerState = _routerState; } /** * ** Factory method. */ static of(componentState, routerState) { return new ComponentModel(componentState, routerState); } /** * @inheritDoc */ get routerState() { return this._routerState; } /** * @inheritDoc */ get status() { return this.getComponentState().status; } /** * @inheritDoc */ get routePath() { return this.getComponentState().routePath || this.routerState.state.routeSegments.routePath; } /** * @inheritDoc */ getComponentState() { return this._componentState; } /** * @inheritDoc */ withSearch(search) { this.updateComponentState({ search }); return this; } /** * @inheritDoc */ withPage(page, size) { this.updateComponentState({ page: RequestPageImpl.of(page, size) }); return this; } /** * @inheritDoc */ withFilter(filterPredicates) { this.updateComponentState({ filter: RequestFilterImpl.of(...filterPredicates) }); return this; } /** * @inheritDoc */ withRequestParam(key, value) { this.getComponentState().requestParams.set(key, value); return this; } /** * @inheritDoc */ withData(key, data) { this.getComponentState().data.set(key, data); return this; } /** * @inheritDoc */ withTask(taskIdentifier) { this.updateComponentState({ task: taskIdentifier }); return this; } /** * @inheritDoc */ clearTask() { this.updateComponentState({ task: null }); return this; } /** * @inheritDoc */ getTask() { return extractTaskFromIdentifier(this.getComponentState().task); } /** * @inheritDoc */ getTaskUniqueIdentifier() { return this.getComponentState().task; } /** * @inheritDoc */ withError(errorRecord) { this.getComponentState().errors.record(errorRecord); return this; } /** * @inheritDoc */ clearErrors() { this.getComponentState().errors.clear(); return this; } /** * @inheritDoc */ removeErrorCode(...errorCodes) { this.getComponentState().errors.removeCode(...errorCodes); return this; } /** * @inheritDoc */ removeErrorCodePatterns(...errorCodePatterns) { this.getComponentState().errors.removeCodePattern(...errorCodePatterns); return this; } /** * @inheritDoc */ withUiState(key, value) { this.getComponentState().uiState.set(key, value); return this; } /** * @inheritDoc */ getUiState(key) { return this.getComponentState().uiState.get(key); } /** * @inheritDoc */ withStatusIdle() { this.updateComponentState({ status: IDLE }); return this; } /** * @inheritDoc */ withStatusLoading() { this.updateComponentState({ status: LOADING }); return this; } /** * @inheritDoc */ withStatusLoaded() { this.updateComponentState({ status: LOADED }); return this; } /** * @inheritDoc */ withStatusFailed() { this.updateComponentState({ status: FAILED }); return this; } /** * @inheritDoc */ updateComponentState(patchState) { this._componentState = ComponentStateImpl.of({ ...this.getComponentState(), ...patchState }); return this; } /** * @inheritDoc */ prepareForDestroy() { this.withStatusIdle(); this.updateComponentState({ errors: null }); return this; } /** * @inheritDoc */ isModified(model) { return ComponentModelComparable.of(this).notEqual(ComponentModelComparable.of(model)); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.model.js","sourceRoot":"","sources":["../../../../../../../projects/shared/src/lib/core/component/model/component.model.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/no-explicit-any */\n\nimport { ApiPredicate, ErrorRecord, extractTaskFromIdentifier, RequestFilterImpl, RequestPageImpl } from '../../../common';\n\nimport { RouterState } from '../../router';\n\nimport { ComponentState, ComponentStateImpl, FAILED, IDLE, LOADED, LOADING, StatusType } from './state';\n\nimport { ComponentModelComparable } from './component-model.comparable';\n\nimport { AbstractComponentModel } from './component.model.interface';\n\n/**\n * ** Generic Model for all Components.\n */\nexport class ComponentModel extends AbstractComponentModel {\n    /**\n     * ** Constructor.\n     */\n    constructor(\n        protected _componentState: ComponentState,\n        protected _routerState: RouterState\n    ) {\n        super();\n    }\n\n    /**\n     * ** Factory method.\n     */\n    static of(componentState: ComponentState, routerState: RouterState) {\n        return new ComponentModel(componentState, routerState);\n    }\n\n    /**\n     * @inheritDoc\n     */\n    get routerState(): RouterState {\n        return this._routerState;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    get status(): StatusType {\n        return this.getComponentState().status;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    get routePath(): string {\n        return this.getComponentState().routePath || this.routerState.state.routeSegments.routePath;\n    }\n\n    /**\n     * ** Reference to previous model for comparison only.\n     */\n    readonly previousModel: Readonly<ComponentModel>;\n\n    /**\n     * @inheritDoc\n     */\n    getComponentState(): ComponentState {\n        return this._componentState;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withSearch(search: string) {\n        this.updateComponentState({\n            search\n        });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withPage(page: number, size: number) {\n        this.updateComponentState({\n            page: RequestPageImpl.of(page, size)\n        });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withFilter(filterPredicates: ApiPredicate[]) {\n        this.updateComponentState({\n            filter: RequestFilterImpl.of(...filterPredicates)\n        });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withRequestParam(key: string, value: any) {\n        this.getComponentState().requestParams.set(key, value);\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withData(key: string, data: any) {\n        this.getComponentState().data.set(key, data);\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withTask(taskIdentifier: string) {\n        this.updateComponentState({ task: taskIdentifier });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    clearTask() {\n        this.updateComponentState({ task: null });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    getTask(): string {\n        return extractTaskFromIdentifier(this.getComponentState().task);\n    }\n\n    /**\n     * @inheritDoc\n     */\n    getTaskUniqueIdentifier(): string {\n        return this.getComponentState().task;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withError(errorRecord: ErrorRecord) {\n        this.getComponentState().errors.record(errorRecord);\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    clearErrors() {\n        this.getComponentState().errors.clear();\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    removeErrorCode(...errorCodes: string[]): this {\n        this.getComponentState().errors.removeCode(...errorCodes);\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    removeErrorCodePatterns(...errorCodePatterns: string[]): this {\n        this.getComponentState().errors.removeCodePattern(...errorCodePatterns);\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withUiState(key: string, value: any) {\n        this.getComponentState().uiState.set(key, value);\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    getUiState<T>(key: string): T {\n        return this.getComponentState().uiState.get(key) as T;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withStatusIdle() {\n        this.updateComponentState({ status: IDLE });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withStatusLoading() {\n        this.updateComponentState({ status: LOADING });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withStatusLoaded() {\n        this.updateComponentState({ status: LOADED });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    withStatusFailed() {\n        this.updateComponentState({ status: FAILED });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    updateComponentState(patchState: Partial<ComponentState>) {\n        this._componentState = ComponentStateImpl.of({\n            ...this.getComponentState(),\n            ...patchState\n        });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    prepareForDestroy() {\n        this.withStatusIdle();\n\n        this.updateComponentState({\n            errors: null\n        });\n\n        return this;\n    }\n\n    /**\n     * @inheritDoc\n     */\n    isModified(model: ComponentModel): boolean {\n        return ComponentModelComparable.of(this).notEqual(ComponentModelComparable.of(model));\n    }\n}\n"]}