@leanix/components 0.4.407 → 0.4.409

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 (40) hide show
  1. package/esm2022/index.mjs +2 -1
  2. package/esm2022/lib/core-ui/components/badge/badge.component.mjs +21 -1
  3. package/esm2022/lib/core-ui/components/banner/banner.component.mjs +23 -1
  4. package/esm2022/lib/core-ui/components/button/button.component.mjs +40 -1
  5. package/esm2022/lib/core-ui/components/card/card.component.mjs +16 -1
  6. package/esm2022/lib/core-ui/components/content-panel/content-panel.component.mjs +18 -3
  7. package/esm2022/lib/core-ui/components/counter/counter.component.mjs +14 -1
  8. package/esm2022/lib/core-ui/components/integration-link-card/integration-link-card.component.mjs +47 -1
  9. package/esm2022/lib/core-ui/components/skeleton/skeleton.component.mjs +19 -1
  10. package/esm2022/lib/core-ui/components/stepper/stepper.component.mjs +41 -1
  11. package/esm2022/lib/core-ui/components/tiny-spinner/tiny-spinner.component.mjs +12 -1
  12. package/esm2022/lib/core-ui/components/tokenizer/tokenizer-overflow-popover/tokenizer-overflow-popover.component.mjs +44 -0
  13. package/esm2022/lib/core-ui/components/tokenizer/tokenizer.component.mjs +3 -3
  14. package/esm2022/lib/core-ui/tooltip/tooltip.directive.mjs +16 -1
  15. package/esm2022/lib/forms-ui/components/breadcrumb/breadcrumb.component.mjs +17 -1
  16. package/esm2022/lib/forms-ui/components/date-input/date-input.component.mjs +100 -38
  17. package/esm2022/lib/forms-ui/components/slider-toggle/slider-toggle.component.mjs +18 -1
  18. package/esm2022/lib/modal-ui/components/modal/modal.component.mjs +55 -7
  19. package/esm2022/lib/popover-ui/components/popover/popover.component.mjs +31 -6
  20. package/fesm2022/leanix-components.mjs +541 -82
  21. package/fesm2022/leanix-components.mjs.map +1 -1
  22. package/index.d.ts +1 -0
  23. package/lib/core-ui/components/badge/badge.component.d.ts +23 -0
  24. package/lib/core-ui/components/banner/banner.component.d.ts +22 -0
  25. package/lib/core-ui/components/button/button.component.d.ts +39 -0
  26. package/lib/core-ui/components/card/card.component.d.ts +15 -0
  27. package/lib/core-ui/components/content-panel/content-panel.component.d.ts +18 -1
  28. package/lib/core-ui/components/counter/counter.component.d.ts +14 -0
  29. package/lib/core-ui/components/integration-link-card/integration-link-card.component.d.ts +60 -0
  30. package/lib/core-ui/components/skeleton/skeleton.component.d.ts +18 -0
  31. package/lib/core-ui/components/stepper/stepper.component.d.ts +40 -0
  32. package/lib/core-ui/components/tiny-spinner/tiny-spinner.component.d.ts +11 -0
  33. package/lib/core-ui/components/tokenizer/tokenizer-overflow-popover/tokenizer-overflow-popover.component.d.ts +19 -0
  34. package/lib/core-ui/tooltip/tooltip.directive.d.ts +17 -0
  35. package/lib/forms-ui/components/breadcrumb/breadcrumb.component.d.ts +16 -0
  36. package/lib/forms-ui/components/date-input/date-input.component.d.ts +80 -7
  37. package/lib/forms-ui/components/slider-toggle/slider-toggle.component.d.ts +20 -0
  38. package/lib/modal-ui/components/modal/modal.component.d.ts +59 -5
  39. package/lib/popover-ui/components/popover/popover.component.d.ts +37 -5
  40. package/package.json +1 -1
@@ -4,19 +4,59 @@ import { ChangeDetectionStrategy, Component } from '@angular/core';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/cdk/bidi";
6
6
  import * as i2 from "@angular/common";
7
+ /**
8
+ * Stepper component is a wrapper around the Angular CDK Stepper component. It provides a way to create a linear
9
+ * sequence of steps that guide users through a process.
10
+ *
11
+ * ## Usage
12
+ *
13
+ * 1. Import `LxCoreUiModule` module from `@leanix/components` and `CdkStepperModule` module from `@angular/cdk/stepper` in your module where you want to use the component, or in case of a standalone parent component, import the
14
+ * `StepperComponent` and `CdkStepperModule` directly into your standalone component.
15
+ *
16
+ * - Module import:
17
+ *
18
+ * ```ts
19
+ * import { LxCoreUiModule } from '@leanix/components';
20
+ * import { CdkStepperModule } from '@angular/cdk/stepper';
21
+ * ```
22
+ *
23
+ * - Standalone component import:
24
+ *
25
+ * ```ts
26
+ * import { StepperComponent } from '@leanix/components';
27
+ * import { CdkStepperModule } from '@angular/cdk/stepper';
28
+ *
29
+ * @Component({
30
+ * selector: 'lx-my-component',
31
+ * standalone: true,
32
+ * imports: [CdkStepperModule, StepperComponent],
33
+ * templateUrl: './my-component.component.html'
34
+ * })
35
+ * export class MyComponent {}
36
+ * ```
37
+ *
38
+ * 2. Use the component in your template. All steps added to the stepper should be wrapped in a `cdk-step` element.
39
+ *
40
+ * Since this component extends the Angular CDK `CdkStepper` component, all the inputs, outputs, and methods available in the
41
+ * `CdkStepper` component are also available in the `StepperComponent` and are documented in the
42
+ * [Angular CDK documentation](https://material.angular.io/cdk/stepper/api).
43
+ */
7
44
  export class StepperComponent extends CdkStepper {
8
45
  // TODO - Remove this constructor once the following issue is resolved: https://github.com/storybookjs/storybook/issues/23534#issuecomment-2042888436
9
46
  // Storybook smoke tests for stepper component are failing without this constructor
10
47
  constructor(_dir, _changeDetectorRef, _elementRef) {
11
48
  super(_dir, _changeDetectorRef, _elementRef);
49
+ /** @internal */
12
50
  this.size = 'normal';
13
51
  }
14
52
  get isSmallVariant() {
15
53
  return this.size === 'small';
16
54
  }
55
+ /** @internal */
17
56
  isCompleted(index) {
18
57
  return index < this.selectedIndex;
19
58
  }
59
+ /** @internal */
20
60
  isActiveStep(index) {
21
61
  return index === this.selectedIndex;
22
62
  }
@@ -27,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
27
67
  type: Component,
28
68
  args: [{ selector: 'lx-stepper', standalone: true, imports: [CommonModule, CdkStepperModule], providers: [{ provide: CdkStepper, useExisting: StepperComponent }], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ul class=\"stepper\">\n @for (step of steps; track step.label; let i = $index) {\n <li class=\"step\" [ngClass]=\"{ 'step-completed': isCompleted(i) }\">\n <div\n class=\"step-container\"\n [class]=\"isSmallVariant ? 'step-container-small' : 'step-container-normal'\"\n [ngClass]=\"{ 'step-container-active': isActiveStep(i), 'step-container-completed': isCompleted(i) }\"\n >\n <div class=\"step-number\" [ngClass]=\"{ 'step-number-active': isActiveStep(i) }\">\n @if (isCompleted(i)) {\n <i [class]=\"'far fa-check check-icon'\" [ngClass]=\"{ 'small-icon': isSmallVariant }\"></i>\n } @else if (!isSmallVariant) {\n {{ i + 1 }}\n }\n </div>\n @if (!isSmallVariant) {\n <div class=\"step-title\">\n {{ step.label }}\n </div>\n }\n </div>\n </li>\n }\n</ul>\n@if (selected) {\n <div class=\"content\">\n <ng-container [ngTemplateOutlet]=\"selected!.content\" />\n </div>\n}\n", styles: [".stepper{display:flex;position:relative;align-items:center;padding-left:0}.step{position:relative;z-index:1;flex:1;display:flex;flex-direction:row;flex-shrink:0}.step:not(:last-child):after{content:\"\";position:relative;z-index:1;flex:auto;height:1px;min-width:30px;border-top:2px solid #b2bccc;align-self:center;margin-left:5px;margin-right:5px}.step-container{display:flex;flex-direction:column;justify-content:space-between;flex-shrink:0;border:2px solid #b2bccc;border-radius:50%;background-color:#fff;pointer-events:none}.step-container-normal{width:40px;height:40px}.step-container-small{width:22.5px;height:22.5px}.step-number{color:#b2bccc;font-size:15.5px;font-style:normal;font-weight:400;line-height:20px;width:100%;height:100%;padding-top:8px;text-align:center}.step-container-small .step-number{padding-top:0}.step-title{width:max-content;top:50px;position:absolute}.check-icon{font-size:20px;color:#0070f2}.small-icon{position:relative;font-size:12px}@supports (-moz-appearance: none){.small-icon{top:-1px}}.content{margin-top:48px;height:100%}.step:first-child{justify-content:flex-start}.step:first-child .step-title{left:0}.step:not(:first-child):not(:last-child) .step-container{align-self:center}.step:not(:first-child):not(:last-child) .step-container .step-title{align-self:center}.step:last-child{justify-content:flex-end;align-items:flex-end;text-align:right;flex:0 0 auto}.step:last-child .step-container .step-title{align-self:flex-end;right:0}.step:last-child .step-number{margin-right:40%}.step:nth-child(n+19):last-child .step-number{margin-right:31%}.step-container.step-container-active{background-color:#0070f2;border-color:#0070f2}.step-number-active{color:#fff}.step.step-completed:not(:last-child):after{border-color:#0070f2}.step-container.step-container-completed{border-color:#0070f2}\n"] }]
29
69
  }], ctorParameters: () => [{ type: i1.Directionality }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }] });
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcHBlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL2NvbXBvbmVudHMvc3RlcHBlci9zdGVwcGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy9zdGVwcGVyL3N0ZXBwZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQXFCLFNBQVMsRUFBYyxNQUFNLGVBQWUsQ0FBQzs7OztBQVdsRyxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsVUFBVTtJQUc5QyxxSkFBcUo7SUFDckosbUZBQW1GO0lBQ25GLFlBQVksSUFBb0IsRUFBRSxrQkFBcUMsRUFBRSxXQUFvQztRQUMzRyxLQUFLLENBQUMsSUFBSSxFQUFFLGtCQUFrQixFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBTC9DLFNBQUksR0FBdUIsUUFBUSxDQUFDO0lBTXBDLENBQUM7SUFFRCxJQUFJLGNBQWM7UUFDaEIsT0FBTyxJQUFJLENBQUMsSUFBSSxLQUFLLE9BQU8sQ0FBQztJQUMvQixDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQWE7UUFDdkIsT0FBTyxLQUFLLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUNwQyxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQWE7UUFDeEIsT0FBTyxLQUFLLEtBQUssSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUN0QyxDQUFDOzhHQW5CVSxnQkFBZ0I7a0dBQWhCLGdCQUFnQix5REFIaEIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLENBQUMsaURDWHJFLHlnQ0E2QkEseTFERHJCWSxZQUFZLG1TQUFFLGdCQUFnQjs7MkZBTTdCLGdCQUFnQjtrQkFUNUIsU0FBUzsrQkFDRSxZQUFZLGNBQ1YsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGdCQUFnQixDQUFDLGFBRzlCLENBQUMsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFdBQVcsa0JBQWtCLEVBQUUsQ0FBQyxtQkFDbEQsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGlvbmFsaXR5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2JpZGknO1xuaW1wb3J0IHsgQ2RrU3RlcHBlciwgQ2RrU3RlcHBlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9zdGVwcGVyJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRWxlbWVudFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdseC1zdGVwcGVyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQ2RrU3RlcHBlck1vZHVsZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi9zdGVwcGVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL3N0ZXBwZXIuY29tcG9uZW50LnNjc3MnLFxuICBwcm92aWRlcnM6IFt7IHByb3ZpZGU6IENka1N0ZXBwZXIsIHVzZUV4aXN0aW5nOiBTdGVwcGVyQ29tcG9uZW50IH1dLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBTdGVwcGVyQ29tcG9uZW50IGV4dGVuZHMgQ2RrU3RlcHBlciB7XG4gIHNpemU6ICdzbWFsbCcgfCAnbm9ybWFsJyA9ICdub3JtYWwnO1xuXG4gIC8vIFRPRE8gLSBSZW1vdmUgdGhpcyBjb25zdHJ1Y3RvciBvbmNlIHRoZSBmb2xsb3dpbmcgaXNzdWUgaXMgcmVzb2x2ZWQ6IGh0dHBzOi8vZ2l0aHViLmNvbS9zdG9yeWJvb2tqcy9zdG9yeWJvb2svaXNzdWVzLzIzNTM0I2lzc3VlY29tbWVudC0yMDQyODg4NDM2XG4gIC8vIFN0b3J5Ym9vayBzbW9rZSB0ZXN0cyBmb3Igc3RlcHBlciBjb21wb25lbnQgYXJlIGZhaWxpbmcgd2l0aG91dCB0aGlzIGNvbnN0cnVjdG9yXG4gIGNvbnN0cnVjdG9yKF9kaXI6IERpcmVjdGlvbmFsaXR5LCBfY2hhbmdlRGV0ZWN0b3JSZWY6IENoYW5nZURldGVjdG9yUmVmLCBfZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4pIHtcbiAgICBzdXBlcihfZGlyLCBfY2hhbmdlRGV0ZWN0b3JSZWYsIF9lbGVtZW50UmVmKTtcbiAgfVxuXG4gIGdldCBpc1NtYWxsVmFyaWFudCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5zaXplID09PSAnc21hbGwnO1xuICB9XG5cbiAgaXNDb21wbGV0ZWQoaW5kZXg6IG51bWJlcik6IGJvb2xlYW4ge1xuICAgIHJldHVybiBpbmRleCA8IHRoaXMuc2VsZWN0ZWRJbmRleDtcbiAgfVxuXG4gIGlzQWN0aXZlU3RlcChpbmRleDogbnVtYmVyKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGluZGV4ID09PSB0aGlzLnNlbGVjdGVkSW5kZXg7XG4gIH1cbn1cbiIsIjx1bCBjbGFzcz1cInN0ZXBwZXJcIj5cbiAgQGZvciAoc3RlcCBvZiBzdGVwczsgdHJhY2sgc3RlcC5sYWJlbDsgbGV0IGkgPSAkaW5kZXgpIHtcbiAgICA8bGkgY2xhc3M9XCJzdGVwXCIgW25nQ2xhc3NdPVwieyAnc3RlcC1jb21wbGV0ZWQnOiBpc0NvbXBsZXRlZChpKSB9XCI+XG4gICAgICA8ZGl2XG4gICAgICAgIGNsYXNzPVwic3RlcC1jb250YWluZXJcIlxuICAgICAgICBbY2xhc3NdPVwiaXNTbWFsbFZhcmlhbnQgPyAnc3RlcC1jb250YWluZXItc21hbGwnIDogJ3N0ZXAtY29udGFpbmVyLW5vcm1hbCdcIlxuICAgICAgICBbbmdDbGFzc109XCJ7ICdzdGVwLWNvbnRhaW5lci1hY3RpdmUnOiBpc0FjdGl2ZVN0ZXAoaSksICdzdGVwLWNvbnRhaW5lci1jb21wbGV0ZWQnOiBpc0NvbXBsZXRlZChpKSB9XCJcbiAgICAgID5cbiAgICAgICAgPGRpdiBjbGFzcz1cInN0ZXAtbnVtYmVyXCIgW25nQ2xhc3NdPVwieyAnc3RlcC1udW1iZXItYWN0aXZlJzogaXNBY3RpdmVTdGVwKGkpIH1cIj5cbiAgICAgICAgICBAaWYgKGlzQ29tcGxldGVkKGkpKSB7XG4gICAgICAgICAgICA8aSBbY2xhc3NdPVwiJ2ZhciBmYS1jaGVjayBjaGVjay1pY29uJ1wiIFtuZ0NsYXNzXT1cInsgJ3NtYWxsLWljb24nOiBpc1NtYWxsVmFyaWFudCB9XCI+PC9pPlxuICAgICAgICAgIH0gQGVsc2UgaWYgKCFpc1NtYWxsVmFyaWFudCkge1xuICAgICAgICAgICAge3sgaSArIDEgfX1cbiAgICAgICAgICB9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICBAaWYgKCFpc1NtYWxsVmFyaWFudCkge1xuICAgICAgICAgIDxkaXYgY2xhc3M9XCJzdGVwLXRpdGxlXCI+XG4gICAgICAgICAgICB7eyBzdGVwLmxhYmVsIH19XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIH1cbiAgICAgIDwvZGl2PlxuICAgIDwvbGk+XG4gIH1cbjwvdWw+XG5AaWYgKHNlbGVjdGVkKSB7XG4gIDxkaXYgY2xhc3M9XCJjb250ZW50XCI+XG4gICAgPG5nLWNvbnRhaW5lciBbbmdUZW1wbGF0ZU91dGxldF09XCJzZWxlY3RlZCEuY29udGVudFwiIC8+XG4gIDwvZGl2PlxufVxuIl19
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcHBlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL2NvbXBvbmVudHMvc3RlcHBlci9zdGVwcGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy9zdGVwcGVyL3N0ZXBwZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQXFCLFNBQVMsRUFBYyxNQUFNLGVBQWUsQ0FBQzs7OztBQUVsRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0NHO0FBVUgsTUFBTSxPQUFPLGdCQUFpQixTQUFRLFVBQVU7SUFJOUMscUpBQXFKO0lBQ3JKLG1GQUFtRjtJQUNuRixZQUFZLElBQW9CLEVBQUUsa0JBQXFDLEVBQUUsV0FBb0M7UUFDM0csS0FBSyxDQUFDLElBQUksRUFBRSxrQkFBa0IsRUFBRSxXQUFXLENBQUMsQ0FBQztRQU4vQyxnQkFBZ0I7UUFDaEIsU0FBSSxHQUF1QixRQUFRLENBQUM7SUFNcEMsQ0FBQztJQUVELElBQUksY0FBYztRQUNoQixPQUFPLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTyxDQUFDO0lBQy9CLENBQUM7SUFFRCxnQkFBZ0I7SUFDaEIsV0FBVyxDQUFDLEtBQWE7UUFDdkIsT0FBTyxLQUFLLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUNwQyxDQUFDO0lBRUQsZ0JBQWdCO0lBQ2hCLFlBQVksQ0FBQyxLQUFhO1FBQ3hCLE9BQU8sS0FBSyxLQUFLLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDdEMsQ0FBQzs4R0F0QlUsZ0JBQWdCO2tHQUFoQixnQkFBZ0IseURBSGhCLENBQUMsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLGlEQ2hEckUseWdDQTZCQSx5MUREZ0JZLFlBQVksbVNBQUUsZ0JBQWdCOzsyRkFNN0IsZ0JBQWdCO2tCQVQ1QixTQUFTOytCQUNFLFlBQVksY0FDVixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZ0JBQWdCLENBQUMsYUFHOUIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsV0FBVyxrQkFBa0IsRUFBRSxDQUFDLG1CQUNsRCx1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aW9uYWxpdHkgfSBmcm9tICdAYW5ndWxhci9jZGsvYmlkaSc7XG5pbXBvcnQgeyBDZGtTdGVwcGVyLCBDZGtTdGVwcGVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3N0ZXBwZXInO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBFbGVtZW50UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogU3RlcHBlciBjb21wb25lbnQgaXMgYSB3cmFwcGVyIGFyb3VuZCB0aGUgQW5ndWxhciBDREsgU3RlcHBlciBjb21wb25lbnQuIEl0IHByb3ZpZGVzIGEgd2F5IHRvIGNyZWF0ZSBhIGxpbmVhclxuICogc2VxdWVuY2Ugb2Ygc3RlcHMgdGhhdCBndWlkZSB1c2VycyB0aHJvdWdoIGEgcHJvY2Vzcy5cbiAqXG4gKiAjIyBVc2FnZVxuICpcbiAqIDEuIEltcG9ydCBgTHhDb3JlVWlNb2R1bGVgIG1vZHVsZSBmcm9tIGBAbGVhbml4L2NvbXBvbmVudHNgIGFuZCBgQ2RrU3RlcHBlck1vZHVsZWAgbW9kdWxlIGZyb20gYEBhbmd1bGFyL2Nkay9zdGVwcGVyYCBpbiB5b3VyIG1vZHVsZSB3aGVyZSB5b3Ugd2FudCB0byB1c2UgdGhlIGNvbXBvbmVudCwgb3IgaW4gY2FzZSBvZiBhIHN0YW5kYWxvbmUgcGFyZW50IGNvbXBvbmVudCwgaW1wb3J0IHRoZVxuICogICAgYFN0ZXBwZXJDb21wb25lbnRgIGFuZCBgQ2RrU3RlcHBlck1vZHVsZWAgZGlyZWN0bHkgaW50byB5b3VyIHN0YW5kYWxvbmUgY29tcG9uZW50LlxuICpcbiAqIC0gTW9kdWxlIGltcG9ydDpcbiAqXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgTHhDb3JlVWlNb2R1bGUgfSBmcm9tICdAbGVhbml4L2NvbXBvbmVudHMnO1xuICogaW1wb3J0IHsgQ2RrU3RlcHBlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9zdGVwcGVyJztcbiAqIGBgYFxuICpcbiAqIC0gU3RhbmRhbG9uZSBjb21wb25lbnQgaW1wb3J0OlxuICpcbiAqIGBgYHRzXG4gKiBpbXBvcnQgeyBTdGVwcGVyQ29tcG9uZW50IH0gZnJvbSAnQGxlYW5peC9jb21wb25lbnRzJztcbiAqIGltcG9ydCB7IENka1N0ZXBwZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvc3RlcHBlcic7XG4gKlxuICogQENvbXBvbmVudCh7XG4gKiAgIHNlbGVjdG9yOiAnbHgtbXktY29tcG9uZW50JyxcbiAqICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAqICAgaW1wb3J0czogW0Nka1N0ZXBwZXJNb2R1bGUsIFN0ZXBwZXJDb21wb25lbnRdLFxuICogICB0ZW1wbGF0ZVVybDogJy4vbXktY29tcG9uZW50LmNvbXBvbmVudC5odG1sJ1xuICogfSlcbiAqIGV4cG9ydCBjbGFzcyBNeUNvbXBvbmVudCB7fVxuICogYGBgXG4gKlxuICogMi4gVXNlIHRoZSBjb21wb25lbnQgaW4geW91ciB0ZW1wbGF0ZS4gQWxsIHN0ZXBzIGFkZGVkIHRvIHRoZSBzdGVwcGVyIHNob3VsZCBiZSB3cmFwcGVkIGluIGEgYGNkay1zdGVwYCBlbGVtZW50LlxuICpcbiAqIFNpbmNlIHRoaXMgY29tcG9uZW50IGV4dGVuZHMgdGhlIEFuZ3VsYXIgQ0RLIGBDZGtTdGVwcGVyYCBjb21wb25lbnQsIGFsbCB0aGUgaW5wdXRzLCBvdXRwdXRzLCBhbmQgbWV0aG9kcyBhdmFpbGFibGUgaW4gdGhlXG4gKiBgQ2RrU3RlcHBlcmAgY29tcG9uZW50IGFyZSBhbHNvIGF2YWlsYWJsZSBpbiB0aGUgYFN0ZXBwZXJDb21wb25lbnRgIGFuZCBhcmUgZG9jdW1lbnRlZCBpbiB0aGVcbiAqIFtBbmd1bGFyIENESyBkb2N1bWVudGF0aW9uXShodHRwczovL21hdGVyaWFsLmFuZ3VsYXIuaW8vY2RrL3N0ZXBwZXIvYXBpKS5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtc3RlcHBlcicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIENka1N0ZXBwZXJNb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vc3RlcHBlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9zdGVwcGVyLmNvbXBvbmVudC5zY3NzJyxcbiAgcHJvdmlkZXJzOiBbeyBwcm92aWRlOiBDZGtTdGVwcGVyLCB1c2VFeGlzdGluZzogU3RlcHBlckNvbXBvbmVudCB9XSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgU3RlcHBlckNvbXBvbmVudCBleHRlbmRzIENka1N0ZXBwZXIge1xuICAvKiogQGludGVybmFsICovXG4gIHNpemU6ICdzbWFsbCcgfCAnbm9ybWFsJyA9ICdub3JtYWwnO1xuXG4gIC8vIFRPRE8gLSBSZW1vdmUgdGhpcyBjb25zdHJ1Y3RvciBvbmNlIHRoZSBmb2xsb3dpbmcgaXNzdWUgaXMgcmVzb2x2ZWQ6IGh0dHBzOi8vZ2l0aHViLmNvbS9zdG9yeWJvb2tqcy9zdG9yeWJvb2svaXNzdWVzLzIzNTM0I2lzc3VlY29tbWVudC0yMDQyODg4NDM2XG4gIC8vIFN0b3J5Ym9vayBzbW9rZSB0ZXN0cyBmb3Igc3RlcHBlciBjb21wb25lbnQgYXJlIGZhaWxpbmcgd2l0aG91dCB0aGlzIGNvbnN0cnVjdG9yXG4gIGNvbnN0cnVjdG9yKF9kaXI6IERpcmVjdGlvbmFsaXR5LCBfY2hhbmdlRGV0ZWN0b3JSZWY6IENoYW5nZURldGVjdG9yUmVmLCBfZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4pIHtcbiAgICBzdXBlcihfZGlyLCBfY2hhbmdlRGV0ZWN0b3JSZWYsIF9lbGVtZW50UmVmKTtcbiAgfVxuXG4gIGdldCBpc1NtYWxsVmFyaWFudCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5zaXplID09PSAnc21hbGwnO1xuICB9XG5cbiAgLyoqIEBpbnRlcm5hbCAqL1xuICBpc0NvbXBsZXRlZChpbmRleDogbnVtYmVyKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGluZGV4IDwgdGhpcy5zZWxlY3RlZEluZGV4O1xuICB9XG5cbiAgLyoqIEBpbnRlcm5hbCAqL1xuICBpc0FjdGl2ZVN0ZXAoaW5kZXg6IG51bWJlcik6IGJvb2xlYW4ge1xuICAgIHJldHVybiBpbmRleCA9PT0gdGhpcy5zZWxlY3RlZEluZGV4O1xuICB9XG59XG4iLCI8dWwgY2xhc3M9XCJzdGVwcGVyXCI+XG4gIEBmb3IgKHN0ZXAgb2Ygc3RlcHM7IHRyYWNrIHN0ZXAubGFiZWw7IGxldCBpID0gJGluZGV4KSB7XG4gICAgPGxpIGNsYXNzPVwic3RlcFwiIFtuZ0NsYXNzXT1cInsgJ3N0ZXAtY29tcGxldGVkJzogaXNDb21wbGV0ZWQoaSkgfVwiPlxuICAgICAgPGRpdlxuICAgICAgICBjbGFzcz1cInN0ZXAtY29udGFpbmVyXCJcbiAgICAgICAgW2NsYXNzXT1cImlzU21hbGxWYXJpYW50ID8gJ3N0ZXAtY29udGFpbmVyLXNtYWxsJyA6ICdzdGVwLWNvbnRhaW5lci1ub3JtYWwnXCJcbiAgICAgICAgW25nQ2xhc3NdPVwieyAnc3RlcC1jb250YWluZXItYWN0aXZlJzogaXNBY3RpdmVTdGVwKGkpLCAnc3RlcC1jb250YWluZXItY29tcGxldGVkJzogaXNDb21wbGV0ZWQoaSkgfVwiXG4gICAgICA+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzdGVwLW51bWJlclwiIFtuZ0NsYXNzXT1cInsgJ3N0ZXAtbnVtYmVyLWFjdGl2ZSc6IGlzQWN0aXZlU3RlcChpKSB9XCI+XG4gICAgICAgICAgQGlmIChpc0NvbXBsZXRlZChpKSkge1xuICAgICAgICAgICAgPGkgW2NsYXNzXT1cIidmYXIgZmEtY2hlY2sgY2hlY2staWNvbidcIiBbbmdDbGFzc109XCJ7ICdzbWFsbC1pY29uJzogaXNTbWFsbFZhcmlhbnQgfVwiPjwvaT5cbiAgICAgICAgICB9IEBlbHNlIGlmICghaXNTbWFsbFZhcmlhbnQpIHtcbiAgICAgICAgICAgIHt7IGkgKyAxIH19XG4gICAgICAgICAgfVxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgQGlmICghaXNTbWFsbFZhcmlhbnQpIHtcbiAgICAgICAgICA8ZGl2IGNsYXNzPVwic3RlcC10aXRsZVwiPlxuICAgICAgICAgICAge3sgc3RlcC5sYWJlbCB9fVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICB9XG4gICAgICA8L2Rpdj5cbiAgICA8L2xpPlxuICB9XG48L3VsPlxuQGlmIChzZWxlY3RlZCkge1xuICA8ZGl2IGNsYXNzPVwiY29udGVudFwiPlxuICAgIDxuZy1jb250YWluZXIgW25nVGVtcGxhdGVPdXRsZXRdPVwic2VsZWN0ZWQhLmNvbnRlbnRcIiAvPlxuICA8L2Rpdj5cbn1cbiJdfQ==
@@ -1,5 +1,16 @@
1
1
  import { Component } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
+ /**
4
+ * Tiny spinner component is used to show a small spinner.
5
+ *
6
+ * ## Usage
7
+ *
8
+ * 1. Import the `TinySpinnerComponent` component from `@leanix/components` in your module or standalone copmonent where you want to use the component.
9
+ *
10
+ * ```ts
11
+ * import { TinySpinnerComponent } from '@leanix/components';
12
+ * ```
13
+ */
3
14
  export class TinySpinnerComponent {
4
15
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TinySpinnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5
16
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: TinySpinnerComponent, isStandalone: true, selector: "lx-tiny-spinner", ngImport: i0, template: "<i class=\"far fa-spinner fa-spin fa-fw\"></i>\n" }); }
@@ -8,4 +19,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
8
19
  type: Component,
9
20
  args: [{ selector: 'lx-tiny-spinner', standalone: true, template: "<i class=\"far fa-spinner fa-spin fa-fw\"></i>\n" }]
10
21
  }] });
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlueS1zcGlubmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy90aW55LXNwaW5uZXIvdGlueS1zcGlubmVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy90aW55LXNwaW5uZXIvdGlueS1zcGlubmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzFDLE1BQU0sT0FBTyxvQkFBb0I7OEdBQXBCLG9CQUFvQjtrR0FBcEIsb0JBQW9CLDJFQ1BqQyxrREFDQTs7MkZETWEsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNFLGlCQUFpQixjQUVmLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtdGlueS1zcGlubmVyJyxcbiAgdGVtcGxhdGVVcmw6ICd0aW55LXNwaW5uZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFRpbnlTcGlubmVyQ29tcG9uZW50IHt9XG4iLCI8aSBjbGFzcz1cImZhciBmYS1zcGlubmVyIGZhLXNwaW4gZmEtZndcIj48L2k+XG4iXX0=
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlueS1zcGlubmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy90aW55LXNwaW5uZXIvdGlueS1zcGlubmVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy90aW55LXNwaW5uZXIvdGlueS1zcGlubmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTFDOzs7Ozs7Ozs7O0dBVUc7QUFNSCxNQUFNLE9BQU8sb0JBQW9COzhHQUFwQixvQkFBb0I7a0dBQXBCLG9CQUFvQiwyRUNsQmpDLGtEQUNBOzsyRkRpQmEsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNFLGlCQUFpQixjQUVmLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBUaW55IHNwaW5uZXIgY29tcG9uZW50IGlzIHVzZWQgdG8gc2hvdyBhIHNtYWxsIHNwaW5uZXIuXG4gKlxuICogIyMgVXNhZ2VcbiAqXG4gKiAxLiBJbXBvcnQgdGhlIGBUaW55U3Bpbm5lckNvbXBvbmVudGAgY29tcG9uZW50IGZyb20gYEBsZWFuaXgvY29tcG9uZW50c2AgaW4geW91ciBtb2R1bGUgb3Igc3RhbmRhbG9uZSBjb3Btb25lbnQgd2hlcmUgeW91IHdhbnQgdG8gdXNlIHRoZSBjb21wb25lbnQuXG4gKlxuICogYGBgdHNcbiAqIGltcG9ydCB7IFRpbnlTcGlubmVyQ29tcG9uZW50IH0gZnJvbSAnQGxlYW5peC9jb21wb25lbnRzJztcbiAqIGBgYFxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdseC10aW55LXNwaW5uZXInLFxuICB0ZW1wbGF0ZVVybDogJ3Rpbnktc3Bpbm5lci5jb21wb25lbnQuaHRtbCcsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgVGlueVNwaW5uZXJDb21wb25lbnQge31cbiIsIjxpIGNsYXNzPVwiZmFyIGZhLXNwaW5uZXIgZmEtc3BpbiBmYS1md1wiPjwvaT5cbiJdfQ==
@@ -0,0 +1,44 @@
1
+ import { NgTemplateOutlet } from '@angular/common';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, DestroyRef, effect, inject, input, signal, ViewChild } from '@angular/core';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import { SatPopoverComponent, SatPopoverModule } from '@ncstate/sat-popover';
5
+ import { TokenizerComponent } from '../tokenizer.component';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@ncstate/sat-popover";
8
+ export class TokenizerOverflowPopoverComponent {
9
+ constructor() {
10
+ this.destroyRef = inject(DestroyRef);
11
+ this.startIndex = signal(0);
12
+ this.changeDetectorRef = inject(ChangeDetectorRef);
13
+ this.tokenizer = input.required();
14
+ this.horizontalAlign = input('after');
15
+ this.verticalAlign = input('start');
16
+ effect(() => {
17
+ this.overflowClickSubscription?.unsubscribe();
18
+ this.overflowClickSubscription = this.tokenizer()
19
+ .overflowPlaceholderClick.pipe(takeUntilDestroyed(this.destroyRef))
20
+ .subscribe(({ startIndex, counterElement }) => {
21
+ this.startIndex.set(startIndex);
22
+ this.popover.anchor = counterElement;
23
+ this.popover.open();
24
+ });
25
+ });
26
+ }
27
+ closePopover() {
28
+ this.popover.close();
29
+ this.changeDetectorRef.detectChanges();
30
+ }
31
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TokenizerOverflowPopoverComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
32
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: TokenizerOverflowPopoverComponent, isStandalone: true, selector: "lx-tokenizer-overflow-popover", inputs: { tokenizer: { classPropertyName: "tokenizer", publicName: "tokenizer", isSignal: true, isRequired: true, transformFunction: null }, horizontalAlign: { classPropertyName: "horizontalAlign", publicName: "horizontalAlign", isSignal: true, isRequired: false, transformFunction: null }, verticalAlign: { classPropertyName: "verticalAlign", publicName: "verticalAlign", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "popoverTemplate", first: true, predicate: ["popoverTemplate"], descendants: true }], viewQueries: [{ propertyName: "popover", first: true, predicate: SatPopoverComponent, descendants: true }], ngImport: i0, template: "<sat-popover\n (backdropClicked)=\"closePopover()\"\n [hasBackdrop]=\"true\"\n [horizontalAlign]=\"horizontalAlign()\"\n [verticalAlign]=\"verticalAlign()\"\n openTransition=\"100ms\"\n closeTransition=\"100ms\"\n>\n @if (popoverTemplate) {\n <div\n class=\"tokenizerPopoverContentWrapper\"\n [class.before]=\"horizontalAlign() === 'before'\"\n [class.after]=\"horizontalAlign() === 'after'\"\n >\n <ng-container *ngTemplateOutlet=\"popoverTemplate; context: { $implicit: startIndex() }\" />\n </div>\n }\n</sat-popover>\n", styles: [".tokenizerPopoverContentWrapper{padding:16px;background:#fff;border-radius:4px;box-shadow:0 8px 14px #5261794d}.tokenizerPopoverContentWrapper.before{margin-right:10px}.tokenizerPopoverContentWrapper.after{margin-left:10px}\n"], dependencies: [{ kind: "ngmodule", type: SatPopoverModule }, { kind: "component", type: i1.SatPopoverComponent, selector: "sat-popover", inputs: ["anchor", "horizontalAlign", "xAlign", "verticalAlign", "yAlign", "forceAlignment", "lockAlignment", "autoFocus", "restoreFocus", "scrollStrategy", "hasBackdrop", "interactiveClose", "openTransition", "closeTransition", "openAnimationStartAtScale", "closeAnimationEndAtScale", "backdropClass", "panelClass"], outputs: ["opened", "closed", "afterOpen", "afterClose", "backdropClicked", "overlayKeydown"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
33
+ }
34
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TokenizerOverflowPopoverComponent, decorators: [{
35
+ type: Component,
36
+ args: [{ selector: 'lx-tokenizer-overflow-popover', standalone: true, imports: [TokenizerComponent, SatPopoverModule, NgTemplateOutlet], changeDetection: ChangeDetectionStrategy.OnPush, template: "<sat-popover\n (backdropClicked)=\"closePopover()\"\n [hasBackdrop]=\"true\"\n [horizontalAlign]=\"horizontalAlign()\"\n [verticalAlign]=\"verticalAlign()\"\n openTransition=\"100ms\"\n closeTransition=\"100ms\"\n>\n @if (popoverTemplate) {\n <div\n class=\"tokenizerPopoverContentWrapper\"\n [class.before]=\"horizontalAlign() === 'before'\"\n [class.after]=\"horizontalAlign() === 'after'\"\n >\n <ng-container *ngTemplateOutlet=\"popoverTemplate; context: { $implicit: startIndex() }\" />\n </div>\n }\n</sat-popover>\n", styles: [".tokenizerPopoverContentWrapper{padding:16px;background:#fff;border-radius:4px;box-shadow:0 8px 14px #5261794d}.tokenizerPopoverContentWrapper.before{margin-right:10px}.tokenizerPopoverContentWrapper.after{margin-left:10px}\n"] }]
37
+ }], ctorParameters: () => [], propDecorators: { popoverTemplate: [{
38
+ type: ContentChild,
39
+ args: ['popoverTemplate']
40
+ }], popover: [{
41
+ type: ViewChild,
42
+ args: [SatPopoverComponent]
43
+ }] } });
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5pemVyLW92ZXJmbG93LXBvcG92ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9jb21wb25lbnRzL3Rva2VuaXplci90b2tlbml6ZXItb3ZlcmZsb3ctcG9wb3Zlci90b2tlbml6ZXItb3ZlcmZsb3ctcG9wb3Zlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL2NvbXBvbmVudHMvdG9rZW5pemVyL3Rva2VuaXplci1vdmVyZmxvdy1wb3BvdmVyL3Rva2VuaXplci1vdmVyZmxvdy1wb3BvdmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxZQUFZLEVBQ1osVUFBVSxFQUNWLE1BQU0sRUFDTixNQUFNLEVBQ04sS0FBSyxFQUNMLE1BQU0sRUFFTixTQUFTLEVBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDaEUsT0FBTyxFQUFFLG1CQUFtQixFQUE2QixnQkFBZ0IsRUFBMkIsTUFBTSxzQkFBc0IsQ0FBQztBQUVqSSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7O0FBUzVELE1BQU0sT0FBTyxpQ0FBaUM7SUFhNUM7UUFaUSxlQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRTlCLGVBQVUsR0FBRyxNQUFNLENBQVMsQ0FBQyxDQUFDLENBQUM7UUFDakMsc0JBQWlCLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFLdEQsY0FBUyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQXNCLENBQUM7UUFDakQsb0JBQWUsR0FBRyxLQUFLLENBQTRCLE9BQU8sQ0FBQyxDQUFDO1FBQzVELGtCQUFhLEdBQUcsS0FBSyxDQUEwQixPQUFPLENBQUMsQ0FBQztRQUd0RCxNQUFNLENBQUMsR0FBRyxFQUFFO1lBQ1YsSUFBSSxDQUFDLHlCQUF5QixFQUFFLFdBQVcsRUFBRSxDQUFDO1lBQzlDLElBQUksQ0FBQyx5QkFBeUIsR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFO2lCQUM5Qyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2lCQUNsRSxTQUFTLENBQUMsQ0FBQyxFQUFFLFVBQVUsRUFBRSxjQUFjLEVBQUUsRUFBRSxFQUFFO2dCQUM1QyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztnQkFDaEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsY0FBYyxDQUFDO2dCQUNyQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3RCLENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRVMsWUFBWTtRQUNwQixJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN6QyxDQUFDOzhHQTdCVSxpQ0FBaUM7a0dBQWpDLGlDQUFpQyx1cUJBT2pDLG1CQUFtQixnRENqQ2hDLGlqQkFrQkEsMFJER2dDLGdCQUFnQiwwZ0JBQUUsZ0JBQWdCOzsyRkFLckQsaUNBQWlDO2tCQVI3QyxTQUFTOytCQUNFLCtCQUErQixjQUM3QixJQUFJLFdBQ1AsQ0FBQyxrQkFBa0IsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsQ0FBQyxtQkFHaEQsdUJBQXVCLENBQUMsTUFBTTt3REFRSyxlQUFlO3NCQUFsRSxZQUFZO3VCQUFDLGlCQUFpQjtnQkFDb0IsT0FBTztzQkFBekQsU0FBUzt1QkFBQyxtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ1RlbXBsYXRlT3V0bGV0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgQ29tcG9uZW50LFxuICBDb250ZW50Q2hpbGQsXG4gIERlc3Ryb3lSZWYsXG4gIGVmZmVjdCxcbiAgaW5qZWN0LFxuICBpbnB1dCxcbiAgc2lnbmFsLFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0NoaWxkXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgdGFrZVVudGlsRGVzdHJveWVkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuaW1wb3J0IHsgU2F0UG9wb3ZlckNvbXBvbmVudCwgU2F0UG9wb3Zlckhvcml6b250YWxBbGlnbiwgU2F0UG9wb3Zlck1vZHVsZSwgU2F0UG9wb3ZlclZlcnRpY2FsQWxpZ24gfSBmcm9tICdAbmNzdGF0ZS9zYXQtcG9wb3Zlcic7XG5pbXBvcnQgeyBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IFRva2VuaXplckNvbXBvbmVudCB9IGZyb20gJy4uL3Rva2VuaXplci5jb21wb25lbnQnO1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtdG9rZW5pemVyLW92ZXJmbG93LXBvcG92ZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbVG9rZW5pemVyQ29tcG9uZW50LCBTYXRQb3BvdmVyTW9kdWxlLCBOZ1RlbXBsYXRlT3V0bGV0XSxcbiAgdGVtcGxhdGVVcmw6ICcuL3Rva2VuaXplci1vdmVyZmxvdy1wb3BvdmVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vdG9rZW5pemVyLW92ZXJmbG93LXBvcG92ZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgVG9rZW5pemVyT3ZlcmZsb3dQb3BvdmVyQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSBkZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpO1xuICBwcml2YXRlIG92ZXJmbG93Q2xpY2tTdWJzY3JpcHRpb24/OiBTdWJzY3JpcHRpb247XG4gIHByb3RlY3RlZCBzdGFydEluZGV4ID0gc2lnbmFsPG51bWJlcj4oMCk7XG4gIHByaXZhdGUgY2hhbmdlRGV0ZWN0b3JSZWYgPSBpbmplY3QoQ2hhbmdlRGV0ZWN0b3JSZWYpO1xuXG4gIEBDb250ZW50Q2hpbGQoJ3BvcG92ZXJUZW1wbGF0ZScpIHByb3RlY3RlZCByZWFkb25seSBwb3BvdmVyVGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjx1bmtub3duPjtcbiAgQFZpZXdDaGlsZChTYXRQb3BvdmVyQ29tcG9uZW50KSBwcm90ZWN0ZWQgcmVhZG9ubHkgcG9wb3ZlciE6IFNhdFBvcG92ZXJDb21wb25lbnQ7XG5cbiAgdG9rZW5pemVyID0gaW5wdXQucmVxdWlyZWQ8VG9rZW5pemVyQ29tcG9uZW50PigpO1xuICBob3Jpem9udGFsQWxpZ24gPSBpbnB1dDxTYXRQb3BvdmVySG9yaXpvbnRhbEFsaWduPignYWZ0ZXInKTtcbiAgdmVydGljYWxBbGlnbiA9IGlucHV0PFNhdFBvcG92ZXJWZXJ0aWNhbEFsaWduPignc3RhcnQnKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBlZmZlY3QoKCkgPT4ge1xuICAgICAgdGhpcy5vdmVyZmxvd0NsaWNrU3Vic2NyaXB0aW9uPy51bnN1YnNjcmliZSgpO1xuICAgICAgdGhpcy5vdmVyZmxvd0NsaWNrU3Vic2NyaXB0aW9uID0gdGhpcy50b2tlbml6ZXIoKVxuICAgICAgICAub3ZlcmZsb3dQbGFjZWhvbGRlckNsaWNrLnBpcGUodGFrZVVudGlsRGVzdHJveWVkKHRoaXMuZGVzdHJveVJlZikpXG4gICAgICAgIC5zdWJzY3JpYmUoKHsgc3RhcnRJbmRleCwgY291bnRlckVsZW1lbnQgfSkgPT4ge1xuICAgICAgICAgIHRoaXMuc3RhcnRJbmRleC5zZXQoc3RhcnRJbmRleCk7XG4gICAgICAgICAgdGhpcy5wb3BvdmVyLmFuY2hvciA9IGNvdW50ZXJFbGVtZW50O1xuICAgICAgICAgIHRoaXMucG9wb3Zlci5vcGVuKCk7XG4gICAgICAgIH0pO1xuICAgIH0pO1xuICB9XG5cbiAgcHJvdGVjdGVkIGNsb3NlUG9wb3ZlcigpOiB2b2lkIHtcbiAgICB0aGlzLnBvcG92ZXIuY2xvc2UoKTtcbiAgICB0aGlzLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgfVxufVxuIiwiPHNhdC1wb3BvdmVyXG4gIChiYWNrZHJvcENsaWNrZWQpPVwiY2xvc2VQb3BvdmVyKClcIlxuICBbaGFzQmFja2Ryb3BdPVwidHJ1ZVwiXG4gIFtob3Jpem9udGFsQWxpZ25dPVwiaG9yaXpvbnRhbEFsaWduKClcIlxuICBbdmVydGljYWxBbGlnbl09XCJ2ZXJ0aWNhbEFsaWduKClcIlxuICBvcGVuVHJhbnNpdGlvbj1cIjEwMG1zXCJcbiAgY2xvc2VUcmFuc2l0aW9uPVwiMTAwbXNcIlxuPlxuICBAaWYgKHBvcG92ZXJUZW1wbGF0ZSkge1xuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwidG9rZW5pemVyUG9wb3ZlckNvbnRlbnRXcmFwcGVyXCJcbiAgICAgIFtjbGFzcy5iZWZvcmVdPVwiaG9yaXpvbnRhbEFsaWduKCkgPT09ICdiZWZvcmUnXCJcbiAgICAgIFtjbGFzcy5hZnRlcl09XCJob3Jpem9udGFsQWxpZ24oKSA9PT0gJ2FmdGVyJ1wiXG4gICAgPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cInBvcG92ZXJUZW1wbGF0ZTsgY29udGV4dDogeyAkaW1wbGljaXQ6IHN0YXJ0SW5kZXgoKSB9XCIgLz5cbiAgICA8L2Rpdj5cbiAgfVxuPC9zYXQtcG9wb3Zlcj5cbiJdfQ==
@@ -87,11 +87,11 @@ export class TokenizerComponent {
87
87
  this.changeDetectorRef.detectChanges();
88
88
  }
89
89
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TokenizerComponent, deps: [{ token: i0.ElementRef }, { token: i0.DestroyRef }, { token: i0.ChangeDetectorRef }, { token: i1.ResizeObserverService }], target: i0.ɵɵFactoryTarget.Component }); }
90
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: TokenizerComponent, isStandalone: true, selector: "lx-tokenizer", inputs: { active: { classPropertyName: "active", publicName: "active", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { overflowPlaceholderClick: "overflowPlaceholderClick" }, queries: [{ propertyName: "items", predicate: TokenComponent }], viewQueries: [{ propertyName: "counter", first: true, predicate: ["counter"], descendants: true, read: ElementRef }, { propertyName: "tokensContainer", first: true, predicate: ["tokensContainer"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div #tokensContainer class=\"tokensContainer\">\n <ng-content select=\"lx-token\" />\n @if (showCounter()) {\n <button\n lx-button\n class=\"counterButton\"\n mode=\"ghost\"\n (click)=\"onCounterClicked()\"\n [attr.aria-label]=\"\n NAME + (overflowItemCount() === 1 ? '.showMoreItem' : '.showMoreItems') | translate: { count: overflowItemCount() }\n \"\n >\n <lx-counter #counter aria-hidden=\"true\" [content]=\"'+' + overflowItemCount()\" color=\"gray\" />\n </button>\n }\n</div>\n", styles: [":host{display:flex;align-items:center;white-space:nowrap}:host .counterButton{padding:0;display:flex;align-items:center;margin-left:4px}.tokensContainer{display:flex;align-items:center}\n"], dependencies: [{ kind: "component", type: CounterComponent, selector: "lx-counter", inputs: ["content", "size", "color"] }, { kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "showSpinner"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
90
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: TokenizerComponent, isStandalone: true, selector: "lx-tokenizer", inputs: { active: { classPropertyName: "active", publicName: "active", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { overflowPlaceholderClick: "overflowPlaceholderClick" }, queries: [{ propertyName: "items", predicate: TokenComponent }], viewQueries: [{ propertyName: "counter", first: true, predicate: ["counter"], descendants: true, read: ElementRef }, { propertyName: "tokensContainer", first: true, predicate: ["tokensContainer"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div #tokensContainer class=\"tokensContainer\">\n <ng-content select=\"lx-token\" />\n @if (showCounter()) {\n <button\n lx-button\n class=\"counterButton\"\n mode=\"ghost\"\n (click)=\"onCounterClicked()\"\n [attr.aria-label]=\"\n NAME + (overflowItemCount() === 1 ? '.showMoreItem' : '.showMoreItems') | translate: { count: overflowItemCount() }\n \"\n >\n <lx-counter #counter aria-hidden=\"true\" [content]=\"'+' + overflowItemCount()\" color=\"gray\" />\n </button>\n }\n</div>\n", styles: [":host{display:flex;align-items:center;white-space:nowrap}:host .counterButton{padding:0;display:flex;align-items:center;margin-left:4px;border-radius:12px}.tokensContainer{display:flex;align-items:center}\n"], dependencies: [{ kind: "component", type: CounterComponent, selector: "lx-counter", inputs: ["content", "size", "color"] }, { kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "showSpinner"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
91
91
  }
92
92
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TokenizerComponent, decorators: [{
93
93
  type: Component,
94
- args: [{ selector: 'lx-tokenizer', standalone: true, imports: [NgIf, CounterComponent, ButtonComponent, TranslateModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #tokensContainer class=\"tokensContainer\">\n <ng-content select=\"lx-token\" />\n @if (showCounter()) {\n <button\n lx-button\n class=\"counterButton\"\n mode=\"ghost\"\n (click)=\"onCounterClicked()\"\n [attr.aria-label]=\"\n NAME + (overflowItemCount() === 1 ? '.showMoreItem' : '.showMoreItems') | translate: { count: overflowItemCount() }\n \"\n >\n <lx-counter #counter aria-hidden=\"true\" [content]=\"'+' + overflowItemCount()\" color=\"gray\" />\n </button>\n }\n</div>\n", styles: [":host{display:flex;align-items:center;white-space:nowrap}:host .counterButton{padding:0;display:flex;align-items:center;margin-left:4px}.tokensContainer{display:flex;align-items:center}\n"] }]
94
+ args: [{ selector: 'lx-tokenizer', standalone: true, imports: [NgIf, CounterComponent, ButtonComponent, TranslateModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #tokensContainer class=\"tokensContainer\">\n <ng-content select=\"lx-token\" />\n @if (showCounter()) {\n <button\n lx-button\n class=\"counterButton\"\n mode=\"ghost\"\n (click)=\"onCounterClicked()\"\n [attr.aria-label]=\"\n NAME + (overflowItemCount() === 1 ? '.showMoreItem' : '.showMoreItems') | translate: { count: overflowItemCount() }\n \"\n >\n <lx-counter #counter aria-hidden=\"true\" [content]=\"'+' + overflowItemCount()\" color=\"gray\" />\n </button>\n }\n</div>\n", styles: [":host{display:flex;align-items:center;white-space:nowrap}:host .counterButton{padding:0;display:flex;align-items:center;margin-left:4px;border-radius:12px}.tokensContainer{display:flex;align-items:center}\n"] }]
95
95
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.DestroyRef }, { type: i0.ChangeDetectorRef }, { type: i1.ResizeObserverService }], propDecorators: { overflowPlaceholderClick: [{
96
96
  type: Output
97
97
  }], items: [{
@@ -104,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
104
104
  type: ViewChild,
105
105
  args: ['tokensContainer', { read: ElementRef }]
106
106
  }] } });
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokenizer.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/core-ui/components/tokenizer/tokenizer.component.ts","../../../../../../../../libs/components/src/lib/core-ui/components/tokenizer/tokenizer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  computed,\n  ContentChildren,\n  DestroyRef,\n  effect,\n  ElementRef,\n  EventEmitter,\n  input,\n  Output,\n  QueryList,\n  signal,\n  ViewChild\n} from '@angular/core';\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { combineLatest } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter, map, startWith } from 'rxjs/operators';\nimport { ButtonComponent } from '../../components/button/button.component';\nimport { CounterComponent } from '../../components/counter/counter.component';\nimport { ResizeObserverService } from '../../services/resize-observer.service';\nimport { TokenComponent } from './token/token.component';\n\n@Component({\n  selector: 'lx-tokenizer',\n  standalone: true,\n  templateUrl: './tokenizer.component.html',\n  styleUrls: ['./tokenizer.component.scss'],\n  imports: [NgIf, CounterComponent, ButtonComponent, TranslateModule],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TokenizerComponent implements AfterContentInit {\n  readonly NAME = 'TokenizerComponent';\n\n  protected overflowItems = signal<TokenComponent[]>([]);\n  protected overflowItemCount = computed(() => this.overflowItems().length);\n  protected showCounter = computed(() => this.active() && this.overflowItemCount() > 0);\n\n  active = input(true);\n  private active$ = toObservable(this.active);\n  private overflowStartIndex = signal<number | null>(null);\n\n  /**\n   * Emitted when the counter button is clicked\n   * @param startIndex The index of the first overflowing element\n   * @param counterElement The counter button element\n   */\n  @Output() overflowPlaceholderClick = new EventEmitter<{ startIndex: number; counterElement: ElementRef<HTMLElement> }>();\n\n  @ContentChildren(TokenComponent) items?: QueryList<TokenComponent>;\n  @ViewChild('counter', { read: ElementRef }) counter?: ElementRef<HTMLElement>;\n  @ViewChild('tokensContainer', { read: ElementRef }) tokensContainer!: ElementRef<HTMLElement>;\n\n  constructor(\n    private elementRef: ElementRef<HTMLElement>,\n    private destroyRef: DestroyRef,\n    private changeDetectorRef: ChangeDetectorRef,\n    private resizeObserverService: ResizeObserverService\n  ) {\n    effect(() => {\n      // Whenever the tokenizer is disabled, ensure all tokens are shown\n      if (!this.active()) {\n        this.items!.forEach((item) => item.show());\n      }\n    });\n  }\n\n  ngAfterContentInit() {\n    const containerWidth = this.resizeObserverService.createResizeObservable(this.elementRef.nativeElement).pipe(\n      map((entry) => entry.contentRect.width ?? 0),\n      debounceTime(16),\n      distinctUntilChanged()\n    );\n    const itemsChanged$ = this.items!.changes;\n\n    combineLatest([\n      this.active$,\n      containerWidth.pipe(startWith(this.elementRef.nativeElement.getBoundingClientRect().width)),\n      itemsChanged$.pipe(startWith(this.items))\n    ])\n      .pipe(\n        filter(([active]) => active),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe(([, containerWidth]) => {\n        this.tokenize(containerWidth);\n      });\n  }\n\n  onCounterClicked(): void {\n    const startIndex = this.overflowStartIndex();\n    if (typeof startIndex === 'number') {\n      this.overflowPlaceholderClick.emit({ startIndex, counterElement: this.counter! });\n    }\n  }\n\n  private tokenize(containerWidth: number): void {\n    if (!this.items) {\n      return;\n    }\n\n    this.items.forEach((item) => item.hide());\n    this.overflowItems.set([]);\n    this.changeDetectorRef.detectChanges();\n\n    let index = 0;\n    for (const item of this.items) {\n      item.show();\n      const usedWidth = this.tokensContainer.nativeElement.getBoundingClientRect().width;\n      if (usedWidth > containerWidth) {\n        item.hide();\n        this.updateOverflowCounter(index);\n\n        const usedWidthIncludingCounter = this.tokensContainer.nativeElement.getBoundingClientRect().width;\n        if (usedWidthIncludingCounter > containerWidth && index >= 1) {\n          const previousItem = this.items.toArray()[index - 1];\n          previousItem?.hide();\n          this.updateOverflowCounter(index - 1);\n        }\n\n        break;\n      }\n      index++;\n    }\n  }\n\n  private updateOverflowCounter(index: number) {\n    this.overflowStartIndex.set(index);\n\n    const overflowingItems = this.items?.toArray().slice(index) ?? [];\n    this.overflowItems.set(overflowingItems);\n    this.changeDetectorRef.detectChanges();\n  }\n}\n","<div #tokensContainer class=\"tokensContainer\">\n  <ng-content select=\"lx-token\" />\n  @if (showCounter()) {\n    <button\n      lx-button\n      class=\"counterButton\"\n      mode=\"ghost\"\n      (click)=\"onCounterClicked()\"\n      [attr.aria-label]=\"\n        NAME + (overflowItemCount() === 1 ? '.showMoreItem' : '.showMoreItems') | translate: { count: overflowItemCount() }\n      \"\n    >\n      <lx-counter #counter aria-hidden=\"true\" [content]=\"'+' + overflowItemCount()\" color=\"gray\" />\n    </button>\n  }\n</div>\n"]}
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokenizer.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/core-ui/components/tokenizer/tokenizer.component.ts","../../../../../../../../libs/components/src/lib/core-ui/components/tokenizer/tokenizer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  computed,\n  ContentChildren,\n  DestroyRef,\n  effect,\n  ElementRef,\n  EventEmitter,\n  input,\n  Output,\n  QueryList,\n  signal,\n  ViewChild\n} from '@angular/core';\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { combineLatest } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter, map, startWith } from 'rxjs/operators';\nimport { ButtonComponent } from '../../components/button/button.component';\nimport { CounterComponent } from '../../components/counter/counter.component';\nimport { ResizeObserverService } from '../../services/resize-observer.service';\nimport { TokenComponent } from './token/token.component';\n\n@Component({\n  selector: 'lx-tokenizer',\n  standalone: true,\n  templateUrl: './tokenizer.component.html',\n  styleUrls: ['./tokenizer.component.scss'],\n  imports: [NgIf, CounterComponent, ButtonComponent, TranslateModule],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TokenizerComponent implements AfterContentInit {\n  readonly NAME = 'TokenizerComponent';\n\n  protected overflowItems = signal<TokenComponent[]>([]);\n  protected overflowItemCount = computed(() => this.overflowItems().length);\n  protected showCounter = computed(() => this.active() && this.overflowItemCount() > 0);\n\n  active = input(true);\n  private active$ = toObservable(this.active);\n  private overflowStartIndex = signal<number | null>(null);\n\n  /**\n   * Emitted when the counter button is clicked\n   * @param startIndex The index of the first overflowing element\n   * @param counterElement The counter button element\n   */\n  @Output() overflowPlaceholderClick = new EventEmitter<{ startIndex: number; counterElement: ElementRef<HTMLElement> }>();\n\n  @ContentChildren(TokenComponent) items?: QueryList<TokenComponent>;\n  @ViewChild('counter', { read: ElementRef }) counter?: ElementRef<HTMLElement>;\n  @ViewChild('tokensContainer', { read: ElementRef }) tokensContainer!: ElementRef<HTMLElement>;\n\n  constructor(\n    private elementRef: ElementRef<HTMLElement>,\n    private destroyRef: DestroyRef,\n    private changeDetectorRef: ChangeDetectorRef,\n    private resizeObserverService: ResizeObserverService\n  ) {\n    effect(() => {\n      // Whenever the tokenizer is disabled, ensure all tokens are shown\n      if (!this.active()) {\n        this.items!.forEach((item) => item.show());\n      }\n    });\n  }\n\n  ngAfterContentInit() {\n    const containerWidth = this.resizeObserverService.createResizeObservable(this.elementRef.nativeElement).pipe(\n      map((entry) => entry.contentRect.width ?? 0),\n      debounceTime(16),\n      distinctUntilChanged()\n    );\n    const itemsChanged$ = this.items!.changes;\n\n    combineLatest([\n      this.active$,\n      containerWidth.pipe(startWith(this.elementRef.nativeElement.getBoundingClientRect().width)),\n      itemsChanged$.pipe(startWith(this.items))\n    ])\n      .pipe(\n        filter(([active]) => active),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe(([, containerWidth]) => {\n        this.tokenize(containerWidth);\n      });\n  }\n\n  onCounterClicked(): void {\n    const startIndex = this.overflowStartIndex();\n    if (typeof startIndex === 'number') {\n      this.overflowPlaceholderClick.emit({ startIndex, counterElement: this.counter! });\n    }\n  }\n\n  private tokenize(containerWidth: number): void {\n    if (!this.items) {\n      return;\n    }\n\n    this.items.forEach((item) => item.hide());\n    this.overflowItems.set([]);\n    this.changeDetectorRef.detectChanges();\n\n    let index = 0;\n    for (const item of this.items) {\n      item.show();\n      const usedWidth = this.tokensContainer.nativeElement.getBoundingClientRect().width;\n      if (usedWidth > containerWidth) {\n        item.hide();\n        this.updateOverflowCounter(index);\n\n        const usedWidthIncludingCounter = this.tokensContainer.nativeElement.getBoundingClientRect().width;\n        if (usedWidthIncludingCounter > containerWidth && index >= 1) {\n          const previousItem = this.items.toArray()[index - 1];\n          previousItem?.hide();\n          this.updateOverflowCounter(index - 1);\n        }\n\n        break;\n      }\n      index++;\n    }\n  }\n\n  private updateOverflowCounter(index: number) {\n    this.overflowStartIndex.set(index);\n\n    const overflowingItems = this.items?.toArray().slice(index) ?? [];\n    this.overflowItems.set(overflowingItems);\n    this.changeDetectorRef.detectChanges();\n  }\n}\n","<div #tokensContainer class=\"tokensContainer\">\n  <ng-content select=\"lx-token\" />\n  @if (showCounter()) {\n    <button\n      lx-button\n      class=\"counterButton\"\n      mode=\"ghost\"\n      (click)=\"onCounterClicked()\"\n      [attr.aria-label]=\"\n        NAME + (overflowItemCount() === 1 ? '.showMoreItem' : '.showMoreItems') | translate: { count: overflowItemCount() }\n      \"\n    >\n      <lx-counter #counter aria-hidden=\"true\" [content]=\"'+' + overflowItemCount()\" color=\"gray\" />\n    </button>\n  }\n</div>\n"]}
@@ -6,7 +6,19 @@ import { TooltipComponent } from './tooltip.component';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/cdk/overlay";
8
8
  import * as i2 from "@angular/cdk/a11y";
9
+ /**
10
+ * Tooltip directive is used to show a tooltip on hover or focus on an element.
11
+ *
12
+ * ## Usage
13
+ *
14
+ * 1. Import the `TooltipDirective` component from `@leanix/components` in your module or standalone copmonent where you want to use the component.
15
+ *
16
+ * ```ts
17
+ * import { TooltipDirective } from '@leanix/components';
18
+ * ```
19
+ */
9
20
  export class TooltipDirective {
21
+ /** The position of the tooltip. */
10
22
  set lxTooltipPosition(value) {
11
23
  this.position = {
12
24
  x: value && isValidX(value.x) ? value.x : 'center',
@@ -25,6 +37,7 @@ export class TooltipDirective {
25
37
  x: 'center',
26
38
  y: 'top'
27
39
  };
40
+ /** Whether the tooltip content is HTML. */
28
41
  this.lxTooltipIsHtmlContent = false;
29
42
  this.mouseOrFocusOnHost = false;
30
43
  }
@@ -50,6 +63,7 @@ export class TooltipDirective {
50
63
  }
51
64
  }
52
65
  }
66
+ /** @internal */
53
67
  show() {
54
68
  this.mouseOrFocusOnHost = true;
55
69
  setTimeout(() => {
@@ -68,6 +82,7 @@ export class TooltipDirective {
68
82
  this.mouseOrFocusOnHost = false;
69
83
  this.overlayRef?.dispose();
70
84
  }
85
+ /** @internal */
71
86
  hide() {
72
87
  this.mouseOrFocusOnHost = false;
73
88
  this.ariaDescriber.removeDescription(this.elementRef.nativeElement, this.tooltipRef?.location.nativeElement);
@@ -107,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
107
122
  type: HostListener,
108
123
  args: ['blur']
109
124
  }] } });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/core-ui/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AriaDescriber } from '@angular/cdk/a11y';\nimport { Overlay, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, Directive, ElementRef, HostListener, Input, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';\nimport { toCdkPosition } from './to-cdk-position.function';\nimport { TooltipPosition, isValidX, isValidY } from './tooltip-position.interface';\nimport { TooltipComponent } from './tooltip.component';\n\n@Directive({\n  selector: '[lxTooltip]',\n  standalone: true\n})\nexport class TooltipDirective implements OnChanges, OnDestroy {\n  @Input('lxTooltip') content?: string | null;\n  @Input() set lxTooltipPosition(value: { x: string; y: string } | undefined) {\n    this.position = {\n      x: value && isValidX(value.x) ? value.x : 'center',\n      y: value && isValidY(value.y) ? value.y : 'top'\n    };\n  }\n  private position: TooltipPosition = {\n    x: 'center',\n    y: 'top'\n  };\n  @Input() lxTooltipDelay?: number;\n  @Input() lxTooltipIsHtmlContent: boolean = false;\n\n  private overlayRef?: OverlayRef;\n  private tooltipRef?: ComponentRef<TooltipComponent>;\n  private mouseOrFocusOnHost: boolean = false;\n\n  get positionStrategy() {\n    return this.overlayPositionBuilder.flexibleConnectedTo(this.elementRef).withPositions([toCdkPosition(this.position)]);\n  }\n\n  constructor(\n    private overlayPositionBuilder: OverlayPositionBuilder,\n    private elementRef: ElementRef,\n    private overlay: Overlay,\n    private ariaDescriber: AriaDescriber\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.overlayRef && changes['lxTooltipPosition']) {\n      this.overlayRef.updatePositionStrategy(this.positionStrategy);\n    }\n    if (this.tooltipRef) {\n      if (changes['lxTooltipPosition']) {\n        this.tooltipRef.instance.position = this.position;\n      }\n      if (changes['lxTooltipIsHtmlContent']) {\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n      }\n      if (changes['content']) {\n        if (this.content) {\n          this.tooltipRef.instance.content = this.content;\n          this.overlayRef?.updatePosition();\n        } else {\n          this.overlayRef?.detach();\n        }\n      }\n    }\n  }\n\n  @HostListener('mouseenter')\n  @HostListener('focus')\n  show() {\n    this.mouseOrFocusOnHost = true;\n    setTimeout(() => {\n      if (!this.overlayRef?.hasAttached() && this.mouseOrFocusOnHost && this.content) {\n        this.overlayRef = this.overlay.create({ positionStrategy: this.positionStrategy });\n        const tooltipPortal = new ComponentPortal(TooltipComponent);\n        this.tooltipRef = this.overlayRef.attach(tooltipPortal);\n        this.tooltipRef.instance.content = this.content;\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n        this.tooltipRef.instance.position = this.position;\n        this.ariaDescriber.describe(this.elementRef.nativeElement, this.tooltipRef.location.nativeElement);\n      }\n    }, this.lxTooltipDelay ?? 90);\n  }\n\n  ngOnDestroy() {\n    this.mouseOrFocusOnHost = false;\n    this.overlayRef?.dispose();\n  }\n\n  @HostListener('mouseleave')\n  @HostListener('click')\n  @HostListener('blur')\n  hide() {\n    this.mouseOrFocusOnHost = false;\n    this.ariaDescriber.removeDescription(this.elementRef.nativeElement, this.tooltipRef?.location.nativeElement);\n    this.overlayRef?.dispose();\n  }\n}\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/core-ui/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AriaDescriber } from '@angular/cdk/a11y';\nimport { Overlay, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, Directive, ElementRef, HostListener, Input, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';\nimport { toCdkPosition } from './to-cdk-position.function';\nimport { TooltipPosition, isValidX, isValidY } from './tooltip-position.interface';\nimport { TooltipComponent } from './tooltip.component';\n\n/**\n * Tooltip directive is used to show a tooltip on hover or focus on an element.\n *\n * ## Usage\n *\n * 1. Import the `TooltipDirective` component from `@leanix/components` in your module or standalone copmonent where you want to use the component.\n *\n * ```ts\n * import { TooltipDirective } from '@leanix/components';\n * ```\n */\n@Directive({\n  selector: '[lxTooltip]',\n  standalone: true\n})\nexport class TooltipDirective implements OnChanges, OnDestroy {\n  /** The content of the tooltip. */\n  @Input('lxTooltip') content?: string | null;\n  /** The position of the tooltip. */\n  @Input() set lxTooltipPosition(value: { x: string; y: string } | undefined) {\n    this.position = {\n      x: value && isValidX(value.x) ? value.x : 'center',\n      y: value && isValidY(value.y) ? value.y : 'top'\n    };\n  }\n  private position: TooltipPosition = {\n    x: 'center',\n    y: 'top'\n  };\n  /** The delay in milliseconds before the tooltip is shown. */\n  @Input() lxTooltipDelay?: number;\n  /** Whether the tooltip content is HTML. */\n  @Input() lxTooltipIsHtmlContent: boolean = false;\n\n  private overlayRef?: OverlayRef;\n  private tooltipRef?: ComponentRef<TooltipComponent>;\n  private mouseOrFocusOnHost: boolean = false;\n\n  get positionStrategy() {\n    return this.overlayPositionBuilder.flexibleConnectedTo(this.elementRef).withPositions([toCdkPosition(this.position)]);\n  }\n\n  constructor(\n    private overlayPositionBuilder: OverlayPositionBuilder,\n    private elementRef: ElementRef,\n    private overlay: Overlay,\n    private ariaDescriber: AriaDescriber\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.overlayRef && changes['lxTooltipPosition']) {\n      this.overlayRef.updatePositionStrategy(this.positionStrategy);\n    }\n    if (this.tooltipRef) {\n      if (changes['lxTooltipPosition']) {\n        this.tooltipRef.instance.position = this.position;\n      }\n      if (changes['lxTooltipIsHtmlContent']) {\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n      }\n      if (changes['content']) {\n        if (this.content) {\n          this.tooltipRef.instance.content = this.content;\n          this.overlayRef?.updatePosition();\n        } else {\n          this.overlayRef?.detach();\n        }\n      }\n    }\n  }\n\n  /** @internal */\n  @HostListener('mouseenter')\n  @HostListener('focus')\n  show() {\n    this.mouseOrFocusOnHost = true;\n    setTimeout(() => {\n      if (!this.overlayRef?.hasAttached() && this.mouseOrFocusOnHost && this.content) {\n        this.overlayRef = this.overlay.create({ positionStrategy: this.positionStrategy });\n        const tooltipPortal = new ComponentPortal(TooltipComponent);\n        this.tooltipRef = this.overlayRef.attach(tooltipPortal);\n        this.tooltipRef.instance.content = this.content;\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n        this.tooltipRef.instance.position = this.position;\n        this.ariaDescriber.describe(this.elementRef.nativeElement, this.tooltipRef.location.nativeElement);\n      }\n    }, this.lxTooltipDelay ?? 90);\n  }\n\n  ngOnDestroy() {\n    this.mouseOrFocusOnHost = false;\n    this.overlayRef?.dispose();\n  }\n\n  /** @internal */\n  @HostListener('mouseleave')\n  @HostListener('click')\n  @HostListener('blur')\n  hide() {\n    this.mouseOrFocusOnHost = false;\n    this.ariaDescriber.removeDescription(this.elementRef.nativeElement, this.tooltipRef?.location.nativeElement);\n    this.overlayRef?.dispose();\n  }\n}\n"]}
@@ -4,9 +4,24 @@ import { KeyboardActionSourceDirective } from '../../directives/keyboard-action-
4
4
  import { CdkOptionsDropdownComponent } from '../cdk-options-dropdown/cdk-options-dropdown.component';
5
5
  import { OptionComponent } from '../option/option.component';
6
6
  import * as i0 from "@angular/core";
7
+ /**
8
+ * Breadcrumb component is used to show a list of labels, usually to show the path of user's navigation.
9
+ *
10
+ * ## Usage
11
+ *
12
+ * 1. Import the LxFormsModule module from @leanix/components in your module where you want to use the component.
13
+ *
14
+ * ```ts
15
+ * import { LxFormsModule } from '@leanix/components';
16
+ * ```
17
+ */
7
18
  export class BreadcrumbComponent {
8
19
  constructor() {
20
+ /**
21
+ * Breadcrumbs array to build the component.
22
+ */
9
23
  this.breadcrumbs = [];
24
+ /** @internal */
10
25
  this.viewBreadcrumbs = [];
11
26
  }
12
27
  ngOnChanges(changes) {
@@ -32,6 +47,7 @@ export class BreadcrumbComponent {
32
47
  }, []);
33
48
  }
34
49
  }
50
+ /** @internal */
35
51
  isEllipsedBreadcrumb(breadcrumb) {
36
52
  return !!breadcrumb.breadcrumbs;
37
53
  }
@@ -44,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
44
60
  }], propDecorators: { breadcrumbs: [{
45
61
  type: Input
46
62
  }] } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2JyZWFkY3J1bWIvYnJlYWRjcnVtYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2JyZWFkY3J1bWIvYnJlYWRjcnVtYi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQTRCLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ2xHLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQ3JHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFxQjdELE1BQU0sT0FBTyxtQkFBbUI7SUFQaEM7UUFRVyxnQkFBVyxHQUFpQixFQUFFLENBQUM7UUFFeEMsb0JBQWUsR0FBcUIsRUFBRSxDQUFDO0tBMkJ4QztJQXpCQyxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsYUFBYSxDQUFDLEVBQUUsQ0FBQztZQUMzQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUMsZUFBZSxFQUFFLFVBQVUsRUFBRSxFQUFFO2dCQUM3RSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDO29CQUN6QixnRUFBZ0U7b0JBQ2hFLGVBQWUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7Z0JBQ25DLENBQUM7cUJBQU0sQ0FBQztvQkFDTixvRkFBb0Y7b0JBQ3BGLE1BQU0sY0FBYyxHQUFHLGVBQWUsQ0FBQyxlQUFlLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO29CQUNuRSxJQUFJLGNBQWMsSUFBSSxJQUFJLENBQUMsb0JBQW9CLENBQUMsY0FBYyxDQUFDLEVBQUUsQ0FBQzt3QkFDaEUsY0FBYyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7b0JBQzlDLENBQUM7eUJBQU0sQ0FBQzt3QkFDTixlQUFlLENBQUMsSUFBSSxDQUFDOzRCQUNuQixXQUFXLEVBQUUsQ0FBQyxVQUFVLENBQUM7eUJBQzFCLENBQUMsQ0FBQztvQkFDTCxDQUFDO2dCQUNILENBQUM7Z0JBQ0QsT0FBTyxlQUFlLENBQUM7WUFDekIsQ0FBQyxFQUFFLEVBQXNCLENBQUMsQ0FBQztRQUM3QixDQUFDO0lBQ0gsQ0FBQztJQUVELG9CQUFvQixDQUFDLFVBQTBCO1FBQzdDLE9BQU8sQ0FBQyxDQUFFLFVBQWlDLENBQUMsV0FBVyxDQUFDO0lBQzFELENBQUM7OEdBN0JVLG1CQUFtQjtrR0FBbkIsbUJBQW1CLHNJQ3pCaEMsOHpCQW9CQSw4YkRHWSxZQUFZLCtCQUFFLDJCQUEyQixpSUFBRSw2QkFBNkIseUdBQUUsZUFBZTs7MkZBRXhGLG1CQUFtQjtrQkFQL0IsU0FBUzsrQkFDRSxlQUFlLGNBR2IsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLDJCQUEyQixFQUFFLDZCQUE2QixFQUFFLGVBQWUsQ0FBQzs4QkFHM0YsV0FBVztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEtleWJvYXJkQWN0aW9uU291cmNlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZGlyZWN0aXZlcy9rZXlib2FyZC1hY3Rpb24tc291cmNlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBDZGtPcHRpb25zRHJvcGRvd25Db21wb25lbnQgfSBmcm9tICcuLi9jZGstb3B0aW9ucy1kcm9wZG93bi9jZGstb3B0aW9ucy1kcm9wZG93bi5jb21wb25lbnQnO1xuaW1wb3J0IHsgT3B0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vb3B0aW9uL29wdGlvbi5jb21wb25lbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJyZWFkY3J1bWIge1xuICBsYWJlbDogc3RyaW5nO1xuICBlbGxpcHNlZD86IGJvb2xlYW47XG4gIG9uQ2xpY2s/OiAoYnJlYWRjcnVtYjogQnJlYWRjcnVtYikgPT4gdm9pZDtcbn1cblxuaW50ZXJmYWNlIEVsbGlwc2VkQnJlYWRjcnVtYiB7XG4gIGJyZWFkY3J1bWJzOiBCcmVhZGNydW1iW107XG59XG5cbnR5cGUgVmlld0JyZWFkY3J1bWIgPSBCcmVhZGNydW1iIHwgRWxsaXBzZWRCcmVhZGNydW1iO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdseC1icmVhZGNydW1iJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2JyZWFkY3J1bWIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9icmVhZGNydW1iLmNvbXBvbmVudC5zY3NzJ10sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIENka09wdGlvbnNEcm9wZG93bkNvbXBvbmVudCwgS2V5Ym9hcmRBY3Rpb25Tb3VyY2VEaXJlY3RpdmUsIE9wdGlvbkNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQnJlYWRjcnVtYkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpIGJyZWFkY3J1bWJzOiBCcmVhZGNydW1iW10gPSBbXTtcblxuICB2aWV3QnJlYWRjcnVtYnM6IFZpZXdCcmVhZGNydW1iW10gPSBbXTtcblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgaWYgKGNoYW5nZXNbJ2JyZWFkY3J1bWJzJ10pIHtcbiAgICAgIHRoaXMudmlld0JyZWFkY3J1bWJzID0gdGhpcy5icmVhZGNydW1icy5yZWR1Y2UoKHZpZXdCcmVhZGNydW1icywgYnJlYWRjcnVtYikgPT4ge1xuICAgICAgICBpZiAoIWJyZWFkY3J1bWIuZWxsaXBzZWQpIHtcbiAgICAgICAgICAvLyBBcHBlbmQgbm9ybWFsIGJyZWFkY3J1bWJzIHRvIHRoZSBlbmQgb2YgdmlldyBicmVhZGNydW1iIGFycmF5XG4gICAgICAgICAgdmlld0JyZWFkY3J1bWJzLnB1c2goYnJlYWRjcnVtYik7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgLy8gUmVkdWNlIGNvbnNlY3V0aXZlIGVsbGlwc2VkIGJyZWFkY3J1bWJzIGludG8gb25lIGVudHJ5IGFuZCBzaG93IGRyb3Bkb3duIG9mIHRoZXNlXG4gICAgICAgICAgY29uc3QgbGFzdEJyZWFkY3J1bWIgPSB2aWV3QnJlYWRjcnVtYnNbdmlld0JyZWFkY3J1bWJzLmxlbmd0aCAtIDFdO1xuICAgICAgICAgIGlmIChsYXN0QnJlYWRjcnVtYiAmJiB0aGlzLmlzRWxsaXBzZWRCcmVhZGNydW1iKGxhc3RCcmVhZGNydW1iKSkge1xuICAgICAgICAgICAgbGFzdEJyZWFkY3J1bWIuYnJlYWRjcnVtYnMucHVzaChicmVhZGNydW1iKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdmlld0JyZWFkY3J1bWJzLnB1c2goe1xuICAgICAgICAgICAgICBicmVhZGNydW1iczogW2JyZWFkY3J1bWJdXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHZpZXdCcmVhZGNydW1icztcbiAgICAgIH0sIFtdIGFzIFZpZXdCcmVhZGNydW1iW10pO1xuICAgIH1cbiAgfVxuXG4gIGlzRWxsaXBzZWRCcmVhZGNydW1iKGJyZWFkY3J1bWI6IFZpZXdCcmVhZGNydW1iKTogYnJlYWRjcnVtYiBpcyBFbGxpcHNlZEJyZWFkY3J1bWIge1xuICAgIHJldHVybiAhIShicmVhZGNydW1iIGFzIEVsbGlwc2VkQnJlYWRjcnVtYikuYnJlYWRjcnVtYnM7XG4gIH1cbn1cbiIsIkBmb3IgKGJyZWFkY3J1bWIgb2Ygdmlld0JyZWFkY3J1bWJzOyB0cmFjayAkaW5kZXg7IGxldCBsYXN0ID0gJGxhc3QpIHtcbiAgQGlmIChpc0VsbGlwc2VkQnJlYWRjcnVtYihicmVhZGNydW1iKSkge1xuICAgIDxseC1jZGstb3B0aW9ucy1kcm9wZG93biBbYWxpZ25dPVwiJ3JpZ2h0J1wiIGNsYXNzPVwiZHJvcGRvd25Db250YWluZXJcIj5cbiAgICAgIDxidXR0b24gY2xhc3M9XCJzdGVwIGNsaWNrYWJsZVwiIGx4S2V5Ym9hcmRBY3Rpb25Tb3VyY2U+Li4uPC9idXR0b24+XG4gICAgICBAZm9yIChlbGxpcHNlZEJyZWFkY3J1bWJzIG9mIGJyZWFkY3J1bWIuYnJlYWRjcnVtYnM7IHRyYWNrICRpbmRleCkge1xuICAgICAgICA8bHgtb3B0aW9uIFtoYXNTZWxlY3RlZFN0YXRlXT1cImZhbHNlXCIgKHNlbGVjdCk9XCJlbGxpcHNlZEJyZWFkY3J1bWJzLm9uQ2xpY2s/LihlbGxpcHNlZEJyZWFkY3J1bWJzKVwiPlxuICAgICAgICAgIHt7IGVsbGlwc2VkQnJlYWRjcnVtYnMubGFiZWwgfX1cbiAgICAgICAgPC9seC1vcHRpb24+XG4gICAgICB9XG4gICAgPC9seC1jZGstb3B0aW9ucy1kcm9wZG93bj5cbiAgfSBAZWxzZSB7XG4gICAgPGJ1dHRvbiBjbGFzcz1cInN0ZXBcIiBbZGlzYWJsZWRdPVwiIWJyZWFkY3J1bWIub25DbGlja1wiIChjbGljayk9XCJicmVhZGNydW1iLm9uQ2xpY2s/LihicmVhZGNydW1iKVwiPlxuICAgICAge3sgYnJlYWRjcnVtYi5sYWJlbCB9fVxuICAgIDwvYnV0dG9uPlxuICB9XG5cbiAgQGlmICghbGFzdCkge1xuICAgIDxpIGNsYXNzPVwiZmEgZmEtYW5nbGUtcmlnaHRcIiBhcmlhLWhpZGRlbj1cInRydWVcIj48L2k+XG4gIH1cbn1cbiJdfQ==
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2JyZWFkY3J1bWIvYnJlYWRjcnVtYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2JyZWFkY3J1bWIvYnJlYWRjcnVtYi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQTRCLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ2xHLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQ3JHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFjN0Q7Ozs7Ozs7Ozs7R0FVRztBQVFILE1BQU0sT0FBTyxtQkFBbUI7SUFQaEM7UUFRRTs7V0FFRztRQUNNLGdCQUFXLEdBQWlCLEVBQUUsQ0FBQztRQUV4QyxnQkFBZ0I7UUFDaEIsb0JBQWUsR0FBcUIsRUFBRSxDQUFDO0tBNEJ4QztJQTFCQyxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsYUFBYSxDQUFDLEVBQUUsQ0FBQztZQUMzQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUMsZUFBZSxFQUFFLFVBQVUsRUFBRSxFQUFFO2dCQUM3RSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDO29CQUN6QixnRUFBZ0U7b0JBQ2hFLGVBQWUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7Z0JBQ25DLENBQUM7cUJBQU0sQ0FBQztvQkFDTixvRkFBb0Y7b0JBQ3BGLE1BQU0sY0FBYyxHQUFHLGVBQWUsQ0FBQyxlQUFlLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO29CQUNuRSxJQUFJLGNBQWMsSUFBSSxJQUFJLENBQUMsb0JBQW9CLENBQUMsY0FBYyxDQUFDLEVBQUUsQ0FBQzt3QkFDaEUsY0FBYyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7b0JBQzlDLENBQUM7eUJBQU0sQ0FBQzt3QkFDTixlQUFlLENBQUMsSUFBSSxDQUFDOzRCQUNuQixXQUFXLEVBQUUsQ0FBQyxVQUFVLENBQUM7eUJBQzFCLENBQUMsQ0FBQztvQkFDTCxDQUFDO2dCQUNILENBQUM7Z0JBQ0QsT0FBTyxlQUFlLENBQUM7WUFDekIsQ0FBQyxFQUFFLEVBQXNCLENBQUMsQ0FBQztRQUM3QixDQUFDO0lBQ0gsQ0FBQztJQUVELGdCQUFnQjtJQUNoQixvQkFBb0IsQ0FBQyxVQUEwQjtRQUM3QyxPQUFPLENBQUMsQ0FBRSxVQUFpQyxDQUFDLFdBQVcsQ0FBQztJQUMxRCxDQUFDOzhHQWxDVSxtQkFBbUI7a0dBQW5CLG1CQUFtQixzSUNwQ2hDLDh6QkFvQkEsOGJEY1ksWUFBWSwrQkFBRSwyQkFBMkIsaUlBQUUsNkJBQTZCLHlHQUFFLGVBQWU7OzJGQUV4RixtQkFBbUI7a0JBUC9CLFNBQVM7K0JBQ0UsZUFBZSxjQUdiLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSwyQkFBMkIsRUFBRSw2QkFBNkIsRUFBRSxlQUFlLENBQUM7OEJBTTNGLFdBQVc7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBLZXlib2FyZEFjdGlvblNvdXJjZURpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMva2V5Ym9hcmQtYWN0aW9uLXNvdXJjZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQ2RrT3B0aW9uc0Ryb3Bkb3duQ29tcG9uZW50IH0gZnJvbSAnLi4vY2RrLW9wdGlvbnMtZHJvcGRvd24vY2RrLW9wdGlvbnMtZHJvcGRvd24uY29tcG9uZW50JztcbmltcG9ydCB7IE9wdGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL29wdGlvbi9vcHRpb24uY29tcG9uZW50JztcblxuZXhwb3J0IGludGVyZmFjZSBCcmVhZGNydW1iIHtcbiAgbGFiZWw6IHN0cmluZztcbiAgZWxsaXBzZWQ/OiBib29sZWFuO1xuICBvbkNsaWNrPzogKGJyZWFkY3J1bWI6IEJyZWFkY3J1bWIpID0+IHZvaWQ7XG59XG5cbmludGVyZmFjZSBFbGxpcHNlZEJyZWFkY3J1bWIge1xuICBicmVhZGNydW1iczogQnJlYWRjcnVtYltdO1xufVxuXG50eXBlIFZpZXdCcmVhZGNydW1iID0gQnJlYWRjcnVtYiB8IEVsbGlwc2VkQnJlYWRjcnVtYjtcblxuLyoqXG4gKiBCcmVhZGNydW1iIGNvbXBvbmVudCBpcyB1c2VkIHRvIHNob3cgYSBsaXN0IG9mIGxhYmVscywgdXN1YWxseSB0byBzaG93IHRoZSBwYXRoIG9mIHVzZXIncyBuYXZpZ2F0aW9uLlxuICpcbiAqICMjIFVzYWdlXG4gKlxuICogMS4gSW1wb3J0IHRoZSBMeEZvcm1zTW9kdWxlIG1vZHVsZSBmcm9tIEBsZWFuaXgvY29tcG9uZW50cyBpbiB5b3VyIG1vZHVsZSB3aGVyZSB5b3Ugd2FudCB0byB1c2UgdGhlIGNvbXBvbmVudC5cbiAqXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgTHhGb3Jtc01vZHVsZSB9IGZyb20gJ0BsZWFuaXgvY29tcG9uZW50cyc7XG4gKiBgYGBcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtYnJlYWRjcnVtYicsXG4gIHRlbXBsYXRlVXJsOiAnLi9icmVhZGNydW1iLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYnJlYWRjcnVtYi5jb21wb25lbnQuc2NzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBDZGtPcHRpb25zRHJvcGRvd25Db21wb25lbnQsIEtleWJvYXJkQWN0aW9uU291cmNlRGlyZWN0aXZlLCBPcHRpb25Db21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIEJyZWFkY3J1bWJDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICAvKipcbiAgICogQnJlYWRjcnVtYnMgYXJyYXkgdG8gYnVpbGQgdGhlIGNvbXBvbmVudC5cbiAgICovXG4gIEBJbnB1dCgpIGJyZWFkY3J1bWJzOiBCcmVhZGNydW1iW10gPSBbXTtcblxuICAvKiogQGludGVybmFsICovXG4gIHZpZXdCcmVhZGNydW1iczogVmlld0JyZWFkY3J1bWJbXSA9IFtdO1xuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcbiAgICBpZiAoY2hhbmdlc1snYnJlYWRjcnVtYnMnXSkge1xuICAgICAgdGhpcy52aWV3QnJlYWRjcnVtYnMgPSB0aGlzLmJyZWFkY3J1bWJzLnJlZHVjZSgodmlld0JyZWFkY3J1bWJzLCBicmVhZGNydW1iKSA9PiB7XG4gICAgICAgIGlmICghYnJlYWRjcnVtYi5lbGxpcHNlZCkge1xuICAgICAgICAgIC8vIEFwcGVuZCBub3JtYWwgYnJlYWRjcnVtYnMgdG8gdGhlIGVuZCBvZiB2aWV3IGJyZWFkY3J1bWIgYXJyYXlcbiAgICAgICAgICB2aWV3QnJlYWRjcnVtYnMucHVzaChicmVhZGNydW1iKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAvLyBSZWR1Y2UgY29uc2VjdXRpdmUgZWxsaXBzZWQgYnJlYWRjcnVtYnMgaW50byBvbmUgZW50cnkgYW5kIHNob3cgZHJvcGRvd24gb2YgdGhlc2VcbiAgICAgICAgICBjb25zdCBsYXN0QnJlYWRjcnVtYiA9IHZpZXdCcmVhZGNydW1ic1t2aWV3QnJlYWRjcnVtYnMubGVuZ3RoIC0gMV07XG4gICAgICAgICAgaWYgKGxhc3RCcmVhZGNydW1iICYmIHRoaXMuaXNFbGxpcHNlZEJyZWFkY3J1bWIobGFzdEJyZWFkY3J1bWIpKSB7XG4gICAgICAgICAgICBsYXN0QnJlYWRjcnVtYi5icmVhZGNydW1icy5wdXNoKGJyZWFkY3J1bWIpO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB2aWV3QnJlYWRjcnVtYnMucHVzaCh7XG4gICAgICAgICAgICAgIGJyZWFkY3J1bWJzOiBbYnJlYWRjcnVtYl1cbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdmlld0JyZWFkY3J1bWJzO1xuICAgICAgfSwgW10gYXMgVmlld0JyZWFkY3J1bWJbXSk7XG4gICAgfVxuICB9XG5cbiAgLyoqIEBpbnRlcm5hbCAqL1xuICBpc0VsbGlwc2VkQnJlYWRjcnVtYihicmVhZGNydW1iOiBWaWV3QnJlYWRjcnVtYik6IGJyZWFkY3J1bWIgaXMgRWxsaXBzZWRCcmVhZGNydW1iIHtcbiAgICByZXR1cm4gISEoYnJlYWRjcnVtYiBhcyBFbGxpcHNlZEJyZWFkY3J1bWIpLmJyZWFkY3J1bWJzO1xuICB9XG59XG4iLCJAZm9yIChicmVhZGNydW1iIG9mIHZpZXdCcmVhZGNydW1iczsgdHJhY2sgJGluZGV4OyBsZXQgbGFzdCA9ICRsYXN0KSB7XG4gIEBpZiAoaXNFbGxpcHNlZEJyZWFkY3J1bWIoYnJlYWRjcnVtYikpIHtcbiAgICA8bHgtY2RrLW9wdGlvbnMtZHJvcGRvd24gW2FsaWduXT1cIidyaWdodCdcIiBjbGFzcz1cImRyb3Bkb3duQ29udGFpbmVyXCI+XG4gICAgICA8YnV0dG9uIGNsYXNzPVwic3RlcCBjbGlja2FibGVcIiBseEtleWJvYXJkQWN0aW9uU291cmNlPi4uLjwvYnV0dG9uPlxuICAgICAgQGZvciAoZWxsaXBzZWRCcmVhZGNydW1icyBvZiBicmVhZGNydW1iLmJyZWFkY3J1bWJzOyB0cmFjayAkaW5kZXgpIHtcbiAgICAgICAgPGx4LW9wdGlvbiBbaGFzU2VsZWN0ZWRTdGF0ZV09XCJmYWxzZVwiIChzZWxlY3QpPVwiZWxsaXBzZWRCcmVhZGNydW1icy5vbkNsaWNrPy4oZWxsaXBzZWRCcmVhZGNydW1icylcIj5cbiAgICAgICAgICB7eyBlbGxpcHNlZEJyZWFkY3J1bWJzLmxhYmVsIH19XG4gICAgICAgIDwvbHgtb3B0aW9uPlxuICAgICAgfVxuICAgIDwvbHgtY2RrLW9wdGlvbnMtZHJvcGRvd24+XG4gIH0gQGVsc2Uge1xuICAgIDxidXR0b24gY2xhc3M9XCJzdGVwXCIgW2Rpc2FibGVkXT1cIiFicmVhZGNydW1iLm9uQ2xpY2tcIiAoY2xpY2spPVwiYnJlYWRjcnVtYi5vbkNsaWNrPy4oYnJlYWRjcnVtYilcIj5cbiAgICAgIHt7IGJyZWFkY3J1bWIubGFiZWwgfX1cbiAgICA8L2J1dHRvbj5cbiAgfVxuXG4gIEBpZiAoIWxhc3QpIHtcbiAgICA8aSBjbGFzcz1cImZhIGZhLWFuZ2xlLXJpZ2h0XCIgYXJpYS1oaWRkZW49XCJ0cnVlXCI+PC9pPlxuICB9XG59XG4iXX0=