@jooler/inputs 0.0.55 → 0.0.56
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/choose-general-item/choose-general-item.component.mjs +75 -14
- package/esm2022/lib/choose-general-item-renderer/choose-general-item-renderer-change-event.interface.mjs +2 -0
- package/esm2022/lib/choose-general-item-renderer/choose-general-item-renderer-validation-type.enum.mjs +6 -0
- package/esm2022/lib/choose-general-item-renderer/choose-general-item-renderer.component.mjs +112 -18
- package/esm2022/lib/formcontrol-validation-msg-for-ng-select.directive.mjs +126 -0
- package/esm2022/lib/inputs.module.mjs +21 -15
- package/esm2022/lib/tooltip-msg-error/tooltip-message-type.enum.mjs +8 -0
- package/esm2022/lib/tooltip-msg-error/tooltip-msg-error.component.mjs +213 -0
- package/esm2022/public-api.mjs +16 -12
- package/fesm2022/inputs.mjs +953 -459
- package/fesm2022/inputs.mjs.map +1 -1
- package/lib/choose-general-item/choose-general-item.component.d.ts +8 -3
- package/lib/choose-general-item-renderer/choose-general-item-renderer-change-event.interface.d.ts +9 -0
- package/lib/choose-general-item-renderer/choose-general-item-renderer-validation-type.enum.d.ts +4 -0
- package/lib/choose-general-item-renderer/choose-general-item-renderer.component.d.ts +19 -4
- package/lib/formcontrol-validation-msg-for-ng-select.directive.d.ts +23 -0
- package/lib/inputs.module.d.ts +9 -7
- package/lib/tooltip-msg-error/tooltip-message-type.enum.d.ts +6 -0
- package/lib/tooltip-msg-error/tooltip-msg-error.component.d.ts +49 -0
- package/package.json +2 -2
- package/public-api.d.ts +15 -11
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { Directive, HostListener, Input } from '@angular/core';
|
|
2
|
+
import { NgModel } from '@angular/forms';
|
|
3
|
+
import { PrimaryColors } from './primary-colors';
|
|
4
|
+
import { ValidationError } from './services/validation-message.service';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/forms";
|
|
7
|
+
export class FormControlValidationMsgDirectiveForNgSelect {
|
|
8
|
+
elRef;
|
|
9
|
+
control;
|
|
10
|
+
errorMessage;
|
|
11
|
+
showDot;
|
|
12
|
+
errorDivId;
|
|
13
|
+
afterEnd = true;
|
|
14
|
+
showBoxError = true;
|
|
15
|
+
validationError = ValidationError;
|
|
16
|
+
statusChangeSubscription;
|
|
17
|
+
constructor(elRef, control) {
|
|
18
|
+
this.elRef = elRef;
|
|
19
|
+
this.control = control;
|
|
20
|
+
}
|
|
21
|
+
ngOnInit() {
|
|
22
|
+
if (!this.errorDivId) {
|
|
23
|
+
this.errorDivId = this.control.name;
|
|
24
|
+
}
|
|
25
|
+
this.statusChangeSubscription = this.control.statusChanges.subscribe(status => {
|
|
26
|
+
if (status == 'INVALID' && this.control.touched) {
|
|
27
|
+
this.showNgSelectError();
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
this.removeError();
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
this.control.valueChanges.subscribe({
|
|
34
|
+
next: () => {
|
|
35
|
+
if (this.control.errors && this.control.touched) {
|
|
36
|
+
this.showNgSelectError();
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
this.removeError();
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
onFocusout() {
|
|
45
|
+
if (this.control.errors && this.control.touched) {
|
|
46
|
+
this.showNgSelectError();
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
this.removeError();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
removeError() {
|
|
53
|
+
this.errorMessage = '';
|
|
54
|
+
const errorElement = document.getElementById(this.errorDivId);
|
|
55
|
+
if (errorElement)
|
|
56
|
+
errorElement.remove();
|
|
57
|
+
}
|
|
58
|
+
showNgSelectError() {
|
|
59
|
+
this.removeError();
|
|
60
|
+
const valErrors = this.control.errors;
|
|
61
|
+
if (this.control.errors.length > 1) {
|
|
62
|
+
this.showDot = true;
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
this.showDot = false;
|
|
66
|
+
}
|
|
67
|
+
if (valErrors) {
|
|
68
|
+
const keys = Object.keys(valErrors);
|
|
69
|
+
for (let i = 0; i < keys.length; i++) {
|
|
70
|
+
switch (keys[i]) {
|
|
71
|
+
case 'required': {
|
|
72
|
+
let message = this.validationError.getRelevantError(keys[i], valErrors);
|
|
73
|
+
this.errorMessage += ` ${this.errorMessage ? '<br>' : ''}${this.showDot ? '\u25CF ' + message : message}`;
|
|
74
|
+
this.control.control.setErrors({ required: true, message: message }, { emitEvent: false });
|
|
75
|
+
break;
|
|
76
|
+
}
|
|
77
|
+
case 'validatePhoneNumber': {
|
|
78
|
+
let message = this.validationError.getRelevantError(keys[i], valErrors);
|
|
79
|
+
this.errorMessage += ` ${this.errorMessage ? '<br>' : ''}${this.showDot ? '\u25CF ' + message : message}`;
|
|
80
|
+
this.control.control.setErrors({ validatePhoneNumber: true, message: message }, { emitEvent: false });
|
|
81
|
+
break;
|
|
82
|
+
}
|
|
83
|
+
case 'customMessage': {
|
|
84
|
+
console.log('valErrors', valErrors);
|
|
85
|
+
let message = valErrors.message;
|
|
86
|
+
this.errorMessage += ` ${this.errorMessage ? '<br>' : ''}${this.showDot ? '\u25CF ' + message : message}`;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
if (this.showBoxError) {
|
|
91
|
+
const errDiv = `<div style="color:${PrimaryColors.$primaryRedColor}; width: ${this.afterEnd ? this.elRef.nativeElement.offsetWidth + 'px' : '100%'}; min-width: 100%; background-color: ${PrimaryColors.$primaryLightRedColor}; padding: .5rem; border-radius: .5rem; border: .1rem solid ${PrimaryColors.$primaryRedColor} ;border-left: .75rem solid ${PrimaryColors.$primaryRedColor}; margin-top:.5rem; font-size: 1.2rem; " id="` +
|
|
92
|
+
this.errorDivId +
|
|
93
|
+
'">' +
|
|
94
|
+
`<h3 style= " font-size: 1.3rem; margin-bottom:.5rem; margin:0; color: ${PrimaryColors.$primaryRedColor}; font-weight: 700; line-height: 1.6rem;">` +
|
|
95
|
+
'Please Complete all details' +
|
|
96
|
+
'</h3>' +
|
|
97
|
+
this.errorMessage +
|
|
98
|
+
'</div>';
|
|
99
|
+
if (!this.afterEnd)
|
|
100
|
+
this.elRef.nativeElement.parentElement.insertAdjacentHTML('afterend', errDiv);
|
|
101
|
+
else {
|
|
102
|
+
this.elRef.nativeElement.insertAdjacentHTML('afterend', errDiv);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormControlValidationMsgDirectiveForNgSelect, deps: [{ token: i0.ElementRef }, { token: i1.NgControl }], target: i0.ɵɵFactoryTarget.Directive });
|
|
108
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: FormControlValidationMsgDirectiveForNgSelect, selector: "[appFormControlValidationMsgForNgSelect]", inputs: { afterEnd: "afterEnd", showBoxError: "showBoxError" }, host: { listeners: { "focusout": "onFocusout()" } }, providers: [NgModel], ngImport: i0 });
|
|
109
|
+
}
|
|
110
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormControlValidationMsgDirectiveForNgSelect, decorators: [{
|
|
111
|
+
type: Directive,
|
|
112
|
+
args: [{
|
|
113
|
+
selector: '[appFormControlValidationMsgForNgSelect]',
|
|
114
|
+
providers: [NgModel],
|
|
115
|
+
}]
|
|
116
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.NgControl }]; }, propDecorators: { afterEnd: [{
|
|
117
|
+
type: Input,
|
|
118
|
+
args: ['afterEnd']
|
|
119
|
+
}], showBoxError: [{
|
|
120
|
+
type: Input,
|
|
121
|
+
args: ['showBoxError']
|
|
122
|
+
}], onFocusout: [{
|
|
123
|
+
type: HostListener,
|
|
124
|
+
args: ['focusout']
|
|
125
|
+
}] } });
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formcontrol-validation-msg-for-ng-select.directive.js","sourceRoot":"","sources":["../../../../projects/inputs/src/lib/formcontrol-validation-msg-for-ng-select.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, OnInit } from '@angular/core';\r\nimport { NgControl, NgModel, ValidationErrors } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { PrimaryColors } from './primary-colors';\r\nimport { ValidationError } from './services/validation-message.service';\r\n\r\n@Directive({\r\n  selector: '[appFormControlValidationMsgForNgSelect]',\r\n  providers: [NgModel],\r\n})\r\nexport class FormControlValidationMsgDirectiveForNgSelect implements OnInit {\r\n  errorMessage: any;\r\n  showDot: boolean;\r\n  errorDivId: string | number;\r\n  @Input('afterEnd') afterEnd: boolean = true;\r\n  @Input('showBoxError') showBoxError: boolean = true;\r\n  validationError = ValidationError;\r\n  statusChangeSubscription: Subscription;\r\n\r\n  constructor(\r\n    private elRef: ElementRef,\r\n    private control: NgControl\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.errorDivId) {\r\n      this.errorDivId = this.control.name;\r\n    }\r\n    this.statusChangeSubscription = this.control.statusChanges.subscribe(status => {\r\n      if (status == 'INVALID' && this.control.touched) {\r\n        this.showNgSelectError();\r\n      } else {\r\n        this.removeError();\r\n      }\r\n    });\r\n    this.control.valueChanges.subscribe({\r\n      next: () => {\r\n        if (this.control.errors && this.control.touched) {\r\n          this.showNgSelectError();\r\n        } else {\r\n          this.removeError();\r\n        }\r\n      },\r\n    });\r\n  }\r\n\r\n  @HostListener('focusout')\r\n  onFocusout() {\r\n    if (this.control.errors && this.control.touched) {\r\n      this.showNgSelectError();\r\n    } else {\r\n      this.removeError();\r\n    }\r\n  }\r\n\r\n  private removeError(): void {\r\n    this.errorMessage = '';\r\n    const errorElement = document.getElementById(this.errorDivId as string);\r\n    if (errorElement) errorElement.remove();\r\n  }\r\n\r\n  private showNgSelectError() {\r\n    this.removeError();\r\n    const valErrors: ValidationErrors = this.control.errors;\r\n\r\n    if (this.control.errors.length > 1) {\r\n      this.showDot = true;\r\n    } else {\r\n      this.showDot = false;\r\n    }\r\n    if (valErrors) {\r\n      const keys = Object.keys(valErrors);\r\n      for (let i = 0; i < keys.length; i++) {\r\n        switch (keys[i]) {\r\n          case 'required': {\r\n            let message = this.validationError.getRelevantError(keys[i], valErrors);\r\n            this.errorMessage += ` ${this.errorMessage ? '<br>' : ''}${this.showDot ? '\\u25CF ' + message : message}`;\r\n            this.control.control.setErrors(\r\n              { required: true, message: message },\r\n              { emitEvent: false }\r\n            );\r\n            break;\r\n          }\r\n          case 'validatePhoneNumber': {\r\n            let message = this.validationError.getRelevantError(keys[i], valErrors);\r\n            this.errorMessage += ` ${this.errorMessage ? '<br>' : ''}${this.showDot ? '\\u25CF ' + message : message}`;\r\n            this.control.control.setErrors(\r\n              { validatePhoneNumber: true, message: message },\r\n              { emitEvent: false }\r\n            );\r\n            break;\r\n          }\r\n          case 'customMessage': {\r\n            console.log('valErrors', valErrors);\r\n            let message = valErrors.message;\r\n            this.errorMessage += ` ${this.errorMessage ? '<br>' : ''}${this.showDot ? '\\u25CF ' + message : message}`;\r\n          }\r\n        }\r\n      }\r\n      if (this.showBoxError) {\r\n        const errDiv =\r\n          `<div style=\"color:${PrimaryColors.$primaryRedColor}; width: ${this.afterEnd ? this.elRef.nativeElement.offsetWidth + 'px' : '100%'}; min-width: 100%; background-color: ${PrimaryColors.$primaryLightRedColor}; padding: .5rem; border-radius: .5rem; border: .1rem solid ${PrimaryColors.$primaryRedColor} ;border-left: .75rem solid ${PrimaryColors.$primaryRedColor};  margin-top:.5rem;  font-size: 1.2rem; \" id=\"` +\r\n          this.errorDivId +\r\n          '\">' +\r\n          `<h3   style= \" font-size: 1.3rem;  margin-bottom:.5rem; margin:0;  color:  ${PrimaryColors.$primaryRedColor}; font-weight: 700; line-height: 1.6rem;\">` +\r\n          'Please Complete all details' +\r\n          '</h3>' +\r\n          this.errorMessage +\r\n          '</div>';\r\n        if (!this.afterEnd)\r\n          this.elRef.nativeElement.parentElement.insertAdjacentHTML('afterend', errDiv);\r\n        else {\r\n          this.elRef.nativeElement.insertAdjacentHTML('afterend', errDiv);\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -1,26 +1,28 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
3
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
-
import {
|
|
4
|
+
import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';
|
|
5
|
+
import { AppMaterialModule } from '@jooler/app-material';
|
|
5
6
|
import { SharedGeneralComponentsModule } from '@jooler/shared-general-components';
|
|
6
|
-
import {
|
|
7
|
+
import { NgSelectModule } from '@ng-select/ng-select';
|
|
8
|
+
import { AddAsteriskDirective } from './add-asterisk.directive';
|
|
7
9
|
import { ChooseEnumRendererComponent } from './choose-enum-renderer/choose-enum-renderer.component';
|
|
10
|
+
import { ChooseEnumComponent } from './choose-enum/choose-enum.component';
|
|
11
|
+
import { ChooseGeneralItemRendererComponent } from './choose-general-item-renderer/choose-general-item-renderer.component';
|
|
8
12
|
import { ChooseGeneralItemComponent } from './choose-general-item/choose-general-item.component';
|
|
13
|
+
import { ChooseGeneralItemService } from './choose-general-item/choose-general-item.service';
|
|
9
14
|
import { ChooseLineTypeComponent } from './choose-line-type/choose-line-type.component';
|
|
10
|
-
import { ChooseYesOrNoComponent } from './choose-yes-or-no/choose-yes-or-no.component';
|
|
11
15
|
import { ChooseYesOrNoRendererComponent } from './choose-yes-or-no-renderer/choose-yes-or-no-renderer.component';
|
|
12
|
-
import {
|
|
13
|
-
import {
|
|
14
|
-
import { AppMaterialModule } from '@jooler/app-material';
|
|
16
|
+
import { ChooseYesOrNoComponent } from './choose-yes-or-no/choose-yes-or-no.component';
|
|
17
|
+
import { DropdownActionsComponent } from './dropdown-actions/dropdown-actions.component';
|
|
15
18
|
import { DynamicPipe } from './editable-savable-input/dynamicPipe';
|
|
16
|
-
import {
|
|
19
|
+
import { EditableSavableInputComponent } from './editable-savable-input/editable-savable-input.component';
|
|
20
|
+
import { FormControlValidationMsgDirectiveForNgSelect } from './formcontrol-validation-msg-for-ng-select.directive';
|
|
21
|
+
import { FormControlValidationMsgDirectiveForInput } from './formcontrol-validation-msg.directive';
|
|
17
22
|
import { CustomDecimalPointTwoDigitsDirective } from './general-input-renderer/custom-decimal-point-two-digits.directive';
|
|
23
|
+
import { GeneralInputRendererComponent } from './general-input-renderer/general-input-renderer.component';
|
|
18
24
|
import { ShowTableErrorsComponent } from './show-table-errors/show-table-errors.component';
|
|
19
|
-
import {
|
|
20
|
-
import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';
|
|
21
|
-
import { ChooseGeneralItemService } from './choose-general-item/choose-general-item.service';
|
|
22
|
-
import { DropdownActionsComponent } from './dropdown-actions/dropdown-actions.component';
|
|
23
|
-
import { AddAsteriskDirective } from './add-asterisk.directive';
|
|
25
|
+
import { TooltipMsgError } from './tooltip-msg-error/tooltip-msg-error.component';
|
|
24
26
|
import * as i0 from "@angular/core";
|
|
25
27
|
export class InputsModule {
|
|
26
28
|
static forRoot(environment) {
|
|
@@ -50,7 +52,9 @@ export class InputsModule {
|
|
|
50
52
|
ShowTableErrorsComponent,
|
|
51
53
|
FormControlValidationMsgDirectiveForInput,
|
|
52
54
|
DropdownActionsComponent,
|
|
53
|
-
AddAsteriskDirective
|
|
55
|
+
AddAsteriskDirective,
|
|
56
|
+
FormControlValidationMsgDirectiveForNgSelect,
|
|
57
|
+
TooltipMsgError], imports: [CommonModule,
|
|
54
58
|
NgSelectModule,
|
|
55
59
|
FormsModule,
|
|
56
60
|
ReactiveFormsModule,
|
|
@@ -93,7 +97,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
93
97
|
ShowTableErrorsComponent,
|
|
94
98
|
FormControlValidationMsgDirectiveForInput,
|
|
95
99
|
DropdownActionsComponent,
|
|
96
|
-
AddAsteriskDirective
|
|
100
|
+
AddAsteriskDirective,
|
|
101
|
+
FormControlValidationMsgDirectiveForNgSelect,
|
|
102
|
+
TooltipMsgError
|
|
97
103
|
],
|
|
98
104
|
imports: [
|
|
99
105
|
CommonModule,
|
|
@@ -119,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
119
125
|
]
|
|
120
126
|
}]
|
|
121
127
|
}] });
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputs.module.js","sourceRoot":"","sources":["../../../../projects/inputs/src/lib/inputs.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { ModuleWithProviders, NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome';\r\nimport { AppMaterialModule } from '@jooler/app-material';\r\nimport { SharedGeneralComponentsModule } from '@jooler/shared-general-components';\r\nimport { NgSelectModule } from '@ng-select/ng-select';\r\nimport { AddAsteriskDirective } from './add-asterisk.directive';\r\nimport { ChooseEnumRendererComponent } from './choose-enum-renderer/choose-enum-renderer.component';\r\nimport { ChooseEnumComponent } from './choose-enum/choose-enum.component';\r\nimport { ChooseGeneralItemRendererComponent } from './choose-general-item-renderer/choose-general-item-renderer.component';\r\nimport { ChooseGeneralItemComponent } from './choose-general-item/choose-general-item.component';\r\nimport { ChooseGeneralItemService } from './choose-general-item/choose-general-item.service';\r\nimport { ChooseLineTypeComponent } from './choose-line-type/choose-line-type.component';\r\nimport { ChooseYesOrNoRendererComponent } from './choose-yes-or-no-renderer/choose-yes-or-no-renderer.component';\r\nimport { ChooseYesOrNoComponent } from './choose-yes-or-no/choose-yes-or-no.component';\r\nimport { DropdownActionsComponent } from './dropdown-actions/dropdown-actions.component';\r\nimport { DynamicPipe } from './editable-savable-input/dynamicPipe';\r\nimport { EditableSavableInputComponent } from './editable-savable-input/editable-savable-input.component';\r\nimport { FormControlValidationMsgDirectiveForNgSelect } from './formcontrol-validation-msg-for-ng-select.directive';\r\nimport { FormControlValidationMsgDirectiveForInput } from './formcontrol-validation-msg.directive';\r\nimport { CustomDecimalPointTwoDigitsDirective } from './general-input-renderer/custom-decimal-point-two-digits.directive';\r\nimport { GeneralInputRendererComponent } from './general-input-renderer/general-input-renderer.component';\r\nimport { ShowTableErrorsComponent } from './show-table-errors/show-table-errors.component';\r\nimport { TooltipMsgError } from './tooltip-msg-error/tooltip-msg-error.component';\r\n\r\n\r\n@NgModule({\r\n  declarations: [\r\n    ChooseEnumComponent,\r\n    ChooseEnumRendererComponent,\r\n    ChooseGeneralItemComponent,\r\n    GeneralInputRendererComponent,\r\n    ChooseLineTypeComponent,\r\n    ChooseYesOrNoComponent,\r\n    ChooseYesOrNoRendererComponent,\r\n    EditableSavableInputComponent,\r\n    DynamicPipe,\r\n    ChooseGeneralItemRendererComponent,\r\n    CustomDecimalPointTwoDigitsDirective,\r\n    ShowTableErrorsComponent,\r\n    FormControlValidationMsgDirectiveForInput,\r\n    DropdownActionsComponent,\r\n    AddAsteriskDirective,\r\n    FormControlValidationMsgDirectiveForNgSelect,\r\n    TooltipMsgError\r\n  ],\r\n  imports: [\r\n    CommonModule,\r\n    NgSelectModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    AppMaterialModule,\r\n    SharedGeneralComponentsModule,\r\n    FontAwesomeModule,\r\n  ],\r\n  exports: [\r\n    ChooseEnumComponent,\r\n    ChooseEnumRendererComponent,\r\n    ChooseGeneralItemComponent,\r\n    GeneralInputRendererComponent,\r\n    ChooseLineTypeComponent,\r\n    ChooseYesOrNoComponent,\r\n    ChooseYesOrNoRendererComponent,\r\n    EditableSavableInputComponent,\r\n    DropdownActionsComponent,\r\n    DynamicPipe,\r\n    AddAsteriskDirective\r\n  ]\r\n})\r\nexport class InputsModule {\r\n\r\n  public static forRoot(environment: any): ModuleWithProviders<InputsModule> {\r\n\r\n    return {\r\n      ngModule: InputsModule,\r\n      providers: [\r\n        ChooseGeneralItemService,\r\n        {\r\n          provide: 'env',\r\n          useValue: environment\r\n        }\r\n      ]\r\n    };\r\n  }\r\n}"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export var ToolTipMessageType;
|
|
2
|
+
(function (ToolTipMessageType) {
|
|
3
|
+
ToolTipMessageType[ToolTipMessageType["ERROR"] = 0] = "ERROR";
|
|
4
|
+
ToolTipMessageType[ToolTipMessageType["WARNING"] = 1] = "WARNING";
|
|
5
|
+
ToolTipMessageType[ToolTipMessageType["HELP"] = 2] = "HELP";
|
|
6
|
+
ToolTipMessageType[ToolTipMessageType["DEFAULT"] = 3] = "DEFAULT";
|
|
7
|
+
})(ToolTipMessageType || (ToolTipMessageType = {}));
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1tZXNzYWdlLXR5cGUuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2lucHV0cy9zcmMvbGliL3Rvb2x0aXAtbXNnLWVycm9yL3Rvb2x0aXAtbWVzc2FnZS10eXBlLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksa0JBS1g7QUFMRCxXQUFZLGtCQUFrQjtJQUM1Qiw2REFBUyxDQUFBO0lBQ1QsaUVBQVcsQ0FBQTtJQUNYLDJEQUFRLENBQUE7SUFDUixpRUFBVyxDQUFBO0FBQ2IsQ0FBQyxFQUxXLGtCQUFrQixLQUFsQixrQkFBa0IsUUFLN0IiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBUb29sVGlwTWVzc2FnZVR5cGUge1xyXG4gIEVSUk9SID0gMCxcclxuICBXQVJOSU5HID0gMSxcclxuICBIRUxQID0gMixcclxuICBERUZBVUxUID0gMyxcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
import { Component, HostListener, Input, } from '@angular/core';
|
|
2
|
+
import { PrimaryColors } from '../primary-colors';
|
|
3
|
+
import { ToolTipMessageType } from './tooltip-message-type.enum';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@fortawesome/angular-fontawesome";
|
|
7
|
+
export class TooltipMsgError {
|
|
8
|
+
cdr;
|
|
9
|
+
_El;
|
|
10
|
+
width;
|
|
11
|
+
control = null;
|
|
12
|
+
messageType = ToolTipMessageType.ERROR;
|
|
13
|
+
message;
|
|
14
|
+
iconElId;
|
|
15
|
+
messageElId;
|
|
16
|
+
isLeft = true;
|
|
17
|
+
showDetails;
|
|
18
|
+
tooltipIcon;
|
|
19
|
+
tooltipMessage;
|
|
20
|
+
iconStyle;
|
|
21
|
+
isDictionary;
|
|
22
|
+
onScrollY() {
|
|
23
|
+
this.onMouseLeave();
|
|
24
|
+
}
|
|
25
|
+
constructor(cdr, _El) {
|
|
26
|
+
this.cdr = cdr;
|
|
27
|
+
this._El = _El;
|
|
28
|
+
}
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
this.iconElId = this.generateRandomString();
|
|
31
|
+
this.messageElId = this.generateRandomString();
|
|
32
|
+
this.setIconStyle();
|
|
33
|
+
this.checkErrorType();
|
|
34
|
+
}
|
|
35
|
+
ngOnChanges(changes) {
|
|
36
|
+
this.checkErrorType();
|
|
37
|
+
}
|
|
38
|
+
ngOnDestroy() {
|
|
39
|
+
if (document.getElementById(this.messageElId)) {
|
|
40
|
+
document.getElementById(this.messageElId).remove();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
checkErrorType() {
|
|
44
|
+
if (this.message) {
|
|
45
|
+
if (this.message.constructor == Object) {
|
|
46
|
+
this.isDictionary = true;
|
|
47
|
+
}
|
|
48
|
+
else if (typeof this.message === 'string') {
|
|
49
|
+
this.isDictionary = false;
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
this.isDictionary = false;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
getThemedMessageStyle() {
|
|
57
|
+
let backgroundColor;
|
|
58
|
+
let fontBorderColor;
|
|
59
|
+
switch (this.messageType) {
|
|
60
|
+
case ToolTipMessageType.ERROR:
|
|
61
|
+
backgroundColor = '#fde5f0';
|
|
62
|
+
fontBorderColor = PrimaryColors.$primaryPinkColor;
|
|
63
|
+
break;
|
|
64
|
+
case ToolTipMessageType.WARNING:
|
|
65
|
+
backgroundColor = '#fdefdd';
|
|
66
|
+
fontBorderColor = PrimaryColors.$primaryOrangeColor;
|
|
67
|
+
break;
|
|
68
|
+
case ToolTipMessageType.HELP:
|
|
69
|
+
backgroundColor = '#d1f9f2';
|
|
70
|
+
fontBorderColor = PrimaryColors.$primaryTealColor;
|
|
71
|
+
break;
|
|
72
|
+
default:
|
|
73
|
+
backgroundColor = PrimaryColors.$primaryLightGrayColor;
|
|
74
|
+
fontBorderColor = PrimaryColors.$primaryGrayColor;
|
|
75
|
+
break;
|
|
76
|
+
}
|
|
77
|
+
let style = {
|
|
78
|
+
'background-color': backgroundColor,
|
|
79
|
+
'font-weight': 'bold',
|
|
80
|
+
color: fontBorderColor,
|
|
81
|
+
border: '0.2rem solid ' + fontBorderColor,
|
|
82
|
+
'border-left': '0.5rem solid ' + fontBorderColor,
|
|
83
|
+
};
|
|
84
|
+
return style;
|
|
85
|
+
}
|
|
86
|
+
setMessageStyle() {
|
|
87
|
+
let style = {};
|
|
88
|
+
if (this.width) {
|
|
89
|
+
style['width'] = this.width;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
get messageStyle() {
|
|
93
|
+
let commonMessageStyle = {};
|
|
94
|
+
if (this.width) {
|
|
95
|
+
commonMessageStyle['width'] = this.width;
|
|
96
|
+
}
|
|
97
|
+
return {
|
|
98
|
+
...commonMessageStyle,
|
|
99
|
+
...(this.showDetails ? this.getThemedMessageStyle() : {}),
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
setIconStyle() {
|
|
103
|
+
let backgroundColor;
|
|
104
|
+
switch (this.messageType) {
|
|
105
|
+
case ToolTipMessageType.ERROR:
|
|
106
|
+
backgroundColor = PrimaryColors.$primaryPinkColor;
|
|
107
|
+
break;
|
|
108
|
+
case ToolTipMessageType.WARNING:
|
|
109
|
+
backgroundColor = PrimaryColors.$primaryOrangeColor;
|
|
110
|
+
break;
|
|
111
|
+
case ToolTipMessageType.HELP:
|
|
112
|
+
backgroundColor = PrimaryColors.$primaryTealColor;
|
|
113
|
+
break;
|
|
114
|
+
default:
|
|
115
|
+
backgroundColor = PrimaryColors.$primaryGrayColor;
|
|
116
|
+
break;
|
|
117
|
+
}
|
|
118
|
+
let style = {
|
|
119
|
+
color: backgroundColor,
|
|
120
|
+
};
|
|
121
|
+
this.iconStyle = style;
|
|
122
|
+
}
|
|
123
|
+
onMouseEnter() {
|
|
124
|
+
this.showDetails = true;
|
|
125
|
+
// CDR is needed to let the DOM know the box error has a width
|
|
126
|
+
this.cdr.detectChanges();
|
|
127
|
+
this.tooltipMessage = document.getElementById(this.messageElId);
|
|
128
|
+
if (this.message) {
|
|
129
|
+
this.getDirection(this.tooltipMessage);
|
|
130
|
+
document.body.appendChild(this.tooltipMessage);
|
|
131
|
+
let messageElement = document.getElementById(this.messageElId);
|
|
132
|
+
let icon = document.getElementById(this.iconElId);
|
|
133
|
+
let rect = icon.getBoundingClientRect();
|
|
134
|
+
let top = rect.top;
|
|
135
|
+
let left = rect.left;
|
|
136
|
+
let right = rect.right;
|
|
137
|
+
let appendedLeft;
|
|
138
|
+
let appendedRight;
|
|
139
|
+
let appendedTop = top - messageElement.offsetHeight;
|
|
140
|
+
this.tooltipMessage.style.top = appendedTop + 'px';
|
|
141
|
+
this.tooltipMessage.style.zIndex = '1000';
|
|
142
|
+
if (this.isLeft) {
|
|
143
|
+
appendedLeft = left + icon.offsetWidth - 5;
|
|
144
|
+
this.tooltipMessage.style.left = appendedLeft + 'px';
|
|
145
|
+
}
|
|
146
|
+
else {
|
|
147
|
+
appendedRight = window.innerWidth - right + 5;
|
|
148
|
+
this.tooltipMessage.style.right = appendedRight + 'px';
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
onMouseLeave() {
|
|
153
|
+
this.showDetails = false;
|
|
154
|
+
}
|
|
155
|
+
getDirection(element) {
|
|
156
|
+
// Calculating the width difference between screen width minus the poistion of the icon from left to right (getBoundingClientRect().right)
|
|
157
|
+
let difference = window.innerWidth - element.getBoundingClientRect().right;
|
|
158
|
+
// hard coded + 12 is for the padding that has been added to router-outlet
|
|
159
|
+
// The if statment here check if there is enough space for the box error to show from left to right , if not enough space, the box error will pop up from right to left
|
|
160
|
+
if (difference <= element.offsetWidth + 12) {
|
|
161
|
+
this.isLeft = false;
|
|
162
|
+
}
|
|
163
|
+
else {
|
|
164
|
+
this.isLeft = true;
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
generateRandomString() {
|
|
168
|
+
let charsAndNumbs = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890';
|
|
169
|
+
let text = '';
|
|
170
|
+
for (let i = 0; i < 8; i++) {
|
|
171
|
+
text += charsAndNumbs.charAt(Math.floor(Math.random() * charsAndNumbs.length));
|
|
172
|
+
}
|
|
173
|
+
return text;
|
|
174
|
+
}
|
|
175
|
+
// Helper to decide how to display the value
|
|
176
|
+
formatValue(value) {
|
|
177
|
+
if (!value)
|
|
178
|
+
return '';
|
|
179
|
+
// 1. If it's an array (like your jurisdiction error)
|
|
180
|
+
if (Array.isArray(value)) {
|
|
181
|
+
// Map through the array and extract 'message' if it exists, otherwise stringify
|
|
182
|
+
return value
|
|
183
|
+
.map(item => {
|
|
184
|
+
return typeof item === 'object' && item.message ? item.message : JSON.stringify(item);
|
|
185
|
+
})
|
|
186
|
+
.join(', ');
|
|
187
|
+
}
|
|
188
|
+
// 2. If it's a single object (but not an array)
|
|
189
|
+
if (typeof value === 'object') {
|
|
190
|
+
return value.message || JSON.stringify(value);
|
|
191
|
+
}
|
|
192
|
+
// 3. It's a string or number
|
|
193
|
+
return value;
|
|
194
|
+
}
|
|
195
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TooltipMsgError, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
196
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TooltipMsgError, selector: "tooltip-msg-error", inputs: { width: "width", control: "control", messageType: "messageType", message: "message" }, host: { listeners: { "document:scroll ": "onScrollY()" } }, usesOnChanges: true, ngImport: i0, template: "<div\r\n *ngIf=\"message && !control\"\r\n class=\"container\"\r\n (mouseenter)=\"onMouseEnter()\"\r\n (mouseleave)=\"onMouseLeave()\">\r\n <fa-icon [id]=\"iconElId\" [ngStyle]=\"iconStyle\" icon=\"circle-exclamation\" class=\"icon\"></fa-icon>\r\n <div\r\n *ngIf=\"!isDictionary\"\r\n [ngStyle]=\"messageStyle\"\r\n [id]=\"messageElId\"\r\n class=\"message\"\r\n [ngClass]=\"{ 'no-details': !showDetails, details: showDetails }\">\r\n {{ message }}\r\n </div>\r\n\r\n <div\r\n *ngIf=\"isDictionary\"\r\n [ngStyle]=\"messageStyle\"\r\n [id]=\"messageElId\"\r\n class=\"message\"\r\n [ngClass]=\"{ 'no-details': !showDetails, details: showDetails }\">\r\n <div class=\"dict-cont\" *ngFor=\"let entry of message | keyvalue\">\r\n <strong>{{ entry.key }}: </strong>\r\n <span>{{ formatValue(entry.value) }}</span>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div\r\n *ngIf=\"control?.touched && control.errors\"\r\n class=\"container\"\r\n (mouseenter)=\"onMouseEnter()\"\r\n (mouseleave)=\"onMouseLeave()\">\r\n <fa-icon [ngStyle]=\"iconStyle\" [id]=\"iconElId\" icon=\"circle-exclamation\" class=\"icon\"></fa-icon>\r\n <div\r\n [ngStyle]=\"messageStyle\"\r\n [id]=\"messageElId\"\r\n class=\"message\"\r\n [ngClass]=\"{ 'no-details': !showDetails, details: showDetails }\">\r\n <div class=\"dict-cont\" *ngFor=\"let entry of message | keyvalue\">\r\n <strong>{{ entry.key }}: </strong>\r\n <span>{{ formatValue(entry.value) }}</span>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".no-details{display:none;position:unset}.icon{cursor:pointer;display:inline-block}.container{position:relative}.details{position:fixed;display:block;z-index:1000;border-radius:.5rem;padding:.75rem 1rem;width:max-content;max-width:500px;font-size:1.2rem;line-height:1.4}@media (max-width: 1024px){.details{max-width:320px}}@media (max-width: 768px){.details{max-width:90vw}}.right-section{right:0}.message{width:max-content;white-space:pre-line;pointer-events:none}.dict-cont{line-height:normal}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "pipe", type: i1.KeyValuePipe, name: "keyvalue" }] });
|
|
197
|
+
}
|
|
198
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TooltipMsgError, decorators: [{
|
|
199
|
+
type: Component,
|
|
200
|
+
args: [{ selector: 'tooltip-msg-error', template: "<div\r\n *ngIf=\"message && !control\"\r\n class=\"container\"\r\n (mouseenter)=\"onMouseEnter()\"\r\n (mouseleave)=\"onMouseLeave()\">\r\n <fa-icon [id]=\"iconElId\" [ngStyle]=\"iconStyle\" icon=\"circle-exclamation\" class=\"icon\"></fa-icon>\r\n <div\r\n *ngIf=\"!isDictionary\"\r\n [ngStyle]=\"messageStyle\"\r\n [id]=\"messageElId\"\r\n class=\"message\"\r\n [ngClass]=\"{ 'no-details': !showDetails, details: showDetails }\">\r\n {{ message }}\r\n </div>\r\n\r\n <div\r\n *ngIf=\"isDictionary\"\r\n [ngStyle]=\"messageStyle\"\r\n [id]=\"messageElId\"\r\n class=\"message\"\r\n [ngClass]=\"{ 'no-details': !showDetails, details: showDetails }\">\r\n <div class=\"dict-cont\" *ngFor=\"let entry of message | keyvalue\">\r\n <strong>{{ entry.key }}: </strong>\r\n <span>{{ formatValue(entry.value) }}</span>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div\r\n *ngIf=\"control?.touched && control.errors\"\r\n class=\"container\"\r\n (mouseenter)=\"onMouseEnter()\"\r\n (mouseleave)=\"onMouseLeave()\">\r\n <fa-icon [ngStyle]=\"iconStyle\" [id]=\"iconElId\" icon=\"circle-exclamation\" class=\"icon\"></fa-icon>\r\n <div\r\n [ngStyle]=\"messageStyle\"\r\n [id]=\"messageElId\"\r\n class=\"message\"\r\n [ngClass]=\"{ 'no-details': !showDetails, details: showDetails }\">\r\n <div class=\"dict-cont\" *ngFor=\"let entry of message | keyvalue\">\r\n <strong>{{ entry.key }}: </strong>\r\n <span>{{ formatValue(entry.value) }}</span>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".no-details{display:none;position:unset}.icon{cursor:pointer;display:inline-block}.container{position:relative}.details{position:fixed;display:block;z-index:1000;border-radius:.5rem;padding:.75rem 1rem;width:max-content;max-width:500px;font-size:1.2rem;line-height:1.4}@media (max-width: 1024px){.details{max-width:320px}}@media (max-width: 768px){.details{max-width:90vw}}.right-section{right:0}.message{width:max-content;white-space:pre-line;pointer-events:none}.dict-cont{line-height:normal}\n"] }]
|
|
201
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { width: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], control: [{
|
|
204
|
+
type: Input
|
|
205
|
+
}], messageType: [{
|
|
206
|
+
type: Input
|
|
207
|
+
}], message: [{
|
|
208
|
+
type: Input
|
|
209
|
+
}], onScrollY: [{
|
|
210
|
+
type: HostListener,
|
|
211
|
+
args: ['document:scroll ']
|
|
212
|
+
}] } });
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-msg-error.component.js","sourceRoot":"","sources":["../../../../../projects/inputs/src/lib/tooltip-msg-error/tooltip-msg-error.component.ts","../../../../../projects/inputs/src/lib/tooltip-msg-error/tooltip-msg-error.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,GAKN,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;;;;AAOjE,MAAM,OAAO,eAAe;IAoBhB;IACA;IApBD,KAAK,CAAS;IACd,OAAO,GAA2B,IAAI,CAAC;IACvC,WAAW,GAAuB,kBAAkB,CAAC,KAAK,CAAC;IAC3D,OAAO,CAAM;IACtB,QAAQ,CAAS;IACjB,WAAW,CAAS;IACpB,MAAM,GAAY,IAAI,CAAC;IACvB,WAAW,CAAU;IACrB,WAAW,CAAc;IACzB,cAAc,CAAc;IAC5B,SAAS,CAAM;IACf,YAAY,CAAU;IAGtB,SAAS;QACP,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,YACU,GAAsB,EACtB,GAAe;QADf,QAAG,GAAH,GAAG,CAAmB;QACtB,QAAG,GAAH,GAAG,CAAY;IACrB,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC/C,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,WAAW;QACT,IAAI,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YAC7C,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE,CAAC;SACpD;IACH,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,IAAI,MAAM,EAAE;gBACtC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;aAC1B;iBAAM,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,EAAE;gBAC3C,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;aAC3B;iBAAM;gBACL,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;aAC3B;SACF;IACH,CAAC;IAED,qBAAqB;QACnB,IAAI,eAAuB,CAAC;QAC5B,IAAI,eAAuB,CAAC;QAE5B,QAAQ,IAAI,CAAC,WAAW,EAAE;YACxB,KAAK,kBAAkB,CAAC,KAAK;gBAC3B,eAAe,GAAG,SAAS,CAAC;gBAC5B,eAAe,GAAG,aAAa,CAAC,iBAAiB,CAAC;gBAClD,MAAM;YACR,KAAK,kBAAkB,CAAC,OAAO;gBAC7B,eAAe,GAAG,SAAS,CAAC;gBAC5B,eAAe,GAAG,aAAa,CAAC,mBAAmB,CAAC;gBAEpD,MAAM;YACR,KAAK,kBAAkB,CAAC,IAAI;gBAC1B,eAAe,GAAG,SAAS,CAAC;gBAC5B,eAAe,GAAG,aAAa,CAAC,iBAAiB,CAAC;gBAClD,MAAM;YACR;gBACE,eAAe,GAAG,aAAa,CAAC,sBAAsB,CAAC;gBACvD,eAAe,GAAG,aAAa,CAAC,iBAAiB,CAAC;gBAClD,MAAM;SACT;QACD,IAAI,KAAK,GAAG;YACV,kBAAkB,EAAE,eAAe;YACnC,aAAa,EAAE,MAAM;YACrB,KAAK,EAAE,eAAe;YACtB,MAAM,EAAE,eAAe,GAAG,eAAe;YACzC,aAAa,EAAE,eAAe,GAAG,eAAe;SACjD,CAAC;QAEF,OAAO,KAAK,CAAC;IACf,CAAC;IAED,eAAe;QACb,IAAI,KAAK,GAAG,EAAE,CAAC;QAEf,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;SAC7B;IACH,CAAC;IAED,IAAI,YAAY;QACd,IAAI,kBAAkB,GAAG,EAAE,CAAC;QAE5B,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,kBAAkB,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;SAC1C;QACD,OAAO;YACL,GAAG,kBAAkB;YACrB,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC1D,CAAC;IACJ,CAAC;IAED,YAAY;QACV,IAAI,eAAuB,CAAC;QAC5B,QAAQ,IAAI,CAAC,WAAW,EAAE;YACxB,KAAK,kBAAkB,CAAC,KAAK;gBAC3B,eAAe,GAAG,aAAa,CAAC,iBAAiB,CAAC;gBAClD,MAAM;YACR,KAAK,kBAAkB,CAAC,OAAO;gBAC7B,eAAe,GAAG,aAAa,CAAC,mBAAmB,CAAC;gBACpD,MAAM;YACR,KAAK,kBAAkB,CAAC,IAAI;gBAC1B,eAAe,GAAG,aAAa,CAAC,iBAAiB,CAAC;gBAClD,MAAM;YACR;gBACE,eAAe,GAAG,aAAa,CAAC,iBAAiB,CAAC;gBAClD,MAAM;SACT;QACD,IAAI,KAAK,GAAG;YACV,KAAK,EAAE,eAAe;SACvB,CAAC;QAEF,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,+DAA+D;QAC/D,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAChE,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACvC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAC/C,IAAI,cAAc,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAC/D,IAAI,IAAI,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAClD,IAAI,IAAI,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAExC,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;YACnB,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;YACrB,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;YACvB,IAAI,YAAoB,CAAC;YACzB,IAAI,aAAqB,CAAC;YAC1B,IAAI,WAAW,GAAG,GAAG,GAAG,cAAc,CAAC,YAAY,CAAC;YACpD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG,GAAG,WAAW,GAAG,IAAI,CAAC;YACnD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;YAE1C,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,YAAY,GAAG,IAAI,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;gBAC3C,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,GAAG,YAAY,GAAG,IAAI,CAAC;aACtD;iBAAM;gBACL,aAAa,GAAG,MAAM,CAAC,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC;gBAC9C,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK,GAAG,aAAa,GAAG,IAAI,CAAC;aACxD;SACF;IACH,CAAC;IAED,YAAY;QACV,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,YAAY,CAAC,OAAO;QAClB,4IAA4I;QAC5I,IAAI,UAAU,GAAG,MAAM,CAAC,UAAU,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;QAC3E,0EAA0E;QAC1E,uKAAuK;QACvK,IAAI,UAAU,IAAI,OAAO,CAAC,WAAW,GAAG,EAAE,EAAE;YAC1C,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;SACrB;aAAM;YACL,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACpB;IACH,CAAC;IAED,oBAAoB;QAClB,IAAI,aAAa,GAAG,sCAAsC,CAAC;QAC3D,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YAC1B,IAAI,IAAI,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC;SAChF;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,4CAA4C;IAC5C,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,KAAK;YAAE,OAAO,EAAE,CAAC;QAEtB,qDAAqD;QACrD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACxB,gFAAgF;YAChF,OAAO,KAAK;iBACT,GAAG,CAAC,IAAI,CAAC,EAAE;gBACV,OAAO,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YACxF,CAAC,CAAC;iBACD,IAAI,CAAC,IAAI,CAAC,CAAC;SACf;QAED,gDAAgD;QAChD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,OAAO,KAAK,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SAC/C;QAED,6BAA6B;QAC7B,OAAO,KAAK,CAAC;IACf,CAAC;wGA/MU,eAAe;4FAAf,eAAe,0OCpB5B,uhDA6CA;;4FDzBa,eAAe;kBAL3B,SAAS;+BACE,mBAAmB;iIAKpB,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBAWN,SAAS;sBADR,YAAY;uBAAC,kBAAkB","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport { AbstractControl } from '@angular/forms';\r\nimport { PrimaryColors } from '../primary-colors';\r\nimport { ToolTipMessageType } from './tooltip-message-type.enum';\r\n\r\n@Component({\r\n  selector: 'tooltip-msg-error',\r\n  templateUrl: './tooltip-msg-error.component.html',\r\n  styleUrls: ['./tooltip-msg-error.component.scss'],\r\n})\r\nexport class TooltipMsgError implements OnInit, OnChanges, OnDestroy {\r\n  @Input() width: string;\r\n  @Input() control: AbstractControl | null = null;\r\n  @Input() messageType: ToolTipMessageType = ToolTipMessageType.ERROR;\r\n  @Input() message: any;\r\n  iconElId: string;\r\n  messageElId: string;\r\n  isLeft: boolean = true;\r\n  showDetails: boolean;\r\n  tooltipIcon: HTMLElement;\r\n  tooltipMessage: HTMLElement;\r\n  iconStyle: any;\r\n  isDictionary: boolean;\r\n\r\n  @HostListener('document:scroll ')\r\n  onScrollY() {\r\n    this.onMouseLeave();\r\n  }\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private _El: ElementRef\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    this.iconElId = this.generateRandomString();\r\n    this.messageElId = this.generateRandomString();\r\n    this.setIconStyle();\r\n    this.checkErrorType();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.checkErrorType();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (document.getElementById(this.messageElId)) {\r\n      document.getElementById(this.messageElId).remove();\r\n    }\r\n  }\r\n\r\n  checkErrorType() {\r\n    if (this.message) {\r\n      if (this.message.constructor == Object) {\r\n        this.isDictionary = true;\r\n      } else if (typeof this.message === 'string') {\r\n        this.isDictionary = false;\r\n      } else {\r\n        this.isDictionary = false;\r\n      }\r\n    }\r\n  }\r\n\r\n  getThemedMessageStyle() {\r\n    let backgroundColor: string;\r\n    let fontBorderColor: string;\r\n\r\n    switch (this.messageType) {\r\n      case ToolTipMessageType.ERROR:\r\n        backgroundColor = '#fde5f0';\r\n        fontBorderColor = PrimaryColors.$primaryPinkColor;\r\n        break;\r\n      case ToolTipMessageType.WARNING:\r\n        backgroundColor = '#fdefdd';\r\n        fontBorderColor = PrimaryColors.$primaryOrangeColor;\r\n\r\n        break;\r\n      case ToolTipMessageType.HELP:\r\n        backgroundColor = '#d1f9f2';\r\n        fontBorderColor = PrimaryColors.$primaryTealColor;\r\n        break;\r\n      default:\r\n        backgroundColor = PrimaryColors.$primaryLightGrayColor;\r\n        fontBorderColor = PrimaryColors.$primaryGrayColor;\r\n        break;\r\n    }\r\n    let style = {\r\n      'background-color': backgroundColor,\r\n      'font-weight': 'bold',\r\n      color: fontBorderColor,\r\n      border: '0.2rem solid ' + fontBorderColor,\r\n      'border-left': '0.5rem solid ' + fontBorderColor,\r\n    };\r\n\r\n    return style;\r\n  }\r\n\r\n  setMessageStyle() {\r\n    let style = {};\r\n\r\n    if (this.width) {\r\n      style['width'] = this.width;\r\n    }\r\n  }\r\n\r\n  get messageStyle() {\r\n    let commonMessageStyle = {};\r\n\r\n    if (this.width) {\r\n      commonMessageStyle['width'] = this.width;\r\n    }\r\n    return {\r\n      ...commonMessageStyle,\r\n      ...(this.showDetails ? this.getThemedMessageStyle() : {}),\r\n    };\r\n  }\r\n\r\n  setIconStyle() {\r\n    let backgroundColor: string;\r\n    switch (this.messageType) {\r\n      case ToolTipMessageType.ERROR:\r\n        backgroundColor = PrimaryColors.$primaryPinkColor;\r\n        break;\r\n      case ToolTipMessageType.WARNING:\r\n        backgroundColor = PrimaryColors.$primaryOrangeColor;\r\n        break;\r\n      case ToolTipMessageType.HELP:\r\n        backgroundColor = PrimaryColors.$primaryTealColor;\r\n        break;\r\n      default:\r\n        backgroundColor = PrimaryColors.$primaryGrayColor;\r\n        break;\r\n    }\r\n    let style = {\r\n      color: backgroundColor,\r\n    };\r\n\r\n    this.iconStyle = style;\r\n  }\r\n\r\n  onMouseEnter() {\r\n    this.showDetails = true;\r\n    //  CDR is needed to let the DOM know the box error has a width\r\n    this.cdr.detectChanges();\r\n    this.tooltipMessage = document.getElementById(this.messageElId);\r\n    if (this.message) {\r\n      this.getDirection(this.tooltipMessage);\r\n      document.body.appendChild(this.tooltipMessage);\r\n      let messageElement = document.getElementById(this.messageElId);\r\n      let icon = document.getElementById(this.iconElId);\r\n      let rect = icon.getBoundingClientRect();\r\n\r\n      let top = rect.top;\r\n      let left = rect.left;\r\n      let right = rect.right;\r\n      let appendedLeft: number;\r\n      let appendedRight: number;\r\n      let appendedTop = top - messageElement.offsetHeight;\r\n      this.tooltipMessage.style.top = appendedTop + 'px';\r\n      this.tooltipMessage.style.zIndex = '1000';\r\n\r\n      if (this.isLeft) {\r\n        appendedLeft = left + icon.offsetWidth - 5;\r\n        this.tooltipMessage.style.left = appendedLeft + 'px';\r\n      } else {\r\n        appendedRight = window.innerWidth - right + 5;\r\n        this.tooltipMessage.style.right = appendedRight + 'px';\r\n      }\r\n    }\r\n  }\r\n\r\n  onMouseLeave() {\r\n    this.showDetails = false;\r\n  }\r\n\r\n  getDirection(element) {\r\n    //  Calculating the width difference between  screen width minus the poistion of the icon from left to right (getBoundingClientRect().right)\r\n    let difference = window.innerWidth - element.getBoundingClientRect().right;\r\n    // hard coded + 12 is for the padding that has been added to router-outlet\r\n    // The if statment here check if there is enough space for the box error to show from left to right , if not enough space, the box error will pop up from right to left\r\n    if (difference <= element.offsetWidth + 12) {\r\n      this.isLeft = false;\r\n    } else {\r\n      this.isLeft = true;\r\n    }\r\n  }\r\n\r\n  generateRandomString() {\r\n    let charsAndNumbs = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890';\r\n    let text = '';\r\n    for (let i = 0; i < 8; i++) {\r\n      text += charsAndNumbs.charAt(Math.floor(Math.random() * charsAndNumbs.length));\r\n    }\r\n    return text;\r\n  }\r\n\r\n  // Helper to decide how to display the value\r\n  formatValue(value: any): string {\r\n    if (!value) return '';\r\n\r\n    // 1. If it's an array (like your jurisdiction error)\r\n    if (Array.isArray(value)) {\r\n      // Map through the array and extract 'message' if it exists, otherwise stringify\r\n      return value\r\n        .map(item => {\r\n          return typeof item === 'object' && item.message ? item.message : JSON.stringify(item);\r\n        })\r\n        .join(', ');\r\n    }\r\n\r\n    // 2. If it's a single object (but not an array)\r\n    if (typeof value === 'object') {\r\n      return value.message || JSON.stringify(value);\r\n    }\r\n\r\n    // 3. It's a string or number\r\n    return value;\r\n  }\r\n}\r\n","<div\r\n  *ngIf=\"message && !control\"\r\n  class=\"container\"\r\n  (mouseenter)=\"onMouseEnter()\"\r\n  (mouseleave)=\"onMouseLeave()\">\r\n  <fa-icon [id]=\"iconElId\" [ngStyle]=\"iconStyle\" icon=\"circle-exclamation\" class=\"icon\"></fa-icon>\r\n  <div\r\n    *ngIf=\"!isDictionary\"\r\n    [ngStyle]=\"messageStyle\"\r\n    [id]=\"messageElId\"\r\n    class=\"message\"\r\n    [ngClass]=\"{ 'no-details': !showDetails, details: showDetails }\">\r\n    {{ message }}\r\n  </div>\r\n\r\n  <div\r\n    *ngIf=\"isDictionary\"\r\n    [ngStyle]=\"messageStyle\"\r\n    [id]=\"messageElId\"\r\n    class=\"message\"\r\n    [ngClass]=\"{ 'no-details': !showDetails, details: showDetails }\">\r\n    <div class=\"dict-cont\" *ngFor=\"let entry of message | keyvalue\">\r\n      <strong>{{ entry.key }}: </strong>\r\n      <span>{{ formatValue(entry.value) }}</span>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<div\r\n  *ngIf=\"control?.touched && control.errors\"\r\n  class=\"container\"\r\n  (mouseenter)=\"onMouseEnter()\"\r\n  (mouseleave)=\"onMouseLeave()\">\r\n  <fa-icon [ngStyle]=\"iconStyle\" [id]=\"iconElId\" icon=\"circle-exclamation\" class=\"icon\"></fa-icon>\r\n  <div\r\n    [ngStyle]=\"messageStyle\"\r\n    [id]=\"messageElId\"\r\n    class=\"message\"\r\n    [ngClass]=\"{ 'no-details': !showDetails, details: showDetails }\">\r\n    <div class=\"dict-cont\" *ngFor=\"let entry of message | keyvalue\">\r\n      <strong>{{ entry.key }}: </strong>\r\n      <span>{{ formatValue(entry.value) }}</span>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -1,24 +1,28 @@
|
|
|
1
1
|
/*
|
|
2
2
|
* Public API Surface of inputs
|
|
3
3
|
*/
|
|
4
|
-
export * from './lib/choose-enum/choose-enum.component';
|
|
5
|
-
export * from './lib/show-table-errors/show-table-errors.component';
|
|
6
4
|
export * from './lib/choose-enum-renderer/choose-enum-renderer.component';
|
|
5
|
+
export * from './lib/choose-enum/choose-enum.component';
|
|
6
|
+
export * from './lib/choose-general-item-renderer/choose-general-item-renderer-change-event.interface';
|
|
7
|
+
export * from './lib/choose-general-item-renderer/choose-general-item-renderer-validation-type.enum';
|
|
7
8
|
export * from './lib/choose-general-item/choose-general-item.component';
|
|
9
|
+
export * from './lib/show-table-errors/show-table-errors.component';
|
|
10
|
+
export * from './lib/tooltip-msg-error/tooltip-message-type.enum';
|
|
11
|
+
export * from './lib/tooltip-msg-error/tooltip-msg-error.component';
|
|
12
|
+
export * from './lib/add-asterisk.directive';
|
|
8
13
|
export * from './lib/choose-general-item-renderer/choose-general-item-renderer.component';
|
|
14
|
+
export * from './lib/choose-general-item/choose-general-item.service';
|
|
9
15
|
export * from './lib/choose-line-type/choose-line-type.component';
|
|
10
|
-
export * from './lib/choose-yes-or-no/choose-yes-or-no.component';
|
|
11
16
|
export * from './lib/choose-yes-or-no-renderer/choose-yes-or-no-renderer.component';
|
|
12
|
-
export * from './lib/
|
|
13
|
-
export * from './lib/
|
|
17
|
+
export * from './lib/choose-yes-or-no/choose-yes-or-no.component';
|
|
18
|
+
export * from './lib/dropdown-actions/dropdown-action-type.model';
|
|
19
|
+
export * from './lib/dropdown-actions/dropdown-actions.component';
|
|
20
|
+
export * from './lib/dropdown-actions/label-and-route.model';
|
|
14
21
|
export * from './lib/editable-savable-input/dynamicPipe';
|
|
15
|
-
export * from './lib/
|
|
16
|
-
export * from './lib/models/label-and-field.model';
|
|
22
|
+
export * from './lib/editable-savable-input/editable-savable-input.component';
|
|
17
23
|
export * from './lib/formcontrol-validation-msg.directive';
|
|
24
|
+
export * from './lib/general-input-renderer/general-input-renderer.component';
|
|
18
25
|
export * from './lib/inputs.module';
|
|
19
|
-
export * from './lib/
|
|
20
|
-
export * from './lib/dropdown-actions/label-and-route.model';
|
|
21
|
-
export * from './lib/dropdown-actions/dropdown-action-type.model';
|
|
22
|
-
export * from './lib/add-asterisk.directive';
|
|
26
|
+
export * from './lib/models/label-and-field.model';
|
|
23
27
|
export * from './lib/primary-colors';
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2lucHV0cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsMkRBQTJELENBQUM7QUFDMUUsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHdGQUF3RixDQUFDO0FBQ3ZHLGNBQWMsc0ZBQXNGLENBQUM7QUFDckcsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxxREFBcUQsQ0FBQztBQUVwRSxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsMkVBQTJFLENBQUM7QUFDMUYsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMscUVBQXFFLENBQUM7QUFDcEYsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsK0RBQStELENBQUM7QUFDOUUsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGlucHV0c1xyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nob29zZS1lbnVtLXJlbmRlcmVyL2Nob29zZS1lbnVtLXJlbmRlcmVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nob29zZS1lbnVtL2Nob29zZS1lbnVtLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nob29zZS1nZW5lcmFsLWl0ZW0tcmVuZGVyZXIvY2hvb3NlLWdlbmVyYWwtaXRlbS1yZW5kZXJlci1jaGFuZ2UtZXZlbnQuaW50ZXJmYWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLWdlbmVyYWwtaXRlbS1yZW5kZXJlci9jaG9vc2UtZ2VuZXJhbC1pdGVtLXJlbmRlcmVyLXZhbGlkYXRpb24tdHlwZS5lbnVtJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLWdlbmVyYWwtaXRlbS9jaG9vc2UtZ2VuZXJhbC1pdGVtLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Nob3ctdGFibGUtZXJyb3JzL3Nob3ctdGFibGUtZXJyb3JzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Rvb2x0aXAtbXNnLWVycm9yL3Rvb2x0aXAtbWVzc2FnZS10eXBlLmVudW0nO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90b29sdGlwLW1zZy1lcnJvci90b29sdGlwLW1zZy1lcnJvci5jb21wb25lbnQnO1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYWRkLWFzdGVyaXNrLmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nob29zZS1nZW5lcmFsLWl0ZW0tcmVuZGVyZXIvY2hvb3NlLWdlbmVyYWwtaXRlbS1yZW5kZXJlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UtZ2VuZXJhbC1pdGVtL2Nob29zZS1nZW5lcmFsLWl0ZW0uc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nob29zZS1saW5lLXR5cGUvY2hvb3NlLWxpbmUtdHlwZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UteWVzLW9yLW5vLXJlbmRlcmVyL2Nob29zZS15ZXMtb3Itbm8tcmVuZGVyZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLXllcy1vci1uby9jaG9vc2UteWVzLW9yLW5vLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ryb3Bkb3duLWFjdGlvbnMvZHJvcGRvd24tYWN0aW9uLXR5cGUubW9kZWwnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1hY3Rpb25zL2Ryb3Bkb3duLWFjdGlvbnMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHJvcGRvd24tYWN0aW9ucy9sYWJlbC1hbmQtcm91dGUubW9kZWwnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lZGl0YWJsZS1zYXZhYmxlLWlucHV0L2R5bmFtaWNQaXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZWRpdGFibGUtc2F2YWJsZS1pbnB1dC9lZGl0YWJsZS1zYXZhYmxlLWlucHV0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm1jb250cm9sLXZhbGlkYXRpb24tbXNnLmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dlbmVyYWwtaW5wdXQtcmVuZGVyZXIvZ2VuZXJhbC1pbnB1dC1yZW5kZXJlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnB1dHMubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2xhYmVsLWFuZC1maWVsZC5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByaW1hcnktY29sb3JzJztcclxuXHJcblxyXG4iXX0=
|