@esfaenza/forms-and-validations 11.2.63 → 11.2.66

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.
Files changed (45) hide show
  1. package/bundles/esfaenza-forms-and-validations.umd.js +310 -523
  2. package/bundles/esfaenza-forms-and-validations.umd.js.map +1 -1
  3. package/esfaenza-forms-and-validations.d.ts +9 -9
  4. package/esfaenza-forms-and-validations.metadata.json +1 -1
  5. package/esm2015/esfaenza-forms-and-validations.js +10 -10
  6. package/esm2015/lib/forms/base-form-control.js +61 -118
  7. package/esm2015/lib/forms/form-adaptive/form-adaptive.component.js +49 -65
  8. package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.js +20 -46
  9. package/esm2015/lib/forms/form-checkbox/form-checkbox.component.js +15 -14
  10. package/esm2015/lib/forms/form-date/form-date.component.js +19 -20
  11. package/esm2015/lib/forms/form-datetime/form-datetime.component.js +18 -17
  12. package/esm2015/lib/forms/form-empty/form-empty.component.js +4 -10
  13. package/esm2015/lib/forms/form-error/form-error.component.js +6 -16
  14. package/esm2015/lib/forms/form-file/form-file.component.js +15 -29
  15. package/esm2015/lib/forms/form-info/form-info.component.js +6 -16
  16. package/esm2015/lib/forms/form-input/form-input.component.js +21 -35
  17. package/esm2015/lib/forms/form-multiselect/form-multiselect.component.js +17 -35
  18. package/esm2015/lib/forms/form-select/form-select.component.js +29 -33
  19. package/esm2015/lib/forms/form-template/form-template.component.js +10 -28
  20. package/esm2015/lib/forms/form-textarea/form-textarea.component.js +15 -17
  21. package/esm2015/lib/forms/form-time/form-time.component.js +17 -34
  22. package/esm2015/lib/forms-and-validations.module.js +3 -2
  23. package/esm2015/lib/models/FormsAndValidationsModuleConfig.js +1 -1
  24. package/esm2015/lib/tokens.js +5 -7
  25. package/fesm2015/esfaenza-forms-and-validations.js +300 -515
  26. package/fesm2015/esfaenza-forms-and-validations.js.map +1 -1
  27. package/lib/forms/base-form-control.d.ts +56 -130
  28. package/lib/forms/form-adaptive/form-adaptive.component.d.ts +25 -72
  29. package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +13 -41
  30. package/lib/forms/form-checkbox/form-checkbox.component.d.ts +8 -12
  31. package/lib/forms/form-date/form-date.component.d.ts +9 -15
  32. package/lib/forms/form-datetime/form-datetime.component.d.ts +8 -12
  33. package/lib/forms/form-empty/form-empty.component.d.ts +3 -9
  34. package/lib/forms/form-error/form-error.component.d.ts +5 -15
  35. package/lib/forms/form-file/form-file.component.d.ts +9 -27
  36. package/lib/forms/form-info/form-info.component.d.ts +5 -15
  37. package/lib/forms/form-input/form-input.component.d.ts +14 -36
  38. package/lib/forms/form-multiselect/form-multiselect.component.d.ts +10 -30
  39. package/lib/forms/form-select/form-select.component.d.ts +11 -24
  40. package/lib/forms/form-template/form-template.component.d.ts +9 -27
  41. package/lib/forms/form-textarea/form-textarea.component.d.ts +7 -15
  42. package/lib/forms/form-time/form-time.component.d.ts +10 -30
  43. package/lib/models/FormsAndValidationsModuleConfig.d.ts +6 -8
  44. package/lib/tokens.d.ts +4 -6
  45. package/package.json +1 -1
@@ -4,25 +4,17 @@ import { NG_VALIDATORS, NgControl } from "@angular/forms";
4
4
  // Configurazioni
5
5
  import { LocalizationService } from "@esfaenza/localizations";
6
6
  import { AccessControlService, ComponentContext } from '@esfaenza/access-control';
7
- import { ACO_CUSTOMKEY } from '../../tokens';
7
+ import { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';
8
8
  // Applicazione
9
9
  import { BaseFormControl } from "../base-form-control";
10
10
  import { FormSelectComponentLoc } from "./form-select.component.loc";
11
- /**
12
- * Componente che permette di selezionare un valore da una lista di valori disponibili
13
- */
11
+ /** Componente che permette di selezionare un valore da una lista di valori disponibili */
14
12
  export class FormSelectComponent extends BaseFormControl {
15
- /**
16
- * Costruttore
17
- *
18
- * @ignore
19
- */
20
- constructor(cdr, lc, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY) {
21
- super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY);
13
+ /** @ignore Costruttore */
14
+ constructor(cdr, lc, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE) {
15
+ super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);
22
16
  this.lc = lc;
23
- /**
24
- * Permette di specificare il testo della Label flottante material-style
25
- */
17
+ /** Permette di specificare il testo della Label flottante material-style */
26
18
  this.SelectLabel = "";
27
19
  /**
28
20
  * Permette al componente di considerare questo valore come "valore placeholder"
@@ -30,9 +22,7 @@ export class FormSelectComponent extends BaseFormControl {
30
22
  * Si consiglia di mantenere il default
31
23
  */
32
24
  this.PlaceholderValue = '';
33
- /**
34
- * Override del placeholder per select requried
35
- */
25
+ /** Override del placeholder per select requried */
36
26
  this.RequiredPlaceholder = null;
37
27
  /**
38
28
  * Permette al componente di considerare questo valore come "valore vuoto"
@@ -40,14 +30,10 @@ export class FormSelectComponent extends BaseFormControl {
40
30
  * Si consiglia di mantenere il default
41
31
  */
42
32
  this.EmptyFieldValue = '-2';
43
- /**
44
- * Se **true** rimuove il simbolino di validazione (croce rossa o tick verde)
45
- */
33
+ /** Se **true** rimuove il simbolino di validazione (croce rossa o tick verde) */
46
34
  this.ShowValidationSymbol = true;
47
35
  }
48
- /**
49
- * @ignore
50
- */
36
+ /** @ignore */
51
37
  ngOnChanges(changes) {
52
38
  let newSource = changes["Source"];
53
39
  if (!newSource)
@@ -92,30 +78,39 @@ export class FormSelectComponent extends BaseFormControl {
92
78
  this.cdr.markForCheck();
93
79
  }
94
80
  }
81
+ /** @ignore */
95
82
  detatchPreviousAndRetatchNext(doStuff) {
96
- this.Form.removeControl(this.validationControl);
83
+ if (this.validationControl && this.Form)
84
+ this.Form.removeControl(this.validationControl);
97
85
  setTimeout(() => {
98
86
  doStuff(() => {
99
- if (this.validationControl)
87
+ if (this.validationControl && this.Form)
100
88
  this.Form.addControl(this.validationControl);
101
- else if (this.validationControl) {
89
+ else if (this.validationControl && this.Form) {
102
90
  this.Form.addControl(this.validationControl);
103
91
  }
104
- else
92
+ else if (!this.validationControl && this.Form) {
93
+ // Questo messaggio ha senso solo se almeno il form esiste... se non esiste sticazzi insomma...
105
94
  console.error(`Impossibile aggiungere il componente di validaazione per ${this.GeneratedName}, le validazioni potrebbero funzionare in maniera erratica`);
95
+ }
106
96
  });
107
97
  });
108
98
  }
109
- /**
110
- * @ignore
111
- */
99
+ /** @ignore */
100
+ writeValue(obj) {
101
+ var _a;
102
+ if (this.BoundSource && this.BoundSource.length > 0)
103
+ this.EvaluatedModel = (_a = this.BoundSource.find(t => t.id == obj)) === null || _a === void 0 ? void 0 : _a.description;
104
+ super.writeValue(obj);
105
+ }
106
+ /** @ignore */
112
107
  onNotNullValueSet() { }
113
108
  }
114
109
  FormSelectComponent.decorators = [
115
110
  { type: Component, args: [{
116
111
  selector: "form-select",
117
112
  providers: [{ provide: LocalizationService, useClass: FormSelectComponentLoc }],
118
- template: "<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\u00E9 una select una volta creata non riesce pi\u00F9 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>",
113
+ template: "<ng-container *ngIf=\"!FormLayout\">\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</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\" [class.app-strong]=\"DisplayMode\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}:</label>\r\n <div class=\"col-md-{{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<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\u00E9 una select una volta creata non riesce pi\u00F9 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>",
119
114
  changeDetection: ChangeDetectionStrategy.OnPush
120
115
  },] }
121
116
  ];
@@ -126,7 +121,8 @@ FormSelectComponent.ctorParameters = () => [
126
121
  { type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_VALIDATORS,] }] },
127
122
  { type: AccessControlService, decorators: [{ type: Optional }] },
128
123
  { type: ComponentContext, decorators: [{ type: Optional }] },
129
- { type: String, decorators: [{ type: Optional }, { type: Inject, args: [ACO_CUSTOMKEY,] }] }
124
+ { type: String, decorators: [{ type: Optional }, { type: Inject, args: [ACO_CUSTOMKEY,] }] },
125
+ { type: Boolean, decorators: [{ type: Optional }, { type: Inject, args: [FAV_DEBUG_MODE,] }] }
130
126
  ];
131
127
  FormSelectComponent.propDecorators = {
132
128
  SelectLabel: [{ type: Input }],
@@ -135,4 +131,4 @@ FormSelectComponent.propDecorators = {
135
131
  EmptyFieldValue: [{ type: Input }],
136
132
  ShowValidationSymbol: [{ type: Input }]
137
133
  };
138
- //# 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"],"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}"]}
134
+ //# 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"],"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, FAV_DEBUG_MODE } 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/** Componente che permette di selezionare un valore da una lista di valori disponibili */\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    /** Permette di specificare il testo della Label flottante material-style */\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    /** Override del placeholder per select requried */\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    /** Se **true** rimuove il simbolino di validazione (croce rossa o tick verde) */\r\n    @Input() ShowValidationSymbol: boolean = true;\r\n\r\n    /** @ignore Costruttore  */\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, @Optional() @Inject(FAV_DEBUG_MODE) FAV_DEBUG_MODE : boolean) {\r\n        super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);\r\n    }\r\n\r\n    /** @ignore */\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    /** @ignore */\r\n    private detatchPreviousAndRetatchNext(doStuff: Function) {\r\n        if(this.validationControl && this.Form)\r\n            this.Form.removeControl(this.validationControl);\r\n\r\n        setTimeout(() => {\r\n            doStuff(() => {\r\n                if (this.validationControl && this.Form)\r\n                    this.Form.addControl(this.validationControl);\r\n                else\r\n                    if (this.validationControl && this.Form) {\r\n                        this.Form.addControl(this.validationControl);\r\n                    }\r\n                    else if (!this.validationControl && this.Form) {\r\n                        // Questo messaggio ha senso solo se almeno il form esiste... se non esiste sticazzi insomma...\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    writeValue(obj: any): void {\r\n        if (this.BoundSource && this.BoundSource.length > 0)\r\n            this.EvaluatedModel = this.BoundSource.find(t => t.id == obj)?.description;\r\n\r\n        super.writeValue(obj);\r\n    }\r\n\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\r\n}"]}
@@ -6,42 +6,24 @@ import { ChangeDetectionStrategy, Component, Input } from "@angular/core";
6
6
  */
7
7
  export class FormTemplateComponent {
8
8
  constructor() {
9
- /**
10
- * Indica se l'input è obbligatorio o no
11
- */
9
+ /** Indica se l'input è obbligatorio o no */
12
10
  this.Required = false;
13
- /**
14
- * Mostra un testo a sinistra dell'input, **FormLayout** permettendo
15
- */
11
+ /** Mostra un testo a sinistra dell'input, **FormLayout** permettendo */
16
12
  this.Label = "";
17
- /**
18
- * Eventuali classi extra da applicare alla Label, di default c'è solo un leggero margin top
19
- */
13
+ /** Eventuali classi extra da applicare alla Label, di default c'è solo un leggero margin top */
20
14
  this.LabelClass = "m-t-5";
21
- /**
22
- * Utilizza o meno il Layout di un form (Label con input di fianco), se false mostra solo l'input
23
- */
15
+ /** Utilizza o meno il Layout di un form (Label con input di fianco), se false mostra solo l'input */
24
16
  this.FormLayout = true;
25
- /**
26
- * col-md-X per la label
27
- */
17
+ /** col-md-X per la label */
28
18
  this.LabelColWidth = 4;
29
- /**
30
- * col-md-X per l'input
31
- */
19
+ /** col-md-X per l'input */
32
20
  this.InputColWidth = 8;
33
- /**
34
- * Indica se è l'ultimo componente di un form (serve per rimuovere il margine finale)
35
- */
21
+ /** Indica se è l'ultimo componente di un form (serve per rimuovere il margine finale) */
36
22
  this.Last = false;
37
- /**
38
- * Classe extra per il form-group in cui viene wrappato l'input
39
- */
23
+ /** Classe extra per il form-group in cui viene wrappato l'input */
40
24
  this.FormGroupClass = "";
41
25
  }
42
- /**
43
- * Permette di settare in una volta solo gli input LabelColWidth e InputColWidth, basta scriverlo con la sintassi "X Y"
44
- */
26
+ /** Permette di settare in una volta solo gli input LabelColWidth e InputColWidth, basta scriverlo con la sintassi "X Y" */
45
27
  set LabelInputRatio(input) {
46
28
  var ratio = input.split(/\s/);
47
29
  this.LabelColWidth = parseInt(ratio[0]);
@@ -66,4 +48,4 @@ FormTemplateComponent.propDecorators = {
66
48
  FormGroupClass: [{ type: Input }],
67
49
  LabelInputRatio: [{ type: Input }]
68
50
  };
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS10ZW1wbGF0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi9mb3Jtcy9mb3JtLXRlbXBsYXRlL2Zvcm0tdGVtcGxhdGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxRTs7O0dBR0c7QUFNSCxNQUFNLE9BQU8scUJBQXFCO0lBTGxDO1FBT0k7O1dBRUc7UUFDTSxhQUFRLEdBQVksS0FBSyxDQUFDO1FBRW5DOztXQUVHO1FBQ00sVUFBSyxHQUFXLEVBQUUsQ0FBQztRQUU1Qjs7V0FFRztRQUNNLGVBQVUsR0FBVyxPQUFPLENBQUM7UUFFdEM7O1dBRUc7UUFDTSxlQUFVLEdBQVksSUFBSSxDQUFDO1FBRXBDOztXQUVHO1FBQ00sa0JBQWEsR0FBVyxDQUFDLENBQUM7UUFFbkM7O1dBRUc7UUFDTSxrQkFBYSxHQUFXLENBQUMsQ0FBQztRQUVuQzs7V0FFRztRQUNNLFNBQUksR0FBWSxLQUFLLENBQUM7UUFFL0I7O1dBRUc7UUFDTSxtQkFBYyxHQUFXLEVBQUUsQ0FBQztJQVV6QyxDQUFDO0lBUkc7O09BRUc7SUFDSCxJQUFhLGVBQWUsQ0FBQyxLQUFhO1FBQ3RDLElBQUksS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLGFBQWEsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEMsSUFBSSxDQUFDLGFBQWEsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDNUMsQ0FBQzs7O1lBdERKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsZUFBZTtnQkFDekIsaWZBQTJDO2dCQUMzQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTthQUNsRDs7O3VCQU1JLEtBQUs7b0JBS0wsS0FBSzt5QkFLTCxLQUFLO3lCQUtMLEtBQUs7NEJBS0wsS0FBSzs0QkFLTCxLQUFLO21CQUtMLEtBQUs7NkJBS0wsS0FBSzs4QkFLTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQW5ndWxhclxyXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vKipcclxuICogQ29tcG9uZW50ZSBkYSB1dGlsaXp6YXJlIHF1YW5kbyBsJ2ltcGxlbWVudGF6aW9uZSBkZWxsJ2lucHV0IG5vbiDDqCBkaXNwb25pYmlsZSBuZWxsYSBsaWJyZXJpYSwgIFxyXG4gKiBmb3JuaXNjZSBsYSBzdHJ1dHR1cmEgc3RhbmRhcmQgZGkgdW4gZm9ybS1jb21wb25lbnQgbWEgbCdpbnB1dCB2ZXJvIGUgcHJvcHJpbyB2aWVuZSBwcm9pZXR0YXRvIGRhbGwnZXN0ZXJub1xyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJmb3JtLXRlbXBsYXRlXCIsXHJcbiAgICB0ZW1wbGF0ZVVybDogXCJmb3JtLXRlbXBsYXRlLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRm9ybVRlbXBsYXRlQ29tcG9uZW50IHtcclxuXHJcbiAgICAvKipcclxuICAgICAqIEluZGljYSBzZSBsJ2lucHV0IMOoIG9iYmxpZ2F0b3JpbyBvIG5vXHJcbiAgICAgKi9cclxuICAgIEBJbnB1dCgpIFJlcXVpcmVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBNb3N0cmEgdW4gdGVzdG8gYSBzaW5pc3RyYSBkZWxsJ2lucHV0LCAqKkZvcm1MYXlvdXQqKiBwZXJtZXR0ZW5kb1xyXG4gICAgICovXHJcbiAgICBASW5wdXQoKSBMYWJlbDogc3RyaW5nID0gXCJcIjtcclxuXHJcbiAgICAvKipcclxuICAgICAqIEV2ZW50dWFsaSBjbGFzc2kgZXh0cmEgZGEgYXBwbGljYXJlIGFsbGEgTGFiZWwsIGRpIGRlZmF1bHQgYyfDqCBzb2xvIHVuIGxlZ2dlcm8gbWFyZ2luIHRvcFxyXG4gICAgICovXHJcbiAgICBASW5wdXQoKSBMYWJlbENsYXNzOiBzdHJpbmcgPSBcIm0tdC01XCI7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBVdGlsaXp6YSBvIG1lbm8gaWwgTGF5b3V0IGRpIHVuIGZvcm0gKExhYmVsIGNvbiBpbnB1dCBkaSBmaWFuY28pLCBzZSBmYWxzZSBtb3N0cmEgc29sbyBsJ2lucHV0XHJcbiAgICAgKi9cclxuICAgIEBJbnB1dCgpIEZvcm1MYXlvdXQ6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogY29sLW1kLVggcGVyIGxhIGxhYmVsXHJcbiAgICAgKi9cclxuICAgIEBJbnB1dCgpIExhYmVsQ29sV2lkdGg6IG51bWJlciA9IDQ7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBjb2wtbWQtWCBwZXIgbCdpbnB1dFxyXG4gICAgICovXHJcbiAgICBASW5wdXQoKSBJbnB1dENvbFdpZHRoOiBudW1iZXIgPSA4O1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogSW5kaWNhIHNlIMOoIGwndWx0aW1vIGNvbXBvbmVudGUgZGkgdW4gZm9ybSAoc2VydmUgcGVyIHJpbXVvdmVyZSBpbCBtYXJnaW5lIGZpbmFsZSlcclxuICAgICAqL1xyXG4gICAgQElucHV0KCkgTGFzdDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogQ2xhc3NlIGV4dHJhIHBlciBpbCBmb3JtLWdyb3VwIGluIGN1aSB2aWVuZSB3cmFwcGF0byBsJ2lucHV0XHJcbiAgICAgKi9cclxuICAgIEBJbnB1dCgpIEZvcm1Hcm91cENsYXNzOiBzdHJpbmcgPSBcIlwiO1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogUGVybWV0dGUgZGkgc2V0dGFyZSBpbiB1bmEgdm9sdGEgc29sbyBnbGkgaW5wdXQgTGFiZWxDb2xXaWR0aCBlIElucHV0Q29sV2lkdGgsIGJhc3RhIHNjcml2ZXJsbyBjb24gbGEgc2ludGFzc2kgXCJYIFlcIlxyXG4gICAgICovXHJcbiAgICBASW5wdXQoKSBzZXQgTGFiZWxJbnB1dFJhdGlvKGlucHV0OiBzdHJpbmcpIHtcclxuICAgICAgICB2YXIgcmF0aW8gPSBpbnB1dC5zcGxpdCgvXFxzLyk7XHJcbiAgICAgICAgdGhpcy5MYWJlbENvbFdpZHRoID0gcGFyc2VJbnQocmF0aW9bMF0pO1xyXG4gICAgICAgIHRoaXMuSW5wdXRDb2xXaWR0aCA9IHBhcnNlSW50KHJhdGlvWzFdKTtcclxuICAgIH1cclxufSJdfQ==
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS10ZW1wbGF0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi9mb3Jtcy9mb3JtLXRlbXBsYXRlL2Zvcm0tdGVtcGxhdGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxRTs7O0dBR0c7QUFNSCxNQUFNLE9BQU8scUJBQXFCO0lBTGxDO1FBT0ksNENBQTRDO1FBQ25DLGFBQVEsR0FBWSxLQUFLLENBQUM7UUFFbkMsd0VBQXdFO1FBQy9ELFVBQUssR0FBVyxFQUFFLENBQUM7UUFFNUIsZ0dBQWdHO1FBQ3ZGLGVBQVUsR0FBVyxPQUFPLENBQUM7UUFFdEMscUdBQXFHO1FBQzVGLGVBQVUsR0FBWSxJQUFJLENBQUM7UUFFcEMsNEJBQTRCO1FBQ25CLGtCQUFhLEdBQVcsQ0FBQyxDQUFDO1FBRW5DLDJCQUEyQjtRQUNsQixrQkFBYSxHQUFXLENBQUMsQ0FBQztRQUVuQyx5RkFBeUY7UUFDaEYsU0FBSSxHQUFZLEtBQUssQ0FBQztRQUUvQixtRUFBbUU7UUFDMUQsbUJBQWMsR0FBVyxFQUFFLENBQUM7SUFRekMsQ0FBQztJQU5HLDJIQUEySDtJQUMzSCxJQUFhLGVBQWUsQ0FBQyxLQUFhO1FBQ3RDLElBQUksS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLGFBQWEsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEMsSUFBSSxDQUFDLGFBQWEsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDNUMsQ0FBQzs7O1lBcENKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsZUFBZTtnQkFDekIsaWZBQTJDO2dCQUMzQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTthQUNsRDs7O3VCQUlJLEtBQUs7b0JBR0wsS0FBSzt5QkFHTCxLQUFLO3lCQUdMLEtBQUs7NEJBR0wsS0FBSzs0QkFHTCxLQUFLO21CQUdMLEtBQUs7NkJBR0wsS0FBSzs4QkFHTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQW5ndWxhclxyXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vKipcclxuICogQ29tcG9uZW50ZSBkYSB1dGlsaXp6YXJlIHF1YW5kbyBsJ2ltcGxlbWVudGF6aW9uZSBkZWxsJ2lucHV0IG5vbiDDqCBkaXNwb25pYmlsZSBuZWxsYSBsaWJyZXJpYSwgIFxyXG4gKiBmb3JuaXNjZSBsYSBzdHJ1dHR1cmEgc3RhbmRhcmQgZGkgdW4gZm9ybS1jb21wb25lbnQgbWEgbCdpbnB1dCB2ZXJvIGUgcHJvcHJpbyB2aWVuZSBwcm9pZXR0YXRvIGRhbGwnZXN0ZXJub1xyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJmb3JtLXRlbXBsYXRlXCIsXHJcbiAgICB0ZW1wbGF0ZVVybDogXCJmb3JtLXRlbXBsYXRlLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRm9ybVRlbXBsYXRlQ29tcG9uZW50IHtcclxuXHJcbiAgICAvKiogSW5kaWNhIHNlIGwnaW5wdXQgw6ggb2JibGlnYXRvcmlvIG8gbm8gKi9cclxuICAgIEBJbnB1dCgpIFJlcXVpcmVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gICAgLyoqIE1vc3RyYSB1biB0ZXN0byBhIHNpbmlzdHJhIGRlbGwnaW5wdXQsICoqRm9ybUxheW91dCoqIHBlcm1ldHRlbmRvICovXHJcbiAgICBASW5wdXQoKSBMYWJlbDogc3RyaW5nID0gXCJcIjtcclxuXHJcbiAgICAvKiogRXZlbnR1YWxpIGNsYXNzaSBleHRyYSBkYSBhcHBsaWNhcmUgYWxsYSBMYWJlbCwgZGkgZGVmYXVsdCBjJ8OoIHNvbG8gdW4gbGVnZ2VybyBtYXJnaW4gdG9wICovXHJcbiAgICBASW5wdXQoKSBMYWJlbENsYXNzOiBzdHJpbmcgPSBcIm0tdC01XCI7XHJcblxyXG4gICAgLyoqIFV0aWxpenphIG8gbWVubyBpbCBMYXlvdXQgZGkgdW4gZm9ybSAoTGFiZWwgY29uIGlucHV0IGRpIGZpYW5jbyksIHNlIGZhbHNlIG1vc3RyYSBzb2xvIGwnaW5wdXQgKi9cclxuICAgIEBJbnB1dCgpIEZvcm1MYXlvdXQ6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICAgIC8qKiBjb2wtbWQtWCBwZXIgbGEgbGFiZWwgKi9cclxuICAgIEBJbnB1dCgpIExhYmVsQ29sV2lkdGg6IG51bWJlciA9IDQ7XHJcblxyXG4gICAgLyoqIGNvbC1tZC1YIHBlciBsJ2lucHV0ICovXHJcbiAgICBASW5wdXQoKSBJbnB1dENvbFdpZHRoOiBudW1iZXIgPSA4O1xyXG5cclxuICAgIC8qKiBJbmRpY2Egc2Ugw6ggbCd1bHRpbW8gY29tcG9uZW50ZSBkaSB1biBmb3JtIChzZXJ2ZSBwZXIgcmltdW92ZXJlIGlsIG1hcmdpbmUgZmluYWxlKSAqL1xyXG4gICAgQElucHV0KCkgTGFzdDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAgIC8qKiBDbGFzc2UgZXh0cmEgcGVyIGlsIGZvcm0tZ3JvdXAgaW4gY3VpIHZpZW5lIHdyYXBwYXRvIGwnaW5wdXQgKi9cclxuICAgIEBJbnB1dCgpIEZvcm1Hcm91cENsYXNzOiBzdHJpbmcgPSBcIlwiO1xyXG5cclxuICAgIC8qKiBQZXJtZXR0ZSBkaSBzZXR0YXJlIGluIHVuYSB2b2x0YSBzb2xvIGdsaSBpbnB1dCBMYWJlbENvbFdpZHRoIGUgSW5wdXRDb2xXaWR0aCwgYmFzdGEgc2NyaXZlcmxvIGNvbiBsYSBzaW50YXNzaSBcIlggWVwiICovXHJcbiAgICBASW5wdXQoKSBzZXQgTGFiZWxJbnB1dFJhdGlvKGlucHV0OiBzdHJpbmcpIHtcclxuICAgICAgICB2YXIgcmF0aW8gPSBpbnB1dC5zcGxpdCgvXFxzLyk7XHJcbiAgICAgICAgdGhpcy5MYWJlbENvbFdpZHRoID0gcGFyc2VJbnQocmF0aW9bMF0pO1xyXG4gICAgICAgIHRoaXMuSW5wdXRDb2xXaWR0aCA9IHBhcnNlSW50KHJhdGlvWzFdKTtcclxuICAgIH1cclxufSJdfQ==
@@ -5,28 +5,25 @@ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, O
5
5
  import { BaseFormControl } from "../base-form-control";
6
6
  // Configurazioni
7
7
  import { AccessControlService, ComponentContext } from '@esfaenza/access-control';
8
- import { ACO_CUSTOMKEY } from '../../tokens';
9
- /**
10
- * Componente che presenta una casella di testo tipicamente utilizzata per scrivere delle note o del log breve
11
- */
8
+ import { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';
9
+ /** Componente che presenta una casella di testo tipicamente utilizzata per scrivere delle note o del log breve */
12
10
  export class FormTextareaComponent extends BaseFormControl {
13
- /**
14
- * Costruttore
15
- *
16
- * @ignore
17
- */
18
- constructor(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY) {
19
- super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY);
11
+ /** @ignore Costruttore */
12
+ constructor(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE) {
13
+ super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);
20
14
  }
21
- /**
22
- * @ignore
23
- */
15
+ /** @ignore */
16
+ writeValue(obj) {
17
+ this.EvaluatedModel = (obj === null || obj === void 0 ? void 0 : obj.toString()) || "";
18
+ super.writeValue(obj);
19
+ }
20
+ /** @ignore */
24
21
  onNotNullValueSet() { }
25
22
  }
26
23
  FormTextareaComponent.decorators = [
27
24
  { type: Component, args: [{
28
25
  selector: "form-textarea",
29
- template: "<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 <val-textarea \r\n [FocusSubject]=\"FocusSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n [noValidate]=\"!Validation\" \r\n [submitted]=\"Form?.submitted\" \r\n [forceInvalid]=\"ForcedError\"\r\n [id]=\"GeneratedName\" \r\n [rows]=\"Rows\" \r\n [readonly]=\"Readonly\"\r\n [class]=\"Readonly ? 'app-bg-lightgrey app-no-resize' : 'app-no-resize'\" \r\n [(ngModel)]=\"Model\"\r\n name=\"{{GeneratedName}}\" \r\n autocomplete=\"off\" \r\n [placeholder]=\"Placeholder\"\r\n [validationFailed]=\"FailedValidationMessage\" \r\n #validationControl=\"ngModel\" \r\n (inputChange)=\"changed();\"\r\n (inputFocus)=\"focused($event);\"\r\n (inputFinalized)=\"finalized()\"\r\n >\r\n </val-textarea>\r\n</ng-template>",
26
+ template: "<ng-container *ngIf=\"!FormLayout\">\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</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\" [class.app-strong]=\"DisplayMode\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}:</label>\r\n <div class=\"col-md-{{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<ng-template #controlTemplate>\r\n <val-textarea \r\n [FocusSubject]=\"FocusSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n [noValidate]=\"!Validation\" \r\n [submitted]=\"Form?.submitted\" \r\n [forceInvalid]=\"ForcedError\"\r\n [id]=\"GeneratedName\" \r\n [rows]=\"Rows\" \r\n [readonly]=\"Readonly\"\r\n [class]=\"Readonly ? 'app-bg-lightgrey app-no-resize' : 'app-no-resize'\" \r\n [(ngModel)]=\"Model\"\r\n name=\"{{GeneratedName}}\" \r\n autocomplete=\"off\" \r\n [placeholder]=\"Placeholder\"\r\n [validationFailed]=\"FailedValidationMessage\" \r\n #validationControl=\"ngModel\" \r\n (inputChange)=\"changed();\"\r\n (inputFocus)=\"focused($event);\"\r\n (inputFinalized)=\"finalized()\"\r\n >\r\n </val-textarea>\r\n</ng-template>",
30
27
  changeDetection: ChangeDetectionStrategy.OnPush
31
28
  },] }
32
29
  ];
@@ -36,9 +33,10 @@ FormTextareaComponent.ctorParameters = () => [
36
33
  { type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_VALIDATORS,] }] },
37
34
  { type: AccessControlService, decorators: [{ type: Optional }] },
38
35
  { type: ComponentContext, decorators: [{ type: Optional }] },
39
- { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [ACO_CUSTOMKEY,] }] }
36
+ { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [ACO_CUSTOMKEY,] }] },
37
+ { type: Boolean, decorators: [{ type: Optional }, { type: Inject, args: [FAV_DEBUG_MODE,] }] }
40
38
  ];
41
39
  FormTextareaComponent.propDecorators = {
42
40
  Rows: [{ type: Input }]
43
41
  };
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS10ZXh0YXJlYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi9mb3Jtcy9mb3JtLXRleHRhcmVhL2Zvcm0tdGV4dGFyZWEuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQXdCLGFBQWEsRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNoRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVySCxlQUFlO0FBQ2YsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXZELGlCQUFpQjtBQUNqQixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNsRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRTdDOztHQUVHO0FBTUgsTUFBTSxPQUFPLHFCQUFzQixTQUFRLGVBQWU7SUFPdEQ7Ozs7T0FJRztJQUNILFlBQVksR0FBc0IsRUFBc0IsU0FBb0IsRUFBcUMsV0FBdUIsRUFBYyxFQUF3QixFQUFjLFVBQTRCLEVBQW9DLGFBQWE7UUFDclEsS0FBSyxDQUFDLEdBQUcsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEVBQUUsRUFBRSxVQUFVLEVBQUMsYUFBYSxDQUFDLENBQUM7SUFDckUsQ0FBQztJQUVEOztPQUVHO0lBQ0gsaUJBQWlCLEtBQVcsQ0FBQzs7O1lBeEJoQyxTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLGVBQWU7Z0JBQ3pCLGk2Q0FBMkM7Z0JBQzNDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2FBQ2xEOzs7WUFoQmlDLGlCQUFpQjtZQURMLFNBQVMsdUJBOEJkLFFBQVEsWUFBSSxJQUFJO1lBQXlFLEtBQUssdUJBQXBELFFBQVEsWUFBSSxNQUFNLFNBQUMsYUFBYTtZQXZCMUcsb0JBQW9CLHVCQXVCa0gsUUFBUTtZQXZCeEgsZ0JBQWdCLHVCQXVCc0ksUUFBUTs0Q0FBa0MsUUFBUSxZQUFHLE1BQU0sU0FBQyxhQUFhOzs7bUJBUHpQLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBBbmd1bGFyXHJcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxJREFUT1JTLCBOZ0NvbnRyb2wgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEluamVjdCwgSW5wdXQsIE9wdGlvbmFsLCBTZWxmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuXHJcbi8vIEFwcGxpY2F6aW9uZVxyXG5pbXBvcnQgeyBCYXNlRm9ybUNvbnRyb2wgfSBmcm9tIFwiLi4vYmFzZS1mb3JtLWNvbnRyb2xcIjtcclxuXHJcbi8vIENvbmZpZ3VyYXppb25pXHJcbmltcG9ydCB7IEFjY2Vzc0NvbnRyb2xTZXJ2aWNlLCBDb21wb25lbnRDb250ZXh0IH0gZnJvbSAnQGVzZmFlbnphL2FjY2Vzcy1jb250cm9sJztcclxuaW1wb3J0IHsgQUNPX0NVU1RPTUtFWSB9IGZyb20gJy4uLy4uL3Rva2Vucyc7XHJcblxyXG4vKipcclxuICogQ29tcG9uZW50ZSBjaGUgcHJlc2VudGEgdW5hIGNhc2VsbGEgZGkgdGVzdG8gdGlwaWNhbWVudGUgdXRpbGl6emF0YSBwZXIgc2NyaXZlcmUgZGVsbGUgbm90ZSBvIGRlbCBsb2cgYnJldmVcclxuICovXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6IFwiZm9ybS10ZXh0YXJlYVwiLFxyXG4gICAgdGVtcGxhdGVVcmw6IFwiZm9ybS10ZXh0YXJlYS5jb21wb25lbnQuaHRtbFwiLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIEZvcm1UZXh0YXJlYUNvbXBvbmVudCBleHRlbmRzIEJhc2VGb3JtQ29udHJvbCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcclxuXHJcbiAgICAvKipcclxuICAgICAqIE51bWVybyBkaSByaWdoZSBkYSB2aXN1YWxpenphcmUgZGkgZGVmYXVsdFxyXG4gICAgICovXHJcbiAgICBASW5wdXQoKSBSb3dzOiBudW1iZXI7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBDb3N0cnV0dG9yZSBcclxuICAgICAqIFxyXG4gICAgICogQGlnbm9yZVxyXG4gICAgICovXHJcbiAgICBjb25zdHJ1Y3RvcihjZHI6IENoYW5nZURldGVjdG9yUmVmLCBAT3B0aW9uYWwoKSBAU2VsZigpIG5nQ29udHJvbDogTmdDb250cm9sLCBAT3B0aW9uYWwoKSBASW5qZWN0KE5HX1ZBTElEQVRPUlMpIF92YWxpZGF0b3JzOiBBcnJheTxhbnk+LCBAT3B0aW9uYWwoKSBhYzogQWNjZXNzQ29udHJvbFNlcnZpY2UsIEBPcHRpb25hbCgpIEFwcENvbnRleHQ6IENvbXBvbmVudENvbnRleHQsIEBPcHRpb25hbCgpQEluamVjdChBQ09fQ1VTVE9NS0VZKSBBQ09fQ1VTVE9NS0VZKSB7XHJcbiAgICAgICAgc3VwZXIoY2RyLCBuZ0NvbnRyb2wsIF92YWxpZGF0b3JzLCBhYywgQXBwQ29udGV4dCxBQ09fQ1VTVE9NS0VZKTtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIEBpZ25vcmVcclxuICAgICAqL1xyXG4gICAgb25Ob3ROdWxsVmFsdWVTZXQoKTogdm9pZCB7IH1cclxufSJdfQ==
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS10ZXh0YXJlYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi9mb3Jtcy9mb3JtLXRleHRhcmVhL2Zvcm0tdGV4dGFyZWEuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQXdCLGFBQWEsRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNoRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVySCxlQUFlO0FBQ2YsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXZELGlCQUFpQjtBQUNqQixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNsRixPQUFPLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUU3RCxrSEFBa0g7QUFNbEgsTUFBTSxPQUFPLHFCQUFzQixTQUFRLGVBQWU7SUFLdEQsMkJBQTJCO0lBQzNCLFlBQVksR0FBc0IsRUFBc0IsU0FBb0IsRUFBcUMsV0FBdUIsRUFBYyxFQUF3QixFQUFjLFVBQTRCLEVBQW9DLGFBQWEsRUFBc0MsY0FBd0I7UUFDblUsS0FBSyxDQUFDLEdBQUcsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEVBQUUsRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQ3RGLENBQUM7SUFFRCxjQUFjO0lBQ2QsVUFBVSxDQUFDLEdBQVE7UUFDZixJQUFJLENBQUMsY0FBYyxHQUFHLENBQUEsR0FBRyxhQUFILEdBQUcsdUJBQUgsR0FBRyxDQUFFLFFBQVEsT0FBTSxFQUFFLENBQUM7UUFDNUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBRUQsY0FBYztJQUNkLGlCQUFpQixLQUFXLENBQUM7OztZQXRCaEMsU0FBUyxTQUFDO2dCQUNQLFFBQVEsRUFBRSxlQUFlO2dCQUN6QixvbkVBQTJDO2dCQUMzQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTthQUNsRDs7O1lBZGlDLGlCQUFpQjtZQURMLFNBQVMsdUJBc0JkLFFBQVEsWUFBSSxJQUFJO1lBQXlFLEtBQUssdUJBQXBELFFBQVEsWUFBSSxNQUFNLFNBQUMsYUFBYTtZQWYxRyxvQkFBb0IsdUJBZWtILFFBQVE7WUFmeEgsZ0JBQWdCLHVCQWVzSSxRQUFROzRDQUFrQyxRQUFRLFlBQUcsTUFBTSxTQUFDLGFBQWE7MENBQWtCLFFBQVEsWUFBSSxNQUFNLFNBQUMsY0FBYzs7O21CQUg1UyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQW5ndWxhclxyXG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMSURBVE9SUywgTmdDb250cm9sIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbmplY3QsIElucHV0LCBPcHRpb25hbCwgU2VsZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vLyBBcHBsaWNhemlvbmVcclxuaW1wb3J0IHsgQmFzZUZvcm1Db250cm9sIH0gZnJvbSBcIi4uL2Jhc2UtZm9ybS1jb250cm9sXCI7XHJcblxyXG4vLyBDb25maWd1cmF6aW9uaVxyXG5pbXBvcnQgeyBBY2Nlc3NDb250cm9sU2VydmljZSwgQ29tcG9uZW50Q29udGV4dCB9IGZyb20gJ0Blc2ZhZW56YS9hY2Nlc3MtY29udHJvbCc7XHJcbmltcG9ydCB7IEFDT19DVVNUT01LRVksIEZBVl9ERUJVR19NT0RFIH0gZnJvbSAnLi4vLi4vdG9rZW5zJztcclxuXHJcbi8qKiBDb21wb25lbnRlIGNoZSBwcmVzZW50YSB1bmEgY2FzZWxsYSBkaSB0ZXN0byB0aXBpY2FtZW50ZSB1dGlsaXp6YXRhIHBlciBzY3JpdmVyZSBkZWxsZSBub3RlIG8gZGVsIGxvZyBicmV2ZSAqL1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiBcImZvcm0tdGV4dGFyZWFcIixcclxuICAgIHRlbXBsYXRlVXJsOiBcImZvcm0tdGV4dGFyZWEuY29tcG9uZW50Lmh0bWxcIixcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGb3JtVGV4dGFyZWFDb21wb25lbnQgZXh0ZW5kcyBCYXNlRm9ybUNvbnRyb2wgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XHJcblxyXG4gICAgLyoqIE51bWVybyBkaSByaWdoZSBkYSB2aXN1YWxpenphcmUgZGkgZGVmYXVsdCAqL1xyXG4gICAgQElucHV0KCkgUm93czogbnVtYmVyO1xyXG5cclxuICAgIC8qKiBAaWdub3JlIENvc3RydXR0b3JlICAqL1xyXG4gICAgY29uc3RydWN0b3IoY2RyOiBDaGFuZ2VEZXRlY3RvclJlZiwgQE9wdGlvbmFsKCkgQFNlbGYoKSBuZ0NvbnRyb2w6IE5nQ29udHJvbCwgQE9wdGlvbmFsKCkgQEluamVjdChOR19WQUxJREFUT1JTKSBfdmFsaWRhdG9yczogQXJyYXk8YW55PiwgQE9wdGlvbmFsKCkgYWM6IEFjY2Vzc0NvbnRyb2xTZXJ2aWNlLCBAT3B0aW9uYWwoKSBBcHBDb250ZXh0OiBDb21wb25lbnRDb250ZXh0LCBAT3B0aW9uYWwoKUBJbmplY3QoQUNPX0NVU1RPTUtFWSkgQUNPX0NVU1RPTUtFWSwgQE9wdGlvbmFsKCkgQEluamVjdChGQVZfREVCVUdfTU9ERSkgRkFWX0RFQlVHX01PREUgOiBib29sZWFuKSB7XHJcbiAgICAgICAgc3VwZXIoY2RyLCBuZ0NvbnRyb2wsIF92YWxpZGF0b3JzLCBhYywgQXBwQ29udGV4dCwgQUNPX0NVU1RPTUtFWSwgRkFWX0RFQlVHX01PREUpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKiBAaWdub3JlICovXHJcbiAgICB3cml0ZVZhbHVlKG9iajogYW55KTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5FdmFsdWF0ZWRNb2RlbCA9IG9iaj8udG9TdHJpbmcoKSB8fCBcIlwiO1xyXG4gICAgICAgIHN1cGVyLndyaXRlVmFsdWUob2JqKTtcclxuICAgIH1cclxuXHJcbiAgICAvKiogQGlnbm9yZSAqL1xyXG4gICAgb25Ob3ROdWxsVmFsdWVTZXQoKTogdm9pZCB7IH1cclxufSJdfQ==
@@ -7,35 +7,21 @@ import { AccessControlService, ComponentContext } from '@esfaenza/access-control
7
7
  // Applicazione
8
8
  import { BaseFormControl } from "../base-form-control";
9
9
  import { ACO_CUSTOMKEY } from '../../tokens';
10
- /**
11
- * Componente che identifica la selezione di un orario
12
- */
10
+ /** Componente che identifica la selezione di un orario */
13
11
  export class FormTimeComponent extends BaseFormControl {
14
- /**
15
- * @ignore
16
- */
12
+ /** @ignore */
17
13
  constructor(cdr, dateAdapter, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY) {
18
14
  super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, true);
19
15
  this.dateAdapter = dateAdapter;
20
- /**
21
- * Mostra o meno gli spinner dove cliccare per aumentare/diminuire le componenti dell'orologio (ore, minuti e secondi)
22
- */
16
+ /** Mostra o meno gli spinner dove cliccare per aumentare/diminuire le componenti dell'orologio (ore, minuti e secondi) */
23
17
  this.ShowSpinners = false;
24
- /**
25
- * Imposta lo step (minimo avanzamento) per la cella "ore"
26
- */
18
+ /** Imposta lo step (minimo avanzamento) per la cella "ore" */
27
19
  this.StepHour = 1;
28
- /**
29
- * Imposta lo step (minimo avanzamento) per la cella "minuti"
30
- */
20
+ /** Imposta lo step (minimo avanzamento) per la cella "minuti" */
31
21
  this.StepMinute = 1;
32
- /**
33
- * Imposta lo step (minimo avanzamento) per la cella "secondi"
34
- */
22
+ /** Imposta lo step (minimo avanzamento) per la cella "secondi" */
35
23
  this.StepSecond = 5;
36
- /**
37
- * Indica se mostrare i secondi o meno
38
- */
24
+ /** Indica se mostrare i secondi o meno */
39
25
  this.ShowSeconds = false;
40
26
  /**
41
27
  * Indica il formato da utilizzare sia in Input che in Output
@@ -48,28 +34,27 @@ export class FormTimeComponent extends BaseFormControl {
48
34
  */
49
35
  this.InOutFormat = 'timestring';
50
36
  }
51
- /**
52
- * @ignore Override per gestire input in ingresso
53
- */
37
+ /** @ignore Override per gestire input in ingresso */
54
38
  writeValue(obj) {
55
- const [hours, minutes, seconds] = (obj || "0:0:0").split(":");
56
39
  //Qualsiasi cosa mi arrivi devo ricondurla a un dayjs
57
40
  switch (this.InOutFormat) {
58
41
  case 'date':
59
42
  obj = dayjs(obj);
43
+ this.EvaluatedModel = obj.format('HH:mm:ss');
60
44
  break;
61
45
  case 'timestring':
62
- obj = dayjs().hour(hours !== null && hours !== void 0 ? hours : 0).minute(minutes !== null && minutes !== void 0 ? minutes : 0).second(seconds !== null && seconds !== void 0 ? seconds : 0);
46
+ const [hours, minutes, seconds] = (obj || "00:00:00").split(":");
47
+ obj = dayjs().hour(parseInt(hours !== null && hours !== void 0 ? hours : 0)).minute(parseInt(minutes !== null && minutes !== void 0 ? minutes : 0)).second(parseInt(seconds !== null && seconds !== void 0 ? seconds : 0));
48
+ this.EvaluatedModel = `${hours || '00'}:${minutes || '00'}:${seconds || '00'}`;
63
49
  break;
64
50
  case 'dayjs':
65
51
  obj = obj;
52
+ this.EvaluatedModel = obj.format('HH:mm:ss');
66
53
  break;
67
54
  }
68
55
  super.writeValue(obj);
69
56
  }
70
- /**
71
- * @ignore Override per gestire input in uscita
72
- */
57
+ /** @ignore Override per gestire input in uscita */
73
58
  changed() {
74
59
  var toEmit = this.dateAdapter.clone(this.Model);
75
60
  switch (this.InOutFormat) {
@@ -85,15 +70,13 @@ export class FormTimeComponent extends BaseFormControl {
85
70
  }
86
71
  super.changed(toEmit);
87
72
  }
88
- /**
89
- * @ignore
90
- */
73
+ /** @ignore */
91
74
  onNotNullValueSet() { }
92
75
  }
93
76
  FormTimeComponent.decorators = [
94
77
  { type: Component, args: [{
95
78
  selector: "form-time",
96
- template: "<ng-container *ngIf=\"!FormLayout\">\r\n <ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout\" 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}} m-t-5\">\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 <ngx-mat-timepicker name=\"val-time\" #elementRef #baseInput=\"ngModel\" [(ngModel)]=\"Model\" [disabled]=\"Readonly\"\r\n [showSpinners]=\"ShowSpinners\" [stepHour]=\"StepHour\" [stepMinute]=\"StepMinute\" [stepSecond]=\"StepSecond\"\r\n [showSeconds]=\"ShowSeconds\" (ngModelChange)=\"changed()\" #validationControl=\"ngModel\">\r\n </ngx-mat-timepicker>\r\n\r\n</ng-template>",
79
+ template: "<ng-container *ngIf=\"!FormLayout\">\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</ng-container>\r\n\r\n<div *ngIf=\"FormLayout\" class=\"form-group row {{FormGroupClass}}\" [class.app-margin-bottom-0]=\"Last\">\r\n <label class=\"col-md-{{LabelColWidth}} m-t-5\" [class.app-strong]=\"DisplayMode\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}:</label>\r\n <div class=\"col-md-{{InputColWidth}} m-t-5\">\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<ng-template #controlTemplate>\r\n\r\n <ngx-mat-timepicker name=\"val-time\" #elementRef #baseInput=\"ngModel\" [(ngModel)]=\"Model\" [disabled]=\"Readonly\"\r\n [showSpinners]=\"ShowSpinners\" [stepHour]=\"StepHour\" [stepMinute]=\"StepMinute\" [stepSecond]=\"StepSecond\"\r\n [showSeconds]=\"ShowSeconds\" (ngModelChange)=\"changed()\" #validationControl=\"ngModel\">\r\n </ngx-mat-timepicker>\r\n\r\n</ng-template>",
97
80
  changeDetection: ChangeDetectionStrategy.OnPush
98
81
  },] }
99
82
  ];
@@ -114,4 +97,4 @@ FormTimeComponent.propDecorators = {
114
97
  ShowSeconds: [{ type: Input }],
115
98
  InOutFormat: [{ type: Input }]
116
99
  };
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-time.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-time/form-time.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\nimport { Component, Inject, Optional, Self, Host, Input, ChangeDetectorRef, ChangeDetectionStrategy } from \"@angular/core\";\r\n\r\nimport { NgxMatDateAdapter } from \"@angular-material-components/datetime-picker\";\r\n\r\n// Esfaenza\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { ACO_CUSTOMKEY } from '../../tokens';\r\n\r\n/**\r\n * Dichiarazione della variabile globale dayjs. L'onere di \"crearla\" è affidato all'applicazione che utilizza questa libreria, \r\n * che dovrà importare lo script globale di dayjs nella CLI\r\n */\r\ndeclare var dayjs: any;\r\n\r\n/**\r\n * Componente che identifica la selezione di un orario\r\n */\r\n@Component({\r\n    selector: \"form-time\",\r\n    templateUrl: \"form-time.component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormTimeComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /**\r\n     * Mostra o meno gli spinner dove cliccare per aumentare/diminuire le componenti dell'orologio (ore, minuti e secondi)\r\n     */\r\n    @Input() ShowSpinners: boolean = false;\r\n\r\n    /**\r\n     * Imposta lo step (minimo avanzamento) per la cella \"ore\"\r\n     */\r\n    @Input() StepHour: number = 1;\r\n\r\n    /**\r\n     * Imposta lo step (minimo avanzamento) per la cella \"minuti\"\r\n     */\r\n    @Input() StepMinute: number = 1;\r\n\r\n    /**\r\n     * Imposta lo step (minimo avanzamento) per la cella \"secondi\"\r\n     */\r\n    @Input() StepSecond: number = 5;\r\n\r\n    /**\r\n     * Indica se mostrare i secondi o meno\r\n     */\r\n    @Input() ShowSeconds: boolean = false;\r\n\r\n    /**\r\n     * Indica il formato da utilizzare sia in Input che in Output\r\n     * \r\n     * 1. Se date vengono utilizzate le Date di Javascript\r\n     * \r\n     * 2. Se timestring vengono utilizzate stringhe del tipo '00:00:00'\r\n     * \r\n     * 3. Se dayjs viene utilizzato, appunto, dayjs\r\n     */\r\n    @Input() InOutFormat: 'date' | 'timestring' | 'dayjs' = 'timestring';\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    constructor(cdr: ChangeDetectorRef, private dateAdapter: NgxMatDateAdapter<any>, @Optional() @Self() ngControl: NgControl, @Optional() @Host() @Inject(NG_VALIDATORS) _validators: Array<any>, ac: AccessControlService, @Optional() AppContext: ComponentContext, @Optional() @Inject(ACO_CUSTOMKEY) ACO_CUSTOMKEY: string) {\r\n        super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, true);\r\n    }\r\n\r\n    /**\r\n     * @ignore Override per gestire input in ingresso\r\n     */\r\n    writeValue(obj: any): void {\r\n\r\n        const [hours, minutes, seconds] = (obj || \"0:0:0\").split(\":\");\r\n\r\n        //Qualsiasi cosa mi arrivi devo ricondurla a un dayjs\r\n        switch (this.InOutFormat) {\r\n            case 'date':\r\n                obj = dayjs(obj);\r\n                break;\r\n            case 'timestring':\r\n                obj = dayjs().hour(hours ?? 0).minute(minutes ?? 0).second(seconds ?? 0);\r\n                break;\r\n            case 'dayjs':\r\n                obj = obj;\r\n                break;\r\n        }\r\n\r\n        super.writeValue(obj);\r\n    }\r\n\r\n    /**\r\n     * @ignore Override per gestire input in uscita\r\n     */\r\n    changed() {\r\n        var toEmit = this.dateAdapter.clone(this.Model);\r\n\r\n        switch (this.InOutFormat) {\r\n            case 'date':\r\n                toEmit = toEmit.toDate();\r\n                break;\r\n            case 'timestring':\r\n                toEmit = toEmit.format(\"HH:mm\" + (this.ShowSeconds ? \":ss\" : \"\"));\r\n                break;\r\n            case 'dayjs':\r\n                toEmit = toEmit;\r\n                break;\r\n        }\r\n\r\n        super.changed(toEmit);\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    onNotNullValueSet(): void { }\r\n}"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-time.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-time/form-time.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\nimport { Component, Inject, Optional, Self, Host, Input, ChangeDetectorRef, ChangeDetectionStrategy } from \"@angular/core\";\r\n\r\nimport { NgxMatDateAdapter } from \"@angular-material-components/datetime-picker\";\r\n\r\n// Esfaenza\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { ACO_CUSTOMKEY } from '../../tokens';\r\n\r\n/**\r\n * Dichiarazione della variabile globale dayjs. L'onere di \"crearla\" è affidato all'applicazione che utilizza questa libreria, \r\n * che dovrà importare lo script globale di dayjs nella CLI\r\n */\r\ndeclare var dayjs: any;\r\n\r\n/** Componente che identifica la selezione di un orario */\r\n@Component({\r\n    selector: \"form-time\",\r\n    templateUrl: \"form-time.component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormTimeComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /** Mostra o meno gli spinner dove cliccare per aumentare/diminuire le componenti dell'orologio (ore, minuti e secondi) */\r\n    @Input() ShowSpinners: boolean = false;\r\n\r\n    /** Imposta lo step (minimo avanzamento) per la cella \"ore\" */\r\n    @Input() StepHour: number = 1;\r\n\r\n    /** Imposta lo step (minimo avanzamento) per la cella \"minuti\" */\r\n    @Input() StepMinute: number = 1;\r\n\r\n    /** Imposta lo step (minimo avanzamento) per la cella \"secondi\" */\r\n    @Input() StepSecond: number = 5;\r\n\r\n    /** Indica se mostrare i secondi o meno */\r\n    @Input() ShowSeconds: boolean = false;\r\n\r\n    /**\r\n     * Indica il formato da utilizzare sia in Input che in Output\r\n     * \r\n     * 1. Se date vengono utilizzate le Date di Javascript\r\n     * \r\n     * 2. Se timestring vengono utilizzate stringhe del tipo '00:00:00'\r\n     * \r\n     * 3. Se dayjs viene utilizzato, appunto, dayjs\r\n     */\r\n    @Input() InOutFormat: 'date' | 'timestring' | 'dayjs' = 'timestring';\r\n\r\n    /** @ignore */\r\n    constructor(cdr: ChangeDetectorRef, private dateAdapter: NgxMatDateAdapter<any>, @Optional() @Self() ngControl: NgControl, @Optional() @Host() @Inject(NG_VALIDATORS) _validators: Array<any>, ac: AccessControlService, @Optional() AppContext: ComponentContext, @Optional() @Inject(ACO_CUSTOMKEY) ACO_CUSTOMKEY: string) {\r\n        super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, true);\r\n    }\r\n\r\n    /** @ignore Override per gestire input in ingresso */\r\n    writeValue(obj: any): void {\r\n\r\n        //Qualsiasi cosa mi arrivi devo ricondurla a un dayjs\r\n        switch (this.InOutFormat) {\r\n            case 'date':\r\n                obj = dayjs(obj);\r\n                this.EvaluatedModel = obj.format('HH:mm:ss');\r\n                break;\r\n            case 'timestring':\r\n                const [hours, minutes, seconds] = (obj || \"00:00:00\").split(\":\");\r\n                obj = dayjs().hour(parseInt(hours ?? 0)).minute(parseInt(minutes ?? 0)).second(parseInt(seconds ?? 0));\r\n                this.EvaluatedModel = `${hours || '00'}:${minutes || '00'}:${seconds || '00'}`;\r\n                break;\r\n            case 'dayjs':\r\n                obj = obj;\r\n                this.EvaluatedModel = obj.format('HH:mm:ss');\r\n                break;\r\n        }\r\n\r\n        super.writeValue(obj);\r\n    }\r\n\r\n    /** @ignore Override per gestire input in uscita */\r\n    changed() {\r\n        var toEmit = this.dateAdapter.clone(this.Model);\r\n\r\n        switch (this.InOutFormat) {\r\n            case 'date':\r\n                toEmit = toEmit.toDate();\r\n                break;\r\n            case 'timestring':\r\n                toEmit = toEmit.format(\"HH:mm\" + (this.ShowSeconds ? \":ss\" : \"\"));\r\n                break;\r\n            case 'dayjs':\r\n                toEmit = toEmit;\r\n                break;\r\n        }\r\n\r\n        super.changed(toEmit);\r\n    }\r\n\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\r\n}"]}
@@ -13,7 +13,7 @@ import { CurrencyMaskModule } from '@esfaenza/ngx-currency-mask';
13
13
  import { AngularMultiSelectModule } from "angular2-multiselect-dropdown";
14
14
  import { NgxMatDateAdapter, NgxMatDatetimePickerModule, NGX_MAT_DATE_FORMATS, NgxMatTimepickerModule } from '@angular-material-components/datetime-picker';
15
15
  import { TooltipModule } from 'ngx-bootstrap/tooltip';
16
- import { FAV_LOCALE, ACO_CUSTOMKEY } from './tokens';
16
+ import { FAV_LOCALE, ACO_CUSTOMKEY, FAV_DEBUG_MODE } from './tokens';
17
17
  import { CustomRequiredDirective } from './validations/customValidators/CustomRequiredDirective';
18
18
  import { NgxExpandedDayJsDateAdapter } from './models/dayjs-adapter/dayjs-date-adapter';
19
19
  // Validations
@@ -110,6 +110,7 @@ export class FormsAndValidationsModule {
110
110
  ngModule: FormsAndValidationsModule,
111
111
  providers: [
112
112
  { provide: FAV_LOCALE, useValue: (config === null || config === void 0 ? void 0 : config.locale) || 'it-IT' },
113
+ { provide: FAV_DEBUG_MODE, useValue: (config === null || config === void 0 ? void 0 : config.debugMode) != null ? config === null || config === void 0 ? void 0 : config.debugMode : false },
113
114
  { provide: ACO_CUSTOMKEY, useValue: (config === null || config === void 0 ? void 0 : config.acocustom) || null },
114
115
  { provide: NGX_MAT_DATE_FORMATS, useValue: formats_long },
115
116
  { provide: NgxMatDateAdapter, useClass: NgxExpandedDayJsDateAdapter },
@@ -124,4 +125,4 @@ FormsAndValidationsModule.decorators = [
124
125
  exports: [...MODULES_TO_EXPORT, ...COMPONENTS]
125
126
  },] }
126
127
  ];
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forms-and-validations.module.js","sourceRoot":"","sources":["../../../../projects/forms-and-validations/src/lib/forms-and-validations.module.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ModuleWithProviders, NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\r\nimport { MatInputModule } from \"@angular/material/input\";\r\n\r\n// Es\r\nimport { LocalizationModule } from \"@esfaenza/localizations\";\r\nimport { MatDayjsDateModule } from '@esfaenza/material-dayjs-adapter';\r\nimport { CurrencyMaskModule } from '@esfaenza/ngx-currency-mask';\r\n\r\n// Librerie / Modelli\r\nimport { AngularMultiSelectModule } from \"angular2-multiselect-dropdown\";\r\nimport { NgxMatDateAdapter, NgxMatDatetimePickerModule, NGX_MAT_DATE_FORMATS, NgxMatTimepickerModule } from '@angular-material-components/datetime-picker';\r\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\r\n\r\nimport { FAV_LOCALE, ACO_CUSTOMKEY } from './tokens';\r\nimport { FormsAndValidationsModuleConfig } from './models/FormsAndValidationsModuleConfig';\r\nimport { CustomRequiredDirective } from './validations/customValidators/CustomRequiredDirective';\r\nimport { NgxExpandedDayJsDateAdapter } from './models/dayjs-adapter/dayjs-date-adapter';\r\n\r\n// Validations\r\nimport { ValidationSelectComponent } from './validations/validation-select/validation-select.component';\r\nimport { ValidationDateComponent } from './validations/validation-date/validation-date.component';\r\nimport { ValidationCurrencyComponent } from './validations/validation-currency/validation-currency.component';\r\nimport { ValidationTextAreaComponent } from './validations/validation-text-area/validation-text-area.component';\r\nimport { ValidationInputComponent } from './validations/validation-input/validation-input.component';\r\nimport { ValidationDateTimeComponent } from './validations/validation-datetime/validation-datetime.component';\r\nimport { ValidationAutocompleteComponent } from './validations/validation-autocomplete/validation-autocomplete.component';\r\n\r\n// Forms\r\nimport { FormFileComponent } from './forms/form-file/form-file.component';\r\nimport { FormDateTimeComponent } from './forms/form-datetime/form-datetime.component';\r\nimport { FormAdaptiveComponent } from './forms/form-adaptive/form-adaptive.component';\r\nimport { FormEmptyComponent } from './forms/form-empty/form-empty.component';\r\nimport { FormTemplateComponent } from './forms/form-template/form-template.component';\r\nimport { FormErrorComponent } from './forms/form-error/form-error.component';\r\nimport { FormInfoComponent } from './forms/form-info/form-info.component';\r\nimport { FormCheckboxComponent } from './forms/form-checkbox/form-checkbox.component';\r\nimport { FormDateComponent } from './forms/form-date/form-date.component';\r\nimport { FormInputComponent } from './forms/form-input/form-input.component';\r\nimport { FormSelectComponent } from './forms/form-select/form-select.component';\r\nimport { FormMultiSelectComponent } from './forms/form-multiselect/form-multiselect.component';\r\nimport { FormTextareaComponent } from './forms/form-textarea/form-textarea.component';\r\nimport { FormAutocompleteComponent } from './forms/form-autocomplete/form-autocomplete.component';\r\nimport { FormTimeComponent } from './forms/form-time/form-time.component';\r\n\r\n/**\r\n * Formato in display (modalità lunga, con ore, minuti e secondi) delle date per tutti i componenti che utilizzino input data.\r\n * \r\n * Da convenzione è sempre quello italiano quindi viene cablato\r\n */\r\nconst formats_long = {\r\n  parse: { dateInput: 'DD/MM/YYYY HH:mm:ss' },\r\n  display: {\r\n    dateInput: 'DD/MM/YYYY HH:mm:ss',\r\n    monthYearLabel: 'MM YYYY',\r\n    dateA11yLabel: 'DD/MM/YYYY HH:mm:ss',\r\n    monthYearA11yLabel: 'MM YYYY',\r\n  }\r\n};\r\n\r\n/**\r\n * Componenti Dichiarati ed esportati dalla libreria\r\n */\r\nconst COMPONENTS = [\r\n  ValidationInputComponent,\r\n  ValidationSelectComponent,\r\n  ValidationDateComponent,\r\n  CustomRequiredDirective,\r\n  ValidationCurrencyComponent,\r\n  ValidationTextAreaComponent,\r\n  FormCheckboxComponent,\r\n  FormDateComponent,\r\n  FormEmptyComponent,\r\n  FormInputComponent,\r\n  FormSelectComponent,\r\n  FormTextareaComponent,\r\n  FormTemplateComponent,\r\n  FormErrorComponent,\r\n  FormInfoComponent,\r\n  FormAdaptiveComponent,\r\n  FormMultiSelectComponent,\r\n  FormFileComponent,\r\n  ValidationAutocompleteComponent,\r\n  FormAutocompleteComponent,\r\n  FormDateTimeComponent,\r\n  ValidationDateTimeComponent,\r\n  FormTimeComponent\r\n];\r\n\r\n/**\r\n * Moduli utilizzati solo dalla libreria\r\n */\r\nconst MODULES = [\r\n  CommonModule,\r\n  FormsModule,\r\n  LocalizationModule,\r\n  MatInputModule,\r\n  MatDatepickerModule,\r\n  MatDayjsDateModule,\r\n  TooltipModule,\r\n  CurrencyMaskModule,\r\n  MatAutocompleteModule,\r\n  NgxMatDatetimePickerModule,\r\n  NgxMatTimepickerModule\r\n];\r\n\r\n/**\r\n * Moduli utilizzati dalla libreria e che devono essere esposti all'esterno\r\n */\r\nconst MODULES_TO_EXPORT = [\r\n  AngularMultiSelectModule\r\n];\r\n\r\n@NgModule({\r\n  imports: [...MODULES, ...MODULES_TO_EXPORT],\r\n  declarations: [...COMPONENTS],\r\n  exports: [...MODULES_TO_EXPORT, ...COMPONENTS]\r\n})\r\nexport class FormsAndValidationsModule {\r\n  static forRoot(config?: FormsAndValidationsModuleConfig): ModuleWithProviders<FormsAndValidationsModule> {\r\n    return {\r\n      ngModule: FormsAndValidationsModule,\r\n      providers: [\r\n        { provide: FAV_LOCALE, useValue: config?.locale || 'it-IT' },\r\n        { provide: ACO_CUSTOMKEY, useValue: config?.acocustom || null },\r\n        { provide: NGX_MAT_DATE_FORMATS, useValue: formats_long },\r\n        { provide: NgxMatDateAdapter, useClass: NgxExpandedDayJsDateAdapter },\r\n      ]\r\n    };\r\n  }\r\n}"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forms-and-validations.module.js","sourceRoot":"","sources":["../../../../projects/forms-and-validations/src/lib/forms-and-validations.module.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ModuleWithProviders, NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\r\nimport { MatInputModule } from \"@angular/material/input\";\r\n\r\n// Es\r\nimport { LocalizationModule } from \"@esfaenza/localizations\";\r\nimport { MatDayjsDateModule } from '@esfaenza/material-dayjs-adapter';\r\nimport { CurrencyMaskModule } from '@esfaenza/ngx-currency-mask';\r\n\r\n// Librerie / Modelli\r\nimport { AngularMultiSelectModule } from \"angular2-multiselect-dropdown\";\r\nimport { NgxMatDateAdapter, NgxMatDatetimePickerModule, NGX_MAT_DATE_FORMATS, NgxMatTimepickerModule } from '@angular-material-components/datetime-picker';\r\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\r\n\r\nimport { FAV_LOCALE, ACO_CUSTOMKEY, FAV_DEBUG_MODE } from './tokens';\r\nimport { FormsAndValidationsModuleConfig } from './models/FormsAndValidationsModuleConfig';\r\nimport { CustomRequiredDirective } from './validations/customValidators/CustomRequiredDirective';\r\nimport { NgxExpandedDayJsDateAdapter } from './models/dayjs-adapter/dayjs-date-adapter';\r\n\r\n// Validations\r\nimport { ValidationSelectComponent } from './validations/validation-select/validation-select.component';\r\nimport { ValidationDateComponent } from './validations/validation-date/validation-date.component';\r\nimport { ValidationCurrencyComponent } from './validations/validation-currency/validation-currency.component';\r\nimport { ValidationTextAreaComponent } from './validations/validation-text-area/validation-text-area.component';\r\nimport { ValidationInputComponent } from './validations/validation-input/validation-input.component';\r\nimport { ValidationDateTimeComponent } from './validations/validation-datetime/validation-datetime.component';\r\nimport { ValidationAutocompleteComponent } from './validations/validation-autocomplete/validation-autocomplete.component';\r\n\r\n// Forms\r\nimport { FormFileComponent } from './forms/form-file/form-file.component';\r\nimport { FormDateTimeComponent } from './forms/form-datetime/form-datetime.component';\r\nimport { FormAdaptiveComponent } from './forms/form-adaptive/form-adaptive.component';\r\nimport { FormEmptyComponent } from './forms/form-empty/form-empty.component';\r\nimport { FormTemplateComponent } from './forms/form-template/form-template.component';\r\nimport { FormErrorComponent } from './forms/form-error/form-error.component';\r\nimport { FormInfoComponent } from './forms/form-info/form-info.component';\r\nimport { FormCheckboxComponent } from './forms/form-checkbox/form-checkbox.component';\r\nimport { FormDateComponent } from './forms/form-date/form-date.component';\r\nimport { FormInputComponent } from './forms/form-input/form-input.component';\r\nimport { FormSelectComponent } from './forms/form-select/form-select.component';\r\nimport { FormMultiSelectComponent } from './forms/form-multiselect/form-multiselect.component';\r\nimport { FormTextareaComponent } from './forms/form-textarea/form-textarea.component';\r\nimport { FormAutocompleteComponent } from './forms/form-autocomplete/form-autocomplete.component';\r\nimport { FormTimeComponent } from './forms/form-time/form-time.component';\r\n\r\n/**\r\n * Formato in display (modalità lunga, con ore, minuti e secondi) delle date per tutti i componenti che utilizzino input data.\r\n * \r\n * Da convenzione è sempre quello italiano quindi viene cablato\r\n */\r\nconst formats_long = {\r\n  parse: { dateInput: 'DD/MM/YYYY HH:mm:ss' },\r\n  display: {\r\n    dateInput: 'DD/MM/YYYY HH:mm:ss',\r\n    monthYearLabel: 'MM YYYY',\r\n    dateA11yLabel: 'DD/MM/YYYY HH:mm:ss',\r\n    monthYearA11yLabel: 'MM YYYY',\r\n  }\r\n};\r\n\r\n/**\r\n * Componenti Dichiarati ed esportati dalla libreria\r\n */\r\nconst COMPONENTS = [\r\n  ValidationInputComponent,\r\n  ValidationSelectComponent,\r\n  ValidationDateComponent,\r\n  CustomRequiredDirective,\r\n  ValidationCurrencyComponent,\r\n  ValidationTextAreaComponent,\r\n  FormCheckboxComponent,\r\n  FormDateComponent,\r\n  FormEmptyComponent,\r\n  FormInputComponent,\r\n  FormSelectComponent,\r\n  FormTextareaComponent,\r\n  FormTemplateComponent,\r\n  FormErrorComponent,\r\n  FormInfoComponent,\r\n  FormAdaptiveComponent,\r\n  FormMultiSelectComponent,\r\n  FormFileComponent,\r\n  ValidationAutocompleteComponent,\r\n  FormAutocompleteComponent,\r\n  FormDateTimeComponent,\r\n  ValidationDateTimeComponent,\r\n  FormTimeComponent\r\n];\r\n\r\n/**\r\n * Moduli utilizzati solo dalla libreria\r\n */\r\nconst MODULES = [\r\n  CommonModule,\r\n  FormsModule,\r\n  LocalizationModule,\r\n  MatInputModule,\r\n  MatDatepickerModule,\r\n  MatDayjsDateModule,\r\n  TooltipModule,\r\n  CurrencyMaskModule,\r\n  MatAutocompleteModule,\r\n  NgxMatDatetimePickerModule,\r\n  NgxMatTimepickerModule\r\n];\r\n\r\n/**\r\n * Moduli utilizzati dalla libreria e che devono essere esposti all'esterno\r\n */\r\nconst MODULES_TO_EXPORT = [\r\n  AngularMultiSelectModule\r\n];\r\n\r\n@NgModule({\r\n  imports: [...MODULES, ...MODULES_TO_EXPORT],\r\n  declarations: [...COMPONENTS],\r\n  exports: [...MODULES_TO_EXPORT, ...COMPONENTS]\r\n})\r\nexport class FormsAndValidationsModule {\r\n  static forRoot(config?: FormsAndValidationsModuleConfig): ModuleWithProviders<FormsAndValidationsModule> {\r\n    return {\r\n      ngModule: FormsAndValidationsModule,\r\n      providers: [\r\n        { provide: FAV_LOCALE, useValue: config?.locale || 'it-IT' },\r\n        { provide: FAV_DEBUG_MODE, useValue: config?.debugMode != null ? config?.debugMode : false },\r\n        { provide: ACO_CUSTOMKEY, useValue: config?.acocustom || null },\r\n        { provide: NGX_MAT_DATE_FORMATS, useValue: formats_long },\r\n        { provide: NgxMatDateAdapter, useClass: NgxExpandedDayJsDateAdapter },\r\n      ]\r\n    };\r\n  }\r\n}"]}
@@ -3,4 +3,4 @@
3
3
  */
4
4
  export class FormsAndValidationsModuleConfig {
5
5
  }
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRm9ybXNBbmRWYWxpZGF0aW9uc01vZHVsZUNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Zvcm1zLWFuZC12YWxpZGF0aW9ucy9zcmMvbGliL21vZGVscy9Gb3Jtc0FuZFZhbGlkYXRpb25zTW9kdWxlQ29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxPQUFPLCtCQUErQjtDQVczQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBDbGFzc2UgZGkgY29uZmlndXJhemlvbmUgZGVsIG1vZHVsb1xyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEZvcm1zQW5kVmFsaWRhdGlvbnNNb2R1bGVDb25maWcge1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogTG9jYWxlIGRlbCBtb2R1bG8uIFNvbm8gc3VwcG9ydGF0aSBzb2xvICdpdC1JVCcgZWQgJ2VuLVVTJ1xyXG4gICAgICovXHJcbiAgICBsb2NhbGU6IHN0cmluZztcclxuXHJcbiAgICAvKipcclxuICAgICAqIENoaWF2ZSBkZWkgcGVybWVzc2kgQ3VzdG9tIGluIGN1aSBjaSBzb25vIGxlIGluZm9ybWF6aW9uaSBkaSBPd25lcnNoaXBcclxuICAgICAqL1xyXG4gICAgYWNvY3VzdG9tOiBzdHJpbmc7XHJcbn0iXX0=
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRm9ybXNBbmRWYWxpZGF0aW9uc01vZHVsZUNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Zvcm1zLWFuZC12YWxpZGF0aW9ucy9zcmMvbGliL21vZGVscy9Gb3Jtc0FuZFZhbGlkYXRpb25zTW9kdWxlQ29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxPQUFPLCtCQUErQjtDQVUzQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBDbGFzc2UgZGkgY29uZmlndXJhemlvbmUgZGVsIG1vZHVsb1xyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEZvcm1zQW5kVmFsaWRhdGlvbnNNb2R1bGVDb25maWcge1xyXG5cclxuICAgIC8qKiBMb2NhbGUgZGVsIG1vZHVsby4gU29ubyBzdXBwb3J0YXRpIHNvbG8gJ2l0LUlUJyBlZCAnZW4tVVMnLCBkZWZhdWx0IGl0LUlUICovXHJcbiAgICBsb2NhbGU/OiBzdHJpbmc7XHJcblxyXG4gICAgLyoqIENoaWF2ZSBkZWkgcGVybWVzc2kgQ3VzdG9tIGluIGN1aSBjaSBzb25vIGxlIGluZm9ybWF6aW9uaSBkaSBPd25lcnNoaXAgKi9cclxuICAgIGFjb2N1c3RvbT86IHN0cmluZztcclxuXHJcbiAgICAvKiogQWJpbGl0YSBvIG1lbm8gbGEgbW9kYWxpdMOgIGRpIGRlYnVnICovXHJcbiAgICBkZWJ1Z01vZGU/OiBib29sZWFuO1xyXG59Il19
@@ -1,10 +1,8 @@
1
1
  import { InjectionToken } from '@angular/core';
2
- /**
3
- * Token che indica la lingua da utilizzare, sono supportate "it-IT" ed "en-US"
4
- */
2
+ /** Token che indica la lingua da utilizzare, sono supportate "it-IT" ed "en-US" */
5
3
  export const FAV_LOCALE = new InjectionToken('FAV_LOCALE');
6
- /**
7
- * Chiave che indica il prefisso dei Contesti Applicativi per permettere l'abilitazione/disabilitazione di input in maniera contestuale
8
- */
4
+ /** Chiave che indica il prefisso dei Contesti Applicativi per permettere l'abilitazione/disabilitazione di input in maniera contestuale */
9
5
  export const ACO_CUSTOMKEY = new InjectionToken('ACO_CUSTOMKEY');
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybXMtYW5kLXZhbGlkYXRpb25zL3NyYy9saWIvdG9rZW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0M7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQTJCLElBQUksY0FBYyxDQUFTLFlBQVksQ0FBQyxDQUFDO0FBRTNGOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUEyQixJQUFJLGNBQWMsQ0FBUyxlQUFlLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogVG9rZW4gY2hlIGluZGljYSBsYSBsaW5ndWEgZGEgdXRpbGl6emFyZSwgc29ubyBzdXBwb3J0YXRlIFwiaXQtSVRcIiBlZCBcImVuLVVTXCJcclxuICovXHJcbmV4cG9ydCBjb25zdCBGQVZfTE9DQUxFOiBJbmplY3Rpb25Ub2tlbjxzdHJpbmc+ID0gbmV3IEluamVjdGlvblRva2VuPHN0cmluZz4oJ0ZBVl9MT0NBTEUnKTtcclxuXHJcbi8qKlxyXG4gKiBDaGlhdmUgY2hlIGluZGljYSBpbCBwcmVmaXNzbyBkZWkgQ29udGVzdGkgQXBwbGljYXRpdmkgcGVyIHBlcm1ldHRlcmUgbCdhYmlsaXRhemlvbmUvZGlzYWJpbGl0YXppb25lIGRpIGlucHV0IGluIG1hbmllcmEgY29udGVzdHVhbGVcclxuICovXHJcbmV4cG9ydCBjb25zdCBBQ09fQ1VTVE9NS0VZOiBJbmplY3Rpb25Ub2tlbjxzdHJpbmc+ID0gbmV3IEluamVjdGlvblRva2VuPHN0cmluZz4oJ0FDT19DVVNUT01LRVknKTsiXX0=
6
+ /** Token che indica la lingua da utilizzare, sono supportate "it-IT" ed "en-US" */
7
+ export const FAV_DEBUG_MODE = new InjectionToken('FAV_DEBUG_MODE');
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybXMtYW5kLXZhbGlkYXRpb25zL3NyYy9saWIvdG9rZW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsbUZBQW1GO0FBQ25GLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBMkIsSUFBSSxjQUFjLENBQVMsWUFBWSxDQUFDLENBQUM7QUFFM0YsMklBQTJJO0FBQzNJLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBMkIsSUFBSSxjQUFjLENBQVMsZUFBZSxDQUFDLENBQUM7QUFFakcsbUZBQW1GO0FBQ25GLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBNEIsSUFBSSxjQUFjLENBQVUsZ0JBQWdCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKiogVG9rZW4gY2hlIGluZGljYSBsYSBsaW5ndWEgZGEgdXRpbGl6emFyZSwgc29ubyBzdXBwb3J0YXRlIFwiaXQtSVRcIiBlZCBcImVuLVVTXCIgKi9cclxuZXhwb3J0IGNvbnN0IEZBVl9MT0NBTEU6IEluamVjdGlvblRva2VuPHN0cmluZz4gPSBuZXcgSW5qZWN0aW9uVG9rZW48c3RyaW5nPignRkFWX0xPQ0FMRScpO1xyXG5cclxuLyoqIENoaWF2ZSBjaGUgaW5kaWNhIGlsIHByZWZpc3NvIGRlaSBDb250ZXN0aSBBcHBsaWNhdGl2aSBwZXIgcGVybWV0dGVyZSBsJ2FiaWxpdGF6aW9uZS9kaXNhYmlsaXRhemlvbmUgZGkgaW5wdXQgaW4gbWFuaWVyYSBjb250ZXN0dWFsZSAqL1xyXG5leHBvcnQgY29uc3QgQUNPX0NVU1RPTUtFWTogSW5qZWN0aW9uVG9rZW48c3RyaW5nPiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxzdHJpbmc+KCdBQ09fQ1VTVE9NS0VZJyk7XHJcblxyXG4vKiogVG9rZW4gY2hlIGluZGljYSBsYSBsaW5ndWEgZGEgdXRpbGl6emFyZSwgc29ubyBzdXBwb3J0YXRlIFwiaXQtSVRcIiBlZCBcImVuLVVTXCIgKi9cclxuZXhwb3J0IGNvbnN0IEZBVl9ERUJVR19NT0RFOiBJbmplY3Rpb25Ub2tlbjxib29sZWFuPiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxib29sZWFuPignRkFWX0RFQlVHX01PREUnKTsiXX0=