@agorapulse/ui-components 18.0.13 → 18.0.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/agorapulse-ui-components-18.0.15.tgz +0 -0
- package/avatar/avatar.component.d.ts +1 -1
- package/checkbox/checkbox.component.d.ts +1 -1
- package/esm2022/add-comment/add-comment.component.mjs +3 -3
- package/esm2022/checkbox/checkbox.component.mjs +5 -4
- package/esm2022/datepicker/datepicker.component.mjs +3 -3
- package/esm2022/labels/label-list.component.mjs +3 -3
- package/esm2022/labels-selector/labels-selector.component.mjs +3 -3
- package/esm2022/media-display-overlay/media-display-overlay-dialog.component.mjs +3 -3
- package/esm2022/modal/modal.component.mjs +3 -3
- package/esm2022/nav-selector/directives/nav-selector-popover-trigger.directive.mjs +71 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +15 -12
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +17 -14
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +38 -94
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.mjs +2 -2
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.mjs +6 -6
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs +12 -9
- package/esm2022/nav-selector/nav-selector-popover/nav-selector-popover-item.component.mjs +14 -0
- package/esm2022/nav-selector/nav-selector-popover/nav-selector-popover.component.mjs +127 -0
- package/esm2022/nav-selector/nav-selector.component.mjs +45 -23
- package/esm2022/nav-selector/nav-selector.mjs +1 -1
- package/esm2022/nav-selector/nav-selector.state.mjs +35 -11
- package/esm2022/nav-selector/utils/leaf.utils.mjs +12 -3
- package/esm2022/nav-selector/utils/nav-selector.accessibility.mjs +22 -14
- package/esm2022/nav-selector/utils/nav-selector.builder.mjs +4 -2
- package/esm2022/nav-selector/utils/nav-selector.filter.mjs +49 -11
- package/esm2022/nav-selector/utils/nav-selector.folding.mjs +26 -23
- package/esm2022/nav-selector/utils/nav-selector.merger.mjs +76 -0
- package/esm2022/nav-selector/utils/nav-selector.minifying.mjs +14 -9
- package/esm2022/nav-selector/utils/nav-selector.multi-select.mjs +2 -2
- package/esm2022/nav-selector/utils/nav-selector.single-select.mjs +46 -23
- package/esm2022/neo-datepicker/neo-datepicker.component.mjs +3 -3
- package/esm2022/notification/notification.component.mjs +3 -3
- package/esm2022/paginator/paginator-button/paginator-button.component.mjs +2 -2
- package/esm2022/password-input/password-input.component.mjs +3 -3
- package/esm2022/popmenu/popmenu.component.mjs +3 -3
- package/esm2022/slide-toggle/slide-toggle.component.mjs +3 -3
- package/esm2022/snackbars-thread/component/snackbars-thread.component.mjs +3 -3
- package/esm2022/stepper/stepper.component.mjs +3 -3
- package/fesm2022/agorapulse-ui-components-add-comment.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-add-comment.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-checkbox.mjs +4 -3
- package/fesm2022/agorapulse-ui-components-checkbox.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-datepicker.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-datepicker.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-labels-selector.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-labels-selector.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-labels.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-labels.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-media-display-overlay.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-media-display-overlay.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-modal.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-modal.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs +599 -238
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-neo-datepicker.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-neo-datepicker.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-notification.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-notification.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-paginator.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-paginator.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-password-input.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-password-input.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-popmenu.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-popmenu.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-slide-toggle.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-slide-toggle.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-stepper.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-stepper.mjs.map +1 -1
- package/nav-selector/directives/nav-selector-popover-trigger.directive.d.ts +25 -0
- package/nav-selector/nav-selector-group/nav-selector-group.component.d.ts +1 -1
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.component.d.ts +5 -20
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.d.ts +1 -1
- package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.d.ts +1 -1
- package/nav-selector/nav-selector-popover/nav-selector-popover-item.component.d.ts +6 -0
- package/nav-selector/nav-selector-popover/nav-selector-popover.component.d.ts +39 -0
- package/nav-selector/nav-selector.component.d.ts +6 -4
- package/nav-selector/nav-selector.d.ts +6 -0
- package/nav-selector/nav-selector.state.d.ts +3 -2
- package/nav-selector/utils/leaf.utils.d.ts +15 -2
- package/nav-selector/utils/nav-selector.accessibility.d.ts +1 -1
- package/nav-selector/utils/nav-selector.filter.d.ts +3 -1
- package/nav-selector/utils/nav-selector.folding.d.ts +6 -3
- package/nav-selector/utils/nav-selector.merger.d.ts +23 -0
- package/nav-selector/utils/nav-selector.minifying.d.ts +4 -2
- package/nav-selector/utils/nav-selector.single-select.d.ts +2 -0
- package/package.json +1 -1
- package/agorapulse-ui-components-18.0.13.tgz +0 -0
package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.mjs
CHANGED
|
@@ -13,18 +13,18 @@ export class NavSelectorLeafDetailComponent {
|
|
|
13
13
|
constructor(navSelectorLeafDetailPresenter) {
|
|
14
14
|
this.navSelectorLeafDetailPresenter = navSelectorLeafDetailPresenter;
|
|
15
15
|
}
|
|
16
|
-
onClick(
|
|
17
|
-
|
|
16
|
+
onClick(event) {
|
|
17
|
+
event.stopImmediatePropagation();
|
|
18
18
|
this.navSelectorLeafDetailPresenter.onLeafDetailClicked(this.detail());
|
|
19
19
|
}
|
|
20
20
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafDetailComponent, deps: [{ token: i1.NavSelectorLeafDetailPresenter }], target: i0.ɵɵFactoryTarget.Component });
|
|
21
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorLeafDetailComponent, isStandalone: true, selector: "ap-nav-selector-leaf-detail", inputs: { detail: { classPropertyName: "detail", publicName: "detail", isSignal: true, isRequired: true, transformFunction: null }, embedded: { classPropertyName: "embedded", publicName: "embedded", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "click": "onClick($event)", "keydown.enter": "onClick($event)", "keydown.space": "onClick($event)" }, properties: { "class.selected": "detail().selected
|
|
21
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorLeafDetailComponent, isStandalone: true, selector: "ap-nav-selector-leaf-detail", inputs: { detail: { classPropertyName: "detail", publicName: "detail", isSignal: true, isRequired: true, transformFunction: null }, embedded: { classPropertyName: "embedded", publicName: "embedded", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "click": "onClick($event)", "keydown.enter": "onClick($event)", "keydown.space": "onClick($event)" }, properties: { "class.selected": "detail().selected", "class.embedded": "embedded()" } }, providers: [withSymbols(apErrorFill), NavSelectorLeafDetailPresenter], hostDirectives: [{ directive: i2.TreeNodeAccessibilityDirective, inputs: ["apTreeNodeAccessibility", "detail"] }], ngImport: i0, template: "<span class=\"caption\">{{ detail().alias }}</span>\n\n@if (detail().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ detail().counter }}\n </ap-counter>\n}\n@if (detail().displayError) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n}\n", styles: [":host{display:flex;height:32px;padding:0 var(--ref-spacing-xxs);align-items:center;gap:var(--ref-spacing-xxs);align-self:stretch;flex-grow:1}:host.embedded{padding:0}:host ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host .caption{flex-grow:1;overflow:hidden;color:var(--ref-color-grey-100);text-overflow:ellipsis;white-space:nowrap;font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-regular);line-height:var(--ref-font-line-height-xs)}:host:not(.disabled):not(.embedded){cursor:pointer}:host:not(.disabled):not(.embedded):hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host:not(.disabled):not(.embedded):active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.disabled):not(.embedded):focus-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:not(.disabled):not(.embedded).selected{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.disabled):not(.embedded).selected .caption{overflow:hidden;color:var(--ref-color-electric-blue-150);text-overflow:ellipsis;white-space:nowrap;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:not(.disabled):not(.embedded).selected:focus-visible{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host.embedded.selected .caption{color:var(--ref-color-electric-blue-150);font-size:var(--ref-font-size-sm);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-sm)}\n"], dependencies: [{ kind: "component", type: CounterComponent, selector: "ap-counter", inputs: ["color", "size", "background", "notif"] }, { kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
22
22
|
}
|
|
23
23
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorLeafDetailComponent, decorators: [{
|
|
24
24
|
type: Component,
|
|
25
25
|
args: [{ selector: 'ap-nav-selector-leaf-detail', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [CounterComponent, SymbolComponent], providers: [withSymbols(apErrorFill), NavSelectorLeafDetailPresenter], host: {
|
|
26
26
|
'(click)': 'onClick($event)',
|
|
27
|
-
'[class.selected]': 'detail().selected
|
|
27
|
+
'[class.selected]': 'detail().selected',
|
|
28
28
|
'[class.embedded]': 'embedded()',
|
|
29
29
|
'(keydown.enter)': 'onClick($event)',
|
|
30
30
|
'(keydown.space)': 'onClick($event)',
|
|
@@ -34,6 +34,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
34
34
|
// Alias the input of the directive to detail the input detail will be used in the directive and in the component as well
|
|
35
35
|
inputs: ['apTreeNodeAccessibility: detail'],
|
|
36
36
|
},
|
|
37
|
-
], template: "<span class=\"caption\"
|
|
37
|
+
], template: "<span class=\"caption\">{{ detail().alias }}</span>\n\n@if (detail().displayCounter) {\n <ap-counter\n color=\"orange\"\n size=\"normal\"\n [background]=\"false\">\n {{ detail().counter }}\n </ap-counter>\n}\n@if (detail().displayError) {\n <ap-symbol\n size=\"sm\"\n symbolId=\"error_fill\" />\n}\n", styles: [":host{display:flex;height:32px;padding:0 var(--ref-spacing-xxs);align-items:center;gap:var(--ref-spacing-xxs);align-self:stretch;flex-grow:1}:host.embedded{padding:0}:host ap-symbol[symbol-id=error_fill]{color:var(--ref-color-red-100)}:host .caption{flex-grow:1;overflow:hidden;color:var(--ref-color-grey-100);text-overflow:ellipsis;white-space:nowrap;font-family:Averta;font-size:var(--ref-font-size-xs);font-style:normal;font-weight:var(--ref-font-weight-regular);line-height:var(--ref-font-line-height-xs)}:host:not(.disabled):not(.embedded){cursor:pointer}:host:not(.disabled):not(.embedded):hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host:not(.disabled):not(.embedded):active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.disabled):not(.embedded):focus-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:not(.disabled):not(.embedded).selected{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.disabled):not(.embedded).selected .caption{overflow:hidden;color:var(--ref-color-electric-blue-150);text-overflow:ellipsis;white-space:nowrap;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:not(.disabled):not(.embedded).selected:focus-visible{box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host.embedded.selected .caption{color:var(--ref-color-electric-blue-150);font-size:var(--ref-font-size-sm);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-sm)}\n"] }]
|
|
38
38
|
}], ctorParameters: () => [{ type: i1.NavSelectorLeafDetailPresenter }] });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXNlbGVjdG9yLWxlYWYtZGV0YWlsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9uYXYtc2VsZWN0b3Ivc3JjL25hdi1zZWxlY3Rvci1sZWFmLWRldGFpbC9uYXYtc2VsZWN0b3ItbGVhZi1kZXRhaWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL25hdi1zZWxlY3Rvci9zcmMvbmF2LXNlbGVjdG9yLWxlYWYtZGV0YWlsL25hdi1zZWxlY3Rvci1sZWFmLWRldGFpbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsV0FBVyxFQUFFLGVBQWUsRUFBRSxXQUFXLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNsRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUVqRyxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7OztBQXlCdEYsTUFBTSxPQUFPLDhCQUE4QjtJQUtwQjtJQUpuQixNQUFNLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBa0MsQ0FBQztJQUUxRCxRQUFRLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRXhCLFlBQW1CLDhCQUE4RDtRQUE5RCxtQ0FBOEIsR0FBOUIsOEJBQThCLENBQWdDO0lBQUcsQ0FBQztJQUVyRixPQUFPLENBQUMsS0FBWTtRQUNoQixLQUFLLENBQUMsd0JBQXdCLEVBQUUsQ0FBQztRQUNqQyxJQUFJLENBQUMsOEJBQThCLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDM0UsQ0FBQzt1R0FWUSw4QkFBOEI7MkZBQTlCLDhCQUE4QixxaUJBaEI1QixDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsRUFBRSw4QkFBOEIsQ0FBQyw2SUNkekUsZ1dBZUEsdTJEREZjLGdCQUFnQix5R0FBRSxlQUFlOzsyRkFpQmxDLDhCQUE4QjtrQkF2QjFDLFNBQVM7K0JBQ0ksNkJBQTZCLGNBRzNCLElBQUksbUJBQ0MsdUJBQXVCLENBQUMsTUFBTSxXQUN0QyxDQUFDLGdCQUFnQixFQUFFLGVBQWUsQ0FBQyxhQUNqQyxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsRUFBRSw4QkFBOEIsQ0FBQyxRQUMvRDt3QkFDRixTQUFTLEVBQUUsaUJBQWlCO3dCQUM1QixrQkFBa0IsRUFBRSxtQkFBbUI7d0JBQ3ZDLGtCQUFrQixFQUFFLFlBQVk7d0JBQ2hDLGlCQUFpQixFQUFFLGlCQUFpQjt3QkFDcEMsaUJBQWlCLEVBQUUsaUJBQWlCO3FCQUN2QyxrQkFDZTt3QkFDWjs0QkFDSSxTQUFTLEVBQUUsOEJBQThCOzRCQUN6Qyx5SEFBeUg7NEJBQ3pILE1BQU0sRUFBRSxDQUFDLGlDQUFpQyxDQUFDO3lCQUM5QztxQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvdW50ZXJDb21wb25lbnQgfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2NvdW50ZXInO1xuaW1wb3J0IHsgYXBFcnJvckZpbGwsIFN5bWJvbENvbXBvbmVudCwgd2l0aFN5bWJvbHMgfSBmcm9tICdAYWdvcmFwdWxzZS91aS1zeW1ib2wnO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyZWVOb2RlQWNjZXNzaWJpbGl0eURpcmVjdGl2ZSB9IGZyb20gJy4uL2RpcmVjdGl2ZXMvdHJlZS1ub2RlLWFjY2Vzc2liaWxpdHkuZGlyZWN0aXZlJztcbmltcG9ydCB7IEludGVybmFsTmF2U2VsZWN0b3JMZWFmRGV0YWlscyB9IGZyb20gJy4uL25hdi1zZWxlY3Rvcic7XG5pbXBvcnQgeyBOYXZTZWxlY3RvckxlYWZEZXRhaWxQcmVzZW50ZXIgfSBmcm9tICcuL25hdi1zZWxlY3Rvci1sZWFmLWRldGFpbC5wcmVzZW50ZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2FwLW5hdi1zZWxlY3Rvci1sZWFmLWRldGFpbCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL25hdi1zZWxlY3Rvci1sZWFmLWRldGFpbC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vbmF2LXNlbGVjdG9yLWxlYWYtZGV0YWlsLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBpbXBvcnRzOiBbQ291bnRlckNvbXBvbmVudCwgU3ltYm9sQ29tcG9uZW50XSxcbiAgICBwcm92aWRlcnM6IFt3aXRoU3ltYm9scyhhcEVycm9yRmlsbCksIE5hdlNlbGVjdG9yTGVhZkRldGFpbFByZXNlbnRlcl0sXG4gICAgaG9zdDoge1xuICAgICAgICAnKGNsaWNrKSc6ICdvbkNsaWNrKCRldmVudCknLFxuICAgICAgICAnW2NsYXNzLnNlbGVjdGVkXSc6ICdkZXRhaWwoKS5zZWxlY3RlZCcsXG4gICAgICAgICdbY2xhc3MuZW1iZWRkZWRdJzogJ2VtYmVkZGVkKCknLFxuICAgICAgICAnKGtleWRvd24uZW50ZXIpJzogJ29uQ2xpY2soJGV2ZW50KScsXG4gICAgICAgICcoa2V5ZG93bi5zcGFjZSknOiAnb25DbGljaygkZXZlbnQpJyxcbiAgICB9LFxuICAgIGhvc3REaXJlY3RpdmVzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIGRpcmVjdGl2ZTogVHJlZU5vZGVBY2Nlc3NpYmlsaXR5RGlyZWN0aXZlLFxuICAgICAgICAgICAgLy8gQWxpYXMgdGhlIGlucHV0IG9mIHRoZSBkaXJlY3RpdmUgdG8gZGV0YWlsIHRoZSBpbnB1dCBkZXRhaWwgd2lsbCBiZSB1c2VkIGluIHRoZSBkaXJlY3RpdmUgYW5kIGluIHRoZSBjb21wb25lbnQgYXMgd2VsbFxuICAgICAgICAgICAgaW5wdXRzOiBbJ2FwVHJlZU5vZGVBY2Nlc3NpYmlsaXR5OiBkZXRhaWwnXSxcbiAgICAgICAgfSxcbiAgICBdLFxufSlcbmV4cG9ydCBjbGFzcyBOYXZTZWxlY3RvckxlYWZEZXRhaWxDb21wb25lbnQge1xuICAgIGRldGFpbCA9IGlucHV0LnJlcXVpcmVkPEludGVybmFsTmF2U2VsZWN0b3JMZWFmRGV0YWlscz4oKTtcblxuICAgIGVtYmVkZGVkID0gaW5wdXQoZmFsc2UpO1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIG5hdlNlbGVjdG9yTGVhZkRldGFpbFByZXNlbnRlcjogTmF2U2VsZWN0b3JMZWFmRGV0YWlsUHJlc2VudGVyKSB7fVxuXG4gICAgb25DbGljayhldmVudDogRXZlbnQpIHtcbiAgICAgICAgZXZlbnQuc3RvcEltbWVkaWF0ZVByb3BhZ2F0aW9uKCk7XG4gICAgICAgIHRoaXMubmF2U2VsZWN0b3JMZWFmRGV0YWlsUHJlc2VudGVyLm9uTGVhZkRldGFpbENsaWNrZWQodGhpcy5kZXRhaWwoKSk7XG4gICAgfVxufVxuIiwiPHNwYW4gY2xhc3M9XCJjYXB0aW9uXCI+e3sgZGV0YWlsKCkuYWxpYXMgfX08L3NwYW4+XG5cbkBpZiAoZGV0YWlsKCkuZGlzcGxheUNvdW50ZXIpIHtcbiAgICA8YXAtY291bnRlclxuICAgICAgICBjb2xvcj1cIm9yYW5nZVwiXG4gICAgICAgIHNpemU9XCJub3JtYWxcIlxuICAgICAgICBbYmFja2dyb3VuZF09XCJmYWxzZVwiPlxuICAgICAgICB7eyBkZXRhaWwoKS5jb3VudGVyIH19XG4gICAgPC9hcC1jb3VudGVyPlxufVxuQGlmIChkZXRhaWwoKS5kaXNwbGF5RXJyb3IpIHtcbiAgICA8YXAtc3ltYm9sXG4gICAgICAgIHNpemU9XCJzbVwiXG4gICAgICAgIHN5bWJvbElkPVwiZXJyb3JfZmlsbFwiIC8+XG59XG4iXX0=
|
package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { animate, keyframes, state, style, transition, trigger } from '@angular/animations';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, computed, effect, input, signal } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, effect, input, signal, untracked } from '@angular/core';
|
|
3
3
|
import { NavSelectorLeafDetailComponent } from '../nav-selector-leaf-detail/nav-selector-leaf-detail.component';
|
|
4
4
|
import { NavSelectorLeafDetailsPresenter } from '../nav-selector-leaf-details/nav-selector-leaf-details.presenter';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -21,13 +21,16 @@ export class NavSelectorLeafDetailsComponent {
|
|
|
21
21
|
this.el = el;
|
|
22
22
|
this.navSelectorLeafDetailsPresenter = navSelectorLeafDetailsPresenter;
|
|
23
23
|
effect(() => {
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
24
|
+
const viewMoreDisplayed = this.leaf().viewMoreDisplayed;
|
|
25
|
+
untracked(() => {
|
|
26
|
+
if (viewMoreDisplayed) {
|
|
27
|
+
setTimeout(() => this.viewMoreDelay.set(false), 150);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
this.viewMoreDelay.set(true);
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
});
|
|
31
34
|
}
|
|
32
35
|
ngAfterViewInit() {
|
|
33
36
|
// scrollHeight = leaf + first details displayed when there is a limit
|
|
@@ -89,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
89
92
|
]),
|
|
90
93
|
], template: "@for (detail of firstDetails(); track detail.uid) {\n <div class=\"detail\">\n <div class=\"separator\">\n <div class=\"rectangle\"></div>\n </div>\n <ap-nav-selector-leaf-detail [detail]=\"detail\" />\n </div>\n}\n\n@if (leaf().viewMoreDisplayable) {\n <div\n class=\"details-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (viewMoreDelay()) {\n @for (detail of lastDetails(); track detail.uid) {\n <div class=\"detail\">\n <div class=\"separator\">\n <div class=\"rectangle\"></div>\n </div>\n <ap-nav-selector-leaf-detail [detail]=\"detail\" />\n </div>\n }\n }\n </div>\n\n <div class=\"detail\">\n <div class=\"separator\">\n <div class=\"rectangle\"></div>\n </div>\n <a\n tabindex=\"0\"\n role=\"button\"\n class=\"standalone view-more\"\n (keydown.space)=\"onSpaceOrEnter($event)\"\n (keydown.enter)=\"onSpaceOrEnter($event)\"\n (click)=\"toggleViewMore()\">\n @if (leaf().viewMoreDisplayed) {\n {{ navSelectorLeafDetailsPresenter.viewMoreText() }}\n } @else {\n {{ navSelectorLeafDetailsPresenter.viewLessText() }}\n }\n </a>\n </div>\n}\n", styles: [":host{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0}:host .detail{display:flex;align-self:stretch}:host .separator{display:flex;padding:0 11px 0 20px;align-items:center;align-self:stretch}:host .rectangle{width:1px;align-self:stretch;background:var(--ref-color-grey-10)}:host .view-more{display:flex;padding:8px;align-items:center;align-self:stretch}:host .details-container{display:flex;flex-direction:column;align-self:stretch}\n"] }]
|
|
91
94
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NavSelectorLeafDetailsPresenter }] });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-leaf-details.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf-details/nav-selector-leaf-details.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf-details/nav-selector-leaf-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, computed, effect, ElementRef, input, signal } from '@angular/core';\nimport { InternalNavSelectorLeaf, InternalNavSelectorLeafDetails } from '../nav-selector';\nimport { NavSelectorLeafDetailComponent } from '../nav-selector-leaf-detail/nav-selector-leaf-detail.component';\nimport { NavSelectorLeafDetailsPresenter } from '../nav-selector-leaf-details/nav-selector-leaf-details.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-leaf-details',\n    templateUrl: './nav-selector-leaf-details.component.html',\n    styleUrls: ['./nav-selector-leaf-details.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [NavSelectorLeafDetailComponent],\n    providers: [NavSelectorLeafDetailsPresenter],\n    host: {\n        '[attr.aria-expanded]': '!leaf().viewMoreDisplayable || leaf().viewMoreDisplayed',\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 NavSelectorLeafDetailsComponent implements AfterViewInit {\n    leaf = input.required<InternalNavSelectorLeaf>();\n    details = input.required<InternalNavSelectorLeafDetails[]>();\n\n    firstDetails = computed(() => this.details().slice(0, this.leaf().viewMoreDetailsDisplayedLimit));\n    lastDetails = computed(() => this.details().slice(this.leaf().viewMoreDetailsDisplayedLimit));\n\n    viewMoreDelay = signal(false);\n\n    animationState = computed(() => (this.leaf().viewMoreDisplayable && this.leaf().viewMoreDisplayed ? 'collapsed' : 'expanded'));\n\n    /**\n     * The height when details are all displayed\n     */\n    maxHeight = signal('0px');\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorLeafDetailsPresenter: NavSelectorLeafDetailsPresenter\n    ) {\n        effect(\n            () => {\n                if (this.leaf().viewMoreDisplayed) {\n                    setTimeout(() => this.viewMoreDelay.set(false), 150);\n                } else {\n                    this.viewMoreDelay.set(true);\n                }\n            },\n            { allowSignalWrites: true }\n        );\n    }\n\n    ngAfterViewInit(): void {\n        // scrollHeight = leaf + first details displayed when there is a limit\n        const height = this.el.nativeElement.scrollHeight;\n        // cross multiplication to determine height of remaining details\n        this.maxHeight.set(`${(height * this.lastDetails().length) / this.firstDetails().length}px`);\n    }\n\n    toggleViewMore() {\n        this.navSelectorLeafDetailsPresenter.toggleViewMore(this.leaf());\n    }\n\n    onSpaceOrEnter(event: Event) {\n        event.stopImmediatePropagation();\n        this.toggleViewMore();\n    }\n}\n","@for (detail of firstDetails(); track detail.uid) {\n    <div class=\"detail\">\n        <div class=\"separator\">\n            <div class=\"rectangle\"></div>\n        </div>\n        <ap-nav-selector-leaf-detail [detail]=\"detail\" />\n    </div>\n}\n\n@if (leaf().viewMoreDisplayable) {\n    <div\n        class=\"details-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (viewMoreDelay()) {\n            @for (detail of lastDetails(); track detail.uid) {\n                <div class=\"detail\">\n                    <div class=\"separator\">\n                        <div class=\"rectangle\"></div>\n                    </div>\n                    <ap-nav-selector-leaf-detail [detail]=\"detail\" />\n                </div>\n            }\n        }\n    </div>\n\n    <div class=\"detail\">\n        <div class=\"separator\">\n            <div class=\"rectangle\"></div>\n        </div>\n        <a\n            tabindex=\"0\"\n            role=\"button\"\n            class=\"standalone view-more\"\n            (keydown.space)=\"onSpaceOrEnter($event)\"\n            (keydown.enter)=\"onSpaceOrEnter($event)\"\n            (click)=\"toggleViewMore()\">\n            @if (leaf().viewMoreDisplayed) {\n                {{ navSelectorLeafDetailsPresenter.viewMoreText() }}\n            } @else {\n                {{ navSelectorLeafDetailsPresenter.viewLessText() }}\n            }\n        </a>\n    </div>\n}\n"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-leaf-details.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf-details/nav-selector-leaf-details.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-leaf-details/nav-selector-leaf-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, computed, effect, ElementRef, input, signal, untracked } from '@angular/core';\nimport { InternalNavSelectorLeaf, InternalNavSelectorLeafDetails } from '../nav-selector';\nimport { NavSelectorLeafDetailComponent } from '../nav-selector-leaf-detail/nav-selector-leaf-detail.component';\nimport { NavSelectorLeafDetailsPresenter } from '../nav-selector-leaf-details/nav-selector-leaf-details.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-leaf-details',\n    templateUrl: './nav-selector-leaf-details.component.html',\n    styleUrls: ['./nav-selector-leaf-details.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [NavSelectorLeafDetailComponent],\n    providers: [NavSelectorLeafDetailsPresenter],\n    host: {\n        '[attr.aria-expanded]': '!leaf().viewMoreDisplayable || leaf().viewMoreDisplayed',\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 NavSelectorLeafDetailsComponent implements AfterViewInit {\n    leaf = input.required<InternalNavSelectorLeaf>();\n    details = input.required<InternalNavSelectorLeafDetails[]>();\n\n    firstDetails = computed(() => this.details().slice(0, this.leaf().viewMoreDetailsDisplayedLimit));\n    lastDetails = computed(() => this.details().slice(this.leaf().viewMoreDetailsDisplayedLimit));\n\n    viewMoreDelay = signal(false);\n\n    animationState = computed(() => (this.leaf().viewMoreDisplayable && this.leaf().viewMoreDisplayed ? 'collapsed' : 'expanded'));\n\n    /**\n     * The height when details are all displayed\n     */\n    maxHeight = signal('0px');\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorLeafDetailsPresenter: NavSelectorLeafDetailsPresenter\n    ) {\n        effect(() => {\n            const viewMoreDisplayed = this.leaf().viewMoreDisplayed;\n            untracked(() => {\n                if (viewMoreDisplayed) {\n                    setTimeout(() => this.viewMoreDelay.set(false), 150);\n                } else {\n                    this.viewMoreDelay.set(true);\n                }\n            });\n        });\n    }\n\n    ngAfterViewInit(): void {\n        // scrollHeight = leaf + first details displayed when there is a limit\n        const height = this.el.nativeElement.scrollHeight;\n        // cross multiplication to determine height of remaining details\n        this.maxHeight.set(`${(height * this.lastDetails().length) / this.firstDetails().length}px`);\n    }\n\n    toggleViewMore() {\n        this.navSelectorLeafDetailsPresenter.toggleViewMore(this.leaf());\n    }\n\n    onSpaceOrEnter(event: Event) {\n        event.stopImmediatePropagation();\n        this.toggleViewMore();\n    }\n}\n","@for (detail of firstDetails(); track detail.uid) {\n    <div class=\"detail\">\n        <div class=\"separator\">\n            <div class=\"rectangle\"></div>\n        </div>\n        <ap-nav-selector-leaf-detail [detail]=\"detail\" />\n    </div>\n}\n\n@if (leaf().viewMoreDisplayable) {\n    <div\n        class=\"details-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (viewMoreDelay()) {\n            @for (detail of lastDetails(); track detail.uid) {\n                <div class=\"detail\">\n                    <div class=\"separator\">\n                        <div class=\"rectangle\"></div>\n                    </div>\n                    <ap-nav-selector-leaf-detail [detail]=\"detail\" />\n                </div>\n            }\n        }\n    </div>\n\n    <div class=\"detail\">\n        <div class=\"separator\">\n            <div class=\"rectangle\"></div>\n        </div>\n        <a\n            tabindex=\"0\"\n            role=\"button\"\n            class=\"standalone view-more\"\n            (keydown.space)=\"onSpaceOrEnter($event)\"\n            (keydown.enter)=\"onSpaceOrEnter($event)\"\n            (click)=\"toggleViewMore()\">\n            @if (leaf().viewMoreDisplayed) {\n                {{ navSelectorLeafDetailsPresenter.viewMoreText() }}\n            } @else {\n                {{ navSelectorLeafDetailsPresenter.viewLessText() }}\n            }\n        </a>\n    </div>\n}\n"]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Component, input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class NavSelectorPopoverItemComponent {
|
|
4
|
+
selected = input(false);
|
|
5
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorPopoverItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.9", type: NavSelectorPopoverItemComponent, isStandalone: true, selector: "ap-nav-selector-popover-item", inputs: { selected: { classPropertyName: "selected", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.selected": "selected()" } }, ngImport: i0, template: '<ng-content/>', isInline: true, styles: [":host{width:100%;height:40px;display:flex;flex-wrap:wrap;align-content:center;gap:var(--ref-spacing-xxs);padding:var(--ref-spacing-xxs) var(--ref-spacing-sm);background:none;border:none;cursor:pointer;color:var(--ref-color-grey-100)}:host:focus-visible{background-color:var(--ref-color-electric-blue-10)}:host:hover{background-color:var(--ref-color-electric-blue-10)}:host:active{background-color:var(--ref-color-electric-blue-20)}:host.nav-selector-popover__item--active{background-color:var(--ref-color-electric-blue-10);color:var(--ref-color-electric-blue-100);font-weight:var(--ref-font-weight-bold)}:host.selected{background:var(--ref-color-electric-blue-10)}\n"] });
|
|
7
|
+
}
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorPopoverItemComponent, decorators: [{
|
|
9
|
+
type: Component,
|
|
10
|
+
args: [{ selector: 'ap-nav-selector-popover-item', standalone: true, template: '<ng-content/>', host: {
|
|
11
|
+
'[class.selected]': 'selected()',
|
|
12
|
+
}, styles: [":host{width:100%;height:40px;display:flex;flex-wrap:wrap;align-content:center;gap:var(--ref-spacing-xxs);padding:var(--ref-spacing-xxs) var(--ref-spacing-sm);background:none;border:none;cursor:pointer;color:var(--ref-color-grey-100)}:host:focus-visible{background-color:var(--ref-color-electric-blue-10)}:host:hover{background-color:var(--ref-color-electric-blue-10)}:host:active{background-color:var(--ref-color-electric-blue-20)}:host.nav-selector-popover__item--active{background-color:var(--ref-color-electric-blue-10);color:var(--ref-color-electric-blue-100);font-weight:var(--ref-font-weight-bold)}:host.selected{background:var(--ref-color-electric-blue-10)}\n"] }]
|
|
13
|
+
}] });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXNlbGVjdG9yLXBvcG92ZXItaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvbmF2LXNlbGVjdG9yL3NyYy9uYXYtc2VsZWN0b3ItcG9wb3Zlci9uYXYtc2VsZWN0b3ItcG9wb3Zlci1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFXakQsTUFBTSxPQUFPLCtCQUErQjtJQUN4QyxRQUFRLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO3VHQURmLCtCQUErQjsyRkFBL0IsK0JBQStCLCtSQU45QixlQUFlOzsyRkFNaEIsK0JBQStCO2tCQVQzQyxTQUFTOytCQUNJLDhCQUE4QixjQUM1QixJQUFJLFlBQ04sZUFBZSxRQUVuQjt3QkFDRixrQkFBa0IsRUFBRSxZQUFZO3FCQUNuQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdhcC1uYXYtc2VsZWN0b3ItcG9wb3Zlci1pdGVtJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQvPicsXG4gICAgc3R5bGVVcmxzOiBbJy4vbmF2LXNlbGVjdG9yLXBvcG92ZXItaXRlbS5jb21wb25lbnQuc2NzcyddLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJ1tjbGFzcy5zZWxlY3RlZF0nOiAnc2VsZWN0ZWQoKScsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgTmF2U2VsZWN0b3JQb3BvdmVySXRlbUNvbXBvbmVudCB7XG4gICAgc2VsZWN0ZWQgPSBpbnB1dChmYWxzZSk7XG59XG4iXX0=
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, contentChildren, input, signal } from '@angular/core';
|
|
3
|
+
import { NavSelectorPopoverItemComponent } from './nav-selector-popover-item.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export const NavSelectorPopoverPlacement = {
|
|
6
|
+
RIGHT: 'right',
|
|
7
|
+
BOTTOM_START: 'bottom_start',
|
|
8
|
+
};
|
|
9
|
+
export class NavSelectorPopoverComponent {
|
|
10
|
+
elementRef;
|
|
11
|
+
placement = input(NavSelectorPopoverPlacement.RIGHT);
|
|
12
|
+
popoverTitle = input();
|
|
13
|
+
offset = input({ mainAxis: 0, crossAxis: 0 });
|
|
14
|
+
items = contentChildren('item');
|
|
15
|
+
displayed = signal(false);
|
|
16
|
+
navSelectorPopoverDisplayed = this.displayed.asReadonly();
|
|
17
|
+
position = signal({
|
|
18
|
+
top: 0,
|
|
19
|
+
left: 0,
|
|
20
|
+
});
|
|
21
|
+
parentEl = signal(null);
|
|
22
|
+
mainAxisOffset = computed(() => this.offset().mainAxis ?? 0);
|
|
23
|
+
crossAxisOffset = computed(() => this.offset().crossAxis ?? 0);
|
|
24
|
+
constructor(elementRef) {
|
|
25
|
+
this.elementRef = elementRef;
|
|
26
|
+
}
|
|
27
|
+
display(parentEl) {
|
|
28
|
+
this.parentEl.set(parentEl);
|
|
29
|
+
this.displayed.set(true);
|
|
30
|
+
this.computePosition(parentEl);
|
|
31
|
+
}
|
|
32
|
+
hide() {
|
|
33
|
+
this.displayed.set(false);
|
|
34
|
+
}
|
|
35
|
+
toggle(parentEl) {
|
|
36
|
+
this.parentEl.set(parentEl);
|
|
37
|
+
this.displayed.update(value => !value);
|
|
38
|
+
if (this.displayed()) {
|
|
39
|
+
this.computePosition(parentEl);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
onClick(event) {
|
|
43
|
+
// Prevent click to be caught from element behind the popover (real bug)
|
|
44
|
+
event.stopImmediatePropagation();
|
|
45
|
+
this.displayed.set(false);
|
|
46
|
+
}
|
|
47
|
+
computePosition(parentEl) {
|
|
48
|
+
// Needed to wait first render and have the total height of the popover
|
|
49
|
+
setTimeout(() => {
|
|
50
|
+
const parentRect = parentEl.nativeElement.getBoundingClientRect();
|
|
51
|
+
if (!parentRect.top && !parentRect.left) {
|
|
52
|
+
this.displayed.set(false);
|
|
53
|
+
}
|
|
54
|
+
else if (this.placement().startsWith('right')) {
|
|
55
|
+
this.computeRightPosition(parentEl);
|
|
56
|
+
}
|
|
57
|
+
else if (this.placement().startsWith('bottom')) {
|
|
58
|
+
this.computeBottomPosition(parentEl);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
computeRightPosition(parentEl) {
|
|
63
|
+
const nativeEl = parentEl.nativeElement;
|
|
64
|
+
const rect = nativeEl.getBoundingClientRect();
|
|
65
|
+
let top = rect.top + (rect.height - nativeEl.offsetHeight) / 2 + this.crossAxisOffset();
|
|
66
|
+
const left = rect.left + rect.width + this.mainAxisOffset();
|
|
67
|
+
const elementEl = this.elementRef.nativeElement;
|
|
68
|
+
const popoverRect = elementEl.getBoundingClientRect();
|
|
69
|
+
if (top + elementEl.clientHeight > window.innerHeight) {
|
|
70
|
+
const popoverEl = document.querySelector('.nav-selector-popover');
|
|
71
|
+
const paddingBottom = parseInt(getComputedStyle(popoverEl).paddingBottom);
|
|
72
|
+
top = rect.top + rect.height - popoverRect.height + paddingBottom;
|
|
73
|
+
}
|
|
74
|
+
this.position.set({
|
|
75
|
+
top: top,
|
|
76
|
+
left: left,
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
computeBottomPosition(parentEl) {
|
|
80
|
+
const nativeEl = parentEl.nativeElement;
|
|
81
|
+
const rect = nativeEl.getBoundingClientRect();
|
|
82
|
+
let top = rect.top + rect.height + this.mainAxisOffset();
|
|
83
|
+
let left = rect.left + (rect.width - nativeEl.offsetWidth) / 2 + this.crossAxisOffset();
|
|
84
|
+
if (this.placement() === NavSelectorPopoverPlacement.BOTTOM_START) {
|
|
85
|
+
left = rect.left;
|
|
86
|
+
}
|
|
87
|
+
const elementEl = this.elementRef.nativeElement;
|
|
88
|
+
const popoverRect = elementEl.getBoundingClientRect();
|
|
89
|
+
if (top + elementEl.clientHeight > window.innerHeight) {
|
|
90
|
+
top -= popoverRect.height + rect.height;
|
|
91
|
+
}
|
|
92
|
+
this.position.set({
|
|
93
|
+
top: top,
|
|
94
|
+
left: left,
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
onAnyScroll() {
|
|
98
|
+
const parent = this.parentEl();
|
|
99
|
+
if (parent) {
|
|
100
|
+
this.computePosition(parent);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
onFocusChanged(event) {
|
|
104
|
+
if (!this.elementRef.nativeElement.contains(event.target)) {
|
|
105
|
+
this.displayed.set(false);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
onAnyClick(event) {
|
|
109
|
+
if (!this.elementRef.nativeElement.contains(event.target)) {
|
|
110
|
+
this.displayed.set(false);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorPopoverComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
114
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorPopoverComponent, isStandalone: true, selector: "ap-nav-selector-popover", inputs: { placement: { classPropertyName: "placement", publicName: "placement", isSignal: true, isRequired: false, transformFunction: null }, popoverTitle: { classPropertyName: "popoverTitle", publicName: "popoverTitle", isSignal: true, isRequired: false, transformFunction: null }, offset: { classPropertyName: "offset", publicName: "offset", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "click": "onClick($event)", "window:wheel": "onAnyScroll()", "window:focusin": "onFocusChanged($event)", "window:click": "onAnyClick($event)" }, properties: { "style.top.px": "position().top", "style.left.px": "position().left" } }, queries: [{ propertyName: "items", predicate: ["item"], isSignal: true }], ngImport: i0, template: "@if (displayed()) {\n <div class=\"nav-selector-popover\">\n @if (popoverTitle()) {\n <div class=\"nav-selector-popover__title\">{{ popoverTitle() }}</div>\n }\n\n @let itemsNotNull = items();\n\n @if (itemsNotNull?.length) {\n @for (item of itemsNotNull; track item) {\n <ap-nav-selector-popover-item>\n <ng-container [ngTemplateOutlet]=\"item\"/>\n </ap-nav-selector-popover-item>\n }\n } @else {\n <ng-content select=\"[item]\"/>\n }\n </div>\n}\n", styles: [":host{position:fixed;z-index:10}:host .nav-selector-popover{padding:var(--ref-spacing-xxs) 0;background:var(--ref-color-white);border-radius:var(--ref-border-radius-sm);box-shadow:0 4px 25px -2px #34456326,0 4px 6px -2px #34456326}:host .nav-selector-popover__title{padding:var(--ref-spacing-xxs) var(--ref-spacing-sm) var(--ref-spacing-xxxs);text-align:left;color:var(--ref-color-grey-100);font-size:var(--ref-font-size-xs);font-weight:var(--ref-font-weight-bold)}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: NavSelectorPopoverItemComponent, selector: "ap-nav-selector-popover-item", inputs: ["selected"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
115
|
+
}
|
|
116
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorPopoverComponent, decorators: [{
|
|
117
|
+
type: Component,
|
|
118
|
+
args: [{ selector: 'ap-nav-selector-popover', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
119
|
+
'[style.top.px]': 'position().top',
|
|
120
|
+
'[style.left.px]': 'position().left',
|
|
121
|
+
'(click)': 'onClick($event)',
|
|
122
|
+
'(window:wheel)': 'onAnyScroll()',
|
|
123
|
+
'(window:focusin)': 'onFocusChanged($event)',
|
|
124
|
+
'(window:click)': 'onAnyClick($event)',
|
|
125
|
+
}, imports: [NgTemplateOutlet, NavSelectorPopoverItemComponent], template: "@if (displayed()) {\n <div class=\"nav-selector-popover\">\n @if (popoverTitle()) {\n <div class=\"nav-selector-popover__title\">{{ popoverTitle() }}</div>\n }\n\n @let itemsNotNull = items();\n\n @if (itemsNotNull?.length) {\n @for (item of itemsNotNull; track item) {\n <ap-nav-selector-popover-item>\n <ng-container [ngTemplateOutlet]=\"item\"/>\n </ap-nav-selector-popover-item>\n }\n } @else {\n <ng-content select=\"[item]\"/>\n }\n </div>\n}\n", styles: [":host{position:fixed;z-index:10}:host .nav-selector-popover{padding:var(--ref-spacing-xxs) 0;background:var(--ref-color-white);border-radius:var(--ref-border-radius-sm);box-shadow:0 4px 25px -2px #34456326,0 4px 6px -2px #34456326}:host .nav-selector-popover__title{padding:var(--ref-spacing-xxs) var(--ref-spacing-sm) var(--ref-spacing-xxxs);text-align:left;color:var(--ref-color-grey-100);font-size:var(--ref-font-size-xs);font-weight:var(--ref-font-weight-bold)}\n"] }]
|
|
126
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }] });
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-popover.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-popover/nav-selector-popover.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-popover/nav-selector-popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, computed, contentChildren, ElementRef, input, signal, TemplateRef } from '@angular/core';\nimport { NavSelectorPopoverItemComponent } from './nav-selector-popover-item.component';\n\nexport const NavSelectorPopoverPlacement = {\n    RIGHT: 'right',\n    BOTTOM_START: 'bottom_start',\n} as const;\nexport type NavSelectorPopoverPlacement = (typeof NavSelectorPopoverPlacement)[keyof typeof NavSelectorPopoverPlacement];\n\n@Component({\n    selector: 'ap-nav-selector-popover',\n    standalone: true,\n    templateUrl: './nav-selector-popover.component.html',\n    styleUrls: ['./nav-selector-popover.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[style.top.px]': 'position().top',\n        '[style.left.px]': 'position().left',\n        '(click)': 'onClick($event)',\n        '(window:wheel)': 'onAnyScroll()',\n        '(window:focusin)': 'onFocusChanged($event)',\n        '(window:click)': 'onAnyClick($event)',\n    },\n    imports: [NgTemplateOutlet, NavSelectorPopoverItemComponent],\n})\nexport class NavSelectorPopoverComponent {\n    placement = input<NavSelectorPopoverPlacement>(NavSelectorPopoverPlacement.RIGHT);\n    popoverTitle = input<string>();\n    offset = input<Partial<{ mainAxis: number; crossAxis: number }>>({ mainAxis: 0, crossAxis: 0 });\n\n    items = contentChildren<TemplateRef<unknown>>('item');\n\n    displayed = signal(false);\n    navSelectorPopoverDisplayed = this.displayed.asReadonly();\n\n    position = signal({\n        top: 0,\n        left: 0,\n    });\n    parentEl = signal<ElementRef | null>(null);\n\n    mainAxisOffset = computed(() => this.offset().mainAxis ?? 0);\n    crossAxisOffset = computed(() => this.offset().crossAxis ?? 0);\n\n    constructor(private elementRef: ElementRef) {}\n\n    display(parentEl: ElementRef): void {\n        this.parentEl.set(parentEl);\n        this.displayed.set(true);\n        this.computePosition(parentEl);\n    }\n\n    hide() {\n        this.displayed.set(false);\n    }\n\n    toggle(parentEl: ElementRef): void {\n        this.parentEl.set(parentEl);\n        this.displayed.update(value => !value);\n        if (this.displayed()) {\n            this.computePosition(parentEl);\n        }\n    }\n\n    onClick(event: Event): void {\n        // Prevent click to be caught from element behind the popover (real bug)\n        event.stopImmediatePropagation();\n        this.displayed.set(false);\n    }\n\n    private computePosition(parentEl: ElementRef): void {\n        // Needed to wait first render and have the total height of the popover\n        setTimeout(() => {\n            const parentRect = parentEl.nativeElement.getBoundingClientRect();\n            if (!parentRect.top && !parentRect.left) {\n                this.displayed.set(false);\n            } else if (this.placement().startsWith('right')) {\n                this.computeRightPosition(parentEl);\n            } else if (this.placement().startsWith('bottom')) {\n                this.computeBottomPosition(parentEl);\n            }\n        });\n    }\n\n    private computeRightPosition(parentEl: ElementRef) {\n        const nativeEl = parentEl.nativeElement;\n        const rect = nativeEl.getBoundingClientRect();\n        let top = rect.top + (rect.height - nativeEl.offsetHeight) / 2 + this.crossAxisOffset();\n        const left = rect.left + rect.width + this.mainAxisOffset();\n\n        const elementEl = this.elementRef.nativeElement;\n\n        const popoverRect = elementEl.getBoundingClientRect();\n        if (top + elementEl.clientHeight > window.innerHeight) {\n            const popoverEl = document.querySelector('.nav-selector-popover') as Element;\n            const paddingBottom = parseInt(getComputedStyle(popoverEl).paddingBottom);\n            top = rect.top + rect.height - popoverRect.height + paddingBottom;\n        }\n\n        this.position.set({\n            top: top,\n            left: left,\n        });\n    }\n\n    private computeBottomPosition(parentEl: ElementRef) {\n        const nativeEl = parentEl.nativeElement;\n        const rect = nativeEl.getBoundingClientRect();\n        let top = rect.top + rect.height + this.mainAxisOffset();\n        let left = rect.left + (rect.width - nativeEl.offsetWidth) / 2 + this.crossAxisOffset();\n\n        if (this.placement() === NavSelectorPopoverPlacement.BOTTOM_START) {\n            left = rect.left;\n        }\n\n        const elementEl = this.elementRef.nativeElement;\n\n        const popoverRect = elementEl.getBoundingClientRect();\n        if (top + elementEl.clientHeight > window.innerHeight) {\n            top -= popoverRect.height + rect.height;\n        }\n\n        this.position.set({\n            top: top,\n            left: left,\n        });\n    }\n\n    onAnyScroll() {\n        const parent = this.parentEl();\n        if (parent) {\n            this.computePosition(parent);\n        }\n    }\n\n    onFocusChanged(event: FocusEvent) {\n        if (!this.elementRef.nativeElement.contains(event.target as Element)) {\n            this.displayed.set(false);\n        }\n    }\n\n    onAnyClick(event: Event) {\n        if (!this.elementRef.nativeElement.contains(event.target as Element)) {\n            this.displayed.set(false);\n        }\n    }\n}\n","@if (displayed()) {\n    <div class=\"nav-selector-popover\">\n        @if (popoverTitle()) {\n            <div class=\"nav-selector-popover__title\">{{ popoverTitle() }}</div>\n        }\n\n        @let itemsNotNull = items();\n\n        @if (itemsNotNull?.length) {\n            @for (item of itemsNotNull; track item) {\n                <ap-nav-selector-popover-item>\n                    <ng-container [ngTemplateOutlet]=\"item\"/>\n                </ap-nav-selector-popover-item>\n            }\n        } @else {\n            <ng-content select=\"[item]\"/>\n        }\n    </div>\n}\n"]}
|