@versatiledatakit/shared
Version:
Versatile Data Kit Shared library enables reusability of shared features like: NgRx Redux, Error Handlers, Utils, Generic Components, etc.
68 lines • 16.8 kB
JavaScript
/*
* Copyright 2023-2025 Broadcom
* SPDX-License-Identifier: Apache-2.0
*/
import { CollectionsUtil } from '../../../utils';
export const ERROR_CODE_CONFIRMATION_FORCEFULLY_DESTROYED_COMPONENT = 'EC_CONFIRMATION_1000';
/**
* ** Confirmation Model implementation that leverage input model and model extension.
*/
export class ConfirmationModelImpl {
/**
* ** Constructor.
*/
constructor(model) {
// assign provided model to model class fields
Object.assign(this, model ?? {});
// assign UUID
this.uuid = CollectionsUtil.generateUUID();
// initialize handler ref
if (CollectionsUtil.isNil(this.handler)) {
this.handler = {
confirm: null,
dismiss: null
};
}
// check if value exist, otherwise set to default FALSE
if (CollectionsUtil.isNil(this.closable)) {
this.closable = false;
}
// check if value exist, otherwise set to default FALSE
if (CollectionsUtil.isNil(this.optionDoNotShowFutureConfirmation)) {
this.optionDoNotShowFutureConfirmation = false;
}
// confirm button model
this._assignButtonModelDefaults('confirmBtnModel', 'Confirm');
// cancel button model
if (CollectionsUtil.isObjectNotNull(this.cancelBtnModel)) {
this._assignButtonModelDefaults('cancelBtnModel', 'Cancel');
}
else {
this.cancelBtnModel = null;
}
}
_assignButtonModelDefaults(modelKey, defaultText) {
// when there is no model set default text only, and return flow to invoker
if (CollectionsUtil.isNil(this[modelKey])) {
this[modelKey] = {
text: defaultText
};
return;
}
// if model exist but there is no text, set default one, and continue further
if (!CollectionsUtil.isStringWithContent(this[modelKey].text)) {
this[modelKey].text = defaultText;
}
// if model exist check if there is no icon shape, and return flow to invoker
if (!this[modelKey].iconShape) {
this[modelKey].iconShape = null;
this[modelKey].iconPosition = null;
return;
}
// if model exist check if there is no position set or position is something unsupported and set default one to 'left'
if (!this[modelKey].iconPosition || (this[modelKey].iconPosition !== 'left' && this[modelKey].iconPosition !== 'right')) {
this[modelKey].iconPosition = 'left';
}
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirmation.model.js","sourceRoot":"","sources":["../../../../../../../projects/shared/src/lib/features/confirmation/model/confirmation.model.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,eAAe,EAAW,MAAM,gBAAgB,CAAC;AAE1D,MAAM,CAAC,MAAM,sDAAsD,GAAG,sBAAsB,CAAC;AAiI7F;;GAEG;AACH,MAAM,OAAO,qBAAqB;IA2D9B;;OAEG;IACH,YAAY,KAA6B;QACrC,8CAA8C;QAC9C,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;QAEjC,cAAc;QACd,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC,YAAY,EAAE,CAAC;QAE3C,yBAAyB;QACzB,IAAI,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YACrC,IAAI,CAAC,OAAO,GAAG;gBACX,OAAO,EAAE,IAAI;gBACb,OAAO,EAAE,IAAI;aAChB,CAAC;SACL;QAED,uDAAuD;QACvD,IAAI,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YACtC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;SACzB;QAED,uDAAuD;QACvD,IAAI,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,iCAAiC,CAAC,EAAE;YAC/D,IAAI,CAAC,iCAAiC,GAAG,KAAK,CAAC;SAClD;QAED,uBAAuB;QACvB,IAAI,CAAC,0BAA0B,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAC;QAE9D,sBAAsB;QACtB,IAAI,eAAe,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE;YACtD,IAAI,CAAC,0BAA0B,CAAC,gBAAgB,EAAE,QAAQ,CAAC,CAAC;SAC/D;aAAM;YACH,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC9B;IACL,CAAC;IAEO,0BAA0B,CAAC,QAAqC,EAAE,WAAmB;QACzF,2EAA2E;QAC3E,IAAI,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE;YACtC,IAAI,CAAC,QAAQ,CAA0B,GAAG;gBACvC,IAAI,EAAE,WAAW;aACpB,CAAC;YAEF,OAAO;SACV;QAED,6EAA6E;QAC7E,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE;YAC1D,IAAI,CAAC,QAAQ,CAA0B,CAAC,IAAI,GAAG,WAAW,CAAC;SAC/D;QAED,6EAA6E;QAC7E,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,SAAS,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAA0B,CAAC,SAAS,GAAG,IAAI,CAAC;YACzD,IAAI,CAAC,QAAQ,CAA0B,CAAC,YAAY,GAAG,IAAI,CAAC;YAE7D,OAAO;SACV;QAED,sHAAsH;QACtH,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,KAAK,MAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,KAAK,OAAO,CAAC,EAAE;YACpH,IAAI,CAAC,QAAQ,CAA0B,CAAC,YAAY,GAAG,MAAM,CAAC;SAClE;IACL,CAAC;CACJ","sourcesContent":["/*\n * Copyright 2023-2025 Broadcom\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { Type } from '@angular/core';\n\nimport { CollectionsUtil, Mutable } from '../../../utils';\n\nexport const ERROR_CODE_CONFIRMATION_FORCEFULLY_DESTROYED_COMPONENT = 'EC_CONFIRMATION_1000';\n\n/**\n * ** Confirmation Input Model.\n *\n *      - Model instance provided as input instructions for Confirmation Service, or to more specific to method {@link ConfirmationService.confirm}\n *      - Most of the fields are optional and Model Impl provides its own defaults.\n */\nexport interface ConfirmationInputModel extends SupportedButtonsModel, SupportedMessageModel {\n    /**\n     * ** Confirmation title.\n     *\n     *      - Service render provided content as innerHTML.\n     *      - HTML tags could be provided in string template.\n     */\n    title?: string;\n    /**\n     * ** Whether confirmation view to render close X button in top right corner.\n     */\n    closable?: boolean;\n    /**\n     * ** Whether confirmation view to render option for User to opt-out of showing confirmations with same context in the future.\n     */\n    optionDoNotShowFutureConfirmation?: boolean;\n}\n\n/**\n * ** Confirmation Input Model extension for the needs of {@link ConfirmationService}.\n *\n *      - private model used only in the service.\n */\nexport interface ConfirmationModelExtension {\n    /**\n     * ** Model UUID.\n     */\n    uuid: string;\n    /**\n     * ** Confirmation Handler.\n     */\n    handler: ConfirmationHandler;\n}\n\n/**\n * ** Supported Confirmation view Messages, providing one of the bellow options.\n *\n *      - it could be text provided with html tags inside\n *      - it could be Component class ref with optional messageCode\n */\nexport interface SupportedMessageModel {\n    /**\n     * ** Confirmation message.\n     *\n     *      - Service render provided content as innerHTML.\n     *      - HTML tags could be provided in string template.\n     */\n    message?: string;\n    /**\n     * ** Confirmation message component.\n     *\n     *      - Service render provided component in the same place where message text is rendered.\n     *      - Message Component takes precedence before message text. e.g. if both fields are provided, Service will render the Component.\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    messageComponent?: Type<any>;\n    /**\n     * ** Confirmation message code, that would be injected to Message component in initialization time\n     *      before first changeDetection in order to re-use same component for different messages.\n     */\n    messageCode?: string;\n}\n\n/**\n * ** Supported Confirmation View Buttons.\n */\nexport interface SupportedButtonsModel {\n    /**\n     * ** Model for Confirmation Cancel Button.\n     *\n     *      - Providing Cancel button model, means this button should be rendered.\n     */\n    cancelBtnModel?: Partial<ButtonModel>;\n    /**\n     * ** Model for Confirmation Confirm Button.\n     */\n    confirmBtnModel?: ButtonModel;\n}\n\n/**\n * ** Generic Button Model in Confirmation view.\n */\nexport interface ButtonModel {\n    /**\n     * ** Button text.\n     */\n    text: string;\n    /**\n     * ** Button icon shape.\n     */\n    iconShape?: string;\n    /**\n     * ** Button icon position.\n     */\n    iconPosition?: 'left' | 'right';\n    /**\n     * ** Button icon direction.\n     */\n    iconDirection?: 'up' | 'down' | 'left' | 'right';\n    /**\n     * ** Button icon size.\n     */\n    iconSize?: string | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'xxl';\n    /**\n     * ** Button icon solid.\n     */\n    iconSolid?: boolean;\n    /**\n     * ** Button icon inverse.\n     */\n    iconInverse?: boolean;\n    /**\n     * ** Button icon status.\n     */\n    iconStatus?: 'info' | 'success' | 'warning' | 'danger';\n    /**\n     * ** Button icon badge.\n     */\n    iconBadge?: 'info' | 'success' | 'warning' | 'danger';\n}\n\n/**\n * ** Confirmation Model implementation that leverage input model and model extension.\n */\nexport class ConfirmationModelImpl implements ConfirmationInputModel, ConfirmationModelExtension {\n    /**\n     * @inheritDoc\n     */\n    readonly uuid: string;\n    /**\n     * @inheritDoc\n     *\n     *      - By default it's empty.\n     */\n    readonly title?: string;\n    /**\n     * @inheritDoc\n     *\n     *      - By default it's empty.\n     */\n    readonly message?: string;\n    /**\n     * @inheritDoc\n     *\n     *      - By default is undefined.\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    readonly messageComponent?: Type<any>;\n    /**\n     * @inheritDoc\n     *\n     *      - By default it's empty.\n     */\n    messageCode?: string;\n    /**\n     * @inheritDoc\n     *\n     *      - By default its FALSE.\n     */\n    readonly closable?: boolean;\n    /**\n     * @inheritDoc\n     *\n     *      - By default its FALSE.\n     */\n    readonly optionDoNotShowFutureConfirmation?: boolean;\n    /**\n     * @inheritDoc\n     *\n     *      - By default its text is Cancel.\n     */\n    readonly cancelBtnModel?: Readonly<ButtonModel>;\n    /**\n     * @inheritDoc\n     *\n     *      - By default its text is Confirm.\n     */\n    readonly confirmBtnModel?: Readonly<ButtonModel>;\n    /**\n     * @inheritDoc\n     */\n    readonly handler: ConfirmationHandler;\n\n    /**\n     * ** Constructor.\n     */\n    constructor(model: ConfirmationInputModel) {\n        // assign provided model to model class fields\n        Object.assign(this, model ?? {});\n\n        // assign UUID\n        this.uuid = CollectionsUtil.generateUUID();\n\n        // initialize handler ref\n        if (CollectionsUtil.isNil(this.handler)) {\n            this.handler = {\n                confirm: null,\n                dismiss: null\n            };\n        }\n\n        // check if value exist, otherwise set to default FALSE\n        if (CollectionsUtil.isNil(this.closable)) {\n            this.closable = false;\n        }\n\n        // check if value exist, otherwise set to default FALSE\n        if (CollectionsUtil.isNil(this.optionDoNotShowFutureConfirmation)) {\n            this.optionDoNotShowFutureConfirmation = false;\n        }\n\n        // confirm button model\n        this._assignButtonModelDefaults('confirmBtnModel', 'Confirm');\n\n        // cancel button model\n        if (CollectionsUtil.isObjectNotNull(this.cancelBtnModel)) {\n            this._assignButtonModelDefaults('cancelBtnModel', 'Cancel');\n        } else {\n            this.cancelBtnModel = null;\n        }\n    }\n\n    private _assignButtonModelDefaults(modelKey: keyof SupportedButtonsModel, defaultText: string): void {\n        // when there is no model set default text only, and return flow to invoker\n        if (CollectionsUtil.isNil(this[modelKey])) {\n            (this[modelKey] as Mutable<ButtonModel>) = {\n                text: defaultText\n            };\n\n            return;\n        }\n\n        // if model exist but there is no text, set default one, and continue further\n        if (!CollectionsUtil.isStringWithContent(this[modelKey].text)) {\n            (this[modelKey] as Mutable<ButtonModel>).text = defaultText;\n        }\n\n        // if model exist check if there is no icon shape, and return flow to invoker\n        if (!this[modelKey].iconShape) {\n            (this[modelKey] as Mutable<ButtonModel>).iconShape = null;\n            (this[modelKey] as Mutable<ButtonModel>).iconPosition = null;\n\n            return;\n        }\n\n        // if model exist check if there is no position set or position is something unsupported and set default one to 'left'\n        if (!this[modelKey].iconPosition || (this[modelKey].iconPosition !== 'left' && this[modelKey].iconPosition !== 'right')) {\n            (this[modelKey] as Mutable<ButtonModel>).iconPosition = 'left';\n        }\n    }\n}\n\n/**\n * ** Confirmation Output Model.\n *\n *      - Returned to invoker after User confirmation.\n */\nexport interface ConfirmationOutputModel {\n    /**\n     * ** Field value of true, means User opt-out of showing confirmations with same context in the future.\n     */\n    doNotShowFutureConfirmation: boolean;\n}\n\n/**\n * ** Confirmation handler.\n */\nexport interface ConfirmationHandler {\n    /**\n     * ** Confirm method, which means User give confirmation.\n     */\n    confirm: (value: ConfirmationOutputModel) => void;\n    /**\n     * ** Dismiss (reject) method, which means User don't give confirmation.\n     */\n    dismiss: (reason?: string | Error) => void;\n}\n"]}