@cuby-ui/core 0.0.123 → 0.0.125
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/README.md +24 -24
- package/components/accordion/accordion-item/accordion-item.component.d.ts +11 -11
- package/components/accordion/accordion.component.d.ts +5 -5
- package/components/accordion/accordion.module.d.ts +11 -11
- package/components/accordion/index.d.ts +3 -3
- package/components/alert/alert.component.d.ts +13 -13
- package/components/alert/alert.interfaces.d.ts +9 -9
- package/components/alert/alert.module.d.ts +11 -11
- package/components/alert/alert.service.d.ts +7 -7
- package/components/alert/alert.tokens.d.ts +15 -15
- package/components/alert/alert.types.d.ts +3 -3
- package/components/alert/alerts.component.d.ts +17 -17
- package/components/alert/index.d.ts +8 -8
- package/components/badge/badge.component.d.ts +10 -10
- package/components/badge/badge.module.d.ts +8 -8
- package/components/badge/badge.options.d.ts +8 -8
- package/components/badge/index.d.ts +2 -2
- package/components/banner/banner.component.d.ts +21 -21
- package/components/banner/banner.module.d.ts +11 -11
- package/components/banner/banner.options.d.ts +13 -13
- package/components/banner/index.d.ts +3 -3
- package/components/breadcrumbs/breadcrumb/breadcrumb.component.d.ts +6 -6
- package/components/breadcrumbs/breadcrumbs.component.d.ts +7 -7
- package/components/breadcrumbs/breadcrumbs.module.d.ts +10 -10
- package/components/breadcrumbs/index.d.ts +3 -3
- package/components/button/button.component.d.ts +30 -30
- package/components/button/button.module.d.ts +9 -9
- package/components/button/button.options.d.ts +9 -9
- package/components/button/index.d.ts +3 -3
- package/components/button-group/button-group.component.d.ts +5 -5
- package/components/button-group/button-group.module.d.ts +7 -7
- package/components/button-group/index.d.ts +2 -2
- package/components/checkbox/checkbox.component.d.ts +5 -5
- package/components/checkbox/checkbox.module.d.ts +7 -7
- package/components/checkbox/index.d.ts +2 -2
- package/components/context-menu/context-menu.component.d.ts +39 -39
- package/components/context-menu/context-menu.module.d.ts +9 -9
- package/components/context-menu/index.d.ts +2 -2
- package/components/dialog/dialog-actions/dialog-actions.component.d.ts +5 -5
- package/components/dialog/dialog-header/dialog-header.component.d.ts +13 -25
- package/components/dialog/dialog.component.d.ts +37 -37
- package/components/dialog/dialog.interfaces.d.ts +10 -10
- package/components/dialog/dialog.module.d.ts +14 -13
- package/components/dialog/dialog.service.d.ts +7 -7
- package/components/dialog/dialog.tokens.d.ts +8 -8
- package/components/dialog/dialogs.component.d.ts +17 -17
- package/components/dialog/index.d.ts +8 -8
- package/components/form-field/form-field.component.d.ts +5 -5
- package/components/form-field/form-field.module.d.ts +7 -7
- package/components/form-field/index.d.ts +2 -2
- package/components/hint/hint.component.d.ts +7 -7
- package/components/hint/hint.module.d.ts +7 -7
- package/components/hint/index.d.ts +2 -2
- package/components/icon-button/icon-button.component.d.ts +13 -13
- package/components/icon-button/icon-button.module.d.ts +9 -9
- package/components/icon-button/index.d.ts +2 -2
- package/components/index.d.ts +25 -25
- package/components/input-number/index.d.ts +2 -2
- package/components/input-number/input-number.component.d.ts +55 -55
- package/components/input-number/input-number.module.d.ts +11 -11
- package/components/input-number/input-number.options.d.ts +9 -9
- package/components/input-password/index.d.ts +2 -2
- package/components/input-password/input-password.component.d.ts +31 -31
- package/components/input-password/input-password.module.d.ts +11 -11
- package/components/input-text/index.d.ts +2 -2
- package/components/input-text/input-text.component.d.ts +31 -31
- package/components/input-text/input-text.module.d.ts +11 -11
- package/components/label/index.d.ts +2 -2
- package/components/label/label.component.d.ts +6 -6
- package/components/label/label.module.d.ts +8 -8
- package/components/notification/index.d.ts +3 -3
- package/components/notification/notification.component.d.ts +13 -13
- package/components/notification/notification.module.d.ts +10 -10
- package/components/notification/notification.options.d.ts +13 -13
- package/components/radio/index.d.ts +2 -2
- package/components/radio/radio.component.d.ts +5 -5
- package/components/radio/radio.module.d.ts +7 -7
- package/components/root/index.d.ts +3 -3
- package/components/root/root.component.d.ts +11 -11
- package/components/root/root.module.d.ts +10 -10
- package/components/root/root.options.d.ts +1 -1
- package/components/select/index.d.ts +2 -2
- package/components/select/select.component.d.ts +52 -52
- package/components/select/select.module.d.ts +10 -10
- package/components/svg/index.d.ts +2 -2
- package/components/svg/svg.component.d.ts +16 -16
- package/components/svg/svg.module.d.ts +8 -8
- package/components/tabs/index.d.ts +3 -3
- package/components/tabs/tab/index.d.ts +1 -1
- package/components/tabs/tab/tab.component.d.ts +8 -8
- package/components/tabs/tabs.component.d.ts +16 -16
- package/components/tabs/tabs.module.d.ts +8 -8
- package/components/textarea/index.d.ts +2 -2
- package/components/textarea/textarea.component.d.ts +10 -10
- package/components/textarea/textarea.module.d.ts +7 -7
- package/components/toggle/index.d.ts +2 -2
- package/components/toggle/toggle.component.d.ts +5 -5
- package/components/toggle/toggle.module.d.ts +7 -7
- package/directives/index.d.ts +1 -1
- package/directives/text-field-controller/index.d.ts +8 -8
- package/directives/text-field-controller/text-field-controller.module.d.ts +11 -11
- package/directives/text-field-controller/text-field-controller.provider.d.ts +4 -4
- package/directives/text-field-controller/text-field-icon-left.directive.d.ts +9 -9
- package/directives/text-field-controller/text-field-id.directive.d.ts +8 -8
- package/directives/text-field-controller/text-field-is-error.directive.d.ts +8 -8
- package/directives/text-field-controller/text-field-placeholder.directive.d.ts +8 -8
- package/directives/text-field-controller/text-field-size.directive.d.ts +9 -9
- package/directives/text-field-controller/text-field.controller.d.ts +20 -20
- package/esm2020/components/accordion/accordion-item/accordion-item.component.mjs +28 -28
- package/esm2020/components/accordion/accordion.component.mjs +11 -11
- package/esm2020/components/accordion/accordion.module.mjs +37 -37
- package/esm2020/components/accordion/index.mjs +4 -4
- package/esm2020/components/alert/alert.component.mjs +37 -37
- package/esm2020/components/alert/alert.interfaces.mjs +2 -2
- package/esm2020/components/alert/alert.module.mjs +40 -40
- package/esm2020/components/alert/alert.service.mjs +17 -17
- package/esm2020/components/alert/alert.tokens.mjs +19 -19
- package/esm2020/components/alert/alert.types.mjs +2 -2
- package/esm2020/components/alert/alerts.component.mjs +36 -36
- package/esm2020/components/alert/index.mjs +9 -9
- package/esm2020/components/badge/badge.component.mjs +31 -31
- package/esm2020/components/badge/badge.module.mjs +18 -18
- package/esm2020/components/badge/badge.options.mjs +8 -8
- package/esm2020/components/badge/index.mjs +3 -3
- package/esm2020/components/banner/banner.component.mjs +68 -68
- package/esm2020/components/banner/banner.module.mjs +31 -31
- package/esm2020/components/banner/banner.options.mjs +6 -6
- package/esm2020/components/banner/index.mjs +4 -4
- package/esm2020/components/breadcrumbs/breadcrumb/breadcrumb.component.mjs +16 -16
- package/esm2020/components/breadcrumbs/breadcrumbs.component.mjs +17 -17
- package/esm2020/components/breadcrumbs/breadcrumbs.module.mjs +33 -33
- package/esm2020/components/breadcrumbs/index.mjs +4 -4
- package/esm2020/components/button/button.component.mjs +104 -104
- package/esm2020/components/button/button.module.mjs +24 -24
- package/esm2020/components/button/button.options.mjs +10 -10
- package/esm2020/components/button/index.mjs +4 -4
- package/esm2020/components/button-group/button-group.component.mjs +11 -11
- package/esm2020/components/button-group/button-group.module.mjs +16 -16
- package/esm2020/components/button-group/index.mjs +3 -3
- package/esm2020/components/checkbox/checkbox.component.mjs +11 -11
- package/esm2020/components/checkbox/checkbox.module.mjs +16 -16
- package/esm2020/components/checkbox/index.mjs +3 -3
- package/esm2020/components/context-menu/context-menu.component.mjs +146 -146
- package/esm2020/components/context-menu/context-menu.module.mjs +24 -24
- package/esm2020/components/context-menu/index.mjs +3 -3
- package/esm2020/components/dialog/dialog-actions/dialog-actions.component.mjs +11 -11
- package/esm2020/components/dialog/dialog-header/dialog-header.component.mjs +28 -49
- package/esm2020/components/dialog/dialog.component.mjs +76 -76
- package/esm2020/components/dialog/dialog.interfaces.mjs +2 -2
- package/esm2020/components/dialog/dialog.module.mjs +50 -46
- package/esm2020/components/dialog/dialog.service.mjs +17 -17
- package/esm2020/components/dialog/dialog.tokens.mjs +11 -11
- package/esm2020/components/dialog/dialogs.component.mjs +48 -48
- package/esm2020/components/dialog/index.mjs +9 -9
- package/esm2020/components/form-field/form-field.component.mjs +11 -11
- package/esm2020/components/form-field/form-field.module.mjs +16 -16
- package/esm2020/components/form-field/index.mjs +3 -3
- package/esm2020/components/hint/hint.component.mjs +19 -19
- package/esm2020/components/hint/hint.module.mjs +16 -16
- package/esm2020/components/hint/index.mjs +3 -3
- package/esm2020/components/icon-button/icon-button.component.mjs +32 -32
- package/esm2020/components/icon-button/icon-button.module.mjs +24 -24
- package/esm2020/components/icon-button/index.mjs +3 -3
- package/esm2020/components/index.mjs +26 -26
- package/esm2020/components/input-number/index.mjs +3 -3
- package/esm2020/components/input-number/input-number.component.mjs +204 -204
- package/esm2020/components/input-number/input-number.module.mjs +33 -33
- package/esm2020/components/input-number/input-number.options.mjs +11 -11
- package/esm2020/components/input-password/index.mjs +3 -3
- package/esm2020/components/input-password/input-password.component.mjs +89 -89
- package/esm2020/components/input-password/input-password.module.mjs +33 -33
- package/esm2020/components/input-text/index.mjs +3 -3
- package/esm2020/components/input-text/input-text.component.mjs +87 -87
- package/esm2020/components/input-text/input-text.module.mjs +33 -33
- package/esm2020/components/label/index.mjs +3 -3
- package/esm2020/components/label/label.component.mjs +17 -17
- package/esm2020/components/label/label.module.mjs +18 -18
- package/esm2020/components/notification/index.mjs +4 -4
- package/esm2020/components/notification/notification.component.mjs +51 -51
- package/esm2020/components/notification/notification.module.mjs +27 -27
- package/esm2020/components/notification/notification.options.mjs +6 -6
- package/esm2020/components/radio/index.mjs +3 -3
- package/esm2020/components/radio/radio.component.mjs +11 -11
- package/esm2020/components/radio/radio.module.mjs +16 -16
- package/esm2020/components/root/index.mjs +4 -4
- package/esm2020/components/root/root.component.mjs +31 -31
- package/esm2020/components/root/root.module.mjs +28 -28
- package/esm2020/components/root/root.options.mjs +1 -1
- package/esm2020/components/select/index.mjs +3 -3
- package/esm2020/components/select/select.component.mjs +162 -162
- package/esm2020/components/select/select.module.mjs +29 -29
- package/esm2020/components/svg/index.mjs +3 -3
- package/esm2020/components/svg/svg.component.mjs +50 -50
- package/esm2020/components/svg/svg.module.mjs +18 -18
- package/esm2020/components/tabs/index.mjs +4 -4
- package/esm2020/components/tabs/tab/index.mjs +1 -1
- package/esm2020/components/tabs/tab/tab.component.mjs +21 -21
- package/esm2020/components/tabs/tabs.component.mjs +49 -49
- package/esm2020/components/tabs/tabs.module.mjs +18 -18
- package/esm2020/components/textarea/index.mjs +3 -3
- package/esm2020/components/textarea/textarea.component.mjs +35 -35
- package/esm2020/components/textarea/textarea.module.mjs +16 -16
- package/esm2020/components/toggle/index.mjs +3 -3
- package/esm2020/components/toggle/toggle.component.mjs +11 -11
- package/esm2020/components/toggle/toggle.module.mjs +16 -16
- package/esm2020/cuby-ui-core.mjs +4 -4
- package/esm2020/directives/index.mjs +2 -2
- package/esm2020/directives/text-field-controller/index.mjs +9 -9
- package/esm2020/directives/text-field-controller/text-field-controller.module.mjs +40 -40
- package/esm2020/directives/text-field-controller/text-field-controller.provider.mjs +24 -24
- package/esm2020/directives/text-field-controller/text-field-icon-left.directive.mjs +21 -21
- package/esm2020/directives/text-field-controller/text-field-id.directive.mjs +21 -21
- package/esm2020/directives/text-field-controller/text-field-is-error.directive.mjs +24 -24
- package/esm2020/directives/text-field-controller/text-field-placeholder.directive.mjs +21 -21
- package/esm2020/directives/text-field-controller/text-field-size.directive.mjs +24 -24
- package/esm2020/directives/text-field-controller/text-field.controller.mjs +25 -25
- package/esm2020/index.mjs +7 -7
- package/esm2020/interfaces/context-menu-item.mjs +2 -2
- package/esm2020/interfaces/index.mjs +3 -3
- package/esm2020/interfaces/option.mjs +2 -2
- package/esm2020/services/index.mjs +3 -3
- package/esm2020/services/theme.options.mjs +6 -6
- package/esm2020/services/theme.service.mjs +30 -30
- package/esm2020/types/appearance.mjs +2 -2
- package/esm2020/types/hint-type.mjs +2 -2
- package/esm2020/types/index.mjs +8 -8
- package/esm2020/types/position.mjs +2 -2
- package/esm2020/types/resizing.mjs +2 -2
- package/esm2020/types/shape.mjs +2 -2
- package/esm2020/types/size.mjs +2 -2
- package/esm2020/types/status.mjs +2 -2
- package/esm2020/utils/format/index.mjs +3 -3
- package/esm2020/utils/format/remove-spaces.mjs +4 -4
- package/esm2020/utils/format/replace.mjs +5 -5
- package/esm2020/utils/index.mjs +2 -2
- package/fesm2015/cuby-ui-core.mjs +2050 -2067
- package/fesm2015/cuby-ui-core.mjs.map +1 -1
- package/fesm2020/cuby-ui-core.mjs +2049 -2066
- package/fesm2020/cuby-ui-core.mjs.map +1 -1
- package/fonts/Inter-Bold.svg +25443 -25443
- package/fonts/Inter-Medium.svg +25400 -25400
- package/fonts/Inter-Regular.svg +24341 -24341
- package/fonts/Inter-SemiBold.svg +25459 -25459
- package/index.d.ts +6 -6
- package/interfaces/context-menu-item.d.ts +7 -7
- package/interfaces/index.d.ts +2 -2
- package/interfaces/option.d.ts +4 -4
- package/package.json +4 -3
- package/services/index.d.ts +2 -2
- package/services/theme.options.d.ts +5 -5
- package/services/theme.service.d.ts +12 -12
- package/styles/fonts.scss +51 -51
- package/styles/global.scss +9 -9
- package/styles/mixins/buttons.scss +13 -13
- package/styles/mixins/headings.scss +115 -115
- package/styles/mixins/inputs.scss +91 -91
- package/styles/mixins/lists.scss +5 -5
- package/styles/mixins/paddings.scss +35 -35
- package/styles/mixins/shadows.scss +38 -38
- package/styles/mixins/texts.scss +219 -219
- package/styles/theme.scss +351 -351
- package/styles/variables/colors.scss +240 -240
- package/types/appearance.d.ts +8 -8
- package/types/hint-type.d.ts +1 -1
- package/types/index.d.ts +7 -7
- package/types/position.d.ts +2 -2
- package/types/resizing.d.ts +2 -2
- package/types/shape.d.ts +1 -1
- package/types/size.d.ts +4 -4
- package/types/status.d.ts +1 -1
- package/utils/format/index.d.ts +2 -2
- package/utils/format/remove-spaces.d.ts +1 -1
- package/utils/format/replace.d.ts +1 -1
- package/utils/index.d.ts +1 -1
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { CuiRootComponent } from './root.component';
|
|
4
|
-
import { CuiDialogModule } from '../dialog';
|
|
5
|
-
import { CuiAlertModule } from '../alert';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export class CuiRootModule {
|
|
8
|
-
}
|
|
9
|
-
CuiRootModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRootModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
-
CuiRootModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: CuiRootModule, declarations: [CuiRootComponent], imports: [CommonModule,
|
|
11
|
-
CuiDialogModule,
|
|
12
|
-
CuiAlertModule], exports: [CuiRootComponent] });
|
|
13
|
-
CuiRootModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRootModule, imports: [CommonModule,
|
|
14
|
-
CuiDialogModule,
|
|
15
|
-
CuiAlertModule] });
|
|
16
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRootModule, decorators: [{
|
|
17
|
-
type: NgModule,
|
|
18
|
-
args: [{
|
|
19
|
-
imports: [
|
|
20
|
-
CommonModule,
|
|
21
|
-
CuiDialogModule,
|
|
22
|
-
CuiAlertModule
|
|
23
|
-
],
|
|
24
|
-
declarations: [CuiRootComponent],
|
|
25
|
-
exports: [CuiRootComponent]
|
|
26
|
-
}]
|
|
27
|
-
}] });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { CuiRootComponent } from './root.component';
|
|
4
|
+
import { CuiDialogModule } from '../dialog';
|
|
5
|
+
import { CuiAlertModule } from '../alert';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class CuiRootModule {
|
|
8
|
+
}
|
|
9
|
+
CuiRootModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRootModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
CuiRootModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: CuiRootModule, declarations: [CuiRootComponent], imports: [CommonModule,
|
|
11
|
+
CuiDialogModule,
|
|
12
|
+
CuiAlertModule], exports: [CuiRootComponent] });
|
|
13
|
+
CuiRootModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRootModule, imports: [CommonModule,
|
|
14
|
+
CuiDialogModule,
|
|
15
|
+
CuiAlertModule] });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiRootModule, decorators: [{
|
|
17
|
+
type: NgModule,
|
|
18
|
+
args: [{
|
|
19
|
+
imports: [
|
|
20
|
+
CommonModule,
|
|
21
|
+
CuiDialogModule,
|
|
22
|
+
CuiAlertModule
|
|
23
|
+
],
|
|
24
|
+
declarations: [CuiRootComponent],
|
|
25
|
+
exports: [CuiRootComponent]
|
|
26
|
+
}]
|
|
27
|
+
}] });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9vdC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvcm9vdC9yb290Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQzVDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxVQUFVLENBQUM7O0FBVzFDLE1BQU0sT0FBTyxhQUFhOzsyR0FBYixhQUFhOzRHQUFiLGFBQWEsaUJBSFQsZ0JBQWdCLGFBSjdCLFlBQVk7UUFDWixlQUFlO1FBQ2YsY0FBYyxhQUdOLGdCQUFnQjs0R0FFZixhQUFhLFlBUHRCLFlBQVk7UUFDWixlQUFlO1FBQ2YsY0FBYzs0RkFLTCxhQUFhO2tCQVR6QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGVBQWU7d0JBQ2YsY0FBYztxQkFDZjtvQkFDRCxZQUFZLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztvQkFDaEMsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7aUJBQzVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IEN1aVJvb3RDb21wb25lbnQgfSBmcm9tICcuL3Jvb3QuY29tcG9uZW50JztcbmltcG9ydCB7IEN1aURpYWxvZ01vZHVsZSB9IGZyb20gJy4uL2RpYWxvZyc7XG5pbXBvcnQgeyBDdWlBbGVydE1vZHVsZSB9IGZyb20gJy4uL2FsZXJ0JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBDdWlEaWFsb2dNb2R1bGUsXG4gICAgQ3VpQWxlcnRNb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbQ3VpUm9vdENvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtDdWlSb290Q29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBDdWlSb290TW9kdWxlIHtcbn1cbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export const CUI_ROOT_SELECTOR = 'cui-root';
|
|
1
|
+
export const CUI_ROOT_SELECTOR = 'cui-root';
|
|
2
2
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9vdC5vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL3Jvb3Qvcm9vdC5vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBDVUlfUk9PVF9TRUxFQ1RPUiA9ICdjdWktcm9vdCc7Il19
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from './select.component';
|
|
2
|
-
export * from './select.module';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export * from './select.component';
|
|
2
|
+
export * from './select.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvc2VsZWN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC5tb2R1bGUnO1xuIl19
|
|
@@ -1,162 +1,162 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, Input, ElementRef, ViewChild, HostBinding, ViewContainerRef, HostListener } 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 { CUI_ROOT_SELECTOR } from '../root';
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "@cuby-ui/cdk";
|
|
11
|
-
import * as i2 from "@angular/common";
|
|
12
|
-
import * as i3 from "../svg/svg.component";
|
|
13
|
-
export class CuiSelectComponent {
|
|
14
|
-
constructor() {
|
|
15
|
-
this.element = inject(ElementRef).nativeElement;
|
|
16
|
-
this.document = inject(DOCUMENT);
|
|
17
|
-
this.changeDetectorRef = inject(ChangeDetectorRef);
|
|
18
|
-
this.viewContainerRef = inject(ViewContainerRef);
|
|
19
|
-
this.destroy$ = inject(CuiDestroyService, { self: true });
|
|
20
|
-
this.cuiTextFieldController = inject(CUI_TEXT_FIELD_CONTROLLER);
|
|
21
|
-
this.cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });
|
|
22
|
-
this.SPACE_BETWEEN_BUTTON_AND_OPTIONS = 3;
|
|
23
|
-
this.isOpened = false;
|
|
24
|
-
this.isOptionsListAbove = false;
|
|
25
|
-
this.gap = `${this.SPACE_BETWEEN_BUTTON_AND_OPTIONS}px`;
|
|
26
|
-
}
|
|
27
|
-
get id() {
|
|
28
|
-
return this.cuiTextFieldController.id;
|
|
29
|
-
}
|
|
30
|
-
get size() {
|
|
31
|
-
return this.cuiTextFieldController.size;
|
|
32
|
-
}
|
|
33
|
-
get placeholder() {
|
|
34
|
-
return this.cuiTextFieldController.placeholder;
|
|
35
|
-
}
|
|
36
|
-
get isError() {
|
|
37
|
-
return this.cuiTextFieldController.isError;
|
|
38
|
-
}
|
|
39
|
-
trackByFn(_, item) {
|
|
40
|
-
return item.label;
|
|
41
|
-
}
|
|
42
|
-
writeValue(value) {
|
|
43
|
-
this.value = value;
|
|
44
|
-
// TODO: Непонятно, зачем нужно в construction вторая часть выражения
|
|
45
|
-
this.selectedOption = this.options.find(option => option.value === value) ?? value;
|
|
46
|
-
this.changeDetectorRef.markForCheck();
|
|
47
|
-
}
|
|
48
|
-
registerOnChange(fn) {
|
|
49
|
-
this.onChange = fn;
|
|
50
|
-
}
|
|
51
|
-
registerOnTouched(fn) {
|
|
52
|
-
this.onTouched = fn;
|
|
53
|
-
}
|
|
54
|
-
ngOnInit() {
|
|
55
|
-
this.initClickOutsideSubscription();
|
|
56
|
-
}
|
|
57
|
-
ngOnDestroy() {
|
|
58
|
-
this.clearViewContainerRef();
|
|
59
|
-
}
|
|
60
|
-
setDisabledState(isDisabled) {
|
|
61
|
-
this.isDisabled = isDisabled;
|
|
62
|
-
this.changeDetectorRef.markForCheck();
|
|
63
|
-
}
|
|
64
|
-
onSelect(option) {
|
|
65
|
-
this.value = option.value;
|
|
66
|
-
this.selectedOption = option;
|
|
67
|
-
this.onChange(this.value);
|
|
68
|
-
this.onSwitch();
|
|
69
|
-
this.onTouched();
|
|
70
|
-
}
|
|
71
|
-
onSwitch() {
|
|
72
|
-
if (!this.options.length && !this.defaultOptionText) {
|
|
73
|
-
return;
|
|
74
|
-
}
|
|
75
|
-
if (!this.isOpened) {
|
|
76
|
-
this.open();
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
this.close();
|
|
80
|
-
}
|
|
81
|
-
onClose() {
|
|
82
|
-
this.close();
|
|
83
|
-
}
|
|
84
|
-
onWindowResize() {
|
|
85
|
-
this.button.nativeElement.blur();
|
|
86
|
-
this.close();
|
|
87
|
-
}
|
|
88
|
-
initClickOutsideSubscription() {
|
|
89
|
-
this.cuiClickOutsideDirective.cuiClickOutside
|
|
90
|
-
.pipe(takeUntil(this.destroy$))
|
|
91
|
-
.subscribe(() => {
|
|
92
|
-
if (this.isOpened) {
|
|
93
|
-
this.onTouched();
|
|
94
|
-
}
|
|
95
|
-
this.close();
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
open() {
|
|
99
|
-
this.isOpened = true;
|
|
100
|
-
const { top: elementRectTop, left: elementRectLeft, bottom: elementRectBottom } = this.element.getBoundingClientRect();
|
|
101
|
-
const distanceToBottom = this.document.documentElement.clientHeight
|
|
102
|
-
- (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);
|
|
103
|
-
const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.optionsWrapper);
|
|
104
|
-
const node = embeddedViewRef.rootNodes[0];
|
|
105
|
-
const nodeStyles = node.style;
|
|
106
|
-
this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;
|
|
107
|
-
embeddedViewRef.detectChanges();
|
|
108
|
-
nodeStyles.width = this.element.offsetWidth + 'px';
|
|
109
|
-
nodeStyles.left = window.scrollX + elementRectLeft + 'px';
|
|
110
|
-
if (this.isOptionsListAbove) {
|
|
111
|
-
nodeStyles.top = window.scrollY + elementRectTop
|
|
112
|
-
- this.getOptionsListHeightContainer.nativeElement.offsetHeight
|
|
113
|
-
- this.SPACE_BETWEEN_BUTTON_AND_OPTIONS
|
|
114
|
-
+ 'px';
|
|
115
|
-
}
|
|
116
|
-
else {
|
|
117
|
-
nodeStyles.top = window.scrollY + elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS + 'px';
|
|
118
|
-
}
|
|
119
|
-
this.document.querySelector(CUI_ROOT_SELECTOR).appendChild(embeddedViewRef.rootNodes[0]);
|
|
120
|
-
}
|
|
121
|
-
close() {
|
|
122
|
-
this.isOpened = false;
|
|
123
|
-
this.clearViewContainerRef();
|
|
124
|
-
}
|
|
125
|
-
clearViewContainerRef() {
|
|
126
|
-
this.viewContainerRef.clear();
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
CuiSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
130
|
-
CuiSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiSelectComponent, selector: "cui-select[options]", inputs: { options: "options", defaultOptionText: "defaultOptionText" }, host: { listeners: { "window:resize": "onWindowResize()" }, properties: { "style.--c-gap": "this.gap" } }, providers: [
|
|
131
|
-
CUI_TEXT_FILED_CONTROLLER_PROVIDER,
|
|
132
|
-
cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
|
|
133
|
-
CuiDestroyService
|
|
134
|
-
], viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }, { propertyName: "getOptionsListHeightContainer", first: true, predicate: ["getOptionsListHeightContainer"], descendants: true }, { propertyName: "optionsWrapper", first: true, predicate: ["optionsWrapper"], descendants: true }], hostDirectives: [{ directive: i1.CuiClickOutsideDirective }], ngImport: i0, template: "<button\
|
|
135
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectComponent, decorators: [{
|
|
136
|
-
type: Component,
|
|
137
|
-
args: [{ selector: 'cui-select[options]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
138
|
-
CUI_TEXT_FILED_CONTROLLER_PROVIDER,
|
|
139
|
-
cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
|
|
140
|
-
CuiDestroyService
|
|
141
|
-
], hostDirectives: [CuiClickOutsideDirective], template: "<button\
|
|
142
|
-
}], propDecorators: { options: [{
|
|
143
|
-
type: Input
|
|
144
|
-
}], defaultOptionText: [{
|
|
145
|
-
type: Input
|
|
146
|
-
}], button: [{
|
|
147
|
-
type: ViewChild,
|
|
148
|
-
args: ['button']
|
|
149
|
-
}], getOptionsListHeightContainer: [{
|
|
150
|
-
type: ViewChild,
|
|
151
|
-
args: ['getOptionsListHeightContainer']
|
|
152
|
-
}], optionsWrapper: [{
|
|
153
|
-
type: ViewChild,
|
|
154
|
-
args: ['optionsWrapper']
|
|
155
|
-
}], gap: [{
|
|
156
|
-
type: HostBinding,
|
|
157
|
-
args: ['style.--c-gap']
|
|
158
|
-
}], onWindowResize: [{
|
|
159
|
-
type: HostListener,
|
|
160
|
-
args: ['window:resize']
|
|
161
|
-
}] } });
|
|
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';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  inject,\r\n  Input,\r\n  ElementRef,\r\n  ViewChild,\r\n  HostBinding,\r\n  ViewContainerRef,\r\n  HostListener\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport type { CuiOnChange, CuiOnTouched, CuiNullable } from '@cuby-ui/cdk';\r\nimport { CuiDestroyService } from '@cuby-ui/cdk';\r\nimport { cuiProvide, CuiClickOutsideDirective } from '@cuby-ui/cdk';\r\nimport { takeUntil } from 'rxjs';\r\n\r\nimport type { CuiOption } from '../../interfaces';\r\nimport type { CuiSizeMd, CuiSizeSm } from '../../types';\r\nimport { CUI_TEXT_FIELD_CONTROLLER, CUI_TEXT_FILED_CONTROLLER_PROVIDER } from '../../directives';\r\nimport { CUI_ROOT_SELECTOR } from '../root';\r\n\r\n@Component({\r\n  selector: 'cui-select[options]',\r\n  templateUrl: './select.template.html',\r\n  styleUrls: ['./select.style.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    CUI_TEXT_FILED_CONTROLLER_PROVIDER,\r\n    cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),\r\n    CuiDestroyService\r\n  ],\r\n  hostDirectives: [CuiClickOutsideDirective]\r\n})\r\nexport class CuiSelectComponent implements ControlValueAccessor, OnInit, OnDestroy {\r\n  private readonly element = inject(ElementRef).nativeElement;\r\n  private readonly document = inject(DOCUMENT);\r\n  private readonly changeDetectorRef = inject(ChangeDetectorRef);\r\n  private readonly viewContainerRef = inject(ViewContainerRef);\r\n  private readonly destroy$ = inject(CuiDestroyService, {self: true});\r\n  private readonly cuiTextFieldController = inject(CUI_TEXT_FIELD_CONTROLLER);\r\n  private readonly cuiClickOutsideDirective = inject(CuiClickOutsideDirective, {self: true});\r\n\r\n  protected readonly SPACE_BETWEEN_BUTTON_AND_OPTIONS = 3;\r\n\r\n  protected isOpened = false;\r\n  protected isOptionsListAbove = false;\r\n  protected value!: CuiNullable<unknown>;\r\n  protected onChange!: CuiOnChange<unknown>;\r\n  protected onTouched!: CuiOnTouched;\r\n  protected isDisabled!: boolean;\r\n  protected selectedOption?: CuiOption;\r\n\r\n  @Input()\r\n  public options!: CuiOption[];\r\n\r\n  @Input()\r\n  public defaultOptionText?: string;\r\n\r\n  @ViewChild('button')\r\n  protected readonly button!: ElementRef<HTMLButtonElement>;\r\n\r\n  @ViewChild('getOptionsListHeightContainer')\r\n  protected readonly getOptionsListHeightContainer!: ElementRef<HTMLUListElement>;\r\n\r\n  @ViewChild('optionsWrapper')\r\n  protected readonly optionsWrapper!: TemplateRef<unknown>;\r\n\r\n  @HostBinding('style.--c-gap')\r\n  protected gap = `${this.SPACE_BETWEEN_BUTTON_AND_OPTIONS}px`;\r\n\r\n  protected get id(): string | undefined {\r\n    return this.cuiTextFieldController.id;\r\n  }\r\n\r\n  protected get size(): CuiSizeSm | CuiSizeMd {\r\n    return this.cuiTextFieldController.size;\r\n  }\r\n\r\n  protected get placeholder(): string | undefined {\r\n    return this.cuiTextFieldController.placeholder;\r\n  }\r\n\r\n  protected get isError(): boolean {\r\n    return this.cuiTextFieldController.isError;\r\n  }\r\n\r\n  protected trackByFn(_: number, item: CuiOption): string {\r\n    return item.label;\r\n  }\r\n\r\n  public writeValue(value: unknown): void {\r\n    this.value = value;\r\n    // TODO: Непонятно, зачем нужно в construction вторая часть выражения\r\n    this.selectedOption = this.options.find(option => option.value === value) ?? value as CuiOption;\r\n\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  public registerOnChange(fn: CuiOnChange<unknown>): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: CuiOnTouched): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.initClickOutsideSubscription();\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.clearViewContainerRef();\r\n  }\r\n\r\n  public setDisabledState(isDisabled: boolean): void {\r\n    this.isDisabled = isDisabled;\r\n\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  protected onSelect(option: CuiOption): void {\r\n    this.value = option.value;\r\n    this.selectedOption = option;\r\n\r\n    this.onChange(this.value);\r\n    this.onSwitch();\r\n    this.onTouched();\r\n  }\r\n\r\n  protected onSwitch(): void {\r\n    if (!this.options.length && !this.defaultOptionText) {\r\n      return;\r\n    }\r\n\r\n    if (!this.isOpened) {\r\n      this.open();\r\n\r\n      return;\r\n    }\r\n\r\n    this.close();\r\n  }\r\n\r\n  protected onClose(): void {\r\n    this.close();\r\n  }\r\n\r\n  @HostListener('window:resize')\r\n  protected onWindowResize(): void {\r\n    this.button.nativeElement.blur();\r\n    this.close();\r\n  }\r\n\r\n  private initClickOutsideSubscription(): void {\r\n    this.cuiClickOutsideDirective.cuiClickOutside\r\n    .pipe(takeUntil(this.destroy$))\r\n    .subscribe(() => {\r\n      if (this.isOpened) {\r\n        this.onTouched();\r\n      }\r\n\r\n      this.close();\r\n    });\r\n  }\r\n\r\n  private open(): void {\r\n    this.isOpened = true;\r\n\r\n    const {\r\n      top: elementRectTop,\r\n      left: elementRectLeft,\r\n      bottom: elementRectBottom\r\n    } = this.element.getBoundingClientRect();\r\n    const distanceToBottom = this.document.documentElement.clientHeight\r\n      - (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);\r\n    const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.optionsWrapper);\r\n    const node = embeddedViewRef.rootNodes[0];\r\n    const nodeStyles = node.style;\r\n\r\n    this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;\r\n\r\n    embeddedViewRef.detectChanges();\r\n\r\n    nodeStyles.width = this.element.offsetWidth + 'px';\r\n    nodeStyles.left = window.scrollX + elementRectLeft + 'px';\r\n\r\n    if (this.isOptionsListAbove) {\r\n      nodeStyles.top = window.scrollY + elementRectTop\r\n        - this.getOptionsListHeightContainer.nativeElement.offsetHeight\r\n        - this.SPACE_BETWEEN_BUTTON_AND_OPTIONS\r\n        + 'px';\r\n    } else {\r\n      nodeStyles.top = window.scrollY + elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS + 'px';\r\n    }\r\n\r\n    this.document.querySelector(CUI_ROOT_SELECTOR)!.appendChild(embeddedViewRef.rootNodes[0]);\r\n  }\r\n\r\n  private close(): void {\r\n    this.isOpened = false;\r\n\r\n    this.clearViewContainerRef();\r\n  }\r\n\r\n  private clearViewContainerRef(): void {\r\n    this.viewContainerRef.clear();\r\n  }\r\n}\r\n","<button\r\n  #button\r\n  type=\"button\"\r\n  [attr.id]=\"id\"\r\n  [attr.data-size]=\"size\"\r\n  [disabled]=\"isDisabled\"\r\n  class=\"c-button\"\r\n  [class.c-button_active]=\"isOpened\"\r\n  [class.c-button_with-error]=\"isError\"\r\n  (click)=\"onSwitch()\"\r\n>\r\n  <ng-container *ngIf=\"selectedOption; else placeholderTemplate\">\r\n    {{ selectedOption.label }}\r\n  </ng-container>\r\n  <ng-template #placeholderTemplate>\r\n    <span class=\"c-placeholder\">{{ placeholder }}</span>\r\n  </ng-template>\r\n  <cui-svg\r\n    icon=\"cuiIconChevronDown\"\r\n    color=\"var(--cui-base-500)\"\r\n  />\r\n</button>\r\n<ng-template #optionsWrapper>\r\n  <div\r\n      class=\"c-options__wrapper\"\r\n      [class.c-options__wrapper_top]=\"isOptionsListAbove\"\r\n  >\r\n    <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n  </div>\r\n</ng-template>\r\n<div\r\n  #getOptionsListHeightContainer\r\n  class=\"c-get-options-list-height-container\"\r\n>\r\n  <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n</div>\r\n<ng-template #optionsList>\r\n  <ul\r\n    class=\"c-options\"\r\n    [class.c-options_top]=\"isOptionsListAbove\"\r\n  >\r\n    <ng-container *ngIf=\"options.length; else empty\">\r\n      <li *ngFor=\"let option of options; trackBy: trackByFn\">\r\n        <button\r\n          type=\"button\"\r\n          class=\"c-option-button\"\r\n          [class.c-option-button_selected]=\"selectedOption === option\"\r\n          (click)=\"onSelect(option)\"\r\n        >\r\n          <span>{{ option.label }}</span>\r\n          <cui-svg\r\n            *ngIf=\"selectedOption === option\"\r\n            icon=\"cuiIconCheckSm\"\r\n            color=\"var(--cui-info)\"\r\n            class=\"c-option-button__icon\"\r\n          />\r\n        </button>\r\n      </li>\r\n    </ng-container>\r\n    <ng-template #empty>\r\n      <li *ngIf=\"defaultOptionText\">\r\n        <button\r\n          type=\"button\"\r\n          class=\"c-option-button\"\r\n          (click)=\"onClose()\"\r\n        >\r\n          {{ defaultOptionText }}\r\n        </button>\r\n      </li>\r\n    </ng-template>\r\n  </ul>\r\n</ng-template>\r\n"]}
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, Input, ElementRef, ViewChild, HostBinding, ViewContainerRef, HostListener } 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 { CUI_ROOT_SELECTOR } from '../root';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@cuby-ui/cdk";
|
|
11
|
+
import * as i2 from "@angular/common";
|
|
12
|
+
import * as i3 from "../svg/svg.component";
|
|
13
|
+
export class CuiSelectComponent {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.element = inject(ElementRef).nativeElement;
|
|
16
|
+
this.document = inject(DOCUMENT);
|
|
17
|
+
this.changeDetectorRef = inject(ChangeDetectorRef);
|
|
18
|
+
this.viewContainerRef = inject(ViewContainerRef);
|
|
19
|
+
this.destroy$ = inject(CuiDestroyService, { self: true });
|
|
20
|
+
this.cuiTextFieldController = inject(CUI_TEXT_FIELD_CONTROLLER);
|
|
21
|
+
this.cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });
|
|
22
|
+
this.SPACE_BETWEEN_BUTTON_AND_OPTIONS = 3;
|
|
23
|
+
this.isOpened = false;
|
|
24
|
+
this.isOptionsListAbove = false;
|
|
25
|
+
this.gap = `${this.SPACE_BETWEEN_BUTTON_AND_OPTIONS}px`;
|
|
26
|
+
}
|
|
27
|
+
get id() {
|
|
28
|
+
return this.cuiTextFieldController.id;
|
|
29
|
+
}
|
|
30
|
+
get size() {
|
|
31
|
+
return this.cuiTextFieldController.size;
|
|
32
|
+
}
|
|
33
|
+
get placeholder() {
|
|
34
|
+
return this.cuiTextFieldController.placeholder;
|
|
35
|
+
}
|
|
36
|
+
get isError() {
|
|
37
|
+
return this.cuiTextFieldController.isError;
|
|
38
|
+
}
|
|
39
|
+
trackByFn(_, item) {
|
|
40
|
+
return item.label;
|
|
41
|
+
}
|
|
42
|
+
writeValue(value) {
|
|
43
|
+
this.value = value;
|
|
44
|
+
// TODO: Непонятно, зачем нужно в construction вторая часть выражения
|
|
45
|
+
this.selectedOption = this.options.find(option => option.value === value) ?? value;
|
|
46
|
+
this.changeDetectorRef.markForCheck();
|
|
47
|
+
}
|
|
48
|
+
registerOnChange(fn) {
|
|
49
|
+
this.onChange = fn;
|
|
50
|
+
}
|
|
51
|
+
registerOnTouched(fn) {
|
|
52
|
+
this.onTouched = fn;
|
|
53
|
+
}
|
|
54
|
+
ngOnInit() {
|
|
55
|
+
this.initClickOutsideSubscription();
|
|
56
|
+
}
|
|
57
|
+
ngOnDestroy() {
|
|
58
|
+
this.clearViewContainerRef();
|
|
59
|
+
}
|
|
60
|
+
setDisabledState(isDisabled) {
|
|
61
|
+
this.isDisabled = isDisabled;
|
|
62
|
+
this.changeDetectorRef.markForCheck();
|
|
63
|
+
}
|
|
64
|
+
onSelect(option) {
|
|
65
|
+
this.value = option.value;
|
|
66
|
+
this.selectedOption = option;
|
|
67
|
+
this.onChange(this.value);
|
|
68
|
+
this.onSwitch();
|
|
69
|
+
this.onTouched();
|
|
70
|
+
}
|
|
71
|
+
onSwitch() {
|
|
72
|
+
if (!this.options.length && !this.defaultOptionText) {
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
if (!this.isOpened) {
|
|
76
|
+
this.open();
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
this.close();
|
|
80
|
+
}
|
|
81
|
+
onClose() {
|
|
82
|
+
this.close();
|
|
83
|
+
}
|
|
84
|
+
onWindowResize() {
|
|
85
|
+
this.button.nativeElement.blur();
|
|
86
|
+
this.close();
|
|
87
|
+
}
|
|
88
|
+
initClickOutsideSubscription() {
|
|
89
|
+
this.cuiClickOutsideDirective.cuiClickOutside
|
|
90
|
+
.pipe(takeUntil(this.destroy$))
|
|
91
|
+
.subscribe(() => {
|
|
92
|
+
if (this.isOpened) {
|
|
93
|
+
this.onTouched();
|
|
94
|
+
}
|
|
95
|
+
this.close();
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
open() {
|
|
99
|
+
this.isOpened = true;
|
|
100
|
+
const { top: elementRectTop, left: elementRectLeft, bottom: elementRectBottom } = this.element.getBoundingClientRect();
|
|
101
|
+
const distanceToBottom = this.document.documentElement.clientHeight
|
|
102
|
+
- (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);
|
|
103
|
+
const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.optionsWrapper);
|
|
104
|
+
const node = embeddedViewRef.rootNodes[0];
|
|
105
|
+
const nodeStyles = node.style;
|
|
106
|
+
this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;
|
|
107
|
+
embeddedViewRef.detectChanges();
|
|
108
|
+
nodeStyles.width = this.element.offsetWidth + 'px';
|
|
109
|
+
nodeStyles.left = window.scrollX + elementRectLeft + 'px';
|
|
110
|
+
if (this.isOptionsListAbove) {
|
|
111
|
+
nodeStyles.top = window.scrollY + elementRectTop
|
|
112
|
+
- this.getOptionsListHeightContainer.nativeElement.offsetHeight
|
|
113
|
+
- this.SPACE_BETWEEN_BUTTON_AND_OPTIONS
|
|
114
|
+
+ 'px';
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
nodeStyles.top = window.scrollY + elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS + 'px';
|
|
118
|
+
}
|
|
119
|
+
this.document.querySelector(CUI_ROOT_SELECTOR).appendChild(embeddedViewRef.rootNodes[0]);
|
|
120
|
+
}
|
|
121
|
+
close() {
|
|
122
|
+
this.isOpened = false;
|
|
123
|
+
this.clearViewContainerRef();
|
|
124
|
+
}
|
|
125
|
+
clearViewContainerRef() {
|
|
126
|
+
this.viewContainerRef.clear();
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
CuiSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
130
|
+
CuiSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiSelectComponent, selector: "cui-select[options]", inputs: { options: "options", defaultOptionText: "defaultOptionText" }, host: { listeners: { "window:resize": "onWindowResize()" }, properties: { "style.--c-gap": "this.gap" } }, providers: [
|
|
131
|
+
CUI_TEXT_FILED_CONTROLLER_PROVIDER,
|
|
132
|
+
cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
|
|
133
|
+
CuiDestroyService
|
|
134
|
+
], viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }, { propertyName: "getOptionsListHeightContainer", first: true, predicate: ["getOptionsListHeightContainer"], descendants: true }, { propertyName: "optionsWrapper", first: true, predicate: ["optionsWrapper"], descendants: true }], hostDirectives: [{ directive: i1.CuiClickOutsideDirective }], ngImport: i0, template: "<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", styles: [":host{display:block;font-family:var(--cui-main-font);position:relative}.c-button{border:0;flex-shrink: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-input);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button:hover{border-color:var(--cui-base-300)}.c-button_active.c-button_active,.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;font-family:var(--cui-main-font);z-index:1}.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;overflow:auto;max-height:180px;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;flex-shrink: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 });
|
|
135
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiSelectComponent, decorators: [{
|
|
136
|
+
type: Component,
|
|
137
|
+
args: [{ selector: 'cui-select[options]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
138
|
+
CUI_TEXT_FILED_CONTROLLER_PROVIDER,
|
|
139
|
+
cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
|
|
140
|
+
CuiDestroyService
|
|
141
|
+
], hostDirectives: [CuiClickOutsideDirective], template: "<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", styles: [":host{display:block;font-family:var(--cui-main-font);position:relative}.c-button{border:0;flex-shrink: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-input);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button:hover{border-color:var(--cui-base-300)}.c-button_active.c-button_active,.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;font-family:var(--cui-main-font);z-index:1}.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;overflow:auto;max-height:180px;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;flex-shrink: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"] }]
|
|
142
|
+
}], propDecorators: { options: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], defaultOptionText: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], button: [{
|
|
147
|
+
type: ViewChild,
|
|
148
|
+
args: ['button']
|
|
149
|
+
}], getOptionsListHeightContainer: [{
|
|
150
|
+
type: ViewChild,
|
|
151
|
+
args: ['getOptionsListHeightContainer']
|
|
152
|
+
}], optionsWrapper: [{
|
|
153
|
+
type: ViewChild,
|
|
154
|
+
args: ['optionsWrapper']
|
|
155
|
+
}], gap: [{
|
|
156
|
+
type: HostBinding,
|
|
157
|
+
args: ['style.--c-gap']
|
|
158
|
+
}], onWindowResize: [{
|
|
159
|
+
type: HostListener,
|
|
160
|
+
args: ['window:resize']
|
|
161
|
+
}] } });
|
|
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"]}
|
|
@@ -1,29 +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,
|
|
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,3 +1,3 @@
|
|
|
1
|
-
export * from './svg.component';
|
|
2
|
-
export * from './svg.module';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export * from './svg.component';
|
|
2
|
+
export * from './svg.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvc3ZnL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3N2Zy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zdmcubW9kdWxlJztcbiJdfQ==
|