@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.
- package/bundles/esfaenza-forms-and-validations.umd.js +99 -16
- package/bundles/esfaenza-forms-and-validations.umd.js.map +1 -1
- package/esfaenza-forms-and-validations.metadata.json +1 -1
- package/esm2015/lib/forms/base-form-control.js +78 -11
- package/esm2015/lib/forms/form-input/form-input.component.js +8 -2
- package/esm2015/lib/forms/form-select/form-select.component.js +2 -2
- package/esm2015/lib/validations/validation-select/validation-select.component.js +3 -3
- package/fesm2015/esfaenza-forms-and-validations.js +87 -14
- package/fesm2015/esfaenza-forms-and-validations.js.map +1 -1
- package/lib/forms/base-form-control.d.ts +46 -8
- package/lib/forms/form-input/form-input.component.d.ts +2 -0
- package/package.json +1 -1
|
@@ -23,11 +23,11 @@ export class ValidationSelectComponent extends BaseValidation {
|
|
|
23
23
|
/**
|
|
24
24
|
* valore del campo vuoto della select
|
|
25
25
|
*/
|
|
26
|
-
this.emptyFieldValue = "-
|
|
26
|
+
this.emptyFieldValue = "-2000";
|
|
27
27
|
/**
|
|
28
28
|
* Valore del placeholder
|
|
29
29
|
*/
|
|
30
|
-
this.placeHolderValue = "-
|
|
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":"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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 = \"-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 = "-
|
|
505
|
+
this.emptyFieldValue = "-2000";
|
|
506
506
|
/**
|
|
507
507
|
* Valore del placeholder
|
|
508
508
|
*/
|
|
509
|
-
this.placeHolderValue = "-
|
|
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 '
|
|
1788
|
+
* Query sull'elemento 'baseInput' che funziona in ambiente statico
|
|
1785
1789
|
*
|
|
1786
|
-
* @param {NgModel} comp Elemento HTML marcato con "#
|
|
1790
|
+
* @param {NgModel} comp Elemento HTML marcato con "#baseInput"
|
|
1787
1791
|
*/
|
|
1788
|
-
set
|
|
1792
|
+
set baseInput(comp) { this.registerBaseInput(comp); }
|
|
1789
1793
|
/**
|
|
1790
|
-
* Query sull'elemento '
|
|
1794
|
+
* Query sull'elemento 'baseInput' che funziona in ambiente dinamico
|
|
1791
1795
|
*
|
|
1792
|
-
* @param {NgModel} comp Elemento HTML marcato con "#
|
|
1796
|
+
* @param {NgModel} comp Elemento HTML marcato con "#baseInput"
|
|
1793
1797
|
*/
|
|
1794
|
-
set
|
|
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
|
-
|
|
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
|
-
|
|
2102
|
-
|
|
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
|
|
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 = '-
|
|
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 */
|