@aquera/nile-elements 1.3.9-beta-1.4 → 1.4.0-beta-1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (602) hide show
  1. package/README.md +19 -0
  2. package/demo/index.css +1 -6
  3. package/demo/index.html +53 -202
  4. package/demo/index.js +10 -0
  5. package/dist/{fixture-1c49c014.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-5b79f853.cjs.js +395 -0
  8. package/dist/fixture-5b79f853.cjs.js.map +1 -0
  9. package/dist/fixture-73855806.cjs.js +395 -0
  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-cf7bfcf5.esm.js +569 -0
  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 +599 -268
  21. package/dist/internal/animate.cjs.js +1 -1
  22. package/dist/internal/animate.cjs.js.map +1 -1
  23. package/dist/internal/animate.esm.js +1 -1
  24. package/dist/nile-accordion/nile-accordian.test.cjs.js +1 -1
  25. package/dist/nile-accordion/nile-accordian.test.esm.js +1 -1
  26. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js +1 -1
  27. package/dist/nile-auto-complete/nile-auto-complete.test.esm.js +1 -1
  28. package/dist/nile-avatar/nile-avatar.test.cjs.js +1 -1
  29. package/dist/nile-avatar/nile-avatar.test.esm.js +1 -1
  30. package/dist/nile-badge/nile-badge.test.cjs.js +1 -1
  31. package/dist/nile-badge/nile-badge.test.esm.js +1 -1
  32. package/dist/nile-button/nile-button.test.cjs.js +1 -1
  33. package/dist/nile-button/nile-button.test.esm.js +1 -1
  34. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.cjs.js +1 -1
  35. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.esm.js +1 -1
  36. package/dist/nile-calendar/nile-calendar.cjs.js +1 -1
  37. package/dist/nile-calendar/nile-calendar.cjs.js.map +1 -1
  38. package/dist/nile-calendar/nile-calendar.css.cjs.js +1 -1
  39. package/dist/nile-calendar/nile-calendar.css.cjs.js.map +1 -1
  40. package/dist/nile-calendar/nile-calendar.css.esm.js +4 -0
  41. package/dist/nile-calendar/nile-calendar.esm.js +2 -0
  42. package/dist/nile-calendar/nile-calendar.test.cjs.js +1 -1
  43. package/dist/nile-calendar/nile-calendar.test.esm.js +1 -1
  44. package/dist/nile-card/nile-card.css.cjs.js +1 -1
  45. package/dist/nile-card/nile-card.css.cjs.js.map +1 -1
  46. package/dist/nile-card/nile-card.css.esm.js +1 -1
  47. package/dist/nile-card/nile-card.test.cjs.js +1 -1
  48. package/dist/nile-card/nile-card.test.esm.js +1 -1
  49. package/dist/nile-carousel/carousel-helpers.cjs.js +2 -0
  50. package/dist/nile-carousel/carousel-helpers.cjs.js.map +1 -0
  51. package/dist/nile-carousel/carousel-helpers.esm.js +1 -0
  52. package/dist/nile-carousel/index.cjs.js +2 -0
  53. package/dist/nile-carousel/index.cjs.js.map +1 -0
  54. package/dist/nile-carousel/index.esm.js +1 -0
  55. package/dist/nile-carousel/nile-carousel-item/index.cjs.js +2 -0
  56. package/dist/nile-carousel/nile-carousel-item/index.cjs.js.map +1 -0
  57. package/dist/nile-carousel/nile-carousel-item/index.esm.js +1 -0
  58. package/dist/nile-carousel/nile-carousel-item/nile-carousel-item.cjs.js +2 -0
  59. package/dist/nile-carousel/nile-carousel-item/nile-carousel-item.cjs.js.map +1 -0
  60. package/dist/nile-carousel/nile-carousel-item/nile-carousel-item.css.cjs.js +2 -0
  61. package/dist/nile-carousel/nile-carousel-item/nile-carousel-item.css.cjs.js.map +1 -0
  62. package/dist/nile-carousel/nile-carousel-item/nile-carousel-item.css.esm.js +18 -0
  63. package/dist/nile-carousel/nile-carousel-item/nile-carousel-item.esm.js +5 -0
  64. package/dist/nile-carousel/nile-carousel.cjs.js +2 -0
  65. package/dist/nile-carousel/nile-carousel.cjs.js.map +1 -0
  66. package/dist/nile-carousel/nile-carousel.css.cjs.js +2 -0
  67. package/dist/nile-carousel/nile-carousel.css.cjs.js.map +1 -0
  68. package/dist/nile-carousel/nile-carousel.css.esm.js +157 -0
  69. package/dist/nile-carousel/nile-carousel.esm.js +58 -0
  70. package/dist/nile-checkbox/nile-checkbox.test.cjs.js +1 -1
  71. package/dist/nile-checkbox/nile-checkbox.test.esm.js +1 -1
  72. package/dist/nile-chip/nile-chip.cjs.js +1 -1
  73. package/dist/nile-chip/nile-chip.cjs.js.map +1 -1
  74. package/dist/nile-chip/nile-chip.esm.js +9 -6
  75. package/dist/nile-chip/nile-chip.test.cjs.js +1 -1
  76. package/dist/nile-chip/nile-chip.test.esm.js +1 -1
  77. package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js +2 -0
  78. package/dist/nile-code-editor/backup_nile-code-editor copy.cjs.js.map +1 -0
  79. package/dist/nile-code-editor/backup_nile-code-editor copy.esm.js +1 -0
  80. package/dist/nile-date-picker/nile-date-picker.cjs.js +1 -1
  81. package/dist/nile-date-picker/nile-date-picker.cjs.js.map +1 -1
  82. package/dist/nile-date-picker/nile-date-picker.esm.js +7 -2
  83. package/dist/nile-dialog/nile-dialog.test.cjs.js +1 -1
  84. package/dist/nile-dialog/nile-dialog.test.esm.js +1 -1
  85. package/dist/nile-drawer/nile-drawer.test.cjs.js +1 -1
  86. package/dist/nile-drawer/nile-drawer.test.esm.js +1 -1
  87. package/dist/nile-dropdown/nile-dropdown.test.cjs.js +1 -1
  88. package/dist/nile-dropdown/nile-dropdown.test.esm.js +1 -1
  89. package/dist/nile-empty-state/nile-empty-state.test.cjs.js +1 -1
  90. package/dist/nile-empty-state/nile-empty-state.test.esm.js +1 -1
  91. package/dist/nile-error-message/nile-error-message.test.cjs.js +1 -1
  92. package/dist/nile-error-message/nile-error-message.test.esm.js +1 -1
  93. package/dist/nile-file-preview/nile-file-preview.test.cjs.js +1 -1
  94. package/dist/nile-file-preview/nile-file-preview.test.esm.js +1 -1
  95. package/dist/nile-file-upload/nile-file-upload.test.cjs.js +1 -1
  96. package/dist/nile-file-upload/nile-file-upload.test.esm.js +1 -1
  97. package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js +1 -1
  98. package/dist/nile-filter-chip/nile-filter-chip.test.esm.js +1 -1
  99. package/dist/nile-form-group/nile-form-group.test.cjs.js +1 -1
  100. package/dist/nile-form-group/nile-form-group.test.esm.js +1 -1
  101. package/dist/nile-form-help-text/nile-form-help-text.test.cjs.js +1 -1
  102. package/dist/nile-form-help-text/nile-form-help-text.test.esm.js +1 -1
  103. package/dist/nile-grid/nile-grid.types.cjs.js +2 -0
  104. package/dist/nile-grid/nile-grid.types.cjs.js.map +1 -0
  105. package/dist/nile-grid/nile-grid.types.esm.js +1 -0
  106. package/dist/nile-grid-body/index.cjs.js +2 -0
  107. package/dist/nile-grid-body/index.cjs.js.map +1 -0
  108. package/dist/nile-grid-body/index.esm.js +1 -0
  109. package/dist/nile-grid-body/nile-grid-body.cjs.js +2 -0
  110. package/dist/nile-grid-body/nile-grid-body.cjs.js.map +1 -0
  111. package/dist/nile-grid-body/nile-grid-body.css.cjs.js +2 -0
  112. package/dist/nile-grid-body/nile-grid-body.css.cjs.js.map +1 -0
  113. package/dist/nile-grid-body/nile-grid-body.css.esm.js +10 -0
  114. package/dist/nile-grid-body/nile-grid-body.esm.js +5 -0
  115. package/dist/nile-grid-cell-item/index.cjs.js +2 -0
  116. package/dist/nile-grid-cell-item/index.cjs.js.map +1 -0
  117. package/dist/nile-grid-cell-item/index.esm.js +1 -0
  118. package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js +2 -0
  119. package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js.map +1 -0
  120. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js +2 -0
  121. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js.map +1 -0
  122. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.esm.js +35 -0
  123. package/dist/nile-grid-cell-item/nile-grid-cell-item.esm.js +12 -0
  124. package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.cjs.js +2 -0
  125. package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.cjs.js.map +1 -0
  126. package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.esm.js +1 -0
  127. package/dist/nile-grid-head/index.cjs.js +2 -0
  128. package/dist/nile-grid-head/index.cjs.js.map +1 -0
  129. package/dist/nile-grid-head/index.esm.js +1 -0
  130. package/dist/nile-grid-head/nile-grid-head.cjs.js +2 -0
  131. package/dist/nile-grid-head/nile-grid-head.cjs.js.map +1 -0
  132. package/dist/nile-grid-head/nile-grid-head.css.cjs.js +2 -0
  133. package/dist/nile-grid-head/nile-grid-head.css.cjs.js.map +1 -0
  134. package/dist/nile-grid-head/nile-grid-head.css.esm.js +7 -0
  135. package/dist/nile-grid-head/nile-grid-head.esm.js +5 -0
  136. package/dist/nile-grid-head-item/index.cjs.js +2 -0
  137. package/dist/nile-grid-head-item/index.cjs.js.map +1 -0
  138. package/dist/nile-grid-head-item/index.esm.js +1 -0
  139. package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js +2 -0
  140. package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js.map +1 -0
  141. package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js +2 -0
  142. package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js.map +1 -0
  143. package/dist/nile-grid-head-item/nile-grid-head-item.css.esm.js +34 -0
  144. package/dist/nile-grid-head-item/nile-grid-head-item.esm.js +12 -0
  145. package/dist/nile-grid-head-item/nile-grid-head-item.utils.cjs.js +2 -0
  146. package/dist/nile-grid-head-item/nile-grid-head-item.utils.cjs.js.map +1 -0
  147. package/dist/nile-grid-head-item/nile-grid-head-item.utils.esm.js +1 -0
  148. package/dist/nile-grid-row/index.cjs.js +2 -0
  149. package/dist/nile-grid-row/index.cjs.js.map +1 -0
  150. package/dist/nile-grid-row/index.esm.js +1 -0
  151. package/dist/nile-grid-row/nile-grid-row.cjs.js +2 -0
  152. package/dist/nile-grid-row/nile-grid-row.cjs.js.map +1 -0
  153. package/dist/nile-grid-row/nile-grid-row.css.cjs.js +2 -0
  154. package/dist/nile-grid-row/nile-grid-row.css.cjs.js.map +1 -0
  155. package/dist/nile-grid-row/nile-grid-row.css.esm.js +15 -0
  156. package/dist/nile-grid-row/nile-grid-row.esm.js +7 -0
  157. package/dist/nile-hero/nile-hero.test.cjs.js +1 -1
  158. package/dist/nile-hero/nile-hero.test.esm.js +1 -1
  159. package/dist/nile-icon/nile-icon.test.cjs.js +1 -1
  160. package/dist/nile-icon/nile-icon.test.esm.js +1 -1
  161. package/dist/nile-icon-button/nile-icon-button.cjs.js +1 -1
  162. package/dist/nile-icon-button/nile-icon-button.cjs.js.map +1 -1
  163. package/dist/nile-icon-button/nile-icon-button.esm.js +2 -2
  164. package/dist/nile-inline-sidebar/nile-inline-sidebar.cjs.js +1 -1
  165. package/dist/nile-inline-sidebar/nile-inline-sidebar.cjs.js.map +1 -1
  166. package/dist/nile-inline-sidebar/nile-inline-sidebar.esm.js +2 -2
  167. package/dist/nile-input/nile-input.css.cjs.js +1 -1
  168. package/dist/nile-input/nile-input.css.cjs.js.map +1 -1
  169. package/dist/nile-input/nile-input.css.esm.js +1 -1
  170. package/dist/nile-input/nile-input.test.cjs.js +1 -1
  171. package/dist/nile-input/nile-input.test.esm.js +1 -1
  172. package/dist/nile-link/nile-link.test.cjs.js +1 -1
  173. package/dist/nile-link/nile-link.test.esm.js +1 -1
  174. package/dist/nile-loader/nile-loader.test.cjs.js +1 -1
  175. package/dist/nile-loader/nile-loader.test.esm.js +1 -1
  176. package/dist/nile-option-group/nile-option-group.cjs.js +1 -1
  177. package/dist/nile-option-group/nile-option-group.cjs.js.map +1 -1
  178. package/dist/nile-option-group/nile-option-group.css.cjs.js +1 -1
  179. package/dist/nile-option-group/nile-option-group.css.cjs.js.map +1 -1
  180. package/dist/nile-option-group/nile-option-group.css.esm.js +14 -0
  181. package/dist/nile-option-group/nile-option-group.esm.js +2 -2
  182. package/dist/nile-popover/nile-popover.test.cjs.js +1 -1
  183. package/dist/nile-popover/nile-popover.test.esm.js +1 -1
  184. package/dist/nile-popup/nile-popup.test.cjs.js +1 -1
  185. package/dist/nile-popup/nile-popup.test.esm.js +1 -1
  186. package/dist/nile-progress-bar/nile-progress-bar.test.cjs.js +1 -1
  187. package/dist/nile-progress-bar/nile-progress-bar.test.esm.js +1 -1
  188. package/dist/nile-radio/nile-radio.test.cjs.js +1 -1
  189. package/dist/nile-radio/nile-radio.test.esm.js +1 -1
  190. package/dist/nile-radio-group/nile-radio-group.test.cjs.js +1 -1
  191. package/dist/nile-radio-group/nile-radio-group.test.esm.js +1 -1
  192. package/dist/nile-rich-text-editor/utils.cjs.js +2 -0
  193. package/dist/nile-rich-text-editor/utils.cjs.js.map +1 -0
  194. package/dist/nile-rich-text-editor/utils.esm.js +1 -0
  195. package/dist/nile-select/nile-select.cjs.js +1 -1
  196. package/dist/nile-select/nile-select.cjs.js.map +1 -1
  197. package/dist/nile-select/nile-select.css.cjs.js +1 -1
  198. package/dist/nile-select/nile-select.css.cjs.js.map +1 -1
  199. package/dist/nile-select/nile-select.css.esm.js +4 -2
  200. package/dist/nile-select/nile-select.esm.js +2 -2
  201. package/dist/nile-select/nile-select.test.cjs.js +1 -1
  202. package/dist/nile-select/nile-select.test.esm.js +1 -1
  203. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.cjs.js +1 -1
  204. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.cjs.js.map +1 -1
  205. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.css.esm.js +2 -10
  206. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.css.cjs.js +1 -1
  207. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.css.cjs.js.map +1 -1
  208. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.css.esm.js +1 -1
  209. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.cjs.js +1 -1
  210. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.cjs.js.map +1 -1
  211. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.esm.js +4 -4
  212. package/dist/nile-sidebar/index.cjs.js +2 -0
  213. package/dist/nile-sidebar/index.cjs.js.map +1 -0
  214. package/dist/nile-sidebar/index.esm.js +75 -0
  215. package/dist/nile-sidebar-menu/index.cjs.js +2 -0
  216. package/dist/nile-sidebar-menu/index.cjs.js.map +1 -0
  217. package/dist/nile-sidebar-menu/index.esm.js +1 -0
  218. package/dist/nile-sidebar-menu/nile-sidebar-menu.cjs.js +2 -0
  219. package/dist/nile-sidebar-menu/nile-sidebar-menu.cjs.js.map +1 -0
  220. package/dist/nile-sidebar-menu/nile-sidebar-menu.css.cjs.js +2 -0
  221. package/dist/nile-sidebar-menu/nile-sidebar-menu.css.cjs.js.map +1 -0
  222. package/dist/nile-sidebar-menu/nile-sidebar-menu.css.esm.js +38 -0
  223. package/dist/nile-sidebar-menu/nile-sidebar-menu.esm.js +10 -0
  224. package/dist/nile-sidebar-menu-items/index.cjs.js +2 -0
  225. package/dist/nile-sidebar-menu-items/index.cjs.js.map +1 -0
  226. package/dist/nile-sidebar-menu-items/index.esm.js +1 -0
  227. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.cjs.js +2 -0
  228. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.cjs.js.map +1 -0
  229. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.css.cjs.js +2 -0
  230. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.css.cjs.js.map +1 -0
  231. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.css.esm.js +36 -0
  232. package/dist/nile-sidebar-menu-items/nile-sidebar-menu-items.esm.js +15 -0
  233. package/dist/nile-sidebar-wrapper/index.cjs.js +2 -0
  234. package/dist/nile-sidebar-wrapper/index.cjs.js.map +1 -0
  235. package/dist/nile-sidebar-wrapper/index.esm.js +1 -0
  236. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.cjs.js +2 -0
  237. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.cjs.js.map +1 -0
  238. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.css.cjs.js +2 -0
  239. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.css.cjs.js.map +1 -0
  240. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.css.esm.js +105 -0
  241. package/dist/nile-sidebar-wrapper/nile-sidebar-wrapper.esm.js +16 -0
  242. package/dist/nile-skeleton-loader/index.cjs.js +2 -0
  243. package/dist/nile-skeleton-loader/index.cjs.js.map +1 -0
  244. package/dist/nile-skeleton-loader/index.esm.js +1 -0
  245. package/dist/nile-skeleton-loader/nile-skeleton-loader.cjs.js +2 -0
  246. package/dist/nile-skeleton-loader/nile-skeleton-loader.cjs.js.map +1 -0
  247. package/dist/nile-skeleton-loader/nile-skeleton-loader.css.cjs.js +2 -0
  248. package/dist/nile-skeleton-loader/nile-skeleton-loader.css.cjs.js.map +1 -0
  249. package/dist/nile-skeleton-loader/nile-skeleton-loader.css.esm.js +49 -0
  250. package/dist/nile-skeleton-loader/nile-skeleton-loader.esm.js +16 -0
  251. package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js +1 -1
  252. package/dist/nile-slide-toggle/nile-slide-toggle.test.esm.js +1 -1
  253. package/dist/nile-tab-group/nile-tab-group.test.cjs.js +1 -1
  254. package/dist/nile-tab-group/nile-tab-group.test.esm.js +1 -1
  255. package/dist/nile-tag/nile-tag.cjs.js +1 -1
  256. package/dist/nile-tag/nile-tag.cjs.js.map +1 -1
  257. package/dist/nile-tag/nile-tag.esm.js +3 -2
  258. package/dist/nile-textarea/nile-textarea.test.cjs.js +1 -1
  259. package/dist/nile-textarea/nile-textarea.test.esm.js +1 -1
  260. package/dist/nile-tooltip/nile-tooltip.cjs.js +1 -1
  261. package/dist/nile-tooltip/nile-tooltip.esm.js +1 -1
  262. package/dist/nile-virtual-select/group-manager.cjs.js +2 -0
  263. package/dist/nile-virtual-select/group-manager.cjs.js.map +1 -0
  264. package/dist/nile-virtual-select/group-manager.esm.js +1 -0
  265. package/dist/nile-virtual-select/nile-virtual-select.test.cjs.js +1 -1
  266. package/dist/nile-virtual-select/nile-virtual-select.test.esm.js +1 -1
  267. package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js +2 -0
  268. package/dist/nile-virtual-select/temp_nile-virtual-select copy.cjs.js.map +1 -0
  269. package/dist/nile-virtual-select/temp_nile-virtual-select copy.esm.js +231 -0
  270. package/dist/scopedElementsWrapper-1bff26ef.cjs.js +2 -0
  271. package/dist/scopedElementsWrapper-1bff26ef.cjs.js.map +1 -0
  272. package/dist/scopedElementsWrapper-4c29be11.esm.js +7 -0
  273. package/dist/scopedElementsWrapper-a112fc73.cjs.js +6 -0
  274. package/dist/scopedElementsWrapper-a112fc73.cjs.js.map +1 -0
  275. package/dist/scopedElementsWrapper-c815042c.cjs.js +2 -0
  276. package/dist/scopedElementsWrapper-c815042c.cjs.js.map +1 -0
  277. package/dist/src/index.d.ts +3 -0
  278. package/dist/src/index.js +3 -0
  279. package/dist/src/index.js.map +1 -1
  280. package/dist/src/internal/portal-manager.d.ts +53 -0
  281. package/dist/src/internal/portal-manager.js +196 -0
  282. package/dist/src/internal/portal-manager.js.map +1 -0
  283. package/dist/src/internal/portal.d.ts +60 -0
  284. package/dist/src/internal/portal.js +199 -0
  285. package/dist/src/internal/portal.js.map +1 -0
  286. package/dist/src/internal/resizable-helper.d.ts +59 -0
  287. package/dist/src/internal/resizable-helper.js +115 -0
  288. package/dist/src/internal/resizable-helper.js.map +1 -0
  289. package/dist/src/internal/resizable-styles.d.ts +16 -0
  290. package/dist/src/internal/resizable-styles.js +144 -0
  291. package/dist/src/internal/resizable-styles.js.map +1 -0
  292. package/dist/src/internal/virtualizer-error-handler.d.ts +30 -0
  293. package/dist/src/internal/virtualizer-error-handler.js +82 -0
  294. package/dist/src/internal/virtualizer-error-handler.js.map +1 -0
  295. package/dist/src/lib/index.d.ts +7 -0
  296. package/dist/src/lib/index.js +8 -0
  297. package/dist/src/lib/index.js.map +1 -0
  298. package/dist/src/lib/virtualize.d.ts +32 -0
  299. package/dist/src/lib/virtualize.js +105 -0
  300. package/dist/src/lib/virtualize.js.map +1 -0
  301. package/dist/src/lib/virtualize.test.d.ts +7 -0
  302. package/dist/src/lib/virtualize.test.js +57 -0
  303. package/dist/src/lib/virtualize.test.js.map +1 -0
  304. package/dist/src/nile-badge/__snapshots__/nile-badge.test.snap.js +17 -0
  305. package/dist/src/nile-calendar/__snapshots__/nile-calendar.test.snap.js +310 -0
  306. package/dist/src/nile-calendar/nile-calendar.css.js +4 -0
  307. package/dist/src/nile-calendar/nile-calendar.css.js.map +1 -1
  308. package/dist/src/nile-calendar/nile-calendar.js +2 -0
  309. package/dist/src/nile-calendar/nile-calendar.js.map +1 -1
  310. package/dist/src/nile-card/__snapshots__/nile-card.test.snap.js +34 -0
  311. package/dist/src/nile-card/nile-card.css.js +1 -1
  312. package/dist/src/nile-card/nile-card.css.js.map +1 -1
  313. package/dist/src/nile-carousel/carousel-helpers.d.ts +18 -0
  314. package/dist/src/nile-carousel/carousel-helpers.js +53 -0
  315. package/dist/src/nile-carousel/carousel-helpers.js.map +1 -0
  316. package/dist/src/nile-carousel/index.d.ts +1 -0
  317. package/dist/src/nile-carousel/index.js +2 -0
  318. package/dist/src/nile-carousel/index.js.map +1 -0
  319. package/dist/src/nile-carousel/nile-carousel-item/index.d.ts +1 -0
  320. package/dist/src/nile-carousel/nile-carousel-item/index.js +2 -0
  321. package/dist/src/nile-carousel/nile-carousel-item/index.js.map +1 -0
  322. package/dist/src/nile-carousel/nile-carousel-item/nile-carousel-item.css.d.ts +12 -0
  323. package/dist/src/nile-carousel/nile-carousel-item/nile-carousel-item.css.js +30 -0
  324. package/dist/src/nile-carousel/nile-carousel-item/nile-carousel-item.css.js.map +1 -0
  325. package/dist/src/nile-carousel/nile-carousel-item/nile-carousel-item.d.ts +24 -0
  326. package/dist/src/nile-carousel/nile-carousel-item/nile-carousel-item.js +35 -0
  327. package/dist/src/nile-carousel/nile-carousel-item/nile-carousel-item.js.map +1 -0
  328. package/dist/src/nile-carousel/nile-carousel.css.d.ts +12 -0
  329. package/dist/src/nile-carousel/nile-carousel.css.js +169 -0
  330. package/dist/src/nile-carousel/nile-carousel.css.js.map +1 -0
  331. package/dist/src/nile-carousel/nile-carousel.d.ts +56 -0
  332. package/dist/src/nile-carousel/nile-carousel.js +340 -0
  333. package/dist/src/nile-carousel/nile-carousel.js.map +1 -0
  334. package/dist/src/nile-checkbox/__snapshots__/nile-checkbox.test.snap.js +31 -0
  335. package/dist/src/nile-chip/nile-chip.d.ts +4 -0
  336. package/dist/src/nile-chip/nile-chip.js +33 -0
  337. package/dist/src/nile-chip/nile-chip.js.map +1 -1
  338. package/dist/src/nile-code-editor/Old_theme copy.d.ts +191 -0
  339. package/dist/src/nile-code-editor/Old_theme copy.js +193 -0
  340. package/dist/src/nile-code-editor/Old_theme copy.js.map +1 -0
  341. package/dist/src/nile-code-editor/backup_nile-code-editor copy.d.ts +0 -0
  342. package/dist/src/nile-code-editor/backup_nile-code-editor copy.js +675 -0
  343. package/dist/src/nile-code-editor/backup_nile-code-editor copy.js.map +1 -0
  344. package/dist/src/nile-code-editor/theme copy.d.ts +191 -0
  345. package/dist/src/nile-code-editor/theme copy.js +193 -0
  346. package/dist/src/nile-code-editor/theme copy.js.map +1 -0
  347. package/dist/src/nile-date-picker/nile-date-picker.d.ts +4 -0
  348. package/dist/src/nile-date-picker/nile-date-picker.js +19 -0
  349. package/dist/src/nile-date-picker/nile-date-picker.js.map +1 -1
  350. package/dist/src/nile-grid/data-processor.d.ts +37 -0
  351. package/dist/src/nile-grid/data-processor.js +122 -0
  352. package/dist/src/nile-grid/data-processor.js.map +1 -0
  353. package/dist/src/nile-grid/event-handlers.d.ts +35 -0
  354. package/dist/src/nile-grid/event-handlers.js +158 -0
  355. package/dist/src/nile-grid/event-handlers.js.map +1 -0
  356. package/dist/src/nile-grid/nile-grid.types.d.ts +3 -0
  357. package/dist/src/nile-grid/nile-grid.types.js +2 -0
  358. package/dist/src/nile-grid/nile-grid.types.js.map +1 -0
  359. package/dist/src/nile-grid/renderer.d.ts +8 -0
  360. package/dist/src/nile-grid/renderer.js +78 -0
  361. package/dist/src/nile-grid/renderer.js.map +1 -0
  362. package/dist/src/nile-grid/resize-handler.d.ts +4 -0
  363. package/dist/src/nile-grid/resize-handler.js +36 -0
  364. package/dist/src/nile-grid/resize-handler.js.map +1 -0
  365. package/dist/src/nile-grid/types.d.ts +32 -0
  366. package/dist/src/nile-grid/types.js +2 -0
  367. package/dist/src/nile-grid/types.js.map +1 -0
  368. package/dist/src/nile-grid/utils.d.ts +4 -0
  369. package/dist/src/nile-grid/utils.js +32 -0
  370. package/dist/src/nile-grid/utils.js.map +1 -0
  371. package/dist/src/nile-grid-body/index.d.ts +1 -0
  372. package/dist/src/nile-grid-body/index.js +2 -0
  373. package/dist/src/nile-grid-body/index.js.map +1 -0
  374. package/dist/src/nile-grid-body/nile-grid-body.css.d.ts +12 -0
  375. package/dist/src/nile-grid-body/nile-grid-body.css.js +22 -0
  376. package/dist/src/nile-grid-body/nile-grid-body.css.js.map +1 -0
  377. package/dist/src/nile-grid-body/nile-grid-body.d.ts +29 -0
  378. package/dist/src/nile-grid-body/nile-grid-body.js +43 -0
  379. package/dist/src/nile-grid-body/nile-grid-body.js.map +1 -0
  380. package/dist/src/nile-grid-cell-item/index.d.ts +1 -0
  381. package/dist/src/nile-grid-cell-item/index.js +2 -0
  382. package/dist/src/nile-grid-cell-item/index.js.map +1 -0
  383. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.d.ts +12 -0
  384. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js +47 -0
  385. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js.map +1 -0
  386. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.d.ts +36 -0
  387. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js +93 -0
  388. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js.map +1 -0
  389. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.d.ts +10 -0
  390. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.js +34 -0
  391. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.js.map +1 -0
  392. package/dist/src/nile-grid-head/index.d.ts +1 -0
  393. package/dist/src/nile-grid-head/index.js +2 -0
  394. package/dist/src/nile-grid-head/index.js.map +1 -0
  395. package/dist/src/nile-grid-head/nile-grid-head.css.d.ts +12 -0
  396. package/dist/src/nile-grid-head/nile-grid-head.css.js +19 -0
  397. package/dist/src/nile-grid-head/nile-grid-head.css.js.map +1 -0
  398. package/dist/src/nile-grid-head/nile-grid-head.d.ts +28 -0
  399. package/dist/src/nile-grid-head/nile-grid-head.js +41 -0
  400. package/dist/src/nile-grid-head/nile-grid-head.js.map +1 -0
  401. package/dist/src/nile-grid-head-item/index.d.ts +1 -0
  402. package/dist/src/nile-grid-head-item/index.js +2 -0
  403. package/dist/src/nile-grid-head-item/index.js.map +1 -0
  404. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.d.ts +12 -0
  405. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js +46 -0
  406. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js.map +1 -0
  407. package/dist/src/nile-grid-head-item/nile-grid-head-item.d.ts +37 -0
  408. package/dist/src/nile-grid-head-item/nile-grid-head-item.js +100 -0
  409. package/dist/src/nile-grid-head-item/nile-grid-head-item.js.map +1 -0
  410. package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.d.ts +10 -0
  411. package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.js +34 -0
  412. package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.js.map +1 -0
  413. package/dist/src/nile-grid-row/index.d.ts +1 -0
  414. package/dist/src/nile-grid-row/index.js +2 -0
  415. package/dist/src/nile-grid-row/index.js.map +1 -0
  416. package/dist/src/nile-grid-row/nile-grid-row.css.d.ts +12 -0
  417. package/dist/src/nile-grid-row/nile-grid-row.css.js +27 -0
  418. package/dist/src/nile-grid-row/nile-grid-row.css.js.map +1 -0
  419. package/dist/src/nile-grid-row/nile-grid-row.d.ts +29 -0
  420. package/dist/src/nile-grid-row/nile-grid-row.js +45 -0
  421. package/dist/src/nile-grid-row/nile-grid-row.js.map +1 -0
  422. package/dist/src/nile-hero/__snapshots__/nile-hero.test.snap.js +47 -0
  423. package/dist/src/nile-icon/__snapshots__/nile-icon.test.snap.js +16 -0
  424. package/dist/src/nile-icon-button/nile-icon-button.js +2 -2
  425. package/dist/src/nile-icon-button/nile-icon-button.js.map +1 -1
  426. package/dist/src/nile-inline-sidebar/nile-inline-sidebar.js +2 -2
  427. package/dist/src/nile-inline-sidebar/nile-inline-sidebar.js.map +1 -1
  428. package/dist/src/nile-input/__snapshots__/nile-input.test.snap.js +75 -0
  429. package/dist/src/nile-input/nile-input.css.js +1 -1
  430. package/dist/src/nile-input/nile-input.css.js.map +1 -1
  431. package/dist/src/nile-menu/portal-manager.d.ts +39 -0
  432. package/dist/src/nile-menu/portal-manager.js +340 -0
  433. package/dist/src/nile-menu/portal-manager.js.map +1 -0
  434. package/dist/src/nile-menu/portal-utils.d.ts +21 -0
  435. package/dist/src/nile-menu/portal-utils.js +128 -0
  436. package/dist/src/nile-menu/portal-utils.js.map +1 -0
  437. package/dist/src/nile-option-group/nile-option-group.css.js +14 -0
  438. package/dist/src/nile-option-group/nile-option-group.css.js.map +1 -1
  439. package/dist/src/nile-option-group/nile-option-group.d.ts +1 -0
  440. package/dist/src/nile-option-group/nile-option-group.js +4 -0
  441. package/dist/src/nile-option-group/nile-option-group.js.map +1 -1
  442. package/dist/src/nile-popover/__snapshots__/nile-popover.test.snap.js +22 -0
  443. package/dist/src/nile-popover/popover-portal-handler.d.ts +21 -0
  444. package/dist/src/nile-popover/popover-portal-handler.js +106 -0
  445. package/dist/src/nile-popover/popover-portal-handler.js.map +1 -0
  446. package/dist/src/nile-portal-wrapper/index.d.ts +1 -0
  447. package/dist/src/nile-portal-wrapper/index.js +2 -0
  448. package/dist/src/nile-portal-wrapper/index.js.map +1 -0
  449. package/dist/src/nile-portal-wrapper/nile-portal-wrapper.d.ts +47 -0
  450. package/dist/src/nile-portal-wrapper/nile-portal-wrapper.js +451 -0
  451. package/dist/src/nile-portal-wrapper/nile-portal-wrapper.js.map +1 -0
  452. package/dist/src/nile-rich-text-editor/utils.d.ts +13 -0
  453. package/dist/src/nile-rich-text-editor/utils.js +538 -0
  454. package/dist/src/nile-rich-text-editor/utils.js.map +1 -0
  455. package/dist/src/nile-select/body-append-manager.d.ts +90 -0
  456. package/dist/src/nile-select/body-append-manager.js +298 -0
  457. package/dist/src/nile-select/body-append-manager.js.map +1 -0
  458. package/dist/src/nile-select/nile-select.css.js +4 -2
  459. package/dist/src/nile-select/nile-select.css.js.map +1 -1
  460. package/dist/src/nile-select/nile-select.d.ts +3 -0
  461. package/dist/src/nile-select/nile-select.js +32 -0
  462. package/dist/src/nile-select/nile-select.js.map +1 -1
  463. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.js +1 -9
  464. package/dist/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.js.map +1 -1
  465. package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.js +1 -1
  466. package/dist/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.js.map +1 -1
  467. package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.js +2 -2
  468. package/dist/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.js.map +1 -1
  469. package/dist/src/nile-sidebar/index.d.ts +28 -0
  470. package/dist/src/nile-sidebar/index.js +116 -0
  471. package/dist/src/nile-sidebar/index.js.map +1 -0
  472. package/dist/src/nile-sidebar-menu/index.d.ts +1 -0
  473. package/dist/src/nile-sidebar-menu/index.js +2 -0
  474. package/dist/src/nile-sidebar-menu/index.js.map +1 -0
  475. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.css.d.ts +12 -0
  476. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.css.js +47 -0
  477. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.css.js.map +1 -0
  478. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.d.ts +37 -0
  479. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.js +84 -0
  480. package/dist/src/nile-sidebar-menu/nile-sidebar-menu.js.map +1 -0
  481. package/dist/src/nile-sidebar-menu-items/index.d.ts +1 -0
  482. package/dist/src/nile-sidebar-menu-items/index.js +2 -0
  483. package/dist/src/nile-sidebar-menu-items/index.js.map +1 -0
  484. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.d.ts +12 -0
  485. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.js +45 -0
  486. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.css.js.map +1 -0
  487. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.d.ts +35 -0
  488. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.js +78 -0
  489. package/dist/src/nile-sidebar-menu-items/nile-sidebar-menu-items.js.map +1 -0
  490. package/dist/src/nile-sidebar-wrapper/index.d.ts +1 -0
  491. package/dist/src/nile-sidebar-wrapper/index.js +2 -0
  492. package/dist/src/nile-sidebar-wrapper/index.js.map +1 -0
  493. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.d.ts +12 -0
  494. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.js +114 -0
  495. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.css.js.map +1 -0
  496. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.d.ts +35 -0
  497. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.js +89 -0
  498. package/dist/src/nile-sidebar-wrapper/nile-sidebar-wrapper.js.map +1 -0
  499. package/dist/src/nile-skeleton-loader/index.d.ts +1 -0
  500. package/dist/src/nile-skeleton-loader/index.js +2 -0
  501. package/dist/src/nile-skeleton-loader/index.js.map +1 -0
  502. package/dist/src/nile-skeleton-loader/nile-skeleton-loader.css.d.ts +3 -0
  503. package/dist/src/nile-skeleton-loader/nile-skeleton-loader.css.js +52 -0
  504. package/dist/src/nile-skeleton-loader/nile-skeleton-loader.css.js.map +1 -0
  505. package/dist/src/nile-skeleton-loader/nile-skeleton-loader.d.ts +20 -0
  506. package/dist/src/nile-skeleton-loader/nile-skeleton-loader.js +104 -0
  507. package/dist/src/nile-skeleton-loader/nile-skeleton-loader.js.map +1 -0
  508. package/dist/src/nile-table-body/virtual-scroll-helper.d.ts +9 -0
  509. package/dist/src/nile-table-body/virtual-scroll-helper.js +24 -0
  510. package/dist/src/nile-table-body/virtual-scroll-helper.js.map +1 -0
  511. package/dist/src/nile-tag/nile-tag.d.ts +2 -0
  512. package/dist/src/nile-tag/nile-tag.js +6 -0
  513. package/dist/src/nile-tag/nile-tag.js.map +1 -1
  514. package/dist/src/nile-virtual-select/body-append-helper.d.ts +16 -0
  515. package/dist/src/nile-virtual-select/body-append-helper.js +95 -0
  516. package/dist/src/nile-virtual-select/body-append-helper.js.map +1 -0
  517. package/dist/src/nile-virtual-select/group-manager.d.ts +32 -0
  518. package/dist/src/nile-virtual-select/group-manager.js +134 -0
  519. package/dist/src/nile-virtual-select/group-manager.js.map +1 -0
  520. package/dist/src/nile-virtual-select/portal-utils.d.ts +65 -0
  521. package/dist/src/nile-virtual-select/portal-utils.js +376 -0
  522. package/dist/src/nile-virtual-select/portal-utils.js.map +1 -0
  523. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.d.ts +273 -0
  524. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js +1305 -0
  525. package/dist/src/nile-virtual-select/temp_nile-virtual-select copy.js.map +1 -0
  526. package/dist/src/nile-virtual-select/virtualizer-error-handler.d.ts +21 -0
  527. package/dist/src/nile-virtual-select/virtualizer-error-handler.js +56 -0
  528. package/dist/src/nile-virtual-select/virtualizer-error-handler.js.map +1 -0
  529. package/dist/src/nile-virtual-select-disabled/index.d.ts +1 -0
  530. package/dist/src/nile-virtual-select-disabled/index.js +2 -0
  531. package/dist/src/nile-virtual-select-disabled/index.js.map +1 -0
  532. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.css.d.ts +12 -0
  533. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.css.js +538 -0
  534. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.css.js.map +1 -0
  535. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.d.ts +299 -0
  536. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.js +1441 -0
  537. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.js.map +1 -0
  538. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.test.d.ts +7 -0
  539. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.test.js +631 -0
  540. package/dist/src/nile-virtual-select-disabled/nile-virtual-select.test.js.map +1 -0
  541. package/dist/src/nile-virtual-select-disabled/portal-manager.d.ts +45 -0
  542. package/dist/src/nile-virtual-select-disabled/portal-manager.js +333 -0
  543. package/dist/src/nile-virtual-select-disabled/portal-manager.js.map +1 -0
  544. package/dist/src/nile-virtual-select-disabled/renderer.d.ts +16 -0
  545. package/dist/src/nile-virtual-select-disabled/renderer.js +79 -0
  546. package/dist/src/nile-virtual-select-disabled/renderer.js.map +1 -0
  547. package/dist/src/nile-virtual-select-disabled/search-manager.d.ts +12 -0
  548. package/dist/src/nile-virtual-select-disabled/search-manager.js +40 -0
  549. package/dist/src/nile-virtual-select-disabled/search-manager.js.map +1 -0
  550. package/dist/src/nile-virtual-select-disabled/selection-manager.d.ts +12 -0
  551. package/dist/src/nile-virtual-select-disabled/selection-manager.js +64 -0
  552. package/dist/src/nile-virtual-select-disabled/selection-manager.js.map +1 -0
  553. package/dist/src/nile-virtual-select-disabled/types.d.ts +50 -0
  554. package/dist/src/nile-virtual-select-disabled/types.js +8 -0
  555. package/dist/src/nile-virtual-select-disabled/types.js.map +1 -0
  556. package/dist/src/nile-virtual-table-body/index.d.ts +2 -0
  557. package/dist/src/nile-virtual-table-body/index.js +3 -0
  558. package/dist/src/nile-virtual-table-body/index.js.map +1 -0
  559. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.d.ts +1 -0
  560. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js +44 -0
  561. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.css.js.map +1 -0
  562. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.d.ts +50 -0
  563. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js +135 -0
  564. package/dist/src/nile-virtual-table-body/nile-virtual-table-body.js.map +1 -0
  565. package/dist/src/nile-virtual-table-body/renderer.d.ts +16 -0
  566. package/dist/src/nile-virtual-table-body/renderer.js +49 -0
  567. package/dist/src/nile-virtual-table-body/renderer.js.map +1 -0
  568. package/dist/src/utilities/stepper-utils.d.ts +71 -0
  569. package/dist/src/utilities/stepper-utils.js +108 -0
  570. package/dist/src/utilities/stepper-utils.js.map +1 -0
  571. package/dist/src/version.js +2 -2
  572. package/dist/src/version.js.map +1 -1
  573. package/dist/tsconfig.tsbuildinfo +1 -1
  574. package/package.json +1 -1
  575. package/src/index.ts +3 -0
  576. package/src/nile-calendar/nile-calendar.css.ts +4 -0
  577. package/src/nile-calendar/nile-calendar.ts +2 -0
  578. package/src/nile-card/nile-card.css.ts +1 -1
  579. package/src/nile-carousel/carousel-helpers.ts +83 -0
  580. package/src/nile-carousel/index.ts +2 -0
  581. package/src/nile-carousel/nile-carousel-item/index.ts +2 -0
  582. package/src/nile-carousel/nile-carousel-item/nile-carousel-item.css.ts +33 -0
  583. package/src/nile-carousel/nile-carousel-item/nile-carousel-item.ts +42 -0
  584. package/src/nile-carousel/nile-carousel.css.ts +172 -0
  585. package/src/nile-carousel/nile-carousel.ts +404 -0
  586. package/src/nile-chip/nile-chip.ts +34 -0
  587. package/src/nile-date-picker/nile-date-picker.ts +12 -0
  588. package/src/nile-icon-button/nile-icon-button.ts +2 -2
  589. package/src/nile-inline-sidebar/nile-inline-sidebar.ts +2 -2
  590. package/src/nile-input/nile-input.css.ts +1 -1
  591. package/src/nile-option-group/nile-option-group.css.ts +14 -0
  592. package/src/nile-option-group/nile-option-group.ts +1 -0
  593. package/src/nile-select/nile-select.css.ts +4 -2
  594. package/src/nile-select/nile-select.ts +33 -2
  595. package/src/nile-side-bar-footer-item/nile-side-bar-footer-item.css.ts +1 -9
  596. package/src/nile-side-bar-footer-text/nile-side-bar-footer-text.css.ts +1 -1
  597. package/src/nile-side-bar-group-item-text/nile-side-bar-group-item-text.css.ts +2 -2
  598. package/src/nile-skeleton-loader/index.ts +2 -0
  599. package/src/nile-skeleton-loader/nile-skeleton-loader.css.ts +54 -0
  600. package/src/nile-skeleton-loader/nile-skeleton-loader.ts +106 -0
  601. package/src/nile-tag/nile-tag.ts +4 -0
  602. package/vscode-html-custom-data.json +138 -21
@@ -0,0 +1,90 @@
1
+ /**
2
+ * Copyright Aquera Inc 2023
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 type NilePopup from '../nile-popup/nile-popup';
8
+ import type NileSelect from './nile-select';
9
+ /**
10
+ * Manager class for handling bodyAppend functionality in nile-select
11
+ * This class manages moving select options to document.body to avoid CSS clipping issues
12
+ */
13
+ export declare class BodyAppendManager {
14
+ private bodyContainer?;
15
+ private originalOptions;
16
+ private boundHandlePopupReposition?;
17
+ private selectElement;
18
+ private popup?;
19
+ private listbox?;
20
+ private injectedStyleId?;
21
+ constructor(selectElement: NileSelect);
22
+ /**
23
+ * Sets the popup and listbox references
24
+ */
25
+ setReferences(popup: NilePopup, listbox: HTMLSlotElement): void;
26
+ /**
27
+ * Handles the bodyAppend change
28
+ */
29
+ handleBodyAppendChange(bodyAppend: boolean): void;
30
+ /**
31
+ * Handles popup reposition events to update body container position
32
+ */
33
+ private handlePopupReposition;
34
+ /**
35
+ * Extracts styles as CSS string from various style formats
36
+ */
37
+ private extractStylesAsCSS;
38
+ /**
39
+ * Injects component styles into document head
40
+ */
41
+ private injectStylesToDocument;
42
+ /**
43
+ * Adopts component styles to the body container (similar to portal-manager pattern)
44
+ */
45
+ private adoptStylesToBodyContainer;
46
+ /**
47
+ * Creates a body container for options when bodyAppend is true
48
+ */
49
+ private createBodyContainer;
50
+ /**
51
+ * Cleans up the body container
52
+ */
53
+ private cleanupBodyContainer;
54
+ /**
55
+ * Moves options to body container when bodyAppend is true
56
+ */
57
+ private moveOptionsToBody;
58
+ /**
59
+ * Restores options to their original position
60
+ */
61
+ private restoreOptionsFromBody;
62
+ /**
63
+ * Updates body container visibility and positioning
64
+ */
65
+ private updateBodyContainerVisibility;
66
+ /**
67
+ * Gets all options from both original location and body container
68
+ */
69
+ private getAllOptions;
70
+ /**
71
+ * Updates body container visibility when select opens/closes
72
+ */
73
+ updateVisibility(visible: boolean): void;
74
+ /**
75
+ * Checks if bodyAppend is active (has body container)
76
+ */
77
+ isActive(): boolean;
78
+ /**
79
+ * Gets the body container element
80
+ */
81
+ getBodyContainer(): HTMLElement | undefined;
82
+ /**
83
+ * Gets the listbox container element inside the body container
84
+ */
85
+ getListboxContainer(): HTMLElement | undefined;
86
+ /**
87
+ * Cleans up all resources
88
+ */
89
+ destroy(): void;
90
+ }
@@ -0,0 +1,298 @@
1
+ /**
2
+ * Copyright Aquera Inc 2023
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
+ /**
8
+ * Manager class for handling bodyAppend functionality in nile-select
9
+ * This class manages moving select options to document.body to avoid CSS clipping issues
10
+ */
11
+ export class BodyAppendManager {
12
+ constructor(selectElement) {
13
+ this.originalOptions = [];
14
+ this.selectElement = selectElement;
15
+ }
16
+ /**
17
+ * Sets the popup and listbox references
18
+ */
19
+ setReferences(popup, listbox) {
20
+ this.popup = popup;
21
+ this.listbox = listbox;
22
+ }
23
+ /**
24
+ * Handles the bodyAppend change
25
+ */
26
+ handleBodyAppendChange(bodyAppend) {
27
+ if (bodyAppend) {
28
+ // Initialize body container when bodyAppend becomes true
29
+ this.createBodyContainer();
30
+ // Move options to body immediately
31
+ this.moveOptionsToBody();
32
+ // If no options were found, retry after a short delay
33
+ if (this.getAllOptions().length === 0) {
34
+ setTimeout(() => {
35
+ this.moveOptionsToBody();
36
+ }, 100);
37
+ }
38
+ // Listen for popup reposition events
39
+ this.boundHandlePopupReposition = this.handlePopupReposition.bind(this);
40
+ this.popup?.addEventListener('reposition', this.boundHandlePopupReposition);
41
+ }
42
+ else {
43
+ // Restore options from body when bodyAppend becomes false
44
+ this.restoreOptionsFromBody();
45
+ // Clean up body container when bodyAppend becomes false
46
+ this.cleanupBodyContainer();
47
+ // Remove popup reposition listener
48
+ if (this.boundHandlePopupReposition) {
49
+ this.popup?.removeEventListener('reposition', this.boundHandlePopupReposition);
50
+ this.boundHandlePopupReposition = undefined;
51
+ }
52
+ }
53
+ }
54
+ /**
55
+ * Handles popup reposition events to update body container position
56
+ */
57
+ handlePopupReposition() {
58
+ if (this.bodyContainer && this.selectElement.open) {
59
+ this.updateBodyContainerVisibility(true);
60
+ }
61
+ }
62
+ /**
63
+ * Extracts styles as CSS string from various style formats
64
+ */
65
+ extractStylesAsCSS(styles) {
66
+ if (typeof styles === 'string') {
67
+ return styles;
68
+ }
69
+ if (Array.isArray(styles)) {
70
+ return styles.map(style => this.extractStylesAsCSS(style)).join('\n');
71
+ }
72
+ if (styles && typeof styles === 'object' && styles.cssText) {
73
+ return styles.cssText;
74
+ }
75
+ return '';
76
+ }
77
+ /**
78
+ * Injects component styles into document head
79
+ */
80
+ injectStylesToDocument() {
81
+ if (!this.bodyContainer)
82
+ return;
83
+ // Create a unique identifier for this component instance
84
+ this.injectedStyleId = `nile-select-body-append-styles-${Math.random().toString(36).substring(2, 11)}`;
85
+ // Check if styles are already injected
86
+ if (document.getElementById(this.injectedStyleId))
87
+ return;
88
+ // Get the component's styles
89
+ const componentStyles = this.selectElement.constructor.styles;
90
+ if (!componentStyles)
91
+ return;
92
+ // Create a style element
93
+ const styleElement = document.createElement('style');
94
+ styleElement.id = this.injectedStyleId;
95
+ styleElement.textContent = this.extractStylesAsCSS(componentStyles);
96
+ // Inject into document head
97
+ document.head.appendChild(styleElement);
98
+ }
99
+ /**
100
+ * Adopts component styles to the body container (similar to portal-manager pattern)
101
+ */
102
+ adoptStylesToBodyContainer(listboxContainer) {
103
+ if (!this.bodyContainer)
104
+ return;
105
+ // Inject styles to document head first
106
+ this.injectStylesToDocument();
107
+ // Apply basic styling to match the original listbox
108
+ if (this.listbox) {
109
+ const computedStyle = window.getComputedStyle(this.listbox);
110
+ listboxContainer.style.backgroundColor = computedStyle.backgroundColor;
111
+ listboxContainer.style.border = computedStyle.border;
112
+ listboxContainer.style.borderRadius = computedStyle.borderRadius;
113
+ listboxContainer.style.boxShadow = computedStyle.boxShadow;
114
+ listboxContainer.style.maxHeight = computedStyle.maxHeight;
115
+ listboxContainer.style.overflow = computedStyle.overflow;
116
+ listboxContainer.style.padding = computedStyle.padding;
117
+ listboxContainer.style.margin = computedStyle.margin;
118
+ }
119
+ }
120
+ /**
121
+ * Creates a body container for options when bodyAppend is true
122
+ */
123
+ createBodyContainer() {
124
+ if (this.bodyContainer) {
125
+ return this.bodyContainer;
126
+ }
127
+ this.bodyContainer = document.createElement('div');
128
+ this.bodyContainer.style.position = 'fixed';
129
+ this.bodyContainer.style.zIndex = '9999';
130
+ this.bodyContainer.style.pointerEvents = 'none';
131
+ this.bodyContainer.style.visibility = 'hidden';
132
+ this.bodyContainer.style.overflow = 'hidden';
133
+ // Create the listbox container inside the body container
134
+ const listboxContainer = document.createElement('div');
135
+ listboxContainer.id = 'listbox';
136
+ listboxContainer.setAttribute('role', 'listbox');
137
+ listboxContainer.className = 'select__listbox';
138
+ listboxContainer.setAttribute('aria-expanded', 'false');
139
+ listboxContainer.setAttribute('aria-multiselectable', 'false');
140
+ listboxContainer.setAttribute('aria-labelledby', 'label');
141
+ listboxContainer.setAttribute('tabindex', '-1');
142
+ // Adopt styles to the listbox container (similar to portal-manager pattern)
143
+ this.adoptStylesToBodyContainer(listboxContainer);
144
+ // Append the listbox container to the body container
145
+ this.bodyContainer.appendChild(listboxContainer);
146
+ // Inject component styles to document head
147
+ this.injectStylesToDocument();
148
+ document.body.appendChild(this.bodyContainer);
149
+ return this.bodyContainer;
150
+ }
151
+ /**
152
+ * Cleans up the body container
153
+ */
154
+ cleanupBodyContainer() {
155
+ if (this.bodyContainer && this.bodyContainer.parentNode) {
156
+ this.bodyContainer.parentNode.removeChild(this.bodyContainer);
157
+ this.bodyContainer = undefined;
158
+ }
159
+ // Clean up injected styles
160
+ if (this.injectedStyleId) {
161
+ const styleElement = document.getElementById(this.injectedStyleId);
162
+ if (styleElement) {
163
+ styleElement.remove();
164
+ }
165
+ this.injectedStyleId = undefined;
166
+ }
167
+ }
168
+ /**
169
+ * Moves options to body container when bodyAppend is true
170
+ */
171
+ moveOptionsToBody() {
172
+ const container = this.createBodyContainer();
173
+ const listboxContainer = container.querySelector('#listbox');
174
+ const allOptions = this.getAllOptions();
175
+ // Only proceed if we have options to move and listbox container exists
176
+ if (allOptions.length === 0 || !listboxContainer) {
177
+ return;
178
+ }
179
+ // Store original options for restoration
180
+ this.originalOptions = [...allOptions];
181
+ // Move options to listbox container inside body container
182
+ allOptions.forEach(option => {
183
+ if (option.parentNode) {
184
+ option.parentNode.removeChild(option);
185
+ }
186
+ listboxContainer.appendChild(option);
187
+ });
188
+ }
189
+ /**
190
+ * Restores options to their original position
191
+ */
192
+ restoreOptionsFromBody() {
193
+ if (!this.bodyContainer) {
194
+ return;
195
+ }
196
+ const allOptions = this.getAllOptions();
197
+ // Move options back to their original position
198
+ allOptions.forEach(option => {
199
+ if (option.parentNode) {
200
+ option.parentNode.removeChild(option);
201
+ }
202
+ // Insert back into the slot
203
+ this.selectElement.appendChild(option);
204
+ });
205
+ }
206
+ /**
207
+ * Updates body container visibility and positioning
208
+ */
209
+ updateBodyContainerVisibility(visible) {
210
+ if (!this.bodyContainer) {
211
+ return;
212
+ }
213
+ if (visible) {
214
+ this.bodyContainer.style.visibility = 'visible';
215
+ this.bodyContainer.style.pointerEvents = 'auto';
216
+ // Position the container relative to the popup
217
+ if (this.popup && this.popup.popup) {
218
+ const popupRect = this.popup.popup.getBoundingClientRect();
219
+ this.bodyContainer.style.left = `${popupRect.left}px`;
220
+ this.bodyContainer.style.top = `${popupRect.top}px`;
221
+ this.bodyContainer.style.width = `${popupRect.width}px`;
222
+ this.bodyContainer.style.height = `${popupRect.height}px`;
223
+ // Update styles to match the popup
224
+ const computedStyle = window.getComputedStyle(this.popup.popup);
225
+ this.bodyContainer.style.backgroundColor = computedStyle.backgroundColor;
226
+ this.bodyContainer.style.border = computedStyle.border;
227
+ this.bodyContainer.style.borderRadius = computedStyle.borderRadius;
228
+ this.bodyContainer.style.boxShadow = computedStyle.boxShadow;
229
+ this.bodyContainer.style.maxHeight = computedStyle.maxHeight;
230
+ }
231
+ }
232
+ else {
233
+ this.bodyContainer.style.visibility = 'hidden';
234
+ this.bodyContainer.style.pointerEvents = 'none';
235
+ }
236
+ }
237
+ /**
238
+ * Gets all options from both original location and body container
239
+ */
240
+ getAllOptions() {
241
+ let options;
242
+ // Always get options from the original location first
243
+ options = [...this.selectElement.querySelectorAll('nile-option')];
244
+ // If no options found in original location and bodyAppend is true, check listbox container
245
+ if (options.length === 0 && this.bodyContainer) {
246
+ const listboxContainer = this.bodyContainer.querySelector('#listbox');
247
+ if (listboxContainer) {
248
+ options = [...listboxContainer.querySelectorAll('nile-option')];
249
+ }
250
+ }
251
+ return options;
252
+ }
253
+ /**
254
+ * Updates body container visibility when select opens/closes
255
+ */
256
+ updateVisibility(visible) {
257
+ this.updateBodyContainerVisibility(visible);
258
+ }
259
+ /**
260
+ * Checks if bodyAppend is active (has body container)
261
+ */
262
+ isActive() {
263
+ return !!this.bodyContainer;
264
+ }
265
+ /**
266
+ * Gets the body container element
267
+ */
268
+ getBodyContainer() {
269
+ return this.bodyContainer;
270
+ }
271
+ /**
272
+ * Gets the listbox container element inside the body container
273
+ */
274
+ getListboxContainer() {
275
+ return this.bodyContainer?.querySelector('#listbox');
276
+ }
277
+ /**
278
+ * Cleans up all resources
279
+ */
280
+ destroy() {
281
+ // Clean up body container if it exists
282
+ this.cleanupBodyContainer();
283
+ // Clean up event listeners
284
+ if (this.boundHandlePopupReposition) {
285
+ this.popup?.removeEventListener('reposition', this.boundHandlePopupReposition);
286
+ this.boundHandlePopupReposition = undefined;
287
+ }
288
+ // Clean up injected styles
289
+ if (this.injectedStyleId) {
290
+ const styleElement = document.getElementById(this.injectedStyleId);
291
+ if (styleElement) {
292
+ styleElement.remove();
293
+ }
294
+ this.injectedStyleId = undefined;
295
+ }
296
+ }
297
+ }
298
+ //# sourceMappingURL=body-append-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"body-append-manager.js","sourceRoot":"","sources":["../../../src/nile-select/body-append-manager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright Aquera Inc 2023\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 type NileOption from '../nile-option/nile-option';\nimport type NilePopup from '../nile-popup/nile-popup';\nimport type NileSelect from './nile-select';\nimport type { CSSResultGroup } from 'lit';\n\n/**\n * Manager class for handling bodyAppend functionality in nile-select\n * This class manages moving select options to document.body to avoid CSS clipping issues\n */\nexport class BodyAppendManager {\n private bodyContainer?: HTMLElement;\n private originalOptions: NileOption[] = [];\n private boundHandlePopupReposition?: () => void;\n private selectElement: NileSelect;\n private popup?: NilePopup;\n private listbox?: HTMLSlotElement;\n private injectedStyleId?: string;\n\n constructor(selectElement: NileSelect) {\n this.selectElement = selectElement;\n }\n\n /**\n * Sets the popup and listbox references\n */\n setReferences(popup: NilePopup, listbox: HTMLSlotElement): void {\n this.popup = popup;\n this.listbox = listbox;\n }\n\n /**\n * Handles the bodyAppend change\n */\n handleBodyAppendChange(bodyAppend: boolean): void {\n if (bodyAppend) {\n // Initialize body container when bodyAppend becomes true\n this.createBodyContainer();\n // Move options to body immediately\n this.moveOptionsToBody();\n // If no options were found, retry after a short delay\n if (this.getAllOptions().length === 0) {\n setTimeout(() => {\n this.moveOptionsToBody();\n }, 100);\n }\n // Listen for popup reposition events\n this.boundHandlePopupReposition = this.handlePopupReposition.bind(this);\n this.popup?.addEventListener('reposition', this.boundHandlePopupReposition);\n } else {\n // Restore options from body when bodyAppend becomes false\n this.restoreOptionsFromBody();\n // Clean up body container when bodyAppend becomes false\n this.cleanupBodyContainer();\n // Remove popup reposition listener\n if (this.boundHandlePopupReposition) {\n this.popup?.removeEventListener('reposition', this.boundHandlePopupReposition);\n this.boundHandlePopupReposition = undefined;\n }\n }\n }\n\n /**\n * Handles popup reposition events to update body container position\n */\n private handlePopupReposition(): void {\n if (this.bodyContainer && this.selectElement.open) {\n this.updateBodyContainerVisibility(true);\n }\n }\n\n /**\n * Extracts styles as CSS string from various style formats\n */\n private 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 /**\n * Injects component styles into document head\n */\n private injectStylesToDocument(): void {\n if (!this.bodyContainer) return;\n\n // Create a unique identifier for this component instance\n this.injectedStyleId = `nile-select-body-append-styles-${Math.random().toString(36).substring(2, 11)}`;\n \n // Check if styles are already injected\n if (document.getElementById(this.injectedStyleId)) return;\n\n // Get the component's styles\n const componentStyles = (this.selectElement.constructor as any).styles;\n if (!componentStyles) return;\n\n // Create a style element\n const styleElement = document.createElement('style');\n styleElement.id = this.injectedStyleId;\n styleElement.textContent = this.extractStylesAsCSS(componentStyles);\n \n // Inject into document head\n document.head.appendChild(styleElement);\n }\n\n /**\n * Adopts component styles to the body container (similar to portal-manager pattern)\n */\n private adoptStylesToBodyContainer(listboxContainer: HTMLElement): void {\n if (!this.bodyContainer) return;\n \n // Inject styles to document head first\n this.injectStylesToDocument();\n \n // Apply basic styling to match the original listbox\n if (this.listbox) {\n const computedStyle = window.getComputedStyle(this.listbox);\n listboxContainer.style.backgroundColor = computedStyle.backgroundColor;\n listboxContainer.style.border = computedStyle.border;\n listboxContainer.style.borderRadius = computedStyle.borderRadius;\n listboxContainer.style.boxShadow = computedStyle.boxShadow;\n listboxContainer.style.maxHeight = computedStyle.maxHeight;\n listboxContainer.style.overflow = computedStyle.overflow;\n listboxContainer.style.padding = computedStyle.padding;\n listboxContainer.style.margin = computedStyle.margin;\n }\n }\n\n /**\n * Creates a body container for options when bodyAppend is true\n */\n private createBodyContainer(): HTMLElement {\n if (this.bodyContainer) {\n return this.bodyContainer;\n }\n\n this.bodyContainer = document.createElement('div');\n this.bodyContainer.style.position = 'fixed';\n this.bodyContainer.style.zIndex = '9999';\n this.bodyContainer.style.pointerEvents = 'none';\n this.bodyContainer.style.visibility = 'hidden';\n this.bodyContainer.style.overflow = 'hidden';\n \n // Create the listbox container inside the body container\n const listboxContainer = document.createElement('div');\n listboxContainer.id = 'listbox';\n listboxContainer.setAttribute('role', 'listbox');\n listboxContainer.className = 'select__listbox';\n listboxContainer.setAttribute('aria-expanded', 'false');\n listboxContainer.setAttribute('aria-multiselectable', 'false');\n listboxContainer.setAttribute('aria-labelledby', 'label');\n listboxContainer.setAttribute('tabindex', '-1');\n \n // Adopt styles to the listbox container (similar to portal-manager pattern)\n this.adoptStylesToBodyContainer(listboxContainer);\n \n // Append the listbox container to the body container\n this.bodyContainer.appendChild(listboxContainer);\n \n // Inject component styles to document head\n this.injectStylesToDocument();\n \n document.body.appendChild(this.bodyContainer);\n \n return this.bodyContainer;\n }\n\n /**\n * Cleans up the body container\n */\n private cleanupBodyContainer(): void {\n if (this.bodyContainer && this.bodyContainer.parentNode) {\n this.bodyContainer.parentNode.removeChild(this.bodyContainer);\n this.bodyContainer = undefined;\n }\n \n // Clean up injected styles\n if (this.injectedStyleId) {\n const styleElement = document.getElementById(this.injectedStyleId);\n if (styleElement) {\n styleElement.remove();\n }\n this.injectedStyleId = undefined;\n }\n }\n\n /**\n * Moves options to body container when bodyAppend is true\n */\n private moveOptionsToBody(): void {\n const container = this.createBodyContainer();\n const listboxContainer = container.querySelector('#listbox') as HTMLElement;\n const allOptions = this.getAllOptions();\n \n // Only proceed if we have options to move and listbox container exists\n if (allOptions.length === 0 || !listboxContainer) {\n return;\n }\n \n // Store original options for restoration\n this.originalOptions = [...allOptions];\n \n // Move options to listbox container inside body container\n allOptions.forEach(option => {\n if (option.parentNode) {\n option.parentNode.removeChild(option);\n }\n listboxContainer.appendChild(option);\n });\n }\n\n /**\n * Restores options to their original position\n */\n private restoreOptionsFromBody(): void {\n if (!this.bodyContainer) {\n return;\n }\n\n const allOptions = this.getAllOptions();\n \n // Move options back to their original position\n allOptions.forEach(option => {\n if (option.parentNode) {\n option.parentNode.removeChild(option);\n }\n // Insert back into the slot\n this.selectElement.appendChild(option);\n });\n }\n\n /**\n * Updates body container visibility and positioning\n */\n private updateBodyContainerVisibility(visible: boolean): void {\n if (!this.bodyContainer) {\n return;\n }\n\n if (visible) {\n this.bodyContainer.style.visibility = 'visible';\n this.bodyContainer.style.pointerEvents = 'auto';\n \n // Position the container relative to the popup\n if (this.popup && this.popup.popup) {\n const popupRect = this.popup.popup.getBoundingClientRect();\n this.bodyContainer.style.left = `${popupRect.left}px`;\n this.bodyContainer.style.top = `${popupRect.top}px`;\n this.bodyContainer.style.width = `${popupRect.width}px`;\n this.bodyContainer.style.height = `${popupRect.height}px`;\n \n // Update styles to match the popup\n const computedStyle = window.getComputedStyle(this.popup.popup);\n this.bodyContainer.style.backgroundColor = computedStyle.backgroundColor;\n this.bodyContainer.style.border = computedStyle.border;\n this.bodyContainer.style.borderRadius = computedStyle.borderRadius;\n this.bodyContainer.style.boxShadow = computedStyle.boxShadow;\n this.bodyContainer.style.maxHeight = computedStyle.maxHeight;\n }\n } else {\n this.bodyContainer.style.visibility = 'hidden';\n this.bodyContainer.style.pointerEvents = 'none';\n }\n }\n\n /**\n * Gets all options from both original location and body container\n */\n private getAllOptions(): NileOption[] {\n let options: NileOption[];\n \n // Always get options from the original location first\n options = [...this.selectElement.querySelectorAll<NileOption>('nile-option')];\n \n // If no options found in original location and bodyAppend is true, check listbox container\n if (options.length === 0 && this.bodyContainer) {\n const listboxContainer = this.bodyContainer.querySelector('#listbox');\n if (listboxContainer) {\n options = [...listboxContainer.querySelectorAll<NileOption>('nile-option')];\n }\n }\n\n return options;\n }\n\n /**\n * Updates body container visibility when select opens/closes\n */\n updateVisibility(visible: boolean): void {\n this.updateBodyContainerVisibility(visible);\n }\n\n /**\n * Checks if bodyAppend is active (has body container)\n */\n isActive(): boolean {\n return !!this.bodyContainer;\n }\n\n /**\n * Gets the body container element\n */\n getBodyContainer(): HTMLElement | undefined {\n return this.bodyContainer;\n }\n\n /**\n * Gets the listbox container element inside the body container\n */\n getListboxContainer(): HTMLElement | undefined {\n return this.bodyContainer?.querySelector('#listbox') as HTMLElement | undefined;\n }\n\n /**\n * Cleans up all resources\n */\n destroy(): void {\n // Clean up body container if it exists\n this.cleanupBodyContainer();\n // Clean up event listeners\n if (this.boundHandlePopupReposition) {\n this.popup?.removeEventListener('reposition', this.boundHandlePopupReposition);\n this.boundHandlePopupReposition = undefined;\n }\n // Clean up injected styles\n if (this.injectedStyleId) {\n const styleElement = document.getElementById(this.injectedStyleId);\n if (styleElement) {\n styleElement.remove();\n }\n this.injectedStyleId = undefined;\n }\n }\n}\n"]}
@@ -502,8 +502,10 @@ export const styles = css `
502
502
  box-shadow: 0 0 0 1px var(--ng-colors-border-brand) inset ;
503
503
  }
504
504
 
505
-
506
-
505
+ :host([stickyHeader]) .select__footer{
506
+ z-index: 1;
507
+ }
508
+
507
509
  `;
508
510
  export default [styles];
509
511
  //# sourceMappingURL=nile-select.css.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"nile-select.css.js","sourceRoot":"","sources":["../../../src/nile-select/nile-select.css.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAgfxB,CAAC;AAEF,eAAe,CAAC,MAAM,CAAC,CAAC","sourcesContent":["/**\n * Copyright Aquera Inc 2023\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 { css } from 'lit';\n\n/**\n * Select_2 CSS\n */\nexport const styles = css`\n :host {\n box-sizing: border-box;\n --ng-nxt-gen-outline: var(--ng-border-width-1) solid var(--ng-colors-border-brand);\n --ng-nxt-gen-outline-error: var(--ng-border-width-1) solid var(--ng-colors-border-error);\n --ng-private-outline-transparent: var(--ng-border-width-1) solid transparent;\n --ng-box-shadow: 0px 12px 16px -4px var(--ng-colors-effects-shadow-lg-01, rgba(10, 13, 18, 0.08)), 0px 4px 6px -2px var(--ng-colors-effects-shadow-lg-02, rgba(10, 13, 18, 0.03)), 0px 2px 2px -1px var(--ng-colors-effects-shadow-lg-03, rgba(10, 13, 18, 0.04));\n -webkit-font-smoothing: var(--nile-webkit-font-smoothing, var(--ng-webkit-font-smoothing));\n -moz-osx-font-smoothing: var(--nile-moz-osx-font-smoothing, var(--ng-moz-osx-font-smoothing));\n text-rendering: var(--nile-text-rendering, var(--ng-text-rendering));\n }\n\n :host *,\n :host *::before,\n :host *::after {\n box-sizing: inherit;\n }\n\n [hidden] {\n display: none !important;\n }\n\n .form-control .form-control__label {\n display: none;\n }\n\n .form-control .form-control__help-text {\n display: none;\n }\n\n /* Label */\n .form-control--has-label .form-control__label {\n display: block;\n margin-bottom: var(--nile-spacing-sm, var(--ng-spacing-sm));\n color: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n font-family: var(--nile-font-family-serif, var(--ng-font-family-body));\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n font-style: normal;\n font-weight: var(--nile-font-weight-regular, var(--ng-font-weight-regular));\n line-height: var(--nile-spacing-2xl, var(--ng-line-height-text-sm));\n letter-spacing: 0.2px;\n }\n\n .form-control--has-label.form-control--medium .form-control__label {\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n }\n\n :host([required]) .form-control--has-label .form-control__label::after {\n content: '*';\n margin-inline-start: -2px;\n color: var(--nile-colors-red-700, var(--ng-colors-text-brand-tertiary-600));\n }\n\n /* Help text */\n .form-control--has-help-text .form-control__help-text {\n display: block;\n color: var(--nile-colors-dark-500, var(--ng-colors-text-tertiary-600));\n margin-top: var(--nile-spacing-lg, var(--ng-spacing-lg));\n }\n\n .form-control--has-help-text.form-control--medium .form-control__help-text {\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n }\n\n .form-control--has-help-text.form-control--radio-group\n .form-control__help-text {\n margin-top: var(--nile-spacing-xs, var(--ng-spacing-sm));\n }\n\n :host {\n display: block;\n }\n\n /** The popup */\n .select {\n flex: 1 1 auto;\n display: inline-flex;\n width: 100%;\n position: relative;\n vertical-align: middle;\n }\n\n .select::part(popup) {\n z-index: 9999;\n }\n\n .select[data-current-placement^='top']::part(popup) {\n transform-origin: bottom;\n }\n\n .select[data-current-placement^='bottom']::part(popup) {\n transform-origin: top;\n }\n\n /* Combobox */\n .select__combobox {\n flex: 1;\n display: flex;\n width: 100%;\n min-width: 0;\n position: relative;\n align-items: center;\n justify-content: start;\n font-family: var(--nile-font-family-sans-serif, var(--ng-font-family-body));\n font-weight: var(--nile-font-weight-regular, var(--ng-font-weight-medium));\n letter-spacing: normal;\n vertical-align: middle;\n overflow: hidden;\n cursor: pointer;\n transition: 150ms color, 150ms border, 150ms box-shadow,\n 150ms background-color;\n }\n\n .select__display-input {\n position: relative;\n width: 100%;\n font: var(--nile-font-family-inherit, var(--ng-font-weight-regular));\n border: none;\n background: none;\n color: var(--nile-colors-dark-900, var(--ng-colors-text-primary-900));\n cursor: inherit;\n overflow: hidden;\n padding: var(--nile-spacing-none, var(--ng-spacing-none));\n margin: var(--nile-spacing-none, var(--ng-spacing-none));\n -webkit-appearance: none;\n font-family: var(--nile-font-family-serif, var(--ng-font-family-body));\n }\n\n\n .select__display-input::placeholder {\n font-family: var(--nile-font-family-serif, var(--ng-font-family-body));\n color: var(--nile-colors-text-placeholder, var(--ng-colors-text-placeholder));\n }\n\n .select:not(.select--disabled):hover .select__display-input {\n color: var(--nile-colors-dark-900, var(--ng-colors-text-primary-900));\n }\n\n .select__display-input:focus {\n outline: none;\n }\n\n /* Visually hide the display input when multiple is enabled */\n .select--multiple:not(.select--placeholder-visible) .select__display-input {\n position: absolute;\n z-index: -1;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n opacity: 0;\n }\n\n .select__value-input {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n padding: var(--nile-spacing-none);\n margin: var(--nile-spacing-none);\n opacity: 0;\n z-index: -1;\n }\n\n .select__tags {\n display: flex;\n flex: 1;\n align-items: center;\n flex-wrap: no-wrap;\n margin-inline-start: var(--nile-spacing-7px, var(--ng-spacing-md));\n width: 100%;\n overflow: hidden;\n }\n\n .select__tags-count {\n color: var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n font-family: var(--nile-font-family-serif, var(--ng-font-family-body));\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n font-style: normal;\n font-weight: var(--nile-font-weight-regular, var(--ng-font-weight-regular));\n line-height: var(--nile-line-height-xsmall);\n letter-spacing: 0.2px;\n margin: var(--nile-spacing-sm, var(--ng-spacing-sm));\n }\n\n .select__tags-count-clearable {\n margin-right: var(--nile-spacing-5xl, var(--ng-spacing-5xl));\n }\n\n .select__tags::slotted(nile-tag) {\n cursor: pointer !important;\n }\n\n .select--disabled .select__tags,\n .select--disabled .select__tags::slotted(nile-tag) {\n cursor: not-allowed !important;\n }\n\n /* Standard selects */\n .select--standard .select__combobox {\n background-color: var(--nile-colors-white-base, var(--ng-colors-bg-primary));\n border: solid 1px var(--nile-colors-neutral-500, var(--ng-colors-border-primary));\n /* outline: var(--nile-outline-none, var(--ng-private-outline-transparent)); */\n }\n\n .select--standard .select__combobox:hover {\n border: 1px solid var(--nile-colors-dark-900, var(--ng-colors-border-neutral));\n background: var(--nile-colors-white-base, var(--ng-colors-bg-primary));\n /* outline: var(--nile-outline-none, var(--ng-nxt-gen-outline)); */\n }\n\n .select--error:hover:not(.select--disabled) .select__combobox{\n border-color: var(--nile-colors-red-500, var(--ng-colors-border-error));\n /* outline: var(--nile-outline-none, var(--ng-colors-border-error)); */\n }\n\n .select--standard.select--disabled .select__combobox {\n background-color: var(--nile-colors-neutral-100, var(--ng-colors-bg-disabled-subtle));\n border-color: var(--nile-colors-neutral-500,var(--ng-colors-border-disabled) );\n color: var(--nile-colors-dark-500, var(--ng-colors-text-disabled));\n opacity: var(--nile-opacity-50, var(--ng-opacity-100));\n cursor: not-allowed;\n outline: none;\n }\n\n .select--standard:not(.select--disabled).select--open .select__combobox,\n .select--standard:not(.select--disabled).select--focused .select__combobox {\n background-color: var(--nile-colors-neutral-100);\n }\n\n .select--warning .select__combobox {\n border-color: var(--nile-colors-yellow-500, var(--ng-colors-border-warning));\n }\n\n .select--error .select__combobox {\n border-color: var(--nile-colors-red-500, var(--ng-colors-border-error));\n outline: var(--nile-outline-none, var(--ng-private-outline-transparent));\n }\n\n\n\n\n .select--success {\n border-color: var(--nile-colors-green-500, var(--ng-componentcolors-utility-success-500));\n }\n\n /* Filled selects */\n .select--filled .select__combobox {\n border: none;\n background-color: var(--nile-colors-neutral-100, var(--ng-colors-bg-secondary));\n color: var(--nile-colors-dark-900, var(--ng-colors-text-primary-900));\n }\n\n .select--filled:hover:not(.select--disabled) .select__combobox {\n background-color: var(--nile-colors-neutral-100);\n }\n\n .select--filled.select--disabled .select__combobox {\n background-color: var(--nile-colors-neutral-100);\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .select--filled:not(.select--disabled).select--open .select__combobox,\n .select--filled:not(.select--disabled).select--focused .select__combobox {\n background-color: var(--nile-colors-neutral-100);\n outline: 3px solid rgba(0, 89, 255, 0.4);\n }\n\n .select--medium .select__combobox {\n border-radius: var(--nile-radius-sm, var(--ng-radius-md));\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n\n padding: var(--nile-spacing-lg, var(--ng-spacing-md)) var(--nile-spacing-lg, var(--ng-spacing-lg));\n height: var(--nile-height-40px, var(--ng-height-40px));\n box-sizing: border-box;\n }\n\n .select--medium .select__clear {\n margin-inline-start: var(--nile-spacing-lg, var(--ng-spacing-lg));\n }\n\n .select--medium .select__prefix::slotted(*) {\n margin-inline-end: var(--nile-spacing-lg, var(--ng-spacing-md));\n }\n\n .select--medium .select__prefix.multiple::slotted(*) {\n margin-right: var(--nile-spacing-lg, var(--ng-spacing-md));\n }\n\n .select--medium:not(.select--placeholder-visible) .select__prefix.multiple::slotted(*) {\n margin-inline-start: var(--nile-spacing-xsmall, var(--ng-spacing-lg));\n }\n\n .select--medium.select--multiple:not(.select--placeholder-visible)\n .select__combobox {\n padding-inline-start: var(--nile-spacing-none, var(--ng-spacing-none));\n }\n\n .select--medium .select__tags {\n gap: var(--nile-spacing-3px, var(--ng-spacing-sm));\n }\n\n /* Pills */\n .select--pill.select--medium .select__combobox {\n border-radius: var(--nile-radius-3xl);\n }\n\n /* Prefix */\n .select__prefix {\n flex: 0;\n display: inline-flex;\n align-items: center;\n color: var(--nile-colors-dark-500);\n }\n\n .select__suffix {\n flex: 0;\n display: inline-flex;\n align-items: center;\n color: var(--nile-colors-dark-500);\n }\n\n /* Clear button */\n .select__clear {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n font-size: inherit;\n color: var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n border: none;\n background: none;\n padding: var(--nile-spacing-none);\n transition: 150ms color;\n cursor: pointer;\n }\n\n .select__clear:hover {\n color: var(--nile-colors-dark-500);\n }\n\n .select__clear:focus {\n outline: none;\n }\n\n /* Expand icon */\n .select__expand-icon {\n flex: 0 0 auto;\n display: flex;\n align-items: center;\n transition: 250ms rotate ease;\n rotate: 0;\n margin-inline-start: var(--nile-spacing-xxxsmall, var(--ng-spacing-md));\n }\n\n .select--open .select__expand-icon {\n rotate: -180deg;\n }\n\n /* Listbox */\n .select__listbox {\n display: block;\n position: relative;\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-md));\n font-weight: var(--nile-font-weight-regular, var(--ng-font-weight-regular));\n background: var(--nile-colors-white-base, var(--ng-colors-bg-primary));\n border: solid 1px var(--nile-colors-neutral-500, var(--ng-colors-border-secondary-alt));\n border-radius: var(--nile-radius-sm, var(--ng-radius-md));\n padding-block: var(--nile-spacing-none, var(--ng-spacing-none));\n padding-inline: var(--nile-spacing-none, var(--ng-spacing-none));\n overflow: auto;\n overscroll-behavior: none;\n /* Make sure it adheres to the popup's auto size */\n max-width: var(--auto-size-available-width);\n max-height: var(--auto-size-available-height);\n box-shadow: var(--nile-box-shadow-none, var(--ng-shadow-xs));\n }\n\n .select__options__search-enabled {\n padding-top: var(--nile-spacing-10px, var(--ng-spacing-lg));\n }\n\n .select__options {\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n\n color: rgb(133, 129, 129);\n }\n\n .select__listbox::slotted(nile-divider) {\n --spacing: var(--nile-spacing-xs, var(--ng-spacing-sm));\n }\n\n .select__listbox::slotted(small) {\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n font-weight: var(--nile-font-weight-semi-bold, var(--ng-font-weight-semibold));\n color: var(--nile-colors-dark-500);\n padding-block: var(--nile-spacing-xs, var(--ng-spacing-sm));\n padding-inline: var(--nile-spacing-xl, var(--ng-spacing-xl));\n }\n\n .select__search {\n position: sticky;\n top: 0px;\n z-index: 1;\n width: calc(100% - 16px);\n padding: var(--nile-spacing-md, var(--ng-spacing-md));\n background-color: var(--nile-colors-white-base, var(--ng-colors-bg-primary));\n margin-bottom: -8px;\n }\n\n .select__footer {\n position: sticky;\n bottom: 0px;\n background: var(--nile-colors-neutral-100);\n border-top: 1px solid var(--nile-colors-neutral-400);\n display: flex;\n height: 15px;\n /* Auto layout */\n display:var(--nile-display-flex, var(--ng-display-none));\n flex-direction: row;\n align-items: flex-start;\n padding: var(--nile-spacing-md) var(--nile-spacing-lg)\n var(--nile-spacing-xl);\n gap: var(--nile-spacing-lg, var(--ng-spacing-lg));\n justify-content: space-between;\n }\n\n .tag__prefix[slot='prefix'] {\n height: 14px;\n display: inline-block;\n overflow: hidden;\n }\n\n .tag__prefix[slot='prefix'] img {\n max-height: 100%;\n }\n\n .select__loader {\n width: 100%;\n text-align: center;\n display: block;\n }\n\n .select__loader--icon {\n margin-top: var(--nile-spacing-xl, var(--ng-spacing-xl));\n animation: spin 0.6s linear infinite;\n }\n\n .select__no-results {\n padding: var(--nile-spacing-lg, var(--ng-spacing-lg));\n }\n\n @keyframes spin {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n }\n\n .select__invisible {\n opacity: 0;\n }\n\n .select__prefix--from-options {\n margin-inline-end: var(--nile-spacing-lg, var(--ng-spacing-md));\n }\n\n .select__prefix--from-options img{\n max-height: var(--nile-height-none, var(--ng-height-24px));\n max-width: var(--nile-width-none, var(--ng-width-6));\n }\n\n .select__hide-default {\n display: none;\n }\n \n .select.select--open .select__combobox {\n border-color: var(--nile-colors-neutral-500,var(--ng-colors-border-brand));\n box-shadow: 0 0 0 1px var(--ng-colors-border-brand) inset ;\n}\n\n.select.select--open:hover .select__combobox {\n border-color: var(--nile-colors-neutral-500,var(--ng-colors-border-brand));\n box-shadow: 0 0 0 1px var(--ng-colors-border-brand) inset ;\n}\n\n.select.select--open .select__combobox:hover {\n border-color: var(--nile-colors-dark-900, var(--ng-colors-border-brand));\n box-shadow: 0 0 0 1px var(--ng-colors-border-brand) inset ;\n}\n\n\n\n`;\n\nexport default [styles];\n"]}
1
+ {"version":3,"file":"nile-select.css.js","sourceRoot":"","sources":["../../../src/nile-select/nile-select.css.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkfxB,CAAC;AAEF,eAAe,CAAC,MAAM,CAAC,CAAC","sourcesContent":["/**\n * Copyright Aquera Inc 2023\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 { css } from 'lit';\n\n/**\n * Select_2 CSS\n */\nexport const styles = css`\n :host {\n box-sizing: border-box;\n --ng-nxt-gen-outline: var(--ng-border-width-1) solid var(--ng-colors-border-brand);\n --ng-nxt-gen-outline-error: var(--ng-border-width-1) solid var(--ng-colors-border-error);\n --ng-private-outline-transparent: var(--ng-border-width-1) solid transparent;\n --ng-box-shadow: 0px 12px 16px -4px var(--ng-colors-effects-shadow-lg-01, rgba(10, 13, 18, 0.08)), 0px 4px 6px -2px var(--ng-colors-effects-shadow-lg-02, rgba(10, 13, 18, 0.03)), 0px 2px 2px -1px var(--ng-colors-effects-shadow-lg-03, rgba(10, 13, 18, 0.04));\n -webkit-font-smoothing: var(--nile-webkit-font-smoothing, var(--ng-webkit-font-smoothing));\n -moz-osx-font-smoothing: var(--nile-moz-osx-font-smoothing, var(--ng-moz-osx-font-smoothing));\n text-rendering: var(--nile-text-rendering, var(--ng-text-rendering));\n }\n\n :host *,\n :host *::before,\n :host *::after {\n box-sizing: inherit;\n }\n\n [hidden] {\n display: none !important;\n }\n\n .form-control .form-control__label {\n display: none;\n }\n\n .form-control .form-control__help-text {\n display: none;\n }\n\n /* Label */\n .form-control--has-label .form-control__label {\n display: block;\n margin-bottom: var(--nile-spacing-sm, var(--ng-spacing-sm));\n color: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n font-family: var(--nile-font-family-serif, var(--ng-font-family-body));\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n font-style: normal;\n font-weight: var(--nile-font-weight-regular, var(--ng-font-weight-regular));\n line-height: var(--nile-spacing-2xl, var(--ng-line-height-text-sm));\n letter-spacing: 0.2px;\n }\n\n .form-control--has-label.form-control--medium .form-control__label {\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n }\n\n :host([required]) .form-control--has-label .form-control__label::after {\n content: '*';\n margin-inline-start: -2px;\n color: var(--nile-colors-red-700, var(--ng-colors-text-brand-tertiary-600));\n }\n\n /* Help text */\n .form-control--has-help-text .form-control__help-text {\n display: block;\n color: var(--nile-colors-dark-500, var(--ng-colors-text-tertiary-600));\n margin-top: var(--nile-spacing-lg, var(--ng-spacing-lg));\n }\n\n .form-control--has-help-text.form-control--medium .form-control__help-text {\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n }\n\n .form-control--has-help-text.form-control--radio-group\n .form-control__help-text {\n margin-top: var(--nile-spacing-xs, var(--ng-spacing-sm));\n }\n\n :host {\n display: block;\n }\n\n /** The popup */\n .select {\n flex: 1 1 auto;\n display: inline-flex;\n width: 100%;\n position: relative;\n vertical-align: middle;\n }\n\n .select::part(popup) {\n z-index: 9999;\n }\n\n .select[data-current-placement^='top']::part(popup) {\n transform-origin: bottom;\n }\n\n .select[data-current-placement^='bottom']::part(popup) {\n transform-origin: top;\n }\n\n /* Combobox */\n .select__combobox {\n flex: 1;\n display: flex;\n width: 100%;\n min-width: 0;\n position: relative;\n align-items: center;\n justify-content: start;\n font-family: var(--nile-font-family-sans-serif, var(--ng-font-family-body));\n font-weight: var(--nile-font-weight-regular, var(--ng-font-weight-medium));\n letter-spacing: normal;\n vertical-align: middle;\n overflow: hidden;\n cursor: pointer;\n transition: 150ms color, 150ms border, 150ms box-shadow,\n 150ms background-color;\n }\n\n .select__display-input {\n position: relative;\n width: 100%;\n font: var(--nile-font-family-inherit, var(--ng-font-weight-regular));\n border: none;\n background: none;\n color: var(--nile-colors-dark-900, var(--ng-colors-text-primary-900));\n cursor: inherit;\n overflow: hidden;\n padding: var(--nile-spacing-none, var(--ng-spacing-none));\n margin: var(--nile-spacing-none, var(--ng-spacing-none));\n -webkit-appearance: none;\n font-family: var(--nile-font-family-serif, var(--ng-font-family-body));\n }\n\n\n .select__display-input::placeholder {\n font-family: var(--nile-font-family-serif, var(--ng-font-family-body));\n color: var(--nile-colors-text-placeholder, var(--ng-colors-text-placeholder));\n }\n\n .select:not(.select--disabled):hover .select__display-input {\n color: var(--nile-colors-dark-900, var(--ng-colors-text-primary-900));\n }\n\n .select__display-input:focus {\n outline: none;\n }\n\n /* Visually hide the display input when multiple is enabled */\n .select--multiple:not(.select--placeholder-visible) .select__display-input {\n position: absolute;\n z-index: -1;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n opacity: 0;\n }\n\n .select__value-input {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n padding: var(--nile-spacing-none);\n margin: var(--nile-spacing-none);\n opacity: 0;\n z-index: -1;\n }\n\n .select__tags {\n display: flex;\n flex: 1;\n align-items: center;\n flex-wrap: no-wrap;\n margin-inline-start: var(--nile-spacing-7px, var(--ng-spacing-md));\n width: 100%;\n overflow: hidden;\n }\n\n .select__tags-count {\n color: var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n font-family: var(--nile-font-family-serif, var(--ng-font-family-body));\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n font-style: normal;\n font-weight: var(--nile-font-weight-regular, var(--ng-font-weight-regular));\n line-height: var(--nile-line-height-xsmall);\n letter-spacing: 0.2px;\n margin: var(--nile-spacing-sm, var(--ng-spacing-sm));\n }\n\n .select__tags-count-clearable {\n margin-right: var(--nile-spacing-5xl, var(--ng-spacing-5xl));\n }\n\n .select__tags::slotted(nile-tag) {\n cursor: pointer !important;\n }\n\n .select--disabled .select__tags,\n .select--disabled .select__tags::slotted(nile-tag) {\n cursor: not-allowed !important;\n }\n\n /* Standard selects */\n .select--standard .select__combobox {\n background-color: var(--nile-colors-white-base, var(--ng-colors-bg-primary));\n border: solid 1px var(--nile-colors-neutral-500, var(--ng-colors-border-primary));\n /* outline: var(--nile-outline-none, var(--ng-private-outline-transparent)); */\n }\n\n .select--standard .select__combobox:hover {\n border: 1px solid var(--nile-colors-dark-900, var(--ng-colors-border-neutral));\n background: var(--nile-colors-white-base, var(--ng-colors-bg-primary));\n /* outline: var(--nile-outline-none, var(--ng-nxt-gen-outline)); */\n }\n\n .select--error:hover:not(.select--disabled) .select__combobox{\n border-color: var(--nile-colors-red-500, var(--ng-colors-border-error));\n /* outline: var(--nile-outline-none, var(--ng-colors-border-error)); */\n }\n\n .select--standard.select--disabled .select__combobox {\n background-color: var(--nile-colors-neutral-100, var(--ng-colors-bg-disabled-subtle));\n border-color: var(--nile-colors-neutral-500,var(--ng-colors-border-disabled) );\n color: var(--nile-colors-dark-500, var(--ng-colors-text-disabled));\n opacity: var(--nile-opacity-50, var(--ng-opacity-100));\n cursor: not-allowed;\n outline: none;\n }\n\n .select--standard:not(.select--disabled).select--open .select__combobox,\n .select--standard:not(.select--disabled).select--focused .select__combobox {\n background-color: var(--nile-colors-neutral-100);\n }\n\n .select--warning .select__combobox {\n border-color: var(--nile-colors-yellow-500, var(--ng-colors-border-warning));\n }\n\n .select--error .select__combobox {\n border-color: var(--nile-colors-red-500, var(--ng-colors-border-error));\n outline: var(--nile-outline-none, var(--ng-private-outline-transparent));\n }\n\n\n\n\n .select--success {\n border-color: var(--nile-colors-green-500, var(--ng-componentcolors-utility-success-500));\n }\n\n /* Filled selects */\n .select--filled .select__combobox {\n border: none;\n background-color: var(--nile-colors-neutral-100, var(--ng-colors-bg-secondary));\n color: var(--nile-colors-dark-900, var(--ng-colors-text-primary-900));\n }\n\n .select--filled:hover:not(.select--disabled) .select__combobox {\n background-color: var(--nile-colors-neutral-100);\n }\n\n .select--filled.select--disabled .select__combobox {\n background-color: var(--nile-colors-neutral-100);\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .select--filled:not(.select--disabled).select--open .select__combobox,\n .select--filled:not(.select--disabled).select--focused .select__combobox {\n background-color: var(--nile-colors-neutral-100);\n outline: 3px solid rgba(0, 89, 255, 0.4);\n }\n\n .select--medium .select__combobox {\n border-radius: var(--nile-radius-sm, var(--ng-radius-md));\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n\n padding: var(--nile-spacing-lg, var(--ng-spacing-md)) var(--nile-spacing-lg, var(--ng-spacing-lg));\n height: var(--nile-height-40px, var(--ng-height-40px));\n box-sizing: border-box;\n }\n\n .select--medium .select__clear {\n margin-inline-start: var(--nile-spacing-lg, var(--ng-spacing-lg));\n }\n\n .select--medium .select__prefix::slotted(*) {\n margin-inline-end: var(--nile-spacing-lg, var(--ng-spacing-md));\n }\n\n .select--medium .select__prefix.multiple::slotted(*) {\n margin-right: var(--nile-spacing-lg, var(--ng-spacing-md));\n }\n\n .select--medium:not(.select--placeholder-visible) .select__prefix.multiple::slotted(*) {\n margin-inline-start: var(--nile-spacing-xsmall, var(--ng-spacing-lg));\n }\n\n .select--medium.select--multiple:not(.select--placeholder-visible)\n .select__combobox {\n padding-inline-start: var(--nile-spacing-none, var(--ng-spacing-none));\n }\n\n .select--medium .select__tags {\n gap: var(--nile-spacing-3px, var(--ng-spacing-sm));\n }\n\n /* Pills */\n .select--pill.select--medium .select__combobox {\n border-radius: var(--nile-radius-3xl);\n }\n\n /* Prefix */\n .select__prefix {\n flex: 0;\n display: inline-flex;\n align-items: center;\n color: var(--nile-colors-dark-500);\n }\n\n .select__suffix {\n flex: 0;\n display: inline-flex;\n align-items: center;\n color: var(--nile-colors-dark-500);\n }\n\n /* Clear button */\n .select__clear {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n font-size: inherit;\n color: var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n border: none;\n background: none;\n padding: var(--nile-spacing-none);\n transition: 150ms color;\n cursor: pointer;\n }\n\n .select__clear:hover {\n color: var(--nile-colors-dark-500);\n }\n\n .select__clear:focus {\n outline: none;\n }\n\n /* Expand icon */\n .select__expand-icon {\n flex: 0 0 auto;\n display: flex;\n align-items: center;\n transition: 250ms rotate ease;\n rotate: 0;\n margin-inline-start: var(--nile-spacing-xxxsmall, var(--ng-spacing-md));\n }\n\n .select--open .select__expand-icon {\n rotate: -180deg;\n }\n\n /* Listbox */\n .select__listbox {\n display: block;\n position: relative;\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-md));\n font-weight: var(--nile-font-weight-regular, var(--ng-font-weight-regular));\n background: var(--nile-colors-white-base, var(--ng-colors-bg-primary));\n border: solid 1px var(--nile-colors-neutral-500, var(--ng-colors-border-secondary-alt));\n border-radius: var(--nile-radius-sm, var(--ng-radius-md));\n padding-block: var(--nile-spacing-none, var(--ng-spacing-none));\n padding-inline: var(--nile-spacing-none, var(--ng-spacing-none));\n overflow: auto;\n overscroll-behavior: none;\n /* Make sure it adheres to the popup's auto size */\n max-width: var(--auto-size-available-width);\n max-height: var(--auto-size-available-height);\n box-shadow: var(--nile-box-shadow-none, var(--ng-shadow-xs));\n }\n\n .select__options__search-enabled {\n padding-top: var(--nile-spacing-10px, var(--ng-spacing-lg));\n }\n\n .select__options {\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n\n color: rgb(133, 129, 129);\n }\n\n .select__listbox::slotted(nile-divider) {\n --spacing: var(--nile-spacing-xs, var(--ng-spacing-sm));\n }\n\n .select__listbox::slotted(small) {\n font-size: var(--nile-type-scale-3, var(--ng-font-size-text-sm));\n font-weight: var(--nile-font-weight-semi-bold, var(--ng-font-weight-semibold));\n color: var(--nile-colors-dark-500);\n padding-block: var(--nile-spacing-xs, var(--ng-spacing-sm));\n padding-inline: var(--nile-spacing-xl, var(--ng-spacing-xl));\n }\n\n .select__search {\n position: sticky;\n top: 0px;\n z-index: 1;\n width: calc(100% - 16px);\n padding: var(--nile-spacing-md, var(--ng-spacing-md));\n background-color: var(--nile-colors-white-base, var(--ng-colors-bg-primary));\n margin-bottom: -8px;\n }\n\n .select__footer {\n position: sticky;\n bottom: 0px;\n background: var(--nile-colors-neutral-100);\n border-top: 1px solid var(--nile-colors-neutral-400);\n display: flex;\n height: 15px;\n /* Auto layout */\n display:var(--nile-display-flex, var(--ng-display-none));\n flex-direction: row;\n align-items: flex-start;\n padding: var(--nile-spacing-md) var(--nile-spacing-lg)\n var(--nile-spacing-xl);\n gap: var(--nile-spacing-lg, var(--ng-spacing-lg));\n justify-content: space-between;\n }\n\n .tag__prefix[slot='prefix'] {\n height: 14px;\n display: inline-block;\n overflow: hidden;\n }\n\n .tag__prefix[slot='prefix'] img {\n max-height: 100%;\n }\n\n .select__loader {\n width: 100%;\n text-align: center;\n display: block;\n }\n\n .select__loader--icon {\n margin-top: var(--nile-spacing-xl, var(--ng-spacing-xl));\n animation: spin 0.6s linear infinite;\n }\n\n .select__no-results {\n padding: var(--nile-spacing-lg, var(--ng-spacing-lg));\n }\n\n @keyframes spin {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n }\n\n .select__invisible {\n opacity: 0;\n }\n\n .select__prefix--from-options {\n margin-inline-end: var(--nile-spacing-lg, var(--ng-spacing-md));\n }\n\n .select__prefix--from-options img{\n max-height: var(--nile-height-none, var(--ng-height-24px));\n max-width: var(--nile-width-none, var(--ng-width-6));\n }\n\n .select__hide-default {\n display: none;\n }\n \n .select.select--open .select__combobox {\n border-color: var(--nile-colors-neutral-500,var(--ng-colors-border-brand));\n box-shadow: 0 0 0 1px var(--ng-colors-border-brand) inset ;\n}\n\n.select.select--open:hover .select__combobox {\n border-color: var(--nile-colors-neutral-500,var(--ng-colors-border-brand));\n box-shadow: 0 0 0 1px var(--ng-colors-border-brand) inset ;\n}\n\n.select.select--open .select__combobox:hover {\n border-color: var(--nile-colors-dark-900, var(--ng-colors-border-brand));\n box-shadow: 0 0 0 1px var(--ng-colors-border-brand) inset ;\n}\n\n:host([stickyHeader]) .select__footer{\n z-index: 1;\n}\n \n`;\n\nexport default [styles];\n"]}
@@ -184,6 +184,7 @@ export declare class NileSelect extends NileElement implements NileFormControl {
184
184
  autoFocusSearch: boolean;
185
185
  /** loading indicator for virtual select */
186
186
  loading: boolean;
187
+ stickyHeader: boolean;
187
188
  /** Gets the validity state object */
188
189
  get validity(): ValidityState;
189
190
  /** Gets the validation message */
@@ -200,6 +201,7 @@ export declare class NileSelect extends NileElement implements NileFormControl {
200
201
  private handleFocus;
201
202
  private handleBlur;
202
203
  private handleDocumentFocusIn;
204
+ private updateGroupStickyOffsets;
203
205
  /**
204
206
  * Handles the click event on the footer.
205
207
  * @param event - The click event.
@@ -224,6 +226,7 @@ export declare class NileSelect extends NileElement implements NileFormControl {
224
226
  private handleClearClick;
225
227
  private handleClearMouseDown;
226
228
  handleOptionClick(event: MouseEvent): void;
229
+ private applyStickyToGroups;
227
230
  private handleDefaultSlotChange;
228
231
  private handleTagRemove;
229
232
  private getAllOptions;
@@ -194,6 +194,7 @@ let NileSelect = class NileSelect extends NileElement {
194
194
  this.autoFocusSearch = false;
195
195
  /** loading indicator for virtual select */
196
196
  this.loading = false;
197
+ this.stickyHeader = false;
197
198
  this.handleWindowResize = () => {
198
199
  this.portalManager.updatePortalAppendPosition();
199
200
  };
@@ -246,6 +247,9 @@ let NileSelect = class NileSelect extends NileElement {
246
247
  }
247
248
  }
248
249
  updated(_changedProperties) {
250
+ if (_changedProperties.has('searchEnabled')) {
251
+ this.updateGroupStickyOffsets();
252
+ }
249
253
  if (_changedProperties.has('multiple')) {
250
254
  this.setCheckBoxInOption(this.multiple);
251
255
  }
@@ -256,6 +260,7 @@ let NileSelect = class NileSelect extends NileElement {
256
260
  firstUpdated(_changedProperties) {
257
261
  if (this.enableGroupHeader) {
258
262
  this.handleGroupSearchChange();
263
+ this.applyStickyToGroups();
259
264
  }
260
265
  this.setupResizeObserver();
261
266
  if (_changedProperties.has('multiple')) {
@@ -330,6 +335,17 @@ let NileSelect = class NileSelect extends NileElement {
330
335
  this.hide();
331
336
  }
332
337
  }
338
+ updateGroupStickyOffsets() {
339
+ const groups = this.querySelectorAll('nile-option-group');
340
+ groups.forEach(g => {
341
+ if (this.searchEnabled) {
342
+ g.setAttribute('search-enabled', '');
343
+ }
344
+ else {
345
+ g.removeAttribute('search-enabled');
346
+ }
347
+ });
348
+ }
333
349
  /**
334
350
  * Handles the click event on the footer.
335
351
  * @param event - The click event.
@@ -570,10 +586,23 @@ let NileSelect = class NileSelect extends NileElement {
570
586
  this.portalManager.updatePortalOptions();
571
587
  }
572
588
  }
589
+ applyStickyToGroups() {
590
+ const groups = this.querySelectorAll('nile-option-group');
591
+ groups.forEach(g => {
592
+ if (this.stickyHeader) {
593
+ g.setAttribute('sticky', '');
594
+ }
595
+ else {
596
+ g.removeAttribute('sticky');
597
+ }
598
+ });
599
+ }
573
600
  handleDefaultSlotChange() {
574
601
  const allOptions = this.getAllOptions();
575
602
  const value = Array.isArray(this.value) ? this.value : [this.value];
576
603
  const values = [];
604
+ this.updateGroupStickyOffsets();
605
+ this.applyStickyToGroups();
577
606
  // Check for duplicate values in menu items
578
607
  if (customElements.get('nile-option')) {
579
608
  allOptions.forEach(option => values.push(option.value));
@@ -1546,6 +1575,9 @@ __decorate([
1546
1575
  __decorate([
1547
1576
  property({ type: Boolean, reflect: true, attribute: true })
1548
1577
  ], NileSelect.prototype, "loading", void 0);
1578
+ __decorate([
1579
+ property({ type: Boolean, reflect: true })
1580
+ ], NileSelect.prototype, "stickyHeader", void 0);
1549
1581
  __decorate([
1550
1582
  watch('disabled', { waitUntilFirstUpdate: true })
1551
1583
  ], NileSelect.prototype, "handleDisabledChange", null);