@esfaenza/forms-and-validations 16.2.30 → 17.3.0

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 (83) hide show
  1. package/esm2022/esfaenza-forms-and-validations.mjs +4 -4
  2. package/esm2022/lib/forms/base-form-control.mjs +558 -558
  3. package/esm2022/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +21 -21
  4. package/esm2022/lib/forms/form-adaptive/form-adaptive.component.mjs +420 -420
  5. package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +20 -20
  6. package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.mjs +289 -289
  7. package/esm2022/lib/forms/form-checkbox/form-checkbox.component.mjs +74 -74
  8. package/esm2022/lib/forms/form-date/form-date.component.mjs +69 -69
  9. package/esm2022/lib/forms/form-datetime/form-datetime.component.mjs +67 -67
  10. package/esm2022/lib/forms/form-empty/form-empty.component.mjs +29 -29
  11. package/esm2022/lib/forms/form-error/form-error.component.mjs +41 -41
  12. package/esm2022/lib/forms/form-file/form-file.component.loc.mjs +21 -21
  13. package/esm2022/lib/forms/form-file/form-file.component.mjs +175 -175
  14. package/esm2022/lib/forms/form-info/form-info.component.mjs +41 -41
  15. package/esm2022/lib/forms/form-input/form-input.component.mjs +83 -83
  16. package/esm2022/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +22 -22
  17. package/esm2022/lib/forms/form-multiselect/form-multiselect.component.mjs +163 -163
  18. package/esm2022/lib/forms/form-select/form-select.component.loc.mjs +20 -20
  19. package/esm2022/lib/forms/form-select/form-select.component.mjs +165 -165
  20. package/esm2022/lib/forms/form-template/form-template.component.mjs +76 -76
  21. package/esm2022/lib/forms/form-textarea/form-textarea.component.mjs +57 -57
  22. package/esm2022/lib/forms/form-time/form-time.component.mjs +115 -115
  23. package/esm2022/lib/forms-and-validations.module.mjs +199 -199
  24. package/esm2022/lib/models/AppFile.mjs +13 -13
  25. package/esm2022/lib/models/ChangeEvent.mjs +6 -6
  26. package/esm2022/lib/models/FormsAndValidationsModuleConfig.mjs +5 -5
  27. package/esm2022/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +89 -89
  28. package/esm2022/lib/tokens.mjs +7 -7
  29. package/esm2022/lib/validations/base-validation.loc.mjs +22 -22
  30. package/esm2022/lib/validations/base-validation.mjs +328 -328
  31. package/esm2022/lib/validations/customValidators/CustomRequiredDirective.mjs +40 -40
  32. package/esm2022/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +147 -147
  33. package/esm2022/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +240 -240
  34. package/esm2022/lib/validations/validation-currency/validation-currency.component.mjs +75 -75
  35. package/esm2022/lib/validations/validation-date/validation-date.component.mjs +183 -183
  36. package/esm2022/lib/validations/validation-datetime/validation-datetime.component.mjs +212 -212
  37. package/esm2022/lib/validations/validation-input/validation-input.component.mjs +222 -222
  38. package/esm2022/lib/validations/validation-select/validation-select.component.mjs +183 -183
  39. package/esm2022/lib/validations/validation-text-area/validation-text-area.component.mjs +78 -78
  40. package/esm2022/public-api.mjs +39 -39
  41. package/fesm2022/esfaenza-forms-and-validations.mjs +4152 -4152
  42. package/fesm2022/esfaenza-forms-and-validations.mjs.map +1 -1
  43. package/index.d.ts +5 -5
  44. package/lib/forms/base-form-control.d.ts +276 -276
  45. package/lib/forms/form-adaptive/form-adaptive.component.d.ts +126 -126
  46. package/lib/forms/form-adaptive/form-adaptive.component.loc.d.ts +14 -14
  47. package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +84 -84
  48. package/lib/forms/form-autocomplete/form-autocomplete.component.loc.d.ts +14 -14
  49. package/lib/forms/form-checkbox/form-checkbox.component.d.ts +23 -23
  50. package/lib/forms/form-date/form-date.component.d.ts +21 -21
  51. package/lib/forms/form-datetime/form-datetime.component.d.ts +23 -23
  52. package/lib/forms/form-empty/form-empty.component.d.ts +15 -15
  53. package/lib/forms/form-error/form-error.component.d.ts +19 -19
  54. package/lib/forms/form-file/form-file.component.d.ts +46 -46
  55. package/lib/forms/form-file/form-file.component.loc.d.ts +14 -14
  56. package/lib/forms/form-info/form-info.component.d.ts +19 -19
  57. package/lib/forms/form-input/form-input.component.d.ts +33 -33
  58. package/lib/forms/form-multiselect/form-multiselect.component.d.ts +67 -67
  59. package/lib/forms/form-multiselect/form-multiselect.component.loc.d.ts +14 -14
  60. package/lib/forms/form-select/form-select.component.d.ts +43 -43
  61. package/lib/forms/form-select/form-select.component.loc.d.ts +14 -14
  62. package/lib/forms/form-template/form-template.component.d.ts +38 -38
  63. package/lib/forms/form-textarea/form-textarea.component.d.ts +18 -18
  64. package/lib/forms/form-time/form-time.component.d.ts +40 -40
  65. package/lib/forms-and-validations.module.d.ts +47 -47
  66. package/lib/models/AppFile.d.ts +21 -21
  67. package/lib/models/ChangeEvent.d.ts +5 -5
  68. package/lib/models/FormsAndValidationsModuleConfig.d.ts +11 -11
  69. package/lib/models/dayjs-adapter/dayjs-date-adapter.d.ts +49 -49
  70. package/lib/tokens.d.ts +7 -7
  71. package/lib/validations/base-validation.d.ts +219 -219
  72. package/lib/validations/base-validation.loc.d.ts +14 -14
  73. package/lib/validations/customValidators/CustomRequiredDirective.d.ts +24 -24
  74. package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +58 -58
  75. package/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.d.ts +88 -88
  76. package/lib/validations/validation-currency/validation-currency.component.d.ts +28 -28
  77. package/lib/validations/validation-date/validation-date.component.d.ts +79 -79
  78. package/lib/validations/validation-datetime/validation-datetime.component.d.ts +109 -109
  79. package/lib/validations/validation-input/validation-input.component.d.ts +134 -134
  80. package/lib/validations/validation-select/validation-select.component.d.ts +95 -95
  81. package/lib/validations/validation-text-area/validation-text-area.component.d.ts +28 -28
  82. package/package.json +13 -13
  83. package/public-api.d.ts +31 -31
@@ -1,89 +1,89 @@
1
- //Angular
2
- import { Inject, Injectable } from "@angular/core";
3
- import { MAT_DATE_LOCALE } from "@angular/material/core";
4
- //Libreria
5
- // Questa non è più usata, la tengo qui per crosscheck in caso di updates
6
- //import { NgxMatDateAdapter } from "@angular-material-components/datetime-picker";
7
- import { DayJsDateAdapter } from "@esfaenza/material-dayjs-adapter";
8
- import * as i0 from "@angular/core";
9
- /**
10
- * Espansione dell'adapter di default di DayJs già utilizzato per i bind base su Material.
11
- *
12
- * Questa versione serve unicamente per i controlli **datetime-picker**, ma dato che io l'adapter già lo avevo lato **esfaenza/material-dayjs-adapter**
13
- * qui devo semplicemente aggiungere le funzioni non presenti nella mia implementazione che servono al **datetime-picker**
14
- */
15
- export class NgxExpandedDayJsDateAdapter extends DayJsDateAdapter {
16
- /**
17
- * @ignore
18
- */
19
- constructor(dateLocale) {
20
- super(dateLocale);
21
- }
22
- // Espando il mio DayJsDateAdapter con i metodi extra del NgxMatDateAdapter che servono per il material timepicker
23
- // Non potendo fare "extends" da due classi mi tocca tenerlo così senza type safety....
24
- /**
25
- * Identifica se due date hanno lo stesso orario
26
- *
27
- * @param {DayJs} a Primo elemento del controllo
28
- * @param {DayJs} b Secondo elemento del controllo
29
- * @returns **true** se hanno lo stess orario, **false** altrimenti
30
- */
31
- isSameTime(a, b) {
32
- if (a == null || b == null)
33
- return true;
34
- return this.getHour(a) === this.getHour(b)
35
- && this.getMinute(a) === this.getMinute(b)
36
- && this.getSecond(a) === this.getSecond(b);
37
- }
38
- /**
39
- * Copia dell'orario da una data all'altra, Modifica direttamente l'oggetto **toDate**
40
- *
41
- * @param {DayJs} toDate Data in cui copiare l'orario
42
- * @param {DayJs} fromDate Data da cui copiare l'orario
43
- */
44
- copyTime(toDate, fromDate) {
45
- this.setHour(toDate, this.getHour(fromDate));
46
- this.setMinute(toDate, this.getMinute(fromDate));
47
- this.setSecond(toDate, this.getSecond(fromDate));
48
- }
49
- /**
50
- * Mette a confronto due date
51
- * @param {Dayjs} first Prima data da confrontare
52
- * @param {Dayjs} second Seconda data da confrontare
53
- * @param {boolean} showSeconds Indica se considerare anche i secondi, di default no
54
- * @returns {number} 0 se le due date sono uguali, un numero minore di 0 se la prima data è precedente alla seconda e un numero maggiore di 0 altrimenti
55
- */
56
- compareDateWithTime(first, second, showSeconds) {
57
- let res = super.compareDate(first, second) ||
58
- this.getHour(first) - this.getHour(second) ||
59
- this.getMinute(first) - this.getMinute(second);
60
- if (showSeconds)
61
- res = res || this.getSecond(first) - this.getSecond(second);
62
- return res;
63
- }
64
- /**
65
- * Assegna a una data i valori di ore, minuti e secondi di default.
66
- *
67
- * Se non specificati vengono assegnati degli '0'
68
- *
69
- * @param {DayJs} date Data a cui assegnare i valori di default
70
- * @param {number[]} defaultTime Valori di default per ore, minuti e secondi, considerati 0 se non presenti
71
- */
72
- setTimeByDefaultValues(date, defaultTime) {
73
- if (!Array.isArray(defaultTime)) {
74
- throw Error('@Input DefaultTime should be an array');
75
- }
76
- this.setHour(date, defaultTime[0] || 0);
77
- this.setMinute(date, defaultTime[1] || 0);
78
- this.setSecond(date, defaultTime[2] || 0);
79
- }
80
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgxExpandedDayJsDateAdapter, deps: [{ token: MAT_DATE_LOCALE }], target: i0.ɵɵFactoryTarget.Injectable }); }
81
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgxExpandedDayJsDateAdapter }); }
82
- }
83
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgxExpandedDayJsDateAdapter, decorators: [{
84
- type: Injectable
85
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
86
- type: Inject,
87
- args: [MAT_DATE_LOCALE]
88
- }] }]; } });
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dayjs-date-adapter.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/models/dayjs-adapter/dayjs-date-adapter.ts"],"names":[],"mappings":"AAAA,SAAS;AACT,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,UAAU;AACV,yEAAyE;AACzE,mFAAmF;AACnF,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;;AAGpE;;;;;GAKG;AAEH,MAAM,OAAO,2BAA4B,SAAQ,gBAAgB;IAE7D;;OAEG;IACH,YAAqC,UAAkB;QACnD,KAAK,CAAC,UAAU,CAAC,CAAC;IACtB,CAAC;IAED,kHAAkH;IAClH,wFAAwF;IAExF;;;;;;OAMG;IACH,UAAU,CAAC,CAAQ,EAAE,CAAQ;QACzB,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI;YAAE,OAAO,IAAI,CAAC;QACxC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;eACnC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;eACvC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC;IAED;;;;;OAKG;IACH,QAAQ,CAAC,MAAa,EAAE,QAAe;QACnC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC7C,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QACjD,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACH,mBAAmB,CAAC,KAAY,EAAE,MAAa,EAAE,WAAqB;QAClE,IAAI,GAAG,GAAG,KAAK,CAAC,WAAW,CAAC,KAAK,EAAE,MAAM,CAAC;YACtC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;YAC1C,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAEnD,IAAI,WAAW;YACX,GAAG,GAAG,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAEhE,OAAO,GAAG,CAAC;IACf,CAAC;IAED;;;;;;;OAOG;IACH,sBAAsB,CAAC,IAAW,EAAE,WAAqB;QACrD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;YAC7B,MAAM,KAAK,CAAC,uCAAuC,CAAC,CAAC;SACxD;QACD,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACxC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9C,CAAC;+GAvEQ,2BAA2B,kBAKhB,eAAe;mHAL1B,2BAA2B;;4FAA3B,2BAA2B;kBADvC,UAAU;;0BAMM,MAAM;2BAAC,eAAe","sourcesContent":["//Angular\r\nimport { Inject, Injectable } from \"@angular/core\";\r\nimport { MAT_DATE_LOCALE } from \"@angular/material/core\";\r\n\r\n//Libreria\r\n// Questa non è più usata, la tengo qui per crosscheck in caso di updates\r\n//import { NgxMatDateAdapter } from \"@angular-material-components/datetime-picker\";\r\nimport { DayJsDateAdapter } from \"@esfaenza/material-dayjs-adapter\";\r\nimport { Dayjs } from \"dayjs\";\r\n\r\n/**\r\n * Espansione dell'adapter di default di DayJs già utilizzato per i bind base su Material.\r\n * \r\n * Questa versione serve unicamente per i controlli **datetime-picker**, ma dato che io l'adapter già lo avevo lato **esfaenza/material-dayjs-adapter** \r\n * qui devo semplicemente aggiungere le funzioni non presenti nella mia implementazione che servono al **datetime-picker**\r\n */\r\n@Injectable()\r\nexport class NgxExpandedDayJsDateAdapter extends DayJsDateAdapter {\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    constructor(@Inject(MAT_DATE_LOCALE) dateLocale: string) {\r\n        super(dateLocale);\r\n    }\r\n\r\n    // Espando il mio DayJsDateAdapter con i metodi extra del NgxMatDateAdapter che servono per il material timepicker\r\n    // Non potendo fare \"extends\" da due classi mi tocca tenerlo così senza type safety.... \r\n\r\n    /**\r\n     * Identifica se due date hanno lo stesso orario\r\n     * \r\n     * @param {DayJs} a Primo elemento del controllo\r\n     * @param {DayJs} b Secondo elemento del controllo\r\n     * @returns **true** se hanno lo stess orario, **false** altrimenti\r\n     */\r\n    isSameTime(a: Dayjs, b: Dayjs): boolean {\r\n        if (a == null || b == null) return true;\r\n        return this.getHour(a) === this.getHour(b)\r\n            && this.getMinute(a) === this.getMinute(b)\r\n            && this.getSecond(a) === this.getSecond(b);\r\n    }\r\n\r\n    /**\r\n     * Copia dell'orario da una data all'altra, Modifica direttamente l'oggetto **toDate**\r\n     * \r\n     * @param {DayJs} toDate Data in cui copiare l'orario\r\n     * @param {DayJs} fromDate Data da cui copiare l'orario\r\n     */\r\n    copyTime(toDate: Dayjs, fromDate: Dayjs) {\r\n        this.setHour(toDate, this.getHour(fromDate));\r\n        this.setMinute(toDate, this.getMinute(fromDate));\r\n        this.setSecond(toDate, this.getSecond(fromDate));\r\n    }\r\n\r\n    /**\r\n     * Mette a confronto due date\r\n     * @param {Dayjs} first Prima data da confrontare\r\n     * @param {Dayjs} second Seconda data da confrontare\r\n     * @param {boolean} showSeconds Indica se considerare anche i secondi, di default no\r\n     * @returns {number} 0 se le due date sono uguali, un numero minore di 0 se la prima data è precedente alla seconda e un numero maggiore di 0 altrimenti\r\n     */\r\n    compareDateWithTime(first: Dayjs, second: Dayjs, showSeconds?: boolean): number {\r\n        let res = super.compareDate(first, second) ||\r\n            this.getHour(first) - this.getHour(second) ||\r\n            this.getMinute(first) - this.getMinute(second);\r\n\r\n        if (showSeconds)\r\n            res = res || this.getSecond(first) - this.getSecond(second);\r\n            \r\n        return res;\r\n    }\r\n\r\n    /**\r\n     * Assegna a una data i valori di ore, minuti e secondi di default. \r\n     * \r\n     * Se non specificati vengono assegnati degli '0'\r\n     * \r\n     * @param {DayJs} date Data a cui assegnare i valori di default\r\n     * @param {number[]} defaultTime Valori di default per ore, minuti e secondi, considerati 0 se non presenti\r\n     */\r\n    setTimeByDefaultValues(date: Dayjs, defaultTime: number[]) {\r\n        if (!Array.isArray(defaultTime)) {\r\n            throw Error('@Input DefaultTime should be an array');\r\n        }\r\n        this.setHour(date, defaultTime[0] || 0);\r\n        this.setMinute(date, defaultTime[1] || 0);\r\n        this.setSecond(date, defaultTime[2] || 0);\r\n    }\r\n}"]}
1
+ //Angular
2
+ import { Inject, Injectable } from "@angular/core";
3
+ import { MAT_DATE_LOCALE } from "@angular/material/core";
4
+ //Libreria
5
+ // Questa non è più usata, la tengo qui per crosscheck in caso di updates
6
+ //import { NgxMatDateAdapter } from "@angular-material-components/datetime-picker";
7
+ import { DayJsDateAdapter } from "@esfaenza/material-dayjs-adapter";
8
+ import * as i0 from "@angular/core";
9
+ /**
10
+ * Espansione dell'adapter di default di DayJs già utilizzato per i bind base su Material.
11
+ *
12
+ * Questa versione serve unicamente per i controlli **datetime-picker**, ma dato che io l'adapter già lo avevo lato **esfaenza/material-dayjs-adapter**
13
+ * qui devo semplicemente aggiungere le funzioni non presenti nella mia implementazione che servono al **datetime-picker**
14
+ */
15
+ export class NgxExpandedDayJsDateAdapter extends DayJsDateAdapter {
16
+ /**
17
+ * @ignore
18
+ */
19
+ constructor(dateLocale) {
20
+ super(dateLocale);
21
+ }
22
+ // Espando il mio DayJsDateAdapter con i metodi extra del NgxMatDateAdapter che servono per il material timepicker
23
+ // Non potendo fare "extends" da due classi mi tocca tenerlo così senza type safety....
24
+ /**
25
+ * Identifica se due date hanno lo stesso orario
26
+ *
27
+ * @param {DayJs} a Primo elemento del controllo
28
+ * @param {DayJs} b Secondo elemento del controllo
29
+ * @returns **true** se hanno lo stess orario, **false** altrimenti
30
+ */
31
+ isSameTime(a, b) {
32
+ if (a == null || b == null)
33
+ return true;
34
+ return this.getHour(a) === this.getHour(b)
35
+ && this.getMinute(a) === this.getMinute(b)
36
+ && this.getSecond(a) === this.getSecond(b);
37
+ }
38
+ /**
39
+ * Copia dell'orario da una data all'altra, Modifica direttamente l'oggetto **toDate**
40
+ *
41
+ * @param {DayJs} toDate Data in cui copiare l'orario
42
+ * @param {DayJs} fromDate Data da cui copiare l'orario
43
+ */
44
+ copyTime(toDate, fromDate) {
45
+ this.setHour(toDate, this.getHour(fromDate));
46
+ this.setMinute(toDate, this.getMinute(fromDate));
47
+ this.setSecond(toDate, this.getSecond(fromDate));
48
+ }
49
+ /**
50
+ * Mette a confronto due date
51
+ * @param {Dayjs} first Prima data da confrontare
52
+ * @param {Dayjs} second Seconda data da confrontare
53
+ * @param {boolean} showSeconds Indica se considerare anche i secondi, di default no
54
+ * @returns {number} 0 se le due date sono uguali, un numero minore di 0 se la prima data è precedente alla seconda e un numero maggiore di 0 altrimenti
55
+ */
56
+ compareDateWithTime(first, second, showSeconds) {
57
+ let res = super.compareDate(first, second) ||
58
+ this.getHour(first) - this.getHour(second) ||
59
+ this.getMinute(first) - this.getMinute(second);
60
+ if (showSeconds)
61
+ res = res || this.getSecond(first) - this.getSecond(second);
62
+ return res;
63
+ }
64
+ /**
65
+ * Assegna a una data i valori di ore, minuti e secondi di default.
66
+ *
67
+ * Se non specificati vengono assegnati degli '0'
68
+ *
69
+ * @param {DayJs} date Data a cui assegnare i valori di default
70
+ * @param {number[]} defaultTime Valori di default per ore, minuti e secondi, considerati 0 se non presenti
71
+ */
72
+ setTimeByDefaultValues(date, defaultTime) {
73
+ if (!Array.isArray(defaultTime)) {
74
+ throw Error('@Input DefaultTime should be an array');
75
+ }
76
+ this.setHour(date, defaultTime[0] || 0);
77
+ this.setMinute(date, defaultTime[1] || 0);
78
+ this.setSecond(date, defaultTime[2] || 0);
79
+ }
80
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgxExpandedDayJsDateAdapter, deps: [{ token: MAT_DATE_LOCALE }], target: i0.ɵɵFactoryTarget.Injectable }); }
81
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgxExpandedDayJsDateAdapter }); }
82
+ }
83
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgxExpandedDayJsDateAdapter, decorators: [{
84
+ type: Injectable
85
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
86
+ type: Inject,
87
+ args: [MAT_DATE_LOCALE]
88
+ }] }] });
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dayjs-date-adapter.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/models/dayjs-adapter/dayjs-date-adapter.ts"],"names":[],"mappings":"AAAA,SAAS;AACT,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,UAAU;AACV,yEAAyE;AACzE,mFAAmF;AACnF,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;;AAGpE;;;;;GAKG;AAEH,MAAM,OAAO,2BAA4B,SAAQ,gBAAgB;IAE7D;;OAEG;IACH,YAAqC,UAAkB;QACnD,KAAK,CAAC,UAAU,CAAC,CAAC;IACtB,CAAC;IAED,kHAAkH;IAClH,wFAAwF;IAExF;;;;;;OAMG;IACH,UAAU,CAAC,CAAQ,EAAE,CAAQ;QACzB,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI;YAAE,OAAO,IAAI,CAAC;QACxC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;eACnC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;eACvC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC;IAED;;;;;OAKG;IACH,QAAQ,CAAC,MAAa,EAAE,QAAe;QACnC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC7C,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QACjD,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACH,mBAAmB,CAAC,KAAY,EAAE,MAAa,EAAE,WAAqB;QAClE,IAAI,GAAG,GAAG,KAAK,CAAC,WAAW,CAAC,KAAK,EAAE,MAAM,CAAC;YACtC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;YAC1C,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAEnD,IAAI,WAAW;YACX,GAAG,GAAG,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAEhE,OAAO,GAAG,CAAC;IACf,CAAC;IAED;;;;;;;OAOG;IACH,sBAAsB,CAAC,IAAW,EAAE,WAAqB;QACrD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;YAC9B,MAAM,KAAK,CAAC,uCAAuC,CAAC,CAAC;QACzD,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACxC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9C,CAAC;+GAvEQ,2BAA2B,kBAKhB,eAAe;mHAL1B,2BAA2B;;4FAA3B,2BAA2B;kBADvC,UAAU;;0BAMM,MAAM;2BAAC,eAAe","sourcesContent":["//Angular\r\nimport { Inject, Injectable } from \"@angular/core\";\r\nimport { MAT_DATE_LOCALE } from \"@angular/material/core\";\r\n\r\n//Libreria\r\n// Questa non è più usata, la tengo qui per crosscheck in caso di updates\r\n//import { NgxMatDateAdapter } from \"@angular-material-components/datetime-picker\";\r\nimport { DayJsDateAdapter } from \"@esfaenza/material-dayjs-adapter\";\r\nimport { Dayjs } from \"dayjs\";\r\n\r\n/**\r\n * Espansione dell'adapter di default di DayJs già utilizzato per i bind base su Material.\r\n * \r\n * Questa versione serve unicamente per i controlli **datetime-picker**, ma dato che io l'adapter già lo avevo lato **esfaenza/material-dayjs-adapter** \r\n * qui devo semplicemente aggiungere le funzioni non presenti nella mia implementazione che servono al **datetime-picker**\r\n */\r\n@Injectable()\r\nexport class NgxExpandedDayJsDateAdapter extends DayJsDateAdapter {\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    constructor(@Inject(MAT_DATE_LOCALE) dateLocale: string) {\r\n        super(dateLocale);\r\n    }\r\n\r\n    // Espando il mio DayJsDateAdapter con i metodi extra del NgxMatDateAdapter che servono per il material timepicker\r\n    // Non potendo fare \"extends\" da due classi mi tocca tenerlo così senza type safety.... \r\n\r\n    /**\r\n     * Identifica se due date hanno lo stesso orario\r\n     * \r\n     * @param {DayJs} a Primo elemento del controllo\r\n     * @param {DayJs} b Secondo elemento del controllo\r\n     * @returns **true** se hanno lo stess orario, **false** altrimenti\r\n     */\r\n    isSameTime(a: Dayjs, b: Dayjs): boolean {\r\n        if (a == null || b == null) return true;\r\n        return this.getHour(a) === this.getHour(b)\r\n            && this.getMinute(a) === this.getMinute(b)\r\n            && this.getSecond(a) === this.getSecond(b);\r\n    }\r\n\r\n    /**\r\n     * Copia dell'orario da una data all'altra, Modifica direttamente l'oggetto **toDate**\r\n     * \r\n     * @param {DayJs} toDate Data in cui copiare l'orario\r\n     * @param {DayJs} fromDate Data da cui copiare l'orario\r\n     */\r\n    copyTime(toDate: Dayjs, fromDate: Dayjs) {\r\n        this.setHour(toDate, this.getHour(fromDate));\r\n        this.setMinute(toDate, this.getMinute(fromDate));\r\n        this.setSecond(toDate, this.getSecond(fromDate));\r\n    }\r\n\r\n    /**\r\n     * Mette a confronto due date\r\n     * @param {Dayjs} first Prima data da confrontare\r\n     * @param {Dayjs} second Seconda data da confrontare\r\n     * @param {boolean} showSeconds Indica se considerare anche i secondi, di default no\r\n     * @returns {number} 0 se le due date sono uguali, un numero minore di 0 se la prima data è precedente alla seconda e un numero maggiore di 0 altrimenti\r\n     */\r\n    compareDateWithTime(first: Dayjs, second: Dayjs, showSeconds?: boolean): number {\r\n        let res = super.compareDate(first, second) ||\r\n            this.getHour(first) - this.getHour(second) ||\r\n            this.getMinute(first) - this.getMinute(second);\r\n\r\n        if (showSeconds)\r\n            res = res || this.getSecond(first) - this.getSecond(second);\r\n            \r\n        return res;\r\n    }\r\n\r\n    /**\r\n     * Assegna a una data i valori di ore, minuti e secondi di default. \r\n     * \r\n     * Se non specificati vengono assegnati degli '0'\r\n     * \r\n     * @param {DayJs} date Data a cui assegnare i valori di default\r\n     * @param {number[]} defaultTime Valori di default per ore, minuti e secondi, considerati 0 se non presenti\r\n     */\r\n    setTimeByDefaultValues(date: Dayjs, defaultTime: number[]) {\r\n        if (!Array.isArray(defaultTime)) {\r\n            throw Error('@Input DefaultTime should be an array');\r\n        }\r\n        this.setHour(date, defaultTime[0] || 0);\r\n        this.setMinute(date, defaultTime[1] || 0);\r\n        this.setSecond(date, defaultTime[2] || 0);\r\n    }\r\n}"]}
@@ -1,8 +1,8 @@
1
- import { InjectionToken } from '@angular/core';
2
- /** Chiave che indica il prefisso dei Contesti Applicativi per permettere l'abilitazione/disabilitazione di input in maniera contestuale */
3
- export const ACO_CUSTOMKEY = new InjectionToken('ACO_CUSTOMKEY');
4
- /** Token che indica la lingua da utilizzare, sono supportate "it-IT" ed "en-US" */
5
- export const FAV_DEBUG_MODE = new InjectionToken('FAV_DEBUG_MODE');
6
- /** Token che indica se far apparire l'input delle checkbox come slider o come input nativi */
7
- export const FAV_SLIDER_MODE = new InjectionToken('FAV_SLIDER_MODE');
1
+ import { InjectionToken } from '@angular/core';
2
+ /** Chiave che indica il prefisso dei Contesti Applicativi per permettere l'abilitazione/disabilitazione di input in maniera contestuale */
3
+ export const ACO_CUSTOMKEY = new InjectionToken('ACO_CUSTOMKEY');
4
+ /** Token che indica la lingua da utilizzare, sono supportate "it-IT" ed "en-US" */
5
+ export const FAV_DEBUG_MODE = new InjectionToken('FAV_DEBUG_MODE');
6
+ /** Token che indica se far apparire l'input delle checkbox come slider o come input nativi */
7
+ export const FAV_SLIDER_MODE = new InjectionToken('FAV_SLIDER_MODE');
8
8
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybXMtYW5kLXZhbGlkYXRpb25zL3NyYy9saWIvdG9rZW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsMklBQTJJO0FBQzNJLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBMkIsSUFBSSxjQUFjLENBQVMsZUFBZSxDQUFDLENBQUM7QUFFakcsbUZBQW1GO0FBQ25GLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBNEIsSUFBSSxjQUFjLENBQVUsZ0JBQWdCLENBQUMsQ0FBQztBQUVyRyw4RkFBOEY7QUFDOUYsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUE0QixJQUFJLGNBQWMsQ0FBVSxpQkFBaUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKiBDaGlhdmUgY2hlIGluZGljYSBpbCBwcmVmaXNzbyBkZWkgQ29udGVzdGkgQXBwbGljYXRpdmkgcGVyIHBlcm1ldHRlcmUgbCdhYmlsaXRhemlvbmUvZGlzYWJpbGl0YXppb25lIGRpIGlucHV0IGluIG1hbmllcmEgY29udGVzdHVhbGUgKi9cclxuZXhwb3J0IGNvbnN0IEFDT19DVVNUT01LRVk6IEluamVjdGlvblRva2VuPHN0cmluZz4gPSBuZXcgSW5qZWN0aW9uVG9rZW48c3RyaW5nPignQUNPX0NVU1RPTUtFWScpO1xyXG5cclxuLyoqIFRva2VuIGNoZSBpbmRpY2EgbGEgbGluZ3VhIGRhIHV0aWxpenphcmUsIHNvbm8gc3VwcG9ydGF0ZSBcIml0LUlUXCIgZWQgXCJlbi1VU1wiICovXHJcbmV4cG9ydCBjb25zdCBGQVZfREVCVUdfTU9ERTogSW5qZWN0aW9uVG9rZW48Ym9vbGVhbj4gPSBuZXcgSW5qZWN0aW9uVG9rZW48Ym9vbGVhbj4oJ0ZBVl9ERUJVR19NT0RFJyk7XHJcblxyXG4vKiogVG9rZW4gY2hlIGluZGljYSBzZSBmYXIgYXBwYXJpcmUgbCdpbnB1dCBkZWxsZSBjaGVja2JveCBjb21lIHNsaWRlciBvIGNvbWUgaW5wdXQgbmF0aXZpICovXHJcbmV4cG9ydCBjb25zdCBGQVZfU0xJREVSX01PREU6IEluamVjdGlvblRva2VuPGJvb2xlYW4+ID0gbmV3IEluamVjdGlvblRva2VuPGJvb2xlYW4+KCdGQVZfU0xJREVSX01PREUnKTsiXX0=
@@ -1,23 +1,23 @@
1
- import { Injectable } from "@angular/core";
2
- import { LocalizationService } from "@esfaenza/localizations";
3
- import * as i0 from "@angular/core";
4
- /**
5
- * Classe di localizzazione in comune con tutti i Componenti di validazione
6
- */
7
- export class BaseValidationLoc extends LocalizationService {
8
- /**
9
- * @ignore
10
- */
11
- constructor(injector) {
12
- super(injector);
13
- super.set("en->it", "Required Input", ["Input Richiesto"]);
14
- super.set("en->it", "Invalid Input Format", ["Formato Input Invalido"]);
15
- super.set("en->it", "Elements selected", ["Elementi selezionati"]);
16
- }
17
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BaseValidationLoc, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable }); }
18
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BaseValidationLoc }); }
19
- }
20
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BaseValidationLoc, decorators: [{
21
- type: Injectable
22
- }], ctorParameters: function () { return [{ type: i0.Injector }]; } });
1
+ import { Injectable } from "@angular/core";
2
+ import { LocalizationService } from "@esfaenza/localizations";
3
+ import * as i0 from "@angular/core";
4
+ /**
5
+ * Classe di localizzazione in comune con tutti i Componenti di validazione
6
+ */
7
+ export class BaseValidationLoc extends LocalizationService {
8
+ /**
9
+ * @ignore
10
+ */
11
+ constructor(injector) {
12
+ super(injector);
13
+ super.set("en->it", "Required Input", ["Input Richiesto"]);
14
+ super.set("en->it", "Invalid Input Format", ["Formato Input Invalido"]);
15
+ super.set("en->it", "Elements selected", ["Elementi selezionati"]);
16
+ }
17
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseValidationLoc, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable }); }
18
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseValidationLoc }); }
19
+ }
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseValidationLoc, decorators: [{
21
+ type: Injectable
22
+ }], ctorParameters: () => [{ type: i0.Injector }] });
23
23
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS12YWxpZGF0aW9uLmxvYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Zvcm1zLWFuZC12YWxpZGF0aW9ucy9zcmMvbGliL3ZhbGlkYXRpb25zL2Jhc2UtdmFsaWRhdGlvbi5sb2MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUNyRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFFOUQ7O0dBRUc7QUFFSCxNQUFNLE9BQU8saUJBQWtCLFNBQVEsbUJBQW1CO0lBRXREOztPQUVHO0lBQ0gsWUFBWSxRQUFrQjtRQUMxQixLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDaEIsS0FBSyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUM7UUFDM0QsS0FBSyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsc0JBQXNCLEVBQUUsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDLENBQUM7UUFDeEUsS0FBSyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsbUJBQW1CLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDLENBQUM7SUFDdkUsQ0FBQzsrR0FWUSxpQkFBaUI7bUhBQWpCLGlCQUFpQjs7NEZBQWpCLGlCQUFpQjtrQkFEN0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEluamVjdG9yIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTG9jYWxpemF0aW9uU2VydmljZSB9IGZyb20gXCJAZXNmYWVuemEvbG9jYWxpemF0aW9uc1wiO1xyXG5cclxuLyoqXHJcbiAqIENsYXNzZSBkaSBsb2NhbGl6emF6aW9uZSBpbiBjb211bmUgY29uIHR1dHRpIGkgQ29tcG9uZW50aSBkaSB2YWxpZGF6aW9uZVxyXG4gKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgQmFzZVZhbGlkYXRpb25Mb2MgZXh0ZW5kcyBMb2NhbGl6YXRpb25TZXJ2aWNlIHtcclxuXHJcbiAgICAvKipcclxuICAgICAqIEBpZ25vcmVcclxuICAgICAqL1xyXG4gICAgY29uc3RydWN0b3IoaW5qZWN0b3I6IEluamVjdG9yKSB7XHJcbiAgICAgICAgc3VwZXIoaW5qZWN0b3IpO1xyXG4gICAgICAgIHN1cGVyLnNldChcImVuLT5pdFwiLCBcIlJlcXVpcmVkIElucHV0XCIsIFtcIklucHV0IFJpY2hpZXN0b1wiXSk7XHJcbiAgICAgICAgc3VwZXIuc2V0KFwiZW4tPml0XCIsIFwiSW52YWxpZCBJbnB1dCBGb3JtYXRcIiwgW1wiRm9ybWF0byBJbnB1dCBJbnZhbGlkb1wiXSk7XHJcbiAgICAgICAgc3VwZXIuc2V0KFwiZW4tPml0XCIsIFwiRWxlbWVudHMgc2VsZWN0ZWRcIiwgW1wiRWxlbWVudGkgc2VsZXppb25hdGlcIl0pO1xyXG4gICAgfVxyXG59Il19