@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
@@ -0,0 +1,21 @@
1
+ import { type Placement, type MiddlewareData } from '@floating-ui/dom';
2
+ export declare class PortalUtils {
3
+ static calculateAvailableSpace(referenceElement: HTMLElement): {
4
+ spaceAbove: number;
5
+ spaceBelow: number;
6
+ viewportHeight: number;
7
+ };
8
+ static getOptimalPlacement(referenceElement: HTMLElement): Placement;
9
+ static findBoundaryElements(component: HTMLElement): Element[] | undefined;
10
+ static calculateOptimalHeight(referenceRect: {
11
+ x: number;
12
+ y: number;
13
+ width: number;
14
+ height: number;
15
+ }, viewportHeight: number, placement: Placement): number;
16
+ static extractStylesAsCSS(styles: any): string;
17
+ static generateStyleId(): string;
18
+ static isPositioningOptimal(placement: Placement, referenceElement: HTMLElement): boolean;
19
+ static applyCollisionData(element: HTMLElement, middlewareData: MiddlewareData, placement: Placement): void;
20
+ static findReferenceElement(menu: HTMLElement): HTMLElement | null;
21
+ }
@@ -0,0 +1,128 @@
1
+ export class PortalUtils {
2
+ static calculateAvailableSpace(referenceElement) {
3
+ const rect = referenceElement.getBoundingClientRect();
4
+ const viewportHeight = window.innerHeight;
5
+ const spaceBelow = viewportHeight - rect.bottom;
6
+ const spaceAbove = rect.top;
7
+ return { spaceAbove, spaceBelow, viewportHeight };
8
+ }
9
+ static getOptimalPlacement(referenceElement) {
10
+ const { spaceAbove, spaceBelow } = this.calculateAvailableSpace(referenceElement);
11
+ if (spaceBelow < 200 && spaceAbove > spaceBelow) {
12
+ return 'top';
13
+ }
14
+ return 'bottom';
15
+ }
16
+ static findBoundaryElements(component) {
17
+ const boundaryElements = [];
18
+ let currentElement = component.parentElement;
19
+ while (currentElement && currentElement !== document.body) {
20
+ const computedStyle = window.getComputedStyle(currentElement);
21
+ const overflow = computedStyle.overflow;
22
+ const overflowY = computedStyle.overflowY;
23
+ const overflowX = computedStyle.overflowX;
24
+ if (overflow === 'auto' || overflow === 'scroll' ||
25
+ overflowY === 'auto' || overflowY === 'scroll' ||
26
+ overflowX === 'auto' || overflowX === 'scroll') {
27
+ boundaryElements.push(currentElement);
28
+ }
29
+ if (currentElement.hasAttribute('data-floating-boundary') ||
30
+ currentElement.classList.contains('floating-boundary') ||
31
+ currentElement.classList.contains('scroll-container')) {
32
+ boundaryElements.push(currentElement);
33
+ }
34
+ currentElement = currentElement.parentElement;
35
+ }
36
+ return boundaryElements.length > 0 ? boundaryElements : undefined;
37
+ }
38
+ static calculateOptimalHeight(referenceRect, viewportHeight, placement) {
39
+ const spaceBelow = viewportHeight - (referenceRect.y + referenceRect.height);
40
+ const spaceAbove = referenceRect.y;
41
+ if (spaceAbove > spaceBelow) {
42
+ return Math.max(spaceAbove - 20, 100);
43
+ }
44
+ else if (spaceBelow > spaceAbove) {
45
+ return Math.max(spaceBelow - 20, 100);
46
+ }
47
+ return Math.max(Math.min(spaceAbove, spaceBelow) - 20, 100);
48
+ }
49
+ static extractStylesAsCSS(styles) {
50
+ if (typeof styles === 'string') {
51
+ return styles;
52
+ }
53
+ if (Array.isArray(styles)) {
54
+ return styles.map(style => this.extractStylesAsCSS(style)).join('\n');
55
+ }
56
+ if (styles && typeof styles === 'object' && styles.cssText) {
57
+ return styles.cssText;
58
+ }
59
+ return '';
60
+ }
61
+ static generateStyleId() {
62
+ return `nile-menu-styles-${Math.random().toString(36).substring(2, 11)}`;
63
+ }
64
+ static isPositioningOptimal(placement, referenceElement) {
65
+ const { spaceAbove, spaceBelow } = this.calculateAvailableSpace(referenceElement);
66
+ const isAbove = placement.startsWith('top');
67
+ const isBelow = placement.startsWith('bottom');
68
+ if (isAbove && spaceBelow > spaceAbove)
69
+ return false;
70
+ if (isBelow && spaceAbove > spaceBelow)
71
+ return false;
72
+ return true;
73
+ }
74
+ static applyCollisionData(element, middlewareData, placement) {
75
+ if (middlewareData.flip) {
76
+ const { overflows } = middlewareData.flip;
77
+ element.setAttribute('data-placement', placement);
78
+ if (overflows && overflows.length > 0) {
79
+ const overflowPlacements = overflows.map(overflow => overflow.placement).join(',');
80
+ element.setAttribute('data-overflow', overflowPlacements);
81
+ }
82
+ else {
83
+ element.removeAttribute('data-overflow');
84
+ }
85
+ }
86
+ if (middlewareData.shift) {
87
+ const { x, y } = middlewareData.shift;
88
+ if (x !== undefined && y !== undefined && (x !== 0 || y !== 0)) {
89
+ element.setAttribute('data-shift', `${x},${y}`);
90
+ }
91
+ else {
92
+ element.removeAttribute('data-shift');
93
+ }
94
+ }
95
+ if (middlewareData.size) {
96
+ const { availableWidth, availableHeight } = middlewareData.size;
97
+ if (availableWidth !== undefined) {
98
+ element.setAttribute('data-available-width', availableWidth.toString());
99
+ }
100
+ if (availableHeight !== undefined) {
101
+ element.setAttribute('data-available-height', availableHeight.toString());
102
+ }
103
+ }
104
+ }
105
+ static findReferenceElement(menu) {
106
+ // Try to find nile-dropdown parent first (common use case)
107
+ let current = menu.parentElement;
108
+ while (current && current !== document.body) {
109
+ if (current.tagName.toLowerCase() === 'nile-dropdown') {
110
+ // Get the trigger element from the dropdown
111
+ const dropdown = current;
112
+ const triggerSlot = dropdown.shadowRoot?.querySelector('.dropdown__trigger');
113
+ if (triggerSlot) {
114
+ const triggerElements = triggerSlot.assignedElements({ flatten: true });
115
+ if (triggerElements.length > 0) {
116
+ return triggerElements[0];
117
+ }
118
+ }
119
+ // Fallback to parent container itself
120
+ return current;
121
+ }
122
+ current = current.parentElement;
123
+ }
124
+ // If no parent container found, try to find closest parent element
125
+ return menu.parentElement || menu;
126
+ }
127
+ }
128
+ //# sourceMappingURL=portal-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"portal-utils.js","sourceRoot":"","sources":["../../../src/nile-menu/portal-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { \n type Placement,\n type MiddlewareData\n} from '@floating-ui/dom';\n\nexport class PortalUtils {\n static calculateAvailableSpace(referenceElement: HTMLElement): {\n spaceAbove: number;\n spaceBelow: number;\n viewportHeight: number;\n } {\n const rect = referenceElement.getBoundingClientRect();\n const viewportHeight = window.innerHeight;\n const spaceBelow = viewportHeight - rect.bottom;\n const spaceAbove = rect.top;\n \n return { spaceAbove, spaceBelow, viewportHeight };\n }\n\n static getOptimalPlacement(referenceElement: HTMLElement): Placement {\n const { spaceAbove, spaceBelow } = this.calculateAvailableSpace(referenceElement);\n \n if (spaceBelow < 200 && spaceAbove > spaceBelow) {\n return 'top';\n }\n \n return 'bottom';\n }\n\n static findBoundaryElements(component: HTMLElement): Element[] | undefined {\n const boundaryElements: Element[] = [];\n \n let currentElement = component.parentElement;\n \n while (currentElement && currentElement !== document.body) {\n const computedStyle = window.getComputedStyle(currentElement);\n const overflow = computedStyle.overflow;\n const overflowY = computedStyle.overflowY;\n const overflowX = computedStyle.overflowX;\n \n if (overflow === 'auto' || overflow === 'scroll' || \n overflowY === 'auto' || overflowY === 'scroll' ||\n overflowX === 'auto' || overflowX === 'scroll') {\n boundaryElements.push(currentElement);\n }\n \n if (currentElement.hasAttribute('data-floating-boundary') ||\n currentElement.classList.contains('floating-boundary') ||\n currentElement.classList.contains('scroll-container')) {\n boundaryElements.push(currentElement);\n }\n \n currentElement = currentElement.parentElement;\n }\n \n return boundaryElements.length > 0 ? boundaryElements : undefined;\n }\n\n static calculateOptimalHeight(\n referenceRect: { x: number; y: number; width: number; height: number },\n viewportHeight: number,\n placement: Placement\n ): number {\n const spaceBelow = viewportHeight - (referenceRect.y + referenceRect.height);\n const spaceAbove = referenceRect.y;\n \n if (spaceAbove > spaceBelow) {\n return Math.max(spaceAbove - 20, 100);\n }\n else if (spaceBelow > spaceAbove) {\n return Math.max(spaceBelow - 20, 100);\n }\n \n return Math.max(Math.min(spaceAbove, spaceBelow) - 20, 100);\n }\n\n static extractStylesAsCSS(styles: any): string {\n if (typeof styles === 'string') {\n return styles;\n }\n \n if (Array.isArray(styles)) {\n return styles.map(style => this.extractStylesAsCSS(style)).join('\\n');\n }\n \n if (styles && typeof styles === 'object' && styles.cssText) {\n return styles.cssText;\n }\n \n return '';\n }\n\n static generateStyleId(): string {\n return `nile-menu-styles-${Math.random().toString(36).substring(2, 11)}`;\n }\n\n static isPositioningOptimal(\n placement: Placement,\n referenceElement: HTMLElement\n ): boolean {\n const { spaceAbove, spaceBelow } = this.calculateAvailableSpace(referenceElement);\n \n const isAbove = placement.startsWith('top');\n const isBelow = placement.startsWith('bottom');\n \n if (isAbove && spaceBelow > spaceAbove) return false;\n if (isBelow && spaceAbove > spaceBelow) return false;\n \n return true;\n }\n\n static applyCollisionData(\n element: HTMLElement,\n middlewareData: MiddlewareData,\n placement: Placement\n ): void {\n if (middlewareData.flip) {\n const { overflows } = middlewareData.flip;\n \n element.setAttribute('data-placement', placement);\n \n if (overflows && overflows.length > 0) {\n const overflowPlacements = overflows.map(overflow => overflow.placement).join(',');\n element.setAttribute('data-overflow', overflowPlacements);\n } else {\n element.removeAttribute('data-overflow');\n }\n }\n\n if (middlewareData.shift) {\n const { x, y } = middlewareData.shift;\n \n if (x !== undefined && y !== undefined && (x !== 0 || y !== 0)) {\n element.setAttribute('data-shift', `${x},${y}`);\n } else {\n element.removeAttribute('data-shift');\n }\n }\n\n if (middlewareData.size) {\n const { availableWidth, availableHeight } = middlewareData.size;\n \n if (availableWidth !== undefined) {\n element.setAttribute('data-available-width', availableWidth.toString());\n }\n if (availableHeight !== undefined) {\n element.setAttribute('data-available-height', availableHeight.toString());\n }\n }\n }\n\n static findReferenceElement(menu: HTMLElement): HTMLElement | null {\n // Try to find nile-dropdown parent first (common use case)\n let current = menu.parentElement;\n while (current && current !== document.body) {\n if (current.tagName.toLowerCase() === 'nile-dropdown') {\n // Get the trigger element from the dropdown\n const dropdown = current as any;\n const triggerSlot = dropdown.shadowRoot?.querySelector('.dropdown__trigger') as HTMLSlotElement;\n if (triggerSlot) {\n const triggerElements = triggerSlot.assignedElements({ flatten: true });\n if (triggerElements.length > 0) {\n return triggerElements[0] as HTMLElement;\n }\n }\n // Fallback to parent container itself\n return current as HTMLElement;\n }\n current = current.parentElement;\n }\n \n // If no parent container found, try to find closest parent element\n return menu.parentElement || menu;\n }\n}\n\n"]}
@@ -0,0 +1,22 @@
1
+ /* @web/test-runner snapshot v1 */
2
+ export const snapshots = {};
3
+
4
+ snapshots["NilePopover renders correctly"] =
5
+ `<nile-popup
6
+ active=""
7
+ arrowplacement="anchor"
8
+ distance="18"
9
+ placement="top"
10
+ shift=""
11
+ strategy="absolute"
12
+ >
13
+ <slot
14
+ aria-describedby="tooltip"
15
+ name="anchor"
16
+ slot="anchor"
17
+ >
18
+ </slot>
19
+ </nile-popup>
20
+ `;
21
+ /* end snapshot NilePopover renders correctly */
22
+
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Copyright Aquera Inc 2025
3
+ *
4
+ * This source code is licensed under the BSD-3-Clause license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ import { PortalContentHandler, PortalConfig } from '../internal/portal-manager';
8
+ import type { CSSResultGroup } from 'lit';
9
+ export declare class PopoverPortalHandler implements PortalContentHandler {
10
+ private component;
11
+ private config;
12
+ private clonedPopoverContent;
13
+ constructor(component: any, config?: PortalConfig);
14
+ createPortalContent(): HTMLElement;
15
+ private createFallbackContent;
16
+ updatePortalContent(portalElement: HTMLElement): void;
17
+ setupEventListeners(portalElement: HTMLElement): void;
18
+ cleanupEventListeners(portalElement: HTMLElement): void;
19
+ getReferenceElement(): HTMLElement;
20
+ getComponentStyles(): CSSResultGroup | undefined;
21
+ }
@@ -0,0 +1,106 @@
1
+ /**
2
+ * Copyright Aquera Inc 2025
3
+ *
4
+ * This source code is licensed under the BSD-3-Clause license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ export class PopoverPortalHandler {
8
+ constructor(component, config = {}) {
9
+ this.component = component;
10
+ this.config = config;
11
+ this.clonedPopoverContent = null;
12
+ }
13
+ createPortalContent() {
14
+ // Find the popover content in the shadow DOM (now it's always rendered but hidden when portal is enabled)
15
+ const popoverBox = this.component.shadowRoot?.querySelector('.popover__box');
16
+ if (!popoverBox) {
17
+ // Fallback: create content directly
18
+ return this.createFallbackContent();
19
+ }
20
+ // Clone the popover content for portal
21
+ this.clonedPopoverContent = popoverBox.cloneNode(true);
22
+ this.clonedPopoverContent.style.display = 'block';
23
+ this.clonedPopoverContent.style.position = 'relative';
24
+ return this.clonedPopoverContent;
25
+ }
26
+ createFallbackContent() {
27
+ // Create the popover content directly as fallback
28
+ this.clonedPopoverContent = document.createElement('div');
29
+ this.clonedPopoverContent.className = 'popover__box';
30
+ this.clonedPopoverContent.setAttribute('part', 'popover');
31
+ this.clonedPopoverContent.style.display = 'block';
32
+ this.clonedPopoverContent.style.position = 'relative';
33
+ // Create the title element
34
+ const titleElement = document.createElement('div');
35
+ titleElement.className = 'popover__title';
36
+ titleElement.textContent = this.component.title;
37
+ // Create the base content slot
38
+ const baseSlot = document.createElement('div');
39
+ baseSlot.setAttribute('part', 'base');
40
+ // Create the action slot
41
+ const actionSlot = document.createElement('div');
42
+ actionSlot.className = 'popover__action';
43
+ // Append elements
44
+ this.clonedPopoverContent.appendChild(titleElement);
45
+ this.clonedPopoverContent.appendChild(baseSlot);
46
+ this.clonedPopoverContent.appendChild(actionSlot);
47
+ return this.clonedPopoverContent;
48
+ }
49
+ updatePortalContent(portalElement) {
50
+ if (!this.component.isShow) {
51
+ portalElement.style.display = 'none';
52
+ return;
53
+ }
54
+ portalElement.style.display = 'block';
55
+ // Update the content by cloning from the shadow DOM again
56
+ const originalPopoverBox = this.component.shadowRoot?.querySelector('.popover__box');
57
+ if (originalPopoverBox) {
58
+ // Clone the updated content
59
+ const updatedContent = originalPopoverBox.cloneNode(true);
60
+ updatedContent.style.display = 'block';
61
+ updatedContent.style.position = 'relative';
62
+ // Replace the content
63
+ portalElement.innerHTML = updatedContent.innerHTML;
64
+ }
65
+ }
66
+ setupEventListeners(portalElement) {
67
+ // Handle click events to prevent them from bubbling up
68
+ portalElement.addEventListener('click', (event) => {
69
+ event.stopPropagation();
70
+ });
71
+ // Handle any other popover-specific events
72
+ // For example, if the popover has action buttons, we might need to handle those
73
+ const actionSlot = portalElement.querySelector('slot[name="action"]');
74
+ if (actionSlot) {
75
+ actionSlot.addEventListener('click', (event) => {
76
+ event.stopPropagation();
77
+ // Forward the event to the original component if needed
78
+ this.component.dispatchEvent(new CustomEvent('nile-popover-action', {
79
+ detail: { originalEvent: event },
80
+ bubbles: true
81
+ }));
82
+ });
83
+ }
84
+ }
85
+ cleanupEventListeners(portalElement) {
86
+ // Remove all event listeners
87
+ const newElement = portalElement.cloneNode(true);
88
+ portalElement.parentNode?.replaceChild(newElement, portalElement);
89
+ }
90
+ getReferenceElement() {
91
+ // Get the anchor element from the slot
92
+ const anchorSlot = this.component.shadowRoot?.querySelector('slot[name="anchor"]');
93
+ if (anchorSlot) {
94
+ const assignedElements = anchorSlot.assignedElements();
95
+ if (assignedElements.length > 0) {
96
+ return assignedElements[0];
97
+ }
98
+ }
99
+ // Fallback to the component itself
100
+ return this.component;
101
+ }
102
+ getComponentStyles() {
103
+ return this.component.constructor.styles;
104
+ }
105
+ }
106
+ //# sourceMappingURL=popover-portal-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"popover-portal-handler.js","sourceRoot":"","sources":["../../../src/nile-popover/popover-portal-handler.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 { PortalContentHandler, PortalConfig } from '../internal/portal-manager';\nimport type { CSSResultGroup } from 'lit';\n\nexport class PopoverPortalHandler implements PortalContentHandler {\n private clonedPopoverContent: HTMLElement | null = null;\n\n constructor(\n private component: any,\n private config: PortalConfig = {}\n ) {}\n\n createPortalContent(): HTMLElement {\n // Find the popover content in the shadow DOM (now it's always rendered but hidden when portal is enabled)\n const popoverBox = this.component.shadowRoot?.querySelector('.popover__box') as HTMLElement;\n if (!popoverBox) {\n // Fallback: create content directly\n return this.createFallbackContent();\n }\n\n // Clone the popover content for portal\n this.clonedPopoverContent = popoverBox.cloneNode(true) as HTMLElement;\n this.clonedPopoverContent.style.display = 'block';\n this.clonedPopoverContent.style.position = 'relative';\n \n return this.clonedPopoverContent;\n }\n\n private createFallbackContent(): HTMLElement {\n // Create the popover content directly as fallback\n this.clonedPopoverContent = document.createElement('div');\n this.clonedPopoverContent.className = 'popover__box';\n this.clonedPopoverContent.setAttribute('part', 'popover');\n this.clonedPopoverContent.style.display = 'block';\n this.clonedPopoverContent.style.position = 'relative';\n \n // Create the title element\n const titleElement = document.createElement('div');\n titleElement.className = 'popover__title';\n titleElement.textContent = this.component.title;\n \n // Create the base content slot\n const baseSlot = document.createElement('div');\n baseSlot.setAttribute('part', 'base');\n \n // Create the action slot\n const actionSlot = document.createElement('div');\n actionSlot.className = 'popover__action';\n \n // Append elements\n this.clonedPopoverContent.appendChild(titleElement);\n this.clonedPopoverContent.appendChild(baseSlot);\n this.clonedPopoverContent.appendChild(actionSlot);\n \n return this.clonedPopoverContent;\n }\n\n updatePortalContent(portalElement: HTMLElement): void {\n if (!this.component.isShow) {\n portalElement.style.display = 'none';\n return;\n }\n\n portalElement.style.display = 'block';\n\n // Update the content by cloning from the shadow DOM again\n const originalPopoverBox = this.component.shadowRoot?.querySelector('.popover__box') as HTMLElement;\n if (originalPopoverBox) {\n // Clone the updated content\n const updatedContent = originalPopoverBox.cloneNode(true) as HTMLElement;\n updatedContent.style.display = 'block';\n updatedContent.style.position = 'relative';\n \n // Replace the content\n portalElement.innerHTML = updatedContent.innerHTML;\n }\n }\n\n setupEventListeners(portalElement: HTMLElement): void {\n // Handle click events to prevent them from bubbling up\n portalElement.addEventListener('click', (event) => {\n event.stopPropagation();\n });\n\n // Handle any other popover-specific events\n // For example, if the popover has action buttons, we might need to handle those\n const actionSlot = portalElement.querySelector('slot[name=\"action\"]');\n if (actionSlot) {\n actionSlot.addEventListener('click', (event) => {\n event.stopPropagation();\n // Forward the event to the original component if needed\n this.component.dispatchEvent(new CustomEvent('nile-popover-action', {\n detail: { originalEvent: event },\n bubbles: true\n }));\n });\n }\n }\n\n cleanupEventListeners(portalElement: HTMLElement): void {\n // Remove all event listeners\n const newElement = portalElement.cloneNode(true) as HTMLElement;\n portalElement.parentNode?.replaceChild(newElement, portalElement);\n }\n\n getReferenceElement(): HTMLElement {\n // Get the anchor element from the slot\n const anchorSlot = this.component.shadowRoot?.querySelector('slot[name=\"anchor\"]') as HTMLSlotElement;\n if (anchorSlot) {\n const assignedElements = anchorSlot.assignedElements();\n if (assignedElements.length > 0) {\n return assignedElements[0] as HTMLElement;\n }\n }\n \n // Fallback to the component itself\n return this.component;\n }\n\n getComponentStyles(): CSSResultGroup | undefined {\n return (this.component.constructor as any).styles;\n }\n}\n"]}
@@ -0,0 +1 @@
1
+ export { NilePortalWrapper } from './nile-portal-wrapper.js';
@@ -0,0 +1,2 @@
1
+ export { NilePortalWrapper } from './nile-portal-wrapper.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/nile-portal-wrapper/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC","sourcesContent":["export { NilePortalWrapper } from './nile-portal-wrapper.js';\n"]}
@@ -0,0 +1,47 @@
1
+ import { LitElement } from 'lit';
2
+ import { type Placement, type Boundary } from '@floating-ui/dom';
3
+ export declare class NilePortalWrapper extends LitElement {
4
+ enabled: boolean;
5
+ targetElement: HTMLElement | null;
6
+ content: HTMLElement | null;
7
+ placement: Placement;
8
+ offset: number;
9
+ padding: number;
10
+ boundary: Boundary;
11
+ fallbackPlacements: Placement[];
12
+ strategy: 'absolute' | 'fixed';
13
+ className: string;
14
+ zIndex: number;
15
+ preserveStyles: boolean;
16
+ cloneContent: boolean;
17
+ private portalContainer;
18
+ private clonedContent;
19
+ private currentPlacement;
20
+ private currentMiddlewareData;
21
+ private measuredHeight;
22
+ private cleanupAutoUpdate;
23
+ private injectedStyleId;
24
+ private resizeObserver;
25
+ static styles: import("lit").CSSResult;
26
+ connectedCallback(): void;
27
+ disconnectedCallback(): void;
28
+ updated(changedProperties: Map<string | number | symbol, unknown>): void;
29
+ private setupPortal;
30
+ private createPortalContainer;
31
+ private createClonedContent;
32
+ private createPortalListbox;
33
+ private cloneOption;
34
+ private positionPortal;
35
+ private handleSizeMiddleware;
36
+ private applyPosition;
37
+ private fallbackPositioning;
38
+ private setupAutoUpdate;
39
+ private setupEventListeners;
40
+ private handleOptionClick;
41
+ private forwardEvent;
42
+ private findOriginalElement;
43
+ private injectStyles;
44
+ private extractStylesAsCSS;
45
+ private cleanup;
46
+ render(): import("lit-html").TemplateResult<1>;
47
+ }