@esfaenza/forms-and-validations 11.2.148 → 11.2.149-beta1

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.
@@ -23,11 +23,11 @@ export class ValidationSelectComponent extends BaseValidation {
23
23
  /**
24
24
  * valore del campo vuoto della select
25
25
  */
26
- this.emptyFieldValue = "-2";
26
+ this.emptyFieldValue = "-2000";
27
27
  /**
28
28
  * Valore del placeholder
29
29
  */
30
- this.placeHolderValue = "-1";
30
+ this.placeHolderValue = "-1000";
31
31
  /**
32
32
  * Per i componenti non obbligatori indica se fornire un "valore vuoto"
33
33
  */
@@ -167,4 +167,4 @@ ValidationSelectComponent.propDecorators = {
167
167
  label: [{ type: Input }],
168
168
  onBlur: [{ type: Output }]
169
169
  };
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-select.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-select/validation-select.component.ts"],"names":[],"mappings":"AAAA,UAAU;AACV,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAc,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAa,iBAAiB,EAAE,MAAM,eAAe,CAAC;AACrM,OAAO,EAAqC,mBAAmB,EAAE,aAAa,EAAE,iBAAiB,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAExJ,iBAAiB;AACjB,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,kCAAkC;AAClC,OAAO,EAAC,cAAc,EAAC,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAC,iBAAiB,EAAC,MAAM,wBAAwB,CAAC;AAGzD,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD;;GAEG;AAgBH,MAAM,OAAO,yBAA0B,SAAQ,cAAc;IA+CzD;;OAEG;IACH,YAAuD,WAAuB,EAAmD,gBAA4B,EAAU,QAAkB,EAAE,GAAsB,EAAY,EAAuB;QAChP,KAAK,CAAC,GAAG,CAAC,CAAC;QADwC,gBAAW,GAAX,WAAW,CAAY;QAAmD,qBAAgB,GAAhB,gBAAgB,CAAY;QAAU,aAAQ,GAAR,QAAQ,CAAU;QAAoC,OAAE,GAAF,EAAE,CAAqB;QAhDpP;;WAEG;QACa,oBAAe,GAAG,IAAI,CAAC;QAEvC;;WAEG;QACa,qBAAgB,GAAG,IAAI,CAAC;QAExC;;WAEG;QACa,eAAU,GAAG,IAAI,CAAC;QAElC;;WAEG;QACa,yBAAoB,GAAY,IAAI,CAAC;QAErD;;WAEG;QACa,UAAK,GAAW,EAAE,CAAC;QAEnC;;WAEG;QACc,WAAM,GAA0B,IAAI,YAAY,EAAW,CAAC;QAwF7E;;WAEG;QACK,cAAS,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,iCAAiC;IArEhE,CAAC;IAED;;OAEG;IACH,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QAEjB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,qIAAqI;QACrI,8JAA8J;QAC9J,qCAAqC;QACrC,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,YAAY,iBAAiB,IAAI,IAAI,CAAC,QAAQ,CAAC;YACrG,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;QAEpB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,IAAI,CAAC,mBAAmB;YAAE,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,CAAC;IACzE,CAAC;IAED;;OAEG;IACH,eAAe;QACX,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAED;;;OAGG;IACH,WAAW;QACP,uBAAuB;QACvB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,kBAAkB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACjE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC1D;QAED,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,SAAS,GAAc,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAChE,IAAI,SAAS,EAAE;YACX,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC,OAAsB,CAAC;YAEtD,uFAAuF;YACvF,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjB,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;gBACrC,IAAI,CAAC,aAAa,CAAC,oBAAoB,EAAE,CAAC;aAC7C;YAED,uHAAuH;YACvH,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,GAAG,EAAE;gBAC5B,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBACnC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;gBAC/B,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YACxB,CAAC,CAAC;SACL;IACL,CAAC;IAOD;;OAEG;IACH,UAAU,CAAC,KAAU;QACjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAED;;;;OAIG;IACH,aAAa,CAAC,MAAM,EAAE,WAAoB,KAAK;QAC3C,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,WAAW,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;;;YA1KJ,SAAS,SAAC;gBACP,QAAQ,EAAE,YAAY;gBACtB,0jDAA+C;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBAErC,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,SAAS,EAAE;oBACP,EAAE,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,iBAAiB,EAAE;oBAC7D;wBACI,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC;wBACxD,KAAK,EAAE,IAAI;qBACd;iBACJ;;aACJ;;;YAmDuE,KAAK,uBAA5D,QAAQ,YAAI,MAAM,SAAC,aAAa;YAAsG,KAAK,uBAAvE,QAAQ,YAAI,MAAM,SAAC,mBAAmB;YAjFb,QAAQ;YAApF,iBAAiB;YAI1C,mBAAmB;;;8BAgCvB,KAAK;+BAKL,KAAK;yBAKL,KAAK;mCAKL,KAAK;oBAKL,KAAK;qBAKL,MAAM","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\nimport { ControlValueAccessor, FormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport {BaseValidation} from '../base-validation';\r\nimport {BaseValidationLoc} from '../base-validation.loc';\r\n\r\nimport { Subscription } from \"rxjs\";\r\nimport { ChangeEvent } from \"../../models/ChangeEvent\";\r\n\r\n/**\r\n * Componente di validaizone per gli input a selezione singola\r\n */\r\n@Component({\r\n    selector: \"val-select\",\r\n    templateUrl: \"validation-select.component.html\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    styleUrls: [\"../validation-style.scss\"],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        { provide: LocalizationService, useClass: BaseValidationLoc },\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => ValidationSelectComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class ValidationSelectComponent extends BaseValidation implements ControlValueAccessor {\r\n    \r\n    /**\r\n     * valore del campo vuoto della select\r\n     */\r\n    @Input() public emptyFieldValue = \"-2\";\r\n    \r\n    /**\r\n     * Valore del placeholder\r\n     */\r\n    @Input() public placeHolderValue = \"-1\";\r\n    \r\n    /**\r\n     * Per i componenti non obbligatori indica se fornire un \"valore vuoto\"\r\n     */\r\n    @Input() public emptyValue = true;\r\n\r\n    /**\r\n     * Indica se mostrare o nascondere il simboletto di validazione (Tic verde o Croce rossa)\r\n     */\r\n    @Input() public showValidationSymbol: boolean = true;\r\n\r\n    /**\r\n     * Contenuto della label Floattante Material-Style\r\n     */\r\n    @Input() public label: string = \"\";\r\n\r\n    /**\r\n     * Evento richiamato quando si perde il focus sull'input di inserimento\r\n     */\r\n    @Output() public onBlur: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    public parentControl: FormControl;\r\n\r\n    /**\r\n     * Valore del modello rappresentato dal componente\r\n     */\r\n    public value: string;\r\n\r\n    /**\r\n     * Subscription del tootltip da ripulire alla distruzione del componente\r\n     */\r\n    private tooltipSubscription: Subscription;\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    constructor(@Optional() @Inject(NG_VALIDATORS) private _validators: Array<any>, @Optional() @Inject(NG_ASYNC_VALIDATORS) private _asyncValidators: Array<any>, private injector: Injector, cdr: ChangeDetectorRef, protected lc: LocalizationService) {\r\n        super(cdr);\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n\r\n        this.registerFocusRequest();\r\n\r\n        //controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno\r\n        //Lo imposto ANCHE se sono in situazione di noValidate perché comporta eventuali modifiche grafiche che potrebbero servirmi, ma comunque non va a d aggiungere\r\n        //validatori o cose strane, quindi GG\r\n        if (this._validators && this._validators.some(elem => elem instanceof RequiredValidator && elem.required))\r\n            this.required = true;\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnDestroy() {\r\n        super.ngOnDestroy();\r\n\r\n        this.deregisterFocusRequest();\r\n        if (this.tooltipSubscription) this.tooltipSubscription.unsubscribe();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngAfterViewInit() {\r\n        this.postBinding();\r\n    }\r\n\r\n    /**\r\n     * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato \r\n     * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML\r\n     */\r\n    postBinding() {\r\n        // Eredito i validatori\r\n        if (!this.noValidate) {\r\n            this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n            this.baseInput.control.setValidators(this._validators);\r\n        }\r\n\r\n        this.CheckValidity();\r\n        const ngControl: NgControl = this.injector.get(NgControl, null);\r\n        if (ngControl) {\r\n            this.parentControl = ngControl.control as FormControl;\r\n\r\n            // se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti\r\n            if (this.noValidate) {\r\n                this.parentControl.clearValidators();\r\n                this.parentControl.clearAsyncValidators();\r\n            }\r\n\r\n            // faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n            const origFunc = this.parentControl.reset;\r\n            this.parentControl.reset = () => {\r\n                origFunc.apply(this.parentControl);\r\n                this.baseInput.control.reset();\r\n                this.tooltip.hide();\r\n            };\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    private onTouched = () => { }; //placeholder on touched function\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    writeValue(value: any): void {\r\n        this.value = value;\r\n        this.propagateChange(value);\r\n        this.cdr.markForCheck();\r\n    }\r\n\r\n    /**\r\n     * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo\r\n     * \r\n     * @param {any} toEmit valore da propagare all'esterno\r\n     */\r\n    onModelChange(toEmit, internal: boolean = false) {\r\n        this.writeValue(toEmit);\r\n        this.inputChange.emit(new ChangeEvent(internal, toEmit));\r\n        this.onTouched();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnChange(fn: any): void {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n}"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-select.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-select/validation-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\nimport { ControlValueAccessor, FormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport {BaseValidation} from '../base-validation';\r\nimport {BaseValidationLoc} from '../base-validation.loc';\r\n\r\nimport { Subscription } from \"rxjs\";\r\nimport { ChangeEvent } from \"../../models/ChangeEvent\";\r\n\r\n/**\r\n * Componente di validaizone per gli input a selezione singola\r\n */\r\n@Component({\r\n    selector: \"val-select\",\r\n    templateUrl: \"validation-select.component.html\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    styleUrls: [\"../validation-style.scss\"],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        { provide: LocalizationService, useClass: BaseValidationLoc },\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => ValidationSelectComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class ValidationSelectComponent extends BaseValidation implements ControlValueAccessor {\r\n    \r\n    /**\r\n     * valore del campo vuoto della select\r\n     */\r\n    @Input() public emptyFieldValue = \"-2000\";\r\n    \r\n    /**\r\n     * Valore del placeholder\r\n     */\r\n    @Input() public placeHolderValue = \"-1000\";\r\n    \r\n    /**\r\n     * Per i componenti non obbligatori indica se fornire un \"valore vuoto\"\r\n     */\r\n    @Input() public emptyValue = true;\r\n\r\n    /**\r\n     * Indica se mostrare o nascondere il simboletto di validazione (Tic verde o Croce rossa)\r\n     */\r\n    @Input() public showValidationSymbol: boolean = true;\r\n\r\n    /**\r\n     * Contenuto della label Floattante Material-Style\r\n     */\r\n    @Input() public label: string = \"\";\r\n\r\n    /**\r\n     * Evento richiamato quando si perde il focus sull'input di inserimento\r\n     */\r\n    @Output() public onBlur: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    public parentControl: FormControl;\r\n\r\n    /**\r\n     * Valore del modello rappresentato dal componente\r\n     */\r\n    public value: string;\r\n\r\n    /**\r\n     * Subscription del tootltip da ripulire alla distruzione del componente\r\n     */\r\n    private tooltipSubscription: Subscription;\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    constructor(@Optional() @Inject(NG_VALIDATORS) private _validators: Array<any>, @Optional() @Inject(NG_ASYNC_VALIDATORS) private _asyncValidators: Array<any>, private injector: Injector, cdr: ChangeDetectorRef, protected lc: LocalizationService) {\r\n        super(cdr);\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n\r\n        this.registerFocusRequest();\r\n\r\n        //controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno\r\n        //Lo imposto ANCHE se sono in situazione di noValidate perché comporta eventuali modifiche grafiche che potrebbero servirmi, ma comunque non va a d aggiungere\r\n        //validatori o cose strane, quindi GG\r\n        if (this._validators && this._validators.some(elem => elem instanceof RequiredValidator && elem.required))\r\n            this.required = true;\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnDestroy() {\r\n        super.ngOnDestroy();\r\n\r\n        this.deregisterFocusRequest();\r\n        if (this.tooltipSubscription) this.tooltipSubscription.unsubscribe();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngAfterViewInit() {\r\n        this.postBinding();\r\n    }\r\n\r\n    /**\r\n     * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato \r\n     * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML\r\n     */\r\n    postBinding() {\r\n        // Eredito i validatori\r\n        if (!this.noValidate) {\r\n            this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n            this.baseInput.control.setValidators(this._validators);\r\n        }\r\n\r\n        this.CheckValidity();\r\n        const ngControl: NgControl = this.injector.get(NgControl, null);\r\n        if (ngControl) {\r\n            this.parentControl = ngControl.control as FormControl;\r\n\r\n            // se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti\r\n            if (this.noValidate) {\r\n                this.parentControl.clearValidators();\r\n                this.parentControl.clearAsyncValidators();\r\n            }\r\n\r\n            // faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n            const origFunc = this.parentControl.reset;\r\n            this.parentControl.reset = () => {\r\n                origFunc.apply(this.parentControl);\r\n                this.baseInput.control.reset();\r\n                this.tooltip.hide();\r\n            };\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    private onTouched = () => { }; //placeholder on touched function\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    writeValue(value: any): void {\r\n        this.value = value;\r\n        this.propagateChange(value);\r\n        this.cdr.markForCheck();\r\n    }\r\n\r\n    /**\r\n     * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo\r\n     * \r\n     * @param {any} toEmit valore da propagare all'esterno\r\n     */\r\n    onModelChange(toEmit, internal: boolean = false) {\r\n        this.writeValue(toEmit);\r\n        this.inputChange.emit(new ChangeEvent(internal, toEmit));\r\n        this.onTouched();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnChange(fn: any): void {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n}"]}
@@ -502,11 +502,11 @@ class ValidationSelectComponent extends BaseValidation {
502
502
  /**
503
503
  * valore del campo vuoto della select
504
504
  */
505
- this.emptyFieldValue = "-2";
505
+ this.emptyFieldValue = "-2000";
506
506
  /**
507
507
  * Valore del placeholder
508
508
  */
509
- this.placeHolderValue = "-1";
509
+ this.placeHolderValue = "-1000";
510
510
  /**
511
511
  * Per i componenti non obbligatori indica se fornire un "valore vuoto"
512
512
  */
@@ -1722,6 +1722,10 @@ class BaseFormControl {
1722
1722
  /** Cache delle proprietà scritte tipo --> {prop} */
1723
1723
  this.BindProperties = [];
1724
1724
  this.destroyed$ = new Subject();
1725
+ /**
1726
+ * Variabile per tenere in memoria il fatto che il componente è forzato a invalido o no
1727
+ */
1728
+ this._forceInvalid = false;
1725
1729
  if (ngControl == null) {
1726
1730
  if (!this.handleNullNgControl())
1727
1731
  console.error("ngControl nullo per qualche motivo! Il 90% delle funzionalità di questo input saranno disabilitate");
@@ -1781,17 +1785,17 @@ class BaseFormControl {
1781
1785
  this.InputColWidth = parseInt(ratio[1]);
1782
1786
  }
1783
1787
  /**
1784
- * Query sull'elemento 'validationControl' che funziona in ambiente statico
1788
+ * Query sull'elemento 'baseInput' che funziona in ambiente statico
1785
1789
  *
1786
- * @param {NgModel} comp Elemento HTML marcato con "#validationControl"
1790
+ * @param {NgModel} comp Elemento HTML marcato con "#baseInput"
1787
1791
  */
1788
- set _validationControl(comp) { this.registerValComp(comp); }
1792
+ set baseInput(comp) { this.registerBaseInput(comp); }
1789
1793
  /**
1790
- * Query sull'elemento 'validationControl' che funziona in ambiente dinamico
1794
+ * Query sull'elemento 'baseInput' che funziona in ambiente dinamico
1791
1795
  *
1792
- * @param {NgModel} comp Elemento HTML marcato con "#validationControl"
1796
+ * @param {NgModel} comp Elemento HTML marcato con "#baseInput"
1793
1797
  */
1794
- set validationControl_static(comp) { this.registerValComp(comp); }
1798
+ set baseInput_static(comp) { this.registerBaseInput(comp); }
1795
1799
  ;
1796
1800
  /**
1797
1801
  * Effettua il Bind/Parse delle varie **Source** unendo le informazioni specificate in **Display**
@@ -1902,11 +1906,14 @@ class BaseFormControl {
1902
1906
  if (this.SetValidationSubject) {
1903
1907
  this.SetValidationSubject.pipe(takeUntil(this.destroyed$)).subscribe(v => {
1904
1908
  if (v.fieldName + "_internal" == this.GeneratedName) {
1909
+ // Bisogna farlo su entrambi i Control per portare il ".valid" nel punto giusto
1910
+ // e per avere gli stili sull'input
1905
1911
  let control = this.Form.getControl(this.validationControl);
1906
1912
  control.setErrors({ forcedtoinvalid: true });
1907
1913
  control.markAsTouched();
1908
1914
  this.ngControl.control.setErrors({ forcedtoinvalid: true });
1909
1915
  this.ngControl.control.markAsTouched();
1916
+ this.cdr.markForCheck();
1910
1917
  }
1911
1918
  });
1912
1919
  }
@@ -1976,7 +1983,7 @@ class BaseFormControl {
1976
1983
  *
1977
1984
  * @param {NgModel} comp Elemento HTML marcato con "#validationControl"
1978
1985
  */
1979
- registerValComp(comp) {
1986
+ registerBaseInput(comp) {
1980
1987
  if (comp) {
1981
1988
  // È arrivato un nuovo validationContorl (succede solo nel form-select quando cambia la source da 0 elementi / null ad N elementi, quindi al massimo una volta)
1982
1989
  if (this.validationControl && this.Form)
@@ -2056,6 +2063,63 @@ class BaseFormControl {
2056
2063
  if (this.FAV_DEBUG_MODE)
2057
2064
  console.log("@forms-and-validations: " + message);
2058
2065
  }
2066
+ /**
2067
+ * Imposta il componente come "submitted" scatenandone le validazioni ed eventualmente la visualizzazione del tooltip di errore
2068
+ *
2069
+ * @param {boolean} val **true** se si vuole impostare questo controllo come submitted, **false** altrimenti
2070
+ */
2071
+ set submitted(val) {
2072
+ this._submitted = val;
2073
+ if (!this.baseInput)
2074
+ return;
2075
+ if (val) {
2076
+ this.baseInput.control.markAsTouched();
2077
+ }
2078
+ if (this.baseInput.control.status === "INVALID" && val) { /*this.showTooltipWithMessage();*/ }
2079
+ else { /*this.tooltip.hide();*/ }
2080
+ }
2081
+ /**
2082
+ * Imposta il componente come "invalid" a prescindere dai validatori
2083
+ */
2084
+ set forceInvalid(val) {
2085
+ this._forceInvalid = val;
2086
+ if (val)
2087
+ setTimeout(() => {
2088
+ this.baseInput.control.setErrors({ forcedtoinvalid: true });
2089
+ this.baseInput.control.markAsTouched();
2090
+ this.baseInput.control.markAsDirty();
2091
+ this.cdr.detectChanges();
2092
+ });
2093
+ else
2094
+ setTimeout(() => {
2095
+ this.baseInput.control.setErrors({ forcedtoinvalid: null });
2096
+ this.baseInput.control.updateValueAndValidity();
2097
+ });
2098
+ }
2099
+ /**
2100
+ * @ignore
2101
+ */
2102
+ setDisabledState(isDisabled) {
2103
+ isDisabled ? this.baseInput.control.disable() : this.baseInput.control.enable();
2104
+ this.Readonly = isDisabled;
2105
+ }
2106
+ /**
2107
+ * Registra il Subject per ricevere le richieste di Focus dall'esterno
2108
+ */
2109
+ registerFocusRequest() {
2110
+ if (!this.FocusSubject)
2111
+ return;
2112
+ this.observable = this.FocusSubject.subscribe(t => {
2113
+ this.htmlInput.nativeElement.focus();
2114
+ });
2115
+ }
2116
+ /**
2117
+ * Deregistra il Subject delle richieste di focus
2118
+ */
2119
+ deregisterFocusRequest() {
2120
+ if (this.observable)
2121
+ this.observable.unsubscribe();
2122
+ }
2059
2123
  }
2060
2124
  BaseFormControl.decorators = [
2061
2125
  { type: Directive }
@@ -2098,11 +2162,14 @@ BaseFormControl.propDecorators = {
2098
2162
  Display: [{ type: Input }],
2099
2163
  Readonly: [{ type: Input }],
2100
2164
  LabelInputRatio: [{ type: Input }],
2101
- _validationControl: [{ type: ViewChild, args: ["validationControl", { static: false },] }],
2102
- validationControl_static: [{ type: ViewChild, args: ["validationControl", { static: true },] }],
2165
+ htmlInput: [{ type: ViewChild, args: ['htmlInput', { static: false },] }],
2166
+ baseInput: [{ type: ViewChild, args: ["baseInput", { static: false },] }],
2167
+ baseInput_static: [{ type: ViewChild, args: ["baseInput", { static: true },] }],
2103
2168
  inputChange: [{ type: Output }],
2104
2169
  inputFocus: [{ type: Output }],
2105
- inputFinalized: [{ type: Output }]
2170
+ inputFinalized: [{ type: Output }],
2171
+ submitted: [{ type: Input, args: ["submitted",] }],
2172
+ forceInvalid: [{ type: Input }]
2106
2173
  };
2107
2174
 
2108
2175
  /**
@@ -2930,6 +2997,7 @@ class FormInputComponent extends BaseFormControl {
2930
2997
  this.HasSuffix = false;
2931
2998
  /** Indica la presenza o meno di un prefisso, si basa sulla "truthiness" della proiezione **prefix** */
2932
2999
  this.HasPrefix = false;
3000
+ this.ShowPassword = false;
2933
3001
  }
2934
3002
  /** @ignore */
2935
3003
  writeValue(obj) {
@@ -2943,11 +3011,16 @@ class FormInputComponent extends BaseFormControl {
2943
3011
  }
2944
3012
  /** @ignore */
2945
3013
  onNotNullValueSet() { }
3014
+ onShowHidePassword(event) {
3015
+ this.Password = !this.Password;
3016
+ this.ShowPassword = !this.ShowPassword;
3017
+ event.preventDefault();
3018
+ }
2946
3019
  }
2947
3020
  FormInputComponent.decorators = [
2948
3021
  { type: Component, args: [{
2949
3022
  selector: "form-input",
2950
- template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n <val-input [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n [noValidate]=\"!Validation\"\r\n [Frozen]=\"Frozen\"\r\n [submitted]=\"Form?.submitted\"\r\n [readonly]=\"Readonly\"\r\n [forceInvalid]=\"ForcedError\" \r\n [FloatingLabel]=\"FloatingLabel\"\r\n type=\"text\"\r\n [(ngModel)]=\"Model\"\r\n [id]=\"GeneratedName\"\r\n name=\"{{GeneratedName}}\"\r\n autocomplete=\"off\"\r\n #validationControl=\"ngModel\"\r\n (inputChange)=\"changed();\"\r\n (inputFocus)=\"focused($event);\"\r\n (inputFinalized)=\"finalized()\"\r\n [placeholder]=\"Placeholder\"\r\n [validationFailed]=\"FailedValidationMessage\"\r\n [Password]=\"Password\">\r\n <ng-container *ngIf=\"HasSuffix\">\r\n <ng-template #suffix_internal>\r\n <button type=\"button\" class=\"mat-button mat-icon-button mat-button-base mat-icon-button-override mat-icon-button-override-suffix\"\r\n matSuffix (click)=\"onSuffixAction.emit(); $event.stopPropagation(); $event.preventDefault();\">\r\n <ng-container *ngTemplateOutlet=\"suffix\"></ng-container>\r\n </button>\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"HasPrefix\">\r\n <ng-template #prefix_internal>\r\n <button type=\"button\" class=\"mat-button mat-icon-button mat-button-base mat-icon-button-override mat-icon-button-override-prefix\"\r\n matPrefix (click)=\"onPrefixAction.emit(); $event.stopPropagation(); $event.preventDefault();\">\r\n <ng-container *ngTemplateOutlet=\"prefix\"></ng-container>\r\n </button>\r\n </ng-template>\r\n </ng-container>\r\n </val-input>\r\n</ng-template>",
3023
+ template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n <mat-form-field floatLabel=\"never\" appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\">\r\n <mat-label [class.app-margin-left-25]=\"HasPrefix\" *ngIf=\"Placeholder && FloatingLabel\">{{Placeholder}}</mat-label>\r\n <!--Prefisso-->\r\n <ng-container *ngIf=\"HasPrefix\">\r\n <button type=\"button\"\r\n class=\"mat-button mat-icon-button mat-button-base mat-icon-button-override mat-icon-button-override-prefix\"\r\n matPrefix (click)=\"onPrefixAction.emit(); $event.stopPropagation(); $event.preventDefault();\">\r\n <ng-container *ngTemplateOutlet=\"prefix\"></ng-container>\r\n </button>\r\n </ng-container>\r\n <!--Input-->\r\n <input matInput\r\n #baseInput=\"ngModel\"\r\n #htmlInput\r\n [type]=\"Password ? 'password' : 'text'\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n autocomplete=\"off\"\r\n name=\"base-input\"\r\n class=\"form-control\"\r\n id=\"{{GeneratedName}}\"\r\n [class.app-margin-left-25]=\"HasPrefix\"\r\n [class.mat-input-with-suffix]=\"HasSuffix || Password\"\r\n [(ngModel)]=\"Model\"\r\n [class.checking-field]=\"!Validation\"\r\n [readonly]=\"Frozen\"\r\n [disabled]=\"Readonly\"\r\n [placeholder]=\"FloatingLabel ? undefined : Placeholder\"\r\n (focus)=\"focused($event);\"\r\n (ngModelChange)=\"changed()\"\r\n (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && finalized();\"\r\n (blur)=\"finalized();\"\r\n >\r\n <ng-container *ngIf=\"HasSuffix || Password\">\r\n <ng-container *ngIf=\"!Password\">\r\n <button type=\"button\"\r\n class=\"mat-button mat-icon-button mat-button-base mat-icon-button-override mat-icon-button-override-suffix\"\r\n matSuffix (click)=\"onSuffixAction.emit(); $event.stopPropagation(); $event.preventDefault();\">\r\n <ng-container *ngTemplateOutlet=\"suffix\"></ng-container>\r\n </button>\r\n </ng-container>\r\n <!--Password-->\r\n <span class=\"form-input-suffix\" *ngIf=\"Password\">\r\n <ng-container *ngIf=\"Password\" matSuffix>\r\n <a *ngIf=\"ShowPassword\" class=\"fa fa-eye-slash app-fs-16 app-pointer\" (click)=\"onShowHidePassword($event)\"></a>\r\n <a *ngIf=\"!ShowPassword\" class=\"fa fa-eye app-fs-16 app-pointer\" (click)=\"onShowHidePassword($event)\"></a>\r\n </ng-container>\r\n </span>\r\n </ng-container>\r\n </mat-form-field>\r\n</ng-template>",
2951
3024
  changeDetection: ChangeDetectionStrategy.OnPush
2952
3025
  },] }
2953
3026
  ];
@@ -3008,7 +3081,7 @@ class FormSelectComponent extends BaseFormControl {
3008
3081
  *
3009
3082
  * Si consiglia di mantenere il default
3010
3083
  */
3011
- this.EmptyFieldValue = '-2';
3084
+ this.EmptyFieldValue = '-2000';
3012
3085
  /** Se **true** rimuove il simbolino di validazione (croce rossa o tick verde) */
3013
3086
  this.ShowValidationSymbol = true;
3014
3087
  /** Template per la visualizzazione delle opzioni */