@energycap/components 0.31.5 → 0.32.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/energycap-components.min.css +2 -2
- package/energycap-email.min.css +1 -1
- package/esm2020/energycap-components.mjs +5 -0
- package/esm2020/lib/components.module.mjs +386 -0
- package/esm2020/lib/controls/banner/banner.component.mjs +106 -0
- package/esm2020/lib/controls/button/button.component.mjs +106 -0
- package/esm2020/lib/controls/button/copy-button.directive.mjs +65 -0
- package/esm2020/lib/controls/checkbox/checkbox.component.mjs +139 -0
- package/esm2020/lib/controls/collapsible-toggle/collapsible-toggle.component.mjs +38 -0
- package/esm2020/lib/controls/combobox/combobox.component.mjs +841 -0
- package/esm2020/lib/controls/dropdown/dropdown.component.mjs +237 -0
- package/esm2020/lib/controls/file-upload/file-upload.component.mjs +169 -0
- package/esm2020/lib/controls/form-control/form-control.component.mjs +86 -0
- package/esm2020/lib/controls/form-control-base.mjs +143 -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 +252 -0
- package/esm2020/lib/controls/help-popover/help-popover.component.mjs +28 -0
- package/esm2020/lib/controls/item-picker/item-picker.component.mjs +233 -0
- package/esm2020/lib/controls/link-button/link-button.component.mjs +11 -0
- package/esm2020/lib/controls/menu/menu.component.mjs +443 -0
- package/{esm2015/lib/controls/navigation/link-item.js → esm2020/lib/controls/navigation/link-item.mjs} +0 -0
- package/{esm2015/lib/controls/navigation/nav-group.js → esm2020/lib/controls/navigation/nav-group.mjs} +0 -0
- package/esm2020/lib/controls/navigation/nav-item-active.directive.mjs +92 -0
- package/{esm2015/lib/controls/navigation/nav-item.js → esm2020/lib/controls/navigation/nav-item.mjs} +0 -0
- package/esm2020/lib/controls/numericbox/numericbox.component.mjs +371 -0
- package/esm2020/lib/controls/popover/popover.component.mjs +84 -0
- package/{esm2015/lib/controls/radio-button/radio-button-option.js → esm2020/lib/controls/radio-button/radio-button-option.mjs} +0 -0
- package/esm2020/lib/controls/radio-button/radio-button.component.mjs +81 -0
- package/esm2020/lib/controls/select/select.component.mjs +87 -0
- package/esm2020/lib/controls/tabs/tabs.component.mjs +47 -0
- package/esm2020/lib/controls/textbox/textbox.component.mjs +154 -0
- package/{esm2015/lib/core/cache.service.js → esm2020/lib/core/cache.service.mjs} +9 -8
- package/{esm2015/lib/core/custom-validators.js → esm2020/lib/core/custom-validators.mjs} +0 -0
- package/{esm2015/lib/core/date-time-helper.js → esm2020/lib/core/date-time-helper.mjs} +0 -0
- package/esm2020/lib/core/error.service.mjs +57 -0
- package/esm2020/lib/core/scroll.service.mjs +89 -0
- package/esm2020/lib/core/telemetry-tracker.service.mjs +16 -0
- package/esm2020/lib/core/telemetry.service.mjs +38 -0
- package/esm2020/lib/core/validation-message.service.mjs +181 -0
- package/{esm2015/lib/core/validation-patterns.js → esm2020/lib/core/validation-patterns.mjs} +0 -0
- package/esm2020/lib/core/window.service.mjs +182 -0
- package/esm2020/lib/display/app-bar/app-bar.component.mjs +46 -0
- package/esm2020/lib/display/avatar/avatar.component.mjs +67 -0
- package/{esm2015/lib/display/avatar/avatar.service.js → esm2020/lib/display/avatar/avatar.service.mjs} +9 -7
- package/esm2020/lib/display/confirm/confirm.component.mjs +131 -0
- package/{esm2015/lib/display/dialog/dialog-content.js → esm2020/lib/display/dialog/dialog-content.mjs} +0 -0
- package/esm2020/lib/display/dialog/dialog-group/dialog-group.component.mjs +63 -0
- package/{esm2015/lib/display/dialog/dialog-types.js → esm2020/lib/display/dialog/dialog-types.mjs} +0 -0
- package/esm2020/lib/display/dialog/dialog.component.mjs +242 -0
- package/esm2020/lib/display/dialog/dialog.service.mjs +71 -0
- package/{esm2015/lib/display/help/help-types.js → esm2020/lib/display/help/help-types.mjs} +0 -0
- package/esm2020/lib/display/hierarchy/hierarchy-base.mjs +106 -0
- package/{esm2015/lib/display/hierarchy/hierarchy-mocks.spec.js → esm2020/lib/display/hierarchy/hierarchy-mocks.spec.mjs} +5 -9
- package/esm2020/lib/display/hierarchy/hierarchy-tree/hierarchy-tree.component.mjs +59 -0
- package/esm2020/lib/display/item-display/item-display.component.mjs +67 -0
- package/esm2020/lib/display/json-display/json-display.component.mjs +47 -0
- package/esm2020/lib/display/resizable/resizable-base.mjs +120 -0
- package/esm2020/lib/display/resizable/resizable.component.mjs +57 -0
- package/esm2020/lib/display/spinner/spinner.component.mjs +12 -0
- package/esm2020/lib/display/splash/splash.component.mjs +42 -0
- package/esm2020/lib/display/splash/splash.service.mjs +35 -0
- package/esm2020/lib/display/table/resizable-column.component.mjs +20 -0
- package/esm2020/lib/display/table/resizable-table.directive.mjs +227 -0
- package/esm2020/lib/display/table/searchable-table.component.mjs +338 -0
- package/esm2020/lib/display/table/table-detail-row.component.mjs +27 -0
- package/esm2020/lib/display/table/table-locked-column.component.mjs +58 -0
- package/esm2020/lib/display/table/table-master-header-row.component.mjs +11 -0
- package/esm2020/lib/display/table/table-master-row.component.mjs +150 -0
- package/esm2020/lib/display/table/table-pagination.component.mjs +150 -0
- package/esm2020/lib/display/table/table-selectable-row.component.mjs +235 -0
- package/esm2020/lib/display/table/table.component.mjs +244 -0
- package/esm2020/lib/display/tags/tag.mjs +15 -0
- package/esm2020/lib/display/tags/tags.component.mjs +77 -0
- package/esm2020/lib/display/toast/toast/toast.component.mjs +77 -0
- package/{esm2015/lib/display/toast/toast-types.js → esm2020/lib/display/toast/toast-types.mjs} +0 -0
- package/esm2020/lib/display/toast/toast.service.mjs +35 -0
- package/esm2020/lib/display/toast/toaster/toaster.component.mjs +114 -0
- package/esm2020/lib/display/tooltip/tooltip.component.mjs +25 -0
- package/esm2020/lib/display/tooltip/tooltip.service.mjs +63 -0
- package/esm2020/lib/display/tree/tree.component.mjs +125 -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/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 +48 -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/{esm2015/lib/shared/display.js → esm2020/lib/shared/display.mjs} +0 -0
- package/esm2020/lib/shared/form-group.helper.mjs +67 -0
- package/{esm2015/lib/shared/json-helper.js → esm2020/lib/shared/json-helper.mjs} +0 -0
- package/{esm2015/lib/shared/lodash-helper.js → esm2020/lib/shared/lodash-helper.mjs} +0 -0
- package/esm2020/lib/shared/page/page-base/page-base.component.mjs +339 -0
- package/{esm2015/lib/shared/page/page-statuses.js → esm2020/lib/shared/page/page-statuses.mjs} +0 -0
- package/esm2020/lib/shared/page/page-title/page-title.component.mjs +23 -0
- package/esm2020/lib/shared/page/page-view/page-view.component.mjs +121 -0
- package/{esm2015/lib/shared/testing/hierarchy-base-test-injector-factory.spec.js → esm2020/lib/shared/testing/hierarchy-base-test-injector-factory.spec.mjs} +0 -0
- package/esm2020/lib/shared/testing/page-base-component-test-helper.spec.mjs +30 -0
- package/{esm2015/lib/shared/testing/page-base-component-test-injector-factory.spec.js → esm2020/lib/shared/testing/page-base-component-test-injector-factory.spec.mjs} +0 -0
- package/esm2020/lib/shared/testing/public-mocks.spec.mjs +132 -0
- package/{esm2015/lib/shared/testing/spy-factory.spec.js → esm2020/lib/shared/testing/spy-factory.spec.mjs} +0 -0
- package/{esm2015/lib/shared/testing/translation-mocks.spec.js → esm2020/lib/shared/testing/translation-mocks.spec.mjs} +0 -0
- package/esm2020/lib/shared/user-preference.service.mjs +17 -0
- package/esm2020/lib/shared/wizard/wizard-base/wizard-base.component.mjs +246 -0
- package/esm2020/lib/shared/wizard/wizard-buttons/wizard-buttons.component.mjs +68 -0
- package/esm2020/lib/shared/wizard/wizard-progress/wizard-progress.component.mjs +18 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/fesm2015/energycap-components.mjs +10090 -0
- package/fesm2015/energycap-components.mjs.map +1 -0
- package/fesm2020/energycap-components.mjs +9999 -0
- package/fesm2020/energycap-components.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components.module.d.ts +72 -0
- package/lib/controls/banner/banner.component.d.ts +3 -0
- package/lib/controls/button/button.component.d.ts +3 -0
- package/lib/controls/button/copy-button.directive.d.ts +3 -0
- package/lib/controls/checkbox/checkbox.component.d.ts +3 -0
- package/lib/controls/collapsible-toggle/collapsible-toggle.component.d.ts +3 -0
- package/lib/controls/combobox/combobox.component.d.ts +5 -2
- package/lib/controls/dropdown/dropdown.component.d.ts +3 -0
- package/lib/controls/file-upload/file-upload.component.d.ts +5 -2
- package/lib/controls/form-control/form-control.component.d.ts +3 -0
- package/lib/controls/form-control-base.d.ts +3 -0
- package/lib/controls/form-control-label/form-control-label.component.d.ts +3 -0
- package/lib/controls/form-group/form-group.component.d.ts +6 -3
- package/lib/controls/help-popover/help-popover.component.d.ts +3 -0
- package/lib/controls/item-picker/item-picker.component.d.ts +5 -2
- package/lib/controls/link-button/link-button.component.d.ts +3 -0
- package/lib/controls/menu/menu.component.d.ts +3 -0
- package/lib/controls/navigation/nav-item-active.directive.d.ts +3 -0
- package/lib/controls/numericbox/numericbox.component.d.ts +5 -2
- package/lib/controls/popover/popover.component.d.ts +3 -0
- package/lib/controls/radio-button/radio-button.component.d.ts +3 -0
- package/lib/controls/select/select.component.d.ts +3 -0
- package/lib/controls/tabs/tabs.component.d.ts +3 -0
- package/lib/controls/textbox/textbox.component.d.ts +3 -0
- package/lib/core/cache.service.d.ts +3 -0
- package/lib/core/error.service.d.ts +3 -0
- package/lib/core/scroll.service.d.ts +3 -0
- package/lib/core/telemetry-tracker.service.d.ts +3 -0
- package/lib/core/telemetry.service.d.ts +3 -0
- package/lib/core/validation-message.service.d.ts +3 -0
- package/lib/core/window.service.d.ts +3 -0
- package/lib/display/app-bar/app-bar.component.d.ts +3 -0
- package/lib/display/avatar/avatar.component.d.ts +3 -0
- package/lib/display/avatar/avatar.service.d.ts +3 -0
- package/lib/display/confirm/confirm.component.d.ts +5 -2
- package/lib/display/dialog/dialog-group/dialog-group.component.d.ts +3 -0
- package/lib/display/dialog/dialog.component.d.ts +3 -0
- package/lib/display/dialog/dialog.service.d.ts +3 -0
- package/lib/display/hierarchy/hierarchy-base.d.ts +3 -0
- package/lib/display/hierarchy/hierarchy-tree/hierarchy-tree.component.d.ts +3 -0
- package/lib/display/item-display/item-display.component.d.ts +3 -0
- package/lib/display/json-display/json-display.component.d.ts +5 -2
- package/lib/display/resizable/resizable-base.d.ts +3 -0
- package/lib/display/resizable/resizable.component.d.ts +3 -0
- package/lib/display/spinner/spinner.component.d.ts +3 -0
- package/lib/display/splash/splash.component.d.ts +3 -0
- package/lib/display/splash/splash.service.d.ts +3 -0
- package/lib/display/table/resizable-column.component.d.ts +3 -0
- package/lib/display/table/resizable-table.directive.d.ts +3 -0
- package/lib/display/table/searchable-table.component.d.ts +6 -3
- package/lib/display/table/table-detail-row.component.d.ts +3 -0
- package/lib/display/table/table-locked-column.component.d.ts +3 -0
- package/lib/display/table/table-master-header-row.component.d.ts +3 -0
- package/lib/display/table/table-master-row.component.d.ts +3 -0
- package/lib/display/table/table-pagination.component.d.ts +3 -0
- package/lib/display/table/table-selectable-row.component.d.ts +5 -2
- package/lib/display/table/table.component.d.ts +3 -0
- package/lib/display/tags/tags.component.d.ts +3 -0
- package/lib/display/toast/toast/toast.component.d.ts +3 -0
- package/lib/display/toast/toast.service.d.ts +3 -0
- package/lib/display/toast/toaster/toaster.component.d.ts +3 -0
- package/lib/display/tooltip/tooltip.component.d.ts +3 -0
- package/lib/display/tooltip/tooltip.service.d.ts +3 -0
- package/lib/display/tree/tree.component.d.ts +3 -0
- package/lib/display/view-overlay/view-overlay.component.d.ts +3 -0
- package/lib/shared/directives/click-area-for/click-area-for.directive.d.ts +3 -0
- package/lib/shared/directives/if-viewport-width/if-viewport-width.directive.d.ts +3 -0
- package/lib/shared/directives/popup/popup-container.directive.d.ts +3 -0
- package/lib/shared/display/pipes/date-display.pipe.d.ts +3 -0
- package/lib/shared/display/pipes/highlight-text.pipe.d.ts +3 -0
- package/lib/shared/display/pipes/relative-date.pipe.d.ts +3 -0
- package/lib/shared/display/pipes/row-count.pipe.d.ts +3 -0
- package/lib/shared/display/pipes/time-display.pipe.d.ts +3 -0
- package/lib/shared/form-group.helper.d.ts +5 -2
- package/lib/shared/page/page-base/page-base.component.d.ts +5 -2
- package/lib/shared/page/page-title/page-title.component.d.ts +3 -0
- package/lib/shared/page/page-view/page-view.component.d.ts +3 -0
- package/lib/shared/testing/public-mocks.spec.d.ts +7 -0
- package/lib/shared/user-preference.service.d.ts +3 -0
- package/lib/shared/wizard/wizard-base/wizard-base.component.d.ts +3 -0
- package/lib/shared/wizard/wizard-buttons/wizard-buttons.component.d.ts +3 -0
- package/lib/shared/wizard/wizard-progress/wizard-progress.component.d.ts +3 -0
- package/package.json +27 -15
- package/src/styles/_functions.scss +6 -4
- package/src/styles/_icons.scss +1 -1
- package/src/styles/mixins/_control-base.scss +2 -2
- package/src/styles/mixins/_form-control-base.scss +3 -1
- package/src/styles/mixins/_spinner-base.scss +3 -1
- package/bundles/energycap-components.umd.js +0 -10646
- package/bundles/energycap-components.umd.js.map +0 -1
- package/bundles/energycap-components.umd.min.js +0 -17
- package/bundles/energycap-components.umd.min.js.map +0 -1
- package/energycap-components.d.ts +0 -7
- package/energycap-components.metadata.json +0 -1
- package/esm2015/energycap-components.js +0 -8
- package/esm2015/lib/components.module.js +0 -238
- package/esm2015/lib/controls/banner/banner.component.js +0 -94
- package/esm2015/lib/controls/button/button.component.js +0 -89
- package/esm2015/lib/controls/button/copy-button.directive.js +0 -63
- package/esm2015/lib/controls/checkbox/checkbox.component.js +0 -137
- package/esm2015/lib/controls/collapsible-toggle/collapsible-toggle.component.js +0 -35
- package/esm2015/lib/controls/combobox/combobox.component.js +0 -819
- package/esm2015/lib/controls/dropdown/dropdown.component.js +0 -207
- package/esm2015/lib/controls/file-upload/file-upload.component.js +0 -172
- package/esm2015/lib/controls/form-control/form-control.component.js +0 -65
- package/esm2015/lib/controls/form-control-base.js +0 -140
- package/esm2015/lib/controls/form-control-label/form-control-label.component.js +0 -139
- package/esm2015/lib/controls/form-group/form-group.component.js +0 -254
- package/esm2015/lib/controls/help-popover/help-popover.component.js +0 -22
- package/esm2015/lib/controls/item-picker/item-picker.component.js +0 -216
- package/esm2015/lib/controls/link-button/link-button.component.js +0 -12
- package/esm2015/lib/controls/menu/menu.component.js +0 -424
- package/esm2015/lib/controls/navigation/nav-item-active.directive.js +0 -86
- package/esm2015/lib/controls/numericbox/numericbox.component.js +0 -362
- package/esm2015/lib/controls/popover/popover.component.js +0 -85
- package/esm2015/lib/controls/radio-button/radio-button.component.js +0 -78
- package/esm2015/lib/controls/select/select.component.js +0 -89
- package/esm2015/lib/controls/tabs/tabs.component.js +0 -42
- package/esm2015/lib/controls/textbox/textbox.component.js +0 -149
- package/esm2015/lib/core/error.service.js +0 -56
- package/esm2015/lib/core/scroll.service.js +0 -88
- package/esm2015/lib/core/telemetry-tracker.service.js +0 -14
- package/esm2015/lib/core/telemetry.service.js +0 -40
- package/esm2015/lib/core/validation-message.service.js +0 -185
- package/esm2015/lib/core/window.service.js +0 -191
- package/esm2015/lib/display/app-bar/app-bar.component.js +0 -42
- package/esm2015/lib/display/avatar/avatar.component.js +0 -73
- package/esm2015/lib/display/confirm/confirm.component.js +0 -127
- package/esm2015/lib/display/dialog/dialog-group/dialog-group.component.js +0 -65
- package/esm2015/lib/display/dialog/dialog.component.js +0 -229
- package/esm2015/lib/display/dialog/dialog.service.js +0 -69
- package/esm2015/lib/display/hierarchy/hierarchy-base.js +0 -106
- package/esm2015/lib/display/hierarchy/hierarchy-tree/hierarchy-tree.component.js +0 -58
- package/esm2015/lib/display/item-display/item-display.component.js +0 -57
- package/esm2015/lib/display/json-display/json-display.component.js +0 -44
- package/esm2015/lib/display/resizable/resizable-base.js +0 -119
- package/esm2015/lib/display/resizable/resizable.component.js +0 -57
- package/esm2015/lib/display/spinner/spinner.component.js +0 -12
- package/esm2015/lib/display/splash/splash.component.js +0 -45
- package/esm2015/lib/display/splash/splash.service.js +0 -34
- package/esm2015/lib/display/table/resizable-column.component.js +0 -23
- package/esm2015/lib/display/table/resizable-table.directive.js +0 -223
- package/esm2015/lib/display/table/searchable-table.component.js +0 -303
- package/esm2015/lib/display/table/table-detail-row.component.js +0 -21
- package/esm2015/lib/display/table/table-locked-column.component.js +0 -53
- package/esm2015/lib/display/table/table-master-header-row.component.js +0 -11
- package/esm2015/lib/display/table/table-master-row.component.js +0 -141
- package/esm2015/lib/display/table/table-pagination.component.js +0 -146
- package/esm2015/lib/display/table/table-selectable-row.component.js +0 -216
- package/esm2015/lib/display/table/table.component.js +0 -210
- package/esm2015/lib/display/tags/tag.js +0 -15
- package/esm2015/lib/display/tags/tags.component.js +0 -73
- package/esm2015/lib/display/toast/toast/toast.component.js +0 -70
- package/esm2015/lib/display/toast/toast.service.js +0 -34
- package/esm2015/lib/display/toast/toaster/toaster.component.js +0 -117
- package/esm2015/lib/display/tooltip/tooltip.component.js +0 -24
- package/esm2015/lib/display/tooltip/tooltip.service.js +0 -64
- package/esm2015/lib/display/tree/tree.component.js +0 -100
- package/esm2015/lib/display/view-overlay/view-overlay.component.js +0 -50
- package/esm2015/lib/shared/directives/click-area-for/click-area-for.directive.js +0 -25
- package/esm2015/lib/shared/directives/if-viewport-width/if-viewport-width.directive.js +0 -112
- package/esm2015/lib/shared/directives/popup/popup-container.directive.js +0 -160
- package/esm2015/lib/shared/display/pipes/date-display.pipe.js +0 -49
- package/esm2015/lib/shared/display/pipes/highlight-text.pipe.js +0 -26
- package/esm2015/lib/shared/display/pipes/relative-date.pipe.js +0 -49
- package/esm2015/lib/shared/display/pipes/row-count.pipe.js +0 -47
- package/esm2015/lib/shared/display/pipes/time-display.pipe.js +0 -40
- package/esm2015/lib/shared/form-group.helper.js +0 -65
- package/esm2015/lib/shared/page/page-base/page-base.component.js +0 -356
- package/esm2015/lib/shared/page/page-title/page-title.component.js +0 -19
- package/esm2015/lib/shared/page/page-view/page-view.component.js +0 -94
- package/esm2015/lib/shared/testing/page-base-component-test-helper.spec.js +0 -35
- package/esm2015/lib/shared/testing/public-mocks.spec.js +0 -126
- package/esm2015/lib/shared/user-preference.service.js +0 -15
- package/esm2015/lib/shared/wizard/wizard-base/wizard-base.component.js +0 -260
- package/esm2015/lib/shared/wizard/wizard-buttons/wizard-buttons.component.js +0 -54
- package/esm2015/lib/shared/wizard/wizard-progress/wizard-progress.component.js +0 -18
- package/fesm2015/energycap-components.js +0 -9638
- package/fesm2015/energycap-components.js.map +0 -1
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { Component, Input, HostBinding, Output, EventEmitter, ViewChild } from '@angular/core';
|
|
2
|
+
import { MenuComponent } from '../../controls/menu/menu.component';
|
|
3
|
+
import { HierarchyTreeComponent } from '../hierarchy/hierarchy-tree/hierarchy-tree.component';
|
|
4
|
+
import { Overlay } from '../view-overlay/view-overlay.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "../view-overlay/view-overlay.component";
|
|
8
|
+
import * as i3 from "../../controls/menu/menu.component";
|
|
9
|
+
import * as i4 from "../../controls/dropdown/dropdown.component";
|
|
10
|
+
import * as i5 from "../hierarchy/hierarchy-tree/hierarchy-tree.component";
|
|
11
|
+
import * as i6 from "@ngx-translate/core";
|
|
12
|
+
export class TreeComponent {
|
|
13
|
+
constructor() {
|
|
14
|
+
/** The value of the host elements id attribute */
|
|
15
|
+
this.attrId = '';
|
|
16
|
+
this._id = '';
|
|
17
|
+
/** The tree's title displayed in the header */
|
|
18
|
+
this.treeTitle = '';
|
|
19
|
+
/** Hides the tree header when set to true */
|
|
20
|
+
this.hideTreeHeader = false;
|
|
21
|
+
/** Used when the tree is in menu mode to tell the menu if it should maintain the selected item
|
|
22
|
+
* Useful in side nav components where this tree component may exist alongside other trees or menus
|
|
23
|
+
* used for navigation. If this tree is in menu mode you would want this set to false so when you select an item
|
|
24
|
+
* from a sibling navigation element the selection will not be maintained.
|
|
25
|
+
*/
|
|
26
|
+
this.treeMenuMaintainSelectedItem = true;
|
|
27
|
+
/** Tree overlay */
|
|
28
|
+
this.status = new Overlay('hasData');
|
|
29
|
+
/** Display the tree items with a MenuComponent or a HierarchyTreeComponent */
|
|
30
|
+
this.type = 'hierarchy';
|
|
31
|
+
/** Tree dropdown menu overlay */
|
|
32
|
+
this.menuStatus = new Overlay('hasData');
|
|
33
|
+
/** The menu item template */
|
|
34
|
+
this.menuTemplateType = "checkAndLabel";
|
|
35
|
+
/**
|
|
36
|
+
* When true, the space for the icon is preserved for menu items that do not have icons.
|
|
37
|
+
* Only applicable for iconAndLabel menus. Not applicable to hierarchy trees.
|
|
38
|
+
*/
|
|
39
|
+
this.preserveIconSpace = false;
|
|
40
|
+
/** Emits the item currently selected item in the tree */
|
|
41
|
+
this.treeSelection = new EventEmitter();
|
|
42
|
+
/** Emits when a hierarchy tree item is expanded as a hook to load the item's children */
|
|
43
|
+
this.getTreeItemChildren = new EventEmitter();
|
|
44
|
+
this.templateType = 'label';
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* The ID of the component, bound to the host element's id attribute and passed
|
|
48
|
+
* to child components
|
|
49
|
+
*/
|
|
50
|
+
set id(value) {
|
|
51
|
+
this._id = value;
|
|
52
|
+
this.attrId = value;
|
|
53
|
+
}
|
|
54
|
+
;
|
|
55
|
+
get id() {
|
|
56
|
+
return this._id;
|
|
57
|
+
}
|
|
58
|
+
/** Emits when a tree item is selected */
|
|
59
|
+
onItemSelected(item) {
|
|
60
|
+
this.treeSelection.emit(item);
|
|
61
|
+
}
|
|
62
|
+
/** Emits when a hierarchy tree item is expanded to load the item's children */
|
|
63
|
+
onHierarchyGetItemChildren(item) {
|
|
64
|
+
this.getTreeItemChildren.emit(item);
|
|
65
|
+
}
|
|
66
|
+
/** Scroll to the tree item that is currently selected. */
|
|
67
|
+
scrollToSelectedItem() {
|
|
68
|
+
if (this.menuComponent) {
|
|
69
|
+
this.menuComponent.scrollToSelectedItem();
|
|
70
|
+
}
|
|
71
|
+
if (this.hierarchyTreeComponent) {
|
|
72
|
+
this.hierarchyTreeComponent.scrollToSelectedItem();
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
TreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TreeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
77
|
+
TreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TreeComponent, selector: "ec-tree", inputs: { id: "id", treeTitle: "treeTitle", hideTreeHeader: "hideTreeHeader", treeItems: "treeItems", treeHierarchyHideRootNode: "treeHierarchyHideRootNode", treeHierarchy: "treeHierarchy", treeMenuMaintainSelectedItem: "treeMenuMaintainSelectedItem", customTreeMenuTemplate: "customTreeMenuTemplate", status: "status", type: "type", menuItems: "menuItems", menuStatus: "menuStatus", menuTemplateType: "menuTemplateType", preserveIconSpace: "preserveIconSpace", templateType: "templateType" }, outputs: { treeSelection: "treeSelection", getTreeItemChildren: "getTreeItemChildren" }, host: { properties: { "attr.id": "this.attrId" } }, viewQueries: [{ propertyName: "menuComponent", first: true, predicate: MenuComponent, descendants: true }, { propertyName: "hierarchyTreeComponent", first: true, predicate: HierarchyTreeComponent, descendants: true }], ngImport: i0, template: "<header *ngIf=\"!hideTreeHeader\"\r\n class=\"flex-shrink d-flex align-items-center border-bottom bg-content pl-2 pr-1\">\r\n <h2 id=\"{{id}}_title\"\r\n class=\"flex-grow mr-2 text-heading-1\">{{treeTitle | translate}}</h2>\r\n <ec-dropdown *ngIf=\"menuItems?.length\"\r\n id=\"{{id}}_dropdown\"\r\n class=\"flex-shrink\"\r\n icon=\"icon-menu\"\r\n [menuTemplateType]=\"menuTemplateType\"\r\n menuPosition=\"left\"\r\n [status]=\"menuStatus\"\r\n [popupFixed]=\"true\"\r\n [showArrow]=\"false\"\r\n [menuMinWidth]=\"240\"\r\n [items]=\"menuItems\">\r\n </ec-dropdown>\r\n</header>\r\n\r\n<div class=\"flex-grow d-flex\"\r\n ecOverlay\r\n [status]=\"status?.status\"\r\n [displayAsMask]=\"true\">\r\n <ng-container *ngIf=\"type === 'menu'\">\r\n <ec-menu [id]=\"id\"\r\n [items]=\"treeItems\"\r\n [templateType]=\"templateType\"\r\n [maintainSelectedItem]=\"treeMenuMaintainSelectedItem\"\r\n [truncateItems]=\"true\"\r\n (selectedChanged)=\"onItemSelected($event)\"\r\n [customMenuTemplate]=\"customTreeMenuTemplate ? customTreeMenuTemplate : undefined\"\r\n [preserveIconSpace]=\"preserveIconSpace\"\r\n class=\"flex-grow\">\r\n </ec-menu>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"type === 'hierarchy'\">\r\n <ec-hierarchy-tree [id]=\"id\"\r\n [rootNode]=\"treeHierarchy\"\r\n [hideRootNode]=\"treeHierarchyHideRootNode\"\r\n (getItemChildren)=\"onHierarchyGetItemChildren($event)\"\r\n (itemSelected)=\"onItemSelected($event)\"\r\n class=\"flex-grow d-flex\">\r\n </ec-hierarchy-tree>\r\n </ng-container>\r\n</div>", styles: [":host{display:flex;flex-direction:column}header{height:3rem}ec-dropdown.fill{height:3rem;width:3rem}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ViewOverlayComponent, selector: "[ecOverlay]", inputs: ["status", "message", "action", "noDataTemplate", "displayAsMask", "overlayClassList"] }, { kind: "component", type: i3.MenuComponent, selector: "ec-menu", inputs: ["id", "items", "selected", "parent", "templateType", "customMenuTemplate", "title", "showNoItems", "noDataText", "enableKeyNav", "highlightedItem", "maintainSelectedItem", "truncateItems", "preserveIconSpace"], outputs: ["selectedChanged", "menuClosed"] }, { kind: "component", type: i4.DropdownComponent, selector: "ec-dropdown", inputs: ["id", "autofocus", "status", "disabled", "label", "icon", "buttonType", "buttonAlignment", "buttonTitle", "tabindex", "showArrow", "items", "menuTemplateType", "menuTitle", "menuHeight", "menuWidth", "menuMinWidth", "menuPosition", "menuFooter", "popupFixed", "buttonCustomTemplate", "pending"], outputs: ["itemSelected", "popupOpened"] }, { kind: "component", type: i5.HierarchyTreeComponent, selector: "ec-hierarchy-tree", inputs: ["id", "hideRootNode"], outputs: ["itemSelected"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] });
|
|
78
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TreeComponent, decorators: [{
|
|
79
|
+
type: Component,
|
|
80
|
+
args: [{ selector: 'ec-tree', template: "<header *ngIf=\"!hideTreeHeader\"\r\n class=\"flex-shrink d-flex align-items-center border-bottom bg-content pl-2 pr-1\">\r\n <h2 id=\"{{id}}_title\"\r\n class=\"flex-grow mr-2 text-heading-1\">{{treeTitle | translate}}</h2>\r\n <ec-dropdown *ngIf=\"menuItems?.length\"\r\n id=\"{{id}}_dropdown\"\r\n class=\"flex-shrink\"\r\n icon=\"icon-menu\"\r\n [menuTemplateType]=\"menuTemplateType\"\r\n menuPosition=\"left\"\r\n [status]=\"menuStatus\"\r\n [popupFixed]=\"true\"\r\n [showArrow]=\"false\"\r\n [menuMinWidth]=\"240\"\r\n [items]=\"menuItems\">\r\n </ec-dropdown>\r\n</header>\r\n\r\n<div class=\"flex-grow d-flex\"\r\n ecOverlay\r\n [status]=\"status?.status\"\r\n [displayAsMask]=\"true\">\r\n <ng-container *ngIf=\"type === 'menu'\">\r\n <ec-menu [id]=\"id\"\r\n [items]=\"treeItems\"\r\n [templateType]=\"templateType\"\r\n [maintainSelectedItem]=\"treeMenuMaintainSelectedItem\"\r\n [truncateItems]=\"true\"\r\n (selectedChanged)=\"onItemSelected($event)\"\r\n [customMenuTemplate]=\"customTreeMenuTemplate ? customTreeMenuTemplate : undefined\"\r\n [preserveIconSpace]=\"preserveIconSpace\"\r\n class=\"flex-grow\">\r\n </ec-menu>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"type === 'hierarchy'\">\r\n <ec-hierarchy-tree [id]=\"id\"\r\n [rootNode]=\"treeHierarchy\"\r\n [hideRootNode]=\"treeHierarchyHideRootNode\"\r\n (getItemChildren)=\"onHierarchyGetItemChildren($event)\"\r\n (itemSelected)=\"onItemSelected($event)\"\r\n class=\"flex-grow d-flex\">\r\n </ec-hierarchy-tree>\r\n </ng-container>\r\n</div>", styles: [":host{display:flex;flex-direction:column}header{height:3rem}ec-dropdown.fill{height:3rem;width:3rem}\n"] }]
|
|
81
|
+
}], ctorParameters: function () { return []; }, propDecorators: { attrId: [{
|
|
82
|
+
type: HostBinding,
|
|
83
|
+
args: ['attr.id']
|
|
84
|
+
}], id: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], treeTitle: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], hideTreeHeader: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], treeItems: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], treeHierarchyHideRootNode: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], treeHierarchy: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], treeMenuMaintainSelectedItem: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], customTreeMenuTemplate: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], status: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], type: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], menuItems: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], menuStatus: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], menuTemplateType: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], preserveIconSpace: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], treeSelection: [{
|
|
113
|
+
type: Output
|
|
114
|
+
}], getTreeItemChildren: [{
|
|
115
|
+
type: Output
|
|
116
|
+
}], menuComponent: [{
|
|
117
|
+
type: ViewChild,
|
|
118
|
+
args: [MenuComponent]
|
|
119
|
+
}], hierarchyTreeComponent: [{
|
|
120
|
+
type: ViewChild,
|
|
121
|
+
args: [HierarchyTreeComponent]
|
|
122
|
+
}], templateType: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}] } });
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/display/tree/tree.component.ts","../../../../../../projects/components/src/lib/display/tree/tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, HostBinding, Output, EventEmitter, ViewChild, TemplateRef } from '@angular/core';\r\nimport { MenuComponent, MenuItem, MenuTemplateType } from '../../controls/menu/menu.component';\r\nimport { HierarchyItem } from '../hierarchy/hierarchy-base';\r\nimport { HierarchyTreeComponent } from '../hierarchy/hierarchy-tree/hierarchy-tree.component';\r\nimport { Overlay } from '../view-overlay/view-overlay.component';\r\n\r\nexport type TreeType = 'hierarchy' | 'menu';\r\n\r\n@Component({\r\n  selector: 'ec-tree',\r\n  templateUrl: './tree.component.html',\r\n  styleUrls: ['./tree.component.scss']\r\n})\r\nexport class TreeComponent {\r\n\r\n  /** The value of the host elements id attribute */\r\n  @HostBinding('attr.id') public attrId: string = '';\r\n\r\n  /**\r\n   * The ID of the component, bound to the host element's id attribute and passed\r\n   * to child components\r\n   */\r\n  @Input()\r\n  public set id(value: string) {\r\n    this._id = value;\r\n    this.attrId = value;\r\n  };\r\n  public get id(): string {\r\n    return this._id;\r\n  }\r\n  private _id: string = '';\r\n\r\n  /** The tree's title displayed in the header */\r\n  @Input() public treeTitle: string = '';\r\n\r\n  /** Hides the tree header when set to true */\r\n  @Input() public hideTreeHeader?: boolean = false;\r\n\r\n  /** Items to display in the tree when type is 'menu' */\r\n  @Input() public treeItems?: MenuItem[];\r\n\r\n  /** Hide the root tree item when type is 'hierarchy' */\r\n  @Input() public treeHierarchyHideRootNode?: boolean;\r\n\r\n  /** Items to display in the tree when type is 'hierarchy' */\r\n  @Input() public treeHierarchy?: HierarchyItem;\r\n\r\n  /** Used when the tree is in menu mode to tell the menu if it should maintain the selected item\r\n   *  Useful in side nav components where this tree component may exist alongside other trees or menus\r\n   *  used for navigation. If this tree is in menu mode you would want this set to false so when you select an item\r\n   *  from a sibling navigation element the selection will not be maintained.\r\n   */\r\n  @Input() public treeMenuMaintainSelectedItem: boolean = true;\r\n\r\n  /** Used when a custom template is needed for the menu items when the tree is in menu mode */\r\n  @Input() public customTreeMenuTemplate?: TemplateRef<any>;\r\n\r\n  /** Tree overlay */\r\n  @Input() public status?: Overlay = new Overlay('hasData');\r\n\r\n  /** Display the tree items with a MenuComponent or a HierarchyTreeComponent */\r\n  @Input() public type?: TreeType = 'hierarchy';\r\n\r\n  /** Items to display in the dropdown menu */\r\n  @Input() public menuItems?: MenuItem[];\r\n\r\n  /** Tree dropdown menu overlay */\r\n  @Input() public menuStatus?: Overlay = new Overlay('hasData');\r\n\r\n  /** The menu item template */\r\n  @Input() public menuTemplateType?: MenuTemplateType = \"checkAndLabel\";\r\n\r\n  /** \r\n   * When true, the space for the icon is preserved for menu items that do not have icons.\r\n   * Only applicable for iconAndLabel menus. Not applicable to hierarchy trees.\r\n   */\r\n  @Input() public preserveIconSpace: boolean = false;\r\n\r\n  /** Emits the item currently selected item in the tree */\r\n  @Output() public treeSelection: EventEmitter<MenuItem | HierarchyItem> = new EventEmitter();\r\n\r\n  /** Emits when a hierarchy tree item is expanded as a hook to load the item's children */\r\n  @Output() public getTreeItemChildren: EventEmitter<HierarchyItem> = new EventEmitter();\r\n\r\n  /** Reference to the MenuComponent instance in the template */\r\n  @ViewChild(MenuComponent) public menuComponent?: MenuComponent;\r\n\r\n  /** Reference to the HierarchyTreeComponent instance in the template */\r\n  @ViewChild(HierarchyTreeComponent) public hierarchyTreeComponent?: HierarchyTreeComponent;\r\n\r\n  @Input() public templateType: MenuTemplateType = 'label';\r\n  \r\n  constructor() { }\r\n\r\n  /** Emits when a tree item is selected */\r\n  public onItemSelected(item: MenuItem | HierarchyItem) {\r\n    this.treeSelection.emit(item);\r\n  }\r\n\r\n  /** Emits when a hierarchy tree item is expanded to load the item's children */\r\n  public onHierarchyGetItemChildren(item: HierarchyItem) {\r\n    this.getTreeItemChildren.emit(item);\r\n  }\r\n\r\n  /** Scroll to the tree item that is currently selected. */\r\n  public scrollToSelectedItem() {\r\n    if (this.menuComponent) {\r\n      this.menuComponent.scrollToSelectedItem();\r\n    }\r\n\r\n    if (this.hierarchyTreeComponent) {\r\n      this.hierarchyTreeComponent.scrollToSelectedItem();\r\n    }\r\n  }\r\n}\r\n","<header *ngIf=\"!hideTreeHeader\"\r\n        class=\"flex-shrink d-flex align-items-center border-bottom bg-content pl-2 pr-1\">\r\n  <h2 id=\"{{id}}_title\"\r\n      class=\"flex-grow mr-2 text-heading-1\">{{treeTitle | translate}}</h2>\r\n  <ec-dropdown *ngIf=\"menuItems?.length\"\r\n               id=\"{{id}}_dropdown\"\r\n               class=\"flex-shrink\"\r\n               icon=\"icon-menu\"\r\n               [menuTemplateType]=\"menuTemplateType\"\r\n               menuPosition=\"left\"\r\n               [status]=\"menuStatus\"\r\n               [popupFixed]=\"true\"\r\n               [showArrow]=\"false\"\r\n               [menuMinWidth]=\"240\"\r\n               [items]=\"menuItems\">\r\n  </ec-dropdown>\r\n</header>\r\n\r\n<div class=\"flex-grow d-flex\"\r\n     ecOverlay\r\n     [status]=\"status?.status\"\r\n     [displayAsMask]=\"true\">\r\n  <ng-container *ngIf=\"type === 'menu'\">\r\n    <ec-menu [id]=\"id\"\r\n             [items]=\"treeItems\"\r\n             [templateType]=\"templateType\"\r\n             [maintainSelectedItem]=\"treeMenuMaintainSelectedItem\"\r\n             [truncateItems]=\"true\"\r\n             (selectedChanged)=\"onItemSelected($event)\"\r\n             [customMenuTemplate]=\"customTreeMenuTemplate ? customTreeMenuTemplate : undefined\"\r\n             [preserveIconSpace]=\"preserveIconSpace\"\r\n             class=\"flex-grow\">\r\n    </ec-menu>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"type === 'hierarchy'\">\r\n    <ec-hierarchy-tree [id]=\"id\"\r\n                       [rootNode]=\"treeHierarchy\"\r\n                       [hideRootNode]=\"treeHierarchyHideRootNode\"\r\n                       (getItemChildren)=\"onHierarchyGetItemChildren($event)\"\r\n                       (itemSelected)=\"onItemSelected($event)\"\r\n                       class=\"flex-grow d-flex\">\r\n    </ec-hierarchy-tree>\r\n  </ng-container>\r\n</div>"]}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../../controls/button/button.component";
|
|
5
|
+
import * as i3 from "../spinner/spinner.component";
|
|
6
|
+
import * as i4 from "@ngx-translate/core";
|
|
7
|
+
export class Overlay {
|
|
8
|
+
constructor(status, message) {
|
|
9
|
+
this.status = 'hasData';
|
|
10
|
+
this.message = '';
|
|
11
|
+
this.setStatus(status, message);
|
|
12
|
+
}
|
|
13
|
+
setStatus(status, message, action, noDataTemplate, overlayClassList) {
|
|
14
|
+
this.status = status;
|
|
15
|
+
this.message = message || '';
|
|
16
|
+
this.action = action || undefined;
|
|
17
|
+
this.noDataTemplate = noDataTemplate || undefined;
|
|
18
|
+
this.overlayClassList = overlayClassList || '';
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Wraps content in order to show pending, error, and no data states with an optional message/noDataTemplate
|
|
23
|
+
*/
|
|
24
|
+
export class ViewOverlayComponent {
|
|
25
|
+
constructor() {
|
|
26
|
+
this.status = 'hasData';
|
|
27
|
+
}
|
|
28
|
+
setStatus(status, message, action, noDataTemplate) {
|
|
29
|
+
this.status = status;
|
|
30
|
+
this.message = message || '';
|
|
31
|
+
this.action = action || undefined;
|
|
32
|
+
this.noDataTemplate = noDataTemplate || undefined;
|
|
33
|
+
}
|
|
34
|
+
actionClicked(event) {
|
|
35
|
+
if (this.action && this.action.onClick) {
|
|
36
|
+
this.action.onClick(event);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
ViewOverlayComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ViewOverlayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
41
|
+
ViewOverlayComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ViewOverlayComponent, selector: "[ecOverlay]", inputs: { status: "status", message: "message", action: "action", noDataTemplate: "noDataTemplate", displayAsMask: "displayAsMask", overlayClassList: "overlayClassList" }, ngImport: i0, template: "<!-- Transcluded Content -->\r\n<ng-content *ngIf=\"displayAsMask || (!displayAsMask && status === 'hasData')\"></ng-content>\r\n<!--Used by GI tests to know the overlay status whether we use ngIf or mask version. No visual impact-->\r\n<span [hidden]=\"true\"\r\n\t class=\"overlay-status-{{status}}\"></span>\r\n<!-- Overlay goes last so it is rendered on top of preceding content due to source order -->\r\n<div *ngIf=\"status !== 'hasData'\"\r\n\t class=\"overlay flex-grow {{overlayClassList}}\"\r\n\t [ngClass]=\"{'not-mask': !displayAsMask,\r\n\t\t\t\t'overlay-error': status === 'error',\r\n\t\t\t\t'overlay-nodata': status === 'noData',\r\n\t\t\t\t'overlay-pending': status === 'pending'}\">\r\n\r\n\t<!--Pending Spinner-->\r\n\t<ec-spinner [hidden]=\"status !== 'pending'\"></ec-spinner>\r\n\r\n\t<ng-template [ngIf]=\"status === 'noData' && noDataTemplate\">\r\n\t\t<ng-container *ngTemplateOutlet=\"noDataTemplate\"></ng-container>\r\n\t</ng-template>\r\n\r\n\t<ng-container *ngIf=\"(status === 'noData' && !noDataTemplate) || status !== 'noData'\">\r\n\t\t<!--Status Message-->\r\n\t\t<div id=\"statusMessage\"\r\n\t\t\t class=\"message\"\r\n\t\t\t *ngIf=\"message\"\r\n\t\t\t [ngClass]=\"{'error': status === 'error', 'mt-1': status === 'pending'}\"\r\n\t\t\t [innerHtml]=\"message | translate\">\r\n\t\t</div>\r\n\r\n\t\t<!-- Action -->\r\n\t\t<ec-button type=\"common\"\r\n\t\t\t\t class=\"mt-3\"\r\n\t\t\t\t *ngIf=\"action?.onClick\"\r\n\t\t\t\t [icon]=\"action?.icon\"\r\n\t\t\t\t (clicked)=\"actionClicked($event)\"\r\n\t\t\t\t [label]=\"action?.label\"\r\n\t\t\t\t [hidden]=\"status === 'pending'\">\r\n\t\t</ec-button>\r\n\t</ng-container>\r\n\r\n</div>", styles: [":host{position:relative}:host(.bg-body)>.overlay{background-color:var(--ec-background-color-body)}:host(.bg-body).is-translucent>.overlay{background-color:var(--ec-background-color-overlay)}:host(.bg-content)>.overlay{background-color:var(--ec-background-color)}:host(.bg-content).is-translucent>.overlay{background-color:var(--ec-background-color-overlay)}.overlay{align-items:center;background-color:var(--ec-background-color);display:flex;flex-direction:column;justify-content:center;padding:3rem 4rem;z-index:var(--ec-z-index-overlay);right:0;top:0;position:absolute;bottom:0;left:0}.overlay.not-mask{position:relative;min-height:100%}.message{color:var(--ec-color-secondary-dark);font-size:var(--ec-font-size-title)}.message.error{color:var(--ec-color-danger);font-size:var(--ec-font-size-title)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ButtonComponent, selector: "ec-button", inputs: ["id", "disabled", "icon", "label", "badge", "tabindex", "type", "pending", "pendingIcon", "customTemplate", "isSubmit", "autofocus"], outputs: ["clicked"] }, { kind: "component", type: i3.SpinnerComponent, selector: "ec-spinner" }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] });
|
|
42
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ViewOverlayComponent, decorators: [{
|
|
43
|
+
type: Component,
|
|
44
|
+
args: [{ selector: '[ecOverlay]', template: "<!-- Transcluded Content -->\r\n<ng-content *ngIf=\"displayAsMask || (!displayAsMask && status === 'hasData')\"></ng-content>\r\n<!--Used by GI tests to know the overlay status whether we use ngIf or mask version. No visual impact-->\r\n<span [hidden]=\"true\"\r\n\t class=\"overlay-status-{{status}}\"></span>\r\n<!-- Overlay goes last so it is rendered on top of preceding content due to source order -->\r\n<div *ngIf=\"status !== 'hasData'\"\r\n\t class=\"overlay flex-grow {{overlayClassList}}\"\r\n\t [ngClass]=\"{'not-mask': !displayAsMask,\r\n\t\t\t\t'overlay-error': status === 'error',\r\n\t\t\t\t'overlay-nodata': status === 'noData',\r\n\t\t\t\t'overlay-pending': status === 'pending'}\">\r\n\r\n\t<!--Pending Spinner-->\r\n\t<ec-spinner [hidden]=\"status !== 'pending'\"></ec-spinner>\r\n\r\n\t<ng-template [ngIf]=\"status === 'noData' && noDataTemplate\">\r\n\t\t<ng-container *ngTemplateOutlet=\"noDataTemplate\"></ng-container>\r\n\t</ng-template>\r\n\r\n\t<ng-container *ngIf=\"(status === 'noData' && !noDataTemplate) || status !== 'noData'\">\r\n\t\t<!--Status Message-->\r\n\t\t<div id=\"statusMessage\"\r\n\t\t\t class=\"message\"\r\n\t\t\t *ngIf=\"message\"\r\n\t\t\t [ngClass]=\"{'error': status === 'error', 'mt-1': status === 'pending'}\"\r\n\t\t\t [innerHtml]=\"message | translate\">\r\n\t\t</div>\r\n\r\n\t\t<!-- Action -->\r\n\t\t<ec-button type=\"common\"\r\n\t\t\t\t class=\"mt-3\"\r\n\t\t\t\t *ngIf=\"action?.onClick\"\r\n\t\t\t\t [icon]=\"action?.icon\"\r\n\t\t\t\t (clicked)=\"actionClicked($event)\"\r\n\t\t\t\t [label]=\"action?.label\"\r\n\t\t\t\t [hidden]=\"status === 'pending'\">\r\n\t\t</ec-button>\r\n\t</ng-container>\r\n\r\n</div>", styles: [":host{position:relative}:host(.bg-body)>.overlay{background-color:var(--ec-background-color-body)}:host(.bg-body).is-translucent>.overlay{background-color:var(--ec-background-color-overlay)}:host(.bg-content)>.overlay{background-color:var(--ec-background-color)}:host(.bg-content).is-translucent>.overlay{background-color:var(--ec-background-color-overlay)}.overlay{align-items:center;background-color:var(--ec-background-color);display:flex;flex-direction:column;justify-content:center;padding:3rem 4rem;z-index:var(--ec-z-index-overlay);right:0;top:0;position:absolute;bottom:0;left:0}.overlay.not-mask{position:relative;min-height:100%}.message{color:var(--ec-color-secondary-dark);font-size:var(--ec-font-size-title)}.message.error{color:var(--ec-color-danger);font-size:var(--ec-font-size-title)}\n"] }]
|
|
45
|
+
}], propDecorators: { status: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}], message: [{
|
|
48
|
+
type: Input
|
|
49
|
+
}], action: [{
|
|
50
|
+
type: Input
|
|
51
|
+
}], noDataTemplate: [{
|
|
52
|
+
type: Input
|
|
53
|
+
}], displayAsMask: [{
|
|
54
|
+
type: Input
|
|
55
|
+
}], overlayClassList: [{
|
|
56
|
+
type: Input
|
|
57
|
+
}] } });
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlldy1vdmVybGF5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9kaXNwbGF5L3ZpZXctb3ZlcmxheS92aWV3LW92ZXJsYXkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvbGliL2Rpc3BsYXkvdmlldy1vdmVybGF5L3ZpZXctb3ZlcmxheS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBZSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBSTlELE1BQU0sT0FBTyxPQUFPO0lBV2xCLFlBQVksTUFBa0IsRUFBRSxPQUFnQjtRQU5oRCxXQUFNLEdBQWUsU0FBUyxDQUFDO1FBQy9CLFlBQU8sR0FBWSxFQUFFLENBQUM7UUFNcEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUNELFNBQVMsQ0FBQyxNQUFrQixFQUFFLE9BQWdCLEVBQUUsTUFBZ0IsRUFBRSxjQUFpQyxFQUFFLGdCQUF5QjtRQUM1SCxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sSUFBSSxFQUFFLENBQUM7UUFDN0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLElBQUksU0FBUyxDQUFDO1FBQ2xDLElBQUksQ0FBQyxjQUFjLEdBQUcsY0FBYyxJQUFJLFNBQVMsQ0FBQztRQUNsRCxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsZ0JBQWdCLElBQUksRUFBRSxDQUFDO0lBQ2pELENBQUM7Q0FDRjtBQUdEOztHQUVHO0FBTUgsTUFBTSxPQUFPLG9CQUFvQjtJQUxqQztRQU1XLFdBQU0sR0FBZSxTQUFTLENBQUM7S0E2QnpDO0lBWkMsU0FBUyxDQUFDLE1BQWtCLEVBQUUsT0FBZ0IsRUFBRSxNQUFnQixFQUFFLGNBQWlDO1FBQ2pHLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxJQUFJLEVBQUUsQ0FBQztRQUM3QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sSUFBSSxTQUFTLENBQUM7UUFDbEMsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLElBQUksU0FBUyxDQUFDO0lBQ3BELENBQUM7SUFFRCxhQUFhLENBQUMsS0FBVTtRQUN0QixJQUFJLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUU7WUFDdEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDNUI7SUFDSCxDQUFDOztpSEE3QlUsb0JBQW9CO3FHQUFwQixvQkFBb0IsK05DcENqQyx5cERBd0NNOzJGREpPLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxhQUFhOzhCQUtkLE1BQU07c0JBQWQsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBR0csTUFBTTtzQkFBZCxLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBS0csYUFBYTtzQkFBckIsS0FBSztnQkFLRyxnQkFBZ0I7c0JBQXhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBOYXZJdGVtIH0gZnJvbSAnLi4vLi4vY29udHJvbHMvbmF2aWdhdGlvbi9uYXYtaXRlbSc7XHJcbmltcG9ydCB7IERpc3BsYXlTdGF0dXMsIFZpZXdTdGF0dXMgfSBmcm9tICcuLi8uLi9zaGFyZWQvZGlzcGxheSc7XHJcblxyXG5leHBvcnQgY2xhc3MgT3ZlcmxheSBpbXBsZW1lbnRzIERpc3BsYXlTdGF0dXMge1xyXG4gIC8qKiAgQGRlcHJlY2F0ZWQgRGVwcmVjYXRlZCBkdWUgdG8gbm9EYXRhVGVtcGxhdGUgYmVpbmcgcHJlZmVyZWQgKi9cclxuICBhY3Rpb24/OiBOYXZJdGVtO1xyXG4gIG5vRGF0YVRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcclxuICBkaXNwbGF5QXNNYXNrPzogYm9vbGVhbjtcclxuICBzdGF0dXM6IFZpZXdTdGF0dXMgPSAnaGFzRGF0YSc7XHJcbiAgbWVzc2FnZT86IHN0cmluZyA9ICcnO1xyXG5cclxuICAvKiogQWRkaXRpb24gY3NzIGNsYXNzZXMgdG8gYXBwbHkgdG8gdGhlIC5vdmVybGF5IGVsZW1lbnQgKi9cclxuICBvdmVybGF5Q2xhc3NMaXN0Pzogc3RyaW5nO1xyXG5cclxuICBjb25zdHJ1Y3RvcihzdGF0dXM6IFZpZXdTdGF0dXMsIG1lc3NhZ2U/OiBzdHJpbmcpIHtcclxuICAgIHRoaXMuc2V0U3RhdHVzKHN0YXR1cywgbWVzc2FnZSk7XHJcbiAgfVxyXG4gIHNldFN0YXR1cyhzdGF0dXM6IFZpZXdTdGF0dXMsIG1lc3NhZ2U/OiBzdHJpbmcsIGFjdGlvbj86IE5hdkl0ZW0sIG5vRGF0YVRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55Piwgb3ZlcmxheUNsYXNzTGlzdD86IHN0cmluZyk6IHZvaWQge1xyXG4gICAgdGhpcy5zdGF0dXMgPSBzdGF0dXM7XHJcbiAgICB0aGlzLm1lc3NhZ2UgPSBtZXNzYWdlIHx8ICcnO1xyXG4gICAgdGhpcy5hY3Rpb24gPSBhY3Rpb24gfHwgdW5kZWZpbmVkO1xyXG4gICAgdGhpcy5ub0RhdGFUZW1wbGF0ZSA9IG5vRGF0YVRlbXBsYXRlIHx8IHVuZGVmaW5lZDtcclxuICAgIHRoaXMub3ZlcmxheUNsYXNzTGlzdCA9IG92ZXJsYXlDbGFzc0xpc3QgfHwgJyc7XHJcbiAgfVxyXG59XHJcblxyXG5cclxuLyoqXHJcbiAqIFdyYXBzIGNvbnRlbnQgaW4gb3JkZXIgdG8gc2hvdyBwZW5kaW5nLCBlcnJvciwgYW5kIG5vIGRhdGEgc3RhdGVzIHdpdGggYW4gb3B0aW9uYWwgbWVzc2FnZS9ub0RhdGFUZW1wbGF0ZVxyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdbZWNPdmVybGF5XScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3ZpZXctb3ZlcmxheS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdmlldy1vdmVybGF5LmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFZpZXdPdmVybGF5Q29tcG9uZW50IGltcGxlbWVudHMgT3ZlcmxheSB7XHJcbiAgQElucHV0KCkgc3RhdHVzOiBWaWV3U3RhdHVzID0gJ2hhc0RhdGEnO1xyXG4gIEBJbnB1dCgpIG1lc3NhZ2U/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XHJcblxyXG4gIC8qKiAgQGRlcHJlY2F0ZWQgRGVwcmVjYXRlZCBkdWUgdG8gbm9EYXRhVGVtcGxhdGUgYmVpbmcgcHJlZmVyZWQgKi9cclxuICBASW5wdXQoKSBhY3Rpb24/OiBOYXZJdGVtIHwgdW5kZWZpbmVkO1xyXG4gIEBJbnB1dCgpIG5vRGF0YVRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgLyoqXHJcbiAgICogTWFzayAobm90IHJlbW92ZSkgdGhlIHRyYW5zY2x1ZGVkIGNvbnRlbnQgZnJvbSB0aGUgZG9tIHdoaWxlIG5vdCBoYXNEYXRhIHN0YXR1cy5cclxuICAgKi9cclxuICBASW5wdXQoKSBkaXNwbGF5QXNNYXNrPzogYm9vbGVhbjtcclxuXHJcbiAgLyoqIFxyXG4gICAqIEFkZGl0aW9uYWwgY3NzIGNsYXNzZXMgdG8gYXBwbHkgdG8gdGhlIC5vdmVybGF5IGVsZW1lbnQgXHJcbiAgICovXHJcbiAgQElucHV0KCkgb3ZlcmxheUNsYXNzTGlzdD86IHN0cmluZztcclxuXHJcbiAgc2V0U3RhdHVzKHN0YXR1czogVmlld1N0YXR1cywgbWVzc2FnZT86IHN0cmluZywgYWN0aW9uPzogTmF2SXRlbSwgbm9EYXRhVGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjxhbnk+KTogdm9pZCB7XHJcbiAgICB0aGlzLnN0YXR1cyA9IHN0YXR1cztcclxuICAgIHRoaXMubWVzc2FnZSA9IG1lc3NhZ2UgfHwgJyc7XHJcbiAgICB0aGlzLmFjdGlvbiA9IGFjdGlvbiB8fCB1bmRlZmluZWQ7XHJcbiAgICB0aGlzLm5vRGF0YVRlbXBsYXRlID0gbm9EYXRhVGVtcGxhdGUgfHwgdW5kZWZpbmVkO1xyXG4gIH1cclxuXHJcbiAgYWN0aW9uQ2xpY2tlZChldmVudDogYW55KTogdm9pZCB7XHJcbiAgICBpZiAodGhpcy5hY3Rpb24gJiYgdGhpcy5hY3Rpb24ub25DbGljaykge1xyXG4gICAgICB0aGlzLmFjdGlvbi5vbkNsaWNrKGV2ZW50KTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPCEtLSBUcmFuc2NsdWRlZCBDb250ZW50IC0tPlxyXG48bmctY29udGVudCAqbmdJZj1cImRpc3BsYXlBc01hc2sgfHwgKCFkaXNwbGF5QXNNYXNrICYmIHN0YXR1cyA9PT0gJ2hhc0RhdGEnKVwiPjwvbmctY29udGVudD5cclxuPCEtLVVzZWQgYnkgR0kgdGVzdHMgdG8ga25vdyB0aGUgb3ZlcmxheSBzdGF0dXMgd2hldGhlciB3ZSB1c2UgbmdJZiBvciBtYXNrIHZlcnNpb24uIE5vIHZpc3VhbCBpbXBhY3QtLT5cclxuPHNwYW4gW2hpZGRlbl09XCJ0cnVlXCJcclxuXHQgIGNsYXNzPVwib3ZlcmxheS1zdGF0dXMte3tzdGF0dXN9fVwiPjwvc3Bhbj5cclxuPCEtLSBPdmVybGF5IGdvZXMgbGFzdCBzbyBpdCBpcyByZW5kZXJlZCBvbiB0b3Agb2YgcHJlY2VkaW5nIGNvbnRlbnQgZHVlIHRvIHNvdXJjZSBvcmRlciAtLT5cclxuPGRpdiAqbmdJZj1cInN0YXR1cyAhPT0gJ2hhc0RhdGEnXCJcclxuXHQgY2xhc3M9XCJvdmVybGF5IGZsZXgtZ3JvdyB7e292ZXJsYXlDbGFzc0xpc3R9fVwiXHJcblx0IFtuZ0NsYXNzXT1cInsnbm90LW1hc2snOiAhZGlzcGxheUFzTWFzayxcclxuXHRcdFx0XHQnb3ZlcmxheS1lcnJvcic6IHN0YXR1cyA9PT0gJ2Vycm9yJyxcclxuXHRcdFx0XHQnb3ZlcmxheS1ub2RhdGEnOiBzdGF0dXMgPT09ICdub0RhdGEnLFxyXG5cdFx0XHRcdCdvdmVybGF5LXBlbmRpbmcnOiBzdGF0dXMgPT09ICdwZW5kaW5nJ31cIj5cclxuXHJcblx0PCEtLVBlbmRpbmcgU3Bpbm5lci0tPlxyXG5cdDxlYy1zcGlubmVyIFtoaWRkZW5dPVwic3RhdHVzICE9PSAncGVuZGluZydcIj48L2VjLXNwaW5uZXI+XHJcblxyXG5cdDxuZy10ZW1wbGF0ZSBbbmdJZl09XCJzdGF0dXMgPT09ICdub0RhdGEnICYmIG5vRGF0YVRlbXBsYXRlXCI+XHJcblx0XHQ8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwibm9EYXRhVGVtcGxhdGVcIj48L25nLWNvbnRhaW5lcj5cclxuXHQ8L25nLXRlbXBsYXRlPlxyXG5cclxuXHQ8bmctY29udGFpbmVyICpuZ0lmPVwiKHN0YXR1cyA9PT0gJ25vRGF0YScgJiYgIW5vRGF0YVRlbXBsYXRlKSB8fCBzdGF0dXMgIT09ICdub0RhdGEnXCI+XHJcblx0XHQ8IS0tU3RhdHVzIE1lc3NhZ2UtLT5cclxuXHRcdDxkaXYgaWQ9XCJzdGF0dXNNZXNzYWdlXCJcclxuXHRcdFx0IGNsYXNzPVwibWVzc2FnZVwiXHJcblx0XHRcdCAqbmdJZj1cIm1lc3NhZ2VcIlxyXG5cdFx0XHQgW25nQ2xhc3NdPVwieydlcnJvcic6IHN0YXR1cyA9PT0gJ2Vycm9yJywgJ210LTEnOiBzdGF0dXMgPT09ICdwZW5kaW5nJ31cIlxyXG5cdFx0XHQgW2lubmVySHRtbF09XCJtZXNzYWdlIHwgdHJhbnNsYXRlXCI+XHJcblx0XHQ8L2Rpdj5cclxuXHJcblx0XHQ8IS0tIEFjdGlvbiAtLT5cclxuXHRcdDxlYy1idXR0b24gdHlwZT1cImNvbW1vblwiXHJcblx0XHRcdFx0ICAgY2xhc3M9XCJtdC0zXCJcclxuXHRcdFx0XHQgICAqbmdJZj1cImFjdGlvbj8ub25DbGlja1wiXHJcblx0XHRcdFx0ICAgW2ljb25dPVwiYWN0aW9uPy5pY29uXCJcclxuXHRcdFx0XHQgICAoY2xpY2tlZCk9XCJhY3Rpb25DbGlja2VkKCRldmVudClcIlxyXG5cdFx0XHRcdCAgIFtsYWJlbF09XCJhY3Rpb24/LmxhYmVsXCJcclxuXHRcdFx0XHQgICBbaGlkZGVuXT1cInN0YXR1cyA9PT0gJ3BlbmRpbmcnXCI+XHJcblx0XHQ8L2VjLWJ1dHRvbj5cclxuXHQ8L25nLWNvbnRhaW5lcj5cclxuXHJcbjwvZGl2PiJdfQ==
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Directive, Input, HostListener, HostBinding } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class ClickAreaForDirective {
|
|
4
|
+
constructor() { }
|
|
5
|
+
ngOnInit() {
|
|
6
|
+
this.isTargetClickable = typeof this.targetEl?.dispatchEvent === 'function';
|
|
7
|
+
}
|
|
8
|
+
onClick(event) {
|
|
9
|
+
if (this.isTargetClickable) {
|
|
10
|
+
event.preventDefault();
|
|
11
|
+
this.targetEl.dispatchEvent(new Event('click'));
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
ClickAreaForDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ClickAreaForDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
16
|
+
ClickAreaForDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: ClickAreaForDirective, selector: "[ecClickAreaFor]", inputs: { targetEl: ["ecClickAreaFor", "targetEl"] }, host: { listeners: { "click": "onClick($event)" }, properties: { "class.cursor-pointer": "this.targetEl" } }, ngImport: i0 });
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ClickAreaForDirective, decorators: [{
|
|
18
|
+
type: Directive,
|
|
19
|
+
args: [{
|
|
20
|
+
selector: '[ecClickAreaFor]'
|
|
21
|
+
}]
|
|
22
|
+
}], ctorParameters: function () { return []; }, propDecorators: { targetEl: [{
|
|
23
|
+
type: HostBinding,
|
|
24
|
+
args: ['class.cursor-pointer']
|
|
25
|
+
}, {
|
|
26
|
+
type: Input,
|
|
27
|
+
args: ['ecClickAreaFor']
|
|
28
|
+
}], onClick: [{
|
|
29
|
+
type: HostListener,
|
|
30
|
+
args: ['click', ['$event']]
|
|
31
|
+
}] } });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stYXJlYS1mb3IuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvbGliL3NoYXJlZC9kaXJlY3RpdmVzL2NsaWNrLWFyZWEtZm9yL2NsaWNrLWFyZWEtZm9yLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFVLE1BQU0sZUFBZSxDQUFDOztBQVNwRixNQUFNLE9BQU8scUJBQXFCO0lBUWhDLGdCQUFlLENBQUM7SUFFaEIsUUFBUTtRQUNOLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsYUFBYSxLQUFLLFVBQVUsQ0FBQztJQUM5RSxDQUFDO0lBRWtDLE9BQU8sQ0FBQyxLQUFZO1FBQ3JELElBQUksSUFBSSxDQUFDLGlCQUFpQixFQUFFO1lBQzFCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUN2QixJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1NBQ2pEO0lBQ0gsQ0FBQzs7a0hBbkJVLHFCQUFxQjtzR0FBckIscUJBQXFCOzJGQUFyQixxQkFBcUI7a0JBSGpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtpQkFDN0I7MEVBS1EsUUFBUTtzQkFGZCxXQUFXO3VCQUFDLHNCQUFzQjs7c0JBQ2xDLEtBQUs7dUJBQUMsZ0JBQWdCO2dCQVdZLE9BQU87c0JBQXpDLFlBQVk7dUJBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCwgSG9zdExpc3RlbmVyLCBIb3N0QmluZGluZywgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENsaWNrYWJsZUVsZW1lbnQge1xyXG4gIGRpc3BhdGNoRXZlbnQoZXZlbnQ6IEV2ZW50KTogdm9pZDtcclxufVxyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbZWNDbGlja0FyZWFGb3JdJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2xpY2tBcmVhRm9yRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5jdXJzb3ItcG9pbnRlcicpXHJcbiAgQElucHV0KCdlY0NsaWNrQXJlYUZvcicpIFxyXG4gIHB1YmxpYyB0YXJnZXRFbD86IGFueTtcclxuXHJcbiAgcHJpdmF0ZSBpc1RhcmdldENsaWNrYWJsZSE6IGJvb2xlYW47XHJcbiAgXHJcbiAgY29uc3RydWN0b3IoKSB7fVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIHRoaXMuaXNUYXJnZXRDbGlja2FibGUgPSB0eXBlb2YgdGhpcy50YXJnZXRFbD8uZGlzcGF0Y2hFdmVudCA9PT0gJ2Z1bmN0aW9uJztcclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJywgWyckZXZlbnQnXSkgb25DbGljayhldmVudDogRXZlbnQpIHtcclxuICAgIGlmICh0aGlzLmlzVGFyZ2V0Q2xpY2thYmxlKSB7XHJcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICAgIHRoaXMudGFyZ2V0RWwuZGlzcGF0Y2hFdmVudChuZXcgRXZlbnQoJ2NsaWNrJykpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import { debounceTime, takeUntil } from 'rxjs/operators';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../../core/window.service";
|
|
6
|
+
/**
|
|
7
|
+
* Conditionally include content in the DOM based on the width of the viewport. Use to programmatically implement reponsive layouts and prevent duplicate markup and listeners.
|
|
8
|
+
* In most scenarios CSS media queries is sufficient to hide/show elements responsively. However, in some cases media queries would result in duplicate markup and listeners
|
|
9
|
+
* that could cause undesired side effects and it is preferred to us programmatic elements to achieve the layout.
|
|
10
|
+
*/
|
|
11
|
+
export class IfViewportWidthDirective {
|
|
12
|
+
constructor(viewContainer, templateRef, windowService) {
|
|
13
|
+
this.viewContainer = viewContainer;
|
|
14
|
+
this.templateRef = templateRef;
|
|
15
|
+
this.windowService = windowService;
|
|
16
|
+
/**
|
|
17
|
+
* Used to unsubscribe when the directive is removed from the DOM
|
|
18
|
+
*/
|
|
19
|
+
this.destroyed = new Subject();
|
|
20
|
+
/**
|
|
21
|
+
* Internally tracks whether the directive and its content is included in the DOM
|
|
22
|
+
*/
|
|
23
|
+
this.isVisible = false;
|
|
24
|
+
}
|
|
25
|
+
ngOnInit() {
|
|
26
|
+
// Window may not available if this code is not being run on a browser platform.
|
|
27
|
+
// If there is no window or innerWidth abort initialization
|
|
28
|
+
if (this.windowService.innerWidth === undefined) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
// Check for required values. If none are set, log error and abort initialization
|
|
32
|
+
if (!this.width) {
|
|
33
|
+
console.error(`A min or max width was not provided. Provide a value for 'min' or 'max' by assigning a single value or object to the directive. E.g. *ecIfViewportWidth="800" (assigned to min) or *ecIfViewportWidth="{min: 800, max: 1280}"`);
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
else if (typeof this.width === 'number') {
|
|
37
|
+
this.minWidth = this.width;
|
|
38
|
+
}
|
|
39
|
+
else if (this.width !== undefined) {
|
|
40
|
+
this.minWidth = this.width.min;
|
|
41
|
+
this.maxWidth = this.width.max;
|
|
42
|
+
}
|
|
43
|
+
if (this.windowService.resized) {
|
|
44
|
+
this.windowService.resized.pipe(debounceTime(100), takeUntil(this.destroyed)).subscribe(() => {
|
|
45
|
+
this.updateVisibility();
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
this.updateVisibility();
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Get the current viewport width and determin if the directive's content should be
|
|
52
|
+
* included in the DOM based on the min and max width settings
|
|
53
|
+
*/
|
|
54
|
+
updateVisibility() {
|
|
55
|
+
const viewportWidth = this.windowService.innerWidth;
|
|
56
|
+
if (this.minWidth !== undefined && this.maxWidth !== undefined) {
|
|
57
|
+
if (viewportWidth >= this.minWidth && viewportWidth <= this.maxWidth) {
|
|
58
|
+
this.show();
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
this.hide();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
else if (this.minWidth !== undefined) {
|
|
65
|
+
if (viewportWidth >= this.minWidth) {
|
|
66
|
+
this.show();
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
this.hide();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
else if (this.maxWidth !== undefined) {
|
|
73
|
+
if (viewportWidth <= this.maxWidth) {
|
|
74
|
+
this.show();
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
this.hide();
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Add the directive's content to the DOM
|
|
83
|
+
*/
|
|
84
|
+
show() {
|
|
85
|
+
if (!this.isVisible) {
|
|
86
|
+
this.viewContainer.createEmbeddedView(this.templateRef);
|
|
87
|
+
this.isVisible = true;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Remove the directive's content from the DOM
|
|
92
|
+
*/
|
|
93
|
+
hide() {
|
|
94
|
+
if (this.isVisible) {
|
|
95
|
+
this.viewContainer.clear();
|
|
96
|
+
this.isVisible = false;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
IfViewportWidthDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: IfViewportWidthDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }, { token: i1.WindowService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
101
|
+
IfViewportWidthDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: IfViewportWidthDirective, selector: "[ecIfViewportWidth]", inputs: { width: ["ecIfViewportWidth", "width"] }, ngImport: i0 });
|
|
102
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: IfViewportWidthDirective, decorators: [{
|
|
103
|
+
type: Directive,
|
|
104
|
+
args: [{
|
|
105
|
+
selector: '[ecIfViewportWidth]'
|
|
106
|
+
}]
|
|
107
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i1.WindowService }]; }, propDecorators: { width: [{
|
|
108
|
+
type: Input,
|
|
109
|
+
args: ['ecIfViewportWidth']
|
|
110
|
+
}] } });
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"if-viewport-width.directive.js","sourceRoot":"","sources":["../../../../../../../projects/components/src/lib/shared/directives/if-viewport-width/if-viewport-width.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, OnInit, ViewContainerRef, TemplateRef } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, takeUntil } from 'rxjs/operators';\r\nimport { WindowService } from '../../../core/window.service';\r\n\r\n/**\r\n * Conditionally include content in the DOM based on the width of the viewport. Use to programmatically implement reponsive layouts and prevent duplicate markup and listeners.\r\n * In most scenarios CSS media queries is sufficient to hide/show elements responsively. However, in some cases media queries would result in duplicate markup and listeners\r\n * that could cause undesired side effects and it is preferred to us programmatic elements to achieve the layout.\r\n */\r\n@Directive({\r\n  selector: '[ecIfViewportWidth]'\r\n})\r\nexport class IfViewportWidthDirective implements OnInit{\r\n\r\n  /**\r\n   * The min and, optionally, max width in pixels that the viewport must be in order to include the directive and its content in the DOM.\r\n   * A single number can be used to set the min width, but an object with min and max must be used to set a min and max width or just a max width.\r\n   * \r\n   * ```html\r\n   * <div *ecIfViewportWidth=\"500\">Content to render if viewport width is >= 500px</div>\r\n   * <div *ecIfViewportWidth=\"{max: 800}\">Content to render if the viewport width is <= 800px</div>\r\n   * <div *ecIfViewportWidth=\"{min: 500, max: 800}\">Content to render if the viewport width is between 500px and 800px</div>\r\n   * ```\r\n   */\r\n  @Input('ecIfViewportWidth') public width!: number | {min?: number; max?: number};\r\n\r\n  /** \r\n   * If defined, the width in pixels that the viewport must be to include the directive and its content in the DOM\r\n   */\r\n  private minWidth?: number;\r\n\r\n  /**\r\n   * If defined, the width in pixels that the viewport cannot be greater than to include the directive and its conten in the DOM\r\n   */\r\n  private maxWidth?: number;\r\n\r\n  /** \r\n   * Used to unsubscribe when the directive is removed from the DOM\r\n   */\r\n  private destroyed: Subject<void> = new Subject();\r\n\r\n  /**\r\n   * Internally tracks whether the directive and its content is included in the DOM\r\n   */\r\n  private isVisible: boolean = false;\r\n\r\n  constructor(\r\n    private viewContainer: ViewContainerRef, \r\n    private templateRef: TemplateRef<any>, \r\n    private windowService: WindowService\r\n  ) { }\r\n\r\n  public ngOnInit(): void {\r\n    // Window may not available if this code is not being run on a browser platform. \r\n    // If there is no window or innerWidth abort initialization\r\n    if (this.windowService.innerWidth === undefined) {\r\n      return;\r\n    }\r\n\r\n    // Check for required values. If none are set, log error and abort initialization\r\n    if (!this.width)  {\r\n      console.error(`A min or max width was not provided. Provide a value for 'min' or 'max' by assigning a single value or object to the directive. E.g. *ecIfViewportWidth=\"800\" (assigned to min) or *ecIfViewportWidth=\"{min: 800, max: 1280}\"`);\r\n      return;\r\n    } else if (typeof this.width === 'number') {\r\n      this.minWidth = this.width;\r\n    } else if (this.width !== undefined) {\r\n      this.minWidth = this.width.min;\r\n      this.maxWidth = this.width.max;\r\n    }\r\n\r\n    if (this.windowService.resized) {\r\n      this.windowService.resized.pipe(debounceTime(100), takeUntil(this.destroyed)).subscribe( () => {\r\n        this.updateVisibility();\r\n      })\r\n    }\r\n    this.updateVisibility();\r\n  }\r\n\r\n  /**\r\n   * Get the current viewport width and determin if the directive's content should be\r\n   * included in the DOM based on the min and max width settings\r\n   */\r\n  private updateVisibility(): void {\r\n    const viewportWidth = this.windowService.innerWidth!;\r\n    \r\n    if (this.minWidth !== undefined && this.maxWidth !== undefined) {\r\n      if (viewportWidth >= this.minWidth && viewportWidth <= this.maxWidth) {\r\n        this.show();\r\n      } else {\r\n        this.hide();\r\n      }\r\n    } else if (this.minWidth !== undefined) {\r\n      if (viewportWidth >= this.minWidth) {\r\n        this.show();\r\n      } else {\r\n        this.hide();\r\n      }\r\n    } else if (this.maxWidth !== undefined) {\r\n      if (viewportWidth <= this.maxWidth) {\r\n        this.show();\r\n      } else {\r\n        this.hide();\r\n      }\r\n    }\r\n      \r\n  }\r\n\r\n  /**\r\n   * Add the directive's content to the DOM\r\n   */\r\n  private show(): void {\r\n    if (!this.isVisible) {\r\n      this.viewContainer.createEmbeddedView(this.templateRef);\r\n      this.isVisible = true;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove the directive's content from the DOM\r\n   */\r\n  private hide(): void {\r\n    if (this.isVisible) {\r\n      this.viewContainer.clear();\r\n      this.isVisible = false;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { Directive, Input, Inject, EventEmitter } from '@angular/core';
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { fromEvent } from "rxjs";
|
|
4
|
+
import Popper from 'popper.js';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* Primitive directive that popups a container using PopperJS
|
|
8
|
+
*
|
|
9
|
+
* @export
|
|
10
|
+
*/
|
|
11
|
+
export class PopupContainerDirective {
|
|
12
|
+
/**
|
|
13
|
+
* Creates an instance of PopupContainerDirective.
|
|
14
|
+
* @param templateRef Reference to the popup template
|
|
15
|
+
* @param viewContainer Reference to the view container
|
|
16
|
+
* @param document Reference to Document
|
|
17
|
+
* @memberof PopupContainerDirective
|
|
18
|
+
*/
|
|
19
|
+
constructor(templateRef, viewContainer, document, renderer) {
|
|
20
|
+
this.templateRef = templateRef;
|
|
21
|
+
this.viewContainer = viewContainer;
|
|
22
|
+
this.document = document;
|
|
23
|
+
this.renderer = renderer;
|
|
24
|
+
/**
|
|
25
|
+
* Emit the {@link PopupStatus} when it changes
|
|
26
|
+
*/
|
|
27
|
+
this.popperStatusChange = new EventEmitter();
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Angular onInit lifecycle hook
|
|
31
|
+
* @see https://angular.io/guide/lifecycle-hooks
|
|
32
|
+
*/
|
|
33
|
+
ngOnInit() {
|
|
34
|
+
this.templateViewRef = this.viewContainer.createEmbeddedView(this.templateRef);
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Angular onDestroy lifecycle hook. Close and delete references. Unsubscribe observables
|
|
38
|
+
* @see https://angular.io/guide/lifecycle-hooks
|
|
39
|
+
*/
|
|
40
|
+
ngOnDestroy() {
|
|
41
|
+
this.hide();
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Displays the templateRef as a popup
|
|
45
|
+
*
|
|
46
|
+
* @memberof PopupContainerDirective
|
|
47
|
+
*/
|
|
48
|
+
show() {
|
|
49
|
+
if (PopupContainerDirective.GlobalPopupRef) {
|
|
50
|
+
if (PopupContainerDirective.GlobalPopupRef != this) {
|
|
51
|
+
PopupContainerDirective.GlobalPopupRef.hide();
|
|
52
|
+
PopupContainerDirective.GlobalPopupRef = undefined;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
if (!this.globalCloseSubscription) {
|
|
56
|
+
this.globalCloseSubscription = fromEvent(this.document.body, "click").subscribe((event) => {
|
|
57
|
+
this.hide();
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
if (!this.popperRef) {
|
|
61
|
+
// Add the popper template as an embedded view since PopperJS
|
|
62
|
+
// manipulates DOM elements.
|
|
63
|
+
this.popupViewRef = this.viewContainer.createEmbeddedView(this.popup);
|
|
64
|
+
// Since popper needs real DOM elements, grab the first non-comment
|
|
65
|
+
// DOM element to use as our anchor.
|
|
66
|
+
let anchorElement = this.popupViewRef.rootNodes.find(elem => { return elem.nodeName !== "#text"; });
|
|
67
|
+
// Use the parents elements as our DOM elements to Popper
|
|
68
|
+
this.popperRef = new Popper(this.templateViewRef.rootNodes[0], anchorElement, this.popperOptions);
|
|
69
|
+
PopupContainerDirective.GlobalPopupRef = this;
|
|
70
|
+
this.popperStatusChange.emit('visible');
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Hides the templateRef
|
|
75
|
+
*
|
|
76
|
+
* @memberof PopupContainerDirective
|
|
77
|
+
*/
|
|
78
|
+
hide() {
|
|
79
|
+
if (this.globalCloseSubscription) {
|
|
80
|
+
this.globalCloseSubscription.unsubscribe();
|
|
81
|
+
this.globalCloseSubscription = undefined;
|
|
82
|
+
}
|
|
83
|
+
if (this.popperRef && this.popupViewRef) {
|
|
84
|
+
this.popupViewRef.destroy();
|
|
85
|
+
this.popperRef.destroy();
|
|
86
|
+
this.popperRef = undefined;
|
|
87
|
+
this.popperStatusChange.emit('hidden');
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Updates the popup container position
|
|
92
|
+
*/
|
|
93
|
+
update() {
|
|
94
|
+
if (this.popperRef) {
|
|
95
|
+
this.popperRef.update();
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
fixPosition(minWidthNone, appendToBody = false) {
|
|
99
|
+
if (this.popperRef && this.popperRef['reference'] && this.popperRef['popper']) {
|
|
100
|
+
let popupEl = this.popperRef['popper'];
|
|
101
|
+
// Reset width style previously assigned because the content may have
|
|
102
|
+
// changed and the auto width would be different
|
|
103
|
+
this.renderer.removeStyle(popupEl, 'width');
|
|
104
|
+
this.renderer.setStyle(popupEl, 'position', 'fixed');
|
|
105
|
+
if (appendToBody) {
|
|
106
|
+
const bodyEl = this.document.querySelector('body');
|
|
107
|
+
const popupParent = this.renderer.parentNode(popupEl);
|
|
108
|
+
if (popupParent !== bodyEl) {
|
|
109
|
+
this.renderer.appendChild(bodyEl, popupEl);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
let toggleEl = this.popperRef['reference'];
|
|
113
|
+
let width = popupEl.offsetWidth;
|
|
114
|
+
let boundaries = popupEl.getBoundingClientRect();
|
|
115
|
+
let left = boundaries.left;
|
|
116
|
+
let coords = toggleEl.getBoundingClientRect();
|
|
117
|
+
// Set the top of our menu to the bottom of the toggle element
|
|
118
|
+
let top = coords.bottom;
|
|
119
|
+
if (this.popperOptions && this.popperOptions.placement) {
|
|
120
|
+
if (this.popperOptions.placement === 'bottom-start' || this.popperOptions.placement === 'top-start') {
|
|
121
|
+
left = coords.left;
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
left = coords.right - ((minWidthNone || width > coords.width) ? width : coords.width);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
// if it won't fit (with 10px space before hitting the window edge), flip it
|
|
128
|
+
if (boundaries.height + top + 10 > window.innerHeight) {
|
|
129
|
+
top = coords.top - boundaries.height;
|
|
130
|
+
}
|
|
131
|
+
this.renderer.setStyle(popupEl, 'transform', 'none');
|
|
132
|
+
this.renderer.setStyle(popupEl, 'left', left + 'px');
|
|
133
|
+
this.renderer.setStyle(popupEl, 'top', top + 'px');
|
|
134
|
+
this.renderer.setStyle(popupEl, 'width', width + 'px');
|
|
135
|
+
if (!minWidthNone) {
|
|
136
|
+
this.renderer.setStyle(popupEl, 'min-width', coords.width + 'px');
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Global reference to the currently displayed popup; only
|
|
143
|
+
* one popup directive can be in `show` state at a given time.
|
|
144
|
+
*
|
|
145
|
+
* @memberof PopupContainerDirective
|
|
146
|
+
*/
|
|
147
|
+
PopupContainerDirective.GlobalPopupRef = undefined;
|
|
148
|
+
PopupContainerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: PopupContainerDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: DOCUMENT }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
149
|
+
PopupContainerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: PopupContainerDirective, selector: "[ecPopup]", inputs: { popup: ["ecPopup", "popup"], popperOptions: ["options", "popperOptions"] }, ngImport: i0 });
|
|
150
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: PopupContainerDirective, decorators: [{
|
|
151
|
+
type: Directive,
|
|
152
|
+
args: [{ selector: '[ecPopup]' }]
|
|
153
|
+
}], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
|
|
154
|
+
type: Inject,
|
|
155
|
+
args: [DOCUMENT]
|
|
156
|
+
}] }, { type: i0.Renderer2 }]; }, propDecorators: { popup: [{
|
|
157
|
+
type: Input,
|
|
158
|
+
args: ['ecPopup']
|
|
159
|
+
}], popperOptions: [{
|
|
160
|
+
type: Input,
|
|
161
|
+
args: ['options']
|
|
162
|
+
}] } });
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popup-container.directive.js","sourceRoot":"","sources":["../../../../../../../projects/components/src/lib/shared/directives/popup/popup-container.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, TemplateRef, ViewContainerRef, OnInit, EmbeddedViewRef, OnDestroy, Renderer2, Inject, EventEmitter } from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { Subscription, fromEvent } from \"rxjs\";\r\nimport Popper from 'popper.js'\r\n\r\nexport type PopupPlacement = 'top' | 'right' | 'bottom' | 'left' | 'top-start' | 'top-end' | 'bottom-start' | 'bottom-end';\r\nexport type PopupStatus = 'visible' | 'hidden';\r\n\r\n/**\r\n * Primitive directive that popups a container using PopperJS\r\n *\r\n * @export\r\n */\r\n@Directive({ selector: '[ecPopup]' })\r\nexport class PopupContainerDirective implements OnInit, OnDestroy, OnInit {\r\n\r\n    /**\r\n     *  Global reference to the currently displayed popup; only\r\n     *  one popup directive can be in `show` state at a given time.\r\n     *\r\n     * @memberof PopupContainerDirective\r\n     */\r\n    public static GlobalPopupRef?: PopupContainerDirective = undefined;\r\n\r\n    /**\r\n     * TemplateRef of container to popup\r\n     *\r\n     */\r\n    @Input('ecPopup') public popup!: TemplateRef<any>;\r\n\r\n    /**\r\n     * Popper options\r\n     *\r\n     * @memberof PopupContainerDirective\r\n     */\r\n    @Input('options') public popperOptions?: Popper.PopperOptions;\r\n\r\n    /**\r\n     * Template View Reference\r\n     *\r\n     * @memberof PopupContainerDirective\r\n     */\r\n    private templateViewRef!: EmbeddedViewRef<any>;\r\n\r\n    /**\r\n     * Popup View Reference (container)\r\n     *\r\n     * @memberof PopupContainerDirective\r\n     */\r\n    private popupViewRef?: EmbeddedViewRef<any>;\r\n\r\n    /**\r\n     * Popper Reference\r\n     *\r\n     * @memberof PopupContainerDirective\r\n     */\r\n    private popperRef?: Popper;\r\n\r\n    /**\r\n     * Close-to-click Subscription. This allows us to close the menu when you click on the body.\r\n     * We attach it when the menu is open and detach it on close, to limit the lifetime of the click handler\r\n     * which helps with performance on a page with many popup containers\r\n     *\r\n     * @memberof PopupContainerDirective\r\n     */\r\n    private globalCloseSubscription?: Subscription;\r\n\r\n    /**\r\n     * Creates an instance of PopupContainerDirective.\r\n     * @param templateRef Reference to the popup template\r\n     * @param viewContainer Reference to the view container\r\n     * @param document Reference to Document\r\n     * @memberof PopupContainerDirective\r\n     */\r\n    constructor(\r\n        private templateRef: TemplateRef<any>,\r\n        private viewContainer: ViewContainerRef,\r\n        @Inject(DOCUMENT) private document: any,\r\n        private renderer: Renderer2\r\n    ) {}\r\n\r\n    /**\r\n     * Angular onInit lifecycle hook\r\n     * @see https://angular.io/guide/lifecycle-hooks\r\n     */\r\n    ngOnInit(): void {\r\n        this.templateViewRef = this.viewContainer.createEmbeddedView(this.templateRef);\r\n    }\r\n\r\n\r\n    /**\r\n     * Angular onDestroy lifecycle hook. Close and delete references. Unsubscribe observables\r\n     * @see https://angular.io/guide/lifecycle-hooks\r\n     */\r\n    ngOnDestroy(): void {\r\n        this.hide();\r\n    }\r\n\r\n\r\n    /**\r\n     * Emit the {@link PopupStatus} when it changes\r\n     */\r\n    public popperStatusChange: EventEmitter<PopupStatus> = new EventEmitter<PopupStatus>();\r\n\r\n\r\n    /**\r\n     * Displays the templateRef as a popup\r\n     *\r\n     * @memberof PopupContainerDirective\r\n     */\r\n    public show(): void {\r\n        if (PopupContainerDirective.GlobalPopupRef) {\r\n            if (PopupContainerDirective.GlobalPopupRef != this) {\r\n                PopupContainerDirective.GlobalPopupRef.hide();\r\n                PopupContainerDirective.GlobalPopupRef = undefined;\r\n            }\r\n        }\r\n\r\n        if(!this.globalCloseSubscription) {\r\n            this.globalCloseSubscription = fromEvent(this.document.body, \"click\").subscribe((event) => {\r\n                this.hide();\r\n            });\r\n        }\r\n\r\n        if (!this.popperRef) {\r\n            // Add the popper template as an embedded view since PopperJS\r\n            // manipulates DOM elements.\r\n            this.popupViewRef = this.viewContainer.createEmbeddedView(this.popup);\r\n\r\n            // Since popper needs real DOM elements, grab the first non-comment\r\n            // DOM element to use as our anchor.\r\n            let anchorElement = (this.popupViewRef.rootNodes as any[]).find(elem => { return elem.nodeName !== \"#text\" });\r\n\r\n\r\n            // Use the parents elements as our DOM elements to Popper\r\n            this.popperRef = new Popper(\r\n                this.templateViewRef.rootNodes[0],\r\n                anchorElement,\r\n                this.popperOptions);\r\n\r\n\r\n            PopupContainerDirective.GlobalPopupRef = this;\r\n\r\n            this.popperStatusChange.emit('visible');\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Hides the templateRef\r\n     *\r\n     * @memberof PopupContainerDirective\r\n     */\r\n    public hide(): void {\r\n        if (this.globalCloseSubscription) {\r\n            this.globalCloseSubscription.unsubscribe();\r\n            this.globalCloseSubscription = undefined;\r\n        }\r\n\r\n        if (this.popperRef && this.popupViewRef) {\r\n            this.popupViewRef.destroy();\r\n            this.popperRef.destroy();\r\n            this.popperRef = undefined;\r\n            this.popperStatusChange.emit('hidden');\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Updates the popup container position\r\n     */\r\n    public update(): void {\r\n        if (this.popperRef) {\r\n            this.popperRef.update();\r\n        }\r\n    }\r\n\r\n    public fixPosition(minWidthNone?:boolean, appendToBody=false ):void {\r\n        if(this.popperRef && this.popperRef['reference'] && this.popperRef['popper']) {\r\n            let popupEl = this.popperRef['popper'];\r\n\r\n            // Reset width style previously assigned because the content may have\r\n            // changed and the auto width would be different\r\n            this.renderer.removeStyle(popupEl, 'width');\r\n\r\n            this.renderer.setStyle(popupEl, 'position', 'fixed');\r\n\r\n            if (appendToBody) {\r\n                const bodyEl = this.document.querySelector('body');\r\n                const popupParent = this.renderer.parentNode(popupEl);\r\n                if (popupParent !== bodyEl) {\r\n                    this.renderer.appendChild(bodyEl, popupEl);\r\n                }\r\n            }\r\n\r\n            let toggleEl = this.popperRef['reference'];\r\n            let width = popupEl.offsetWidth;\r\n            let boundaries = popupEl.getBoundingClientRect();\r\n            let left:number = boundaries.left;\r\n            let coords = toggleEl.getBoundingClientRect();\r\n\r\n            // Set the top of our menu to the bottom of the toggle element\r\n            let top:number = coords.bottom;\r\n\r\n            if (this.popperOptions && this.popperOptions.placement) {\r\n                if (this.popperOptions.placement === 'bottom-start' || this.popperOptions.placement === 'top-start') {\r\n                    left = coords.left;\r\n                } else {\r\n                    left = coords.right - ((minWidthNone || width > coords.width) ? width : coords.width);\r\n                }\r\n            }\r\n\r\n            // if it won't fit (with 10px space before hitting the window edge), flip it\r\n            if (boundaries.height + top + 10 > window.innerHeight) {\r\n                top = coords.top - boundaries.height;\r\n            }\r\n\r\n            this.renderer.setStyle(popupEl, 'transform', 'none');\r\n            this.renderer.setStyle(popupEl, 'left', left + 'px');\r\n            this.renderer.setStyle(popupEl, 'top', top + 'px');\r\n            this.renderer.setStyle(popupEl, 'width', width + 'px');\r\n\r\n            if (!minWidthNone) {\r\n                this.renderer.setStyle(popupEl, 'min-width', coords.width + 'px');\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}
|