@aquera/nile-elements 1.3.0-beta-1.0 → 1.3.0-beta-1.1

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 (540) hide show
  1. package/README.md +0 -1
  2. package/demo/index.css +0 -3
  3. package/demo/index.html +32 -79
  4. package/demo/variables.css +1 -0
  5. package/dist/{fixture-dff65c89.cjs.js → fixture-54600b35.cjs.js} +2 -2
  6. package/dist/{fixture-1c49c014.cjs.js.map → fixture-54600b35.cjs.js.map} +1 -1
  7. package/dist/{fixture-1c49c014.cjs.js → fixture-5b79f853.cjs.js} +2 -2
  8. package/dist/{fixture-dff65c89.cjs.js.map → fixture-5b79f853.cjs.js.map} +1 -1
  9. package/dist/{fixture-f575d0df.cjs.js → fixture-73855806.cjs.js} +4 -4
  10. package/dist/fixture-73855806.cjs.js.map +1 -0
  11. package/dist/fixture-90b199c4.esm.js +569 -0
  12. package/dist/{fixture-985bba12.esm.js → fixture-9871e8a9.esm.js} +1 -1
  13. package/dist/fixture-c1d78368.cjs.js +395 -0
  14. package/dist/fixture-c1d78368.cjs.js.map +1 -0
  15. package/dist/{fixture-eddab1c0.esm.js → fixture-cf7bfcf5.esm.js} +2 -2
  16. package/dist/fixture-dbd66009.cjs.js +395 -0
  17. package/dist/fixture-dbd66009.cjs.js.map +1 -0
  18. package/dist/index.cjs.js +1 -1
  19. package/dist/index.esm.js +1 -1
  20. package/dist/index.js +173 -188
  21. package/dist/nile-accordion/nile-accordian.test.cjs.js +1 -1
  22. package/dist/nile-accordion/nile-accordian.test.esm.js +1 -1
  23. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js +1 -1
  24. package/dist/nile-auto-complete/nile-auto-complete.test.esm.js +1 -1
  25. package/dist/nile-avatar/nile-avatar.test.cjs.js +1 -1
  26. package/dist/nile-avatar/nile-avatar.test.esm.js +1 -1
  27. package/dist/nile-badge/nile-badge.test.cjs.js +1 -1
  28. package/dist/nile-badge/nile-badge.test.esm.js +1 -1
  29. package/dist/nile-button/nile-button.test.cjs.js +1 -1
  30. package/dist/nile-button/nile-button.test.esm.js +1 -1
  31. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.cjs.js +1 -1
  32. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.esm.js +1 -1
  33. package/dist/nile-calendar/nile-calendar.test.cjs.js +1 -1
  34. package/dist/nile-calendar/nile-calendar.test.esm.js +1 -1
  35. package/dist/nile-card/nile-card.test.cjs.js +1 -1
  36. package/dist/nile-card/nile-card.test.esm.js +1 -1
  37. package/dist/nile-checkbox/nile-checkbox.test.cjs.js +1 -1
  38. package/dist/nile-checkbox/nile-checkbox.test.esm.js +1 -1
  39. package/dist/nile-chip/nile-chip.test.cjs.js +1 -1
  40. package/dist/nile-chip/nile-chip.test.esm.js +1 -1
  41. package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js +2 -0
  42. package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js.map +1 -0
  43. package/dist/nile-code-editor/backup_nile-code-editor copy.esm.js +1 -0
  44. package/dist/nile-dialog/nile-dialog.test.cjs.js +1 -1
  45. package/dist/nile-dialog/nile-dialog.test.esm.js +1 -1
  46. package/dist/nile-drawer/nile-drawer.test.cjs.js +1 -1
  47. package/dist/nile-drawer/nile-drawer.test.esm.js +1 -1
  48. package/dist/nile-dropdown/nile-dropdown.test.cjs.js +1 -1
  49. package/dist/nile-dropdown/nile-dropdown.test.esm.js +1 -1
  50. package/dist/nile-empty-state/nile-empty-state.test.cjs.js +1 -1
  51. package/dist/nile-empty-state/nile-empty-state.test.esm.js +1 -1
  52. package/dist/nile-error-message/nile-error-message.test.cjs.js +1 -1
  53. package/dist/nile-error-message/nile-error-message.test.esm.js +1 -1
  54. package/dist/nile-file-preview/nile-file-preview.test.cjs.js +1 -1
  55. package/dist/nile-file-preview/nile-file-preview.test.esm.js +1 -1
  56. package/dist/nile-file-upload/nile-file-upload.test.cjs.js +1 -1
  57. package/dist/nile-file-upload/nile-file-upload.test.esm.js +1 -1
  58. package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js +1 -1
  59. package/dist/nile-filter-chip/nile-filter-chip.test.esm.js +1 -1
  60. package/dist/nile-form-group/nile-form-group.test.cjs.js +1 -1
  61. package/dist/nile-form-group/nile-form-group.test.esm.js +1 -1
  62. package/dist/nile-form-help-text/nile-form-help-text.test.cjs.js +1 -1
  63. package/dist/nile-form-help-text/nile-form-help-text.test.esm.js +1 -1
  64. package/dist/nile-grid-body/index.cjs.js +2 -0
  65. package/dist/nile-grid-body/index.esm.js +1 -0
  66. package/dist/nile-grid-body/nile-grid-body.cjs.js +2 -0
  67. package/dist/nile-grid-body/nile-grid-body.cjs.js.map +1 -0
  68. package/dist/nile-grid-body/nile-grid-body.css.cjs.js +2 -0
  69. package/dist/nile-grid-body/nile-grid-body.css.cjs.js.map +1 -0
  70. package/dist/nile-grid-body/nile-grid-body.css.esm.js +10 -0
  71. package/dist/nile-grid-body/nile-grid-body.esm.js +5 -0
  72. package/dist/nile-grid-cell-item/index.cjs.js +2 -0
  73. package/dist/nile-grid-cell-item/index.cjs.js.map +1 -0
  74. package/dist/nile-grid-cell-item/index.esm.js +1 -0
  75. package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js +2 -0
  76. package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js.map +1 -0
  77. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js +2 -0
  78. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js.map +1 -0
  79. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.esm.js +35 -0
  80. package/dist/nile-grid-cell-item/nile-grid-cell-item.esm.js +12 -0
  81. package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.cjs.js +2 -0
  82. package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.cjs.js.map +1 -0
  83. package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.esm.js +1 -0
  84. package/dist/nile-grid-head/index.cjs.js +2 -0
  85. package/dist/nile-grid-head/index.cjs.js.map +1 -0
  86. package/dist/nile-grid-head/index.esm.js +1 -0
  87. package/dist/nile-grid-head/nile-grid-head.cjs.js +2 -0
  88. package/dist/nile-grid-head/nile-grid-head.cjs.js.map +1 -0
  89. package/dist/nile-grid-head/nile-grid-head.css.cjs.js +2 -0
  90. package/dist/nile-grid-head/nile-grid-head.css.cjs.js.map +1 -0
  91. package/dist/nile-grid-head/nile-grid-head.css.esm.js +7 -0
  92. package/dist/nile-grid-head/nile-grid-head.esm.js +5 -0
  93. package/dist/nile-grid-head-item/index.cjs.js +2 -0
  94. package/dist/nile-grid-head-item/index.cjs.js.map +1 -0
  95. package/dist/nile-grid-head-item/index.esm.js +1 -0
  96. package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js +2 -0
  97. package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js.map +1 -0
  98. package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js +2 -0
  99. package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js.map +1 -0
  100. package/dist/nile-grid-head-item/nile-grid-head-item.css.esm.js +34 -0
  101. package/dist/nile-grid-head-item/nile-grid-head-item.esm.js +12 -0
  102. package/dist/nile-grid-head-item/nile-grid-head-item.utils.cjs.js +2 -0
  103. package/dist/nile-grid-head-item/nile-grid-head-item.utils.cjs.js.map +1 -0
  104. package/dist/nile-grid-head-item/nile-grid-head-item.utils.esm.js +1 -0
  105. package/dist/nile-grid-row/index.cjs.js +2 -0
  106. package/dist/nile-grid-row/index.cjs.js.map +1 -0
  107. package/dist/nile-grid-row/index.esm.js +1 -0
  108. package/dist/nile-grid-row/nile-grid-row.cjs.js +2 -0
  109. package/dist/nile-grid-row/nile-grid-row.cjs.js.map +1 -0
  110. package/dist/nile-grid-row/nile-grid-row.css.cjs.js +2 -0
  111. package/dist/nile-grid-row/nile-grid-row.css.cjs.js.map +1 -0
  112. package/dist/nile-grid-row/nile-grid-row.css.esm.js +15 -0
  113. package/dist/nile-grid-row/nile-grid-row.esm.js +7 -0
  114. package/dist/nile-hero/nile-hero.test.cjs.js +1 -1
  115. package/dist/nile-hero/nile-hero.test.esm.js +1 -1
  116. package/dist/nile-icon/nile-icon.test.cjs.js +1 -1
  117. package/dist/nile-icon/nile-icon.test.esm.js +1 -1
  118. package/dist/nile-inline-edit/index.cjs.js +1 -1
  119. package/dist/nile-inline-edit/index.esm.js +1 -1
  120. package/dist/nile-inline-edit/nile-inline-edit-utils.cjs.js +2 -0
  121. package/dist/nile-inline-edit/nile-inline-edit-utils.cjs.js.map +1 -0
  122. package/dist/nile-inline-edit/nile-inline-edit-utils.esm.js +1 -0
  123. package/dist/nile-inline-edit/nile-inline-edit.cjs.js +1 -1
  124. package/dist/nile-inline-edit/nile-inline-edit.cjs.js.map +1 -1
  125. package/dist/nile-inline-edit/nile-inline-edit.esm.js +4 -4
  126. package/dist/nile-inline-sidebar/nile-inline-sidebar.cjs.js +1 -1
  127. package/dist/nile-inline-sidebar/nile-inline-sidebar.cjs.js.map +1 -1
  128. package/dist/nile-inline-sidebar/nile-inline-sidebar.css.cjs.js +1 -1
  129. package/dist/nile-inline-sidebar/nile-inline-sidebar.css.cjs.js.map +1 -1
  130. package/dist/nile-inline-sidebar/nile-inline-sidebar.css.esm.js +2 -2
  131. package/dist/nile-inline-sidebar/nile-inline-sidebar.esm.js +6 -10
  132. package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.cjs.js +1 -1
  133. package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.cjs.js.map +1 -1
  134. package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.esm.js +2 -2
  135. package/dist/nile-input/nile-input.test.cjs.js +1 -1
  136. package/dist/nile-input/nile-input.test.esm.js +1 -1
  137. package/dist/nile-link/nile-link.test.cjs.js +1 -1
  138. package/dist/nile-link/nile-link.test.esm.js +1 -1
  139. package/dist/nile-loader/nile-loader.test.cjs.js +1 -1
  140. package/dist/nile-loader/nile-loader.test.esm.js +1 -1
  141. package/dist/nile-popover/nile-popover.test.cjs.js +1 -1
  142. package/dist/nile-popover/nile-popover.test.esm.js +1 -1
  143. package/dist/nile-popup/nile-popup.test.cjs.js +1 -1
  144. package/dist/nile-popup/nile-popup.test.esm.js +1 -1
  145. package/dist/nile-progress-bar/nile-progress-bar.test.cjs.js +1 -1
  146. package/dist/nile-progress-bar/nile-progress-bar.test.esm.js +1 -1
  147. package/dist/nile-radio/nile-radio.test.cjs.js +1 -1
  148. package/dist/nile-radio/nile-radio.test.esm.js +1 -1
  149. package/dist/nile-radio-group/nile-radio-group.test.cjs.js +1 -1
  150. package/dist/nile-radio-group/nile-radio-group.test.esm.js +1 -1
  151. package/dist/nile-rich-text-editor/utils.cjs.js +2 -0
  152. package/dist/nile-rich-text-editor/utils.cjs.js.map +1 -0
  153. package/dist/nile-rich-text-editor/utils.esm.js +1 -0
  154. package/dist/nile-select/nile-select.test.cjs.js +1 -1
  155. package/dist/nile-select/nile-select.test.esm.js +1 -1
  156. package/dist/nile-side-bar-expand/nile-side-bar-expand.cjs.js +1 -1
  157. package/dist/nile-side-bar-expand/nile-side-bar-expand.cjs.js.map +1 -1
  158. package/dist/nile-side-bar-expand/nile-side-bar-expand.css.cjs.js +1 -1
  159. package/dist/nile-side-bar-expand/nile-side-bar-expand.css.cjs.js.map +1 -1
  160. package/dist/nile-side-bar-expand/nile-side-bar-expand.css.esm.js +5 -3
  161. package/dist/nile-side-bar-expand/nile-side-bar-expand.esm.js +6 -6
  162. package/dist/nile-side-bar-footer/nile-side-bar-footer.css.cjs.js +1 -1
  163. package/dist/nile-side-bar-footer/nile-side-bar-footer.css.cjs.js.map +1 -1
  164. package/dist/nile-side-bar-footer/nile-side-bar-footer.css.esm.js +1 -0
  165. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.cjs.js +1 -1
  166. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.cjs.js.map +1 -1
  167. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.cjs.js +1 -1
  168. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.cjs.js.map +1 -1
  169. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.esm.js +5 -17
  170. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.esm.js +3 -3
  171. package/dist/nile-side-bar-group/nile-side-bar-group.css.cjs.js +1 -1
  172. package/dist/nile-side-bar-group/nile-side-bar-group.css.cjs.js.map +1 -1
  173. package/dist/nile-side-bar-group/nile-side-bar-group.css.esm.js +2 -2
  174. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.css.cjs.js +1 -1
  175. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.css.cjs.js.map +1 -1
  176. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.css.esm.js +56 -58
  177. package/dist/nile-sidebar/index.cjs.js +2 -0
  178. package/dist/nile-sidebar/index.cjs.js.map +1 -0
  179. package/dist/nile-sidebar/index.esm.js +75 -0
  180. package/dist/nile-sidebar-menu/index.cjs.js +2 -0
  181. package/dist/nile-sidebar-menu/index.cjs.js.map +1 -0
  182. package/dist/nile-sidebar-menu/index.esm.js +1 -0
  183. package/dist/nile-sidebar-menu/nile-sidebar-menu.cjs.js +2 -0
  184. package/dist/nile-sidebar-menu/nile-sidebar-menu.cjs.js.map +1 -0
  185. package/dist/nile-sidebar-menu/nile-sidebar-menu.css.cjs.js +2 -0
  186. package/dist/nile-sidebar-menu/nile-sidebar-menu.css.cjs.js.map +1 -0
  187. package/dist/nile-sidebar-menu/nile-sidebar-menu.css.esm.js +38 -0
  188. package/dist/nile-sidebar-menu/nile-sidebar-menu.esm.js +10 -0
  189. package/dist/nile-sidebar-menu-items/index.cjs.js +2 -0
  190. package/dist/nile-sidebar-menu-items/index.cjs.js.map +1 -0
  191. package/dist/nile-sidebar-menu-items/index.esm.js +1 -0
  192. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.cjs.js +2 -0
  193. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.cjs.js.map +1 -0
  194. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.css.cjs.js +2 -0
  195. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.css.cjs.js.map +1 -0
  196. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.css.esm.js +36 -0
  197. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.esm.js +15 -0
  198. package/dist/nile-sidebar-wrapper/index.cjs.js +2 -0
  199. package/dist/nile-sidebar-wrapper/index.cjs.js.map +1 -0
  200. package/dist/nile-sidebar-wrapper/index.esm.js +1 -0
  201. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.cjs.js +2 -0
  202. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.cjs.js.map +1 -0
  203. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.css.cjs.js +2 -0
  204. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.css.cjs.js.map +1 -0
  205. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.css.esm.js +105 -0
  206. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.esm.js +16 -0
  207. package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js +1 -1
  208. package/dist/nile-slide-toggle/nile-slide-toggle.test.esm.js +1 -1
  209. package/dist/nile-tab-group/nile-tab-group.test.cjs.js +1 -1
  210. package/dist/nile-tab-group/nile-tab-group.test.esm.js +1 -1
  211. package/dist/nile-textarea/nile-textarea.test.cjs.js +1 -1
  212. package/dist/nile-textarea/nile-textarea.test.esm.js +1 -1
  213. package/dist/nile-virtual-select/group-manager.cjs.js +2 -0
  214. package/dist/nile-virtual-select/group-manager.cjs.js.map +1 -0
  215. package/dist/nile-virtual-select/group-manager.esm.js +1 -0
  216. package/dist/nile-virtual-select/nile-virtual-select.test.cjs.js +1 -1
  217. package/dist/nile-virtual-select/nile-virtual-select.test.esm.js +1 -1
  218. package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js +2 -0
  219. package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js.map +1 -0
  220. package/dist/nile-virtual-select/temp_nile-virtual-select copy.esm.js +231 -0
  221. package/dist/scopedElementsWrapper-4c29be11.esm.js +7 -0
  222. package/dist/scopedElementsWrapper-a112fc73.cjs.js +6 -0
  223. package/dist/scopedElementsWrapper-a112fc73.cjs.js.map +1 -0
  224. package/dist/scopedElementsWrapper-c815042c.cjs.js +2 -0
  225. package/dist/scopedElementsWrapper-c815042c.cjs.js.map +1 -0
  226. package/dist/src/internal/portal-manager.d.ts +53 -0
  227. package/dist/src/internal/portal-manager.js +196 -0
  228. package/dist/src/internal/portal-manager.js.map +1 -0
  229. package/dist/src/internal/portal.d.ts +60 -0
  230. package/dist/src/internal/portal.js +199 -0
  231. package/dist/src/internal/portal.js.map +1 -0
  232. package/dist/src/internal/resizable-helper.d.ts +59 -0
  233. package/dist/src/internal/resizable-helper.js +115 -0
  234. package/dist/src/internal/resizable-helper.js.map +1 -0
  235. package/dist/src/internal/resizable-styles.d.ts +16 -0
  236. package/dist/src/internal/resizable-styles.js +144 -0
  237. package/dist/src/internal/resizable-styles.js.map +1 -0
  238. package/dist/src/internal/virtualizer-error-handler.d.ts +30 -0
  239. package/dist/src/internal/virtualizer-error-handler.js +82 -0
  240. package/dist/src/internal/virtualizer-error-handler.js.map +1 -0
  241. package/dist/src/lib/index.d.ts +7 -0
  242. package/dist/src/lib/index.js +8 -0
  243. package/dist/src/lib/index.js.map +1 -0
  244. package/dist/src/lib/virtualize.d.ts +32 -0
  245. package/dist/src/lib/virtualize.js +105 -0
  246. package/dist/src/lib/virtualize.js.map +1 -0
  247. package/dist/src/lib/virtualize.test.d.ts +7 -0
  248. package/dist/src/lib/virtualize.test.js +57 -0
  249. package/dist/src/lib/virtualize.test.js.map +1 -0
  250. package/dist/src/nile-badge/__snapshots__/nile-badge.test.snap.js +17 -0
  251. package/dist/src/nile-calendar/__snapshots__/nile-calendar.test.snap.js +310 -0
  252. package/dist/src/nile-card/__snapshots__/nile-card.test.snap.js +34 -0
  253. package/dist/src/nile-checkbox/__snapshots__/nile-checkbox.test.snap.js +31 -0
  254. package/dist/src/nile-code-editor/Old_theme copy.d.ts +191 -0
  255. package/dist/src/nile-code-editor/Old_theme copy.js +193 -0
  256. package/dist/src/nile-code-editor/Old_theme copy.js.map +1 -0
  257. package/dist/src/nile-code-editor/backup_nile-code-editor copy.d.ts +0 -0
  258. package/dist/src/nile-code-editor/backup_nile-code-editor copy.js +675 -0
  259. package/dist/src/nile-code-editor/backup_nile-code-editor copy.js.map +1 -0
  260. package/dist/src/nile-code-editor/theme copy.d.ts +191 -0
  261. package/dist/src/nile-code-editor/theme copy.js +193 -0
  262. package/dist/src/nile-code-editor/theme copy.js.map +1 -0
  263. package/dist/src/nile-grid/data-processor.d.ts +37 -0
  264. package/dist/src/nile-grid/data-processor.js +122 -0
  265. package/dist/src/nile-grid/data-processor.js.map +1 -0
  266. package/dist/src/nile-grid/event-handlers.d.ts +35 -0
  267. package/dist/src/nile-grid/event-handlers.js +158 -0
  268. package/dist/src/nile-grid/event-handlers.js.map +1 -0
  269. package/dist/src/nile-grid/renderer.d.ts +8 -0
  270. package/dist/src/nile-grid/renderer.js +78 -0
  271. package/dist/src/nile-grid/renderer.js.map +1 -0
  272. package/dist/src/nile-grid/resize-handler.d.ts +4 -0
  273. package/dist/src/nile-grid/resize-handler.js +36 -0
  274. package/dist/src/nile-grid/resize-handler.js.map +1 -0
  275. package/dist/src/nile-grid/types.d.ts +32 -0
  276. package/dist/src/nile-grid/types.js +2 -0
  277. package/dist/src/nile-grid/types.js.map +1 -0
  278. package/dist/src/nile-grid/utils.d.ts +4 -0
  279. package/dist/src/nile-grid/utils.js +32 -0
  280. package/dist/src/nile-grid/utils.js.map +1 -0
  281. package/dist/src/nile-grid-body/index.d.ts +1 -0
  282. package/dist/src/nile-grid-body/index.js +2 -0
  283. package/dist/src/nile-grid-body/index.js.map +1 -0
  284. package/dist/src/nile-grid-body/nile-grid-body.css.d.ts +12 -0
  285. package/dist/src/nile-grid-body/nile-grid-body.css.js +22 -0
  286. package/dist/src/nile-grid-body/nile-grid-body.css.js.map +1 -0
  287. package/dist/src/nile-grid-body/nile-grid-body.d.ts +29 -0
  288. package/dist/src/nile-grid-body/nile-grid-body.js +43 -0
  289. package/dist/src/nile-grid-body/nile-grid-body.js.map +1 -0
  290. package/dist/src/nile-grid-cell-item/index.d.ts +1 -0
  291. package/dist/src/nile-grid-cell-item/index.js +2 -0
  292. package/dist/src/nile-grid-cell-item/index.js.map +1 -0
  293. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.d.ts +12 -0
  294. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js +47 -0
  295. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js.map +1 -0
  296. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.d.ts +36 -0
  297. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js +93 -0
  298. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js.map +1 -0
  299. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.d.ts +10 -0
  300. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.js +34 -0
  301. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.js.map +1 -0
  302. package/dist/src/nile-grid-head/index.d.ts +1 -0
  303. package/dist/src/nile-grid-head/index.js +2 -0
  304. package/dist/src/nile-grid-head/index.js.map +1 -0
  305. package/dist/src/nile-grid-head/nile-grid-head.css.d.ts +12 -0
  306. package/dist/src/nile-grid-head/nile-grid-head.css.js +19 -0
  307. package/dist/src/nile-grid-head/nile-grid-head.css.js.map +1 -0
  308. package/dist/src/nile-grid-head/nile-grid-head.d.ts +28 -0
  309. package/dist/src/nile-grid-head/nile-grid-head.js +41 -0
  310. package/dist/src/nile-grid-head/nile-grid-head.js.map +1 -0
  311. package/dist/src/nile-grid-head-item/index.d.ts +1 -0
  312. package/dist/src/nile-grid-head-item/index.js +2 -0
  313. package/dist/src/nile-grid-head-item/index.js.map +1 -0
  314. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.d.ts +12 -0
  315. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js +46 -0
  316. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js.map +1 -0
  317. package/dist/src/nile-grid-head-item/nile-grid-head-item.d.ts +37 -0
  318. package/dist/src/nile-grid-head-item/nile-grid-head-item.js +100 -0
  319. package/dist/src/nile-grid-head-item/nile-grid-head-item.js.map +1 -0
  320. package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.d.ts +10 -0
  321. package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.js +34 -0
  322. package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.js.map +1 -0
  323. package/dist/src/nile-grid-row/index.d.ts +1 -0
  324. package/dist/src/nile-grid-row/index.js +2 -0
  325. package/dist/src/nile-grid-row/index.js.map +1 -0
  326. package/dist/src/nile-grid-row/nile-grid-row.css.d.ts +12 -0
  327. package/dist/src/nile-grid-row/nile-grid-row.css.js +27 -0
  328. package/dist/src/nile-grid-row/nile-grid-row.css.js.map +1 -0
  329. package/dist/src/nile-grid-row/nile-grid-row.d.ts +29 -0
  330. package/dist/src/nile-grid-row/nile-grid-row.js +45 -0
  331. package/dist/src/nile-grid-row/nile-grid-row.js.map +1 -0
  332. package/dist/src/nile-hero/__snapshots__/nile-hero.test.snap.js +47 -0
  333. package/dist/src/nile-icon/__snapshots__/nile-icon.test.snap.js +16 -0
  334. package/dist/src/nile-inline-edit/nile-inline-edit-utils.d.ts +20 -0
  335. package/dist/src/nile-inline-edit/nile-inline-edit-utils.js +70 -0
  336. package/dist/src/nile-inline-edit/nile-inline-edit-utils.js.map +1 -0
  337. package/dist/src/nile-inline-edit/nile-inline-edit.d.ts +8 -0
  338. package/dist/src/nile-inline-edit/nile-inline-edit.js +47 -1
  339. package/dist/src/nile-inline-edit/nile-inline-edit.js.map +1 -1
  340. package/dist/src/nile-inline-sidebar/nile-inline-sidebar.css.js +2 -2
  341. package/dist/src/nile-inline-sidebar/nile-inline-sidebar.css.js.map +1 -1
  342. package/dist/src/nile-inline-sidebar/nile-inline-sidebar.js +3 -10
  343. package/dist/src/nile-inline-sidebar/nile-inline-sidebar.js.map +1 -1
  344. package/dist/src/nile-inline-sidebar-item/nile-inline-sidebar-item.d.ts +0 -1
  345. package/dist/src/nile-inline-sidebar-item/nile-inline-sidebar-item.js +0 -4
  346. package/dist/src/nile-inline-sidebar-item/nile-inline-sidebar-item.js.map +1 -1
  347. package/dist/src/nile-input/__snapshots__/nile-input.test.snap.js +75 -0
  348. package/dist/src/nile-menu/portal-manager.d.ts +39 -0
  349. package/dist/src/nile-menu/portal-manager.js +340 -0
  350. package/dist/src/nile-menu/portal-manager.js.map +1 -0
  351. package/dist/src/nile-menu/portal-utils.d.ts +21 -0
  352. package/dist/src/nile-menu/portal-utils.js +128 -0
  353. package/dist/src/nile-menu/portal-utils.js.map +1 -0
  354. package/dist/src/nile-popover/__snapshots__/nile-popover.test.snap.js +22 -0
  355. package/dist/src/nile-popover/popover-portal-handler.d.ts +21 -0
  356. package/dist/src/nile-popover/popover-portal-handler.js +106 -0
  357. package/dist/src/nile-popover/popover-portal-handler.js.map +1 -0
  358. package/dist/src/nile-portal-wrapper/index.d.ts +1 -0
  359. package/dist/src/nile-portal-wrapper/index.js +2 -0
  360. package/dist/src/nile-portal-wrapper/index.js.map +1 -0
  361. package/dist/src/nile-portal-wrapper/nile-portal-wrapper.d.ts +47 -0
  362. package/dist/src/nile-portal-wrapper/nile-portal-wrapper.js +451 -0
  363. package/dist/src/nile-portal-wrapper/nile-portal-wrapper.js.map +1 -0
  364. package/dist/src/nile-rich-text-editor/utils.d.ts +13 -0
  365. package/dist/src/nile-rich-text-editor/utils.js +538 -0
  366. package/dist/src/nile-rich-text-editor/utils.js.map +1 -0
  367. package/dist/src/nile-select/body-append-manager.d.ts +90 -0
  368. package/dist/src/nile-select/body-append-manager.js +298 -0
  369. package/dist/src/nile-select/body-append-manager.js.map +1 -0
  370. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.css.js +5 -3
  371. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.css.js.map +1 -1
  372. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.js +4 -4
  373. package/dist/src/nile-side-bar-expand/nile-side-bar-expand.js.map +1 -1
  374. package/dist/src/nile-side-bar-footer/nile-side-bar-footer.css.js +1 -0
  375. package/dist/src/nile-side-bar-footer/nile-side-bar-footer.css.js.map +1 -1
  376. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.js +3 -15
  377. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.js.map +1 -1
  378. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.d.ts +15 -9
  379. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.js +15 -36
  380. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.js.map +1 -1
  381. package/dist/src/nile-side-bar-group/nile-side-bar-group.css.js +2 -2
  382. package/dist/src/nile-side-bar-group/nile-side-bar-group.css.js.map +1 -1
  383. package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.css.js +46 -48
  384. package/dist/src/nile-side-bar-group-item/nile-side-bar-group-item.css.js.map +1 -1
  385. package/dist/src/nile-sidebar/index.d.ts +28 -0
  386. package/dist/src/nile-sidebar/index.js +116 -0
  387. package/dist/src/nile-sidebar/index.js.map +1 -0
  388. package/dist/src/nile-sidebar-menu/index.d.ts +1 -0
  389. package/dist/src/nile-sidebar-menu/index.js +2 -0
  390. package/dist/src/nile-sidebar-menu/index.js.map +1 -0
  391. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.css.d.ts +12 -0
  392. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.css.js +47 -0
  393. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.css.js.map +1 -0
  394. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.d.ts +37 -0
  395. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.js +84 -0
  396. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.js.map +1 -0
  397. package/dist/src/nile-sidebar-menu-items/index.d.ts +1 -0
  398. package/dist/src/nile-sidebar-menu-items/index.js +2 -0
  399. package/dist/src/nile-sidebar-menu-items/index.js.map +1 -0
  400. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.d.ts +12 -0
  401. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.js +45 -0
  402. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.js.map +1 -0
  403. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.d.ts +35 -0
  404. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.js +78 -0
  405. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.js.map +1 -0
  406. package/dist/src/nile-sidebar-wrapper/index.d.ts +1 -0
  407. package/dist/src/nile-sidebar-wrapper/index.js +2 -0
  408. package/dist/src/nile-sidebar-wrapper/index.js.map +1 -0
  409. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.d.ts +12 -0
  410. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.js +114 -0
  411. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.js.map +1 -0
  412. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.d.ts +35 -0
  413. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.js +89 -0
  414. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.js.map +1 -0
  415. package/dist/src/nile-table-body/virtual-scroll-helper.d.ts +9 -0
  416. package/dist/src/nile-table-body/virtual-scroll-helper.js +24 -0
  417. package/dist/src/nile-table-body/virtual-scroll-helper.js.map +1 -0
  418. package/dist/src/nile-virtual-select/body-append-helper.d.ts +16 -0
  419. package/dist/src/nile-virtual-select/body-append-helper.js +95 -0
  420. package/dist/src/nile-virtual-select/body-append-helper.js.map +1 -0
  421. package/dist/src/nile-virtual-select/group-manager.d.ts +32 -0
  422. package/dist/src/nile-virtual-select/group-manager.js +134 -0
  423. package/dist/src/nile-virtual-select/group-manager.js.map +1 -0
  424. package/dist/src/nile-virtual-select/portal-utils.d.ts +65 -0
  425. package/dist/src/nile-virtual-select/portal-utils.js +376 -0
  426. package/dist/src/nile-virtual-select/portal-utils.js.map +1 -0
  427. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.d.ts +273 -0
  428. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js +1305 -0
  429. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js.map +1 -0
  430. package/dist/src/nile-virtual-select/virtualizer-error-handler.d.ts +21 -0
  431. package/dist/src/nile-virtual-select/virtualizer-error-handler.js +56 -0
  432. package/dist/src/nile-virtual-select/virtualizer-error-handler.js.map +1 -0
  433. package/dist/src/nile-virtual-select-disabled/index.d.ts +1 -0
  434. package/dist/src/nile-virtual-select-disabled/index.js +2 -0
  435. package/dist/src/nile-virtual-select-disabled/index.js.map +1 -0
  436. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.css.d.ts +12 -0
  437. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.css.js +538 -0
  438. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.css.js.map +1 -0
  439. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.d.ts +299 -0
  440. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.js +1441 -0
  441. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.js.map +1 -0
  442. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.test.d.ts +7 -0
  443. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.test.js +631 -0
  444. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.test.js.map +1 -0
  445. package/dist/src/nile-virtual-select-disabled/portal-manager.d.ts +45 -0
  446. package/dist/src/nile-virtual-select-disabled/portal-manager.js +333 -0
  447. package/dist/src/nile-virtual-select-disabled/portal-manager.js.map +1 -0
  448. package/dist/src/nile-virtual-select-disabled/renderer.d.ts +16 -0
  449. package/dist/src/nile-virtual-select-disabled/renderer.js +79 -0
  450. package/dist/src/nile-virtual-select-disabled/renderer.js.map +1 -0
  451. package/dist/src/nile-virtual-select-disabled/search-manager.d.ts +12 -0
  452. package/dist/src/nile-virtual-select-disabled/search-manager.js +40 -0
  453. package/dist/src/nile-virtual-select-disabled/search-manager.js.map +1 -0
  454. package/dist/src/nile-virtual-select-disabled/selection-manager.d.ts +12 -0
  455. package/dist/src/nile-virtual-select-disabled/selection-manager.js +64 -0
  456. package/dist/src/nile-virtual-select-disabled/selection-manager.js.map +1 -0
  457. package/dist/src/nile-virtual-select-disabled/types.d.ts +50 -0
  458. package/dist/src/nile-virtual-select-disabled/types.js +8 -0
  459. package/dist/src/nile-virtual-select-disabled/types.js.map +1 -0
  460. package/dist/src/nile-virtual-table-body/index.d.ts +2 -0
  461. package/dist/src/nile-virtual-table-body/index.js +3 -0
  462. package/dist/src/nile-virtual-table-body/index.js.map +1 -0
  463. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.d.ts +1 -0
  464. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js +44 -0
  465. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js.map +1 -0
  466. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.d.ts +50 -0
  467. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js +135 -0
  468. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js.map +1 -0
  469. package/dist/src/nile-virtual-table-body/renderer.d.ts +16 -0
  470. package/dist/src/nile-virtual-table-body/renderer.js +49 -0
  471. package/dist/src/nile-virtual-table-body/renderer.js.map +1 -0
  472. package/dist/src/utilities/stepper-utils.d.ts +71 -0
  473. package/dist/src/utilities/stepper-utils.js +108 -0
  474. package/dist/src/utilities/stepper-utils.js.map +1 -0
  475. package/dist/src/version.js +1 -1
  476. package/dist/src/version.js.map +1 -1
  477. package/dist/tsconfig.tsbuildinfo +1 -1
  478. package/package.json +2 -2
  479. package/src/nile-inline-edit/nile-inline-edit-utils.ts +94 -0
  480. package/src/nile-inline-edit/nile-inline-edit.ts +59 -1
  481. package/src/nile-inline-sidebar/nile-inline-sidebar.css.ts +2 -2
  482. package/src/nile-inline-sidebar/nile-inline-sidebar.ts +5 -16
  483. package/src/nile-inline-sidebar-item/nile-inline-sidebar-item.ts +0 -1
  484. package/src/nile-side-bar-expand/nile-side-bar-expand.css.ts +5 -3
  485. package/src/nile-side-bar-expand/nile-side-bar-expand.ts +4 -4
  486. package/src/nile-side-bar-footer/nile-side-bar-footer.css.ts +1 -0
  487. package/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.ts +3 -15
  488. package/src/nile-side-bar-footer-item/nile-side-bar-footer-item.ts +16 -42
  489. package/src/nile-side-bar-group/nile-side-bar-group.css.ts +2 -2
  490. package/src/nile-side-bar-group-item/nile-side-bar-group-item.css.ts +47 -49
  491. package/vscode-html-custom-data.json +8 -30
  492. package/dist/axe.min-140df6c2.cjs.js +0 -2
  493. package/dist/axe.min-140df6c2.cjs.js.map +0 -1
  494. package/dist/axe.min-591c52c3.esm.js +0 -1
  495. package/dist/fixture-f575d0df.cjs.js.map +0 -1
  496. package/dist/floating-ui.dom-70d5643f.esm.js +0 -1
  497. package/dist/floating-ui.dom-f19772dc.cjs.js +0 -2
  498. package/dist/floating-ui.dom-f19772dc.cjs.js.map +0 -1
  499. package/dist/flow-3e83b6f4.esm.js +0 -17
  500. package/dist/flow-ca47f938.cjs.js +0 -14
  501. package/dist/flow-ca47f938.cjs.js.map +0 -1
  502. package/dist/nile-light-tooltip/index.cjs.js +0 -2
  503. package/dist/nile-light-tooltip/index.esm.js +0 -1
  504. package/dist/nile-light-tooltip/nile-light-tooltip.cjs.js +0 -2
  505. package/dist/nile-light-tooltip/nile-light-tooltip.cjs.js.map +0 -1
  506. package/dist/nile-light-tooltip/nile-light-tooltip.css.cjs.js +0 -2
  507. package/dist/nile-light-tooltip/nile-light-tooltip.css.cjs.js.map +0 -1
  508. package/dist/nile-light-tooltip/nile-light-tooltip.css.esm.js +0 -5
  509. package/dist/nile-light-tooltip/nile-light-tooltip.esm.js +0 -1
  510. package/dist/nile-light-tooltip/utils.cjs.js +0 -2
  511. package/dist/nile-light-tooltip/utils.cjs.js.map +0 -1
  512. package/dist/nile-light-tooltip/utils.esm.js +0 -1
  513. package/dist/scopedElementsWrapper-067597d2.cjs.js +0 -6
  514. package/dist/scopedElementsWrapper-067597d2.cjs.js.map +0 -1
  515. package/dist/scopedElementsWrapper-4374e962.esm.js +0 -7
  516. package/dist/sinon-esm-283dcc9b.cjs.js +0 -2
  517. package/dist/sinon-esm-283dcc9b.cjs.js.map +0 -1
  518. package/dist/sinon-esm-abe9b0ec.esm.js +0 -1
  519. package/dist/src/nile-light-tooltip/index.d.ts +0 -1
  520. package/dist/src/nile-light-tooltip/index.js +0 -2
  521. package/dist/src/nile-light-tooltip/index.js.map +0 -1
  522. package/dist/src/nile-light-tooltip/nile-light-tooltip.css.d.ts +0 -12
  523. package/dist/src/nile-light-tooltip/nile-light-tooltip.css.js +0 -17
  524. package/dist/src/nile-light-tooltip/nile-light-tooltip.css.js.map +0 -1
  525. package/dist/src/nile-light-tooltip/nile-light-tooltip.d.ts +0 -79
  526. package/dist/src/nile-light-tooltip/nile-light-tooltip.js +0 -350
  527. package/dist/src/nile-light-tooltip/nile-light-tooltip.js.map +0 -1
  528. package/dist/src/nile-light-tooltip/nile-lite-tooltip.css.d.ts +0 -12
  529. package/dist/src/nile-light-tooltip/nile-lite-tooltip.css.js +0 -17
  530. package/dist/src/nile-light-tooltip/nile-lite-tooltip.css.js.map +0 -1
  531. package/dist/src/nile-light-tooltip/nile-lite-tooltip.d.ts +0 -79
  532. package/dist/src/nile-light-tooltip/nile-lite-tooltip.js +0 -350
  533. package/dist/src/nile-light-tooltip/nile-lite-tooltip.js.map +0 -1
  534. package/dist/src/nile-light-tooltip/utils.d.ts +0 -2
  535. package/dist/src/nile-light-tooltip/utils.js +0 -29
  536. package/dist/src/nile-light-tooltip/utils.js.map +0 -1
  537. package/dist/virtualize-73f68d08.esm.js +0 -22
  538. package/dist/virtualize-eb33a9a0.cjs.js +0 -18
  539. package/dist/virtualize-eb33a9a0.cjs.js.map +0 -1
  540. /package/dist/{nile-light-tooltip → nile-grid-body}/index.cjs.js.map +0 -0
@@ -112,9 +112,6 @@ let NileInlineSidebar = class NileInlineSidebar extends NileElement {
112
112
  if (!this.sidebarItems?.length)
113
113
  return null;
114
114
  return this.sidebarItems.map((item, index) => {
115
- const shouldShowTooltip = item.tooltip;
116
- const isTruncated = item.scrollWidth > item.clientWidth ||
117
- item.scrollHeight > item.clientHeight;
118
115
  const content = html `
119
116
  <nile-side-bar-action-menu-item
120
117
  ?disabled=${item.hasAttribute('disabled')}
@@ -124,15 +121,11 @@ let NileInlineSidebar = class NileInlineSidebar extends NileElement {
124
121
  ${item.textContent}
125
122
  </nile-side-bar-action-menu-item>
126
123
  `;
127
- return shouldShowTooltip || isTruncated
124
+ return this.showTooltip
128
125
  ? html `
129
- <nile-inline-tooltip
130
- content=${item.textContent?.trim() || ''}
131
- hoist
132
- placement="right"
133
- >
126
+ <nile-tooltip content=${item.textContent} hoist placement="right">
134
127
  ${content}
135
- </nile-inline-tooltip>
128
+ </nile-tooltip>
136
129
  `
137
130
  : content;
138
131
  });
@@ -1 +1 @@
1
- {"version":3,"file":"nile-inline-sidebar.js","sourceRoot":"","sources":["../../../src/nile-inline-sidebar/nile-inline-sidebar.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright Aquera Inc 2025\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { html, CSSResultArray, TemplateResult } from 'lit';\nimport { customElement, property, query, state } from 'lit/decorators.js';\nimport { styles } from './nile-inline-sidebar.css';\nimport NileElement from '../internal/nile-element';\n\n/**\n * Nile inline sidebar component.\n *\n * @tag nile-inline-sidebar\n */\n@customElement('nile-inline-sidebar')\nexport class NileInlineSidebar extends NileElement {\n @property({ type: Boolean, reflect: true }) collapsed = false;\n\n @property({ type: Boolean, reflect: true, attribute: true }) fixed = false;\n\n @property({ type: Boolean, reflect: true }) showTooltip = false;\n\n @state() private activeIndex: number = -1;\n\n @query('slot') private defaultSlot!: HTMLSlotElement;\n\n private mutationObserver?: MutationObserver;\n\n public static get styles(): CSSResultArray {\n return [styles];\n }\n\n private get sidebarItems(): HTMLElement[] {\n if (!this.defaultSlot) return [];\n const assigned = this.defaultSlot.assignedElements({ flatten: true });\n const items = assigned.flatMap(el =>\n el.tagName.toLowerCase() === 'nile-inline-sidebar-item'\n ? [el]\n : Array.from(el.querySelectorAll('nile-inline-sidebar-item'))\n );\n return items as HTMLElement[];\n }\n\n connectedCallback() {\n super.connectedCallback();\n this.addEventListener('nile-click', this.handleItemSelect);\n this.mutationObserver = new MutationObserver(() =>\n this.syncActiveFromItems()\n );\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n this.mutationObserver?.disconnect();\n this.removeEventListener('nile-click', this.handleItemSelect);\n }\n\n firstUpdated() {\n this.observeSidebarItems();\n this.syncActiveFromItems();\n\n if (this.fixed) {\n this.collapsed = false;\n }\n }\n\n private observeSidebarItems() {\n if (!this.sidebarItems?.length || !this.mutationObserver) return;\n this.sidebarItems.forEach(item =>\n this.mutationObserver!.observe(item, {\n attributes: true,\n attributeFilter: ['active'],\n })\n );\n }\n\n private syncActiveFromItems() {\n if (!this.sidebarItems?.length) return;\n const activeIndex = this.sidebarItems.findIndex(item =>\n item.hasAttribute('active')\n );\n if (activeIndex !== -1 && activeIndex !== this.activeIndex) {\n this.activeIndex = activeIndex;\n this.requestUpdate();\n }\n }\n\n private handleItemSelect = (event: CustomEvent) => {\n const selectedItem = event.detail.item as HTMLElement;\n const index = this.sidebarItems.indexOf(selectedItem);\n\n this.sidebarItems.forEach(\n (item, i) => ((item as any).active = i === index)\n );\n this.activeIndex = index;\n\n this.dispatchEvent(\n new CustomEvent('nile-change', {\n detail: { selectedItem, index },\n bubbles: true,\n composed: true,\n })\n );\n\n this.requestUpdate();\n };\n\n private toggleCollapse() {\n if (this.fixed) return;\n this.collapsed = !this.collapsed;\n console.log('[Sidebar] Toggled collapse →', this.collapsed);\n\n this.dispatchEvent(\n new CustomEvent('nile-toggle', {\n detail: { collapsed: this.collapsed },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private handleMenuItemClick(index: number) {\n const selectedItem = this.sidebarItems[index];\n if (!selectedItem || selectedItem.hasAttribute('disabled')) return;\n\n this.sidebarItems.forEach(\n (item, i) => ((item as any).active = i === index)\n );\n this.activeIndex = index;\n const text = selectedItem.textContent?.trim() || '';\n const href = (selectedItem as any).href;\n this.dispatchEvent(\n new CustomEvent('nile-click', {\n detail: { item: selectedItem, href, text },\n bubbles: true,\n composed: true,\n })\n );\n\n if (href) window.location.href = href;\n\n this.requestUpdate();\n }\n\n private get menuItemsTemplate() {\n if (!this.sidebarItems?.length) return null;\n \n return this.sidebarItems.map((item, index) => {\n const shouldShowTooltip = (item as any).tooltip;\n const isTruncated =\n item.scrollWidth > item.clientWidth ||\n item.scrollHeight > item.clientHeight;\n \n const content = html`\n <nile-side-bar-action-menu-item\n ?disabled=${item.hasAttribute('disabled')}\n ?active=${this.activeIndex === index}\n @click=${() => this.handleMenuItemClick(index)}\n >\n ${item.textContent}\n </nile-side-bar-action-menu-item>\n `;\n return shouldShowTooltip || isTruncated\n ? html`\n <nile-inline-tooltip\n content=${item.textContent?.trim() || ''}\n hoist\n placement=\"right\"\n >\n ${content}\n </nile-inline-tooltip>\n `\n : content;\n });\n }\n \n \n \n\n public render(): TemplateResult {\n return html`\n <div class=\"sidebar\" part=\"base\">\n <div class=\"sidebar-header\" part=\"header\">\n ${!this.fixed\n ? this.collapsed\n ? html`\n <nile-side-bar-action\n class=\"toggle-action\"\n placement=\"bottom-start\"\n hoist\n open\n triggerDropdown=\"hover\"\n >\n <nile-button\n slot=\"trigger\"\n class=\"toggle-btn\"\n variant=\"tertiary\"\n @click=${this.toggleCollapse}\n >\n <nile-icon name=\"menu_close\"></nile-icon>\n </nile-button>\n <nile-side-bar-action-menu>\n ${this.menuItemsTemplate}\n </nile-side-bar-action-menu>\n </nile-side-bar-action>\n `\n : html`\n <nile-button\n class=\"toggle-btn\"\n variant=\"tertiary\"\n @click=${this.toggleCollapse}\n >\n <nile-icon name=\"menu_open\"></nile-icon>\n </nile-button>\n `\n : null}\n </div>\n\n <nav\n class=\"sidebar-nav\"\n style=${this.collapsed ? 'display:none;' : ''}\n part=\"nav-items\"\n >\n <slot\n @slotchange=${() => {\n this.requestUpdate();\n this.observeSidebarItems();\n this.syncActiveFromItems();\n }}\n ></slot>\n </nav>\n </div>\n `;\n }\n}\n\nexport default NileInlineSidebar;\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nile-inline-sidebar': NileInlineSidebar;\n }\n}\n"]}
1
+ {"version":3,"file":"nile-inline-sidebar.js","sourceRoot":"","sources":["../../../src/nile-inline-sidebar/nile-inline-sidebar.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright Aquera Inc 2025\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { html, CSSResultArray, TemplateResult } from 'lit';\nimport { customElement, property, query, state } from 'lit/decorators.js';\nimport { styles } from './nile-inline-sidebar.css';\nimport NileElement from '../internal/nile-element';\n\n/**\n * Nile inline sidebar component.\n *\n * @tag nile-inline-sidebar\n */\n@customElement('nile-inline-sidebar')\nexport class NileInlineSidebar extends NileElement {\n @property({ type: Boolean, reflect: true }) collapsed = false;\n\n @property({ type: Boolean, reflect: true, attribute: true }) fixed = false;\n\n @property({ type: Boolean, reflect: true }) showTooltip = false;\n\n @state() private activeIndex: number = -1;\n\n @query('slot') private defaultSlot!: HTMLSlotElement;\n\n private mutationObserver?: MutationObserver;\n\n public static get styles(): CSSResultArray {\n return [styles];\n }\n\n private get sidebarItems(): HTMLElement[] {\n if (!this.defaultSlot) return [];\n const assigned = this.defaultSlot.assignedElements({ flatten: true });\n const items = assigned.flatMap(el =>\n el.tagName.toLowerCase() === 'nile-inline-sidebar-item'\n ? [el]\n : Array.from(el.querySelectorAll('nile-inline-sidebar-item'))\n );\n return items as HTMLElement[];\n }\n\n connectedCallback() {\n super.connectedCallback();\n this.addEventListener('nile-click', this.handleItemSelect);\n this.mutationObserver = new MutationObserver(() =>\n this.syncActiveFromItems()\n );\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n this.mutationObserver?.disconnect();\n this.removeEventListener('nile-click', this.handleItemSelect);\n }\n\n firstUpdated() {\n this.observeSidebarItems();\n this.syncActiveFromItems();\n\n if (this.fixed) {\n this.collapsed = false;\n }\n }\n\n private observeSidebarItems() {\n if (!this.sidebarItems?.length || !this.mutationObserver) return;\n this.sidebarItems.forEach(item =>\n this.mutationObserver!.observe(item, {\n attributes: true,\n attributeFilter: ['active'],\n })\n );\n }\n\n private syncActiveFromItems() {\n if (!this.sidebarItems?.length) return;\n const activeIndex = this.sidebarItems.findIndex(item =>\n item.hasAttribute('active')\n );\n if (activeIndex !== -1 && activeIndex !== this.activeIndex) {\n this.activeIndex = activeIndex;\n this.requestUpdate();\n }\n }\n\n private handleItemSelect = (event: CustomEvent) => {\n const selectedItem = event.detail.item as HTMLElement;\n const index = this.sidebarItems.indexOf(selectedItem);\n\n this.sidebarItems.forEach(\n (item, i) => ((item as any).active = i === index)\n );\n this.activeIndex = index;\n\n this.dispatchEvent(\n new CustomEvent('nile-change', {\n detail: { selectedItem, index },\n bubbles: true,\n composed: true,\n })\n );\n\n this.requestUpdate();\n };\n\n private toggleCollapse() {\n if (this.fixed) return;\n this.collapsed = !this.collapsed;\n console.log('[Sidebar] Toggled collapse →', this.collapsed);\n\n this.dispatchEvent(\n new CustomEvent('nile-toggle', {\n detail: { collapsed: this.collapsed },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private handleMenuItemClick(index: number) {\n const selectedItem = this.sidebarItems[index];\n if (!selectedItem || selectedItem.hasAttribute('disabled')) return;\n\n this.sidebarItems.forEach(\n (item, i) => ((item as any).active = i === index)\n );\n this.activeIndex = index;\n const text = selectedItem.textContent?.trim() || '';\n const href = (selectedItem as any).href;\n this.dispatchEvent(\n new CustomEvent('nile-click', {\n detail: { item: selectedItem, href, text },\n bubbles: true,\n composed: true,\n })\n );\n\n if (href) window.location.href = href;\n\n this.requestUpdate();\n }\n\n private get menuItemsTemplate() {\n if (!this.sidebarItems?.length) return null;\n\n return this.sidebarItems.map((item, index) => {\n const content = html`\n <nile-side-bar-action-menu-item\n ?disabled=${item.hasAttribute('disabled')}\n ?active=${this.activeIndex === index}\n @click=${() => this.handleMenuItemClick(index)}\n >\n ${item.textContent}\n </nile-side-bar-action-menu-item>\n `;\n\n return this.showTooltip\n ? html`\n <nile-tooltip content=${item.textContent} hoist placement=\"right\">\n ${content}\n </nile-tooltip>\n `\n : content;\n });\n }\n\n public render(): TemplateResult {\n return html`\n <div class=\"sidebar\" part=\"base\">\n <div class=\"sidebar-header\" part=\"header\">\n ${!this.fixed\n ? this.collapsed\n ? html`\n <nile-side-bar-action\n class=\"toggle-action\"\n placement=\"bottom-start\"\n hoist\n open\n triggerDropdown=\"hover\"\n >\n <nile-button\n slot=\"trigger\"\n class=\"toggle-btn\"\n variant=\"tertiary\"\n @click=${this.toggleCollapse}\n >\n <nile-icon name=\"menu_close\"></nile-icon>\n </nile-button>\n <nile-side-bar-action-menu>\n ${this.menuItemsTemplate}\n </nile-side-bar-action-menu>\n </nile-side-bar-action>\n `\n : html`\n <nile-button\n class=\"toggle-btn\"\n variant=\"tertiary\"\n @click=${this.toggleCollapse}\n >\n <nile-icon name=\"menu_open\"></nile-icon>\n </nile-button>\n `\n : null}\n </div>\n\n <nav\n class=\"sidebar-nav\"\n style=${this.collapsed ? 'display:none;' : ''}\n part=\"nav-items\"\n >\n <slot\n @slotchange=${() => {\n this.requestUpdate();\n this.observeSidebarItems();\n this.syncActiveFromItems();\n }}\n ></slot>\n </nav>\n </div>\n `;\n }\n}\n\nexport default NileInlineSidebar;\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nile-inline-sidebar': NileInlineSidebar;\n }\n}\n"]}
@@ -24,7 +24,6 @@ export declare class NileInlineSidebarItem extends NileElement {
24
24
  active: boolean;
25
25
  disabled: boolean;
26
26
  href?: string;
27
- tooltip: boolean;
28
27
  static get styles(): CSSResultArray;
29
28
  private handleClick;
30
29
  render(): TemplateResult;
@@ -28,7 +28,6 @@ let NileInlineSidebarItem = class NileInlineSidebarItem extends NileElement {
28
28
  super(...arguments);
29
29
  this.active = false;
30
30
  this.disabled = false;
31
- this.tooltip = false;
32
31
  }
33
32
  static get styles() {
34
33
  return [styles];
@@ -73,9 +72,6 @@ __decorate([
73
72
  __decorate([
74
73
  property({ type: String })
75
74
  ], NileInlineSidebarItem.prototype, "href", void 0);
76
- __decorate([
77
- property({ type: Boolean, reflect: true })
78
- ], NileInlineSidebarItem.prototype, "tooltip", void 0);
79
75
  NileInlineSidebarItem = __decorate([
80
76
  customElement('nile-inline-sidebar-item')
81
77
  ], NileInlineSidebarItem);
@@ -1 +1 @@
1
- {"version":3,"file":"nile-inline-sidebar-item.js","sourceRoot":"","sources":["../../../src/nile-inline-sidebar-item/nile-inline-sidebar-item.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;;AAEH,OAAO,EAAE,IAAI,EAAkC,MAAM,KAAK,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AACxD,OAAO,WAAW,MAAM,0BAA0B,CAAC;AAEnD;;;;;;;;;;;;;GAaG;AAEI,IAAM,qBAAqB,GAA3B,MAAM,qBAAsB,SAAQ,WAAW;IAA/C;;QACuC,WAAM,GAAG,KAAK,CAAC;QACf,aAAQ,GAAG,KAAK,CAAC;QAEjB,YAAO,GAAG,KAAK,CAAC;IA4C9D,CAAC;IA1CQ,MAAM,KAAK,MAAM;QACtB,OAAO,CAAC,MAAM,CAAC,CAAC;IAClB,CAAC;IAEO,WAAW,CAAC,CAAQ;QAC1B,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;QACnD,IAAI,MAAM,EAAE,CAAC;YACX,MAAM,QAAQ,GAAG,MAAM,CAAC,gBAAgB,CAAC,0BAA0B,CAAC,CAAC;YACrE,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAE,IAA8B,CAAC,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC,CAAC;QACrF,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAE5C,IAAI,CAAC,aAAa,CAChB,IAAI,WAAW,CAAC,YAAY,EAAE;YAC5B,MAAM,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE;YAC7C,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,IAAI;SACf,CAAC,CACH,CAAC;QAEF,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACnC,CAAC;IACH,CAAC;IAGM,MAAM;QACX,OAAO,IAAI,CAAA;iCACkB,IAAI,CAAC,WAAW;UACvC,IAAI,CAAC,IAAI;YACT,CAAC,CAAC,IAAI,CAAA,WAAW,IAAI,CAAC,IAAI,WAAW,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,oBAAoB;YACzF,CAAC,CAAC,IAAI,CAAA,eAAe;;KAE1B,CAAC;IACJ,CAAC;CACF,CAAA;AA/C6C;IAA3C,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;qDAAgB;AACf;IAA3C,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;uDAAkB;AACjC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAAe;AACE;IAA3C,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;sDAAiB;AAJjD,qBAAqB;IADjC,aAAa,CAAC,0BAA0B,CAAC;GAC7B,qBAAqB,CAgDjC;;AAED,eAAe,qBAAqB,CAAC","sourcesContent":["/**\n * Copyright Aquera Inc 2025\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { html, CSSResultArray, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styles } from './nile-inline-sidebar-item.css';\nimport NileElement from '../internal/nile-element';\n\n/**\n * Nile inline sidebar item.\n *\n * @tag nile-inlinesidebar-item\n *\n * @attr active - Marks the item as active (selected).\n * @attr disabled - Marks the item as disabled (non-interactive).\n * @attr href - Optional URL to navigate to when the item is clicked.\n *\n * @slot - Default slot for the item text or content.\n *\n * @fires nile-select - Emitted when the item is clicked (not disabled).\n * detail: { item: this, href?: string }\n */\n@customElement('nile-inline-sidebar-item')\nexport class NileInlineSidebarItem extends NileElement {\n @property({ type: Boolean, reflect: true }) active = false;\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: String }) href?: string;\n @property({ type: Boolean, reflect: true }) tooltip = false;\n\n public static get styles(): CSSResultArray {\n return [styles];\n }\n\n private handleClick(e: Event) {\n if (this.disabled) {\n e.preventDefault();\n e.stopPropagation();\n return;\n }\n \n const parent = this.closest('nile-inline-sidebar');\n if (parent) {\n const allItems = parent.querySelectorAll('nile-inline-sidebar-item');\n allItems.forEach((item) => (item as NileInlineSidebarItem).active = item === this);\n }\n \n const text = this.textContent?.trim() || '';\n \n this.dispatchEvent(\n new CustomEvent('nile-click', {\n detail: { item: this, href: this.href, text },\n bubbles: true,\n composed: true,\n }),\n );\n \n if (this.href) {\n window.location.href = this.href;\n }\n }\n \n\n public render(): TemplateResult {\n return html`\n <div class=\"item\" @click=${this.handleClick} role=\"button\" tabindex=\"0\">\n ${this.href\n ? html`<a href=${this.href} @click=${(e: Event) => e.preventDefault()}><slot></slot></a>`\n : html`<slot></slot>`}\n </div>\n `;\n }\n}\n\nexport default NileInlineSidebarItem;\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nile-inline-sidebar-item': NileInlineSidebarItem;\n }\n}\n"]}
1
+ {"version":3,"file":"nile-inline-sidebar-item.js","sourceRoot":"","sources":["../../../src/nile-inline-sidebar-item/nile-inline-sidebar-item.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;;AAEH,OAAO,EAAE,IAAI,EAAkC,MAAM,KAAK,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AACxD,OAAO,WAAW,MAAM,0BAA0B,CAAC;AAEnD;;;;;;;;;;;;;GAaG;AAEI,IAAM,qBAAqB,GAA3B,MAAM,qBAAsB,SAAQ,WAAW;IAA/C;;QACuC,WAAM,GAAG,KAAK,CAAC;QACf,aAAQ,GAAG,KAAK,CAAC;IA6C/D,CAAC;IA1CQ,MAAM,KAAK,MAAM;QACtB,OAAO,CAAC,MAAM,CAAC,CAAC;IAClB,CAAC;IAEO,WAAW,CAAC,CAAQ;QAC1B,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;QACnD,IAAI,MAAM,EAAE,CAAC;YACX,MAAM,QAAQ,GAAG,MAAM,CAAC,gBAAgB,CAAC,0BAA0B,CAAC,CAAC;YACrE,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAE,IAA8B,CAAC,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC,CAAC;QACrF,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAE5C,IAAI,CAAC,aAAa,CAChB,IAAI,WAAW,CAAC,YAAY,EAAE;YAC5B,MAAM,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE;YAC7C,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,IAAI;SACf,CAAC,CACH,CAAC;QAEF,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACnC,CAAC;IACH,CAAC;IAGM,MAAM;QACX,OAAO,IAAI,CAAA;iCACkB,IAAI,CAAC,WAAW;UACvC,IAAI,CAAC,IAAI;YACT,CAAC,CAAC,IAAI,CAAA,WAAW,IAAI,CAAC,IAAI,WAAW,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,oBAAoB;YACzF,CAAC,CAAC,IAAI,CAAA,eAAe;;KAE1B,CAAC;IACJ,CAAC;CACF,CAAA;AA9C6C;IAA3C,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;qDAAgB;AACf;IAA3C,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;uDAAkB;AACjC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAAe;AAH/B,qBAAqB;IADjC,aAAa,CAAC,0BAA0B,CAAC;GAC7B,qBAAqB,CA+CjC;;AAED,eAAe,qBAAqB,CAAC","sourcesContent":["/**\n * Copyright Aquera Inc 2025\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { html, CSSResultArray, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styles } from './nile-inline-sidebar-item.css';\nimport NileElement from '../internal/nile-element';\n\n/**\n * Nile inline sidebar item.\n *\n * @tag nile-inlinesidebar-item\n *\n * @attr active - Marks the item as active (selected).\n * @attr disabled - Marks the item as disabled (non-interactive).\n * @attr href - Optional URL to navigate to when the item is clicked.\n *\n * @slot - Default slot for the item text or content.\n *\n * @fires nile-select - Emitted when the item is clicked (not disabled).\n * detail: { item: this, href?: string }\n */\n@customElement('nile-inline-sidebar-item')\nexport class NileInlineSidebarItem extends NileElement {\n @property({ type: Boolean, reflect: true }) active = false;\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: String }) href?: string;\n\n public static get styles(): CSSResultArray {\n return [styles];\n }\n\n private handleClick(e: Event) {\n if (this.disabled) {\n e.preventDefault();\n e.stopPropagation();\n return;\n }\n \n const parent = this.closest('nile-inline-sidebar');\n if (parent) {\n const allItems = parent.querySelectorAll('nile-inline-sidebar-item');\n allItems.forEach((item) => (item as NileInlineSidebarItem).active = item === this);\n }\n \n const text = this.textContent?.trim() || '';\n \n this.dispatchEvent(\n new CustomEvent('nile-click', {\n detail: { item: this, href: this.href, text },\n bubbles: true,\n composed: true,\n }),\n );\n \n if (this.href) {\n window.location.href = this.href;\n }\n }\n \n\n public render(): TemplateResult {\n return html`\n <div class=\"item\" @click=${this.handleClick} role=\"button\" tabindex=\"0\">\n ${this.href\n ? html`<a href=${this.href} @click=${(e: Event) => e.preventDefault()}><slot></slot></a>`\n : html`<slot></slot>`}\n </div>\n `;\n }\n}\n\nexport default NileInlineSidebarItem;\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nile-inline-sidebar-item': NileInlineSidebarItem;\n }\n}\n"]}
@@ -0,0 +1,75 @@
1
+ /* @web/test-runner snapshot v1 */
2
+ export const snapshots = {};
3
+
4
+ snapshots["nile-input renders correctly"] =
5
+ `<div
6
+ class="form-control form-control--has-label form-control--medium"
7
+ part="form-control"
8
+ >
9
+ <label
10
+ aria-hidden="false"
11
+ class="form-control__label"
12
+ for="input"
13
+ part="form-control-label"
14
+ >
15
+ <slot name="label">
16
+ Test Label
17
+ </slot>
18
+ </label>
19
+ <div
20
+ class="form-control-input"
21
+ part="form-control-input"
22
+ >
23
+ <nile-popup
24
+ distance="5"
25
+ exportparts="input"
26
+ placement="bottom-start"
27
+ strategy="fixed"
28
+ >
29
+ <div
30
+ class="input input--empty input--medium input--standard"
31
+ part="base"
32
+ slot="anchor"
33
+ >
34
+ <slot
35
+ class="input__prefix"
36
+ name="prefix"
37
+ part="prefix"
38
+ >
39
+ </slot>
40
+ <input
41
+ aria-describedby="help-text"
42
+ autocomplete="off"
43
+ class="input__control"
44
+ id="input"
45
+ name=""
46
+ part="input"
47
+ placeholder=""
48
+ spellcheck="true"
49
+ title=""
50
+ type="text"
51
+ >
52
+ <slot
53
+ class="input__suffix"
54
+ name="suffix"
55
+ part="suffix"
56
+ >
57
+ </slot>
58
+ </div>
59
+ <div class="input__non-printable">
60
+ Non-printable character detected.
61
+ <nile-badge
62
+ class="input__remove-non-printable"
63
+ variant="error"
64
+ >
65
+ Remove All
66
+ </nile-badge>
67
+ <div class="input__srtiked-text-container">
68
+ </div>
69
+ </div>
70
+ </nile-popup>
71
+ </div>
72
+ </div>
73
+ `;
74
+ /* end snapshot nile-input renders correctly */
75
+
@@ -0,0 +1,39 @@
1
+ import { type Placement, type MiddlewareData } from '@floating-ui/dom';
2
+ export declare class MenuPortalManager {
3
+ private portalContainer;
4
+ private originalMenuParent;
5
+ private measuredMenuHeight;
6
+ private component;
7
+ private clonedMenu;
8
+ private cleanupAutoUpdate;
9
+ private currentPlacement;
10
+ private currentMiddlewareData;
11
+ constructor(component: any);
12
+ private createPortalAppendContainer;
13
+ positionPortalAppend(): void;
14
+ private measureMenuHeight;
15
+ private computeFloatingUIPosition;
16
+ private calculateFloatingUIPosition;
17
+ private createFloatingUIMiddleware;
18
+ private handleSizeMiddleware;
19
+ private createCustomPlatform;
20
+ private applyFloatingUIPosition;
21
+ private fallbackPositioning;
22
+ private calculateAndSetAutoSizeProperties;
23
+ updatePortalAppendPosition(): void;
24
+ handleWindowResize(): void;
25
+ private setupAutoUpdatePositioning;
26
+ private cleanupAutoUpdatePositioning;
27
+ private injectStylesToDocument;
28
+ private adoptStylesToPortalAppend;
29
+ setupPortalAppend(): void;
30
+ private findParentContainer;
31
+ private setupPortalEventListeners;
32
+ cleanupPortalAppend(): void;
33
+ get portalContainerElement(): HTMLElement | null;
34
+ resetMeasuredHeight(): void;
35
+ forceReposition(): void;
36
+ getCurrentPlacement(): Placement;
37
+ getCurrentMiddlewareData(): MiddlewareData | null;
38
+ isUsingFloatingUI(): boolean;
39
+ }
@@ -0,0 +1,340 @@
1
+ import { autoUpdate, computePosition, flip, offset, shift, size, platform } from '@floating-ui/dom';
2
+ import { PortalUtils } from './portal-utils';
3
+ export class MenuPortalManager {
4
+ constructor(component) {
5
+ this.portalContainer = null;
6
+ this.originalMenuParent = null;
7
+ this.measuredMenuHeight = null;
8
+ this.clonedMenu = null;
9
+ this.cleanupAutoUpdate = null;
10
+ this.currentPlacement = 'bottom';
11
+ this.currentMiddlewareData = null;
12
+ this.component = component;
13
+ }
14
+ createPortalAppendContainer() {
15
+ const container = document.createElement('div');
16
+ container.style.position = 'absolute';
17
+ container.style.zIndex = '9999';
18
+ container.style.pointerEvents = 'none';
19
+ container.className = 'nile-menu-portal-append';
20
+ return container;
21
+ }
22
+ positionPortalAppend() {
23
+ if (!this.portalContainer)
24
+ return;
25
+ this.measureMenuHeight();
26
+ this.computeFloatingUIPosition();
27
+ }
28
+ measureMenuHeight() {
29
+ if (this.measuredMenuHeight || !this.portalContainer)
30
+ return;
31
+ this.portalContainer.style.position = 'absolute';
32
+ this.portalContainer.style.visibility = 'hidden';
33
+ this.portalContainer.style.top = '0px';
34
+ this.portalContainer.style.left = '0px';
35
+ this.portalContainer.offsetHeight;
36
+ this.measuredMenuHeight = this.portalContainer.offsetHeight;
37
+ this.portalContainer.style.visibility = '';
38
+ }
39
+ async computeFloatingUIPosition() {
40
+ if (!this.portalContainer)
41
+ return;
42
+ const referenceElement = PortalUtils.findReferenceElement(this.component);
43
+ if (!referenceElement) {
44
+ console.warn('Reference element not found for menu portal positioning');
45
+ return;
46
+ }
47
+ const floatingElement = this.portalContainer;
48
+ try {
49
+ const { x, y, placement, middlewareData } = await this.calculateFloatingUIPosition(referenceElement, floatingElement);
50
+ this.applyFloatingUIPosition(floatingElement, referenceElement, x, y, placement, middlewareData);
51
+ }
52
+ catch (error) {
53
+ console.warn('Floating UI positioning failed, falling back to simple positioning:', error);
54
+ this.fallbackPositioning();
55
+ }
56
+ }
57
+ async calculateFloatingUIPosition(referenceElement, floatingElement) {
58
+ const boundary = PortalUtils.findBoundaryElements(referenceElement);
59
+ const basePlacement = PortalUtils.getOptimalPlacement(referenceElement);
60
+ const initialPlacement = basePlacement === 'top' ? 'top-start' : 'bottom-start';
61
+ const middleware = this.createFloatingUIMiddleware(boundary);
62
+ return await computePosition(referenceElement, floatingElement, {
63
+ placement: initialPlacement,
64
+ strategy: 'fixed',
65
+ middleware,
66
+ platform: this.createCustomPlatform()
67
+ });
68
+ }
69
+ createFloatingUIMiddleware(boundary) {
70
+ return [
71
+ offset(4),
72
+ size({
73
+ apply: this.handleSizeMiddleware.bind(this),
74
+ padding: 10,
75
+ boundary: boundary
76
+ }),
77
+ flip({
78
+ fallbackPlacements: ['bottom-start', 'top-start', 'bottom', 'top', 'bottom-end', 'top-end'],
79
+ fallbackStrategy: 'bestFit',
80
+ padding: 10,
81
+ boundary: boundary
82
+ }),
83
+ shift({
84
+ padding: 10,
85
+ crossAxis: true,
86
+ boundary: boundary
87
+ })
88
+ ];
89
+ }
90
+ handleSizeMiddleware({ availableWidth, availableHeight, elements, rects }) {
91
+ const maxHeight = PortalUtils.calculateOptimalHeight(rects.reference, window.innerHeight, this.currentPlacement);
92
+ elements.floating.style.maxHeight = `${maxHeight}px`;
93
+ elements.floating.style.setProperty('--auto-size-available-width', `${availableWidth}px`);
94
+ elements.floating.style.setProperty('--auto-size-available-height', `${maxHeight}px`);
95
+ }
96
+ createCustomPlatform() {
97
+ return platform;
98
+ }
99
+ applyFloatingUIPosition(floatingElement, referenceElement, x, y, placement, middlewareData) {
100
+ // Align left edge with reference element
101
+ const referenceRect = referenceElement.getBoundingClientRect();
102
+ Object.assign(floatingElement.style, {
103
+ left: `${referenceRect.left}px`,
104
+ top: `${y}px`,
105
+ position: 'fixed',
106
+ pointerEvents: 'auto',
107
+ width: 'auto',
108
+ minWidth: 'auto'
109
+ });
110
+ this.currentPlacement = placement;
111
+ this.currentMiddlewareData = middlewareData;
112
+ PortalUtils.applyCollisionData(floatingElement, middlewareData, placement);
113
+ const placementClass = placement.split('-')[0];
114
+ floatingElement.className = `nile-menu-portal-append menu__listbox--${placementClass}`;
115
+ }
116
+ fallbackPositioning() {
117
+ if (!this.portalContainer)
118
+ return;
119
+ const referenceElement = PortalUtils.findReferenceElement(this.component);
120
+ if (!referenceElement)
121
+ return;
122
+ const rect = referenceElement.getBoundingClientRect();
123
+ const viewportHeight = window.innerHeight;
124
+ const menuHeight = this.measuredMenuHeight || 200;
125
+ const spaceBelow = viewportHeight - rect.bottom;
126
+ const spaceAbove = rect.top;
127
+ let topPosition;
128
+ let placementClass;
129
+ let maxHeight;
130
+ if (spaceAbove > spaceBelow) {
131
+ maxHeight = Math.max(spaceAbove - 20, 100);
132
+ topPosition = Math.max(rect.top - maxHeight - 4, 10);
133
+ placementClass = 'top';
134
+ }
135
+ else {
136
+ maxHeight = Math.max(spaceBelow - 20, 100);
137
+ topPosition = rect.bottom + 4;
138
+ placementClass = 'bottom';
139
+ }
140
+ this.portalContainer.style.left = `${rect.left}px`;
141
+ this.portalContainer.style.top = `${topPosition}px`;
142
+ this.portalContainer.style.width = 'auto';
143
+ this.portalContainer.style.minWidth = 'auto';
144
+ this.portalContainer.style.maxHeight = `${maxHeight}px`;
145
+ this.portalContainer.style.pointerEvents = 'auto';
146
+ this.portalContainer.className = `nile-menu-portal-append menu__listbox--${placementClass}`;
147
+ this.calculateAndSetAutoSizeProperties(rect, topPosition, placementClass);
148
+ }
149
+ calculateAndSetAutoSizeProperties(rect, topPosition, placementClass) {
150
+ if (!this.portalContainer)
151
+ return;
152
+ const viewportHeight = window.innerHeight;
153
+ const viewportWidth = window.innerWidth;
154
+ let availableHeight;
155
+ if (placementClass === 'top') {
156
+ availableHeight = rect.top - 10;
157
+ }
158
+ else {
159
+ availableHeight = viewportHeight - rect.bottom - 10;
160
+ }
161
+ const availableWidth = Math.min(rect.width, viewportWidth - rect.left - 10);
162
+ this.portalContainer.style.setProperty('--auto-size-available-height', `${Math.max(availableHeight, 100)}px`);
163
+ this.portalContainer.style.setProperty('--auto-size-available-width', `${Math.max(availableWidth, 200)}px`);
164
+ }
165
+ updatePortalAppendPosition() {
166
+ if (this.component.portal && this.portalContainer) {
167
+ this.positionPortalAppend();
168
+ }
169
+ }
170
+ handleWindowResize() {
171
+ if (this.component.portal && this.portalContainer) {
172
+ this.positionPortalAppend();
173
+ }
174
+ }
175
+ setupAutoUpdatePositioning() {
176
+ if (!this.portalContainer || !this.component)
177
+ return;
178
+ this.cleanupAutoUpdatePositioning();
179
+ const referenceElement = PortalUtils.findReferenceElement(this.component);
180
+ if (!referenceElement)
181
+ return;
182
+ this.cleanupAutoUpdate = autoUpdate(referenceElement, this.portalContainer, () => {
183
+ this.computeFloatingUIPosition();
184
+ }, {
185
+ ancestorScroll: true,
186
+ ancestorResize: true,
187
+ elementResize: true,
188
+ layoutShift: true,
189
+ animationFrame: true
190
+ });
191
+ }
192
+ cleanupAutoUpdatePositioning() {
193
+ if (this.cleanupAutoUpdate) {
194
+ this.cleanupAutoUpdate();
195
+ this.cleanupAutoUpdate = null;
196
+ }
197
+ }
198
+ injectStylesToDocument() {
199
+ if (!this.portalContainer)
200
+ return;
201
+ const styleId = PortalUtils.generateStyleId();
202
+ if (document.getElementById(styleId))
203
+ return;
204
+ const componentStyles = this.component.constructor.styles;
205
+ if (!componentStyles)
206
+ return;
207
+ const styleElement = document.createElement('style');
208
+ styleElement.id = styleId;
209
+ styleElement.textContent = PortalUtils.extractStylesAsCSS(componentStyles);
210
+ document.head.appendChild(styleElement);
211
+ this.portalContainer.__injectedStyleId = styleId;
212
+ }
213
+ adoptStylesToPortalAppend() {
214
+ if (!this.portalContainer)
215
+ return;
216
+ this.injectStylesToDocument();
217
+ }
218
+ setupPortalAppend() {
219
+ if (!this.component.portal)
220
+ return;
221
+ // If portal already exists, don't recreate it
222
+ if (this.portalContainer && this.portalContainer.parentNode) {
223
+ return;
224
+ }
225
+ this.component.updateComplete.then(() => {
226
+ setTimeout(() => {
227
+ // Check if menu is inside a parent container (e.g., nile-dropdown) and if it's open
228
+ const parentContainer = this.findParentContainer();
229
+ const isParentOpen = parentContainer ? parentContainer.open : true;
230
+ // Portal the menu if parent is open or if no parent found (standalone menu)
231
+ if (isParentOpen || !parentContainer) {
232
+ this.originalMenuParent = this.component.parentElement;
233
+ // Clone the menu element with all its children and attributes
234
+ this.clonedMenu = this.component.cloneNode(true);
235
+ // Copy all attributes from original to cloned menu
236
+ Array.from(this.component.attributes).forEach((attr) => {
237
+ this.clonedMenu.setAttribute(attr.name, attr.value);
238
+ });
239
+ this.portalContainer = this.createPortalAppendContainer();
240
+ this.portalContainer.appendChild(this.clonedMenu);
241
+ document.body.appendChild(this.portalContainer);
242
+ this.adoptStylesToPortalAppend();
243
+ this.clonedMenu.style.display = '';
244
+ this.positionPortalAppend();
245
+ this.setupPortalEventListeners();
246
+ this.setupAutoUpdatePositioning();
247
+ window.addEventListener('resize', this.handleWindowResize.bind(this));
248
+ }
249
+ }, 50);
250
+ });
251
+ }
252
+ findParentContainer() {
253
+ // First, check if we're in a slot and find the dropdown through the slot
254
+ const root = this.component.getRootNode();
255
+ if (root instanceof ShadowRoot) {
256
+ // We're in a shadow root, find the dropdown host
257
+ const host = root.host;
258
+ if (host && host.tagName.toLowerCase() === 'nile-dropdown') {
259
+ return host;
260
+ }
261
+ }
262
+ // Also check parent element chain
263
+ let current = this.component.parentElement;
264
+ while (current && current !== document.body) {
265
+ // Check for nile-dropdown or other containers that might have open/close behavior
266
+ if (current.tagName.toLowerCase() === 'nile-dropdown') {
267
+ return current;
268
+ }
269
+ // If we hit a shadow root, check the host
270
+ if (current instanceof ShadowRoot) {
271
+ const host = current.host;
272
+ if (host && host.tagName.toLowerCase() === 'nile-dropdown') {
273
+ return host;
274
+ }
275
+ }
276
+ current = current.parentElement;
277
+ }
278
+ // Try to find dropdown through assigned slot
279
+ if (this.component.assignedSlot) {
280
+ const slotRoot = this.component.assignedSlot.getRootNode();
281
+ if (slotRoot instanceof ShadowRoot) {
282
+ const host = slotRoot.host;
283
+ if (host && host.tagName.toLowerCase() === 'nile-dropdown') {
284
+ return host;
285
+ }
286
+ }
287
+ }
288
+ return null;
289
+ }
290
+ setupPortalEventListeners() {
291
+ if (!this.clonedMenu)
292
+ return;
293
+ // Forward events from cloned menu to original component
294
+ this.clonedMenu.addEventListener('nile-select', (event) => {
295
+ const customEvent = event;
296
+ this.component.dispatchEvent(new CustomEvent('nile-select', { detail: customEvent.detail, bubbles: true }));
297
+ });
298
+ }
299
+ cleanupPortalAppend() {
300
+ this.cleanupAutoUpdatePositioning();
301
+ if (this.portalContainer && this.portalContainer.parentNode) {
302
+ const injectedStyleId = this.portalContainer.__injectedStyleId;
303
+ if (injectedStyleId) {
304
+ const styleElement = document.getElementById(injectedStyleId);
305
+ if (styleElement) {
306
+ styleElement.remove();
307
+ }
308
+ }
309
+ this.portalContainer.parentNode.removeChild(this.portalContainer);
310
+ }
311
+ window.removeEventListener('resize', this.handleWindowResize.bind(this));
312
+ this.portalContainer = null;
313
+ this.originalMenuParent = null;
314
+ this.clonedMenu = null;
315
+ this.measuredMenuHeight = null;
316
+ this.currentPlacement = 'bottom';
317
+ this.currentMiddlewareData = null;
318
+ }
319
+ get portalContainerElement() {
320
+ return this.portalContainer;
321
+ }
322
+ resetMeasuredHeight() {
323
+ this.measuredMenuHeight = null;
324
+ }
325
+ forceReposition() {
326
+ if (this.portalContainer) {
327
+ this.computeFloatingUIPosition();
328
+ }
329
+ }
330
+ getCurrentPlacement() {
331
+ return this.currentPlacement;
332
+ }
333
+ getCurrentMiddlewareData() {
334
+ return this.currentMiddlewareData;
335
+ }
336
+ isUsingFloatingUI() {
337
+ return this.cleanupAutoUpdate !== null;
338
+ }
339
+ }
340
+ //# sourceMappingURL=portal-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"portal-manager.js","sourceRoot":"","sources":["../../../src/nile-menu/portal-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { \n autoUpdate, \n computePosition, \n flip, \n offset, \n shift, \n size, \n platform,\n type Placement,\n type MiddlewareData,\n type ComputePositionConfig\n} from '@floating-ui/dom';\nimport { PortalUtils } from './portal-utils';\n\nexport class MenuPortalManager {\n private portalContainer: HTMLElement | null = null;\n private originalMenuParent: HTMLElement | null = null;\n private measuredMenuHeight: number | null = null;\n private component: any;\n private clonedMenu: HTMLElement | null = null;\n private cleanupAutoUpdate: (() => void) | null = null;\n private currentPlacement: Placement = 'bottom';\n private currentMiddlewareData: MiddlewareData | null = null;\n\n constructor(component: any) {\n this.component = component;\n }\n\n private createPortalAppendContainer(): HTMLElement {\n const container = document.createElement('div');\n container.style.position = 'absolute';\n container.style.zIndex = '9999';\n container.style.pointerEvents = 'none';\n container.className = 'nile-menu-portal-append';\n return container;\n }\n\n positionPortalAppend(): void {\n if (!this.portalContainer) return;\n\n this.measureMenuHeight();\n this.computeFloatingUIPosition();\n }\n\n private measureMenuHeight(): void {\n if (this.measuredMenuHeight || !this.portalContainer) return;\n\n this.portalContainer.style.position = 'absolute';\n this.portalContainer.style.visibility = 'hidden';\n this.portalContainer.style.top = '0px';\n this.portalContainer.style.left = '0px';\n \n this.portalContainer.offsetHeight;\n \n this.measuredMenuHeight = this.portalContainer.offsetHeight;\n \n this.portalContainer.style.visibility = '';\n }\n\n private async computeFloatingUIPosition(): Promise<void> {\n if (!this.portalContainer) return;\n\n const referenceElement = PortalUtils.findReferenceElement(this.component);\n if (!referenceElement) {\n console.warn('Reference element not found for menu portal positioning');\n return;\n }\n\n const floatingElement = this.portalContainer;\n\n try {\n const { x, y, placement, middlewareData } = await this.calculateFloatingUIPosition(\n referenceElement,\n floatingElement\n );\n\n this.applyFloatingUIPosition(floatingElement, referenceElement, x, y, placement, middlewareData);\n\n } catch (error) {\n console.warn('Floating UI positioning failed, falling back to simple positioning:', error);\n this.fallbackPositioning();\n }\n }\n\n private async calculateFloatingUIPosition(\n referenceElement: HTMLElement,\n floatingElement: HTMLElement\n ): Promise<{ x: number; y: number; placement: Placement; middlewareData: MiddlewareData }> {\n const boundary = PortalUtils.findBoundaryElements(referenceElement);\n const basePlacement = PortalUtils.getOptimalPlacement(referenceElement);\n const initialPlacement = basePlacement === 'top' ? 'top-start' : 'bottom-start';\n const middleware = this.createFloatingUIMiddleware(boundary);\n\n return await computePosition(referenceElement, floatingElement, {\n placement: initialPlacement,\n strategy: 'fixed',\n middleware,\n platform: this.createCustomPlatform()\n });\n }\n\n private createFloatingUIMiddleware(boundary: Element[] | undefined): ComputePositionConfig['middleware'] {\n return [\n offset(4),\n size({\n apply: this.handleSizeMiddleware.bind(this),\n padding: 10,\n boundary: boundary\n }),\n flip({\n fallbackPlacements: ['bottom-start', 'top-start', 'bottom', 'top', 'bottom-end', 'top-end'],\n fallbackStrategy: 'bestFit',\n padding: 10,\n boundary: boundary\n }),\n shift({\n padding: 10,\n crossAxis: true,\n boundary: boundary\n })\n ];\n }\n\n private handleSizeMiddleware({ availableWidth, availableHeight, elements, rects }: {\n availableWidth: number;\n availableHeight: number;\n elements: { floating: HTMLElement };\n rects: { reference: { x: number; y: number; width: number; height: number } };\n }): void {\n const maxHeight = PortalUtils.calculateOptimalHeight(\n rects.reference,\n window.innerHeight,\n this.currentPlacement\n );\n\n elements.floating.style.maxHeight = `${maxHeight}px`;\n \n elements.floating.style.setProperty('--auto-size-available-width', `${availableWidth}px`);\n elements.floating.style.setProperty('--auto-size-available-height', `${maxHeight}px`);\n }\n\n private createCustomPlatform() {\n return platform;\n }\n\n private applyFloatingUIPosition(\n floatingElement: HTMLElement,\n referenceElement: HTMLElement,\n x: number,\n y: number,\n placement: Placement,\n middlewareData: MiddlewareData\n ): void {\n // Align left edge with reference element\n const referenceRect = referenceElement.getBoundingClientRect();\n \n Object.assign(floatingElement.style, {\n left: `${referenceRect.left}px`,\n top: `${y}px`,\n position: 'fixed',\n pointerEvents: 'auto',\n width: 'auto',\n minWidth: 'auto'\n });\n\n this.currentPlacement = placement;\n this.currentMiddlewareData = middlewareData;\n \n PortalUtils.applyCollisionData(floatingElement, middlewareData, placement);\n \n const placementClass = placement.split('-')[0];\n floatingElement.className = `nile-menu-portal-append menu__listbox--${placementClass}`;\n }\n\n private fallbackPositioning(): void {\n if (!this.portalContainer) return;\n\n const referenceElement = PortalUtils.findReferenceElement(this.component);\n if (!referenceElement) return;\n\n const rect = referenceElement.getBoundingClientRect();\n const viewportHeight = window.innerHeight;\n const menuHeight = this.measuredMenuHeight || 200;\n \n const spaceBelow = viewportHeight - rect.bottom;\n const spaceAbove = rect.top;\n \n let topPosition: number;\n let placementClass: string;\n let maxHeight: number;\n \n if (spaceAbove > spaceBelow) {\n maxHeight = Math.max(spaceAbove - 20, 100);\n topPosition = Math.max(rect.top - maxHeight - 4, 10);\n placementClass = 'top';\n } else {\n maxHeight = Math.max(spaceBelow - 20, 100);\n topPosition = rect.bottom + 4;\n placementClass = 'bottom';\n }\n\n this.portalContainer.style.left = `${rect.left}px`;\n this.portalContainer.style.top = `${topPosition}px`;\n this.portalContainer.style.width = 'auto';\n this.portalContainer.style.minWidth = 'auto';\n this.portalContainer.style.maxHeight = `${maxHeight}px`;\n this.portalContainer.style.pointerEvents = 'auto';\n this.portalContainer.className = `nile-menu-portal-append menu__listbox--${placementClass}`;\n \n this.calculateAndSetAutoSizeProperties(rect, topPosition, placementClass);\n }\n\n private calculateAndSetAutoSizeProperties(rect: DOMRect, topPosition: number, placementClass: string): void {\n if (!this.portalContainer) return;\n\n const viewportHeight = window.innerHeight;\n const viewportWidth = window.innerWidth;\n \n let availableHeight: number;\n if (placementClass === 'top') {\n availableHeight = rect.top - 10;\n } else {\n availableHeight = viewportHeight - rect.bottom - 10;\n }\n \n const availableWidth = Math.min(rect.width, viewportWidth - rect.left - 10);\n \n this.portalContainer.style.setProperty('--auto-size-available-height', `${Math.max(availableHeight, 100)}px`);\n this.portalContainer.style.setProperty('--auto-size-available-width', `${Math.max(availableWidth, 200)}px`);\n }\n\n updatePortalAppendPosition(): void {\n if (this.component.portal && this.portalContainer) {\n this.positionPortalAppend();\n }\n }\n\n handleWindowResize(): void {\n if (this.component.portal && this.portalContainer) {\n this.positionPortalAppend();\n }\n }\n\n private setupAutoUpdatePositioning(): void {\n if (!this.portalContainer || !this.component) return;\n\n this.cleanupAutoUpdatePositioning();\n\n const referenceElement = PortalUtils.findReferenceElement(this.component);\n if (!referenceElement) return;\n\n this.cleanupAutoUpdate = autoUpdate(\n referenceElement,\n this.portalContainer,\n () => {\n this.computeFloatingUIPosition();\n },\n {\n ancestorScroll: true,\n ancestorResize: true,\n elementResize: true,\n layoutShift: true,\n animationFrame: true\n }\n );\n }\n\n private cleanupAutoUpdatePositioning(): void {\n if (this.cleanupAutoUpdate) {\n this.cleanupAutoUpdate();\n this.cleanupAutoUpdate = null;\n }\n }\n\n private injectStylesToDocument(): void {\n if (!this.portalContainer) return;\n\n const styleId = PortalUtils.generateStyleId();\n \n if (document.getElementById(styleId)) return;\n\n const componentStyles = (this.component.constructor as any).styles;\n if (!componentStyles) return;\n\n const styleElement = document.createElement('style');\n styleElement.id = styleId;\n styleElement.textContent = PortalUtils.extractStylesAsCSS(componentStyles);\n \n document.head.appendChild(styleElement);\n \n (this.portalContainer as any).__injectedStyleId = styleId;\n }\n\n private adoptStylesToPortalAppend(): void {\n if (!this.portalContainer) return;\n this.injectStylesToDocument();\n }\n\n setupPortalAppend(): void {\n if (!this.component.portal) return;\n \n // If portal already exists, don't recreate it\n if (this.portalContainer && this.portalContainer.parentNode) {\n return;\n }\n\n this.component.updateComplete.then(() => {\n setTimeout(() => {\n // Check if menu is inside a parent container (e.g., nile-dropdown) and if it's open\n const parentContainer = this.findParentContainer();\n const isParentOpen = parentContainer ? parentContainer.open : true;\n \n // Portal the menu if parent is open or if no parent found (standalone menu)\n if (isParentOpen || !parentContainer) {\n this.originalMenuParent = this.component.parentElement as HTMLElement;\n \n // Clone the menu element with all its children and attributes\n this.clonedMenu = this.component.cloneNode(true) as HTMLElement;\n \n // Copy all attributes from original to cloned menu\n Array.from(this.component.attributes).forEach((attr: Attr) => {\n this.clonedMenu!.setAttribute(attr.name, attr.value);\n });\n \n this.portalContainer = this.createPortalAppendContainer();\n this.portalContainer.appendChild(this.clonedMenu);\n document.body.appendChild(this.portalContainer);\n \n this.adoptStylesToPortalAppend();\n \n this.clonedMenu.style.display = '';\n this.positionPortalAppend();\n \n this.setupPortalEventListeners();\n \n this.setupAutoUpdatePositioning();\n \n window.addEventListener('resize', this.handleWindowResize.bind(this));\n }\n }, 50);\n });\n }\n\n private findParentContainer(): any {\n // First, check if we're in a slot and find the dropdown through the slot\n const root = this.component.getRootNode();\n if (root instanceof ShadowRoot) {\n // We're in a shadow root, find the dropdown host\n const host = root.host;\n if (host && host.tagName.toLowerCase() === 'nile-dropdown') {\n return host;\n }\n }\n \n // Also check parent element chain\n let current = this.component.parentElement;\n while (current && current !== document.body) {\n // Check for nile-dropdown or other containers that might have open/close behavior\n if (current.tagName.toLowerCase() === 'nile-dropdown') {\n return current;\n }\n \n // If we hit a shadow root, check the host\n if (current instanceof ShadowRoot) {\n const host = current.host;\n if (host && host.tagName.toLowerCase() === 'nile-dropdown') {\n return host;\n }\n }\n \n current = current.parentElement;\n }\n \n // Try to find dropdown through assigned slot\n if (this.component.assignedSlot) {\n const slotRoot = this.component.assignedSlot.getRootNode();\n if (slotRoot instanceof ShadowRoot) {\n const host = slotRoot.host;\n if (host && host.tagName.toLowerCase() === 'nile-dropdown') {\n return host;\n }\n }\n }\n \n return null;\n }\n\n private setupPortalEventListeners(): void {\n if (!this.clonedMenu) return;\n\n // Forward events from cloned menu to original component\n this.clonedMenu.addEventListener('nile-select', (event: Event) => {\n const customEvent = event as CustomEvent;\n this.component.dispatchEvent(new CustomEvent('nile-select', { detail: customEvent.detail, bubbles: true }));\n });\n }\n\n cleanupPortalAppend(): void {\n this.cleanupAutoUpdatePositioning();\n \n if (this.portalContainer && this.portalContainer.parentNode) {\n const injectedStyleId = (this.portalContainer as any).__injectedStyleId;\n if (injectedStyleId) {\n const styleElement = document.getElementById(injectedStyleId);\n if (styleElement) {\n styleElement.remove();\n }\n }\n \n this.portalContainer.parentNode.removeChild(this.portalContainer);\n }\n \n window.removeEventListener('resize', this.handleWindowResize.bind(this));\n \n this.portalContainer = null;\n this.originalMenuParent = null;\n this.clonedMenu = null;\n this.measuredMenuHeight = null;\n this.currentPlacement = 'bottom';\n this.currentMiddlewareData = null;\n }\n\n get portalContainerElement(): HTMLElement | null {\n return this.portalContainer;\n }\n\n resetMeasuredHeight(): void {\n this.measuredMenuHeight = null;\n }\n\n forceReposition(): void {\n if (this.portalContainer) {\n this.computeFloatingUIPosition();\n }\n }\n\n getCurrentPlacement(): Placement {\n return this.currentPlacement;\n }\n\n getCurrentMiddlewareData(): MiddlewareData | null {\n return this.currentMiddlewareData;\n }\n\n isUsingFloatingUI(): boolean {\n return this.cleanupAutoUpdate !== null;\n }\n}\n\n"]}