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