@aquera/nile-elements 1.6.1 → 1.6.3

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 (741) hide show
  1. package/README.md +14 -0
  2. package/dist/index.cjs.js +1 -1
  3. package/dist/index.esm.js +1 -1
  4. package/dist/index.js +1150 -624
  5. package/dist/internal/accessibility/a11y.custom-value.enum.cjs.js +2 -0
  6. package/dist/internal/accessibility/a11y.custom-value.enum.cjs.js.map +1 -0
  7. package/dist/internal/accessibility/a11y.custom-value.enum.esm.js +1 -0
  8. package/dist/internal/accessibility/a11y.property.enum.cjs.js +2 -0
  9. package/dist/internal/accessibility/a11y.property.enum.cjs.js.map +1 -0
  10. package/dist/internal/accessibility/a11y.property.enum.esm.js +1 -0
  11. package/dist/internal/accessibility/a11y.role.enum.cjs.js +2 -0
  12. package/dist/internal/accessibility/a11y.role.enum.cjs.js.map +1 -0
  13. package/dist/internal/accessibility/a11y.role.enum.esm.js +1 -0
  14. package/dist/internal/accessibility/a11y.state.enum.cjs.js +2 -0
  15. package/dist/internal/accessibility/a11y.state.enum.cjs.js.map +1 -0
  16. package/dist/internal/accessibility/a11y.state.enum.esm.js +1 -0
  17. package/dist/internal/accessibility/accessibility.const.cjs.js +2 -0
  18. package/dist/internal/accessibility/accessibility.const.cjs.js.map +1 -0
  19. package/dist/internal/accessibility/accessibility.const.esm.js +1 -0
  20. package/dist/internal/accessibility/role.enum.cjs.js +2 -0
  21. package/dist/internal/accessibility/role.enum.cjs.js.map +1 -0
  22. package/dist/internal/accessibility/role.enum.esm.js +1 -0
  23. package/dist/internal/enum.cjs.js +1 -1
  24. package/dist/internal/enum.cjs.js.map +1 -1
  25. package/dist/internal/enum.esm.js +1 -1
  26. package/dist/internal/nile-element.cjs.js +1 -1
  27. package/dist/internal/nile-element.cjs.js.map +1 -1
  28. package/dist/internal/nile-element.esm.js +1 -1
  29. package/dist/nile-accordion/index.cjs.js +1 -1
  30. package/dist/nile-accordion/index.esm.js +1 -1
  31. package/dist/nile-accordion/nile-accordion.cjs.js +1 -1
  32. package/dist/nile-accordion/nile-accordion.cjs.js.map +1 -1
  33. package/dist/nile-accordion/nile-accordion.esm.js +2 -2
  34. package/dist/nile-auto-complete/index.cjs.js +1 -1
  35. package/dist/nile-auto-complete/index.esm.js +1 -1
  36. package/dist/nile-auto-complete/nile-auto-complete.cjs.js +1 -1
  37. package/dist/nile-auto-complete/nile-auto-complete.cjs.js.map +1 -1
  38. package/dist/nile-auto-complete/nile-auto-complete.esm.js +1 -1
  39. package/dist/nile-avatar/index.cjs.js +1 -1
  40. package/dist/nile-avatar/index.esm.js +1 -1
  41. package/dist/nile-avatar/nile-avatar.cjs.js +1 -1
  42. package/dist/nile-avatar/nile-avatar.cjs.js.map +1 -1
  43. package/dist/nile-avatar/nile-avatar.esm.js +3 -1
  44. package/dist/nile-badge/index.cjs.js +1 -1
  45. package/dist/nile-badge/index.esm.js +1 -1
  46. package/dist/nile-badge/nile-badge.cjs.js +1 -1
  47. package/dist/nile-badge/nile-badge.cjs.js.map +1 -1
  48. package/dist/nile-badge/nile-badge.esm.js +2 -2
  49. package/dist/nile-breadcrumb/index.cjs.js +1 -1
  50. package/dist/nile-breadcrumb/index.esm.js +1 -1
  51. package/dist/nile-breadcrumb/nile-breadcrumb.cjs.js +1 -1
  52. package/dist/nile-breadcrumb/nile-breadcrumb.cjs.js.map +1 -1
  53. package/dist/nile-breadcrumb/nile-breadcrumb.esm.js +1 -1
  54. package/dist/nile-breadcrumb-item/index.cjs.js +1 -1
  55. package/dist/nile-breadcrumb-item/index.esm.js +1 -1
  56. package/dist/nile-breadcrumb-item/nile-breadcrumb-item.cjs.js +1 -1
  57. package/dist/nile-breadcrumb-item/nile-breadcrumb-item.cjs.js.map +1 -1
  58. package/dist/nile-breadcrumb-item/nile-breadcrumb-item.esm.js +4 -4
  59. package/dist/nile-button/index.cjs.js +1 -1
  60. package/dist/nile-button/index.esm.js +1 -1
  61. package/dist/nile-button/nile-button.cjs.js +1 -1
  62. package/dist/nile-button/nile-button.cjs.js.map +1 -1
  63. package/dist/nile-button/nile-button.esm.js +1 -1
  64. package/dist/nile-button-filter/index.cjs.js +1 -1
  65. package/dist/nile-button-filter/index.esm.js +1 -1
  66. package/dist/nile-button-filter/nile-button-filter.cjs.js +1 -1
  67. package/dist/nile-button-filter/nile-button-filter.cjs.js.map +1 -1
  68. package/dist/nile-button-filter/nile-button-filter.esm.js +7 -7
  69. package/dist/nile-button-toggle/index.cjs.js +1 -1
  70. package/dist/nile-button-toggle/index.esm.js +1 -1
  71. package/dist/nile-button-toggle/nile-button-toggle.cjs.js +1 -1
  72. package/dist/nile-button-toggle/nile-button-toggle.cjs.js.map +1 -1
  73. package/dist/nile-button-toggle/nile-button-toggle.esm.js +2 -2
  74. package/dist/nile-button-toggle-group/index.cjs.js +1 -1
  75. package/dist/nile-button-toggle-group/index.esm.js +1 -1
  76. package/dist/nile-button-toggle-group/nile-button-toggle-group.cjs.js +1 -1
  77. package/dist/nile-button-toggle-group/nile-button-toggle-group.cjs.js.map +1 -1
  78. package/dist/nile-button-toggle-group/nile-button-toggle-group.esm.js +1 -1
  79. package/dist/nile-calendar/index.cjs.js +1 -1
  80. package/dist/nile-calendar/index.esm.js +1 -1
  81. package/dist/nile-calendar/nile-calendar.cjs.js +1 -1
  82. package/dist/nile-calendar/nile-calendar.cjs.js.map +1 -1
  83. package/dist/nile-calendar/nile-calendar.esm.js +4 -4
  84. package/dist/nile-card/index.cjs.js +1 -1
  85. package/dist/nile-card/index.esm.js +1 -1
  86. package/dist/nile-card/nile-card.cjs.js +1 -1
  87. package/dist/nile-card/nile-card.cjs.js.map +1 -1
  88. package/dist/nile-card/nile-card.esm.js +2 -2
  89. package/dist/nile-carousel/index.cjs.js +1 -1
  90. package/dist/nile-carousel/index.esm.js +1 -1
  91. package/dist/nile-carousel/nile-carousel-item/index.cjs.js +1 -1
  92. package/dist/nile-carousel/nile-carousel-item/index.esm.js +1 -1
  93. package/dist/nile-carousel/nile-carousel-item/nile-carousel-item.cjs.js +1 -1
  94. package/dist/nile-carousel/nile-carousel-item/nile-carousel-item.cjs.js.map +1 -1
  95. package/dist/nile-carousel/nile-carousel-item/nile-carousel-item.esm.js +2 -2
  96. package/dist/nile-carousel/nile-carousel.cjs.js +1 -1
  97. package/dist/nile-carousel/nile-carousel.cjs.js.map +1 -1
  98. package/dist/nile-carousel/nile-carousel.esm.js +1 -1
  99. package/dist/nile-checkbox/index.cjs.js +1 -1
  100. package/dist/nile-checkbox/index.esm.js +1 -1
  101. package/dist/nile-checkbox/nile-checkbox.cjs.js +1 -1
  102. package/dist/nile-checkbox/nile-checkbox.cjs.js.map +1 -1
  103. package/dist/nile-checkbox/nile-checkbox.css.cjs.js +1 -1
  104. package/dist/nile-checkbox/nile-checkbox.css.cjs.js.map +1 -1
  105. package/dist/nile-checkbox/nile-checkbox.css.esm.js +4 -0
  106. package/dist/nile-checkbox/nile-checkbox.esm.js +3 -3
  107. package/dist/nile-checkbox-group/index.cjs.js +2 -0
  108. package/dist/nile-checkbox-group/index.cjs.js.map +1 -0
  109. package/dist/nile-checkbox-group/index.esm.js +1 -0
  110. package/dist/nile-checkbox-group/nile-checkbox-group.cjs.js +2 -0
  111. package/dist/nile-checkbox-group/nile-checkbox-group.cjs.js.map +1 -0
  112. package/dist/nile-checkbox-group/nile-checkbox-group.css.cjs.js +2 -0
  113. package/dist/nile-checkbox-group/nile-checkbox-group.css.cjs.js.map +1 -0
  114. package/dist/nile-checkbox-group/nile-checkbox-group.css.esm.js +68 -0
  115. package/dist/nile-checkbox-group/nile-checkbox-group.esm.js +56 -0
  116. package/dist/nile-chip/index.cjs.js +1 -1
  117. package/dist/nile-chip/index.esm.js +1 -1
  118. package/dist/nile-chip/nile-chip.cjs.js +1 -1
  119. package/dist/nile-chip/nile-chip.cjs.js.map +1 -1
  120. package/dist/nile-chip/nile-chip.esm.js +2 -2
  121. package/dist/nile-circular-progressbar/index.cjs.js +1 -1
  122. package/dist/nile-circular-progressbar/index.esm.js +1 -1
  123. package/dist/nile-circular-progressbar/nile-circular-progressbar.cjs.js +1 -1
  124. package/dist/nile-circular-progressbar/nile-circular-progressbar.cjs.js.map +1 -1
  125. package/dist/nile-circular-progressbar/nile-circular-progressbar.esm.js +2 -2
  126. package/dist/nile-code-editor/index.cjs.js +1 -1
  127. package/dist/nile-code-editor/index.esm.js +1 -1
  128. package/dist/nile-code-editor/nile-code-editor.cjs.js +1 -1
  129. package/dist/nile-code-editor/nile-code-editor.cjs.js.map +1 -1
  130. package/dist/nile-code-editor/nile-code-editor.esm.js +1 -1
  131. package/dist/nile-content-editor/index.cjs.js +1 -1
  132. package/dist/nile-content-editor/index.esm.js +1 -1
  133. package/dist/nile-content-editor/nile-content-editor.cjs.js +1 -1
  134. package/dist/nile-content-editor/nile-content-editor.cjs.js.map +1 -1
  135. package/dist/nile-content-editor/nile-content-editor.esm.js +5 -5
  136. package/dist/nile-date-picker/index.cjs.js +1 -1
  137. package/dist/nile-date-picker/index.esm.js +1 -1
  138. package/dist/nile-date-picker/nile-date-picker.cjs.js +1 -1
  139. package/dist/nile-date-picker/nile-date-picker.cjs.js.map +1 -1
  140. package/dist/nile-date-picker/nile-date-picker.esm.js +1 -1
  141. package/dist/nile-detail/index.cjs.js +1 -1
  142. package/dist/nile-detail/index.esm.js +1 -1
  143. package/dist/nile-detail/nile-detail.cjs.js +1 -1
  144. package/dist/nile-detail/nile-detail.cjs.js.map +1 -1
  145. package/dist/nile-detail/nile-detail.esm.js +2 -2
  146. package/dist/nile-dialog/index.cjs.js +1 -1
  147. package/dist/nile-dialog/index.esm.js +1 -1
  148. package/dist/nile-dialog/nile-dialog.cjs.js +1 -1
  149. package/dist/nile-dialog/nile-dialog.cjs.js.map +1 -1
  150. package/dist/nile-dialog/nile-dialog.esm.js +2 -2
  151. package/dist/nile-divider/index.cjs.js +1 -1
  152. package/dist/nile-divider/index.esm.js +1 -1
  153. package/dist/nile-divider/nile-divider.cjs.js +1 -1
  154. package/dist/nile-divider/nile-divider.cjs.js.map +1 -1
  155. package/dist/nile-divider/nile-divider.esm.js +2 -2
  156. package/dist/nile-drawer/index.cjs.js +1 -1
  157. package/dist/nile-drawer/index.esm.js +1 -1
  158. package/dist/nile-drawer/nile-drawer.cjs.js +1 -1
  159. package/dist/nile-drawer/nile-drawer.cjs.js.map +1 -1
  160. package/dist/nile-drawer/nile-drawer.esm.js +1 -1
  161. package/dist/nile-dropdown/index.cjs.js +1 -1
  162. package/dist/nile-dropdown/index.esm.js +1 -1
  163. package/dist/nile-dropdown/nile-dropdown.cjs.js +1 -1
  164. package/dist/nile-dropdown/nile-dropdown.cjs.js.map +1 -1
  165. package/dist/nile-dropdown/nile-dropdown.esm.js +1 -1
  166. package/dist/nile-empty-state/index.cjs.js +1 -1
  167. package/dist/nile-empty-state/index.esm.js +1 -1
  168. package/dist/nile-empty-state/nile-empty-state.cjs.js +1 -1
  169. package/dist/nile-empty-state/nile-empty-state.cjs.js.map +1 -1
  170. package/dist/nile-empty-state/nile-empty-state.esm.js +2 -2
  171. package/dist/nile-file-preview/index.cjs.js +1 -1
  172. package/dist/nile-file-preview/index.esm.js +1 -1
  173. package/dist/nile-file-preview/nile-file-preview.cjs.js +1 -1
  174. package/dist/nile-file-preview/nile-file-preview.cjs.js.map +1 -1
  175. package/dist/nile-file-preview/nile-file-preview.esm.js +1 -1
  176. package/dist/nile-file-upload/index.cjs.js +1 -1
  177. package/dist/nile-file-upload/index.esm.js +1 -1
  178. package/dist/nile-file-upload/nile-file-upload.cjs.js +1 -1
  179. package/dist/nile-file-upload/nile-file-upload.cjs.js.map +1 -1
  180. package/dist/nile-file-upload/nile-file-upload.esm.js +2 -2
  181. package/dist/nile-filter-chip/index.cjs.js +1 -1
  182. package/dist/nile-filter-chip/index.esm.js +1 -1
  183. package/dist/nile-filter-chip/nile-filter-chip.cjs.js +1 -1
  184. package/dist/nile-filter-chip/nile-filter-chip.cjs.js.map +1 -1
  185. package/dist/nile-filter-chip/nile-filter-chip.esm.js +2 -2
  186. package/dist/nile-floating-panel/index.cjs.js +1 -1
  187. package/dist/nile-floating-panel/index.esm.js +1 -1
  188. package/dist/nile-floating-panel/nile-floating-panel.cjs.js +1 -1
  189. package/dist/nile-floating-panel/nile-floating-panel.cjs.js.map +1 -1
  190. package/dist/nile-floating-panel/nile-floating-panel.esm.js +1 -1
  191. package/dist/nile-form-group/index.cjs.js +1 -1
  192. package/dist/nile-form-group/index.esm.js +1 -1
  193. package/dist/nile-form-group/nile-form-group.cjs.js +1 -1
  194. package/dist/nile-form-group/nile-form-group.cjs.js.map +1 -1
  195. package/dist/nile-form-group/nile-form-group.esm.js +2 -2
  196. package/dist/nile-format-date/index.cjs.js +1 -1
  197. package/dist/nile-format-date/index.esm.js +1 -1
  198. package/dist/nile-format-date/nile-format-date.cjs.js +1 -1
  199. package/dist/nile-format-date/nile-format-date.cjs.js.map +1 -1
  200. package/dist/nile-format-date/nile-format-date.esm.js +1 -1
  201. package/dist/nile-grid/index.cjs.js +1 -1
  202. package/dist/nile-grid/index.esm.js +1 -1
  203. package/dist/nile-grid/nile-grid-body/index.cjs.js +1 -1
  204. package/dist/nile-grid/nile-grid-body/index.esm.js +1 -1
  205. package/dist/nile-grid/nile-grid-body/nile-grid-body.cjs.js +1 -1
  206. package/dist/nile-grid/nile-grid-body/nile-grid-body.cjs.js.map +1 -1
  207. package/dist/nile-grid/nile-grid-body/nile-grid-body.esm.js +2 -2
  208. package/dist/nile-grid/nile-grid-cell-item/index.cjs.js +1 -1
  209. package/dist/nile-grid/nile-grid-cell-item/index.esm.js +1 -1
  210. package/dist/nile-grid/nile-grid-cell-item/nile-grid-cell-item.cjs.js +1 -1
  211. package/dist/nile-grid/nile-grid-cell-item/nile-grid-cell-item.cjs.js.map +1 -1
  212. package/dist/nile-grid/nile-grid-cell-item/nile-grid-cell-item.esm.js +2 -2
  213. package/dist/nile-grid/nile-grid-head/index.cjs.js +1 -1
  214. package/dist/nile-grid/nile-grid-head/index.esm.js +1 -1
  215. package/dist/nile-grid/nile-grid-head/nile-grid-head.cjs.js +1 -1
  216. package/dist/nile-grid/nile-grid-head/nile-grid-head.cjs.js.map +1 -1
  217. package/dist/nile-grid/nile-grid-head/nile-grid-head.esm.js +2 -2
  218. package/dist/nile-grid/nile-grid-head-item/index.cjs.js +1 -1
  219. package/dist/nile-grid/nile-grid-head-item/index.esm.js +1 -1
  220. package/dist/nile-grid/nile-grid-head-item/nile-grid-head-item.cjs.js +1 -1
  221. package/dist/nile-grid/nile-grid-head-item/nile-grid-head-item.cjs.js.map +1 -1
  222. package/dist/nile-grid/nile-grid-head-item/nile-grid-head-item.esm.js +3 -3
  223. package/dist/nile-grid/nile-grid-row/index.cjs.js +1 -1
  224. package/dist/nile-grid/nile-grid-row/index.esm.js +1 -1
  225. package/dist/nile-grid/nile-grid-row/nile-grid-row.cjs.js +1 -1
  226. package/dist/nile-grid/nile-grid-row/nile-grid-row.cjs.js.map +1 -1
  227. package/dist/nile-grid/nile-grid-row/nile-grid-row.esm.js +2 -2
  228. package/dist/nile-grid/nile-grid.cjs.js +1 -1
  229. package/dist/nile-grid/nile-grid.cjs.js.map +1 -1
  230. package/dist/nile-grid/nile-grid.esm.js +2 -2
  231. package/dist/nile-hero/index.cjs.js +1 -1
  232. package/dist/nile-hero/index.esm.js +1 -1
  233. package/dist/nile-hero/nile-hero.cjs.js +1 -1
  234. package/dist/nile-hero/nile-hero.cjs.js.map +1 -1
  235. package/dist/nile-hero/nile-hero.esm.js +2 -2
  236. package/dist/nile-hero-header/index.cjs.js +1 -1
  237. package/dist/nile-hero-header/index.esm.js +1 -1
  238. package/dist/nile-hero-header/nile-hero-header.cjs.js +1 -1
  239. package/dist/nile-hero-header/nile-hero-header.cjs.js.map +1 -1
  240. package/dist/nile-hero-header/nile-hero-header.esm.js +2 -2
  241. package/dist/nile-icon/icons/svg/folder_delete.cjs.js +2 -0
  242. package/dist/nile-icon/icons/svg/folder_delete.cjs.js.map +1 -0
  243. package/dist/nile-icon/icons/svg/folder_delete.esm.js +1 -0
  244. package/dist/nile-icon/icons/svg/index.cjs.js +1 -1
  245. package/dist/nile-icon/icons/svg/index.esm.js +1 -1
  246. package/dist/nile-icon/icons/svg/layers-three-02.cjs.js +1 -1
  247. package/dist/nile-icon/icons/svg/layers-three-02.cjs.js.map +1 -1
  248. package/dist/nile-icon/icons/svg/layers-three-02.esm.js +1 -1
  249. package/dist/nile-icon/index.cjs.js +1 -1
  250. package/dist/nile-icon/index.cjs.js.map +1 -1
  251. package/dist/nile-icon/index.esm.js +1 -1
  252. package/dist/nile-icon-button/index.cjs.js +1 -1
  253. package/dist/nile-icon-button/index.esm.js +1 -1
  254. package/dist/nile-icon-button/nile-icon-button.cjs.js +1 -1
  255. package/dist/nile-icon-button/nile-icon-button.cjs.js.map +1 -1
  256. package/dist/nile-icon-button/nile-icon-button.esm.js +1 -1
  257. package/dist/nile-inline-edit/index.cjs.js +1 -1
  258. package/dist/nile-inline-edit/index.esm.js +1 -1
  259. package/dist/nile-inline-edit/nile-inline-edit.cjs.js +1 -1
  260. package/dist/nile-inline-edit/nile-inline-edit.cjs.js.map +1 -1
  261. package/dist/nile-inline-edit/nile-inline-edit.esm.js +2 -2
  262. package/dist/nile-inline-sidebar/index.cjs.js +1 -1
  263. package/dist/nile-inline-sidebar/index.esm.js +1 -1
  264. package/dist/nile-inline-sidebar/nile-inline-sidebar.cjs.js +1 -1
  265. package/dist/nile-inline-sidebar/nile-inline-sidebar.cjs.js.map +1 -1
  266. package/dist/nile-inline-sidebar/nile-inline-sidebar.esm.js +3 -3
  267. package/dist/nile-inline-sidebar-group/index.cjs.js +1 -1
  268. package/dist/nile-inline-sidebar-group/index.esm.js +1 -1
  269. package/dist/nile-inline-sidebar-group/nile-inline-sidebar-group.cjs.js +1 -1
  270. package/dist/nile-inline-sidebar-group/nile-inline-sidebar-group.cjs.js.map +1 -1
  271. package/dist/nile-inline-sidebar-group/nile-inline-sidebar-group.esm.js +3 -3
  272. package/dist/nile-inline-sidebar-item/index.cjs.js +1 -1
  273. package/dist/nile-inline-sidebar-item/index.esm.js +1 -1
  274. package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.cjs.js +1 -1
  275. package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.cjs.js.map +1 -1
  276. package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.esm.js +3 -3
  277. package/dist/nile-input/index.cjs.js +1 -1
  278. package/dist/nile-input/index.esm.js +1 -1
  279. package/dist/nile-input/nile-input.cjs.js +1 -1
  280. package/dist/nile-input/nile-input.cjs.js.map +1 -1
  281. package/dist/nile-input/nile-input.esm.js +1 -1
  282. package/dist/nile-link/index.cjs.js +1 -1
  283. package/dist/nile-link/index.esm.js +1 -1
  284. package/dist/nile-link/nile-link.cjs.js +1 -1
  285. package/dist/nile-link/nile-link.cjs.js.map +1 -1
  286. package/dist/nile-link/nile-link.esm.js +3 -3
  287. package/dist/nile-list/index.cjs.js +1 -1
  288. package/dist/nile-list/index.esm.js +1 -1
  289. package/dist/nile-list/nile-list.cjs.js +1 -1
  290. package/dist/nile-list/nile-list.cjs.js.map +1 -1
  291. package/dist/nile-list/nile-list.esm.js +1 -1
  292. package/dist/nile-list-item/index.cjs.js +1 -1
  293. package/dist/nile-list-item/index.esm.js +1 -1
  294. package/dist/nile-list-item/nile-list-item.cjs.js +1 -1
  295. package/dist/nile-list-item/nile-list-item.cjs.js.map +1 -1
  296. package/dist/nile-list-item/nile-list-item.esm.js +2 -2
  297. package/dist/nile-lite-tooltip/index.cjs.js +1 -1
  298. package/dist/nile-lite-tooltip/index.esm.js +1 -1
  299. package/dist/nile-lite-tooltip/nile-lite-tooltip.cjs.js +1 -1
  300. package/dist/nile-lite-tooltip/nile-lite-tooltip.cjs.js.map +1 -1
  301. package/dist/nile-lite-tooltip/nile-lite-tooltip.esm.js +1 -1
  302. package/dist/nile-menu/index.cjs.js +1 -1
  303. package/dist/nile-menu/index.esm.js +1 -1
  304. package/dist/nile-menu/nile-menu.cjs.js +1 -1
  305. package/dist/nile-menu/nile-menu.cjs.js.map +1 -1
  306. package/dist/nile-menu/nile-menu.esm.js +2 -2
  307. package/dist/nile-menu-item/index.cjs.js +1 -1
  308. package/dist/nile-menu-item/index.esm.js +1 -1
  309. package/dist/nile-menu-item/nile-menu-item.cjs.js +1 -1
  310. package/dist/nile-menu-item/nile-menu-item.cjs.js.map +1 -1
  311. package/dist/nile-menu-item/nile-menu-item.esm.js +1 -1
  312. package/dist/nile-option/index.cjs.js +1 -1
  313. package/dist/nile-option/index.esm.js +1 -1
  314. package/dist/nile-option/nile-option.cjs.js +1 -1
  315. package/dist/nile-option/nile-option.cjs.js.map +1 -1
  316. package/dist/nile-option/nile-option.esm.js +5 -5
  317. package/dist/nile-option-group/index.cjs.js +1 -1
  318. package/dist/nile-option-group/index.esm.js +1 -1
  319. package/dist/nile-option-group/nile-option-group.cjs.js +1 -1
  320. package/dist/nile-option-group/nile-option-group.cjs.js.map +1 -1
  321. package/dist/nile-option-group/nile-option-group.esm.js +2 -2
  322. package/dist/nile-otp-input/index.cjs.js +2 -0
  323. package/dist/nile-otp-input/index.cjs.js.map +1 -0
  324. package/dist/nile-otp-input/index.esm.js +1 -0
  325. package/dist/nile-otp-input/nile-otp-input.cjs.js +2 -0
  326. package/dist/nile-otp-input/nile-otp-input.cjs.js.map +1 -0
  327. package/dist/nile-otp-input/nile-otp-input.css.cjs.js +2 -0
  328. package/dist/nile-otp-input/nile-otp-input.css.cjs.js.map +1 -0
  329. package/dist/nile-otp-input/nile-otp-input.css.esm.js +257 -0
  330. package/dist/nile-otp-input/nile-otp-input.enum.cjs.js +2 -0
  331. package/dist/nile-otp-input/nile-otp-input.enum.cjs.js.map +1 -0
  332. package/dist/nile-otp-input/nile-otp-input.enum.esm.js +1 -0
  333. package/dist/nile-otp-input/nile-otp-input.esm.js +103 -0
  334. package/dist/nile-page-header/index.cjs.js +1 -1
  335. package/dist/nile-page-header/index.esm.js +1 -1
  336. package/dist/nile-page-header/nile-page-header.cjs.js +1 -1
  337. package/dist/nile-page-header/nile-page-header.cjs.js.map +1 -1
  338. package/dist/nile-page-header/nile-page-header.esm.js +2 -2
  339. package/dist/nile-pagination/index.cjs.js +1 -1
  340. package/dist/nile-pagination/index.esm.js +1 -1
  341. package/dist/nile-pagination/nile-pagination.cjs.js +1 -1
  342. package/dist/nile-pagination/nile-pagination.cjs.js.map +1 -1
  343. package/dist/nile-pagination/nile-pagination.css.cjs.js +1 -1
  344. package/dist/nile-pagination/nile-pagination.css.cjs.js.map +1 -1
  345. package/dist/nile-pagination/nile-pagination.css.esm.js +7 -0
  346. package/dist/nile-pagination/nile-pagination.esm.js +1 -1
  347. package/dist/nile-popover/index.cjs.js +1 -1
  348. package/dist/nile-popover/index.esm.js +1 -1
  349. package/dist/nile-popover/nile-popover.cjs.js +2 -2
  350. package/dist/nile-popover/nile-popover.cjs.js.map +1 -1
  351. package/dist/nile-popover/nile-popover.esm.js +3 -3
  352. package/dist/nile-popup/index.cjs.js +1 -1
  353. package/dist/nile-popup/index.esm.js +1 -1
  354. package/dist/nile-popup/nile-popup.cjs.js +1 -1
  355. package/dist/nile-popup/nile-popup.cjs.js.map +1 -1
  356. package/dist/nile-popup/nile-popup.esm.js +2 -2
  357. package/dist/nile-progress-bar/index.cjs.js +1 -1
  358. package/dist/nile-progress-bar/index.esm.js +1 -1
  359. package/dist/nile-progress-bar/nile-progress-bar.cjs.js +1 -1
  360. package/dist/nile-progress-bar/nile-progress-bar.cjs.js.map +1 -1
  361. package/dist/nile-progress-bar/nile-progress-bar.esm.js +2 -2
  362. package/dist/nile-qr-code/index.cjs.js +1 -1
  363. package/dist/nile-qr-code/index.esm.js +1 -1
  364. package/dist/nile-qr-code/nile-qr-code.cjs.js +1 -1
  365. package/dist/nile-qr-code/nile-qr-code.cjs.js.map +1 -1
  366. package/dist/nile-qr-code/nile-qr-code.esm.js +2 -2
  367. package/dist/nile-radio/index.cjs.js +1 -1
  368. package/dist/nile-radio/index.esm.js +1 -1
  369. package/dist/nile-radio/nile-radio.cjs.js +1 -1
  370. package/dist/nile-radio/nile-radio.cjs.js.map +1 -1
  371. package/dist/nile-radio/nile-radio.css.cjs.js +1 -1
  372. package/dist/nile-radio/nile-radio.css.cjs.js.map +1 -1
  373. package/dist/nile-radio/nile-radio.css.esm.js +4 -0
  374. package/dist/nile-radio/nile-radio.esm.js +2 -2
  375. package/dist/nile-radio-group/index.cjs.js +1 -1
  376. package/dist/nile-radio-group/index.esm.js +1 -1
  377. package/dist/nile-radio-group/nile-radio-group.cjs.js +1 -1
  378. package/dist/nile-radio-group/nile-radio-group.cjs.js.map +1 -1
  379. package/dist/nile-radio-group/nile-radio-group.esm.js +2 -2
  380. package/dist/nile-rich-text-editor/nile-rich-text-editor.cjs.js +1 -1
  381. package/dist/nile-rich-text-editor/nile-rich-text-editor.cjs.js.map +1 -1
  382. package/dist/nile-rich-text-editor/nile-rich-text-editor.css.cjs.js +1 -1
  383. package/dist/nile-rich-text-editor/nile-rich-text-editor.css.cjs.js.map +1 -1
  384. package/dist/nile-rich-text-editor/nile-rich-text-editor.css.esm.js +8 -6
  385. package/dist/nile-rich-text-editor/nile-rich-text-editor.esm.js +1 -1
  386. package/dist/nile-section-message/index.cjs.js +1 -1
  387. package/dist/nile-section-message/index.esm.js +1 -1
  388. package/dist/nile-section-message/nile-section-message.cjs.js +1 -1
  389. package/dist/nile-section-message/nile-section-message.cjs.js.map +1 -1
  390. package/dist/nile-section-message/nile-section-message.esm.js +2 -2
  391. package/dist/nile-select/index.cjs.js +1 -1
  392. package/dist/nile-select/index.esm.js +1 -1
  393. package/dist/nile-select/nile-select.cjs.js +1 -1
  394. package/dist/nile-select/nile-select.cjs.js.map +1 -1
  395. package/dist/nile-select/nile-select.css.cjs.js +1 -1
  396. package/dist/nile-select/nile-select.css.cjs.js.map +1 -1
  397. package/dist/nile-select/nile-select.css.esm.js +21 -2
  398. package/dist/nile-select/nile-select.esm.js +33 -25
  399. package/dist/nile-select/portal-utils.cjs.js +1 -1
  400. package/dist/nile-select/portal-utils.cjs.js.map +1 -1
  401. package/dist/nile-select/portal-utils.esm.js +1 -1
  402. package/dist/nile-side-bar/index.cjs.js +1 -1
  403. package/dist/nile-side-bar/index.esm.js +1 -1
  404. package/dist/nile-side-bar/nile-side-bar.cjs.js +1 -1
  405. package/dist/nile-side-bar/nile-side-bar.cjs.js.map +1 -1
  406. package/dist/nile-side-bar/nile-side-bar.esm.js +2 -2
  407. package/dist/nile-side-bar-action/index.cjs.js +1 -1
  408. package/dist/nile-side-bar-action/index.esm.js +1 -1
  409. package/dist/nile-side-bar-action/nile-side-bar-action.cjs.js +1 -1
  410. package/dist/nile-side-bar-action/nile-side-bar-action.cjs.js.map +1 -1
  411. package/dist/nile-side-bar-action/nile-side-bar-action.esm.js +3 -3
  412. package/dist/nile-side-bar-action-menu/index.cjs.js +1 -1
  413. package/dist/nile-side-bar-action-menu/index.esm.js +1 -1
  414. package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.cjs.js +1 -1
  415. package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.cjs.js.map +1 -1
  416. package/dist/nile-side-bar-action-menu/nile-side-bar-action-menu.esm.js +2 -2
  417. package/dist/nile-side-bar-action-menu-item/index.cjs.js +1 -1
  418. package/dist/nile-side-bar-action-menu-item/index.esm.js +1 -1
  419. package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.cjs.js +1 -1
  420. package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.cjs.js.map +1 -1
  421. package/dist/nile-side-bar-action-menu-item/nile-side-bar-action-menu-item.esm.js +1 -1
  422. package/dist/nile-side-bar-expand/index.cjs.js +1 -1
  423. package/dist/nile-side-bar-expand/index.esm.js +1 -1
  424. package/dist/nile-side-bar-expand/nile-side-bar-expand.cjs.js +1 -1
  425. package/dist/nile-side-bar-expand/nile-side-bar-expand.cjs.js.map +1 -1
  426. package/dist/nile-side-bar-expand/nile-side-bar-expand.esm.js +2 -2
  427. package/dist/nile-side-bar-footer/index.cjs.js +1 -1
  428. package/dist/nile-side-bar-footer/index.esm.js +1 -1
  429. package/dist/nile-side-bar-footer/nile-side-bar-footer.cjs.js +1 -1
  430. package/dist/nile-side-bar-footer/nile-side-bar-footer.cjs.js.map +1 -1
  431. package/dist/nile-side-bar-footer/nile-side-bar-footer.esm.js +2 -2
  432. package/dist/nile-side-bar-footer-item/index.cjs.js +1 -1
  433. package/dist/nile-side-bar-footer-item/index.esm.js +1 -1
  434. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.cjs.js +1 -1
  435. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.cjs.js.map +1 -1
  436. package/dist/nile-side-bar-footer-item/nile-side-bar-footer-item.esm.js +1 -1
  437. package/dist/nile-side-bar-footer-text/index.cjs.js +1 -1
  438. package/dist/nile-side-bar-footer-text/index.esm.js +1 -1
  439. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.cjs.js +1 -1
  440. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.cjs.js.map +1 -1
  441. package/dist/nile-side-bar-footer-text/nile-side-bar-footer-text.esm.js +3 -3
  442. package/dist/nile-side-bar-group/index.cjs.js +1 -1
  443. package/dist/nile-side-bar-group/index.esm.js +1 -1
  444. package/dist/nile-side-bar-group/nile-side-bar-group.cjs.js +1 -1
  445. package/dist/nile-side-bar-group/nile-side-bar-group.cjs.js.map +1 -1
  446. package/dist/nile-side-bar-group/nile-side-bar-group.esm.js +2 -2
  447. package/dist/nile-side-bar-group-item/index.cjs.js +1 -1
  448. package/dist/nile-side-bar-group-item/index.esm.js +1 -1
  449. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.cjs.js +1 -1
  450. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.cjs.js.map +1 -1
  451. package/dist/nile-side-bar-group-item/nile-side-bar-group-item.esm.js +2 -2
  452. package/dist/nile-side-bar-group-item-icon/index.cjs.js +1 -1
  453. package/dist/nile-side-bar-group-item-icon/index.esm.js +1 -1
  454. package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.cjs.js +1 -1
  455. package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.cjs.js.map +1 -1
  456. package/dist/nile-side-bar-group-item-icon/nile-side-bar-group-item-icon.esm.js +2 -2
  457. package/dist/nile-side-bar-group-item-text/index.cjs.js +1 -1
  458. package/dist/nile-side-bar-group-item-text/index.esm.js +1 -1
  459. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.cjs.js +1 -1
  460. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.cjs.js.map +1 -1
  461. package/dist/nile-side-bar-group-item-text/nile-side-bar-group-item-text.esm.js +1 -1
  462. package/dist/nile-side-bar-header/index.cjs.js +1 -1
  463. package/dist/nile-side-bar-header/index.esm.js +1 -1
  464. package/dist/nile-side-bar-header/nile-side-bar-header.cjs.js +1 -1
  465. package/dist/nile-side-bar-header/nile-side-bar-header.cjs.js.map +1 -1
  466. package/dist/nile-side-bar-header/nile-side-bar-header.esm.js +2 -2
  467. package/dist/nile-side-bar-logo/index.cjs.js +1 -1
  468. package/dist/nile-side-bar-logo/index.esm.js +1 -1
  469. package/dist/nile-side-bar-logo/nile-side-bar-logo.cjs.js +1 -1
  470. package/dist/nile-side-bar-logo/nile-side-bar-logo.cjs.js.map +1 -1
  471. package/dist/nile-side-bar-logo/nile-side-bar-logo.esm.js +2 -2
  472. package/dist/nile-side-bar-panel/index.cjs.js +1 -1
  473. package/dist/nile-side-bar-panel/index.esm.js +1 -1
  474. package/dist/nile-side-bar-panel/nile-side-bar-panel.cjs.js +1 -1
  475. package/dist/nile-side-bar-panel/nile-side-bar-panel.cjs.js.map +1 -1
  476. package/dist/nile-side-bar-panel/nile-side-bar-panel.esm.js +2 -2
  477. package/dist/nile-skeleton-loader/index.cjs.js +1 -1
  478. package/dist/nile-skeleton-loader/index.esm.js +1 -1
  479. package/dist/nile-skeleton-loader/nile-skeleton-loader.cjs.js +1 -1
  480. package/dist/nile-skeleton-loader/nile-skeleton-loader.cjs.js.map +1 -1
  481. package/dist/nile-skeleton-loader/nile-skeleton-loader.esm.js +2 -2
  482. package/dist/nile-slide-toggle/index.cjs.js +1 -1
  483. package/dist/nile-slide-toggle/index.esm.js +1 -1
  484. package/dist/nile-slide-toggle/nile-slide-toggle.cjs.js +1 -1
  485. package/dist/nile-slide-toggle/nile-slide-toggle.cjs.js.map +1 -1
  486. package/dist/nile-slide-toggle/nile-slide-toggle.esm.js +2 -2
  487. package/dist/nile-slider/index.cjs.js +1 -1
  488. package/dist/nile-slider/index.esm.js +1 -1
  489. package/dist/nile-slider/nile-slider.cjs.js +1 -1
  490. package/dist/nile-slider/nile-slider.cjs.js.map +1 -1
  491. package/dist/nile-slider/nile-slider.esm.js +3 -3
  492. package/dist/nile-split-panel/index.cjs.js +1 -1
  493. package/dist/nile-split-panel/index.esm.js +1 -1
  494. package/dist/nile-split-panel/nile-split-panel.cjs.js +1 -1
  495. package/dist/nile-split-panel/nile-split-panel.cjs.js.map +1 -1
  496. package/dist/nile-split-panel/nile-split-panel.esm.js +2 -2
  497. package/dist/nile-stepper/index.cjs.js +1 -1
  498. package/dist/nile-stepper/index.esm.js +1 -1
  499. package/dist/nile-stepper/nile-stepper.cjs.js +1 -1
  500. package/dist/nile-stepper/nile-stepper.cjs.js.map +1 -1
  501. package/dist/nile-stepper/nile-stepper.esm.js +3 -3
  502. package/dist/nile-stepper-item/index.cjs.js +1 -1
  503. package/dist/nile-stepper-item/index.esm.js +1 -1
  504. package/dist/nile-stepper-item/nile-stepper-item.cjs.js +1 -1
  505. package/dist/nile-stepper-item/nile-stepper-item.cjs.js.map +1 -1
  506. package/dist/nile-stepper-item/nile-stepper-item.esm.js +1 -1
  507. package/dist/nile-switcher/index.cjs.js +1 -1
  508. package/dist/nile-switcher/index.esm.js +1 -1
  509. package/dist/nile-switcher/nile-switcher.cjs.js +1 -1
  510. package/dist/nile-switcher/nile-switcher.cjs.js.map +1 -1
  511. package/dist/nile-switcher/nile-switcher.esm.js +23 -23
  512. package/dist/nile-tab/index.cjs.js +1 -1
  513. package/dist/nile-tab/index.esm.js +1 -1
  514. package/dist/nile-tab/nile-tab.cjs.js +1 -1
  515. package/dist/nile-tab/nile-tab.cjs.js.map +1 -1
  516. package/dist/nile-tab/nile-tab.esm.js +1 -1
  517. package/dist/nile-tab-group/index.cjs.js +1 -1
  518. package/dist/nile-tab-group/index.esm.js +1 -1
  519. package/dist/nile-tab-group/nile-tab-group.cjs.js +1 -1
  520. package/dist/nile-tab-group/nile-tab-group.cjs.js.map +1 -1
  521. package/dist/nile-tab-group/nile-tab-group.esm.js +1 -1
  522. package/dist/nile-tab-panel/index.cjs.js +1 -1
  523. package/dist/nile-tab-panel/index.esm.js +1 -1
  524. package/dist/nile-tab-panel/nile-tab-panel.cjs.js +1 -1
  525. package/dist/nile-tab-panel/nile-tab-panel.cjs.js.map +1 -1
  526. package/dist/nile-tab-panel/nile-tab-panel.esm.js +3 -3
  527. package/dist/nile-table/index.cjs.js +1 -1
  528. package/dist/nile-table/index.esm.js +1 -1
  529. package/dist/nile-table/nile-table.cjs.js +1 -1
  530. package/dist/nile-table/nile-table.cjs.js.map +1 -1
  531. package/dist/nile-table/nile-table.esm.js +1 -1
  532. package/dist/nile-table-body/index.cjs.js +1 -1
  533. package/dist/nile-table-body/index.esm.js +1 -1
  534. package/dist/nile-table-body/nile-table-body.cjs.js +1 -1
  535. package/dist/nile-table-body/nile-table-body.cjs.js.map +1 -1
  536. package/dist/nile-table-body/nile-table-body.esm.js +3 -3
  537. package/dist/nile-table-cell-item/index.cjs.js +1 -1
  538. package/dist/nile-table-cell-item/index.esm.js +1 -1
  539. package/dist/nile-table-cell-item/nile-table-cell-item.cjs.js +1 -1
  540. package/dist/nile-table-cell-item/nile-table-cell-item.cjs.js.map +1 -1
  541. package/dist/nile-table-cell-item/nile-table-cell-item.esm.js +5 -5
  542. package/dist/nile-table-header-item/index.cjs.js +1 -1
  543. package/dist/nile-table-header-item/index.esm.js +1 -1
  544. package/dist/nile-table-header-item/nile-table-header-item.cjs.js +1 -1
  545. package/dist/nile-table-header-item/nile-table-header-item.cjs.js.map +1 -1
  546. package/dist/nile-table-header-item/nile-table-header-item.esm.js +1 -1
  547. package/dist/nile-table-row/index.cjs.js +1 -1
  548. package/dist/nile-table-row/index.esm.js +1 -1
  549. package/dist/nile-table-row/nile-table-row.cjs.js +1 -1
  550. package/dist/nile-table-row/nile-table-row.cjs.js.map +1 -1
  551. package/dist/nile-table-row/nile-table-row.esm.js +2 -2
  552. package/dist/nile-tag/index.cjs.js +1 -1
  553. package/dist/nile-tag/index.esm.js +1 -1
  554. package/dist/nile-tag/nile-tag.cjs.js +1 -1
  555. package/dist/nile-tag/nile-tag.cjs.js.map +1 -1
  556. package/dist/nile-tag/nile-tag.esm.js +1 -1
  557. package/dist/nile-textarea/index.cjs.js +1 -1
  558. package/dist/nile-textarea/index.esm.js +1 -1
  559. package/dist/nile-textarea/nile-textarea.cjs.js +1 -1
  560. package/dist/nile-textarea/nile-textarea.cjs.js.map +1 -1
  561. package/dist/nile-textarea/nile-textarea.esm.js +2 -2
  562. package/dist/nile-title/index.cjs.js +1 -1
  563. package/dist/nile-title/index.esm.js +1 -1
  564. package/dist/nile-title/nile-title.cjs.js +1 -1
  565. package/dist/nile-title/nile-title.cjs.js.map +1 -1
  566. package/dist/nile-title/nile-title.esm.js +1 -1
  567. package/dist/nile-toast/index.cjs.js +1 -1
  568. package/dist/nile-toast/index.esm.js +1 -1
  569. package/dist/nile-toast/nile-toast.cjs.js +1 -1
  570. package/dist/nile-toast/nile-toast.cjs.js.map +1 -1
  571. package/dist/nile-toast/nile-toast.esm.js +2 -2
  572. package/dist/nile-toolbar/index.cjs.js +1 -1
  573. package/dist/nile-toolbar/index.esm.js +1 -1
  574. package/dist/nile-toolbar/nile-toolbar.cjs.js +1 -1
  575. package/dist/nile-toolbar/nile-toolbar.cjs.js.map +1 -1
  576. package/dist/nile-toolbar/nile-toolbar.esm.js +2 -2
  577. package/dist/nile-tooltip/index.cjs.js +1 -1
  578. package/dist/nile-tooltip/index.esm.js +1 -1
  579. package/dist/nile-tooltip/nile-tooltip.cjs.js +1 -1
  580. package/dist/nile-tooltip/nile-tooltip.cjs.js.map +1 -1
  581. package/dist/nile-tooltip/nile-tooltip.esm.js +2 -2
  582. package/dist/nile-tree/index.cjs.js +1 -1
  583. package/dist/nile-tree/index.esm.js +1 -1
  584. package/dist/nile-tree/nile-tree.cjs.js +1 -1
  585. package/dist/nile-tree/nile-tree.cjs.js.map +1 -1
  586. package/dist/nile-tree/nile-tree.esm.js +1 -1
  587. package/dist/nile-tree-item/index.cjs.js +1 -1
  588. package/dist/nile-tree-item/index.esm.js +1 -1
  589. package/dist/nile-tree-item/nile-tree-item.cjs.js +1 -1
  590. package/dist/nile-tree-item/nile-tree-item.cjs.js.map +1 -1
  591. package/dist/nile-tree-item/nile-tree-item.esm.js +1 -1
  592. package/dist/nile-vertical-stepper-item/index.cjs.js +1 -1
  593. package/dist/nile-vertical-stepper-item/index.esm.js +1 -1
  594. package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js +1 -1
  595. package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js.map +1 -1
  596. package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.esm.js +7 -7
  597. package/dist/nile-virtual-select/index.cjs.js +1 -1
  598. package/dist/nile-virtual-select/index.esm.js +1 -1
  599. package/dist/nile-virtual-select/nile-virtual-select.cjs.js +3 -3
  600. package/dist/nile-virtual-select/nile-virtual-select.esm.js +3 -3
  601. package/dist/src/index.d.ts +2 -0
  602. package/dist/src/index.js +2 -0
  603. package/dist/src/index.js.map +1 -1
  604. package/dist/src/internal/accessibility/a11y.custom-value.enum.d.ts +69 -0
  605. package/dist/src/internal/accessibility/a11y.custom-value.enum.js +71 -0
  606. package/dist/src/internal/accessibility/a11y.custom-value.enum.js.map +1 -0
  607. package/dist/src/internal/accessibility/a11y.property.enum.d.ts +33 -0
  608. package/dist/src/internal/accessibility/a11y.property.enum.js +35 -0
  609. package/dist/src/internal/accessibility/a11y.property.enum.js.map +1 -0
  610. package/dist/src/internal/accessibility/a11y.role.enum.d.ts +50 -0
  611. package/dist/src/internal/accessibility/a11y.role.enum.js +52 -0
  612. package/dist/src/internal/accessibility/a11y.role.enum.js.map +1 -0
  613. package/dist/src/internal/accessibility/a11y.state.enum.d.ts +17 -0
  614. package/dist/src/internal/accessibility/a11y.state.enum.js +19 -0
  615. package/dist/src/internal/accessibility/a11y.state.enum.js.map +1 -0
  616. package/dist/src/internal/accessibility/accessibility.const.d.ts +8 -0
  617. package/dist/src/internal/accessibility/accessibility.const.js +9 -0
  618. package/dist/src/internal/accessibility/accessibility.const.js.map +1 -0
  619. package/dist/src/internal/accessibility/role.enum.d.ts +3 -0
  620. package/dist/src/internal/accessibility/role.enum.js +5 -0
  621. package/dist/src/internal/accessibility/role.enum.js.map +1 -0
  622. package/dist/src/internal/enum.d.ts +21 -0
  623. package/dist/src/internal/enum.js +23 -1
  624. package/dist/src/internal/enum.js.map +1 -1
  625. package/dist/src/internal/nile-element.d.ts +52 -0
  626. package/dist/src/internal/nile-element.js +45 -0
  627. package/dist/src/internal/nile-element.js.map +1 -1
  628. package/dist/src/nile-avatar/nile-avatar.js +2 -0
  629. package/dist/src/nile-avatar/nile-avatar.js.map +1 -1
  630. package/dist/src/nile-badge/nile-badge.d.ts +1 -0
  631. package/dist/src/nile-badge/nile-badge.js +12 -1
  632. package/dist/src/nile-badge/nile-badge.js.map +1 -1
  633. package/dist/src/nile-checkbox/nile-checkbox.css.js +4 -0
  634. package/dist/src/nile-checkbox/nile-checkbox.css.js.map +1 -1
  635. package/dist/src/nile-checkbox/nile-checkbox.d.ts +2 -0
  636. package/dist/src/nile-checkbox/nile-checkbox.js +5 -0
  637. package/dist/src/nile-checkbox/nile-checkbox.js.map +1 -1
  638. package/dist/src/nile-checkbox-group/index.d.ts +1 -0
  639. package/dist/src/nile-checkbox-group/index.js +2 -0
  640. package/dist/src/nile-checkbox-group/index.js.map +1 -0
  641. package/dist/src/nile-checkbox-group/nile-checkbox-group.css.d.ts +1 -0
  642. package/dist/src/nile-checkbox-group/nile-checkbox-group.css.js +70 -0
  643. package/dist/src/nile-checkbox-group/nile-checkbox-group.css.js.map +1 -0
  644. package/dist/src/nile-checkbox-group/nile-checkbox-group.d.ts +84 -0
  645. package/dist/src/nile-checkbox-group/nile-checkbox-group.js +355 -0
  646. package/dist/src/nile-checkbox-group/nile-checkbox-group.js.map +1 -0
  647. package/dist/src/nile-checkbox-group/nile-checkbox-group.test.d.ts +2 -0
  648. package/dist/src/nile-checkbox-group/nile-checkbox-group.test.js +671 -0
  649. package/dist/src/nile-checkbox-group/nile-checkbox-group.test.js.map +1 -0
  650. package/dist/src/nile-floating-panel/nile-floating-panel.d.ts +2 -0
  651. package/dist/src/nile-floating-panel/nile-floating-panel.js +12 -1
  652. package/dist/src/nile-floating-panel/nile-floating-panel.js.map +1 -1
  653. package/dist/src/nile-icon/icons/svg/folder_delete.d.ts +5 -0
  654. package/dist/src/nile-icon/icons/svg/folder_delete.js +5 -0
  655. package/dist/src/nile-icon/icons/svg/folder_delete.js.map +1 -0
  656. package/dist/src/nile-icon/icons/svg/index.d.ts +1 -0
  657. package/dist/src/nile-icon/icons/svg/index.js +1 -0
  658. package/dist/src/nile-icon/icons/svg/index.js.map +1 -1
  659. package/dist/src/nile-icon/icons/svg/layers-three-02.d.ts +1 -1
  660. package/dist/src/nile-icon/icons/svg/layers-three-02.js +1 -1
  661. package/dist/src/nile-icon/icons/svg/layers-three-02.js.map +1 -1
  662. package/dist/src/nile-link/nile-link.d.ts +2 -1
  663. package/dist/src/nile-link/nile-link.js +18 -1
  664. package/dist/src/nile-link/nile-link.js.map +1 -1
  665. package/dist/src/nile-otp-input/index.d.ts +1 -0
  666. package/dist/src/nile-otp-input/index.js +2 -0
  667. package/dist/src/nile-otp-input/index.js.map +1 -0
  668. package/dist/src/nile-otp-input/nile-otp-input.css.d.ts +12 -0
  669. package/dist/src/nile-otp-input/nile-otp-input.css.js +269 -0
  670. package/dist/src/nile-otp-input/nile-otp-input.css.js.map +1 -0
  671. package/dist/src/nile-otp-input/nile-otp-input.d.ts +156 -0
  672. package/dist/src/nile-otp-input/nile-otp-input.enum.d.ts +26 -0
  673. package/dist/src/nile-otp-input/nile-otp-input.enum.js +32 -0
  674. package/dist/src/nile-otp-input/nile-otp-input.enum.js.map +1 -0
  675. package/dist/src/nile-otp-input/nile-otp-input.js +762 -0
  676. package/dist/src/nile-otp-input/nile-otp-input.js.map +1 -0
  677. package/dist/src/nile-otp-input/nile-otp-input.test.d.ts +1 -0
  678. package/dist/src/nile-otp-input/nile-otp-input.test.js +493 -0
  679. package/dist/src/nile-otp-input/nile-otp-input.test.js.map +1 -0
  680. package/dist/src/nile-pagination/nile-pagination.css.js +7 -0
  681. package/dist/src/nile-pagination/nile-pagination.css.js.map +1 -1
  682. package/dist/src/nile-radio/nile-radio.css.js +4 -0
  683. package/dist/src/nile-radio/nile-radio.css.js.map +1 -1
  684. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.css.js +8 -6
  685. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.css.js.map +1 -1
  686. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.d.ts +2 -0
  687. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.js +43 -0
  688. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.js.map +1 -1
  689. package/dist/src/nile-rich-text-editor/nile-rte-link.test.js +6 -5
  690. package/dist/src/nile-rich-text-editor/nile-rte-link.test.js.map +1 -1
  691. package/dist/src/nile-select/nile-select.css.js +21 -2
  692. package/dist/src/nile-select/nile-select.css.js.map +1 -1
  693. package/dist/src/nile-select/nile-select.d.ts +4 -0
  694. package/dist/src/nile-select/nile-select.js +42 -24
  695. package/dist/src/nile-select/nile-select.js.map +1 -1
  696. package/dist/src/nile-select/portal-utils.d.ts +2 -0
  697. package/dist/src/nile-select/portal-utils.js +36 -3
  698. package/dist/src/nile-select/portal-utils.js.map +1 -1
  699. package/dist/src/version.js +2 -2
  700. package/dist/src/version.js.map +1 -1
  701. package/dist/tsconfig.tsbuildinfo +1 -1
  702. package/package.json +4 -2
  703. package/plop-templates/lit/index.ts.hbs +1 -1
  704. package/plop-templates/lit/lit.css.ts.hbs +1 -1
  705. package/plop-templates/lit/lit.ts.hbs +1 -1
  706. package/src/index.ts +3 -1
  707. package/src/internal/accessibility/a11y.custom-value.enum.ts +69 -0
  708. package/src/internal/accessibility/a11y.property.enum.ts +33 -0
  709. package/src/internal/accessibility/a11y.role.enum.ts +50 -0
  710. package/src/internal/accessibility/a11y.state.enum.ts +17 -0
  711. package/src/internal/accessibility/accessibility.const.ts +9 -0
  712. package/src/internal/accessibility/role.enum.ts +3 -0
  713. package/src/internal/enum.ts +23 -1
  714. package/src/internal/nile-element.ts +99 -0
  715. package/src/nile-avatar/nile-avatar.ts +2 -0
  716. package/src/nile-badge/nile-badge.ts +13 -1
  717. package/src/nile-checkbox/nile-checkbox.css.ts +4 -0
  718. package/src/nile-checkbox/nile-checkbox.ts +3 -0
  719. package/src/nile-checkbox-group/index.ts +1 -0
  720. package/src/nile-checkbox-group/nile-checkbox-group.css.ts +70 -0
  721. package/src/nile-checkbox-group/nile-checkbox-group.test.ts +769 -0
  722. package/src/nile-checkbox-group/nile-checkbox-group.ts +351 -0
  723. package/src/nile-floating-panel/nile-floating-panel.ts +10 -1
  724. package/src/nile-icon/icons/svg/folder_delete.ts +5 -0
  725. package/src/nile-icon/icons/svg/index.ts +1 -0
  726. package/src/nile-icon/icons/svg/layers-three-02.ts +1 -1
  727. package/src/nile-link/nile-link.ts +21 -2
  728. package/src/nile-otp-input/index.ts +1 -0
  729. package/src/nile-otp-input/nile-otp-input.css.ts +271 -0
  730. package/src/nile-otp-input/nile-otp-input.enum.ts +30 -0
  731. package/src/nile-otp-input/nile-otp-input.test.ts +732 -0
  732. package/src/nile-otp-input/nile-otp-input.ts +835 -0
  733. package/src/nile-pagination/nile-pagination.css.ts +7 -0
  734. package/src/nile-radio/nile-radio.css.ts +4 -0
  735. package/src/nile-rich-text-editor/nile-rich-text-editor.css.ts +8 -6
  736. package/src/nile-rich-text-editor/nile-rich-text-editor.ts +43 -0
  737. package/src/nile-rich-text-editor/nile-rte-link.test.ts +6 -5
  738. package/src/nile-select/nile-select.css.ts +21 -2
  739. package/src/nile-select/nile-select.ts +44 -24
  740. package/src/nile-select/portal-utils.ts +46 -3
  741. package/vscode-html-custom-data.json +281 -19
@@ -0,0 +1,732 @@
1
+ import { aTimeout, expect, fixture, html } from '@open-wc/testing';
2
+ import './nile-otp-input';
3
+ import type { NileOtpInput } from './nile-otp-input';
4
+
5
+ const getCells = (el: NileOtpInput) =>
6
+ Array.from(el.shadowRoot!.querySelectorAll<HTMLInputElement>('.otp__cell'));
7
+
8
+ const inputCell = async (el: NileOtpInput, index: number, value: string) => {
9
+ const cell = getCells(el)[index];
10
+ cell.value = value;
11
+ cell.dispatchEvent(new Event('input', { bubbles: true, composed: true }));
12
+ await el.updateComplete;
13
+ return cell;
14
+ };
15
+
16
+ const pressKey = async (
17
+ el: NileOtpInput,
18
+ index: number,
19
+ key: string,
20
+ opts: Partial<KeyboardEventInit> = {}
21
+ ) => {
22
+ const cell = getCells(el)[index];
23
+ cell.dispatchEvent(
24
+ new KeyboardEvent('keydown', {
25
+ key,
26
+ bubbles: true,
27
+ composed: true,
28
+ cancelable: true,
29
+ ...opts,
30
+ })
31
+ );
32
+ await el.updateComplete;
33
+ return cell;
34
+ };
35
+
36
+ const pasteInto = async (el: NileOtpInput, index: number, text: string) => {
37
+ const cell = getCells(el)[index];
38
+ const event = new Event('paste', {
39
+ bubbles: true,
40
+ composed: true,
41
+ cancelable: true,
42
+ }) as ClipboardEvent;
43
+ Object.defineProperty(event, 'clipboardData', {
44
+ value: { getData: () => text },
45
+ });
46
+ cell.dispatchEvent(event);
47
+ await el.updateComplete;
48
+ };
49
+
50
+ describe('NileOtpInput', () => {
51
+ // ---- Rendering ----
52
+
53
+ it('renders default 6 cells', async () => {
54
+ const el = await fixture<NileOtpInput>(
55
+ html`<nile-otp-input></nile-otp-input>`
56
+ );
57
+ expect(el).to.exist;
58
+ expect(getCells(el).length).to.equal(6);
59
+ });
60
+
61
+ it('normalizes incoming value (strips non-numeric in numeric mode)', async () => {
62
+ const el = await fixture<NileOtpInput>(
63
+ html`<nile-otp-input value="12A34B"></nile-otp-input>`
64
+ );
65
+ await el.updateComplete;
66
+ expect(el.value).to.equal('1234');
67
+ expect(getCells(el).map(c => c.value)).to.deep.equal([
68
+ '1', '2', '3', '4', '', '',
69
+ ]);
70
+ });
71
+
72
+ it('supports configurable length and clamps below 4', async () => {
73
+ const el = await fixture<NileOtpInput>(
74
+ html`<nile-otp-input length="8"></nile-otp-input>`
75
+ );
76
+ expect(getCells(el).length).to.equal(8);
77
+
78
+ el.length = 2;
79
+ await el.updateComplete;
80
+ expect(el.length).to.equal(4);
81
+ expect(getCells(el).length).to.equal(4);
82
+ });
83
+
84
+ it('renders label when provided', async () => {
85
+ const el = await fixture<NileOtpInput>(
86
+ html`<nile-otp-input label="Verification code"></nile-otp-input>`
87
+ );
88
+ const label = el.shadowRoot!.querySelector('.form-control__label');
89
+ expect(label).to.exist;
90
+ expect(label!.textContent).to.contain('Verification code');
91
+ });
92
+
93
+ it('renders help text when provided', async () => {
94
+ const el = await fixture<NileOtpInput>(
95
+ html`<nile-otp-input .helpText=${'Enter your code'}></nile-otp-input>`
96
+ );
97
+ const helpText = el.shadowRoot!.querySelector('.form-control__help-text');
98
+ expect(helpText).to.exist;
99
+ expect(helpText!.textContent).to.contain('Enter your code');
100
+ });
101
+
102
+ it('renders error message when provided', async () => {
103
+ const el = await fixture<NileOtpInput>(
104
+ html`<nile-otp-input .errorMessage=${'Invalid code'}></nile-otp-input>`
105
+ );
106
+ const errorMsg = el.shadowRoot!.querySelector('.form-control__error-message');
107
+ expect(errorMsg).to.exist;
108
+ expect(errorMsg!.textContent).to.contain('Invalid code');
109
+ });
110
+
111
+ it('renders separators with separator-every', async () => {
112
+ const el = await fixture<NileOtpInput>(html`
113
+ <nile-otp-input separator="-" .separatorEvery=${3}></nile-otp-input>
114
+ `);
115
+ const separators = el.shadowRoot!.querySelectorAll('.otp__separator');
116
+ expect(separators.length).to.equal(1);
117
+ expect(separators[0].textContent!.trim()).to.equal('-');
118
+ });
119
+
120
+ it('renders separators from separator-positions', async () => {
121
+ const el = await fixture<NileOtpInput>(html`
122
+ <nile-otp-input
123
+ length="8"
124
+ separator="/"
125
+ separator-positions="1, 3, 5"
126
+ ></nile-otp-input>
127
+ `);
128
+ const separators = el.shadowRoot!.querySelectorAll('.otp__separator');
129
+ expect(separators.length).to.equal(3);
130
+ separators.forEach(s =>
131
+ expect(s.textContent!.trim()).to.equal('/')
132
+ );
133
+ });
134
+
135
+ // ---- Input behavior ----
136
+
137
+ it('auto-advances focus to next empty cell after typing', async () => {
138
+ const el = await fixture<NileOtpInput>(
139
+ html`<nile-otp-input></nile-otp-input>`
140
+ );
141
+ const cells = getCells(el);
142
+
143
+ cells[0].focus();
144
+ await inputCell(el, 0, '1');
145
+ await aTimeout(0);
146
+
147
+ expect(el.value).to.equal('1');
148
+ expect(el.shadowRoot!.activeElement).to.equal(cells[1]);
149
+ });
150
+
151
+ it('typing a character on a filled cell replaces it and advances', async () => {
152
+ const el = await fixture<NileOtpInput>(
153
+ html`<nile-otp-input value="123456"></nile-otp-input>`
154
+ );
155
+ await el.updateComplete;
156
+ const cells = getCells(el);
157
+
158
+ cells[2].focus();
159
+ await el.updateComplete;
160
+ await pressKey(el, 2, '9');
161
+ await aTimeout(0);
162
+
163
+ expect(el.value[2]).to.equal('9');
164
+ });
165
+
166
+ it('blocks invalid characters in numeric mode', async () => {
167
+ const el = await fixture<NileOtpInput>(
168
+ html`<nile-otp-input></nile-otp-input>`
169
+ );
170
+ const first = getCells(el)[0];
171
+ first.focus();
172
+
173
+ const event = new KeyboardEvent('keydown', {
174
+ key: 'A',
175
+ bubbles: true,
176
+ composed: true,
177
+ cancelable: true,
178
+ });
179
+ first.dispatchEvent(event);
180
+
181
+ expect(event.defaultPrevented).to.be.true;
182
+ });
183
+
184
+ it('allows alphanumeric values when alphanumeric attribute is set', async () => {
185
+ const el = await fixture<NileOtpInput>(
186
+ html`<nile-otp-input alphanumeric></nile-otp-input>`
187
+ );
188
+ const cells = getCells(el);
189
+ cells[0].focus();
190
+ await el.updateComplete;
191
+
192
+ await pressKey(el, 0, 'A');
193
+ expect(el.value).to.equal('A');
194
+ });
195
+
196
+ it('alphanumeric overrides numeric-only', async () => {
197
+ const el = await fixture<NileOtpInput>(
198
+ html`<nile-otp-input numeric-only alphanumeric></nile-otp-input>`
199
+ );
200
+ const cells = getCells(el);
201
+ cells[0].focus();
202
+ await el.updateComplete;
203
+
204
+ await pressKey(el, 0, 'B');
205
+ expect(el.value).to.equal('B');
206
+ });
207
+
208
+ it('supports controlled value updates', async () => {
209
+ const el = await fixture<NileOtpInput>(
210
+ html`<nile-otp-input></nile-otp-input>`
211
+ );
212
+
213
+ el.value = '2468';
214
+ await el.updateComplete;
215
+
216
+ expect(getCells(el).map(c => c.value)).to.deep.equal([
217
+ '2', '4', '6', '8', '', '',
218
+ ]);
219
+ });
220
+
221
+ // ---- Focus management (ShadCN style) ----
222
+
223
+ it('focus() targets the first empty cell', async () => {
224
+ const el = await fixture<NileOtpInput>(
225
+ html`<nile-otp-input value="12"></nile-otp-input>`
226
+ );
227
+ await el.updateComplete;
228
+ const cells = getCells(el);
229
+
230
+ el.focus();
231
+ await aTimeout(0);
232
+
233
+ expect(el.shadowRoot!.activeElement).to.equal(cells[2]);
234
+ });
235
+
236
+ it('clicking an empty cell beyond the cursor redirects to first empty', async () => {
237
+ const el = await fixture<NileOtpInput>(
238
+ html`<nile-otp-input value="12"></nile-otp-input>`
239
+ );
240
+ await el.updateComplete;
241
+ const cells = getCells(el);
242
+
243
+ cells[5].focus();
244
+ await aTimeout(0);
245
+ await el.updateComplete;
246
+
247
+ expect(el.shadowRoot!.activeElement).to.equal(cells[2]);
248
+ });
249
+
250
+ it('clicking a filled cell focuses it directly', async () => {
251
+ const el = await fixture<NileOtpInput>(
252
+ html`<nile-otp-input value="123"></nile-otp-input>`
253
+ );
254
+ await el.updateComplete;
255
+ const cells = getCells(el);
256
+
257
+ cells[1].focus();
258
+ await aTimeout(0);
259
+ await el.updateComplete;
260
+
261
+ expect(el.shadowRoot!.activeElement).to.equal(cells[1]);
262
+ });
263
+
264
+ // ---- Keyboard navigation ----
265
+
266
+ it('Backspace clears current cell and retreats', async () => {
267
+ const el = await fixture<NileOtpInput>(
268
+ html`<nile-otp-input value="123"></nile-otp-input>`
269
+ );
270
+ await el.updateComplete;
271
+ const cells = getCells(el);
272
+
273
+ cells[2].focus();
274
+ await pressKey(el, 2, 'Backspace');
275
+ await aTimeout(0);
276
+
277
+ expect(el.value).to.equal('12');
278
+ expect(el.shadowRoot!.activeElement).to.equal(cells[1]);
279
+ });
280
+
281
+ it('Backspace on empty cell clears previous and moves there', async () => {
282
+ const el = await fixture<NileOtpInput>(
283
+ html`<nile-otp-input value="12"></nile-otp-input>`
284
+ );
285
+ await el.updateComplete;
286
+ const cells = getCells(el);
287
+
288
+ cells[2].focus();
289
+ await pressKey(el, 2, 'Backspace');
290
+ await aTimeout(0);
291
+
292
+ expect(el.value).to.equal('1');
293
+ expect(cells[1].value).to.equal('');
294
+ expect(el.shadowRoot!.activeElement).to.equal(cells[1]);
295
+ });
296
+
297
+ it('Delete clears current cell without moving', async () => {
298
+ const el = await fixture<NileOtpInput>(
299
+ html`<nile-otp-input value="123"></nile-otp-input>`
300
+ );
301
+ await el.updateComplete;
302
+ const cells = getCells(el);
303
+
304
+ cells[1].focus();
305
+ await pressKey(el, 1, 'Delete');
306
+ await aTimeout(0);
307
+
308
+ expect(el.value).to.equal('13');
309
+ expect(el.shadowRoot!.activeElement).to.equal(cells[1]);
310
+ });
311
+
312
+ it('ArrowLeft moves focus back', async () => {
313
+ const el = await fixture<NileOtpInput>(
314
+ html`<nile-otp-input value="123"></nile-otp-input>`
315
+ );
316
+ await el.updateComplete;
317
+ const cells = getCells(el);
318
+
319
+ cells[2].focus();
320
+ await pressKey(el, 2, 'ArrowLeft');
321
+ await aTimeout(0);
322
+
323
+ expect(el.shadowRoot!.activeElement).to.equal(cells[1]);
324
+ });
325
+
326
+ it('ArrowRight cannot move past the first empty cell', async () => {
327
+ const el = await fixture<NileOtpInput>(
328
+ html`<nile-otp-input value="12"></nile-otp-input>`
329
+ );
330
+ await el.updateComplete;
331
+ const cells = getCells(el);
332
+
333
+ cells[1].focus();
334
+ await pressKey(el, 1, 'ArrowRight');
335
+ await aTimeout(0);
336
+
337
+ expect(el.shadowRoot!.activeElement).to.equal(cells[2]);
338
+
339
+ await pressKey(el, 2, 'ArrowRight');
340
+ await aTimeout(0);
341
+
342
+ expect(el.shadowRoot!.activeElement).to.equal(cells[2]);
343
+ });
344
+
345
+ it('Home goes to first cell', async () => {
346
+ const el = await fixture<NileOtpInput>(
347
+ html`<nile-otp-input value="123"></nile-otp-input>`
348
+ );
349
+ await el.updateComplete;
350
+ const cells = getCells(el);
351
+
352
+ cells[2].focus();
353
+ await pressKey(el, 2, 'Home');
354
+ await aTimeout(0);
355
+
356
+ expect(el.shadowRoot!.activeElement).to.equal(cells[0]);
357
+ });
358
+
359
+ it('End goes to first empty cell', async () => {
360
+ const el = await fixture<NileOtpInput>(
361
+ html`<nile-otp-input value="123"></nile-otp-input>`
362
+ );
363
+ await el.updateComplete;
364
+ const cells = getCells(el);
365
+
366
+ cells[0].focus();
367
+ await pressKey(el, 0, 'End');
368
+ await aTimeout(0);
369
+
370
+ expect(el.shadowRoot!.activeElement).to.equal(cells[3]);
371
+ });
372
+
373
+ it('Space is blocked', async () => {
374
+ const el = await fixture<NileOtpInput>(
375
+ html`<nile-otp-input></nile-otp-input>`
376
+ );
377
+ const cells = getCells(el);
378
+ cells[0].focus();
379
+
380
+ const event = new KeyboardEvent('keydown', {
381
+ key: ' ',
382
+ bubbles: true,
383
+ composed: true,
384
+ cancelable: true,
385
+ });
386
+ cells[0].dispatchEvent(event);
387
+
388
+ expect(event.defaultPrevented).to.be.true;
389
+ });
390
+
391
+ // ---- Paste ----
392
+
393
+ it('paste fills from position 0 and focuses next empty', async () => {
394
+ const el = await fixture<NileOtpInput>(
395
+ html`<nile-otp-input></nile-otp-input>`
396
+ );
397
+
398
+ await pasteInto(el, 3, '987654');
399
+
400
+ expect(el.value).to.equal('987654');
401
+ expect(getCells(el).map(c => c.value).join('')).to.equal('987654');
402
+ });
403
+
404
+ it('paste emits nile-paste event', async () => {
405
+ const el = await fixture<NileOtpInput>(
406
+ html`<nile-otp-input></nile-otp-input>`
407
+ );
408
+ let pasteValue = '';
409
+
410
+ el.addEventListener('nile-paste', (e: Event) => {
411
+ pasteValue = (e as CustomEvent).detail.value;
412
+ });
413
+
414
+ await pasteInto(el, 0, '123456');
415
+
416
+ expect(pasteValue).to.equal('123456');
417
+ });
418
+
419
+ it('paste is ignored when disabled', async () => {
420
+ const el = await fixture<NileOtpInput>(
421
+ html`<nile-otp-input disabled></nile-otp-input>`
422
+ );
423
+
424
+ await pasteInto(el, 0, '123456');
425
+
426
+ expect(el.value).to.equal('');
427
+ });
428
+
429
+ // ---- Visual states ----
430
+
431
+ it('applies warning class', async () => {
432
+ const el = await fixture<NileOtpInput>(
433
+ html`<nile-otp-input warning></nile-otp-input>`
434
+ );
435
+ const base = el.shadowRoot!.querySelector('.otp');
436
+ expect(base!.classList.contains('otp--warning')).to.be.true;
437
+ });
438
+
439
+ it('applies error class', async () => {
440
+ const el = await fixture<NileOtpInput>(
441
+ html`<nile-otp-input error></nile-otp-input>`
442
+ );
443
+ const base = el.shadowRoot!.querySelector('.otp');
444
+ expect(base!.classList.contains('otp--error')).to.be.true;
445
+ });
446
+
447
+ it('applies success class', async () => {
448
+ const el = await fixture<NileOtpInput>(
449
+ html`<nile-otp-input success></nile-otp-input>`
450
+ );
451
+ const base = el.shadowRoot!.querySelector('.otp');
452
+ expect(base!.classList.contains('otp--success')).to.be.true;
453
+ });
454
+
455
+ it('applies disabled class and blocks input', async () => {
456
+ const el = await fixture<NileOtpInput>(
457
+ html`<nile-otp-input disabled></nile-otp-input>`
458
+ );
459
+ const base = el.shadowRoot!.querySelector('.otp');
460
+ expect(base!.classList.contains('otp--disabled')).to.be.true;
461
+
462
+ const first = getCells(el)[0];
463
+ first.value = '9';
464
+ first.dispatchEvent(new Event('input', { bubbles: true, composed: true }));
465
+ await el.updateComplete;
466
+
467
+ expect(el.value).to.equal('');
468
+ expect(first.value).to.equal('');
469
+ });
470
+
471
+ it('applies readonly class and blocks input', async () => {
472
+ const el = await fixture<NileOtpInput>(
473
+ html`<nile-otp-input readonly value="123456"></nile-otp-input>`
474
+ );
475
+ const base = el.shadowRoot!.querySelector('.otp');
476
+ expect(base!.classList.contains('otp--readonly')).to.be.true;
477
+
478
+ const first = getCells(el)[0];
479
+ first.value = '9';
480
+ first.dispatchEvent(new Event('input', { bubbles: true, composed: true }));
481
+ await el.updateComplete;
482
+
483
+ expect(el.value).to.equal('123456');
484
+ });
485
+
486
+ // ---- Masked ----
487
+
488
+ it('masked cells use type="password" for filled non-active cells', async () => {
489
+ const el = await fixture<NileOtpInput>(
490
+ html`<nile-otp-input masked value="12"></nile-otp-input>`
491
+ );
492
+ await el.updateComplete;
493
+ const cells = getCells(el);
494
+
495
+ expect(cells[0].type).to.equal('password');
496
+ expect(cells[1].type).to.equal('password');
497
+ expect(cells[2].type).to.equal('text');
498
+ });
499
+
500
+ it('active masked cell shows text while typing', async () => {
501
+ const el = await fixture<NileOtpInput>(
502
+ html`<nile-otp-input masked value="12"></nile-otp-input>`
503
+ );
504
+ await el.updateComplete;
505
+ const cells = getCells(el);
506
+
507
+ cells[1].focus();
508
+ await el.updateComplete;
509
+
510
+ expect(cells[1].type).to.equal('text');
511
+ expect(cells[0].type).to.equal('password');
512
+ });
513
+
514
+ it('unmasked cells are always type="text"', async () => {
515
+ const el = await fixture<NileOtpInput>(
516
+ html`<nile-otp-input value="12"></nile-otp-input>`
517
+ );
518
+ await el.updateComplete;
519
+ const cells = getCells(el);
520
+
521
+ cells.forEach(c => expect(c.type).to.equal('text'));
522
+ });
523
+
524
+ // ---- Events ----
525
+
526
+ it('emits nile-input and nile-change with value detail', async () => {
527
+ const el = await fixture<NileOtpInput>(
528
+ html`<nile-otp-input></nile-otp-input>`
529
+ );
530
+ let inputDetail: any;
531
+ let changeDetail: any;
532
+
533
+ el.addEventListener('nile-input', (e: Event) => {
534
+ inputDetail = (e as CustomEvent).detail;
535
+ });
536
+ el.addEventListener('nile-change', (e: Event) => {
537
+ changeDetail = (e as CustomEvent).detail;
538
+ });
539
+
540
+ getCells(el)[0].focus();
541
+ await el.updateComplete;
542
+ await pressKey(el, 0, '7');
543
+
544
+ expect(inputDetail.value).to.equal('7');
545
+ expect(inputDetail.complete).to.be.false;
546
+ expect(changeDetail.value).to.equal('7');
547
+ });
548
+
549
+ it('emits nile-complete when all cells are filled', async () => {
550
+ const el = await fixture<NileOtpInput>(
551
+ html`<nile-otp-input length="4" value="123"></nile-otp-input>`
552
+ );
553
+ await el.updateComplete;
554
+ let completedValue = '';
555
+
556
+ el.addEventListener('nile-complete', (e: Event) => {
557
+ completedValue = (e as CustomEvent).detail.value;
558
+ });
559
+
560
+ const cells = getCells(el);
561
+ cells[3].focus();
562
+ await el.updateComplete;
563
+ await pressKey(el, 3, '4');
564
+
565
+ expect(completedValue).to.equal('1234');
566
+ });
567
+
568
+ it('emits nile-focus when entering and nile-blur when leaving', async () => {
569
+ const el = await fixture<NileOtpInput>(
570
+ html`<nile-otp-input></nile-otp-input>`
571
+ );
572
+ let focused = false;
573
+ let blurred = false;
574
+
575
+ el.addEventListener('nile-focus', () => { focused = true; });
576
+ el.addEventListener('nile-blur', () => { blurred = true; });
577
+
578
+ getCells(el)[0].focus();
579
+ await el.updateComplete;
580
+ expect(focused).to.be.true;
581
+
582
+ getCells(el)[0].blur();
583
+ await aTimeout(50);
584
+ expect(blurred).to.be.true;
585
+ });
586
+
587
+ // ---- Public methods ----
588
+
589
+ it('clear() empties all cells', async () => {
590
+ const el = await fixture<NileOtpInput>(
591
+ html`<nile-otp-input value="123456"></nile-otp-input>`
592
+ );
593
+ await el.updateComplete;
594
+
595
+ el.clear();
596
+ await el.updateComplete;
597
+
598
+ expect(el.value).to.equal('');
599
+ getCells(el).forEach(c => expect(c.value).to.equal(''));
600
+ });
601
+
602
+ it('clear() is blocked when disabled', async () => {
603
+ const el = await fixture<NileOtpInput>(
604
+ html`<nile-otp-input disabled value="123456"></nile-otp-input>`
605
+ );
606
+ await el.updateComplete;
607
+
608
+ el.clear();
609
+ await el.updateComplete;
610
+
611
+ expect(el.value).to.equal('123456');
612
+ });
613
+
614
+ it('complete getter returns true when all cells filled', async () => {
615
+ const el = await fixture<NileOtpInput>(
616
+ html`<nile-otp-input value="123456"></nile-otp-input>`
617
+ );
618
+ await el.updateComplete;
619
+ expect(el.complete).to.be.true;
620
+ });
621
+
622
+ it('complete getter returns false when cells are empty', async () => {
623
+ const el = await fixture<NileOtpInput>(
624
+ html`<nile-otp-input value="12"></nile-otp-input>`
625
+ );
626
+ await el.updateComplete;
627
+ expect(el.complete).to.be.false;
628
+ });
629
+
630
+ // ---- Validation ----
631
+
632
+ it('validates required and exact length using checkValidity', async () => {
633
+ const el = await fixture<NileOtpInput>(
634
+ html`<nile-otp-input required></nile-otp-input>`
635
+ );
636
+ el.value = '12';
637
+ await el.updateComplete;
638
+ expect(el.checkValidity()).to.be.false;
639
+
640
+ el.value = '123456';
641
+ await el.updateComplete;
642
+ expect(el.checkValidity()).to.be.true;
643
+ });
644
+
645
+ it('supports custom validity messaging', async () => {
646
+ const el = await fixture<NileOtpInput>(
647
+ html`<nile-otp-input value="123456"></nile-otp-input>`
648
+ );
649
+ el.setCustomValidity('Invalid OTP');
650
+ await el.updateComplete;
651
+
652
+ expect(el.checkValidity()).to.be.false;
653
+ expect(el.validationMessage).to.equal('Invalid OTP');
654
+
655
+ el.setCustomValidity('');
656
+ await el.updateComplete;
657
+ expect(el.checkValidity()).to.be.true;
658
+ });
659
+
660
+ it('validates against custom pattern', async () => {
661
+ const el = await fixture<NileOtpInput>(
662
+ html`<nile-otp-input pattern="[0-9]{6}" value="1234"></nile-otp-input>`
663
+ );
664
+ await el.updateComplete;
665
+ expect(el.checkValidity()).to.be.false;
666
+
667
+ el.value = '123456';
668
+ await el.updateComplete;
669
+ expect(el.checkValidity()).to.be.true;
670
+ });
671
+
672
+ // ---- Form integration ----
673
+
674
+ it('participates in form data submission', async () => {
675
+ const form = await fixture<HTMLFormElement>(html`
676
+ <form id="otp-form">
677
+ <nile-otp-input name="otp" value="321654"></nile-otp-input>
678
+ </form>
679
+ `);
680
+ const data = new FormData(form);
681
+
682
+ expect(data.get('otp')).to.equal('321654');
683
+ });
684
+
685
+ // ---- Placeholder ----
686
+
687
+ it('shows no placeholder by default', async () => {
688
+ const el = await fixture<NileOtpInput>(html`
689
+ <nile-otp-input value="12"></nile-otp-input>
690
+ `);
691
+
692
+ const placeholders = getCells(el).map(c => c.getAttribute('placeholder'));
693
+ expect(placeholders).to.deep.equal([null, null, null, null, null, null]);
694
+ });
695
+
696
+ it('moves custom placeholder to active cell on focus', async () => {
697
+ const el = await fixture<NileOtpInput>(
698
+ html`<nile-otp-input placeholder="0"></nile-otp-input>`
699
+ );
700
+ const cells = getCells(el);
701
+
702
+ cells[0].focus();
703
+ await el.updateComplete;
704
+
705
+ const placeholders = getCells(el).map(c => c.getAttribute('placeholder'));
706
+ expect(placeholders[0]).to.equal('0');
707
+ expect(placeholders.slice(1).every(p => p === null)).to.be.true;
708
+ });
709
+
710
+ // ---- CSS parts ----
711
+
712
+ it('exposes all required CSS parts', async () => {
713
+ const el = await fixture<NileOtpInput>(html`
714
+ <nile-otp-input
715
+ label="Test"
716
+ .helpText=${'Help'}
717
+ .errorMessage=${'Error'}
718
+ separator="-"
719
+ .separatorEvery=${3}
720
+ ></nile-otp-input>
721
+ `);
722
+
723
+ expect(el.shadowRoot!.querySelector('[part="form-control"]')).to.exist;
724
+ expect(el.shadowRoot!.querySelector('[part="form-control-label"]')).to.exist;
725
+ expect(el.shadowRoot!.querySelector('[part="form-control-input"]')).to.exist;
726
+ expect(el.shadowRoot!.querySelector('[part="base"]')).to.exist;
727
+ expect(el.shadowRoot!.querySelector('[part="cell"]')).to.exist;
728
+ expect(el.shadowRoot!.querySelector('[part="separator"]')).to.exist;
729
+ expect(el.shadowRoot!.querySelector('[part="form-control-help-text"]')).to.exist;
730
+ expect(el.shadowRoot!.querySelector('[part="form-control-error-message"]')).to.exist;
731
+ });
732
+ });