@acorex/components 5.0.8 → 5.0.14
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/{esm2015/acorex-components.js → esm2020/acorex-components.mjs} +0 -0
- package/{esm2015/lib/alert/alert-button.component.js → esm2020/lib/alert/alert-button.component.mjs} +3 -3
- package/{esm2015/lib/alert/alert-contnet.component.js → esm2020/lib/alert/alert-contnet.component.mjs} +3 -3
- package/{esm2015/lib/alert/alert-footer.component.js → esm2020/lib/alert/alert-footer.component.mjs} +3 -3
- package/{esm2015/lib/alert/alert-suffix.component.js → esm2020/lib/alert/alert-suffix.component.mjs} +3 -3
- package/{esm2015/lib/alert/alert-title.component.js → esm2020/lib/alert/alert-title.component.mjs} +3 -3
- package/esm2020/lib/alert/alert.component.mjs +124 -0
- package/{esm2015/lib/alert/alert.module.js → esm2020/lib/alert/alert.module.mjs} +4 -4
- package/{esm2015/lib/alert/index.js → esm2020/lib/alert/index.mjs} +0 -0
- package/{esm2015/lib/avatar/avatar.component.js → esm2020/lib/avatar/avatar.component.mjs} +5 -12
- package/{esm2015/lib/avatar/avatar.module.js → esm2020/lib/avatar/avatar.module.mjs} +4 -4
- package/{esm2015/lib/avatar/index.js → esm2020/lib/avatar/index.mjs} +0 -0
- package/{esm2015/lib/badge/badge.component.js → esm2020/lib/badge/badge.component.mjs} +6 -12
- package/{esm2015/lib/badge/badge.module.js → esm2020/lib/badge/badge.module.mjs} +4 -4
- package/{esm2015/lib/badge/index.js → esm2020/lib/badge/index.mjs} +0 -0
- package/{esm2015/lib/base/common.module.js → esm2020/lib/base/common.module.mjs} +4 -4
- package/{esm2015/lib/base/custom-cdk-overlay.service.js → esm2020/lib/base/custom-cdk-overlay.service.mjs} +6 -6
- package/{esm2015/lib/base/drawing.class.js → esm2020/lib/base/drawing.class.mjs} +0 -0
- package/{esm2015/lib/base/events.class.js → esm2020/lib/base/events.class.mjs} +0 -0
- package/{esm2015/lib/base/index.js → esm2020/lib/base/index.mjs} +0 -0
- package/esm2020/lib/base/mixin/base-components.class.mjs +102 -0
- package/esm2020/lib/base/mixin/button-mixin.class.mjs +116 -0
- package/esm2020/lib/base/mixin/clickable-mixin.class.mjs +24 -0
- package/{esm2015/lib/base/mixin/constratctor.js → esm2020/lib/base/mixin/constratctor.mjs} +0 -0
- package/esm2020/lib/base/mixin/datalist-component.class.mjs +96 -0
- package/esm2020/lib/base/mixin/dropdown-mixin.class.mjs +89 -0
- package/{esm2015/lib/base/mixin/index.js → esm2020/lib/base/mixin/index.mjs} +0 -0
- package/esm2020/lib/base/mixin/interactive-mixin.class.mjs +77 -0
- package/{esm2015/lib/base/mixin/loading-mixin.class.js → esm2020/lib/base/mixin/loading-mixin.class.mjs} +0 -0
- package/{esm2015/lib/base/mixin/mixin.class.js → esm2020/lib/base/mixin/mixin.class.mjs} +2 -2
- package/{esm2015/lib/base/mixin/selection-component.class.js → esm2020/lib/base/mixin/selection-component.class.mjs} +0 -0
- package/{esm2015/lib/base/mixin/sizable-mixin.class.js → esm2020/lib/base/mixin/sizable-mixin.class.mjs} +0 -0
- package/{esm2015/lib/base/mixin/textbox-mixin.class.js → esm2020/lib/base/mixin/textbox-mixin.class.mjs} +0 -0
- package/esm2020/lib/base/mixin/value-mixin.class.mjs +196 -0
- package/{esm2015/lib/base/overlay.service.js → esm2020/lib/base/overlay.service.mjs} +3 -3
- package/{esm2015/lib/base/responsive.directive.js → esm2020/lib/base/responsive.directive.mjs} +3 -3
- package/{esm2015/lib/base/styles.class.js → esm2020/lib/base/styles.class.mjs} +0 -0
- package/{esm2015/lib/button/button-group.component.js → esm2020/lib/button/button-group.component.mjs} +8 -15
- package/{esm2015/lib/button/button-item.class.js → esm2020/lib/button/button-item.class.mjs} +0 -0
- package/{esm2015/lib/button/button-item.component.js → esm2020/lib/button/button-item.component.mjs} +3 -3
- package/esm2020/lib/button/button.component.mjs +65 -0
- package/{esm2015/lib/button/button.module.js → esm2020/lib/button/button.module.mjs} +4 -4
- package/{esm2015/lib/button/index.js → esm2020/lib/button/index.mjs} +0 -0
- package/esm2020/lib/calendar/calendar.class.mjs +97 -0
- package/esm2020/lib/calendar/calendar.component.mjs +230 -0
- package/{esm2015/lib/calendar/calendar.module.js → esm2020/lib/calendar/calendar.module.mjs} +4 -4
- package/{esm2015/lib/calendar/index.js → esm2020/lib/calendar/index.mjs} +0 -0
- package/{esm2015/lib/carousel/carousel-arrows.component.js → esm2020/lib/carousel/carousel-arrows.component.mjs} +3 -3
- package/{esm2015/lib/carousel/carousel-item.component.js → esm2020/lib/carousel/carousel-item.component.mjs} +3 -3
- package/{esm2015/lib/carousel/carousel-pager.component.js → esm2020/lib/carousel/carousel-pager.component.mjs} +3 -3
- package/{esm2015/lib/carousel/carousel-splidejs.class.js → esm2020/lib/carousel/carousel-splidejs.class.mjs} +0 -0
- package/{esm2015/lib/carousel/carousel.class.js → esm2020/lib/carousel/carousel.class.mjs} +3 -3
- package/{esm2015/lib/carousel/carousel.component.js → esm2020/lib/carousel/carousel.component.mjs} +7 -15
- package/{esm2015/lib/carousel/carousel.module.js → esm2020/lib/carousel/carousel.module.mjs} +4 -4
- package/{esm2015/lib/carousel/index.js → esm2020/lib/carousel/index.mjs} +0 -0
- package/esm2020/lib/checkbox/checkbox.component.mjs +51 -0
- package/{esm2015/lib/checkbox/checkbox.module.js → esm2020/lib/checkbox/checkbox.module.mjs} +4 -4
- package/{esm2015/lib/checkbox/index.js → esm2020/lib/checkbox/index.mjs} +0 -0
- package/esm2020/lib/datalist/datalist.component.mjs +73 -0
- package/{esm2015/lib/datalist/datalist.module.js → esm2020/lib/datalist/datalist.module.mjs} +4 -4
- package/{esm2015/lib/datalist/index.js → esm2020/lib/datalist/index.mjs} +0 -0
- package/esm2020/lib/datepicker/datepicker.component.mjs +125 -0
- package/esm2020/lib/datepicker/datepicker.module.mjs +47 -0
- package/{esm2015/lib/datepicker/index.js → esm2020/lib/datepicker/index.mjs} +0 -0
- package/esm2020/lib/decorators/content.component.mjs +26 -0
- package/esm2020/lib/decorators/decorators.module.mjs +23 -0
- package/{esm2015/lib/decorators/index.js → esm2020/lib/decorators/index.mjs} +2 -1
- package/{esm2015/lib/decorators/prefix.component.js → esm2020/lib/decorators/prefix.component.mjs} +5 -6
- package/{esm2015/lib/decorators/suffix.component.js → esm2020/lib/decorators/suffix.component.mjs} +5 -6
- package/{esm2015/lib/dialog/dialog.class.js → esm2020/lib/dialog/dialog.class.mjs} +0 -0
- package/esm2020/lib/dialog/dialog.component.mjs +40 -0
- package/{esm2015/lib/dialog/dialog.module.js → esm2020/lib/dialog/dialog.module.mjs} +4 -4
- package/esm2020/lib/dialog/dialog.service.mjs +145 -0
- package/{esm2015/lib/dialog/index.js → esm2020/lib/dialog/index.mjs} +0 -0
- package/{esm2015/lib/drawer/drawer-container.component.js → esm2020/lib/drawer/drawer-container.component.mjs} +3 -3
- package/{esm2015/lib/drawer/drawer-content.component.js → esm2020/lib/drawer/drawer-content.component.mjs} +3 -3
- package/{esm2015/lib/drawer/drawer.component.js → esm2020/lib/drawer/drawer.component.mjs} +3 -3
- package/{esm2015/lib/drawer/drawer.module.js → esm2020/lib/drawer/drawer.module.mjs} +4 -4
- package/{esm2015/lib/drawer/index.js → esm2020/lib/drawer/index.mjs} +0 -0
- package/esm2020/lib/dropdown/dropdown-panel.component.mjs +80 -0
- package/esm2020/lib/dropdown/dropdown.component.mjs +28 -0
- package/{esm2015/lib/dropdown/dropdown.module.js → esm2020/lib/dropdown/dropdown.module.mjs} +4 -4
- package/{esm2015/lib/dropdown/index.js → esm2020/lib/dropdown/index.mjs} +0 -0
- package/{esm2015/lib/form/form-field.component.js → esm2020/lib/form/form-field.component.mjs} +3 -3
- package/{esm2015/lib/form/form-field.module.js → esm2020/lib/form/form-field.module.mjs} +4 -4
- package/{esm2015/lib/form/form-hint.component.js → esm2020/lib/form/form-hint.component.mjs} +5 -5
- package/{esm2015/lib/form/form.component.js → esm2020/lib/form/form.component.mjs} +3 -3
- package/{esm2015/lib/form/index.js → esm2020/lib/form/index.mjs} +0 -0
- package/{esm2015/lib/icon/icon.component.js → esm2020/lib/icon/icon.component.mjs} +3 -3
- package/{esm2015/lib/icon/icon.module.js → esm2020/lib/icon/icon.module.mjs} +4 -4
- package/{esm2015/lib/icon/index.js → esm2020/lib/icon/index.mjs} +0 -0
- package/{esm2015/lib/input-mask/index.js → esm2020/lib/input-mask/index.mjs} +0 -0
- package/{esm2015/lib/input-mask/input-mask.component.js → esm2020/lib/input-mask/input-mask.component.mjs} +3 -3
- package/{esm2015/lib/input-mask/input-mask.module.js → esm2020/lib/input-mask/input-mask.module.mjs} +4 -4
- package/{esm2015/lib/label/index.js → esm2020/lib/label/index.mjs} +0 -0
- package/esm2020/lib/label/label.component.mjs +15 -0
- package/{esm2015/lib/label/label.module.js → esm2020/lib/label/label.module.mjs} +4 -4
- package/{esm2015/lib/loading/index.js → esm2020/lib/loading/index.mjs} +0 -0
- package/{esm2015/lib/loading/loading-spinner.component.js → esm2020/lib/loading/loading-spinner.component.mjs} +3 -3
- package/{esm2015/lib/loading/loading.component.js → esm2020/lib/loading/loading.component.mjs} +3 -3
- package/{esm2015/lib/loading/loading.directive.js → esm2020/lib/loading/loading.directive.mjs} +3 -3
- package/{esm2015/lib/loading/loading.module.js → esm2020/lib/loading/loading.module.mjs} +4 -4
- package/esm2020/lib/loading/loading.service.mjs +154 -0
- package/{esm2015/lib/number-box/index.js → esm2020/lib/number-box/index.mjs} +0 -0
- package/{esm2015/lib/number-box/number-box.component.js → esm2020/lib/number-box/number-box.component.mjs} +9 -17
- package/{esm2015/lib/number-box/number-box.module.js → esm2020/lib/number-box/number-box.module.mjs} +4 -4
- package/esm2020/lib/page/base-page.class.mjs +67 -0
- package/{esm2015/lib/page/index.js → esm2020/lib/page/index.mjs} +0 -0
- package/{esm2015/lib/page/page-footer.component.js → esm2020/lib/page/page-footer.component.mjs} +6 -10
- package/{esm2015/lib/page/page.component.js → esm2020/lib/page/page.component.mjs} +3 -3
- package/{esm2015/lib/page/page.module.js → esm2020/lib/page/page.module.mjs} +4 -4
- package/{esm2015/lib/password-box/index.js → esm2020/lib/password-box/index.mjs} +0 -0
- package/{esm2015/lib/password-box/password-box.component.js → esm2020/lib/password-box/password-box.component.mjs} +7 -15
- package/{esm2015/lib/password-box/password-box.module.js → esm2020/lib/password-box/password-box.module.mjs} +4 -4
- package/{esm2015/lib/popover/index.js → esm2020/lib/popover/index.mjs} +0 -0
- package/esm2020/lib/popover/popover.component.mjs +213 -0
- package/{esm2015/lib/popover/popover.module.js → esm2020/lib/popover/popover.module.mjs} +4 -4
- package/{esm2015/lib/popup/index.js → esm2020/lib/popup/index.mjs} +0 -0
- package/esm2020/lib/popup/popup.component.mjs +100 -0
- package/{esm2015/lib/popup/popup.module.js → esm2020/lib/popup/popup.module.mjs} +4 -4
- package/esm2020/lib/popup/popup.service.mjs +93 -0
- package/esm2020/lib/radio/index.mjs +3 -0
- package/esm2020/lib/radio/radio.component.mjs +16 -0
- package/esm2020/lib/radio/radio.module.mjs +21 -0
- package/{esm2015/lib/range-slider/index.js → esm2020/lib/range-slider/index.mjs} +0 -0
- package/{esm2015/lib/range-slider/range-slider.component.js → esm2020/lib/range-slider/range-slider.component.mjs} +5 -11
- package/{esm2015/lib/range-slider/range-slider.module.js → esm2020/lib/range-slider/range-slider.module.mjs} +4 -4
- package/{esm2015/lib/selectbox/index.js → esm2020/lib/selectbox/index.mjs} +0 -0
- package/esm2020/lib/selectbox/selectbox.component.mjs +193 -0
- package/{esm2015/lib/selectbox/selectbox.module.js → esm2020/lib/selectbox/selectbox.module.mjs} +4 -4
- package/{esm2015/lib/selection-list/index.js → esm2020/lib/selection-list/index.mjs} +0 -0
- package/esm2020/lib/selection-list/selection-list.component.mjs +40 -0
- package/{esm2015/lib/selection-list/selection-list.module.js → esm2020/lib/selection-list/selection-list.module.mjs} +4 -4
- package/{esm2015/lib/side-menu/index.js → esm2020/lib/side-menu/index.mjs} +0 -0
- package/{esm2015/lib/side-menu/side-menu.component.js → esm2020/lib/side-menu/side-menu.component.mjs} +5 -11
- package/{esm2015/lib/side-menu/side-menu.module.js → esm2020/lib/side-menu/side-menu.module.mjs} +4 -4
- package/{esm2015/lib/switch/index.js → esm2020/lib/switch/index.mjs} +0 -0
- package/{esm2015/lib/switch/switch.component.js → esm2020/lib/switch/switch.component.mjs} +5 -12
- package/{esm2015/lib/switch/switch.module.js → esm2020/lib/switch/switch.module.mjs} +6 -7
- package/{esm2015/lib/tabs/index.js → esm2020/lib/tabs/index.mjs} +0 -0
- package/esm2020/lib/tabs/tab-content.directive.mjs +29 -0
- package/esm2020/lib/tabs/tab-item.component.mjs +91 -0
- package/{esm2015/lib/tabs/tab-strip.component.js → esm2020/lib/tabs/tab-strip.component.mjs} +5 -12
- package/{esm2015/lib/tabs/tab-view.component.js → esm2020/lib/tabs/tab-view.component.mjs} +5 -12
- package/{esm2015/lib/tabs/tab.component.js → esm2020/lib/tabs/tab.component.mjs} +3 -3
- package/{esm2015/lib/tabs/tabs.class.js → esm2020/lib/tabs/tabs.class.mjs} +0 -0
- package/esm2020/lib/tabs/tabs.component.mjs +67 -0
- package/{esm2015/lib/tabs/tabs.module.js → esm2020/lib/tabs/tabs.module.mjs} +4 -4
- package/{esm2015/lib/textbox/index.js → esm2020/lib/textbox/index.mjs} +0 -0
- package/{esm2015/lib/textbox/textbox.component.js → esm2020/lib/textbox/textbox.component.mjs} +7 -15
- package/{esm2015/lib/textbox/textbox.module.js → esm2020/lib/textbox/textbox.module.mjs} +4 -4
- package/{esm2015/lib/time-box/index.js → esm2020/lib/time-box/index.mjs} +0 -0
- package/{esm2015/lib/time-box/time-box.component.js → esm2020/lib/time-box/time-box.component.mjs} +5 -13
- package/{esm2015/lib/time-box/time-box.module.js → esm2020/lib/time-box/time-box.module.mjs} +4 -4
- package/{esm2015/lib/toast/index.js → esm2020/lib/toast/index.mjs} +0 -0
- package/{esm2015/lib/toast/toast.class.js → esm2020/lib/toast/toast.class.mjs} +0 -0
- package/esm2020/lib/toast/toast.component.mjs +44 -0
- package/{esm2015/lib/toast/toast.module.js → esm2020/lib/toast/toast.module.mjs} +4 -4
- package/{esm2015/lib/toast/toast.service.js → esm2020/lib/toast/toast.service.mjs} +3 -3
- package/{esm2015/lib/tooltip/index.js → esm2020/lib/tooltip/index.mjs} +0 -0
- package/{esm2015/lib/tooltip/tooltip.component.js → esm2020/lib/tooltip/tooltip.component.mjs} +6 -13
- package/{esm2015/lib/tooltip/tooltip.directive.js → esm2020/lib/tooltip/tooltip.directive.mjs} +3 -3
- package/{esm2015/lib/tooltip/tooltip.module.js → esm2020/lib/tooltip/tooltip.module.mjs} +4 -4
- package/{esm2015/lib/validation/index.js → esm2020/lib/validation/index.mjs} +0 -0
- package/{esm2015/lib/validation/validation-rule.widget.js → esm2020/lib/validation/validation-rule.widget.mjs} +3 -3
- package/{esm2015/lib/validation/validation.class.js → esm2020/lib/validation/validation.class.mjs} +0 -0
- package/{esm2015/lib/validation/validation.module.js → esm2020/lib/validation/validation.module.mjs} +4 -4
- package/esm2020/public-api.mjs +42 -0
- package/fesm2015/acorex-components.mjs +6423 -0
- package/fesm2015/acorex-components.mjs.map +1 -0
- package/{fesm2015/acorex-components.js → fesm2020/acorex-components.mjs} +1343 -1386
- package/fesm2020/acorex-components.mjs.map +1 -0
- package/lib/base/mixin/base-components.class.d.ts +23 -18
- package/lib/base/mixin/button-mixin.class.d.ts +12 -17
- package/lib/base/mixin/clickable-mixin.class.d.ts +4 -9
- package/lib/base/mixin/datalist-component.class.d.ts +10 -15
- package/lib/base/mixin/dropdown-mixin.class.d.ts +17 -12
- package/lib/base/mixin/interactive-mixin.class.d.ts +6 -11
- package/lib/base/mixin/loading-mixin.class.d.ts +4 -9
- package/lib/base/mixin/mixin.class.d.ts +183 -165
- package/lib/base/mixin/selection-component.class.d.ts +4 -9
- package/lib/base/mixin/sizable-mixin.class.d.ts +4 -9
- package/lib/base/mixin/textbox-mixin.class.d.ts +5 -12
- package/lib/base/mixin/value-mixin.class.d.ts +16 -20
- package/lib/button/button-item.component.d.ts +10 -20
- package/lib/calendar/calendar.class.d.ts +38 -0
- package/lib/calendar/calendar.component.d.ts +5 -26
- package/lib/checkbox/checkbox.component.d.ts +6 -5
- package/lib/datepicker/datepicker.component.d.ts +170 -16
- package/lib/datepicker/datepicker.module.d.ts +8 -2
- package/lib/decorators/content.component.d.ts +8 -0
- package/lib/decorators/decorators.module.d.ts +3 -2
- package/lib/decorators/index.d.ts +1 -0
- package/lib/dropdown/dropdown-panel.component.d.ts +4 -5
- package/lib/dropdown/dropdown.component.d.ts +5 -6
- package/lib/label/label.component.d.ts +2 -2
- package/lib/popup/popup.component.d.ts +3 -2
- package/lib/radio/index.d.ts +2 -0
- package/lib/radio/radio.component.d.ts +8 -0
- package/lib/radio/radio.module.d.ts +8 -0
- package/lib/tabs/tab-item.component.d.ts +2 -1
- package/lib/tabs/tabs.component.d.ts +2 -4
- package/package.json +21 -8
- package/public-api.d.ts +1 -0
- package/bundles/acorex-components.umd.js +0 -7545
- package/bundles/acorex-components.umd.js.map +0 -1
- package/esm2015/lib/alert/alert.component.js +0 -130
- package/esm2015/lib/base/mixin/base-components.class.js +0 -83
- package/esm2015/lib/base/mixin/button-mixin.class.js +0 -129
- package/esm2015/lib/base/mixin/clickable-mixin.class.js +0 -24
- package/esm2015/lib/base/mixin/datalist-component.class.js +0 -97
- package/esm2015/lib/base/mixin/dropdown-mixin.class.js +0 -36
- package/esm2015/lib/base/mixin/interactive-mixin.class.js +0 -77
- package/esm2015/lib/base/mixin/value-mixin.class.js +0 -190
- package/esm2015/lib/button/button.component.js +0 -73
- package/esm2015/lib/calendar/calendar.component.js +0 -287
- package/esm2015/lib/checkbox/checkbox.component.js +0 -40
- package/esm2015/lib/datalist/datalist.component.js +0 -81
- package/esm2015/lib/datepicker/datepicker.component.js +0 -80
- package/esm2015/lib/datepicker/datepicker.module.js +0 -23
- package/esm2015/lib/decorators/decorators.module.js +0 -22
- package/esm2015/lib/dialog/dialog.component.js +0 -45
- package/esm2015/lib/dialog/dialog.service.js +0 -146
- package/esm2015/lib/dropdown/dropdown-base.class.js +0 -98
- package/esm2015/lib/dropdown/dropdown-panel.component.js +0 -84
- package/esm2015/lib/dropdown/dropdown.component.js +0 -32
- package/esm2015/lib/label/label.component.js +0 -20
- package/esm2015/lib/loading/loading.service.js +0 -155
- package/esm2015/lib/page/base-page.class.js +0 -66
- package/esm2015/lib/popover/popover.component.js +0 -220
- package/esm2015/lib/popup/popup.component.js +0 -97
- package/esm2015/lib/popup/popup.service.js +0 -94
- package/esm2015/lib/selectbox/selectbox.component.js +0 -201
- package/esm2015/lib/selection-list/selection-list.component.js +0 -47
- package/esm2015/lib/tabs/tab-content.directive.js +0 -27
- package/esm2015/lib/tabs/tab-item.component.js +0 -76
- package/esm2015/lib/tabs/tabs.component.js +0 -74
- package/esm2015/lib/toast/toast.component.js +0 -50
- package/esm2015/public-api.js +0 -41
- package/fesm2015/acorex-components.js.map +0 -1
- package/lib/dropdown/dropdown-base.class.d.ts +0 -92
|
@@ -6,10 +6,10 @@ const COMPONENT = [AXIconComponent];
|
|
|
6
6
|
const MODULES = [CommonModule];
|
|
7
7
|
export class AXIconModule {
|
|
8
8
|
}
|
|
9
|
-
AXIconModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
10
|
-
AXIconModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "
|
|
11
|
-
AXIconModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
9
|
+
AXIconModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXIconModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
AXIconModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXIconModule, declarations: [AXIconComponent], imports: [CommonModule], exports: [AXIconComponent] });
|
|
11
|
+
AXIconModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXIconModule, providers: [], imports: [[...MODULES]] });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXIconModule, decorators: [{
|
|
13
13
|
type: NgModule,
|
|
14
14
|
args: [{
|
|
15
15
|
declarations: [...COMPONENT],
|
|
File without changes
|
|
File without changes
|
|
@@ -18,9 +18,9 @@ export class AXInputMaskComponent {
|
|
|
18
18
|
this._suffix = v;
|
|
19
19
|
}
|
|
20
20
|
}
|
|
21
|
-
AXInputMaskComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
22
|
-
AXInputMaskComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "
|
|
23
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
21
|
+
AXInputMaskComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXInputMaskComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
22
|
+
AXInputMaskComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AXInputMaskComponent, selector: "ax-input-mask", inputs: { prefix: "prefix", suffix: "suffix", showMaskTyped: "showMaskTyped", clearIfNotMatch: "clearIfNotMatch", mask: "mask" }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXInputMaskComponent, decorators: [{
|
|
24
24
|
type: Component,
|
|
25
25
|
args: [{
|
|
26
26
|
selector: 'ax-input-mask',
|
package/{esm2015/lib/input-mask/input-mask.module.js → esm2020/lib/input-mask/input-mask.module.mjs}
RENAMED
|
@@ -8,10 +8,10 @@ const COMPONENT = [AXInputMaskComponent];
|
|
|
8
8
|
const MODULES = [CommonModule, NgxMaskModule.forRoot()];
|
|
9
9
|
export class AXInputMaskModule {
|
|
10
10
|
}
|
|
11
|
-
AXInputMaskModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
12
|
-
AXInputMaskModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "
|
|
13
|
-
AXInputMaskModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
14
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
11
|
+
AXInputMaskModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXInputMaskModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
12
|
+
AXInputMaskModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXInputMaskModule, declarations: [AXInputMaskComponent], imports: [CommonModule, i1.NgxMaskModule], exports: [AXInputMaskComponent] });
|
|
13
|
+
AXInputMaskModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXInputMaskModule, providers: [], imports: [[...MODULES]] });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXInputMaskModule, decorators: [{
|
|
15
15
|
type: NgModule,
|
|
16
16
|
args: [{
|
|
17
17
|
declarations: [...COMPONENT],
|
|
File without changes
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
+
import { AXBaseComponentMixin } from '../base';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class AXLabelComponent extends AXBaseComponentMixin {
|
|
5
|
+
constructor(elementRef, cdr) {
|
|
6
|
+
super(elementRef, cdr);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
AXLabelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLabelComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
+
AXLabelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AXLabelComponent, selector: "ax-label", usesInheritance: true, ngImport: i0, template: "<label>\r\n <ng-content></ng-content>\r\n</label>", changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLabelComponent, decorators: [{
|
|
12
|
+
type: Component,
|
|
13
|
+
args: [{ selector: 'ax-label', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<label>\r\n <ng-content></ng-content>\r\n</label>" }]
|
|
14
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; } });
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvc3JjL2xpYi9sYWJlbC9sYWJlbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2xhYmVsL2xhYmVsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQWlDLE1BQU0sZUFBZSxDQUFDO0FBQ3JILE9BQU8sRUFBRSxvQkFBb0IsRUFBQyxNQUFNLFNBQVMsQ0FBQzs7QUFROUMsTUFBTSxPQUFPLGdCQUFpQixTQUFRLG9CQUFvQjtJQUV4RCxZQUFZLFVBQXNCLEVBQUUsR0FBc0I7UUFDeEQsS0FBSyxDQUFDLFVBQVUsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN6QixDQUFDOzs2R0FKVSxnQkFBZ0I7aUdBQWhCLGdCQUFnQix1RUNUN0Isc0RBRVE7MkZET0ssZ0JBQWdCO2tCQU41QixTQUFTOytCQUNFLFVBQVUsbUJBRUgsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24sIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBFbGVtZW50UmVmLCBDaGFuZ2VEZXRlY3RvclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBWEJhc2VDb21wb25lbnRNaXhpbn0gZnJvbSAnLi4vYmFzZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2F4LWxhYmVsJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vbGFiZWwuY29tcG9uZW50Lmh0bWwnLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIEFYTGFiZWxDb21wb25lbnQgZXh0ZW5kcyBBWEJhc2VDb21wb25lbnRNaXhpbiB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgIHN1cGVyKGVsZW1lbnRSZWYsIGNkcik7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8bGFiZWw+XHJcbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbjwvbGFiZWw+Il19
|
|
@@ -6,10 +6,10 @@ const COMPONENT = [AXLabelComponent];
|
|
|
6
6
|
const MODULES = [CommonModule];
|
|
7
7
|
export class AXLabelModule {
|
|
8
8
|
}
|
|
9
|
-
AXLabelModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
10
|
-
AXLabelModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "
|
|
11
|
-
AXLabelModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
9
|
+
AXLabelModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLabelModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
AXLabelModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLabelModule, declarations: [AXLabelComponent], imports: [CommonModule], exports: [AXLabelComponent] });
|
|
11
|
+
AXLabelModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLabelModule, providers: [], imports: [[...MODULES]] });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLabelModule, decorators: [{
|
|
13
13
|
type: NgModule,
|
|
14
14
|
args: [{
|
|
15
15
|
declarations: [...COMPONENT],
|
|
File without changes
|
|
@@ -2,8 +2,8 @@ import { Component } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class AXLoadingSpinnerComponent {
|
|
4
4
|
}
|
|
5
|
-
AXLoadingSpinnerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
6
|
-
AXLoadingSpinnerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "
|
|
5
|
+
AXLoadingSpinnerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingSpinnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
AXLoadingSpinnerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AXLoadingSpinnerComponent, selector: "ax-loading-spinner", ngImport: i0, template: `
|
|
7
7
|
<svg version="1.1" width="100" id="loader-1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
8
8
|
x="0px" y="0px" viewBox="0 0 50 50" xml:space="preserve">
|
|
9
9
|
<path fill="current"
|
|
@@ -13,7 +13,7 @@ AXLoadingSpinnerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.
|
|
|
13
13
|
</path>
|
|
14
14
|
</svg>
|
|
15
15
|
`, isInline: true });
|
|
16
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingSpinnerComponent, decorators: [{
|
|
17
17
|
type: Component,
|
|
18
18
|
args: [{
|
|
19
19
|
selector: 'ax-loading-spinner',
|
package/{esm2015/lib/loading/loading.component.js → esm2020/lib/loading/loading.component.mjs}
RENAMED
|
@@ -29,11 +29,11 @@ export class AXLoadingComponent extends AXBaseComponentMixin {
|
|
|
29
29
|
this._cdr.markForCheck();
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
|
-
AXLoadingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
33
|
-
AXLoadingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "
|
|
32
|
+
AXLoadingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
AXLoadingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AXLoadingComponent, selector: "ax-loading", inputs: { visible: "visible", type: "type" }, outputs: { visibleChange: "visibleChange" }, host: { classAttribute: "ax-loading" }, usesInheritance: true, ngImport: i0, template: `
|
|
34
34
|
<ng-template [cdkPortalOutlet]="_selectedPortal" ></ng-template>
|
|
35
35
|
`, isInline: true, directives: [{ type: i1.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
36
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingComponent, decorators: [{
|
|
37
37
|
type: Component,
|
|
38
38
|
args: [{
|
|
39
39
|
selector: 'ax-loading',
|
package/{esm2015/lib/loading/loading.directive.js → esm2020/lib/loading/loading.directive.mjs}
RENAMED
|
@@ -53,9 +53,9 @@ export class AXLoadingDirective {
|
|
|
53
53
|
this.renderer.addClass(this.overlayElement, OVERLAY_CLASS);
|
|
54
54
|
}
|
|
55
55
|
}
|
|
56
|
-
AXLoadingDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
57
|
-
AXLoadingDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "
|
|
58
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
56
|
+
AXLoadingDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive });
|
|
57
|
+
AXLoadingDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.1.1", type: AXLoadingDirective, selector: "[axIsLoading]", inputs: { isLoading: ["axIsLoading", "isLoading"] }, usesOnChanges: true, ngImport: i0 });
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingDirective, decorators: [{
|
|
59
59
|
type: Directive,
|
|
60
60
|
args: [{
|
|
61
61
|
selector: '[axIsLoading]'
|
|
@@ -20,10 +20,10 @@ export class AXLoadingModule {
|
|
|
20
20
|
});
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
|
-
AXLoadingModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
24
|
-
AXLoadingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "
|
|
25
|
-
AXLoadingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
26
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
23
|
+
AXLoadingModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
24
|
+
AXLoadingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingModule, declarations: [AXLoadingComponent, AXLoadingDirective, AXLoadingSpinnerComponent], imports: [CommonModule, OverlayModule, PortalModule], exports: [AXLoadingComponent, AXLoadingDirective, AXLoadingSpinnerComponent] });
|
|
25
|
+
AXLoadingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingModule, providers: [], imports: [[...MODULES]] });
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingModule, decorators: [{
|
|
27
27
|
type: NgModule,
|
|
28
28
|
args: [{
|
|
29
29
|
declarations: [...COMPONENT],
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { asyncScheduler, BehaviorSubject } from 'rxjs';
|
|
3
|
+
import { finalize, observeOn } from 'rxjs/operators';
|
|
4
|
+
import { AXLoadingComponent } from './loading.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../base/overlay.service";
|
|
7
|
+
const DEFAULT_LOADER_ID = '_DEFAULT';
|
|
8
|
+
/**
|
|
9
|
+
* Used for centrally setting/unsetting loading flags for components or services.
|
|
10
|
+
* Should be connected to global HTTP interceptor which will unset
|
|
11
|
+
* the loading flags in case an error happens using the clearLoadings() method.
|
|
12
|
+
*
|
|
13
|
+
* FAQ:
|
|
14
|
+
* Q: How to change loading flag for a parent component?
|
|
15
|
+
* A: Inject the parent component as a dependency to your constructor and
|
|
16
|
+
* call loadingService.setLoading(parentComponent, STATE).
|
|
17
|
+
*
|
|
18
|
+
* Q: How to change loading flag for a child component?
|
|
19
|
+
* A: Use a @ViewChild with component selector and pass the
|
|
20
|
+
* reference of the child to setLoading method.
|
|
21
|
+
*
|
|
22
|
+
* Q: I need more loading indicators in my components. How to?
|
|
23
|
+
* A: Assign a LoaderId to each indicator and then use them
|
|
24
|
+
* with calls to methods of this service.
|
|
25
|
+
*/
|
|
26
|
+
export class AXLoadingService {
|
|
27
|
+
constructor(zoneRef, overlayService) {
|
|
28
|
+
this.zoneRef = zoneRef;
|
|
29
|
+
this.overlayService = overlayService;
|
|
30
|
+
// WeakMap will remove components from itself upon
|
|
31
|
+
// their garbage collection by JS runtime.
|
|
32
|
+
this.loadingStates = new WeakMap();
|
|
33
|
+
// Both loading state maps are kept in-sync such that
|
|
34
|
+
// they can be used by both sync and async methods.
|
|
35
|
+
this.loadingStates$ = new WeakMap();
|
|
36
|
+
this._stack = [];
|
|
37
|
+
}
|
|
38
|
+
show(location) {
|
|
39
|
+
let host;
|
|
40
|
+
if (location) {
|
|
41
|
+
host = location.closest('.ax-loading-host');
|
|
42
|
+
}
|
|
43
|
+
const containerElement = (host || location);
|
|
44
|
+
const com = this.overlayService.show(AXLoadingComponent, {}, {
|
|
45
|
+
closeOnClickOutside: false,
|
|
46
|
+
containerElement,
|
|
47
|
+
hasBackdrop: true,
|
|
48
|
+
backdropClass: ['ax-loading-overlay'],
|
|
49
|
+
scroll: 'block'
|
|
50
|
+
});
|
|
51
|
+
com.instance.visible = true;
|
|
52
|
+
const id = new Date().getTime();
|
|
53
|
+
this._stack.push({ id, component: com });
|
|
54
|
+
return id;
|
|
55
|
+
}
|
|
56
|
+
hide(id) {
|
|
57
|
+
const f = this._stack.find(c => c.id === id);
|
|
58
|
+
if (f) {
|
|
59
|
+
f.component.dispose();
|
|
60
|
+
this._stack = this._stack.filter(c => c.id !== id);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
// Observable creation operator.
|
|
64
|
+
// LoaderId can be used when there are multiple loading indicators associated to a single context.
|
|
65
|
+
// Context can be any object, though in practice, components and services will be the most common contexts.
|
|
66
|
+
// loaderId is a non-mandatory parameter - when not specified, a default loaderId is used.
|
|
67
|
+
// Such a scenario is used when your context has contains only one loading indicator.
|
|
68
|
+
doLoading(source$, context, loaderId) {
|
|
69
|
+
this.startLoading(context, loaderId);
|
|
70
|
+
return source$.pipe(observeOn(asyncScheduler), finalize(() => this.endLoading(context, loaderId)));
|
|
71
|
+
}
|
|
72
|
+
// To be used in your html templates.
|
|
73
|
+
// Returns a boolean indicating whether a given loader is active in a given context.
|
|
74
|
+
// If loaderId is unspecified, the method will return a logical disjunction of all
|
|
75
|
+
// loader states in the context.
|
|
76
|
+
isLoading(context, loaderId) {
|
|
77
|
+
const loaderStates = this.loadingStates.get(context);
|
|
78
|
+
if (!loaderStates) {
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
if (loaderId !== undefined) {
|
|
83
|
+
return loaderStates.get(this.getLoaderId(loaderId)) ?? false;
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
return [...loaderStates.values()].filter(state => state).length > 0;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
// To be used in your html templates with async pipes.
|
|
91
|
+
// Returns an Observable of booleans indicating whether a given loader is active in a given context.
|
|
92
|
+
isLoading$(context, loaderId) {
|
|
93
|
+
const coalescedLoaderId = this.getLoaderId(loaderId);
|
|
94
|
+
if (!this.hasLoadingStates(context, coalescedLoaderId)) {
|
|
95
|
+
this.setLoadingState(context, false, loaderId);
|
|
96
|
+
}
|
|
97
|
+
return this.loadingStates$.get(context).get(coalescedLoaderId);
|
|
98
|
+
}
|
|
99
|
+
// The startLoading and endLoading methods are intended to be used when handling
|
|
100
|
+
// complex scenarios where a need for extended usage flexibility is desired.
|
|
101
|
+
startLoading(context, loaderId) {
|
|
102
|
+
this.setLoadingState(context, true, this.getLoaderId(loaderId));
|
|
103
|
+
}
|
|
104
|
+
endLoading(context, loaderId) {
|
|
105
|
+
this.setLoadingState(context, false, this.getLoaderId(loaderId));
|
|
106
|
+
}
|
|
107
|
+
// To be called by middleware code (HTTP interceptors/routing listeners, etc.).
|
|
108
|
+
clearLoadings() {
|
|
109
|
+
this.loadingStates = new WeakMap();
|
|
110
|
+
this.loadingStates$ = new WeakMap();
|
|
111
|
+
}
|
|
112
|
+
setLoadingState(context, state, loaderId) {
|
|
113
|
+
if (!this.hasLoadingStates(context, loaderId)) {
|
|
114
|
+
if (this.hasContextLoadingState(context)) {
|
|
115
|
+
this.loadingStates.get(context).set(loaderId, state);
|
|
116
|
+
this.loadingStates$.get(context).set(loaderId, new BehaviorSubject(state));
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
this.loadingStates.set(context, new Map([
|
|
120
|
+
[loaderId, state]
|
|
121
|
+
]));
|
|
122
|
+
this.loadingStates$.set(context, new Map([
|
|
123
|
+
[loaderId, new BehaviorSubject(state)]
|
|
124
|
+
]));
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
// @ts-ignore - loadingStates[context] is surely defined in this branch
|
|
129
|
+
this.loadingStates.get(context).set(loaderId, state);
|
|
130
|
+
this.loadingStates$.get(context).get(loaderId).next(state);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
hasLoadingStates(context, loaderId) {
|
|
134
|
+
return this.hasContextLoadingState(context) && this.hasLoaderLoadingState(context, loaderId);
|
|
135
|
+
}
|
|
136
|
+
hasContextLoadingState(context) {
|
|
137
|
+
return this.loadingStates.has(context) && this.loadingStates$.has(context);
|
|
138
|
+
}
|
|
139
|
+
hasLoaderLoadingState(context, loaderId) {
|
|
140
|
+
return this.loadingStates.get(context).has(loaderId) && this.loadingStates$.get(context).has(loaderId);
|
|
141
|
+
}
|
|
142
|
+
getLoaderId(loaderId) {
|
|
143
|
+
return loaderId ?? DEFAULT_LOADER_ID;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
AXLoadingService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingService, deps: [{ token: i0.NgZone }, { token: i1.AXOverlayService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
147
|
+
AXLoadingService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingService, providedIn: 'root' });
|
|
148
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXLoadingService, decorators: [{
|
|
149
|
+
type: Injectable,
|
|
150
|
+
args: [{
|
|
151
|
+
providedIn: 'root'
|
|
152
|
+
}]
|
|
153
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i1.AXOverlayService }]; } });
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loading.service.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/loading/loading.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\r\nimport { asyncScheduler, BehaviorSubject, Observable } from 'rxjs';\r\nimport { finalize, observeOn } from 'rxjs/operators';\r\nimport { AXOverlayService, AXOverlayViewRef } from '../base/overlay.service';\r\nimport { AXLoadingComponent } from './loading.component';\r\n\r\ntype LoadingContext = object;\r\ntype LoaderId = string | number; // expected enum values\r\nconst DEFAULT_LOADER_ID: LoaderId = '_DEFAULT';\r\n\r\n/**\r\n * Used for centrally setting/unsetting loading flags for components or services.\r\n * Should be connected to global HTTP interceptor which will unset\r\n * the loading flags in case an error happens using the clearLoadings() method.\r\n *\r\n * FAQ:\r\n * Q: How to change loading flag for a parent component?\r\n * A: Inject the parent component as a dependency to your constructor and\r\n *    call loadingService.setLoading(parentComponent, STATE).\r\n * \r\n * Q: How to change loading flag for a child component?\r\n * A: Use a @ViewChild with component selector and pass the\r\n *    reference of the child to setLoading method.\r\n *\r\n * Q: I need more loading indicators in my components. How to?\r\n * A: Assign a LoaderId to each indicator and then use them\r\n *    with calls to methods of this service.\r\n */\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class AXLoadingService {\r\n    // WeakMap will remove components from itself upon\r\n    // their garbage collection by JS runtime.\r\n    protected loadingStates = new WeakMap<LoadingContext, Map<LoaderId, boolean>>();\r\n    // Both loading state maps are kept in-sync such that\r\n    // they can be used by both sync and async methods.\r\n    protected loadingStates$ = new WeakMap<LoadingContext, Map<LoaderId, BehaviorSubject<boolean>>>();\r\n\r\n    constructor(protected zoneRef: NgZone, private overlayService: AXOverlayService) { }\r\n\r\n    private _stack: { id: number, component: AXOverlayViewRef }[] = [];\r\n\r\n    show(location?: Element): number {\r\n        let host: Element;\r\n        if (location) {\r\n            host = location.closest('.ax-loading-host');\r\n        }\r\n        const containerElement = (host || location) as HTMLDivElement;\r\n        const com = this.overlayService.show(AXLoadingComponent, {},\r\n            {\r\n                closeOnClickOutside: false,\r\n                containerElement,\r\n                hasBackdrop: true,\r\n                backdropClass: ['ax-loading-overlay'],\r\n                scroll: 'block'\r\n            });\r\n        com.instance.visible = true;\r\n        const id = new Date().getTime();\r\n        this._stack.push({ id, component: com });\r\n        return id;\r\n    }\r\n\r\n    hide(id): void {\r\n        const f = this._stack.find(c => c.id === id);\r\n        if (f) {\r\n            f.component.dispose();\r\n            this._stack = this._stack.filter(c => c.id !== id);\r\n        }\r\n    }\r\n\r\n\r\n    // Observable creation operator.\r\n    // LoaderId can be used when there are multiple loading indicators associated to a single context.\r\n    // Context can be any object, though in practice, components and services will be the most common contexts.\r\n    // loaderId is a non-mandatory parameter - when not specified, a default loaderId is used.\r\n    // Such a scenario is used when your context has contains only one loading indicator.\r\n    doLoading<V>(source$: Observable<V>, context: LoadingContext, loaderId?: LoaderId): Observable<V> {\r\n        this.startLoading(context, loaderId);\r\n\r\n        return source$.pipe(\r\n            observeOn(asyncScheduler),\r\n            finalize(() => this.endLoading(context, loaderId)),\r\n        );\r\n    }\r\n\r\n    // To be used in your html templates.\r\n    // Returns a boolean indicating whether a given loader is active in a given context.\r\n    // If loaderId is unspecified, the method will return a logical disjunction of all\r\n    // loader states in the context.\r\n    isLoading(context: LoadingContext, loaderId?: LoaderId): boolean {\r\n        const loaderStates = this.loadingStates.get(context);\r\n\r\n        if (!loaderStates) {\r\n            return false;\r\n        }\r\n        else {\r\n            if (loaderId !== undefined) {\r\n                return loaderStates.get(this.getLoaderId(loaderId)) ?? false;\r\n            }\r\n            else {\r\n                return [...loaderStates.values()].filter(state => state).length > 0;\r\n            }\r\n        }\r\n    }\r\n\r\n    // To be used in your html templates with async pipes.\r\n    // Returns an Observable of booleans indicating whether a given loader is active in a given context.\r\n    isLoading$(context: LoadingContext, loaderId?: LoaderId): Observable<boolean> {\r\n        const coalescedLoaderId = this.getLoaderId(loaderId);\r\n\r\n        if (!this.hasLoadingStates(context, coalescedLoaderId)) {\r\n            this.setLoadingState(context, false, loaderId);\r\n        }\r\n\r\n        return this.loadingStates$.get(context).get(coalescedLoaderId);\r\n    }\r\n\r\n    // The startLoading and endLoading methods are intended to be used when handling\r\n    // complex scenarios where a need for extended usage flexibility is desired.\r\n    startLoading(context: LoadingContext, loaderId?: LoaderId): void {\r\n        this.setLoadingState(context, true, this.getLoaderId(loaderId));\r\n    }\r\n\r\n    endLoading(context: LoadingContext, loaderId?: LoaderId): void {\r\n        this.setLoadingState(context, false, this.getLoaderId(loaderId));\r\n    }\r\n\r\n    // To be called by middleware code (HTTP interceptors/routing listeners, etc.).\r\n    clearLoadings(): void {\r\n        this.loadingStates = new WeakMap<LoadingContext, Map<LoaderId, boolean>>();\r\n        this.loadingStates$ = new WeakMap<LoadingContext, Map<LoaderId, BehaviorSubject<boolean>>>();\r\n    }\r\n\r\n    protected setLoadingState(context: LoadingContext, state: boolean, loaderId: LoaderId): void {\r\n        if (!this.hasLoadingStates(context, loaderId)) {\r\n            if (this.hasContextLoadingState(context)) {\r\n                this.loadingStates.get(context).set(loaderId, state);\r\n                this.loadingStates$.get(context).set(loaderId, new BehaviorSubject<boolean>(state));\r\n            }\r\n            else {\r\n                this.loadingStates.set(context, new Map<LoaderId, boolean>([\r\n                    [loaderId, state]\r\n                ]));\r\n                this.loadingStates$.set(context, new Map<LoaderId, BehaviorSubject<boolean>>([\r\n                    [loaderId, new BehaviorSubject<boolean>(state)]\r\n                ]));\r\n            }\r\n        }\r\n        else {\r\n            // @ts-ignore - loadingStates[context] is surely defined in this branch\r\n            this.loadingStates.get(context).set(loaderId, state);\r\n            this.loadingStates$.get(context).get(loaderId).next(state);\r\n        }\r\n    }\r\n\r\n    protected hasLoadingStates(context: LoadingContext, loaderId: LoaderId) {\r\n        return this.hasContextLoadingState(context) && this.hasLoaderLoadingState(context, loaderId);\r\n    }\r\n\r\n    protected hasContextLoadingState(context: LoadingContext) {\r\n        return this.loadingStates.has(context) && this.loadingStates$.has(context);\r\n    }\r\n\r\n    protected hasLoaderLoadingState(context: LoadingContext, loaderId: LoaderId) {\r\n        return this.loadingStates.get(context).has(loaderId) && this.loadingStates$.get(context).has(loaderId);\r\n    }\r\n\r\n    protected getLoaderId(loaderId?: LoaderId): LoaderId {\r\n        return loaderId ?? DEFAULT_LOADER_ID;\r\n    }\r\n}\r\n"]}
|
|
File without changes
|
|
@@ -217,13 +217,13 @@ export class AXNumberBoxComponent extends AXBaseTextBoxMixin {
|
|
|
217
217
|
this._maskService.thousandSeparator = this.separator;
|
|
218
218
|
this._maskService.allowNegativeNumbers = true;
|
|
219
219
|
const format = `separator.${this.scale}`;
|
|
220
|
-
return this._maskService.applyMask(value
|
|
220
|
+
return this._maskService.applyMask(value?.toString(), format);
|
|
221
221
|
}
|
|
222
222
|
else {
|
|
223
223
|
this._maskService.thousandSeparator = '';
|
|
224
224
|
this._maskService.allowNegativeNumbers = true;
|
|
225
225
|
const format = `separator.${this.scale}`;
|
|
226
|
-
return this._maskService.applyMask(value
|
|
226
|
+
return this._maskService.applyMask(value?.toString(), format);
|
|
227
227
|
}
|
|
228
228
|
}
|
|
229
229
|
_onValueChanged(oldValue, newValue) {
|
|
@@ -236,32 +236,24 @@ export class AXNumberBoxComponent extends AXBaseTextBoxMixin {
|
|
|
236
236
|
this._emitOnFocusEvent(e);
|
|
237
237
|
}
|
|
238
238
|
}
|
|
239
|
-
AXNumberBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
240
|
-
AXNumberBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "
|
|
241
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
239
|
+
AXNumberBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXNumberBoxComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.MaskApplierService }], target: i0.ɵɵFactoryTarget.Component });
|
|
240
|
+
AXNumberBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AXNumberBoxComponent, selector: "ax-number-box", inputs: { disabled: "disabled", readonly: "readonly", tabIndex: "tabIndex", size: "size", value: "value", placeholder: "placeholder", maxLength: "maxLength", allowNull: "allowNull", debounceTime: "debounceTime", name: "name", separator: "separator", thousandSeparator: "thousandSeparator", step: "step", scale: "scale", decimalStep: "decimalStep", showSpinButtons: "showSpinButtons", minValue: "minValue", maxValue: "maxValue", displayText: "displayText" }, outputs: { valueChange: "valueChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", displayTextChange: "displayTextChange" }, host: { properties: { "class": "this.__hostClass" }, classAttribute: "ax-number-box ax-editor-container" }, usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input class=\"ax-input\" type=\"text\" [attr.pattern]=\"'[\\d\\.]*'\" [attr.placeholder]=\"placeholder\" [attr.min]=\"minValue\"\r\n [attr.max]=\"maxValue\" [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\"\r\n [disabled]=\"disabled\" [readonly]=\"readonly\" [tabindex]=\"tabIndex\" [ngModel]=\"displayText\"\r\n (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_handleOnBlurEvent($event)\" (keydown)=\"_handleOnKeydownEvent($event)\"\r\n autocomplete=\"off\">\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\"\r\n *ngIf=\"value && allowNull && !(disabled || readonly)\">\r\n <i class=\"ax-icon-x icon\"></i>\r\n</ax-button>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>", components: [{ type: i2.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "tabIndex", "size", "text", "submitBehavior", "cancelBehavior", "color", "look", "toggleable", "selected"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange"] }], directives: [{ type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
241
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXNumberBoxComponent, decorators: [{
|
|
242
242
|
type: Component,
|
|
243
|
-
args: [{
|
|
244
|
-
selector: 'ax-number-box',
|
|
245
|
-
templateUrl: './number-box.component.html',
|
|
246
|
-
inputs: [
|
|
243
|
+
args: [{ selector: 'ax-number-box', inputs: [
|
|
247
244
|
'disabled',
|
|
248
245
|
'readonly',
|
|
249
246
|
'tabIndex',
|
|
250
247
|
'size',
|
|
251
248
|
'value',
|
|
252
249
|
...TEXTBOX_INPUTS,
|
|
253
|
-
],
|
|
254
|
-
outputs: [
|
|
250
|
+
], outputs: [
|
|
255
251
|
'valueChange',
|
|
256
252
|
'onValueChanged',
|
|
257
253
|
'onBlur',
|
|
258
254
|
'onFocus',
|
|
259
255
|
...TEXTBOX_OUTPUT,
|
|
260
|
-
],
|
|
261
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
262
|
-
encapsulation: ViewEncapsulation.None,
|
|
263
|
-
host: { class: 'ax-number-box ax-editor-container' },
|
|
264
|
-
}]
|
|
256
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class: 'ax-number-box ax-editor-container' }, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input class=\"ax-input\" type=\"text\" [attr.pattern]=\"'[\\d\\.]*'\" [attr.placeholder]=\"placeholder\" [attr.min]=\"minValue\"\r\n [attr.max]=\"maxValue\" [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\"\r\n [disabled]=\"disabled\" [readonly]=\"readonly\" [tabindex]=\"tabIndex\" [ngModel]=\"displayText\"\r\n (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_handleOnBlurEvent($event)\" (keydown)=\"_handleOnKeydownEvent($event)\"\r\n autocomplete=\"off\">\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\"\r\n *ngIf=\"value && allowNull && !(disabled || readonly)\">\r\n <i class=\"ax-icon-x icon\"></i>\r\n</ax-button>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>" }]
|
|
265
257
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.MaskApplierService }]; }, propDecorators: { __hostClass: [{
|
|
266
258
|
type: HostBinding,
|
|
267
259
|
args: ['class']
|
|
@@ -286,4 +278,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.6", ngImpor
|
|
|
286
278
|
}], displayText: [{
|
|
287
279
|
type: Input
|
|
288
280
|
}] } });
|
|
289
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-box.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/number-box/number-box.component.ts","../../../../../../projects/acorex/components/src/lib/number-box/number-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  HostBinding,\r\n} from '@angular/core';\r\nimport { MaskApplierService } from 'ngx-mask';\r\nimport { AXBaseTextBoxMixin } from '../base';\r\nimport {\r\n  TEXTBOX_INPUTS,\r\n  TEXTBOX_OUTPUT,\r\n} from '../base/mixin/textbox-mixin.class';\r\n\r\n/**\r\n * The NumberBox is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n  selector: 'ax-number-box',\r\n  templateUrl: './number-box.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'readonly',\r\n    'tabIndex',\r\n    'size',\r\n    'value',\r\n    ...TEXTBOX_INPUTS,\r\n  ],\r\n  outputs: [\r\n    'valueChange',\r\n    'onValueChanged',\r\n    'onBlur',\r\n    'onFocus',\r\n    ...TEXTBOX_OUTPUT,\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { class: 'ax-number-box ax-editor-container' },\r\n})\r\nexport class AXNumberBoxComponent extends AXBaseTextBoxMixin {\r\n\r\n  @HostBinding('class')\r\n  private get __hostClass(): string {\r\n    return `${this.cssClass} ax-${this.size}`;\r\n  }\r\n\r\n  /**\r\n  *  A character value that specifies the separator character.\r\n  */\r\n  @Input()\r\n  separator: string = ',';\r\n\r\n   /**\r\n  *  Specifies whether the Separator character will be displayed or not\r\n  */\r\n  @Input()\r\n  thousandSeparator: boolean = false;\r\n\r\n   /**\r\n  *  Specifies the value that is used to increment or decrement the **Integer** part of number\r\n  */\r\n  @Input()\r\n  step: number = 1;\r\n\r\n  /**\r\n  *  Specifies the number of decimals that the user can enter\r\n  */\r\n  @Input()\r\n  scale: number = 0;\r\n\r\n  /**\r\n  *  Specifies the value that is used to increment or decrement the **Deciaml** part of number\r\n  */\r\n  @Input()\r\n  decimalStep: number = 0.1;\r\n\r\n  /**\r\n  *  Specifies whether the Up and Down spin buttons will be rendered or not\r\n  */\r\n  @Input()\r\n  showSpinButtons: boolean = true;\r\n\r\n  private _minValue: number = Number.MIN_VALUE;\r\n\r\n  /**\r\n  *  Specifies the smallest value that is valid\r\n  */\r\n  @Input()\r\n  public get minValue(): number {\r\n    return this._minValue;\r\n  }\r\n  public set minValue(v: number) {\r\n    this._minValue = v ? Number(v) : Number.MIN_VALUE;\r\n  }\r\n\r\n  private _maxValue: number = Number.MAX_VALUE;\r\n\r\n  /**\r\n  *  Specifies the greatest value that is valid\r\n  */\r\n  @Input()\r\n  public get maxValue(): number {\r\n    return this._maxValue;\r\n  }\r\n  public set maxValue(v: number) {\r\n    this._maxValue = v ? Number(v) : Number.MAX_VALUE;\r\n  }\r\n\r\n  @Output()\r\n  public displayTextChange: EventEmitter<string> = new EventEmitter<string>();\r\n  private _displayText: string;\r\n\r\n  /**\r\n  *  The formatted string which is displaying in the numberbox\r\n  */\r\n  @Input()\r\n  public get displayText(): string {\r\n    return this._displayText;\r\n  }\r\n\r\n  public set displayText(v: string) {\r\n    this._displayText = v;\r\n    this.displayTextChange.emit(v);\r\n  }\r\n\r\n\r\n  /**\r\n  *  @ignore\r\n  */\r\n  constructor(\r\n    elementRef: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private _maskService: MaskApplierService\r\n  ) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n  _handleOnKeydownEvent(e: KeyboardEvent) {\r\n    const ignore = () => {\r\n      e.preventDefault();\r\n      e.stopPropagation();\r\n    };\r\n    const toNum = (val: string) => {\r\n      return Number(val.replace(/[^0-9.-]+/g, ''));\r\n    };\r\n    const nums: string[] = Array(10)\r\n      .fill(0)\r\n      .map((v, i) => i.toString());\r\n    const chars: string[] = [\r\n      '.',\r\n      '-',\r\n      'Backspace',\r\n      'ArrowDown',\r\n      'ArrowUp',\r\n      'ArrowRight',\r\n      'ArrowLeft',\r\n      'Tab',\r\n      'Enter',\r\n    ];\r\n    const input = e.target as HTMLInputElement;\r\n    const key = e.key;\r\n    const valStr = input.value;\r\n    const val = toNum(valStr);\r\n    const decimalPointIndex = valStr.indexOf('.');\r\n    const selectionStart = input.selectionStart;\r\n    const selectionEnd = input.selectionEnd;\r\n    //\r\n\r\n    //\r\n    if (![...nums, ...chars].includes(key)) {\r\n      ignore();\r\n    }\r\n    if (e.key === 'ArrowDown' || e.key === 'ArrowUp') {\r\n      const stepVal =\r\n        decimalPointIndex > -1\r\n          ? selectionStart >= decimalPointIndex\r\n            ? this.decimalStep\r\n            : this.step\r\n          : this.step;\r\n      if (e.key === 'ArrowDown') {\r\n        this.value = val - stepVal;\r\n      } else {\r\n        this.value = val + stepVal;\r\n      }\r\n      ignore();\r\n      input.setSelectionRange(selectionStart, selectionStart);\r\n    } else if (e.key == 'Backspace') {\r\n      const chr = valStr.substr(selectionStart - 1, 1);\r\n      if (!nums.includes(chr)) {\r\n        ignore();\r\n        input.setSelectionRange(selectionStart - 1, selectionStart - 1);\r\n      } else {\r\n        const newVal = toNum(\r\n          valStr.substr(0, selectionStart - 1) + valStr.substr(selectionEnd)\r\n        );\r\n        input.value = this._format(newVal);\r\n        this.value = newVal;\r\n        ignore();\r\n        if (newVal == 0) {\r\n          input.setSelectionRange(1, 1);\r\n        } else {\r\n          input.setSelectionRange(selectionStart - 1, selectionStart - 1);\r\n        }\r\n      }\r\n    } else if (e.key == '.') {\r\n      if (!this.scale) {\r\n        ignore();\r\n      } else if (decimalPointIndex > -1) {\r\n        input.setSelectionRange(decimalPointIndex + 1, decimalPointIndex + 1);\r\n        ignore();\r\n      } else {\r\n        if (input.selectionEnd != valStr.length) {\r\n          input.setSelectionRange(valStr.length, valStr.length);\r\n          ignore();\r\n        }\r\n      }\r\n    } else if (e.key == '-') {\r\n      const index = valStr.indexOf('-');\r\n      if (index > -1) {\r\n        ignore();\r\n      } else {\r\n        this.value = Math.abs(this.value) * -1;\r\n        input.setSelectionRange(index + 1, index + 1);\r\n        ignore();\r\n      }\r\n    } else if (nums.includes(key)) {\r\n      const newVal = toNum(\r\n        valStr.substr(0, selectionStart) + key + valStr.substr(selectionEnd)\r\n      );\r\n      if (newVal < this.minValue) {\r\n        //TODO : highlight correct number\r\n        //input.value = this._format(this.minValue);\r\n        //const diff = this.minValue - val;\r\n        //this.value = this.minValue;\r\n        //ignore();\r\n        // setTimeout(() => {\r\n        //     input.setSelectionRange(input.selectionStart + 1, this.minValue.toString().length);\r\n        // }, 50);\r\n      } else if (newVal > this.maxValue) {\r\n        input.value = this._format(this.maxValue);\r\n        this.value = this.maxValue;\r\n        ignore();\r\n      } else {\r\n        input.value = this._format(newVal);\r\n        this.value = newVal;\r\n        ignore();\r\n      }\r\n    }\r\n    super._emitOnKeydownEvent(e);\r\n  }\r\n\r\n  _onValueChanging(value: number) {\r\n    return this._fixValue(value);\r\n  }\r\n\r\n  _fixValue(value: number): number {\r\n    if (value == null || value == undefined) {\r\n      return this.allowNull ? null : this.minValue;\r\n    } else if (value > this.maxValue) {\r\n      return this.maxValue;\r\n    } else if (value < this.minValue) {\r\n      return this.minValue;\r\n    }\r\n    return parseFloat(value.toFixed(this.scale));\r\n  }\r\n\r\n  _format(value: number): string {\r\n    if (this.thousandSeparator) {\r\n      this._maskService.thousandSeparator = this.separator;\r\n      this._maskService.allowNegativeNumbers = true;\r\n      const format = `separator.${this.scale}`;\r\n      return this._maskService.applyMask(value?.toString(), format);\r\n    } else {\r\n      this._maskService.thousandSeparator = '';\r\n      this._maskService.allowNegativeNumbers = true;\r\n      const format = `separator.${this.scale}`;\r\n      return this._maskService.applyMask(value?.toString(), format);\r\n    }\r\n  }\r\n\r\n  _onValueChanged(oldValue: any, newValue: any): void {\r\n    this.displayText = this._format(newValue);\r\n  }\r\n\r\n  _handleOnBlurEvent(e: FocusEvent) {\r\n    const input = e.target as HTMLInputElement;\r\n    this.value = this._fixValue(this.value);\r\n    input.value = this._format(this.value);\r\n    this._emitOnFocusEvent(e);\r\n  }\r\n}\r\n","<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input class=\"ax-input\" type=\"text\" [attr.pattern]=\"'[\\d\\.]*'\" [attr.placeholder]=\"placeholder\" [attr.min]=\"minValue\"\r\n    [attr.max]=\"maxValue\" [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\"\r\n    [disabled]=\"disabled\" [readonly]=\"readonly\" [tabindex]=\"tabIndex\" [ngModel]=\"displayText\"\r\n    (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_handleOnBlurEvent($event)\" (keydown)=\"_handleOnKeydownEvent($event)\"\r\n    autocomplete=\"off\">\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\"\r\n    *ngIf=\"value && allowNull && !(disabled || readonly)\">\r\n    <i class=\"ax-icon-x icon\"></i>\r\n</ax-button>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>"]}
|
|
281
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-box.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/number-box/number-box.component.ts","../../../../../../projects/acorex/components/src/lib/number-box/number-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  HostBinding,\r\n} from '@angular/core';\r\nimport { MaskApplierService } from 'ngx-mask';\r\nimport { AXBaseTextBoxMixin } from '../base';\r\nimport {\r\n  TEXTBOX_INPUTS,\r\n  TEXTBOX_OUTPUT,\r\n} from '../base/mixin/textbox-mixin.class';\r\n\r\n/**\r\n * The NumberBox is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n  selector: 'ax-number-box',\r\n  templateUrl: './number-box.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'readonly',\r\n    'tabIndex',\r\n    'size',\r\n    'value',\r\n    ...TEXTBOX_INPUTS,\r\n  ],\r\n  outputs: [\r\n    'valueChange',\r\n    'onValueChanged',\r\n    'onBlur',\r\n    'onFocus',\r\n    ...TEXTBOX_OUTPUT,\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { class: 'ax-number-box ax-editor-container' },\r\n})\r\nexport class AXNumberBoxComponent extends AXBaseTextBoxMixin {\r\n\r\n  @HostBinding('class')\r\n  private get __hostClass(): string {\r\n    return `${this.cssClass} ax-${this.size}`;\r\n  }\r\n\r\n  /**\r\n  *  A character value that specifies the separator character.\r\n  */\r\n  @Input()\r\n  separator: string = ',';\r\n\r\n   /**\r\n  *  Specifies whether the Separator character will be displayed or not\r\n  */\r\n  @Input()\r\n  thousandSeparator: boolean = false;\r\n\r\n   /**\r\n  *  Specifies the value that is used to increment or decrement the **Integer** part of number\r\n  */\r\n  @Input()\r\n  step: number = 1;\r\n\r\n  /**\r\n  *  Specifies the number of decimals that the user can enter\r\n  */\r\n  @Input()\r\n  scale: number = 0;\r\n\r\n  /**\r\n  *  Specifies the value that is used to increment or decrement the **Deciaml** part of number\r\n  */\r\n  @Input()\r\n  decimalStep: number = 0.1;\r\n\r\n  /**\r\n  *  Specifies whether the Up and Down spin buttons will be rendered or not\r\n  */\r\n  @Input()\r\n  showSpinButtons: boolean = true;\r\n\r\n  private _minValue: number = Number.MIN_VALUE;\r\n\r\n  /**\r\n  *  Specifies the smallest value that is valid\r\n  */\r\n  @Input()\r\n  public get minValue(): number {\r\n    return this._minValue;\r\n  }\r\n  public set minValue(v: number) {\r\n    this._minValue = v ? Number(v) : Number.MIN_VALUE;\r\n  }\r\n\r\n  private _maxValue: number = Number.MAX_VALUE;\r\n\r\n  /**\r\n  *  Specifies the greatest value that is valid\r\n  */\r\n  @Input()\r\n  public get maxValue(): number {\r\n    return this._maxValue;\r\n  }\r\n  public set maxValue(v: number) {\r\n    this._maxValue = v ? Number(v) : Number.MAX_VALUE;\r\n  }\r\n\r\n  @Output()\r\n  public displayTextChange: EventEmitter<string> = new EventEmitter<string>();\r\n  private _displayText: string;\r\n\r\n  /**\r\n  *  The formatted string which is displaying in the numberbox\r\n  */\r\n  @Input()\r\n  public get displayText(): string {\r\n    return this._displayText;\r\n  }\r\n\r\n  public set displayText(v: string) {\r\n    this._displayText = v;\r\n    this.displayTextChange.emit(v);\r\n  }\r\n\r\n\r\n  /**\r\n  *  @ignore\r\n  */\r\n  constructor(\r\n    elementRef: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private _maskService: MaskApplierService\r\n  ) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n  _handleOnKeydownEvent(e: KeyboardEvent) {\r\n    const ignore = () => {\r\n      e.preventDefault();\r\n      e.stopPropagation();\r\n    };\r\n    const toNum = (val: string) => {\r\n      return Number(val.replace(/[^0-9.-]+/g, ''));\r\n    };\r\n    const nums: string[] = Array(10)\r\n      .fill(0)\r\n      .map((v, i) => i.toString());\r\n    const chars: string[] = [\r\n      '.',\r\n      '-',\r\n      'Backspace',\r\n      'ArrowDown',\r\n      'ArrowUp',\r\n      'ArrowRight',\r\n      'ArrowLeft',\r\n      'Tab',\r\n      'Enter',\r\n    ];\r\n    const input = e.target as HTMLInputElement;\r\n    const key = e.key;\r\n    const valStr = input.value;\r\n    const val = toNum(valStr);\r\n    const decimalPointIndex = valStr.indexOf('.');\r\n    const selectionStart = input.selectionStart;\r\n    const selectionEnd = input.selectionEnd;\r\n    //\r\n\r\n    //\r\n    if (![...nums, ...chars].includes(key)) {\r\n      ignore();\r\n    }\r\n    if (e.key === 'ArrowDown' || e.key === 'ArrowUp') {\r\n      const stepVal =\r\n        decimalPointIndex > -1\r\n          ? selectionStart >= decimalPointIndex\r\n            ? this.decimalStep\r\n            : this.step\r\n          : this.step;\r\n      if (e.key === 'ArrowDown') {\r\n        this.value = val - stepVal;\r\n      } else {\r\n        this.value = val + stepVal;\r\n      }\r\n      ignore();\r\n      input.setSelectionRange(selectionStart, selectionStart);\r\n    } else if (e.key == 'Backspace') {\r\n      const chr = valStr.substr(selectionStart - 1, 1);\r\n      if (!nums.includes(chr)) {\r\n        ignore();\r\n        input.setSelectionRange(selectionStart - 1, selectionStart - 1);\r\n      } else {\r\n        const newVal = toNum(\r\n          valStr.substr(0, selectionStart - 1) + valStr.substr(selectionEnd)\r\n        );\r\n        input.value = this._format(newVal);\r\n        this.value = newVal;\r\n        ignore();\r\n        if (newVal == 0) {\r\n          input.setSelectionRange(1, 1);\r\n        } else {\r\n          input.setSelectionRange(selectionStart - 1, selectionStart - 1);\r\n        }\r\n      }\r\n    } else if (e.key == '.') {\r\n      if (!this.scale) {\r\n        ignore();\r\n      } else if (decimalPointIndex > -1) {\r\n        input.setSelectionRange(decimalPointIndex + 1, decimalPointIndex + 1);\r\n        ignore();\r\n      } else {\r\n        if (input.selectionEnd != valStr.length) {\r\n          input.setSelectionRange(valStr.length, valStr.length);\r\n          ignore();\r\n        }\r\n      }\r\n    } else if (e.key == '-') {\r\n      const index = valStr.indexOf('-');\r\n      if (index > -1) {\r\n        ignore();\r\n      } else {\r\n        this.value = Math.abs(this.value) * -1;\r\n        input.setSelectionRange(index + 1, index + 1);\r\n        ignore();\r\n      }\r\n    } else if (nums.includes(key)) {\r\n      const newVal = toNum(\r\n        valStr.substr(0, selectionStart) + key + valStr.substr(selectionEnd)\r\n      );\r\n      if (newVal < this.minValue) {\r\n        //TODO : highlight correct number\r\n        //input.value = this._format(this.minValue);\r\n        //const diff = this.minValue - val;\r\n        //this.value = this.minValue;\r\n        //ignore();\r\n        // setTimeout(() => {\r\n        //     input.setSelectionRange(input.selectionStart + 1, this.minValue.toString().length);\r\n        // }, 50);\r\n      } else if (newVal > this.maxValue) {\r\n        input.value = this._format(this.maxValue);\r\n        this.value = this.maxValue;\r\n        ignore();\r\n      } else {\r\n        input.value = this._format(newVal);\r\n        this.value = newVal;\r\n        ignore();\r\n      }\r\n    }\r\n    super._emitOnKeydownEvent(e);\r\n  }\r\n\r\n  _onValueChanging(value: number) {\r\n    return this._fixValue(value);\r\n  }\r\n\r\n  _fixValue(value: number): number {\r\n    if (value == null || value == undefined) {\r\n      return this.allowNull ? null : this.minValue;\r\n    } else if (value > this.maxValue) {\r\n      return this.maxValue;\r\n    } else if (value < this.minValue) {\r\n      return this.minValue;\r\n    }\r\n    return parseFloat(value.toFixed(this.scale));\r\n  }\r\n\r\n  _format(value: number): string {\r\n    if (this.thousandSeparator) {\r\n      this._maskService.thousandSeparator = this.separator;\r\n      this._maskService.allowNegativeNumbers = true;\r\n      const format = `separator.${this.scale}`;\r\n      return this._maskService.applyMask(value?.toString(), format);\r\n    } else {\r\n      this._maskService.thousandSeparator = '';\r\n      this._maskService.allowNegativeNumbers = true;\r\n      const format = `separator.${this.scale}`;\r\n      return this._maskService.applyMask(value?.toString(), format);\r\n    }\r\n  }\r\n\r\n  _onValueChanged(oldValue: any, newValue: any): void {\r\n    this.displayText = this._format(newValue);\r\n  }\r\n\r\n  _handleOnBlurEvent(e: FocusEvent) {\r\n    const input = e.target as HTMLInputElement;\r\n    this.value = this._fixValue(this.value);\r\n    input.value = this._format(this.value);\r\n    this._emitOnFocusEvent(e);\r\n  }\r\n}\r\n","<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input class=\"ax-input\" type=\"text\" [attr.pattern]=\"'[\\d\\.]*'\" [attr.placeholder]=\"placeholder\" [attr.min]=\"minValue\"\r\n    [attr.max]=\"maxValue\" [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\"\r\n    [disabled]=\"disabled\" [readonly]=\"readonly\" [tabindex]=\"tabIndex\" [ngModel]=\"displayText\"\r\n    (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_handleOnBlurEvent($event)\" (keydown)=\"_handleOnKeydownEvent($event)\"\r\n    autocomplete=\"off\">\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\"\r\n    *ngIf=\"value && allowNull && !(disabled || readonly)\">\r\n    <i class=\"ax-icon-x icon\"></i>\r\n</ax-button>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>"]}
|
package/{esm2015/lib/number-box/number-box.module.js → esm2020/lib/number-box/number-box.module.mjs}
RENAMED
|
@@ -15,12 +15,12 @@ const MODULES = [
|
|
|
15
15
|
];
|
|
16
16
|
export class AXNumberBoxModule {
|
|
17
17
|
}
|
|
18
|
-
AXNumberBoxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
19
|
-
AXNumberBoxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "
|
|
18
|
+
AXNumberBoxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXNumberBoxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
19
|
+
AXNumberBoxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXNumberBoxModule, declarations: [AXNumberBoxComponent], imports: [CommonModule,
|
|
20
20
|
FormsModule,
|
|
21
21
|
AXButtonModule, i1.NgxMaskModule], exports: [AXNumberBoxComponent] });
|
|
22
|
-
AXNumberBoxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
23
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
22
|
+
AXNumberBoxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXNumberBoxModule, providers: [], imports: [[...MODULES]] });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AXNumberBoxModule, decorators: [{
|
|
24
24
|
type: NgModule,
|
|
25
25
|
args: [{
|
|
26
26
|
declarations: [...COMPONENT],
|