ng-inail-common 2.1.1-beta.9 → 2.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (146) hide show
  1. package/README.md +1 -1
  2. package/esm2022/lib/components/core/base.component.mjs +120 -0
  3. package/{esm2020 → esm2022}/lib/components/core/basic-ux-element.component.mjs +4 -4
  4. package/esm2022/lib/components/core/form/checkbox/checkbox.component.mjs +124 -0
  5. package/{esm2020 → esm2022}/lib/components/core/form/form-element.component.mjs +4 -4
  6. package/{esm2020 → esm2022}/lib/components/core/form/input-date/input-date.component.mjs +10 -10
  7. package/{esm2020 → esm2022}/lib/components/core/form/input-file/input-file.component.mjs +4 -4
  8. package/{esm2020 → esm2022}/lib/components/core/form/input-money/input-money.component.mjs +10 -10
  9. package/esm2022/lib/components/core/form/input-number/input-number.component.mjs +202 -0
  10. package/esm2022/lib/components/core/form/input-text/input-text.component.mjs +131 -0
  11. package/{esm2020 → esm2022}/lib/components/core/form/input-time/input-time.component.mjs +10 -10
  12. package/{esm2020 → esm2022}/lib/components/core/form/multi-select/multi-select.component.mjs +4 -4
  13. package/esm2022/lib/components/core/form/radio-select/radio-select.component.mjs +144 -0
  14. package/esm2022/lib/components/core/form/select/select.component.mjs +144 -0
  15. package/esm2022/lib/components/core/form/textarea/textarea.component.mjs +134 -0
  16. package/{esm2020 → esm2022}/lib/components/core/layout/breadcrumb/breadcrumb.component.mjs +4 -4
  17. package/esm2022/lib/components/core/layout/dynamic-layout-element.component.mjs +158 -0
  18. package/esm2022/lib/components/core/layout/footer/footer.component.mjs +50 -0
  19. package/esm2022/lib/components/core/layout/header/header.component.mjs +100 -0
  20. package/esm2022/lib/components/core/layout/header-secondario/header-secondario.component.mjs +166 -0
  21. package/esm2022/lib/components/core/layout/inail-layout/inail-layout.component.mjs +587 -0
  22. package/{esm2020 → esm2022}/lib/components/core/layout/loader/loader.component.mjs +4 -4
  23. package/esm2022/lib/components/core/layout/logo-header/logo-header.component.mjs +55 -0
  24. package/{esm2020 → esm2022}/lib/components/core/layout/menu/menu.component.mjs +4 -4
  25. package/{esm2020 → esm2022}/lib/components/core/layout/menu-intranet/menu-intranet.component.mjs +4 -4
  26. package/esm2022/lib/components/core/layout/navigazione-principale/navigazione-principale.component.mjs +102 -0
  27. package/{esm2020 → esm2022}/lib/components/core/layout/navigazione-secondaria/navigazione-secondaria.component.mjs +4 -4
  28. package/{esm2020 → esm2022}/lib/components/core/layout/trigger-slider-menu-button/trigger-slider-menu-button.component.mjs +4 -4
  29. package/{esm2020 → esm2022}/lib/components/core/responsive-element.component.mjs +4 -4
  30. package/{esm2020 → esm2022}/lib/components/core/table/inail-table-page-selector/inail-table-page-selector.component.mjs +4 -4
  31. package/{esm2020 → esm2022}/lib/components/core/table/table/table.component.mjs +4 -4
  32. package/{esm2020 → esm2022}/lib/components/core/table/table-page-length-selector/table-page-length-selector.component.mjs +4 -4
  33. package/esm2022/lib/components/core/table/th-label/th-label.component.mjs +89 -0
  34. package/{esm2020 → esm2022}/lib/components/core/table/tr-accordion/tr-accordion.component.mjs +4 -4
  35. package/{esm2020 → esm2022}/lib/components/core/table/tr-checkbox/tr-checkbox.component.mjs +4 -4
  36. package/{esm2020 → esm2022}/lib/components/core/ux/accordion/accordion.component.mjs +4 -4
  37. package/{esm2020 → esm2022}/lib/components/core/ux/alert/alert.component.mjs +4 -4
  38. package/{esm2020 → esm2022}/lib/components/core/ux/button/button.component.mjs +4 -4
  39. package/{esm2020 → esm2022}/lib/components/core/ux/confirm/confirm.component.mjs +4 -4
  40. package/{esm2020 → esm2022}/lib/components/core/ux/container/container.component.mjs +4 -4
  41. package/{esm2020 → esm2022}/lib/components/core/ux/feedback/feedback.component.mjs +4 -4
  42. package/{esm2020 → esm2022}/lib/components/core/ux/form-grey/form-grey.component.mjs +4 -4
  43. package/{esm2020 → esm2022}/lib/components/core/ux/modal/modal.component.mjs +4 -4
  44. package/{esm2020 → esm2022}/lib/components/core/ux/page-title/page-title.component.mjs +4 -4
  45. package/{esm2020 → esm2022}/lib/components/core/ux/popover/popover.component.mjs +5 -5
  46. package/{esm2020 → esm2022}/lib/components/core/ux/progress-bar/progress-bar.component.mjs +4 -4
  47. package/{esm2020 → esm2022}/lib/components/core/ux/selector/selector.component.mjs +4 -4
  48. package/{esm2020 → esm2022}/lib/components/core/ux/tab-group/tab-group.component.mjs +4 -4
  49. package/{esm2020 → esm2022}/lib/components/core/ux/tab-pane/tab-pane.component.mjs +4 -4
  50. package/{esm2020 → esm2022}/lib/components/core/ux/wizard/wizard.component.mjs +4 -4
  51. package/{esm2020 → esm2022}/lib/components/utilities/form-element-state-propertie/form-element-state-propertie.component.mjs +4 -4
  52. package/{esm2020 → esm2022}/lib/components/utilities/pre/pre.component.mjs +4 -4
  53. package/{esm2020 → esm2022}/lib/components/utilities/state-propertie/state-propertie.component.mjs +4 -4
  54. package/esm2022/lib/ng-inail-common.component.mjs +19 -0
  55. package/esm2022/lib/ng-inail-common.module.mjs +296 -0
  56. package/esm2022/lib/ng-inail-common.service.mjs +14 -0
  57. package/{esm2020 → esm2022}/lib/services/agw-rest.service.mjs +4 -4
  58. package/esm2022/public-api.mjs +64 -0
  59. package/{fesm2020 → fesm2022}/ng-inail-common.mjs +2753 -2908
  60. package/fesm2022/ng-inail-common.mjs.map +1 -0
  61. package/lib/components/core/base.component.d.ts +7 -5
  62. package/lib/components/core/basic-ux-element.component.d.ts +1 -1
  63. package/lib/components/core/form/checkbox/checkbox.component.d.ts +1 -1
  64. package/lib/components/core/form/form-element.component.d.ts +1 -1
  65. package/lib/components/core/form/input-date/input-date.component.d.ts +1 -1
  66. package/lib/components/core/form/input-file/input-file.component.d.ts +1 -1
  67. package/lib/components/core/form/input-money/input-money.component.d.ts +2 -2
  68. package/lib/components/core/form/input-number/input-number.component.d.ts +1 -1
  69. package/lib/components/core/form/input-text/input-text.component.d.ts +1 -1
  70. package/lib/components/core/form/input-time/input-time.component.d.ts +1 -1
  71. package/lib/components/core/form/multi-select/multi-select.component.d.ts +1 -1
  72. package/lib/components/core/form/radio-select/radio-select.component.d.ts +1 -1
  73. package/lib/components/core/form/select/select.component.d.ts +1 -2
  74. package/lib/components/core/form/textarea/textarea.component.d.ts +1 -1
  75. package/lib/components/core/layout/breadcrumb/breadcrumb.component.d.ts +1 -1
  76. package/lib/components/core/layout/dynamic-layout-element.component.d.ts +70 -0
  77. package/lib/components/core/layout/footer/footer.component.d.ts +15 -63
  78. package/lib/components/core/layout/header/header.component.d.ts +22 -18
  79. package/lib/components/core/layout/header-secondario/header-secondario.component.d.ts +14 -63
  80. package/lib/components/core/layout/inail-layout/inail-layout.component.d.ts +19 -19
  81. package/lib/components/core/layout/loader/loader.component.d.ts +1 -1
  82. package/lib/components/core/layout/logo-header/logo-header.component.d.ts +15 -63
  83. package/lib/components/core/layout/menu/menu.component.d.ts +2 -2
  84. package/lib/components/core/layout/menu-intranet/menu-intranet.component.d.ts +1 -1
  85. package/lib/components/core/layout/navigazione-principale/navigazione-principale.component.d.ts +16 -67
  86. package/lib/components/core/layout/navigazione-secondaria/navigazione-secondaria.component.d.ts +1 -1
  87. package/lib/components/core/layout/trigger-slider-menu-button/trigger-slider-menu-button.component.d.ts +1 -1
  88. package/lib/components/core/responsive-element.component.d.ts +2 -2
  89. package/lib/components/core/table/inail-table-page-selector/inail-table-page-selector.component.d.ts +1 -1
  90. package/lib/components/core/table/table/table.component.d.ts +2 -2
  91. package/lib/components/core/table/table-page-length-selector/table-page-length-selector.component.d.ts +1 -1
  92. package/lib/components/core/table/th-label/th-label.component.d.ts +1 -1
  93. package/lib/components/core/table/tr-accordion/tr-accordion.component.d.ts +1 -1
  94. package/lib/components/core/table/tr-checkbox/tr-checkbox.component.d.ts +1 -1
  95. package/lib/components/core/ux/accordion/accordion.component.d.ts +1 -1
  96. package/lib/components/core/ux/alert/alert.component.d.ts +1 -1
  97. package/lib/components/core/ux/button/button.component.d.ts +1 -1
  98. package/lib/components/core/ux/confirm/confirm.component.d.ts +2 -2
  99. package/lib/components/core/ux/container/container.component.d.ts +1 -1
  100. package/lib/components/core/ux/feedback/feedback.component.d.ts +2 -2
  101. package/lib/components/core/ux/form-grey/form-grey.component.d.ts +1 -1
  102. package/lib/components/core/ux/modal/modal.component.d.ts +1 -1
  103. package/lib/components/core/ux/page-title/page-title.component.d.ts +1 -1
  104. package/lib/components/core/ux/popover/popover.component.d.ts +1 -1
  105. package/lib/components/core/ux/progress-bar/progress-bar.component.d.ts +1 -1
  106. package/lib/components/core/ux/selector/selector.component.d.ts +1 -1
  107. package/lib/components/core/ux/tab-group/tab-group.component.d.ts +1 -1
  108. package/lib/components/core/ux/tab-pane/tab-pane.component.d.ts +1 -1
  109. package/lib/components/core/ux/wizard/wizard.component.d.ts +1 -1
  110. package/lib/components/utilities/form-element-state-propertie/form-element-state-propertie.component.d.ts +1 -1
  111. package/lib/components/utilities/pre/pre.component.d.ts +1 -1
  112. package/lib/components/utilities/state-propertie/state-propertie.component.d.ts +1 -1
  113. package/lib/ng-inail-common.component.d.ts +5 -0
  114. package/lib/ng-inail-common.module.d.ts +59 -57
  115. package/lib/ng-inail-common.service.d.ts +6 -0
  116. package/lib/utils/common.operators.d.ts +1 -1
  117. package/lib/utils/date.operators.d.ts +1 -1
  118. package/lib/utils/types.d.ts +1 -1
  119. package/package.json +10 -16
  120. package/public-api.d.ts +2 -0
  121. package/esm2020/lib/components/core/base.component.mjs +0 -115
  122. package/esm2020/lib/components/core/form/checkbox/checkbox.component.mjs +0 -124
  123. package/esm2020/lib/components/core/form/input-number/input-number.component.mjs +0 -202
  124. package/esm2020/lib/components/core/form/input-text/input-text.component.mjs +0 -131
  125. package/esm2020/lib/components/core/form/radio-select/radio-select.component.mjs +0 -143
  126. package/esm2020/lib/components/core/form/select/select.component.mjs +0 -146
  127. package/esm2020/lib/components/core/form/textarea/textarea.component.mjs +0 -134
  128. package/esm2020/lib/components/core/layout/footer/footer.component.mjs +0 -171
  129. package/esm2020/lib/components/core/layout/header/header.component.mjs +0 -106
  130. package/esm2020/lib/components/core/layout/header-secondario/header-secondario.component.mjs +0 -230
  131. package/esm2020/lib/components/core/layout/inail-layout/inail-layout.component.mjs +0 -586
  132. package/esm2020/lib/components/core/layout/logo-header/logo-header.component.mjs +0 -175
  133. package/esm2020/lib/components/core/layout/navigazione-principale/navigazione-principale.component.mjs +0 -199
  134. package/esm2020/lib/components/core/table/th-label/th-label.component.mjs +0 -89
  135. package/esm2020/lib/ng-inail-common.module.mjs +0 -288
  136. package/esm2020/public-api.mjs +0 -62
  137. package/fesm2015/ng-inail-common.mjs +0 -7362
  138. package/fesm2015/ng-inail-common.mjs.map +0 -1
  139. package/fesm2020/ng-inail-common.mjs.map +0 -1
  140. /package/{esm2020 → esm2022}/lib/components/core/layout/inail-layout/static-resources.mjs +0 -0
  141. /package/{esm2020 → esm2022}/lib/components/core/layout/inail-layout/webkit-resources.mjs +0 -0
  142. /package/{esm2020 → esm2022}/lib/ng-inail-common.config.mjs +0 -0
  143. /package/{esm2020 → esm2022}/lib/utils/common.operators.mjs +0 -0
  144. /package/{esm2020 → esm2022}/lib/utils/date.operators.mjs +0 -0
  145. /package/{esm2020 → esm2022}/lib/utils/types.mjs +0 -0
  146. /package/{esm2020 → esm2022}/ng-inail-common.mjs +0 -0
package/README.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # NgInailCommon
2
2
 
3
- This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 11.2.3.
3
+ This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 16.2.0.
4
4
 
5
5
  ## Code scaffolding
6
6
 
@@ -0,0 +1,120 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Output, ViewEncapsulation } from '@angular/core';
2
+ import { isNotBlankOrNull, isString } from "../../utils/common.operators";
3
+ import { NG_INAIL_COMMON_CONFIG } from "../../ng-inail-common.config";
4
+ import * as i0 from "@angular/core";
5
+ export var LogLevel;
6
+ (function (LogLevel) {
7
+ LogLevel["LOG"] = "log";
8
+ LogLevel["TRACE"] = "trace";
9
+ LogLevel["DEBUG"] = "debug";
10
+ LogLevel["INFO"] = "info";
11
+ LogLevel["WARN"] = "warn";
12
+ LogLevel["ERROR"] = "error";
13
+ })(LogLevel || (LogLevel = {}));
14
+ export const CHANGE_DETECTION_STRATEGY = ChangeDetectionStrategy.OnPush;
15
+ // export const CHANGE_DETECTION_STRATEGY = ChangeDetectionStrategy.Default;
16
+ export const getConfigValue = (value, defaultValue) => value != undefined ? value : defaultValue;
17
+ export class BaseComponent {
18
+ constructor(baseComponentCdr, baseElementLibConfig) {
19
+ this.baseComponentCdr = baseComponentCdr;
20
+ this.baseElementLibConfig = baseElementLibConfig;
21
+ this.viewInit = false;
22
+ /**
23
+ * Se true effettua il log direttamente nella console.
24
+ * Altrimenti emette l'evento log
25
+ */
26
+ this.logOnConsole = getConfigValue(this.baseElementLibConfig?.logOnConsole, false);
27
+ /**
28
+ *
29
+ */
30
+ this.showState = false;
31
+ this.subcriptions = [];
32
+ this.push = (subcription) => this.subcriptions.push(subcription);
33
+ // Detach centralizzato
34
+ this.detach = () => {
35
+ this.baseComponentCdr.detach();
36
+ };
37
+ this.detectChanges = () => this.baseComponentCdr.detectChanges();
38
+ this.getMessage = (event) => this.logPrefix && isString(event.message) ? `${this.logPrefix} ${event.message}` : event.message;
39
+ this.getNotBlankValue = (v) => isNotBlankOrNull(`${v}`) ? v : undefined;
40
+ this.log = new EventEmitter();
41
+ saveEE();
42
+ }
43
+ overrideConfig(config) {
44
+ if (config) {
45
+ this.logOnConsole = getConfigValue(config.logOnConsole, this.logOnConsole);
46
+ }
47
+ }
48
+ ngOnChanges(changes) {
49
+ this.emitDebug(`ngOnChanges`);
50
+ this.emitDebug(changes);
51
+ }
52
+ ngOnInit() {
53
+ this.emitDebug(`ngOnInit`);
54
+ this.emitDebug(`this`);
55
+ this.emitDebug(this);
56
+ if (this.detectChange) {
57
+ this.push(this.detectChange.subscribe(() => this.baseComponentCdr.detectChanges()));
58
+ }
59
+ }
60
+ ngOnDestroy() {
61
+ this.emitDebug(`${this.logPrefix} ngOnDestroy`);
62
+ this.subcriptions.forEach(s => s?.unsubscribe());
63
+ }
64
+ emitLog(message) {
65
+ this.emit({ message: message, level: LogLevel.LOG });
66
+ }
67
+ emitTrace(message) {
68
+ this.emit({ message: message, level: LogLevel.TRACE });
69
+ }
70
+ emitDebug(message) {
71
+ this.emit({ message: message, level: LogLevel.DEBUG });
72
+ }
73
+ emitInfo(message) {
74
+ this.emit({ message: message, level: LogLevel.INFO });
75
+ }
76
+ emitWarn(message) {
77
+ this.emit({ message: message, level: LogLevel.WARN });
78
+ }
79
+ emitError(message) {
80
+ this.emit({ message: message, level: LogLevel.ERROR });
81
+ }
82
+ emit(event) {
83
+ if (event) {
84
+ if (this.logOnConsole === true) {
85
+ console[event.level].apply(this, [this.getMessage(event)]);
86
+ }
87
+ else {
88
+ event.message = this.getMessage(event);
89
+ this.log.emit(event);
90
+ }
91
+ }
92
+ }
93
+ ngAfterViewInit() {
94
+ this.viewInit = true;
95
+ this.detectChanges();
96
+ }
97
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BaseComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_INAIL_COMMON_CONFIG }], target: i0.ɵɵFactoryTarget.Component }); }
98
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BaseComponent, selector: "inail-base", inputs: { logOnConsole: "logOnConsole", showState: "showState", detectChange: "detectChange" }, outputs: { log: "log" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
99
+ }
100
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BaseComponent, decorators: [{
101
+ type: Component,
102
+ args: [{ selector: 'inail-base', template: '', changeDetection: CHANGE_DETECTION_STRATEGY, encapsulation: ViewEncapsulation.None }]
103
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
104
+ type: Inject,
105
+ args: [NG_INAIL_COMMON_CONFIG]
106
+ }] }]; }, propDecorators: { log: [{
107
+ type: Output
108
+ }], logOnConsole: [{
109
+ type: Input
110
+ }], showState: [{
111
+ type: Input
112
+ }], detectChange: [{
113
+ type: Input
114
+ }] } });
115
+ function saveEE() {
116
+ if (!window['asd']) {
117
+ window['asd'] = JSON.parse(atob('ewogICJhdXRvcmUiOiAiU2ltb25lIEFudG9uaW5pIiwKICAiZXRhIjogImRpcGVuZGUgZGFsbCdhbm5vIGNvcnJlbnRlIiwKICAiaG9iYnkiOiBbIlBlc2NhIiwgIlNub3dib2FyZCIsICJHYW1pbmciLCAiQ3Jvc3NmaXQiXSwKICAicHJlZmVyaXRpIjogewogICAgInBlc2NpIjogWyJDYXJwYSIsICJCbGFjayBCYXNzIl0sCiAgICAidmlkZW9naW9jaGkiOiBbIkZGVklJIiwgIkZGVklJUiIsICJEZWF0aCBTdHJhbmRpbmciLCAiU2VraXJvIiwgIlJlZCBEZWFkIFJlZGVtcHRpb24gMiIsICJUTE9VIiwgIlRMT1UyIl0sCiAgICAibGlicmkiOiBbCiAgICAgIHsiYXV0b3JlIjogIkdhYnJpZWwgR2FyY2lhIE1hcnF1ZXoiLCAidGl0b2xvIjogIkNlbnQnYW5uaSBkaSBzb2xpdHVkaW5lIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiQ2FzdGVsbGkgZGkgcmFiYmlhIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiU2V0YSJ9LAogICAgICB7ImF1dG9yZSI6ICJZYXN1bmFyaSBLYXdhYmF0YSIsICJ0aXRvbG8iOiAiTGEgY2FzYSBkZWxsZSBiZWxsZSBhZGRvcm1lbnRhdGUifQogICAgXQogIH0sCiAgImltcHJlc2VDZWxlYnJpIjogWyJTb3Bwb3J0byBtaWEgbWFkcmUgZGEgcXVhc2kgNDAgYW5uaSJdLAogICJwcm92b0Ftb3JlUGVyIjogWyJJbCBtaW8gY2FuZSIsICJJbCBtaW8gZ2F0dG8iLCAiSWwgdGlyYW1pc3UiXQp9'));
118
+ }
119
+ }
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-inail-common/src/lib/components/core/base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,MAAM,EAGN,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,gBAAgB,EAAE,QAAQ,EAAC,MAAM,8BAA8B,CAAC;AAExE,OAAO,EAAsB,sBAAsB,EAAsB,MAAM,8BAA8B,CAAC;;AAE9G,MAAM,CAAN,IAAY,QAQX;AARD,WAAY,QAAQ;IAElB,uBAAW,CAAA;IACX,2BAAe,CAAA;IACf,2BAAe,CAAA;IACf,yBAAa,CAAA;IACb,yBAAa,CAAA;IACb,2BAAe,CAAA;AACjB,CAAC,EARW,QAAQ,KAAR,QAAQ,QAQnB;AAQD,MAAM,CAAC,MAAM,yBAAyB,GAAG,uBAAuB,CAAC,MAAM,CAAC;AACxE,4EAA4E;AAE5E,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAAU,EAAE,YAAiB,EAAE,EAAE,CAAC,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC;AAS3G,MAAM,OAAO,aAAa;IAwCxB,YAAoB,gBAAmC,EAEnC,oBAA0C;QAF1C,qBAAgB,GAAhB,gBAAgB,CAAmB;QAEnC,yBAAoB,GAApB,oBAAoB,CAAsB;QAxC9D,aAAQ,GAAY,KAAK,CAAC;QAQ1B;;;WAGG;QAEH,iBAAY,GAAY,cAAc,CAAC,IAAI,CAAC,oBAAoB,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;QAEvF;;WAEG;QAEH,cAAS,GAAY,KAAK,CAAC;QAO3B,iBAAY,GAAmB,EAAE,CAAC;QAClC,SAAI,GAAG,CAAC,WAAyB,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAE1E,uBAAuB;QACvB,WAAM,GAAG,GAAG,EAAE;YACZ,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC;QACjC,CAAC,CAAC;QAEF,kBAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC;QAC5D,eAAU,GAAG,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,IAAI,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC;QACnI,qBAAgB,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAKjE,IAAI,CAAC,GAAG,GAAG,IAAI,YAAY,EAAY,CAAC;QACxC,MAAM,EAAE,CAAC;IACX,CAAC;IAED,cAAc,CAAC,MAA2B;QAExC,IAAI,MAAM,EAAE;YAEV,IAAI,CAAC,YAAY,GAAG,cAAc,CAAC,MAAM,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;SAC5E;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QAC9B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IAC1B,CAAC;IAED,QAAQ;QAEN,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC3B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAErB,IAAI,IAAI,CAAC,YAAY,EAAE;YAErB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;SACrF;IACH,CAAC;IAED,WAAW;QAET,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,SAAS,cAAc,CAAC,CAAC;QAChD,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,OAAO,CAAC,OAAY;QAClB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,GAAG,EAAC,CAAC,CAAC;IACrD,CAAC;IAED,SAAS,CAAC,OAAY;QACpB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAC,CAAC,CAAC;IACvD,CAAC;IAED,SAAS,CAAC,OAAY;QACpB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAC,CAAC,CAAC;IACvD,CAAC;IAED,QAAQ,CAAC,OAAY;QACnB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,IAAI,EAAC,CAAC,CAAC;IACtD,CAAC;IAED,QAAQ,CAAC,OAAY;QACnB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,IAAI,EAAC,CAAC,CAAC;IACtD,CAAC;IAED,SAAS,CAAC,OAAY;QAEpB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAC,CAAC,CAAC;IACvD,CAAC;IAED,IAAI,CAAC,KAAe;QAElB,IAAI,KAAK,EAAE;YAET,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;gBAE9B,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;aAC5D;iBAAM;gBAEL,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;gBACvC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACtB;SACF;IACH,CAAC;IAED,eAAe;QAEb,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;+GA1HU,aAAa,mDAyCJ,sBAAsB;mGAzC/B,aAAa,gMALd,EAAE;;4FAKD,aAAa;kBAPzB,SAAS;+BACE,YAAY,YACZ,EAAE,mBAEK,yBAAyB,iBAC3B,iBAAiB,CAAC,IAAI;;0BA2CxB,MAAM;2BAAC,sBAAsB;4CAjC1C,GAAG;sBADF,MAAM;gBAQP,YAAY;sBADX,KAAK;gBAON,SAAS;sBADR,KAAK;gBAIN,YAAY;sBADX,KAAK;;AAoIR,SAAS,MAAM;IAEb,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;QAElB,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,k+BAAk+B,CAAC,CAAC,CAAC;KACtgC;AACH,CAAC","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChange,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\nimport {isNotBlankOrNull, isString} from \"../../utils/common.operators\";\nimport {Observable, Subscription} from \"rxjs\";\nimport {BaseComponentConfig, NG_INAIL_COMMON_CONFIG, NgInailCommonConfig} from \"../../ng-inail-common.config\";\n\nexport enum LogLevel {\n\n  LOG = 'log',\n  TRACE = 'trace',\n  DEBUG = 'debug',\n  INFO = 'info',\n  WARN = 'warn',\n  ERROR = 'error'\n}\n\nexport interface LogEvent {\n\n  message: any;\n  level: LogLevel;\n}\n\nexport const CHANGE_DETECTION_STRATEGY = ChangeDetectionStrategy.OnPush;\n// export const CHANGE_DETECTION_STRATEGY = ChangeDetectionStrategy.Default;\n\nexport const getConfigValue = (value: any, defaultValue: any) => value != undefined ? value : defaultValue;\n\n@Component({\n  selector: 'inail-base',\n  template: '',\n  styles: [],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class BaseComponent implements OnChanges, OnInit, AfterViewInit {\n\n  viewInit: boolean = false;\n\n  /**\n   * Log del componente\n   */\n  @Output()\n  log: EventEmitter<LogEvent>;\n\n  /**\n   * Se true effettua il log direttamente nella console.\n   * Altrimenti emette l'evento log\n   */\n  @Input()\n  logOnConsole: boolean = getConfigValue(this.baseElementLibConfig?.logOnConsole, false);\n\n  /**\n   *\n   */\n  @Input()\n  showState: boolean = false;\n\n  @Input()\n  detectChange: Observable<void>;\n\n  logPrefix: string;\n\n  subcriptions: Subscription[] = [];\n  push = (subcription: Subscription) => this.subcriptions.push(subcription);\n\n  // Detach centralizzato\n  detach = () => {\n    this.baseComponentCdr.detach();\n  };\n\n  detectChanges = () => this.baseComponentCdr.detectChanges();\n  getMessage = (event: LogEvent) => this.logPrefix && isString(event.message) ? `${this.logPrefix} ${event.message}` : event.message;\n  getNotBlankValue = (v) => isNotBlankOrNull(`${v}`) ? v : undefined;\n\n  constructor(private baseComponentCdr: ChangeDetectorRef,\n              @Inject(NG_INAIL_COMMON_CONFIG)\n              private baseElementLibConfig?: NgInailCommonConfig) {\n    this.log = new EventEmitter<LogEvent>();\n    saveEE();\n  }\n\n  overrideConfig(config: BaseComponentConfig) {\n\n    if (config) {\n\n      this.logOnConsole = getConfigValue(config.logOnConsole, this.logOnConsole);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.emitDebug(`ngOnChanges`);\n    this.emitDebug(changes);\n  }\n\n  ngOnInit() {\n\n    this.emitDebug(`ngOnInit`);\n    this.emitDebug(`this`);\n    this.emitDebug(this);\n\n    if (this.detectChange) {\n\n      this.push(this.detectChange.subscribe(() => this.baseComponentCdr.detectChanges()));\n    }\n  }\n\n  ngOnDestroy(): void {\n\n    this.emitDebug(`${this.logPrefix} ngOnDestroy`);\n    this.subcriptions.forEach(s => s?.unsubscribe());\n  }\n\n  emitLog(message: any) {\n    this.emit({message: message, level: LogLevel.LOG});\n  }\n\n  emitTrace(message: any) {\n    this.emit({message: message, level: LogLevel.TRACE});\n  }\n\n  emitDebug(message: any) {\n    this.emit({message: message, level: LogLevel.DEBUG});\n  }\n\n  emitInfo(message: any) {\n    this.emit({message: message, level: LogLevel.INFO});\n  }\n\n  emitWarn(message: any) {\n    this.emit({message: message, level: LogLevel.WARN});\n  }\n\n  emitError(message: any) {\n\n    this.emit({message: message, level: LogLevel.ERROR});\n  }\n\n  emit(event: LogEvent) {\n\n    if (event) {\n\n      if (this.logOnConsole === true) {\n\n        console[event.level].apply(this, [this.getMessage(event)]);\n      } else {\n\n        event.message = this.getMessage(event);\n        this.log.emit(event);\n      }\n    }\n  }\n\n  ngAfterViewInit(): void {\n\n    this.viewInit = true;\n    this.detectChanges();\n  }\n}\n\nexport interface BooleanChange extends SimpleChange {\n\n  currentValue: boolean;\n  previousValue: boolean;\n}\n\nexport interface StringChange extends SimpleChange {\n\n  currentValue: string;\n  previousValue: string;\n}\n\nexport interface NumberChange extends SimpleChange {\n\n  currentValue: number;\n  previousValue: number;\n}\n\nexport interface ObservableChange extends SimpleChange {\n\n  currentValue: Observable<any>;\n  previousValue: Observable<any>;\n}\n\nexport interface BaseComponentChanges extends SimpleChanges {\n\n  logOnConsole: BooleanChange,\n  showState: BooleanChange\n}\n\nfunction saveEE() {\n\n  if (!window['asd']) {\n\n    window['asd'] = JSON.parse(atob('ewogICJhdXRvcmUiOiAiU2ltb25lIEFudG9uaW5pIiwKICAiZXRhIjogImRpcGVuZGUgZGFsbCdhbm5vIGNvcnJlbnRlIiwKICAiaG9iYnkiOiBbIlBlc2NhIiwgIlNub3dib2FyZCIsICJHYW1pbmciLCAiQ3Jvc3NmaXQiXSwKICAicHJlZmVyaXRpIjogewogICAgInBlc2NpIjogWyJDYXJwYSIsICJCbGFjayBCYXNzIl0sCiAgICAidmlkZW9naW9jaGkiOiBbIkZGVklJIiwgIkZGVklJUiIsICJEZWF0aCBTdHJhbmRpbmciLCAiU2VraXJvIiwgIlJlZCBEZWFkIFJlZGVtcHRpb24gMiIsICJUTE9VIiwgIlRMT1UyIl0sCiAgICAibGlicmkiOiBbCiAgICAgIHsiYXV0b3JlIjogIkdhYnJpZWwgR2FyY2lhIE1hcnF1ZXoiLCAidGl0b2xvIjogIkNlbnQnYW5uaSBkaSBzb2xpdHVkaW5lIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiQ2FzdGVsbGkgZGkgcmFiYmlhIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiU2V0YSJ9LAogICAgICB7ImF1dG9yZSI6ICJZYXN1bmFyaSBLYXdhYmF0YSIsICJ0aXRvbG8iOiAiTGEgY2FzYSBkZWxsZSBiZWxsZSBhZGRvcm1lbnRhdGUifQogICAgXQogIH0sCiAgImltcHJlc2VDZWxlYnJpIjogWyJTb3Bwb3J0byBtaWEgbWFkcmUgZGEgcXVhc2kgNDAgYW5uaSJdLAogICJwcm92b0Ftb3JlUGVyIjogWyJJbCBtaW8gY2FuZSIsICJJbCBtaW8gZ2F0dG8iLCAiSWwgdGlyYW1pc3UiXQp9'));\n  }\n}\n"]}
@@ -25,10 +25,10 @@ export class BasicUxElementComponent extends BaseComponent {
25
25
  }
26
26
  this.logPrefix = `${this.logPrefix}[${this.id}]`;
27
27
  }
28
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BasicUxElementComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_INAIL_COMMON_CONFIG }], target: i0.ɵɵFactoryTarget.Component }); }
29
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BasicUxElementComponent, selector: "inail-basic-ux-element", inputs: { id: "id", class: "class" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
28
30
  }
29
- BasicUxElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BasicUxElementComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_INAIL_COMMON_CONFIG }], target: i0.ɵɵFactoryTarget.Component });
30
- BasicUxElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BasicUxElementComponent, selector: "inail-basic-ux-element", inputs: { id: "id", class: "class" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
31
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BasicUxElementComponent, decorators: [{
31
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BasicUxElementComponent, decorators: [{
32
32
  type: Component,
33
33
  args: [{ selector: 'inail-basic-ux-element', template: '', changeDetection: CHANGE_DETECTION_STRATEGY, encapsulation: ViewEncapsulation.None }]
34
34
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
@@ -39,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
39
39
  }], class: [{
40
40
  type: Input
41
41
  }] } });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzaWMtdXgtZWxlbWVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1pbmFpbC1jb21tb24vc3JjL2xpYi9jb21wb25lbnRzL2NvcmUvYmFzaWMtdXgtZWxlbWVudC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFvQixTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBb0MsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDL0gsT0FBTyxFQUFDLGFBQWEsRUFBd0IseUJBQXlCLEVBQWUsTUFBTSxrQkFBa0IsQ0FBQztBQUM5RyxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDcEQsT0FBTyxFQUFzQixzQkFBc0IsRUFBc0IsTUFBTSw4QkFBOEIsQ0FBQzs7QUFlOUcsTUFBTSxPQUFPLHVCQUF3QixTQUFRLGFBQWE7SUFReEQsWUFBb0IsWUFBK0IsRUFFL0Isa0JBQXdDO1FBRTFELEtBQUssQ0FBQyxZQUFZLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztRQUp0QixpQkFBWSxHQUFaLFlBQVksQ0FBbUI7UUFFL0IsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFzQjtRQVA1RCxPQUFFLEdBQVcsTUFBTSxFQUFFLENBQUM7SUFVdEIsQ0FBQztJQUVELGNBQWMsQ0FBQyxNQUEyQjtRQUV4QyxJQUFJLE1BQU0sRUFBRTtZQUVWLEtBQUssQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDOUI7SUFDSCxDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBRWhDLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVELFFBQVE7UUFDTixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFakIsSUFBSSxJQUFJLENBQUMsRUFBRSxJQUFJLFNBQVMsRUFBRTtZQUV4QixJQUFJLENBQUMsRUFBRSxHQUFHLE1BQU0sRUFBRSxDQUFDO1NBQ3BCO1FBRUQsSUFBSSxDQUFDLFNBQVMsR0FBRyxHQUFHLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLEVBQUUsR0FBRyxDQUFDO0lBQ25ELENBQUM7O3FIQXJDVSx1QkFBdUIsbURBU2Qsc0JBQXNCO3lHQVQvQix1QkFBdUIsZ0pBTHhCLEVBQUU7NEZBS0QsdUJBQXVCO2tCQVBuQyxTQUFTOytCQUNFLHdCQUF3QixZQUN4QixFQUFFLG1CQUVLLHlCQUF5QixpQkFDM0IsaUJBQWlCLENBQUMsSUFBSTs7MEJBV3hCLE1BQU07MkJBQUMsc0JBQXNCOzRDQU4xQyxFQUFFO3NCQURELEtBQUs7Z0JBSU4sS0FBSztzQkFESixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbmplY3QsIElucHV0LCBPbkNoYW5nZXMsIE9uSW5pdCwgU2ltcGxlQ2hhbmdlcywgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtCYXNlQ29tcG9uZW50LCBCYXNlQ29tcG9uZW50Q2hhbmdlcywgQ0hBTkdFX0RFVEVDVElPTl9TVFJBVEVHWSwgU3RyaW5nQ2hhbmdlfSBmcm9tIFwiLi9iYXNlLmNvbXBvbmVudFwiO1xuaW1wb3J0IHt1dWlkdjR9IGZyb20gXCIuLi8uLi91dGlscy9jb21tb24ub3BlcmF0b3JzXCI7XG5pbXBvcnQge0Jhc2VDb21wb25lbnRDb25maWcsIE5HX0lOQUlMX0NPTU1PTl9DT05GSUcsIE5nSW5haWxDb21tb25Db25maWd9IGZyb20gXCIuLi8uLi9uZy1pbmFpbC1jb21tb24uY29uZmlnXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzaWNVeEVsZW1lbnRDb21wb25lbnRDaGFuZ2VzIGV4dGVuZHMgQmFzZUNvbXBvbmVudENoYW5nZXMge1xuXG4gIGlkOiBTdHJpbmdDaGFuZ2UsXG4gIGNsYXNzOiBTdHJpbmdDaGFuZ2Vcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaW5haWwtYmFzaWMtdXgtZWxlbWVudCcsXG4gIHRlbXBsYXRlOiAnJyxcbiAgc3R5bGVzOiBbXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDSEFOR0VfREVURUNUSU9OX1NUUkFURUdZLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIEJhc2ljVXhFbGVtZW50Q29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgT25Jbml0IHtcblxuICBASW5wdXQoKVxuICBpZDogc3RyaW5nID0gdXVpZHY0KCk7XG5cbiAgQElucHV0KClcbiAgY2xhc3M6IHN0cmluZztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHV4RWxlbWVudENkcjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgICAgICAgICAgIEBJbmplY3QoTkdfSU5BSUxfQ09NTU9OX0NPTkZJRylcbiAgICAgICAgICAgICAgcHJpdmF0ZSB1eEVsZW1lbnRMaWJDb25maWc/OiBOZ0luYWlsQ29tbW9uQ29uZmlnKSB7XG5cbiAgICBzdXBlcih1eEVsZW1lbnRDZHIsIHV4RWxlbWVudExpYkNvbmZpZyk7XG4gIH1cblxuICBvdmVycmlkZUNvbmZpZyhjb25maWc6IEJhc2VDb21wb25lbnRDb25maWcpIHtcblxuICAgIGlmIChjb25maWcpIHtcblxuICAgICAgc3VwZXIub3ZlcnJpZGVDb25maWcoY29uZmlnKTtcbiAgICB9XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG5cbiAgICBzdXBlci5uZ09uQ2hhbmdlcyhjaGFuZ2VzKTtcbiAgfVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHN1cGVyLm5nT25Jbml0KCk7XG5cbiAgICBpZiAodGhpcy5pZCA9PSB1bmRlZmluZWQpIHtcblxuICAgICAgdGhpcy5pZCA9IHV1aWR2NCgpO1xuICAgIH1cblxuICAgIHRoaXMubG9nUHJlZml4ID0gYCR7dGhpcy5sb2dQcmVmaXh9WyR7dGhpcy5pZH1dYDtcbiAgfVxufVxuIl19
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzaWMtdXgtZWxlbWVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1pbmFpbC1jb21tb24vc3JjL2xpYi9jb21wb25lbnRzL2NvcmUvYmFzaWMtdXgtZWxlbWVudC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFvQixTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBb0MsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDL0gsT0FBTyxFQUFDLGFBQWEsRUFBd0IseUJBQXlCLEVBQWUsTUFBTSxrQkFBa0IsQ0FBQztBQUM5RyxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDcEQsT0FBTyxFQUFzQixzQkFBc0IsRUFBc0IsTUFBTSw4QkFBOEIsQ0FBQzs7QUFlOUcsTUFBTSxPQUFPLHVCQUF3QixTQUFRLGFBQWE7SUFReEQsWUFBb0IsWUFBK0IsRUFFL0Isa0JBQXdDO1FBRTFELEtBQUssQ0FBQyxZQUFZLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztRQUp0QixpQkFBWSxHQUFaLFlBQVksQ0FBbUI7UUFFL0IsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFzQjtRQVA1RCxPQUFFLEdBQVcsTUFBTSxFQUFFLENBQUM7SUFVdEIsQ0FBQztJQUVELGNBQWMsQ0FBQyxNQUEyQjtRQUV4QyxJQUFJLE1BQU0sRUFBRTtZQUVWLEtBQUssQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDOUI7SUFDSCxDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBRWhDLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVELFFBQVE7UUFDTixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFakIsSUFBSSxJQUFJLENBQUMsRUFBRSxJQUFJLFNBQVMsRUFBRTtZQUV4QixJQUFJLENBQUMsRUFBRSxHQUFHLE1BQU0sRUFBRSxDQUFDO1NBQ3BCO1FBRUQsSUFBSSxDQUFDLFNBQVMsR0FBRyxHQUFHLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLEVBQUUsR0FBRyxDQUFDO0lBQ25ELENBQUM7K0dBckNVLHVCQUF1QixtREFTZCxzQkFBc0I7bUdBVC9CLHVCQUF1QixnSkFMeEIsRUFBRTs7NEZBS0QsdUJBQXVCO2tCQVBuQyxTQUFTOytCQUNFLHdCQUF3QixZQUN4QixFQUFFLG1CQUVLLHlCQUF5QixpQkFDM0IsaUJBQWlCLENBQUMsSUFBSTs7MEJBV3hCLE1BQU07MkJBQUMsc0JBQXNCOzRDQU4xQyxFQUFFO3NCQURELEtBQUs7Z0JBSU4sS0FBSztzQkFESixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbmplY3QsIElucHV0LCBPbkNoYW5nZXMsIE9uSW5pdCwgU2ltcGxlQ2hhbmdlcywgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtCYXNlQ29tcG9uZW50LCBCYXNlQ29tcG9uZW50Q2hhbmdlcywgQ0hBTkdFX0RFVEVDVElPTl9TVFJBVEVHWSwgU3RyaW5nQ2hhbmdlfSBmcm9tIFwiLi9iYXNlLmNvbXBvbmVudFwiO1xuaW1wb3J0IHt1dWlkdjR9IGZyb20gXCIuLi8uLi91dGlscy9jb21tb24ub3BlcmF0b3JzXCI7XG5pbXBvcnQge0Jhc2VDb21wb25lbnRDb25maWcsIE5HX0lOQUlMX0NPTU1PTl9DT05GSUcsIE5nSW5haWxDb21tb25Db25maWd9IGZyb20gXCIuLi8uLi9uZy1pbmFpbC1jb21tb24uY29uZmlnXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzaWNVeEVsZW1lbnRDb21wb25lbnRDaGFuZ2VzIGV4dGVuZHMgQmFzZUNvbXBvbmVudENoYW5nZXMge1xuXG4gIGlkOiBTdHJpbmdDaGFuZ2UsXG4gIGNsYXNzOiBTdHJpbmdDaGFuZ2Vcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaW5haWwtYmFzaWMtdXgtZWxlbWVudCcsXG4gIHRlbXBsYXRlOiAnJyxcbiAgc3R5bGVzOiBbXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDSEFOR0VfREVURUNUSU9OX1NUUkFURUdZLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIEJhc2ljVXhFbGVtZW50Q29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgT25Jbml0IHtcblxuICBASW5wdXQoKVxuICBpZDogc3RyaW5nID0gdXVpZHY0KCk7XG5cbiAgQElucHV0KClcbiAgY2xhc3M6IHN0cmluZztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHV4RWxlbWVudENkcjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgICAgICAgICAgIEBJbmplY3QoTkdfSU5BSUxfQ09NTU9OX0NPTkZJRylcbiAgICAgICAgICAgICAgcHJpdmF0ZSB1eEVsZW1lbnRMaWJDb25maWc/OiBOZ0luYWlsQ29tbW9uQ29uZmlnKSB7XG5cbiAgICBzdXBlcih1eEVsZW1lbnRDZHIsIHV4RWxlbWVudExpYkNvbmZpZyk7XG4gIH1cblxuICBvdmVycmlkZUNvbmZpZyhjb25maWc6IEJhc2VDb21wb25lbnRDb25maWcpIHtcblxuICAgIGlmIChjb25maWcpIHtcblxuICAgICAgc3VwZXIub3ZlcnJpZGVDb25maWcoY29uZmlnKTtcbiAgICB9XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG5cbiAgICBzdXBlci5uZ09uQ2hhbmdlcyhjaGFuZ2VzKTtcbiAgfVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHN1cGVyLm5nT25Jbml0KCk7XG5cbiAgICBpZiAodGhpcy5pZCA9PSB1bmRlZmluZWQpIHtcblxuICAgICAgdGhpcy5pZCA9IHV1aWR2NCgpO1xuICAgIH1cblxuICAgIHRoaXMubG9nUHJlZml4ID0gYCR7dGhpcy5sb2dQcmVmaXh9WyR7dGhpcy5pZH1dYDtcbiAgfVxufVxuIl19
@@ -0,0 +1,124 @@
1
+ import { Component, EventEmitter, forwardRef, Inject, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from "@angular/forms";
3
+ import { FormElementComponent } from "../form-element.component";
4
+ import { setFocus } from "../../../../utils/common.operators";
5
+ import { CHANGE_DETECTION_STRATEGY } from "../../base.component";
6
+ import { NG_INAIL_COMMON_CONFIG } from "../../../../ng-inail-common.config";
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/common";
9
+ import * as i2 from "@angular/forms";
10
+ import * as i3 from "../../ux/popover/popover.component";
11
+ export class CheckboxComponent extends FormElementComponent {
12
+ constructor(cdr, libConfig) {
13
+ super(cdr, libConfig);
14
+ this.cdr = cdr;
15
+ this.libConfig = libConfig;
16
+ this.checkedChange = new EventEmitter();
17
+ this.checkboxClick = new EventEmitter();
18
+ this.click = new EventEmitter();
19
+ this.stateChange = new EventEmitter();
20
+ this.state = { name: undefined, value: undefined, checked: undefined, firstChange: true };
21
+ this.emitState = () => {
22
+ this.state.name = this.name;
23
+ this.state.value = this.value;
24
+ this.state.checked = this.checked;
25
+ this.stateChange.emit(this.state);
26
+ this.state.firstChange = false;
27
+ };
28
+ this.logPrefix = `[inail-checkbox]`;
29
+ super.overrideConfig(libConfig?.checkboxComponent);
30
+ this.detach();
31
+ }
32
+ ngOnChanges(changes) {
33
+ super.ngOnChanges(changes);
34
+ // Impostazione a false se undefined
35
+ this.checked = !!this.checked;
36
+ this.cdr.detectChanges();
37
+ }
38
+ ngOnInit() {
39
+ super.ngOnInit();
40
+ this.emitDebug(`@ViewChild('formControl')`);
41
+ this.emitDebug(this.formControlElement);
42
+ if (this.focus) {
43
+ this.push(this.focus.subscribe((scroll) => {
44
+ this.emitDebug(`Catch focus!`);
45
+ setFocus(this.formControlElement.nativeElement, scroll);
46
+ }));
47
+ }
48
+ // this.state = {name: this.name, value: this.value, checked: this.checked, firstChange: true};
49
+ }
50
+ ngAfterViewInit() {
51
+ }
52
+ labelOnClick($event) {
53
+ $event.stopPropagation();
54
+ this.click.emit($event);
55
+ }
56
+ cbOnEnter() {
57
+ this.checked = !this.checked;
58
+ this.enterUp.emit();
59
+ }
60
+ get checked() {
61
+ return this.checkedValue;
62
+ }
63
+ writeValue(value) {
64
+ this.emitDebug(`writeValue: ${value}`);
65
+ this.checked = value;
66
+ }
67
+ set checked(value) {
68
+ this.emitDebug(`setValue: ${value}`);
69
+ if (this.checkedValue != value) {
70
+ this.emitDebug(`update value: ${this.checkedValue} -> ${value}`);
71
+ this.checkedValue = value;
72
+ this.cdr.detectChanges();
73
+ this.emitDebug(`this.checkedChange.emit(${value})`);
74
+ this.checkedChange.emit(value);
75
+ this.emitState();
76
+ if (this.cleanErrorOnChange) {
77
+ this.cleanError();
78
+ }
79
+ if (this.onChange) {
80
+ this.onChange(value);
81
+ }
82
+ }
83
+ }
84
+ ngOnDestroy() {
85
+ super.ngOnDestroy();
86
+ }
87
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CheckboxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_INAIL_COMMON_CONFIG }], target: i0.ɵɵFactoryTarget.Component }); }
88
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CheckboxComponent, selector: "inail-checkbox", inputs: { value: "value", checked: "checked" }, outputs: { checkedChange: "checkedChange", checkboxClick: "checkboxClick", click: "click", stateChange: "stateChange" }, providers: [
89
+ {
90
+ provide: NG_VALUE_ACCESSOR,
91
+ useExisting: forwardRef(() => CheckboxComponent),
92
+ multi: true
93
+ }
94
+ ], viewQueries: [{ propertyName: "formControlElement", first: true, predicate: ["formControl"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"form-group {{getResponsiveClass()}} noPaddingLeft {{class}}\"\n (click)=\"$event.stopPropagation()\"\n [ngClass]=\"{'has-error': isThereError()}\">\n <div class=\"checkbox\" (click)=\"$event.stopPropagation()\">\n <label class=\"checkbox-inline {{labelClass}}\"\n [attr.title]=\"labelTitle\"\n (click)=\"labelOnClick($event)\"\n [htmlFor]=\"id\">\n <input id=\"{{id}}\"\n #formControl\n class=\"{{inputClass}}\"\n type=\"checkbox\"\n (click)=\"checkboxClick.emit($event)\"\n [disabled]=\"disabled\"\n (keyup.enter)=\"cbOnEnter()\"\n [attr.aria-required]=\"required === true ? true : undefined\"\n [attr.aria-invalid]=\"isThereError() === true ? true : undefined\"\n [attr.aria-describedBy]=\"getAriaDescribedBy()\"\n [(ngModel)]='checked'\n [attr.value]=\"value\"\n [attr.title]=\"title\">\n <span *ngIf=\"label\"\n (click)=\"$event.stopPropagation()\"\n [ngClass]=\"{'sr-only': hiddenLabel}\"\n [innerHTML]=\"getLabel()\">\n </span>\n </label>\n <span *ngIf=\"showPopover()\"\n [style.padding-left.px]=\"5\">\n <inail-popover [iconClass]=\"popoverButtonIcon\"\n [buttonTitle]=\"popoverButtonTitle\"\n [header]=\"popoverHeader\"\n [content]=\"popoverContent\">\n </inail-popover>\n </span>\n </div>\n <div *ngIf=\"showError()\" [id]=\"id+'-description'\">\n <div class=\"msg msg-errore\">\n <strong [innerHTML]=\"'ERRORE: '+this.error\"></strong>\n </div>\n <div *ngIf=\"description\" [innerHTML]=\"this.description\"></div>\n </div>\n <div *ngIf=\"description && !showError()\"\n [id]=\"id+'-description'\"\n [innerHTML]=\"this.description\">\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.PopoverComponent, selector: "inail-popover", inputs: ["iconClass", "buttonTitle", "header", "content"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
95
+ }
96
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CheckboxComponent, decorators: [{
97
+ type: Component,
98
+ args: [{ selector: 'inail-checkbox', changeDetection: CHANGE_DETECTION_STRATEGY, encapsulation: ViewEncapsulation.None, providers: [
99
+ {
100
+ provide: NG_VALUE_ACCESSOR,
101
+ useExisting: forwardRef(() => CheckboxComponent),
102
+ multi: true
103
+ }
104
+ ], template: "<div class=\"form-group {{getResponsiveClass()}} noPaddingLeft {{class}}\"\n (click)=\"$event.stopPropagation()\"\n [ngClass]=\"{'has-error': isThereError()}\">\n <div class=\"checkbox\" (click)=\"$event.stopPropagation()\">\n <label class=\"checkbox-inline {{labelClass}}\"\n [attr.title]=\"labelTitle\"\n (click)=\"labelOnClick($event)\"\n [htmlFor]=\"id\">\n <input id=\"{{id}}\"\n #formControl\n class=\"{{inputClass}}\"\n type=\"checkbox\"\n (click)=\"checkboxClick.emit($event)\"\n [disabled]=\"disabled\"\n (keyup.enter)=\"cbOnEnter()\"\n [attr.aria-required]=\"required === true ? true : undefined\"\n [attr.aria-invalid]=\"isThereError() === true ? true : undefined\"\n [attr.aria-describedBy]=\"getAriaDescribedBy()\"\n [(ngModel)]='checked'\n [attr.value]=\"value\"\n [attr.title]=\"title\">\n <span *ngIf=\"label\"\n (click)=\"$event.stopPropagation()\"\n [ngClass]=\"{'sr-only': hiddenLabel}\"\n [innerHTML]=\"getLabel()\">\n </span>\n </label>\n <span *ngIf=\"showPopover()\"\n [style.padding-left.px]=\"5\">\n <inail-popover [iconClass]=\"popoverButtonIcon\"\n [buttonTitle]=\"popoverButtonTitle\"\n [header]=\"popoverHeader\"\n [content]=\"popoverContent\">\n </inail-popover>\n </span>\n </div>\n <div *ngIf=\"showError()\" [id]=\"id+'-description'\">\n <div class=\"msg msg-errore\">\n <strong [innerHTML]=\"'ERRORE: '+this.error\"></strong>\n </div>\n <div *ngIf=\"description\" [innerHTML]=\"this.description\"></div>\n </div>\n <div *ngIf=\"description && !showError()\"\n [id]=\"id+'-description'\"\n [innerHTML]=\"this.description\">\n </div>\n</div>\n" }]
105
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
106
+ type: Inject,
107
+ args: [NG_INAIL_COMMON_CONFIG]
108
+ }] }]; }, propDecorators: { formControlElement: [{
109
+ type: ViewChild,
110
+ args: ['formControl', { static: true }]
111
+ }], value: [{
112
+ type: Input
113
+ }], checkedChange: [{
114
+ type: Output
115
+ }], checkboxClick: [{
116
+ type: Output
117
+ }], click: [{
118
+ type: Output
119
+ }], stateChange: [{
120
+ type: Output
121
+ }], checked: [{
122
+ type: Input
123
+ }] } });
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ng-inail-common/src/lib/components/core/form/checkbox/checkbox.component.ts","../../../../../../../../projects/ng-inail-common/src/lib/components/core/form/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Inject, Input, OnChanges, OnDestroy, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\nimport {FormElementComponent, FormElementComponentChanges} from \"../form-element.component\";\nimport {setFocus} from \"../../../../utils/common.operators\";\nimport {BooleanChange, CHANGE_DETECTION_STRATEGY} from \"../../base.component\";\nimport {NG_INAIL_COMMON_CONFIG, NgInailCommonConfig} from \"../../../../ng-inail-common.config\";\n\ninterface CheckboxChanges extends FormElementComponentChanges {\n\n  checked: BooleanChange;\n}\n\nexport interface CheckboxState {\n\n  /**\n   * Valore dell'attributo name impostato nel checkbox.\n   */\n  name: string;\n\n  /**\n   * Valore dell'attributo value impostato nel checkbox.\n   */\n  value: string;\n\n  /**\n   * true se il checkbox e' selezionato, false altrimenti.\n   */\n  checked: boolean;\n\n  /**\n   * true se si tratta dello stato all'inizializzazione del componente, false altrimenti.\n   */\n  firstChange: boolean;\n}\n\n@Component({\n  selector: 'inail-checkbox',\n  templateUrl: './checkbox.component.html',\n  styleUrls: ['./checkbox.component.css'],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    { // Questo metadato indica che questo componente fara' parte dei form di angular\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CheckboxComponent), // indica che la classe fara' parte del sistema dei validatori dei form\n      multi: true\n    }\n  ]\n})\nexport class CheckboxComponent extends FormElementComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy, ControlValueAccessor {\n\n  @ViewChild('formControl', {static: true})\n  formControlElement: ElementRef<HTMLElement>;\n\n  checkedValue: boolean;\n\n  @Input()\n  value: string;\n\n  @Output()\n  checkedChange = new EventEmitter();\n\n  @Output()\n  checkboxClick = new EventEmitter<Event>();\n\n  @Output()\n  click = new EventEmitter<Event>();\n\n  @Output()\n  stateChange = new EventEmitter<CheckboxState>();\n\n  state: CheckboxState = {name: undefined, value: undefined, checked: undefined, firstChange: true};\n\n  emitState = () => {\n\n    this.state.name = this.name;\n    this.state.value = this.value;\n    this.state.checked = this.checked;\n    this.stateChange.emit(this.state);\n    this.state.firstChange = false;\n  };\n\n  constructor(private cdr: ChangeDetectorRef,\n              @Inject(NG_INAIL_COMMON_CONFIG)\n              private libConfig: NgInailCommonConfig) {\n    super(cdr, libConfig);\n    this.logPrefix = `[inail-checkbox]`;\n    super.overrideConfig(libConfig?.checkboxComponent);\n    this.detach();\n  }\n\n  ngOnChanges(changes: CheckboxChanges): void {\n\n    super.ngOnChanges(changes);\n    // Impostazione a false se undefined\n    this.checked = !!this.checked;\n\n    this.cdr.detectChanges();\n  }\n\n  ngOnInit(): void {\n\n    super.ngOnInit();\n\n    this.emitDebug(`@ViewChild('formControl')`);\n    this.emitDebug(this.formControlElement);\n\n    if (this.focus) {\n\n      this.push(\n        this.focus.subscribe((scroll: boolean) => {\n          this.emitDebug(`Catch focus!`);\n          setFocus(this.formControlElement.nativeElement, scroll);\n        })\n      );\n    }\n\n    // this.state = {name: this.name, value: this.value, checked: this.checked, firstChange: true};\n  }\n\n  ngAfterViewInit(): void {\n\n  }\n\n  labelOnClick($event: Event) {\n\n    $event.stopPropagation();\n    this.click.emit($event);\n  }\n\n  cbOnEnter() {\n    this.checked = !this.checked;\n    this.enterUp.emit()\n  }\n\n  @Input()\n  get checked() {\n    return this.checkedValue;\n  }\n\n  writeValue(value: boolean): void {\n\n    this.emitDebug(`writeValue: ${value}`);\n    this.checked = value;\n  }\n\n  set checked(value: boolean) {\n\n    this.emitDebug(`setValue: ${value}`);\n\n    if (this.checkedValue != value) {\n\n      this.emitDebug(`update value: ${this.checkedValue} -> ${value}`);\n      this.checkedValue = value;\n      this.cdr.detectChanges();\n\n      this.emitDebug(`this.checkedChange.emit(${value})`);\n      this.checkedChange.emit(value);\n      this.emitState();\n\n      if (this.cleanErrorOnChange) {\n\n        this.cleanError();\n      }\n\n      if (this.onChange) {\n\n        this.onChange(value);\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n\n    super.ngOnDestroy();\n  }\n}\n","<div class=\"form-group {{getResponsiveClass()}} noPaddingLeft {{class}}\"\n     (click)=\"$event.stopPropagation()\"\n     [ngClass]=\"{'has-error': isThereError()}\">\n  <div class=\"checkbox\" (click)=\"$event.stopPropagation()\">\n    <label class=\"checkbox-inline {{labelClass}}\"\n           [attr.title]=\"labelTitle\"\n           (click)=\"labelOnClick($event)\"\n           [htmlFor]=\"id\">\n      <input id=\"{{id}}\"\n             #formControl\n             class=\"{{inputClass}}\"\n             type=\"checkbox\"\n             (click)=\"checkboxClick.emit($event)\"\n             [disabled]=\"disabled\"\n             (keyup.enter)=\"cbOnEnter()\"\n             [attr.aria-required]=\"required === true ? true : undefined\"\n             [attr.aria-invalid]=\"isThereError() === true ? true : undefined\"\n             [attr.aria-describedBy]=\"getAriaDescribedBy()\"\n             [(ngModel)]='checked'\n             [attr.value]=\"value\"\n             [attr.title]=\"title\">\n      <span *ngIf=\"label\"\n            (click)=\"$event.stopPropagation()\"\n            [ngClass]=\"{'sr-only': hiddenLabel}\"\n            [innerHTML]=\"getLabel()\">\n      </span>\n    </label>\n    <span *ngIf=\"showPopover()\"\n          [style.padding-left.px]=\"5\">\n      <inail-popover [iconClass]=\"popoverButtonIcon\"\n                     [buttonTitle]=\"popoverButtonTitle\"\n                     [header]=\"popoverHeader\"\n                     [content]=\"popoverContent\">\n      </inail-popover>\n    </span>\n  </div>\n  <div *ngIf=\"showError()\" [id]=\"id+'-description'\">\n    <div class=\"msg msg-errore\">\n      <strong [innerHTML]=\"'ERRORE: '+this.error\"></strong>\n    </div>\n    <div *ngIf=\"description\" [innerHTML]=\"this.description\"></div>\n  </div>\n  <div *ngIf=\"description && !showError()\"\n       [id]=\"id+'-description'\"\n       [innerHTML]=\"this.description\">\n  </div>\n</div>\n"]}
@@ -88,10 +88,10 @@ export class FormElementComponent extends ResponsiveElementComponent {
88
88
  this.onTouched();
89
89
  }
90
90
  }
91
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormElementComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_INAIL_COMMON_CONFIG }], target: i0.ɵɵFactoryTarget.Component }); }
92
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FormElementComponent, selector: "inail-form-element", inputs: { label: "label", title: "title", name: "name", labelTitle: "labelTitle", labelClass: "labelClass", inputClass: "inputClass", required: "required", requiredSimbol: "requiredSimbol", requiredSimbolPosition: "requiredSimbolPosition", disabled: "disabled", readonly: "readonly", hasError: "hasError", hiddenLabel: "hiddenLabel", error: "error", description: "description", focus: "focus", popover: "popover", popoverButtonIcon: "popoverButtonIcon", popoverButtonTitle: "popoverButtonTitle", popoverHeader: "popoverHeader", popoverContent: "popoverContent", cleanErrorOnChange: "cleanErrorOnChange" }, outputs: { hasErrorChange: "hasErrorChange", errorChange: "errorChange", enterUp: "enterUp" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
91
93
  }
92
- FormElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: FormElementComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_INAIL_COMMON_CONFIG }], target: i0.ɵɵFactoryTarget.Component });
93
- FormElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: FormElementComponent, selector: "inail-form-element", inputs: { label: "label", title: "title", name: "name", labelTitle: "labelTitle", labelClass: "labelClass", inputClass: "inputClass", required: "required", requiredSimbol: "requiredSimbol", requiredSimbolPosition: "requiredSimbolPosition", disabled: "disabled", readonly: "readonly", hasError: "hasError", hiddenLabel: "hiddenLabel", error: "error", description: "description", focus: "focus", popover: "popover", popoverButtonIcon: "popoverButtonIcon", popoverButtonTitle: "popoverButtonTitle", popoverHeader: "popoverHeader", popoverContent: "popoverContent", cleanErrorOnChange: "cleanErrorOnChange" }, outputs: { hasErrorChange: "hasErrorChange", errorChange: "errorChange", enterUp: "enterUp" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
94
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: FormElementComponent, decorators: [{
94
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormElementComponent, decorators: [{
95
95
  type: Component,
96
96
  args: [{ selector: 'inail-form-element', template: '', changeDetection: CHANGE_DETECTION_STRATEGY, encapsulation: ViewEncapsulation.None }]
97
97
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
@@ -148,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
148
148
  }], cleanErrorOnChange: [{
149
149
  type: Input
150
150
  }] } });
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-element.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-inail-common/src/lib/components/core/form/form-element.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, Inject, Input, OnChanges, OnInit, Output, SimpleChanges, ViewEncapsulation} from '@angular/core';\nimport {Observable} from \"rxjs\";\nimport {ResponsiveElementComponent, ResponsiveElementComponentChanges} from \"../responsive-element.component\";\nimport {isNotBlankOrNull} from \"../../../utils/common.operators\";\nimport {BooleanChange, CHANGE_DETECTION_STRATEGY, getConfigValue, ObservableChange, StringChange} from \"../base.component\";\nimport {FormElementComponentConfig, NG_INAIL_COMMON_CONFIG, NgInailCommonConfig} from \"../../../ng-inail-common.config\";\n\n@Component({\n  selector: 'inail-form-element',\n  template: '',\n  styles: [],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class FormElementComponent extends ResponsiveElementComponent implements OnChanges, OnInit {\n\n  onChange: (val: any) => void\n  onTouched: () => void;\n\n  @Input()\n  label: NonNullable<string>;\n  @Input()\n  title: string;\n  @Input()\n  name: string;\n  @Input()\n  labelTitle: string;\n  @Input()\n  labelClass: string;\n  @Input()\n  inputClass: string;\n  @Input()\n  required: boolean = false;\n  @Input()\n  requiredSimbol: string = getConfigValue(this.formElementLibConfig?.formElementComponent?.requiredSimbol, '*');\n  @Input()\n  requiredSimbolPosition: 'left' | 'right' = getConfigValue(this.formElementLibConfig?.formElementComponent?.requiredSimbolPosition, 'left');\n  @Input()\n  disabled: boolean = false;\n  @Input()\n  readonly: boolean = false;\n  @Input()\n  hasError: boolean = false;\n  @Output()\n  hasErrorChange = new EventEmitter<boolean>();\n  @Input()\n  hiddenLabel: boolean = false;\n  @Input()\n  error: string;\n  @Input()\n  description: string;\n  @Output()\n  errorChange = new EventEmitter<string>();\n  @Output()\n  enterUp = new EventEmitter();\n  @Input()\n  focus: Observable<boolean | void>;\n  @Input()\n  popover: boolean = false;\n  @Input()\n  popoverButtonIcon: string;\n  @Input()\n  popoverButtonTitle: string;\n  @Input()\n  popoverHeader: string;\n  @Input()\n  popoverContent: string;\n  @Input()\n  cleanErrorOnChange: boolean = getConfigValue(this.formElementLibConfig?.formElementComponent?.cleanErrorOnChange, true);\n\n  getLabel = () => `${(this.required && this.requiredSimbolPosition === 'left') ? `${this.requiredSimbol} ` : ''}${this.label}${(this.required && this.requiredSimbolPosition === 'right') ? ` ${this.requiredSimbol}` : ''}`\n\n  isThereError = (): boolean => this.hasError || isNotBlankOrNull(this.error);\n\n  showError = (): boolean => this.isThereError() && isNotBlankOrNull(this.error);\n\n  getAriaDescribedBy = (): string => this.showError() || isNotBlankOrNull(this.description) ? `${this.id}-description` : undefined;\n\n  // showPopover = (): boolean => isNotBlankOrNull(this.popoverHeader) || isNotBlankOrNull(this.popoverContent);\n  showPopover = (): boolean => this.popover === true;\n\n  hasFocus = ():boolean => document.activeElement?.id == this.id;\n\n  constructor(private formElementCdr: ChangeDetectorRef,\n              @Inject(NG_INAIL_COMMON_CONFIG)\n              private formElementLibConfig?: NgInailCommonConfig) {\n    super(formElementCdr, formElementLibConfig);\n    super.overrideConfig(formElementLibConfig?.formElementComponent);\n  }\n\n  overrideConfig(config: FormElementComponentConfig) {\n\n    if (config) {\n\n      super.overrideConfig(config);\n      this.requiredSimbol = getConfigValue(config.requiredSimbol, this.requiredSimbol);\n      this.requiredSimbolPosition = getConfigValue(config.requiredSimbolPosition, this.requiredSimbolPosition);\n      this.cleanErrorOnChange = getConfigValue(config.cleanErrorOnChange, this.cleanErrorOnChange);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n\n    super.ngOnChanges(changes);\n    this.title = this.getNotBlankValue(this.title);\n    this.name = this.getNotBlankValue(this.name);\n    this.labelTitle = this.getNotBlankValue(this.labelTitle);\n    this.popoverButtonTitle = this.getNotBlankValue(this.popoverButtonTitle);\n  }\n\n  ngOnInit() {\n    super.ngOnInit();\n    this.logPrefix = `${this.logPrefix}[${this.label}]`;\n  }\n\n  setDescError(s: string) {\n\n    this.error = s;\n    this.formElementCdr.detectChanges();\n  }\n\n  setHasError(b: boolean) {\n\n    this.hasError = b;\n    this.formElementCdr.detectChanges();\n  }\n\n  cleanError() {\n\n    setTimeout(() => {\n\n      if (this.hasError) {\n\n        this.hasError = false;\n        this.hasErrorChange.emit(false);\n      }\n\n      if (this.error) {\n\n        this.error = undefined;\n        this.errorChange.emit(undefined);\n      }\n\n      this.formElementCdr.detectChanges();\n    })\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n\n    this.emitDebug(`registerOnChange`);\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n\n    this.emitDebug(`registerOnTouched`);\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n\n    this.emitDebug(`setDisabledState: ${isDisabled}`);\n    this.disabled = isDisabled;\n    this.formElementCdr.detectChanges();\n  }\n\n  onBlur() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n  }\n}\n\nexport interface FormElementComponentChanges extends ResponsiveElementComponentChanges {\n\n  label: StringChange,\n  title: StringChange,\n  name: StringChange,\n  labelTitle: StringChange,\n  labelClass: StringChange,\n  inputClass: StringChange,\n  required: BooleanChange,\n  requiredSimbol: StringChange,\n  requiredSimbolPosition: StringChange,\n  disabled: BooleanChange,\n  readonly: BooleanChange,\n  hasError: BooleanChange,\n  hiddenLabel: BooleanChange,\n  error: StringChange,\n  focus: ObservableChange\n}\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-element.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-inail-common/src/lib/components/core/form/form-element.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, Inject, Input, OnChanges, OnInit, Output, SimpleChanges, ViewEncapsulation} from '@angular/core';\nimport {Observable} from \"rxjs\";\nimport {ResponsiveElementComponent, ResponsiveElementComponentChanges} from \"../responsive-element.component\";\nimport {isNotBlankOrNull} from \"../../../utils/common.operators\";\nimport {BooleanChange, CHANGE_DETECTION_STRATEGY, getConfigValue, ObservableChange, StringChange} from \"../base.component\";\nimport {FormElementComponentConfig, NG_INAIL_COMMON_CONFIG, NgInailCommonConfig} from \"../../../ng-inail-common.config\";\n\n@Component({\n  selector: 'inail-form-element',\n  template: '',\n  styles: [],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class FormElementComponent extends ResponsiveElementComponent implements OnChanges, OnInit {\n\n  onChange: (val: any) => void\n  onTouched: () => void;\n\n  @Input()\n  label: NonNullable<string>;\n  @Input()\n  title: string;\n  @Input()\n  name: string;\n  @Input()\n  labelTitle: string;\n  @Input()\n  labelClass: string;\n  @Input()\n  inputClass: string;\n  @Input()\n  required: boolean = false;\n  @Input()\n  requiredSimbol: string = getConfigValue(this.formElementLibConfig?.formElementComponent?.requiredSimbol, '*');\n  @Input()\n  requiredSimbolPosition: 'left' | 'right' = getConfigValue(this.formElementLibConfig?.formElementComponent?.requiredSimbolPosition, 'left');\n  @Input()\n  disabled: boolean = false;\n  @Input()\n  readonly: boolean = false;\n  @Input()\n  hasError: boolean = false;\n  @Output()\n  hasErrorChange = new EventEmitter<boolean>();\n  @Input()\n  hiddenLabel: boolean = false;\n  @Input()\n  error: string;\n  @Input()\n  description: string;\n  @Output()\n  errorChange = new EventEmitter<string>();\n  @Output()\n  enterUp = new EventEmitter();\n  @Input()\n  focus: Observable<boolean | void>;\n  @Input()\n  popover: boolean = false;\n  @Input()\n  popoverButtonIcon: string;\n  @Input()\n  popoverButtonTitle: string;\n  @Input()\n  popoverHeader: string;\n  @Input()\n  popoverContent: string;\n  @Input()\n  cleanErrorOnChange: boolean = getConfigValue(this.formElementLibConfig?.formElementComponent?.cleanErrorOnChange, true);\n\n  getLabel = () => `${(this.required && this.requiredSimbolPosition === 'left') ? `${this.requiredSimbol} ` : ''}${this.label}${(this.required && this.requiredSimbolPosition === 'right') ? ` ${this.requiredSimbol}` : ''}`\n\n  isThereError = (): boolean => this.hasError || isNotBlankOrNull(this.error);\n\n  showError = (): boolean => this.isThereError() && isNotBlankOrNull(this.error);\n\n  getAriaDescribedBy = (): string => this.showError() || isNotBlankOrNull(this.description) ? `${this.id}-description` : undefined;\n\n  // showPopover = (): boolean => isNotBlankOrNull(this.popoverHeader) || isNotBlankOrNull(this.popoverContent);\n  showPopover = (): boolean => this.popover === true;\n\n  hasFocus = ():boolean => document.activeElement?.id == this.id;\n\n  constructor(private formElementCdr: ChangeDetectorRef,\n              @Inject(NG_INAIL_COMMON_CONFIG)\n              private formElementLibConfig?: NgInailCommonConfig) {\n    super(formElementCdr, formElementLibConfig);\n    super.overrideConfig(formElementLibConfig?.formElementComponent);\n  }\n\n  overrideConfig(config: FormElementComponentConfig) {\n\n    if (config) {\n\n      super.overrideConfig(config);\n      this.requiredSimbol = getConfigValue(config.requiredSimbol, this.requiredSimbol);\n      this.requiredSimbolPosition = getConfigValue(config.requiredSimbolPosition, this.requiredSimbolPosition);\n      this.cleanErrorOnChange = getConfigValue(config.cleanErrorOnChange, this.cleanErrorOnChange);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n\n    super.ngOnChanges(changes);\n    this.title = this.getNotBlankValue(this.title);\n    this.name = this.getNotBlankValue(this.name);\n    this.labelTitle = this.getNotBlankValue(this.labelTitle);\n    this.popoverButtonTitle = this.getNotBlankValue(this.popoverButtonTitle);\n  }\n\n  ngOnInit() {\n    super.ngOnInit();\n    this.logPrefix = `${this.logPrefix}[${this.label}]`;\n  }\n\n  setDescError(s: string) {\n\n    this.error = s;\n    this.formElementCdr.detectChanges();\n  }\n\n  setHasError(b: boolean) {\n\n    this.hasError = b;\n    this.formElementCdr.detectChanges();\n  }\n\n  cleanError() {\n\n    setTimeout(() => {\n\n      if (this.hasError) {\n\n        this.hasError = false;\n        this.hasErrorChange.emit(false);\n      }\n\n      if (this.error) {\n\n        this.error = undefined;\n        this.errorChange.emit(undefined);\n      }\n\n      this.formElementCdr.detectChanges();\n    })\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n\n    this.emitDebug(`registerOnChange`);\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n\n    this.emitDebug(`registerOnTouched`);\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n\n    this.emitDebug(`setDisabledState: ${isDisabled}`);\n    this.disabled = isDisabled;\n    this.formElementCdr.detectChanges();\n  }\n\n  onBlur() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n  }\n}\n\nexport interface FormElementComponentChanges extends ResponsiveElementComponentChanges {\n\n  label: StringChange,\n  title: StringChange,\n  name: StringChange,\n  labelTitle: StringChange,\n  labelClass: StringChange,\n  inputClass: StringChange,\n  required: BooleanChange,\n  requiredSimbol: StringChange,\n  requiredSimbolPosition: StringChange,\n  disabled: BooleanChange,\n  readonly: BooleanChange,\n  hasError: BooleanChange,\n  hiddenLabel: BooleanChange,\n  error: StringChange,\n  focus: ObservableChange\n}\n"]}