@esfaenza/forms-and-validations 11.2.93 → 11.2.96
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/esfaenza-forms-and-validations.umd.js +29 -16
- package/bundles/esfaenza-forms-and-validations.umd.js.map +1 -1
- package/esfaenza-forms-and-validations.metadata.json +1 -1
- package/esm2015/lib/forms/base-form-control.js +7 -4
- package/esm2015/lib/forms/form-adaptive/form-adaptive.component.js +2 -2
- package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.js +3 -3
- package/esm2015/lib/forms/form-checkbox/form-checkbox.component.js +2 -2
- package/esm2015/lib/forms/form-date/form-date.component.js +2 -2
- package/esm2015/lib/forms/form-datetime/form-datetime.component.js +2 -2
- package/esm2015/lib/forms/form-file/form-file.component.js +2 -2
- package/esm2015/lib/forms/form-input/form-input.component.js +2 -2
- package/esm2015/lib/forms/form-multiselect/form-multiselect.component.js +2 -2
- package/esm2015/lib/forms/form-select/form-select.component.js +2 -2
- package/esm2015/lib/forms/form-template/form-template.component.js +12 -2
- package/esm2015/lib/forms/form-textarea/form-textarea.component.js +2 -2
- package/esm2015/lib/forms/form-time/form-time.component.js +2 -2
- package/fesm2015/esfaenza-forms-and-validations.js +29 -16
- package/fesm2015/esfaenza-forms-and-validations.js.map +1 -1
- package/lib/forms/base-form-control.d.ts +4 -2
- package/lib/forms/form-template/form-template.component.d.ts +9 -0
- package/package.json +1 -1
|
@@ -118,7 +118,7 @@ FormSelectComponent.decorators = [
|
|
|
118
118
|
{ type: Component, args: [{
|
|
119
119
|
selector: "form-select",
|
|
120
120
|
providers: [{ provide: LocalizationService, useClass: FormSelectComponentLoc }],
|
|
121
|
-
template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || DisplayLayout != 'hidden')\">\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')\" 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>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline'\"> </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\" [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>",
|
|
121
|
+
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>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline'\"> </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\" [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>",
|
|
122
122
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
123
123
|
},] }
|
|
124
124
|
];
|
|
@@ -139,4 +139,4 @@ FormSelectComponent.propDecorators = {
|
|
|
139
139
|
EmptyFieldValue: [{ type: Input }],
|
|
140
140
|
ShowValidationSymbol: [{ type: Input }]
|
|
141
141
|
};
|
|
142
|
-
//# 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.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.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        this.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == this.Model)?.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}"]}
|
|
142
|
+
//# 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.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.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        this.EvaluatedModel = this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == this.Model)?.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}"]}
|
|
@@ -22,6 +22,12 @@ export class FormTemplateComponent {
|
|
|
22
22
|
this.Last = false;
|
|
23
23
|
/** Classe extra per il form-group in cui viene wrappato l'input */
|
|
24
24
|
this.FormGroupClass = "";
|
|
25
|
+
/** 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 */
|
|
26
|
+
this.DisplayMode = false;
|
|
27
|
+
/** Layout del Form quando è in modalità Display. Di default mantiene la formattazione a form */
|
|
28
|
+
this.DisplayLayout = 'form';
|
|
29
|
+
/** Indica la condizione per cui un elemento in Modalità Display può essere visibile in base a ulteriori controlli */
|
|
30
|
+
this.DisplayCondition = true;
|
|
25
31
|
}
|
|
26
32
|
/** Permette di settare in una volta solo gli input LabelColWidth e InputColWidth, basta scriverlo con la sintassi "X Y" */
|
|
27
33
|
set LabelInputRatio(input) {
|
|
@@ -33,7 +39,7 @@ export class FormTemplateComponent {
|
|
|
33
39
|
FormTemplateComponent.decorators = [
|
|
34
40
|
{ type: Component, args: [{
|
|
35
41
|
selector: "form-template",
|
|
36
|
-
template: "<ng-container *ngIf=\"!FormLayout\">\r\n <ng-content></ng-content>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout\" class=\"
|
|
42
|
+
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>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline'\"> </span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"content\"></ng-container></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 </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<!-- Singola proiezione -->\r\n<ng-container *ngTemplateOutlet=\"content\"></ng-container>\r\n<ng-template #content><ng-content></ng-content></ng-template>",
|
|
37
43
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
38
44
|
},] }
|
|
39
45
|
];
|
|
@@ -46,6 +52,10 @@ FormTemplateComponent.propDecorators = {
|
|
|
46
52
|
InputColWidth: [{ type: Input }],
|
|
47
53
|
Last: [{ type: Input }],
|
|
48
54
|
FormGroupClass: [{ type: Input }],
|
|
55
|
+
DisplayMode: [{ type: Input }],
|
|
56
|
+
DisplayModeTemplate: [{ type: Input }],
|
|
57
|
+
DisplayLayout: [{ type: Input }],
|
|
58
|
+
DisplayCondition: [{ type: Input }],
|
|
49
59
|
LabelInputRatio: [{ type: Input }]
|
|
50
60
|
};
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS10ZW1wbGF0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi9mb3Jtcy9mb3JtLXRlbXBsYXRlL2Zvcm0tdGVtcGxhdGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBZSxNQUFNLGVBQWUsQ0FBQztBQUV2Rjs7O0dBR0c7QUFNSCxNQUFNLE9BQU8scUJBQXFCO0lBTGxDO1FBT0ksNENBQTRDO1FBQ25DLGFBQVEsR0FBWSxLQUFLLENBQUM7UUFFbkMsd0VBQXdFO1FBQy9ELFVBQUssR0FBVyxFQUFFLENBQUM7UUFFNUIsZ0dBQWdHO1FBQ3ZGLGVBQVUsR0FBVyxPQUFPLENBQUM7UUFFdEMscUdBQXFHO1FBQzVGLGVBQVUsR0FBWSxJQUFJLENBQUM7UUFFcEMsNEJBQTRCO1FBQ25CLGtCQUFhLEdBQVcsQ0FBQyxDQUFDO1FBRW5DLDJCQUEyQjtRQUNsQixrQkFBYSxHQUFXLENBQUMsQ0FBQztRQUVuQyx5RkFBeUY7UUFDaEYsU0FBSSxHQUFZLEtBQUssQ0FBQztRQUUvQixtRUFBbUU7UUFDMUQsbUJBQWMsR0FBVyxFQUFFLENBQUM7UUFFckMsc01BQXNNO1FBQzdMLGdCQUFXLEdBQVksS0FBSyxDQUFDO1FBS3RDLGdHQUFnRztRQUN2RixrQkFBYSxHQUFpQyxNQUFNLENBQUM7UUFFOUQscUhBQXFIO1FBQzVHLHFCQUFnQixHQUFZLElBQUksQ0FBQztJQVE5QyxDQUFDO0lBTkcsMkhBQTJIO0lBQzNILElBQWEsZUFBZSxDQUFDLEtBQWE7UUFDdEMsSUFBSSxLQUFLLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM5QixJQUFJLENBQUMsYUFBYSxHQUFHLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4QyxJQUFJLENBQUMsYUFBYSxHQUFHLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM1QyxDQUFDOzs7WUFoREosU0FBUyxTQUFDO2dCQUNQLFFBQVEsRUFBRSxlQUFlO2dCQUN6QiwwMEVBQTJDO2dCQUMzQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTthQUNsRDs7O3VCQUlJLEtBQUs7b0JBR0wsS0FBSzt5QkFHTCxLQUFLO3lCQUdMLEtBQUs7NEJBR0wsS0FBSzs0QkFHTCxLQUFLO21CQUdMLEtBQUs7NkJBR0wsS0FBSzswQkFHTCxLQUFLO2tDQUdMLEtBQUs7NEJBR0wsS0FBSzsrQkFHTCxLQUFLOzhCQUdMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBBbmd1bGFyXHJcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0LCBUZW1wbGF0ZVJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vKipcclxuICogQ29tcG9uZW50ZSBkYSB1dGlsaXp6YXJlIHF1YW5kbyBsJ2ltcGxlbWVudGF6aW9uZSBkZWxsJ2lucHV0IG5vbiDDqCBkaXNwb25pYmlsZSBuZWxsYSBsaWJyZXJpYSwgIFxyXG4gKiBmb3JuaXNjZSBsYSBzdHJ1dHR1cmEgc3RhbmRhcmQgZGkgdW4gZm9ybS1jb21wb25lbnQgbWEgbCdpbnB1dCB2ZXJvIGUgcHJvcHJpbyB2aWVuZSBwcm9pZXR0YXRvIGRhbGwnZXN0ZXJub1xyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJmb3JtLXRlbXBsYXRlXCIsXHJcbiAgICB0ZW1wbGF0ZVVybDogXCJmb3JtLXRlbXBsYXRlLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRm9ybVRlbXBsYXRlQ29tcG9uZW50IHtcclxuXHJcbiAgICAvKiogSW5kaWNhIHNlIGwnaW5wdXQgw6ggb2JibGlnYXRvcmlvIG8gbm8gKi9cclxuICAgIEBJbnB1dCgpIFJlcXVpcmVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gICAgLyoqIE1vc3RyYSB1biB0ZXN0byBhIHNpbmlzdHJhIGRlbGwnaW5wdXQsICoqRm9ybUxheW91dCoqIHBlcm1ldHRlbmRvICovXHJcbiAgICBASW5wdXQoKSBMYWJlbDogc3RyaW5nID0gXCJcIjtcclxuXHJcbiAgICAvKiogRXZlbnR1YWxpIGNsYXNzaSBleHRyYSBkYSBhcHBsaWNhcmUgYWxsYSBMYWJlbCwgZGkgZGVmYXVsdCBjJ8OoIHNvbG8gdW4gbGVnZ2VybyBtYXJnaW4gdG9wICovXHJcbiAgICBASW5wdXQoKSBMYWJlbENsYXNzOiBzdHJpbmcgPSBcIm0tdC01XCI7XHJcblxyXG4gICAgLyoqIFV0aWxpenphIG8gbWVubyBpbCBMYXlvdXQgZGkgdW4gZm9ybSAoTGFiZWwgY29uIGlucHV0IGRpIGZpYW5jbyksIHNlIGZhbHNlIG1vc3RyYSBzb2xvIGwnaW5wdXQgKi9cclxuICAgIEBJbnB1dCgpIEZvcm1MYXlvdXQ6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICAgIC8qKiBjb2wtbWQtWCBwZXIgbGEgbGFiZWwgKi9cclxuICAgIEBJbnB1dCgpIExhYmVsQ29sV2lkdGg6IG51bWJlciA9IDQ7XHJcblxyXG4gICAgLyoqIGNvbC1tZC1YIHBlciBsJ2lucHV0ICovXHJcbiAgICBASW5wdXQoKSBJbnB1dENvbFdpZHRoOiBudW1iZXIgPSA4O1xyXG5cclxuICAgIC8qKiBJbmRpY2Egc2Ugw6ggbCd1bHRpbW8gY29tcG9uZW50ZSBkaSB1biBmb3JtIChzZXJ2ZSBwZXIgcmltdW92ZXJlIGlsIG1hcmdpbmUgZmluYWxlKSAqL1xyXG4gICAgQElucHV0KCkgTGFzdDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAgIC8qKiBDbGFzc2UgZXh0cmEgcGVyIGlsIGZvcm0tZ3JvdXAgaW4gY3VpIHZpZW5lIHdyYXBwYXRvIGwnaW5wdXQgKi9cclxuICAgIEBJbnB1dCgpIEZvcm1Hcm91cENsYXNzOiBzdHJpbmcgPSBcIlwiO1xyXG5cclxuICAgIC8qKiBJbmRpY2EgY2hlIGxhIHBhcnRlIGlucHV0IGRlbCBjb250cm9sbG8gZGV2J2Vzc2VyZSB1bmEgbGFiZWwgcmVhZG9ubHkgZSBsYSBwYXJ0ZSBsYWJlbCBkaSB0aXRvbG8gZGV2J2Vzc2VyZSBpbiBib2xkLiBQZXIgdXRpbGl6emFyZSB1biBzb2xvIGNvbXBvbmVudGUgc2lhIHBlciBsYSBtb2RpZmljYSBjaGUgcGVyIGlsIGRldHRhZ2xpbyAqL1xyXG4gICAgQElucHV0KCkgRGlzcGxheU1vZGU6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgICAvKiogVGVtcGxhdGUgcGVyIHZpc3VhbGl6emFyZSBsYSBtb2RhbGl0w6AgKipEaXNwbGF5TW9kZSoqIGNvbWUgdnVvbGUgaWwgcHJvZ3JhbW1hdG9yZSBmcm9jaW8gZGkgdHVybm8gKi9cclxuICAgIEBJbnB1dCgpIERpc3BsYXlNb2RlVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XHJcblxyXG4gICAgLyoqIExheW91dCBkZWwgRm9ybSBxdWFuZG8gw6ggaW4gbW9kYWxpdMOgIERpc3BsYXkuIERpIGRlZmF1bHQgbWFudGllbmUgbGEgZm9ybWF0dGF6aW9uZSBhIGZvcm0gKi9cclxuICAgIEBJbnB1dCgpIERpc3BsYXlMYXlvdXQ6ICdmb3JtJyB8ICdpbmxpbmUnIHwgJ2hpZGRlbicgPSAnZm9ybSc7XHJcblxyXG4gICAgLyoqIEluZGljYSBsYSBjb25kaXppb25lIHBlciBjdWkgdW4gZWxlbWVudG8gaW4gTW9kYWxpdMOgIERpc3BsYXkgcHXDsiBlc3NlcmUgdmlzaWJpbGUgaW4gYmFzZSBhIHVsdGVyaW9yaSBjb250cm9sbGkgKi9cclxuICAgIEBJbnB1dCgpIERpc3BsYXlDb25kaXRpb246IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICAgIC8qKiBQZXJtZXR0ZSBkaSBzZXR0YXJlIGluIHVuYSB2b2x0YSBzb2xvIGdsaSBpbnB1dCBMYWJlbENvbFdpZHRoIGUgSW5wdXRDb2xXaWR0aCwgYmFzdGEgc2NyaXZlcmxvIGNvbiBsYSBzaW50YXNzaSBcIlggWVwiICovXHJcbiAgICBASW5wdXQoKSBzZXQgTGFiZWxJbnB1dFJhdGlvKGlucHV0OiBzdHJpbmcpIHtcclxuICAgICAgICB2YXIgcmF0aW8gPSBpbnB1dC5zcGxpdCgvXFxzLyk7XHJcbiAgICAgICAgdGhpcy5MYWJlbENvbFdpZHRoID0gcGFyc2VJbnQocmF0aW9bMF0pO1xyXG4gICAgICAgIHRoaXMuSW5wdXRDb2xXaWR0aCA9IHBhcnNlSW50KHJhdGlvWzFdKTtcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -23,7 +23,7 @@ export class FormTextareaComponent extends BaseFormControl {
|
|
|
23
23
|
FormTextareaComponent.decorators = [
|
|
24
24
|
{ type: Component, args: [{
|
|
25
25
|
selector: "form-textarea",
|
|
26
|
-
template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || DisplayLayout != 'hidden')\">\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')\" 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>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline'\"> </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\" [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: "<!-- 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>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline'\"> </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\" [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>",
|
|
27
27
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
28
28
|
},] }
|
|
29
29
|
];
|
|
@@ -39,4 +39,4 @@ FormTextareaComponent.ctorParameters = () => [
|
|
|
39
39
|
FormTextareaComponent.propDecorators = {
|
|
40
40
|
Rows: [{ type: Input }]
|
|
41
41
|
};
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS10ZXh0YXJlYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi9mb3Jtcy9mb3JtLXRleHRhcmVhL2Zvcm0tdGV4dGFyZWEuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQXdCLGFBQWEsRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNoRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVySCxlQUFlO0FBQ2YsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXZELGlCQUFpQjtBQUNqQixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNsRixPQUFPLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUU3RCxrSEFBa0g7QUFNbEgsTUFBTSxPQUFPLHFCQUFzQixTQUFRLGVBQWU7SUFLdEQsMkJBQTJCO0lBQzNCLFlBQVksR0FBc0IsRUFBc0IsU0FBb0IsRUFBcUMsV0FBdUIsRUFBYyxFQUF3QixFQUFjLFVBQTRCLEVBQW9DLGFBQWEsRUFBc0MsY0FBd0I7UUFDblUsS0FBSyxDQUFDLEdBQUcsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEVBQUUsRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQ3RGLENBQUM7SUFFRCxjQUFjO0lBQ2QsVUFBVSxDQUFDLEdBQVE7UUFDZixJQUFJLENBQUMsY0FBYyxHQUFHLENBQUEsR0FBRyxhQUFILEdBQUcsdUJBQUgsR0FBRyxDQUFFLFFBQVEsT0FBTSxFQUFFLENBQUM7UUFDNUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBRUQsY0FBYztJQUNkLGlCQUFpQixLQUFXLENBQUM7OztZQXRCaEMsU0FBUyxTQUFDO2dCQUNQLFFBQVEsRUFBRSxlQUFlO2dCQUN6QixpZ0dBQTJDO2dCQUMzQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTthQUNsRDs7O1lBZGlDLGlCQUFpQjtZQURMLFNBQVMsdUJBc0JkLFFBQVEsWUFBSSxJQUFJO1lBQXlFLEtBQUssdUJBQXBELFFBQVEsWUFBSSxNQUFNLFNBQUMsYUFBYTtZQWYxRyxvQkFBb0IsdUJBZWtILFFBQVE7WUFmeEgsZ0JBQWdCLHVCQWVzSSxRQUFROzRDQUFrQyxRQUFRLFlBQUcsTUFBTSxTQUFDLGFBQWE7MENBQWtCLFFBQVEsWUFBSSxNQUFNLFNBQUMsY0FBYzs7O21CQUg1UyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQW5ndWxhclxyXG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMSURBVE9SUywgTmdDb250cm9sIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbmplY3QsIElucHV0LCBPcHRpb25hbCwgU2VsZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vLyBBcHBsaWNhemlvbmVcclxuaW1wb3J0IHsgQmFzZUZvcm1Db250cm9sIH0gZnJvbSBcIi4uL2Jhc2UtZm9ybS1jb250cm9sXCI7XHJcblxyXG4vLyBDb25maWd1cmF6aW9uaVxyXG5pbXBvcnQgeyBBY2Nlc3NDb250cm9sU2VydmljZSwgQ29tcG9uZW50Q29udGV4dCB9IGZyb20gJ0Blc2ZhZW56YS9hY2Nlc3MtY29udHJvbCc7XHJcbmltcG9ydCB7IEFDT19DVVNUT01LRVksIEZBVl9ERUJVR19NT0RFIH0gZnJvbSAnLi4vLi4vdG9rZW5zJztcclxuXHJcbi8qKiBDb21wb25lbnRlIGNoZSBwcmVzZW50YSB1bmEgY2FzZWxsYSBkaSB0ZXN0byB0aXBpY2FtZW50ZSB1dGlsaXp6YXRhIHBlciBzY3JpdmVyZSBkZWxsZSBub3RlIG8gZGVsIGxvZyBicmV2ZSAqL1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiBcImZvcm0tdGV4dGFyZWFcIixcclxuICAgIHRlbXBsYXRlVXJsOiBcImZvcm0tdGV4dGFyZWEuY29tcG9uZW50Lmh0bWxcIixcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGb3JtVGV4dGFyZWFDb21wb25lbnQgZXh0ZW5kcyBCYXNlRm9ybUNvbnRyb2wgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XHJcblxyXG4gICAgLyoqIE51bWVybyBkaSByaWdoZSBkYSB2aXN1YWxpenphcmUgZGkgZGVmYXVsdCAqL1xyXG4gICAgQElucHV0KCkgUm93czogbnVtYmVyO1xyXG5cclxuICAgIC8qKiBAaWdub3JlIENvc3RydXR0b3JlICAqL1xyXG4gICAgY29uc3RydWN0b3IoY2RyOiBDaGFuZ2VEZXRlY3RvclJlZiwgQE9wdGlvbmFsKCkgQFNlbGYoKSBuZ0NvbnRyb2w6IE5nQ29udHJvbCwgQE9wdGlvbmFsKCkgQEluamVjdChOR19WQUxJREFUT1JTKSBfdmFsaWRhdG9yczogQXJyYXk8YW55PiwgQE9wdGlvbmFsKCkgYWM6IEFjY2Vzc0NvbnRyb2xTZXJ2aWNlLCBAT3B0aW9uYWwoKSBBcHBDb250ZXh0OiBDb21wb25lbnRDb250ZXh0LCBAT3B0aW9uYWwoKUBJbmplY3QoQUNPX0NVU1RPTUtFWSkgQUNPX0NVU1RPTUtFWSwgQE9wdGlvbmFsKCkgQEluamVjdChGQVZfREVCVUdfTU9ERSkgRkFWX0RFQlVHX01PREUgOiBib29sZWFuKSB7XHJcbiAgICAgICAgc3VwZXIoY2RyLCBuZ0NvbnRyb2wsIF92YWxpZGF0b3JzLCBhYywgQXBwQ29udGV4dCwgQUNPX0NVU1RPTUtFWSwgRkFWX0RFQlVHX01PREUpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKiBAaWdub3JlICovXHJcbiAgICB3cml0ZVZhbHVlKG9iajogYW55KTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5FdmFsdWF0ZWRNb2RlbCA9IG9iaj8udG9TdHJpbmcoKSB8fCBcIlwiO1xyXG4gICAgICAgIHN1cGVyLndyaXRlVmFsdWUob2JqKTtcclxuICAgIH1cclxuXHJcbiAgICAvKiogQGlnbm9yZSAqL1xyXG4gICAgb25Ob3ROdWxsVmFsdWVTZXQoKTogdm9pZCB7IH1cclxufSJdfQ==
|
|
@@ -79,7 +79,7 @@ export class FormTimeComponent extends BaseFormControl {
|
|
|
79
79
|
FormTimeComponent.decorators = [
|
|
80
80
|
{ type: Component, args: [{
|
|
81
81
|
selector: "form-time",
|
|
82
|
-
template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || DisplayLayout != 'hidden')\">\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')\" 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>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline'\"> </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=\"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>",
|
|
82
|
+
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>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline'\"> </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=\"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>",
|
|
83
83
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
84
84
|
},] }
|
|
85
85
|
];
|
|
@@ -100,4 +100,4 @@ FormTimeComponent.propDecorators = {
|
|
|
100
100
|
ShowSeconds: [{ type: Input }],
|
|
101
101
|
InOutFormat: [{ type: Input }]
|
|
102
102
|
};
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
103
|
+
//# 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                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}"]}
|