@depup/lexical__react 0.41.0-depup.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 (471) hide show
  1. package/ExtensionComponent.d.ts +42 -0
  2. package/LICENSE +21 -0
  3. package/LexicalAutoEmbedPlugin.d.ts +39 -0
  4. package/LexicalAutoEmbedPlugin.dev.js +146 -0
  5. package/LexicalAutoEmbedPlugin.dev.mjs +141 -0
  6. package/LexicalAutoEmbedPlugin.js +11 -0
  7. package/LexicalAutoEmbedPlugin.js.flow +64 -0
  8. package/LexicalAutoEmbedPlugin.mjs +15 -0
  9. package/LexicalAutoEmbedPlugin.node.mjs +13 -0
  10. package/LexicalAutoEmbedPlugin.prod.js +9 -0
  11. package/LexicalAutoEmbedPlugin.prod.mjs +9 -0
  12. package/LexicalAutoFocusPlugin.d.ts +12 -0
  13. package/LexicalAutoFocusPlugin.dev.js +47 -0
  14. package/LexicalAutoFocusPlugin.dev.mjs +45 -0
  15. package/LexicalAutoFocusPlugin.js +11 -0
  16. package/LexicalAutoFocusPlugin.js.flow +14 -0
  17. package/LexicalAutoFocusPlugin.mjs +12 -0
  18. package/LexicalAutoFocusPlugin.node.mjs +10 -0
  19. package/LexicalAutoFocusPlugin.prod.js +9 -0
  20. package/LexicalAutoFocusPlugin.prod.mjs +9 -0
  21. package/LexicalAutoLinkPlugin.d.ts +16 -0
  22. package/LexicalAutoLinkPlugin.dev.js +56 -0
  23. package/LexicalAutoLinkPlugin.dev.mjs +54 -0
  24. package/LexicalAutoLinkPlugin.js +11 -0
  25. package/LexicalAutoLinkPlugin.js.flow +18 -0
  26. package/LexicalAutoLinkPlugin.mjs +13 -0
  27. package/LexicalAutoLinkPlugin.node.mjs +11 -0
  28. package/LexicalAutoLinkPlugin.prod.js +9 -0
  29. package/LexicalAutoLinkPlugin.prod.mjs +9 -0
  30. package/LexicalBlockWithAlignableContents.d.ts +21 -0
  31. package/LexicalBlockWithAlignableContents.dev.js +81 -0
  32. package/LexicalBlockWithAlignableContents.dev.mjs +79 -0
  33. package/LexicalBlockWithAlignableContents.js +11 -0
  34. package/LexicalBlockWithAlignableContents.js.flow +28 -0
  35. package/LexicalBlockWithAlignableContents.mjs +12 -0
  36. package/LexicalBlockWithAlignableContents.node.mjs +10 -0
  37. package/LexicalBlockWithAlignableContents.prod.js +9 -0
  38. package/LexicalBlockWithAlignableContents.prod.mjs +9 -0
  39. package/LexicalCharacterLimitPlugin.d.ts +15 -0
  40. package/LexicalCharacterLimitPlugin.dev.js +292 -0
  41. package/LexicalCharacterLimitPlugin.dev.mjs +290 -0
  42. package/LexicalCharacterLimitPlugin.js +11 -0
  43. package/LexicalCharacterLimitPlugin.js.flow +12 -0
  44. package/LexicalCharacterLimitPlugin.mjs +12 -0
  45. package/LexicalCharacterLimitPlugin.node.mjs +10 -0
  46. package/LexicalCharacterLimitPlugin.prod.js +9 -0
  47. package/LexicalCharacterLimitPlugin.prod.mjs +9 -0
  48. package/LexicalCheckListPlugin.d.ts +10 -0
  49. package/LexicalCheckListPlugin.dev.js +35 -0
  50. package/LexicalCheckListPlugin.dev.mjs +33 -0
  51. package/LexicalCheckListPlugin.js +11 -0
  52. package/LexicalCheckListPlugin.js.flow +12 -0
  53. package/LexicalCheckListPlugin.mjs +12 -0
  54. package/LexicalCheckListPlugin.node.mjs +10 -0
  55. package/LexicalCheckListPlugin.prod.js +9 -0
  56. package/LexicalCheckListPlugin.prod.mjs +9 -0
  57. package/LexicalClearEditorPlugin.d.ts +13 -0
  58. package/LexicalClearEditorPlugin.dev.js +55 -0
  59. package/LexicalClearEditorPlugin.dev.mjs +53 -0
  60. package/LexicalClearEditorPlugin.js +11 -0
  61. package/LexicalClearEditorPlugin.js.flow +14 -0
  62. package/LexicalClearEditorPlugin.mjs +12 -0
  63. package/LexicalClearEditorPlugin.node.mjs +10 -0
  64. package/LexicalClearEditorPlugin.prod.js +9 -0
  65. package/LexicalClearEditorPlugin.prod.mjs +9 -0
  66. package/LexicalClickableLinkPlugin.d.ts +11 -0
  67. package/LexicalClickableLinkPlugin.dev.js +38 -0
  68. package/LexicalClickableLinkPlugin.dev.mjs +36 -0
  69. package/LexicalClickableLinkPlugin.js +11 -0
  70. package/LexicalClickableLinkPlugin.js.flow +12 -0
  71. package/LexicalClickableLinkPlugin.mjs +12 -0
  72. package/LexicalClickableLinkPlugin.node.mjs +10 -0
  73. package/LexicalClickableLinkPlugin.prod.js +9 -0
  74. package/LexicalClickableLinkPlugin.prod.mjs +9 -0
  75. package/LexicalCollaborationContext.d.ts +19 -0
  76. package/LexicalCollaborationContext.dev.js +69 -0
  77. package/LexicalCollaborationContext.dev.mjs +65 -0
  78. package/LexicalCollaborationContext.js +11 -0
  79. package/LexicalCollaborationContext.js.flow +22 -0
  80. package/LexicalCollaborationContext.mjs +14 -0
  81. package/LexicalCollaborationContext.node.mjs +12 -0
  82. package/LexicalCollaborationContext.prod.js +9 -0
  83. package/LexicalCollaborationContext.prod.mjs +9 -0
  84. package/LexicalCollaborationPlugin.d.ts +39 -0
  85. package/LexicalCollaborationPlugin.dev.js +584 -0
  86. package/LexicalCollaborationPlugin.dev.mjs +569 -0
  87. package/LexicalCollaborationPlugin.js +11 -0
  88. package/LexicalCollaborationPlugin.js.flow +50 -0
  89. package/LexicalCollaborationPlugin.mjs +13 -0
  90. package/LexicalCollaborationPlugin.node.mjs +11 -0
  91. package/LexicalCollaborationPlugin.prod.js +9 -0
  92. package/LexicalCollaborationPlugin.prod.mjs +9 -0
  93. package/LexicalComposer.d.ts +25 -0
  94. package/LexicalComposer.dev.js +134 -0
  95. package/LexicalComposer.dev.mjs +132 -0
  96. package/LexicalComposer.js +11 -0
  97. package/LexicalComposer.js.flow +40 -0
  98. package/LexicalComposer.mjs +12 -0
  99. package/LexicalComposer.node.mjs +10 -0
  100. package/LexicalComposer.prod.js +9 -0
  101. package/LexicalComposer.prod.mjs +9 -0
  102. package/LexicalComposerContext.d.ts +18 -0
  103. package/LexicalComposerContext.dev.js +55 -0
  104. package/LexicalComposerContext.dev.mjs +51 -0
  105. package/LexicalComposerContext.js +11 -0
  106. package/LexicalComposerContext.js.flow +27 -0
  107. package/LexicalComposerContext.mjs +14 -0
  108. package/LexicalComposerContext.node.mjs +12 -0
  109. package/LexicalComposerContext.prod.js +9 -0
  110. package/LexicalComposerContext.prod.mjs +9 -0
  111. package/LexicalContentEditable.d.ts +26 -0
  112. package/LexicalContentEditable.dev.js +242 -0
  113. package/LexicalContentEditable.dev.mjs +239 -0
  114. package/LexicalContentEditable.js +11 -0
  115. package/LexicalContentEditable.js.flow +80 -0
  116. package/LexicalContentEditable.mjs +13 -0
  117. package/LexicalContentEditable.node.mjs +11 -0
  118. package/LexicalContentEditable.prod.js +9 -0
  119. package/LexicalContentEditable.prod.mjs +9 -0
  120. package/LexicalContextMenuPlugin.d.ts +42 -0
  121. package/LexicalContextMenuPlugin.dev.js +526 -0
  122. package/LexicalContextMenuPlugin.dev.mjs +511 -0
  123. package/LexicalContextMenuPlugin.js +11 -0
  124. package/LexicalContextMenuPlugin.js.flow +13 -0
  125. package/LexicalContextMenuPlugin.mjs +13 -0
  126. package/LexicalContextMenuPlugin.node.mjs +11 -0
  127. package/LexicalContextMenuPlugin.prod.js +9 -0
  128. package/LexicalContextMenuPlugin.prod.mjs +9 -0
  129. package/LexicalDecoratorBlockNode.d.ts +25 -0
  130. package/LexicalDecoratorBlockNode.dev.js +59 -0
  131. package/LexicalDecoratorBlockNode.dev.mjs +56 -0
  132. package/LexicalDecoratorBlockNode.js +11 -0
  133. package/LexicalDecoratorBlockNode.js.flow +35 -0
  134. package/LexicalDecoratorBlockNode.mjs +13 -0
  135. package/LexicalDecoratorBlockNode.node.mjs +11 -0
  136. package/LexicalDecoratorBlockNode.prod.js +9 -0
  137. package/LexicalDecoratorBlockNode.prod.mjs +9 -0
  138. package/LexicalDraggableBlockPlugin.d.ts +18 -0
  139. package/LexicalDraggableBlockPlugin.dev.js +655 -0
  140. package/LexicalDraggableBlockPlugin.dev.mjs +653 -0
  141. package/LexicalDraggableBlockPlugin.js +11 -0
  142. package/LexicalDraggableBlockPlugin.js.flow +24 -0
  143. package/LexicalDraggableBlockPlugin.mjs +12 -0
  144. package/LexicalDraggableBlockPlugin.node.mjs +10 -0
  145. package/LexicalDraggableBlockPlugin.prod.js +9 -0
  146. package/LexicalDraggableBlockPlugin.prod.mjs +9 -0
  147. package/LexicalEditorRefPlugin.d.ts +20 -0
  148. package/LexicalEditorRefPlugin.dev.js +58 -0
  149. package/LexicalEditorRefPlugin.dev.mjs +43 -0
  150. package/LexicalEditorRefPlugin.js +11 -0
  151. package/LexicalEditorRefPlugin.js.flow +19 -0
  152. package/LexicalEditorRefPlugin.mjs +12 -0
  153. package/LexicalEditorRefPlugin.node.mjs +10 -0
  154. package/LexicalEditorRefPlugin.prod.js +9 -0
  155. package/LexicalEditorRefPlugin.prod.mjs +9 -0
  156. package/LexicalErrorBoundary.d.ts +13 -0
  157. package/LexicalErrorBoundary.dev.js +40 -0
  158. package/LexicalErrorBoundary.dev.mjs +38 -0
  159. package/LexicalErrorBoundary.js +11 -0
  160. package/LexicalErrorBoundary.js.flow +17 -0
  161. package/LexicalErrorBoundary.mjs +12 -0
  162. package/LexicalErrorBoundary.node.mjs +10 -0
  163. package/LexicalErrorBoundary.prod.js +9 -0
  164. package/LexicalErrorBoundary.prod.mjs +9 -0
  165. package/LexicalExtensionComponent.dev.js +53 -0
  166. package/LexicalExtensionComponent.dev.mjs +51 -0
  167. package/LexicalExtensionComponent.js +11 -0
  168. package/LexicalExtensionComponent.js.flow +12 -0
  169. package/LexicalExtensionComponent.mjs +12 -0
  170. package/LexicalExtensionComponent.node.mjs +10 -0
  171. package/LexicalExtensionComponent.prod.js +9 -0
  172. package/LexicalExtensionComponent.prod.mjs +9 -0
  173. package/LexicalExtensionComposer.d.ts +69 -0
  174. package/LexicalExtensionComposer.dev.js +105 -0
  175. package/LexicalExtensionComposer.dev.mjs +103 -0
  176. package/LexicalExtensionComposer.js +11 -0
  177. package/LexicalExtensionComposer.js.flow +20 -0
  178. package/LexicalExtensionComposer.mjs +12 -0
  179. package/LexicalExtensionComposer.node.mjs +10 -0
  180. package/LexicalExtensionComposer.prod.js +9 -0
  181. package/LexicalExtensionComposer.prod.mjs +9 -0
  182. package/LexicalHashtagPlugin.d.ts +9 -0
  183. package/LexicalHashtagPlugin.dev.js +34 -0
  184. package/LexicalHashtagPlugin.dev.mjs +32 -0
  185. package/LexicalHashtagPlugin.js +11 -0
  186. package/LexicalHashtagPlugin.js.flow +10 -0
  187. package/LexicalHashtagPlugin.mjs +12 -0
  188. package/LexicalHashtagPlugin.node.mjs +10 -0
  189. package/LexicalHashtagPlugin.prod.js +9 -0
  190. package/LexicalHashtagPlugin.prod.mjs +9 -0
  191. package/LexicalHistoryPlugin.d.ts +14 -0
  192. package/LexicalHistoryPlugin.dev.js +48 -0
  193. package/LexicalHistoryPlugin.dev.mjs +46 -0
  194. package/LexicalHistoryPlugin.js +11 -0
  195. package/LexicalHistoryPlugin.js.flow +28 -0
  196. package/LexicalHistoryPlugin.mjs +13 -0
  197. package/LexicalHistoryPlugin.node.mjs +11 -0
  198. package/LexicalHistoryPlugin.prod.js +9 -0
  199. package/LexicalHistoryPlugin.prod.mjs +9 -0
  200. package/LexicalHorizontalRuleNode.d.ts +25 -0
  201. package/LexicalHorizontalRuleNode.dev.js +102 -0
  202. package/LexicalHorizontalRuleNode.dev.mjs +98 -0
  203. package/LexicalHorizontalRuleNode.js +11 -0
  204. package/LexicalHorizontalRuleNode.js.flow +27 -0
  205. package/LexicalHorizontalRuleNode.mjs +15 -0
  206. package/LexicalHorizontalRuleNode.node.mjs +13 -0
  207. package/LexicalHorizontalRuleNode.prod.js +9 -0
  208. package/LexicalHorizontalRuleNode.prod.mjs +9 -0
  209. package/LexicalHorizontalRulePlugin.d.ts +8 -0
  210. package/LexicalHorizontalRulePlugin.dev.js +44 -0
  211. package/LexicalHorizontalRulePlugin.dev.mjs +42 -0
  212. package/LexicalHorizontalRulePlugin.js +11 -0
  213. package/LexicalHorizontalRulePlugin.js.flow +12 -0
  214. package/LexicalHorizontalRulePlugin.mjs +12 -0
  215. package/LexicalHorizontalRulePlugin.node.mjs +10 -0
  216. package/LexicalHorizontalRulePlugin.prod.js +9 -0
  217. package/LexicalHorizontalRulePlugin.prod.mjs +9 -0
  218. package/LexicalLinkPlugin.d.ts +14 -0
  219. package/LexicalLinkPlugin.dev.js +43 -0
  220. package/LexicalLinkPlugin.dev.mjs +41 -0
  221. package/LexicalLinkPlugin.js +11 -0
  222. package/LexicalLinkPlugin.js.flow +21 -0
  223. package/LexicalLinkPlugin.mjs +12 -0
  224. package/LexicalLinkPlugin.node.mjs +10 -0
  225. package/LexicalLinkPlugin.prod.js +9 -0
  226. package/LexicalLinkPlugin.prod.mjs +9 -0
  227. package/LexicalListPlugin.d.ts +20 -0
  228. package/LexicalListPlugin.dev.js +57 -0
  229. package/LexicalListPlugin.dev.mjs +55 -0
  230. package/LexicalListPlugin.js +11 -0
  231. package/LexicalListPlugin.js.flow +15 -0
  232. package/LexicalListPlugin.mjs +12 -0
  233. package/LexicalListPlugin.node.mjs +10 -0
  234. package/LexicalListPlugin.prod.js +9 -0
  235. package/LexicalListPlugin.prod.mjs +9 -0
  236. package/LexicalMarkdownShortcutPlugin.d.ts +12 -0
  237. package/LexicalMarkdownShortcutPlugin.dev.js +55 -0
  238. package/LexicalMarkdownShortcutPlugin.dev.mjs +52 -0
  239. package/LexicalMarkdownShortcutPlugin.js +11 -0
  240. package/LexicalMarkdownShortcutPlugin.js.flow +16 -0
  241. package/LexicalMarkdownShortcutPlugin.mjs +13 -0
  242. package/LexicalMarkdownShortcutPlugin.node.mjs +11 -0
  243. package/LexicalMarkdownShortcutPlugin.prod.js +9 -0
  244. package/LexicalMarkdownShortcutPlugin.prod.mjs +9 -0
  245. package/LexicalNestedComposer.d.ts +57 -0
  246. package/LexicalNestedComposer.dev.js +161 -0
  247. package/LexicalNestedComposer.dev.mjs +159 -0
  248. package/LexicalNestedComposer.js +11 -0
  249. package/LexicalNestedComposer.js.flow +26 -0
  250. package/LexicalNestedComposer.mjs +12 -0
  251. package/LexicalNestedComposer.node.mjs +10 -0
  252. package/LexicalNestedComposer.prod.js +9 -0
  253. package/LexicalNestedComposer.prod.mjs +9 -0
  254. package/LexicalNodeContextMenuPlugin.d.ts +46 -0
  255. package/LexicalNodeContextMenuPlugin.dev.js +257 -0
  256. package/LexicalNodeContextMenuPlugin.dev.mjs +253 -0
  257. package/LexicalNodeContextMenuPlugin.js +11 -0
  258. package/LexicalNodeContextMenuPlugin.js.flow +12 -0
  259. package/LexicalNodeContextMenuPlugin.mjs +14 -0
  260. package/LexicalNodeContextMenuPlugin.node.mjs +12 -0
  261. package/LexicalNodeContextMenuPlugin.prod.js +9 -0
  262. package/LexicalNodeContextMenuPlugin.prod.mjs +9 -0
  263. package/LexicalNodeEventPlugin.d.ts +13 -0
  264. package/LexicalNodeEventPlugin.dev.js +61 -0
  265. package/LexicalNodeEventPlugin.dev.mjs +59 -0
  266. package/LexicalNodeEventPlugin.js +11 -0
  267. package/LexicalNodeEventPlugin.js.flow +20 -0
  268. package/LexicalNodeEventPlugin.mjs +12 -0
  269. package/LexicalNodeEventPlugin.node.mjs +10 -0
  270. package/LexicalNodeEventPlugin.prod.js +9 -0
  271. package/LexicalNodeEventPlugin.prod.mjs +9 -0
  272. package/LexicalNodeMenuPlugin.d.ts +24 -0
  273. package/LexicalNodeMenuPlugin.dev.js +527 -0
  274. package/LexicalNodeMenuPlugin.dev.mjs +524 -0
  275. package/LexicalNodeMenuPlugin.js +11 -0
  276. package/LexicalNodeMenuPlugin.js.flow +64 -0
  277. package/LexicalNodeMenuPlugin.mjs +13 -0
  278. package/LexicalNodeMenuPlugin.node.mjs +11 -0
  279. package/LexicalNodeMenuPlugin.prod.js +9 -0
  280. package/LexicalNodeMenuPlugin.prod.mjs +9 -0
  281. package/LexicalOnChangePlugin.d.ts +13 -0
  282. package/LexicalOnChangePlugin.dev.js +72 -0
  283. package/LexicalOnChangePlugin.dev.mjs +70 -0
  284. package/LexicalOnChangePlugin.js +11 -0
  285. package/LexicalOnChangePlugin.js.flow +16 -0
  286. package/LexicalOnChangePlugin.mjs +12 -0
  287. package/LexicalOnChangePlugin.node.mjs +10 -0
  288. package/LexicalOnChangePlugin.prod.js +9 -0
  289. package/LexicalOnChangePlugin.prod.mjs +9 -0
  290. package/LexicalPlainTextPlugin.d.ts +14 -0
  291. package/LexicalPlainTextPlugin.dev.js +235 -0
  292. package/LexicalPlainTextPlugin.dev.mjs +233 -0
  293. package/LexicalPlainTextPlugin.js +11 -0
  294. package/LexicalPlainTextPlugin.js.flow +29 -0
  295. package/LexicalPlainTextPlugin.mjs +12 -0
  296. package/LexicalPlainTextPlugin.node.mjs +10 -0
  297. package/LexicalPlainTextPlugin.prod.js +9 -0
  298. package/LexicalPlainTextPlugin.prod.mjs +9 -0
  299. package/LexicalReactExtension.dev.js +187 -0
  300. package/LexicalReactExtension.dev.mjs +184 -0
  301. package/LexicalReactExtension.js +11 -0
  302. package/LexicalReactExtension.js.flow +68 -0
  303. package/LexicalReactExtension.mjs +13 -0
  304. package/LexicalReactExtension.node.mjs +11 -0
  305. package/LexicalReactExtension.prod.js +9 -0
  306. package/LexicalReactExtension.prod.mjs +9 -0
  307. package/LexicalReactPluginHostExtension.dev.js +189 -0
  308. package/LexicalReactPluginHostExtension.dev.mjs +181 -0
  309. package/LexicalReactPluginHostExtension.js +11 -0
  310. package/LexicalReactPluginHostExtension.js.flow +84 -0
  311. package/LexicalReactPluginHostExtension.mjs +18 -0
  312. package/LexicalReactPluginHostExtension.node.mjs +16 -0
  313. package/LexicalReactPluginHostExtension.prod.js +9 -0
  314. package/LexicalReactPluginHostExtension.prod.mjs +9 -0
  315. package/LexicalReactProviderExtension.dev.js +33 -0
  316. package/LexicalReactProviderExtension.dev.mjs +31 -0
  317. package/LexicalReactProviderExtension.js +11 -0
  318. package/LexicalReactProviderExtension.js.flow +12 -0
  319. package/LexicalReactProviderExtension.mjs +12 -0
  320. package/LexicalReactProviderExtension.node.mjs +10 -0
  321. package/LexicalReactProviderExtension.prod.js +9 -0
  322. package/LexicalReactProviderExtension.prod.mjs +9 -0
  323. package/LexicalRichTextPlugin.d.ts +14 -0
  324. package/LexicalRichTextPlugin.dev.js +235 -0
  325. package/LexicalRichTextPlugin.dev.mjs +233 -0
  326. package/LexicalRichTextPlugin.js +11 -0
  327. package/LexicalRichTextPlugin.js.flow +29 -0
  328. package/LexicalRichTextPlugin.mjs +12 -0
  329. package/LexicalRichTextPlugin.node.mjs +10 -0
  330. package/LexicalRichTextPlugin.prod.js +9 -0
  331. package/LexicalRichTextPlugin.prod.mjs +9 -0
  332. package/LexicalSelectionAlwaysOnDisplay.d.ts +12 -0
  333. package/LexicalSelectionAlwaysOnDisplay.dev.js +33 -0
  334. package/LexicalSelectionAlwaysOnDisplay.dev.mjs +31 -0
  335. package/LexicalSelectionAlwaysOnDisplay.js +11 -0
  336. package/LexicalSelectionAlwaysOnDisplay.js.flow +15 -0
  337. package/LexicalSelectionAlwaysOnDisplay.mjs +12 -0
  338. package/LexicalSelectionAlwaysOnDisplay.node.mjs +10 -0
  339. package/LexicalSelectionAlwaysOnDisplay.prod.js +9 -0
  340. package/LexicalSelectionAlwaysOnDisplay.prod.mjs +9 -0
  341. package/LexicalTabIndentationPlugin.d.ts +22 -0
  342. package/LexicalTabIndentationPlugin.dev.js +41 -0
  343. package/LexicalTabIndentationPlugin.dev.mjs +39 -0
  344. package/LexicalTabIndentationPlugin.js +11 -0
  345. package/LexicalTabIndentationPlugin.js.flow +21 -0
  346. package/LexicalTabIndentationPlugin.mjs +13 -0
  347. package/LexicalTabIndentationPlugin.node.mjs +11 -0
  348. package/LexicalTabIndentationPlugin.prod.js +9 -0
  349. package/LexicalTabIndentationPlugin.prod.mjs +9 -0
  350. package/LexicalTableOfContentsPlugin.d.ts +20 -0
  351. package/LexicalTableOfContentsPlugin.dev.js +209 -0
  352. package/LexicalTableOfContentsPlugin.dev.mjs +207 -0
  353. package/LexicalTableOfContentsPlugin.js +11 -0
  354. package/LexicalTableOfContentsPlugin.js.flow +18 -0
  355. package/LexicalTableOfContentsPlugin.mjs +12 -0
  356. package/LexicalTableOfContentsPlugin.node.mjs +10 -0
  357. package/LexicalTableOfContentsPlugin.prod.js +9 -0
  358. package/LexicalTableOfContentsPlugin.prod.mjs +9 -0
  359. package/LexicalTablePlugin.d.ts +46 -0
  360. package/LexicalTablePlugin.dev.js +84 -0
  361. package/LexicalTablePlugin.dev.mjs +82 -0
  362. package/LexicalTablePlugin.js +11 -0
  363. package/LexicalTablePlugin.js.flow +15 -0
  364. package/LexicalTablePlugin.mjs +12 -0
  365. package/LexicalTablePlugin.node.mjs +10 -0
  366. package/LexicalTablePlugin.prod.js +9 -0
  367. package/LexicalTablePlugin.prod.mjs +9 -0
  368. package/LexicalTreeView.d.ts +37 -0
  369. package/LexicalTreeView.dev.js +105 -0
  370. package/LexicalTreeView.dev.mjs +91 -0
  371. package/LexicalTreeView.js +11 -0
  372. package/LexicalTreeView.js.flow +21 -0
  373. package/LexicalTreeView.mjs +12 -0
  374. package/LexicalTreeView.node.mjs +10 -0
  375. package/LexicalTreeView.prod.js +9 -0
  376. package/LexicalTreeView.prod.mjs +9 -0
  377. package/LexicalTreeViewExtension.dev.js +57 -0
  378. package/LexicalTreeViewExtension.dev.mjs +54 -0
  379. package/LexicalTreeViewExtension.js +11 -0
  380. package/LexicalTreeViewExtension.js.flow +12 -0
  381. package/LexicalTreeViewExtension.mjs +13 -0
  382. package/LexicalTreeViewExtension.node.mjs +11 -0
  383. package/LexicalTreeViewExtension.prod.js +9 -0
  384. package/LexicalTreeViewExtension.prod.mjs +9 -0
  385. package/LexicalTypeaheadMenuPlugin.d.ts +40 -0
  386. package/LexicalTypeaheadMenuPlugin.dev.js +654 -0
  387. package/LexicalTypeaheadMenuPlugin.dev.mjs +646 -0
  388. package/LexicalTypeaheadMenuPlugin.js +11 -0
  389. package/LexicalTypeaheadMenuPlugin.js.flow +83 -0
  390. package/LexicalTypeaheadMenuPlugin.mjs +18 -0
  391. package/LexicalTypeaheadMenuPlugin.node.mjs +16 -0
  392. package/LexicalTypeaheadMenuPlugin.prod.js +9 -0
  393. package/LexicalTypeaheadMenuPlugin.prod.mjs +9 -0
  394. package/README.md +32 -0
  395. package/ReactExtension.d.ts +41 -0
  396. package/ReactPluginHostExtension.d.ts +56 -0
  397. package/ReactProviderExtension.d.ts +9 -0
  398. package/TreeViewExtension.d.ts +18 -0
  399. package/changes.json +14 -0
  400. package/package.json +1572 -0
  401. package/shared/LegacyDecorators.d.ts +23 -0
  402. package/shared/LexicalContentEditableElement.d.ts +43 -0
  403. package/shared/LexicalMenu.d.ts +52 -0
  404. package/shared/buildEditorComponent.d.ts +11 -0
  405. package/shared/mergeRefs.d.ts +9 -0
  406. package/shared/point.d.ts +21 -0
  407. package/shared/rect.d.ts +45 -0
  408. package/shared/types.d.ts +89 -0
  409. package/shared/useCanShowPlaceholder.d.ts +9 -0
  410. package/shared/useCharacterLimit.d.ts +16 -0
  411. package/shared/useDecorators.d.ts +17 -0
  412. package/shared/useHistory.d.ts +10 -0
  413. package/shared/useList.d.ts +9 -0
  414. package/shared/usePlainTextSetup.d.ts +9 -0
  415. package/shared/useReactDecorators.d.ts +12 -0
  416. package/shared/useRichTextSetup.d.ts +9 -0
  417. package/shared/useYjsCollaboration.d.ts +25 -0
  418. package/useExtensionComponent.d.ts +10 -0
  419. package/useLexicalEditable.d.ts +16 -0
  420. package/useLexicalEditable.dev.js +102 -0
  421. package/useLexicalEditable.dev.mjs +100 -0
  422. package/useLexicalEditable.js +11 -0
  423. package/useLexicalEditable.js.flow +12 -0
  424. package/useLexicalEditable.mjs +12 -0
  425. package/useLexicalEditable.node.mjs +10 -0
  426. package/useLexicalEditable.prod.js +9 -0
  427. package/useLexicalEditable.prod.mjs +9 -0
  428. package/useLexicalExtensionComponent.dev.js +37 -0
  429. package/useLexicalExtensionComponent.dev.mjs +34 -0
  430. package/useLexicalExtensionComponent.js +11 -0
  431. package/useLexicalExtensionComponent.js.flow +12 -0
  432. package/useLexicalExtensionComponent.mjs +13 -0
  433. package/useLexicalExtensionComponent.node.mjs +11 -0
  434. package/useLexicalExtensionComponent.prod.js +9 -0
  435. package/useLexicalExtensionComponent.prod.mjs +9 -0
  436. package/useLexicalIsTextContentEmpty.d.ts +9 -0
  437. package/useLexicalIsTextContentEmpty.dev.js +60 -0
  438. package/useLexicalIsTextContentEmpty.dev.mjs +58 -0
  439. package/useLexicalIsTextContentEmpty.js +11 -0
  440. package/useLexicalIsTextContentEmpty.js.flow +15 -0
  441. package/useLexicalIsTextContentEmpty.mjs +12 -0
  442. package/useLexicalIsTextContentEmpty.node.mjs +10 -0
  443. package/useLexicalIsTextContentEmpty.prod.js +9 -0
  444. package/useLexicalIsTextContentEmpty.prod.mjs +9 -0
  445. package/useLexicalNodeSelection.d.ts +24 -0
  446. package/useLexicalNodeSelection.dev.js +102 -0
  447. package/useLexicalNodeSelection.dev.mjs +100 -0
  448. package/useLexicalNodeSelection.js +11 -0
  449. package/useLexicalNodeSelection.js.flow +14 -0
  450. package/useLexicalNodeSelection.mjs +12 -0
  451. package/useLexicalNodeSelection.node.mjs +10 -0
  452. package/useLexicalNodeSelection.prod.js +9 -0
  453. package/useLexicalNodeSelection.prod.mjs +9 -0
  454. package/useLexicalSubscription.d.ts +17 -0
  455. package/useLexicalSubscription.dev.js +73 -0
  456. package/useLexicalSubscription.dev.mjs +71 -0
  457. package/useLexicalSubscription.js +11 -0
  458. package/useLexicalSubscription.js.flow +19 -0
  459. package/useLexicalSubscription.mjs +12 -0
  460. package/useLexicalSubscription.node.mjs +10 -0
  461. package/useLexicalSubscription.prod.js +9 -0
  462. package/useLexicalSubscription.prod.mjs +9 -0
  463. package/useLexicalTextEntity.d.ts +10 -0
  464. package/useLexicalTextEntity.dev.js +31 -0
  465. package/useLexicalTextEntity.dev.mjs +29 -0
  466. package/useLexicalTextEntity.js +11 -0
  467. package/useLexicalTextEntity.js.flow +18 -0
  468. package/useLexicalTextEntity.mjs +12 -0
  469. package/useLexicalTextEntity.node.mjs +10 -0
  470. package/useLexicalTextEntity.prod.js +9 -0
  471. package/useLexicalTextEntity.prod.mjs +9 -0
@@ -0,0 +1,257 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+
9
+ 'use strict';
10
+
11
+ var react$1 = require('@floating-ui/react');
12
+ var LexicalComposerContext = require('@lexical/react/LexicalComposerContext');
13
+ var lexical = require('lexical');
14
+ var react = require('react');
15
+ var jsxRuntime = require('react/jsx-runtime');
16
+
17
+ /**
18
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
19
+ *
20
+ * This source code is licensed under the MIT license found in the
21
+ * LICENSE file in the root directory of this source tree.
22
+ *
23
+ */
24
+
25
+ class MenuOption {
26
+ key;
27
+ ref;
28
+ constructor(key) {
29
+ this.key = key;
30
+ this.ref = {
31
+ current: null
32
+ };
33
+ this.setRefElement = this.setRefElement.bind(this);
34
+ }
35
+ setRefElement(element) {
36
+ this.ref = {
37
+ current: element
38
+ };
39
+ }
40
+ }
41
+ class NodeContextMenuOption extends MenuOption {
42
+ type;
43
+ title;
44
+ icon;
45
+ disabled;
46
+ $onSelect;
47
+ $showOn;
48
+ constructor(title, options) {
49
+ super(title);
50
+ this.type = 'item';
51
+ this.title = title;
52
+ this.disabled = options.disabled ?? false;
53
+ this.icon = options.icon ?? null;
54
+ this.$onSelect = options.$onSelect;
55
+ if (options.$showOn) {
56
+ this.$showOn = options.$showOn;
57
+ }
58
+ }
59
+ }
60
+ class NodeContextMenuSeparator extends MenuOption {
61
+ type;
62
+ $showOn;
63
+ constructor(options) {
64
+ super('_separator');
65
+ this.type = 'separator';
66
+ if (options && options.$showOn) {
67
+ this.$showOn = options.$showOn;
68
+ }
69
+ }
70
+ }
71
+ const ContextMenuSeparatorItem = /*#__PURE__*/react.forwardRef(({
72
+ className,
73
+ disabled,
74
+ ...props
75
+ }, ref) => {
76
+ return /*#__PURE__*/jsxRuntime.jsx("hr", {
77
+ className: className
78
+ });
79
+ });
80
+ const ContextMenuItem = /*#__PURE__*/react.forwardRef(({
81
+ className,
82
+ label,
83
+ disabled,
84
+ icon,
85
+ ...props
86
+ }, ref) => {
87
+ return /*#__PURE__*/jsxRuntime.jsxs("button", {
88
+ ...props,
89
+ className: className,
90
+ ref: ref,
91
+ role: "menuitem",
92
+ disabled: disabled,
93
+ children: [icon, label]
94
+ });
95
+ });
96
+ const NodeContextMenuPlugin = /*#__PURE__*/react.forwardRef(({
97
+ items,
98
+ className,
99
+ itemClassName,
100
+ separatorClassName
101
+ }, forwardedRef) => {
102
+ const [editor] = LexicalComposerContext.useLexicalComposerContext();
103
+ const [activeIndex, setActiveIndex] = react.useState(null);
104
+ const [isOpen, setIsOpen] = react.useState(false);
105
+ const listItemsRef = react.useRef([]);
106
+ const listContentRef = react.useRef([]);
107
+ const {
108
+ refs,
109
+ floatingStyles,
110
+ context
111
+ } = react$1.useFloating({
112
+ middleware: [react$1.offset({
113
+ alignmentAxis: 4,
114
+ mainAxis: 5
115
+ }), react$1.flip({
116
+ fallbackPlacements: ['left-start']
117
+ }), react$1.shift({
118
+ padding: 10
119
+ })],
120
+ onOpenChange: setIsOpen,
121
+ open: isOpen,
122
+ placement: 'right-start',
123
+ strategy: 'fixed',
124
+ whileElementsMounted: react$1.autoUpdate
125
+ });
126
+ const role = react$1.useRole(context, {
127
+ role: 'menu'
128
+ });
129
+ const dismiss = react$1.useDismiss(context);
130
+ const listNavigation = react$1.useListNavigation(context, {
131
+ activeIndex,
132
+ listRef: listItemsRef,
133
+ onNavigate: setActiveIndex
134
+ });
135
+ const typeahead = react$1.useTypeahead(context, {
136
+ activeIndex,
137
+ enabled: isOpen,
138
+ listRef: listContentRef,
139
+ onMatch: setActiveIndex
140
+ });
141
+ const {
142
+ getFloatingProps,
143
+ getItemProps
144
+ } = react$1.useInteractions([role, dismiss, listNavigation, typeahead]);
145
+ const [renderItems, setRenderItems] = react.useState([]);
146
+ react.useEffect(() => {
147
+ function onContextMenu(e) {
148
+ e.preventDefault();
149
+ refs.setPositionReference({
150
+ getBoundingClientRect() {
151
+ return {
152
+ bottom: e.clientY,
153
+ height: 0,
154
+ left: e.clientX,
155
+ right: e.clientX,
156
+ top: e.clientY,
157
+ width: 0,
158
+ x: e.clientX,
159
+ y: e.clientY
160
+ };
161
+ }
162
+ });
163
+ let visibleItems = [];
164
+ if (items) {
165
+ editor.read(() => {
166
+ const node = lexical.$getNearestNodeFromDOMNode(e.target);
167
+ if (node) {
168
+ visibleItems = items.filter(option => option.$showOn ? option.$showOn(node) : true);
169
+ }
170
+ });
171
+ }
172
+ const renderableItems = visibleItems.map((option, index) => {
173
+ if (option.type === 'separator') {
174
+ return {
175
+ className: separatorClassName,
176
+ key: option.key + '-' + index,
177
+ type: option.type
178
+ };
179
+ } else {
180
+ return {
181
+ className: itemClassName,
182
+ disabled: option.disabled,
183
+ icon: option.icon,
184
+ key: option.key,
185
+ label: option.title,
186
+ onClick: () => editor.update(() => option.$onSelect()),
187
+ title: option.title,
188
+ type: option.type
189
+ };
190
+ }
191
+ });
192
+ listContentRef.current = renderableItems.map(item => item.key);
193
+ setRenderItems(renderableItems);
194
+ setIsOpen(true);
195
+ }
196
+ return editor.registerRootListener((rootElement, prevRootElement) => {
197
+ if (prevRootElement !== null) {
198
+ prevRootElement.removeEventListener('contextmenu', onContextMenu);
199
+ }
200
+ if (rootElement !== null) {
201
+ rootElement.addEventListener('contextmenu', onContextMenu);
202
+ }
203
+ });
204
+ }, [items, itemClassName, separatorClassName, refs, editor]);
205
+ return /*#__PURE__*/jsxRuntime.jsx(react$1.FloatingPortal, {
206
+ children: isOpen && /*#__PURE__*/jsxRuntime.jsx(react$1.FloatingOverlay, {
207
+ lockScroll: true,
208
+ children: /*#__PURE__*/jsxRuntime.jsx(react$1.FloatingFocusManager, {
209
+ context: context,
210
+ initialFocus: refs.floating,
211
+ children: /*#__PURE__*/jsxRuntime.jsx("div", {
212
+ className: className,
213
+ ref: refs.setFloating,
214
+ style: floatingStyles,
215
+ ...getFloatingProps(),
216
+ children: renderItems.map((item, index) => {
217
+ if (item.type === 'item') {
218
+ return /*#__PURE__*/react.createElement(ContextMenuItem, {
219
+ ...getItemProps({
220
+ ...item,
221
+ onClick() {
222
+ item.onClick();
223
+ setIsOpen(false);
224
+ },
225
+ onMouseUp() {
226
+ item.onClick();
227
+ setIsOpen(false);
228
+ },
229
+ ref(node) {
230
+ listItemsRef.current[index] = node;
231
+ },
232
+ tabIndex: activeIndex === index ? 0 : -1
233
+ }),
234
+ key: item.key
235
+ });
236
+ } else if (item.type === 'separator') {
237
+ return /*#__PURE__*/react.createElement(ContextMenuSeparatorItem, {
238
+ ...getItemProps({
239
+ ...item,
240
+ ref(node) {
241
+ listItemsRef.current[index] = node;
242
+ },
243
+ tabIndex: activeIndex === index ? 0 : -1
244
+ }),
245
+ key: item.key
246
+ });
247
+ }
248
+ })
249
+ })
250
+ })
251
+ })
252
+ });
253
+ });
254
+
255
+ exports.NodeContextMenuOption = NodeContextMenuOption;
256
+ exports.NodeContextMenuPlugin = NodeContextMenuPlugin;
257
+ exports.NodeContextMenuSeparator = NodeContextMenuSeparator;
@@ -0,0 +1,253 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+
9
+ import { useFloating, autoUpdate, offset, flip, shift, useRole, useDismiss, useListNavigation, useTypeahead, useInteractions, FloatingPortal, FloatingOverlay, FloatingFocusManager } from '@floating-ui/react';
10
+ import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext';
11
+ import { $getNearestNodeFromDOMNode } from 'lexical';
12
+ import { forwardRef, useState, useRef, useEffect, createElement } from 'react';
13
+ import { jsx, jsxs } from 'react/jsx-runtime';
14
+
15
+ /**
16
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
17
+ *
18
+ * This source code is licensed under the MIT license found in the
19
+ * LICENSE file in the root directory of this source tree.
20
+ *
21
+ */
22
+
23
+ class MenuOption {
24
+ key;
25
+ ref;
26
+ constructor(key) {
27
+ this.key = key;
28
+ this.ref = {
29
+ current: null
30
+ };
31
+ this.setRefElement = this.setRefElement.bind(this);
32
+ }
33
+ setRefElement(element) {
34
+ this.ref = {
35
+ current: element
36
+ };
37
+ }
38
+ }
39
+ class NodeContextMenuOption extends MenuOption {
40
+ type;
41
+ title;
42
+ icon;
43
+ disabled;
44
+ $onSelect;
45
+ $showOn;
46
+ constructor(title, options) {
47
+ super(title);
48
+ this.type = 'item';
49
+ this.title = title;
50
+ this.disabled = options.disabled ?? false;
51
+ this.icon = options.icon ?? null;
52
+ this.$onSelect = options.$onSelect;
53
+ if (options.$showOn) {
54
+ this.$showOn = options.$showOn;
55
+ }
56
+ }
57
+ }
58
+ class NodeContextMenuSeparator extends MenuOption {
59
+ type;
60
+ $showOn;
61
+ constructor(options) {
62
+ super('_separator');
63
+ this.type = 'separator';
64
+ if (options && options.$showOn) {
65
+ this.$showOn = options.$showOn;
66
+ }
67
+ }
68
+ }
69
+ const ContextMenuSeparatorItem = /*#__PURE__*/forwardRef(({
70
+ className,
71
+ disabled,
72
+ ...props
73
+ }, ref) => {
74
+ return /*#__PURE__*/jsx("hr", {
75
+ className: className
76
+ });
77
+ });
78
+ const ContextMenuItem = /*#__PURE__*/forwardRef(({
79
+ className,
80
+ label,
81
+ disabled,
82
+ icon,
83
+ ...props
84
+ }, ref) => {
85
+ return /*#__PURE__*/jsxs("button", {
86
+ ...props,
87
+ className: className,
88
+ ref: ref,
89
+ role: "menuitem",
90
+ disabled: disabled,
91
+ children: [icon, label]
92
+ });
93
+ });
94
+ const NodeContextMenuPlugin = /*#__PURE__*/forwardRef(({
95
+ items,
96
+ className,
97
+ itemClassName,
98
+ separatorClassName
99
+ }, forwardedRef) => {
100
+ const [editor] = useLexicalComposerContext();
101
+ const [activeIndex, setActiveIndex] = useState(null);
102
+ const [isOpen, setIsOpen] = useState(false);
103
+ const listItemsRef = useRef([]);
104
+ const listContentRef = useRef([]);
105
+ const {
106
+ refs,
107
+ floatingStyles,
108
+ context
109
+ } = useFloating({
110
+ middleware: [offset({
111
+ alignmentAxis: 4,
112
+ mainAxis: 5
113
+ }), flip({
114
+ fallbackPlacements: ['left-start']
115
+ }), shift({
116
+ padding: 10
117
+ })],
118
+ onOpenChange: setIsOpen,
119
+ open: isOpen,
120
+ placement: 'right-start',
121
+ strategy: 'fixed',
122
+ whileElementsMounted: autoUpdate
123
+ });
124
+ const role = useRole(context, {
125
+ role: 'menu'
126
+ });
127
+ const dismiss = useDismiss(context);
128
+ const listNavigation = useListNavigation(context, {
129
+ activeIndex,
130
+ listRef: listItemsRef,
131
+ onNavigate: setActiveIndex
132
+ });
133
+ const typeahead = useTypeahead(context, {
134
+ activeIndex,
135
+ enabled: isOpen,
136
+ listRef: listContentRef,
137
+ onMatch: setActiveIndex
138
+ });
139
+ const {
140
+ getFloatingProps,
141
+ getItemProps
142
+ } = useInteractions([role, dismiss, listNavigation, typeahead]);
143
+ const [renderItems, setRenderItems] = useState([]);
144
+ useEffect(() => {
145
+ function onContextMenu(e) {
146
+ e.preventDefault();
147
+ refs.setPositionReference({
148
+ getBoundingClientRect() {
149
+ return {
150
+ bottom: e.clientY,
151
+ height: 0,
152
+ left: e.clientX,
153
+ right: e.clientX,
154
+ top: e.clientY,
155
+ width: 0,
156
+ x: e.clientX,
157
+ y: e.clientY
158
+ };
159
+ }
160
+ });
161
+ let visibleItems = [];
162
+ if (items) {
163
+ editor.read(() => {
164
+ const node = $getNearestNodeFromDOMNode(e.target);
165
+ if (node) {
166
+ visibleItems = items.filter(option => option.$showOn ? option.$showOn(node) : true);
167
+ }
168
+ });
169
+ }
170
+ const renderableItems = visibleItems.map((option, index) => {
171
+ if (option.type === 'separator') {
172
+ return {
173
+ className: separatorClassName,
174
+ key: option.key + '-' + index,
175
+ type: option.type
176
+ };
177
+ } else {
178
+ return {
179
+ className: itemClassName,
180
+ disabled: option.disabled,
181
+ icon: option.icon,
182
+ key: option.key,
183
+ label: option.title,
184
+ onClick: () => editor.update(() => option.$onSelect()),
185
+ title: option.title,
186
+ type: option.type
187
+ };
188
+ }
189
+ });
190
+ listContentRef.current = renderableItems.map(item => item.key);
191
+ setRenderItems(renderableItems);
192
+ setIsOpen(true);
193
+ }
194
+ return editor.registerRootListener((rootElement, prevRootElement) => {
195
+ if (prevRootElement !== null) {
196
+ prevRootElement.removeEventListener('contextmenu', onContextMenu);
197
+ }
198
+ if (rootElement !== null) {
199
+ rootElement.addEventListener('contextmenu', onContextMenu);
200
+ }
201
+ });
202
+ }, [items, itemClassName, separatorClassName, refs, editor]);
203
+ return /*#__PURE__*/jsx(FloatingPortal, {
204
+ children: isOpen && /*#__PURE__*/jsx(FloatingOverlay, {
205
+ lockScroll: true,
206
+ children: /*#__PURE__*/jsx(FloatingFocusManager, {
207
+ context: context,
208
+ initialFocus: refs.floating,
209
+ children: /*#__PURE__*/jsx("div", {
210
+ className: className,
211
+ ref: refs.setFloating,
212
+ style: floatingStyles,
213
+ ...getFloatingProps(),
214
+ children: renderItems.map((item, index) => {
215
+ if (item.type === 'item') {
216
+ return /*#__PURE__*/createElement(ContextMenuItem, {
217
+ ...getItemProps({
218
+ ...item,
219
+ onClick() {
220
+ item.onClick();
221
+ setIsOpen(false);
222
+ },
223
+ onMouseUp() {
224
+ item.onClick();
225
+ setIsOpen(false);
226
+ },
227
+ ref(node) {
228
+ listItemsRef.current[index] = node;
229
+ },
230
+ tabIndex: activeIndex === index ? 0 : -1
231
+ }),
232
+ key: item.key
233
+ });
234
+ } else if (item.type === 'separator') {
235
+ return /*#__PURE__*/createElement(ContextMenuSeparatorItem, {
236
+ ...getItemProps({
237
+ ...item,
238
+ ref(node) {
239
+ listItemsRef.current[index] = node;
240
+ },
241
+ tabIndex: activeIndex === index ? 0 : -1
242
+ }),
243
+ key: item.key
244
+ });
245
+ }
246
+ })
247
+ })
248
+ })
249
+ })
250
+ });
251
+ });
252
+
253
+ export { NodeContextMenuOption, NodeContextMenuPlugin, NodeContextMenuSeparator };
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+
9
+ 'use strict'
10
+ const LexicalNodeContextMenuPlugin = process.env.NODE_ENV !== 'production' ? require('./LexicalNodeContextMenuPlugin.dev.js') : require('./LexicalNodeContextMenuPlugin.prod.js');
11
+ module.exports = LexicalNodeContextMenuPlugin;
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ * @flow strict
8
+ */
9
+
10
+ /**
11
+ * LexicalNodeContextMenuPlugin
12
+ */
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+
9
+ import * as modDev from './LexicalNodeContextMenuPlugin.dev.mjs';
10
+ import * as modProd from './LexicalNodeContextMenuPlugin.prod.mjs';
11
+ const mod = process.env.NODE_ENV !== 'production' ? modDev : modProd;
12
+ export const NodeContextMenuOption = mod.NodeContextMenuOption;
13
+ export const NodeContextMenuPlugin = mod.NodeContextMenuPlugin;
14
+ export const NodeContextMenuSeparator = mod.NodeContextMenuSeparator;
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+
9
+ const mod = await (process.env.NODE_ENV !== 'production' ? import('./LexicalNodeContextMenuPlugin.dev.mjs') : import('./LexicalNodeContextMenuPlugin.prod.mjs'));
10
+ export const NodeContextMenuOption = mod.NodeContextMenuOption;
11
+ export const NodeContextMenuPlugin = mod.NodeContextMenuPlugin;
12
+ export const NodeContextMenuSeparator = mod.NodeContextMenuSeparator;
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+
9
+ "use strict";var e=require("@floating-ui/react"),t=require("@lexical/react/LexicalComposerContext"),s=require("lexical"),n=require("react"),i=require("react/jsx-runtime");class a{key;ref;constructor(e){this.key=e,this.ref={current:null},this.setRefElement=this.setRefElement.bind(this)}setRefElement(e){this.ref={current:e}}}const l=n.forwardRef(({className:e,disabled:t,...s},n)=>i.jsx("hr",{className:e})),o=n.forwardRef(({className:e,label:t,disabled:s,icon:n,...a},l)=>i.jsxs("button",{...a,className:e,ref:l,role:"menuitem",disabled:s,children:[n,t]})),r=n.forwardRef(({items:a,className:r,itemClassName:c,separatorClassName:u},d)=>{const[m]=t.useLexicalComposerContext(),[p,h]=n.useState(null),[f,x]=n.useState(!1),y=n.useRef([]),g=n.useRef([]),{refs:N,floatingStyles:b,context:k}=e.useFloating({middleware:[e.offset({alignmentAxis:4,mainAxis:5}),e.flip({fallbackPlacements:["left-start"]}),e.shift({padding:10})],onOpenChange:x,open:f,placement:"right-start",strategy:"fixed",whileElementsMounted:e.autoUpdate}),w=e.useRole(k,{role:"menu"}),C=e.useDismiss(k),$=e.useListNavigation(k,{activeIndex:p,listRef:y,onNavigate:h}),O=e.useTypeahead(k,{activeIndex:p,enabled:f,listRef:g,onMatch:h}),{getFloatingProps:R,getItemProps:v}=e.useInteractions([w,C,$,O]),[S,E]=n.useState([]);return n.useEffect(()=>{function e(e){e.preventDefault(),N.setPositionReference({getBoundingClientRect:()=>({bottom:e.clientY,height:0,left:e.clientX,right:e.clientX,top:e.clientY,width:0,x:e.clientX,y:e.clientY})});let t=[];a&&m.read(()=>{const n=s.$getNearestNodeFromDOMNode(e.target);n&&(t=a.filter(e=>!e.$showOn||e.$showOn(n)))});const n=t.map((e,t)=>"separator"===e.type?{className:u,key:e.key+"-"+t,type:e.type}:{className:c,disabled:e.disabled,icon:e.icon,key:e.key,label:e.title,onClick:()=>m.update(()=>e.$onSelect()),title:e.title,type:e.type});g.current=n.map(e=>e.key),E(n),x(!0)}return m.registerRootListener((t,s)=>{null!==s&&s.removeEventListener("contextmenu",e),null!==t&&t.addEventListener("contextmenu",e)})},[a,c,u,N,m]),i.jsx(e.FloatingPortal,{children:f&&i.jsx(e.FloatingOverlay,{lockScroll:!0,children:i.jsx(e.FloatingFocusManager,{context:k,initialFocus:N.floating,children:i.jsx("div",{className:r,ref:N.setFloating,style:b,...R(),children:S.map((e,t)=>"item"===e.type?n.createElement(o,{...v({...e,onClick(){e.onClick(),x(!1)},onMouseUp(){e.onClick(),x(!1)},ref(e){y.current[t]=e},tabIndex:p===t?0:-1}),key:e.key}):"separator"===e.type?n.createElement(l,{...v({...e,ref(e){y.current[t]=e},tabIndex:p===t?0:-1}),key:e.key}):void 0)})})})})});exports.NodeContextMenuOption=class extends a{type;title;icon;disabled;$onSelect;$showOn;constructor(e,t){super(e),this.type="item",this.title=e,this.disabled=t.disabled??!1,this.icon=t.icon??null,this.$onSelect=t.$onSelect,t.$showOn&&(this.$showOn=t.$showOn)}},exports.NodeContextMenuPlugin=r,exports.NodeContextMenuSeparator=class extends a{type;$showOn;constructor(e){super("_separator"),this.type="separator",e&&e.$showOn&&(this.$showOn=e.$showOn)}};
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+
9
+ import{useFloating as e,autoUpdate as t,offset as n,flip as s,shift as i,useRole as l,useDismiss as o,useListNavigation as r,useTypeahead as a,useInteractions as c,FloatingPortal as m,FloatingOverlay as d,FloatingFocusManager as h}from"@floating-ui/react";import{useLexicalComposerContext as p}from"@lexical/react/LexicalComposerContext";import{$getNearestNodeFromDOMNode as u}from"lexical";import{forwardRef as f,useState as y,useRef as x,useEffect as g,createElement as b}from"react";import{jsx as k,jsxs as $}from"react/jsx-runtime";class w{key;ref;constructor(e){this.key=e,this.ref={current:null},this.setRefElement=this.setRefElement.bind(this)}setRefElement(e){this.ref={current:e}}}class N extends w{type;title;icon;disabled;$onSelect;$showOn;constructor(e,t){super(e),this.type="item",this.title=e,this.disabled=t.disabled??!1,this.icon=t.icon??null,this.$onSelect=t.$onSelect,t.$showOn&&(this.$showOn=t.$showOn)}}class O extends w{type;$showOn;constructor(e){super("_separator"),this.type="separator",e&&e.$showOn&&(this.$showOn=e.$showOn)}}const C=f(({className:e,disabled:t,...n},s)=>k("hr",{className:e})),v=f(({className:e,label:t,disabled:n,icon:s,...i},l)=>$("button",{...i,className:e,ref:l,role:"menuitem",disabled:n,children:[s,t]})),R=f(({items:f,className:$,itemClassName:w,separatorClassName:N},O)=>{const[R]=p(),[E,S]=y(null),[I,L]=y(!1),P=x([]),F=x([]),{refs:M,floatingStyles:X,context:Y}=e({middleware:[n({alignmentAxis:4,mainAxis:5}),s({fallbackPlacements:["left-start"]}),i({padding:10})],onOpenChange:L,open:I,placement:"right-start",strategy:"fixed",whileElementsMounted:t}),A=l(Y,{role:"menu"}),j=o(Y),B=r(Y,{activeIndex:E,listRef:P,onNavigate:S}),D=a(Y,{activeIndex:E,enabled:I,listRef:F,onMatch:S}),{getFloatingProps:U,getItemProps:_}=c([A,j,B,D]),[q,z]=y([]);return g(()=>{function e(e){e.preventDefault(),M.setPositionReference({getBoundingClientRect:()=>({bottom:e.clientY,height:0,left:e.clientX,right:e.clientX,top:e.clientY,width:0,x:e.clientX,y:e.clientY})});let t=[];f&&R.read(()=>{const n=u(e.target);n&&(t=f.filter(e=>!e.$showOn||e.$showOn(n)))});const n=t.map((e,t)=>"separator"===e.type?{className:N,key:e.key+"-"+t,type:e.type}:{className:w,disabled:e.disabled,icon:e.icon,key:e.key,label:e.title,onClick:()=>R.update(()=>e.$onSelect()),title:e.title,type:e.type});F.current=n.map(e=>e.key),z(n),L(!0)}return R.registerRootListener((t,n)=>{null!==n&&n.removeEventListener("contextmenu",e),null!==t&&t.addEventListener("contextmenu",e)})},[f,w,N,M,R]),k(m,{children:I&&k(d,{lockScroll:!0,children:k(h,{context:Y,initialFocus:M.floating,children:k("div",{className:$,ref:M.setFloating,style:X,...U(),children:q.map((e,t)=>"item"===e.type?b(v,{..._({...e,onClick(){e.onClick(),L(!1)},onMouseUp(){e.onClick(),L(!1)},ref(e){P.current[t]=e},tabIndex:E===t?0:-1}),key:e.key}):"separator"===e.type?b(C,{..._({...e,ref(e){P.current[t]=e},tabIndex:E===t?0:-1}),key:e.key}):void 0)})})})})});export{N as NodeContextMenuOption,R as NodeContextMenuPlugin,O as NodeContextMenuSeparator};
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+ import type { Klass, LexicalEditor, LexicalNode, NodeKey } from 'lexical';
9
+ export declare function NodeEventPlugin({ nodeType, eventType, eventListener, }: {
10
+ nodeType: Klass<LexicalNode>;
11
+ eventType: string;
12
+ eventListener: (event: Event, editor: LexicalEditor, nodeKey: NodeKey) => void;
13
+ }): null;
@@ -0,0 +1,61 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+
9
+ 'use strict';
10
+
11
+ var LexicalComposerContext = require('@lexical/react/LexicalComposerContext');
12
+ var utils = require('@lexical/utils');
13
+ var lexical = require('lexical');
14
+ var react = require('react');
15
+
16
+ /**
17
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
18
+ *
19
+ * This source code is licensed under the MIT license found in the
20
+ * LICENSE file in the root directory of this source tree.
21
+ *
22
+ */
23
+
24
+ const capturedEvents = new Set(['mouseenter', 'mouseleave']);
25
+ function NodeEventPlugin({
26
+ nodeType,
27
+ eventType,
28
+ eventListener
29
+ }) {
30
+ const [editor] = LexicalComposerContext.useLexicalComposerContext();
31
+ const listenerRef = react.useRef(eventListener);
32
+ listenerRef.current = eventListener;
33
+ react.useEffect(() => {
34
+ const isCaptured = capturedEvents.has(eventType);
35
+ const onEvent = event => {
36
+ editor.update(() => {
37
+ const nearestNode = lexical.$getNearestNodeFromDOMNode(event.target);
38
+ if (nearestNode !== null) {
39
+ const targetNode = isCaptured ? nearestNode instanceof nodeType ? nearestNode : null : utils.$findMatchingParent(nearestNode, node => node instanceof nodeType);
40
+ if (targetNode !== null) {
41
+ listenerRef.current(event, editor, targetNode.getKey());
42
+ return;
43
+ }
44
+ }
45
+ });
46
+ };
47
+ return editor.registerRootListener((rootElement, prevRootElement) => {
48
+ if (rootElement) {
49
+ rootElement.addEventListener(eventType, onEvent, isCaptured);
50
+ }
51
+ if (prevRootElement) {
52
+ prevRootElement.removeEventListener(eventType, onEvent, isCaptured);
53
+ }
54
+ });
55
+ // We intentionally don't respect changes to eventType.
56
+ // eslint-disable-next-line react-hooks/exhaustive-deps
57
+ }, [editor, nodeType]);
58
+ return null;
59
+ }
60
+
61
+ exports.NodeEventPlugin = NodeEventPlugin;