@agorapulse/ui-components 18.0.13 → 18.0.15
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.15.tgz +0 -0
- package/avatar/avatar.component.d.ts +1 -1
- package/checkbox/checkbox.component.d.ts +1 -1
- package/esm2022/add-comment/add-comment.component.mjs +3 -3
- package/esm2022/checkbox/checkbox.component.mjs +5 -4
- package/esm2022/datepicker/datepicker.component.mjs +3 -3
- package/esm2022/labels/label-list.component.mjs +3 -3
- package/esm2022/labels-selector/labels-selector.component.mjs +3 -3
- package/esm2022/media-display-overlay/media-display-overlay-dialog.component.mjs +3 -3
- package/esm2022/modal/modal.component.mjs +3 -3
- package/esm2022/nav-selector/directives/nav-selector-popover-trigger.directive.mjs +71 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +15 -12
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +17 -14
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +38 -94
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.mjs +2 -2
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.mjs +6 -6
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs +12 -9
- package/esm2022/nav-selector/nav-selector-popover/nav-selector-popover-item.component.mjs +14 -0
- package/esm2022/nav-selector/nav-selector-popover/nav-selector-popover.component.mjs +127 -0
- package/esm2022/nav-selector/nav-selector.component.mjs +45 -23
- package/esm2022/nav-selector/nav-selector.mjs +1 -1
- package/esm2022/nav-selector/nav-selector.state.mjs +35 -11
- package/esm2022/nav-selector/utils/leaf.utils.mjs +12 -3
- package/esm2022/nav-selector/utils/nav-selector.accessibility.mjs +22 -14
- package/esm2022/nav-selector/utils/nav-selector.builder.mjs +4 -2
- package/esm2022/nav-selector/utils/nav-selector.filter.mjs +49 -11
- package/esm2022/nav-selector/utils/nav-selector.folding.mjs +26 -23
- package/esm2022/nav-selector/utils/nav-selector.merger.mjs +76 -0
- package/esm2022/nav-selector/utils/nav-selector.minifying.mjs +14 -9
- package/esm2022/nav-selector/utils/nav-selector.multi-select.mjs +2 -2
- package/esm2022/nav-selector/utils/nav-selector.single-select.mjs +46 -23
- package/esm2022/neo-datepicker/neo-datepicker.component.mjs +3 -3
- package/esm2022/notification/notification.component.mjs +3 -3
- package/esm2022/paginator/paginator-button/paginator-button.component.mjs +2 -2
- package/esm2022/password-input/password-input.component.mjs +3 -3
- package/esm2022/popmenu/popmenu.component.mjs +3 -3
- package/esm2022/slide-toggle/slide-toggle.component.mjs +3 -3
- package/esm2022/snackbars-thread/component/snackbars-thread.component.mjs +3 -3
- package/esm2022/stepper/stepper.component.mjs +3 -3
- package/fesm2022/agorapulse-ui-components-add-comment.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-add-comment.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-checkbox.mjs +4 -3
- package/fesm2022/agorapulse-ui-components-checkbox.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-datepicker.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-datepicker.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-labels-selector.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-labels-selector.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-labels.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-labels.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-media-display-overlay.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-media-display-overlay.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-modal.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-modal.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs +599 -238
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-neo-datepicker.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-neo-datepicker.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-notification.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-notification.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-paginator.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-paginator.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-password-input.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-password-input.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-popmenu.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-popmenu.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-slide-toggle.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-slide-toggle.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-stepper.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-stepper.mjs.map +1 -1
- package/nav-selector/directives/nav-selector-popover-trigger.directive.d.ts +25 -0
- package/nav-selector/nav-selector-group/nav-selector-group.component.d.ts +1 -1
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.component.d.ts +5 -20
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.d.ts +1 -1
- package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.d.ts +1 -1
- package/nav-selector/nav-selector-popover/nav-selector-popover-item.component.d.ts +6 -0
- package/nav-selector/nav-selector-popover/nav-selector-popover.component.d.ts +39 -0
- package/nav-selector/nav-selector.component.d.ts +6 -4
- package/nav-selector/nav-selector.d.ts +6 -0
- package/nav-selector/nav-selector.state.d.ts +3 -2
- package/nav-selector/utils/leaf.utils.d.ts +15 -2
- package/nav-selector/utils/nav-selector.accessibility.d.ts +1 -1
- package/nav-selector/utils/nav-selector.filter.d.ts +3 -1
- package/nav-selector/utils/nav-selector.folding.d.ts +6 -3
- package/nav-selector/utils/nav-selector.merger.d.ts +23 -0
- package/nav-selector/utils/nav-selector.minifying.d.ts +4 -2
- package/nav-selector/utils/nav-selector.single-select.d.ts +2 -0
- package/package.json +1 -1
- package/agorapulse-ui-components-18.0.13.tgz +0 -0
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { Directive, effect, input, untracked } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class NavSelectorPopoverTriggerDirective {
|
|
4
|
+
el;
|
|
5
|
+
renderer;
|
|
6
|
+
apNavSelectorPopoverTrigger = input.required();
|
|
7
|
+
apNavSelectorPopoverTriggerMode = input({
|
|
8
|
+
click: true,
|
|
9
|
+
keyboard: [],
|
|
10
|
+
hover: false,
|
|
11
|
+
focus: false,
|
|
12
|
+
});
|
|
13
|
+
apNavSelectorPopoverDisabled = input(false);
|
|
14
|
+
ACTIVE_CLASS = 'nav-selector-popover-trigger--active';
|
|
15
|
+
constructor(el, renderer) {
|
|
16
|
+
this.el = el;
|
|
17
|
+
this.renderer = renderer;
|
|
18
|
+
effect(() => {
|
|
19
|
+
const displayed = this.apNavSelectorPopoverTrigger().navSelectorPopoverDisplayed();
|
|
20
|
+
untracked(() => {
|
|
21
|
+
if (displayed) {
|
|
22
|
+
this.renderer.addClass(this.el.nativeElement, this.ACTIVE_CLASS);
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
this.renderer.removeClass(this.el.nativeElement, this.ACTIVE_CLASS);
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
onClick(event) {
|
|
31
|
+
if (!this.apNavSelectorPopoverTriggerMode().click || this.apNavSelectorPopoverDisabled()) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
event.stopImmediatePropagation();
|
|
35
|
+
this.toggleDisplay();
|
|
36
|
+
}
|
|
37
|
+
onKeydown(event) {
|
|
38
|
+
if (this.apNavSelectorPopoverTriggerMode().keyboard?.includes(event.code) && !this.apNavSelectorPopoverDisabled()) {
|
|
39
|
+
this.toggleDisplay();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
onMouseEnter() {
|
|
43
|
+
if (this.apNavSelectorPopoverTriggerMode().hover && !this.apNavSelectorPopoverDisabled()) {
|
|
44
|
+
this.apNavSelectorPopoverTrigger().display(this.el);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
onMouseLeave() {
|
|
48
|
+
if (this.apNavSelectorPopoverTriggerMode().hover) {
|
|
49
|
+
this.apNavSelectorPopoverTrigger().hide();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
toggleDisplay() {
|
|
53
|
+
this.apNavSelectorPopoverTrigger().toggle(this.el);
|
|
54
|
+
}
|
|
55
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorPopoverTriggerDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
56
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.9", type: NavSelectorPopoverTriggerDirective, isStandalone: true, selector: "[apNavSelectorPopoverTrigger]", inputs: { apNavSelectorPopoverTrigger: { classPropertyName: "apNavSelectorPopoverTrigger", publicName: "apNavSelectorPopoverTrigger", isSignal: true, isRequired: true, transformFunction: null }, apNavSelectorPopoverTriggerMode: { classPropertyName: "apNavSelectorPopoverTriggerMode", publicName: "apNavSelectorPopoverTriggerMode", isSignal: true, isRequired: false, transformFunction: null }, apNavSelectorPopoverDisabled: { classPropertyName: "apNavSelectorPopoverDisabled", publicName: "apNavSelectorPopoverDisabled", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "click": "onClick($event)", "keydown": "onKeydown($event)", "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" } }, ngImport: i0 });
|
|
57
|
+
}
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorPopoverTriggerDirective, decorators: [{
|
|
59
|
+
type: Directive,
|
|
60
|
+
args: [{
|
|
61
|
+
selector: '[apNavSelectorPopoverTrigger]',
|
|
62
|
+
standalone: true,
|
|
63
|
+
host: {
|
|
64
|
+
'(click)': 'onClick($event)',
|
|
65
|
+
'(keydown)': 'onKeydown($event)',
|
|
66
|
+
'(mouseenter)': 'onMouseEnter()',
|
|
67
|
+
'(mouseleave)': 'onMouseLeave()',
|
|
68
|
+
},
|
|
69
|
+
}]
|
|
70
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }] });
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXNlbGVjdG9yLXBvcG92ZXItdHJpZ2dlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvbmF2LXNlbGVjdG9yL3NyYy9kaXJlY3RpdmVzL25hdi1zZWxlY3Rvci1wb3BvdmVyLXRyaWdnZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFjLEtBQUssRUFBYSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBb0IzRixNQUFNLE9BQU8sa0NBQWtDO0lBYS9CO0lBQ0E7SUFiWiwyQkFBMkIsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUErQixDQUFDO0lBQzVFLCtCQUErQixHQUFHLEtBQUssQ0FBeUM7UUFDNUUsS0FBSyxFQUFFLElBQUk7UUFDWCxRQUFRLEVBQUUsRUFBRTtRQUNaLEtBQUssRUFBRSxLQUFLO1FBQ1osS0FBSyxFQUFFLEtBQUs7S0FDZixDQUFDLENBQUM7SUFDSCw0QkFBNEIsR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7SUFFcEMsWUFBWSxHQUFHLHNDQUFzQyxDQUFDO0lBRXZFLFlBQ1ksRUFBYyxFQUNkLFFBQW1CO1FBRG5CLE9BQUUsR0FBRixFQUFFLENBQVk7UUFDZCxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBRTNCLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDUixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsMkJBQTJCLEVBQUUsQ0FBQywyQkFBMkIsRUFBRSxDQUFDO1lBQ25GLFNBQVMsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1gsSUFBSSxTQUFTLEVBQUUsQ0FBQztvQkFDWixJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7Z0JBQ3JFLENBQUM7cUJBQU0sQ0FBQztvQkFDSixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7Z0JBQ3hFLENBQUM7WUFDTCxDQUFDLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELE9BQU8sQ0FBQyxLQUFZO1FBQ2hCLElBQUksQ0FBQyxJQUFJLENBQUMsK0JBQStCLEVBQUUsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLDRCQUE0QixFQUFFLEVBQUUsQ0FBQztZQUN2RixPQUFPO1FBQ1gsQ0FBQztRQUNELEtBQUssQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsU0FBUyxDQUFDLEtBQW9CO1FBQzFCLElBQUksSUFBSSxDQUFDLCtCQUErQixFQUFFLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsNEJBQTRCLEVBQUUsRUFBRSxDQUFDO1lBQ2hILElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUN6QixDQUFDO0lBQ0wsQ0FBQztJQUVELFlBQVk7UUFDUixJQUFJLElBQUksQ0FBQywrQkFBK0IsRUFBRSxDQUFDLEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQyw0QkFBNEIsRUFBRSxFQUFFLENBQUM7WUFDdkYsSUFBSSxDQUFDLDJCQUEyQixFQUFFLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUN4RCxDQUFDO0lBQ0wsQ0FBQztJQUVELFlBQVk7UUFDUixJQUFJLElBQUksQ0FBQywrQkFBK0IsRUFBRSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQy9DLElBQUksQ0FBQywyQkFBMkIsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQzlDLENBQUM7SUFDTCxDQUFDO0lBRU8sYUFBYTtRQUNqQixJQUFJLENBQUMsMkJBQTJCLEVBQUUsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7dUdBeERRLGtDQUFrQzsyRkFBbEMsa0NBQWtDOzsyRkFBbEMsa0NBQWtDO2tCQVY5QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSwrQkFBK0I7b0JBQ3pDLFVBQVUsRUFBRSxJQUFJO29CQUNoQixJQUFJLEVBQUU7d0JBQ0YsU0FBUyxFQUFFLGlCQUFpQjt3QkFDNUIsV0FBVyxFQUFFLG1CQUFtQjt3QkFDaEMsY0FBYyxFQUFFLGdCQUFnQjt3QkFDaEMsY0FBYyxFQUFFLGdCQUFnQjtxQkFDbkM7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGVmZmVjdCwgRWxlbWVudFJlZiwgaW5wdXQsIFJlbmRlcmVyMiwgdW50cmFja2VkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOYXZTZWxlY3RvclBvcG92ZXJDb21wb25lbnQgfSBmcm9tICcuLi9uYXYtc2VsZWN0b3ItcG9wb3Zlci9uYXYtc2VsZWN0b3ItcG9wb3Zlci5jb21wb25lbnQnO1xuXG5leHBvcnQgdHlwZSBOYXZTZWxlY3RvclBvcG92ZXJUcmlnZ2VyTW9kZSA9IHtcbiAgICBjbGljazogYm9vbGVhbjtcbiAgICBob3ZlcjogYm9vbGVhbjtcbiAgICBmb2N1czogYm9vbGVhbjtcbiAgICBrZXlib2FyZDogKCdTcGFjZScgfCAnRW50ZXInIHwgc3RyaW5nKVtdO1xufTtcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbYXBOYXZTZWxlY3RvclBvcG92ZXJUcmlnZ2VyXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBob3N0OiB7XG4gICAgICAgICcoY2xpY2spJzogJ29uQ2xpY2soJGV2ZW50KScsXG4gICAgICAgICcoa2V5ZG93biknOiAnb25LZXlkb3duKCRldmVudCknLFxuICAgICAgICAnKG1vdXNlZW50ZXIpJzogJ29uTW91c2VFbnRlcigpJyxcbiAgICAgICAgJyhtb3VzZWxlYXZlKSc6ICdvbk1vdXNlTGVhdmUoKScsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgTmF2U2VsZWN0b3JQb3BvdmVyVHJpZ2dlckRpcmVjdGl2ZSB7XG4gICAgYXBOYXZTZWxlY3RvclBvcG92ZXJUcmlnZ2VyID0gaW5wdXQucmVxdWlyZWQ8TmF2U2VsZWN0b3JQb3BvdmVyQ29tcG9uZW50PigpO1xuICAgIGFwTmF2U2VsZWN0b3JQb3BvdmVyVHJpZ2dlck1vZGUgPSBpbnB1dDxQYXJ0aWFsPE5hdlNlbGVjdG9yUG9wb3ZlclRyaWdnZXJNb2RlPj4oe1xuICAgICAgICBjbGljazogdHJ1ZSxcbiAgICAgICAga2V5Ym9hcmQ6IFtdLFxuICAgICAgICBob3ZlcjogZmFsc2UsXG4gICAgICAgIGZvY3VzOiBmYWxzZSxcbiAgICB9KTtcbiAgICBhcE5hdlNlbGVjdG9yUG9wb3ZlckRpc2FibGVkID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSBBQ1RJVkVfQ0xBU1MgPSAnbmF2LXNlbGVjdG9yLXBvcG92ZXItdHJpZ2dlci0tYWN0aXZlJztcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIGVsOiBFbGVtZW50UmVmLFxuICAgICAgICBwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjJcbiAgICApIHtcbiAgICAgICAgZWZmZWN0KCgpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IGRpc3BsYXllZCA9IHRoaXMuYXBOYXZTZWxlY3RvclBvcG92ZXJUcmlnZ2VyKCkubmF2U2VsZWN0b3JQb3BvdmVyRGlzcGxheWVkKCk7XG4gICAgICAgICAgICB1bnRyYWNrZWQoKCkgPT4ge1xuICAgICAgICAgICAgICAgIGlmIChkaXNwbGF5ZWQpIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5yZW5kZXJlci5hZGRDbGFzcyh0aGlzLmVsLm5hdGl2ZUVsZW1lbnQsIHRoaXMuQUNUSVZFX0NMQVNTKTtcbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnJlbmRlcmVyLnJlbW92ZUNsYXNzKHRoaXMuZWwubmF0aXZlRWxlbWVudCwgdGhpcy5BQ1RJVkVfQ0xBU1MpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBvbkNsaWNrKGV2ZW50OiBFdmVudCkge1xuICAgICAgICBpZiAoIXRoaXMuYXBOYXZTZWxlY3RvclBvcG92ZXJUcmlnZ2VyTW9kZSgpLmNsaWNrIHx8IHRoaXMuYXBOYXZTZWxlY3RvclBvcG92ZXJEaXNhYmxlZCgpKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgZXZlbnQuc3RvcEltbWVkaWF0ZVByb3BhZ2F0aW9uKCk7XG4gICAgICAgIHRoaXMudG9nZ2xlRGlzcGxheSgpO1xuICAgIH1cblxuICAgIG9uS2V5ZG93bihldmVudDogS2V5Ym9hcmRFdmVudCkge1xuICAgICAgICBpZiAodGhpcy5hcE5hdlNlbGVjdG9yUG9wb3ZlclRyaWdnZXJNb2RlKCkua2V5Ym9hcmQ/LmluY2x1ZGVzKGV2ZW50LmNvZGUpICYmICF0aGlzLmFwTmF2U2VsZWN0b3JQb3BvdmVyRGlzYWJsZWQoKSkge1xuICAgICAgICAgICAgdGhpcy50b2dnbGVEaXNwbGF5KCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBvbk1vdXNlRW50ZXIoKSB7XG4gICAgICAgIGlmICh0aGlzLmFwTmF2U2VsZWN0b3JQb3BvdmVyVHJpZ2dlck1vZGUoKS5ob3ZlciAmJiAhdGhpcy5hcE5hdlNlbGVjdG9yUG9wb3ZlckRpc2FibGVkKCkpIHtcbiAgICAgICAgICAgIHRoaXMuYXBOYXZTZWxlY3RvclBvcG92ZXJUcmlnZ2VyKCkuZGlzcGxheSh0aGlzLmVsKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIG9uTW91c2VMZWF2ZSgpIHtcbiAgICAgICAgaWYgKHRoaXMuYXBOYXZTZWxlY3RvclBvcG92ZXJUcmlnZ2VyTW9kZSgpLmhvdmVyKSB7XG4gICAgICAgICAgICB0aGlzLmFwTmF2U2VsZWN0b3JQb3BvdmVyVHJpZ2dlcigpLmhpZGUoKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgdG9nZ2xlRGlzcGxheSgpIHtcbiAgICAgICAgdGhpcy5hcE5hdlNlbGVjdG9yUG9wb3ZlclRyaWdnZXIoKS50b2dnbGUodGhpcy5lbCk7XG4gICAgfVxufVxuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { apChevronDown, apChevronUp, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';
|
|
2
2
|
import { animate, keyframes, state, style, transition, trigger } from '@angular/animations';
|
|
3
|
-
import { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, input, signal } from '@angular/core';
|
|
3
|
+
import { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, input, signal, untracked } from '@angular/core';
|
|
4
4
|
import { EventPluginsModule } from '@tinkoff/ng-event-plugins';
|
|
5
5
|
import { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';
|
|
6
6
|
import { NavSelectorGroupComponent } from '../nav-selector-group/nav-selector-group.component';
|
|
@@ -18,19 +18,22 @@ export class NavSelectorCategoryComponent {
|
|
|
18
18
|
constructor(el, navSelectorCategoryPresenter) {
|
|
19
19
|
this.el = el;
|
|
20
20
|
this.navSelectorCategoryPresenter = navSelectorCategoryPresenter;
|
|
21
|
-
afterNextRender(() => this.maxHeight.set(`${this.el.nativeElement.
|
|
21
|
+
afterNextRender(() => this.maxHeight.set(`${this.el.nativeElement.clientHeight * this.category().children.length}px`));
|
|
22
22
|
effect(() => {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
23
|
+
const folded = this.category().folded;
|
|
24
|
+
untracked(() => {
|
|
25
|
+
if (folded) {
|
|
26
|
+
setTimeout(() => this.foldedWithDelay.set(true), 150);
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
this.foldedWithDelay.set(false);
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
});
|
|
30
33
|
}
|
|
31
34
|
maxHeight = signal('0px');
|
|
32
35
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorCategoryComponent, deps: [{ token: i0.ElementRef }, { token: i1.NavSelectorCategoryPresenter }], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorCategoryComponent, isStandalone: true, selector: "ap-nav-selector-category", inputs: { category: { classPropertyName: "category", publicName: "category", isSignal: true, isRequired: true, transformFunction: null } }, host: { listeners: { "keydown.arrowLeft": "navSelectorCategoryPresenter.fold($event, this.category())", "keydown.arrowRight": "navSelectorCategoryPresenter.unfold($event, this.category())" }, properties: { "class.minified": "!navSelectorCategoryPresenter.expanded()" } }, providers: [withSymbols(apChevronDown, apChevronUp), NavSelectorCategoryPresenter], ngImport: i0, template: "@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (keydown.space
|
|
36
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorCategoryComponent, isStandalone: true, selector: "ap-nav-selector-category", inputs: { category: { classPropertyName: "category", publicName: "category", isSignal: true, isRequired: true, transformFunction: null } }, host: { listeners: { "keydown.arrowLeft": "navSelectorCategoryPresenter.fold($event, this.category())", "keydown.arrowRight": "navSelectorCategoryPresenter.unfold($event, this.category())" }, properties: { "class.minified": "!navSelectorCategoryPresenter.expanded()" } }, providers: [withSymbols(apChevronDown, apChevronUp), NavSelectorCategoryPresenter], ngImport: i0, template: "@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n <span class=\"caption\">{{ category().alias }}</span>\n\n <ap-symbol\n class=\"folding-button\"\n size=\"sm\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of category().children; track child.uid) {\n @if (!child.hidden) {\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group [group]=\"child\" />\n }\n }\n }\n </div>\n }\n </div>\n} @else {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n <div class=\"name-container\">\n <span class=\"caption\">{{ category().alias }}</span>\n <span>.</span>\n </div>\n\n <div class=\"toggle\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of category().children; track child.uid) {\n @if (!child.hidden) {\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group [group]=\"child\" />\n }\n }\n }\n </div>\n }\n </div>\n}\n", styles: [":host{display:flex;align-items:center;flex-shrink:0;align-self:stretch;flex-direction:column}:host .children-container{align-self:stretch}:host .folding-button{display:flex;width:16px;height:16px;justify-content:center;align-items:center;flex-shrink:0}:host .content{padding:0 var(--ref-spacing-xxs);display:flex;height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch;cursor:pointer}:host .content:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .content:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .content: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 .content:focus-within{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}: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(--sys-text-style-h4-size);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-md)}:host .children{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch}:host.minified .name-container{overflow:hidden;display:flex}:host.minified .content{position:relative}:host.minified .content .toggle{position:absolute;display:none}:host.minified .content:hover .toggle,:host.minified .content:focus .toggle{inset:0;display:flex;justify-content:center;align-items:center}:host.minified .content:hover .name-container,:host.minified .content:focus .name-container{display:none}\n"], dependencies: [{ kind: "component", type: NavSelectorLeafComponent, selector: "ap-nav-selector-leaf", inputs: ["leaf"] }, { kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }, { kind: "component", type: NavSelectorGroupComponent, selector: "ap-nav-selector-group", inputs: ["group"] }, { kind: "ngmodule", type: EventPluginsModule }, { kind: "directive", type: TreeNodeAccessibilityDirective, selector: "[apTreeNodeAccessibility]", inputs: ["apTreeNodeAccessibility"] }], animations: [
|
|
34
37
|
/**
|
|
35
38
|
* 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)
|
|
36
39
|
*/
|
|
@@ -76,6 +79,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
76
79
|
animate('250ms cubic-bezier(.4, 0, .3, 1)', keyframes([style({ maxHeight: '{{maxHeight}}' }), style({ overflow: 'hidden', maxHeight: 0 })])),
|
|
77
80
|
]),
|
|
78
81
|
]),
|
|
79
|
-
], template: "@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (keydown.space
|
|
82
|
+
], template: "@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n <span class=\"caption\">{{ category().alias }}</span>\n\n <ap-symbol\n class=\"folding-button\"\n size=\"sm\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of category().children; track child.uid) {\n @if (!child.hidden) {\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group [group]=\"child\" />\n }\n }\n }\n </div>\n }\n </div>\n} @else {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n <div class=\"name-container\">\n <span class=\"caption\">{{ category().alias }}</span>\n <span>.</span>\n </div>\n\n <div class=\"toggle\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of category().children; track child.uid) {\n @if (!child.hidden) {\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group [group]=\"child\" />\n }\n }\n }\n </div>\n }\n </div>\n}\n", styles: [":host{display:flex;align-items:center;flex-shrink:0;align-self:stretch;flex-direction:column}:host .children-container{align-self:stretch}:host .folding-button{display:flex;width:16px;height:16px;justify-content:center;align-items:center;flex-shrink:0}:host .content{padding:0 var(--ref-spacing-xxs);display:flex;height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch;cursor:pointer}:host .content:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .content:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .content: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 .content:focus-within{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}: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(--sys-text-style-h4-size);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-md)}:host .children{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch}:host.minified .name-container{overflow:hidden;display:flex}:host.minified .content{position:relative}:host.minified .content .toggle{position:absolute;display:none}:host.minified .content:hover .toggle,:host.minified .content:focus .toggle{inset:0;display:flex;justify-content:center;align-items:center}:host.minified .content:hover .name-container,:host.minified .content:focus .name-container{display:none}\n"] }]
|
|
80
83
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NavSelectorCategoryPresenter }] });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-category.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-category/nav-selector-category.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-category/nav-selector-category.component.html"],"names":[],"mappings":"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","sourcesContent":["import { apChevronDown, apChevronUp, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, ElementRef, input, signal } from '@angular/core';\nimport { EventPluginsModule } from '@tinkoff/ng-event-plugins';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorCategory } from '../nav-selector';\nimport { NavSelectorGroupComponent } from '../nav-selector-group/nav-selector-group.component';\nimport { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';\nimport { NavSelectorCategoryPresenter } from './nav-selector-category.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-category',\n    templateUrl: './nav-selector-category.component.html',\n    styleUrls: ['./nav-selector-category.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [NavSelectorLeafComponent, SymbolComponent, NavSelectorGroupComponent, EventPluginsModule, TreeNodeAccessibilityDirective],\n    providers: [withSymbols(apChevronDown, apChevronUp), NavSelectorCategoryPresenter],\n    host: {\n        '[class.minified]': '!navSelectorCategoryPresenter.expanded()',\n        '(keydown.arrowLeft)': 'navSelectorCategoryPresenter.fold($event, this.category())',\n        '(keydown.arrowRight)': 'navSelectorCategoryPresenter.unfold($event, this.category())',\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({ maxHeight: '{{maxHeight}}' }), style({ overflow: 'hidden', maxHeight: 0 })])\n                ),\n            ]),\n        ]),\n    ],\n})\nexport class NavSelectorCategoryComponent {\n    category = input.required<InternalNavSelectorCategory>();\n\n    foldSymbol = computed(() => (this.category().folded ? 'chevron-down' : 'chevron-up'));\n\n    foldedWithDelay = signal(false);\n\n    animationState = computed(() => (this.category().folded ? 'collapsed' : 'expanded'));\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorCategoryPresenter: NavSelectorCategoryPresenter\n    ) {\n        afterNextRender(() => this.maxHeight.set(`${this.el.nativeElement.scrollHeight}px`));\n\n        effect(\n            () => {\n                if (this.category().folded) {\n                    setTimeout(() => this.foldedWithDelay.set(true), 150);\n                } else {\n                    this.foldedWithDelay.set(false);\n                }\n            },\n            { allowSignalWrites: true }\n        );\n    }\n\n    maxHeight = signal('0px');\n}\n","@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n    <div\n        class=\"content\"\n        [apTreeNodeAccessibility]=\"category()\"\n        (keydown.space.stop)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n        <span class=\"caption\">{{ category().alias }}</span>\n\n        <ap-symbol\n            class=\"folding-button\"\n            size=\"sm\"\n            [attr.aria-label]=\"'Toggle ' + category().alias\"\n            [symbolId]=\"foldSymbol()\"\n            (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n            (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n            (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\" />\n    </div>\n\n    <div\n        class=\"children-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <div class=\"children\">\n                @for (child of category().children; track child.uid) {\n                    @if (!child.hidden) {\n                        @if (child.type === 'LEAF') {\n                            <ap-nav-selector-leaf [leaf]=\"child\" />\n                        } @else if (child.type === 'GROUP') {\n                            <ap-nav-selector-group [group]=\"child\" />\n                        }\n                    }\n                }\n            </div>\n        }\n    </div>\n} @else {\n    <div\n        class=\"content\"\n        [apTreeNodeAccessibility]=\"category()\"\n        (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n        <div class=\"name-container\">\n            <span class=\"caption\">{{ category().alias }}</span>\n            <span>.</span>\n        </div>\n\n        <div class=\"toggle\">\n            <ap-symbol\n                size=\"sm\"\n                [symbolId]=\"foldSymbol()\" />\n        </div>\n    </div>\n\n    <div\n        class=\"children-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <div class=\"children\">\n                @for (child of category().children; track child.uid) {\n                    @if (!child.hidden) {\n                        @if (child.type === 'LEAF') {\n                            <ap-nav-selector-leaf [leaf]=\"child\" />\n                        } @else if (child.type === 'GROUP') {\n                            <ap-nav-selector-group [group]=\"child\" />\n                        }\n                    }\n                }\n            </div>\n        }\n    </div>\n}\n"]}
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-category.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-category/nav-selector-category.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-category/nav-selector-category.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACjG,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC5F,OAAO,EAAE,eAAe,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAc,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC5I,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,8BAA8B,EAAE,MAAM,iDAAiD,CAAC;AAEjG,OAAO,EAAE,yBAAyB,EAAE,MAAM,oDAAoD,CAAC;AAC/F,OAAO,EAAE,wBAAwB,EAAE,MAAM,kDAAkD,CAAC;AAC5F,OAAO,EAAE,4BAA4B,EAAE,MAAM,mCAAmC,CAAC;;;AA6CjF,MAAM,OAAO,4BAA4B;IAUzB;IACD;IAVX,QAAQ,GAAG,KAAK,CAAC,QAAQ,EAA+B,CAAC;IAEzD,UAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;IAEtF,eAAe,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAEhC,cAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;IAErF,YACY,EAAc,EACf,4BAA0D;QADzD,OAAE,GAAF,EAAE,CAAY;QACf,iCAA4B,GAA5B,4BAA4B,CAA8B;QAEjE,eAAe,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC;QAEvH,MAAM,CAAC,GAAG,EAAE;YACR,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC;YACtC,SAAS,CAAC,GAAG,EAAE;gBACX,IAAI,MAAM,EAAE,CAAC;oBACT,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;gBAC1D,CAAC;qBAAM,CAAC;oBACJ,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBACpC,CAAC;YACL,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IAED,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;uGA3BjB,4BAA4B;2FAA5B,4BAA4B,meApC1B,CAAC,WAAW,CAAC,aAAa,EAAE,WAAW,CAAC,EAAE,4BAA4B,CAAC,0BCjBtF,yzFA+EA,67DD/Dc,wBAAwB,mFAAE,eAAe,sHAAE,yBAAyB,oFAAE,kBAAkB,+BAAE,8BAA8B,6FAOtH;YACR;;eAEG;YACH,OAAO,CAAC,WAAW,EAAE;gBACjB,KAAK,CACD,WAAW,EACX,KAAK,CAAC;oBACF,SAAS,EAAE,CAAC;oBACZ,QAAQ,EAAE,QAAQ;iBACrB,CAAC,CACL;gBACD,KAAK,CACD,UAAU,EACV,KAAK,CAAC;oBACF,SAAS,EAAE,SAAS;iBACvB,CAAC,CACL;gBACD,UAAU,CAAC,uBAAuB,EAAE;oBAChC,OAAO,CAAC,kCAAkC,EAAE,KAAK,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC,CAAC;iBACzG,CAAC;gBACF,UAAU,CAAC,uBAAuB,EAAE;oBAChC,OAAO,CACH,kCAAkC,EAClC,SAAS,CAAC,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAClG;iBACJ,CAAC;aACL,CAAC;SACL;;2FAEQ,4BAA4B;kBA3CxC,SAAS;+BACI,0BAA0B,cAGxB,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC,CAAC,wBAAwB,EAAE,eAAe,EAAE,yBAAyB,EAAE,kBAAkB,EAAE,8BAA8B,CAAC,aACxH,CAAC,WAAW,CAAC,aAAa,EAAE,WAAW,CAAC,EAAE,4BAA4B,CAAC,QAC5E;wBACF,kBAAkB,EAAE,0CAA0C;wBAC9D,qBAAqB,EAAE,4DAA4D;wBACnF,sBAAsB,EAAE,8DAA8D;qBACzF,cACW;wBACR;;2BAEG;wBACH,OAAO,CAAC,WAAW,EAAE;4BACjB,KAAK,CACD,WAAW,EACX,KAAK,CAAC;gCACF,SAAS,EAAE,CAAC;gCACZ,QAAQ,EAAE,QAAQ;6BACrB,CAAC,CACL;4BACD,KAAK,CACD,UAAU,EACV,KAAK,CAAC;gCACF,SAAS,EAAE,SAAS;6BACvB,CAAC,CACL;4BACD,UAAU,CAAC,uBAAuB,EAAE;gCAChC,OAAO,CAAC,kCAAkC,EAAE,KAAK,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC,CAAC;6BACzG,CAAC;4BACF,UAAU,CAAC,uBAAuB,EAAE;gCAChC,OAAO,CACH,kCAAkC,EAClC,SAAS,CAAC,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAClG;6BACJ,CAAC;yBACL,CAAC;qBACL","sourcesContent":["import { apChevronDown, apChevronUp, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, ElementRef, input, signal, untracked } from '@angular/core';\nimport { EventPluginsModule } from '@tinkoff/ng-event-plugins';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorCategory } from '../nav-selector';\nimport { NavSelectorGroupComponent } from '../nav-selector-group/nav-selector-group.component';\nimport { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';\nimport { NavSelectorCategoryPresenter } from './nav-selector-category.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-category',\n    templateUrl: './nav-selector-category.component.html',\n    styleUrls: ['./nav-selector-category.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [NavSelectorLeafComponent, SymbolComponent, NavSelectorGroupComponent, EventPluginsModule, TreeNodeAccessibilityDirective],\n    providers: [withSymbols(apChevronDown, apChevronUp), NavSelectorCategoryPresenter],\n    host: {\n        '[class.minified]': '!navSelectorCategoryPresenter.expanded()',\n        '(keydown.arrowLeft)': 'navSelectorCategoryPresenter.fold($event, this.category())',\n        '(keydown.arrowRight)': 'navSelectorCategoryPresenter.unfold($event, this.category())',\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({ maxHeight: '{{maxHeight}}' }), style({ overflow: 'hidden', maxHeight: 0 })])\n                ),\n            ]),\n        ]),\n    ],\n})\nexport class NavSelectorCategoryComponent {\n    category = input.required<InternalNavSelectorCategory>();\n\n    foldSymbol = computed(() => (this.category().folded ? 'chevron-down' : 'chevron-up'));\n\n    foldedWithDelay = signal(false);\n\n    animationState = computed(() => (this.category().folded ? 'collapsed' : 'expanded'));\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorCategoryPresenter: NavSelectorCategoryPresenter\n    ) {\n        afterNextRender(() => this.maxHeight.set(`${this.el.nativeElement.clientHeight * this.category().children.length}px`));\n\n        effect(() => {\n            const folded = this.category().folded;\n            untracked(() => {\n                if (folded) {\n                    setTimeout(() => this.foldedWithDelay.set(true), 150);\n                } else {\n                    this.foldedWithDelay.set(false);\n                }\n            });\n        });\n    }\n\n    maxHeight = signal('0px');\n}\n","@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n    <div\n        class=\"content\"\n        [apTreeNodeAccessibility]=\"category()\"\n        (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n        <span class=\"caption\">{{ category().alias }}</span>\n\n        <ap-symbol\n            class=\"folding-button\"\n            size=\"sm\"\n            [symbolId]=\"foldSymbol()\" />\n    </div>\n\n    <div\n        class=\"children-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <div class=\"children\">\n                @for (child of category().children; track child.uid) {\n                    @if (!child.hidden) {\n                        @if (child.type === 'LEAF') {\n                            <ap-nav-selector-leaf [leaf]=\"child\" />\n                        } @else if (child.type === 'GROUP') {\n                            <ap-nav-selector-group [group]=\"child\" />\n                        }\n                    }\n                }\n            </div>\n        }\n    </div>\n} @else {\n    <div\n        class=\"content\"\n        [apTreeNodeAccessibility]=\"category()\"\n        (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n        <div class=\"name-container\">\n            <span class=\"caption\">{{ category().alias }}</span>\n            <span>.</span>\n        </div>\n\n        <div class=\"toggle\">\n            <ap-symbol\n                size=\"sm\"\n                [symbolId]=\"foldSymbol()\" />\n        </div>\n    </div>\n\n    <div\n        class=\"children-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <div class=\"children\">\n                @for (child of category().children; track child.uid) {\n                    @if (!child.hidden) {\n                        @if (child.type === 'LEAF') {\n                            <ap-nav-selector-leaf [leaf]=\"child\" />\n                        } @else if (child.type === 'GROUP') {\n                            <ap-nav-selector-group [group]=\"child\" />\n                        }\n                    }\n                }\n            </div>\n        }\n    </div>\n}\n"]}
|
|
@@ -4,7 +4,7 @@ import { CounterComponent } from '@agorapulse/ui-components/counter';
|
|
|
4
4
|
import { TooltipDirective } from '@agorapulse/ui-components/tooltip';
|
|
5
5
|
import { apChevronDown, apChevronUp, apErrorFill, apFolder, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';
|
|
6
6
|
import { animate, keyframes, state, style, transition, trigger } from '@angular/animations';
|
|
7
|
-
import { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, input, signal, viewChild } from '@angular/core';
|
|
7
|
+
import { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, input, signal, untracked, viewChild, } from '@angular/core';
|
|
8
8
|
import { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';
|
|
9
9
|
import { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';
|
|
10
10
|
import { NavSelectorGroupPresenter } from './nav-selector-group.presenter';
|
|
@@ -40,7 +40,7 @@ export class NavSelectorGroupComponent {
|
|
|
40
40
|
this.el = el;
|
|
41
41
|
this.navSelectorGroupPresenter = navSelectorGroupPresenter;
|
|
42
42
|
afterNextRender(() => {
|
|
43
|
-
this.maxHeight.set(`${this.el.nativeElement.
|
|
43
|
+
this.maxHeight.set(`${this.el.nativeElement.clientHeight * this.group().children.length}px`);
|
|
44
44
|
const el = this.aliasEl()?.nativeElement;
|
|
45
45
|
if (el) {
|
|
46
46
|
this.aliasBoundedClientRect.set({
|
|
@@ -52,19 +52,22 @@ export class NavSelectorGroupComponent {
|
|
|
52
52
|
}
|
|
53
53
|
});
|
|
54
54
|
effect(() => {
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
55
|
+
const folded = this.group().folded;
|
|
56
|
+
untracked(() => {
|
|
57
|
+
if (folded) {
|
|
58
|
+
setTimeout(() => this.foldedWithDelay.set(true), 150);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
this.foldedWithDelay.set(false);
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
});
|
|
62
65
|
}
|
|
63
66
|
maxHeight = signal('0px');
|
|
64
|
-
onKeydownSpaceOrEnter(
|
|
67
|
+
onKeydownSpaceOrEnter(event) {
|
|
65
68
|
// Prevent to toggle folding when focus is on the checkbox
|
|
66
69
|
if (document.activeElement === this.el.nativeElement.querySelector('.content')) {
|
|
67
|
-
this.toggleFolding(
|
|
70
|
+
this.toggleFolding(event);
|
|
68
71
|
}
|
|
69
72
|
else {
|
|
70
73
|
this.navSelectorGroupPresenter.onGroupSelected(this.group());
|
|
@@ -83,7 +86,7 @@ export class NavSelectorGroupComponent {
|
|
|
83
86
|
this.navSelectorGroupPresenter.unfold(this.group());
|
|
84
87
|
}
|
|
85
88
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorGroupComponent, deps: [{ token: i0.ElementRef }, { token: i1.NavSelectorGroupPresenter }], target: i0.ɵɵFactoryTarget.Component });
|
|
86
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorGroupComponent, isStandalone: true, selector: "ap-nav-selector-group", inputs: { group: { classPropertyName: "group", publicName: "group", isSignal: true, isRequired: true, transformFunction: null } }, host: { listeners: { "keydown.arrowLeft": "fold($event)", "keydown.arrowRight": "unfold($event)" }, properties: { "class.minified": "!navSelectorGroupPresenter.expanded()" } }, providers: [withSymbols(apFolder, apErrorFill, apChevronDown, apChevronUp), NavSelectorGroupPresenter], viewQueries: [{ propertyName: "aliasEl", first: true, predicate: ["alias"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (navSelectorGroupPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"group()\"\n (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n (keydown.enter)=\"onKeydownSpaceOrEnter($event)\">\n @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"group().uid\"\n [checked]=\"group().selected\"\n [disabled]=\"!group().selectable\"\n [indeterminate]=\"group().undeterminedSelection\"\n (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n }\n\n <ap-symbol\n symbolId=\"folder\"\n size=\"sm\" />\n\n <span\n #alias\n class=\"caption\">\n {{ group().alias }}\n </span>\n\n @if (group().displayTokenInvalid) {\n <ap-symbol\n symbolId=\"error_fill\"\n size=\"sm\" />\n }\n\n @if (group().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ group().counter }}\n </ap-counter>\n }\n\n <ap-symbol\n size=\"sm\"\n class=\"folding-button\"\n [tabindex]=\"group().accessibility.tabIndex\"\n [attr.aria-label]=\"'Toggle ' + group().alias\"\n [symbolId]=\"foldSymbol()\"\n (keydown.space)=\"toggleFolding($event)\"\n (keydown.enter)=\"toggleFolding($event)\"\n (click)=\"toggleFolding($event)\" />\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of group().children; track child.uid) {\n @if (!child.hidden) {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n }\n }\n </div>\n }\n </div>\n} @else {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"group()\"\n (click)=\"toggleFolding($event)\"\n (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n (keydown.enter)=\"onKeydownSpaceOrEnter($event)\">\n @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"group().uid\"\n [checked]=\"group().selected\"\n [disabled]=\"!group().selectable\"\n [indeterminate]=\"group().undeterminedSelection\"\n (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n }\n\n <div class=\"picture-url-sample-container\">\n <div class=\"picture-url-sample\">\n @for (pictureUrlSample of group().childrenPictureUrlSample; track pictureUrlSample) {\n <ap-avatar\n [size]=\"$any(12)\"\n [profilePicture]=\"pictureUrlSample.url ?? undefined\"\n [showInitials]=\"pictureUrlSample.initial\" />\n }\n\n <div class=\"status\">\n @if (group().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [notif]=\"true\"\n [background]=\"true\">\n {{ group().counter }}\n </ap-counter>\n }\n </div>\n </div>\n\n <div class=\"toggle\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n </div>\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 <div class=\"children\">\n @for (child of group().children; track child.uid) {\n @if (!child.hidden) {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n }\n }\n </div>\n }\n </div>\n}\n", styles: [":host{display:flex;align-items:center;flex-shrink:0;align-self:stretch;flex-direction:column}:host .children-container{align-self:stretch}:host .content{padding:0 var(--ref-spacing-xxs);display:flex;height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch;cursor:pointer}:host .content:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .content:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .content: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 .content:focus-within{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.minified) ap-symbol[symbol-id=chevron-down],:host:not(.minified) ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host:not(.minified) ap-symbol[symbol-id=chevron-down]:hover,:host:not(.minified) ap-symbol[symbol-id=chevron-up]:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.minified) ap-symbol[symbol-id=chevron-down]:active,:host:not(.minified) ap-symbol[symbol-id=chevron-up]:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-40)}:host:not(.minified) ap-symbol[symbol-id=chevron-down]:focus,:host:not(.minified) ap-symbol[symbol-id=chevron-up]: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 ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host ap-symbol[symbol-id=folder]{color:var(--ref-color-grey-100)}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host .folding-button{display:flex;width:24px;height:24px;justify-content:center;align-items:center;flex-shrink:0}:host .folding-button:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .folding-button:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-40)}: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-bold);line-height:var(--ref-font-line-height-xs)}:host .children{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch}:host .picture-url-sample-container{position:relative;width:26px}:host .picture-url-sample{display:flex;width:26px;align-items:center;align-content:center;gap:2px;flex-wrap:wrap}:host.minified .content{gap:var(--ref-spacing-xxxs);position:relative;justify-content:center}:host.minified .content .toggle{position:absolute;display:none}:host.minified .content:hover .toggle,:host.minified .content:focus .toggle{inset:0;display:flex;justify-content:center;align-items:center}:host.minified .content:hover .picture-url-sample,:host.minified .content:focus .picture-url-sample{display:none}:host.minified ::ng-deep ap-checkbox .checkbox .checkbox-container{padding:0}:host.minified .status{position:absolute;right:-4px;top:-6px}\n"], dependencies: [{ kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }, { kind: "component", type: CounterComponent, selector: "ap-counter", inputs: ["color", "size", "background", "notif"] }, { kind: "component", type: NavSelectorLeafComponent, selector: "ap-nav-selector-leaf", inputs: ["leaf"] }, { kind: "component", type: CheckboxComponent, selector: "ap-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "disabled", "indeterminate", "checked", "required", "name"], outputs: ["change"] }, { kind: "component", type: AvatarComponent, selector: "ap-avatar", inputs: ["profilePicture", "alt", "network", "size", "username", "showInitials", "bigNetwork", "anonymous", "online", "youtubeAvatarMode", "rounded"] }, { kind: "directive", type: TooltipDirective, selector: "[apTooltip]", inputs: ["apTooltip", "apTooltipPosition", "apTooltipShowDelay", "apTooltipHideDelay", "apTooltipDuration", "apTooltipDisabled", "apTooltipTruncatedTextOnly", "apTooltipTemplateContext", "apTooltipVirtualScrollElement"] }, { kind: "directive", type: TreeNodeAccessibilityDirective, selector: "[apTreeNodeAccessibility]", inputs: ["apTreeNodeAccessibility"] }], animations: [
|
|
89
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorGroupComponent, isStandalone: true, selector: "ap-nav-selector-group", inputs: { group: { classPropertyName: "group", publicName: "group", isSignal: true, isRequired: true, transformFunction: null } }, host: { listeners: { "keydown.arrowLeft": "fold($event)", "keydown.arrowRight": "unfold($event)" }, properties: { "class.minified": "!navSelectorGroupPresenter.expanded()" } }, providers: [withSymbols(apFolder, apErrorFill, apChevronDown, apChevronUp), NavSelectorGroupPresenter], viewQueries: [{ propertyName: "aliasEl", first: true, predicate: ["alias"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (navSelectorGroupPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"group()\"\n (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n (keydown.enter)=\"onKeydownSpaceOrEnter($event)\"\n (click)=\"toggleFolding($event)\">\n @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"group().uid\"\n [checked]=\"group().selected\"\n [disabled]=\"!group().selectable\"\n [indeterminate]=\"group().undeterminedSelection\"\n (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n }\n\n <ap-symbol\n symbolId=\"folder\"\n size=\"sm\" />\n\n <span\n #alias\n class=\"caption\">\n {{ group().alias }}\n </span>\n\n @if (group().displayTokenInvalid) {\n <ap-symbol\n symbolId=\"error_fill\"\n size=\"sm\" />\n }\n\n @if (group().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ group().counter }}\n </ap-counter>\n }\n\n <ap-symbol\n size=\"sm\"\n class=\"folding-button\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of group().children; track child.uid) {\n @if (!child.hidden) {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n }\n }\n </div>\n }\n </div>\n} @else {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [class.token-invalid]=\"group().displayTokenInvalid\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"group()\"\n (click)=\"toggleFolding($event)\"\n (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n (keydown.enter)=\"onKeydownSpaceOrEnter($event)\">\n @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"group().uid\"\n [checked]=\"group().selected\"\n [disabled]=\"!group().selectable\"\n [indeterminate]=\"group().undeterminedSelection\"\n (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n }\n\n <div class=\"picture-url-sample-container\">\n <div class=\"picture-url-sample\">\n @for (pictureUrlSample of group().childrenPictureUrlSample; track pictureUrlSample) {\n <ap-avatar\n class=\"avatar-sample\"\n [size]=\"16\"\n [profilePicture]=\"pictureUrlSample.url ?? undefined\"\n [showInitials]=\"pictureUrlSample.initial\" />\n }\n\n <div class=\"status\">\n @if (group().displayCounter) {\n <ap-counter\n class=\"counter-override\"\n color=\"orange\"\n size=\"normal\"\n [notif]=\"true\"\n [background]=\"true\">\n {{ group().counter }}\n </ap-counter>\n }\n </div>\n </div>\n\n <div class=\"toggle\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n </div>\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 <div class=\"children\">\n @for (child of group().children; track child.uid) {\n @if (!child.hidden) {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n }\n }\n </div>\n }\n </div>\n}\n", styles: [":host{display:flex;align-items:center;flex-shrink:0;align-self:stretch;flex-direction:column}:host .children-container{align-self:stretch}:host .content{padding:0 var(--ref-spacing-xxs);display:flex;height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch;cursor:pointer}:host .content ::ng-deep ap-checkbox .checkbox .checkbox-container{padding:0}:host .content:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .content:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .content:focus-visible{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 ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host ap-symbol[symbol-id=folder]{color:var(--ref-color-grey-100)}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host .folding-button{display:flex;width:16px;height:16px;justify-content:center;align-items:center;flex-shrink:0}: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-bold);line-height:var(--ref-font-line-height-xs)}:host .children{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch}:host .picture-url-sample-container{position:relative;width:26px}:host .picture-url-sample{display:flex;width:26px;align-items:center;align-content:center;gap:2px;flex-wrap:wrap}:host .avatar-sample{width:12px;height:12px;min-width:12px;max-width:12px;min-height:12px;max-height:12px}:host.minified .content{gap:var(--ref-spacing-xxxs);padding:var(--ref-spacing-xxxs);position:relative;justify-content:center}:host.minified .content .toggle{display:none}:host.minified .content .counter-override{background-color:var(--ref-color-orange-150)}:host.minified .content:hover .toggle,:host.minified .content:focus-visible .toggle{width:26px;display:flex;justify-content:center;align-items:center}:host.minified .content:hover .picture-url-sample,:host.minified .content:focus-visible .picture-url-sample{display:none}:host.minified ::ng-deep ap-checkbox .checkbox .checkbox-container{padding:0}:host.minified .status{position:absolute;right:-12px;top:-2px}\n"], dependencies: [{ kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }, { kind: "component", type: CounterComponent, selector: "ap-counter", inputs: ["color", "size", "background", "notif"] }, { kind: "component", type: NavSelectorLeafComponent, selector: "ap-nav-selector-leaf", inputs: ["leaf"] }, { kind: "component", type: CheckboxComponent, selector: "ap-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "disabled", "indeterminate", "checked", "required", "name"], outputs: ["change"] }, { kind: "component", type: AvatarComponent, selector: "ap-avatar", inputs: ["profilePicture", "alt", "network", "size", "username", "showInitials", "bigNetwork", "anonymous", "online", "youtubeAvatarMode", "rounded"] }, { kind: "directive", type: TooltipDirective, selector: "[apTooltip]", inputs: ["apTooltip", "apTooltipPosition", "apTooltipShowDelay", "apTooltipHideDelay", "apTooltipDuration", "apTooltipDisabled", "apTooltipTruncatedTextOnly", "apTooltipTemplateContext", "apTooltipVirtualScrollElement"] }, { kind: "directive", type: TreeNodeAccessibilityDirective, selector: "[apTreeNodeAccessibility]", inputs: ["apTreeNodeAccessibility"] }], animations: [
|
|
87
90
|
/**
|
|
88
91
|
* 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)
|
|
89
92
|
*/
|
|
@@ -137,6 +140,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
137
140
|
animate('250ms cubic-bezier(.4, 0, .3, 1)', keyframes([style({ maxHeight: '{{maxHeight}}', overflow: 'hidden' }), style({ maxHeight: 0, overflow: 'hidden' })])),
|
|
138
141
|
]),
|
|
139
142
|
]),
|
|
140
|
-
], template: "@if (navSelectorGroupPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"group()\"\n (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n (keydown.enter)=\"onKeydownSpaceOrEnter($event)\">\n @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"group().uid\"\n [checked]=\"group().selected\"\n [disabled]=\"!group().selectable\"\n [indeterminate]=\"group().undeterminedSelection\"\n (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n }\n\n <ap-symbol\n symbolId=\"folder\"\n size=\"sm\" />\n\n <span\n #alias\n class=\"caption\">\n {{ group().alias }}\n </span>\n\n @if (group().displayTokenInvalid) {\n <ap-symbol\n symbolId=\"error_fill\"\n size=\"sm\" />\n }\n\n @if (group().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ group().counter }}\n </ap-counter>\n }\n\n <ap-symbol\n size=\"sm\"\n class=\"folding-button\"\n [
|
|
143
|
+
], template: "@if (navSelectorGroupPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"group()\"\n (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n (keydown.enter)=\"onKeydownSpaceOrEnter($event)\"\n (click)=\"toggleFolding($event)\">\n @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"group().uid\"\n [checked]=\"group().selected\"\n [disabled]=\"!group().selectable\"\n [indeterminate]=\"group().undeterminedSelection\"\n (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n }\n\n <ap-symbol\n symbolId=\"folder\"\n size=\"sm\" />\n\n <span\n #alias\n class=\"caption\">\n {{ group().alias }}\n </span>\n\n @if (group().displayTokenInvalid) {\n <ap-symbol\n symbolId=\"error_fill\"\n size=\"sm\" />\n }\n\n @if (group().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ group().counter }}\n </ap-counter>\n }\n\n <ap-symbol\n size=\"sm\"\n class=\"folding-button\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of group().children; track child.uid) {\n @if (!child.hidden) {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n }\n }\n </div>\n }\n </div>\n} @else {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [class.token-invalid]=\"group().displayTokenInvalid\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"group()\"\n (click)=\"toggleFolding($event)\"\n (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n (keydown.enter)=\"onKeydownSpaceOrEnter($event)\">\n @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"group().uid\"\n [checked]=\"group().selected\"\n [disabled]=\"!group().selectable\"\n [indeterminate]=\"group().undeterminedSelection\"\n (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n }\n\n <div class=\"picture-url-sample-container\">\n <div class=\"picture-url-sample\">\n @for (pictureUrlSample of group().childrenPictureUrlSample; track pictureUrlSample) {\n <ap-avatar\n class=\"avatar-sample\"\n [size]=\"16\"\n [profilePicture]=\"pictureUrlSample.url ?? undefined\"\n [showInitials]=\"pictureUrlSample.initial\" />\n }\n\n <div class=\"status\">\n @if (group().displayCounter) {\n <ap-counter\n class=\"counter-override\"\n color=\"orange\"\n size=\"normal\"\n [notif]=\"true\"\n [background]=\"true\">\n {{ group().counter }}\n </ap-counter>\n }\n </div>\n </div>\n\n <div class=\"toggle\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n </div>\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 <div class=\"children\">\n @for (child of group().children; track child.uid) {\n @if (!child.hidden) {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n }\n }\n </div>\n }\n </div>\n}\n", styles: [":host{display:flex;align-items:center;flex-shrink:0;align-self:stretch;flex-direction:column}:host .children-container{align-self:stretch}:host .content{padding:0 var(--ref-spacing-xxs);display:flex;height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch;cursor:pointer}:host .content ::ng-deep ap-checkbox .checkbox .checkbox-container{padding:0}:host .content:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .content:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .content:focus-visible{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 ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host ap-symbol[symbol-id=folder]{color:var(--ref-color-grey-100)}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host .folding-button{display:flex;width:16px;height:16px;justify-content:center;align-items:center;flex-shrink:0}: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-bold);line-height:var(--ref-font-line-height-xs)}:host .children{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch}:host .picture-url-sample-container{position:relative;width:26px}:host .picture-url-sample{display:flex;width:26px;align-items:center;align-content:center;gap:2px;flex-wrap:wrap}:host .avatar-sample{width:12px;height:12px;min-width:12px;max-width:12px;min-height:12px;max-height:12px}:host.minified .content{gap:var(--ref-spacing-xxxs);padding:var(--ref-spacing-xxxs);position:relative;justify-content:center}:host.minified .content .toggle{display:none}:host.minified .content .counter-override{background-color:var(--ref-color-orange-150)}:host.minified .content:hover .toggle,:host.minified .content:focus-visible .toggle{width:26px;display:flex;justify-content:center;align-items:center}:host.minified .content:hover .picture-url-sample,:host.minified .content:focus-visible .picture-url-sample{display:none}:host.minified ::ng-deep ap-checkbox .checkbox .checkbox-container{padding:0}:host.minified .status{position:absolute;right:-12px;top:-2px}\n"] }]
|
|
141
144
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NavSelectorGroupPresenter }] });
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-group.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-group/nav-selector-group.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-group/nav-selector-group.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, apFolder, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, ElementRef, input, signal, viewChild } from '@angular/core';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorGroup } from '../nav-selector';\nimport { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';\nimport { NavSelectorGroupPresenter } from './nav-selector-group.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-group',\n    templateUrl: './nav-selector-group.component.html',\n    styleUrls: ['./nav-selector-group.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [withSymbols(apFolder, apErrorFill, apChevronDown, apChevronUp), NavSelectorGroupPresenter],\n    imports: [\n        SymbolComponent,\n        CounterComponent,\n        NavSelectorLeafComponent,\n        CheckboxComponent,\n        AvatarComponent,\n        TooltipDirective,\n        TreeNodeAccessibilityDirective,\n    ],\n    host: {\n        '[class.minified]': '!navSelectorGroupPresenter.expanded()',\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({ maxHeight: '{{maxHeight}}', overflow: 'hidden' })),\n            ]),\n            transition('expanded => collapsed', [\n                animate(\n                    '250ms cubic-bezier(.4, 0, .3, 1)',\n                    keyframes([style({ maxHeight: '{{maxHeight}}', overflow: 'hidden' }), style({ maxHeight: 0, overflow: 'hidden' })])\n                ),\n            ]),\n        ]),\n    ],\n})\nexport class NavSelectorGroupComponent {\n    group = input.required<InternalNavSelectorGroup>();\n\n    foldSymbol = computed(() => (this.group().folded ? 'chevron-down' : 'chevron-up'));\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.navSelectorGroupPresenter.expanded() || el.offsetWidth < el.scrollWidth || el.offsetHeight < el.scrollHeight) {\n            content.push(this.group().alias);\n        }\n\n        if (this.group().displayTokenInvalid) {\n            content.push(this.navSelectorGroupPresenter.texts().tokenInvalid);\n        }\n\n        return content.join('<br>');\n    });\n    tooltipDisabled = computed(() => !this.tooltipContent().length);\n\n    foldedWithDelay = signal(false);\n\n    animationState = computed(() => (this.group().folded ? 'collapsed' : 'expanded'));\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorGroupPresenter: NavSelectorGroupPresenter\n    ) {\n        afterNextRender(() => {\n            this.maxHeight.set(`${this.el.nativeElement.scrollHeight}px`);\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.group().folded) {\n                    setTimeout(() => this.foldedWithDelay.set(true), 150);\n                } else {\n                    this.foldedWithDelay.set(false);\n                }\n            },\n            { allowSignalWrites: true }\n        );\n    }\n\n    maxHeight = signal('0px');\n\n    onKeydownSpaceOrEnter($event: Event) {\n        // Prevent to toggle folding when focus is on the checkbox\n        if (document.activeElement === this.el.nativeElement.querySelector('.content')) {\n            this.toggleFolding($event);\n        } else {\n            this.navSelectorGroupPresenter.onGroupSelected(this.group());\n        }\n    }\n\n    toggleFolding(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorGroupPresenter.onGroupToggleFolding(this.group());\n    }\n\n    fold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorGroupPresenter.fold(this.group());\n    }\n\n    unfold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorGroupPresenter.unfold(this.group());\n    }\n}\n","@if (navSelectorGroupPresenter.expandedAfterDelay()) {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [apTreeNodeAccessibility]=\"group()\"\n        (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n        (keydown.enter)=\"onKeydownSpaceOrEnter($event)\">\n        @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"group().uid\"\n                [checked]=\"group().selected\"\n                [disabled]=\"!group().selectable\"\n                [indeterminate]=\"group().undeterminedSelection\"\n                (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n        }\n\n        <ap-symbol\n            symbolId=\"folder\"\n            size=\"sm\" />\n\n        <span\n            #alias\n            class=\"caption\">\n            {{ group().alias }}\n        </span>\n\n        @if (group().displayTokenInvalid) {\n            <ap-symbol\n                symbolId=\"error_fill\"\n                size=\"sm\" />\n        }\n\n        @if (group().displayCounter) {\n            <ap-counter\n                color=\"orange\"\n                size=\"normal\"\n                [background]=\"false\">\n                {{ group().counter }}\n            </ap-counter>\n        }\n\n        <ap-symbol\n            size=\"sm\"\n            class=\"folding-button\"\n            [tabindex]=\"group().accessibility.tabIndex\"\n            [attr.aria-label]=\"'Toggle ' + group().alias\"\n            [symbolId]=\"foldSymbol()\"\n            (keydown.space)=\"toggleFolding($event)\"\n            (keydown.enter)=\"toggleFolding($event)\"\n            (click)=\"toggleFolding($event)\" />\n    </div>\n\n    <div\n        class=\"children-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <div class=\"children\">\n                @for (child of group().children; track child.uid) {\n                    @if (!child.hidden) {\n                        <ap-nav-selector-leaf [leaf]=\"child\" />\n                    }\n                }\n            </div>\n        }\n    </div>\n} @else {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [apTreeNodeAccessibility]=\"group()\"\n        (click)=\"toggleFolding($event)\"\n        (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n        (keydown.enter)=\"onKeydownSpaceOrEnter($event)\">\n        @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"group().uid\"\n                [checked]=\"group().selected\"\n                [disabled]=\"!group().selectable\"\n                [indeterminate]=\"group().undeterminedSelection\"\n                (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n        }\n\n        <div class=\"picture-url-sample-container\">\n            <div class=\"picture-url-sample\">\n                @for (pictureUrlSample of group().childrenPictureUrlSample; track pictureUrlSample) {\n                    <ap-avatar\n                        [size]=\"$any(12)\"\n                        [profilePicture]=\"pictureUrlSample.url ?? undefined\"\n                        [showInitials]=\"pictureUrlSample.initial\" />\n                }\n\n                <div class=\"status\">\n                    @if (group().displayCounter) {\n                        <ap-counter\n                            color=\"orange\"\n                            size=\"normal\"\n                            [notif]=\"true\"\n                            [background]=\"true\">\n                            {{ group().counter }}\n                        </ap-counter>\n                    }\n                </div>\n            </div>\n\n            <div class=\"toggle\">\n                <ap-symbol\n                    size=\"sm\"\n                    [symbolId]=\"foldSymbol()\" />\n            </div>\n        </div>\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            <div class=\"children\">\n                @for (child of group().children; track child.uid) {\n                    @if (!child.hidden) {\n                        <ap-nav-selector-leaf [leaf]=\"child\" />\n                    }\n                }\n            </div>\n        }\n    </div>\n}\n"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-group.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-group/nav-selector-group.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-group/nav-selector-group.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, apFolder, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport {\n    afterNextRender,\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    ElementRef,\n    input,\n    signal,\n    untracked,\n    viewChild,\n} from '@angular/core';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorGroup } from '../nav-selector';\nimport { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';\nimport { NavSelectorGroupPresenter } from './nav-selector-group.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-group',\n    templateUrl: './nav-selector-group.component.html',\n    styleUrls: ['./nav-selector-group.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [withSymbols(apFolder, apErrorFill, apChevronDown, apChevronUp), NavSelectorGroupPresenter],\n    imports: [\n        SymbolComponent,\n        CounterComponent,\n        NavSelectorLeafComponent,\n        CheckboxComponent,\n        AvatarComponent,\n        TooltipDirective,\n        TreeNodeAccessibilityDirective,\n    ],\n    host: {\n        '[class.minified]': '!navSelectorGroupPresenter.expanded()',\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({ maxHeight: '{{maxHeight}}', overflow: 'hidden' })),\n            ]),\n            transition('expanded => collapsed', [\n                animate(\n                    '250ms cubic-bezier(.4, 0, .3, 1)',\n                    keyframes([style({ maxHeight: '{{maxHeight}}', overflow: 'hidden' }), style({ maxHeight: 0, overflow: 'hidden' })])\n                ),\n            ]),\n        ]),\n    ],\n})\nexport class NavSelectorGroupComponent {\n    group = input.required<InternalNavSelectorGroup>();\n\n    foldSymbol = computed(() => (this.group().folded ? 'chevron-down' : 'chevron-up'));\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.navSelectorGroupPresenter.expanded() || el.offsetWidth < el.scrollWidth || el.offsetHeight < el.scrollHeight) {\n            content.push(this.group().alias);\n        }\n\n        if (this.group().displayTokenInvalid) {\n            content.push(this.navSelectorGroupPresenter.texts().tokenInvalid);\n        }\n\n        return content.join('<br>');\n    });\n    tooltipDisabled = computed(() => !this.tooltipContent().length);\n\n    foldedWithDelay = signal(false);\n\n    animationState = computed(() => (this.group().folded ? 'collapsed' : 'expanded'));\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorGroupPresenter: NavSelectorGroupPresenter\n    ) {\n        afterNextRender(() => {\n            this.maxHeight.set(`${this.el.nativeElement.clientHeight * this.group().children.length}px`);\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            const folded = this.group().folded;\n            untracked(() => {\n                if (folded) {\n                    setTimeout(() => this.foldedWithDelay.set(true), 150);\n                } else {\n                    this.foldedWithDelay.set(false);\n                }\n            });\n        });\n    }\n\n    maxHeight = signal('0px');\n\n    onKeydownSpaceOrEnter(event: Event) {\n        // Prevent to toggle folding when focus is on the checkbox\n        if (document.activeElement === this.el.nativeElement.querySelector('.content')) {\n            this.toggleFolding(event);\n        } else {\n            this.navSelectorGroupPresenter.onGroupSelected(this.group());\n        }\n    }\n\n    toggleFolding(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorGroupPresenter.onGroupToggleFolding(this.group());\n    }\n\n    fold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorGroupPresenter.fold(this.group());\n    }\n\n    unfold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorGroupPresenter.unfold(this.group());\n    }\n}\n","@if (navSelectorGroupPresenter.expandedAfterDelay()) {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [apTreeNodeAccessibility]=\"group()\"\n        (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n        (keydown.enter)=\"onKeydownSpaceOrEnter($event)\"\n        (click)=\"toggleFolding($event)\">\n        @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"group().uid\"\n                [checked]=\"group().selected\"\n                [disabled]=\"!group().selectable\"\n                [indeterminate]=\"group().undeterminedSelection\"\n                (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n        }\n\n        <ap-symbol\n            symbolId=\"folder\"\n            size=\"sm\" />\n\n        <span\n            #alias\n            class=\"caption\">\n            {{ group().alias }}\n        </span>\n\n        @if (group().displayTokenInvalid) {\n            <ap-symbol\n                symbolId=\"error_fill\"\n                size=\"sm\" />\n        }\n\n        @if (group().displayCounter) {\n            <ap-counter\n                color=\"orange\"\n                size=\"normal\"\n                [background]=\"false\">\n                {{ group().counter }}\n            </ap-counter>\n        }\n\n        <ap-symbol\n            size=\"sm\"\n            class=\"folding-button\"\n            [symbolId]=\"foldSymbol()\" />\n    </div>\n\n    <div\n        class=\"children-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <div class=\"children\">\n                @for (child of group().children; track child.uid) {\n                    @if (!child.hidden) {\n                        <ap-nav-selector-leaf [leaf]=\"child\" />\n                    }\n                }\n            </div>\n        }\n    </div>\n} @else {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [class.token-invalid]=\"group().displayTokenInvalid\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [apTreeNodeAccessibility]=\"group()\"\n        (click)=\"toggleFolding($event)\"\n        (keydown.space)=\"onKeydownSpaceOrEnter($event)\"\n        (keydown.enter)=\"onKeydownSpaceOrEnter($event)\">\n        @if (navSelectorGroupPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"group().uid\"\n                [checked]=\"group().selected\"\n                [disabled]=\"!group().selectable\"\n                [indeterminate]=\"group().undeterminedSelection\"\n                (change)=\"navSelectorGroupPresenter.onGroupSelected(group())\" />\n        }\n\n        <div class=\"picture-url-sample-container\">\n            <div class=\"picture-url-sample\">\n                @for (pictureUrlSample of group().childrenPictureUrlSample; track pictureUrlSample) {\n                    <ap-avatar\n                        class=\"avatar-sample\"\n                        [size]=\"16\"\n                        [profilePicture]=\"pictureUrlSample.url ?? undefined\"\n                        [showInitials]=\"pictureUrlSample.initial\" />\n                }\n\n                <div class=\"status\">\n                    @if (group().displayCounter) {\n                        <ap-counter\n                            class=\"counter-override\"\n                            color=\"orange\"\n                            size=\"normal\"\n                            [notif]=\"true\"\n                            [background]=\"true\">\n                            {{ group().counter }}\n                        </ap-counter>\n                    }\n                </div>\n            </div>\n\n            <div class=\"toggle\">\n                <ap-symbol\n                    size=\"sm\"\n                    [symbolId]=\"foldSymbol()\" />\n            </div>\n        </div>\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            <div class=\"children\">\n                @for (child of group().children; track child.uid) {\n                    @if (!child.hidden) {\n                        <ap-nav-selector-leaf [leaf]=\"child\" />\n                    }\n                }\n            </div>\n        }\n    </div>\n}\n"]}
|