@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
JavaScript
/*
* 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"]}