@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,643 @@
1
+ export function closestBlock(
2
+ node: Node | null,
3
+ root: HTMLElement
4
+ ): HTMLElement | null {
5
+ while (node && node !== root) {
6
+ if (node instanceof HTMLElement) {
7
+ const display = getComputedStyle(node).display;
8
+ if (
9
+ node.tagName.match(/^(P|DIV|H1|H2|H3|H4|H5|H6|LI)$/) ||
10
+ display === 'block' ||
11
+ display === 'list-item'
12
+ ) {
13
+ return node;
14
+ }
15
+ }
16
+ node = node?.parentNode || null;
17
+ }
18
+ return root;
19
+ }
20
+
21
+ export function nearestElement(n: Node | null): HTMLElement | null {
22
+ while (n && !(n instanceof HTMLElement)) n = n.parentNode as Node | null;
23
+ return n as HTMLElement | null;
24
+ }
25
+
26
+ export function rgbToHex(rgb: string): string {
27
+ const m = rgb.match(/rgba?\((\d+),\s*(\d+),\s*(\d+)/i);
28
+ if (!m) return '#000000';
29
+ const r = Number(m[1]).toString(16).padStart(2, '0');
30
+ const g = Number(m[2]).toString(16).padStart(2, '0');
31
+ const b = Number(m[3]).toString(16).padStart(2, '0');
32
+ return `#${r}${g}${b}`;
33
+ }
34
+
35
+ export function unwrap(node: HTMLElement) {
36
+ const p = node.parentNode;
37
+ if (!p) return;
38
+ while (node.firstChild) p.insertBefore(node.firstChild, node);
39
+ p.removeChild(node);
40
+ }
41
+
42
+ export function surroundInline(
43
+ range: Range,
44
+ tag: string,
45
+ attrs?: Record<string, string>
46
+ ) {
47
+ const wrap = document.createElement(tag);
48
+ if (attrs) Object.entries(attrs).forEach(([k, v]) => wrap.setAttribute(k, v));
49
+ try {
50
+ range.surroundContents(wrap);
51
+ } catch {
52
+ const frag = range.extractContents();
53
+ wrap.appendChild(frag);
54
+ range.insertNode(wrap);
55
+ }
56
+ }
57
+
58
+ function unwrapAllMatching(
59
+ node: Node,
60
+ root: HTMLElement,
61
+ matcher: (el: HTMLElement) => boolean
62
+ ) {
63
+ let n: Node | null = node.parentNode;
64
+ while (n && n !== root) {
65
+ if (n instanceof HTMLElement && matcher(n)) {
66
+ unwrap(n);
67
+
68
+ n = node.parentNode;
69
+ continue;
70
+ }
71
+ n = n.parentNode;
72
+ }
73
+ }
74
+
75
+ export function toggleInlineTag(
76
+ root: HTMLElement,
77
+ tag: 'strong' | 'em' | 'u' | 'span',
78
+ attrs?: Record<string, string>
79
+ ) {
80
+ const sel = document.getSelection();
81
+ if (!sel || sel.rangeCount === 0) {
82
+ return;
83
+ }
84
+ const range = sel.getRangeAt(0);
85
+
86
+ const aliases: Record<string, string[]> = {
87
+ strong: ['strong', 'b'],
88
+ em: ['em', 'i'],
89
+ u: ['u'],
90
+ span: ['span'],
91
+ };
92
+ const candidates = aliases[tag] ?? [tag];
93
+
94
+ function isMatchingInline(el: HTMLElement): boolean {
95
+ return candidates.includes(el.tagName.toLowerCase());
96
+ }
97
+
98
+ if (range.collapsed) {
99
+ let n: Node | null = range.startContainer;
100
+ while (n && n !== root) {
101
+ if (n instanceof HTMLElement && isMatchingInline(n)) {
102
+ unwrapAllMatching(range.startContainer, root, isMatchingInline);
103
+ return;
104
+ }
105
+ n = n.parentNode;
106
+ }
107
+
108
+ const elm = document.createElement(tag);
109
+ if (attrs)
110
+ Object.entries(attrs).forEach(([k, v]) => elm.setAttribute(k, v));
111
+ elm.appendChild(document.createTextNode('\u200b'));
112
+ range.insertNode(elm);
113
+
114
+ const r = document.createRange();
115
+ r.setStart(elm.firstChild!, 1);
116
+ r.collapse(true);
117
+ sel.removeAllRanges();
118
+ sel.addRange(r);
119
+
120
+ return;
121
+ }
122
+
123
+ const startBlock = closestBlock(range.startContainer, root);
124
+ const endBlock = closestBlock(range.endContainer, root);
125
+ if (startBlock && endBlock && startBlock !== endBlock) {
126
+ const blocks: HTMLElement[] = [];
127
+ let node: Node | null = startBlock;
128
+ while (node) {
129
+ if (node instanceof HTMLElement) blocks.push(node);
130
+ if (node === endBlock) break;
131
+ node = node.nextSibling;
132
+ }
133
+
134
+ blocks.forEach((block, i) => {
135
+ const r = document.createRange();
136
+ r.selectNodeContents(block);
137
+
138
+ const textNodes: Text[] = [];
139
+ const tw = document.createTreeWalker(block, NodeFilter.SHOW_TEXT, null);
140
+ let tn: Node | null;
141
+ while ((tn = tw.nextNode())) {
142
+ if (tn.nodeValue?.trim()) textNodes.push(tn as Text);
143
+ }
144
+
145
+ const allWrapped =
146
+ textNodes.length > 0 &&
147
+ textNodes.every(txt => {
148
+ let n: Node | null = txt;
149
+ while (n && n !== block) {
150
+ if (n instanceof HTMLElement && isMatchingInline(n)) return true;
151
+ n = n.parentNode;
152
+ }
153
+ return false;
154
+ });
155
+
156
+ if (allWrapped) {
157
+ textNodes.forEach(txt =>
158
+ unwrapAllMatching(txt, block, isMatchingInline)
159
+ );
160
+ } else {
161
+ surroundInline(r, tag, attrs);
162
+ }
163
+ });
164
+ return;
165
+ }
166
+ const walker = document.createTreeWalker(
167
+ range.commonAncestorContainer,
168
+ NodeFilter.SHOW_TEXT,
169
+ {
170
+ acceptNode: n => {
171
+ if (!n.nodeValue || !n.nodeValue.trim())
172
+ return NodeFilter.FILTER_REJECT;
173
+ const nodeRange = document.createRange();
174
+ nodeRange.selectNodeContents(n);
175
+ const intersects =
176
+ range.compareBoundaryPoints(Range.END_TO_START, nodeRange) <= 0 &&
177
+ range.compareBoundaryPoints(Range.START_TO_END, nodeRange) >= 0;
178
+ return intersects ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_REJECT;
179
+ },
180
+ }
181
+ );
182
+
183
+ const textNodes: Text[] = [];
184
+ let t: Node | null;
185
+ while ((t = walker.nextNode())) textNodes.push(t as Text);
186
+
187
+ if (textNodes.length === 0) {
188
+ let n: Node | null = range.startContainer;
189
+ while (n && n !== root) {
190
+ if (n instanceof HTMLElement && isMatchingInline(n)) {
191
+ unwrapAllMatching(range.startContainer, root, isMatchingInline);
192
+ return;
193
+ }
194
+ n = n.parentNode;
195
+ }
196
+ }
197
+
198
+ const allWrapped =
199
+ textNodes.length > 0 &&
200
+ textNodes.every(txt => {
201
+ let n: Node | null = txt;
202
+ while (n && n !== root) {
203
+ if (n instanceof HTMLElement && isMatchingInline(n)) {
204
+ return true;
205
+ }
206
+ n = n.parentNode;
207
+ }
208
+ return false;
209
+ });
210
+
211
+ if (allWrapped) {
212
+ textNodes.forEach(txt => unwrapAllMatching(txt, root, isMatchingInline));
213
+ } else {
214
+ surroundInline(range, tag, attrs);
215
+ }
216
+
217
+ // restore selection
218
+ const selRange = document.createRange();
219
+ selRange.setStart(range.startContainer, range.startOffset);
220
+ selRange.setEnd(range.endContainer, range.endOffset);
221
+ sel.removeAllRanges();
222
+ sel.addRange(selRange);
223
+ }
224
+
225
+ export function setBlockTag(root: HTMLElement, tag: 'p' | 'h1' | 'h2' | 'h3') {
226
+ const sel = document.getSelection();
227
+ if (!sel || sel.rangeCount === 0) return;
228
+ const range = sel.getRangeAt(0);
229
+ const block = closestBlock(range.startContainer, root);
230
+ if (!block) return;
231
+ if (block.tagName.toLowerCase() === tag) return;
232
+ const nb = document.createElement(tag);
233
+ while (block.firstChild) nb.appendChild(block.firstChild);
234
+ block.replaceWith(nb);
235
+ const r = document.createRange();
236
+ r.selectNodeContents(nb);
237
+ r.collapse(true);
238
+ sel.removeAllRanges();
239
+ sel.addRange(r);
240
+ }
241
+
242
+ export function setAlignment(
243
+ root: HTMLElement,
244
+ align: 'left' | 'center' | 'right' | 'justify'
245
+ ) {
246
+ const sel = document.getSelection();
247
+ if (!sel || sel.rangeCount === 0) return;
248
+ const range = sel.getRangeAt(0);
249
+
250
+ let block = closestBlock(range.startContainer, root);
251
+ if (!block) return;
252
+
253
+ if (block.tagName.toLowerCase() === 'li') {
254
+ block.style.textAlign = align;
255
+ const list = block.closest('ul,ol') as HTMLElement | null;
256
+ if (list) list.style.textAlign = align;
257
+ } else {
258
+ block.style.textAlign = align === 'justify' ? 'justify' : align;
259
+ }
260
+ }
261
+
262
+ export function setFontFamily(root: HTMLElement, family: string) {
263
+ const sel = document.getSelection();
264
+ if (!sel || sel.rangeCount === 0) return;
265
+ const range = sel.getRangeAt(0);
266
+ if (range.collapsed) {
267
+ const span = document.createElement('span');
268
+ span.style.fontFamily = family;
269
+ span.appendChild(document.createTextNode('\u200b'));
270
+ range.insertNode(span);
271
+ const r = document.createRange();
272
+ r.setStart(span.firstChild!, 1);
273
+ r.collapse(true);
274
+ sel.removeAllRanges();
275
+ sel.addRange(r);
276
+ return;
277
+ }
278
+ surroundInline(range, 'span', { style: `font-family:${family}` });
279
+ }
280
+
281
+ function enclosingStyledSpan(
282
+ editor: HTMLElement,
283
+ node: Node | null,
284
+ dataAttr: 'data-rte-color' | 'data-rte-bg'
285
+ ): HTMLSpanElement | null {
286
+ while (node && node !== editor) {
287
+ if (node instanceof HTMLSpanElement && node.hasAttribute(dataAttr)) {
288
+ return node;
289
+ }
290
+ node = node.parentNode;
291
+ }
292
+ return null;
293
+ }
294
+
295
+ function applyInlineStyle(
296
+ editor: HTMLElement,
297
+ cssProp: 'color' | 'backgroundColor',
298
+ value: string,
299
+ dataAttr: 'data-rte-color' | 'data-rte-bg'
300
+ ) {
301
+ const sel = window.getSelection();
302
+ if (!sel || sel.rangeCount === 0) return;
303
+ const r0 = sel.getRangeAt(0);
304
+ if (!editor.contains(r0.commonAncestorContainer)) return;
305
+
306
+ const range = r0.cloneRange();
307
+
308
+ if (range.collapsed) {
309
+ const enclosing = enclosingStyledSpan(
310
+ editor,
311
+ range.startContainer,
312
+ dataAttr
313
+ );
314
+ if (enclosing) {
315
+ (enclosing.style as any)[cssProp] = value;
316
+ mergeAdjacentStyledSpans(editor, dataAttr, cssProp);
317
+ return;
318
+ }
319
+
320
+ const s = document.createElement('span');
321
+ s.setAttribute(dataAttr, '1');
322
+ (s.style as any)[cssProp] = value;
323
+ s.appendChild(document.createTextNode('\u200B'));
324
+ range.insertNode(s);
325
+
326
+ const caret = document.createRange();
327
+ caret.setStart(s.firstChild!, 1);
328
+ caret.collapse(true);
329
+ sel.removeAllRanges();
330
+ sel.addRange(caret);
331
+
332
+ mergeAdjacentStyledSpans(editor, dataAttr, cssProp);
333
+ return;
334
+ }
335
+
336
+ const leftEdge = enclosingStyledSpan(editor, range.startContainer, dataAttr);
337
+ const rightEdge = enclosingStyledSpan(editor, range.endContainer, dataAttr);
338
+ if (leftEdge && leftEdge === rightEdge) {
339
+ if (rangeCoversWholeNode(range, leftEdge)) {
340
+ (leftEdge.style as any)[cssProp] = value;
341
+ } else {
342
+ const mid = splitAndRecolorWithinSpan(
343
+ leftEdge,
344
+ range,
345
+ dataAttr,
346
+ cssProp,
347
+ value
348
+ );
349
+
350
+ const sel = window.getSelection();
351
+ const r = document.createRange();
352
+ r.selectNodeContents(mid);
353
+ sel?.removeAllRanges();
354
+ sel?.addRange(r);
355
+ }
356
+ mergeAdjacentStyledSpans(editor, dataAttr, cssProp);
357
+ return;
358
+ }
359
+
360
+ const commonEl = (() => {
361
+ let n: Node | null = range.commonAncestorContainer;
362
+ while (n && !(n instanceof HTMLElement)) n = n.parentNode;
363
+ return n as HTMLElement | null;
364
+ })();
365
+
366
+ const walker = document.createTreeWalker(
367
+ commonEl || editor,
368
+ NodeFilter.SHOW_TEXT,
369
+ {
370
+ acceptNode: n => {
371
+ if (!n.nodeValue || !n.nodeValue.trim())
372
+ return NodeFilter.FILTER_REJECT;
373
+ const nodeRange = document.createRange();
374
+ nodeRange.selectNodeContents(n);
375
+ const intersects =
376
+ range.compareBoundaryPoints(Range.END_TO_START, nodeRange) < 0 &&
377
+ range.compareBoundaryPoints(Range.START_TO_END, nodeRange) > 0;
378
+ return intersects ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_REJECT;
379
+ },
380
+ }
381
+ );
382
+
383
+ const toProcess: Text[] = [];
384
+ let t: Node | null;
385
+ while ((t = walker.nextNode())) toProcess.push(t as Text);
386
+
387
+ toProcess.forEach(text => {
388
+ let start = 0,
389
+ end = text.length;
390
+ if (text === range.startContainer) start = range.startOffset;
391
+ if (text === range.endContainer) end = range.endOffset;
392
+ if (start > 0) text = text.splitText(start);
393
+ if (end < text.length) text.splitText(end);
394
+
395
+ const existing = enclosingStyledSpan(editor, text, dataAttr);
396
+ if (existing) {
397
+ (existing.style as any)[cssProp] = value;
398
+ return;
399
+ }
400
+
401
+ const span = document.createElement('span');
402
+ span.setAttribute(dataAttr, '1');
403
+ (span.style as any)[cssProp] = value;
404
+ const parent = text.parentElement!;
405
+ parent.replaceChild(span, text);
406
+ span.appendChild(text);
407
+ });
408
+
409
+ mergeAdjacentStyledSpans(editor, dataAttr, cssProp);
410
+
411
+ // restore selection
412
+ sel.removeAllRanges();
413
+ sel.addRange(range);
414
+ }
415
+
416
+ // Is the range covering the entire node's contents?
417
+ function rangeCoversWholeNode(range: Range, node: Node): boolean {
418
+ const all = document.createRange();
419
+ all.selectNodeContents(node);
420
+ return (
421
+ range.compareBoundaryPoints(Range.START_TO_START, all) <= 0 &&
422
+ range.compareBoundaryPoints(Range.END_TO_END, all) >= 0
423
+ );
424
+ }
425
+
426
+ function hasRangeContent(r: Range): boolean {
427
+ if (r.collapsed) return false;
428
+ const text = r.cloneContents().textContent || '';
429
+ return text.length > 0;
430
+ }
431
+
432
+ // Split one styled span into [left][middle][right]; recolor only middle
433
+ function splitAndRecolorWithinSpan(
434
+ span: HTMLSpanElement,
435
+ range: Range,
436
+ dataAttr: 'data-rte-color' | 'data-rte-bg',
437
+ cssProp: 'color' | 'backgroundColor',
438
+ newValue: string
439
+ ): HTMLSpanElement {
440
+ const oldValue = (span.style as any)[cssProp];
441
+
442
+ const left = document.createRange();
443
+ left.setStart(span, 0);
444
+ left.setEnd(range.startContainer, range.startOffset);
445
+
446
+ const right = document.createRange();
447
+ right.setStart(range.endContainer, range.endOffset);
448
+ right.setEnd(span, span.childNodes.length);
449
+
450
+ // Build replacement fragment
451
+ const frag = document.createDocumentFragment();
452
+
453
+ // helper to make a styled clone shell
454
+ const makeShell = (val: string) => {
455
+ const s = document.createElement('span');
456
+ s.setAttribute(dataAttr, '1');
457
+ (s.style as any)[cssProp] = val;
458
+ return s;
459
+ };
460
+
461
+ if (hasRangeContent(left)) {
462
+ const sLeft = makeShell(oldValue);
463
+ sLeft.appendChild(left.cloneContents());
464
+ frag.appendChild(sLeft);
465
+ }
466
+
467
+ const mid = makeShell(newValue);
468
+ mid.appendChild(range.cloneContents());
469
+ frag.appendChild(mid);
470
+
471
+ if (hasRangeContent(right)) {
472
+ const sRight = makeShell(oldValue);
473
+ sRight.appendChild(right.cloneContents());
474
+ frag.appendChild(sRight);
475
+ }
476
+
477
+ span.replaceWith(frag);
478
+ return mid;
479
+ }
480
+
481
+ function mergeAdjacentStyledSpans(
482
+ root: HTMLElement,
483
+ dataAttr: 'data-rte-color' | 'data-rte-bg',
484
+ cssProp: 'color' | 'backgroundColor'
485
+ ) {
486
+ const spans = Array.from(
487
+ root.querySelectorAll<HTMLSpanElement>(`span[${dataAttr}]`)
488
+ );
489
+
490
+ const valOf = (el: HTMLElement) => (el.style as any)[cssProp];
491
+
492
+ spans.forEach(s => {
493
+ const nested = Array.from(
494
+ s.querySelectorAll<HTMLSpanElement>(`span[${dataAttr}]`)
495
+ );
496
+ nested.forEach(child => {
497
+ if (valOf(child) === valOf(s)) {
498
+ while (child.firstChild) s.insertBefore(child.firstChild, child);
499
+ child.remove();
500
+ }
501
+ });
502
+
503
+ const prev = s.previousSibling;
504
+ if (
505
+ prev instanceof HTMLSpanElement &&
506
+ prev.hasAttribute(dataAttr) &&
507
+ valOf(prev) === valOf(s)
508
+ ) {
509
+ while (s.firstChild) prev.appendChild(s.firstChild);
510
+ s.remove();
511
+ return;
512
+ }
513
+
514
+ const next = s.nextSibling;
515
+ if (
516
+ next instanceof HTMLSpanElement &&
517
+ next.hasAttribute(dataAttr) &&
518
+ valOf(next) === valOf(s)
519
+ ) {
520
+ while (next.firstChild) s.appendChild(next.firstChild);
521
+ next.remove();
522
+ }
523
+ });
524
+ }
525
+
526
+ export function setForeColor(editor: HTMLElement, hex: string) {
527
+ applyInlineStyle(editor, 'color', hex, 'data-rte-color');
528
+ }
529
+ export function setBackColor(editor: HTMLElement, hex: string) {
530
+ applyInlineStyle(editor, 'backgroundColor', hex, 'data-rte-bg');
531
+ }
532
+
533
+ export function toggleList(root: HTMLElement, kind: 'ul' | 'ol') {
534
+ const sel = document.getSelection();
535
+ if (!sel || sel.rangeCount === 0) return;
536
+ const range = sel.getRangeAt(0);
537
+
538
+ const blocks: HTMLElement[] = [];
539
+ const walker = document.createTreeWalker(root, NodeFilter.SHOW_ELEMENT, {
540
+ acceptNode: n => {
541
+ if (!(n instanceof HTMLElement)) return NodeFilter.FILTER_SKIP;
542
+ if (!/^(P|DIV|LI|H[1-6])$/.test(n.tagName)) return NodeFilter.FILTER_SKIP;
543
+
544
+ const r = document.createRange();
545
+ r.selectNodeContents(n);
546
+ const intersects =
547
+ range.compareBoundaryPoints(Range.END_TO_START, r) < 0 &&
548
+ range.compareBoundaryPoints(Range.START_TO_END, r) > 0;
549
+ return intersects ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_REJECT;
550
+ },
551
+ });
552
+
553
+ let n: Node | null;
554
+ while ((n = walker.nextNode())) {
555
+ blocks.push(n as HTMLElement);
556
+ }
557
+
558
+ if (blocks.length === 0) {
559
+ const block = closestBlock(range.startContainer, root);
560
+ if (block) blocks.push(block);
561
+ }
562
+
563
+ const firstLi = blocks[0].closest('li');
564
+ if (firstLi) {
565
+ const currentList = firstLi.closest('ul,ol') as HTMLElement | null;
566
+ if (!currentList) return;
567
+
568
+ if (currentList.tagName.toLowerCase() === kind) {
569
+ const frag = document.createDocumentFragment();
570
+ for (const li of Array.from(currentList.querySelectorAll('li'))) {
571
+ const p = document.createElement('p');
572
+ while (li.firstChild) p.appendChild(li.firstChild);
573
+ frag.appendChild(p);
574
+ }
575
+ currentList.replaceWith(frag);
576
+ } else {
577
+ const newList = document.createElement(kind);
578
+ while (currentList.firstChild)
579
+ newList.appendChild(currentList.firstChild);
580
+ currentList.replaceWith(newList);
581
+ }
582
+ return;
583
+ }
584
+
585
+ const newList = document.createElement(kind);
586
+ for (const block of blocks) {
587
+ const li = document.createElement('li');
588
+ while (block.firstChild) li.appendChild(block.firstChild);
589
+ newList.appendChild(li);
590
+ block.replaceWith(newList);
591
+ }
592
+ }
593
+
594
+ export function insertOrEditLink(root: HTMLElement, href?: string) {
595
+ const sel = document.getSelection();
596
+ if (!sel || sel.rangeCount === 0) return;
597
+ const range = sel.getRangeAt(0);
598
+
599
+ let n: Node | null = range.startContainer;
600
+ let a: HTMLAnchorElement | null = null;
601
+ while (n && n !== root) {
602
+ if (n instanceof HTMLAnchorElement) {
603
+ a = n;
604
+ break;
605
+ }
606
+ n = n.parentNode;
607
+ }
608
+
609
+ const url =
610
+ href ??
611
+ (typeof window !== 'undefined'
612
+ ? window.prompt('Enter URL', a?.href || 'https://') || ''
613
+ : '');
614
+ if (!url) return;
615
+
616
+ if (a) {
617
+ a.href = url;
618
+ return;
619
+ }
620
+
621
+ if (range.collapsed) {
622
+ const link = document.createElement('a');
623
+ link.href = url;
624
+ link.textContent = url;
625
+ range.insertNode(link);
626
+ const r = document.createRange();
627
+ r.setStartAfter(link);
628
+ r.collapse(true);
629
+ sel.removeAllRanges();
630
+ sel.addRange(r);
631
+ return;
632
+ }
633
+
634
+ const link = document.createElement('a');
635
+ link.href = url;
636
+ try {
637
+ range.surroundContents(link);
638
+ } catch {
639
+ const frag = range.extractContents();
640
+ link.appendChild(frag);
641
+ range.insertNode(link);
642
+ }
643
+ }