@siemens/element-ng 47.3.0 → 47.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/badge/si-badge.component.d.ts +1 -1
- package/breadcrumb/breadcrumb-item.model.d.ts +36 -0
- package/breadcrumb/index.d.ts +7 -0
- package/breadcrumb/package.json +3 -0
- package/breadcrumb/si-breadcrumb-item-template.directive.d.ts +10 -0
- package/breadcrumb/si-breadcrumb.component.d.ts +46 -0
- package/breadcrumb/si-breadcrumb.module.d.ts +7 -0
- package/card/index.d.ts +6 -0
- package/card/package.json +3 -0
- package/card/si-card.component.d.ts +79 -0
- package/card/si-card.module.d.ts +7 -0
- package/circle-status/index.d.ts +6 -0
- package/circle-status/package.json +3 -0
- package/circle-status/si-circle-status.component.d.ts +66 -0
- package/circle-status/si-circle-status.module.d.ts +7 -0
- package/column-selection-dialog/column-selection-editor/si-column-selection-editor.component.d.ts +23 -0
- package/column-selection-dialog/index.d.ts +6 -0
- package/column-selection-dialog/package.json +3 -0
- package/column-selection-dialog/si-column-selection-dialog.component.d.ts +114 -0
- package/column-selection-dialog/si-column-selection-dialog.service.d.ts +20 -0
- package/column-selection-dialog/si-column-selection-dialog.types.d.ts +68 -0
- package/common/models/status-type.model.d.ts +4 -2
- package/datatable/index.d.ts +42 -0
- package/datatable/package.json +3 -0
- package/datatable/si-datatable-interaction.directive.d.ts +34 -0
- package/datatable/si-datatable.module.d.ts +7 -0
- package/date-range-filter/index.d.ts +8 -0
- package/date-range-filter/package.json +3 -0
- package/date-range-filter/si-date-range-calculation.service.d.ts +33 -0
- package/date-range-filter/si-date-range-filter.component.d.ts +248 -0
- package/date-range-filter/si-date-range-filter.module.d.ts +7 -0
- package/date-range-filter/si-date-range-filter.types.d.ts +40 -0
- package/date-range-filter/si-relative-date.component.d.ts +31 -0
- package/datepicker/components/si-calendar-body.component.d.ts +137 -0
- package/datepicker/components/si-calendar-date-cell.directive.d.ts +16 -0
- package/datepicker/components/si-calendar-direction-button.component.d.ts +18 -0
- package/datepicker/components/si-compare-adapter.d.ts +37 -0
- package/datepicker/components/si-day-selection.component.d.ts +76 -0
- package/datepicker/components/si-initial-focus.component.d.ts +74 -0
- package/datepicker/components/si-month-selection.component.d.ts +62 -0
- package/datepicker/components/si-year-selection.component.d.ts +65 -0
- package/datepicker/date-time-helper.d.ts +302 -0
- package/datepicker/index.d.ts +15 -0
- package/datepicker/package.json +3 -0
- package/datepicker/si-calendar-button.component.d.ts +49 -0
- package/datepicker/si-date-input.directive.d.ts +114 -0
- package/datepicker/si-date-range.component.d.ts +150 -0
- package/datepicker/si-datepicker-overlay.component.d.ts +82 -0
- package/datepicker/si-datepicker-overlay.directive.d.ts +104 -0
- package/datepicker/si-datepicker.component.d.ts +228 -0
- package/datepicker/si-datepicker.directive.d.ts +62 -0
- package/datepicker/si-datepicker.model.d.ts +129 -0
- package/datepicker/si-datepicker.module.d.ts +12 -0
- package/datepicker/si-timepicker.component.d.ts +214 -0
- package/electron-titlebar/electron.helpers.d.ts +5 -0
- package/electron-titlebar/index.d.ts +7 -0
- package/electron-titlebar/package.json +3 -0
- package/electron-titlebar/si-electron-titlebar.component.d.ts +72 -0
- package/electron-titlebar/si-electron-titlebar.module.d.ts +7 -0
- package/fesm2022/siemens-element-ng-badge.mjs.map +1 -1
- package/fesm2022/siemens-element-ng-breadcrumb.mjs +302 -0
- package/fesm2022/siemens-element-ng-breadcrumb.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-card.mjs +122 -0
- package/fesm2022/siemens-element-ng-card.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-circle-status.mjs +146 -0
- package/fesm2022/siemens-element-ng-circle-status.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-column-selection-dialog.mjs +369 -0
- package/fesm2022/siemens-element-ng-column-selection-dialog.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-common.mjs.map +1 -1
- package/fesm2022/siemens-element-ng-datatable.mjs +173 -0
- package/fesm2022/siemens-element-ng-datatable.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-date-range-filter.mjs +649 -0
- package/fesm2022/siemens-element-ng-date-range-filter.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-datepicker.mjs +4231 -0
- package/fesm2022/siemens-element-ng-datepicker.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-electron-titlebar.mjs +142 -0
- package/fesm2022/siemens-element-ng-electron-titlebar.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-file-uploader.mjs +751 -0
- package/fesm2022/siemens-element-ng-file-uploader.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-filter-bar.mjs +153 -0
- package/fesm2022/siemens-element-ng-filter-bar.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-filtered-search.mjs +1139 -0
- package/fesm2022/siemens-element-ng-filtered-search.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-formly.mjs +935 -0
- package/fesm2022/siemens-element-ng-formly.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-icon.mjs +52 -14
- package/fesm2022/siemens-element-ng-icon.mjs.map +1 -1
- package/fesm2022/siemens-element-ng-info-page.mjs +63 -0
- package/fesm2022/siemens-element-ng-info-page.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-inline-notification.mjs +4 -6
- package/fesm2022/siemens-element-ng-inline-notification.mjs.map +1 -1
- package/fesm2022/siemens-element-ng-ip-input.mjs +451 -0
- package/fesm2022/siemens-element-ng-ip-input.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-list-details.mjs +390 -0
- package/fesm2022/siemens-element-ng-list-details.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-loading-spinner.mjs +15 -12
- package/fesm2022/siemens-element-ng-loading-spinner.mjs.map +1 -1
- package/fesm2022/siemens-element-ng-localization.mjs +306 -0
- package/fesm2022/siemens-element-ng-localization.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-modal.mjs +4 -1
- package/fesm2022/siemens-element-ng-modal.mjs.map +1 -1
- package/fesm2022/siemens-element-ng-password-strength.mjs +22 -16
- package/fesm2022/siemens-element-ng-password-strength.mjs.map +1 -1
- package/fesm2022/siemens-element-ng-phone-number.mjs +426 -0
- package/fesm2022/siemens-element-ng-phone-number.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-photo-upload.mjs +480 -0
- package/fesm2022/siemens-element-ng-photo-upload.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-result-details-list.mjs +74 -0
- package/fesm2022/siemens-element-ng-result-details-list.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-search-bar.mjs +193 -0
- package/fesm2022/siemens-element-ng-search-bar.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-shadow-root.mjs +70 -0
- package/fesm2022/siemens-element-ng-shadow-root.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-side-panel.mjs +554 -0
- package/fesm2022/siemens-element-ng-side-panel.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-slider.mjs +313 -0
- package/fesm2022/siemens-element-ng-slider.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-sort-bar.mjs +89 -0
- package/fesm2022/siemens-element-ng-sort-bar.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-split.mjs +575 -0
- package/fesm2022/siemens-element-ng-split.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-status-bar.mjs +348 -0
- package/fesm2022/siemens-element-ng-status-bar.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-status-toggle.mjs +196 -0
- package/fesm2022/siemens-element-ng-status-toggle.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-system-banner.mjs +47 -0
- package/fesm2022/siemens-element-ng-system-banner.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-tabs-next.mjs +491 -0
- package/fesm2022/siemens-element-ng-tabs-next.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-tabs.mjs +395 -0
- package/fesm2022/siemens-element-ng-tabs.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-translate.mjs.map +1 -1
- package/fesm2022/siemens-element-ng-tree-view.mjs +2936 -0
- package/fesm2022/siemens-element-ng-tree-view.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-unauthorized-page.mjs +76 -0
- package/fesm2022/siemens-element-ng-unauthorized-page.mjs.map +1 -0
- package/fesm2022/siemens-element-ng-wizard.mjs +2 -2
- package/fesm2022/siemens-element-ng-wizard.mjs.map +1 -1
- package/file-uploader/index.d.ts +8 -0
- package/file-uploader/package.json +3 -0
- package/file-uploader/si-file-dropzone.component.d.ts +106 -0
- package/file-uploader/si-file-uploader.component.d.ts +296 -0
- package/file-uploader/si-file-uploader.model.d.ts +12 -0
- package/file-uploader/si-file-uploader.module.d.ts +8 -0
- package/filter-bar/filter.d.ts +26 -0
- package/filter-bar/index.d.ts +8 -0
- package/filter-bar/package.json +3 -0
- package/filter-bar/si-filter-bar.component.d.ts +65 -0
- package/filter-bar/si-filter-bar.module.d.ts +7 -0
- package/filter-bar/si-filter-pill.component.d.ts +20 -0
- package/filtered-search/index.d.ts +7 -0
- package/filtered-search/package.json +3 -0
- package/filtered-search/si-filtered-search-helper.d.ts +22 -0
- package/filtered-search/si-filtered-search-value.component.d.ts +53 -0
- package/filtered-search/si-filtered-search.component.d.ts +329 -0
- package/filtered-search/si-filtered-search.model.d.ts +139 -0
- package/filtered-search/si-filtered-search.module.d.ts +7 -0
- package/filtered-search/values/date-value/si-filtered-search-date-value.component.d.ts +57 -0
- package/filtered-search/values/si-filtered-search-value.base.d.ts +27 -0
- package/filtered-search/values/typeahead/si-filtered-search-typeahead.component.d.ts +45 -0
- package/formly/fields/button/si-formly-button.component.d.ts +7 -0
- package/formly/fields/date-range/si-formly-date-range.component.d.ts +6 -0
- package/formly/fields/datetime/si-formly-datetime.component.d.ts +13 -0
- package/formly/fields/email/si-formly-email.component.d.ts +6 -0
- package/formly/fields/ip-input/si-formly-ip-input.component.d.ts +6 -0
- package/formly/fields/number/si-formly-number.component.d.ts +6 -0
- package/formly/fields/password/si-formly-password.component.d.ts +6 -0
- package/formly/fields/select/si-formly-select.component.d.ts +6 -0
- package/formly/fields/text/si-formly-text-display.component.d.ts +7 -0
- package/formly/fields/textarea/si-formly-textarea.component.d.ts +18 -0
- package/formly/fields/time/si-formly-time.component.d.ts +13 -0
- package/formly/index.d.ts +6 -0
- package/formly/package.json +3 -0
- package/formly/si-formly-translate.extension.d.ts +11 -0
- package/formly/si-formly.component.d.ts +62 -0
- package/formly/si-formly.module.d.ts +35 -0
- package/formly/structural/si-formly-accordion/si-formly-accordion.component.d.ts +13 -0
- package/formly/structural/si-formly-array/si-formly-array.component.d.ts +6 -0
- package/formly/structural/si-formly-object/si-formly-object.component.d.ts +6 -0
- package/formly/structural/si-formly-object-grid/si-formly-object-grid.component.d.ts +22 -0
- package/formly/structural/si-formly-object-grid/si-formly-object-grid.model.d.ts +21 -0
- package/formly/structural/si-formly-object-plain/si-formly-object-plain.component.d.ts +6 -0
- package/formly/structural/si-formly-tabset/si-formly-object-tabset.component.d.ts +7 -0
- package/formly/utils.d.ts +6 -0
- package/formly/wrapper/si-formly-fieldset.component.d.ts +8 -0
- package/formly/wrapper/si-formly-form-field-provider.directive.d.ts +19 -0
- package/formly/wrapper/si-formly-horizontal-wrapper.component.d.ts +6 -0
- package/formly/wrapper/si-formly-icon-wrapper.component.d.ts +6 -0
- package/formly/wrapper/si-formly-wrapper.component.d.ts +8 -0
- package/icon/element-icons.d.ts +15 -0
- package/icon/si-status-icon.component.d.ts +6 -1
- package/info-page/index.d.ts +5 -0
- package/info-page/package.json +3 -0
- package/info-page/si-info-page.component.d.ts +38 -0
- package/inline-notification/si-inline-notification.component.d.ts +0 -2
- package/ip-input/address-utils.d.ts +28 -0
- package/ip-input/address-validators.d.ts +21 -0
- package/ip-input/index.d.ts +7 -0
- package/ip-input/package.json +3 -0
- package/ip-input/si-ip-input.directive.d.ts +53 -0
- package/ip-input/si-ip4-input.directive.d.ts +9 -0
- package/ip-input/si-ip6-input.directive.d.ts +10 -0
- package/list-details/index.d.ts +12 -0
- package/list-details/package.json +3 -0
- package/list-details/si-details-pane/si-details-pane.component.d.ts +8 -0
- package/list-details/si-details-pane-body/si-details-pane-body.component.d.ts +6 -0
- package/list-details/si-details-pane-footer/si-details-pane-footer.component.d.ts +6 -0
- package/list-details/si-details-pane-header/si-details-pane-header.component.d.ts +38 -0
- package/list-details/si-list-details.component.d.ts +100 -0
- package/list-details/si-list-pane/si-list-pane.component.d.ts +10 -0
- package/list-details/si-list-pane-body/si-list-pane-body.component.d.ts +6 -0
- package/list-details/si-list-pane-header/si-list-pane-header.component.d.ts +6 -0
- package/loading-spinner/si-loading-spinner.directive.d.ts +3 -2
- package/localization/index.d.ts +8 -0
- package/localization/package.json +3 -0
- package/localization/si-directionality.d.ts +41 -0
- package/localization/si-locale-id.d.ts +22 -0
- package/localization/si-locale-store.d.ts +16 -0
- package/localization/si-locale.service.d.ts +73 -0
- package/package.json +161 -9
- package/password-strength/si-password-strength.directive.d.ts +11 -0
- package/phone-number/index.d.ts +7 -0
- package/phone-number/package.json +3 -0
- package/phone-number/si-phone-number-input-select.directive.d.ts +10 -0
- package/phone-number/si-phone-number-input.component.d.ts +137 -0
- package/phone-number/si-phone-number-input.models.d.ts +48 -0
- package/phone-number/si-phone-number-input.module.d.ts +7 -0
- package/photo-upload/index.d.ts +6 -0
- package/photo-upload/package.json +3 -0
- package/photo-upload/si-image-cropper-style.component.d.ts +5 -0
- package/photo-upload/si-photo-upload.component.d.ts +298 -0
- package/result-details-list/index.d.ts +7 -0
- package/result-details-list/package.json +3 -0
- package/result-details-list/si-result-details-list.component.d.ts +14 -0
- package/result-details-list/si-result-details-list.datamodel.d.ts +48 -0
- package/result-details-list/si-result-details-list.module.d.ts +7 -0
- package/search-bar/index.d.ts +6 -0
- package/search-bar/package.json +3 -0
- package/search-bar/si-search-bar.component.d.ts +87 -0
- package/search-bar/si-search-bar.module.d.ts +7 -0
- package/shadow-root/index.d.ts +5 -0
- package/shadow-root/package.json +3 -0
- package/shadow-root/si-shadow-root.directive.d.ts +39 -0
- package/side-panel/index.d.ts +9 -0
- package/side-panel/package.json +3 -0
- package/side-panel/si-side-panel-content.component.d.ts +105 -0
- package/side-panel/si-side-panel.component.d.ts +108 -0
- package/side-panel/si-side-panel.module.d.ts +8 -0
- package/side-panel/si-side-panel.service.d.ts +45 -0
- package/side-panel/side-panel.model.d.ts +16 -0
- package/slider/index.d.ts +6 -0
- package/slider/package.json +3 -0
- package/slider/si-slider.component.d.ts +129 -0
- package/slider/si-slider.module.d.ts +7 -0
- package/sort-bar/index.d.ts +6 -0
- package/sort-bar/package.json +3 -0
- package/sort-bar/si-sort-bar.component.d.ts +42 -0
- package/sort-bar/si-sort-bar.module.d.ts +7 -0
- package/split/index.d.ts +8 -0
- package/split/package.json +3 -0
- package/split/si-split-part.component.d.ts +154 -0
- package/split/si-split.component.d.ts +48 -0
- package/split/si-split.interfaces.d.ts +17 -0
- package/split/si-split.module.d.ts +8 -0
- package/status-bar/index.d.ts +7 -0
- package/status-bar/package.json +3 -0
- package/status-bar/si-status-bar-item/index.d.ts +6 -0
- package/status-bar/si-status-bar-item/si-status-bar-item.component.d.ts +22 -0
- package/status-bar/si-status-bar-item/si-status-bar-item.model.d.ts +33 -0
- package/status-bar/si-status-bar.component.d.ts +116 -0
- package/status-bar/si-status-bar.module.d.ts +7 -0
- package/status-toggle/index.d.ts +6 -0
- package/status-toggle/package.json +3 -0
- package/status-toggle/si-status-toggle.component.d.ts +54 -0
- package/status-toggle/status-toggle.model.d.ts +26 -0
- package/system-banner/index.d.ts +5 -0
- package/system-banner/package.json +3 -0
- package/system-banner/system-banner.component.d.ts +23 -0
- package/tabs/index.d.ts +7 -0
- package/tabs/package.json +3 -0
- package/tabs/si-tab/index.d.ts +5 -0
- package/tabs/si-tab/si-tab.component.d.ts +58 -0
- package/tabs/si-tabs.module.d.ts +8 -0
- package/tabs/si-tabset/index.d.ts +5 -0
- package/tabs/si-tabset/si-tabset.component.d.ts +100 -0
- package/tabs-next/index.d.ts +7 -0
- package/tabs-next/package.json +3 -0
- package/tabs-next/si-tab-next-base.directive.d.ts +66 -0
- package/tabs-next/si-tab-next-link.component.d.ts +18 -0
- package/tabs-next/si-tab-next.component.d.ts +16 -0
- package/tabs-next/si-tabs-tokens.d.ts +7 -0
- package/tabs-next/si-tabset-next.component.d.ts +72 -0
- package/template-i18n.json +111 -0
- package/translate/si-translatable-keys.interface.d.ts +111 -0
- package/tree-view/drag-drop.util.d.ts +32 -0
- package/tree-view/index.d.ts +12 -0
- package/tree-view/package.json +3 -0
- package/tree-view/si-tree-view-converter.service.d.ts +41 -0
- package/tree-view/si-tree-view-item/si-tree-view-item.component.d.ts +105 -0
- package/tree-view/si-tree-view-item/si-tree-view-item.directive.d.ts +24 -0
- package/tree-view/si-tree-view-item-context.d.ts +11 -0
- package/tree-view/si-tree-view-item-height.service.d.ts +49 -0
- package/tree-view/si-tree-view-item-template.directive.d.ts +18 -0
- package/tree-view/si-tree-view-virtualization.service.d.ts +150 -0
- package/tree-view/si-tree-view.component.d.ts +466 -0
- package/tree-view/si-tree-view.model.d.ts +146 -0
- package/tree-view/si-tree-view.module.d.ts +10 -0
- package/tree-view/si-tree-view.service.d.ts +55 -0
- package/tree-view/si-tree-view.utils.d.ts +46 -0
- package/unauthorized-page/index.d.ts +6 -0
- package/unauthorized-page/package.json +3 -0
- package/unauthorized-page/si-unauthorized-page.component.d.ts +35 -0
- package/unauthorized-page/si-unauthorized-page.module.d.ts +7 -0
|
@@ -0,0 +1,554 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { signal, Injectable, input, booleanAttribute, model, output, computed, viewChild, inject, PLATFORM_ID, ElementRef, ChangeDetectorRef, DestroyRef, Component, NgModule } from '@angular/core';
|
|
3
|
+
import { BehaviorSubject, Subject, EMPTY } from 'rxjs';
|
|
4
|
+
import * as i1 from '@angular/cdk/portal';
|
|
5
|
+
import { CdkPortalOutlet, PortalModule } from '@angular/cdk/portal';
|
|
6
|
+
import { isPlatformBrowser, DOCUMENT } from '@angular/common';
|
|
7
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
8
|
+
import { ResizeObserverService, BOOTSTRAP_BREAKPOINTS } from '@siemens/element-ng/resize-observer';
|
|
9
|
+
import { debounceTime } from 'rxjs/operators';
|
|
10
|
+
import { BreakpointObserver } from '@angular/cdk/layout';
|
|
11
|
+
import { SiAccordionHCollapseService } from '@siemens/element-ng/accordion';
|
|
12
|
+
import { SiContentActionBarComponent } from '@siemens/element-ng/content-action-bar';
|
|
13
|
+
import { addIcons, elementDoubleRight, elementDoubleLeft, SiIconNextComponent } from '@siemens/element-ng/icon';
|
|
14
|
+
import { SiLinkDirective } from '@siemens/element-ng/link';
|
|
15
|
+
import { SiSearchBarComponent } from '@siemens/element-ng/search-bar';
|
|
16
|
+
import * as i1$1 from '@siemens/element-translate-ng/translate';
|
|
17
|
+
import { SiTranslateModule } from '@siemens/element-translate-ng/translate';
|
|
18
|
+
|
|
19
|
+
class SiSidePanelService {
|
|
20
|
+
contentSubject = new BehaviorSubject(undefined);
|
|
21
|
+
/** @internal */
|
|
22
|
+
content$ = this.contentSubject.asObservable();
|
|
23
|
+
openSubject = new BehaviorSubject(false);
|
|
24
|
+
/**
|
|
25
|
+
* Emits on side panel is open or close.
|
|
26
|
+
*
|
|
27
|
+
* @defaultValue this.openSubject.asObservable()
|
|
28
|
+
*/
|
|
29
|
+
isOpen$ = this.openSubject.asObservable();
|
|
30
|
+
tempContentSubject = new BehaviorSubject(undefined);
|
|
31
|
+
/** @internal */
|
|
32
|
+
tempContent$ = this.tempContentSubject.asObservable();
|
|
33
|
+
tempContentClosed;
|
|
34
|
+
/** @internal */
|
|
35
|
+
enableMobile = signal(false);
|
|
36
|
+
/** Set or update displayed content. */
|
|
37
|
+
setSidePanelContent(portal) {
|
|
38
|
+
this.contentSubject.next(portal);
|
|
39
|
+
}
|
|
40
|
+
/** Open side panel. */
|
|
41
|
+
open() {
|
|
42
|
+
this.hideTemporaryContent();
|
|
43
|
+
this.openSubject.next(true);
|
|
44
|
+
}
|
|
45
|
+
/** Close side panel. */
|
|
46
|
+
close() {
|
|
47
|
+
if (this.hideTemporaryContent()) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
this.openSubject.next(false);
|
|
51
|
+
}
|
|
52
|
+
/** Toggle side panel open/close. */
|
|
53
|
+
toggle() {
|
|
54
|
+
this.hideTemporaryContent();
|
|
55
|
+
this.openSubject.next(!this.openSubject.value);
|
|
56
|
+
}
|
|
57
|
+
/** Indicate is side panel open. */
|
|
58
|
+
isOpen() {
|
|
59
|
+
return this.openSubject.value;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Indicate that the side panel is open with temporary content.
|
|
63
|
+
*/
|
|
64
|
+
isTemporaryOpen() {
|
|
65
|
+
return !!this.tempContentSubject.value;
|
|
66
|
+
}
|
|
67
|
+
/** Show side panel temporary content, opening the side panel when necessary. */
|
|
68
|
+
showTemporaryContent(portal) {
|
|
69
|
+
this.hideTemporaryContent();
|
|
70
|
+
this.tempContentSubject.next(portal);
|
|
71
|
+
if (portal) {
|
|
72
|
+
this.tempContentClosed = new Subject();
|
|
73
|
+
return this.tempContentClosed.asObservable();
|
|
74
|
+
}
|
|
75
|
+
return EMPTY;
|
|
76
|
+
}
|
|
77
|
+
/** Hide side panel temporary content, reverting to state before showing temporary content. */
|
|
78
|
+
hideTemporaryContent() {
|
|
79
|
+
if (!this.isTemporaryOpen()) {
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
if (this.tempContentClosed) {
|
|
83
|
+
const sub = this.tempContentClosed;
|
|
84
|
+
this.tempContentClosed = undefined;
|
|
85
|
+
sub.next();
|
|
86
|
+
sub.complete();
|
|
87
|
+
}
|
|
88
|
+
this.tempContentSubject.next(undefined);
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
92
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelService, providedIn: 'root' });
|
|
93
|
+
}
|
|
94
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelService, decorators: [{
|
|
95
|
+
type: Injectable,
|
|
96
|
+
args: [{
|
|
97
|
+
providedIn: 'root'
|
|
98
|
+
}]
|
|
99
|
+
}] });
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* Copyright Siemens 2016 - 2025.
|
|
103
|
+
* SPDX-License-Identifier: MIT
|
|
104
|
+
*/
|
|
105
|
+
class SiSidePanelComponent {
|
|
106
|
+
/**
|
|
107
|
+
* @defaultValue false
|
|
108
|
+
*/
|
|
109
|
+
collapsible = input(false, { transform: booleanAttribute });
|
|
110
|
+
/**
|
|
111
|
+
* Default state of navigation
|
|
112
|
+
*/
|
|
113
|
+
collapsed = model();
|
|
114
|
+
/**
|
|
115
|
+
* Mode of side panel
|
|
116
|
+
* (ignored below a certain width)
|
|
117
|
+
*
|
|
118
|
+
* @defaultValue 'over'
|
|
119
|
+
*/
|
|
120
|
+
mode = input('over');
|
|
121
|
+
/**
|
|
122
|
+
* Size of side-panel
|
|
123
|
+
*
|
|
124
|
+
* @defaultValue 'regular'
|
|
125
|
+
*/
|
|
126
|
+
size = input('regular');
|
|
127
|
+
/**
|
|
128
|
+
* Toggle icon aria-label, required for a11y
|
|
129
|
+
*
|
|
130
|
+
* @defaultValue
|
|
131
|
+
* ```
|
|
132
|
+
* $localize`:@@SI_SIDE_PANEL.TOGGLE:Toggle`
|
|
133
|
+
* ```
|
|
134
|
+
*/
|
|
135
|
+
toggleItemLabel = input($localize `:@@SI_SIDE_PANEL.TOGGLE:Toggle`);
|
|
136
|
+
/**
|
|
137
|
+
* Specifies custom breakpoints to automatically switch mode.
|
|
138
|
+
* The `smMinimum` specifies the breakpoint for the mobile view.
|
|
139
|
+
* The `lgMinimum` specifies the breakpoint to allow scroll mode
|
|
140
|
+
* (below automatically uses over mode).
|
|
141
|
+
* The `xlMinimum` specifies the breakpoint to allow scroll mode
|
|
142
|
+
* with wide size (below automatically uses over mode).
|
|
143
|
+
*/
|
|
144
|
+
breakpoints = input();
|
|
145
|
+
/**
|
|
146
|
+
* Enable mobile drawer for small screen sizes. Should not be used in conjunction with the vertical navbar.
|
|
147
|
+
*
|
|
148
|
+
* @defaultValue false
|
|
149
|
+
*/
|
|
150
|
+
enableMobile = input(false, { transform: booleanAttribute });
|
|
151
|
+
/**
|
|
152
|
+
* Emits when the panel is closed
|
|
153
|
+
*/
|
|
154
|
+
closed = output();
|
|
155
|
+
/**
|
|
156
|
+
* Emits whenever the content is resized due to opening and closing or parent resize.
|
|
157
|
+
*/
|
|
158
|
+
contentResize = output();
|
|
159
|
+
isScrollMode = computed(() => this.mode() === 'scroll');
|
|
160
|
+
isXs = signal(false);
|
|
161
|
+
isSm = signal(false);
|
|
162
|
+
isMd = signal(true);
|
|
163
|
+
isLg = signal(false);
|
|
164
|
+
isXl = signal(false);
|
|
165
|
+
isCollapsed = signal(false);
|
|
166
|
+
ready = signal(false);
|
|
167
|
+
isHidden = signal(false);
|
|
168
|
+
showTempContent = signal(false);
|
|
169
|
+
panelElement = viewChild.required('sidePanel');
|
|
170
|
+
contentElement = viewChild.required('content');
|
|
171
|
+
portalOutlet = viewChild.required('portalOutlet', {
|
|
172
|
+
read: CdkPortalOutlet
|
|
173
|
+
});
|
|
174
|
+
tmpPortalOutlet = viewChild.required('tmpPortalOutlet', {
|
|
175
|
+
read: CdkPortalOutlet
|
|
176
|
+
});
|
|
177
|
+
/**
|
|
178
|
+
* The $rpanel-transition-duration in the style is 0.5 seconds.
|
|
179
|
+
* Sending the resize event after resize need to wait until resize is done.
|
|
180
|
+
*/
|
|
181
|
+
resizeEventDelay = 500;
|
|
182
|
+
resizeEvent = new Subject();
|
|
183
|
+
openingOrClosing = false;
|
|
184
|
+
previousContentDimensions = { width: 0, height: 0 };
|
|
185
|
+
isCollapsedInternal = false; // same as the other one, except w/o timeout for animation
|
|
186
|
+
isBrowser = isPlatformBrowser(inject(PLATFORM_ID));
|
|
187
|
+
element = inject(ElementRef);
|
|
188
|
+
resizeObserver = inject(ResizeObserverService);
|
|
189
|
+
service = inject(SiSidePanelService);
|
|
190
|
+
cdRef = inject(ChangeDetectorRef);
|
|
191
|
+
destroyRef = inject(DestroyRef);
|
|
192
|
+
document = inject(DOCUMENT);
|
|
193
|
+
constructor() {
|
|
194
|
+
if (this.isBrowser) {
|
|
195
|
+
this.resizeEvent
|
|
196
|
+
.asObservable()
|
|
197
|
+
.pipe(takeUntilDestroyed(this.destroyRef), debounceTime(this.resizeEventDelay))
|
|
198
|
+
.subscribe(() => {
|
|
199
|
+
this.openingOrClosing = false;
|
|
200
|
+
this.emitResizeOutputs();
|
|
201
|
+
if (this.isCollapsedInternal && !this.collapsible()) {
|
|
202
|
+
this.isHidden.set(true);
|
|
203
|
+
}
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
ngOnChanges(changes) {
|
|
208
|
+
if (changes.collapsed) {
|
|
209
|
+
if (this.collapsed()) {
|
|
210
|
+
this.service.close();
|
|
211
|
+
}
|
|
212
|
+
else {
|
|
213
|
+
this.service.open();
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
else if (changes.enableMobile) {
|
|
217
|
+
this.service.enableMobile.set(this.enableMobile());
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
ngOnInit() {
|
|
221
|
+
// handle initial state to avoid flicker
|
|
222
|
+
const collapsed = this.collapsed() ?? !this.service.isOpen();
|
|
223
|
+
this.isCollapsedInternal = collapsed;
|
|
224
|
+
this.isHidden.set(collapsed);
|
|
225
|
+
this.isCollapsed.set(collapsed);
|
|
226
|
+
this.resizeObserver
|
|
227
|
+
.observe(this.element.nativeElement, 100, true)
|
|
228
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
229
|
+
.subscribe(dim => {
|
|
230
|
+
this.setBreakpoints(dim.width, dim.height);
|
|
231
|
+
if (!this.ready()) {
|
|
232
|
+
// delay because the initial sizing needs to settle
|
|
233
|
+
setTimeout(() => {
|
|
234
|
+
this.ready.set(true);
|
|
235
|
+
}, 100);
|
|
236
|
+
}
|
|
237
|
+
if (!this.openingOrClosing) {
|
|
238
|
+
this.emitResizeOutputs();
|
|
239
|
+
}
|
|
240
|
+
});
|
|
241
|
+
this.service.content$
|
|
242
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
243
|
+
.subscribe(portal => this.attachContent(portal));
|
|
244
|
+
this.service.tempContent$
|
|
245
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
246
|
+
.subscribe(portal => this.attachTempContent(portal));
|
|
247
|
+
this.service.isOpen$
|
|
248
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
249
|
+
.subscribe(state => this.openClose(state));
|
|
250
|
+
}
|
|
251
|
+
ngOnDestroy() {
|
|
252
|
+
this.portalOutlet().detach();
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* Toggle whether the side panel is expanded or not.
|
|
256
|
+
*/
|
|
257
|
+
toggleSidePanel() {
|
|
258
|
+
if (this.collapsible()) {
|
|
259
|
+
this.service.toggle();
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
this.service.close();
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
emitResizeOutputs() {
|
|
266
|
+
const contentDimensions = this.getContentDimensions();
|
|
267
|
+
if (contentDimensions.width !== this.previousContentDimensions.width ||
|
|
268
|
+
contentDimensions.height !== this.previousContentDimensions.height) {
|
|
269
|
+
this.previousContentDimensions = contentDimensions;
|
|
270
|
+
this.contentResize.emit(contentDimensions);
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
getContentDimensions() {
|
|
274
|
+
if (!this.isCollapsedInternal && this.isXs()) {
|
|
275
|
+
return { width: 0, height: 0 };
|
|
276
|
+
}
|
|
277
|
+
const rect = this.contentElement().nativeElement.getBoundingClientRect();
|
|
278
|
+
return { width: rect.width, height: rect.height };
|
|
279
|
+
}
|
|
280
|
+
setBreakpoints(width, height) {
|
|
281
|
+
if (!width && !height) {
|
|
282
|
+
// element is not visible, no point in changing anything
|
|
283
|
+
return;
|
|
284
|
+
}
|
|
285
|
+
const breakpoints = this.breakpoints() ?? BOOTSTRAP_BREAKPOINTS;
|
|
286
|
+
this.isXs.set(width < breakpoints.smMinimum);
|
|
287
|
+
this.isSm.set(width >= breakpoints.smMinimum && width < breakpoints.mdMinimum);
|
|
288
|
+
this.isMd.set(width >= breakpoints.mdMinimum && width < breakpoints.lgMinimum);
|
|
289
|
+
this.isLg.set(width >= breakpoints.lgMinimum && width < breakpoints.xlMinimum);
|
|
290
|
+
this.isXl.set(width >= breakpoints.xlMinimum);
|
|
291
|
+
}
|
|
292
|
+
sendResize() {
|
|
293
|
+
if (this.isScrollMode() || this.element.nativeElement.style.paddingRight !== '0') {
|
|
294
|
+
this.openingOrClosing = true;
|
|
295
|
+
this.resizeEvent.next();
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
attachContent(portal) {
|
|
299
|
+
const portalOutlet = this.portalOutlet();
|
|
300
|
+
portalOutlet.detach();
|
|
301
|
+
if (portal) {
|
|
302
|
+
portalOutlet.attach(portal);
|
|
303
|
+
}
|
|
304
|
+
this.cdRef.markForCheck();
|
|
305
|
+
}
|
|
306
|
+
attachTempContent(portal) {
|
|
307
|
+
const tmpPortalOutlet = this.tmpPortalOutlet();
|
|
308
|
+
tmpPortalOutlet.detach();
|
|
309
|
+
if (portal) {
|
|
310
|
+
tmpPortalOutlet.attach(portal);
|
|
311
|
+
this.showTempContent.set(true);
|
|
312
|
+
this.openClose(true, true);
|
|
313
|
+
}
|
|
314
|
+
else if (this.showTempContent) {
|
|
315
|
+
this.showTempContent.set(false);
|
|
316
|
+
this.openClose(this.service.isOpen(), true);
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
openClose(open, regainFocus = false) {
|
|
320
|
+
if (open !== this.isCollapsedInternal) {
|
|
321
|
+
this.moveFocusInside(open && regainFocus);
|
|
322
|
+
return;
|
|
323
|
+
}
|
|
324
|
+
this.isCollapsedInternal = !open;
|
|
325
|
+
if (open) {
|
|
326
|
+
this.isHidden.set(false);
|
|
327
|
+
}
|
|
328
|
+
setTimeout(() => this.doOpenClose(open));
|
|
329
|
+
}
|
|
330
|
+
doOpenClose(open) {
|
|
331
|
+
this.moveFocusInside(open);
|
|
332
|
+
this.isCollapsed.set(!open);
|
|
333
|
+
this.collapsed.set(this.isCollapsed());
|
|
334
|
+
if (this.isCollapsedInternal) {
|
|
335
|
+
this.closed.emit();
|
|
336
|
+
}
|
|
337
|
+
this.sendResize();
|
|
338
|
+
}
|
|
339
|
+
moveFocusInside(open) {
|
|
340
|
+
if (open &&
|
|
341
|
+
!this.document.activeElement?.parentElement?.classList.contains('side-panel-collapse-toggle') &&
|
|
342
|
+
!this.document.activeElement?.classList.contains('side-panel-collapse-toggle')) {
|
|
343
|
+
// moves the keyboard focus inside the panel so that the next tab is somewhere useful
|
|
344
|
+
this.panelElement().nativeElement.focus();
|
|
345
|
+
queueMicrotask(() => this.panelElement().nativeElement.blur());
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
349
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "19.0.6", type: SiSidePanelComponent, isStandalone: true, selector: "si-side-panel", inputs: { collapsible: { classPropertyName: "collapsible", publicName: "collapsible", isSignal: true, isRequired: false, transformFunction: null }, collapsed: { classPropertyName: "collapsed", publicName: "collapsed", isSignal: true, isRequired: false, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, toggleItemLabel: { classPropertyName: "toggleItemLabel", publicName: "toggleItemLabel", isSignal: true, isRequired: false, transformFunction: null }, breakpoints: { classPropertyName: "breakpoints", publicName: "breakpoints", isSignal: true, isRequired: false, transformFunction: null }, enableMobile: { classPropertyName: "enableMobile", publicName: "enableMobile", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { collapsed: "collapsedChange", closed: "closed", contentResize: "contentResize" }, host: { properties: { "class.enable-mobile": "enableMobile()", "class.rpanel-size--regular": "this.size() === \"regular\"", "class.rpanel-size--wide": "this.size() === \"wide\"", "class.rpanel-mode--over": "this.mode() === \"over\"", "class.rpanel-mode--scroll": "isScrollMode()", "class.rpanel-collapsed": "isCollapsed()", "class.ready": "ready()", "class.collapsible": "collapsible() && !this.showTempContent()", "class.collapsible-temp": "collapsible() && this.showTempContent()", "class.rpanel-hidden": "isHidden()", "class.rpanel-resize-xs": "isXs()", "class.rpanel-resize-sm": "isSm()", "class.rpanel-resize-md": "isMd()", "class.rpanel-resize-lg": "isLg()", "class.rpanel-resize-xl": "isXl()" }, classAttribute: "si-layout-inner" }, viewQueries: [{ propertyName: "panelElement", first: true, predicate: ["sidePanel"], descendants: true, isSignal: true }, { propertyName: "contentElement", first: true, predicate: ["content"], descendants: true, isSignal: true }, { propertyName: "portalOutlet", first: true, predicate: ["portalOutlet"], descendants: true, read: CdkPortalOutlet, isSignal: true }, { propertyName: "tmpPortalOutlet", first: true, predicate: ["tmpPortalOutlet"], descendants: true, read: CdkPortalOutlet, isSignal: true }], usesOnChanges: true, ngImport: i0, template: "<div #sidePanel class=\"side-panel focus-none\" tabindex=\"-1\">\n <div class=\"inner\" [class.d-none]=\"showTempContent()\">\n <ng-content select=\"si-side-panel-content, element-side-panel-content\" />\n <ng-container #portalOutlet cdkPortalOutlet />\n </div>\n <div class=\"inner\" [class.d-none]=\"!showTempContent()\">\n <ng-container #tmpPortalOutlet cdkPortalOutlet />\n </div>\n</div>\n<div #content class=\"main-content si-layout-inner\">\n <ng-content />\n</div>\n", styles: [":host{--rpanel-collapsed-padding: 0;--rpanel-size: 390px;display:block;padding-inline-end:var(--rpanel-size)}:host.ready{transition:padding-inline-end calc(.5s * var(--element-animations-enabled, 1))}:host.ready .side-panel{transition:inline-size calc(.5s * var(--element-animations-enabled, 1))}:host .side-panel,:host .side-panel>.inner{inline-size:var(--rpanel-size)}:host.collapsible,:host.collapsible-temp{--rpanel-collapsed-width: 48px}:host.rpanel-size--wide{--rpanel-size: 500px}:host.rpanel-resize-sm.rpanel-mode--over,:host.rpanel-resize-md.rpanel-mode--over,:host.rpanel-resize-lg.rpanel-mode--over,:host.rpanel-resize-xl.rpanel-mode--over{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-resize-sm.rpanel-mode--over:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-md.rpanel-mode--over:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-lg.rpanel-mode--over:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-xl.rpanel-mode--over:not(.rpanel-collapsed) .side-panel{box-shadow:0 0 8px var(--element-box-shadow-color-1),0 8px 8px var(--element-box-shadow-color-2)}:host.rpanel-resize-lg.rpanel-mode--scroll.rpanel-size--wide{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-resize-sm.rpanel-mode--scroll,:host.rpanel-resize-md.rpanel-mode--scroll{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-resize-sm.rpanel-mode--scroll:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-md.rpanel-mode--scroll:not(.rpanel-collapsed) .side-panel{box-shadow:0 0 8px var(--element-box-shadow-color-1),0 8px 8px var(--element-box-shadow-color-2)}:host.rpanel-resize-xs.rpanel-mode--over,:host.rpanel-resize-xs.rpanel-mode--scroll{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-resize-xs .side-panel{z-index:1031}:host.rpanel-resize-xs:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-xs:not(.rpanel-collapsed) .side-panel>.inner{inline-size:100%}:host.rpanel-hidden:not(.collapsible) .side-panel{display:none}:host.rpanel-collapsed{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-collapsed:not(.collapsible) .side-panel{inline-size:0;overflow:hidden}:host.rpanel-collapsed.collapsible .side-panel{inline-size:var(--rpanel-collapsed-width);overflow:hidden}.side-panel{position:fixed;z-index:1029;inset-block-start:calc(48px + var(--element-titlebar-spacing, 0px) + var(--element-system-banner-spacing, 0px));inset-block-end:0;inset-inline-end:0;overflow-x:hidden;background:var(--element-base-1)}.side-panel>.inner{display:flex;flex-direction:column;position:absolute;inset-block:0;inset-inline-start:0}@media (max-width: 575.98px){:host.enable-mobile{padding-inline-end:0!important;--si-layout-header-first-element-offset-end: 40px}:host.enable-mobile.rpanel-collapsed .side-panel{inline-size:0!important}}\n"], dependencies: [{ kind: "ngmodule", type: PortalModule }, { kind: "directive", type: i1.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }] });
|
|
350
|
+
}
|
|
351
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelComponent, decorators: [{
|
|
352
|
+
type: Component,
|
|
353
|
+
args: [{ selector: 'si-side-panel', host: {
|
|
354
|
+
class: 'si-layout-inner',
|
|
355
|
+
'[class.enable-mobile]': 'enableMobile()',
|
|
356
|
+
'[class.rpanel-size--regular]': 'this.size() === "regular"',
|
|
357
|
+
'[class.rpanel-size--wide]': 'this.size() === "wide"',
|
|
358
|
+
'[class.rpanel-mode--over]': 'this.mode() === "over"',
|
|
359
|
+
'[class.rpanel-mode--scroll]': 'isScrollMode()',
|
|
360
|
+
'[class.rpanel-collapsed]': 'isCollapsed()',
|
|
361
|
+
'[class.ready]': 'ready()',
|
|
362
|
+
'[class.collapsible]': 'collapsible() && !this.showTempContent()',
|
|
363
|
+
'[class.collapsible-temp]': 'collapsible() && this.showTempContent()',
|
|
364
|
+
'[class.rpanel-hidden]': 'isHidden()',
|
|
365
|
+
'[class.rpanel-resize-xs]': 'isXs()',
|
|
366
|
+
'[class.rpanel-resize-sm]': 'isSm()',
|
|
367
|
+
'[class.rpanel-resize-md]': 'isMd()',
|
|
368
|
+
'[class.rpanel-resize-lg]': 'isLg()',
|
|
369
|
+
'[class.rpanel-resize-xl]': 'isXl()'
|
|
370
|
+
}, imports: [PortalModule], template: "<div #sidePanel class=\"side-panel focus-none\" tabindex=\"-1\">\n <div class=\"inner\" [class.d-none]=\"showTempContent()\">\n <ng-content select=\"si-side-panel-content, element-side-panel-content\" />\n <ng-container #portalOutlet cdkPortalOutlet />\n </div>\n <div class=\"inner\" [class.d-none]=\"!showTempContent()\">\n <ng-container #tmpPortalOutlet cdkPortalOutlet />\n </div>\n</div>\n<div #content class=\"main-content si-layout-inner\">\n <ng-content />\n</div>\n", styles: [":host{--rpanel-collapsed-padding: 0;--rpanel-size: 390px;display:block;padding-inline-end:var(--rpanel-size)}:host.ready{transition:padding-inline-end calc(.5s * var(--element-animations-enabled, 1))}:host.ready .side-panel{transition:inline-size calc(.5s * var(--element-animations-enabled, 1))}:host .side-panel,:host .side-panel>.inner{inline-size:var(--rpanel-size)}:host.collapsible,:host.collapsible-temp{--rpanel-collapsed-width: 48px}:host.rpanel-size--wide{--rpanel-size: 500px}:host.rpanel-resize-sm.rpanel-mode--over,:host.rpanel-resize-md.rpanel-mode--over,:host.rpanel-resize-lg.rpanel-mode--over,:host.rpanel-resize-xl.rpanel-mode--over{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-resize-sm.rpanel-mode--over:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-md.rpanel-mode--over:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-lg.rpanel-mode--over:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-xl.rpanel-mode--over:not(.rpanel-collapsed) .side-panel{box-shadow:0 0 8px var(--element-box-shadow-color-1),0 8px 8px var(--element-box-shadow-color-2)}:host.rpanel-resize-lg.rpanel-mode--scroll.rpanel-size--wide{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-resize-sm.rpanel-mode--scroll,:host.rpanel-resize-md.rpanel-mode--scroll{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-resize-sm.rpanel-mode--scroll:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-md.rpanel-mode--scroll:not(.rpanel-collapsed) .side-panel{box-shadow:0 0 8px var(--element-box-shadow-color-1),0 8px 8px var(--element-box-shadow-color-2)}:host.rpanel-resize-xs.rpanel-mode--over,:host.rpanel-resize-xs.rpanel-mode--scroll{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-resize-xs .side-panel{z-index:1031}:host.rpanel-resize-xs:not(.rpanel-collapsed) .side-panel,:host.rpanel-resize-xs:not(.rpanel-collapsed) .side-panel>.inner{inline-size:100%}:host.rpanel-hidden:not(.collapsible) .side-panel{display:none}:host.rpanel-collapsed{padding-inline-end:var(--rpanel-collapsed-width)}:host.rpanel-collapsed:not(.collapsible) .side-panel{inline-size:0;overflow:hidden}:host.rpanel-collapsed.collapsible .side-panel{inline-size:var(--rpanel-collapsed-width);overflow:hidden}.side-panel{position:fixed;z-index:1029;inset-block-start:calc(48px + var(--element-titlebar-spacing, 0px) + var(--element-system-banner-spacing, 0px));inset-block-end:0;inset-inline-end:0;overflow-x:hidden;background:var(--element-base-1)}.side-panel>.inner{display:flex;flex-direction:column;position:absolute;inset-block:0;inset-inline-start:0}@media (max-width: 575.98px){:host.enable-mobile{padding-inline-end:0!important;--si-layout-header-first-element-offset-end: 40px}:host.enable-mobile.rpanel-collapsed .side-panel{inline-size:0!important}}\n"] }]
|
|
371
|
+
}], ctorParameters: () => [] });
|
|
372
|
+
|
|
373
|
+
/**
|
|
374
|
+
* Copyright Siemens 2016 - 2025.
|
|
375
|
+
* SPDX-License-Identifier: MIT
|
|
376
|
+
*/
|
|
377
|
+
class SiSidePanelContentComponent {
|
|
378
|
+
/**
|
|
379
|
+
* @defaultValue false
|
|
380
|
+
*/
|
|
381
|
+
collapsible = input(false, { transform: booleanAttribute });
|
|
382
|
+
/**
|
|
383
|
+
* Header of side panel
|
|
384
|
+
*
|
|
385
|
+
* @defaultValue ''
|
|
386
|
+
*/
|
|
387
|
+
heading = input('');
|
|
388
|
+
/**
|
|
389
|
+
* Input list of primary action items
|
|
390
|
+
*
|
|
391
|
+
* @defaultValue []
|
|
392
|
+
*/
|
|
393
|
+
primaryActions = input([]);
|
|
394
|
+
/**
|
|
395
|
+
* Input list of secondary action items.
|
|
396
|
+
*
|
|
397
|
+
* @defaultValue []
|
|
398
|
+
*/
|
|
399
|
+
secondaryActions = input([]);
|
|
400
|
+
/**
|
|
401
|
+
* Status icons/actions
|
|
402
|
+
*
|
|
403
|
+
* @defaultValue []
|
|
404
|
+
*/
|
|
405
|
+
statusActions = input([]);
|
|
406
|
+
/**
|
|
407
|
+
* Toggles search bar
|
|
408
|
+
*
|
|
409
|
+
* @defaultValue false
|
|
410
|
+
*/
|
|
411
|
+
searchable = input(false, { transform: booleanAttribute });
|
|
412
|
+
/**
|
|
413
|
+
* Placeholder text for search
|
|
414
|
+
*
|
|
415
|
+
* @defaultValue
|
|
416
|
+
* ```
|
|
417
|
+
* $localize`:@@SI_SIDE_PANEL.SEARCH_PLACEHOLDER:Search...`
|
|
418
|
+
* ```
|
|
419
|
+
*/
|
|
420
|
+
searchPlaceholder = input($localize `:@@SI_SIDE_PANEL.SEARCH_PLACEHOLDER:Search...`);
|
|
421
|
+
/**
|
|
422
|
+
* Aria label for close button. Needed for a11y
|
|
423
|
+
*
|
|
424
|
+
* @defaultValue
|
|
425
|
+
* ```
|
|
426
|
+
* $localize`:@@SI_SIDE_PANEL.CLOSE:Close`
|
|
427
|
+
* ```
|
|
428
|
+
*/
|
|
429
|
+
closeButtonLabel = input($localize `:@@SI_SIDE_PANEL.CLOSE:Close`);
|
|
430
|
+
/**
|
|
431
|
+
* Toggle icon aria-label, required for a11y
|
|
432
|
+
*
|
|
433
|
+
* @defaultValue
|
|
434
|
+
* ```
|
|
435
|
+
* $localize`:@@SI_SIDE_PANEL.TOGGLE:Toggle`
|
|
436
|
+
* ```
|
|
437
|
+
*/
|
|
438
|
+
toggleItemLabel = input($localize `:@@SI_SIDE_PANEL.TOGGLE:Toggle`);
|
|
439
|
+
/**
|
|
440
|
+
* Show a badge on the mobile drawer indicating a new alert or notification
|
|
441
|
+
*
|
|
442
|
+
* @defaultValue false
|
|
443
|
+
*/
|
|
444
|
+
showMobileDrawerBadge = input(false, { transform: booleanAttribute });
|
|
445
|
+
/**
|
|
446
|
+
* Output for search bar input
|
|
447
|
+
*/
|
|
448
|
+
searchEvent = output();
|
|
449
|
+
isCollapsed = signal(false);
|
|
450
|
+
isExpanded = signal(true);
|
|
451
|
+
enableMobile = computed(() => this.service?.enableMobile() ?? false);
|
|
452
|
+
mobileSize = signal(false);
|
|
453
|
+
focusable = computed(() => !this.mobileSize() || !this.enableMobile() || !this.isCollapsed());
|
|
454
|
+
icons = addIcons({ elementDoubleLeft, elementDoubleRight });
|
|
455
|
+
/**
|
|
456
|
+
* The $rpanel-transition-duration in the style is 0.5 seconds.
|
|
457
|
+
* For the animation we need to wait until the resize is done.
|
|
458
|
+
*/
|
|
459
|
+
resizeAnimationDelay = 500;
|
|
460
|
+
destroyRef = inject(DestroyRef);
|
|
461
|
+
service = inject(SiSidePanelService);
|
|
462
|
+
breakpointObserver = inject(BreakpointObserver);
|
|
463
|
+
expandedTimeout;
|
|
464
|
+
constructor() {
|
|
465
|
+
const accordionHcollapse = inject(SiAccordionHCollapseService);
|
|
466
|
+
this.service.isOpen$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(state => {
|
|
467
|
+
this.isCollapsed.set(!state);
|
|
468
|
+
clearTimeout(this.expandedTimeout);
|
|
469
|
+
this.expandedTimeout = undefined;
|
|
470
|
+
if (!state) {
|
|
471
|
+
this.isExpanded.set(false);
|
|
472
|
+
}
|
|
473
|
+
else {
|
|
474
|
+
this.expandedTimeout = setTimeout(() => {
|
|
475
|
+
this.isExpanded.set(true);
|
|
476
|
+
}, this.resizeAnimationDelay / 2);
|
|
477
|
+
}
|
|
478
|
+
accordionHcollapse.hcollapsed.set(!state);
|
|
479
|
+
});
|
|
480
|
+
accordionHcollapse.open$
|
|
481
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
482
|
+
.subscribe(() => this.service.open());
|
|
483
|
+
}
|
|
484
|
+
ngOnInit() {
|
|
485
|
+
this.breakpointObserver
|
|
486
|
+
.observe('(max-width: ' + BOOTSTRAP_BREAKPOINTS.smMinimum + 'px)')
|
|
487
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
488
|
+
.subscribe(({ matches }) => {
|
|
489
|
+
this.mobileSize.set(matches);
|
|
490
|
+
});
|
|
491
|
+
}
|
|
492
|
+
toggleSidePanel(event) {
|
|
493
|
+
if (event?.detail !== 0) {
|
|
494
|
+
// Blur except if triggered by keyboard
|
|
495
|
+
document?.activeElement?.blur();
|
|
496
|
+
}
|
|
497
|
+
if (this.service.isTemporaryOpen()) {
|
|
498
|
+
this.service.hideTemporaryContent();
|
|
499
|
+
}
|
|
500
|
+
else {
|
|
501
|
+
this.service.toggle();
|
|
502
|
+
}
|
|
503
|
+
}
|
|
504
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
505
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.6", type: SiSidePanelContentComponent, isStandalone: true, selector: "si-side-panel-content", inputs: { collapsible: { classPropertyName: "collapsible", publicName: "collapsible", isSignal: true, isRequired: false, transformFunction: null }, heading: { classPropertyName: "heading", publicName: "heading", isSignal: true, isRequired: false, transformFunction: null }, primaryActions: { classPropertyName: "primaryActions", publicName: "primaryActions", isSignal: true, isRequired: false, transformFunction: null }, secondaryActions: { classPropertyName: "secondaryActions", publicName: "secondaryActions", isSignal: true, isRequired: false, transformFunction: null }, statusActions: { classPropertyName: "statusActions", publicName: "statusActions", isSignal: true, isRequired: false, transformFunction: null }, searchable: { classPropertyName: "searchable", publicName: "searchable", isSignal: true, isRequired: false, transformFunction: null }, searchPlaceholder: { classPropertyName: "searchPlaceholder", publicName: "searchPlaceholder", isSignal: true, isRequired: false, transformFunction: null }, closeButtonLabel: { classPropertyName: "closeButtonLabel", publicName: "closeButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, toggleItemLabel: { classPropertyName: "toggleItemLabel", publicName: "toggleItemLabel", isSignal: true, isRequired: false, transformFunction: null }, showMobileDrawerBadge: { classPropertyName: "showMobileDrawerBadge", publicName: "showMobileDrawerBadge", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { searchEvent: "searchEvent" }, host: { properties: { "class.collapsed": "isCollapsed()", "class.expanded": "isExpanded()", "class.enable-mobile": "enableMobile()" } }, providers: [SiAccordionHCollapseService], ngImport: i0, template: "<div class=\"rpanel-header pt-5\">\n <p class=\"si-title-2 my-0 ms-6 auto-hide text-truncate\">{{ heading() | translate }}</p>\n @if ((primaryActions().length || secondaryActions().length) && focusable()) {\n <si-content-action-bar\n class=\"auto-hide ms-auto\"\n viewType=\"expanded\"\n [primaryActions]=\"primaryActions()\"\n [secondaryActions]=\"secondaryActions()\"\n [toggleItemLabel]=\"toggleItemLabel()\"\n />\n }\n <button\n type=\"button\"\n class=\"close-button btn btn-circle btn-sm btn-ghost element-cancel me-4\"\n [attr.aria-label]=\"closeButtonLabel() | translate\"\n [tabindex]=\"focusable() ? '0' : '-1'\"\n (click)=\"toggleSidePanel($event)\"\n ></button>\n <div class=\"collapse-toggle\">\n <button\n type=\"button\"\n class=\"side-panel-collapse-toggle btn btn-circle btn-sm btn-ghost mx-4\"\n [attr.aria-label]=\"toggleItemLabel() | translate\"\n (click)=\"toggleSidePanel($event)\"\n >\n <si-icon-next\n class=\"flip-rtl\"\n [class.badge-dot]=\"showMobileDrawerBadge()\"\n [icon]=\"isCollapsed() ? icons.elementDoubleLeft : icons.elementDoubleRight\"\n />\n </button>\n </div>\n</div>\n<div class=\"rpanel-wrapper d-flex flex-column\">\n @if (statusActions().length && focusable()) {\n <div class=\"rpanel-header rpanel-statusactions px-6\">\n @for (dp of statusActions(); track $index) {\n @if (!dp.disabled) {\n <a\n class=\"rpanel-statusaction position-relative focus-inside\"\n [attr.aria-label]=\"!isCollapsed ? '' : (dp.title | translate)\"\n [siLink]=\"dp\"\n >\n <si-icon-next class=\"icon\" [icon]=\"dp.icon!\" />\n @if (dp.overlayIcon) {\n <si-icon-next class=\"icon position-absolute\" [icon]=\"dp.overlayIcon\" />\n }\n <span class=\"ms-2 auto-hide\">{{ dp.title | translate }}</span>\n </a>\n }\n @if (dp.disabled) {\n <div class=\"rpanel-statusaction dot-outer\" aria-hidden=\"true\">\n <div class=\"dot text-muted text-center\">•</div>\n </div>\n }\n }\n </div>\n }\n @if (searchable() && focusable()) {\n <div class=\"nav-search px-6 auto-hide\">\n <si-search-bar\n #searchBar\n class=\"m-0\"\n colorVariant=\"base-0\"\n prohibitedCharacters=\"*?\"\n [placeholder]=\"searchPlaceholder() | translate\"\n [debounceTime]=\"400\"\n [showIcon]=\"true\"\n (searchChange)=\"searchEvent.emit($event)\"\n />\n </div>\n }\n @if (focusable()) {\n <div class=\"rpanel-content\">\n <ng-content />\n </div>\n }\n</div>\n", styles: [":host{--si-accordion-radius: 0;display:flex;flex-direction:column;flex:1;gap:12px}:host-context(.collapsible) .close-button{display:none}:host-context(.collapsible) .collapse-toggle{display:block}:host-context(.collapsible) .rpanel-wrapper{gap:12px}:host-context(.collapsible) :host.collapsed{gap:0}:host-context(.collapsible) :host.collapsed .auto-hide{display:none}:host-context(.collapsible) :host.collapsed .rpanel-wrapper{gap:0;inline-size:var(--rpanel-collapsed-width)}:host-context(.collapsible) :host.collapsed .rpanel-content{flex:0 0 auto;margin-block-start:8px}:host-context(.collapsible) :host.collapsed .rpanel-statusactions{order:3;flex-direction:column;align-items:flex-start;padding:0!important}:host-context(.collapsible) :host.collapsed .rpanel-statusaction{padding-block:8px;padding-inline:12px}:host-context(.collapsible) :host.collapsed .rpanel-statusaction:not(.dot-outer):hover{background:var(--element-base-1-hover)}.collapse-toggle{display:none}.collapse-toggle i{vertical-align:bottom}.rpanel-header,.rpanel-statusaction{display:flex;align-items:center}.rpanel-header{justify-content:space-between}.rpanel-wrapper,.rpanel-content{min-block-size:0;flex:1 0 0;overflow-x:hidden;overflow-y:auto}.rpanel-statusaction{text-decoration:none}.rpanel-statusaction .dot{inline-size:24px;line-height:24px}.rpanel-statusaction span{font-size:12px;white-space:pre-wrap;color:var(--element-text-primary)}.rpanel-statusaction:hover span{color:var(--element-text-active)}@media (max-width: 575.98px){:host.enable-mobile:not(.collapsed):not(.expanded) si-content-action-bar{margin-inline-end:48px}:host.enable-mobile:not(.expanded) .collapse-toggle{position:fixed;border:0;text-align:end;padding-block:4px!important;margin-block-start:8px!important;inset-inline-end:0;inset-block-start:calc(48px + var(--element-titlebar-spacing, 0px) + var(--element-system-banner-spacing, 0px));border-start-start-radius:var(--element-radius-2);border-end-start-radius:var(--element-radius-2);border-start-end-radius:0!important;border-end-end-radius:0!important;background:var(--element-base-1);box-shadow:0 0 4px var(--element-box-shadow-color-1),0 4px 4px var(--element-box-shadow-color-2);z-index:2}}\n"], dependencies: [{ kind: "component", type: SiContentActionBarComponent, selector: "si-content-action-bar", inputs: ["primaryActions", "secondaryActions", "actionParam", "viewType", "toggleItemLabel", "preventIconsInDropdownMenus", "disabled"] }, { kind: "component", type: SiIconNextComponent, selector: "si-icon-next", inputs: ["icon"] }, { kind: "directive", type: SiLinkDirective, selector: "[siLink]", inputs: ["siLink", "siLinkDefaultTarget", "actionParam", "activeClass", "exactMatch", "ariaCurrent"], outputs: ["activeChange"], exportAs: ["siLink"] }, { kind: "component", type: SiSearchBarComponent, selector: "si-search-bar", inputs: ["debounceTime", "prohibitedCharacters", "placeholder", "showIcon", "tabbable", "value", "readonly", "colorVariant", "disabled"], outputs: ["searchChange"] }, { kind: "ngmodule", type: SiTranslateModule }, { kind: "pipe", type: i1$1.SiTranslatePipe, name: "translate" }] });
|
|
506
|
+
}
|
|
507
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelContentComponent, decorators: [{
|
|
508
|
+
type: Component,
|
|
509
|
+
args: [{ selector: 'si-side-panel-content', providers: [SiAccordionHCollapseService], imports: [
|
|
510
|
+
SiContentActionBarComponent,
|
|
511
|
+
SiIconNextComponent,
|
|
512
|
+
SiLinkDirective,
|
|
513
|
+
SiSearchBarComponent,
|
|
514
|
+
SiTranslateModule
|
|
515
|
+
], host: {
|
|
516
|
+
'[class.collapsed]': 'isCollapsed()',
|
|
517
|
+
'[class.expanded]': 'isExpanded()',
|
|
518
|
+
'[class.enable-mobile]': 'enableMobile()'
|
|
519
|
+
}, template: "<div class=\"rpanel-header pt-5\">\n <p class=\"si-title-2 my-0 ms-6 auto-hide text-truncate\">{{ heading() | translate }}</p>\n @if ((primaryActions().length || secondaryActions().length) && focusable()) {\n <si-content-action-bar\n class=\"auto-hide ms-auto\"\n viewType=\"expanded\"\n [primaryActions]=\"primaryActions()\"\n [secondaryActions]=\"secondaryActions()\"\n [toggleItemLabel]=\"toggleItemLabel()\"\n />\n }\n <button\n type=\"button\"\n class=\"close-button btn btn-circle btn-sm btn-ghost element-cancel me-4\"\n [attr.aria-label]=\"closeButtonLabel() | translate\"\n [tabindex]=\"focusable() ? '0' : '-1'\"\n (click)=\"toggleSidePanel($event)\"\n ></button>\n <div class=\"collapse-toggle\">\n <button\n type=\"button\"\n class=\"side-panel-collapse-toggle btn btn-circle btn-sm btn-ghost mx-4\"\n [attr.aria-label]=\"toggleItemLabel() | translate\"\n (click)=\"toggleSidePanel($event)\"\n >\n <si-icon-next\n class=\"flip-rtl\"\n [class.badge-dot]=\"showMobileDrawerBadge()\"\n [icon]=\"isCollapsed() ? icons.elementDoubleLeft : icons.elementDoubleRight\"\n />\n </button>\n </div>\n</div>\n<div class=\"rpanel-wrapper d-flex flex-column\">\n @if (statusActions().length && focusable()) {\n <div class=\"rpanel-header rpanel-statusactions px-6\">\n @for (dp of statusActions(); track $index) {\n @if (!dp.disabled) {\n <a\n class=\"rpanel-statusaction position-relative focus-inside\"\n [attr.aria-label]=\"!isCollapsed ? '' : (dp.title | translate)\"\n [siLink]=\"dp\"\n >\n <si-icon-next class=\"icon\" [icon]=\"dp.icon!\" />\n @if (dp.overlayIcon) {\n <si-icon-next class=\"icon position-absolute\" [icon]=\"dp.overlayIcon\" />\n }\n <span class=\"ms-2 auto-hide\">{{ dp.title | translate }}</span>\n </a>\n }\n @if (dp.disabled) {\n <div class=\"rpanel-statusaction dot-outer\" aria-hidden=\"true\">\n <div class=\"dot text-muted text-center\">•</div>\n </div>\n }\n }\n </div>\n }\n @if (searchable() && focusable()) {\n <div class=\"nav-search px-6 auto-hide\">\n <si-search-bar\n #searchBar\n class=\"m-0\"\n colorVariant=\"base-0\"\n prohibitedCharacters=\"*?\"\n [placeholder]=\"searchPlaceholder() | translate\"\n [debounceTime]=\"400\"\n [showIcon]=\"true\"\n (searchChange)=\"searchEvent.emit($event)\"\n />\n </div>\n }\n @if (focusable()) {\n <div class=\"rpanel-content\">\n <ng-content />\n </div>\n }\n</div>\n", styles: [":host{--si-accordion-radius: 0;display:flex;flex-direction:column;flex:1;gap:12px}:host-context(.collapsible) .close-button{display:none}:host-context(.collapsible) .collapse-toggle{display:block}:host-context(.collapsible) .rpanel-wrapper{gap:12px}:host-context(.collapsible) :host.collapsed{gap:0}:host-context(.collapsible) :host.collapsed .auto-hide{display:none}:host-context(.collapsible) :host.collapsed .rpanel-wrapper{gap:0;inline-size:var(--rpanel-collapsed-width)}:host-context(.collapsible) :host.collapsed .rpanel-content{flex:0 0 auto;margin-block-start:8px}:host-context(.collapsible) :host.collapsed .rpanel-statusactions{order:3;flex-direction:column;align-items:flex-start;padding:0!important}:host-context(.collapsible) :host.collapsed .rpanel-statusaction{padding-block:8px;padding-inline:12px}:host-context(.collapsible) :host.collapsed .rpanel-statusaction:not(.dot-outer):hover{background:var(--element-base-1-hover)}.collapse-toggle{display:none}.collapse-toggle i{vertical-align:bottom}.rpanel-header,.rpanel-statusaction{display:flex;align-items:center}.rpanel-header{justify-content:space-between}.rpanel-wrapper,.rpanel-content{min-block-size:0;flex:1 0 0;overflow-x:hidden;overflow-y:auto}.rpanel-statusaction{text-decoration:none}.rpanel-statusaction .dot{inline-size:24px;line-height:24px}.rpanel-statusaction span{font-size:12px;white-space:pre-wrap;color:var(--element-text-primary)}.rpanel-statusaction:hover span{color:var(--element-text-active)}@media (max-width: 575.98px){:host.enable-mobile:not(.collapsed):not(.expanded) si-content-action-bar{margin-inline-end:48px}:host.enable-mobile:not(.expanded) .collapse-toggle{position:fixed;border:0;text-align:end;padding-block:4px!important;margin-block-start:8px!important;inset-inline-end:0;inset-block-start:calc(48px + var(--element-titlebar-spacing, 0px) + var(--element-system-banner-spacing, 0px));border-start-start-radius:var(--element-radius-2);border-end-start-radius:var(--element-radius-2);border-start-end-radius:0!important;border-end-end-radius:0!important;background:var(--element-base-1);box-shadow:0 0 4px var(--element-box-shadow-color-1),0 4px 4px var(--element-box-shadow-color-2);z-index:2}}\n"] }]
|
|
520
|
+
}], ctorParameters: () => [] });
|
|
521
|
+
|
|
522
|
+
/**
|
|
523
|
+
* Copyright Siemens 2016 - 2025.
|
|
524
|
+
* SPDX-License-Identifier: MIT
|
|
525
|
+
*/
|
|
526
|
+
class SiSidePanelModule {
|
|
527
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
528
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelModule, imports: [SiSidePanelComponent, SiSidePanelContentComponent], exports: [SiSidePanelComponent, SiSidePanelContentComponent] });
|
|
529
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelModule, imports: [SiSidePanelComponent, SiSidePanelContentComponent] });
|
|
530
|
+
}
|
|
531
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiSidePanelModule, decorators: [{
|
|
532
|
+
type: NgModule,
|
|
533
|
+
args: [{
|
|
534
|
+
imports: [SiSidePanelComponent, SiSidePanelContentComponent],
|
|
535
|
+
exports: [SiSidePanelComponent, SiSidePanelContentComponent]
|
|
536
|
+
}]
|
|
537
|
+
}] });
|
|
538
|
+
|
|
539
|
+
/**
|
|
540
|
+
* Copyright Siemens 2016 - 2025.
|
|
541
|
+
* SPDX-License-Identifier: MIT
|
|
542
|
+
*/
|
|
543
|
+
|
|
544
|
+
/**
|
|
545
|
+
* Copyright Siemens 2016 - 2025.
|
|
546
|
+
* SPDX-License-Identifier: MIT
|
|
547
|
+
*/
|
|
548
|
+
|
|
549
|
+
/**
|
|
550
|
+
* Generated bundle index. Do not edit.
|
|
551
|
+
*/
|
|
552
|
+
|
|
553
|
+
export { SiSidePanelComponent, SiSidePanelContentComponent, SiSidePanelModule, SiSidePanelService };
|
|
554
|
+
//# sourceMappingURL=siemens-element-ng-side-panel.mjs.map
|