@acorex/components 7.3.2 → 7.4.1
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/button/lib/button-group.component.d.ts +10 -73
- package/button/lib/button-item.class.d.ts +1 -3
- package/button/lib/button-item.component.d.ts +12 -75
- package/button/lib/button.component.d.ts +1 -1
- package/button-group/README.md +3 -0
- package/button-group/index.d.ts +2 -0
- package/button-group/lib/button-group.component.d.ts +21 -0
- package/button-group/lib/button-group.module.d.ts +8 -0
- package/calendar/lib/calendar-range.component.d.ts +2 -1
- package/calendar/lib/calendar.class.d.ts +9 -8
- package/calendar/lib/calendar.component.d.ts +2 -1
- package/check-box/lib/check-box.component.d.ts +3 -2
- package/color-box/README.md +3 -0
- package/color-box/index.d.ts +2 -0
- package/color-box/lib/color-box.component.d.ts +27 -0
- package/color-box/lib/color-box.module.d.ts +11 -0
- package/common/index.d.ts +5 -3
- package/common/lib/classes/styles.class.d.ts +0 -9
- package/common/lib/components/button-base-component.class.d.ts +0 -2
- package/common/lib/components/interactive-component.class.d.ts +7 -1
- package/common/lib/types/direction.d.ts +4 -0
- package/common/lib/types/orientation.d.ts +4 -0
- package/common/lib/types/placement.d.ts +30 -0
- package/common/lib/types/selection-mode.d.ts +4 -0
- package/data-pager/lib/data-pager.module.d.ts +5 -4
- package/data-table/lib/data-column.directive.d.ts +2 -2
- package/datetime-box/README.md +3 -0
- package/datetime-box/index.d.ts +2 -0
- package/datetime-box/lib/datetime-box.component.d.ts +34 -0
- package/datetime-box/lib/datetime-box.module.d.ts +13 -0
- package/datetime-input/README.md +3 -0
- package/datetime-input/index.d.ts +2 -0
- package/datetime-input/lib/datetime-input.component.d.ts +44 -0
- package/datetime-input/lib/datetime-input.module.d.ts +10 -0
- package/datetime-picker/README.md +3 -0
- package/datetime-picker/index.d.ts +2 -0
- package/datetime-picker/lib/datetime-picker.component.d.ts +42 -0
- package/datetime-picker/lib/datetime-picker.module.d.ts +14 -0
- package/decorators/index.d.ts +4 -4
- package/decorators/lib/decorators.module.d.ts +4 -4
- package/dropdown/index.d.ts +2 -0
- package/dropdown/lib/dropdown-box.class.d.ts +15 -0
- package/dropdown/lib/dropdown-box.component.d.ts +25 -0
- package/dropdown/lib/dropdown-panel.component.d.ts +31 -20
- package/dropdown/lib/dropdown.module.d.ts +9 -8
- package/esm2022/action-sheet/lib/action-sheet.class.mjs +1 -1
- package/esm2022/action-sheet/lib/action-sheet.component.mjs +3 -3
- package/esm2022/action-sheet/lib/action-sheet.module.mjs +4 -4
- package/esm2022/action-sheet/lib/action-sheet.service.mjs +3 -3
- package/esm2022/alert/lib/alert.component.mjs +3 -3
- package/esm2022/alert/lib/alert.module.mjs +4 -4
- package/esm2022/avatar/lib/avatar-group.component.mjs +3 -3
- package/esm2022/avatar/lib/avatar.component.mjs +3 -3
- package/esm2022/avatar/lib/avatar.module.mjs +4 -4
- package/esm2022/badge/lib/badge.component.mjs +3 -3
- package/esm2022/badge/lib/badge.module.mjs +4 -4
- package/esm2022/breadcrumbs/lib/breadcrumbs-item.component.mjs +3 -3
- package/esm2022/breadcrumbs/lib/breadcrumbs.component.mjs +3 -3
- package/esm2022/breadcrumbs/lib/breadcrumbs.module.mjs +4 -4
- package/esm2022/button/lib/button-group.component.mjs +36 -29
- package/esm2022/button/lib/button-item.class.mjs +1 -1
- package/esm2022/button/lib/button-item.component.mjs +46 -32
- package/esm2022/button/lib/button.component.mjs +10 -7
- package/esm2022/button/lib/button.module.mjs +4 -4
- package/esm2022/{color-picker/acorex-components-color-picker.mjs → button-group/acorex-components-button-group.mjs} +1 -1
- package/esm2022/button-group/index.mjs +3 -0
- package/esm2022/button-group/lib/button-group.component.mjs +97 -0
- package/esm2022/button-group/lib/button-group.module.mjs +21 -0
- package/esm2022/calendar/lib/calendar-range.component.mjs +14 -13
- package/esm2022/calendar/lib/calendar.class.mjs +19 -18
- package/esm2022/calendar/lib/calendar.component.mjs +80 -40
- package/esm2022/calendar/lib/calendar.module.mjs +4 -4
- package/esm2022/check-box/lib/check-box.component.mjs +9 -5
- package/esm2022/check-box/lib/check-box.module.mjs +4 -4
- package/esm2022/chips/lib/chips.component.mjs +3 -3
- package/esm2022/chips/lib/chips.module.mjs +4 -4
- package/esm2022/collapse/lib/collapse-group.component.mjs +3 -3
- package/esm2022/collapse/lib/collapse.component.mjs +3 -3
- package/esm2022/collapse/lib/collapse.module.mjs +4 -4
- package/esm2022/color-box/acorex-components-color-box.mjs +5 -0
- package/esm2022/color-box/index.mjs +3 -0
- package/esm2022/color-box/lib/color-box.component.mjs +91 -0
- package/esm2022/color-box/lib/color-box.module.mjs +24 -0
- package/esm2022/color-palette/lib/color-palette-input.component.mjs +3 -3
- package/esm2022/color-palette/lib/color-palette-picker.component.mjs +13 -13
- package/esm2022/color-palette/lib/color-palette-preview.component.mjs +3 -3
- package/esm2022/color-palette/lib/color-palette-swatches.component.mjs +3 -3
- package/esm2022/color-palette/lib/color-palette.class.mjs +6 -6
- package/esm2022/color-palette/lib/color-palette.component.mjs +5 -5
- package/esm2022/color-palette/lib/color-palette.module.mjs +4 -4
- package/esm2022/common/index.mjs +6 -4
- package/esm2022/common/lib/classes/components.class.mjs +22 -22
- package/esm2022/common/lib/classes/styles.class.mjs +1 -2
- package/esm2022/common/lib/common.module.mjs +4 -4
- package/esm2022/common/lib/components/base-component.class.mjs +3 -3
- package/esm2022/common/lib/components/button-base-component.class.mjs +4 -18
- package/esm2022/common/lib/components/input-base-value-component.class.mjs +3 -3
- package/esm2022/common/lib/components/interactive-component.class.mjs +14 -1
- package/esm2022/common/lib/components/value-component.class.mjs +6 -6
- package/esm2022/common/lib/directives/auto-focus.directive.mjs +3 -3
- package/esm2022/common/lib/directives/delayed-value-changed.directive.mjs +3 -3
- package/esm2022/common/lib/directives/hotkey.directive.mjs +3 -3
- package/esm2022/common/lib/directives/infinite-scroll.directive.mjs +3 -3
- package/esm2022/common/lib/directives/responsive.directive.mjs +3 -3
- package/esm2022/common/lib/services/dom.service.mjs +3 -3
- package/esm2022/common/lib/services/hotkey.service.mjs +3 -3
- package/esm2022/common/lib/types/direction.mjs +2 -0
- package/esm2022/common/lib/types/orientation.mjs +2 -0
- package/esm2022/common/lib/types/placement.mjs +160 -0
- package/esm2022/common/lib/types/range.mjs +2 -0
- package/esm2022/common/lib/types/selection-mode.mjs +5 -0
- package/esm2022/context-menu/lib/context-menu.component.mjs +3 -3
- package/esm2022/context-menu/lib/context-menu.module.mjs +4 -4
- package/esm2022/data-pager/lib/data-pager-base.component.mjs +6 -6
- package/esm2022/data-pager/lib/data-pager-info.component.mjs +3 -3
- package/esm2022/data-pager/lib/data-pager-input-selector.component.mjs +3 -3
- package/esm2022/data-pager/lib/data-pager-next-buttons.components.mjs +4 -4
- package/esm2022/data-pager/lib/data-pager-numeric-selector.component.mjs +15 -18
- package/esm2022/data-pager/lib/data-pager-pagesize-dropdown.component.mjs +7 -7
- package/esm2022/data-pager/lib/data-pager-prev-buttons.component.mjs +4 -4
- package/esm2022/data-pager/lib/data-pager.component.mjs +5 -5
- package/esm2022/data-pager/lib/data-pager.module.mjs +8 -7
- package/esm2022/data-table/lib/data-column.directive.mjs +6 -8
- package/esm2022/data-table/lib/data-table.component.mjs +3 -3
- package/esm2022/data-table/lib/data-table.module.mjs +4 -4
- package/esm2022/datetime-box/acorex-components-datetime-box.mjs +5 -0
- package/esm2022/datetime-box/index.mjs +3 -0
- package/esm2022/datetime-box/lib/datetime-box.component.mjs +109 -0
- package/esm2022/datetime-box/lib/datetime-box.module.mjs +38 -0
- package/esm2022/datetime-input/acorex-components-datetime-input.mjs +5 -0
- package/esm2022/datetime-input/index.mjs +3 -0
- package/esm2022/datetime-input/lib/datetime-input.component.mjs +522 -0
- package/esm2022/datetime-input/lib/datetime-input.module.mjs +23 -0
- package/esm2022/datetime-picker/acorex-components-datetime-picker.mjs +5 -0
- package/esm2022/datetime-picker/index.mjs +3 -0
- package/esm2022/datetime-picker/lib/datetime-picker.component.mjs +232 -0
- package/esm2022/datetime-picker/lib/datetime-picker.module.mjs +41 -0
- package/esm2022/decorators/index.mjs +5 -5
- package/esm2022/decorators/lib/components/clear-button.component.mjs +58 -0
- package/esm2022/decorators/lib/components/close-button.component.mjs +43 -0
- package/esm2022/decorators/lib/components/generic-content.component.mjs +17 -0
- package/esm2022/decorators/lib/components/icon.component.mjs +26 -0
- package/esm2022/decorators/lib/decorators.module.mjs +10 -10
- package/esm2022/dialog/lib/dialog.component.mjs +4 -4
- package/esm2022/dialog/lib/dialog.module.mjs +4 -4
- package/esm2022/dialog/lib/dialog.service.mjs +3 -3
- package/esm2022/drawer/lib/drawer-container.component.mjs +3 -3
- package/esm2022/drawer/lib/drawer.component.mjs +3 -3
- package/esm2022/drawer/lib/drawer.module.mjs +4 -4
- package/esm2022/dropdown/index.mjs +3 -1
- package/esm2022/dropdown/lib/dropdown-box.class.mjs +38 -0
- package/esm2022/dropdown/lib/dropdown-box.component.mjs +94 -0
- package/esm2022/dropdown/lib/dropdown-panel.component.mjs +88 -37
- package/esm2022/dropdown/lib/dropdown.module.mjs +8 -7
- package/esm2022/form/index.mjs +2 -1
- package/esm2022/form/lib/form-field.component.mjs +3 -3
- package/esm2022/form/lib/form.component.mjs +3 -3
- package/esm2022/form/lib/form.config.mjs +36 -0
- package/esm2022/form/lib/form.module.mjs +6 -28
- package/esm2022/form/lib/validation-rule.widget.mjs +8 -7
- package/esm2022/form/lib/validation-summary.component.mjs +4 -4
- package/esm2022/image/lib/image.component.mjs +3 -3
- package/esm2022/image/lib/image.module.mjs +4 -4
- package/esm2022/label/lib/label.component.mjs +3 -3
- package/esm2022/label/lib/label.module.mjs +4 -4
- package/esm2022/loading/lib/loading-spinner.component.mjs +3 -3
- package/esm2022/loading/lib/loading.component.mjs +3 -3
- package/esm2022/loading/lib/loading.directive.mjs +3 -3
- package/esm2022/loading/lib/loading.module.mjs +4 -4
- package/esm2022/loading/lib/loading.service.mjs +3 -3
- package/esm2022/menu/lib/menu.component.mjs +3 -3
- package/esm2022/menu/lib/menu.module.mjs +4 -4
- package/esm2022/mixin/lib/base-components.class.mjs +3 -3
- package/esm2022/mixin/lib/selection-component.class.mjs +3 -3
- package/esm2022/mixin/lib/value-mixin.class.mjs +3 -3
- package/esm2022/notification/lib/notification.component.mjs +3 -3
- package/esm2022/notification/lib/notification.module.mjs +4 -4
- package/esm2022/notification/lib/notification.service.mjs +3 -3
- package/esm2022/number-box/lib/number-box.component.mjs +3 -3
- package/esm2022/number-box/lib/number-box.module.mjs +4 -4
- package/esm2022/otp/lib/otp.component.mjs +23 -11
- package/esm2022/otp/lib/otp.module.mjs +4 -4
- package/esm2022/page/lib/base-page.class.mjs +3 -3
- package/esm2022/page/lib/page.component.mjs +3 -3
- package/esm2022/page/lib/page.module.mjs +4 -4
- package/esm2022/password-box/lib/password-box.component.mjs +3 -3
- package/esm2022/password-box/lib/password-box.module.mjs +4 -4
- package/esm2022/picker/acorex-components-picker.mjs +5 -0
- package/esm2022/picker/index.mjs +4 -0
- package/esm2022/picker/lib/picker-column.directive.mjs +73 -0
- package/esm2022/picker/lib/picker.component.mjs +148 -0
- package/esm2022/picker/lib/picker.module.mjs +22 -0
- package/esm2022/popover/index.mjs +1 -2
- package/esm2022/popover/lib/popover.component.mjs +241 -176
- package/esm2022/popover/lib/popover.module.mjs +4 -4
- package/esm2022/popup/lib/popup.component.mjs +37 -12
- package/esm2022/popup/lib/popup.module.mjs +4 -4
- package/esm2022/popup/lib/popup.service.mjs +9 -6
- package/esm2022/progress-bar/lib/progress-bar.component.mjs +4 -4
- package/esm2022/progress-bar/lib/progress-bar.module.mjs +4 -4
- package/esm2022/radio/lib/radio.component.mjs +36 -21
- package/esm2022/radio/lib/radio.module.mjs +4 -4
- package/esm2022/range-slider/lib/range-slider.component.mjs +21 -34
- package/esm2022/range-slider/lib/range-slider.module.mjs +4 -4
- package/esm2022/result/lib/result.component.mjs +6 -6
- package/esm2022/result/lib/result.module.mjs +4 -4
- package/esm2022/scheduler/index.mjs +2 -1
- package/esm2022/scheduler/lib/scheduler-month-view.component.mjs +16 -9
- package/esm2022/scheduler/lib/scheduler-week-view.component.mjs +12 -0
- package/esm2022/scheduler/lib/scheduler.component.mjs +27 -14
- package/esm2022/scheduler/lib/scheduler.module.mjs +10 -9
- package/esm2022/search-box/lib/search-box.component.mjs +3 -3
- package/esm2022/search-box/lib/search-box.module.mjs +4 -4
- package/esm2022/select-box/lib/select-box.component.mjs +7 -7
- package/esm2022/select-box/lib/select-box.module.mjs +4 -4
- package/esm2022/selection-list/lib/selection-list.component.mjs +3 -3
- package/esm2022/selection-list/lib/selection-list.module.mjs +4 -4
- package/esm2022/switch/lib/switch-content.component.mjs +3 -3
- package/esm2022/switch/lib/switch.component.mjs +3 -3
- package/esm2022/switch/lib/switch.module.mjs +4 -4
- package/esm2022/tabs/lib/tab-content.directive.mjs +3 -3
- package/esm2022/tabs/lib/tab-item.component.mjs +23 -53
- package/esm2022/tabs/lib/tabs.class.mjs +1 -1
- package/esm2022/tabs/lib/tabs.component.mjs +19 -28
- package/esm2022/tabs/lib/tabs.module.mjs +4 -4
- package/esm2022/tag/lib/tag.component.mjs +8 -10
- package/esm2022/tag/lib/tag.module.mjs +4 -4
- package/esm2022/text-area/lib/text-area.component.mjs +3 -3
- package/esm2022/text-area/lib/text-area.module.mjs +4 -4
- package/esm2022/text-box/lib/mask-options.directive.mjs +3 -3
- package/esm2022/text-box/lib/text-box.component.mjs +3 -3
- package/esm2022/text-box/lib/text-box.module.mjs +4 -4
- package/esm2022/toast/lib/toast.component.mjs +3 -3
- package/esm2022/toast/lib/toast.module.mjs +4 -4
- package/esm2022/toast/lib/toast.service.mjs +3 -3
- package/esm2022/tooltip/lib/tooltip.component.mjs +9 -13
- package/esm2022/tooltip/lib/tooltip.directive.mjs +35 -143
- package/esm2022/tooltip/lib/tooltip.module.mjs +4 -4
- package/esm2022/uploader/index.mjs +4 -2
- package/esm2022/uploader/lib/uploader-drop-zone.component.mjs +13 -0
- package/esm2022/uploader/lib/uploader-list.component.mjs +14 -0
- package/esm2022/uploader/lib/uploader-overlay.component.mjs +12 -0
- package/esm2022/uploader/lib/uploader.module.mjs +14 -11
- package/fesm2022/acorex-components-action-sheet.mjs +10 -10
- package/fesm2022/acorex-components-alert.mjs +7 -7
- package/fesm2022/acorex-components-avatar.mjs +10 -10
- package/fesm2022/acorex-components-badge.mjs +7 -7
- package/fesm2022/acorex-components-breadcrumbs.mjs +10 -10
- package/fesm2022/acorex-components-button-group.mjs +122 -0
- package/fesm2022/acorex-components-button-group.mjs.map +1 -0
- package/fesm2022/acorex-components-button.mjs +134 -113
- package/fesm2022/acorex-components-button.mjs.map +1 -1
- package/fesm2022/acorex-components-calendar.mjs +110 -68
- package/fesm2022/acorex-components-calendar.mjs.map +1 -1
- package/fesm2022/acorex-components-check-box.mjs +12 -8
- package/fesm2022/acorex-components-check-box.mjs.map +1 -1
- package/fesm2022/acorex-components-chips.mjs +7 -7
- package/fesm2022/acorex-components-collapse.mjs +10 -10
- package/fesm2022/acorex-components-color-box.mjs +116 -0
- package/fesm2022/acorex-components-color-box.mjs.map +1 -0
- package/fesm2022/acorex-components-color-palette.mjs +36 -36
- package/fesm2022/acorex-components-color-palette.mjs.map +1 -1
- package/fesm2022/acorex-components-common.mjs +236 -149
- package/fesm2022/acorex-components-common.mjs.map +1 -1
- package/fesm2022/acorex-components-context-menu.mjs +7 -7
- package/fesm2022/acorex-components-data-pager.mjs +52 -54
- package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
- package/fesm2022/acorex-components-data-table.mjs +12 -14
- package/fesm2022/acorex-components-data-table.mjs.map +1 -1
- package/fesm2022/acorex-components-datetime-box.mjs +146 -0
- package/fesm2022/acorex-components-datetime-box.mjs.map +1 -0
- package/fesm2022/acorex-components-datetime-input.mjs +547 -0
- package/fesm2022/acorex-components-datetime-input.mjs.map +1 -0
- package/fesm2022/acorex-components-datetime-picker.mjs +273 -0
- package/fesm2022/acorex-components-datetime-picker.mjs.map +1 -0
- package/fesm2022/acorex-components-decorators.mjs +50 -50
- package/fesm2022/acorex-components-decorators.mjs.map +1 -1
- package/fesm2022/acorex-components-dialog.mjs +11 -11
- package/fesm2022/acorex-components-dialog.mjs.map +1 -1
- package/fesm2022/acorex-components-drawer.mjs +10 -10
- package/fesm2022/acorex-components-dropdown.mjs +217 -44
- package/fesm2022/acorex-components-dropdown.mjs.map +1 -1
- package/fesm2022/acorex-components-form.mjs +58 -44
- package/fesm2022/acorex-components-form.mjs.map +1 -1
- package/fesm2022/acorex-components-image.mjs +7 -7
- package/fesm2022/acorex-components-label.mjs +7 -7
- package/fesm2022/acorex-components-loading.mjs +16 -16
- package/fesm2022/acorex-components-menu.mjs +7 -7
- package/fesm2022/acorex-components-mixin.mjs +6 -7
- package/fesm2022/acorex-components-mixin.mjs.map +1 -1
- package/fesm2022/acorex-components-notification.mjs +10 -10
- package/fesm2022/acorex-components-notification.mjs.map +1 -1
- package/fesm2022/acorex-components-number-box.mjs +7 -7
- package/fesm2022/acorex-components-otp.mjs +27 -15
- package/fesm2022/acorex-components-otp.mjs.map +1 -1
- package/fesm2022/acorex-components-page.mjs +10 -10
- package/fesm2022/acorex-components-password-box.mjs +7 -7
- package/fesm2022/acorex-components-picker.mjs +242 -0
- package/fesm2022/acorex-components-picker.mjs.map +1 -0
- package/fesm2022/acorex-components-popover.mjs +246 -251
- package/fesm2022/acorex-components-popover.mjs.map +1 -1
- package/fesm2022/acorex-components-popup.mjs +48 -20
- package/fesm2022/acorex-components-popup.mjs.map +1 -1
- package/fesm2022/acorex-components-progress-bar.mjs +8 -8
- package/fesm2022/acorex-components-progress-bar.mjs.map +1 -1
- package/fesm2022/acorex-components-radio.mjs +39 -25
- package/fesm2022/acorex-components-radio.mjs.map +1 -1
- package/fesm2022/acorex-components-range-slider.mjs +24 -37
- package/fesm2022/acorex-components-range-slider.mjs.map +1 -1
- package/fesm2022/acorex-components-result.mjs +9 -9
- package/fesm2022/acorex-components-result.mjs.map +1 -1
- package/fesm2022/acorex-components-scheduler.mjs +50 -25
- package/fesm2022/acorex-components-scheduler.mjs.map +1 -1
- package/fesm2022/acorex-components-search-box.mjs +7 -7
- package/fesm2022/acorex-components-select-box.mjs +10 -10
- package/fesm2022/acorex-components-select-box.mjs.map +1 -1
- package/fesm2022/acorex-components-selection-list.mjs +7 -7
- package/fesm2022/acorex-components-switch.mjs +10 -10
- package/fesm2022/acorex-components-tabs.mjs +45 -85
- package/fesm2022/acorex-components-tabs.mjs.map +1 -1
- package/fesm2022/acorex-components-tag.mjs +11 -13
- package/fesm2022/acorex-components-tag.mjs.map +1 -1
- package/fesm2022/acorex-components-text-area.mjs +7 -7
- package/fesm2022/acorex-components-text-box.mjs +10 -10
- package/fesm2022/acorex-components-toast.mjs +10 -10
- package/fesm2022/acorex-components-tooltip.mjs +45 -157
- package/fesm2022/acorex-components-tooltip.mjs.map +1 -1
- package/fesm2022/acorex-components-uploader.mjs +38 -103
- package/fesm2022/acorex-components-uploader.mjs.map +1 -1
- package/form/index.d.ts +1 -0
- package/form/lib/form.config.d.ts +17 -0
- package/form/lib/form.module.d.ts +0 -1
- package/form/lib/validation-rule.widget.d.ts +1 -0
- package/mixin/lib/base-components.class.d.ts +2 -2
- package/mixin/lib/base-menu-mixin.class.d.ts +5 -5
- package/mixin/lib/button-mixin.class.d.ts +2 -2
- package/mixin/lib/clickable-mixin.class.d.ts +2 -2
- package/mixin/lib/color-look-mixing.class.d.ts +2 -2
- package/mixin/lib/datalist-component.class.d.ts +10 -10
- package/mixin/lib/dropdown-mixin.class.d.ts +2 -2
- package/mixin/lib/interactive-mixin.class.d.ts +4 -4
- package/mixin/lib/mixin.class.d.ts +61 -61
- package/mixin/lib/page-component.class.d.ts +2 -2
- package/mixin/lib/selection-component.class.d.ts +2 -2
- package/mixin/lib/sizable-mixin.class.d.ts +2 -2
- package/mixin/lib/textbox-mixin.class.d.ts +2 -2
- package/mixin/lib/value-mixin.class.d.ts +8 -8
- package/otp/lib/otp.component.d.ts +10 -6
- package/package.json +42 -24
- package/picker/README.md +3 -0
- package/picker/index.d.ts +3 -0
- package/picker/lib/picker-column.directive.d.ts +16 -0
- package/picker/lib/picker.component.d.ts +30 -0
- package/picker/lib/picker.module.d.ts +9 -0
- package/popover/index.d.ts +0 -1
- package/popover/lib/popover.component.d.ts +43 -27
- package/popup/lib/popup.component.d.ts +6 -6
- package/radio/lib/radio.component.d.ts +8 -10
- package/range-slider/lib/range-slider.component.d.ts +12 -12
- package/result/lib/result.component.d.ts +2 -2
- package/scheduler/index.d.ts +1 -0
- package/scheduler/lib/scheduler-month-view.component.d.ts +2 -1
- package/scheduler/lib/scheduler-week-view.component.d.ts +6 -0
- package/scheduler/lib/scheduler.component.d.ts +6 -0
- package/scheduler/lib/scheduler.module.d.ts +7 -6
- package/tabs/lib/tab-item.component.d.ts +7 -38
- package/tabs/lib/tabs.class.d.ts +2 -1
- package/tabs/lib/tabs.component.d.ts +7 -9
- package/tag/lib/tag.component.d.ts +2 -4
- package/tooltip/lib/tooltip.component.d.ts +3 -6
- package/tooltip/lib/tooltip.directive.d.ts +11 -17
- package/uploader/index.d.ts +3 -1
- package/uploader/lib/uploader-drop-zone.component.d.ts +6 -0
- package/uploader/lib/uploader-list.component.d.ts +6 -0
- package/uploader/lib/uploader-overlay.component.d.ts +6 -0
- package/uploader/lib/uploader.module.d.ts +7 -4
- package/color-picker/README.md +0 -3
- package/color-picker/index.d.ts +0 -2
- package/color-picker/lib/color-picker.component.d.ts +0 -191
- package/color-picker/lib/color-picker.module.d.ts +0 -18
- package/common/lib/classes/drawing.class.d.ts +0 -9
- package/common/lib/constant/positions.d.ts +0 -75
- package/date-picker/README.md +0 -3
- package/date-picker/index.d.ts +0 -2
- package/date-picker/lib/datepicker.component.d.ts +0 -40
- package/date-picker/lib/datepicker.module.d.ts +0 -15
- package/esm2022/color-picker/index.mjs +0 -3
- package/esm2022/color-picker/lib/color-picker.component.mjs +0 -116
- package/esm2022/color-picker/lib/color-picker.module.mjs +0 -61
- package/esm2022/common/lib/classes/data.class.mjs +0 -2
- package/esm2022/common/lib/classes/drawing.class.mjs +0 -2
- package/esm2022/common/lib/constant/positions.mjs +0 -75
- package/esm2022/date-picker/acorex-components-date-picker.mjs +0 -5
- package/esm2022/date-picker/index.mjs +0 -3
- package/esm2022/date-picker/lib/datepicker.component.mjs +0 -128
- package/esm2022/date-picker/lib/datepicker.module.mjs +0 -44
- package/esm2022/decorators/lib/clear-button.component.mjs +0 -58
- package/esm2022/decorators/lib/close-button.component.mjs +0 -43
- package/esm2022/decorators/lib/generic-content.component.mjs +0 -17
- package/esm2022/decorators/lib/icon.component.mjs +0 -26
- package/esm2022/popover/lib/dropdown-component.class.mjs +0 -73
- package/esm2022/time-box/acorex-components-time-box.mjs +0 -5
- package/esm2022/time-box/index.mjs +0 -3
- package/esm2022/time-box/lib/time-box.component.mjs +0 -294
- package/esm2022/time-box/lib/time-box.module.mjs +0 -32
- package/esm2022/uploader/lib/uploader.component.mjs +0 -99
- package/fesm2022/acorex-components-color-picker.mjs +0 -178
- package/fesm2022/acorex-components-color-picker.mjs.map +0 -1
- package/fesm2022/acorex-components-date-picker.mjs +0 -173
- package/fesm2022/acorex-components-date-picker.mjs.map +0 -1
- package/fesm2022/acorex-components-time-box.mjs +0 -329
- package/fesm2022/acorex-components-time-box.mjs.map +0 -1
- package/popover/lib/dropdown-component.class.d.ts +0 -17
- package/time-box/README.md +0 -3
- package/time-box/index.d.ts +0 -2
- package/time-box/lib/time-box.component.d.ts +0 -50
- package/time-box/lib/time-box.module.d.ts +0 -11
- package/uploader/lib/uploader.component.d.ts +0 -28
- /package/common/lib/{classes/data.class.d.ts → types/range.d.ts} +0 -0
- /package/decorators/lib/{clear-button.component.d.ts → components/clear-button.component.d.ts} +0 -0
- /package/decorators/lib/{close-button.component.d.ts → components/close-button.component.d.ts} +0 -0
- /package/decorators/lib/{generic-content.component.d.ts → components/generic-content.component.d.ts} +0 -0
- /package/decorators/lib/{icon.component.d.ts → components/icon.component.d.ts} +0 -0
@@ -0,0 +1,522 @@
|
|
1
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, forwardRef, inject } from '@angular/core';
|
2
|
+
import { AXClearableComponent, AXComponent, AXFocusableComponent, AXValuableComponent, MXInputBaseValueComponent } from '@acorex/components/common';
|
3
|
+
import { AXStringUtil } from '@acorex/core/utils';
|
4
|
+
import { AXCalendarService } from '@acorex/core/dateTime';
|
5
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "@angular/forms";
|
8
|
+
export class AXDateTimeInputComponent extends MXInputBaseValueComponent {
|
9
|
+
constructor() {
|
10
|
+
super(...arguments);
|
11
|
+
this.calendarService = inject(AXCalendarService);
|
12
|
+
this._editingParts = {
|
13
|
+
year: {
|
14
|
+
key: "year",
|
15
|
+
placeholder: "yyyy",
|
16
|
+
placeholders: ["YY", "yy", "YYYY", "yyyy"],
|
17
|
+
enabled: false,
|
18
|
+
default: 2023,
|
19
|
+
typedValue: null,
|
20
|
+
realValue: () => this.editingDateObj.format(this._editingParts.year.placeholder)
|
21
|
+
},
|
22
|
+
month: {
|
23
|
+
key: "month",
|
24
|
+
placeholder: "MM",
|
25
|
+
placeholders: ["MMM", "MMMM", "MM", "M"],
|
26
|
+
enabled: false,
|
27
|
+
default: 1,
|
28
|
+
typedValue: null,
|
29
|
+
realValue: () => this.editingDateObj.format(this._editingParts.month.placeholder)
|
30
|
+
},
|
31
|
+
day: {
|
32
|
+
key: "day",
|
33
|
+
placeholder: "dd",
|
34
|
+
placeholders: ["dd", "d"],
|
35
|
+
enabled: false,
|
36
|
+
default: 1,
|
37
|
+
typedValue: null,
|
38
|
+
realValue: () => this.editingDateObj.format(this._editingParts.day.placeholder)
|
39
|
+
},
|
40
|
+
hour: {
|
41
|
+
key: "hour",
|
42
|
+
placeholder: "HH",
|
43
|
+
placeholders: ["HH", "H", "hh", "h"],
|
44
|
+
enabled: false,
|
45
|
+
default: 0,
|
46
|
+
typedValue: null,
|
47
|
+
realValue: () => this.editingDateObj.format(this._editingParts.hour.placeholder)
|
48
|
+
},
|
49
|
+
minute: {
|
50
|
+
key: "minute",
|
51
|
+
placeholder: "mm",
|
52
|
+
placeholders: ["mm", "m"],
|
53
|
+
enabled: false,
|
54
|
+
default: 0,
|
55
|
+
typedValue: null,
|
56
|
+
realValue: () => this.editingDateObj.format(this._editingParts.minute.placeholder)
|
57
|
+
},
|
58
|
+
second: {
|
59
|
+
key: "second",
|
60
|
+
placeholder: "ss",
|
61
|
+
placeholders: ["ss", "s"],
|
62
|
+
enabled: false,
|
63
|
+
default: 0,
|
64
|
+
typedValue: null,
|
65
|
+
realValue: () => this.editingDateObj.format(this._editingParts.second.placeholder)
|
66
|
+
}
|
67
|
+
};
|
68
|
+
this._inputChars = [];
|
69
|
+
this._type = this.calendarService.calendar.name();
|
70
|
+
this._activePart = 'hour';
|
71
|
+
this._editingDateObj = this.calendarService.now(this.type);
|
72
|
+
this.formatChange = new EventEmitter();
|
73
|
+
this._format = this.calendarService.calendar.formats.dateTimeDisplay;
|
74
|
+
}
|
75
|
+
get type() {
|
76
|
+
return this._type || this.calendarService.calendar.name();
|
77
|
+
}
|
78
|
+
set type(v) {
|
79
|
+
this.setOption({
|
80
|
+
name: 'type',
|
81
|
+
value: v,
|
82
|
+
afterCallback: () => {
|
83
|
+
this.cdr.markForCheck();
|
84
|
+
},
|
85
|
+
});
|
86
|
+
}
|
87
|
+
get activePart() {
|
88
|
+
return this._activePart;
|
89
|
+
}
|
90
|
+
set activePart(v) {
|
91
|
+
this._activePart = v;
|
92
|
+
this._clearInputBuffer();
|
93
|
+
}
|
94
|
+
get editingDateObj() {
|
95
|
+
return this._editingDateObj;
|
96
|
+
}
|
97
|
+
get minValue() {
|
98
|
+
return this._minValue;
|
99
|
+
}
|
100
|
+
set minValue(v) {
|
101
|
+
this._minValue = v;
|
102
|
+
}
|
103
|
+
get maxValue() {
|
104
|
+
return this._maxValue;
|
105
|
+
}
|
106
|
+
set maxValue(v) {
|
107
|
+
this._maxValue = v;
|
108
|
+
}
|
109
|
+
get format() {
|
110
|
+
return this._format;
|
111
|
+
}
|
112
|
+
set format(v) {
|
113
|
+
this.setOption({
|
114
|
+
name: 'format',
|
115
|
+
value: v,
|
116
|
+
afterCallback: (o, n) => {
|
117
|
+
Object.values(this._editingParts).forEach(e => {
|
118
|
+
e.enabled = false;
|
119
|
+
});
|
120
|
+
const formatParts = n.split(/[^a-zA-Z]+/);
|
121
|
+
formatParts.forEach(f => {
|
122
|
+
const found = Object.values(this._editingParts).find(c => c.placeholders.some(d => d == f));
|
123
|
+
if (found) {
|
124
|
+
found.enabled = true;
|
125
|
+
found.placeholder = f;
|
126
|
+
}
|
127
|
+
});
|
128
|
+
},
|
129
|
+
});
|
130
|
+
}
|
131
|
+
_getOrderedParts() {
|
132
|
+
// TODO: better spliter format
|
133
|
+
const formatParts = this.format.split(/[^a-zA-Z]+/);
|
134
|
+
const result = [];
|
135
|
+
formatParts.forEach(f => {
|
136
|
+
const found = Object.values(this._editingParts).find(c => c.placeholders.some(d => d == f));
|
137
|
+
if (found && found.enabled)
|
138
|
+
result.push(found);
|
139
|
+
});
|
140
|
+
return result;
|
141
|
+
}
|
142
|
+
_clearInputBuffer() {
|
143
|
+
this._inputChars = [];
|
144
|
+
}
|
145
|
+
_updateText() {
|
146
|
+
let text = this.format;
|
147
|
+
//
|
148
|
+
Object.values(this._editingParts).forEach(part => {
|
149
|
+
if (this.activePart == part.key) {
|
150
|
+
if (part.typedValue)
|
151
|
+
text = text.replace(part.placeholder, part.typedValue);
|
152
|
+
}
|
153
|
+
else {
|
154
|
+
if (part.typedValue != part.placeholder && part.typedValue != null) {
|
155
|
+
text = text.replace(part.placeholder, part.realValue());
|
156
|
+
}
|
157
|
+
}
|
158
|
+
});
|
159
|
+
this._editingText = text == this.format ? '' : text;
|
160
|
+
if (this.activePart) {
|
161
|
+
this._highlightActivePart();
|
162
|
+
}
|
163
|
+
}
|
164
|
+
internalSetValue(value) {
|
165
|
+
if (value) {
|
166
|
+
let editingDate = this.calendarService.create(value, this.type);
|
167
|
+
let applyChanges = false;
|
168
|
+
Object.values(this._editingParts).forEach(part => {
|
169
|
+
if (!part.enabled) {
|
170
|
+
editingDate = editingDate.set(part.key, part.default);
|
171
|
+
applyChanges = true;
|
172
|
+
}
|
173
|
+
});
|
174
|
+
if (applyChanges) {
|
175
|
+
return editingDate.date;
|
176
|
+
}
|
177
|
+
}
|
178
|
+
return value;
|
179
|
+
}
|
180
|
+
internalValueChanged(value) {
|
181
|
+
if (value) {
|
182
|
+
this._editingDateObj = this.calendarService.create(value, this.type);
|
183
|
+
}
|
184
|
+
Object.values(this._editingParts).forEach(part => {
|
185
|
+
if (value) {
|
186
|
+
if (part.typedValue != part.placeholder)
|
187
|
+
part.typedValue = part.realValue();
|
188
|
+
}
|
189
|
+
else
|
190
|
+
part.typedValue = null;
|
191
|
+
});
|
192
|
+
this._updateText();
|
193
|
+
}
|
194
|
+
_handleOnKeydownEvent(e) {
|
195
|
+
const ignore = () => {
|
196
|
+
e.preventDefault();
|
197
|
+
e.stopPropagation();
|
198
|
+
};
|
199
|
+
const input = e.target;
|
200
|
+
//
|
201
|
+
const orderedParts = this._getOrderedParts();
|
202
|
+
const part = this.activePart ? this._editingParts[this.activePart] : orderedParts[0];
|
203
|
+
const nextPart = part ? orderedParts[orderedParts.indexOf(part) + 1] : null;
|
204
|
+
const prevPart = part ? orderedParts[orderedParts.indexOf(part) - 1] : null;
|
205
|
+
//
|
206
|
+
const goNext = () => {
|
207
|
+
this._clearInputBuffer();
|
208
|
+
if (nextPart) {
|
209
|
+
this.activePart = nextPart.key;
|
210
|
+
this._highlightActivePart();
|
211
|
+
}
|
212
|
+
};
|
213
|
+
const goPrev = () => {
|
214
|
+
this._clearInputBuffer();
|
215
|
+
if (prevPart) {
|
216
|
+
this.activePart = prevPart.key;
|
217
|
+
this._highlightActivePart();
|
218
|
+
}
|
219
|
+
};
|
220
|
+
/*************** Handle Left and Right **************/
|
221
|
+
if (e.code === 'ArrowRight' || e.code === 'ArrowLeft') {
|
222
|
+
ignore();
|
223
|
+
e.code === 'ArrowRight' ? goNext() : goPrev();
|
224
|
+
}
|
225
|
+
/*************** Handle Up and Down **************/
|
226
|
+
else if ((e.code === 'ArrowUp' || e.code === 'ArrowDown') && !e.ctrlKey) {
|
227
|
+
if (this.disabled || this.readonly) {
|
228
|
+
ignore();
|
229
|
+
return;
|
230
|
+
}
|
231
|
+
else {
|
232
|
+
ignore();
|
233
|
+
const sign = e.code === 'ArrowUp' ? +1 : -1;
|
234
|
+
this.activePart = part.key;
|
235
|
+
let newVal = this.editingDateObj.add(part.key, sign);
|
236
|
+
this._editingParts[part.key].typedValue = newVal.format(this._editingParts[part.key].placeholder);
|
237
|
+
this._editingDateObj = newVal;
|
238
|
+
this._detectValueChanges();
|
239
|
+
}
|
240
|
+
}
|
241
|
+
/*************** Handle Backspace **************/
|
242
|
+
else if (e.code == 'Backspace' || e.code == 'Delete') {
|
243
|
+
if (this.disabled || this.readonly) {
|
244
|
+
return;
|
245
|
+
}
|
246
|
+
if (input.value) {
|
247
|
+
ignore();
|
248
|
+
this._editingParts[part.key].typedValue = this._editingParts[part.key].placeholder;
|
249
|
+
this._detectValueChanges();
|
250
|
+
goPrev();
|
251
|
+
}
|
252
|
+
}
|
253
|
+
/*************** Handle Backspace **************/
|
254
|
+
else if (e.code == 'Tab' || e.code == 'Space') {
|
255
|
+
if (input.value) {
|
256
|
+
if (!e.shiftKey && nextPart) {
|
257
|
+
ignore();
|
258
|
+
goNext();
|
259
|
+
}
|
260
|
+
else if (e.shiftKey && prevPart) {
|
261
|
+
ignore();
|
262
|
+
goPrev();
|
263
|
+
}
|
264
|
+
}
|
265
|
+
}
|
266
|
+
else if (e.key?.trim() && !isNaN(Number(e.key))) {
|
267
|
+
ignore();
|
268
|
+
if (this.disabled || this.readonly) {
|
269
|
+
return;
|
270
|
+
}
|
271
|
+
let next = false;
|
272
|
+
const editing = this._editingParts[part.key];
|
273
|
+
//
|
274
|
+
switch (part.key) {
|
275
|
+
case 'year':
|
276
|
+
{
|
277
|
+
if (editing.placeholder.length == 2 && this._inputChars.length == 0) {
|
278
|
+
this._inputChars.push(...this.calendarService.now(this.type).format('yyyy').substring(0, 2).split(''));
|
279
|
+
}
|
280
|
+
if (this._inputChars.length < 4) {
|
281
|
+
editing.typedValue = `${this._inputChars.join('')}${e.key}`;
|
282
|
+
this._inputChars.push(e.key);
|
283
|
+
if (this._inputChars.length > 3) {
|
284
|
+
next = true;
|
285
|
+
}
|
286
|
+
}
|
287
|
+
else {
|
288
|
+
next = true;
|
289
|
+
}
|
290
|
+
editing.typedValue = ('0000' + editing.typedValue).slice(-4);
|
291
|
+
const nv = parseInt(editing.typedValue);
|
292
|
+
//if (nv > 0) {
|
293
|
+
const newVal = this.editingDateObj.set('year', nv);
|
294
|
+
this._editingDateObj = newVal;
|
295
|
+
this._detectValueChanges();
|
296
|
+
//}
|
297
|
+
break;
|
298
|
+
}
|
299
|
+
case 'month':
|
300
|
+
{
|
301
|
+
if (this._inputChars.length == 0) {
|
302
|
+
this._inputChars.push(e.key);
|
303
|
+
editing.typedValue = `0${e.key}`;
|
304
|
+
if (parseInt(e.key) > 1) {
|
305
|
+
this._clearInputBuffer();
|
306
|
+
next = true;
|
307
|
+
}
|
308
|
+
}
|
309
|
+
else if (this._inputChars.length == 1) {
|
310
|
+
const newStr = parseInt(`${this._inputChars[0]}${e.key}`);
|
311
|
+
if (newStr > 12) {
|
312
|
+
editing.typedValue = `0${e.key}`;
|
313
|
+
}
|
314
|
+
else {
|
315
|
+
editing.typedValue = newStr.toString();
|
316
|
+
}
|
317
|
+
this._clearInputBuffer();
|
318
|
+
next = true;
|
319
|
+
}
|
320
|
+
editing.typedValue = editing.typedValue?.length === 1 ? "0" + editing.typedValue : editing.typedValue;
|
321
|
+
const nv = parseInt(editing.typedValue);
|
322
|
+
if (nv > 0) {
|
323
|
+
const newVal = this.editingDateObj.set(part.key, nv);
|
324
|
+
this._editingDateObj = newVal;
|
325
|
+
this._detectValueChanges();
|
326
|
+
}
|
327
|
+
break;
|
328
|
+
}
|
329
|
+
case 'day':
|
330
|
+
{
|
331
|
+
if (this._inputChars.length == 0) {
|
332
|
+
this._inputChars.push(e.key);
|
333
|
+
editing.typedValue = `0${e.key}`;
|
334
|
+
if (parseInt(e.key) > 3) {
|
335
|
+
this._clearInputBuffer();
|
336
|
+
next = true;
|
337
|
+
}
|
338
|
+
}
|
339
|
+
else if (this._inputChars.length == 1) {
|
340
|
+
const newStr = parseInt(`${this._inputChars[0]}${e.key}`);
|
341
|
+
if (newStr > this._editingDateObj.month.totalDays) {
|
342
|
+
editing.typedValue = `0${e.key}`;
|
343
|
+
}
|
344
|
+
else {
|
345
|
+
editing.typedValue = newStr.toString();
|
346
|
+
}
|
347
|
+
this._clearInputBuffer();
|
348
|
+
next = true;
|
349
|
+
}
|
350
|
+
editing.typedValue = editing.typedValue?.length === 1 ? "0" + editing.typedValue : editing.typedValue;
|
351
|
+
const nv = parseInt(editing.typedValue);
|
352
|
+
if (nv > 0) {
|
353
|
+
const newVal = this.editingDateObj.set(part.key, nv);
|
354
|
+
this._editingDateObj = newVal;
|
355
|
+
this._detectValueChanges();
|
356
|
+
}
|
357
|
+
break;
|
358
|
+
}
|
359
|
+
case 'hour':
|
360
|
+
{
|
361
|
+
if (this._inputChars.length == 0) {
|
362
|
+
this._inputChars.push(e.key);
|
363
|
+
editing.typedValue = `0${e.key}`;
|
364
|
+
if (parseInt(e.key) > 2) {
|
365
|
+
next = true;
|
366
|
+
}
|
367
|
+
}
|
368
|
+
else if (this._inputChars.length == 1) {
|
369
|
+
const newStr = parseInt(`${this._inputChars[0]}${e.key}`);
|
370
|
+
if (newStr > 23) {
|
371
|
+
editing.typedValue = `0${e.key}`;
|
372
|
+
}
|
373
|
+
else {
|
374
|
+
editing.typedValue = newStr.toString();
|
375
|
+
}
|
376
|
+
next = true;
|
377
|
+
}
|
378
|
+
editing.typedValue = editing.typedValue?.length === 1 ? "0" + editing.typedValue : editing.typedValue;
|
379
|
+
const newVal = this.editingDateObj.set('hour', parseInt(editing.typedValue));
|
380
|
+
this._editingDateObj = newVal;
|
381
|
+
this._detectValueChanges();
|
382
|
+
break;
|
383
|
+
}
|
384
|
+
case 'minute':
|
385
|
+
case 'second':
|
386
|
+
if (this._inputChars.length == 0) {
|
387
|
+
this._inputChars.push(e.key);
|
388
|
+
editing.typedValue = `0${e.key}`;
|
389
|
+
if (parseInt(e.key) > 5) {
|
390
|
+
this._clearInputBuffer();
|
391
|
+
next = true;
|
392
|
+
}
|
393
|
+
}
|
394
|
+
else if (this._inputChars.length == 1) {
|
395
|
+
const newStr = parseInt(`${this._inputChars[0]}${e.key}`);
|
396
|
+
if (newStr > 59) {
|
397
|
+
editing.typedValue = `0${e.key}`;
|
398
|
+
}
|
399
|
+
else {
|
400
|
+
editing.typedValue = newStr.toString();
|
401
|
+
}
|
402
|
+
this._clearInputBuffer();
|
403
|
+
next = true;
|
404
|
+
}
|
405
|
+
editing.typedValue = editing.typedValue?.length === 1 ? "0" + editing.typedValue : editing.typedValue;
|
406
|
+
const newVal = this.editingDateObj.set(part.key, parseInt(editing.typedValue));
|
407
|
+
this._editingDateObj = newVal;
|
408
|
+
this._detectValueChanges();
|
409
|
+
break;
|
410
|
+
default:
|
411
|
+
}
|
412
|
+
if (next) {
|
413
|
+
goNext();
|
414
|
+
return;
|
415
|
+
}
|
416
|
+
}
|
417
|
+
/*************** Emit Event **************/
|
418
|
+
super.emitOnKeydownEvent(e);
|
419
|
+
}
|
420
|
+
_handleKeyUpEvent(e) {
|
421
|
+
if (this.activePart) {
|
422
|
+
this._highlightActivePart();
|
423
|
+
}
|
424
|
+
}
|
425
|
+
_handleFocusEvent(e) {
|
426
|
+
//this._highlightActivePart();
|
427
|
+
super.emitOnFocusEvent(e);
|
428
|
+
}
|
429
|
+
_handleBlurEvent(e) {
|
430
|
+
super.emitOnBlurEvent(e);
|
431
|
+
}
|
432
|
+
_handleOnInputClickEvent(e) {
|
433
|
+
setTimeout(() => {
|
434
|
+
this._detectPartAtPosition();
|
435
|
+
}, 0);
|
436
|
+
super.emitOnClickEvent(e);
|
437
|
+
}
|
438
|
+
_detectPartAtPosition() {
|
439
|
+
const input = this.input.nativeElement;
|
440
|
+
if (!input.value)
|
441
|
+
return;
|
442
|
+
const sStart = input.selectionEnd || 0;
|
443
|
+
const re = /[a-zA-Z0-9]+/gi;
|
444
|
+
const valueParts = Array.from(input.value.matchAll(re));
|
445
|
+
const orderedParts = this._getOrderedParts();
|
446
|
+
const index = valueParts.findIndex((c) => c.index <= sStart && (c.index + c[0].length) >= sStart);
|
447
|
+
this.activePart = orderedParts[index].key;
|
448
|
+
this._highlightActivePart();
|
449
|
+
}
|
450
|
+
_highlightActivePart() {
|
451
|
+
const input = this.input.nativeElement;
|
452
|
+
if (!input.value || !this.activePart)
|
453
|
+
return;
|
454
|
+
const orderedParts = this._getOrderedParts();
|
455
|
+
const index = orderedParts.findIndex(c => c.key == this.activePart);
|
456
|
+
const re = /[a-zA-Z0-9]+/gi;
|
457
|
+
const valueParts = Array.from(input.value.matchAll(re));
|
458
|
+
const { start, end } = AXStringUtil.getWordBoundsAtPosition(input.value, valueParts[index].index);
|
459
|
+
input.setSelectionRange(start, end);
|
460
|
+
}
|
461
|
+
_detectValueChanges() {
|
462
|
+
this.commitValue(this._editingDateObj.date, true);
|
463
|
+
}
|
464
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXDateTimeInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
465
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.9", type: AXDateTimeInputComponent, selector: "ax-datetime-input", inputs: { disabled: "disabled", readonly: "readonly", tabIndex: "tabIndex", placeholder: "placeholder", value: "value", state: "state", name: "name", id: "id", type: "type", minValue: "minValue", maxValue: "maxValue", format: "format" }, outputs: { valueChange: "valueChange", stateChange: "stateChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", onClick: "onClick", readonlyChange: "readonlyChange", disabledChange: "disabledChange", formatChange: "formatChange" }, host: { listeners: { "keydown": "_handleOnKeydownEvent($event)", "keyup": "_handleKeyUpEvent($event)" }, classAttribute: "ax-editor-input" }, providers: [
|
466
|
+
{ provide: AXComponent, useExisting: AXDateTimeInputComponent },
|
467
|
+
{ provide: AXFocusableComponent, useExisting: AXDateTimeInputComponent },
|
468
|
+
{ provide: AXValuableComponent, useExisting: AXDateTimeInputComponent },
|
469
|
+
{ provide: AXClearableComponent, useExisting: AXDateTimeInputComponent },
|
470
|
+
{
|
471
|
+
provide: NG_VALUE_ACCESSOR,
|
472
|
+
useExisting: forwardRef(() => AXDateTimeInputComponent),
|
473
|
+
multi: true,
|
474
|
+
},
|
475
|
+
], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "input2", first: true, predicate: ["input2"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<input #input autocomplete=\"off\" autocorrect=\"off\" autocapitalize=\"off\" spellcheck=\"false\" class=\"ax-input\" type=\"text\"\n [attr.placeholder]=\"placeholder\" [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\" [readonly]=\"true\" [ngModel]=\"_editingText\" (mouseup)=\"_handleOnInputClickEvent($event)\"\n (blur)=\"_handleBlurEvent($event)\" (focus)=\"_handleFocusEvent($event)\">", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
476
|
+
}
|
477
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXDateTimeInputComponent, decorators: [{
|
478
|
+
type: Component,
|
479
|
+
args: [{ selector: 'ax-datetime-input', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, inputs: ['disabled', 'readonly', 'tabIndex', 'placeholder', 'value', 'state', 'name', 'id'], host: { class: 'ax-editor-input' }, outputs: [
|
480
|
+
'valueChange',
|
481
|
+
'stateChange',
|
482
|
+
'onValueChanged',
|
483
|
+
'onBlur',
|
484
|
+
'onFocus',
|
485
|
+
'onClick',
|
486
|
+
'readonlyChange',
|
487
|
+
'disabledChange',
|
488
|
+
], providers: [
|
489
|
+
{ provide: AXComponent, useExisting: AXDateTimeInputComponent },
|
490
|
+
{ provide: AXFocusableComponent, useExisting: AXDateTimeInputComponent },
|
491
|
+
{ provide: AXValuableComponent, useExisting: AXDateTimeInputComponent },
|
492
|
+
{ provide: AXClearableComponent, useExisting: AXDateTimeInputComponent },
|
493
|
+
{
|
494
|
+
provide: NG_VALUE_ACCESSOR,
|
495
|
+
useExisting: forwardRef(() => AXDateTimeInputComponent),
|
496
|
+
multi: true,
|
497
|
+
},
|
498
|
+
], template: "<input #input autocomplete=\"off\" autocorrect=\"off\" autocapitalize=\"off\" spellcheck=\"false\" class=\"ax-input\" type=\"text\"\n [attr.placeholder]=\"placeholder\" [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\" [readonly]=\"true\" [ngModel]=\"_editingText\" (mouseup)=\"_handleOnInputClickEvent($event)\"\n (blur)=\"_handleBlurEvent($event)\" (focus)=\"_handleFocusEvent($event)\">" }]
|
499
|
+
}], propDecorators: { type: [{
|
500
|
+
type: Input
|
501
|
+
}], input: [{
|
502
|
+
type: ViewChild,
|
503
|
+
args: ['input']
|
504
|
+
}], input2: [{
|
505
|
+
type: ViewChild,
|
506
|
+
args: ['input2']
|
507
|
+
}], minValue: [{
|
508
|
+
type: Input
|
509
|
+
}], maxValue: [{
|
510
|
+
type: Input
|
511
|
+
}], formatChange: [{
|
512
|
+
type: Output
|
513
|
+
}], format: [{
|
514
|
+
type: Input
|
515
|
+
}], _handleOnKeydownEvent: [{
|
516
|
+
type: HostListener,
|
517
|
+
args: ["keydown", ["$event"]]
|
518
|
+
}], _handleKeyUpEvent: [{
|
519
|
+
type: HostListener,
|
520
|
+
args: ["keyup", ["$event"]]
|
521
|
+
}] } });
|
522
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-input.component.js","sourceRoot":"","sources":["../../../../../../libs/components/datetime-input/src/lib/datetime-input.component.ts","../../../../../../libs/components/datetime-input/src/lib/datetime-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, forwardRef, inject } from '@angular/core';\nimport { AXClearableComponent, AXComponent, AXFocusableComponent, AXValuableComponent, MXInputBaseValueComponent } from '@acorex/components/common';\nimport { AXStringUtil } from '@acorex/core/utils';\nimport { AXCalendarService, AXDateTime, TimeUnit, AXDateTimePart, AXDateTimeParts } from '@acorex/core/dateTime';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\n\n\n\n@Component({\n    selector: 'ax-datetime-input',\n    templateUrl: './datetime-input.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    inputs: ['disabled', 'readonly', 'tabIndex', 'placeholder', 'value', 'state', 'name', 'id'],\n    host: { class: 'ax-editor-input' },\n    outputs: [\n        'valueChange',\n        'stateChange',\n        'onValueChanged',\n        'onBlur',\n        'onFocus',\n        'onClick',\n        'readonlyChange',\n        'disabledChange',\n    ],\n    providers: [\n        { provide: AXComponent, useExisting: AXDateTimeInputComponent },\n        { provide: AXFocusableComponent, useExisting: AXDateTimeInputComponent },\n        { provide: AXValuableComponent, useExisting: AXDateTimeInputComponent },\n        { provide: AXClearableComponent, useExisting: AXDateTimeInputComponent },\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => AXDateTimeInputComponent),\n            multi: true,\n        },\n    ],\n})\nexport class AXDateTimeInputComponent extends MXInputBaseValueComponent<Date> {\n\n    private calendarService: AXCalendarService = inject(AXCalendarService);\n\n    private _editingParts: AXDateTimeParts = {\n        year: {\n            key: \"year\",\n            placeholder: \"yyyy\",\n            placeholders: [\"YY\", \"yy\", \"YYYY\", \"yyyy\"],\n            enabled: false,\n            default: 2023,\n            typedValue: null,\n            realValue: () => this.editingDateObj.format(this._editingParts.year.placeholder)\n        },\n        month: {\n            key: \"month\",\n            placeholder: \"MM\",\n            placeholders: [\"MMM\", \"MMMM\", \"MM\", \"M\"],\n            enabled: false,\n            default: 1,\n            typedValue: null,\n            realValue: () => this.editingDateObj.format(this._editingParts.month.placeholder)\n        },\n        day: {\n            key: \"day\",\n            placeholder: \"dd\",\n            placeholders: [\"dd\", \"d\"],\n            enabled: false,\n            default: 1,\n            typedValue: null,\n            realValue: () => this.editingDateObj.format(this._editingParts.day.placeholder)\n        },\n        hour: {\n            key: \"hour\",\n            placeholder: \"HH\",\n            placeholders: [\"HH\", \"H\", \"hh\", \"h\"],\n            enabled: false,\n            default: 0,\n            typedValue: null,\n            realValue: () => this.editingDateObj.format(this._editingParts.hour.placeholder)\n        },\n        minute: {\n            key: \"minute\",\n            placeholder: \"mm\",\n            placeholders: [\"mm\", \"m\"],\n            enabled: false,\n            default: 0,\n            typedValue: null,\n            realValue: () => this.editingDateObj.format(this._editingParts.minute.placeholder)\n        },\n        second: {\n            key: \"second\",\n            placeholder: \"ss\",\n            placeholders: [\"ss\", \"s\"],\n            enabled: false,\n            default: 0,\n            typedValue: null,\n            realValue: () => this.editingDateObj.format(this._editingParts.second.placeholder)\n        }\n    }\n\n    protected _editingText: string;\n    protected _inputChars: string[] = [];\n\n\n    private _type: string = this.calendarService.calendar.name();\n\n    @Input()\n    public get type(): string {\n        return this._type || this.calendarService.calendar.name();\n    }\n    public set type(v: string) {\n        this.setOption({\n            name: 'type',\n            value: v,\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            },\n        });\n    }\n\n\n    private _activePart = 'hour';\n    public get activePart(): string {\n        return this._activePart;\n    }\n    public set activePart(v: string) {\n        this._activePart = v;\n        this._clearInputBuffer();\n    }\n\n    private _editingDateObj: AXDateTime = this.calendarService.now(this.type);\n    private get editingDateObj(): AXDateTime {\n        return this._editingDateObj;\n    }\n\n\n    @ViewChild('input')\n    input: ElementRef<HTMLInputElement>;\n\n    @ViewChild('input2')\n    input2: ElementRef<HTMLInputElement>;\n\n    private _minValue: Date;\n    @Input()\n    public get minValue(): Date {\n        return this._minValue;\n    }\n    public set minValue(v: Date) {\n        this._minValue = v;\n    }\n\n    private _maxValue: Date;\n    @Input()\n    public get maxValue(): Date {\n        return this._maxValue;\n    }\n    public set maxValue(v: Date) {\n        this._maxValue = v;\n    }\n\n    @Output()\n    formatChange = new EventEmitter<string>();\n\n    private _format = this.calendarService.calendar.formats.dateTimeDisplay;\n    @Input()\n    public get format(): string {\n        return this._format;\n    }\n    public set format(v: string) {\n        this.setOption({\n            name: 'format',\n            value: v,\n            afterCallback: (o, n) => {\n                Object.values(this._editingParts).forEach(e => {\n                    e.enabled = false;\n                });\n                const formatParts = n.split(/[^a-zA-Z]+/);\n                formatParts.forEach(f => {\n                    const found = Object.values(this._editingParts).find(c => c.placeholders.some(d => d == f));\n                    if (found) {\n                        found.enabled = true;\n                        found.placeholder = f;\n                    }\n                });\n            },\n        });\n    }\n\n\n    private _getOrderedParts(): AXDateTimePart[] {\n        // TODO: better spliter format\n        const formatParts = this.format.split(/[^a-zA-Z]+/);\n        const result: AXDateTimePart[] = [];\n        formatParts.forEach(f => {\n            const found = Object.values(this._editingParts).find(c => c.placeholders.some(d => d == f));\n            if (found && found.enabled)\n                result.push(found);\n        });\n        return result;\n    }\n\n    private _clearInputBuffer() {\n        this._inputChars = [];\n    }\n\n    private _updateText() {\n        let text = this.format;\n        //\n        Object.values(this._editingParts).forEach(part => {\n            if (this.activePart == part.key) {\n                if (part.typedValue)\n                    text = text.replace(part.placeholder, part.typedValue);\n            }\n            else {\n                if (part.typedValue != part.placeholder && part.typedValue != null) {\n                    text = text.replace(part.placeholder, part.realValue())\n                }\n            }\n\n        });\n        this._editingText = text == this.format ? '' : text;\n        if (this.activePart) {\n            this._highlightActivePart()\n        }\n    }\n\n    override internalSetValue(value?: Date) {\n        if (value) {\n            let editingDate = this.calendarService.create(value, this.type);\n            let applyChanges = false;\n            Object.values(this._editingParts).forEach(part => {\n                if (!part.enabled) {\n                    editingDate = editingDate.set(part.key as TimeUnit, part.default);\n                    applyChanges = true;\n                }\n            });\n            if (applyChanges) {\n                return editingDate.date;\n            }\n        }\n        return value;\n    }\n\n    override internalValueChanged(value?: Date): void {\n        if (value) {\n            this._editingDateObj = this.calendarService.create(value, this.type);\n        }\n        Object.values(this._editingParts).forEach(part => {\n            if (value) {\n                if (part.typedValue != part.placeholder)\n                    part.typedValue = part.realValue();\n            }\n            else\n                part.typedValue = null;\n        });\n        this._updateText();\n    }\n\n    @HostListener(\"keydown\", [\"$event\"])\n    _handleOnKeydownEvent(e: KeyboardEvent) {\n        const ignore = () => {\n            e.preventDefault();\n            e.stopPropagation();\n        };\n\n        const input = e.target as HTMLInputElement;\n        //\n        const orderedParts = this._getOrderedParts();\n        const part = this.activePart ? this._editingParts[this.activePart] : orderedParts[0];\n        const nextPart = part ? orderedParts[orderedParts.indexOf(part) + 1] : null;\n        const prevPart = part ? orderedParts[orderedParts.indexOf(part) - 1] : null;\n        //\n        const goNext = () => {\n            this._clearInputBuffer();\n            if (nextPart) {\n                this.activePart = nextPart.key;\n                this._highlightActivePart();\n            }\n        };\n        const goPrev = () => {\n            this._clearInputBuffer();\n            if (prevPart) {\n                this.activePart = prevPart.key;\n                this._highlightActivePart();\n            }\n        };\n        /***************  Handle Left and Right  **************/\n        if (e.code === 'ArrowRight' || e.code === 'ArrowLeft') {\n            ignore();\n            e.code === 'ArrowRight' ? goNext() : goPrev();\n        }\n        /***************  Handle Up and Down  **************/\n        else if ((e.code === 'ArrowUp' || e.code === 'ArrowDown') && !e.ctrlKey) {\n            if (this.disabled || this.readonly) {\n                ignore();\n                return;\n            }\n            else {\n                ignore();\n                const sign = e.code === 'ArrowUp' ? +1 : -1;\n                this.activePart = part.key;\n                let newVal: AXDateTime = this.editingDateObj.add(part.key, sign);\n                this._editingParts[part.key].typedValue = newVal.format(this._editingParts[part.key].placeholder)\n                this._editingDateObj = newVal;\n                this._detectValueChanges();\n            }\n        }\n        /***************  Handle Backspace  **************/\n        else if (e.code == 'Backspace' || e.code == 'Delete') {\n            if (this.disabled || this.readonly) {\n                return;\n            }\n            if (input.value) {\n                ignore();\n                this._editingParts[part.key].typedValue = this._editingParts[part.key].placeholder;\n                this._detectValueChanges();\n                goPrev();\n            }\n        }\n        /***************  Handle Backspace  **************/\n        else if (e.code == 'Tab' || e.code == 'Space') {\n            if (input.value) {\n                if (!e.shiftKey && nextPart) {\n                    ignore();\n                    goNext();\n                } else if (e.shiftKey && prevPart) {\n                    ignore();\n                    goPrev();\n                }\n            }\n        }\n        else if (e.key?.trim() && !isNaN(Number(e.key))) {\n            ignore();\n            if (this.disabled || this.readonly) {\n                return;\n            }\n            let next = false;\n            const editing = this._editingParts[part.key];\n            //\n            switch (part.key) {\n                case 'year':\n                    {\n                        if (editing.placeholder.length == 2 && this._inputChars.length == 0) {\n                            this._inputChars.push(...this.calendarService.now(this.type).format('yyyy').substring(0, 2).split(''));\n                        }\n                        if (this._inputChars.length < 4) {\n                            editing.typedValue = `${this._inputChars.join('')}${e.key}`;\n                            this._inputChars.push(e.key)\n                            if (this._inputChars.length > 3) {\n                                next = true;\n                            }\n                        }\n                        else {\n                            next = true;\n                        }\n                        editing.typedValue = ('0000' + editing.typedValue).slice(-4);\n                        const nv = parseInt(editing.typedValue);\n                        //if (nv > 0) {\n                        const newVal = this.editingDateObj.set('year', nv);\n                        this._editingDateObj = newVal;\n                        this._detectValueChanges();\n                        //}\n                        break;\n                    }\n                case 'month':\n                    {\n                        if (this._inputChars.length == 0) {\n                            this._inputChars.push(e.key)\n                            editing.typedValue = `0${e.key}`;\n                            if (parseInt(e.key) > 1) {\n                                this._clearInputBuffer();\n                                next = true;\n                            }\n                        }\n                        else if (this._inputChars.length == 1) {\n                            const newStr = parseInt(`${this._inputChars[0]}${e.key}`);\n                            if (newStr > 12) {\n                                editing.typedValue = `0${e.key}`;\n                            }\n                            else {\n                                editing.typedValue = newStr.toString();\n                            }\n                            this._clearInputBuffer();\n                            next = true;\n                        }\n                        editing.typedValue = editing.typedValue?.length === 1 ? \"0\" + editing.typedValue : editing.typedValue;\n                        const nv = parseInt(editing.typedValue);\n                        if (nv > 0) {\n                            const newVal = this.editingDateObj.set(part.key, nv);\n                            this._editingDateObj = newVal;\n                            this._detectValueChanges();\n                        }\n                        break;\n                    }\n                case 'day':\n                    {\n                        if (this._inputChars.length == 0) {\n                            this._inputChars.push(e.key)\n                            editing.typedValue = `0${e.key}`;\n                            if (parseInt(e.key) > 3) {\n                                this._clearInputBuffer();\n                                next = true;\n                            }\n                        }\n                        else if (this._inputChars.length == 1) {\n                            const newStr = parseInt(`${this._inputChars[0]}${e.key}`);\n                            if (newStr > this._editingDateObj.month.totalDays) {\n                                editing.typedValue = `0${e.key}`;\n                            }\n                            else {\n                                editing.typedValue = newStr.toString();\n                            }\n                            this._clearInputBuffer();\n                            next = true;\n                        }\n                        editing.typedValue = editing.typedValue?.length === 1 ? \"0\" + editing.typedValue : editing.typedValue;\n                        const nv = parseInt(editing.typedValue);\n                        if (nv > 0) {\n                            const newVal = this.editingDateObj.set(part.key, nv);\n                            this._editingDateObj = newVal;\n                            this._detectValueChanges();\n                        }\n                        break;\n                    }\n                case 'hour':\n                    {\n                        if (this._inputChars.length == 0) {\n                            this._inputChars.push(e.key)\n                            editing.typedValue = `0${e.key}`;\n                            if (parseInt(e.key) > 2) {\n                                next = true;\n                            }\n                        }\n                        else if (this._inputChars.length == 1) {\n                            const newStr = parseInt(`${this._inputChars[0]}${e.key}`);\n                            if (newStr > 23) {\n                                editing.typedValue = `0${e.key}`;\n                            }\n                            else {\n                                editing.typedValue = newStr.toString();\n                            }\n                            next = true;\n                        }\n                        editing.typedValue = editing.typedValue?.length === 1 ? \"0\" + editing.typedValue : editing.typedValue;\n                        const newVal = this.editingDateObj.set('hour', parseInt(editing.typedValue));\n                        this._editingDateObj = newVal;\n                        this._detectValueChanges();\n                        break;\n                    }\n                case 'minute':\n                case 'second':\n                    if (this._inputChars.length == 0) {\n                        this._inputChars.push(e.key)\n                        editing.typedValue = `0${e.key}`;\n                        if (parseInt(e.key) > 5) {\n                            this._clearInputBuffer();\n                            next = true;\n                        }\n                    }\n                    else if (this._inputChars.length == 1) {\n                        const newStr = parseInt(`${this._inputChars[0]}${e.key}`);\n                        if (newStr > 59) {\n                            editing.typedValue = `0${e.key}`;\n                        }\n                        else {\n                            editing.typedValue = newStr.toString();\n                        }\n                        this._clearInputBuffer();\n                        next = true;\n                    }\n                    editing.typedValue = editing.typedValue?.length === 1 ? \"0\" + editing.typedValue : editing.typedValue;\n                    const newVal = this.editingDateObj.set(part.key, parseInt(editing.typedValue));\n                    this._editingDateObj = newVal;\n                    this._detectValueChanges();\n                    break;\n                default:\n            }\n            if (next) {\n                goNext()\n                return;\n            }\n        }\n        /***************  Emit Event  **************/\n        super.emitOnKeydownEvent(e);\n    }\n\n    @HostListener(\"keyup\", [\"$event\"])\n    _handleKeyUpEvent(e: KeyboardEvent) {\n        if (this.activePart) {\n            this._highlightActivePart()\n        }\n    }\n\n    protected _handleFocusEvent(e: FocusEvent) {\n        //this._highlightActivePart();\n        super.emitOnFocusEvent(e);\n    }\n\n    protected _handleBlurEvent(e: FocusEvent) {\n        super.emitOnBlurEvent(e);\n    }\n\n    protected _handleOnInputClickEvent(e: MouseEvent): void {\n        setTimeout(() => {\n            this._detectPartAtPosition();\n        }, 0);\n        super.emitOnClickEvent(e);\n    }\n\n    private _detectPartAtPosition(): void {\n        const input = this.input.nativeElement;\n        if (!input.value)\n            return;\n        const sStart = input.selectionEnd || 0;\n        const re = /[a-zA-Z0-9]+/gi;\n        const valueParts = Array.from(input.value.matchAll(re));\n        const orderedParts = this._getOrderedParts();\n        const index = valueParts.findIndex((c: any) => c.index <= sStart && (c.index + c[0].length) >= sStart);\n        this.activePart = orderedParts[index].key;\n        this._highlightActivePart();\n    }\n\n    private _highlightActivePart(): void {\n        const input = this.input.nativeElement;\n        if (!input.value || !this.activePart)\n            return;\n        const orderedParts = this._getOrderedParts();\n        const index = orderedParts.findIndex(c => c.key == this.activePart);\n        const re = /[a-zA-Z0-9]+/gi;\n        const valueParts = Array.from(input.value.matchAll(re));\n        const { start, end } = AXStringUtil.getWordBoundsAtPosition(\n            input.value, valueParts[index].index\n        );\n        input.setSelectionRange(start, end);\n    }\n\n    private _detectValueChanges() {\n        this.commitValue(this._editingDateObj.date, true);\n    }\n}\n","<input #input autocomplete=\"off\" autocorrect=\"off\" autocapitalize=\"off\" spellcheck=\"false\" class=\"ax-input\" type=\"text\"\n    [attr.placeholder]=\"placeholder\" [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\"\n    [disabled]=\"disabled\" [readonly]=\"true\" [ngModel]=\"_editingText\" (mouseup)=\"_handleOnInputClickEvent($event)\"\n    (blur)=\"_handleBlurEvent($event)\" (focus)=\"_handleFocusEvent($event)\">"]}
|