cmat 0.0.3 → 0.0.4
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/breadcrumb/breadcrumb.component.d.ts +18 -20
- package/components/card/card.component.d.ts +0 -5
- package/components/cascade/cascade-list/cascade-list.component.d.ts +12 -9
- package/components/cascade/cascade-menu/cascade-menu.component.d.ts +0 -1
- package/components/chip-input/chip-input.component.d.ts +34 -0
- package/components/chip-input/index.d.ts +5 -0
- package/components/chip-input/public-api.d.ts +1 -0
- package/components/date-range/date-range.component.d.ts +3 -2
- package/components/json-editor/index.d.ts +5 -0
- package/components/json-editor/json-editor.component.d.ts +25 -0
- package/components/json-editor/public-api.d.ts +1 -0
- package/components/navigation/vertical/components/aside/aside.component.d.ts +2 -5
- package/components/navigation/vertical/components/basic/basic.component.d.ts +2 -5
- package/components/navigation/vertical/components/collapsable/collapsable.component.d.ts +2 -5
- package/components/navigation/vertical/components/divider/divider.component.d.ts +2 -5
- package/components/navigation/vertical/components/group/group.component.d.ts +2 -5
- package/components/navigation/vertical/components/spacer/spacer.component.d.ts +2 -5
- package/components/navigation/vertical/vertical.component.d.ts +1 -4
- package/components/progress-bar/progress-bar.component.d.ts +3 -2
- package/components/rating/rating.component.d.ts +3 -2
- package/components/select-search/select-search.component.d.ts +1 -2
- package/components/select-tree/select-tree.component.d.ts +5 -12
- package/components/timeline/timeline-item/timeline-item.component.d.ts +1 -1
- package/components/transfer-picker/interface.d.ts +1 -1
- package/components/transfer-picker/transfer-picker-source/transfer-picker-source.component.d.ts +4 -4
- package/components/transfer-picker/transfer-picker.service.d.ts +2 -1
- package/directives/autofocus/autofocus.directive.d.ts +1 -3
- package/directives/debounce/debounce-keyup.directive.d.ts +1 -1
- package/directives/digit-only/digit-only.directive.d.ts +2 -0
- package/esm2022/animations/dropdown.mjs +26 -0
- package/esm2022/animations/public-api.mjs +2 -2
- package/esm2022/components/adapter/dayjs-date-adapter.mjs +3 -3
- package/esm2022/components/adapter/dayjs-datetime-adapter.mjs +3 -3
- package/esm2022/components/adapter/native-datetime-adapter.mjs +3 -3
- package/esm2022/components/breadcrumb/breadcrumb-item.directive.mjs +3 -3
- package/esm2022/components/breadcrumb/breadcrumb.component.mjs +16 -17
- package/esm2022/components/breadcrumb/breadcrumb.service.mjs +4 -4
- package/esm2022/components/card/card.component.mjs +5 -14
- package/esm2022/components/cascade/cascade-bottom-sheet/cascade-bottom-sheet.component.mjs +5 -6
- package/esm2022/components/cascade/cascade-list/cascade-list.component.mjs +65 -39
- package/esm2022/components/cascade/cascade-menu/cascade-menu.component.mjs +5 -9
- package/esm2022/components/chip-input/chip-input.component.mjs +144 -0
- package/esm2022/components/chip-input/cmat-components-chip-input.mjs +5 -0
- package/esm2022/components/chip-input/public-api.mjs +2 -0
- package/esm2022/components/date-range/date-range.component.mjs +13 -9
- package/esm2022/components/drawer/drawer.component.mjs +4 -4
- package/esm2022/components/drawer/drawer.service.mjs +3 -3
- package/esm2022/components/fullscreen/fullscreen.component.mjs +3 -3
- package/esm2022/components/highlight/highlight.component.mjs +3 -3
- package/esm2022/components/highlight/highlight.service.mjs +3 -3
- package/esm2022/components/json-editor/cmat-components-json-editor.mjs +5 -0
- package/esm2022/components/json-editor/json-editor.component.mjs +176 -0
- package/esm2022/components/json-editor/public-api.mjs +2 -0
- package/esm2022/components/masonry/masonry.component.mjs +3 -3
- package/esm2022/components/material-color-picker/material-color-picker.component.mjs +6 -6
- package/esm2022/components/material-datetimepicker/calendar-body.mjs +5 -6
- package/esm2022/components/material-datetimepicker/calendar.mjs +7 -8
- package/esm2022/components/material-datetimepicker/clock.mjs +6 -6
- package/esm2022/components/material-datetimepicker/datetimepicker-input.mjs +3 -3
- package/esm2022/components/material-datetimepicker/datetimepicker-intl.mjs +3 -3
- package/esm2022/components/material-datetimepicker/datetimepicker-toggle.mjs +8 -9
- package/esm2022/components/material-datetimepicker/datetimepicker.mjs +7 -7
- package/esm2022/components/material-datetimepicker/month-view.mjs +5 -6
- package/esm2022/components/material-datetimepicker/multi-year-view.mjs +3 -3
- package/esm2022/components/material-datetimepicker/time.mjs +8 -9
- package/esm2022/components/material-datetimepicker/year-view.mjs +3 -3
- package/esm2022/components/navigation/horizontal/components/basic/basic.component.mjs +6 -6
- package/esm2022/components/navigation/horizontal/components/branch/branch.component.mjs +7 -8
- package/esm2022/components/navigation/horizontal/components/divider/divider.component.mjs +3 -3
- package/esm2022/components/navigation/horizontal/components/spacer/spacer.component.mjs +3 -3
- package/esm2022/components/navigation/horizontal/horizontal.component.mjs +5 -6
- package/esm2022/components/navigation/navigation.service.mjs +3 -3
- package/esm2022/components/navigation/vertical/components/aside/aside.component.mjs +8 -17
- package/esm2022/components/navigation/vertical/components/basic/basic.component.mjs +7 -15
- package/esm2022/components/navigation/vertical/components/collapsable/collapsable.component.mjs +8 -19
- package/esm2022/components/navigation/vertical/components/divider/divider.component.mjs +6 -15
- package/esm2022/components/navigation/vertical/components/group/group.component.mjs +9 -19
- package/esm2022/components/navigation/vertical/components/spacer/spacer.component.mjs +6 -15
- package/esm2022/components/navigation/vertical/vertical.component.mjs +7 -18
- package/esm2022/components/pagination/pagination.component.mjs +6 -7
- package/esm2022/components/pagination/pagination.directive.mjs +3 -3
- package/esm2022/components/pagination/pagination.pipe.mjs +5 -5
- package/esm2022/components/pagination/pagination.service.mjs +3 -3
- package/esm2022/components/password-strength/mat-pass-toggle-visibility/mat-pass-toggle-visibility.component.mjs +3 -3
- package/esm2022/components/password-strength/mat-password-strength/mat-password-strength.component.mjs +6 -6
- package/esm2022/components/password-strength/mat-password-strength-info/mat-password-strength-info.component.mjs +8 -9
- package/esm2022/components/popover/popover.component.mjs +5 -5
- package/esm2022/components/progress-bar/progress-bar.component.mjs +11 -8
- package/esm2022/components/rating/rating.component.mjs +14 -6
- package/esm2022/components/select-search/select-no-entries-found.directive.mjs +3 -3
- package/esm2022/components/select-search/select-search-clear.directive.mjs +3 -3
- package/esm2022/components/select-search/select-search.component.mjs +8 -11
- package/esm2022/components/select-tree/select-tree.component.mjs +13 -29
- package/esm2022/components/timeline/timeline-item/timeline-item.component.mjs +18 -16
- package/esm2022/components/timeline/timeline.component.mjs +3 -3
- package/esm2022/components/toast/toast-modal.component.mjs +7 -7
- package/esm2022/components/toast/toast.component.mjs +6 -6
- package/esm2022/components/toast/toast.service.mjs +3 -3
- package/esm2022/components/transfer-picker/filter/filter.component.mjs +17 -8
- package/esm2022/components/transfer-picker/interface.mjs +1 -1
- package/esm2022/components/transfer-picker/search/search.component.mjs +9 -5
- package/esm2022/components/transfer-picker/transfer-picker-source/transfer-picker-source.component.mjs +44 -21
- package/esm2022/components/transfer-picker/transfer-picker-target/transfer-picker-target.component.mjs +7 -6
- package/esm2022/components/transfer-picker/transfer-picker.component.mjs +9 -7
- package/esm2022/components/transfer-picker/transfer-picker.service.mjs +10 -7
- package/esm2022/directives/animate-on-scroll/animate-on-scroll.directive.mjs +3 -3
- package/esm2022/directives/animate-on-scroll/scroll.service.mjs +3 -3
- package/esm2022/directives/autofocus/autofocus.directive.mjs +7 -7
- package/esm2022/directives/debounce/abstract-debounce.directive.mjs +3 -3
- package/esm2022/directives/debounce/debounce-click.directive.mjs +3 -3
- package/esm2022/directives/debounce/debounce-keyup.directive.mjs +5 -5
- package/esm2022/directives/digit-only/digit-only.directive.mjs +20 -4
- package/esm2022/directives/digit-only/mask.directive.mjs +3 -3
- package/esm2022/directives/digit-only/public-api.mjs +1 -1
- package/esm2022/directives/equal-validator/equal-validator.directive.mjs +3 -3
- package/esm2022/lib/mock-api/mock-api.interceptor.mjs +3 -3
- package/esm2022/lib/mock-api/mock-api.service.mjs +3 -3
- package/esm2022/pipes/bytes/bytes.pipe.mjs +3 -3
- package/esm2022/pipes/date-format/date-format.pipe.mjs +3 -3
- package/esm2022/pipes/find-by-key/find-by-key.pipe.mjs +3 -3
- package/esm2022/pipes/group-by/group-by.pipe.mjs +3 -3
- package/esm2022/pipes/keys/keys.pipe.mjs +3 -3
- package/esm2022/pipes/secure/secure-pipe.mjs +5 -5
- package/esm2022/pipes/uppercase/uppercase.pipe.mjs +3 -3
- package/esm2022/services/alert/alert.service.mjs +16 -16
- package/esm2022/services/config/config.constants.mjs +1 -1
- package/esm2022/services/config/config.service.mjs +3 -3
- package/esm2022/services/config/urlStateConfig.service.mjs +4 -4
- package/esm2022/services/confirmation/confirmation.service.mjs +3 -3
- package/esm2022/services/confirmation/dialog/dialog.component.mjs +6 -6
- package/esm2022/services/data/data.service.mjs +4 -4
- package/esm2022/services/loading/loading.interceptor.mjs +3 -3
- package/esm2022/services/loading/loading.service.mjs +3 -3
- package/esm2022/services/local-storage/local-storage.service.mjs +3 -3
- package/esm2022/services/media-watcher/media-watcher.service.mjs +3 -3
- package/esm2022/services/platform/platform.service.mjs +3 -3
- package/esm2022/services/splash-screen/splash-screen.service.mjs +3 -3
- package/esm2022/services/title/title.service.mjs +3 -3
- package/esm2022/services/translation/translation.service.mjs +3 -3
- package/esm2022/services/utils/utils.service.mjs +3 -3
- package/fesm2022/cmat-animations.mjs.map +1 -1
- package/fesm2022/cmat-components-adapter.mjs +9 -9
- package/fesm2022/cmat-components-breadcrumb.mjs +21 -22
- package/fesm2022/cmat-components-breadcrumb.mjs.map +1 -1
- package/fesm2022/cmat-components-card.mjs +4 -13
- package/fesm2022/cmat-components-card.mjs.map +1 -1
- package/fesm2022/cmat-components-cascade.mjs +72 -49
- package/fesm2022/cmat-components-cascade.mjs.map +1 -1
- package/fesm2022/cmat-components-chip-input.mjs +151 -0
- package/fesm2022/cmat-components-chip-input.mjs.map +1 -0
- package/fesm2022/cmat-components-date-range.mjs +12 -8
- package/fesm2022/cmat-components-date-range.mjs.map +1 -1
- package/fesm2022/cmat-components-drawer.mjs +7 -7
- package/fesm2022/cmat-components-drawer.mjs.map +1 -1
- package/fesm2022/cmat-components-fullscreen.mjs +3 -3
- package/fesm2022/cmat-components-highlight.mjs +6 -6
- package/fesm2022/cmat-components-json-editor.mjs +183 -0
- package/fesm2022/cmat-components-json-editor.mjs.map +1 -0
- package/fesm2022/cmat-components-masonry.mjs +3 -3
- package/fesm2022/cmat-components-material-color-picker.mjs +5 -5
- package/fesm2022/cmat-components-material-color-picker.mjs.map +1 -1
- package/fesm2022/cmat-components-material-datetimepicker.mjs +51 -52
- package/fesm2022/cmat-components-material-datetimepicker.mjs.map +1 -1
- package/fesm2022/cmat-components-navigation.mjs +58 -125
- package/fesm2022/cmat-components-navigation.mjs.map +1 -1
- package/fesm2022/cmat-components-pagination.mjs +15 -16
- package/fesm2022/cmat-components-pagination.mjs.map +1 -1
- package/fesm2022/cmat-components-password-strength.mjs +14 -15
- package/fesm2022/cmat-components-password-strength.mjs.map +1 -1
- package/fesm2022/cmat-components-popover.mjs +4 -4
- package/fesm2022/cmat-components-popover.mjs.map +1 -1
- package/fesm2022/cmat-components-progress-bar.mjs +10 -7
- package/fesm2022/cmat-components-progress-bar.mjs.map +1 -1
- package/fesm2022/cmat-components-rating.mjs +13 -5
- package/fesm2022/cmat-components-rating.mjs.map +1 -1
- package/fesm2022/cmat-components-select-search.mjs +13 -16
- package/fesm2022/cmat-components-select-search.mjs.map +1 -1
- package/fesm2022/cmat-components-select-tree.mjs +12 -28
- package/fesm2022/cmat-components-select-tree.mjs.map +1 -1
- package/fesm2022/cmat-components-timeline.mjs +21 -19
- package/fesm2022/cmat-components-timeline.mjs.map +1 -1
- package/fesm2022/cmat-components-toast.mjs +13 -13
- package/fesm2022/cmat-components-toast.mjs.map +1 -1
- package/fesm2022/cmat-components-transfer-picker.mjs +81 -45
- package/fesm2022/cmat-components-transfer-picker.mjs.map +1 -1
- package/fesm2022/cmat-directives-animate-on-scroll.mjs +6 -6
- package/fesm2022/cmat-directives-autofocus.mjs +6 -6
- package/fesm2022/cmat-directives-autofocus.mjs.map +1 -1
- package/fesm2022/cmat-directives-debounce.mjs +10 -10
- package/fesm2022/cmat-directives-debounce.mjs.map +1 -1
- package/fesm2022/cmat-directives-digit-only.mjs +22 -6
- package/fesm2022/cmat-directives-digit-only.mjs.map +1 -1
- package/fesm2022/cmat-directives-equal-validator.mjs +3 -3
- package/fesm2022/cmat-lib-mock-api.mjs +6 -6
- package/fesm2022/cmat-pipes-bytes.mjs +3 -3
- package/fesm2022/cmat-pipes-date-format.mjs +3 -3
- package/fesm2022/cmat-pipes-find-by-key.mjs +3 -3
- package/fesm2022/cmat-pipes-group-by.mjs +3 -3
- package/fesm2022/cmat-pipes-keys.mjs +3 -3
- package/fesm2022/cmat-pipes-secure.mjs +4 -4
- package/fesm2022/cmat-pipes-secure.mjs.map +1 -1
- package/fesm2022/cmat-pipes-uppercase.mjs +3 -3
- package/fesm2022/cmat-services-alert.mjs +15 -15
- package/fesm2022/cmat-services-alert.mjs.map +1 -1
- package/fesm2022/cmat-services-config.mjs +6 -6
- package/fesm2022/cmat-services-config.mjs.map +1 -1
- package/fesm2022/cmat-services-confirmation.mjs +8 -8
- package/fesm2022/cmat-services-confirmation.mjs.map +1 -1
- package/fesm2022/cmat-services-data.mjs +3 -3
- package/fesm2022/cmat-services-data.mjs.map +1 -1
- package/fesm2022/cmat-services-loading.mjs +6 -6
- package/fesm2022/cmat-services-local-storage.mjs +3 -3
- package/fesm2022/cmat-services-media-watcher.mjs +3 -3
- package/fesm2022/cmat-services-platform.mjs +3 -3
- package/fesm2022/cmat-services-splash-screen.mjs +3 -3
- package/fesm2022/cmat-services-title.mjs +3 -3
- package/fesm2022/cmat-services-translation.mjs +3 -3
- package/fesm2022/cmat-services-utils.mjs +3 -3
- package/package.json +75 -65
- package/pipes/secure/secure-pipe.d.ts +1 -1
- package/services/alert/alert.service.d.ts +4 -4
- package/services/config/config.constants.d.ts +1 -1
- package/services/config/urlStateConfig.service.d.ts +3 -2
- package/styles/components/bundle.scss +559 -0
- package/styles/overrides/angular-material.scss +16 -16
- package/styles/styles.scss +6 -1
- package/styles/tailwind.scss +4 -2
- package/components/breadcrumb/breadcrumb.component.scss +0 -18
- package/components/card/card.component.scss +0 -63
- package/components/cascade/cascade-bottom-sheet/cascade-bottom-sheet.component.scss +0 -43
- package/components/cascade/cascade-list/cascade-list.component.scss +0 -22
- package/components/cascade/cascade-menu/cascade-menu.component.scss +0 -48
- package/components/date-range/date-range.component.scss +0 -232
- package/components/drawer/drawer.component.scss +0 -133
- package/components/highlight/highlight.component.scss +0 -3
- package/components/material-color-picker/material-color-picker.component.scss +0 -5
- package/components/material-datetimepicker/calendar-body.scss +0 -58
- package/components/material-datetimepicker/calendar.scss +0 -194
- package/components/material-datetimepicker/clock.scss +0 -90
- package/components/material-datetimepicker/datetimepicker-content.scss +0 -151
- package/components/material-datetimepicker/datetimepicker.scss +0 -145
- package/components/material-datetimepicker/time.scss +0 -82
- package/components/navigation/horizontal/horizontal.component.scss +0 -167
- package/components/navigation/vertical/styles/appearances/compact.scss +0 -103
- package/components/navigation/vertical/styles/appearances/default.scss +0 -550
- package/components/navigation/vertical/styles/appearances/dense.scss +0 -171
- package/components/navigation/vertical/styles/appearances/thin.scss +0 -91
- package/components/navigation/vertical/vertical.component.scss +0 -4
- package/components/password-strength/mat-password-strength-info/mat-password-strength-info.component.scss +0 -19
- package/components/popover/popover.component.scss +0 -174
- package/components/progress-bar/progress-bar.component.scss +0 -7
- package/components/rating/rating.component.scss +0 -33
- package/components/select-search/select-search.component.scss +0 -126
- package/components/select-tree/select-tree.component.scss +0 -54
- package/components/timeline/timeline-item/timeline-item.component.scss +0 -329
- package/components/timeline/timeline.component.scss +0 -42
- package/components/toast/toast-modal.component.scss +0 -119
- package/components/toast/toast.component.scss +0 -62
- package/components/transfer-picker/filter/filter.component.scss +0 -40
- package/components/transfer-picker/search/search.component.scss +0 -7
- package/components/transfer-picker/transfer-picker-source/transfer-picker-source.component.scss +0 -25
- package/components/transfer-picker/transfer-picker-target/transfer-picker-target.component.scss +0 -27
- package/components/transfer-picker/transfer-picker.component.scss +0 -8
- package/esm2022/animations/drop.mjs +0 -26
- package/styles/main.scss +0 -9
- /package/animations/{drop.d.ts → dropdown.d.ts} +0 -0
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
3
|
-
import { NgIf } from '@angular/common';
|
|
4
3
|
import { cmatAnimations } from 'cmat/animations';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
export class CmatCardComponent {
|
|
@@ -19,14 +18,6 @@ export class CmatCardComponent {
|
|
|
19
18
|
};
|
|
20
19
|
/* eslint-enable @typescript-eslint/naming-convention */
|
|
21
20
|
}
|
|
22
|
-
// -----------------------------------------------------------------------------------------------------
|
|
23
|
-
// @ Lifecycle hooks
|
|
24
|
-
// -----------------------------------------------------------------------------------------------------
|
|
25
|
-
/**
|
|
26
|
-
* On changes
|
|
27
|
-
*
|
|
28
|
-
* @param changes
|
|
29
|
-
*/
|
|
30
21
|
ngOnChanges(changes) {
|
|
31
22
|
// Expanded
|
|
32
23
|
if ('expanded' in changes) {
|
|
@@ -39,12 +30,12 @@ export class CmatCardComponent {
|
|
|
39
30
|
this.flippable = coerceBooleanProperty(changes['flippable'].currentValue);
|
|
40
31
|
}
|
|
41
32
|
}
|
|
42
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
43
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
33
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
34
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatCardComponent, isStandalone: true, selector: "cmat-card", inputs: { expanded: "expanded", face: "face", flippable: "flippable" }, host: { properties: { "class": "this.classList" } }, exportAs: ["cmatCard"], usesOnChanges: true, ngImport: i0, template: "<!-- Flippable card -->\n@if (flippable) {\n <!-- Front -->\n <div class=\"cmat-card-front\">\n <ng-content select=\"[cmatCardFront]\"></ng-content>\n </div>\n <!-- Back -->\n <div class=\"cmat-card-back overflow-y-auto lg:overflow-y-hidden lg:hover:overflow-y-auto scrollbar-custom\">\n <ng-content select=\"[cmatCardBack]\"></ng-content>\n </div>\n}\n\n<!-- Normal card -->\n@if (!flippable) {\n <!-- Content -->\n <ng-content></ng-content>\n <!-- Expansion -->\n @if (expanded) {\n <div class=\"cmat-card-expansion\" [@expandCollapse]>\n <ng-content select=\"[cmatCardExpansion]\"></ng-content>\n </div>\n }\n}", styles: ["cmat-card{position:relative;display:flex;overflow:hidden;border-radius:1rem}cmat-card.cmat-card-flippable{border-width:0!important;border-radius:1rem;overflow:visible;transform-style:preserve-3d;transition:transform 1s;perspective:600px;background:transparent}cmat-card.cmat-card-flippable.cmat-card-face-back .cmat-card-front{visibility:hidden;opacity:0;transform:rotateY(180deg)}cmat-card.cmat-card-flippable.cmat-card-face-back .cmat-card-back{visibility:visible;opacity:1;transform:rotateY(360deg)}cmat-card.cmat-card-flippable .cmat-card-front,cmat-card.cmat-card-flippable .cmat-card-back{display:flex;flex-direction:column;flex:1 1 auto;z-index:10;transition:transform .5s ease-out 0s,visibility 0s ease-in .2s,opacity 0s ease-in .2s;backface-visibility:hidden;border-radius:1rem}cmat-card.cmat-card-flippable .cmat-card-front{position:relative;opacity:1;visibility:visible;transform:rotateY(0);overflow:hidden}cmat-card.cmat-card-flippable .cmat-card-back{position:absolute;inset:0;opacity:0;visibility:hidden;transform:rotateY(180deg)}\n"], animations: cmatAnimations, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
44
35
|
}
|
|
45
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatCardComponent, decorators: [{
|
|
46
37
|
type: Component,
|
|
47
|
-
args: [{ selector: 'cmat-card', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: cmatAnimations, exportAs: 'cmatCard', standalone: true, imports: [
|
|
38
|
+
args: [{ selector: 'cmat-card', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: cmatAnimations, exportAs: 'cmatCard', standalone: true, imports: [], template: "<!-- Flippable card -->\n@if (flippable) {\n <!-- Front -->\n <div class=\"cmat-card-front\">\n <ng-content select=\"[cmatCardFront]\"></ng-content>\n </div>\n <!-- Back -->\n <div class=\"cmat-card-back overflow-y-auto lg:overflow-y-hidden lg:hover:overflow-y-auto scrollbar-custom\">\n <ng-content select=\"[cmatCardBack]\"></ng-content>\n </div>\n}\n\n<!-- Normal card -->\n@if (!flippable) {\n <!-- Content -->\n <ng-content></ng-content>\n <!-- Expansion -->\n @if (expanded) {\n <div class=\"cmat-card-expansion\" [@expandCollapse]>\n <ng-content select=\"[cmatCardExpansion]\"></ng-content>\n </div>\n }\n}", styles: ["cmat-card{position:relative;display:flex;overflow:hidden;border-radius:1rem}cmat-card.cmat-card-flippable{border-width:0!important;border-radius:1rem;overflow:visible;transform-style:preserve-3d;transition:transform 1s;perspective:600px;background:transparent}cmat-card.cmat-card-flippable.cmat-card-face-back .cmat-card-front{visibility:hidden;opacity:0;transform:rotateY(180deg)}cmat-card.cmat-card-flippable.cmat-card-face-back .cmat-card-back{visibility:visible;opacity:1;transform:rotateY(360deg)}cmat-card.cmat-card-flippable .cmat-card-front,cmat-card.cmat-card-flippable .cmat-card-back{display:flex;flex-direction:column;flex:1 1 auto;z-index:10;transition:transform .5s ease-out 0s,visibility 0s ease-in .2s,opacity 0s ease-in .2s;backface-visibility:hidden;border-radius:1rem}cmat-card.cmat-card-flippable .cmat-card-front{position:relative;opacity:1;visibility:visible;transform:rotateY(0);overflow:hidden}cmat-card.cmat-card-flippable .cmat-card-back{position:absolute;inset:0;opacity:0;visibility:hidden;transform:rotateY(180deg)}\n"] }]
|
|
48
39
|
}], propDecorators: { expanded: [{
|
|
49
40
|
type: Input
|
|
50
41
|
}], face: [{
|
|
@@ -55,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
|
55
46
|
type: HostBinding,
|
|
56
47
|
args: ['class']
|
|
57
48
|
}] } });
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbWF0L2NvbXBvbmVudHMvY2FyZC9jYXJkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NtYXQvY29tcG9uZW50cy9jYXJkL2NhcmQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUE0QixpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwSSxPQUFPLEVBQWdCLHFCQUFxQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFHNUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQWFqRCxNQUFNLE9BQU8saUJBQWlCO0lBWDlCO1FBaUJhLGFBQVEsR0FBWSxLQUFLLENBQUM7UUFDMUIsU0FBSSxHQUFpQixPQUFPLENBQUM7UUFDN0IsY0FBUyxHQUFZLEtBQUssQ0FBQztLQTBCdkM7SUF4QkcsSUFBMEIsU0FBUztRQUMvQix5REFBeUQ7UUFDekQsT0FBTztZQUNILG9CQUFvQixFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ25DLHFCQUFxQixFQUFFLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxNQUFNO1lBQzdELHNCQUFzQixFQUFFLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxPQUFPO1lBQy9ELHFCQUFxQixFQUFFLElBQUksQ0FBQyxTQUFTO1NBQ3hDLENBQUM7UUFDRix3REFBd0Q7SUFDNUQsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUM5QixXQUFXO1FBQ1gsSUFBSSxVQUFVLElBQUksT0FBTyxFQUFFO1lBQ3ZCLGdDQUFnQztZQUNoQyxJQUFJLENBQUMsUUFBUSxHQUFHLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FBQztTQUMzRTtRQUVELFlBQVk7UUFDWixJQUFJLFdBQVcsSUFBSSxPQUFPLEVBQUU7WUFDeEIsZ0NBQWdDO1lBQ2hDLElBQUksQ0FBQyxTQUFTLEdBQUcscUJBQXFCLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDO1NBQzdFO0lBQ0wsQ0FBQzs4R0FqQ1EsaUJBQWlCO2tHQUFqQixpQkFBaUIsK09DakI5Qixtb0JBc0JDLGtqQ0RWZSxjQUFjOzsyRkFLakIsaUJBQWlCO2tCQVg3QixTQUFTOytCQUNJLFdBQVcsaUJBR04saUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxjQUFjLFlBQ2hCLFVBQVUsY0FDUixJQUFJLFdBQ1AsRUFBRTs4QkFRRixRQUFRO3NCQUFoQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVvQixTQUFTO3NCQUFsQyxXQUFXO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBIb3N0QmluZGluZywgSW5wdXQsIE9uQ2hhbmdlcywgU2ltcGxlQ2hhbmdlcywgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQm9vbGVhbklucHV0LCBjb2VyY2VCb29sZWFuUHJvcGVydHkgfSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xyXG5pbXBvcnQgeyBDbWF0Q2FyZEZhY2UgfSBmcm9tICcuL2NhcmQudHlwZXMnO1xyXG5cclxuaW1wb3J0IHsgY21hdEFuaW1hdGlvbnMgfSBmcm9tICdjbWF0L2FuaW1hdGlvbnMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2NtYXQtY2FyZCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2FyZC5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9jYXJkLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgICBhbmltYXRpb25zOiBjbWF0QW5pbWF0aW9ucyxcclxuICAgIGV4cG9ydEFzOiAnY21hdENhcmQnLFxyXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAgIGltcG9ydHM6IFtdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDbWF0Q2FyZENvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XHJcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXHJcbiAgICBzdGF0aWMgbmdBY2NlcHRJbnB1dFR5cGVfZXhwYW5kZWQ6IEJvb2xlYW5JbnB1dDtcclxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cclxuICAgIHN0YXRpYyBuZ0FjY2VwdElucHV0VHlwZV9mbGlwcGFibGU6IEJvb2xlYW5JbnB1dDtcclxuXHJcbiAgICBASW5wdXQoKSBleHBhbmRlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG4gICAgQElucHV0KCkgZmFjZTogQ21hdENhcmRGYWNlID0gJ2Zyb250JztcclxuICAgIEBJbnB1dCgpIGZsaXBwYWJsZTogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAgIEBIb3N0QmluZGluZygnY2xhc3MnKSBnZXQgY2xhc3NMaXN0KCk6IGFueSB7XHJcbiAgICAgICAgLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uICovXHJcbiAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgJ2NtYXQtY2FyZC1leHBhbmRlZCc6IHRoaXMuZXhwYW5kZWQsXHJcbiAgICAgICAgICAgICdjbWF0LWNhcmQtZmFjZS1iYWNrJzogdGhpcy5mbGlwcGFibGUgJiYgdGhpcy5mYWNlID09PSAnYmFjaycsXHJcbiAgICAgICAgICAgICdjbWF0LWNhcmQtZmFjZS1mcm9udCc6IHRoaXMuZmxpcHBhYmxlICYmIHRoaXMuZmFjZSA9PT0gJ2Zyb250JyxcclxuICAgICAgICAgICAgJ2NtYXQtY2FyZC1mbGlwcGFibGUnOiB0aGlzLmZsaXBwYWJsZVxyXG4gICAgICAgIH07XHJcbiAgICAgICAgLyogZXNsaW50LWVuYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb24gKi9cclxuICAgIH1cclxuXHJcbiAgICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICAgICAgLy8gRXhwYW5kZWRcclxuICAgICAgICBpZiAoJ2V4cGFuZGVkJyBpbiBjaGFuZ2VzKSB7XHJcbiAgICAgICAgICAgIC8vIENvZXJjZSB0aGUgdmFsdWUgdG8gYSBib29sZWFuXHJcbiAgICAgICAgICAgIHRoaXMuZXhwYW5kZWQgPSBjb2VyY2VCb29sZWFuUHJvcGVydHkoY2hhbmdlc1snZXhwYW5kZWQnXS5jdXJyZW50VmFsdWUpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgLy8gRmxpcHBhYmxlXHJcbiAgICAgICAgaWYgKCdmbGlwcGFibGUnIGluIGNoYW5nZXMpIHtcclxuICAgICAgICAgICAgLy8gQ29lcmNlIHRoZSB2YWx1ZSB0byBhIGJvb2xlYW5cclxuICAgICAgICAgICAgdGhpcy5mbGlwcGFibGUgPSBjb2VyY2VCb29sZWFuUHJvcGVydHkoY2hhbmdlc1snZmxpcHBhYmxlJ10uY3VycmVudFZhbHVlKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn1cclxuIiwiPCEtLSBGbGlwcGFibGUgY2FyZCAtLT5cbkBpZiAoZmxpcHBhYmxlKSB7XG4gIDwhLS0gRnJvbnQgLS0+XG4gIDxkaXYgY2xhc3M9XCJjbWF0LWNhcmQtZnJvbnRcIj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbY21hdENhcmRGcm9udF1cIj48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuICA8IS0tIEJhY2sgLS0+XG4gIDxkaXYgY2xhc3M9XCJjbWF0LWNhcmQtYmFjayBvdmVyZmxvdy15LWF1dG8gbGc6b3ZlcmZsb3cteS1oaWRkZW4gbGc6aG92ZXI6b3ZlcmZsb3cteS1hdXRvIHNjcm9sbGJhci1jdXN0b21cIj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbY21hdENhcmRCYWNrXVwiPjwvbmctY29udGVudD5cbiAgPC9kaXY+XG59XG5cbjwhLS0gTm9ybWFsIGNhcmQgLS0+XG5AaWYgKCFmbGlwcGFibGUpIHtcbiAgPCEtLSBDb250ZW50IC0tPlxuICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gIDwhLS0gRXhwYW5zaW9uIC0tPlxuICBAaWYgKGV4cGFuZGVkKSB7XG4gICAgPGRpdiBjbGFzcz1cImNtYXQtY2FyZC1leHBhbnNpb25cIiBbQGV4cGFuZENvbGxhcHNlXT5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIltjbWF0Q2FyZEV4cGFuc2lvbl1cIj48L25nLWNvbnRlbnQ+XG4gICAgPC9kaXY+XG4gIH1cbn0iXX0=
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { NgFor } from '@angular/common';
|
|
2
1
|
import { ChangeDetectionStrategy, Component, Inject, ViewEncapsulation } from '@angular/core';
|
|
3
2
|
import { MAT_BOTTOM_SHEET_DATA } from '@angular/material/bottom-sheet';
|
|
4
3
|
import { FormControl } from '@angular/forms';
|
|
@@ -40,14 +39,14 @@ export class CmatCascadeBottomSheetComponent {
|
|
|
40
39
|
trackByFn(index, item) {
|
|
41
40
|
return index || item;
|
|
42
41
|
}
|
|
43
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
44
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
42
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatCascadeBottomSheetComponent, deps: [{ token: MAT_BOTTOM_SHEET_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
43
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatCascadeBottomSheetComponent, isStandalone: true, selector: "cmat-cascade-bottom-sheet", exportAs: ["cmatCascadeBottomSheet"], ngImport: i0, template: "<div role=\"presentation\" class=\"cmat-cascade-bottom-sheet\" (click)=\"clickHandle($event)\">\n <div class=\"sheet-header flex items-center\">\n <p class=\"sheet-title\">{{root.placeholder}}</p>\n <button type=\"button\" mat-icon-button (click)=\"root.bottomSheetRef.dismiss()\">\n <mat-icon [svgIcon]=\"'heroicons_outline:x-mark'\"></mat-icon>\n </button>\n </div>\n <mat-tab-group [selectedIndex]=\"selected.value\" (selectedIndexChange)=\"selected.setValue($event);\">\n @for (menuItem of root.steps; track trackByFn(step, menuItem); let step = $index) {\n <mat-tab\n [label]=\"labels[step] || '\u9009\u62E9'\">\n <mat-list class=\"menu-list overflow-y-auto lg:overflow-y-hidden lg:hover:overflow-y-auto scrollbar-custom\">\n @for (listItem of menuItem; track trackByFn(i, listItem); let i = $index) {\n <mat-list-item class=\"menu-item\"\n [class.active]=\"listItem.active\" [class.disabled]=\"listItem.disabled\"\n (click)=\"root.selectHandle($event, step, i); select(listItem.disabled,listItem.label);\">\n <div matLine>{{listItem.label}}</div>\n </mat-list-item>\n }\n </mat-list>\n </mat-tab>\n }\n </mat-tab-group>\n</div>", styles: [".cmat-cascade-bottom-sheet{padding:0;margin:-8px -16px}.cmat-cascade-bottom-sheet .sheet-header{display:flex;flex:1 1 0%;align-items:center;font-size:1rem;border-bottom-width:1px;padding:12px 16px}.cmat-cascade-bottom-sheet .sheet-header .sheet-title{margin:0;padding:0;letter-spacing:.05rem;text-align:center;flex-grow:1}.cmat-cascade-bottom-sheet .menu-list{vertical-align:top;box-sizing:border-box;margin:0;padding:0;width:100%;overflow:hidden;position:relative;height:204px}.cmat-cascade-bottom-sheet .menu-item{padding:0 16px;text-overflow:ellipsis;box-sizing:border-box;cursor:pointer!important;font-size:14px;line-height:3em}.cmat-cascade-bottom-sheet .menu-item.disabled{cursor:not-allowed!important;pointer-events:none}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatTabsModule }, { kind: "component", type: i2.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i2.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "ngmodule", type: MatListModule }, { kind: "component", type: i3.MatList, selector: "mat-list", exportAs: ["matList"] }, { kind: "component", type: i3.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
45
44
|
}
|
|
46
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatCascadeBottomSheetComponent, decorators: [{
|
|
47
46
|
type: Component,
|
|
48
|
-
args: [{ selector: 'cmat-cascade-bottom-sheet', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'cmatCascadeBottomSheet', standalone: true, imports: [MatButtonModule, MatTabsModule, MatListModule, MatIconModule
|
|
47
|
+
args: [{ selector: 'cmat-cascade-bottom-sheet', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'cmatCascadeBottomSheet', standalone: true, imports: [MatButtonModule, MatTabsModule, MatListModule, MatIconModule], template: "<div role=\"presentation\" class=\"cmat-cascade-bottom-sheet\" (click)=\"clickHandle($event)\">\n <div class=\"sheet-header flex items-center\">\n <p class=\"sheet-title\">{{root.placeholder}}</p>\n <button type=\"button\" mat-icon-button (click)=\"root.bottomSheetRef.dismiss()\">\n <mat-icon [svgIcon]=\"'heroicons_outline:x-mark'\"></mat-icon>\n </button>\n </div>\n <mat-tab-group [selectedIndex]=\"selected.value\" (selectedIndexChange)=\"selected.setValue($event);\">\n @for (menuItem of root.steps; track trackByFn(step, menuItem); let step = $index) {\n <mat-tab\n [label]=\"labels[step] || '\u9009\u62E9'\">\n <mat-list class=\"menu-list overflow-y-auto lg:overflow-y-hidden lg:hover:overflow-y-auto scrollbar-custom\">\n @for (listItem of menuItem; track trackByFn(i, listItem); let i = $index) {\n <mat-list-item class=\"menu-item\"\n [class.active]=\"listItem.active\" [class.disabled]=\"listItem.disabled\"\n (click)=\"root.selectHandle($event, step, i); select(listItem.disabled,listItem.label);\">\n <div matLine>{{listItem.label}}</div>\n </mat-list-item>\n }\n </mat-list>\n </mat-tab>\n }\n </mat-tab-group>\n</div>", styles: [".cmat-cascade-bottom-sheet{padding:0;margin:-8px -16px}.cmat-cascade-bottom-sheet .sheet-header{display:flex;flex:1 1 0%;align-items:center;font-size:1rem;border-bottom-width:1px;padding:12px 16px}.cmat-cascade-bottom-sheet .sheet-header .sheet-title{margin:0;padding:0;letter-spacing:.05rem;text-align:center;flex-grow:1}.cmat-cascade-bottom-sheet .menu-list{vertical-align:top;box-sizing:border-box;margin:0;padding:0;width:100%;overflow:hidden;position:relative;height:204px}.cmat-cascade-bottom-sheet .menu-item{padding:0 16px;text-overflow:ellipsis;box-sizing:border-box;cursor:pointer!important;font-size:14px;line-height:3em}.cmat-cascade-bottom-sheet .menu-item.disabled{cursor:not-allowed!important;pointer-events:none}\n"] }]
|
|
49
48
|
}], ctorParameters: () => [{ type: i5.CmatCascadeListComponent, decorators: [{
|
|
50
49
|
type: Inject,
|
|
51
50
|
args: [MAT_BOTTOM_SHEET_DATA]
|
|
52
51
|
}] }] });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FzY2FkZS1ib3R0b20tc2hlZXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY21hdC9jb21wb25lbnRzL2Nhc2NhZGUvY2FzY2FkZS1ib3R0b20tc2hlZXQvY2FzY2FkZS1ib3R0b20tc2hlZXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY21hdC9jb21wb25lbnRzL2Nhc2NhZGUvY2FzY2FkZS1ib3R0b20tc2hlZXQvY2FzY2FkZS1ib3R0b20tc2hlZXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdkUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRzdDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7Ozs7OztBQVloRCxNQUFNLE9BQU8sK0JBQStCO0lBSXhDLFlBQzBDLElBQThCO1FBQTlCLFNBQUksR0FBSixJQUFJLENBQTBCO1FBSnhFLGFBQVEsR0FBRyxJQUFJLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM5QixXQUFNLEdBQWEsRUFBRSxDQUFDO1FBS2xCLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQXlDLEVBQUUsRUFBRTtZQUNsRSxNQUFNLEtBQUssR0FBdUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQWlDLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNuSCxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO2FBQUU7UUFDdkYsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQVk7UUFDcEIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFRCxNQUFNLENBQUMsUUFBaUIsRUFBRSxLQUFhO1FBQ25DLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDWCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQzlCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsR0FBRyxLQUFLLENBQUM7Z0JBQ3pDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDO2FBQy9EO1lBQ0QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO1NBQ3REO0lBQ0wsQ0FBQztJQUVELFNBQVMsQ0FBQyxLQUFhLEVBQUUsSUFBUztRQUM5QixPQUFPLEtBQUssSUFBSSxJQUFJLENBQUM7SUFDekIsQ0FBQzs4R0E3QlEsK0JBQStCLGtCQUs1QixxQkFBcUI7a0dBTHhCLCtCQUErQiwySEN0QjVDLHF2Q0F1Qk0sbXhCREhRLGVBQWUsMklBQUUsYUFBYSwybUJBQUUsYUFBYSx1UkFBRSxhQUFhOzsyRkFFN0QsK0JBQStCO2tCQVYzQyxTQUFTOytCQUNJLDJCQUEyQixpQkFHdEIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxZQUNyQyx3QkFBd0IsY0FDdEIsSUFBSSxXQUNQLENBQUMsZUFBZSxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsYUFBYSxDQUFDOzswQkFPbEUsTUFBTTsyQkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJcclxuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5qZWN0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNQVRfQk9UVE9NX1NIRUVUX0RBVEEgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9ib3R0b20tc2hlZXQnO1xyXG5pbXBvcnQgeyBGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgQ21hdENhc2NhZGVPcHRpb25zSW50ZXJmYWNlIH0gZnJvbSAnLi4vb3B0aW9ucy5pbnRlcmZhY2UnO1xyXG5pbXBvcnQgeyBDbWF0Q2FzY2FkZUxpc3RDb21wb25lbnQgfSBmcm9tICcuLi9jYXNjYWRlLWxpc3QvY2FzY2FkZS1saXN0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdFRhYnNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90YWJzJztcclxuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcclxuaW1wb3J0IHsgTWF0TGlzdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xpc3QnO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcbmltcG9ydCB7IGlzTnVsbCwgaXNVbmRlZmluZWQgfSBmcm9tICdsb2Rhc2gtZXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2NtYXQtY2FzY2FkZS1ib3R0b20tc2hlZXQnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2Nhc2NhZGUtYm90dG9tLXNoZWV0LmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2Nhc2NhZGUtYm90dG9tLXNoZWV0LmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgICBleHBvcnRBczogJ2NtYXRDYXNjYWRlQm90dG9tU2hlZXQnLFxyXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAgIGltcG9ydHM6IFtNYXRCdXR0b25Nb2R1bGUsIE1hdFRhYnNNb2R1bGUsIE1hdExpc3RNb2R1bGUsIE1hdEljb25Nb2R1bGVdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDbWF0Q2FzY2FkZUJvdHRvbVNoZWV0Q29tcG9uZW50IHtcclxuICAgIHNlbGVjdGVkID0gbmV3IEZvcm1Db250cm9sKDApO1xyXG4gICAgbGFiZWxzOiBzdHJpbmdbXSA9IFtdO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIEBJbmplY3QoTUFUX0JPVFRPTV9TSEVFVF9EQVRBKSBwdWJsaWMgcm9vdDogQ21hdENhc2NhZGVMaXN0Q29tcG9uZW50LFxyXG4gICAgKSB7XHJcbiAgICAgICAgdGhpcy5yb290LnN0ZXBzLmZvckVhY2goKGl0ZW1zOiBBcnJheTxDbWF0Q2FzY2FkZU9wdGlvbnNJbnRlcmZhY2U+KSA9PiB7XHJcbiAgICAgICAgICAgIGNvbnN0IHN0ZXBzOiBBcnJheTxDbWF0Q2FzY2FkZU9wdGlvbnNJbnRlcmZhY2U+ID0gaXRlbXMuZmlsdGVyKChpdGVtOiBDbWF0Q2FzY2FkZU9wdGlvbnNJbnRlcmZhY2UpID0+IGl0ZW0uYWN0aXZlKTtcclxuICAgICAgICAgICAgaWYgKHN0ZXBzWzBdICYmICFpc1VuZGVmaW5lZChzdGVwc1swXS5sYWJlbCkpIHsgdGhpcy5sYWJlbHMucHVzaChzdGVwc1swXS5sYWJlbCk7IH1cclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBjbGlja0hhbmRsZShldmVudDogRXZlbnQpOiB2b2lkIHtcclxuICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcclxuICAgIH1cclxuXHJcbiAgICBzZWxlY3QoZGlzYWJsZWQ6IGJvb2xlYW4sIGxhYmVsOiBzdHJpbmcpOiB2b2lkIHtcclxuICAgICAgICBpZiAoIWRpc2FibGVkKSB7XHJcbiAgICAgICAgICAgIGlmICghaXNOdWxsKHRoaXMuc2VsZWN0ZWQudmFsdWUpKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmxhYmVsc1t0aGlzLnNlbGVjdGVkLnZhbHVlXSA9IGxhYmVsO1xyXG4gICAgICAgICAgICAgICAgdGhpcy5sYWJlbHMgPSB0aGlzLmxhYmVscy5zbGljZSgwLCB0aGlzLnNlbGVjdGVkLnZhbHVlICsgMSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgdGhpcy5zZWxlY3RlZC5zZXRWYWx1ZSh0aGlzLnJvb3Quc3RlcHMubGVuZ3RoIC0gMSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHRyYWNrQnlGbihpbmRleDogbnVtYmVyLCBpdGVtOiBhbnkpOiBhbnkge1xyXG4gICAgICAgIHJldHVybiBpbmRleCB8fCBpdGVtO1xyXG4gICAgfVxyXG59XHJcbiIsIjxkaXYgcm9sZT1cInByZXNlbnRhdGlvblwiIGNsYXNzPVwiY21hdC1jYXNjYWRlLWJvdHRvbS1zaGVldFwiIChjbGljayk9XCJjbGlja0hhbmRsZSgkZXZlbnQpXCI+XG4gIDxkaXYgY2xhc3M9XCJzaGVldC1oZWFkZXIgZmxleCBpdGVtcy1jZW50ZXJcIj5cbiAgICA8cCBjbGFzcz1cInNoZWV0LXRpdGxlXCI+e3tyb290LnBsYWNlaG9sZGVyfX08L3A+XG4gICAgPGJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgbWF0LWljb24tYnV0dG9uIChjbGljayk9XCJyb290LmJvdHRvbVNoZWV0UmVmLmRpc21pc3MoKVwiPlxuICAgICAgPG1hdC1pY29uIFtzdmdJY29uXT1cIidoZXJvaWNvbnNfb3V0bGluZTp4LW1hcmsnXCI+PC9tYXQtaWNvbj5cbiAgICA8L2J1dHRvbj5cbiAgPC9kaXY+XG4gIDxtYXQtdGFiLWdyb3VwIFtzZWxlY3RlZEluZGV4XT1cInNlbGVjdGVkLnZhbHVlXCIgKHNlbGVjdGVkSW5kZXhDaGFuZ2UpPVwic2VsZWN0ZWQuc2V0VmFsdWUoJGV2ZW50KTtcIj5cbiAgICBAZm9yIChtZW51SXRlbSBvZiByb290LnN0ZXBzOyB0cmFjayB0cmFja0J5Rm4oc3RlcCwgbWVudUl0ZW0pOyBsZXQgc3RlcCA9ICRpbmRleCkge1xuICAgICAgPG1hdC10YWJcbiAgICAgICAgW2xhYmVsXT1cImxhYmVsc1tzdGVwXSB8fCAn6YCJ5oupJ1wiPlxuICAgICAgICA8bWF0LWxpc3QgY2xhc3M9XCJtZW51LWxpc3Qgb3ZlcmZsb3cteS1hdXRvIGxnOm92ZXJmbG93LXktaGlkZGVuIGxnOmhvdmVyOm92ZXJmbG93LXktYXV0byBzY3JvbGxiYXItY3VzdG9tXCI+XG4gICAgICAgICAgQGZvciAobGlzdEl0ZW0gb2YgbWVudUl0ZW07IHRyYWNrIHRyYWNrQnlGbihpLCBsaXN0SXRlbSk7IGxldCBpID0gJGluZGV4KSB7XG4gICAgICAgICAgICA8bWF0LWxpc3QtaXRlbSBjbGFzcz1cIm1lbnUtaXRlbVwiXG4gICAgICAgICAgICAgIFtjbGFzcy5hY3RpdmVdPVwibGlzdEl0ZW0uYWN0aXZlXCIgW2NsYXNzLmRpc2FibGVkXT1cImxpc3RJdGVtLmRpc2FibGVkXCJcbiAgICAgICAgICAgICAgKGNsaWNrKT1cInJvb3Quc2VsZWN0SGFuZGxlKCRldmVudCwgc3RlcCwgaSk7IHNlbGVjdChsaXN0SXRlbS5kaXNhYmxlZCxsaXN0SXRlbS5sYWJlbCk7XCI+XG4gICAgICAgICAgICAgIDxkaXYgbWF0TGluZT57e2xpc3RJdGVtLmxhYmVsfX08L2Rpdj5cbiAgICAgICAgICAgIDwvbWF0LWxpc3QtaXRlbT5cbiAgICAgICAgICB9XG4gICAgICAgIDwvbWF0LWxpc3Q+XG4gICAgICA8L21hdC10YWI+XG4gICAgfVxuICA8L21hdC10YWItZ3JvdXA+XG48L2Rpdj4iXX0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { NgClass
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
1
|
+
import { NgClass } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
4
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
5
5
|
import { Breakpoints } from '@angular/cdk/layout';
|
|
@@ -10,36 +10,38 @@ import { MatFormFieldModule } from '@angular/material/form-field';
|
|
|
10
10
|
import { MatIconModule } from '@angular/material/icon';
|
|
11
11
|
import { CmatCascadeMenuComponent } from '../cascade-menu/cascade-menu.component';
|
|
12
12
|
import { isUndefined } from 'lodash-es';
|
|
13
|
+
import { MatInputModule } from '@angular/material/input';
|
|
14
|
+
import { CdkOverlayOrigin, OverlayConfig, OverlayModule } from '@angular/cdk/overlay';
|
|
15
|
+
import { PortalModule } from '@angular/cdk/portal';
|
|
13
16
|
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "@angular/cdk/
|
|
15
|
-
import * as i2 from "@angular/
|
|
16
|
-
import * as i3 from "@angular/material/
|
|
17
|
-
import * as i4 from "@angular/material/
|
|
17
|
+
import * as i1 from "@angular/cdk/overlay";
|
|
18
|
+
import * as i2 from "@angular/cdk/layout";
|
|
19
|
+
import * as i3 from "@angular/material/bottom-sheet";
|
|
20
|
+
import * as i4 from "@angular/material/form-field";
|
|
21
|
+
import * as i5 from "@angular/material/icon";
|
|
22
|
+
import * as i6 from "@angular/material/input";
|
|
23
|
+
import * as i7 from "@angular/cdk/portal";
|
|
18
24
|
let NEXT_ID = 0;
|
|
19
25
|
export class CmatCascadeListComponent {
|
|
20
|
-
constructor(
|
|
21
|
-
this.
|
|
26
|
+
constructor(_overlay, _breakpointObserver, _bottomSheet) {
|
|
27
|
+
this._overlay = _overlay;
|
|
22
28
|
this._breakpointObserver = _breakpointObserver;
|
|
23
29
|
this._bottomSheet = _bottomSheet;
|
|
24
30
|
/* 组件 id */
|
|
25
31
|
this.id = `cmat-cascade-list-${NEXT_ID++}`;
|
|
26
32
|
this.disabled = false;
|
|
27
33
|
this.placeholder = '请选择';
|
|
28
|
-
this.appearance = 'fill';
|
|
29
34
|
this.clearable = false;
|
|
30
35
|
this.fullLevels = true;
|
|
31
36
|
this.changeOnSelect = false;
|
|
32
37
|
this.modelChange = new EventEmitter();
|
|
33
38
|
this.steps = [];
|
|
34
39
|
this.menuVisible = false;
|
|
35
|
-
this.inputHover = false;
|
|
36
40
|
this.currentLabels = [];
|
|
37
41
|
this._touchUi = false;
|
|
38
42
|
this._unsubscribeAll = new Subject();
|
|
39
43
|
this.onTouched = () => { };
|
|
40
44
|
this.controlChange = () => { };
|
|
41
|
-
this.globalListenFunc = () => { };
|
|
42
|
-
this._unsubscribeAll = new Subject();
|
|
43
45
|
}
|
|
44
46
|
// Whether the cascade dropdownlist UI is in touch mode.
|
|
45
47
|
get touchUi() {
|
|
@@ -48,6 +50,34 @@ export class CmatCascadeListComponent {
|
|
|
48
50
|
set touchUi(value) {
|
|
49
51
|
this._touchUi = coerceBooleanProperty(value);
|
|
50
52
|
}
|
|
53
|
+
ngOnInit() {
|
|
54
|
+
const config = new OverlayConfig({
|
|
55
|
+
hasBackdrop: true,
|
|
56
|
+
backdropClass: 'cdk-overlay-transparent-backdrop',
|
|
57
|
+
scrollStrategy: this._overlay.scrollStrategies.reposition(),
|
|
58
|
+
positionStrategy: this._overlay
|
|
59
|
+
.position()
|
|
60
|
+
.flexibleConnectedTo(this.overlayOrigin.elementRef)
|
|
61
|
+
.withPositions([
|
|
62
|
+
{
|
|
63
|
+
originX: 'start',
|
|
64
|
+
originY: 'bottom',
|
|
65
|
+
overlayX: 'start',
|
|
66
|
+
overlayY: 'top'
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
originX: 'start',
|
|
70
|
+
originY: 'top',
|
|
71
|
+
overlayX: 'start',
|
|
72
|
+
overlayY: 'bottom'
|
|
73
|
+
}
|
|
74
|
+
])
|
|
75
|
+
});
|
|
76
|
+
this.overlayRef = this._overlay.create(config);
|
|
77
|
+
this.overlayRef.backdropClick().subscribe(() => {
|
|
78
|
+
this.overlayRef.detach();
|
|
79
|
+
});
|
|
80
|
+
}
|
|
51
81
|
ngOnChanges(changes) {
|
|
52
82
|
if (changes['options']) {
|
|
53
83
|
this.options = changes['options'].currentValue;
|
|
@@ -55,8 +85,6 @@ export class CmatCascadeListComponent {
|
|
|
55
85
|
}
|
|
56
86
|
}
|
|
57
87
|
ngOnDestroy() {
|
|
58
|
-
this.globalListenFunc();
|
|
59
|
-
// unsubscribe
|
|
60
88
|
this._unsubscribeAll.next(void 0);
|
|
61
89
|
this._unsubscribeAll.complete();
|
|
62
90
|
}
|
|
@@ -69,10 +97,6 @@ export class CmatCascadeListComponent {
|
|
|
69
97
|
registerOnTouched(fn) {
|
|
70
98
|
this.onTouched = fn;
|
|
71
99
|
}
|
|
72
|
-
close() {
|
|
73
|
-
this.menuVisible = false;
|
|
74
|
-
this.globalListenFunc();
|
|
75
|
-
}
|
|
76
100
|
clickHandle(event) {
|
|
77
101
|
event.stopPropagation();
|
|
78
102
|
if (this.disabled) {
|
|
@@ -84,19 +108,13 @@ export class CmatCascadeListComponent {
|
|
|
84
108
|
return;
|
|
85
109
|
}
|
|
86
110
|
if (this.touchUi) {
|
|
87
|
-
this.
|
|
111
|
+
if (this.overlayRef && this.overlayRef.hasAttached()) {
|
|
112
|
+
this.overlayRef.detach();
|
|
113
|
+
}
|
|
88
114
|
this.openBottomSheet();
|
|
89
115
|
}
|
|
90
116
|
else {
|
|
91
|
-
this.
|
|
92
|
-
if (this.menuVisible) {
|
|
93
|
-
this.globalListenFunc = this._renderer.listen('document', 'click', () => {
|
|
94
|
-
this.menuVisible = false;
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
else {
|
|
98
|
-
this.globalListenFunc();
|
|
99
|
-
}
|
|
117
|
+
this.overlayRef.attach(this.menuTemplate);
|
|
100
118
|
}
|
|
101
119
|
}
|
|
102
120
|
changeLabels() {
|
|
@@ -125,7 +143,7 @@ export class CmatCascadeListComponent {
|
|
|
125
143
|
}));
|
|
126
144
|
this.steps = [step1];
|
|
127
145
|
}
|
|
128
|
-
this.menuVisible = false;
|
|
146
|
+
//this.menuVisible = false;
|
|
129
147
|
this.inputValue = '';
|
|
130
148
|
if (event) {
|
|
131
149
|
this.modelChange.emit([]);
|
|
@@ -178,13 +196,15 @@ export class CmatCascadeListComponent {
|
|
|
178
196
|
}
|
|
179
197
|
// last step
|
|
180
198
|
this.changeLabels();
|
|
181
|
-
this.
|
|
199
|
+
if (this.overlayRef && this.overlayRef.hasAttached()) {
|
|
200
|
+
this.overlayRef.detach();
|
|
201
|
+
}
|
|
182
202
|
if (this.touchUi) {
|
|
183
203
|
this.bottomSheetRef.dismiss();
|
|
184
204
|
}
|
|
185
205
|
}
|
|
186
206
|
showClearIcon() {
|
|
187
|
-
return !!(this.clearable && this.
|
|
207
|
+
return !!(this.clearable && this.currentLabels.length);
|
|
188
208
|
}
|
|
189
209
|
openBottomSheet() {
|
|
190
210
|
this.bottomSheetRef = this._bottomSheet.open(CmatCascadeBottomSheetComponent, {
|
|
@@ -218,21 +238,21 @@ export class CmatCascadeListComponent {
|
|
|
218
238
|
this.inputValue = this.currentLabels[this.currentLabels.length - 1].label;
|
|
219
239
|
}
|
|
220
240
|
}
|
|
221
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
222
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
241
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatCascadeListComponent, deps: [{ token: i1.Overlay }, { token: i2.BreakpointObserver }, { token: i3.MatBottomSheet }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
242
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatCascadeListComponent, isStandalone: true, selector: "cmat-cascade-list", inputs: { id: "id", disabled: "disabled", placeholder: "placeholder", label: "label", options: "options", clearable: "clearable", fullLevels: "fullLevels", changeOnSelect: "changeOnSelect", model: "model", touchUi: "touchUi" }, outputs: { modelChange: "modelChange" }, host: { properties: { "attr.id": "this.id" } }, providers: [{
|
|
223
243
|
provide: NG_VALUE_ACCESSOR,
|
|
224
244
|
useExisting: forwardRef(() => CmatCascadeListComponent),
|
|
225
245
|
multi: true
|
|
226
|
-
}], exportAs: ["cmatCascadeList"], usesOnChanges: true, ngImport: i0, template: "<span role=\"presentation\" class=\"cmat-cascade-list\" [ngClass]=\"{'opened': menuVisible, 'disabled': disabled}\"\n
|
|
246
|
+
}], viewQueries: [{ propertyName: "overlayOrigin", first: true, predicate: CdkOverlayOrigin, descendants: true, static: true }, { propertyName: "menuTemplate", first: true, predicate: ["menuTemplate"], descendants: true, static: true }], exportAs: ["cmatCascadeList"], usesOnChanges: true, ngImport: i0, template: "<span role=\"presentation\" class=\"cmat-cascade-list\" [ngClass]=\"{'opened': menuVisible, 'disabled': disabled}\"\n cdk-overlay-origin>\n <mat-form-field>\n @if (label) {\n <mat-label>{{label}}</mat-label>\n }\n <input (click)=\"clickHandle($event)\" [value]=\"inputValue || ''\" matInput readonly\n [placeholder]=\"currentLabels.length ? '' : placeholder\">\n\n @if (showClearIcon()) {\n <button type=\"button\" matSuffix mat-icon-button aria-label=\"Clear\"\n (click)=\"clearValue(false,$event)\">\n <mat-icon [svgIcon]=\"'heroicons_outline:x-mark'\"></mat-icon>\n </button>\n }\n @if (!showClearIcon()) {\n <mat-icon matSuffix [svgIcon]=\"'mat_outline:arrow_drop_down'\"></mat-icon>\n }\n </mat-form-field>\n</span>\n\n<ng-template cdk-portal #menuTemplate=\"cdkPortal\">\n <cmat-cascade-menu></cmat-cascade-menu>\n</ng-template>", styles: [".cmat-cascade-list{position:relative;display:inline-block;width:100%;line-height:2}.cmat-cascade-list mat-form-field{width:100%}.cmat-cascade-list input{cursor:pointer}.cmat-cascade-list.disabled .cascade-label{z-index:2}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: CmatCascadeMenuComponent, selector: "cmat-cascade-menu", exportAs: ["cmatCascadeMenu"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: OverlayModule }, { kind: "directive", type: i1.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "ngmodule", type: PortalModule }, { kind: "directive", type: i7.TemplatePortalDirective, selector: "[cdk-portal], [portal]", exportAs: ["cdkPortal"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
227
247
|
}
|
|
228
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
248
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatCascadeListComponent, decorators: [{
|
|
229
249
|
type: Component,
|
|
230
250
|
args: [{ selector: 'cmat-cascade-list', providers: [{
|
|
231
251
|
provide: NG_VALUE_ACCESSOR,
|
|
232
252
|
useExisting: forwardRef(() => CmatCascadeListComponent),
|
|
233
253
|
multi: true
|
|
234
|
-
}], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'cmatCascadeList', standalone: true, imports: [MatFormFieldModule, MatIconModule, NgClass,
|
|
235
|
-
}], ctorParameters: () => [{ type:
|
|
254
|
+
}], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'cmatCascadeList', standalone: true, imports: [MatFormFieldModule, MatIconModule, NgClass, CmatCascadeMenuComponent, MatInputModule, OverlayModule, PortalModule], template: "<span role=\"presentation\" class=\"cmat-cascade-list\" [ngClass]=\"{'opened': menuVisible, 'disabled': disabled}\"\n cdk-overlay-origin>\n <mat-form-field>\n @if (label) {\n <mat-label>{{label}}</mat-label>\n }\n <input (click)=\"clickHandle($event)\" [value]=\"inputValue || ''\" matInput readonly\n [placeholder]=\"currentLabels.length ? '' : placeholder\">\n\n @if (showClearIcon()) {\n <button type=\"button\" matSuffix mat-icon-button aria-label=\"Clear\"\n (click)=\"clearValue(false,$event)\">\n <mat-icon [svgIcon]=\"'heroicons_outline:x-mark'\"></mat-icon>\n </button>\n }\n @if (!showClearIcon()) {\n <mat-icon matSuffix [svgIcon]=\"'mat_outline:arrow_drop_down'\"></mat-icon>\n }\n </mat-form-field>\n</span>\n\n<ng-template cdk-portal #menuTemplate=\"cdkPortal\">\n <cmat-cascade-menu></cmat-cascade-menu>\n</ng-template>", styles: [".cmat-cascade-list{position:relative;display:inline-block;width:100%;line-height:2}.cmat-cascade-list mat-form-field{width:100%}.cmat-cascade-list input{cursor:pointer}.cmat-cascade-list.disabled .cascade-label{z-index:2}\n"] }]
|
|
255
|
+
}], ctorParameters: () => [{ type: i1.Overlay }, { type: i2.BreakpointObserver }, { type: i3.MatBottomSheet }], propDecorators: { id: [{
|
|
236
256
|
type: HostBinding,
|
|
237
257
|
args: ['attr.id']
|
|
238
258
|
}, {
|
|
@@ -241,7 +261,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
|
241
261
|
type: Input
|
|
242
262
|
}], placeholder: [{
|
|
243
263
|
type: Input
|
|
244
|
-
}],
|
|
264
|
+
}], label: [{
|
|
245
265
|
type: Input
|
|
246
266
|
}], options: [{
|
|
247
267
|
type: Input,
|
|
@@ -257,7 +277,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
|
257
277
|
args: [{ required: true }]
|
|
258
278
|
}], modelChange: [{
|
|
259
279
|
type: Output
|
|
280
|
+
}], overlayOrigin: [{
|
|
281
|
+
type: ViewChild,
|
|
282
|
+
args: [CdkOverlayOrigin, { static: true }]
|
|
283
|
+
}], menuTemplate: [{
|
|
284
|
+
type: ViewChild,
|
|
285
|
+
args: ['menuTemplate', { static: true }]
|
|
260
286
|
}], touchUi: [{
|
|
261
287
|
type: Input
|
|
262
288
|
}] } });
|
|
263
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cascade-list.component.js","sourceRoot":"","sources":["../../../../../../projects/cmat/components/cascade/cascade-list/cascade-list.component.ts","../../../../../../projects/cmat/components/cascade/cascade-list/cascade-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf } from '@angular/common';\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    forwardRef,\r\n    HostBinding,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    Renderer2,\r\n    SimpleChanges,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\r\nimport { MatBottomSheet, MatBottomSheetRef } from '@angular/material/bottom-sheet';\r\nimport { Subject } from 'rxjs';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\n\r\nimport { CmatCascadeOptionsInterface } from '../options.interface';\r\nimport { CmatCascadeBottomSheetComponent } from '../cascade-bottom-sheet/cascade-bottom-sheet.component';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { CmatCascadeMenuComponent } from '../cascade-menu/cascade-menu.component';\r\nimport { isUndefined } from 'lodash-es';\r\n\r\nlet NEXT_ID = 0;\r\n\r\n@Component({\r\n    selector: 'cmat-cascade-list',\r\n    templateUrl: './cascade-list.component.html',\r\n    styleUrls: ['./cascade-list.component.scss'],\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => CmatCascadeListComponent),\r\n        multi: true\r\n    }],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    exportAs: 'cmatCascadeList',\r\n    standalone: true,\r\n    imports: [MatFormFieldModule, MatIconModule, NgClass, NgIf, CmatCascadeMenuComponent]\r\n})\r\nexport class CmatCascadeListComponent implements OnDestroy, OnChanges, ControlValueAccessor {\r\n    /* 组件 id */\r\n    @HostBinding('attr.id')\r\n    @Input()\r\n    public id = `cmat-cascade-list-${NEXT_ID++}`;\r\n\r\n    @Input() disabled = false;\r\n\r\n    @Input() placeholder = '请选择';\r\n\r\n    @Input() appearance: 'fill' | 'outline' = 'fill';\r\n\r\n    // data\r\n    @Input({ required: true }) options: Array<CmatCascadeOptionsInterface>;\r\n    @Input() clearable = false;\r\n    @Input() fullLevels = true;\r\n    @Input() changeOnSelect = false;\r\n\r\n    // bind value\r\n    @Input({ required: true }) model: Array<string>;\r\n    @Output() modelChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    // bottomSheet\r\n    bottomSheetRef: MatBottomSheetRef;\r\n    steps: Array<any> = [];\r\n    menuVisible = false;\r\n    inputHover = false;\r\n    currentLabels: Array<CmatCascadeOptionsInterface> = [];\r\n    inputValue?: string;\r\n\r\n    private _touchUi = false;\r\n    private _unsubscribeAll: Subject<void> = new Subject<void>();\r\n\r\n    constructor(\r\n        private _renderer: Renderer2,\r\n        private _breakpointObserver: BreakpointObserver,\r\n        private _bottomSheet: MatBottomSheet\r\n    ) {\r\n        this._unsubscribeAll = new Subject<void>();\r\n    }\r\n\r\n    // Whether the cascade dropdownlist UI is in touch mode.\r\n    @Input()\r\n    get touchUi(): boolean {\r\n        return this._touchUi;\r\n    }\r\n\r\n    set touchUi(value: boolean) {\r\n        this._touchUi = coerceBooleanProperty(value);\r\n    }\r\n\r\n    onTouched: () => any = () => { };\r\n    controlChange: () => any = () => { };\r\n    globalListenFunc: () => any = () => { };\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (changes['options']) {\r\n            this.options = changes['options'].currentValue;\r\n            this._init();\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.globalListenFunc();\r\n        // unsubscribe\r\n        this._unsubscribeAll.next(void 0);\r\n        this._unsubscribeAll.complete();\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        this.model = value;\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this.controlChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n\r\n    close(): void {\r\n        this.menuVisible = false;\r\n        this.globalListenFunc();\r\n    }\r\n\r\n    clickHandle(event: MouseEvent): void {\r\n        event.stopPropagation();\r\n        if (this.disabled) {\r\n            return;\r\n        }\r\n        const element: HTMLElement = event.target as HTMLElement;\r\n        const isSelfTrigger = ['SPAN', 'I', 'INPUT'].find(v => v === element.tagName);\r\n        if (!isSelfTrigger) {\r\n            return;\r\n        }\r\n\r\n        if (this.touchUi) {\r\n            this.menuVisible = false;\r\n            this.openBottomSheet();\r\n        } else {\r\n            this.menuVisible = !this.menuVisible;\r\n\r\n            if (this.menuVisible) {\r\n                this.globalListenFunc = this._renderer.listen(\r\n                    'document', 'click', () => {\r\n                        this.menuVisible = false;\r\n                    }\r\n                );\r\n            } else {\r\n                this.globalListenFunc();\r\n            }\r\n        }\r\n    }\r\n\r\n    changeLabels(): void {\r\n        this.inputValue = '';\r\n        const nextValue: Array<CmatCascadeOptionsInterface> = [];\r\n\r\n        this.steps.forEach((items: Array<CmatCascadeOptionsInterface>) => {\r\n            const steps: Array<CmatCascadeOptionsInterface> = items.filter((item: CmatCascadeOptionsInterface) => item.active);\r\n            nextValue.push(steps[0]);\r\n        });\r\n        this.currentLabels = nextValue;\r\n        this._setInputValue();\r\n        const next = nextValue.map((item: CmatCascadeOptionsInterface) => item.value);\r\n        this.model = next;\r\n\r\n        this.modelChange.emit(next);\r\n        this.controlChange();\r\n    }\r\n\r\n    clearValue(isFirst: boolean, event?: Event): void {\r\n        if (event) { event.stopPropagation(); }\r\n        this.currentLabels = [];\r\n\r\n        if (!isFirst || (this.model && !this.model.length) || !this.model) {\r\n            const step1 = this.options.map((option: CmatCascadeOptionsInterface) => ({\r\n                ...option,\r\n                active: false\r\n            }));\r\n            this.steps = [step1];\r\n        }\r\n\r\n        this.menuVisible = false;\r\n        this.inputValue = '';\r\n\r\n        if (event) { this.modelChange.emit([]); }\r\n    }\r\n\r\n    initSteps(index: number, options: CmatCascadeOptionsInterface[]): void {\r\n        const step: CmatCascadeOptionsInterface[] = [];\r\n        options.map((item: CmatCascadeOptionsInterface) => {\r\n            if (this.model[index] === item.value) {\r\n                if (!isUndefined(item.children))\r\n                    options = item.children;\r\n\r\n                step.push(({\r\n                    ...item,\r\n                    active: true\r\n                }));\r\n            } else {\r\n                step.push(item);\r\n            }\r\n        });\r\n        this.steps.push(step);\r\n        index += 1;\r\n        if (index < this.model.length) {\r\n            this.initSteps(index, options);\r\n        }\r\n    }\r\n\r\n    selectHandle(event: Event, step: number, index: number): any {\r\n        event.stopPropagation();\r\n\r\n        if (this.steps[step][index].disabled) {\r\n            return;\r\n        }\r\n\r\n        this.steps[step] = this.steps[step].map((item: CmatCascadeOptionsInterface, i: number) =>\r\n        ({\r\n            ...item,\r\n            active: i === index\r\n        }));\r\n        // reset steps\r\n        this.steps.length = step + 1;\r\n        const next = this.steps[step][index].children;\r\n\r\n        // go next\r\n        if (next && Array.isArray(next) && next.length) {\r\n            // change on select (props)\r\n            if (this.changeOnSelect) { this.changeLabels(); }\r\n\r\n            const nativeNext = next.map((item: CmatCascadeOptionsInterface) => ({\r\n                ...item,\r\n                active: false\r\n            }));\r\n            return this.steps.push(nativeNext);\r\n        }\r\n\r\n        // last step\r\n        this.changeLabels();\r\n        this.menuVisible = false;\r\n        if (this.touchUi) {\r\n            this.bottomSheetRef.dismiss();\r\n        }\r\n    }\r\n\r\n    showClearIcon(): boolean {\r\n        return !!(this.clearable && this.inputHover && this.currentLabels.length);\r\n    }\r\n\r\n    openBottomSheet(): void {\r\n        this.bottomSheetRef = this._bottomSheet.open(CmatCascadeBottomSheetComponent, {\r\n            data: this\r\n        });\r\n    }\r\n\r\n    private _init(): void {\r\n        this.clearValue(true);\r\n\r\n        if (this.model && this.model.length) {\r\n            const val = this.model.map((v) => {\r\n                const item = this.options.filter((i: CmatCascadeOptionsInterface) => i.value === v)[0];\r\n                if (!isUndefined(item.children))\r\n                    this.options = item.children;\r\n                return item;\r\n            });\r\n\r\n            this.currentLabels = val.filter(v => !!v);\r\n            this._setInputValue();\r\n            this.initSteps(0, this.options);\r\n        }\r\n\r\n        this._breakpointObserver.observe(Breakpoints.Handset).pipe(\r\n            takeUntil(this._unsubscribeAll),\r\n            map((match: { matches: any }) => match.matches)\r\n        ).subscribe((matches: boolean) => {\r\n            this.touchUi !== matches && !matches && this.bottomSheetRef && this.bottomSheetRef.dismiss();\r\n        });\r\n    }\r\n\r\n    private _setInputValue(): void {\r\n        if (this.fullLevels) {\r\n            this.currentLabels.map((value, i) => {\r\n                this.inputValue += `${value.label}${i < this.currentLabels.length - 1 ? ' / ' : ''}`;\r\n            });\r\n        } else {\r\n            this.inputValue = this.currentLabels[this.currentLabels.length - 1].label;\r\n        }\r\n    }\r\n}\r\n","<span role=\"presentation\" class=\"cmat-cascade-list\" [ngClass]=\"{'opened': menuVisible, 'disabled': disabled}\"\n    (click)=\"clickHandle($event)\" (mouseenter)=\"inputHover = true\" (mouseleave)=\"inputHover = false\">\n    <mat-form-field [appearance]=\"appearance\">\n        <input [value]=\"inputValue || ''\" matInput readonly [placeholder]=\"currentLabels.length ? '' : placeholder\">\n        <button type=\"button\" *ngIf=\"showClearIcon()\" matSuffix mat-icon-button aria-label=\"Clear\"\n            (click)=\"clearValue(false,$event)\">\n            <mat-icon [svgIcon]=\"'heroicons_outline:x-mark'\"></mat-icon>\n        </button>\n        <mat-icon matSuffix *ngIf=\"!showClearIcon()\" [svgIcon]=\"'mat_outline:arrow_drop_down'\"></mat-icon>\n    </mat-form-field>\n    <cmat-cascade-menu></cmat-cascade-menu>\n</span>"]}
|
|
289
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cascade-list.component.js","sourceRoot":"","sources":["../../../../../../projects/cmat/components/cascade/cascade-list/cascade-list.component.ts","../../../../../../projects/cmat/components/cascade/cascade-list/cascade-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EAIL,MAAM,EAEN,SAAS,EACT,iBAAiB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAsB,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAEtE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAGhD,OAAO,EAAE,+BAA+B,EAAE,MAAM,wDAAwD,CAAC;AACzG,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,wBAAwB,EAAE,MAAM,wCAAwC,CAAC;AAClF,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxC,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,gBAAgB,EAAW,aAAa,EAAE,aAAa,EAAc,MAAM,sBAAsB,CAAC;AAC3G,OAAO,EAAa,YAAY,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;;AAE9D,IAAI,OAAO,GAAG,CAAC,CAAC;AAiBhB,MAAM,OAAO,wBAAwB;IAmCjC,YACY,QAAiB,EACjB,mBAAuC,EACvC,YAA4B;QAF5B,aAAQ,GAAR,QAAQ,CAAS;QACjB,wBAAmB,GAAnB,mBAAmB,CAAoB;QACvC,iBAAY,GAAZ,YAAY,CAAgB;QArCxC,WAAW;QAGJ,OAAE,GAAG,qBAAqB,OAAO,EAAE,EAAE,CAAC;QAEpC,aAAQ,GAAG,KAAK,CAAC;QAEjB,gBAAW,GAAG,KAAK,CAAC;QAKpB,cAAS,GAAG,KAAK,CAAC;QAClB,eAAU,GAAG,IAAI,CAAC;QAClB,mBAAc,GAAG,KAAK,CAAC;QAItB,gBAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;QAQnE,UAAK,GAAe,EAAE,CAAC;QACvB,gBAAW,GAAG,KAAK,CAAC;QACpB,kBAAa,GAAuC,EAAE,CAAC;QAG/C,aAAQ,GAAG,KAAK,CAAC;QACjB,oBAAe,GAAkB,IAAI,OAAO,EAAQ,CAAC;QAoB7D,cAAS,GAAc,GAAG,EAAE,GAAG,CAAC,CAAC;QACjC,kBAAa,GAAc,GAAG,EAAE,GAAG,CAAC,CAAC;IAbrC,CAAC;IAED,wDAAwD;IACxD,IACI,OAAO;QACP,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED,IAAI,OAAO,CAAC,KAAc;QACtB,IAAI,CAAC,QAAQ,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC;IAKD,QAAQ;QACJ,MAAM,MAAM,GAAG,IAAI,aAAa,CAAC;YAC7B,WAAW,EAAE,IAAI;YACjB,aAAa,EAAE,kCAAkC;YACjD,cAAc,EAAE,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,UAAU,EAAE;YAC3D,gBAAgB,EAAE,IAAI,CAAC,QAAQ;iBAC1B,QAAQ,EAAE;iBACV,mBAAmB,CAChB,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;iBACjC,aAAa,CAAC;gBACX;oBACI,OAAO,EAAE,OAAO;oBAChB,OAAO,EAAE,QAAQ;oBACjB,QAAQ,EAAE,OAAO;oBACjB,QAAQ,EAAE,KAAK;iBAClB;gBACD;oBACI,OAAO,EAAE,OAAO;oBAChB,OAAO,EAAE,KAAK;oBACd,QAAQ,EAAE,OAAO;oBACjB,QAAQ,EAAE,QAAQ;iBACrB;aACJ,CAAC;SACT,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAE/C,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YAC3C,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,CAAC,SAAS,CAAC,EAAE;YACpB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC;YAC/C,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAED,UAAU,CAAC,KAAU;QACjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,WAAW,CAAC,KAAiB;QACzB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,OAAO;SACV;QACD,MAAM,OAAO,GAAgB,KAAK,CAAC,MAAqB,CAAC;QACzD,MAAM,aAAa,GAAG,CAAC,MAAM,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;QAC9E,IAAI,CAAC,aAAa,EAAE;YAChB,OAAO;SACV;QAED,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,EAAE;gBAClD,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;aAC5B;YACD,IAAI,CAAC,eAAe,EAAE,CAAC;SAC1B;aAAM;YACH,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SAC7C;IACL,CAAC;IAED,YAAY;QACR,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,MAAM,SAAS,GAAuC,EAAE,CAAC;QAEzD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,KAAyC,EAAE,EAAE;YAC7D,MAAM,KAAK,GAAuC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAiC,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACnH,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QAC/B,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,MAAM,IAAI,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,IAAiC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9E,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAElB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAED,UAAU,CAAC,OAAgB,EAAE,KAAa;QACtC,IAAI,KAAK,EAAE;YAAE,KAAK,CAAC,eAAe,EAAE,CAAC;SAAE;QACvC,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QAExB,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YAC/D,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAmC,EAAE,EAAE,CAAC,CAAC;gBACrE,GAAG,MAAM;gBACT,MAAM,EAAE,KAAK;aAChB,CAAC,CAAC,CAAC;YACJ,IAAI,CAAC,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;SACxB;QAED,2BAA2B;QAC3B,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QAErB,IAAI,KAAK,EAAE;YAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SAAE;IAC7C,CAAC;IAED,SAAS,CAAC,KAAa,EAAE,OAAsC;QAC3D,MAAM,IAAI,GAAkC,EAAE,CAAC;QAC/C,OAAO,CAAC,GAAG,CAAC,CAAC,IAAiC,EAAE,EAAE;YAC9C,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE;gBAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC;oBAC3B,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;gBAE5B,IAAI,CAAC,IAAI,CAAC,CAAC;oBACP,GAAG,IAAI;oBACP,MAAM,EAAE,IAAI;iBACf,CAAC,CAAC,CAAC;aACP;iBAAM;gBACH,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACnB;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtB,KAAK,IAAI,CAAC,CAAC;QACX,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YAC3B,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;SAClC;IACL,CAAC;IAED,YAAY,CAAC,KAAY,EAAE,IAAY,EAAE,KAAa;QAClD,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE;YAClC,OAAO;SACV;QAED,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,IAAiC,EAAE,CAAS,EAAE,EAAE,CACzF,CAAC;YACG,GAAG,IAAI;YACP,MAAM,EAAE,CAAC,KAAK,KAAK;SACtB,CAAC,CAAC,CAAC;QACJ,cAAc;QACd,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,GAAG,CAAC,CAAC;QAC7B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC;QAE9C,UAAU;QACV,IAAI,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE;YAC5C,2BAA2B;YAC3B,IAAI,IAAI,CAAC,cAAc,EAAE;gBAAE,IAAI,CAAC,YAAY,EAAE,CAAC;aAAE;YAEjD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,IAAiC,EAAE,EAAE,CAAC,CAAC;gBAChE,GAAG,IAAI;gBACP,MAAM,EAAE,KAAK;aAChB,CAAC,CAAC,CAAC;YACJ,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACtC;QAED,YAAY;QACZ,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,EAAE;YAClD,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;SAC5B;QACD,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;SACjC;IACL,CAAC;IAED,aAAa;QACT,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IAC3D,CAAC;IAED,eAAe;QACX,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,+BAA+B,EAAE;YAC1E,IAAI,EAAE,IAAI;SACb,CAAC,CAAC;IACP,CAAC;IAEO,KAAK;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAEtB,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YACjC,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBAC7B,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAA8B,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACvF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC;oBAC3B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;gBACjC,OAAO,IAAI,CAAC;YAChB,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1C,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;SACnC;QAED,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,IAAI,CACtD,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,EAC/B,GAAG,CAAC,CAAC,KAAuB,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAClD,CAAC,SAAS,CAAC,CAAC,OAAgB,EAAE,EAAE;YAC7B,IAAI,CAAC,OAAO,KAAK,OAAO,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;QACjG,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,cAAc;QAClB,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;gBAChC,IAAI,CAAC,UAAU,IAAI,GAAG,KAAK,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;YACzF,CAAC,CAAC,CAAC;SACN;aAAM;YACH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC;SAC7E;IACL,CAAC;8GA9QQ,wBAAwB;kGAAxB,wBAAwB,6XAXtB,CAAC;gBACR,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC;gBACvD,KAAK,EAAE,IAAI;aACd,CAAC,yEA4BS,gBAAgB,+NCvE/B,o4BAuBc,wRDyBA,kBAAkB,2aAAE,aAAa,oLAAE,OAAO,oFAAE,wBAAwB,4FAAE,cAAc,0WAAE,aAAa,wLAAE,YAAY;;2FAElH,wBAAwB;kBAfpC,SAAS;+BACI,mBAAmB,aAGlB,CAAC;4BACR,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,yBAAyB,CAAC;4BACvD,KAAK,EAAE,IAAI;yBACd,CAAC,iBACa,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,YACrC,iBAAiB,cACf,IAAI,WACP,CAAC,kBAAkB,EAAE,aAAa,EAAE,OAAO,EAAE,wBAAwB,EAAE,cAAc,EAAE,aAAa,EAAE,YAAY,CAAC;0IAMrH,EAAE;sBAFR,WAAW;uBAAC,SAAS;;sBACrB,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAGqB,OAAO;sBAAjC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAChB,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAGqB,KAAK;sBAA/B,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBACf,WAAW;sBAApB,MAAM;gBAEwC,aAAa;sBAA3D,SAAS;uBAAC,gBAAgB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACA,YAAY;sBAAxD,SAAS;uBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAuBvC,OAAO;sBADV,KAAK","sourcesContent":["import { NgClass } from '@angular/common';\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    forwardRef,\r\n    HostBinding,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n    ViewChild,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\r\nimport { MatBottomSheet, MatBottomSheetRef } from '@angular/material/bottom-sheet';\r\nimport { Subject } from 'rxjs';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\n\r\nimport { CmatCascadeOptionsInterface } from '../options.interface';\r\nimport { CmatCascadeBottomSheetComponent } from '../cascade-bottom-sheet/cascade-bottom-sheet.component';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { CmatCascadeMenuComponent } from '../cascade-menu/cascade-menu.component';\r\nimport { isUndefined } from 'lodash-es';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { CdkOverlayOrigin, Overlay, OverlayConfig, OverlayModule, OverlayRef } from '@angular/cdk/overlay';\r\nimport { CdkPortal, PortalModule } from '@angular/cdk/portal';\r\n\r\nlet NEXT_ID = 0;\r\n\r\n@Component({\r\n    selector: 'cmat-cascade-list',\r\n    templateUrl: './cascade-list.component.html',\r\n    styleUrls: ['./cascade-list.component.scss'],\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => CmatCascadeListComponent),\r\n        multi: true\r\n    }],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    exportAs: 'cmatCascadeList',\r\n    standalone: true,\r\n    imports: [MatFormFieldModule, MatIconModule, NgClass, CmatCascadeMenuComponent, MatInputModule, OverlayModule, PortalModule]\r\n})\r\nexport class CmatCascadeListComponent implements OnDestroy, OnInit, OnChanges, ControlValueAccessor {\r\n    /* 组件 id */\r\n    @HostBinding('attr.id')\r\n    @Input()\r\n    public id = `cmat-cascade-list-${NEXT_ID++}`;\r\n\r\n    @Input() disabled = false;\r\n\r\n    @Input() placeholder = '请选择';\r\n    @Input() label: string;\r\n\r\n    // data\r\n    @Input({ required: true }) options: Array<CmatCascadeOptionsInterface>;\r\n    @Input() clearable = false;\r\n    @Input() fullLevels = true;\r\n    @Input() changeOnSelect = false;\r\n\r\n    // bind value\r\n    @Input({ required: true }) model: Array<string>;\r\n    @Output() modelChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    @ViewChild(CdkOverlayOrigin, { static: true }) overlayOrigin: CdkOverlayOrigin;\r\n    @ViewChild('menuTemplate', { static: true }) menuTemplate: CdkPortal;\r\n    overlayRef: OverlayRef;\r\n\r\n    // bottomSheet\r\n    bottomSheetRef: MatBottomSheetRef;\r\n    steps: Array<any> = [];\r\n    menuVisible = false;\r\n    currentLabels: Array<CmatCascadeOptionsInterface> = [];\r\n    inputValue?: string;\r\n\r\n    private _touchUi = false;\r\n    private _unsubscribeAll: Subject<void> = new Subject<void>();\r\n\r\n    constructor(\r\n        private _overlay: Overlay,\r\n        private _breakpointObserver: BreakpointObserver,\r\n        private _bottomSheet: MatBottomSheet\r\n    ) {\r\n\r\n    }\r\n\r\n    // Whether the cascade dropdownlist UI is in touch mode.\r\n    @Input()\r\n    get touchUi(): boolean {\r\n        return this._touchUi;\r\n    }\r\n\r\n    set touchUi(value: boolean) {\r\n        this._touchUi = coerceBooleanProperty(value);\r\n    }\r\n\r\n    onTouched: () => any = () => { };\r\n    controlChange: () => any = () => { };\r\n\r\n    ngOnInit(): void {\r\n        const config = new OverlayConfig({\r\n            hasBackdrop: true,\r\n            backdropClass: 'cdk-overlay-transparent-backdrop',\r\n            scrollStrategy: this._overlay.scrollStrategies.reposition(),\r\n            positionStrategy: this._overlay\r\n                .position()\r\n                .flexibleConnectedTo(\r\n                    this.overlayOrigin.elementRef)\r\n                .withPositions([\r\n                    {\r\n                        originX: 'start',\r\n                        originY: 'bottom',\r\n                        overlayX: 'start',\r\n                        overlayY: 'top'\r\n                    },\r\n                    {\r\n                        originX: 'start',\r\n                        originY: 'top',\r\n                        overlayX: 'start',\r\n                        overlayY: 'bottom'\r\n                    }\r\n                ])\r\n        });\r\n\r\n        this.overlayRef = this._overlay.create(config);\r\n\r\n        this.overlayRef.backdropClick().subscribe(() => {\r\n            this.overlayRef.detach();\r\n        });\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (changes['options']) {\r\n            this.options = changes['options'].currentValue;\r\n            this._init();\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this._unsubscribeAll.next(void 0);\r\n        this._unsubscribeAll.complete();\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        this.model = value;\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this.controlChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n\r\n    clickHandle(event: MouseEvent): void {\r\n        event.stopPropagation();\r\n        if (this.disabled) {\r\n            return;\r\n        }\r\n        const element: HTMLElement = event.target as HTMLElement;\r\n        const isSelfTrigger = ['SPAN', 'I', 'INPUT'].find(v => v === element.tagName);\r\n        if (!isSelfTrigger) {\r\n            return;\r\n        }\r\n\r\n        if (this.touchUi) {\r\n            if (this.overlayRef && this.overlayRef.hasAttached()) {\r\n                this.overlayRef.detach();\r\n            }\r\n            this.openBottomSheet();\r\n        } else {\r\n            this.overlayRef.attach(this.menuTemplate);\r\n        }\r\n    }\r\n\r\n    changeLabels(): void {\r\n        this.inputValue = '';\r\n        const nextValue: Array<CmatCascadeOptionsInterface> = [];\r\n\r\n        this.steps.forEach((items: Array<CmatCascadeOptionsInterface>) => {\r\n            const steps: Array<CmatCascadeOptionsInterface> = items.filter((item: CmatCascadeOptionsInterface) => item.active);\r\n            nextValue.push(steps[0]);\r\n        });\r\n        this.currentLabels = nextValue;\r\n        this._setInputValue();\r\n        const next = nextValue.map((item: CmatCascadeOptionsInterface) => item.value);\r\n        this.model = next;\r\n\r\n        this.modelChange.emit(next);\r\n        this.controlChange();\r\n    }\r\n\r\n    clearValue(isFirst: boolean, event?: Event): void {\r\n        if (event) { event.stopPropagation(); }\r\n        this.currentLabels = [];\r\n\r\n        if (!isFirst || (this.model && !this.model.length) || !this.model) {\r\n            const step1 = this.options.map((option: CmatCascadeOptionsInterface) => ({\r\n                ...option,\r\n                active: false\r\n            }));\r\n            this.steps = [step1];\r\n        }\r\n\r\n        //this.menuVisible = false;\r\n        this.inputValue = '';\r\n\r\n        if (event) { this.modelChange.emit([]); }\r\n    }\r\n\r\n    initSteps(index: number, options: CmatCascadeOptionsInterface[]): void {\r\n        const step: CmatCascadeOptionsInterface[] = [];\r\n        options.map((item: CmatCascadeOptionsInterface) => {\r\n            if (this.model[index] === item.value) {\r\n                if (!isUndefined(item.children))\r\n                    options = item.children;\r\n\r\n                step.push(({\r\n                    ...item,\r\n                    active: true\r\n                }));\r\n            } else {\r\n                step.push(item);\r\n            }\r\n        });\r\n        this.steps.push(step);\r\n        index += 1;\r\n        if (index < this.model.length) {\r\n            this.initSteps(index, options);\r\n        }\r\n    }\r\n\r\n    selectHandle(event: Event, step: number, index: number): any {\r\n        event.stopPropagation();\r\n\r\n        if (this.steps[step][index].disabled) {\r\n            return;\r\n        }\r\n\r\n        this.steps[step] = this.steps[step].map((item: CmatCascadeOptionsInterface, i: number) =>\r\n        ({\r\n            ...item,\r\n            active: i === index\r\n        }));\r\n        // reset steps\r\n        this.steps.length = step + 1;\r\n        const next = this.steps[step][index].children;\r\n\r\n        // go next\r\n        if (next && Array.isArray(next) && next.length) {\r\n            // change on select (props)\r\n            if (this.changeOnSelect) { this.changeLabels(); }\r\n\r\n            const nativeNext = next.map((item: CmatCascadeOptionsInterface) => ({\r\n                ...item,\r\n                active: false\r\n            }));\r\n            return this.steps.push(nativeNext);\r\n        }\r\n\r\n        // last step\r\n        this.changeLabels();\r\n        if (this.overlayRef && this.overlayRef.hasAttached()) {\r\n            this.overlayRef.detach();\r\n        }\r\n        if (this.touchUi) {\r\n            this.bottomSheetRef.dismiss();\r\n        }\r\n    }\r\n\r\n    showClearIcon(): boolean {\r\n        return !!(this.clearable && this.currentLabels.length);\r\n    }\r\n\r\n    openBottomSheet(): void {\r\n        this.bottomSheetRef = this._bottomSheet.open(CmatCascadeBottomSheetComponent, {\r\n            data: this\r\n        });\r\n    }\r\n\r\n    private _init(): void {\r\n        this.clearValue(true);\r\n\r\n        if (this.model && this.model.length) {\r\n            const val = this.model.map((v) => {\r\n                const item = this.options.filter((i: CmatCascadeOptionsInterface) => i.value === v)[0];\r\n                if (!isUndefined(item.children))\r\n                    this.options = item.children;\r\n                return item;\r\n            });\r\n\r\n            this.currentLabels = val.filter(v => !!v);\r\n            this._setInputValue();\r\n            this.initSteps(0, this.options);\r\n        }\r\n\r\n        this._breakpointObserver.observe(Breakpoints.Handset).pipe(\r\n            takeUntil(this._unsubscribeAll),\r\n            map((match: { matches: any }) => match.matches)\r\n        ).subscribe((matches: boolean) => {\r\n            this.touchUi !== matches && !matches && this.bottomSheetRef && this.bottomSheetRef.dismiss();\r\n        });\r\n    }\r\n\r\n    private _setInputValue(): void {\r\n        if (this.fullLevels) {\r\n            this.currentLabels.map((value, i) => {\r\n                this.inputValue += `${value.label}${i < this.currentLabels.length - 1 ? ' / ' : ''}`;\r\n            });\r\n        } else {\r\n            this.inputValue = this.currentLabels[this.currentLabels.length - 1].label;\r\n        }\r\n    }\r\n}\r\n","<span role=\"presentation\" class=\"cmat-cascade-list\" [ngClass]=\"{'opened': menuVisible, 'disabled': disabled}\"\n  cdk-overlay-origin>\n  <mat-form-field>\n    @if (label) {\n      <mat-label>{{label}}</mat-label>\n    }\n    <input (click)=\"clickHandle($event)\" [value]=\"inputValue || ''\" matInput readonly\n      [placeholder]=\"currentLabels.length ? '' : placeholder\">\n\n    @if (showClearIcon()) {\n      <button type=\"button\" matSuffix mat-icon-button aria-label=\"Clear\"\n        (click)=\"clearValue(false,$event)\">\n        <mat-icon [svgIcon]=\"'heroicons_outline:x-mark'\"></mat-icon>\n      </button>\n    }\n    @if (!showClearIcon()) {\n      <mat-icon matSuffix [svgIcon]=\"'mat_outline:arrow_drop_down'\"></mat-icon>\n    }\n  </mat-form-field>\n</span>\n\n<ng-template cdk-portal #menuTemplate=\"cdkPortal\">\n  <cmat-cascade-menu></cmat-cascade-menu>\n</ng-template>"]}
|