cmat 0.0.7 → 0.0.9
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/adapter/dayjs-datetime-adapter.d.ts +1 -1
- package/components/breadcrumb/breadcrumb.service.d.ts +1 -1
- package/components/card/card.component.d.ts +1 -1
- package/components/cascade/cascade-list/cascade-list.component.d.ts +45 -21
- package/components/chip-input/chip-input.component.d.ts +39 -12
- package/components/custom-formly/extension/addons.extension.d.ts +2 -0
- package/components/custom-formly/index.d.ts +5 -0
- package/components/custom-formly/public-api.d.ts +26 -0
- package/components/custom-formly/types/button/button.component.d.ts +18 -0
- package/components/custom-formly/types/cascade/cascade.component.d.ts +38 -0
- package/components/custom-formly/types/checklist/checklist.component.d.ts +41 -0
- package/components/custom-formly/types/chips/chips.component.d.ts +27 -0
- package/components/custom-formly/types/color-picker/color-picker.component.d.ts +7 -0
- package/components/custom-formly/types/date-range/date-range.component.d.ts +20 -0
- package/components/custom-formly/types/datepicker/datepicker.component.d.ts +41 -0
- package/components/custom-formly/types/multicheckbox/multicheckbox.component.d.ts +44 -0
- package/components/custom-formly/types/number/number.component.d.ts +20 -0
- package/components/custom-formly/types/radio/radio.component.d.ts +44 -0
- package/components/custom-formly/types/rating/rating.component.d.ts +24 -0
- package/components/custom-formly/types/repeat/repeat.component.d.ts +16 -0
- package/components/custom-formly/types/select/select.component.d.ts +54 -0
- package/components/custom-formly/types/select-tree/select-tree.component.d.ts +43 -0
- package/components/custom-formly/types/stepper/horizontal/stepper.component.d.ts +9 -0
- package/components/custom-formly/types/stepper/stepper.type.d.ts +6 -0
- package/components/custom-formly/types/stepper/vertical/stepper.component.d.ts +9 -0
- package/components/custom-formly/types/table/table.component.d.ts +43 -0
- package/components/custom-formly/types/tabs/tab.component.d.ts +8 -0
- package/components/custom-formly/types/tags/tags.component.d.ts +41 -0
- package/components/custom-formly/types/textarea/textarea.component.d.ts +13 -0
- package/components/custom-formly/types/upload/upload.component.d.ts +31 -0
- package/components/custom-formly/wrappers/addons/addons.component.d.ts +10 -0
- package/components/custom-formly/wrappers/card/card.component.d.ts +6 -0
- package/components/custom-formly/wrappers/expansion/expansion.component.d.ts +6 -0
- package/components/custom-formly/wrappers/panel/panel.component.d.ts +6 -0
- package/components/date-range/date-range.component.d.ts +8 -6
- package/components/drawer/drawer.component.d.ts +2 -2
- package/components/fullscreen/fullscreen.component.d.ts +2 -9
- package/components/fullscreen/public-api.d.ts +0 -1
- package/components/material-color-picker/material-color-picker.component.d.ts +8 -4
- package/components/material-datetimepicker/calendar.d.ts +2 -2
- package/components/material-datetimepicker/clock.d.ts +1 -1
- package/components/material-datetimepicker/datetimepicker-input.d.ts +1 -1
- package/components/material-datetimepicker/datetimepicker-toggle.d.ts +1 -1
- package/components/material-datetimepicker/datetimepicker.d.ts +5 -10
- package/components/material-datetimepicker/month-view.d.ts +1 -2
- package/components/material-datetimepicker/multi-year-view.d.ts +1 -1
- package/components/material-datetimepicker/time.d.ts +2 -2
- package/components/material-datetimepicker/year-view.d.ts +1 -1
- package/components/navigation/horizontal/components/basic/basic.component.d.ts +1 -1
- package/components/navigation/horizontal/components/branch/branch.component.d.ts +1 -1
- package/components/navigation/horizontal/horizontal.component.d.ts +2 -2
- package/components/navigation/vertical/components/aside/aside.component.d.ts +1 -1
- package/components/navigation/vertical/components/basic/basic.component.d.ts +1 -7
- package/components/navigation/vertical/components/collapsable/collapsable.component.d.ts +1 -1
- package/components/navigation/vertical/components/group/group.component.d.ts +1 -1
- package/components/navigation/vertical/vertical.component.d.ts +5 -5
- package/components/popover/popover-trigger.d.ts +1 -1
- package/components/popover/popover.component.d.ts +3 -3
- package/components/rating/rating.component.d.ts +38 -9
- package/components/select-search/select-search.component.d.ts +4 -4
- package/components/select-tree/select-tree.component.d.ts +50 -21
- package/components/toast/toast.component.d.ts +4 -4
- package/components/transfer-picker/filter/filter.component.d.ts +1 -1
- package/components/transfer-picker/transfer-picker-source/transfer-picker-source.component.d.ts +2 -2
- package/components/transfer-picker/transfer-picker.component.d.ts +1 -1
- package/components/upload/files.type.d.ts +22 -0
- package/components/upload/files.util.service.d.ts +20 -0
- package/components/upload/index.d.ts +5 -0
- package/components/upload/public-api.d.ts +4 -0
- package/components/upload/upload-queue/upload-queue.component.d.ts +39 -0
- package/components/upload/upload.component.d.ts +32 -0
- package/esm2022/animations/public-api.mjs +2 -2
- package/esm2022/components/adapter/dayjs-date-adapter.mjs +6 -6
- package/esm2022/components/adapter/dayjs-datetime-adapter.mjs +5 -5
- 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 +6 -6
- package/esm2022/components/breadcrumb/breadcrumb.service.mjs +5 -5
- package/esm2022/components/card/card.component.mjs +5 -5
- package/esm2022/components/cascade/cascade-bottom-sheet/cascade-bottom-sheet.component.mjs +7 -7
- package/esm2022/components/cascade/cascade-list/cascade-list.component.mjs +207 -114
- package/esm2022/components/cascade/cascade-menu/cascade-menu.component.mjs +4 -4
- package/esm2022/components/chip-input/chip-input.component.mjs +152 -49
- package/esm2022/components/custom-formly/cmat-components-custom-formly.mjs +5 -0
- package/esm2022/components/custom-formly/extension/addons.extension.mjs +13 -0
- package/esm2022/components/custom-formly/public-api.mjs +27 -0
- package/esm2022/components/custom-formly/types/button/button.component.mjs +39 -0
- package/esm2022/components/custom-formly/types/cascade/cascade.component.mjs +71 -0
- package/esm2022/components/custom-formly/types/checklist/checklist.component.mjs +161 -0
- package/esm2022/components/custom-formly/types/chips/chips.component.mjs +55 -0
- package/esm2022/components/custom-formly/types/color-picker/color-picker.component.mjs +15 -0
- package/esm2022/components/custom-formly/types/date-range/date-range.component.mjs +25 -0
- package/esm2022/components/custom-formly/types/datepicker/datepicker.component.mjs +51 -0
- package/esm2022/components/custom-formly/types/multicheckbox/multicheckbox.component.mjs +89 -0
- package/esm2022/components/custom-formly/types/number/number.component.mjs +27 -0
- package/esm2022/components/custom-formly/types/radio/radio.component.mjs +88 -0
- package/esm2022/components/custom-formly/types/rating/rating.component.mjs +27 -0
- package/esm2022/components/custom-formly/types/repeat/repeat.component.mjs +28 -0
- package/esm2022/components/custom-formly/types/select/select.component.mjs +169 -0
- package/esm2022/components/custom-formly/types/select-tree/select-tree.component.mjs +66 -0
- package/esm2022/components/custom-formly/types/stepper/horizontal/stepper.component.mjs +31 -0
- package/esm2022/components/custom-formly/types/stepper/stepper.type.mjs +2 -0
- package/esm2022/components/custom-formly/types/stepper/vertical/stepper.component.mjs +31 -0
- package/esm2022/components/custom-formly/types/table/table.component.mjs +116 -0
- package/esm2022/components/custom-formly/types/tabs/tab.component.mjs +19 -0
- package/esm2022/components/custom-formly/types/tags/tags.component.mjs +149 -0
- package/esm2022/components/custom-formly/types/textarea/textarea.component.mjs +25 -0
- package/esm2022/components/custom-formly/types/upload/upload.component.mjs +58 -0
- package/esm2022/components/custom-formly/wrappers/addons/addons.component.mjs +92 -0
- package/esm2022/components/custom-formly/wrappers/card/card.component.mjs +14 -0
- package/esm2022/components/custom-formly/wrappers/expansion/expansion.component.mjs +14 -0
- package/esm2022/components/custom-formly/wrappers/panel/panel.component.mjs +12 -0
- package/esm2022/components/date-range/date-range.component.mjs +26 -17
- package/esm2022/components/drawer/drawer.component.mjs +5 -5
- package/esm2022/components/drawer/drawer.service.mjs +3 -3
- package/esm2022/components/fullscreen/fullscreen.component.mjs +16 -73
- package/esm2022/components/fullscreen/public-api.mjs +1 -2
- package/esm2022/components/highlight/highlight.component.mjs +5 -5
- package/esm2022/components/highlight/highlight.service.mjs +3 -3
- package/esm2022/components/json-editor/json-editor.component.mjs +3 -3
- package/esm2022/components/masonry/masonry.component.mjs +5 -5
- package/esm2022/components/material-color-picker/material-color-picker.component.mjs +22 -12
- package/esm2022/components/material-datetimepicker/calendar-body.mjs +3 -3
- package/esm2022/components/material-datetimepicker/calendar.mjs +11 -12
- package/esm2022/components/material-datetimepicker/clock.mjs +5 -5
- package/esm2022/components/material-datetimepicker/datetimepicker-input.mjs +4 -5
- package/esm2022/components/material-datetimepicker/datetimepicker-intl.mjs +3 -3
- package/esm2022/components/material-datetimepicker/datetimepicker-toggle.mjs +9 -9
- package/esm2022/components/material-datetimepicker/datetimepicker.mjs +17 -22
- package/esm2022/components/material-datetimepicker/month-view.mjs +5 -6
- package/esm2022/components/material-datetimepicker/multi-year-view.mjs +7 -8
- package/esm2022/components/material-datetimepicker/time.mjs +8 -8
- package/esm2022/components/material-datetimepicker/year-view.mjs +7 -8
- package/esm2022/components/navigation/horizontal/components/basic/basic.component.mjs +8 -8
- package/esm2022/components/navigation/horizontal/components/branch/branch.component.mjs +8 -8
- package/esm2022/components/navigation/horizontal/components/divider/divider.component.mjs +5 -5
- package/esm2022/components/navigation/horizontal/components/spacer/spacer.component.mjs +6 -6
- package/esm2022/components/navigation/horizontal/horizontal.component.mjs +6 -6
- package/esm2022/components/navigation/navigation.service.mjs +3 -3
- package/esm2022/components/navigation/vertical/components/aside/aside.component.mjs +11 -11
- package/esm2022/components/navigation/vertical/components/basic/basic.component.mjs +7 -24
- package/esm2022/components/navigation/vertical/components/collapsable/collapsable.component.mjs +10 -10
- package/esm2022/components/navigation/vertical/components/divider/divider.component.mjs +5 -5
- package/esm2022/components/navigation/vertical/components/group/group.component.mjs +9 -9
- package/esm2022/components/navigation/vertical/components/spacer/spacer.component.mjs +6 -6
- package/esm2022/components/navigation/vertical/vertical.component.mjs +11 -11
- package/esm2022/components/pagination/pagination.component.mjs +10 -10
- package/esm2022/components/pagination/pagination.directive.mjs +4 -4
- package/esm2022/components/pagination/pagination.pipe.mjs +4 -4
- package/esm2022/components/pagination/pagination.service.mjs +3 -3
- package/esm2022/components/password-strength/mat-pass-toggle-visibility/mat-pass-toggle-visibility.component.mjs +6 -6
- package/esm2022/components/password-strength/mat-password-strength/mat-password-strength.component.mjs +5 -5
- package/esm2022/components/password-strength/mat-password-strength-info/mat-password-strength-info.component.mjs +6 -6
- package/esm2022/components/popover/popover-trigger.mjs +5 -5
- package/esm2022/components/popover/popover.component.mjs +8 -9
- package/esm2022/components/popover/popover.target.mjs +3 -3
- package/esm2022/components/progress-bar/progress-bar.component.mjs +6 -6
- package/esm2022/components/rating/rating.component.mjs +122 -23
- 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 +15 -15
- package/esm2022/components/select-tree/select-tree.component.mjs +281 -157
- package/esm2022/components/timeline/timeline-item/timeline-item.component.mjs +9 -9
- package/esm2022/components/timeline/timeline.component.mjs +5 -5
- package/esm2022/components/toast/toast-modal.component.mjs +5 -5
- 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 +9 -9
- package/esm2022/components/transfer-picker/search/search.component.mjs +6 -6
- package/esm2022/components/transfer-picker/transfer-picker-source/transfer-picker-source.component.mjs +11 -11
- package/esm2022/components/transfer-picker/transfer-picker-target/transfer-picker-target.component.mjs +5 -5
- package/esm2022/components/transfer-picker/transfer-picker.component.mjs +7 -7
- package/esm2022/components/transfer-picker/transfer-picker.service.mjs +4 -4
- package/esm2022/components/upload/cmat-components-upload.mjs +5 -0
- package/esm2022/components/upload/files.type.mjs +2 -0
- package/esm2022/components/upload/files.util.service.mjs +100 -0
- package/esm2022/components/upload/public-api.mjs +5 -0
- package/esm2022/components/upload/upload-queue/upload-queue.component.mjs +154 -0
- package/esm2022/components/upload/upload.component.mjs +118 -0
- 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 +3 -3
- 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 +3 -3
- package/esm2022/directives/digit-only/digit-only.directive.mjs +3 -3
- package/esm2022/directives/digit-only/mask.directive.mjs +3 -3
- package/esm2022/directives/equal-validator/equal-validator.directive.mjs +3 -3
- package/esm2022/lib/mock-api/mock-api.interceptor.mjs +5 -5
- 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/public-api.mjs +1 -1
- package/esm2022/services/alert/alert.service.mjs +7 -7
- package/esm2022/services/alert/enum.mjs +2 -2
- package/esm2022/services/config/config.service.mjs +5 -5
- package/esm2022/services/config/urlStateConfig.service.mjs +5 -5
- package/esm2022/services/confirmation/confirmation.service.mjs +5 -5
- package/esm2022/services/confirmation/dialog/dialog.component.mjs +7 -7
- package/esm2022/services/data/data.service.mjs +5 -5
- package/esm2022/services/loading/loading.interceptor.mjs +4 -4
- 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 +5 -5
- package/esm2022/services/platform/platform.service.mjs +4 -4
- package/esm2022/services/splash-screen/splash-screen.service.mjs +6 -6
- package/esm2022/services/title/title.service.mjs +4 -4
- package/esm2022/services/translation/translation.service.mjs +3 -3
- package/esm2022/services/utils/utils.service.mjs +54 -9
- package/fesm2022/cmat-animations.mjs +15 -15
- package/fesm2022/cmat-animations.mjs.map +1 -1
- package/fesm2022/cmat-components-adapter.mjs +11 -11
- package/fesm2022/cmat-components-adapter.mjs.map +1 -1
- package/fesm2022/cmat-components-breadcrumb.mjs +11 -11
- package/fesm2022/cmat-components-breadcrumb.mjs.map +1 -1
- package/fesm2022/cmat-components-card.mjs +4 -4
- package/fesm2022/cmat-components-card.mjs.map +1 -1
- package/fesm2022/cmat-components-cascade.mjs +215 -123
- package/fesm2022/cmat-components-cascade.mjs.map +1 -1
- package/fesm2022/cmat-components-chip-input.mjs +153 -50
- package/fesm2022/cmat-components-chip-input.mjs.map +1 -1
- package/fesm2022/cmat-components-custom-formly.mjs +1331 -0
- package/fesm2022/cmat-components-custom-formly.mjs.map +1 -0
- package/fesm2022/cmat-components-date-range.mjs +27 -18
- package/fesm2022/cmat-components-date-range.mjs.map +1 -1
- package/fesm2022/cmat-components-drawer.mjs +8 -8
- package/fesm2022/cmat-components-drawer.mjs.map +1 -1
- package/fesm2022/cmat-components-fullscreen.mjs +16 -73
- package/fesm2022/cmat-components-fullscreen.mjs.map +1 -1
- package/fesm2022/cmat-components-highlight.mjs +7 -7
- package/fesm2022/cmat-components-highlight.mjs.map +1 -1
- package/fesm2022/cmat-components-json-editor.mjs +3 -3
- package/fesm2022/cmat-components-masonry.mjs +4 -4
- package/fesm2022/cmat-components-masonry.mjs.map +1 -1
- package/fesm2022/cmat-components-material-color-picker.mjs +21 -11
- package/fesm2022/cmat-components-material-color-picker.mjs.map +1 -1
- package/fesm2022/cmat-components-material-datetimepicker.mjs +189 -195
- package/fesm2022/cmat-components-material-datetimepicker.mjs.map +1 -1
- package/fesm2022/cmat-components-navigation.mjs +166 -183
- package/fesm2022/cmat-components-navigation.mjs.map +1 -1
- package/fesm2022/cmat-components-pagination.mjs +20 -20
- package/fesm2022/cmat-components-pagination.mjs.map +1 -1
- package/fesm2022/cmat-components-password-strength.mjs +13 -13
- package/fesm2022/cmat-components-password-strength.mjs.map +1 -1
- package/fesm2022/cmat-components-popover.mjs +13 -14
- package/fesm2022/cmat-components-popover.mjs.map +1 -1
- package/fesm2022/cmat-components-progress-bar.mjs +6 -6
- package/fesm2022/cmat-components-progress-bar.mjs.map +1 -1
- package/fesm2022/cmat-components-rating.mjs +121 -22
- package/fesm2022/cmat-components-rating.mjs.map +1 -1
- package/fesm2022/cmat-components-select-search.mjs +41 -41
- package/fesm2022/cmat-components-select-search.mjs.map +1 -1
- package/fesm2022/cmat-components-select-tree.mjs +281 -157
- package/fesm2022/cmat-components-select-tree.mjs.map +1 -1
- package/fesm2022/cmat-components-timeline.mjs +12 -12
- package/fesm2022/cmat-components-timeline.mjs.map +1 -1
- package/fesm2022/cmat-components-toast.mjs +12 -12
- package/fesm2022/cmat-components-toast.mjs.map +1 -1
- package/fesm2022/cmat-components-transfer-picker.mjs +33 -33
- package/fesm2022/cmat-components-transfer-picker.mjs.map +1 -1
- package/fesm2022/cmat-components-upload.mjs +366 -0
- package/fesm2022/cmat-components-upload.mjs.map +1 -0
- package/fesm2022/cmat-directives-animate-on-scroll.mjs +6 -6
- package/fesm2022/cmat-directives-autofocus.mjs +3 -3
- package/fesm2022/cmat-directives-debounce.mjs +9 -9
- package/fesm2022/cmat-directives-digit-only.mjs +6 -6
- package/fesm2022/cmat-directives-equal-validator.mjs +3 -3
- package/fesm2022/cmat-lib-mock-api.mjs +6 -6
- package/fesm2022/cmat-lib-mock-api.mjs.map +1 -1
- 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 +6 -6
- package/fesm2022/cmat-services-alert.mjs.map +1 -1
- package/fesm2022/cmat-services-config.mjs +7 -7
- package/fesm2022/cmat-services-config.mjs.map +1 -1
- package/fesm2022/cmat-services-confirmation.mjs +11 -11
- package/fesm2022/cmat-services-confirmation.mjs.map +1 -1
- package/fesm2022/cmat-services-data.mjs +5 -5
- package/fesm2022/cmat-services-data.mjs.map +1 -1
- package/fesm2022/cmat-services-loading.mjs +6 -6
- package/fesm2022/cmat-services-loading.mjs.map +1 -1
- package/fesm2022/cmat-services-local-storage.mjs +3 -3
- package/fesm2022/cmat-services-media-watcher.mjs +4 -4
- package/fesm2022/cmat-services-media-watcher.mjs.map +1 -1
- package/fesm2022/cmat-services-platform.mjs +3 -3
- package/fesm2022/cmat-services-platform.mjs.map +1 -1
- package/fesm2022/cmat-services-splash-screen.mjs +5 -5
- package/fesm2022/cmat-services-splash-screen.mjs.map +1 -1
- package/fesm2022/cmat-services-title.mjs +3 -3
- package/fesm2022/cmat-services-title.mjs.map +1 -1
- package/fesm2022/cmat-services-translation.mjs +3 -3
- package/fesm2022/cmat-services-utils.mjs +53 -8
- package/fesm2022/cmat-services-utils.mjs.map +1 -1
- package/package.json +30 -18
- package/pipes/secure/secure-pipe.d.ts +1 -1
- package/services/alert/enum.d.ts +1 -1
- package/services/confirmation/confirmation.service.d.ts +1 -1
- package/services/data/data.service.d.ts +1 -1
- package/services/media-watcher/media-watcher.service.d.ts +1 -1
- package/services/title/title.service.d.ts +1 -1
- package/services/utils/utils.service.d.ts +1 -0
- package/styles/components/bundle.scss +18 -5
- package/styles/overrides/angular-material.scss +51 -52
- package/styles/tailwind.scss +2 -8
- package/styles/themes.scss +7 -7
- package/styles/user-themes.scss +1 -1
- package/tailwind/plugins/utilities.js +1 -1
- package/components/fullscreen/fullscreen.types.d.ts +0 -13
- package/esm2022/components/fullscreen/fullscreen.types.mjs +0 -2
|
@@ -1,55 +1,114 @@
|
|
|
1
|
-
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
3
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
1
|
+
/* eslint-disable @typescript-eslint/member-ordering */
|
|
4
2
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
5
3
|
import { Breakpoints } from '@angular/cdk/layout';
|
|
4
|
+
import { CdkOverlayOrigin, OverlayConfig, OverlayModule } from '@angular/cdk/overlay';
|
|
5
|
+
import { PortalModule } from '@angular/cdk/portal';
|
|
6
|
+
import { NgClass } from '@angular/common';
|
|
7
|
+
import { ChangeDetectionStrategy, Component, HostBinding, Input, Optional, Self, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
8
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
9
|
+
import { MatFormFieldControl } from '@angular/material/form-field';
|
|
10
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
11
|
+
import { MatInputModule } from '@angular/material/input';
|
|
12
|
+
import { isUndefined } from 'lodash-es';
|
|
6
13
|
import { Subject } from 'rxjs';
|
|
7
14
|
import { map, takeUntil } from 'rxjs/operators';
|
|
8
15
|
import { CmatCascadeBottomSheetComponent } from '../cascade-bottom-sheet/cascade-bottom-sheet.component';
|
|
9
|
-
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
10
|
-
import { MatIconModule } from '@angular/material/icon';
|
|
11
16
|
import { CmatCascadeMenuComponent } from '../cascade-menu/cascade-menu.component';
|
|
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';
|
|
16
17
|
import * as i0 from "@angular/core";
|
|
17
|
-
import * as i1 from "@angular/
|
|
18
|
-
import * as i2 from "@angular/cdk/
|
|
19
|
-
import * as i3 from "@angular/
|
|
20
|
-
import * as i4 from "@angular/material/
|
|
18
|
+
import * as i1 from "@angular/forms";
|
|
19
|
+
import * as i2 from "@angular/cdk/overlay";
|
|
20
|
+
import * as i3 from "@angular/cdk/layout";
|
|
21
|
+
import * as i4 from "@angular/material/bottom-sheet";
|
|
21
22
|
import * as i5 from "@angular/material/icon";
|
|
22
23
|
import * as i6 from "@angular/material/input";
|
|
23
|
-
import * as i7 from "@angular/
|
|
24
|
+
import * as i7 from "@angular/material/form-field";
|
|
25
|
+
import * as i8 from "@angular/cdk/portal";
|
|
26
|
+
import * as i9 from "@angular/material/button";
|
|
24
27
|
let NEXT_ID = 0;
|
|
25
28
|
export class CmatCascadeListComponent {
|
|
26
|
-
constructor(_overlay, _breakpointObserver, _bottomSheet) {
|
|
29
|
+
constructor(ngControl, _overlay, _breakpointObserver, _bottomSheet, _changeDetectorRef) {
|
|
30
|
+
this.ngControl = ngControl;
|
|
27
31
|
this._overlay = _overlay;
|
|
28
32
|
this._breakpointObserver = _breakpointObserver;
|
|
29
33
|
this._bottomSheet = _bottomSheet;
|
|
34
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
30
35
|
/* 组件 id */
|
|
31
36
|
this.id = `cmat-cascade-list-${NEXT_ID++}`;
|
|
32
|
-
this.disabled = false;
|
|
33
|
-
this.placeholder = '请选择';
|
|
34
37
|
this.clearable = false;
|
|
35
38
|
this.fullLevels = true;
|
|
36
39
|
this.changeOnSelect = false;
|
|
37
|
-
this.modelChange = new EventEmitter();
|
|
38
40
|
this.steps = [];
|
|
39
41
|
this.menuVisible = false;
|
|
40
42
|
this.currentLabels = [];
|
|
41
|
-
this.
|
|
43
|
+
this.stateChanges = new Subject();
|
|
44
|
+
this.focused = false;
|
|
45
|
+
this.touched = false;
|
|
46
|
+
this.controlType = 'cmat-cascade-list';
|
|
42
47
|
this._unsubscribeAll = new Subject();
|
|
48
|
+
// Whether the cascade dropdownlist UI is in touch mode.
|
|
49
|
+
this._touchUi = false;
|
|
50
|
+
this._placeholder = '请选择';
|
|
51
|
+
this._required = false;
|
|
52
|
+
this._disabled = false;
|
|
43
53
|
this.onTouched = () => { };
|
|
44
54
|
this.controlChange = () => { };
|
|
55
|
+
if (this.ngControl != null) {
|
|
56
|
+
this.ngControl.valueAccessor = this;
|
|
57
|
+
}
|
|
45
58
|
}
|
|
46
|
-
// Whether the cascade dropdownlist UI is in touch mode.
|
|
47
59
|
get touchUi() {
|
|
48
60
|
return this._touchUi;
|
|
49
61
|
}
|
|
50
62
|
set touchUi(value) {
|
|
51
63
|
this._touchUi = coerceBooleanProperty(value);
|
|
52
64
|
}
|
|
65
|
+
get placeholder() {
|
|
66
|
+
return this._placeholder;
|
|
67
|
+
}
|
|
68
|
+
set placeholder(value) {
|
|
69
|
+
this._placeholder = value;
|
|
70
|
+
this.stateChanges.next();
|
|
71
|
+
}
|
|
72
|
+
get value() {
|
|
73
|
+
return this._value;
|
|
74
|
+
}
|
|
75
|
+
set value(value) {
|
|
76
|
+
if (value !== this.value) {
|
|
77
|
+
this._value = value;
|
|
78
|
+
this._setInputValue();
|
|
79
|
+
this.stateChanges.next();
|
|
80
|
+
this.controlChange(value);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
get empty() {
|
|
84
|
+
return !this._value;
|
|
85
|
+
}
|
|
86
|
+
get errorState() {
|
|
87
|
+
if (this.ngControl == null)
|
|
88
|
+
return false;
|
|
89
|
+
return (this.touched && this.ngControl?.invalid) ?? false;
|
|
90
|
+
}
|
|
91
|
+
get shouldLabelFloat() {
|
|
92
|
+
return this.focused || !this.empty;
|
|
93
|
+
}
|
|
94
|
+
get required() { return this._required; }
|
|
95
|
+
set required(value) {
|
|
96
|
+
this._required = coerceBooleanProperty(value);
|
|
97
|
+
this.stateChanges.next();
|
|
98
|
+
}
|
|
99
|
+
get disabled() {
|
|
100
|
+
if (this.ngControl && this.ngControl.disabled !== null) {
|
|
101
|
+
return this.ngControl.disabled;
|
|
102
|
+
}
|
|
103
|
+
return this._disabled;
|
|
104
|
+
}
|
|
105
|
+
set disabled(value) {
|
|
106
|
+
this._disabled = coerceBooleanProperty(value);
|
|
107
|
+
if (this.focused) {
|
|
108
|
+
this.focused = false;
|
|
109
|
+
this.stateChanges.next();
|
|
110
|
+
}
|
|
111
|
+
}
|
|
53
112
|
ngOnInit() {
|
|
54
113
|
const config = new OverlayConfig({
|
|
55
114
|
hasBackdrop: true,
|
|
@@ -73,6 +132,9 @@ export class CmatCascadeListComponent {
|
|
|
73
132
|
}
|
|
74
133
|
])
|
|
75
134
|
});
|
|
135
|
+
this._breakpointObserver.observe(Breakpoints.Handset).pipe(takeUntil(this._unsubscribeAll), map((match) => match.matches)).subscribe((matches) => {
|
|
136
|
+
this.touchUi !== matches && !matches && this.bottomSheetRef && this.bottomSheetRef.dismiss();
|
|
137
|
+
});
|
|
76
138
|
this.overlayRef = this._overlay.create(config);
|
|
77
139
|
this.overlayRef.backdropClick().subscribe(() => {
|
|
78
140
|
this.overlayRef.detach();
|
|
@@ -80,16 +142,25 @@ export class CmatCascadeListComponent {
|
|
|
80
142
|
}
|
|
81
143
|
ngOnChanges(changes) {
|
|
82
144
|
if (changes['options']) {
|
|
83
|
-
this.
|
|
145
|
+
if ((this.value && !this.value.length) || !this.value) {
|
|
146
|
+
const step1 = this.options.map((option) => ({
|
|
147
|
+
...option,
|
|
148
|
+
active: false
|
|
149
|
+
}));
|
|
150
|
+
this.steps = [step1];
|
|
151
|
+
}
|
|
84
152
|
this._init();
|
|
85
153
|
}
|
|
86
154
|
}
|
|
87
155
|
ngOnDestroy() {
|
|
156
|
+
this.stateChanges.complete();
|
|
88
157
|
this._unsubscribeAll.next(void 0);
|
|
89
158
|
this._unsubscribeAll.complete();
|
|
90
159
|
}
|
|
91
160
|
writeValue(value) {
|
|
92
|
-
this.
|
|
161
|
+
this.value = value;
|
|
162
|
+
this.steps = [];
|
|
163
|
+
this._init();
|
|
93
164
|
}
|
|
94
165
|
registerOnChange(fn) {
|
|
95
166
|
this.controlChange = fn;
|
|
@@ -97,9 +168,24 @@ export class CmatCascadeListComponent {
|
|
|
97
168
|
registerOnTouched(fn) {
|
|
98
169
|
this.onTouched = fn;
|
|
99
170
|
}
|
|
171
|
+
setDisabledState(isDisabled) {
|
|
172
|
+
this.disabled = isDisabled;
|
|
173
|
+
}
|
|
174
|
+
setDescribedByIds(ids) {
|
|
175
|
+
if (ids.length) {
|
|
176
|
+
this._inputElement.nativeElement.setAttribute('aria-describedby', ids.join(' '));
|
|
177
|
+
}
|
|
178
|
+
else {
|
|
179
|
+
this._inputElement.nativeElement.removeAttribute('aria-describedby');
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
onContainerClick() {
|
|
183
|
+
if (!this.focused) {
|
|
184
|
+
this._inputElement.nativeElement.focus();
|
|
185
|
+
}
|
|
186
|
+
}
|
|
100
187
|
clickHandle(event) {
|
|
101
|
-
|
|
102
|
-
if (this.disabled) {
|
|
188
|
+
if (this.disabled || this.options.length === 0) {
|
|
103
189
|
return;
|
|
104
190
|
}
|
|
105
191
|
const element = event.target;
|
|
@@ -111,64 +197,28 @@ export class CmatCascadeListComponent {
|
|
|
111
197
|
if (this.overlayRef && this.overlayRef.hasAttached()) {
|
|
112
198
|
this.overlayRef.detach();
|
|
113
199
|
}
|
|
114
|
-
this.
|
|
200
|
+
this._openBottomSheet();
|
|
115
201
|
}
|
|
116
202
|
else {
|
|
117
203
|
this.overlayRef.attach(this.menuTemplate);
|
|
118
204
|
}
|
|
119
205
|
}
|
|
120
|
-
|
|
121
|
-
this.inputValue = '';
|
|
122
|
-
const nextValue = [];
|
|
123
|
-
this.steps.forEach((items) => {
|
|
124
|
-
const steps = items.filter((item) => item.active);
|
|
125
|
-
nextValue.push(steps[0]);
|
|
126
|
-
});
|
|
127
|
-
this.currentLabels = nextValue;
|
|
128
|
-
this._setInputValue();
|
|
129
|
-
const next = nextValue.map((item) => item.value);
|
|
130
|
-
this.model = next;
|
|
131
|
-
this.modelChange.emit(next);
|
|
132
|
-
this.controlChange();
|
|
133
|
-
}
|
|
134
|
-
clearValue(isFirst, event) {
|
|
206
|
+
clearValue(event) {
|
|
135
207
|
if (event) {
|
|
136
208
|
event.stopPropagation();
|
|
137
209
|
}
|
|
138
210
|
this.currentLabels = [];
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
this.inputValue = '';
|
|
148
|
-
if (event) {
|
|
149
|
-
this.modelChange.emit([]);
|
|
150
|
-
}
|
|
211
|
+
this.steps = [];
|
|
212
|
+
const step1 = this.options.map((option) => ({
|
|
213
|
+
...option,
|
|
214
|
+
active: false
|
|
215
|
+
}));
|
|
216
|
+
this.steps = [step1];
|
|
217
|
+
this.value = null;
|
|
218
|
+
this._changeDetectorRef.markForCheck();
|
|
151
219
|
}
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
options.map((item) => {
|
|
155
|
-
if (this.model[index] === item.value) {
|
|
156
|
-
if (!isUndefined(item.children))
|
|
157
|
-
options = item.children;
|
|
158
|
-
step.push(({
|
|
159
|
-
...item,
|
|
160
|
-
active: true
|
|
161
|
-
}));
|
|
162
|
-
}
|
|
163
|
-
else {
|
|
164
|
-
step.push(item);
|
|
165
|
-
}
|
|
166
|
-
});
|
|
167
|
-
this.steps.push(step);
|
|
168
|
-
index += 1;
|
|
169
|
-
if (index < this.model.length) {
|
|
170
|
-
this.initSteps(index, options);
|
|
171
|
-
}
|
|
220
|
+
showClearIcon() {
|
|
221
|
+
return !!(this.clearable && this.currentLabels.length > 0 && !this.disabled);
|
|
172
222
|
}
|
|
173
223
|
selectHandle(event, step, index) {
|
|
174
224
|
event.stopPropagation();
|
|
@@ -186,7 +236,7 @@ export class CmatCascadeListComponent {
|
|
|
186
236
|
if (next && Array.isArray(next) && next.length) {
|
|
187
237
|
// change on select (props)
|
|
188
238
|
if (this.changeOnSelect) {
|
|
189
|
-
this.
|
|
239
|
+
this._changeLabels();
|
|
190
240
|
}
|
|
191
241
|
const nativeNext = next.map((item) => ({
|
|
192
242
|
...item,
|
|
@@ -195,7 +245,7 @@ export class CmatCascadeListComponent {
|
|
|
195
245
|
return this.steps.push(nativeNext);
|
|
196
246
|
}
|
|
197
247
|
// last step
|
|
198
|
-
this.
|
|
248
|
+
this._changeLabels();
|
|
199
249
|
if (this.overlayRef && this.overlayRef.hasAttached()) {
|
|
200
250
|
this.overlayRef.detach();
|
|
201
251
|
}
|
|
@@ -203,66 +253,103 @@ export class CmatCascadeListComponent {
|
|
|
203
253
|
this.bottomSheetRef.dismiss();
|
|
204
254
|
}
|
|
205
255
|
}
|
|
206
|
-
|
|
207
|
-
|
|
256
|
+
onFocusIn() {
|
|
257
|
+
if (!this.focused) {
|
|
258
|
+
this.focused = true;
|
|
259
|
+
this.stateChanges.next();
|
|
260
|
+
}
|
|
208
261
|
}
|
|
209
|
-
|
|
262
|
+
onFocusOut(event) {
|
|
263
|
+
if (!this._inputElement.nativeElement.contains(event.relatedTarget)) {
|
|
264
|
+
this.touched = true;
|
|
265
|
+
this.focused = false;
|
|
266
|
+
this.onTouched();
|
|
267
|
+
this.stateChanges.next();
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
_initSteps(index, options) {
|
|
271
|
+
const step = [];
|
|
272
|
+
options.map((item) => {
|
|
273
|
+
if (this.value[index].value === item.value) {
|
|
274
|
+
if (!isUndefined(item.children))
|
|
275
|
+
options = item.children;
|
|
276
|
+
step.push(({
|
|
277
|
+
...item,
|
|
278
|
+
active: true
|
|
279
|
+
}));
|
|
280
|
+
}
|
|
281
|
+
else {
|
|
282
|
+
step.push(item);
|
|
283
|
+
}
|
|
284
|
+
});
|
|
285
|
+
this.steps.push(step);
|
|
286
|
+
index += 1;
|
|
287
|
+
if (index < this.value.length) {
|
|
288
|
+
this._initSteps(index, options);
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
_changeLabels() {
|
|
292
|
+
const nextValue = [];
|
|
293
|
+
this.steps.forEach((items) => {
|
|
294
|
+
const steps = items.filter((item) => item.active);
|
|
295
|
+
nextValue.push(steps[0]);
|
|
296
|
+
});
|
|
297
|
+
this.currentLabels = nextValue;
|
|
298
|
+
const next = nextValue.map((item) => {
|
|
299
|
+
return {
|
|
300
|
+
value: item.value,
|
|
301
|
+
label: item.label
|
|
302
|
+
};
|
|
303
|
+
});
|
|
304
|
+
this.value = next;
|
|
305
|
+
}
|
|
306
|
+
_openBottomSheet() {
|
|
210
307
|
this.bottomSheetRef = this._bottomSheet.open(CmatCascadeBottomSheetComponent, {
|
|
211
308
|
data: this
|
|
212
309
|
});
|
|
213
310
|
}
|
|
214
311
|
_init() {
|
|
215
|
-
this.
|
|
216
|
-
if (this.
|
|
217
|
-
|
|
218
|
-
|
|
312
|
+
this.currentLabels = [];
|
|
313
|
+
if (this.value && this.value.length && this.options.length > 0) {
|
|
314
|
+
let options = this.options;
|
|
315
|
+
const val = this.value.map((v) => {
|
|
316
|
+
const item = options.filter((i) => i.value === v.value)[0];
|
|
219
317
|
if (!isUndefined(item.children))
|
|
220
|
-
|
|
318
|
+
options = item.children;
|
|
221
319
|
return item;
|
|
222
320
|
});
|
|
223
|
-
this.currentLabels = val.filter(v => !!v);
|
|
321
|
+
this.currentLabels = val.filter((v) => !!v);
|
|
224
322
|
this._setInputValue();
|
|
225
|
-
this.
|
|
323
|
+
this._initSteps(0, this.options);
|
|
226
324
|
}
|
|
227
|
-
this.
|
|
228
|
-
this.touchUi !== matches && !matches && this.bottomSheetRef && this.bottomSheetRef.dismiss();
|
|
229
|
-
});
|
|
325
|
+
this._changeDetectorRef.markForCheck();
|
|
230
326
|
}
|
|
231
327
|
_setInputValue() {
|
|
328
|
+
this._inputElement.nativeElement.value = '';
|
|
232
329
|
if (this.fullLevels) {
|
|
233
330
|
this.currentLabels.map((value, i) => {
|
|
234
|
-
this.
|
|
331
|
+
this._inputElement.nativeElement.value += `${value.label}${i < this.currentLabels.length - 1 ? ' / ' : ''}`;
|
|
235
332
|
});
|
|
236
333
|
}
|
|
237
334
|
else {
|
|
238
|
-
this.
|
|
335
|
+
this._inputElement.nativeElement.value = this.currentLabels[this.currentLabels.length - 1].label ?? '';
|
|
239
336
|
}
|
|
240
337
|
}
|
|
241
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
242
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.
|
|
243
|
-
provide: NG_VALUE_ACCESSOR,
|
|
244
|
-
useExisting: forwardRef(() => CmatCascadeListComponent),
|
|
245
|
-
multi: true
|
|
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 }); }
|
|
338
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CmatCascadeListComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i2.Overlay }, { token: i3.BreakpointObserver }, { token: i4.MatBottomSheet }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
339
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.7", type: CmatCascadeListComponent, isStandalone: true, selector: "cmat-cascade-list", inputs: { id: "id", options: "options", clearable: "clearable", fullLevels: "fullLevels", changeOnSelect: "changeOnSelect", touchUi: "touchUi", placeholder: "placeholder", value: "value", required: "required", disabled: "disabled" }, host: { properties: { "attr.id": "this.id" } }, providers: [{ provide: MatFormFieldControl, useExisting: CmatCascadeListComponent }], viewQueries: [{ propertyName: "overlayOrigin", first: true, predicate: CdkOverlayOrigin, descendants: true, static: true }, { propertyName: "menuTemplate", first: true, predicate: ["menuTemplate"], descendants: true, static: true }, { propertyName: "_inputElement", first: true, predicate: ["inputElement"], 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 <input (click)=\"clickHandle($event)\" matInput readonly #inputElement [required]='required' (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\" [placeholder]=\"currentLabels.length>0 ? '' : placeholder\">\n\n @if (showClearIcon()) {\n <button type=\"button\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"clearValue($event)\">\n <mat-icon [svgIcon]=\"'heroicons_outline:x-mark'\"></mat-icon>\n </button>\n }\n @else {\n <mat-icon matSuffix [svgIcon]=\"'mat_outline:arrow_drop_down'\"></mat-icon>\n }\n</span>\n\n<ng-template cdk-portal #menuTemplate=\"cdkPortal\">\n <cmat-cascade-menu></cmat-cascade-menu>\n</ng-template>", styles: ["cmat-cascade-list{width:100%}.cmat-cascade-list{position:relative;display:flex;width:100%;line-height:2;align-items:center}.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: 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: "directive", type: i7.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: OverlayModule }, { kind: "directive", type: i2.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "ngmodule", type: PortalModule }, { kind: "directive", type: i8.TemplatePortalDirective, selector: "[cdk-portal], [portal]", exportAs: ["cdkPortal"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i9.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
247
340
|
}
|
|
248
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
341
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CmatCascadeListComponent, decorators: [{
|
|
249
342
|
type: Component,
|
|
250
|
-
args: [{ selector: 'cmat-cascade-list', providers: [{
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
343
|
+
args: [{ selector: 'cmat-cascade-list', providers: [{ provide: MatFormFieldControl, useExisting: CmatCascadeListComponent }], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'cmatCascadeList', standalone: true, imports: [MatIconModule, NgClass, CmatCascadeMenuComponent, MatInputModule, OverlayModule, PortalModule, MatButtonModule], template: "<span role=\"presentation\" class=\"cmat-cascade-list\" [ngClass]=\"{'opened': menuVisible, 'disabled': disabled}\"\n cdk-overlay-origin>\n <input (click)=\"clickHandle($event)\" matInput readonly #inputElement [required]='required' (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\" [placeholder]=\"currentLabels.length>0 ? '' : placeholder\">\n\n @if (showClearIcon()) {\n <button type=\"button\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"clearValue($event)\">\n <mat-icon [svgIcon]=\"'heroicons_outline:x-mark'\"></mat-icon>\n </button>\n }\n @else {\n <mat-icon matSuffix [svgIcon]=\"'mat_outline:arrow_drop_down'\"></mat-icon>\n }\n</span>\n\n<ng-template cdk-portal #menuTemplate=\"cdkPortal\">\n <cmat-cascade-menu></cmat-cascade-menu>\n</ng-template>", styles: ["cmat-cascade-list{width:100%}.cmat-cascade-list{position:relative;display:flex;width:100%;line-height:2;align-items:center}.cmat-cascade-list mat-form-field{width:100%}.cmat-cascade-list input{cursor:pointer}.cmat-cascade-list.disabled .cascade-label{z-index:2}\n"] }]
|
|
344
|
+
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
345
|
+
type: Optional
|
|
346
|
+
}, {
|
|
347
|
+
type: Self
|
|
348
|
+
}] }, { type: i2.Overlay }, { type: i3.BreakpointObserver }, { type: i4.MatBottomSheet }, { type: i0.ChangeDetectorRef }], propDecorators: { id: [{
|
|
256
349
|
type: HostBinding,
|
|
257
350
|
args: ['attr.id']
|
|
258
351
|
}, {
|
|
259
352
|
type: Input
|
|
260
|
-
}], disabled: [{
|
|
261
|
-
type: Input
|
|
262
|
-
}], placeholder: [{
|
|
263
|
-
type: Input
|
|
264
|
-
}], label: [{
|
|
265
|
-
type: Input
|
|
266
353
|
}], options: [{
|
|
267
354
|
type: Input,
|
|
268
355
|
args: [{ required: true }]
|
|
@@ -272,18 +359,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
272
359
|
type: Input
|
|
273
360
|
}], changeOnSelect: [{
|
|
274
361
|
type: Input
|
|
275
|
-
}], model: [{
|
|
276
|
-
type: Input,
|
|
277
|
-
args: [{ required: true }]
|
|
278
|
-
}], modelChange: [{
|
|
279
|
-
type: Output
|
|
280
362
|
}], overlayOrigin: [{
|
|
281
363
|
type: ViewChild,
|
|
282
364
|
args: [CdkOverlayOrigin, { static: true }]
|
|
283
365
|
}], menuTemplate: [{
|
|
284
366
|
type: ViewChild,
|
|
285
367
|
args: ['menuTemplate', { static: true }]
|
|
368
|
+
}], _inputElement: [{
|
|
369
|
+
type: ViewChild,
|
|
370
|
+
args: ['inputElement', { static: true }]
|
|
286
371
|
}], touchUi: [{
|
|
287
372
|
type: Input
|
|
373
|
+
}], placeholder: [{
|
|
374
|
+
type: Input
|
|
375
|
+
}], value: [{
|
|
376
|
+
type: Input
|
|
377
|
+
}], required: [{
|
|
378
|
+
type: Input
|
|
379
|
+
}], disabled: [{
|
|
380
|
+
type: Input
|
|
288
381
|
}] } });
|
|
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":"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","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>"]}
|
|
382
|
+
//# 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":["/* eslint-disable @typescript-eslint/member-ordering */\r\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\r\nimport { CdkOverlayOrigin, Overlay, OverlayConfig, OverlayModule, OverlayRef } from '@angular/cdk/overlay';\r\nimport { CdkPortal, PortalModule } from '@angular/cdk/portal';\r\nimport { NgClass } from '@angular/common';\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ElementRef,\r\n    HostBinding,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    OnInit,\r\n    Optional,\r\n    Self,\r\n    SimpleChanges,\r\n    ViewChild,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\r\nimport { MatBottomSheet, MatBottomSheetRef } from '@angular/material/bottom-sheet';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatFormFieldControl } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { isUndefined } from 'lodash-es';\r\nimport { Subject } from 'rxjs';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\nimport { CmatCascadeBottomSheetComponent } from '../cascade-bottom-sheet/cascade-bottom-sheet.component';\r\nimport { CmatCascadeMenuComponent } from '../cascade-menu/cascade-menu.component';\r\nimport { CmatCascadeOptionsInterface } from '../options.interface';\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: [{ provide: MatFormFieldControl, useExisting: CmatCascadeListComponent }],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    exportAs: 'cmatCascadeList',\r\n    standalone: true,\r\n    imports: [MatIconModule, NgClass, CmatCascadeMenuComponent, MatInputModule, OverlayModule, PortalModule, MatButtonModule]\r\n})\r\nexport class CmatCascadeListComponent implements MatFormFieldControl<any>, 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    // 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    @ViewChild(CdkOverlayOrigin, { static: true }) overlayOrigin: CdkOverlayOrigin;\r\n    @ViewChild('menuTemplate', { static: true }) menuTemplate: CdkPortal;\r\n    @ViewChild('inputElement', { static: true }) private _inputElement: ElementRef<HTMLInputElement>;\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\r\n    readonly stateChanges: Subject<void> = new Subject<void>();\r\n    focused: boolean = false;\r\n    touched: boolean = false;\r\n    controlType: string = 'cmat-cascade-list';\r\n\r\n    private _unsubscribeAll: Subject<void> = new Subject<void>();\r\n    constructor(\r\n        @Optional() @Self() public ngControl: NgControl,\r\n        private _overlay: Overlay,\r\n        private _breakpointObserver: BreakpointObserver,\r\n        private _bottomSheet: MatBottomSheet,\r\n        private _changeDetectorRef: ChangeDetectorRef\r\n    ) {\r\n        if (this.ngControl != null) {\r\n            this.ngControl.valueAccessor = this;\r\n        }\r\n    }\r\n\r\n    // Whether the cascade dropdownlist UI is in touch mode.\r\n    private _touchUi = false;\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    @Input()\r\n    get placeholder(): string {\r\n        return this._placeholder;\r\n    }\r\n    set placeholder(value: string) {\r\n        this._placeholder = value;\r\n        this.stateChanges.next();\r\n    }\r\n    private _placeholder: string = '请选择';\r\n\r\n    @Input()\r\n    get value(): any {\r\n        return this._value;\r\n    }\r\n    set value(value: any) {\r\n        if (value !== this.value) {\r\n            this._value = value;\r\n            this._setInputValue();\r\n\r\n            this.stateChanges.next();\r\n\r\n            this.controlChange(value);\r\n        }\r\n    }\r\n    protected _value: any;\r\n\r\n    get empty(): boolean {\r\n        return !this._value;\r\n    }\r\n\r\n    get errorState(): boolean {\r\n        if (this.ngControl == null)\r\n            return false;\r\n\r\n        return (this.touched && this.ngControl?.invalid) ?? false;\r\n    }\r\n\r\n    get shouldLabelFloat(): boolean {\r\n        return this.focused || !this.empty;\r\n    }\r\n\r\n    @Input()\r\n    get required(): boolean { return this._required; }\r\n    set required(value: any) {\r\n        this._required = coerceBooleanProperty(value);\r\n        this.stateChanges.next();\r\n    }\r\n    protected _required = false;\r\n\r\n\r\n    @Input()\r\n    get disabled(): boolean {\r\n        if (this.ngControl && this.ngControl.disabled !== null) {\r\n            return this.ngControl.disabled;\r\n        }\r\n        return this._disabled;\r\n    }\r\n    set disabled(value: BooleanInput) {\r\n        this._disabled = coerceBooleanProperty(value);\r\n\r\n        if (this.focused) {\r\n            this.focused = false;\r\n            this.stateChanges.next();\r\n        }\r\n    }\r\n    protected _disabled = false;\r\n\r\n    onTouched: () => any = () => { };\r\n    controlChange: (value: any[] | null) => 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._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        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            if ((this.value && !this.value.length) || !this.value) {\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._init();\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.stateChanges.complete();\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.value = value;\r\n        this.steps = [];\r\n        this._init();\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    setDisabledState(isDisabled: boolean): void {\r\n        this.disabled = isDisabled;\r\n    }\r\n\r\n    setDescribedByIds(ids: string[]): void {\r\n        if (ids.length) {\r\n            this._inputElement.nativeElement.setAttribute('aria-describedby', ids.join(' '));\r\n        } else {\r\n            this._inputElement.nativeElement.removeAttribute('aria-describedby');\r\n        }\r\n    }\r\n\r\n    onContainerClick(): void {\r\n        if (!this.focused) {\r\n            this._inputElement.nativeElement.focus();\r\n        }\r\n    }\r\n\r\n    clickHandle(event: MouseEvent): void {\r\n        if (this.disabled || this.options.length === 0) {\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    clearValue(event?: Event): void {\r\n        if (event) { event.stopPropagation(); }\r\n        this.currentLabels = [];\r\n\r\n        this.steps = [];\r\n\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.value = null;\r\n\r\n        this._changeDetectorRef.markForCheck();\r\n    }\r\n\r\n\r\n    showClearIcon(): boolean {\r\n        return !!(this.clearable && this.currentLabels.length > 0 && !this.disabled);\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\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    onFocusIn(): void {\r\n        if (!this.focused) {\r\n            this.focused = true;\r\n            this.stateChanges.next();\r\n        }\r\n    }\r\n\r\n    onFocusOut(event: FocusEvent): void {\r\n        if (!this._inputElement.nativeElement.contains(event.relatedTarget as Element)) {\r\n            this.touched = true;\r\n            this.focused = false;\r\n            this.onTouched();\r\n            this.stateChanges.next();\r\n        }\r\n    }\r\n\r\n    private _initSteps(index: number, options: CmatCascadeOptionsInterface[]): void {\r\n        const step: CmatCascadeOptionsInterface[] = [];\r\n        options.map((item: CmatCascadeOptionsInterface) => {\r\n            if (this.value[index].value === 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.value.length) {\r\n            this._initSteps(index, options);\r\n        }\r\n    }\r\n\r\n    private _changeLabels(): void {\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        const next = nextValue.map((item: CmatCascadeOptionsInterface) => {\r\n            return {\r\n                value: item.value,\r\n                label: item.label\r\n            }\r\n        });\r\n\r\n        this.value = next;\r\n    }\r\n\r\n\r\n    private _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.currentLabels = [];\r\n\r\n        if (this.value && this.value.length && this.options.length > 0) {\r\n            let options: Array<CmatCascadeOptionsInterface> = this.options;\r\n\r\n            const val = this.value.map((v: any) => {\r\n                const item = options.filter((i: CmatCascadeOptionsInterface) => i.value === v.value)[0];\r\n                if (!isUndefined(item.children))\r\n                    options = item.children;\r\n                return item;\r\n            });\r\n\r\n            this.currentLabels = val.filter((v: any) => !!v);\r\n            this._setInputValue();\r\n            this._initSteps(0, this.options);\r\n        }\r\n\r\n        this._changeDetectorRef.markForCheck();\r\n    }\r\n\r\n    private _setInputValue(): void {\r\n        this._inputElement.nativeElement.value = '';\r\n        if (this.fullLevels) {\r\n            this.currentLabels.map((value, i) => {\r\n                this._inputElement.nativeElement.value += `${value.label}${i < this.currentLabels.length - 1 ? ' / ' : ''}`;\r\n            });\r\n        } else {\r\n            this._inputElement.nativeElement.value = 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  <input (click)=\"clickHandle($event)\" matInput readonly #inputElement [required]='required' (focusin)=\"onFocusIn()\"\n    (focusout)=\"onFocusOut($event)\" [placeholder]=\"currentLabels.length>0 ? '' : placeholder\">\n\n  @if (showClearIcon()) {\n  <button type=\"button\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"clearValue($event)\">\n    <mat-icon [svgIcon]=\"'heroicons_outline:x-mark'\"></mat-icon>\n  </button>\n  }\n  @else {\n  <mat-icon matSuffix [svgIcon]=\"'mat_outline:arrow_drop_down'\"></mat-icon>\n  }\n</span>\n\n<ng-template cdk-portal #menuTemplate=\"cdkPortal\">\n  <cmat-cascade-menu></cmat-cascade-menu>\n</ng-template>"]}
|