@agorapulse/ui-components 18.0.9 → 18.0.11
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/agorapulse-ui-components-18.0.11.tgz +0 -0
- package/esm2022/datepicker/datepicker.component.mjs +1 -1
- package/esm2022/index.mjs +2 -1
- package/esm2022/input-search/input-search.component.mjs +5 -4
- package/esm2022/nav-selector/agorapulse-ui-components-nav-selector.mjs +5 -0
- package/esm2022/nav-selector/directives/tree-node-accessibility.directive.mjs +30 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +81 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.presenter.mjs +29 -0
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +142 -0
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.presenter.mjs +31 -0
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +240 -0
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.mjs +35 -0
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.mjs +39 -0
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.presenter.mjs +18 -0
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs +92 -0
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.presenter.mjs +31 -0
- package/esm2022/nav-selector/nav-selector.component.mjs +123 -0
- package/esm2022/nav-selector/nav-selector.mjs +9 -0
- package/esm2022/nav-selector/nav-selector.state.mjs +173 -0
- package/esm2022/nav-selector/public_api.mjs +2 -0
- package/esm2022/nav-selector/utils/leaf.utils.mjs +10 -0
- package/esm2022/nav-selector/utils/nav-selector.accessibility.mjs +171 -0
- package/esm2022/nav-selector/utils/nav-selector.builder.mjs +263 -0
- package/esm2022/nav-selector/utils/nav-selector.filter.mjs +102 -0
- package/esm2022/nav-selector/utils/nav-selector.folding.mjs +219 -0
- package/esm2022/nav-selector/utils/nav-selector.minifying.mjs +50 -0
- package/esm2022/nav-selector/utils/nav-selector.multi-select.mjs +208 -0
- package/esm2022/nav-selector/utils/nav-selector.single-select.mjs +91 -0
- package/esm2022/nav-selector/utils/nav-selector.view-more.mjs +98 -0
- package/fesm2022/agorapulse-ui-components-datepicker.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-input-search.mjs +4 -3
- package/fesm2022/agorapulse-ui-components-input-search.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs +2198 -0
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -0
- package/fesm2022/agorapulse-ui-components.mjs +1 -0
- package/fesm2022/agorapulse-ui-components.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/input-search/input-search.component.d.ts +1 -1
- package/nav-selector/directives/tree-node-accessibility.directive.d.ts +9 -0
- package/nav-selector/index.d.ts +5 -0
- package/nav-selector/nav-selector-category/nav-selector-category.component.d.ts +16 -0
- package/nav-selector/nav-selector-category/nav-selector-category.presenter.d.ts +14 -0
- package/nav-selector/nav-selector-group/nav-selector-group.component.d.ts +29 -0
- package/nav-selector/nav-selector-group/nav-selector-group.presenter.d.ts +17 -0
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.component.d.ts +51 -0
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.d.ts +19 -0
- package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.d.ts +13 -0
- package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.presenter.d.ts +10 -0
- package/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.d.ts +24 -0
- package/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.presenter.d.ts +14 -0
- package/nav-selector/nav-selector.component.d.ts +29 -0
- package/nav-selector/nav-selector.d.ts +220 -0
- package/nav-selector/nav-selector.state.d.ts +47 -0
- package/nav-selector/public_api.d.ts +2 -0
- package/nav-selector/utils/leaf.utils.d.ts +5 -0
- package/nav-selector/utils/nav-selector.accessibility.d.ts +52 -0
- package/nav-selector/utils/nav-selector.builder.d.ts +32 -0
- package/nav-selector/utils/nav-selector.filter.d.ts +30 -0
- package/nav-selector/utils/nav-selector.folding.d.ts +47 -0
- package/nav-selector/utils/nav-selector.minifying.d.ts +27 -0
- package/nav-selector/utils/nav-selector.multi-select.d.ts +54 -0
- package/nav-selector/utils/nav-selector.single-select.d.ts +15 -0
- package/nav-selector/utils/nav-selector.view-more.d.ts +30 -0
- package/package.json +13 -7
- package/agorapulse-ui-components-18.0.9.tgz +0 -0
|
@@ -0,0 +1,240 @@
|
|
|
1
|
+
import { AvatarComponent } from '@agorapulse/ui-components/avatar';
|
|
2
|
+
import { CheckboxComponent } from '@agorapulse/ui-components/checkbox';
|
|
3
|
+
import { CounterComponent } from '@agorapulse/ui-components/counter';
|
|
4
|
+
import { TooltipDirective } from '@agorapulse/ui-components/tooltip';
|
|
5
|
+
import { apChevronDown, apChevronUp, apErrorFill, apFeatureLock, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';
|
|
6
|
+
import { apMore } from '@agorapulse/ui-symbol/icons';
|
|
7
|
+
import { animate, keyframes, state, style, transition, trigger } from '@angular/animations';
|
|
8
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
9
|
+
import { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, input, signal, viewChild } from '@angular/core';
|
|
10
|
+
import { MatMenu, MatMenuItem, MatMenuTrigger } from '@angular/material/menu';
|
|
11
|
+
import { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';
|
|
12
|
+
import { NavSelectorLeafDetailComponent } from '../nav-selector-leaf-detail/nav-selector-leaf-detail.component';
|
|
13
|
+
import { NavSelectorLeafDetailsComponent } from '../nav-selector-leaf-details/nav-selector-leaf-details.component';
|
|
14
|
+
import { NavSelectorLeafPresenter } from './nav-selector-leaf.presenter';
|
|
15
|
+
import * as i0 from "@angular/core";
|
|
16
|
+
import * as i1 from "./nav-selector-leaf.presenter";
|
|
17
|
+
export class NavSelectorLeafComponent {
|
|
18
|
+
el;
|
|
19
|
+
navSelectorLeafPresenter;
|
|
20
|
+
leaf = input.required();
|
|
21
|
+
initial = computed(() => this.leaf().alias[0].toUpperCase());
|
|
22
|
+
foldSymbol = computed(() => (this.leaf().folded ? 'chevron-down' : 'chevron-up'));
|
|
23
|
+
hovering = signal(false);
|
|
24
|
+
hoveringMenu = signal(false);
|
|
25
|
+
onlyButtonDisplayed = computed(() => this.navSelectorLeafPresenter.isMultipleModeEnabled() &&
|
|
26
|
+
(this.hovering() || this.leaf().accessibility.tabIndex === 0) &&
|
|
27
|
+
this.leaf().selectable);
|
|
28
|
+
aliasEl = viewChild('alias');
|
|
29
|
+
aliasBoundedClientRect = signal({
|
|
30
|
+
offsetWidth: 0,
|
|
31
|
+
offsetHeight: 0,
|
|
32
|
+
scrollWidth: 0,
|
|
33
|
+
scrollHeight: 0,
|
|
34
|
+
});
|
|
35
|
+
tooltipContent = computed(() => {
|
|
36
|
+
const content = [];
|
|
37
|
+
const el = this.aliasBoundedClientRect();
|
|
38
|
+
if (!this.navSelectorLeafPresenter.expanded() || el.offsetWidth < el.scrollWidth || el.offsetHeight < el.scrollHeight) {
|
|
39
|
+
content.push(this.leaf().alias);
|
|
40
|
+
}
|
|
41
|
+
const disableReason = this.leaf().disableReason;
|
|
42
|
+
if (disableReason) {
|
|
43
|
+
content.push(disableReason);
|
|
44
|
+
}
|
|
45
|
+
if (this.leaf().displayFeatureLocked) {
|
|
46
|
+
content.push(this.navSelectorLeafPresenter.texts().featureLocked);
|
|
47
|
+
}
|
|
48
|
+
if (this.leaf().displayTokenInvalid) {
|
|
49
|
+
content.push(this.navSelectorLeafPresenter.texts().tokenInvalid);
|
|
50
|
+
}
|
|
51
|
+
return content.join('<br>');
|
|
52
|
+
});
|
|
53
|
+
tooltipDisabled = computed(() => !this.tooltipContent().length || this.leaf().detailsDisplayable);
|
|
54
|
+
minifiedEl = viewChild('minified');
|
|
55
|
+
menuEl = viewChild('menuContainer');
|
|
56
|
+
menuTriggerEl = viewChild('menuTrigger');
|
|
57
|
+
actionMenuTriggerEl = viewChild('actionMenuTrigger');
|
|
58
|
+
foldedWithDelay = signal(false);
|
|
59
|
+
network = computed(() => (this.leaf().network ? this.leaf().network : undefined));
|
|
60
|
+
constructor(el, navSelectorLeafPresenter) {
|
|
61
|
+
this.el = el;
|
|
62
|
+
this.navSelectorLeafPresenter = navSelectorLeafPresenter;
|
|
63
|
+
afterNextRender(() => {
|
|
64
|
+
this.maxHeight.set(`${this.el.nativeElement.scrollHeight}px`);
|
|
65
|
+
const el = this.aliasEl()?.nativeElement;
|
|
66
|
+
if (el) {
|
|
67
|
+
this.aliasBoundedClientRect.set({
|
|
68
|
+
offsetWidth: el.offsetWidth,
|
|
69
|
+
offsetHeight: el.offsetHeight,
|
|
70
|
+
scrollWidth: el.scrollWidth,
|
|
71
|
+
scrollHeight: el.scrollHeight,
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
effect(() => {
|
|
76
|
+
if (this.leaf().folded) {
|
|
77
|
+
setTimeout(() => this.foldedWithDelay.set(true), 150);
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
this.foldedWithDelay.set(false);
|
|
81
|
+
}
|
|
82
|
+
}, { allowSignalWrites: true });
|
|
83
|
+
}
|
|
84
|
+
animationState = computed(() => (this.leaf().folded ? 'collapsed' : 'expanded'));
|
|
85
|
+
maxHeight = signal('0px');
|
|
86
|
+
onClick($event) {
|
|
87
|
+
$event.stopImmediatePropagation();
|
|
88
|
+
this.navSelectorLeafPresenter.onLeafClicked(this.leaf());
|
|
89
|
+
}
|
|
90
|
+
toggleFolding(event) {
|
|
91
|
+
event.stopImmediatePropagation();
|
|
92
|
+
this.navSelectorLeafPresenter.onLeafToggleFolding(this.leaf());
|
|
93
|
+
}
|
|
94
|
+
mouseEntered() {
|
|
95
|
+
this.hovering.set(true);
|
|
96
|
+
const menuTrigger = this.menuTriggerEl();
|
|
97
|
+
if (menuTrigger && this.leaf().detailsDisplayable) {
|
|
98
|
+
menuTrigger.openMenu();
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
mouseLeft($event) {
|
|
102
|
+
this.hovering.set(false);
|
|
103
|
+
const menuTrigger = this.menuTriggerEl();
|
|
104
|
+
if (menuTrigger) {
|
|
105
|
+
setTimeout(() => {
|
|
106
|
+
this.tryCloseMenu(menuTrigger, $event);
|
|
107
|
+
}, 100);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
mouseEnteredMenu() {
|
|
111
|
+
this.hoveringMenu.set(true);
|
|
112
|
+
}
|
|
113
|
+
mouseLeftMenu(menuTrigger, $event) {
|
|
114
|
+
this.hoveringMenu.set(false);
|
|
115
|
+
this.tryCloseMenu(menuTrigger, $event);
|
|
116
|
+
}
|
|
117
|
+
menuOpened() {
|
|
118
|
+
if (!this.leaf().detailsDisplayable) {
|
|
119
|
+
this.menuTriggerEl()?.closeMenu();
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
onActionButtonClick($event) {
|
|
123
|
+
$event.stopImmediatePropagation();
|
|
124
|
+
}
|
|
125
|
+
onActionButtonKeyDownSpaceOrEnter($event) {
|
|
126
|
+
$event.stopImmediatePropagation();
|
|
127
|
+
this.actionMenuTriggerEl()?.openMenu();
|
|
128
|
+
}
|
|
129
|
+
selectOnly(event) {
|
|
130
|
+
event.stopImmediatePropagation();
|
|
131
|
+
this.navSelectorLeafPresenter.selectOnlyLeaf(this.leaf());
|
|
132
|
+
}
|
|
133
|
+
onCheckboxToggle() {
|
|
134
|
+
this.navSelectorLeafPresenter.onLeafClicked(this.leaf());
|
|
135
|
+
}
|
|
136
|
+
onSpaceOrEnterPressed($event) {
|
|
137
|
+
$event.stopImmediatePropagation();
|
|
138
|
+
if (document.activeElement === this.el.nativeElement.querySelector('.nav-selector-leaf')) {
|
|
139
|
+
if (this.leaf().foldable) {
|
|
140
|
+
this.toggleFolding($event);
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
this.navSelectorLeafPresenter.onLeafClicked(this.leaf());
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
fold(event) {
|
|
148
|
+
event.stopImmediatePropagation();
|
|
149
|
+
this.navSelectorLeafPresenter.fold(this.leaf());
|
|
150
|
+
}
|
|
151
|
+
unfold(event) {
|
|
152
|
+
event.stopImmediatePropagation();
|
|
153
|
+
this.navSelectorLeafPresenter.unfold(this.leaf());
|
|
154
|
+
}
|
|
155
|
+
tryCloseMenu(menuTrigger, $event) {
|
|
156
|
+
if (!this.hoveringMenu()) {
|
|
157
|
+
const minifiedEl = this.minifiedEl();
|
|
158
|
+
const minifiedBoundedClientRect = minifiedEl.nativeElement.getBoundingClientRect();
|
|
159
|
+
const mouseHoveringLeaf = this.mouseIsHovering($event, minifiedBoundedClientRect);
|
|
160
|
+
const menuEl = this.menuEl();
|
|
161
|
+
const menuBoundedClientRect = menuEl.nativeElement.getBoundingClientRect();
|
|
162
|
+
const mouseHoveringMenu = this.mouseIsHovering($event, menuBoundedClientRect);
|
|
163
|
+
if (!mouseHoveringLeaf && !mouseHoveringMenu) {
|
|
164
|
+
menuTrigger.closeMenu();
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
mouseIsHovering($event, boundingClientRect) {
|
|
169
|
+
return (boundingClientRect.left <= $event.clientX &&
|
|
170
|
+
$event.clientX <= boundingClientRect.right &&
|
|
171
|
+
boundingClientRect.top <= $event.clientY &&
|
|
172
|
+
$event.clientY <= boundingClientRect.bottom);
|
|
173
|
+
}
|
|
174
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafComponent, deps: [{ token: i0.ElementRef }, { token: i1.NavSelectorLeafPresenter }], target: i0.ɵɵFactoryTarget.Component });
|
|
175
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorLeafComponent, isStandalone: true, selector: "ap-nav-selector-leaf", inputs: { leaf: { classPropertyName: "leaf", publicName: "leaf", isSignal: true, isRequired: true, transformFunction: null } }, host: { attributes: { "role": "treeitem" }, listeners: { "mouseenter": "mouseEntered()", "mouseleave": "mouseLeft($event)", "keydown.arrowLeft": "fold($event)", "keydown.arrowRight": "unfold($event)" }, properties: { "class.minified": "!navSelectorLeafPresenter.expanded()" } }, providers: [withSymbols(apErrorFill, apFeatureLock, apChevronDown, apChevronUp, apMore), NavSelectorLeafPresenter], viewQueries: [{ propertyName: "aliasEl", first: true, predicate: ["alias"], descendants: true, isSignal: true }, { propertyName: "minifiedEl", first: true, predicate: ["minified"], descendants: true, isSignal: true }, { propertyName: "menuEl", first: true, predicate: ["menuContainer"], descendants: true, isSignal: true }, { propertyName: "menuTriggerEl", first: true, predicate: ["menuTrigger"], descendants: true, isSignal: true }, { propertyName: "actionMenuTriggerEl", first: true, predicate: ["actionMenuTrigger"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (navSelectorLeafPresenter.expandedAfterDelay()) {\n <div\n class=\"nav-selector-leaf\"\n apTooltipPosition=\"right\"\n role=\"treeitem\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [class.feature-locked]=\"leaf().displayFeatureLocked\"\n [class.selected]=\"leaf().selected\"\n [class.token-error]=\"leaf().displayTokenInvalid\"\n [class.disabled]=\"leaf().disabled\"\n [apTreeNodeAccessibility]=\"leaf()\"\n (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n (click)=\"onClick($event)\">\n @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"leaf().uid\"\n [checked]=\"leaf().selected\"\n [disabled]=\"!leaf().selectable\"\n (change)=\"onCheckboxToggle()\" />\n }\n <ap-avatar\n size=\"24\"\n [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n [network]=\"$any(leaf().network)\"\n [showInitials]=\"initial()\" />\n\n <span\n #alias\n class=\"caption\">\n {{ leaf().alias }}\n </span>\n\n @if (onlyButtonDisplayed()) {\n <a\n class=\"standalone\"\n role=\"button\"\n [attr.aria-label]=\"'Select only ' + leaf().alias\"\n [attr.tabindex]=\"leaf().accessibility.tabIndex\"\n (keydown.space)=\"selectOnly($event)\"\n (keydown.enter)=\"selectOnly($event)\"\n (click)=\"selectOnly($event)\">\n {{ navSelectorLeafPresenter.texts().only }}\n </a>\n } @else {\n @if (leaf().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ leaf().counter }}\n </ap-counter>\n }\n @if (leaf().displayTokenInvalid) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n }\n @if (leaf().displayFeatureLocked) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"feature-lock\" />\n }\n\n @let actionProjection = navSelectorLeafPresenter.leafActionProjection();\n @if (actionProjection?.length) {\n <ap-symbol\n #actionMenuTrigger=\"matMenuTrigger\"\n class=\"actions-menu\"\n size=\"sm\"\n symbolId=\"more\"\n [tabindex]=\"leaf().accessibility.tabIndex\"\n [attr.aria-label]=\"'Action menu ' + leaf().alias\"\n [matMenuTriggerFor]=\"actionMenu\"\n (click)=\"onActionButtonClick($event)\"\n (keydown.space)=\"onActionButtonKeyDownSpaceOrEnter($event)\"\n (keydown.enter)=\"onActionButtonKeyDownSpaceOrEnter($event)\" />\n\n <mat-menu #actionMenu=\"matMenu\">\n @for (action of actionProjection; track action) {\n <button mat-menu-item>\n <ng-container\n [ngTemplateOutlet]=\"action\"\n [ngTemplateOutletContext]=\"{\n uid: leaf().uid\n }\" />\n </button>\n }\n </mat-menu>\n }\n\n @if (leaf().foldable) {\n <ap-symbol\n class=\"folding-button\"\n size=\"sm\"\n role=\"button\"\n [tabindex]=\"leaf().accessibility.tabIndex\"\n [attr.aria-label]=\"'Toggle ' + leaf().alias\"\n [symbolId]=\"foldSymbol()\"\n (click)=\"toggleFolding($event)\"\n (keydown.space)=\"toggleFolding($event)\"\n (keydown.enter)=\"toggleFolding($event)\" />\n }\n }\n </div>\n\n <div\n class=\"details-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <ap-nav-selector-leaf-details [details]=\"leaf().details\" [leaf]=\"leaf()\"/>\n }\n </div>\n} @else {\n <div\n #menuTrigger=\"matMenuTrigger\"\n #minified\n class=\"nav-selector-leaf\"\n apTooltipPosition=\"right\"\n [matMenuTriggerFor]=\"menu\"\n [class.feature-locked]=\"leaf().displayFeatureLocked\"\n [class.selected]=\"leaf().selected\"\n [class.token-error]=\"leaf().displayTokenInvalid\"\n [class.disabled]=\"leaf().disabled\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"leaf()\"\n (menuOpened)=\"menuOpened()\"\n (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n (click)=\"onClick($event)\">\n @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"leaf().uid\"\n [checked]=\"leaf().selected\"\n [disabled]=\"!leaf().selectable\" />\n }\n\n <div class=\"avatar-container\">\n <ap-avatar\n size=\"24\"\n [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n [network]=\"$any(leaf().network)\"\n [showInitials]=\"initial()\" />\n\n <div class=\"status\">\n @if (leaf().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [notif]=\"true\"\n [background]=\"true\">\n {{ leaf().counter }}\n </ap-counter>\n }\n @if (leaf().displayTokenInvalid) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n }\n @if (leaf().displayFeatureLocked) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"feature-lock\" />\n }\n </div>\n </div>\n <mat-menu\n #menu=\"matMenu\"\n class=\"nav-selector-leaf-menu\"\n xPosition=\"after\"\n [hasBackdrop]=\"false\">\n <div\n #menuContainer\n [class.not-displayable]=\"!leaf().detailsDisplayable\"\n (mouseenter)=\"mouseEnteredMenu()\"\n (mouseleave)=\"mouseLeftMenu(menuTrigger, $event)\">\n <button mat-menu-item>\n <span class=\"caption-bold\">{{ leaf().alias }}</span>\n </button>\n @for (detail of leaf().details; track detail.uid) {\n <button\n mat-menu-item\n [class.selected]=\"detail.selected\">\n <ap-nav-selector-leaf-detail\n [embedded]=\"true\"\n [detail]=\"detail\" />\n </button>\n }\n </div>\n </mat-menu>\n </div>\n}\n", styles: [":host{display:flex;gap:2px;flex-shrink:0;align-self:stretch;flex-direction:column}:host .details-container{align-self:stretch}:host .nav-selector-leaf{position:relative;display:flex;padding:0 var(--ref-spacing-xxs);height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch}:host .caption{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1;flex:1 0 0;overflow:hidden;color:var(--ref-color-grey-100);text-overflow:ellipsis;font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-regular);line-height:var(--ref-font-line-height-xs)}:host ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host ap-symbol[symbol-id=feature-lock]{color:var(--ref-color-purple-100)}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host .folding-button,:host .actions-menu{display:flex;width:24px;height:24px;justify-content:center;align-items:center;flex-shrink:0}:host .folding-button:hover,:host .actions-menu:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .folding-button:active,:host .actions-menu:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-40)}:host .folding-button:focus,:host .actions-menu:focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20);box-shadow:0 0 0 1px #fff,0 0 0 3px #178dfe}:host .nav-selector-leaf:not(.disabled){cursor:pointer}:host .nav-selector-leaf:not(.disabled):hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .nav-selector-leaf:not(.disabled):active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled):focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10);box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .nav-selector-leaf:not(.disabled):focus-within{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled).selected{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled).selected:focus{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .nav-selector-leaf.feature-locked{border-radius:var(--ref-border-radius-sm)}:host .nav-selector-leaf.feature-locked:hover{background:var(--ref-color-purple-10)}:host .nav-selector-leaf.feature-locked:active{background:var(--ref-color-purple-20)}:host .nav-selector-leaf.feature-locked:focus{background:var(--ref-color-purple-10);box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-purple-100)}:host .nav-selector-leaf.feature-locked.selected{background:var(--ref-color-purple-20)}:host .nav-selector-leaf.feature-locked.selected:focus{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .nav-selector-leaf.disabled{opacity:.5}:host .status{position:absolute;right:-4px;top:-6px}:host .avatar-container{position:relative}:host.minified .nav-selector-leaf{gap:var(--ref-spacing-xxxs);justify-content:center}:host.minified ::ng-deep ap-checkbox .checkbox .checkbox-container{padding:0}::ng-deep .nav-selector-leaf-menu{position:absolute;left:55px;top:-20%;width:225px}::ng-deep .nav-selector-leaf-menu .not-displayable{display:none}::ng-deep .nav-selector-leaf-menu .caption-bold{color:var(--ref-color-grey-100);font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-xs)}::ng-deep .nav-selector-leaf-menu.mat-mdc-menu-panel:not(.pop-menu) .mat-mdc-menu-item.selected{background:var(--ref-color-electric-blue-20)}::ng-deep .nav-selector-leaf-menu.mat-mdc-menu-panel:not(.pop-menu) .mat-mdc-menu-item ap-symbol{padding-right:0}\n"], dependencies: [{ kind: "component", type: AvatarComponent, selector: "ap-avatar", inputs: ["profilePicture", "alt", "network", "size", "username", "showInitials", "bigNetwork", "anonymous", "online", "youtubeAvatarMode", "rounded"] }, { kind: "component", type: CounterComponent, selector: "ap-counter", inputs: ["color", "size", "background", "notif"] }, { kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }, { kind: "component", type: NavSelectorLeafDetailsComponent, selector: "ap-nav-selector-leaf-details", inputs: ["leaf", "details"] }, { kind: "component", type: CheckboxComponent, selector: "ap-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "disabled", "indeterminate", "checked", "required", "name"], outputs: ["change"] }, { kind: "directive", type: TooltipDirective, selector: "[apTooltip]", inputs: ["apTooltip", "apTooltipPosition", "apTooltipShowDelay", "apTooltipHideDelay", "apTooltipDuration", "apTooltipDisabled", "apTooltipTruncatedTextOnly", "apTooltipTemplateContext", "apTooltipVirtualScrollElement"] }, { kind: "component", type: MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "directive", type: MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "component", type: NavSelectorLeafDetailComponent, selector: "ap-nav-selector-leaf-detail", inputs: ["detail", "embedded"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: TreeNodeAccessibilityDirective, selector: "[apTreeNodeAccessibility]", inputs: ["apTreeNodeAccessibility"] }], animations: [
|
|
176
|
+
/**
|
|
177
|
+
* Overflow hidden is put only during the animation and on the collapsed state because if it is put on the expanded state then children’s border will be cut (hover / focus)
|
|
178
|
+
*/
|
|
179
|
+
trigger('accordion', [
|
|
180
|
+
state('collapsed', style({
|
|
181
|
+
maxHeight: 0,
|
|
182
|
+
overflow: 'hidden',
|
|
183
|
+
})),
|
|
184
|
+
state('expanded', style({
|
|
185
|
+
maxHeight: 'initial',
|
|
186
|
+
})),
|
|
187
|
+
transition('collapsed => expanded', [
|
|
188
|
+
animate('250ms cubic-bezier(.4, 0, .3, 1)', style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' })),
|
|
189
|
+
]),
|
|
190
|
+
transition('expanded => collapsed', [
|
|
191
|
+
animate('250ms cubic-bezier(.4, 0, .3, 1)', keyframes([style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' }), style({ maxHeight: 0 })])),
|
|
192
|
+
]),
|
|
193
|
+
]),
|
|
194
|
+
], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
195
|
+
}
|
|
196
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafComponent, decorators: [{
|
|
197
|
+
type: Component,
|
|
198
|
+
args: [{ selector: 'ap-nav-selector-leaf', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
199
|
+
AvatarComponent,
|
|
200
|
+
CounterComponent,
|
|
201
|
+
SymbolComponent,
|
|
202
|
+
NavSelectorLeafDetailsComponent,
|
|
203
|
+
CheckboxComponent,
|
|
204
|
+
TooltipDirective,
|
|
205
|
+
MatMenu,
|
|
206
|
+
MatMenuTrigger,
|
|
207
|
+
MatMenuItem,
|
|
208
|
+
NavSelectorLeafDetailComponent,
|
|
209
|
+
NavSelectorLeafDetailComponent,
|
|
210
|
+
NgTemplateOutlet,
|
|
211
|
+
TreeNodeAccessibilityDirective,
|
|
212
|
+
], providers: [withSymbols(apErrorFill, apFeatureLock, apChevronDown, apChevronUp, apMore), NavSelectorLeafPresenter], host: {
|
|
213
|
+
'[class.minified]': '!navSelectorLeafPresenter.expanded()',
|
|
214
|
+
role: 'treeitem',
|
|
215
|
+
'(mouseenter)': 'mouseEntered()',
|
|
216
|
+
'(mouseleave)': 'mouseLeft($event)',
|
|
217
|
+
'(keydown.arrowLeft)': 'fold($event)',
|
|
218
|
+
'(keydown.arrowRight)': 'unfold($event)',
|
|
219
|
+
}, animations: [
|
|
220
|
+
/**
|
|
221
|
+
* Overflow hidden is put only during the animation and on the collapsed state because if it is put on the expanded state then children’s border will be cut (hover / focus)
|
|
222
|
+
*/
|
|
223
|
+
trigger('accordion', [
|
|
224
|
+
state('collapsed', style({
|
|
225
|
+
maxHeight: 0,
|
|
226
|
+
overflow: 'hidden',
|
|
227
|
+
})),
|
|
228
|
+
state('expanded', style({
|
|
229
|
+
maxHeight: 'initial',
|
|
230
|
+
})),
|
|
231
|
+
transition('collapsed => expanded', [
|
|
232
|
+
animate('250ms cubic-bezier(.4, 0, .3, 1)', style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' })),
|
|
233
|
+
]),
|
|
234
|
+
transition('expanded => collapsed', [
|
|
235
|
+
animate('250ms cubic-bezier(.4, 0, .3, 1)', keyframes([style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' }), style({ maxHeight: 0 })])),
|
|
236
|
+
]),
|
|
237
|
+
]),
|
|
238
|
+
], template: "@if (navSelectorLeafPresenter.expandedAfterDelay()) {\n <div\n class=\"nav-selector-leaf\"\n apTooltipPosition=\"right\"\n role=\"treeitem\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [class.feature-locked]=\"leaf().displayFeatureLocked\"\n [class.selected]=\"leaf().selected\"\n [class.token-error]=\"leaf().displayTokenInvalid\"\n [class.disabled]=\"leaf().disabled\"\n [apTreeNodeAccessibility]=\"leaf()\"\n (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n (click)=\"onClick($event)\">\n @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"leaf().uid\"\n [checked]=\"leaf().selected\"\n [disabled]=\"!leaf().selectable\"\n (change)=\"onCheckboxToggle()\" />\n }\n <ap-avatar\n size=\"24\"\n [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n [network]=\"$any(leaf().network)\"\n [showInitials]=\"initial()\" />\n\n <span\n #alias\n class=\"caption\">\n {{ leaf().alias }}\n </span>\n\n @if (onlyButtonDisplayed()) {\n <a\n class=\"standalone\"\n role=\"button\"\n [attr.aria-label]=\"'Select only ' + leaf().alias\"\n [attr.tabindex]=\"leaf().accessibility.tabIndex\"\n (keydown.space)=\"selectOnly($event)\"\n (keydown.enter)=\"selectOnly($event)\"\n (click)=\"selectOnly($event)\">\n {{ navSelectorLeafPresenter.texts().only }}\n </a>\n } @else {\n @if (leaf().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ leaf().counter }}\n </ap-counter>\n }\n @if (leaf().displayTokenInvalid) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n }\n @if (leaf().displayFeatureLocked) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"feature-lock\" />\n }\n\n @let actionProjection = navSelectorLeafPresenter.leafActionProjection();\n @if (actionProjection?.length) {\n <ap-symbol\n #actionMenuTrigger=\"matMenuTrigger\"\n class=\"actions-menu\"\n size=\"sm\"\n symbolId=\"more\"\n [tabindex]=\"leaf().accessibility.tabIndex\"\n [attr.aria-label]=\"'Action menu ' + leaf().alias\"\n [matMenuTriggerFor]=\"actionMenu\"\n (click)=\"onActionButtonClick($event)\"\n (keydown.space)=\"onActionButtonKeyDownSpaceOrEnter($event)\"\n (keydown.enter)=\"onActionButtonKeyDownSpaceOrEnter($event)\" />\n\n <mat-menu #actionMenu=\"matMenu\">\n @for (action of actionProjection; track action) {\n <button mat-menu-item>\n <ng-container\n [ngTemplateOutlet]=\"action\"\n [ngTemplateOutletContext]=\"{\n uid: leaf().uid\n }\" />\n </button>\n }\n </mat-menu>\n }\n\n @if (leaf().foldable) {\n <ap-symbol\n class=\"folding-button\"\n size=\"sm\"\n role=\"button\"\n [tabindex]=\"leaf().accessibility.tabIndex\"\n [attr.aria-label]=\"'Toggle ' + leaf().alias\"\n [symbolId]=\"foldSymbol()\"\n (click)=\"toggleFolding($event)\"\n (keydown.space)=\"toggleFolding($event)\"\n (keydown.enter)=\"toggleFolding($event)\" />\n }\n }\n </div>\n\n <div\n class=\"details-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <ap-nav-selector-leaf-details [details]=\"leaf().details\" [leaf]=\"leaf()\"/>\n }\n </div>\n} @else {\n <div\n #menuTrigger=\"matMenuTrigger\"\n #minified\n class=\"nav-selector-leaf\"\n apTooltipPosition=\"right\"\n [matMenuTriggerFor]=\"menu\"\n [class.feature-locked]=\"leaf().displayFeatureLocked\"\n [class.selected]=\"leaf().selected\"\n [class.token-error]=\"leaf().displayTokenInvalid\"\n [class.disabled]=\"leaf().disabled\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"leaf()\"\n (menuOpened)=\"menuOpened()\"\n (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n (click)=\"onClick($event)\">\n @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"leaf().uid\"\n [checked]=\"leaf().selected\"\n [disabled]=\"!leaf().selectable\" />\n }\n\n <div class=\"avatar-container\">\n <ap-avatar\n size=\"24\"\n [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n [network]=\"$any(leaf().network)\"\n [showInitials]=\"initial()\" />\n\n <div class=\"status\">\n @if (leaf().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [notif]=\"true\"\n [background]=\"true\">\n {{ leaf().counter }}\n </ap-counter>\n }\n @if (leaf().displayTokenInvalid) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n }\n @if (leaf().displayFeatureLocked) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"feature-lock\" />\n }\n </div>\n </div>\n <mat-menu\n #menu=\"matMenu\"\n class=\"nav-selector-leaf-menu\"\n xPosition=\"after\"\n [hasBackdrop]=\"false\">\n <div\n #menuContainer\n [class.not-displayable]=\"!leaf().detailsDisplayable\"\n (mouseenter)=\"mouseEnteredMenu()\"\n (mouseleave)=\"mouseLeftMenu(menuTrigger, $event)\">\n <button mat-menu-item>\n <span class=\"caption-bold\">{{ leaf().alias }}</span>\n </button>\n @for (detail of leaf().details; track detail.uid) {\n <button\n mat-menu-item\n [class.selected]=\"detail.selected\">\n <ap-nav-selector-leaf-detail\n [embedded]=\"true\"\n [detail]=\"detail\" />\n </button>\n }\n </div>\n </mat-menu>\n </div>\n}\n", styles: [":host{display:flex;gap:2px;flex-shrink:0;align-self:stretch;flex-direction:column}:host .details-container{align-self:stretch}:host .nav-selector-leaf{position:relative;display:flex;padding:0 var(--ref-spacing-xxs);height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch}:host .caption{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1;flex:1 0 0;overflow:hidden;color:var(--ref-color-grey-100);text-overflow:ellipsis;font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-regular);line-height:var(--ref-font-line-height-xs)}:host ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host ap-symbol[symbol-id=feature-lock]{color:var(--ref-color-purple-100)}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host .folding-button,:host .actions-menu{display:flex;width:24px;height:24px;justify-content:center;align-items:center;flex-shrink:0}:host .folding-button:hover,:host .actions-menu:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .folding-button:active,:host .actions-menu:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-40)}:host .folding-button:focus,:host .actions-menu:focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20);box-shadow:0 0 0 1px #fff,0 0 0 3px #178dfe}:host .nav-selector-leaf:not(.disabled){cursor:pointer}:host .nav-selector-leaf:not(.disabled):hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .nav-selector-leaf:not(.disabled):active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled):focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10);box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .nav-selector-leaf:not(.disabled):focus-within{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled).selected{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled).selected:focus{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .nav-selector-leaf.feature-locked{border-radius:var(--ref-border-radius-sm)}:host .nav-selector-leaf.feature-locked:hover{background:var(--ref-color-purple-10)}:host .nav-selector-leaf.feature-locked:active{background:var(--ref-color-purple-20)}:host .nav-selector-leaf.feature-locked:focus{background:var(--ref-color-purple-10);box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-purple-100)}:host .nav-selector-leaf.feature-locked.selected{background:var(--ref-color-purple-20)}:host .nav-selector-leaf.feature-locked.selected:focus{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .nav-selector-leaf.disabled{opacity:.5}:host .status{position:absolute;right:-4px;top:-6px}:host .avatar-container{position:relative}:host.minified .nav-selector-leaf{gap:var(--ref-spacing-xxxs);justify-content:center}:host.minified ::ng-deep ap-checkbox .checkbox .checkbox-container{padding:0}::ng-deep .nav-selector-leaf-menu{position:absolute;left:55px;top:-20%;width:225px}::ng-deep .nav-selector-leaf-menu .not-displayable{display:none}::ng-deep .nav-selector-leaf-menu .caption-bold{color:var(--ref-color-grey-100);font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-xs)}::ng-deep .nav-selector-leaf-menu.mat-mdc-menu-panel:not(.pop-menu) .mat-mdc-menu-item.selected{background:var(--ref-color-electric-blue-20)}::ng-deep .nav-selector-leaf-menu.mat-mdc-menu-panel:not(.pop-menu) .mat-mdc-menu-item ap-symbol{padding-right:0}\n"] }]
|
|
239
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NavSelectorLeafPresenter }] });
|
|
240
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-leaf.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf/nav-selector-leaf.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf/nav-selector-leaf.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AvatarComponent } from '@agorapulse/ui-components/avatar';\nimport { CheckboxComponent } from '@agorapulse/ui-components/checkbox';\nimport { CounterComponent } from '@agorapulse/ui-components/counter';\nimport { TooltipDirective } from '@agorapulse/ui-components/tooltip';\nimport { apChevronDown, apChevronUp, apErrorFill, apFeatureLock, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { apMore } from '@agorapulse/ui-symbol/icons';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, ElementRef, input, signal, viewChild } from '@angular/core';\nimport { MatMenu, MatMenuItem, MatMenuTrigger } from '@angular/material/menu';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorLeaf } from '../nav-selector';\nimport { NavSelectorLeafDetailComponent } from '../nav-selector-leaf-detail/nav-selector-leaf-detail.component';\nimport { NavSelectorLeafDetailsComponent } from '../nav-selector-leaf-details/nav-selector-leaf-details.component';\nimport { NavSelectorLeafPresenter } from './nav-selector-leaf.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-leaf',\n    templateUrl: './nav-selector-leaf.component.html',\n    styleUrls: ['./nav-selector-leaf.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [\n        AvatarComponent,\n        CounterComponent,\n        SymbolComponent,\n        NavSelectorLeafDetailsComponent,\n        CheckboxComponent,\n        TooltipDirective,\n        MatMenu,\n        MatMenuTrigger,\n        MatMenuItem,\n        NavSelectorLeafDetailComponent,\n        NavSelectorLeafDetailComponent,\n        NgTemplateOutlet,\n        TreeNodeAccessibilityDirective,\n    ],\n    providers: [withSymbols(apErrorFill, apFeatureLock, apChevronDown, apChevronUp, apMore), NavSelectorLeafPresenter],\n    host: {\n        '[class.minified]': '!navSelectorLeafPresenter.expanded()',\n        role: 'treeitem',\n        '(mouseenter)': 'mouseEntered()',\n        '(mouseleave)': 'mouseLeft($event)',\n        '(keydown.arrowLeft)': 'fold($event)',\n        '(keydown.arrowRight)': 'unfold($event)',\n    },\n    animations: [\n        /**\n         * Overflow hidden is put only during the animation and on the collapsed state because if it is put on the expanded state then children’s border will be cut (hover / focus)\n         */\n        trigger('accordion', [\n            state(\n                'collapsed',\n                style({\n                    maxHeight: 0,\n                    overflow: 'hidden',\n                })\n            ),\n            state(\n                'expanded',\n                style({\n                    maxHeight: 'initial',\n                })\n            ),\n            transition('collapsed => expanded', [\n                animate('250ms cubic-bezier(.4, 0, .3, 1)', style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' })),\n            ]),\n            transition('expanded => collapsed', [\n                animate(\n                    '250ms cubic-bezier(.4, 0, .3, 1)',\n                    keyframes([style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' }), style({ maxHeight: 0 })])\n                ),\n            ]),\n        ]),\n    ],\n})\nexport class NavSelectorLeafComponent {\n    leaf = input.required<InternalNavSelectorLeaf>();\n\n    initial = computed(() => this.leaf().alias[0].toUpperCase());\n    foldSymbol = computed(() => (this.leaf().folded ? 'chevron-down' : 'chevron-up'));\n\n    hovering = signal(false);\n    hoveringMenu = signal(false);\n    onlyButtonDisplayed = computed(\n        () =>\n            this.navSelectorLeafPresenter.isMultipleModeEnabled() &&\n            (this.hovering() || this.leaf().accessibility.tabIndex === 0) &&\n            this.leaf().selectable\n    );\n\n    aliasEl = viewChild<ElementRef>('alias');\n    aliasBoundedClientRect = signal<{\n        offsetWidth: number;\n        offsetHeight: number;\n        scrollWidth: number;\n        scrollHeight: number;\n    }>({\n        offsetWidth: 0,\n        offsetHeight: 0,\n        scrollWidth: 0,\n        scrollHeight: 0,\n    });\n\n    tooltipContent = computed(() => {\n        const content = [];\n\n        const el = this.aliasBoundedClientRect();\n        if (!this.navSelectorLeafPresenter.expanded() || el.offsetWidth < el.scrollWidth || el.offsetHeight < el.scrollHeight) {\n            content.push(this.leaf().alias);\n        }\n\n        const disableReason = this.leaf().disableReason;\n        if (disableReason) {\n            content.push(disableReason);\n        }\n\n        if (this.leaf().displayFeatureLocked) {\n            content.push(this.navSelectorLeafPresenter.texts().featureLocked);\n        }\n\n        if (this.leaf().displayTokenInvalid) {\n            content.push(this.navSelectorLeafPresenter.texts().tokenInvalid);\n        }\n\n        return content.join('<br>');\n    });\n    tooltipDisabled = computed(() => !this.tooltipContent().length || this.leaf().detailsDisplayable);\n\n    minifiedEl = viewChild<ElementRef>('minified');\n    menuEl = viewChild<ElementRef>('menuContainer');\n\n    menuTriggerEl = viewChild<MatMenuTrigger>('menuTrigger');\n    actionMenuTriggerEl = viewChild<MatMenuTrigger>('actionMenuTrigger');\n\n    foldedWithDelay = signal(false);\n\n    network = computed(() => (this.leaf().network ? this.leaf().network : undefined));\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorLeafPresenter: NavSelectorLeafPresenter\n    ) {\n        afterNextRender(() => {\n            this.maxHeight.set(`${this.el.nativeElement.scrollHeight}px`);\n\n            const el = this.aliasEl()?.nativeElement;\n            if (el) {\n                this.aliasBoundedClientRect.set({\n                    offsetWidth: el.offsetWidth,\n                    offsetHeight: el.offsetHeight,\n                    scrollWidth: el.scrollWidth,\n                    scrollHeight: el.scrollHeight,\n                });\n            }\n        });\n\n        effect(\n            () => {\n                if (this.leaf().folded) {\n                    setTimeout(() => this.foldedWithDelay.set(true), 150);\n                } else {\n                    this.foldedWithDelay.set(false);\n                }\n            },\n            { allowSignalWrites: true }\n        );\n    }\n\n    animationState = computed(() => (this.leaf().folded ? 'collapsed' : 'expanded'));\n\n    maxHeight = signal('0px');\n\n    onClick($event: Event) {\n        $event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.onLeafClicked(this.leaf());\n    }\n\n    toggleFolding(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.onLeafToggleFolding(this.leaf());\n    }\n\n    mouseEntered() {\n        this.hovering.set(true);\n        const menuTrigger = this.menuTriggerEl();\n        if (menuTrigger && this.leaf().detailsDisplayable) {\n            menuTrigger.openMenu();\n        }\n    }\n\n    mouseLeft($event: MouseEvent) {\n        this.hovering.set(false);\n        const menuTrigger = this.menuTriggerEl();\n        if (menuTrigger) {\n            setTimeout(() => {\n                this.tryCloseMenu(menuTrigger, $event);\n            }, 100);\n        }\n    }\n\n    mouseEnteredMenu() {\n        this.hoveringMenu.set(true);\n    }\n\n    mouseLeftMenu(menuTrigger: MatMenuTrigger, $event: MouseEvent) {\n        this.hoveringMenu.set(false);\n        this.tryCloseMenu(menuTrigger, $event);\n    }\n\n    menuOpened() {\n        if (!this.leaf().detailsDisplayable) {\n            this.menuTriggerEl()?.closeMenu();\n        }\n    }\n\n    onActionButtonClick($event: Event) {\n        $event.stopImmediatePropagation();\n    }\n\n    onActionButtonKeyDownSpaceOrEnter($event: Event) {\n        $event.stopImmediatePropagation();\n        this.actionMenuTriggerEl()?.openMenu();\n    }\n\n    selectOnly(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.selectOnlyLeaf(this.leaf());\n    }\n\n    onCheckboxToggle() {\n        this.navSelectorLeafPresenter.onLeafClicked(this.leaf());\n    }\n\n    onSpaceOrEnterPressed($event: Event) {\n        $event.stopImmediatePropagation();\n        if (document.activeElement === this.el.nativeElement.querySelector('.nav-selector-leaf')) {\n            if (this.leaf().foldable) {\n                this.toggleFolding($event);\n            } else {\n                this.navSelectorLeafPresenter.onLeafClicked(this.leaf());\n            }\n        }\n    }\n\n    fold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.fold(this.leaf());\n    }\n\n    unfold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.unfold(this.leaf());\n    }\n\n    private tryCloseMenu(menuTrigger: MatMenuTrigger, $event: MouseEvent) {\n        if (!this.hoveringMenu()) {\n            const minifiedEl = this.minifiedEl() as ElementRef;\n            const minifiedBoundedClientRect = minifiedEl.nativeElement.getBoundingClientRect();\n            const mouseHoveringLeaf = this.mouseIsHovering($event, minifiedBoundedClientRect);\n\n            const menuEl = this.menuEl() as ElementRef;\n            const menuBoundedClientRect = menuEl.nativeElement.getBoundingClientRect();\n            const mouseHoveringMenu = this.mouseIsHovering($event, menuBoundedClientRect);\n\n            if (!mouseHoveringLeaf && !mouseHoveringMenu) {\n                menuTrigger.closeMenu();\n            }\n        }\n    }\n\n    private mouseIsHovering($event: MouseEvent, boundingClientRect: { top: number; right: number; bottom: number; left: number }): boolean {\n        return (\n            boundingClientRect.left <= $event.clientX &&\n            $event.clientX <= boundingClientRect.right &&\n            boundingClientRect.top <= $event.clientY &&\n            $event.clientY <= boundingClientRect.bottom\n        );\n    }\n}\n","@if (navSelectorLeafPresenter.expandedAfterDelay()) {\n    <div\n        class=\"nav-selector-leaf\"\n        apTooltipPosition=\"right\"\n        role=\"treeitem\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [class.feature-locked]=\"leaf().displayFeatureLocked\"\n        [class.selected]=\"leaf().selected\"\n        [class.token-error]=\"leaf().displayTokenInvalid\"\n        [class.disabled]=\"leaf().disabled\"\n        [apTreeNodeAccessibility]=\"leaf()\"\n        (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n        (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n        (click)=\"onClick($event)\">\n        @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"leaf().uid\"\n                [checked]=\"leaf().selected\"\n                [disabled]=\"!leaf().selectable\"\n                (change)=\"onCheckboxToggle()\" />\n        }\n        <ap-avatar\n            size=\"24\"\n            [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n            [network]=\"$any(leaf().network)\"\n            [showInitials]=\"initial()\" />\n\n        <span\n            #alias\n            class=\"caption\">\n            {{ leaf().alias }}\n        </span>\n\n        @if (onlyButtonDisplayed()) {\n            <a\n                class=\"standalone\"\n                role=\"button\"\n                [attr.aria-label]=\"'Select only ' + leaf().alias\"\n                [attr.tabindex]=\"leaf().accessibility.tabIndex\"\n                (keydown.space)=\"selectOnly($event)\"\n                (keydown.enter)=\"selectOnly($event)\"\n                (click)=\"selectOnly($event)\">\n                {{ navSelectorLeafPresenter.texts().only }}\n            </a>\n        } @else {\n            @if (leaf().displayCounter) {\n                <ap-counter\n                    color=\"orange\"\n                    size=\"normal\"\n                    [background]=\"false\">\n                    {{ leaf().counter }}\n                </ap-counter>\n            }\n            @if (leaf().displayTokenInvalid) {\n                <ap-symbol\n                    size=\"sm\"\n                    symbolId=\"error_fill\" />\n            }\n            @if (leaf().displayFeatureLocked) {\n                <ap-symbol\n                    size=\"sm\"\n                    symbolId=\"feature-lock\" />\n            }\n\n            @let actionProjection = navSelectorLeafPresenter.leafActionProjection();\n            @if (actionProjection?.length) {\n                <ap-symbol\n                    #actionMenuTrigger=\"matMenuTrigger\"\n                    class=\"actions-menu\"\n                    size=\"sm\"\n                    symbolId=\"more\"\n                    [tabindex]=\"leaf().accessibility.tabIndex\"\n                    [attr.aria-label]=\"'Action menu ' + leaf().alias\"\n                    [matMenuTriggerFor]=\"actionMenu\"\n                    (click)=\"onActionButtonClick($event)\"\n                    (keydown.space)=\"onActionButtonKeyDownSpaceOrEnter($event)\"\n                    (keydown.enter)=\"onActionButtonKeyDownSpaceOrEnter($event)\" />\n\n                <mat-menu #actionMenu=\"matMenu\">\n                    @for (action of actionProjection; track action) {\n                        <button mat-menu-item>\n                            <ng-container\n                                [ngTemplateOutlet]=\"action\"\n                                [ngTemplateOutletContext]=\"{\n                                    uid: leaf().uid\n                                }\" />\n                        </button>\n                    }\n                </mat-menu>\n            }\n\n            @if (leaf().foldable) {\n                <ap-symbol\n                    class=\"folding-button\"\n                    size=\"sm\"\n                    role=\"button\"\n                    [tabindex]=\"leaf().accessibility.tabIndex\"\n                    [attr.aria-label]=\"'Toggle ' + leaf().alias\"\n                    [symbolId]=\"foldSymbol()\"\n                    (click)=\"toggleFolding($event)\"\n                    (keydown.space)=\"toggleFolding($event)\"\n                    (keydown.enter)=\"toggleFolding($event)\" />\n            }\n        }\n    </div>\n\n    <div\n        class=\"details-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <ap-nav-selector-leaf-details [details]=\"leaf().details\"  [leaf]=\"leaf()\"/>\n        }\n    </div>\n} @else {\n    <div\n        #menuTrigger=\"matMenuTrigger\"\n        #minified\n        class=\"nav-selector-leaf\"\n        apTooltipPosition=\"right\"\n        [matMenuTriggerFor]=\"menu\"\n        [class.feature-locked]=\"leaf().displayFeatureLocked\"\n        [class.selected]=\"leaf().selected\"\n        [class.token-error]=\"leaf().displayTokenInvalid\"\n        [class.disabled]=\"leaf().disabled\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [apTreeNodeAccessibility]=\"leaf()\"\n        (menuOpened)=\"menuOpened()\"\n        (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n        (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n        (click)=\"onClick($event)\">\n        @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"leaf().uid\"\n                [checked]=\"leaf().selected\"\n                [disabled]=\"!leaf().selectable\" />\n        }\n\n        <div class=\"avatar-container\">\n            <ap-avatar\n                size=\"24\"\n                [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n                [network]=\"$any(leaf().network)\"\n                [showInitials]=\"initial()\" />\n\n            <div class=\"status\">\n                @if (leaf().displayCounter) {\n                    <ap-counter\n                        color=\"orange\"\n                        size=\"normal\"\n                        [notif]=\"true\"\n                        [background]=\"true\">\n                        {{ leaf().counter }}\n                    </ap-counter>\n                }\n                @if (leaf().displayTokenInvalid) {\n                    <ap-symbol\n                        size=\"sm\"\n                        symbolId=\"error_fill\" />\n                }\n                @if (leaf().displayFeatureLocked) {\n                    <ap-symbol\n                        size=\"sm\"\n                        symbolId=\"feature-lock\" />\n                }\n            </div>\n        </div>\n        <mat-menu\n            #menu=\"matMenu\"\n            class=\"nav-selector-leaf-menu\"\n            xPosition=\"after\"\n            [hasBackdrop]=\"false\">\n            <div\n                #menuContainer\n                [class.not-displayable]=\"!leaf().detailsDisplayable\"\n                (mouseenter)=\"mouseEnteredMenu()\"\n                (mouseleave)=\"mouseLeftMenu(menuTrigger, $event)\">\n                <button mat-menu-item>\n                    <span class=\"caption-bold\">{{ leaf().alias }}</span>\n                </button>\n                @for (detail of leaf().details; track detail.uid) {\n                    <button\n                        mat-menu-item\n                        [class.selected]=\"detail.selected\">\n                        <ap-nav-selector-leaf-detail\n                            [embedded]=\"true\"\n                            [detail]=\"detail\" />\n                    </button>\n                }\n            </div>\n        </mat-menu>\n    </div>\n}\n"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { computed, Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../nav-selector.state";
|
|
4
|
+
export class NavSelectorLeafPresenter {
|
|
5
|
+
navSelectorState;
|
|
6
|
+
expanded = computed(() => this.navSelectorState.expanded());
|
|
7
|
+
texts = computed(() => this.navSelectorState.texts());
|
|
8
|
+
isMultipleModeEnabled = computed(() => this.navSelectorState.isMultipleModeEnabled());
|
|
9
|
+
leafActionProjection = computed(() => this.navSelectorState.leafActionProjection());
|
|
10
|
+
expandedAfterDelay = computed(() => this.navSelectorState.expandedAfterDelay());
|
|
11
|
+
constructor(navSelectorState) {
|
|
12
|
+
this.navSelectorState = navSelectorState;
|
|
13
|
+
}
|
|
14
|
+
onLeafClicked(leaf) {
|
|
15
|
+
this.navSelectorState.onLeafClicked(leaf);
|
|
16
|
+
}
|
|
17
|
+
onLeafToggleFolding(leaf) {
|
|
18
|
+
this.navSelectorState.onLeafToggleFolding(leaf);
|
|
19
|
+
}
|
|
20
|
+
selectOnlyLeaf(leaf) {
|
|
21
|
+
this.navSelectorState.selectOnlyLeaf(leaf);
|
|
22
|
+
}
|
|
23
|
+
fold(leaf) {
|
|
24
|
+
this.navSelectorState.fold(leaf);
|
|
25
|
+
}
|
|
26
|
+
unfold(leaf) {
|
|
27
|
+
this.navSelectorState.unfold(leaf);
|
|
28
|
+
}
|
|
29
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafPresenter, deps: [{ token: i1.NavSelectorState }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
30
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafPresenter });
|
|
31
|
+
}
|
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafPresenter, decorators: [{
|
|
33
|
+
type: Injectable
|
|
34
|
+
}], ctorParameters: () => [{ type: i1.NavSelectorState }] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXNlbGVjdG9yLWxlYWYucHJlc2VudGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL25hdi1zZWxlY3Rvci9zcmMvbmF2LXNlbGVjdG9yLWxlYWYvbmF2LXNlbGVjdG9yLWxlYWYucHJlc2VudGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFLckQsTUFBTSxPQUFPLHdCQUF3QjtJQU9iO0lBTnBCLFFBQVEsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7SUFDNUQsS0FBSyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUN0RCxxQkFBcUIsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLHFCQUFxQixFQUFFLENBQUMsQ0FBQztJQUN0RixvQkFBb0IsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLG9CQUFvQixFQUFFLENBQUMsQ0FBQztJQUNwRixrQkFBa0IsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixFQUFFLENBQUMsQ0FBQztJQUVoRixZQUFvQixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtJQUFHLENBQUM7SUFFMUQsYUFBYSxDQUFDLElBQTZCO1FBQ3ZDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVELG1CQUFtQixDQUFDLElBQTZCO1FBQzdDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsY0FBYyxDQUFDLElBQTZCO1FBQ3hDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELElBQUksQ0FBQyxJQUE2QjtRQUM5QixJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxNQUFNLENBQUMsSUFBNkI7UUFDaEMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2QyxDQUFDO3VHQTNCUSx3QkFBd0I7MkdBQXhCLHdCQUF3Qjs7MkZBQXhCLHdCQUF3QjtrQkFEcEMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvbXB1dGVkLCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJbnRlcm5hbE5hdlNlbGVjdG9yTGVhZiB9IGZyb20gJy4uL25hdi1zZWxlY3Rvcic7XG5pbXBvcnQgeyBOYXZTZWxlY3RvclN0YXRlIH0gZnJvbSAnLi4vbmF2LXNlbGVjdG9yLnN0YXRlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIE5hdlNlbGVjdG9yTGVhZlByZXNlbnRlciB7XG4gICAgZXhwYW5kZWQgPSBjb21wdXRlZCgoKSA9PiB0aGlzLm5hdlNlbGVjdG9yU3RhdGUuZXhwYW5kZWQoKSk7XG4gICAgdGV4dHMgPSBjb21wdXRlZCgoKSA9PiB0aGlzLm5hdlNlbGVjdG9yU3RhdGUudGV4dHMoKSk7XG4gICAgaXNNdWx0aXBsZU1vZGVFbmFibGVkID0gY29tcHV0ZWQoKCkgPT4gdGhpcy5uYXZTZWxlY3RvclN0YXRlLmlzTXVsdGlwbGVNb2RlRW5hYmxlZCgpKTtcbiAgICBsZWFmQWN0aW9uUHJvamVjdGlvbiA9IGNvbXB1dGVkKCgpID0+IHRoaXMubmF2U2VsZWN0b3JTdGF0ZS5sZWFmQWN0aW9uUHJvamVjdGlvbigpKTtcbiAgICBleHBhbmRlZEFmdGVyRGVsYXkgPSBjb21wdXRlZCgoKSA9PiB0aGlzLm5hdlNlbGVjdG9yU3RhdGUuZXhwYW5kZWRBZnRlckRlbGF5KCkpO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBuYXZTZWxlY3RvclN0YXRlOiBOYXZTZWxlY3RvclN0YXRlKSB7fVxuXG4gICAgb25MZWFmQ2xpY2tlZChsZWFmOiBJbnRlcm5hbE5hdlNlbGVjdG9yTGVhZikge1xuICAgICAgICB0aGlzLm5hdlNlbGVjdG9yU3RhdGUub25MZWFmQ2xpY2tlZChsZWFmKTtcbiAgICB9XG5cbiAgICBvbkxlYWZUb2dnbGVGb2xkaW5nKGxlYWY6IEludGVybmFsTmF2U2VsZWN0b3JMZWFmKSB7XG4gICAgICAgIHRoaXMubmF2U2VsZWN0b3JTdGF0ZS5vbkxlYWZUb2dnbGVGb2xkaW5nKGxlYWYpO1xuICAgIH1cblxuICAgIHNlbGVjdE9ubHlMZWFmKGxlYWY6IEludGVybmFsTmF2U2VsZWN0b3JMZWFmKSB7XG4gICAgICAgIHRoaXMubmF2U2VsZWN0b3JTdGF0ZS5zZWxlY3RPbmx5TGVhZihsZWFmKTtcbiAgICB9XG5cbiAgICBmb2xkKGxlYWY6IEludGVybmFsTmF2U2VsZWN0b3JMZWFmKSB7XG4gICAgICAgIHRoaXMubmF2U2VsZWN0b3JTdGF0ZS5mb2xkKGxlYWYpO1xuICAgIH1cblxuICAgIHVuZm9sZChsZWFmOiBJbnRlcm5hbE5hdlNlbGVjdG9yTGVhZikge1xuICAgICAgICB0aGlzLm5hdlNlbGVjdG9yU3RhdGUudW5mb2xkKGxlYWYpO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { CounterComponent } from '@agorapulse/ui-components/counter';
|
|
2
|
+
import { apErrorFill, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, input } from '@angular/core';
|
|
4
|
+
import { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';
|
|
5
|
+
import { NavSelectorLeafDetailPresenter } from './nav-selector-leaf-detail.presenter';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "./nav-selector-leaf-detail.presenter";
|
|
8
|
+
import * as i2 from "../directives/tree-node-accessibility.directive";
|
|
9
|
+
export class NavSelectorLeafDetailComponent {
|
|
10
|
+
navSelectorLeafDetailPresenter;
|
|
11
|
+
detail = input.required();
|
|
12
|
+
embedded = input(false);
|
|
13
|
+
constructor(navSelectorLeafDetailPresenter) {
|
|
14
|
+
this.navSelectorLeafDetailPresenter = navSelectorLeafDetailPresenter;
|
|
15
|
+
}
|
|
16
|
+
onClick($event) {
|
|
17
|
+
$event.stopImmediatePropagation();
|
|
18
|
+
this.navSelectorLeafDetailPresenter.onLeafDetailClicked(this.detail());
|
|
19
|
+
}
|
|
20
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafDetailComponent, deps: [{ token: i1.NavSelectorLeafDetailPresenter }], target: i0.ɵɵFactoryTarget.Component });
|
|
21
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorLeafDetailComponent, isStandalone: true, selector: "ap-nav-selector-leaf-detail", inputs: { detail: { classPropertyName: "detail", publicName: "detail", isSignal: true, isRequired: true, transformFunction: null }, embedded: { classPropertyName: "embedded", publicName: "embedded", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "click": "onClick($event)", "keydown.enter": "onClick($event)", "keydown.space": "onClick($event)" }, properties: { "class.selected": "detail().selected && !embedded()", "class.embedded": "embedded()" } }, providers: [withSymbols(apErrorFill), NavSelectorLeafDetailPresenter], hostDirectives: [{ directive: i2.TreeNodeAccessibilityDirective, inputs: ["apTreeNodeAccessibility", "detail"] }], ngImport: i0, template: "<span class=\"caption\">\n {{ detail().alias }}\n</span>\n\n@if (detail().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ detail().counter }}\n </ap-counter>\n}\n@if (detail().displayError) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n}\n", styles: [":host{display:flex;height:32px;padding:0 var(--ref-spacing-xxs);align-items:center;gap:var(--ref-spacing-xxs);align-self:stretch;flex-grow:1}:host.embedded{padding:0}:host ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host:not(.disabled):not(.embedded){cursor:pointer}:host:not(.disabled):not(.embedded):hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host:not(.disabled):not(.embedded):active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.disabled):not(.embedded):focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10);box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host:not(.disabled):not(.embedded).selected{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.disabled):not(.embedded).selected:focus{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .caption{flex-grow:1;overflow:hidden;color:var(--ref-color-grey-100);text-overflow:ellipsis;white-space:nowrap;font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-regular);line-height:var(--ref-font-line-height-xs)}\n"], dependencies: [{ kind: "component", type: CounterComponent, selector: "ap-counter", inputs: ["color", "size", "background", "notif"] }, { kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
22
|
+
}
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafDetailComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{ selector: 'ap-nav-selector-leaf-detail', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [CounterComponent, SymbolComponent], providers: [withSymbols(apErrorFill), NavSelectorLeafDetailPresenter], host: {
|
|
26
|
+
'(click)': 'onClick($event)',
|
|
27
|
+
'[class.selected]': 'detail().selected && !embedded()',
|
|
28
|
+
'[class.embedded]': 'embedded()',
|
|
29
|
+
'(keydown.enter)': 'onClick($event)',
|
|
30
|
+
'(keydown.space)': 'onClick($event)',
|
|
31
|
+
}, hostDirectives: [
|
|
32
|
+
{
|
|
33
|
+
directive: TreeNodeAccessibilityDirective,
|
|
34
|
+
// Alias the input of the directive to detail the input detail will be used in the directive and in the component as well
|
|
35
|
+
inputs: ['apTreeNodeAccessibility: detail'],
|
|
36
|
+
},
|
|
37
|
+
], template: "<span class=\"caption\">\n {{ detail().alias }}\n</span>\n\n@if (detail().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ detail().counter }}\n </ap-counter>\n}\n@if (detail().displayError) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n}\n", styles: [":host{display:flex;height:32px;padding:0 var(--ref-spacing-xxs);align-items:center;gap:var(--ref-spacing-xxs);align-self:stretch;flex-grow:1}:host.embedded{padding:0}:host ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host:not(.disabled):not(.embedded){cursor:pointer}:host:not(.disabled):not(.embedded):hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host:not(.disabled):not(.embedded):active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.disabled):not(.embedded):focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10);box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host:not(.disabled):not(.embedded).selected{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.disabled):not(.embedded).selected:focus{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .caption{flex-grow:1;overflow:hidden;color:var(--ref-color-grey-100);text-overflow:ellipsis;white-space:nowrap;font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-regular);line-height:var(--ref-font-line-height-xs)}\n"] }]
|
|
38
|
+
}], ctorParameters: () => [{ type: i1.NavSelectorLeafDetailPresenter }] });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXNlbGVjdG9yLWxlYWYtZGV0YWlsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9uYXYtc2VsZWN0b3Ivc3JjL25hdi1zZWxlY3Rvci1sZWFmLWRldGFpbC9uYXYtc2VsZWN0b3ItbGVhZi1kZXRhaWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL25hdi1zZWxlY3Rvci9zcmMvbmF2LXNlbGVjdG9yLWxlYWYtZGV0YWlsL25hdi1zZWxlY3Rvci1sZWFmLWRldGFpbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsV0FBVyxFQUFFLGVBQWUsRUFBRSxXQUFXLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNsRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUVqRyxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7OztBQXlCdEYsTUFBTSxPQUFPLDhCQUE4QjtJQUtwQjtJQUpuQixNQUFNLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBa0MsQ0FBQztJQUUxRCxRQUFRLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRXhCLFlBQW1CLDhCQUE4RDtRQUE5RCxtQ0FBOEIsR0FBOUIsOEJBQThCLENBQWdDO0lBQUcsQ0FBQztJQUVyRixPQUFPLENBQUMsTUFBYTtRQUNqQixNQUFNLENBQUMsd0JBQXdCLEVBQUUsQ0FBQztRQUNsQyxJQUFJLENBQUMsOEJBQThCLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDM0UsQ0FBQzt1R0FWUSw4QkFBOEI7MkZBQTlCLDhCQUE4QixvakJBaEI1QixDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsRUFBRSw4QkFBOEIsQ0FBQyw2SUNkekUsd1dBaUJBLHMyQ0RKYyxnQkFBZ0IseUdBQUUsZUFBZTs7MkZBaUJsQyw4QkFBOEI7a0JBdkIxQyxTQUFTOytCQUNJLDZCQUE2QixjQUczQixJQUFJLG1CQUNDLHVCQUF1QixDQUFDLE1BQU0sV0FDdEMsQ0FBQyxnQkFBZ0IsRUFBRSxlQUFlLENBQUMsYUFDakMsQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDLEVBQUUsOEJBQThCLENBQUMsUUFDL0Q7d0JBQ0YsU0FBUyxFQUFFLGlCQUFpQjt3QkFDNUIsa0JBQWtCLEVBQUUsa0NBQWtDO3dCQUN0RCxrQkFBa0IsRUFBRSxZQUFZO3dCQUNoQyxpQkFBaUIsRUFBRSxpQkFBaUI7d0JBQ3BDLGlCQUFpQixFQUFFLGlCQUFpQjtxQkFDdkMsa0JBQ2U7d0JBQ1o7NEJBQ0ksU0FBUyxFQUFFLDhCQUE4Qjs0QkFDekMseUhBQXlIOzRCQUN6SCxNQUFNLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQzt5QkFDOUM7cUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb3VudGVyQ29tcG9uZW50IH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9jb3VudGVyJztcbmltcG9ydCB7IGFwRXJyb3JGaWxsLCBTeW1ib2xDb21wb25lbnQsIHdpdGhTeW1ib2xzIH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktc3ltYm9sJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUcmVlTm9kZUFjY2Vzc2liaWxpdHlEaXJlY3RpdmUgfSBmcm9tICcuLi9kaXJlY3RpdmVzL3RyZWUtbm9kZS1hY2Nlc3NpYmlsaXR5LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBJbnRlcm5hbE5hdlNlbGVjdG9yTGVhZkRldGFpbHMgfSBmcm9tICcuLi9uYXYtc2VsZWN0b3InO1xuaW1wb3J0IHsgTmF2U2VsZWN0b3JMZWFmRGV0YWlsUHJlc2VudGVyIH0gZnJvbSAnLi9uYXYtc2VsZWN0b3ItbGVhZi1kZXRhaWwucHJlc2VudGVyJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdhcC1uYXYtc2VsZWN0b3ItbGVhZi1kZXRhaWwnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9uYXYtc2VsZWN0b3ItbGVhZi1kZXRhaWwuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL25hdi1zZWxlY3Rvci1sZWFmLWRldGFpbC5jb21wb25lbnQuc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaW1wb3J0czogW0NvdW50ZXJDb21wb25lbnQsIFN5bWJvbENvbXBvbmVudF0sXG4gICAgcHJvdmlkZXJzOiBbd2l0aFN5bWJvbHMoYXBFcnJvckZpbGwpLCBOYXZTZWxlY3RvckxlYWZEZXRhaWxQcmVzZW50ZXJdLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJyhjbGljayknOiAnb25DbGljaygkZXZlbnQpJyxcbiAgICAgICAgJ1tjbGFzcy5zZWxlY3RlZF0nOiAnZGV0YWlsKCkuc2VsZWN0ZWQgJiYgIWVtYmVkZGVkKCknLFxuICAgICAgICAnW2NsYXNzLmVtYmVkZGVkXSc6ICdlbWJlZGRlZCgpJyxcbiAgICAgICAgJyhrZXlkb3duLmVudGVyKSc6ICdvbkNsaWNrKCRldmVudCknLFxuICAgICAgICAnKGtleWRvd24uc3BhY2UpJzogJ29uQ2xpY2soJGV2ZW50KScsXG4gICAgfSxcbiAgICBob3N0RGlyZWN0aXZlczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBkaXJlY3RpdmU6IFRyZWVOb2RlQWNjZXNzaWJpbGl0eURpcmVjdGl2ZSxcbiAgICAgICAgICAgIC8vIEFsaWFzIHRoZSBpbnB1dCBvZiB0aGUgZGlyZWN0aXZlIHRvIGRldGFpbCB0aGUgaW5wdXQgZGV0YWlsIHdpbGwgYmUgdXNlZCBpbiB0aGUgZGlyZWN0aXZlIGFuZCBpbiB0aGUgY29tcG9uZW50IGFzIHdlbGxcbiAgICAgICAgICAgIGlucHV0czogWydhcFRyZWVOb2RlQWNjZXNzaWJpbGl0eTogZGV0YWlsJ10sXG4gICAgICAgIH0sXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTmF2U2VsZWN0b3JMZWFmRGV0YWlsQ29tcG9uZW50IHtcbiAgICBkZXRhaWwgPSBpbnB1dC5yZXF1aXJlZDxJbnRlcm5hbE5hdlNlbGVjdG9yTGVhZkRldGFpbHM+KCk7XG5cbiAgICBlbWJlZGRlZCA9IGlucHV0KGZhbHNlKTtcblxuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBuYXZTZWxlY3RvckxlYWZEZXRhaWxQcmVzZW50ZXI6IE5hdlNlbGVjdG9yTGVhZkRldGFpbFByZXNlbnRlcikge31cblxuICAgIG9uQ2xpY2soJGV2ZW50OiBFdmVudCkge1xuICAgICAgICAkZXZlbnQuc3RvcEltbWVkaWF0ZVByb3BhZ2F0aW9uKCk7XG4gICAgICAgIHRoaXMubmF2U2VsZWN0b3JMZWFmRGV0YWlsUHJlc2VudGVyLm9uTGVhZkRldGFpbENsaWNrZWQodGhpcy5kZXRhaWwoKSk7XG4gICAgfVxufVxuIiwiPHNwYW4gY2xhc3M9XCJjYXB0aW9uXCI+XG4gICAge3sgZGV0YWlsKCkuYWxpYXMgfX1cbjwvc3Bhbj5cblxuQGlmIChkZXRhaWwoKS5kaXNwbGF5Q291bnRlcikge1xuICAgIDxhcC1jb3VudGVyXG4gICAgICAgIGNvbG9yPVwib3JhbmdlXCJcbiAgICAgICAgc2l6ZT1cIm5vcm1hbFwiXG4gICAgICAgIFtiYWNrZ3JvdW5kXT1cImZhbHNlXCI+XG4gICAgICAgIHt7IGRldGFpbCgpLmNvdW50ZXIgfX1cbiAgICA8L2FwLWNvdW50ZXI+XG59XG5AaWYgKGRldGFpbCgpLmRpc3BsYXlFcnJvcikge1xuICAgIDxhcC1zeW1ib2xcbiAgICAgICAgc2l6ZT1cInNtXCJcbiAgICAgICAgc3ltYm9sSWQ9XCJlcnJvcl9maWxsXCIgLz5cbn1cbiJdfQ==
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../nav-selector.state";
|
|
4
|
+
export class NavSelectorLeafDetailPresenter {
|
|
5
|
+
navSelectorState;
|
|
6
|
+
constructor(navSelectorState) {
|
|
7
|
+
this.navSelectorState = navSelectorState;
|
|
8
|
+
}
|
|
9
|
+
onLeafDetailClicked(detail) {
|
|
10
|
+
this.navSelectorState.onLeafDetailClicked(detail);
|
|
11
|
+
}
|
|
12
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafDetailPresenter, deps: [{ token: i1.NavSelectorState }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
13
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafDetailPresenter });
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafDetailPresenter, decorators: [{
|
|
16
|
+
type: Injectable
|
|
17
|
+
}], ctorParameters: () => [{ type: i1.NavSelectorState }] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXNlbGVjdG9yLWxlYWYtZGV0YWlsLnByZXNlbnRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9uYXYtc2VsZWN0b3Ivc3JjL25hdi1zZWxlY3Rvci1sZWFmLWRldGFpbC9uYXYtc2VsZWN0b3ItbGVhZi1kZXRhaWwucHJlc2VudGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQUszQyxNQUFNLE9BQU8sOEJBQThCO0lBQ25CO0lBQXBCLFlBQW9CLGdCQUFrQztRQUFsQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO0lBQUcsQ0FBQztJQUUxRCxtQkFBbUIsQ0FBQyxNQUFzQztRQUN0RCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsbUJBQW1CLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDdEQsQ0FBQzt1R0FMUSw4QkFBOEI7MkdBQTlCLDhCQUE4Qjs7MkZBQTlCLDhCQUE4QjtrQkFEMUMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEludGVybmFsTmF2U2VsZWN0b3JMZWFmRGV0YWlscyB9IGZyb20gJy4uL25hdi1zZWxlY3Rvcic7XG5pbXBvcnQgeyBOYXZTZWxlY3RvclN0YXRlIH0gZnJvbSAnLi4vbmF2LXNlbGVjdG9yLnN0YXRlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIE5hdlNlbGVjdG9yTGVhZkRldGFpbFByZXNlbnRlciB7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBuYXZTZWxlY3RvclN0YXRlOiBOYXZTZWxlY3RvclN0YXRlKSB7fVxuXG4gICAgb25MZWFmRGV0YWlsQ2xpY2tlZChkZXRhaWw6IEludGVybmFsTmF2U2VsZWN0b3JMZWFmRGV0YWlscykge1xuICAgICAgICB0aGlzLm5hdlNlbGVjdG9yU3RhdGUub25MZWFmRGV0YWlsQ2xpY2tlZChkZXRhaWwpO1xuICAgIH1cbn1cbiJdfQ==
|