@softheon/armature 17.5.0 → 17.5.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -68,7 +68,8 @@ export class SofInputStepperComponent {
68
68
  }
69
69
  this.setDefinedValidators();
70
70
  // Subscribe to form control's validation
71
- this.subscription.add(this.derivedFormControl?.valueChanges?.subscribe(() => {
71
+ this.subscription.add(this.derivedFormControl?.valueChanges?.subscribe(x => {
72
+ this.customValue = x;
72
73
  this.setDefinedValidators();
73
74
  }));
74
75
  }
@@ -182,4 +183,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
182
183
  }], valueChange: [{
183
184
  type: Output
184
185
  }] } });
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sof-input-stepper.component.js","sourceRoot":"","sources":["../../../../../../../projects/armature/src/lib/base-components/sof-input-stepper/sof-input-stepper.component.ts","../../../../../../../projects/armature/src/lib/base-components/sof-input-stepper/sof-input-stepper.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Host, Input, OnDestroy, OnInit, Optional, Output, Self } from '@angular/core';\r\nimport { AbstractControl, ControlValueAccessor, NgControl, Validators } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\n\r\n/**\r\n * Custom Input Stepper Component\r\n */\r\n@Component({\r\n    selector: 'sof-input-stepper',\r\n    templateUrl: 'sof-input-stepper.component.html',\r\n    styleUrls: ['./sof-input-stepper.component.scss']\r\n})\r\nexport class SofInputStepperComponent implements OnInit, OnDestroy, ControlValueAccessor, AfterViewInit {\r\n\r\n    /** The value */\r\n    @Input() public customValue: number;\r\n\r\n    /** The minimum value */\r\n    @Input() public min: number = null;\r\n\r\n    /** The max value */\r\n    @Input() public max: number = null;\r\n\r\n    /** The step by which the number increases/decreases */\r\n    @Input() public step: number = 1;\r\n\r\n    /** The label text */\r\n    @Input() public labelText: string = '';\r\n\r\n    /** If the input is required or not */\r\n    @Input(\"required\") public isRequired: boolean = true;\r\n\r\n    /** The error message */\r\n    @Input() public requiredErrorMessage: string = '';\r\n\r\n    /** The min max error message */\r\n    @Input() public minMaxErrorMessage: string = '';\r\n\r\n    /** The aria label */\r\n    @Input() public ariaLabel: string = '';\r\n\r\n    /** The value change event emitter */\r\n    @Output() public valueChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n    /** If the input is disabled or not */\r\n    public isDisabled: boolean = false;\r\n\r\n    /** The control name */\r\n    public controlName: string | number = \"\";\r\n\r\n    /** The derived form control */\r\n    public get derivedFormControl(): AbstractControl {\r\n        return this.control?.control;\r\n    }\r\n\r\n    /** The OnChange form control method */\r\n    private onChange = (toggleVal: any): void => { };\r\n\r\n    /** The OnTouched form control method */\r\n    private onTouched = (): void => { };\r\n\r\n    /** The component subscription */\r\n    private subscription: Subscription = new Subscription();\r\n\r\n    /**\r\n     * Constructor.\r\n     * @param control The ng control\r\n     */\r\n    constructor(@Self() @Optional() @Host() private control: NgControl) {\r\n        if (this.control) {\r\n            this.control.valueAccessor = this;\r\n            setTimeout(() => {\r\n                this.controlName = this.control.name;\r\n            });\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Component Initialization\r\n     */\r\n    public ngOnInit(): void {\r\n        if (!this.ariaLabel) {\r\n            this.ariaLabel = this.labelText;\r\n        }\r\n\r\n        this.setDefinedValidators();\r\n\r\n        // Subscribe to form control's validation\r\n        this.subscription.add(this.derivedFormControl?.valueChanges?.subscribe(() => {\r\n            this.setDefinedValidators();\r\n        }));\r\n    }\r\n\r\n    /** After View Initialization */\r\n    public ngAfterViewInit(): void {\r\n        if (this.customValue != undefined && this.customValue != null) {\r\n            this.derivedFormControl?.markAsTouched();\r\n            this.derivedFormControl?.updateValueAndValidity();\r\n        }\r\n    }\r\n\r\n    /** Triggered when control is changed\r\n     * @param fn The callback function.\r\n     */\r\n    public registerOnChange(fn: any): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    /** Triggered when control is touched\r\n     * @param fn The callback function.\r\n     */\r\n    public registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n    \r\n    /** Sets the disabled state\r\n     * @param isDisabled If the control is disabled or not\r\n     */\r\n    public setDisabledState(isDisabled: boolean): void {\r\n        this.isDisabled = isDisabled;\r\n    }\r\n    \r\n    /** Component Destruction */\r\n    public ngOnDestroy(): void {\r\n        this.subscription.unsubscribe();\r\n    }\r\n\r\n    /** Triggered when the form control value is set outside the component\r\n     * @param newVal The new value.\r\n     */\r\n    public writeValue(newVal: any): void {\r\n        this.customValue = newVal;\r\n    }\r\n\r\n    /** Increase the value by step */\r\n    public increaseVal(): void {\r\n        let newVal = this.customValue;\r\n        if (!newVal) {\r\n            newVal = 0;\r\n        }\r\n        newVal += this.step;\r\n        if (this.max != null && newVal > this.max) {\r\n            newVal = this.max;\r\n        }\r\n        this.customValue = newVal;\r\n        this.derivedFormControl.setValue(this.customValue);\r\n        this.derivedFormControl.markAsTouched();\r\n    }\r\n\r\n    /** Decrease the value by step */\r\n    public decreaseVal(): void {\r\n        let newVal = this.customValue;\r\n        if (!newVal) {\r\n            newVal = 0;\r\n        }\r\n        newVal -= this.step;\r\n        if (this.min != null && newVal < this.min) {\r\n            newVal = this.min;\r\n        }\r\n        this.customValue = newVal;\r\n        this.derivedFormControl.setValue(this.customValue);\r\n        this.derivedFormControl.markAsTouched();\r\n    }\r\n\r\n    /** Updates the isRequired field based on the control */\r\n    private setDefinedValidators(): void {\r\n        // Only update if a control is available\r\n        if (this.derivedFormControl) {\r\n            const controlValidator = this.control.control.validator;\r\n            //  Set the required state false when no control validator function is provided\r\n            if (!controlValidator) {\r\n                this.isRequired = false;\r\n                return;\r\n            }\r\n            this.isRequired = this.derivedFormControl?.hasValidator(Validators.required);\r\n        }\r\n    }\r\n}","<div *ngIf=\"derivedFormControl\" fxLayoutAlign=\"row\" class=\"input-stepper-container\">\r\n    <mat-form-field appearance=\"outline\" class=\"full-width sof-form-field\">\r\n        <mat-label>{{ labelText | translate}}</mat-label>\r\n        <input [formControl]=\"derivedFormControl\" matInput type=\"number\" [name]=\"controlName\" id=\"stepper-{{controlName}}\"\r\n            attr.aria-label=\"{{ariaLabel | translate}}\" [required]=\"isRequired\" [value]=\"customValue\" [step]=\"step\"\r\n            placeholder=\"{{ labelText | translate}}\" [disabled]=\"isDisabled\">\r\n        <mat-error *ngIf=\"derivedFormControl?.errors?.required\">{{ requiredErrorMessage | translate}}</mat-error>\r\n        <mat-error *ngIf=\"derivedFormControl?.errors?.min || derivedFormControl?.errors?.max\">{{ minMaxErrorMessage | translate}}</mat-error>\r\n        <span matSuffix class=\"error\" *ngIf=\"derivedFormControl?.touched && derivedFormControl?.invalid\">\r\n            <i class=\"fa-light fa-circle-exclamation\"></i>\r\n        </span>\r\n    </mat-form-field>\r\n    <button mat-flat-button [ngClass]=\"{'invalid': derivedFormControl?.touched && derivedFormControl?.invalid}\" [disabled]=\"isDisabled\"\r\n        class=\"sof-flat-icon-button\" size=\"large\" id=\"decrease-step-{{controlName}}\" (click)=\"decreaseVal()\">\r\n        <i class=\"fa-regular fa-minus\"></i>\r\n    </button>\r\n    <button mat-flat-button [ngClass]=\"{'invalid': derivedFormControl?.touched && derivedFormControl?.invalid}\" [disabled]=\"isDisabled\"\r\n        class=\"sof-flat-icon-button\" size=\"large\" id=\"increase-step-{{controlName}}\" (click)=\"increaseVal()\">\r\n        <i class=\"fa-regular fa-plus\"></i>\r\n    </button>\r\n</div>"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sof-input-stepper.component.js","sourceRoot":"","sources":["../../../../../../../projects/armature/src/lib/base-components/sof-input-stepper/sof-input-stepper.component.ts","../../../../../../../projects/armature/src/lib/base-components/sof-input-stepper/sof-input-stepper.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,YAAY,EAAE,IAAI,EAAE,KAAK,EAAqB,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAC/H,OAAO,EAAoD,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC9F,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;AAEpC;;GAEG;AAMH,MAAM,OAAO,wBAAwB;IAsCjC,+BAA+B;IAC/B,IAAW,kBAAkB;QACzB,OAAO,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC;IACjC,CAAC;IAWD;;;OAGG;IACH,YAAgD,OAAkB;QAAlB,YAAO,GAAP,OAAO,CAAW;QAnDlE,wBAAwB;QACR,QAAG,GAAW,IAAI,CAAC;QAEnC,oBAAoB;QACJ,QAAG,GAAW,IAAI,CAAC;QAEnC,uDAAuD;QACvC,SAAI,GAAW,CAAC,CAAC;QAEjC,qBAAqB;QACL,cAAS,GAAW,EAAE,CAAC;QAEvC,sCAAsC;QACZ,eAAU,GAAY,IAAI,CAAC;QAErD,wBAAwB;QACR,yBAAoB,GAAW,EAAE,CAAC;QAElD,gCAAgC;QAChB,uBAAkB,GAAW,EAAE,CAAC;QAEhD,qBAAqB;QACL,cAAS,GAAW,EAAE,CAAC;QAEvC,qCAAqC;QACpB,gBAAW,GAAyB,IAAI,YAAY,EAAU,CAAC;QAEhF,sCAAsC;QAC/B,eAAU,GAAY,KAAK,CAAC;QAEnC,uBAAuB;QAChB,gBAAW,GAAoB,EAAE,CAAC;QAOzC,uCAAuC;QAC/B,aAAQ,GAAG,CAAC,SAAc,EAAQ,EAAE,GAAG,CAAC,CAAC;QAEjD,wCAAwC;QAChC,cAAS,GAAG,GAAS,EAAE,GAAG,CAAC,CAAC;QAEpC,iCAAiC;QACzB,iBAAY,GAAiB,IAAI,YAAY,EAAE,CAAC;QAOpD,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;YAClC,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YACzC,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;SACnC;QAED,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,yCAAyC;QACzC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,kBAAkB,EAAE,YAAY,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE;YACvE,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;YACrB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAChC,CAAC,CAAC,CAAC,CAAC;IACR,CAAC;IAED,gCAAgC;IACzB,eAAe;QAClB,IAAI,IAAI,CAAC,WAAW,IAAI,SAAS,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,EAAE;YAC3D,IAAI,CAAC,kBAAkB,EAAE,aAAa,EAAE,CAAC;YACzC,IAAI,CAAC,kBAAkB,EAAE,sBAAsB,EAAE,CAAC;SACrD;IACL,CAAC;IAED;;OAEG;IACI,gBAAgB,CAAC,EAAO;QAC3B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAED;;OAEG;IACI,iBAAiB,CAAC,EAAO;QAC5B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAED;;OAEG;IACI,gBAAgB,CAAC,UAAmB;QACvC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IACjC,CAAC;IAED,4BAA4B;IACrB,WAAW;QACd,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,MAAW;QACzB,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;IAC9B,CAAC;IAED,iCAAiC;IAC1B,WAAW;QACd,IAAI,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC;QAC9B,IAAI,CAAC,MAAM,EAAE;YACT,MAAM,GAAG,CAAC,CAAC;SACd;QACD,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC;QACpB,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,IAAI,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE;YACvC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC;SACrB;QACD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;QAC1B,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACnD,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;IAC5C,CAAC;IAED,iCAAiC;IAC1B,WAAW;QACd,IAAI,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC;QAC9B,IAAI,CAAC,MAAM,EAAE;YACT,MAAM,GAAG,CAAC,CAAC;SACd;QACD,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC;QACpB,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,IAAI,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE;YACvC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC;SACrB;QACD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;QAC1B,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACnD,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;IAC5C,CAAC;IAED,wDAAwD;IAChD,oBAAoB;QACxB,wCAAwC;QACxC,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC;YACxD,+EAA+E;YAC/E,IAAI,CAAC,gBAAgB,EAAE;gBACnB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACxB,OAAO;aACV;YACD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,kBAAkB,EAAE,YAAY,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAChF;IACL,CAAC;8GArKQ,wBAAwB;kGAAxB,wBAAwB,gWCZrC,0sDAoBM;;2FDRO,wBAAwB;kBALpC,SAAS;+BACI,mBAAmB;;0BA4DhB,IAAI;;0BAAI,QAAQ;;0BAAI,IAAI;yCArDrB,WAAW;sBAA1B,KAAK;gBAGU,GAAG;sBAAlB,KAAK;gBAGU,GAAG;sBAAlB,KAAK;gBAGU,IAAI;sBAAnB,KAAK;gBAGU,SAAS;sBAAxB,KAAK;gBAGoB,UAAU;sBAAnC,KAAK;uBAAC,UAAU;gBAGD,oBAAoB;sBAAnC,KAAK;gBAGU,kBAAkB;sBAAjC,KAAK;gBAGU,SAAS;sBAAxB,KAAK;gBAGW,WAAW;sBAA3B,MAAM","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Host, Input, OnDestroy, OnInit, Optional, Output, Self } from '@angular/core';\r\nimport { AbstractControl, ControlValueAccessor, NgControl, Validators } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\n\r\n/**\r\n * Custom Input Stepper Component\r\n */\r\n@Component({\r\n    selector: 'sof-input-stepper',\r\n    templateUrl: 'sof-input-stepper.component.html',\r\n    styleUrls: ['./sof-input-stepper.component.scss']\r\n})\r\nexport class SofInputStepperComponent implements OnInit, OnDestroy, ControlValueAccessor, AfterViewInit {\r\n\r\n    /** The value */\r\n    @Input() public customValue: number;\r\n\r\n    /** The minimum value */\r\n    @Input() public min: number = null;\r\n\r\n    /** The max value */\r\n    @Input() public max: number = null;\r\n\r\n    /** The step by which the number increases/decreases */\r\n    @Input() public step: number = 1;\r\n\r\n    /** The label text */\r\n    @Input() public labelText: string = '';\r\n\r\n    /** If the input is required or not */\r\n    @Input(\"required\") public isRequired: boolean = true;\r\n\r\n    /** The error message */\r\n    @Input() public requiredErrorMessage: string = '';\r\n\r\n    /** The min max error message */\r\n    @Input() public minMaxErrorMessage: string = '';\r\n\r\n    /** The aria label */\r\n    @Input() public ariaLabel: string = '';\r\n\r\n    /** The value change event emitter */\r\n    @Output() public valueChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n    /** If the input is disabled or not */\r\n    public isDisabled: boolean = false;\r\n\r\n    /** The control name */\r\n    public controlName: string | number = \"\";\r\n\r\n    /** The derived form control */\r\n    public get derivedFormControl(): AbstractControl {\r\n        return this.control?.control;\r\n    }\r\n\r\n    /** The OnChange form control method */\r\n    private onChange = (toggleVal: any): void => { };\r\n\r\n    /** The OnTouched form control method */\r\n    private onTouched = (): void => { };\r\n\r\n    /** The component subscription */\r\n    private subscription: Subscription = new Subscription();\r\n\r\n    /**\r\n     * Constructor.\r\n     * @param control The ng control\r\n     */\r\n    constructor(@Self() @Optional() @Host() private control: NgControl) {\r\n        if (this.control) {\r\n            this.control.valueAccessor = this;\r\n            setTimeout(() => {\r\n                this.controlName = this.control.name;\r\n            });\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Component Initialization\r\n     */\r\n    public ngOnInit(): void {\r\n        if (!this.ariaLabel) {\r\n            this.ariaLabel = this.labelText;\r\n        }\r\n\r\n        this.setDefinedValidators();\r\n\r\n        // Subscribe to form control's validation\r\n        this.subscription.add(this.derivedFormControl?.valueChanges?.subscribe(x => {\r\n            this.customValue = x;\r\n            this.setDefinedValidators();\r\n        }));\r\n    }\r\n\r\n    /** After View Initialization */\r\n    public ngAfterViewInit(): void {\r\n        if (this.customValue != undefined && this.customValue != null) {\r\n            this.derivedFormControl?.markAsTouched();\r\n            this.derivedFormControl?.updateValueAndValidity();\r\n        }\r\n    }\r\n\r\n    /** Triggered when control is changed\r\n     * @param fn The callback function.\r\n     */\r\n    public registerOnChange(fn: any): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    /** Triggered when control is touched\r\n     * @param fn The callback function.\r\n     */\r\n    public registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n    \r\n    /** Sets the disabled state\r\n     * @param isDisabled If the control is disabled or not\r\n     */\r\n    public setDisabledState(isDisabled: boolean): void {\r\n        this.isDisabled = isDisabled;\r\n    }\r\n    \r\n    /** Component Destruction */\r\n    public ngOnDestroy(): void {\r\n        this.subscription.unsubscribe();\r\n    }\r\n\r\n    /** Triggered when the form control value is set outside the component\r\n     * @param newVal The new value.\r\n     */\r\n    public writeValue(newVal: any): void {\r\n        this.customValue = newVal;\r\n    }\r\n\r\n    /** Increase the value by step */\r\n    public increaseVal(): void {\r\n        let newVal = this.customValue;\r\n        if (!newVal) {\r\n            newVal = 0;\r\n        }\r\n        newVal += this.step;\r\n        if (this.max != null && newVal > this.max) {\r\n            newVal = this.max;\r\n        }\r\n        this.customValue = newVal;\r\n        this.derivedFormControl.setValue(this.customValue);\r\n        this.derivedFormControl.markAsTouched();\r\n    }\r\n\r\n    /** Decrease the value by step */\r\n    public decreaseVal(): void {\r\n        let newVal = this.customValue;\r\n        if (!newVal) {\r\n            newVal = 0;\r\n        }\r\n        newVal -= this.step;\r\n        if (this.min != null && newVal < this.min) {\r\n            newVal = this.min;\r\n        }\r\n        this.customValue = newVal;\r\n        this.derivedFormControl.setValue(this.customValue);\r\n        this.derivedFormControl.markAsTouched();\r\n    }\r\n\r\n    /** Updates the isRequired field based on the control */\r\n    private setDefinedValidators(): void {\r\n        // Only update if a control is available\r\n        if (this.derivedFormControl) {\r\n            const controlValidator = this.control.control.validator;\r\n            //  Set the required state false when no control validator function is provided\r\n            if (!controlValidator) {\r\n                this.isRequired = false;\r\n                return;\r\n            }\r\n            this.isRequired = this.derivedFormControl?.hasValidator(Validators.required);\r\n        }\r\n    }\r\n}","<div *ngIf=\"derivedFormControl\" fxLayoutAlign=\"row\" class=\"input-stepper-container\">\r\n    <mat-form-field appearance=\"outline\" class=\"full-width sof-form-field\">\r\n        <mat-label>{{ labelText | translate}}</mat-label>\r\n        <input [formControl]=\"derivedFormControl\" matInput type=\"number\" [name]=\"controlName\" id=\"stepper-{{controlName}}\"\r\n            attr.aria-label=\"{{ariaLabel | translate}}\" [required]=\"isRequired\" [value]=\"customValue\" [step]=\"step\"\r\n            placeholder=\"{{ labelText | translate}}\" [disabled]=\"isDisabled\">\r\n        <mat-error *ngIf=\"derivedFormControl?.errors?.required\">{{ requiredErrorMessage | translate}}</mat-error>\r\n        <mat-error *ngIf=\"derivedFormControl?.errors?.min || derivedFormControl?.errors?.max\">{{ minMaxErrorMessage | translate}}</mat-error>\r\n        <span matSuffix class=\"error\" *ngIf=\"derivedFormControl?.touched && derivedFormControl?.invalid\">\r\n            <i class=\"fa-light fa-circle-exclamation\"></i>\r\n        </span>\r\n    </mat-form-field>\r\n    <button mat-flat-button [ngClass]=\"{'invalid': derivedFormControl?.touched && derivedFormControl?.invalid}\" [disabled]=\"isDisabled\"\r\n        class=\"sof-flat-icon-button\" size=\"large\" id=\"decrease-step-{{controlName}}\" (click)=\"decreaseVal()\">\r\n        <i class=\"fa-regular fa-minus\"></i>\r\n    </button>\r\n    <button mat-flat-button [ngClass]=\"{'invalid': derivedFormControl?.touched && derivedFormControl?.invalid}\" [disabled]=\"isDisabled\"\r\n        class=\"sof-flat-icon-button\" size=\"large\" id=\"increase-step-{{controlName}}\" (click)=\"increaseVal()\">\r\n        <i class=\"fa-regular fa-plus\"></i>\r\n    </button>\r\n</div>"]}
@@ -5211,7 +5211,8 @@ class SofInputStepperComponent {
5211
5211
  }
5212
5212
  this.setDefinedValidators();
5213
5213
  // Subscribe to form control's validation
5214
- this.subscription.add(this.derivedFormControl?.valueChanges?.subscribe(() => {
5214
+ this.subscription.add(this.derivedFormControl?.valueChanges?.subscribe(x => {
5215
+ this.customValue = x;
5215
5216
  this.setDefinedValidators();
5216
5217
  }));
5217
5218
  }