@cuby-ui/core 0.0.199 → 0.0.200
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/components/button/button.component.d.ts +1 -1
- package/components/dropdown/dropdown-wrapper.component.d.ts +8 -0
- package/components/dropdown/dropdown.directive.d.ts +41 -0
- package/components/dropdown/dropdown.interfaces.d.ts +7 -0
- package/components/dropdown/index.d.ts +3 -0
- package/components/index.d.ts +1 -0
- package/esm2022/components/dropdown/dropdown-wrapper.component.mjs +18 -0
- package/esm2022/components/dropdown/dropdown.directive.mjs +179 -0
- package/esm2022/components/dropdown/dropdown.interfaces.mjs +2 -0
- package/esm2022/components/dropdown/index.mjs +3 -0
- package/esm2022/components/index.mjs +2 -1
- package/fesm2022/cuby-ui-core.mjs +188 -2
- package/fesm2022/cuby-ui-core.mjs.map +1 -1
- package/package.json +3 -3
- package/styles/global.scss +1 -0
- package/styles/mixins/flex.scss +21 -0
|
@@ -10,7 +10,7 @@ export declare class CuiButtonComponent implements CuiButtonOptions, OnInit {
|
|
|
10
10
|
protected readonly AppearanceIconColors: Record<CuiButtonOptions['appearance'], string>;
|
|
11
11
|
protected readonly COLOR_BASE_500 = "var(--cui-base-500)";
|
|
12
12
|
protected readonly BUTTON_ICONS_COLOR_BASE_500: CuiButtonOptions['appearance'][];
|
|
13
|
-
protected _appearance: "action" | "secondary" | "outlined" | "outlined-gray" | "ghost" | "flat" | "destructive"
|
|
13
|
+
protected _appearance: "link" | "action" | "secondary" | "outlined" | "outlined-gray" | "ghost" | "flat" | "destructive";
|
|
14
14
|
protected iconColor: string;
|
|
15
15
|
protected _size: "xxs" | "xs" | "sm" | "md";
|
|
16
16
|
protected iconDimensions: {
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "@cuby-ui/cdk";
|
|
3
|
+
export declare class CuiDropdownWrapperComponent {
|
|
4
|
+
title?: string;
|
|
5
|
+
width?: string;
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiDropdownWrapperComponent, never>;
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiDropdownWrapperComponent, "cui-dropdown-wrapper", never, { "title": { "alias": "title"; "required": false; }; "width": { "alias": "width"; "required": false; }; }, {}, never, ["[ccDropdownHeaderContent]", "*", "[ccDropdownFooterContent]"], true, [{ directive: typeof i1.CuiFocusTrapDirective; inputs: {}; outputs: {}; }]>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { OnDestroy, OnInit, TemplateRef } from '@angular/core';
|
|
2
|
+
import { EventEmitter } from '@angular/core';
|
|
3
|
+
import type { CuiDropdownOrientation } from './dropdown.interfaces';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class CuiDropdownDirective implements OnInit, OnDestroy {
|
|
6
|
+
private readonly document;
|
|
7
|
+
private readonly viewContainerRef;
|
|
8
|
+
private readonly target;
|
|
9
|
+
private readonly window;
|
|
10
|
+
private readonly SPACE_BETWEEN_TARGET_AND_LIST;
|
|
11
|
+
private readonly CONTAINER_SELECTOR;
|
|
12
|
+
private readonly DROPDOWN_SELECTOR;
|
|
13
|
+
private container;
|
|
14
|
+
private element;
|
|
15
|
+
private backdrop;
|
|
16
|
+
content: TemplateRef<unknown>;
|
|
17
|
+
orientation: CuiDropdownOrientation;
|
|
18
|
+
readonly isOpened: EventEmitter<boolean>;
|
|
19
|
+
private readonly isOpen;
|
|
20
|
+
private readonly targetToggleEventListener;
|
|
21
|
+
private elementResizeObserver;
|
|
22
|
+
constructor();
|
|
23
|
+
protected onResize(): void;
|
|
24
|
+
protected onClick(event: MouseEvent): void;
|
|
25
|
+
ngOnInit(): void;
|
|
26
|
+
ngOnDestroy(): void;
|
|
27
|
+
open(): void;
|
|
28
|
+
close(): void;
|
|
29
|
+
private initContainer;
|
|
30
|
+
private initDropdown;
|
|
31
|
+
private initTargetElementListener;
|
|
32
|
+
private initResizeObserver;
|
|
33
|
+
private destroyElementResizeObserver;
|
|
34
|
+
private changeDropdownYCoordinateIfNeeded;
|
|
35
|
+
private calculateDropdownPosition;
|
|
36
|
+
private changePositionX;
|
|
37
|
+
private changePositionY;
|
|
38
|
+
private findScrollableContainer;
|
|
39
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiDropdownDirective, never>;
|
|
40
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<CuiDropdownDirective, "[cuiDropdown]", ["cuiDropdown"], { "content": { "alias": "cuiDropdown"; "required": true; }; "orientation": { "alias": "orientation"; "required": false; }; }, { "isOpened": "isOpened"; }, never, never, true, never>;
|
|
41
|
+
}
|
package/components/index.d.ts
CHANGED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { NgIf } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
3
|
+
import { CuiFocusTrapDirective } from '@cuby-ui/cdk';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@cuby-ui/cdk";
|
|
6
|
+
export class CuiDropdownWrapperComponent {
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiDropdownWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
8
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CuiDropdownWrapperComponent, isStandalone: true, selector: "cui-dropdown-wrapper", inputs: { title: "title", width: "width" }, hostDirectives: [{ directive: i1.CuiFocusTrapDirective }], ngImport: i0, template: "<div\r\n [style.width]=\"width\"\r\n class=\"dropdown\"\r\n>\r\n <header *ngIf=\"title\" class=\"header\">\r\n <h3 class=\"title\">{{ title }}</h3>\r\n <ng-content select=\"[ccDropdownHeaderContent]\" />\r\n </header>\r\n\r\n <div class=\"scrollable-content\">\r\n <ng-content />\r\n </div>\r\n <footer class=\"footer\">\r\n <ng-content select=\"[ccDropdownFooterContent]\" />\r\n </footer>\r\n</div>\r\n", styles: [".dropdown{box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;padding-top:3px;padding-bottom:3px;display:flex;flex-direction:column;border-radius:8px;border:1px solid var(--cui-base-200);max-height:350px;height:100%;width:345px;background:var(--cui-base-0)}.header{padding-right:5px;padding-left:5px;display:flex;flex-direction:column;justify-content:center}.title{font-weight:400;font-size:14px;line-height:20px;padding:4px 8px;color:var(--cui-base-500);text-transform:uppercase}.scrollable-content{overflow:auto}.footer{padding:2px 5px}.footer:empty{display:contents}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiDropdownWrapperComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{ selector: 'cui-dropdown-wrapper', standalone: true, imports: [NgIf], changeDetection: ChangeDetectionStrategy.OnPush, hostDirectives: [CuiFocusTrapDirective], template: "<div\r\n [style.width]=\"width\"\r\n class=\"dropdown\"\r\n>\r\n <header *ngIf=\"title\" class=\"header\">\r\n <h3 class=\"title\">{{ title }}</h3>\r\n <ng-content select=\"[ccDropdownHeaderContent]\" />\r\n </header>\r\n\r\n <div class=\"scrollable-content\">\r\n <ng-content />\r\n </div>\r\n <footer class=\"footer\">\r\n <ng-content select=\"[ccDropdownFooterContent]\" />\r\n </footer>\r\n</div>\r\n", styles: [".dropdown{box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;padding-top:3px;padding-bottom:3px;display:flex;flex-direction:column;border-radius:8px;border:1px solid var(--cui-base-200);max-height:350px;height:100%;width:345px;background:var(--cui-base-0)}.header{padding-right:5px;padding-left:5px;display:flex;flex-direction:column;justify-content:center}.title{font-weight:400;font-size:14px;line-height:20px;padding:4px 8px;color:var(--cui-base-500);text-transform:uppercase}.scrollable-content{overflow:auto}.footer{padding:2px 5px}.footer:empty{display:contents}\n"] }]
|
|
13
|
+
}], propDecorators: { title: [{
|
|
14
|
+
type: Input
|
|
15
|
+
}], width: [{
|
|
16
|
+
type: Input
|
|
17
|
+
}] } });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24td3JhcHBlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZHJvcGRvd24vZHJvcGRvd24td3JhcHBlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZHJvcGRvd24vZHJvcGRvd24td3JhcHBlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sY0FBYyxDQUFDOzs7QUFXckQsTUFBTSxPQUFPLDJCQUEyQjsrR0FBM0IsMkJBQTJCO21HQUEzQiwyQkFBMkIsdUxDYnhDLDBjQWdCQSxvbkJEVGMsSUFBSTs7NEZBTUwsMkJBQTJCO2tCQVR2QyxTQUFTOytCQUNJLHNCQUFzQixjQUNwQixJQUFJLFdBQ1AsQ0FBQyxJQUFJLENBQUMsbUJBR0UsdUJBQXVCLENBQUMsTUFBTSxrQkFDL0IsQ0FBQyxxQkFBcUIsQ0FBQzs4QkFJaEMsS0FBSztzQkFEWCxLQUFLO2dCQUlDLEtBQUs7c0JBRFgsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nSWYgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDdWlGb2N1c1RyYXBEaXJlY3RpdmUgfSBmcm9tICdAY3VieS11aS9jZGsnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2N1aS1kcm9wZG93bi13cmFwcGVyJyxcclxuICAgIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgICBpbXBvcnRzOiBbTmdJZl0sXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vZHJvcGRvd24td3JhcHBlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9kcm9wZG93bi13cmFwcGVyLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIGhvc3REaXJlY3RpdmVzOiBbQ3VpRm9jdXNUcmFwRGlyZWN0aXZlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ3VpRHJvcGRvd25XcmFwcGVyQ29tcG9uZW50IHtcclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgdGl0bGU/OiBzdHJpbmc7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIHB1YmxpYyB3aWR0aD86IHN0cmluZztcclxufVxyXG4iLCI8ZGl2XHJcbiAgICBbc3R5bGUud2lkdGhdPVwid2lkdGhcIlxyXG4gICAgY2xhc3M9XCJkcm9wZG93blwiXHJcbj5cclxuICAgIDxoZWFkZXIgKm5nSWY9XCJ0aXRsZVwiIGNsYXNzPVwiaGVhZGVyXCI+XHJcbiAgICAgICAgPGgzIGNsYXNzPVwidGl0bGVcIj57eyB0aXRsZSB9fTwvaDM+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2NjRHJvcGRvd25IZWFkZXJDb250ZW50XVwiIC8+XHJcbiAgICA8L2hlYWRlcj5cclxuXHJcbiAgICA8ZGl2IGNsYXNzPVwic2Nyb2xsYWJsZS1jb250ZW50XCI+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQgLz5cclxuICAgIDwvZGl2PlxyXG4gICAgPGZvb3RlciBjbGFzcz1cImZvb3RlclwiPlxyXG4gICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIltjY0Ryb3Bkb3duRm9vdGVyQ29udGVudF1cIiAvPlxyXG4gICAgPC9mb290ZXI+XHJcbjwvZGl2PlxyXG4iXX0=
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
import { DOCUMENT } from '@angular/common';
|
|
2
|
+
import { Directive, ElementRef, EventEmitter, HostListener, inject, Input, Output, signal, ViewContainerRef } from '@angular/core';
|
|
3
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
|
+
import { CUI_WINDOW } from '@cuby-ui/cdk';
|
|
5
|
+
import { fromEvent } from 'rxjs';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class CuiDropdownDirective {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.document = inject(DOCUMENT);
|
|
10
|
+
this.viewContainerRef = inject(ViewContainerRef);
|
|
11
|
+
this.target = inject(ElementRef).nativeElement;
|
|
12
|
+
this.window = inject(CUI_WINDOW);
|
|
13
|
+
this.SPACE_BETWEEN_TARGET_AND_LIST = 5;
|
|
14
|
+
this.CONTAINER_SELECTOR = 'cui-dropdowns';
|
|
15
|
+
this.DROPDOWN_SELECTOR = 'cui-dropdown';
|
|
16
|
+
this.orientation = 'left';
|
|
17
|
+
this.isOpened = new EventEmitter();
|
|
18
|
+
this.isOpen = signal(false);
|
|
19
|
+
this.targetToggleEventListener = () => {
|
|
20
|
+
if (!this.isOpen()) {
|
|
21
|
+
this.open();
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
this.close();
|
|
25
|
+
};
|
|
26
|
+
this.initTargetElementListener();
|
|
27
|
+
}
|
|
28
|
+
onResize() {
|
|
29
|
+
this.close();
|
|
30
|
+
}
|
|
31
|
+
onClick(event) {
|
|
32
|
+
if (!this.isOpen()) {
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
const target = event.target;
|
|
36
|
+
const elements = this.document.elementsFromPoint(event.clientX, event.clientY);
|
|
37
|
+
const doesExist = elements.some((element) => this.element.contains(element));
|
|
38
|
+
if (this.target.contains(target) || this.element.contains(target) || doesExist) {
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
this.close();
|
|
42
|
+
}
|
|
43
|
+
ngOnInit() {
|
|
44
|
+
this.initContainer();
|
|
45
|
+
this.initDropdown();
|
|
46
|
+
}
|
|
47
|
+
ngOnDestroy() {
|
|
48
|
+
this.close();
|
|
49
|
+
this.destroyElementResizeObserver();
|
|
50
|
+
}
|
|
51
|
+
open() {
|
|
52
|
+
this.isOpen.set(true);
|
|
53
|
+
this.container.append(this.backdrop, this.element);
|
|
54
|
+
this.calculateDropdownPosition();
|
|
55
|
+
this.isOpened.emit(true);
|
|
56
|
+
}
|
|
57
|
+
close() {
|
|
58
|
+
this.isOpen.set(false);
|
|
59
|
+
this.element?.remove();
|
|
60
|
+
this.backdrop?.remove();
|
|
61
|
+
this.isOpened.emit(false);
|
|
62
|
+
}
|
|
63
|
+
initContainer() {
|
|
64
|
+
const root = this.document.querySelector('cui-dialogs');
|
|
65
|
+
const container = this.document.body.querySelector(this.CONTAINER_SELECTOR);
|
|
66
|
+
if (container) {
|
|
67
|
+
this.container = container;
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
this.container = this.document.createElement(this.CONTAINER_SELECTOR);
|
|
71
|
+
root?.after(this.container);
|
|
72
|
+
}
|
|
73
|
+
initDropdown() {
|
|
74
|
+
const content = this.viewContainerRef.createEmbeddedView(this.content).rootNodes;
|
|
75
|
+
this.element = this.document.createElement(this.DROPDOWN_SELECTOR);
|
|
76
|
+
this.backdrop = this.document.createElement('div');
|
|
77
|
+
this.element.style.top = '0';
|
|
78
|
+
this.element.style.position = 'absolute';
|
|
79
|
+
this.backdrop.style.position = 'fixed';
|
|
80
|
+
this.backdrop.style.inset = '0';
|
|
81
|
+
this.element.append(...content);
|
|
82
|
+
this.initResizeObserver();
|
|
83
|
+
}
|
|
84
|
+
initTargetElementListener() {
|
|
85
|
+
fromEvent(this.target, 'click').pipe(takeUntilDestroyed()).subscribe(this.targetToggleEventListener);
|
|
86
|
+
}
|
|
87
|
+
initResizeObserver() {
|
|
88
|
+
this.elementResizeObserver = new ResizeObserver(() => {
|
|
89
|
+
this.changeDropdownYCoordinateIfNeeded();
|
|
90
|
+
});
|
|
91
|
+
this.elementResizeObserver.observe(this.element);
|
|
92
|
+
}
|
|
93
|
+
destroyElementResizeObserver() {
|
|
94
|
+
this.elementResizeObserver.disconnect();
|
|
95
|
+
}
|
|
96
|
+
changeDropdownYCoordinateIfNeeded() {
|
|
97
|
+
const distanceToBottom = this.document.documentElement.clientHeight - this.element.getBoundingClientRect().bottom;
|
|
98
|
+
if (distanceToBottom >= 0) {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
this.element.style.top = parseFloat(this.element.style.top) + distanceToBottom + 'px';
|
|
102
|
+
}
|
|
103
|
+
calculateDropdownPosition() {
|
|
104
|
+
this.element.style.visibility = 'hidden';
|
|
105
|
+
setTimeout(() => {
|
|
106
|
+
const targetRect = this.target.getBoundingClientRect();
|
|
107
|
+
const container = this.findScrollableContainer(this.target);
|
|
108
|
+
const containerRect = container.getBoundingClientRect();
|
|
109
|
+
const { clientHeight, clientWidth } = this.document.documentElement;
|
|
110
|
+
const visibleTop = Math.max(targetRect.top, containerRect.top);
|
|
111
|
+
const visibleBottom = Math.min(targetRect.bottom, containerRect.bottom);
|
|
112
|
+
const dropdownHeight = this.element.offsetHeight;
|
|
113
|
+
const shouldListOpenAbove = clientHeight - visibleBottom < dropdownHeight;
|
|
114
|
+
const shouldListAlignLeft = targetRect.left + dropdownHeight > clientWidth;
|
|
115
|
+
const orientation = this.orientation ?? (shouldListAlignLeft ? 'left' : 'right');
|
|
116
|
+
this.changePositionY({ shouldListOpenAbove, visibleTop, visibleBottom, dropdownHeight });
|
|
117
|
+
this.changePositionX(orientation, clientWidth, targetRect);
|
|
118
|
+
this.element.style.visibility = 'visible';
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
changePositionX(orientation, clientWidth, targetRect) {
|
|
122
|
+
switch (orientation) {
|
|
123
|
+
case 'right':
|
|
124
|
+
this.element.style.left = 'auto';
|
|
125
|
+
this.element.style.right = `${clientWidth - targetRect.right}px`;
|
|
126
|
+
break;
|
|
127
|
+
case 'stretch':
|
|
128
|
+
this.element.style.left = `${targetRect.left}px`;
|
|
129
|
+
this.element.style.right = `${clientWidth - targetRect.right}px`;
|
|
130
|
+
break;
|
|
131
|
+
default:
|
|
132
|
+
this.element.style.right = 'auto';
|
|
133
|
+
this.element.style.left = `${targetRect.left}px`;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
changePositionY({ shouldListOpenAbove, visibleTop, visibleBottom, dropdownHeight }) {
|
|
137
|
+
const offset = this.SPACE_BETWEEN_TARGET_AND_LIST;
|
|
138
|
+
if (shouldListOpenAbove) {
|
|
139
|
+
this.element.style.top = `${this.window.scrollY + visibleTop - dropdownHeight - offset}px`;
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
this.element.style.top = `${this.window.scrollY + visibleBottom + offset}px`;
|
|
143
|
+
}
|
|
144
|
+
findScrollableContainer(element) {
|
|
145
|
+
let parent = element.parentElement;
|
|
146
|
+
while (parent) {
|
|
147
|
+
const { overflowY } = window.getComputedStyle(parent);
|
|
148
|
+
if (overflowY === 'auto' || overflowY === 'scroll') {
|
|
149
|
+
return parent;
|
|
150
|
+
}
|
|
151
|
+
parent = parent.parentElement;
|
|
152
|
+
}
|
|
153
|
+
return this.document.body;
|
|
154
|
+
}
|
|
155
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiDropdownDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
156
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CuiDropdownDirective, isStandalone: true, selector: "[cuiDropdown]", inputs: { content: ["cuiDropdown", "content"], orientation: "orientation" }, outputs: { isOpened: "isOpened" }, host: { listeners: { "window:resize": "onResize()", "document:click": "onClick($event)" } }, exportAs: ["cuiDropdown"], ngImport: i0 }); }
|
|
157
|
+
}
|
|
158
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiDropdownDirective, decorators: [{
|
|
159
|
+
type: Directive,
|
|
160
|
+
args: [{
|
|
161
|
+
selector: '[cuiDropdown]',
|
|
162
|
+
exportAs: 'cuiDropdown',
|
|
163
|
+
standalone: true,
|
|
164
|
+
}]
|
|
165
|
+
}], ctorParameters: function () { return []; }, propDecorators: { content: [{
|
|
166
|
+
type: Input,
|
|
167
|
+
args: [{ required: true, alias: 'cuiDropdown' }]
|
|
168
|
+
}], orientation: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], isOpened: [{
|
|
171
|
+
type: Output
|
|
172
|
+
}], onResize: [{
|
|
173
|
+
type: HostListener,
|
|
174
|
+
args: ['window:resize']
|
|
175
|
+
}], onClick: [{
|
|
176
|
+
type: HostListener,
|
|
177
|
+
args: ['document:click', ['$event']]
|
|
178
|
+
}] } });
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/core/components/dropdown/dropdown.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACnI,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;AASjC,MAAM,OAAO,oBAAoB;IAmC7B;QAlCiB,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5B,qBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAC5C,WAAM,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,aAAa,CAAC;QAC1C,WAAM,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAE5B,kCAA6B,GAAG,CAAC,CAAC;QAClC,uBAAkB,GAAG,eAAe,CAAC;QACrC,sBAAiB,GAAG,cAAc,CAAC;QAU7C,gBAAW,GAA2B,MAAM,CAAC;QAGpC,aAAQ,GAAG,IAAI,YAAY,EAAW,CAAC;QAEtC,WAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACvB,8BAAyB,GAAG,GAAS,EAAE;YACpD,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE;gBAChB,IAAI,CAAC,IAAI,EAAE,CAAC;gBAEZ,OAAO;aACV;YAED,IAAI,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC,CAAC;QAIE,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACrC,CAAC;IAGS,QAAQ;QACd,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAGS,OAAO,CAAC,KAAiB;QAC/B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE;YAChB,OAAO;SACV;QAED,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;QAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;QAC/E,MAAM,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;QAE7E,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,SAAS,EAAE;YAC5E,OAAO;SACV;QAED,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,IAAI,CAAC,4BAA4B,EAAE,CAAC;IACxC,CAAC;IAEM,IAAI;QACP,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACnD,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAEM,KAAK;QACR,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,CAAC;QACvB,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC;QACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAEO,aAAa;QACjB,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QACxD,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAE5E,IAAI,SAAS,EAAE;YACX,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAE3B,OAAO;SACV;QAED,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAEtE,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAChC,CAAC;IAEO,YAAY;QAChB,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;QACjF,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACnE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAEnD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,CAAC;QAC7B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC;QACzC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;QACvC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC;QAChC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC;QAEhC,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAEO,yBAAyB;QAC7B,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;IACzG,CAAC;IAEO,kBAAkB;QACtB,IAAI,CAAC,qBAAqB,GAAG,IAAI,cAAc,CAAC,GAAG,EAAE;YACjD,IAAI,CAAC,iCAAiC,EAAE,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrD,CAAC;IAEO,4BAA4B;QAChC,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE,CAAC;IAC5C,CAAC;IAEO,iCAAiC;QACrC,MAAM,gBAAgB,GAClB,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC,MAAM,CAAC;QAE7F,IAAI,gBAAgB,IAAI,CAAC,EAAE;YACvB,OAAO;SACV;QAED,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,gBAAgB,GAAG,IAAI,CAAC;IAC1F,CAAC;IAEO,yBAAyB;QAC7B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC;QAEzC,UAAU,CAAC,GAAG,EAAE;YACZ,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC;YACvD,MAAM,SAAS,GAAG,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC5D,MAAM,aAAa,GAAG,SAAS,CAAC,qBAAqB,EAAE,CAAC;YACxD,MAAM,EAAE,YAAY,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;YACpE,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;YAC/D,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;YACxE,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;YAEjD,MAAM,mBAAmB,GAAG,YAAY,GAAG,aAAa,GAAG,cAAc,CAAC;YAC1E,MAAM,mBAAmB,GAAG,UAAU,CAAC,IAAI,GAAG,cAAc,GAAG,WAAW,CAAC;YAC3E,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;YAEjF,IAAI,CAAC,eAAe,CAAC,EAAE,mBAAmB,EAAE,UAAU,EAAE,aAAa,EAAE,cAAc,EAAE,CAAC,CAAC;YACzF,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;YAE3D,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG,SAAS,CAAC;QAC9C,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,eAAe,CAAC,WAAmB,EAAE,WAAmB,EAAE,UAAmB;QACjF,QAAQ,WAAW,EAAE;YACjB,KAAK,OAAO;gBACR,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC;gBACjC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,WAAW,GAAG,UAAU,CAAC,KAAK,IAAI,CAAC;gBACjE,MAAM;YAEV,KAAK,SAAS;gBACV,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,UAAU,CAAC,IAAI,IAAI,CAAC;gBACjD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,WAAW,GAAG,UAAU,CAAC,KAAK,IAAI,CAAC;gBACjE,MAAM;YAEV;gBACI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC;gBAClC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,UAAU,CAAC,IAAI,IAAI,CAAC;SACxD;IACL,CAAC;IAEO,eAAe,CAAC,EACpB,mBAAmB,EACnB,UAAU,EACV,aAAa,EACb,cAAc,EACM;QACpB,MAAM,MAAM,GAAG,IAAI,CAAC,6BAA6B,CAAC;QAElD,IAAI,mBAAmB,EAAE;YACrB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,UAAU,GAAG,cAAc,GAAG,MAAM,IAAI,CAAC;YAE3F,OAAO;SACV;QAED,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,aAAa,GAAG,MAAM,IAAI,CAAC;IACjF,CAAC;IAEO,uBAAuB,CAAC,OAAoB;QAChD,IAAI,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC;QAEnC,OAAO,MAAM,EAAE;YACX,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAEtD,IAAI,SAAS,KAAK,MAAM,IAAI,SAAS,KAAK,QAAQ,EAAE;gBAChD,OAAO,MAAM,CAAC;aACjB;YAED,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;SACjC;QAED,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;IAC9B,CAAC;+GArNQ,oBAAoB;mGAApB,oBAAoB;;4FAApB,oBAAoB;kBALhC,SAAS;mBAAC;oBACP,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE,aAAa;oBACvB,UAAU,EAAE,IAAI;iBACnB;0EAgBU,OAAO;sBADb,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,aAAa,EAAE;gBAIxC,WAAW;sBADjB,KAAK;gBAIU,QAAQ;sBADvB,MAAM;gBAoBG,QAAQ;sBADjB,YAAY;uBAAC,eAAe;gBAMnB,OAAO;sBADhB,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { DOCUMENT } from '@angular/common';\r\nimport type { OnDestroy, OnInit, TemplateRef } from '@angular/core';\r\nimport { Directive, ElementRef, EventEmitter, HostListener, inject, Input, Output, signal, ViewContainerRef } from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { CUI_WINDOW } from '@cuby-ui/cdk';\r\nimport { fromEvent } from 'rxjs';\r\n\r\nimport type { ChangePositionYParams, CuiDropdownOrientation } from './dropdown.interfaces';\r\n\r\n@Directive({\r\n    selector: '[cuiDropdown]',\r\n    exportAs: 'cuiDropdown',\r\n    standalone: true,\r\n})\r\nexport class CuiDropdownDirective implements OnInit, OnDestroy {\r\n    private readonly document = inject(DOCUMENT);\r\n    private readonly viewContainerRef = inject(ViewContainerRef);\r\n    private readonly target = inject(ElementRef).nativeElement;\r\n    private readonly window = inject(CUI_WINDOW);\r\n\r\n    private readonly SPACE_BETWEEN_TARGET_AND_LIST = 5;\r\n    private readonly CONTAINER_SELECTOR = 'cui-dropdowns';\r\n    private readonly DROPDOWN_SELECTOR = 'cui-dropdown';\r\n\r\n    private container!: Element;\r\n    private element!: HTMLElement;\r\n    private backdrop!: HTMLDivElement;\r\n\r\n    @Input({ required: true, alias: 'cuiDropdown' })\r\n    public content!: TemplateRef<unknown>;\r\n\r\n    @Input()\r\n    public orientation: CuiDropdownOrientation = 'left';\r\n\r\n    @Output()\r\n    public readonly isOpened = new EventEmitter<boolean>();\r\n\r\n    private readonly isOpen = signal(false);\r\n    private readonly targetToggleEventListener = (): void => {\r\n        if (!this.isOpen()) {\r\n            this.open();\r\n\r\n            return;\r\n        }\r\n\r\n        this.close();\r\n    };\r\n    private elementResizeObserver!: ResizeObserver;\r\n\r\n    constructor() {\r\n        this.initTargetElementListener();\r\n    }\r\n\r\n    @HostListener('window:resize')\r\n    protected onResize(): void {\r\n        this.close();\r\n    }\r\n\r\n    @HostListener('document:click', ['$event'])\r\n    protected onClick(event: MouseEvent): void {\r\n        if (!this.isOpen()) {\r\n            return;\r\n        }\r\n\r\n        const target = event.target as HTMLElement;\r\n        const elements = this.document.elementsFromPoint(event.clientX, event.clientY);\r\n        const doesExist = elements.some((element) => this.element.contains(element));\r\n\r\n        if (this.target.contains(target) || this.element.contains(target) || doesExist) {\r\n            return;\r\n        }\r\n\r\n        this.close();\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.initContainer();\r\n        this.initDropdown();\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.close();\r\n        this.destroyElementResizeObserver();\r\n    }\r\n\r\n    public open(): void {\r\n        this.isOpen.set(true);\r\n        this.container.append(this.backdrop, this.element);\r\n        this.calculateDropdownPosition();\r\n        this.isOpened.emit(true);\r\n    }\r\n\r\n    public close(): void {\r\n        this.isOpen.set(false);\r\n        this.element?.remove();\r\n        this.backdrop?.remove();\r\n        this.isOpened.emit(false);\r\n    }\r\n\r\n    private initContainer(): void {\r\n        const root = this.document.querySelector('cui-dialogs');\r\n        const container = this.document.body.querySelector(this.CONTAINER_SELECTOR);\r\n\r\n        if (container) {\r\n            this.container = container;\r\n\r\n            return;\r\n        }\r\n\r\n        this.container = this.document.createElement(this.CONTAINER_SELECTOR);\r\n\r\n        root?.after(this.container);\r\n    }\r\n\r\n    private initDropdown(): void {\r\n        const content = this.viewContainerRef.createEmbeddedView(this.content).rootNodes;\r\n        this.element = this.document.createElement(this.DROPDOWN_SELECTOR);\r\n        this.backdrop = this.document.createElement('div');\r\n\r\n        this.element.style.top = '0';\r\n        this.element.style.position = 'absolute';\r\n        this.backdrop.style.position = 'fixed';\r\n        this.backdrop.style.inset = '0';\r\n        this.element.append(...content);\r\n\r\n        this.initResizeObserver();\r\n    }\r\n\r\n    private initTargetElementListener(): void {\r\n        fromEvent(this.target, 'click').pipe(takeUntilDestroyed()).subscribe(this.targetToggleEventListener);\r\n    }\r\n\r\n    private initResizeObserver(): void {\r\n        this.elementResizeObserver = new ResizeObserver(() => {\r\n            this.changeDropdownYCoordinateIfNeeded();\r\n        });\r\n\r\n        this.elementResizeObserver.observe(this.element);\r\n    }\r\n\r\n    private destroyElementResizeObserver(): void {\r\n        this.elementResizeObserver.disconnect();\r\n    }\r\n\r\n    private changeDropdownYCoordinateIfNeeded(): void {\r\n        const distanceToBottom =\r\n            this.document.documentElement.clientHeight - this.element.getBoundingClientRect().bottom;\r\n\r\n        if (distanceToBottom >= 0) {\r\n            return;\r\n        }\r\n\r\n        this.element.style.top = parseFloat(this.element.style.top) + distanceToBottom + 'px';\r\n    }\r\n\r\n    private calculateDropdownPosition(): void {\r\n        this.element.style.visibility = 'hidden';\r\n\r\n        setTimeout(() => {\r\n            const targetRect = this.target.getBoundingClientRect();\r\n            const container = this.findScrollableContainer(this.target);\r\n            const containerRect = container.getBoundingClientRect();\r\n            const { clientHeight, clientWidth } = this.document.documentElement;\r\n            const visibleTop = Math.max(targetRect.top, containerRect.top);\r\n            const visibleBottom = Math.min(targetRect.bottom, containerRect.bottom);\r\n            const dropdownHeight = this.element.offsetHeight;\r\n\r\n            const shouldListOpenAbove = clientHeight - visibleBottom < dropdownHeight;\r\n            const shouldListAlignLeft = targetRect.left + dropdownHeight > clientWidth;\r\n            const orientation = this.orientation ?? (shouldListAlignLeft ? 'left' : 'right');\r\n\r\n            this.changePositionY({ shouldListOpenAbove, visibleTop, visibleBottom, dropdownHeight });\r\n            this.changePositionX(orientation, clientWidth, targetRect);\r\n\r\n            this.element.style.visibility = 'visible';\r\n        });\r\n    }\r\n\r\n    private changePositionX(orientation: string, clientWidth: number, targetRect: DOMRect): void {\r\n        switch (orientation) {\r\n            case 'right':\r\n                this.element.style.left = 'auto';\r\n                this.element.style.right = `${clientWidth - targetRect.right}px`;\r\n                break;\r\n\r\n            case 'stretch':\r\n                this.element.style.left = `${targetRect.left}px`;\r\n                this.element.style.right = `${clientWidth - targetRect.right}px`;\r\n                break;\r\n\r\n            default:\r\n                this.element.style.right = 'auto';\r\n                this.element.style.left = `${targetRect.left}px`;\r\n        }\r\n    }\r\n\r\n    private changePositionY({\r\n        shouldListOpenAbove,\r\n        visibleTop,\r\n        visibleBottom,\r\n        dropdownHeight\r\n    }: ChangePositionYParams): void {\r\n        const offset = this.SPACE_BETWEEN_TARGET_AND_LIST;\r\n\r\n        if (shouldListOpenAbove) {\r\n            this.element.style.top = `${this.window.scrollY + visibleTop - dropdownHeight - offset}px`;\r\n\r\n            return;\r\n        }\r\n\r\n        this.element.style.top = `${this.window.scrollY + visibleBottom + offset}px`;\r\n    }\r\n\r\n    private findScrollableContainer(element: HTMLElement): HTMLElement {\r\n        let parent = element.parentElement;\r\n\r\n        while (parent) {\r\n            const { overflowY } = window.getComputedStyle(parent);\r\n\r\n            if (overflowY === 'auto' || overflowY === 'scroll') {\r\n                return parent;\r\n            }\r\n\r\n            parent = parent.parentElement;\r\n        }\r\n\r\n        return this.document.body;\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9kcm9wZG93bi9kcm9wZG93bi5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIENoYW5nZVBvc2l0aW9uWVBhcmFtcyB7XHJcbiAgICBzaG91bGRMaXN0T3BlbkFib3ZlOiBib29sZWFuO1xyXG4gICAgdmlzaWJsZVRvcDogbnVtYmVyO1xyXG4gICAgdmlzaWJsZUJvdHRvbTogbnVtYmVyO1xyXG4gICAgZHJvcGRvd25IZWlnaHQ6IG51bWJlcjtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQ3VpRHJvcGRvd25PcmllbnRhdGlvbiA9ICdsZWZ0JyB8ICdyaWdodCcgfCAnc3RyZXRjaCc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { CuiDropdownDirective } from './dropdown.directive';
|
|
2
|
+
export { CuiDropdownWrapperComponent } from './dropdown-wrapper.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZHJvcGRvd24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFNUQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBDdWlEcm9wZG93bkRpcmVjdGl2ZSB9IGZyb20gJy4vZHJvcGRvd24uZGlyZWN0aXZlJztcclxuZXhwb3J0IHsgQ3VpRHJvcGRvd25PcmllbnRhdGlvbiB9IGZyb20gJy4vZHJvcGRvd24uaW50ZXJmYWNlcyc7XHJcbmV4cG9ydCB7IEN1aURyb3Bkb3duV3JhcHBlckNvbXBvbmVudCB9IGZyb20gJy4vZHJvcGRvd24td3JhcHBlci5jb21wb25lbnQnO1xyXG4iXX0=
|
|
@@ -8,6 +8,7 @@ export * from './button-group';
|
|
|
8
8
|
export * from './checkbox';
|
|
9
9
|
export * from './context-menu';
|
|
10
10
|
export * from './dialog';
|
|
11
|
+
export * from './dropdown';
|
|
11
12
|
export * from './form-field';
|
|
12
13
|
export * from './hint';
|
|
13
14
|
export * from './icon-button';
|
|
@@ -25,4 +26,4 @@ export * from './svg';
|
|
|
25
26
|
export * from './tabs';
|
|
26
27
|
export * from './textarea';
|
|
27
28
|
export * from './toggle';
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsT0FBTyxDQUFDO0FBQ3RCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY2NvcmRpb24nO1xyXG5leHBvcnQgKiBmcm9tICcuL2FsZXJ0JztcclxuZXhwb3J0ICogZnJvbSAnLi9iYWRnZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYmFubmVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9icmVhZGNydW1icyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uJztcclxuZXhwb3J0ICogZnJvbSAnLi9idXR0b24tZ3JvdXAnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NoZWNrYm94JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LW1lbnUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2RpYWxvZyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZHJvcGRvd24nO1xyXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0tZmllbGQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2hpbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2ljb24tYnV0dG9uJztcclxuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1udW1iZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2lucHV0LXBhc3N3b3JkJztcclxuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC10ZXh0JztcclxuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC10aW1lJztcclxuZXhwb3J0ICogZnJvbSAnLi9sYWJlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGV0dGVyLWJveCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbm90aWZpY2F0aW9uJztcclxuZXhwb3J0ICogZnJvbSAnLi9yYWRpbyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcm9vdCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0JztcclxuZXhwb3J0ICogZnJvbSAnLi9zdmcnO1xyXG5leHBvcnQgKiBmcm9tICcuL3RhYnMnO1xyXG5leHBvcnQgKiBmcm9tICcuL3RleHRhcmVhJztcclxuZXhwb3J0ICogZnJvbSAnLi90b2dnbGUnO1xyXG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { Component, ChangeDetectionStrategy, InjectionToken, inject, Input, HostBinding, ChangeDetectorRef, ElementRef, ViewChild, EventEmitter, Output, NgModule, Injector, Injectable, SkipSelf, Optional, DestroyRef, Directive, NgZone, TemplateRef, ContentChildren, HostListener, Self, signal, INJECTOR, forwardRef, ViewContainerRef } from '@angular/core';
|
|
3
3
|
import * as i1 from '@angular/common';
|
|
4
|
-
import { CommonModule, DOCUMENT, NgForOf } from '@angular/common';
|
|
4
|
+
import { CommonModule, DOCUMENT, NgForOf, NgIf } from '@angular/common';
|
|
5
5
|
import * as i1$1 from '@cuby-ui/cdk';
|
|
6
6
|
import { CUI_WINDOW, cuiCreateToken, cuiCreateTokenFromFactory, CuiDestroyService, CuiFilterPipe, CuiLetDirective, CuiPopoverService, cuiProvide, CUI_ANIMATION_FRAME, cuiZonefree, EMPTY_CLIENT_RECT, cuiInjectElement, CUI_LOCAL_STORAGE, CUI_IS_WEBKIT, CuiItemDirective, CuiActiveZone, CuiFocusTrapDirective, cuiGetElementObscures, CUI_IS_MOBILE, CuiHoveredService, cuiPure, cuiPointToClientRect, cuiClamp, cuiPx, cuiIfMap, cuiIsPresent, cuiTypedFromEvent, cuiZonefreeScheduler, cuiZoneOptimized, cuiIsNativeFocused, CuiClickOutsideDirective, CuiTargetDirective, cuiGetClosestFocusable, CuiTime, CuiAutoResizingDirective } from '@cuby-ui/cdk';
|
|
7
7
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
@@ -2294,6 +2294,192 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
2294
2294
|
}]
|
|
2295
2295
|
}] });
|
|
2296
2296
|
|
|
2297
|
+
class CuiDropdownDirective {
|
|
2298
|
+
constructor() {
|
|
2299
|
+
this.document = inject(DOCUMENT);
|
|
2300
|
+
this.viewContainerRef = inject(ViewContainerRef);
|
|
2301
|
+
this.target = inject(ElementRef).nativeElement;
|
|
2302
|
+
this.window = inject(CUI_WINDOW);
|
|
2303
|
+
this.SPACE_BETWEEN_TARGET_AND_LIST = 5;
|
|
2304
|
+
this.CONTAINER_SELECTOR = 'cui-dropdowns';
|
|
2305
|
+
this.DROPDOWN_SELECTOR = 'cui-dropdown';
|
|
2306
|
+
this.orientation = 'left';
|
|
2307
|
+
this.isOpened = new EventEmitter();
|
|
2308
|
+
this.isOpen = signal(false);
|
|
2309
|
+
this.targetToggleEventListener = () => {
|
|
2310
|
+
if (!this.isOpen()) {
|
|
2311
|
+
this.open();
|
|
2312
|
+
return;
|
|
2313
|
+
}
|
|
2314
|
+
this.close();
|
|
2315
|
+
};
|
|
2316
|
+
this.initTargetElementListener();
|
|
2317
|
+
}
|
|
2318
|
+
onResize() {
|
|
2319
|
+
this.close();
|
|
2320
|
+
}
|
|
2321
|
+
onClick(event) {
|
|
2322
|
+
if (!this.isOpen()) {
|
|
2323
|
+
return;
|
|
2324
|
+
}
|
|
2325
|
+
const target = event.target;
|
|
2326
|
+
const elements = this.document.elementsFromPoint(event.clientX, event.clientY);
|
|
2327
|
+
const doesExist = elements.some((element) => this.element.contains(element));
|
|
2328
|
+
if (this.target.contains(target) || this.element.contains(target) || doesExist) {
|
|
2329
|
+
return;
|
|
2330
|
+
}
|
|
2331
|
+
this.close();
|
|
2332
|
+
}
|
|
2333
|
+
ngOnInit() {
|
|
2334
|
+
this.initContainer();
|
|
2335
|
+
this.initDropdown();
|
|
2336
|
+
}
|
|
2337
|
+
ngOnDestroy() {
|
|
2338
|
+
this.close();
|
|
2339
|
+
this.destroyElementResizeObserver();
|
|
2340
|
+
}
|
|
2341
|
+
open() {
|
|
2342
|
+
this.isOpen.set(true);
|
|
2343
|
+
this.container.append(this.backdrop, this.element);
|
|
2344
|
+
this.calculateDropdownPosition();
|
|
2345
|
+
this.isOpened.emit(true);
|
|
2346
|
+
}
|
|
2347
|
+
close() {
|
|
2348
|
+
this.isOpen.set(false);
|
|
2349
|
+
this.element?.remove();
|
|
2350
|
+
this.backdrop?.remove();
|
|
2351
|
+
this.isOpened.emit(false);
|
|
2352
|
+
}
|
|
2353
|
+
initContainer() {
|
|
2354
|
+
const root = this.document.querySelector('cui-dialogs');
|
|
2355
|
+
const container = this.document.body.querySelector(this.CONTAINER_SELECTOR);
|
|
2356
|
+
if (container) {
|
|
2357
|
+
this.container = container;
|
|
2358
|
+
return;
|
|
2359
|
+
}
|
|
2360
|
+
this.container = this.document.createElement(this.CONTAINER_SELECTOR);
|
|
2361
|
+
root?.after(this.container);
|
|
2362
|
+
}
|
|
2363
|
+
initDropdown() {
|
|
2364
|
+
const content = this.viewContainerRef.createEmbeddedView(this.content).rootNodes;
|
|
2365
|
+
this.element = this.document.createElement(this.DROPDOWN_SELECTOR);
|
|
2366
|
+
this.backdrop = this.document.createElement('div');
|
|
2367
|
+
this.element.style.top = '0';
|
|
2368
|
+
this.element.style.position = 'absolute';
|
|
2369
|
+
this.backdrop.style.position = 'fixed';
|
|
2370
|
+
this.backdrop.style.inset = '0';
|
|
2371
|
+
this.element.append(...content);
|
|
2372
|
+
this.initResizeObserver();
|
|
2373
|
+
}
|
|
2374
|
+
initTargetElementListener() {
|
|
2375
|
+
fromEvent(this.target, 'click').pipe(takeUntilDestroyed()).subscribe(this.targetToggleEventListener);
|
|
2376
|
+
}
|
|
2377
|
+
initResizeObserver() {
|
|
2378
|
+
this.elementResizeObserver = new ResizeObserver(() => {
|
|
2379
|
+
this.changeDropdownYCoordinateIfNeeded();
|
|
2380
|
+
});
|
|
2381
|
+
this.elementResizeObserver.observe(this.element);
|
|
2382
|
+
}
|
|
2383
|
+
destroyElementResizeObserver() {
|
|
2384
|
+
this.elementResizeObserver.disconnect();
|
|
2385
|
+
}
|
|
2386
|
+
changeDropdownYCoordinateIfNeeded() {
|
|
2387
|
+
const distanceToBottom = this.document.documentElement.clientHeight - this.element.getBoundingClientRect().bottom;
|
|
2388
|
+
if (distanceToBottom >= 0) {
|
|
2389
|
+
return;
|
|
2390
|
+
}
|
|
2391
|
+
this.element.style.top = parseFloat(this.element.style.top) + distanceToBottom + 'px';
|
|
2392
|
+
}
|
|
2393
|
+
calculateDropdownPosition() {
|
|
2394
|
+
this.element.style.visibility = 'hidden';
|
|
2395
|
+
setTimeout(() => {
|
|
2396
|
+
const targetRect = this.target.getBoundingClientRect();
|
|
2397
|
+
const container = this.findScrollableContainer(this.target);
|
|
2398
|
+
const containerRect = container.getBoundingClientRect();
|
|
2399
|
+
const { clientHeight, clientWidth } = this.document.documentElement;
|
|
2400
|
+
const visibleTop = Math.max(targetRect.top, containerRect.top);
|
|
2401
|
+
const visibleBottom = Math.min(targetRect.bottom, containerRect.bottom);
|
|
2402
|
+
const dropdownHeight = this.element.offsetHeight;
|
|
2403
|
+
const shouldListOpenAbove = clientHeight - visibleBottom < dropdownHeight;
|
|
2404
|
+
const shouldListAlignLeft = targetRect.left + dropdownHeight > clientWidth;
|
|
2405
|
+
const orientation = this.orientation ?? (shouldListAlignLeft ? 'left' : 'right');
|
|
2406
|
+
this.changePositionY({ shouldListOpenAbove, visibleTop, visibleBottom, dropdownHeight });
|
|
2407
|
+
this.changePositionX(orientation, clientWidth, targetRect);
|
|
2408
|
+
this.element.style.visibility = 'visible';
|
|
2409
|
+
});
|
|
2410
|
+
}
|
|
2411
|
+
changePositionX(orientation, clientWidth, targetRect) {
|
|
2412
|
+
switch (orientation) {
|
|
2413
|
+
case 'right':
|
|
2414
|
+
this.element.style.left = 'auto';
|
|
2415
|
+
this.element.style.right = `${clientWidth - targetRect.right}px`;
|
|
2416
|
+
break;
|
|
2417
|
+
case 'stretch':
|
|
2418
|
+
this.element.style.left = `${targetRect.left}px`;
|
|
2419
|
+
this.element.style.right = `${clientWidth - targetRect.right}px`;
|
|
2420
|
+
break;
|
|
2421
|
+
default:
|
|
2422
|
+
this.element.style.right = 'auto';
|
|
2423
|
+
this.element.style.left = `${targetRect.left}px`;
|
|
2424
|
+
}
|
|
2425
|
+
}
|
|
2426
|
+
changePositionY({ shouldListOpenAbove, visibleTop, visibleBottom, dropdownHeight }) {
|
|
2427
|
+
const offset = this.SPACE_BETWEEN_TARGET_AND_LIST;
|
|
2428
|
+
if (shouldListOpenAbove) {
|
|
2429
|
+
this.element.style.top = `${this.window.scrollY + visibleTop - dropdownHeight - offset}px`;
|
|
2430
|
+
return;
|
|
2431
|
+
}
|
|
2432
|
+
this.element.style.top = `${this.window.scrollY + visibleBottom + offset}px`;
|
|
2433
|
+
}
|
|
2434
|
+
findScrollableContainer(element) {
|
|
2435
|
+
let parent = element.parentElement;
|
|
2436
|
+
while (parent) {
|
|
2437
|
+
const { overflowY } = window.getComputedStyle(parent);
|
|
2438
|
+
if (overflowY === 'auto' || overflowY === 'scroll') {
|
|
2439
|
+
return parent;
|
|
2440
|
+
}
|
|
2441
|
+
parent = parent.parentElement;
|
|
2442
|
+
}
|
|
2443
|
+
return this.document.body;
|
|
2444
|
+
}
|
|
2445
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiDropdownDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
2446
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CuiDropdownDirective, isStandalone: true, selector: "[cuiDropdown]", inputs: { content: ["cuiDropdown", "content"], orientation: "orientation" }, outputs: { isOpened: "isOpened" }, host: { listeners: { "window:resize": "onResize()", "document:click": "onClick($event)" } }, exportAs: ["cuiDropdown"], ngImport: i0 }); }
|
|
2447
|
+
}
|
|
2448
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiDropdownDirective, decorators: [{
|
|
2449
|
+
type: Directive,
|
|
2450
|
+
args: [{
|
|
2451
|
+
selector: '[cuiDropdown]',
|
|
2452
|
+
exportAs: 'cuiDropdown',
|
|
2453
|
+
standalone: true,
|
|
2454
|
+
}]
|
|
2455
|
+
}], ctorParameters: function () { return []; }, propDecorators: { content: [{
|
|
2456
|
+
type: Input,
|
|
2457
|
+
args: [{ required: true, alias: 'cuiDropdown' }]
|
|
2458
|
+
}], orientation: [{
|
|
2459
|
+
type: Input
|
|
2460
|
+
}], isOpened: [{
|
|
2461
|
+
type: Output
|
|
2462
|
+
}], onResize: [{
|
|
2463
|
+
type: HostListener,
|
|
2464
|
+
args: ['window:resize']
|
|
2465
|
+
}], onClick: [{
|
|
2466
|
+
type: HostListener,
|
|
2467
|
+
args: ['document:click', ['$event']]
|
|
2468
|
+
}] } });
|
|
2469
|
+
|
|
2470
|
+
class CuiDropdownWrapperComponent {
|
|
2471
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiDropdownWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2472
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CuiDropdownWrapperComponent, isStandalone: true, selector: "cui-dropdown-wrapper", inputs: { title: "title", width: "width" }, hostDirectives: [{ directive: i1$1.CuiFocusTrapDirective }], ngImport: i0, template: "<div\r\n [style.width]=\"width\"\r\n class=\"dropdown\"\r\n>\r\n <header *ngIf=\"title\" class=\"header\">\r\n <h3 class=\"title\">{{ title }}</h3>\r\n <ng-content select=\"[ccDropdownHeaderContent]\" />\r\n </header>\r\n\r\n <div class=\"scrollable-content\">\r\n <ng-content />\r\n </div>\r\n <footer class=\"footer\">\r\n <ng-content select=\"[ccDropdownFooterContent]\" />\r\n </footer>\r\n</div>\r\n", styles: [".dropdown{box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;padding-top:3px;padding-bottom:3px;display:flex;flex-direction:column;border-radius:8px;border:1px solid var(--cui-base-200);max-height:350px;height:100%;width:345px;background:var(--cui-base-0)}.header{padding-right:5px;padding-left:5px;display:flex;flex-direction:column;justify-content:center}.title{font-weight:400;font-size:14px;line-height:20px;padding:4px 8px;color:var(--cui-base-500);text-transform:uppercase}.scrollable-content{overflow:auto}.footer{padding:2px 5px}.footer:empty{display:contents}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
2473
|
+
}
|
|
2474
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiDropdownWrapperComponent, decorators: [{
|
|
2475
|
+
type: Component,
|
|
2476
|
+
args: [{ selector: 'cui-dropdown-wrapper', standalone: true, imports: [NgIf], changeDetection: ChangeDetectionStrategy.OnPush, hostDirectives: [CuiFocusTrapDirective], template: "<div\r\n [style.width]=\"width\"\r\n class=\"dropdown\"\r\n>\r\n <header *ngIf=\"title\" class=\"header\">\r\n <h3 class=\"title\">{{ title }}</h3>\r\n <ng-content select=\"[ccDropdownHeaderContent]\" />\r\n </header>\r\n\r\n <div class=\"scrollable-content\">\r\n <ng-content />\r\n </div>\r\n <footer class=\"footer\">\r\n <ng-content select=\"[ccDropdownFooterContent]\" />\r\n </footer>\r\n</div>\r\n", styles: [".dropdown{box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;padding-top:3px;padding-bottom:3px;display:flex;flex-direction:column;border-radius:8px;border:1px solid var(--cui-base-200);max-height:350px;height:100%;width:345px;background:var(--cui-base-0)}.header{padding-right:5px;padding-left:5px;display:flex;flex-direction:column;justify-content:center}.title{font-weight:400;font-size:14px;line-height:20px;padding:4px 8px;color:var(--cui-base-500);text-transform:uppercase}.scrollable-content{overflow:auto}.footer{padding:2px 5px}.footer:empty{display:contents}\n"] }]
|
|
2477
|
+
}], propDecorators: { title: [{
|
|
2478
|
+
type: Input
|
|
2479
|
+
}], width: [{
|
|
2480
|
+
type: Input
|
|
2481
|
+
}] } });
|
|
2482
|
+
|
|
2297
2483
|
class CuiFormFieldComponent {
|
|
2298
2484
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiFormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2299
2485
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CuiFormFieldComponent, selector: "cui-form-field", ngImport: i0, template: "<ng-content select=\"label[cuiLabel]\" />\r\n<ng-content />\r\n<div class=\"c-hint-container\">\r\n <ng-content select=\"cui-hint\" />\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;gap:4px}.c-hint-container{margin-top:2px}.c-hint-container:empty{display:contents}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
@@ -3502,5 +3688,5 @@ const cuiXNdjsonInterceptor = (request, next) => {
|
|
|
3502
3688
|
* Generated bundle index. Do not edit.
|
|
3503
3689
|
*/
|
|
3504
3690
|
|
|
3505
|
-
export { CUI_ALERTS, CUI_ALERT_CONTEXT, CUI_ALERT_DEFAULT_OPTIONS, CUI_ALERT_OPTIONS, CUI_ANIMATIONS_DEFAULT_DURATION, CUI_BANNER_DEFAULT_OPTIONS, CUI_BANNER_OPTIONS, CUI_BUTTON_DEFAULT_OPTIONS, CUI_BUTTON_OPTIONS, CUI_DEFAULT_THEME, CUI_DIALOGS, CUI_DIALOG_CONTEXT, CUI_DIALOG_DEFAULT_OPTIONS, CUI_DIALOG_OPTIONS, CUI_INPUT_TIME_DEFAULT_OPTIONS, CUI_INPUT_TIME_OPTIONS, CUI_NOTIFICATION_DEFAULT_OPTIONS, CUI_NOTIFICATION_ICONS, CUI_NOTIFICATION_ICON_OPTIONS, CUI_NOTIFICATION_ICON_OPTIONS_DEFAULT_MODE, CUI_NOTIFICATION_ICON_OPTIONS_LIGHT_MODE, CUI_NOTIFICATION_OPTIONS, CUI_ROOT_SELECTOR, CUI_TAB_ACTIVATE, CUI_TEXT_FIELD_CONTROLLER, CUI_TEXT_FIELD_ICON_LEFT, CUI_TEXT_FIELD_ID, CUI_TEXT_FIELD_IS_ERROR, CUI_TEXT_FIELD_PLACEHOLDER, CUI_TEXT_FIELD_SIZE, CUI_TEXT_FILED_CONTROLLER_PROVIDER, CUI_THEME, CUI_THEME_STORAGE_DEFAULT_KEY, CUI_THEME_STORAGE_KEY, CUI_TOOLTIP_COMPONENT, CUI_TOOLTIP_DEFAULT_OPTIONS, CUI_TOOLTIP_DIRECTIONS, CUI_TOOLTIP_OPTIONS, CUI_TOOLTIP_PROVIDERS, CuiAccordionComponent, CuiAccordionItemComponent, CuiAccordionModule, CuiAlertComponent, CuiAlertModule, CuiAlertService, CuiAlertsComponent, CuiBadgeComponent, CuiBadgeModule, CuiBannerComponent, CuiBannerModule, CuiBreadcrumbComponent, CuiBreadcrumbsComponent, CuiBreadcrumbsModule, CuiButtonComponent, CuiButtonGroupComponent, CuiButtonGroupModule, CuiButtonModule, CuiCheckboxComponent, CuiCheckboxModule, CuiContextMenuComponent, CuiContextMenuModule, CuiDialogActionsComponent, CuiDialogComponent, CuiDialogHeaderComponent, CuiDialogModule, CuiDialogService, CuiDialogsComponent, CuiFormFieldComponent, CuiFormFieldModule, CuiHintComponent, CuiHintModule, CuiIconButtonComponent, CuiIconButtonModule, CuiInputModule, CuiInputNumberComponent, CuiInputNumberModule, CuiInputPasswordComponent, CuiInputPasswordModule, CuiInputTextComponent, CuiInputTimeComponent, CuiInputTimeModule, CuiLabelComponent, CuiLabelModule, CuiLetterBoxComponent, CuiNotificationComponent, CuiNotificationModule, CuiPositionService, CuiRadioComponent, CuiRadioModule, CuiRootComponent, CuiRootModule, CuiSelectComponent, CuiSelectModule, CuiSvgComponent, CuiSvgModule, CuiTabComponent, CuiTabsComponent, CuiTabsModule, CuiTextFieldController, CuiTextFieldControllerModule, CuiTextFieldIconLeftDirective, CuiTextFieldIdDirective, CuiTextFieldIsErrorDirective, CuiTextFieldPlaceholderDirective, CuiTextFieldSizeDirective, CuiTextareaComponent, CuiTextareaModule, CuiThemeService, CuiToggleComponent, CuiToggleModule, CuiTooltip, CuiTooltipComponent, CuiTooltipDescribe, CuiTooltipDirective, CuiTooltipDriver, CuiTooltipHost, CuiTooltipHover, CuiTooltipManual, CuiTooltipOptionsDirective, CuiTooltipOverflow, CuiTooltipPointer, CuiTooltipPosition, CuiTooltipService, CuiTooltipUnstyled, CuiTooltipUnstyledComponent, CuiTooltips, CuiVisualViewportService, cuiGetDuration, cuiIsObscured, cuiOverrideOptions, cuiRemoveSpaces, cuiReplace, cuiToAnimationOptions, cuiTooltipOptionsProvider, cuiXNdjsonInterceptor };
|
|
3691
|
+
export { CUI_ALERTS, CUI_ALERT_CONTEXT, CUI_ALERT_DEFAULT_OPTIONS, CUI_ALERT_OPTIONS, CUI_ANIMATIONS_DEFAULT_DURATION, CUI_BANNER_DEFAULT_OPTIONS, CUI_BANNER_OPTIONS, CUI_BUTTON_DEFAULT_OPTIONS, CUI_BUTTON_OPTIONS, CUI_DEFAULT_THEME, CUI_DIALOGS, CUI_DIALOG_CONTEXT, CUI_DIALOG_DEFAULT_OPTIONS, CUI_DIALOG_OPTIONS, CUI_INPUT_TIME_DEFAULT_OPTIONS, CUI_INPUT_TIME_OPTIONS, CUI_NOTIFICATION_DEFAULT_OPTIONS, CUI_NOTIFICATION_ICONS, CUI_NOTIFICATION_ICON_OPTIONS, CUI_NOTIFICATION_ICON_OPTIONS_DEFAULT_MODE, CUI_NOTIFICATION_ICON_OPTIONS_LIGHT_MODE, CUI_NOTIFICATION_OPTIONS, CUI_ROOT_SELECTOR, CUI_TAB_ACTIVATE, CUI_TEXT_FIELD_CONTROLLER, CUI_TEXT_FIELD_ICON_LEFT, CUI_TEXT_FIELD_ID, CUI_TEXT_FIELD_IS_ERROR, CUI_TEXT_FIELD_PLACEHOLDER, CUI_TEXT_FIELD_SIZE, CUI_TEXT_FILED_CONTROLLER_PROVIDER, CUI_THEME, CUI_THEME_STORAGE_DEFAULT_KEY, CUI_THEME_STORAGE_KEY, CUI_TOOLTIP_COMPONENT, CUI_TOOLTIP_DEFAULT_OPTIONS, CUI_TOOLTIP_DIRECTIONS, CUI_TOOLTIP_OPTIONS, CUI_TOOLTIP_PROVIDERS, CuiAccordionComponent, CuiAccordionItemComponent, CuiAccordionModule, CuiAlertComponent, CuiAlertModule, CuiAlertService, CuiAlertsComponent, CuiBadgeComponent, CuiBadgeModule, CuiBannerComponent, CuiBannerModule, CuiBreadcrumbComponent, CuiBreadcrumbsComponent, CuiBreadcrumbsModule, CuiButtonComponent, CuiButtonGroupComponent, CuiButtonGroupModule, CuiButtonModule, CuiCheckboxComponent, CuiCheckboxModule, CuiContextMenuComponent, CuiContextMenuModule, CuiDialogActionsComponent, CuiDialogComponent, CuiDialogHeaderComponent, CuiDialogModule, CuiDialogService, CuiDialogsComponent, CuiDropdownDirective, CuiDropdownWrapperComponent, CuiFormFieldComponent, CuiFormFieldModule, CuiHintComponent, CuiHintModule, CuiIconButtonComponent, CuiIconButtonModule, CuiInputModule, CuiInputNumberComponent, CuiInputNumberModule, CuiInputPasswordComponent, CuiInputPasswordModule, CuiInputTextComponent, CuiInputTimeComponent, CuiInputTimeModule, CuiLabelComponent, CuiLabelModule, CuiLetterBoxComponent, CuiNotificationComponent, CuiNotificationModule, CuiPositionService, CuiRadioComponent, CuiRadioModule, CuiRootComponent, CuiRootModule, CuiSelectComponent, CuiSelectModule, CuiSvgComponent, CuiSvgModule, CuiTabComponent, CuiTabsComponent, CuiTabsModule, CuiTextFieldController, CuiTextFieldControllerModule, CuiTextFieldIconLeftDirective, CuiTextFieldIdDirective, CuiTextFieldIsErrorDirective, CuiTextFieldPlaceholderDirective, CuiTextFieldSizeDirective, CuiTextareaComponent, CuiTextareaModule, CuiThemeService, CuiToggleComponent, CuiToggleModule, CuiTooltip, CuiTooltipComponent, CuiTooltipDescribe, CuiTooltipDirective, CuiTooltipDriver, CuiTooltipHost, CuiTooltipHover, CuiTooltipManual, CuiTooltipOptionsDirective, CuiTooltipOverflow, CuiTooltipPointer, CuiTooltipPosition, CuiTooltipService, CuiTooltipUnstyled, CuiTooltipUnstyledComponent, CuiTooltips, CuiVisualViewportService, cuiGetDuration, cuiIsObscured, cuiOverrideOptions, cuiRemoveSpaces, cuiReplace, cuiToAnimationOptions, cuiTooltipOptionsProvider, cuiXNdjsonInterceptor };
|
|
3506
3692
|
//# sourceMappingURL=cuby-ui-core.mjs.map
|