@versatiledatakit/shared
Version:
Versatile Data Kit Shared library enables reusability of shared features like: NgRx Redux, Error Handlers, Utils, Generic Components, etc.
94 lines • 16.5 kB
JavaScript
/*
* Copyright 2023-2025 Broadcom
* SPDX-License-Identifier: Apache-2.0
*/
/* eslint-disable arrow-body-style,prefer-arrow/prefer-arrow-functions */
import { ROUTER_NAVIGATION } from '@ngrx/router-store';
import { CollectionsUtil } from '../../../../utils';
import { RouteSegments } from '../../../router';
import { ComponentsStateHelper, FAILED, IDLE, INITIALIZED, LOADED, LOADING } from '../../model';
import { COMPONENT_CLEAR_DATA, COMPONENT_FAILED, COMPONENT_IDLE, COMPONENT_INIT, COMPONENT_LOADED, COMPONENT_LOADING, COMPONENT_UPDATE, ComponentIdle, ComponentLoaded } from '../actions';
const stateHelper = new ComponentsStateHelper();
/**
* ** Reducer for Components Actions.
*/
export function componentReducer(state = stateHelper.getState(), action = { type: null, payload: null }) {
let actionComponentState;
let actionLiteralComponentState;
let storeLiteralComponentState;
stateHelper.setState(state);
switch (action.type) {
case COMPONENT_INIT:
actionComponentState = action.payload;
stateHelper.updateLiteralComponentState({
...actionComponentState.toLiteralCloneDeep(),
status: INITIALIZED
});
return stateHelper.getState();
case COMPONENT_IDLE:
case COMPONENT_LOADING:
actionComponentState = action.payload;
storeLiteralComponentState = stateHelper.getLiteralComponentState(actionComponentState.id, actionComponentState.routePathSegments);
actionLiteralComponentState = actionComponentState.toLiteralCloneDeep();
stateHelper.updateLiteralComponentState({
...storeLiteralComponentState,
...actionLiteralComponentState,
status: action instanceof ComponentIdle ? IDLE : LOADING
});
return stateHelper.getState();
case COMPONENT_UPDATE:
case COMPONENT_LOADED:
actionComponentState = action.payload;
storeLiteralComponentState = stateHelper.getLiteralComponentState(actionComponentState.id, actionComponentState.routePathSegments);
actionLiteralComponentState = actionComponentState.toLiteralCloneDeep();
stateHelper.updateLiteralComponentState({
...storeLiteralComponentState,
...actionLiteralComponentState,
status: action instanceof ComponentLoaded ? LOADED : actionComponentState.status,
data: getComponentStateData(actionLiteralComponentState, storeLiteralComponentState)
});
return stateHelper.getState();
case COMPONENT_FAILED:
actionComponentState = action.payload;
storeLiteralComponentState = stateHelper.getLiteralComponentState(actionComponentState.id, actionComponentState.routePathSegments);
actionLiteralComponentState = actionComponentState.toLiteralCloneDeep();
stateHelper.updateLiteralComponentState({
...storeLiteralComponentState,
...actionLiteralComponentState,
data: getComponentStateData(actionLiteralComponentState, storeLiteralComponentState),
status: FAILED
});
return stateHelper.getState();
case COMPONENT_CLEAR_DATA:
actionComponentState = action.payload;
storeLiteralComponentState = stateHelper.getLiteralComponentState(actionComponentState.id, actionComponentState.routePathSegments);
stateHelper.updateLiteralComponentState({
...storeLiteralComponentState,
...actionComponentState.toLiteralCloneDeep(),
data: {},
status: LOADING
});
return stateHelper.getState();
case ROUTER_NAVIGATION:
const routeSegments = action.payload.routerState.routeSegments;
if (!(routeSegments instanceof RouteSegments)) {
return state;
}
stateHelper.resetComponentStates(routeSegments.routePathSegments);
return stateHelper.getState();
default:
return state;
}
}
const getComponentStateData = (actionComponentState,
// eslint-disable-next-line @typescript-eslint/no-explicit-any
storeLiteralComponentState) => {
if (CollectionsUtil.isLiteralObjectWithProperties(actionComponentState.data)) {
return actionComponentState.data;
}
if (CollectionsUtil.isDefined(storeLiteralComponentState)) {
return storeLiteralComponentState.data;
}
return {};
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.reducer.js","sourceRoot":"","sources":["../../../../../../../../projects/shared/src/lib/core/component/state/reducers/component.reducer.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 arrow-body-style,prefer-arrow/prefer-arrow-functions */\n\nimport { ROUTER_NAVIGATION, RouterNavigationAction } from '@ngrx/router-store';\n\nimport { CollectionsUtil } from '../../../../utils';\n\nimport { NavigationActions, RouteSegments, RouteState } from '../../../router';\n\nimport { ComponentsStateHelper, ComponentState, FAILED, IDLE, INITIALIZED, LiteralComponentState, LOADED, LOADING } from '../../model';\n\nimport {\n    COMPONENT_CLEAR_DATA,\n    COMPONENT_FAILED,\n    COMPONENT_IDLE,\n    COMPONENT_INIT,\n    COMPONENT_LOADED,\n    COMPONENT_LOADING,\n    COMPONENT_UPDATE,\n    ComponentActions,\n    ComponentClearData,\n    ComponentIdle,\n    ComponentInit,\n    ComponentLoaded,\n    ComponentLoading,\n    ComponentUpdate\n} from '../actions';\n\nconst stateHelper = new ComponentsStateHelper();\n\n/**\n * ** Reducer for Components Actions.\n */\nexport function componentReducer(\n    state = stateHelper.getState(),\n    action: ComponentActions | NavigationActions = { type: null, payload: null }\n) {\n    let actionComponentState: ComponentState;\n    let actionLiteralComponentState: LiteralComponentState;\n    let storeLiteralComponentState: LiteralComponentState;\n\n    stateHelper.setState(state);\n\n    switch (action.type) {\n        case COMPONENT_INIT:\n            actionComponentState = (action as ComponentInit).payload;\n\n            stateHelper.updateLiteralComponentState({\n                ...actionComponentState.toLiteralCloneDeep(),\n                status: INITIALIZED\n            });\n\n            return stateHelper.getState();\n        case COMPONENT_IDLE:\n        case COMPONENT_LOADING:\n            actionComponentState = (action as ComponentIdle | ComponentLoading).payload;\n            storeLiteralComponentState = stateHelper.getLiteralComponentState(\n                actionComponentState.id,\n                actionComponentState.routePathSegments\n            );\n\n            actionLiteralComponentState = actionComponentState.toLiteralCloneDeep();\n\n            stateHelper.updateLiteralComponentState({\n                ...storeLiteralComponentState,\n                ...actionLiteralComponentState,\n                status: action instanceof ComponentIdle ? IDLE : LOADING\n            });\n\n            return stateHelper.getState();\n        case COMPONENT_UPDATE:\n        case COMPONENT_LOADED:\n            actionComponentState = (action as ComponentLoaded | ComponentUpdate).payload;\n            storeLiteralComponentState = stateHelper.getLiteralComponentState(\n                actionComponentState.id,\n                actionComponentState.routePathSegments\n            );\n\n            actionLiteralComponentState = actionComponentState.toLiteralCloneDeep();\n\n            stateHelper.updateLiteralComponentState({\n                ...storeLiteralComponentState,\n                ...actionLiteralComponentState,\n                status: action instanceof ComponentLoaded ? LOADED : actionComponentState.status,\n                data: getComponentStateData(actionLiteralComponentState, storeLiteralComponentState)\n            });\n\n            return stateHelper.getState();\n        case COMPONENT_FAILED:\n            actionComponentState = (action as ComponentLoaded | ComponentUpdate).payload;\n            storeLiteralComponentState = stateHelper.getLiteralComponentState(\n                actionComponentState.id,\n                actionComponentState.routePathSegments\n            );\n\n            actionLiteralComponentState = actionComponentState.toLiteralCloneDeep();\n\n            stateHelper.updateLiteralComponentState({\n                ...storeLiteralComponentState,\n                ...actionLiteralComponentState,\n                data: getComponentStateData(actionLiteralComponentState, storeLiteralComponentState),\n                status: FAILED\n            });\n\n            return stateHelper.getState();\n        case COMPONENT_CLEAR_DATA:\n            actionComponentState = (action as ComponentClearData).payload;\n            storeLiteralComponentState = stateHelper.getLiteralComponentState(\n                actionComponentState.id,\n                actionComponentState.routePathSegments\n            );\n\n            stateHelper.updateLiteralComponentState({\n                ...storeLiteralComponentState,\n                ...actionComponentState.toLiteralCloneDeep(),\n                data: {},\n                status: LOADING\n            });\n\n            return stateHelper.getState();\n        case ROUTER_NAVIGATION:\n            const routeSegments = (action as RouterNavigationAction<RouteState>).payload.routerState.routeSegments;\n\n            if (!(routeSegments instanceof RouteSegments)) {\n                return state;\n            }\n\n            stateHelper.resetComponentStates(routeSegments.routePathSegments);\n\n            return stateHelper.getState();\n        default:\n            return state;\n    }\n}\n\nconst getComponentStateData = (\n    actionComponentState: LiteralComponentState,\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    storeLiteralComponentState: LiteralComponentState\n): { [key: string]: any } => {\n    if (CollectionsUtil.isLiteralObjectWithProperties(actionComponentState.data)) {\n        return actionComponentState.data;\n    }\n\n    if (CollectionsUtil.isDefined(storeLiteralComponentState)) {\n        return storeLiteralComponentState.data;\n    }\n\n    return {};\n};\n"]}