@byline/richtext-lexical 0.9.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (655) hide show
  1. package/LICENSE +373 -0
  2. package/README.md +18 -0
  3. package/dist/field/apply-value-plugin.d.ts +10 -0
  4. package/dist/field/apply-value-plugin.d.ts.map +1 -0
  5. package/dist/field/apply-value-plugin.js +60 -0
  6. package/dist/field/config/default.d.ts +6 -0
  7. package/dist/field/config/default.d.ts.map +1 -0
  8. package/dist/field/config/default.js +53 -0
  9. package/dist/field/config/editor-config-context.d.ts +14 -0
  10. package/dist/field/config/editor-config-context.d.ts.map +1 -0
  11. package/dist/field/config/editor-config-context.js +51 -0
  12. package/dist/field/config/types.d.ts +28 -0
  13. package/dist/field/config/types.d.ts.map +1 -0
  14. package/dist/field/config/types.js +1 -0
  15. package/dist/field/constants.d.ts +2 -0
  16. package/dist/field/constants.d.ts.map +1 -0
  17. package/dist/field/constants.js +2 -0
  18. package/dist/field/content-editable-inline.d.ts +13 -0
  19. package/dist/field/content-editable-inline.d.ts.map +1 -0
  20. package/dist/field/content-editable-inline.js +11 -0
  21. package/dist/field/content-editable.css +23 -0
  22. package/dist/field/content-editable.d.ts +13 -0
  23. package/dist/field/content-editable.d.ts.map +1 -0
  24. package/dist/field/content-editable.js +14 -0
  25. package/dist/field/context/shared-autocomplete-context.js +44 -0
  26. package/dist/field/context/shared-history-context.d.ts +19 -0
  27. package/dist/field/context/shared-history-context.d.ts.map +1 -0
  28. package/dist/field/context/shared-history-context.js +16 -0
  29. package/dist/field/context/shared-on-change-context.d.ts +13 -0
  30. package/dist/field/context/shared-on-change-context.d.ts.map +1 -0
  31. package/dist/field/context/shared-on-change-context.js +21 -0
  32. package/dist/field/debug.d.ts +10 -0
  33. package/dist/field/debug.d.ts.map +1 -0
  34. package/dist/field/debug.js +30 -0
  35. package/dist/field/editor-component.css +33 -0
  36. package/dist/field/editor-component.d.ts +13 -0
  37. package/dist/field/editor-component.d.ts.map +1 -0
  38. package/dist/field/editor-component.js +115 -0
  39. package/dist/field/editor-context.d.ts +23 -0
  40. package/dist/field/editor-context.d.ts.map +1 -0
  41. package/dist/field/editor-context.js +57 -0
  42. package/dist/field/editor-field.d.ts +34 -0
  43. package/dist/field/editor-field.d.ts.map +1 -0
  44. package/dist/field/editor-field.js +18 -0
  45. package/dist/field/editor.css +1449 -0
  46. package/dist/field/editor.d.ts +14 -0
  47. package/dist/field/editor.d.ts.map +1 -0
  48. package/dist/field/editor.js +190 -0
  49. package/dist/field/hooks/use-modal.d.ts +13 -0
  50. package/dist/field/hooks/use-modal.d.ts.map +1 -0
  51. package/dist/field/hooks/use-modal.js +37 -0
  52. package/dist/field/hooks/use-report.js +39 -0
  53. package/dist/field/lexical-populate-shared.d.ts +97 -0
  54. package/dist/field/lexical-populate-shared.d.ts.map +1 -0
  55. package/dist/field/lexical-populate-shared.js +60 -0
  56. package/dist/field/nodes/admonition-node/admonition-node-component.css +119 -0
  57. package/dist/field/nodes/admonition-node/admonition-node-component.d.ts +18 -0
  58. package/dist/field/nodes/admonition-node/admonition-node-component.d.ts.map +1 -0
  59. package/dist/field/nodes/admonition-node/admonition-node-component.js +190 -0
  60. package/dist/field/nodes/admonition-node/admonition-node.d.ts +35 -0
  61. package/dist/field/nodes/admonition-node/admonition-node.d.ts.map +1 -0
  62. package/dist/field/nodes/admonition-node/admonition-node.js +129 -0
  63. package/dist/field/nodes/admonition-node/icons/danger-icon.css +12 -0
  64. package/dist/field/nodes/admonition-node/icons/danger-icon.d.ts +8 -0
  65. package/dist/field/nodes/admonition-node/icons/danger-icon.d.ts.map +1 -0
  66. package/dist/field/nodes/admonition-node/icons/danger-icon.js +18 -0
  67. package/dist/field/nodes/admonition-node/icons/index.d.ts +5 -0
  68. package/dist/field/nodes/admonition-node/icons/index.d.ts.map +1 -0
  69. package/dist/field/nodes/admonition-node/icons/index.js +4 -0
  70. package/dist/field/nodes/admonition-node/icons/note-icon.css +12 -0
  71. package/dist/field/nodes/admonition-node/icons/note-icon.d.ts +8 -0
  72. package/dist/field/nodes/admonition-node/icons/note-icon.d.ts.map +1 -0
  73. package/dist/field/nodes/admonition-node/icons/note-icon.js +18 -0
  74. package/dist/field/nodes/admonition-node/icons/tip-icon.css +12 -0
  75. package/dist/field/nodes/admonition-node/icons/tip-icon.d.ts +8 -0
  76. package/dist/field/nodes/admonition-node/icons/tip-icon.d.ts.map +1 -0
  77. package/dist/field/nodes/admonition-node/icons/tip-icon.js +18 -0
  78. package/dist/field/nodes/admonition-node/icons/warning-icon.css +12 -0
  79. package/dist/field/nodes/admonition-node/icons/warning-icon.d.ts +8 -0
  80. package/dist/field/nodes/admonition-node/icons/warning-icon.d.ts.map +1 -0
  81. package/dist/field/nodes/admonition-node/icons/warning-icon.js +18 -0
  82. package/dist/field/nodes/admonition-node/index.d.ts +10 -0
  83. package/dist/field/nodes/admonition-node/index.d.ts.map +1 -0
  84. package/dist/field/nodes/admonition-node/index.js +2 -0
  85. package/dist/field/nodes/admonition-node/types.d.ts +21 -0
  86. package/dist/field/nodes/admonition-node/types.d.ts.map +1 -0
  87. package/dist/field/nodes/admonition-node/types.js +1 -0
  88. package/dist/field/nodes/document-relation.d.ts +33 -0
  89. package/dist/field/nodes/document-relation.d.ts.map +1 -0
  90. package/dist/field/nodes/document-relation.js +1 -0
  91. package/dist/field/nodes/index.d.ts +10 -0
  92. package/dist/field/nodes/index.d.ts.map +1 -0
  93. package/dist/field/nodes/index.js +37 -0
  94. package/dist/field/nodes/inline-image-node/index.d.ts +10 -0
  95. package/dist/field/nodes/inline-image-node/index.d.ts.map +1 -0
  96. package/dist/field/nodes/inline-image-node/index.js +2 -0
  97. package/dist/field/nodes/inline-image-node/inline-image-node-component.css +204 -0
  98. package/dist/field/nodes/inline-image-node/inline-image-node-component.d.ts +24 -0
  99. package/dist/field/nodes/inline-image-node/inline-image-node-component.d.ts.map +1 -0
  100. package/dist/field/nodes/inline-image-node/inline-image-node-component.js +221 -0
  101. package/dist/field/nodes/inline-image-node/inline-image-node.d.ts +45 -0
  102. package/dist/field/nodes/inline-image-node/inline-image-node.d.ts.map +1 -0
  103. package/dist/field/nodes/inline-image-node/inline-image-node.js +187 -0
  104. package/dist/field/nodes/inline-image-node/types.d.ts +30 -0
  105. package/dist/field/nodes/inline-image-node/types.d.ts.map +1 -0
  106. package/dist/field/nodes/inline-image-node/types.js +1 -0
  107. package/dist/field/nodes/layout-container-node/layout-container-node.d.ts +29 -0
  108. package/dist/field/nodes/layout-container-node/layout-container-node.d.ts.map +1 -0
  109. package/dist/field/nodes/layout-container-node/layout-container-node.js +54 -0
  110. package/dist/field/nodes/layout-container-node/layout-item-node.d.ts +23 -0
  111. package/dist/field/nodes/layout-container-node/layout-item-node.d.ts.map +1 -0
  112. package/dist/field/nodes/layout-container-node/layout-item-node.js +41 -0
  113. package/dist/field/nodes/link-nodes/auto-link-node.d.ts +17 -0
  114. package/dist/field/nodes/link-nodes/auto-link-node.d.ts.map +1 -0
  115. package/dist/field/nodes/link-nodes/auto-link-node.js +52 -0
  116. package/dist/field/nodes/link-nodes/index.d.ts +4 -0
  117. package/dist/field/nodes/link-nodes/index.d.ts.map +1 -0
  118. package/dist/field/nodes/link-nodes/index.js +3 -0
  119. package/dist/field/nodes/link-nodes/link-node.d.ts +49 -0
  120. package/dist/field/nodes/link-nodes/link-node.d.ts.map +1 -0
  121. package/dist/field/nodes/link-nodes/link-node.js +253 -0
  122. package/dist/field/nodes/link-nodes/types.d.ts +26 -0
  123. package/dist/field/nodes/link-nodes/types.d.ts.map +1 -0
  124. package/dist/field/nodes/link-nodes/types.js +1 -0
  125. package/dist/field/nodes/vimeo-node/index.d.ts +30 -0
  126. package/dist/field/nodes/vimeo-node/index.d.ts.map +1 -0
  127. package/dist/field/nodes/vimeo-node/index.js +109 -0
  128. package/dist/field/nodes/youtube-node/index.d.ts +30 -0
  129. package/dist/field/nodes/youtube-node/index.d.ts.map +1 -0
  130. package/dist/field/nodes/youtube-node/index.js +110 -0
  131. package/dist/field/plugins/admonition-plugin/admonition-modal.css +26 -0
  132. package/dist/field/plugins/admonition-plugin/admonition-modal.d.ts +12 -0
  133. package/dist/field/plugins/admonition-plugin/admonition-modal.d.ts.map +1 -0
  134. package/dist/field/plugins/admonition-plugin/admonition-modal.js +165 -0
  135. package/dist/field/plugins/admonition-plugin/fields.d.ts +21 -0
  136. package/dist/field/plugins/admonition-plugin/fields.d.ts.map +1 -0
  137. package/dist/field/plugins/admonition-plugin/fields.js +55 -0
  138. package/dist/field/plugins/admonition-plugin/index.d.ts +15 -0
  139. package/dist/field/plugins/admonition-plugin/index.d.ts.map +1 -0
  140. package/dist/field/plugins/admonition-plugin/index.js +54 -0
  141. package/dist/field/plugins/admonition-plugin/types.d.ts +34 -0
  142. package/dist/field/plugins/admonition-plugin/types.d.ts.map +1 -0
  143. package/dist/field/plugins/admonition-plugin/types.js +1 -0
  144. package/dist/field/plugins/auto-embed-plugin/auto-embed-modal.css +16 -0
  145. package/dist/field/plugins/auto-embed-plugin/auto-embed-modal.d.ts +8 -0
  146. package/dist/field/plugins/auto-embed-plugin/auto-embed-modal.d.ts.map +1 -0
  147. package/dist/field/plugins/auto-embed-plugin/auto-embed-modal.js +105 -0
  148. package/dist/field/plugins/auto-embed-plugin/index.d.ts +21 -0
  149. package/dist/field/plugins/auto-embed-plugin/index.d.ts.map +1 -0
  150. package/dist/field/plugins/auto-embed-plugin/index.js +152 -0
  151. package/dist/field/plugins/code-highlight-plugin/index.d.ts +10 -0
  152. package/dist/field/plugins/code-highlight-plugin/index.d.ts.map +1 -0
  153. package/dist/field/plugins/code-highlight-plugin/index.js +11 -0
  154. package/dist/field/plugins/drag-drop-paste-plugin/index.js +1 -0
  155. package/dist/field/plugins/floating-text-format-toolbar-plugin/index.css +148 -0
  156. package/dist/field/plugins/floating-text-format-toolbar-plugin/index.d.ts +13 -0
  157. package/dist/field/plugins/floating-text-format-toolbar-plugin/index.d.ts.map +1 -0
  158. package/dist/field/plugins/floating-text-format-toolbar-plugin/index.js +279 -0
  159. package/dist/field/plugins/inline-image-plugin/fields.d.ts +12 -0
  160. package/dist/field/plugins/inline-image-plugin/fields.d.ts.map +1 -0
  161. package/dist/field/plugins/inline-image-plugin/fields.js +22 -0
  162. package/dist/field/plugins/inline-image-plugin/index.d.ts +34 -0
  163. package/dist/field/plugins/inline-image-plugin/index.d.ts.map +1 -0
  164. package/dist/field/plugins/inline-image-plugin/index.js +107 -0
  165. package/dist/field/plugins/inline-image-plugin/inline-image-modal.css +25 -0
  166. package/dist/field/plugins/inline-image-plugin/inline-image-modal.d.ts +11 -0
  167. package/dist/field/plugins/inline-image-plugin/inline-image-modal.d.ts.map +1 -0
  168. package/dist/field/plugins/inline-image-plugin/inline-image-modal.js +271 -0
  169. package/dist/field/plugins/inline-image-plugin/populate.d.ts +10 -0
  170. package/dist/field/plugins/inline-image-plugin/populate.d.ts.map +1 -0
  171. package/dist/field/plugins/inline-image-plugin/populate.js +28 -0
  172. package/dist/field/plugins/inline-image-plugin/types.d.ts +37 -0
  173. package/dist/field/plugins/inline-image-plugin/types.d.ts.map +1 -0
  174. package/dist/field/plugins/inline-image-plugin/types.js +1 -0
  175. package/dist/field/plugins/inline-image-plugin/utils.d.ts +42 -0
  176. package/dist/field/plugins/inline-image-plugin/utils.d.ts.map +1 -0
  177. package/dist/field/plugins/inline-image-plugin/utils.js +46 -0
  178. package/dist/field/plugins/layout-plugin/insert-layout-modal.css +20 -0
  179. package/dist/field/plugins/layout-plugin/insert-layout-modal.d.ts +22 -0
  180. package/dist/field/plugins/layout-plugin/insert-layout-modal.d.ts.map +1 -0
  181. package/dist/field/plugins/layout-plugin/insert-layout-modal.js +97 -0
  182. package/dist/field/plugins/layout-plugin/layout-plugin.d.ts +10 -0
  183. package/dist/field/plugins/layout-plugin/layout-plugin.d.ts.map +1 -0
  184. package/dist/field/plugins/layout-plugin/layout-plugin.js +81 -0
  185. package/dist/field/plugins/link-plugin/auto-link/auto-link-plugin.d.ts +22 -0
  186. package/dist/field/plugins/link-plugin/auto-link/auto-link-plugin.d.ts.map +1 -0
  187. package/dist/field/plugins/link-plugin/auto-link/auto-link-plugin.js +185 -0
  188. package/dist/field/plugins/link-plugin/auto-link/index.d.ts +10 -0
  189. package/dist/field/plugins/link-plugin/auto-link/index.d.ts.map +1 -0
  190. package/dist/field/plugins/link-plugin/auto-link/index.js +15 -0
  191. package/dist/field/plugins/link-plugin/link/floating-link-editor.css +124 -0
  192. package/dist/field/plugins/link-plugin/link/floating-link-editor.d.ts +15 -0
  193. package/dist/field/plugins/link-plugin/link/floating-link-editor.d.ts.map +1 -0
  194. package/dist/field/plugins/link-plugin/link/floating-link-editor.js +234 -0
  195. package/dist/field/plugins/link-plugin/link/index.d.ts +2 -0
  196. package/dist/field/plugins/link-plugin/link/index.d.ts.map +1 -0
  197. package/dist/field/plugins/link-plugin/link/index.js +43 -0
  198. package/dist/field/plugins/link-plugin/link/link-modal.d.ts +11 -0
  199. package/dist/field/plugins/link-plugin/link/link-modal.d.ts.map +1 -0
  200. package/dist/field/plugins/link-plugin/link/link-modal.js +311 -0
  201. package/dist/field/plugins/link-plugin/link/types.d.ts +19 -0
  202. package/dist/field/plugins/link-plugin/link/types.d.ts.map +1 -0
  203. package/dist/field/plugins/link-plugin/link/types.js +1 -0
  204. package/dist/field/plugins/link-plugin/populate.d.ts +22 -0
  205. package/dist/field/plugins/link-plugin/populate.d.ts.map +1 -0
  206. package/dist/field/plugins/link-plugin/populate.js +28 -0
  207. package/dist/field/plugins/table-action-menu-plugin/index.d.ts +6 -0
  208. package/dist/field/plugins/table-action-menu-plugin/index.d.ts.map +1 -0
  209. package/dist/field/plugins/table-action-menu-plugin/index.js +598 -0
  210. package/dist/field/plugins/table-plugin/index.d.ts +4 -0
  211. package/dist/field/plugins/table-plugin/index.d.ts.map +1 -0
  212. package/dist/field/plugins/table-plugin/index.js +26 -0
  213. package/dist/field/plugins/table-plugin/table-modal.css +20 -0
  214. package/dist/field/plugins/table-plugin/table-modal.d.ts +21 -0
  215. package/dist/field/plugins/table-plugin/table-modal.d.ts.map +1 -0
  216. package/dist/field/plugins/table-plugin/table-modal.js +111 -0
  217. package/dist/field/plugins/toolbar-plugin/index.d.ts +17 -0
  218. package/dist/field/plugins/toolbar-plugin/index.d.ts.map +1 -0
  219. package/dist/field/plugins/toolbar-plugin/index.js +837 -0
  220. package/dist/field/plugins/treeview-plugin/index.d.ts +10 -0
  221. package/dist/field/plugins/treeview-plugin/index.d.ts.map +1 -0
  222. package/dist/field/plugins/treeview-plugin/index.js +17 -0
  223. package/dist/field/plugins/vimeo-plugin/index.d.ts +4 -0
  224. package/dist/field/plugins/vimeo-plugin/index.d.ts.map +1 -0
  225. package/dist/field/plugins/vimeo-plugin/index.js +24 -0
  226. package/dist/field/plugins/youtube-plugin/index.d.ts +4 -0
  227. package/dist/field/plugins/youtube-plugin/index.d.ts.map +1 -0
  228. package/dist/field/plugins/youtube-plugin/index.js +24 -0
  229. package/dist/field/shared/canUseDOM.d.ts +9 -0
  230. package/dist/field/shared/canUseDOM.d.ts.map +1 -0
  231. package/dist/field/shared/canUseDOM.js +2 -0
  232. package/dist/field/shared/environment.d.ts +23 -0
  233. package/dist/field/shared/environment.d.ts.map +1 -0
  234. package/dist/field/shared/environment.js +10 -0
  235. package/dist/field/shared/invariant.d.ts +9 -0
  236. package/dist/field/shared/invariant.d.ts.map +1 -0
  237. package/dist/field/shared/invariant.js +6 -0
  238. package/dist/field/shared/simpleDiffWithCursor.js +15 -0
  239. package/dist/field/shared/useLayoutEffect.js +5 -0
  240. package/dist/field/shared/useModalFormState.d.ts +23 -0
  241. package/dist/field/shared/useModalFormState.d.ts.map +1 -0
  242. package/dist/field/shared/useModalFormState.js +23 -0
  243. package/dist/field/shared/warnOnlyOnce.js +9 -0
  244. package/dist/field/themes/lexical-editor-theme.css +537 -0
  245. package/dist/field/themes/lexical-editor-theme.d.ts +10 -0
  246. package/dist/field/themes/lexical-editor-theme.d.ts.map +1 -0
  247. package/dist/field/themes/lexical-editor-theme.js +105 -0
  248. package/dist/field/toolbar-extensions.d.ts +32 -0
  249. package/dist/field/toolbar-extensions.d.ts.map +1 -0
  250. package/dist/field/toolbar-extensions.js +56 -0
  251. package/dist/field/types.js +1 -0
  252. package/dist/field/ui/button.css +31 -0
  253. package/dist/field/ui/button.js +19 -0
  254. package/dist/field/ui/checkbox.css +46 -0
  255. package/dist/field/ui/color-picker.css +75 -0
  256. package/dist/field/ui/color-picker.d.ts +21 -0
  257. package/dist/field/ui/color-picker.d.ts.map +1 -0
  258. package/dist/field/ui/color-picker.js +360 -0
  259. package/dist/field/ui/dialog.css +18 -0
  260. package/dist/field/ui/dialog.js +17 -0
  261. package/dist/field/ui/dropdown.d.ts +25 -0
  262. package/dist/field/ui/dropdown.d.ts.map +1 -0
  263. package/dist/field/ui/dropdown.js +150 -0
  264. package/dist/field/ui/file-input.js +27 -0
  265. package/dist/field/ui/input.css +23 -0
  266. package/dist/field/ui/modal.css +73 -0
  267. package/dist/field/ui/modal.d.ts +17 -0
  268. package/dist/field/ui/modal.d.ts.map +1 -0
  269. package/dist/field/ui/modal.js +69 -0
  270. package/dist/field/ui/placeholder-inline.d.ts +14 -0
  271. package/dist/field/ui/placeholder-inline.d.ts.map +1 -0
  272. package/dist/field/ui/placeholder-inline.js +12 -0
  273. package/dist/field/ui/placeholder.css +26 -0
  274. package/dist/field/ui/placeholder.d.ts +14 -0
  275. package/dist/field/ui/placeholder.d.ts.map +1 -0
  276. package/dist/field/ui/placeholder.js +14 -0
  277. package/dist/field/ui/select.css +32 -0
  278. package/dist/field/ui/select.js +28 -0
  279. package/dist/field/ui/switch.js +25 -0
  280. package/dist/field/ui/text-area.css +31 -0
  281. package/dist/field/ui/text-area.js +28 -0
  282. package/dist/field/ui/text-input.d.ts +20 -0
  283. package/dist/field/ui/text-input.d.ts.map +1 -0
  284. package/dist/field/ui/text-input.js +29 -0
  285. package/dist/field/utils/cloneDeep.js +26 -0
  286. package/dist/field/utils/deepEqual.js +19 -0
  287. package/dist/field/utils/emoji-list.js +21389 -0
  288. package/dist/field/utils/getDOMRangeRect.d.ts +9 -0
  289. package/dist/field/utils/getDOMRangeRect.d.ts.map +1 -0
  290. package/dist/field/utils/getDOMRangeRect.js +11 -0
  291. package/dist/field/utils/getSelectedNode.d.ts +3 -0
  292. package/dist/field/utils/getSelectedNode.d.ts.map +1 -0
  293. package/dist/field/utils/getSelectedNode.js +12 -0
  294. package/dist/field/utils/guard.js +4 -0
  295. package/dist/field/utils/hashSerializedState.d.ts +3 -0
  296. package/dist/field/utils/hashSerializedState.d.ts.map +1 -0
  297. package/dist/field/utils/hashSerializedState.js +22 -0
  298. package/dist/field/utils/isMobileWidth.js +1 -0
  299. package/dist/field/utils/joinClasses.js +4 -0
  300. package/dist/field/utils/point.js +34 -0
  301. package/dist/field/utils/rect.js +95 -0
  302. package/dist/field/utils/setFloatingElemPosition.d.ts +2 -0
  303. package/dist/field/utils/setFloatingElemPosition.d.ts.map +1 -0
  304. package/dist/field/utils/setFloatingElemPosition.js +22 -0
  305. package/dist/field/utils/setFloatingElemPositionForLinkEditor.d.ts +2 -0
  306. package/dist/field/utils/setFloatingElemPositionForLinkEditor.d.ts.map +1 -0
  307. package/dist/field/utils/setFloatingElemPositionForLinkEditor.js +22 -0
  308. package/dist/field/utils/swipe.js +77 -0
  309. package/dist/field/utils/url.d.ts +11 -0
  310. package/dist/field/utils/url.d.ts.map +1 -0
  311. package/dist/field/utils/url.js +30 -0
  312. package/dist/index.d.ts +12 -0
  313. package/dist/index.d.ts.map +1 -0
  314. package/dist/index.js +7 -0
  315. package/dist/lexical-editor.d.ts +41 -0
  316. package/dist/lexical-editor.d.ts.map +1 -0
  317. package/dist/lexical-editor.js +13 -0
  318. package/dist/richtext-field.d.ts +25 -0
  319. package/dist/richtext-field.d.ts.map +1 -0
  320. package/dist/richtext-field.js +62 -0
  321. package/dist/richtext-field.module.js +8 -0
  322. package/dist/richtext-field_module.css +18 -0
  323. package/dist/server.d.ts +64 -0
  324. package/dist/server.d.ts.map +1 -0
  325. package/dist/server.js +20 -0
  326. package/dist/static/svg/3-columns.svg +3 -0
  327. package/dist/static/svg/admonition.svg +1 -0
  328. package/dist/static/svg/ai.svg +5 -0
  329. package/dist/static/svg/arrow-clockwise.svg +1 -0
  330. package/dist/static/svg/arrow-counterclockwise.svg +1 -0
  331. package/dist/static/svg/bg-color.svg +1 -0
  332. package/dist/static/svg/camera.svg +1 -0
  333. package/dist/static/svg/caret-right-fill.svg +1 -0
  334. package/dist/static/svg/chat-square-quote.svg +1 -0
  335. package/dist/static/svg/chevron-down.svg +1 -0
  336. package/dist/static/svg/clipboard.svg +1 -0
  337. package/dist/static/svg/close.svg +1 -0
  338. package/dist/static/svg/code.svg +1 -0
  339. package/dist/static/svg/copy.svg +1 -0
  340. package/dist/static/svg/diagram-2.svg +1 -0
  341. package/dist/static/svg/download.svg +1 -0
  342. package/dist/static/svg/dropdown-more.svg +1 -0
  343. package/dist/static/svg/file-image.svg +1 -0
  344. package/dist/static/svg/filetype-gif.svg +1 -0
  345. package/dist/static/svg/font-color.svg +1 -0
  346. package/dist/static/svg/font-family.svg +1 -0
  347. package/dist/static/svg/gear.svg +1 -0
  348. package/dist/static/svg/horizontal-rule.svg +1 -0
  349. package/dist/static/svg/indent.svg +1 -0
  350. package/dist/static/svg/journal-code.svg +1 -0
  351. package/dist/static/svg/justify.svg +1 -0
  352. package/dist/static/svg/link.svg +1 -0
  353. package/dist/static/svg/list-ol.svg +1 -0
  354. package/dist/static/svg/list-ul.svg +1 -0
  355. package/dist/static/svg/lock-fill.svg +1 -0
  356. package/dist/static/svg/lock.svg +1 -0
  357. package/dist/static/svg/markdown.svg +1 -0
  358. package/dist/static/svg/mic.svg +1 -0
  359. package/dist/static/svg/outdent.svg +1 -0
  360. package/dist/static/svg/paint-bucket.svg +1 -0
  361. package/dist/static/svg/palette.svg +1 -0
  362. package/dist/static/svg/pencil-fill.svg +1 -0
  363. package/dist/static/svg/plug-fill.svg +1 -0
  364. package/dist/static/svg/plug.svg +1 -0
  365. package/dist/static/svg/plus.svg +1 -0
  366. package/dist/static/svg/prettier-error.svg +1 -0
  367. package/dist/static/svg/prettier.svg +1 -0
  368. package/dist/static/svg/square-check.svg +1 -0
  369. package/dist/static/svg/success.svg +1 -0
  370. package/dist/static/svg/table.svg +1 -0
  371. package/dist/static/svg/text-center.svg +1 -0
  372. package/dist/static/svg/text-left.svg +1 -0
  373. package/dist/static/svg/text-paragraph.svg +1 -0
  374. package/dist/static/svg/text-right.svg +1 -0
  375. package/dist/static/svg/trash.svg +1 -0
  376. package/dist/static/svg/type-bold.svg +1 -0
  377. package/dist/static/svg/type-h1.svg +1 -0
  378. package/dist/static/svg/type-h2.svg +1 -0
  379. package/dist/static/svg/type-h3.svg +1 -0
  380. package/dist/static/svg/type-h4.svg +1 -0
  381. package/dist/static/svg/type-h5.svg +1 -0
  382. package/dist/static/svg/type-h6.svg +1 -0
  383. package/dist/static/svg/type-italic.svg +1 -0
  384. package/dist/static/svg/type-strikethrough.svg +1 -0
  385. package/dist/static/svg/type-subscript.svg +1 -0
  386. package/dist/static/svg/type-superscript.svg +1 -0
  387. package/dist/static/svg/type-underline.svg +1 -0
  388. package/dist/static/svg/upload.svg +1 -0
  389. package/dist/static/svg/user.svg +1 -0
  390. package/dist/static/svg/vimeo.svg +1 -0
  391. package/dist/static/svg/youtube.svg +1 -0
  392. package/dist/types.d.ts +37 -0
  393. package/dist/types.d.ts.map +1 -0
  394. package/dist/types.js +1 -0
  395. package/dist/validate/createEmptyEditorState.d.ts +25 -0
  396. package/dist/validate/createEmptyEditorState.d.ts.map +1 -0
  397. package/dist/validate/createEmptyEditorState.js +26 -0
  398. package/dist/validate/hasText.d.ts +3 -0
  399. package/dist/validate/hasText.d.ts.map +1 -0
  400. package/dist/validate/hasText.js +20 -0
  401. package/dist/validate/validate.d.ts +5 -0
  402. package/dist/validate/validate.d.ts.map +1 -0
  403. package/dist/validate/validate.js +7 -0
  404. package/package.json +120 -0
  405. package/src/declarations.d.ts +4 -0
  406. package/src/field/apply-value-plugin.tsx +104 -0
  407. package/src/field/config/default.ts +58 -0
  408. package/src/field/config/editor-config-context.tsx +60 -0
  409. package/src/field/config/types.ts +67 -0
  410. package/src/field/constants.ts +1 -0
  411. package/src/field/content-editable-inline.tsx +27 -0
  412. package/src/field/content-editable.css +29 -0
  413. package/src/field/content-editable.tsx +27 -0
  414. package/src/field/context/shared-autocomplete-context.tsx +61 -0
  415. package/src/field/context/shared-history-context.tsx +30 -0
  416. package/src/field/context/shared-on-change-context.tsx +32 -0
  417. package/src/field/debug.tsx +39 -0
  418. package/src/field/editor-component.css +46 -0
  419. package/src/field/editor-component.md +87 -0
  420. package/src/field/editor-component.test.tsx +170 -0
  421. package/src/field/editor-component.tsx +207 -0
  422. package/src/field/editor-context.tsx +102 -0
  423. package/src/field/editor-field.tsx +51 -0
  424. package/src/field/editor.css +1481 -0
  425. package/src/field/editor.tsx +245 -0
  426. package/src/field/hooks/use-media-queryts +21 -0
  427. package/src/field/hooks/use-modal.tsx +59 -0
  428. package/src/field/hooks/use-report.ts +62 -0
  429. package/src/field/images/LICENSE.md +5 -0
  430. package/src/field/images/assets.d.ts +27 -0
  431. package/src/field/images/cat-typing.gif +0 -0
  432. package/src/field/images/emoji/1F600.png +0 -0
  433. package/src/field/images/emoji/1F641.png +0 -0
  434. package/src/field/images/emoji/1F642.png +0 -0
  435. package/src/field/images/emoji/2764.png +0 -0
  436. package/src/field/images/emoji/LICENSE.md +5 -0
  437. package/src/field/images/icons/3-columns.svg +3 -0
  438. package/src/field/images/icons/LICENSE.md +5 -0
  439. package/src/field/images/icons/admonition.svg +1 -0
  440. package/src/field/images/icons/ai.svg +5 -0
  441. package/src/field/images/icons/arrow-clockwise.svg +1 -0
  442. package/src/field/images/icons/arrow-counterclockwise.svg +1 -0
  443. package/src/field/images/icons/bg-color.svg +1 -0
  444. package/src/field/images/icons/camera.svg +1 -0
  445. package/src/field/images/icons/card-checklist.svg +1 -0
  446. package/src/field/images/icons/caret-right-fill.svg +1 -0
  447. package/src/field/images/icons/chat-left-text.svg +1 -0
  448. package/src/field/images/icons/chat-right-dots.svg +1 -0
  449. package/src/field/images/icons/chat-right-text.svg +1 -0
  450. package/src/field/images/icons/chat-right.svg +1 -0
  451. package/src/field/images/icons/chat-square-quote.svg +1 -0
  452. package/src/field/images/icons/chevron-down.svg +1 -0
  453. package/src/field/images/icons/clipboard.svg +1 -0
  454. package/src/field/images/icons/close.svg +1 -0
  455. package/src/field/images/icons/code.svg +1 -0
  456. package/src/field/images/icons/comments.svg +1 -0
  457. package/src/field/images/icons/copy.svg +1 -0
  458. package/src/field/images/icons/diagram-2.svg +1 -0
  459. package/src/field/images/icons/download.svg +1 -0
  460. package/src/field/images/icons/draggable-block-menu.svg +1 -0
  461. package/src/field/images/icons/dropdown-more.svg +1 -0
  462. package/src/field/images/icons/figma.svg +1 -0
  463. package/src/field/images/icons/file-earmark-text.svg +4 -0
  464. package/src/field/images/icons/file-image.svg +1 -0
  465. package/src/field/images/icons/filetype-gif.svg +1 -0
  466. package/src/field/images/icons/font-color.svg +1 -0
  467. package/src/field/images/icons/font-family.svg +1 -0
  468. package/src/field/images/icons/gear.svg +1 -0
  469. package/src/field/images/icons/horizontal-rule.svg +1 -0
  470. package/src/field/images/icons/indent.svg +1 -0
  471. package/src/field/images/icons/journal-code.svg +1 -0
  472. package/src/field/images/icons/journal-text.svg +1 -0
  473. package/src/field/images/icons/justify.svg +1 -0
  474. package/src/field/images/icons/link.svg +1 -0
  475. package/src/field/images/icons/list-ol.svg +1 -0
  476. package/src/field/images/icons/list-ul.svg +1 -0
  477. package/src/field/images/icons/lock-fill.svg +1 -0
  478. package/src/field/images/icons/lock.svg +1 -0
  479. package/src/field/images/icons/markdown.svg +1 -0
  480. package/src/field/images/icons/mic.svg +1 -0
  481. package/src/field/images/icons/outdent.svg +1 -0
  482. package/src/field/images/icons/paint-bucket.svg +1 -0
  483. package/src/field/images/icons/palette.svg +1 -0
  484. package/src/field/images/icons/pencil-fill.svg +1 -0
  485. package/src/field/images/icons/plug-fill.svg +1 -0
  486. package/src/field/images/icons/plug.svg +1 -0
  487. package/src/field/images/icons/plus-slash-minus.svg +1 -0
  488. package/src/field/images/icons/plus.svg +1 -0
  489. package/src/field/images/icons/prettier-error.svg +1 -0
  490. package/src/field/images/icons/prettier.svg +1 -0
  491. package/src/field/images/icons/send.svg +1 -0
  492. package/src/field/images/icons/square-check.svg +1 -0
  493. package/src/field/images/icons/sticky.svg +1 -0
  494. package/src/field/images/icons/success-alt.svg +1 -0
  495. package/src/field/images/icons/success.svg +1 -0
  496. package/src/field/images/icons/table.svg +1 -0
  497. package/src/field/images/icons/text-center.svg +1 -0
  498. package/src/field/images/icons/text-left.svg +1 -0
  499. package/src/field/images/icons/text-paragraph.svg +1 -0
  500. package/src/field/images/icons/text-right.svg +1 -0
  501. package/src/field/images/icons/trash.svg +1 -0
  502. package/src/field/images/icons/trash3.svg +1 -0
  503. package/src/field/images/icons/tweet.svg +1 -0
  504. package/src/field/images/icons/type-bold.svg +1 -0
  505. package/src/field/images/icons/type-h1.svg +1 -0
  506. package/src/field/images/icons/type-h2.svg +1 -0
  507. package/src/field/images/icons/type-h3.svg +1 -0
  508. package/src/field/images/icons/type-h4.svg +1 -0
  509. package/src/field/images/icons/type-h5.svg +1 -0
  510. package/src/field/images/icons/type-h6.svg +1 -0
  511. package/src/field/images/icons/type-italic.svg +1 -0
  512. package/src/field/images/icons/type-strikethrough.svg +1 -0
  513. package/src/field/images/icons/type-subscript.svg +1 -0
  514. package/src/field/images/icons/type-superscript.svg +1 -0
  515. package/src/field/images/icons/type-underline.svg +1 -0
  516. package/src/field/images/icons/upload.svg +1 -0
  517. package/src/field/images/icons/user.svg +1 -0
  518. package/src/field/images/icons/vimeo.svg +1 -0
  519. package/src/field/images/icons/youtube.svg +1 -0
  520. package/src/field/images/landscape.jpg +0 -0
  521. package/src/field/images/logo.svg +1 -0
  522. package/src/field/images/yellow-flower-small.jpg +0 -0
  523. package/src/field/images/yellow-flower.jpg +0 -0
  524. package/src/field/lexical-populate-shared.ts +188 -0
  525. package/src/field/nodes/admonition-node/admonition-node-component.css +115 -0
  526. package/src/field/nodes/admonition-node/admonition-node-component.tsx +256 -0
  527. package/src/field/nodes/admonition-node/admonition-node.tsx +189 -0
  528. package/src/field/nodes/admonition-node/icons/danger-icon.css +11 -0
  529. package/src/field/nodes/admonition-node/icons/danger-icon.js +17 -0
  530. package/src/field/nodes/admonition-node/icons/danger-icon.tsx +19 -0
  531. package/src/field/nodes/admonition-node/icons/index.js +4 -0
  532. package/src/field/nodes/admonition-node/icons/index.ts +4 -0
  533. package/src/field/nodes/admonition-node/icons/note-icon.css +11 -0
  534. package/src/field/nodes/admonition-node/icons/note-icon.js +17 -0
  535. package/src/field/nodes/admonition-node/icons/note-icon.tsx +19 -0
  536. package/src/field/nodes/admonition-node/icons/tip-icon.css +11 -0
  537. package/src/field/nodes/admonition-node/icons/tip-icon.js +17 -0
  538. package/src/field/nodes/admonition-node/icons/tip-icon.tsx +19 -0
  539. package/src/field/nodes/admonition-node/icons/warning-icon.css +11 -0
  540. package/src/field/nodes/admonition-node/icons/warning-icon.js +17 -0
  541. package/src/field/nodes/admonition-node/icons/warning-icon.tsx +19 -0
  542. package/src/field/nodes/admonition-node/index.ts +14 -0
  543. package/src/field/nodes/admonition-node/types.ts +33 -0
  544. package/src/field/nodes/document-relation.ts +33 -0
  545. package/src/field/nodes/index.ts +47 -0
  546. package/src/field/nodes/inline-image-node/index.ts +10 -0
  547. package/src/field/nodes/inline-image-node/inline-image-node-component.css +205 -0
  548. package/src/field/nodes/inline-image-node/inline-image-node-component.tsx +342 -0
  549. package/src/field/nodes/inline-image-node/inline-image-node.tsx +328 -0
  550. package/src/field/nodes/inline-image-node/types.ts +43 -0
  551. package/src/field/nodes/layout-container-node/layout-container-node.ts +97 -0
  552. package/src/field/nodes/layout-container-node/layout-item-node.ts +63 -0
  553. package/src/field/nodes/link-nodes/auto-link-node.ts +64 -0
  554. package/src/field/nodes/link-nodes/index.ts +3 -0
  555. package/src/field/nodes/link-nodes/link-node.ts +426 -0
  556. package/src/field/nodes/link-nodes/types.ts +33 -0
  557. package/src/field/nodes/vimeo-node/index.tsx +172 -0
  558. package/src/field/nodes/youtube-node/index.tsx +178 -0
  559. package/src/field/plugins/admonition-plugin/admonition-modal.css +25 -0
  560. package/src/field/plugins/admonition-plugin/admonition-modal.tsx +187 -0
  561. package/src/field/plugins/admonition-plugin/fields.ts +103 -0
  562. package/src/field/plugins/admonition-plugin/index.tsx +105 -0
  563. package/src/field/plugins/admonition-plugin/types.ts +37 -0
  564. package/src/field/plugins/auto-embed-plugin/auto-embed-modal.css +15 -0
  565. package/src/field/plugins/auto-embed-plugin/auto-embed-modal.tsx +110 -0
  566. package/src/field/plugins/auto-embed-plugin/index.tsx +323 -0
  567. package/src/field/plugins/code-highlight-plugin/index.ts +23 -0
  568. package/src/field/plugins/drag-drop-paste-plugin/index.ts +47 -0
  569. package/src/field/plugins/floating-text-format-toolbar-plugin/index.css +148 -0
  570. package/src/field/plugins/floating-text-format-toolbar-plugin/index.tsx +398 -0
  571. package/src/field/plugins/inline-image-plugin/fields.ts +21 -0
  572. package/src/field/plugins/inline-image-plugin/index.tsx +202 -0
  573. package/src/field/plugins/inline-image-plugin/inline-image-modal.css +29 -0
  574. package/src/field/plugins/inline-image-plugin/inline-image-modal.tsx +314 -0
  575. package/src/field/plugins/inline-image-plugin/populate.ts +48 -0
  576. package/src/field/plugins/inline-image-plugin/types.ts +39 -0
  577. package/src/field/plugins/inline-image-plugin/utils.ts +113 -0
  578. package/src/field/plugins/layout-plugin/insert-layout-modal.css +19 -0
  579. package/src/field/plugins/layout-plugin/insert-layout-modal.tsx +100 -0
  580. package/src/field/plugins/layout-plugin/layout-plugin.tsx +162 -0
  581. package/src/field/plugins/link-plugin/auto-link/auto-link-plugin.tsx +327 -0
  582. package/src/field/plugins/link-plugin/auto-link/index.tsx +35 -0
  583. package/src/field/plugins/link-plugin/link/floating-link-editor.css +128 -0
  584. package/src/field/plugins/link-plugin/link/floating-link-editor.tsx +348 -0
  585. package/src/field/plugins/link-plugin/link/index.tsx +99 -0
  586. package/src/field/plugins/link-plugin/link/link-modal.tsx +376 -0
  587. package/src/field/plugins/link-plugin/link/types.ts +20 -0
  588. package/src/field/plugins/link-plugin/populate.ts +48 -0
  589. package/src/field/plugins/table-action-menu-plugin/index.tsx +804 -0
  590. package/src/field/plugins/table-plugin/index.tsx +33 -0
  591. package/src/field/plugins/table-plugin/table-modal.css +19 -0
  592. package/src/field/plugins/table-plugin/table-modal.tsx +127 -0
  593. package/src/field/plugins/toolbar-plugin/index.tsx +937 -0
  594. package/src/field/plugins/treeview-plugin/index.tsx +29 -0
  595. package/src/field/plugins/vimeo-plugin/index.ts +42 -0
  596. package/src/field/plugins/youtube-plugin/index.ts +43 -0
  597. package/src/field/shared/canUseDOM.ts +10 -0
  598. package/src/field/shared/caretFromPoint.bak +40 -0
  599. package/src/field/shared/environment.ts +44 -0
  600. package/src/field/shared/invariant.ts +25 -0
  601. package/src/field/shared/simpleDiffWithCursor.ts +40 -0
  602. package/src/field/shared/useLayoutEffect.ts +15 -0
  603. package/src/field/shared/useModalFormState.ts +48 -0
  604. package/src/field/shared/warnOnlyOnce.ts +21 -0
  605. package/src/field/themes/lexical-editor-theme.css +565 -0
  606. package/src/field/themes/lexical-editor-theme.js +104 -0
  607. package/src/field/themes/lexical-editor-theme.tsx +115 -0
  608. package/src/field/toolbar-extensions.tsx +93 -0
  609. package/src/field/types.ts +19 -0
  610. package/src/field/ui/button.css +45 -0
  611. package/src/field/ui/button.tsx +51 -0
  612. package/src/field/ui/checkbox.css +52 -0
  613. package/src/field/ui/color-picker.css +88 -0
  614. package/src/field/ui/color-picker.tsx +395 -0
  615. package/src/field/ui/dialog.css +17 -0
  616. package/src/field/ui/dialog.tsx +29 -0
  617. package/src/field/ui/dropdown.tsx +217 -0
  618. package/src/field/ui/file-input.tsx +44 -0
  619. package/src/field/ui/input.css +32 -0
  620. package/src/field/ui/modal.css +84 -0
  621. package/src/field/ui/modal.tsx +106 -0
  622. package/src/field/ui/placeholder-inline.tsx +28 -0
  623. package/src/field/ui/placeholder.css +33 -0
  624. package/src/field/ui/placeholder.tsx +32 -0
  625. package/src/field/ui/select.css +34 -0
  626. package/src/field/ui/select.tsx +38 -0
  627. package/src/field/ui/switch.tsx +33 -0
  628. package/src/field/ui/text-area.css +45 -0
  629. package/src/field/ui/text-area.tsx +50 -0
  630. package/src/field/ui/text-input.tsx +51 -0
  631. package/src/field/utils/cloneDeep.ts +57 -0
  632. package/src/field/utils/deepEqual.ts +54 -0
  633. package/src/field/utils/emoji-list.ts +16615 -0
  634. package/src/field/utils/getDOMRangeRect.ts +24 -0
  635. package/src/field/utils/getSelectedNode.ts +25 -0
  636. package/src/field/utils/guard.ts +10 -0
  637. package/src/field/utils/hashSerializedState.ts +34 -0
  638. package/src/field/utils/isMobileWidth.ts +7 -0
  639. package/src/field/utils/joinClasses.ts +11 -0
  640. package/src/field/utils/point.ts +52 -0
  641. package/src/field/utils/rect.ts +142 -0
  642. package/src/field/utils/setFloatingElemPosition.ts +48 -0
  643. package/src/field/utils/setFloatingElemPositionForLinkEditor.ts +46 -0
  644. package/src/field/utils/swipe.ts +129 -0
  645. package/src/field/utils/url.ts +49 -0
  646. package/src/index.ts +26 -0
  647. package/src/lexical-editor.tsx +56 -0
  648. package/src/richtext-field.module.css +29 -0
  649. package/src/richtext-field.tsx +113 -0
  650. package/src/server.ts +85 -0
  651. package/src/types.ts +43 -0
  652. package/src/validate/createEmptyEditorState.ts +52 -0
  653. package/src/validate/hasText.test.ts +89 -0
  654. package/src/validate/hasText.ts +34 -0
  655. package/src/validate/validate.ts +18 -0
@@ -0,0 +1,28 @@
1
+ const linkVisitor = {
2
+ match (node) {
3
+ if ('link' !== node.type) return null;
4
+ const attributes = node.attributes;
5
+ if (null == attributes) return null;
6
+ if ('internal' !== attributes.linkType) return null;
7
+ const collectionPath = attributes.targetCollectionPath;
8
+ const documentId = attributes.targetDocumentId;
9
+ if (!collectionPath || !documentId) return null;
10
+ return {
11
+ node,
12
+ collectionPath,
13
+ documentId,
14
+ apply (target) {
15
+ const targetFields = target.fields ?? {};
16
+ const path = target.path;
17
+ const title = targetFields.title;
18
+ const next = {
19
+ ...attributes.document ?? {}
20
+ };
21
+ if ('string' == typeof title && title.length > 0) next.title = title;
22
+ if ('string' == typeof path && path.length > 0) next.path = path;
23
+ attributes.document = next;
24
+ }
25
+ };
26
+ }
27
+ };
28
+ export { linkVisitor };
@@ -0,0 +1,6 @@
1
+ import { type ReactPortal } from 'react';
2
+ export declare function TableActionMenuPlugin({ anchorElem, cellMerge, }: {
3
+ anchorElem?: HTMLElement;
4
+ cellMerge?: boolean;
5
+ }): null | ReactPortal;
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/field/plugins/table-action-menu-plugin/index.tsx"],"names":[],"mappings":"AAaA,OAAO,EAAE,KAAK,WAAW,EAA4C,MAAM,OAAO,CAAA;AAwwBlF,wBAAgB,qBAAqB,CAAC,EACpC,UAA0B,EAC1B,SAAiB,GAClB,EAAE;IACD,UAAU,CAAC,EAAE,WAAW,CAAA;IACxB,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,GAAG,IAAI,GAAG,WAAW,CAQrB"}
@@ -0,0 +1,598 @@
1
+ "use client";
2
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
3
+ import { useCallback, useEffect, useRef, useState } from "react";
4
+ import { useLexicalComposerContext } from "@lexical/react/LexicalComposerContext";
5
+ import { useLexicalEditable } from "@lexical/react/useLexicalEditable";
6
+ import { $deleteTableColumnAtSelection, $deleteTableRowAtSelection, $getNodeTriplet, $getTableCellNodeFromLexicalNode, $getTableColumnIndexFromTableCellNode, $getTableNodeFromLexicalNodeOrThrow, $getTableRowIndexFromTableCellNode, $insertTableColumnAtSelection, $insertTableRowAtSelection, $isTableCellNode, $isTableRowNode, $isTableSelection, $unmergeCell, TableCellHeaderStates, TableCellNode, getTableObserverFromTableElement } from "@lexical/table";
7
+ import { $createParagraphNode, $getRoot, $getSelection, $isElementNode, $isParagraphNode, $isRangeSelection, $isTextNode } from "lexical";
8
+ import { createPortal } from "react-dom";
9
+ import use_modal from "../../hooks/use-modal.js";
10
+ import invariant from "../../shared/invariant.js";
11
+ import color_picker from "../../ui/color-picker.js";
12
+ function computeSelectionCount(selection) {
13
+ const selectionShape = selection.getShape();
14
+ return {
15
+ columns: selectionShape.toX - selectionShape.fromX + 1,
16
+ rows: selectionShape.toY - selectionShape.fromY + 1
17
+ };
18
+ }
19
+ function isTableSelectionRectangular(selection) {
20
+ const nodes = selection.getNodes();
21
+ const currentRows = [];
22
+ let currentRow = null;
23
+ let expectedColumns = null;
24
+ let currentColumns = 0;
25
+ for(let i = 0; i < nodes.length; i++){
26
+ const node = nodes[i];
27
+ if ($isTableCellNode(node)) {
28
+ const row = node.getParentOrThrow();
29
+ invariant($isTableRowNode(row), 'Expected CellNode to have a RowNode parent');
30
+ if (currentRow !== row) {
31
+ if (null !== expectedColumns && currentColumns !== expectedColumns) return false;
32
+ if (null !== currentRow) expectedColumns = currentColumns;
33
+ currentRow = row;
34
+ currentColumns = 0;
35
+ }
36
+ const colSpan = node.__colSpan;
37
+ for(let j = 0; j < colSpan; j++){
38
+ if (void 0 === currentRows[currentColumns + j]) currentRows[currentColumns + j] = 0;
39
+ currentRows[currentColumns + j] += node.__rowSpan;
40
+ }
41
+ currentColumns += colSpan;
42
+ }
43
+ }
44
+ return (null === expectedColumns || currentColumns === expectedColumns) && currentRows.every((v)=>v === currentRows[0]);
45
+ }
46
+ function $canUnmerge() {
47
+ const selection = $getSelection();
48
+ if ($isRangeSelection(selection) && !selection.isCollapsed() || $isTableSelection(selection) && !selection.anchor.is(selection.focus) || !$isRangeSelection(selection) && !$isTableSelection(selection)) return false;
49
+ const [cell] = $getNodeTriplet(selection.anchor);
50
+ return cell.__colSpan > 1 || cell.__rowSpan > 1;
51
+ }
52
+ function $cellContainsEmptyParagraph(cell) {
53
+ if (1 !== cell.getChildrenSize()) return false;
54
+ const firstChild = cell.getFirstChildOrThrow();
55
+ if (!$isParagraphNode(firstChild) || !firstChild.isEmpty()) return false;
56
+ return true;
57
+ }
58
+ function $selectLastDescendant(node) {
59
+ const lastDescendant = node.getLastDescendant();
60
+ if ($isTextNode(lastDescendant)) lastDescendant.select();
61
+ else if ($isElementNode(lastDescendant)) lastDescendant.selectEnd();
62
+ else if (null !== lastDescendant) lastDescendant.selectNext();
63
+ }
64
+ function currentCellBackgroundColor(editor) {
65
+ return editor.getEditorState().read(()=>{
66
+ const selection = $getSelection();
67
+ if ($isRangeSelection(selection) || $isTableSelection(selection)) {
68
+ const [cell] = $getNodeTriplet(selection.anchor);
69
+ if ($isTableCellNode(cell)) return cell.getBackgroundColor();
70
+ }
71
+ return null;
72
+ });
73
+ }
74
+ function TableActionMenu({ onClose, tableCellNode: _tableCellNode, setIsMenuOpen, contextRef, cellMerge, showColorPickerModal }) {
75
+ const [editor] = useLexicalComposerContext();
76
+ const dropDownRef = useRef(null);
77
+ const [tableCellNode, updateTableCellNode] = useState(_tableCellNode);
78
+ const [selectionCounts, updateSelectionCounts] = useState({
79
+ columns: 1,
80
+ rows: 1
81
+ });
82
+ const [canMergeCells, setCanMergeCells] = useState(false);
83
+ const [canUnmergeCell, setCanUnmergeCell] = useState(false);
84
+ const [backgroundColor, setBackgroundColor] = useState(()=>currentCellBackgroundColor(editor) ?? '');
85
+ useEffect(()=>editor.registerMutationListener(TableCellNode, (nodeMutations)=>{
86
+ const nodeUpdated = 'updated' === nodeMutations.get(tableCellNode.getKey());
87
+ if (nodeUpdated) {
88
+ editor.getEditorState().read(()=>{
89
+ updateTableCellNode(tableCellNode.getLatest());
90
+ });
91
+ setBackgroundColor(currentCellBackgroundColor(editor) ?? '');
92
+ }
93
+ }), [
94
+ editor,
95
+ tableCellNode
96
+ ]);
97
+ useEffect(()=>{
98
+ editor.getEditorState().read(()=>{
99
+ const selection = $getSelection();
100
+ if ($isTableSelection(selection)) {
101
+ const currentSelectionCounts = computeSelectionCount(selection);
102
+ updateSelectionCounts(computeSelectionCount(selection));
103
+ setCanMergeCells(isTableSelectionRectangular(selection) && (currentSelectionCounts.columns > 1 || currentSelectionCounts.rows > 1));
104
+ }
105
+ setCanUnmergeCell($canUnmerge());
106
+ });
107
+ }, [
108
+ editor
109
+ ]);
110
+ useEffect(()=>{
111
+ const menuButtonElement = contextRef.current;
112
+ const dropDownElement = dropDownRef.current;
113
+ const rootElement = editor.getRootElement();
114
+ if (null != menuButtonElement && null != dropDownElement && null != rootElement) {
115
+ const rootEleRect = rootElement.getBoundingClientRect();
116
+ const menuButtonRect = menuButtonElement.getBoundingClientRect();
117
+ dropDownElement.style.opacity = '1';
118
+ const dropDownElementRect = dropDownElement.getBoundingClientRect();
119
+ const margin = 5;
120
+ let leftPosition = menuButtonRect.right + margin;
121
+ if (leftPosition + dropDownElementRect.width > window.innerWidth || leftPosition + dropDownElementRect.width > rootEleRect.right) {
122
+ const position = menuButtonRect.left - dropDownElementRect.width - margin;
123
+ leftPosition = position < 0 ? margin : position;
124
+ }
125
+ dropDownElement.style.left = `${leftPosition}px`;
126
+ let topPosition = menuButtonRect.top;
127
+ if (topPosition + dropDownElementRect.height > window.innerHeight) {
128
+ const position = menuButtonRect.bottom - dropDownElementRect.height;
129
+ topPosition = position < 0 ? margin : position;
130
+ }
131
+ dropDownElement.style.top = `${topPosition}px`;
132
+ }
133
+ }, [
134
+ contextRef,
135
+ editor
136
+ ]);
137
+ useEffect(()=>{
138
+ function handleClickOutside(event) {
139
+ if (null != dropDownRef.current && null != contextRef.current && !dropDownRef.current.contains(event.target) && !contextRef.current.contains(event.target)) setIsMenuOpen(false);
140
+ }
141
+ window.addEventListener('click', handleClickOutside);
142
+ return ()=>{
143
+ window.removeEventListener('click', handleClickOutside);
144
+ };
145
+ }, [
146
+ setIsMenuOpen,
147
+ contextRef
148
+ ]);
149
+ const clearTableSelection = useCallback(()=>{
150
+ editor.update(()=>{
151
+ if (tableCellNode.isAttached()) {
152
+ const tableNode = $getTableNodeFromLexicalNodeOrThrow(tableCellNode);
153
+ const tableElement = editor.getElementByKey(tableNode.getKey());
154
+ if (null == tableElement) throw new Error('Expected to find tableElement in DOM');
155
+ const tableSelection = getTableObserverFromTableElement(tableElement);
156
+ if (null !== tableSelection) tableSelection.$clearHighlight();
157
+ tableNode.markDirty();
158
+ updateTableCellNode(tableCellNode.getLatest());
159
+ }
160
+ const rootNode = $getRoot();
161
+ rootNode.selectStart();
162
+ });
163
+ }, [
164
+ editor,
165
+ tableCellNode
166
+ ]);
167
+ const mergeTableCellsAtSelection = ()=>{
168
+ editor.update(()=>{
169
+ const selection = $getSelection();
170
+ if ($isTableSelection(selection)) {
171
+ const { columns, rows } = computeSelectionCount(selection);
172
+ const nodes = selection.getNodes();
173
+ let firstCell = null;
174
+ for(let i = 0; i < nodes.length; i++){
175
+ const node = nodes[i];
176
+ if ($isTableCellNode(node)) {
177
+ if (null === firstCell) {
178
+ node.setColSpan(columns).setRowSpan(rows);
179
+ firstCell = node;
180
+ const isEmpty = $cellContainsEmptyParagraph(node);
181
+ let firstChild;
182
+ if (isEmpty && $isParagraphNode(firstChild = node.getFirstChild())) firstChild.remove();
183
+ } else if ($isTableCellNode(firstCell)) {
184
+ const isEmpty = $cellContainsEmptyParagraph(node);
185
+ if (!isEmpty) firstCell.append(...node.getChildren());
186
+ node.remove();
187
+ }
188
+ }
189
+ }
190
+ if (null !== firstCell) {
191
+ if (0 === firstCell.getChildrenSize()) firstCell.append($createParagraphNode());
192
+ $selectLastDescendant(firstCell);
193
+ }
194
+ onClose();
195
+ }
196
+ });
197
+ };
198
+ const unmergeTableCellsAtSelection = ()=>{
199
+ editor.update(()=>{
200
+ $unmergeCell();
201
+ });
202
+ };
203
+ const insertTableRowAtSelection = useCallback((shouldInsertAfter)=>{
204
+ editor.update(()=>{
205
+ $insertTableRowAtSelection(shouldInsertAfter);
206
+ onClose();
207
+ });
208
+ }, [
209
+ editor,
210
+ onClose
211
+ ]);
212
+ const insertTableColumnAtSelection = useCallback((shouldInsertAfter)=>{
213
+ editor.update(()=>{
214
+ for(let i = 0; i < selectionCounts.columns; i++)$insertTableColumnAtSelection(shouldInsertAfter);
215
+ onClose();
216
+ });
217
+ }, [
218
+ editor,
219
+ onClose,
220
+ selectionCounts.columns
221
+ ]);
222
+ const deleteTableRowAtSelection = useCallback(()=>{
223
+ editor.update(()=>{
224
+ $deleteTableRowAtSelection();
225
+ onClose();
226
+ });
227
+ }, [
228
+ editor,
229
+ onClose
230
+ ]);
231
+ const deleteTableAtSelection = useCallback(()=>{
232
+ editor.update(()=>{
233
+ const tableNode = $getTableNodeFromLexicalNodeOrThrow(tableCellNode);
234
+ tableNode.remove();
235
+ clearTableSelection();
236
+ onClose();
237
+ });
238
+ }, [
239
+ editor,
240
+ tableCellNode,
241
+ clearTableSelection,
242
+ onClose
243
+ ]);
244
+ const deleteTableColumnAtSelection = useCallback(()=>{
245
+ editor.update(()=>{
246
+ $deleteTableColumnAtSelection();
247
+ onClose();
248
+ });
249
+ }, [
250
+ editor,
251
+ onClose
252
+ ]);
253
+ const toggleTableRowIsHeader = useCallback(()=>{
254
+ editor.update(()=>{
255
+ const tableNode = $getTableNodeFromLexicalNodeOrThrow(tableCellNode);
256
+ const tableRowIndex = $getTableRowIndexFromTableCellNode(tableCellNode);
257
+ const tableRows = tableNode.getChildren();
258
+ if (tableRowIndex >= tableRows.length || tableRowIndex < 0) throw new Error('Expected table cell to be inside of table row.');
259
+ const tableRow = tableRows[tableRowIndex];
260
+ if (!$isTableRowNode(tableRow)) throw new Error('Expected table row');
261
+ tableRow.getChildren().forEach((tableCell)=>{
262
+ if (!$isTableCellNode(tableCell)) throw new Error('Expected table cell');
263
+ tableCell.toggleHeaderStyle(TableCellHeaderStates.ROW);
264
+ });
265
+ clearTableSelection();
266
+ onClose();
267
+ });
268
+ }, [
269
+ editor,
270
+ tableCellNode,
271
+ clearTableSelection,
272
+ onClose
273
+ ]);
274
+ const toggleTableColumnIsHeader = useCallback(()=>{
275
+ editor.update(()=>{
276
+ const tableNode = $getTableNodeFromLexicalNodeOrThrow(tableCellNode);
277
+ const tableColumnIndex = $getTableColumnIndexFromTableCellNode(tableCellNode);
278
+ const tableRows = tableNode.getChildren();
279
+ const maxRowsLength = Math.max(...tableRows.map((row)=>row.getChildren().length));
280
+ if (tableColumnIndex >= maxRowsLength || tableColumnIndex < 0) throw new Error('Expected table cell to be inside of table row.');
281
+ for(let r = 0; r < tableRows.length; r++){
282
+ const tableRow = tableRows[r];
283
+ if (!$isTableRowNode(tableRow)) throw new Error('Expected table row');
284
+ const tableCells = tableRow.getChildren();
285
+ if (tableColumnIndex >= tableCells.length) continue;
286
+ const tableCell = tableCells[tableColumnIndex];
287
+ if (!$isTableCellNode(tableCell)) throw new Error('Expected table cell');
288
+ tableCell.toggleHeaderStyle(TableCellHeaderStates.COLUMN);
289
+ }
290
+ clearTableSelection();
291
+ onClose();
292
+ });
293
+ }, [
294
+ editor,
295
+ tableCellNode,
296
+ clearTableSelection,
297
+ onClose
298
+ ]);
299
+ const handleCellBackgroundColor = useCallback((value)=>{
300
+ editor.update(()=>{
301
+ const selection = $getSelection();
302
+ if ($isRangeSelection(selection) || $isTableSelection(selection)) {
303
+ const [cell] = $getNodeTriplet(selection.anchor);
304
+ if ($isTableCellNode(cell)) cell.setBackgroundColor(value);
305
+ if ($isTableSelection(selection)) {
306
+ const nodes = selection.getNodes();
307
+ for(let i = 0; i < nodes.length; i++){
308
+ const node = nodes[i];
309
+ if ($isTableCellNode(node)) node.setBackgroundColor(value);
310
+ }
311
+ }
312
+ }
313
+ });
314
+ }, [
315
+ editor
316
+ ]);
317
+ let mergeCellButton = null;
318
+ if (cellMerge) {
319
+ if (canMergeCells) mergeCellButton = /*#__PURE__*/ jsx("button", {
320
+ type: "button",
321
+ className: "item",
322
+ onClick: ()=>{
323
+ mergeTableCellsAtSelection();
324
+ },
325
+ "data-test-id": "table-merge-cells",
326
+ children: "Merge cells"
327
+ });
328
+ else if (canUnmergeCell) mergeCellButton = /*#__PURE__*/ jsx("button", {
329
+ type: "button",
330
+ className: "item",
331
+ onClick: ()=>{
332
+ unmergeTableCellsAtSelection();
333
+ },
334
+ "data-test-id": "table-unmerge-cells",
335
+ children: "Unmerge cells"
336
+ });
337
+ }
338
+ return /*#__PURE__*/ createPortal(/*#__PURE__*/ jsxs("div", {
339
+ className: "dropdown",
340
+ ref: dropDownRef,
341
+ onClick: (e)=>{
342
+ e.stopPropagation();
343
+ },
344
+ children: [
345
+ mergeCellButton,
346
+ /*#__PURE__*/ jsx("button", {
347
+ type: "button",
348
+ className: "item",
349
+ onClick: ()=>{
350
+ showColorPickerModal('Cell background color', ()=>/*#__PURE__*/ jsx(color_picker, {
351
+ color: backgroundColor,
352
+ onChange: handleCellBackgroundColor
353
+ }));
354
+ },
355
+ "data-test-id": "table-background-color",
356
+ children: /*#__PURE__*/ jsx("span", {
357
+ className: "text",
358
+ children: "Background color"
359
+ })
360
+ }),
361
+ /*#__PURE__*/ jsx("hr", {}),
362
+ /*#__PURE__*/ jsx("button", {
363
+ type: "button",
364
+ className: "item",
365
+ onClick: ()=>{
366
+ insertTableRowAtSelection(false);
367
+ },
368
+ "data-test-id": "table-insert-row-above",
369
+ children: /*#__PURE__*/ jsxs("span", {
370
+ className: "text",
371
+ children: [
372
+ "Insert ",
373
+ 1 === selectionCounts.rows ? 'row' : `${selectionCounts.rows} rows`,
374
+ " above"
375
+ ]
376
+ })
377
+ }),
378
+ /*#__PURE__*/ jsx("button", {
379
+ type: "button",
380
+ className: "item",
381
+ onClick: ()=>{
382
+ insertTableRowAtSelection(true);
383
+ },
384
+ "data-test-id": "table-insert-row-below",
385
+ children: /*#__PURE__*/ jsxs("span", {
386
+ className: "text",
387
+ children: [
388
+ "Insert ",
389
+ 1 === selectionCounts.rows ? 'row' : `${selectionCounts.rows} rows`,
390
+ " below"
391
+ ]
392
+ })
393
+ }),
394
+ /*#__PURE__*/ jsx("hr", {}),
395
+ /*#__PURE__*/ jsx("button", {
396
+ type: "button",
397
+ className: "item",
398
+ onClick: ()=>{
399
+ insertTableColumnAtSelection(false);
400
+ },
401
+ "data-test-id": "table-insert-column-before",
402
+ children: /*#__PURE__*/ jsxs("span", {
403
+ className: "text",
404
+ children: [
405
+ "Insert ",
406
+ 1 === selectionCounts.columns ? 'column' : `${selectionCounts.columns} columns`,
407
+ ' ',
408
+ "left"
409
+ ]
410
+ })
411
+ }),
412
+ /*#__PURE__*/ jsx("button", {
413
+ type: "button",
414
+ className: "item",
415
+ onClick: ()=>{
416
+ insertTableColumnAtSelection(true);
417
+ },
418
+ "data-test-id": "table-insert-column-after",
419
+ children: /*#__PURE__*/ jsxs("span", {
420
+ className: "text",
421
+ children: [
422
+ "Insert ",
423
+ 1 === selectionCounts.columns ? 'column' : `${selectionCounts.columns} columns`,
424
+ ' ',
425
+ "right"
426
+ ]
427
+ })
428
+ }),
429
+ /*#__PURE__*/ jsx("hr", {}),
430
+ /*#__PURE__*/ jsx("button", {
431
+ type: "button",
432
+ className: "item",
433
+ onClick: ()=>{
434
+ deleteTableColumnAtSelection();
435
+ },
436
+ "data-test-id": "table-delete-columns",
437
+ children: /*#__PURE__*/ jsx("span", {
438
+ className: "text",
439
+ children: "Delete column"
440
+ })
441
+ }),
442
+ /*#__PURE__*/ jsx("button", {
443
+ type: "button",
444
+ className: "item",
445
+ onClick: ()=>{
446
+ deleteTableRowAtSelection();
447
+ },
448
+ "data-test-id": "table-delete-rows",
449
+ children: /*#__PURE__*/ jsx("span", {
450
+ className: "text",
451
+ children: "Delete row"
452
+ })
453
+ }),
454
+ /*#__PURE__*/ jsx("button", {
455
+ type: "button",
456
+ className: "item",
457
+ onClick: ()=>{
458
+ deleteTableAtSelection();
459
+ },
460
+ "data-test-id": "table-delete",
461
+ children: /*#__PURE__*/ jsx("span", {
462
+ className: "text",
463
+ children: "Delete table"
464
+ })
465
+ }),
466
+ /*#__PURE__*/ jsx("hr", {}),
467
+ /*#__PURE__*/ jsx("button", {
468
+ type: "button",
469
+ className: "item",
470
+ onClick: ()=>{
471
+ toggleTableRowIsHeader();
472
+ },
473
+ children: /*#__PURE__*/ jsxs("span", {
474
+ className: "text",
475
+ children: [
476
+ (tableCellNode.__headerState & TableCellHeaderStates.ROW) === TableCellHeaderStates.ROW ? 'Remove' : 'Add',
477
+ ' ',
478
+ "row header"
479
+ ]
480
+ })
481
+ }),
482
+ /*#__PURE__*/ jsx("button", {
483
+ type: "button",
484
+ className: "item",
485
+ onClick: ()=>{
486
+ toggleTableColumnIsHeader();
487
+ },
488
+ "data-test-id": "table-column-header",
489
+ children: /*#__PURE__*/ jsxs("span", {
490
+ className: "text",
491
+ children: [
492
+ (tableCellNode.__headerState & TableCellHeaderStates.COLUMN) === TableCellHeaderStates.COLUMN ? 'Remove' : 'Add',
493
+ ' ',
494
+ "column header"
495
+ ]
496
+ })
497
+ })
498
+ ]
499
+ }), document.body);
500
+ }
501
+ function TableCellActionMenuContainer({ anchorElem, cellMerge }) {
502
+ const [editor] = useLexicalComposerContext();
503
+ const menuButtonRef = useRef(null);
504
+ const menuRootRef = useRef(null);
505
+ const [isMenuOpen, setIsMenuOpen] = useState(false);
506
+ const [tableCellNode, setTableMenuCellNode] = useState(null);
507
+ const [colorPickerModal, showColorPickerModal] = use_modal();
508
+ const moveMenu = useCallback(()=>{
509
+ const menu = menuButtonRef.current;
510
+ const selection = $getSelection();
511
+ const nativeSelection = window.getSelection();
512
+ const activeElement = document.activeElement;
513
+ if (null == selection || null == menu) return void setTableMenuCellNode(null);
514
+ const rootElement = editor.getRootElement();
515
+ if ($isRangeSelection(selection) && null !== rootElement && null !== nativeSelection && rootElement.contains(nativeSelection.anchorNode)) {
516
+ const tableCellNodeFromSelection = $getTableCellNodeFromLexicalNode(selection.anchor.getNode());
517
+ if (null == tableCellNodeFromSelection) return void setTableMenuCellNode(null);
518
+ const tableCellParentNodeDOM = editor.getElementByKey(tableCellNodeFromSelection.getKey());
519
+ if (null == tableCellParentNodeDOM) return void setTableMenuCellNode(null);
520
+ setTableMenuCellNode(tableCellNodeFromSelection);
521
+ } else if (null == activeElement) setTableMenuCellNode(null);
522
+ }, [
523
+ editor
524
+ ]);
525
+ useEffect(()=>editor.registerUpdateListener(()=>{
526
+ editor.getEditorState().read(()=>{
527
+ moveMenu();
528
+ });
529
+ }));
530
+ useEffect(()=>{
531
+ const menuButtonDOM = menuButtonRef.current;
532
+ if (null != menuButtonDOM && null != tableCellNode) {
533
+ const tableCellNodeDOM = editor.getElementByKey(tableCellNode.getKey());
534
+ if (null != tableCellNodeDOM) {
535
+ const tableCellRect = tableCellNodeDOM.getBoundingClientRect();
536
+ const menuRect = menuButtonDOM.getBoundingClientRect();
537
+ const anchorRect = anchorElem.getBoundingClientRect();
538
+ const top = tableCellRect.top - anchorRect.top + 4;
539
+ const left = tableCellRect.right - menuRect.width - 10 - anchorRect.left;
540
+ menuButtonDOM.style.opacity = '1';
541
+ menuButtonDOM.style.transform = `translate(${left}px, ${top}px)`;
542
+ } else {
543
+ menuButtonDOM.style.opacity = '0';
544
+ menuButtonDOM.style.transform = 'translate(-10000px, -10000px)';
545
+ }
546
+ }
547
+ }, [
548
+ tableCellNode,
549
+ editor,
550
+ anchorElem
551
+ ]);
552
+ const prevTableCellDOM = useRef(tableCellNode);
553
+ useEffect(()=>{
554
+ if (prevTableCellDOM.current !== tableCellNode) setIsMenuOpen(false);
555
+ prevTableCellDOM.current = tableCellNode;
556
+ }, [
557
+ tableCellNode
558
+ ]);
559
+ return /*#__PURE__*/ jsx("div", {
560
+ className: "table-cell-action-button-container",
561
+ ref: menuButtonRef,
562
+ children: null != tableCellNode && /*#__PURE__*/ jsxs(Fragment, {
563
+ children: [
564
+ /*#__PURE__*/ jsx("button", {
565
+ type: "button",
566
+ className: "table-cell-action-button chevron-down",
567
+ onClick: (e)=>{
568
+ e.stopPropagation();
569
+ setIsMenuOpen(!isMenuOpen);
570
+ },
571
+ ref: menuRootRef,
572
+ children: /*#__PURE__*/ jsx("i", {
573
+ className: "chevron-down"
574
+ })
575
+ }),
576
+ colorPickerModal,
577
+ isMenuOpen && /*#__PURE__*/ jsx(TableActionMenu, {
578
+ contextRef: menuRootRef,
579
+ setIsMenuOpen: setIsMenuOpen,
580
+ onClose: ()=>{
581
+ setIsMenuOpen(false);
582
+ },
583
+ tableCellNode: tableCellNode,
584
+ cellMerge: cellMerge,
585
+ showColorPickerModal: showColorPickerModal
586
+ })
587
+ ]
588
+ })
589
+ });
590
+ }
591
+ function TableActionMenuPlugin({ anchorElem = document.body, cellMerge = false }) {
592
+ const isEditable = useLexicalEditable();
593
+ return /*#__PURE__*/ createPortal(isEditable ? /*#__PURE__*/ jsx(TableCellActionMenuContainer, {
594
+ anchorElem: anchorElem,
595
+ cellMerge: cellMerge
596
+ }) : null, anchorElem);
597
+ }
598
+ export { TableActionMenuPlugin };
@@ -0,0 +1,4 @@
1
+ import * as React from 'react';
2
+ export declare const OPEN_TABLE_MODAL_COMMAND: import("lexical").LexicalCommand<unknown>;
3
+ export declare function TablePlugin(): React.JSX.Element;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/field/plugins/table-plugin/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAO9B,eAAO,MAAM,wBAAwB,2CAA4C,CAAA;AAEjF,wBAAgB,WAAW,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,CAqB/C"}
@@ -0,0 +1,26 @@
1
+ "use client";
2
+ import { jsx } from "react/jsx-runtime";
3
+ import { useLexicalComposerContext } from "@lexical/react/LexicalComposerContext";
4
+ import { COMMAND_PRIORITY_NORMAL, createCommand } from "lexical";
5
+ import { TableModal } from "./table-modal.js";
6
+ import * as __rspack_external_react from "react";
7
+ const OPEN_TABLE_MODAL_COMMAND = createCommand('OPEN_TABLE_MODAL_COMMAND');
8
+ function TablePlugin() {
9
+ const [editor] = useLexicalComposerContext();
10
+ const [open, setOpen] = __rspack_external_react.useState(false);
11
+ editor.registerCommand(OPEN_TABLE_MODAL_COMMAND, ()=>{
12
+ if (false === open) {
13
+ setOpen(true);
14
+ return true;
15
+ }
16
+ return false;
17
+ }, COMMAND_PRIORITY_NORMAL);
18
+ const handleOnClose = ()=>{
19
+ setOpen(false);
20
+ };
21
+ return /*#__PURE__*/ jsx(TableModal, {
22
+ open: open,
23
+ onClose: handleOnClose
24
+ });
25
+ }
26
+ export { OPEN_TABLE_MODAL_COMMAND, TablePlugin };