@esfaenza/forms-and-validations 15.2.33 → 15.2.34

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.
@@ -25,8 +25,12 @@ export class FormDateComponent extends BaseFormControl {
25
25
  super.writeValue(obj);
26
26
  }
27
27
  changed() {
28
- this.EvaluatedModel = this.Model ? this.datesExts.getFormatted(this.Model, true, false) : '';
29
- super.changed(null, false, true);
28
+ let newlyEvaluatedModel = this.Model ? this.datesExts.getFormatted(this.Model, true, false) : '';
29
+ // Evito che l'inputChange lato html mi faccia sparare fuori dai changed finti. L'input cambia solo quando cambia il modello presentato
30
+ if (newlyEvaluatedModel != this.EvaluatedModel) {
31
+ this.EvaluatedModel = newlyEvaluatedModel;
32
+ super.changed(null, false, true);
33
+ }
30
34
  }
31
35
  /** @ignore */
32
36
  onNotNullValueSet() { }
@@ -62,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
62
66
  }] }]; }, propDecorators: { JsDates: [{
63
67
  type: Input
64
68
  }] } });
65
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-date.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-date/form-date.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-date/form-date.component.html"],"names":[],"mappings":"AAAA,UAAU;AACV,OAAO,EAAwB,aAAa,EAAa,MAAM,gBAAgB,CAAC;AAChF,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAKlG,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAE7D,eAAe;AACf,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;;;;;;;AAGvD,0EAA0E;AAM1E,MAAM,OAAO,iBAAkB,SAAQ,eAAe;IAKlD,2BAA2B;IAC3B,YAAoB,SAAsB,EAAE,GAAsB,EAAsB,SAAoB,EAAqC,WAAuB,EAAc,EAAwB,EAAc,UAA4B,EAAqC,aAAsB,EAAsC,cAAwB;QAC7W,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,EAAE,UAAU,EAAE,aAAa,EAAE,cAAc,CAAC,CAAC;QADlE,cAAS,GAAT,SAAS,CAAa;QAJ1C,wHAAwH;QAC/G,YAAO,GAAY,KAAK,CAAC;IAKlC,CAAC;IAED,cAAc;IACd,UAAU,CAAC,GAAQ;QACf,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,GAAG,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QACpE,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,OAAO;QACH,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7F,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;IACrC,CAAC;IAED,cAAc;IACd,iBAAiB,KAAW,CAAC;;8GAtBpB,iBAAiB,mIAMwG,aAAa,iIAA+H,aAAa,6BAA8C,cAAc;kGAN9U,iBAAiB,wGCnB9B,soGA0Cc;2FDvBD,iBAAiB;kBAL7B,SAAS;+BACI,WAAW,mBAEJ,uBAAuB,CAAC,MAAM;;0BAQsB,QAAQ;;0BAAI,IAAI;;0BAA0B,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAA4B,QAAQ;;0BAA8B,QAAQ;;0BAAkC,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAA2B,QAAQ;;0BAAI,MAAM;2BAAC,cAAc;4CAH9U,OAAO;sBAAf,KAAK","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self } from \"@angular/core\";\r\n\r\n// Configurazioni\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { DateService } from \"@esfaenza/extensions\";\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { ChangeDetectorRef } from \"@angular/core\";\r\n\r\n/** Componente che dà all'utente la possibilità di selezionare una data */\r\n@Component({\r\n    selector: \"form-date\",\r\n    templateUrl: \"form-date.component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormDateComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /** Utilizza il Date di Javascript come modello in uscita. Il modello in entrata verrà comunque ricondotto a un DayJs */\r\n    @Input() JsDates: boolean = false;\r\n\r\n    /** @ignore Costruttore  */\r\n    constructor(private datesExts: DateService, 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 : 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    writeValue(obj: any): void {\r\n        this.EvaluatedModel = this.datesExts.getFormatted(obj, true, false);\r\n        super.writeValue(obj);\r\n    }\r\n\r\n    changed(): void {\r\n        this.EvaluatedModel = this.Model ? this.datesExts.getFormatted(this.Model, true, false) : '';\r\n        super.changed(null, false, true);\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-date [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n              [submitted]=\"Form?.submitted\"\r\n              [forceInvalid]=\"ForcedError\" \r\n              [FloatingLabel]=\"FloatingLabel\"\r\n              [id]=\"GeneratedName\"\r\n              [Readonly]=\"Readonly\"\r\n              [class]=\"Readonly ? 'app-bg-lightgrey' : ''\"\r\n              [useJsDates]=\"JsDates\"\r\n              [(ngModel)]=\"Model\"\r\n              name=\"{{GeneratedName}}\"\r\n              #validationControl=\"ngModel\"\r\n              (inputChange)=\"changed();\"\r\n              (inputFocus)=\"focused($event);\"\r\n              (inputFinalized)=\"finalized()\"\r\n              [placeholder]=\"Placeholder\"\r\n              [validationFailed]=\"FailedValidationMessage\">\r\n    </val-date>\r\n</ng-template>"]}
69
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-date.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-date/form-date.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-date/form-date.component.html"],"names":[],"mappings":"AAAA,UAAU;AACV,OAAO,EAAwB,aAAa,EAAa,MAAM,gBAAgB,CAAC;AAChF,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAKlG,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAE7D,eAAe;AACf,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;;;;;;;AAGvD,0EAA0E;AAM1E,MAAM,OAAO,iBAAkB,SAAQ,eAAe;IAKlD,2BAA2B;IAC3B,YAAoB,SAAsB,EAAE,GAAsB,EAAsB,SAAoB,EAAqC,WAAuB,EAAc,EAAwB,EAAc,UAA4B,EAAqC,aAAqB,EAAsC,cAAuB;QAC3W,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,EAAE,UAAU,EAAE,aAAa,EAAE,cAAc,CAAC,CAAC;QADlE,cAAS,GAAT,SAAS,CAAa;QAJ1C,wHAAwH;QAC/G,YAAO,GAAY,KAAK,CAAC;IAKlC,CAAC;IAED,cAAc;IACd,UAAU,CAAC,GAAQ;QACf,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,GAAG,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QACpE,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,OAAO;QACH,IAAI,mBAAmB,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAEjG,uIAAuI;QACvI,IAAI,mBAAmB,IAAI,IAAI,CAAC,cAAc,EAAE;YAC5C,IAAI,CAAC,cAAc,GAAG,mBAAmB,CAAA;YACzC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;SACpC;IACL,CAAC;IAED,cAAc;IACd,iBAAiB,KAAW,CAAC;;8GA3BpB,iBAAiB,mIAMwG,aAAa,iIAA+H,aAAa,6BAA6C,cAAc;kGAN7U,iBAAiB,wGCnB9B,soGA0Cc;2FDvBD,iBAAiB;kBAL7B,SAAS;+BACI,WAAW,mBAEJ,uBAAuB,CAAC,MAAM;;0BAQsB,QAAQ;;0BAAI,IAAI;;0BAA0B,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAA4B,QAAQ;;0BAA8B,QAAQ;;0BAAkC,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAA0B,QAAQ;;0BAAI,MAAM;2BAAC,cAAc;4CAH7U,OAAO;sBAAf,KAAK","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self } from \"@angular/core\";\r\n\r\n// Configurazioni\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { DateService } from \"@esfaenza/extensions\";\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { ChangeDetectorRef } from \"@angular/core\";\r\n\r\n/** Componente che dà all'utente la possibilità di selezionare una data */\r\n@Component({\r\n    selector: \"form-date\",\r\n    templateUrl: \"form-date.component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormDateComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /** Utilizza il Date di Javascript come modello in uscita. Il modello in entrata verrà comunque ricondotto a un DayJs */\r\n    @Input() JsDates: boolean = false;\r\n\r\n    /** @ignore Costruttore  */\r\n    constructor(private datesExts: DateService, 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: 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    writeValue(obj: any): void {\r\n        this.EvaluatedModel = this.datesExts.getFormatted(obj, true, false);\r\n        super.writeValue(obj);\r\n    }\r\n\r\n    changed(): void {\r\n        let newlyEvaluatedModel = this.Model ? this.datesExts.getFormatted(this.Model, true, false) : '';\r\n\r\n        // Evito che l'inputChange lato html mi faccia sparare fuori dai changed finti. L'input cambia solo quando cambia il modello presentato\r\n        if (newlyEvaluatedModel != this.EvaluatedModel) {\r\n            this.EvaluatedModel = newlyEvaluatedModel\r\n            super.changed(null, false, true);\r\n        }\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-date [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n              [submitted]=\"Form?.submitted\"\r\n              [forceInvalid]=\"ForcedError\" \r\n              [FloatingLabel]=\"FloatingLabel\"\r\n              [id]=\"GeneratedName\"\r\n              [Readonly]=\"Readonly\"\r\n              [class]=\"Readonly ? 'app-bg-lightgrey' : ''\"\r\n              [useJsDates]=\"JsDates\"\r\n              [(ngModel)]=\"Model\"\r\n              name=\"{{GeneratedName}}\"\r\n              #validationControl=\"ngModel\"\r\n              (inputChange)=\"changed();\"\r\n              (inputFocus)=\"focused($event);\"\r\n              (inputFinalized)=\"finalized()\"\r\n              [placeholder]=\"Placeholder\"\r\n              [validationFailed]=\"FailedValidationMessage\">\r\n    </val-date>\r\n</ng-template>"]}
@@ -3145,8 +3145,12 @@ class FormDateComponent extends BaseFormControl {
3145
3145
  super.writeValue(obj);
3146
3146
  }
3147
3147
  changed() {
3148
- this.EvaluatedModel = this.Model ? this.datesExts.getFormatted(this.Model, true, false) : '';
3149
- super.changed(null, false, true);
3148
+ let newlyEvaluatedModel = this.Model ? this.datesExts.getFormatted(this.Model, true, false) : '';
3149
+ // Evito che l'inputChange lato html mi faccia sparare fuori dai changed finti. L'input cambia solo quando cambia il modello presentato
3150
+ if (newlyEvaluatedModel != this.EvaluatedModel) {
3151
+ this.EvaluatedModel = newlyEvaluatedModel;
3152
+ super.changed(null, false, true);
3153
+ }
3150
3154
  }
3151
3155
  /** @ignore */
3152
3156
  onNotNullValueSet() { }