@esfaenza/forms-and-validations 12.2.31 → 13.1.5

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 (118) hide show
  1. package/esfaenza-forms-and-validations.d.ts +1 -12
  2. package/esm2020/esfaenza-forms-and-validations.mjs +5 -0
  3. package/esm2020/lib/forms/base-form-control.mjs +482 -0
  4. package/esm2020/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +28 -0
  5. package/esm2020/lib/forms/form-adaptive/form-adaptive.component.mjs +294 -0
  6. package/esm2020/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +26 -0
  7. package/esm2020/lib/forms/form-autocomplete/form-autocomplete.component.mjs +200 -0
  8. package/esm2020/lib/forms/form-checkbox/form-checkbox.component.mjs +52 -0
  9. package/esm2020/lib/forms/form-date/form-date.component.mjs +59 -0
  10. package/esm2020/lib/forms/form-datetime/form-datetime.component.mjs +59 -0
  11. package/esm2020/lib/forms/form-empty/form-empty.component.mjs +36 -0
  12. package/esm2020/lib/forms/form-error/form-error.component.mjs +52 -0
  13. package/esm2020/lib/forms/form-file/form-file.component.loc.mjs +28 -0
  14. package/esm2020/lib/forms/form-file/form-file.component.mjs +119 -0
  15. package/esm2020/lib/forms/form-info/form-info.component.mjs +52 -0
  16. package/esm2020/lib/forms/form-input/form-input.component.mjs +93 -0
  17. package/esm2020/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +29 -0
  18. package/esm2020/lib/forms/form-multiselect/form-multiselect.component.mjs +159 -0
  19. package/esm2020/lib/forms/form-select/form-select.component.loc.mjs +26 -0
  20. package/esm2020/lib/forms/form-select/form-select.component.mjs +129 -0
  21. package/esm2020/lib/forms/form-template/form-template.component.mjs +71 -0
  22. package/esm2020/lib/forms/form-textarea/form-textarea.component.mjs +54 -0
  23. package/esm2020/lib/forms/form-time/form-time.component.mjs +131 -0
  24. package/esm2020/lib/forms-and-validations.module.mjs +203 -0
  25. package/{esm2015/lib/models/AppFile.js → esm2020/lib/models/AppFile.mjs} +0 -0
  26. package/{esm2015/lib/models/FormsAndValidationsModuleConfig.js → esm2020/lib/models/FormsAndValidationsModuleConfig.mjs} +0 -0
  27. package/esm2020/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +89 -0
  28. package/{esm2015/lib/tokens.js → esm2020/lib/tokens.mjs} +0 -0
  29. package/esm2020/lib/validations/base-validation.loc.mjs +28 -0
  30. package/esm2020/lib/validations/base-validation.mjs +238 -0
  31. package/esm2020/lib/validations/customValidators/CustomRequiredDirective.mjs +41 -0
  32. package/esm2020/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +168 -0
  33. package/esm2020/lib/validations/validation-currency/validation-currency.component.mjs +61 -0
  34. package/esm2020/lib/validations/validation-date/validation-date.component.mjs +177 -0
  35. package/esm2020/lib/validations/validation-datetime/validation-datetime.component.mjs +206 -0
  36. package/esm2020/lib/validations/validation-input/validation-input.component.mjs +207 -0
  37. package/esm2020/lib/validations/validation-select/validation-select.component.mjs +184 -0
  38. package/esm2020/lib/validations/validation-text-area/validation-text-area.component.mjs +64 -0
  39. package/esm2020/public-api.mjs +35 -0
  40. package/fesm2015/esfaenza-forms-and-validations.mjs +3626 -0
  41. package/fesm2015/esfaenza-forms-and-validations.mjs.map +1 -0
  42. package/fesm2020/esfaenza-forms-and-validations.mjs +3568 -0
  43. package/fesm2020/esfaenza-forms-and-validations.mjs.map +1 -0
  44. package/lib/forms/base-form-control.d.ts +3 -0
  45. package/lib/forms/form-adaptive/form-adaptive.component.d.ts +3 -0
  46. package/lib/forms/form-adaptive/form-adaptive.component.loc.d.ts +3 -0
  47. package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +3 -0
  48. package/lib/forms/form-autocomplete/form-autocomplete.component.loc.d.ts +3 -0
  49. package/lib/forms/form-checkbox/form-checkbox.component.d.ts +3 -0
  50. package/lib/forms/form-date/form-date.component.d.ts +3 -0
  51. package/lib/forms/form-datetime/form-datetime.component.d.ts +3 -0
  52. package/lib/forms/form-empty/form-empty.component.d.ts +3 -0
  53. package/lib/forms/form-error/form-error.component.d.ts +3 -0
  54. package/lib/forms/form-file/form-file.component.d.ts +3 -0
  55. package/lib/forms/form-file/form-file.component.loc.d.ts +3 -0
  56. package/lib/forms/form-info/form-info.component.d.ts +3 -0
  57. package/lib/forms/form-input/form-input.component.d.ts +3 -0
  58. package/lib/forms/form-multiselect/form-multiselect.component.d.ts +3 -0
  59. package/lib/forms/form-multiselect/form-multiselect.component.loc.d.ts +3 -0
  60. package/lib/forms/form-select/form-select.component.d.ts +3 -0
  61. package/lib/forms/form-select/form-select.component.loc.d.ts +3 -0
  62. package/lib/forms/form-template/form-template.component.d.ts +3 -0
  63. package/lib/forms/form-textarea/form-textarea.component.d.ts +3 -0
  64. package/lib/forms/form-time/form-time.component.d.ts +3 -0
  65. package/lib/forms-and-validations.module.d.ts +38 -0
  66. package/lib/models/dayjs-adapter/dayjs-date-adapter.d.ts +3 -0
  67. package/lib/validations/base-validation.d.ts +7 -0
  68. package/lib/validations/base-validation.loc.d.ts +3 -0
  69. package/lib/validations/customValidators/CustomRequiredDirective.d.ts +3 -0
  70. package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +3 -0
  71. package/lib/validations/validation-currency/validation-currency.component.d.ts +3 -0
  72. package/lib/validations/validation-date/validation-date.component.d.ts +3 -0
  73. package/lib/validations/validation-datetime/validation-datetime.component.d.ts +3 -0
  74. package/lib/validations/validation-input/validation-input.component.d.ts +3 -0
  75. package/lib/validations/validation-select/validation-select.component.d.ts +3 -0
  76. package/lib/validations/validation-text-area/validation-text-area.component.d.ts +3 -0
  77. package/package.json +31 -19
  78. package/public-api.d.ts +2 -0
  79. package/bundles/esfaenza-forms-and-validations.umd.js +0 -3754
  80. package/bundles/esfaenza-forms-and-validations.umd.js.map +0 -1
  81. package/esfaenza-forms-and-validations.metadata.json +0 -1
  82. package/esm2015/esfaenza-forms-and-validations.js +0 -17
  83. package/esm2015/lib/forms/base-form-control.js +0 -460
  84. package/esm2015/lib/forms/form-adaptive/form-adaptive.component.js +0 -277
  85. package/esm2015/lib/forms/form-adaptive/form-adaptive.component.loc.js +0 -23
  86. package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.js +0 -187
  87. package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.loc.js +0 -21
  88. package/esm2015/lib/forms/form-checkbox/form-checkbox.component.js +0 -41
  89. package/esm2015/lib/forms/form-date/form-date.component.js +0 -49
  90. package/esm2015/lib/forms/form-datetime/form-datetime.component.js +0 -49
  91. package/esm2015/lib/forms/form-empty/form-empty.component.js +0 -34
  92. package/esm2015/lib/forms/form-error/form-error.component.js +0 -49
  93. package/esm2015/lib/forms/form-file/form-file.component.js +0 -109
  94. package/esm2015/lib/forms/form-file/form-file.component.loc.js +0 -23
  95. package/esm2015/lib/forms/form-info/form-info.component.js +0 -49
  96. package/esm2015/lib/forms/form-input/form-input.component.js +0 -76
  97. package/esm2015/lib/forms/form-multiselect/form-multiselect.component.js +0 -154
  98. package/esm2015/lib/forms/form-multiselect/form-multiselect.component.loc.js +0 -24
  99. package/esm2015/lib/forms/form-select/form-select.component.js +0 -114
  100. package/esm2015/lib/forms/form-select/form-select.component.loc.js +0 -21
  101. package/esm2015/lib/forms/form-template/form-template.component.js +0 -64
  102. package/esm2015/lib/forms/form-textarea/form-textarea.component.js +0 -44
  103. package/esm2015/lib/forms/form-time/form-time.component.js +0 -117
  104. package/esm2015/lib/forms-and-validations.module.js +0 -144
  105. package/esm2015/lib/models/dayjs-adapter/dayjs-date-adapter.js +0 -86
  106. package/esm2015/lib/validations/base-validation.js +0 -208
  107. package/esm2015/lib/validations/base-validation.loc.js +0 -23
  108. package/esm2015/lib/validations/customValidators/CustomRequiredDirective.js +0 -35
  109. package/esm2015/lib/validations/validation-autocomplete/validation-autocomplete.component.js +0 -151
  110. package/esm2015/lib/validations/validation-currency/validation-currency.component.js +0 -48
  111. package/esm2015/lib/validations/validation-date/validation-date.component.js +0 -165
  112. package/esm2015/lib/validations/validation-datetime/validation-datetime.component.js +0 -193
  113. package/esm2015/lib/validations/validation-input/validation-input.component.js +0 -186
  114. package/esm2015/lib/validations/validation-select/validation-select.component.js +0 -166
  115. package/esm2015/lib/validations/validation-text-area/validation-text-area.component.js +0 -52
  116. package/esm2015/public-api.js +0 -32
  117. package/fesm2015/esfaenza-forms-and-validations.js +0 -3262
  118. package/fesm2015/esfaenza-forms-and-validations.js.map +0 -1
@@ -1,144 +0,0 @@
1
- // Angular
2
- import { NgModule } from '@angular/core';
3
- import { CommonModule } from '@angular/common';
4
- import { FormsModule } from '@angular/forms';
5
- import { MatDatepickerModule } from '@angular/material/datepicker';
6
- import { MatAutocompleteModule } from '@angular/material/autocomplete';
7
- import { MatInputModule } from "@angular/material/input";
8
- import { MAT_DATE_LOCALE, MAT_DATE_FORMATS } from "@angular/material/core";
9
- // Es
10
- import { LocalizationModule } from "@esfaenza/localizations";
11
- import { MatDayjsDateModule } from '@esfaenza/material-dayjs-adapter';
12
- import { CurrencyMaskModule } from '@esfaenza/ngx-currency-mask';
13
- // Librerie / Modelli
14
- import { AngularMultiSelectModule } from "angular2-multiselect-dropdown";
15
- import { NgxMatDateAdapter, NgxMatDatetimePickerModule, NGX_MAT_DATE_FORMATS, NgxMatTimepickerModule } from '@angular-material-components/datetime-picker';
16
- import { TooltipModule } from 'ngx-bootstrap/tooltip';
17
- import { FAV_LOCALE, ACO_CUSTOMKEY } from './tokens';
18
- import { CustomRequiredDirective } from './validations/customValidators/CustomRequiredDirective';
19
- import { NgxExpandedDayJsDateAdapter } from './models/dayjs-adapter/dayjs-date-adapter';
20
- // Validations
21
- import { ValidationSelectComponent } from './validations/validation-select/validation-select.component';
22
- import { ValidationDateComponent } from './validations/validation-date/validation-date.component';
23
- import { ValidationCurrencyComponent } from './validations/validation-currency/validation-currency.component';
24
- import { ValidationTextAreaComponent } from './validations/validation-text-area/validation-text-area.component';
25
- import { ValidationInputComponent } from './validations/validation-input/validation-input.component';
26
- import { ValidationDateTimeComponent } from './validations/validation-datetime/validation-datetime.component';
27
- import { ValidationAutocompleteComponent } from './validations/validation-autocomplete/validation-autocomplete.component';
28
- // Forms
29
- import { FormFileComponent } from './forms/form-file/form-file.component';
30
- import { FormDateTimeComponent } from './forms/form-datetime/form-datetime.component';
31
- import { FormAdaptiveComponent } from './forms/form-adaptive/form-adaptive.component';
32
- import { FormEmptyComponent } from './forms/form-empty/form-empty.component';
33
- import { FormTemplateComponent } from './forms/form-template/form-template.component';
34
- import { FormErrorComponent } from './forms/form-error/form-error.component';
35
- import { FormInfoComponent } from './forms/form-info/form-info.component';
36
- import { FormCheckboxComponent } from './forms/form-checkbox/form-checkbox.component';
37
- import { FormDateComponent } from './forms/form-date/form-date.component';
38
- import { FormInputComponent } from './forms/form-input/form-input.component';
39
- import { FormSelectComponent } from './forms/form-select/form-select.component';
40
- import { FormMultiSelectComponent } from './forms/form-multiselect/form-multiselect.component';
41
- import { FormTextareaComponent } from './forms/form-textarea/form-textarea.component';
42
- import { FormAutocompleteComponent } from './forms/form-autocomplete/form-autocomplete.component';
43
- import { FormTimeComponent } from './forms/form-time/form-time.component';
44
- /**
45
- * Formato in display (modalità breve, senza ore, minuti e secondi) delle date per tutti i componenti che utilizzino input data.
46
- *
47
- * Da convenzione è sempre quello italiano quindi viene cablato
48
- */
49
- const formats = {
50
- parse: { dateInput: 'DD/MM/YYYY' },
51
- display: {
52
- dateInput: 'DD/MM/YYYY',
53
- monthYearLabel: 'MM YYYY',
54
- dateA11yLabel: 'DD/MM/YYYY',
55
- monthYearA11yLabel: 'MM YYYY',
56
- }
57
- };
58
- /**
59
- * Formato in display (modalità lunga, con ore, minuti e secondi) delle date per tutti i componenti che utilizzino input data.
60
- *
61
- * Da convenzione è sempre quello italiano quindi viene cablato
62
- */
63
- const formats_long = {
64
- parse: { dateInput: 'DD/MM/YYYY HH:mm:ss' },
65
- display: {
66
- dateInput: 'DD/MM/YYYY HH:mm:ss',
67
- monthYearLabel: 'MM YYYY',
68
- dateA11yLabel: 'DD/MM/YYYY HH:mm:ss',
69
- monthYearA11yLabel: 'MM YYYY',
70
- }
71
- };
72
- /**
73
- * Componenti Dichiarati ed esportati dalla libreria
74
- */
75
- const COMPONENTS = [
76
- ValidationInputComponent,
77
- ValidationSelectComponent,
78
- ValidationDateComponent,
79
- CustomRequiredDirective,
80
- ValidationCurrencyComponent,
81
- ValidationTextAreaComponent,
82
- FormCheckboxComponent,
83
- FormDateComponent,
84
- FormEmptyComponent,
85
- FormInputComponent,
86
- FormSelectComponent,
87
- FormTextareaComponent,
88
- FormTemplateComponent,
89
- FormErrorComponent,
90
- FormInfoComponent,
91
- FormAdaptiveComponent,
92
- FormMultiSelectComponent,
93
- FormFileComponent,
94
- ValidationAutocompleteComponent,
95
- FormAutocompleteComponent,
96
- FormDateTimeComponent,
97
- ValidationDateTimeComponent,
98
- FormTimeComponent
99
- ];
100
- /**
101
- * Moduli utilizzati solo dalla libreria
102
- */
103
- const MODULES = [
104
- CommonModule,
105
- FormsModule,
106
- LocalizationModule,
107
- MatInputModule,
108
- MatDatepickerModule,
109
- MatDayjsDateModule,
110
- TooltipModule,
111
- CurrencyMaskModule,
112
- MatAutocompleteModule,
113
- NgxMatDatetimePickerModule,
114
- NgxMatTimepickerModule
115
- ];
116
- /**
117
- * Moduli utilizzati dalla libreria e che devono essere esposti all'esterno
118
- */
119
- const MODULES_TO_EXPORT = [
120
- AngularMultiSelectModule
121
- ];
122
- export class FormsAndValidationsModule {
123
- static forRoot(config) {
124
- return {
125
- ngModule: FormsAndValidationsModule,
126
- providers: [
127
- { provide: FAV_LOCALE, useValue: (config === null || config === void 0 ? void 0 : config.locale) || 'it-IT' },
128
- { provide: ACO_CUSTOMKEY, useValue: (config === null || config === void 0 ? void 0 : config.acocustom) || null },
129
- { provide: MAT_DATE_LOCALE, useValue: 'it' },
130
- { provide: MAT_DATE_FORMATS, useValue: formats },
131
- { provide: NGX_MAT_DATE_FORMATS, useValue: formats_long },
132
- { provide: NgxMatDateAdapter, useClass: NgxExpandedDayJsDateAdapter },
133
- ]
134
- };
135
- }
136
- }
137
- FormsAndValidationsModule.decorators = [
138
- { type: NgModule, args: [{
139
- imports: [...MODULES, ...MODULES_TO_EXPORT],
140
- declarations: [...COMPONENTS],
141
- exports: [...MODULES_TO_EXPORT, ...COMPONENTS]
142
- },] }
143
- ];
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forms-and-validations.module.js","sourceRoot":"","sources":["../../../../projects/forms-and-validations/src/lib/forms-and-validations.module.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ModuleWithProviders, NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\r\nimport { MatInputModule } from \"@angular/material/input\";\r\nimport { MAT_DATE_LOCALE, MAT_DATE_FORMATS } from \"@angular/material/core\";\r\n\r\n// Es\r\nimport { LocalizationModule } from \"@esfaenza/localizations\";\r\nimport { MatDayjsDateModule } from '@esfaenza/material-dayjs-adapter';\r\nimport { CurrencyMaskModule } from '@esfaenza/ngx-currency-mask';\r\n\r\n// Librerie / Modelli\r\nimport { AngularMultiSelectModule } from \"angular2-multiselect-dropdown\";\r\nimport { NgxMatDateAdapter, NgxMatDatetimePickerModule, NGX_MAT_DATE_FORMATS, NgxMatTimepickerModule } from '@angular-material-components/datetime-picker';\r\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\r\n\r\nimport { FAV_LOCALE, ACO_CUSTOMKEY } from './tokens';\r\nimport { FormsAndValidationsModuleConfig } from './models/FormsAndValidationsModuleConfig';\r\nimport { CustomRequiredDirective } from './validations/customValidators/CustomRequiredDirective';\r\nimport { NgxExpandedDayJsDateAdapter } from './models/dayjs-adapter/dayjs-date-adapter';\r\n\r\n// Validations\r\nimport { ValidationSelectComponent } from './validations/validation-select/validation-select.component';\r\nimport { ValidationDateComponent } from './validations/validation-date/validation-date.component';\r\nimport { ValidationCurrencyComponent } from './validations/validation-currency/validation-currency.component';\r\nimport { ValidationTextAreaComponent } from './validations/validation-text-area/validation-text-area.component';\r\nimport { ValidationInputComponent } from './validations/validation-input/validation-input.component';\r\nimport { ValidationDateTimeComponent } from './validations/validation-datetime/validation-datetime.component';\r\nimport { ValidationAutocompleteComponent } from './validations/validation-autocomplete/validation-autocomplete.component';\r\n\r\n// Forms\r\nimport { FormFileComponent } from './forms/form-file/form-file.component';\r\nimport { FormDateTimeComponent } from './forms/form-datetime/form-datetime.component';\r\nimport { FormAdaptiveComponent } from './forms/form-adaptive/form-adaptive.component';\r\nimport { FormEmptyComponent } from './forms/form-empty/form-empty.component';\r\nimport { FormTemplateComponent } from './forms/form-template/form-template.component';\r\nimport { FormErrorComponent } from './forms/form-error/form-error.component';\r\nimport { FormInfoComponent } from './forms/form-info/form-info.component';\r\nimport { FormCheckboxComponent } from './forms/form-checkbox/form-checkbox.component';\r\nimport { FormDateComponent } from './forms/form-date/form-date.component';\r\nimport { FormInputComponent } from './forms/form-input/form-input.component';\r\nimport { FormSelectComponent } from './forms/form-select/form-select.component';\r\nimport { FormMultiSelectComponent } from './forms/form-multiselect/form-multiselect.component';\r\nimport { FormTextareaComponent } from './forms/form-textarea/form-textarea.component';\r\nimport { FormAutocompleteComponent } from './forms/form-autocomplete/form-autocomplete.component';\r\nimport { FormTimeComponent } from './forms/form-time/form-time.component';\r\n\r\n/**\r\n * Formato in display (modalità breve, senza ore, minuti e secondi) delle date per tutti i componenti che utilizzino input data.\r\n * \r\n * Da convenzione è sempre quello italiano quindi viene cablato\r\n */\r\nconst formats = {\r\n  parse: { dateInput: 'DD/MM/YYYY' },\r\n  display: {\r\n    dateInput: 'DD/MM/YYYY',\r\n    monthYearLabel: 'MM YYYY',\r\n    dateA11yLabel: 'DD/MM/YYYY',\r\n    monthYearA11yLabel: 'MM YYYY',\r\n  }\r\n};\r\n\r\n/**\r\n * Formato in display (modalità lunga, con ore, minuti e secondi) delle date per tutti i componenti che utilizzino input data.\r\n * \r\n * Da convenzione è sempre quello italiano quindi viene cablato\r\n */\r\nconst formats_long = {\r\n  parse: { dateInput: 'DD/MM/YYYY HH:mm:ss' },\r\n  display: {\r\n    dateInput: 'DD/MM/YYYY HH:mm:ss',\r\n    monthYearLabel: 'MM YYYY',\r\n    dateA11yLabel: 'DD/MM/YYYY HH:mm:ss',\r\n    monthYearA11yLabel: 'MM YYYY',\r\n  }\r\n};\r\n\r\n/**\r\n * Componenti Dichiarati ed esportati dalla libreria\r\n */\r\nconst COMPONENTS = [\r\n  ValidationInputComponent,\r\n  ValidationSelectComponent,\r\n  ValidationDateComponent,\r\n  CustomRequiredDirective,\r\n  ValidationCurrencyComponent,\r\n  ValidationTextAreaComponent,\r\n  FormCheckboxComponent,\r\n  FormDateComponent,\r\n  FormEmptyComponent,\r\n  FormInputComponent,\r\n  FormSelectComponent,\r\n  FormTextareaComponent,\r\n  FormTemplateComponent,\r\n  FormErrorComponent,\r\n  FormInfoComponent,\r\n  FormAdaptiveComponent,\r\n  FormMultiSelectComponent,\r\n  FormFileComponent,\r\n  ValidationAutocompleteComponent,\r\n  FormAutocompleteComponent,\r\n  FormDateTimeComponent,\r\n  ValidationDateTimeComponent,\r\n  FormTimeComponent\r\n];\r\n\r\n/**\r\n * Moduli utilizzati solo dalla libreria\r\n */\r\nconst MODULES = [\r\n  CommonModule,\r\n  FormsModule,\r\n  LocalizationModule,\r\n  MatInputModule,\r\n  MatDatepickerModule,\r\n  MatDayjsDateModule,\r\n  TooltipModule,\r\n  CurrencyMaskModule,\r\n  MatAutocompleteModule,\r\n  NgxMatDatetimePickerModule,\r\n  NgxMatTimepickerModule\r\n];\r\n\r\n/**\r\n * Moduli utilizzati dalla libreria e che devono essere esposti all'esterno\r\n */\r\nconst MODULES_TO_EXPORT = [\r\n  AngularMultiSelectModule\r\n];\r\n\r\n@NgModule({\r\n  imports: [...MODULES, ...MODULES_TO_EXPORT],\r\n  declarations: [...COMPONENTS],\r\n  exports: [...MODULES_TO_EXPORT, ...COMPONENTS]\r\n})\r\nexport class FormsAndValidationsModule {\r\n  static forRoot(config?: FormsAndValidationsModuleConfig): ModuleWithProviders<FormsAndValidationsModule> {\r\n    return {\r\n      ngModule: FormsAndValidationsModule,\r\n      providers: [\r\n        { provide: FAV_LOCALE, useValue: config?.locale || 'it-IT' },\r\n        { provide: ACO_CUSTOMKEY, useValue: config?.acocustom || null },\r\n        { provide: MAT_DATE_LOCALE, useValue: 'it' },\r\n        { provide: MAT_DATE_FORMATS, useValue: formats },\r\n        { provide: NGX_MAT_DATE_FORMATS, useValue: formats_long },\r\n        { provide: NgxMatDateAdapter, useClass: NgxExpandedDayJsDateAdapter },\r\n      ]\r\n    };\r\n  }\r\n}"]}
@@ -1,86 +0,0 @@
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
- /**
9
- * Espansione dell'adapter di default di DayJs già utilizzato per i bind base su Material.
10
- *
11
- * Questa versione serve unicamente per i controlli **datetime-picker**, ma dato che io l'adapter già lo avevo lato **esfaenza/material-dayjs-adapter**
12
- * qui devo semplicemente aggiungere le funzioni non presenti nella mia implementazione che servono al **datetime-picker**
13
- */
14
- export class NgxExpandedDayJsDateAdapter extends DayJsDateAdapter {
15
- /**
16
- * @ignore
17
- */
18
- constructor(dateLocale) {
19
- super(dateLocale);
20
- }
21
- // Espando il mio DayJsDateAdapter con i metodi extra del NgxMatDateAdapter che servono per il material timepicker
22
- // Non potendo fare "extends" da due classi mi tocca tenerlo così senza type safety....
23
- /**
24
- * Identifica se due date hanno lo stesso orario
25
- *
26
- * @param {DayJs} a Primo elemento del controllo
27
- * @param {DayJs} b Secondo elemento del controllo
28
- * @returns **true** se hanno lo stess orario, **false** altrimenti
29
- */
30
- isSameTime(a, b) {
31
- if (a == null || b == null)
32
- return true;
33
- return this.getHour(a) === this.getHour(b)
34
- && this.getMinute(a) === this.getMinute(b)
35
- && this.getSecond(a) === this.getSecond(b);
36
- }
37
- /**
38
- * Copia dell'orario da una data all'altra, Modifica direttamente l'oggetto **toDate**
39
- *
40
- * @param {DayJs} toDate Data in cui copiare l'orario
41
- * @param {DayJs} fromDate Data da cui copiare l'orario
42
- */
43
- copyTime(toDate, fromDate) {
44
- this.setHour(toDate, this.getHour(fromDate));
45
- this.setMinute(toDate, this.getMinute(fromDate));
46
- this.setSecond(toDate, this.getSecond(fromDate));
47
- }
48
- /**
49
- * Mette a confronto due date
50
- * @param {Dayjs} first Prima data da confrontare
51
- * @param {Dayjs} second Seconda data da confrontare
52
- * @param {boolean} showSeconds Indica se considerare anche i secondi, di default no
53
- * @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
54
- */
55
- compareDateWithTime(first, second, showSeconds) {
56
- let res = super.compareDate(first, second) ||
57
- this.getHour(first) - this.getHour(second) ||
58
- this.getMinute(first) - this.getMinute(second);
59
- if (showSeconds)
60
- res = res || this.getSecond(first) - this.getSecond(second);
61
- return res;
62
- }
63
- /**
64
- * Assegna a una data i valori di ore, minuti e secondi di default.
65
- *
66
- * Se non specificati vengono assegnati degli '0'
67
- *
68
- * @param {DayJs} date Data a cui assegnare i valori di default
69
- * @param {number[]} defaultTime Valori di default per ore, minuti e secondi, considerati 0 se non presenti
70
- */
71
- setTimeByDefaultValues(date, defaultTime) {
72
- if (!Array.isArray(defaultTime)) {
73
- throw Error('@Input DefaultTime should be an array');
74
- }
75
- this.setHour(date, defaultTime[0] || 0);
76
- this.setMinute(date, defaultTime[1] || 0);
77
- this.setSecond(date, defaultTime[2] || 0);
78
- }
79
- }
80
- NgxExpandedDayJsDateAdapter.decorators = [
81
- { type: Injectable }
82
- ];
83
- NgxExpandedDayJsDateAdapter.ctorParameters = () => [
84
- { type: String, decorators: [{ type: Inject, args: [MAT_DATE_LOCALE,] }] }
85
- ];
86
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5anMtZGF0ZS1hZGFwdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybXMtYW5kLXZhbGlkYXRpb25zL3NyYy9saWIvbW9kZWxzL2RheWpzLWFkYXB0ZXIvZGF5anMtZGF0ZS1hZGFwdGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFNBQVM7QUFDVCxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQW9CLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRTNFLFVBQVU7QUFDVix5RUFBeUU7QUFDekUsbUZBQW1GO0FBQ25GLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBR3BFOzs7OztHQUtHO0FBRUgsTUFBTSxPQUFPLDJCQUE0QixTQUFRLGdCQUFnQjtJQUU3RDs7T0FFRztJQUNILFlBQXFDLFVBQWtCO1FBQ25ELEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN0QixDQUFDO0lBRUQsa0hBQWtIO0lBQ2xILHdGQUF3RjtJQUV4Rjs7Ozs7O09BTUc7SUFDSCxVQUFVLENBQUMsQ0FBUSxFQUFFLENBQVE7UUFDekIsSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJO1lBQUUsT0FBTyxJQUFJLENBQUM7UUFDeEMsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO2VBQ25DLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7ZUFDdkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILFFBQVEsQ0FBQyxNQUFhLEVBQUUsUUFBZTtRQUNuQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDN0MsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1FBQ2pELElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUNyRCxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsbUJBQW1CLENBQUMsS0FBWSxFQUFFLE1BQWEsRUFBRSxXQUFxQjtRQUNsRSxJQUFJLEdBQUcsR0FBRyxLQUFLLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUM7WUFDdEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztZQUMxQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFbkQsSUFBSSxXQUFXO1lBQ1gsR0FBRyxHQUFHLEdBQUcsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFaEUsT0FBTyxHQUFHLENBQUM7SUFDZixDQUFDO0lBRUQ7Ozs7Ozs7T0FPRztJQUNILHNCQUFzQixDQUFDLElBQVcsRUFBRSxXQUFxQjtRQUNyRCxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUM3QixNQUFNLEtBQUssQ0FBQyx1Q0FBdUMsQ0FBQyxDQUFDO1NBQ3hEO1FBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQ3hDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDOUMsQ0FBQzs7O1lBeEVKLFVBQVU7Ozt5Q0FNTSxNQUFNLFNBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbIi8vQW5ndWxhclxyXG5pbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBNQVRfREFURV9GT1JNQVRTLCBNQVRfREFURV9MT0NBTEUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZVwiO1xyXG5cclxuLy9MaWJyZXJpYVxyXG4vLyBRdWVzdGEgbm9uIMOoIHBpw7kgdXNhdGEsIGxhIHRlbmdvIHF1aSBwZXIgY3Jvc3NjaGVjayBpbiBjYXNvIGRpIHVwZGF0ZXNcclxuLy9pbXBvcnQgeyBOZ3hNYXREYXRlQWRhcHRlciB9IGZyb20gXCJAYW5ndWxhci1tYXRlcmlhbC1jb21wb25lbnRzL2RhdGV0aW1lLXBpY2tlclwiO1xyXG5pbXBvcnQgeyBEYXlKc0RhdGVBZGFwdGVyIH0gZnJvbSBcIkBlc2ZhZW56YS9tYXRlcmlhbC1kYXlqcy1hZGFwdGVyXCI7XHJcbmltcG9ydCB7IERheWpzIH0gZnJvbSBcImRheWpzXCI7XHJcblxyXG4vKipcclxuICogRXNwYW5zaW9uZSBkZWxsJ2FkYXB0ZXIgZGkgZGVmYXVsdCBkaSBEYXlKcyBnacOgIHV0aWxpenphdG8gcGVyIGkgYmluZCBiYXNlIHN1IE1hdGVyaWFsLlxyXG4gKiBcclxuICogUXVlc3RhIHZlcnNpb25lIHNlcnZlIHVuaWNhbWVudGUgcGVyIGkgY29udHJvbGxpICoqZGF0ZXRpbWUtcGlja2VyKiosIG1hIGRhdG8gY2hlIGlvIGwnYWRhcHRlciBnacOgIGxvIGF2ZXZvIGxhdG8gKiplc2ZhZW56YS9tYXRlcmlhbC1kYXlqcy1hZGFwdGVyKiogXHJcbiAqIHF1aSBkZXZvIHNlbXBsaWNlbWVudGUgYWdnaXVuZ2VyZSBsZSBmdW56aW9uaSBub24gcHJlc2VudGkgbmVsbGEgbWlhIGltcGxlbWVudGF6aW9uZSBjaGUgc2Vydm9ubyBhbCAqKmRhdGV0aW1lLXBpY2tlcioqXHJcbiAqL1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBOZ3hFeHBhbmRlZERheUpzRGF0ZUFkYXB0ZXIgZXh0ZW5kcyBEYXlKc0RhdGVBZGFwdGVyIHtcclxuXHJcbiAgICAvKipcclxuICAgICAqIEBpZ25vcmVcclxuICAgICAqL1xyXG4gICAgY29uc3RydWN0b3IoQEluamVjdChNQVRfREFURV9MT0NBTEUpIGRhdGVMb2NhbGU6IHN0cmluZykge1xyXG4gICAgICAgIHN1cGVyKGRhdGVMb2NhbGUpO1xyXG4gICAgfVxyXG5cclxuICAgIC8vIEVzcGFuZG8gaWwgbWlvIERheUpzRGF0ZUFkYXB0ZXIgY29uIGkgbWV0b2RpIGV4dHJhIGRlbCBOZ3hNYXREYXRlQWRhcHRlciBjaGUgc2Vydm9ubyBwZXIgaWwgbWF0ZXJpYWwgdGltZXBpY2tlclxyXG4gICAgLy8gTm9uIHBvdGVuZG8gZmFyZSBcImV4dGVuZHNcIiBkYSBkdWUgY2xhc3NpIG1pIHRvY2NhIHRlbmVybG8gY29zw6wgc2VuemEgdHlwZSBzYWZldHkuLi4uIFxyXG5cclxuICAgIC8qKlxyXG4gICAgICogSWRlbnRpZmljYSBzZSBkdWUgZGF0ZSBoYW5ubyBsbyBzdGVzc28gb3JhcmlvXHJcbiAgICAgKiBcclxuICAgICAqIEBwYXJhbSB7RGF5SnN9IGEgUHJpbW8gZWxlbWVudG8gZGVsIGNvbnRyb2xsb1xyXG4gICAgICogQHBhcmFtIHtEYXlKc30gYiBTZWNvbmRvIGVsZW1lbnRvIGRlbCBjb250cm9sbG9cclxuICAgICAqIEByZXR1cm5zICoqdHJ1ZSoqIHNlIGhhbm5vIGxvIHN0ZXNzIG9yYXJpbywgKipmYWxzZSoqIGFsdHJpbWVudGlcclxuICAgICAqL1xyXG4gICAgaXNTYW1lVGltZShhOiBEYXlqcywgYjogRGF5anMpOiBib29sZWFuIHtcclxuICAgICAgICBpZiAoYSA9PSBudWxsIHx8IGIgPT0gbnVsbCkgcmV0dXJuIHRydWU7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuZ2V0SG91cihhKSA9PT0gdGhpcy5nZXRIb3VyKGIpXHJcbiAgICAgICAgICAgICYmIHRoaXMuZ2V0TWludXRlKGEpID09PSB0aGlzLmdldE1pbnV0ZShiKVxyXG4gICAgICAgICAgICAmJiB0aGlzLmdldFNlY29uZChhKSA9PT0gdGhpcy5nZXRTZWNvbmQoYik7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBDb3BpYSBkZWxsJ29yYXJpbyBkYSB1bmEgZGF0YSBhbGwnYWx0cmEsIE1vZGlmaWNhIGRpcmV0dGFtZW50ZSBsJ29nZ2V0dG8gKip0b0RhdGUqKlxyXG4gICAgICogXHJcbiAgICAgKiBAcGFyYW0ge0RheUpzfSB0b0RhdGUgRGF0YSBpbiBjdWkgY29waWFyZSBsJ29yYXJpb1xyXG4gICAgICogQHBhcmFtIHtEYXlKc30gZnJvbURhdGUgRGF0YSBkYSBjdWkgY29waWFyZSBsJ29yYXJpb1xyXG4gICAgICovXHJcbiAgICBjb3B5VGltZSh0b0RhdGU6IERheWpzLCBmcm9tRGF0ZTogRGF5anMpIHtcclxuICAgICAgICB0aGlzLnNldEhvdXIodG9EYXRlLCB0aGlzLmdldEhvdXIoZnJvbURhdGUpKTtcclxuICAgICAgICB0aGlzLnNldE1pbnV0ZSh0b0RhdGUsIHRoaXMuZ2V0TWludXRlKGZyb21EYXRlKSk7XHJcbiAgICAgICAgdGhpcy5zZXRTZWNvbmQodG9EYXRlLCB0aGlzLmdldFNlY29uZChmcm9tRGF0ZSkpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogTWV0dGUgYSBjb25mcm9udG8gZHVlIGRhdGVcclxuICAgICAqIEBwYXJhbSB7RGF5anN9IGZpcnN0IFByaW1hIGRhdGEgZGEgY29uZnJvbnRhcmVcclxuICAgICAqIEBwYXJhbSB7RGF5anN9IHNlY29uZCBTZWNvbmRhIGRhdGEgZGEgY29uZnJvbnRhcmVcclxuICAgICAqIEBwYXJhbSB7Ym9vbGVhbn0gc2hvd1NlY29uZHMgSW5kaWNhIHNlIGNvbnNpZGVyYXJlIGFuY2hlIGkgc2Vjb25kaSwgZGkgZGVmYXVsdCBub1xyXG4gICAgICogQHJldHVybnMge251bWJlcn0gMCBzZSBsZSBkdWUgZGF0ZSBzb25vIHVndWFsaSwgdW4gbnVtZXJvIG1pbm9yZSBkaSAwIHNlIGxhIHByaW1hIGRhdGEgw6ggcHJlY2VkZW50ZSBhbGxhIHNlY29uZGEgZSB1biBudW1lcm8gbWFnZ2lvcmUgZGkgMCBhbHRyaW1lbnRpXHJcbiAgICAgKi9cclxuICAgIGNvbXBhcmVEYXRlV2l0aFRpbWUoZmlyc3Q6IERheWpzLCBzZWNvbmQ6IERheWpzLCBzaG93U2Vjb25kcz86IGJvb2xlYW4pOiBudW1iZXIge1xyXG4gICAgICAgIGxldCByZXMgPSBzdXBlci5jb21wYXJlRGF0ZShmaXJzdCwgc2Vjb25kKSB8fFxyXG4gICAgICAgICAgICB0aGlzLmdldEhvdXIoZmlyc3QpIC0gdGhpcy5nZXRIb3VyKHNlY29uZCkgfHxcclxuICAgICAgICAgICAgdGhpcy5nZXRNaW51dGUoZmlyc3QpIC0gdGhpcy5nZXRNaW51dGUoc2Vjb25kKTtcclxuXHJcbiAgICAgICAgaWYgKHNob3dTZWNvbmRzKVxyXG4gICAgICAgICAgICByZXMgPSByZXMgfHwgdGhpcy5nZXRTZWNvbmQoZmlyc3QpIC0gdGhpcy5nZXRTZWNvbmQoc2Vjb25kKTtcclxuICAgICAgICAgICAgXHJcbiAgICAgICAgcmV0dXJuIHJlcztcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIEFzc2VnbmEgYSB1bmEgZGF0YSBpIHZhbG9yaSBkaSBvcmUsIG1pbnV0aSBlIHNlY29uZGkgZGkgZGVmYXVsdC4gXHJcbiAgICAgKiBcclxuICAgICAqIFNlIG5vbiBzcGVjaWZpY2F0aSB2ZW5nb25vIGFzc2VnbmF0aSBkZWdsaSAnMCdcclxuICAgICAqIFxyXG4gICAgICogQHBhcmFtIHtEYXlKc30gZGF0ZSBEYXRhIGEgY3VpIGFzc2VnbmFyZSBpIHZhbG9yaSBkaSBkZWZhdWx0XHJcbiAgICAgKiBAcGFyYW0ge251bWJlcltdfSBkZWZhdWx0VGltZSBWYWxvcmkgZGkgZGVmYXVsdCBwZXIgb3JlLCBtaW51dGkgZSBzZWNvbmRpLCBjb25zaWRlcmF0aSAwIHNlIG5vbiBwcmVzZW50aVxyXG4gICAgICovXHJcbiAgICBzZXRUaW1lQnlEZWZhdWx0VmFsdWVzKGRhdGU6IERheWpzLCBkZWZhdWx0VGltZTogbnVtYmVyW10pIHtcclxuICAgICAgICBpZiAoIUFycmF5LmlzQXJyYXkoZGVmYXVsdFRpbWUpKSB7XHJcbiAgICAgICAgICAgIHRocm93IEVycm9yKCdASW5wdXQgRGVmYXVsdFRpbWUgc2hvdWxkIGJlIGFuIGFycmF5Jyk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHRoaXMuc2V0SG91cihkYXRlLCBkZWZhdWx0VGltZVswXSB8fCAwKTtcclxuICAgICAgICB0aGlzLnNldE1pbnV0ZShkYXRlLCBkZWZhdWx0VGltZVsxXSB8fCAwKTtcclxuICAgICAgICB0aGlzLnNldFNlY29uZChkYXRlLCBkZWZhdWx0VGltZVsyXSB8fCAwKTtcclxuICAgIH1cclxufSJdfQ==
@@ -1,208 +0,0 @@
1
- // Angular
2
- import { EventEmitter, Input, Output, ViewChild, Directive } from "@angular/core";
3
- // Direttive, Componenti, Librerie
4
- import { TooltipDirective } from "ngx-bootstrap/tooltip";
5
- /**
6
- * Classe astratta base che contiene le logiche / proprietà in comune a tutti i validatori
7
- *
8
- * Nota bene: I tooltip rallentano tantissimo la pagina perché il tizio che ha fatto ngx bootstrap non è capace
9
- */
10
- export class BaseValidation {
11
- constructor() {
12
- /**
13
- * Variabile per tenere in memoria il fatto che il componente è forzato a invalido o no
14
- */
15
- this._forceInvalid = false;
16
- /**
17
- * Indica se il valore è obbligatorio o opzionale
18
- */
19
- this.required = false;
20
- /**
21
- * Indica se di default deve valutare il messaggio di errore in base al validatore che fallisce.
22
- *
23
- * Se fallisce il required validator scriverà che l'input è obbligatorio, se invece fallisce
24
- * un eventuale pattern validator scriverà che il formato dell'input è invalido
25
- */
26
- this.InferErrorMessages = true;
27
- /**
28
- * Messaggio da mostrare se la validazione fallisce.
29
- *
30
- * Se questo è valorizzato, il messaggio non viene valutato in automatico nonstante **InferErrorMessages** sia **true**
31
- */
32
- this.validationFailed = "";
33
- /**
34
- * Indica se il componente è in sola lettura
35
- */
36
- this.readonly = false;
37
- /**
38
- * Indica le dimensioni del componente
39
- */
40
- this.widthPx = null;
41
- /**
42
- * Indica se il componente è disabilitato o no (più o meno stesso concetto del readonly)
43
- */
44
- this.disabled = false;
45
- /**
46
- * Eventuale placeholder da mostrare al posto del valore quando il valore è nullo / vuoto
47
- */
48
- this.placeholder = "";
49
- /**
50
- * Classi da applicare al componente
51
- */
52
- this.class = "";
53
- /**
54
- * Stili da applicare al componente
55
- */
56
- this.style = "";
57
- /**
58
- * Pattern di validazione dell'input
59
- */
60
- this.pattern = "";
61
- /**
62
- * Indica di non validare il componente
63
- */
64
- this.noValidate = false;
65
- /**
66
- * Indica se abilitare o meno l'autocompletamento di default del browser
67
- */
68
- this.autocomplete = "off";
69
- /**
70
- * Evento che sostituisce l'ngModelChange facendolo funzionare in maniera un po' più consistente
71
- */
72
- this.inputChange = new EventEmitter();
73
- /**
74
- * @ignore
75
- */
76
- this.propagateChange = (_) => { };
77
- }
78
- /**
79
- * Query che raccoglie il tooltip in maniera dinamica (ad ogni change detection)
80
- *
81
- * @param {TooltipDirective} comp Elemento HTML a cui è applicata la direttiva del tooltip
82
- */
83
- set tooltip_static(comp) {
84
- if (comp) {
85
- this.tooltip = comp;
86
- }
87
- }
88
- ;
89
- /**
90
- * Query che raccoglie l'input o direttiva che contiene il valore in maniera dinamica (ad ogni change detection)
91
- *
92
- * @param {NgModel} comp Elemento HTML associato al ngModel del componente
93
- */
94
- set baseInput_static(comp) {
95
- if (comp) {
96
- this.baseInput = comp;
97
- }
98
- }
99
- ;
100
- /**
101
- * Imposta il componente come "submitted" scatenandone le validazioni ed eventualmente la visualizzazione del tooltip di errore
102
- *
103
- * @param {boolean} val **true** se si vuole impostare questo controllo come submitted, **false** altrimenti
104
- */
105
- set submitted(val) {
106
- this._submitted = val;
107
- if (!this.baseInput)
108
- return;
109
- if (val)
110
- this.baseInput.control.markAsTouched();
111
- if (this.baseInput.control.status === "INVALID" && val)
112
- this.showTooltipWithMessage();
113
- else
114
- this.tooltip.hide();
115
- }
116
- /**
117
- * Imposta il componente come "invalid" a prescindere dai validatori
118
- */
119
- set forceInvalid(val) {
120
- this._forceInvalid = val;
121
- if (val)
122
- setTimeout(() => this.baseInput.control.setErrors({ forcedtoinvalid: true }));
123
- else
124
- setTimeout(() => {
125
- this.baseInput.control.setErrors({ forcedtoinvalid: null });
126
- this.baseInput.control.updateValueAndValidity();
127
- });
128
- }
129
- /**
130
- * Helper che controlla se il tooltip deve essere mostrato o meno,
131
- * richiamato direttamente dall'HTML dei componenti
132
- */
133
- checkTooltip() {
134
- if ((this.baseInput.invalid && this.baseInput.touched))
135
- this.showTooltipWithMessage();
136
- }
137
- /**
138
- * Helper che calcola il messaggio da mostrare nel tooltip che andrà ad aprire
139
- */
140
- showTooltipWithMessage() {
141
- this.validationFailed = this.validationFailed ? this.validationFailed : this.InferErrorMessages ? this.inferMessage() : "";
142
- if (this.validationFailed)
143
- this.tooltip.show();
144
- }
145
- /**
146
- * Calcola il messaggio da mostrare in base al valore.
147
- *
148
- * Entrare in questa funzione significa che lo stato di validazione è fallito, per questo si comporta semplicemente in maniera esclusiva, e cioè:
149
- *
150
- * 1) Se ero required e sono senza valore --> Input richiesto
151
- *
152
- * 2) Altrimenti se ho un valore --> Di sicuro il formato è errato
153
- */
154
- inferMessage() {
155
- if (this.required && !this.baseInput.value)
156
- return this.lc.loc("Required Input");
157
- if (this.baseInput.value)
158
- return this.lc.loc("Invalid Input Format");
159
- }
160
- /**
161
- * Forza la chiusura del tooltip
162
- */
163
- closeTooltip() {
164
- this.tooltip.hide();
165
- }
166
- /**
167
- * Controlla se il controllo è valido e in caso lo sia chiude il tooltip
168
- */
169
- CheckValidity() {
170
- if (!this.baseInput.statusChanges)
171
- return;
172
- this.baseInput.statusChanges.subscribe(event => {
173
- if (event === "VALID")
174
- this.tooltip.hide();
175
- });
176
- }
177
- /**
178
- * @ignore
179
- */
180
- setDisabledState(isDisabled) {
181
- isDisabled ? this.baseInput.control.disable() : this.baseInput.control.enable();
182
- this.readonly = isDisabled;
183
- }
184
- }
185
- BaseValidation.decorators = [
186
- { type: Directive }
187
- ];
188
- BaseValidation.propDecorators = {
189
- tooltip: [{ type: ViewChild, args: [TooltipDirective, { static: false },] }],
190
- tooltip_static: [{ type: ViewChild, args: [TooltipDirective, { static: true },] }],
191
- baseInput: [{ type: ViewChild, args: ["baseInput", { static: false },] }],
192
- baseInput_static: [{ type: ViewChild, args: ["baseInput", { static: true },] }],
193
- InferErrorMessages: [{ type: Input }],
194
- validationFailed: [{ type: Input }],
195
- readonly: [{ type: Input }],
196
- widthPx: [{ type: Input }],
197
- disabled: [{ type: Input }],
198
- placeholder: [{ type: Input }],
199
- class: [{ type: Input }],
200
- style: [{ type: Input }],
201
- pattern: [{ type: Input }],
202
- noValidate: [{ type: Input }],
203
- autocomplete: [{ type: Input }],
204
- inputChange: [{ type: Output }],
205
- submitted: [{ type: Input, args: ["submitted",] }],
206
- forceInvalid: [{ type: Input }]
207
- };
208
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-validation.js","sourceRoot":"","sources":["../../../../../projects/forms-and-validations/src/lib/validations/base-validation.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { EventEmitter, Input, Output, ViewChild, Directive } from \"@angular/core\";\r\nimport { NgModel } from \"@angular/forms\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport { TooltipDirective } from \"ngx-bootstrap/tooltip\";\r\n\r\n/**\r\n * Classe astratta base che contiene le logiche / proprietà in comune a tutti i validatori\r\n * \r\n * Nota bene: I tooltip rallentano tantissimo la pagina perché il tizio che ha fatto ngx bootstrap non è capace\r\n */\r\n@Directive()\r\nexport abstract class BaseValidation {\r\n\r\n    /**\r\n     * Servizio di localizzazione del Componente\r\n     */\r\n    protected lc: LocalizationService;\r\n\r\n    /**\r\n     * Variabile per tenere in memoria lo stato di submit di questo componente\r\n     */\r\n    protected _submitted: boolean;\r\n\r\n    /**\r\n     * Variabile per tenere in memoria il fatto che il componente è forzato a invalido o no\r\n     */\r\n    protected _forceInvalid: boolean = false;\r\n\r\n    /**\r\n     * Indica se il valore è obbligatorio o opzionale\r\n     */\r\n    public required: boolean = false;\r\n\r\n    /**\r\n     * Query che raccoglie il tooltip in maniera statica (solo all'inizio)\r\n     */\r\n    @ViewChild(TooltipDirective, { static: false }) protected tooltip: TooltipDirective;\r\n\r\n    /**\r\n     * Query che raccoglie il tooltip in maniera dinamica (ad ogni change detection)\r\n     * \r\n     * @param {TooltipDirective} comp Elemento HTML a cui è applicata la direttiva del tooltip\r\n     */\r\n    @ViewChild(TooltipDirective, { static: true }) set tooltip_static(comp: TooltipDirective) {\r\n        if (comp) { this.tooltip = comp; }\r\n    };\r\n\r\n    /**\r\n     * Query che raccoglie l'input o direttiva che contiene il valore in maniera statica (solo all'inizio)\r\n     */\r\n    @ViewChild(\"baseInput\", { static: false }) baseInput: NgModel;\r\n\r\n    /**\r\n     * Query che raccoglie l'input o direttiva che contiene il valore in maniera dinamica (ad ogni change detection)\r\n     * \r\n     * @param {NgModel} comp Elemento HTML associato al ngModel del componente\r\n     */\r\n    @ViewChild(\"baseInput\", { static: true }) set baseInput_static(comp: NgModel) {\r\n        if (comp) { this.baseInput = comp; }\r\n    };\r\n\r\n    /**\r\n     * Indica se di default deve valutare il messaggio di errore in base al validatore che fallisce.\r\n     * \r\n     * Se fallisce il required validator scriverà che l'input è obbligatorio, se invece fallisce \r\n     * un eventuale pattern validator scriverà che il formato dell'input è invalido\r\n     */\r\n    @Input() InferErrorMessages: boolean = true;\r\n\r\n    /**\r\n     * Messaggio da mostrare se la validazione fallisce. \r\n     * \r\n     * Se questo è valorizzato, il messaggio non viene valutato in automatico nonstante **InferErrorMessages** sia **true**\r\n     */\r\n    @Input() validationFailed: string = \"\";\r\n\r\n    /**\r\n     * Indica se il componente è in sola lettura\r\n     */\r\n    @Input() readonly: boolean = false;\r\n\r\n    /**\r\n     * Indica le dimensioni del componente\r\n     */\r\n    @Input() widthPx: number = null;\r\n\r\n    /**\r\n     * Indica se il componente è disabilitato o no (più o meno stesso concetto del readonly)\r\n     */\r\n    @Input() disabled: boolean = false;\r\n\r\n    /**\r\n     * Eventuale placeholder da mostrare al posto del valore quando il valore è nullo / vuoto\r\n     */\r\n    @Input() placeholder: string = \"\";\r\n\r\n    /**\r\n     * Classi da applicare al componente\r\n     */\r\n    @Input() class: string = \"\";\r\n\r\n    /**\r\n     * Stili da applicare al componente\r\n     */\r\n    @Input() style: string = \"\";\r\n\r\n    /**\r\n     * Pattern di validazione dell'input\r\n     */\r\n    @Input() pattern: string = \"\";\r\n\r\n    /**\r\n     * Indica di non validare il componente\r\n     */\r\n    @Input() noValidate: boolean = false;\r\n\r\n    /**\r\n     * Indica se abilitare o meno l'autocompletamento di default del browser\r\n     */\r\n    @Input() autocomplete: string = \"off\";\r\n\r\n    /**\r\n     * Evento che sostituisce l'ngModelChange facendolo funzionare in maniera un po' più consistente\r\n     */\r\n    @Output() inputChange: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n    /**\r\n     * Imposta il componente come \"submitted\" scatenandone le validazioni ed eventualmente la visualizzazione del tooltip di errore\r\n     * \r\n     * @param {boolean} val **true** se si vuole impostare questo controllo come submitted, **false** altrimenti\r\n     */\r\n    @Input(\"submitted\") set submitted(val: boolean) {\r\n        this._submitted = val;\r\n        if (!this.baseInput)\r\n            return;\r\n\r\n        if (val)\r\n            this.baseInput.control.markAsTouched();\r\n\r\n        if (this.baseInput.control.status === \"INVALID\" && val)\r\n            this.showTooltipWithMessage();\r\n        else\r\n            this.tooltip.hide();\r\n    }\r\n\r\n    /**\r\n     * Imposta il componente come \"invalid\" a prescindere dai validatori\r\n     */\r\n    @Input() set forceInvalid(val: boolean) {\r\n        this._forceInvalid = val;\r\n\r\n        if (val)\r\n            setTimeout(() => this.baseInput.control.setErrors({ forcedtoinvalid: true }));\r\n        else\r\n            setTimeout(() => {\r\n                this.baseInput.control.setErrors({ forcedtoinvalid: null });\r\n                this.baseInput.control.updateValueAndValidity();\r\n            });\r\n    }\r\n\r\n\r\n    /**\r\n     * Helper che controlla se il tooltip deve essere mostrato o meno, \r\n     * richiamato direttamente dall'HTML dei componenti\r\n     */\r\n    public checkTooltip() {\r\n        if ((this.baseInput.invalid && this.baseInput.touched))\r\n            this.showTooltipWithMessage();\r\n    }\r\n\r\n    /**\r\n     * Helper che calcola il messaggio da mostrare nel tooltip che andrà ad aprire\r\n     */\r\n    private showTooltipWithMessage() {\r\n        this.validationFailed = this.validationFailed ? this.validationFailed : this.InferErrorMessages ? this.inferMessage() : \"\";\r\n        if (this.validationFailed)\r\n            this.tooltip.show();\r\n    }\r\n\r\n    /**\r\n     * Calcola il messaggio da mostrare in base al valore.\r\n     * \r\n     * Entrare in questa funzione significa che lo stato di validazione è fallito, per questo si comporta semplicemente in maniera esclusiva, e cioè:\r\n     * \r\n     * 1) Se ero required e sono senza valore --> Input richiesto\r\n     * \r\n     * 2) Altrimenti se ho un valore --> Di sicuro il formato è errato\r\n     */\r\n    private inferMessage(): string {\r\n        if (this.required && !this.baseInput.value)\r\n            return this.lc.loc(\"Required Input\")\r\n\r\n        if (this.baseInput.value)\r\n            return this.lc.loc(\"Invalid Input Format\")\r\n    }\r\n\r\n    /**\r\n     * Forza la chiusura del tooltip\r\n     */\r\n    closeTooltip() {\r\n        this.tooltip.hide();\r\n    }\r\n\r\n    /**\r\n     * Controlla se il controllo è valido e in caso lo sia chiude il tooltip\r\n     */\r\n    protected CheckValidity() {\r\n        if (!this.baseInput.statusChanges)\r\n            return;\r\n\r\n        this.baseInput.statusChanges.subscribe(event => {\r\n            if (event === \"VALID\")\r\n                this.tooltip.hide();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    setDisabledState?(isDisabled: boolean): void {\r\n        isDisabled ? this.baseInput.control.disable() : this.baseInput.control.enable();\r\n        this.readonly = isDisabled;\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    protected propagateChange = (_: any) => { };\r\n}"]}
@@ -1,23 +0,0 @@
1
- import { Injectable, Inject, Optional } from "@angular/core";
2
- import { LocalizationService } from "@esfaenza/localizations";
3
- import { FAV_LOCALE } from '../tokens';
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(LOC_LOCALE) {
12
- super(LOC_LOCALE !== null && LOC_LOCALE !== void 0 ? LOC_LOCALE : 'it-IT');
13
- super.set("en->it", "Required Input", ["Input Richiesto"]);
14
- super.set("en->it", "Invalid Input Format", ["Formato Input Invalido"]);
15
- }
16
- }
17
- BaseValidationLoc.decorators = [
18
- { type: Injectable }
19
- ];
20
- BaseValidationLoc.ctorParameters = () => [
21
- { type: String, decorators: [{ type: Optional }, { type: Inject, args: [FAV_LOCALE,] }] }
22
- ];
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS12YWxpZGF0aW9uLmxvYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Zvcm1zLWFuZC12YWxpZGF0aW9ucy9zcmMvbGliL3ZhbGlkYXRpb25zL2Jhc2UtdmFsaWRhdGlvbi5sb2MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFdkM7O0dBRUc7QUFFSCxNQUFNLE9BQU8saUJBQWtCLFNBQVEsbUJBQW1CO0lBRXREOztPQUVHO0lBQ0gsWUFBNkMsVUFBa0I7UUFDM0QsS0FBSyxDQUFDLFVBQVUsYUFBVixVQUFVLGNBQVYsVUFBVSxHQUFJLE9BQU8sQ0FBQyxDQUFDO1FBQzdCLEtBQUssQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLGdCQUFnQixFQUFFLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDO1FBQzNELEtBQUssQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLHNCQUFzQixFQUFFLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxDQUFDO0lBQzVFLENBQUM7OztZQVZKLFVBQVU7Ozt5Q0FNTSxRQUFRLFlBQUssTUFBTSxTQUFDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3QsIE9wdGlvbmFsIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTG9jYWxpemF0aW9uU2VydmljZSB9IGZyb20gXCJAZXNmYWVuemEvbG9jYWxpemF0aW9uc1wiO1xyXG5pbXBvcnQgeyBGQVZfTE9DQUxFIH0gZnJvbSAnLi4vdG9rZW5zJztcclxuXHJcbi8qKlxyXG4gKiBDbGFzc2UgZGkgbG9jYWxpenphemlvbmUgaW4gY29tdW5lIGNvbiB0dXR0aSBpIENvbXBvbmVudGkgZGkgdmFsaWRhemlvbmVcclxuICovXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIEJhc2VWYWxpZGF0aW9uTG9jIGV4dGVuZHMgTG9jYWxpemF0aW9uU2VydmljZSB7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBAaWdub3JlXHJcbiAgICAgKi9cclxuICAgIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpICBASW5qZWN0KEZBVl9MT0NBTEUpIExPQ19MT0NBTEU6IHN0cmluZykge1xyXG4gICAgICAgIHN1cGVyKExPQ19MT0NBTEUgPz8gJ2l0LUlUJyk7XHJcbiAgICAgICAgc3VwZXIuc2V0KFwiZW4tPml0XCIsIFwiUmVxdWlyZWQgSW5wdXRcIiwgW1wiSW5wdXQgUmljaGllc3RvXCJdKTtcclxuICAgICAgICBzdXBlci5zZXQoXCJlbi0+aXRcIiwgXCJJbnZhbGlkIElucHV0IEZvcm1hdFwiLCBbXCJGb3JtYXRvIElucHV0IEludmFsaWRvXCJdKTtcclxuICAgIH1cclxufSJdfQ==
@@ -1,35 +0,0 @@
1
- // Angular
2
- import { NG_VALIDATORS } from "@angular/forms";
3
- import { Directive, Input } from "@angular/core";
4
- /**
5
- * Direttiva utilizzata per validazioni "required" custom, in modo da poter dire che anche se c'è un valore selezionato, ma quel valore lo considero null
6
- * allora la validazione fallisce. Attualmente usato nell'unico punto sensato: validation-select
7
- */
8
- export class CustomRequiredDirective {
9
- constructor() {
10
- /**
11
- * Lista di valori che vengono considerati "vuoti" seppur presenti
12
- */
13
- this.NullValues = [];
14
- }
15
- /**
16
- * @ignore
17
- */
18
- validate(c) {
19
- // Controllo solo per custom required a true, altrimenti qualsiasi valore mi va bene
20
- if (this.customRequired != "true")
21
- return null;
22
- return !c.value || this.NullValues.includes(c.value) ? { required: true } : null;
23
- }
24
- }
25
- CustomRequiredDirective.decorators = [
26
- { type: Directive, args: [{
27
- selector: '[customRequired]',
28
- providers: [{ provide: NG_VALIDATORS, useExisting: CustomRequiredDirective, multi: true }]
29
- },] }
30
- ];
31
- CustomRequiredDirective.propDecorators = {
32
- NullValues: [{ type: Input, args: ["CustomNullValues",] }],
33
- customRequired: [{ type: Input, args: ['customRequired',] }]
34
- };
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ3VzdG9tUmVxdWlyZWREaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi92YWxpZGF0aW9ucy9jdXN0b21WYWxpZGF0b3JzL0N1c3RvbVJlcXVpcmVkRGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQW1CLGFBQWEsRUFBYSxNQUFNLGdCQUFnQixDQUFDO0FBQzNFLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWpEOzs7R0FHRztBQUtILE1BQU0sT0FBTyx1QkFBdUI7SUFKcEM7UUFNSTs7V0FFRztRQUN3QixlQUFVLEdBQWEsRUFBRSxDQUFDO0lBaUJ6RCxDQUFDO0lBVkc7O09BRUc7SUFDSCxRQUFRLENBQUMsQ0FBa0I7UUFDdkIsb0ZBQW9GO1FBQ3BGLElBQUksSUFBSSxDQUFDLGNBQWMsSUFBSSxNQUFNO1lBQzdCLE9BQU8sSUFBSSxDQUFDO1FBRWhCLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUNyRixDQUFDOzs7WUF6QkosU0FBUyxTQUFDO2dCQUNQLFFBQVEsRUFBRSxrQkFBa0I7Z0JBQzVCLFNBQVMsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxXQUFXLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxDQUFDO2FBQzdGOzs7eUJBTUksS0FBSyxTQUFDLGtCQUFrQjs2QkFLeEIsS0FBSyxTQUFDLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFuZ3VsYXJcclxuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBOR19WQUxJREFUT1JTLCBWYWxpZGF0b3IgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vKipcclxuICogRGlyZXR0aXZhIHV0aWxpenphdGEgcGVyIHZhbGlkYXppb25pIFwicmVxdWlyZWRcIiBjdXN0b20sIGluIG1vZG8gZGEgcG90ZXIgZGlyZSBjaGUgYW5jaGUgc2UgYyfDqCB1biB2YWxvcmUgc2VsZXppb25hdG8sIG1hIHF1ZWwgdmFsb3JlIGxvIGNvbnNpZGVybyBudWxsIFxyXG4gKiBhbGxvcmEgbGEgdmFsaWRhemlvbmUgZmFsbGlzY2UuIEF0dHVhbG1lbnRlIHVzYXRvIG5lbGwndW5pY28gcHVudG8gc2Vuc2F0bzogdmFsaWRhdGlvbi1zZWxlY3RcclxuICovXHJcbkBEaXJlY3RpdmUoe1xyXG4gICAgc2VsZWN0b3I6ICdbY3VzdG9tUmVxdWlyZWRdJyxcclxuICAgIHByb3ZpZGVyczogW3sgcHJvdmlkZTogTkdfVkFMSURBVE9SUywgdXNlRXhpc3Rpbmc6IEN1c3RvbVJlcXVpcmVkRGlyZWN0aXZlLCBtdWx0aTogdHJ1ZSB9XVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ3VzdG9tUmVxdWlyZWREaXJlY3RpdmUgaW1wbGVtZW50cyBWYWxpZGF0b3Ige1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogTGlzdGEgZGkgdmFsb3JpIGNoZSB2ZW5nb25vIGNvbnNpZGVyYXRpIFwidnVvdGlcIiBzZXBwdXIgcHJlc2VudGlcclxuICAgICAqL1xyXG4gICAgQElucHV0KFwiQ3VzdG9tTnVsbFZhbHVlc1wiKSBOdWxsVmFsdWVzOiBzdHJpbmdbXSA9IFtdO1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogYm9vbGVhbm8gaW4gbW9kYWxpdMOgIHN0cmluZ2EgKFwidHJ1ZVwiIG8gXCJmYWxzZVwiKSBjaGUgaW5kaWNhIHNlIGFwcGxpY2FyZSBsYSB2YWxpZGF6aW9uZSBkaSBvYmJsaWdhdG9yaWV0w6AgbyBtZW5vXHJcbiAgICAgKi9cclxuICAgIEBJbnB1dCgnY3VzdG9tUmVxdWlyZWQnKSBwdWJsaWMgY3VzdG9tUmVxdWlyZWQ6IHN0cmluZztcclxuXHJcbiAgICAvKipcclxuICAgICAqIEBpZ25vcmVcclxuICAgICAqL1xyXG4gICAgdmFsaWRhdGUoYzogQWJzdHJhY3RDb250cm9sKTogeyBba2V5OiBzdHJpbmddOiBhbnk7IH0ge1xyXG4gICAgICAgIC8vIENvbnRyb2xsbyBzb2xvIHBlciBjdXN0b20gcmVxdWlyZWQgYSB0cnVlLCBhbHRyaW1lbnRpIHF1YWxzaWFzaSB2YWxvcmUgbWkgdmEgYmVuZVxyXG4gICAgICAgIGlmICh0aGlzLmN1c3RvbVJlcXVpcmVkICE9IFwidHJ1ZVwiKVxyXG4gICAgICAgICAgICByZXR1cm4gbnVsbDtcclxuXHJcbiAgICAgICAgcmV0dXJuICFjLnZhbHVlIHx8IHRoaXMuTnVsbFZhbHVlcy5pbmNsdWRlcyhjLnZhbHVlKSA/IHsgcmVxdWlyZWQ6IHRydWUgfSA6IG51bGw7XHJcbiAgICB9XHJcbn0iXX0=