@eui/components 17.0.0-next.7 → 17.0.0-next.9
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/directives/eui-clearable.directive.d.ts.map +1 -1
- package/esm2022/directives/eui-clearable.directive.mjs +10 -9
- package/esm2022/directives/eui-has-permission.directive.mjs +9 -9
- package/esm2022/directives/eui-loading.directive.mjs +5 -5
- package/esm2022/directives/eui-maxlength.directive.mjs +10 -10
- package/esm2022/directives/eui-resizable/eui-resizable.component.mjs +3 -3
- package/esm2022/directives/eui-resizable/eui-resizable.directive.mjs +6 -6
- package/esm2022/directives/eui-resizable/eui-resizable.module.mjs +4 -4
- package/esm2022/directives/eui-scroll-handler.directive.mjs +15 -15
- package/esm2022/directives/eui-smooth-scroll.directive.mjs +13 -13
- package/esm2022/directives/eui-template.directive.mjs +9 -9
- package/esm2022/directives/eui-tooltip/container/eui-tooltip-container.component.mjs +6 -6
- package/esm2022/directives/eui-tooltip/eui-tooltip.directive.mjs +5 -5
- package/esm2022/directives/eui-tooltip/eui-tooltip.module.mjs +4 -4
- package/esm2022/eui-alert/eui-alert.component.mjs +9 -9
- package/esm2022/eui-all/eui-all.module.mjs +10 -9
- package/esm2022/eui-autocomplete/eui-autocomplete.component.mjs +11 -9
- package/esm2022/eui-autocomplete/eui-autocomplete.module.mjs +4 -4
- package/esm2022/eui-badge/eui-badge.component.mjs +9 -9
- package/esm2022/eui-block-content/eui-block-content.component.mjs +5 -5
- package/esm2022/eui-block-content/eui-block-content.module.mjs +4 -4
- package/esm2022/eui-block-document/eui-block-document.component.mjs +5 -5
- package/esm2022/eui-block-document/eui-block-document.module.mjs +4 -4
- package/esm2022/eui-button/eui-button.component.mjs +9 -9
- package/esm2022/eui-button-group/eui-button-group.component.mjs +9 -9
- package/esm2022/eui-buttons/eui-buttons.component.mjs +15 -15
- package/esm2022/eui-card/components/eui-card-content/eui-card-content.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-footer/eui-card-footer-action-buttons.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-footer/eui-card-footer-action-icons.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-footer/eui-card-footer-menu-content.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-footer/eui-card-footer.component.mjs +4 -4
- package/esm2022/eui-card/components/eui-card-header/eui-card-header-left-content.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-header/eui-card-header-right-content.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-header/eui-card-header-subtitle.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-header/eui-card-header-title.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-header/eui-card-header.component.mjs +5 -5
- package/esm2022/eui-card/components/eui-card-header-body/eui-card-header-body.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-media/eui-card-media.component.mjs +3 -3
- package/esm2022/eui-card/eui-card.component.mjs +5 -5
- package/esm2022/eui-card/eui-card.module.mjs +4 -4
- package/esm2022/eui-card/services/ui-state.service.mjs +3 -3
- package/esm2022/eui-chip/eui-chip.component.mjs +5 -5
- package/esm2022/eui-chip/eui-chip.module.mjs +4 -4
- package/esm2022/eui-chip-list/eui-chip-list.component.mjs +8 -8
- package/esm2022/eui-chip-list/eui-chip-list.module.mjs +4 -4
- package/esm2022/eui-chip-list/services/eui-chip-list-drag.service.mjs +3 -3
- package/esm2022/eui-dashboard-button/eui-dashboard-button.component.mjs +15 -15
- package/esm2022/eui-dashboard-card/eui-dashboard-card.component.mjs +9 -9
- package/esm2022/eui-date-range-selector/eui-date-range-selector.component.mjs +7 -7
- package/esm2022/eui-date-range-selector/eui-date-range-selector.module.mjs +4 -4
- package/esm2022/eui-datepicker/eui-datepicker.component.mjs +19 -19
- package/esm2022/eui-datepicker/eui-datepicker.module.mjs +4 -4
- package/esm2022/eui-dialog/container/eui-dialog-container.component.mjs +21 -7
- package/esm2022/eui-dialog/eui-dialog.component.mjs +11 -11
- package/esm2022/eui-dialog/eui-dialog.module.mjs +4 -4
- package/esm2022/eui-dialog/services/eui-dialog.service.mjs +4 -4
- package/esm2022/eui-dimmer/dimmer.component.mjs +5 -5
- package/esm2022/eui-dimmer/dimmer.module.mjs +4 -4
- package/esm2022/eui-disable-content/eui-disable-content.component.mjs +9 -9
- package/esm2022/eui-discussion-thread/eui-discussion-thread-item.component.mjs +3 -3
- package/esm2022/eui-discussion-thread/eui-discussion-thread.component.mjs +3 -3
- package/esm2022/eui-discussion-thread/eui-discussion-thread.module.mjs +4 -4
- package/esm2022/eui-dropdown/directives/eui-dropdown-content.directive.mjs +3 -3
- package/esm2022/eui-dropdown/dropdown-item/eui-dropdown-item.component.mjs +6 -6
- package/esm2022/eui-dropdown/eui-dropdown.component.mjs +7 -7
- package/esm2022/eui-dropdown/eui-dropdown.module.mjs +8 -8
- package/esm2022/eui-dropdown/eui-dropdown.service.mjs +3 -3
- package/esm2022/eui-feedback-message/eui-feedback-message.component.mjs +5 -5
- package/esm2022/eui-feedback-message/eui-feedback-message.module.mjs +4 -4
- package/esm2022/eui-fieldset/eui-fieldset.component.mjs +11 -11
- package/esm2022/eui-fieldset/eui-fieldset.module.mjs +4 -4
- package/esm2022/eui-file-upload/eui-file-upload.component.mjs +3 -3
- package/esm2022/eui-file-upload/eui-file-upload.module.mjs +4 -4
- package/esm2022/eui-file-upload/file-preview/file-preview.component.mjs +5 -5
- package/esm2022/eui-file-upload/pipes/filesize.pipe.mjs +3 -3
- package/esm2022/eui-file-upload/progress/eui-file-upload-progress.component.mjs +3 -3
- package/esm2022/eui-file-upload/utils/eui-file-upload.utils.mjs +4 -4
- package/esm2022/eui-growl/eui-growl.component.mjs +5 -5
- package/esm2022/eui-growl/eui-growl.module.mjs +4 -4
- package/esm2022/eui-icon/eui-icon-color.component.mjs +3 -3
- package/esm2022/eui-icon/eui-icon-svg.component.mjs +6 -6
- package/esm2022/eui-icon/eui-icon.component.mjs +5 -5
- package/esm2022/eui-icon/eui-icon.module.mjs +4 -4
- package/esm2022/eui-icon-toggle/eui-icon-toggle.component.mjs +3 -3
- package/esm2022/eui-icon-toggle/eui-icon-toggle.module.mjs +4 -4
- package/esm2022/eui-input-checkbox/eui-input-checkbox.component.mjs +6 -6
- package/esm2022/eui-input-checkbox/eui-input-checkbox.module.mjs +4 -4
- package/esm2022/eui-input-group/eui-input-group.component.mjs +4 -4
- package/esm2022/eui-input-group/eui-input-group.module.mjs +4 -4
- package/esm2022/eui-input-number/eui-input-number.component.mjs +7 -7
- package/esm2022/eui-input-number/eui-input-number.module.mjs +4 -4
- package/esm2022/eui-input-number/eui-number-control.directive.mjs +5 -5
- package/esm2022/eui-input-radio/eui-input-radio.component.mjs +6 -6
- package/esm2022/eui-input-radio/eui-input-radio.module.mjs +4 -4
- package/esm2022/eui-input-text/eui-input-text.component.mjs +7 -7
- package/esm2022/eui-input-text/eui-input-text.module.mjs +4 -4
- package/esm2022/eui-label/eui-label.component.mjs +5 -5
- package/esm2022/eui-label/eui-label.module.mjs +4 -4
- package/esm2022/eui-list/eui-list-item/eui-list-item.component.mjs +5 -5
- package/esm2022/eui-list/eui-list.component.mjs +5 -5
- package/esm2022/eui-list/eui-list.module.mjs +4 -4
- package/esm2022/eui-list/services/eui-list.service.mjs +3 -3
- package/esm2022/eui-menu/eui-menu-item.component.mjs +5 -5
- package/esm2022/eui-menu/eui-menu.component.mjs +5 -5
- package/esm2022/eui-menu/eui-menu.module.mjs +4 -4
- package/esm2022/eui-message-box/eui-message-box.component.mjs +18 -9
- package/esm2022/eui-message-box/eui-message-box.module.mjs +4 -4
- package/esm2022/eui-message-box/services/eui-message-box.service.mjs +6 -6
- package/esm2022/eui-overlay/components/eui-overlay-body/eui-overlay-body.component.mjs +5 -5
- package/esm2022/eui-overlay/components/eui-overlay-footer/eui-overlay-footer.component.mjs +5 -5
- package/esm2022/eui-overlay/components/eui-overlay-header/eui-overlay-header-title/eui-overlay-header-title.component.mjs +5 -5
- package/esm2022/eui-overlay/components/eui-overlay-header/eui-overlay-header.component.mjs +5 -5
- package/esm2022/eui-overlay/eui-overlay.component.mjs +31 -16
- package/esm2022/eui-page/components/eui-page-breadcrumb/eui-page-breadcrumb.component.mjs +3 -3
- package/esm2022/eui-page/components/eui-page-column/eui-page-column.component.mjs +23 -23
- package/esm2022/eui-page/components/eui-page-columns/eui-page-columns.component.mjs +3 -3
- package/esm2022/eui-page/components/eui-page-content/eui-page-content.component.mjs +3 -3
- package/esm2022/eui-page/components/eui-page-footer/eui-page-footer.component.mjs +5 -5
- package/esm2022/eui-page/components/eui-page-header/eui-page-header.component.mjs +10 -10
- package/esm2022/eui-page/components/eui-page-hero-header/eui-page-hero-header.component.mjs +3 -3
- package/esm2022/eui-page/components/eui-page-top-content/eui-page-top-content.component.mjs +5 -5
- package/esm2022/eui-page/eui-page.component.mjs +4 -4
- package/esm2022/eui-page/eui-page.module.mjs +4 -4
- package/esm2022/eui-paginator/eui-paginator.component.mjs +5 -5
- package/esm2022/eui-paginator/eui-paginator.module.mjs +4 -4
- package/esm2022/eui-picker/eui-picker.component.mjs +5 -5
- package/esm2022/eui-picker/eui-picker.module.mjs +4 -4
- package/esm2022/eui-picker/modal-picker/eui-modal-picker.component.mjs +5 -5
- package/esm2022/eui-popover/directives/eui-popover-arrow-position.directive.mjs +6 -6
- package/esm2022/eui-popover/eui-popover.component.mjs +5 -5
- package/esm2022/eui-popover/eui-popover.module.mjs +4 -4
- package/esm2022/eui-progress-bar/eui-progress-bar.component.mjs +5 -5
- package/esm2022/eui-progress-bar/eui-progress-bar.module.mjs +4 -4
- package/esm2022/eui-progress-circle/eui-progress-circle.component.mjs +9 -9
- package/esm2022/eui-select/eui-select-control.directive.mjs +6 -6
- package/esm2022/eui-select/eui-select-multiple.directive.mjs +6 -6
- package/esm2022/eui-select/eui-select-mutli-option.directive.mjs +6 -6
- package/esm2022/eui-select/eui-select-option.directive.mjs +6 -6
- package/esm2022/eui-select/eui-select.component.mjs +6 -6
- package/esm2022/eui-select/eui-select.module.mjs +4 -4
- package/esm2022/eui-sidebar-menu/eui-sidebar-menu.component.mjs +3 -3
- package/esm2022/eui-sidebar-menu/eui-sidebar-menu.module.mjs +4 -4
- package/esm2022/eui-slide-toggle/eui-slide-toggle.component.mjs +6 -6
- package/esm2022/eui-slide-toggle/eui-slide-toggle.module.mjs +4 -4
- package/esm2022/eui-table/directives/eui-table-sticky-columns.directive.mjs +3 -3
- package/esm2022/eui-table/eui-table.component.mjs +39 -9
- package/esm2022/eui-table/eui-table.module.mjs +4 -4
- package/esm2022/eui-table/expandable-row/eui-table-expandable-row.component.mjs +3 -3
- package/esm2022/eui-table/filter/eui-table-filter.component.mjs +5 -5
- package/esm2022/eui-table/pipes/eui-table-highlight-filter.pipe.mjs +3 -3
- package/esm2022/eui-table/selectable-header/eui-table-selectable-header.component.mjs +5 -5
- package/esm2022/eui-table/selectable-row/eui-table-selectable-row.component.mjs +5 -5
- package/esm2022/eui-table/services/eui-table-selectable-row.service.mjs +3 -3
- package/esm2022/eui-table/services/eui-table-sort.service.mjs +3 -3
- package/esm2022/eui-table/sortable-col/eui-table-sortable-col.component.mjs +5 -5
- package/esm2022/eui-tabs/eui-tab/eui-tab.component.mjs +5 -5
- package/esm2022/eui-tabs/eui-tab-content/eui-tab-content.component.mjs +5 -5
- package/esm2022/eui-tabs/eui-tab-label/eui-tab-label.component.mjs +8 -8
- package/esm2022/eui-tabs/eui-tabs.component.mjs +8 -8
- package/esm2022/eui-tabs/eui-tabs.module.mjs +4 -4
- package/esm2022/eui-textarea/auto-resize.directive.mjs +6 -6
- package/esm2022/eui-textarea/eui-textarea.component.mjs +6 -6
- package/esm2022/eui-textarea/eui-textarea.module.mjs +4 -4
- package/esm2022/eui-timebar/eui-timebar.component.mjs +9 -9
- package/esm2022/eui-timeline/eui-timeline-item.component.mjs +6 -6
- package/esm2022/eui-timeline/eui-timeline.component.mjs +3 -3
- package/esm2022/eui-timeline/eui-timeline.module.mjs +4 -4
- package/esm2022/eui-timepicker/eui-timepicker.component.mjs +6 -6
- package/esm2022/eui-timepicker/eui-timepicker.module.mjs +4 -4
- package/esm2022/eui-tree/eui-dropdown-tree.directive.mjs +10 -10
- package/esm2022/eui-tree/eui-tree-form-control.directive.mjs +10 -10
- package/esm2022/eui-tree/eui-tree.component.mjs +9 -9
- package/esm2022/eui-wizard/eui-wizard-step.component.mjs +3 -3
- package/esm2022/eui-wizard/eui-wizard.component.mjs +3 -3
- package/esm2022/eui-wizard/eui-wizard.module.mjs +4 -4
- package/esm2022/eui-wizard/services/eui-wizard.service.mjs +4 -4
- package/esm2022/externals/charts/chart/chart.component.mjs +3 -3
- package/esm2022/externals/charts/eui-charts.module.mjs +4 -4
- package/esm2022/externals/eui-editor/counters/eui-editor-counters.component.mjs +3 -3
- package/esm2022/externals/eui-editor/directives/eui-editor-maxlength.directive.mjs +6 -6
- package/esm2022/externals/eui-editor/eui-editor.component.mjs +10 -10
- package/esm2022/externals/eui-editor/eui-editor.module.mjs +4 -4
- package/esm2022/externals/eui-editor/html-view/eui-editor-html-view.component.mjs +5 -5
- package/esm2022/externals/eui-editor/image-url-dialog/image-url-dialog.component.mjs +5 -5
- package/esm2022/externals/eui-editor/json-view/eui-editor-json-view.component.mjs +6 -6
- package/esm2022/externals/quill/quill-editor.component.mjs +6 -6
- package/esm2022/externals/quill/quill.module.mjs +4 -4
- package/esm2022/layout/eui-app/eui-app-breadcrumb/breadcrumb.component.mjs +5 -5
- package/esm2022/layout/eui-app/eui-app-breadcrumb/breadcrumb.module.mjs +4 -4
- package/esm2022/layout/eui-app/eui-app-footer/footer.component.mjs +3 -3
- package/esm2022/layout/eui-app/eui-app-footer/footer.module.mjs +4 -4
- package/esm2022/layout/eui-app/eui-app-header/header.component.mjs +5 -5
- package/esm2022/layout/eui-app/eui-app-header/header.module.mjs +4 -4
- package/esm2022/layout/eui-app/eui-app-sidebar/sidebar-body/sidebar-body.component.mjs +3 -3
- package/esm2022/layout/eui-app/eui-app-sidebar/sidebar-drawer/sidebar-drawer.component.mjs +3 -3
- package/esm2022/layout/eui-app/eui-app-sidebar/sidebar-footer/sidebar-footer.component.mjs +5 -5
- package/esm2022/layout/eui-app/eui-app-sidebar/sidebar-header/sidebar-header.component.mjs +5 -5
- package/esm2022/layout/eui-app/eui-app-sidebar/sidebar-header-user-profile/sidebar-header-user-profile.component.mjs +5 -5
- package/esm2022/layout/eui-app/eui-app-sidebar/sidebar-menu/sidebar-menu.component.mjs +5 -5
- package/esm2022/layout/eui-app/eui-app-sidebar/sidebar.component.mjs +6 -6
- package/esm2022/layout/eui-app/eui-app-sidebar/sidebar.module.mjs +4 -4
- package/esm2022/layout/eui-app/eui-app-toolbar/toolbar.component.mjs +5 -5
- package/esm2022/layout/eui-app/eui-app-toolbar/toolbar.module.mjs +4 -4
- package/esm2022/layout/eui-app/eui-app-top-message/top-message.component.mjs +5 -5
- package/esm2022/layout/eui-app/eui-app-top-message/top-message.module.mjs +4 -4
- package/esm2022/layout/eui-app/eui-app.component.mjs +9 -9
- package/esm2022/layout/eui-app/eui-app.module.mjs +4 -4
- package/esm2022/layout/eui-breadcrumb/breadcrumb.component.mjs +5 -5
- package/esm2022/layout/eui-breadcrumb/breadcrumb.module.mjs +4 -4
- package/esm2022/layout/eui-breadcrumb/breadcrumb.service.mjs +4 -4
- package/esm2022/layout/eui-breadcrumb/collapsed-breadcrumb/collapsed-breadcrumb.component.mjs +8 -8
- package/esm2022/layout/eui-breadcrumb/item/breadcrumb-item.component.mjs +6 -6
- package/esm2022/layout/eui-footer/footer.component.mjs +5 -5
- package/esm2022/layout/eui-footer/footer.module.mjs +4 -4
- package/esm2022/layout/eui-header/header-app/header-app.component.mjs +15 -15
- package/esm2022/layout/eui-header/header-app-name/header-app-name.component.mjs +6 -6
- package/esm2022/layout/eui-header/header-app-name-logo/header-app-name-logo.component.mjs +6 -6
- package/esm2022/layout/eui-header/header-app-subtitle/header-app-subtitle.component.mjs +6 -6
- package/esm2022/layout/eui-header/header-environment/header-environment.component.mjs +6 -6
- package/esm2022/layout/eui-header/header-logo/header-logo.component.mjs +6 -6
- package/esm2022/layout/eui-header/header-user-profile/header-user-profile.component.mjs +4 -4
- package/esm2022/layout/eui-header/header.component.mjs +3 -3
- package/esm2022/layout/eui-header/header.module.mjs +4 -4
- package/esm2022/layout/eui-language-selector/language-selector.component.mjs +5 -5
- package/esm2022/layout/eui-language-selector/language-selector.module.mjs +4 -4
- package/esm2022/layout/eui-language-selector/modal-selector/modal-selector.component.mjs +5 -5
- package/esm2022/layout/eui-layout.module.mjs +4 -4
- package/esm2022/layout/eui-notifications/eui-notification-item.component.mjs +3 -3
- package/esm2022/layout/eui-notifications/eui-notifications.component.mjs +3 -3
- package/esm2022/layout/eui-notifications/eui-notifications.module.mjs +4 -4
- package/esm2022/layout/eui-notifications-v2/eui-notification-item.component.mjs +3 -3
- package/esm2022/layout/eui-notifications-v2/eui-notifications.component.mjs +3 -3
- package/esm2022/layout/eui-notifications-v2/eui-notifications.module.mjs +4 -4
- package/esm2022/layout/eui-search/search.component.mjs +5 -5
- package/esm2022/layout/eui-search/search.module.mjs +4 -4
- package/esm2022/layout/eui-sidebar-toggle/sidebar-toggle.component.mjs +5 -5
- package/esm2022/layout/eui-sidebar-toggle/sidebar-toggle.module.mjs +4 -4
- package/esm2022/layout/eui-toolbar/toolbar-app/toolbar-app.component.mjs +3 -3
- package/esm2022/layout/eui-toolbar/toolbar-center/toolbar-center.component.mjs +3 -3
- package/esm2022/layout/eui-toolbar/toolbar-environment/toolbar-environment.component.mjs +3 -3
- package/esm2022/layout/eui-toolbar/toolbar-item/toolbar-item.component.mjs +3 -3
- package/esm2022/layout/eui-toolbar/toolbar-item-notifications/toolbar-item-notifications.component.mjs +3 -3
- package/esm2022/layout/eui-toolbar/toolbar-item-search/toolbar-item-search.component.mjs +3 -3
- package/esm2022/layout/eui-toolbar/toolbar-item-user-profile/toolbar-item-user-profile.component.mjs +4 -4
- package/esm2022/layout/eui-toolbar/toolbar-items/toolbar-items.component.mjs +5 -5
- package/esm2022/layout/eui-toolbar/toolbar-logo/toolbar-logo.component.mjs +5 -5
- package/esm2022/layout/eui-toolbar/toolbar-menu/toolbar-menu.component.mjs +5 -5
- package/esm2022/layout/eui-toolbar/toolbar.component.mjs +5 -5
- package/esm2022/layout/eui-toolbar/toolbar.module.mjs +4 -4
- package/esm2022/layout/eui-user-profile/user-profile-card/user-profile-card.component.mjs +5 -5
- package/esm2022/layout/eui-user-profile/user-profile-menu/user-profile-menu.component.mjs +5 -5
- package/esm2022/layout/eui-user-profile/user-profile-menu-item/user-profile-menu-item.component.mjs +5 -5
- package/esm2022/layout/eui-user-profile/user-profile.component.mjs +5 -5
- package/esm2022/layout/eui-user-profile/user-profile.module.mjs +4 -4
- package/esm2022/pipes/eui-is-empty.pipe.mjs +7 -7
- package/esm2022/pipes/eui-truncate.pipe.mjs +7 -7
- package/esm2022/shared/base/base-states.directive.mjs +3 -3
- package/esm2022/shared/base/base.directive.mjs +3 -3
- package/esm2022/shared/eui-common-header/common-header.component.mjs +7 -7
- package/esm2022/shared/eui-expand-content/eui-expand-content.component.mjs +7 -7
- package/esm2022/shared/input.directive.mjs +5 -5
- package/eui-all/eui-all.module.d.ts +20 -19
- package/eui-all/eui-all.module.d.ts.map +1 -1
- package/eui-autocomplete/eui-autocomplete.component.d.ts.map +1 -1
- package/eui-dialog/container/eui-dialog-container.component.d.ts +4 -0
- package/eui-dialog/container/eui-dialog-container.component.d.ts.map +1 -1
- package/eui-message-box/eui-message-box.component.d.ts +4 -1
- package/eui-message-box/eui-message-box.component.d.ts.map +1 -1
- package/eui-overlay/eui-overlay.component.d.ts +5 -2
- package/eui-overlay/eui-overlay.component.d.ts.map +1 -1
- package/eui-table/eui-table.component.d.ts +1 -0
- package/eui-table/eui-table.component.d.ts.map +1 -1
- package/fesm2022/eui-components-directives.mjs +89 -88
- package/fesm2022/eui-components-directives.mjs.map +1 -1
- package/fesm2022/eui-components-eui-alert.mjs +8 -8
- package/fesm2022/eui-components-eui-alert.mjs.map +1 -1
- package/fesm2022/eui-components-eui-all.mjs +9 -8
- package/fesm2022/eui-components-eui-all.mjs.map +1 -1
- package/fesm2022/eui-components-eui-autocomplete.mjs +14 -12
- package/fesm2022/eui-components-eui-autocomplete.mjs.map +1 -1
- package/fesm2022/eui-components-eui-badge.mjs +8 -8
- package/fesm2022/eui-components-eui-badge.mjs.map +1 -1
- package/fesm2022/eui-components-eui-block-content.mjs +8 -8
- package/fesm2022/eui-components-eui-block-content.mjs.map +1 -1
- package/fesm2022/eui-components-eui-block-document.mjs +8 -8
- package/fesm2022/eui-components-eui-block-document.mjs.map +1 -1
- package/fesm2022/eui-components-eui-button-group.mjs +8 -8
- package/fesm2022/eui-components-eui-button-group.mjs.map +1 -1
- package/fesm2022/eui-components-eui-button.mjs +8 -8
- package/fesm2022/eui-components-eui-button.mjs.map +1 -1
- package/fesm2022/eui-components-eui-buttons.mjs +14 -14
- package/fesm2022/eui-components-eui-buttons.mjs.map +1 -1
- package/fesm2022/eui-components-eui-card.mjs +48 -48
- package/fesm2022/eui-components-eui-card.mjs.map +1 -1
- package/fesm2022/eui-components-eui-chip-list.mjs +14 -14
- package/fesm2022/eui-components-eui-chip-list.mjs.map +1 -1
- package/fesm2022/eui-components-eui-chip.mjs +8 -8
- package/fesm2022/eui-components-eui-chip.mjs.map +1 -1
- package/fesm2022/eui-components-eui-dashboard-button.mjs +14 -14
- package/fesm2022/eui-components-eui-dashboard-button.mjs.map +1 -1
- package/fesm2022/eui-components-eui-dashboard-card.mjs +8 -8
- package/fesm2022/eui-components-eui-dashboard-card.mjs.map +1 -1
- package/fesm2022/eui-components-eui-date-range-selector.mjs +10 -10
- package/fesm2022/eui-components-eui-date-range-selector.mjs.map +1 -1
- package/fesm2022/eui-components-eui-datepicker.mjs +22 -22
- package/fesm2022/eui-components-eui-datepicker.mjs.map +1 -1
- package/fesm2022/eui-components-eui-dialog.mjs +38 -24
- package/fesm2022/eui-components-eui-dialog.mjs.map +1 -1
- package/fesm2022/eui-components-eui-dimmer.mjs +8 -8
- package/fesm2022/eui-components-eui-dimmer.mjs.map +1 -1
- package/fesm2022/eui-components-eui-disable-content.mjs +8 -8
- package/fesm2022/eui-components-eui-disable-content.mjs.map +1 -1
- package/fesm2022/eui-components-eui-discussion-thread.mjs +10 -10
- package/fesm2022/eui-components-eui-dropdown.mjs +25 -25
- package/fesm2022/eui-components-eui-dropdown.mjs.map +1 -1
- package/fesm2022/eui-components-eui-feedback-message.mjs +8 -8
- package/fesm2022/eui-components-eui-feedback-message.mjs.map +1 -1
- package/fesm2022/eui-components-eui-fieldset.mjs +14 -14
- package/fesm2022/eui-components-eui-fieldset.mjs.map +1 -1
- package/fesm2022/eui-components-eui-file-upload.mjs +21 -21
- package/fesm2022/eui-components-eui-file-upload.mjs.map +1 -1
- package/fesm2022/eui-components-eui-growl.mjs +8 -8
- package/fesm2022/eui-components-eui-growl.mjs.map +1 -1
- package/fesm2022/eui-components-eui-icon-toggle.mjs +7 -7
- package/fesm2022/eui-components-eui-icon.mjs +16 -16
- package/fesm2022/eui-components-eui-icon.mjs.map +1 -1
- package/fesm2022/eui-components-eui-input-checkbox.mjs +9 -9
- package/fesm2022/eui-components-eui-input-checkbox.mjs.map +1 -1
- package/fesm2022/eui-components-eui-input-group.mjs +8 -8
- package/fesm2022/eui-components-eui-input-group.mjs.map +1 -1
- package/fesm2022/eui-components-eui-input-number.mjs +15 -15
- package/fesm2022/eui-components-eui-input-number.mjs.map +1 -1
- package/fesm2022/eui-components-eui-input-radio.mjs +9 -9
- package/fesm2022/eui-components-eui-input-radio.mjs.map +1 -1
- package/fesm2022/eui-components-eui-input-text.mjs +10 -10
- package/fesm2022/eui-components-eui-input-text.mjs.map +1 -1
- package/fesm2022/eui-components-eui-label.mjs +8 -8
- package/fesm2022/eui-components-eui-label.mjs.map +1 -1
- package/fesm2022/eui-components-eui-list.mjs +15 -15
- package/fesm2022/eui-components-eui-list.mjs.map +1 -1
- package/fesm2022/eui-components-eui-menu.mjs +12 -12
- package/fesm2022/eui-components-eui-menu.mjs.map +1 -1
- package/fesm2022/eui-components-eui-message-box.mjs +26 -17
- package/fesm2022/eui-components-eui-message-box.mjs.map +1 -1
- package/fesm2022/eui-components-eui-overlay.mjs +46 -31
- package/fesm2022/eui-components-eui-overlay.mjs.map +1 -1
- package/fesm2022/eui-components-eui-page.mjs +59 -59
- package/fesm2022/eui-components-eui-page.mjs.map +1 -1
- package/fesm2022/eui-components-eui-paginator.mjs +8 -8
- package/fesm2022/eui-components-eui-paginator.mjs.map +1 -1
- package/fesm2022/eui-components-eui-picker.mjs +13 -13
- package/fesm2022/eui-components-eui-picker.mjs.map +1 -1
- package/fesm2022/eui-components-eui-popover.mjs +13 -13
- package/fesm2022/eui-components-eui-popover.mjs.map +1 -1
- package/fesm2022/eui-components-eui-progress-bar.mjs +8 -8
- package/fesm2022/eui-components-eui-progress-bar.mjs.map +1 -1
- package/fesm2022/eui-components-eui-progress-circle.mjs +8 -8
- package/fesm2022/eui-components-eui-progress-circle.mjs.map +1 -1
- package/fesm2022/eui-components-eui-select.mjs +29 -29
- package/fesm2022/eui-components-eui-select.mjs.map +1 -1
- package/fesm2022/eui-components-eui-sidebar-menu.mjs +7 -7
- package/fesm2022/eui-components-eui-slide-toggle.mjs +9 -9
- package/fesm2022/eui-components-eui-slide-toggle.mjs.map +1 -1
- package/fesm2022/eui-components-eui-table.mjs +73 -43
- package/fesm2022/eui-components-eui-table.mjs.map +1 -1
- package/fesm2022/eui-components-eui-tabs.mjs +26 -26
- package/fesm2022/eui-components-eui-tabs.mjs.map +1 -1
- package/fesm2022/eui-components-eui-textarea.mjs +14 -14
- package/fesm2022/eui-components-eui-textarea.mjs.map +1 -1
- package/fesm2022/eui-components-eui-timebar.mjs +8 -8
- package/fesm2022/eui-components-eui-timebar.mjs.map +1 -1
- package/fesm2022/eui-components-eui-timeline.mjs +12 -12
- package/fesm2022/eui-components-eui-timeline.mjs.map +1 -1
- package/fesm2022/eui-components-eui-timepicker.mjs +9 -9
- package/fesm2022/eui-components-eui-timepicker.mjs.map +1 -1
- package/fesm2022/eui-components-eui-tree.mjs +26 -26
- package/fesm2022/eui-components-eui-tree.mjs.map +1 -1
- package/fesm2022/eui-components-eui-wizard.mjs +14 -14
- package/fesm2022/eui-components-externals-charts.mjs +7 -7
- package/fesm2022/eui-components-externals-eui-editor.mjs +35 -35
- package/fesm2022/eui-components-externals-eui-editor.mjs.map +1 -1
- package/fesm2022/eui-components-externals-quill.mjs +9 -9
- package/fesm2022/eui-components-externals-quill.mjs.map +1 -1
- package/fesm2022/eui-components-layout.mjs +277 -277
- package/fesm2022/eui-components-layout.mjs.map +1 -1
- package/fesm2022/eui-components-pipes.mjs +14 -14
- package/fesm2022/eui-components-shared-base.mjs +6 -6
- package/fesm2022/eui-components-shared.mjs +18 -18
- package/fesm2022/eui-components-shared.mjs.map +1 -1
- package/package.json +7 -7
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"eui-clearable.directive.d.ts","sourceRoot":"","sources":["../../directives/eui-clearable.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,aAAa,EACb,YAAY,EAEZ,UAAU,EAGV,QAAQ,EAER,SAAS,EACT,SAAS,EACT,aAAa,EACb,gBAAgB,EACnB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAyB,MAAM,uBAAuB,CAAC;AAE5E,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;;AAG/D,qBAIa,qBAAsB,YAAW,SAAS,EAAE,aAAa;IA0C9D,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,QAAQ;IA5CpB,IAEI,QAAQ,IAAI,GAAG,CAElB;IACD,IAAI,QAAQ,CAAC,CAAC,EAAE,YAAY,EAE3B;IAED,IAEI,QAAQ,IAAI,GAAG,CAElB;IACD,IAAI,QAAQ,CAAC,CAAC,EAAE,YAAY,EAE3B;IAED,IACW,UAAU,IAAI,MAAM,CAE9B;IACD,IAAW,UAAU,CAAC,KAAK,EAAE,MAAM,EAElC;IACD,OAAO,CAAC,WAAW,CAAS;IAE5B,IACI,YAAY,IAAI,OAAO,CAE1B;IACD,IAAI,YAAY,CAAC,KAAK,EAAE,YAAY,EAEnC;IACD,SAAS,CAAC,cAAc,EAAE,YAAY,CAAC,mBAAmB,CAAC,CAAC;IAC5D,OAAO,CAAC,gBAAgB,CAAiB;IACzC,OAAO,CAAC,aAAa,CAAU;IAC/B,OAAO,CAAC,WAAW,CAAU;IAC7B,OAAO,CAAC,SAAS,CAAU;gBAGf,WAAW,EAAE,UAAU,EACvB,iBAAiB,EAAE,gBAAgB,EACnC,SAAS,EAAE,SAAS,EACpB,QAAQ,EAAE,QAAQ;IAG9B,eAAe,IAAI,IAAI;IAYvB,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI;IAuDzC,OAAO,CAAC,qBAAqB;IAO7B,OAAO,CAAC,kBAAkB;IAiB1B;;;;OAIG;IACH,OAAO,CAAC,mBAAmB;IAyB3B;;;;OAIG;IACH,OAAO,CAAC,mBAAmB;IAQ3B;;;;OAIG;IACH,OAAO,CAAC,iBAAiB;
|
1
|
+
{"version":3,"file":"eui-clearable.directive.d.ts","sourceRoot":"","sources":["../../directives/eui-clearable.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,aAAa,EACb,YAAY,EAEZ,UAAU,EAGV,QAAQ,EAER,SAAS,EACT,SAAS,EACT,aAAa,EACb,gBAAgB,EACnB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAyB,MAAM,uBAAuB,CAAC;AAE5E,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;;AAG/D,qBAIa,qBAAsB,YAAW,SAAS,EAAE,aAAa;IA0C9D,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,QAAQ;IA5CpB,IAEI,QAAQ,IAAI,GAAG,CAElB;IACD,IAAI,QAAQ,CAAC,CAAC,EAAE,YAAY,EAE3B;IAED,IAEI,QAAQ,IAAI,GAAG,CAElB;IACD,IAAI,QAAQ,CAAC,CAAC,EAAE,YAAY,EAE3B;IAED,IACW,UAAU,IAAI,MAAM,CAE9B;IACD,IAAW,UAAU,CAAC,KAAK,EAAE,MAAM,EAElC;IACD,OAAO,CAAC,WAAW,CAAS;IAE5B,IACI,YAAY,IAAI,OAAO,CAE1B;IACD,IAAI,YAAY,CAAC,KAAK,EAAE,YAAY,EAEnC;IACD,SAAS,CAAC,cAAc,EAAE,YAAY,CAAC,mBAAmB,CAAC,CAAC;IAC5D,OAAO,CAAC,gBAAgB,CAAiB;IACzC,OAAO,CAAC,aAAa,CAAU;IAC/B,OAAO,CAAC,WAAW,CAAU;IAC7B,OAAO,CAAC,SAAS,CAAU;gBAGf,WAAW,EAAE,UAAU,EACvB,iBAAiB,EAAE,gBAAgB,EACnC,SAAS,EAAE,SAAS,EACpB,QAAQ,EAAE,QAAQ;IAG9B,eAAe,IAAI,IAAI;IAYvB,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI;IAuDzC,OAAO,CAAC,qBAAqB;IAO7B,OAAO,CAAC,kBAAkB;IAiB1B;;;;OAIG;IACH,OAAO,CAAC,mBAAmB;IAyB3B;;;;OAIG;IACH,OAAO,CAAC,mBAAmB;IAQ3B;;;;OAIG;IACH,OAAO,CAAC,iBAAiB;IAkBzB;;;;OAIG;IACH,OAAO,CAAC,yBAAyB;IAIjC;;;;OAIG;IACH,OAAO,CAAC,iBAAiB;yCA3NhB,qBAAqB;2CAArB,qBAAqB;CAmOjC"}
|
@@ -54,11 +54,11 @@ export class EuiClearableDirective {
|
|
54
54
|
// check if type is not euiInputNumber or euiInputText, reset and throw error
|
55
55
|
if (type !== 'eui-number' && type !== 'text' && type !== 'search') {
|
56
56
|
this.euiClearable = true;
|
57
|
-
throw new Error('euiClearable is only allowed
|
57
|
+
throw new Error('euiClearable is only allowed in euiInputNumber or euiInputText');
|
58
58
|
}
|
59
59
|
// create dynamically the icon
|
60
60
|
this.createClearableIcon();
|
61
|
-
// wrap them all
|
61
|
+
// wrap them all at an eui-u-flex class
|
62
62
|
this.createFlexWrapper();
|
63
63
|
this._renderer.appendChild(this._euiUFlexWrapper, this._clearableIcon.location.nativeElement);
|
64
64
|
}
|
@@ -132,7 +132,7 @@ export class EuiClearableDirective {
|
|
132
132
|
this._clearableIcon.instance.set = 'eui';
|
133
133
|
this._clearableIcon.instance.icon = 'eui-close';
|
134
134
|
this._clearableIcon.instance.ariaLabel = 'Clear input field';
|
135
|
-
this._renderer.addClass(this._clearableIcon.location.nativeElement, 'eui-input-text--clearable-icon');
|
135
|
+
this._renderer.addClass(this._clearableIcon.location.nativeElement, 'eui-input-text--clearable-icon');
|
136
136
|
this._renderer.listen(this._clearableIcon.location.nativeElement, 'click', this.onClearableClicked.bind(this));
|
137
137
|
this._renderer.listen(this._clearableIcon.location.nativeElement, 'keydown.enter', this.onClearableClicked.bind(this));
|
138
138
|
const control = this.injector.get(NgControl, null, { optional: true });
|
@@ -170,7 +170,8 @@ export class EuiClearableDirective {
|
|
170
170
|
createFlexWrapper() {
|
171
171
|
if (!this._euiUFlexWrapper && !this.doesParentHasAFlexWrapper()) {
|
172
172
|
this._euiUFlexWrapper = this._renderer.createElement('div');
|
173
|
-
this._renderer.addClass(this._euiUFlexWrapper, 'eui-
|
173
|
+
this._renderer.addClass(this._euiUFlexWrapper, 'eui-u-flex');
|
174
|
+
this._renderer.addClass(this._euiUFlexWrapper, 'eui-u-p-relative');
|
174
175
|
this._renderer.setAttribute(this._euiUFlexWrapper, 'flexWrapper', null);
|
175
176
|
this._renderer.insertBefore(this._elementRef.nativeElement.parentElement, this._euiUFlexWrapper, this._elementRef.nativeElement);
|
176
177
|
this._renderer.appendChild(this._euiUFlexWrapper, this._elementRef.nativeElement);
|
@@ -200,16 +201,16 @@ export class EuiClearableDirective {
|
|
200
201
|
this._euiUFlexWrapper = null;
|
201
202
|
}
|
202
203
|
}
|
203
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.
|
204
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.
|
204
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiClearableDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
|
205
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.7", type: EuiClearableDirective, isStandalone: true, selector: "input[euiClearable]", inputs: { readonly: "readonly", disabled: "disabled", euiClearable: "euiClearable" }, host: { listeners: { "input": "onKeyUpAndModelChange($event.target.value)", "ngModelChange": "onKeyUpAndModelChange($event)" }, properties: { "attr.readonly": "this.readonly", "disabled": "this.disabled", "class": "this.cssClasses" } }, usesOnChanges: true, ngImport: i0 }); }
|
205
206
|
}
|
206
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.
|
207
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiClearableDirective, decorators: [{
|
207
208
|
type: Directive,
|
208
209
|
args: [{
|
209
210
|
selector: 'input[euiClearable]',
|
210
211
|
standalone: true,
|
211
212
|
}]
|
212
|
-
}], ctorParameters:
|
213
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.Renderer2 }, { type: i0.Injector }], propDecorators: { readonly: [{
|
213
214
|
type: HostBinding,
|
214
215
|
args: ['attr.readonly']
|
215
216
|
}, {
|
@@ -231,4 +232,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.4",
|
|
231
232
|
type: HostListener,
|
232
233
|
args: ['ngModelChange', ['$event']]
|
233
234
|
}] } });
|
234
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-clearable.directive.js","sourceRoot":"","sources":["../../../directives/eui-clearable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Injector,\n    Input,\n    OnChanges,\n    Renderer2,\n    SimpleChanges,\n    ViewContainerRef,\n} from '@angular/core';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { NgControl, NgModel } from '@angular/forms';\nimport { EuiIconSvgComponent } from '@eui/components/eui-icon';\nimport { EuiLoadingDirective } from './eui-loading.directive';\n\n@Directive({\n    selector: 'input[euiClearable]',\n    standalone: true,\n})\nexport class EuiClearableDirective implements OnChanges, AfterViewInit {\n    @HostBinding('attr.readonly')\n    @Input()\n    get readonly(): any {\n        return this._isReadonly ? '' : null;\n    }\n    set readonly(v: BooleanInput) {\n        this._isReadonly = coerceBooleanProperty(v);\n    }\n\n    @HostBinding('disabled')\n    @Input()\n    get disabled(): any {\n        return this._disabled ? '' : null;\n    }\n    set disabled(v: BooleanInput) {\n        this._disabled = coerceBooleanProperty(v);\n    }\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [this._cssClasses, this._euiClearable ? `${this._elementRef.nativeElement.rootClassName}--clearable` : ``].join(' ').trim();\n    }\n    public set cssClasses(value: string) {\n        this._cssClasses = value;\n    }\n    private _cssClasses: string;\n\n    @Input()\n    get euiClearable(): boolean {\n        return this._euiClearable;\n    }\n    set euiClearable(value: BooleanInput) {\n        this._euiClearable = coerceBooleanProperty(value);\n    }\n    protected _clearableIcon: ComponentRef<EuiIconSvgComponent>;\n    private _euiUFlexWrapper: HTMLDivElement;\n    private _euiClearable: boolean;\n    private _isReadonly: boolean;\n    private _disabled: boolean;\n\n    constructor(\n        private _elementRef: ElementRef,\n        private _viewContainerRef: ViewContainerRef,\n        private _renderer: Renderer2,\n        private injector: Injector\n    ) {}\n\n    ngAfterViewInit(): void {\n        if (this._clearableIcon) {\n            const control = this.injector.get(NgControl, null, { optional: true });\n            const value = control\n                ? control instanceof NgModel\n                    ? control.model?.toString()\n                    : control.value?.toString()\n                : this._elementRef.nativeElement.value;\n            this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'visibility', value?.length > 0 ? 'visible' : 'hidden');\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.euiClearable) {\n            // get type of the control\n            const type = this._elementRef.nativeElement.type;\n            if (coerceBooleanProperty(changes['euiClearable'].currentValue)) {\n                // check if type is not euiInputNumber or euiInputText, reset and throw error\n                if (type !== 'eui-number' && type !== 'text' && type !== 'search') {\n                    this.euiClearable = true;\n                    throw new Error('euiClearable is only allowed for euiInputText or euiInputNumber');\n                }\n                // create dynamically the icon\n                this.createClearableIcon();\n\n                // wrap them all to an eui-clearable-wrapper\n                this.createFlexWrapper();\n                this._renderer.appendChild(this._euiUFlexWrapper, this._clearableIcon.location.nativeElement);\n            } else if (this._clearableIcon) {\n                this.removeClearableIcon();\n                const euiLoading = this.injector.get(EuiLoadingDirective, null, { optional: true })?.euiLoading;\n                if (!euiLoading) {\n                    this.removeFlexWrapper();\n                }\n            }\n        }\n\n        if (changes['readonly']) {\n            if (changes['readonly'].currentValue === false && this.euiClearable) {\n                // create wrapper\n                this.createFlexWrapper();\n                // create dynamically the icon\n                this.createClearableIcon();\n                this._renderer.appendChild(this._euiUFlexWrapper, this._clearableIcon.location.nativeElement);\n            }\n            if (changes['readonly'].currentValue === true) {\n                this.removeClearableIcon();\n                this.removeFlexWrapper();\n            }\n        }\n\n        if (changes['disabled']) {\n            if (this._clearableIcon) {\n                const disabled = changes['disabled']?.currentValue;\n                if (disabled) {\n                    this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'pointer-events', 'none');\n                    this._renderer.removeAttribute(this._clearableIcon.location.nativeElement, 'tabindex');\n                } else {\n                    this._renderer.removeStyle(this._clearableIcon.location.nativeElement, 'pointer-events');\n                    this._renderer.setAttribute(this._clearableIcon.location.nativeElement, 'tabindex', '0');\n                }\n            }\n        }\n    }\n\n    @HostListener('input', ['$event.target.value'])\n    @HostListener('ngModelChange', ['$event'])\n    private onKeyUpAndModelChange(value): void {\n        if (this.euiClearable) {\n            const visibility = value?.toString().length > 0 ? 'visible' : 'hidden';\n            this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'visibility', visibility);\n        }\n    }\n\n    private onClearableClicked(): void {\n        if (this._elementRef.nativeElement.disabled) {\n            return;\n        }\n        const control = this.injector.get(NgControl, undefined, { optional: true });\n        if (control) {\n            control.reset();\n        } else {\n            const inputEvent = new InputEvent('input', { data: null });\n            this._elementRef.nativeElement.value = null;\n            this._elementRef.nativeElement.dispatchEvent(inputEvent);\n        }\n        const clearEvent = new InputEvent('clear');\n        this._elementRef.nativeElement.dispatchEvent(clearEvent);\n        this._elementRef.nativeElement.focus();\n    }\n\n    /**\n     * creates the Clearable icon component\n     *\n     * @private\n     */\n    private createClearableIcon(): void {\n        if (!this._clearableIcon) {\n            // TODO: turn import of EuiIconSvgComponent into a type?\n            this._clearableIcon = this._viewContainerRef.createComponent(EuiIconSvgComponent);\n            this._clearableIcon.instance.set = 'eui';\n            this._clearableIcon.instance.icon = 'eui-close';\n            this._clearableIcon.instance.ariaLabel = 'Clear input field';\n            this._renderer.addClass(this._clearableIcon.location.nativeElement, 'eui-input-text--clearable-icon'); // TODO: use generic name like eui-icon--clearable\n            this._renderer.listen(this._clearableIcon.location.nativeElement, 'click', this.onClearableClicked.bind(this));\n            this._renderer.listen(this._clearableIcon.location.nativeElement, 'keydown.enter', this.onClearableClicked.bind(this));\n            const control = this.injector.get(NgControl, null, { optional: true });\n            const value = control\n                ? control instanceof NgModel\n                    ? control.model?.toString()\n                    : control.value?.toString()\n                : this._elementRef.nativeElement.value;\n            this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'visibility', value?.length > 0 ? 'visible' : 'hidden');\n            if (!this._elementRef.nativeElement.disabled) {\n                this._renderer.setAttribute(this._clearableIcon.location.nativeElement, 'tabindex', '0');\n            } else {\n                this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'pointer-events', 'none');\n            }\n        }\n    }\n\n    /**\n     * detach the Clearable icon from the view\n     *\n     * @private\n     */\n    private removeClearableIcon(): void {\n        if (this._clearableIcon) {\n            const index = this._viewContainerRef.indexOf(this._clearableIcon.hostView);\n            this._viewContainerRef.detach(index);\n            this._clearableIcon = null;\n        }\n    }\n\n    /**\n     * create a flex wrapper for the input to hold the icon\n     *\n     * @private\n     */\n    private createFlexWrapper(): void {\n        if (!this._euiUFlexWrapper && !this.doesParentHasAFlexWrapper()) {\n            this._euiUFlexWrapper = this._renderer.createElement('div');\n            this._renderer.addClass(this._euiUFlexWrapper, 'eui-clearable-wrapper');\n            this._renderer.setAttribute(this._euiUFlexWrapper, 'flexWrapper', null);\n            this._renderer.insertBefore(\n                this._elementRef.nativeElement.parentElement,\n                this._euiUFlexWrapper,\n                this._elementRef.nativeElement\n            );\n            this._renderer.appendChild(this._euiUFlexWrapper, this._elementRef.nativeElement);\n        }\n        if (!this._euiUFlexWrapper && this.doesParentHasAFlexWrapper()) {\n            this._euiUFlexWrapper = this._elementRef.nativeElement.parentElement;\n        }\n    }\n\n    /**\n     * checks if the parent has a flexWrapper. This is used to avoid creating multiple flexWrappers\n     *\n     * @private\n     */\n    private doesParentHasAFlexWrapper(): boolean {\n        return this._elementRef.nativeElement.parentElement.hasAttribute('flexWrapper');\n    }\n\n    /**\n     * removes the flexWrapper while keeping the input element intact\n     *\n     * @private\n     */\n    private removeFlexWrapper(): void {\n        if (this._euiUFlexWrapper) {\n            this._renderer.insertBefore(this._euiUFlexWrapper.parentElement, this._elementRef.nativeElement, this._euiUFlexWrapper);\n            this._renderer.removeChild(this._euiUFlexWrapper.parentElement, this._euiUFlexWrapper);\n            this._euiUFlexWrapper.remove();\n            this._euiUFlexWrapper = null;\n        }\n    }\n}\n"]}
|
235
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-clearable.directive.js","sourceRoot":"","sources":["../../../directives/eui-clearable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Injector,\n    Input,\n    OnChanges,\n    Renderer2,\n    SimpleChanges,\n    ViewContainerRef,\n} from '@angular/core';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { NgControl, NgModel } from '@angular/forms';\nimport { EuiIconSvgComponent } from '@eui/components/eui-icon';\nimport { EuiLoadingDirective } from './eui-loading.directive';\n\n@Directive({\n    selector: 'input[euiClearable]',\n    standalone: true,\n})\nexport class EuiClearableDirective implements OnChanges, AfterViewInit {\n    @HostBinding('attr.readonly')\n    @Input()\n    get readonly(): any {\n        return this._isReadonly ? '' : null;\n    }\n    set readonly(v: BooleanInput) {\n        this._isReadonly = coerceBooleanProperty(v);\n    }\n\n    @HostBinding('disabled')\n    @Input()\n    get disabled(): any {\n        return this._disabled ? '' : null;\n    }\n    set disabled(v: BooleanInput) {\n        this._disabled = coerceBooleanProperty(v);\n    }\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [this._cssClasses, this._euiClearable ? `${this._elementRef.nativeElement.rootClassName}--clearable` : ``].join(' ').trim();\n    }\n    public set cssClasses(value: string) {\n        this._cssClasses = value;\n    }\n    private _cssClasses: string;\n\n    @Input()\n    get euiClearable(): boolean {\n        return this._euiClearable;\n    }\n    set euiClearable(value: BooleanInput) {\n        this._euiClearable = coerceBooleanProperty(value);\n    }\n    protected _clearableIcon: ComponentRef<EuiIconSvgComponent>;\n    private _euiUFlexWrapper: HTMLDivElement;\n    private _euiClearable: boolean;\n    private _isReadonly: boolean;\n    private _disabled: boolean;\n\n    constructor(\n        private _elementRef: ElementRef,\n        private _viewContainerRef: ViewContainerRef,\n        private _renderer: Renderer2,\n        private injector: Injector\n    ) {}\n\n    ngAfterViewInit(): void {\n        if (this._clearableIcon) {\n            const control = this.injector.get(NgControl, null, { optional: true });\n            const value = control\n                ? control instanceof NgModel\n                    ? control.model?.toString()\n                    : control.value?.toString()\n                : this._elementRef.nativeElement.value;\n            this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'visibility', value?.length > 0 ? 'visible' : 'hidden');\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.euiClearable) {\n            // get type of the control\n            const type = this._elementRef.nativeElement.type;\n            if (coerceBooleanProperty(changes['euiClearable'].currentValue)) {\n                // check if type is not euiInputNumber or euiInputText, reset and throw error\n                if (type !== 'eui-number' && type !== 'text' && type !== 'search') {\n                    this.euiClearable = true;\n                    throw new Error('euiClearable is only allowed in euiInputNumber or euiInputText');\n                }\n                // create dynamically the icon\n                this.createClearableIcon();\n\n                // wrap them all at an eui-u-flex class\n                this.createFlexWrapper();\n                this._renderer.appendChild(this._euiUFlexWrapper, this._clearableIcon.location.nativeElement);\n            } else if (this._clearableIcon) {\n                this.removeClearableIcon();\n                const euiLoading = this.injector.get(EuiLoadingDirective, null, { optional: true })?.euiLoading;\n                if (!euiLoading) {\n                    this.removeFlexWrapper();\n                }\n            }\n        }\n\n        if (changes['readonly']) {\n            if (changes['readonly'].currentValue === false && this.euiClearable) {\n                // create wrapper\n                this.createFlexWrapper();\n                // create dynamically the icon\n                this.createClearableIcon();\n                this._renderer.appendChild(this._euiUFlexWrapper, this._clearableIcon.location.nativeElement);\n            }\n            if (changes['readonly'].currentValue === true) {\n                this.removeClearableIcon();\n                this.removeFlexWrapper();\n            }\n        }\n\n        if (changes['disabled']) {\n            if (this._clearableIcon) {\n                const disabled = changes['disabled']?.currentValue;\n                if (disabled) {\n                    this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'pointer-events', 'none');\n                    this._renderer.removeAttribute(this._clearableIcon.location.nativeElement, 'tabindex');\n                } else {\n                    this._renderer.removeStyle(this._clearableIcon.location.nativeElement, 'pointer-events');\n                    this._renderer.setAttribute(this._clearableIcon.location.nativeElement, 'tabindex', '0');\n                }\n            }\n        }\n    }\n\n    @HostListener('input', ['$event.target.value'])\n    @HostListener('ngModelChange', ['$event'])\n    private onKeyUpAndModelChange(value): void {\n        if (this.euiClearable) {\n            const visibility = value?.toString().length > 0 ? 'visible' : 'hidden';\n            this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'visibility', visibility);\n        }\n    }\n\n    private onClearableClicked(): void {\n        if (this._elementRef.nativeElement.disabled) {\n            return;\n        }\n        const control = this.injector.get(NgControl, undefined, { optional: true });\n        if (control) {\n            control.reset();\n        } else {\n            const inputEvent = new InputEvent('input', { data: null });\n            this._elementRef.nativeElement.value = null;\n            this._elementRef.nativeElement.dispatchEvent(inputEvent);\n        }\n        const clearEvent = new InputEvent('clear');\n        this._elementRef.nativeElement.dispatchEvent(clearEvent);\n        this._elementRef.nativeElement.focus();\n    }\n\n    /**\n     * creates the Clearable icon component\n     *\n     * @private\n     */\n    private createClearableIcon(): void {\n        if (!this._clearableIcon) {\n            // TODO: turn import of EuiIconSvgComponent into a type?\n            this._clearableIcon = this._viewContainerRef.createComponent(EuiIconSvgComponent);\n            this._clearableIcon.instance.set = 'eui';\n            this._clearableIcon.instance.icon = 'eui-close';\n            this._clearableIcon.instance.ariaLabel = 'Clear input field';\n            this._renderer.addClass(this._clearableIcon.location.nativeElement, 'eui-input-text--clearable-icon');\n            this._renderer.listen(this._clearableIcon.location.nativeElement, 'click', this.onClearableClicked.bind(this));\n            this._renderer.listen(this._clearableIcon.location.nativeElement, 'keydown.enter', this.onClearableClicked.bind(this));\n            const control = this.injector.get(NgControl, null, { optional: true });\n            const value = control\n                ? control instanceof NgModel\n                    ? control.model?.toString()\n                    : control.value?.toString()\n                : this._elementRef.nativeElement.value;\n            this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'visibility', value?.length > 0 ? 'visible' : 'hidden');\n            if (!this._elementRef.nativeElement.disabled) {\n                this._renderer.setAttribute(this._clearableIcon.location.nativeElement, 'tabindex', '0');\n            } else {\n                this._renderer.setStyle(this._clearableIcon.location.nativeElement, 'pointer-events', 'none');\n            }\n        }\n    }\n\n    /**\n     * detach the Clearable icon from the view\n     *\n     * @private\n     */\n    private removeClearableIcon(): void {\n        if (this._clearableIcon) {\n            const index = this._viewContainerRef.indexOf(this._clearableIcon.hostView);\n            this._viewContainerRef.detach(index);\n            this._clearableIcon = null;\n        }\n    }\n\n    /**\n     * create a flex wrapper for the input to hold the icon\n     *\n     * @private\n     */\n    private createFlexWrapper(): void {\n        if (!this._euiUFlexWrapper && !this.doesParentHasAFlexWrapper()) {\n            this._euiUFlexWrapper = this._renderer.createElement('div');\n            this._renderer.addClass(this._euiUFlexWrapper, 'eui-u-flex');\n            this._renderer.addClass(this._euiUFlexWrapper, 'eui-u-p-relative');\n            this._renderer.setAttribute(this._euiUFlexWrapper, 'flexWrapper', null);\n            this._renderer.insertBefore(\n                this._elementRef.nativeElement.parentElement,\n                this._euiUFlexWrapper,\n                this._elementRef.nativeElement\n            );\n            this._renderer.appendChild(this._euiUFlexWrapper, this._elementRef.nativeElement);\n        }\n        if (!this._euiUFlexWrapper && this.doesParentHasAFlexWrapper()) {\n            this._euiUFlexWrapper = this._elementRef.nativeElement.parentElement;\n        }\n    }\n\n    /**\n     * checks if the parent has a flexWrapper. This is used to avoid creating multiple flexWrappers\n     *\n     * @private\n     */\n    private doesParentHasAFlexWrapper(): boolean {\n        return this._elementRef.nativeElement.parentElement.hasAttribute('flexWrapper');\n    }\n\n    /**\n     * removes the flexWrapper while keeping the input element intact\n     *\n     * @private\n     */\n    private removeFlexWrapper(): void {\n        if (this._euiUFlexWrapper) {\n            this._renderer.insertBefore(this._euiUFlexWrapper.parentElement, this._elementRef.nativeElement, this._euiUFlexWrapper);\n            this._renderer.removeChild(this._euiUFlexWrapper.parentElement, this._euiUFlexWrapper);\n            this._euiUFlexWrapper.remove();\n            this._euiUFlexWrapper = null;\n        }\n    }\n}"]}
|
@@ -37,23 +37,23 @@ export class EuiHasPermissionDirective {
|
|
37
37
|
});
|
38
38
|
return hasPermission;
|
39
39
|
}
|
40
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.
|
41
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.
|
40
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiHasPermissionDirective, deps: [{ token: i0.ElementRef }, { token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: i1.EuiPermissionService }], target: i0.ɵɵFactoryTarget.Directive }); }
|
41
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.7", type: EuiHasPermissionDirective, selector: "[euiHasPermission]", inputs: { euiHasPermission: "euiHasPermission" }, ngImport: i0 }); }
|
42
42
|
}
|
43
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiHasPermissionDirective, decorators: [{
|
44
44
|
type: Directive,
|
45
45
|
args: [{
|
46
46
|
selector: '[euiHasPermission]',
|
47
47
|
}]
|
48
|
-
}], ctorParameters:
|
48
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: i1.EuiPermissionService }], propDecorators: { euiHasPermission: [{
|
49
49
|
type: Input
|
50
50
|
}] } });
|
51
51
|
export class EuiHasPermissionDirectiveModule {
|
52
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.
|
53
|
-
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.0-next.
|
54
|
-
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.0-next.
|
52
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiHasPermissionDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
53
|
+
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiHasPermissionDirectiveModule, declarations: [EuiHasPermissionDirective], imports: [CommonModule], exports: [EuiHasPermissionDirective] }); }
|
54
|
+
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiHasPermissionDirectiveModule, imports: [CommonModule] }); }
|
55
55
|
}
|
56
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.
|
56
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiHasPermissionDirectiveModule, decorators: [{
|
57
57
|
type: NgModule,
|
58
58
|
args: [{
|
59
59
|
imports: [CommonModule],
|
@@ -61,4 +61,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.4",
|
|
61
61
|
declarations: [EuiHasPermissionDirective],
|
62
62
|
}]
|
63
63
|
}] });
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLWhhcy1wZXJtaXNzaW9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2RpcmVjdGl2ZXMvZXVpLWhhcy1wZXJtaXNzaW9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxRQUFRLEVBQWlDLE1BQU0sZUFBZSxDQUFDO0FBQ3RHLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7O0FBRy9DLG9CQUFvQjtBQUlwQixtQkFBbUI7QUFDbkIsTUFBTSxPQUFPLHlCQUF5QjtJQUlsQyxZQUNZLE9BQW1CLEVBQ25CLFdBQTZCLEVBQzdCLGFBQStCLEVBQy9CLGlCQUF1QztRQUh2QyxZQUFPLEdBQVAsT0FBTyxDQUFZO1FBQ25CLGdCQUFXLEdBQVgsV0FBVyxDQUFrQjtRQUM3QixrQkFBYSxHQUFiLGFBQWEsQ0FBa0I7UUFDL0Isc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFzQjtRQVAzQyxnQkFBVyxHQUFHLEVBQUUsQ0FBQztRQUNqQixhQUFRLEdBQUcsSUFBSSxDQUFDO0lBT3JCLENBQUM7SUFFSixJQUNJLGdCQUFnQixDQUFDLEdBQUc7UUFDcEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxHQUFHLENBQUM7UUFDdkIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFTyxVQUFVO1FBQ2QsSUFBSSxJQUFJLENBQUMsZUFBZSxFQUFFLEVBQUU7WUFDeEIsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUNmLElBQUksQ0FBQyxhQUFhLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO2dCQUN4RCxJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQzthQUN6QjtTQUNKO2FBQU07WUFDSCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztZQUNyQixJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO1NBQzlCO0lBQ0wsQ0FBQztJQUVPLGVBQWU7UUFDbkIsSUFBSSxhQUFhLEdBQUcsSUFBSSxDQUFDO1FBQ3pCLHlDQUF5QztRQUN6QyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFO1lBQ3BDLGFBQWEsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsd0JBQXdCLENBQUMsVUFBVSxDQUFDLElBQUksYUFBYSxDQUFDO1FBQ2pHLENBQUMsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxhQUFhLENBQUM7SUFDekIsQ0FBQzt3SUFwQ1EseUJBQXlCOzRIQUF6Qix5QkFBeUI7O2tHQUF6Qix5QkFBeUI7a0JBSnJDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLG9CQUFvQjtpQkFDakM7MktBY08sZ0JBQWdCO3NCQURuQixLQUFLOztBQWlDVixNQUFNLE9BQU8sK0JBQStCO3dJQUEvQiwrQkFBK0I7eUlBQS9CLCtCQUErQixpQkE1Qy9CLHlCQUF5QixhQXdDeEIsWUFBWSxhQXhDYix5QkFBeUI7eUlBNEN6QiwrQkFBK0IsWUFKOUIsWUFBWTs7a0dBSWIsK0JBQStCO2tCQUwzQyxRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFLENBQUMseUJBQXlCLENBQUM7b0JBQ3BDLFlBQVksRUFBRSxDQUFDLHlCQUF5QixDQUFDO2lCQUM1QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5wdXQsIE5nTW9kdWxlLCBUZW1wbGF0ZVJlZiwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEV1aVBlcm1pc3Npb25TZXJ2aWNlIH0gZnJvbSAnQGV1aS9jb3JlJztcblxuLyogZXNsaW50LWRpc2FibGUgKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2V1aUhhc1Blcm1pc3Npb25dJyxcbn0pXG4vKiBlc2xpbnQtZW5hYmxlICovXG5leHBvcnQgY2xhc3MgRXVpSGFzUGVybWlzc2lvbkRpcmVjdGl2ZSB7XG4gICAgcHJpdmF0ZSBwZXJtaXNzaW9ucyA9IFtdO1xuICAgIHByaXZhdGUgaXNIaWRkZW4gPSB0cnVlO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgZWxlbWVudDogRWxlbWVudFJlZixcbiAgICAgICAgcHJpdmF0ZSB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcbiAgICAgICAgcHJpdmF0ZSB2aWV3Q29udGFpbmVyOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgICAgICBwcml2YXRlIHBlcm1pc3Npb25TZXJ2aWNlOiBFdWlQZXJtaXNzaW9uU2VydmljZVxuICAgICkge31cblxuICAgIEBJbnB1dCgpXG4gICAgc2V0IGV1aUhhc1Blcm1pc3Npb24odmFsKSB7XG4gICAgICAgIHRoaXMucGVybWlzc2lvbnMgPSB2YWw7XG4gICAgICAgIHRoaXMudXBkYXRlVmlldygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgdXBkYXRlVmlldygpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuY2hlY2tQZXJtaXNzaW9uKCkpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLmlzSGlkZGVuKSB7XG4gICAgICAgICAgICAgICAgdGhpcy52aWV3Q29udGFpbmVyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLnRlbXBsYXRlUmVmKTtcbiAgICAgICAgICAgICAgICB0aGlzLmlzSGlkZGVuID0gZmFsc2U7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLmlzSGlkZGVuID0gdHJ1ZTtcbiAgICAgICAgICAgIHRoaXMudmlld0NvbnRhaW5lci5jbGVhcigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjaGVja1Blcm1pc3Npb24oKTogYm9vbGVhbiB7XG4gICAgICAgIGxldCBoYXNQZXJtaXNzaW9uID0gdHJ1ZTtcbiAgICAgICAgLy8gZm9yIHN0YXJ0LCBpdCBjaGVja3Mgd2l0aCBhbmQgb3BlcmF0b3JcbiAgICAgICAgdGhpcy5wZXJtaXNzaW9ucy5mb3JFYWNoKChwZXJtaXNzaW9uKSA9PiB7XG4gICAgICAgICAgICBoYXNQZXJtaXNzaW9uID0gdGhpcy5wZXJtaXNzaW9uU2VydmljZS5jaGVja0F0dHJpYnV0ZVBlcm1pc3Npb24ocGVybWlzc2lvbikgJiYgaGFzUGVybWlzc2lvbjtcbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybiBoYXNQZXJtaXNzaW9uO1xuICAgIH1cbn1cblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbRXVpSGFzUGVybWlzc2lvbkRpcmVjdGl2ZV0sXG4gICAgZGVjbGFyYXRpb25zOiBbRXVpSGFzUGVybWlzc2lvbkRpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIEV1aUhhc1Blcm1pc3Npb25EaXJlY3RpdmVNb2R1bGUge31cbiJdfQ==
|
@@ -122,16 +122,16 @@ export class EuiLoadingDirective {
|
|
122
122
|
this._loadingIcon = null;
|
123
123
|
}
|
124
124
|
}
|
125
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.
|
126
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.
|
125
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiLoadingDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
|
126
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.7", type: EuiLoadingDirective, isStandalone: true, selector: "[euiLoading]", inputs: { readonly: "readonly", euiLoading: "euiLoading" }, host: { properties: { "attr.readonly": "this.readonly", "class": "this.cssClasses" } }, usesOnChanges: true, ngImport: i0 }); }
|
127
127
|
}
|
128
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.
|
128
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiLoadingDirective, decorators: [{
|
129
129
|
type: Directive,
|
130
130
|
args: [{
|
131
131
|
selector: '[euiLoading]',
|
132
132
|
standalone: true,
|
133
133
|
}]
|
134
|
-
}], ctorParameters:
|
134
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.Renderer2 }, { type: i0.Injector }], propDecorators: { readonly: [{
|
135
135
|
type: HostBinding,
|
136
136
|
args: ['attr.readonly']
|
137
137
|
}, {
|
@@ -142,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.4",
|
|
142
142
|
}], euiLoading: [{
|
143
143
|
type: Input
|
144
144
|
}] } });
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-loading.directive.js","sourceRoot":"","sources":["../../../directives/eui-loading.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostBinding,\n    Injector,\n    Input,\n    OnChanges,\n    Renderer2,\n    SimpleChanges,\n    ViewContainerRef,\n} from '@angular/core';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { EuiClearableDirective } from './eui-clearable.directive';\nimport { EuiIconComponent } from '@eui/components/eui-icon';\n\n@Directive({\n    selector: '[euiLoading]',\n    standalone: true,\n})\nexport class EuiLoadingDirective implements OnChanges {\n    @HostBinding('attr.readonly')\n    @Input()\n    get readonly(): any {\n        return this._isReadonly ? '' : null;\n    }\n    set readonly(v: BooleanInput) {\n        this._isReadonly = coerceBooleanProperty(v);\n    }\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [this._cssClasses, this._euiLoading ? `${this._elementRef.nativeElement.rootClassName}--loading` : ``].join(' ').trim();\n    }\n    public set cssClasses(value: string) {\n        this._cssClasses = value;\n    }\n    @Input()\n    get euiLoading(): boolean {\n        return this._euiLoading;\n    }\n    set euiLoading(value: BooleanInput) {\n        this._euiLoading = coerceBooleanProperty(value);\n    }\n    protected _loadingIcon: ComponentRef<EuiIconComponent>;\n    private _euiUFlexWrapper: HTMLDivElement;\n    private _euiLoading;\n    private rootClassName: string;\n    private _cssClasses: string;\n    private _isReadonly: boolean;\n\n    constructor(\n        private _elementRef: ElementRef,\n        private _viewContainerRef: ViewContainerRef,\n        private _renderer: Renderer2,\n        private injector: Injector\n    ) {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.euiLoading) {\n            const euiClearable = this.injector.get(EuiClearableDirective, undefined, { optional: true })?.euiClearable;\n            if (coerceBooleanProperty(changes['euiLoading'].currentValue)) {\n                // wrap them all in an eui-u-flex class\n                this.createFlexWrapper();\n\n                // create dynamically the icon\n                this.createLoadingIcon();\n            } else if (this._loadingIcon) {\n                this.removeLoadingIcon();\n                if (!euiClearable) {\n                    this.removeFlexWrapper();\n                }\n            }\n        }\n\n        if (changes['readonly']) {\n            if (changes['readonly'].currentValue === false && this.euiLoading) {\n                // create wrapper\n                this.createFlexWrapper();\n\n                // create dynamically the icon\n                this.createLoadingIcon();\n                this._renderer.appendChild(this._euiUFlexWrapper, this._loadingIcon.location.nativeElement);\n            }\n            if (changes['readonly'].currentValue === true) {\n                this.removeLoadingIcon();\n                this.removeFlexWrapper();\n            }\n        }\n    }\n\n    /**\n     * create a flex wrapper for the input to hold the icon\n     *\n     * @private\n     */\n    private createFlexWrapper(): void {\n        if (!this._euiUFlexWrapper && !this.doesParentHasAFlexWrapper()) {\n            this._euiUFlexWrapper = this._renderer.createElement('div');\n            this._renderer.addClass(this._euiUFlexWrapper, 'eui-u-flex');\n            this._renderer.setAttribute(this._euiUFlexWrapper, 'flexWrapper', null);\n            this._renderer.setStyle(this._euiUFlexWrapper, 'position', 'relative');\n            this._renderer.insertBefore(\n                this._elementRef.nativeElement.parentElement,\n                this._euiUFlexWrapper,\n                this._elementRef.nativeElement\n            );\n            this._renderer.appendChild(this._euiUFlexWrapper, this._elementRef.nativeElement);\n        }\n        if (!this._euiUFlexWrapper && this.doesParentHasAFlexWrapper()) {\n            this._euiUFlexWrapper = this._elementRef.nativeElement.parentElement;\n        }\n    }\n\n    /**\n     * checks if the parent has a flexWrapper. This is used to avoid creating multiple flexWrappers\n     *\n     * @private\n     */\n    private doesParentHasAFlexWrapper(): boolean {\n        return this._elementRef.nativeElement.parentElement.hasAttribute('flexWrapper');\n    }\n\n    /**\n     * removes the flexWrapper while keeping the input element intact\n     *\n     * @private\n     */\n    private removeFlexWrapper(): void {\n        if (this._euiUFlexWrapper) {\n            this._renderer.insertBefore(this._euiUFlexWrapper.parentElement, this._elementRef.nativeElement, this._euiUFlexWrapper);\n            this._renderer.removeChild(this._euiUFlexWrapper.parentElement, this._euiUFlexWrapper);\n            this._euiUFlexWrapper.remove();\n            this._euiUFlexWrapper = null;\n        }\n    }\n\n    /**\n     * creates the loading icon component\n     *\n     * @private\n     */\n    private createLoadingIcon(): void {\n        if (!this._loadingIcon) {\n            this._loadingIcon = this._viewContainerRef.createComponent(EuiIconComponent);\n            this._loadingIcon.instance.styleClass = 'eui-input-text--loading-icon';\n            this._loadingIcon.instance.ariaLabel = 'XXXXX';\n            this._renderer.appendChild(this._euiUFlexWrapper, this._loadingIcon.location.nativeElement);\n        }\n    }\n\n    /**\n     * removes the loading icon component\n     *\n     * @private\n     */\n    private removeLoadingIcon(): void {\n        if (this._loadingIcon) {\n            const index = this._viewContainerRef.indexOf(this._loadingIcon.hostView);\n            this._viewContainerRef.detach(index);\n            this._loadingIcon = null;\n        }\n    }\n}\n"]}
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-loading.directive.js","sourceRoot":"","sources":["../../../directives/eui-loading.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostBinding,\n    Injector,\n    Input,\n    OnChanges,\n    Renderer2,\n    SimpleChanges,\n    ViewContainerRef,\n} from '@angular/core';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { EuiClearableDirective } from './eui-clearable.directive';\nimport { EuiIconComponent } from '@eui/components/eui-icon';\n\n@Directive({\n    selector: '[euiLoading]',\n    standalone: true,\n})\nexport class EuiLoadingDirective implements OnChanges {\n    @HostBinding('attr.readonly')\n    @Input()\n    get readonly(): any {\n        return this._isReadonly ? '' : null;\n    }\n    set readonly(v: BooleanInput) {\n        this._isReadonly = coerceBooleanProperty(v);\n    }\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [this._cssClasses, this._euiLoading ? `${this._elementRef.nativeElement.rootClassName}--loading` : ``].join(' ').trim();\n    }\n    public set cssClasses(value: string) {\n        this._cssClasses = value;\n    }\n    @Input()\n    get euiLoading(): boolean {\n        return this._euiLoading;\n    }\n    set euiLoading(value: BooleanInput) {\n        this._euiLoading = coerceBooleanProperty(value);\n    }\n    protected _loadingIcon: ComponentRef<EuiIconComponent>;\n    private _euiUFlexWrapper: HTMLDivElement;\n    private _euiLoading;\n    private rootClassName: string;\n    private _cssClasses: string;\n    private _isReadonly: boolean;\n\n    constructor(\n        private _elementRef: ElementRef,\n        private _viewContainerRef: ViewContainerRef,\n        private _renderer: Renderer2,\n        private injector: Injector\n    ) {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.euiLoading) {\n            const euiClearable = this.injector.get(EuiClearableDirective, undefined, { optional: true })?.euiClearable;\n            if (coerceBooleanProperty(changes['euiLoading'].currentValue)) {\n                // wrap them all in an eui-u-flex class\n                this.createFlexWrapper();\n\n                // create dynamically the icon\n                this.createLoadingIcon();\n            } else if (this._loadingIcon) {\n                this.removeLoadingIcon();\n                if (!euiClearable) {\n                    this.removeFlexWrapper();\n                }\n            }\n        }\n\n        if (changes['readonly']) {\n            if (changes['readonly'].currentValue === false && this.euiLoading) {\n                // create wrapper\n                this.createFlexWrapper();\n\n                // create dynamically the icon\n                this.createLoadingIcon();\n                this._renderer.appendChild(this._euiUFlexWrapper, this._loadingIcon.location.nativeElement);\n            }\n            if (changes['readonly'].currentValue === true) {\n                this.removeLoadingIcon();\n                this.removeFlexWrapper();\n            }\n        }\n    }\n\n    /**\n     * create a flex wrapper for the input to hold the icon\n     *\n     * @private\n     */\n    private createFlexWrapper(): void {\n        if (!this._euiUFlexWrapper && !this.doesParentHasAFlexWrapper()) {\n            this._euiUFlexWrapper = this._renderer.createElement('div');\n            this._renderer.addClass(this._euiUFlexWrapper, 'eui-u-flex');\n            this._renderer.setAttribute(this._euiUFlexWrapper, 'flexWrapper', null);\n            this._renderer.setStyle(this._euiUFlexWrapper, 'position', 'relative');\n            this._renderer.insertBefore(\n                this._elementRef.nativeElement.parentElement,\n                this._euiUFlexWrapper,\n                this._elementRef.nativeElement\n            );\n            this._renderer.appendChild(this._euiUFlexWrapper, this._elementRef.nativeElement);\n        }\n        if (!this._euiUFlexWrapper && this.doesParentHasAFlexWrapper()) {\n            this._euiUFlexWrapper = this._elementRef.nativeElement.parentElement;\n        }\n    }\n\n    /**\n     * checks if the parent has a flexWrapper. This is used to avoid creating multiple flexWrappers\n     *\n     * @private\n     */\n    private doesParentHasAFlexWrapper(): boolean {\n        return this._elementRef.nativeElement.parentElement.hasAttribute('flexWrapper');\n    }\n\n    /**\n     * removes the flexWrapper while keeping the input element intact\n     *\n     * @private\n     */\n    private removeFlexWrapper(): void {\n        if (this._euiUFlexWrapper) {\n            this._renderer.insertBefore(this._euiUFlexWrapper.parentElement, this._elementRef.nativeElement, this._euiUFlexWrapper);\n            this._renderer.removeChild(this._euiUFlexWrapper.parentElement, this._euiUFlexWrapper);\n            this._euiUFlexWrapper.remove();\n            this._euiUFlexWrapper = null;\n        }\n    }\n\n    /**\n     * creates the loading icon component\n     *\n     * @private\n     */\n    private createLoadingIcon(): void {\n        if (!this._loadingIcon) {\n            this._loadingIcon = this._viewContainerRef.createComponent(EuiIconComponent);\n            this._loadingIcon.instance.styleClass = 'eui-input-text--loading-icon';\n            this._loadingIcon.instance.ariaLabel = 'XXXXX';\n            this._renderer.appendChild(this._euiUFlexWrapper, this._loadingIcon.location.nativeElement);\n        }\n    }\n\n    /**\n     * removes the loading icon component\n     *\n     * @private\n     */\n    private removeLoadingIcon(): void {\n        if (this._loadingIcon) {\n            const index = this._viewContainerRef.indexOf(this._loadingIcon.hostView);\n            this._viewContainerRef.detach(index);\n            this._loadingIcon = null;\n        }\n    }\n}\n"]}
|
@@ -182,10 +182,10 @@ export class EuiMaxLengthDirective {
|
|
182
182
|
let input = this.el.nativeElement;
|
183
183
|
return this.control && this.control.control.updateOn === 'change' ? this.control.value : input.value;
|
184
184
|
}
|
185
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.
|
186
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.
|
185
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiMaxLengthDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
186
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.7", type: EuiMaxLengthDirective, selector: "\n input[euiMaxlength],\n textarea[euiMaxlength],\n [ngModel][euiMaxlength],\n [formControlName][euiMaxlength]", inputs: { maxLength: ["euiMaxlength", "maxLength"], isShowMaxlength: "isShowMaxlength" }, outputs: { maxLengthReached: "maxLengthReached" }, host: { listeners: { "change": "onChange($event)", "input": "onInput($event)", "paste": "onPaste($event)" } }, usesOnChanges: true, ngImport: i0 }); }
|
187
187
|
}
|
188
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.
|
188
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiMaxLengthDirective, decorators: [{
|
189
189
|
type: Directive,
|
190
190
|
args: [{
|
191
191
|
selector: `
|
@@ -194,11 +194,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.4",
|
|
194
194
|
[ngModel][euiMaxlength],
|
195
195
|
[formControlName][euiMaxlength]`,
|
196
196
|
}]
|
197
|
-
}], ctorParameters:
|
197
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.NgControl, decorators: [{
|
198
198
|
type: Self
|
199
199
|
}, {
|
200
200
|
type: Optional
|
201
|
-
}] }]
|
201
|
+
}] }], propDecorators: { maxLength: [{
|
202
202
|
type: Input,
|
203
203
|
args: ['euiMaxlength']
|
204
204
|
}], isShowMaxlength: [{
|
@@ -217,11 +217,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.4",
|
|
217
217
|
args: ['paste', ['$event']]
|
218
218
|
}] } });
|
219
219
|
export class EuiMaxLengthDirectiveModule {
|
220
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.
|
221
|
-
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.0-next.
|
222
|
-
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.0-next.
|
220
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiMaxLengthDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
221
|
+
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiMaxLengthDirectiveModule, declarations: [EuiMaxLengthDirective], imports: [CommonModule], exports: [EuiMaxLengthDirective] }); }
|
222
|
+
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiMaxLengthDirectiveModule, imports: [CommonModule] }); }
|
223
223
|
}
|
224
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.
|
224
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiMaxLengthDirectiveModule, decorators: [{
|
225
225
|
type: NgModule,
|
226
226
|
args: [{
|
227
227
|
imports: [CommonModule],
|
@@ -229,4 +229,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.4",
|
|
229
229
|
declarations: [EuiMaxLengthDirective]
|
230
230
|
}]
|
231
231
|
}] });
|
232
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-maxlength.directive.js","sourceRoot":"","sources":["../../../directives/eui-maxlength.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    Input,\n    Output,\n    AfterContentInit,\n    NgModule,\n    EventEmitter,\n    OnDestroy,\n    HostListener,\n    Optional,\n    Self,\n    OnChanges,\n    SimpleChanges,\n    Renderer2,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { coerceBooleanProperty, BooleanInput, NumberInput, coerceNumberProperty } from '@angular/cdk/coercion';\n\n/* eslint-disable */\n@Directive({\n    selector: `\n    input[euiMaxlength],\n    textarea[euiMaxlength],\n    [ngModel][euiMaxlength],\n    [formControlName][euiMaxlength]`,\n})\nexport class EuiMaxLengthDirective implements AfterContentInit, OnDestroy, OnChanges {\n    @Input('euiMaxlength')\n    get maxLength(): number { return this._maxLength; }\n    set maxLength(value: NumberInput) { this._maxLength = coerceNumberProperty(value); }\n    private _maxLength: number;\n    @Input('isShowMaxlength')\n    get isShowMaxlength(): boolean { return this._isShowMaxlength; }\n    set isShowMaxlength(value: BooleanInput) { this._isShowMaxlength = coerceBooleanProperty(value); }\n    private _isShowMaxlength = true;\n    @Output() maxLengthReached: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    valueChangesSubscription: Subscription;\n\n    private maxLengthSpan: HTMLSpanElement;\n    private wrapper: HTMLDivElement;\n    private lengthCalcFn: () => number;\n\n    constructor(private el: ElementRef,\n                private renderer: Renderer2,\n                @Self() @Optional() private control: NgControl) {\n        // set default length calculation behavior\n        this.setLengthCalcFactory((value) => value?.length || 0);\n    }\n\n    ngOnDestroy() {\n        // remove all DOM added elements\n        this.destroyMaxLengthBox();\n\n        // unsubscribe from valueChanges\n        if(this.valueChangesSubscription) {\n            this.valueChangesSubscription.unsubscribe();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if(changes['isShowMaxlength'] && this.maxLengthSpan) {\n            if(this.isShowMaxlength) {\n                this.createMaxLengthBox();\n                this._refreshValue();\n            } else {\n                this.destroyMaxLengthBox();\n            }\n        }\n        if(changes['maxLength']) {\n            if(this.maxLength < 0) {\n                throw new Error('euiMaxlength of an input or a textarea cannot be negative.')\n            }\n            if(this.maxLength) {\n                this._refreshValue();\n            } else {\n                this.renderer.removeAttribute(this.el.nativeElement, 'maxLength');\n            }\n        }\n    }\n\n    ngAfterContentInit() {\n        if (this.maxLength) {\n            this.createMaxLengthBox();\n            this._refreshValue();\n        }\n\n        // this subscription is needed apart from HostListener to Changes in case usage of this directive\n        // in custom component that implements ngDefaultControl\n        if (this.control?.valueChanges) {\n            this.valueChangesSubscription = this.control.valueChanges.subscribe(() => {\n                this._refreshValue();\n            });\n        }\n    }\n\n    @HostListener('change', ['$event'])\n    onChange(event: Event) {\n        if(!this.control || this.control?.control.updateOn !== 'change') {\n            this._refreshValue();\n        }\n    }\n\n    @HostListener('input', ['$event'])\n    onInput(event: KeyboardEvent) {\n        if(!this.control || this.control?.control.updateOn !== 'change') {\n            this._refreshValue();\n        }\n    }\n\n    @HostListener('paste', ['$event'])\n    onPaste(event: ClipboardEvent) {\n        // get the value from clipboard\n        let value = (event.clipboardData || window['clipboardData']).getData('text');\n        // calculate and set the maxLength based on the clipboard value\n        let input = <HTMLInputElement>this.el.nativeElement;\n        this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength(value));\n    }\n\n    public setLengthCalcFactory(fn: (input: string) => number): void {\n        this.lengthCalcFn = () => {\n            const value = this.getValue();\n            return fn(value);\n        }\n    }\n\n    /**\n     * calculates the maxLength of an input element. Calculation is made\n     * against the value of the Model or Input Element.\n     * @param value Optional the value to calculate max length against (override the Model one)\n     * @private\n     */\n    private calculateMaxLength(value?: string): number {\n        const inputValue = this.getValue();\n        return (value?.length || (inputValue?.length || 0) - this.lengthCalcFn()) + this.maxLength;\n    }\n\n    private _refreshValue() {\n        let input = <HTMLInputElement>this.el.nativeElement;\n        let valueLength = this.lengthCalcFn();\n        let remainingLength = this.maxLength - valueLength;\n\n        this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength());\n        if(this.maxLengthSpan) {\n            // based on the remaining length add/remove the error class\n            if (remainingLength <= 0) {\n                this.renderer.addClass(this.maxLengthSpan, 'eui-input-maxlength--invalid')\n                this.maxLengthReached.emit(true);\n            } else {\n                this.renderer.removeClass(this.maxLengthSpan, 'eui-input-maxlength--invalid')\n                this.maxLengthReached.emit(false);\n            }\n            // set the value of remaining characters\n            if (remainingLength < 0) {\n                // this feature is only available when the calculation of length is not custom\n                // to support this feature you need to calculate this.maxLength also\n                if (this.control) {\n                    this.control.control.setValue(input.value.substring(0, this.calculateMaxLength()))\n                } else {\n                    input.value = input.value.substring(0, this.calculateMaxLength());\n                }\n                this.renderer.setProperty(this.maxLengthSpan, 'innerHTML', '0')\n            } else if (remainingLength >= 0) {\n                this.renderer.setProperty(this.maxLengthSpan, 'innerHTML', (this.maxLength - valueLength).toString())\n            }\n        }\n    }\n\n    /**\n     * creates the maxLength box by adding it to DOM and attaching correct Classes\n     * for Wrapper and Span (actual box holding max length)\n     * @private\n     */\n    private createMaxLengthBox() {\n        // creates the span that holds the max length value which changes according to input\n        this.maxLengthSpan = this.renderer.createElement('span');\n        this.renderer.addClass(this.maxLengthSpan, 'eui-input-maxlength')\n        this.renderer.setAttribute(this.maxLengthSpan, 'innerHTML', this.maxLength.toString());\n\n        // create wrapper element\n        let nativeElement: HTMLElement = this.el.nativeElement;\n        if (nativeElement != null) {\n            // set width to 100%\n            this.renderer.setStyle(nativeElement, 'width', '100%');\n            let parent: Node = nativeElement.parentNode;\n            if (parent != null && this.isShowMaxlength) {\n                // creates wrapper div of input and maxLength span\n                this.wrapper = this.renderer.createElement('div');\n                this.renderer.addClass(this.wrapper, 'eui-input-maxlength-wrapper');\n                // swap, wrapper should wrap the nativeElement and maxLength span\n                parent.replaceChild(this.wrapper, nativeElement);\n                this.renderer.appendChild(this.wrapper, nativeElement);\n                this.renderer.appendChild(this.wrapper, this.maxLengthSpan);\n            }\n        }\n    }\n\n    /**\n     * destroys the maxLength box from DOM\n     * @private\n     */\n    private destroyMaxLengthBox() {\n        // removes maxlength element from DOM\n        if(this.maxLengthSpan) {\n            this.renderer.removeChild(this.maxLengthSpan.parentElement, this.maxLengthSpan);\n        }\n\n        // remove wrapper from DOM\n        if(this.wrapper) {\n            // get parent node of wrapper\n            let parent: Node = this.wrapper.parentNode;\n            let nativeElement: HTMLElement = this.el.nativeElement;\n            // swap wrapper and nativeElement\n            parent?.replaceChild(nativeElement, this.wrapper);\n            // removes wrapper element from DOM\n            this.renderer.removeChild(this.wrapper.parentElement, this.wrapper);\n        }\n    }\n\n    /**\n     * returns the value based on whether control is present and control's\n     * updateOn strategy.\n     * @private\n     */\n    private getValue(): string {\n        let input = <HTMLInputElement>this.el.nativeElement;\n        return this.control && this.control.control.updateOn === 'change' ? this.control.value : input.value;\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [EuiMaxLengthDirective],\n    declarations: [EuiMaxLengthDirective]\n})\nexport class EuiMaxLengthDirectiveModule {\n}\n/* eslint-enable */\n"]}
|
232
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-maxlength.directive.js","sourceRoot":"","sources":["../../../directives/eui-maxlength.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    Input,\n    Output,\n    AfterContentInit,\n    NgModule,\n    EventEmitter,\n    OnDestroy,\n    HostListener,\n    Optional,\n    Self,\n    OnChanges,\n    SimpleChanges,\n    Renderer2,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { coerceBooleanProperty, BooleanInput, NumberInput, coerceNumberProperty } from '@angular/cdk/coercion';\n\n/* eslint-disable */\n@Directive({\n    selector: `\n    input[euiMaxlength],\n    textarea[euiMaxlength],\n    [ngModel][euiMaxlength],\n    [formControlName][euiMaxlength]`,\n})\nexport class EuiMaxLengthDirective implements AfterContentInit, OnDestroy, OnChanges {\n    @Input('euiMaxlength')\n    get maxLength(): number { return this._maxLength; }\n    set maxLength(value: NumberInput) { this._maxLength = coerceNumberProperty(value); }\n    private _maxLength: number;\n    @Input('isShowMaxlength')\n    get isShowMaxlength(): boolean { return this._isShowMaxlength; }\n    set isShowMaxlength(value: BooleanInput) { this._isShowMaxlength = coerceBooleanProperty(value); }\n    private _isShowMaxlength = true;\n    @Output() maxLengthReached: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    valueChangesSubscription: Subscription;\n\n    private maxLengthSpan: HTMLSpanElement;\n    private wrapper: HTMLDivElement;\n    private lengthCalcFn: () => number;\n\n    constructor(private el: ElementRef,\n                private renderer: Renderer2,\n                @Self() @Optional() private control: NgControl) {\n        // set default length calculation behavior\n        this.setLengthCalcFactory((value) => value?.length || 0);\n    }\n\n    ngOnDestroy() {\n        // remove all DOM added elements\n        this.destroyMaxLengthBox();\n\n        // unsubscribe from valueChanges\n        if(this.valueChangesSubscription) {\n            this.valueChangesSubscription.unsubscribe();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if(changes['isShowMaxlength'] && this.maxLengthSpan) {\n            if(this.isShowMaxlength) {\n                this.createMaxLengthBox();\n                this._refreshValue();\n            } else {\n                this.destroyMaxLengthBox();\n            }\n        }\n        if(changes['maxLength']) {\n            if(this.maxLength < 0) {\n                throw new Error('euiMaxlength of an input or a textarea cannot be negative.')\n            }\n            if(this.maxLength) {\n                this._refreshValue();\n            } else {\n                this.renderer.removeAttribute(this.el.nativeElement, 'maxLength');\n            }\n        }\n    }\n\n    ngAfterContentInit() {\n        if (this.maxLength) {\n            this.createMaxLengthBox();\n            this._refreshValue();\n        }\n\n        // this subscription is needed apart from HostListener to Changes in case usage of this directive\n        // in custom component that implements ngDefaultControl\n        if (this.control?.valueChanges) {\n            this.valueChangesSubscription = this.control.valueChanges.subscribe(() => {\n                this._refreshValue();\n            });\n        }\n    }\n\n    @HostListener('change', ['$event'])\n    onChange(event: Event) {\n        if(!this.control || this.control?.control.updateOn !== 'change') {\n            this._refreshValue();\n        }\n    }\n\n    @HostListener('input', ['$event'])\n    onInput(event: KeyboardEvent) {\n        if(!this.control || this.control?.control.updateOn !== 'change') {\n            this._refreshValue();\n        }\n    }\n\n    @HostListener('paste', ['$event'])\n    onPaste(event: ClipboardEvent) {\n        // get the value from clipboard\n        let value = (event.clipboardData || window['clipboardData']).getData('text');\n        // calculate and set the maxLength based on the clipboard value\n        let input = <HTMLInputElement>this.el.nativeElement;\n        this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength(value));\n    }\n\n    public setLengthCalcFactory(fn: (input: string) => number): void {\n        this.lengthCalcFn = () => {\n            const value = this.getValue();\n            return fn(value);\n        }\n    }\n\n    /**\n     * calculates the maxLength of an input element. Calculation is made\n     * against the value of the Model or Input Element.\n     * @param value Optional the value to calculate max length against (override the Model one)\n     * @private\n     */\n    private calculateMaxLength(value?: string): number {\n        const inputValue = this.getValue();\n        return (value?.length || (inputValue?.length || 0) - this.lengthCalcFn()) + this.maxLength;\n    }\n\n    private _refreshValue() {\n        let input = <HTMLInputElement>this.el.nativeElement;\n        let valueLength = this.lengthCalcFn();\n        let remainingLength = this.maxLength - valueLength;\n\n        this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength());\n        if(this.maxLengthSpan) {\n            // based on the remaining length add/remove the error class\n            if (remainingLength <= 0) {\n                this.renderer.addClass(this.maxLengthSpan, 'eui-input-maxlength--invalid')\n                this.maxLengthReached.emit(true);\n            } else {\n                this.renderer.removeClass(this.maxLengthSpan, 'eui-input-maxlength--invalid')\n                this.maxLengthReached.emit(false);\n            }\n            // set the value of remaining characters\n            if (remainingLength < 0) {\n                // this feature is only available when the calculation of length is not custom\n                // to support this feature you need to calculate this.maxLength also\n                if (this.control) {\n                    this.control.control.setValue(input.value.substring(0, this.calculateMaxLength()))\n                } else {\n                    input.value = input.value.substring(0, this.calculateMaxLength());\n                }\n                this.renderer.setProperty(this.maxLengthSpan, 'innerHTML', '0')\n            } else if (remainingLength >= 0) {\n                this.renderer.setProperty(this.maxLengthSpan, 'innerHTML', (this.maxLength - valueLength).toString())\n            }\n        }\n    }\n\n    /**\n     * creates the maxLength box by adding it to DOM and attaching correct Classes\n     * for Wrapper and Span (actual box holding max length)\n     * @private\n     */\n    private createMaxLengthBox() {\n        // creates the span that holds the max length value which changes according to input\n        this.maxLengthSpan = this.renderer.createElement('span');\n        this.renderer.addClass(this.maxLengthSpan, 'eui-input-maxlength')\n        this.renderer.setAttribute(this.maxLengthSpan, 'innerHTML', this.maxLength.toString());\n\n        // create wrapper element\n        let nativeElement: HTMLElement = this.el.nativeElement;\n        if (nativeElement != null) {\n            // set width to 100%\n            this.renderer.setStyle(nativeElement, 'width', '100%');\n            let parent: Node = nativeElement.parentNode;\n            if (parent != null && this.isShowMaxlength) {\n                // creates wrapper div of input and maxLength span\n                this.wrapper = this.renderer.createElement('div');\n                this.renderer.addClass(this.wrapper, 'eui-input-maxlength-wrapper');\n                // swap, wrapper should wrap the nativeElement and maxLength span\n                parent.replaceChild(this.wrapper, nativeElement);\n                this.renderer.appendChild(this.wrapper, nativeElement);\n                this.renderer.appendChild(this.wrapper, this.maxLengthSpan);\n            }\n        }\n    }\n\n    /**\n     * destroys the maxLength box from DOM\n     * @private\n     */\n    private destroyMaxLengthBox() {\n        // removes maxlength element from DOM\n        if(this.maxLengthSpan) {\n            this.renderer.removeChild(this.maxLengthSpan.parentElement, this.maxLengthSpan);\n        }\n\n        // remove wrapper from DOM\n        if(this.wrapper) {\n            // get parent node of wrapper\n            let parent: Node = this.wrapper.parentNode;\n            let nativeElement: HTMLElement = this.el.nativeElement;\n            // swap wrapper and nativeElement\n            parent?.replaceChild(nativeElement, this.wrapper);\n            // removes wrapper element from DOM\n            this.renderer.removeChild(this.wrapper.parentElement, this.wrapper);\n        }\n    }\n\n    /**\n     * returns the value based on whether control is present and control's\n     * updateOn strategy.\n     * @private\n     */\n    private getValue(): string {\n        let input = <HTMLInputElement>this.el.nativeElement;\n        return this.control && this.control.control.updateOn === 'change' ? this.control.value : input.value;\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [EuiMaxLengthDirective],\n    declarations: [EuiMaxLengthDirective]\n})\nexport class EuiMaxLengthDirectiveModule {\n}\n/* eslint-enable */\n"]}
|
@@ -5,10 +5,10 @@ export class EuiResizableComponent {
|
|
5
5
|
this.classes = 'eui-resizable';
|
6
6
|
this.e2e = 'eui-resizable';
|
7
7
|
}
|
8
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.
|
9
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.0-next.
|
8
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiResizableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
9
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.0-next.7", type: EuiResizableComponent, selector: "eui-resizable", host: { properties: { "class": "this.classes", "attr.data-e2e": "this.e2e" } }, ngImport: i0, template: "<div class=\"eui-resizable-bar\" aria-describedby=\"Resizable handle\"></div>\n<span class=\"eui-resizable-icon__container\">\n <svg aria-hidden=\"true\" role=\"img\" focusable=\"false\" class=\"eui-resizable-icon\">\n <use href=\"assets/icons/sprites/sharp.svg#code-working-sharp\"></use>\n </svg>\n</span>\n", styles: [".eui-resizable{--eui-resizable-bar-color: blueviolet;display:flex;justify-content:flex-end;vertical-align:middle}.eui-resizable .eui-resizable-bar{background:var(--eui-resizable-bar-color);background-clip:content-box;bottom:0;border-left:var(--eui-base-spacing-2xs) solid transparent;border-right:var(--eui-base-spacing-2xs) solid transparent;cursor:ew-resize;margin:0 calc(-1.1 * var(--eui-base-spacing-m));opacity:0;position:absolute;top:0;transition:opacity .3s;width:var(--eui-base-spacing-s)}.eui-resizable .eui-resizable-bar:hover,.eui-resizable .eui-resizable-bar:active{opacity:1}.eui-resizable .eui-resizable-icon__container{height:var(--eui-base-spacing-m);margin-right:calc(-1 * (var(--eui-base-spacing-m) + var(--eui-base-spacing-2xs)));position:absolute;top:0;transform:translateY(calc(var(--eui-base-spacing-m) + 2px))}.eui-resizable .eui-resizable-icon__container .eui-resizable-icon{color:var(--eui-base-color-grey-35);fill:var(--eui-base-color-grey-35);height:var(--eui-base-spacing-m);width:var(--eui-base-spacing-m)}*:not(th)[euiresizable]{position:relative}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
10
10
|
}
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiResizableComponent, decorators: [{
|
12
12
|
type: Component,
|
13
13
|
args: [{ selector: 'eui-resizable', encapsulation: ViewEncapsulation.None, template: "<div class=\"eui-resizable-bar\" aria-describedby=\"Resizable handle\"></div>\n<span class=\"eui-resizable-icon__container\">\n <svg aria-hidden=\"true\" role=\"img\" focusable=\"false\" class=\"eui-resizable-icon\">\n <use href=\"assets/icons/sprites/sharp.svg#code-working-sharp\"></use>\n </svg>\n</span>\n", styles: [".eui-resizable{--eui-resizable-bar-color: blueviolet;display:flex;justify-content:flex-end;vertical-align:middle}.eui-resizable .eui-resizable-bar{background:var(--eui-resizable-bar-color);background-clip:content-box;bottom:0;border-left:var(--eui-base-spacing-2xs) solid transparent;border-right:var(--eui-base-spacing-2xs) solid transparent;cursor:ew-resize;margin:0 calc(-1.1 * var(--eui-base-spacing-m));opacity:0;position:absolute;top:0;transition:opacity .3s;width:var(--eui-base-spacing-s)}.eui-resizable .eui-resizable-bar:hover,.eui-resizable .eui-resizable-bar:active{opacity:1}.eui-resizable .eui-resizable-icon__container{height:var(--eui-base-spacing-m);margin-right:calc(-1 * (var(--eui-base-spacing-m) + var(--eui-base-spacing-2xs)));position:absolute;top:0;transform:translateY(calc(var(--eui-base-spacing-m) + 2px))}.eui-resizable .eui-resizable-icon__container .eui-resizable-icon{color:var(--eui-base-color-grey-35);fill:var(--eui-base-color-grey-35);height:var(--eui-base-spacing-m);width:var(--eui-base-spacing-m)}*:not(th)[euiresizable]{position:relative}\n"] }]
|
14
14
|
}], propDecorators: { classes: [{
|
@@ -40,18 +40,18 @@ export class EuiResizableDirective {
|
|
40
40
|
this._renderer.appendChild(this._elementRef.nativeElement, this._resizableBar.location.nativeElement);
|
41
41
|
}
|
42
42
|
}
|
43
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.
|
44
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.
|
43
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiResizableDirective, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
44
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.0-next.7", type: EuiResizableDirective, selector: "[euiResizable]", host: { properties: { "style.width.px": "this.styleWidth", "style.max-width.px": "this.styleMaxWidth", "style.flex-basis.px": "this.styleFlexBasisWidth" } }, ngImport: i0 }); }
|
45
45
|
}
|
46
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.
|
46
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiResizableDirective, decorators: [{
|
47
47
|
type: Directive,
|
48
48
|
args: [{
|
49
49
|
selector: '[euiResizable]',
|
50
50
|
}]
|
51
|
-
}], ctorParameters:
|
51
|
+
}], ctorParameters: () => [{ type: Document, decorators: [{
|
52
52
|
type: Inject,
|
53
53
|
args: [DOCUMENT]
|
54
|
-
}] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }]
|
54
|
+
}] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }], propDecorators: { styleWidth: [{
|
55
55
|
type: HostBinding,
|
56
56
|
args: ['style.width.px']
|
57
57
|
}], styleMaxWidth: [{
|
@@ -61,4 +61,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.4",
|
|
61
61
|
type: HostBinding,
|
62
62
|
args: ['style.flex-basis.px']
|
63
63
|
}] } });
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLXJlc2l6YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9kaXJlY3RpdmVzL2V1aS1yZXNpemFibGUvZXVpLXJlc2l6YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNDLE9BQU8sRUFBZ0IsU0FBUyxFQUFjLFdBQVcsRUFBRSxNQUFNLEVBQWtELE1BQU0sZUFBZSxDQUFDO0FBQ3pJLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzNFLE9BQU8sRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTFDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDOztBQUtsRSxNQUFNLE9BQU8scUJBQXFCO0lBUTlCLFlBQzhCLFlBQXNCLEVBQ3hDLFdBQW9DLEVBQ3BDLFNBQW9CLEVBQ3BCLGlCQUFtQztRQUhqQixpQkFBWSxHQUFaLFlBQVksQ0FBVTtRQUN4QyxnQkFBVyxHQUFYLFdBQVcsQ0FBeUI7UUFDcEMsY0FBUyxHQUFULFNBQVMsQ0FBVztRQUNwQixzQkFBaUIsR0FBakIsaUJBQWlCLENBQWtCO1FBTnZDLGFBQVEsR0FBRyxJQUFJLE9BQU8sRUFBVyxDQUFDO0lBT3ZDLENBQUM7SUFFSixRQUFRO1FBQ0osSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7UUFDM0IsU0FBUyxDQUFhLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxvQkFBb0IsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxDQUFDLElBQUksQ0FDdkcsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsY0FBYyxFQUFFLENBQUMsRUFBTSxtREFBbUQ7UUFDdkYsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FDdkI7YUFDQSxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUNiLG1CQUFtQjtZQUNuQixJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO2dCQUNoQixNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLHFCQUFxQixFQUFFLENBQUM7Z0JBRWhGLFNBQVMsQ0FBYSxJQUFJLENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQyxDQUFDLElBQUksQ0FDdEQsR0FBRyxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLENBQUMsS0FBSyxHQUFHLE9BQU8sR0FBRyxLQUFLLENBQUMsRUFDN0Msb0JBQW9CLEVBQUUsRUFDdEIsU0FBUyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUM7cUJBQ2xELFNBQVMsQ0FBRSxDQUFDLElBQUksRUFBRSxFQUFFO29CQUNqQixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO29CQUNyQyxJQUFJLENBQUMsVUFBVSxHQUFHLFdBQVcsQ0FBQztvQkFDOUIsSUFBSSxDQUFDLGFBQWEsR0FBRyxXQUFXLENBQUM7b0JBQ2pDLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxXQUFXLENBQUM7Z0JBQzNDLENBQUMsQ0FBQyxDQUFBO2FBQ1Q7UUFDTCxDQUFDLENBQUMsQ0FBQTtJQUNWLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDekIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNoQyxDQUFDO0lBRU8sbUJBQW1CO1FBQ3ZCLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3JCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1lBQ25GLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1NBQ3pHO0lBQ0wsQ0FBQzt3SUFsRFEscUJBQXFCLGtCQVNsQixRQUFROzRIQVRYLHFCQUFxQjs7a0dBQXJCLHFCQUFxQjtrQkFIakMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsZ0JBQWdCO2lCQUM3Qjs7MEJBVVEsTUFBTTsyQkFBQyxRQUFRO3lIQVJXLFVBQVU7c0JBQXhDLFdBQVc7dUJBQUMsZ0JBQWdCO2dCQUNNLGFBQWE7c0JBQS9DLFdBQVc7dUJBQUMsb0JBQW9CO2dCQUNHLG1CQUFtQjtzQkFBdEQsV0FBVzt1QkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJcbmltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudFJlZiwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0QmluZGluZywgSW5qZWN0LCBPbkRlc3Ryb3ksIE9uSW5pdCwgUmVuZGVyZXIyLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBkaXN0aW5jdFVudGlsQ2hhbmdlZCwgbWFwLCB0YWtlVW50aWwsIHRhcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IGZyb21FdmVudCwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBFdWlSZXNpemFibGVDb21wb25lbnQgfSBmcm9tICcuL2V1aS1yZXNpemFibGUuY29tcG9uZW50JztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbZXVpUmVzaXphYmxlXScsXG59KVxuZXhwb3J0IGNsYXNzIEV1aVJlc2l6YWJsZURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBASG9zdEJpbmRpbmcoJ3N0eWxlLndpZHRoLnB4Jykgc3R5bGVXaWR0aDogbnVtYmVyO1xuICAgIEBIb3N0QmluZGluZygnc3R5bGUubWF4LXdpZHRoLnB4Jykgc3R5bGVNYXhXaWR0aDogbnVtYmVyO1xuICAgIEBIb3N0QmluZGluZygnc3R5bGUuZmxleC1iYXNpcy5weCcpIHN0eWxlRmxleEJhc2lzV2lkdGg6IG51bWJlcjtcblxuICAgIHByaXZhdGUgX3Jlc2l6YWJsZUJhcjogQ29tcG9uZW50UmVmPEV1aVJlc2l6YWJsZUNvbXBvbmVudD47XG4gICAgcHJpdmF0ZSBkZXN0cm95JCA9IG5ldyBTdWJqZWN0PGJvb2xlYW4+KCk7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChET0NVTUVOVCkgcHJpdmF0ZSBfZG9jdW1lbnRSZWY6IERvY3VtZW50LFxuICAgICAgICBwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcbiAgICAgICAgcHJpdmF0ZSBfcmVuZGVyZXI6IFJlbmRlcmVyMixcbiAgICAgICAgcHJpdmF0ZSBfdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZixcbiAgICApIHt9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5fY3JlYXRlUmVzaXphYmxlQmFyKCk7XG4gICAgICAgIGZyb21FdmVudDxNb3VzZUV2ZW50Pih0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQucXVlcnlTZWxlY3RvcignLmV1aS1yZXNpemFibGUtYmFyJyksICdtb3VzZWRvd24nKS5waXBlKFxuICAgICAgICAgICAgdGFwKChlKSA9PiBlLnByZXZlbnREZWZhdWx0KCkpLCAgICAgLy8gRGlzYWxsb3cgc2VsZWN0aW5nIHRleHQgd2hlbiBkcmFnZ2luZyBmb3IgcmVzaXplXG4gICAgICAgICAgICB0YWtlVW50aWwodGhpcy5kZXN0cm95JClcbiAgICAgICAgICAgIClcbiAgICAgICAgICAgIC5zdWJzY3JpYmUoKGUpID0+IHtcbiAgICAgICAgICAgICAgICAvLyBPbmx5IGxlZnQgYnV0dG9uXG4gICAgICAgICAgICAgICAgaWYgKGUuYnV0dG9uID09PSAwKSB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IHsgd2lkdGgsIHJpZ2h0IH0gPSB0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgICAgICAgICAgICAgZnJvbUV2ZW50PE1vdXNlRXZlbnQ+KHRoaXMuX2RvY3VtZW50UmVmLCAnbW91c2Vtb3ZlJykucGlwZShcbiAgICAgICAgICAgICAgICAgICAgICAgIG1hcCgoeyBjbGllbnRYIH0pID0+IHdpZHRoICsgY2xpZW50WCAtIHJpZ2h0KSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKCksXG4gICAgICAgICAgICAgICAgICAgICAgICB0YWtlVW50aWwoZnJvbUV2ZW50KHRoaXMuX2RvY3VtZW50UmVmLCAnbW91c2V1cCcpKSlcbiAgICAgICAgICAgICAgICAgICAgICAgIC5zdWJzY3JpYmUoIChzaXplKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgY29uc3Qgcm91bmRlZFNpemUgPSBNYXRoLnJvdW5kKHNpemUpO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuc3R5bGVXaWR0aCA9IHJvdW5kZWRTaXplO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuc3R5bGVNYXhXaWR0aCA9IHJvdW5kZWRTaXplO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuc3R5bGVGbGV4QmFzaXNXaWR0aCA9IHJvdW5kZWRTaXplO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KVxuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRlc3Ryb3kkLm5leHQodHJ1ZSk7XG4gICAgICAgIHRoaXMuZGVzdHJveSQudW5zdWJzY3JpYmUoKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIF9jcmVhdGVSZXNpemFibGVCYXIoKTogdm9pZCB7XG4gICAgICAgIGlmICghdGhpcy5fcmVzaXphYmxlQmFyKSB7XG4gICAgICAgICAgICB0aGlzLl9yZXNpemFibGVCYXIgPSB0aGlzLl92aWV3Q29udGFpbmVyUmVmLmNyZWF0ZUNvbXBvbmVudChFdWlSZXNpemFibGVDb21wb25lbnQpO1xuICAgICAgICAgICAgdGhpcy5fcmVuZGVyZXIuYXBwZW5kQ2hpbGQodGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCB0aGlzLl9yZXNpemFibGVCYXIubG9jYXRpb24ubmF0aXZlRWxlbWVudCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
@@ -4,11 +4,11 @@ import { EuiResizableComponent } from './eui-resizable.component';
|
|
4
4
|
import { EuiResizableDirective } from './eui-resizable.directive';
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
export class EuiResizableDirectiveModule {
|
7
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.
|
8
|
-
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.0-next.
|
9
|
-
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.0-next.
|
7
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiResizableDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
8
|
+
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiResizableDirectiveModule, declarations: [EuiResizableComponent, EuiResizableDirective], imports: [CommonModule], exports: [EuiResizableDirective] }); }
|
9
|
+
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiResizableDirectiveModule, imports: [CommonModule] }); }
|
10
10
|
}
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-next.7", ngImport: i0, type: EuiResizableDirectiveModule, decorators: [{
|
12
12
|
type: NgModule,
|
13
13
|
args: [{
|
14
14
|
imports: [CommonModule],
|