@ng-matero/extensions 15.5.0 → 16.0.0
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/alert/alert.d.ts +1 -1
- package/button/button-loading.d.ts +1 -1
- package/checkbox-group/checkbox-group.d.ts +1 -1
- package/colorpicker/colorpicker-input.d.ts +1 -1
- package/colorpicker/colorpicker-toggle.d.ts +1 -1
- package/colorpicker/colorpicker.d.ts +2 -2
- package/datetimepicker/calendar-body.d.ts +1 -1
- package/datetimepicker/calendar.d.ts +1 -1
- package/datetimepicker/clock.d.ts +1 -1
- package/datetimepicker/clock.scss +1 -4
- package/datetimepicker/datetimepicker-input.d.ts +1 -1
- package/datetimepicker/datetimepicker-toggle.d.ts +1 -1
- package/datetimepicker/datetimepicker.d.ts +2 -2
- package/datetimepicker/month-view.d.ts +1 -1
- package/datetimepicker/multi-year-view.d.ts +1 -1
- package/datetimepicker/time.d.ts +2 -2
- package/datetimepicker/year-view.d.ts +1 -1
- package/esm2022/alert/alert-module.mjs +19 -0
- package/esm2022/alert/alert.mjs +53 -0
- package/esm2022/button/button-loading.mjs +77 -0
- package/esm2022/button/button-module.mjs +21 -0
- package/esm2022/checkbox-group/checkbox-group-module.mjs +22 -0
- package/esm2022/checkbox-group/checkbox-group.mjs +234 -0
- package/esm2022/colorpicker/colorpicker-input.mjs +229 -0
- package/esm2022/colorpicker/colorpicker-module.mjs +64 -0
- package/esm2022/colorpicker/colorpicker-toggle.mjs +103 -0
- package/esm2022/colorpicker/colorpicker.mjs +367 -0
- package/esm2022/column-resize/column-resize-directives/column-resize-flex.mjs +46 -0
- package/esm2022/column-resize/column-resize-directives/column-resize.mjs +46 -0
- package/esm2022/column-resize/column-resize-module.mjs +29 -0
- package/esm2022/column-resize/column-resize-notifier.mjs +49 -0
- package/esm2022/column-resize/column-resize.mjs +83 -0
- package/esm2022/column-resize/column-size-store.mjs +21 -0
- package/esm2022/column-resize/event-dispatcher.mjs +68 -0
- package/esm2022/column-resize/overlay-handle.mjs +147 -0
- package/esm2022/column-resize/resizable.mjs +200 -0
- package/esm2022/column-resize/resize-strategy.mjs +235 -0
- package/{esm2020 → esm2022}/core/datetime/datetime-adapter.mjs +1 -1
- package/esm2022/core/datetime/datetime.module.mjs +44 -0
- package/esm2022/core/datetime/native-datetime-adapter.mjs +139 -0
- package/esm2022/core/pipes/is-template-ref.pipe.mjs +15 -0
- package/esm2022/core/pipes/pipes.module.mjs +20 -0
- package/esm2022/core/pipes/to-observable.pipe.mjs +16 -0
- package/esm2022/datetimepicker/calendar-body.mjs +79 -0
- package/esm2022/datetimepicker/calendar.mjs +672 -0
- package/esm2022/datetimepicker/clock.mjs +354 -0
- package/esm2022/datetimepicker/datetimepicker-input.mjs +350 -0
- package/esm2022/datetimepicker/datetimepicker-intl.mjs +64 -0
- package/esm2022/datetimepicker/datetimepicker-module.mjs +83 -0
- package/esm2022/datetimepicker/datetimepicker-toggle.mjs +106 -0
- package/esm2022/datetimepicker/datetimepicker.mjs +529 -0
- package/esm2022/datetimepicker/month-view.mjs +149 -0
- package/esm2022/datetimepicker/multi-year-view.mjs +215 -0
- package/esm2022/datetimepicker/time.mjs +458 -0
- package/esm2022/datetimepicker/year-view.mjs +139 -0
- package/esm2022/dialog/dialog-container.mjs +36 -0
- package/esm2022/dialog/dialog-module.mjs +25 -0
- package/esm2022/dialog/dialog.mjs +75 -0
- package/esm2022/drawer/drawer-container.mjs +253 -0
- package/esm2022/drawer/drawer-module.mjs +23 -0
- package/esm2022/drawer/drawer.mjs +167 -0
- package/esm2022/grid/cell.mjs +117 -0
- package/{esm2020 → esm2022}/grid/column-menu.mjs +6 -5
- package/esm2022/grid/column-resize/column-resize-directives/column-resize-flex.mjs +38 -0
- package/esm2022/grid/column-resize/column-resize-directives/column-resize.mjs +38 -0
- package/esm2022/grid/column-resize/column-resize-module.mjs +44 -0
- package/esm2022/grid/column-resize/overlay-handle.mjs +61 -0
- package/esm2022/grid/column-resize/resizable-directives/resizable.mjs +63 -0
- package/esm2022/grid/column-resize/resize-strategy.mjs +43 -0
- package/esm2022/grid/expansion-toggle.mjs +65 -0
- package/esm2022/grid/grid-module.mjs +137 -0
- package/esm2022/grid/grid-pipes.mjs +113 -0
- package/esm2022/grid/grid-utils.mjs +64 -0
- package/esm2022/grid/grid.mjs +630 -0
- package/esm2022/loader/loader-module.mjs +21 -0
- package/esm2022/loader/loader.mjs +70 -0
- package/esm2022/popover/popover-content.mjs +92 -0
- package/esm2022/popover/popover-module.mjs +25 -0
- package/esm2022/popover/popover-target.mjs +18 -0
- package/esm2022/popover/popover-trigger.mjs +472 -0
- package/esm2022/popover/popover.mjs +384 -0
- package/esm2022/progress/progress-module.mjs +19 -0
- package/esm2022/progress/progress.mjs +56 -0
- package/esm2022/select/option.mjs +58 -0
- package/esm2022/select/select-module.mjs +75 -0
- package/esm2022/select/select.mjs +561 -0
- package/esm2022/select/templates.mjs +135 -0
- package/esm2022/slider/slider-module.mjs +20 -0
- package/esm2022/slider/slider.mjs +1116 -0
- package/esm2022/split/split-module.mjs +20 -0
- package/esm2022/split/split-pane.mjs +150 -0
- package/esm2022/split/split.mjs +635 -0
- package/esm2022/tooltip/tooltip-module.mjs +25 -0
- package/esm2022/tooltip/tooltip.mjs +930 -0
- package/{fesm2020 → fesm2022}/mtxAlert.mjs +7 -7
- package/{fesm2020 → fesm2022}/mtxAlert.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxButton.mjs +7 -7
- package/{fesm2015 → fesm2022}/mtxButton.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxCheckboxGroup.mjs +13 -13
- package/{fesm2020 → fesm2022}/mtxCheckboxGroup.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxColorpicker.mjs +41 -41
- package/{fesm2020 → fesm2022}/mtxColorpicker.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxColumnResize.mjs +46 -46
- package/{fesm2015 → fesm2022}/mtxColumnResize.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxCore.mjs +26 -26
- package/fesm2022/mtxCore.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/mtxDatetimepicker.mjs +84 -80
- package/fesm2022/mtxDatetimepicker.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/mtxDialog.mjs +10 -10
- package/{fesm2015 → fesm2022}/mtxDialog.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxDrawer.mjs +10 -10
- package/{fesm2020 → fesm2022}/mtxDrawer.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxGrid.mjs +120 -120
- package/{fesm2020 → fesm2022}/mtxGrid.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxLoader.mjs +7 -7
- package/{fesm2020 → fesm2022}/mtxLoader.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxPopover.mjs +19 -19
- package/{fesm2020 → fesm2022}/mtxPopover.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxProgress.mjs +7 -7
- package/{fesm2015 → fesm2022}/mtxProgress.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxSelect.mjs +68 -68
- package/{fesm2015 → fesm2022}/mtxSelect.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxSlider.mjs +7 -7
- package/{fesm2020 → fesm2022}/mtxSlider.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxSplit.mjs +10 -10
- package/{fesm2020 → fesm2022}/mtxSplit.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mtxTooltip.mjs +16 -16
- package/{fesm2015 → fesm2022}/mtxTooltip.mjs.map +1 -1
- package/grid/cell.d.ts +1 -1
- package/grid/column-menu.d.ts +1 -1
- package/grid/column-resize/resizable-directives/resizable.d.ts +1 -1
- package/grid/expansion-toggle.d.ts +1 -1
- package/grid/grid.d.ts +2 -2
- package/loader/loader.d.ts +1 -1
- package/package.json +69 -109
- package/popover/popover-trigger.d.ts +1 -1
- package/popover/popover.d.ts +1 -1
- package/progress/progress.d.ts +1 -1
- package/select/option.d.ts +1 -1
- package/select/select.d.ts +1 -1
- package/select/select.scss +0 -7
- package/slider/slider.d.ts +1 -1
- package/split/split-pane.d.ts +1 -1
- package/split/split.d.ts +1 -1
- package/tooltip/tooltip.d.ts +1 -1
- package/tooltip/tooltip.scss +1 -4
- package/esm2020/alert/alert-module.mjs +0 -18
- package/esm2020/alert/alert.mjs +0 -52
- package/esm2020/button/button-loading.mjs +0 -76
- package/esm2020/button/button-module.mjs +0 -20
- package/esm2020/checkbox-group/checkbox-group-module.mjs +0 -21
- package/esm2020/checkbox-group/checkbox-group.mjs +0 -233
- package/esm2020/colorpicker/colorpicker-input.mjs +0 -228
- package/esm2020/colorpicker/colorpicker-module.mjs +0 -63
- package/esm2020/colorpicker/colorpicker-toggle.mjs +0 -101
- package/esm2020/colorpicker/colorpicker.mjs +0 -365
- package/esm2020/column-resize/column-resize-directives/column-resize-flex.mjs +0 -45
- package/esm2020/column-resize/column-resize-directives/column-resize.mjs +0 -45
- package/esm2020/column-resize/column-resize-module.mjs +0 -28
- package/esm2020/column-resize/column-resize-notifier.mjs +0 -47
- package/esm2020/column-resize/column-resize.mjs +0 -82
- package/esm2020/column-resize/column-size-store.mjs +0 -20
- package/esm2020/column-resize/event-dispatcher.mjs +0 -67
- package/esm2020/column-resize/overlay-handle.mjs +0 -146
- package/esm2020/column-resize/resizable.mjs +0 -199
- package/esm2020/column-resize/resize-strategy.mjs +0 -232
- package/esm2020/core/datetime/datetime.module.mjs +0 -42
- package/esm2020/core/datetime/native-datetime-adapter.mjs +0 -138
- package/esm2020/core/pipes/is-template-ref.pipe.mjs +0 -14
- package/esm2020/core/pipes/pipes.module.mjs +0 -19
- package/esm2020/core/pipes/to-observable.pipe.mjs +0 -15
- package/esm2020/datetimepicker/calendar-body.mjs +0 -78
- package/esm2020/datetimepicker/calendar.mjs +0 -671
- package/esm2020/datetimepicker/clock.mjs +0 -349
- package/esm2020/datetimepicker/datetimepicker-input.mjs +0 -349
- package/esm2020/datetimepicker/datetimepicker-intl.mjs +0 -63
- package/esm2020/datetimepicker/datetimepicker-module.mjs +0 -82
- package/esm2020/datetimepicker/datetimepicker-toggle.mjs +0 -104
- package/esm2020/datetimepicker/datetimepicker.mjs +0 -527
- package/esm2020/datetimepicker/month-view.mjs +0 -148
- package/esm2020/datetimepicker/multi-year-view.mjs +0 -214
- package/esm2020/datetimepicker/time.mjs +0 -456
- package/esm2020/datetimepicker/year-view.mjs +0 -138
- package/esm2020/dialog/dialog-container.mjs +0 -35
- package/esm2020/dialog/dialog-module.mjs +0 -24
- package/esm2020/dialog/dialog.mjs +0 -74
- package/esm2020/drawer/drawer-container.mjs +0 -252
- package/esm2020/drawer/drawer-module.mjs +0 -22
- package/esm2020/drawer/drawer.mjs +0 -166
- package/esm2020/grid/cell.mjs +0 -116
- package/esm2020/grid/column-resize/column-resize-directives/column-resize-flex.mjs +0 -37
- package/esm2020/grid/column-resize/column-resize-directives/column-resize.mjs +0 -37
- package/esm2020/grid/column-resize/column-resize-module.mjs +0 -42
- package/esm2020/grid/column-resize/overlay-handle.mjs +0 -60
- package/esm2020/grid/column-resize/resizable-directives/resizable.mjs +0 -62
- package/esm2020/grid/column-resize/resize-strategy.mjs +0 -42
- package/esm2020/grid/expansion-toggle.mjs +0 -64
- package/esm2020/grid/grid-module.mjs +0 -136
- package/esm2020/grid/grid-pipes.mjs +0 -108
- package/esm2020/grid/grid-utils.mjs +0 -63
- package/esm2020/grid/grid.mjs +0 -628
- package/esm2020/loader/loader-module.mjs +0 -20
- package/esm2020/loader/loader.mjs +0 -69
- package/esm2020/popover/popover-content.mjs +0 -90
- package/esm2020/popover/popover-module.mjs +0 -24
- package/esm2020/popover/popover-target.mjs +0 -17
- package/esm2020/popover/popover-trigger.mjs +0 -471
- package/esm2020/popover/popover.mjs +0 -383
- package/esm2020/progress/progress-module.mjs +0 -18
- package/esm2020/progress/progress.mjs +0 -55
- package/esm2020/select/option.mjs +0 -57
- package/esm2020/select/select-module.mjs +0 -74
- package/esm2020/select/select.mjs +0 -560
- package/esm2020/select/templates.mjs +0 -124
- package/esm2020/slider/slider-module.mjs +0 -19
- package/esm2020/slider/slider.mjs +0 -1115
- package/esm2020/split/split-module.mjs +0 -19
- package/esm2020/split/split-pane.mjs +0 -149
- package/esm2020/split/split.mjs +0 -634
- package/esm2020/tooltip/tooltip-module.mjs +0 -24
- package/esm2020/tooltip/tooltip.mjs +0 -926
- package/fesm2015/mtxAlert.mjs +0 -74
- package/fesm2015/mtxAlert.mjs.map +0 -1
- package/fesm2015/mtxButton.mjs +0 -99
- package/fesm2015/mtxCheckboxGroup.mjs +0 -256
- package/fesm2015/mtxCheckboxGroup.mjs.map +0 -1
- package/fesm2015/mtxColorpicker.mjs +0 -767
- package/fesm2015/mtxColorpicker.mjs.map +0 -1
- package/fesm2015/mtxColumnResize.mjs +0 -959
- package/fesm2015/mtxCore.mjs +0 -374
- package/fesm2015/mtxCore.mjs.map +0 -1
- package/fesm2015/mtxDatetimepicker.mjs +0 -3164
- package/fesm2015/mtxDatetimepicker.mjs.map +0 -1
- package/fesm2015/mtxDialog.mjs +0 -130
- package/fesm2015/mtxDrawer.mjs +0 -578
- package/fesm2015/mtxDrawer.mjs.map +0 -1
- package/fesm2015/mtxGrid.mjs +0 -1514
- package/fesm2015/mtxGrid.mjs.map +0 -1
- package/fesm2015/mtxLoader.mjs +0 -93
- package/fesm2015/mtxLoader.mjs.map +0 -1
- package/fesm2015/mtxPopover.mjs +0 -1027
- package/fesm2015/mtxPopover.mjs.map +0 -1
- package/fesm2015/mtxProgress.mjs +0 -77
- package/fesm2015/mtxSelect.mjs +0 -814
- package/fesm2015/mtxSlider.mjs +0 -1139
- package/fesm2015/mtxSlider.mjs.map +0 -1
- package/fesm2015/mtxSplit.mjs +0 -1025
- package/fesm2015/mtxSplit.mjs.map +0 -1
- package/fesm2015/mtxTooltip.mjs +0 -982
- package/fesm2020/mtxButton.mjs.map +0 -1
- package/fesm2020/mtxColumnResize.mjs.map +0 -1
- package/fesm2020/mtxCore.mjs.map +0 -1
- package/fesm2020/mtxDatetimepicker.mjs.map +0 -1
- package/fesm2020/mtxDialog.mjs.map +0 -1
- package/fesm2020/mtxProgress.mjs.map +0 -1
- package/fesm2020/mtxSelect.mjs.map +0 -1
- package/fesm2020/mtxTooltip.mjs.map +0 -1
- package/fesm2020/ng-matero-extensions.mjs +0 -9
- package/fesm2020/ng-matero-extensions.mjs.map +0 -1
- /package/{esm2020 → esm2022}/alert/mtxAlert.mjs +0 -0
- /package/{esm2020 → esm2022}/alert/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/button/mtxButton.mjs +0 -0
- /package/{esm2020 → esm2022}/button/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/checkbox-group/interfaces.mjs +0 -0
- /package/{esm2020 → esm2022}/checkbox-group/mtxCheckboxGroup.mjs +0 -0
- /package/{esm2020 → esm2022}/checkbox-group/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/colorpicker/colorpicker-animations.mjs +0 -0
- /package/{esm2020 → esm2022}/colorpicker/mtxColorpicker.mjs +0 -0
- /package/{esm2020 → esm2022}/colorpicker/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/column-resize/column-resize-directives/constants.mjs +0 -0
- /package/{esm2020 → esm2022}/column-resize/mtxColumnResize.mjs +0 -0
- /package/{esm2020 → esm2022}/column-resize/polyfill.mjs +0 -0
- /package/{esm2020 → esm2022}/column-resize/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/column-resize/resize-ref.mjs +0 -0
- /package/{esm2020 → esm2022}/column-resize/selectors.mjs +0 -0
- /package/{esm2020 → esm2022}/core/datetime/datetime-formats.mjs +0 -0
- /package/{esm2020 → esm2022}/core/datetime/index.mjs +0 -0
- /package/{esm2020 → esm2022}/core/datetime/native-datetime-formats.mjs +0 -0
- /package/{esm2020 → esm2022}/core/mtxCore.mjs +0 -0
- /package/{esm2020 → esm2022}/core/pipes/index.mjs +0 -0
- /package/{esm2020 → esm2022}/core/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/datetimepicker/datetimepicker-animations.mjs +0 -0
- /package/{esm2020 → esm2022}/datetimepicker/datetimepicker-errors.mjs +0 -0
- /package/{esm2020 → esm2022}/datetimepicker/datetimepicker-filtertype.mjs +0 -0
- /package/{esm2020 → esm2022}/datetimepicker/datetimepicker-types.mjs +0 -0
- /package/{esm2020 → esm2022}/datetimepicker/mtxDatetimepicker.mjs +0 -0
- /package/{esm2020 → esm2022}/datetimepicker/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/dialog-config.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/mtxDialog.mjs +0 -0
- /package/{esm2020 → esm2022}/dialog/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/drawer/drawer-animation.mjs +0 -0
- /package/{esm2020 → esm2022}/drawer/drawer-config.mjs +0 -0
- /package/{esm2020 → esm2022}/drawer/drawer-ref.mjs +0 -0
- /package/{esm2020 → esm2022}/drawer/mtxDrawer.mjs +0 -0
- /package/{esm2020 → esm2022}/drawer/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/grid/column-resize/column-resize-directives/common.mjs +0 -0
- /package/{esm2020 → esm2022}/grid/column-resize/resizable-directives/common.mjs +0 -0
- /package/{esm2020 → esm2022}/grid/interfaces.mjs +0 -0
- /package/{esm2020 → esm2022}/grid/mtxGrid.mjs +0 -0
- /package/{esm2020 → esm2022}/grid/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/loader/mtxLoader.mjs +0 -0
- /package/{esm2020 → esm2022}/loader/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/ng-matero-extensions.mjs +0 -0
- /package/{esm2020 → esm2022}/popover/mtxPopover.mjs +0 -0
- /package/{esm2020 → esm2022}/popover/popover-animations.mjs +0 -0
- /package/{esm2020 → esm2022}/popover/popover-errors.mjs +0 -0
- /package/{esm2020 → esm2022}/popover/popover-interfaces.mjs +0 -0
- /package/{esm2020 → esm2022}/popover/popover-types.mjs +0 -0
- /package/{esm2020 → esm2022}/popover/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/progress/mtxProgress.mjs +0 -0
- /package/{esm2020 → esm2022}/progress/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/select/mtxSelect.mjs +0 -0
- /package/{esm2020 → esm2022}/select/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/slider/mtxSlider.mjs +0 -0
- /package/{esm2020 → esm2022}/slider/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/split/interfaces.mjs +0 -0
- /package/{esm2020 → esm2022}/split/mtxSplit.mjs +0 -0
- /package/{esm2020 → esm2022}/split/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/split/utils.mjs +0 -0
- /package/{esm2020 → esm2022}/tooltip/mtxTooltip.mjs +0 -0
- /package/{esm2020 → esm2022}/tooltip/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/tooltip/tooltip-animations.mjs +0 -0
- /package/{fesm2015 → fesm2022}/ng-matero-extensions.mjs +0 -0
- /package/{fesm2015 → fesm2022}/ng-matero-extensions.mjs.map +0 -0
|
@@ -0,0 +1,350 @@
|
|
|
1
|
+
import { Directive, EventEmitter, forwardRef, Inject, Input, Optional, Output, } from '@angular/core';
|
|
2
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, Validators, } from '@angular/forms';
|
|
3
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
4
|
+
import { DOWN_ARROW } from '@angular/cdk/keycodes';
|
|
5
|
+
import { MAT_INPUT_VALUE_ACCESSOR } from '@angular/material/input';
|
|
6
|
+
import { Subscription } from 'rxjs';
|
|
7
|
+
import { MTX_DATETIME_FORMATS, } from '@ng-matero/extensions/core';
|
|
8
|
+
import { createMissingDateImplError } from './datetimepicker-errors';
|
|
9
|
+
import { MtxDatetimepickerFilterType } from './datetimepicker-filtertype';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@ng-matero/extensions/core";
|
|
12
|
+
import * as i2 from "@angular/material/form-field";
|
|
13
|
+
export const MAT_DATETIMEPICKER_VALUE_ACCESSOR = {
|
|
14
|
+
provide: NG_VALUE_ACCESSOR,
|
|
15
|
+
useExisting: forwardRef(() => MtxDatetimepickerInput),
|
|
16
|
+
multi: true,
|
|
17
|
+
};
|
|
18
|
+
export const MAT_DATETIMEPICKER_VALIDATORS = {
|
|
19
|
+
provide: NG_VALIDATORS,
|
|
20
|
+
useExisting: forwardRef(() => MtxDatetimepickerInput),
|
|
21
|
+
multi: true,
|
|
22
|
+
};
|
|
23
|
+
/**
|
|
24
|
+
* An event used for datetimepicker input and change events. We don't always have access to a native
|
|
25
|
+
* input or change event because the event may have been triggered by the user clicking on the
|
|
26
|
+
* calendar popup. For consistency, we always use MtxDatetimepickerInputEvent instead.
|
|
27
|
+
*/
|
|
28
|
+
export class MtxDatetimepickerInputEvent {
|
|
29
|
+
constructor(target, targetElement) {
|
|
30
|
+
this.target = target;
|
|
31
|
+
this.targetElement = targetElement;
|
|
32
|
+
this.value = this.target.value;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
/** Directive used to connect an input to a MtxDatetimepicker. */
|
|
36
|
+
class MtxDatetimepickerInput {
|
|
37
|
+
constructor(_elementRef, _dateAdapter, _dateFormats, _formField) {
|
|
38
|
+
this._elementRef = _elementRef;
|
|
39
|
+
this._dateAdapter = _dateAdapter;
|
|
40
|
+
this._dateFormats = _dateFormats;
|
|
41
|
+
this._formField = _formField;
|
|
42
|
+
/** Emits when a `change` event is fired on this `<input>`. */
|
|
43
|
+
this.dateChange = new EventEmitter();
|
|
44
|
+
/** Emits when an `input` event is fired on this `<input>`. */
|
|
45
|
+
this.dateInput = new EventEmitter();
|
|
46
|
+
/** Emits when the value changes (either due to user input or programmatic change). */
|
|
47
|
+
this._valueChange = new EventEmitter();
|
|
48
|
+
/** Emits when the disabled state has changed */
|
|
49
|
+
this._disabledChange = new EventEmitter();
|
|
50
|
+
this._datetimepickerSubscription = Subscription.EMPTY;
|
|
51
|
+
this._localeSubscription = Subscription.EMPTY;
|
|
52
|
+
/** Whether the last value set on the input was valid. */
|
|
53
|
+
this._lastValueValid = false;
|
|
54
|
+
this._onTouched = () => { };
|
|
55
|
+
this._cvaOnChange = () => { };
|
|
56
|
+
this._validatorOnChange = () => { };
|
|
57
|
+
/** The form control validator for whether the input parses. */
|
|
58
|
+
this._parseValidator = () => {
|
|
59
|
+
return this._lastValueValid
|
|
60
|
+
? null
|
|
61
|
+
: { mtxDatetimepickerParse: { text: this._elementRef.nativeElement.value } };
|
|
62
|
+
};
|
|
63
|
+
/** The form control validator for the min date. */
|
|
64
|
+
this._minValidator = (control) => {
|
|
65
|
+
const controlValue = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(control.value));
|
|
66
|
+
return !this.min ||
|
|
67
|
+
!controlValue ||
|
|
68
|
+
this._dateAdapter.compareDatetime(this.min, controlValue) <= 0
|
|
69
|
+
? null
|
|
70
|
+
: { mtxDatetimepickerMin: { min: this.min, actual: controlValue } };
|
|
71
|
+
};
|
|
72
|
+
/** The form control validator for the max date. */
|
|
73
|
+
this._maxValidator = (control) => {
|
|
74
|
+
const controlValue = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(control.value));
|
|
75
|
+
return !this.max ||
|
|
76
|
+
!controlValue ||
|
|
77
|
+
this._dateAdapter.compareDatetime(this.max, controlValue) >= 0
|
|
78
|
+
? null
|
|
79
|
+
: { mtxDatetimepickerMax: { max: this.max, actual: controlValue } };
|
|
80
|
+
};
|
|
81
|
+
/** The form control validator for the date filter. */
|
|
82
|
+
this._filterValidator = (control) => {
|
|
83
|
+
const controlValue = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(control.value));
|
|
84
|
+
return !this._dateFilter ||
|
|
85
|
+
!controlValue ||
|
|
86
|
+
this._dateFilter(controlValue, MtxDatetimepickerFilterType.DATE)
|
|
87
|
+
? null
|
|
88
|
+
: { mtxDatetimepickerFilter: true };
|
|
89
|
+
};
|
|
90
|
+
/** The combined form control validator for this input. */
|
|
91
|
+
this._validator = Validators.compose([
|
|
92
|
+
this._parseValidator,
|
|
93
|
+
this._minValidator,
|
|
94
|
+
this._maxValidator,
|
|
95
|
+
this._filterValidator,
|
|
96
|
+
]);
|
|
97
|
+
if (!this._dateAdapter) {
|
|
98
|
+
throw createMissingDateImplError('DatetimeAdapter');
|
|
99
|
+
}
|
|
100
|
+
if (!this._dateFormats) {
|
|
101
|
+
throw createMissingDateImplError('MTX_DATETIME_FORMATS');
|
|
102
|
+
}
|
|
103
|
+
// Update the displayed date when the locale changes.
|
|
104
|
+
this._localeSubscription = _dateAdapter.localeChanges.subscribe(() => {
|
|
105
|
+
this.value = this._dateAdapter.deserialize(this.value);
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
/** The datetimepicker that this input is associated with. */
|
|
109
|
+
set mtxDatetimepicker(value) {
|
|
110
|
+
this.registerDatetimepicker(value);
|
|
111
|
+
}
|
|
112
|
+
set mtxDatetimepickerFilter(filter) {
|
|
113
|
+
this._dateFilter = filter;
|
|
114
|
+
this._validatorOnChange();
|
|
115
|
+
}
|
|
116
|
+
/** The value of the input. */
|
|
117
|
+
get value() {
|
|
118
|
+
return this._value;
|
|
119
|
+
}
|
|
120
|
+
set value(value) {
|
|
121
|
+
value = this._dateAdapter.deserialize(value);
|
|
122
|
+
this._lastValueValid = !value || this._dateAdapter.isValid(value);
|
|
123
|
+
value = this._dateAdapter.getValidDateOrNull(value);
|
|
124
|
+
const oldDate = this.value;
|
|
125
|
+
this._value = value;
|
|
126
|
+
this._formatValue(value);
|
|
127
|
+
// use timeout to ensure the datetimepicker is instantiated and we get the correct format
|
|
128
|
+
setTimeout(() => {
|
|
129
|
+
if (!this._dateAdapter.sameDatetime(oldDate, value)) {
|
|
130
|
+
this._valueChange.emit(value);
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
/** The minimum valid date. */
|
|
135
|
+
get min() {
|
|
136
|
+
return this._min;
|
|
137
|
+
}
|
|
138
|
+
set min(value) {
|
|
139
|
+
this._min = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
|
140
|
+
this._validatorOnChange();
|
|
141
|
+
}
|
|
142
|
+
/** The maximum valid date. */
|
|
143
|
+
get max() {
|
|
144
|
+
return this._max;
|
|
145
|
+
}
|
|
146
|
+
set max(value) {
|
|
147
|
+
this._max = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
|
148
|
+
this._validatorOnChange();
|
|
149
|
+
}
|
|
150
|
+
/** Whether the datetimepicker-input is disabled. */
|
|
151
|
+
get disabled() {
|
|
152
|
+
return !!this._disabled;
|
|
153
|
+
}
|
|
154
|
+
set disabled(value) {
|
|
155
|
+
const newValue = coerceBooleanProperty(value);
|
|
156
|
+
if (this._disabled !== newValue) {
|
|
157
|
+
this._disabled = newValue;
|
|
158
|
+
this._disabledChange.emit(newValue);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
ngAfterContentInit() {
|
|
162
|
+
if (this._datetimepicker) {
|
|
163
|
+
this._datetimepickerSubscription = this._datetimepicker.selectedChanged.subscribe((selected) => {
|
|
164
|
+
this.value = selected;
|
|
165
|
+
this._cvaOnChange(selected);
|
|
166
|
+
this._onTouched();
|
|
167
|
+
this.dateInput.emit(new MtxDatetimepickerInputEvent(this, this._elementRef.nativeElement));
|
|
168
|
+
this.dateChange.emit(new MtxDatetimepickerInputEvent(this, this._elementRef.nativeElement));
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
ngOnDestroy() {
|
|
173
|
+
this._datetimepickerSubscription.unsubscribe();
|
|
174
|
+
this._localeSubscription.unsubscribe();
|
|
175
|
+
this._valueChange.complete();
|
|
176
|
+
this._disabledChange.complete();
|
|
177
|
+
}
|
|
178
|
+
registerOnValidatorChange(fn) {
|
|
179
|
+
this._validatorOnChange = fn;
|
|
180
|
+
}
|
|
181
|
+
validate(c) {
|
|
182
|
+
return this._validator ? this._validator(c) : null;
|
|
183
|
+
}
|
|
184
|
+
/**
|
|
185
|
+
* Gets the element that the datetimepicker popup should be connected to.
|
|
186
|
+
* @return The element to connect the popup to.
|
|
187
|
+
*/
|
|
188
|
+
getConnectedOverlayOrigin() {
|
|
189
|
+
return this._formField ? this._formField.getConnectedOverlayOrigin() : this._elementRef;
|
|
190
|
+
}
|
|
191
|
+
/** Gets the ID of an element that should be used a description for the calendar overlay. */
|
|
192
|
+
getOverlayLabelId() {
|
|
193
|
+
if (this._formField) {
|
|
194
|
+
return this._formField.getLabelId();
|
|
195
|
+
}
|
|
196
|
+
return this._elementRef.nativeElement.getAttribute('aria-labelledby');
|
|
197
|
+
}
|
|
198
|
+
// Implemented as part of ControlValueAccessor
|
|
199
|
+
writeValue(value) {
|
|
200
|
+
this.value = value;
|
|
201
|
+
}
|
|
202
|
+
// Implemented as part of ControlValueAccessor
|
|
203
|
+
registerOnChange(fn) {
|
|
204
|
+
this._cvaOnChange = fn;
|
|
205
|
+
}
|
|
206
|
+
// Implemented as part of ControlValueAccessor
|
|
207
|
+
registerOnTouched(fn) {
|
|
208
|
+
this._onTouched = fn;
|
|
209
|
+
}
|
|
210
|
+
// Implemented as part of ControlValueAccessor
|
|
211
|
+
setDisabledState(disabled) {
|
|
212
|
+
this.disabled = disabled;
|
|
213
|
+
}
|
|
214
|
+
_onKeydown(event) {
|
|
215
|
+
if (event.altKey && event.keyCode === DOWN_ARROW) {
|
|
216
|
+
this._datetimepicker.open();
|
|
217
|
+
event.preventDefault();
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
_onInput(value) {
|
|
221
|
+
let date = this._dateAdapter.parse(value, this.getParseFormat());
|
|
222
|
+
this._lastValueValid = !date || this._dateAdapter.isValid(date);
|
|
223
|
+
date = this._dateAdapter.getValidDateOrNull(date);
|
|
224
|
+
this._value = date;
|
|
225
|
+
this._cvaOnChange(date);
|
|
226
|
+
this._valueChange.emit(date);
|
|
227
|
+
this.dateInput.emit(new MtxDatetimepickerInputEvent(this, this._elementRef.nativeElement));
|
|
228
|
+
}
|
|
229
|
+
_onChange() {
|
|
230
|
+
this.dateChange.emit(new MtxDatetimepickerInputEvent(this, this._elementRef.nativeElement));
|
|
231
|
+
}
|
|
232
|
+
/** Handles blur events on the input. */
|
|
233
|
+
_onBlur() {
|
|
234
|
+
// Reformat the input only if we have a valid value.
|
|
235
|
+
if (this.value) {
|
|
236
|
+
this._formatValue(this.value);
|
|
237
|
+
}
|
|
238
|
+
this._onTouched();
|
|
239
|
+
}
|
|
240
|
+
registerDatetimepicker(value) {
|
|
241
|
+
if (value) {
|
|
242
|
+
this._datetimepicker = value;
|
|
243
|
+
this._datetimepicker._registerInput(this);
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
getDisplayFormat() {
|
|
247
|
+
switch (this._datetimepicker.type) {
|
|
248
|
+
case 'date':
|
|
249
|
+
return this._dateFormats.display.dateInput;
|
|
250
|
+
case 'datetime':
|
|
251
|
+
return this._dateFormats.display.datetimeInput;
|
|
252
|
+
case 'time':
|
|
253
|
+
return this._dateFormats.display.timeInput;
|
|
254
|
+
case 'month':
|
|
255
|
+
return this._dateFormats.display.monthInput;
|
|
256
|
+
case 'year':
|
|
257
|
+
return this._dateFormats.display.yearInput;
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
getParseFormat() {
|
|
261
|
+
let parseFormat;
|
|
262
|
+
switch (this._datetimepicker.type) {
|
|
263
|
+
case 'date':
|
|
264
|
+
parseFormat = this._dateFormats.parse.dateInput;
|
|
265
|
+
break;
|
|
266
|
+
case 'datetime':
|
|
267
|
+
parseFormat = this._dateFormats.parse.datetimeInput;
|
|
268
|
+
break;
|
|
269
|
+
case 'time':
|
|
270
|
+
parseFormat = this._dateFormats.parse.timeInput;
|
|
271
|
+
break;
|
|
272
|
+
case 'month':
|
|
273
|
+
parseFormat = this._dateFormats.parse.monthInput;
|
|
274
|
+
break;
|
|
275
|
+
case 'year':
|
|
276
|
+
parseFormat = this._dateFormats.parse.yearInput;
|
|
277
|
+
break;
|
|
278
|
+
}
|
|
279
|
+
if (!parseFormat) {
|
|
280
|
+
parseFormat = this._dateFormats.parse.dateInput;
|
|
281
|
+
}
|
|
282
|
+
return parseFormat;
|
|
283
|
+
}
|
|
284
|
+
/** Formats a value and sets it on the input element. */
|
|
285
|
+
_formatValue(value) {
|
|
286
|
+
this._elementRef.nativeElement.value = value
|
|
287
|
+
? this._dateAdapter.format(value, this.getDisplayFormat())
|
|
288
|
+
: '';
|
|
289
|
+
}
|
|
290
|
+
/** Returns the palette used by the input's form field, if any. */
|
|
291
|
+
getThemePalette() {
|
|
292
|
+
return this._formField ? this._formField.color : undefined;
|
|
293
|
+
}
|
|
294
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: MtxDatetimepickerInput, deps: [{ token: i0.ElementRef }, { token: i1.DatetimeAdapter, optional: true }, { token: MTX_DATETIME_FORMATS, optional: true }, { token: i2.MatFormField, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
295
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.3", type: MtxDatetimepickerInput, selector: "input[mtxDatetimepicker]", inputs: { mtxDatetimepicker: "mtxDatetimepicker", mtxDatetimepickerFilter: "mtxDatetimepickerFilter", value: "value", min: "min", max: "max", disabled: "disabled" }, outputs: { dateChange: "dateChange", dateInput: "dateInput" }, host: { listeners: { "input": "_onInput($event.target.value)", "change": "_onChange()", "blur": "_onBlur()", "keydown": "_onKeydown($event)" }, properties: { "attr.aria-haspopup": "true", "attr.aria-owns": "(_datetimepicker?.opened && _datetimepicker.id) || null", "attr.min": "min ? _dateAdapter.toIso8601(min) : null", "attr.max": "max ? _dateAdapter.toIso8601(max) : null", "disabled": "disabled" } }, providers: [
|
|
296
|
+
MAT_DATETIMEPICKER_VALUE_ACCESSOR,
|
|
297
|
+
MAT_DATETIMEPICKER_VALIDATORS,
|
|
298
|
+
{ provide: MAT_INPUT_VALUE_ACCESSOR, useExisting: MtxDatetimepickerInput },
|
|
299
|
+
], exportAs: ["mtxDatetimepickerInput"], ngImport: i0 }); }
|
|
300
|
+
}
|
|
301
|
+
export { MtxDatetimepickerInput };
|
|
302
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: MtxDatetimepickerInput, decorators: [{
|
|
303
|
+
type: Directive,
|
|
304
|
+
args: [{
|
|
305
|
+
selector: 'input[mtxDatetimepicker]',
|
|
306
|
+
providers: [
|
|
307
|
+
MAT_DATETIMEPICKER_VALUE_ACCESSOR,
|
|
308
|
+
MAT_DATETIMEPICKER_VALIDATORS,
|
|
309
|
+
{ provide: MAT_INPUT_VALUE_ACCESSOR, useExisting: MtxDatetimepickerInput },
|
|
310
|
+
],
|
|
311
|
+
host: {
|
|
312
|
+
'[attr.aria-haspopup]': 'true',
|
|
313
|
+
'[attr.aria-owns]': '(_datetimepicker?.opened && _datetimepicker.id) || null',
|
|
314
|
+
'[attr.min]': 'min ? _dateAdapter.toIso8601(min) : null',
|
|
315
|
+
'[attr.max]': 'max ? _dateAdapter.toIso8601(max) : null',
|
|
316
|
+
'[disabled]': 'disabled',
|
|
317
|
+
'(input)': '_onInput($event.target.value)',
|
|
318
|
+
'(change)': '_onChange()',
|
|
319
|
+
'(blur)': '_onBlur()',
|
|
320
|
+
'(keydown)': '_onKeydown($event)',
|
|
321
|
+
},
|
|
322
|
+
exportAs: 'mtxDatetimepickerInput',
|
|
323
|
+
}]
|
|
324
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.DatetimeAdapter, decorators: [{
|
|
325
|
+
type: Optional
|
|
326
|
+
}] }, { type: undefined, decorators: [{
|
|
327
|
+
type: Optional
|
|
328
|
+
}, {
|
|
329
|
+
type: Inject,
|
|
330
|
+
args: [MTX_DATETIME_FORMATS]
|
|
331
|
+
}] }, { type: i2.MatFormField, decorators: [{
|
|
332
|
+
type: Optional
|
|
333
|
+
}] }]; }, propDecorators: { dateChange: [{
|
|
334
|
+
type: Output
|
|
335
|
+
}], dateInput: [{
|
|
336
|
+
type: Output
|
|
337
|
+
}], mtxDatetimepicker: [{
|
|
338
|
+
type: Input
|
|
339
|
+
}], mtxDatetimepickerFilter: [{
|
|
340
|
+
type: Input
|
|
341
|
+
}], value: [{
|
|
342
|
+
type: Input
|
|
343
|
+
}], min: [{
|
|
344
|
+
type: Input
|
|
345
|
+
}], max: [{
|
|
346
|
+
type: Input
|
|
347
|
+
}], disabled: [{
|
|
348
|
+
type: Input
|
|
349
|
+
}] } });
|
|
350
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetimepicker-input.js","sourceRoot":"","sources":["../../../../projects/extensions/datetimepicker/datetimepicker-input.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { DOWN_ARROW } from '@angular/cdk/keycodes';\nimport { ThemePalette } from '@angular/material/core';\nimport { MAT_INPUT_VALUE_ACCESSOR } from '@angular/material/input';\nimport { MatFormField } from '@angular/material/form-field';\nimport { Subscription } from 'rxjs';\nimport {\n  DatetimeAdapter,\n  MTX_DATETIME_FORMATS,\n  MtxDatetimeFormats,\n} from '@ng-matero/extensions/core';\nimport { MtxDatetimepicker } from './datetimepicker';\nimport { createMissingDateImplError } from './datetimepicker-errors';\nimport { MtxDatetimepickerFilterType } from './datetimepicker-filtertype';\n\nexport const MAT_DATETIMEPICKER_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => MtxDatetimepickerInput),\n  multi: true,\n};\n\nexport const MAT_DATETIMEPICKER_VALIDATORS: any = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => MtxDatetimepickerInput),\n  multi: true,\n};\n\n/**\n * An event used for datetimepicker input and change events. We don't always have access to a native\n * input or change event because the event may have been triggered by the user clicking on the\n * calendar popup. For consistency, we always use MtxDatetimepickerInputEvent instead.\n */\nexport class MtxDatetimepickerInputEvent<D> {\n  /** The new value for the target datetimepicker input. */\n  value: D | null;\n\n  constructor(public target: MtxDatetimepickerInput<D>, public targetElement: HTMLElement) {\n    this.value = this.target.value;\n  }\n}\n\n/** Directive used to connect an input to a MtxDatetimepicker. */\n@Directive({\n  selector: 'input[mtxDatetimepicker]',\n  providers: [\n    MAT_DATETIMEPICKER_VALUE_ACCESSOR,\n    MAT_DATETIMEPICKER_VALIDATORS,\n    { provide: MAT_INPUT_VALUE_ACCESSOR, useExisting: MtxDatetimepickerInput },\n  ],\n  host: {\n    '[attr.aria-haspopup]': 'true',\n    '[attr.aria-owns]': '(_datetimepicker?.opened && _datetimepicker.id) || null',\n    '[attr.min]': 'min ? _dateAdapter.toIso8601(min) : null',\n    '[attr.max]': 'max ? _dateAdapter.toIso8601(max) : null',\n    '[disabled]': 'disabled',\n    '(input)': '_onInput($event.target.value)',\n    '(change)': '_onChange()',\n    '(blur)': '_onBlur()',\n    '(keydown)': '_onKeydown($event)',\n  },\n  exportAs: 'mtxDatetimepickerInput',\n})\nexport class MtxDatetimepickerInput<D>\n  implements AfterContentInit, ControlValueAccessor, OnDestroy, Validator\n{\n  _datetimepicker!: MtxDatetimepicker<D>;\n\n  _dateFilter!: (date: D | null, type: MtxDatetimepickerFilterType) => boolean;\n\n  /** Emits when a `change` event is fired on this `<input>`. */\n  @Output() dateChange = new EventEmitter<MtxDatetimepickerInputEvent<D>>();\n\n  /** Emits when an `input` event is fired on this `<input>`. */\n  @Output() dateInput = new EventEmitter<MtxDatetimepickerInputEvent<D>>();\n\n  /** Emits when the value changes (either due to user input or programmatic change). */\n  _valueChange = new EventEmitter<D | null>();\n\n  /** Emits when the disabled state has changed */\n  _disabledChange = new EventEmitter<boolean>();\n\n  private _datetimepickerSubscription = Subscription.EMPTY;\n\n  private _localeSubscription = Subscription.EMPTY;\n\n  /** Whether the last value set on the input was valid. */\n  private _lastValueValid = false;\n\n  constructor(\n    private _elementRef: ElementRef,\n    @Optional() public _dateAdapter: DatetimeAdapter<D>,\n    @Optional() @Inject(MTX_DATETIME_FORMATS) private _dateFormats: MtxDatetimeFormats,\n    @Optional() private _formField: MatFormField\n  ) {\n    if (!this._dateAdapter) {\n      throw createMissingDateImplError('DatetimeAdapter');\n    }\n    if (!this._dateFormats) {\n      throw createMissingDateImplError('MTX_DATETIME_FORMATS');\n    }\n\n    // Update the displayed date when the locale changes.\n    this._localeSubscription = _dateAdapter.localeChanges.subscribe(() => {\n      this.value = this._dateAdapter.deserialize(this.value);\n    });\n  }\n\n  /** The datetimepicker that this input is associated with. */\n  @Input()\n  set mtxDatetimepicker(value: MtxDatetimepicker<D>) {\n    this.registerDatetimepicker(value);\n  }\n\n  @Input()\n  set mtxDatetimepickerFilter(\n    filter: (date: D | null, type: MtxDatetimepickerFilterType) => boolean\n  ) {\n    this._dateFilter = filter;\n    this._validatorOnChange();\n  }\n\n  /** The value of the input. */\n  @Input()\n  get value(): D | null {\n    return this._value;\n  }\n  set value(value: D | null) {\n    value = this._dateAdapter.deserialize(value);\n    this._lastValueValid = !value || this._dateAdapter.isValid(value);\n    value = this._dateAdapter.getValidDateOrNull(value);\n    const oldDate = this.value;\n    this._value = value;\n    this._formatValue(value);\n\n    // use timeout to ensure the datetimepicker is instantiated and we get the correct format\n    setTimeout(() => {\n      if (!this._dateAdapter.sameDatetime(oldDate, value)) {\n        this._valueChange.emit(value);\n      }\n    });\n  }\n  private _value!: D | null;\n\n  /** The minimum valid date. */\n  @Input()\n  get min(): D | null {\n    return this._min;\n  }\n  set min(value: D | null) {\n    this._min = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n    this._validatorOnChange();\n  }\n  private _min!: D | null;\n\n  /** The maximum valid date. */\n  @Input()\n  get max(): D | null {\n    return this._max;\n  }\n  set max(value: D | null) {\n    this._max = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n    this._validatorOnChange();\n  }\n  private _max!: D | null;\n\n  /** Whether the datetimepicker-input is disabled. */\n  @Input()\n  get disabled(): boolean {\n    return !!this._disabled;\n  }\n  set disabled(value: boolean) {\n    const newValue = coerceBooleanProperty(value);\n\n    if (this._disabled !== newValue) {\n      this._disabled = newValue;\n      this._disabledChange.emit(newValue);\n    }\n  }\n  private _disabled!: boolean;\n\n  _onTouched = () => {};\n\n  ngAfterContentInit() {\n    if (this._datetimepicker) {\n      this._datetimepickerSubscription = this._datetimepicker.selectedChanged.subscribe(\n        (selected: D) => {\n          this.value = selected;\n          this._cvaOnChange(selected);\n          this._onTouched();\n          this.dateInput.emit(\n            new MtxDatetimepickerInputEvent(this, this._elementRef.nativeElement)\n          );\n          this.dateChange.emit(\n            new MtxDatetimepickerInputEvent(this, this._elementRef.nativeElement)\n          );\n        }\n      );\n    }\n  }\n\n  ngOnDestroy() {\n    this._datetimepickerSubscription.unsubscribe();\n    this._localeSubscription.unsubscribe();\n    this._valueChange.complete();\n    this._disabledChange.complete();\n  }\n\n  registerOnValidatorChange(fn: () => void): void {\n    this._validatorOnChange = fn;\n  }\n\n  validate(c: AbstractControl): ValidationErrors | null {\n    return this._validator ? this._validator(c) : null;\n  }\n\n  /**\n   * Gets the element that the datetimepicker popup should be connected to.\n   * @return The element to connect the popup to.\n   */\n  getConnectedOverlayOrigin(): ElementRef {\n    return this._formField ? this._formField.getConnectedOverlayOrigin() : this._elementRef;\n  }\n\n  /** Gets the ID of an element that should be used a description for the calendar overlay. */\n  getOverlayLabelId(): string | null {\n    if (this._formField) {\n      return this._formField.getLabelId();\n    }\n\n    return this._elementRef.nativeElement.getAttribute('aria-labelledby');\n  }\n\n  // Implemented as part of ControlValueAccessor\n  writeValue(value: D): void {\n    this.value = value;\n  }\n\n  // Implemented as part of ControlValueAccessor\n  registerOnChange(fn: (value: any) => void): void {\n    this._cvaOnChange = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor\n  registerOnTouched(fn: () => void): void {\n    this._onTouched = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n  }\n\n  _onKeydown(event: KeyboardEvent) {\n    if (event.altKey && event.keyCode === DOWN_ARROW) {\n      this._datetimepicker.open();\n      event.preventDefault();\n    }\n  }\n\n  _onInput(value: string) {\n    let date = this._dateAdapter.parse(value, this.getParseFormat());\n    this._lastValueValid = !date || this._dateAdapter.isValid(date);\n    date = this._dateAdapter.getValidDateOrNull(date);\n    this._value = date;\n    this._cvaOnChange(date);\n    this._valueChange.emit(date);\n    this.dateInput.emit(new MtxDatetimepickerInputEvent(this, this._elementRef.nativeElement));\n  }\n\n  _onChange() {\n    this.dateChange.emit(new MtxDatetimepickerInputEvent(this, this._elementRef.nativeElement));\n  }\n\n  /** Handles blur events on the input. */\n  _onBlur() {\n    // Reformat the input only if we have a valid value.\n    if (this.value) {\n      this._formatValue(this.value);\n    }\n\n    this._onTouched();\n  }\n\n  private registerDatetimepicker(value: MtxDatetimepicker<D>) {\n    if (value) {\n      this._datetimepicker = value;\n      this._datetimepicker._registerInput(this);\n    }\n  }\n\n  private getDisplayFormat() {\n    switch (this._datetimepicker.type) {\n      case 'date':\n        return this._dateFormats.display.dateInput;\n      case 'datetime':\n        return this._dateFormats.display.datetimeInput;\n      case 'time':\n        return this._dateFormats.display.timeInput;\n      case 'month':\n        return this._dateFormats.display.monthInput;\n      case 'year':\n        return this._dateFormats.display.yearInput;\n    }\n  }\n\n  private getParseFormat() {\n    let parseFormat;\n\n    switch (this._datetimepicker.type) {\n      case 'date':\n        parseFormat = this._dateFormats.parse.dateInput;\n        break;\n      case 'datetime':\n        parseFormat = this._dateFormats.parse.datetimeInput;\n        break;\n      case 'time':\n        parseFormat = this._dateFormats.parse.timeInput;\n        break;\n      case 'month':\n        parseFormat = this._dateFormats.parse.monthInput;\n        break;\n      case 'year':\n        parseFormat = this._dateFormats.parse.yearInput;\n        break;\n    }\n    if (!parseFormat) {\n      parseFormat = this._dateFormats.parse.dateInput;\n    }\n\n    return parseFormat;\n  }\n\n  private _cvaOnChange: (value: any) => void = () => {};\n\n  private _validatorOnChange = () => {};\n\n  /** The form control validator for whether the input parses. */\n  private _parseValidator: ValidatorFn = (): ValidationErrors | null => {\n    return this._lastValueValid\n      ? null\n      : { mtxDatetimepickerParse: { text: this._elementRef.nativeElement.value } };\n  };\n\n  /** The form control validator for the min date. */\n  private _minValidator: ValidatorFn = (control: AbstractControl): ValidationErrors | null => {\n    const controlValue = this._dateAdapter.getValidDateOrNull(\n      this._dateAdapter.deserialize(control.value)\n    );\n    return !this.min ||\n      !controlValue ||\n      (this._dateAdapter.compareDatetime(this.min, controlValue) as number) <= 0\n      ? null\n      : { mtxDatetimepickerMin: { min: this.min, actual: controlValue } };\n  };\n\n  /** The form control validator for the max date. */\n  private _maxValidator: ValidatorFn = (control: AbstractControl): ValidationErrors | null => {\n    const controlValue = this._dateAdapter.getValidDateOrNull(\n      this._dateAdapter.deserialize(control.value)\n    );\n    return !this.max ||\n      !controlValue ||\n      (this._dateAdapter.compareDatetime(this.max, controlValue) as number) >= 0\n      ? null\n      : { mtxDatetimepickerMax: { max: this.max, actual: controlValue } };\n  };\n\n  /** The form control validator for the date filter. */\n  private _filterValidator: ValidatorFn = (control: AbstractControl): ValidationErrors | null => {\n    const controlValue = this._dateAdapter.getValidDateOrNull(\n      this._dateAdapter.deserialize(control.value)\n    );\n    return !this._dateFilter ||\n      !controlValue ||\n      this._dateFilter(controlValue, MtxDatetimepickerFilterType.DATE)\n      ? null\n      : { mtxDatetimepickerFilter: true };\n  };\n\n  /** The combined form control validator for this input. */\n  private _validator: ValidatorFn | null = Validators.compose([\n    this._parseValidator,\n    this._minValidator,\n    this._maxValidator,\n    this._filterValidator,\n  ]);\n\n  /** Formats a value and sets it on the input element. */\n  private _formatValue(value: D | null) {\n    this._elementRef.nativeElement.value = value\n      ? this._dateAdapter.format(value, this.getDisplayFormat())\n      : '';\n  }\n\n  /** Returns the palette used by the input's form field, if any. */\n  getThemePalette(): ThemePalette {\n    return this._formField ? this._formField.color : undefined;\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n"]}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
class MtxDatetimepickerIntl {
|
|
5
|
+
constructor() {
|
|
6
|
+
/**
|
|
7
|
+
* Stream to emit from when labels are changed. Use this to notify components when the labels have
|
|
8
|
+
* changed after initialization.
|
|
9
|
+
*/
|
|
10
|
+
this.changes = new Subject();
|
|
11
|
+
/** A label for the calendar popup (used by screen readers). */
|
|
12
|
+
this.calendarLabel = 'Calendar';
|
|
13
|
+
/** A label for the button used to open the calendar popup (used by screen readers). */
|
|
14
|
+
this.openCalendarLabel = 'Open calendar';
|
|
15
|
+
/** Label for the button used to close the calendar popup. */
|
|
16
|
+
this.closeCalendarLabel = 'Close calendar';
|
|
17
|
+
/** A label for the previous month button (used by screen readers). */
|
|
18
|
+
this.prevMonthLabel = 'Previous month';
|
|
19
|
+
/** A label for the next month button (used by screen readers). */
|
|
20
|
+
this.nextMonthLabel = 'Next month';
|
|
21
|
+
/** A label for the previous year button (used by screen readers). */
|
|
22
|
+
this.prevYearLabel = 'Previous year';
|
|
23
|
+
/** A label for the next year button (used by screen readers). */
|
|
24
|
+
this.nextYearLabel = 'Next year';
|
|
25
|
+
/** A label for the previous multi-year button (used by screen readers). */
|
|
26
|
+
this.prevMultiYearLabel = 'Previous 24 years';
|
|
27
|
+
/** A label for the next multi-year button (used by screen readers). */
|
|
28
|
+
this.nextMultiYearLabel = 'Next 24 years';
|
|
29
|
+
/** A label for the 'switch to month view' button (used by screen readers). */
|
|
30
|
+
this.switchToMonthViewLabel = 'Choose date';
|
|
31
|
+
/** A label for the 'switch to year view' button (used by screen readers). */
|
|
32
|
+
this.switchToYearViewLabel = 'Choose month';
|
|
33
|
+
/** A label for the 'switch to multi-year view' button (used by screen readers). */
|
|
34
|
+
this.switchToMultiYearViewLabel = 'Choose month and year';
|
|
35
|
+
/** A label for the first date of a range of dates (used by screen readers). */
|
|
36
|
+
this.startDateLabel = 'Start date';
|
|
37
|
+
/** A label for the last date of a range of dates (used by screen readers). */
|
|
38
|
+
this.endDateLabel = 'End date';
|
|
39
|
+
/** A label for the 'switch to clock hour view' button (used by screen readers). */
|
|
40
|
+
this.switchToClockHourViewLabel = 'Choose hour';
|
|
41
|
+
/** A label for the 'switch to clock minute view' button (used by screen readers). */
|
|
42
|
+
this.switchToClockMinuteViewLabel = 'Choose minute';
|
|
43
|
+
/** Label used for ok button within the manual time input. */
|
|
44
|
+
this.okLabel = 'OK';
|
|
45
|
+
/** Label used for cancel button within the manual time input. */
|
|
46
|
+
this.cancelLabel = 'Cancel';
|
|
47
|
+
}
|
|
48
|
+
/** Formats a range of years (used for visuals). */
|
|
49
|
+
formatYearRange(start, end) {
|
|
50
|
+
return `${start} \u2013 ${end}`;
|
|
51
|
+
}
|
|
52
|
+
/** Formats a label for a range of years (used by screen readers). */
|
|
53
|
+
formatYearRangeLabel(start, end) {
|
|
54
|
+
return `${start} to ${end}`;
|
|
55
|
+
}
|
|
56
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: MtxDatetimepickerIntl, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
57
|
+
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: MtxDatetimepickerIntl, providedIn: 'root' }); }
|
|
58
|
+
}
|
|
59
|
+
export { MtxDatetimepickerIntl };
|
|
60
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: MtxDatetimepickerIntl, decorators: [{
|
|
61
|
+
type: Injectable,
|
|
62
|
+
args: [{ providedIn: 'root' }]
|
|
63
|
+
}] });
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXRpbWVwaWNrZXItaW50bC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2V4dGVuc2lvbnMvZGF0ZXRpbWVwaWNrZXIvZGF0ZXRpbWVwaWNrZXItaW50bC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBRS9CLE1BQ2EscUJBQXFCO0lBRGxDO1FBRUU7OztXQUdHO1FBQ00sWUFBTyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFFdkMsK0RBQStEO1FBQy9ELGtCQUFhLEdBQUcsVUFBVSxDQUFDO1FBRTNCLHVGQUF1RjtRQUN2RixzQkFBaUIsR0FBRyxlQUFlLENBQUM7UUFFcEMsNkRBQTZEO1FBQzdELHVCQUFrQixHQUFHLGdCQUFnQixDQUFDO1FBRXRDLHNFQUFzRTtRQUN0RSxtQkFBYyxHQUFHLGdCQUFnQixDQUFDO1FBRWxDLGtFQUFrRTtRQUNsRSxtQkFBYyxHQUFHLFlBQVksQ0FBQztRQUU5QixxRUFBcUU7UUFDckUsa0JBQWEsR0FBRyxlQUFlLENBQUM7UUFFaEMsaUVBQWlFO1FBQ2pFLGtCQUFhLEdBQUcsV0FBVyxDQUFDO1FBRTVCLDJFQUEyRTtRQUMzRSx1QkFBa0IsR0FBRyxtQkFBbUIsQ0FBQztRQUV6Qyx1RUFBdUU7UUFDdkUsdUJBQWtCLEdBQUcsZUFBZSxDQUFDO1FBRXJDLDhFQUE4RTtRQUM5RSwyQkFBc0IsR0FBRyxhQUFhLENBQUM7UUFFdkMsNkVBQTZFO1FBQzdFLDBCQUFxQixHQUFHLGNBQWMsQ0FBQztRQUV2QyxtRkFBbUY7UUFDbkYsK0JBQTBCLEdBQUcsdUJBQXVCLENBQUM7UUFFckQsK0VBQStFO1FBQy9FLG1CQUFjLEdBQUcsWUFBWSxDQUFDO1FBRTlCLDhFQUE4RTtRQUM5RSxpQkFBWSxHQUFHLFVBQVUsQ0FBQztRQVkxQixtRkFBbUY7UUFDbkYsK0JBQTBCLEdBQUcsYUFBYSxDQUFDO1FBRTNDLHFGQUFxRjtRQUNyRixpQ0FBNEIsR0FBRyxlQUFlLENBQUM7UUFFL0MsNkRBQTZEO1FBQzdELFlBQU8sR0FBRyxJQUFJLENBQUM7UUFFZixpRUFBaUU7UUFDakUsZ0JBQVcsR0FBRyxRQUFRLENBQUM7S0FDeEI7SUFyQkMsbURBQW1EO0lBQ25ELGVBQWUsQ0FBQyxLQUFhLEVBQUUsR0FBVztRQUN4QyxPQUFPLEdBQUcsS0FBSyxXQUFXLEdBQUcsRUFBRSxDQUFDO0lBQ2xDLENBQUM7SUFFRCxxRUFBcUU7SUFDckUsb0JBQW9CLENBQUMsS0FBYSxFQUFFLEdBQVc7UUFDN0MsT0FBTyxHQUFHLEtBQUssT0FBTyxHQUFHLEVBQUUsQ0FBQztJQUM5QixDQUFDO2lJQXpEVSxxQkFBcUI7cUlBQXJCLHFCQUFxQixjQURSLE1BQU07O1NBQ25CLHFCQUFxQjsyRkFBckIscUJBQXFCO2tCQURqQyxVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBNdHhEYXRldGltZXBpY2tlckludGwge1xuICAvKipcbiAgICogU3RyZWFtIHRvIGVtaXQgZnJvbSB3aGVuIGxhYmVscyBhcmUgY2hhbmdlZC4gVXNlIHRoaXMgdG8gbm90aWZ5IGNvbXBvbmVudHMgd2hlbiB0aGUgbGFiZWxzIGhhdmVcbiAgICogY2hhbmdlZCBhZnRlciBpbml0aWFsaXphdGlvbi5cbiAgICovXG4gIHJlYWRvbmx5IGNoYW5nZXMgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgY2FsZW5kYXIgcG9wdXAgKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBjYWxlbmRhckxhYmVsID0gJ0NhbGVuZGFyJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlIGJ1dHRvbiB1c2VkIHRvIG9wZW4gdGhlIGNhbGVuZGFyIHBvcHVwICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gKi9cbiAgb3BlbkNhbGVuZGFyTGFiZWwgPSAnT3BlbiBjYWxlbmRhcic7XG5cbiAgLyoqIExhYmVsIGZvciB0aGUgYnV0dG9uIHVzZWQgdG8gY2xvc2UgdGhlIGNhbGVuZGFyIHBvcHVwLiAqL1xuICBjbG9zZUNhbGVuZGFyTGFiZWwgPSAnQ2xvc2UgY2FsZW5kYXInO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgcHJldmlvdXMgbW9udGggYnV0dG9uICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gKi9cbiAgcHJldk1vbnRoTGFiZWwgPSAnUHJldmlvdXMgbW9udGgnO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgbmV4dCBtb250aCBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBuZXh0TW9udGhMYWJlbCA9ICdOZXh0IG1vbnRoJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlIHByZXZpb3VzIHllYXIgYnV0dG9uICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gKi9cbiAgcHJldlllYXJMYWJlbCA9ICdQcmV2aW91cyB5ZWFyJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlIG5leHQgeWVhciBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBuZXh0WWVhckxhYmVsID0gJ05leHQgeWVhcic7XG5cbiAgLyoqIEEgbGFiZWwgZm9yIHRoZSBwcmV2aW91cyBtdWx0aS15ZWFyIGJ1dHRvbiAodXNlZCBieSBzY3JlZW4gcmVhZGVycykuICovXG4gIHByZXZNdWx0aVllYXJMYWJlbCA9ICdQcmV2aW91cyAyNCB5ZWFycyc7XG5cbiAgLyoqIEEgbGFiZWwgZm9yIHRoZSBuZXh0IG11bHRpLXllYXIgYnV0dG9uICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gKi9cbiAgbmV4dE11bHRpWWVhckxhYmVsID0gJ05leHQgMjQgeWVhcnMnO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgJ3N3aXRjaCB0byBtb250aCB2aWV3JyBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBzd2l0Y2hUb01vbnRoVmlld0xhYmVsID0gJ0Nob29zZSBkYXRlJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlICdzd2l0Y2ggdG8geWVhciB2aWV3JyBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBzd2l0Y2hUb1llYXJWaWV3TGFiZWwgPSAnQ2hvb3NlIG1vbnRoJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlICdzd2l0Y2ggdG8gbXVsdGkteWVhciB2aWV3JyBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBzd2l0Y2hUb011bHRpWWVhclZpZXdMYWJlbCA9ICdDaG9vc2UgbW9udGggYW5kIHllYXInO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgZmlyc3QgZGF0ZSBvZiBhIHJhbmdlIG9mIGRhdGVzICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gKi9cbiAgc3RhcnREYXRlTGFiZWwgPSAnU3RhcnQgZGF0ZSc7XG5cbiAgLyoqIEEgbGFiZWwgZm9yIHRoZSBsYXN0IGRhdGUgb2YgYSByYW5nZSBvZiBkYXRlcyAodXNlZCBieSBzY3JlZW4gcmVhZGVycykuICovXG4gIGVuZERhdGVMYWJlbCA9ICdFbmQgZGF0ZSc7XG5cbiAgLyoqIEZvcm1hdHMgYSByYW5nZSBvZiB5ZWFycyAodXNlZCBmb3IgdmlzdWFscykuICovXG4gIGZvcm1hdFllYXJSYW5nZShzdGFydDogc3RyaW5nLCBlbmQ6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke3N0YXJ0fSBcXHUyMDEzICR7ZW5kfWA7XG4gIH1cblxuICAvKiogRm9ybWF0cyBhIGxhYmVsIGZvciBhIHJhbmdlIG9mIHllYXJzICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gKi9cbiAgZm9ybWF0WWVhclJhbmdlTGFiZWwoc3RhcnQ6IHN0cmluZywgZW5kOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBgJHtzdGFydH0gdG8gJHtlbmR9YDtcbiAgfVxuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgJ3N3aXRjaCB0byBjbG9jayBob3VyIHZpZXcnIGJ1dHRvbiAodXNlZCBieSBzY3JlZW4gcmVhZGVycykuICovXG4gIHN3aXRjaFRvQ2xvY2tIb3VyVmlld0xhYmVsID0gJ0Nob29zZSBob3VyJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlICdzd2l0Y2ggdG8gY2xvY2sgbWludXRlIHZpZXcnIGJ1dHRvbiAodXNlZCBieSBzY3JlZW4gcmVhZGVycykuICovXG4gIHN3aXRjaFRvQ2xvY2tNaW51dGVWaWV3TGFiZWwgPSAnQ2hvb3NlIG1pbnV0ZSc7XG5cbiAgLyoqIExhYmVsIHVzZWQgZm9yIG9rIGJ1dHRvbiB3aXRoaW4gdGhlIG1hbnVhbCB0aW1lIGlucHV0LiAqL1xuICBva0xhYmVsID0gJ09LJztcblxuICAvKiogTGFiZWwgdXNlZCBmb3IgY2FuY2VsIGJ1dHRvbiB3aXRoaW4gdGhlIG1hbnVhbCB0aW1lIGlucHV0LiAqL1xuICBjYW5jZWxMYWJlbCA9ICdDYW5jZWwnO1xufVxuIl19
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { A11yModule } from '@angular/cdk/a11y';
|
|
2
|
+
import { OverlayModule } from '@angular/cdk/overlay';
|
|
3
|
+
import { PortalModule } from '@angular/cdk/portal';
|
|
4
|
+
import { CommonModule } from '@angular/common';
|
|
5
|
+
import { NgModule } from '@angular/core';
|
|
6
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
7
|
+
import { MtxCalendar } from './calendar';
|
|
8
|
+
import { MtxCalendarBody } from './calendar-body';
|
|
9
|
+
import { MtxClock } from './clock';
|
|
10
|
+
import { MtxTime, MtxTimeInput } from './time';
|
|
11
|
+
import { MtxDatetimepicker, MtxDatetimepickerContent, MTX_DATETIMEPICKER_SCROLL_STRATEGY_FACTORY_PROVIDER, } from './datetimepicker';
|
|
12
|
+
import { MtxDatetimepickerInput } from './datetimepicker-input';
|
|
13
|
+
import { MtxDatetimepickerToggle, MtxDatetimepickerToggleIcon } from './datetimepicker-toggle';
|
|
14
|
+
import { MtxMonthView } from './month-view';
|
|
15
|
+
import { MtxYearView } from './year-view';
|
|
16
|
+
import { MtxMultiYearView } from './multi-year-view';
|
|
17
|
+
import * as i0 from "@angular/core";
|
|
18
|
+
class MtxDatetimepickerModule {
|
|
19
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: MtxDatetimepickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
20
|
+
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.3", ngImport: i0, type: MtxDatetimepickerModule, declarations: [MtxCalendar,
|
|
21
|
+
MtxCalendarBody,
|
|
22
|
+
MtxClock,
|
|
23
|
+
MtxTime,
|
|
24
|
+
MtxTimeInput,
|
|
25
|
+
MtxDatetimepicker,
|
|
26
|
+
MtxDatetimepickerToggle,
|
|
27
|
+
MtxDatetimepickerToggleIcon,
|
|
28
|
+
MtxDatetimepickerInput,
|
|
29
|
+
MtxDatetimepickerContent,
|
|
30
|
+
MtxMonthView,
|
|
31
|
+
MtxYearView,
|
|
32
|
+
MtxMultiYearView], imports: [CommonModule, MatButtonModule, OverlayModule, A11yModule, PortalModule], exports: [MtxCalendar,
|
|
33
|
+
MtxCalendarBody,
|
|
34
|
+
MtxClock,
|
|
35
|
+
MtxTime,
|
|
36
|
+
MtxDatetimepicker,
|
|
37
|
+
MtxDatetimepickerToggle,
|
|
38
|
+
MtxDatetimepickerToggleIcon,
|
|
39
|
+
MtxDatetimepickerInput,
|
|
40
|
+
MtxDatetimepickerContent,
|
|
41
|
+
MtxMonthView,
|
|
42
|
+
MtxYearView,
|
|
43
|
+
MtxMultiYearView] }); }
|
|
44
|
+
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: MtxDatetimepickerModule, providers: [MTX_DATETIMEPICKER_SCROLL_STRATEGY_FACTORY_PROVIDER], imports: [CommonModule, MatButtonModule, OverlayModule, A11yModule, PortalModule] }); }
|
|
45
|
+
}
|
|
46
|
+
export { MtxDatetimepickerModule };
|
|
47
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: MtxDatetimepickerModule, decorators: [{
|
|
48
|
+
type: NgModule,
|
|
49
|
+
args: [{
|
|
50
|
+
imports: [CommonModule, MatButtonModule, OverlayModule, A11yModule, PortalModule],
|
|
51
|
+
declarations: [
|
|
52
|
+
MtxCalendar,
|
|
53
|
+
MtxCalendarBody,
|
|
54
|
+
MtxClock,
|
|
55
|
+
MtxTime,
|
|
56
|
+
MtxTimeInput,
|
|
57
|
+
MtxDatetimepicker,
|
|
58
|
+
MtxDatetimepickerToggle,
|
|
59
|
+
MtxDatetimepickerToggleIcon,
|
|
60
|
+
MtxDatetimepickerInput,
|
|
61
|
+
MtxDatetimepickerContent,
|
|
62
|
+
MtxMonthView,
|
|
63
|
+
MtxYearView,
|
|
64
|
+
MtxMultiYearView,
|
|
65
|
+
],
|
|
66
|
+
exports: [
|
|
67
|
+
MtxCalendar,
|
|
68
|
+
MtxCalendarBody,
|
|
69
|
+
MtxClock,
|
|
70
|
+
MtxTime,
|
|
71
|
+
MtxDatetimepicker,
|
|
72
|
+
MtxDatetimepickerToggle,
|
|
73
|
+
MtxDatetimepickerToggleIcon,
|
|
74
|
+
MtxDatetimepickerInput,
|
|
75
|
+
MtxDatetimepickerContent,
|
|
76
|
+
MtxMonthView,
|
|
77
|
+
MtxYearView,
|
|
78
|
+
MtxMultiYearView,
|
|
79
|
+
],
|
|
80
|
+
providers: [MTX_DATETIMEPICKER_SCROLL_STRATEGY_FACTORY_PROVIDER],
|
|
81
|
+
}]
|
|
82
|
+
}] });
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXRpbWVwaWNrZXItbW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvZXh0ZW5zaW9ucy9kYXRldGltZXBpY2tlci9kYXRldGltZXBpY2tlci1tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDbkMsT0FBTyxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDL0MsT0FBTyxFQUNMLGlCQUFpQixFQUNqQix3QkFBd0IsRUFDeEIsbURBQW1ELEdBQ3BELE1BQU0sa0JBQWtCLENBQUM7QUFDMUIsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDaEUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLDJCQUEyQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDL0YsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM1QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQUVyRCxNQWlDYSx1QkFBdUI7aUlBQXZCLHVCQUF1QjtrSUFBdkIsdUJBQXVCLGlCQTlCaEMsV0FBVztZQUNYLGVBQWU7WUFDZixRQUFRO1lBQ1IsT0FBTztZQUNQLFlBQVk7WUFDWixpQkFBaUI7WUFDakIsdUJBQXVCO1lBQ3ZCLDJCQUEyQjtZQUMzQixzQkFBc0I7WUFDdEIsd0JBQXdCO1lBQ3hCLFlBQVk7WUFDWixXQUFXO1lBQ1gsZ0JBQWdCLGFBZFIsWUFBWSxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLFlBQVksYUFpQjlFLFdBQVc7WUFDWCxlQUFlO1lBQ2YsUUFBUTtZQUNSLE9BQU87WUFDUCxpQkFBaUI7WUFDakIsdUJBQXVCO1lBQ3ZCLDJCQUEyQjtZQUMzQixzQkFBc0I7WUFDdEIsd0JBQXdCO1lBQ3hCLFlBQVk7WUFDWixXQUFXO1lBQ1gsZ0JBQWdCO2tJQUlQLHVCQUF1QixhQUZ2QixDQUFDLG1EQUFtRCxDQUFDLFlBOUJ0RCxZQUFZLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxVQUFVLEVBQUUsWUFBWTs7U0FnQ3JFLHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQWpDbkMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxVQUFVLEVBQUUsWUFBWSxDQUFDO29CQUNqRixZQUFZLEVBQUU7d0JBQ1osV0FBVzt3QkFDWCxlQUFlO3dCQUNmLFFBQVE7d0JBQ1IsT0FBTzt3QkFDUCxZQUFZO3dCQUNaLGlCQUFpQjt3QkFDakIsdUJBQXVCO3dCQUN2QiwyQkFBMkI7d0JBQzNCLHNCQUFzQjt3QkFDdEIsd0JBQXdCO3dCQUN4QixZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsZ0JBQWdCO3FCQUNqQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsV0FBVzt3QkFDWCxlQUFlO3dCQUNmLFFBQVE7d0JBQ1IsT0FBTzt3QkFDUCxpQkFBaUI7d0JBQ2pCLHVCQUF1Qjt3QkFDdkIsMkJBQTJCO3dCQUMzQixzQkFBc0I7d0JBQ3RCLHdCQUF3Qjt3QkFDeEIsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGdCQUFnQjtxQkFDakI7b0JBQ0QsU0FBUyxFQUFFLENBQUMsbURBQW1ELENBQUM7aUJBQ2pFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQTExeU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7IE92ZXJsYXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBQb3J0YWxNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE10eENhbGVuZGFyIH0gZnJvbSAnLi9jYWxlbmRhcic7XG5pbXBvcnQgeyBNdHhDYWxlbmRhckJvZHkgfSBmcm9tICcuL2NhbGVuZGFyLWJvZHknO1xuaW1wb3J0IHsgTXR4Q2xvY2sgfSBmcm9tICcuL2Nsb2NrJztcbmltcG9ydCB7IE10eFRpbWUsIE10eFRpbWVJbnB1dCB9IGZyb20gJy4vdGltZSc7XG5pbXBvcnQge1xuICBNdHhEYXRldGltZXBpY2tlcixcbiAgTXR4RGF0ZXRpbWVwaWNrZXJDb250ZW50LFxuICBNVFhfREFURVRJTUVQSUNLRVJfU0NST0xMX1NUUkFURUdZX0ZBQ1RPUllfUFJPVklERVIsXG59IGZyb20gJy4vZGF0ZXRpbWVwaWNrZXInO1xuaW1wb3J0IHsgTXR4RGF0ZXRpbWVwaWNrZXJJbnB1dCB9IGZyb20gJy4vZGF0ZXRpbWVwaWNrZXItaW5wdXQnO1xuaW1wb3J0IHsgTXR4RGF0ZXRpbWVwaWNrZXJUb2dnbGUsIE10eERhdGV0aW1lcGlja2VyVG9nZ2xlSWNvbiB9IGZyb20gJy4vZGF0ZXRpbWVwaWNrZXItdG9nZ2xlJztcbmltcG9ydCB7IE10eE1vbnRoVmlldyB9IGZyb20gJy4vbW9udGgtdmlldyc7XG5pbXBvcnQgeyBNdHhZZWFyVmlldyB9IGZyb20gJy4veWVhci12aWV3JztcbmltcG9ydCB7IE10eE11bHRpWWVhclZpZXcgfSBmcm9tICcuL211bHRpLXllYXItdmlldyc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdEJ1dHRvbk1vZHVsZSwgT3ZlcmxheU1vZHVsZSwgQTExeU1vZHVsZSwgUG9ydGFsTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgTXR4Q2FsZW5kYXIsXG4gICAgTXR4Q2FsZW5kYXJCb2R5LFxuICAgIE10eENsb2NrLFxuICAgIE10eFRpbWUsXG4gICAgTXR4VGltZUlucHV0LFxuICAgIE10eERhdGV0aW1lcGlja2VyLFxuICAgIE10eERhdGV0aW1lcGlja2VyVG9nZ2xlLFxuICAgIE10eERhdGV0aW1lcGlja2VyVG9nZ2xlSWNvbixcbiAgICBNdHhEYXRldGltZXBpY2tlcklucHV0LFxuICAgIE10eERhdGV0aW1lcGlja2VyQ29udGVudCxcbiAgICBNdHhNb250aFZpZXcsXG4gICAgTXR4WWVhclZpZXcsXG4gICAgTXR4TXVsdGlZZWFyVmlldyxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIE10eENhbGVuZGFyLFxuICAgIE10eENhbGVuZGFyQm9keSxcbiAgICBNdHhDbG9jayxcbiAgICBNdHhUaW1lLFxuICAgIE10eERhdGV0aW1lcGlja2VyLFxuICAgIE10eERhdGV0aW1lcGlja2VyVG9nZ2xlLFxuICAgIE10eERhdGV0aW1lcGlja2VyVG9nZ2xlSWNvbixcbiAgICBNdHhEYXRldGltZXBpY2tlcklucHV0LFxuICAgIE10eERhdGV0aW1lcGlja2VyQ29udGVudCxcbiAgICBNdHhNb250aFZpZXcsXG4gICAgTXR4WWVhclZpZXcsXG4gICAgTXR4TXVsdGlZZWFyVmlldyxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbTVRYX0RBVEVUSU1FUElDS0VSX1NDUk9MTF9TVFJBVEVHWV9GQUNUT1JZX1BST1ZJREVSXSxcbn0pXG5leHBvcnQgY2xhc3MgTXR4RGF0ZXRpbWVwaWNrZXJNb2R1bGUge31cbiJdfQ==
|