@agorapulse/ui-components 18.0.36 → 18.0.38
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.38.tgz +0 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +17 -6
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +17 -6
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +15 -6
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.mjs +3 -3
- package/esm2022/nav-selector/nav-selector.component.mjs +3 -3
- package/esm2022/nav-selector/utils/leaf.utils.mjs +16 -1
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs +61 -17
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -1
- package/nav-selector/nav-selector-category/nav-selector-category.component.d.ts +1 -0
- package/nav-selector/nav-selector-group/nav-selector-group.component.d.ts +1 -0
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.component.d.ts +1 -0
- package/nav-selector/utils/leaf.utils.d.ts +1 -0
- package/package.json +7 -7
- package/agorapulse-ui-components-18.0.36.tgz +0 -0
|
Binary file
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { TooltipDirective } from '@agorapulse/ui-components/tooltip';
|
|
2
2
|
import { apChevronDown, apChevronUp, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';
|
|
3
3
|
import { animate, keyframes, state, style, transition, trigger } from '@angular/animations';
|
|
4
|
-
import {
|
|
4
|
+
import { afterRender, ChangeDetectionStrategy, Component, computed, effect, input, output, signal, untracked, viewChild, } from '@angular/core';
|
|
5
5
|
import { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';
|
|
6
6
|
import { NavSelectorGroupComponent } from '../nav-selector-group/nav-selector-group.component';
|
|
7
7
|
import { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';
|
|
8
|
+
import { computeNumberOfDisplayableChildrenOnUnfold } from '../utils/leaf.utils';
|
|
8
9
|
import { NavSelectorCategoryPresenter } from './nav-selector-category.presenter';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
import * as i1 from "./nav-selector-category.presenter";
|
|
@@ -34,11 +35,13 @@ export class NavSelectorCategoryComponent {
|
|
|
34
35
|
constructor(el, navSelectorCategoryPresenter) {
|
|
35
36
|
this.el = el;
|
|
36
37
|
this.navSelectorCategoryPresenter = navSelectorCategoryPresenter;
|
|
37
|
-
|
|
38
|
-
|
|
38
|
+
afterRender(() => untracked(() => {
|
|
39
|
+
const maxHeight = this.computeMaxHeight();
|
|
40
|
+
if (this.maxHeight() !== maxHeight) {
|
|
41
|
+
this.maxHeight.set(maxHeight);
|
|
42
|
+
}
|
|
39
43
|
this.updateAliasBoundedClientRect();
|
|
40
|
-
});
|
|
41
|
-
afterRender(() => untracked(() => this.updateAliasBoundedClientRect()));
|
|
44
|
+
}));
|
|
42
45
|
effect(() => {
|
|
43
46
|
const folded = this.category().folded;
|
|
44
47
|
untracked(() => {
|
|
@@ -52,6 +55,14 @@ export class NavSelectorCategoryComponent {
|
|
|
52
55
|
});
|
|
53
56
|
}
|
|
54
57
|
maxHeight = signal('0px');
|
|
58
|
+
computeMaxHeight() {
|
|
59
|
+
let maxHeight = this.el.nativeElement.clientHeight;
|
|
60
|
+
if (this.category().folded) {
|
|
61
|
+
const numberOfDisplayableChildren = computeNumberOfDisplayableChildrenOnUnfold(this.category());
|
|
62
|
+
maxHeight = this.el.nativeElement.clientHeight * numberOfDisplayableChildren;
|
|
63
|
+
}
|
|
64
|
+
return `${maxHeight}px`;
|
|
65
|
+
}
|
|
55
66
|
updateAliasBoundedClientRect() {
|
|
56
67
|
const el = this.aliasEl()?.nativeElement;
|
|
57
68
|
if (el) {
|
|
@@ -115,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
115
126
|
]),
|
|
116
127
|
], template: "@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\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\n #alias\n class=\"caption\">\n {{ category().alias }}\n </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 <div\n class=\"entry\"\n [class.folder]=\"child.type === 'GROUP'\">\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf\n [leaf]=\"child\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group\n [group]=\"child\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n }\n </div>\n }\n }\n </div>\n }\n </div>\n} @else {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [apTreeNodeAccessibility]=\"category()\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\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 </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 <div\n class=\"entry\"\n [class.folder]=\"child.type === 'GROUP'\">\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf\n [leaf]=\"child\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group\n [group]=\"child\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n }\n </div>\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-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=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host .caption{-webkit-box-orient:vertical;-webkit-line-clamp:1;flex:1 0 0;overflow:hidden;white-space:nowrap;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 .children .entry{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch;margin-left:calc(-1 * var(--ref-spacing-xxs));margin-right:calc(-1 * var(--ref-spacing-xxs))}:host .children .entry.folder{padding:var(--ref-spacing-xxs);border-bottom:1px solid var(--sys-border-color-default)}:host .children .entry.folder+.entry:not(.folder){padding-top:var(--ref-spacing-xxs)}:host .children .entry.folder:first-child{padding-top:0}:host .children .entry.folder:last-child{border-bottom:none;padding-bottom:0}:host .children .entry:not(.folder){padding-left:var(--ref-spacing-xxs);padding-right:var(--ref-spacing-xxs)}:host .children .entry:not(.folder):first-child:not(:last-child){padding-top:var(--ref-spacing-xxs)}:host .children .entry:not(.folder):last-child:not(:first-child){padding-bottom:var(--ref-spacing-xxs);border-bottom:none}:host .children .entry:not(.folder):has(+.entry.folder){padding-bottom:var(--ref-spacing-xxs)}:host .children .entry:not(.folder)+.entry.folder{border-top:1px solid var(--sys-border-color-default)}:host.minified .name-container{overflow:hidden;display:flex}:host.minified .name-container span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;display:inline-block}:host.minified .caption{white-space:nowrap}:host.minified .content{position:relative}:host.minified .content .toggle{position:absolute;display:none}:host.minified .content:hover .toggle,:host.minified .content:focus-visible .toggle{inset:0;display:flex;justify-content:center;align-items:center}:host.minified .content:hover .name-container,:host.minified .content:focus-visible .name-container{display:none}\n"] }]
|
|
117
128
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NavSelectorCategoryPresenter }] });
|
|
118
|
-
//# 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 { TooltipDirective } from '@agorapulse/ui-components/tooltip';\nimport { apChevronDown, apChevronUp, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport {\n    afterNextRender,\n    afterRender,\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    ElementRef,\n    input,\n    output,\n    signal,\n    untracked,\n    viewChild,\n} from '@angular/core';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorCategory, NavSelectorLeafActionClickedEvent } 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, TreeNodeAccessibilityDirective, TooltipDirective],\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    actionClicked = output<NavSelectorLeafActionClickedEvent>();\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    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 el = this.aliasBoundedClientRect();\n        if (!this.navSelectorCategoryPresenter.expanded() || el.offsetWidth < el.scrollWidth || el.offsetHeight < el.scrollHeight) {\n            return this.category().alias;\n        }\n\n        return '';\n    });\n    tooltipDisabled = computed(() => !this.tooltipContent().length);\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorCategoryPresenter: NavSelectorCategoryPresenter\n    ) {\n        afterNextRender(() => {\n            this.maxHeight.set(`${this.el.nativeElement.clientHeight * this.category().children.length}px`);\n            this.updateAliasBoundedClientRect();\n        });\n\n        afterRender(() => untracked(() => this.updateAliasBoundedClientRect()));\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    private updateAliasBoundedClientRect() {\n        const el = this.aliasEl()?.nativeElement;\n        if (el) {\n            const boundedClientRect = {\n                offsetWidth: el.offsetWidth,\n                offsetHeight: el.offsetHeight,\n                scrollWidth: el.scrollWidth,\n                scrollHeight: el.scrollHeight,\n            };\n            if (JSON.stringify(this.aliasBoundedClientRect()) !== JSON.stringify(boundedClientRect)) {\n                this.aliasBoundedClientRect.set(boundedClientRect);\n            }\n        }\n    }\n}\n","@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\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\n            #alias\n            class=\"caption\">\n            {{ category().alias }}\n        </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                        <div\n                            class=\"entry\"\n                            [class.folder]=\"child.type === 'GROUP'\">\n                            @if (child.type === 'LEAF') {\n                                <ap-nav-selector-leaf\n                                    [leaf]=\"child\"\n                                    (actionClicked)=\"actionClicked.emit($event)\" />\n                            } @else if (child.type === 'GROUP') {\n                                <ap-nav-selector-group\n                                    [group]=\"child\"\n                                    (actionClicked)=\"actionClicked.emit($event)\" />\n                            }\n                        </div>\n                    }\n                }\n            </div>\n        }\n    </div>\n} @else {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [apTreeNodeAccessibility]=\"category()\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\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        </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                        <div\n                            class=\"entry\"\n                            [class.folder]=\"child.type === 'GROUP'\">\n                            @if (child.type === 'LEAF') {\n                                <ap-nav-selector-leaf\n                                    [leaf]=\"child\"\n                                    (actionClicked)=\"actionClicked.emit($event)\" />\n                            } @else if (child.type === 'GROUP') {\n                                <ap-nav-selector-group\n                                    [group]=\"child\"\n                                    (actionClicked)=\"actionClicked.emit($event)\" />\n                            }\n                        </div>\n                    }\n                }\n            </div>\n        }\n    </div>\n}\n"]}
|
|
129
|
+
//# 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 { TooltipDirective } from '@agorapulse/ui-components/tooltip';\nimport { apChevronDown, apChevronUp, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport {\n    afterRender,\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    ElementRef,\n    input,\n    output,\n    signal,\n    untracked,\n    viewChild,\n} from '@angular/core';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorCategory, NavSelectorLeafActionClickedEvent } from '../nav-selector';\nimport { NavSelectorGroupComponent } from '../nav-selector-group/nav-selector-group.component';\nimport { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';\nimport { computeNumberOfDisplayableChildrenOnUnfold } from '../utils/leaf.utils';\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, TreeNodeAccessibilityDirective, TooltipDirective],\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    actionClicked = output<NavSelectorLeafActionClickedEvent>();\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    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 el = this.aliasBoundedClientRect();\n        if (!this.navSelectorCategoryPresenter.expanded() || el.offsetWidth < el.scrollWidth || el.offsetHeight < el.scrollHeight) {\n            return this.category().alias;\n        }\n\n        return '';\n    });\n    tooltipDisabled = computed(() => !this.tooltipContent().length);\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorCategoryPresenter: NavSelectorCategoryPresenter\n    ) {\n        afterRender(() =>\n            untracked(() => {\n                const maxHeight = this.computeMaxHeight();\n                if (this.maxHeight() !== maxHeight) {\n                    this.maxHeight.set(maxHeight);\n                }\n                this.updateAliasBoundedClientRect();\n            })\n        );\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    private computeMaxHeight() {\n        let maxHeight = this.el.nativeElement.clientHeight;\n        if (this.category().folded) {\n            const numberOfDisplayableChildren = computeNumberOfDisplayableChildrenOnUnfold(this.category());\n            maxHeight = this.el.nativeElement.clientHeight * numberOfDisplayableChildren;\n        }\n        return `${maxHeight}px`;\n    }\n\n    private updateAliasBoundedClientRect() {\n        const el = this.aliasEl()?.nativeElement;\n        if (el) {\n            const boundedClientRect = {\n                offsetWidth: el.offsetWidth,\n                offsetHeight: el.offsetHeight,\n                scrollWidth: el.scrollWidth,\n                scrollHeight: el.scrollHeight,\n            };\n            if (JSON.stringify(this.aliasBoundedClientRect()) !== JSON.stringify(boundedClientRect)) {\n                this.aliasBoundedClientRect.set(boundedClientRect);\n            }\n        }\n    }\n}\n","@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\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\n            #alias\n            class=\"caption\">\n            {{ category().alias }}\n        </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                        <div\n                            class=\"entry\"\n                            [class.folder]=\"child.type === 'GROUP'\">\n                            @if (child.type === 'LEAF') {\n                                <ap-nav-selector-leaf\n                                    [leaf]=\"child\"\n                                    (actionClicked)=\"actionClicked.emit($event)\" />\n                            } @else if (child.type === 'GROUP') {\n                                <ap-nav-selector-group\n                                    [group]=\"child\"\n                                    (actionClicked)=\"actionClicked.emit($event)\" />\n                            }\n                        </div>\n                    }\n                }\n            </div>\n        }\n    </div>\n} @else {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [apTreeNodeAccessibility]=\"category()\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\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        </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                        <div\n                            class=\"entry\"\n                            [class.folder]=\"child.type === 'GROUP'\">\n                            @if (child.type === 'LEAF') {\n                                <ap-nav-selector-leaf\n                                    [leaf]=\"child\"\n                                    (actionClicked)=\"actionClicked.emit($event)\" />\n                            } @else if (child.type === 'GROUP') {\n                                <ap-nav-selector-group\n                                    [group]=\"child\"\n                                    (actionClicked)=\"actionClicked.emit($event)\" />\n                            }\n                        </div>\n                    }\n                }\n            </div>\n        }\n    </div>\n}\n"]}
|
|
@@ -4,9 +4,10 @@ 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 {
|
|
7
|
+
import { afterRender, ChangeDetectionStrategy, Component, computed, effect, input, output, 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
|
+
import { computeNumberOfDisplayableChildrenOnUnfold } from '../utils/leaf.utils';
|
|
10
11
|
import { NavSelectorGroupPresenter } from './nav-selector-group.presenter';
|
|
11
12
|
import * as i0 from "@angular/core";
|
|
12
13
|
import * as i1 from "./nav-selector-group.presenter";
|
|
@@ -40,11 +41,13 @@ export class NavSelectorGroupComponent {
|
|
|
40
41
|
constructor(el, navSelectorGroupPresenter) {
|
|
41
42
|
this.el = el;
|
|
42
43
|
this.navSelectorGroupPresenter = navSelectorGroupPresenter;
|
|
43
|
-
|
|
44
|
-
|
|
44
|
+
afterRender(() => untracked(() => {
|
|
45
|
+
const maxHeight = this.computeMaxHeight();
|
|
46
|
+
if (this.maxHeight() !== maxHeight) {
|
|
47
|
+
this.maxHeight.set(maxHeight);
|
|
48
|
+
}
|
|
45
49
|
this.updateAliasBoundedClientRect();
|
|
46
|
-
});
|
|
47
|
-
afterRender(() => untracked(() => this.updateAliasBoundedClientRect()));
|
|
50
|
+
}));
|
|
48
51
|
effect(() => {
|
|
49
52
|
const folded = this.group().folded;
|
|
50
53
|
untracked(() => {
|
|
@@ -89,6 +92,14 @@ export class NavSelectorGroupComponent {
|
|
|
89
92
|
event.stopImmediatePropagation();
|
|
90
93
|
this.navSelectorGroupPresenter.unfold(this.group());
|
|
91
94
|
}
|
|
95
|
+
computeMaxHeight() {
|
|
96
|
+
let maxHeight = this.el.nativeElement.clientHeight;
|
|
97
|
+
if (this.group().folded) {
|
|
98
|
+
const numberOfDisplayableChildren = computeNumberOfDisplayableChildrenOnUnfold(this.group());
|
|
99
|
+
maxHeight = this.el.nativeElement.clientHeight * numberOfDisplayableChildren;
|
|
100
|
+
}
|
|
101
|
+
return `${maxHeight}px`;
|
|
102
|
+
}
|
|
92
103
|
updateAliasBoundedClientRect() {
|
|
93
104
|
const el = this.aliasEl()?.nativeElement;
|
|
94
105
|
if (el) {
|
|
@@ -160,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
160
171
|
]),
|
|
161
172
|
], 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 (click)=\"eventStopper($event)\"\n (change)=\"onGroupSelected()\" />\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\n [leaf]=\"child\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n }\n }\n </div>\n }\n </div>\n} @else {\n <div\n class=\"content\"\n apTooltipPosition=\"right\"\n [class.token-invalid]=\"group().displayTokenInvalid\"\n [class.multiple-mode]=\"navSelectorGroupPresenter.isMultipleModeEnabled()\"\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 (click)=\"eventStopper($event)\"\n (change)=\"onGroupSelected()\" />\n }\n\n <div class=\"picture-url-sample-container\">\n <div class=\"picture-url-sample\">\n <div class=\"avatars\">\n @for (pictureUrlSample of group().childrenPictureUrlSample; track pictureUrlSample) {\n <ap-avatar\n class=\"avatar-sample\"\n [size]=\"24\"\n [profilePicture]=\"pictureUrlSample.url ?? undefined\"\n [showInitials]=\"pictureUrlSample.initial\" />\n }\n </div>\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=\"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\n [leaf]=\"child\"\n (actionClicked)=\"actionClicked.emit($event)\" />\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{-webkit-box-orient:vertical;-webkit-line-clamp:1;flex:1 0 0;overflow:hidden;white-space:nowrap;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}:host .avatars{display:flex;width:24px;height:24px;transform:scale(.5);gap:var(--ref-spacing-xxxs);align-content:center;justify-content:center}:host .avatars:has(:nth-child(3)){display:grid;grid-template-columns:1fr 1fr}:host.minified .content{gap:var(--ref-spacing-xxxs);padding:var(--ref-spacing-xxxs);position:relative}:host.minified .content:not(.multiple-mode){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;background-color:var(--ref-color-white);border-radius:100%}\n"] }]
|
|
162
173
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NavSelectorGroupPresenter }] });
|
|
163
|
-
//# 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    afterRender,\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    ElementRef,\n    input,\n    output,\n    signal,\n    untracked,\n    viewChild,\n} from '@angular/core';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorGroup, NavSelectorLeafActionClickedEvent } 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    actionClicked = output<NavSelectorLeafActionClickedEvent>();\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().groupTokenInvalid);\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            this.updateAliasBoundedClientRect();\n        });\n\n        afterRender(() => untracked(() => this.updateAliasBoundedClientRect()));\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        event.stopImmediatePropagation();\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    onGroupSelected() {\n        this.navSelectorGroupPresenter.onGroupSelected(this.group());\n    }\n\n    /**\n     * For checkboxes, as they do not stop event propagation, we need to stop it manually\n     */\n    eventStopper(event: Event) {\n        event.stopImmediatePropagation();\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    private updateAliasBoundedClientRect() {\n        const el = this.aliasEl()?.nativeElement;\n        if (el) {\n            const boundedClientRect = {\n                offsetWidth: el.offsetWidth,\n                offsetHeight: el.offsetHeight,\n                scrollWidth: el.scrollWidth,\n                scrollHeight: el.scrollHeight,\n            };\n            if (JSON.stringify(this.aliasBoundedClientRect()) !== JSON.stringify(boundedClientRect)) {\n                this.aliasBoundedClientRect.set(boundedClientRect);\n            }\n        }\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                (click)=\"eventStopper($event)\"\n                (change)=\"onGroupSelected()\" />\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\n                            [leaf]=\"child\"\n                            (actionClicked)=\"actionClicked.emit($event)\" />\n                    }\n                }\n            </div>\n        }\n    </div>\n} @else {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [class.token-invalid]=\"group().displayTokenInvalid\"\n        [class.multiple-mode]=\"navSelectorGroupPresenter.isMultipleModeEnabled()\"\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                (click)=\"eventStopper($event)\"\n                (change)=\"onGroupSelected()\" />\n        }\n\n        <div class=\"picture-url-sample-container\">\n            <div class=\"picture-url-sample\">\n                <div class=\"avatars\">\n                    @for (pictureUrlSample of group().childrenPictureUrlSample; track pictureUrlSample) {\n                        <ap-avatar\n                            class=\"avatar-sample\"\n                            [size]=\"24\"\n                            [profilePicture]=\"pictureUrlSample.url ?? undefined\"\n                            [showInitials]=\"pictureUrlSample.initial\" />\n                    }\n                </div>\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=\"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\n                            [leaf]=\"child\"\n                            (actionClicked)=\"actionClicked.emit($event)\" />\n                    }\n                }\n            </div>\n        }\n    </div>\n}\n"]}
|
|
174
|
+
//# 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":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACxH,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC5F,OAAO,EACH,WAAW,EACX,uBAAuB,EACvB,SAAS,EACT,QAAQ,EACR,MAAM,EAEN,KAAK,EACL,MAAM,EACN,MAAM,EACN,SAAS,EACT,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,8BAA8B,EAAE,MAAM,iDAAiD,CAAC;AAEjG,OAAO,EAAE,wBAAwB,EAAE,MAAM,kDAAkD,CAAC;AAC5F,OAAO,EAAE,0CAA0C,EAAE,MAAM,qBAAqB,CAAC;AACjF,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;;;AAqD3E,MAAM,OAAO,yBAAyB;IAwCtB;IACD;IAxCX,KAAK,GAAG,KAAK,CAAC,QAAQ,EAA4B,CAAC;IACnD,aAAa,GAAG,MAAM,EAAqC,CAAC;IAE5D,UAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;IAEnF,OAAO,GAAG,SAAS,CAAa,OAAO,CAAC,CAAC;IACzC,sBAAsB,GAAG,MAAM,CAK5B;QACC,WAAW,EAAE,CAAC;QACd,YAAY,EAAE,CAAC;QACf,WAAW,EAAE,CAAC;QACd,YAAY,EAAE,CAAC;KAClB,CAAC,CAAC;IAEH,cAAc,GAAG,QAAQ,CAAC,GAAG,EAAE;QAC3B,MAAM,OAAO,GAAG,EAAE,CAAC;QAEnB,MAAM,EAAE,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QACzC,IAAI,CAAC,IAAI,CAAC,yBAAyB,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,WAAW,GAAG,EAAE,CAAC,WAAW,IAAI,EAAE,CAAC,YAAY,GAAG,EAAE,CAAC,YAAY,EAAE,CAAC;YACrH,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC;QAED,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC,mBAAmB,EAAE,CAAC;YACnC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,yBAAyB,CAAC,KAAK,EAAE,CAAC,iBAAiB,CAAC,CAAC;QAC3E,CAAC;QAED,OAAO,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IACH,eAAe,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,CAAC;IAEhE,eAAe,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAEhC,cAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;IAElF,YACY,EAAc,EACf,yBAAoD;QADnD,OAAE,GAAF,EAAE,CAAY;QACf,8BAAyB,GAAzB,yBAAyB,CAA2B;QAE3D,WAAW,CAAC,GAAG,EAAE,CACb,SAAS,CAAC,GAAG,EAAE;YACX,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1C,IAAI,IAAI,CAAC,SAAS,EAAE,KAAK,SAAS,EAAE,CAAC;gBACjC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YAClC,CAAC;YACD,IAAI,CAAC,4BAA4B,EAAE,CAAC;QACxC,CAAC,CAAC,CACL,CAAC;QAEF,MAAM,CAAC,GAAG,EAAE;YACR,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC;YACnC,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;IAE1B,qBAAqB,CAAC,KAAY;QAC9B,KAAK,CAAC,wBAAwB,EAAE,CAAC;QACjC,0DAA0D;QAC1D,IAAI,QAAQ,CAAC,aAAa,KAAK,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,CAAC;YAC7E,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,yBAAyB,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QACjE,CAAC;IACL,CAAC;IAED,eAAe;QACX,IAAI,CAAC,yBAAyB,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACjE,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,KAAY;QACrB,KAAK,CAAC,wBAAwB,EAAE,CAAC;IACrC,CAAC;IAED,aAAa,CAAC,KAAY;QACtB,KAAK,CAAC,wBAAwB,EAAE,CAAC;QACjC,IAAI,CAAC,yBAAyB,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,IAAI,CAAC,KAAY;QACb,KAAK,CAAC,wBAAwB,EAAE,CAAC;QACjC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACtD,CAAC;IAED,MAAM,CAAC,KAAY;QACf,KAAK,CAAC,wBAAwB,EAAE,CAAC;QACjC,IAAI,CAAC,yBAAyB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACxD,CAAC;IAEO,gBAAgB;QACpB,IAAI,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC;QACnD,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,CAAC;YACtB,MAAM,2BAA2B,GAAG,0CAA0C,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;YAC7F,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,YAAY,GAAG,2BAA2B,CAAC;QACjF,CAAC;QACD,OAAO,GAAG,SAAS,IAAI,CAAC;IAC5B,CAAC;IAEO,4BAA4B;QAChC,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,CAAC;QACzC,IAAI,EAAE,EAAE,CAAC;YACL,MAAM,iBAAiB,GAAG;gBACtB,WAAW,EAAE,EAAE,CAAC,WAAW;gBAC3B,YAAY,EAAE,EAAE,CAAC,YAAY;gBAC7B,WAAW,EAAE,EAAE,CAAC,WAAW;gBAC3B,YAAY,EAAE,EAAE,CAAC,YAAY;aAChC,CAAC;YACF,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,EAAE,CAAC;gBACtF,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;YACvD,CAAC;QACL,CAAC;IACL,CAAC;uGA7HQ,yBAAyB;2FAAzB,yBAAyB,qaA7CvB,CAAC,WAAW,CAAC,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE,WAAW,CAAC,EAAE,yBAAyB,CAAC,4IC/B1G,+iKAoJA,+vFDnHQ,eAAe,sHACf,gBAAgB,iHAChB,wBAAwB,+GACxB,iBAAiB,wMACjB,eAAe,6MACf,gBAAgB,qRAChB,8BAA8B,6FAOtB;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,SAAS,EAAE,eAAe,EAAE,QAAQ,EAAE,QAAQ,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,QAAQ,EAAE,QAAQ,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,CACtH;iBACJ,CAAC;aACL,CAAC;SACL;;2FAEQ,yBAAyB;kBAnDrC,SAAS;+BACI,uBAAuB,cAGrB,IAAI,mBACC,uBAAuB,CAAC,MAAM,aACpC,CAAC,WAAW,CAAC,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE,WAAW,CAAC,EAAE,yBAAyB,CAAC,WAC7F;wBACL,eAAe;wBACf,gBAAgB;wBAChB,wBAAwB;wBACxB,iBAAiB;wBACjB,eAAe;wBACf,gBAAgB;wBAChB,8BAA8B;qBACjC,QACK;wBACF,kBAAkB,EAAE,uCAAuC;wBAC3D,qBAAqB,EAAE,cAAc;wBACrC,sBAAsB,EAAE,gBAAgB;qBAC3C,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,SAAS,EAAE,eAAe,EAAE,QAAQ,EAAE,QAAQ,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,QAAQ,EAAE,QAAQ,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,CACtH;6BACJ,CAAC;yBACL,CAAC;qBACL","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    afterRender,\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    ElementRef,\n    input,\n    output,\n    signal,\n    untracked,\n    viewChild,\n} from '@angular/core';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorGroup, NavSelectorLeafActionClickedEvent } from '../nav-selector';\nimport { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';\nimport { computeNumberOfDisplayableChildrenOnUnfold } from '../utils/leaf.utils';\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    actionClicked = output<NavSelectorLeafActionClickedEvent>();\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().groupTokenInvalid);\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        afterRender(() =>\n            untracked(() => {\n                const maxHeight = this.computeMaxHeight();\n                if (this.maxHeight() !== maxHeight) {\n                    this.maxHeight.set(maxHeight);\n                }\n                this.updateAliasBoundedClientRect();\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        event.stopImmediatePropagation();\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    onGroupSelected() {\n        this.navSelectorGroupPresenter.onGroupSelected(this.group());\n    }\n\n    /**\n     * For checkboxes, as they do not stop event propagation, we need to stop it manually\n     */\n    eventStopper(event: Event) {\n        event.stopImmediatePropagation();\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    private computeMaxHeight() {\n        let maxHeight = this.el.nativeElement.clientHeight;\n        if (this.group().folded) {\n            const numberOfDisplayableChildren = computeNumberOfDisplayableChildrenOnUnfold(this.group());\n            maxHeight = this.el.nativeElement.clientHeight * numberOfDisplayableChildren;\n        }\n        return `${maxHeight}px`;\n    }\n\n    private updateAliasBoundedClientRect() {\n        const el = this.aliasEl()?.nativeElement;\n        if (el) {\n            const boundedClientRect = {\n                offsetWidth: el.offsetWidth,\n                offsetHeight: el.offsetHeight,\n                scrollWidth: el.scrollWidth,\n                scrollHeight: el.scrollHeight,\n            };\n            if (JSON.stringify(this.aliasBoundedClientRect()) !== JSON.stringify(boundedClientRect)) {\n                this.aliasBoundedClientRect.set(boundedClientRect);\n            }\n        }\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                (click)=\"eventStopper($event)\"\n                (change)=\"onGroupSelected()\" />\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\n                            [leaf]=\"child\"\n                            (actionClicked)=\"actionClicked.emit($event)\" />\n                    }\n                }\n            </div>\n        }\n    </div>\n} @else {\n    <div\n        class=\"content\"\n        apTooltipPosition=\"right\"\n        [class.token-invalid]=\"group().displayTokenInvalid\"\n        [class.multiple-mode]=\"navSelectorGroupPresenter.isMultipleModeEnabled()\"\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                (click)=\"eventStopper($event)\"\n                (change)=\"onGroupSelected()\" />\n        }\n\n        <div class=\"picture-url-sample-container\">\n            <div class=\"picture-url-sample\">\n                <div class=\"avatars\">\n                    @for (pictureUrlSample of group().childrenPictureUrlSample; track pictureUrlSample) {\n                        <ap-avatar\n                            class=\"avatar-sample\"\n                            [size]=\"24\"\n                            [profilePicture]=\"pictureUrlSample.url ?? undefined\"\n                            [showInitials]=\"pictureUrlSample.initial\" />\n                    }\n                </div>\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=\"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\n                            [leaf]=\"child\"\n                            (actionClicked)=\"actionClicked.emit($event)\" />\n                    }\n                }\n            </div>\n        }\n    </div>\n}\n"]}
|
|
@@ -5,7 +5,7 @@ import { TooltipDirective } from '@agorapulse/ui-components/tooltip';
|
|
|
5
5
|
import { apChevronDown, apChevronUp, apErrorFill, apFeatureLock, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';
|
|
6
6
|
import { apMore } from '@agorapulse/ui-symbol/icons';
|
|
7
7
|
import { animate, keyframes, state, style, transition, trigger } from '@angular/animations';
|
|
8
|
-
import {
|
|
8
|
+
import { afterRender, ChangeDetectionStrategy, Component, computed, effect, input, output, signal, untracked, viewChild, } from '@angular/core';
|
|
9
9
|
import { NavSelectorPopoverTriggerDirective } from '../directives/nav-selector-popover-trigger.directive';
|
|
10
10
|
import { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';
|
|
11
11
|
import { NavSelectorLeafActionComponent } from '../nav-selector-leaf-action/nav-selector-leaf-action.component';
|
|
@@ -55,11 +55,13 @@ export class NavSelectorLeafComponent {
|
|
|
55
55
|
constructor(el, navSelectorLeafPresenter) {
|
|
56
56
|
this.el = el;
|
|
57
57
|
this.navSelectorLeafPresenter = navSelectorLeafPresenter;
|
|
58
|
-
|
|
59
|
-
|
|
58
|
+
afterRender(() => untracked(() => {
|
|
59
|
+
const newMaxHeight = this.computeMaxHeight();
|
|
60
|
+
if (this.maxHeight() !== newMaxHeight) {
|
|
61
|
+
this.maxHeight.set(newMaxHeight);
|
|
62
|
+
}
|
|
60
63
|
this.updateAliasBoundedClientRect();
|
|
61
|
-
});
|
|
62
|
-
afterRender(() => untracked(() => this.updateAliasBoundedClientRect()));
|
|
64
|
+
}));
|
|
63
65
|
effect(() => {
|
|
64
66
|
const folded = this.leaf().folded;
|
|
65
67
|
untracked(() => {
|
|
@@ -141,6 +143,13 @@ export class NavSelectorLeafComponent {
|
|
|
141
143
|
actionName: action.name,
|
|
142
144
|
});
|
|
143
145
|
}
|
|
146
|
+
computeMaxHeight() {
|
|
147
|
+
let maxHeight = this.el.nativeElement.clientHeight;
|
|
148
|
+
if (this.leaf().folded) {
|
|
149
|
+
maxHeight = this.el.nativeElement.clientHeight * this.leaf().details.length;
|
|
150
|
+
}
|
|
151
|
+
return `${maxHeight}px`;
|
|
152
|
+
}
|
|
144
153
|
updateAliasBoundedClientRect() {
|
|
145
154
|
const el = this.aliasEl()?.nativeElement;
|
|
146
155
|
if (el) {
|
|
@@ -219,4 +228,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
219
228
|
]),
|
|
220
229
|
], template: "@if (navSelectorLeafPresenter.expandedAfterDelay()) {\n <div\n class=\"nav-selector-leaf\"\n apTooltipPosition=\"right\"\n [attr.aria-selected]=\"leaf().selected\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [class.multiple-mode]=\"navSelectorLeafPresenter.isMultipleModeEnabled()\"\n [class.feature-locked]=\"leaf().displayFeatureLocked\"\n [class.selected]=\"leaf().selected\"\n [class.token-error]=\"leaf().displayTokenInvalid\"\n [class.disabled]=\"leaf().disabled\"\n [class.detail-selected]=\"leaf().detailSelected\"\n [class.actions-displayable]=\"leaf().actionsDisplayable && leaf().detailsDisplayable\"\n [class.details-displayable]=\"leaf().detailsDisplayable\"\n [apTreeNodeAccessibility]=\"leaf()\"\n (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n (focusin)=\"focused.set(true)\"\n (focusout)=\"focused.set(false)\"\n (click)=\"onClick($event)\">\n @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"leaf().uid\"\n [checked]=\"leaf().selected\"\n [aria-label]=\"leaf().alias\"\n [disabled]=\"!leaf().selectable\"\n (click)=\"eventStopper($event)\"\n (change)=\"onCheckboxToggle()\" />\n }\n <ap-avatar\n size=\"24\"\n [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n [network]=\"$any(leaf().network)\"\n [showInitials]=\"initial()\" />\n\n <span\n #alias\n class=\"caption\">\n {{ leaf().alias }}\n </span>\n\n <a\n class=\"standalone only-button\"\n role=\"button\"\n [attr.aria-label]=\"'Select only ' + leaf().alias\"\n [attr.tabindex]=\"leaf().accessibility.tabIndex\"\n (keydown.space)=\"selectOnly($event)\"\n (keydown.enter)=\"selectOnly($event)\"\n (click)=\"clickOnSelectOnly($event)\">\n {{ navSelectorLeafPresenter.texts().only }}\n </a>\n\n @if (leaf().actionsDisplayable) {\n <ap-symbol\n class=\"actions-menu\"\n size=\"sm\"\n symbolId=\"more\"\n [tabindex]=\"leaf().accessibility.tabIndex\"\n [attr.aria-label]=\"'Action menu ' + leaf().alias\"\n [apNavSelectorPopoverTrigger]=\"popover\"\n [apNavSelectorPopoverTriggerMode]=\"{ click: true, keyboard: ['Space', 'Enter'] }\" />\n\n <ap-nav-selector-popover\n #popover\n placement=\"bottom_start\">\n @for (action of leaf().actions; track action) {\n <ap-nav-selector-popover-item\n item\n [id]=\"action.id\"\n [locked]=\"action.status === 'locked'\"\n [disabled]=\"action.status === 'disabled'\"\n [name]=\"action.name\"\n (click)=\"onActionClicked(action)\">\n <ap-nav-selector-leaf-action [action]=\"action\" />\n </ap-nav-selector-popover-item>\n }\n </ap-nav-selector-popover>\n }\n\n @if (leaf().foldable) {\n <ap-symbol\n class=\"folding-button\"\n size=\"sm\"\n role=\"button\"\n [tabindex]=\"leaf().accessibility.tabIndex\"\n [attr.aria-label]=\"'Toggle ' + leaf().alias\"\n [symbolId]=\"foldSymbol()\"\n (click)=\"clickOnToggleFolding($event)\"\n (keydown.space)=\"toggleFolding($event)\"\n (keydown.enter)=\"toggleFolding($event)\" />\n }\n @if (leaf().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ leaf().counter }}\n </ap-counter>\n }\n @if (leaf().displayTokenInvalid) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n }\n @if (leaf().displayFeatureLocked) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"feature-lock\" />\n }\n </div>\n\n <div\n class=\"details-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <ap-nav-selector-leaf-details\n [details]=\"leaf().details\"\n [leaf]=\"leaf()\" />\n }\n </div>\n} @else {\n <div\n #minified\n class=\"nav-selector-leaf\"\n apTooltipPosition=\"right\"\n [apNavSelectorPopoverTrigger]=\"minifiedPopover\"\n [apNavSelectorPopoverDisabled]=\"!leaf().detailsDisplayable\"\n [apNavSelectorPopoverTriggerMode]=\"{ click: false, hover: true }\"\n [class.feature-locked]=\"leaf().displayFeatureLocked\"\n [class.selected]=\"leaf().selected || leaf().detailSelected\"\n [class.token-error]=\"leaf().displayTokenInvalid\"\n [class.multiple-mode]=\"navSelectorLeafPresenter.isMultipleModeEnabled()\"\n [class.disabled]=\"leaf().disabled\"\n [apTooltip]=\"tooltipContent()\"\n [apTooltipDisabled]=\"tooltipDisabled()\"\n [apTreeNodeAccessibility]=\"leaf()\"\n (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n (click)=\"onClick($event)\">\n @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n <ap-checkbox\n [name]=\"leaf().uid\"\n [checked]=\"leaf().selected\"\n [disabled]=\"!leaf().selectable\" />\n }\n\n <div class=\"avatar-container\">\n <ap-avatar\n size=\"24\"\n [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n [network]=\"$any(leaf().network)\"\n [showInitials]=\"initial()\" />\n\n <div class=\"status\">\n @if (leaf().displayCounter) {\n <ap-counter\n class=\"counter-override\"\n color=\"orange\"\n size=\"normal\"\n [notif]=\"true\"\n [background]=\"true\">\n {{ leaf().counter }}\n </ap-counter>\n }\n @if (leaf().displayTokenInvalid) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n }\n @if (leaf().displayFeatureLocked) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"feature-lock\" />\n }\n </div>\n </div>\n\n <ap-nav-selector-popover\n #minifiedPopover\n placement=\"right\"\n [popoverTitle]=\"leaf().alias\"\n [offset]=\"{ mainAxis: 0, crossAxis: -36.5 }\">\n @for (detail of leaf().details; track detail.uid) {\n <ap-nav-selector-popover-item\n item\n [selected]=\"detail.selected\"\n [disabled]=\"detail.displayError\"\n [name]=\"detail.alias\"\n (click)=\"onDetailClicked($event, detail)\">\n <ap-nav-selector-leaf-detail\n [embedded]=\"true\"\n [detail]=\"detail\" />\n </ap-nav-selector-popover-item>\n }\n </ap-nav-selector-popover>\n </div>\n}\n", styles: [":host{display:flex;flex-shrink:0;align-self:stretch;flex-direction:column}:host .details-container{align-self:stretch}:host .nav-selector-leaf{position:relative;display:flex;padding:0 var(--ref-spacing-xxs);height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch}:host .nav-selector-leaf ::ng-deep ap-checkbox .checkbox .checkbox-container{padding:0}:host .caption{-webkit-box-orient:vertical;-webkit-line-clamp:1;flex:1 0 0;overflow:hidden;white-space:nowrap;color:var(--ref-color-grey-100);text-overflow:ellipsis;font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-regular);line-height:var(--ref-font-line-height-xs)}:host ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host ap-symbol[symbol-id=feature-lock]{color:var(--ref-color-purple-100)}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host .folding-button,:host .actions-menu{display:none;width:24px;height:24px;justify-content:center;align-items:center;flex-shrink:0}:host .folding-button:hover,:host .actions-menu:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .folding-button:active,:host .folding-button.nav-selector-popover-trigger--active,:host .actions-menu:active,:host .actions-menu.nav-selector-popover-trigger--active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-40)}:host .folding-button:focus-visible,:host .actions-menu:focus-visible{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20);box-shadow:0 0 0 1px #fff,0 0 0 3px #178dfe}:host .nav-selector-leaf.details-displayable{cursor:pointer}:host .nav-selector-leaf.details-displayable.detail-selected .caption{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);color:var(--ref-color-grey-100)}:host .nav-selector-leaf.details-displayable: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 .nav-selector-leaf.details-displayable:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .nav-selector-leaf.details-displayable:focus-within:not(:host .nav-selector-leaf.details-displayable.detail-selected){border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable){cursor:pointer}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable):hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable):active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable):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 .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable):focus-within{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).selected:not(.multiple-mode){border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).selected:not(.multiple-mode) .caption{color:var(--ref-color-electric-blue-150)}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).selected.multiple-mode .caption{color:var(--ref-color-grey-100)}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).selected .caption{overflow:hidden;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 .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).selected:focus-visible{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).multiple-mode:hover ap-counter,:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).multiple-mode:focus-within ap-counter,:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).multiple-mode:focus-visible ap-counter{display:none}:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).multiple-mode:hover .only-button,:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).multiple-mode:focus-within .only-button,:host .nav-selector-leaf:not(.disabled):not(.feature-locked):not(.multiple-mode.token-error):not(.details-displayable).multiple-mode:focus-visible .only-button{display:flex}:host .nav-selector-leaf.feature-locked:not(.multiple-mode){border-radius:var(--ref-border-radius-sm);outline:none;cursor:pointer}:host .nav-selector-leaf.feature-locked:not(.multiple-mode):hover{background:var(--ref-color-purple-10)}:host .nav-selector-leaf.feature-locked:not(.multiple-mode):active{background:var(--ref-color-purple-20)}:host .nav-selector-leaf.feature-locked:not(.multiple-mode):focus-visible{background:var(--ref-color-purple-10);box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-purple-100)}:host .nav-selector-leaf.feature-locked:not(.multiple-mode).selected{background:var(--ref-color-purple-20)}:host .nav-selector-leaf.feature-locked:not(.multiple-mode).selected .caption{overflow:hidden;color:var(--ref-color-purple-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 .nav-selector-leaf.feature-locked:not(.multiple-mode).selected:focus-visible{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .nav-selector-leaf.actions-displayable:not(.feature-locked):not(.disabled):not(.token-error):focus-visible .actions-menu,:host .nav-selector-leaf.actions-displayable:not(.feature-locked):not(.disabled):not(.token-error):focus-within:not(:has(ap-nav-selector-leaf-detail:focus)):not(:host .nav-selector-leaf.actions-displayable:not(.feature-locked):not(.disabled):not(.token-error):focus) .actions-menu,:host .nav-selector-leaf.actions-displayable:not(.feature-locked):not(.disabled):not(.token-error):hover .actions-menu{display:flex}:host .nav-selector-leaf.details-displayable:not(.feature-locked):not(.disabled):not(.token-error):focus-visible ap-counter,:host .nav-selector-leaf.details-displayable:not(.feature-locked):not(.disabled):not(.token-error):focus-within:not(:has(ap-nav-selector-leaf-detail:focus)):not(:host .nav-selector-leaf.details-displayable:not(.feature-locked):not(.disabled):not(.token-error):focus) ap-counter,:host .nav-selector-leaf.details-displayable:not(.feature-locked):not(.disabled):not(.token-error):hover ap-counter{display:none}:host .nav-selector-leaf.details-displayable:not(.feature-locked):not(.disabled):not(.token-error):focus-visible .folding-button,:host .nav-selector-leaf.details-displayable:not(.feature-locked):not(.disabled):not(.token-error):focus-within:not(:has(ap-nav-selector-leaf-detail:focus)):not(:host .nav-selector-leaf.details-displayable:not(.feature-locked):not(.disabled):not(.token-error):focus) .folding-button,:host .nav-selector-leaf.details-displayable:not(.feature-locked):not(.disabled):not(.token-error):hover .folding-button{display:flex}:host .nav-selector-leaf.feature-locked.multiple-mode ap-avatar,:host .nav-selector-leaf.feature-locked.multiple-mode .caption{opacity:.5}:host .nav-selector-leaf.feature-locked.multiple-mode .caption{color:var(--ref-color-grey-40)}:host .nav-selector-leaf.token-error.multiple-mode ap-avatar,:host .nav-selector-leaf.token-error.multiple-mode .caption{opacity:.5}:host .nav-selector-leaf.token-error.multiple-mode .caption{color:var(--ref-color-grey-40)}:host .nav-selector-leaf.disabled.multiple-mode ap-avatar,:host .nav-selector-leaf.disabled.multiple-mode .caption{opacity:.5}:host .nav-selector-leaf.disabled.multiple-mode .caption{color:var(--ref-color-grey-40)}:host .nav-selector-leaf.disabled ap-avatar,:host .nav-selector-leaf.disabled .caption{opacity:.5}:host .nav-selector-leaf.disabled .caption{color:var(--ref-color-grey-40)}:host .status{position:absolute;right:-4px;top:-6px;background-color:var(--ref-color-white);border-radius:100%}:host .avatar-container{position:relative}:host.minified .counter-override{background-color:var(--ref-color-orange-150)}:host.minified .nav-selector-leaf{gap:var(--ref-spacing-xxxs);padding:var(--ref-spacing-xxxs)}:host.minified .nav-selector-leaf:not(.multiple-mode){justify-content:center}:host.minified ::ng-deep ap-checkbox .checkbox .checkbox-container{padding:0}:host .only-button{display:none;font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-xs)}::ng-deep .nav-selector-leaf-menu{position:absolute;left:55px;top:-20%;width:225px}::ng-deep .nav-selector-leaf-menu .not-displayable{display:none}::ng-deep .nav-selector-leaf-menu .caption-bold{color:var(--ref-color-grey-100);font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-xs)}\n"] }]
|
|
221
230
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NavSelectorLeafPresenter }] });
|
|
222
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-leaf.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf/nav-selector-leaf.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf/nav-selector-leaf.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AvatarComponent } from '@agorapulse/ui-components/avatar';\nimport { CheckboxComponent } from '@agorapulse/ui-components/checkbox';\nimport { CounterComponent } from '@agorapulse/ui-components/counter';\nimport { TooltipDirective } from '@agorapulse/ui-components/tooltip';\nimport { apChevronDown, apChevronUp, apErrorFill, apFeatureLock, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { apMore } from '@agorapulse/ui-symbol/icons';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport {\n    afterNextRender,\n    afterRender,\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    ElementRef,\n    input,\n    output,\n    signal,\n    untracked,\n    viewChild,\n} from '@angular/core';\nimport { NavSelectorPopoverTriggerDirective } from '../directives/nav-selector-popover-trigger.directive';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport {\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafAction,\n    InternalNavSelectorLeafDetails,\n    NavSelectorLeafActionClickedEvent,\n} from '../nav-selector';\nimport { NavSelectorLeafActionComponent } from '../nav-selector-leaf-action/nav-selector-leaf-action.component';\nimport { NavSelectorLeafDetailComponent } from '../nav-selector-leaf-detail/nav-selector-leaf-detail.component';\nimport { NavSelectorLeafDetailsComponent } from '../nav-selector-leaf-details/nav-selector-leaf-details.component';\nimport { NavSelectorPopoverItemComponent } from '../nav-selector-popover/nav-selector-popover-item.component';\nimport { NavSelectorPopoverComponent } from '../nav-selector-popover/nav-selector-popover.component';\nimport { NavSelectorLeafPresenter } from './nav-selector-leaf.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-leaf',\n    templateUrl: './nav-selector-leaf.component.html',\n    styleUrls: ['./nav-selector-leaf.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [\n        AvatarComponent,\n        CounterComponent,\n        SymbolComponent,\n        NavSelectorLeafDetailsComponent,\n        CheckboxComponent,\n        TooltipDirective,\n        NavSelectorLeafDetailComponent,\n        NavSelectorLeafDetailComponent,\n        TreeNodeAccessibilityDirective,\n        NavSelectorPopoverComponent,\n        NavSelectorPopoverTriggerDirective,\n        NavSelectorPopoverItemComponent,\n        NavSelectorLeafActionComponent,\n    ],\n    providers: [withSymbols(apErrorFill, apFeatureLock, apChevronDown, apChevronUp, apMore), NavSelectorLeafPresenter],\n    host: {\n        '[class.minified]': '!navSelectorLeafPresenter.expanded()',\n        role: 'treeitem',\n        '(keydown.arrowLeft)': 'fold($event)',\n        '(keydown.arrowRight)': 'unfold($event)',\n    },\n    animations: [\n        /**\n         * Overflow hidden is put only during the animation and on the collapsed state because if it is put on the expanded state then children’s border will be cut (hover / focus)\n         */\n        trigger('accordion', [\n            state(\n                'collapsed',\n                style({\n                    maxHeight: 0,\n                    overflow: 'hidden',\n                })\n            ),\n            state(\n                'expanded',\n                style({\n                    maxHeight: 'initial',\n                })\n            ),\n            transition('collapsed => expanded', [\n                animate('250ms cubic-bezier(.4, 0, .3, 1)', style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' })),\n            ]),\n            transition('expanded => collapsed', [\n                animate(\n                    '250ms cubic-bezier(.4, 0, .3, 1)',\n                    keyframes([style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' }), style({ maxHeight: 0 })])\n                ),\n            ]),\n        ]),\n    ],\n})\nexport class NavSelectorLeafComponent {\n    leaf = input.required<InternalNavSelectorLeaf>();\n\n    actionClicked = output<NavSelectorLeafActionClickedEvent>();\n\n    initial = computed(() => this.leaf().alias[0].toUpperCase());\n    foldSymbol = computed(() => (this.leaf().folded ? 'chevron-down' : 'chevron-up'));\n\n    focused = signal(false);\n\n    aliasEl = viewChild<ElementRef>('alias');\n    aliasBoundedClientRect = signal<{\n        offsetWidth: number;\n        offsetHeight: number;\n        scrollWidth: number;\n        scrollHeight: number;\n    }>({\n        offsetWidth: 0,\n        offsetHeight: 0,\n        scrollWidth: 0,\n        scrollHeight: 0,\n    });\n\n    tooltipContent = computed(() => {\n        const content = [];\n\n        const el = this.aliasBoundedClientRect();\n        if (!this.navSelectorLeafPresenter.expanded() || el.offsetWidth < el.scrollWidth || el.offsetHeight < el.scrollHeight) {\n            content.push(this.leaf().alias);\n        }\n\n        const disableReason = this.leaf().disableReason;\n        if (disableReason) {\n            content.push(disableReason);\n        }\n\n        if (this.leaf().displayFeatureLocked) {\n            content.push(this.navSelectorLeafPresenter.texts().featureLocked);\n        }\n\n        if (this.leaf().displayTokenInvalid) {\n            content.push(this.navSelectorLeafPresenter.texts().tokenInvalid);\n        }\n\n        return content.join('<br>');\n    });\n    tooltipDisabled = computed(() => !this.tooltipContent().length || this.leaf().detailsDisplayable);\n\n    foldedWithDelay = signal(false);\n\n    network = computed(() => (this.leaf().network ? this.leaf().network : undefined));\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorLeafPresenter: NavSelectorLeafPresenter\n    ) {\n        afterNextRender(() => {\n            this.maxHeight.set(`${this.el.nativeElement.clientHeight * this.leaf().details.length}px`);\n            this.updateAliasBoundedClientRect();\n        });\n\n        afterRender(() => untracked(() => this.updateAliasBoundedClientRect()));\n\n        effect(() => {\n            const folded = this.leaf().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    animationState = computed(() => (this.leaf().folded ? 'collapsed' : 'expanded'));\n\n    maxHeight = signal('0px');\n\n    onClick(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.selectLeaf(this.leaf());\n    }\n\n    toggleFolding(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.onLeafToggleFolding(this.leaf());\n    }\n\n    clickOnToggleFolding(event: Event) {\n        event.stopImmediatePropagation();\n        // Remove the focus from the toggle folding so we do not have the :focus-within style on the leaf\n        if (event.currentTarget && 'blur' in event.currentTarget && typeof event.currentTarget.blur === 'function') {\n            event.currentTarget.blur();\n        }\n        this.navSelectorLeafPresenter.onLeafToggleFolding(this.leaf());\n    }\n\n    selectOnly(event: Event) {\n        event.stopImmediatePropagation();\n        // (event.target as Element).blur();\n        this.navSelectorLeafPresenter.selectOnlyLeaf(this.leaf());\n    }\n\n    clickOnSelectOnly(event: Event) {\n        event.stopImmediatePropagation();\n        // Remove the focus from the select only so we do not have the :focus-within style on the leaf\n        if (event.currentTarget && 'blur' in event.currentTarget && typeof event.currentTarget.blur === 'function') {\n            event.currentTarget.blur();\n        }\n        this.navSelectorLeafPresenter.selectOnlyLeaf(this.leaf());\n    }\n\n    /**\n     * For checkboxes, as they do not stop event propagation, we need to stop it manually\n     */\n    eventStopper(event: Event) {\n        event.stopImmediatePropagation();\n    }\n\n    onCheckboxToggle() {\n        this.navSelectorLeafPresenter.selectLeaf(this.leaf());\n    }\n\n    onSpaceOrEnterPressed(event: Event) {\n        event.stopImmediatePropagation();\n        if (document.activeElement === this.el.nativeElement.querySelector('.nav-selector-leaf')) {\n            if (this.leaf().foldable) {\n                this.toggleFolding(event);\n            } else {\n                this.navSelectorLeafPresenter.selectLeaf(this.leaf());\n            }\n        }\n    }\n\n    fold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.fold(this.leaf());\n    }\n\n    unfold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.unfold(this.leaf());\n    }\n\n    onDetailClicked(event: Event, detail: InternalNavSelectorLeafDetails) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.onLeafDetailClicked(detail);\n    }\n\n    onActionClicked(action: InternalNavSelectorLeafAction) {\n        this.actionClicked.emit({\n            leafUid: this.leaf().uid,\n            actionName: action.name,\n        });\n    }\n\n    private updateAliasBoundedClientRect() {\n        const el = this.aliasEl()?.nativeElement;\n        if (el) {\n            const boundedClientRect = {\n                offsetWidth: el.offsetWidth,\n                offsetHeight: el.offsetHeight,\n                scrollWidth: el.scrollWidth,\n                scrollHeight: el.scrollHeight,\n            };\n            if (JSON.stringify(this.aliasBoundedClientRect()) !== JSON.stringify(boundedClientRect)) {\n                this.aliasBoundedClientRect.set(boundedClientRect);\n            }\n        }\n    }\n}\n","@if (navSelectorLeafPresenter.expandedAfterDelay()) {\n    <div\n        class=\"nav-selector-leaf\"\n        apTooltipPosition=\"right\"\n        [attr.aria-selected]=\"leaf().selected\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [class.multiple-mode]=\"navSelectorLeafPresenter.isMultipleModeEnabled()\"\n        [class.feature-locked]=\"leaf().displayFeatureLocked\"\n        [class.selected]=\"leaf().selected\"\n        [class.token-error]=\"leaf().displayTokenInvalid\"\n        [class.disabled]=\"leaf().disabled\"\n        [class.detail-selected]=\"leaf().detailSelected\"\n        [class.actions-displayable]=\"leaf().actionsDisplayable && leaf().detailsDisplayable\"\n        [class.details-displayable]=\"leaf().detailsDisplayable\"\n        [apTreeNodeAccessibility]=\"leaf()\"\n        (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n        (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n        (focusin)=\"focused.set(true)\"\n        (focusout)=\"focused.set(false)\"\n        (click)=\"onClick($event)\">\n        @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"leaf().uid\"\n                [checked]=\"leaf().selected\"\n                [aria-label]=\"leaf().alias\"\n                [disabled]=\"!leaf().selectable\"\n                (click)=\"eventStopper($event)\"\n                (change)=\"onCheckboxToggle()\" />\n        }\n        <ap-avatar\n            size=\"24\"\n            [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n            [network]=\"$any(leaf().network)\"\n            [showInitials]=\"initial()\" />\n\n        <span\n            #alias\n            class=\"caption\">\n            {{ leaf().alias }}\n        </span>\n\n        <a\n            class=\"standalone only-button\"\n            role=\"button\"\n            [attr.aria-label]=\"'Select only ' + leaf().alias\"\n            [attr.tabindex]=\"leaf().accessibility.tabIndex\"\n            (keydown.space)=\"selectOnly($event)\"\n            (keydown.enter)=\"selectOnly($event)\"\n            (click)=\"clickOnSelectOnly($event)\">\n            {{ navSelectorLeafPresenter.texts().only }}\n        </a>\n\n        @if (leaf().actionsDisplayable) {\n            <ap-symbol\n                class=\"actions-menu\"\n                size=\"sm\"\n                symbolId=\"more\"\n                [tabindex]=\"leaf().accessibility.tabIndex\"\n                [attr.aria-label]=\"'Action menu ' + leaf().alias\"\n                [apNavSelectorPopoverTrigger]=\"popover\"\n                [apNavSelectorPopoverTriggerMode]=\"{ click: true, keyboard: ['Space', 'Enter'] }\" />\n\n            <ap-nav-selector-popover\n                #popover\n                placement=\"bottom_start\">\n                @for (action of leaf().actions; track action) {\n                    <ap-nav-selector-popover-item\n                        item\n                        [id]=\"action.id\"\n                        [locked]=\"action.status === 'locked'\"\n                        [disabled]=\"action.status === 'disabled'\"\n                        [name]=\"action.name\"\n                        (click)=\"onActionClicked(action)\">\n                        <ap-nav-selector-leaf-action [action]=\"action\" />\n                    </ap-nav-selector-popover-item>\n                }\n            </ap-nav-selector-popover>\n        }\n\n        @if (leaf().foldable) {\n            <ap-symbol\n                class=\"folding-button\"\n                size=\"sm\"\n                role=\"button\"\n                [tabindex]=\"leaf().accessibility.tabIndex\"\n                [attr.aria-label]=\"'Toggle ' + leaf().alias\"\n                [symbolId]=\"foldSymbol()\"\n                (click)=\"clickOnToggleFolding($event)\"\n                (keydown.space)=\"toggleFolding($event)\"\n                (keydown.enter)=\"toggleFolding($event)\" />\n        }\n        @if (leaf().displayCounter) {\n            <ap-counter\n                color=\"orange\"\n                size=\"normal\"\n                [background]=\"false\">\n                {{ leaf().counter }}\n            </ap-counter>\n        }\n        @if (leaf().displayTokenInvalid) {\n            <ap-symbol\n                size=\"sm\"\n                symbolId=\"error_fill\" />\n        }\n        @if (leaf().displayFeatureLocked) {\n            <ap-symbol\n                size=\"sm\"\n                symbolId=\"feature-lock\" />\n        }\n    </div>\n\n    <div\n        class=\"details-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <ap-nav-selector-leaf-details\n                [details]=\"leaf().details\"\n                [leaf]=\"leaf()\" />\n        }\n    </div>\n} @else {\n    <div\n        #minified\n        class=\"nav-selector-leaf\"\n        apTooltipPosition=\"right\"\n        [apNavSelectorPopoverTrigger]=\"minifiedPopover\"\n        [apNavSelectorPopoverDisabled]=\"!leaf().detailsDisplayable\"\n        [apNavSelectorPopoverTriggerMode]=\"{ click: false, hover: true }\"\n        [class.feature-locked]=\"leaf().displayFeatureLocked\"\n        [class.selected]=\"leaf().selected || leaf().detailSelected\"\n        [class.token-error]=\"leaf().displayTokenInvalid\"\n        [class.multiple-mode]=\"navSelectorLeafPresenter.isMultipleModeEnabled()\"\n        [class.disabled]=\"leaf().disabled\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [apTreeNodeAccessibility]=\"leaf()\"\n        (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n        (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n        (click)=\"onClick($event)\">\n        @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"leaf().uid\"\n                [checked]=\"leaf().selected\"\n                [disabled]=\"!leaf().selectable\" />\n        }\n\n        <div class=\"avatar-container\">\n            <ap-avatar\n                size=\"24\"\n                [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n                [network]=\"$any(leaf().network)\"\n                [showInitials]=\"initial()\" />\n\n            <div class=\"status\">\n                @if (leaf().displayCounter) {\n                    <ap-counter\n                        class=\"counter-override\"\n                        color=\"orange\"\n                        size=\"normal\"\n                        [notif]=\"true\"\n                        [background]=\"true\">\n                        {{ leaf().counter }}\n                    </ap-counter>\n                }\n                @if (leaf().displayTokenInvalid) {\n                    <ap-symbol\n                        size=\"sm\"\n                        symbolId=\"error_fill\" />\n                }\n                @if (leaf().displayFeatureLocked) {\n                    <ap-symbol\n                        size=\"sm\"\n                        symbolId=\"feature-lock\" />\n                }\n            </div>\n        </div>\n\n        <ap-nav-selector-popover\n            #minifiedPopover\n            placement=\"right\"\n            [popoverTitle]=\"leaf().alias\"\n            [offset]=\"{ mainAxis: 0, crossAxis: -36.5 }\">\n            @for (detail of leaf().details; track detail.uid) {\n                <ap-nav-selector-popover-item\n                    item\n                    [selected]=\"detail.selected\"\n                    [disabled]=\"detail.displayError\"\n                    [name]=\"detail.alias\"\n                    (click)=\"onDetailClicked($event, detail)\">\n                    <ap-nav-selector-leaf-detail\n                        [embedded]=\"true\"\n                        [detail]=\"detail\" />\n                </ap-nav-selector-popover-item>\n            }\n        </ap-nav-selector-popover>\n    </div>\n}\n"]}
|
|
231
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-leaf.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf/nav-selector-leaf.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf/nav-selector-leaf.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AvatarComponent } from '@agorapulse/ui-components/avatar';\nimport { CheckboxComponent } from '@agorapulse/ui-components/checkbox';\nimport { CounterComponent } from '@agorapulse/ui-components/counter';\nimport { TooltipDirective } from '@agorapulse/ui-components/tooltip';\nimport { apChevronDown, apChevronUp, apErrorFill, apFeatureLock, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { apMore } from '@agorapulse/ui-symbol/icons';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport {\n    afterRender,\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    ElementRef,\n    input,\n    output,\n    signal,\n    untracked,\n    viewChild,\n} from '@angular/core';\nimport { NavSelectorPopoverTriggerDirective } from '../directives/nav-selector-popover-trigger.directive';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport {\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafAction,\n    InternalNavSelectorLeafDetails,\n    NavSelectorLeafActionClickedEvent,\n} from '../nav-selector';\nimport { NavSelectorLeafActionComponent } from '../nav-selector-leaf-action/nav-selector-leaf-action.component';\nimport { NavSelectorLeafDetailComponent } from '../nav-selector-leaf-detail/nav-selector-leaf-detail.component';\nimport { NavSelectorLeafDetailsComponent } from '../nav-selector-leaf-details/nav-selector-leaf-details.component';\nimport { NavSelectorPopoverItemComponent } from '../nav-selector-popover/nav-selector-popover-item.component';\nimport { NavSelectorPopoverComponent } from '../nav-selector-popover/nav-selector-popover.component';\nimport { NavSelectorLeafPresenter } from './nav-selector-leaf.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-leaf',\n    templateUrl: './nav-selector-leaf.component.html',\n    styleUrls: ['./nav-selector-leaf.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [\n        AvatarComponent,\n        CounterComponent,\n        SymbolComponent,\n        NavSelectorLeafDetailsComponent,\n        CheckboxComponent,\n        TooltipDirective,\n        NavSelectorLeafDetailComponent,\n        NavSelectorLeafDetailComponent,\n        TreeNodeAccessibilityDirective,\n        NavSelectorPopoverComponent,\n        NavSelectorPopoverTriggerDirective,\n        NavSelectorPopoverItemComponent,\n        NavSelectorLeafActionComponent,\n    ],\n    providers: [withSymbols(apErrorFill, apFeatureLock, apChevronDown, apChevronUp, apMore), NavSelectorLeafPresenter],\n    host: {\n        '[class.minified]': '!navSelectorLeafPresenter.expanded()',\n        role: 'treeitem',\n        '(keydown.arrowLeft)': 'fold($event)',\n        '(keydown.arrowRight)': 'unfold($event)',\n    },\n    animations: [\n        /**\n         * Overflow hidden is put only during the animation and on the collapsed state because if it is put on the expanded state then children’s border will be cut (hover / focus)\n         */\n        trigger('accordion', [\n            state(\n                'collapsed',\n                style({\n                    maxHeight: 0,\n                    overflow: 'hidden',\n                })\n            ),\n            state(\n                'expanded',\n                style({\n                    maxHeight: 'initial',\n                })\n            ),\n            transition('collapsed => expanded', [\n                animate('250ms cubic-bezier(.4, 0, .3, 1)', style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' })),\n            ]),\n            transition('expanded => collapsed', [\n                animate(\n                    '250ms cubic-bezier(.4, 0, .3, 1)',\n                    keyframes([style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' }), style({ maxHeight: 0 })])\n                ),\n            ]),\n        ]),\n    ],\n})\nexport class NavSelectorLeafComponent {\n    leaf = input.required<InternalNavSelectorLeaf>();\n\n    actionClicked = output<NavSelectorLeafActionClickedEvent>();\n\n    initial = computed(() => this.leaf().alias[0].toUpperCase());\n    foldSymbol = computed(() => (this.leaf().folded ? 'chevron-down' : 'chevron-up'));\n\n    focused = signal(false);\n\n    aliasEl = viewChild<ElementRef>('alias');\n    aliasBoundedClientRect = signal<{\n        offsetWidth: number;\n        offsetHeight: number;\n        scrollWidth: number;\n        scrollHeight: number;\n    }>({\n        offsetWidth: 0,\n        offsetHeight: 0,\n        scrollWidth: 0,\n        scrollHeight: 0,\n    });\n\n    tooltipContent = computed(() => {\n        const content = [];\n\n        const el = this.aliasBoundedClientRect();\n        if (!this.navSelectorLeafPresenter.expanded() || el.offsetWidth < el.scrollWidth || el.offsetHeight < el.scrollHeight) {\n            content.push(this.leaf().alias);\n        }\n\n        const disableReason = this.leaf().disableReason;\n        if (disableReason) {\n            content.push(disableReason);\n        }\n\n        if (this.leaf().displayFeatureLocked) {\n            content.push(this.navSelectorLeafPresenter.texts().featureLocked);\n        }\n\n        if (this.leaf().displayTokenInvalid) {\n            content.push(this.navSelectorLeafPresenter.texts().tokenInvalid);\n        }\n\n        return content.join('<br>');\n    });\n    tooltipDisabled = computed(() => !this.tooltipContent().length || this.leaf().detailsDisplayable);\n\n    foldedWithDelay = signal(false);\n\n    network = computed(() => (this.leaf().network ? this.leaf().network : undefined));\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorLeafPresenter: NavSelectorLeafPresenter\n    ) {\n        afterRender(() =>\n            untracked(() => {\n                const newMaxHeight = this.computeMaxHeight();\n                if (this.maxHeight() !== newMaxHeight) {\n                    this.maxHeight.set(newMaxHeight);\n                }\n                this.updateAliasBoundedClientRect();\n            })\n        );\n\n        effect(() => {\n            const folded = this.leaf().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    animationState = computed(() => (this.leaf().folded ? 'collapsed' : 'expanded'));\n\n    maxHeight = signal('0px');\n\n    onClick(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.selectLeaf(this.leaf());\n    }\n\n    toggleFolding(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.onLeafToggleFolding(this.leaf());\n    }\n\n    clickOnToggleFolding(event: Event) {\n        event.stopImmediatePropagation();\n        // Remove the focus from the toggle folding so we do not have the :focus-within style on the leaf\n        if (event.currentTarget && 'blur' in event.currentTarget && typeof event.currentTarget.blur === 'function') {\n            event.currentTarget.blur();\n        }\n        this.navSelectorLeafPresenter.onLeafToggleFolding(this.leaf());\n    }\n\n    selectOnly(event: Event) {\n        event.stopImmediatePropagation();\n        // (event.target as Element).blur();\n        this.navSelectorLeafPresenter.selectOnlyLeaf(this.leaf());\n    }\n\n    clickOnSelectOnly(event: Event) {\n        event.stopImmediatePropagation();\n        // Remove the focus from the select only so we do not have the :focus-within style on the leaf\n        if (event.currentTarget && 'blur' in event.currentTarget && typeof event.currentTarget.blur === 'function') {\n            event.currentTarget.blur();\n        }\n        this.navSelectorLeafPresenter.selectOnlyLeaf(this.leaf());\n    }\n\n    /**\n     * For checkboxes, as they do not stop event propagation, we need to stop it manually\n     */\n    eventStopper(event: Event) {\n        event.stopImmediatePropagation();\n    }\n\n    onCheckboxToggle() {\n        this.navSelectorLeafPresenter.selectLeaf(this.leaf());\n    }\n\n    onSpaceOrEnterPressed(event: Event) {\n        event.stopImmediatePropagation();\n        if (document.activeElement === this.el.nativeElement.querySelector('.nav-selector-leaf')) {\n            if (this.leaf().foldable) {\n                this.toggleFolding(event);\n            } else {\n                this.navSelectorLeafPresenter.selectLeaf(this.leaf());\n            }\n        }\n    }\n\n    fold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.fold(this.leaf());\n    }\n\n    unfold(event: Event) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.unfold(this.leaf());\n    }\n\n    onDetailClicked(event: Event, detail: InternalNavSelectorLeafDetails) {\n        event.stopImmediatePropagation();\n        this.navSelectorLeafPresenter.onLeafDetailClicked(detail);\n    }\n\n    onActionClicked(action: InternalNavSelectorLeafAction) {\n        this.actionClicked.emit({\n            leafUid: this.leaf().uid,\n            actionName: action.name,\n        });\n    }\n\n    private computeMaxHeight() {\n        let maxHeight = this.el.nativeElement.clientHeight;\n        if (this.leaf().folded) {\n            maxHeight = this.el.nativeElement.clientHeight * this.leaf().details.length;\n        }\n        return `${maxHeight}px`;\n    }\n\n    private updateAliasBoundedClientRect() {\n        const el = this.aliasEl()?.nativeElement;\n        if (el) {\n            const boundedClientRect = {\n                offsetWidth: el.offsetWidth,\n                offsetHeight: el.offsetHeight,\n                scrollWidth: el.scrollWidth,\n                scrollHeight: el.scrollHeight,\n            };\n            if (JSON.stringify(this.aliasBoundedClientRect()) !== JSON.stringify(boundedClientRect)) {\n                this.aliasBoundedClientRect.set(boundedClientRect);\n            }\n        }\n    }\n}\n","@if (navSelectorLeafPresenter.expandedAfterDelay()) {\n    <div\n        class=\"nav-selector-leaf\"\n        apTooltipPosition=\"right\"\n        [attr.aria-selected]=\"leaf().selected\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [class.multiple-mode]=\"navSelectorLeafPresenter.isMultipleModeEnabled()\"\n        [class.feature-locked]=\"leaf().displayFeatureLocked\"\n        [class.selected]=\"leaf().selected\"\n        [class.token-error]=\"leaf().displayTokenInvalid\"\n        [class.disabled]=\"leaf().disabled\"\n        [class.detail-selected]=\"leaf().detailSelected\"\n        [class.actions-displayable]=\"leaf().actionsDisplayable && leaf().detailsDisplayable\"\n        [class.details-displayable]=\"leaf().detailsDisplayable\"\n        [apTreeNodeAccessibility]=\"leaf()\"\n        (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n        (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n        (focusin)=\"focused.set(true)\"\n        (focusout)=\"focused.set(false)\"\n        (click)=\"onClick($event)\">\n        @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"leaf().uid\"\n                [checked]=\"leaf().selected\"\n                [aria-label]=\"leaf().alias\"\n                [disabled]=\"!leaf().selectable\"\n                (click)=\"eventStopper($event)\"\n                (change)=\"onCheckboxToggle()\" />\n        }\n        <ap-avatar\n            size=\"24\"\n            [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n            [network]=\"$any(leaf().network)\"\n            [showInitials]=\"initial()\" />\n\n        <span\n            #alias\n            class=\"caption\">\n            {{ leaf().alias }}\n        </span>\n\n        <a\n            class=\"standalone only-button\"\n            role=\"button\"\n            [attr.aria-label]=\"'Select only ' + leaf().alias\"\n            [attr.tabindex]=\"leaf().accessibility.tabIndex\"\n            (keydown.space)=\"selectOnly($event)\"\n            (keydown.enter)=\"selectOnly($event)\"\n            (click)=\"clickOnSelectOnly($event)\">\n            {{ navSelectorLeafPresenter.texts().only }}\n        </a>\n\n        @if (leaf().actionsDisplayable) {\n            <ap-symbol\n                class=\"actions-menu\"\n                size=\"sm\"\n                symbolId=\"more\"\n                [tabindex]=\"leaf().accessibility.tabIndex\"\n                [attr.aria-label]=\"'Action menu ' + leaf().alias\"\n                [apNavSelectorPopoverTrigger]=\"popover\"\n                [apNavSelectorPopoverTriggerMode]=\"{ click: true, keyboard: ['Space', 'Enter'] }\" />\n\n            <ap-nav-selector-popover\n                #popover\n                placement=\"bottom_start\">\n                @for (action of leaf().actions; track action) {\n                    <ap-nav-selector-popover-item\n                        item\n                        [id]=\"action.id\"\n                        [locked]=\"action.status === 'locked'\"\n                        [disabled]=\"action.status === 'disabled'\"\n                        [name]=\"action.name\"\n                        (click)=\"onActionClicked(action)\">\n                        <ap-nav-selector-leaf-action [action]=\"action\" />\n                    </ap-nav-selector-popover-item>\n                }\n            </ap-nav-selector-popover>\n        }\n\n        @if (leaf().foldable) {\n            <ap-symbol\n                class=\"folding-button\"\n                size=\"sm\"\n                role=\"button\"\n                [tabindex]=\"leaf().accessibility.tabIndex\"\n                [attr.aria-label]=\"'Toggle ' + leaf().alias\"\n                [symbolId]=\"foldSymbol()\"\n                (click)=\"clickOnToggleFolding($event)\"\n                (keydown.space)=\"toggleFolding($event)\"\n                (keydown.enter)=\"toggleFolding($event)\" />\n        }\n        @if (leaf().displayCounter) {\n            <ap-counter\n                color=\"orange\"\n                size=\"normal\"\n                [background]=\"false\">\n                {{ leaf().counter }}\n            </ap-counter>\n        }\n        @if (leaf().displayTokenInvalid) {\n            <ap-symbol\n                size=\"sm\"\n                symbolId=\"error_fill\" />\n        }\n        @if (leaf().displayFeatureLocked) {\n            <ap-symbol\n                size=\"sm\"\n                symbolId=\"feature-lock\" />\n        }\n    </div>\n\n    <div\n        class=\"details-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <ap-nav-selector-leaf-details\n                [details]=\"leaf().details\"\n                [leaf]=\"leaf()\" />\n        }\n    </div>\n} @else {\n    <div\n        #minified\n        class=\"nav-selector-leaf\"\n        apTooltipPosition=\"right\"\n        [apNavSelectorPopoverTrigger]=\"minifiedPopover\"\n        [apNavSelectorPopoverDisabled]=\"!leaf().detailsDisplayable\"\n        [apNavSelectorPopoverTriggerMode]=\"{ click: false, hover: true }\"\n        [class.feature-locked]=\"leaf().displayFeatureLocked\"\n        [class.selected]=\"leaf().selected || leaf().detailSelected\"\n        [class.token-error]=\"leaf().displayTokenInvalid\"\n        [class.multiple-mode]=\"navSelectorLeafPresenter.isMultipleModeEnabled()\"\n        [class.disabled]=\"leaf().disabled\"\n        [apTooltip]=\"tooltipContent()\"\n        [apTooltipDisabled]=\"tooltipDisabled()\"\n        [apTreeNodeAccessibility]=\"leaf()\"\n        (keydown.space)=\"onSpaceOrEnterPressed($event)\"\n        (keydown.enter)=\"onSpaceOrEnterPressed($event)\"\n        (click)=\"onClick($event)\">\n        @if (navSelectorLeafPresenter.isMultipleModeEnabled()) {\n            <ap-checkbox\n                [name]=\"leaf().uid\"\n                [checked]=\"leaf().selected\"\n                [disabled]=\"!leaf().selectable\" />\n        }\n\n        <div class=\"avatar-container\">\n            <ap-avatar\n                size=\"24\"\n                [profilePicture]=\"leaf().pictureUrl ?? undefined\"\n                [network]=\"$any(leaf().network)\"\n                [showInitials]=\"initial()\" />\n\n            <div class=\"status\">\n                @if (leaf().displayCounter) {\n                    <ap-counter\n                        class=\"counter-override\"\n                        color=\"orange\"\n                        size=\"normal\"\n                        [notif]=\"true\"\n                        [background]=\"true\">\n                        {{ leaf().counter }}\n                    </ap-counter>\n                }\n                @if (leaf().displayTokenInvalid) {\n                    <ap-symbol\n                        size=\"sm\"\n                        symbolId=\"error_fill\" />\n                }\n                @if (leaf().displayFeatureLocked) {\n                    <ap-symbol\n                        size=\"sm\"\n                        symbolId=\"feature-lock\" />\n                }\n            </div>\n        </div>\n\n        <ap-nav-selector-popover\n            #minifiedPopover\n            placement=\"right\"\n            [popoverTitle]=\"leaf().alias\"\n            [offset]=\"{ mainAxis: 0, crossAxis: -36.5 }\">\n            @for (detail of leaf().details; track detail.uid) {\n                <ap-nav-selector-popover-item\n                    item\n                    [selected]=\"detail.selected\"\n                    [disabled]=\"detail.displayError\"\n                    [name]=\"detail.alias\"\n                    (click)=\"onDetailClicked($event, detail)\">\n                    <ap-nav-selector-leaf-detail\n                        [embedded]=\"true\"\n                        [detail]=\"detail\" />\n                </ap-nav-selector-popover-item>\n            }\n        </ap-nav-selector-popover>\n    </div>\n}\n"]}
|