@design-system-rte/angular 0.14.0 → 0.16.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.
Files changed (52) hide show
  1. package/esm2022/lib/components/banner/banner.component.mjs +3 -3
  2. package/esm2022/lib/components/breadcrumbs/breadcrumb-item/breadcrumb-item.component.mjs +38 -0
  3. package/esm2022/lib/components/breadcrumbs/breadcrumbs.component.mjs +5 -4
  4. package/esm2022/lib/components/button/button.component.mjs +12 -17
  5. package/esm2022/lib/components/checkbox/checkbox.component.mjs +3 -3
  6. package/esm2022/lib/components/checkbox-group/checkbox-group.component.mjs +3 -3
  7. package/esm2022/lib/components/divider/divider.component.mjs +3 -3
  8. package/esm2022/lib/components/dropdown/dropdown-trigger/dropdown-trigger.directive.mjs +11 -3
  9. package/esm2022/lib/components/dropdown/dropdown.directive.mjs +12 -13
  10. package/esm2022/lib/components/dropdown/dropdown.utils.mjs +40 -0
  11. package/esm2022/lib/components/icon-button/icon-button.component.mjs +13 -3
  12. package/esm2022/lib/components/icon-button-toggle/icon-button-toggle.component.mjs +1 -1
  13. package/esm2022/lib/components/link/link.component.mjs +5 -3
  14. package/esm2022/lib/components/modal/modal-trigger/modal-trigger.directive.mjs +31 -0
  15. package/esm2022/lib/components/modal/modal.component.mjs +48 -0
  16. package/esm2022/lib/components/modal/modal.directive.mjs +118 -0
  17. package/esm2022/lib/components/modal/modal.module.mjs +17 -0
  18. package/esm2022/lib/components/popover/popover.component.mjs +11 -28
  19. package/esm2022/lib/components/radio-button/radio-button.component.mjs +3 -3
  20. package/esm2022/lib/components/radio-button-group/radio-button-group.component.mjs +3 -3
  21. package/esm2022/lib/components/split-button/split-button.component.mjs +31 -5
  22. package/esm2022/lib/components/text-input/text-input.component.mjs +3 -3
  23. package/esm2022/lib/components/textarea/textarea.component.mjs +3 -3
  24. package/esm2022/lib/components/tooltip/tooltip.directive.mjs +18 -3
  25. package/esm2022/lib/services/focus-trap.service.mjs +64 -0
  26. package/esm2022/lib/services/overlay.service.mjs +19 -4
  27. package/esm2022/public-api.mjs +4 -1
  28. package/fesm2022/design-system-rte-angular.mjs +1149 -774
  29. package/fesm2022/design-system-rte-angular.mjs.map +1 -1
  30. package/lib/components/breadcrumbs/breadcrumb-item/breadcrumb-item.component.d.ts +16 -0
  31. package/lib/components/breadcrumbs/breadcrumbs.component.d.ts +2 -1
  32. package/lib/components/button/button.component.d.ts +4 -12
  33. package/lib/components/chip/chip.component.d.ts +1 -1
  34. package/lib/components/dropdown/dropdown-trigger/dropdown-trigger.directive.d.ts +4 -1
  35. package/lib/components/dropdown/dropdown.directive.d.ts +3 -1
  36. package/lib/components/dropdown/dropdown.utils.d.ts +4 -0
  37. package/lib/components/icon-button/icon-button.component.d.ts +8 -2
  38. package/lib/components/icon-button-toggle/icon-button-toggle.component.d.ts +1 -1
  39. package/lib/components/link/link.component.d.ts +3 -1
  40. package/lib/components/modal/modal-trigger/modal-trigger.directive.d.ts +11 -0
  41. package/lib/components/modal/modal.component.d.ts +28 -0
  42. package/lib/components/modal/modal.directive.d.ts +40 -0
  43. package/lib/components/modal/modal.module.d.ts +8 -0
  44. package/lib/components/popover/popover.component.d.ts +5 -6
  45. package/lib/components/split-button/split-button.component.d.ts +11 -4
  46. package/lib/components/text-input/text-input.component.d.ts +1 -1
  47. package/lib/components/tooltip/tooltip.component.d.ts +1 -1
  48. package/lib/components/tooltip/tooltip.directive.d.ts +2 -1
  49. package/lib/services/focus-trap.service.d.ts +17 -0
  50. package/lib/services/overlay.service.d.ts +2 -1
  51. package/package.json +2 -2
  52. package/public-api.d.ts +3 -0
@@ -1,6 +1,7 @@
1
1
  import { ChangeDetectorRef, Directive, ElementRef, HostListener, inject, input, Renderer2, ViewContainerRef, } from "@angular/core";
2
2
  import { TOOLTIP_GAP, TOOLTIP_GAP_ARROW } from "@design-system-rte/core/components/tooltip/tooltip.constants";
3
3
  import { getAutoPlacement, getCoordinates } from "@design-system-rte/core/components/utils/auto-placement";
4
+ import { FOCUSABLE_ELEMENTS_QUERY } from "@design-system-rte/core/constants/dom/dom.constants";
4
5
  import { OverlayService } from "../../services/overlay.service";
5
6
  import { TooltipComponent } from "./tooltip.component";
6
7
  import * as i0 from "@angular/core";
@@ -22,6 +23,7 @@ export class TooltipDirective {
22
23
  this.rteTooltipPosition = input("auto");
23
24
  this.rteTooltipAlignment = input("center");
24
25
  this.rteTooltipArrow = input(true);
26
+ this.rteTooltipShouldFocusTrigger = input(true);
25
27
  this.tooltipRef = null;
26
28
  this.elementRef = inject(ElementRef);
27
29
  this.viewContainerRef = inject(ViewContainerRef);
@@ -29,12 +31,25 @@ export class TooltipDirective {
29
31
  this.cdr = inject(ChangeDetectorRef);
30
32
  this.overlayService = inject(OverlayService);
31
33
  this.hostElement = this.elementRef.nativeElement;
32
- this.hostElement.setAttribute("tabindex", "0");
33
34
  }
34
35
  ngAfterViewInit() {
36
+ if (!this.rteTooltipShouldFocusTrigger()) {
37
+ this.renderer.setAttribute(this.hostElement, "tabindex", "-1");
38
+ const focusableTrigger = this.hostElement.querySelectorAll(FOCUSABLE_ELEMENTS_QUERY)[0];
39
+ focusableTrigger.addEventListener("focus", () => this.onFocus());
40
+ focusableTrigger.addEventListener("blur", () => this.onBlur());
41
+ }
42
+ else {
43
+ this.renderer.setAttribute(this.hostElement, "tabindex", "0");
44
+ }
35
45
  window.addEventListener("scroll", this.positionTooltip.bind(this));
36
46
  }
37
47
  ngOnDestroy() {
48
+ if (!this.rteTooltipShouldFocusTrigger()) {
49
+ const focusableTrigger = this.hostElement.querySelectorAll(FOCUSABLE_ELEMENTS_QUERY)[0];
50
+ focusableTrigger.removeEventListener("focus", () => this.onFocus());
51
+ focusableTrigger.removeEventListener("blur", () => this.onBlur());
52
+ }
38
53
  window.removeEventListener("scroll", this.positionTooltip.bind(this));
39
54
  }
40
55
  showTooltip() {
@@ -80,7 +95,7 @@ export class TooltipDirective {
80
95
  }
81
96
  }
82
97
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TooltipDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
83
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.14", type: TooltipDirective, isStandalone: true, selector: "[rteTooltip]", inputs: { rteTooltip: { classPropertyName: "rteTooltip", publicName: "rteTooltip", isSignal: true, isRequired: true, transformFunction: null }, rteTooltipPosition: { classPropertyName: "rteTooltipPosition", publicName: "rteTooltipPosition", isSignal: true, isRequired: false, transformFunction: null }, rteTooltipAlignment: { classPropertyName: "rteTooltipAlignment", publicName: "rteTooltipAlignment", isSignal: true, isRequired: false, transformFunction: null }, rteTooltipArrow: { classPropertyName: "rteTooltipArrow", publicName: "rteTooltipArrow", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "focus": "onFocus()", "blur": "onBlur()" } }, ngImport: i0 }); }
98
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.14", type: TooltipDirective, isStandalone: true, selector: "[rteTooltip]", inputs: { rteTooltip: { classPropertyName: "rteTooltip", publicName: "rteTooltip", isSignal: true, isRequired: true, transformFunction: null }, rteTooltipPosition: { classPropertyName: "rteTooltipPosition", publicName: "rteTooltipPosition", isSignal: true, isRequired: false, transformFunction: null }, rteTooltipAlignment: { classPropertyName: "rteTooltipAlignment", publicName: "rteTooltipAlignment", isSignal: true, isRequired: false, transformFunction: null }, rteTooltipArrow: { classPropertyName: "rteTooltipArrow", publicName: "rteTooltipArrow", isSignal: true, isRequired: false, transformFunction: null }, rteTooltipShouldFocusTrigger: { classPropertyName: "rteTooltipShouldFocusTrigger", publicName: "rteTooltipShouldFocusTrigger", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "focus": "onFocus()", "blur": "onBlur()" } }, ngImport: i0 }); }
84
99
  }
85
100
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TooltipDirective, decorators: [{
86
101
  type: Directive,
@@ -101,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
101
116
  type: HostListener,
102
117
  args: ["blur"]
103
118
  }] } });
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":"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","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              true,\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"]}
119
+ //# 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  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\";\nimport { FOCUSABLE_ELEMENTS_QUERY } from \"@design-system-rte/core/constants/dom/dom.constants\";\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  readonly rteTooltipShouldFocusTrigger = 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  }\n\n  ngAfterViewInit() {\n    if (!this.rteTooltipShouldFocusTrigger()) {\n      this.renderer.setAttribute(this.hostElement, \"tabindex\", \"-1\");\n      const focusableTrigger = this.hostElement.querySelectorAll(FOCUSABLE_ELEMENTS_QUERY)[0];\n      focusableTrigger.addEventListener(\"focus\", () => this.onFocus());\n      focusableTrigger.addEventListener(\"blur\", () => this.onBlur());\n    } else {\n      this.renderer.setAttribute(this.hostElement, \"tabindex\", \"0\");\n    }\n    window.addEventListener(\"scroll\", this.positionTooltip.bind(this));\n  }\n\n  ngOnDestroy() {\n    if (!this.rteTooltipShouldFocusTrigger()) {\n      const focusableTrigger = this.hostElement.querySelectorAll(FOCUSABLE_ELEMENTS_QUERY)[0];\n      focusableTrigger.removeEventListener(\"focus\", () => this.onFocus());\n      focusableTrigger.removeEventListener(\"blur\", () => this.onBlur());\n    }\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              true,\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,64 @@
1
+ import { inject, Injectable, RendererFactory2 } from "@angular/core";
2
+ import { FOCUSABLE_ELEMENTS_QUERY } from "@design-system-rte/core/constants/dom/dom.constants";
3
+ import * as i0 from "@angular/core";
4
+ export class FocusTrapService {
5
+ constructor() {
6
+ this.activeTrapElement = null;
7
+ this.previouslyFocusedElement = null;
8
+ this.focusable = [];
9
+ this.rendererFactory = inject(RendererFactory2);
10
+ this.renderer = this.rendererFactory.createRenderer(null, null);
11
+ }
12
+ activate(element) {
13
+ this.previouslyFocusedElement = document.activeElement;
14
+ this.activeTrapElement = element;
15
+ this.focusable = this.getFocusableElements(element);
16
+ this.focusFirstElement();
17
+ this.keyUnlisten = this.renderer.listen(element, "keydown", (event) => {
18
+ if (event.key === "Tab") {
19
+ this.handleTab(event, this.focusable);
20
+ }
21
+ });
22
+ }
23
+ deactivate() {
24
+ if (this.keyUnlisten)
25
+ this.keyUnlisten();
26
+ this.keyUnlisten = undefined;
27
+ if (this.previouslyFocusedElement) {
28
+ this.previouslyFocusedElement.focus();
29
+ }
30
+ this.activeTrapElement = null;
31
+ }
32
+ focusFirstElement() {
33
+ if (!this.activeTrapElement)
34
+ return;
35
+ const focusable = this.activeTrapElement.querySelectorAll(FOCUSABLE_ELEMENTS_QUERY);
36
+ if (focusable.length > 0)
37
+ focusable[0].focus();
38
+ }
39
+ handleTab(event, focusable) {
40
+ if (!this.activeTrapElement || focusable.length === 0)
41
+ return;
42
+ const first = focusable[0];
43
+ const last = focusable[focusable.length - 1];
44
+ const current = document.activeElement;
45
+ if (event.shiftKey && current === first) {
46
+ last.focus();
47
+ event.preventDefault();
48
+ }
49
+ else if (!event.shiftKey && current === last) {
50
+ first.focus();
51
+ event.preventDefault();
52
+ }
53
+ }
54
+ getFocusableElements(container) {
55
+ return Array.from(container.querySelectorAll(FOCUSABLE_ELEMENTS_QUERY));
56
+ }
57
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FocusTrapService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
58
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FocusTrapService, providedIn: "root" }); }
59
+ }
60
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FocusTrapService, decorators: [{
61
+ type: Injectable,
62
+ args: [{ providedIn: "root" }]
63
+ }], ctorParameters: () => [] });
64
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9jdXMtdHJhcC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHMtcnRlLWxpYi9zcmMvbGliL3NlcnZpY2VzL2ZvY3VzLXRyYXAuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBYSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxxREFBcUQsQ0FBQzs7QUFHL0YsTUFBTSxPQUFPLGdCQUFnQjtJQVMzQjtRQU5RLHNCQUFpQixHQUF1QixJQUFJLENBQUM7UUFDN0MsNkJBQXdCLEdBQXVCLElBQUksQ0FBQztRQUNwRCxjQUFTLEdBQWtCLEVBQUUsQ0FBQztRQUU5QixvQkFBZSxHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBR2pELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ2xFLENBQUM7SUFFRCxRQUFRLENBQUMsT0FBb0I7UUFDM0IsSUFBSSxDQUFDLHdCQUF3QixHQUFHLFFBQVEsQ0FBQyxhQUE0QixDQUFDO1FBRXRFLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxPQUFPLENBQUM7UUFFakMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsb0JBQW9CLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFcEQsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFFekIsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsU0FBUyxFQUFFLENBQUMsS0FBb0IsRUFBRSxFQUFFO1lBQ25GLElBQUksS0FBSyxDQUFDLEdBQUcsS0FBSyxLQUFLLEVBQUUsQ0FBQztnQkFDeEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3hDLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxJQUFJLENBQUMsV0FBVztZQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUN6QyxJQUFJLENBQUMsV0FBVyxHQUFHLFNBQVMsQ0FBQztRQUU3QixJQUFJLElBQUksQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1lBQ2xDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN4QyxDQUFDO1FBRUQsSUFBSSxDQUFDLGlCQUFpQixHQUFHLElBQUksQ0FBQztJQUNoQyxDQUFDO0lBRU8saUJBQWlCO1FBQ3ZCLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCO1lBQUUsT0FBTztRQUVwQyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsZ0JBQWdCLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQUNwRixJQUFJLFNBQVMsQ0FBQyxNQUFNLEdBQUcsQ0FBQztZQUFHLFNBQVMsQ0FBQyxDQUFDLENBQWlCLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDbEUsQ0FBQztJQUVPLFNBQVMsQ0FBQyxLQUFvQixFQUFFLFNBQXdCO1FBQzlELElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLElBQUksU0FBUyxDQUFDLE1BQU0sS0FBSyxDQUFDO1lBQUUsT0FBTztRQUU5RCxNQUFNLEtBQUssR0FBRyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0IsTUFBTSxJQUFJLEdBQUcsU0FBUyxDQUFDLFNBQVMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFFN0MsTUFBTSxPQUFPLEdBQUcsUUFBUSxDQUFDLGFBQTRCLENBQUM7UUFFdEQsSUFBSSxLQUFLLENBQUMsUUFBUSxJQUFJLE9BQU8sS0FBSyxLQUFLLEVBQUUsQ0FBQztZQUN4QyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDYixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDekIsQ0FBQzthQUFNLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxJQUFJLE9BQU8sS0FBSyxJQUFJLEVBQUUsQ0FBQztZQUMvQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDZCxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDekIsQ0FBQztJQUNILENBQUM7SUFFTyxvQkFBb0IsQ0FBQyxTQUFzQjtRQUNqRCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLGdCQUFnQixDQUFjLHdCQUF3QixDQUFDLENBQUMsQ0FBQztJQUN2RixDQUFDOytHQWxFVSxnQkFBZ0I7bUhBQWhCLGdCQUFnQixjQURILE1BQU07OzRGQUNuQixnQkFBZ0I7a0JBRDVCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0LCBJbmplY3RhYmxlLCBSZW5kZXJlcjIsIFJlbmRlcmVyRmFjdG9yeTIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgRk9DVVNBQkxFX0VMRU1FTlRTX1FVRVJZIH0gZnJvbSBcIkBkZXNpZ24tc3lzdGVtLXJ0ZS9jb3JlL2NvbnN0YW50cy9kb20vZG9tLmNvbnN0YW50c1wiO1xuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46IFwicm9vdFwiIH0pXG5leHBvcnQgY2xhc3MgRm9jdXNUcmFwU2VydmljZSB7XG4gIHByaXZhdGUga2V5VW5saXN0ZW4/OiAoKSA9PiB2b2lkO1xuICBwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjI7XG4gIHByaXZhdGUgYWN0aXZlVHJhcEVsZW1lbnQ6IEhUTUxFbGVtZW50IHwgbnVsbCA9IG51bGw7XG4gIHByaXZhdGUgcHJldmlvdXNseUZvY3VzZWRFbGVtZW50OiBIVE1MRWxlbWVudCB8IG51bGwgPSBudWxsO1xuICBwcml2YXRlIGZvY3VzYWJsZTogSFRNTEVsZW1lbnRbXSA9IFtdO1xuXG4gIHByaXZhdGUgcmVuZGVyZXJGYWN0b3J5ID0gaW5qZWN0KFJlbmRlcmVyRmFjdG9yeTIpO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMucmVuZGVyZXIgPSB0aGlzLnJlbmRlcmVyRmFjdG9yeS5jcmVhdGVSZW5kZXJlcihudWxsLCBudWxsKTtcbiAgfVxuXG4gIGFjdGl2YXRlKGVsZW1lbnQ6IEhUTUxFbGVtZW50KSB7XG4gICAgdGhpcy5wcmV2aW91c2x5Rm9jdXNlZEVsZW1lbnQgPSBkb2N1bWVudC5hY3RpdmVFbGVtZW50IGFzIEhUTUxFbGVtZW50O1xuXG4gICAgdGhpcy5hY3RpdmVUcmFwRWxlbWVudCA9IGVsZW1lbnQ7XG5cbiAgICB0aGlzLmZvY3VzYWJsZSA9IHRoaXMuZ2V0Rm9jdXNhYmxlRWxlbWVudHMoZWxlbWVudCk7XG5cbiAgICB0aGlzLmZvY3VzRmlyc3RFbGVtZW50KCk7XG5cbiAgICB0aGlzLmtleVVubGlzdGVuID0gdGhpcy5yZW5kZXJlci5saXN0ZW4oZWxlbWVudCwgXCJrZXlkb3duXCIsIChldmVudDogS2V5Ym9hcmRFdmVudCkgPT4ge1xuICAgICAgaWYgKGV2ZW50LmtleSA9PT0gXCJUYWJcIikge1xuICAgICAgICB0aGlzLmhhbmRsZVRhYihldmVudCwgdGhpcy5mb2N1c2FibGUpO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgZGVhY3RpdmF0ZSgpIHtcbiAgICBpZiAodGhpcy5rZXlVbmxpc3RlbikgdGhpcy5rZXlVbmxpc3RlbigpO1xuICAgIHRoaXMua2V5VW5saXN0ZW4gPSB1bmRlZmluZWQ7XG5cbiAgICBpZiAodGhpcy5wcmV2aW91c2x5Rm9jdXNlZEVsZW1lbnQpIHtcbiAgICAgIHRoaXMucHJldmlvdXNseUZvY3VzZWRFbGVtZW50LmZvY3VzKCk7XG4gICAgfVxuXG4gICAgdGhpcy5hY3RpdmVUcmFwRWxlbWVudCA9IG51bGw7XG4gIH1cblxuICBwcml2YXRlIGZvY3VzRmlyc3RFbGVtZW50KCkge1xuICAgIGlmICghdGhpcy5hY3RpdmVUcmFwRWxlbWVudCkgcmV0dXJuO1xuXG4gICAgY29uc3QgZm9jdXNhYmxlID0gdGhpcy5hY3RpdmVUcmFwRWxlbWVudC5xdWVyeVNlbGVjdG9yQWxsKEZPQ1VTQUJMRV9FTEVNRU5UU19RVUVSWSk7XG4gICAgaWYgKGZvY3VzYWJsZS5sZW5ndGggPiAwKSAoZm9jdXNhYmxlWzBdIGFzIEhUTUxFbGVtZW50KS5mb2N1cygpO1xuICB9XG5cbiAgcHJpdmF0ZSBoYW5kbGVUYWIoZXZlbnQ6IEtleWJvYXJkRXZlbnQsIGZvY3VzYWJsZTogSFRNTEVsZW1lbnRbXSkge1xuICAgIGlmICghdGhpcy5hY3RpdmVUcmFwRWxlbWVudCB8fCBmb2N1c2FibGUubGVuZ3RoID09PSAwKSByZXR1cm47XG5cbiAgICBjb25zdCBmaXJzdCA9IGZvY3VzYWJsZVswXTtcbiAgICBjb25zdCBsYXN0ID0gZm9jdXNhYmxlW2ZvY3VzYWJsZS5sZW5ndGggLSAxXTtcblxuICAgIGNvbnN0IGN1cnJlbnQgPSBkb2N1bWVudC5hY3RpdmVFbGVtZW50IGFzIEhUTUxFbGVtZW50O1xuXG4gICAgaWYgKGV2ZW50LnNoaWZ0S2V5ICYmIGN1cnJlbnQgPT09IGZpcnN0KSB7XG4gICAgICBsYXN0LmZvY3VzKCk7XG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIH0gZWxzZSBpZiAoIWV2ZW50LnNoaWZ0S2V5ICYmIGN1cnJlbnQgPT09IGxhc3QpIHtcbiAgICAgIGZpcnN0LmZvY3VzKCk7XG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgZ2V0Rm9jdXNhYmxlRWxlbWVudHMoY29udGFpbmVyOiBIVE1MRWxlbWVudCk6IEhUTUxFbGVtZW50W10ge1xuICAgIHJldHVybiBBcnJheS5mcm9tKGNvbnRhaW5lci5xdWVyeVNlbGVjdG9yQWxsPEhUTUxFbGVtZW50PihGT0NVU0FCTEVfRUxFTUVOVFNfUVVFUlkpKTtcbiAgfVxufVxuIl19
@@ -3,20 +3,32 @@ import * as i0 from "@angular/core";
3
3
  export class OverlayService {
4
4
  constructor() {
5
5
  this.activeOverlays = new Set();
6
+ this.isNavigationFrozen = false;
6
7
  }
7
- getOverlayRoot() {
8
+ getOverlayRoot(freezeNavigation) {
8
9
  if (!this.overlayRoot) {
9
10
  this.overlayRoot = document.getElementById("overlay-root");
10
11
  if (!this.overlayRoot) {
11
12
  this.overlayRoot = document.createElement("div");
12
13
  this.overlayRoot.id = "overlay-root";
14
+ this.overlayRoot.tabIndex = -1;
15
+ if (freezeNavigation) {
16
+ this.isNavigationFrozen = true;
17
+ this.overlayRoot.style.position = "fixed";
18
+ this.overlayRoot.style.width = "100%";
19
+ this.overlayRoot.style.height = "100%";
20
+ this.overlayRoot.style.top = "0";
21
+ this.overlayRoot.style.left = "0";
22
+ this.overlayRoot.style.zIndex = "999";
23
+ document.body.style.overflow = "hidden";
24
+ }
13
25
  document.body.appendChild(this.overlayRoot);
14
26
  }
15
27
  }
16
28
  return this.overlayRoot;
17
29
  }
18
- create(component, viewContainer) {
19
- const root = this.getOverlayRoot();
30
+ create(component, viewContainer, freezeNavigation = false) {
31
+ const root = this.getOverlayRoot(freezeNavigation);
20
32
  const componentRef = viewContainer.createComponent(component);
21
33
  root.appendChild(componentRef.location.nativeElement);
22
34
  this.activeOverlays.add(componentRef);
@@ -29,6 +41,9 @@ export class OverlayService {
29
41
  }
30
42
  destroy() {
31
43
  if (this.activeOverlays.size === 0) {
44
+ if (this.isNavigationFrozen) {
45
+ document.body.style.overflow = "unset";
46
+ }
32
47
  this.overlayRoot?.remove();
33
48
  this.overlayRoot = undefined;
34
49
  }
@@ -40,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
40
55
  type: Injectable,
41
56
  args: [{ providedIn: "root" }]
42
57
  }], ctorParameters: () => [] });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHMtcnRlLWxpYi9zcmMvbGliL3NlcnZpY2VzL292ZXJsYXkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUF3QyxNQUFNLGVBQWUsQ0FBQzs7QUFHakYsTUFBTSxPQUFPLGNBQWM7SUFJekI7UUFGUSxtQkFBYyxHQUFHLElBQUksR0FBRyxFQUF5QixDQUFDO0lBRTNDLENBQUM7SUFFUixjQUFjO1FBQ3BCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDdEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FBZ0IsQ0FBQztZQUUxRSxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO2dCQUN0QixJQUFJLENBQUMsV0FBVyxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQ2pELElBQUksQ0FBQyxXQUFXLENBQUMsRUFBRSxHQUFHLGNBQWMsQ0FBQztnQkFDckMsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQzlDLENBQUM7UUFDSCxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQzFCLENBQUM7SUFFRCxNQUFNLENBQUksU0FBa0IsRUFBRSxhQUErQjtRQUMzRCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7UUFFbkMsTUFBTSxZQUFZLEdBQUcsYUFBYSxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUU5RCxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDLENBQUM7UUFFdEMsTUFBTSxlQUFlLEdBQUcsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDaEUsWUFBWSxDQUFDLE9BQU8sR0FBRyxHQUFHLEVBQUU7WUFDMUIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDekMsZUFBZSxFQUFFLENBQUM7UUFDcEIsQ0FBQyxDQUFDO1FBRUYsT0FBTyxZQUFZLENBQUM7SUFDdEIsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQ25DLElBQUksQ0FBQyxXQUFXLEVBQUUsTUFBTSxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxTQUFTLENBQUM7UUFDL0IsQ0FBQztJQUNILENBQUM7K0dBekNVLGNBQWM7bUhBQWQsY0FBYyxjQURELE1BQU07OzRGQUNuQixjQUFjO2tCQUQxQixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIENvbXBvbmVudFJlZiwgVHlwZSwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogXCJyb290XCIgfSlcbmV4cG9ydCBjbGFzcyBPdmVybGF5U2VydmljZSB7XG4gIHByaXZhdGUgb3ZlcmxheVJvb3Q/OiBIVE1MRWxlbWVudDtcbiAgcHJpdmF0ZSBhY3RpdmVPdmVybGF5cyA9IG5ldyBTZXQ8Q29tcG9uZW50UmVmPHVua25vd24+PigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBwcml2YXRlIGdldE92ZXJsYXlSb290KCk6IEhUTUxFbGVtZW50IHtcbiAgICBpZiAoIXRoaXMub3ZlcmxheVJvb3QpIHtcbiAgICAgIHRoaXMub3ZlcmxheVJvb3QgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcIm92ZXJsYXktcm9vdFwiKSBhcyBIVE1MRWxlbWVudDtcblxuICAgICAgaWYgKCF0aGlzLm92ZXJsYXlSb290KSB7XG4gICAgICAgIHRoaXMub3ZlcmxheVJvb3QgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiZGl2XCIpO1xuICAgICAgICB0aGlzLm92ZXJsYXlSb290LmlkID0gXCJvdmVybGF5LXJvb3RcIjtcbiAgICAgICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZCh0aGlzLm92ZXJsYXlSb290KTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHRoaXMub3ZlcmxheVJvb3Q7XG4gIH1cblxuICBjcmVhdGU8VD4oY29tcG9uZW50OiBUeXBlPFQ+LCB2aWV3Q29udGFpbmVyOiBWaWV3Q29udGFpbmVyUmVmKTogQ29tcG9uZW50UmVmPFQ+IHtcbiAgICBjb25zdCByb290ID0gdGhpcy5nZXRPdmVybGF5Um9vdCgpO1xuXG4gICAgY29uc3QgY29tcG9uZW50UmVmID0gdmlld0NvbnRhaW5lci5jcmVhdGVDb21wb25lbnQoY29tcG9uZW50KTtcblxuICAgIHJvb3QuYXBwZW5kQ2hpbGQoY29tcG9uZW50UmVmLmxvY2F0aW9uLm5hdGl2ZUVsZW1lbnQpO1xuICAgIHRoaXMuYWN0aXZlT3ZlcmxheXMuYWRkKGNvbXBvbmVudFJlZik7XG5cbiAgICBjb25zdCBvcmlnaW5hbERlc3Ryb3kgPSBjb21wb25lbnRSZWYuZGVzdHJveS5iaW5kKGNvbXBvbmVudFJlZik7XG4gICAgY29tcG9uZW50UmVmLmRlc3Ryb3kgPSAoKSA9PiB7XG4gICAgICB0aGlzLmFjdGl2ZU92ZXJsYXlzLmRlbGV0ZShjb21wb25lbnRSZWYpO1xuICAgICAgb3JpZ2luYWxEZXN0cm95KCk7XG4gICAgfTtcblxuICAgIHJldHVybiBjb21wb25lbnRSZWY7XG4gIH1cblxuICBkZXN0cm95KCkge1xuICAgIGlmICh0aGlzLmFjdGl2ZU92ZXJsYXlzLnNpemUgPT09IDApIHtcbiAgICAgIHRoaXMub3ZlcmxheVJvb3Q/LnJlbW92ZSgpO1xuICAgICAgdGhpcy5vdmVybGF5Um9vdCA9IHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHMtcnRlLWxpYi9zcmMvbGliL3NlcnZpY2VzL292ZXJsYXkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUF3QyxNQUFNLGVBQWUsQ0FBQzs7QUFHakYsTUFBTSxPQUFPLGNBQWM7SUFLekI7UUFIUSxtQkFBYyxHQUFHLElBQUksR0FBRyxFQUF5QixDQUFDO1FBQ2xELHVCQUFrQixHQUFHLEtBQUssQ0FBQztJQUVwQixDQUFDO0lBRVIsY0FBYyxDQUFDLGdCQUF5QjtRQUM5QyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDLGNBQWMsQ0FBQyxjQUFjLENBQWdCLENBQUM7WUFFMUUsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztnQkFDdEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUNqRCxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQUUsR0FBRyxjQUFjLENBQUM7Z0JBQ3JDLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQyxDQUFDO2dCQUMvQixJQUFJLGdCQUFnQixFQUFFLENBQUM7b0JBQ3JCLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUM7b0JBQy9CLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLFFBQVEsR0FBRyxPQUFPLENBQUM7b0JBQzFDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUM7b0JBQ3RDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7b0JBQ3ZDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7b0JBQ2pDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxHQUFHLENBQUM7b0JBQ2xDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7b0JBQ3RDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7Z0JBQzFDLENBQUM7Z0JBQ0QsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQzlDLENBQUM7UUFDSCxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQzFCLENBQUM7SUFFRCxNQUFNLENBQUksU0FBa0IsRUFBRSxhQUErQixFQUFFLG1CQUE0QixLQUFLO1FBQzlGLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUVuRCxNQUFNLFlBQVksR0FBRyxhQUFhLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBRTlELElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUN0RCxJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUV0QyxNQUFNLGVBQWUsR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNoRSxZQUFZLENBQUMsT0FBTyxHQUFHLEdBQUcsRUFBRTtZQUMxQixJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUN6QyxlQUFlLEVBQUUsQ0FBQztRQUNwQixDQUFDLENBQUM7UUFFRixPQUFPLFlBQVksQ0FBQztJQUN0QixDQUFDO0lBRUQsT0FBTztRQUNMLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDbkMsSUFBSSxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztnQkFDNUIsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztZQUN6QyxDQUFDO1lBQ0QsSUFBSSxDQUFDLFdBQVcsRUFBRSxNQUFNLEVBQUUsQ0FBQztZQUMzQixJQUFJLENBQUMsV0FBVyxHQUFHLFNBQVMsQ0FBQztRQUMvQixDQUFDO0lBQ0gsQ0FBQzsrR0F4RFUsY0FBYzttSEFBZCxjQUFjLGNBREQsTUFBTTs7NEZBQ25CLGNBQWM7a0JBRDFCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgQ29tcG9uZW50UmVmLCBUeXBlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiBcInJvb3RcIiB9KVxuZXhwb3J0IGNsYXNzIE92ZXJsYXlTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBvdmVybGF5Um9vdD86IEhUTUxFbGVtZW50O1xuICBwcml2YXRlIGFjdGl2ZU92ZXJsYXlzID0gbmV3IFNldDxDb21wb25lbnRSZWY8dW5rbm93bj4+KCk7XG4gIHByaXZhdGUgaXNOYXZpZ2F0aW9uRnJvemVuID0gZmFsc2U7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIHByaXZhdGUgZ2V0T3ZlcmxheVJvb3QoZnJlZXplTmF2aWdhdGlvbjogYm9vbGVhbik6IEhUTUxFbGVtZW50IHtcbiAgICBpZiAoIXRoaXMub3ZlcmxheVJvb3QpIHtcbiAgICAgIHRoaXMub3ZlcmxheVJvb3QgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcIm92ZXJsYXktcm9vdFwiKSBhcyBIVE1MRWxlbWVudDtcblxuICAgICAgaWYgKCF0aGlzLm92ZXJsYXlSb290KSB7XG4gICAgICAgIHRoaXMub3ZlcmxheVJvb3QgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiZGl2XCIpO1xuICAgICAgICB0aGlzLm92ZXJsYXlSb290LmlkID0gXCJvdmVybGF5LXJvb3RcIjtcbiAgICAgICAgdGhpcy5vdmVybGF5Um9vdC50YWJJbmRleCA9IC0xO1xuICAgICAgICBpZiAoZnJlZXplTmF2aWdhdGlvbikge1xuICAgICAgICAgIHRoaXMuaXNOYXZpZ2F0aW9uRnJvemVuID0gdHJ1ZTtcbiAgICAgICAgICB0aGlzLm92ZXJsYXlSb290LnN0eWxlLnBvc2l0aW9uID0gXCJmaXhlZFwiO1xuICAgICAgICAgIHRoaXMub3ZlcmxheVJvb3Quc3R5bGUud2lkdGggPSBcIjEwMCVcIjtcbiAgICAgICAgICB0aGlzLm92ZXJsYXlSb290LnN0eWxlLmhlaWdodCA9IFwiMTAwJVwiO1xuICAgICAgICAgIHRoaXMub3ZlcmxheVJvb3Quc3R5bGUudG9wID0gXCIwXCI7XG4gICAgICAgICAgdGhpcy5vdmVybGF5Um9vdC5zdHlsZS5sZWZ0ID0gXCIwXCI7XG4gICAgICAgICAgdGhpcy5vdmVybGF5Um9vdC5zdHlsZS56SW5kZXggPSBcIjk5OVwiO1xuICAgICAgICAgIGRvY3VtZW50LmJvZHkuc3R5bGUub3ZlcmZsb3cgPSBcImhpZGRlblwiO1xuICAgICAgICB9XG4gICAgICAgIGRvY3VtZW50LmJvZHkuYXBwZW5kQ2hpbGQodGhpcy5vdmVybGF5Um9vdCk7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB0aGlzLm92ZXJsYXlSb290O1xuICB9XG5cbiAgY3JlYXRlPFQ+KGNvbXBvbmVudDogVHlwZTxUPiwgdmlld0NvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZiwgZnJlZXplTmF2aWdhdGlvbjogYm9vbGVhbiA9IGZhbHNlKTogQ29tcG9uZW50UmVmPFQ+IHtcbiAgICBjb25zdCByb290ID0gdGhpcy5nZXRPdmVybGF5Um9vdChmcmVlemVOYXZpZ2F0aW9uKTtcblxuICAgIGNvbnN0IGNvbXBvbmVudFJlZiA9IHZpZXdDb250YWluZXIuY3JlYXRlQ29tcG9uZW50KGNvbXBvbmVudCk7XG5cbiAgICByb290LmFwcGVuZENoaWxkKGNvbXBvbmVudFJlZi5sb2NhdGlvbi5uYXRpdmVFbGVtZW50KTtcbiAgICB0aGlzLmFjdGl2ZU92ZXJsYXlzLmFkZChjb21wb25lbnRSZWYpO1xuXG4gICAgY29uc3Qgb3JpZ2luYWxEZXN0cm95ID0gY29tcG9uZW50UmVmLmRlc3Ryb3kuYmluZChjb21wb25lbnRSZWYpO1xuICAgIGNvbXBvbmVudFJlZi5kZXN0cm95ID0gKCkgPT4ge1xuICAgICAgdGhpcy5hY3RpdmVPdmVybGF5cy5kZWxldGUoY29tcG9uZW50UmVmKTtcbiAgICAgIG9yaWdpbmFsRGVzdHJveSgpO1xuICAgIH07XG5cbiAgICByZXR1cm4gY29tcG9uZW50UmVmO1xuICB9XG5cbiAgZGVzdHJveSgpIHtcbiAgICBpZiAodGhpcy5hY3RpdmVPdmVybGF5cy5zaXplID09PSAwKSB7XG4gICAgICBpZiAodGhpcy5pc05hdmlnYXRpb25Gcm96ZW4pIHtcbiAgICAgICAgZG9jdW1lbnQuYm9keS5zdHlsZS5vdmVyZmxvdyA9IFwidW5zZXRcIjtcbiAgICAgIH1cbiAgICAgIHRoaXMub3ZlcmxheVJvb3Q/LnJlbW92ZSgpO1xuICAgICAgdGhpcy5vdmVybGF5Um9vdCA9IHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -21,4 +21,7 @@ export * from "./lib/components/segmented-control/segmented-control.component";
21
21
  export * from "./lib/components/breadcrumbs/breadcrumbs.component";
22
22
  export * from "./lib/components/banner/banner.component";
23
23
  export * from "./lib/components/popover/popover.directive";
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RzLXJ0ZS1saWIvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsa0VBQWtFLENBQUM7QUFDakYsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLDBEQUEwRCxDQUFDO0FBQ3pFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxrRUFBa0UsQ0FBQztBQUNqRixjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLDRDQUE0QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2dyaWQvZ3JpZC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2dyaWQvY29sL2NvbC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2xpbmsvbGluay5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9yYWRpby1idXR0b24tZ3JvdXAvcmFkaW8tYnV0dG9uLWdyb3VwLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9jaGVja2JveC1ncm91cC9jaGVja2JveC1ncm91cC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2ljb24vaWNvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3Rvb2x0aXAvdG9vbHRpcC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3NwbGl0LWJ1dHRvbi9zcGxpdC1idXR0b24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9pY29uLWJ1dHRvbi9pY29uLWJ1dHRvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2ljb24tYnV0dG9uLXRvZ2dsZS9pY29uLWJ1dHRvbi10b2dnbGUuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy90ZXh0LWlucHV0L3RleHQtaW5wdXQuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9jaGlwL2NoaXAuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9iYWRnZS9iYWRnZS5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3RleHRhcmVhL3RleHRhcmVhLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvZGl2aWRlci9kaXZpZGVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvc3dpdGNoL3N3aXRjaC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3NlZ21lbnRlZC1jb250cm9sL3NlZ21lbnRlZC1jb250cm9sLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvYnJlYWRjcnVtYnMvYnJlYWRjcnVtYnMuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9iYW5uZXIvYmFubmVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvcG9wb3Zlci9wb3BvdmVyLmRpcmVjdGl2ZVwiO1xuIl19
24
+ export * from "./lib/components/modal/modal-trigger/modal-trigger.directive";
25
+ export * from "./lib/components/modal/modal.directive";
26
+ export * from "./lib/components/modal/modal.module";
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RzLXJ0ZS1saWIvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsa0VBQWtFLENBQUM7QUFDakYsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLDBEQUEwRCxDQUFDO0FBQ3pFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxrRUFBa0UsQ0FBQztBQUNqRixjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2dyaWQvZ3JpZC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2dyaWQvY29sL2NvbC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2xpbmsvbGluay5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9yYWRpby1idXR0b24tZ3JvdXAvcmFkaW8tYnV0dG9uLWdyb3VwLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9jaGVja2JveC1ncm91cC9jaGVja2JveC1ncm91cC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2ljb24vaWNvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3Rvb2x0aXAvdG9vbHRpcC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3NwbGl0LWJ1dHRvbi9zcGxpdC1idXR0b24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9pY29uLWJ1dHRvbi9pY29uLWJ1dHRvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL2ljb24tYnV0dG9uLXRvZ2dsZS9pY29uLWJ1dHRvbi10b2dnbGUuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy90ZXh0LWlucHV0L3RleHQtaW5wdXQuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9jaGlwL2NoaXAuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9iYWRnZS9iYWRnZS5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3RleHRhcmVhL3RleHRhcmVhLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvZGl2aWRlci9kaXZpZGVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvc3dpdGNoL3N3aXRjaC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzL3NlZ21lbnRlZC1jb250cm9sL3NlZ21lbnRlZC1jb250cm9sLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvYnJlYWRjcnVtYnMvYnJlYWRjcnVtYnMuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9iYW5uZXIvYmFubmVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvcG9wb3Zlci9wb3BvdmVyLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvbW9kYWwvbW9kYWwtdHJpZ2dlci9tb2RhbC10cmlnZ2VyLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHMvbW9kYWwvbW9kYWwuZGlyZWN0aXZlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29tcG9uZW50cy9tb2RhbC9tb2RhbC5tb2R1bGVcIjtcbiJdfQ==