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