@cuby-ui/core 0.0.35 → 0.0.37
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/checkbox/checkbox.component.d.ts +5 -0
- package/components/checkbox/checkbox.module.d.ts +7 -0
- package/components/checkbox/index.d.ts +2 -0
- package/components/context-menu/context-menu.component.d.ts +8 -4
- package/components/index.d.ts +4 -0
- package/components/radio/index.d.ts +2 -0
- package/components/radio/radio.component.d.ts +5 -0
- package/components/radio/radio.module.d.ts +7 -0
- package/components/select/index.d.ts +2 -0
- package/components/select/select.component.d.ts +43 -0
- package/components/select/select.module.d.ts +10 -0
- package/components/toggle/index.d.ts +2 -0
- package/components/toggle/toggle.component.d.ts +5 -0
- package/components/toggle/toggle.module.d.ts +7 -0
- package/esm2020/components/checkbox/checkbox.component.mjs +11 -0
- package/esm2020/components/checkbox/checkbox.module.mjs +16 -0
- package/esm2020/components/checkbox/index.mjs +3 -0
- package/esm2020/components/context-menu/context-menu.component.mjs +23 -14
- package/esm2020/components/index.mjs +5 -1
- package/esm2020/components/radio/index.mjs +3 -0
- package/esm2020/components/radio/radio.component.mjs +11 -0
- package/esm2020/components/radio/radio.module.mjs +16 -0
- package/esm2020/components/select/index.mjs +3 -0
- package/esm2020/components/select/select.component.mjs +111 -0
- package/esm2020/components/select/select.module.mjs +29 -0
- package/esm2020/components/toggle/index.mjs +3 -0
- package/esm2020/components/toggle/toggle.component.mjs +11 -0
- package/esm2020/components/toggle/toggle.module.mjs +16 -0
- package/esm2020/interfaces/index.mjs +2 -1
- package/esm2020/interfaces/option.mjs +2 -0
- package/fesm2015/cuby-ui-core.mjs +215 -20
- package/fesm2015/cuby-ui-core.mjs.map +1 -1
- package/fesm2020/cuby-ui-core.mjs +215 -20
- package/fesm2020/cuby-ui-core.mjs.map +1 -1
- package/interfaces/index.d.ts +1 -0
- package/interfaces/option.d.ts +4 -0
- package/package.json +3 -3
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class CuiCheckboxComponent {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiCheckboxComponent, never>;
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiCheckboxComponent, "input[type=\"checkbox\"][cuiCheckbox]", never, {}, {}, never, never, false, never>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./checkbox.component";
|
|
3
|
+
export declare class CuiCheckboxModule {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiCheckboxModule, never>;
|
|
5
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<CuiCheckboxModule, [typeof i1.CuiCheckboxComponent], never, [typeof i1.CuiCheckboxComponent]>;
|
|
6
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<CuiCheckboxModule>;
|
|
7
|
+
}
|
|
@@ -1,11 +1,14 @@
|
|
|
1
|
-
import type { AfterViewInit, OnDestroy } from '@angular/core';
|
|
1
|
+
import type { OnInit, AfterViewInit, OnDestroy } from '@angular/core';
|
|
2
2
|
import type { CuiContextMenuItem } from '../../interfaces';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
|
|
4
|
+
import * as i1 from "@cuby-ui/cdk";
|
|
5
|
+
export declare class CuiContextMenuComponent implements OnInit, AfterViewInit, OnDestroy {
|
|
5
6
|
private readonly changeDetectorRef;
|
|
6
7
|
private readonly element;
|
|
7
8
|
private readonly document;
|
|
8
9
|
private readonly documentElement;
|
|
10
|
+
private readonly destroy$;
|
|
11
|
+
private readonly cuiClickOutsideDirective;
|
|
9
12
|
protected readonly EXTRA_OFFSET_LEFT = 0;
|
|
10
13
|
protected readonly EXTRA_OFFSET_TOP = 0;
|
|
11
14
|
protected isVisible: boolean;
|
|
@@ -15,16 +18,17 @@ export declare class CuiContextMenuComponent implements AfterViewInit, OnDestroy
|
|
|
15
18
|
isHidden: boolean;
|
|
16
19
|
protected clientX?: number;
|
|
17
20
|
protected clientY?: number;
|
|
21
|
+
ngOnInit(): void;
|
|
18
22
|
ngAfterViewInit(): void;
|
|
19
23
|
ngOnDestroy(): void;
|
|
20
24
|
protected onSelect(item: CuiContextMenuItem): void;
|
|
21
|
-
protected onClickOutside(target: HTMLElement): void;
|
|
22
25
|
protected onClose(): void;
|
|
23
26
|
protected onStopClickPropagation(event: MouseEvent): void;
|
|
24
27
|
protected trackByFn(_: number, item: CuiContextMenuItem): string;
|
|
28
|
+
private initClickOutsideSubscription;
|
|
25
29
|
private initTargetElementListener;
|
|
26
30
|
private destroyTargetElementListener;
|
|
27
31
|
private changePosition;
|
|
28
32
|
static ɵfac: i0.ɵɵFactoryDeclaration<CuiContextMenuComponent, never>;
|
|
29
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CuiContextMenuComponent, "cui-context-menu[items][target]", never, { "items": "items"; "target": "target"; }, {}, never, never, false,
|
|
33
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiContextMenuComponent, "cui-context-menu[items][target]", never, { "items": "items"; "target": "target"; }, {}, never, never, false, [{ directive: typeof i1.CuiClickOutsideDirective; inputs: {}; outputs: {}; }]>;
|
|
30
34
|
}
|
package/components/index.d.ts
CHANGED
|
@@ -4,6 +4,7 @@ export * from './banner';
|
|
|
4
4
|
export * from './breadcrumbs';
|
|
5
5
|
export * from './button';
|
|
6
6
|
export * from './button-group';
|
|
7
|
+
export * from './checkbox';
|
|
7
8
|
export * from './context-menu';
|
|
8
9
|
export * from './dialog';
|
|
9
10
|
export * from './editor';
|
|
@@ -14,6 +15,9 @@ export * from './input-password';
|
|
|
14
15
|
export * from './input-text';
|
|
15
16
|
export * from './label';
|
|
16
17
|
export * from './notification';
|
|
18
|
+
export * from './radio';
|
|
17
19
|
export * from './root';
|
|
20
|
+
export * from './select';
|
|
18
21
|
export * from './svg';
|
|
19
22
|
export * from './textarea';
|
|
23
|
+
export * from './toggle';
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class CuiRadioComponent {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiRadioComponent, never>;
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiRadioComponent, "input[type=\"radio\"][cuiRadio]", never, {}, {}, never, never, false, never>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./radio.component";
|
|
3
|
+
export declare class CuiRadioModule {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiRadioModule, never>;
|
|
5
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<CuiRadioModule, [typeof i1.CuiRadioComponent], never, [typeof i1.CuiRadioComponent]>;
|
|
6
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<CuiRadioModule>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import type { OnInit } from '@angular/core';
|
|
2
|
+
import { ElementRef } from '@angular/core';
|
|
3
|
+
import { ControlValueAccessor } from '@angular/forms';
|
|
4
|
+
import type { CuiOnChange, CuiOnTouched, CuiNullable } from '@cuby-ui/cdk';
|
|
5
|
+
import type { CuiOption } from '../../interfaces';
|
|
6
|
+
import type { CuiSizeMd, CuiSizeSm } from '../../types';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@cuby-ui/cdk";
|
|
9
|
+
export declare class CuiSelectComponent implements ControlValueAccessor, OnInit {
|
|
10
|
+
private readonly element;
|
|
11
|
+
private readonly document;
|
|
12
|
+
private readonly changeDetectorRef;
|
|
13
|
+
private readonly destroy$;
|
|
14
|
+
private readonly cuiTextFieldController;
|
|
15
|
+
private readonly cuiClickOutsideDirective;
|
|
16
|
+
protected readonly SPACE_BETWEEN_BUTTON_AND_OPTIONS = 3;
|
|
17
|
+
protected isOpened: boolean;
|
|
18
|
+
protected isOptionsListAbove: boolean;
|
|
19
|
+
protected value: CuiNullable<unknown>;
|
|
20
|
+
protected onChange: CuiOnChange<unknown>;
|
|
21
|
+
protected onTouched: CuiOnTouched;
|
|
22
|
+
protected isDisabled: boolean;
|
|
23
|
+
protected selectedOption?: CuiOption;
|
|
24
|
+
options: CuiOption[];
|
|
25
|
+
protected getOptionsListHeightContainer: ElementRef<HTMLUListElement>;
|
|
26
|
+
protected gap: string;
|
|
27
|
+
protected get size(): CuiSizeSm | CuiSizeMd;
|
|
28
|
+
protected get placeholder(): string | undefined;
|
|
29
|
+
protected get isError(): boolean;
|
|
30
|
+
protected trackByFn(_: number, item: CuiOption): string;
|
|
31
|
+
writeValue(value: unknown): void;
|
|
32
|
+
registerOnChange(fn: CuiOnChange<unknown>): void;
|
|
33
|
+
registerOnTouched(fn: CuiOnTouched): void;
|
|
34
|
+
ngOnInit(): void;
|
|
35
|
+
setDisabledState(isDisabled: boolean): void;
|
|
36
|
+
protected onSelect(option: CuiOption): void;
|
|
37
|
+
protected onSwitch(): void;
|
|
38
|
+
private initClickOutsideSubscription;
|
|
39
|
+
private open;
|
|
40
|
+
private close;
|
|
41
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiSelectComponent, never>;
|
|
42
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiSelectComponent, "cui-select[options]", never, { "options": "options"; }, {}, never, never, false, [{ directive: typeof i1.CuiClickOutsideDirective; inputs: {}; outputs: {}; }]>;
|
|
43
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./select.component";
|
|
3
|
+
import * as i2 from "@angular/common";
|
|
4
|
+
import * as i3 from "../svg/svg.module";
|
|
5
|
+
import * as i4 from "../../directives/text-field-controller/text-field-controller.module";
|
|
6
|
+
export declare class CuiSelectModule {
|
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiSelectModule, never>;
|
|
8
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<CuiSelectModule, [typeof i1.CuiSelectComponent], [typeof i2.CommonModule, typeof i3.CuiSvgModule], [typeof i1.CuiSelectComponent, typeof i4.CuiTextFieldControllerModule]>;
|
|
9
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<CuiSelectModule>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class CuiToggleComponent {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiToggleComponent, never>;
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiToggleComponent, "input[type=\"checkbox\"][cuiToggle]", never, {}, {}, never, never, false, never>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./toggle.component";
|
|
3
|
+
export declare class CuiToggleModule {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CuiToggleModule, never>;
|
|
5
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<CuiToggleModule, [typeof i1.CuiToggleComponent], never, [typeof i1.CuiToggleComponent]>;
|
|
6
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<CuiToggleModule>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CuiCheckboxComponent {
|
|
4
|
+
}
|
|
5
|
+
CuiCheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiCheckboxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
CuiCheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiCheckboxComponent, selector: "input[type=\"checkbox\"][cuiCheckbox]", ngImport: i0, template: '', isInline: true, styles: [":host{position:relative;width:16px;height:16px;border:1px solid var(--cui-base-200);border-radius:4px;outline:none;margin:0;appearance:none;cursor:pointer}:host:before{content:\"\";position:absolute;transform:translate(-50%,-50%);top:50%;left:50%;width:12px;height:12px;mask-image:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\"><path d=\"M10 3L4.5 8.5L2 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');background:none}:host:checked{border:none;background:var(--cui-info)}:host:checked:before{background:var(--cui-gray-0)}:host:focus{box-shadow:0 0 0 2px var(--cui-focus)}@media (hover: hover){:host:hover{border-color:var(--cui-base-400)}}:host:active{border-color:var(--cui-base-400);box-shadow:none}:host:disabled{cursor:not-allowed;border:1px solid var(--cui-base-200);background:var(--cui-base-100)}:host:disabled:checked:before{background:var(--cui-gray-500)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiCheckboxComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ selector: 'input[type="checkbox"][cuiCheckbox]', template: '', changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{position:relative;width:16px;height:16px;border:1px solid var(--cui-base-200);border-radius:4px;outline:none;margin:0;appearance:none;cursor:pointer}:host:before{content:\"\";position:absolute;transform:translate(-50%,-50%);top:50%;left:50%;width:12px;height:12px;mask-image:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\"><path d=\"M10 3L4.5 8.5L2 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>');background:none}:host:checked{border:none;background:var(--cui-info)}:host:checked:before{background:var(--cui-gray-0)}:host:focus{box-shadow:0 0 0 2px var(--cui-focus)}@media (hover: hover){:host:hover{border-color:var(--cui-base-400)}}:host:active{border-color:var(--cui-base-400);box-shadow:none}:host:disabled{cursor:not-allowed;border:1px solid var(--cui-base-200);background:var(--cui-base-100)}:host:disabled:checked:before{background:var(--cui-gray-500)}\n"] }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVFuRSxNQUFNLE9BQU8sb0JBQW9COztrSEFBcEIsb0JBQW9CO3NHQUFwQixvQkFBb0IsNkVBSnJCLEVBQUU7NEZBSUQsb0JBQW9CO2tCQU5oQyxTQUFTOytCQUNFLHFDQUFxQyxZQUNyQyxFQUFFLG1CQUVLLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2lucHV0W3R5cGU9XCJjaGVja2JveFwiXVtjdWlDaGVja2JveF0nLFxuICB0ZW1wbGF0ZTogJycsXG4gIHN0eWxlVXJsczogWycuL2NoZWNrYm94LnN0eWxlLnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQ3VpQ2hlY2tib3hDb21wb25lbnQge1xufVxuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CuiCheckboxComponent } from './checkbox.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class CuiCheckboxModule {
|
|
5
|
+
}
|
|
6
|
+
CuiCheckboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiCheckboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
7
|
+
CuiCheckboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: CuiCheckboxModule, declarations: [CuiCheckboxComponent], exports: [CuiCheckboxComponent] });
|
|
8
|
+
CuiCheckboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiCheckboxModule });
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiCheckboxModule, decorators: [{
|
|
10
|
+
type: NgModule,
|
|
11
|
+
args: [{
|
|
12
|
+
declarations: [CuiCheckboxComponent],
|
|
13
|
+
exports: [CuiCheckboxComponent]
|
|
14
|
+
}]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2NoZWNrYm94L2NoZWNrYm94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQU01RCxNQUFNLE9BQU8saUJBQWlCOzsrR0FBakIsaUJBQWlCO2dIQUFqQixpQkFBaUIsaUJBSGIsb0JBQW9CLGFBQ3pCLG9CQUFvQjtnSEFFbkIsaUJBQWlCOzRGQUFqQixpQkFBaUI7a0JBSjdCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsb0JBQW9CLENBQUM7b0JBQ3BDLE9BQU8sRUFBRSxDQUFDLG9CQUFvQixDQUFDO2lCQUNoQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEN1aUNoZWNrYm94Q29tcG9uZW50IH0gZnJvbSAnLi9jaGVja2JveC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtDdWlDaGVja2JveENvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtDdWlDaGVja2JveENvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQ3VpQ2hlY2tib3hNb2R1bGUge1xufVxuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './checkbox.component';
|
|
2
|
+
export * from './checkbox.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvY2hlY2tib3gvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jaGVja2JveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jaGVja2JveC5tb2R1bGUnOyJdfQ==
|
|
@@ -1,19 +1,27 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, inject, Input } from '@angular/core';
|
|
2
2
|
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { takeUntil } from 'rxjs';
|
|
4
|
+
import { CuiDestroyService, CuiClickOutsideDirective } from '@cuby-ui/cdk';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@
|
|
5
|
-
import * as i2 from "
|
|
6
|
+
import * as i1 from "@cuby-ui/cdk";
|
|
7
|
+
import * as i2 from "@angular/common";
|
|
8
|
+
import * as i3 from "../svg/svg.component";
|
|
6
9
|
export class CuiContextMenuComponent {
|
|
7
10
|
constructor() {
|
|
8
11
|
this.changeDetectorRef = inject(ChangeDetectorRef);
|
|
9
12
|
this.element = inject(ElementRef).nativeElement;
|
|
10
13
|
this.document = inject(DOCUMENT);
|
|
11
14
|
this.documentElement = this.document.documentElement;
|
|
15
|
+
this.destroy$ = inject(CuiDestroyService, { self: true });
|
|
16
|
+
this.cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });
|
|
12
17
|
this.EXTRA_OFFSET_LEFT = 0;
|
|
13
18
|
this.EXTRA_OFFSET_TOP = 0;
|
|
14
19
|
this.isVisible = false;
|
|
15
20
|
this.isHidden = false;
|
|
16
21
|
}
|
|
22
|
+
ngOnInit() {
|
|
23
|
+
this.initClickOutsideSubscription();
|
|
24
|
+
}
|
|
17
25
|
ngAfterViewInit() {
|
|
18
26
|
this.initTargetElementListener();
|
|
19
27
|
}
|
|
@@ -24,12 +32,6 @@ export class CuiContextMenuComponent {
|
|
|
24
32
|
this.isVisible = false;
|
|
25
33
|
item.command?.();
|
|
26
34
|
}
|
|
27
|
-
onClickOutside(target) {
|
|
28
|
-
if (this.element.contains(target) || this.target.contains(target)) {
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
this.isVisible = false;
|
|
32
|
-
}
|
|
33
35
|
onClose() {
|
|
34
36
|
this.isVisible = false;
|
|
35
37
|
}
|
|
@@ -39,6 +41,16 @@ export class CuiContextMenuComponent {
|
|
|
39
41
|
trackByFn(_, item) {
|
|
40
42
|
return item.label;
|
|
41
43
|
}
|
|
44
|
+
initClickOutsideSubscription() {
|
|
45
|
+
this.cuiClickOutsideDirective.cuiClickOutside
|
|
46
|
+
.pipe(takeUntil(this.destroy$))
|
|
47
|
+
.subscribe((target) => {
|
|
48
|
+
if (this.target.contains(target)) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
this.isVisible = false;
|
|
52
|
+
});
|
|
53
|
+
}
|
|
42
54
|
initTargetElementListener() {
|
|
43
55
|
this.targetEventListener = ({ clientX, clientY }) => {
|
|
44
56
|
this.isVisible = !this.isVisible;
|
|
@@ -76,10 +88,10 @@ export class CuiContextMenuComponent {
|
|
|
76
88
|
}
|
|
77
89
|
}
|
|
78
90
|
CuiContextMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
79
|
-
CuiContextMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiContextMenuComponent, selector: "cui-context-menu[items][target]", inputs: { items: "items", target: "target" }, host: { listeners: { "
|
|
91
|
+
CuiContextMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiContextMenuComponent, selector: "cui-context-menu[items][target]", inputs: { items: "items", target: "target" }, host: { listeners: { "window:scroll": "onClose()", "window:resize": "onClose()", "click": "onStopClickPropagation($event)" }, properties: { "class._hidden": "this.isHidden", "style.left.px": "this.clientX", "style.top.px": "this.clientY" } }, providers: [CuiDestroyService], hostDirectives: [{ directive: i1.CuiClickOutsideDirective }], ngImport: i0, template: "<ul\n *ngIf=\"isVisible\"\n class=\"c-ul\"\n>\n <li\n *ngFor=\"let item of items; trackBy: trackByFn\"\n [style.color]=\"item.color\"\n >\n <button\n class=\"c-button\"\n (click)=\"onSelect(item)\"\n >\n <cui-svg\n *ngIf=\"item.icon\"\n [icon]=\"item.icon\"\n [color]=\"item.color\"\n ></cui-svg>\n <span>{{ item.label }}</span>\n </button>\n </li>\n</ul>\n", styles: [":host{position:fixed;z-index:2;display:block;width:268px;border-radius:8px}:host._hidden{visibility:hidden}.c-ul{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;border:1px solid var(--cui-base-200);border-radius:inherit;background:var(--cui-base-0);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button{padding:8px 11px 8px 0;border:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px}.c-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-button:hover{background:var(--cui-base-50)}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
80
92
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuComponent, decorators: [{
|
|
81
93
|
type: Component,
|
|
82
|
-
args: [{ selector: 'cui-context-menu[items][target]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ul\n *ngIf=\"isVisible\"\n class=\"c-ul\"\n>\n <li\n *ngFor=\"let item of items; trackBy: trackByFn\"\n [style.color]=\"item.color\"\n >\n <button\n class=\"c-button\"\n (click)=\"onSelect(item)\"\n >\n <cui-svg\n *ngIf=\"item.icon\"\n [icon]=\"item.icon\"\n [color]=\"item.color\"\n ></cui-svg>\n <span>{{ item.label }}</span>\n </button>\n </li>\n</ul>\n", styles: [":host{position:fixed;z-index:2;display:block;width:268px;border-radius:8px}:host._hidden{visibility:hidden}.c-ul{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;border:1px solid var(--cui-base-200);border-radius:inherit;background:var(--cui-base-0);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button{padding:8px 11px 8px 0;border:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px}.c-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-button:hover{background:var(--cui-base-50)}}\n"] }]
|
|
94
|
+
args: [{ selector: 'cui-context-menu[items][target]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [CuiDestroyService], hostDirectives: [CuiClickOutsideDirective], template: "<ul\n *ngIf=\"isVisible\"\n class=\"c-ul\"\n>\n <li\n *ngFor=\"let item of items; trackBy: trackByFn\"\n [style.color]=\"item.color\"\n >\n <button\n class=\"c-button\"\n (click)=\"onSelect(item)\"\n >\n <cui-svg\n *ngIf=\"item.icon\"\n [icon]=\"item.icon\"\n [color]=\"item.color\"\n ></cui-svg>\n <span>{{ item.label }}</span>\n </button>\n </li>\n</ul>\n", styles: [":host{position:fixed;z-index:2;display:block;width:268px;border-radius:8px}:host._hidden{visibility:hidden}.c-ul{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;border:1px solid var(--cui-base-200);border-radius:inherit;background:var(--cui-base-0);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button{padding:8px 11px 8px 0;border:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px}.c-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-button:hover{background:var(--cui-base-50)}}\n"] }]
|
|
83
95
|
}], propDecorators: { items: [{
|
|
84
96
|
type: Input
|
|
85
97
|
}], target: [{
|
|
@@ -93,9 +105,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
93
105
|
}], clientY: [{
|
|
94
106
|
type: HostBinding,
|
|
95
107
|
args: ['style.top.px']
|
|
96
|
-
}], onClickOutside: [{
|
|
97
|
-
type: HostListener,
|
|
98
|
-
args: ['document:click', ['$event.target']]
|
|
99
108
|
}], onClose: [{
|
|
100
109
|
type: HostListener,
|
|
101
110
|
args: ['window:scroll']
|
|
@@ -106,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
106
115
|
type: HostListener,
|
|
107
116
|
args: ['click', ['$event']]
|
|
108
117
|
}] } });
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/context-menu/context-menu.component.ts","../../../../../projects/core/components/context-menu/context-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import type { AfterViewInit, OnDestroy } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  inject,\n  Input\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\nimport type { CuiContextMenuItem } from '../../interfaces';\n\n@Component({\n  selector: 'cui-context-menu[items][target]',\n  templateUrl: './context-menu.component.html',\n  styleUrls: ['./context-menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiContextMenuComponent implements AfterViewInit, OnDestroy {\n  private readonly changeDetectorRef = inject(ChangeDetectorRef);\n  private readonly element = inject(ElementRef).nativeElement;\n  private readonly document = inject(DOCUMENT);\n  private readonly documentElement = this.document.documentElement;\n\n  protected readonly EXTRA_OFFSET_LEFT = 0;\n  protected readonly EXTRA_OFFSET_TOP = 0;\n\n  protected isVisible = false;\n  protected targetEventListener!: (event: MouseEvent) => void;\n\n  @Input()\n  public items!: CuiContextMenuItem[];\n\n  @Input()\n  public target!: HTMLElement;\n\n  @HostBinding('class._hidden')\n  isHidden: boolean = false;\n\n  @HostBinding('style.left.px')\n  protected clientX?: number;\n\n  @HostBinding('style.top.px')\n  protected clientY?: number;\n\n  public ngAfterViewInit(): void {\n    this.initTargetElementListener();\n  }\n\n  public ngOnDestroy(): void {\n    this.destroyTargetElementListener();\n  }\n\n  protected onSelect(item: CuiContextMenuItem): void {\n    this.isVisible = false;\n\n    item.command?.();\n  }\n\n  @HostListener('document:click', ['$event.target'])\n  protected onClickOutside(target: HTMLElement): void {\n    if (this.element.contains(target) || this.target.contains(target)) {\n      return;\n    }\n\n    this.isVisible = false;\n  }\n\n  @HostListener('window:scroll')\n  @HostListener('window:resize')\n  protected onClose(): void {\n    this.isVisible = false;\n  }\n\n  @HostListener('click', ['$event'])\n  protected onStopClickPropagation(event: MouseEvent): void {\n      event.stopPropagation();\n  }\n\n  protected trackByFn(_: number, item: CuiContextMenuItem): string {\n    return item.label;\n  }\n\n  private initTargetElementListener(): void {\n    this.targetEventListener = ({ clientX, clientY }) => {\n      this.isVisible = !this.isVisible;\n\n      if (this.isVisible) {\n        this.changePosition(clientX, clientY);\n      }\n\n      this.changeDetectorRef.markForCheck();\n    };\n\n    this.target.addEventListener('click', this.targetEventListener);\n  }\n\n  private destroyTargetElementListener(): void {\n    this.target.removeEventListener('click', this.targetEventListener);\n  }\n\n  private changePosition(x: number, y: number): void {\n    this.isHidden = true;\n\n    setTimeout(() => {\n      const { clientWidth, clientHeight } = this.documentElement;\n      const width = this.element.offsetWidth;\n      const height = this.element.offsetHeight;\n      let left = x;\n      let top = y;\n\n      if (left + width > clientWidth) {\n        left -= width;\n      }\n\n      if (top + height > clientHeight) {\n        top -= height;\n      }\n\n      left = Math.max(left, this.EXTRA_OFFSET_LEFT);\n      top = Math.max(top, this.EXTRA_OFFSET_TOP);\n\n      this.isHidden = false;\n      this.clientX = left;\n      this.clientY = top;\n\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n}\n","<ul\n  *ngIf=\"isVisible\"\n  class=\"c-ul\"\n>\n  <li\n    *ngFor=\"let item of items; trackBy: trackByFn\"\n    [style.color]=\"item.color\"\n  >\n    <button\n      class=\"c-button\"\n      (click)=\"onSelect(item)\"\n    >\n      <cui-svg\n        *ngIf=\"item.icon\"\n        [icon]=\"item.icon\"\n        [color]=\"item.color\"\n      ></cui-svg>\n      <span>{{ item.label }}</span>\n    </button>\n  </li>\n</ul>\n"]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/context-menu/context-menu.component.ts","../../../../../projects/core/components/context-menu/context-menu.component.html"],"names":[],"mappings":"AACA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EACN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAEjC,OAAO,EAAE,iBAAiB,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;;;;;AAY3E,MAAM,OAAO,uBAAuB;IARpC;QASmB,sBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC9C,YAAO,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,aAAa,CAAC;QAC3C,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5B,oBAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;QAChD,aAAQ,GAAI,MAAM,CAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QACtD,6BAAwB,GAAG,MAAM,CAAC,wBAAwB,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QAE1E,sBAAiB,GAAG,CAAC,CAAC;QACtB,qBAAgB,GAAG,CAAC,CAAC;QAE9B,cAAS,GAAG,KAAK,CAAC;QAU5B,aAAQ,GAAY,KAAK,CAAC;KAmG3B;IA3FQ,QAAQ;QACb,IAAI,CAAC,4BAA4B,EAAE,CAAC;IACtC,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,4BAA4B,EAAE,CAAC;IACtC,CAAC;IAES,QAAQ,CAAC,IAAwB;QACzC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAEvB,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;IACnB,CAAC;IAIS,OAAO;QACf,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAGS,sBAAsB,CAAC,KAAiB;QAC9C,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAES,SAAS,CAAC,CAAS,EAAE,IAAwB;QACrD,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAEO,4BAA4B;QAClC,IAAI,CAAC,wBAAwB,CAAC,eAAe;aAC1C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpB,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;gBAChC,OAAO;aACR;YAED,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,CAAC,CAAA;IACN,CAAC;IAEO,yBAAyB;QAC/B,IAAI,CAAC,mBAAmB,GAAG,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE;YAClD,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;YAEjC,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;aACvC;YAED,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC,CAAC;QAEF,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IAClE,CAAC;IAEO,4BAA4B;QAClC,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACrE,CAAC;IAEO,cAAc,CAAC,CAAS,EAAE,CAAS;QACzC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QAErB,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC;YAC3D,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;YACvC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;YACzC,IAAI,IAAI,GAAG,CAAC,CAAC;YACb,IAAI,GAAG,GAAG,CAAC,CAAC;YAEZ,IAAI,IAAI,GAAG,KAAK,GAAG,WAAW,EAAE;gBAC9B,IAAI,IAAI,KAAK,CAAC;aACf;YAED,IAAI,GAAG,GAAG,MAAM,GAAG,YAAY,EAAE;gBAC/B,GAAG,IAAI,MAAM,CAAC;aACf;YAED,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAC9C,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;YAE3C,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;YAEnB,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;;qHAvHU,uBAAuB;yGAAvB,uBAAuB,2VAHvB,CAAC,iBAAiB,CAAC,wFCvBhC,yaAqBA;4FDKa,uBAAuB;kBARnC,SAAS;+BACE,iCAAiC,mBAG1B,uBAAuB,CAAC,MAAM,aACpC,CAAC,iBAAiB,CAAC,kBACd,CAAC,wBAAwB,CAAC;8BAiBnC,KAAK;sBADX,KAAK;gBAIC,MAAM;sBADZ,KAAK;gBAIN,QAAQ;sBADP,WAAW;uBAAC,eAAe;gBAIlB,OAAO;sBADhB,WAAW;uBAAC,eAAe;gBAIlB,OAAO;sBADhB,WAAW;uBAAC,cAAc;gBAuBjB,OAAO;sBAFhB,YAAY;uBAAC,eAAe;;sBAC5B,YAAY;uBAAC,eAAe;gBAMnB,sBAAsB;sBAD/B,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import type { OnInit, AfterViewInit, OnDestroy } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  inject,\n  Input\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { takeUntil } from 'rxjs';\n\nimport { CuiDestroyService, CuiClickOutsideDirective } from '@cuby-ui/cdk';\n\nimport type { CuiContextMenuItem } from '../../interfaces';\n\n@Component({\n  selector: 'cui-context-menu[items][target]',\n  templateUrl: './context-menu.component.html',\n  styleUrls: ['./context-menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [CuiDestroyService],\n  hostDirectives: [CuiClickOutsideDirective]\n})\nexport class CuiContextMenuComponent implements OnInit, AfterViewInit, OnDestroy {\n  private readonly changeDetectorRef = inject(ChangeDetectorRef);\n  private readonly element = inject(ElementRef).nativeElement;\n  private readonly document = inject(DOCUMENT);\n  private readonly documentElement = this.document.documentElement;\n  private readonly destroy$ =  inject(CuiDestroyService, { self: true });\n  private readonly cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });\n\n  protected readonly EXTRA_OFFSET_LEFT = 0;\n  protected readonly EXTRA_OFFSET_TOP = 0;\n\n  protected isVisible = false;\n  protected targetEventListener!: (event: MouseEvent) => void;\n\n  @Input()\n  public items!: CuiContextMenuItem[];\n\n  @Input()\n  public target!: HTMLElement;\n\n  @HostBinding('class._hidden')\n  isHidden: boolean = false;\n\n  @HostBinding('style.left.px')\n  protected clientX?: number;\n\n  @HostBinding('style.top.px')\n  protected clientY?: number;\n\n  public ngOnInit(): void {\n    this.initClickOutsideSubscription();\n  }\n\n  public ngAfterViewInit(): void {\n    this.initTargetElementListener();\n  }\n\n  public ngOnDestroy(): void {\n    this.destroyTargetElementListener();\n  }\n\n  protected onSelect(item: CuiContextMenuItem): void {\n    this.isVisible = false;\n\n    item.command?.();\n  }\n\n  @HostListener('window:scroll')\n  @HostListener('window:resize')\n  protected onClose(): void {\n    this.isVisible = false;\n  }\n\n  @HostListener('click', ['$event'])\n  protected onStopClickPropagation(event: MouseEvent): void {\n      event.stopPropagation();\n  }\n\n  protected trackByFn(_: number, item: CuiContextMenuItem): string {\n    return item.label;\n  }\n\n  private initClickOutsideSubscription(): void {\n    this.cuiClickOutsideDirective.cuiClickOutside\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((target) => {\n        if (this.target.contains(target)) {\n          return;\n        }\n\n        this.isVisible = false;\n      })\n  }\n\n  private initTargetElementListener(): void {\n    this.targetEventListener = ({ clientX, clientY }) => {\n      this.isVisible = !this.isVisible;\n\n      if (this.isVisible) {\n        this.changePosition(clientX, clientY);\n      }\n\n      this.changeDetectorRef.markForCheck();\n    };\n\n    this.target.addEventListener('click', this.targetEventListener);\n  }\n\n  private destroyTargetElementListener(): void {\n    this.target.removeEventListener('click', this.targetEventListener);\n  }\n\n  private changePosition(x: number, y: number): void {\n    this.isHidden = true;\n\n    setTimeout(() => {\n      const { clientWidth, clientHeight } = this.documentElement;\n      const width = this.element.offsetWidth;\n      const height = this.element.offsetHeight;\n      let left = x;\n      let top = y;\n\n      if (left + width > clientWidth) {\n        left -= width;\n      }\n\n      if (top + height > clientHeight) {\n        top -= height;\n      }\n\n      left = Math.max(left, this.EXTRA_OFFSET_LEFT);\n      top = Math.max(top, this.EXTRA_OFFSET_TOP);\n\n      this.isHidden = false;\n      this.clientX = left;\n      this.clientY = top;\n\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n}\n","<ul\n  *ngIf=\"isVisible\"\n  class=\"c-ul\"\n>\n  <li\n    *ngFor=\"let item of items; trackBy: trackByFn\"\n    [style.color]=\"item.color\"\n  >\n    <button\n      class=\"c-button\"\n      (click)=\"onSelect(item)\"\n    >\n      <cui-svg\n        *ngIf=\"item.icon\"\n        [icon]=\"item.icon\"\n        [color]=\"item.color\"\n      ></cui-svg>\n      <span>{{ item.label }}</span>\n    </button>\n  </li>\n</ul>\n"]}
|
|
@@ -4,6 +4,7 @@ export * from './banner';
|
|
|
4
4
|
export * from './breadcrumbs';
|
|
5
5
|
export * from './button';
|
|
6
6
|
export * from './button-group';
|
|
7
|
+
export * from './checkbox';
|
|
7
8
|
export * from './context-menu';
|
|
8
9
|
export * from './dialog';
|
|
9
10
|
export * from './editor';
|
|
@@ -14,7 +15,10 @@ export * from './input-password';
|
|
|
14
15
|
export * from './input-text';
|
|
15
16
|
export * from './label';
|
|
16
17
|
export * from './notification';
|
|
18
|
+
export * from './radio';
|
|
17
19
|
export * from './root';
|
|
20
|
+
export * from './select';
|
|
18
21
|
export * from './svg';
|
|
19
22
|
export * from './textarea';
|
|
20
|
-
|
|
23
|
+
export * from './toggle';
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsT0FBTyxDQUFDO0FBQ3RCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY2NvcmRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydCc7XG5leHBvcnQgKiBmcm9tICcuL2Jhbm5lcic7XG5leHBvcnQgKiBmcm9tICcuL2JyZWFkY3J1bWJzJztcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uJztcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uLWdyb3VwJztcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tib3gnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LW1lbnUnO1xuZXhwb3J0ICogZnJvbSAnLi9kaWFsb2cnO1xuZXhwb3J0ICogZnJvbSAnLi9lZGl0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9oaW50JztcbmV4cG9ydCAqIGZyb20gJy4vaWNvbi1idXR0b24nO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1udW1iZXInO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1wYXNzd29yZCc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LXRleHQnO1xuZXhwb3J0ICogZnJvbSAnLi9sYWJlbCc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3JhZGlvJztcbmV4cG9ydCAqIGZyb20gJy4vcm9vdCc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdCc7XG5leHBvcnQgKiBmcm9tICcuL3N2Zyc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRhcmVhJztcbmV4cG9ydCAqIGZyb20gJy4vdG9nZ2xlJztcbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './radio.module';
|
|
2
|
+
export * from './radio.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvcmFkaW8vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9yYWRpby5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9yYWRpby5jb21wb25lbnQnO1xuIl19
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CuiRadioComponent {
|
|
4
|
+
}
|
|
5
|
+
CuiRadioComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRadioComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
CuiRadioComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiRadioComponent, selector: "input[type=\"radio\"][cuiRadio]", ngImport: i0, template: '', isInline: true, styles: [":host{position:relative;width:16px;height:16px;outline:none;margin:0;appearance:none;border:1px solid var(--cui-base-200);border-radius:50%;cursor:pointer}:host:before{content:\"\";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%}:host:focus{box-shadow:0 0 0 2px var(--cui-focus)}@media (hover: hover){:host:hover{border-color:var(--cui-base-400)}}:host:active{border-color:var(--cui-base-400);box-shadow:none}:host:checked{border:2px solid var(--cui-info)}:host:checked:before{background:var(--cui-info)}:host:disabled{cursor:not-allowed;border:1px solid var(--cui-base-200);background:var(--cui-base-100)}:host:disabled:checked{border-width:2px}:host:disabled:checked:before{background:var(--cui-base-200)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRadioComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ selector: 'input[type="radio"][cuiRadio]', template: '', changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{position:relative;width:16px;height:16px;outline:none;margin:0;appearance:none;border:1px solid var(--cui-base-200);border-radius:50%;cursor:pointer}:host:before{content:\"\";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%}:host:focus{box-shadow:0 0 0 2px var(--cui-focus)}@media (hover: hover){:host:hover{border-color:var(--cui-base-400)}}:host:active{border-color:var(--cui-base-400);box-shadow:none}:host:checked{border:2px solid var(--cui-info)}:host:checked:before{background:var(--cui-info)}:host:disabled{cursor:not-allowed;border:1px solid var(--cui-base-200);background:var(--cui-base-100)}:host:disabled:checked{border-width:2px}:host:disabled:checked:before{background:var(--cui-base-200)}\n"] }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL3JhZGlvL3JhZGlvLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVFuRSxNQUFNLE9BQU8saUJBQWlCOzsrR0FBakIsaUJBQWlCO21HQUFqQixpQkFBaUIsdUVBSmxCLEVBQUU7NEZBSUQsaUJBQWlCO2tCQU43QixTQUFTOytCQUNFLCtCQUErQixZQUMvQixFQUFFLG1CQUVLLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2lucHV0W3R5cGU9XCJyYWRpb1wiXVtjdWlSYWRpb10nLFxuICB0ZW1wbGF0ZTogJycsXG4gIHN0eWxlVXJsczogWycuL3JhZGlvLnN0eWxlLnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQ3VpUmFkaW9Db21wb25lbnQge1xufVxuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CuiRadioComponent } from './radio.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class CuiRadioModule {
|
|
5
|
+
}
|
|
6
|
+
CuiRadioModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRadioModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
7
|
+
CuiRadioModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: CuiRadioModule, declarations: [CuiRadioComponent], exports: [CuiRadioComponent] });
|
|
8
|
+
CuiRadioModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRadioModule });
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRadioModule, decorators: [{
|
|
10
|
+
type: NgModule,
|
|
11
|
+
args: [{
|
|
12
|
+
declarations: [CuiRadioComponent],
|
|
13
|
+
exports: [CuiRadioComponent]
|
|
14
|
+
}]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL3JhZGlvL3JhZGlvLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQU10RCxNQUFNLE9BQU8sY0FBYzs7NEdBQWQsY0FBYzs2R0FBZCxjQUFjLGlCQUhWLGlCQUFpQixhQUN0QixpQkFBaUI7NkdBRWhCLGNBQWM7NEZBQWQsY0FBYztrQkFKMUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztvQkFDakMsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQ3VpUmFkaW9Db21wb25lbnQgfSBmcm9tICcuL3JhZGlvLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0N1aVJhZGlvQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW0N1aVJhZGlvQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBDdWlSYWRpb01vZHVsZSB7XG59XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './select.component';
|
|
2
|
+
export * from './select.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvc2VsZWN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC5tb2R1bGUnO1xuIl19
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, Input, ElementRef, ViewChild, HostBinding } from '@angular/core';
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
+
import { CuiDestroyService } from '@cuby-ui/cdk';
|
|
5
|
+
import { cuiProvide, CuiClickOutsideDirective } from '@cuby-ui/cdk';
|
|
6
|
+
import { takeUntil } from 'rxjs';
|
|
7
|
+
import { CUI_TEXT_FIELD_CONTROLLER, CUI_TEXT_FILED_CONTROLLER_PROVIDER } from '../../directives';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@cuby-ui/cdk";
|
|
10
|
+
import * as i2 from "@angular/common";
|
|
11
|
+
import * as i3 from "../svg/svg.component";
|
|
12
|
+
export class CuiSelectComponent {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.element = inject(ElementRef).nativeElement;
|
|
15
|
+
this.document = inject(DOCUMENT);
|
|
16
|
+
this.changeDetectorRef = inject(ChangeDetectorRef);
|
|
17
|
+
this.destroy$ = inject(CuiDestroyService, { self: true });
|
|
18
|
+
this.cuiTextFieldController = inject(CUI_TEXT_FIELD_CONTROLLER);
|
|
19
|
+
this.cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });
|
|
20
|
+
this.SPACE_BETWEEN_BUTTON_AND_OPTIONS = 3;
|
|
21
|
+
this.isOpened = false;
|
|
22
|
+
this.isOptionsListAbove = false;
|
|
23
|
+
this.gap = `${this.SPACE_BETWEEN_BUTTON_AND_OPTIONS}px`;
|
|
24
|
+
}
|
|
25
|
+
get size() {
|
|
26
|
+
return this.cuiTextFieldController.size;
|
|
27
|
+
}
|
|
28
|
+
get placeholder() {
|
|
29
|
+
return this.cuiTextFieldController.placeholder;
|
|
30
|
+
}
|
|
31
|
+
get isError() {
|
|
32
|
+
return this.cuiTextFieldController.isError;
|
|
33
|
+
}
|
|
34
|
+
trackByFn(_, item) {
|
|
35
|
+
return item.label;
|
|
36
|
+
}
|
|
37
|
+
writeValue(value) {
|
|
38
|
+
this.value = value;
|
|
39
|
+
this.changeDetectorRef.markForCheck();
|
|
40
|
+
}
|
|
41
|
+
registerOnChange(fn) {
|
|
42
|
+
this.onChange = fn;
|
|
43
|
+
}
|
|
44
|
+
registerOnTouched(fn) {
|
|
45
|
+
this.onTouched = fn;
|
|
46
|
+
}
|
|
47
|
+
ngOnInit() {
|
|
48
|
+
this.initClickOutsideSubscription();
|
|
49
|
+
}
|
|
50
|
+
setDisabledState(isDisabled) {
|
|
51
|
+
this.isDisabled = isDisabled;
|
|
52
|
+
this.changeDetectorRef.markForCheck();
|
|
53
|
+
}
|
|
54
|
+
onSelect(option) {
|
|
55
|
+
this.value = option.value;
|
|
56
|
+
this.selectedOption = option;
|
|
57
|
+
this.onChange(this.value);
|
|
58
|
+
this.onSwitch();
|
|
59
|
+
this.onTouched();
|
|
60
|
+
}
|
|
61
|
+
onSwitch() {
|
|
62
|
+
if (!this.isOpened) {
|
|
63
|
+
this.open();
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
this.close();
|
|
67
|
+
}
|
|
68
|
+
initClickOutsideSubscription() {
|
|
69
|
+
this.cuiClickOutsideDirective.cuiClickOutside
|
|
70
|
+
.pipe(takeUntil(this.destroy$))
|
|
71
|
+
.subscribe(() => {
|
|
72
|
+
if (this.isOpened) {
|
|
73
|
+
this.onTouched();
|
|
74
|
+
}
|
|
75
|
+
this.close();
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
open() {
|
|
79
|
+
this.isOpened = true;
|
|
80
|
+
const { bottom: elementRectBottom } = this.element.getBoundingClientRect();
|
|
81
|
+
const distanceToBottom = this.document.documentElement.clientHeight
|
|
82
|
+
- (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);
|
|
83
|
+
this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;
|
|
84
|
+
}
|
|
85
|
+
close() {
|
|
86
|
+
this.isOpened = false;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
CuiSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
+
CuiSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiSelectComponent, selector: "cui-select[options]", inputs: { options: "options" }, host: { properties: { "style.--c-gap": "this.gap" } }, providers: [
|
|
91
|
+
CUI_TEXT_FILED_CONTROLLER_PROVIDER,
|
|
92
|
+
cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
|
|
93
|
+
CuiDestroyService
|
|
94
|
+
], viewQueries: [{ propertyName: "getOptionsListHeightContainer", first: true, predicate: ["getOptionsListHeightContainer"], descendants: true }], hostDirectives: [{ directive: i1.CuiClickOutsideDirective }], ngImport: i0, template: "<button\n [attr.data-size]=\"size\"\n class=\"c-button\"\n [class.c-button_with-error]=\"isError\"\n [disabled]=\"isDisabled\"\n (click)=\"onSwitch()\"\n>\n <ng-container *ngIf=\"selectedOption; else placeholderTemplate\">\n {{ selectedOption.label }}\n </ng-container>\n <ng-template #placeholderTemplate>\n <span class=\"c-placeholder\">{{ placeholder }}</span>\n </ng-template>\n <cui-svg\n icon=\"cuiIconChevronDown\"\n color=\"var(--cui-base-500)\"\n />\n</button>\n<div\n *ngIf=\"isOpened\"\n class=\"c-options__wrapper\"\n [class.c-options__wrapper_top]=\"isOptionsListAbove\"\n>\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\n</div>\n<div\n #getOptionsListHeightContainer\n class=\"c-get-options-list-height-container\"\n>\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\n</div>\n<ng-template #optionsList>\n <ul\n class=\"c-options\"\n [class.c-options_top]=\"isOptionsListAbove\"\n >\n <li *ngFor=\"let option of options; trackBy: trackByFn\">\n <button\n class=\"c-option-button\"\n [class.c-option-button_selected]=\"selectedOption === option\"\n (click)=\"onSelect(option)\"\n >\n <span>{{ option.label }}</span>\n <cui-svg\n *ngIf=\"selectedOption === option\"\n icon=\"cuiIconCheckSm\"\n color=\"var(--cui-info)\"\n class=\"c-option-button__icon\"\n />\n </button>\n </li>\n </ul>\n</ng-template>\n", styles: [":host{position:relative;z-index:1;display:block;font-family:var(--cui-main-font)}.c-button{border:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:0 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;border:1px solid var(--cui-base-200);border-radius:8px;cursor:pointer;background:var(--cui-base-10);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button:hover{border-color:var(--cui-base-300)}.c-button:focus{box-shadow:0 0 0 2px var(--cui-focus);border-color:var(--cui-info)}.c-button:disabled{cursor:not-allowed;opacity:.5;background:var(--cui-base-50);border-color:var(--cui-base-200)}.c-button[data-size=sm]{padding-top:7px;padding-bottom:7px}.c-button[data-size=md]{padding-top:8px;padding-bottom:8px}.c-button_with-error{border-color:var(--cui-danger)}.c-button_with-error:focus{box-shadow:0 0 0 2px #d92d2040;border-color:var(--cui-danger)}.c-placeholder{color:var(--cui-base-400)}.c-options__wrapper{position:absolute;top:calc(100% + var(--c-gap));width:100%}.c-options__wrapper_top{top:unset;bottom:calc(100% + var(--c-gap))}.c-get-options-list-height-container{position:fixed;visibility:hidden}.c-options{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;border:1px solid var(--cui-base-200);border-radius:8px;background:var(--cui-base-0);color:var(--cui-base-900)}.c-option-button{padding:8px 11px 8px 0;border:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px}.c-option-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-option-button:hover{background:var(--cui-base-50)}}.c-option-button_selected{background:var(--cui-base-50)}.c-option-button__icon{margin-left:auto}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
95
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectComponent, decorators: [{
|
|
96
|
+
type: Component,
|
|
97
|
+
args: [{ selector: 'cui-select[options]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
98
|
+
CUI_TEXT_FILED_CONTROLLER_PROVIDER,
|
|
99
|
+
cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
|
|
100
|
+
CuiDestroyService
|
|
101
|
+
], hostDirectives: [CuiClickOutsideDirective], template: "<button\n [attr.data-size]=\"size\"\n class=\"c-button\"\n [class.c-button_with-error]=\"isError\"\n [disabled]=\"isDisabled\"\n (click)=\"onSwitch()\"\n>\n <ng-container *ngIf=\"selectedOption; else placeholderTemplate\">\n {{ selectedOption.label }}\n </ng-container>\n <ng-template #placeholderTemplate>\n <span class=\"c-placeholder\">{{ placeholder }}</span>\n </ng-template>\n <cui-svg\n icon=\"cuiIconChevronDown\"\n color=\"var(--cui-base-500)\"\n />\n</button>\n<div\n *ngIf=\"isOpened\"\n class=\"c-options__wrapper\"\n [class.c-options__wrapper_top]=\"isOptionsListAbove\"\n>\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\n</div>\n<div\n #getOptionsListHeightContainer\n class=\"c-get-options-list-height-container\"\n>\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\n</div>\n<ng-template #optionsList>\n <ul\n class=\"c-options\"\n [class.c-options_top]=\"isOptionsListAbove\"\n >\n <li *ngFor=\"let option of options; trackBy: trackByFn\">\n <button\n class=\"c-option-button\"\n [class.c-option-button_selected]=\"selectedOption === option\"\n (click)=\"onSelect(option)\"\n >\n <span>{{ option.label }}</span>\n <cui-svg\n *ngIf=\"selectedOption === option\"\n icon=\"cuiIconCheckSm\"\n color=\"var(--cui-info)\"\n class=\"c-option-button__icon\"\n />\n </button>\n </li>\n </ul>\n</ng-template>\n", styles: [":host{position:relative;z-index:1;display:block;font-family:var(--cui-main-font)}.c-button{border:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:0 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;border:1px solid var(--cui-base-200);border-radius:8px;cursor:pointer;background:var(--cui-base-10);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button:hover{border-color:var(--cui-base-300)}.c-button:focus{box-shadow:0 0 0 2px var(--cui-focus);border-color:var(--cui-info)}.c-button:disabled{cursor:not-allowed;opacity:.5;background:var(--cui-base-50);border-color:var(--cui-base-200)}.c-button[data-size=sm]{padding-top:7px;padding-bottom:7px}.c-button[data-size=md]{padding-top:8px;padding-bottom:8px}.c-button_with-error{border-color:var(--cui-danger)}.c-button_with-error:focus{box-shadow:0 0 0 2px #d92d2040;border-color:var(--cui-danger)}.c-placeholder{color:var(--cui-base-400)}.c-options__wrapper{position:absolute;top:calc(100% + var(--c-gap));width:100%}.c-options__wrapper_top{top:unset;bottom:calc(100% + var(--c-gap))}.c-get-options-list-height-container{position:fixed;visibility:hidden}.c-options{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;border:1px solid var(--cui-base-200);border-radius:8px;background:var(--cui-base-0);color:var(--cui-base-900)}.c-option-button{padding:8px 11px 8px 0;border:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px}.c-option-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-option-button:hover{background:var(--cui-base-50)}}.c-option-button_selected{background:var(--cui-base-50)}.c-option-button__icon{margin-left:auto}\n"] }]
|
|
102
|
+
}], propDecorators: { options: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], getOptionsListHeightContainer: [{
|
|
105
|
+
type: ViewChild,
|
|
106
|
+
args: ['getOptionsListHeightContainer']
|
|
107
|
+
}], gap: [{
|
|
108
|
+
type: HostBinding,
|
|
109
|
+
args: ['style.--c-gap']
|
|
110
|
+
}] } });
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/select/select.component.ts","../../../../../projects/core/components/select/select.template.html"],"names":[],"mappings":"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","sourcesContent":["import type { OnInit } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  inject,\n  Input,\n  ElementRef,\n  ViewChild,\n  HostBinding\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport type { CuiOnChange, CuiOnTouched, CuiNullable } from '@cuby-ui/cdk';\nimport { CuiDestroyService } from '@cuby-ui/cdk';\nimport { cuiProvide, CuiClickOutsideDirective } from '@cuby-ui/cdk';\nimport { takeUntil } from 'rxjs';\n\nimport type { CuiOption } from '../../interfaces';\nimport type { CuiSizeMd, CuiSizeSm } from '../../types';\nimport { CUI_TEXT_FIELD_CONTROLLER, CUI_TEXT_FILED_CONTROLLER_PROVIDER } from '../../directives';\n\n@Component({\n  selector: 'cui-select[options]',\n  templateUrl: './select.template.html',\n  styleUrls: ['./select.style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    CUI_TEXT_FILED_CONTROLLER_PROVIDER,\n    cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),\n    CuiDestroyService\n  ],\n  hostDirectives: [CuiClickOutsideDirective]\n})\nexport class CuiSelectComponent implements ControlValueAccessor, OnInit {\n  private readonly element = inject(ElementRef).nativeElement;\n  private readonly document = inject(DOCUMENT);\n  private readonly changeDetectorRef = inject(ChangeDetectorRef);\n  private readonly destroy$ = inject(CuiDestroyService, { self: true });\n  private readonly cuiTextFieldController = inject(CUI_TEXT_FIELD_CONTROLLER);\n  private readonly cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });\n\n  protected readonly SPACE_BETWEEN_BUTTON_AND_OPTIONS = 3;\n\n  protected isOpened = false;\n  protected isOptionsListAbove = false;\n  protected value!: CuiNullable<unknown>;\n  protected onChange!: CuiOnChange<unknown>;\n  protected onTouched!: CuiOnTouched;\n  protected isDisabled!: boolean;\n  protected selectedOption?: CuiOption;\n\n  @Input()\n  public options!: CuiOption[];\n\n  @ViewChild('getOptionsListHeightContainer')\n  protected getOptionsListHeightContainer!: ElementRef<HTMLUListElement>;\n\n  @HostBinding('style.--c-gap')\n  protected gap = `${this.SPACE_BETWEEN_BUTTON_AND_OPTIONS}px`;\n\n  protected get size(): CuiSizeSm | CuiSizeMd {\n    return this.cuiTextFieldController.size;\n  }\n\n  protected get placeholder(): string | undefined {\n    return this.cuiTextFieldController.placeholder;\n  }\n\n  protected get isError(): boolean {\n    return this.cuiTextFieldController.isError;\n  }\n\n  protected trackByFn(_: number, item: CuiOption): string {\n    return item.label;\n  }\n\n  public writeValue(value: unknown): void {\n    this.value = value;\n\n    this.changeDetectorRef.markForCheck();\n  }\n\n  public registerOnChange(fn: CuiOnChange<unknown>): void {\n    this.onChange = fn;\n  }\n\n  public registerOnTouched(fn: CuiOnTouched): void {\n    this.onTouched = fn;\n  }\n\n  public ngOnInit(): void {\n    this.initClickOutsideSubscription();\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n\n    this.changeDetectorRef.markForCheck();\n  }\n\n  protected onSelect(option: CuiOption): void {\n    this.value = option.value;\n    this.selectedOption = option;\n\n    this.onChange(this.value);\n    this.onSwitch();\n    this.onTouched();\n  }\n\n  protected onSwitch(): void {\n    if (!this.isOpened) {\n      this.open();\n\n      return;\n    }\n\n    this.close();\n  }\n\n  private initClickOutsideSubscription(): void {\n    this.cuiClickOutsideDirective.cuiClickOutside\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        if (this.isOpened) {\n          this.onTouched();\n        }\n\n        this.close();\n      });\n  }\n\n  private open(): void {\n    this.isOpened = true;\n\n    const { bottom: elementRectBottom } = this.element.getBoundingClientRect();\n    const distanceToBottom = this.document.documentElement.clientHeight\n      - (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);\n\n    this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;\n  }\n\n  private close(): void {\n    this.isOpened = false;\n  }\n}\n","<button\n  [attr.data-size]=\"size\"\n  class=\"c-button\"\n  [class.c-button_with-error]=\"isError\"\n  [disabled]=\"isDisabled\"\n  (click)=\"onSwitch()\"\n>\n  <ng-container *ngIf=\"selectedOption; else placeholderTemplate\">\n    {{ selectedOption.label }}\n  </ng-container>\n  <ng-template #placeholderTemplate>\n    <span class=\"c-placeholder\">{{ placeholder }}</span>\n  </ng-template>\n  <cui-svg\n    icon=\"cuiIconChevronDown\"\n    color=\"var(--cui-base-500)\"\n  />\n</button>\n<div\n  *ngIf=\"isOpened\"\n  class=\"c-options__wrapper\"\n  [class.c-options__wrapper_top]=\"isOptionsListAbove\"\n>\n  <ng-container *ngTemplateOutlet=\"optionsList\"/>\n</div>\n<div\n  #getOptionsListHeightContainer\n  class=\"c-get-options-list-height-container\"\n>\n  <ng-container *ngTemplateOutlet=\"optionsList\"/>\n</div>\n<ng-template #optionsList>\n  <ul\n    class=\"c-options\"\n    [class.c-options_top]=\"isOptionsListAbove\"\n  >\n    <li *ngFor=\"let option of options; trackBy: trackByFn\">\n      <button\n        class=\"c-option-button\"\n        [class.c-option-button_selected]=\"selectedOption === option\"\n        (click)=\"onSelect(option)\"\n      >\n        <span>{{ option.label }}</span>\n        <cui-svg\n          *ngIf=\"selectedOption === option\"\n          icon=\"cuiIconCheckSm\"\n          color=\"var(--cui-info)\"\n          class=\"c-option-button__icon\"\n        />\n      </button>\n    </li>\n  </ul>\n</ng-template>\n"]}
|