@energycap/components 0.41.1-ECAP-27592-angular-17.20241223-1652 → 0.41.1-ECAP-26841-date-input-features.20250106-0847
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/{esm2022 → esm2020}/energycap-components.mjs +4 -4
- package/esm2020/lib/components.module.mjs +423 -0
- package/esm2020/lib/controls/banner/banner.component.mjs +109 -0
- package/esm2020/lib/controls/button/button.component.mjs +106 -0
- package/esm2020/lib/controls/button/copy-button-base.directive.mjs +67 -0
- package/{esm2022 → esm2020}/lib/controls/button/copy-button.directive.mjs +28 -28
- package/esm2020/lib/controls/button/copy-table-button.directive.mjs +43 -0
- package/esm2020/lib/controls/calendar/calendar-item.component.mjs +91 -0
- package/esm2020/lib/controls/calendar/calendar.component.mjs +248 -0
- package/esm2020/lib/controls/calendar/calendar.types.mjs +2 -0
- package/esm2020/lib/controls/checkbox/checkbox.component.mjs +140 -0
- package/{esm2022 → esm2020}/lib/controls/collapsible-toggle/collapsible-toggle.component.mjs +38 -38
- package/esm2020/lib/controls/combobox/combobox.component.mjs +879 -0
- package/esm2020/lib/controls/date-input/date-input-selection-strategies/date-input-selection-strategy-base.mjs +57 -0
- package/esm2020/lib/controls/date-input/date-input-selection-strategies/day-selection-strategy.mjs +62 -0
- package/esm2020/lib/controls/date-input/date-input-selection-strategies/last-28-days-selection-strategy.mjs +100 -0
- package/esm2020/lib/controls/date-input/date-input-selection-strategies/last-7-days-selection-strategy.mjs +101 -0
- package/esm2020/lib/controls/date-input/date-input-selection-strategies/month-selection-strategy.mjs +76 -0
- package/esm2020/lib/controls/date-input/date-input-selection-strategies/quarter-selection-strategy.mjs +79 -0
- package/esm2020/lib/controls/date-input/date-input-selection-strategies/range-selection-strategy.mjs +210 -0
- package/esm2020/lib/controls/date-input/date-input-selection-strategies/year-selection-strategy.mjs +81 -0
- package/esm2020/lib/controls/date-input/date-input.component.mjs +462 -0
- package/esm2020/lib/controls/date-input/date-input.types.mjs +44 -0
- package/esm2020/lib/controls/dropdown/dropdown.component.mjs +243 -0
- package/esm2020/lib/controls/file-upload/file-upload.component.mjs +261 -0
- package/esm2020/lib/controls/form-control/form-control.component.mjs +98 -0
- package/esm2020/lib/controls/form-control-base.mjs +151 -0
- package/esm2020/lib/controls/form-control-label/form-control-label.component.mjs +136 -0
- package/esm2020/lib/controls/form-group/form-group.component.mjs +261 -0
- package/{esm2022 → esm2020}/lib/controls/help-popover/help-popover.component.mjs +31 -31
- package/esm2020/lib/controls/item-picker/item-picker.component.mjs +329 -0
- package/{esm2022 → esm2020}/lib/controls/link-button/link-button.component.mjs +11 -11
- package/esm2020/lib/controls/menu/menu.component.mjs +485 -0
- package/{esm2022 → esm2020}/lib/controls/navigation/link-item.mjs +1 -1
- package/esm2020/lib/controls/navigation/nav-group.mjs +39 -0
- package/esm2020/lib/controls/navigation/nav-item-active.directive.mjs +92 -0
- package/{esm2022 → esm2020}/lib/controls/navigation/nav-item.mjs +1 -1
- package/esm2020/lib/controls/numericbox/numericbox.component.mjs +372 -0
- package/esm2020/lib/controls/popover/popover.component.mjs +117 -0
- package/{esm2022 → esm2020}/lib/controls/radio-button/radio-button-option.mjs +2 -2
- package/esm2020/lib/controls/radio-button/radio-button.component.mjs +82 -0
- package/esm2020/lib/controls/select/select.component.mjs +88 -0
- package/esm2020/lib/controls/tabs/tabs.component.mjs +47 -0
- package/esm2020/lib/controls/textbox/textbox.component.mjs +155 -0
- package/esm2020/lib/core/cache.service.mjs +105 -0
- package/esm2020/lib/core/custom-validators.mjs +29 -0
- package/esm2020/lib/core/date-time-helper.mjs +228 -0
- package/esm2020/lib/core/error.service.mjs +61 -0
- package/esm2020/lib/core/router-helper.service.mjs +111 -0
- package/esm2020/lib/core/scroll.service.mjs +89 -0
- package/{esm2022 → esm2020}/lib/core/telemetry-tracker.service.mjs +16 -16
- package/{esm2022 → esm2020}/lib/core/telemetry.service.mjs +38 -38
- package/esm2020/lib/core/validation-message.service.mjs +185 -0
- package/{esm2022 → esm2020}/lib/core/validation-patterns.mjs +30 -30
- package/esm2020/lib/core/window.service.mjs +186 -0
- package/esm2020/lib/display/app-bar/app-bar.component.mjs +46 -0
- package/esm2020/lib/display/avatar/avatar.component.mjs +67 -0
- package/esm2020/lib/display/avatar/avatar.service.mjs +64 -0
- package/esm2020/lib/display/confirm/confirm.component.mjs +168 -0
- package/{esm2022 → esm2020}/lib/display/dialog/dialog-content.mjs +1 -1
- package/esm2020/lib/display/dialog/dialog-group/dialog-group.component.mjs +63 -0
- package/{esm2022 → esm2020}/lib/display/dialog/dialog-types.mjs +76 -76
- package/esm2020/lib/display/dialog/dialog.component.mjs +281 -0
- package/{esm2022 → esm2020}/lib/display/dialog/dialog.service.mjs +71 -71
- package/{esm2022 → esm2020}/lib/display/help/help-types.mjs +1 -1
- package/esm2020/lib/display/hierarchy/hierarchy-base.mjs +111 -0
- package/{esm2022 → esm2020}/lib/display/hierarchy/hierarchy-mocks.spec.mjs +53 -53
- package/esm2020/lib/display/hierarchy/hierarchy-tree/hierarchy-tree.component.mjs +61 -0
- package/esm2020/lib/display/item-display/item-display.component.mjs +81 -0
- package/esm2020/lib/display/json-display/json-display.component.mjs +47 -0
- package/esm2020/lib/display/resizable/resizable-base.mjs +120 -0
- package/{esm2022 → esm2020}/lib/display/resizable/resizable.component.mjs +52 -52
- package/{esm2022 → esm2020}/lib/display/spinner/spinner.component.mjs +12 -12
- package/esm2020/lib/display/splash/splash.component.mjs +42 -0
- package/{esm2022 → esm2020}/lib/display/splash/splash.service.mjs +35 -35
- package/{esm2022 → esm2020}/lib/display/table/resizable-column.component.mjs +20 -20
- package/esm2020/lib/display/table/resizable-table.directive.mjs +227 -0
- package/esm2020/lib/display/table/searchable-table.component.mjs +342 -0
- package/{esm2022 → esm2020}/lib/display/table/table-detail-row.component.mjs +19 -19
- package/esm2020/lib/display/table/table-locked-column.component.mjs +58 -0
- package/{esm2022 → esm2020}/lib/display/table/table-master-header-row.component.mjs +14 -14
- package/esm2020/lib/display/table/table-master-row.component.mjs +163 -0
- package/esm2020/lib/display/table/table-pagination.component.mjs +155 -0
- package/esm2020/lib/display/table/table-selectable-row.component.mjs +235 -0
- package/esm2020/lib/display/table/table.component.mjs +249 -0
- package/esm2020/lib/display/tags/tag.mjs +18 -0
- package/esm2020/lib/display/tags/tags.component.mjs +77 -0
- package/esm2020/lib/display/toast/toast/toast.component.mjs +77 -0
- package/{esm2022 → esm2020}/lib/display/toast/toast-types.mjs +7 -7
- package/{esm2022 → esm2020}/lib/display/toast/toast.service.mjs +35 -35
- package/esm2020/lib/display/toast/toaster/toaster.component.mjs +114 -0
- package/{esm2022 → esm2020}/lib/display/tooltip/tooltip.component.mjs +28 -28
- package/{esm2022 → esm2020}/lib/display/tooltip/tooltip.service.mjs +78 -78
- package/esm2020/lib/display/tooltip-directive/tooltip.directive.mjs +173 -0
- package/{esm2022 → esm2020}/lib/display/tour/tour-types.mjs +33 -33
- package/esm2020/lib/display/tour/tour.component.mjs +398 -0
- package/esm2020/lib/display/tour/tour.service.mjs +75 -0
- package/esm2020/lib/display/tree/tree.component.mjs +135 -0
- package/esm2020/lib/display/view-overlay/view-overlay.component.mjs +58 -0
- package/esm2020/lib/shared/directives/click-area-for/click-area-for.directive.mjs +32 -0
- package/esm2020/lib/shared/directives/if-viewport-width/if-viewport-width.directive.mjs +111 -0
- package/esm2020/lib/shared/directives/keyboard-nav-container/keyboard-nav-container.directive.mjs +100 -0
- package/esm2020/lib/shared/directives/popup/popup-container.directive.mjs +163 -0
- package/esm2020/lib/shared/display/pipes/date-display.pipe.mjs +50 -0
- package/esm2020/lib/shared/display/pipes/highlight-text.pipe.mjs +30 -0
- package/esm2020/lib/shared/display/pipes/relative-date.pipe.mjs +62 -0
- package/esm2020/lib/shared/display/pipes/row-count.pipe.mjs +48 -0
- package/esm2020/lib/shared/display/pipes/time-display.pipe.mjs +41 -0
- package/esm2020/lib/shared/display.mjs +6 -0
- package/esm2020/lib/shared/form-group.helper.mjs +67 -0
- package/esm2020/lib/shared/json-helper.mjs +19 -0
- package/esm2020/lib/shared/lodash-helper.mjs +51 -0
- package/esm2020/lib/shared/page/page-base/page-base.component.mjs +387 -0
- package/{esm2022 → esm2020}/lib/shared/page/page-statuses.mjs +22 -22
- package/{esm2022 → esm2020}/lib/shared/page/page-title/page-title.component.mjs +23 -23
- package/esm2020/lib/shared/page/page-view/page-view.component.mjs +147 -0
- package/{esm2022 → esm2020}/lib/shared/testing/copy-button-base-test-injector-factory.spec.mjs +16 -16
- package/{esm2022 → esm2020}/lib/shared/testing/hierarchy-base-test-injector-factory.spec.mjs +16 -16
- package/{esm2022 → esm2020}/lib/shared/testing/page-base-component-test-helper.spec.mjs +37 -37
- package/esm2020/lib/shared/testing/page-base-component-test-injector-factory.spec.mjs +98 -0
- package/{esm2022 → esm2020}/lib/shared/testing/public-mocks.spec.mjs +148 -148
- package/{esm2022 → esm2020}/lib/shared/testing/spy-factory.spec.mjs +39 -39
- package/{esm2022 → esm2020}/lib/shared/testing/translation-mocks.spec.mjs +56 -56
- package/{esm2022 → esm2020}/lib/shared/user-preference.service.mjs +17 -17
- package/esm2020/lib/shared/wizard/wizard-base/wizard-base.component.mjs +246 -0
- package/{esm2022 → esm2020}/lib/shared/wizard/wizard-buttons/wizard-buttons.component.mjs +68 -68
- package/{esm2022 → esm2020}/lib/shared/wizard/wizard-progress/wizard-progress.component.mjs +18 -18
- package/esm2020/public-api.mjs +117 -0
- package/fesm2015/energycap-components.mjs +13370 -0
- package/fesm2015/energycap-components.mjs.map +1 -0
- package/{fesm2022 → fesm2020}/energycap-components.mjs +12971 -11819
- package/fesm2020/energycap-components.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/components.module.d.ts +92 -91
- package/lib/controls/banner/banner.component.d.ts +50 -50
- package/lib/controls/button/button.component.d.ts +78 -78
- package/lib/controls/button/copy-button-base.directive.d.ts +20 -20
- package/lib/controls/button/copy-button.directive.d.ts +14 -14
- package/lib/controls/button/copy-table-button.directive.d.ts +19 -19
- package/lib/controls/calendar/calendar-item.component.d.ts +22 -17
- package/lib/controls/calendar/calendar.component.d.ts +52 -54
- package/lib/controls/calendar/calendar.types.d.ts +11 -7
- package/lib/controls/checkbox/checkbox.component.d.ts +65 -65
- package/lib/controls/collapsible-toggle/collapsible-toggle.component.d.ts +25 -25
- package/lib/controls/combobox/combobox.component.d.ts +418 -418
- package/lib/controls/date-input/date-input-selection-strategies/date-input-selection-strategy-base.d.ts +42 -0
- package/lib/controls/date-input/date-input-selection-strategies/day-selection-strategy.d.ts +21 -0
- package/lib/controls/date-input/date-input-selection-strategies/last-28-days-selection-strategy.d.ts +21 -0
- package/lib/controls/date-input/date-input-selection-strategies/last-7-days-selection-strategy.d.ts +21 -0
- package/lib/controls/date-input/date-input-selection-strategies/month-selection-strategy.d.ts +18 -0
- package/lib/controls/date-input/date-input-selection-strategies/quarter-selection-strategy.d.ts +18 -0
- package/lib/controls/date-input/date-input-selection-strategies/range-selection-strategy.d.ts +21 -0
- package/lib/controls/date-input/date-input-selection-strategies/year-selection-strategy.d.ts +20 -0
- package/lib/controls/date-input/date-input.component.d.ts +115 -80
- package/lib/controls/date-input/date-input.types.d.ts +62 -0
- package/lib/controls/dropdown/dropdown.component.d.ts +161 -161
- package/lib/controls/file-upload/file-upload.component.d.ts +124 -124
- package/lib/controls/form-control/form-control.component.d.ts +28 -30
- package/lib/controls/form-control-base.d.ts +110 -110
- package/lib/controls/form-control-label/form-control-label.component.d.ts +73 -73
- package/lib/controls/form-group/form-group.component.d.ts +105 -105
- package/lib/controls/help-popover/help-popover.component.d.ts +11 -11
- package/lib/controls/item-picker/item-picker.component.d.ts +164 -164
- package/lib/controls/link-button/link-button.component.d.ts +5 -5
- package/lib/controls/menu/menu.component.d.ts +255 -255
- package/lib/controls/navigation/link-item.d.ts +32 -32
- package/lib/controls/navigation/nav-group.d.ts +18 -18
- package/lib/controls/navigation/nav-item-active.directive.d.ts +42 -42
- package/lib/controls/navigation/nav-item.d.ts +31 -31
- package/lib/controls/numericbox/numericbox.component.d.ts +148 -148
- package/lib/controls/popover/popover.component.d.ts +51 -51
- package/lib/controls/radio-button/radio-button-option.d.ts +19 -19
- package/lib/controls/radio-button/radio-button.component.d.ts +53 -53
- package/lib/controls/select/select.component.d.ts +44 -44
- package/lib/controls/tabs/tabs.component.d.ts +30 -30
- package/lib/controls/textbox/textbox.component.d.ts +107 -107
- package/lib/core/cache.service.d.ts +33 -33
- package/lib/core/custom-validators.d.ts +20 -20
- package/lib/core/date-time-helper.d.ts +101 -101
- package/lib/core/error.service.d.ts +20 -20
- package/lib/core/router-helper.service.d.ts +48 -48
- package/lib/core/scroll.service.d.ts +36 -36
- package/lib/core/telemetry-tracker.service.d.ts +13 -13
- package/lib/core/telemetry.service.d.ts +31 -31
- package/lib/core/validation-message.service.d.ts +26 -26
- package/lib/core/validation-patterns.d.ts +22 -22
- package/lib/core/window.service.d.ts +116 -116
- package/lib/display/app-bar/app-bar.component.d.ts +20 -20
- package/lib/display/avatar/avatar.component.d.ts +35 -35
- package/lib/display/avatar/avatar.service.d.ts +24 -24
- package/lib/display/confirm/confirm.component.d.ts +123 -123
- package/lib/display/dialog/dialog-content.d.ts +19 -19
- package/lib/display/dialog/dialog-group/dialog-group.component.d.ts +32 -32
- package/lib/display/dialog/dialog-types.d.ts +130 -130
- package/lib/display/dialog/dialog.component.d.ts +120 -120
- package/lib/display/dialog/dialog.service.d.ts +48 -48
- package/lib/display/help/help-types.d.ts +33 -33
- package/lib/display/hierarchy/hierarchy-base.d.ts +97 -97
- package/lib/display/hierarchy/hierarchy-mocks.spec.d.ts +53 -53
- package/lib/display/hierarchy/hierarchy-tree/hierarchy-tree.component.d.ts +34 -34
- package/lib/display/item-display/item-display.component.d.ts +43 -43
- package/lib/display/json-display/json-display.component.d.ts +16 -16
- package/lib/display/resizable/resizable-base.d.ts +67 -67
- package/lib/display/resizable/resizable.component.d.ts +31 -31
- package/lib/display/spinner/spinner.component.d.ts +5 -5
- package/lib/display/splash/splash.component.d.ts +16 -16
- package/lib/display/splash/splash.service.d.ts +22 -22
- package/lib/display/table/resizable-column.component.d.ts +10 -10
- package/lib/display/table/resizable-table.directive.d.ts +93 -93
- package/lib/display/table/searchable-table.component.d.ts +206 -206
- package/lib/display/table/table-detail-row.component.d.ts +8 -8
- package/lib/display/table/table-locked-column.component.d.ts +20 -20
- package/lib/display/table/table-master-header-row.component.d.ts +9 -9
- package/lib/display/table/table-master-row.component.d.ts +113 -113
- package/lib/display/table/table-pagination.component.d.ts +91 -91
- package/lib/display/table/table-selectable-row.component.d.ts +102 -102
- package/lib/display/table/table.component.d.ts +121 -121
- package/lib/display/tags/tag.d.ts +18 -18
- package/lib/display/tags/tags.component.d.ts +48 -48
- package/lib/display/toast/toast/toast.component.d.ts +23 -23
- package/lib/display/toast/toast-types.d.ts +24 -24
- package/lib/display/toast/toast.service.d.ts +20 -20
- package/lib/display/toast/toaster/toaster.component.d.ts +35 -35
- package/lib/display/tooltip/tooltip.component.d.ts +70 -70
- package/lib/display/tooltip/tooltip.service.d.ts +16 -16
- package/lib/display/tooltip-directive/tooltip.directive.d.ts +44 -44
- package/lib/display/tour/tour-types.d.ts +70 -70
- package/lib/display/tour/tour.component.d.ts +147 -147
- package/lib/display/tour/tour.service.d.ts +38 -38
- package/lib/display/tree/tree.component.d.ts +75 -75
- package/lib/display/view-overlay/view-overlay.component.d.ts +38 -38
- package/lib/shared/directives/click-area-for/click-area-for.directive.d.ts +14 -14
- package/lib/shared/directives/if-viewport-width/if-viewport-width.directive.d.ts +60 -60
- package/lib/shared/directives/keyboard-nav-container/keyboard-nav-container.directive.d.ts +23 -0
- package/lib/shared/directives/popup/popup-container.directive.d.ts +101 -101
- package/lib/shared/display/pipes/date-display.pipe.d.ts +21 -21
- package/lib/shared/display/pipes/highlight-text.pipe.d.ts +9 -9
- package/lib/shared/display/pipes/relative-date.pipe.d.ts +36 -36
- package/lib/shared/display/pipes/row-count.pipe.d.ts +23 -23
- package/lib/shared/display/pipes/time-display.pipe.d.ts +18 -18
- package/lib/shared/display.d.ts +42 -42
- package/lib/shared/form-group.helper.d.ts +31 -31
- package/lib/shared/json-helper.d.ts +7 -7
- package/lib/shared/lodash-helper.d.ts +18 -18
- package/lib/shared/page/page-base/page-base.component.d.ts +259 -259
- package/lib/shared/page/page-statuses.d.ts +13 -13
- package/lib/shared/page/page-title/page-title.component.d.ts +9 -9
- package/lib/shared/page/page-view/page-view.component.d.ts +102 -102
- package/lib/shared/testing/copy-button-base-test-injector-factory.spec.d.ts +4 -4
- package/lib/shared/testing/hierarchy-base-test-injector-factory.spec.d.ts +4 -4
- package/lib/shared/testing/page-base-component-test-helper.spec.d.ts +30 -30
- package/lib/shared/testing/page-base-component-test-injector-factory.spec.d.ts +28 -28
- package/lib/shared/testing/public-mocks.spec.d.ts +90 -90
- package/lib/shared/testing/spy-factory.spec.d.ts +27 -27
- package/lib/shared/testing/translation-mocks.spec.d.ts +30 -30
- package/lib/shared/user-preference.service.d.ts +13 -13
- package/lib/shared/wizard/wizard-base/wizard-base.component.d.ts +134 -134
- package/lib/shared/wizard/wizard-buttons/wizard-buttons.component.d.ts +27 -27
- package/lib/shared/wizard/wizard-progress/wizard-progress.component.d.ts +10 -10
- package/package.json +18 -12
- package/public-api.d.ts +113 -111
- package/schematics/rxjs-7-upgrade/index.d.ts +3 -3
- package/schematics/rxjs-7-upgrade/index.js +67 -67
- package/schematics/rxjs-7-upgrade/index.js.map +1 -1
- package/schematics/rxjs-7-upgrade/schema.d.ts +4 -4
- package/schematics/rxjs-7-upgrade/schema.js +2 -2
- package/schematics/utilities/typescript.d.ts +7 -7
- package/schematics/utilities/typescript.js +41 -41
- package/schematics/utilities/workspace.d.ts +8 -8
- package/schematics/utilities/workspace.js +71 -71
- package/schematics/utilities/workspace.js.map +1 -1
- package/src/assets/locales/en_US.json +9 -1
- package/esm2022/lib/components.module.mjs +0 -418
- package/esm2022/lib/controls/banner/banner.component.mjs +0 -109
- package/esm2022/lib/controls/button/button.component.mjs +0 -106
- package/esm2022/lib/controls/button/copy-button-base.directive.mjs +0 -67
- package/esm2022/lib/controls/button/copy-table-button.directive.mjs +0 -43
- package/esm2022/lib/controls/calendar/calendar-item.component.mjs +0 -59
- package/esm2022/lib/controls/calendar/calendar.component.mjs +0 -200
- package/esm2022/lib/controls/calendar/calendar.types.mjs +0 -4
- package/esm2022/lib/controls/checkbox/checkbox.component.mjs +0 -140
- package/esm2022/lib/controls/combobox/combobox.component.mjs +0 -879
- package/esm2022/lib/controls/date-input/date-input.component.mjs +0 -256
- package/esm2022/lib/controls/dropdown/dropdown.component.mjs +0 -243
- package/esm2022/lib/controls/file-upload/file-upload.component.mjs +0 -261
- package/esm2022/lib/controls/form-control/form-control.component.mjs +0 -104
- package/esm2022/lib/controls/form-control-base.mjs +0 -151
- package/esm2022/lib/controls/form-control-label/form-control-label.component.mjs +0 -136
- package/esm2022/lib/controls/form-group/form-group.component.mjs +0 -261
- package/esm2022/lib/controls/item-picker/item-picker.component.mjs +0 -329
- package/esm2022/lib/controls/menu/menu.component.mjs +0 -485
- package/esm2022/lib/controls/navigation/nav-group.mjs +0 -39
- package/esm2022/lib/controls/navigation/nav-item-active.directive.mjs +0 -92
- package/esm2022/lib/controls/numericbox/numericbox.component.mjs +0 -372
- package/esm2022/lib/controls/popover/popover.component.mjs +0 -117
- package/esm2022/lib/controls/radio-button/radio-button.component.mjs +0 -82
- package/esm2022/lib/controls/select/select.component.mjs +0 -88
- package/esm2022/lib/controls/tabs/tabs.component.mjs +0 -47
- package/esm2022/lib/controls/textbox/textbox.component.mjs +0 -155
- package/esm2022/lib/core/cache.service.mjs +0 -105
- package/esm2022/lib/core/custom-validators.mjs +0 -29
- package/esm2022/lib/core/date-time-helper.mjs +0 -220
- package/esm2022/lib/core/error.service.mjs +0 -61
- package/esm2022/lib/core/router-helper.service.mjs +0 -111
- package/esm2022/lib/core/scroll.service.mjs +0 -89
- package/esm2022/lib/core/validation-message.service.mjs +0 -185
- package/esm2022/lib/core/window.service.mjs +0 -186
- package/esm2022/lib/display/app-bar/app-bar.component.mjs +0 -46
- package/esm2022/lib/display/avatar/avatar.component.mjs +0 -67
- package/esm2022/lib/display/avatar/avatar.service.mjs +0 -64
- package/esm2022/lib/display/confirm/confirm.component.mjs +0 -168
- package/esm2022/lib/display/dialog/dialog-group/dialog-group.component.mjs +0 -63
- package/esm2022/lib/display/dialog/dialog.component.mjs +0 -281
- package/esm2022/lib/display/hierarchy/hierarchy-base.mjs +0 -111
- package/esm2022/lib/display/hierarchy/hierarchy-tree/hierarchy-tree.component.mjs +0 -61
- package/esm2022/lib/display/item-display/item-display.component.mjs +0 -81
- package/esm2022/lib/display/json-display/json-display.component.mjs +0 -47
- package/esm2022/lib/display/resizable/resizable-base.mjs +0 -120
- package/esm2022/lib/display/splash/splash.component.mjs +0 -42
- package/esm2022/lib/display/table/resizable-table.directive.mjs +0 -227
- package/esm2022/lib/display/table/searchable-table.component.mjs +0 -342
- package/esm2022/lib/display/table/table-locked-column.component.mjs +0 -58
- package/esm2022/lib/display/table/table-master-row.component.mjs +0 -163
- package/esm2022/lib/display/table/table-pagination.component.mjs +0 -155
- package/esm2022/lib/display/table/table-selectable-row.component.mjs +0 -235
- package/esm2022/lib/display/table/table.component.mjs +0 -249
- package/esm2022/lib/display/tags/tag.mjs +0 -18
- package/esm2022/lib/display/tags/tags.component.mjs +0 -77
- package/esm2022/lib/display/toast/toast/toast.component.mjs +0 -77
- package/esm2022/lib/display/toast/toaster/toaster.component.mjs +0 -114
- package/esm2022/lib/display/tooltip-directive/tooltip.directive.mjs +0 -173
- package/esm2022/lib/display/tour/tour.component.mjs +0 -398
- package/esm2022/lib/display/tour/tour.service.mjs +0 -75
- package/esm2022/lib/display/tree/tree.component.mjs +0 -135
- package/esm2022/lib/display/view-overlay/view-overlay.component.mjs +0 -58
- package/esm2022/lib/shared/directives/click-area-for/click-area-for.directive.mjs +0 -32
- package/esm2022/lib/shared/directives/if-viewport-width/if-viewport-width.directive.mjs +0 -111
- package/esm2022/lib/shared/directives/popup/popup-container.directive.mjs +0 -166
- package/esm2022/lib/shared/display/pipes/date-display.pipe.mjs +0 -50
- package/esm2022/lib/shared/display/pipes/highlight-text.pipe.mjs +0 -30
- package/esm2022/lib/shared/display/pipes/relative-date.pipe.mjs +0 -62
- package/esm2022/lib/shared/display/pipes/row-count.pipe.mjs +0 -48
- package/esm2022/lib/shared/display/pipes/time-display.pipe.mjs +0 -41
- package/esm2022/lib/shared/display.mjs +0 -6
- package/esm2022/lib/shared/form-group.helper.mjs +0 -67
- package/esm2022/lib/shared/json-helper.mjs +0 -19
- package/esm2022/lib/shared/lodash-helper.mjs +0 -52
- package/esm2022/lib/shared/page/page-base/page-base.component.mjs +0 -387
- package/esm2022/lib/shared/page/page-view/page-view.component.mjs +0 -147
- package/esm2022/lib/shared/testing/page-base-component-test-injector-factory.spec.mjs +0 -98
- package/esm2022/lib/shared/wizard/wizard-base/wizard-base.component.mjs +0 -246
- package/esm2022/public-api.mjs +0 -115
- package/fesm2022/energycap-components.mjs.map +0 -1
@@ -0,0 +1,372 @@
|
|
1
|
+
import { Component, ElementRef, Input, ViewChild } from '@angular/core';
|
2
|
+
import { UntypedFormControl, Validators } from "@angular/forms";
|
3
|
+
import { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';
|
4
|
+
import { getDecimalPattern, integerPattern } from '../../core/validation-patterns';
|
5
|
+
import { FormControlBase } from "../form-control-base";
|
6
|
+
import { TextboxComponent } from '../textbox/textbox.component';
|
7
|
+
import * as i0 from "@angular/core";
|
8
|
+
import * as i1 from "../../core/validation-message.service";
|
9
|
+
import * as i2 from "../../shared/form-group.helper";
|
10
|
+
import * as i3 from "@angular/common";
|
11
|
+
import * as i4 from "../textbox/textbox.component";
|
12
|
+
import * as i5 from "../help-popover/help-popover.component";
|
13
|
+
import * as i6 from "@ngx-translate/core";
|
14
|
+
/**
|
15
|
+
* Custom validator to check that min/max and pattern validation is met on the numericbox
|
16
|
+
* component
|
17
|
+
*/
|
18
|
+
export const numericboxValidation = (min, max, decimals, maxPrecisionDigits) => {
|
19
|
+
return (control) => {
|
20
|
+
let hasError = false;
|
21
|
+
// If the control is empty we won't attempt to validate, if there is a required
|
22
|
+
// validator we will never get here until there is a value
|
23
|
+
if (control.value && control.value !== "") {
|
24
|
+
let numericPattern;
|
25
|
+
if (decimals && decimals > 0) {
|
26
|
+
numericPattern = getDecimalPattern(decimals);
|
27
|
+
}
|
28
|
+
else if (maxPrecisionDigits) {
|
29
|
+
// Still need to check for a valid number formatting when in max precision mode
|
30
|
+
numericPattern = getDecimalPattern(maxPrecisionDigits);
|
31
|
+
}
|
32
|
+
else {
|
33
|
+
// Allow an optional negative sign and any number of digits 0-9
|
34
|
+
numericPattern = integerPattern;
|
35
|
+
}
|
36
|
+
if (!numericPattern.test(control.value)) {
|
37
|
+
hasError = true;
|
38
|
+
}
|
39
|
+
else if (maxPrecisionDigits) {
|
40
|
+
// Converting to a number then back to string removes trailing zeros, and the regex replace removes
|
41
|
+
// any negative signs, leading zeros or decimal points from the number.
|
42
|
+
const val = Number(control.value).toString().replace(/^-?/, '').replace(/(^0\.)|(\.)/, '');
|
43
|
+
hasError = val.length > maxPrecisionDigits;
|
44
|
+
}
|
45
|
+
// We now know we have a valid number, so we can cast these to numbers
|
46
|
+
// for proper range validation
|
47
|
+
if (min !== undefined && Number(control.value) < min) {
|
48
|
+
hasError = true;
|
49
|
+
}
|
50
|
+
if (max !== undefined && Number(control.value) > max) {
|
51
|
+
hasError = true;
|
52
|
+
}
|
53
|
+
}
|
54
|
+
if (hasError) {
|
55
|
+
return {
|
56
|
+
numericbox: {
|
57
|
+
valid: false,
|
58
|
+
min: min,
|
59
|
+
max: max,
|
60
|
+
decimals: decimals,
|
61
|
+
maxPrecisionDigits: maxPrecisionDigits
|
62
|
+
}
|
63
|
+
};
|
64
|
+
}
|
65
|
+
else {
|
66
|
+
return null;
|
67
|
+
}
|
68
|
+
};
|
69
|
+
};
|
70
|
+
export class NumericboxComponent extends FormControlBase {
|
71
|
+
constructor(validationMessageService, formGroupHelper, renderer) {
|
72
|
+
super(validationMessageService, formGroupHelper);
|
73
|
+
this.validationMessageService = validationMessageService;
|
74
|
+
this.formGroupHelper = formGroupHelper;
|
75
|
+
this.renderer = renderer;
|
76
|
+
/**
|
77
|
+
* Show trailing zeros after the decimal point.
|
78
|
+
* Do not use with maxPrecisionDigits.
|
79
|
+
*/
|
80
|
+
this.showPrecision = false;
|
81
|
+
/**
|
82
|
+
* If set to true this will update the form model after a debounce as the user
|
83
|
+
* interacts with the component
|
84
|
+
*/
|
85
|
+
this.autoUpdateFormModel = false;
|
86
|
+
/** Flag to tell the page we finally computed a greater than zero
|
87
|
+
* width for units (if applicable)
|
88
|
+
*/
|
89
|
+
this.unitsWidthCalculated = false;
|
90
|
+
/** Flag used to filter the form models value changes subscription
|
91
|
+
* to prevent the textbox model from being formatted as the form model is updated
|
92
|
+
* programmatically when the textbox model updates
|
93
|
+
*/
|
94
|
+
this.autoUpdatingFormModel = false;
|
95
|
+
}
|
96
|
+
/**
|
97
|
+
* Angular AfterViewInit life-cycle hook
|
98
|
+
* Subscribe to textbox model value changes if the hosting
|
99
|
+
* page has opted in for this component
|
100
|
+
*/
|
101
|
+
ngAfterViewInit() {
|
102
|
+
if (this.autoUpdateFormModel) {
|
103
|
+
this.textboxFormModel.valueChanges
|
104
|
+
.pipe(debounceTime(300), distinctUntilChanged(), takeUntil(this.componentDestroyed)).subscribe(() => {
|
105
|
+
this.updateFormModelValue();
|
106
|
+
});
|
107
|
+
}
|
108
|
+
}
|
109
|
+
/**
|
110
|
+
* Angular onChanges life-cycle hook
|
111
|
+
* @see {@link https://angular.io/guide/lifecycle-hooks | Life-cycle hooks}
|
112
|
+
*/
|
113
|
+
ngOnChanges(changes) {
|
114
|
+
// If either units change after we've calculated,
|
115
|
+
// reset the flag so we can react and redraw
|
116
|
+
if (changes.rightUnits || changes.leftUnits) {
|
117
|
+
this.unitsWidthCalculated = false;
|
118
|
+
}
|
119
|
+
super.ngOnChanges(changes);
|
120
|
+
}
|
121
|
+
/**
|
122
|
+
* Angular onInit lifecycle hook
|
123
|
+
* If units is defined, set the position and listen for status changes so we
|
124
|
+
* can update the positioning of the units element
|
125
|
+
*/
|
126
|
+
ngOnInit() {
|
127
|
+
super.ngOnInit();
|
128
|
+
// Initialize the textbox form model with the value of the form model and synchronize
|
129
|
+
// disabled state
|
130
|
+
this.textboxFormModel = new UntypedFormControl({ value: this.formModel.value, disabled: this.formModel.disabled });
|
131
|
+
// Update the form model's errors when the textbox form model status changes
|
132
|
+
this.textboxFormModel.statusChanges.pipe(takeUntil(this.componentDestroyed)).subscribe(() => {
|
133
|
+
if (this.formModel.enabled) {
|
134
|
+
this.formModel.setErrors(this.textboxFormModel.errors);
|
135
|
+
}
|
136
|
+
});
|
137
|
+
// Synchronize disabled state between form model and internal textbox form model
|
138
|
+
this.formModel.statusChanges.pipe(takeUntil(this.componentDestroyed)).subscribe(() => {
|
139
|
+
if (this.formModel.disabled) {
|
140
|
+
this.textboxFormModel.disable();
|
141
|
+
}
|
142
|
+
else {
|
143
|
+
if (this.textboxFormModel.disabled) {
|
144
|
+
this.textboxFormModel.enable();
|
145
|
+
}
|
146
|
+
}
|
147
|
+
});
|
148
|
+
// Set textbox validators
|
149
|
+
this.textboxFormModel.setValidators(this.getValidators());
|
150
|
+
// Now that the textbox is set up we will set it's value to whatever the
|
151
|
+
// form model had when we initialized
|
152
|
+
this.textboxFormModel.setValue(this.formatDisplayNumber(this.formModel.value));
|
153
|
+
// If the form model's value changes programmatically we need to update the
|
154
|
+
// textbox form model
|
155
|
+
this.formModel.valueChanges.pipe(
|
156
|
+
// We need to filter out when we are updating it programmatically if the
|
157
|
+
// hosting page has opted into the auto updating input
|
158
|
+
filter(() => !this.autoUpdatingFormModel), takeUntil(this.componentDestroyed)).subscribe(value => {
|
159
|
+
this.textboxFormModel.setValue(this.formatDisplayNumber(value));
|
160
|
+
});
|
161
|
+
// If the textbox status changes we need to update the left units position because
|
162
|
+
// we want to make room for the invalid icon
|
163
|
+
if (this.leftUnits) {
|
164
|
+
this.textboxFormModel.statusChanges.pipe(takeUntil(this.componentDestroyed)).subscribe(() => {
|
165
|
+
this.positionLeftUnits();
|
166
|
+
});
|
167
|
+
}
|
168
|
+
}
|
169
|
+
/**
|
170
|
+
* Angular afterViewChecked lifecycle hook
|
171
|
+
* Show the units element if units is defined. Runs after every ngOnChanges
|
172
|
+
*/
|
173
|
+
ngAfterViewChecked() {
|
174
|
+
if ((this.leftUnits || this.rightUnits) && !this.unitsWidthCalculated) {
|
175
|
+
this.showUnits();
|
176
|
+
}
|
177
|
+
}
|
178
|
+
/**
|
179
|
+
* Function that builds and returns a ValidatorFn array to set on the form control
|
180
|
+
*/
|
181
|
+
getValidators() {
|
182
|
+
let validators = [];
|
183
|
+
if (this.required) {
|
184
|
+
validators.push(Validators.required);
|
185
|
+
}
|
186
|
+
validators.push(numericboxValidation(this.min, this.max, this.decimals, this.maxPrecisionDigits));
|
187
|
+
return validators;
|
188
|
+
}
|
189
|
+
/**
|
190
|
+
* Focus out event handler for the Textbox component
|
191
|
+
*/
|
192
|
+
onFocusOut() {
|
193
|
+
this.updateFormModelValue(true);
|
194
|
+
}
|
195
|
+
/**
|
196
|
+
* Function to set focus on an input programatically after the page
|
197
|
+
* had been rendered. The highlight text flag will select the text
|
198
|
+
* within the input if passed in and true
|
199
|
+
*/
|
200
|
+
setFocus(highlightText) {
|
201
|
+
this.textboxInput.setFocus(highlightText);
|
202
|
+
}
|
203
|
+
/**
|
204
|
+
* When the textbox model updates we need to add some display formatting for
|
205
|
+
* display in the textbox and cast the textbox model to a number. Avoid updating
|
206
|
+
* the form model when the value doesn't change because listeners will fire for no reason
|
207
|
+
*/
|
208
|
+
updateFormModelValue(isFocusOut) {
|
209
|
+
if (this.autoUpdateFormModel) {
|
210
|
+
// Make it so value changes on the form model do not get triggered
|
211
|
+
// as we change it programmatically. We do not want the textbox
|
212
|
+
// model to be updated while the user is in the input
|
213
|
+
this.autoUpdatingFormModel = true;
|
214
|
+
}
|
215
|
+
try {
|
216
|
+
if (this.textboxFormModel.valid || this.textboxFormModel.value === "") {
|
217
|
+
// Start out with null for the number, if the textbox value is not a number
|
218
|
+
// we will clear it out on focus out
|
219
|
+
let number = null;
|
220
|
+
// Make sure the textbox model is a number before trying to update the
|
221
|
+
// form model value with it
|
222
|
+
if (this.textboxFormModel.value && !isNaN(this.textboxFormModel.value)) {
|
223
|
+
// Our value is a legit number, on focus out we will format it if needed
|
224
|
+
number = Number(this.textboxFormModel.value);
|
225
|
+
// Checking if the value has actually changed, if not don't set the
|
226
|
+
// value to avoid extra listener calls
|
227
|
+
if (this.formModel.value !== number) {
|
228
|
+
this.formModel.setValue(number);
|
229
|
+
}
|
230
|
+
// The textbox model is not a number, check to see if our form model has a value
|
231
|
+
// and if so clear it out
|
232
|
+
}
|
233
|
+
else if (this.formModel.value !== null) {
|
234
|
+
this.formModel.setValue(null);
|
235
|
+
}
|
236
|
+
// We only will update the textbox form model with formatting if needed
|
237
|
+
// on Focus out. This works well for the user whether the auto update
|
238
|
+
// is opted in or not
|
239
|
+
if (isFocusOut) {
|
240
|
+
this.textboxFormModel.setValue(this.formatDisplayNumber(number));
|
241
|
+
}
|
242
|
+
}
|
243
|
+
this.formModel.markAsTouched();
|
244
|
+
}
|
245
|
+
catch (error) {
|
246
|
+
// Nothing to display, just ensuring we reset our flag that filters
|
247
|
+
// the form model value changes
|
248
|
+
}
|
249
|
+
finally {
|
250
|
+
this.autoUpdatingFormModel = false;
|
251
|
+
}
|
252
|
+
}
|
253
|
+
/**
|
254
|
+
* Convert a number value to the formmated display string. If there is no value
|
255
|
+
* return null
|
256
|
+
*/
|
257
|
+
formatDisplayNumber(value) {
|
258
|
+
if (value || value === 0) {
|
259
|
+
// Guard against calling toFixed if the value isn't a number. This is possible
|
260
|
+
// if patching a value from outside of the component as you don't have
|
261
|
+
// type checking there
|
262
|
+
if (this.showPrecision && this.decimals && !isNaN(value)) {
|
263
|
+
return value.toFixed(this.decimals);
|
264
|
+
}
|
265
|
+
else {
|
266
|
+
return value.toString();
|
267
|
+
}
|
268
|
+
}
|
269
|
+
else {
|
270
|
+
return null;
|
271
|
+
}
|
272
|
+
}
|
273
|
+
/**
|
274
|
+
* Position the units element and set the padding in the textbox input based
|
275
|
+
* on the width of the units element
|
276
|
+
*/
|
277
|
+
positionRightUnits() {
|
278
|
+
let unitsEl = this.textboxEl.nativeElement.querySelector('.units-right');
|
279
|
+
let inputEl = this.textboxEl.nativeElement.querySelector('input');
|
280
|
+
if (unitsEl && inputEl) {
|
281
|
+
let unitsWidth = unitsEl.offsetWidth;
|
282
|
+
if (unitsWidth > 0) {
|
283
|
+
this.unitsWidthCalculated = true;
|
284
|
+
}
|
285
|
+
let padding = unitsWidth;
|
286
|
+
this.renderer.setStyle(inputEl, 'padding-right', padding + 'px');
|
287
|
+
}
|
288
|
+
}
|
289
|
+
positionLeftUnits() {
|
290
|
+
let unitsEl = this.textboxEl.nativeElement.querySelector('.units-left');
|
291
|
+
let inputEl = this.textboxEl.nativeElement.querySelector('input');
|
292
|
+
if (unitsEl && inputEl) {
|
293
|
+
let unitsWidth = unitsEl.offsetWidth;
|
294
|
+
if (unitsWidth > 0) {
|
295
|
+
this.unitsWidthCalculated = true;
|
296
|
+
}
|
297
|
+
let padding = unitsWidth;
|
298
|
+
let leftPosition = getComputedStyle(unitsEl).left;
|
299
|
+
if (leftPosition) {
|
300
|
+
padding += parseInt(leftPosition.replace('px', ''), 0);
|
301
|
+
}
|
302
|
+
this.renderer.setStyle(inputEl, 'padding-left', padding + 'px');
|
303
|
+
}
|
304
|
+
}
|
305
|
+
/**
|
306
|
+
* Create and append the units element to the textbox element
|
307
|
+
*/
|
308
|
+
showUnits() {
|
309
|
+
let inputWrapper = this.textboxEl.nativeElement.querySelector('.input-wrapper');
|
310
|
+
if (inputWrapper) {
|
311
|
+
if (this.leftUnits) {
|
312
|
+
let unitsEl = this.textboxEl.nativeElement.querySelector('.units-left');
|
313
|
+
if (unitsEl) {
|
314
|
+
this.renderer.setProperty(unitsEl, 'innerHTML', this.leftUnits);
|
315
|
+
}
|
316
|
+
else {
|
317
|
+
this.renderer.appendChild(inputWrapper, this.makeUnitElement('left', this.leftUnits));
|
318
|
+
}
|
319
|
+
this.positionLeftUnits();
|
320
|
+
}
|
321
|
+
if (this.rightUnits) {
|
322
|
+
let unitsEl = this.textboxEl.nativeElement.querySelector('.units-right');
|
323
|
+
if (unitsEl) {
|
324
|
+
this.renderer.setProperty(unitsEl, 'innerHTML', this.rightUnits);
|
325
|
+
}
|
326
|
+
else {
|
327
|
+
this.renderer.appendChild(inputWrapper, this.makeUnitElement('right', this.rightUnits));
|
328
|
+
}
|
329
|
+
this.positionRightUnits();
|
330
|
+
}
|
331
|
+
}
|
332
|
+
}
|
333
|
+
makeUnitElement(side, text) {
|
334
|
+
let unitsEl = this.renderer.createElement('span');
|
335
|
+
this.renderer.setAttribute(unitsEl, 'class', `units units-${side}`);
|
336
|
+
this.renderer.setAttribute(unitsEl, 'id', `${this.id}_units`);
|
337
|
+
this.renderer.setAttribute(unitsEl, 'style', 'pointer-events: none');
|
338
|
+
this.renderer.setProperty(unitsEl, 'innerHTML', text);
|
339
|
+
return unitsEl;
|
340
|
+
}
|
341
|
+
}
|
342
|
+
NumericboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NumericboxComponent, deps: [{ token: i1.ValidationMessageService }, { token: i2.FormGroupHelper }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
|
343
|
+
NumericboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NumericboxComponent, selector: "ec-numericbox", inputs: { placeholder: "placeholder", decimals: "decimals", showPrecision: "showPrecision", maxPrecisionDigits: "maxPrecisionDigits", max: "max", min: "min", leftUnits: "leftUnits", rightUnits: "rightUnits", autoUpdateFormModel: "autoUpdateFormModel" }, viewQueries: [{ propertyName: "textboxEl", first: true, predicate: TextboxComponent, descendants: true, read: ElementRef, static: true }, { propertyName: "textboxInput", first: true, predicate: ["textbox"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"control control-label-{{labelPosition}}\"\r\n [class.invalid]=\"formModel?.invalid && (formModel?.touched)\">\r\n\r\n <label *ngIf=\"label\">\r\n <span>{{label | translate}}</span>\r\n <span *ngIf=\"validationErrors.length && formModel?.touched && formModel?.invalid\"> {{validationErrors | translate}}</span>\r\n <ec-help-popover id=\"{{id}}_helpPopover\"\r\n *ngIf=\"helpPopover\"\r\n class=\"d-inline-block my-n3 mx-n1\"\r\n text=\"{{helpPopover | translate}}\"\r\n contentPosition=\"{{helpPopoverPosition}}\">\r\n </ec-help-popover>\r\n </label>\r\n\r\n <!-- Setting the maxlength to 13 to combat the user from entering too large of a number\r\n for javascript to support. If the user enters all 13 characters as numbers and we have showPrecision set, adding the\r\n decimal and the empty zero characters will get them in a situation where to edit it they must remove characters\r\n as we would push them past the limit -->\r\n <ec-textbox [id]=\"id\"\r\n #textbox\r\n class=\"control-input mb-0\"\r\n [placeholder]=\"placeholder\"\r\n [maxlength]=\"maxPrecisionDigits ? maxPrecisionDigits + 3 : 13\"\r\n [autofocus]=\"autofocus\"\r\n [formModel]=\"textboxFormModel\"\r\n [required]=\"required\"\r\n [tabindex]=\"tabindex\"\r\n [readonly]=\"readonly\"\r\n [tooltip]=\"tooltip\"\r\n (focusout)=\"onFocusOut()\">\r\n </ec-textbox>\r\n</div>", styles: [":host{color:var(--ec-form-control-color);font-size:var(--ec-form-control-font-size);display:block;margin-bottom:1rem;width:100%}:host :host-context(.form-condensed){margin-bottom:.5rem}:host .control{width:100%;display:flex;flex-direction:column}:host .control.control-label-bottom{flex-direction:column-reverse}:host .control.control-label-left{flex-direction:row}:host .control.control-label-left label{margin-right:.25rem}:host .control.control-label-right{flex-direction:row-reverse}:host .control.control-label-right label{margin-left:.25rem}:host .control.control-label-left,:host .control.control-label-right{align-items:center}:host .control.control-label-left label,:host .control.control-label-right label{flex:1 1;margin-top:0;margin-bottom:0}:host .control.control-label-left .control-input,:host .control.control-label-right .control-input{flex:2 2}:host .control.is-readonly input,:host .control.is-readonly select,:host .control.is-readonly textarea{border-color:var(--ec-form-control-border-color-readonly);background-color:var(--ec-form-control-background-color-readonly);background-clip:border-box;background-image:none;color:var(--ec-form-control-color-readonly);opacity:1;-webkit-user-select:none;user-select:none;pointer-events:none;overflow:hidden;white-space:nowrap}:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-invalid,:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-valid{background-color:var(--ec-form-control-background-color-invalid);border-color:var(--ec-form-control-border-color-invalid);background-repeat:no-repeat;background-position:.5rem center;background-size:1rem,1rem;padding-left:1.75rem;background-image:none}:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-invalid:focus,:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-valid:focus{border-color:var(--ec-form-control-background-color-invalid)}:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-invalid~.icon-invalid,:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-valid~.icon-invalid{display:inline-flex;position:absolute;left:.5rem;top:.5rem;z-index:1}:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-invalid~.icon-required,:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-valid~.icon-required{display:none}:host .control.invalid:not(.open) .textbox-group-btn-right ::ng-deep button{background-color:var(--ec-form-control-background-color-invalid)}:host .control.invalid:not(.open) .textbox-group-btn-right ::ng-deep button:not(:focus){border-color:var(--ec-form-control-border-color-invalid)}:host .textbox-group{display:flex;position:relative}:host textarea:focus,:host input:focus,:host select:focus{outline:none}label{color:var(--ec-form-control-label-color, var(--ec-color-secondary-dark));display:block;font-size:var(--ec-font-size-label);line-height:1;margin:calc(var(--ec-font-size-label) / 2) 0}ec-textbox ::ng-deep .input-wrapper{position:relative}ec-textbox ::ng-deep input{text-align:right}ec-textbox ::ng-deep input:required.is-empty:not(:disabled)~.units-left{left:1.25rem}ec-textbox ::ng-deep input.ng-invalid.ng-touched~.units-left{left:1.25rem}ec-textbox ::ng-deep .control:not(.is-readonly) input:disabled~.units{color:var(--ec-form-control-color-disabled);opacity:.65}ec-textbox ::ng-deep .units{display:block;position:absolute;top:0;height:2rem;line-height:1.25rem;padding:.375rem .25rem;z-index:2}ec-textbox ::ng-deep .units.units-right{right:0;padding-right:.5rem}ec-textbox ::ng-deep .units.units-left{left:0;padding-left:.5rem}.control.invalid ec-textbox ::ng-deep input.ng-invalid,.control.invalid ec-textbox ::ng-deep input.ng-valid{background-color:var(--ec-form-control-background-color-invalid);border-color:var(--ec-form-control-border-color-invalid);background-repeat:no-repeat;background-position:.5rem center;background-size:1rem,1rem;padding-left:1.75rem;background-image:none}.control.invalid ec-textbox ::ng-deep input.ng-invalid:focus,.control.invalid ec-textbox ::ng-deep input.ng-valid:focus{border-color:var(--ec-form-control-background-color-invalid)}.control.invalid ec-textbox ::ng-deep input.ng-invalid~.units-left,.control.invalid ec-textbox ::ng-deep input.ng-valid~.units-left{left:1.25rem}.control.invalid ec-textbox ::ng-deep input.ng-invalid~.icon-invalid,.control.invalid ec-textbox ::ng-deep input.ng-valid~.icon-invalid{display:inline-flex;position:absolute;left:.5rem;top:.5rem;z-index:1}.control.invalid ec-textbox ::ng-deep input.ng-invalid~.icon-required,.control.invalid ec-textbox ::ng-deep input.ng-valid~.icon-required{display:none}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TextboxComponent, selector: "ec-textbox", inputs: ["autocomplete", "type", "placeholder", "maxlength", "minlength", "rows", "selectOnAutofocus", "upperCase"] }, { kind: "component", type: i5.HelpPopoverComponent, selector: "ec-help-popover", inputs: ["id", "text", "contentPosition", "maxWidth"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] });
|
344
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NumericboxComponent, decorators: [{
|
345
|
+
type: Component,
|
346
|
+
args: [{ selector: 'ec-numericbox', template: "<div class=\"control control-label-{{labelPosition}}\"\r\n [class.invalid]=\"formModel?.invalid && (formModel?.touched)\">\r\n\r\n <label *ngIf=\"label\">\r\n <span>{{label | translate}}</span>\r\n <span *ngIf=\"validationErrors.length && formModel?.touched && formModel?.invalid\"> {{validationErrors | translate}}</span>\r\n <ec-help-popover id=\"{{id}}_helpPopover\"\r\n *ngIf=\"helpPopover\"\r\n class=\"d-inline-block my-n3 mx-n1\"\r\n text=\"{{helpPopover | translate}}\"\r\n contentPosition=\"{{helpPopoverPosition}}\">\r\n </ec-help-popover>\r\n </label>\r\n\r\n <!-- Setting the maxlength to 13 to combat the user from entering too large of a number\r\n for javascript to support. If the user enters all 13 characters as numbers and we have showPrecision set, adding the\r\n decimal and the empty zero characters will get them in a situation where to edit it they must remove characters\r\n as we would push them past the limit -->\r\n <ec-textbox [id]=\"id\"\r\n #textbox\r\n class=\"control-input mb-0\"\r\n [placeholder]=\"placeholder\"\r\n [maxlength]=\"maxPrecisionDigits ? maxPrecisionDigits + 3 : 13\"\r\n [autofocus]=\"autofocus\"\r\n [formModel]=\"textboxFormModel\"\r\n [required]=\"required\"\r\n [tabindex]=\"tabindex\"\r\n [readonly]=\"readonly\"\r\n [tooltip]=\"tooltip\"\r\n (focusout)=\"onFocusOut()\">\r\n </ec-textbox>\r\n</div>", styles: [":host{color:var(--ec-form-control-color);font-size:var(--ec-form-control-font-size);display:block;margin-bottom:1rem;width:100%}:host :host-context(.form-condensed){margin-bottom:.5rem}:host .control{width:100%;display:flex;flex-direction:column}:host .control.control-label-bottom{flex-direction:column-reverse}:host .control.control-label-left{flex-direction:row}:host .control.control-label-left label{margin-right:.25rem}:host .control.control-label-right{flex-direction:row-reverse}:host .control.control-label-right label{margin-left:.25rem}:host .control.control-label-left,:host .control.control-label-right{align-items:center}:host .control.control-label-left label,:host .control.control-label-right label{flex:1 1;margin-top:0;margin-bottom:0}:host .control.control-label-left .control-input,:host .control.control-label-right .control-input{flex:2 2}:host .control.is-readonly input,:host .control.is-readonly select,:host .control.is-readonly textarea{border-color:var(--ec-form-control-border-color-readonly);background-color:var(--ec-form-control-background-color-readonly);background-clip:border-box;background-image:none;color:var(--ec-form-control-color-readonly);opacity:1;-webkit-user-select:none;user-select:none;pointer-events:none;overflow:hidden;white-space:nowrap}:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-invalid,:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-valid{background-color:var(--ec-form-control-background-color-invalid);border-color:var(--ec-form-control-border-color-invalid);background-repeat:no-repeat;background-position:.5rem center;background-size:1rem,1rem;padding-left:1.75rem;background-image:none}:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-invalid:focus,:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-valid:focus{border-color:var(--ec-form-control-background-color-invalid)}:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-invalid~.icon-invalid,:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-valid~.icon-invalid{display:inline-flex;position:absolute;left:.5rem;top:.5rem;z-index:1}:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-invalid~.icon-required,:host .control.invalid .textbox-group-input ::ng-deep .control input.ng-valid~.icon-required{display:none}:host .control.invalid:not(.open) .textbox-group-btn-right ::ng-deep button{background-color:var(--ec-form-control-background-color-invalid)}:host .control.invalid:not(.open) .textbox-group-btn-right ::ng-deep button:not(:focus){border-color:var(--ec-form-control-border-color-invalid)}:host .textbox-group{display:flex;position:relative}:host textarea:focus,:host input:focus,:host select:focus{outline:none}label{color:var(--ec-form-control-label-color, var(--ec-color-secondary-dark));display:block;font-size:var(--ec-font-size-label);line-height:1;margin:calc(var(--ec-font-size-label) / 2) 0}ec-textbox ::ng-deep .input-wrapper{position:relative}ec-textbox ::ng-deep input{text-align:right}ec-textbox ::ng-deep input:required.is-empty:not(:disabled)~.units-left{left:1.25rem}ec-textbox ::ng-deep input.ng-invalid.ng-touched~.units-left{left:1.25rem}ec-textbox ::ng-deep .control:not(.is-readonly) input:disabled~.units{color:var(--ec-form-control-color-disabled);opacity:.65}ec-textbox ::ng-deep .units{display:block;position:absolute;top:0;height:2rem;line-height:1.25rem;padding:.375rem .25rem;z-index:2}ec-textbox ::ng-deep .units.units-right{right:0;padding-right:.5rem}ec-textbox ::ng-deep .units.units-left{left:0;padding-left:.5rem}.control.invalid ec-textbox ::ng-deep input.ng-invalid,.control.invalid ec-textbox ::ng-deep input.ng-valid{background-color:var(--ec-form-control-background-color-invalid);border-color:var(--ec-form-control-border-color-invalid);background-repeat:no-repeat;background-position:.5rem center;background-size:1rem,1rem;padding-left:1.75rem;background-image:none}.control.invalid ec-textbox ::ng-deep input.ng-invalid:focus,.control.invalid ec-textbox ::ng-deep input.ng-valid:focus{border-color:var(--ec-form-control-background-color-invalid)}.control.invalid ec-textbox ::ng-deep input.ng-invalid~.units-left,.control.invalid ec-textbox ::ng-deep input.ng-valid~.units-left{left:1.25rem}.control.invalid ec-textbox ::ng-deep input.ng-invalid~.icon-invalid,.control.invalid ec-textbox ::ng-deep input.ng-valid~.icon-invalid{display:inline-flex;position:absolute;left:.5rem;top:.5rem;z-index:1}.control.invalid ec-textbox ::ng-deep input.ng-invalid~.icon-required,.control.invalid ec-textbox ::ng-deep input.ng-valid~.icon-required{display:none}\n"] }]
|
347
|
+
}], ctorParameters: function () { return [{ type: i1.ValidationMessageService }, { type: i2.FormGroupHelper }, { type: i0.Renderer2 }]; }, propDecorators: { placeholder: [{
|
348
|
+
type: Input
|
349
|
+
}], decimals: [{
|
350
|
+
type: Input
|
351
|
+
}], showPrecision: [{
|
352
|
+
type: Input
|
353
|
+
}], maxPrecisionDigits: [{
|
354
|
+
type: Input
|
355
|
+
}], max: [{
|
356
|
+
type: Input
|
357
|
+
}], min: [{
|
358
|
+
type: Input
|
359
|
+
}], leftUnits: [{
|
360
|
+
type: Input
|
361
|
+
}], rightUnits: [{
|
362
|
+
type: Input
|
363
|
+
}], autoUpdateFormModel: [{
|
364
|
+
type: Input
|
365
|
+
}], textboxEl: [{
|
366
|
+
type: ViewChild,
|
367
|
+
args: [TextboxComponent, { read: ElementRef, static: true }]
|
368
|
+
}], textboxInput: [{
|
369
|
+
type: ViewChild,
|
370
|
+
args: ['textbox', { static: true }]
|
371
|
+
}] } });
|
372
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"numericbox.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/controls/numericbox/numericbox.component.ts","../../../../../../projects/components/src/lib/controls/numericbox/numericbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, AfterViewInit, Component, ElementRef, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { AbstractControl, UntypedFormControl, ValidatorFn, Validators } from \"@angular/forms\";\r\nimport { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';\r\nimport { ValidationMessageService } from '../../core/validation-message.service';\r\nimport { getDecimalPattern, integerPattern } from '../../core/validation-patterns';\r\nimport { FormGroupHelper } from '../../shared/form-group.helper';\r\nimport { FormControlBase } from \"../form-control-base\";\r\nimport { TextboxComponent } from '../textbox/textbox.component';\r\n\r\n\r\n/**\r\n * Custom validator to check that min/max and pattern validation is met on the numericbox\r\n * component\r\n */\r\nexport const numericboxValidation = (min: number | undefined, max: number | undefined, decimals: number | undefined, maxPrecisionDigits: number | undefined): ValidatorFn => {\r\n    return (control: AbstractControl) => {\r\n        let hasError: boolean = false;\r\n\r\n        // If the control is empty we won't attempt to validate, if there is a required\r\n        // validator we will never get here until there is a value\r\n        if (control.value && control.value !== \"\") {\r\n\r\n            let numericPattern: RegExp;\r\n            if (decimals && decimals > 0) {\r\n                numericPattern = getDecimalPattern(decimals);\r\n            } else if (maxPrecisionDigits) {\r\n                // Still need to check for a valid number formatting when in max precision mode\r\n                numericPattern = getDecimalPattern(maxPrecisionDigits);\r\n            } else {\r\n                // Allow an optional negative sign and any number of digits 0-9\r\n                numericPattern = integerPattern;\r\n            }\r\n\r\n            if (!numericPattern.test(control.value)) {\r\n                hasError = true;\r\n            } else if (maxPrecisionDigits) {\r\n                // Converting to a number then back to string removes trailing zeros, and the regex replace removes\r\n                // any negative signs, leading zeros or decimal points from the number.\r\n                const val = Number(control.value).toString().replace(/^-?/, '').replace(/(^0\\.)|(\\.)/, '');\r\n                hasError = val.length > maxPrecisionDigits;\r\n            }\r\n\r\n            // We now know we have a valid number, so we can cast these to numbers\r\n            // for proper range validation\r\n            if (min !== undefined && Number(control.value) < min) {\r\n                hasError = true;\r\n            }\r\n\r\n            if (max !== undefined && Number(control.value) > max) {\r\n                hasError = true;\r\n            }\r\n        }\r\n\r\n        if (hasError) {\r\n            return {\r\n                numericbox: {\r\n                    valid: false,\r\n                    min: min,\r\n                    max: max,\r\n                    decimals: decimals,\r\n                    maxPrecisionDigits: maxPrecisionDigits\r\n                }\r\n            };\r\n        } else {\r\n            return null;\r\n        }\r\n\r\n    }\r\n};\r\n\r\n@Component({\r\n    selector: 'ec-numericbox',\r\n    templateUrl: './numericbox.component.html',\r\n    styleUrls: ['./numericbox.component.scss']\r\n})\r\n\r\nexport class NumericboxComponent extends FormControlBase implements OnInit, OnDestroy, OnChanges, AfterViewChecked, AfterViewInit {\r\n\r\n\r\n    /**\r\n     * The value of the textbox input's placeholder\r\n     */\r\n    @Input() public placeholder?: string;\r\n\r\n    /**\r\n     * The number of decimals allowed.  If not supplied the input value will be validated as a\r\n     * whole number\r\n     */\r\n    @Input() public decimals?: number;\r\n\r\n\r\n    /**\r\n     * Show trailing zeros after the decimal point.\r\n     * Do not use with maxPrecisionDigits.\r\n     */\r\n    @Input() public showPrecision?: boolean = false;\r\n\r\n\r\n    /**\r\n     * The maximum total digits a number can have left or right of the decimal point.\r\n     * Due to limitations with how JS handles numbers, the max value for this is 15.\r\n     * Numbers longer than 15 digits may cause rounding errors.\r\n     * Do not use with showPrecision = true\r\n     */\r\n    @Input() public maxPrecisionDigits?: number;\r\n\r\n\r\n    /**\r\n     * The maximum value allowed in the input\r\n     *\r\n     * This is for adding the attribute on the element to get the browser functionality\r\n     * from the input.  If you need the form to be validated before submission, apply the\r\n     * max validator to the form conrol.\r\n     */\r\n    @Input() public max?: number;\r\n\r\n\r\n    /**\r\n     * The minimum value allowed in the input\r\n     *\r\n     * This is for adding the attribute on the element to get the browser functionality\r\n     * from the input.  If you need the form to be validated before submission, apply the\r\n     * min validator to the form conrol.\r\n     */\r\n    @Input() public min?: number;\r\n\r\n\r\n    /**\r\n     * Text to display on the left side of the input\r\n     */\r\n    @Input() public leftUnits?: string;\r\n\r\n\r\n    /**\r\n     * Text to display on the right side of the input\r\n     */\r\n    @Input() public rightUnits?: string;\r\n\r\n    /**\r\n     * If set to true this will update the form model after a debounce as the user\r\n     * interacts with the component\r\n     */\r\n    @Input() public autoUpdateFormModel: boolean = false;\r\n\r\n    /**\r\n     * A reference to the textbox element\r\n     */\r\n    @ViewChild(TextboxComponent, { read: ElementRef, static: true }) private textboxEl!: ElementRef;\r\n\r\n\r\n    /**\r\n     * The internal form model we use to display the value with formatting\r\n     */\r\n    public textboxFormModel!: UntypedFormControl;\r\n\r\n    /** Flag to tell the page we finally computed a greater than zero\r\n     *  width for units (if applicable)\r\n     */\r\n    private unitsWidthCalculated: boolean = false;\r\n\r\n    /** Flag used to filter the form models value changes subscription\r\n     *  to prevent the textbox model from being formatted as the form model is updated\r\n     *  programmatically when the textbox model updates\r\n     */\r\n    private autoUpdatingFormModel: boolean = false;\r\n\r\n    /**\r\n   * Reference to the textbox input control\r\n   */\r\n    @ViewChild('textbox', { static: true }) private textboxInput!: TextboxComponent;\r\n\r\n    constructor(\r\n        protected validationMessageService: ValidationMessageService,\r\n        protected formGroupHelper: FormGroupHelper,\r\n        protected renderer: Renderer2\r\n    ) {\r\n        super(validationMessageService, formGroupHelper);\r\n    }\r\n\r\n    /**\r\n     * Angular AfterViewInit life-cycle hook\r\n     * Subscribe to textbox model value changes if the hosting\r\n     * page has opted in for this component\r\n     */\r\n    public ngAfterViewInit(): void {\r\n        if (this.autoUpdateFormModel) {\r\n            this.textboxFormModel.valueChanges\r\n                .pipe(\r\n                    debounceTime(300),\r\n                    distinctUntilChanged(),\r\n                    takeUntil(this.componentDestroyed),\r\n                ).subscribe(() => {\r\n                    this.updateFormModelValue();\r\n                });\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Angular onChanges life-cycle hook\r\n     * @see {@link https://angular.io/guide/lifecycle-hooks | Life-cycle hooks}\r\n     */\r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        // If either units change after we've calculated,\r\n        // reset the flag so we can react and redraw\r\n        if (changes.rightUnits || changes.leftUnits) {\r\n            this.unitsWidthCalculated = false;\r\n        }\r\n\r\n        super.ngOnChanges(changes);\r\n    }\r\n\r\n\r\n    /**\r\n     * Angular onInit lifecycle hook\r\n     * If units is defined, set the position and listen for status changes so we\r\n     * can update the positioning of the units element\r\n     */\r\n    public ngOnInit(): void {\r\n        super.ngOnInit();\r\n\r\n        // Initialize the textbox form model with the value of the form model and synchronize\r\n        // disabled state\r\n        this.textboxFormModel = new UntypedFormControl({ value: this.formModel.value, disabled: this.formModel.disabled });\r\n\r\n        // Update the form model's errors when the textbox form model status changes\r\n        this.textboxFormModel.statusChanges.pipe(takeUntil(this.componentDestroyed)).subscribe(() => {\r\n            if (this.formModel.enabled) {\r\n                this.formModel.setErrors(this.textboxFormModel.errors);\r\n            }\r\n        })\r\n\r\n        // Synchronize disabled state between form model and internal textbox form model\r\n        this.formModel.statusChanges.pipe(takeUntil(this.componentDestroyed)).subscribe(() => {\r\n            if (this.formModel.disabled) {\r\n                this.textboxFormModel.disable();\r\n            } else {\r\n                if (this.textboxFormModel.disabled) {\r\n                    this.textboxFormModel.enable();\r\n                }\r\n            }\r\n        });\r\n\r\n        // Set textbox validators\r\n        this.textboxFormModel.setValidators(this.getValidators());\r\n\r\n        // Now that the textbox is set up we will set it's value to whatever the\r\n        // form model had when we initialized\r\n        this.textboxFormModel.setValue(this.formatDisplayNumber(this.formModel.value));\r\n\r\n        // If the form model's value changes programmatically we need to update the\r\n        // textbox form model\r\n        this.formModel.valueChanges.pipe(\r\n            // We need to filter out when we are updating it programmatically if the\r\n            // hosting page has opted into the auto updating input\r\n            filter(() => !this.autoUpdatingFormModel),\r\n            takeUntil(this.componentDestroyed)).subscribe(value => {\r\n                this.textboxFormModel.setValue(this.formatDisplayNumber(value));\r\n            });\r\n\r\n        // If the textbox status changes we need to update the left units position because\r\n        // we want to make room for the invalid icon\r\n        if (this.leftUnits) {\r\n            this.textboxFormModel.statusChanges.pipe(takeUntil(this.componentDestroyed)).subscribe(() => {\r\n                this.positionLeftUnits();\r\n            });\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Angular afterViewChecked lifecycle hook\r\n     * Show the units element if units is defined. Runs after every ngOnChanges\r\n     */\r\n    public ngAfterViewChecked(): void {\r\n        if ((this.leftUnits || this.rightUnits) && !this.unitsWidthCalculated) {\r\n            this.showUnits();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Function that builds and returns a ValidatorFn array to set on the form control\r\n     */\r\n    private getValidators(): ValidatorFn[] {\r\n        let validators: ValidatorFn[] = [];\r\n\r\n        if (this.required) {\r\n            validators.push(Validators.required);\r\n        }\r\n\r\n        validators.push(numericboxValidation(this.min, this.max, this.decimals, this.maxPrecisionDigits));\r\n\r\n        return validators;\r\n    }\r\n\r\n    /**\r\n     * Focus out event handler for the Textbox component\r\n     */\r\n    public onFocusOut(): void {\r\n        this.updateFormModelValue(true);\r\n    }\r\n\r\n    /**\r\n    * Function to set focus on an input programatically after the page\r\n    * had been rendered.  The highlight text flag will select the text\r\n    * within the input if passed in and true\r\n    */\r\n    public setFocus(highlightText?: boolean): void {\r\n        this.textboxInput.setFocus(highlightText);\r\n    }\r\n\r\n\r\n    /**\r\n     * When the textbox model updates we need to add some display formatting for\r\n     * display in the textbox and cast the textbox model to a number. Avoid updating\r\n     * the form model when the value doesn't change because listeners will fire for no reason\r\n     */\r\n    private updateFormModelValue(isFocusOut?: boolean): void {\r\n        if (this.autoUpdateFormModel) {\r\n            // Make it so value changes on the form model do not get triggered\r\n            // as we change it programmatically.  We do not want the textbox\r\n            // model to be updated while the user is in the input\r\n            this.autoUpdatingFormModel = true;\r\n        }\r\n\r\n        try {\r\n            if (this.textboxFormModel.valid || this.textboxFormModel.value === \"\") {\r\n                // Start out with null for the number, if the textbox value is not a number\r\n                // we will clear it out on focus out\r\n                let number: number | null = null;\r\n\r\n                // Make sure the textbox model is a number before trying to update the\r\n                // form model value with it\r\n                if (this.textboxFormModel.value && !isNaN(this.textboxFormModel.value)) {\r\n                    // Our value is a legit number, on focus out we will format it if needed\r\n                    number = Number(this.textboxFormModel.value);\r\n\r\n                    // Checking if the value has actually changed, if not don't set the\r\n                    // value to avoid extra listener calls\r\n                    if (this.formModel.value !== number) {\r\n                        this.formModel.setValue(number);\r\n                    }\r\n                    // The textbox model is not a number, check to see if our form model has a value\r\n                    // and if so clear it out\r\n                } else if (this.formModel.value !== null) {\r\n                    this.formModel.setValue(null);\r\n                }\r\n\r\n                // We only will update the textbox form model with formatting if needed\r\n                // on Focus out.  This works well for the user whether the auto update\r\n                // is opted in or not\r\n                if (isFocusOut) {\r\n                    this.textboxFormModel.setValue(this.formatDisplayNumber(number));\r\n                }\r\n            }\r\n\r\n            this.formModel.markAsTouched();\r\n        } catch (error) {\r\n            // Nothing to display, just ensuring we reset our flag that filters\r\n            // the form model value changes\r\n        } finally {\r\n            this.autoUpdatingFormModel = false;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Convert a number value to the formmated display string. If there is no value\r\n     * return null\r\n     */\r\n    private formatDisplayNumber(value: number | null | undefined): string | null {\r\n        if (value || value === 0) {\r\n            // Guard against calling toFixed if the value isn't a number.  This is possible\r\n            // if patching a value from outside of the component as you don't have\r\n            // type checking there\r\n            if (this.showPrecision && this.decimals && !isNaN(value)) {\r\n                return value.toFixed(this.decimals);\r\n            } else {\r\n                return value.toString();\r\n            }\r\n        } else {\r\n            return null;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Position the units element and set the padding in the textbox input based\r\n     * on the width of the units element\r\n     */\r\n    private positionRightUnits(): void {\r\n        let unitsEl = this.textboxEl.nativeElement.querySelector('.units-right');\r\n        let inputEl = this.textboxEl.nativeElement.querySelector('input');\r\n\r\n        if (unitsEl && inputEl) {\r\n            let unitsWidth = unitsEl.offsetWidth;\r\n\r\n            if (unitsWidth > 0) {\r\n                this.unitsWidthCalculated = true;\r\n            }\r\n\r\n            let padding = unitsWidth;\r\n            this.renderer.setStyle(inputEl, 'padding-right', padding + 'px');\r\n        }\r\n    }\r\n\r\n\r\n    private positionLeftUnits() {\r\n        let unitsEl = this.textboxEl.nativeElement.querySelector('.units-left');\r\n        let inputEl = this.textboxEl.nativeElement.querySelector('input');\r\n\r\n        if (unitsEl && inputEl) {\r\n            let unitsWidth = unitsEl.offsetWidth;\r\n\r\n            if (unitsWidth > 0) {\r\n                this.unitsWidthCalculated = true;\r\n            }\r\n\r\n            let padding = unitsWidth;\r\n            let leftPosition = getComputedStyle(unitsEl).left;\r\n            if (leftPosition) {\r\n                padding += parseInt(leftPosition.replace('px', ''), 0);\r\n            }\r\n            this.renderer.setStyle(inputEl, 'padding-left', padding + 'px');\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Create and append the units element to the textbox element\r\n     */\r\n    private showUnits(): void {\r\n        let inputWrapper = this.textboxEl.nativeElement.querySelector('.input-wrapper');\r\n\r\n        if (inputWrapper) {\r\n            if (this.leftUnits) {\r\n                let unitsEl = this.textboxEl.nativeElement.querySelector('.units-left');\r\n                if (unitsEl) {\r\n                    this.renderer.setProperty(unitsEl, 'innerHTML', this.leftUnits);\r\n                } else {\r\n                    this.renderer.appendChild(inputWrapper, this.makeUnitElement('left', this.leftUnits));\r\n                }\r\n                this.positionLeftUnits();\r\n            }\r\n\r\n            if (this.rightUnits) {\r\n                let unitsEl = this.textboxEl.nativeElement.querySelector('.units-right');\r\n                if (unitsEl) {\r\n                    this.renderer.setProperty(unitsEl, 'innerHTML', this.rightUnits);\r\n                } else {\r\n                    this.renderer.appendChild(inputWrapper, this.makeUnitElement('right', this.rightUnits));\r\n                }\r\n                this.positionRightUnits();\r\n            }\r\n        }\r\n    }\r\n\r\n    private makeUnitElement(side: 'left' | 'right', text: string): any {\r\n        let unitsEl = this.renderer.createElement('span');\r\n        this.renderer.setAttribute(unitsEl, 'class', `units units-${side}`);\r\n        this.renderer.setAttribute(unitsEl, 'id', `${this.id}_units`);\r\n        this.renderer.setAttribute(unitsEl, 'style', 'pointer-events: none');\r\n        this.renderer.setProperty(unitsEl, 'innerHTML', text);\r\n\r\n        return unitsEl;\r\n    }\r\n}","<div class=\"control control-label-{{labelPosition}}\"\r\n     [class.invalid]=\"formModel?.invalid && (formModel?.touched)\">\r\n\r\n       <label *ngIf=\"label\">\r\n              <span>{{label | translate}}</span>\r\n              <span *ngIf=\"validationErrors.length && formModel?.touched && formModel?.invalid\">&nbsp;{{validationErrors | translate}}</span>\r\n              <ec-help-popover id=\"{{id}}_helpPopover\"\r\n                               *ngIf=\"helpPopover\"\r\n                               class=\"d-inline-block my-n3 mx-n1\"\r\n                               text=\"{{helpPopover | translate}}\"\r\n                               contentPosition=\"{{helpPopoverPosition}}\">\r\n              </ec-help-popover>\r\n       </label>\r\n\r\n       <!-- Setting the maxlength to 13 to combat the user from entering too large of a number\r\n         for javascript to support.  If the user enters all 13 characters as numbers and we have showPrecision set, adding the\r\n         decimal and the empty zero characters will get them in a situation where to edit it they must remove characters\r\n         as we would push them past the limit -->\r\n       <ec-textbox [id]=\"id\"\r\n                   #textbox\r\n                   class=\"control-input mb-0\"\r\n                   [placeholder]=\"placeholder\"\r\n                   [maxlength]=\"maxPrecisionDigits ? maxPrecisionDigits + 3 : 13\"\r\n                   [autofocus]=\"autofocus\"\r\n                   [formModel]=\"textboxFormModel\"\r\n                   [required]=\"required\"\r\n                   [tabindex]=\"tabindex\"\r\n                   [readonly]=\"readonly\"\r\n                   [tooltip]=\"tooltip\"\r\n                   (focusout)=\"onFocusOut()\">\r\n       </ec-textbox>\r\n</div>"]}
|
@@ -0,0 +1,117 @@
|
|
1
|
+
import { OverlayConfig } from '@angular/cdk/overlay';
|
2
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
3
|
+
import { Component, HostListener, Input, ViewChild } from '@angular/core';
|
4
|
+
import { of, Subject } from 'rxjs';
|
5
|
+
import { delay, switchMap, takeUntil } from 'rxjs/operators';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "@angular/cdk/overlay";
|
8
|
+
import * as i2 from "../../display/tooltip/tooltip.service";
|
9
|
+
import * as i3 from "@angular/common";
|
10
|
+
import * as i4 from "../../display/tags/tags.component";
|
11
|
+
export class PopoverComponent {
|
12
|
+
constructor(overlay, viewContainerRef, elementRef, tooltipService) {
|
13
|
+
this.overlay = overlay;
|
14
|
+
this.viewContainerRef = viewContainerRef;
|
15
|
+
this.elementRef = elementRef;
|
16
|
+
this.tooltipService = tooltipService;
|
17
|
+
/** An optional icon that, if provided, enables the popover to use it as the anchor element */
|
18
|
+
this.icon = '';
|
19
|
+
this.contentPosition = 'top-left';
|
20
|
+
this.iconHoverClass = '';
|
21
|
+
this.isVisible = false;
|
22
|
+
this.mouseOver = new Subject();
|
23
|
+
this.interrupt = new Subject();
|
24
|
+
}
|
25
|
+
/** When the popover initializes, if a new tagType is provided for the hover state of the popover,
|
26
|
+
* we use it to update the type of our "hoverTag" (which controls background-color of tag)
|
27
|
+
*/
|
28
|
+
ngOnInit() {
|
29
|
+
if (this.tag && this.tagHoverType) {
|
30
|
+
this.hoverTag = { ...this.tag, type: this.tagHoverType };
|
31
|
+
}
|
32
|
+
this.mouseOver
|
33
|
+
.pipe(switchMap(v => of(v).pipe(delay(300), takeUntil(this.interrupt))))
|
34
|
+
.subscribe(() => this.show());
|
35
|
+
}
|
36
|
+
ngOnDestroy() {
|
37
|
+
this.hide();
|
38
|
+
}
|
39
|
+
show() {
|
40
|
+
if (!this.isVisible) {
|
41
|
+
const overlayConfig = this.getOverlayConfig();
|
42
|
+
this.overlayRef = this.overlay.create(overlayConfig);
|
43
|
+
const contentPortal = new TemplatePortal(this.content, this.viewContainerRef);
|
44
|
+
this.contentViewRef = this.overlayRef.attach(contentPortal);
|
45
|
+
this.isVisible = true;
|
46
|
+
}
|
47
|
+
}
|
48
|
+
onMouseOver() {
|
49
|
+
this.mouseOver.next();
|
50
|
+
}
|
51
|
+
onLeave() {
|
52
|
+
this.interrupt.next();
|
53
|
+
}
|
54
|
+
/**
|
55
|
+
* Hides the popover if the mouse moves outside of the popover content
|
56
|
+
*/
|
57
|
+
onMouseMove(event) {
|
58
|
+
let callCallback = false;
|
59
|
+
if (!this.contentRect) {
|
60
|
+
this.contentRect = this.contentViewRef?.rootNodes[0].getBoundingClientRect();
|
61
|
+
}
|
62
|
+
if (this.contentRect) {
|
63
|
+
callCallback = this.tooltipService.onMove(event, this.contentRect);
|
64
|
+
}
|
65
|
+
if (callCallback) {
|
66
|
+
this.hide();
|
67
|
+
}
|
68
|
+
}
|
69
|
+
hide() {
|
70
|
+
this.interrupt.next();
|
71
|
+
this.overlayRef?.dispose();
|
72
|
+
this.isVisible = false;
|
73
|
+
this.contentRect = undefined;
|
74
|
+
}
|
75
|
+
getOverlayConfig() {
|
76
|
+
const position = this.getPosition();
|
77
|
+
const positionStrategy = this.overlay.position()
|
78
|
+
.flexibleConnectedTo(this.elementRef)
|
79
|
+
.withPositions([position]);
|
80
|
+
const config = new OverlayConfig({
|
81
|
+
positionStrategy: positionStrategy
|
82
|
+
});
|
83
|
+
return config;
|
84
|
+
}
|
85
|
+
getPosition() {
|
86
|
+
const position = this.contentPosition.split('-');
|
87
|
+
const overlayX = (position[1] == 'left' ? 'start' : 'end');
|
88
|
+
const overlayY = position[0];
|
89
|
+
return { originX: overlayX, originY: overlayY, overlayX: overlayX, overlayY: overlayY };
|
90
|
+
}
|
91
|
+
}
|
92
|
+
PopoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: PopoverComponent, deps: [{ token: i1.Overlay }, { token: i0.ViewContainerRef }, { token: i0.ElementRef }, { token: i2.TooltipService }], target: i0.ɵɵFactoryTarget.Component });
|
93
|
+
PopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: PopoverComponent, selector: "ec-popover", inputs: { icon: "icon", tag: "tag", tagHoverType: "tagHoverType", contentPosition: "contentPosition", iconHoverClass: "iconHoverClass" }, host: { listeners: { "mouseover": "onMouseOver()", "mouseleave": "onLeave()" } }, viewQueries: [{ propertyName: "content", first: true, predicate: ["content"], descendants: true }], ngImport: i0, template: "<!-- Before hover state -->\r\n<div class=\"p-2\">\r\n <i *ngIf=\"!tag\" class=\"ec-icon {{icon}} ec-icon-sm\"></i>\r\n <ec-tags *ngIf=\"tag\"\r\n [isCondensed] = \"true\"\r\n [tags]=\"tag\">\r\n </ec-tags>\r\n</div>\r\n<!-- ./Before hover state -->\r\n\r\n<!-- Hover state -->\r\n<ng-template #content>\r\n <article class=\"popover-content\"\r\n (document:mousemove)=\"onMouseMove($event)\">\r\n <ng-content></ng-content>\r\n </article>\r\n <div class=\"p-2 {{contentPosition}}\">\r\n <i *ngIf=\"!tag\" class=\"ec-icon {{icon}} ec-icon-sm {{iconHoverClass}}\"></i>\r\n <ec-tags *ngIf=\"tag\"\r\n [isCondensed]=\"true\"\r\n [tags]=\"hoverTag\">\r\n </ec-tags>\r\n </div>\r\n</ng-template>\r\n<!-- ./Hover state -->\r\n", styles: [":host{line-height:.75rem;display:inline-block}.popover-content{border-radius:var(--ec-border-radius);box-shadow:0 3px 6px #1a1a231f;overflow:hidden;position:relative}.popover-content+div{position:absolute;line-height:.75rem}.popover-content+div.top-left{top:0;left:0}.popover-content+div.top-right{top:0;right:0}.popover-content+div.bottom-right{bottom:0;right:0}.popover-content+div.bottom-left{bottom:0;left:0}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TagsComponent, selector: "ec-tags", inputs: ["id", "tags", "wrap", "isCondensed"], outputs: ["tagClosed"] }] });
|
94
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: PopoverComponent, decorators: [{
|
95
|
+
type: Component,
|
96
|
+
args: [{ selector: 'ec-popover', template: "<!-- Before hover state -->\r\n<div class=\"p-2\">\r\n <i *ngIf=\"!tag\" class=\"ec-icon {{icon}} ec-icon-sm\"></i>\r\n <ec-tags *ngIf=\"tag\"\r\n [isCondensed] = \"true\"\r\n [tags]=\"tag\">\r\n </ec-tags>\r\n</div>\r\n<!-- ./Before hover state -->\r\n\r\n<!-- Hover state -->\r\n<ng-template #content>\r\n <article class=\"popover-content\"\r\n (document:mousemove)=\"onMouseMove($event)\">\r\n <ng-content></ng-content>\r\n </article>\r\n <div class=\"p-2 {{contentPosition}}\">\r\n <i *ngIf=\"!tag\" class=\"ec-icon {{icon}} ec-icon-sm {{iconHoverClass}}\"></i>\r\n <ec-tags *ngIf=\"tag\"\r\n [isCondensed]=\"true\"\r\n [tags]=\"hoverTag\">\r\n </ec-tags>\r\n </div>\r\n</ng-template>\r\n<!-- ./Hover state -->\r\n", styles: [":host{line-height:.75rem;display:inline-block}.popover-content{border-radius:var(--ec-border-radius);box-shadow:0 3px 6px #1a1a231f;overflow:hidden;position:relative}.popover-content+div{position:absolute;line-height:.75rem}.popover-content+div.top-left{top:0;left:0}.popover-content+div.top-right{top:0;right:0}.popover-content+div.bottom-right{bottom:0;right:0}.popover-content+div.bottom-left{bottom:0;left:0}\n"] }]
|
97
|
+
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ViewContainerRef }, { type: i0.ElementRef }, { type: i2.TooltipService }]; }, propDecorators: { icon: [{
|
98
|
+
type: Input
|
99
|
+
}], tag: [{
|
100
|
+
type: Input
|
101
|
+
}], tagHoverType: [{
|
102
|
+
type: Input
|
103
|
+
}], contentPosition: [{
|
104
|
+
type: Input
|
105
|
+
}], iconHoverClass: [{
|
106
|
+
type: Input
|
107
|
+
}], content: [{
|
108
|
+
type: ViewChild,
|
109
|
+
args: ['content']
|
110
|
+
}], onMouseOver: [{
|
111
|
+
type: HostListener,
|
112
|
+
args: ['mouseover']
|
113
|
+
}], onLeave: [{
|
114
|
+
type: HostListener,
|
115
|
+
args: ['mouseleave']
|
116
|
+
}] } });
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/controls/popover/popover.component.ts","../../../../../../projects/components/src/lib/controls/popover/popover.component.html"],"names":[],"mappings":"AAAA,OAAO,EAA8B,aAAa,EAAc,MAAM,sBAAsB,CAAC;AAC7F,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,SAAS,EAA+B,YAAY,EAAE,KAAK,EAA0B,SAAS,EAAoB,MAAM,eAAe,CAAC;AACjJ,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;;AAW7D,MAAM,OAAO,gBAAgB;IAkC3B,YACU,OAAgB,EAChB,gBAAkC,EAClC,UAAsB,EACtB,cAA8B;QAH9B,YAAO,GAAP,OAAO,CAAS;QAChB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,eAAU,GAAV,UAAU,CAAY;QACtB,mBAAc,GAAd,cAAc,CAAgB;QApCxC,8FAA8F;QACrF,SAAI,GAAY,EAAE,CAAC;QAQnB,oBAAe,GAA2B,UAAU,CAAC;QAErD,mBAAc,GAAW,EAAE,CAAC;QAgB7B,cAAS,GAAY,KAAK,CAAC;QAE3B,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;QAChC,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;IAOpC,CAAC;IAEL;;OAEG;IACH,QAAQ;QACN,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,YAAY,EAAE;YACjC,IAAI,CAAC,QAAQ,GAAG,EAAC,GAAG,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;SACzD;QACD,IAAI,CAAC,SAAS;aACb,IAAI,CACH,SAAS,CAAC,CAAC,CAAC,EAAE,CACZ,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CACR,KAAK,CAAC,GAAG,CAAC,EACV,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B,CACF,CACF;aACA,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IAChC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAEO,IAAI;QAEV,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YAEnB,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC9C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YAErD,MAAM,aAAa,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;YAC9E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YAE5D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;IACH,CAAC;IAGM,WAAW;QAChB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IAGM,OAAO;QACZ,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,KAAiB;QAClC,IAAI,YAAY,GAAG,KAAK,CAAC;QAEzB,IAAG,CAAC,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,qBAAqB,EAAE,CAAC;SAC9E;QAED,IAAG,IAAI,CAAC,WAAW,EAAE;YACnB,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,WAAY,CAAC,CAAC;SACrE;QACD,IAAG,YAAY,EAAE;YACf,IAAI,CAAC,IAAI,EAAE,CAAC;SACb;IACH,CAAC;IAEO,IAAI;QACV,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;IAC/B,CAAC;IAEO,gBAAgB;QACtB,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QAEpC,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;aAC7C,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC;aACpC,aAAa,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAE7B,MAAM,MAAM,GAAG,IAAI,aAAa,CAAC;YAC/B,gBAAgB,EAAE,gBAAgB;SACnC,CAAC,CAAC;QAEH,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,WAAW;QACjB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACjD,MAAM,QAAQ,GAAoB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAC5E,MAAM,QAAQ,GAAqB,QAAQ,CAAC,CAAC,CAAC,CAAC;QAC/C,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC;IAC1F,CAAC;;6GApIU,gBAAgB;iGAAhB,gBAAgB,kXCf7B,2xBAyBA;2FDVa,gBAAgB;kBAL5B,SAAS;+BACE,YAAY;mLAOb,IAAI;sBAAZ,KAAK;gBAGG,GAAG;sBAAX,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAEG,eAAe;sBAAvB,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBAEuB,OAAO;sBAAnC,SAAS;uBAAC,SAAS;gBAgEb,WAAW;sBADjB,YAAY;uBAAC,WAAW;gBAMlB,OAAO;sBADb,YAAY;uBAAC,YAAY","sourcesContent":["import { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { Component, ElementRef, EmbeddedViewRef, HostListener, Input, OnDestroy, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { of, Subject } from 'rxjs';\r\nimport { delay, switchMap, takeUntil } from 'rxjs/operators';\r\nimport { Tag, TagType } from '../../display/tags/tag';\r\nimport { TooltipService } from '../../display/tooltip/tooltip.service';\r\n\r\nexport type PopoverContentPosition = 'top-left' | 'top-right' | 'bottom-right' | 'bottom-left';\r\n\r\n@Component({\r\n  selector: 'ec-popover',\r\n  templateUrl: './popover.component.html',\r\n  styleUrls: ['./popover.component.scss']\r\n})\r\nexport class PopoverComponent implements OnDestroy {\r\n\r\n  /** An optional icon that, if provided, enables the popover to use it as the anchor element */\r\n  @Input() icon?: string = '';\r\n  \r\n  /** An optional tag that, if provided, enables the popover to use it as the anchor element */\r\n  @Input() tag?: Tag;\r\n\r\n  /** Used to denote the hover tag's type (and thus background-color) */\r\n  @Input() tagHoverType?: TagType;\r\n\r\n  @Input() contentPosition: PopoverContentPosition = 'top-left';\r\n\r\n  @Input() iconHoverClass: string = '';\r\n\r\n  @ViewChild('content') public content!: TemplateRef<any>;\r\n\r\n  \r\n\r\n  /** In the template, we use an ec-tags element for the pre-hover state and an entirely\r\n   *  separate ec-tags element for our hover state, resulting in two components. To achieve a change \r\n   * in the background-color for our anchor tag, on hover, a different tag.tagType must be provided on the\r\n   * second ec-tag element\r\n   */\r\n  public hoverTag?: Tag;\r\n\r\n  private overlayRef?: OverlayRef;\r\n  private contentViewRef?: EmbeddedViewRef<any>;\r\n  private contentRect: DOMRect | undefined;\r\n  private isVisible: boolean = false;\r\n\r\n  private mouseOver = new Subject<void>();\r\n  private interrupt = new Subject<void>();\r\n\r\n  constructor(\r\n    private overlay: Overlay,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private elementRef: ElementRef,\r\n    private tooltipService: TooltipService,\r\n  ) { }\r\n\r\n  /** When the popover initializes, if a new tagType is provided for the hover state of the popover, \r\n   *  we use it to update the type of our \"hoverTag\" (which controls background-color of tag) \r\n   */\r\n  ngOnInit() {\r\n    if (this.tag && this.tagHoverType) {\r\n      this.hoverTag = {...this.tag, type: this.tagHoverType };\r\n    }\r\n    this.mouseOver\r\n    .pipe(\r\n      switchMap(v =>\r\n        of(v).pipe(\r\n          delay(300),\r\n          takeUntil(this.interrupt)\r\n        )\r\n      )\r\n    )\r\n    .subscribe(() => this.show());\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.hide();\r\n  }\r\n\r\n  private show() {\r\n\r\n    if (!this.isVisible) {\r\n      \r\n      const overlayConfig = this.getOverlayConfig();\r\n      this.overlayRef = this.overlay.create(overlayConfig);\r\n  \r\n      const contentPortal = new TemplatePortal(this.content, this.viewContainerRef);\r\n      this.contentViewRef = this.overlayRef.attach(contentPortal);\r\n  \r\n      this.isVisible = true;\r\n    }\r\n  }\r\n\r\n  @HostListener('mouseover')\r\n  public onMouseOver() {\r\n    this.mouseOver.next();\r\n  }\r\n\r\n  @HostListener('mouseleave')\r\n  public onLeave() {\r\n    this.interrupt.next();\r\n  }\r\n\r\n  /**\r\n   * Hides the popover if the mouse moves outside of the popover content\r\n   */\r\n  public onMouseMove(event: MouseEvent) {\r\n    let callCallback = false;\r\n    \r\n    if(!this.contentRect) {\r\n      this.contentRect = this.contentViewRef?.rootNodes[0].getBoundingClientRect();\r\n    }\r\n\r\n    if(this.contentRect) {\r\n      callCallback = this.tooltipService.onMove(event, this.contentRect!);\r\n    }\r\n    if(callCallback) {\r\n      this.hide();\r\n    }\r\n  } \r\n\r\n  private hide() {\r\n    this.interrupt.next();\r\n    this.overlayRef?.dispose();\r\n    this.isVisible = false;\r\n    this.contentRect = undefined;\r\n  }\r\n\r\n  private getOverlayConfig(): OverlayConfig {\r\n    const position = this.getPosition();\r\n\r\n    const positionStrategy = this.overlay.position()\r\n      .flexibleConnectedTo(this.elementRef)\r\n      .withPositions([position]);\r\n\r\n    const config = new OverlayConfig({\r\n      positionStrategy: positionStrategy\r\n    });\r\n\r\n    return config;\r\n  }\r\n\r\n  private getPosition(): ConnectedPosition {\r\n    const position = this.contentPosition.split('-');\r\n    const overlayX = <'start' | 'end'>(position[1] == 'left' ? 'start' : 'end');\r\n    const overlayY = <'top' | 'bottom'>position[0];\r\n    return { originX: overlayX, originY: overlayY, overlayX: overlayX, overlayY: overlayY };\r\n  }\r\n}\r\n","<!-- Before hover state -->\r\n<div class=\"p-2\">\r\n  <i *ngIf=\"!tag\" class=\"ec-icon {{icon}} ec-icon-sm\"></i>\r\n  <ec-tags *ngIf=\"tag\"\r\n            [isCondensed] = \"true\"\r\n            [tags]=\"tag\">\r\n  </ec-tags>\r\n</div>\r\n<!-- ./Before hover state -->\r\n\r\n<!-- Hover state -->\r\n<ng-template #content>\r\n  <article class=\"popover-content\"\r\n           (document:mousemove)=\"onMouseMove($event)\">\r\n    <ng-content></ng-content>\r\n  </article>\r\n  <div class=\"p-2 {{contentPosition}}\">\r\n    <i *ngIf=\"!tag\" class=\"ec-icon {{icon}} ec-icon-sm {{iconHoverClass}}\"></i>\r\n    <ec-tags *ngIf=\"tag\"\r\n             [isCondensed]=\"true\"\r\n             [tags]=\"hoverTag\">\r\n    </ec-tags>\r\n  </div>\r\n</ng-template>\r\n<!-- ./Hover state -->\r\n"]}
|
@@ -1,3 +1,3 @@
|
|
1
|
-
export class RadioButtonOption {
|
2
|
-
}
|
1
|
+
export class RadioButtonOption {
|
2
|
+
}
|
3
3
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tYnV0dG9uLW9wdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9jb250cm9scy9yYWRpby1idXR0b24vcmFkaW8tYnV0dG9uLW9wdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8saUJBQWlCO0NBa0I3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBSYWRpb0J1dHRvbk9wdGlvbjxUID0gYW55PiB7XHJcbiAgLyoqXHJcbiAgICogVGhlIHRleHQgdG8gZGlzcGxheSBhcyB0aGUgcmFkaW8gYnV0dG9uIGxhYmVsLCB0aGlzIGNhbiBhbHNvIGluY2x1ZGUgaHRtbCBmb3JtYXR0aW5nIHN1Y2hcclxuICAgKiBhcyBib2xkIGFuZCBpdGFsaWNzIHRvIGVtcGhhc2l6ZSB3b3JkcyBpbiB0aGUgc3RyaW5nXHJcbiAgICovXHJcbiAgbGFiZWw/OiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogVGhlIHZhbHVlIG9mIHRoZSBhIHNlbGVjdGVkIHJhZGlvIGJ1dHRvbiBtb2RlbFxyXG4gICAqL1xyXG4gIHZhbHVlPzogVDtcclxuICAvKipcclxuICAgKiBUaGUgaWNvbiB0byBkaXNwbGF5IHdpdGggdGhlIHJhZGlvIGJ1dHRvbiBvcHRpb25cclxuICAgKi9cclxuICBpY29uPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIFRoZSB0b29sdGlwIHRleHQgdG8gc2hvdyB3aGVuIGhvdmVyaW5nIG92ZXIgYW4gb3B0aW9uXHJcbiAgICovXHJcbiAgdG9vbHRpcD86IHN0cmluZztcclxufSJdfQ==
|