@indigina/ui-kit 1.1.49 → 1.1.51
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.
- package/assets/icons/seko-360.svg +5 -0
- package/assets/icons/seko.svg +5 -0
- package/esm2022/lib/components/kit-datepicker/kit-datepicker.component.mjs +2 -2
- package/esm2022/lib/components/kit-daterange/kit-daterange.component.mjs +6 -17
- package/esm2022/lib/components/kit-navigation-menu/kit-navigation-menu-submenu/kit-navigation-menu-submenu.component.mjs +11 -19
- package/esm2022/lib/components/kit-navigation-menu/kit-navigation-menu.component.mjs +54 -39
- package/esm2022/lib/components/kit-navigation-menu/kit-navigation-menu.model.mjs +1 -1
- package/esm2022/lib/components/kit-navigation-menu/kit-navigation-menu.module.mjs +7 -3
- package/esm2022/lib/components/kit-navigation-menu/kit-navigation-menu.util.mjs +5 -8
- package/esm2022/lib/components/kit-svg-icon/kit-svg-icon.const.mjs +3 -1
- package/esm2022/lib/components/kit-svg-sprite/kit-svg-sprite.component.mjs +3 -3
- package/esm2022/public-api.mjs +2 -2
- package/fesm2022/indigina-ui-kit.mjs +80 -122
- package/fesm2022/indigina-ui-kit.mjs.map +1 -1
- package/lib/components/kit-daterange/kit-daterange.component.d.ts +3 -11
- package/lib/components/kit-navigation-menu/kit-navigation-menu-submenu/kit-navigation-menu-submenu.component.d.ts +3 -3
- package/lib/components/kit-navigation-menu/kit-navigation-menu.component.d.ts +14 -12
- package/lib/components/kit-navigation-menu/kit-navigation-menu.model.d.ts +1 -0
- package/lib/components/kit-navigation-menu/kit-navigation-menu.module.d.ts +2 -1
- package/lib/components/kit-navigation-menu/kit-navigation-menu.util.d.ts +1 -1
- package/lib/components/kit-svg-icon/kit-svg-icon.const.d.ts +3 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -1
- package/esm2022/lib/components/kit-navigation-menu/kit-navigation-menu-base.component.mjs +0 -42
- package/lib/components/kit-navigation-menu/kit-navigation-menu-base.component.d.ts +0 -15
|
@@ -1,80 +1,95 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, signal } from '@angular/core';
|
|
2
2
|
import { expandCollapseAnimation } from './kit-navigation-menu.util';
|
|
3
3
|
import { KitSvgIconType } from '../kit-svg-icon/kit-svg-icon.const';
|
|
4
4
|
import { NavigationEnd } from '@angular/router';
|
|
5
5
|
import { filter } from 'rxjs';
|
|
6
6
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
7
|
-
import {
|
|
7
|
+
import { KitTooltipPosition } from '../../directives/kit-tooltip/kit-tooltip.directive';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
import * as i1 from "@angular/router";
|
|
10
10
|
import * as i2 from "@angular/common";
|
|
11
11
|
import * as i3 from "../kit-svg-icon/kit-svg-icon.component";
|
|
12
12
|
import * as i4 from "./kit-navigation-menu-submenu/kit-navigation-menu-submenu.component";
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
13
|
+
import * as i5 from "../../directives/kit-tooltip/kit-tooltip.directive";
|
|
14
|
+
export class KitNavigationMenuComponent {
|
|
15
|
+
constructor(router) {
|
|
16
16
|
this.router = router;
|
|
17
|
-
this.changeDetectorRef = changeDetectorRef;
|
|
18
17
|
/**
|
|
19
18
|
* An items list which is going to be rendered as menu items
|
|
20
19
|
*/
|
|
21
20
|
this.items = [];
|
|
22
21
|
/**
|
|
23
|
-
* Defines whether
|
|
22
|
+
* Defines whether menu will be collapsed
|
|
24
23
|
*/
|
|
25
|
-
this.
|
|
24
|
+
this.collapsed = true;
|
|
26
25
|
/**
|
|
27
|
-
*
|
|
26
|
+
* An action which is emitted when the collapse state changes
|
|
28
27
|
*/
|
|
29
|
-
this.
|
|
28
|
+
this.collapseChanged = new EventEmitter();
|
|
29
|
+
this.selectedItem = signal(null);
|
|
30
30
|
this.KitSvgIconType = KitSvgIconType;
|
|
31
|
+
this.KitTooltipPosition = KitTooltipPosition;
|
|
31
32
|
this.setExpandedStateOnRouterChange();
|
|
32
33
|
}
|
|
33
34
|
ngOnInit() {
|
|
34
|
-
this.
|
|
35
|
-
}
|
|
36
|
-
ngOnChanges(changes) {
|
|
37
|
-
if (changes.collapsed?.currentValue) {
|
|
38
|
-
this.collapseAll(this.items);
|
|
39
|
-
}
|
|
35
|
+
this.updateNavigationState(this.items, this.router.url);
|
|
40
36
|
}
|
|
41
37
|
handleClick(item) {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
super.handleClick(item);
|
|
38
|
+
!item.items ? this.collapseAllItems(this.items) : this.toggleItem(item);
|
|
39
|
+
this.collapseChanged.emit(this.collapsed);
|
|
40
|
+
this.selectedItem.set(item);
|
|
46
41
|
}
|
|
47
42
|
setExpandedStateOnRouterChange() {
|
|
48
|
-
this.router.events.pipe(filter(event => event instanceof NavigationEnd), takeUntilDestroyed()).subscribe(() => this.
|
|
43
|
+
this.router.events.pipe(filter(event => event instanceof NavigationEnd), takeUntilDestroyed()).subscribe(() => this.updateNavigationState(this.items, this.router.url));
|
|
49
44
|
}
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
45
|
+
updateNavigationState(items, url) {
|
|
46
|
+
const matchLink = (item) => !!(item.link && url.startsWith(item.link));
|
|
54
47
|
items.forEach(item => {
|
|
55
|
-
item.expanded = !!(item.link && url.startsWith(item.link));
|
|
56
48
|
if (item.items) {
|
|
57
|
-
this.
|
|
58
|
-
item.expanded = item.items.some(child => child.expanded)
|
|
49
|
+
this.updateNavigationState(item.items, url);
|
|
50
|
+
item.expanded = item.items.some(child => child.expanded) ||
|
|
51
|
+
item.items.some(child => matchLink(child));
|
|
52
|
+
item.active = item.items.some(child => child.active);
|
|
53
|
+
if (item.expanded) {
|
|
54
|
+
this.selectedItem.set(item);
|
|
55
|
+
this.collapsed = false;
|
|
56
|
+
this.collapseChanged.emit(this.collapsed);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
item.expanded = false;
|
|
61
|
+
item.active = matchLink(item);
|
|
59
62
|
}
|
|
60
63
|
});
|
|
61
|
-
this.changeDetectorRef.markForCheck();
|
|
62
64
|
}
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
65
|
+
collapseAllItems(items) {
|
|
66
|
+
this.collapsed = true;
|
|
67
|
+
items.forEach(item => item.expanded = false);
|
|
68
|
+
}
|
|
69
|
+
toggleItem(item) {
|
|
70
|
+
if (this.collapsed || item.expanded) {
|
|
71
|
+
this.collapsed = !this.collapsed;
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
this.items.forEach(item => item.expanded = false);
|
|
75
|
+
}
|
|
76
|
+
item.expanded = !item.expanded;
|
|
77
|
+
}
|
|
78
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: KitNavigationMenuComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
79
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.7", type: KitNavigationMenuComponent, selector: "kit-navigation-menu", inputs: { items: "items", collapsed: "collapsed" }, outputs: { collapseChanged: "collapseChanged" }, ngImport: i0, template: "<div class=\"kit-navigation-menu\"\n [class.collapsed]=\"collapsed\">\n <div class=\"main-panel\">\n <div class=\"nav-list\">\n @for (item of items; track item) {\n @if (item.items?.length) {\n <a class=\"nav-link\"\n kitTooltip\n kitTooltipFilter=\".nav-link\"\n [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n [title]=\"item.title\"\n [class.active]=\"item.active\"\n (click)=\"handleClick(item)\">\n @if (item.icon) {\n <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n ></ng-container>\n }\n </a>\n } @else {\n @if (item.link) {\n <a class=\"nav-link\"\n routerLinkActive=\"active\"\n kitTooltip\n kitTooltipFilter=\".nav-link\"\n [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n [title]=\"item.title\"\n [routerLink]=\"item?.link\"\n (click)=\"handleClick(item)\">\n @if (item.icon) {\n <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n ></ng-container>\n }\n </a>\n }\n }\n }\n </div>\n </div>\n\n @if (!collapsed && selectedItem()?.items) {\n <kit-navigation-menu-submenu class=\"sub-panel\"\n [@widthExpandCollapseAnimation]\n [item]=\"selectedItem()\"\n ></kit-navigation-menu-submenu>\n }\n\n <ng-template #linkIconTemplate let-item>\n <kit-svg-icon class=\"nav-link-icon\"\n [icon]=\"item.icon\"\n [ngClass]=\"item?.iconType ?? KitSvgIconType.FILL\"\n ></kit-svg-icon>\n </ng-template>\n</div>\n", styles: [".kit-navigation-menu{display:flex;height:100%}.kit-navigation-menu .main-panel{padding:25px 10px;width:56px;box-sizing:border-box}.kit-navigation-menu .sub-panel{display:block;width:200px;overflow:hidden}.kit-navigation-menu .nav-list{display:flex;flex-direction:column;gap:30px;margin-top:82px}.kit-navigation-menu .nav-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;cursor:pointer}.kit-navigation-menu .nav-link:hover{background:var(--ui-kit-color-grey-14)}.kit-navigation-menu .nav-link.active{background:var(--ui-kit-color-main)}.kit-navigation-menu .nav-link-icon{display:block;width:16px;height:16px;flex-shrink:0}.kit-navigation-menu .nav-link-icon.fill{fill:var(--ui-kit-color-white);stroke:none}.kit-navigation-menu .nav-link-icon.stroke{fill:none;stroke:var(--ui-kit-color-white)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.KitSvgIconComponent, selector: "kit-svg-icon", inputs: ["icon", "iconClass"] }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i1.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "component", type: i4.KitNavigationMenuSubmenuComponent, selector: "kit-navigation-menu-submenu", inputs: ["item"] }, { kind: "directive", type: i5.KitTooltipDirective, selector: "[kitTooltip]", inputs: ["kitTooltipPosition", "kitTooltipFilter", "kitTooltipTemplateRef"] }], animations: [
|
|
80
|
+
expandCollapseAnimation('width'),
|
|
66
81
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
67
82
|
}
|
|
68
83
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: KitNavigationMenuComponent, decorators: [{
|
|
69
84
|
type: Component,
|
|
70
85
|
args: [{ selector: 'kit-navigation-menu', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
|
|
71
|
-
expandCollapseAnimation,
|
|
72
|
-
], template: "<div class=\"kit-navigation-menu\"\n [class.collapsed]=\"collapsed\">\n @for (item of items; track item) {\n
|
|
73
|
-
}], ctorParameters: () => [{ type: i1.Router }
|
|
74
|
-
type: Input
|
|
75
|
-
}], animate: [{
|
|
86
|
+
expandCollapseAnimation('width'),
|
|
87
|
+
], template: "<div class=\"kit-navigation-menu\"\n [class.collapsed]=\"collapsed\">\n <div class=\"main-panel\">\n <div class=\"nav-list\">\n @for (item of items; track item) {\n @if (item.items?.length) {\n <a class=\"nav-link\"\n kitTooltip\n kitTooltipFilter=\".nav-link\"\n [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n [title]=\"item.title\"\n [class.active]=\"item.active\"\n (click)=\"handleClick(item)\">\n @if (item.icon) {\n <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n ></ng-container>\n }\n </a>\n } @else {\n @if (item.link) {\n <a class=\"nav-link\"\n routerLinkActive=\"active\"\n kitTooltip\n kitTooltipFilter=\".nav-link\"\n [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n [title]=\"item.title\"\n [routerLink]=\"item?.link\"\n (click)=\"handleClick(item)\">\n @if (item.icon) {\n <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n ></ng-container>\n }\n </a>\n }\n }\n }\n </div>\n </div>\n\n @if (!collapsed && selectedItem()?.items) {\n <kit-navigation-menu-submenu class=\"sub-panel\"\n [@widthExpandCollapseAnimation]\n [item]=\"selectedItem()\"\n ></kit-navigation-menu-submenu>\n }\n\n <ng-template #linkIconTemplate let-item>\n <kit-svg-icon class=\"nav-link-icon\"\n [icon]=\"item.icon\"\n [ngClass]=\"item?.iconType ?? KitSvgIconType.FILL\"\n ></kit-svg-icon>\n </ng-template>\n</div>\n", styles: [".kit-navigation-menu{display:flex;height:100%}.kit-navigation-menu .main-panel{padding:25px 10px;width:56px;box-sizing:border-box}.kit-navigation-menu .sub-panel{display:block;width:200px;overflow:hidden}.kit-navigation-menu .nav-list{display:flex;flex-direction:column;gap:30px;margin-top:82px}.kit-navigation-menu .nav-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;cursor:pointer}.kit-navigation-menu .nav-link:hover{background:var(--ui-kit-color-grey-14)}.kit-navigation-menu .nav-link.active{background:var(--ui-kit-color-main)}.kit-navigation-menu .nav-link-icon{display:block;width:16px;height:16px;flex-shrink:0}.kit-navigation-menu .nav-link-icon.fill{fill:var(--ui-kit-color-white);stroke:none}.kit-navigation-menu .nav-link-icon.stroke{fill:none;stroke:var(--ui-kit-color-white)}\n"] }]
|
|
88
|
+
}], ctorParameters: () => [{ type: i1.Router }], propDecorators: { items: [{
|
|
76
89
|
type: Input
|
|
77
|
-
}],
|
|
90
|
+
}], collapsed: [{
|
|
78
91
|
type: Input
|
|
92
|
+
}], collapseChanged: [{
|
|
93
|
+
type: Output
|
|
79
94
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kit-navigation-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-kit/src/lib/components/kit-navigation-menu/kit-navigation-menu.component.ts","../../../../../../projects/ui-kit/src/lib/components/kit-navigation-menu/kit-navigation-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, OnChanges, OnInit, SimpleChanges } from '@angular/core';\nimport { KitNavigationMenuItem } from './kit-navigation-menu.model';\nimport { expandCollapseAnimation } from './kit-navigation-menu.util';\nimport { KitSvgIconType } from '../kit-svg-icon/kit-svg-icon.const';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { filter } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { KitNavigationMenuBaseComponent } from './kit-navigation-menu-base.component';\n\n@Component({\n  selector: 'kit-navigation-menu',\n  templateUrl: './kit-navigation-menu.component.html',\n  styleUrl: './kit-navigation-menu.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    expandCollapseAnimation,\n  ],\n})\nexport class KitNavigationMenuComponent extends KitNavigationMenuBaseComponent implements OnInit, OnChanges {\n  /**\n   * An items list which is going to be rendered as menu items\n   */\n  @Input() items: KitNavigationMenuItem[] = [];\n\n  /**\n   * Defines whether the component will have an animation when collapsing/expanding the menu\n   */\n  @Input() animate: boolean = true;\n\n  /**\n   * Defines whether the component can have more than one item expanded at the same time\n   */\n  @Input() multiple: boolean = false;\n\n  readonly KitSvgIconType: typeof KitSvgIconType = KitSvgIconType;\n\n  constructor(\n    private router: Router,\n    private changeDetectorRef: ChangeDetectorRef,\n  ) {\n    super();\n    this.setExpandedStateOnRouterChange();\n  }\n\n  ngOnInit(): void {\n    this.setExpandedState(this.items, this.router.url);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.collapsed?.currentValue) {\n      this.collapseAll(this.items);\n    }\n  }\n\n  override handleClick(item: KitNavigationMenuItem): void {\n    if(!this.multiple && !item.expanded) {\n      this.collapseAll(this.items);\n    }\n\n    super.handleClick(item);\n  }\n\n  private setExpandedStateOnRouterChange(): void {\n    this.router.events.pipe(\n      filter(event => event instanceof NavigationEnd),\n      takeUntilDestroyed(),\n    ).subscribe(() => this.setExpandedState(this.items, this.router.url));\n  }\n\n  private setExpandedState(items: KitNavigationMenuItem[], url: string): void {\n    if (this.collapsed) {\n      return;\n    }\n\n    items.forEach(item => {\n      item.expanded = !!(item.link && url.startsWith(item.link));\n      if (item.items) {\n        this.setExpandedState(item.items, url);\n        item.expanded = item.items.some(child => child.expanded);\n      }\n    });\n    this.changeDetectorRef.markForCheck();\n  }\n}\n","<div class=\"kit-navigation-menu\"\n     [class.collapsed]=\"collapsed\">\n  @for (item of items; track item) {\n    @if (item.items?.length) {\n      <div class=\"nav-item\"\n           [class.expanded]=\"item.expanded\"\n           (mouseenter)=\"handleHover(item, true)\"\n           (mouseleave)=\"handleHover(item, false)\">\n        <a class=\"nav-link\"\n           (mouseleave)=\"$event.stopPropagation()\"\n           (click)=\"handleClick(item)\">\n          @if (item.icon) {\n            <kit-svg-icon class=\"nav-link-icon\"\n                          [icon]=\"item.icon\"\n                          [ngClass]=\"item?.iconType ?? KitSvgIconType.FILL\"\n            ></kit-svg-icon>\n          }\n          <span class=\"nav-link-title\">{{ item.title }}</span>\n          <kit-svg-icon class=\"nav-link-toggle\"\n                        [icon]=\"KitSvgIcon.CHEVRON_DOWN\"\n          ></kit-svg-icon>\n        </a>\n\n        @if (item.expanded) {\n          <kit-navigation-menu-submenu class=\"display-block\"\n                                       [@expandCollapseAnimation]\n                                       [@.disabled]=\"!animate || collapsed\"\n                                       [item]=\"item\"\n                                       [collapsed]=\"collapsed\"\n          ></kit-navigation-menu-submenu>\n        }\n      </div>\n    } @else {\n      @if (item.link) {\n        <div class=\"nav-item\">\n          <a class=\"nav-link\"\n             routerLinkActive=\"active\"\n             [routerLink]=\"item?.link\"\n             [title]=\"item.title\">\n            @if (item.icon) {\n              <kit-svg-icon class=\"nav-link-icon\"\n                            [icon]=\"item.icon\"\n                            [ngClass]=\"item?.iconType ?? KitSvgIconType.FILL\"\n              ></kit-svg-icon>\n            }\n            <span class=\"nav-link-title\">{{ item.title }}</span>\n          </a>\n        </div>\n      }\n    }\n  }\n</div>\n"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kit-navigation-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-kit/src/lib/components/kit-navigation-menu/kit-navigation-menu.component.ts","../../../../../../projects/ui-kit/src/lib/components/kit-navigation-menu/kit-navigation-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnInit, Output, signal, WritableSignal } from '@angular/core';\nimport { KitNavigationMenuItem } from './kit-navigation-menu.model';\nimport { expandCollapseAnimation } from './kit-navigation-menu.util';\nimport { KitSvgIconType } from '../kit-svg-icon/kit-svg-icon.const';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { filter } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { KitTooltipPosition } from '../../directives/kit-tooltip/kit-tooltip.directive';\n\n@Component({\n  selector: 'kit-navigation-menu',\n  templateUrl: './kit-navigation-menu.component.html',\n  styleUrl: './kit-navigation-menu.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    expandCollapseAnimation('width'),\n  ],\n})\nexport class KitNavigationMenuComponent implements OnInit {\n  /**\n   * An items list which is going to be rendered as menu items\n   */\n  @Input() items: KitNavigationMenuItem[] = [];\n\n  /**\n   * Defines whether menu will be collapsed\n   */\n  @Input() collapsed: boolean = true;\n\n  /**\n   * An action which is emitted when the collapse state changes\n   */\n  @Output() collapseChanged: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  readonly selectedItem: WritableSignal<KitNavigationMenuItem | null> = signal(null);\n  readonly KitSvgIconType: typeof KitSvgIconType = KitSvgIconType;\n  readonly KitTooltipPosition: typeof KitTooltipPosition = KitTooltipPosition;\n\n  constructor(\n    private router: Router,\n  ) {\n    this.setExpandedStateOnRouterChange();\n  }\n\n  ngOnInit(): void {\n    this.updateNavigationState(this.items, this.router.url);\n  }\n\n  handleClick(item: KitNavigationMenuItem): void {\n    !item.items ? this.collapseAllItems(this.items) : this.toggleItem(item);\n    this.collapseChanged.emit(this.collapsed);\n    this.selectedItem.set(item);\n  }\n\n  private setExpandedStateOnRouterChange(): void {\n    this.router.events.pipe(\n      filter(event => event instanceof NavigationEnd),\n      takeUntilDestroyed(),\n    ).subscribe(() => this.updateNavigationState(this.items, this.router.url));\n  }\n\n  private updateNavigationState(items: KitNavigationMenuItem[], url: string): void {\n    const matchLink = (item: KitNavigationMenuItem): boolean => !!(item.link && url.startsWith(item.link));\n    items.forEach(item => {\n      if (item.items) {\n        this.updateNavigationState(item.items, url);\n        item.expanded = item.items.some(child => child.expanded) ||\n          item.items.some(child => matchLink(child));\n        item.active = item.items.some(child => child.active);\n        if (item.expanded) {\n          this.selectedItem.set(item);\n          this.collapsed = false;\n          this.collapseChanged.emit(this.collapsed);\n        }\n      } else {\n        item.expanded = false;\n        item.active = matchLink(item);\n      }\n    });\n  }\n\n  private collapseAllItems(items: KitNavigationMenuItem[]): void {\n    this.collapsed = true;\n    items.forEach(item => item.expanded = false);\n  }\n\n  private toggleItem(item: KitNavigationMenuItem): void {\n    if (this.collapsed || item.expanded) {\n      this.collapsed = !this.collapsed;\n    } else {\n      this.items.forEach(item => item.expanded = false);\n    }\n\n    item.expanded = !item.expanded;\n  }\n}\n","<div class=\"kit-navigation-menu\"\n     [class.collapsed]=\"collapsed\">\n  <div class=\"main-panel\">\n    <div class=\"nav-list\">\n      @for (item of items; track item) {\n        @if (item.items?.length) {\n          <a class=\"nav-link\"\n             kitTooltip\n             kitTooltipFilter=\".nav-link\"\n             [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n             [title]=\"item.title\"\n             [class.active]=\"item.active\"\n             (click)=\"handleClick(item)\">\n            @if (item.icon) {\n              <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n              ></ng-container>\n            }\n          </a>\n        } @else {\n          @if (item.link) {\n            <a class=\"nav-link\"\n               routerLinkActive=\"active\"\n               kitTooltip\n               kitTooltipFilter=\".nav-link\"\n               [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n               [title]=\"item.title\"\n               [routerLink]=\"item?.link\"\n               (click)=\"handleClick(item)\">\n              @if (item.icon) {\n                <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n                ></ng-container>\n              }\n            </a>\n          }\n        }\n      }\n    </div>\n  </div>\n\n  @if (!collapsed && selectedItem()?.items) {\n    <kit-navigation-menu-submenu class=\"sub-panel\"\n                                 [@widthExpandCollapseAnimation]\n                                 [item]=\"selectedItem()\"\n    ></kit-navigation-menu-submenu>\n  }\n\n  <ng-template #linkIconTemplate let-item>\n    <kit-svg-icon class=\"nav-link-icon\"\n                  [icon]=\"item.icon\"\n                  [ngClass]=\"item?.iconType ?? KitSvgIconType.FILL\"\n    ></kit-svg-icon>\n  </ng-template>\n</div>\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l0LW5hdmlnYXRpb24tbWVudS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMva2l0LW5hdmlnYXRpb24tbWVudS9raXQtbmF2aWdhdGlvbi1tZW51Lm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBLaXRTdmdJY29uLCBLaXRTdmdJY29uVHlwZSB9IGZyb20gJy4uL2tpdC1zdmctaWNvbi9raXQtc3ZnLWljb24uY29uc3QnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEtpdE5hdmlnYXRpb25NZW51SXRlbSB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGxpbms/OiBzdHJpbmc7XG4gIGNzc0NsYXNzPzogc3RyaW5nO1xuICBpY29uPzogS2l0U3ZnSWNvbjtcbiAgaWNvblR5cGU/OiBLaXRTdmdJY29uVHlwZTtcbiAgZXhwYW5kZWQ/OiBib29sZWFuO1xuICBpdGVtcz86IEtpdE5hdmlnYXRpb25NZW51SXRlbVtdO1xufVxuIl19
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l0LW5hdmlnYXRpb24tbWVudS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMva2l0LW5hdmlnYXRpb24tbWVudS9raXQtbmF2aWdhdGlvbi1tZW51Lm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBLaXRTdmdJY29uLCBLaXRTdmdJY29uVHlwZSB9IGZyb20gJy4uL2tpdC1zdmctaWNvbi9raXQtc3ZnLWljb24uY29uc3QnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEtpdE5hdmlnYXRpb25NZW51SXRlbSB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGxpbms/OiBzdHJpbmc7XG4gIGNzc0NsYXNzPzogc3RyaW5nO1xuICBpY29uPzogS2l0U3ZnSWNvbjtcbiAgaWNvblR5cGU/OiBLaXRTdmdJY29uVHlwZTtcbiAgZXhwYW5kZWQ/OiBib29sZWFuO1xuICBhY3RpdmU/OiBib29sZWFuO1xuICBpdGVtcz86IEtpdE5hdmlnYXRpb25NZW51SXRlbVtdO1xufVxuIl19
|
|
@@ -4,17 +4,20 @@ import { KitNavigationMenuComponent } from './kit-navigation-menu.component';
|
|
|
4
4
|
import { KitSvgIconModule } from '../kit-svg-icon/kit-svg-icon.module';
|
|
5
5
|
import { RouterModule } from '@angular/router';
|
|
6
6
|
import { KitNavigationMenuSubmenuModule } from './kit-navigation-menu-submenu/kit-navigation-menu-submenu.module';
|
|
7
|
+
import { KitTooltipModule } from '../../directives/kit-tooltip/kit-tooltip.module';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
export class KitNavigationMenuModule {
|
|
9
10
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: KitNavigationMenuModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
11
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.7", ngImport: i0, type: KitNavigationMenuModule, declarations: [KitNavigationMenuComponent], imports: [CommonModule,
|
|
11
12
|
KitSvgIconModule,
|
|
12
13
|
RouterModule,
|
|
13
|
-
KitNavigationMenuSubmenuModule
|
|
14
|
+
KitNavigationMenuSubmenuModule,
|
|
15
|
+
KitTooltipModule], exports: [KitNavigationMenuComponent] }); }
|
|
14
16
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: KitNavigationMenuModule, imports: [CommonModule,
|
|
15
17
|
KitSvgIconModule,
|
|
16
18
|
RouterModule,
|
|
17
|
-
KitNavigationMenuSubmenuModule
|
|
19
|
+
KitNavigationMenuSubmenuModule,
|
|
20
|
+
KitTooltipModule] }); }
|
|
18
21
|
}
|
|
19
22
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: KitNavigationMenuModule, decorators: [{
|
|
20
23
|
type: NgModule,
|
|
@@ -27,10 +30,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImpor
|
|
|
27
30
|
KitSvgIconModule,
|
|
28
31
|
RouterModule,
|
|
29
32
|
KitNavigationMenuSubmenuModule,
|
|
33
|
+
KitTooltipModule,
|
|
30
34
|
],
|
|
31
35
|
exports: [
|
|
32
36
|
KitNavigationMenuComponent,
|
|
33
37
|
],
|
|
34
38
|
}]
|
|
35
39
|
}] });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l0LW5hdmlnYXRpb24tbWVudS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2tpdC1uYXZpZ2F0aW9uLW1lbnUva2l0LW5hdmlnYXRpb24tbWVudS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDdkUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGtFQUFrRSxDQUFDO0FBQ2xILE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlEQUFpRCxDQUFDOztBQWlCbkYsTUFBTSxPQUFPLHVCQUF1Qjs4R0FBdkIsdUJBQXVCOytHQUF2Qix1QkFBdUIsaUJBYmhDLDBCQUEwQixhQUcxQixZQUFZO1lBQ1osZ0JBQWdCO1lBQ2hCLFlBQVk7WUFDWiw4QkFBOEI7WUFDOUIsZ0JBQWdCLGFBR2hCLDBCQUEwQjsrR0FHakIsdUJBQXVCLFlBVmhDLFlBQVk7WUFDWixnQkFBZ0I7WUFDaEIsWUFBWTtZQUNaLDhCQUE4QjtZQUM5QixnQkFBZ0I7OzJGQU1QLHVCQUF1QjtrQkFmbkMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osMEJBQTBCO3FCQUMzQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLFlBQVk7d0JBQ1osOEJBQThCO3dCQUM5QixnQkFBZ0I7cUJBQ2pCO29CQUNELE9BQU8sRUFBRTt3QkFDUCwwQkFBMEI7cUJBQzNCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBLaXROYXZpZ2F0aW9uTWVudUNvbXBvbmVudCB9IGZyb20gJy4va2l0LW5hdmlnYXRpb24tbWVudS5jb21wb25lbnQnO1xuaW1wb3J0IHsgS2l0U3ZnSWNvbk1vZHVsZSB9IGZyb20gJy4uL2tpdC1zdmctaWNvbi9raXQtc3ZnLWljb24ubW9kdWxlJztcbmltcG9ydCB7IFJvdXRlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBLaXROYXZpZ2F0aW9uTWVudVN1Ym1lbnVNb2R1bGUgfSBmcm9tICcuL2tpdC1uYXZpZ2F0aW9uLW1lbnUtc3VibWVudS9raXQtbmF2aWdhdGlvbi1tZW51LXN1Ym1lbnUubW9kdWxlJztcbmltcG9ydCB7IEtpdFRvb2x0aXBNb2R1bGUgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzL2tpdC10b29sdGlwL2tpdC10b29sdGlwLm1vZHVsZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEtpdE5hdmlnYXRpb25NZW51Q29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEtpdFN2Z0ljb25Nb2R1bGUsXG4gICAgUm91dGVyTW9kdWxlLFxuICAgIEtpdE5hdmlnYXRpb25NZW51U3VibWVudU1vZHVsZSxcbiAgICBLaXRUb29sdGlwTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgS2l0TmF2aWdhdGlvbk1lbnVDb21wb25lbnQsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEtpdE5hdmlnYXRpb25NZW51TW9kdWxlIHtcbn1cbiJdfQ==
|
|
@@ -1,20 +1,17 @@
|
|
|
1
1
|
import { animate, state, style, transition, trigger } from '@angular/animations';
|
|
2
|
-
export const expandCollapseAnimation = trigger(
|
|
2
|
+
export const expandCollapseAnimation = (property) => trigger(`${property}ExpandCollapseAnimation`, [
|
|
3
3
|
state('void', style({
|
|
4
|
-
|
|
5
|
-
overflow: 'hidden',
|
|
4
|
+
[property]: '0',
|
|
6
5
|
})),
|
|
7
6
|
transition(':enter', [
|
|
8
7
|
animate('0.2s ease-in-out', style({
|
|
9
|
-
|
|
10
|
-
overflow: 'hidden',
|
|
8
|
+
[property]: '*',
|
|
11
9
|
})),
|
|
12
10
|
]),
|
|
13
11
|
transition(':leave', [
|
|
14
12
|
animate('0.2s ease-in-out', style({
|
|
15
|
-
|
|
16
|
-
overflow: 'hidden',
|
|
13
|
+
[property]: '0',
|
|
17
14
|
})),
|
|
18
15
|
]),
|
|
19
16
|
]);
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l0LW5hdmlnYXRpb24tbWVudS51dGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9raXQtbmF2aWdhdGlvbi1tZW51L2tpdC1uYXZpZ2F0aW9uLW1lbnUudXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUE0QixLQUFLLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUUzRyxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxDQUFDLFFBQTRCLEVBQTRCLEVBQUUsQ0FDaEcsT0FBTyxDQUFDLEdBQUcsUUFBUSx5QkFBeUIsRUFBRTtJQUM1QyxLQUFLLENBQ0gsTUFBTSxFQUNOLEtBQUssQ0FBQztRQUNKLENBQUMsUUFBUSxDQUFDLEVBQUUsR0FBRztLQUNoQixDQUFDLENBQ0g7SUFDRCxVQUFVLENBQUMsUUFBUSxFQUFFO1FBQ25CLE9BQU8sQ0FDTCxrQkFBa0IsRUFDbEIsS0FBSyxDQUFDO1lBQ0osQ0FBQyxRQUFRLENBQUMsRUFBRSxHQUFHO1NBQ2hCLENBQUMsQ0FDSDtLQUNGLENBQUM7SUFDRixVQUFVLENBQUMsUUFBUSxFQUFFO1FBQ25CLE9BQU8sQ0FDTCxrQkFBa0IsRUFDbEIsS0FBSyxDQUFDO1lBQ0osQ0FBQyxRQUFRLENBQUMsRUFBRSxHQUFHO1NBQ2hCLENBQUMsQ0FDSDtLQUNGLENBQUM7Q0FDSCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhbmltYXRlLCBBbmltYXRpb25UcmlnZ2VyTWV0YWRhdGEsIHN0YXRlLCBzdHlsZSwgdHJhbnNpdGlvbiwgdHJpZ2dlciB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuXG5leHBvcnQgY29uc3QgZXhwYW5kQ29sbGFwc2VBbmltYXRpb24gPSAocHJvcGVydHk6ICdoZWlnaHQnIHwgJ3dpZHRoJyk6IEFuaW1hdGlvblRyaWdnZXJNZXRhZGF0YSA9PlxuICB0cmlnZ2VyKGAke3Byb3BlcnR5fUV4cGFuZENvbGxhcHNlQW5pbWF0aW9uYCwgW1xuICAgIHN0YXRlKFxuICAgICAgJ3ZvaWQnLFxuICAgICAgc3R5bGUoe1xuICAgICAgICBbcHJvcGVydHldOiAnMCcsXG4gICAgICB9KSxcbiAgICApLFxuICAgIHRyYW5zaXRpb24oJzplbnRlcicsIFtcbiAgICAgIGFuaW1hdGUoXG4gICAgICAgICcwLjJzIGVhc2UtaW4tb3V0JyxcbiAgICAgICAgc3R5bGUoe1xuICAgICAgICAgIFtwcm9wZXJ0eV06ICcqJyxcbiAgICAgICAgfSksXG4gICAgICApLFxuICAgIF0pLFxuICAgIHRyYW5zaXRpb24oJzpsZWF2ZScsIFtcbiAgICAgIGFuaW1hdGUoXG4gICAgICAgICcwLjJzIGVhc2UtaW4tb3V0JyxcbiAgICAgICAgc3R5bGUoe1xuICAgICAgICAgIFtwcm9wZXJ0eV06ICcwJyxcbiAgICAgICAgfSksXG4gICAgICApLFxuICAgIF0pLFxuICBdKTtcbiJdfQ==
|
|
@@ -94,10 +94,12 @@ export var KitSvgIcon;
|
|
|
94
94
|
KitSvgIcon["SUPPLY_CHAIN"] = "supply-chain";
|
|
95
95
|
KitSvgIcon["ANALYTICS"] = "analytics";
|
|
96
96
|
KitSvgIcon["CONTROL_PANEL"] = "control-panel";
|
|
97
|
+
KitSvgIcon["SEKO"] = "seko";
|
|
98
|
+
KitSvgIcon["SEKO_360"] = "seko-360";
|
|
97
99
|
})(KitSvgIcon || (KitSvgIcon = {}));
|
|
98
100
|
export var KitSvgIconType;
|
|
99
101
|
(function (KitSvgIconType) {
|
|
100
102
|
KitSvgIconType["FILL"] = "fill";
|
|
101
103
|
KitSvgIconType["STROKE"] = "stroke";
|
|
102
104
|
})(KitSvgIconType || (KitSvgIconType = {}));
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l0LXN2Zy1pY29uLmNvbnN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9raXQtc3ZnLWljb24va2l0LXN2Zy1pY29uLmNvbnN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLFVBaUdYO0FBakdELFdBQVksVUFBVTtJQUNwQiwyQkFBYSxDQUFBO0lBQ2IsMkNBQTZCLENBQUE7SUFDN0IsdUNBQXlCLENBQUE7SUFDekIsNkNBQStCLENBQUE7SUFDL0IsMkJBQWEsQ0FBQTtJQUNiLDJCQUFhLENBQUE7SUFDYixtQ0FBcUIsQ0FBQTtJQUNyQixpQ0FBbUIsQ0FBQTtJQUNuQiw2QkFBZSxDQUFBO0lBQ2YsaUNBQW1CLENBQUE7SUFDbkIseUJBQVcsQ0FBQTtJQUNYLCtCQUFpQixDQUFBO0lBQ2pCLDJCQUFhLENBQUE7SUFDYixtQ0FBcUIsQ0FBQTtJQUNyQiw2QkFBZSxDQUFBO0lBQ2YsNkJBQWUsQ0FBQTtJQUNmLDJDQUE2QixDQUFBO0lBQzdCLG1DQUFxQixDQUFBO0lBQ3JCLHFDQUF1QixDQUFBO0lBQ3ZCLCtCQUFpQixDQUFBO0lBQ2pCLGtDQUFvQixDQUFBO0lBQ3BCLDJCQUFhLENBQUE7SUFDYiw2Q0FBK0IsQ0FBQTtJQUMvQiwrQkFBaUIsQ0FBQTtJQUNqQiw2QkFBZSxDQUFBO0lBQ2YsNkJBQWUsQ0FBQTtJQUNmLDJDQUE2QixDQUFBO0lBQzdCLDZCQUFlLENBQUE7SUFDZixxQ0FBdUIsQ0FBQTtJQUN2Qix5QkFBVyxDQUFBO0lBQ1gseUJBQVcsQ0FBQTtJQUNYLHlCQUFXLENBQUE7SUFDWCxpQ0FBbUIsQ0FBQTtJQUNuQiwrQkFBaUIsQ0FBQTtJQUNqQixxQ0FBdUIsQ0FBQTtJQUN2QixpQ0FBbUIsQ0FBQTtJQUNuQiwrQkFBaUIsQ0FBQTtJQUNqQiwyQkFBYSxDQUFBO0lBQ2IsNkJBQWUsQ0FBQTtJQUNmLCtCQUFpQixDQUFBO0lBQ2pCLHVDQUF5QixDQUFBO0lBQ3pCLCtDQUFpQyxDQUFBO0lBQ2pDLGlEQUFtQyxDQUFBO0lBQ25DLHVDQUF5QixDQUFBO0lBQ3pCLCtDQUFpQyxDQUFBO0lBQ2pDLDJDQUE2QixDQUFBO0lBQzdCLHlDQUEyQixDQUFBO0lBQzNCLGlFQUFtRCxDQUFBO0lBQ25ELG1FQUFxRCxDQUFBO0lBQ3JELDJCQUFhLENBQUE7SUFDYiwrQ0FBaUMsQ0FBQTtJQUNqQywrQ0FBaUMsQ0FBQTtJQUNqQywrQkFBaUIsQ0FBQTtJQUNqQiwyQ0FBNkIsQ0FBQTtJQUM3QixxREFBdUMsQ0FBQTtJQUN2Qyw2QkFBZSxDQUFBO0lBQ2YsK0JBQWlCLENBQUE7SUFDakIsMkJBQWEsQ0FBQTtJQUNiLGlEQUFtQyxDQUFBO0lBQ25DLHlDQUEyQixDQUFBO0lBQzNCLG1DQUFxQixDQUFBO0lBQ3JCLHFDQUF1QixDQUFBO0lBQ3ZCLHVFQUF5RCxDQUFBO0lBQ3pELHVEQUF5QyxDQUFBO0lBQ3pDLDJEQUE2QyxDQUFBO0lBQzdDLDJCQUFhLENBQUE7SUFDYiw2QkFBZSxDQUFBO0lBQ2YsaUNBQW1CLENBQUE7SUFDbkIsMkJBQWEsQ0FBQTtJQUNiLCtCQUFpQixDQUFBO0lBQ2pCLDZCQUFlLENBQUE7SUFDZiw2QkFBZSxDQUFBO0lBQ2YsMkJBQWEsQ0FBQTtJQUNiLDJCQUFhLENBQUE7SUFDYiwyQkFBYSxDQUFBO0lBQ2IsaUNBQW1CLENBQUE7SUFDbkIsK0JBQWlCLENBQUE7SUFDakIsK0NBQWlDLENBQUE7SUFDakMsdUNBQXlCLENBQUE7SUFDekIsMkJBQWEsQ0FBQTtJQUNiLHVDQUF5QixDQUFBO0lBQ3pCLG1DQUFxQixDQUFBO0lBQ3JCLHlDQUEyQixDQUFBO0lBQzNCLHlEQUEyQyxDQUFBO0lBQzNDLDZEQUErQyxDQUFBO0lBQy9DLHlEQUEyQyxDQUFBO0lBQzNDLGlEQUFtQyxDQUFBO0lBQ25DLDJCQUFhLENBQUE7SUFDYiwrQ0FBaUMsQ0FBQTtJQUNqQyxpREFBbUMsQ0FBQTtJQUNuQyxtQ0FBcUIsQ0FBQTtJQUNyQiwyQ0FBNkIsQ0FBQTtJQUM3QixxQ0FBdUIsQ0FBQTtJQUN2Qiw2Q0FBK0IsQ0FBQTtJQUMvQiwyQkFBYSxDQUFBO0lBQ2IsbUNBQXFCLENBQUE7QUFDdkIsQ0FBQyxFQWpHVyxVQUFVLEtBQVYsVUFBVSxRQWlHckI7QUFFRCxNQUFNLENBQU4sSUFBWSxjQUdYO0FBSEQsV0FBWSxjQUFjO0lBQ3hCLCtCQUFhLENBQUE7SUFDYixtQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBSFcsY0FBYyxLQUFkLGNBQWMsUUFHekIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBLaXRTdmdJY29uIHtcbiAgTE9HTyA9ICdsb2dvJyxcbiAgQ0hFVlJPTl9ET1dOID0gJ2NoZXZyb24tZG93bicsXG4gIENIRVZST05fVVAgPSAnY2hldnJvbi11cCcsXG4gIENIRVZST05fUklHSFQgPSAnY2hldnJvbi1yaWdodCcsXG4gIFBMVVMgPSAncGx1cycsXG4gIElORk8gPSAnaW5mbycsXG4gIENBTEVOREFSID0gJ2NhbGVuZGFyJyxcbiAgV0FSTklORyA9ICd3YXJuaW5nJyxcbiAgRVJST1IgPSAnZXJyb3InLFxuICBTVUNDRVNTID0gJ3N1Y2Nlc3MnLFxuICBFWUUgPSAnZXllJyxcbiAgU0VBUkNIID0gJ3NlYXJjaCcsXG4gIEVESVQgPSAnZWRpdCcsXG4gIExPQ0FUSU9OID0gJ2xvY2F0aW9uJyxcbiAgQ1JPU1MgPSAnY3Jvc3MnLFxuICBDSEVDSyA9ICdjaGVjaycsXG4gIENIRUNLX0NJUkNMRSA9ICdjaGVjay1jaXJjbGUnLFxuICBESVNLRVRURSA9ICdkaXNrZXR0ZScsXG4gIENMSVBCT0FSRCA9ICdjbGlwYm9hcmQnLFxuICBMQVlFUlMgPSAnbGF5ZXJzJyxcbiAgS05BVUYgPSAna25hdWYtbG9nbycsXG4gIEhPTUUgPSAnaG9tZScsXG4gIERPVUJMRV9DSVJDTEUgPSAnZG91YmxlLWNpcmNsZScsXG4gIFBFTkNJTCA9ICdwZW5jaWwnLFxuICBPUkRFUiA9ICdvcmRlcicsXG4gIFJFU0VUID0gJ3Jlc2V0JyxcbiAgQ0lSQ0xFX0NST1NTID0gJ2NpcmNsZS1jcm9zcycsXG4gIFRSVUNLID0gJ3RydWNrJyxcbiAgREVMSVZFUkVEID0gJ2RlbGl2ZXJlZCcsXG4gIEZUTCA9ICdmdGwnLFxuICBMVEwgPSAnbHRsJyxcbiAgT1JHID0gJ29yZycsXG4gIEFSQ0hJVkUgPSAnYXJjaGl2ZScsXG4gIExPR09VVCA9ICdsb2dvdXQnLFxuICBDT05UQUlORVIgPSAnY29udGFpbmVyJyxcbiAgQ0FSUklFUiA9ICdjYXJyaWVyJyxcbiAgRVhQT1JUID0gJ2V4cG9ydCcsXG4gIEdFQVIgPSAnZ2VhcicsXG4gIFNUT0NLID0gJ3N0b2NrJyxcbiAgU1RBVFVTID0gJ3N0YXR1cycsXG4gIENMT1NFX1NJR04gPSAnY2xvc2Utc2lnbicsXG4gIENMT1NFX1NJR05fUkVEID0gJ2Nsb3NlLXNpZ24tcmVkJyxcbiAgT1BFTl9TSUdOX0dSRUVOID0gJ29wZW4tc2lnbi1ncmVlbicsXG4gIEFSUk9XX0xFRlQgPSAnYXJyb3ctbGVmdCcsXG4gIFdBUk5JTkdfWUVMTE9XID0gJ3dhcm5pbmcteWVsbG93JyxcbiAgQ0lSQ0xFX01JTlVTID0gJ2NpcmNsZS1taW51cycsXG4gIENJUkNMRV9QTFVTID0gJ2NpcmNsZS1wbHVzJyxcbiAgVEhSRUVfQ0lSQ0xFX0FSUk9XX0xFRlQgPSAndGhyZWUtY2lyY2xlLWFycm93LWxlZnQnLFxuICBUSFJFRV9DSVJDTEVfQVJST1dfUklHSFQgPSAndGhyZWUtY2lyY2xlLWFycm93LXJpZ2h0JyxcbiAgU0VORCA9ICdzZW5kJyxcbiAgQ0FMRU5EQVJfQ0hFQ0sgPSAnY2FsZW5kYXItY2hlY2snLFxuICBDTElQQk9BUkRfVEhJTiA9ICdjbGlwYm9hcmQtdGhpbicsXG4gIFdBTExFVCA9ICd3YWxsZXQnLFxuICBDSVJDTEVfUFVMU0UgPSAnY2lyY2xlLXB1bHNlJyxcbiAgQ0lSQ0xFX0NST1NTX1RISU4gPSAnY2lyY2xlLWNyb3NzLXRoaW4nLFxuICBUUkFTSCA9ICd0cmFzaCcsXG4gIFdSRU5DSCA9ICd3cmVuY2gnLFxuICBUSU1FID0gJ3RpbWUnLFxuICBXQVJOSU5HX0RFRkFVTFQgPSAnd2FybmluZy1kZWZhdWx0JyxcbiAgUk9UQVRFX0xFRlQgPSAncm90YXRlLWxlZnQnLFxuICBET1dOTE9BRCA9ICdkb3dubG9hZCcsXG4gIEZJTEVfVEVYVCA9ICdmaWxlLXRleHQnLFxuICBBUlJPV19VUF9SSUdIVF9GUk9NX1NRVUFSRSA9ICdhcnJvdy11cC1yaWdodC1mcm9tLXNxdWFyZScsXG4gIENJUkNMRV9FWENMQU1BVElPTiA9ICdjaXJjbGUtZXhjbGFtYXRpb24nLFxuICBUUklBTkdMRV9FWENMQU1BVElPTiA9ICd0cmlhbmdsZS1leGNsYW1hdGlvbicsXG4gIFNISVAgPSAnc2hpcCcsXG4gIENMT0NLID0gJ2Nsb2NrJyxcbiAgRkFDVE9SWSA9ICdmYWN0b3J5JyxcbiAgQ09QWSA9ICdjb3B5JyxcbiAgR0VBUl8xID0gJ2dlYXItMScsXG4gIEhPVVNFID0gJ2hvdXNlJyxcbiAgQ0hBUlQgPSAnY2hhcnQnLFxuICBDTElQID0gJ2NsaXAnLFxuICBNQUlMID0gJ21haWwnLFxuICBNRU5VID0gJ21lbnUnLFxuICBNRVNTQUdFID0gJ21lc3NhZ2UnLFxuICBSRUxPQUQgPSAncmVsb2FkJyxcbiAgV0lORE9XX1JFU1RPUkUgPSAnd2luZG93LXJlc3RvcmUnLFxuICBCQUNLX0FSUk9XID0gJ2JhY2stYXJyb3cnLFxuICBVU0VSID0gJ3VzZXInLFxuICBDQVJFVF9ET1dOID0gJ2NhcmV0LWRvd24nLFxuICBDQVJFVF9VUCA9ICdjYXJldC11cCcsXG4gIElORk9fQ0lSQ0xFID0gJ2luZm8tY2lyY2xlJyxcbiAgQ0hFQ0tfQ0lSQ0xFX0ZJTExFRCA9ICdjaGVjay1jaXJjbGUtZmlsbGVkJyxcbiAgV0FSTklOR19DSVJDTEVfRklMTEVEID0gJ3dhcm5pbmctY2lyY2xlLWZpbGxlZCcsXG4gIENMT1NFX0NJUkNMRV9GSUxMRUQgPSAnY2xvc2UtY2lyY2xlLWZpbGxlZCcsXG4gIFFVRVNUSU9OX0NJUkNMRSA9ICdxdWVzdGlvbi1jaXJjbGUnLFxuICBTVEFSID0gJ3N0YXInLFxuICBTT1JUX0FTQ0VORElORyA9ICdzb3J0LWFzY2VuZGluZycsXG4gIFNPUlRfREVTQ0VORElORyA9ICdzb3J0LWRlc2NlbmRpbmcnLFxuICBQQVlNRU5UUyA9ICdwYXltZW50cycsXG4gIFNVUFBMWV9DSEFJTiA9ICdzdXBwbHktY2hhaW4nLFxuICBBTkFMWVRJQ1MgPSAnYW5hbHl0aWNzJyxcbiAgQ09OVFJPTF9QQU5FTCA9ICdjb250cm9sLXBhbmVsJyxcbiAgU0VLTyA9ICdzZWtvJyxcbiAgU0VLT18zNjAgPSAnc2Vrby0zNjAnLFxufVxuXG5leHBvcnQgZW51bSBLaXRTdmdJY29uVHlwZSB7XG4gIEZJTEwgPSAnZmlsbCcsXG4gIFNUUk9LRSA9ICdzdHJva2UnLFxufVxuIl19
|