@esfaenza/forms-and-validations 13.3.3 → 13.3.4

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.
@@ -98,7 +98,10 @@ export class FormSelectComponent extends BaseFormControl {
98
98
  }
99
99
  }
100
100
  detatchPreviousAndRetatchNext(doStuff) {
101
- this.Form.removeControl(this.validationControl);
101
+ if (this.validationControl)
102
+ this.Form.removeControl(this.validationControl);
103
+ else
104
+ console.log("Nothing to detatch");
102
105
  setTimeout(() => {
103
106
  doStuff(() => {
104
107
  if (this.validationControl)
@@ -150,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImpor
150
153
  }], ShowValidationSymbol: [{
151
154
  type: Input
152
155
  }] } });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-select.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-select/form-select.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-select/form-select.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self, SimpleChanges, ChangeDetectorRef } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { ACO_CUSTOMKEY } from '../../tokens';\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { FormSelectComponentLoc } from \"./form-select.component.loc\";\r\n\r\n/**\r\n * Componente che permette di selezionare un valore da una lista di valori disponibili\r\n */\r\n@Component({\r\n    selector: \"form-select\",\r\n    providers: [{ provide: LocalizationService, useClass: FormSelectComponentLoc }],\r\n    templateUrl: \"form-select.component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormSelectComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /**\r\n     * Permette di specificare il testo della Label flottante material-style\r\n     */\r\n    @Input() SelectLabel: string = \"\";\r\n\r\n    /**\r\n     * Permette al componente di considerare questo valore come \"valore placeholder\"\r\n     * \r\n     * Si consiglia di mantenere il default\r\n     */\r\n    @Input() PlaceholderValue: string = '';\r\n\r\n    /**\r\n     * Override del placeholder per select requried\r\n     */\r\n    @Input() RequiredPlaceholder: string = null;\r\n\r\n    /**\r\n     * Permette al componente di considerare questo valore come \"valore vuoto\"\r\n     * \r\n     * Si consiglia di mantenere il default\r\n     */\r\n    @Input() EmptyFieldValue: string = '-2';\r\n\r\n    /**\r\n     * Se **true** rimuove il simbolino di validazione (croce rossa o tick verde)\r\n     */\r\n    @Input() ShowValidationSymbol: boolean = true;\r\n\r\n    /**\r\n     * Costruttore \r\n     * \r\n     * @ignore\r\n     */\r\n    constructor(cdr: ChangeDetectorRef, public lc: LocalizationService, @Optional() @Self() ngControl: NgControl, @Optional() @Inject(NG_VALIDATORS) _validators: Array<any>, @Optional() ac: AccessControlService, @Optional() AppContext: ComponentContext, @Optional() @Inject(ACO_CUSTOMKEY) ACO_CUSTOMKEY: string) {\r\n        super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY);\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    public ngOnChanges(changes: SimpleChanges) {\r\n        let newSource = changes[\"Source\"];\r\n        if (!newSource)\r\n            return;\r\n\r\n        let curr = newSource.currentValue;\r\n        let prev = newSource.previousValue;\r\n\r\n        // Se manca curr vuol dire che non ho un valore e posso ignorare (alla peggio deve arrivarmi un array vuoto)\r\n        if (!curr)\r\n            return;\r\n\r\n        // Se manca prev vuol dire che è la prima assegnazione, lo considero un array vuoto e proseguo... ogni tanto viene chiamato una sola volta\r\n        // ogni tanto viene chiamato due volte... è un pelo arbitrario ma vabbè\r\n        if (!prev)\r\n            prev = [];\r\n\r\n        // Considero di aver ricevuto una nuova sorgente se:\r\n        // 1: La sorgente nuova ha un numero di elementi diverso dalla sorgente vecchia\r\n        // 2: Sia la sorgente nuova che vecchia hanno almeno un elemento e l'id del primo elemento della sorgente nuova è diverso dall'id del primo elemento della sorgente vecchia\r\n        if (newSource && (curr.length != prev.length || (curr.length > 0 && curr[0][this.IdField] != prev[0][this.IdField]))) {\r\n            /*\r\n             * NGBUG:\r\n             * Uso questo escamotage per distruggere il val-select e ricrearlo\r\n             * Purtroppo una volta bindato a una sorgente, cambiargliela sotto significa mandare in palla material\r\n             * che si mette a far floattare la label anche se il valore e' vuoto\r\n             * Distruggendo il componente e ricreandolo material riparte da 0 e non da' problemi.\r\n             * Ovviamente lo faccio solo quando ho una SelectLabel, altrimenti non ho problemi di floattamenti\r\n             */\r\n            if (!this.SourceFirstBind && this.SelectLabel) {\r\n\r\n                this.detatchPreviousAndRetatchNext((afterStuff) => {\r\n                    this.BoundSource = null;\r\n                    setTimeout(() => {\r\n                        this.tryBindSourceDisplay();\r\n                        this.cdr.detectChanges();\r\n                        setTimeout(() => { afterStuff(); })\r\n\r\n                    });\r\n                });\r\n            }\r\n            else\r\n                this.detatchPreviousAndRetatchNext((afterStuff) => {\r\n                    this.tryBindSourceDisplay();\r\n                    this.cdr.detectChanges();\r\n                    setTimeout(() => { afterStuff(); })\r\n                });\r\n\r\n            this.cdr.markForCheck();\r\n        }\r\n    }\r\n\r\n    private detatchPreviousAndRetatchNext(doStuff: Function) {\r\n        this.Form.removeControl(this.validationControl);\r\n        setTimeout(() => {\r\n            doStuff(() => {\r\n                if (this.validationControl)\r\n                    this.Form.addControl(this.validationControl);\r\n                else\r\n                    if (this.validationControl) {\r\n                        this.Form.addControl(this.validationControl);\r\n                    }\r\n                    else\r\n                        console.error(`Impossibile aggiungere il componente di validaazione per ${this.GeneratedName}, le validazioni potrebbero funzionare in maniera erratica`)\r\n            });\r\n        })\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    onNotNullValueSet(): void { }\r\n}","<ng-container *ngIf=\"!FormLayout\">\r\n    <ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && BoundSource\" class=\"form-group row {{FormGroupClass}}\" [class.app-margin-bottom-0]=\"Last\">\r\n    <label class=\"col-md-{{LabelColWidth}} m-t-5\">{{Label}}{{Required ? '*' : ''}}:</label>\r\n    <div class=\"col-md-{{InputColWidth}}\">\r\n        <ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container>\r\n    </div>\r\n    <div class=\"clearfix\"></div>\r\n</div>\r\n\r\n<ng-template #controlTemplate>\r\n\r\n    <!-- Select vuota per quando non ho Sorgenti dati da cui selezionare. Uguale identica alla piena ma senza option\r\n    Purtroppo devono essere due componenti distinti perché una select una volta creata non riesce più ad adattarsi ai cambi di options -->\r\n    <val-select *ngIf=\"!BoundSource || BoundSource.length == 0\"\r\n                [FocusSubject]=\"FocusSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n                [required]=\"Required ? 'required' : null\"\r\n                [noValidate]=\"!Validation\"\r\n                [readonly]=\"Readonly\"\r\n                [forceInvalid]=\"ForcedError\"\r\n                [label]=\"SelectLabel\"\r\n                [validationFailed]=\"FailedValidationMessage\"\r\n                [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Select' | localize : lc) + '...'))  : Placeholder\"\r\n                [placeHolderValue]=\"PlaceholderValue\"\r\n                [submitted]=\"Form?.submitted\"\r\n                [emptyFieldValue]=\"Required || Placeholder || SelectLabel ? EmptyFieldValue : ''\"\r\n                [(ngModel)]=\"Model\"\r\n                [showValidationSymbol]=\"ShowValidationSymbol\"\r\n                [id]=\"GeneratedName\"\r\n                name=\"{{GeneratedName}}_zero\"\r\n                (inputChange)=\"Model = $event == EmptyFieldValue ? (Required? PlaceholderValue : '') : $event; changed();\"\r\n                (inputFocus)=\"focused($event);\"\r\n                #validationControl=\"ngModel\">\r\n    </val-select>\r\n\r\n    <!-- Select vera e propria per quando arrivano i dati -->\r\n    <val-select *ngIf=\"BoundSource && BoundSource.length > 0\"\r\n                [FocusSubject]=\"FocusSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n                [required]=\"Required ? 'required' : null\"\r\n                [noValidate]=\"!Validation\"\r\n                [readonly]=\"Readonly\"\r\n                [forceInvalid]=\"ForcedError\"\r\n                [label]=\"SelectLabel\"\r\n                [validationFailed]=\"FailedValidationMessage\"\r\n                [showValidationSymbol]=\"ShowValidationSymbol\"\r\n                [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Select' | localize : lc) + '...')) : Placeholder\"\r\n                [placeHolderValue]=\"PlaceholderValue\"\r\n                [submitted]=\"Form?.submitted\"\r\n                [emptyFieldValue]=\"Required || Placeholder || SelectLabel ? EmptyFieldValue : ''\"\r\n                [(ngModel)]=\"Model\"\r\n                [id]=\"GeneratedName\"\r\n                name=\"{{GeneratedName}}_filled\"\r\n                (inputChange)=\"Model = $event == EmptyFieldValue ? (Required? PlaceholderValue : '') : $event; changed();\"\r\n                (inputFocus)=\"focused($event);\"\r\n                (inputFinalized)=\"finalized()\"\r\n                #validationControl=\"ngModel\">\r\n        <option *ngFor=\"let obj of BoundSource\" [value]=\"obj.id\">{{obj.description}}</option>\r\n    </val-select>\r\n</ng-template>"]}
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-select.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-select/form-select.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-select/form-select.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self, SimpleChanges, ChangeDetectorRef } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { ACO_CUSTOMKEY } from '../../tokens';\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { FormSelectComponentLoc } from \"./form-select.component.loc\";\r\n\r\n/**\r\n * Componente che permette di selezionare un valore da una lista di valori disponibili\r\n */\r\n@Component({\r\n    selector: \"form-select\",\r\n    providers: [{ provide: LocalizationService, useClass: FormSelectComponentLoc }],\r\n    templateUrl: \"form-select.component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormSelectComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /**\r\n     * Permette di specificare il testo della Label flottante material-style\r\n     */\r\n    @Input() SelectLabel: string = \"\";\r\n\r\n    /**\r\n     * Permette al componente di considerare questo valore come \"valore placeholder\"\r\n     * \r\n     * Si consiglia di mantenere il default\r\n     */\r\n    @Input() PlaceholderValue: string = '';\r\n\r\n    /**\r\n     * Override del placeholder per select requried\r\n     */\r\n    @Input() RequiredPlaceholder: string = null;\r\n\r\n    /**\r\n     * Permette al componente di considerare questo valore come \"valore vuoto\"\r\n     * \r\n     * Si consiglia di mantenere il default\r\n     */\r\n    @Input() EmptyFieldValue: string = '-2';\r\n\r\n    /**\r\n     * Se **true** rimuove il simbolino di validazione (croce rossa o tick verde)\r\n     */\r\n    @Input() ShowValidationSymbol: boolean = true;\r\n\r\n    /**\r\n     * Costruttore \r\n     * \r\n     * @ignore\r\n     */\r\n    constructor(cdr: ChangeDetectorRef, public lc: LocalizationService, @Optional() @Self() ngControl: NgControl, @Optional() @Inject(NG_VALIDATORS) _validators: Array<any>, @Optional() ac: AccessControlService, @Optional() AppContext: ComponentContext, @Optional() @Inject(ACO_CUSTOMKEY) ACO_CUSTOMKEY: string) {\r\n        super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY);\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    public ngOnChanges(changes: SimpleChanges) {\r\n        let newSource = changes[\"Source\"];\r\n        if (!newSource)\r\n            return;\r\n\r\n        let curr = newSource.currentValue;\r\n        let prev = newSource.previousValue;\r\n\r\n        // Se manca curr vuol dire che non ho un valore e posso ignorare (alla peggio deve arrivarmi un array vuoto)\r\n        if (!curr)\r\n            return;\r\n\r\n        // Se manca prev vuol dire che è la prima assegnazione, lo considero un array vuoto e proseguo... ogni tanto viene chiamato una sola volta\r\n        // ogni tanto viene chiamato due volte... è un pelo arbitrario ma vabbè\r\n        if (!prev)\r\n            prev = [];\r\n\r\n        // Considero di aver ricevuto una nuova sorgente se:\r\n        // 1: La sorgente nuova ha un numero di elementi diverso dalla sorgente vecchia\r\n        // 2: Sia la sorgente nuova che vecchia hanno almeno un elemento e l'id del primo elemento della sorgente nuova è diverso dall'id del primo elemento della sorgente vecchia\r\n        if (newSource && (curr.length != prev.length || (curr.length > 0 && curr[0][this.IdField] != prev[0][this.IdField]))) {\r\n            /*\r\n             * NGBUG:\r\n             * Uso questo escamotage per distruggere il val-select e ricrearlo\r\n             * Purtroppo una volta bindato a una sorgente, cambiargliela sotto significa mandare in palla material\r\n             * che si mette a far floattare la label anche se il valore e' vuoto\r\n             * Distruggendo il componente e ricreandolo material riparte da 0 e non da' problemi.\r\n             * Ovviamente lo faccio solo quando ho una SelectLabel, altrimenti non ho problemi di floattamenti\r\n             */\r\n            if (!this.SourceFirstBind && this.SelectLabel) {\r\n\r\n                this.detatchPreviousAndRetatchNext((afterStuff) => {\r\n                    this.BoundSource = null;\r\n                    setTimeout(() => {\r\n                        this.tryBindSourceDisplay();\r\n                        this.cdr.detectChanges();\r\n                        setTimeout(() => { afterStuff(); })\r\n\r\n                    });\r\n                });\r\n            }\r\n            else\r\n                this.detatchPreviousAndRetatchNext((afterStuff) => {\r\n                    this.tryBindSourceDisplay();\r\n                    this.cdr.detectChanges();\r\n                    setTimeout(() => { afterStuff(); })\r\n                });\r\n\r\n            this.cdr.markForCheck();\r\n        }\r\n    }\r\n\r\n    private detatchPreviousAndRetatchNext(doStuff: Function) {\r\n        if(this.validationControl)\r\n            this.Form.removeControl(this.validationControl);\r\n        else\r\n            console.log(\"Nothing to detatch\");\r\n        setTimeout(() => {\r\n            doStuff(() => {\r\n                if (this.validationControl)\r\n                    this.Form.addControl(this.validationControl);\r\n                else\r\n                    if (this.validationControl) {\r\n                        this.Form.addControl(this.validationControl);\r\n                    }\r\n                    else\r\n                        console.error(`Impossibile aggiungere il componente di validaazione per ${this.GeneratedName}, le validazioni potrebbero funzionare in maniera erratica`)\r\n            });\r\n        })\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    onNotNullValueSet(): void { }\r\n}","<ng-container *ngIf=\"!FormLayout\">\r\n    <ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && BoundSource\" class=\"form-group row {{FormGroupClass}}\" [class.app-margin-bottom-0]=\"Last\">\r\n    <label class=\"col-md-{{LabelColWidth}} m-t-5\">{{Label}}{{Required ? '*' : ''}}:</label>\r\n    <div class=\"col-md-{{InputColWidth}}\">\r\n        <ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container>\r\n    </div>\r\n    <div class=\"clearfix\"></div>\r\n</div>\r\n\r\n<ng-template #controlTemplate>\r\n\r\n    <!-- Select vuota per quando non ho Sorgenti dati da cui selezionare. Uguale identica alla piena ma senza option\r\n    Purtroppo devono essere due componenti distinti perché una select una volta creata non riesce più ad adattarsi ai cambi di options -->\r\n    <val-select *ngIf=\"!BoundSource || BoundSource.length == 0\"\r\n                [FocusSubject]=\"FocusSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n                [required]=\"Required ? 'required' : null\"\r\n                [noValidate]=\"!Validation\"\r\n                [readonly]=\"Readonly\"\r\n                [forceInvalid]=\"ForcedError\"\r\n                [label]=\"SelectLabel\"\r\n                [validationFailed]=\"FailedValidationMessage\"\r\n                [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Select' | localize : lc) + '...'))  : Placeholder\"\r\n                [placeHolderValue]=\"PlaceholderValue\"\r\n                [submitted]=\"Form?.submitted\"\r\n                [emptyFieldValue]=\"Required || Placeholder || SelectLabel ? EmptyFieldValue : ''\"\r\n                [(ngModel)]=\"Model\"\r\n                [showValidationSymbol]=\"ShowValidationSymbol\"\r\n                [id]=\"GeneratedName\"\r\n                name=\"{{GeneratedName}}_zero\"\r\n                (inputChange)=\"Model = $event == EmptyFieldValue ? (Required? PlaceholderValue : '') : $event; changed();\"\r\n                (inputFocus)=\"focused($event);\"\r\n                #validationControl=\"ngModel\">\r\n    </val-select>\r\n\r\n    <!-- Select vera e propria per quando arrivano i dati -->\r\n    <val-select *ngIf=\"BoundSource && BoundSource.length > 0\"\r\n                [FocusSubject]=\"FocusSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n                [required]=\"Required ? 'required' : null\"\r\n                [noValidate]=\"!Validation\"\r\n                [readonly]=\"Readonly\"\r\n                [forceInvalid]=\"ForcedError\"\r\n                [label]=\"SelectLabel\"\r\n                [validationFailed]=\"FailedValidationMessage\"\r\n                [showValidationSymbol]=\"ShowValidationSymbol\"\r\n                [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Select' | localize : lc) + '...')) : Placeholder\"\r\n                [placeHolderValue]=\"PlaceholderValue\"\r\n                [submitted]=\"Form?.submitted\"\r\n                [emptyFieldValue]=\"Required || Placeholder || SelectLabel ? EmptyFieldValue : ''\"\r\n                [(ngModel)]=\"Model\"\r\n                [id]=\"GeneratedName\"\r\n                name=\"{{GeneratedName}}_filled\"\r\n                (inputChange)=\"Model = $event == EmptyFieldValue ? (Required? PlaceholderValue : '') : $event; changed();\"\r\n                (inputFocus)=\"focused($event);\"\r\n                (inputFinalized)=\"finalized()\"\r\n                #validationControl=\"ngModel\">\r\n        <option *ngFor=\"let obj of BoundSource\" [value]=\"obj.id\">{{obj.description}}</option>\r\n    </val-select>\r\n</ng-template>"]}
@@ -3045,7 +3045,10 @@ class FormSelectComponent extends BaseFormControl {
3045
3045
  }
3046
3046
  }
3047
3047
  detatchPreviousAndRetatchNext(doStuff) {
3048
- this.Form.removeControl(this.validationControl);
3048
+ if (this.validationControl)
3049
+ this.Form.removeControl(this.validationControl);
3050
+ else
3051
+ console.log("Nothing to detatch");
3049
3052
  setTimeout(() => {
3050
3053
  doStuff(() => {
3051
3054
  if (this.validationControl)