@jooler/inputs 0.0.55 → 0.0.57

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 (25) hide show
  1. package/esm2022/lib/choose-general-item/choose-general-item.component.mjs +75 -14
  2. package/esm2022/lib/choose-general-item-renderer/choose-general-item-renderer-change-event.interface.mjs +2 -0
  3. package/esm2022/lib/choose-general-item-renderer/choose-general-item-renderer-validation-type.enum.mjs +6 -0
  4. package/esm2022/lib/choose-general-item-renderer/choose-general-item-renderer.component.mjs +112 -18
  5. package/esm2022/lib/formcontrol-validation-msg-for-ng-select.directive.mjs +126 -0
  6. package/esm2022/lib/general-input-renderer/general-input-renderer-change-event.interface.mjs +2 -0
  7. package/esm2022/lib/general-input-renderer/general-input-renderer.component.mjs +36 -23
  8. package/esm2022/lib/inputs.module.mjs +21 -15
  9. package/esm2022/lib/tooltip-msg-error/tooltip-message-type.enum.mjs +8 -0
  10. package/esm2022/lib/tooltip-msg-error/tooltip-msg-error.component.mjs +213 -0
  11. package/esm2022/public-api.mjs +17 -12
  12. package/fesm2022/inputs.mjs +979 -470
  13. package/fesm2022/inputs.mjs.map +1 -1
  14. package/lib/choose-general-item/choose-general-item.component.d.ts +8 -3
  15. package/lib/choose-general-item-renderer/choose-general-item-renderer-change-event.interface.d.ts +9 -0
  16. package/lib/choose-general-item-renderer/choose-general-item-renderer-validation-type.enum.d.ts +4 -0
  17. package/lib/choose-general-item-renderer/choose-general-item-renderer.component.d.ts +19 -4
  18. package/lib/formcontrol-validation-msg-for-ng-select.directive.d.ts +23 -0
  19. package/lib/general-input-renderer/general-input-renderer-change-event.interface.d.ts +6 -0
  20. package/lib/general-input-renderer/general-input-renderer.component.d.ts +9 -4
  21. package/lib/inputs.module.d.ts +9 -7
  22. package/lib/tooltip-msg-error/tooltip-message-type.enum.d.ts +6 -0
  23. package/lib/tooltip-msg-error/tooltip-msg-error.component.d.ts +49 -0
  24. package/package.json +2 -2
  25. package/public-api.d.ts +16 -11
@@ -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":"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","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"]}
@@ -1,24 +1,29 @@
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/general-input-renderer/general-input-renderer-change-event.interface';
10
+ export * from './lib/show-table-errors/show-table-errors.component';
11
+ export * from './lib/tooltip-msg-error/tooltip-message-type.enum';
12
+ export * from './lib/tooltip-msg-error/tooltip-msg-error.component';
13
+ export * from './lib/add-asterisk.directive';
8
14
  export * from './lib/choose-general-item-renderer/choose-general-item-renderer.component';
15
+ export * from './lib/choose-general-item/choose-general-item.service';
9
16
  export * from './lib/choose-line-type/choose-line-type.component';
10
- export * from './lib/choose-yes-or-no/choose-yes-or-no.component';
11
17
  export * from './lib/choose-yes-or-no-renderer/choose-yes-or-no-renderer.component';
12
- export * from './lib/editable-savable-input/editable-savable-input.component';
13
- export * from './lib/general-input-renderer/general-input-renderer.component';
18
+ export * from './lib/choose-yes-or-no/choose-yes-or-no.component';
19
+ export * from './lib/dropdown-actions/dropdown-action-type.model';
20
+ export * from './lib/dropdown-actions/dropdown-actions.component';
21
+ export * from './lib/dropdown-actions/label-and-route.model';
14
22
  export * from './lib/editable-savable-input/dynamicPipe';
15
- export * from './lib/choose-general-item/choose-general-item.service';
16
- export * from './lib/models/label-and-field.model';
23
+ export * from './lib/editable-savable-input/editable-savable-input.component';
17
24
  export * from './lib/formcontrol-validation-msg.directive';
25
+ export * from './lib/general-input-renderer/general-input-renderer.component';
18
26
  export * from './lib/inputs.module';
19
- export * from './lib/dropdown-actions/dropdown-actions.component';
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';
27
+ export * from './lib/models/label-and-field.model';
23
28
  export * from './lib/primary-colors';
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2lucHV0cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLDJEQUEyRCxDQUFDO0FBQzFFLGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYywyRUFBMkUsQ0FBQztBQUMxRixjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxxRUFBcUUsQ0FBQztBQUNwRixjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMsK0RBQStELENBQUM7QUFDOUUsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBpbnB1dHNcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UtZW51bS9jaG9vc2UtZW51bS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zaG93LXRhYmxlLWVycm9ycy9zaG93LXRhYmxlLWVycm9ycy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UtZW51bS1yZW5kZXJlci9jaG9vc2UtZW51bS1yZW5kZXJlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UtZ2VuZXJhbC1pdGVtL2Nob29zZS1nZW5lcmFsLWl0ZW0uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLWdlbmVyYWwtaXRlbS1yZW5kZXJlci9jaG9vc2UtZ2VuZXJhbC1pdGVtLXJlbmRlcmVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nob29zZS1saW5lLXR5cGUvY2hvb3NlLWxpbmUtdHlwZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UteWVzLW9yLW5vL2Nob29zZS15ZXMtb3Itbm8uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLXllcy1vci1uby1yZW5kZXJlci9jaG9vc2UteWVzLW9yLW5vLXJlbmRlcmVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VkaXRhYmxlLXNhdmFibGUtaW5wdXQvZWRpdGFibGUtc2F2YWJsZS1pbnB1dC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9nZW5lcmFsLWlucHV0LXJlbmRlcmVyL2dlbmVyYWwtaW5wdXQtcmVuZGVyZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZWRpdGFibGUtc2F2YWJsZS1pbnB1dC9keW5hbWljUGlwZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nob29zZS1nZW5lcmFsLWl0ZW0vY2hvb3NlLWdlbmVyYWwtaXRlbS5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2xhYmVsLWFuZC1maWVsZC5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm1jb250cm9sLXZhbGlkYXRpb24tbXNnLmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2lucHV0cy5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1hY3Rpb25zL2Ryb3Bkb3duLWFjdGlvbnMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHJvcGRvd24tYWN0aW9ucy9sYWJlbC1hbmQtcm91dGUubW9kZWwnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1hY3Rpb25zL2Ryb3Bkb3duLWFjdGlvbi10eXBlLm1vZGVsJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYWRkLWFzdGVyaXNrLmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByaW1hcnktY29sb3JzJztcclxuXHJcblxyXG4iXX0=
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2lucHV0cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsMkRBQTJELENBQUM7QUFDMUUsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHdGQUF3RixDQUFDO0FBQ3ZHLGNBQWMsc0ZBQXNGLENBQUM7QUFDckcsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLDRFQUE0RSxDQUFDO0FBQzNGLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLHFEQUFxRCxDQUFDO0FBRXBFLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYywyRUFBMkUsQ0FBQztBQUMxRixjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxxRUFBcUUsQ0FBQztBQUNwRixjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYywrREFBK0QsQ0FBQztBQUM5RSxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsK0RBQStELENBQUM7QUFDOUUsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgaW5wdXRzXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLWVudW0tcmVuZGVyZXIvY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLWVudW0vY2hvb3NlLWVudW0uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLWdlbmVyYWwtaXRlbS1yZW5kZXJlci9jaG9vc2UtZ2VuZXJhbC1pdGVtLXJlbmRlcmVyLWNoYW5nZS1ldmVudC5pbnRlcmZhY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UtZ2VuZXJhbC1pdGVtLXJlbmRlcmVyL2Nob29zZS1nZW5lcmFsLWl0ZW0tcmVuZGVyZXItdmFsaWRhdGlvbi10eXBlLmVudW0nO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UtZ2VuZXJhbC1pdGVtL2Nob29zZS1nZW5lcmFsLWl0ZW0uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZ2VuZXJhbC1pbnB1dC1yZW5kZXJlci9nZW5lcmFsLWlucHV0LXJlbmRlcmVyLWNoYW5nZS1ldmVudC5pbnRlcmZhY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zaG93LXRhYmxlLWVycm9ycy9zaG93LXRhYmxlLWVycm9ycy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90b29sdGlwLW1zZy1lcnJvci90b29sdGlwLW1lc3NhZ2UtdHlwZS5lbnVtJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdG9vbHRpcC1tc2ctZXJyb3IvdG9vbHRpcC1tc2ctZXJyb3IuY29tcG9uZW50JztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FkZC1hc3Rlcmlzay5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UtZ2VuZXJhbC1pdGVtLXJlbmRlcmVyL2Nob29zZS1nZW5lcmFsLWl0ZW0tcmVuZGVyZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLWdlbmVyYWwtaXRlbS9jaG9vc2UtZ2VuZXJhbC1pdGVtLnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaG9vc2UtbGluZS10eXBlL2Nob29zZS1saW5lLXR5cGUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hvb3NlLXllcy1vci1uby1yZW5kZXJlci9jaG9vc2UteWVzLW9yLW5vLXJlbmRlcmVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nob29zZS15ZXMtb3Itbm8vY2hvb3NlLXllcy1vci1uby5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1hY3Rpb25zL2Ryb3Bkb3duLWFjdGlvbi10eXBlLm1vZGVsJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHJvcGRvd24tYWN0aW9ucy9kcm9wZG93bi1hY3Rpb25zLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ryb3Bkb3duLWFjdGlvbnMvbGFiZWwtYW5kLXJvdXRlLm1vZGVsJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZWRpdGFibGUtc2F2YWJsZS1pbnB1dC9keW5hbWljUGlwZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VkaXRhYmxlLXNhdmFibGUtaW5wdXQvZWRpdGFibGUtc2F2YWJsZS1pbnB1dC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtY29udHJvbC12YWxpZGF0aW9uLW1zZy5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9nZW5lcmFsLWlucHV0LXJlbmRlcmVyL2dlbmVyYWwtaW5wdXQtcmVuZGVyZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaW5wdXRzLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9sYWJlbC1hbmQtZmllbGQubW9kZWwnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wcmltYXJ5LWNvbG9ycyc7XHJcblxyXG5cclxuIl19