@acorex/components 6.5.26 → 6.5.28
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/karma.conf.js +32 -0
- package/ng-package.json +10 -0
- package/package.json +12 -32
- package/src/lib/accordion/accordion.component.ts +43 -0
- package/src/lib/accordion/accordion.module.ts +11 -0
- package/src/lib/accordion/api.ts +2 -0
- package/src/lib/base/base-page.class.ts +116 -0
- package/src/lib/base/components.class.ts +9 -0
- package/src/lib/base/element.class.ts +344 -0
- package/src/lib/base/events.class.ts +32 -0
- package/src/lib/button/button.component.html +17 -0
- package/src/lib/button/button.component.ts +72 -0
- package/src/lib/button/button.module.ts +14 -0
- package/src/lib/calendar/calendar-box/calendar-box.component.html +68 -0
- package/src/lib/calendar/calendar-box/calendar-box.component.ts +461 -0
- package/src/lib/calendar/calendar-box/calendar-box.module.ts +16 -0
- package/src/lib/calendar/scheduler/scheduler-views.property.ts +38 -0
- package/{lib/calendar/scheduler/scheduler.class.d.ts → src/lib/calendar/scheduler/scheduler.class.ts} +20 -6
- package/src/lib/calendar/scheduler/scheduler.component.html +9 -0
- package/src/lib/calendar/scheduler/scheduler.component.scss +181 -0
- package/src/lib/calendar/scheduler/scheduler.component.ts +249 -0
- package/src/lib/calendar/scheduler/scheduler.module.ts +45 -0
- package/src/lib/calendar/scheduler/toolbars/scheduler-toolbar-navigator.ts +133 -0
- package/src/lib/calendar/scheduler/toolbars/scheduler-toolbar-views.ts +33 -0
- package/src/lib/calendar/scheduler/views/agenda/scheduler-agenda-view.component.html +43 -0
- package/src/lib/calendar/scheduler/views/agenda/scheduler-agenda-view.component.scss +66 -0
- package/src/lib/calendar/scheduler/views/agenda/scheduler-agenda-view.component.ts +50 -0
- package/src/lib/calendar/scheduler/views/daytime/scheduler-daytime-view.component.html +45 -0
- package/src/lib/calendar/scheduler/views/daytime/scheduler-daytime-view.component.scss +19 -0
- package/src/lib/calendar/scheduler/views/daytime/scheduler-daytime-view.component.ts +103 -0
- package/src/lib/calendar/scheduler/views/month/scheduler-month-view.component.html +39 -0
- package/src/lib/calendar/scheduler/views/month/scheduler-month-view.component.scss +55 -0
- package/src/lib/calendar/scheduler/views/month/scheduler-month-view.component.ts +233 -0
- package/src/lib/calendar/scheduler/views/scheduler-view.component.ts +124 -0
- package/src/lib/calendar/scheduler/views/timeline/scheduler-timeline-view.component.html +50 -0
- package/src/lib/calendar/scheduler/views/timeline/scheduler-timeline-view.component.scss +4 -0
- package/src/lib/calendar/scheduler/views/timeline/scheduler-timeline-view.component.ts +92 -0
- package/src/lib/checkbox/checkbox.component.html +22 -0
- package/src/lib/checkbox/checkbox.component.ts +107 -0
- package/src/lib/checkbox/checkbox.module.ts +11 -0
- package/src/lib/color-picker/color-box/color-box.component.html +37 -0
- package/src/lib/color-picker/color-box/color-box.component.scss +60 -0
- package/src/lib/color-picker/color-box/color-box.component.ts +438 -0
- package/src/lib/color-picker/color-picker.component.html +31 -0
- package/src/lib/color-picker/color-picker.component.ts +87 -0
- package/src/lib/color-picker/color-picker.module.ts +16 -0
- package/src/lib/context-menu/context-menu.component.html +42 -0
- package/src/lib/context-menu/context-menu.component.ts +78 -0
- package/src/lib/context-menu/context-menu.directive.ts +159 -0
- package/src/lib/context-menu/context-menu.module.ts +15 -0
- package/src/lib/data-filter/columns/filter-column-date.component.ts +123 -0
- package/src/lib/data-filter/columns/filter-column-number.component.ts +100 -0
- package/src/lib/data-filter/columns/filter-column-selection.component.ts +69 -0
- package/src/lib/data-filter/columns/filter-column-string.component.ts +100 -0
- package/src/lib/data-filter/filter-panel/filter-panel.component.html +120 -0
- package/src/lib/data-filter/filter-panel/filter-panel.component.scss +143 -0
- package/src/lib/data-filter/filter-panel/filter-panel.component.ts +266 -0
- package/src/lib/data-filter/filter.class.ts +73 -0
- package/src/lib/data-filter/filter.module.ts +52 -0
- package/src/lib/data-filter/toolbar/filter-toolbar.component.html +5 -0
- package/src/lib/data-filter/toolbar/filter-toolbar.component.scss +17 -0
- package/src/lib/data-filter/toolbar/filter-toolbar.component.ts +179 -0
- package/src/lib/data-list/core/data-list.component.ts +62 -0
- package/src/lib/data-list/list/list.component.html +32 -0
- package/src/lib/data-list/list/list.component.scss +64 -0
- package/src/lib/data-list/list/list.component.ts +149 -0
- package/src/lib/data-list/list/list.module.ts +14 -0
- package/src/lib/data-list/list/toolbar-list-view.component.ts +63 -0
- package/src/lib/data-source/datasource.component.ts +50 -0
- package/src/lib/data-source/datasource.module.ts +11 -0
- package/{lib/data-source/read-param.d.ts → src/lib/data-source/read-param.ts} +13 -3
- package/src/lib/date-picker/date-picker.component.html +30 -0
- package/src/lib/date-picker/date-picker.component.scss +5 -0
- package/src/lib/date-picker/date-picker.component.ts +720 -0
- package/src/lib/date-picker/date-picker.module.ts +17 -0
- package/src/lib/dialog/dialog.component.html +5 -0
- package/src/lib/dialog/dialog.component.scss +32 -0
- package/src/lib/dialog/dialog.component.ts +32 -0
- package/src/lib/dialog/dialog.module.ts +13 -0
- package/src/lib/dialog/dialog.service.ts +178 -0
- package/src/lib/drawer/content.component.ts +18 -0
- package/src/lib/drawer/drawer-container.component.ts +37 -0
- package/src/lib/drawer/drawer.component.ts +151 -0
- package/src/lib/drawer/drawer.module.ts +16 -0
- package/src/lib/dropdown/dropdown.component.html +26 -0
- package/src/lib/dropdown/dropdown.component.scss +8 -0
- package/src/lib/dropdown/dropdown.component.ts +197 -0
- package/src/lib/dropdown/dropdown.module.ts +19 -0
- package/src/lib/fieldset/fieldset.component.html +6 -0
- package/src/lib/fieldset/fieldset.component.ts +49 -0
- package/src/lib/fieldset/fieldset.module.ts +11 -0
- package/src/lib/form-group/form-group.component.html +15 -0
- package/src/lib/form-group/form-group.component.ts +39 -0
- package/src/lib/form-group/form-group.module.ts +14 -0
- package/src/lib/label/label.component.html +5 -0
- package/src/lib/label/label.component.ts +18 -0
- package/src/lib/label/label.module.ts +14 -0
- package/src/lib/loading/loading-indicator.component.html +27 -0
- package/src/lib/loading/loading-indicator.component.ts +16 -0
- package/src/lib/loading/loading-panel.component.ts +37 -0
- package/src/lib/loading/loading.module.ts +13 -0
- package/src/lib/loading/loading.service.ts +44 -0
- package/src/lib/menu/menu-item.component.ts +41 -0
- package/src/lib/menu/menu.component.html +74 -0
- package/src/lib/menu/menu.component.ts +111 -0
- package/src/lib/menu/menu.module.ts +13 -0
- package/src/lib/menu/menu2.component.scss +59 -0
- package/src/lib/menu/menu2.component.ts +98 -0
- package/src/lib/number-box/number-box.component.html +32 -0
- package/src/lib/number-box/number-box.component.ts +641 -0
- package/src/lib/number-box/number-box.module.ts +13 -0
- package/src/lib/page/content.component.ts +18 -0
- package/src/lib/page/footer.component.ts +13 -0
- package/src/lib/page/page.component.ts +43 -0
- package/src/lib/page/page.module.ts +14 -0
- package/src/lib/panel-box/panel-box.component.html +19 -0
- package/src/lib/panel-box/panel-box.component.scss +25 -0
- package/src/lib/panel-box/panel-box.component.ts +87 -0
- package/src/lib/panel-box/panel-box.module.ts +10 -0
- package/src/lib/password-box/password-box.component.html +22 -0
- package/src/lib/password-box/password-box.component.ts +30 -0
- package/src/lib/password-box/password-box.module.ts +16 -0
- package/src/lib/popover/custom-cdk-overlay.service.ts +82 -0
- package/src/lib/popover/overlay.service.ts +102 -0
- package/src/lib/popover/popover.component.html +5 -0
- package/src/lib/popover/popover.component.scss +9 -0
- package/src/lib/popover/popover.component.ts +130 -0
- package/src/lib/popover/popover.module.ts +11 -0
- package/src/lib/popup/popup.component.html +33 -0
- package/src/lib/popup/popup.component.scss +167 -0
- package/src/lib/popup/popup.component.ts +184 -0
- package/src/lib/popup/popup.module.ts +16 -0
- package/src/lib/popup/popup.service.ts +103 -0
- package/src/lib/progress-bar/progress-bar.component.html +5 -0
- package/src/lib/progress-bar/progress-bar.component.ts +10 -0
- package/src/lib/progress-bar/progress-bar.module.ts +11 -0
- package/src/lib/property-editor/editors/check-editor/check-editor.ts +44 -0
- package/src/lib/property-editor/editors/check-editor/check.module.ts +14 -0
- package/src/lib/property-editor/editors/color-editor/color.editor.ts +30 -0
- package/src/lib/property-editor/editors/color-editor/color.module.ts +20 -0
- package/src/lib/property-editor/editors/column-editor/column.editor.html +75 -0
- package/src/lib/property-editor/editors/column-editor/column.editor.scss +193 -0
- package/src/lib/property-editor/editors/column-editor/column.editor.ts +124 -0
- package/src/lib/property-editor/editors/column-editor/column.module.ts +28 -0
- package/src/lib/property-editor/editors/conditional-color-editor/conditional-color.editor.html +80 -0
- package/src/lib/property-editor/editors/conditional-color-editor/conditional-color.editor.scss +71 -0
- package/src/lib/property-editor/editors/conditional-color-editor/conditional-color.editor.ts +232 -0
- package/src/lib/property-editor/editors/conditional-color-editor/conditional-color.module.ts +52 -0
- package/src/lib/property-editor/editors/date-editor/date.editor.ts +49 -0
- package/src/lib/property-editor/editors/date-editor/date.module.ts +20 -0
- package/src/lib/property-editor/editors/number-editor/number.editor.ts +46 -0
- package/src/lib/property-editor/editors/number-editor/number.module.ts +20 -0
- package/src/lib/property-editor/editors/range-editor/range.editor.html +67 -0
- package/src/lib/property-editor/editors/range-editor/range.editor.scss +68 -0
- package/src/lib/property-editor/editors/range-editor/range.editor.ts +153 -0
- package/src/lib/property-editor/editors/range-editor/range.module.ts +37 -0
- package/src/lib/property-editor/editors/searchbar-selectbox-editor/searchbar-selectbox-editor.html +8 -0
- package/src/lib/property-editor/editors/searchbar-selectbox-editor/searchbar-selectbox-editor.ts +70 -0
- package/src/lib/property-editor/editors/selectbox-editor/selectbox.editor.html +8 -0
- package/src/lib/property-editor/editors/selectbox-editor/selectbox.editor.ts +77 -0
- package/src/lib/property-editor/editors/selectbox-editor/selectbox.module.ts +18 -0
- package/src/lib/property-editor/editors/selection-editor/selection-editor.ts +52 -0
- package/src/lib/property-editor/editors/selection-editor/selection.module.ts +14 -0
- package/src/lib/property-editor/editors/switch-editor/number.editor.ts +26 -0
- package/src/lib/property-editor/editors/switch-editor/number.module.ts +21 -0
- package/src/lib/property-editor/editors/text-editor/text.editor.html +5 -0
- package/src/lib/property-editor/editors/text-editor/text.editor.ts +31 -0
- package/src/lib/property-editor/editors/text-editor/text.module.ts +20 -0
- package/src/lib/property-editor/editors/textarea-editor/textarea.editor.html +9 -0
- package/src/lib/property-editor/editors/textarea-editor/textarea.editor.ts +37 -0
- package/src/lib/property-editor/editors/textarea-editor/textarea.module.ts +20 -0
- package/src/lib/property-editor/editors/time-editor/time.editor.ts +38 -0
- package/src/lib/property-editor/editors/time-editor/time.module.ts +20 -0
- package/src/lib/property-editor/property-editor-renderer.directive.ts +165 -0
- package/src/lib/property-editor/property-editor.class.ts +178 -0
- package/src/lib/property-editor/property-editor.module.ts +115 -0
- package/src/lib/query-builder/query-builder-group.component.html +68 -0
- package/src/lib/query-builder/query-builder-group.component.ts +122 -0
- package/src/lib/query-builder/query-builder-popup/query-builder-popup.component.html +82 -0
- package/src/lib/query-builder/query-builder-popup/query-builder-popup.component.ts +178 -0
- package/src/lib/query-builder/query-builder-rule.component.html +135 -0
- package/src/lib/query-builder/query-builder-rule.component.ts +390 -0
- package/src/lib/query-builder/query-builder.class.ts +53 -0
- package/src/lib/query-builder/query-builder.component.html +3 -0
- package/src/lib/query-builder/query-builder.component.scss +286 -0
- package/src/lib/query-builder/query-builder.component.ts +220 -0
- package/src/lib/query-builder/query-builder.module.ts +44 -0
- package/src/lib/query-builder/query-builder.service.ts +188 -0
- package/src/lib/search-bar/search-bar.component.html +30 -0
- package/src/lib/search-bar/search-bar.component.scss +114 -0
- package/src/lib/search-bar/search-bar.component.ts +287 -0
- package/src/lib/search-bar/search-bar.module.ts +33 -0
- package/src/lib/searchbox/searchbox.component.html +25 -0
- package/src/lib/searchbox/searchbox.component.ts +85 -0
- package/src/lib/searchbox/searchbox.module.ts +17 -0
- package/src/lib/selectbox/selectbox.component.html +100 -0
- package/src/lib/selectbox/selectbox.component.ts +984 -0
- package/src/lib/selectbox/selectbox.module.ts +31 -0
- package/src/lib/selectbox/selectbox2.component.html +78 -0
- package/src/lib/selectbox/selectbox2.component.ts +603 -0
- package/src/lib/selection-list/selection-list.component.html +21 -0
- package/src/lib/selection-list/selection-list.component.ts +115 -0
- package/src/lib/selection-list/selection-list.module.ts +13 -0
- package/src/lib/switch/switch.component.html +4 -0
- package/src/lib/switch/switch.component.scss +65 -0
- package/src/lib/switch/switch.component.ts +57 -0
- package/src/lib/switch/switch.module.ts +14 -0
- package/src/lib/tab-page/tab-page-Renderer.component.ts +70 -0
- package/src/lib/tab-page/tab-page-host.component.ts +110 -0
- package/src/lib/tab-page/tab-page.module.ts +13 -0
- package/src/lib/tab-page/tab-page.service.ts +176 -0
- package/src/lib/tab-strip/tab-strip.component.html +6 -0
- package/src/lib/tab-strip/tab-strip.component.ts +47 -0
- package/src/lib/tab-strip/tab-strip.module.ts +11 -0
- package/src/lib/tab-view/dynamic-tabs.directive.ts +17 -0
- package/src/lib/tab-view/tab-view.component.html +33 -0
- package/src/lib/tab-view/tab-view.component.scss +0 -0
- package/src/lib/tab-view/tab-view.component.ts +129 -0
- package/src/lib/tab-view/tab-view.module.ts +12 -0
- package/src/lib/tab-view/tab.component.html +8 -0
- package/src/lib/tab-view/tab.component.ts +15 -0
- package/src/lib/textarea/textarea.component.html +13 -0
- package/src/lib/textarea/textarea.component.ts +24 -0
- package/src/lib/textarea/textarea.module.ts +14 -0
- package/src/lib/textbox/textbox.component.html +22 -0
- package/src/lib/textbox/textbox.component.ts +38 -0
- package/src/lib/textbox/textbox.module.ts +16 -0
- package/src/lib/time-picker/time-picker.component.html +21 -0
- package/src/lib/time-picker/time-picker.component.ts +1003 -0
- package/src/lib/time-picker/time-picker.module.ts +15 -0
- package/src/lib/toast/toast-message/toast-message.component.html +17 -0
- package/src/lib/toast/toast-message/toast-message.component.scss +75 -0
- package/src/lib/toast/toast-message/toast-message.component.ts +64 -0
- package/src/lib/toast/toast-wrapper/toast-wrapper.component.scss +15 -0
- package/src/lib/toast/toast-wrapper/toast-wrapper.component.ts +13 -0
- package/src/lib/toast/toast.module.ts +12 -0
- package/src/lib/toast/toast.service.ts +64 -0
- package/src/lib/toolbar/group-button/toolbar-group-button.component.ts +54 -0
- package/src/lib/toolbar/menu/toolbar-menu.component.html +4 -0
- package/src/lib/toolbar/menu/toolbar-menu.component.ts +81 -0
- package/src/lib/toolbar/search/toolbar-search.component.html +4 -0
- package/src/lib/toolbar/search/toolbar-search.component.scss +24 -0
- package/src/lib/toolbar/search/toolbar-search.component.ts +61 -0
- package/src/lib/toolbar/title/toolbar-title.component.ts +35 -0
- package/src/lib/toolbar/toolbar-item.ts +4 -0
- package/src/lib/toolbar/toolbar.component.html +4 -0
- package/src/lib/toolbar/toolbar.component.scss +9 -0
- package/src/lib/toolbar/toolbar.component.ts +16 -0
- package/src/lib/toolbar/toolbar.module.ts +25 -0
- package/src/lib/tooltip/tooltip.directive.ts +101 -0
- package/src/lib/tooltip/tooltip.module.ts +11 -0
- package/src/lib/tree-side-menu/tree-side-menu.component.html +43 -0
- package/src/lib/tree-side-menu/tree-side-menu.component.ts +698 -0
- package/src/lib/tree-side-menu/tree-side-menu.module.ts +19 -0
- package/src/lib/tree-view/tree-view.component.html +46 -0
- package/src/lib/tree-view/tree-view.component.ts +835 -0
- package/src/lib/tree-view/tree-view.module.ts +16 -0
- package/src/lib/upload-file/upload-file.component.html +16 -0
- package/src/lib/upload-file/upload-file.component.ts +230 -0
- package/src/lib/upload-file/upload-file.events.ts +11 -0
- package/src/lib/upload-file/upload-file.module.ts +16 -0
- package/src/lib/validation/validation-form.component.ts +78 -0
- package/src/lib/validation/validation-rule.widget.ts +112 -0
- package/src/lib/validation/validation.class.ts +22 -0
- package/src/lib/validation/validation.component.ts +92 -0
- package/src/lib/validation/validation.module.ts +28 -0
- package/{public-api.d.ts → src/public-api.ts} +61 -2
- package/src/test.ts +28 -0
- package/tsconfig.lib.json +25 -0
- package/tsconfig.lib.prod.json +6 -0
- package/tsconfig.spec.json +17 -0
- package/tslint.json +17 -0
- package/acorex-components.d.ts +0 -5
- package/esm2020/acorex-components.mjs +0 -5
- package/esm2020/lib/accordion/accordion.component.mjs +0 -44
- package/esm2020/lib/accordion/accordion.module.mjs +0 -20
- package/esm2020/lib/base/base-page.class.mjs +0 -94
- package/esm2020/lib/base/components.class.mjs +0 -17
- package/esm2020/lib/base/element.class.mjs +0 -294
- package/esm2020/lib/base/events.class.mjs +0 -11
- package/esm2020/lib/button/button.component.mjs +0 -71
- package/esm2020/lib/button/button.module.mjs +0 -21
- package/esm2020/lib/calendar/calendar-box/calendar-box.component.mjs +0 -413
- package/esm2020/lib/calendar/calendar-box/calendar-box.module.mjs +0 -22
- package/esm2020/lib/calendar/scheduler/scheduler-views.property.mjs +0 -54
- package/esm2020/lib/calendar/scheduler/scheduler.class.mjs +0 -18
- package/esm2020/lib/calendar/scheduler/scheduler.component.mjs +0 -213
- package/esm2020/lib/calendar/scheduler/scheduler.module.mjs +0 -68
- package/esm2020/lib/calendar/scheduler/toolbars/scheduler-toolbar-navigator.mjs +0 -132
- package/esm2020/lib/calendar/scheduler/toolbars/scheduler-toolbar-views.mjs +0 -37
- package/esm2020/lib/calendar/scheduler/views/agenda/scheduler-agenda-view.component.mjs +0 -47
- package/esm2020/lib/calendar/scheduler/views/daytime/scheduler-daytime-view.component.mjs +0 -95
- package/esm2020/lib/calendar/scheduler/views/month/scheduler-month-view.component.mjs +0 -204
- package/esm2020/lib/calendar/scheduler/views/scheduler-view.component.mjs +0 -99
- package/esm2020/lib/calendar/scheduler/views/timeline/scheduler-timeline-view.component.mjs +0 -77
- package/esm2020/lib/checkbox/checkbox.component.mjs +0 -98
- package/esm2020/lib/checkbox/checkbox.module.mjs +0 -20
- package/esm2020/lib/color-picker/color-box/color-box.component.mjs +0 -422
- package/esm2020/lib/color-picker/color-picker.component.mjs +0 -82
- package/esm2020/lib/color-picker/color-picker.module.mjs +0 -24
- package/esm2020/lib/context-menu/context-menu.component.mjs +0 -65
- package/esm2020/lib/context-menu/context-menu.directive.mjs +0 -135
- package/esm2020/lib/context-menu/context-menu.module.mjs +0 -20
- package/esm2020/lib/data-filter/columns/filter-column-date.component.mjs +0 -138
- package/esm2020/lib/data-filter/columns/filter-column-number.component.mjs +0 -117
- package/esm2020/lib/data-filter/columns/filter-column-selection.component.mjs +0 -74
- package/esm2020/lib/data-filter/columns/filter-column-string.component.mjs +0 -117
- package/esm2020/lib/data-filter/filter-panel/filter-panel.component.mjs +0 -258
- package/esm2020/lib/data-filter/filter.class.mjs +0 -44
- package/esm2020/lib/data-filter/filter.module.mjs +0 -90
- package/esm2020/lib/data-filter/toolbar/filter-toolbar.component.mjs +0 -166
- package/esm2020/lib/data-list/core/data-list.component.mjs +0 -40
- package/esm2020/lib/data-list/list/list.component.mjs +0 -124
- package/esm2020/lib/data-list/list/list.module.mjs +0 -22
- package/esm2020/lib/data-list/list/toolbar-list-view.component.mjs +0 -85
- package/esm2020/lib/data-source/datasource.component.mjs +0 -47
- package/esm2020/lib/data-source/datasource.module.mjs +0 -18
- package/esm2020/lib/data-source/read-param.mjs +0 -5
- package/esm2020/lib/date-picker/date-picker.component.mjs +0 -702
- package/esm2020/lib/date-picker/date-picker.module.mjs +0 -25
- package/esm2020/lib/dialog/dialog.component.mjs +0 -24
- package/esm2020/lib/dialog/dialog.module.mjs +0 -21
- package/esm2020/lib/dialog/dialog.service.mjs +0 -150
- package/esm2020/lib/drawer/content.component.mjs +0 -18
- package/esm2020/lib/drawer/drawer-container.component.mjs +0 -36
- package/esm2020/lib/drawer/drawer.component.mjs +0 -142
- package/esm2020/lib/drawer/drawer.module.mjs +0 -23
- package/esm2020/lib/dropdown/dropdown.component.mjs +0 -176
- package/esm2020/lib/dropdown/dropdown.module.mjs +0 -26
- package/esm2020/lib/fieldset/fieldset.component.mjs +0 -59
- package/esm2020/lib/fieldset/fieldset.module.mjs +0 -19
- package/esm2020/lib/form-group/form-group.component.mjs +0 -34
- package/esm2020/lib/form-group/form-group.module.mjs +0 -21
- package/esm2020/lib/label/label.component.mjs +0 -19
- package/esm2020/lib/label/label.module.mjs +0 -21
- package/esm2020/lib/loading/loading-indicator.component.mjs +0 -17
- package/esm2020/lib/loading/loading-panel.component.mjs +0 -44
- package/esm2020/lib/loading/loading.module.mjs +0 -21
- package/esm2020/lib/loading/loading.service.mjs +0 -45
- package/esm2020/lib/menu/menu-item.component.mjs +0 -47
- package/esm2020/lib/menu/menu.component.mjs +0 -86
- package/esm2020/lib/menu/menu.module.mjs +0 -22
- package/esm2020/lib/menu/menu2.component.mjs +0 -96
- package/esm2020/lib/number-box/number-box.component.mjs +0 -622
- package/esm2020/lib/number-box/number-box.module.mjs +0 -21
- package/esm2020/lib/page/content.component.mjs +0 -32
- package/esm2020/lib/page/footer.component.mjs +0 -19
- package/esm2020/lib/page/page.component.mjs +0 -53
- package/esm2020/lib/page/page.module.mjs +0 -22
- package/esm2020/lib/panel-box/panel-box.component.mjs +0 -88
- package/esm2020/lib/panel-box/panel-box.module.mjs +0 -19
- package/esm2020/lib/password-box/password-box.component.mjs +0 -31
- package/esm2020/lib/password-box/password-box.module.mjs +0 -23
- package/esm2020/lib/popover/custom-cdk-overlay.service.mjs +0 -48
- package/esm2020/lib/popover/overlay.service.mjs +0 -90
- package/esm2020/lib/popover/popover.component.mjs +0 -127
- package/esm2020/lib/popover/popover.module.mjs +0 -19
- package/esm2020/lib/popup/popup.component.mjs +0 -147
- package/esm2020/lib/popup/popup.module.mjs +0 -25
- package/esm2020/lib/popup/popup.service.mjs +0 -93
- package/esm2020/lib/progress-bar/progress-bar.component.mjs +0 -19
- package/esm2020/lib/progress-bar/progress-bar.module.mjs +0 -19
- package/esm2020/lib/property-editor/editors/check-editor/check-editor.mjs +0 -61
- package/esm2020/lib/property-editor/editors/check-editor/check.module.mjs +0 -22
- package/esm2020/lib/property-editor/editors/color-editor/color.editor.mjs +0 -38
- package/esm2020/lib/property-editor/editors/color-editor/color.module.mjs +0 -24
- package/esm2020/lib/property-editor/editors/column-editor/column.editor.mjs +0 -115
- package/esm2020/lib/property-editor/editors/column-editor/column.module.mjs +0 -32
- package/esm2020/lib/property-editor/editors/conditional-color-editor/conditional-color.editor.mjs +0 -211
- package/esm2020/lib/property-editor/editors/conditional-color-editor/conditional-color.module.mjs +0 -78
- package/esm2020/lib/property-editor/editors/date-editor/date.editor.mjs +0 -51
- package/esm2020/lib/property-editor/editors/date-editor/date.module.mjs +0 -24
- package/esm2020/lib/property-editor/editors/number-editor/number.editor.mjs +0 -63
- package/esm2020/lib/property-editor/editors/number-editor/number.module.mjs +0 -24
- package/esm2020/lib/property-editor/editors/range-editor/range.editor.mjs +0 -140
- package/esm2020/lib/property-editor/editors/range-editor/range.module.mjs +0 -61
- package/esm2020/lib/property-editor/editors/searchbar-selectbox-editor/searchbar-selectbox-editor.mjs +0 -72
- package/esm2020/lib/property-editor/editors/selectbox-editor/selectbox.editor.mjs +0 -71
- package/esm2020/lib/property-editor/editors/selectbox-editor/selectbox.module.mjs +0 -25
- package/esm2020/lib/property-editor/editors/selection-editor/selection-editor.mjs +0 -69
- package/esm2020/lib/property-editor/editors/selection-editor/selection.module.mjs +0 -22
- package/esm2020/lib/property-editor/editors/switch-editor/number.editor.mjs +0 -29
- package/esm2020/lib/property-editor/editors/switch-editor/number.module.mjs +0 -25
- package/esm2020/lib/property-editor/editors/text-editor/text.editor.mjs +0 -32
- package/esm2020/lib/property-editor/editors/text-editor/text.module.mjs +0 -24
- package/esm2020/lib/property-editor/editors/textarea-editor/textarea.editor.mjs +0 -32
- package/esm2020/lib/property-editor/editors/textarea-editor/textarea.module.mjs +0 -24
- package/esm2020/lib/property-editor/editors/time-editor/time.editor.mjs +0 -43
- package/esm2020/lib/property-editor/editors/time-editor/time.module.mjs +0 -24
- package/esm2020/lib/property-editor/property-editor-renderer.directive.mjs +0 -154
- package/esm2020/lib/property-editor/property-editor.class.mjs +0 -101
- package/esm2020/lib/property-editor/property-editor.module.mjs +0 -196
- package/esm2020/lib/query-builder/query-builder-group.component.mjs +0 -124
- package/esm2020/lib/query-builder/query-builder-popup/query-builder-popup.component.mjs +0 -171
- package/esm2020/lib/query-builder/query-builder-rule.component.mjs +0 -395
- package/esm2020/lib/query-builder/query-builder.class.mjs +0 -20
- package/esm2020/lib/query-builder/query-builder.component.mjs +0 -82
- package/esm2020/lib/query-builder/query-builder.module.mjs +0 -62
- package/esm2020/lib/query-builder/query-builder.service.mjs +0 -197
- package/esm2020/lib/search-bar/search-bar.component.mjs +0 -283
- package/esm2020/lib/search-bar/search-bar.module.mjs +0 -63
- package/esm2020/lib/searchbox/searchbox.component.mjs +0 -79
- package/esm2020/lib/searchbox/searchbox.module.mjs +0 -24
- package/esm2020/lib/selectbox/selectbox.component.mjs +0 -961
- package/esm2020/lib/selectbox/selectbox.module.mjs +0 -44
- package/esm2020/lib/selectbox/selectbox2.component.mjs +0 -574
- package/esm2020/lib/selection-list/selection-list.component.mjs +0 -108
- package/esm2020/lib/selection-list/selection-list.module.mjs +0 -21
- package/esm2020/lib/switch/switch.component.mjs +0 -51
- package/esm2020/lib/switch/switch.module.mjs +0 -20
- package/esm2020/lib/tab-page/tab-page-Renderer.component.mjs +0 -71
- package/esm2020/lib/tab-page/tab-page-host.component.mjs +0 -116
- package/esm2020/lib/tab-page/tab-page.module.mjs +0 -21
- package/esm2020/lib/tab-page/tab-page.service.mjs +0 -156
- package/esm2020/lib/tab-strip/tab-strip.component.mjs +0 -36
- package/esm2020/lib/tab-strip/tab-strip.module.mjs +0 -19
- package/esm2020/lib/tab-view/dynamic-tabs.directive.mjs +0 -24
- package/esm2020/lib/tab-view/tab-view.component.mjs +0 -105
- package/esm2020/lib/tab-view/tab-view.module.mjs +0 -21
- package/esm2020/lib/tab-view/tab.component.mjs +0 -30
- package/esm2020/lib/textarea/textarea.component.mjs +0 -26
- package/esm2020/lib/textarea/textarea.module.mjs +0 -21
- package/esm2020/lib/textbox/textbox.component.mjs +0 -39
- package/esm2020/lib/textbox/textbox.module.mjs +0 -24
- package/esm2020/lib/time-picker/time-picker.component.mjs +0 -943
- package/esm2020/lib/time-picker/time-picker.module.mjs +0 -22
- package/esm2020/lib/toast/toast-message/toast-message.component.mjs +0 -74
- package/esm2020/lib/toast/toast-wrapper/toast-wrapper.component.mjs +0 -13
- package/esm2020/lib/toast/toast.module.mjs +0 -21
- package/esm2020/lib/toast/toast.service.mjs +0 -44
- package/esm2020/lib/toolbar/group-button/toolbar-group-button.component.mjs +0 -78
- package/esm2020/lib/toolbar/menu/toolbar-menu.component.mjs +0 -57
- package/esm2020/lib/toolbar/search/toolbar-search.component.mjs +0 -54
- package/esm2020/lib/toolbar/title/toolbar-title.component.mjs +0 -47
- package/esm2020/lib/toolbar/toolbar-item.mjs +0 -6
- package/esm2020/lib/toolbar/toolbar.component.mjs +0 -13
- package/esm2020/lib/toolbar/toolbar.module.mjs +0 -40
- package/esm2020/lib/tooltip/tooltip.directive.mjs +0 -100
- package/esm2020/lib/tooltip/tooltip.module.mjs +0 -19
- package/esm2020/lib/tree-side-menu/tree-side-menu.component.mjs +0 -646
- package/esm2020/lib/tree-side-menu/tree-side-menu.module.mjs +0 -35
- package/esm2020/lib/tree-view/tree-view.component.mjs +0 -775
- package/esm2020/lib/tree-view/tree-view.module.mjs +0 -22
- package/esm2020/lib/upload-file/upload-file.component.mjs +0 -208
- package/esm2020/lib/upload-file/upload-file.events.mjs +0 -2
- package/esm2020/lib/upload-file/upload-file.module.mjs +0 -24
- package/esm2020/lib/validation/validation-form.component.mjs +0 -65
- package/esm2020/lib/validation/validation-rule.widget.mjs +0 -111
- package/esm2020/lib/validation/validation.class.mjs +0 -2
- package/esm2020/lib/validation/validation.component.mjs +0 -89
- package/esm2020/lib/validation/validation.module.mjs +0 -34
- package/esm2020/public-api.mjs +0 -158
- package/fesm2015/acorex-components.mjs +0 -15988
- package/fesm2015/acorex-components.mjs.map +0 -1
- package/fesm2020/acorex-components.mjs +0 -15923
- package/fesm2020/acorex-components.mjs.map +0 -1
- package/lib/accordion/accordion.component.d.ts +0 -13
- package/lib/accordion/accordion.module.d.ts +0 -9
- package/lib/base/base-page.class.d.ts +0 -46
- package/lib/base/components.class.d.ts +0 -10
- package/lib/base/element.class.d.ts +0 -106
- package/lib/base/events.class.d.ts +0 -18
- package/lib/button/button.component.d.ts +0 -21
- package/lib/button/button.module.d.ts +0 -8
- package/lib/calendar/calendar-box/calendar-box.component.d.ts +0 -81
- package/lib/calendar/calendar-box/calendar-box.module.d.ts +0 -11
- package/lib/calendar/scheduler/scheduler-views.property.d.ts +0 -19
- package/lib/calendar/scheduler/scheduler.component.d.ts +0 -39
- package/lib/calendar/scheduler/scheduler.module.d.ts +0 -21
- package/lib/calendar/scheduler/toolbars/scheduler-toolbar-navigator.d.ts +0 -25
- package/lib/calendar/scheduler/toolbars/scheduler-toolbar-views.d.ts +0 -14
- package/lib/calendar/scheduler/views/agenda/scheduler-agenda-view.component.d.ts +0 -16
- package/lib/calendar/scheduler/views/daytime/scheduler-daytime-view.component.d.ts +0 -26
- package/lib/calendar/scheduler/views/month/scheduler-month-view.component.d.ts +0 -37
- package/lib/calendar/scheduler/views/scheduler-view.component.d.ts +0 -28
- package/lib/calendar/scheduler/views/timeline/scheduler-timeline-view.component.d.ts +0 -24
- package/lib/checkbox/checkbox.component.d.ts +0 -30
- package/lib/checkbox/checkbox.module.d.ts +0 -9
- package/lib/color-picker/color-box/color-box.component.d.ts +0 -25
- package/lib/color-picker/color-picker.component.d.ts +0 -30
- package/lib/color-picker/color-picker.module.d.ts +0 -13
- package/lib/context-menu/context-menu.component.d.ts +0 -22
- package/lib/context-menu/context-menu.directive.d.ts +0 -38
- package/lib/context-menu/context-menu.module.d.ts +0 -9
- package/lib/data-filter/columns/filter-column-date.component.d.ts +0 -22
- package/lib/data-filter/columns/filter-column-number.component.d.ts +0 -15
- package/lib/data-filter/columns/filter-column-selection.component.d.ts +0 -18
- package/lib/data-filter/columns/filter-column-string.component.d.ts +0 -15
- package/lib/data-filter/filter-panel/filter-panel.component.d.ts +0 -45
- package/lib/data-filter/filter.class.d.ts +0 -40
- package/lib/data-filter/filter.module.d.ts +0 -24
- package/lib/data-filter/toolbar/filter-toolbar.component.d.ts +0 -25
- package/lib/data-list/core/data-list.component.d.ts +0 -15
- package/lib/data-list/list/list.component.d.ts +0 -40
- package/lib/data-list/list/list.module.d.ts +0 -11
- package/lib/data-list/list/toolbar-list-view.component.d.ts +0 -17
- package/lib/data-source/datasource.component.d.ts +0 -16
- package/lib/data-source/datasource.module.d.ts +0 -7
- package/lib/date-picker/date-picker.component.d.ts +0 -81
- package/lib/date-picker/date-picker.module.d.ts +0 -14
- package/lib/dialog/dialog.component.d.ts +0 -14
- package/lib/dialog/dialog.module.d.ts +0 -10
- package/lib/dialog/dialog.service.d.ts +0 -36
- package/lib/drawer/content.component.d.ts +0 -7
- package/lib/drawer/drawer-container.component.d.ts +0 -10
- package/lib/drawer/drawer.component.d.ts +0 -34
- package/lib/drawer/drawer.module.d.ts +0 -10
- package/lib/dropdown/dropdown.component.d.ts +0 -38
- package/lib/dropdown/dropdown.module.d.ts +0 -13
- package/lib/fieldset/fieldset.component.d.ts +0 -11
- package/lib/fieldset/fieldset.module.d.ts +0 -8
- package/lib/form-group/form-group.component.d.ts +0 -14
- package/lib/form-group/form-group.module.d.ts +0 -8
- package/lib/label/label.component.d.ts +0 -9
- package/lib/label/label.module.d.ts +0 -8
- package/lib/loading/loading-indicator.component.d.ts +0 -9
- package/lib/loading/loading-panel.component.d.ts +0 -13
- package/lib/loading/loading.module.d.ts +0 -10
- package/lib/loading/loading.service.d.ts +0 -13
- package/lib/menu/menu-item.component.d.ts +0 -18
- package/lib/menu/menu.component.d.ts +0 -35
- package/lib/menu/menu.module.d.ts +0 -11
- package/lib/menu/menu2.component.d.ts +0 -21
- package/lib/number-box/number-box.component.d.ts +0 -52
- package/lib/number-box/number-box.module.d.ts +0 -10
- package/lib/page/content.component.d.ts +0 -8
- package/lib/page/footer.component.d.ts +0 -5
- package/lib/page/page.component.d.ts +0 -16
- package/lib/page/page.module.d.ts +0 -11
- package/lib/panel-box/panel-box.component.d.ts +0 -19
- package/lib/panel-box/panel-box.module.d.ts +0 -8
- package/lib/password-box/password-box.component.d.ts +0 -12
- package/lib/password-box/password-box.module.d.ts +0 -10
- package/lib/popover/custom-cdk-overlay.service.d.ts +0 -19
- package/lib/popover/overlay.service.d.ts +0 -31
- package/lib/popover/popover.component.d.ts +0 -34
- package/lib/popover/popover.module.d.ts +0 -8
- package/lib/popup/popup.component.d.ts +0 -40
- package/lib/popup/popup.module.d.ts +0 -13
- package/lib/popup/popup.service.d.ts +0 -22
- package/lib/progress-bar/progress-bar.component.d.ts +0 -7
- package/lib/progress-bar/progress-bar.module.d.ts +0 -8
- package/lib/property-editor/editors/check-editor/check-editor.d.ts +0 -19
- package/lib/property-editor/editors/check-editor/check.module.d.ts +0 -11
- package/lib/property-editor/editors/color-editor/color.editor.d.ts +0 -13
- package/lib/property-editor/editors/color-editor/color.module.d.ts +0 -12
- package/lib/property-editor/editors/column-editor/column.editor.d.ts +0 -34
- package/lib/property-editor/editors/column-editor/column.module.d.ts +0 -20
- package/lib/property-editor/editors/conditional-color-editor/conditional-color.editor.d.ts +0 -44
- package/lib/property-editor/editors/conditional-color-editor/conditional-color.module.d.ts +0 -19
- package/lib/property-editor/editors/date-editor/date.editor.d.ts +0 -28
- package/lib/property-editor/editors/date-editor/date.module.d.ts +0 -12
- package/lib/property-editor/editors/number-editor/number.editor.d.ts +0 -20
- package/lib/property-editor/editors/number-editor/number.module.d.ts +0 -12
- package/lib/property-editor/editors/range-editor/range.editor.d.ts +0 -29
- package/lib/property-editor/editors/range-editor/range.module.d.ts +0 -18
- package/lib/property-editor/editors/searchbar-selectbox-editor/searchbar-selectbox-editor.d.ts +0 -29
- package/lib/property-editor/editors/selectbox-editor/selectbox.editor.d.ts +0 -28
- package/lib/property-editor/editors/selectbox-editor/selectbox.module.d.ts +0 -14
- package/lib/property-editor/editors/selection-editor/selection-editor.d.ts +0 -25
- package/lib/property-editor/editors/selection-editor/selection.module.d.ts +0 -11
- package/lib/property-editor/editors/switch-editor/number.editor.d.ts +0 -11
- package/lib/property-editor/editors/switch-editor/number.module.d.ts +0 -13
- package/lib/property-editor/editors/text-editor/text.editor.d.ts +0 -18
- package/lib/property-editor/editors/text-editor/text.module.d.ts +0 -12
- package/lib/property-editor/editors/textarea-editor/textarea.editor.d.ts +0 -17
- package/lib/property-editor/editors/textarea-editor/textarea.module.d.ts +0 -12
- package/lib/property-editor/editors/time-editor/time.editor.d.ts +0 -17
- package/lib/property-editor/editors/time-editor/time.module.d.ts +0 -12
- package/lib/property-editor/property-editor-renderer.directive.d.ts +0 -30
- package/lib/property-editor/property-editor.class.d.ts +0 -92
- package/lib/property-editor/property-editor.module.d.ts +0 -21
- package/lib/query-builder/query-builder-group.component.d.ts +0 -33
- package/lib/query-builder/query-builder-popup/query-builder-popup.component.d.ts +0 -35
- package/lib/query-builder/query-builder-rule.component.d.ts +0 -45
- package/lib/query-builder/query-builder.class.d.ts +0 -45
- package/lib/query-builder/query-builder.component.d.ts +0 -27
- package/lib/query-builder/query-builder.module.d.ts +0 -23
- package/lib/query-builder/query-builder.service.d.ts +0 -18
- package/lib/search-bar/search-bar.component.d.ts +0 -61
- package/lib/search-bar/search-bar.module.d.ts +0 -18
- package/lib/searchbox/searchbox.component.d.ts +0 -22
- package/lib/searchbox/searchbox.module.d.ts +0 -13
- package/lib/selectbox/selectbox.component.d.ts +0 -118
- package/lib/selectbox/selectbox.module.d.ts +0 -15
- package/lib/selectbox/selectbox2.component.d.ts +0 -103
- package/lib/selection-list/selection-list.component.d.ts +0 -32
- package/lib/selection-list/selection-list.module.d.ts +0 -10
- package/lib/switch/switch.component.d.ts +0 -20
- package/lib/switch/switch.module.d.ts +0 -9
- package/lib/tab-page/tab-page-Renderer.component.d.ts +0 -16
- package/lib/tab-page/tab-page-host.component.d.ts +0 -25
- package/lib/tab-page/tab-page.module.d.ts +0 -10
- package/lib/tab-page/tab-page.service.d.ts +0 -30
- package/lib/tab-strip/tab-strip.component.d.ts +0 -28
- package/lib/tab-strip/tab-strip.module.d.ts +0 -8
- package/lib/tab-view/dynamic-tabs.directive.d.ts +0 -16
- package/lib/tab-view/tab-view.component.d.ts +0 -26
- package/lib/tab-view/tab-view.module.d.ts +0 -10
- package/lib/tab-view/tab.component.d.ts +0 -12
- package/lib/textarea/textarea.component.d.ts +0 -12
- package/lib/textarea/textarea.module.d.ts +0 -8
- package/lib/textbox/textbox.component.d.ts +0 -16
- package/lib/textbox/textbox.module.d.ts +0 -11
- package/lib/time-picker/time-picker.component.d.ts +0 -52
- package/lib/time-picker/time-picker.module.d.ts +0 -11
- package/lib/toast/toast-message/toast-message.component.d.ts +0 -18
- package/lib/toast/toast-wrapper/toast-wrapper.component.d.ts +0 -8
- package/lib/toast/toast.module.d.ts +0 -9
- package/lib/toast/toast.service.d.ts +0 -18
- package/lib/toolbar/group-button/toolbar-group-button.component.d.ts +0 -12
- package/lib/toolbar/menu/toolbar-menu.component.d.ts +0 -24
- package/lib/toolbar/search/toolbar-search.component.d.ts +0 -16
- package/lib/toolbar/title/toolbar-title.component.d.ts +0 -9
- package/lib/toolbar/toolbar-item.d.ts +0 -3
- package/lib/toolbar/toolbar.component.d.ts +0 -8
- package/lib/toolbar/toolbar.module.d.ts +0 -14
- package/lib/tooltip/tooltip.directive.d.ts +0 -21
- package/lib/tooltip/tooltip.module.d.ts +0 -8
- package/lib/tree-side-menu/tree-side-menu.component.d.ts +0 -111
- package/lib/tree-side-menu/tree-side-menu.module.d.ts +0 -11
- package/lib/tree-view/tree-view.component.d.ts +0 -121
- package/lib/tree-view/tree-view.module.d.ts +0 -11
- package/lib/upload-file/upload-file.component.d.ts +0 -42
- package/lib/upload-file/upload-file.events.d.ts +0 -10
- package/lib/upload-file/upload-file.module.d.ts +0 -13
- package/lib/validation/validation-form.component.d.ts +0 -19
- package/lib/validation/validation-rule.widget.d.ts +0 -23
- package/lib/validation/validation.class.d.ts +0 -16
- package/lib/validation/validation.component.d.ts +0 -25
- package/lib/validation/validation.module.d.ts +0 -11
@@ -0,0 +1,197 @@
|
|
1
|
+
import {
|
2
|
+
Component,
|
3
|
+
ViewEncapsulation,
|
4
|
+
ChangeDetectionStrategy,
|
5
|
+
ViewChild,
|
6
|
+
Input,
|
7
|
+
ElementRef,
|
8
|
+
AfterViewInit,
|
9
|
+
HostListener,
|
10
|
+
Output,
|
11
|
+
EventEmitter,
|
12
|
+
ChangeDetectorRef,
|
13
|
+
ViewContainerRef,
|
14
|
+
TemplateRef,
|
15
|
+
OnDestroy,
|
16
|
+
DebugElement
|
17
|
+
} from '@angular/core';
|
18
|
+
import { AXBaseDropdownComponent } from '../base/element.class';
|
19
|
+
import { AXHtmlEvent } from '../base/events.class';
|
20
|
+
import { Overlay, OverlayRef } from '@angular/cdk/overlay';
|
21
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
22
|
+
import { AXConfig } from '@acorex/core';
|
23
|
+
|
24
|
+
@Component({
|
25
|
+
selector: 'ax-drop-down',
|
26
|
+
templateUrl: './dropdown.component.html',
|
27
|
+
styleUrls: ['./dropdown.component.scss'],
|
28
|
+
encapsulation: ViewEncapsulation.None,
|
29
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
30
|
+
host: { style: 'display:contents;' }
|
31
|
+
})
|
32
|
+
export class AXDropdownComponent extends AXBaseDropdownComponent implements AfterViewInit, OnDestroy {
|
33
|
+
@ViewChild('baseTemplate') baseTemplate: TemplateRef<any>;
|
34
|
+
@ViewChild('content', { static: false }) content: ElementRef<HTMLDivElement>;
|
35
|
+
@ViewChild('endButtons', { static: false }) endButtons: ElementRef<HTMLDivElement>;
|
36
|
+
@ViewChild('el', { static: true }) dropdownEL: ElementRef<HTMLDivElement>;
|
37
|
+
|
38
|
+
@Input()
|
39
|
+
rtl: boolean = AXConfig.get('layout.rtl');
|
40
|
+
|
41
|
+
@Input()
|
42
|
+
readonly: boolean = false;
|
43
|
+
|
44
|
+
@Input()
|
45
|
+
loading: boolean = false;
|
46
|
+
|
47
|
+
@Output()
|
48
|
+
dropdownToggle: EventEmitter<any> = new EventEmitter<any>();
|
49
|
+
|
50
|
+
@Output()
|
51
|
+
onButtonClick: EventEmitter<AXHtmlEvent<MouseEvent>> = new EventEmitter<AXHtmlEvent<MouseEvent>>();
|
52
|
+
|
53
|
+
@HostListener('keydown', ['$event'])
|
54
|
+
onKeydownHandler(e: KeyboardEvent) {
|
55
|
+
if (!this.disabled && e.key === 'Enter' && e.type === 'keydown') {
|
56
|
+
if (!this.readonly) {
|
57
|
+
this.toggle();
|
58
|
+
// this.dropdownToggle.emit({ mode: 'enter' });
|
59
|
+
}
|
60
|
+
}
|
61
|
+
if (e.key === 'Escape') {
|
62
|
+
if (this.isOpen) {
|
63
|
+
this.close();
|
64
|
+
e.stopPropagation();
|
65
|
+
}
|
66
|
+
}
|
67
|
+
}
|
68
|
+
|
69
|
+
@Input()
|
70
|
+
dropdownWidth: string = "300px";
|
71
|
+
|
72
|
+
private overlayRef: OverlayRef;
|
73
|
+
private templatePortal: TemplatePortal;
|
74
|
+
|
75
|
+
constructor(
|
76
|
+
private cdr: ChangeDetectorRef,
|
77
|
+
private ref: ElementRef<HTMLDivElement>,
|
78
|
+
private overlay: Overlay,
|
79
|
+
private viewContainerRef: ViewContainerRef
|
80
|
+
) {
|
81
|
+
super();
|
82
|
+
}
|
83
|
+
|
84
|
+
ngOnInit(): void {
|
85
|
+
if (this.rtl == null) {
|
86
|
+
this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';
|
87
|
+
}
|
88
|
+
setTimeout(() => {
|
89
|
+
this.ref.nativeElement.classList.add(this.rtl ? 'rtl' : 'ltr');
|
90
|
+
this.dropdownEL.nativeElement.classList.add(this.rtl ? 'rtl' : 'ltr');
|
91
|
+
}, 5);
|
92
|
+
}
|
93
|
+
ngAfterViewInit(): void {
|
94
|
+
setTimeout(() => {
|
95
|
+
if (this.endButtons && this.endButtons.nativeElement.childNodes.length !== 0) {
|
96
|
+
this.content.nativeElement.style.paddingInlineEnd = `${this.endButtons.nativeElement.clientWidth}px`;
|
97
|
+
}
|
98
|
+
if (this.fitParent == true) {
|
99
|
+
this.dropdownWidth = `${this.dropdownEL.nativeElement.offsetWidth}px`;
|
100
|
+
}
|
101
|
+
}, 5);
|
102
|
+
}
|
103
|
+
|
104
|
+
ngOnDestroy(): void {
|
105
|
+
this.overlayRef?.detach();
|
106
|
+
this.overlayRef?.dispose();
|
107
|
+
}
|
108
|
+
|
109
|
+
handleArrowClick(e: AXHtmlEvent<MouseEvent>) {
|
110
|
+
setTimeout(() => {
|
111
|
+
this.toggle();
|
112
|
+
}, 0);
|
113
|
+
}
|
114
|
+
|
115
|
+
toggle() {
|
116
|
+
if (this.disabled !== true) {
|
117
|
+
this.isOpen ? this.close() : this.open();
|
118
|
+
}
|
119
|
+
}
|
120
|
+
|
121
|
+
close() {
|
122
|
+
if (!this.isOpen) {
|
123
|
+
return;
|
124
|
+
}
|
125
|
+
this.overlayRef?.detach();
|
126
|
+
this.dropdownToggle.emit({ mode: 'close' });
|
127
|
+
}
|
128
|
+
|
129
|
+
open() {
|
130
|
+
if (this.isOpen) {
|
131
|
+
return;
|
132
|
+
}
|
133
|
+
this.ensureOverlayCreated();
|
134
|
+
this.overlayRef.attach(this.templatePortal);
|
135
|
+
this.dropdownToggle.emit({ mode: 'open' });
|
136
|
+
}
|
137
|
+
|
138
|
+
private ensureOverlayCreated() {
|
139
|
+
if (!this.overlayRef) {
|
140
|
+
const targetEl = document.querySelector<HTMLElement>('#' + this.uid);
|
141
|
+
const positionStrategy = this.overlay
|
142
|
+
.position()
|
143
|
+
.flexibleConnectedTo(targetEl)
|
144
|
+
.withPositions([
|
145
|
+
{
|
146
|
+
originX: 'start',
|
147
|
+
originY: 'bottom',
|
148
|
+
overlayX: 'start',
|
149
|
+
overlayY: 'top'
|
150
|
+
},
|
151
|
+
{
|
152
|
+
originX: 'start',
|
153
|
+
originY: 'bottom',
|
154
|
+
overlayX: 'start',
|
155
|
+
overlayY: 'bottom'
|
156
|
+
},
|
157
|
+
{
|
158
|
+
originX: 'end',
|
159
|
+
originY: 'bottom',
|
160
|
+
overlayX: 'end',
|
161
|
+
overlayY: 'top'
|
162
|
+
},
|
163
|
+
{
|
164
|
+
originX: 'end',
|
165
|
+
originY: 'bottom',
|
166
|
+
overlayX: 'end',
|
167
|
+
overlayY: 'bottom'
|
168
|
+
}
|
169
|
+
])
|
170
|
+
.withPush(false);
|
171
|
+
this.overlayRef = this.overlay.create({
|
172
|
+
positionStrategy,
|
173
|
+
|
174
|
+
//width: this.dropdownEL.nativeElement.clientWidth,
|
175
|
+
scrollStrategy: this.overlay.scrollStrategies.reposition({
|
176
|
+
autoClose: true
|
177
|
+
}),
|
178
|
+
hasBackdrop: true,
|
179
|
+
backdropClass: 'cdk-overlay-transparent-backdrop'
|
180
|
+
});
|
181
|
+
this.overlayRef.setDirection(this.rtl ? 'rtl' : 'ltr');
|
182
|
+
this.overlayRef.backdropClick().subscribe(() => this.close());
|
183
|
+
}
|
184
|
+
if (!this.templatePortal) {
|
185
|
+
this.templatePortal = new TemplatePortal(this.baseTemplate, this.viewContainerRef);
|
186
|
+
}
|
187
|
+
}
|
188
|
+
|
189
|
+
get isOpen(): boolean {
|
190
|
+
return this.overlayRef ? this.overlayRef.hasAttached() : false;
|
191
|
+
}
|
192
|
+
|
193
|
+
updatePosition(): void {
|
194
|
+
this.overlayRef?.updatePosition();
|
195
|
+
}
|
196
|
+
focus() { }
|
197
|
+
}
|
@@ -0,0 +1,19 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import { AXDropdownComponent } from './dropdown.component';
|
4
|
+
import { AXFormGroupModule } from '../form-group/form-group.module';
|
5
|
+
import { AXTextBoxModule } from '../textbox/textbox.module';
|
6
|
+
import { AXButtonModule } from '../button/button.module';
|
7
|
+
import { AXPopoverModule } from '../popover/popover.module';
|
8
|
+
import { OverlayModule } from '@angular/cdk/overlay';
|
9
|
+
|
10
|
+
const COMPONENT = [AXDropdownComponent];
|
11
|
+
const MODULES = [CommonModule, AXFormGroupModule, AXTextBoxModule, AXButtonModule, AXPopoverModule, OverlayModule];
|
12
|
+
|
13
|
+
@NgModule({
|
14
|
+
declarations: [...COMPONENT],
|
15
|
+
imports: [...MODULES],
|
16
|
+
exports: [...COMPONENT],
|
17
|
+
providers: [],
|
18
|
+
})
|
19
|
+
export class AXDropdownModule { }
|
@@ -0,0 +1,49 @@
|
|
1
|
+
import { Component, OnInit, ViewEncapsulation, ChangeDetectionStrategy, Input } from '@angular/core';
|
2
|
+
import { trigger, state, style, transition, animate } from '@angular/animations';
|
3
|
+
import { AXBaseSizableComponent, AXElementSize } from '../base/element.class';
|
4
|
+
|
5
|
+
@Component({
|
6
|
+
selector: 'ax-fieldset',
|
7
|
+
templateUrl: './fieldset.component.html',
|
8
|
+
encapsulation: ViewEncapsulation.None,
|
9
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
10
|
+
animations: [
|
11
|
+
trigger('visibilityChanged', [
|
12
|
+
state(
|
13
|
+
'shown',
|
14
|
+
style({
|
15
|
+
height: '*',
|
16
|
+
opacity: 1
|
17
|
+
})
|
18
|
+
),
|
19
|
+
state(
|
20
|
+
'hidden',
|
21
|
+
style({
|
22
|
+
height: '0px',
|
23
|
+
opacity: 0,
|
24
|
+
padding: 0
|
25
|
+
})
|
26
|
+
),
|
27
|
+
transition('Void => *', animate('0ms')),
|
28
|
+
transition('shown => hidden', animate('200ms')),
|
29
|
+
transition('hidden => shown', animate('200ms'))
|
30
|
+
])
|
31
|
+
]
|
32
|
+
})
|
33
|
+
export class AXFieldsetComponent implements AXBaseSizableComponent {
|
34
|
+
@Input()
|
35
|
+
size: AXElementSize = "md";
|
36
|
+
|
37
|
+
@Input()
|
38
|
+
caption: string = '';
|
39
|
+
|
40
|
+
@Input()
|
41
|
+
allowCollapse: boolean = false;
|
42
|
+
|
43
|
+
collapsed: boolean = false;
|
44
|
+
toggle() {
|
45
|
+
if (this.allowCollapse) {
|
46
|
+
this.collapsed = !this.collapsed;
|
47
|
+
}
|
48
|
+
}
|
49
|
+
}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import { AXFieldsetComponent } from './fieldset.component';
|
4
|
+
|
5
|
+
@NgModule({
|
6
|
+
declarations: [AXFieldsetComponent],
|
7
|
+
imports: [ CommonModule ],
|
8
|
+
exports: [AXFieldsetComponent],
|
9
|
+
providers: [],
|
10
|
+
})
|
11
|
+
export class AXFieldsetModule {}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
<div class="ax form-group {{size}}">
|
2
|
+
<ng-content select="ax-label"></ng-content>
|
3
|
+
<div #div class="ax form-item {{size}}" [ngClass]="{'required-state': required}">
|
4
|
+
<div class="ax buttons start-buttons" #startButtons>
|
5
|
+
<ng-content select="ax-button[start]"></ng-content>
|
6
|
+
</div>
|
7
|
+
<div class="content" #content>
|
8
|
+
<ng-content></ng-content>
|
9
|
+
</div>
|
10
|
+
<div class="ax buttons end-buttons" #endButtons>
|
11
|
+
<ng-content select="ax-button[end]"></ng-content>
|
12
|
+
<ng-content select="ax-button"></ng-content>
|
13
|
+
</div>
|
14
|
+
</div>
|
15
|
+
</div>
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import {
|
2
|
+
Component, Input, ChangeDetectorRef, ChangeDetectionStrategy,
|
3
|
+
ViewEncapsulation, ContentChild, ViewChild, ElementRef
|
4
|
+
} from '@angular/core';
|
5
|
+
import { AXBaseComponent, AXBaseSizableComponent, AXElementSize, AXValidatableComponent } from '../base/element.class';
|
6
|
+
|
7
|
+
@Component({
|
8
|
+
selector: 'ax-form-group',
|
9
|
+
templateUrl: './form-group.component.html',
|
10
|
+
encapsulation: ViewEncapsulation.None,
|
11
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
12
|
+
host: { style:'width: 100%; display:contents;' }
|
13
|
+
})
|
14
|
+
export class AXFormGroupComponent extends AXBaseComponent implements AXBaseSizableComponent {
|
15
|
+
@Input()
|
16
|
+
size: AXElementSize = 'md';
|
17
|
+
|
18
|
+
@ViewChild('div')
|
19
|
+
div: ElementRef
|
20
|
+
|
21
|
+
@ContentChild(AXValidatableComponent)
|
22
|
+
private component: AXValidatableComponent;
|
23
|
+
|
24
|
+
required: boolean = false;
|
25
|
+
|
26
|
+
constructor(private cdr: ChangeDetectorRef) {
|
27
|
+
super();
|
28
|
+
}
|
29
|
+
|
30
|
+
|
31
|
+
ngAfterViewInit(): void {
|
32
|
+
this.required = this.component?.validation?.rules?.some(c => c.type === 'required');
|
33
|
+
this.div.nativeElement.classList.add(this.size)
|
34
|
+
if (this.required) {
|
35
|
+
this.div.nativeElement.classList.add('required-state')
|
36
|
+
}
|
37
|
+
}
|
38
|
+
|
39
|
+
}
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import { AXFormGroupComponent } from './form-group.component';
|
4
|
+
|
5
|
+
const COMPONENT = [AXFormGroupComponent];
|
6
|
+
const MODULES = [CommonModule];
|
7
|
+
|
8
|
+
@NgModule({
|
9
|
+
declarations: [...COMPONENT],
|
10
|
+
imports: [...MODULES],
|
11
|
+
exports: [...COMPONENT],
|
12
|
+
providers: [],
|
13
|
+
})
|
14
|
+
export class AXFormGroupModule { }
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import { Component, OnInit, ViewEncapsulation, Input } from '@angular/core';
|
2
|
+
import { AXBaseComponent, AXBaseSizableComponent, AXElementSize } from '../base/element.class';
|
3
|
+
|
4
|
+
@Component({
|
5
|
+
selector: 'ax-label',
|
6
|
+
templateUrl: './label.component.html',
|
7
|
+
encapsulation: ViewEncapsulation.None
|
8
|
+
})
|
9
|
+
export class AXLabelComponent extends AXBaseComponent implements AXBaseSizableComponent {
|
10
|
+
constructor() {
|
11
|
+
super();
|
12
|
+
}
|
13
|
+
|
14
|
+
@Input()
|
15
|
+
size: AXElementSize = 'md';
|
16
|
+
|
17
|
+
ngOnInit(): void {}
|
18
|
+
}
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import { AXLabelComponent } from './label.component';
|
4
|
+
|
5
|
+
const COMPONENT = [AXLabelComponent];
|
6
|
+
const MODULES = [CommonModule];
|
7
|
+
|
8
|
+
@NgModule({
|
9
|
+
declarations: [...COMPONENT],
|
10
|
+
imports: [...MODULES],
|
11
|
+
exports: [...COMPONENT],
|
12
|
+
providers: [],
|
13
|
+
})
|
14
|
+
export class AXLabelModule { }
|
@@ -0,0 +1,27 @@
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="margin:auto;display:block;"
|
2
|
+
[style.width.px]="size" [style.height.px]="size" viewBox="0 0 100 100" preserveAspectRatio="xMidYMid">
|
3
|
+
<rect fill="var(--ax-gray-trans-light-color)" x="55" y="55" width="30" height="30" rx="3" ry="3">
|
4
|
+
<animate attributeName="x" dur="2s" repeatCount="indefinite"
|
5
|
+
keyTimes="0;0.083;0.25;0.333;0.5;0.583;0.75;0.833;1" values="15;55;55;55;55;15;15;15;15"
|
6
|
+
begin="-1.8333333333333333s"></animate>
|
7
|
+
<animate attributeName="y" dur="2s" repeatCount="indefinite"
|
8
|
+
keyTimes="0;0.083;0.25;0.333;0.5;0.583;0.75;0.833;1" values="15;55;55;55;55;15;15;15;15"
|
9
|
+
begin="-1.3333333333333333s"></animate>
|
10
|
+
</rect>
|
11
|
+
<rect fill="var(--ax-primary-light-color)" x="55" y="15" width="30" height="30" rx="3" ry="3">
|
12
|
+
<animate attributeName="x" dur="2s" repeatCount="indefinite"
|
13
|
+
keyTimes="0;0.083;0.25;0.333;0.5;0.583;0.75;0.833;1" values="15;55;55;55;55;15;15;15;15"
|
14
|
+
begin="-1.1666666666666667s"></animate>
|
15
|
+
<animate attributeName="y" dur="2s" repeatCount="indefinite"
|
16
|
+
keyTimes="0;0.083;0.25;0.333;0.5;0.583;0.75;0.833;1" values="15;55;55;55;55;15;15;15;15"
|
17
|
+
begin="-0.6666666666666666s"></animate>
|
18
|
+
</rect>
|
19
|
+
<rect fill="var(--ax-primary-dark-color)" x="15" y="34.6776" width="30" height="30" rx="3" ry="3">
|
20
|
+
<animate attributeName="x" dur="2s" repeatCount="indefinite"
|
21
|
+
keyTimes="0;0.083;0.25;0.333;0.5;0.583;0.75;0.833;1" values="15;55;55;55;55;15;15;15;15" begin="-0.5s">
|
22
|
+
</animate>
|
23
|
+
<animate attributeName="y" dur="2s" repeatCount="indefinite"
|
24
|
+
keyTimes="0;0.083;0.25;0.333;0.5;0.583;0.75;0.833;1" values="15;55;55;55;55;15;15;15;15" begin="0s">
|
25
|
+
</animate>
|
26
|
+
</rect>
|
27
|
+
</svg>
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import { Component, OnInit, Input } from '@angular/core';
|
2
|
+
|
3
|
+
@Component({
|
4
|
+
selector: 'ax-loading-indicator',
|
5
|
+
templateUrl: './loading-indicator.component.html'
|
6
|
+
})
|
7
|
+
export class AXLoadingIndicatorComponent implements OnInit {
|
8
|
+
constructor() { }
|
9
|
+
|
10
|
+
ngOnInit(): void {
|
11
|
+
this.size = 80;
|
12
|
+
}
|
13
|
+
|
14
|
+
@Input()
|
15
|
+
size: number;
|
16
|
+
}
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import { Component, OnInit, Input, ElementRef } from '@angular/core';
|
2
|
+
|
3
|
+
@Component({
|
4
|
+
selector: 'ax-loading-panel',
|
5
|
+
template: `
|
6
|
+
<div onclick="return false;" class="ax ax-loading-panel ax-overlay-wrapper ax-overlay-modal ax-loading-overlay" *ngIf="visible" >
|
7
|
+
<ax-loading-indicator tabindex="0" cdkTrapFocus>
|
8
|
+
</ax-loading-indicator>
|
9
|
+
</div>
|
10
|
+
`
|
11
|
+
})
|
12
|
+
export class AXLoadingPanelComponent implements OnInit {
|
13
|
+
|
14
|
+
constructor(private ref: ElementRef<HTMLDivElement>) {
|
15
|
+
|
16
|
+
}
|
17
|
+
|
18
|
+
@Input()
|
19
|
+
visible: boolean = false;
|
20
|
+
|
21
|
+
ngOnInit(): void {
|
22
|
+
|
23
|
+
}
|
24
|
+
|
25
|
+
ngAfterViewInit() {
|
26
|
+
const host = this.ref.nativeElement.closest('.ax-loading-host');
|
27
|
+
}
|
28
|
+
|
29
|
+
show() {
|
30
|
+
this.visible = true;
|
31
|
+
}
|
32
|
+
|
33
|
+
hide() {
|
34
|
+
this.visible = false;
|
35
|
+
}
|
36
|
+
}
|
37
|
+
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import { AXLoadingIndicatorComponent } from './loading-indicator.component';
|
4
|
+
import { AXLoadingPanelComponent } from './loading-panel.component';
|
5
|
+
import { A11yModule } from '@angular/cdk/a11y';
|
6
|
+
|
7
|
+
@NgModule({
|
8
|
+
declarations: [AXLoadingIndicatorComponent, AXLoadingPanelComponent],
|
9
|
+
imports: [CommonModule, A11yModule],
|
10
|
+
exports: [AXLoadingIndicatorComponent, AXLoadingPanelComponent],
|
11
|
+
providers: [],
|
12
|
+
})
|
13
|
+
export class AXLoadingModule { }
|
@@ -0,0 +1,44 @@
|
|
1
|
+
import { Injectable, ComponentRef, EventEmitter } from '@angular/core';
|
2
|
+
import { AXRenderService } from '@acorex/core';
|
3
|
+
import { AXLoadingPanelComponent } from './loading-panel.component';
|
4
|
+
import { AXOverlayService, AXOverlayViewRef } from '../popover/overlay.service';
|
5
|
+
import { AXLoadingIndicatorComponent } from './loading-indicator.component';
|
6
|
+
|
7
|
+
|
8
|
+
@Injectable({ providedIn: 'root' })
|
9
|
+
export class AXLoadingService {
|
10
|
+
|
11
|
+
private _stack: { id: number, component: AXOverlayViewRef }[] = [];
|
12
|
+
|
13
|
+
|
14
|
+
constructor(private injection: AXRenderService, private overlayService: AXOverlayService) {
|
15
|
+
|
16
|
+
}
|
17
|
+
|
18
|
+
show(location?: Element): number {
|
19
|
+
let host: Element;
|
20
|
+
if (location) {
|
21
|
+
host = location.closest('.ax-loading-host');
|
22
|
+
}
|
23
|
+
const containerElement = (host || location) as HTMLDivElement;
|
24
|
+
const com = this.overlayService.show(AXLoadingIndicatorComponent, {},
|
25
|
+
{
|
26
|
+
closeOnClickOutside: false,
|
27
|
+
containerElement,
|
28
|
+
hasBackdrop: true,
|
29
|
+
backdropClass: ['ax-loading-overlay'],
|
30
|
+
scroll: 'block'
|
31
|
+
});
|
32
|
+
const id = new Date().getTime();
|
33
|
+
this._stack.push({ id, component: com });
|
34
|
+
return id;
|
35
|
+
}
|
36
|
+
|
37
|
+
hide(id): void {
|
38
|
+
const f = this._stack.find(c => c.id === id);
|
39
|
+
if (f) {
|
40
|
+
f.component.dispose();
|
41
|
+
this._stack = this._stack.filter(c => c.id !== id);
|
42
|
+
}
|
43
|
+
}
|
44
|
+
}
|
@@ -0,0 +1,41 @@
|
|
1
|
+
import {
|
2
|
+
Component,
|
3
|
+
ElementRef,
|
4
|
+
EventEmitter,
|
5
|
+
Input,
|
6
|
+
Output,
|
7
|
+
ViewEncapsulation,
|
8
|
+
} from '@angular/core';
|
9
|
+
import { AXMenuItem } from '@acorex/core';
|
10
|
+
|
11
|
+
@Component({
|
12
|
+
selector: 'ax-menu-item',
|
13
|
+
template: `
|
14
|
+
<div class="ax-menu-item {{item.style}}" [attr.data-level]="level" (click)="showSubItems($event)" [ngClass]="{'disabled': item.disable}" >
|
15
|
+
<i *ngIf="item.startIcon" class="icon {{item.startIcon}}"></i>
|
16
|
+
<span class="text">{{ item.text }}</span>
|
17
|
+
<i *ngIf="item.endIcon" class="icon {{item.endIcon}}"></i>
|
18
|
+
<i class="far fa-angle-down icon drop-icon" *ngIf="item?.items?.length && item.text"></i>
|
19
|
+
</div>
|
20
|
+
`,
|
21
|
+
encapsulation: ViewEncapsulation.None
|
22
|
+
})
|
23
|
+
export class AXMenuItemComponent {
|
24
|
+
@Input() item: AXMenuItem;
|
25
|
+
@Input() level: number;
|
26
|
+
@Output() showSubMenu = new EventEmitter<SubItemsEvent>();
|
27
|
+
|
28
|
+
constructor(private element: ElementRef) { }
|
29
|
+
|
30
|
+
showSubItems(event: Event) {
|
31
|
+
event.stopPropagation();
|
32
|
+
if (this.item?.items?.length) {
|
33
|
+
this.showSubMenu.emit({ item: this.item, element: this.element, level: this.level });
|
34
|
+
}
|
35
|
+
}
|
36
|
+
}
|
37
|
+
export interface SubItemsEvent {
|
38
|
+
element: ElementRef;
|
39
|
+
item: AXMenuItem;
|
40
|
+
level: number;
|
41
|
+
}
|
@@ -0,0 +1,74 @@
|
|
1
|
+
<!-- <div class="ax menu-container {{size}}" #container>
|
2
|
+
<ul class="root" [class.horizontal]="direction=='horizontal'" [class.vertical]="direction=='vertical'" #root>
|
3
|
+
<ng-template #recursiveList let-list>
|
4
|
+
<ng-container *ngFor="let item of list;trackBy:trackByItem">
|
5
|
+
<li class="ax-toolbar-menu-item ax {{item.type || 'ax primary'}} {{item.style || 'ax primary'}}" [class.disabled]='item.disable' [class.subIcon]='item.items' [class.startIcon]='item.startIcon' [class.startIcon]='item.icon' [class.endIcon]='item.endIcon' *ngIf="item.visible!=false" (click)="handleItemClick($event, item)"
|
6
|
+
[class.selected]="item.selected" [class.divider]="item.divider" [attr.title]="item.tooltip ? item.tooltip : null"
|
7
|
+
[attr.data-uid]="item.uid"
|
8
|
+
[class.split]="item.split">
|
9
|
+
<div class="content-side">
|
10
|
+
<ng-container *ngIf="menuTemplate; else menuBody">
|
11
|
+
<ng-container *ngTemplateOutlet="menuTemplate; context: { $implicit: item }">
|
12
|
+
</ng-container>
|
13
|
+
</ng-container>
|
14
|
+
<ng-template #menuBody>
|
15
|
+
<span class="ax-toolbar-menu-item-text">
|
16
|
+
<i class="{{ item.startIcon }} start-icon ax-menu-item-icon" *ngIf="item.startIcon"></i>
|
17
|
+
<i class="{{ item.icon }} start-icon ax-menu-item-icon" *ngIf="item.icon"></i>
|
18
|
+
<span *ngIf="item.text">{{ item.text }}</span>
|
19
|
+
<i class="{{ item.endIcon }} end-icon ax-menu-item-icon" *ngIf="item.endIcon"></i>
|
20
|
+
</span>
|
21
|
+
</ng-template>
|
22
|
+
</div>
|
23
|
+
<div class="sub-icon-side" *ngIf="item.hasChildren">
|
24
|
+
<i class="far fa-angle-down ax-menu-item-drop-icon"></i>
|
25
|
+
</div>
|
26
|
+
<ul *ngIf="item.hasChildren" class="collapsed sub-menu">
|
27
|
+
<ng-container *ngTemplateOutlet="
|
28
|
+
recursiveList;
|
29
|
+
context: { $implicit: item.items }
|
30
|
+
"></ng-container>
|
31
|
+
</ul>
|
32
|
+
</li>
|
33
|
+
</ng-container>
|
34
|
+
</ng-template>
|
35
|
+
<ng-container *ngTemplateOutlet="recursiveList; context: { $implicit: items }"></ng-container>
|
36
|
+
<li class="more" #moreLI (click)="handleItemClick($event)">
|
37
|
+
<i class="far fa-bars"></i>
|
38
|
+
<ul #moreUL class="collapsed sub-menu"></ul>
|
39
|
+
</li>
|
40
|
+
</ul>
|
41
|
+
</div> -->
|
42
|
+
|
43
|
+
<nav>
|
44
|
+
<ul class="ax nav-menu" [class.rtl]="rtl" [class.nav-center]="direction=='horizontal'"
|
45
|
+
[class.nav-vertical]="direction=='vertical'">
|
46
|
+
<ng-container *ngTemplateOutlet="recursiveMenu; context:{ $implicit: items }"></ng-container>
|
47
|
+
</ul>
|
48
|
+
</nav>
|
49
|
+
|
50
|
+
<ng-template #recursiveMenu let-items>
|
51
|
+
<ng-container *ngFor="let item of items">
|
52
|
+
<li class="ax {{item.style}}" [ngClass]="{'disabled': item.disable}"
|
53
|
+
*ngIf="item.visible === undefined || item.visible" (click)="handleItemClick($event,item)" axTooltip
|
54
|
+
[placement]="item.tooltipPlacement ? item.tooltipPlacement : 'bottom'"
|
55
|
+
[tooltip]="item.tooltip ? item.tooltip : ''">
|
56
|
+
<div class="ax-menu-item" >
|
57
|
+
<span class="menu-item-start-side">
|
58
|
+
<i class="{{ item.startIcon }}" *ngIf="item.startIcon"></i>
|
59
|
+
<i class="{{ item.icon }}" *ngIf="item.icon"></i>
|
60
|
+
<span class="ax-menu-item-text" *ngIf="item.text">{{item.text}}</span>
|
61
|
+
</span>
|
62
|
+
<span class="menu-item-end-side">
|
63
|
+
<i class="far fa-angle-down drop-icon" *ngIf="item.items && item.text"></i>
|
64
|
+
<i class="{{ item.endIcon }}" *ngIf="item.endIcon"></i>
|
65
|
+
</span>
|
66
|
+
|
67
|
+
</div>
|
68
|
+
<ul *ngIf="item.items" class="ax-sub-menu">
|
69
|
+
<ng-container *ngTemplateOutlet="recursiveMenu; context:{ $implicit: item.items }">
|
70
|
+
</ng-container>
|
71
|
+
</ul>
|
72
|
+
</li>
|
73
|
+
</ng-container>
|
74
|
+
</ng-template>
|