@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.
Files changed (313) hide show
  1. package/badge/si-badge.component.d.ts +1 -1
  2. package/breadcrumb/breadcrumb-item.model.d.ts +36 -0
  3. package/breadcrumb/index.d.ts +7 -0
  4. package/breadcrumb/package.json +3 -0
  5. package/breadcrumb/si-breadcrumb-item-template.directive.d.ts +10 -0
  6. package/breadcrumb/si-breadcrumb.component.d.ts +46 -0
  7. package/breadcrumb/si-breadcrumb.module.d.ts +7 -0
  8. package/card/index.d.ts +6 -0
  9. package/card/package.json +3 -0
  10. package/card/si-card.component.d.ts +79 -0
  11. package/card/si-card.module.d.ts +7 -0
  12. package/circle-status/index.d.ts +6 -0
  13. package/circle-status/package.json +3 -0
  14. package/circle-status/si-circle-status.component.d.ts +66 -0
  15. package/circle-status/si-circle-status.module.d.ts +7 -0
  16. package/column-selection-dialog/column-selection-editor/si-column-selection-editor.component.d.ts +23 -0
  17. package/column-selection-dialog/index.d.ts +6 -0
  18. package/column-selection-dialog/package.json +3 -0
  19. package/column-selection-dialog/si-column-selection-dialog.component.d.ts +114 -0
  20. package/column-selection-dialog/si-column-selection-dialog.service.d.ts +20 -0
  21. package/column-selection-dialog/si-column-selection-dialog.types.d.ts +68 -0
  22. package/common/models/status-type.model.d.ts +4 -2
  23. package/datatable/index.d.ts +42 -0
  24. package/datatable/package.json +3 -0
  25. package/datatable/si-datatable-interaction.directive.d.ts +34 -0
  26. package/datatable/si-datatable.module.d.ts +7 -0
  27. package/date-range-filter/index.d.ts +8 -0
  28. package/date-range-filter/package.json +3 -0
  29. package/date-range-filter/si-date-range-calculation.service.d.ts +33 -0
  30. package/date-range-filter/si-date-range-filter.component.d.ts +248 -0
  31. package/date-range-filter/si-date-range-filter.module.d.ts +7 -0
  32. package/date-range-filter/si-date-range-filter.types.d.ts +40 -0
  33. package/date-range-filter/si-relative-date.component.d.ts +31 -0
  34. package/datepicker/components/si-calendar-body.component.d.ts +137 -0
  35. package/datepicker/components/si-calendar-date-cell.directive.d.ts +16 -0
  36. package/datepicker/components/si-calendar-direction-button.component.d.ts +18 -0
  37. package/datepicker/components/si-compare-adapter.d.ts +37 -0
  38. package/datepicker/components/si-day-selection.component.d.ts +76 -0
  39. package/datepicker/components/si-initial-focus.component.d.ts +74 -0
  40. package/datepicker/components/si-month-selection.component.d.ts +62 -0
  41. package/datepicker/components/si-year-selection.component.d.ts +65 -0
  42. package/datepicker/date-time-helper.d.ts +302 -0
  43. package/datepicker/index.d.ts +15 -0
  44. package/datepicker/package.json +3 -0
  45. package/datepicker/si-calendar-button.component.d.ts +49 -0
  46. package/datepicker/si-date-input.directive.d.ts +114 -0
  47. package/datepicker/si-date-range.component.d.ts +150 -0
  48. package/datepicker/si-datepicker-overlay.component.d.ts +82 -0
  49. package/datepicker/si-datepicker-overlay.directive.d.ts +104 -0
  50. package/datepicker/si-datepicker.component.d.ts +228 -0
  51. package/datepicker/si-datepicker.directive.d.ts +62 -0
  52. package/datepicker/si-datepicker.model.d.ts +129 -0
  53. package/datepicker/si-datepicker.module.d.ts +12 -0
  54. package/datepicker/si-timepicker.component.d.ts +214 -0
  55. package/electron-titlebar/electron.helpers.d.ts +5 -0
  56. package/electron-titlebar/index.d.ts +7 -0
  57. package/electron-titlebar/package.json +3 -0
  58. package/electron-titlebar/si-electron-titlebar.component.d.ts +72 -0
  59. package/electron-titlebar/si-electron-titlebar.module.d.ts +7 -0
  60. package/fesm2022/siemens-element-ng-badge.mjs.map +1 -1
  61. package/fesm2022/siemens-element-ng-breadcrumb.mjs +302 -0
  62. package/fesm2022/siemens-element-ng-breadcrumb.mjs.map +1 -0
  63. package/fesm2022/siemens-element-ng-card.mjs +122 -0
  64. package/fesm2022/siemens-element-ng-card.mjs.map +1 -0
  65. package/fesm2022/siemens-element-ng-circle-status.mjs +146 -0
  66. package/fesm2022/siemens-element-ng-circle-status.mjs.map +1 -0
  67. package/fesm2022/siemens-element-ng-column-selection-dialog.mjs +369 -0
  68. package/fesm2022/siemens-element-ng-column-selection-dialog.mjs.map +1 -0
  69. package/fesm2022/siemens-element-ng-common.mjs.map +1 -1
  70. package/fesm2022/siemens-element-ng-datatable.mjs +173 -0
  71. package/fesm2022/siemens-element-ng-datatable.mjs.map +1 -0
  72. package/fesm2022/siemens-element-ng-date-range-filter.mjs +649 -0
  73. package/fesm2022/siemens-element-ng-date-range-filter.mjs.map +1 -0
  74. package/fesm2022/siemens-element-ng-datepicker.mjs +4231 -0
  75. package/fesm2022/siemens-element-ng-datepicker.mjs.map +1 -0
  76. package/fesm2022/siemens-element-ng-electron-titlebar.mjs +142 -0
  77. package/fesm2022/siemens-element-ng-electron-titlebar.mjs.map +1 -0
  78. package/fesm2022/siemens-element-ng-file-uploader.mjs +751 -0
  79. package/fesm2022/siemens-element-ng-file-uploader.mjs.map +1 -0
  80. package/fesm2022/siemens-element-ng-filter-bar.mjs +153 -0
  81. package/fesm2022/siemens-element-ng-filter-bar.mjs.map +1 -0
  82. package/fesm2022/siemens-element-ng-filtered-search.mjs +1139 -0
  83. package/fesm2022/siemens-element-ng-filtered-search.mjs.map +1 -0
  84. package/fesm2022/siemens-element-ng-formly.mjs +935 -0
  85. package/fesm2022/siemens-element-ng-formly.mjs.map +1 -0
  86. package/fesm2022/siemens-element-ng-icon.mjs +52 -14
  87. package/fesm2022/siemens-element-ng-icon.mjs.map +1 -1
  88. package/fesm2022/siemens-element-ng-info-page.mjs +63 -0
  89. package/fesm2022/siemens-element-ng-info-page.mjs.map +1 -0
  90. package/fesm2022/siemens-element-ng-inline-notification.mjs +4 -6
  91. package/fesm2022/siemens-element-ng-inline-notification.mjs.map +1 -1
  92. package/fesm2022/siemens-element-ng-ip-input.mjs +451 -0
  93. package/fesm2022/siemens-element-ng-ip-input.mjs.map +1 -0
  94. package/fesm2022/siemens-element-ng-list-details.mjs +390 -0
  95. package/fesm2022/siemens-element-ng-list-details.mjs.map +1 -0
  96. package/fesm2022/siemens-element-ng-loading-spinner.mjs +15 -12
  97. package/fesm2022/siemens-element-ng-loading-spinner.mjs.map +1 -1
  98. package/fesm2022/siemens-element-ng-localization.mjs +306 -0
  99. package/fesm2022/siemens-element-ng-localization.mjs.map +1 -0
  100. package/fesm2022/siemens-element-ng-modal.mjs +4 -1
  101. package/fesm2022/siemens-element-ng-modal.mjs.map +1 -1
  102. package/fesm2022/siemens-element-ng-password-strength.mjs +22 -16
  103. package/fesm2022/siemens-element-ng-password-strength.mjs.map +1 -1
  104. package/fesm2022/siemens-element-ng-phone-number.mjs +426 -0
  105. package/fesm2022/siemens-element-ng-phone-number.mjs.map +1 -0
  106. package/fesm2022/siemens-element-ng-photo-upload.mjs +480 -0
  107. package/fesm2022/siemens-element-ng-photo-upload.mjs.map +1 -0
  108. package/fesm2022/siemens-element-ng-result-details-list.mjs +74 -0
  109. package/fesm2022/siemens-element-ng-result-details-list.mjs.map +1 -0
  110. package/fesm2022/siemens-element-ng-search-bar.mjs +193 -0
  111. package/fesm2022/siemens-element-ng-search-bar.mjs.map +1 -0
  112. package/fesm2022/siemens-element-ng-shadow-root.mjs +70 -0
  113. package/fesm2022/siemens-element-ng-shadow-root.mjs.map +1 -0
  114. package/fesm2022/siemens-element-ng-side-panel.mjs +554 -0
  115. package/fesm2022/siemens-element-ng-side-panel.mjs.map +1 -0
  116. package/fesm2022/siemens-element-ng-slider.mjs +313 -0
  117. package/fesm2022/siemens-element-ng-slider.mjs.map +1 -0
  118. package/fesm2022/siemens-element-ng-sort-bar.mjs +89 -0
  119. package/fesm2022/siemens-element-ng-sort-bar.mjs.map +1 -0
  120. package/fesm2022/siemens-element-ng-split.mjs +575 -0
  121. package/fesm2022/siemens-element-ng-split.mjs.map +1 -0
  122. package/fesm2022/siemens-element-ng-status-bar.mjs +348 -0
  123. package/fesm2022/siemens-element-ng-status-bar.mjs.map +1 -0
  124. package/fesm2022/siemens-element-ng-status-toggle.mjs +196 -0
  125. package/fesm2022/siemens-element-ng-status-toggle.mjs.map +1 -0
  126. package/fesm2022/siemens-element-ng-system-banner.mjs +47 -0
  127. package/fesm2022/siemens-element-ng-system-banner.mjs.map +1 -0
  128. package/fesm2022/siemens-element-ng-tabs-next.mjs +491 -0
  129. package/fesm2022/siemens-element-ng-tabs-next.mjs.map +1 -0
  130. package/fesm2022/siemens-element-ng-tabs.mjs +395 -0
  131. package/fesm2022/siemens-element-ng-tabs.mjs.map +1 -0
  132. package/fesm2022/siemens-element-ng-translate.mjs.map +1 -1
  133. package/fesm2022/siemens-element-ng-tree-view.mjs +2936 -0
  134. package/fesm2022/siemens-element-ng-tree-view.mjs.map +1 -0
  135. package/fesm2022/siemens-element-ng-unauthorized-page.mjs +76 -0
  136. package/fesm2022/siemens-element-ng-unauthorized-page.mjs.map +1 -0
  137. package/fesm2022/siemens-element-ng-wizard.mjs +2 -2
  138. package/fesm2022/siemens-element-ng-wizard.mjs.map +1 -1
  139. package/file-uploader/index.d.ts +8 -0
  140. package/file-uploader/package.json +3 -0
  141. package/file-uploader/si-file-dropzone.component.d.ts +106 -0
  142. package/file-uploader/si-file-uploader.component.d.ts +296 -0
  143. package/file-uploader/si-file-uploader.model.d.ts +12 -0
  144. package/file-uploader/si-file-uploader.module.d.ts +8 -0
  145. package/filter-bar/filter.d.ts +26 -0
  146. package/filter-bar/index.d.ts +8 -0
  147. package/filter-bar/package.json +3 -0
  148. package/filter-bar/si-filter-bar.component.d.ts +65 -0
  149. package/filter-bar/si-filter-bar.module.d.ts +7 -0
  150. package/filter-bar/si-filter-pill.component.d.ts +20 -0
  151. package/filtered-search/index.d.ts +7 -0
  152. package/filtered-search/package.json +3 -0
  153. package/filtered-search/si-filtered-search-helper.d.ts +22 -0
  154. package/filtered-search/si-filtered-search-value.component.d.ts +53 -0
  155. package/filtered-search/si-filtered-search.component.d.ts +329 -0
  156. package/filtered-search/si-filtered-search.model.d.ts +139 -0
  157. package/filtered-search/si-filtered-search.module.d.ts +7 -0
  158. package/filtered-search/values/date-value/si-filtered-search-date-value.component.d.ts +57 -0
  159. package/filtered-search/values/si-filtered-search-value.base.d.ts +27 -0
  160. package/filtered-search/values/typeahead/si-filtered-search-typeahead.component.d.ts +45 -0
  161. package/formly/fields/button/si-formly-button.component.d.ts +7 -0
  162. package/formly/fields/date-range/si-formly-date-range.component.d.ts +6 -0
  163. package/formly/fields/datetime/si-formly-datetime.component.d.ts +13 -0
  164. package/formly/fields/email/si-formly-email.component.d.ts +6 -0
  165. package/formly/fields/ip-input/si-formly-ip-input.component.d.ts +6 -0
  166. package/formly/fields/number/si-formly-number.component.d.ts +6 -0
  167. package/formly/fields/password/si-formly-password.component.d.ts +6 -0
  168. package/formly/fields/select/si-formly-select.component.d.ts +6 -0
  169. package/formly/fields/text/si-formly-text-display.component.d.ts +7 -0
  170. package/formly/fields/textarea/si-formly-textarea.component.d.ts +18 -0
  171. package/formly/fields/time/si-formly-time.component.d.ts +13 -0
  172. package/formly/index.d.ts +6 -0
  173. package/formly/package.json +3 -0
  174. package/formly/si-formly-translate.extension.d.ts +11 -0
  175. package/formly/si-formly.component.d.ts +62 -0
  176. package/formly/si-formly.module.d.ts +35 -0
  177. package/formly/structural/si-formly-accordion/si-formly-accordion.component.d.ts +13 -0
  178. package/formly/structural/si-formly-array/si-formly-array.component.d.ts +6 -0
  179. package/formly/structural/si-formly-object/si-formly-object.component.d.ts +6 -0
  180. package/formly/structural/si-formly-object-grid/si-formly-object-grid.component.d.ts +22 -0
  181. package/formly/structural/si-formly-object-grid/si-formly-object-grid.model.d.ts +21 -0
  182. package/formly/structural/si-formly-object-plain/si-formly-object-plain.component.d.ts +6 -0
  183. package/formly/structural/si-formly-tabset/si-formly-object-tabset.component.d.ts +7 -0
  184. package/formly/utils.d.ts +6 -0
  185. package/formly/wrapper/si-formly-fieldset.component.d.ts +8 -0
  186. package/formly/wrapper/si-formly-form-field-provider.directive.d.ts +19 -0
  187. package/formly/wrapper/si-formly-horizontal-wrapper.component.d.ts +6 -0
  188. package/formly/wrapper/si-formly-icon-wrapper.component.d.ts +6 -0
  189. package/formly/wrapper/si-formly-wrapper.component.d.ts +8 -0
  190. package/icon/element-icons.d.ts +15 -0
  191. package/icon/si-status-icon.component.d.ts +6 -1
  192. package/info-page/index.d.ts +5 -0
  193. package/info-page/package.json +3 -0
  194. package/info-page/si-info-page.component.d.ts +38 -0
  195. package/inline-notification/si-inline-notification.component.d.ts +0 -2
  196. package/ip-input/address-utils.d.ts +28 -0
  197. package/ip-input/address-validators.d.ts +21 -0
  198. package/ip-input/index.d.ts +7 -0
  199. package/ip-input/package.json +3 -0
  200. package/ip-input/si-ip-input.directive.d.ts +53 -0
  201. package/ip-input/si-ip4-input.directive.d.ts +9 -0
  202. package/ip-input/si-ip6-input.directive.d.ts +10 -0
  203. package/list-details/index.d.ts +12 -0
  204. package/list-details/package.json +3 -0
  205. package/list-details/si-details-pane/si-details-pane.component.d.ts +8 -0
  206. package/list-details/si-details-pane-body/si-details-pane-body.component.d.ts +6 -0
  207. package/list-details/si-details-pane-footer/si-details-pane-footer.component.d.ts +6 -0
  208. package/list-details/si-details-pane-header/si-details-pane-header.component.d.ts +38 -0
  209. package/list-details/si-list-details.component.d.ts +100 -0
  210. package/list-details/si-list-pane/si-list-pane.component.d.ts +10 -0
  211. package/list-details/si-list-pane-body/si-list-pane-body.component.d.ts +6 -0
  212. package/list-details/si-list-pane-header/si-list-pane-header.component.d.ts +6 -0
  213. package/loading-spinner/si-loading-spinner.directive.d.ts +3 -2
  214. package/localization/index.d.ts +8 -0
  215. package/localization/package.json +3 -0
  216. package/localization/si-directionality.d.ts +41 -0
  217. package/localization/si-locale-id.d.ts +22 -0
  218. package/localization/si-locale-store.d.ts +16 -0
  219. package/localization/si-locale.service.d.ts +73 -0
  220. package/package.json +161 -9
  221. package/password-strength/si-password-strength.directive.d.ts +11 -0
  222. package/phone-number/index.d.ts +7 -0
  223. package/phone-number/package.json +3 -0
  224. package/phone-number/si-phone-number-input-select.directive.d.ts +10 -0
  225. package/phone-number/si-phone-number-input.component.d.ts +137 -0
  226. package/phone-number/si-phone-number-input.models.d.ts +48 -0
  227. package/phone-number/si-phone-number-input.module.d.ts +7 -0
  228. package/photo-upload/index.d.ts +6 -0
  229. package/photo-upload/package.json +3 -0
  230. package/photo-upload/si-image-cropper-style.component.d.ts +5 -0
  231. package/photo-upload/si-photo-upload.component.d.ts +298 -0
  232. package/result-details-list/index.d.ts +7 -0
  233. package/result-details-list/package.json +3 -0
  234. package/result-details-list/si-result-details-list.component.d.ts +14 -0
  235. package/result-details-list/si-result-details-list.datamodel.d.ts +48 -0
  236. package/result-details-list/si-result-details-list.module.d.ts +7 -0
  237. package/search-bar/index.d.ts +6 -0
  238. package/search-bar/package.json +3 -0
  239. package/search-bar/si-search-bar.component.d.ts +87 -0
  240. package/search-bar/si-search-bar.module.d.ts +7 -0
  241. package/shadow-root/index.d.ts +5 -0
  242. package/shadow-root/package.json +3 -0
  243. package/shadow-root/si-shadow-root.directive.d.ts +39 -0
  244. package/side-panel/index.d.ts +9 -0
  245. package/side-panel/package.json +3 -0
  246. package/side-panel/si-side-panel-content.component.d.ts +105 -0
  247. package/side-panel/si-side-panel.component.d.ts +108 -0
  248. package/side-panel/si-side-panel.module.d.ts +8 -0
  249. package/side-panel/si-side-panel.service.d.ts +45 -0
  250. package/side-panel/side-panel.model.d.ts +16 -0
  251. package/slider/index.d.ts +6 -0
  252. package/slider/package.json +3 -0
  253. package/slider/si-slider.component.d.ts +129 -0
  254. package/slider/si-slider.module.d.ts +7 -0
  255. package/sort-bar/index.d.ts +6 -0
  256. package/sort-bar/package.json +3 -0
  257. package/sort-bar/si-sort-bar.component.d.ts +42 -0
  258. package/sort-bar/si-sort-bar.module.d.ts +7 -0
  259. package/split/index.d.ts +8 -0
  260. package/split/package.json +3 -0
  261. package/split/si-split-part.component.d.ts +154 -0
  262. package/split/si-split.component.d.ts +48 -0
  263. package/split/si-split.interfaces.d.ts +17 -0
  264. package/split/si-split.module.d.ts +8 -0
  265. package/status-bar/index.d.ts +7 -0
  266. package/status-bar/package.json +3 -0
  267. package/status-bar/si-status-bar-item/index.d.ts +6 -0
  268. package/status-bar/si-status-bar-item/si-status-bar-item.component.d.ts +22 -0
  269. package/status-bar/si-status-bar-item/si-status-bar-item.model.d.ts +33 -0
  270. package/status-bar/si-status-bar.component.d.ts +116 -0
  271. package/status-bar/si-status-bar.module.d.ts +7 -0
  272. package/status-toggle/index.d.ts +6 -0
  273. package/status-toggle/package.json +3 -0
  274. package/status-toggle/si-status-toggle.component.d.ts +54 -0
  275. package/status-toggle/status-toggle.model.d.ts +26 -0
  276. package/system-banner/index.d.ts +5 -0
  277. package/system-banner/package.json +3 -0
  278. package/system-banner/system-banner.component.d.ts +23 -0
  279. package/tabs/index.d.ts +7 -0
  280. package/tabs/package.json +3 -0
  281. package/tabs/si-tab/index.d.ts +5 -0
  282. package/tabs/si-tab/si-tab.component.d.ts +58 -0
  283. package/tabs/si-tabs.module.d.ts +8 -0
  284. package/tabs/si-tabset/index.d.ts +5 -0
  285. package/tabs/si-tabset/si-tabset.component.d.ts +100 -0
  286. package/tabs-next/index.d.ts +7 -0
  287. package/tabs-next/package.json +3 -0
  288. package/tabs-next/si-tab-next-base.directive.d.ts +66 -0
  289. package/tabs-next/si-tab-next-link.component.d.ts +18 -0
  290. package/tabs-next/si-tab-next.component.d.ts +16 -0
  291. package/tabs-next/si-tabs-tokens.d.ts +7 -0
  292. package/tabs-next/si-tabset-next.component.d.ts +72 -0
  293. package/template-i18n.json +111 -0
  294. package/translate/si-translatable-keys.interface.d.ts +111 -0
  295. package/tree-view/drag-drop.util.d.ts +32 -0
  296. package/tree-view/index.d.ts +12 -0
  297. package/tree-view/package.json +3 -0
  298. package/tree-view/si-tree-view-converter.service.d.ts +41 -0
  299. package/tree-view/si-tree-view-item/si-tree-view-item.component.d.ts +105 -0
  300. package/tree-view/si-tree-view-item/si-tree-view-item.directive.d.ts +24 -0
  301. package/tree-view/si-tree-view-item-context.d.ts +11 -0
  302. package/tree-view/si-tree-view-item-height.service.d.ts +49 -0
  303. package/tree-view/si-tree-view-item-template.directive.d.ts +18 -0
  304. package/tree-view/si-tree-view-virtualization.service.d.ts +150 -0
  305. package/tree-view/si-tree-view.component.d.ts +466 -0
  306. package/tree-view/si-tree-view.model.d.ts +146 -0
  307. package/tree-view/si-tree-view.module.d.ts +10 -0
  308. package/tree-view/si-tree-view.service.d.ts +55 -0
  309. package/tree-view/si-tree-view.utils.d.ts +46 -0
  310. package/unauthorized-page/index.d.ts +6 -0
  311. package/unauthorized-page/package.json +3 -0
  312. package/unauthorized-page/si-unauthorized-page.component.d.ts +35 -0
  313. 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\">&bull;</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\">&bull;</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