@esfaenza/forms-and-validations 18.2.1 → 19.2.1

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 (47) hide show
  1. package/fesm2022/esfaenza-forms-and-validations.mjs +153 -153
  2. package/fesm2022/esfaenza-forms-and-validations.mjs.map +1 -1
  3. package/lib/forms/base-form-control.d.ts +1 -1
  4. package/lib/forms/form-adaptive/form-adaptive.component.d.ts +2 -2
  5. package/lib/forms/form-time/form-time.component.d.ts +2 -2
  6. package/lib/validations/base-validation.d.ts +1 -1
  7. package/package.json +13 -15
  8. package/esm2022/esfaenza-forms-and-validations.mjs +0 -5
  9. package/esm2022/lib/forms/base-form-control.mjs +0 -558
  10. package/esm2022/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +0 -22
  11. package/esm2022/lib/forms/form-adaptive/form-adaptive.component.mjs +0 -420
  12. package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +0 -21
  13. package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.mjs +0 -289
  14. package/esm2022/lib/forms/form-checkbox/form-checkbox.component.mjs +0 -74
  15. package/esm2022/lib/forms/form-date/form-date.component.mjs +0 -69
  16. package/esm2022/lib/forms/form-datetime/form-datetime.component.mjs +0 -67
  17. package/esm2022/lib/forms/form-empty/form-empty.component.mjs +0 -30
  18. package/esm2022/lib/forms/form-error/form-error.component.mjs +0 -42
  19. package/esm2022/lib/forms/form-file/form-file.component.loc.mjs +0 -22
  20. package/esm2022/lib/forms/form-file/form-file.component.mjs +0 -175
  21. package/esm2022/lib/forms/form-info/form-info.component.mjs +0 -42
  22. package/esm2022/lib/forms/form-input/form-input.component.mjs +0 -83
  23. package/esm2022/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +0 -23
  24. package/esm2022/lib/forms/form-multiselect/form-multiselect.component.mjs +0 -163
  25. package/esm2022/lib/forms/form-select/form-select.component.loc.mjs +0 -21
  26. package/esm2022/lib/forms/form-select/form-select.component.mjs +0 -165
  27. package/esm2022/lib/forms/form-template/form-template.component.mjs +0 -77
  28. package/esm2022/lib/forms/form-textarea/form-textarea.component.mjs +0 -57
  29. package/esm2022/lib/forms/form-time/form-time.component.mjs +0 -115
  30. package/esm2022/lib/forms-and-validations.module.mjs +0 -213
  31. package/esm2022/lib/models/AppFile.mjs +0 -14
  32. package/esm2022/lib/models/ChangeEvent.mjs +0 -7
  33. package/esm2022/lib/models/FormsAndValidationsModuleConfig.mjs +0 -6
  34. package/esm2022/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +0 -89
  35. package/esm2022/lib/tokens.mjs +0 -8
  36. package/esm2022/lib/validations/base-validation.loc.mjs +0 -23
  37. package/esm2022/lib/validations/base-validation.mjs +0 -328
  38. package/esm2022/lib/validations/customValidators/CustomRequiredDirective.mjs +0 -41
  39. package/esm2022/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +0 -147
  40. package/esm2022/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +0 -240
  41. package/esm2022/lib/validations/validation-currency/validation-currency.component.mjs +0 -75
  42. package/esm2022/lib/validations/validation-date/validation-date.component.mjs +0 -183
  43. package/esm2022/lib/validations/validation-datetime/validation-datetime.component.mjs +0 -212
  44. package/esm2022/lib/validations/validation-input/validation-input.component.mjs +0 -222
  45. package/esm2022/lib/validations/validation-select/validation-select.component.mjs +0 -183
  46. package/esm2022/lib/validations/validation-text-area/validation-text-area.component.mjs +0 -78
  47. package/esm2022/public-api.mjs +0 -40
@@ -1,165 +0,0 @@
1
- // Angular
2
- import { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self } from "@angular/core";
3
- import { NG_VALIDATORS } from "@angular/forms";
4
- // Configurazioni
5
- import { LocalizationService } from "@esfaenza/localizations";
6
- import { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';
7
- // Applicazione
8
- import { BaseFormControl } from "../base-form-control";
9
- import { FormSelectComponentLoc } from "./form-select.component.loc";
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "@esfaenza/localizations";
12
- import * as i2 from "@angular/forms";
13
- import * as i3 from "@esfaenza/access-control";
14
- import * as i4 from "@angular/common";
15
- import * as i5 from "../../validations/validation-select/validation-select.component";
16
- /** Componente che permette di selezionare un valore da una lista di valori disponibili */
17
- export class FormSelectComponent extends BaseFormControl {
18
- /** @ignore Costruttore */
19
- constructor(cdr, lc, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE) {
20
- super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);
21
- this.lc = lc;
22
- /** Permette di specificare il testo della Label flottante material-style */
23
- this.SelectLabel = "";
24
- /**
25
- * Permette al componente di considerare questo valore come "valore placeholder"
26
- *
27
- * Si consiglia di mantenere il default
28
- */
29
- this.PlaceholderValue = '';
30
- /** Override del placeholder per select requried */
31
- this.RequiredPlaceholder = null;
32
- /**
33
- * Permette al componente di considerare questo valore come "valore vuoto"
34
- *
35
- * Si consiglia di mantenere il default
36
- */
37
- this.EmptyFieldValue = '-2000';
38
- /** Se **true** rimuove il simbolino di validazione (croce rossa o tick verde) */
39
- this.ShowValidationSymbol = true;
40
- /** Template per la visualizzazione delle opzioni */
41
- this.OptionTemplate = null;
42
- }
43
- /** @ignore */
44
- ngOnChanges(changes) {
45
- let newSource = changes["Source"];
46
- if (!newSource)
47
- return;
48
- let curr = newSource.currentValue;
49
- let prev = newSource.previousValue;
50
- // Se manca curr vuol dire che non ho un valore e posso ignorare (alla peggio deve arrivarmi un array vuoto)
51
- if (!curr)
52
- return;
53
- // Se manca prev vuol dire che è la prima assegnazione, lo considero un array vuoto e proseguo... ogni tanto viene chiamato una sola volta
54
- // ogni tanto viene chiamato due volte... è un pelo arbitrario ma vabbè
55
- if (!prev)
56
- prev = [];
57
- // Considero di aver ricevuto una nuova sorgente se:
58
- // 1: La sorgente nuova ha un numero di elementi diverso dalla sorgente vecchia
59
- // 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
60
- if (newSource && (curr.length != prev.length || (curr.length > 0 && curr[0][this.IdField] != prev[0][this.IdField]))) {
61
- /*
62
- * NGBUG:
63
- * Uso questo escamotage per distruggere il val-select e ricrearlo
64
- * Purtroppo una volta bindato a una sorgente, cambiargliela sotto significa mandare in palla material
65
- * che si mette a far floattare la label anche se il valore e' vuoto
66
- * Distruggendo il componente e ricreandolo material riparte da 0 e non da' problemi.
67
- * Ovviamente lo faccio solo quando ho una SelectLabel, altrimenti non ho problemi di floattamenti
68
- */
69
- if (!this.SourceFirstBind && this.SelectLabel) {
70
- this.detatchPreviousAndRetatchNext((afterStuff) => {
71
- this.BoundSource = null;
72
- setTimeout(() => {
73
- this.tryBindSourceDisplay();
74
- this.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == this.Model)?.description : "";
75
- this.cdr.detectChanges();
76
- setTimeout(() => { afterStuff(); });
77
- });
78
- });
79
- }
80
- else
81
- this.detatchPreviousAndRetatchNext((afterStuff) => {
82
- this.tryBindSourceDisplay();
83
- this.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == this.Model)?.description : "";
84
- this.cdr.detectChanges();
85
- setTimeout(() => { afterStuff(); });
86
- });
87
- this.cdr.markForCheck();
88
- }
89
- }
90
- /** @ignore */
91
- detatchPreviousAndRetatchNext(doStuff) {
92
- if (this.DisplayMode) {
93
- doStuff(() => { });
94
- return;
95
- }
96
- if (this.validationControl && this.Form)
97
- this.Form.removeControl(this.validationControl);
98
- setTimeout(() => {
99
- doStuff(() => {
100
- if (this.validationControl && this.Form)
101
- this.Form.addControl(this.validationControl);
102
- else if (this.validationControl && this.Form) {
103
- this.Form.addControl(this.validationControl);
104
- }
105
- else if (!this.validationControl && this.Form) {
106
- // Questo messaggio ha senso solo se almeno il form esiste... se non esiste sticazzi insomma...
107
- console.error(`Impossibile aggiungere il componente di validazione per ${this.GeneratedName}, le validazioni potrebbero funzionare in maniera erratica`);
108
- }
109
- });
110
- });
111
- }
112
- /** @ignore */
113
- writeValue(obj) {
114
- this.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == obj)?.description : "";
115
- super.writeValue(obj);
116
- }
117
- changed() {
118
- this.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == this.Model)?.description : "";
119
- super.changed(null, false, true);
120
- }
121
- /** @ignore */
122
- onNotNullValueSet() { }
123
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormSelectComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.LocalizationService }, { token: i2.NgControl, optional: true, self: true }, { token: NG_VALIDATORS, optional: true }, { token: i3.AccessControlService, optional: true }, { token: i3.ComponentContext, optional: true }, { token: ACO_CUSTOMKEY, optional: true }, { token: FAV_DEBUG_MODE, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
124
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormSelectComponent, selector: "form-select", inputs: { SelectLabel: "SelectLabel", PlaceholderValue: "PlaceholderValue", RequiredPlaceholder: "RequiredPlaceholder", EmptyFieldValue: "EmptyFieldValue", ShowValidationSymbol: "ShowValidationSymbol", OptionTemplate: "OptionTemplate" }, providers: [{ provide: LocalizationService, useClass: FormSelectComponentLoc }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n\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\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n [attr.required]=\"Required\"\r\n [noValidate]=\"!Validation\"\r\n [Readonly]=\"Readonly\"\r\n [label]=\"SelectLabel\"\r\n [validationFailed]=\"FailedValidationMessage\"\r\n [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Seleziona' | 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\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n [attr.required]=\"Required\"\r\n [noValidate]=\"!Validation\"\r\n [Readonly]=\"Readonly\"\r\n [label]=\"SelectLabel\"\r\n [validationFailed]=\"FailedValidationMessage\"\r\n [showValidationSymbol]=\"ShowValidationSymbol\"\r\n [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Seleziona' | 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\r\n <ng-container *ngIf=\"OptionTemplate\">\r\n <option *ngFor=\"let obj of Source\" [value]=\"obj[IdField]\">\r\n <ng-container *ngTemplateOutlet=\"OptionTemplate; context: { $implicit : obj }\"></ng-container>\r\n </option>\r\n </ng-container>\r\n <ng-container *ngIf=\"!OptionTemplate\">\r\n <option *ngFor=\"let obj of BoundSource\" [value]=\"obj.id\">\r\n {{obj.description}}\r\n </option>\r\n </ng-container>\r\n </val-select>\r\n</ng-template>", dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.ValidationSelectComponent, selector: "val-select", inputs: ["emptyFieldValue", "placeHolderValue", "emptyValue", "showValidationSymbol", "label"], outputs: ["onBlur"] }, { kind: "pipe", type: i1.LocalizePipe, name: "localize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
125
- }
126
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormSelectComponent, decorators: [{
127
- type: Component,
128
- args: [{ selector: "form-select", providers: [{ provide: LocalizationService, useClass: FormSelectComponentLoc }], changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n\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\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n [attr.required]=\"Required\"\r\n [noValidate]=\"!Validation\"\r\n [Readonly]=\"Readonly\"\r\n [label]=\"SelectLabel\"\r\n [validationFailed]=\"FailedValidationMessage\"\r\n [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Seleziona' | 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\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n [attr.required]=\"Required\"\r\n [noValidate]=\"!Validation\"\r\n [Readonly]=\"Readonly\"\r\n [label]=\"SelectLabel\"\r\n [validationFailed]=\"FailedValidationMessage\"\r\n [showValidationSymbol]=\"ShowValidationSymbol\"\r\n [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Seleziona' | 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\r\n <ng-container *ngIf=\"OptionTemplate\">\r\n <option *ngFor=\"let obj of Source\" [value]=\"obj[IdField]\">\r\n <ng-container *ngTemplateOutlet=\"OptionTemplate; context: { $implicit : obj }\"></ng-container>\r\n </option>\r\n </ng-container>\r\n <ng-container *ngIf=\"!OptionTemplate\">\r\n <option *ngFor=\"let obj of BoundSource\" [value]=\"obj.id\">\r\n {{obj.description}}\r\n </option>\r\n </ng-container>\r\n </val-select>\r\n</ng-template>" }]
129
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.LocalizationService }, { type: i2.NgControl, decorators: [{
130
- type: Optional
131
- }, {
132
- type: Self
133
- }] }, { type: Array, decorators: [{
134
- type: Optional
135
- }, {
136
- type: Inject,
137
- args: [NG_VALIDATORS]
138
- }] }, { type: i3.AccessControlService, decorators: [{
139
- type: Optional
140
- }] }, { type: i3.ComponentContext, decorators: [{
141
- type: Optional
142
- }] }, { type: undefined, decorators: [{
143
- type: Optional
144
- }, {
145
- type: Inject,
146
- args: [ACO_CUSTOMKEY]
147
- }] }, { type: undefined, decorators: [{
148
- type: Optional
149
- }, {
150
- type: Inject,
151
- args: [FAV_DEBUG_MODE]
152
- }] }], propDecorators: { SelectLabel: [{
153
- type: Input
154
- }], PlaceholderValue: [{
155
- type: Input
156
- }], RequiredPlaceholder: [{
157
- type: Input
158
- }], EmptyFieldValue: [{
159
- type: Input
160
- }], ShowValidationSymbol: [{
161
- type: Input
162
- }], OptionTemplate: [{
163
- type: Input
164
- }] } });
165
- //# 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, TemplateRef, Host } 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 = '-2000';\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    /** Template per la visualizzazione delle opzioni */\r\n    @Input() OptionTemplate: TemplateRef<any> = null;\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.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == this.Model)?.description : \"\";\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.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == this.Model)?.description : \"\";\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.DisplayMode) {\r\n            doStuff(() => { });\r\n            return;\r\n        }\r\n\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 validazione 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        this.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == obj)?.description : \"\";\r\n\r\n        super.writeValue(obj);\r\n    }\r\n\r\n    changed() {\r\n        this.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == this.Model)?.description : \"\";\r\n\r\n        super.changed(null, false, true);\r\n    }\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\r\n}","<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n    <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n        <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n        <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n    <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n    <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n    <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n    <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n        <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n        <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n        <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n    </div>\r\n    <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n\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\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n                [attr.required]=\"Required\"\r\n                [noValidate]=\"!Validation\"\r\n                [Readonly]=\"Readonly\"\r\n                [label]=\"SelectLabel\"\r\n                [validationFailed]=\"FailedValidationMessage\"\r\n                [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Seleziona' | 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\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n                [attr.required]=\"Required\"\r\n                [noValidate]=\"!Validation\"\r\n                [Readonly]=\"Readonly\"\r\n                [label]=\"SelectLabel\"\r\n                [validationFailed]=\"FailedValidationMessage\"\r\n                [showValidationSymbol]=\"ShowValidationSymbol\"\r\n                [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : ('Seleziona' | 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\r\n        <ng-container *ngIf=\"OptionTemplate\">\r\n            <option *ngFor=\"let obj of Source\" [value]=\"obj[IdField]\">\r\n                <ng-container *ngTemplateOutlet=\"OptionTemplate; context: { $implicit : obj }\"></ng-container>\r\n            </option>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"!OptionTemplate\">\r\n            <option *ngFor=\"let obj of BoundSource\" [value]=\"obj.id\">\r\n                {{obj.description}}\r\n            </option>\r\n        </ng-container>\r\n    </val-select>\r\n</ng-template>"]}
@@ -1,77 +0,0 @@
1
- // Angular
2
- import { ChangeDetectionStrategy, Component, Input } from "@angular/core";
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/common";
5
- /**
6
- * Componente da utilizzare quando l'implementazione dell'input non è disponibile nella libreria,
7
- * fornisce la struttura standard di un form-component ma l'input vero e proprio viene proiettato dall'esterno
8
- */
9
- export class FormTemplateComponent {
10
- constructor() {
11
- /** Indica se l'input è obbligatorio o no */
12
- this.Required = false;
13
- /** Mostra un testo a sinistra dell'input, **FormLayout** permettendo */
14
- this.Label = "";
15
- /** Eventuali classi extra da applicare alla Label, di default c'è solo un leggero margin top */
16
- this.LabelClass = "m-t-5";
17
- /** Utilizza o meno il Layout di un form (Label con input di fianco), se false mostra solo l'input */
18
- this.FormLayout = true;
19
- /** col-md-X per la label */
20
- this.LabelColWidth = 4;
21
- /** col-md-X per l'input */
22
- this.InputColWidth = 8;
23
- /** Indica se è l'ultimo componente di un form (serve per rimuovere il margine finale) */
24
- this.Last = false;
25
- /** Classe extra per il form-group in cui viene wrappato l'input */
26
- this.FormGroupClass = "";
27
- /** Indica che la parte input del controllo dev'essere una label readonly e la parte label di titolo dev'essere in bold. Per utilizzare un solo componente sia per la modifica che per il dettaglio */
28
- this.DisplayMode = false;
29
- /** Layout del Form quando è in modalità Display. Di default mantiene la formattazione a form */
30
- this.DisplayLayout = 'form';
31
- /** Indica la condizione per cui un elemento in Modalità Display può essere visibile in base a ulteriori controlli */
32
- this.DisplayCondition = true;
33
- /** Separatore da mettere in automatico fra un elemento Form e l'altro quando sono in **DisplayMode** con **DisplayLayout** inline */
34
- this.InlineSeparator = ' ';
35
- }
36
- /** Permette di settare in una volta solo gli input LabelColWidth e InputColWidth, basta scriverlo con la sintassi "X Y" */
37
- set LabelInputRatio(input) {
38
- var ratio = input.split(/\s/);
39
- this.LabelColWidth = parseInt(ratio[0]);
40
- this.InputColWidth = parseInt(ratio[1]);
41
- }
42
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
43
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormTemplateComponent, selector: "form-template", inputs: { Required: "Required", Label: "Label", LabelClass: "LabelClass", FormLayout: "FormLayout", LabelColWidth: "LabelColWidth", InputColWidth: "InputColWidth", Last: "Last", FormGroupClass: "FormGroupClass", DisplayMode: "DisplayMode", DisplayModeTemplate: "DisplayModeTemplate", DisplayLayout: "DisplayLayout", DisplayCondition: "DisplayCondition", InlineSeparator: "InlineSeparator", LabelInputRatio: "LabelInputRatio" }, ngImport: i0, template: "<!-- NON PROPRIO Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n <div [hidden]=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></div>\r\n <div [hidden]=\"!DisplayMode || !DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<!-- Singola proiezione -->\r\n<ng-template #content><ng-content></ng-content></ng-template>", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
44
- }
45
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormTemplateComponent, decorators: [{
46
- type: Component,
47
- args: [{ selector: "form-template", changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- NON PROPRIO Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n <div [hidden]=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></div>\r\n <div [hidden]=\"!DisplayMode || !DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<!-- Singola proiezione -->\r\n<ng-template #content><ng-content></ng-content></ng-template>" }]
48
- }], propDecorators: { Required: [{
49
- type: Input
50
- }], Label: [{
51
- type: Input
52
- }], LabelClass: [{
53
- type: Input
54
- }], FormLayout: [{
55
- type: Input
56
- }], LabelColWidth: [{
57
- type: Input
58
- }], InputColWidth: [{
59
- type: Input
60
- }], Last: [{
61
- type: Input
62
- }], FormGroupClass: [{
63
- type: Input
64
- }], DisplayMode: [{
65
- type: Input
66
- }], DisplayModeTemplate: [{
67
- type: Input
68
- }], DisplayLayout: [{
69
- type: Input
70
- }], DisplayCondition: [{
71
- type: Input
72
- }], InlineSeparator: [{
73
- type: Input
74
- }], LabelInputRatio: [{
75
- type: Input
76
- }] } });
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-template.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-template/form-template.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-template/form-template.component.html"],"names":[],"mappings":"AAAA,UAAU;AACV,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAe,MAAM,eAAe,CAAC;;;AAEvF;;;GAGG;AAMH,MAAM,OAAO,qBAAqB;IALlC;QAOI,4CAA4C;QACnC,aAAQ,GAAY,KAAK,CAAC;QAEnC,wEAAwE;QAC/D,UAAK,GAAW,EAAE,CAAC;QAE5B,gGAAgG;QACvF,eAAU,GAAW,OAAO,CAAC;QAEtC,qGAAqG;QAC5F,eAAU,GAAY,IAAI,CAAC;QAEpC,4BAA4B;QACnB,kBAAa,GAAW,CAAC,CAAC;QAEnC,2BAA2B;QAClB,kBAAa,GAAW,CAAC,CAAC;QAEnC,yFAAyF;QAChF,SAAI,GAAY,KAAK,CAAC;QAE/B,mEAAmE;QAC1D,mBAAc,GAAW,EAAE,CAAC;QAErC,sMAAsM;QAC7L,gBAAW,GAAY,KAAK,CAAC;QAKtC,gGAAgG;QACvF,kBAAa,GAAiC,MAAM,CAAC;QAE9D,qHAAqH;QAC5G,qBAAgB,GAAY,IAAI,CAAC;QAE1C,qIAAqI;QAC5H,oBAAe,GAAW,GAAG,CAAC;KAQ1C;IANG,2HAA2H;IAC3H,IAAa,eAAe,CAAC,KAAa;QACtC,IAAI,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;+GA9CQ,qBAAqB;mGAArB,qBAAqB,ieCZlC,srEAsB6D;;4FDVhD,qBAAqB;kBALjC,SAAS;+BACI,eAAe,mBAER,uBAAuB,CAAC,MAAM;8BAKtC,QAAQ;sBAAhB,KAAK;gBAGG,KAAK;sBAAb,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,IAAI;sBAAZ,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAGG,mBAAmB;sBAA3B,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,gBAAgB;sBAAxB,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBAGO,eAAe;sBAA3B,KAAK","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, Component, Input, TemplateRef } from \"@angular/core\";\r\n\r\n/**\r\n * Componente da utilizzare quando l'implementazione dell'input non è disponibile nella libreria,  \r\n * fornisce la struttura standard di un form-component ma l'input vero e proprio viene proiettato dall'esterno\r\n */\r\n@Component({\r\n    selector: \"form-template\",\r\n    templateUrl: \"form-template.component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormTemplateComponent {\r\n\r\n    /** Indica se l'input è obbligatorio o no */\r\n    @Input() Required: boolean = false;\r\n\r\n    /** Mostra un testo a sinistra dell'input, **FormLayout** permettendo */\r\n    @Input() Label: string = \"\";\r\n\r\n    /** Eventuali classi extra da applicare alla Label, di default c'è solo un leggero margin top */\r\n    @Input() LabelClass: string = \"m-t-5\";\r\n\r\n    /** Utilizza o meno il Layout di un form (Label con input di fianco), se false mostra solo l'input */\r\n    @Input() FormLayout: boolean = true;\r\n\r\n    /** col-md-X per la label */\r\n    @Input() LabelColWidth: number = 4;\r\n\r\n    /** col-md-X per l'input */\r\n    @Input() InputColWidth: number = 8;\r\n\r\n    /** Indica se è l'ultimo componente di un form (serve per rimuovere il margine finale) */\r\n    @Input() Last: boolean = false;\r\n\r\n    /** Classe extra per il form-group in cui viene wrappato l'input */\r\n    @Input() FormGroupClass: string = \"\";\r\n\r\n    /** Indica che la parte input del controllo dev'essere una label readonly e la parte label di titolo dev'essere in bold. Per utilizzare un solo componente sia per la modifica che per il dettaglio */\r\n    @Input() DisplayMode: boolean = false;\r\n\r\n    /** Template per visualizzare la modalità **DisplayMode** come vuole il programmatore frocio di turno */\r\n    @Input() DisplayModeTemplate: TemplateRef<any>;\r\n\r\n    /** Layout del Form quando è in modalità Display. Di default mantiene la formattazione a form */\r\n    @Input() DisplayLayout: 'form' | 'inline' | 'hidden' = 'form';\r\n\r\n    /** Indica la condizione per cui un elemento in Modalità Display può essere visibile in base a ulteriori controlli */\r\n    @Input() DisplayCondition: boolean = true;\r\n\r\n    /** Separatore da mettere in automatico fra un elemento Form e l'altro quando sono in **DisplayMode** con **DisplayLayout** inline */\r\n    @Input() InlineSeparator: string = ' ';\r\n\r\n    /** Permette di settare in una volta solo gli input LabelColWidth e InputColWidth, basta scriverlo con la sintassi \"X Y\" */\r\n    @Input() set LabelInputRatio(input: string) {\r\n        var ratio = input.split(/\\s/);\r\n        this.LabelColWidth = parseInt(ratio[0]);\r\n        this.InputColWidth = parseInt(ratio[1]);\r\n    }\r\n}","<!-- NON PROPRIO Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n    <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n        <ng-container *ngIf=\"DisplayLayout == 'form'\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></ng-container>\r\n        <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate\"></ng-container></ng-container>\r\n    <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n    <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n    <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n    <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n        <div [hidden]=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></div>\r\n        <div [hidden]=\"!DisplayMode || !DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate\"></ng-container></div>\r\n    </div>\r\n    <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<!-- Singola proiezione -->\r\n<ng-template #content><ng-content></ng-content></ng-template>"]}
@@ -1,57 +0,0 @@
1
- // Angular
2
- import { NG_VALIDATORS } from "@angular/forms";
3
- import { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self } from "@angular/core";
4
- // Applicazione
5
- import { BaseFormControl } from "../base-form-control";
6
- import { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/forms";
9
- import * as i2 from "@esfaenza/access-control";
10
- import * as i3 from "@angular/common";
11
- import * as i4 from "../../validations/validation-text-area/validation-text-area.component";
12
- /** Componente che presenta una casella di testo tipicamente utilizzata per scrivere delle note o del log breve */
13
- export class FormTextareaComponent extends BaseFormControl {
14
- /** @ignore Costruttore */
15
- constructor(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE) {
16
- super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);
17
- }
18
- /** @ignore */
19
- writeValue(obj) {
20
- this.EvaluatedModel = obj?.toString() || "";
21
- super.writeValue(obj);
22
- }
23
- /** @ignore */
24
- onNotNullValueSet() { }
25
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormTextareaComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NgControl, optional: true, self: true }, { token: NG_VALIDATORS, optional: true }, { token: i2.AccessControlService, optional: true }, { token: i2.ComponentContext, optional: true }, { token: ACO_CUSTOMKEY, optional: true }, { token: FAV_DEBUG_MODE, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
26
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormTextareaComponent, selector: "form-textarea", inputs: { Rows: "Rows" }, usesInheritance: true, ngImport: i0, template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n <val-textarea \r\n [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n [noValidate]=\"!Validation\" \r\n [submitted]=\"Form?.submitted\" \r\n [forceInvalid]=\"ForcedError\" \r\n [FloatingLabel]=\"FloatingLabel\"\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>", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.ValidationTextAreaComponent, selector: "val-textarea", inputs: ["rows"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
27
- }
28
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormTextareaComponent, decorators: [{
29
- type: Component,
30
- args: [{ selector: "form-textarea", changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n <val-textarea \r\n [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n [noValidate]=\"!Validation\" \r\n [submitted]=\"Form?.submitted\" \r\n [forceInvalid]=\"ForcedError\" \r\n [FloatingLabel]=\"FloatingLabel\"\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>" }]
31
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.NgControl, decorators: [{
32
- type: Optional
33
- }, {
34
- type: Self
35
- }] }, { type: Array, decorators: [{
36
- type: Optional
37
- }, {
38
- type: Inject,
39
- args: [NG_VALIDATORS]
40
- }] }, { type: i2.AccessControlService, decorators: [{
41
- type: Optional
42
- }] }, { type: i2.ComponentContext, decorators: [{
43
- type: Optional
44
- }] }, { type: undefined, decorators: [{
45
- type: Optional
46
- }, {
47
- type: Inject,
48
- args: [ACO_CUSTOMKEY]
49
- }] }, { type: undefined, decorators: [{
50
- type: Optional
51
- }, {
52
- type: Inject,
53
- args: [FAV_DEBUG_MODE]
54
- }] }], propDecorators: { Rows: [{
55
- type: Input
56
- }] } });
57
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-textarea.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-textarea/form-textarea.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-textarea/form-textarea.component.html"],"names":[],"mappings":"AAAA,UAAU;AACV,OAAO,EAAwB,aAAa,EAAa,MAAM,gBAAgB,CAAC;AAChF,OAAO,EAAE,uBAAuB,EAAqB,SAAS,EAAQ,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE3H,eAAe;AACf,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAIvD,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;;;;;;AAE7D,kHAAkH;AAMlH,MAAM,OAAO,qBAAsB,SAAQ,eAAe;IAKtD,2BAA2B;IAC3B,YAAY,GAAsB,EAAsB,SAAoB,EAAqC,WAAuB,EAAc,EAAwB,EAAc,UAA4B,EAAoC,aAAa,EAAsC,cAAwB;QACnU,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,EAAE,UAAU,EAAE,aAAa,EAAE,cAAc,CAAC,CAAC;IACtF,CAAC;IAED,cAAc;IACd,UAAU,CAAC,GAAQ;QACf,IAAI,CAAC,cAAc,GAAG,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;QAC5C,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,cAAc;IACd,iBAAiB,KAAW,CAAC;+GAjBpB,qBAAqB,wGAMoE,aAAa,iIAA8H,aAAa,6BAAqC,cAAc;mGANpS,qBAAqB,sGCjBlC,kpGA8Cc;;4FD7BD,qBAAqB;kBALjC,SAAS;+BACI,eAAe,mBAER,uBAAuB,CAAC,MAAM;;0BAQV,QAAQ;;0BAAI,IAAI;;0BAA0B,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAA4B,QAAQ;;0BAA8B,QAAQ;;0BAAkC,QAAQ;;0BAAG,MAAM;2BAAC,aAAa;;0BAAkB,QAAQ;;0BAAI,MAAM;2BAAC,cAAc;yCAHpS,IAAI;sBAAZ,KAAK","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, Host, Inject, Input, Optional, Self } from \"@angular/core\";\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\n\r\n// Configurazioni\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';\r\n\r\n/** Componente che presenta una casella di testo tipicamente utilizzata per scrivere delle note o del log breve */\r\n@Component({\r\n    selector: \"form-textarea\",\r\n    templateUrl: \"form-textarea.component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormTextareaComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /** Numero di righe da visualizzare di default */\r\n    @Input() Rows: number;\r\n\r\n    /** @ignore Costruttore  */\r\n    constructor(cdr: ChangeDetectorRef, @Optional() @Self() ngControl: NgControl, @Optional() @Inject(NG_VALIDATORS) _validators: Array<any>, @Optional() ac: AccessControlService, @Optional() AppContext: ComponentContext, @Optional()@Inject(ACO_CUSTOMKEY) ACO_CUSTOMKEY, @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    writeValue(obj: any): void {\r\n        this.EvaluatedModel = obj?.toString() || \"\";\r\n        super.writeValue(obj);\r\n    }\r\n\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\r\n}","<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n    <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n        <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n        <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n    <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n    <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n    <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n    <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n        <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n        <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n        <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n    </div>\r\n    <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n    <val-textarea \r\n        [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\"\r\n        [noValidate]=\"!Validation\" \r\n        [submitted]=\"Form?.submitted\" \r\n        [forceInvalid]=\"ForcedError\" \r\n        [FloatingLabel]=\"FloatingLabel\"\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>"]}
@@ -1,115 +0,0 @@
1
- // Angular
2
- import { NG_VALIDATORS } from "@angular/forms";
3
- import { Component, Inject, Optional, Self, Input, ChangeDetectionStrategy } from "@angular/core";
4
- // Applicazione
5
- import { BaseFormControl } from "../base-form-control";
6
- import { ACO_CUSTOMKEY } from '../../tokens';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@ngxmc/datetime-picker";
9
- import * as i2 from "@angular/forms";
10
- import * as i3 from "@esfaenza/access-control";
11
- import * as i4 from "@angular/common";
12
- /** Componente che identifica la selezione di un orario */
13
- export class FormTimeComponent extends BaseFormControl {
14
- /** @ignore */
15
- constructor(cdr, dateAdapter, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY) {
16
- super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, true);
17
- this.dateAdapter = dateAdapter;
18
- /** Mostra o meno gli spinner dove cliccare per aumentare/diminuire le componenti dell'orologio (ore, minuti e secondi) */
19
- this.ShowSpinners = false;
20
- /** Imposta lo step (minimo avanzamento) per la cella "ore" */
21
- this.StepHour = 1;
22
- /** Imposta lo step (minimo avanzamento) per la cella "minuti" */
23
- this.StepMinute = 1;
24
- /** Imposta lo step (minimo avanzamento) per la cella "secondi" */
25
- this.StepSecond = 5;
26
- /** Indica se mostrare i secondi o meno */
27
- this.ShowSeconds = false;
28
- /**
29
- * Indica il formato da utilizzare sia in Input che in Output
30
- *
31
- * 1. Se date vengono utilizzate le Date di Javascript
32
- *
33
- * 2. Se timestring vengono utilizzate stringhe del tipo '00:00:00'
34
- *
35
- * 3. Se dayjs viene utilizzato, appunto, dayjs
36
- */
37
- this.InOutFormat = 'timestring';
38
- }
39
- /** @ignore Override per gestire input in ingresso */
40
- writeValue(obj) {
41
- //Qualsiasi cosa mi arrivi devo ricondurla a un dayjs
42
- switch (this.InOutFormat) {
43
- case 'date':
44
- obj = dayjs(obj);
45
- this.EvaluatedModel = obj.format('HH:mm:ss');
46
- break;
47
- case 'timestring':
48
- const [hours, minutes, seconds] = (obj || "00:00:00").split(":");
49
- obj = dayjs().hour(parseInt(hours ?? 0)).minute(parseInt(minutes ?? 0)).second(parseInt(seconds ?? 0));
50
- this.EvaluatedModel = `${hours || '00'}:${minutes || '00'}:${seconds || '00'}`;
51
- break;
52
- case 'dayjs':
53
- obj = obj;
54
- this.EvaluatedModel = obj.format('HH:mm:ss');
55
- break;
56
- }
57
- super.writeValue(obj);
58
- }
59
- /** @ignore Override per gestire input in uscita */
60
- changed() {
61
- var toEmit = this.dateAdapter.clone(this.Model);
62
- switch (this.InOutFormat) {
63
- case 'date':
64
- toEmit = toEmit.toDate();
65
- this.EvaluatedModel = toEmit.format('HH:mm:ss');
66
- break;
67
- case 'timestring':
68
- toEmit = toEmit.format("HH:mm" + (this.ShowSeconds ? ":ss" : ""));
69
- this.EvaluatedModel = toEmit;
70
- break;
71
- case 'dayjs':
72
- toEmit = toEmit;
73
- this.EvaluatedModel = toEmit.format('HH:mm:ss');
74
- break;
75
- }
76
- super.changed(toEmit);
77
- }
78
- /** @ignore */
79
- onNotNullValueSet() { }
80
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormTimeComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NgxMatDateAdapter }, { token: i2.NgControl, optional: true, self: true }, { token: NG_VALIDATORS, optional: true }, { token: i3.AccessControlService }, { token: i3.ComponentContext, optional: true }, { token: ACO_CUSTOMKEY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
81
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormTimeComponent, selector: "form-time", inputs: { ShowSpinners: "ShowSpinners", StepHour: "StepHour", StepMinute: "StepMinute", StepSecond: "StepSecond", ShowSeconds: "ShowSeconds", InOutFormat: "InOutFormat" }, usesInheritance: true, ngImport: i0, template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n <ngx-mat-timepicker name=\"{{GeneratedName}}\" #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>", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i1.NgxMatTimepickerComponent, selector: "ngx-mat-timepicker", inputs: ["disabled", "showSpinners", "stepHour", "stepMinute", "stepSecond", "showSeconds", "disableMinute", "enableMeridian", "defaultTime", "color"], exportAs: ["ngxMatTimepicker"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
82
- }
83
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormTimeComponent, decorators: [{
84
- type: Component,
85
- args: [{ selector: "form-time", changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n <ngx-mat-timepicker name=\"{{GeneratedName}}\" #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>" }]
86
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.NgxMatDateAdapter }, { type: i2.NgControl, decorators: [{
87
- type: Optional
88
- }, {
89
- type: Self
90
- }] }, { type: Array, decorators: [{
91
- type: Optional
92
- }, {
93
- type: Inject,
94
- args: [NG_VALIDATORS]
95
- }] }, { type: i3.AccessControlService }, { type: i3.ComponentContext, decorators: [{
96
- type: Optional
97
- }] }, { type: undefined, decorators: [{
98
- type: Optional
99
- }, {
100
- type: Inject,
101
- args: [ACO_CUSTOMKEY]
102
- }] }], propDecorators: { ShowSpinners: [{
103
- type: Input
104
- }], StepHour: [{
105
- type: Input
106
- }], StepMinute: [{
107
- type: Input
108
- }], StepSecond: [{
109
- type: Input
110
- }], ShowSeconds: [{
111
- type: Input
112
- }], InOutFormat: [{
113
- type: Input
114
- }] } });
115
- //# 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","../../../../../../projects/forms-and-validations/src/lib/forms/form-time/form-time.component.html"],"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 \"@ngxmc/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() @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                this.EvaluatedModel = toEmit.format('HH:mm:ss');\r\n                break;\r\n            case 'timestring':\r\n                toEmit = toEmit.format(\"HH:mm\" + (this.ShowSeconds ? \":ss\" : \"\"));\r\n                this.EvaluatedModel = toEmit;\r\n                break;\r\n            case 'dayjs':\r\n                toEmit = toEmit;\r\n                this.EvaluatedModel = toEmit.format('HH:mm:ss');\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}","<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n    <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n        <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n        <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n    <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n    <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n    <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n    <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n        <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n        <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n        <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n    </div>\r\n    <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n    <ngx-mat-timepicker name=\"{{GeneratedName}}\" #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>"]}