@ng-nest/ui 13.0.0 → 13.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/README.md +1 -1
- package/carousel/carousel-panel.component.d.ts +2 -3
- package/core/config/config.d.ts +4 -0
- package/date-picker/date-picker.component.d.ts +1 -1
- package/date-picker/date-picker.property.d.ts +51 -1
- package/date-picker/date-range-portal.component.d.ts +7 -5
- package/date-picker/date-range.component.d.ts +5 -1
- package/date-picker/examples/en_US/default/disabled/README.md +1 -1
- package/date-picker/examples/en_US/default/time/README.md +6 -0
- package/date-picker/examples/zh_CN/default/disabled/README.md +1 -1
- package/date-picker/examples/zh_CN/default/time/README.md +6 -0
- package/date-picker/picker-date.component.d.ts +3 -0
- package/dialog/dialog-container.component.d.ts +18 -0
- package/dialog/dialog-container.directives.d.ts +24 -0
- package/dialog/dialog-ref.d.ts +9 -0
- package/dialog/dialog.module.d.ts +13 -11
- package/dialog/dialog.property.d.ts +84 -6
- package/dialog/dialog.service.d.ts +19 -0
- package/dialog/examples/en_US/default/service/README.md +6 -0
- package/dialog/examples/zh_CN/default/service/README.md +6 -0
- package/dialog/public-api.d.ts +4 -0
- package/drawer/drawer-container.component.d.ts +18 -0
- package/drawer/drawer-container.directives.d.ts +19 -0
- package/drawer/drawer-ref.d.ts +9 -0
- package/drawer/drawer.module.d.ts +8 -6
- package/drawer/drawer.property.d.ts +83 -2
- package/drawer/drawer.service.d.ts +19 -0
- package/drawer/examples/en_US/default/service/README.md +6 -0
- package/drawer/examples/zh_CN/default/service/README.md +6 -0
- package/drawer/public-api.d.ts +5 -0
- package/esm2020/affix/affix.component.mjs +3 -3
- package/esm2020/affix/affix.module.mjs +4 -4
- package/esm2020/affix/affix.property.mjs +3 -3
- package/esm2020/alert/alert.component.mjs +5 -5
- package/esm2020/alert/alert.module.mjs +4 -4
- package/esm2020/alert/alert.property.mjs +3 -3
- package/esm2020/anchor/anchor.component.mjs +3 -3
- package/esm2020/anchor/anchor.module.mjs +4 -4
- package/esm2020/anchor/anchor.property.mjs +3 -3
- package/esm2020/api/api.component.mjs +3 -3
- package/esm2020/api/api.module.mjs +4 -4
- package/esm2020/auto-complete/auto-complete-portal.component.mjs +5 -5
- package/esm2020/auto-complete/auto-complete.component.mjs +4 -4
- package/esm2020/auto-complete/auto-complete.module.mjs +4 -4
- package/esm2020/auto-complete/auto-complete.property.mjs +3 -3
- package/esm2020/avatar/avatar.component.mjs +3 -3
- package/esm2020/avatar/avatar.module.mjs +4 -4
- package/esm2020/avatar/avatar.property.mjs +3 -3
- package/esm2020/back-top/back-top.component.mjs +3 -3
- package/esm2020/back-top/back-top.module.mjs +4 -4
- package/esm2020/back-top/back-top.property.mjs +3 -3
- package/esm2020/badge/badge.component.mjs +3 -3
- package/esm2020/badge/badge.module.mjs +4 -4
- package/esm2020/badge/badge.property.mjs +3 -3
- package/esm2020/base-form/base-form.component.mjs +3 -3
- package/esm2020/base-form/base-form.module.mjs +4 -4
- package/esm2020/base-form/base-form.property.mjs +3 -3
- package/esm2020/border/border.component.mjs +3 -3
- package/esm2020/border/border.module.mjs +4 -4
- package/esm2020/button/button.component.mjs +4 -4
- package/esm2020/button/button.module.mjs +4 -4
- package/esm2020/button/button.property.mjs +6 -6
- package/esm2020/button/buttons.component.mjs +3 -3
- package/esm2020/calendar/calendar.component.mjs +3 -3
- package/esm2020/calendar/calendar.module.mjs +4 -4
- package/esm2020/calendar/calendar.property.mjs +3 -3
- package/esm2020/card/card.component.mjs +4 -4
- package/esm2020/card/card.module.mjs +4 -4
- package/esm2020/card/card.property.mjs +3 -3
- package/esm2020/carousel/carousel-panel.component.mjs +14 -13
- package/esm2020/carousel/carousel.component.mjs +3 -3
- package/esm2020/carousel/carousel.module.mjs +4 -4
- package/esm2020/carousel/carousel.property.mjs +6 -6
- package/esm2020/cascade/cascade-portal.component.mjs +5 -5
- package/esm2020/cascade/cascade.component.mjs +4 -4
- package/esm2020/cascade/cascade.module.mjs +4 -4
- package/esm2020/cascade/cascade.property.mjs +3 -3
- package/esm2020/checkbox/checkbox.component.mjs +4 -4
- package/esm2020/checkbox/checkbox.module.mjs +4 -4
- package/esm2020/checkbox/checkbox.property.mjs +3 -3
- package/esm2020/collapse/collapse-panel.component.mjs +3 -3
- package/esm2020/collapse/collapse.component.mjs +3 -3
- package/esm2020/collapse/collapse.module.mjs +4 -4
- package/esm2020/collapse/collapse.property.mjs +6 -6
- package/esm2020/color/color.component.mjs +3 -3
- package/esm2020/color/color.module.mjs +4 -4
- package/esm2020/color/color.property.mjs +3 -3
- package/esm2020/color-picker/color-picker-portal.component.mjs +5 -5
- package/esm2020/color-picker/color-picker.component.mjs +4 -4
- package/esm2020/color-picker/color-picker.module.mjs +4 -4
- package/esm2020/color-picker/color-picker.property.mjs +3 -3
- package/esm2020/comment/comment-reply.component.mjs +3 -3
- package/esm2020/comment/comment.component.mjs +3 -3
- package/esm2020/comment/comment.module.mjs +4 -4
- package/esm2020/comment/comment.property.mjs +6 -6
- package/esm2020/container/aside.component.mjs +3 -3
- package/esm2020/container/container.component.mjs +3 -3
- package/esm2020/container/container.module.mjs +4 -4
- package/esm2020/container/container.property.mjs +12 -12
- package/esm2020/container/footer.component.mjs +4 -4
- package/esm2020/container/header.component.mjs +4 -4
- package/esm2020/container/main.component.mjs +4 -4
- package/esm2020/core/config/config.mjs +1 -1
- package/esm2020/core/config/config.service.mjs +3 -3
- package/esm2020/core/services/http.service.mjs +3 -3
- package/esm2020/core/services/preloading-strategy.service.mjs +3 -3
- package/esm2020/core/services/storage.service.mjs +3 -3
- package/esm2020/core/theme/theme.service.mjs +3 -3
- package/esm2020/crumb/crumb.component.mjs +3 -3
- package/esm2020/crumb/crumb.module.mjs +4 -4
- package/esm2020/crumb/crumb.property.mjs +3 -3
- package/esm2020/date-picker/date-picker-portal.component.mjs +6 -6
- package/esm2020/date-picker/date-picker.component.mjs +6 -10
- package/esm2020/date-picker/date-picker.module.mjs +4 -4
- package/esm2020/date-picker/date-picker.property.mjs +86 -16
- package/esm2020/date-picker/date-range-portal.component.mjs +47 -28
- package/esm2020/date-picker/date-range.component.mjs +33 -10
- package/esm2020/date-picker/picker-date.component.mjs +33 -6
- package/esm2020/date-picker/picker-month.component.mjs +3 -3
- package/esm2020/date-picker/picker-year.component.mjs +3 -3
- package/esm2020/description/description-item.component.mjs +3 -3
- package/esm2020/description/description.component.mjs +3 -3
- package/esm2020/description/description.module.mjs +4 -4
- package/esm2020/description/description.property.mjs +6 -6
- package/esm2020/dialog/dialog-container.component.mjs +52 -0
- package/esm2020/dialog/dialog-container.directives.mjs +73 -0
- package/esm2020/dialog/dialog-ref.mjs +17 -0
- package/esm2020/dialog/dialog.component.mjs +5 -5
- package/esm2020/dialog/dialog.module.mjs +39 -9
- package/esm2020/dialog/dialog.property.mjs +20 -19
- package/esm2020/dialog/dialog.service.mjs +67 -0
- package/esm2020/dialog/public-api.mjs +5 -1
- package/esm2020/doc/doc.component.mjs +4 -4
- package/esm2020/doc/doc.module.mjs +4 -4
- package/esm2020/drawer/drawer-container.component.mjs +52 -0
- package/esm2020/drawer/drawer-container.directives.mjs +57 -0
- package/esm2020/drawer/drawer-ref.mjs +17 -0
- package/esm2020/drawer/drawer.component.mjs +5 -5
- package/esm2020/drawer/drawer.module.mjs +24 -8
- package/esm2020/drawer/drawer.property.mjs +24 -8
- package/esm2020/drawer/drawer.service.mjs +65 -0
- package/esm2020/drawer/public-api.mjs +6 -1
- package/esm2020/dropdown/dropdown-portal.component.mjs +3 -3
- package/esm2020/dropdown/dropdown.component.mjs +3 -3
- package/esm2020/dropdown/dropdown.module.mjs +4 -4
- package/esm2020/dropdown/dropdown.property.mjs +3 -3
- package/esm2020/empty/empty.component.mjs +3 -3
- package/esm2020/empty/empty.module.mjs +4 -4
- package/esm2020/empty/empty.property.mjs +3 -3
- package/esm2020/examples/examples.component.mjs +3 -3
- package/esm2020/examples/examples.module.mjs +4 -4
- package/esm2020/find/find.component.mjs +4 -4
- package/esm2020/find/find.module.mjs +4 -4
- package/esm2020/find/find.property.mjs +3 -3
- package/esm2020/form/control.component.mjs +3 -3
- package/esm2020/form/form.component.mjs +3 -3
- package/esm2020/form/form.module.mjs +4 -4
- package/esm2020/form/form.property.mjs +6 -6
- package/esm2020/highlight/highlight.component.mjs +3 -3
- package/esm2020/highlight/highlight.module.mjs +4 -4
- package/esm2020/highlight/highlight.property.mjs +3 -3
- package/esm2020/i18n/i18n.directive.mjs +3 -3
- package/esm2020/i18n/i18n.module.mjs +4 -4
- package/esm2020/i18n/i18n.pipe.mjs +3 -3
- package/esm2020/i18n/i18n.service.mjs +3 -3
- package/esm2020/icon/icon.component.mjs +3 -3
- package/esm2020/icon/icon.module.mjs +4 -4
- package/esm2020/icon/icon.property.mjs +3 -3
- package/esm2020/icon/icon.service.mjs +3 -3
- package/esm2020/inner/inner.component.mjs +3 -3
- package/esm2020/inner/inner.module.mjs +4 -4
- package/esm2020/inner/inner.property.mjs +3 -3
- package/esm2020/input/input-group.component.mjs +3 -3
- package/esm2020/input/input.component.mjs +8 -5
- package/esm2020/input/input.module.mjs +4 -4
- package/esm2020/input/input.property.mjs +6 -6
- package/esm2020/input-number/input-number.component.mjs +3 -3
- package/esm2020/input-number/input-number.module.mjs +4 -4
- package/esm2020/input-number/input-number.property.mjs +3 -3
- package/esm2020/layout/col.component.mjs +3 -3
- package/esm2020/layout/layout.module.mjs +4 -4
- package/esm2020/layout/layout.property.mjs +6 -6
- package/esm2020/layout/row.component.mjs +3 -3
- package/esm2020/link/link.component.mjs +3 -3
- package/esm2020/link/link.module.mjs +4 -4
- package/esm2020/link/link.property.mjs +3 -3
- package/esm2020/list/list-option.component.mjs +3 -3
- package/esm2020/list/list.component.mjs +3 -3
- package/esm2020/list/list.module.mjs +4 -4
- package/esm2020/list/list.property.mjs +6 -6
- package/esm2020/loading/loading.component.mjs +3 -3
- package/esm2020/loading/loading.module.mjs +4 -4
- package/esm2020/loading/loading.property.mjs +3 -3
- package/esm2020/menu/menu-node.component.mjs +3 -3
- package/esm2020/menu/menu.component.mjs +5 -5
- package/esm2020/menu/menu.module.mjs +4 -4
- package/esm2020/menu/menu.property.mjs +6 -6
- package/esm2020/message/message.component.mjs +3 -3
- package/esm2020/message/message.module.mjs +4 -4
- package/esm2020/message/message.property.mjs +2 -2
- package/esm2020/message/message.service.mjs +6 -6
- package/esm2020/message-box/message-box.component.mjs +3 -3
- package/esm2020/message-box/message-box.module.mjs +4 -4
- package/esm2020/message-box/message-box.service.mjs +3 -3
- package/esm2020/notification/notification.component.mjs +3 -3
- package/esm2020/notification/notification.module.mjs +4 -4
- package/esm2020/notification/notification.service.mjs +3 -3
- package/esm2020/outlet/outlet.directive.mjs +3 -3
- package/esm2020/outlet/outlet.module.mjs +4 -4
- package/esm2020/page-header/page-header.component.mjs +3 -3
- package/esm2020/page-header/page-header.module.mjs +4 -4
- package/esm2020/page-header/page-header.property.mjs +3 -3
- package/esm2020/pagination/pagination.component.mjs +4 -4
- package/esm2020/pagination/pagination.module.mjs +4 -4
- package/esm2020/pagination/pagination.property.mjs +3 -3
- package/esm2020/pattern/pattern.component.mjs +3 -3
- package/esm2020/pattern/pattern.module.mjs +4 -4
- package/esm2020/popconfirm/popconfirm.component.mjs +3 -3
- package/esm2020/popconfirm/popconfirm.module.mjs +4 -4
- package/esm2020/popconfirm/popconfirm.property.mjs +3 -3
- package/esm2020/popover/popover-portal.component.mjs +3 -3
- package/esm2020/popover/popover.directive.mjs +3 -3
- package/esm2020/popover/popover.module.mjs +4 -4
- package/esm2020/popover/popover.property.mjs +3 -3
- package/esm2020/portal/portal.module.mjs +6 -5
- package/esm2020/portal/portal.service.mjs +11 -12
- package/esm2020/progress/progress.component.mjs +179 -18
- package/esm2020/progress/progress.module.mjs +4 -4
- package/esm2020/progress/progress.property.mjs +52 -5
- package/esm2020/radio/radio.component.mjs +4 -4
- package/esm2020/radio/radio.module.mjs +4 -4
- package/esm2020/radio/radio.property.mjs +3 -3
- package/esm2020/rate/rate.component.mjs +4 -4
- package/esm2020/rate/rate.module.mjs +4 -4
- package/esm2020/rate/rate.property.mjs +3 -3
- package/esm2020/result/result.component.mjs +4 -4
- package/esm2020/result/result.module.mjs +4 -4
- package/esm2020/result/result.property.mjs +3 -3
- package/esm2020/ripple/ripple.directive.mjs +3 -3
- package/esm2020/ripple/ripple.module.mjs +4 -4
- package/esm2020/ripple/ripple.property.mjs +3 -3
- package/esm2020/select/select-portal.component.mjs +5 -5
- package/esm2020/select/select.component.mjs +4 -4
- package/esm2020/select/select.module.mjs +4 -4
- package/esm2020/select/select.property.mjs +3 -3
- package/esm2020/skeleton/skeleton.component.mjs +3 -3
- package/esm2020/skeleton/skeleton.module.mjs +4 -4
- package/esm2020/skeleton/skeleton.property.mjs +3 -3
- package/esm2020/slider/slider.component.mjs +3 -3
- package/esm2020/slider/slider.module.mjs +4 -4
- package/esm2020/slider/slider.property.mjs +3 -3
- package/esm2020/slider-select/slider-select.component.mjs +4 -4
- package/esm2020/slider-select/slider-select.module.mjs +4 -4
- package/esm2020/slider-select/slider-select.property.mjs +3 -3
- package/esm2020/statistic/countdown.component.mjs +3 -3
- package/esm2020/statistic/statistic.component.mjs +3 -3
- package/esm2020/statistic/statistic.module.mjs +4 -4
- package/esm2020/statistic/statistic.property.mjs +6 -6
- package/esm2020/steps/steps.component.mjs +18 -11
- package/esm2020/steps/steps.module.mjs +4 -4
- package/esm2020/steps/steps.property.mjs +10 -5
- package/esm2020/switch/switch.component.mjs +4 -4
- package/esm2020/switch/switch.module.mjs +4 -4
- package/esm2020/switch/switch.property.mjs +3 -3
- package/esm2020/table/drag.directive.mjs +3 -3
- package/esm2020/table/table-body.component.mjs +3 -3
- package/esm2020/table/table-foot.component.mjs +3 -3
- package/esm2020/table/table-head.component.mjs +3 -3
- package/esm2020/table/table.component.mjs +3 -3
- package/esm2020/table/table.module.mjs +4 -4
- package/esm2020/table/table.property.mjs +13 -13
- package/esm2020/tabs/tab-content.component.mjs +3 -3
- package/esm2020/tabs/tab.component.mjs +3 -3
- package/esm2020/tabs/tabs.component.mjs +3 -3
- package/esm2020/tabs/tabs.module.mjs +4 -4
- package/esm2020/tabs/tabs.property.mjs +6 -6
- package/esm2020/tag/tag.component.mjs +4 -4
- package/esm2020/tag/tag.module.mjs +4 -4
- package/esm2020/tag/tag.property.mjs +3 -3
- package/esm2020/text-retract/text-retract.component.mjs +3 -3
- package/esm2020/text-retract/text-retract.module.mjs +4 -4
- package/esm2020/text-retract/text-retract.property.mjs +3 -3
- package/esm2020/textarea/textarea.component.mjs +4 -4
- package/esm2020/textarea/textarea.module.mjs +4 -4
- package/esm2020/textarea/textarea.property.mjs +3 -3
- package/esm2020/theme/theme.component.mjs +3 -3
- package/esm2020/theme/theme.module.mjs +4 -4
- package/esm2020/theme/theme.property.mjs +3 -3
- package/esm2020/time-ago/time-ago.module.mjs +4 -4
- package/esm2020/time-ago/time-ago.pipe.mjs +3 -3
- package/esm2020/time-picker/time-picker-frame.component.mjs +11 -8
- package/esm2020/time-picker/time-picker-portal.component.mjs +3 -3
- package/esm2020/time-picker/time-picker.component.mjs +27 -14
- package/esm2020/time-picker/time-picker.module.mjs +4 -4
- package/esm2020/time-picker/time-picker.property.mjs +3 -3
- package/esm2020/time-range/time-range.module.mjs +4 -4
- package/esm2020/time-range/time-range.pipe.mjs +3 -3
- package/esm2020/timeline/timeline.component.mjs +3 -3
- package/esm2020/timeline/timeline.module.mjs +4 -4
- package/esm2020/timeline/timeline.property.mjs +3 -3
- package/esm2020/tooltip/tooltip-portal.component.mjs +3 -3
- package/esm2020/tooltip/tooltip.directive.mjs +3 -3
- package/esm2020/tooltip/tooltip.module.mjs +4 -4
- package/esm2020/tooltip/tooltip.property.mjs +3 -3
- package/esm2020/transfer/transfer.component.mjs +3 -3
- package/esm2020/transfer/transfer.module.mjs +4 -4
- package/esm2020/transfer/transfer.property.mjs +3 -3
- package/esm2020/tree/tree-node.component.mjs +3 -3
- package/esm2020/tree/tree.component.mjs +3 -3
- package/esm2020/tree/tree.module.mjs +4 -4
- package/esm2020/tree/tree.property.mjs +6 -6
- package/esm2020/tree-file/tree-file.component.mjs +4 -4
- package/esm2020/tree-file/tree-file.module.mjs +4 -4
- package/esm2020/tree-file/tree-file.property.mjs +3 -3
- package/esm2020/typography/typography.component.mjs +3 -3
- package/esm2020/typography/typography.module.mjs +4 -4
- package/esm2020/typography/typography.property.mjs +3 -3
- package/esm2020/upload/upload-portal.component.mjs +4 -4
- package/esm2020/upload/upload.component.mjs +3 -3
- package/esm2020/upload/upload.module.mjs +4 -4
- package/esm2020/upload/upload.property.mjs +3 -3
- package/fesm2015/ng-nest-ui-affix.mjs +10 -10
- package/fesm2015/ng-nest-ui-alert.mjs +12 -11
- package/fesm2015/ng-nest-ui-alert.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-anchor.mjs +10 -10
- package/fesm2015/ng-nest-ui-api.mjs +7 -7
- package/fesm2015/ng-nest-ui-auto-complete.mjs +16 -15
- package/fesm2015/ng-nest-ui-auto-complete.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-avatar.mjs +11 -10
- package/fesm2015/ng-nest-ui-back-top.mjs +10 -10
- package/fesm2015/ng-nest-ui-badge.mjs +11 -10
- package/fesm2015/ng-nest-ui-base-form.mjs +11 -10
- package/fesm2015/ng-nest-ui-border.mjs +8 -7
- package/fesm2015/ng-nest-ui-button.mjs +18 -17
- package/fesm2015/ng-nest-ui-calendar.mjs +11 -10
- package/fesm2015/ng-nest-ui-card.mjs +12 -11
- package/fesm2015/ng-nest-ui-carousel.mjs +27 -26
- package/fesm2015/ng-nest-ui-carousel.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-cascade.mjs +16 -15
- package/fesm2015/ng-nest-ui-cascade.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-checkbox.mjs +12 -11
- package/fesm2015/ng-nest-ui-collapse.mjs +17 -16
- package/fesm2015/ng-nest-ui-color-picker.mjs +16 -15
- package/fesm2015/ng-nest-ui-color-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-color.mjs +11 -10
- package/fesm2015/ng-nest-ui-comment.mjs +17 -16
- package/fesm2015/ng-nest-ui-container.mjs +35 -34
- package/fesm2015/ng-nest-ui-core.mjs +16 -15
- package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-crumb.mjs +11 -10
- package/fesm2015/ng-nest-ui-date-picker.mjs +216 -80
- package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-description.mjs +17 -16
- package/fesm2015/ng-nest-ui-dialog.mjs +258 -33
- package/fesm2015/ng-nest-ui-dialog.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-doc.mjs +8 -8
- package/fesm2015/ng-nest-ui-drawer.mjs +227 -20
- package/fesm2015/ng-nest-ui-drawer.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-dropdown.mjs +13 -13
- package/fesm2015/ng-nest-ui-empty.mjs +11 -10
- package/fesm2015/ng-nest-ui-examples.mjs +7 -7
- package/fesm2015/ng-nest-ui-find.mjs +12 -11
- package/fesm2015/ng-nest-ui-form.mjs +17 -16
- package/fesm2015/ng-nest-ui-highlight.mjs +11 -10
- package/fesm2015/ng-nest-ui-i18n.mjs +14 -13
- package/fesm2015/ng-nest-ui-icon.mjs +14 -13
- package/fesm2015/ng-nest-ui-inner.mjs +10 -10
- package/fesm2015/ng-nest-ui-input-number.mjs +11 -10
- package/fesm2015/ng-nest-ui-input.mjs +21 -17
- package/fesm2015/ng-nest-ui-input.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-layout.mjs +17 -16
- package/fesm2015/ng-nest-ui-link.mjs +11 -10
- package/fesm2015/ng-nest-ui-list.mjs +17 -16
- package/fesm2015/ng-nest-ui-loading.mjs +11 -10
- package/fesm2015/ng-nest-ui-menu.mjs +17 -17
- package/fesm2015/ng-nest-ui-menu.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-message-box.mjs +10 -10
- package/fesm2015/ng-nest-ui-message.mjs +14 -13
- package/fesm2015/ng-nest-ui-message.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-notification.mjs +10 -10
- package/fesm2015/ng-nest-ui-outlet.mjs +8 -7
- package/fesm2015/ng-nest-ui-page-header.mjs +10 -10
- package/fesm2015/ng-nest-ui-pagination.mjs +12 -11
- package/fesm2015/ng-nest-ui-pattern.mjs +7 -7
- package/fesm2015/ng-nest-ui-popconfirm.mjs +10 -10
- package/fesm2015/ng-nest-ui-popover.mjs +13 -13
- package/fesm2015/ng-nest-ui-portal.mjs +16 -15
- package/fesm2015/ng-nest-ui-portal.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-progress.mjs +235 -26
- package/fesm2015/ng-nest-ui-progress.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-radio.mjs +12 -11
- package/fesm2015/ng-nest-ui-rate.mjs +12 -11
- package/fesm2015/ng-nest-ui-result.mjs +11 -11
- package/fesm2015/ng-nest-ui-ripple.mjs +11 -10
- package/fesm2015/ng-nest-ui-select.mjs +16 -15
- package/fesm2015/ng-nest-ui-select.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-skeleton.mjs +10 -10
- package/fesm2015/ng-nest-ui-slider-select.mjs +12 -11
- package/fesm2015/ng-nest-ui-slider.mjs +11 -10
- package/fesm2015/ng-nest-ui-statistic.mjs +17 -16
- package/fesm2015/ng-nest-ui-steps.mjs +30 -18
- package/fesm2015/ng-nest-ui-steps.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-switch.mjs +12 -11
- package/fesm2015/ng-nest-ui-table.mjs +32 -31
- package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tabs.mjs +20 -19
- package/fesm2015/ng-nest-ui-tag.mjs +12 -11
- package/fesm2015/ng-nest-ui-text-retract.mjs +11 -10
- package/fesm2015/ng-nest-ui-textarea.mjs +12 -11
- package/fesm2015/ng-nest-ui-theme.mjs +11 -10
- package/fesm2015/ng-nest-ui-time-ago.mjs +8 -7
- package/fesm2015/ng-nest-ui-time-picker.mjs +47 -30
- package/fesm2015/ng-nest-ui-time-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-time-range.mjs +8 -7
- package/fesm2015/ng-nest-ui-timeline.mjs +11 -10
- package/fesm2015/ng-nest-ui-tooltip.mjs +14 -13
- package/fesm2015/ng-nest-ui-transfer.mjs +10 -10
- package/fesm2015/ng-nest-ui-tree-file.mjs +12 -11
- package/fesm2015/ng-nest-ui-tree.mjs +17 -16
- package/fesm2015/ng-nest-ui-typography.mjs +11 -10
- package/fesm2015/ng-nest-ui-upload.mjs +14 -14
- package/fesm2020/ng-nest-ui-affix.mjs +10 -10
- package/fesm2020/ng-nest-ui-alert.mjs +12 -11
- package/fesm2020/ng-nest-ui-alert.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-anchor.mjs +10 -10
- package/fesm2020/ng-nest-ui-api.mjs +7 -7
- package/fesm2020/ng-nest-ui-auto-complete.mjs +16 -15
- package/fesm2020/ng-nest-ui-auto-complete.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-avatar.mjs +11 -10
- package/fesm2020/ng-nest-ui-back-top.mjs +10 -10
- package/fesm2020/ng-nest-ui-badge.mjs +11 -10
- package/fesm2020/ng-nest-ui-base-form.mjs +11 -10
- package/fesm2020/ng-nest-ui-border.mjs +8 -7
- package/fesm2020/ng-nest-ui-button.mjs +18 -17
- package/fesm2020/ng-nest-ui-calendar.mjs +11 -10
- package/fesm2020/ng-nest-ui-card.mjs +12 -11
- package/fesm2020/ng-nest-ui-carousel.mjs +27 -25
- package/fesm2020/ng-nest-ui-carousel.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-cascade.mjs +16 -15
- package/fesm2020/ng-nest-ui-cascade.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-checkbox.mjs +12 -11
- package/fesm2020/ng-nest-ui-collapse.mjs +17 -16
- package/fesm2020/ng-nest-ui-color-picker.mjs +16 -15
- package/fesm2020/ng-nest-ui-color-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-color.mjs +11 -10
- package/fesm2020/ng-nest-ui-comment.mjs +17 -16
- package/fesm2020/ng-nest-ui-container.mjs +35 -34
- package/fesm2020/ng-nest-ui-core.mjs +16 -15
- package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-crumb.mjs +11 -10
- package/fesm2020/ng-nest-ui-date-picker.mjs +216 -80
- package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-description.mjs +17 -16
- package/fesm2020/ng-nest-ui-dialog.mjs +256 -33
- package/fesm2020/ng-nest-ui-dialog.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-doc.mjs +8 -8
- package/fesm2020/ng-nest-ui-drawer.mjs +225 -20
- package/fesm2020/ng-nest-ui-drawer.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-dropdown.mjs +13 -13
- package/fesm2020/ng-nest-ui-empty.mjs +11 -10
- package/fesm2020/ng-nest-ui-examples.mjs +7 -7
- package/fesm2020/ng-nest-ui-find.mjs +12 -11
- package/fesm2020/ng-nest-ui-form.mjs +17 -16
- package/fesm2020/ng-nest-ui-highlight.mjs +11 -10
- package/fesm2020/ng-nest-ui-i18n.mjs +14 -13
- package/fesm2020/ng-nest-ui-icon.mjs +14 -13
- package/fesm2020/ng-nest-ui-inner.mjs +10 -10
- package/fesm2020/ng-nest-ui-input-number.mjs +11 -10
- package/fesm2020/ng-nest-ui-input.mjs +21 -17
- package/fesm2020/ng-nest-ui-input.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-layout.mjs +17 -16
- package/fesm2020/ng-nest-ui-link.mjs +11 -10
- package/fesm2020/ng-nest-ui-list.mjs +17 -16
- package/fesm2020/ng-nest-ui-loading.mjs +11 -10
- package/fesm2020/ng-nest-ui-menu.mjs +17 -17
- package/fesm2020/ng-nest-ui-menu.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-message-box.mjs +10 -10
- package/fesm2020/ng-nest-ui-message.mjs +14 -13
- package/fesm2020/ng-nest-ui-message.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-notification.mjs +10 -10
- package/fesm2020/ng-nest-ui-outlet.mjs +8 -7
- package/fesm2020/ng-nest-ui-page-header.mjs +10 -10
- package/fesm2020/ng-nest-ui-pagination.mjs +12 -11
- package/fesm2020/ng-nest-ui-pattern.mjs +7 -7
- package/fesm2020/ng-nest-ui-popconfirm.mjs +10 -10
- package/fesm2020/ng-nest-ui-popover.mjs +13 -13
- package/fesm2020/ng-nest-ui-portal.mjs +16 -15
- package/fesm2020/ng-nest-ui-portal.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-progress.mjs +234 -25
- package/fesm2020/ng-nest-ui-progress.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-radio.mjs +12 -11
- package/fesm2020/ng-nest-ui-rate.mjs +12 -11
- package/fesm2020/ng-nest-ui-result.mjs +11 -11
- package/fesm2020/ng-nest-ui-ripple.mjs +11 -10
- package/fesm2020/ng-nest-ui-select.mjs +16 -15
- package/fesm2020/ng-nest-ui-select.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-skeleton.mjs +10 -10
- package/fesm2020/ng-nest-ui-slider-select.mjs +12 -11
- package/fesm2020/ng-nest-ui-slider.mjs +11 -10
- package/fesm2020/ng-nest-ui-statistic.mjs +17 -16
- package/fesm2020/ng-nest-ui-steps.mjs +30 -18
- package/fesm2020/ng-nest-ui-steps.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-switch.mjs +12 -11
- package/fesm2020/ng-nest-ui-table.mjs +32 -31
- package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tabs.mjs +20 -19
- package/fesm2020/ng-nest-ui-tag.mjs +12 -11
- package/fesm2020/ng-nest-ui-text-retract.mjs +11 -10
- package/fesm2020/ng-nest-ui-textarea.mjs +12 -11
- package/fesm2020/ng-nest-ui-theme.mjs +11 -10
- package/fesm2020/ng-nest-ui-time-ago.mjs +8 -7
- package/fesm2020/ng-nest-ui-time-picker.mjs +47 -30
- package/fesm2020/ng-nest-ui-time-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-time-range.mjs +8 -7
- package/fesm2020/ng-nest-ui-timeline.mjs +11 -10
- package/fesm2020/ng-nest-ui-tooltip.mjs +14 -13
- package/fesm2020/ng-nest-ui-transfer.mjs +10 -10
- package/fesm2020/ng-nest-ui-tree-file.mjs +12 -11
- package/fesm2020/ng-nest-ui-tree.mjs +17 -16
- package/fesm2020/ng-nest-ui-typography.mjs +11 -10
- package/fesm2020/ng-nest-ui-upload.mjs +14 -14
- package/layout/examples/en_US/default/flex/README.md +1 -1
- package/layout/examples/zh_CN/default/flex/README.md +1 -1
- package/message/message.property.d.ts +1 -1
- package/package.json +7 -7
- package/portal/portal.module.d.ts +1 -1
- package/portal/portal.service.d.ts +2 -3
- package/progress/examples/en_US/default/circle/README.md +6 -0
- package/progress/examples/en_US/default/dashboard/README.md +6 -0
- package/progress/examples/en_US/default/gradient/README.md +6 -0
- package/progress/examples/en_US/default/steps/README.md +6 -0
- package/progress/examples/en_US/default/subsection/README.md +6 -0
- package/progress/examples/zh_CN/default/circle/README.md +6 -0
- package/progress/examples/zh_CN/default/dashboard/README.md +6 -0
- package/progress/examples/zh_CN/default/gradient/README.md +6 -0
- package/progress/examples/zh_CN/default/steps/README.md +6 -0
- package/progress/examples/zh_CN/default/subsection/README.md +6 -0
- package/progress/progress.component.d.ts +31 -3
- package/progress/progress.property.d.ts +80 -5
- package/steps/examples/en_US/default/node-status/README.md +6 -0
- package/steps/examples/zh_CN/default/node-status/README.md +6 -0
- package/steps/steps.property.d.ts +7 -2
- package/style/core/index.scss +1 -0
- package/table/table.property.d.ts +1 -1
- package/time-picker/time-picker-frame.component.d.ts +1 -0
- package/time-picker/time-picker.component.d.ts +3 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, ViewEncapsulation, ChangeDetectionStrategy, HostBinding, HostListener } from '@angular/core';
|
|
2
2
|
import { XDateRangePortalPrefix } from './date-picker.property';
|
|
3
|
-
import { XIsEmpty, XConnectBaseAnimation,
|
|
3
|
+
import { XIsEmpty, XConnectBaseAnimation, XAddMonths, XAddYears } from '@ng-nest/ui/core';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
5
|
import { takeUntil, map } from 'rxjs/operators';
|
|
6
6
|
import { DatePipe, LowerCasePipe } from '@angular/common';
|
|
@@ -40,6 +40,10 @@ export class XDateRangePortalComponent {
|
|
|
40
40
|
this.placement = x;
|
|
41
41
|
this.cdr.detectChanges();
|
|
42
42
|
});
|
|
43
|
+
this.inputActiveChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {
|
|
44
|
+
this.activeType = x;
|
|
45
|
+
this.setDefault();
|
|
46
|
+
});
|
|
43
47
|
this.i18n.localeChange
|
|
44
48
|
.pipe(map((x) => x.datePicker), takeUntil(this._unSubject))
|
|
45
49
|
.subscribe((x) => {
|
|
@@ -63,50 +67,65 @@ export class XDateRangePortalComponent {
|
|
|
63
67
|
this.model = this.display;
|
|
64
68
|
this.startModel = this.model;
|
|
65
69
|
this.endModel = XAddMonths(this.model, 1);
|
|
70
|
+
this.setDisplay(this.model);
|
|
66
71
|
}
|
|
67
|
-
this.time = this.model.getTime();
|
|
68
72
|
this._type = this.type;
|
|
69
|
-
this.setDisplay(this.model);
|
|
70
73
|
this.cdr.detectChanges();
|
|
71
74
|
}
|
|
72
75
|
stopPropagation(event) {
|
|
73
76
|
event.stopPropagation();
|
|
74
77
|
}
|
|
75
78
|
setDefault() {
|
|
76
|
-
const
|
|
77
|
-
|
|
78
|
-
if (this.value.length > 0) {
|
|
79
|
+
const type = this.activeType || 'start';
|
|
80
|
+
if (type === 'start') {
|
|
79
81
|
this.startModel = new Date(this.value[0]);
|
|
80
82
|
this.startDisplay = this.startModel;
|
|
83
|
+
this.endModel = XAddMonths(this.startModel, 1);
|
|
84
|
+
this.endDisplay = this.endModel;
|
|
81
85
|
}
|
|
82
|
-
if (
|
|
86
|
+
else if (type === 'end') {
|
|
83
87
|
this.endModel = new Date(this.value[1]);
|
|
84
88
|
this.endDisplay = this.endModel;
|
|
89
|
+
this.startModel = XAddMonths(this.endModel, -1);
|
|
90
|
+
this.startDisplay = this.startModel;
|
|
85
91
|
}
|
|
92
|
+
this.cdr.detectChanges();
|
|
86
93
|
}
|
|
87
94
|
setDisplay(date) {
|
|
88
95
|
this.display = new Date(date.getFullYear(), date.getMonth(), 1);
|
|
89
96
|
this.startDisplay = this.display;
|
|
90
97
|
this.endDisplay = XAddMonths(this.display, 1);
|
|
91
98
|
}
|
|
92
|
-
dateChange(date) {
|
|
99
|
+
dateChange(date, type) {
|
|
93
100
|
let time = date.getTime();
|
|
94
101
|
if (this.value.length === 0) {
|
|
95
|
-
this.value
|
|
102
|
+
this.value = [time];
|
|
96
103
|
this.startNodeEmit(date);
|
|
97
104
|
}
|
|
98
105
|
else if (this.value.length === 1) {
|
|
99
106
|
if (time > this.value[0]) {
|
|
100
|
-
this.value.
|
|
107
|
+
this.value = [...this.value, time];
|
|
101
108
|
this.endNodeEmit(date);
|
|
102
109
|
}
|
|
103
110
|
else {
|
|
104
|
-
this.value.
|
|
111
|
+
this.value = [time, ...this.value];
|
|
105
112
|
this.startNodeEmit(date);
|
|
106
113
|
this.endNodeEmit(new Date(this.value[1]));
|
|
107
114
|
}
|
|
108
115
|
this.nodeEmit(this.value.map((x) => new Date(x)));
|
|
109
116
|
}
|
|
117
|
+
else {
|
|
118
|
+
if (type === 'start') {
|
|
119
|
+
this.value = [time, this.value[1]];
|
|
120
|
+
this.startNodeEmit(date);
|
|
121
|
+
}
|
|
122
|
+
else if (type === 'end') {
|
|
123
|
+
this.value = [this.value[0], time];
|
|
124
|
+
this.cdr.detectChanges();
|
|
125
|
+
this.endNodeEmit(date);
|
|
126
|
+
}
|
|
127
|
+
this.nodeEmit(this.value.map((x) => new Date(x)), type !== 'start');
|
|
128
|
+
}
|
|
110
129
|
}
|
|
111
130
|
typeChange(type) {
|
|
112
131
|
this.type = type;
|
|
@@ -160,18 +179,6 @@ export class XDateRangePortalComponent {
|
|
|
160
179
|
getLocaleMonth(date) {
|
|
161
180
|
return this.locale[this.lowerCasePipe.transform(this.datePipe.transform(date, 'LLLL'))];
|
|
162
181
|
}
|
|
163
|
-
onToday() {
|
|
164
|
-
this.dateChange(new Date());
|
|
165
|
-
}
|
|
166
|
-
onYesterday() {
|
|
167
|
-
this.dateChange(XAddDays(new Date(), -1));
|
|
168
|
-
}
|
|
169
|
-
onTomorrow() {
|
|
170
|
-
this.dateChange(XAddDays(new Date(), 1));
|
|
171
|
-
}
|
|
172
|
-
onPresetFunc(item) {
|
|
173
|
-
this.dateChange(item.func());
|
|
174
|
-
}
|
|
175
182
|
selectTime(time) {
|
|
176
183
|
this.time = time.getTime();
|
|
177
184
|
// this.nodeEmit(this.setModel(this.model, time), false);
|
|
@@ -181,12 +188,24 @@ export class XDateRangePortalComponent {
|
|
|
181
188
|
this.model = new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes(), time.getSeconds());
|
|
182
189
|
return this.model;
|
|
183
190
|
}
|
|
191
|
+
startYearChange(num) {
|
|
192
|
+
this.endDisplay = XAddYears(this.endDisplay, num);
|
|
193
|
+
}
|
|
194
|
+
endYearChange(num) {
|
|
195
|
+
this.startDisplay = XAddYears(this.startDisplay, num);
|
|
196
|
+
}
|
|
197
|
+
startMonthChange(num) {
|
|
198
|
+
this.endDisplay = XAddMonths(this.endDisplay, num);
|
|
199
|
+
}
|
|
200
|
+
endMonthChange(num) {
|
|
201
|
+
this.startDisplay = XAddMonths(this.startDisplay, num);
|
|
202
|
+
}
|
|
184
203
|
}
|
|
185
|
-
/** @nocollapse */ /** @nocollapse */ XDateRangePortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.
|
|
186
|
-
/** @nocollapse */ /** @nocollapse */ XDateRangePortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.
|
|
187
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.
|
|
204
|
+
/** @nocollapse */ /** @nocollapse */ XDateRangePortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: XDateRangePortalComponent, deps: [{ token: i1.DatePipe }, { token: i1.LowerCasePipe }, { token: i0.ChangeDetectorRef }, { token: i2.XI18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
205
|
+
/** @nocollapse */ /** @nocollapse */ XDateRangePortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: XDateRangePortalComponent, selector: "x-date-range-portal", host: { listeners: { "@x-connect-base-animation.done": "done($event)", "@x-connect-base-animation.start": "start($event)" }, properties: { "@x-connect-base-animation": "this.placement" } }, providers: [DatePipe, LowerCasePipe], ngImport: i0, template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-body\">\r\n <x-picker-date\r\n class=\"x-date-range-portal-start\"\r\n [(display)]=\"startDisplay\"\r\n [model]=\"startModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [nextYearBtn]=\"false\"\r\n [nextMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'start')\"\r\n (yearChange)=\"startYearChange($event)\"\r\n (monthChange)=\"startMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n <x-picker-date\r\n class=\"x-date-range-portal-end\"\r\n [(display)]=\"endDisplay\"\r\n [model]=\"endModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [lastYearBtn]=\"false\"\r\n [lastMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'end')\"\r\n (yearChange)=\"endYearChange($event)\"\r\n (monthChange)=\"endMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-range-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:34rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-range-portal.date-time{width:27rem}.x-date-range-portal.date-hour{width:19.75rem}.x-date-range-portal.date-minute{width:23.375rem}.x-date-range-portal-content{display:flex}.x-date-range-portal-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset>x-button{flex:1}.x-date-range-portal-year-month{flex:1;text-align:center}.x-date-range-portal-body{display:flex}.x-date-range-portal-start,.x-date-range-portal-end{flex:1}.x-date-range-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-range-portal-date{flex:1}.x-date-range-portal-time{display:flex;flex-direction:column}.x-date-range-portal-time-label{padding:.4rem;text-align:center;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-range-portal-time .x-time-picker-frame{border-width:var(--x-border-width) 0 0 var(--x-border-width);box-shadow:none}\n"], components: [{ type: i3.XPickerDateComponent, selector: "x-picker-date" }, { type: i4.XButtonComponent, selector: "x-button" }], directives: [{ type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], pipes: { "date": i1.DatePipe }, animations: [XConnectBaseAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
206
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: XDateRangePortalComponent, decorators: [{
|
|
188
207
|
type: Component,
|
|
189
|
-
args: [{ selector: `${XDateRangePortalPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XConnectBaseAnimation], providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-
|
|
208
|
+
args: [{ selector: `${XDateRangePortalPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XConnectBaseAnimation], providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-body\">\r\n <x-picker-date\r\n class=\"x-date-range-portal-start\"\r\n [(display)]=\"startDisplay\"\r\n [model]=\"startModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [nextYearBtn]=\"false\"\r\n [nextMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'start')\"\r\n (yearChange)=\"startYearChange($event)\"\r\n (monthChange)=\"startMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n <x-picker-date\r\n class=\"x-date-range-portal-end\"\r\n [(display)]=\"endDisplay\"\r\n [model]=\"endModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [lastYearBtn]=\"false\"\r\n [lastMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'end')\"\r\n (yearChange)=\"endYearChange($event)\"\r\n (monthChange)=\"endMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-range-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:34rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-range-portal.date-time{width:27rem}.x-date-range-portal.date-hour{width:19.75rem}.x-date-range-portal.date-minute{width:23.375rem}.x-date-range-portal-content{display:flex}.x-date-range-portal-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset>x-button{flex:1}.x-date-range-portal-year-month{flex:1;text-align:center}.x-date-range-portal-body{display:flex}.x-date-range-portal-start,.x-date-range-portal-end{flex:1}.x-date-range-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-range-portal-date{flex:1}.x-date-range-portal-time{display:flex;flex-direction:column}.x-date-range-portal-time-label{padding:.4rem;text-align:center;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-range-portal-time .x-time-picker-frame{border-width:var(--x-border-width) 0 0 var(--x-border-width);box-shadow:none}\n"] }]
|
|
190
209
|
}], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i1.LowerCasePipe }, { type: i0.ChangeDetectorRef }, { type: i2.XI18nService }]; }, propDecorators: { placement: [{
|
|
191
210
|
type: HostBinding,
|
|
192
211
|
args: ['@x-connect-base-animation']
|
|
@@ -197,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImpor
|
|
|
197
216
|
type: HostListener,
|
|
198
217
|
args: ['@x-connect-base-animation.start', ['$event']]
|
|
199
218
|
}] } });
|
|
200
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-portal.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-range-portal.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-range-portal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  OnInit,\r\n  OnDestroy,\r\n  AfterViewInit,\r\n  HostBinding,\r\n  HostListener\r\n} from '@angular/core';\r\nimport { XDateRangePortalPrefix, XDatePickerPreset, XDatePickerType } from './date-picker.property';\r\nimport { XIsEmpty, XConnectBaseAnimation, XPositionTopBottom, XAddDays, XAddMonths } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, map } from 'rxjs/operators';\r\nimport { DatePipe, LowerCasePipe } from '@angular/common';\r\nimport { XI18nService, XI18nDatePicker } from '@ng-nest/ui/i18n';\r\n\r\n@Component({\r\n  selector: `${XDateRangePortalPrefix}`,\r\n  templateUrl: './date-range-portal.component.html',\r\n  styleUrls: ['./date-range-portal.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [XConnectBaseAnimation],\r\n  providers: [DatePipe, LowerCasePipe]\r\n})\r\nexport class XDateRangePortalComponent implements OnInit, OnDestroy, AfterViewInit {\r\n  @HostBinding('@x-connect-base-animation') public placement!: XPositionTopBottom;\r\n  @HostListener('@x-connect-base-animation.done', ['$event']) done(event: { toState: any }) {\r\n    this.animating(false);\r\n    event.toState === 'void' && this.destroyPortal();\r\n  }\r\n  @HostListener('@x-connect-base-animation.start', ['$event']) start() {\r\n    this.animating(true);\r\n  }\r\n\r\n  type: XDatePickerType = 'date';\r\n  display = new Date();\r\n  model!: Date;\r\n  startModel!: Date;\r\n  endModel!: Date;\r\n  startYear!: number;\r\n  startDisplay: Date = new Date();\r\n  endDisplay: Date = XAddMonths(this.startDisplay, 1);\r\n  value: number[] = [];\r\n  valueChange!: Subject<number[]>;\r\n  positionChange!: Subject<any>;\r\n  animating!: Function;\r\n  closePortal!: Function;\r\n  destroyPortal!: Function;\r\n  nodeEmit!: (date: Date[], sure?: boolean) => void;\r\n  startNodeEmit!: (date: Date) => void;\r\n  endNodeEmit!: (date: Date) => void;\r\n  locale: XI18nDatePicker = {};\r\n  time!: number;\r\n  preset: XDatePickerPreset[] = [];\r\n  private _type!: XDatePickerType;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  constructor(public datePipe: DatePipe, public lowerCasePipe: LowerCasePipe, public cdr: ChangeDetectorRef, public i18n: XI18nService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.valueChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.value = x;\r\n      this.init();\r\n    });\r\n    this.positionChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.placement = x;\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.datePicker as XI18nDatePicker),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.init();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  init() {\r\n    if (!XIsEmpty(this.value)) {\r\n      this.setDefault();\r\n    } else {\r\n      this.value = [];\r\n      this.model = this.display;\r\n      this.startModel = this.model;\r\n      this.endModel = XAddMonths(this.model, 1);\r\n    }\r\n    this.time = this.model.getTime();\r\n    this._type = this.type;\r\n    this.setDisplay(this.model);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  stopPropagation(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  setDefault() {\r\n    const date = new Date();\r\n    this.model = date;\r\n    if (this.value.length > 0) {\r\n      this.startModel = new Date(this.value[0]);\r\n      this.startDisplay = this.startModel;\r\n    }\r\n    if (this.value.length > 1) {\r\n      this.endModel = new Date(this.value[1]);\r\n      this.endDisplay = this.endModel;\r\n    }\r\n  }\r\n\r\n  setDisplay(date: Date) {\r\n    this.display = new Date(date.getFullYear(), date.getMonth(), 1);\r\n    this.startDisplay = this.display;\r\n    this.endDisplay = XAddMonths(this.display, 1);\r\n  }\r\n\r\n  dateChange(date: Date) {\r\n    let time = date.getTime();\r\n    if (this.value.length === 0) {\r\n      this.value.push(time);\r\n      this.startNodeEmit(date);\r\n    } else if (this.value.length === 1) {\r\n      if (time > this.value[0]) {\r\n        this.value.push(time);\r\n        this.endNodeEmit(date);\r\n      } else {\r\n        this.value.unshift(time);\r\n        this.startNodeEmit(date);\r\n        this.endNodeEmit(new Date(this.value[1]));\r\n      }\r\n      this.nodeEmit(this.value.map((x) => new Date(x)));\r\n    }\r\n  }\r\n\r\n  typeChange(type: XDatePickerType) {\r\n    this.type = type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  monthChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'month') {\r\n      this.model = date;\r\n      // this.nodeEmit(date);\r\n    } else {\r\n      this.type = this._type;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'year') {\r\n      this.model = date;\r\n      // this.nodeEmit(date);\r\n    } else {\r\n      this.type = 'month';\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearStartChange(number: number) {\r\n    this.startYear = number;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextMonth(num: number) {\r\n    let date = new Date(this.display);\r\n    date.setMonth(date.getMonth() + num);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextYear(num: number) {\r\n    let date = new Date(this.display);\r\n    date.setFullYear(date.getFullYear() + num);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextYears(num: number) {\r\n    this.startYear += num;\r\n    let date = new Date(this.display);\r\n    date.setFullYear(this.startYear);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  getLocaleMonth(date: Date) {\r\n    return (this.locale as any)[this.lowerCasePipe.transform(this.datePipe.transform(date, 'LLLL') as string)];\r\n  }\r\n\r\n  onToday() {\r\n    this.dateChange(new Date());\r\n  }\r\n\r\n  onYesterday() {\r\n    this.dateChange(XAddDays(new Date(), -1));\r\n  }\r\n\r\n  onTomorrow() {\r\n    this.dateChange(XAddDays(new Date(), 1));\r\n  }\r\n\r\n  onPresetFunc(item: XDatePickerPreset) {\r\n    this.dateChange(item.func());\r\n  }\r\n\r\n  selectTime(time: Date) {\r\n    this.time = time.getTime();\r\n    // this.nodeEmit(this.setModel(this.model, time), false);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setModel(date: Date, time: Date) {\r\n    this.model = new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes(), time.getSeconds());\r\n    return this.model;\r\n  }\r\n}\r\n","<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n  <ng-container *ngSwitchCase=\"'date'\">\r\n    <div class=\"x-date-range-portal-header\">\r\n      <ng-container *ngTemplateOutlet=\"startDateHeaderTpl\"></ng-container>\r\n      <ng-container *ngTemplateOutlet=\"endDateHeaderTpl\"></ng-container>\r\n    </div>\r\n    <div class=\"x-date-range-portal-body\">\r\n      <x-picker-date\r\n        class=\"x-date-range-portal-start\"\r\n        [display]=\"startDisplay\"\r\n        [model]=\"startModel\"\r\n        (modelChange)=\"dateChange($event)\"\r\n        rangePicker\r\n      ></x-picker-date>\r\n      <x-picker-date\r\n        class=\"x-date-range-portal-end\"\r\n        [display]=\"endDisplay\"\r\n        [model]=\"endModel\"\r\n        (modelChange)=\"dateChange($event)\"\r\n        rangePicker\r\n      ></x-picker-date>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n  <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n  <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n  <div class=\"x-date-range-portal-year-month\">\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n  </div>\r\n  <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n  <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n  <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n  <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n  <div class=\"x-date-range-portal-year-month\">\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n  </div>\r\n  <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n  <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n"]}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-portal.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-range-portal.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-range-portal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  OnInit,\r\n  OnDestroy,\r\n  AfterViewInit,\r\n  HostBinding,\r\n  HostListener\r\n} from '@angular/core';\r\nimport { XDateRangePortalPrefix, XDatePickerPreset, XDatePickerType } from './date-picker.property';\r\nimport { XIsEmpty, XConnectBaseAnimation, XPositionTopBottom, XAddMonths, XAddYears } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, map } from 'rxjs/operators';\r\nimport { DatePipe, LowerCasePipe } from '@angular/common';\r\nimport { XI18nService, XI18nDatePicker } from '@ng-nest/ui/i18n';\r\n\r\n@Component({\r\n  selector: `${XDateRangePortalPrefix}`,\r\n  templateUrl: './date-range-portal.component.html',\r\n  styleUrls: ['./date-range-portal.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [XConnectBaseAnimation],\r\n  providers: [DatePipe, LowerCasePipe]\r\n})\r\nexport class XDateRangePortalComponent implements OnInit, OnDestroy, AfterViewInit {\r\n  @HostBinding('@x-connect-base-animation') public placement!: XPositionTopBottom;\r\n  @HostListener('@x-connect-base-animation.done', ['$event']) done(event: { toState: any }) {\r\n    this.animating(false);\r\n    event.toState === 'void' && this.destroyPortal();\r\n  }\r\n  @HostListener('@x-connect-base-animation.start', ['$event']) start() {\r\n    this.animating(true);\r\n  }\r\n\r\n  type: XDatePickerType = 'date';\r\n  display = new Date();\r\n  model!: Date;\r\n  startModel!: Date;\r\n  endModel!: Date;\r\n  startYear!: number;\r\n  startDisplay: Date = new Date();\r\n  endDisplay: Date = XAddMonths(this.startDisplay, 1);\r\n  value: number[] = [];\r\n  valueChange!: Subject<number[]>;\r\n  positionChange!: Subject<any>;\r\n  inputActiveChange!: Subject<'start' | 'end'>;\r\n  activeType!: 'start' | 'end';\r\n  animating!: Function;\r\n  closePortal!: Function;\r\n  destroyPortal!: Function;\r\n  nodeEmit!: (date: Date[], sure?: boolean) => void;\r\n  startNodeEmit!: (date: Date) => void;\r\n  endNodeEmit!: (date: Date) => void;\r\n  locale: XI18nDatePicker = {};\r\n  time!: number;\r\n  preset: XDatePickerPreset[] = [];\r\n  private _type!: XDatePickerType;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  constructor(public datePipe: DatePipe, public lowerCasePipe: LowerCasePipe, public cdr: ChangeDetectorRef, public i18n: XI18nService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.valueChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.value = x;\r\n      this.init();\r\n    });\r\n    this.positionChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.placement = x;\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.inputActiveChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.activeType = x;\r\n      this.setDefault();\r\n    });\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.datePicker as XI18nDatePicker),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.init();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  init() {\r\n    if (!XIsEmpty(this.value)) {\r\n      this.setDefault();\r\n    } else {\r\n      this.value = [];\r\n      this.model = this.display;\r\n      this.startModel = this.model;\r\n      this.endModel = XAddMonths(this.model, 1);\r\n      this.setDisplay(this.model);\r\n    }\r\n    this._type = this.type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  stopPropagation(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  setDefault() {\r\n    const type = this.activeType || 'start';\r\n    if (type === 'start') {\r\n      this.startModel = new Date(this.value[0]);\r\n      this.startDisplay = this.startModel;\r\n      this.endModel = XAddMonths(this.startModel, 1);\r\n      this.endDisplay = this.endModel;\r\n    } else if (type === 'end') {\r\n      this.endModel = new Date(this.value[1]);\r\n      this.endDisplay = this.endModel;\r\n      this.startModel = XAddMonths(this.endModel, -1);\r\n      this.startDisplay = this.startModel;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setDisplay(date: Date) {\r\n    this.display = new Date(date.getFullYear(), date.getMonth(), 1);\r\n    this.startDisplay = this.display;\r\n    this.endDisplay = XAddMonths(this.display, 1);\r\n  }\r\n\r\n  dateChange(date: Date, type: 'start' | 'end') {\r\n    let time = date.getTime();\r\n    if (this.value.length === 0) {\r\n      this.value = [time];\r\n      this.startNodeEmit(date);\r\n    } else if (this.value.length === 1) {\r\n      if (time > this.value[0]) {\r\n        this.value = [...this.value, time];\r\n        this.endNodeEmit(date);\r\n      } else {\r\n        this.value = [time, ...this.value];\r\n        this.startNodeEmit(date);\r\n        this.endNodeEmit(new Date(this.value[1]));\r\n      }\r\n      this.nodeEmit(this.value.map((x) => new Date(x)));\r\n    } else {\r\n      if (type === 'start') {\r\n        this.value = [time, this.value[1]];\r\n        this.startNodeEmit(date);\r\n      } else if (type === 'end') {\r\n        this.value = [this.value[0], time];\r\n        this.cdr.detectChanges();\r\n        this.endNodeEmit(date);\r\n      }\r\n      this.nodeEmit(\r\n        this.value.map((x) => new Date(x)),\r\n        type !== 'start'\r\n      );\r\n    }\r\n  }\r\n\r\n  typeChange(type: XDatePickerType) {\r\n    this.type = type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  monthChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'month') {\r\n      this.model = date;\r\n      // this.nodeEmit(date);\r\n    } else {\r\n      this.type = this._type;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'year') {\r\n      this.model = date;\r\n      // this.nodeEmit(date);\r\n    } else {\r\n      this.type = 'month';\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearStartChange(number: number) {\r\n    this.startYear = number;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextMonth(num: number) {\r\n    let date = new Date(this.display);\r\n    date.setMonth(date.getMonth() + num);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextYear(num: number) {\r\n    let date = new Date(this.display);\r\n    date.setFullYear(date.getFullYear() + num);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextYears(num: number) {\r\n    this.startYear += num;\r\n    let date = new Date(this.display);\r\n    date.setFullYear(this.startYear);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  getLocaleMonth(date: Date) {\r\n    return (this.locale as any)[this.lowerCasePipe.transform(this.datePipe.transform(date, 'LLLL') as string)];\r\n  }\r\n\r\n  selectTime(time: Date) {\r\n    this.time = time.getTime();\r\n    // this.nodeEmit(this.setModel(this.model, time), false);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setModel(date: Date, time: Date) {\r\n    this.model = new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes(), time.getSeconds());\r\n    return this.model;\r\n  }\r\n\r\n  startYearChange(num: number) {\r\n    this.endDisplay = XAddYears(this.endDisplay, num);\r\n  }\r\n\r\n  endYearChange(num: number) {\r\n    this.startDisplay = XAddYears(this.startDisplay, num);\r\n  }\r\n\r\n  startMonthChange(num: number) {\r\n    this.endDisplay = XAddMonths(this.endDisplay, num);\r\n  }\r\n\r\n  endMonthChange(num: number) {\r\n    this.startDisplay = XAddMonths(this.startDisplay, num);\r\n  }\r\n}\r\n","<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n  <ng-container *ngSwitchCase=\"'date'\">\r\n    <div class=\"x-date-range-portal-body\">\r\n      <x-picker-date\r\n        class=\"x-date-range-portal-start\"\r\n        [(display)]=\"startDisplay\"\r\n        [model]=\"startModel\"\r\n        [rangeValue]=\"value\"\r\n        [rangeType]=\"activeType\"\r\n        [nextYearBtn]=\"false\"\r\n        [nextMonthBtn]=\"false\"\r\n        (modelChange)=\"dateChange($event, 'start')\"\r\n        (yearChange)=\"startYearChange($event)\"\r\n        (monthChange)=\"startMonthChange($event)\"\r\n        rangePicker\r\n      ></x-picker-date>\r\n      <x-picker-date\r\n        class=\"x-date-range-portal-end\"\r\n        [(display)]=\"endDisplay\"\r\n        [model]=\"endModel\"\r\n        [rangeValue]=\"value\"\r\n        [rangeType]=\"activeType\"\r\n        [lastYearBtn]=\"false\"\r\n        [lastMonthBtn]=\"false\"\r\n        (modelChange)=\"dateChange($event, 'end')\"\r\n        (yearChange)=\"endYearChange($event)\"\r\n        (monthChange)=\"endMonthChange($event)\"\r\n        rangePicker\r\n      ></x-picker-date>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n  <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n  <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n  <div class=\"x-date-range-portal-year-month\">\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n  </div>\r\n  <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n  <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n  <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n  <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n  <div class=\"x-date-range-portal-year-month\">\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n  </div>\r\n  <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n  <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n"]}
|
|
@@ -37,6 +37,7 @@ export class XDateRangeComponent extends XDateRangeProperty {
|
|
|
37
37
|
this.valueChange = new Subject();
|
|
38
38
|
this.dataChange = new Subject();
|
|
39
39
|
this.positionChange = new Subject();
|
|
40
|
+
this.inputActiveChange = new Subject();
|
|
40
41
|
this.closeSubject = new Subject();
|
|
41
42
|
this.startDisplay = '';
|
|
42
43
|
this.endDisplay = '';
|
|
@@ -164,6 +165,8 @@ export class XDateRangeComponent extends XDateRangeProperty {
|
|
|
164
165
|
if (this.portalAttached()) {
|
|
165
166
|
this.portal?.overlayRef?.detach();
|
|
166
167
|
this.active = false;
|
|
168
|
+
this.startActive = false;
|
|
169
|
+
this.endActive = false;
|
|
167
170
|
this.cdr.detectChanges();
|
|
168
171
|
return true;
|
|
169
172
|
}
|
|
@@ -173,12 +176,16 @@ export class XDateRangeComponent extends XDateRangeProperty {
|
|
|
173
176
|
this.portal?.overlayRef?.dispose();
|
|
174
177
|
}
|
|
175
178
|
showPortal($event, type) {
|
|
176
|
-
$event.stopPropagation();
|
|
179
|
+
type && $event.stopPropagation();
|
|
177
180
|
if (this.disabled || this.animating)
|
|
178
181
|
return;
|
|
179
|
-
this.active = true;
|
|
180
182
|
this.startActive = type === 'start';
|
|
181
183
|
this.endActive = type === 'end';
|
|
184
|
+
this.activeType = type;
|
|
185
|
+
this.activeType && this.inputActiveChange.next(this.activeType);
|
|
186
|
+
if (this.active)
|
|
187
|
+
return;
|
|
188
|
+
this.active = true;
|
|
182
189
|
const config = {
|
|
183
190
|
backdropClass: '',
|
|
184
191
|
positionStrategy: this.setPlacement(),
|
|
@@ -193,9 +200,12 @@ export class XDateRangeComponent extends XDateRangeProperty {
|
|
|
193
200
|
this.portal.overlayRef
|
|
194
201
|
?.outsidePointerEvents()
|
|
195
202
|
.pipe(takeUntil(this._unSubject))
|
|
196
|
-
.subscribe(() => {
|
|
197
|
-
|
|
198
|
-
this.
|
|
203
|
+
.subscribe((event) => {
|
|
204
|
+
const clickTarget = event.target;
|
|
205
|
+
if (clickTarget !== this.inputStartCom.inputRef.nativeElement && clickTarget !== this.inputEndCom.inputRef.nativeElement) {
|
|
206
|
+
this.setDisplayValue(this.numberValue);
|
|
207
|
+
this.closeSubject.next();
|
|
208
|
+
}
|
|
199
209
|
});
|
|
200
210
|
this.setInstance();
|
|
201
211
|
}
|
|
@@ -217,6 +227,8 @@ export class XDateRangeComponent extends XDateRangeProperty {
|
|
|
217
227
|
preset: this.preset,
|
|
218
228
|
valueChange: this.valueChange,
|
|
219
229
|
positionChange: this.positionChange,
|
|
230
|
+
inputActiveChange: this.inputActiveChange,
|
|
231
|
+
activeType: this.activeType,
|
|
220
232
|
closePortal: () => this.closeSubject.next(),
|
|
221
233
|
destroyPortal: () => this.destroyPortal(),
|
|
222
234
|
nodeEmit: (dates, sure = true) => this.onNodeClick(dates, sure),
|
|
@@ -228,6 +240,9 @@ export class XDateRangeComponent extends XDateRangeProperty {
|
|
|
228
240
|
}
|
|
229
241
|
startNodeClick(node) {
|
|
230
242
|
this.startDisplay = this.datePipe.transform(node, this.format);
|
|
243
|
+
this.startActive = false;
|
|
244
|
+
this.endActive = true;
|
|
245
|
+
this.inputEndCom.inputFocus('after');
|
|
231
246
|
this.cdr.detectChanges();
|
|
232
247
|
}
|
|
233
248
|
endNodeClick(node) {
|
|
@@ -260,6 +275,8 @@ export class XDateRangeComponent extends XDateRangeProperty {
|
|
|
260
275
|
// this.modelChange();
|
|
261
276
|
// this.isInput = false;
|
|
262
277
|
// } else {
|
|
278
|
+
if (!dateNumber)
|
|
279
|
+
return;
|
|
263
280
|
this.displayValue = dateNumber.map((x) => this.datePipe.transform(x, this.format));
|
|
264
281
|
// }
|
|
265
282
|
}
|
|
@@ -282,16 +299,22 @@ export class XDateRangeComponent extends XDateRangeProperty {
|
|
|
282
299
|
this.cdr.detectChanges();
|
|
283
300
|
}
|
|
284
301
|
}
|
|
285
|
-
/** @nocollapse */ /** @nocollapse */ XDateRangeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.
|
|
286
|
-
/** @nocollapse */ /** @nocollapse */ XDateRangeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.
|
|
287
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.
|
|
302
|
+
/** @nocollapse */ /** @nocollapse */ XDateRangeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: XDateRangeComponent, deps: [{ token: i0.Renderer2 }, { token: i1.XConfigService }, { token: i0.ChangeDetectorRef }, { token: i2.XPortalService }, { token: i0.ViewContainerRef }, { token: i3.DatePipe }, { token: i4.Overlay }], target: i0.ɵɵFactoryTarget.Component });
|
|
303
|
+
/** @nocollapse */ /** @nocollapse */ XDateRangeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: XDateRangeComponent, selector: "x-date-range", providers: [XValueAccessor(XDateRangeComponent), DatePipe], viewQueries: [{ propertyName: "dateRange", first: true, predicate: ["dateRange"], descendants: true, static: true }, { propertyName: "inputGroup", first: true, predicate: ["inputGroup"], descendants: true, static: true }, { propertyName: "inputStartCom", first: true, predicate: ["inputStartCom"], descendants: true, static: true }, { propertyName: "inputEndCom", first: true, predicate: ["inputEndCom"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #dateRange class=\"x-date-range\" [class.x-date-range-active]=\"active\">\r\n <div class=\"x-date-range-row\">\r\n <x-input-group #inputGroup class=\"x-date-range-group\" bordered=\"false\" (click)=\"showPortal($event)\">\r\n <x-input\r\n #inputStartCom\r\n [class.x-input-active]=\"startActive\"\r\n type=\"text\"\r\n placeholder=\"\u5F00\u59CB\u65E5\u671F\"\r\n (click)=\"showPortal($event, 'start')\"\r\n (xFocus)=\"startActive = true\"\r\n (xBlur)=\"startActive = false\"\r\n [(ngModel)]=\"startDisplay\"\r\n ></x-input>\r\n <x-icon type=\"fto-arrow-right\"></x-icon>\r\n <x-input\r\n #inputEndCom\r\n [class.x-input-active]=\"endActive\"\r\n type=\"text\"\r\n placeholder=\"\u7ED3\u675F\u65E5\u671F\"\r\n (click)=\"showPortal($event, 'end')\"\r\n (xFocus)=\"endActive = true\"\r\n (xBlur)=\"endActive = false\"\r\n [(ngModel)]=\"endDisplay\"\r\n ></x-input>\r\n <x-icon [type]=\"icon\"></x-icon>\r\n </x-input-group>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-date-range{display:inline-block}.x-date-range{margin:0;padding:0;width:100%}.x-date-range-row{flex:1;display:flex;align-items:center}.x-date-range-group{display:inline-flex;flex:1;width:100%;font-size:var(--x-font-size);background-color:var(--x-background);background-image:none;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) transparent;transition:all var(--x-animation-duration-slow)}.x-date-range-group .x-input-group{display:flex;align-items:center}.x-date-range-group .x-input-group>x-icon{color:var(--x-text-400);transition:all var(--x-animation-duration-base);z-index:2;padding:.4rem}.x-date-range-group .x-input-group>x-input{width:6rem}.x-date-range-group .x-input-group>x-input input{padding-left:0!important;padding-right:0!important;margin-left:.4rem;margin-right:.4rem;border-radius:0;border-bottom:var(--x-border-width) var(--x-border-style) transparent}.x-date-range-group .x-input-group>x-input .x-input-active input{border-color:var(--x-primary)}.x-date-range-group:hover{border-color:var(--x-primary-300)}.x-date-range-active .x-date-range-group{border-color:var(--x-primary)}\n"], components: [{ type: i5.XInputGroupComponent, selector: "x-input-group" }, { type: i5.XInputComponent, selector: "x-input" }, { type: i6.XIconComponent, selector: "x-icon" }], directives: [{ type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
304
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: XDateRangeComponent, decorators: [{
|
|
288
305
|
type: Component,
|
|
289
|
-
args: [{ selector: `${XDateRangePrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XDateRangeComponent), DatePipe], template: "<div #dateRange class=\"x-date-range\" [class.x-date-range-active]=\"active\">\r\n <div class=\"x-date-range-row\">\r\n <x-input-group #inputGroup class=\"x-date-range-group\" bordered=\"false\" (click)=\"showPortal($event)\">\r\n <x-input\r\n #inputStartCom\r\n type=\"text\"\r\n placeholder=\"\u5F00\u59CB\u65E5\u671F\"\r\n
|
|
306
|
+
args: [{ selector: `${XDateRangePrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XDateRangeComponent), DatePipe], template: "<div #dateRange class=\"x-date-range\" [class.x-date-range-active]=\"active\">\r\n <div class=\"x-date-range-row\">\r\n <x-input-group #inputGroup class=\"x-date-range-group\" bordered=\"false\" (click)=\"showPortal($event)\">\r\n <x-input\r\n #inputStartCom\r\n [class.x-input-active]=\"startActive\"\r\n type=\"text\"\r\n placeholder=\"\u5F00\u59CB\u65E5\u671F\"\r\n (click)=\"showPortal($event, 'start')\"\r\n (xFocus)=\"startActive = true\"\r\n (xBlur)=\"startActive = false\"\r\n [(ngModel)]=\"startDisplay\"\r\n ></x-input>\r\n <x-icon type=\"fto-arrow-right\"></x-icon>\r\n <x-input\r\n #inputEndCom\r\n [class.x-input-active]=\"endActive\"\r\n type=\"text\"\r\n placeholder=\"\u7ED3\u675F\u65E5\u671F\"\r\n (click)=\"showPortal($event, 'end')\"\r\n (xFocus)=\"endActive = true\"\r\n (xBlur)=\"endActive = false\"\r\n [(ngModel)]=\"endDisplay\"\r\n ></x-input>\r\n <x-icon [type]=\"icon\"></x-icon>\r\n </x-input-group>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-date-range{display:inline-block}.x-date-range{margin:0;padding:0;width:100%}.x-date-range-row{flex:1;display:flex;align-items:center}.x-date-range-group{display:inline-flex;flex:1;width:100%;font-size:var(--x-font-size);background-color:var(--x-background);background-image:none;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) transparent;transition:all var(--x-animation-duration-slow)}.x-date-range-group .x-input-group{display:flex;align-items:center}.x-date-range-group .x-input-group>x-icon{color:var(--x-text-400);transition:all var(--x-animation-duration-base);z-index:2;padding:.4rem}.x-date-range-group .x-input-group>x-input{width:6rem}.x-date-range-group .x-input-group>x-input input{padding-left:0!important;padding-right:0!important;margin-left:.4rem;margin-right:.4rem;border-radius:0;border-bottom:var(--x-border-width) var(--x-border-style) transparent}.x-date-range-group .x-input-group>x-input .x-input-active input{border-color:var(--x-primary)}.x-date-range-group:hover{border-color:var(--x-primary-300)}.x-date-range-active .x-date-range-group{border-color:var(--x-primary)}\n"] }]
|
|
290
307
|
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i1.XConfigService }, { type: i0.ChangeDetectorRef }, { type: i2.XPortalService }, { type: i0.ViewContainerRef }, { type: i3.DatePipe }, { type: i4.Overlay }]; }, propDecorators: { dateRange: [{
|
|
291
308
|
type: ViewChild,
|
|
292
309
|
args: ['dateRange', { static: true }]
|
|
293
310
|
}], inputGroup: [{
|
|
294
311
|
type: ViewChild,
|
|
295
312
|
args: ['inputGroup', { static: true }]
|
|
313
|
+
}], inputStartCom: [{
|
|
314
|
+
type: ViewChild,
|
|
315
|
+
args: ['inputStartCom', { static: true }]
|
|
316
|
+
}], inputEndCom: [{
|
|
317
|
+
type: ViewChild,
|
|
318
|
+
args: ['inputEndCom', { static: true }]
|
|
296
319
|
}] } });
|
|
297
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-range.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { XPortalService, XPortalOverlayRef, XPortalConnectedPosition } from '@ng-nest/ui/portal';\r\nimport { Subject } from 'rxjs';\r\nimport {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Renderer2,\r\n  ElementRef,\r\n  OnChanges,\r\n  ViewContainerRef,\r\n  ViewChild,\r\n  SimpleChanges\r\n} from '@angular/core';\r\nimport { XDatePickerModelType, XDateRangePrefix, XDateRangeProperty } from './date-picker.property';\r\nimport {\r\n  XIsEmpty,\r\n  XIsDate,\r\n  XIsNumber,\r\n  XIsChange,\r\n  XCorner,\r\n  XClearClass,\r\n  XIsString,\r\n  XConfigService,\r\n  XIsUndefined,\r\n  XBoolean\r\n} from '@ng-nest/ui/core';\r\nimport { XInputGroupComponent } from '@ng-nest/ui/input';\r\nimport { DatePipe } from '@angular/common';\r\nimport { Overlay, OverlayConfig, FlexibleConnectedPositionStrategy, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\nimport { XDateRangePortalComponent } from './date-range-portal.component';\r\n\r\n@Component({\r\n  selector: `${XDateRangePrefix}`,\r\n  templateUrl: './date-range.component.html',\r\n  styleUrls: ['./date-range.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XDateRangeComponent), DatePipe]\r\n})\r\nexport class XDateRangeComponent extends XDateRangeProperty implements OnInit, OnChanges {\r\n  @ViewChild('dateRange', { static: true }) dateRange!: ElementRef;\r\n  @ViewChild('inputGroup', { static: true }) inputGroup!: XInputGroupComponent;\r\n\r\n  modelType: XDatePickerModelType = 'date';\r\n  numberValue!: number[];\r\n  isInput = false;\r\n\r\n  get getRequired() {\r\n    return this.required && XIsEmpty(this.value);\r\n  }\r\n\r\n  override writeValue(value: any) {\r\n    if (XIsUndefined(value)) value = [];\r\n    if (value.length > 0) {\r\n      if (XIsDate(value[0])) {\r\n        this.modelType = 'date';\r\n        this.numberValue = value.getTime();\r\n      } else if (XIsNumber(value[0])) {\r\n        this.modelType = 'number';\r\n        this.numberValue = value;\r\n      } else if (XIsString(value[0])) {\r\n        this.modelType = 'string';\r\n        const valueTime = value.map((x: string) => new Date(x).getTime());\r\n        this.numberValue = !isNaN(valueTime[0]) ? valueTime : [];\r\n      }\r\n    }\r\n    this.value = value;\r\n    this.setDisplayValue(this.numberValue);\r\n    this.valueChange.next(this.numberValue);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  enter: boolean = false;\r\n  inputClearable: boolean = false;\r\n  animating = false;\r\n  displayValue: string[] = [];\r\n  portal!: XPortalOverlayRef<XDateRangePortalComponent>;\r\n  icon: string = 'fto-calendar';\r\n  box!: DOMRect;\r\n  protalHeight!: number;\r\n  maxNodes: number = 6;\r\n  protalTobottom: boolean = true;\r\n  valueChange: Subject<any> = new Subject();\r\n  dataChange: Subject<any> = new Subject();\r\n  positionChange: Subject<any> = new Subject();\r\n  closeSubject: Subject<void> = new Subject();\r\n  startDisplay: string | number = '';\r\n  endDisplay: string | number = '';\r\n  startActive: XBoolean = false;\r\n  endActive: XBoolean = false;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public configService: XConfigService,\r\n    private cdr: ChangeDetectorRef,\r\n    private portalService: XPortalService,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private datePipe: DatePipe,\r\n    private overlay: Overlay\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setFlex(this.dateRange.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setFormat();\r\n    this.setClassMap();\r\n    this.setSubject();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setPortal();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { type } = changes;\r\n    if (XIsChange(type)) {\r\n      this.setFormat();\r\n      this.setDisplayValue(this.numberValue);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  setSubject() {\r\n    this.closeSubject.pipe(takeUntil(this._unSubject)).subscribe(() => {\r\n      this.closePortal();\r\n    });\r\n  }\r\n\r\n  setFormat() {\r\n    if (this.format !== 'yyyy-MM-dd') return;\r\n    if (this.type === 'date') {\r\n      this.format = 'yyyy-MM-dd';\r\n    } else if (this.type === 'year') {\r\n      this.format = 'yyyy';\r\n    } else if (this.type === 'month') {\r\n      this.format = 'yyyy-MM';\r\n    } else if (this.type === 'date-time') {\r\n      this.format = 'yyyy-MM-dd HH:mm:ss';\r\n    } else if (this.type === 'date-hour') {\r\n      this.format = 'yyyy-MM-dd HH';\r\n    } else if (this.type === 'date-minute') {\r\n      this.format = 'yyyy-MM-dd HH:mm';\r\n    }\r\n  }\r\n\r\n  menter() {\r\n    if (this.disabled) return;\r\n    this.enter = true;\r\n    if (!XIsEmpty(this.numberValue)) {\r\n      this.icon = '';\r\n      this.inputClearable = true;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  mleave() {\r\n    if (this.disabled) return;\r\n    this.enter = false;\r\n    if (this.inputClearable) {\r\n      this.icon = 'fto-calendar';\r\n      this.inputClearable = false;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  clearEmit() {\r\n    this.value = [];\r\n    this.numberValue = [];\r\n    this.displayValue = [];\r\n    this.mleave();\r\n    this.valueChange.next(this.numberValue);\r\n    this.modelChange();\r\n  }\r\n\r\n  modelChange() {\r\n    if (this.onChange) {\r\n      this.onChange(this.getValue());\r\n    }\r\n  }\r\n\r\n  getValue() {\r\n    return this.modelType === 'date'\r\n      ? this.numberValue.map((x) => new Date(x))\r\n      : this.modelType === 'string'\r\n      ? this.numberValue.map((x) => this.datePipe.transform(x, this.format))\r\n      : this.numberValue;\r\n  }\r\n\r\n  portalAttached() {\r\n    return this.portal?.overlayRef?.hasAttached();\r\n  }\r\n\r\n  closePortal() {\r\n    if (this.portalAttached()) {\r\n      this.portal?.overlayRef?.detach();\r\n      this.active = false;\r\n      this.cdr.detectChanges();\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  destroyPortal() {\r\n    this.portal?.overlayRef?.dispose();\r\n  }\r\n\r\n  showPortal($event: Event, type?: 'start' | 'end') {\r\n    $event.stopPropagation();\r\n    if (this.disabled || this.animating) return;\r\n    this.active = true;\r\n    this.startActive = type === 'start';\r\n    this.endActive = type === 'end';\r\n    const config: OverlayConfig = {\r\n      backdropClass: '',\r\n      positionStrategy: this.setPlacement(),\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition()\r\n    };\r\n    this.setPosition(config);\r\n    this.portal = this.portalService.attach({\r\n      content: XDateRangePortalComponent,\r\n      viewContainerRef: this.viewContainerRef,\r\n      overlayConfig: config\r\n    });\r\n    this.portal.overlayRef\r\n      ?.outsidePointerEvents()\r\n      .pipe(takeUntil(this._unSubject))\r\n      .subscribe(() => {\r\n        this.setDisplayValue(this.numberValue);\r\n        this.closeSubject.next();\r\n      });\r\n    this.setInstance();\r\n  }\r\n\r\n  setPosition(config: OverlayConfig) {\r\n    let position = config.positionStrategy as FlexibleConnectedPositionStrategy;\r\n    position.positionChanges.pipe(takeUntil(this._unSubject)).subscribe((pos: ConnectedOverlayPositionChange) => {\r\n      const place = XPortalConnectedPosition.get(pos.connectionPair) as XCorner;\r\n      place !== this.placement && this.positionChange.next(place);\r\n    });\r\n  }\r\n\r\n  setInstance() {\r\n    let componentRef = this.portal?.componentRef;\r\n    if (!componentRef) return;\r\n    Object.assign(componentRef.instance, {\r\n      type: this.type,\r\n      value: this.numberValue,\r\n      placement: this.placement,\r\n      preset: this.preset,\r\n      valueChange: this.valueChange,\r\n      positionChange: this.positionChange,\r\n      closePortal: () => this.closeSubject.next(),\r\n      destroyPortal: () => this.destroyPortal(),\r\n      nodeEmit: (dates: Date[], sure = true) => this.onNodeClick(dates, sure),\r\n      startNodeEmit: (node: Date) => this.startNodeClick(node),\r\n      endNodeEmit: (node: Date) => this.endNodeClick(node),\r\n      animating: (ing: boolean) => (this.animating = ing)\r\n    });\r\n    componentRef.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  startNodeClick(node: Date) {\r\n    this.startDisplay = this.datePipe.transform(node, this.format) as string;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  endNodeClick(node: Date) {\r\n    this.endDisplay = this.datePipe.transform(node, this.format) as string;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onNodeClick(dates: Date[], sure = true) {\r\n    this.isInput = false;\r\n    if (sure) {\r\n      this.numberValue = dates.map((x) => x.getTime());\r\n      this.value = this.getValue();\r\n      this.setDisplayValue(this.numberValue);\r\n      this.closeSubject.next();\r\n      this.modelChange();\r\n      this.nodeEmit.emit(this.numberValue);\r\n    } else {\r\n      this.setDisplayValue(dates.map((x) => x.getTime()));\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  onInput() {\r\n    this.isInput = true;\r\n  }\r\n\r\n  setDisplayValue(dateNumber: number[]) {\r\n    // if (this.isInput && isNaN(this.startDisplay) && !isNaN(Date.parse(this.displayValue))) {\r\n    //   this.displayValue = this.datePipe.transform(this.displayValue, this.format);\r\n    //   this.numberValue = new Date(this.displayValue).getTime();\r\n    //   this.value = this.getValue();\r\n    //   this.modelChange();\r\n    //   this.isInput = false;\r\n    // } else {\r\n    this.displayValue = dateNumber.map((x) => this.datePipe.transform(x, this.format)) as string[];\r\n    // }\r\n  }\r\n\r\n  setPlacement() {\r\n    return this.portalService.setPlacement({\r\n      elementRef: this.inputGroup.elementRef,\r\n      placement: [this.placement as XCorner, 'bottom-start', 'bottom-end', 'top-start', 'top-end'],\r\n      transformOriginOn: 'x-date-range-portal'\r\n    });\r\n  }\r\n\r\n  setPortal() {\r\n    this.portalAttached() && this.portal?.overlayRef?.updatePositionStrategy(this.setPlacement());\r\n  }\r\n\r\n  setClassMap() {\r\n    XClearClass(this.labelMap);\r\n    this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div #dateRange class=\"x-date-range\" [class.x-date-range-active]=\"active\">\r\n  <div class=\"x-date-range-row\">\r\n    <x-input-group #inputGroup class=\"x-date-range-group\" bordered=\"false\" (click)=\"showPortal($event)\">\r\n      <x-input\r\n        #inputStartCom\r\n        type=\"text\"\r\n        placeholder=\"开始日期\"\r\n        [(active)]=\"startActive\"\r\n        (click)=\"showPortal($event, 'start')\"\r\n        [(ngModel)]=\"startDisplay\"\r\n      ></x-input>\r\n      <x-icon type=\"fto-arrow-right\"></x-icon>\r\n      <x-input\r\n        #inputEndCom\r\n        type=\"text\"\r\n        placeholder=\"结束日期\"\r\n        [(active)]=\"endActive\"\r\n        (click)=\"showPortal($event, 'end')\"\r\n        [(ngModel)]=\"endDisplay\"\r\n      ></x-input>\r\n      <x-icon [type]=\"icon\"></x-icon>\r\n    </x-input-group>\r\n  </div>\r\n</div>\r\n"]}
|
|
320
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-range.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { XPortalService, XPortalOverlayRef, XPortalConnectedPosition } from '@ng-nest/ui/portal';\r\nimport { Subject } from 'rxjs';\r\nimport {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Renderer2,\r\n  ElementRef,\r\n  OnChanges,\r\n  ViewContainerRef,\r\n  ViewChild,\r\n  SimpleChanges\r\n} from '@angular/core';\r\nimport { XDatePickerModelType, XDateRangePrefix, XDateRangeProperty } from './date-picker.property';\r\nimport {\r\n  XIsEmpty,\r\n  XIsDate,\r\n  XIsNumber,\r\n  XIsChange,\r\n  XCorner,\r\n  XClearClass,\r\n  XIsString,\r\n  XConfigService,\r\n  XIsUndefined,\r\n  XBoolean\r\n} from '@ng-nest/ui/core';\r\nimport { XInputComponent, XInputGroupComponent } from '@ng-nest/ui/input';\r\nimport { DatePipe } from '@angular/common';\r\nimport { Overlay, OverlayConfig, FlexibleConnectedPositionStrategy, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\nimport { XDateRangePortalComponent } from './date-range-portal.component';\r\n\r\n@Component({\r\n  selector: `${XDateRangePrefix}`,\r\n  templateUrl: './date-range.component.html',\r\n  styleUrls: ['./date-range.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XDateRangeComponent), DatePipe]\r\n})\r\nexport class XDateRangeComponent extends XDateRangeProperty implements OnInit, OnChanges {\r\n  @ViewChild('dateRange', { static: true }) dateRange!: ElementRef;\r\n  @ViewChild('inputGroup', { static: true }) inputGroup!: XInputGroupComponent;\r\n  @ViewChild('inputStartCom', { static: true }) inputStartCom!: XInputComponent;\r\n  @ViewChild('inputEndCom', { static: true }) inputEndCom!: XInputComponent;\r\n\r\n  modelType: XDatePickerModelType = 'date';\r\n  numberValue!: number[];\r\n  isInput = false;\r\n\r\n  get getRequired() {\r\n    return this.required && XIsEmpty(this.value);\r\n  }\r\n\r\n  override writeValue(value: any) {\r\n    if (XIsUndefined(value)) value = [];\r\n    if (value.length > 0) {\r\n      if (XIsDate(value[0])) {\r\n        this.modelType = 'date';\r\n        this.numberValue = value.getTime();\r\n      } else if (XIsNumber(value[0])) {\r\n        this.modelType = 'number';\r\n        this.numberValue = value;\r\n      } else if (XIsString(value[0])) {\r\n        this.modelType = 'string';\r\n        const valueTime = value.map((x: string) => new Date(x).getTime());\r\n        this.numberValue = !isNaN(valueTime[0]) ? valueTime : [];\r\n      }\r\n    }\r\n    this.value = value;\r\n    this.setDisplayValue(this.numberValue);\r\n    this.valueChange.next(this.numberValue);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  enter: boolean = false;\r\n  inputClearable: boolean = false;\r\n  animating = false;\r\n  displayValue: string[] = [];\r\n  portal!: XPortalOverlayRef<XDateRangePortalComponent>;\r\n  icon: string = 'fto-calendar';\r\n  box!: DOMRect;\r\n  protalHeight!: number;\r\n  maxNodes: number = 6;\r\n  protalTobottom: boolean = true;\r\n  valueChange: Subject<any> = new Subject();\r\n  dataChange: Subject<any> = new Subject();\r\n  positionChange: Subject<any> = new Subject();\r\n  inputActiveChange: Subject<string> = new Subject();\r\n  closeSubject: Subject<void> = new Subject();\r\n  startDisplay: string | number = '';\r\n  endDisplay: string | number = '';\r\n  startActive: XBoolean = false;\r\n  endActive: XBoolean = false;\r\n  activeType?: 'start' | 'end';\r\n  private _unSubject = new Subject<void>();\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public configService: XConfigService,\r\n    private cdr: ChangeDetectorRef,\r\n    private portalService: XPortalService,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private datePipe: DatePipe,\r\n    private overlay: Overlay\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setFlex(this.dateRange.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setFormat();\r\n    this.setClassMap();\r\n    this.setSubject();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setPortal();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { type } = changes;\r\n    if (XIsChange(type)) {\r\n      this.setFormat();\r\n      this.setDisplayValue(this.numberValue);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  setSubject() {\r\n    this.closeSubject.pipe(takeUntil(this._unSubject)).subscribe(() => {\r\n      this.closePortal();\r\n    });\r\n  }\r\n\r\n  setFormat() {\r\n    if (this.format !== 'yyyy-MM-dd') return;\r\n    if (this.type === 'date') {\r\n      this.format = 'yyyy-MM-dd';\r\n    } else if (this.type === 'year') {\r\n      this.format = 'yyyy';\r\n    } else if (this.type === 'month') {\r\n      this.format = 'yyyy-MM';\r\n    } else if (this.type === 'date-time') {\r\n      this.format = 'yyyy-MM-dd HH:mm:ss';\r\n    } else if (this.type === 'date-hour') {\r\n      this.format = 'yyyy-MM-dd HH';\r\n    } else if (this.type === 'date-minute') {\r\n      this.format = 'yyyy-MM-dd HH:mm';\r\n    }\r\n  }\r\n\r\n  menter() {\r\n    if (this.disabled) return;\r\n    this.enter = true;\r\n    if (!XIsEmpty(this.numberValue)) {\r\n      this.icon = '';\r\n      this.inputClearable = true;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  mleave() {\r\n    if (this.disabled) return;\r\n    this.enter = false;\r\n    if (this.inputClearable) {\r\n      this.icon = 'fto-calendar';\r\n      this.inputClearable = false;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  clearEmit() {\r\n    this.value = [];\r\n    this.numberValue = [];\r\n    this.displayValue = [];\r\n    this.mleave();\r\n    this.valueChange.next(this.numberValue);\r\n    this.modelChange();\r\n  }\r\n\r\n  modelChange() {\r\n    if (this.onChange) {\r\n      this.onChange(this.getValue());\r\n    }\r\n  }\r\n\r\n  getValue() {\r\n    return this.modelType === 'date'\r\n      ? this.numberValue.map((x) => new Date(x))\r\n      : this.modelType === 'string'\r\n      ? this.numberValue.map((x) => this.datePipe.transform(x, this.format))\r\n      : this.numberValue;\r\n  }\r\n\r\n  portalAttached() {\r\n    return this.portal?.overlayRef?.hasAttached();\r\n  }\r\n\r\n  closePortal() {\r\n    if (this.portalAttached()) {\r\n      this.portal?.overlayRef?.detach();\r\n      this.active = false;\r\n      this.startActive = false;\r\n      this.endActive = false;\r\n      this.cdr.detectChanges();\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  destroyPortal() {\r\n    this.portal?.overlayRef?.dispose();\r\n  }\r\n\r\n  showPortal($event: Event, type?: 'start' | 'end') {\r\n    type && $event.stopPropagation();\r\n    if (this.disabled || this.animating) return;\r\n    this.startActive = type === 'start';\r\n    this.endActive = type === 'end';\r\n    this.activeType = type;\r\n    this.activeType && this.inputActiveChange.next(this.activeType);\r\n    if (this.active) return;\r\n    this.active = true;\r\n    const config: OverlayConfig = {\r\n      backdropClass: '',\r\n      positionStrategy: this.setPlacement(),\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition()\r\n    };\r\n    this.setPosition(config);\r\n    this.portal = this.portalService.attach({\r\n      content: XDateRangePortalComponent,\r\n      viewContainerRef: this.viewContainerRef,\r\n      overlayConfig: config\r\n    });\r\n    this.portal.overlayRef\r\n      ?.outsidePointerEvents()\r\n      .pipe(takeUntil(this._unSubject))\r\n      .subscribe((event: MouseEvent) => {\r\n        const clickTarget = event.target as HTMLElement;\r\n        if (clickTarget !== this.inputStartCom.inputRef.nativeElement && clickTarget !== this.inputEndCom.inputRef.nativeElement) {\r\n          this.setDisplayValue(this.numberValue);\r\n          this.closeSubject.next();\r\n        }\r\n      });\r\n    this.setInstance();\r\n  }\r\n\r\n  setPosition(config: OverlayConfig) {\r\n    let position = config.positionStrategy as FlexibleConnectedPositionStrategy;\r\n    position.positionChanges.pipe(takeUntil(this._unSubject)).subscribe((pos: ConnectedOverlayPositionChange) => {\r\n      const place = XPortalConnectedPosition.get(pos.connectionPair) as XCorner;\r\n      place !== this.placement && this.positionChange.next(place);\r\n    });\r\n  }\r\n\r\n  setInstance() {\r\n    let componentRef = this.portal?.componentRef;\r\n    if (!componentRef) return;\r\n    Object.assign(componentRef.instance, {\r\n      type: this.type,\r\n      value: this.numberValue,\r\n      placement: this.placement,\r\n      preset: this.preset,\r\n      valueChange: this.valueChange,\r\n      positionChange: this.positionChange,\r\n      inputActiveChange: this.inputActiveChange,\r\n      activeType: this.activeType,\r\n      closePortal: () => this.closeSubject.next(),\r\n      destroyPortal: () => this.destroyPortal(),\r\n      nodeEmit: (dates: Date[], sure = true) => this.onNodeClick(dates, sure),\r\n      startNodeEmit: (node: Date) => this.startNodeClick(node),\r\n      endNodeEmit: (node: Date) => this.endNodeClick(node),\r\n      animating: (ing: boolean) => (this.animating = ing)\r\n    });\r\n    componentRef.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  startNodeClick(node: Date) {\r\n    this.startDisplay = this.datePipe.transform(node, this.format) as string;\r\n    this.startActive = false;\r\n    this.endActive = true;\r\n    this.inputEndCom.inputFocus('after');\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  endNodeClick(node: Date) {\r\n    this.endDisplay = this.datePipe.transform(node, this.format) as string;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onNodeClick(dates: Date[], sure = true) {\r\n    this.isInput = false;\r\n    if (sure) {\r\n      this.numberValue = dates.map((x) => x.getTime());\r\n      this.value = this.getValue();\r\n      this.setDisplayValue(this.numberValue);\r\n      this.closeSubject.next();\r\n      this.modelChange();\r\n      this.nodeEmit.emit(this.numberValue);\r\n    } else {\r\n      this.setDisplayValue(dates.map((x) => x.getTime()));\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  onInput() {\r\n    this.isInput = true;\r\n  }\r\n\r\n  setDisplayValue(dateNumber: number[]) {\r\n    // if (this.isInput && isNaN(this.startDisplay) && !isNaN(Date.parse(this.displayValue))) {\r\n    //   this.displayValue = this.datePipe.transform(this.displayValue, this.format);\r\n    //   this.numberValue = new Date(this.displayValue).getTime();\r\n    //   this.value = this.getValue();\r\n    //   this.modelChange();\r\n    //   this.isInput = false;\r\n    // } else {\r\n    if (!dateNumber) return;\r\n    this.displayValue = dateNumber.map((x) => this.datePipe.transform(x, this.format)) as string[];\r\n    // }\r\n  }\r\n\r\n  setPlacement() {\r\n    return this.portalService.setPlacement({\r\n      elementRef: this.inputGroup.elementRef,\r\n      placement: [this.placement as XCorner, 'bottom-start', 'bottom-end', 'top-start', 'top-end'],\r\n      transformOriginOn: 'x-date-range-portal'\r\n    });\r\n  }\r\n\r\n  setPortal() {\r\n    this.portalAttached() && this.portal?.overlayRef?.updatePositionStrategy(this.setPlacement());\r\n  }\r\n\r\n  setClassMap() {\r\n    XClearClass(this.labelMap);\r\n    this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div #dateRange class=\"x-date-range\" [class.x-date-range-active]=\"active\">\r\n  <div class=\"x-date-range-row\">\r\n    <x-input-group #inputGroup class=\"x-date-range-group\" bordered=\"false\" (click)=\"showPortal($event)\">\r\n      <x-input\r\n        #inputStartCom\r\n        [class.x-input-active]=\"startActive\"\r\n        type=\"text\"\r\n        placeholder=\"开始日期\"\r\n        (click)=\"showPortal($event, 'start')\"\r\n        (xFocus)=\"startActive = true\"\r\n        (xBlur)=\"startActive = false\"\r\n        [(ngModel)]=\"startDisplay\"\r\n      ></x-input>\r\n      <x-icon type=\"fto-arrow-right\"></x-icon>\r\n      <x-input\r\n        #inputEndCom\r\n        [class.x-input-active]=\"endActive\"\r\n        type=\"text\"\r\n        placeholder=\"结束日期\"\r\n        (click)=\"showPortal($event, 'end')\"\r\n        (xFocus)=\"endActive = true\"\r\n        (xBlur)=\"endActive = false\"\r\n        [(ngModel)]=\"endDisplay\"\r\n      ></x-input>\r\n      <x-icon [type]=\"icon\"></x-icon>\r\n    </x-input-group>\r\n  </div>\r\n</div>\r\n"]}
|