@design-system-rte/angular 0.11.0 → 0.12.0

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.
@@ -1,8 +1,9 @@
1
1
  import { ChangeDetectorRef, Directive, ElementRef, HostListener, inject, input, Renderer2, ViewContainerRef, } from "@angular/core";
2
- import { getAutoPlacement } from "@design-system-rte/core/components/utils/auto-placement";
2
+ import { TOOLTIP_GAP, TOOLTIP_GAP_ARROW } from "@design-system-rte/core/components/tooltip/tooltip.constants";
3
+ import { getAutoPlacement, getCoordinates } from "@design-system-rte/core/components/utils/auto-placement";
4
+ import { OverlayService } from "../../services/overlay.service";
3
5
  import { TooltipComponent } from "./tooltip.component";
4
6
  import * as i0 from "@angular/core";
5
- const TOOLTIP_GAP = 8;
6
7
  export class TooltipDirective {
7
8
  onMouseEnter() {
8
9
  this.showTooltip();
@@ -26,29 +27,29 @@ export class TooltipDirective {
26
27
  this.viewContainerRef = inject(ViewContainerRef);
27
28
  this.renderer = inject(Renderer2);
28
29
  this.cdr = inject(ChangeDetectorRef);
30
+ this.overlayService = inject(OverlayService);
29
31
  this.hostElement = this.elementRef.nativeElement;
30
32
  this.hostElement.setAttribute("tabindex", "0");
31
33
  }
34
+ ngAfterViewInit() {
35
+ window.addEventListener("scroll", this.positionTooltip.bind(this));
36
+ }
37
+ ngOnDestroy() {
38
+ window.removeEventListener("scroll", this.positionTooltip.bind(this));
39
+ }
32
40
  showTooltip() {
33
41
  if (this.tooltipRef) {
34
42
  this.tooltipRef.destroy();
35
43
  }
36
- this.tooltipRef = this.viewContainerRef.createComponent(TooltipComponent);
44
+ this.tooltipRef = this.overlayService.create(TooltipComponent, this.viewContainerRef);
37
45
  this.assignDirectiveToComponent();
38
- this.appendComponentToHost();
39
- this.cdr.detectChanges();
40
- if (this.tooltipRef) {
41
- const tooltipElement = this.tooltipRef.location.nativeElement;
42
- this.renderer.setStyle(tooltipElement, "opacity", "0");
43
- this.positionTooltip();
44
- this.renderer.setStyle(tooltipElement, "opacity", "1");
45
- }
46
+ this.positionTooltip();
46
47
  }
47
48
  assignDirectiveToComponent() {
48
49
  if (this.tooltipRef) {
49
50
  const tooltipElement = this.tooltipRef.location.nativeElement;
50
51
  const position = this.rteTooltipPosition() === "auto"
51
- ? getAutoPlacement(this.hostElement, tooltipElement, "top")
52
+ ? getAutoPlacement(this.hostElement, tooltipElement, "top", this.rteTooltipArrow() ? TOOLTIP_GAP_ARROW : TOOLTIP_GAP)
52
53
  : this.rteTooltipPosition();
53
54
  this.tooltipRef.setInput("label", this.rteTooltip());
54
55
  this.tooltipRef.setInput("position", position);
@@ -56,57 +57,14 @@ export class TooltipDirective {
56
57
  this.tooltipRef.setInput("arrow", this.rteTooltipArrow());
57
58
  }
58
59
  }
59
- appendComponentToHost() {
60
- if (this.tooltipRef) {
61
- this.renderer.appendChild(this.elementRef.nativeElement, this.tooltipRef.location.nativeElement);
62
- }
63
- }
64
60
  positionTooltip() {
65
61
  if (this.tooltipRef) {
66
62
  const tooltipElement = this.tooltipRef.location.nativeElement;
67
- const bounds = this.getTooltipPosition(this.hostElement, this.tooltipRef);
63
+ const positions = getCoordinates(this.tooltipRef.instance.position(), this.hostElement, tooltipElement, this.rteTooltipArrow() ? TOOLTIP_GAP_ARROW : TOOLTIP_GAP);
68
64
  this.renderer.setStyle(this.hostElement, "position", "relative");
69
- this.renderer.setStyle(tooltipElement, bounds.x.position, `${bounds.x.offset}px`);
70
- this.renderer.setStyle(tooltipElement, bounds.y.position, `${bounds.y.offset}px`);
71
- }
72
- }
73
- getTooltipPosition(host, tooltip) {
74
- return {
75
- x: this.getTooltipXBound(host, tooltip),
76
- y: this.getTooltipYBound(host, tooltip),
77
- };
78
- }
79
- getTooltipXBound(host, tooltip) {
80
- return {
81
- position: tooltip.instance.position() === "right" ? "right" : "left",
82
- offset: this.getTooltipXOffset(host, tooltip),
83
- };
84
- }
85
- getTooltipXOffset(host, tooltip) {
86
- const hostRect = host.getBoundingClientRect();
87
- if (tooltip.instance.position() === "left") {
88
- return -tooltip.location.nativeElement.querySelector(".tooltip").offsetWidth - TOOLTIP_GAP;
89
- }
90
- if (tooltip.instance.position() === "right") {
91
- return -TOOLTIP_GAP;
92
- }
93
- return hostRect.width / 2;
94
- }
95
- getTooltipYBound(host, tooltip) {
96
- return {
97
- position: tooltip.instance.position() === "bottom" ? "bottom" : "top",
98
- offset: this.getTooltipYOffset(host, tooltip),
99
- };
100
- }
101
- getTooltipYOffset(host, tooltip) {
102
- const hostRect = host.getBoundingClientRect();
103
- if (tooltip.instance.position() === "top") {
104
- return -tooltip.location.nativeElement.querySelector(".tooltip").offsetHeight - TOOLTIP_GAP;
105
- }
106
- if (tooltip.instance.position() === "bottom") {
107
- return -TOOLTIP_GAP;
65
+ this.renderer.setStyle(tooltipElement, "top", `${positions.top}px`);
66
+ this.renderer.setStyle(tooltipElement, "left", `${positions.left}px`);
108
67
  }
109
- return hostRect.height / 2;
110
68
  }
111
69
  hideTooltip() {
112
70
  if (this.tooltipRef) {
@@ -116,6 +74,7 @@ export class TooltipDirective {
116
74
  if (this.tooltipRef) {
117
75
  this.tooltipRef.destroy();
118
76
  this.tooltipRef = null;
77
+ this.overlayService.destroy();
119
78
  }
120
79
  }, 200);
121
80
  }
@@ -142,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
142
101
  type: HostListener,
143
102
  args: ["blur"]
144
103
  }] } });
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/ds-rte-lib/src/lib/components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  inject,\n  input,\n  Renderer2,\n  ViewContainerRef,\n} from \"@angular/core\";\nimport { getAutoPlacement } from \"@design-system-rte/core/components/utils/auto-placement\";\n\nimport { TooltipComponent } from \"./tooltip.component\";\n\ninterface TooltipXBound {\n  position: \"left\" | \"right\";\n  offset: number;\n}\n\ninterface TooltipYBound {\n  position: \"top\" | \"bottom\";\n  offset: number;\n}\n\ninterface TooltipBounds {\n  x: TooltipXBound;\n  y: TooltipYBound;\n}\n\nconst TOOLTIP_GAP = 8;\n\n@Directive({\n  selector: \"[rteTooltip]\",\n  standalone: true,\n})\nexport class TooltipDirective {\n  readonly rteTooltip = input.required<string>();\n  readonly rteTooltipPosition = input(\"auto\");\n  readonly rteTooltipAlignment = input(\"center\");\n  readonly rteTooltipArrow = input(true);\n\n  private tooltipRef: ComponentRef<TooltipComponent> | null = null;\n  private hostElement: HTMLElement;\n\n  private elementRef = inject(ElementRef);\n  private viewContainerRef = inject(ViewContainerRef);\n  private renderer = inject(Renderer2);\n  private cdr = inject(ChangeDetectorRef);\n\n  @HostListener(\"mouseenter\")\n  onMouseEnter(): void {\n    this.showTooltip();\n  }\n\n  @HostListener(\"mouseleave\")\n  onMouseLeave(): void {\n    this.hideTooltip();\n  }\n\n  @HostListener(\"focus\")\n  onFocus(): void {\n    this.showTooltip();\n  }\n\n  @HostListener(\"blur\")\n  onBlur(): void {\n    this.hideTooltip();\n  }\n\n  constructor() {\n    this.hostElement = this.elementRef.nativeElement;\n    this.hostElement.setAttribute(\"tabindex\", \"0\");\n  }\n\n  showTooltip(): void {\n    if (this.tooltipRef) {\n      this.tooltipRef.destroy();\n    }\n\n    this.tooltipRef = this.viewContainerRef.createComponent(TooltipComponent);\n    this.assignDirectiveToComponent();\n    this.appendComponentToHost();\n    this.cdr.detectChanges();\n\n    if (this.tooltipRef) {\n      const tooltipElement = this.tooltipRef.location.nativeElement;\n      this.renderer.setStyle(tooltipElement, \"opacity\", \"0\");\n      this.positionTooltip();\n\n      this.renderer.setStyle(tooltipElement, \"opacity\", \"1\");\n    }\n  }\n\n  private assignDirectiveToComponent(): void {\n    if (this.tooltipRef) {\n      const tooltipElement = this.tooltipRef.location.nativeElement;\n      const position =\n        this.rteTooltipPosition() === \"auto\"\n          ? getAutoPlacement(this.hostElement, tooltipElement, \"top\")\n          : this.rteTooltipPosition();\n\n      this.tooltipRef.setInput(\"label\", this.rteTooltip());\n      this.tooltipRef.setInput(\"position\", position);\n      this.tooltipRef.setInput(\"alignment\", this.rteTooltipAlignment());\n      this.tooltipRef.setInput(\"arrow\", this.rteTooltipArrow());\n    }\n  }\n\n  private appendComponentToHost(): void {\n    if (this.tooltipRef) {\n      this.renderer.appendChild(this.elementRef.nativeElement, this.tooltipRef.location.nativeElement);\n    }\n  }\n\n  private positionTooltip(): void {\n    if (this.tooltipRef) {\n      const tooltipElement = this.tooltipRef.location.nativeElement;\n\n      const bounds = this.getTooltipPosition(this.hostElement, this.tooltipRef);\n\n      this.renderer.setStyle(this.hostElement, \"position\", \"relative\");\n\n      this.renderer.setStyle(tooltipElement, bounds.x.position, `${bounds.x.offset}px`);\n      this.renderer.setStyle(tooltipElement, bounds.y.position, `${bounds.y.offset}px`);\n    }\n  }\n\n  private getTooltipPosition(host: HTMLElement, tooltip: ComponentRef<TooltipComponent>): TooltipBounds {\n    return {\n      x: this.getTooltipXBound(host, tooltip),\n      y: this.getTooltipYBound(host, tooltip),\n    };\n  }\n\n  private getTooltipXBound(host: HTMLElement, tooltip: ComponentRef<TooltipComponent>): TooltipXBound {\n    return {\n      position: tooltip.instance.position() === \"right\" ? \"right\" : \"left\",\n      offset: this.getTooltipXOffset(host, tooltip),\n    };\n  }\n\n  private getTooltipXOffset(host: HTMLElement, tooltip: ComponentRef<TooltipComponent>): number {\n    const hostRect = host.getBoundingClientRect();\n    if (tooltip.instance.position() === \"left\") {\n      return -tooltip.location.nativeElement.querySelector(\".tooltip\").offsetWidth - TOOLTIP_GAP;\n    }\n    if (tooltip.instance.position() === \"right\") {\n      return -TOOLTIP_GAP;\n    }\n    return hostRect.width / 2;\n  }\n\n  private getTooltipYBound(host: HTMLElement, tooltip: ComponentRef<TooltipComponent>): TooltipYBound {\n    return {\n      position: tooltip.instance.position() === \"bottom\" ? \"bottom\" : \"top\",\n      offset: this.getTooltipYOffset(host, tooltip),\n    };\n  }\n\n  private getTooltipYOffset(host: HTMLElement, tooltip: ComponentRef<TooltipComponent>): number {\n    const hostRect = host.getBoundingClientRect();\n\n    if (tooltip.instance.position() === \"top\") {\n      return -tooltip.location.nativeElement.querySelector(\".tooltip\").offsetHeight - TOOLTIP_GAP;\n    }\n    if (tooltip.instance.position() === \"bottom\") {\n      return -TOOLTIP_GAP;\n    }\n    return hostRect.height / 2;\n  }\n\n  private hideTooltip(): void {\n    if (this.tooltipRef) {\n      const tooltipElement = this.tooltipRef.location.nativeElement;\n\n      this.renderer.setStyle(tooltipElement, \"opacity\", \"0\");\n\n      setTimeout(() => {\n        if (this.tooltipRef) {\n          this.tooltipRef.destroy();\n          this.tooltipRef = null;\n        }\n      }, 200);\n    }\n  }\n}\n"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/ds-rte-lib/src/lib/components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EAEjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,SAAS,EACT,gBAAgB,GACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,8DAA8D,CAAC;AAC9G,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,yDAAyD,CAAC;AAE3G,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAEhE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;AAMvD,MAAM,OAAO,gBAAgB;IAgB3B,YAAY;QACV,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAGD,YAAY;QACV,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAGD,OAAO;QACL,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAGD,MAAM;QACJ,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED;QAlCS,eAAU,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;QACtC,uBAAkB,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;QACnC,wBAAmB,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC;QACtC,oBAAe,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QAE/B,eAAU,GAA0C,IAAI,CAAC;QAIzD,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAChC,qBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAC5C,aAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAC7B,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAuBtC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAC7C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACjD,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;IACjD,CAAC;IAED,eAAe;QACb,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACrE,CAAC;IAED,WAAW;QACT,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;QAC5B,CAAC;QAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACtF,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAEO,0BAA0B;QAChC,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,aAAa,CAAC;YAE9D,MAAM,QAAQ,GACZ,IAAI,CAAC,kBAAkB,EAAE,KAAK,MAAM;gBAClC,CAAC,CAAC,gBAAgB,CACd,IAAI,CAAC,WAAW,EAChB,cAAc,EACd,KAAK,EACL,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,WAAW,CACzD;gBACH,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAEhC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;YACrD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;YAC/C,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC;YAClE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;IAEO,eAAe;QACrB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,aAAa,CAAC;YAE9D,MAAM,SAAS,GAAG,cAAc,CAC9B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,QAAQ,EAAE,EACnC,IAAI,CAAC,WAAW,EAChB,cAAc,EACd,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,WAAW,CACzD,CAAC;YAEF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;YAEjE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,cAAc,EAAE,KAAK,EAAE,GAAG,SAAS,CAAC,GAAG,IAAI,CAAC,CAAC;YACpE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC,IAAI,IAAI,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IAEO,WAAW;QACjB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,aAAa,CAAC;YAE9D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,cAAc,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;YAEvD,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;oBACpB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;oBAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;oBACvB,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;gBAChC,CAAC;YACH,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC;IACH,CAAC;+GAhHU,gBAAgB;mGAAhB,gBAAgB;;4FAAhB,gBAAgB;kBAJ5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;oBACxB,UAAU,EAAE,IAAI;iBACjB;wDAiBC,YAAY;sBADX,YAAY;uBAAC,YAAY;gBAM1B,YAAY;sBADX,YAAY;uBAAC,YAAY;gBAM1B,OAAO;sBADN,YAAY;uBAAC,OAAO;gBAMrB,MAAM;sBADL,YAAY;uBAAC,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  inject,\n  input,\n  OnDestroy,\n  Renderer2,\n  ViewContainerRef,\n} from \"@angular/core\";\nimport { TOOLTIP_GAP, TOOLTIP_GAP_ARROW } from \"@design-system-rte/core/components/tooltip/tooltip.constants\";\nimport { getAutoPlacement, getCoordinates } from \"@design-system-rte/core/components/utils/auto-placement\";\n\nimport { OverlayService } from \"../../services/overlay.service\";\n\nimport { TooltipComponent } from \"./tooltip.component\";\n\n@Directive({\n  selector: \"[rteTooltip]\",\n  standalone: true,\n})\nexport class TooltipDirective implements AfterViewInit, OnDestroy {\n  readonly rteTooltip = input.required<string>();\n  readonly rteTooltipPosition = input(\"auto\");\n  readonly rteTooltipAlignment = input(\"center\");\n  readonly rteTooltipArrow = input(true);\n\n  private tooltipRef: ComponentRef<TooltipComponent> | null = null;\n  private hostElement: HTMLElement;\n  private overlayService: OverlayService;\n\n  private elementRef = inject(ElementRef);\n  private viewContainerRef = inject(ViewContainerRef);\n  private renderer = inject(Renderer2);\n  private cdr = inject(ChangeDetectorRef);\n\n  @HostListener(\"mouseenter\")\n  onMouseEnter(): void {\n    this.showTooltip();\n  }\n\n  @HostListener(\"mouseleave\")\n  onMouseLeave(): void {\n    this.hideTooltip();\n  }\n\n  @HostListener(\"focus\")\n  onFocus(): void {\n    this.showTooltip();\n  }\n\n  @HostListener(\"blur\")\n  onBlur(): void {\n    this.hideTooltip();\n  }\n\n  constructor() {\n    this.overlayService = inject(OverlayService);\n    this.hostElement = this.elementRef.nativeElement;\n    this.hostElement.setAttribute(\"tabindex\", \"0\");\n  }\n\n  ngAfterViewInit() {\n    window.addEventListener(\"scroll\", this.positionTooltip.bind(this));\n  }\n\n  ngOnDestroy() {\n    window.removeEventListener(\"scroll\", this.positionTooltip.bind(this));\n  }\n\n  showTooltip(): void {\n    if (this.tooltipRef) {\n      this.tooltipRef.destroy();\n    }\n\n    this.tooltipRef = this.overlayService.create(TooltipComponent, this.viewContainerRef);\n    this.assignDirectiveToComponent();\n    this.positionTooltip();\n  }\n\n  private assignDirectiveToComponent(): void {\n    if (this.tooltipRef) {\n      const tooltipElement = this.tooltipRef.location.nativeElement;\n\n      const position =\n        this.rteTooltipPosition() === \"auto\"\n          ? getAutoPlacement(\n              this.hostElement,\n              tooltipElement,\n              \"top\",\n              this.rteTooltipArrow() ? TOOLTIP_GAP_ARROW : TOOLTIP_GAP,\n            )\n          : this.rteTooltipPosition();\n\n      this.tooltipRef.setInput(\"label\", this.rteTooltip());\n      this.tooltipRef.setInput(\"position\", position);\n      this.tooltipRef.setInput(\"alignment\", this.rteTooltipAlignment());\n      this.tooltipRef.setInput(\"arrow\", this.rteTooltipArrow());\n    }\n  }\n\n  private positionTooltip(): void {\n    if (this.tooltipRef) {\n      const tooltipElement = this.tooltipRef.location.nativeElement;\n\n      const positions = getCoordinates(\n        this.tooltipRef.instance.position(),\n        this.hostElement,\n        tooltipElement,\n        this.rteTooltipArrow() ? TOOLTIP_GAP_ARROW : TOOLTIP_GAP,\n      );\n\n      this.renderer.setStyle(this.hostElement, \"position\", \"relative\");\n\n      this.renderer.setStyle(tooltipElement, \"top\", `${positions.top}px`);\n      this.renderer.setStyle(tooltipElement, \"left\", `${positions.left}px`);\n    }\n  }\n\n  private hideTooltip(): void {\n    if (this.tooltipRef) {\n      const tooltipElement = this.tooltipRef.location.nativeElement;\n\n      this.renderer.setStyle(tooltipElement, \"opacity\", \"0\");\n\n      setTimeout(() => {\n        if (this.tooltipRef) {\n          this.tooltipRef.destroy();\n          this.tooltipRef = null;\n          this.overlayService.destroy();\n        }\n      }, 200);\n    }\n  }\n}\n"]}
@@ -0,0 +1,51 @@
1
+ // overlay.service.ts
2
+ import { Injectable } from "@angular/core";
3
+ import * as i0 from "@angular/core";
4
+ export class OverlayService {
5
+ constructor() {
6
+ this.activeOverlays = new Set();
7
+ }
8
+ getOverlayRoot() {
9
+ if (!this.overlayRoot) {
10
+ this.overlayRoot = document.getElementById("overlay-root");
11
+ if (!this.overlayRoot) {
12
+ this.overlayRoot = document.createElement("div");
13
+ this.overlayRoot.id = "overlay-root";
14
+ this.overlayRoot.style.position = "fixed";
15
+ this.overlayRoot.style.top = "0";
16
+ this.overlayRoot.style.left = "0";
17
+ this.overlayRoot.style.width = "100%";
18
+ this.overlayRoot.style.height = "100%";
19
+ this.overlayRoot.style.pointerEvents = "none";
20
+ this.overlayRoot.style.zIndex = "1000";
21
+ document.body.appendChild(this.overlayRoot);
22
+ }
23
+ }
24
+ return this.overlayRoot;
25
+ }
26
+ create(component, viewContainer) {
27
+ const root = this.getOverlayRoot();
28
+ const componentRef = viewContainer.createComponent(component);
29
+ root.appendChild(componentRef.location.nativeElement);
30
+ this.activeOverlays.add(componentRef);
31
+ const originalDestroy = componentRef.destroy.bind(componentRef);
32
+ componentRef.destroy = () => {
33
+ this.activeOverlays.delete(componentRef);
34
+ originalDestroy();
35
+ };
36
+ return componentRef;
37
+ }
38
+ destroy() {
39
+ if (this.activeOverlays.size === 0) {
40
+ this.overlayRoot?.remove();
41
+ this.overlayRoot = undefined;
42
+ }
43
+ }
44
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: OverlayService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
45
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: OverlayService, providedIn: "root" }); }
46
+ }
47
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: OverlayService, decorators: [{
48
+ type: Injectable,
49
+ args: [{ providedIn: "root" }]
50
+ }], ctorParameters: () => [] });
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHMtcnRlLWxpYi9zcmMvbGliL3NlcnZpY2VzL292ZXJsYXkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxxQkFBcUI7QUFDckIsT0FBTyxFQUFFLFVBQVUsRUFBd0MsTUFBTSxlQUFlLENBQUM7O0FBR2pGLE1BQU0sT0FBTyxjQUFjO0lBSXpCO1FBRlEsbUJBQWMsR0FBRyxJQUFJLEdBQUcsRUFBeUIsQ0FBQztJQUUzQyxDQUFDO0lBRVIsY0FBYztRQUNwQixJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDLGNBQWMsQ0FBQyxjQUFjLENBQWdCLENBQUM7WUFFMUUsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztnQkFDdEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUNqRCxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQUUsR0FBRyxjQUFjLENBQUM7Z0JBQ3JDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLFFBQVEsR0FBRyxPQUFPLENBQUM7Z0JBQzFDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7Z0JBQ2pDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxHQUFHLENBQUM7Z0JBQ2xDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUM7Z0JBQ3RDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7Z0JBQ3ZDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUM7Z0JBQzlDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7Z0JBQ3ZDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUM5QyxDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBRUQsTUFBTSxDQUFJLFNBQWtCLEVBQUUsYUFBK0I7UUFDM0QsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBRW5DLE1BQU0sWUFBWSxHQUFHLGFBQWEsQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLENBQUM7UUFFOUQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3RELElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRXRDLE1BQU0sZUFBZSxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ2hFLFlBQVksQ0FBQyxPQUFPLEdBQUcsR0FBRyxFQUFFO1lBQzFCLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQ3pDLGVBQWUsRUFBRSxDQUFDO1FBQ3BCLENBQUMsQ0FBQztRQUVGLE9BQU8sWUFBWSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUNuQyxJQUFJLENBQUMsV0FBVyxFQUFFLE1BQU0sRUFBRSxDQUFDO1lBQzNCLElBQUksQ0FBQyxXQUFXLEdBQUcsU0FBUyxDQUFDO1FBQy9CLENBQUM7SUFDSCxDQUFDOytHQWhEVSxjQUFjO21IQUFkLGNBQWMsY0FERCxNQUFNOzs0RkFDbkIsY0FBYztrQkFEMUIsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBvdmVybGF5LnNlcnZpY2UudHNcbmltcG9ydCB7IEluamVjdGFibGUsIENvbXBvbmVudFJlZiwgVHlwZSwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogXCJyb290XCIgfSlcbmV4cG9ydCBjbGFzcyBPdmVybGF5U2VydmljZSB7XG4gIHByaXZhdGUgb3ZlcmxheVJvb3Q/OiBIVE1MRWxlbWVudDtcbiAgcHJpdmF0ZSBhY3RpdmVPdmVybGF5cyA9IG5ldyBTZXQ8Q29tcG9uZW50UmVmPHVua25vd24+PigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBwcml2YXRlIGdldE92ZXJsYXlSb290KCk6IEhUTUxFbGVtZW50IHtcbiAgICBpZiAoIXRoaXMub3ZlcmxheVJvb3QpIHtcbiAgICAgIHRoaXMub3ZlcmxheVJvb3QgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcIm92ZXJsYXktcm9vdFwiKSBhcyBIVE1MRWxlbWVudDtcblxuICAgICAgaWYgKCF0aGlzLm92ZXJsYXlSb290KSB7XG4gICAgICAgIHRoaXMub3ZlcmxheVJvb3QgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiZGl2XCIpO1xuICAgICAgICB0aGlzLm92ZXJsYXlSb290LmlkID0gXCJvdmVybGF5LXJvb3RcIjtcbiAgICAgICAgdGhpcy5vdmVybGF5Um9vdC5zdHlsZS5wb3NpdGlvbiA9IFwiZml4ZWRcIjtcbiAgICAgICAgdGhpcy5vdmVybGF5Um9vdC5zdHlsZS50b3AgPSBcIjBcIjtcbiAgICAgICAgdGhpcy5vdmVybGF5Um9vdC5zdHlsZS5sZWZ0ID0gXCIwXCI7XG4gICAgICAgIHRoaXMub3ZlcmxheVJvb3Quc3R5bGUud2lkdGggPSBcIjEwMCVcIjtcbiAgICAgICAgdGhpcy5vdmVybGF5Um9vdC5zdHlsZS5oZWlnaHQgPSBcIjEwMCVcIjtcbiAgICAgICAgdGhpcy5vdmVybGF5Um9vdC5zdHlsZS5wb2ludGVyRXZlbnRzID0gXCJub25lXCI7XG4gICAgICAgIHRoaXMub3ZlcmxheVJvb3Quc3R5bGUuekluZGV4ID0gXCIxMDAwXCI7XG4gICAgICAgIGRvY3VtZW50LmJvZHkuYXBwZW5kQ2hpbGQodGhpcy5vdmVybGF5Um9vdCk7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB0aGlzLm92ZXJsYXlSb290O1xuICB9XG5cbiAgY3JlYXRlPFQ+KGNvbXBvbmVudDogVHlwZTxUPiwgdmlld0NvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZik6IENvbXBvbmVudFJlZjxUPiB7XG4gICAgY29uc3Qgcm9vdCA9IHRoaXMuZ2V0T3ZlcmxheVJvb3QoKTtcblxuICAgIGNvbnN0IGNvbXBvbmVudFJlZiA9IHZpZXdDb250YWluZXIuY3JlYXRlQ29tcG9uZW50KGNvbXBvbmVudCk7XG5cbiAgICByb290LmFwcGVuZENoaWxkKGNvbXBvbmVudFJlZi5sb2NhdGlvbi5uYXRpdmVFbGVtZW50KTtcbiAgICB0aGlzLmFjdGl2ZU92ZXJsYXlzLmFkZChjb21wb25lbnRSZWYpO1xuXG4gICAgY29uc3Qgb3JpZ2luYWxEZXN0cm95ID0gY29tcG9uZW50UmVmLmRlc3Ryb3kuYmluZChjb21wb25lbnRSZWYpO1xuICAgIGNvbXBvbmVudFJlZi5kZXN0cm95ID0gKCkgPT4ge1xuICAgICAgdGhpcy5hY3RpdmVPdmVybGF5cy5kZWxldGUoY29tcG9uZW50UmVmKTtcbiAgICAgIG9yaWdpbmFsRGVzdHJveSgpO1xuICAgIH07XG5cbiAgICByZXR1cm4gY29tcG9uZW50UmVmO1xuICB9XG5cbiAgZGVzdHJveSgpIHtcbiAgICBpZiAodGhpcy5hY3RpdmVPdmVybGF5cy5zaXplID09PSAwKSB7XG4gICAgICB0aGlzLm92ZXJsYXlSb290Py5yZW1vdmUoKTtcbiAgICAgIHRoaXMub3ZlcmxheVJvb3QgPSB1bmRlZmluZWQ7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -18,4 +18,5 @@ export * from "./lib/components/textarea/textarea.component";
18
18
  export * from "./lib/components/divider/divider.component";
19
19
  export * from "./lib/components/switch/switch.component";
20
20
  export * from "./lib/components/segmented-control/segmented-control.component";
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RzLXJ0ZS1saWIvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsa0VBQWtFLENBQUM7QUFDakYsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLDBEQUEwRCxDQUFDO0FBQ3pFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxrRUFBa0UsQ0FBQztBQUNqRixjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLGdFQUFnRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2dyaWQvZ3JpZC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2dyaWQvY29sL2NvbC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2xpbmsvbGluay5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9yYWRpby1idXR0b24tZ3JvdXAvcmFkaW8tYnV0dG9uLWdyb3VwLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9jaGVja2JveC1ncm91cC9jaGVja2JveC1ncm91cC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2ljb24vaWNvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3Rvb2x0aXAvdG9vbHRpcC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3NwbGl0LWJ1dHRvbi9zcGxpdC1idXR0b24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9pY29uLWJ1dHRvbi9pY29uLWJ1dHRvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2ljb24tYnV0dG9uLXRvZ2dsZS9pY29uLWJ1dHRvbi10b2dnbGUuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy90ZXh0LWlucHV0L3RleHQtaW5wdXQuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9jaGlwL2NoaXAuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9iYWRnZS9iYWRnZS5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3RleHRhcmVhL3RleHRhcmVhLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvZGl2aWRlci9kaXZpZGVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvc3dpdGNoL3N3aXRjaC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3NlZ21lbnRlZC1jb250cm9sL3NlZ21lbnRlZC1jb250cm9sLmNvbXBvbmVudFwiO1xuIl19
21
+ export * from "./lib/components/breadcrumbs/breadcrumbs.component";
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RzLXJ0ZS1saWIvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsa0VBQWtFLENBQUM7QUFDakYsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLDBEQUEwRCxDQUFDO0FBQ3pFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxrRUFBa0UsQ0FBQztBQUNqRixjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsb0RBQW9ELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9idXR0b24vYnV0dG9uLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvZ3JpZC9ncmlkLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvZ3JpZC9jb2wvY29sLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvbGluay9saW5rLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3JhZGlvLWJ1dHRvbi1ncm91cC9yYWRpby1idXR0b24tZ3JvdXAuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2NoZWNrYm94LWdyb3VwL2NoZWNrYm94LWdyb3VwLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvaWNvbi9pY29uLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvdG9vbHRpcC90b29sdGlwLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvc3BsaXQtYnV0dG9uL3NwbGl0LWJ1dHRvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2ljb24tYnV0dG9uL2ljb24tYnV0dG9uLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvaWNvbi1idXR0b24tdG9nZ2xlL2ljb24tYnV0dG9uLXRvZ2dsZS5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3RleHQtaW5wdXQvdGV4dC1pbnB1dC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2NoaXAvY2hpcC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2JhZGdlL2JhZGdlLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvdGV4dGFyZWEvdGV4dGFyZWEuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9kaXZpZGVyL2RpdmlkZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvc2VnbWVudGVkLWNvbnRyb2wvc2VnbWVudGVkLWNvbnRyb2wuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9icmVhZGNydW1icy9icmVhZGNydW1icy5jb21wb25lbnRcIjtcbiJdfQ==