@ekz/lexical-react 0.40.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 (470) hide show
  1. package/@ekz/lexicalExtensionComponent.dev.js +53 -0
  2. package/@ekz/lexicalExtensionComponent.dev.mjs +51 -0
  3. package/@ekz/lexicalExtensionComponent.js +11 -0
  4. package/@ekz/lexicalExtensionComponent.mjs +12 -0
  5. package/@ekz/lexicalExtensionComponent.node.mjs +10 -0
  6. package/@ekz/lexicalExtensionComponent.prod.js +9 -0
  7. package/@ekz/lexicalExtensionComponent.prod.mjs +9 -0
  8. package/@ekz/lexicalReactExtension.dev.js +187 -0
  9. package/@ekz/lexicalReactExtension.dev.mjs +184 -0
  10. package/@ekz/lexicalReactExtension.js +11 -0
  11. package/@ekz/lexicalReactExtension.mjs +13 -0
  12. package/@ekz/lexicalReactExtension.node.mjs +11 -0
  13. package/@ekz/lexicalReactExtension.prod.js +9 -0
  14. package/@ekz/lexicalReactExtension.prod.mjs +9 -0
  15. package/@ekz/lexicalReactPluginHostExtension.dev.js +189 -0
  16. package/@ekz/lexicalReactPluginHostExtension.dev.mjs +181 -0
  17. package/@ekz/lexicalReactPluginHostExtension.js +11 -0
  18. package/@ekz/lexicalReactPluginHostExtension.mjs +18 -0
  19. package/@ekz/lexicalReactPluginHostExtension.node.mjs +16 -0
  20. package/@ekz/lexicalReactPluginHostExtension.prod.js +9 -0
  21. package/@ekz/lexicalReactPluginHostExtension.prod.mjs +9 -0
  22. package/@ekz/lexicalReactProviderExtension.dev.js +33 -0
  23. package/@ekz/lexicalReactProviderExtension.dev.mjs +31 -0
  24. package/@ekz/lexicalReactProviderExtension.js +11 -0
  25. package/@ekz/lexicalReactProviderExtension.mjs +12 -0
  26. package/@ekz/lexicalReactProviderExtension.node.mjs +10 -0
  27. package/@ekz/lexicalReactProviderExtension.prod.js +9 -0
  28. package/@ekz/lexicalReactProviderExtension.prod.mjs +9 -0
  29. package/@ekz/lexicalTreeViewExtension.dev.js +57 -0
  30. package/@ekz/lexicalTreeViewExtension.dev.mjs +54 -0
  31. package/@ekz/lexicalTreeViewExtension.js +11 -0
  32. package/@ekz/lexicalTreeViewExtension.mjs +13 -0
  33. package/@ekz/lexicalTreeViewExtension.node.mjs +11 -0
  34. package/@ekz/lexicalTreeViewExtension.prod.js +9 -0
  35. package/@ekz/lexicalTreeViewExtension.prod.mjs +9 -0
  36. package/ExtensionComponent.d.ts +42 -0
  37. package/LICENSE +21 -0
  38. package/LexicalAutoEmbedPlugin.d.ts +39 -0
  39. package/LexicalAutoEmbedPlugin.dev.js +146 -0
  40. package/LexicalAutoEmbedPlugin.dev.mjs +141 -0
  41. package/LexicalAutoEmbedPlugin.js +11 -0
  42. package/LexicalAutoEmbedPlugin.js.flow +64 -0
  43. package/LexicalAutoEmbedPlugin.mjs +15 -0
  44. package/LexicalAutoEmbedPlugin.node.mjs +13 -0
  45. package/LexicalAutoEmbedPlugin.prod.js +9 -0
  46. package/LexicalAutoEmbedPlugin.prod.mjs +9 -0
  47. package/LexicalAutoFocusPlugin.d.ts +12 -0
  48. package/LexicalAutoFocusPlugin.dev.js +47 -0
  49. package/LexicalAutoFocusPlugin.dev.mjs +45 -0
  50. package/LexicalAutoFocusPlugin.js +11 -0
  51. package/LexicalAutoFocusPlugin.js.flow +14 -0
  52. package/LexicalAutoFocusPlugin.mjs +12 -0
  53. package/LexicalAutoFocusPlugin.node.mjs +10 -0
  54. package/LexicalAutoFocusPlugin.prod.js +9 -0
  55. package/LexicalAutoFocusPlugin.prod.mjs +9 -0
  56. package/LexicalAutoLinkPlugin.d.ts +14 -0
  57. package/LexicalAutoLinkPlugin.dev.js +54 -0
  58. package/LexicalAutoLinkPlugin.dev.mjs +52 -0
  59. package/LexicalAutoLinkPlugin.js +11 -0
  60. package/LexicalAutoLinkPlugin.js.flow +18 -0
  61. package/LexicalAutoLinkPlugin.mjs +13 -0
  62. package/LexicalAutoLinkPlugin.node.mjs +11 -0
  63. package/LexicalAutoLinkPlugin.prod.js +9 -0
  64. package/LexicalAutoLinkPlugin.prod.mjs +9 -0
  65. package/LexicalBlockWithAlignableContents.d.ts +21 -0
  66. package/LexicalBlockWithAlignableContents.dev.js +81 -0
  67. package/LexicalBlockWithAlignableContents.dev.mjs +79 -0
  68. package/LexicalBlockWithAlignableContents.js +11 -0
  69. package/LexicalBlockWithAlignableContents.js.flow +28 -0
  70. package/LexicalBlockWithAlignableContents.mjs +12 -0
  71. package/LexicalBlockWithAlignableContents.node.mjs +10 -0
  72. package/LexicalBlockWithAlignableContents.prod.js +9 -0
  73. package/LexicalBlockWithAlignableContents.prod.mjs +9 -0
  74. package/LexicalCharacterLimitPlugin.d.ts +15 -0
  75. package/LexicalCharacterLimitPlugin.dev.js +292 -0
  76. package/LexicalCharacterLimitPlugin.dev.mjs +290 -0
  77. package/LexicalCharacterLimitPlugin.js +11 -0
  78. package/LexicalCharacterLimitPlugin.js.flow +12 -0
  79. package/LexicalCharacterLimitPlugin.mjs +12 -0
  80. package/LexicalCharacterLimitPlugin.node.mjs +10 -0
  81. package/LexicalCharacterLimitPlugin.prod.js +9 -0
  82. package/LexicalCharacterLimitPlugin.prod.mjs +9 -0
  83. package/LexicalCheckListPlugin.d.ts +8 -0
  84. package/LexicalCheckListPlugin.dev.js +31 -0
  85. package/LexicalCheckListPlugin.dev.mjs +29 -0
  86. package/LexicalCheckListPlugin.js +11 -0
  87. package/LexicalCheckListPlugin.js.flow +10 -0
  88. package/LexicalCheckListPlugin.mjs +12 -0
  89. package/LexicalCheckListPlugin.node.mjs +10 -0
  90. package/LexicalCheckListPlugin.prod.js +9 -0
  91. package/LexicalCheckListPlugin.prod.mjs +9 -0
  92. package/LexicalClearEditorPlugin.d.ts +13 -0
  93. package/LexicalClearEditorPlugin.dev.js +55 -0
  94. package/LexicalClearEditorPlugin.dev.mjs +53 -0
  95. package/LexicalClearEditorPlugin.js +11 -0
  96. package/LexicalClearEditorPlugin.js.flow +14 -0
  97. package/LexicalClearEditorPlugin.mjs +12 -0
  98. package/LexicalClearEditorPlugin.node.mjs +10 -0
  99. package/LexicalClearEditorPlugin.prod.js +9 -0
  100. package/LexicalClearEditorPlugin.prod.mjs +9 -0
  101. package/LexicalClickableLinkPlugin.d.ts +11 -0
  102. package/LexicalClickableLinkPlugin.dev.js +38 -0
  103. package/LexicalClickableLinkPlugin.dev.mjs +36 -0
  104. package/LexicalClickableLinkPlugin.js +11 -0
  105. package/LexicalClickableLinkPlugin.js.flow +12 -0
  106. package/LexicalClickableLinkPlugin.mjs +12 -0
  107. package/LexicalClickableLinkPlugin.node.mjs +10 -0
  108. package/LexicalClickableLinkPlugin.prod.js +9 -0
  109. package/LexicalClickableLinkPlugin.prod.mjs +9 -0
  110. package/LexicalCollaborationContext.d.ts +19 -0
  111. package/LexicalCollaborationContext.dev.js +69 -0
  112. package/LexicalCollaborationContext.dev.mjs +65 -0
  113. package/LexicalCollaborationContext.js +11 -0
  114. package/LexicalCollaborationContext.js.flow +22 -0
  115. package/LexicalCollaborationContext.mjs +14 -0
  116. package/LexicalCollaborationContext.node.mjs +12 -0
  117. package/LexicalCollaborationContext.prod.js +9 -0
  118. package/LexicalCollaborationContext.prod.mjs +9 -0
  119. package/LexicalCollaborationPlugin.d.ts +39 -0
  120. package/LexicalCollaborationPlugin.dev.js +584 -0
  121. package/LexicalCollaborationPlugin.dev.mjs +569 -0
  122. package/LexicalCollaborationPlugin.js +11 -0
  123. package/LexicalCollaborationPlugin.js.flow +50 -0
  124. package/LexicalCollaborationPlugin.mjs +13 -0
  125. package/LexicalCollaborationPlugin.node.mjs +11 -0
  126. package/LexicalCollaborationPlugin.prod.js +9 -0
  127. package/LexicalCollaborationPlugin.prod.mjs +9 -0
  128. package/LexicalComposer.d.ts +25 -0
  129. package/LexicalComposer.dev.js +134 -0
  130. package/LexicalComposer.dev.mjs +132 -0
  131. package/LexicalComposer.js +11 -0
  132. package/LexicalComposer.js.flow +40 -0
  133. package/LexicalComposer.mjs +12 -0
  134. package/LexicalComposer.node.mjs +10 -0
  135. package/LexicalComposer.prod.js +9 -0
  136. package/LexicalComposer.prod.mjs +9 -0
  137. package/LexicalComposerContext.d.ts +18 -0
  138. package/LexicalComposerContext.dev.js +55 -0
  139. package/LexicalComposerContext.dev.mjs +51 -0
  140. package/LexicalComposerContext.js +11 -0
  141. package/LexicalComposerContext.js.flow +27 -0
  142. package/LexicalComposerContext.mjs +14 -0
  143. package/LexicalComposerContext.node.mjs +12 -0
  144. package/LexicalComposerContext.prod.js +9 -0
  145. package/LexicalComposerContext.prod.mjs +9 -0
  146. package/LexicalContentEditable.d.ts +26 -0
  147. package/LexicalContentEditable.dev.js +242 -0
  148. package/LexicalContentEditable.dev.mjs +239 -0
  149. package/LexicalContentEditable.js +11 -0
  150. package/LexicalContentEditable.js.flow +80 -0
  151. package/LexicalContentEditable.mjs +13 -0
  152. package/LexicalContentEditable.node.mjs +11 -0
  153. package/LexicalContentEditable.prod.js +9 -0
  154. package/LexicalContentEditable.prod.mjs +9 -0
  155. package/LexicalContextMenuPlugin.d.ts +36 -0
  156. package/LexicalContextMenuPlugin.dev.js +524 -0
  157. package/LexicalContextMenuPlugin.dev.mjs +509 -0
  158. package/LexicalContextMenuPlugin.js +11 -0
  159. package/LexicalContextMenuPlugin.js.flow +13 -0
  160. package/LexicalContextMenuPlugin.mjs +13 -0
  161. package/LexicalContextMenuPlugin.node.mjs +11 -0
  162. package/LexicalContextMenuPlugin.prod.js +9 -0
  163. package/LexicalContextMenuPlugin.prod.mjs +9 -0
  164. package/LexicalDecoratorBlockNode.d.ts +25 -0
  165. package/LexicalDecoratorBlockNode.dev.js +59 -0
  166. package/LexicalDecoratorBlockNode.dev.mjs +56 -0
  167. package/LexicalDecoratorBlockNode.js +11 -0
  168. package/LexicalDecoratorBlockNode.js.flow +35 -0
  169. package/LexicalDecoratorBlockNode.mjs +13 -0
  170. package/LexicalDecoratorBlockNode.node.mjs +11 -0
  171. package/LexicalDecoratorBlockNode.prod.js +9 -0
  172. package/LexicalDecoratorBlockNode.prod.mjs +9 -0
  173. package/LexicalDraggableBlockPlugin.d.ts +18 -0
  174. package/LexicalDraggableBlockPlugin.dev.js +655 -0
  175. package/LexicalDraggableBlockPlugin.dev.mjs +653 -0
  176. package/LexicalDraggableBlockPlugin.js +11 -0
  177. package/LexicalDraggableBlockPlugin.js.flow +24 -0
  178. package/LexicalDraggableBlockPlugin.mjs +12 -0
  179. package/LexicalDraggableBlockPlugin.node.mjs +10 -0
  180. package/LexicalDraggableBlockPlugin.prod.js +9 -0
  181. package/LexicalDraggableBlockPlugin.prod.mjs +9 -0
  182. package/LexicalEditorRefPlugin.d.ts +20 -0
  183. package/LexicalEditorRefPlugin.dev.js +58 -0
  184. package/LexicalEditorRefPlugin.dev.mjs +43 -0
  185. package/LexicalEditorRefPlugin.js +11 -0
  186. package/LexicalEditorRefPlugin.js.flow +19 -0
  187. package/LexicalEditorRefPlugin.mjs +12 -0
  188. package/LexicalEditorRefPlugin.node.mjs +10 -0
  189. package/LexicalEditorRefPlugin.prod.js +9 -0
  190. package/LexicalEditorRefPlugin.prod.mjs +9 -0
  191. package/LexicalErrorBoundary.d.ts +13 -0
  192. package/LexicalErrorBoundary.dev.js +40 -0
  193. package/LexicalErrorBoundary.dev.mjs +38 -0
  194. package/LexicalErrorBoundary.js +11 -0
  195. package/LexicalErrorBoundary.js.flow +17 -0
  196. package/LexicalErrorBoundary.mjs +12 -0
  197. package/LexicalErrorBoundary.node.mjs +10 -0
  198. package/LexicalErrorBoundary.prod.js +9 -0
  199. package/LexicalErrorBoundary.prod.mjs +9 -0
  200. package/LexicalExtensionComponent.js.flow +12 -0
  201. package/LexicalExtensionComposer.d.ts +69 -0
  202. package/LexicalExtensionComposer.dev.js +105 -0
  203. package/LexicalExtensionComposer.dev.mjs +103 -0
  204. package/LexicalExtensionComposer.js +11 -0
  205. package/LexicalExtensionComposer.js.flow +20 -0
  206. package/LexicalExtensionComposer.mjs +12 -0
  207. package/LexicalExtensionComposer.node.mjs +10 -0
  208. package/LexicalExtensionComposer.prod.js +9 -0
  209. package/LexicalExtensionComposer.prod.mjs +9 -0
  210. package/LexicalHashtagPlugin.d.ts +9 -0
  211. package/LexicalHashtagPlugin.dev.js +34 -0
  212. package/LexicalHashtagPlugin.dev.mjs +32 -0
  213. package/LexicalHashtagPlugin.js +11 -0
  214. package/LexicalHashtagPlugin.js.flow +10 -0
  215. package/LexicalHashtagPlugin.mjs +12 -0
  216. package/LexicalHashtagPlugin.node.mjs +10 -0
  217. package/LexicalHashtagPlugin.prod.js +9 -0
  218. package/LexicalHashtagPlugin.prod.mjs +9 -0
  219. package/LexicalHistoryPlugin.d.ts +14 -0
  220. package/LexicalHistoryPlugin.dev.js +48 -0
  221. package/LexicalHistoryPlugin.dev.mjs +46 -0
  222. package/LexicalHistoryPlugin.js +11 -0
  223. package/LexicalHistoryPlugin.js.flow +28 -0
  224. package/LexicalHistoryPlugin.mjs +13 -0
  225. package/LexicalHistoryPlugin.node.mjs +11 -0
  226. package/LexicalHistoryPlugin.prod.js +9 -0
  227. package/LexicalHistoryPlugin.prod.mjs +9 -0
  228. package/LexicalHorizontalRuleNode.d.ts +25 -0
  229. package/LexicalHorizontalRuleNode.dev.js +102 -0
  230. package/LexicalHorizontalRuleNode.dev.mjs +98 -0
  231. package/LexicalHorizontalRuleNode.js +11 -0
  232. package/LexicalHorizontalRuleNode.js.flow +27 -0
  233. package/LexicalHorizontalRuleNode.mjs +15 -0
  234. package/LexicalHorizontalRuleNode.node.mjs +13 -0
  235. package/LexicalHorizontalRuleNode.prod.js +9 -0
  236. package/LexicalHorizontalRuleNode.prod.mjs +9 -0
  237. package/LexicalHorizontalRulePlugin.d.ts +8 -0
  238. package/LexicalHorizontalRulePlugin.dev.js +44 -0
  239. package/LexicalHorizontalRulePlugin.dev.mjs +42 -0
  240. package/LexicalHorizontalRulePlugin.js +11 -0
  241. package/LexicalHorizontalRulePlugin.js.flow +12 -0
  242. package/LexicalHorizontalRulePlugin.mjs +12 -0
  243. package/LexicalHorizontalRulePlugin.node.mjs +10 -0
  244. package/LexicalHorizontalRulePlugin.prod.js +9 -0
  245. package/LexicalHorizontalRulePlugin.prod.mjs +9 -0
  246. package/LexicalLinkPlugin.d.ts +14 -0
  247. package/LexicalLinkPlugin.dev.js +43 -0
  248. package/LexicalLinkPlugin.dev.mjs +41 -0
  249. package/LexicalLinkPlugin.js +11 -0
  250. package/LexicalLinkPlugin.js.flow +21 -0
  251. package/LexicalLinkPlugin.mjs +12 -0
  252. package/LexicalLinkPlugin.node.mjs +10 -0
  253. package/LexicalLinkPlugin.prod.js +9 -0
  254. package/LexicalLinkPlugin.prod.mjs +9 -0
  255. package/LexicalListPlugin.d.ts +20 -0
  256. package/LexicalListPlugin.dev.js +55 -0
  257. package/LexicalListPlugin.dev.mjs +53 -0
  258. package/LexicalListPlugin.js +11 -0
  259. package/LexicalListPlugin.js.flow +15 -0
  260. package/LexicalListPlugin.mjs +12 -0
  261. package/LexicalListPlugin.node.mjs +10 -0
  262. package/LexicalListPlugin.prod.js +9 -0
  263. package/LexicalListPlugin.prod.mjs +9 -0
  264. package/LexicalMarkdownShortcutPlugin.d.ts +12 -0
  265. package/LexicalMarkdownShortcutPlugin.dev.js +55 -0
  266. package/LexicalMarkdownShortcutPlugin.dev.mjs +52 -0
  267. package/LexicalMarkdownShortcutPlugin.js +11 -0
  268. package/LexicalMarkdownShortcutPlugin.js.flow +16 -0
  269. package/LexicalMarkdownShortcutPlugin.mjs +13 -0
  270. package/LexicalMarkdownShortcutPlugin.node.mjs +11 -0
  271. package/LexicalMarkdownShortcutPlugin.prod.js +9 -0
  272. package/LexicalMarkdownShortcutPlugin.prod.mjs +9 -0
  273. package/LexicalNestedComposer.d.ts +57 -0
  274. package/LexicalNestedComposer.dev.js +161 -0
  275. package/LexicalNestedComposer.dev.mjs +159 -0
  276. package/LexicalNestedComposer.js +11 -0
  277. package/LexicalNestedComposer.js.flow +26 -0
  278. package/LexicalNestedComposer.mjs +12 -0
  279. package/LexicalNestedComposer.node.mjs +10 -0
  280. package/LexicalNestedComposer.prod.js +9 -0
  281. package/LexicalNestedComposer.prod.mjs +9 -0
  282. package/LexicalNodeContextMenuPlugin.d.ts +46 -0
  283. package/LexicalNodeContextMenuPlugin.dev.js +257 -0
  284. package/LexicalNodeContextMenuPlugin.dev.mjs +253 -0
  285. package/LexicalNodeContextMenuPlugin.js +11 -0
  286. package/LexicalNodeContextMenuPlugin.js.flow +12 -0
  287. package/LexicalNodeContextMenuPlugin.mjs +14 -0
  288. package/LexicalNodeContextMenuPlugin.node.mjs +12 -0
  289. package/LexicalNodeContextMenuPlugin.prod.js +9 -0
  290. package/LexicalNodeContextMenuPlugin.prod.mjs +9 -0
  291. package/LexicalNodeEventPlugin.d.ts +13 -0
  292. package/LexicalNodeEventPlugin.dev.js +61 -0
  293. package/LexicalNodeEventPlugin.dev.mjs +59 -0
  294. package/LexicalNodeEventPlugin.js +11 -0
  295. package/LexicalNodeEventPlugin.js.flow +20 -0
  296. package/LexicalNodeEventPlugin.mjs +12 -0
  297. package/LexicalNodeEventPlugin.node.mjs +10 -0
  298. package/LexicalNodeEventPlugin.prod.js +9 -0
  299. package/LexicalNodeEventPlugin.prod.mjs +9 -0
  300. package/LexicalNodeMenuPlugin.d.ts +24 -0
  301. package/LexicalNodeMenuPlugin.dev.js +527 -0
  302. package/LexicalNodeMenuPlugin.dev.mjs +524 -0
  303. package/LexicalNodeMenuPlugin.js +11 -0
  304. package/LexicalNodeMenuPlugin.js.flow +64 -0
  305. package/LexicalNodeMenuPlugin.mjs +13 -0
  306. package/LexicalNodeMenuPlugin.node.mjs +11 -0
  307. package/LexicalNodeMenuPlugin.prod.js +9 -0
  308. package/LexicalNodeMenuPlugin.prod.mjs +9 -0
  309. package/LexicalOnChangePlugin.d.ts +13 -0
  310. package/LexicalOnChangePlugin.dev.js +72 -0
  311. package/LexicalOnChangePlugin.dev.mjs +70 -0
  312. package/LexicalOnChangePlugin.js +11 -0
  313. package/LexicalOnChangePlugin.js.flow +16 -0
  314. package/LexicalOnChangePlugin.mjs +12 -0
  315. package/LexicalOnChangePlugin.node.mjs +10 -0
  316. package/LexicalOnChangePlugin.prod.js +9 -0
  317. package/LexicalOnChangePlugin.prod.mjs +9 -0
  318. package/LexicalPlainTextPlugin.d.ts +14 -0
  319. package/LexicalPlainTextPlugin.dev.js +235 -0
  320. package/LexicalPlainTextPlugin.dev.mjs +233 -0
  321. package/LexicalPlainTextPlugin.js +11 -0
  322. package/LexicalPlainTextPlugin.js.flow +29 -0
  323. package/LexicalPlainTextPlugin.mjs +12 -0
  324. package/LexicalPlainTextPlugin.node.mjs +10 -0
  325. package/LexicalPlainTextPlugin.prod.js +9 -0
  326. package/LexicalPlainTextPlugin.prod.mjs +9 -0
  327. package/LexicalReactExtension.js.flow +68 -0
  328. package/LexicalReactPluginHostExtension.js.flow +84 -0
  329. package/LexicalReactProviderExtension.js.flow +12 -0
  330. package/LexicalRichTextPlugin.d.ts +14 -0
  331. package/LexicalRichTextPlugin.dev.js +235 -0
  332. package/LexicalRichTextPlugin.dev.mjs +233 -0
  333. package/LexicalRichTextPlugin.js +11 -0
  334. package/LexicalRichTextPlugin.js.flow +29 -0
  335. package/LexicalRichTextPlugin.mjs +12 -0
  336. package/LexicalRichTextPlugin.node.mjs +10 -0
  337. package/LexicalRichTextPlugin.prod.js +9 -0
  338. package/LexicalRichTextPlugin.prod.mjs +9 -0
  339. package/LexicalSelectionAlwaysOnDisplay.d.ts +12 -0
  340. package/LexicalSelectionAlwaysOnDisplay.dev.js +33 -0
  341. package/LexicalSelectionAlwaysOnDisplay.dev.mjs +31 -0
  342. package/LexicalSelectionAlwaysOnDisplay.js +11 -0
  343. package/LexicalSelectionAlwaysOnDisplay.js.flow +15 -0
  344. package/LexicalSelectionAlwaysOnDisplay.mjs +12 -0
  345. package/LexicalSelectionAlwaysOnDisplay.node.mjs +10 -0
  346. package/LexicalSelectionAlwaysOnDisplay.prod.js +9 -0
  347. package/LexicalSelectionAlwaysOnDisplay.prod.mjs +9 -0
  348. package/LexicalTabIndentationPlugin.d.ts +17 -0
  349. package/LexicalTabIndentationPlugin.dev.js +40 -0
  350. package/LexicalTabIndentationPlugin.dev.mjs +38 -0
  351. package/LexicalTabIndentationPlugin.js +11 -0
  352. package/LexicalTabIndentationPlugin.js.flow +21 -0
  353. package/LexicalTabIndentationPlugin.mjs +13 -0
  354. package/LexicalTabIndentationPlugin.node.mjs +11 -0
  355. package/LexicalTabIndentationPlugin.prod.js +9 -0
  356. package/LexicalTabIndentationPlugin.prod.mjs +9 -0
  357. package/LexicalTableOfContentsPlugin.d.ts +20 -0
  358. package/LexicalTableOfContentsPlugin.dev.js +209 -0
  359. package/LexicalTableOfContentsPlugin.dev.mjs +207 -0
  360. package/LexicalTableOfContentsPlugin.js +11 -0
  361. package/LexicalTableOfContentsPlugin.js.flow +18 -0
  362. package/LexicalTableOfContentsPlugin.mjs +12 -0
  363. package/LexicalTableOfContentsPlugin.node.mjs +10 -0
  364. package/LexicalTableOfContentsPlugin.prod.js +9 -0
  365. package/LexicalTableOfContentsPlugin.prod.mjs +9 -0
  366. package/LexicalTablePlugin.d.ts +46 -0
  367. package/LexicalTablePlugin.dev.js +81 -0
  368. package/LexicalTablePlugin.dev.mjs +79 -0
  369. package/LexicalTablePlugin.js +11 -0
  370. package/LexicalTablePlugin.js.flow +15 -0
  371. package/LexicalTablePlugin.mjs +12 -0
  372. package/LexicalTablePlugin.node.mjs +10 -0
  373. package/LexicalTablePlugin.prod.js +9 -0
  374. package/LexicalTablePlugin.prod.mjs +9 -0
  375. package/LexicalTreeView.d.ts +37 -0
  376. package/LexicalTreeView.dev.js +105 -0
  377. package/LexicalTreeView.dev.mjs +91 -0
  378. package/LexicalTreeView.js +11 -0
  379. package/LexicalTreeView.js.flow +21 -0
  380. package/LexicalTreeView.mjs +12 -0
  381. package/LexicalTreeView.node.mjs +10 -0
  382. package/LexicalTreeView.prod.js +9 -0
  383. package/LexicalTreeView.prod.mjs +9 -0
  384. package/LexicalTreeViewExtension.js.flow +12 -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 +90 -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/package.json +1549 -0
  400. package/shared/LegacyDecorators.d.ts +23 -0
  401. package/shared/LexicalContentEditableElement.d.ts +43 -0
  402. package/shared/LexicalMenu.d.ts +52 -0
  403. package/shared/buildEditorComponent.d.ts +11 -0
  404. package/shared/mergeRefs.d.ts +9 -0
  405. package/shared/point.d.ts +21 -0
  406. package/shared/rect.d.ts +45 -0
  407. package/shared/types.d.ts +89 -0
  408. package/shared/useCanShowPlaceholder.d.ts +9 -0
  409. package/shared/useCharacterLimit.d.ts +16 -0
  410. package/shared/useDecorators.d.ts +17 -0
  411. package/shared/useHistory.d.ts +10 -0
  412. package/shared/useList.d.ts +9 -0
  413. package/shared/usePlainTextSetup.d.ts +9 -0
  414. package/shared/useReactDecorators.d.ts +12 -0
  415. package/shared/useRichTextSetup.d.ts +9 -0
  416. package/shared/useYjsCollaboration.d.ts +25 -0
  417. package/useExtensionComponent.d.ts +10 -0
  418. package/useLexicalEditable.d.ts +16 -0
  419. package/useLexicalEditable.dev.js +102 -0
  420. package/useLexicalEditable.dev.mjs +100 -0
  421. package/useLexicalEditable.js +11 -0
  422. package/useLexicalEditable.js.flow +12 -0
  423. package/useLexicalEditable.mjs +12 -0
  424. package/useLexicalEditable.node.mjs +10 -0
  425. package/useLexicalEditable.prod.js +9 -0
  426. package/useLexicalEditable.prod.mjs +9 -0
  427. package/useLexicalExtensionComponent.dev.js +37 -0
  428. package/useLexicalExtensionComponent.dev.mjs +34 -0
  429. package/useLexicalExtensionComponent.js +11 -0
  430. package/useLexicalExtensionComponent.js.flow +12 -0
  431. package/useLexicalExtensionComponent.mjs +13 -0
  432. package/useLexicalExtensionComponent.node.mjs +11 -0
  433. package/useLexicalExtensionComponent.prod.js +9 -0
  434. package/useLexicalExtensionComponent.prod.mjs +9 -0
  435. package/useLexicalIsTextContentEmpty.d.ts +9 -0
  436. package/useLexicalIsTextContentEmpty.dev.js +60 -0
  437. package/useLexicalIsTextContentEmpty.dev.mjs +58 -0
  438. package/useLexicalIsTextContentEmpty.js +11 -0
  439. package/useLexicalIsTextContentEmpty.js.flow +15 -0
  440. package/useLexicalIsTextContentEmpty.mjs +12 -0
  441. package/useLexicalIsTextContentEmpty.node.mjs +10 -0
  442. package/useLexicalIsTextContentEmpty.prod.js +9 -0
  443. package/useLexicalIsTextContentEmpty.prod.mjs +9 -0
  444. package/useLexicalNodeSelection.d.ts +24 -0
  445. package/useLexicalNodeSelection.dev.js +102 -0
  446. package/useLexicalNodeSelection.dev.mjs +100 -0
  447. package/useLexicalNodeSelection.js +11 -0
  448. package/useLexicalNodeSelection.js.flow +14 -0
  449. package/useLexicalNodeSelection.mjs +12 -0
  450. package/useLexicalNodeSelection.node.mjs +10 -0
  451. package/useLexicalNodeSelection.prod.js +9 -0
  452. package/useLexicalNodeSelection.prod.mjs +9 -0
  453. package/useLexicalSubscription.d.ts +17 -0
  454. package/useLexicalSubscription.dev.js +73 -0
  455. package/useLexicalSubscription.dev.mjs +71 -0
  456. package/useLexicalSubscription.js +11 -0
  457. package/useLexicalSubscription.js.flow +19 -0
  458. package/useLexicalSubscription.mjs +12 -0
  459. package/useLexicalSubscription.node.mjs +10 -0
  460. package/useLexicalSubscription.prod.js +9 -0
  461. package/useLexicalSubscription.prod.mjs +9 -0
  462. package/useLexicalTextEntity.d.ts +10 -0
  463. package/useLexicalTextEntity.dev.js +31 -0
  464. package/useLexicalTextEntity.dev.mjs +29 -0
  465. package/useLexicalTextEntity.js +11 -0
  466. package/useLexicalTextEntity.js.flow +18 -0
  467. package/useLexicalTextEntity.mjs +12 -0
  468. package/useLexicalTextEntity.node.mjs +10 -0
  469. package/useLexicalTextEntity.prod.js +9 -0
  470. package/useLexicalTextEntity.prod.mjs +9 -0
@@ -0,0 +1,524 @@
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('@ekz/lexical-react/LexicalComposerContext');
12
+ var lexicalUtils = require('@ekz/lexical-utils');
13
+ var lexical = require('@ekz/lexical');
14
+ var React = require('react');
15
+ var jsxRuntime = require('react/jsx-runtime');
16
+
17
+ function _interopNamespaceDefault(e) {
18
+ var n = Object.create(null);
19
+ if (e) {
20
+ for (var k in e) {
21
+ n[k] = e[k];
22
+ }
23
+ }
24
+ n.default = e;
25
+ return n;
26
+ }
27
+
28
+ var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
29
+
30
+ /**
31
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
32
+ *
33
+ * This source code is licensed under the MIT license found in the
34
+ * LICENSE file in the root directory of this source tree.
35
+ *
36
+ */
37
+
38
+ const CAN_USE_DOM = typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined';
39
+
40
+ /**
41
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
42
+ *
43
+ * This source code is licensed under the MIT license found in the
44
+ * LICENSE file in the root directory of this source tree.
45
+ *
46
+ */
47
+
48
+
49
+ // This workaround is no longer necessary in React 19,
50
+ // but we currently support React >=17.x
51
+ // https://github.com/facebook/react/pull/26395
52
+ const useLayoutEffectImpl = CAN_USE_DOM ? React.useLayoutEffect : React.useEffect;
53
+
54
+ /**
55
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
56
+ *
57
+ * This source code is licensed under the MIT license found in the
58
+ * LICENSE file in the root directory of this source tree.
59
+ *
60
+ */
61
+
62
+ class MenuOption {
63
+ key;
64
+ ref;
65
+ constructor(key) {
66
+ this.key = key;
67
+ this.ref = {
68
+ current: null
69
+ };
70
+ this.setRefElement = this.setRefElement.bind(this);
71
+ }
72
+ setRefElement(element) {
73
+ this.ref = {
74
+ current: element
75
+ };
76
+ }
77
+ }
78
+ const scrollIntoViewIfNeeded = target => {
79
+ const typeaheadContainerNode = document.getElementById('typeahead-menu');
80
+ if (!typeaheadContainerNode) {
81
+ return;
82
+ }
83
+ const typeaheadRect = typeaheadContainerNode.getBoundingClientRect();
84
+ if (typeaheadRect.top + typeaheadRect.height > window.innerHeight) {
85
+ typeaheadContainerNode.scrollIntoView({
86
+ block: 'center'
87
+ });
88
+ }
89
+ if (typeaheadRect.top < 0) {
90
+ typeaheadContainerNode.scrollIntoView({
91
+ block: 'center'
92
+ });
93
+ }
94
+ target.scrollIntoView({
95
+ block: 'nearest'
96
+ });
97
+ };
98
+
99
+ /**
100
+ * Walk backwards along user input and forward through entity title to try
101
+ * and replace more of the user's text with entity.
102
+ */
103
+ function getFullMatchOffset(documentText, entryText, offset) {
104
+ let triggerOffset = offset;
105
+ for (let i = triggerOffset; i <= entryText.length; i++) {
106
+ if (documentText.slice(-i) === entryText.substring(0, i)) {
107
+ triggerOffset = i;
108
+ }
109
+ }
110
+ return triggerOffset;
111
+ }
112
+
113
+ /**
114
+ * Split Lexical TextNode and return a new TextNode only containing matched text.
115
+ * Common use cases include: removing the node, replacing with a new node.
116
+ */
117
+ function $splitNodeContainingQuery(match) {
118
+ const selection = lexical.$getSelection();
119
+ if (!lexical.$isRangeSelection(selection) || !selection.isCollapsed()) {
120
+ return null;
121
+ }
122
+ const anchor = selection.anchor;
123
+ if (anchor.type !== 'text') {
124
+ return null;
125
+ }
126
+ const anchorNode = anchor.getNode();
127
+ if (!anchorNode.isSimpleText()) {
128
+ return null;
129
+ }
130
+ const selectionOffset = anchor.offset;
131
+ const textContent = anchorNode.getTextContent().slice(0, selectionOffset);
132
+ const characterOffset = match.replaceableString.length;
133
+ const queryOffset = getFullMatchOffset(textContent, match.matchingString, characterOffset);
134
+ const startOffset = selectionOffset - queryOffset;
135
+ if (startOffset < 0) {
136
+ return null;
137
+ }
138
+ let newNode;
139
+ if (startOffset === 0) {
140
+ [newNode] = anchorNode.splitText(selectionOffset);
141
+ } else {
142
+ [, newNode] = anchorNode.splitText(startOffset, selectionOffset);
143
+ }
144
+ return newNode;
145
+ }
146
+
147
+ // Got from https://stackoverflow.com/a/42543908/2013580
148
+ function getScrollParent(element, includeHidden) {
149
+ let style = getComputedStyle(element);
150
+ const excludeStaticParent = style.position === 'absolute';
151
+ const overflowRegex = /(auto|scroll)/;
152
+ if (style.position === 'fixed') {
153
+ return document.body;
154
+ }
155
+ for (let parent = element; parent = parent.parentElement;) {
156
+ style = getComputedStyle(parent);
157
+ if (excludeStaticParent && style.position === 'static') {
158
+ continue;
159
+ }
160
+ if (overflowRegex.test(style.overflow + style.overflowY + style.overflowX)) {
161
+ return parent;
162
+ }
163
+ }
164
+ return document.body;
165
+ }
166
+ function isTriggerVisibleInNearestScrollContainer(targetElement, containerElement) {
167
+ const tRect = targetElement.getBoundingClientRect();
168
+ const cRect = containerElement.getBoundingClientRect();
169
+ const VISIBILITY_MARGIN_PX = 6;
170
+ return tRect.top >= cRect.top - VISIBILITY_MARGIN_PX && tRect.top <= cRect.bottom + VISIBILITY_MARGIN_PX;
171
+ }
172
+
173
+ // Reposition the menu on scroll, window resize, and element resize.
174
+ function useDynamicPositioning(resolution, targetElement, onReposition, onVisibilityChange) {
175
+ const [editor] = LexicalComposerContext.useLexicalComposerContext();
176
+ React.useEffect(() => {
177
+ if (targetElement != null && resolution != null) {
178
+ const rootElement = editor.getRootElement();
179
+ const rootScrollParent = rootElement != null ? getScrollParent(rootElement) : document.body;
180
+ let ticking = false;
181
+ let previousIsInView = isTriggerVisibleInNearestScrollContainer(targetElement, rootScrollParent);
182
+ const handleScroll = function () {
183
+ if (!ticking) {
184
+ window.requestAnimationFrame(function () {
185
+ onReposition();
186
+ ticking = false;
187
+ });
188
+ ticking = true;
189
+ }
190
+ const isInView = isTriggerVisibleInNearestScrollContainer(targetElement, rootScrollParent);
191
+ if (isInView !== previousIsInView) {
192
+ previousIsInView = isInView;
193
+ if (onVisibilityChange != null) {
194
+ onVisibilityChange(isInView);
195
+ }
196
+ }
197
+ };
198
+ const resizeObserver = new ResizeObserver(onReposition);
199
+ window.addEventListener('resize', onReposition);
200
+ document.addEventListener('scroll', handleScroll, {
201
+ capture: true,
202
+ passive: true
203
+ });
204
+ resizeObserver.observe(targetElement);
205
+ return () => {
206
+ resizeObserver.unobserve(targetElement);
207
+ window.removeEventListener('resize', onReposition);
208
+ document.removeEventListener('scroll', handleScroll, true);
209
+ };
210
+ }
211
+ }, [targetElement, editor, onVisibilityChange, onReposition, resolution]);
212
+ }
213
+ const SCROLL_TYPEAHEAD_OPTION_INTO_VIEW_COMMAND = lexical.createCommand('SCROLL_TYPEAHEAD_OPTION_INTO_VIEW_COMMAND');
214
+ function LexicalMenu({
215
+ close,
216
+ editor,
217
+ anchorElementRef,
218
+ resolution,
219
+ options,
220
+ menuRenderFn,
221
+ onSelectOption,
222
+ shouldSplitNodeWithQuery = false,
223
+ commandPriority = lexical.COMMAND_PRIORITY_LOW,
224
+ preselectFirstItem = true
225
+ }) {
226
+ const [rawSelectedIndex, setHighlightedIndex] = React.useState(null);
227
+ // Clamp highlighted index if options list shrinks
228
+ const selectedIndex = rawSelectedIndex !== null ? Math.min(options.length - 1, rawSelectedIndex) : null;
229
+ const matchingString = resolution.match && resolution.match.matchingString;
230
+ React.useEffect(() => {
231
+ if (preselectFirstItem) {
232
+ setHighlightedIndex(0);
233
+ }
234
+ }, [matchingString, preselectFirstItem]);
235
+ const selectOptionAndCleanUp = React.useCallback(selectedEntry => {
236
+ editor.update(() => {
237
+ const textNodeContainingQuery = resolution.match != null && shouldSplitNodeWithQuery ? $splitNodeContainingQuery(resolution.match) : null;
238
+ onSelectOption(selectedEntry, textNodeContainingQuery, close, resolution.match ? resolution.match.matchingString : '');
239
+ });
240
+ }, [editor, shouldSplitNodeWithQuery, resolution.match, onSelectOption, close]);
241
+ const updateSelectedIndex = React.useCallback(index => {
242
+ const rootElem = editor.getRootElement();
243
+ if (rootElem !== null) {
244
+ rootElem.setAttribute('aria-activedescendant', 'typeahead-item-' + index);
245
+ setHighlightedIndex(index);
246
+ }
247
+ }, [editor]);
248
+ React.useEffect(() => {
249
+ return () => {
250
+ const rootElem = editor.getRootElement();
251
+ if (rootElem !== null) {
252
+ rootElem.removeAttribute('aria-activedescendant');
253
+ }
254
+ };
255
+ }, [editor]);
256
+ useLayoutEffectImpl(() => {
257
+ if (options === null) {
258
+ setHighlightedIndex(null);
259
+ } else if (selectedIndex === null && preselectFirstItem) {
260
+ updateSelectedIndex(0);
261
+ }
262
+ }, [options, selectedIndex, updateSelectedIndex, preselectFirstItem]);
263
+ React.useEffect(() => {
264
+ return lexicalUtils.mergeRegister(editor.registerCommand(SCROLL_TYPEAHEAD_OPTION_INTO_VIEW_COMMAND, ({
265
+ option
266
+ }) => {
267
+ if (option.ref && option.ref.current != null) {
268
+ scrollIntoViewIfNeeded(option.ref.current);
269
+ return true;
270
+ }
271
+ return false;
272
+ }, commandPriority));
273
+ }, [editor, updateSelectedIndex, commandPriority]);
274
+ React.useEffect(() => {
275
+ return lexicalUtils.mergeRegister(editor.registerCommand(lexical.KEY_ARROW_DOWN_COMMAND, payload => {
276
+ const event = payload;
277
+ if (options !== null && options.length) {
278
+ const newSelectedIndex = selectedIndex === null ? 0 : selectedIndex !== options.length - 1 ? selectedIndex + 1 : 0;
279
+ updateSelectedIndex(newSelectedIndex);
280
+ const option = options[newSelectedIndex];
281
+ if (!option) {
282
+ updateSelectedIndex(-1);
283
+ event.preventDefault();
284
+ event.stopImmediatePropagation();
285
+ return true;
286
+ }
287
+ if (option.ref && option.ref.current) {
288
+ editor.dispatchCommand(SCROLL_TYPEAHEAD_OPTION_INTO_VIEW_COMMAND, {
289
+ index: newSelectedIndex,
290
+ option
291
+ });
292
+ }
293
+ event.preventDefault();
294
+ event.stopImmediatePropagation();
295
+ }
296
+ return true;
297
+ }, commandPriority), editor.registerCommand(lexical.KEY_ARROW_UP_COMMAND, payload => {
298
+ const event = payload;
299
+ if (options !== null && options.length) {
300
+ const newSelectedIndex = selectedIndex === null ? options.length - 1 : selectedIndex !== 0 ? selectedIndex - 1 : options.length - 1;
301
+ updateSelectedIndex(newSelectedIndex);
302
+ const option = options[newSelectedIndex];
303
+ if (!option) {
304
+ updateSelectedIndex(-1);
305
+ event.preventDefault();
306
+ event.stopImmediatePropagation();
307
+ return true;
308
+ }
309
+ if (option.ref && option.ref.current) {
310
+ scrollIntoViewIfNeeded(option.ref.current);
311
+ }
312
+ event.preventDefault();
313
+ event.stopImmediatePropagation();
314
+ }
315
+ return true;
316
+ }, commandPriority), editor.registerCommand(lexical.KEY_ESCAPE_COMMAND, payload => {
317
+ const event = payload;
318
+ event.preventDefault();
319
+ event.stopImmediatePropagation();
320
+ close();
321
+ return true;
322
+ }, commandPriority), editor.registerCommand(lexical.KEY_TAB_COMMAND, payload => {
323
+ const event = payload;
324
+ if (options === null || selectedIndex === null || options[selectedIndex] == null) {
325
+ return false;
326
+ }
327
+ event.preventDefault();
328
+ event.stopImmediatePropagation();
329
+ selectOptionAndCleanUp(options[selectedIndex]);
330
+ return true;
331
+ }, commandPriority), editor.registerCommand(lexical.KEY_ENTER_COMMAND, event => {
332
+ if (options === null || selectedIndex === null || options[selectedIndex] == null) {
333
+ return false;
334
+ }
335
+ if (event !== null) {
336
+ event.preventDefault();
337
+ event.stopImmediatePropagation();
338
+ }
339
+ selectOptionAndCleanUp(options[selectedIndex]);
340
+ return true;
341
+ }, commandPriority));
342
+ }, [selectOptionAndCleanUp, close, editor, options, selectedIndex, updateSelectedIndex, commandPriority]);
343
+ const listItemProps = React.useMemo(() => ({
344
+ options,
345
+ selectOptionAndCleanUp,
346
+ selectedIndex,
347
+ setHighlightedIndex
348
+ }), [selectOptionAndCleanUp, selectedIndex, options]);
349
+ return menuRenderFn(anchorElementRef, listItemProps, resolution.match ? resolution.match.matchingString : '');
350
+ }
351
+ function setContainerDivAttributes(containerDiv, className) {
352
+ if (className != null) {
353
+ containerDiv.className = className;
354
+ }
355
+ containerDiv.setAttribute('aria-label', 'Typeahead menu');
356
+ containerDiv.setAttribute('role', 'listbox');
357
+ containerDiv.style.display = 'block';
358
+ containerDiv.style.position = 'absolute';
359
+ }
360
+ function useMenuAnchorRef(resolution, setResolution, className, parent = CAN_USE_DOM ? document.body : undefined, shouldIncludePageYOffset__EXPERIMENTAL = true) {
361
+ const [editor] = LexicalComposerContext.useLexicalComposerContext();
362
+ const initialAnchorElement = CAN_USE_DOM ? document.createElement('div') : null;
363
+ const anchorElementRef = React.useRef(initialAnchorElement);
364
+ const positionMenu = React.useCallback(() => {
365
+ if (anchorElementRef.current === null || parent === undefined) {
366
+ return;
367
+ }
368
+ anchorElementRef.current.style.top = anchorElementRef.current.style.bottom;
369
+ const rootElement = editor.getRootElement();
370
+ const containerDiv = anchorElementRef.current;
371
+ const menuEle = containerDiv.firstChild;
372
+ if (rootElement !== null && resolution !== null) {
373
+ const {
374
+ left,
375
+ top,
376
+ width,
377
+ height
378
+ } = resolution.getRect();
379
+ const anchorHeight = anchorElementRef.current.offsetHeight; // use to position under anchor
380
+ containerDiv.style.top = `${top + anchorHeight + 3 + (shouldIncludePageYOffset__EXPERIMENTAL ? window.pageYOffset : 0)}px`;
381
+ containerDiv.style.left = `${left + window.pageXOffset}px`;
382
+ containerDiv.style.height = `${height}px`;
383
+ containerDiv.style.width = `${width}px`;
384
+ if (menuEle !== null) {
385
+ menuEle.style.top = `${top}`;
386
+ const menuRect = menuEle.getBoundingClientRect();
387
+ const menuHeight = menuRect.height;
388
+ const menuWidth = menuRect.width;
389
+ const rootElementRect = rootElement.getBoundingClientRect();
390
+ if (left + menuWidth > rootElementRect.right) {
391
+ containerDiv.style.left = `${rootElementRect.right - menuWidth + window.pageXOffset}px`;
392
+ }
393
+ if ((top + menuHeight > window.innerHeight || top + menuHeight > rootElementRect.bottom) && top - rootElementRect.top > menuHeight + height) {
394
+ containerDiv.style.top = `${top - menuHeight - height + (shouldIncludePageYOffset__EXPERIMENTAL ? window.pageYOffset : 0)}px`;
395
+ }
396
+ }
397
+ if (!containerDiv.isConnected) {
398
+ setContainerDivAttributes(containerDiv, className);
399
+ parent.append(containerDiv);
400
+ }
401
+ containerDiv.setAttribute('id', 'typeahead-menu');
402
+ rootElement.setAttribute('aria-controls', 'typeahead-menu');
403
+ }
404
+ }, [editor, resolution, shouldIncludePageYOffset__EXPERIMENTAL, className, parent]);
405
+ React.useEffect(() => {
406
+ const rootElement = editor.getRootElement();
407
+ if (resolution !== null) {
408
+ positionMenu();
409
+ }
410
+ return () => {
411
+ if (rootElement !== null) {
412
+ rootElement.removeAttribute('aria-controls');
413
+ }
414
+ // eslint-disable-next-line react-hooks/exhaustive-deps
415
+ const containerDiv = anchorElementRef.current;
416
+ if (containerDiv !== null && containerDiv.isConnected) {
417
+ containerDiv.remove();
418
+ containerDiv.removeAttribute('id');
419
+ }
420
+ };
421
+ }, [editor, positionMenu, resolution]);
422
+ const onVisibilityChange = React.useCallback(isInView => {
423
+ if (resolution !== null) {
424
+ if (!isInView) {
425
+ setResolution(null);
426
+ }
427
+ }
428
+ }, [resolution, setResolution]);
429
+ useDynamicPositioning(resolution, anchorElementRef.current, positionMenu, onVisibilityChange);
430
+
431
+ // Append the context for the menu immediately
432
+ if (initialAnchorElement != null && initialAnchorElement === anchorElementRef.current) {
433
+ setContainerDivAttributes(initialAnchorElement, className);
434
+ if (parent != null) {
435
+ parent.append(initialAnchorElement);
436
+ }
437
+ }
438
+ return anchorElementRef;
439
+ }
440
+
441
+ /**
442
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
443
+ *
444
+ * This source code is licensed under the MIT license found in the
445
+ * LICENSE file in the root directory of this source tree.
446
+ *
447
+ */
448
+
449
+ const PRE_PORTAL_DIV_SIZE = 1;
450
+
451
+ /**
452
+ * @deprecated Use LexicalNodeContextMenuPlugin instead.
453
+ */
454
+ function LexicalContextMenuPlugin({
455
+ options,
456
+ onWillOpen,
457
+ onClose,
458
+ onOpen,
459
+ onSelectOption,
460
+ menuRenderFn: contextMenuRenderFn,
461
+ anchorClassName,
462
+ commandPriority = lexical.COMMAND_PRIORITY_LOW,
463
+ parent
464
+ }) {
465
+ const [editor] = LexicalComposerContext.useLexicalComposerContext();
466
+ const [resolution, setResolution] = React.useState(null);
467
+ const menuRef = React__namespace.useRef(null);
468
+ const anchorElementRef = useMenuAnchorRef(resolution, setResolution, anchorClassName, parent);
469
+ const closeNodeMenu = React.useCallback(() => {
470
+ setResolution(null);
471
+ if (onClose != null && resolution !== null) {
472
+ onClose();
473
+ }
474
+ }, [onClose, resolution]);
475
+ const openNodeMenu = React.useCallback(res => {
476
+ setResolution(res);
477
+ if (onOpen != null && resolution === null) {
478
+ onOpen(res);
479
+ }
480
+ }, [onOpen, resolution]);
481
+ const handleContextMenu = React.useCallback(event => {
482
+ event.preventDefault();
483
+ if (onWillOpen != null) {
484
+ onWillOpen(event);
485
+ }
486
+ const zoom = lexicalUtils.calculateZoomLevel(event.target);
487
+ openNodeMenu({
488
+ getRect: () => new DOMRect(event.clientX / zoom, event.clientY / zoom, PRE_PORTAL_DIV_SIZE, PRE_PORTAL_DIV_SIZE)
489
+ });
490
+ }, [openNodeMenu, onWillOpen]);
491
+ const handleClick = React.useCallback(event => {
492
+ if (resolution !== null && menuRef.current != null && event.target != null && lexical.isDOMNode(event.target) && !menuRef.current.contains(event.target)) {
493
+ closeNodeMenu();
494
+ }
495
+ }, [closeNodeMenu, resolution]);
496
+ React.useEffect(() => {
497
+ const editorElement = editor.getRootElement();
498
+ if (editorElement) {
499
+ editorElement.addEventListener('contextmenu', handleContextMenu);
500
+ return () => editorElement.removeEventListener('contextmenu', handleContextMenu);
501
+ }
502
+ }, [editor, handleContextMenu]);
503
+ React.useEffect(() => {
504
+ document.addEventListener('click', handleClick);
505
+ return () => document.removeEventListener('click', handleClick);
506
+ }, [editor, handleClick]);
507
+ return anchorElementRef.current === null || resolution === null || editor === null ? null : /*#__PURE__*/jsxRuntime.jsx(LexicalMenu, {
508
+ close: closeNodeMenu,
509
+ resolution: resolution,
510
+ editor: editor,
511
+ anchorElementRef: anchorElementRef,
512
+ options: options,
513
+ menuRenderFn: (anchorRef, itemProps) => contextMenuRenderFn(anchorRef, itemProps, {
514
+ setMenuRef: ref => {
515
+ menuRef.current = ref;
516
+ }
517
+ }),
518
+ onSelectOption: onSelectOption,
519
+ commandPriority: commandPriority
520
+ });
521
+ }
522
+
523
+ exports.LexicalContextMenuPlugin = LexicalContextMenuPlugin;
524
+ exports.MenuOption = MenuOption;