@cuby-ui/core 0.0.36 → 0.0.38

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -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
- export declare class CuiContextMenuComponent implements AfterViewInit, OnDestroy {
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, never>;
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
  }
@@ -0,0 +1,5 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class CuiFormFieldComponent {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<CuiFormFieldComponent, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<CuiFormFieldComponent, "cui-form-field", never, {}, {}, never, ["label[cuiLabel]", "*", "cui-hint"], false, never>;
5
+ }
@@ -0,0 +1,7 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "./form-field.component";
3
+ export declare class CuiFormFieldModule {
4
+ static ɵfac: i0.ɵɵFactoryDeclaration<CuiFormFieldModule, never>;
5
+ static ɵmod: i0.ɵɵNgModuleDeclaration<CuiFormFieldModule, [typeof i1.CuiFormFieldComponent], never, [typeof i1.CuiFormFieldComponent]>;
6
+ static ɵinj: i0.ɵɵInjectorDeclaration<CuiFormFieldModule>;
7
+ }
@@ -0,0 +1,2 @@
1
+ export * from './form-field.component';
2
+ export * from './form-field.module';
@@ -8,6 +8,7 @@ export * from './checkbox';
8
8
  export * from './context-menu';
9
9
  export * from './dialog';
10
10
  export * from './editor';
11
+ export * from './form-field';
11
12
  export * from './hint';
12
13
  export * from './icon-button';
13
14
  export * from './input-number';
@@ -17,6 +18,7 @@ export * from './label';
17
18
  export * from './notification';
18
19
  export * from './radio';
19
20
  export * from './root';
21
+ export * from './select';
20
22
  export * from './svg';
21
23
  export * from './textarea';
22
24
  export * from './toggle';
@@ -0,0 +1,2 @@
1
+ export * from './select.component';
2
+ export * from './select.module';
@@ -0,0 +1,44 @@
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 id(): string | undefined;
28
+ protected get size(): CuiSizeSm | CuiSizeMd;
29
+ protected get placeholder(): string | undefined;
30
+ protected get isError(): boolean;
31
+ protected trackByFn(_: number, item: CuiOption): string;
32
+ writeValue(value: unknown): void;
33
+ registerOnChange(fn: CuiOnChange<unknown>): void;
34
+ registerOnTouched(fn: CuiOnTouched): void;
35
+ ngOnInit(): void;
36
+ setDisabledState(isDisabled: boolean): void;
37
+ protected onSelect(option: CuiOption): void;
38
+ protected onSwitch(): void;
39
+ private initClickOutsideSubscription;
40
+ private open;
41
+ private close;
42
+ static ɵfac: i0.ɵɵFactoryDeclaration<CuiSelectComponent, never>;
43
+ static ɵcmp: i0.ɵɵComponentDeclaration<CuiSelectComponent, "cui-select[options]", never, { "options": "options"; }, {}, never, never, false, [{ directive: typeof i1.CuiClickOutsideDirective; inputs: {}; outputs: {}; }]>;
44
+ }
@@ -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
+ }
@@ -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 "@angular/common";
5
- import * as i2 from "../svg/svg.component";
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: { "document:click": "onClickOutside($event.target)", "window:scroll": "onClose()", "window:resize": "onClose()", "click": "onStopClickPropagation($event)" }, properties: { "class._hidden": "this.isHidden", "style.left.px": "this.clientX", "style.top.px": "this.clientY" } }, 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: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
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":"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","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"]}
@@ -0,0 +1,11 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class CuiFormFieldComponent {
4
+ }
5
+ CuiFormFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiFormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
+ CuiFormFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiFormFieldComponent, selector: "cui-form-field", ngImport: i0, template: "<ng-content select=\"label[cuiLabel]\" />\n<ng-content />\n<div class=\"c-hint-container\">\n <ng-content select=\"cui-hint\" />\n</div>\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 });
7
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiFormFieldComponent, decorators: [{
8
+ type: Component,
9
+ args: [{ selector: 'cui-form-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content select=\"label[cuiLabel]\" />\n<ng-content />\n<div class=\"c-hint-container\">\n <ng-content select=\"cui-hint\" />\n</div>\n", styles: [":host{display:flex;flex-direction:column;gap:4px}.c-hint-container{margin-top:2px}.c-hint-container:empty{display:contents}\n"] }]
10
+ }] });
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZm9ybS1maWVsZC9mb3JtLWZpZWxkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9mb3JtLWZpZWxkL2Zvcm0tZmllbGQudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVFuRSxNQUFNLE9BQU8scUJBQXFCOzttSEFBckIscUJBQXFCO3VHQUFyQixxQkFBcUIsc0RDUmxDLCtJQUtBOzRGREdhLHFCQUFxQjtrQkFOakMsU0FBUzsrQkFDRSxnQkFBZ0IsbUJBR1QsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnY3VpLWZvcm0tZmllbGQnLFxuICB0ZW1wbGF0ZVVybDogJy4vZm9ybS1maWVsZC50ZW1wbGF0ZS5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZm9ybS1maWVsZC5zdHlsZS5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEN1aUZvcm1GaWVsZENvbXBvbmVudCB7XG59XG4iLCI8bmctY29udGVudCBzZWxlY3Q9XCJsYWJlbFtjdWlMYWJlbF1cIiAvPlxuPG5nLWNvbnRlbnQgLz5cbjxkaXYgY2xhc3M9XCJjLWhpbnQtY29udGFpbmVyXCI+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiY3VpLWhpbnRcIiAvPlxuPC9kaXY+XG4iXX0=
@@ -0,0 +1,16 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CuiFormFieldComponent } from './form-field.component';
3
+ import * as i0 from "@angular/core";
4
+ export class CuiFormFieldModule {
5
+ }
6
+ CuiFormFieldModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiFormFieldModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
7
+ CuiFormFieldModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: CuiFormFieldModule, declarations: [CuiFormFieldComponent], exports: [CuiFormFieldComponent] });
8
+ CuiFormFieldModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiFormFieldModule });
9
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiFormFieldModule, decorators: [{
10
+ type: NgModule,
11
+ args: [{
12
+ declarations: [CuiFormFieldComponent],
13
+ exports: [CuiFormFieldComponent]
14
+ }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZm9ybS1maWVsZC9mb3JtLWZpZWxkLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU0vRCxNQUFNLE9BQU8sa0JBQWtCOztnSEFBbEIsa0JBQWtCO2lIQUFsQixrQkFBa0IsaUJBSGQscUJBQXFCLGFBQzFCLHFCQUFxQjtpSEFFcEIsa0JBQWtCOzRGQUFsQixrQkFBa0I7a0JBSjlCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMscUJBQXFCLENBQUM7b0JBQ3JDLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO2lCQUNqQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEN1aUZvcm1GaWVsZENvbXBvbmVudCB9IGZyb20gJy4vZm9ybS1maWVsZC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtDdWlGb3JtRmllbGRDb21wb25lbnRdLFxuICBleHBvcnRzOiBbQ3VpRm9ybUZpZWxkQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBDdWlGb3JtRmllbGRNb2R1bGUge1xufVxuIl19
@@ -0,0 +1,3 @@
1
+ export * from './form-field.component';
2
+ export * from './form-field.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZm9ybS1maWVsZC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMscUJBQXFCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Zvcm0tZmllbGQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS1maWVsZC5tb2R1bGUnO1xuIl19
@@ -8,6 +8,7 @@ export * from './checkbox';
8
8
  export * from './context-menu';
9
9
  export * from './dialog';
10
10
  export * from './editor';
11
+ export * from './form-field';
11
12
  export * from './hint';
12
13
  export * from './icon-button';
13
14
  export * from './input-number';
@@ -17,7 +18,8 @@ export * from './label';
17
18
  export * from './notification';
18
19
  export * from './radio';
19
20
  export * from './root';
21
+ export * from './select';
20
22
  export * from './svg';
21
23
  export * from './textarea';
22
24
  export * from './toggle';
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsT0FBTyxDQUFDO0FBQ3RCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY2NvcmRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydCc7XG5leHBvcnQgKiBmcm9tICcuL2Jhbm5lcic7XG5leHBvcnQgKiBmcm9tICcuL2JyZWFkY3J1bWJzJztcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uJztcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uLWdyb3VwJztcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tib3gnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LW1lbnUnO1xuZXhwb3J0ICogZnJvbSAnLi9kaWFsb2cnO1xuZXhwb3J0ICogZnJvbSAnLi9lZGl0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9oaW50JztcbmV4cG9ydCAqIGZyb20gJy4vaWNvbi1idXR0b24nO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1udW1iZXInO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1wYXNzd29yZCc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LXRleHQnO1xuZXhwb3J0ICogZnJvbSAnLi9sYWJlbCc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3JhZGlvJztcbmV4cG9ydCAqIGZyb20gJy4vcm9vdCc7XG5leHBvcnQgKiBmcm9tICcuL3N2Zyc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRhcmVhJztcbmV4cG9ydCAqIGZyb20gJy4vdG9nZ2xlJztcbiJdfQ==
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsT0FBTyxDQUFDO0FBQ3RCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY2NvcmRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydCc7XG5leHBvcnQgKiBmcm9tICcuL2Jhbm5lcic7XG5leHBvcnQgKiBmcm9tICcuL2JyZWFkY3J1bWJzJztcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uJztcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uLWdyb3VwJztcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tib3gnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LW1lbnUnO1xuZXhwb3J0ICogZnJvbSAnLi9kaWFsb2cnO1xuZXhwb3J0ICogZnJvbSAnLi9lZGl0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtLWZpZWxkJztcbmV4cG9ydCAqIGZyb20gJy4vaGludCc7XG5leHBvcnQgKiBmcm9tICcuL2ljb24tYnV0dG9uJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtbnVtYmVyJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtcGFzc3dvcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC10ZXh0JztcbmV4cG9ydCAqIGZyb20gJy4vbGFiZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9ub3RpZmljYXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9yYWRpbyc7XG5leHBvcnQgKiBmcm9tICcuL3Jvb3QnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3QnO1xuZXhwb3J0ICogZnJvbSAnLi9zdmcnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0YXJlYSc7XG5leHBvcnQgKiBmcm9tICcuL3RvZ2dsZSc7XG4iXX0=
@@ -7,11 +7,11 @@ export class CuiLabelComponent {
7
7
  }
8
8
  }
9
9
  CuiLabelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
10
- CuiLabelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiLabelComponent, selector: "label[cuiLabel]", inputs: { isRequired: "isRequired" }, ngImport: i0, template: "<ng-content></ng-content>\n<span\n *ngIf=\"isRequired\"\n class=\"c-star\"\n>\n *\n</span>\n", styles: [":host{font-weight:500;font-size:14px;line-height:20px;display:inline-flex;gap:2px;color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-star{color:var(--cui-danger)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
10
+ CuiLabelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiLabelComponent, selector: "label[cuiLabel]", inputs: { isRequired: "isRequired" }, ngImport: i0, template: "<span class=\"c-wrapper\">\n <ng-content></ng-content>\n</span>\n<span\n *ngIf=\"isRequired\"\n class=\"c-star\"\n>\n *\n</span>\n", styles: [":host{font-weight:500;font-size:14px;line-height:20px;display:inline-flex;gap:2px;cursor:pointer;width:-moz-fit-content;width:fit-content;color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-wrapper{display:inline-flex;align-items:center;gap:8px}.c-star{color:var(--cui-danger)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
11
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiLabelComponent, decorators: [{
12
12
  type: Component,
13
- args: [{ selector: 'label[cuiLabel]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n<span\n *ngIf=\"isRequired\"\n class=\"c-star\"\n>\n *\n</span>\n", styles: [":host{font-weight:500;font-size:14px;line-height:20px;display:inline-flex;gap:2px;color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-star{color:var(--cui-danger)}\n"] }]
13
+ args: [{ selector: 'label[cuiLabel]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span class=\"c-wrapper\">\n <ng-content></ng-content>\n</span>\n<span\n *ngIf=\"isRequired\"\n class=\"c-star\"\n>\n *\n</span>\n", styles: [":host{font-weight:500;font-size:14px;line-height:20px;display:inline-flex;gap:2px;cursor:pointer;width:-moz-fit-content;width:fit-content;color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-wrapper{display:inline-flex;align-items:center;gap:8px}.c-star{color:var(--cui-danger)}\n"] }]
14
14
  }], propDecorators: { isRequired: [{
15
15
  type: Input
16
16
  }] } });
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2xhYmVsL2xhYmVsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9sYWJlbC9sYWJlbC50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFRMUUsTUFBTSxPQUFPLGlCQUFpQjtJQU45QjtRQVFTLGVBQVUsR0FBRyxLQUFLLENBQUM7S0FDM0I7OytHQUhZLGlCQUFpQjttR0FBakIsaUJBQWlCLDZGQ1I5QixpR0FPQTs0RkRDYSxpQkFBaUI7a0JBTjdCLFNBQVM7K0JBQ0UsaUJBQWlCLG1CQUdWLHVCQUF1QixDQUFDLE1BQU07OEJBSXhDLFVBQVU7c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsYWJlbFtjdWlMYWJlbF0nLFxuICB0ZW1wbGF0ZVVybDogJy4vbGFiZWwudGVtcGxhdGUuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2xhYmVsLnN0eWxlLnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQ3VpTGFiZWxDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgaXNSZXF1aXJlZCA9IGZhbHNlO1xufVxuIiwiPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPHNwYW5cbiAgKm5nSWY9XCJpc1JlcXVpcmVkXCJcbiAgY2xhc3M9XCJjLXN0YXJcIlxuPlxuICAqXG48L3NwYW4+XG4iXX0=
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2xhYmVsL2xhYmVsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9sYWJlbC9sYWJlbC50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFRMUUsTUFBTSxPQUFPLGlCQUFpQjtJQU45QjtRQVFTLGVBQVUsR0FBRyxLQUFLLENBQUM7S0FDM0I7OytHQUhZLGlCQUFpQjttR0FBakIsaUJBQWlCLDZGQ1I5Qix3SUFTQTs0RkREYSxpQkFBaUI7a0JBTjdCLFNBQVM7K0JBQ0UsaUJBQWlCLG1CQUdWLHVCQUF1QixDQUFDLE1BQU07OEJBSXhDLFVBQVU7c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsYWJlbFtjdWlMYWJlbF0nLFxuICB0ZW1wbGF0ZVVybDogJy4vbGFiZWwudGVtcGxhdGUuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2xhYmVsLnN0eWxlLnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQ3VpTGFiZWxDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgaXNSZXF1aXJlZCA9IGZhbHNlO1xufVxuIiwiPHNwYW4gY2xhc3M9XCJjLXdyYXBwZXJcIj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPC9zcGFuPlxuPHNwYW5cbiAgKm5nSWY9XCJpc1JlcXVpcmVkXCJcbiAgY2xhc3M9XCJjLXN0YXJcIlxuPlxuICAqXG48L3NwYW4+XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './select.component';
2
+ export * from './select.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvc2VsZWN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC5tb2R1bGUnO1xuIl19
@@ -0,0 +1,114 @@
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 id() {
26
+ return this.cuiTextFieldController.id;
27
+ }
28
+ get size() {
29
+ return this.cuiTextFieldController.size;
30
+ }
31
+ get placeholder() {
32
+ return this.cuiTextFieldController.placeholder;
33
+ }
34
+ get isError() {
35
+ return this.cuiTextFieldController.isError;
36
+ }
37
+ trackByFn(_, item) {
38
+ return item.label;
39
+ }
40
+ writeValue(value) {
41
+ this.value = value;
42
+ this.changeDetectorRef.markForCheck();
43
+ }
44
+ registerOnChange(fn) {
45
+ this.onChange = fn;
46
+ }
47
+ registerOnTouched(fn) {
48
+ this.onTouched = fn;
49
+ }
50
+ ngOnInit() {
51
+ this.initClickOutsideSubscription();
52
+ }
53
+ setDisabledState(isDisabled) {
54
+ this.isDisabled = isDisabled;
55
+ this.changeDetectorRef.markForCheck();
56
+ }
57
+ onSelect(option) {
58
+ this.value = option.value;
59
+ this.selectedOption = option;
60
+ this.onChange(this.value);
61
+ this.onSwitch();
62
+ this.onTouched();
63
+ }
64
+ onSwitch() {
65
+ if (!this.isOpened) {
66
+ this.open();
67
+ return;
68
+ }
69
+ this.close();
70
+ }
71
+ initClickOutsideSubscription() {
72
+ this.cuiClickOutsideDirective.cuiClickOutside
73
+ .pipe(takeUntil(this.destroy$))
74
+ .subscribe(() => {
75
+ if (this.isOpened) {
76
+ this.onTouched();
77
+ }
78
+ this.close();
79
+ });
80
+ }
81
+ open() {
82
+ this.isOpened = true;
83
+ const { bottom: elementRectBottom } = this.element.getBoundingClientRect();
84
+ const distanceToBottom = this.document.documentElement.clientHeight
85
+ - (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);
86
+ this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;
87
+ }
88
+ close() {
89
+ this.isOpened = false;
90
+ }
91
+ }
92
+ CuiSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
93
+ 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: [
94
+ CUI_TEXT_FILED_CONTROLLER_PROVIDER,
95
+ cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
96
+ CuiDestroyService
97
+ ], viewQueries: [{ propertyName: "getOptionsListHeightContainer", first: true, predicate: ["getOptionsListHeightContainer"], descendants: true }], hostDirectives: [{ directive: i1.CuiClickOutsideDirective }], ngImport: i0, template: "<button\n [attr.id]=\"id\"\n [attr.data-size]=\"size\"\n [disabled]=\"isDisabled\"\n class=\"c-button\"\n [class.c-button_with-error]=\"isError\"\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 });
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectComponent, decorators: [{
99
+ type: Component,
100
+ args: [{ selector: 'cui-select[options]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
101
+ CUI_TEXT_FILED_CONTROLLER_PROVIDER,
102
+ cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
103
+ CuiDestroyService
104
+ ], hostDirectives: [CuiClickOutsideDirective], template: "<button\n [attr.id]=\"id\"\n [attr.data-size]=\"size\"\n [disabled]=\"isDisabled\"\n class=\"c-button\"\n [class.c-button_with-error]=\"isError\"\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"] }]
105
+ }], propDecorators: { options: [{
106
+ type: Input
107
+ }], getOptionsListHeightContainer: [{
108
+ type: ViewChild,
109
+ args: ['getOptionsListHeightContainer']
110
+ }], gap: [{
111
+ type: HostBinding,
112
+ args: ['style.--c-gap']
113
+ }] } });
114
+ //# 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 id(): string | undefined {\n    return this.cuiTextFieldController.id;\n  }\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.id]=\"id\"\n  [attr.data-size]=\"size\"\n  [disabled]=\"isDisabled\"\n  class=\"c-button\"\n  [class.c-button_with-error]=\"isError\"\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"]}
@@ -0,0 +1,29 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { CuiSelectComponent } from './select.component';
4
+ import { CuiSvgModule } from '../svg';
5
+ import { CuiTextFieldControllerModule } from '../../directives';
6
+ import * as i0 from "@angular/core";
7
+ export class CuiSelectModule {
8
+ }
9
+ CuiSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
10
+ CuiSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectModule, declarations: [CuiSelectComponent], imports: [CommonModule,
11
+ CuiSvgModule], exports: [CuiSelectComponent,
12
+ CuiTextFieldControllerModule] });
13
+ CuiSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectModule, imports: [CommonModule,
14
+ CuiSvgModule, CuiTextFieldControllerModule] });
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectModule, decorators: [{
16
+ type: NgModule,
17
+ args: [{
18
+ imports: [
19
+ CommonModule,
20
+ CuiSvgModule
21
+ ],
22
+ declarations: [CuiSelectComponent],
23
+ exports: [
24
+ CuiSelectComponent,
25
+ CuiTextFieldControllerModule
26
+ ]
27
+ }]
28
+ }] });
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9zZWxlY3Qvc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ3RDLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLGtCQUFrQixDQUFDOztBQWFoRSxNQUFNLE9BQU8sZUFBZTs7NkdBQWYsZUFBZTs4R0FBZixlQUFlLGlCQU5YLGtCQUFrQixhQUgvQixZQUFZO1FBQ1osWUFBWSxhQUlaLGtCQUFrQjtRQUNsQiw0QkFBNEI7OEdBR25CLGVBQWUsWUFUeEIsWUFBWTtRQUNaLFlBQVksRUFLWiw0QkFBNEI7NEZBR25CLGVBQWU7a0JBWDNCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osWUFBWTtxQkFDYjtvQkFDRCxZQUFZLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztvQkFDbEMsT0FBTyxFQUFFO3dCQUNQLGtCQUFrQjt3QkFDbEIsNEJBQTRCO3FCQUM3QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5pbXBvcnQgeyBDdWlTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ3VpU3ZnTW9kdWxlIH0gZnJvbSAnLi4vc3ZnJztcbmltcG9ydCB7IEN1aVRleHRGaWVsZENvbnRyb2xsZXJNb2R1bGUgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBDdWlTdmdNb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbQ3VpU2VsZWN0Q29tcG9uZW50XSxcbiAgZXhwb3J0czogW1xuICAgIEN1aVNlbGVjdENvbXBvbmVudCxcbiAgICBDdWlUZXh0RmllbGRDb250cm9sbGVyTW9kdWxlXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgQ3VpU2VsZWN0TW9kdWxlIHtcbn1cbiJdfQ==
@@ -1,2 +1,3 @@
1
1
  export * from './context-menu-item';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2ludGVyZmFjZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1tZW51LWl0ZW0nO1xuIl19
2
+ export * from './option';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2ludGVyZmFjZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1tZW51LWl0ZW0nO1xuZXhwb3J0ICogZnJvbSAnLi9vcHRpb24nOyJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9pbnRlcmZhY2VzL29wdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBDdWlPcHRpb24ge1xuICByZWFkb25seSBsYWJlbDogc3RyaW5nO1xuICByZWFkb25seSB2YWx1ZTogdW5rbm93bjtcbn1cbiJdfQ==