@cuby-ui/core 0.0.115 → 0.0.117
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/dialog/dialogs.component.d.ts +1 -0
- package/esm2020/components/dialog/dialogs.component.mjs +4 -2
- package/esm2020/components/select/select.component.mjs +3 -2
- package/fesm2015/cuby-ui-core.mjs +6 -2
- package/fesm2015/cuby-ui-core.mjs.map +1 -1
- package/fesm2020/cuby-ui-core.mjs +5 -2
- package/fesm2020/cuby-ui-core.mjs.map +1 -1
- package/package.json +3 -3
|
@@ -5,6 +5,7 @@ import type { Observable } from 'rxjs';
|
|
|
5
5
|
import type { CuiDialogOptions } from './dialog.interfaces';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export declare class CuiDialogsComponent implements OnInit {
|
|
8
|
+
private readonly injector;
|
|
8
9
|
private readonly destroy$;
|
|
9
10
|
protected readonly dialogs$: Observable<ReadonlyArray<CuiPopover<CuiDialogOptions>>>;
|
|
10
11
|
protected dialogInjectorCache: Map<string, Injector>;
|
|
@@ -7,6 +7,7 @@ import * as i1 from "@angular/common";
|
|
|
7
7
|
import * as i2 from "@cuby-ui/cdk";
|
|
8
8
|
export class CuiDialogsComponent {
|
|
9
9
|
constructor() {
|
|
10
|
+
this.injector = inject(Injector);
|
|
10
11
|
this.destroy$ = inject(CuiDestroyService, { self: true });
|
|
11
12
|
this.dialogs$ = inject(CUI_DIALOGS);
|
|
12
13
|
this.dialogInjectorCache = new Map();
|
|
@@ -24,7 +25,8 @@ export class CuiDialogsComponent {
|
|
|
24
25
|
this.dialogInjectors = dialogs.map(dialog => {
|
|
25
26
|
if (!this.dialogInjectorCache.has(dialog.id)) {
|
|
26
27
|
this.dialogInjectorCache.set(dialog.id, Injector.create({
|
|
27
|
-
providers: [{ provide: CUI_DIALOG_CONTEXT, useValue: dialog }]
|
|
28
|
+
providers: [{ provide: CUI_DIALOG_CONTEXT, useValue: dialog }],
|
|
29
|
+
parent: this.injector
|
|
28
30
|
}));
|
|
29
31
|
}
|
|
30
32
|
return this.dialogInjectorCache.get(dialog.id);
|
|
@@ -44,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
44
46
|
type: Component,
|
|
45
47
|
args: [{ selector: 'cui-dialogs', changeDetection: ChangeDetectionStrategy.OnPush, providers: [CuiDestroyService], template: "<ng-container *cuiLet=\"dialogs$ | async as dialogs\">\n <ng-container *ngFor=\"let dialog of dialogs; let i = index; trackBy: trackByFn\">\n <ng-container *ngComponentOutlet=\"dialog.component; injector: dialogInjectors[i]\"></ng-container>\n </ng-container>\n <div\n *ngIf=\"dialogs!.length\"\n class=\"c-overlay\"\n ></div>\n</ng-container>\n", styles: [".c-overlay{position:fixed;inset:0;background:var(--cui-base-900);opacity:.3}\n"] }]
|
|
46
48
|
}] });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9ncy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZGlhbG9nL2RpYWxvZ3MuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2RpYWxvZy9kaWFsb2dzLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXJGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUVqRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRWpDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7OztBQVVsRSxNQUFNLE9BQU8sbUJBQW1CO0lBUGhDO1FBUW1CLGFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDNUIsYUFBUSxHQUFHLE1BQU0sQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBRW5ELGFBQVEsR0FBNEQsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ2pHLHdCQUFtQixHQUFHLElBQUksR0FBRyxFQUFvQixDQUFDO0tBbUM3RDtJQWhDUSxRQUFRO1FBQ2IsSUFBSSxDQUFDLCtCQUErQixFQUFFLENBQUM7SUFDekMsQ0FBQztJQUVTLFNBQVMsQ0FBQyxDQUFTLEVBQUUsTUFBb0M7UUFDakUsT0FBTyxNQUFNLENBQUMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFUywrQkFBK0I7UUFDdkMsSUFBSSxDQUFDLFFBQVE7YUFDWixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUM5QixTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDbkIsSUFBSSxDQUFDLGVBQWUsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFO2dCQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLEVBQUU7b0JBQzVDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxRQUFRLENBQUMsTUFBTSxDQUFDO3dCQUN0RCxTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLENBQUM7d0JBQzlELE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUTtxQkFDdEIsQ0FBQyxDQUFDLENBQUM7aUJBQ0w7Z0JBRUQsT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUUsQ0FBQztZQUNsRCxDQUFDLENBQUMsQ0FBQztZQUVILElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsUUFBUSxFQUFFLEVBQUU7Z0JBQy9DLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEtBQUssUUFBUSxDQUFDLEVBQUU7b0JBQ2xELE9BQU87aUJBQ1I7Z0JBRUQsSUFBSSxDQUFDLG1CQUFtQixDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM1QyxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7aUhBdkNVLG1CQUFtQjtxR0FBbkIsbUJBQW1CLHNDQUZuQixDQUFDLGlCQUFpQixDQUFDLDBCQ2ZoQyx3V0FTQTs0RkRRYSxtQkFBbUI7a0JBUC9CLFNBQVM7K0JBQ0UsYUFBYSxtQkFHTix1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDLENBQUMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgaW5qZWN0LCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUgeyBDdWlQb3BvdmVyIH0gZnJvbSAnQGN1YnktdWkvY2RrJztcbmltcG9ydCB7IEN1aURlc3Ryb3lTZXJ2aWNlIH0gZnJvbSAnQGN1YnktdWkvY2RrJztcbmltcG9ydCB0eXBlIHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgdGFrZVVudGlsIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IENVSV9ESUFMT0dfQ09OVEVYVCwgQ1VJX0RJQUxPR1MgfSBmcm9tICcuL2RpYWxvZy50b2tlbnMnO1xuaW1wb3J0IHR5cGUgeyBDdWlEaWFsb2dPcHRpb25zIH0gZnJvbSAnLi9kaWFsb2cuaW50ZXJmYWNlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2N1aS1kaWFsb2dzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RpYWxvZ3MudGVtcGxhdGUuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2RpYWxvZ3Muc3R5bGUuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgcHJvdmlkZXJzOiBbQ3VpRGVzdHJveVNlcnZpY2VdXG59KVxuZXhwb3J0IGNsYXNzIEN1aURpYWxvZ3NDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBwcml2YXRlIHJlYWRvbmx5IGluamVjdG9yID0gaW5qZWN0KEluamVjdG9yKTtcbiAgcHJpdmF0ZSByZWFkb25seSBkZXN0cm95JCA9IGluamVjdChDdWlEZXN0cm95U2VydmljZSwgeyBzZWxmOiB0cnVlIH0pO1xuXG4gIHByb3RlY3RlZCByZWFkb25seSBkaWFsb2dzJDogT2JzZXJ2YWJsZTxSZWFkb25seUFycmF5PEN1aVBvcG92ZXI8Q3VpRGlhbG9nT3B0aW9ucz4+PiA9IGluamVjdChDVUlfRElBTE9HUyk7XG4gIHByb3RlY3RlZCBkaWFsb2dJbmplY3RvckNhY2hlID0gbmV3IE1hcDxzdHJpbmcsIEluamVjdG9yPigpO1xuICBwcm90ZWN0ZWQgZGlhbG9nSW5qZWN0b3JzITogUmVhZG9ubHlBcnJheTxJbmplY3Rvcj47XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuaW5pdERpYWxvZ0luamVjdG9yc1N1YnNjcmlwdGlvbigpO1xuICB9XG5cbiAgcHJvdGVjdGVkIHRyYWNrQnlGbihfOiBudW1iZXIsIGRpYWxvZzogQ3VpUG9wb3ZlcjxDdWlEaWFsb2dPcHRpb25zPik6IHN0cmluZyB7XG4gICAgcmV0dXJuIGRpYWxvZy5pZDtcbiAgfVxuXG4gIHByb3RlY3RlZCBpbml0RGlhbG9nSW5qZWN0b3JzU3Vic2NyaXB0aW9uKCk6IHZvaWQge1xuICAgIHRoaXMuZGlhbG9ncyRcbiAgICAucGlwZSh0YWtlVW50aWwodGhpcy5kZXN0cm95JCkpXG4gICAgLnN1YnNjcmliZShkaWFsb2dzID0+IHtcbiAgICAgIHRoaXMuZGlhbG9nSW5qZWN0b3JzID0gZGlhbG9ncy5tYXAoZGlhbG9nID0+IHtcbiAgICAgICAgaWYgKCF0aGlzLmRpYWxvZ0luamVjdG9yQ2FjaGUuaGFzKGRpYWxvZy5pZCkpIHtcbiAgICAgICAgICB0aGlzLmRpYWxvZ0luamVjdG9yQ2FjaGUuc2V0KGRpYWxvZy5pZCwgSW5qZWN0b3IuY3JlYXRlKHtcbiAgICAgICAgICAgIHByb3ZpZGVyczogW3sgcHJvdmlkZTogQ1VJX0RJQUxPR19DT05URVhULCB1c2VWYWx1ZTogZGlhbG9nIH1dLFxuICAgICAgICAgICAgcGFyZW50OiB0aGlzLmluamVjdG9yXG4gICAgICAgICAgfSkpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRoaXMuZGlhbG9nSW5qZWN0b3JDYWNoZS5nZXQoZGlhbG9nLmlkKSE7XG4gICAgICB9KTtcblxuICAgICAgdGhpcy5kaWFsb2dJbmplY3RvckNhY2hlLmZvckVhY2goKF8sIGRpYWxvZ0lkKSA9PiB7XG4gICAgICAgIGlmIChkaWFsb2dzLmZpbmQoZGlhbG9nID0+IGRpYWxvZy5pZCA9PT0gZGlhbG9nSWQpKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5kaWFsb2dJbmplY3RvckNhY2hlLmRlbGV0ZShkaWFsb2dJZCk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxufVxuIiwiPG5nLWNvbnRhaW5lciAqY3VpTGV0PVwiZGlhbG9ncyQgfCBhc3luYyBhcyBkaWFsb2dzXCI+XG4gIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGRpYWxvZyBvZiBkaWFsb2dzOyBsZXQgaSA9IGluZGV4OyB0cmFja0J5OiB0cmFja0J5Rm5cIj5cbiAgICA8bmctY29udGFpbmVyICpuZ0NvbXBvbmVudE91dGxldD1cImRpYWxvZy5jb21wb25lbnQ7IGluamVjdG9yOiBkaWFsb2dJbmplY3RvcnNbaV1cIj48L25nLWNvbnRhaW5lcj5cbiAgPC9uZy1jb250YWluZXI+XG4gIDxkaXZcbiAgICAqbmdJZj1cImRpYWxvZ3MhLmxlbmd0aFwiXG4gICAgY2xhc3M9XCJjLW92ZXJsYXlcIlxuICA+PC9kaXY+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
|
|
@@ -41,7 +41,8 @@ export class CuiSelectComponent {
|
|
|
41
41
|
}
|
|
42
42
|
writeValue(value) {
|
|
43
43
|
this.value = value;
|
|
44
|
-
|
|
44
|
+
// TODO: Непонятно, зачем нужно в construction вторая часть выражения
|
|
45
|
+
this.selectedOption = this.options.find(option => option.value === value) ?? value;
|
|
45
46
|
this.changeDetectorRef.markForCheck();
|
|
46
47
|
}
|
|
47
48
|
registerOnChange(fn) {
|
|
@@ -158,4 +159,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
158
159
|
type: HostListener,
|
|
159
160
|
args: ['window:resize']
|
|
160
161
|
}] } });
|
|
161
|
-
//# 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 { OnDestroy, OnInit, TemplateRef } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  inject,\n  Input,\n  ElementRef,\n  ViewChild,\n  HostBinding,\n  ViewContainerRef,\n  HostListener\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';\nimport { CUI_ROOT_SELECTOR } from '../root';\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, OnDestroy {\n  private readonly element = inject(ElementRef).nativeElement;\n  private readonly document = inject(DOCUMENT);\n  private readonly changeDetectorRef = inject(ChangeDetectorRef);\n  private readonly viewContainerRef = inject(ViewContainerRef);\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  @Input()\n  public defaultOptionText?: string;\n\n  @ViewChild('button')\n  protected readonly button!: ElementRef<HTMLButtonElement>;\n\n  @ViewChild('getOptionsListHeightContainer')\n  protected readonly getOptionsListHeightContainer!: ElementRef<HTMLUListElement>;\n\n  @ViewChild('optionsWrapper')\n  protected readonly optionsWrapper!: TemplateRef<unknown>;\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    this.selectedOption = value as CuiOption;\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 ngOnDestroy(): void {\n    this.clearViewContainerRef();\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.options.length && !this.defaultOptionText) {\n      return;\n    }\n\n    if (!this.isOpened) {\n      this.open();\n\n      return;\n    }\n\n    this.close();\n  }\n\n  protected onClose(): void {\n    this.close();\n  }\n\n  @HostListener('window:resize')\n  protected onWindowResize(): void {\n    this.button.nativeElement.blur();\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 {\n      top: elementRectTop,\n      left: elementRectLeft,\n      bottom: elementRectBottom\n    } = this.element.getBoundingClientRect();\n    const distanceToBottom = this.document.documentElement.clientHeight\n      - (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);\n    const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.optionsWrapper);\n    const node = embeddedViewRef.rootNodes[0];\n    const nodeStyles = node.style;\n\n    this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;\n\n    embeddedViewRef.detectChanges();\n\n    nodeStyles.width = this.element.offsetWidth + 'px';\n    nodeStyles.left = window.scrollX + elementRectLeft + 'px';\n\n    if (this.isOptionsListAbove) {\n      nodeStyles.top = window.scrollY + elementRectTop\n        - this.getOptionsListHeightContainer.nativeElement.offsetHeight\n        - this.SPACE_BETWEEN_BUTTON_AND_OPTIONS\n        + 'px';\n    } else {\n      nodeStyles.top = window.scrollY + elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS + 'px';\n    }\n\n    this.document.querySelector(CUI_ROOT_SELECTOR)!.appendChild(embeddedViewRef.rootNodes[0]);\n  }\n\n  private close(): void {\n    this.isOpened = false;\n\n    this.clearViewContainerRef();\n  }\n\n  private clearViewContainerRef(): void {\n    this.viewContainerRef.clear();\n  }\n}\n","<button\n  #button\n  type=\"button\"\n  [attr.id]=\"id\"\n  [attr.data-size]=\"size\"\n  [disabled]=\"isDisabled\"\n  class=\"c-button\"\n  [class.c-button_active]=\"isOpened\"\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<ng-template #optionsWrapper>\n  <div\n      class=\"c-options__wrapper\"\n      [class.c-options__wrapper_top]=\"isOptionsListAbove\"\n  >\n    <ng-container *ngTemplateOutlet=\"optionsList\"/>\n  </div>\n</ng-template>\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    <ng-container *ngIf=\"options.length; else empty\">\n      <li *ngFor=\"let option of options; trackBy: trackByFn\">\n        <button\n          type=\"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    </ng-container>\n    <ng-template #empty>\n      <li *ngIf=\"defaultOptionText\">\n        <button\n          type=\"button\"\n          class=\"c-option-button\"\n          (click)=\"onClose()\"\n        >\n          {{ defaultOptionText }}\n        </button>\n      </li>\n    </ng-template>\n  </ul>\n</ng-template>\n"]}
|
|
162
|
+
//# 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 { OnDestroy, OnInit, TemplateRef } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  inject,\n  Input,\n  ElementRef,\n  ViewChild,\n  HostBinding,\n  ViewContainerRef,\n  HostListener\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';\nimport { CUI_ROOT_SELECTOR } from '../root';\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, OnDestroy {\n  private readonly element = inject(ElementRef).nativeElement;\n  private readonly document = inject(DOCUMENT);\n  private readonly changeDetectorRef = inject(ChangeDetectorRef);\n  private readonly viewContainerRef = inject(ViewContainerRef);\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  @Input()\n  public defaultOptionText?: string;\n\n  @ViewChild('button')\n  protected readonly button!: ElementRef<HTMLButtonElement>;\n\n  @ViewChild('getOptionsListHeightContainer')\n  protected readonly getOptionsListHeightContainer!: ElementRef<HTMLUListElement>;\n\n  @ViewChild('optionsWrapper')\n  protected readonly optionsWrapper!: TemplateRef<unknown>;\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    // TODO: Непонятно, зачем нужно в construction вторая часть выражения\n    this.selectedOption = this.options.find(option => option.value === value) ?? value as CuiOption;\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 ngOnDestroy(): void {\n    this.clearViewContainerRef();\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.options.length && !this.defaultOptionText) {\n      return;\n    }\n\n    if (!this.isOpened) {\n      this.open();\n\n      return;\n    }\n\n    this.close();\n  }\n\n  protected onClose(): void {\n    this.close();\n  }\n\n  @HostListener('window:resize')\n  protected onWindowResize(): void {\n    this.button.nativeElement.blur();\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 {\n      top: elementRectTop,\n      left: elementRectLeft,\n      bottom: elementRectBottom\n    } = this.element.getBoundingClientRect();\n    const distanceToBottom = this.document.documentElement.clientHeight\n      - (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);\n    const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.optionsWrapper);\n    const node = embeddedViewRef.rootNodes[0];\n    const nodeStyles = node.style;\n\n    this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;\n\n    embeddedViewRef.detectChanges();\n\n    nodeStyles.width = this.element.offsetWidth + 'px';\n    nodeStyles.left = window.scrollX + elementRectLeft + 'px';\n\n    if (this.isOptionsListAbove) {\n      nodeStyles.top = window.scrollY + elementRectTop\n        - this.getOptionsListHeightContainer.nativeElement.offsetHeight\n        - this.SPACE_BETWEEN_BUTTON_AND_OPTIONS\n        + 'px';\n    } else {\n      nodeStyles.top = window.scrollY + elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS + 'px';\n    }\n\n    this.document.querySelector(CUI_ROOT_SELECTOR)!.appendChild(embeddedViewRef.rootNodes[0]);\n  }\n\n  private close(): void {\n    this.isOpened = false;\n\n    this.clearViewContainerRef();\n  }\n\n  private clearViewContainerRef(): void {\n    this.viewContainerRef.clear();\n  }\n}\n","<button\n  #button\n  type=\"button\"\n  [attr.id]=\"id\"\n  [attr.data-size]=\"size\"\n  [disabled]=\"isDisabled\"\n  class=\"c-button\"\n  [class.c-button_active]=\"isOpened\"\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<ng-template #optionsWrapper>\n  <div\n      class=\"c-options__wrapper\"\n      [class.c-options__wrapper_top]=\"isOptionsListAbove\"\n  >\n    <ng-container *ngTemplateOutlet=\"optionsList\"/>\n  </div>\n</ng-template>\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    <ng-container *ngIf=\"options.length; else empty\">\n      <li *ngFor=\"let option of options; trackBy: trackByFn\">\n        <button\n          type=\"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    </ng-container>\n    <ng-template #empty>\n      <li *ngIf=\"defaultOptionText\">\n        <button\n          type=\"button\"\n          class=\"c-option-button\"\n          (click)=\"onClose()\"\n        >\n          {{ defaultOptionText }}\n        </button>\n      </li>\n    </ng-template>\n  </ul>\n</ng-template>\n"]}
|
|
@@ -723,6 +723,7 @@ const CUI_DIALOG_CONTEXT = new InjectionToken('');
|
|
|
723
723
|
|
|
724
724
|
class CuiDialogsComponent {
|
|
725
725
|
constructor() {
|
|
726
|
+
this.injector = inject(Injector);
|
|
726
727
|
this.destroy$ = inject(CuiDestroyService, { self: true });
|
|
727
728
|
this.dialogs$ = inject(CUI_DIALOGS);
|
|
728
729
|
this.dialogInjectorCache = new Map();
|
|
@@ -740,7 +741,8 @@ class CuiDialogsComponent {
|
|
|
740
741
|
this.dialogInjectors = dialogs.map(dialog => {
|
|
741
742
|
if (!this.dialogInjectorCache.has(dialog.id)) {
|
|
742
743
|
this.dialogInjectorCache.set(dialog.id, Injector.create({
|
|
743
|
-
providers: [{ provide: CUI_DIALOG_CONTEXT, useValue: dialog }]
|
|
744
|
+
providers: [{ provide: CUI_DIALOG_CONTEXT, useValue: dialog }],
|
|
745
|
+
parent: this.injector
|
|
744
746
|
}));
|
|
745
747
|
}
|
|
746
748
|
return this.dialogInjectorCache.get(dialog.id);
|
|
@@ -1937,8 +1939,10 @@ class CuiSelectComponent {
|
|
|
1937
1939
|
return item.label;
|
|
1938
1940
|
}
|
|
1939
1941
|
writeValue(value) {
|
|
1942
|
+
var _a;
|
|
1940
1943
|
this.value = value;
|
|
1941
|
-
|
|
1944
|
+
// TODO: Непонятно, зачем нужно в construction вторая часть выражения
|
|
1945
|
+
this.selectedOption = (_a = this.options.find(option => option.value === value)) !== null && _a !== void 0 ? _a : value;
|
|
1942
1946
|
this.changeDetectorRef.markForCheck();
|
|
1943
1947
|
}
|
|
1944
1948
|
registerOnChange(fn) {
|