@seniorsistemas/angular-components 17.10.0 → 17.10.2

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/bundles/seniorsistemas-angular-components.umd.js +85 -143
  2. package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
  3. package/bundles/seniorsistemas-angular-components.umd.min.js +2 -2
  4. package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
  5. package/components/badge/badge.component.d.ts +4 -2
  6. package/components/dynamic-form/components/lookup/lookup.component.d.ts +25 -3
  7. package/components/tooltip/tooltip.directive.d.ts +1 -1
  8. package/esm2015/components/badge/badge.component.js +10 -4
  9. package/esm2015/components/dynamic-form/components/fields/lookup/lookup-field.component.js +2 -2
  10. package/esm2015/components/dynamic-form/components/lookup/lookup.component.js +5 -2
  11. package/esm2015/components/dynamic-form/dynamic-form.module.js +3 -1
  12. package/esm2015/components/tooltip/tooltip.component.js +3 -3
  13. package/esm2015/components/tooltip/tooltip.directive.js +59 -138
  14. package/esm5/components/badge/badge.component.js +10 -4
  15. package/esm5/components/dynamic-form/components/fields/lookup/lookup-field.component.js +2 -2
  16. package/esm5/components/dynamic-form/components/lookup/lookup.component.js +5 -2
  17. package/esm5/components/dynamic-form/dynamic-form.module.js +3 -1
  18. package/esm5/components/tooltip/tooltip.component.js +3 -3
  19. package/esm5/components/tooltip/tooltip.directive.js +71 -139
  20. package/fesm2015/seniorsistemas-angular-components.js +74 -143
  21. package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
  22. package/fesm5/seniorsistemas-angular-components.js +86 -144
  23. package/fesm5/seniorsistemas-angular-components.js.map +1 -1
  24. package/package.json +1 -1
  25. package/seniorsistemas-angular-components.metadata.json +1 -1
@@ -13,9 +13,9 @@ let TooltipComponent = class TooltipComponent {
13
13
  };
14
14
  TooltipComponent = __decorate([
15
15
  Component({
16
- template: "<div\n class=\"tooltip\"\n [ngClass]=\"['tooltip--' + position]\"\n [class.tooltip--visible]=\"visible\"\n [ngStyle]=\"{\n 'left': left + 'px',\n 'top': top + 'px'\n }\">\n <ng-template\n *ngIf=\"escape;\n then escapeTemplate;\n else noEscapeTemplate\">\n </ng-template> \n</div>\n\n<ng-template #noEscapeTemplate>\n <span\n class=\"tooltip__content\"\n [innerHTML]=\"tooltip\">\n </span>\n</ng-template>\n\n<ng-template #escapeTemplate>\n <span class=\"tooltip__content\">\n {{ tooltip }}\n </span>\n</ng-template>",
17
- styles: [".tooltip{background-color:#000;border-radius:2px;color:#fff;font-family:\"Open Sans\",sans-serif;font-size:14px;font-weight:400;line-height:21px;margin-top:5px;opacity:0;padding:8px;position:fixed;transform:translateX(-50%);text-align:center;max-width:150px;word-wrap:break-word;z-index:99999}.tooltip--visible{opacity:1;transition:opacity .3s}.tooltip::before{content:\"\";height:0;position:absolute;width:0}.tooltip--bottom{margin-top:8px;transform:translateX(-50%)}.tooltip--bottom::before{border:5px solid transparent;border-bottom:5px solid #000;left:calc(50% - 5px);top:-10px}.tooltip--top{margin-bottom:8px;transform:translate(-50%,-100%)}.tooltip--top::before{border:5px solid transparent;border-top:5px solid #000;left:calc(50% - 5px);bottom:-10px}.tooltip--left{margin-right:28px;transform:translate(calc(-100% - 7px),-50%)}.tooltip--left::before{border:5px solid transparent;border-left:5px solid #000;right:-10px;bottom:calc(50% - 5px)}.tooltip--right{margin-left:7px;transform:translateY(-50%)}.tooltip--right::before{border:5px solid transparent;border-right:5px solid #000;left:-10px;bottom:calc(50% - 5px)}"]
16
+ template: "<div\n id=\"tooltip\"\n class=\"tooltip\"\n [ngClass]=\"['tooltip--' + position]\"\n [class.tooltip--visible]=\"visible\"\n [ngStyle]=\"{\n 'left': left + 'px',\n 'top': top + 'px'\n }\">\n <ng-template\n *ngIf=\"escape;\n then escapeTemplate;\n else noEscapeTemplate\">\n </ng-template> \n</div>\n\n<ng-template #noEscapeTemplate>\n <span\n class=\"tooltip__content\"\n [innerHTML]=\"tooltip\">\n </span>\n</ng-template>\n\n<ng-template #escapeTemplate>\n <span class=\"tooltip__content\">\n {{ tooltip }}\n </span>\n</ng-template>",
17
+ styles: [".tooltip{background-color:#000;border-radius:2px;color:#fff;font-family:\"Open Sans\",sans-serif;font-size:14px;font-weight:400;line-height:21px;margin-top:5px;opacity:0;padding:8px;position:fixed;transform:translateX(-50%);text-align:center;max-width:220px;word-wrap:break-word;z-index:99999}.tooltip--visible{opacity:1;transition:opacity .3s}.tooltip::before{content:\"\";height:0;position:absolute;width:0}.tooltip--bottom{margin-top:8px;transform:translateX(-50%)}.tooltip--bottom::before{border:5px solid transparent;border-bottom:5px solid #000;left:calc(50% - 5px);top:-10px}.tooltip--top{margin-bottom:8px;transform:translate(-50%,-100%)}.tooltip--top::before{border:5px solid transparent;border-top:5px solid #000;left:calc(50% - 5px);bottom:-10px}.tooltip--left{margin-right:28px;transform:translate(calc(-100% - 7px),-50%)}.tooltip--left::before{border:5px solid transparent;border-left:5px solid #000;right:-10px;bottom:calc(50% - 5px)}.tooltip--right{margin-left:7px;transform:translateY(-50%)}.tooltip--right::before{border:5px solid transparent;border-right:5px solid #000;left:-10px;bottom:calc(50% - 5px)}"]
18
18
  })
19
19
  ], TooltipComponent);
20
20
  export { TooltipComponent };
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy90b29sdGlwL3Rvb2x0aXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQU01RCxJQUFhLGdCQUFnQixHQUE3QixNQUFhLGdCQUFnQjtJQUE3QjtRQUNVLFlBQU8sR0FBRyxFQUFFLENBQUM7UUFDYixhQUFRLEdBQUcsZUFBZSxDQUFDLEdBQUcsQ0FBQztRQUMvQixTQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQ1QsUUFBRyxHQUFHLENBQUMsQ0FBQztRQUNSLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFDaEIsV0FBTSxHQUFHLEtBQUssQ0FBQztJQUN6QixDQUFDO0NBQUEsQ0FBQTtBQVBZLGdCQUFnQjtJQUo1QixTQUFTLENBQUM7UUFDUixxbEJBQXVDOztLQUV6QyxDQUFDO0dBQ1csZ0JBQWdCLENBTzVCO1NBUFksZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IFRvb2x0aXBQb3NpdGlvbiB9IGZyb20gXCIuL21vZGVscy90b29sdGlwLXBvc2l0aW9uXCI7XG5cbkBDb21wb25lbnQoe1xuICAgdGVtcGxhdGVVcmw6IFwiLi90b29sdGlwLmNvbXBvbmVudC5odG1sXCIsXG4gICBzdHlsZVVybHM6IFtcIi4vdG9vbHRpcC5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgVG9vbHRpcENvbXBvbmVudCB7XG4gICBwdWJsaWMgdG9vbHRpcCA9IFwiXCI7XG4gICBwdWJsaWMgcG9zaXRpb24gPSBUb29sdGlwUG9zaXRpb24uVG9wO1xuICAgcHVibGljIGxlZnQgPSAwO1xuICAgcHVibGljIHRvcCA9IDA7XG4gICBwdWJsaWMgdmlzaWJsZSA9IGZhbHNlO1xuICAgcHVibGljIGVzY2FwZSA9IGZhbHNlO1xufVxuIl19
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy90b29sdGlwL3Rvb2x0aXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQU01RCxJQUFhLGdCQUFnQixHQUE3QixNQUFhLGdCQUFnQjtJQUE3QjtRQUNVLFlBQU8sR0FBRyxFQUFFLENBQUM7UUFDYixhQUFRLEdBQUcsZUFBZSxDQUFDLEdBQUcsQ0FBQztRQUMvQixTQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQ1QsUUFBRyxHQUFHLENBQUMsQ0FBQztRQUNSLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFDaEIsV0FBTSxHQUFHLEtBQUssQ0FBQztJQUN6QixDQUFDO0NBQUEsQ0FBQTtBQVBZLGdCQUFnQjtJQUo1QixTQUFTLENBQUM7UUFDUix3bUJBQXVDOztLQUV6QyxDQUFDO0dBQ1csZ0JBQWdCLENBTzVCO1NBUFksZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IFRvb2x0aXBQb3NpdGlvbiB9IGZyb20gXCIuL21vZGVscy90b29sdGlwLXBvc2l0aW9uXCI7XG5cbkBDb21wb25lbnQoe1xuICAgdGVtcGxhdGVVcmw6IFwiLi90b29sdGlwLmNvbXBvbmVudC5odG1sXCIsXG4gICBzdHlsZVVybHM6IFtcIi4vdG9vbHRpcC5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgVG9vbHRpcENvbXBvbmVudCB7XG4gICBwdWJsaWMgdG9vbHRpcCA9IFwiXCI7XG4gICBwdWJsaWMgcG9zaXRpb24gPSBUb29sdGlwUG9zaXRpb24uVG9wO1xuICAgcHVibGljIGxlZnQgPSAwO1xuICAgcHVibGljIHRvcCA9IDA7XG4gICBwdWJsaWMgdmlzaWJsZSA9IGZhbHNlO1xuICAgcHVibGljIGVzY2FwZSA9IGZhbHNlO1xufVxuIl19
@@ -1,5 +1,5 @@
1
1
  import { __decorate } from "tslib";
2
- import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Directive, ElementRef, EmbeddedViewRef, HostListener, Injector, Input, OnDestroy, OnInit, Renderer2 } from "@angular/core";
2
+ import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Directive, ElementRef, EmbeddedViewRef, HostListener, Injector, Input, OnDestroy, OnInit, Renderer2, } from "@angular/core";
3
3
  import { DebounceUtils } from "../utils/debouce";
4
4
  import { MobileBehavior, TooltipEvent, TooltipPosition } from "./models";
5
5
  import { TooltipComponent } from "./tooltip.component";
@@ -38,7 +38,7 @@ let TooltipDirective = class TooltipDirective {
38
38
  top: Math.min(elementRect.top, toolTipRect.top),
39
39
  right: Math.max(elementRect.right, toolTipRect.right),
40
40
  left: Math.min(elementRect.left, toolTipRect.left),
41
- bottom: Math.max(elementRect.bottom, toolTipRect.bottom)
41
+ bottom: Math.max(elementRect.bottom, toolTipRect.bottom),
42
42
  };
43
43
  if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea)) {
44
44
  this.destroy();
@@ -54,12 +54,12 @@ let TooltipDirective = class TooltipDirective {
54
54
  if (this.focusedInputRef) {
55
55
  const inputFocus = this.focusedInputRef;
56
56
  const icon = this.getIconFromFocusedInput();
57
- this.renderer.listen(this.focusedInputRef, 'focus', () => {
57
+ this.renderer.listen(this.focusedInputRef, "focus", () => {
58
58
  if (icon && this.isMatchingTooltip(icon)) {
59
59
  this.createTootipByFocus(icon);
60
60
  }
61
61
  });
62
- this.renderer.listen(inputFocus, 'blur', () => {
62
+ this.renderer.listen(inputFocus, "blur", () => {
63
63
  if (icon && this.isMatchingTooltip(icon)) {
64
64
  this.removeTooltip(icon);
65
65
  this.destroy();
@@ -80,7 +80,7 @@ let TooltipDirective = class TooltipDirective {
80
80
  * @returns true se o tooltip corresponde; caso contrário, false.
81
81
  */
82
82
  isMatchingTooltip(icon) {
83
- const tooltipText = icon.getAttribute('ng-reflect-tooltip');
83
+ const tooltipText = icon.getAttribute("ng-reflect-tooltip");
84
84
  return this.tooltip === tooltipText;
85
85
  }
86
86
  /**
@@ -88,7 +88,7 @@ let TooltipDirective = class TooltipDirective {
88
88
  * @param icon O ícone do input em focus.
89
89
  */
90
90
  removeTooltip(icon) {
91
- const tooltip = icon.querySelector('.tooltip');
91
+ const tooltip = icon.querySelector(".tooltip");
92
92
  if (tooltip) {
93
93
  tooltip.remove();
94
94
  }
@@ -96,9 +96,7 @@ let TooltipDirective = class TooltipDirective {
96
96
  // whenever the component with the tooltip is clicked I destroy the tooltip.
97
97
  // whenever a key is pressed on the component with the tooltip I destroy the tooltip.
98
98
  onClick() {
99
- if (this.tooltipEvent === TooltipEvent.Hover &&
100
- !navigator.userAgent.match(/Android/i) &&
101
- !navigator.userAgent.match(/iPhone/i)) {
99
+ if (this.tooltipEvent === TooltipEvent.Hover && !navigator.userAgent.match(/Android/i) && !navigator.userAgent.match(/iPhone/i)) {
102
100
  this.destroy();
103
101
  }
104
102
  }
@@ -143,12 +141,7 @@ let TooltipDirective = class TooltipDirective {
143
141
  }
144
142
  }
145
143
  validatePosition() {
146
- const containsPosition = [
147
- TooltipPosition.Top,
148
- TooltipPosition.Right,
149
- TooltipPosition.Bottom,
150
- TooltipPosition.Left,
151
- ].includes(this.position);
144
+ const containsPosition = [TooltipPosition.Top, TooltipPosition.Right, TooltipPosition.Bottom, TooltipPosition.Left].includes(this.position);
152
145
  if (!containsPosition) {
153
146
  this.position = TooltipPosition.Top;
154
147
  throw new Error(`Tooltip ${this.position} position is unexpected`);
@@ -161,7 +154,7 @@ let TooltipDirective = class TooltipDirective {
161
154
  document.body.appendChild(domElem);
162
155
  this.setTooltipComponentProperties();
163
156
  this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);
164
- this.tooltipDivElement = domElem.querySelector('.tooltip');
157
+ this.tooltipDivElement = domElem.querySelector(".tooltip");
165
158
  if (this.displayTime) {
166
159
  window.setTimeout(this.destroy.bind(this), this.displayTime);
167
160
  }
@@ -182,142 +175,70 @@ let TooltipDirective = class TooltipDirective {
182
175
  var _a;
183
176
  if (this.componentRef === null && ((_a = this.tooltip) === null || _a === void 0 ? void 0 : _a.length)) {
184
177
  const domElem = this.getDomElement();
185
- const tooltip = domElem.querySelector('.tooltip');
178
+ const tooltip = domElem.querySelector(".tooltip");
186
179
  icon.appendChild(tooltip);
187
180
  this.setTooltipComponentProperties();
188
181
  setTimeout(() => tooltip.classList.add("tooltip--visible"), 0);
189
- this.renderer.listen(window, 'scroll', () => {
190
- this.updateTooltipPosition();
182
+ this.renderer.listen(window, "scroll", () => {
183
+ this.setTooltipPositionProperty();
191
184
  });
192
185
  }
193
186
  }
194
- updateTooltipPosition() {
195
- if (this.componentRef) {
196
- const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();
197
- const tooltipWidth = right - left;
198
- const tooltipHeight = bottom - top;
199
- switch (this.position) {
200
- case TooltipPosition.Top:
201
- this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);
202
- this.componentRef.instance.top = Math.round(top - 20 - 5);
203
- break;
204
- case TooltipPosition.Bottom:
205
- this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);
206
- this.componentRef.instance.top = Math.round(bottom + 20);
207
- break;
208
- case TooltipPosition.Left:
209
- this.componentRef.instance.left = Math.round(left - 20);
210
- this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - 5);
211
- break;
212
- case TooltipPosition.Right:
213
- this.componentRef.instance.left = Math.round(right + 20);
214
- this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - 5);
215
- break;
216
- default:
217
- break;
218
- }
219
- }
220
- }
221
187
  showTooltip() {
222
188
  if (this.componentRef !== null) {
223
189
  this.componentRef.instance.visible = this.visible;
224
- window.addEventListener('mousemove', this.boundOnWindowMouseMoveFunction);
190
+ this.setTooltipPositionProperty();
191
+ window.addEventListener("mousemove", this.boundOnWindowMouseMoveFunction);
225
192
  }
226
193
  }
227
- setTooltipComponentProperties() {
194
+ setTooltipPositionProperty() {
228
195
  const margin = 20;
229
196
  const anchorSize = 5;
197
+ const domElem = this.componentRef.hostView.rootNodes[0].querySelector("#tooltip");
198
+ const { height, width } = domElem.getBoundingClientRect();
199
+ const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();
200
+ const positions = [
201
+ {
202
+ pos: TooltipPosition.Top,
203
+ check: () => top > height,
204
+ set: () => ({ left: left + (right - left) / 2, top: top - margin - anchorSize }),
205
+ },
206
+ {
207
+ pos: TooltipPosition.Bottom,
208
+ check: () => document.body.clientHeight - bottom > height,
209
+ set: () => ({ left: left + (right - left) / 2, top: bottom + margin }),
210
+ },
211
+ {
212
+ pos: TooltipPosition.Left,
213
+ check: () => left > width,
214
+ set: () => ({ left: left - margin, top: top + height / 2 - anchorSize }),
215
+ },
216
+ {
217
+ pos: TooltipPosition.Right,
218
+ check: () => document.body.clientWidth - right > width,
219
+ set: () => ({ left: right + margin, top: top + height / 2 - anchorSize }),
220
+ },
221
+ ];
222
+ for (const { pos, check, set } of positions) {
223
+ if (check()) {
224
+ this.position = pos;
225
+ const { left, top } = set();
226
+ this.componentRef.instance.left = Math.round(left);
227
+ this.componentRef.instance.top = Math.round(top);
228
+ this.componentRef.instance.position = this.position;
229
+ return;
230
+ }
231
+ }
232
+ // Se não conseguir posicionar, mostrar abaixo
233
+ this.position = TooltipPosition.Bottom;
234
+ this.componentRef.instance.left = Math.round(left + (right - left) / 2);
235
+ this.componentRef.instance.top = Math.round(bottom + margin);
236
+ this.componentRef.instance.position = this.position;
237
+ }
238
+ setTooltipComponentProperties() {
230
239
  if (this.componentRef !== null) {
231
240
  this.componentRef.instance.tooltip = this.tooltip;
232
241
  this.componentRef.instance.escape = this.escape;
233
- const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();
234
- const tooltipHeight = bottom - top;
235
- const tooltipWidth = right - left;
236
- const safeSpace = 150;
237
- let positioned = false;
238
- const invalidOptions = [];
239
- while (!positioned) {
240
- if (invalidOptions.includes(TooltipPosition.Top)
241
- && invalidOptions.includes(TooltipPosition.Bottom)
242
- && invalidOptions.includes(TooltipPosition.Left)
243
- && invalidOptions.includes(TooltipPosition.Right)) {
244
- this.destroy();
245
- throw new Error("No space to show tooltip");
246
- }
247
- switch (this.position) {
248
- case TooltipPosition.Top: {
249
- if (invalidOptions.includes(TooltipPosition.Top)) {
250
- this.position = TooltipPosition.Left;
251
- break;
252
- }
253
- const topShift = top;
254
- if (topShift <= tooltipHeight + safeSpace) {
255
- this.position = TooltipPosition.Bottom;
256
- invalidOptions.push(TooltipPosition.Top);
257
- positioned = false;
258
- break;
259
- }
260
- this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);
261
- this.componentRef.instance.top = Math.round(top - margin - anchorSize);
262
- positioned = true;
263
- break;
264
- }
265
- case TooltipPosition.Bottom: {
266
- if (invalidOptions.includes(TooltipPosition.Bottom)) {
267
- this.position = TooltipPosition.Left;
268
- break;
269
- }
270
- const bottomShift = document.body.clientHeight - bottom;
271
- if (bottomShift <= tooltipHeight + safeSpace) {
272
- this.position = TooltipPosition.Top;
273
- invalidOptions.push(TooltipPosition.Bottom);
274
- break;
275
- }
276
- this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);
277
- this.componentRef.instance.top = Math.round(bottom + margin);
278
- positioned = true;
279
- break;
280
- }
281
- case TooltipPosition.Left: {
282
- if (invalidOptions.includes(TooltipPosition.Left)) {
283
- this.position = TooltipPosition.Top;
284
- break;
285
- }
286
- const leftShift = left;
287
- if (leftShift <= tooltipWidth + safeSpace) {
288
- this.position = TooltipPosition.Right;
289
- invalidOptions.push(TooltipPosition.Left);
290
- positioned = false;
291
- break;
292
- }
293
- this.componentRef.instance.left = Math.round(left - margin);
294
- this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);
295
- positioned = true;
296
- break;
297
- }
298
- case TooltipPosition.Right: {
299
- if (invalidOptions.includes(TooltipPosition.Right)) {
300
- this.position = TooltipPosition.Top;
301
- break;
302
- }
303
- const rightShift = document.body.clientWidth - right;
304
- if (rightShift <= tooltipWidth + safeSpace) {
305
- this.position = TooltipPosition.Left;
306
- invalidOptions.push(TooltipPosition.Right);
307
- positioned = false;
308
- break;
309
- }
310
- this.componentRef.instance.left = Math.round(right + margin);
311
- this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);
312
- positioned = true;
313
- break;
314
- }
315
- default: {
316
- break;
317
- }
318
- }
319
- this.componentRef.instance.position = this.position;
320
- }
321
242
  }
322
243
  }
323
244
  destroy() {
@@ -328,7 +249,7 @@ let TooltipDirective = class TooltipDirective {
328
249
  this.componentRef = null;
329
250
  this.tooltipDivElement = null;
330
251
  }
331
- window.removeEventListener('mousemove', this.boundOnWindowMouseMoveFunction);
252
+ window.removeEventListener("mousemove", this.boundOnWindowMouseMoveFunction);
332
253
  }
333
254
  };
334
255
  TooltipDirective.ctorParameters = () => [
@@ -398,4 +319,4 @@ TooltipDirective = __decorate([
398
319
  })
399
320
  ], TooltipDirective);
400
321
  export { TooltipDirective };
401
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tooltip/tooltip.directive.ts"],"names":[],"mappings":";AAAA,OAAO,EACJ,cAAc,EACd,wBAAwB,EACxB,YAAY,EACZ,SAAS,EACT,UAAU,EACV,eAAe,EACf,YAAY,EACZ,QAAQ,EACR,KAAK,EACL,SAAS,EACT,MAAM,EACN,SAAS,EACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAMvD,IAAa,gBAAgB,GAA7B,MAAa,gBAAgB;IAmC1B,YACoB,UAAsB,EACtB,MAAsB,EACtB,wBAAkD,EAClD,QAAkB,EAClB,aAA4B,EAC5B,QAAmB;QALnB,eAAU,GAAV,UAAU,CAAY;QACtB,WAAM,GAAN,MAAM,CAAgB;QACtB,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,aAAQ,GAAR,QAAQ,CAAU;QAClB,kBAAa,GAAb,aAAa,CAAe;QAC5B,aAAQ,GAAR,QAAQ,CAAW;QApChC,aAAQ,GAAoB,eAAe,CAAC,GAAG,CAAC;QAGhD,cAAS,GAAG,GAAG,CAAC;QAMhB,iBAAY,GAAG,YAAY,CAAC,KAAK,CAAC;QAGlC,WAAM,GAAG,KAAK,CAAC;QAGf,YAAO,GAAG,IAAI,CAAC;QAGf,mBAAc,GAAG,cAAc,CAAC,QAAQ,CAAC;QAKxC,iBAAY,GAAsB,IAAI,CAAC;QAe5C,IAAI,CAAC,8BAA8B,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxE,IAAI,CAAC,6BAA6B,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;IACtG,CAAC;IAEM,QAAQ;QACZ,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,uCAAuC,EAAE,CAAC;IAClD,CAAC;IAEM,WAAW;QACf,IAAI,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC;IAEO,iBAAiB,CAAC,KAAiB;QACxC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACrB,OAAO;SACT;QACD,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;QAC1E,MAAM,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,qBAAqB,EAAE,CAAC;QAEnE,MAAM,gBAAgB,GAAG;YACtB,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,GAAG,EAAE,WAAW,CAAC,GAAG,CAAC;YAC/C,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,KAAK,EAAE,WAAW,CAAC,KAAK,CAAC;YACrD,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC;YAClD,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,MAAM,EAAE,WAAW,CAAC,MAAM,CAAC;SAC1D,CAAC;QAEF,IAAI,IAAI,CAAC,+BAA+B,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,gBAAgB,CAAC,EAAE;YACvF,IAAI,CAAC,OAAO,EAAE,CAAC;SACjB;IACJ,CAAC;IAEO,+BAA+B,CAAC,MAAc,EAAE,MAAc,EAAE,WAAwB;QAC7F,OAAO,MAAM,GAAG,WAAW,CAAC,IAAI,IAAI,MAAM,IAAI,WAAW,CAAC,KAAK,IAAI,MAAM,GAAG,WAAW,CAAC,GAAG,IAAI,MAAM,IAAI,WAAW,CAAC,MAAM,CAAC;IAC/H,CAAC;IAED;;OAEG;IACK,uCAAuC;QAC1C,IAAI,IAAI,CAAC,eAAe,EAAE;YACtB,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC;YACxC,MAAM,IAAI,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC;YAE5C,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,OAAO,EAAE,GAAG,EAAE;gBACrD,IAAI,IAAI,IAAI,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE;oBACtC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;iBAClC;YACL,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,EAAE;gBAC3C,IAAI,IAAI,IAAI,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE;oBACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBACzB,IAAI,CAAC,OAAO,EAAE,CAAC;iBAClB;YACL,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED;;;OAGG;IACK,uBAAuB;QAC7B,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACvC,CAAC;IAED;;;;OAIG;IACK,iBAAiB,CAAC,IAAiB;QACvC,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC,CAAC;QAC5D,OAAO,IAAI,CAAC,OAAO,KAAK,WAAW,CAAC;IACxC,CAAC;IAED;;;OAGG;IACK,aAAa,CAAC,IAAiB;QACnC,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,CAAgB,CAAC;QAC9D,IAAI,OAAO,EAAE;YACT,OAAO,CAAC,MAAM,EAAE,CAAC;SACpB;IACL,CAAC;IAEF,4EAA4E;IAC5E,qFAAqF;IAG9E,OAAO;QACX,IAAI,IAAI,CAAC,YAAY,KAAK,YAAY,CAAC,KAAK;YACzC,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC;YACtC,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;YACvC,IAAI,CAAC,OAAO,EAAE,CAAC;SACjB;IACJ,CAAC;IAED,mFAAmF;IAE5E,oBAAoB;QACxB,IAAI,IAAI,CAAC,YAAY,KAAK,YAAY,CAAC,KAAK,EAAE;YAC3C,IAAI,CAAC,OAAO,EAAE,CAAC;SACjB;IACJ,CAAC;IAGM,OAAO;QACX,IAAI,IAAI,CAAC,YAAY,KAAK,YAAY,CAAC,KAAK,EAAE;YAC3C,IAAI,CAAC,YAAY,EAAE,CAAC;SACtB;IACJ,CAAC;IAGM,MAAM;QACV,IAAI,IAAI,CAAC,YAAY,KAAK,YAAY,CAAC,KAAK,EAAE;YAC3C,IAAI,CAAC,OAAO,EAAE,CAAC;SACjB;IACJ,CAAC;IAGM,YAAY;QAChB,IAAI,IAAI,CAAC,YAAY,KAAK,YAAY,CAAC,KAAK,EAAE;YAC3C,IAAI,CAAC,6BAA6B,EAAE,CAAC;SACvC;IACJ,CAAC;IAIM,YAAY;QAChB,IAAI,IAAI,CAAC,YAAY,KAAK,YAAY,CAAC,KAAK,EAAE;YAC3C,IAAI,CAAC,OAAO,EAAE,CAAC;SACjB;IACJ,CAAC;IAGM,YAAY;QAChB,IAAI,IAAI,CAAC,YAAY,KAAK,YAAY,CAAC,KAAK,EAAE;YAC3C,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACvC,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,UAAU,CAClC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAC5B,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CACtE,CAAC;SACJ;IACJ,CAAC;IAGM,UAAU;QACd,IAAI,IAAI,CAAC,YAAY,KAAK,YAAY,CAAC,KAAK,EAAE;YAC3C,IAAI,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,QAAQ,EAAE;gBAClD,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACvC,IAAI,CAAC,OAAO,EAAE,CAAC;aACjB;SACH;IACJ,CAAC;IAEO,gBAAgB;QACrB,MAAM,gBAAgB,GAAG;YACtB,eAAe,CAAC,GAAG;YACnB,eAAe,CAAC,KAAK;YACrB,eAAe,CAAC,MAAM;YACtB,eAAe,CAAC,IAAI;SACtB,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE1B,IAAI,CAAC,gBAAgB,EAAE;YACpB,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,WAAW,IAAI,CAAC,QAAQ,yBAAyB,CAAC,CAAC;SACrE;IACJ,CAAC;IAEO,YAAY;;QACjB,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,WAAI,IAAI,CAAC,OAAO,0CAAE,MAAM,CAAA,EAAE;YACrD,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YACrC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YACnC,IAAI,CAAC,6BAA6B,EAAE,CAAC;YACrC,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YAElF,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;YAE3D,IAAI,IAAI,CAAC,WAAW,EAAE;gBACnB,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;aAC/D;SACH;IACJ,CAAC;IAEO,aAAa;QAChB,MAAM,gBAAgB,GAAG,IAAI,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,gBAAgB,CAAC,CAAC;QACjG,IAAI,CAAC,YAAY,GAAG,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC3D,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QACnD,OAAQ,IAAI,CAAC,YAAY,CAAC,QAAiC,CAAC,SAAS,CAAC,CAAC,CAAgB,CAAC;IAC7F,CAAC;IAED;;;;OAIG;IACK,mBAAmB,CAAC,IAAiB;;QACxC,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,WAAI,IAAI,CAAC,OAAO,0CAAE,MAAM,CAAA,EAAE;YACpD,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YACrC,MAAM,OAAO,GAAG,OAAO,CAAC,aAAa,CAAC,UAAU,CAAgB,CAAC;YACjE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC1B,IAAI,CAAC,6BAA6B,EAAE,CAAC;YAErC,UAAU,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC,CAAC;YAC/D,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,GAAG,EAAE;gBACxC,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACjC,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAEO,qBAAqB;QACzB,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YAC3F,MAAM,YAAY,GAAG,KAAK,GAAG,IAAI,CAAC;YAClC,MAAM,aAAa,GAAG,MAAM,GAAG,GAAG,CAAC;YAEnC,QAAQ,IAAI,CAAC,QAAQ,EAAE;gBACnB,KAAK,eAAe,CAAC,GAAG;oBACpB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;oBACtE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;oBAC1D,MAAM;gBACV,KAAK,eAAe,CAAC,MAAM;oBACvB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;oBACtE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC;oBACzD,MAAM;gBACV,KAAK,eAAe,CAAC,IAAI;oBACrB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC;oBACxD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,aAAa,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;oBACzE,MAAM;gBACV,KAAK,eAAe,CAAC,KAAK;oBACtB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC;oBACzD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,aAAa,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;oBACzE,MAAM;gBACV;oBACI,MAAM;aACb;SACJ;IACL,CAAC;IAEM,WAAW;QAChB,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;YAC7B,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YAElD,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,8BAA8B,CAAC,CAAC;SAC5E;IACJ,CAAC;IAEO,6BAA6B;QAClC,MAAM,MAAM,GAAG,EAAE,CAAC;QAClB,MAAM,UAAU,GAAG,CAAC,CAAC;QAErB,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;YAC7B,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YAClD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAEhD,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YAE3F,MAAM,aAAa,GAAG,MAAM,GAAG,GAAG,CAAC;YACnC,MAAM,YAAY,GAAG,KAAK,GAAG,IAAI,CAAC;YAClC,MAAM,SAAS,GAAG,GAAG,CAAC;YAEtB,IAAI,UAAU,GAAG,KAAK,CAAC;YACvB,MAAM,cAAc,GAAsB,EAAE,CAAC;YAE7C,OAAO,CAAC,UAAU,EAAE;gBACjB,IAAI,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,GAAG,CAAC;uBAC1C,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC;uBAC/C,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC;uBAC7C,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE;oBACnD,IAAI,CAAC,OAAO,EAAE,CAAC;oBACf,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;iBAC9C;gBAED,QAAQ,IAAI,CAAC,QAAQ,EAAE;oBACpB,KAAK,eAAe,CAAC,GAAG,CAAC,CAAC;wBACvB,IAAI,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE;4BAC/C,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,IAAI,CAAC;4BACrC,MAAM;yBACR;wBAED,MAAM,QAAQ,GAAG,GAAG,CAAC;wBAErB,IAAI,QAAQ,IAAI,aAAa,GAAG,SAAS,EAAE;4BACxC,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,MAAM,CAAC;4BACvC,cAAc,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;4BACzC,UAAU,GAAG,KAAK,CAAC;4BACnB,MAAM;yBACR;wBAED,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;wBACtE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,MAAM,GAAG,UAAU,CAAC,CAAC;wBACvE,UAAU,GAAG,IAAI,CAAC;wBAClB,MAAM;qBACR;oBACD,KAAK,eAAe,CAAC,MAAM,CAAC,CAAC;wBAE1B,IAAI,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE;4BAClD,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,IAAI,CAAC;4BACrC,MAAM;yBACR;wBAED,MAAM,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;wBAExD,IAAI,WAAW,IAAI,aAAa,GAAG,SAAS,EAAE;4BAC3C,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC;4BACpC,cAAc,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;4BAC5C,MAAM;yBACR;wBAED,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;wBACtE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC;wBAC7D,UAAU,GAAG,IAAI,CAAC;wBAClB,MAAM;qBACR;oBACD,KAAK,eAAe,CAAC,IAAI,CAAC,CAAC;wBACxB,IAAI,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE;4BAChD,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC;4BACpC,MAAM;yBACR;wBAED,MAAM,SAAS,GAAG,IAAI,CAAC;wBAEvB,IAAI,SAAS,IAAI,YAAY,GAAG,SAAS,EAAE;4BACxC,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,KAAK,CAAC;4BACtC,cAAc,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;4BAC1C,UAAU,GAAG,KAAK,CAAC;4BACnB,MAAM;yBACR;wBAED,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,CAAC;wBAC5D,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,aAAa,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC;wBAClF,UAAU,GAAG,IAAI,CAAC;wBAClB,MAAM;qBACR;oBACD,KAAK,eAAe,CAAC,KAAK,CAAC,CAAC;wBACzB,IAAI,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE;4BACjD,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC;4BACpC,MAAM;yBACR;wBAED,MAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;wBAErD,IAAI,UAAU,IAAI,YAAY,GAAG,SAAS,EAAE;4BACzC,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,IAAI,CAAC;4BACrC,cAAc,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;4BAC3C,UAAU,GAAG,KAAK,CAAC;4BACnB,MAAM;yBACR;wBAED,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC;wBAC7D,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,aAAa,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC;wBAClF,UAAU,GAAG,IAAI,CAAC;wBAClB,MAAM;qBACR;oBACD,OAAO,CAAC,CAAC;wBACN,MAAM;qBACR;iBACH;gBAED,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;aACtD;SACH;IACJ,CAAC;IAEO,OAAO;QACZ,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;YAC7B,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACtC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;YACnD,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;SAChC;QAED,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,8BAA8B,CAAC,CAAC;IAChF,CAAC;CACH,CAAA;;YAhYkC,UAAU;YACd,cAAc;YACI,wBAAwB;YACxC,QAAQ;YACH,aAAa;YAClB,SAAS;;AAvCvC;IADC,KAAK,CAAC,UAAU,CAAC;iDACK;AAGvB;IADC,KAAK,CAAC,iBAAiB,CAAC;kDAC8B;AAGvD;IADC,KAAK,EAAE;mDACe;AAGvB;IADC,KAAK,EAAE;qDACmB;AAG3B;IADC,KAAK,EAAE;sDACiC;AAGzC;IADC,KAAK,EAAE;gDACc;AAGtB;IADC,KAAK,EAAE;iDACc;AAGtB;IADC,KAAK,EAAE;wDACwC;AAGhD;IADC,KAAK,EAAE;yDACiC;AA4GzC;IAFC,YAAY,CAAC,OAAO,CAAC;IACrB,YAAY,CAAC,SAAS,CAAC;+CAOvB;AAID;IADC,YAAY,CAAC,qBAAqB,CAAC;4DAKnC;AAGD;IADC,YAAY,CAAC,OAAO,CAAC;+CAKrB;AAGD;IADC,YAAY,CAAC,MAAM,CAAC;8CAKpB;AAGD;IADC,YAAY,CAAC,YAAY,CAAC;oDAK1B;AAID;IAFC,YAAY,CAAC,YAAY,CAAC;IAC1B,YAAY,CAAC,OAAO,CAAC;oDAKrB;AAGD;IADC,YAAY,CAAC,YAAY,CAAC;oDAS1B;AAGD;IADC,YAAY,CAAC,UAAU,CAAC;kDAQxB;AAtMS,gBAAgB;IAH5B,SAAS,CAAC;QACR,QAAQ,EAAE,YAAY;KACxB,CAAC;GACW,gBAAgB,CAoa5B;SApaY,gBAAgB","sourcesContent":["import {\n   ApplicationRef,\n   ComponentFactoryResolver,\n   ComponentRef,\n   Directive,\n   ElementRef,\n   EmbeddedViewRef,\n   HostListener,\n   Injector,\n   Input,\n   OnDestroy,\n   OnInit,\n   Renderer2\n} from \"@angular/core\";\nimport { DebounceUtils } from \"../utils/debouce\";\nimport { MobileBehavior, TooltipEvent, TooltipPosition } from \"./models\";\nimport { TooltipComponent } from \"./tooltip.component\";\nimport { ElementArea } from \"./models/element-area\";\n\n@Directive({\n   selector: \"[sTooltip]\",\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n   @Input(\"sTooltip\")\n   public tooltip: string;\n\n   @Input(\"tooltipPosition\")\n   public position: TooltipPosition = TooltipPosition.Top;\n\n   @Input()\n   public showDelay = 500;\n\n   @Input()\n   public displayTime: number;\n\n   @Input()\n   public tooltipEvent = TooltipEvent.Hover;\n\n   @Input()\n   public escape = false;\n\n   @Input()\n   public visible = true;\n\n   @Input()\n   public mobileBehavior = MobileBehavior.Pressing;\n\n   @Input()\n   public focusedInputRef: HTMLInputElement;\n\n   private componentRef: ComponentRef<any> = null;\n   private showTimeout?: number;\n   private touchTimeout?: number;\n   private tooltipDivElement?: HTMLElement;\n   private readonly boundOnWindowMouseMoveFunction: (event: MouseEvent) => void;\n   private readonly debounceCreateTooltipFunction: () => void;\n\n   constructor(\n      private readonly elementRef: ElementRef,\n      private readonly appRef: ApplicationRef,\n      private readonly componentFactoryResolver: ComponentFactoryResolver,\n      private readonly injector: Injector,\n      private readonly debounceUtils: DebounceUtils,\n      private readonly renderer: Renderer2\n   ) {\n      this.boundOnWindowMouseMoveFunction = this.onWindowMouseMove.bind(this);\n      this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(() => this.createTootip());\n   }\n\n   public ngOnInit(): void {\n      this.validatePosition();\n      this.updateTooltipVisibilityWhenFocusOnInput();\n   }\n\n   public ngOnDestroy(): void {\n      this.destroy();\n   }\n\n   private onWindowMouseMove(event: MouseEvent) {\n      if (!this.componentRef) {\n         return;\n      }\n      const elementRect = this.elementRef.nativeElement.getBoundingClientRect();\n      const toolTipRect = this.tooltipDivElement.getBoundingClientRect();\n\n      const totalElementArea = {\n         top: Math.min(elementRect.top, toolTipRect.top),\n         right: Math.max(elementRect.right, toolTipRect.right),\n         left: Math.min(elementRect.left, toolTipRect.left),\n         bottom: Math.max(elementRect.bottom, toolTipRect.bottom)\n      };\n\n      if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea)) {\n         this.destroy();\n      }\n   }\n\n   private isMousePositionOutsideOfElement(mouseX: number, mouseY: number, elementArea: ElementArea) {\n      return mouseX < elementArea.left || mouseX >= elementArea.right || mouseY < elementArea.top || mouseY >= elementArea.bottom;\n   }\n\n   /**\n    * Manipula a visibilidade do tooltip quando houver uma referência de input.\n    */\n   private updateTooltipVisibilityWhenFocusOnInput() {\n        if (this.focusedInputRef) {\n            const inputFocus = this.focusedInputRef;\n            const icon = this.getIconFromFocusedInput();\n\n            this.renderer.listen(this.focusedInputRef, 'focus', () => {\n                if (icon && this.isMatchingTooltip(icon)) {\n                    this.createTootipByFocus(icon);\n                }\n            });\n            this.renderer.listen(inputFocus, 'blur', () => {\n               if (icon && this.isMatchingTooltip(icon)) {\n                    this.removeTooltip(icon);\n                    this.destroy();\n                }\n            });\n        }\n    }\n\n    /**\n     * Obtém o elemento do ícone associado ao label do input em focus.\n     * @returns O ícone do input em focus.\n     */\n    private getIconFromFocusedInput(): HTMLElement {\n      return this.elementRef.nativeElement;\n    }\n\n    /**\n     * Verifica se o ícone tem o tooltip correspondente ao atual.\n     * @param icon O ícone do input em focus.\n     * @returns true se o tooltip corresponde; caso contrário, false.\n     */\n    private isMatchingTooltip(icon: HTMLElement): boolean {\n        const tooltipText = icon.getAttribute('ng-reflect-tooltip');\n        return this.tooltip === tooltipText;\n    }\n\n    /**\n     * Remove o tooltip associado ao ícone do input em focus.\n     * @param icon O ícone do input em focus.\n     */\n    private removeTooltip(icon: HTMLElement): void {\n        const tooltip = icon.querySelector('.tooltip') as HTMLElement;\n        if (tooltip) {\n            tooltip.remove();\n        }\n    }\n\n   // whenever the component with the tooltip is clicked I destroy the tooltip.\n   // whenever a key is pressed on the component with the tooltip I destroy the tooltip.\n   @HostListener(\"click\")\n   @HostListener(\"keydown\")\n   public onClick(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover &&\n         !navigator.userAgent.match(/Android/i) &&\n         !navigator.userAgent.match(/iPhone/i)) {\n         this.destroy();\n      }\n   }\n\n   // whenever you touch outside the component with the tooltip I destroy the tooltip.\n   @HostListener(\"document:touchstart\")\n   public onDocumentTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"focus\")\n   public onFocus(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.createTootip();\n      }\n   }\n\n   @HostListener(\"blur\")\n   public onBlur(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"mouseenter\")\n   public onMouseEnter(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.debounceCreateTooltipFunction();\n      }\n   }\n\n   @HostListener(\"mouseleave\")\n   @HostListener(\"wheel\")\n   public onMouseLeave(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"touchstart\")\n   public onTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         window.clearTimeout(this.touchTimeout);\n         this.touchTimeout = window.setTimeout(\n            this.createTootip.bind(this),\n            this.mobileBehavior === MobileBehavior.Pressing ? this.showDelay : 0\n         );\n      }\n   }\n\n   @HostListener(\"touchend\")\n   public onTouchEnd(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         if (this.mobileBehavior === MobileBehavior.Pressing) {\n            window.clearTimeout(this.touchTimeout);\n            this.destroy();\n         }\n      }\n   }\n\n   private validatePosition() {\n      const containsPosition = [\n         TooltipPosition.Top,\n         TooltipPosition.Right,\n         TooltipPosition.Bottom,\n         TooltipPosition.Left,\n      ].includes(this.position);\n\n      if (!containsPosition) {\n         this.position = TooltipPosition.Top;\n         throw new Error(`Tooltip ${this.position} position is unexpected`);\n      }\n   }\n\n   private createTootip() {\n      if (this.componentRef === null && this.tooltip?.length) {\n         const domElem = this.getDomElement();\n         document.body.appendChild(domElem);\n         this.setTooltipComponentProperties();\n         this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);\n\n         this.tooltipDivElement = domElem.querySelector('.tooltip');\n\n         if (this.displayTime) {\n            window.setTimeout(this.destroy.bind(this), this.displayTime);\n         }\n      }\n   }\n\n   private getDomElement(): HTMLElement {\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);\n        this.componentRef = componentFactory.create(this.injector);\n        this.appRef.attachView(this.componentRef.hostView);\n        return (this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n   }\n\n   /**\n    * Cria um tooltip para o icone do input em focus.\n    *\n    * @param icon O ícone do input em focus.\n    */\n   private createTootipByFocus(icon: HTMLElement) {\n        if (this.componentRef === null && this.tooltip?.length) {\n            const domElem = this.getDomElement();\n            const tooltip = domElem.querySelector('.tooltip') as HTMLElement;\n            icon.appendChild(tooltip);\n            this.setTooltipComponentProperties();\n\n            setTimeout(() => tooltip.classList.add(\"tooltip--visible\"), 0);\n            this.renderer.listen(window, 'scroll', () => {\n                this.updateTooltipPosition();\n            });\n        }\n    }\n\n    private updateTooltipPosition() {\n        if (this.componentRef) {\n            const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();\n            const tooltipWidth = right - left;\n            const tooltipHeight = bottom - top;\n\n            switch (this.position) {\n                case TooltipPosition.Top:\n                    this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                    this.componentRef.instance.top = Math.round(top - 20 - 5);\n                    break;\n                case TooltipPosition.Bottom:\n                    this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                    this.componentRef.instance.top = Math.round(bottom + 20);\n                    break;\n                case TooltipPosition.Left:\n                    this.componentRef.instance.left = Math.round(left - 20);\n                    this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - 5);\n                    break;\n                case TooltipPosition.Right:\n                    this.componentRef.instance.left = Math.round(right + 20);\n                    this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - 5);\n                    break;\n                default:\n                    break;\n            }\n        }\n    }\n\n   private showTooltip() {\n      if (this.componentRef !== null) {\n         this.componentRef.instance.visible = this.visible;\n\n         window.addEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n      }\n   }\n\n   private setTooltipComponentProperties() {\n      const margin = 20;\n      const anchorSize = 5;\n\n      if (this.componentRef !== null) {\n         this.componentRef.instance.tooltip = this.tooltip;\n         this.componentRef.instance.escape = this.escape;\n\n         const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();\n\n         const tooltipHeight = bottom - top;\n         const tooltipWidth = right - left;\n         const safeSpace = 150;\n\n         let positioned = false;\n         const invalidOptions: TooltipPosition[] = [];\n\n         while (!positioned) {\n            if (invalidOptions.includes(TooltipPosition.Top)\n               && invalidOptions.includes(TooltipPosition.Bottom)\n               && invalidOptions.includes(TooltipPosition.Left)\n               && invalidOptions.includes(TooltipPosition.Right)) {\n               this.destroy();\n               throw new Error(\"No space to show tooltip\");\n            }\n\n            switch (this.position) {\n               case TooltipPosition.Top: {\n                  if (invalidOptions.includes(TooltipPosition.Top)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const topShift = top;\n\n                  if (topShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Bottom;\n                     invalidOptions.push(TooltipPosition.Top);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(top - margin - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Bottom: {\n\n                  if (invalidOptions.includes(TooltipPosition.Bottom)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const bottomShift = document.body.clientHeight - bottom;\n\n                  if (bottomShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Top;\n                     invalidOptions.push(TooltipPosition.Bottom);\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(bottom + margin);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Left: {\n                  if (invalidOptions.includes(TooltipPosition.Left)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const leftShift = left;\n\n                  if (leftShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Right;\n                     invalidOptions.push(TooltipPosition.Left);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(left - margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Right: {\n                  if (invalidOptions.includes(TooltipPosition.Right)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const rightShift = document.body.clientWidth - right;\n\n                  if (rightShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Left;\n                     invalidOptions.push(TooltipPosition.Right);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(right + margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               default: {\n                  break;\n               }\n            }\n\n            this.componentRef.instance.position = this.position;\n         }\n      }\n   }\n\n   private destroy(): void {\n      if (this.componentRef !== null) {\n         window.clearTimeout(this.showTimeout);\n         this.appRef.detachView(this.componentRef.hostView);\n         this.componentRef.destroy();\n         this.componentRef = null;\n         this.tooltipDivElement = null;\n      }\n\n      window.removeEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n   }\n}\n"]}
322
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ApplicationRef,\n    ComponentFactoryResolver,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    EmbeddedViewRef,\n    HostListener,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Renderer2,\n} from \"@angular/core\";\nimport { DebounceUtils } from \"../utils/debouce\";\nimport { MobileBehavior, TooltipEvent, TooltipPosition } from \"./models\";\nimport { TooltipComponent } from \"./tooltip.component\";\nimport { ElementArea } from \"./models/element-area\";\n\n@Directive({\n    selector: \"[sTooltip]\",\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n    @Input(\"sTooltip\")\n    public tooltip: string;\n\n    @Input(\"tooltipPosition\")\n    public position: TooltipPosition = TooltipPosition.Top;\n\n    @Input()\n    public showDelay = 500;\n\n    @Input()\n    public displayTime: number;\n\n    @Input()\n    public tooltipEvent = TooltipEvent.Hover;\n\n    @Input()\n    public escape = false;\n\n    @Input()\n    public visible = true;\n\n    @Input()\n    public mobileBehavior = MobileBehavior.Pressing;\n\n    @Input()\n    public focusedInputRef: HTMLInputElement;\n\n    private componentRef: ComponentRef<any> = null;\n    private showTimeout?: number;\n    private touchTimeout?: number;\n    private tooltipDivElement?: HTMLElement;\n    private readonly boundOnWindowMouseMoveFunction: (event: MouseEvent) => void;\n    private readonly debounceCreateTooltipFunction: () => void;\n\n    constructor(\n        private readonly elementRef: ElementRef,\n        private readonly appRef: ApplicationRef,\n        private readonly componentFactoryResolver: ComponentFactoryResolver,\n        private readonly injector: Injector,\n        private readonly debounceUtils: DebounceUtils,\n        private readonly renderer: Renderer2\n    ) {\n        this.boundOnWindowMouseMoveFunction = this.onWindowMouseMove.bind(this);\n        this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(() => this.createTootip());\n    }\n\n    public ngOnInit(): void {\n        this.validatePosition();\n        this.updateTooltipVisibilityWhenFocusOnInput();\n    }\n\n    public ngOnDestroy(): void {\n        this.destroy();\n    }\n\n    private onWindowMouseMove(event: MouseEvent) {\n        if (!this.componentRef) {\n            return;\n        }\n        const elementRect = this.elementRef.nativeElement.getBoundingClientRect();\n        const toolTipRect = this.tooltipDivElement.getBoundingClientRect();\n\n        const totalElementArea = {\n            top: Math.min(elementRect.top, toolTipRect.top),\n            right: Math.max(elementRect.right, toolTipRect.right),\n            left: Math.min(elementRect.left, toolTipRect.left),\n            bottom: Math.max(elementRect.bottom, toolTipRect.bottom),\n        };\n\n        if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea)) {\n            this.destroy();\n        }\n    }\n\n    private isMousePositionOutsideOfElement(mouseX: number, mouseY: number, elementArea: ElementArea) {\n        return mouseX < elementArea.left || mouseX >= elementArea.right || mouseY < elementArea.top || mouseY >= elementArea.bottom;\n    }\n\n    /**\n     * Manipula a visibilidade do tooltip quando houver uma referência de input.\n     */\n    private updateTooltipVisibilityWhenFocusOnInput() {\n        if (this.focusedInputRef) {\n            const inputFocus = this.focusedInputRef;\n            const icon = this.getIconFromFocusedInput();\n\n            this.renderer.listen(this.focusedInputRef, \"focus\", () => {\n                if (icon && this.isMatchingTooltip(icon)) {\n                    this.createTootipByFocus(icon);\n                }\n            });\n            this.renderer.listen(inputFocus, \"blur\", () => {\n                if (icon && this.isMatchingTooltip(icon)) {\n                    this.removeTooltip(icon);\n                    this.destroy();\n                }\n            });\n        }\n    }\n\n    /**\n     * Obtém o elemento do ícone associado ao label do input em focus.\n     * @returns O ícone do input em focus.\n     */\n    private getIconFromFocusedInput(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    /**\n     * Verifica se o ícone tem o tooltip correspondente ao atual.\n     * @param icon O ícone do input em focus.\n     * @returns true se o tooltip corresponde; caso contrário, false.\n     */\n    private isMatchingTooltip(icon: HTMLElement): boolean {\n        const tooltipText = icon.getAttribute(\"ng-reflect-tooltip\");\n        return this.tooltip === tooltipText;\n    }\n\n    /**\n     * Remove o tooltip associado ao ícone do input em focus.\n     * @param icon O ícone do input em focus.\n     */\n    private removeTooltip(icon: HTMLElement): void {\n        const tooltip = icon.querySelector(\".tooltip\") as HTMLElement;\n        if (tooltip) {\n            tooltip.remove();\n        }\n    }\n\n    // whenever the component with the tooltip is clicked I destroy the tooltip.\n    // whenever a key is pressed on the component with the tooltip I destroy the tooltip.\n    @HostListener(\"click\")\n    @HostListener(\"keydown\")\n    public onClick(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover && !navigator.userAgent.match(/Android/i) && !navigator.userAgent.match(/iPhone/i)) {\n            this.destroy();\n        }\n    }\n\n    // whenever you touch outside the component with the tooltip I destroy the tooltip.\n    @HostListener(\"document:touchstart\")\n    public onDocumentTouchStart(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            this.destroy();\n        }\n    }\n\n    @HostListener(\"focus\")\n    public onFocus(): void {\n        if (this.tooltipEvent === TooltipEvent.Focus) {\n            this.createTootip();\n        }\n    }\n\n    @HostListener(\"blur\")\n    public onBlur(): void {\n        if (this.tooltipEvent === TooltipEvent.Focus) {\n            this.destroy();\n        }\n    }\n\n    @HostListener(\"mouseenter\")\n    public onMouseEnter(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            this.debounceCreateTooltipFunction();\n        }\n    }\n\n    @HostListener(\"mouseleave\")\n    @HostListener(\"wheel\")\n    public onMouseLeave(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            this.destroy();\n        }\n    }\n\n    @HostListener(\"touchstart\")\n    public onTouchStart(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            window.clearTimeout(this.touchTimeout);\n            this.touchTimeout = window.setTimeout(\n                this.createTootip.bind(this),\n                this.mobileBehavior === MobileBehavior.Pressing ? this.showDelay : 0\n            );\n        }\n    }\n\n    @HostListener(\"touchend\")\n    public onTouchEnd(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            if (this.mobileBehavior === MobileBehavior.Pressing) {\n                window.clearTimeout(this.touchTimeout);\n                this.destroy();\n            }\n        }\n    }\n\n    private validatePosition() {\n        const containsPosition = [TooltipPosition.Top, TooltipPosition.Right, TooltipPosition.Bottom, TooltipPosition.Left].includes(\n            this.position\n        );\n\n        if (!containsPosition) {\n            this.position = TooltipPosition.Top;\n            throw new Error(`Tooltip ${this.position} position is unexpected`);\n        }\n    }\n\n    private createTootip() {\n        if (this.componentRef === null && this.tooltip?.length) {\n            const domElem = this.getDomElement();\n            document.body.appendChild(domElem);\n            this.setTooltipComponentProperties();\n            this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);\n\n            this.tooltipDivElement = domElem.querySelector(\".tooltip\");\n\n            if (this.displayTime) {\n                window.setTimeout(this.destroy.bind(this), this.displayTime);\n            }\n        }\n    }\n\n    private getDomElement(): HTMLElement {\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);\n        this.componentRef = componentFactory.create(this.injector);\n        this.appRef.attachView(this.componentRef.hostView);\n        return (this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n    }\n\n    /**\n     * Cria um tooltip para o icone do input em focus.\n     *\n     * @param icon O ícone do input em focus.\n     */\n    private createTootipByFocus(icon: HTMLElement) {\n        if (this.componentRef === null && this.tooltip?.length) {\n            const domElem = this.getDomElement();\n            const tooltip = domElem.querySelector(\".tooltip\") as HTMLElement;\n            icon.appendChild(tooltip);\n            this.setTooltipComponentProperties();\n\n            setTimeout(() => tooltip.classList.add(\"tooltip--visible\"), 0);\n            this.renderer.listen(window, \"scroll\", () => {\n                this.setTooltipPositionProperty();\n            });\n        }\n    }\n\n    private showTooltip() {\n        if (this.componentRef !== null) {\n            this.componentRef.instance.visible = this.visible;\n\n            this.setTooltipPositionProperty();\n\n            window.addEventListener(\"mousemove\", this.boundOnWindowMouseMoveFunction);\n        }\n    }\n\n    private setTooltipPositionProperty() {\n        const margin = 20;\n        const anchorSize = 5;\n\n        const domElem = ((this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement).querySelector(\"#tooltip\");\n        const { height, width } = domElem.getBoundingClientRect();\n        const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();\n\n        const positions = [\n            {\n                pos: TooltipPosition.Top,\n                check: () => top > height,\n                set: () => ({ left: left + (right - left) / 2, top: top - margin - anchorSize }),\n            },\n            {\n                pos: TooltipPosition.Bottom,\n                check: () => document.body.clientHeight - bottom > height,\n                set: () => ({ left: left + (right - left) / 2, top: bottom + margin }),\n            },\n            {\n                pos: TooltipPosition.Left,\n                check: () => left > width,\n                set: () => ({ left: left - margin, top: top + height / 2 - anchorSize }),\n            },\n            {\n                pos: TooltipPosition.Right,\n                check: () => document.body.clientWidth - right > width,\n                set: () => ({ left: right + margin, top: top + height / 2 - anchorSize }),\n            },\n        ];\n\n        for (const { pos, check, set } of positions) {\n            if (check()) {\n                this.position = pos;\n                const { left, top } = set();\n                this.componentRef.instance.left = Math.round(left);\n                this.componentRef.instance.top = Math.round(top);\n                this.componentRef.instance.position = this.position;\n                return;\n            }\n        }\n\n        // Se não conseguir posicionar, mostrar abaixo\n        this.position = TooltipPosition.Bottom;\n        this.componentRef.instance.left = Math.round(left + (right - left) / 2);\n        this.componentRef.instance.top = Math.round(bottom + margin);\n        this.componentRef.instance.position = this.position;\n    }\n\n    private setTooltipComponentProperties() {\n        if (this.componentRef !== null) {\n            this.componentRef.instance.tooltip = this.tooltip;\n            this.componentRef.instance.escape = this.escape;\n        }\n    }\n\n    private destroy(): void {\n        if (this.componentRef !== null) {\n            window.clearTimeout(this.showTimeout);\n            this.appRef.detachView(this.componentRef.hostView);\n            this.componentRef.destroy();\n            this.componentRef = null;\n            this.tooltipDivElement = null;\n        }\n\n        window.removeEventListener(\"mousemove\", this.boundOnWindowMouseMoveFunction);\n    }\n}\n"]}
@@ -4,15 +4,21 @@ import { BadgeColors } from "./models/badge-colors";
4
4
  import { BadgeTypes } from "./models/badge-types";
5
5
  var BadgeComponent = /** @class */ (function () {
6
6
  function BadgeComponent() {
7
- this.type = BadgeTypes.Pill;
8
- this.color = BadgeColors.Blue;
9
7
  this.selectable = false;
10
- this.iconPosition = "left";
11
8
  this.selected = new EventEmitter();
12
9
  }
13
10
  BadgeComponent.prototype.onClick = function () {
14
11
  this.selected.emit(this.text);
15
12
  };
13
+ BadgeComponent.prototype.ngOnInit = function () {
14
+ this._setDefaultValues();
15
+ };
16
+ BadgeComponent.prototype._setDefaultValues = function () {
17
+ var _a, _b, _c;
18
+ this.type = (_a = this.type) !== null && _a !== void 0 ? _a : BadgeTypes.Pill;
19
+ this.color = (_b = this.color) !== null && _b !== void 0 ? _b : BadgeColors.Blue;
20
+ this.iconPosition = (_c = this.iconPosition) !== null && _c !== void 0 ? _c : "left";
21
+ };
16
22
  __decorate([
17
23
  Input()
18
24
  ], BadgeComponent.prototype, "type", void 0);
@@ -50,4 +56,4 @@ var BadgeComponent = /** @class */ (function () {
50
56
  return BadgeComponent;
51
57
  }());
52
58
  export { BadgeComponent };
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvYmFkZ2UvYmFkZ2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVyRixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDcEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBT2xEO0lBQUE7UUFFVSxTQUFJLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQztRQUd2QixVQUFLLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQztRQVN6QixlQUFVLEdBQUcsS0FBSyxDQUFDO1FBTW5CLGlCQUFZLEdBQXFCLE1BQU0sQ0FBQztRQUd4QyxhQUFRLEdBQXlCLElBQUksWUFBWSxFQUFFLENBQUM7SUFNOUQsQ0FBQztJQUhTLGdDQUFPLEdBQWQ7UUFDRyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDakMsQ0FBQztJQTFCRDtRQURDLEtBQUssRUFBRTtnREFDc0I7SUFHOUI7UUFEQyxLQUFLLEVBQUU7aURBQ3dCO0lBR2hDO1FBREMsS0FBSyxFQUFFO2lEQUNhO0lBR3JCO1FBREMsS0FBSyxFQUFFO2dEQUNZO0lBR3BCO1FBREMsS0FBSyxFQUFFO3NEQUNrQjtJQUcxQjtRQURDLEtBQUssRUFBRTtxREFDaUI7SUFHekI7UUFEQyxLQUFLLEVBQUU7d0RBQ3VDO0lBRy9DO1FBREMsTUFBTSxFQUFFO29EQUNrRDtJQUczRDtRQURDLFlBQVksQ0FBQyxPQUFPLENBQUM7aURBR3JCO0lBNUJTLGNBQWM7UUFMMUIsU0FBUyxDQUFDO1lBQ1IsUUFBUSxFQUFFLFNBQVM7WUFDbkIsMHlCQUFxQzs7U0FFdkMsQ0FBQztPQUNXLGNBQWMsQ0E2QjFCO0lBQUQscUJBQUM7Q0FBQSxBQTdCRCxJQTZCQztTQTdCWSxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE91dHB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbmltcG9ydCB7IEJhZGdlQ29sb3JzIH0gZnJvbSBcIi4vbW9kZWxzL2JhZGdlLWNvbG9yc1wiO1xuaW1wb3J0IHsgQmFkZ2VUeXBlcyB9IGZyb20gXCIuL21vZGVscy9iYWRnZS10eXBlc1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgIHNlbGVjdG9yOiBcInMtYmFkZ2VcIixcbiAgIHRlbXBsYXRlVXJsOiBcIi4vYmFkZ2UuY29tcG9uZW50Lmh0bWxcIixcbiAgIHN0eWxlVXJsczogW1wiLi9iYWRnZS5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgQmFkZ2VDb21wb25lbnQge1xuICAgQElucHV0KClcbiAgIHB1YmxpYyB0eXBlID0gQmFkZ2VUeXBlcy5QaWxsO1xuXG4gICBASW5wdXQoKVxuICAgcHVibGljIGNvbG9yID0gQmFkZ2VDb2xvcnMuQmx1ZTtcblxuICAgQElucHV0KClcbiAgIHB1YmxpYyB0aXRsZTogc3RyaW5nO1xuXG4gICBASW5wdXQoKVxuICAgcHVibGljIHRleHQ6IHN0cmluZztcblxuICAgQElucHV0KClcbiAgIHB1YmxpYyBzZWxlY3RhYmxlID0gZmFsc2U7XG5cbiAgIEBJbnB1dCgpXG4gICBwdWJsaWMgaWNvbkNsYXNzOiBzdHJpbmc7XG5cbiAgIEBJbnB1dCgpXG4gICBwdWJsaWMgaWNvblBvc2l0aW9uOiBcImxlZnRcIiB8IFwicmlnaHRcIiA9IFwibGVmdFwiO1xuXG4gICBAT3V0cHV0KClcbiAgIHB1YmxpYyBzZWxlY3RlZDogRXZlbnRFbWl0dGVyPHN0cmluZz4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgIEBIb3N0TGlzdGVuZXIoXCJjbGlja1wiKVxuICAgcHVibGljIG9uQ2xpY2soKSB7XG4gICAgICB0aGlzLnNlbGVjdGVkLmVtaXQodGhpcy50ZXh0KTtcbiAgIH1cbn0iXX0=
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvYmFkZ2UvYmFkZ2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU3RixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDcEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBT2xEO0lBQUE7UUFjVyxlQUFVLEdBQUcsS0FBSyxDQUFDO1FBU25CLGFBQVEsR0FBeUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQWdCL0QsQ0FBQztJQWJVLGdDQUFPLEdBQWQ7UUFDSSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVNLGlDQUFRLEdBQWY7UUFDSSxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRU8sMENBQWlCLEdBQXpCOztRQUNJLElBQUksQ0FBQyxJQUFJLFNBQUcsSUFBSSxDQUFDLElBQUksbUNBQUksVUFBVSxDQUFDLElBQUksQ0FBQztRQUN6QyxJQUFJLENBQUMsS0FBSyxTQUFHLElBQUksQ0FBQyxLQUFLLG1DQUFJLFdBQVcsQ0FBQyxJQUFJLENBQUM7UUFDNUMsSUFBSSxDQUFDLFlBQVksU0FBRyxJQUFJLENBQUMsWUFBWSxtQ0FBSSxNQUFNLENBQUM7SUFDcEQsQ0FBQztJQXBDRDtRQURDLEtBQUssRUFBRTtnREFDZ0I7SUFHeEI7UUFEQyxLQUFLLEVBQUU7aURBQ2tCO0lBRzFCO1FBREMsS0FBSyxFQUFFO2lEQUNhO0lBR3JCO1FBREMsS0FBSyxFQUFFO2dEQUNZO0lBR3BCO1FBREMsS0FBSyxFQUFFO3NEQUNrQjtJQUcxQjtRQURDLEtBQUssRUFBRTtxREFDaUI7SUFHekI7UUFEQyxLQUFLLEVBQUU7d0RBQzhCO0lBR3RDO1FBREMsTUFBTSxFQUFFO29EQUNrRDtJQUczRDtRQURDLFlBQVksQ0FBQyxPQUFPLENBQUM7aURBR3JCO0lBNUJRLGNBQWM7UUFMMUIsU0FBUyxDQUFDO1lBQ1AsUUFBUSxFQUFFLFNBQVM7WUFDbkIsMHlCQUFxQzs7U0FFeEMsQ0FBQztPQUNXLGNBQWMsQ0F1QzFCO0lBQUQscUJBQUM7Q0FBQSxBQXZDRCxJQXVDQztTQXZDWSxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuaW1wb3J0IHsgQmFkZ2VDb2xvcnMgfSBmcm9tIFwiLi9tb2RlbHMvYmFkZ2UtY29sb3JzXCI7XG5pbXBvcnQgeyBCYWRnZVR5cGVzIH0gZnJvbSBcIi4vbW9kZWxzL2JhZGdlLXR5cGVzXCI7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiBcInMtYmFkZ2VcIixcbiAgICB0ZW1wbGF0ZVVybDogXCIuL2JhZGdlLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCIuL2JhZGdlLmNvbXBvbmVudC5zY3NzXCJdLFxufSlcbmV4cG9ydCBjbGFzcyBCYWRnZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgdHlwZTogQmFkZ2VUeXBlcztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGNvbG9yOiBCYWRnZUNvbG9ycztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHRpdGxlOiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyB0ZXh0OiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBzZWxlY3RhYmxlID0gZmFsc2U7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpY29uQ2xhc3M6IHN0cmluZztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGljb25Qb3NpdGlvbjogXCJsZWZ0XCIgfCBcInJpZ2h0XCI7XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgc2VsZWN0ZWQ6IEV2ZW50RW1pdHRlcjxzdHJpbmc+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gICAgQEhvc3RMaXN0ZW5lcihcImNsaWNrXCIpXG4gICAgcHVibGljIG9uQ2xpY2soKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2VsZWN0ZWQuZW1pdCh0aGlzLnRleHQpO1xuICAgIH1cblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5fc2V0RGVmYXVsdFZhbHVlcygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgX3NldERlZmF1bHRWYWx1ZXMoKTogdm9pZCB7XG4gICAgICAgIHRoaXMudHlwZSA9IHRoaXMudHlwZSA/PyBCYWRnZVR5cGVzLlBpbGw7XG4gICAgICAgIHRoaXMuY29sb3IgPSB0aGlzLmNvbG9yID8/IEJhZGdlQ29sb3JzLkJsdWU7XG4gICAgICAgIHRoaXMuaWNvblBvc2l0aW9uID0gdGhpcy5pY29uUG9zaXRpb24gPz8gXCJsZWZ0XCI7XG4gICAgfVxufSJdfQ==
@@ -11,10 +11,10 @@ var LookupFieldComponent = /** @class */ (function () {
11
11
  ], LookupFieldComponent.prototype, "formControl", void 0);
12
12
  LookupFieldComponent = __decorate([
13
13
  Component({
14
- template: "<s-field-label [field]=\"field\">\n\n<div [sTooltip]=\"field.tooltip\" tooltipPosition=\"top\" [showDelay]=\"500\">\n <s-lookup\n [id]=\"field.id || field.name\"\n [multiple]=\"field.multiple\"\n [formControl]=\"formControl\"\n [lookupSuggestions]=\"field.lookupSuggestions\"\n [dataKey]=\"field.dataKey\"\n [placeholder]=\"field.placeholder\"\n [showSearch]=\"field.showSearch\"\n [searchFields]=\"field.searchFields\"\n [searchGridFields]=\"field.searchGridFields\"\n [searchGridData]=\"field.gridData\"\n (onLookupRequest)=\"field.onLookupRequest($event)\"\n (onSearchRequest)=\"field.onSearchRequest($event)\"\n [lookupDisplayField]=\"field.lookupDisplayField\"\n [searchTotalRecords]=\"field.searchTotalRecords\"\n [searchTotalRecordsLabel]=\"field.searchTotalRecordsLabel\"\n [searchTitle]=\"field.searchTitle\"\n [selectLabel]=\"field.selectLabel\"\n [searchEmptyTitle]=\"field.searchEmptyTitle\"\n [filterLabel]=\"field.filterLabel\"\n [filterTitle]=\"field.filterTitle\"\n [clearLabel]=\"field.clearLabel\"\n [cancelLabel]=\"field.cancelLabel\"\n [emptyFieldLabel]=\"field.emptyFieldLabel\"\n (onSelect)=\"field.onSelect($event)\"\n (onUnselect)=\"field.onUnselect($event)\"\n (onClear)=\"field.onClear ? field.onClear($event) : null\"\n (onBlur)=\"field.onBlur ? field.onBlur($event) : null\"\n [lookupAppendTo]=\"field.appendTo\"\n [lookupEmptyMessage]=\"field.emptyMessage\"\n [recordLabel]=\"field.recordLabel\"\n [recordsLabel]=\"field.recordsLabel\"\n [defaultFilter]=\"field.defaultFilter\"\n [autocompleteForceSelection]=\"field.autocompleteForceSelection\"\n [showAddOption]=\"field.showAddOption\"\n [showEditOption]=\"field.showEditOption\"\n [showRemoveOption]=\"field.showRemoveOption\"\n (onAdd)=\"field.onAdd()\"\n (onEdit)=\"field.onEdit($event)\"\n (onRemove)=\"field.onRemove($event)\"\n >\n </s-lookup>\n</div>\n"
14
+ template: "<s-field-label [field]=\"field\"></s-field-label>\n\n<div [sTooltip]=\"field.tooltip\" tooltipPosition=\"top\" [showDelay]=\"500\">\n <s-lookup\n [id]=\"field.id || field.name\"\n [multiple]=\"field.multiple\"\n [formControl]=\"formControl\"\n [lookupSuggestions]=\"field.lookupSuggestions\"\n [dataKey]=\"field.dataKey\"\n [placeholder]=\"field.placeholder\"\n [showSearch]=\"field.showSearch\"\n [searchFields]=\"field.searchFields\"\n [searchGridFields]=\"field.searchGridFields\"\n [searchGridData]=\"field.gridData\"\n (onLookupRequest)=\"field.onLookupRequest($event)\"\n (onSearchRequest)=\"field.onSearchRequest($event)\"\n [lookupDisplayField]=\"field.lookupDisplayField\"\n [searchTotalRecords]=\"field.searchTotalRecords\"\n [searchTotalRecordsLabel]=\"field.searchTotalRecordsLabel\"\n [searchTitle]=\"field.searchTitle\"\n [selectLabel]=\"field.selectLabel\"\n [searchEmptyTitle]=\"field.searchEmptyTitle\"\n [filterLabel]=\"field.filterLabel\"\n [filterTitle]=\"field.filterTitle\"\n [clearLabel]=\"field.clearLabel\"\n [cancelLabel]=\"field.cancelLabel\"\n [emptyFieldLabel]=\"field.emptyFieldLabel\"\n (onSelect)=\"field.onSelect($event)\"\n (onUnselect)=\"field.onUnselect($event)\"\n (onClear)=\"field.onClear ? field.onClear($event) : null\"\n (onBlur)=\"field.onBlur ? field.onBlur($event) : null\"\n [lookupAppendTo]=\"field.appendTo\"\n [lookupEmptyMessage]=\"field.emptyMessage\"\n [recordLabel]=\"field.recordLabel\"\n [recordsLabel]=\"field.recordsLabel\"\n [defaultFilter]=\"field.defaultFilter\"\n [autocompleteForceSelection]=\"field.autocompleteForceSelection\"\n [showAddOption]=\"field.showAddOption\"\n [showEditOption]=\"field.showEditOption\"\n [showRemoveOption]=\"field.showRemoveOption\"\n (onAdd)=\"field.onAdd()\"\n (onEdit)=\"field.onEdit($event)\"\n (onRemove)=\"field.onRemove($event)\"\n >\n </s-lookup>\n</div>\n"
15
15
  })
16
16
  ], LookupFieldComponent);
17
17
  return LookupFieldComponent;
18
18
  }());
19
19
  export { LookupFieldComponent };
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9va3VwLWZpZWxkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2R5bmFtaWMtZm9ybS9jb21wb25lbnRzL2ZpZWxkcy9sb29rdXAvbG9va3VwLWZpZWxkLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFRakQ7SUFBQTtJQUtBLENBQUM7SUFIRztRQURDLEtBQUssRUFBRTt1REFDa0I7SUFFMUI7UUFEQyxLQUFLLEVBQUU7NkRBQ3dCO0lBSnZCLG9CQUFvQjtRQUhoQyxTQUFTLENBQUM7WUFDUCxzbEVBQTBDO1NBQzdDLENBQUM7T0FDVyxvQkFBb0IsQ0FLaEM7SUFBRCwyQkFBQztDQUFBLEFBTEQsSUFLQztTQUxZLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcbmltcG9ydCB7IExvb2t1cEZpZWxkIH0gZnJvbSBcIi4uLy4uLy4uL2NvbmZpZ3VyYXRpb25zL2ZpZWxkcy9sb29rdXAtZmllbGRcIjtcbmltcG9ydCB7IEJhc2VGaWVsZENvbXBvbmVudENvbmZpZyB9IGZyb20gXCIuLi9iYXNlLWZpZWxkLWNvbXBvbmVudFwiO1xuXG5AQ29tcG9uZW50KHtcbiAgICB0ZW1wbGF0ZVVybDogXCJsb29rdXAtZmllbGQuY29tcG9uZW50Lmh0bWxcIixcbn0pXG5leHBvcnQgY2xhc3MgTG9va3VwRmllbGRDb21wb25lbnQgaW1wbGVtZW50cyBCYXNlRmllbGRDb21wb25lbnRDb25maWcge1xuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGZpZWxkOiBMb29rdXBGaWVsZDtcbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBmb3JtQ29udHJvbDogRm9ybUNvbnRyb2w7XG59XG4iXX0=
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9va3VwLWZpZWxkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2R5bmFtaWMtZm9ybS9jb21wb25lbnRzL2ZpZWxkcy9sb29rdXAvbG9va3VwLWZpZWxkLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFRakQ7SUFBQTtJQUtBLENBQUM7SUFIRztRQURDLEtBQUssRUFBRTt1REFDa0I7SUFFMUI7UUFEQyxLQUFLLEVBQUU7NkRBQ3dCO0lBSnZCLG9CQUFvQjtRQUhoQyxTQUFTLENBQUM7WUFDUCxzbUVBQTBDO1NBQzdDLENBQUM7T0FDVyxvQkFBb0IsQ0FLaEM7SUFBRCwyQkFBQztDQUFBLEFBTEQsSUFLQztTQUxZLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcbmltcG9ydCB7IExvb2t1cEZpZWxkIH0gZnJvbSBcIi4uLy4uLy4uL2NvbmZpZ3VyYXRpb25zL2ZpZWxkcy9sb29rdXAtZmllbGRcIjtcbmltcG9ydCB7IEJhc2VGaWVsZENvbXBvbmVudENvbmZpZyB9IGZyb20gXCIuLi9iYXNlLWZpZWxkLWNvbXBvbmVudFwiO1xuXG5AQ29tcG9uZW50KHtcbiAgICB0ZW1wbGF0ZVVybDogXCJsb29rdXAtZmllbGQuY29tcG9uZW50Lmh0bWxcIixcbn0pXG5leHBvcnQgY2xhc3MgTG9va3VwRmllbGRDb21wb25lbnQgaW1wbGVtZW50cyBCYXNlRmllbGRDb21wb25lbnRDb25maWcge1xuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGZpZWxkOiBMb29rdXBGaWVsZDtcbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBmb3JtQ29udHJvbDogRm9ybUNvbnRyb2w7XG59XG4iXX0=