@aquera/nile-elements 0.1.75-beta-1.1 → 0.1.75-beta-2.0

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