@aquera/nile-elements 1.0.4-beta-1.2 → 1.0.4-beta-1.4

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 (595) hide show
  1. package/README.md +6 -0
  2. package/demo/variables.css +1 -0
  3. package/dist/css-tag-bb10c0fa.cjs.js +6 -0
  4. package/dist/css-tag-bb10c0fa.cjs.js.map +1 -0
  5. package/dist/css-tag-dc564feb.esm.js +6 -0
  6. package/dist/{fixture-8edec91c.esm.js → fixture-985bba12.esm.js} +1 -1
  7. package/dist/{fixture-3bfb4490.cjs.js → fixture-d1470b58.cjs.js} +2 -2
  8. package/dist/{fixture-3bfb4490.cjs.js.map → fixture-d1470b58.cjs.js.map} +1 -1
  9. package/dist/index.cjs.js +1 -1
  10. package/dist/index.esm.js +1 -1
  11. package/dist/index.js +797 -316
  12. package/dist/nile-accordion/nile-accordian.test.cjs.js +1 -1
  13. package/dist/nile-accordion/nile-accordian.test.esm.js +1 -1
  14. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js +1 -1
  15. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js.map +1 -1
  16. package/dist/nile-auto-complete/nile-auto-complete.test.esm.js +1 -1
  17. package/dist/nile-avatar/nile-avatar.test.cjs.js +1 -1
  18. package/dist/nile-avatar/nile-avatar.test.cjs.js.map +1 -1
  19. package/dist/nile-avatar/nile-avatar.test.esm.js +1 -1
  20. package/dist/nile-badge/index.cjs.js +1 -1
  21. package/dist/nile-badge/index.esm.js +1 -1
  22. package/dist/nile-badge/nile-badge.cjs.js +1 -1
  23. package/dist/nile-badge/nile-badge.cjs.js.map +1 -1
  24. package/dist/nile-badge/nile-badge.esm.js +1 -1
  25. package/dist/nile-badge/nile-badge.test.cjs.js +1 -1
  26. package/dist/nile-badge/nile-badge.test.cjs.js.map +1 -1
  27. package/dist/nile-badge/nile-badge.test.esm.js +1 -1
  28. package/dist/nile-button/index.cjs.js +1 -1
  29. package/dist/nile-button/index.esm.js +1 -1
  30. package/dist/nile-button/nile-button.cjs.js +1 -1
  31. package/dist/nile-button/nile-button.cjs.js.map +1 -1
  32. package/dist/nile-button/nile-button.esm.js +2 -2
  33. package/dist/nile-button/nile-button.test.cjs.js +1 -1
  34. package/dist/nile-button/nile-button.test.cjs.js.map +1 -1
  35. package/dist/nile-button/nile-button.test.esm.js +1 -1
  36. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.cjs.js +1 -1
  37. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.esm.js +1 -1
  38. package/dist/nile-calendar/nile-calendar.test.cjs.js +1 -1
  39. package/dist/nile-calendar/nile-calendar.test.cjs.js.map +1 -1
  40. package/dist/nile-calendar/nile-calendar.test.esm.js +1 -1
  41. package/dist/nile-card/nile-card.test.cjs.js +1 -1
  42. package/dist/nile-card/nile-card.test.esm.js +1 -1
  43. package/dist/nile-checkbox/nile-checkbox.css.cjs.js +1 -1
  44. package/dist/nile-checkbox/nile-checkbox.css.cjs.js.map +1 -1
  45. package/dist/nile-checkbox/nile-checkbox.css.esm.js +1 -1
  46. package/dist/nile-checkbox/nile-checkbox.test.cjs.js +1 -1
  47. package/dist/nile-checkbox/nile-checkbox.test.esm.js +1 -1
  48. package/dist/nile-chip/nile-chip.test.cjs.js +1 -1
  49. package/dist/nile-chip/nile-chip.test.cjs.js.map +1 -1
  50. package/dist/nile-chip/nile-chip.test.esm.js +1 -1
  51. package/dist/nile-dialog/index.cjs.js +1 -1
  52. package/dist/nile-dialog/index.esm.js +1 -1
  53. package/dist/nile-dialog/nile-dialog.cjs.js +1 -1
  54. package/dist/nile-dialog/nile-dialog.cjs.js.map +1 -1
  55. package/dist/nile-dialog/nile-dialog.esm.js +6 -6
  56. package/dist/nile-dialog/nile-dialog.test.cjs.js +1 -1
  57. package/dist/nile-dialog/nile-dialog.test.cjs.js.map +1 -1
  58. package/dist/nile-dialog/nile-dialog.test.esm.js +1 -1
  59. package/dist/nile-drawer/index.cjs.js +1 -1
  60. package/dist/nile-drawer/index.esm.js +1 -1
  61. package/dist/nile-drawer/nile-drawer.cjs.js +1 -1
  62. package/dist/nile-drawer/nile-drawer.cjs.js.map +1 -1
  63. package/dist/nile-drawer/nile-drawer.esm.js +1 -1
  64. package/dist/nile-drawer/nile-drawer.test.cjs.js +1 -1
  65. package/dist/nile-drawer/nile-drawer.test.cjs.js.map +1 -1
  66. package/dist/nile-drawer/nile-drawer.test.esm.js +1 -1
  67. package/dist/nile-dropdown/nile-dropdown.test.cjs.js +1 -1
  68. package/dist/nile-dropdown/nile-dropdown.test.esm.js +1 -1
  69. package/dist/nile-empty-state/nile-empty-state.test.cjs.js +1 -1
  70. package/dist/nile-empty-state/nile-empty-state.test.esm.js +1 -1
  71. package/dist/nile-error-message/nile-error-message.test.cjs.js +1 -1
  72. package/dist/nile-error-message/nile-error-message.test.esm.js +1 -1
  73. package/dist/nile-file-preview/nile-file-preview.test.cjs.js +1 -1
  74. package/dist/nile-file-preview/nile-file-preview.test.esm.js +1 -1
  75. package/dist/nile-file-upload/index.cjs.js +1 -1
  76. package/dist/nile-file-upload/nile-file-upload.cjs.js +1 -1
  77. package/dist/nile-file-upload/nile-file-upload.template.cjs.js +1 -1
  78. package/dist/nile-file-upload/nile-file-upload.test.cjs.js +1 -1
  79. package/dist/nile-file-upload/nile-file-upload.test.esm.js +1 -1
  80. package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js +1 -1
  81. package/dist/nile-filter-chip/nile-filter-chip.test.esm.js +1 -1
  82. package/dist/nile-form-group/nile-form-group.test.cjs.js +1 -1
  83. package/dist/nile-form-group/nile-form-group.test.esm.js +1 -1
  84. package/dist/nile-form-help-text/nile-form-help-text.test.cjs.js +1 -1
  85. package/dist/nile-form-help-text/nile-form-help-text.test.esm.js +1 -1
  86. package/dist/nile-grid/index.cjs.js +2 -0
  87. package/dist/nile-grid/index.cjs.js.map +1 -0
  88. package/dist/nile-grid/index.esm.js +1 -0
  89. package/dist/nile-grid/nile-grid.cjs.js +2 -0
  90. package/dist/nile-grid/nile-grid.cjs.js.map +1 -0
  91. package/dist/nile-grid/nile-grid.css.cjs.js +2 -0
  92. package/dist/nile-grid/nile-grid.css.cjs.js.map +1 -0
  93. package/dist/nile-grid/nile-grid.css.esm.js +32 -0
  94. package/dist/nile-grid/nile-grid.esm.js +7 -0
  95. package/dist/nile-grid/nile-grid.utils.cjs.js +2 -0
  96. package/dist/nile-grid/nile-grid.utils.cjs.js.map +1 -0
  97. package/dist/nile-grid/nile-grid.utils.esm.js +1 -0
  98. package/dist/nile-grid-body/index.cjs.js +2 -0
  99. package/dist/nile-grid-body/index.cjs.js.map +1 -0
  100. package/dist/nile-grid-body/index.esm.js +1 -0
  101. package/dist/nile-grid-body/nile-grid-body.cjs.js +2 -0
  102. package/dist/nile-grid-body/nile-grid-body.cjs.js.map +1 -0
  103. package/dist/nile-grid-body/nile-grid-body.css.cjs.js +2 -0
  104. package/dist/nile-grid-body/nile-grid-body.css.cjs.js.map +1 -0
  105. package/dist/nile-grid-body/nile-grid-body.css.esm.js +10 -0
  106. package/dist/nile-grid-body/nile-grid-body.esm.js +5 -0
  107. package/dist/nile-grid-cell-item/index.cjs.js +2 -0
  108. package/dist/nile-grid-cell-item/index.cjs.js.map +1 -0
  109. package/dist/nile-grid-cell-item/index.esm.js +1 -0
  110. package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js +2 -0
  111. package/dist/nile-grid-cell-item/nile-grid-cell-item.cjs.js.map +1 -0
  112. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js +2 -0
  113. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.cjs.js.map +1 -0
  114. package/dist/nile-grid-cell-item/nile-grid-cell-item.css.esm.js +35 -0
  115. package/dist/nile-grid-cell-item/nile-grid-cell-item.esm.js +12 -0
  116. package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.cjs.js +2 -0
  117. package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.cjs.js.map +1 -0
  118. package/dist/nile-grid-cell-item/nile-grid-cell-item.utils.esm.js +1 -0
  119. package/dist/nile-grid-head/index.cjs.js +2 -0
  120. package/dist/nile-grid-head/index.cjs.js.map +1 -0
  121. package/dist/nile-grid-head/index.esm.js +1 -0
  122. package/dist/nile-grid-head/nile-grid-head.cjs.js +2 -0
  123. package/dist/nile-grid-head/nile-grid-head.cjs.js.map +1 -0
  124. package/dist/nile-grid-head/nile-grid-head.css.cjs.js +2 -0
  125. package/dist/nile-grid-head/nile-grid-head.css.cjs.js.map +1 -0
  126. package/dist/nile-grid-head/nile-grid-head.css.esm.js +7 -0
  127. package/dist/nile-grid-head/nile-grid-head.esm.js +5 -0
  128. package/dist/nile-grid-head-item/index.cjs.js +2 -0
  129. package/dist/nile-grid-head-item/index.cjs.js.map +1 -0
  130. package/dist/nile-grid-head-item/index.esm.js +1 -0
  131. package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js +2 -0
  132. package/dist/nile-grid-head-item/nile-grid-head-item.cjs.js.map +1 -0
  133. package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js +2 -0
  134. package/dist/nile-grid-head-item/nile-grid-head-item.css.cjs.js.map +1 -0
  135. package/dist/nile-grid-head-item/nile-grid-head-item.css.esm.js +34 -0
  136. package/dist/nile-grid-head-item/nile-grid-head-item.esm.js +12 -0
  137. package/dist/nile-grid-head-item/nile-grid-head-item.utils.cjs.js +2 -0
  138. package/dist/nile-grid-head-item/nile-grid-head-item.utils.cjs.js.map +1 -0
  139. package/dist/nile-grid-head-item/nile-grid-head-item.utils.esm.js +1 -0
  140. package/dist/nile-grid-row/index.cjs.js +2 -0
  141. package/dist/nile-grid-row/index.cjs.js.map +1 -0
  142. package/dist/nile-grid-row/index.esm.js +1 -0
  143. package/dist/nile-grid-row/nile-grid-row.cjs.js +2 -0
  144. package/dist/nile-grid-row/nile-grid-row.cjs.js.map +1 -0
  145. package/dist/nile-grid-row/nile-grid-row.css.cjs.js +2 -0
  146. package/dist/nile-grid-row/nile-grid-row.css.cjs.js.map +1 -0
  147. package/dist/nile-grid-row/nile-grid-row.css.esm.js +15 -0
  148. package/dist/nile-grid-row/nile-grid-row.esm.js +7 -0
  149. package/dist/nile-hero/nile-hero.test.cjs.js +1 -1
  150. package/dist/nile-hero/nile-hero.test.esm.js +1 -1
  151. package/dist/nile-icon/icons/svg/format_align_justify.cjs.js +2 -0
  152. package/dist/nile-icon/icons/svg/format_align_justify.cjs.js.map +1 -0
  153. package/dist/nile-icon/icons/svg/format_align_justify.esm.js +1 -0
  154. package/dist/nile-icon/icons/svg/format_align_left.cjs.js +2 -0
  155. package/dist/nile-icon/icons/svg/format_align_left.cjs.js.map +1 -0
  156. package/dist/nile-icon/icons/svg/format_align_left.esm.js +1 -0
  157. package/dist/nile-icon/icons/svg/format_align_middle.cjs.js +2 -0
  158. package/dist/nile-icon/icons/svg/format_align_middle.cjs.js.map +1 -0
  159. package/dist/nile-icon/icons/svg/format_align_middle.esm.js +1 -0
  160. package/dist/nile-icon/icons/svg/format_align_right.cjs.js +2 -0
  161. package/dist/nile-icon/icons/svg/format_align_right.cjs.js.map +1 -0
  162. package/dist/nile-icon/icons/svg/format_align_right.esm.js +1 -0
  163. package/dist/nile-icon/icons/svg/format_bold.cjs.js +2 -0
  164. package/dist/nile-icon/icons/svg/format_bold.cjs.js.map +1 -0
  165. package/dist/nile-icon/icons/svg/format_bold.esm.js +1 -0
  166. package/dist/nile-icon/icons/svg/format_clear.cjs.js +2 -0
  167. package/dist/nile-icon/icons/svg/format_clear.cjs.js.map +1 -0
  168. package/dist/nile-icon/icons/svg/format_clear.esm.js +1 -0
  169. package/dist/nile-icon/icons/svg/format_italic.cjs.js +2 -0
  170. package/dist/nile-icon/icons/svg/format_italic.cjs.js.map +1 -0
  171. package/dist/nile-icon/icons/svg/format_italic.esm.js +1 -0
  172. package/dist/nile-icon/icons/svg/format_list_bulleted.cjs.js +2 -0
  173. package/dist/nile-icon/icons/svg/format_list_bulleted.cjs.js.map +1 -0
  174. package/dist/nile-icon/icons/svg/format_list_bulleted.esm.js +1 -0
  175. package/dist/nile-icon/icons/svg/format_list_numbered.cjs.js +2 -0
  176. package/dist/nile-icon/icons/svg/format_list_numbered.cjs.js.map +1 -0
  177. package/dist/nile-icon/icons/svg/format_list_numbered.esm.js +1 -0
  178. package/dist/nile-icon/icons/svg/format_underline.cjs.js +2 -0
  179. package/dist/nile-icon/icons/svg/format_underline.cjs.js.map +1 -0
  180. package/dist/nile-icon/icons/svg/format_underline.esm.js +1 -0
  181. package/dist/nile-icon/icons/svg/image_2.cjs.js +2 -0
  182. package/dist/nile-icon/icons/svg/image_2.cjs.js.map +1 -0
  183. package/dist/nile-icon/icons/svg/image_2.esm.js +1 -0
  184. package/dist/nile-icon/icons/svg/index.cjs.js +1 -1
  185. package/dist/nile-icon/icons/svg/index.esm.js +1 -1
  186. package/dist/nile-icon/icons/svg/link_2.cjs.js +2 -0
  187. package/dist/nile-icon/icons/svg/link_2.cjs.js.map +1 -0
  188. package/dist/nile-icon/icons/svg/link_2.esm.js +1 -0
  189. package/dist/nile-icon/index.cjs.js +1 -1
  190. package/dist/nile-icon/index.cjs.js.map +1 -1
  191. package/dist/nile-icon/index.esm.js +1 -1
  192. package/dist/nile-icon/nile-icon.test.cjs.js +1 -1
  193. package/dist/nile-icon/nile-icon.test.cjs.js.map +1 -1
  194. package/dist/nile-icon/nile-icon.test.esm.js +1 -1
  195. package/dist/nile-icon-button/index.cjs.js +1 -1
  196. package/dist/nile-icon-button/index.esm.js +1 -1
  197. package/dist/nile-icon-button/nile-icon-button.cjs.js +1 -1
  198. package/dist/nile-icon-button/nile-icon-button.cjs.js.map +1 -1
  199. package/dist/nile-icon-button/nile-icon-button.esm.js +1 -1
  200. package/dist/nile-input/index.cjs.js +1 -1
  201. package/dist/nile-input/index.esm.js +1 -1
  202. package/dist/nile-input/nile-input.cjs.js +1 -1
  203. package/dist/nile-input/nile-input.cjs.js.map +1 -1
  204. package/dist/nile-input/nile-input.esm.js +5 -5
  205. package/dist/nile-input/nile-input.test.cjs.js +1 -1
  206. package/dist/nile-input/nile-input.test.cjs.js.map +1 -1
  207. package/dist/nile-input/nile-input.test.esm.js +1 -1
  208. package/dist/nile-link/nile-link.css.cjs.js +1 -1
  209. package/dist/nile-link/nile-link.css.cjs.js.map +1 -1
  210. package/dist/nile-link/nile-link.css.esm.js +3 -2
  211. package/dist/nile-link/nile-link.test.cjs.js +1 -1
  212. package/dist/nile-link/nile-link.test.esm.js +1 -1
  213. package/dist/nile-loader/nile-loader.test.cjs.js +1 -1
  214. package/dist/nile-loader/nile-loader.test.esm.js +1 -1
  215. package/dist/nile-menu-item/index.cjs.js +1 -1
  216. package/dist/nile-menu-item/index.esm.js +1 -1
  217. package/dist/nile-menu-item/nile-menu-item.cjs.js +1 -1
  218. package/dist/nile-menu-item/nile-menu-item.cjs.js.map +1 -1
  219. package/dist/nile-menu-item/nile-menu-item.esm.js +2 -2
  220. package/dist/nile-option/index.cjs.js +1 -1
  221. package/dist/nile-option/index.esm.js +1 -1
  222. package/dist/nile-option/nile-option.cjs.js +1 -1
  223. package/dist/nile-option/nile-option.cjs.js.map +1 -1
  224. package/dist/nile-option/nile-option.esm.js +1 -1
  225. package/dist/nile-popover/index.cjs.js +1 -1
  226. package/dist/nile-popover/index.esm.js +1 -1
  227. package/dist/nile-popover/nile-popover.cjs.js +4 -4
  228. package/dist/nile-popover/nile-popover.cjs.js.map +1 -1
  229. package/dist/nile-popover/nile-popover.esm.js +6 -11
  230. package/dist/nile-popover/nile-popover.test.cjs.js +1 -1
  231. package/dist/nile-popover/nile-popover.test.cjs.js.map +1 -1
  232. package/dist/nile-popover/nile-popover.test.esm.js +5 -5
  233. package/dist/nile-popup/nile-popup.test.cjs.js +1 -1
  234. package/dist/nile-popup/nile-popup.test.esm.js +1 -1
  235. package/dist/nile-progress-bar/nile-progress-bar.test.cjs.js +1 -1
  236. package/dist/nile-progress-bar/nile-progress-bar.test.esm.js +1 -1
  237. package/dist/nile-radio/nile-radio.test.cjs.js +1 -1
  238. package/dist/nile-radio/nile-radio.test.esm.js +1 -1
  239. package/dist/nile-radio-group/nile-radio-group.test.cjs.js +1 -1
  240. package/dist/nile-radio-group/nile-radio-group.test.esm.js +1 -1
  241. package/dist/nile-rich-text-editor/index.cjs.js +2 -0
  242. package/dist/nile-rich-text-editor/index.cjs.js.map +1 -0
  243. package/dist/nile-rich-text-editor/index.esm.js +1 -0
  244. package/dist/nile-rich-text-editor/nile-rich-text-editor.cjs.js +2 -0
  245. package/dist/nile-rich-text-editor/nile-rich-text-editor.cjs.js.map +1 -0
  246. package/dist/nile-rich-text-editor/nile-rich-text-editor.css.cjs.js +2 -0
  247. package/dist/nile-rich-text-editor/nile-rich-text-editor.css.cjs.js.map +1 -0
  248. package/dist/nile-rich-text-editor/nile-rich-text-editor.css.esm.js +149 -0
  249. package/dist/nile-rich-text-editor/nile-rich-text-editor.esm.js +1 -0
  250. package/dist/nile-rich-text-editor/nile-rte-color.cjs.js +2 -0
  251. package/dist/nile-rich-text-editor/nile-rte-color.cjs.js.map +1 -0
  252. package/dist/nile-rich-text-editor/nile-rte-color.esm.js +53 -0
  253. package/dist/nile-rich-text-editor/nile-rte-divider.cjs.js +2 -0
  254. package/dist/nile-rich-text-editor/nile-rte-divider.cjs.js.map +1 -0
  255. package/dist/nile-rich-text-editor/nile-rte-divider.esm.js +1 -0
  256. package/dist/nile-rich-text-editor/nile-rte-link.cjs.js +2 -0
  257. package/dist/nile-rich-text-editor/nile-rte-link.cjs.js.map +1 -0
  258. package/dist/nile-rich-text-editor/nile-rte-link.esm.js +19 -0
  259. package/dist/nile-rich-text-editor/nile-rte-mentions-item.cjs.js +2 -0
  260. package/dist/nile-rich-text-editor/nile-rte-mentions-item.cjs.js.map +1 -0
  261. package/dist/nile-rich-text-editor/nile-rte-mentions-item.esm.js +1 -0
  262. package/dist/nile-rich-text-editor/nile-rte-mentions.cjs.js +3 -0
  263. package/dist/nile-rich-text-editor/nile-rte-mentions.cjs.js.map +1 -0
  264. package/dist/nile-rich-text-editor/nile-rte-mentions.esm.js +1 -0
  265. package/dist/nile-rich-text-editor/nile-rte-preview.cjs.js +2 -0
  266. package/dist/nile-rich-text-editor/nile-rte-preview.cjs.js.map +1 -0
  267. package/dist/nile-rich-text-editor/nile-rte-preview.esm.js +1 -0
  268. package/dist/nile-rich-text-editor/nile-rte-select.cjs.js +2 -0
  269. package/dist/nile-rich-text-editor/nile-rte-select.cjs.js.map +1 -0
  270. package/dist/nile-rich-text-editor/nile-rte-select.esm.js +66 -0
  271. package/dist/nile-rich-text-editor/nile-rte-toolbar-item.cjs.js +2 -0
  272. package/dist/nile-rich-text-editor/nile-rte-toolbar-item.cjs.js.map +1 -0
  273. package/dist/nile-rich-text-editor/nile-rte-toolbar-item.esm.js +1 -0
  274. package/dist/nile-rich-text-editor/nile-rte-toolbar.cjs.js +2 -0
  275. package/dist/nile-rich-text-editor/nile-rte-toolbar.cjs.js.map +1 -0
  276. package/dist/nile-rich-text-editor/nile-rte-toolbar.esm.js +1 -0
  277. package/dist/nile-rich-text-editor/utils.cjs.js +2 -0
  278. package/dist/nile-rich-text-editor/utils.cjs.js.map +1 -0
  279. package/dist/nile-rich-text-editor/utils.esm.js +1 -0
  280. package/dist/nile-select/index.cjs.js +1 -1
  281. package/dist/nile-select/index.esm.js +1 -1
  282. package/dist/nile-select/nile-select.cjs.js +1 -1
  283. package/dist/nile-select/nile-select.cjs.js.map +1 -1
  284. package/dist/nile-select/nile-select.css.cjs.js +1 -1
  285. package/dist/nile-select/nile-select.css.cjs.js.map +1 -1
  286. package/dist/nile-select/nile-select.css.esm.js +1 -1
  287. package/dist/nile-select/nile-select.esm.js +2 -2
  288. package/dist/nile-select/nile-select.test.cjs.js +1 -1
  289. package/dist/nile-select/nile-select.test.cjs.js.map +1 -1
  290. package/dist/nile-select/nile-select.test.esm.js +12 -12
  291. package/dist/nile-select/virtual-scroll-helper.cjs.js +1 -1
  292. package/dist/nile-select/virtual-scroll-helper.cjs.js.map +1 -1
  293. package/dist/nile-select/virtual-scroll-helper.esm.js +2 -0
  294. package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js +1 -1
  295. package/dist/nile-slide-toggle/nile-slide-toggle.test.esm.js +1 -1
  296. package/dist/nile-stepper-item/nile-stepper-item.cjs.js +1 -1
  297. package/dist/nile-stepper-item/nile-stepper-item.cjs.js.map +1 -1
  298. package/dist/nile-stepper-item/nile-stepper-item.esm.js +6 -6
  299. package/dist/nile-tab/index.cjs.js +1 -1
  300. package/dist/nile-tab/index.esm.js +1 -1
  301. package/dist/nile-tab/nile-tab.cjs.js +1 -1
  302. package/dist/nile-tab/nile-tab.cjs.js.map +1 -1
  303. package/dist/nile-tab/nile-tab.esm.js +2 -2
  304. package/dist/nile-tab-group/index.cjs.js +1 -1
  305. package/dist/nile-tab-group/index.esm.js +1 -1
  306. package/dist/nile-tab-group/nile-tab-group.cjs.js +1 -1
  307. package/dist/nile-tab-group/nile-tab-group.cjs.js.map +1 -1
  308. package/dist/nile-tab-group/nile-tab-group.esm.js +1 -1
  309. package/dist/nile-tab-group/nile-tab-group.test.cjs.js +1 -1
  310. package/dist/nile-tab-group/nile-tab-group.test.cjs.js.map +1 -1
  311. package/dist/nile-tab-group/nile-tab-group.test.esm.js +1 -1
  312. package/dist/nile-tag/index.cjs.js +1 -1
  313. package/dist/nile-tag/index.esm.js +1 -1
  314. package/dist/nile-tag/nile-tag.cjs.js +1 -1
  315. package/dist/nile-tag/nile-tag.cjs.js.map +1 -1
  316. package/dist/nile-tag/nile-tag.esm.js +1 -1
  317. package/dist/nile-textarea/nile-textarea.test.cjs.js +1 -1
  318. package/dist/nile-textarea/nile-textarea.test.esm.js +1 -1
  319. package/dist/nile-toast/index.cjs.js +1 -1
  320. package/dist/nile-toast/index.esm.js +1 -1
  321. package/dist/nile-toast/nile-toast.cjs.js +1 -1
  322. package/dist/nile-toast/nile-toast.cjs.js.map +1 -1
  323. package/dist/nile-toast/nile-toast.esm.js +2 -2
  324. package/dist/nile-tree/index.cjs.js +1 -1
  325. package/dist/nile-tree/index.esm.js +1 -1
  326. package/dist/nile-tree/nile-tree.cjs.js +1 -1
  327. package/dist/nile-tree/nile-tree.cjs.js.map +1 -1
  328. package/dist/nile-tree/nile-tree.esm.js +1 -1
  329. package/dist/nile-tree-item/index.cjs.js +1 -1
  330. package/dist/nile-tree-item/index.esm.js +1 -1
  331. package/dist/nile-tree-item/nile-tree-item.cjs.js +1 -1
  332. package/dist/nile-tree-item/nile-tree-item.cjs.js.map +1 -1
  333. package/dist/nile-tree-item/nile-tree-item.esm.js +3 -3
  334. package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js +1 -1
  335. package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js.map +1 -1
  336. package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.esm.js +8 -8
  337. package/dist/nile-virtual-select/index.cjs.js +1 -1
  338. package/dist/nile-virtual-select/index.esm.js +1 -1
  339. package/dist/nile-virtual-select/nile-virtual-select.cjs.js +5 -1
  340. package/dist/nile-virtual-select/nile-virtual-select.cjs.js.map +1 -1
  341. package/dist/nile-virtual-select/nile-virtual-select.css.cjs.js +1 -1
  342. package/dist/nile-virtual-select/nile-virtual-select.css.cjs.js.map +1 -1
  343. package/dist/nile-virtual-select/nile-virtual-select.css.esm.js +29 -1
  344. package/dist/nile-virtual-select/nile-virtual-select.esm.js +21 -13
  345. package/dist/nile-virtual-select/nile-virtual-select.test.cjs.js +1 -1
  346. package/dist/nile-virtual-select/nile-virtual-select.test.esm.js +1 -1
  347. package/dist/nile-virtual-select/renderer.cjs.js +1 -1
  348. package/dist/nile-virtual-select/renderer.cjs.js.map +1 -1
  349. package/dist/nile-virtual-select/renderer.esm.js +11 -10
  350. package/dist/nile-virtual-select/selection-manager.cjs.js +1 -1
  351. package/dist/nile-virtual-select/selection-manager.cjs.js.map +1 -1
  352. package/dist/nile-virtual-select/selection-manager.esm.js +1 -1
  353. package/dist/scopedElementsWrapper-31107e48.esm.js +1 -0
  354. package/dist/scopedElementsWrapper-c815042c.cjs.js +2 -0
  355. package/dist/scopedElementsWrapper-c815042c.cjs.js.map +1 -0
  356. package/dist/src/index.d.ts +7 -0
  357. package/dist/src/index.js +7 -0
  358. package/dist/src/index.js.map +1 -1
  359. package/dist/src/nile-button/nile-button.d.ts +1 -1
  360. package/dist/src/nile-button/nile-button.js +1 -1
  361. package/dist/src/nile-button/nile-button.js.map +1 -1
  362. package/dist/src/nile-checkbox/nile-checkbox.css.js +1 -1
  363. package/dist/src/nile-checkbox/nile-checkbox.css.js.map +1 -1
  364. package/dist/src/nile-grid/index.d.ts +1 -0
  365. package/dist/src/nile-grid/index.js +2 -0
  366. package/dist/src/nile-grid/index.js.map +1 -0
  367. package/dist/src/nile-grid/nile-grid.css.d.ts +9 -0
  368. package/dist/src/nile-grid/nile-grid.css.js +41 -0
  369. package/dist/src/nile-grid/nile-grid.css.js.map +1 -0
  370. package/dist/src/nile-grid/nile-grid.d.ts +50 -0
  371. package/dist/src/nile-grid/nile-grid.js +130 -0
  372. package/dist/src/nile-grid/nile-grid.js.map +1 -0
  373. package/dist/src/nile-grid/nile-grid.utils.d.ts +9 -0
  374. package/dist/src/nile-grid/nile-grid.utils.js +170 -0
  375. package/dist/src/nile-grid/nile-grid.utils.js.map +1 -0
  376. package/dist/src/nile-grid-body/index.d.ts +1 -0
  377. package/dist/src/nile-grid-body/index.js +2 -0
  378. package/dist/src/nile-grid-body/index.js.map +1 -0
  379. package/dist/src/nile-grid-body/nile-grid-body.css.d.ts +12 -0
  380. package/dist/src/nile-grid-body/nile-grid-body.css.js +22 -0
  381. package/dist/src/nile-grid-body/nile-grid-body.css.js.map +1 -0
  382. package/dist/src/nile-grid-body/nile-grid-body.d.ts +29 -0
  383. package/dist/src/nile-grid-body/nile-grid-body.js +43 -0
  384. package/dist/src/nile-grid-body/nile-grid-body.js.map +1 -0
  385. package/dist/src/nile-grid-cell-item/index.d.ts +1 -0
  386. package/dist/src/nile-grid-cell-item/index.js +2 -0
  387. package/dist/src/nile-grid-cell-item/index.js.map +1 -0
  388. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.d.ts +12 -0
  389. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js +47 -0
  390. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.css.js.map +1 -0
  391. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.d.ts +36 -0
  392. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js +93 -0
  393. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.js.map +1 -0
  394. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.d.ts +10 -0
  395. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.js +34 -0
  396. package/dist/src/nile-grid-cell-item/nile-grid-cell-item.utils.js.map +1 -0
  397. package/dist/src/nile-grid-head/index.d.ts +1 -0
  398. package/dist/src/nile-grid-head/index.js +2 -0
  399. package/dist/src/nile-grid-head/index.js.map +1 -0
  400. package/dist/src/nile-grid-head/nile-grid-head.css.d.ts +12 -0
  401. package/dist/src/nile-grid-head/nile-grid-head.css.js +19 -0
  402. package/dist/src/nile-grid-head/nile-grid-head.css.js.map +1 -0
  403. package/dist/src/nile-grid-head/nile-grid-head.d.ts +28 -0
  404. package/dist/src/nile-grid-head/nile-grid-head.js +41 -0
  405. package/dist/src/nile-grid-head/nile-grid-head.js.map +1 -0
  406. package/dist/src/nile-grid-head-item/index.d.ts +1 -0
  407. package/dist/src/nile-grid-head-item/index.js +2 -0
  408. package/dist/src/nile-grid-head-item/index.js.map +1 -0
  409. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.d.ts +12 -0
  410. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js +46 -0
  411. package/dist/src/nile-grid-head-item/nile-grid-head-item.css.js.map +1 -0
  412. package/dist/src/nile-grid-head-item/nile-grid-head-item.d.ts +37 -0
  413. package/dist/src/nile-grid-head-item/nile-grid-head-item.js +100 -0
  414. package/dist/src/nile-grid-head-item/nile-grid-head-item.js.map +1 -0
  415. package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.d.ts +10 -0
  416. package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.js +34 -0
  417. package/dist/src/nile-grid-head-item/nile-grid-head-item.utils.js.map +1 -0
  418. package/dist/src/nile-grid-row/index.d.ts +1 -0
  419. package/dist/src/nile-grid-row/index.js +2 -0
  420. package/dist/src/nile-grid-row/index.js.map +1 -0
  421. package/dist/src/nile-grid-row/nile-grid-row.css.d.ts +12 -0
  422. package/dist/src/nile-grid-row/nile-grid-row.css.js +27 -0
  423. package/dist/src/nile-grid-row/nile-grid-row.css.js.map +1 -0
  424. package/dist/src/nile-grid-row/nile-grid-row.d.ts +29 -0
  425. package/dist/src/nile-grid-row/nile-grid-row.js +45 -0
  426. package/dist/src/nile-grid-row/nile-grid-row.js.map +1 -0
  427. package/dist/src/nile-icon/icons/svg/format_align_justify.d.ts +5 -0
  428. package/dist/src/nile-icon/icons/svg/format_align_justify.js +5 -0
  429. package/dist/src/nile-icon/icons/svg/format_align_justify.js.map +1 -0
  430. package/dist/src/nile-icon/icons/svg/format_align_left.d.ts +5 -0
  431. package/dist/src/nile-icon/icons/svg/format_align_left.js +5 -0
  432. package/dist/src/nile-icon/icons/svg/format_align_left.js.map +1 -0
  433. package/dist/src/nile-icon/icons/svg/format_align_middle.d.ts +5 -0
  434. package/dist/src/nile-icon/icons/svg/format_align_middle.js +5 -0
  435. package/dist/src/nile-icon/icons/svg/format_align_middle.js.map +1 -0
  436. package/dist/src/nile-icon/icons/svg/format_align_right.d.ts +5 -0
  437. package/dist/src/nile-icon/icons/svg/format_align_right.js +5 -0
  438. package/dist/src/nile-icon/icons/svg/format_align_right.js.map +1 -0
  439. package/dist/src/nile-icon/icons/svg/format_bold.d.ts +5 -0
  440. package/dist/src/nile-icon/icons/svg/format_bold.js +5 -0
  441. package/dist/src/nile-icon/icons/svg/format_bold.js.map +1 -0
  442. package/dist/src/nile-icon/icons/svg/format_clear.d.ts +5 -0
  443. package/dist/src/nile-icon/icons/svg/format_clear.js +5 -0
  444. package/dist/src/nile-icon/icons/svg/format_clear.js.map +1 -0
  445. package/dist/src/nile-icon/icons/svg/format_italic.d.ts +5 -0
  446. package/dist/src/nile-icon/icons/svg/format_italic.js +5 -0
  447. package/dist/src/nile-icon/icons/svg/format_italic.js.map +1 -0
  448. package/dist/src/nile-icon/icons/svg/format_list_bulleted.d.ts +5 -0
  449. package/dist/src/nile-icon/icons/svg/format_list_bulleted.js +5 -0
  450. package/dist/src/nile-icon/icons/svg/format_list_bulleted.js.map +1 -0
  451. package/dist/src/nile-icon/icons/svg/format_list_numbered.d.ts +5 -0
  452. package/dist/src/nile-icon/icons/svg/format_list_numbered.js +5 -0
  453. package/dist/src/nile-icon/icons/svg/format_list_numbered.js.map +1 -0
  454. package/dist/src/nile-icon/icons/svg/format_underline.d.ts +5 -0
  455. package/dist/src/nile-icon/icons/svg/format_underline.js +5 -0
  456. package/dist/src/nile-icon/icons/svg/format_underline.js.map +1 -0
  457. package/dist/src/nile-icon/icons/svg/image_2.d.ts +5 -0
  458. package/dist/src/nile-icon/icons/svg/image_2.js +5 -0
  459. package/dist/src/nile-icon/icons/svg/image_2.js.map +1 -0
  460. package/dist/src/nile-icon/icons/svg/index.d.ts +12 -0
  461. package/dist/src/nile-icon/icons/svg/index.js +12 -0
  462. package/dist/src/nile-icon/icons/svg/index.js.map +1 -1
  463. package/dist/src/nile-icon/icons/svg/link_2.d.ts +5 -0
  464. package/dist/src/nile-icon/icons/svg/link_2.js +5 -0
  465. package/dist/src/nile-icon/icons/svg/link_2.js.map +1 -0
  466. package/dist/src/nile-link/nile-link.css.js +1 -0
  467. package/dist/src/nile-link/nile-link.css.js.map +1 -1
  468. package/dist/src/nile-popover/nile-popover.js.map +1 -1
  469. package/dist/src/nile-rich-text-editor/index.d.ts +1 -0
  470. package/dist/src/nile-rich-text-editor/index.js +2 -0
  471. package/dist/src/nile-rich-text-editor/index.js.map +1 -0
  472. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.css.d.ts +3 -0
  473. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.css.js +152 -0
  474. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.css.js.map +1 -0
  475. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.d.ts +63 -0
  476. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.js +734 -0
  477. package/dist/src/nile-rich-text-editor/nile-rich-text-editor.js.map +1 -0
  478. package/dist/src/nile-rich-text-editor/nile-rte-color.d.ts +20 -0
  479. package/dist/src/nile-rich-text-editor/nile-rte-color.js +188 -0
  480. package/dist/src/nile-rich-text-editor/nile-rte-color.js.map +1 -0
  481. package/dist/src/nile-rich-text-editor/nile-rte-divider.d.ts +10 -0
  482. package/dist/src/nile-rich-text-editor/nile-rte-divider.js +12 -0
  483. package/dist/src/nile-rich-text-editor/nile-rte-divider.js.map +1 -0
  484. package/dist/src/nile-rich-text-editor/nile-rte-link.d.ts +19 -0
  485. package/dist/src/nile-rich-text-editor/nile-rte-link.js +169 -0
  486. package/dist/src/nile-rich-text-editor/nile-rte-link.js.map +1 -0
  487. package/dist/src/nile-rich-text-editor/nile-rte-mentions-item.d.ts +18 -0
  488. package/dist/src/nile-rich-text-editor/nile-rte-mentions-item.js +52 -0
  489. package/dist/src/nile-rich-text-editor/nile-rte-mentions-item.js.map +1 -0
  490. package/dist/src/nile-rich-text-editor/nile-rte-mentions.d.ts +64 -0
  491. package/dist/src/nile-rich-text-editor/nile-rte-mentions.js +544 -0
  492. package/dist/src/nile-rich-text-editor/nile-rte-mentions.js.map +1 -0
  493. package/dist/src/nile-rich-text-editor/nile-rte-preview.d.ts +10 -0
  494. package/dist/src/nile-rich-text-editor/nile-rte-preview.js +12 -0
  495. package/dist/src/nile-rich-text-editor/nile-rte-preview.js.map +1 -0
  496. package/dist/src/nile-rich-text-editor/nile-rte-select.d.ts +33 -0
  497. package/dist/src/nile-rich-text-editor/nile-rte-select.js +228 -0
  498. package/dist/src/nile-rich-text-editor/nile-rte-select.js.map +1 -0
  499. package/dist/src/nile-rich-text-editor/nile-rte-toolbar-item.d.ts +12 -0
  500. package/dist/src/nile-rich-text-editor/nile-rte-toolbar-item.js +23 -0
  501. package/dist/src/nile-rich-text-editor/nile-rte-toolbar-item.js.map +1 -0
  502. package/dist/src/nile-rich-text-editor/nile-rte-toolbar.d.ts +10 -0
  503. package/dist/src/nile-rich-text-editor/nile-rte-toolbar.js +12 -0
  504. package/dist/src/nile-rich-text-editor/nile-rte-toolbar.js.map +1 -0
  505. package/dist/src/nile-rich-text-editor/utils.d.ts +13 -0
  506. package/dist/src/nile-rich-text-editor/utils.js +538 -0
  507. package/dist/src/nile-rich-text-editor/utils.js.map +1 -0
  508. package/dist/src/nile-select/nile-select.css.js +1 -1
  509. package/dist/src/nile-select/nile-select.css.js.map +1 -1
  510. package/dist/src/nile-select/nile-select.d.ts +5 -0
  511. package/dist/src/nile-select/nile-select.js +32 -2
  512. package/dist/src/nile-select/nile-select.js.map +1 -1
  513. package/dist/src/nile-select/virtual-scroll-helper.js +2 -0
  514. package/dist/src/nile-select/virtual-scroll-helper.js.map +1 -1
  515. package/dist/src/nile-stepper-item/nile-stepper-item.js +5 -5
  516. package/dist/src/nile-stepper-item/nile-stepper-item.js.map +1 -1
  517. package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.js +4 -4
  518. package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.js.map +1 -1
  519. package/dist/src/nile-virtual-select/nile-virtual-select.css.js +29 -1
  520. package/dist/src/nile-virtual-select/nile-virtual-select.css.js.map +1 -1
  521. package/dist/src/nile-virtual-select/nile-virtual-select.d.ts +22 -1
  522. package/dist/src/nile-virtual-select/nile-virtual-select.js +148 -23
  523. package/dist/src/nile-virtual-select/nile-virtual-select.js.map +1 -1
  524. package/dist/src/nile-virtual-select/renderer.d.ts +2 -2
  525. package/dist/src/nile-virtual-select/renderer.js +9 -8
  526. package/dist/src/nile-virtual-select/renderer.js.map +1 -1
  527. package/dist/src/nile-virtual-select/selection-manager.js +1 -1
  528. package/dist/src/nile-virtual-select/selection-manager.js.map +1 -1
  529. package/dist/tsconfig.tsbuildinfo +1 -1
  530. package/package.json +11 -4
  531. package/src/index.ts +8 -1
  532. package/src/nile-button/nile-button.ts +1 -1
  533. package/src/nile-checkbox/nile-checkbox.css.ts +1 -1
  534. package/src/nile-grid/index.ts +1 -0
  535. package/src/nile-grid/nile-grid.css.ts +43 -0
  536. package/src/nile-grid/nile-grid.ts +185 -0
  537. package/src/nile-grid/nile-grid.utils.ts +252 -0
  538. package/src/nile-grid-body/index.ts +1 -0
  539. package/src/nile-grid-body/nile-grid-body.css.ts +24 -0
  540. package/src/nile-grid-body/nile-grid-body.ts +51 -0
  541. package/src/nile-grid-cell-item/index.ts +1 -0
  542. package/src/nile-grid-cell-item/nile-grid-cell-item.css.ts +49 -0
  543. package/src/nile-grid-cell-item/nile-grid-cell-item.ts +98 -0
  544. package/src/nile-grid-cell-item/nile-grid-cell-item.utils.ts +65 -0
  545. package/src/nile-grid-head/index.ts +1 -0
  546. package/src/nile-grid-head/nile-grid-head.css.ts +21 -0
  547. package/src/nile-grid-head/nile-grid-head.ts +50 -0
  548. package/src/nile-grid-head-item/index.ts +1 -0
  549. package/src/nile-grid-head-item/nile-grid-head-item.css.ts +48 -0
  550. package/src/nile-grid-head-item/nile-grid-head-item.ts +111 -0
  551. package/src/nile-grid-head-item/nile-grid-head-item.utils.ts +66 -0
  552. package/src/nile-grid-row/index.ts +1 -0
  553. package/src/nile-grid-row/nile-grid-row.css.ts +29 -0
  554. package/src/nile-grid-row/nile-grid-row.ts +53 -0
  555. package/src/nile-icon/icons/svg/format_align_justify.ts +5 -0
  556. package/src/nile-icon/icons/svg/format_align_left.ts +5 -0
  557. package/src/nile-icon/icons/svg/format_align_middle.ts +5 -0
  558. package/src/nile-icon/icons/svg/format_align_right.ts +5 -0
  559. package/src/nile-icon/icons/svg/format_bold.ts +5 -0
  560. package/src/nile-icon/icons/svg/format_clear.ts +5 -0
  561. package/src/nile-icon/icons/svg/format_italic.ts +5 -0
  562. package/src/nile-icon/icons/svg/format_list_bulleted.ts +5 -0
  563. package/src/nile-icon/icons/svg/format_list_numbered.ts +5 -0
  564. package/src/nile-icon/icons/svg/format_underline.ts +5 -0
  565. package/src/nile-icon/icons/svg/image_2.ts +5 -0
  566. package/src/nile-icon/icons/svg/index.ts +12 -0
  567. package/src/nile-icon/icons/svg/link_2.ts +5 -0
  568. package/src/nile-link/nile-link.css.ts +1 -0
  569. package/src/nile-popover/nile-popover.ts +0 -1
  570. package/src/nile-rich-text-editor/index.ts +1 -0
  571. package/src/nile-rich-text-editor/nile-rich-text-editor.css.ts +154 -0
  572. package/src/nile-rich-text-editor/nile-rich-text-editor.ts +835 -0
  573. package/src/nile-rich-text-editor/nile-rte-color.ts +189 -0
  574. package/src/nile-rich-text-editor/nile-rte-divider.ts +9 -0
  575. package/src/nile-rich-text-editor/nile-rte-link.ts +161 -0
  576. package/src/nile-rich-text-editor/nile-rte-mentions-item.ts +45 -0
  577. package/src/nile-rich-text-editor/nile-rte-mentions.ts +618 -0
  578. package/src/nile-rich-text-editor/nile-rte-preview.ts +9 -0
  579. package/src/nile-rich-text-editor/nile-rte-select.ts +249 -0
  580. package/src/nile-rich-text-editor/nile-rte-toolbar-item.ts +13 -0
  581. package/src/nile-rich-text-editor/nile-rte-toolbar.ts +9 -0
  582. package/src/nile-rich-text-editor/utils.ts +643 -0
  583. package/src/nile-select/nile-select.css.ts +1 -1
  584. package/src/nile-select/nile-select.ts +30 -2
  585. package/src/nile-select/virtual-scroll-helper.ts +2 -0
  586. package/src/nile-stepper-item/nile-stepper-item.ts +5 -5
  587. package/src/nile-vertical-stepper-item/nile-vertical-stepper-item.ts +4 -4
  588. package/src/nile-virtual-select/nile-virtual-select.css.ts +29 -1
  589. package/src/nile-virtual-select/nile-virtual-select.ts +158 -27
  590. package/src/nile-virtual-select/renderer.ts +10 -8
  591. package/src/nile-virtual-select/selection-manager.ts +1 -1
  592. package/vscode-html-custom-data.json +363 -34
  593. package/dist/scopedElementsWrapper-4c29be11.esm.js +0 -7
  594. package/dist/scopedElementsWrapper-a112fc73.cjs.js +0 -6
  595. package/dist/scopedElementsWrapper-a112fc73.cjs.js.map +0 -1
@@ -0,0 +1,835 @@
1
+ import { LitElement } from 'lit';
2
+ import { customElement, property, state } from 'lit/decorators.js';
3
+
4
+ import './nile-rte-toolbar';
5
+ import './nile-rte-toolbar-item';
6
+ import './nile-rte-select';
7
+ import './nile-rte-color';
8
+ import './nile-rte-divider';
9
+ import './nile-rte-preview';
10
+ import './nile-rte-mentions';
11
+ import './nile-rte-link';
12
+
13
+ import {
14
+ closestBlock,
15
+ nearestElement,
16
+ rgbToHex,
17
+ toggleInlineTag,
18
+ setBlockTag,
19
+ setAlignment,
20
+ setFontFamily,
21
+ setForeColor,
22
+ setBackColor,
23
+ toggleList,
24
+ } from './utils';
25
+
26
+ import { styles } from './nile-rich-text-editor.css';
27
+
28
+ type MentionsConfig = Record<string, { key: string; label: string }[]>;
29
+
30
+ const DEFAULT_ICONS: Record<string, string> = {
31
+ bold: 'format_bold',
32
+ italic: 'format_italic',
33
+ underline: 'format_underline',
34
+ link: 'link_2',
35
+ left: 'format_align_left',
36
+ center: 'format_align_middle',
37
+ right: 'format_align_right',
38
+ justify: 'format_align_justify',
39
+ ul: 'format_list_bulleted',
40
+ ol: 'format_list_numbered',
41
+ clear: 'format_clear',
42
+ };
43
+
44
+ @customElement('nile-rich-text-editor')
45
+ export class NileRichTextEditor extends LitElement {
46
+ protected createRenderRoot() {
47
+ return this;
48
+ }
49
+
50
+ @property({ type: String }) value = '';
51
+ @property({ type: Boolean, attribute: 'singlelineeditor' }) singleLineEditor =
52
+ false;
53
+
54
+ @property({
55
+ attribute: 'mentions',
56
+ converter: {
57
+ fromAttribute: (value: string): MentionsConfig => {
58
+ try {
59
+ const parsed = JSON.parse(value);
60
+ const out: MentionsConfig = {};
61
+ for (const trig of Object.keys(parsed)) {
62
+ const arr = parsed[trig];
63
+ if (Array.isArray(arr)) {
64
+ out[trig] = arr
65
+ .filter(
66
+ i =>
67
+ i &&
68
+ typeof i.key === 'string' &&
69
+ typeof i.label === 'string'
70
+ )
71
+ .map(i => ({ key: i.key, label: i.label }));
72
+ }
73
+ }
74
+ return out;
75
+ } catch {
76
+ return {};
77
+ }
78
+ },
79
+ toAttribute: (v: MentionsConfig) => JSON.stringify(v),
80
+ },
81
+ })
82
+ mentions: MentionsConfig = {};
83
+
84
+ @state() private content = '';
85
+ private editorEl!: HTMLElement;
86
+ private previewEl: HTMLElement | null = null;
87
+ private toolbarEl: HTMLElement | null = null;
88
+
89
+ private lastRange: Range | null = null;
90
+
91
+ private buttonMap = new Map<string, HTMLElement[]>();
92
+ private headingSelect: HTMLSelectElement | null = null;
93
+ private fontSelect: HTMLSelectElement | null = null;
94
+ private colorInput: HTMLInputElement | null = null;
95
+ private bgColorInput: HTMLInputElement | null = null;
96
+ private colorSwatchEl: HTMLElement | null = null;
97
+ private bgSwatchEl: HTMLElement | null = null;
98
+ private containerEl: HTMLElement | null = null;
99
+
100
+ private mentionsEl: HTMLElement | null = null;
101
+
102
+ private injectCss(cssText: string) {
103
+ if (this.querySelector('style[data-rte-style]')) return;
104
+ const style = document.createElement('style');
105
+ style.setAttribute('data-rte-style', 'true');
106
+ style.textContent = cssText;
107
+ this.insertBefore(style, this.firstChild);
108
+ }
109
+
110
+ connectedCallback(): void {
111
+ super.connectedCallback();
112
+ this.injectCss(styles.cssText);
113
+ this.ensureStructure();
114
+
115
+ if (this.value && !this.editorEl.innerHTML.trim()) {
116
+ this.editorEl.innerHTML = this.value;
117
+ }
118
+ this.content = this.editorEl.innerHTML;
119
+
120
+ if (this.toolbarEl) this.wireAuthoredToolbar(this.toolbarEl);
121
+ this.mentionsEl = this.querySelector('nile-rte-mentions');
122
+ if (this.mentionsEl) {
123
+ (this.mentionsEl as any).attach?.(this.editorEl, this as HTMLElement);
124
+ (this.mentionsEl as any).setExternalConfig?.(this.mentions);
125
+ }
126
+
127
+ this.wireEditor();
128
+ document.addEventListener('selectionchange', this.onSelectionChange, {
129
+ passive: true,
130
+ });
131
+ this.updateToolbarState();
132
+ this.syncPreview();
133
+ }
134
+
135
+ private ensureStructure() {
136
+ this.toolbarEl = this.querySelector('nile-rte-toolbar');
137
+ this.previewEl = this.querySelector('nile-rte-preview');
138
+
139
+ // container for toolbar + editor
140
+ this.containerEl = this.querySelector('.rte-container') as HTMLElement;
141
+ if (!this.containerEl) {
142
+ this.containerEl = document.createElement('div');
143
+ this.containerEl.className = 'rte-container';
144
+ this.appendChild(this.containerEl);
145
+ }
146
+
147
+ // ensure editor
148
+ this.ensureEditor();
149
+
150
+ // put toolbar + editor inside container
151
+ if (this.toolbarEl && this.toolbarEl.parentElement !== this.containerEl) {
152
+ this.containerEl.appendChild(this.toolbarEl);
153
+ }
154
+ if (this.editorEl.parentElement !== this.containerEl) {
155
+ this.containerEl.appendChild(this.editorEl);
156
+ }
157
+
158
+ if (this.previewEl) {
159
+ if (this.previewEl.parentElement !== this) {
160
+ this.appendChild(this.previewEl);
161
+ }
162
+
163
+ if (this.previewEl.previousElementSibling !== this.containerEl) {
164
+ this.insertBefore(this.previewEl, this.containerEl.nextSibling);
165
+ }
166
+ }
167
+ }
168
+
169
+ private updateContentWithMention(mentionDetail: any) {
170
+ this.updateContent();
171
+ this.dispatchEvent(
172
+ new CustomEvent('content-changed', {
173
+ detail: {
174
+ content: this.content,
175
+ mention: mentionDetail,
176
+ },
177
+ bubbles: true,
178
+ composed: true,
179
+ })
180
+ );
181
+ }
182
+
183
+ disconnectedCallback(): void {
184
+ document.removeEventListener('selectionchange', this.onSelectionChange);
185
+
186
+ if (this.mentionsEl && (this.mentionsEl as any).detach) {
187
+ (this.mentionsEl as any).detach();
188
+ }
189
+ super.disconnectedCallback();
190
+ }
191
+ protected updated(changed: Map<string, any>) {
192
+ if (changed.has('value')) {
193
+ if (this.editorEl && this.value !== this.editorEl.innerHTML) {
194
+ this.editorEl.innerHTML = this.value || '<p><br></p>';
195
+ this.content = this.editorEl.innerHTML;
196
+ this.syncPreview();
197
+ }
198
+ }
199
+ if (changed.has('singleLineEditor')) {
200
+ if (this.editorEl) {
201
+ this.editorEl.classList.toggle('single-line', this.singleLineEditor);
202
+ }
203
+ if (this.previewEl) {
204
+ this.previewEl.classList.toggle('single-line', this.singleLineEditor);
205
+ }
206
+ }
207
+ }
208
+
209
+ private ensureEditor() {
210
+ this.editorEl = this.querySelector('.editor') as HTMLElement;
211
+ if (!this.editorEl) {
212
+ const editor = document.createElement('article');
213
+ editor.className = 'editor';
214
+ editor.setAttribute('contenteditable', 'true');
215
+ this.editorEl = editor;
216
+ }
217
+ if (!this.editorEl.innerHTML.trim()) {
218
+ this.editorEl.innerHTML = '<p><br></p>';
219
+ }
220
+ }
221
+
222
+ private unwrapMention(span: HTMLElement, preserveText = true) {
223
+ const parent = span.parentNode;
224
+ if (!parent) return;
225
+
226
+ const txt = preserveText
227
+ ? (span.textContent ?? '').replace(/\u200B/g, '')
228
+ : '';
229
+ const textNode = document.createTextNode(txt);
230
+ parent.insertBefore(textNode, span);
231
+ parent.removeChild(span);
232
+ const r = document.createRange();
233
+ r.setStartAfter(textNode);
234
+ r.collapse(true);
235
+ const sel = window.getSelection();
236
+ sel?.removeAllRanges();
237
+ sel?.addRange(r);
238
+ }
239
+
240
+ private scrubBrokenMentions() {
241
+ if (!this.editorEl) return;
242
+ const mentions = this.editorEl.querySelectorAll('span.mention');
243
+
244
+ mentions.forEach(m => {
245
+ const span = m as HTMLElement;
246
+ const key = span.getAttribute('data-mention-key');
247
+ const label = span.getAttribute('data-mention-label');
248
+ const trigger = span.getAttribute('data-mention-trigger') || '';
249
+ const text = (span.textContent ?? '').replace(/\u200B/g, '').trim();
250
+
251
+ const looksValid =
252
+ !!key &&
253
+ !!label &&
254
+ text.length > 0 &&
255
+ text.startsWith(trigger) &&
256
+ text.includes(label);
257
+
258
+ if (!text || !looksValid) {
259
+ this.unwrapMention(span, true);
260
+ return;
261
+ }
262
+ });
263
+ }
264
+
265
+ private wireEditor() {
266
+ this.editorEl.addEventListener('input', () => {
267
+ this.ensureAtLeastOneParagraph();
268
+ this.scrubBrokenMentions();
269
+ this.updateContent();
270
+ this.updateToolbarState();
271
+ });
272
+ this.editorEl.addEventListener('mouseup', () => {
273
+ this.saveSelection();
274
+ this.updateToolbarState();
275
+ });
276
+ this.editorEl.addEventListener('keyup', e => {
277
+ this.saveSelection();
278
+
279
+ if (
280
+ [
281
+ 'ArrowLeft',
282
+ 'ArrowRight',
283
+ 'ArrowUp',
284
+ 'ArrowDown',
285
+ 'Home',
286
+ 'End',
287
+ ].includes(e.key)
288
+ ) {
289
+ this.updateToolbarState();
290
+ }
291
+ });
292
+ this.editorEl.addEventListener('keydown', this.onEditorKeydown);
293
+ }
294
+
295
+ private onEditorKeydown = (e: KeyboardEvent) => {
296
+ if (this.singleLineEditor && e.key === 'Enter' && e.shiftKey) {
297
+ e.preventDefault();
298
+ return;
299
+ }
300
+ if (e.ctrlKey && e.key.toLowerCase() === 'i') {
301
+ e.preventDefault();
302
+ toggleInlineTag(this.editorEl, 'em');
303
+ this.updateContent();
304
+ this.updateToolbarState();
305
+ }
306
+
307
+ if (this.singleLineEditor && e.key === 'Enter') {
308
+ e.preventDefault();
309
+ return;
310
+ }
311
+ if (e.key !== 'Tab') return;
312
+
313
+ e.preventDefault();
314
+ this.focusAndRestore();
315
+
316
+ const sel = window.getSelection();
317
+ if (!sel || sel.rangeCount === 0) return;
318
+ const range = sel.getRangeAt(0);
319
+
320
+ if (e.shiftKey) {
321
+ if (range.collapsed && range.startContainer.nodeType === Node.TEXT_NODE) {
322
+ const t = range.startContainer as Text;
323
+ const off = range.startOffset;
324
+ const before = t.data.slice(0, off);
325
+
326
+ const removed = before.replace(/(\t|[ \u00a0]{2})$/, '');
327
+ if (removed.length !== before.length) {
328
+ t.data = removed + t.data.slice(off);
329
+ const r = document.createRange();
330
+ r.setStart(t, removed.length);
331
+ r.collapse(true);
332
+ sel.removeAllRanges();
333
+ sel.addRange(r);
334
+ this.updateContent();
335
+ this.updateToolbarState();
336
+ }
337
+ }
338
+ return;
339
+ }
340
+
341
+ range.deleteContents();
342
+ const tabNode = document.createTextNode('\t');
343
+ range.insertNode(tabNode);
344
+
345
+ const r = document.createRange();
346
+ r.setStartAfter(tabNode);
347
+ r.collapse(true);
348
+ sel.removeAllRanges();
349
+ sel.addRange(r);
350
+
351
+ this.updateContent();
352
+ this.updateToolbarState();
353
+ };
354
+
355
+ private wireAuthoredToolbar(tb: HTMLElement) {
356
+ this.buttonMap.clear();
357
+ this.headingSelect = null;
358
+ this.fontSelect = null;
359
+ this.colorInput = null;
360
+
361
+ Array.from(tb.children).forEach(child => {
362
+ const tag = child.tagName.toLowerCase();
363
+
364
+ if (tag === 'nile-rte-select' && child.getAttribute('type') === 'align') {
365
+ child.addEventListener('change', (e: any) => {
366
+ this.focusAndRestore();
367
+ const alignment = e.detail as 'left' | 'center' | 'right' | 'justify';
368
+ setAlignment(this.editorEl, alignment);
369
+ this.updateContent();
370
+ this.updateToolbarState();
371
+ });
372
+ return;
373
+ }
374
+ if (tag === 'nile-rte-link') {
375
+ (child as any).editorEl = this.editorEl;
376
+ child.addEventListener('link-changed', () => {
377
+ this.updateContent();
378
+ this.updateToolbarState();
379
+ });
380
+ return;
381
+ }
382
+
383
+ if (tag === 'nile-rte-toolbar-item') {
384
+ let btn = child.querySelector(
385
+ ':scope > nile-button'
386
+ ) as HTMLElement | null;
387
+
388
+ const cmd = child.getAttribute('name') || '';
389
+ const label = child.getAttribute('label') || cmd;
390
+ const iconAttr = child.getAttribute('icon');
391
+ const authoredHasContent = child.innerHTML.trim().length > 0;
392
+
393
+ if (!btn) {
394
+ btn = document.createElement('nile-button');
395
+ (btn as any).variant = 'tertiary';
396
+ (btn as any).size = 'small';
397
+ }
398
+
399
+ if (iconAttr) {
400
+ btn.innerHTML = `<nile-icon name="${iconAttr}" aria-label="${label}"></nile-icon>`;
401
+ child.innerHTML = '';
402
+ } else if (!authoredHasContent) {
403
+ const defaultIcon = DEFAULT_ICONS[cmd];
404
+ if (defaultIcon) {
405
+ btn.innerHTML = `<nile-icon name="${defaultIcon}" size="20" color="black" aria-label="${label}"></nile-icon>`;
406
+ } else {
407
+ btn.textContent = label || cmd;
408
+ }
409
+ child.innerHTML = '';
410
+ } else {
411
+ btn.innerHTML = child.innerHTML;
412
+ child.innerHTML = '';
413
+ }
414
+
415
+ if (!btn.isConnected) {
416
+ const tooltip = document.createElement('nile-tooltip');
417
+ tooltip.setAttribute('content', label);
418
+ tooltip.appendChild(btn);
419
+ child.appendChild(tooltip);
420
+ }
421
+
422
+ btn.setAttribute('aria-label', label);
423
+ btn.addEventListener('mousedown', e => e.preventDefault());
424
+ btn.addEventListener('click', () => this.onToolbarCommand(cmd));
425
+
426
+ const arr = this.buttonMap.get(cmd) ?? [];
427
+ arr.push(btn);
428
+ this.buttonMap.set(cmd, arr);
429
+
430
+ return;
431
+ }
432
+ if (tag === 'nile-rte-select') {
433
+ const type = child.getAttribute('type') || '';
434
+
435
+ child.addEventListener('change', (e: any) => {
436
+ this.focusAndRestore();
437
+
438
+ const val = e.detail as string;
439
+
440
+ if (type === 'heading') {
441
+ setBlockTag(this.editorEl, val as any);
442
+ } else if (type === 'font') {
443
+ setFontFamily(this.editorEl, val);
444
+ }
445
+
446
+ this.updateContent();
447
+ this.updateToolbarState();
448
+ });
449
+
450
+ return;
451
+ }
452
+
453
+ if (tag === 'nile-rte-color') {
454
+ child.addEventListener('change', (e: any) => {
455
+ this.focusAndRestore();
456
+ const { mode, value } = e.detail;
457
+
458
+ if (mode === 'backColor') {
459
+ setBackColor(this.editorEl, value);
460
+ } else {
461
+ setForeColor(this.editorEl, value);
462
+ }
463
+
464
+ this.updateContent();
465
+ this.updateToolbarState();
466
+ });
467
+ return;
468
+ }
469
+ });
470
+ }
471
+ private onSelectionChange = () => {
472
+ if (!this.editorEl) return;
473
+ const sel = document.getSelection();
474
+ if (!sel || sel.rangeCount === 0) return;
475
+ const range = sel.getRangeAt(0);
476
+ if (this.editorEl.contains(range.commonAncestorContainer)) {
477
+ this.lastRange = range.cloneRange();
478
+ this.updateToolbarState();
479
+ }
480
+ };
481
+ private saveSelection() {
482
+ const sel = window.getSelection();
483
+ if (sel && sel.rangeCount) this.lastRange = sel.getRangeAt(0).cloneRange();
484
+ }
485
+ private restoreSelection() {
486
+ if (!this.lastRange) return;
487
+ const sel = document.getSelection();
488
+ if (!sel) return;
489
+ sel.removeAllRanges();
490
+ sel.addRange(this.lastRange);
491
+ }
492
+ private focusAndRestore() {
493
+ this.editorEl?.focus();
494
+ this.restoreSelection();
495
+ }
496
+
497
+ private insertList(type: 'ul' | 'ol') {
498
+ this.restoreSelection();
499
+ if (!this.lastRange) return;
500
+
501
+ const list = document.createElement(type);
502
+
503
+ // grab the selected fragment
504
+ const frag = this.lastRange.extractContents();
505
+ const temp = document.createElement('div');
506
+ temp.appendChild(frag);
507
+
508
+ // wrap each top-level node in an <li>
509
+ Array.from(temp.childNodes).forEach(n => {
510
+ // skip empty whitespace text nodes
511
+ if (n.nodeType === Node.TEXT_NODE && !n.textContent?.trim()) return;
512
+ const li = document.createElement('li');
513
+ li.appendChild(n);
514
+ list.appendChild(li);
515
+ });
516
+
517
+ this.lastRange.insertNode(list);
518
+ this.afterListEdit(list);
519
+ }
520
+
521
+ private afterListEdit(node: Node) {
522
+ const range = document.createRange();
523
+ range.setStartAfter(node);
524
+ range.collapse(true);
525
+ const sel = window.getSelection();
526
+ sel?.removeAllRanges();
527
+ sel?.addRange(range);
528
+
529
+ this.saveSelection();
530
+ this.updateContent();
531
+ this.updateToolbarState();
532
+ }
533
+
534
+ private ensureAtLeastOneParagraph() {
535
+ const el = this.editorEl;
536
+ if (!el) return;
537
+
538
+ const onlyWhitespace =
539
+ (el.textContent ?? '').replace(/\u200B/g, '').trim() === '';
540
+ if (el.childNodes.length === 0 || onlyWhitespace) {
541
+ el.innerHTML = '<p><br></p>';
542
+ return;
543
+ }
544
+
545
+ const hasBlock = el.querySelector(
546
+ 'p,h1,h2,h3,h4,h5,h6,ul,ol,table,blockquote,pre'
547
+ );
548
+ if (!hasBlock) {
549
+ const p = document.createElement('p');
550
+ while (el.firstChild) p.appendChild(el.firstChild);
551
+ if (!p.hasChildNodes()) p.appendChild(document.createElement('br'));
552
+ el.appendChild(p);
553
+ return;
554
+ }
555
+
556
+ el.querySelectorAll('p').forEach(p => {
557
+ if ((p.textContent ?? '').replace(/\u200B/g, '') === '') {
558
+ if (!p.innerHTML.toLowerCase().includes('<br')) p.innerHTML = '<br>';
559
+ }
560
+ });
561
+ }
562
+
563
+ // ---------- Toolbar/commands ----------
564
+ private onToolbarCommand(cmd: string) {
565
+ this.focusAndRestore();
566
+ switch (cmd) {
567
+ case 'bold':
568
+ toggleInlineTag(this.editorEl, 'strong');
569
+ break;
570
+ case 'italic':
571
+ toggleInlineTag(this.editorEl, 'em');
572
+ break;
573
+ case 'underline':
574
+ toggleInlineTag(this.editorEl, 'u');
575
+ break;
576
+ case 'left':
577
+ setAlignment(this.editorEl, 'left');
578
+ break;
579
+ case 'center':
580
+ setAlignment(this.editorEl, 'center');
581
+ break;
582
+ case 'right':
583
+ setAlignment(this.editorEl, 'right');
584
+ break;
585
+ case 'justify':
586
+ setAlignment(this.editorEl, 'justify');
587
+ break;
588
+ case 'ul':
589
+ toggleList(this.editorEl, 'ul');
590
+ this.updateContent();
591
+ this.updateToolbarState();
592
+ break;
593
+ case 'ol':
594
+ toggleList(this.editorEl, 'ol');
595
+ this.updateContent();
596
+ this.updateToolbarState();
597
+ break;
598
+
599
+ case 'link':
600
+ break;
601
+ case 'clear':
602
+ const walker = document.createTreeWalker(
603
+ this.editorEl,
604
+ NodeFilter.SHOW_ELEMENT
605
+ );
606
+ const toUnwrap: HTMLElement[] = [];
607
+ while (walker.nextNode()) {
608
+ const el = walker.currentNode as HTMLElement;
609
+ el.removeAttribute('style');
610
+ if (
611
+ ['B', 'STRONG', 'I', 'EM', 'U', 'SPAN', 'FONT'].includes(el.tagName)
612
+ ) {
613
+ toUnwrap.push(el);
614
+ }
615
+ }
616
+ for (const el of toUnwrap) {
617
+ while (el.firstChild) el.parentNode?.insertBefore(el.firstChild, el);
618
+ el.remove();
619
+ }
620
+ this.ensureAtLeastOneParagraph();
621
+ break;
622
+
623
+ default:
624
+ break;
625
+ }
626
+ this.updateContent();
627
+ this.updateToolbarState();
628
+ }
629
+
630
+ private setBtnActive(cmd: string, active: boolean) {
631
+ const arr = this.buttonMap.get(cmd);
632
+ if (!arr) return;
633
+ for (const btn of arr) btn.toggleAttribute('data-active', !!active);
634
+ }
635
+
636
+ private updateToolbarState() {
637
+ if (!this.editorEl) return;
638
+ const sel = document.getSelection();
639
+ if (!sel || sel.rangeCount === 0) return;
640
+ const range = sel.getRangeAt(0);
641
+ if (!this.editorEl.contains(range.commonAncestorContainer)) return;
642
+
643
+ const startElm = nearestElement(range.startContainer) || this.editorEl;
644
+ const comp = getComputedStyle(startElm);
645
+ const block =
646
+ closestBlock(range.startContainer, this.editorEl) || this.editorEl;
647
+
648
+ const isBold = (() => {
649
+ let n: Node | null = startElm;
650
+ while (n && n !== this.editorEl) {
651
+ if (n instanceof HTMLElement) {
652
+ const t = n.tagName.toLowerCase();
653
+ if (t === 'strong' || t === 'b') return true;
654
+ const w = getComputedStyle(n).fontWeight;
655
+ if (parseInt(w, 10) >= 600) return true;
656
+ }
657
+ n = n.parentNode;
658
+ }
659
+ return false;
660
+ })();
661
+
662
+ const isItalic = (() => {
663
+ let n: Node | null = startElm;
664
+ while (n && n !== this.editorEl) {
665
+ if (n instanceof HTMLElement) {
666
+ const t = n.tagName.toLowerCase();
667
+ if (t === 'em' || t === 'i') return true;
668
+ if (getComputedStyle(n).fontStyle === 'italic') return true;
669
+ }
670
+ n = n.parentNode;
671
+ }
672
+ return false;
673
+ })();
674
+
675
+ const isUnderline = (() => {
676
+ let n: Node | null = startElm;
677
+ while (n && n !== this.editorEl) {
678
+ if (n instanceof HTMLElement) {
679
+ const tdl = getComputedStyle(n).textDecorationLine;
680
+ if (tdl && tdl.includes('underline')) return true;
681
+ if (n.tagName.toLowerCase() === 'u') return true;
682
+ }
683
+ n = n.parentNode;
684
+ }
685
+ return false;
686
+ })();
687
+
688
+ const inLink = !!startElm.closest('a');
689
+
690
+ const align = (block.style.textAlign ||
691
+ getComputedStyle(block).textAlign ||
692
+ 'start') as string;
693
+ const alignNorm = align === 'start' ? 'left' : align;
694
+
695
+ const inLi = !!startElm.closest('li');
696
+ const listType = inLi
697
+ ? startElm.closest('ul,ol')?.tagName.toLowerCase() || ''
698
+ : '';
699
+
700
+ this.setBtnActive('bold', isBold);
701
+ this.setBtnActive('italic', isItalic);
702
+ this.setBtnActive('underline', isUnderline);
703
+ this.setBtnActive('link', inLink);
704
+
705
+ this.setBtnActive(
706
+ 'left',
707
+ alignNorm === 'left' &&
708
+ !['center', 'right', 'justify'].includes(alignNorm)
709
+ );
710
+ this.setBtnActive('center', alignNorm === 'center');
711
+ this.setBtnActive('right', alignNorm === 'right');
712
+ this.setBtnActive('justify', alignNorm === 'justify');
713
+
714
+ this.setBtnActive('ul', listType === 'ul');
715
+ this.setBtnActive('ol', listType === 'ol');
716
+
717
+ if (this.headingSelect) {
718
+ const tag = block.tagName.toLowerCase();
719
+ const v = ['h1', 'h2', 'h3'].includes(tag) ? tag : 'p';
720
+ if (this.headingSelect.value !== v) this.headingSelect.value = v;
721
+ }
722
+
723
+ if (this.fontSelect) {
724
+ const ff = (comp.fontFamily || '')
725
+ .replace(/["']/g, '')
726
+ .split(',')[0]
727
+ .trim()
728
+ .toLowerCase();
729
+ if (ff) {
730
+ for (const opt of Array.from(this.fontSelect.options)) {
731
+ if (opt.value.toLowerCase() === ff) {
732
+ this.fontSelect.value = opt.value;
733
+ break;
734
+ }
735
+ }
736
+ }
737
+ }
738
+
739
+ if (this.colorInput) {
740
+ const hex = rgbToHex(comp.color);
741
+ if (hex && this.colorInput.value.toLowerCase() !== hex.toLowerCase()) {
742
+ this.colorInput.value = hex;
743
+ }
744
+ if (this.colorSwatchEl)
745
+ this.colorSwatchEl.style.backgroundColor = this.colorInput.value;
746
+ }
747
+
748
+ if (this.bgColorInput) {
749
+ const bg = getComputedStyle(startElm).backgroundColor;
750
+ if (
751
+ bg &&
752
+ !/transparent|rgba\(\s*0\s*,\s*0\s*,\s*0\s*,\s*0\s*\)/i.test(bg)
753
+ ) {
754
+ const bgHex = rgbToHex(bg);
755
+ if (
756
+ bgHex &&
757
+ this.bgColorInput.value.toLowerCase() !== bgHex.toLowerCase()
758
+ ) {
759
+ this.bgColorInput.value = bgHex;
760
+ }
761
+ }
762
+ if (this.bgSwatchEl)
763
+ this.bgSwatchEl.style.backgroundColor = this.bgColorInput.value;
764
+ }
765
+ }
766
+
767
+ private syncPreview() {
768
+ this.updateContent();
769
+ }
770
+
771
+ private updateContent() {
772
+ if (!this.editorEl) return;
773
+ this.ensureAtLeastOneParagraph();
774
+
775
+ const clone = this.editorEl.cloneNode(true) as HTMLElement;
776
+
777
+ const origWalker = document.createTreeWalker(
778
+ this.editorEl,
779
+ NodeFilter.SHOW_ELEMENT
780
+ );
781
+ const cloneWalker = document.createTreeWalker(
782
+ clone,
783
+ NodeFilter.SHOW_ELEMENT
784
+ );
785
+
786
+ const importantProps = [
787
+ 'font-weight',
788
+ 'font-style',
789
+ 'text-decoration',
790
+ 'color',
791
+ 'background-color',
792
+ 'font-size',
793
+ 'font-family',
794
+ 'text-align',
795
+ 'line-height',
796
+ 'letter-spacing',
797
+ 'white-space',
798
+ 'vertical-align',
799
+ 'list-style-position',
800
+ 'padding-inline-start',
801
+ ];
802
+
803
+ while (origWalker.nextNode() && cloneWalker.nextNode()) {
804
+ const origEl = origWalker.currentNode as HTMLElement;
805
+ const cloneEl = cloneWalker.currentNode as HTMLElement;
806
+ const computed = window.getComputedStyle(origEl);
807
+
808
+ const cssText = importantProps
809
+ .map(prop => `${prop}:${computed.getPropertyValue(prop)}`)
810
+ .join(';');
811
+
812
+ if (cssText.trim()) {
813
+ cloneEl.setAttribute('style', cssText);
814
+ }
815
+ }
816
+
817
+ this.content = clone.innerHTML;
818
+
819
+ if (this.previewEl) this.previewEl.innerHTML = this.content;
820
+
821
+ this.dispatchEvent(
822
+ new CustomEvent('content-changed', {
823
+ detail: { content: this.content },
824
+ bubbles: true,
825
+ composed: true,
826
+ })
827
+ );
828
+ }
829
+ }
830
+
831
+ declare global {
832
+ interface HTMLElementTagNameMap {
833
+ 'nile-rich-text-editor': NileRichTextEditor;
834
+ }
835
+ }