@payloadcms/richtext-lexical 4.0.0-internal.5b1e7cd → 4.0.0-internal.c2b57ce

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 (669) hide show
  1. package/dist/exports/client/Field-VMNLDBRS.js +2 -0
  2. package/dist/exports/client/Field-VMNLDBRS.js.map +7 -0
  3. package/dist/exports/client/RelationshipComponent-RZL743CS.js +2 -0
  4. package/dist/exports/client/RelationshipComponent-RZL743CS.js.map +7 -0
  5. package/dist/exports/client/bundled.css +1 -1
  6. package/dist/exports/client/chunk-74RUDY7K.js +2 -0
  7. package/dist/exports/client/chunk-74RUDY7K.js.map +7 -0
  8. package/dist/exports/client/chunk-WSAPGI3Z.js +2 -0
  9. package/dist/exports/client/chunk-WSAPGI3Z.js.map +7 -0
  10. package/dist/exports/client/component-2ZTDKRVK.js +2 -0
  11. package/dist/exports/client/component-2ZTDKRVK.js.map +7 -0
  12. package/dist/exports/client/componentInline-JYKBUUPZ.js +2 -0
  13. package/dist/exports/client/index.d.ts +0 -2
  14. package/dist/exports/client/index.d.ts.map +1 -1
  15. package/dist/exports/client/index.js +30 -30
  16. package/dist/exports/client/index.js.map +4 -4
  17. package/dist/features/align/client/toolbarAlignGroup.d.ts.map +1 -1
  18. package/dist/features/align/client/toolbarAlignGroup.js +1 -0
  19. package/dist/features/align/client/toolbarAlignGroup.js.map +1 -1
  20. package/dist/features/blockquote/server/index.d.ts.map +1 -1
  21. package/dist/features/blockquote/server/index.js +0 -39
  22. package/dist/features/blockquote/server/index.js.map +1 -1
  23. package/dist/features/blocks/client/component/BlockContent.d.ts +10 -0
  24. package/dist/features/blocks/client/component/BlockContent.d.ts.map +1 -1
  25. package/dist/features/blocks/client/component/BlockContent.js.map +1 -1
  26. package/dist/features/blocks/client/component/index.css +178 -0
  27. package/dist/features/blocks/client/component/index.d.ts +1 -1
  28. package/dist/features/blocks/client/component/index.d.ts.map +1 -1
  29. package/dist/features/blocks/client/component/index.js +90 -18
  30. package/dist/features/blocks/client/component/index.js.map +1 -1
  31. package/dist/features/blocks/client/componentInline/components/InlineBlockContainer.d.ts.map +1 -1
  32. package/dist/features/blocks/client/componentInline/index.css +85 -0
  33. package/dist/features/blocks/client/componentInline/index.d.ts +1 -1
  34. package/dist/features/blocks/client/componentInline/index.d.ts.map +1 -1
  35. package/dist/features/blocks/client/componentInline/index.js +31 -8
  36. package/dist/features/blocks/client/componentInline/index.js.map +1 -1
  37. package/dist/features/blocks/client/index.d.ts.map +1 -1
  38. package/dist/features/blocks/client/index.js +0 -2
  39. package/dist/features/blocks/client/index.js.map +1 -1
  40. package/dist/features/blocks/client/markdown/markdownTransformer.d.ts.map +1 -1
  41. package/dist/features/blocks/premade/CodeBlock/Component/Block.d.ts +1 -1
  42. package/dist/features/blocks/premade/CodeBlock/Component/Block.d.ts.map +1 -1
  43. package/dist/features/blocks/premade/CodeBlock/Component/Block.js +3 -0
  44. package/dist/features/blocks/premade/CodeBlock/Component/Block.js.map +1 -1
  45. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.css +26 -0
  46. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.d.ts +1 -1
  47. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.d.ts.map +1 -1
  48. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.js +4 -1
  49. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.js.map +1 -1
  50. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.css +40 -0
  51. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.d.ts +1 -1
  52. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.d.ts.map +1 -1
  53. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.js +7 -8
  54. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.js.map +1 -1
  55. package/dist/features/blocks/premade/CodeBlock/Component/index.css +171 -0
  56. package/dist/features/blocks/server/graphQLPopulationPromise.d.ts.map +1 -1
  57. package/dist/features/blocks/server/markdown/markdownTransformer.d.ts.map +1 -1
  58. package/dist/features/blocks/server/validate.d.ts.map +1 -1
  59. package/dist/features/converters/htmlToLexical/index.d.ts.map +1 -1
  60. package/dist/features/converters/lexicalToHtml/async/converters/table.js +1 -1
  61. package/dist/features/converters/lexicalToHtml/async/converters/table.js.map +1 -1
  62. package/dist/features/converters/lexicalToHtml/async/converters/upload.js.map +1 -1
  63. package/dist/features/converters/lexicalToHtml/shared/cssColors.d.ts.map +1 -1
  64. package/dist/features/converters/lexicalToHtml/sync/converters/table.js +1 -1
  65. package/dist/features/converters/lexicalToHtml/sync/converters/table.js.map +1 -1
  66. package/dist/features/converters/lexicalToHtml/sync/converters/upload.js.map +1 -1
  67. package/dist/features/converters/lexicalToJSX/converter/converters/upload.js.map +1 -1
  68. package/dist/features/converters/lexicalToMarkdown/index.d.ts.map +1 -1
  69. package/dist/features/converters/markdownToLexical/index.d.ts.map +1 -1
  70. package/dist/features/debug/jsxConverter/client/plugin/index.d.ts +1 -1
  71. package/dist/features/debug/jsxConverter/client/plugin/index.d.ts.map +1 -1
  72. package/dist/features/debug/jsxConverter/client/plugin/index.js +1 -0
  73. package/dist/features/debug/jsxConverter/client/plugin/index.js.map +1 -1
  74. package/dist/features/debug/jsxConverter/client/plugin/style.css +9 -0
  75. package/dist/features/debug/testRecorder/client/plugin/index.css +51 -0
  76. package/dist/features/debug/testRecorder/client/plugin/index.d.ts +1 -1
  77. package/dist/features/debug/testRecorder/client/plugin/index.d.ts.map +1 -1
  78. package/dist/features/debug/testRecorder/client/plugin/index.js +1 -0
  79. package/dist/features/debug/testRecorder/client/plugin/index.js.map +1 -1
  80. package/dist/features/debug/treeView/client/plugin/index.css +81 -0
  81. package/dist/features/debug/treeView/client/plugin/index.d.ts +1 -1
  82. package/dist/features/debug/treeView/client/plugin/index.d.ts.map +1 -1
  83. package/dist/features/debug/treeView/client/plugin/index.js +1 -0
  84. package/dist/features/debug/treeView/client/plugin/index.js.map +1 -1
  85. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.css +91 -0
  86. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.d.ts +1 -1
  87. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.d.ts.map +1 -1
  88. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.js +3 -2
  89. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.js.map +1 -1
  90. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.css +11 -0
  91. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.d.ts +1 -1
  92. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.d.ts.map +1 -1
  93. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.js +1 -0
  94. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.js.map +1 -1
  95. package/dist/features/experimental_table/client/plugins/TableHoverActionsPlugin/index.js +1 -1
  96. package/dist/features/experimental_table/client/plugins/TableHoverActionsPlugin/index.js.map +1 -1
  97. package/dist/features/experimental_table/client/plugins/TablePlugin/TableGridPopup/index.css +166 -0
  98. package/dist/features/experimental_table/client/plugins/TablePlugin/TableGridPopup/index.d.ts +17 -0
  99. package/dist/features/experimental_table/client/plugins/TablePlugin/TableGridPopup/index.d.ts.map +1 -0
  100. package/dist/features/experimental_table/client/plugins/TablePlugin/TableGridPopup/index.js +219 -0
  101. package/dist/features/experimental_table/client/plugins/TablePlugin/TableGridPopup/index.js.map +1 -0
  102. package/dist/features/experimental_table/client/plugins/TablePlugin/index.css +235 -0
  103. package/dist/features/experimental_table/client/plugins/TablePlugin/index.d.ts +1 -1
  104. package/dist/features/experimental_table/client/plugins/TablePlugin/index.d.ts.map +1 -1
  105. package/dist/features/experimental_table/client/plugins/TablePlugin/index.js +95 -104
  106. package/dist/features/experimental_table/client/plugins/TablePlugin/index.js.map +1 -1
  107. package/dist/features/experimental_table/server/index.d.ts.map +1 -1
  108. package/dist/features/experimental_table/server/index.js +0 -102
  109. package/dist/features/experimental_table/server/index.js.map +1 -1
  110. package/dist/features/format/shared/toolbarFormatGroup.d.ts.map +1 -1
  111. package/dist/features/heading/server/index.d.ts.map +1 -1
  112. package/dist/features/heading/server/index.js +0 -39
  113. package/dist/features/heading/server/index.js.map +1 -1
  114. package/dist/features/horizontalRule/client/plugin/index.css +25 -0
  115. package/dist/features/horizontalRule/client/plugin/index.d.ts +1 -1
  116. package/dist/features/horizontalRule/client/plugin/index.d.ts.map +1 -1
  117. package/dist/features/horizontalRule/client/plugin/index.js +73 -4
  118. package/dist/features/horizontalRule/client/plugin/index.js.map +1 -1
  119. package/dist/features/horizontalRule/server/index.d.ts.map +1 -1
  120. package/dist/features/horizontalRule/server/index.js +0 -8
  121. package/dist/features/horizontalRule/server/index.js.map +1 -1
  122. package/dist/features/indent/client/toolbarIndentGroup.d.ts.map +1 -1
  123. package/dist/features/link/client/plugins/autoLink/index.d.ts.map +1 -1
  124. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/index.d.ts.map +1 -1
  125. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/index.js +28 -8
  126. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/index.js.map +1 -1
  127. package/dist/features/link/client/plugins/floatingLinkEditor/index.css +112 -0
  128. package/dist/features/link/client/plugins/floatingLinkEditor/index.d.ts +1 -1
  129. package/dist/features/link/client/plugins/floatingLinkEditor/index.d.ts.map +1 -1
  130. package/dist/features/link/client/plugins/floatingLinkEditor/index.js +1 -0
  131. package/dist/features/link/client/plugins/floatingLinkEditor/index.js.map +1 -1
  132. package/dist/features/link/markdownTransformer.d.ts.map +1 -1
  133. package/dist/features/link/server/baseFields.d.ts.map +1 -1
  134. package/dist/features/link/server/graphQLPopulationPromise.d.ts.map +1 -1
  135. package/dist/features/link/server/index.d.ts.map +1 -1
  136. package/dist/features/link/server/index.js +0 -71
  137. package/dist/features/link/server/index.js.map +1 -1
  138. package/dist/features/link/server/validate.d.ts.map +1 -1
  139. package/dist/features/lists/checklist/server/index.d.ts.map +1 -1
  140. package/dist/features/lists/checklist/server/index.js +0 -7
  141. package/dist/features/lists/checklist/server/index.js.map +1 -1
  142. package/dist/features/lists/orderedList/server/index.d.ts.map +1 -1
  143. package/dist/features/lists/orderedList/server/index.js +0 -7
  144. package/dist/features/lists/orderedList/server/index.js.map +1 -1
  145. package/dist/features/lists/shared/markdown.d.ts.map +1 -1
  146. package/dist/features/lists/unorderedList/server/index.d.ts.map +1 -1
  147. package/dist/features/lists/unorderedList/server/index.js +0 -7
  148. package/dist/features/lists/unorderedList/server/index.js.map +1 -1
  149. package/dist/features/relationship/client/components/RelationshipComponent.d.ts +1 -1
  150. package/dist/features/relationship/client/components/RelationshipComponent.d.ts.map +1 -1
  151. package/dist/features/relationship/client/components/RelationshipComponent.js +29 -4
  152. package/dist/features/relationship/client/components/RelationshipComponent.js.map +1 -1
  153. package/dist/features/relationship/client/components/index.css +112 -0
  154. package/dist/features/relationship/client/drawer/index.d.ts.map +1 -1
  155. package/dist/features/relationship/client/utils/useEnabledRelationships.d.ts.map +1 -1
  156. package/dist/features/relationship/server/graphQLPopulationPromise.d.ts.map +1 -1
  157. package/dist/features/shared/toolbar/addDropdownGroup.d.ts.map +1 -1
  158. package/dist/features/shared/toolbar/featureButtonsGroup.d.ts.map +1 -1
  159. package/dist/features/shared/toolbar/textDropdownGroup.d.ts.map +1 -1
  160. package/dist/features/toolbars/fixed/client/Toolbar/index.css +87 -0
  161. package/dist/features/toolbars/fixed/client/Toolbar/index.d.ts +1 -1
  162. package/dist/features/toolbars/fixed/client/Toolbar/index.d.ts.map +1 -1
  163. package/dist/features/toolbars/fixed/client/Toolbar/index.js +1 -0
  164. package/dist/features/toolbars/fixed/client/Toolbar/index.js.map +1 -1
  165. package/dist/features/toolbars/inline/client/Toolbar/index.css +43 -0
  166. package/dist/features/toolbars/inline/client/Toolbar/index.d.ts +1 -1
  167. package/dist/features/toolbars/inline/client/Toolbar/index.d.ts.map +1 -1
  168. package/dist/features/toolbars/inline/client/Toolbar/index.js +1 -0
  169. package/dist/features/toolbars/inline/client/Toolbar/index.js.map +1 -1
  170. package/dist/features/toolbars/shared/ToolbarButton/index.css +57 -0
  171. package/dist/features/toolbars/shared/ToolbarButton/index.d.ts +1 -1
  172. package/dist/features/toolbars/shared/ToolbarButton/index.d.ts.map +1 -1
  173. package/dist/features/toolbars/shared/ToolbarButton/index.js +80 -74
  174. package/dist/features/toolbars/shared/ToolbarButton/index.js.map +1 -1
  175. package/dist/features/toolbars/shared/ToolbarDropdown/DropDown.d.ts.map +1 -1
  176. package/dist/features/toolbars/shared/ToolbarDropdown/DropDown.js +5 -2
  177. package/dist/features/toolbars/shared/ToolbarDropdown/DropDown.js.map +1 -1
  178. package/dist/features/toolbars/shared/ToolbarDropdown/index.css +214 -0
  179. package/dist/features/toolbars/shared/ToolbarDropdown/index.d.ts +1 -1
  180. package/dist/features/toolbars/shared/ToolbarDropdown/index.d.ts.map +1 -1
  181. package/dist/features/toolbars/shared/ToolbarDropdown/index.js +11 -7
  182. package/dist/features/toolbars/shared/ToolbarDropdown/index.js.map +1 -1
  183. package/dist/features/toolbars/types.d.ts +4 -0
  184. package/dist/features/toolbars/types.d.ts.map +1 -1
  185. package/dist/features/toolbars/types.js.map +1 -1
  186. package/dist/features/typesServer.d.ts +0 -17
  187. package/dist/features/typesServer.d.ts.map +1 -1
  188. package/dist/features/typesServer.js.map +1 -1
  189. package/dist/features/upload/client/component/index.css +220 -0
  190. package/dist/features/upload/client/component/index.d.ts +1 -1
  191. package/dist/features/upload/client/component/index.d.ts.map +1 -1
  192. package/dist/features/upload/client/component/index.js +86 -63
  193. package/dist/features/upload/client/component/index.js.map +1 -1
  194. package/dist/features/upload/client/component/pending/index.d.ts +0 -1
  195. package/dist/features/upload/client/component/pending/index.d.ts.map +1 -1
  196. package/dist/features/upload/client/component/pending/index.js.map +1 -1
  197. package/dist/features/upload/client/drawer/index.d.ts.map +1 -1
  198. package/dist/features/upload/server/graphQLPopulationPromise.d.ts.map +1 -1
  199. package/dist/features/upload/server/index.d.ts.map +1 -1
  200. package/dist/features/upload/server/index.js +0 -78
  201. package/dist/features/upload/server/index.js.map +1 -1
  202. package/dist/features/upload/server/validate.d.ts.map +1 -1
  203. package/dist/field/Diff/converters/listitem/index.css +44 -0
  204. package/dist/field/Diff/converters/listitem/index.d.ts +1 -1
  205. package/dist/field/Diff/converters/listitem/index.d.ts.map +1 -1
  206. package/dist/field/Diff/converters/listitem/index.js +1 -0
  207. package/dist/field/Diff/converters/listitem/index.js.map +1 -1
  208. package/dist/field/Diff/converters/relationship/index.css +68 -0
  209. package/dist/field/Diff/converters/relationship/index.d.ts +1 -1
  210. package/dist/field/Diff/converters/relationship/index.d.ts.map +1 -1
  211. package/dist/field/Diff/converters/relationship/index.js +1 -0
  212. package/dist/field/Diff/converters/relationship/index.js.map +1 -1
  213. package/dist/field/Diff/converters/unknown/index.css +37 -0
  214. package/dist/field/Diff/converters/unknown/index.d.ts +1 -1
  215. package/dist/field/Diff/converters/unknown/index.d.ts.map +1 -1
  216. package/dist/field/Diff/converters/unknown/index.js +1 -0
  217. package/dist/field/Diff/converters/unknown/index.js.map +1 -1
  218. package/dist/field/Diff/converters/upload/index.css +112 -0
  219. package/dist/field/Diff/converters/upload/index.d.ts +1 -1
  220. package/dist/field/Diff/converters/upload/index.d.ts.map +1 -1
  221. package/dist/field/Diff/converters/upload/index.js +1 -0
  222. package/dist/field/Diff/converters/upload/index.js.map +1 -1
  223. package/dist/field/Diff/index.css +101 -0
  224. package/dist/field/Diff/index.d.ts +1 -1
  225. package/dist/field/Diff/index.d.ts.map +1 -1
  226. package/dist/field/Diff/index.js +1 -0
  227. package/dist/field/Diff/index.js.map +1 -1
  228. package/dist/field/Field.d.ts +2 -2
  229. package/dist/field/Field.d.ts.map +1 -1
  230. package/dist/field/Field.js +13 -12
  231. package/dist/field/Field.js.map +1 -1
  232. package/dist/field/ViewSelector.css +32 -0
  233. package/dist/field/ViewSelector.d.ts +1 -1
  234. package/dist/field/ViewSelector.d.ts.map +1 -1
  235. package/dist/field/ViewSelector.js +1 -0
  236. package/dist/field/ViewSelector.js.map +1 -1
  237. package/dist/field/bundled.css +1 -1
  238. package/dist/field/index.css +60 -0
  239. package/dist/index.d.ts +0 -10
  240. package/dist/index.d.ts.map +1 -1
  241. package/dist/index.js +11 -10
  242. package/dist/index.js.map +1 -1
  243. package/dist/lexical/LexicalEditor.css +50 -0
  244. package/dist/lexical/LexicalEditor.d.ts +1 -1
  245. package/dist/lexical/LexicalEditor.d.ts.map +1 -1
  246. package/dist/lexical/LexicalEditor.js +1 -0
  247. package/dist/lexical/LexicalEditor.js.map +1 -1
  248. package/dist/lexical/config/client/EditorConfigProvider.d.ts.map +1 -1
  249. package/dist/lexical/config/client/sanitize.d.ts.map +1 -1
  250. package/dist/lexical/config/server/loader.d.ts.map +1 -1
  251. package/dist/lexical/config/server/loader.js +12 -9
  252. package/dist/lexical/config/server/loader.js.map +1 -1
  253. package/dist/lexical/config/server/sanitize.d.ts.map +1 -1
  254. package/dist/lexical/config/server/sanitize.js +0 -6
  255. package/dist/lexical/config/server/sanitize.js.map +1 -1
  256. package/dist/lexical/plugins/DecoratorPlugin/index.css +11 -0
  257. package/dist/lexical/plugins/DecoratorPlugin/index.d.ts +1 -1
  258. package/dist/lexical/plugins/DecoratorPlugin/index.d.ts.map +1 -1
  259. package/dist/lexical/plugins/DecoratorPlugin/index.js +1 -0
  260. package/dist/lexical/plugins/DecoratorPlugin/index.js.map +1 -1
  261. package/dist/lexical/plugins/InsertParagraphAtEnd/index.css +52 -0
  262. package/dist/lexical/plugins/InsertParagraphAtEnd/index.d.ts +1 -1
  263. package/dist/lexical/plugins/InsertParagraphAtEnd/index.d.ts.map +1 -1
  264. package/dist/lexical/plugins/InsertParagraphAtEnd/index.js +1 -0
  265. package/dist/lexical/plugins/InsertParagraphAtEnd/index.js.map +1 -1
  266. package/dist/lexical/plugins/SlashMenu/index.css +65 -0
  267. package/dist/lexical/plugins/SlashMenu/index.d.ts +1 -1
  268. package/dist/lexical/plugins/SlashMenu/index.d.ts.map +1 -1
  269. package/dist/lexical/plugins/SlashMenu/index.js +2 -0
  270. package/dist/lexical/plugins/SlashMenu/index.js.map +1 -1
  271. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.css +40 -0
  272. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.d.ts +1 -1
  273. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.d.ts.map +1 -1
  274. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.js +1 -0
  275. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.js.map +1 -1
  276. package/dist/lexical/plugins/handles/DraggableBlockPlugin/debounce.d.ts.map +1 -1
  277. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.css +84 -0
  278. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.d.ts +1 -1
  279. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.d.ts.map +1 -1
  280. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.js +15 -8
  281. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.js.map +1 -1
  282. package/dist/lexical/plugins/handles/DraggableBlockPlugin/setTargetLine.js +1 -1
  283. package/dist/lexical/plugins/handles/DraggableBlockPlugin/setTargetLine.js.map +1 -1
  284. package/dist/lexical/plugins/handles/utils/calculateDistanceFromScrollerElem.d.ts.map +1 -1
  285. package/dist/lexical/theme/EditorTheme.css +359 -0
  286. package/dist/lexical/theme/EditorTheme.d.ts.map +1 -1
  287. package/dist/lexical/theme/EditorTheme.js +1 -0
  288. package/dist/lexical/theme/EditorTheme.js.map +1 -1
  289. package/dist/lexical/ui/ContentEditable.css +95 -0
  290. package/dist/lexical/ui/ContentEditable.d.ts +1 -1
  291. package/dist/lexical/ui/ContentEditable.d.ts.map +1 -1
  292. package/dist/lexical/ui/ContentEditable.js +1 -0
  293. package/dist/lexical/ui/ContentEditable.js.map +1 -1
  294. package/dist/lexical/ui/icons/Add/index.d.ts +4 -1
  295. package/dist/lexical/ui/icons/Add/index.d.ts.map +1 -1
  296. package/dist/lexical/ui/icons/Add/index.js +19 -12
  297. package/dist/lexical/ui/icons/Add/index.js.map +1 -1
  298. package/dist/lexical/ui/icons/Add/index.svg +2 -3
  299. package/dist/lexical/ui/icons/Add/light.svg +2 -3
  300. package/dist/lexical/ui/icons/AlignCenter/index.d.ts +3 -1
  301. package/dist/lexical/ui/icons/AlignCenter/index.d.ts.map +1 -1
  302. package/dist/lexical/ui/icons/AlignCenter/index.js +15 -19
  303. package/dist/lexical/ui/icons/AlignCenter/index.js.map +1 -1
  304. package/dist/lexical/ui/icons/AlignJustify/index.d.ts +3 -1
  305. package/dist/lexical/ui/icons/AlignJustify/index.d.ts.map +1 -1
  306. package/dist/lexical/ui/icons/AlignJustify/index.js +15 -19
  307. package/dist/lexical/ui/icons/AlignJustify/index.js.map +1 -1
  308. package/dist/lexical/ui/icons/AlignLeft/index.d.ts +3 -1
  309. package/dist/lexical/ui/icons/AlignLeft/index.d.ts.map +1 -1
  310. package/dist/lexical/ui/icons/AlignLeft/index.js +15 -19
  311. package/dist/lexical/ui/icons/AlignLeft/index.js.map +1 -1
  312. package/dist/lexical/ui/icons/AlignRight/index.d.ts +3 -1
  313. package/dist/lexical/ui/icons/AlignRight/index.d.ts.map +1 -1
  314. package/dist/lexical/ui/icons/AlignRight/index.js +15 -19
  315. package/dist/lexical/ui/icons/AlignRight/index.js.map +1 -1
  316. package/dist/lexical/ui/icons/Block/index.d.ts +3 -1
  317. package/dist/lexical/ui/icons/Block/index.d.ts.map +1 -1
  318. package/dist/lexical/ui/icons/Block/index.js +13 -28
  319. package/dist/lexical/ui/icons/Block/index.js.map +1 -1
  320. package/dist/lexical/ui/icons/Blockquote/index.d.ts +3 -1
  321. package/dist/lexical/ui/icons/Blockquote/index.d.ts.map +1 -1
  322. package/dist/lexical/ui/icons/Blockquote/index.js +9 -6
  323. package/dist/lexical/ui/icons/Blockquote/index.js.map +1 -1
  324. package/dist/lexical/ui/icons/Bold/index.d.ts +3 -1
  325. package/dist/lexical/ui/icons/Bold/index.d.ts.map +1 -1
  326. package/dist/lexical/ui/icons/Bold/index.js +13 -8
  327. package/dist/lexical/ui/icons/Bold/index.js.map +1 -1
  328. package/dist/lexical/ui/icons/Checklist/index.d.ts +4 -1
  329. package/dist/lexical/ui/icons/Checklist/index.d.ts.map +1 -1
  330. package/dist/lexical/ui/icons/Checklist/index.js +17 -18
  331. package/dist/lexical/ui/icons/Checklist/index.js.map +1 -1
  332. package/dist/lexical/ui/icons/Code/index.d.ts +3 -1
  333. package/dist/lexical/ui/icons/Code/index.d.ts.map +1 -1
  334. package/dist/lexical/ui/icons/Code/index.js +15 -13
  335. package/dist/lexical/ui/icons/Code/index.js.map +1 -1
  336. package/dist/lexical/ui/icons/CodeBlock/index.d.ts +4 -1
  337. package/dist/lexical/ui/icons/CodeBlock/index.d.ts.map +1 -1
  338. package/dist/lexical/ui/icons/CodeBlock/index.js +18 -7
  339. package/dist/lexical/ui/icons/CodeBlock/index.js.map +1 -1
  340. package/dist/lexical/ui/icons/Collapse/index.d.ts +3 -1
  341. package/dist/lexical/ui/icons/Collapse/index.d.ts.map +1 -1
  342. package/dist/lexical/ui/icons/Collapse/index.js +10 -8
  343. package/dist/lexical/ui/icons/Collapse/index.js.map +1 -1
  344. package/dist/lexical/ui/icons/DraggableBlock/index.svg +7 -7
  345. package/dist/lexical/ui/icons/DraggableBlock/light.svg +7 -7
  346. package/dist/lexical/ui/icons/Expand/index.d.ts +5 -0
  347. package/dist/lexical/ui/icons/Expand/index.d.ts.map +1 -0
  348. package/dist/lexical/ui/icons/Expand/index.js +22 -0
  349. package/dist/lexical/ui/icons/Expand/index.js.map +1 -0
  350. package/dist/lexical/ui/icons/H1/index.d.ts +3 -1
  351. package/dist/lexical/ui/icons/H1/index.d.ts.map +1 -1
  352. package/dist/lexical/ui/icons/H1/index.js +9 -6
  353. package/dist/lexical/ui/icons/H1/index.js.map +1 -1
  354. package/dist/lexical/ui/icons/H2/index.d.ts +3 -1
  355. package/dist/lexical/ui/icons/H2/index.d.ts.map +1 -1
  356. package/dist/lexical/ui/icons/H2/index.js +9 -6
  357. package/dist/lexical/ui/icons/H2/index.js.map +1 -1
  358. package/dist/lexical/ui/icons/H3/index.d.ts +3 -1
  359. package/dist/lexical/ui/icons/H3/index.d.ts.map +1 -1
  360. package/dist/lexical/ui/icons/H3/index.js +9 -6
  361. package/dist/lexical/ui/icons/H3/index.js.map +1 -1
  362. package/dist/lexical/ui/icons/H4/index.d.ts +3 -1
  363. package/dist/lexical/ui/icons/H4/index.d.ts.map +1 -1
  364. package/dist/lexical/ui/icons/H4/index.js +9 -6
  365. package/dist/lexical/ui/icons/H4/index.js.map +1 -1
  366. package/dist/lexical/ui/icons/H5/index.d.ts +3 -1
  367. package/dist/lexical/ui/icons/H5/index.d.ts.map +1 -1
  368. package/dist/lexical/ui/icons/H5/index.js +9 -6
  369. package/dist/lexical/ui/icons/H5/index.js.map +1 -1
  370. package/dist/lexical/ui/icons/H6/index.d.ts +3 -1
  371. package/dist/lexical/ui/icons/H6/index.d.ts.map +1 -1
  372. package/dist/lexical/ui/icons/H6/index.js +9 -6
  373. package/dist/lexical/ui/icons/H6/index.js.map +1 -1
  374. package/dist/lexical/ui/icons/HorizontalRule/index.d.ts +3 -1
  375. package/dist/lexical/ui/icons/HorizontalRule/index.d.ts.map +1 -1
  376. package/dist/lexical/ui/icons/HorizontalRule/index.js +11 -11
  377. package/dist/lexical/ui/icons/HorizontalRule/index.js.map +1 -1
  378. package/dist/lexical/ui/icons/IndentDecrease/index.d.ts +3 -1
  379. package/dist/lexical/ui/icons/IndentDecrease/index.d.ts.map +1 -1
  380. package/dist/lexical/ui/icons/IndentDecrease/index.js +18 -22
  381. package/dist/lexical/ui/icons/IndentDecrease/index.js.map +1 -1
  382. package/dist/lexical/ui/icons/IndentIncrease/index.d.ts +3 -1
  383. package/dist/lexical/ui/icons/IndentIncrease/index.d.ts.map +1 -1
  384. package/dist/lexical/ui/icons/IndentIncrease/index.js +15 -22
  385. package/dist/lexical/ui/icons/IndentIncrease/index.js.map +1 -1
  386. package/dist/lexical/ui/icons/InlineBlocks/index.d.ts +3 -1
  387. package/dist/lexical/ui/icons/InlineBlocks/index.d.ts.map +1 -1
  388. package/dist/lexical/ui/icons/InlineBlocks/index.js +9 -6
  389. package/dist/lexical/ui/icons/InlineBlocks/index.js.map +1 -1
  390. package/dist/lexical/ui/icons/Italic/index.d.ts +3 -1
  391. package/dist/lexical/ui/icons/Italic/index.d.ts.map +1 -1
  392. package/dist/lexical/ui/icons/Italic/index.js +13 -8
  393. package/dist/lexical/ui/icons/Italic/index.js.map +1 -1
  394. package/dist/lexical/ui/icons/Link/index.d.ts +4 -1
  395. package/dist/lexical/ui/icons/Link/index.d.ts.map +1 -1
  396. package/dist/lexical/ui/icons/Link/index.js +14 -9
  397. package/dist/lexical/ui/icons/Link/index.js.map +1 -1
  398. package/dist/lexical/ui/icons/Meatballs/index.d.ts +4 -1
  399. package/dist/lexical/ui/icons/Meatballs/index.d.ts.map +1 -1
  400. package/dist/lexical/ui/icons/Meatballs/index.js +19 -15
  401. package/dist/lexical/ui/icons/Meatballs/index.js.map +1 -1
  402. package/dist/lexical/ui/icons/OrderedList/index.d.ts +4 -1
  403. package/dist/lexical/ui/icons/OrderedList/index.d.ts.map +1 -1
  404. package/dist/lexical/ui/icons/OrderedList/index.js +19 -25
  405. package/dist/lexical/ui/icons/OrderedList/index.js.map +1 -1
  406. package/dist/lexical/ui/icons/Page/index.d.ts +5 -0
  407. package/dist/lexical/ui/icons/Page/index.d.ts.map +1 -0
  408. package/dist/lexical/ui/icons/Page/index.js +21 -0
  409. package/dist/lexical/ui/icons/Page/index.js.map +1 -0
  410. package/dist/lexical/ui/icons/Relationship/index.d.ts +3 -1
  411. package/dist/lexical/ui/icons/Relationship/index.d.ts.map +1 -1
  412. package/dist/lexical/ui/icons/Relationship/index.js +13 -25
  413. package/dist/lexical/ui/icons/Relationship/index.js.map +1 -1
  414. package/dist/lexical/ui/icons/Strikethrough/index.d.ts +3 -1
  415. package/dist/lexical/ui/icons/Strikethrough/index.d.ts.map +1 -1
  416. package/dist/lexical/ui/icons/Strikethrough/index.js +13 -13
  417. package/dist/lexical/ui/icons/Strikethrough/index.js.map +1 -1
  418. package/dist/lexical/ui/icons/Subscript/index.d.ts +3 -1
  419. package/dist/lexical/ui/icons/Subscript/index.d.ts.map +1 -1
  420. package/dist/lexical/ui/icons/Subscript/index.js +10 -7
  421. package/dist/lexical/ui/icons/Subscript/index.js.map +1 -1
  422. package/dist/lexical/ui/icons/Superscript/index.d.ts +3 -1
  423. package/dist/lexical/ui/icons/Superscript/index.d.ts.map +1 -1
  424. package/dist/lexical/ui/icons/Superscript/index.js +10 -7
  425. package/dist/lexical/ui/icons/Superscript/index.js.map +1 -1
  426. package/dist/lexical/ui/icons/Table/index.d.ts +4 -1
  427. package/dist/lexical/ui/icons/Table/index.d.ts.map +1 -1
  428. package/dist/lexical/ui/icons/Table/index.js +20 -15
  429. package/dist/lexical/ui/icons/Table/index.js.map +1 -1
  430. package/dist/lexical/ui/icons/Text/index.d.ts +4 -1
  431. package/dist/lexical/ui/icons/Text/index.d.ts.map +1 -1
  432. package/dist/lexical/ui/icons/Text/index.js +17 -8
  433. package/dist/lexical/ui/icons/Text/index.js.map +1 -1
  434. package/dist/lexical/ui/icons/Trash/index.d.ts +10 -0
  435. package/dist/lexical/ui/icons/Trash/index.d.ts.map +1 -0
  436. package/dist/lexical/ui/icons/Trash/index.js +29 -0
  437. package/dist/lexical/ui/icons/Trash/index.js.map +1 -0
  438. package/dist/lexical/ui/icons/Underline/index.d.ts +3 -1
  439. package/dist/lexical/ui/icons/Underline/index.d.ts.map +1 -1
  440. package/dist/lexical/ui/icons/Underline/index.js +16 -14
  441. package/dist/lexical/ui/icons/Underline/index.js.map +1 -1
  442. package/dist/lexical/ui/icons/UnorderedList/index.d.ts +3 -1
  443. package/dist/lexical/ui/icons/UnorderedList/index.d.ts.map +1 -1
  444. package/dist/lexical/ui/icons/UnorderedList/index.js +13 -40
  445. package/dist/lexical/ui/icons/UnorderedList/index.js.map +1 -1
  446. package/dist/lexical/ui/icons/Upload/index.d.ts +3 -1
  447. package/dist/lexical/ui/icons/Upload/index.d.ts.map +1 -1
  448. package/dist/lexical/ui/icons/Upload/index.js +15 -22
  449. package/dist/lexical/ui/icons/Upload/index.js.map +1 -1
  450. package/dist/lexical/utils/markdown/createBlockNode.d.ts.map +1 -1
  451. package/dist/populateGraphQL/populateLexicalPopulationPromises.d.ts.map +1 -1
  452. package/dist/populateGraphQL/recursivelyPopulateFieldsForGraphQL.d.ts.map +1 -1
  453. package/dist/utilities/buildEditorState.d.ts.map +1 -1
  454. package/dist/utilities/buildEditorState.js +13 -0
  455. package/dist/utilities/buildEditorState.js.map +1 -1
  456. package/dist/utilities/editorConfigFactory.d.ts.map +1 -1
  457. package/dist/utilities/fieldsDrawer/useLexicalDocumentDrawer.d.ts +1 -0
  458. package/dist/utilities/fieldsDrawer/useLexicalDocumentDrawer.d.ts.map +1 -1
  459. package/dist/utilities/fieldsDrawer/useLexicalDocumentDrawer.js +34 -18
  460. package/dist/utilities/fieldsDrawer/useLexicalDocumentDrawer.js.map +1 -1
  461. package/dist/utilities/fieldsDrawer/useLexicalDrawer.d.ts.map +1 -1
  462. package/dist/utilities/fieldsDrawer/useLexicalListDrawer.d.ts.map +1 -1
  463. package/dist/utilities/generateImportMap.d.ts.map +1 -1
  464. package/dist/utilities/generateSchemaMap.d.ts.map +1 -1
  465. package/dist/utilities/getDefaultSanitizedEditorConfig.d.ts.map +1 -1
  466. package/dist/utilities/recurseNodeTree.d.ts.map +1 -1
  467. package/dist/utilities/upgradeLexicalData/upgradeDocumentFieldsRecursively.d.ts.map +1 -1
  468. package/dist/utilities/useLexicalFeature.d.ts.map +1 -1
  469. package/dist/validate/index.d.ts.map +1 -1
  470. package/package.json +16 -21
  471. package/dist/exports/client/Component-DOSSWC76.js +0 -2
  472. package/dist/exports/client/Component-DOSSWC76.js.map +0 -7
  473. package/dist/exports/client/Component-MBLHTKDK.js +0 -2
  474. package/dist/exports/client/Component-MBLHTKDK.js.map +0 -7
  475. package/dist/exports/client/Field-4UEGQMIN.js +0 -2
  476. package/dist/exports/client/Field-4UEGQMIN.js.map +0 -7
  477. package/dist/exports/client/RelationshipComponent-BG3DPV3T.js +0 -2
  478. package/dist/exports/client/RelationshipComponent-BG3DPV3T.js.map +0 -7
  479. package/dist/exports/client/chunk-F26IQ5RE.js +0 -2
  480. package/dist/exports/client/chunk-F26IQ5RE.js.map +0 -7
  481. package/dist/exports/client/chunk-YWIZCGSY.js +0 -2
  482. package/dist/exports/client/chunk-YWIZCGSY.js.map +0 -7
  483. package/dist/exports/client/component-XIHC3W6W.js +0 -2
  484. package/dist/exports/client/component-XIHC3W6W.js.map +0 -7
  485. package/dist/exports/client/componentInline-CBBUBQ7P.js +0 -2
  486. package/dist/exports/server/migrate.d.ts +0 -16
  487. package/dist/exports/server/migrate.d.ts.map +0 -1
  488. package/dist/exports/server/migrate.js +0 -16
  489. package/dist/exports/server/migrate.js.map +0 -1
  490. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/linebreak.d.ts +0 -4
  491. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/linebreak.d.ts.map +0 -1
  492. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/linebreak.js +0 -7
  493. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/linebreak.js.map +0 -1
  494. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/paragraph.d.ts +0 -4
  495. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/paragraph.d.ts.map +0 -1
  496. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/paragraph.js +0 -38
  497. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/paragraph.js.map +0 -1
  498. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/tab.d.ts +0 -4
  499. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/tab.d.ts.map +0 -1
  500. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/tab.js +0 -9
  501. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/tab.js.map +0 -1
  502. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/text.d.ts +0 -4
  503. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/text.d.ts.map +0 -1
  504. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/text.js +0 -33
  505. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/text.js.map +0 -1
  506. package/dist/features/converters/lexicalToHtml_deprecated/converter/defaultConverters.d.ts +0 -6
  507. package/dist/features/converters/lexicalToHtml_deprecated/converter/defaultConverters.d.ts.map +0 -1
  508. package/dist/features/converters/lexicalToHtml_deprecated/converter/defaultConverters.js +0 -9
  509. package/dist/features/converters/lexicalToHtml_deprecated/converter/defaultConverters.js.map +0 -1
  510. package/dist/features/converters/lexicalToHtml_deprecated/converter/index.d.ts +0 -70
  511. package/dist/features/converters/lexicalToHtml_deprecated/converter/index.d.ts.map +0 -1
  512. package/dist/features/converters/lexicalToHtml_deprecated/converter/index.js +0 -104
  513. package/dist/features/converters/lexicalToHtml_deprecated/converter/index.js.map +0 -1
  514. package/dist/features/converters/lexicalToHtml_deprecated/converter/types.d.ts +0 -27
  515. package/dist/features/converters/lexicalToHtml_deprecated/converter/types.d.ts.map +0 -1
  516. package/dist/features/converters/lexicalToHtml_deprecated/converter/types.js +0 -2
  517. package/dist/features/converters/lexicalToHtml_deprecated/converter/types.js.map +0 -1
  518. package/dist/features/converters/lexicalToHtml_deprecated/field/index.d.ts +0 -39
  519. package/dist/features/converters/lexicalToHtml_deprecated/field/index.d.ts.map +0 -1
  520. package/dist/features/converters/lexicalToHtml_deprecated/field/index.js +0 -122
  521. package/dist/features/converters/lexicalToHtml_deprecated/field/index.js.map +0 -1
  522. package/dist/features/converters/lexicalToHtml_deprecated/index.d.ts +0 -12
  523. package/dist/features/converters/lexicalToHtml_deprecated/index.d.ts.map +0 -1
  524. package/dist/features/converters/lexicalToHtml_deprecated/index.js +0 -11
  525. package/dist/features/converters/lexicalToHtml_deprecated/index.js.map +0 -1
  526. package/dist/features/lists/htmlConverter.d.ts +0 -5
  527. package/dist/features/lists/htmlConverter.d.ts.map +0 -1
  528. package/dist/features/lists/htmlConverter.js +0 -81
  529. package/dist/features/lists/htmlConverter.js.map +0 -1
  530. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/heading/converter.d.ts +0 -3
  531. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/heading/converter.d.ts.map +0 -1
  532. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/heading/converter.js +0 -22
  533. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/heading/converter.js.map +0 -1
  534. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/link/converter.d.ts +0 -3
  535. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/link/converter.d.ts.map +0 -1
  536. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/link/converter.js +0 -33
  537. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/link/converter.js.map +0 -1
  538. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/list/converter.d.ts +0 -3
  539. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/list/converter.d.ts.map +0 -1
  540. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/list/converter.js +0 -24
  541. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/list/converter.js.map +0 -1
  542. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/listItem/converter.d.ts +0 -3
  543. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/listItem/converter.d.ts.map +0 -1
  544. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/listItem/converter.js +0 -25
  545. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/listItem/converter.js.map +0 -1
  546. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/quote/converter.d.ts +0 -3
  547. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/quote/converter.d.ts.map +0 -1
  548. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/quote/converter.js +0 -22
  549. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/quote/converter.js.map +0 -1
  550. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/unknown/converter.d.ts +0 -3
  551. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/unknown/converter.d.ts.map +0 -1
  552. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/unknown/converter.js +0 -28
  553. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/unknown/converter.js.map +0 -1
  554. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/upload/converter.d.ts +0 -3
  555. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/upload/converter.d.ts.map +0 -1
  556. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/upload/converter.js +0 -22
  557. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/upload/converter.js.map +0 -1
  558. package/dist/features/migrations/lexicalPluginToLexical/converter/defaultConverters.d.ts +0 -3
  559. package/dist/features/migrations/lexicalPluginToLexical/converter/defaultConverters.d.ts.map +0 -1
  560. package/dist/features/migrations/lexicalPluginToLexical/converter/defaultConverters.js +0 -9
  561. package/dist/features/migrations/lexicalPluginToLexical/converter/defaultConverters.js.map +0 -1
  562. package/dist/features/migrations/lexicalPluginToLexical/converter/index.d.ts +0 -19
  563. package/dist/features/migrations/lexicalPluginToLexical/converter/index.d.ts.map +0 -1
  564. package/dist/features/migrations/lexicalPluginToLexical/converter/index.js +0 -78
  565. package/dist/features/migrations/lexicalPluginToLexical/converter/index.js.map +0 -1
  566. package/dist/features/migrations/lexicalPluginToLexical/converter/types.d.ts +0 -23
  567. package/dist/features/migrations/lexicalPluginToLexical/converter/types.d.ts.map +0 -1
  568. package/dist/features/migrations/lexicalPluginToLexical/converter/types.js +0 -2
  569. package/dist/features/migrations/lexicalPluginToLexical/converter/types.js.map +0 -1
  570. package/dist/features/migrations/lexicalPluginToLexical/feature.client.d.ts +0 -2
  571. package/dist/features/migrations/lexicalPluginToLexical/feature.client.d.ts.map +0 -1
  572. package/dist/features/migrations/lexicalPluginToLexical/feature.client.js +0 -10
  573. package/dist/features/migrations/lexicalPluginToLexical/feature.client.js.map +0 -1
  574. package/dist/features/migrations/lexicalPluginToLexical/feature.server.d.ts +0 -10
  575. package/dist/features/migrations/lexicalPluginToLexical/feature.server.d.ts.map +0 -1
  576. package/dist/features/migrations/lexicalPluginToLexical/feature.server.js +0 -49
  577. package/dist/features/migrations/lexicalPluginToLexical/feature.server.js.map +0 -1
  578. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/Component.d.ts +0 -9
  579. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/Component.d.ts.map +0 -1
  580. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/Component.js +0 -15
  581. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/Component.js.map +0 -1
  582. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.d.ts +0 -33
  583. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.d.ts.map +0 -1
  584. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.js +0 -74
  585. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.js.map +0 -1
  586. package/dist/features/migrations/slateToLexical/converter/converters/blockquote/converter.d.ts +0 -3
  587. package/dist/features/migrations/slateToLexical/converter/converters/blockquote/converter.d.ts.map +0 -1
  588. package/dist/features/migrations/slateToLexical/converter/converters/blockquote/converter.js +0 -23
  589. package/dist/features/migrations/slateToLexical/converter/converters/blockquote/converter.js.map +0 -1
  590. package/dist/features/migrations/slateToLexical/converter/converters/heading/converter.d.ts +0 -3
  591. package/dist/features/migrations/slateToLexical/converter/converters/heading/converter.d.ts.map +0 -1
  592. package/dist/features/migrations/slateToLexical/converter/converters/heading/converter.js +0 -24
  593. package/dist/features/migrations/slateToLexical/converter/converters/heading/converter.js.map +0 -1
  594. package/dist/features/migrations/slateToLexical/converter/converters/indent/converter.d.ts +0 -3
  595. package/dist/features/migrations/slateToLexical/converter/converters/indent/converter.d.ts.map +0 -1
  596. package/dist/features/migrations/slateToLexical/converter/converters/indent/converter.js +0 -33
  597. package/dist/features/migrations/slateToLexical/converter/converters/indent/converter.js.map +0 -1
  598. package/dist/features/migrations/slateToLexical/converter/converters/link/converter.d.ts +0 -3
  599. package/dist/features/migrations/slateToLexical/converter/converters/link/converter.d.ts.map +0 -1
  600. package/dist/features/migrations/slateToLexical/converter/converters/link/converter.js +0 -30
  601. package/dist/features/migrations/slateToLexical/converter/converters/link/converter.js.map +0 -1
  602. package/dist/features/migrations/slateToLexical/converter/converters/listItem/converter.d.ts +0 -3
  603. package/dist/features/migrations/slateToLexical/converter/converters/listItem/converter.d.ts.map +0 -1
  604. package/dist/features/migrations/slateToLexical/converter/converters/listItem/converter.js +0 -26
  605. package/dist/features/migrations/slateToLexical/converter/converters/listItem/converter.js.map +0 -1
  606. package/dist/features/migrations/slateToLexical/converter/converters/orderedList/converter.d.ts +0 -3
  607. package/dist/features/migrations/slateToLexical/converter/converters/orderedList/converter.d.ts.map +0 -1
  608. package/dist/features/migrations/slateToLexical/converter/converters/orderedList/converter.js +0 -26
  609. package/dist/features/migrations/slateToLexical/converter/converters/orderedList/converter.js.map +0 -1
  610. package/dist/features/migrations/slateToLexical/converter/converters/relationship/converter.d.ts +0 -3
  611. package/dist/features/migrations/slateToLexical/converter/converters/relationship/converter.d.ts.map +0 -1
  612. package/dist/features/migrations/slateToLexical/converter/converters/relationship/converter.js +0 -15
  613. package/dist/features/migrations/slateToLexical/converter/converters/relationship/converter.js.map +0 -1
  614. package/dist/features/migrations/slateToLexical/converter/converters/unknown/converter.d.ts +0 -3
  615. package/dist/features/migrations/slateToLexical/converter/converters/unknown/converter.d.ts.map +0 -1
  616. package/dist/features/migrations/slateToLexical/converter/converters/unknown/converter.js +0 -27
  617. package/dist/features/migrations/slateToLexical/converter/converters/unknown/converter.js.map +0 -1
  618. package/dist/features/migrations/slateToLexical/converter/converters/unorderedList/converter.d.ts +0 -3
  619. package/dist/features/migrations/slateToLexical/converter/converters/unorderedList/converter.d.ts.map +0 -1
  620. package/dist/features/migrations/slateToLexical/converter/converters/unorderedList/converter.js +0 -26
  621. package/dist/features/migrations/slateToLexical/converter/converters/unorderedList/converter.js.map +0 -1
  622. package/dist/features/migrations/slateToLexical/converter/converters/upload/converter.d.ts +0 -3
  623. package/dist/features/migrations/slateToLexical/converter/converters/upload/converter.d.ts.map +0 -1
  624. package/dist/features/migrations/slateToLexical/converter/converters/upload/converter.js +0 -18
  625. package/dist/features/migrations/slateToLexical/converter/converters/upload/converter.js.map +0 -1
  626. package/dist/features/migrations/slateToLexical/converter/defaultConverters.d.ts +0 -3
  627. package/dist/features/migrations/slateToLexical/converter/defaultConverters.d.ts.map +0 -1
  628. package/dist/features/migrations/slateToLexical/converter/defaultConverters.js +0 -12
  629. package/dist/features/migrations/slateToLexical/converter/defaultConverters.js.map +0 -1
  630. package/dist/features/migrations/slateToLexical/converter/index.d.ts +0 -19
  631. package/dist/features/migrations/slateToLexical/converter/index.d.ts.map +0 -1
  632. package/dist/features/migrations/slateToLexical/converter/index.js +0 -130
  633. package/dist/features/migrations/slateToLexical/converter/index.js.map +0 -1
  634. package/dist/features/migrations/slateToLexical/converter/types.d.ts +0 -16
  635. package/dist/features/migrations/slateToLexical/converter/types.d.ts.map +0 -1
  636. package/dist/features/migrations/slateToLexical/converter/types.js +0 -2
  637. package/dist/features/migrations/slateToLexical/converter/types.js.map +0 -1
  638. package/dist/features/migrations/slateToLexical/feature.client.d.ts +0 -2
  639. package/dist/features/migrations/slateToLexical/feature.client.d.ts.map +0 -1
  640. package/dist/features/migrations/slateToLexical/feature.client.js +0 -10
  641. package/dist/features/migrations/slateToLexical/feature.client.js.map +0 -1
  642. package/dist/features/migrations/slateToLexical/feature.server.d.ts +0 -40
  643. package/dist/features/migrations/slateToLexical/feature.server.d.ts.map +0 -1
  644. package/dist/features/migrations/slateToLexical/feature.server.js +0 -68
  645. package/dist/features/migrations/slateToLexical/feature.server.js.map +0 -1
  646. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/Component.d.ts +0 -9
  647. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/Component.d.ts.map +0 -1
  648. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/Component.js +0 -15
  649. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/Component.js.map +0 -1
  650. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.d.ts +0 -33
  651. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.d.ts.map +0 -1
  652. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.js +0 -74
  653. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.js.map +0 -1
  654. package/dist/lexical/ui/icons/AI/index.d.ts +0 -3
  655. package/dist/lexical/ui/icons/AI/index.d.ts.map +0 -1
  656. package/dist/lexical/ui/icons/AI/index.js +0 -34
  657. package/dist/lexical/ui/icons/AI/index.js.map +0 -1
  658. package/dist/lexical/ui/icons/Caret/index.svg +0 -3
  659. package/dist/lexical/ui/icons/Edit/index.svg +0 -10
  660. package/dist/lexical/ui/icons/Remove/index.svg +0 -4
  661. package/dist/utilities/migrateSlateToLexical/index.d.ts +0 -15
  662. package/dist/utilities/migrateSlateToLexical/index.d.ts.map +0 -1
  663. package/dist/utilities/migrateSlateToLexical/index.js +0 -152
  664. package/dist/utilities/migrateSlateToLexical/index.js.map +0 -1
  665. package/dist/utilities/migrateSlateToLexical/migrateDocumentFieldsRecursively.d.ts +0 -10
  666. package/dist/utilities/migrateSlateToLexical/migrateDocumentFieldsRecursively.d.ts.map +0 -1
  667. package/dist/utilities/migrateSlateToLexical/migrateDocumentFieldsRecursively.js +0 -85
  668. package/dist/utilities/migrateSlateToLexical/migrateDocumentFieldsRecursively.js.map +0 -1
  669. /package/dist/exports/client/{componentInline-CBBUBQ7P.js.map → componentInline-JYKBUUPZ.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["c","_c","$addUpdateTag","React","useCallback","useMemo","baseClass","ToolbarButton","t0","$","active","t1","children","editor","enabled","t2","item","undefined","t3","t4","t5","key","t6","filter","Boolean","className","join","t7","focus","update","_temp","onSelect","isActive","handleClick","handleMouseDown","_temp2","t8","_jsx","onClick","onMouseDown","type","e","preventDefault"],"sources":["../../../../../src/features/toolbars/shared/ToolbarButton/index.tsx"],"sourcesContent":["'use client'\nimport type { LexicalEditor } from 'lexical'\n\nimport { $addUpdateTag } from 'lexical'\nimport React, { useCallback, useMemo } from 'react'\n\nimport type { ToolbarGroupItem } from '../../types.js'\n\nimport './index.scss'\n\nconst baseClass = 'toolbar-popup__button'\n\nexport const ToolbarButton = ({\n active = false,\n children,\n editor,\n enabled = true,\n item,\n}: {\n active?: boolean\n children: React.JSX.Element\n editor: LexicalEditor\n enabled?: boolean\n item: ToolbarGroupItem\n}) => {\n const className = useMemo(() => {\n return [\n baseClass,\n !enabled ? 'disabled' : '',\n active ? 'active' : '',\n item.key ? `${baseClass}-${item.key}` : '',\n ]\n .filter(Boolean)\n .join(' ')\n }, [active, enabled, item.key])\n\n const handleClick = useCallback(() => {\n if (!enabled) {\n return\n }\n\n editor.focus(() => {\n editor.update(() => {\n $addUpdateTag('toolbar')\n })\n // We need to wrap the onSelect in the callback, so the editor is properly focused before the onSelect is called.\n item.onSelect?.({\n editor,\n isActive: active,\n })\n })\n }, [editor, item, active, enabled])\n\n const handleMouseDown = useCallback((e: React.MouseEvent) => {\n // This fixes a bug where you are unable to click the button if you are in a NESTED editor (editor in blocks field in editor).\n // Thus only happens if you click on the SVG of the button. Clicking on the outside works. Related issue: https://github.com/payloadcms/payload/issues/4025\n // TODO: Find out why exactly it happens and why e.preventDefault() on the mouseDown fixes it. Write that down here, or potentially fix a root cause, if there is any.\n e.preventDefault()\n }, [])\n\n return (\n <button\n className={className}\n data-button-key={item.key}\n onClick={handleClick}\n onMouseDown={handleMouseDown}\n type=\"button\"\n >\n {children}\n </button>\n )\n}\n"],"mappings":"AAAA;;AAAA,SAAAA,CAAA,IAAAC,EAAA;;AAGA,SAASC,aAAa,QAAQ;AAC9B,OAAOC,KAAA,IAASC,WAAW,EAAEC,OAAO,QAAQ;AAM5C,MAAMC,SAAA,GAAY;AAElB,OAAO,MAAMC,aAAA,GAAgBC,EAAA;EAAA,MAAAC,CAAA,GAAAR,EAAA;EAAC;IAAAS,MAAA,EAAAC,EAAA;IAAAC,QAAA;IAAAC,MAAA;IAAAC,OAAA,EAAAC,EAAA;IAAAC;EAAA,IAAAR,EAY7B;EAXC,MAAAE,MAAA,GAAAC,EAAc,KAAAM,SAAA,WAAdN,EAAc;EAGd,MAAAG,OAAA,GAAAC,EAAc,KAAAE,SAAA,UAAdF,EAAc;EAYV,MAAAG,EAAA,IAACJ,OAAA,GAAU,aAAa;EACxB,MAAAK,EAAA,GAAAT,MAAA,GAAS,WAAW;EACpB,MAAAU,EAAA,GAAAJ,IAAA,CAAAK,GAAA,GAAW,GAAAf,SAAA,IAAgBU,IAAA,CAAAK,GAAA,EAAU,GAAG;EAAA,IAAAC,EAAA;EAAA,IAAAb,CAAA,QAAAS,EAAA,IAAAT,CAAA,QAAAU,EAAA,IAAAV,CAAA,QAAAW,EAAA;IAJnCE,EAAA,IAAAhB,SAAA,EAELY,EAAwB,EACxBC,EAAoB,EACpBC,EAAwC,EAAAG,MAAA,CAAAC,OAEhC;IAAAf,CAAA,MAAAS,EAAA;IAAAT,CAAA,MAAAU,EAAA;IAAAV,CAAA,MAAAW,EAAA;IAAAX,CAAA,MAAAa,EAAA;EAAA;IAAAA,EAAA,GAAAb,CAAA;EAAA;EAPZ,MAAAgB,SAAA,GACSH,EAMG,CAAAI,IAAA,CACF;EACoB,IAAAC,EAAA;EAAA,IAAAlB,CAAA,QAAAC,MAAA,IAAAD,CAAA,QAAAI,MAAA,IAAAJ,CAAA,QAAAK,OAAA,IAAAL,CAAA,QAAAO,IAAA;IAEEW,EAAA,GAAAA,CAAA;MAAA,KACzBb,OAAA;QAAA;MAAA;MAILD,MAAA,CAAAe,KAAA;QACEf,MAAA,CAAAgB,MAAA,CAAAC,KAEA;QAEAd,IAAA,CAAAe,QAAA;UAAAlB,MAAA;UAAAmB,QAAA,EAEYtB;QAAA;MAAA,CAEd;IAAA;IACFD,CAAA,MAAAC,MAAA;IAAAD,CAAA,MAAAI,MAAA;IAAAJ,CAAA,MAAAK,OAAA;IAAAL,CAAA,MAAAO,IAAA;IAAAP,CAAA,MAAAkB,EAAA;EAAA;IAAAA,EAAA,GAAAlB,CAAA;EAAA;EAfA,MAAAwB,WAAA,GAAoBN,EAec;EAElC,MAAAO,eAAA,GAAAC,MAAA;EAKK,IAAAC,EAAA;EAAA,IAAA3B,CAAA,QAAAG,QAAA,IAAAH,CAAA,SAAAgB,SAAA,IAAAhB,CAAA,SAAAwB,WAAA,IAAAxB,CAAA,SAAAO,IAAA,CAAAK,GAAA;IAGHe,EAAA,GAAAC,IAAA,CAAC;MAAAZ,SAAA;MAAA,mBAEkBT,IAAA,CAAAK,GAAA;MAAAiB,OAAA,EACRL,WAAA;MAAAM,WAAA,EACIL,eAAA;MAAAM,IAAA,EACR;MAAA5B;IAAA,C;;;;;;;;;SALPwB,E;CAUJ;AA3D6B,SAAAN,MAAA;EA+BrB5B,aAAA,CAAc;AAAA;AA/BO,SAAAiC,OAAAM,CAAA;EA6CzBA,CAAA,CAAAC,cAAA,CAAgB;AAAA","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["Tooltip","useTranslation","$addUpdateTag","React","useCallback","useEffect","useMemo","useRef","useState","useEditorConfigContext","baseClass","ToolbarButton","active","children","editor","enabled","item","i18n","fieldProps","featureClientSchemaMap","schemaPath","showTooltip","setShowTooltip","buttonRef","current","removeAttribute","tooltipLabel","label","key","replace","c","toUpperCase","className","filter","Boolean","join","handleClick","focus","update","onSelect","isActive","handleMouseDown","e","preventDefault","currentTarget","setAttribute","_jsxs","disabled","onClick","onMouseDown","onPointerEnter","onPointerLeave","ref","type","_jsx","show"],"sources":["../../../../../src/features/toolbars/shared/ToolbarButton/index.tsx"],"sourcesContent":["'use client'\nimport type { LexicalEditor } from 'lexical'\n\nimport { Tooltip, useTranslation } from '@payloadcms/ui'\nimport { $addUpdateTag } from 'lexical'\nimport React, { useCallback, useEffect, useMemo, useRef, useState } from 'react'\n\nimport type { ToolbarGroupItem } from '../../types.js'\n\nimport { useEditorConfigContext } from '../../../../lexical/config/client/EditorConfigProvider.js'\nimport './index.css'\n\nconst baseClass = 'toolbar-popup__button'\n\nexport const ToolbarButton = ({\n active = false,\n children,\n editor,\n enabled = true,\n item,\n}: {\n active?: boolean\n children: React.JSX.Element\n editor: LexicalEditor\n enabled?: boolean\n item: ToolbarGroupItem\n}) => {\n const { i18n } = useTranslation<{}, string>()\n const {\n fieldProps: { featureClientSchemaMap, schemaPath },\n } = useEditorConfigContext()\n\n const [showTooltip, setShowTooltip] = useState(false)\n const buttonRef = useRef<HTMLButtonElement>(null)\n\n // Clear pressing state when active prop changes (React has re-rendered)\n useEffect(() => {\n buttonRef.current?.removeAttribute('data-pressing')\n }, [active])\n\n const tooltipLabel = useMemo(() => {\n if (item.label) {\n return typeof item.label === 'function'\n ? item.label({ featureClientSchemaMap, i18n, schemaPath })\n : item.label\n }\n // Convert camelCase key to Title Case (e.g. \"inlineCode\" -> \"Inline Code\")\n return item.key.replace(/([a-z])([A-Z])/g, '$1 $2').replace(/^./, (c) => c.toUpperCase())\n }, [featureClientSchemaMap, i18n, schemaPath, item])\n\n const className = useMemo(() => {\n return [\n baseClass,\n !enabled ? 'disabled' : '',\n active ? 'active' : '',\n item.key ? `${baseClass}-${item.key}` : '',\n ]\n .filter(Boolean)\n .join(' ')\n }, [active, enabled, item.key])\n\n const handleClick = useCallback(() => {\n if (!enabled) {\n return\n }\n\n editor.focus(() => {\n editor.update(() => {\n $addUpdateTag('toolbar')\n })\n // We need to wrap the onSelect in the callback, so the editor is properly focused before the onSelect is called.\n item.onSelect?.({\n editor,\n isActive: active,\n })\n })\n }, [editor, item, active, enabled])\n\n const handleMouseDown = useCallback((e: React.MouseEvent) => {\n // This fixes a bug where you are unable to click the button if you are in a NESTED editor (editor in blocks field in editor).\n // Thus only happens if you click on the SVG of the button. Clicking on the outside works. Related issue: https://github.com/payloadcms/payload/issues/4025\n // TODO: Find out why exactly it happens and why e.preventDefault() on the mouseDown fixes it. Write that down here, or potentially fix a root cause, if there is any.\n e.preventDefault()\n // Suppress hover flash between mouseup and React adding .active class\n ;(e.currentTarget as HTMLElement).setAttribute('data-pressing', '')\n }, [])\n\n return (\n <button\n aria-label={tooltipLabel}\n className={className}\n data-button-key={item.key}\n disabled={!enabled}\n onClick={handleClick}\n onMouseDown={handleMouseDown}\n onPointerEnter={() => setShowTooltip(true)}\n onPointerLeave={() => {\n setShowTooltip(false)\n buttonRef.current?.removeAttribute('data-pressing')\n }}\n ref={buttonRef}\n type=\"button\"\n >\n <Tooltip className={`${baseClass}__tooltip`} show={showTooltip}>\n {tooltipLabel}\n </Tooltip>\n {children}\n </button>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"DropDown.d.ts","sourceRoot":"","sources":["../../../../../src/features/toolbars/shared/ToolbarDropdown/DropDown.tsx"],"names":[],"mappings":"AAEA,OAAO,EAA4B,KAAK,aAAa,EAAE,MAAM,SAAS,CAAA;AACtE,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,EAAqD,MAAM,OAAO,CAAA;AAGhG,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AAUtD,wBAAgB,YAAY,CAAC,EAC3B,MAAM,EACN,QAAQ,EACR,MAAM,EACN,OAAO,EACP,IAAI,EACJ,IAAI,EACJ,OAAO,EACP,OAAO,GACR,EAAE;IACD,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,MAAM,EAAE,aAAa,CAAA;IACrB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,IAAI,EAAE,KAAK,CAAC,SAAS,CAAA;IACrB,IAAI,EAAE,gBAAgB,CAAA;IACtB,OAAO,EAAE,MAAM,CAAA;IACf,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB,GAAG,KAAK,CAAC,SAAS,CAkElB;AAqFD,wBAAgB,QAAQ,CAAC,EACvB,eAAe,EACf,eAAe,EACf,QAAQ,EACR,QAAgB,EAChB,WAAW,EACX,IAAI,EACJ,wBAAwB,EACxB,KAAK,EACL,oBAAoB,GACrB,EAAE;IACD,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,EAAE,MAAM,CAAA;IACvB,QAAQ,EAAE,SAAS,CAAA;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,WAAW,EAAE,MAAM,CAAA;IACnB,IAAI,CAAC,EAAE,KAAK,CAAC,EAAE,CAAA;IACf,wBAAwB,CAAC,EAAE,MAAM,EAAE,CAAA;IACnC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,oBAAoB,CAAC,EAAE,OAAO,CAAA;CAC/B,GAAG,KAAK,CAAC,SAAS,CAyFlB"}
1
+ {"version":3,"file":"DropDown.d.ts","sourceRoot":"","sources":["../../../../../src/features/toolbars/shared/ToolbarDropdown/DropDown.tsx"],"names":[],"mappings":"AAEA,OAAO,EAA4B,KAAK,aAAa,EAAE,MAAM,SAAS,CAAA;AACtE,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,EAAqD,MAAM,OAAO,CAAA;AAGhG,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AAUtD,wBAAgB,YAAY,CAAC,EAC3B,MAAM,EACN,QAAQ,EACR,MAAM,EACN,OAAO,EACP,IAAI,EACJ,IAAI,EACJ,OAAO,EACP,OAAO,GACR,EAAE;IACD,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,MAAM,EAAE,aAAa,CAAA;IACrB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,IAAI,EAAE,KAAK,CAAC,SAAS,CAAA;IACrB,IAAI,EAAE,gBAAgB,CAAA;IACtB,OAAO,EAAE,MAAM,CAAA;IACf,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB,GAAG,KAAK,CAAC,SAAS,CAiElB;AAyFD,wBAAgB,QAAQ,CAAC,EACvB,eAAe,EACf,eAAe,EACf,QAAQ,EACR,QAAgB,EAChB,WAAW,EACX,IAAI,EACJ,wBAAwB,EACxB,KAAK,EACL,oBAAoB,GACrB,EAAE;IACD,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,EAAE,MAAM,CAAA;IACvB,QAAQ,EAAE,SAAS,CAAA;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,WAAW,EAAE,MAAM,CAAA;IACnB,IAAI,CAAC,EAAE,KAAK,CAAC,EAAE,CAAA;IACf,wBAAwB,CAAC,EAAE,MAAM,EAAE,CAAA;IACnC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,oBAAoB,CAAC,EAAE,OAAO,CAAA;CAC/B,GAAG,KAAK,CAAC,SAAS,CA0FlB"}
@@ -35,7 +35,7 @@ export function DropDownItem({
35
35
  }, [ref, registerItem]);
36
36
  return /*#__PURE__*/_jsx(Button, {
37
37
  "aria-label": tooltip,
38
- buttonStyle: "none",
38
+ buttonStyle: "ghost",
39
39
  className: className,
40
40
  disabled: enabled === false,
41
41
  extraButtonProps: {
@@ -43,7 +43,6 @@ export function DropDownItem({
43
43
  },
44
44
  icon: Icon,
45
45
  iconPosition: "left",
46
- iconStyle: "none",
47
46
  onClick: () => {
48
47
  if (enabled !== false) {
49
48
  editor.focus(() => {
@@ -71,6 +70,7 @@ export function DropDownItem({
71
70
  }
72
71
  function DropDownItems({
73
72
  children,
73
+ dropdownKey,
74
74
  dropDownRef,
75
75
  itemsContainerClassNames,
76
76
  onClose
@@ -124,6 +124,8 @@ function DropDownItems({
124
124
  value: contextValue,
125
125
  children: /*#__PURE__*/_jsx("div", {
126
126
  className: (itemsContainerClassNames ?? ['toolbar-popup__dropdown-items']).join(' '),
127
+ "data-dropdown-key": dropdownKey,
128
+ "data-theme": "dark",
127
129
  onKeyDown: handleKeyDown,
128
130
  ref: dropDownRef,
129
131
  children: children
@@ -187,6 +189,7 @@ export function DropDown({
187
189
  }
188
190
  }, [dropDownRef, buttonRef, showDropDown, stopCloseOnClickSelf]);
189
191
  const portal = /*#__PURE__*/createPortal(/*#__PURE__*/_jsx(DropDownItems, {
192
+ dropdownKey: dropdownKey,
190
193
  dropDownRef: dropDownRef,
191
194
  itemsContainerClassNames: itemsContainerClassNames,
192
195
  onClose: handleClose,
@@ -1 +1 @@
1
- {"version":3,"file":"DropDown.js","names":["Button","$addUpdateTag","isDOMNode","React","useCallback","useEffect","useMemo","useRef","useState","createPortal","baseClass","DropDownContext","createContext","DropDownItem","active","children","editor","enabled","Icon","item","itemKey","tooltip","className","key","filter","Boolean","join","ref","dropDownContext","use","Error","registerItem","current","_jsx","buttonStyle","disabled","extraButtonProps","icon","iconPosition","iconStyle","onClick","focus","update","onSelect","isActive","onMouseDown","e","preventDefault","type","DropDownItems","dropDownRef","itemsContainerClassNames","onClose","items","setItems","highlightedItem","setHighlightedItem","itemRef","prev","handleKeyDown","event","includes","index","indexOf","length","contextValue","value","onKeyDown","DropDown","buttonAriaLabel","buttonClassName","dropdownKey","label","stopCloseOnClickSelf","buttonRef","showDropDown","setShowDropDown","handleClose","button","dropDown","left","top","getBoundingClientRect","scrollTopOffset","window","scrollY","document","documentElement","scrollTop","style","offsetHeight","Math","min","innerWidth","offsetWidth","handle","target","contains","addEventListener","removeEventListener","portal","body","_jsxs","Fragment"],"sources":["../../../../../src/features/toolbars/shared/ToolbarDropdown/DropDown.tsx"],"sourcesContent":["'use client'\nimport { Button } from '@payloadcms/ui'\nimport { $addUpdateTag, isDOMNode, type LexicalEditor } from 'lexical'\nimport React, { type ReactNode, useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\n\nimport type { ToolbarGroupItem } from '../../types.js'\n\nconst baseClass = 'toolbar-popup__dropdown-item'\n\ninterface DropDownContextType {\n registerItem: (ref: React.RefObject<HTMLButtonElement | null>) => void\n}\n\nconst DropDownContext = React.createContext<DropDownContextType | null>(null)\n\nexport function DropDownItem({\n active,\n children,\n editor,\n enabled,\n Icon,\n item,\n itemKey,\n tooltip,\n}: {\n active?: boolean\n children: React.ReactNode\n editor: LexicalEditor\n enabled?: boolean\n Icon: React.ReactNode\n item: ToolbarGroupItem\n itemKey: string\n tooltip?: string\n}): React.ReactNode {\n const className = useMemo(() => {\n return [\n baseClass,\n enabled === false ? 'disabled' : '',\n active ? 'active' : '',\n item?.key ? `${baseClass}-${item.key}` : '',\n ]\n .filter(Boolean)\n .join(' ')\n }, [enabled, active, item.key])\n\n const ref = useRef<HTMLButtonElement>(null)\n\n const dropDownContext = React.use(DropDownContext)\n\n if (dropDownContext === null) {\n throw new Error('DropDownItem must be used within a DropDown')\n }\n\n const { registerItem } = dropDownContext\n\n useEffect(() => {\n if (ref?.current != null) {\n registerItem(ref)\n }\n }, [ref, registerItem])\n\n return (\n <Button\n aria-label={tooltip}\n buttonStyle=\"none\"\n className={className}\n disabled={enabled === false}\n extraButtonProps={{\n 'data-item-key': itemKey,\n }}\n icon={Icon}\n iconPosition=\"left\"\n iconStyle=\"none\"\n onClick={() => {\n if (enabled !== false) {\n editor.focus(() => {\n editor.update(() => {\n $addUpdateTag('toolbar')\n })\n // We need to wrap the onSelect in the callback, so the editor is properly focused before the onSelect is called.\n item.onSelect?.({\n editor,\n isActive: active!,\n })\n })\n }\n }}\n onMouseDown={(e) => {\n // This is required for Firefox compatibility. Without it, the dropdown will disappear without the onClick being called.\n // This only happens in Firefox. Must be something about how Firefox handles focus events differently.\n e.preventDefault()\n }}\n ref={ref}\n tooltip={tooltip}\n type=\"button\"\n >\n {children}\n </Button>\n )\n}\n\nfunction DropDownItems({\n children,\n dropDownRef,\n itemsContainerClassNames,\n onClose,\n}: {\n children: React.ReactNode\n dropDownRef: React.Ref<HTMLDivElement>\n itemsContainerClassNames?: string[]\n onClose: () => void\n}): React.ReactElement {\n const [items, setItems] = useState<Array<React.RefObject<HTMLButtonElement | null>>>()\n const [highlightedItem, setHighlightedItem] =\n useState<React.RefObject<HTMLButtonElement | null>>()\n\n const registerItem = useCallback(\n (itemRef: React.RefObject<HTMLButtonElement | null>) => {\n setItems((prev) => (prev != null ? [...prev, itemRef] : [itemRef]))\n },\n [setItems],\n )\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>): void => {\n if (items == null) {\n return\n }\n\n const { key } = event\n\n if (['ArrowDown', 'ArrowUp', 'Escape', 'Tab'].includes(key)) {\n event.preventDefault()\n }\n\n if (key === 'Escape' || key === 'Tab') {\n onClose()\n } else if (key === 'ArrowUp') {\n setHighlightedItem((prev) => {\n if (prev == null) {\n return items[0]\n }\n const index = items.indexOf(prev) - 1\n return items[index === -1 ? items.length - 1 : index]\n })\n } else if (key === 'ArrowDown') {\n setHighlightedItem((prev) => {\n if (prev == null) {\n return items[0]\n }\n return items[items.indexOf(prev) + 1]\n })\n }\n }\n\n const contextValue = useMemo(\n () => ({\n registerItem,\n }),\n [registerItem],\n )\n\n useEffect(() => {\n if (items != null && highlightedItem == null) {\n setHighlightedItem(items[0])\n }\n\n if (highlightedItem != null && highlightedItem?.current != null) {\n highlightedItem.current.focus()\n }\n }, [items, highlightedItem])\n\n return (\n <DropDownContext value={contextValue}>\n <div\n className={(itemsContainerClassNames ?? ['toolbar-popup__dropdown-items']).join(' ')}\n onKeyDown={handleKeyDown}\n ref={dropDownRef}\n >\n {children}\n </div>\n </DropDownContext>\n )\n}\n\nexport function DropDown({\n buttonAriaLabel,\n buttonClassName,\n children,\n disabled = false,\n dropdownKey,\n Icon,\n itemsContainerClassNames,\n label,\n stopCloseOnClickSelf,\n}: {\n buttonAriaLabel?: string\n buttonClassName: string\n children: ReactNode\n disabled?: boolean\n dropdownKey: string\n Icon?: React.FC\n itemsContainerClassNames?: string[]\n label?: string\n stopCloseOnClickSelf?: boolean\n}): React.ReactNode {\n const dropDownRef = useRef<HTMLDivElement>(null)\n const buttonRef = useRef<HTMLButtonElement>(null)\n const [showDropDown, setShowDropDown] = useState(false)\n\n const handleClose = (): void => {\n setShowDropDown(false)\n if (buttonRef?.current != null) {\n buttonRef.current.focus()\n }\n }\n\n useEffect(() => {\n const button = buttonRef.current\n const dropDown = dropDownRef.current\n\n if (showDropDown && button !== null && dropDown !== null) {\n const { left, top } = button.getBoundingClientRect()\n const scrollTopOffset = window.scrollY || document.documentElement.scrollTop\n dropDown.style.top = `${top + scrollTopOffset + button.offsetHeight + 5}px`\n dropDown.style.left = `${Math.min(left - 5, window.innerWidth - dropDown.offsetWidth - 20)}px`\n }\n }, [dropDownRef, buttonRef, showDropDown])\n\n useEffect(() => {\n const button = buttonRef.current\n\n if (button !== null && showDropDown) {\n const handle = (event: MouseEvent): void => {\n const target = event.target\n if (!isDOMNode(target)) {\n return\n }\n if (stopCloseOnClickSelf) {\n if (dropDownRef.current && dropDownRef.current.contains(target)) {\n return\n }\n }\n if (!button.contains(target)) {\n setShowDropDown(false)\n }\n }\n document.addEventListener('click', handle)\n\n return () => {\n document.removeEventListener('click', handle)\n }\n }\n }, [dropDownRef, buttonRef, showDropDown, stopCloseOnClickSelf])\n\n const portal = createPortal(\n <DropDownItems\n dropDownRef={dropDownRef}\n itemsContainerClassNames={itemsContainerClassNames}\n onClose={handleClose}\n >\n {children}\n </DropDownItems>,\n document.body,\n )\n\n return (\n <React.Fragment>\n <button\n aria-label={buttonAriaLabel}\n className={buttonClassName + (showDropDown ? ' active' : '')}\n data-dropdown-key={dropdownKey}\n disabled={disabled}\n onClick={(event) => {\n event.preventDefault()\n setShowDropDown(!showDropDown)\n }}\n onMouseDown={(e) => {\n // This fixes a bug where you are unable to click the button if you are in a NESTED editor (editor in blocks field in editor).\n // Thus only happens if you click on the SVG of the button. Clicking on the outside works. Related issue: https://github.com/payloadcms/payload/issues/4025\n // TODO: Find out why exactly it happens and why e.preventDefault() on the mouseDown fixes it. Write that down here, or potentially fix a root cause, if there is any.\n e.preventDefault()\n }}\n ref={buttonRef}\n type=\"button\"\n >\n {Icon && <Icon />}\n {label && <span className=\"toolbar-popup__dropdown-label\">{label}</span>}\n <i className=\"toolbar-popup__dropdown-caret\" />\n </button>\n\n {showDropDown && <React.Fragment>{portal}</React.Fragment>}\n </React.Fragment>\n )\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"DropDown.js","names":["Button","$addUpdateTag","isDOMNode","React","useCallback","useEffect","useMemo","useRef","useState","createPortal","baseClass","DropDownContext","createContext","DropDownItem","active","children","editor","enabled","Icon","item","itemKey","tooltip","className","key","filter","Boolean","join","ref","dropDownContext","use","Error","registerItem","current","_jsx","buttonStyle","disabled","extraButtonProps","icon","iconPosition","onClick","focus","update","onSelect","isActive","onMouseDown","e","preventDefault","type","DropDownItems","dropdownKey","dropDownRef","itemsContainerClassNames","onClose","items","setItems","highlightedItem","setHighlightedItem","itemRef","prev","handleKeyDown","event","includes","index","indexOf","length","contextValue","value","onKeyDown","DropDown","buttonAriaLabel","buttonClassName","label","stopCloseOnClickSelf","buttonRef","showDropDown","setShowDropDown","handleClose","button","dropDown","left","top","getBoundingClientRect","scrollTopOffset","window","scrollY","document","documentElement","scrollTop","style","offsetHeight","Math","min","innerWidth","offsetWidth","handle","target","contains","addEventListener","removeEventListener","portal","body","_jsxs","Fragment"],"sources":["../../../../../src/features/toolbars/shared/ToolbarDropdown/DropDown.tsx"],"sourcesContent":["'use client'\nimport { Button } from '@payloadcms/ui'\nimport { $addUpdateTag, isDOMNode, type LexicalEditor } from 'lexical'\nimport React, { type ReactNode, useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\n\nimport type { ToolbarGroupItem } from '../../types.js'\n\nconst baseClass = 'toolbar-popup__dropdown-item'\n\ninterface DropDownContextType {\n registerItem: (ref: React.RefObject<HTMLButtonElement | null>) => void\n}\n\nconst DropDownContext = React.createContext<DropDownContextType | null>(null)\n\nexport function DropDownItem({\n active,\n children,\n editor,\n enabled,\n Icon,\n item,\n itemKey,\n tooltip,\n}: {\n active?: boolean\n children: React.ReactNode\n editor: LexicalEditor\n enabled?: boolean\n Icon: React.ReactNode\n item: ToolbarGroupItem\n itemKey: string\n tooltip?: string\n}): React.ReactNode {\n const className = useMemo(() => {\n return [\n baseClass,\n enabled === false ? 'disabled' : '',\n active ? 'active' : '',\n item?.key ? `${baseClass}-${item.key}` : '',\n ]\n .filter(Boolean)\n .join(' ')\n }, [enabled, active, item.key])\n\n const ref = useRef<HTMLButtonElement>(null)\n\n const dropDownContext = React.use(DropDownContext)\n\n if (dropDownContext === null) {\n throw new Error('DropDownItem must be used within a DropDown')\n }\n\n const { registerItem } = dropDownContext\n\n useEffect(() => {\n if (ref?.current != null) {\n registerItem(ref)\n }\n }, [ref, registerItem])\n\n return (\n <Button\n aria-label={tooltip}\n buttonStyle=\"ghost\"\n className={className}\n disabled={enabled === false}\n extraButtonProps={{\n 'data-item-key': itemKey,\n }}\n icon={Icon}\n iconPosition=\"left\"\n onClick={() => {\n if (enabled !== false) {\n editor.focus(() => {\n editor.update(() => {\n $addUpdateTag('toolbar')\n })\n // We need to wrap the onSelect in the callback, so the editor is properly focused before the onSelect is called.\n item.onSelect?.({\n editor,\n isActive: active!,\n })\n })\n }\n }}\n onMouseDown={(e) => {\n // This is required for Firefox compatibility. Without it, the dropdown will disappear without the onClick being called.\n // This only happens in Firefox. Must be something about how Firefox handles focus events differently.\n e.preventDefault()\n }}\n ref={ref}\n tooltip={tooltip}\n type=\"button\"\n >\n {children}\n </Button>\n )\n}\n\nfunction DropDownItems({\n children,\n dropdownKey,\n dropDownRef,\n itemsContainerClassNames,\n onClose,\n}: {\n children: React.ReactNode\n dropdownKey?: string\n dropDownRef: React.Ref<HTMLDivElement>\n itemsContainerClassNames?: string[]\n onClose: () => void\n}): React.ReactElement {\n const [items, setItems] = useState<Array<React.RefObject<HTMLButtonElement | null>>>()\n const [highlightedItem, setHighlightedItem] =\n useState<React.RefObject<HTMLButtonElement | null>>()\n\n const registerItem = useCallback(\n (itemRef: React.RefObject<HTMLButtonElement | null>) => {\n setItems((prev) => (prev != null ? [...prev, itemRef] : [itemRef]))\n },\n [setItems],\n )\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>): void => {\n if (items == null) {\n return\n }\n\n const { key } = event\n\n if (['ArrowDown', 'ArrowUp', 'Escape', 'Tab'].includes(key)) {\n event.preventDefault()\n }\n\n if (key === 'Escape' || key === 'Tab') {\n onClose()\n } else if (key === 'ArrowUp') {\n setHighlightedItem((prev) => {\n if (prev == null) {\n return items[0]\n }\n const index = items.indexOf(prev) - 1\n return items[index === -1 ? items.length - 1 : index]\n })\n } else if (key === 'ArrowDown') {\n setHighlightedItem((prev) => {\n if (prev == null) {\n return items[0]\n }\n return items[items.indexOf(prev) + 1]\n })\n }\n }\n\n const contextValue = useMemo(\n () => ({\n registerItem,\n }),\n [registerItem],\n )\n\n useEffect(() => {\n if (items != null && highlightedItem == null) {\n setHighlightedItem(items[0])\n }\n\n if (highlightedItem != null && highlightedItem?.current != null) {\n highlightedItem.current.focus()\n }\n }, [items, highlightedItem])\n\n return (\n <DropDownContext value={contextValue}>\n <div\n className={(itemsContainerClassNames ?? ['toolbar-popup__dropdown-items']).join(' ')}\n data-dropdown-key={dropdownKey}\n data-theme=\"dark\"\n onKeyDown={handleKeyDown}\n ref={dropDownRef}\n >\n {children}\n </div>\n </DropDownContext>\n )\n}\n\nexport function DropDown({\n buttonAriaLabel,\n buttonClassName,\n children,\n disabled = false,\n dropdownKey,\n Icon,\n itemsContainerClassNames,\n label,\n stopCloseOnClickSelf,\n}: {\n buttonAriaLabel?: string\n buttonClassName: string\n children: ReactNode\n disabled?: boolean\n dropdownKey: string\n Icon?: React.FC\n itemsContainerClassNames?: string[]\n label?: string\n stopCloseOnClickSelf?: boolean\n}): React.ReactNode {\n const dropDownRef = useRef<HTMLDivElement>(null)\n const buttonRef = useRef<HTMLButtonElement>(null)\n const [showDropDown, setShowDropDown] = useState(false)\n\n const handleClose = (): void => {\n setShowDropDown(false)\n if (buttonRef?.current != null) {\n buttonRef.current.focus()\n }\n }\n\n useEffect(() => {\n const button = buttonRef.current\n const dropDown = dropDownRef.current\n\n if (showDropDown && button !== null && dropDown !== null) {\n const { left, top } = button.getBoundingClientRect()\n const scrollTopOffset = window.scrollY || document.documentElement.scrollTop\n dropDown.style.top = `${top + scrollTopOffset + button.offsetHeight + 5}px`\n dropDown.style.left = `${Math.min(left - 5, window.innerWidth - dropDown.offsetWidth - 20)}px`\n }\n }, [dropDownRef, buttonRef, showDropDown])\n\n useEffect(() => {\n const button = buttonRef.current\n\n if (button !== null && showDropDown) {\n const handle = (event: MouseEvent): void => {\n const target = event.target\n if (!isDOMNode(target)) {\n return\n }\n if (stopCloseOnClickSelf) {\n if (dropDownRef.current && dropDownRef.current.contains(target)) {\n return\n }\n }\n if (!button.contains(target)) {\n setShowDropDown(false)\n }\n }\n document.addEventListener('click', handle)\n\n return () => {\n document.removeEventListener('click', handle)\n }\n }\n }, [dropDownRef, buttonRef, showDropDown, stopCloseOnClickSelf])\n\n const portal = createPortal(\n <DropDownItems\n dropdownKey={dropdownKey}\n dropDownRef={dropDownRef}\n itemsContainerClassNames={itemsContainerClassNames}\n onClose={handleClose}\n >\n {children}\n </DropDownItems>,\n document.body,\n )\n\n return (\n <React.Fragment>\n <button\n aria-label={buttonAriaLabel}\n className={buttonClassName + (showDropDown ? ' active' : '')}\n data-dropdown-key={dropdownKey}\n disabled={disabled}\n onClick={(event) => {\n event.preventDefault()\n setShowDropDown(!showDropDown)\n }}\n onMouseDown={(e) => {\n // This fixes a bug where you are unable to click the button if you are in a NESTED editor (editor in blocks field in editor).\n // Thus only happens if you click on the SVG of the button. Clicking on the outside works. Related issue: https://github.com/payloadcms/payload/issues/4025\n // TODO: Find out why exactly it happens and why e.preventDefault() on the mouseDown fixes it. Write that down here, or potentially fix a root cause, if there is any.\n e.preventDefault()\n }}\n ref={buttonRef}\n type=\"button\"\n >\n {Icon && <Icon />}\n {label && <span className=\"toolbar-popup__dropdown-label\">{label}</span>}\n <i className=\"toolbar-popup__dropdown-caret\" />\n </button>\n\n {showDropDown && <React.Fragment>{portal}</React.Fragment>}\n </React.Fragment>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,214 @@
1
+ @layer payload-default {
2
+ @keyframes dropdown-press {
3
+ 0% {
4
+ background-color: var(--color-bg-transparent-pressed);
5
+ }
6
+
7
+ 100% {
8
+ background-color: var(--color-bg-selected);
9
+ }
10
+ }
11
+
12
+ .toolbar-popup__dropdown {
13
+ display: flex;
14
+ align-items: center;
15
+ vertical-align: middle;
16
+ justify-content: flex-start;
17
+ border: 0;
18
+ background: none;
19
+ border-radius: var(--radius-medium);
20
+ cursor: pointer;
21
+ position: relative;
22
+ transition: background-color 0.15s cubic-bezier(0, 0.2, 0.2, 1);
23
+ min-width: calc(var(--spacer-4) + var(--spacer-2-5));
24
+
25
+ &:disabled {
26
+ cursor: not-allowed;
27
+ opacity: 0.2;
28
+ }
29
+
30
+ &:hover:not([disabled]):not(.active) {
31
+ background-color: var(--color-bg-transparent-hover);
32
+ }
33
+
34
+ &:active:not(.active) {
35
+ background-color: var(--color-bg-transparent-pressed);
36
+ }
37
+
38
+ &.active {
39
+ color: var(--color-icon-selected);
40
+ background-color: var(--color-bg-selected);
41
+ animation: dropdown-press 0.15s cubic-bezier(0, 0.2, 0.2, 1);
42
+
43
+ .toolbar-popup__dropdown-caret {
44
+ background-color: var(--color-icon-selected);
45
+
46
+ &:after {
47
+ transform: rotate(0deg);
48
+ }
49
+ }
50
+ }
51
+ }
52
+
53
+ .toolbar-popup__dropdown-label {
54
+ padding-block: 0;
55
+ padding-inline: var(--spacer-1) var(--spacer-2);
56
+ }
57
+
58
+ .toolbar-popup__dropdown-caret {
59
+ display: flex;
60
+ align-items: center;
61
+ justify-content: center;
62
+ width: 6px;
63
+ margin: 0 4px 0 2px;
64
+ height: 4px;
65
+ background-color: var(--color-icon);
66
+ mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='6' height='4' viewBox='0 0 6 4' fill='none'%3E%3Cpath d='M4.38921 0.146406C4.58445 -0.0488286 4.90098 -0.0487744 5.09624 0.146406C5.29151 0.341668 5.29151 0.658175 5.09624 0.853437L2.97515 2.97453C2.77987 3.16959 2.46332 3.16972 2.26812 2.97453L0.146049 0.853437C-0.0487219 0.6583 -0.0486443 0.341591 0.146049 0.146406C0.341285 -0.0488288 0.658788 -0.0487749 0.854057 0.146406L2.62164 1.91398L4.38921 0.146406Z' fill='black'/%3E%3C/svg%3E");
67
+ mask-size: contain;
68
+ mask-repeat: no-repeat;
69
+ }
70
+
71
+ .toolbar-popup__dropdown-items {
72
+ --dropdown-min-width: 5rem;
73
+ position: absolute;
74
+ background: var(--color-bg-elevated);
75
+ color: var(--color-text);
76
+ border-radius: var(--radius-large);
77
+ padding: var(--spacer-2);
78
+ min-width: var(--dropdown-min-width);
79
+ z-index: 100;
80
+ box-shadow:
81
+ 0 2px 6px 0 rgba(0, 0, 0, 0.12),
82
+ 0 10px 16px 0 rgba(0, 0, 0, 0.08),
83
+ 0 0 0.5px 0 rgba(0, 0, 0, 0.12),
84
+ 0 0 0 1px rgba(0, 0, 0, 0.04);
85
+
86
+ .toolbar-popup__dropdown-item {
87
+ all: unset;
88
+ cursor: pointer;
89
+ color: var(--color-text);
90
+ transition: background-color 0.15s cubic-bezier(0, 0.2, 0.2, 1);
91
+ position: relative;
92
+ font-family: var(--text-body-medium-font-family);
93
+ font-size: var(--text-body-medium-font-size);
94
+ font-weight: var(--text-body-medium-font-weight);
95
+ line-height: var(--text-body-medium-line-height);
96
+ padding: 0 var(--spacer-1);
97
+ width: 100%;
98
+ height: var(--spacer-4);
99
+ border-radius: var(--radius-medium);
100
+ box-sizing: border-box;
101
+ display: flex;
102
+ align-items: center;
103
+ gap: var(--spacer-1);
104
+ margin-right: -var(--spacer-3);
105
+
106
+ .text {
107
+ overflow: hidden;
108
+ white-space: nowrap;
109
+ text-overflow: ellipsis;
110
+ }
111
+
112
+ &:hover:not([disabled]) {
113
+ background-color: var(--color-bg-transparent-pressed);
114
+ }
115
+
116
+ &:active:not([disabled]) {
117
+ background-color: var(--color-bg-transparent-pressed);
118
+ }
119
+
120
+ &.active {
121
+ background-color: var(--color-bg-selected-strong);
122
+ color: var(--color-text-onselected-strong);
123
+
124
+ .icon {
125
+ color: var(--color-text-onselected-strong);
126
+ }
127
+
128
+ &:hover:not([disabled]) {
129
+ background-color: var(--color-bg-selected-strong-hover);
130
+ }
131
+
132
+ &:active:not([disabled]) {
133
+ background-color: var(--color-bg-selected-strong-pressed);
134
+ }
135
+ }
136
+
137
+ &.disabled {
138
+ cursor: not-allowed;
139
+ opacity: 0.2;
140
+ }
141
+
142
+ .btn__icon {
143
+ --btn-icon-size: var(--spacer-4);
144
+ background: none !important;
145
+ background-color: none !important;
146
+ }
147
+ }
148
+ }
149
+
150
+ [data-dropdown-key='align'] {
151
+ display: flex;
152
+ min-width: unset;
153
+ gap: var(--spacer-2);
154
+
155
+ & .toolbar-popup__dropdown-item {
156
+ padding: 0;
157
+
158
+ .text {
159
+ display: none;
160
+ }
161
+
162
+ .btn__content {
163
+ gap: 0;
164
+ }
165
+
166
+ .btn__icon {
167
+ border: none;
168
+ }
169
+
170
+ .btn__tooltip {
171
+ background-color: var(--color-grey-900);
172
+ color: var(--color-grey-100);
173
+
174
+ &.tooltip--position-top::after {
175
+ border-top-color: var(--color-grey-900);
176
+ }
177
+
178
+ &.tooltip--position-bottom::after {
179
+ border-bottom-color: var(--color-grey-900);
180
+ }
181
+ }
182
+ }
183
+
184
+ & .toolbar-popup__dropdown-label {
185
+ display: none;
186
+ }
187
+ }
188
+
189
+ .toolbar-popup__dropdown-align {
190
+ gap: 0;
191
+ }
192
+
193
+ [data-dropdown-key='text'] {
194
+ & .toolbar-popup__dropdown-item {
195
+ padding: 0 var(--spacer-4);
196
+ }
197
+
198
+ & .toolbar-popup__dropdown-item.active::before {
199
+ content: '';
200
+ position: absolute;
201
+ left: var(--spacer-2-5);
202
+ top: 50%;
203
+ width: var(--spacer-1);
204
+ height: var(--spacer-2);
205
+ border: solid var(--color-text-onselected-strong);
206
+ border-width: 0 1px 1px 0;
207
+ transform: translateY(-60%) rotate(45deg);
208
+ }
209
+
210
+ .btn__icon {
211
+ margin: 0;
212
+ }
213
+ }
214
+ }
@@ -2,7 +2,7 @@ import React from 'react';
2
2
  import type { LexicalEditor } from 'lexical';
3
3
  import type { ToolbarDropdownGroup } from '../../types.js';
4
4
  import type { ToolbarGroupState } from '../useToolbarStates.js';
5
- import './index.scss';
5
+ import './index.css';
6
6
  export declare const ToolbarDropdown: ({ anchorElem, classNames, editor, group, groupState, Icon, itemsContainerClassNames, label, }: {
7
7
  anchorElem: HTMLElement;
8
8
  classNames?: string[];
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/features/toolbars/shared/ToolbarDropdown/index.tsx"],"names":[],"mappings":"AACA,OAAO,KAAkB,MAAM,OAAO,CAAA;AAItC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAI5C,OAAO,KAAK,EAAE,oBAAoB,EAAoB,MAAM,gBAAgB,CAAA;AAC5E,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAG/D,OAAO,cAAc,CAAA;AAoErB,eAAO,MAAM,eAAe,kGASzB;IACD,UAAU,EAAE,WAAW,CAAA;IACvB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAA;IACrB,MAAM,EAAE,aAAa,CAAA;IACrB,KAAK,EAAE,oBAAoB,CAAA;IAC3B,UAAU,EAAE,iBAAiB,CAAA;IAC7B,IAAI,CAAC,EAAE,KAAK,CAAC,EAAE,CAAA;IACf,wBAAwB,CAAC,EAAE,MAAM,EAAE,CAAA;IACnC,KAAK,CAAC,EAAE,MAAM,CAAA;CACf,sBAkCA,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/features/toolbars/shared/ToolbarDropdown/index.tsx"],"names":[],"mappings":"AACA,OAAO,KAAkB,MAAM,OAAO,CAAA;AAItC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAI5C,OAAO,KAAK,EAAE,oBAAoB,EAAoB,MAAM,gBAAgB,CAAA;AAC5E,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAG/D,OAAO,aAAa,CAAA;AAsEpB,eAAO,MAAM,eAAe,GAAI,+FAS7B;IACD,UAAU,EAAE,WAAW,CAAA;IACvB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAA;IACrB,MAAM,EAAE,aAAa,CAAA;IACrB,KAAK,EAAE,oBAAoB,CAAA;IAC3B,UAAU,EAAE,iBAAiB,CAAA;IAC7B,IAAI,CAAC,EAAE,KAAK,CAAC,EAAE,CAAA;IACf,wBAAwB,CAAC,EAAE,MAAM,EAAE,CAAA;IACnC,KAAK,CAAC,EAAE,MAAM,CAAA;CACf,sBAmCA,CAAA"}
@@ -6,14 +6,16 @@ import React, { useMemo } from 'react';
6
6
  const baseClass = 'toolbar-popup__dropdown';
7
7
  import { useTranslation } from '@payloadcms/ui';
8
8
  import { useEditorConfigContext } from '../../../../lexical/config/client/EditorConfigProvider.js';
9
+ import './index.css';
9
10
  import { DropDown, DropDownItem } from './DropDown.js';
10
11
  const ToolbarItem = t0 => {
11
- const $ = _c(14);
12
+ const $ = _c(15);
12
13
  const {
13
14
  active,
14
15
  anchorElem,
15
16
  editor,
16
17
  enabled,
18
+ iconOnly,
17
19
  item
18
20
  } = t0;
19
21
  const {
@@ -48,7 +50,7 @@ const ToolbarItem = t0 => {
48
50
  return t2;
49
51
  }
50
52
  let t2;
51
- if ($[6] !== active || $[7] !== editor || $[8] !== enabled || $[9] !== featureClientSchemaMap || $[10] !== i18n || $[11] !== item || $[12] !== schemaPath) {
53
+ if ($[6] !== active || $[7] !== editor || $[8] !== enabled || $[9] !== featureClientSchemaMap || $[10] !== i18n || $[11] !== iconOnly || $[12] !== item || $[13] !== schemaPath) {
52
54
  let title = item.key;
53
55
  let croppedTitle;
54
56
  if (item.label) {
@@ -70,7 +72,7 @@ const ToolbarItem = t0 => {
70
72
  Icon: item?.ChildComponent ? _jsx(item.ChildComponent, {}) : undefined,
71
73
  item,
72
74
  itemKey: item.key,
73
- tooltip: title,
75
+ tooltip: iconOnly ? title : undefined,
74
76
  children: _jsx("span", {
75
77
  className: "text",
76
78
  children: croppedTitle
@@ -81,11 +83,12 @@ const ToolbarItem = t0 => {
81
83
  $[8] = enabled;
82
84
  $[9] = featureClientSchemaMap;
83
85
  $[10] = i18n;
84
- $[11] = item;
85
- $[12] = schemaPath;
86
- $[13] = t2;
86
+ $[11] = iconOnly;
87
+ $[12] = item;
88
+ $[13] = schemaPath;
89
+ $[14] = t2;
87
90
  } else {
88
- t2 = $[13];
91
+ t2 = $[14];
89
92
  }
90
93
  return t2;
91
94
  };
@@ -110,6 +113,7 @@ export const ToolbarDropdown = ({
110
113
  anchorElem: anchorElem,
111
114
  editor: editor,
112
115
  enabled: groupState.enabledItemKeys.includes(item.key),
116
+ iconOnly: group.iconOnly,
113
117
  item: item
114
118
  }, item.key)) : null;
115
119
  }, [items, groupState.activeItemKeys, groupState.enabledItemKeys, anchorElem, editor]);
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["c","_c","React","useMemo","baseClass","useTranslation","useEditorConfigContext","DropDown","DropDownItem","ToolbarItem","t0","$","active","anchorElem","editor","enabled","item","i18n","fieldProps","t1","featureClientSchemaMap","schemaPath","Component","t2","_jsx","key","title","croppedTitle","label","length","substring","Icon","ChildComponent","undefined","itemKey","tooltip","children","className","MemoToolbarItem","memo","ToolbarDropdown","classNames","group","groupState","itemsContainerClassNames","items","groupKey","renderedItems","map","activeItemKeys","includes","enabledItemKeys","buttonAriaLabel","buttonClassName","filter","Boolean","join","disabled","enabledGroup","dropdownKey"],"sources":["../../../../../src/features/toolbars/shared/ToolbarDropdown/index.tsx"],"sourcesContent":["'use client'\nimport React, { useMemo } from 'react'\n\nconst baseClass = 'toolbar-popup__dropdown'\n\nimport type { LexicalEditor } from 'lexical'\n\nimport { useTranslation } from '@payloadcms/ui'\n\nimport type { ToolbarDropdownGroup, ToolbarGroupItem } from '../../types.js'\nimport type { ToolbarGroupState } from '../useToolbarStates.js'\n\nimport { useEditorConfigContext } from '../../../../lexical/config/client/EditorConfigProvider.js'\nimport './index.scss'\nimport { DropDown, DropDownItem } from './DropDown.js'\n\nconst ToolbarItem = ({\n active,\n anchorElem,\n editor,\n enabled,\n item,\n}: {\n active?: boolean\n anchorElem: HTMLElement\n editor: LexicalEditor\n enabled?: boolean\n item: ToolbarGroupItem\n}) => {\n const { i18n } = useTranslation<{}, string>()\n const {\n fieldProps: { featureClientSchemaMap, schemaPath },\n } = useEditorConfigContext()\n\n if (item.Component) {\n return (\n item?.Component && (\n <item.Component\n active={active}\n anchorElem={anchorElem}\n editor={editor}\n enabled={enabled}\n item={item}\n key={item.key}\n />\n )\n )\n }\n\n let title = item.key\n let croppedTitle = item.key\n if (item.label) {\n title =\n typeof item.label === 'function'\n ? item.label({ featureClientSchemaMap, i18n, schemaPath })\n : item.label\n }\n if (title.length > 25) {\n croppedTitle = title.substring(0, 25) + '...'\n } else {\n croppedTitle = title\n }\n\n return (\n <DropDownItem\n active={active}\n editor={editor}\n enabled={enabled}\n Icon={item?.ChildComponent ? <item.ChildComponent /> : undefined}\n item={item}\n itemKey={item.key}\n key={item.key}\n tooltip={title}\n >\n <span className=\"text\">{croppedTitle}</span>\n </DropDownItem>\n )\n}\n\nconst MemoToolbarItem = React.memo(ToolbarItem)\n\nexport const ToolbarDropdown = ({\n anchorElem,\n classNames,\n editor,\n group,\n groupState,\n Icon,\n itemsContainerClassNames,\n label,\n}: {\n anchorElem: HTMLElement\n classNames?: string[]\n editor: LexicalEditor\n group: ToolbarDropdownGroup\n groupState: ToolbarGroupState\n Icon?: React.FC\n itemsContainerClassNames?: string[]\n label?: string\n}) => {\n const { items, key: groupKey } = group\n\n const renderedItems = useMemo(() => {\n return items?.length\n ? items.map((item) => (\n <MemoToolbarItem\n active={groupState.activeItemKeys.includes(item.key)}\n anchorElem={anchorElem}\n editor={editor}\n enabled={groupState.enabledItemKeys.includes(item.key)}\n item={item}\n key={item.key}\n />\n ))\n : null\n }, [items, groupState.activeItemKeys, groupState.enabledItemKeys, anchorElem, editor])\n\n return (\n <DropDown\n buttonAriaLabel={`${groupKey} dropdown`}\n buttonClassName={[baseClass, `${baseClass}-${groupKey}`, ...(classNames || [])]\n .filter(Boolean)\n .join(' ')}\n disabled={!groupState.enabledGroup}\n dropdownKey={groupKey}\n Icon={Icon}\n itemsContainerClassNames={[`${baseClass}-items`, ...(itemsContainerClassNames || [])]}\n key={groupKey}\n label={label}\n >\n {renderedItems}\n </DropDown>\n )\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["c","_c","React","useMemo","baseClass","useTranslation","useEditorConfigContext","DropDown","DropDownItem","ToolbarItem","t0","$","active","anchorElem","editor","enabled","iconOnly","item","i18n","fieldProps","t1","featureClientSchemaMap","schemaPath","Component","t2","_jsx","key","title","croppedTitle","label","length","substring","Icon","ChildComponent","undefined","itemKey","tooltip","children","className","MemoToolbarItem","memo","ToolbarDropdown","classNames","group","groupState","itemsContainerClassNames","items","groupKey","renderedItems","map","activeItemKeys","includes","enabledItemKeys","buttonAriaLabel","buttonClassName","filter","Boolean","join","disabled","enabledGroup","dropdownKey"],"sources":["../../../../../src/features/toolbars/shared/ToolbarDropdown/index.tsx"],"sourcesContent":["'use client'\nimport React, { useMemo } from 'react'\n\nconst baseClass = 'toolbar-popup__dropdown'\n\nimport type { LexicalEditor } from 'lexical'\n\nimport { useTranslation } from '@payloadcms/ui'\n\nimport type { ToolbarDropdownGroup, ToolbarGroupItem } from '../../types.js'\nimport type { ToolbarGroupState } from '../useToolbarStates.js'\n\nimport { useEditorConfigContext } from '../../../../lexical/config/client/EditorConfigProvider.js'\nimport './index.css'\nimport { DropDown, DropDownItem } from './DropDown.js'\n\nconst ToolbarItem = ({\n active,\n anchorElem,\n editor,\n enabled,\n iconOnly,\n item,\n}: {\n active?: boolean\n anchorElem: HTMLElement\n editor: LexicalEditor\n enabled?: boolean\n iconOnly?: boolean\n item: ToolbarGroupItem\n}) => {\n const { i18n } = useTranslation<{}, string>()\n const {\n fieldProps: { featureClientSchemaMap, schemaPath },\n } = useEditorConfigContext()\n\n if (item.Component) {\n return (\n item?.Component && (\n <item.Component\n active={active}\n anchorElem={anchorElem}\n editor={editor}\n enabled={enabled}\n item={item}\n key={item.key}\n />\n )\n )\n }\n\n let title = item.key\n let croppedTitle = item.key\n if (item.label) {\n title =\n typeof item.label === 'function'\n ? item.label({ featureClientSchemaMap, i18n, schemaPath })\n : item.label\n }\n if (title.length > 25) {\n croppedTitle = title.substring(0, 25) + '...'\n } else {\n croppedTitle = title\n }\n\n return (\n <DropDownItem\n active={active}\n editor={editor}\n enabled={enabled}\n Icon={item?.ChildComponent ? <item.ChildComponent /> : undefined}\n item={item}\n itemKey={item.key}\n key={item.key}\n tooltip={iconOnly ? title : undefined}\n >\n <span className=\"text\">{croppedTitle}</span>\n </DropDownItem>\n )\n}\n\nconst MemoToolbarItem = React.memo(ToolbarItem)\n\nexport const ToolbarDropdown = ({\n anchorElem,\n classNames,\n editor,\n group,\n groupState,\n Icon,\n itemsContainerClassNames,\n label,\n}: {\n anchorElem: HTMLElement\n classNames?: string[]\n editor: LexicalEditor\n group: ToolbarDropdownGroup\n groupState: ToolbarGroupState\n Icon?: React.FC\n itemsContainerClassNames?: string[]\n label?: string\n}) => {\n const { items, key: groupKey } = group\n\n const renderedItems = useMemo(() => {\n return items?.length\n ? items.map((item) => (\n <MemoToolbarItem\n active={groupState.activeItemKeys.includes(item.key)}\n anchorElem={anchorElem}\n editor={editor}\n enabled={groupState.enabledItemKeys.includes(item.key)}\n iconOnly={group.iconOnly}\n item={item}\n key={item.key}\n />\n ))\n : null\n }, [items, groupState.activeItemKeys, groupState.enabledItemKeys, anchorElem, editor])\n\n return (\n <DropDown\n buttonAriaLabel={`${groupKey} dropdown`}\n buttonClassName={[baseClass, `${baseClass}-${groupKey}`, ...(classNames || [])]\n .filter(Boolean)\n .join(' ')}\n disabled={!groupState.enabledGroup}\n dropdownKey={groupKey}\n Icon={Icon}\n itemsContainerClassNames={[`${baseClass}-items`, ...(itemsContainerClassNames || [])]}\n key={groupKey}\n label={label}\n >\n {renderedItems}\n </DropDown>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -9,6 +9,10 @@ export type ToolbarDropdownGroup = {
9
9
  * The dropdown toolbar ChildComponent allows you to pass in a React Component which will be displayed within the dropdown button.
10
10
  */
11
11
  ChildComponent?: React.FC;
12
+ /**
13
+ * If true, the dropdown items will only show icons (text labels are hidden via CSS) and tooltips will be displayed on hover.
14
+ */
15
+ iconOnly?: boolean;
12
16
  /**
13
17
  * This is optional and controls if the toolbar group is highlighted or not.
14
18
  */
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/features/toolbars/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/features/toolbars/types.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","names":[],"sources":["../../../src/features/toolbars/types.ts"],"sourcesContent":["import type { I18nClient } from '@payloadcms/translations'\nimport type { BaseSelection, LexicalEditor } from 'lexical'\nimport type React from 'react'\n\nimport type { EditorConfigContextType } from '../../lexical/config/client/EditorConfigProvider.js'\nimport type { FeatureClientSchemaMap } from '../../types.js'\n\nexport type ToolbarGroup = ToolbarButtonsGroup | ToolbarDropdownGroup\n\nexport type ToolbarDropdownGroup = {\n /**\n * The dropdown toolbar ChildComponent allows you to pass in a React Component which will be displayed within the dropdown button.\n */\n ChildComponent?: React.FC\n /**\n * This is optional and controls if the toolbar group is highlighted or not.\n */\n isEnabled?: ({\n editor,\n editorConfigContext,\n selection,\n }: {\n editor: LexicalEditor\n editorConfigContext: EditorConfigContextType\n selection: BaseSelection\n }) => boolean\n /**\n * All toolbar items part of this toolbar group need to be added here.\n */\n items: Array<ToolbarGroupItem>\n /**\n * Each toolbar group needs to have a unique key. Groups with the same keys will have their items merged together.\n */\n key: string\n /**\n * The maximum number of active items that can be selected at once.\n * Increasing this will hurt performance, as more nodes need to be checked for their active state.\n *\n * E.g. if this is 1, we can stop checking nodes once we find an active node.\n *\n * @default 1\n */\n maxActiveItems?: number\n /**\n * Determines where the toolbar group will be.\n */\n order?: number\n /**\n * Controls the toolbar group type. Set to `dropdown` to create a buttons toolbar group, which displays toolbar items vertically using their icons and labels, if the dropdown is open.\n */\n type: 'dropdown'\n}\n\nexport type ToolbarButtonsGroup = {\n /**\n * All toolbar items part of this toolbar group need to be added here.\n */\n items: Array<ToolbarGroupItem>\n /**\n * Each toolbar group needs to have a unique key. Groups with the same keys will have their items merged together.\n */\n key: string\n /**\n * Determines where the toolbar group will be.\n */\n order?: number\n /**\n * Controls the toolbar group type. Set to `buttons` to create a buttons toolbar group, which displays toolbar items horizontally using only their icons.\n */\n type: 'buttons'\n}\n\nexport type ToolbarGroupItem = {\n /** A React component which is rendered within your toolbar item's default button component. Usually, you want this to be an icon. */\n ChildComponent?: React.FC\n /** A React component which is rendered in place of the toolbar item's default button component, thus completely replacing it. The `ChildComponent` and `onSelect` properties will be ignored. */\n Component?: React.FC<{\n active?: boolean\n anchorElem: HTMLElement\n editor: LexicalEditor\n enabled?: boolean\n item: ToolbarGroupItem\n }>\n /** This is optional and controls if the toolbar item is highlighted or not. */\n isActive?: ({\n editor,\n editorConfigContext,\n selection,\n }: {\n editor: LexicalEditor\n editorConfigContext: EditorConfigContextType\n selection: BaseSelection\n }) => boolean\n /** This is optional and controls if the toolbar item is clickable or not. If `false` is returned here, it will be grayed out and unclickable. */\n isEnabled?: ({\n editor,\n editorConfigContext,\n selection,\n }: {\n editor: LexicalEditor\n editorConfigContext: EditorConfigContextType\n selection: BaseSelection\n }) => boolean\n /** Each toolbar item needs to have a unique key. */\n key: string\n /** The label will be displayed in your toolbar item, if it's within a dropdown group. In order to make use of i18n, this can be a function. */\n label?:\n | ((args: {\n featureClientSchemaMap: FeatureClientSchemaMap\n i18n: I18nClient<{}, string>\n schemaPath: string\n }) => string)\n | string\n /** Each toolbar item needs to have a unique key. */\n onSelect?: ({ editor, isActive }: { editor: LexicalEditor; isActive: boolean }) => void\n order?: number\n}\n\nexport type CustomGroups = Record<\n string,\n | Partial<Omit<ToolbarButtonsGroup, 'items' | 'key'>>\n | Partial<Omit<ToolbarDropdownGroup, 'isEnabled' | 'items' | 'key'>>\n>\n"],"mappings":"AAsHA","ignoreList":[]}
1
+ {"version":3,"file":"types.js","names":[],"sources":["../../../src/features/toolbars/types.ts"],"sourcesContent":["import type { I18nClient } from '@payloadcms/translations'\nimport type { BaseSelection, LexicalEditor } from 'lexical'\nimport type React from 'react'\n\nimport type { EditorConfigContextType } from '../../lexical/config/client/EditorConfigProvider.js'\nimport type { FeatureClientSchemaMap } from '../../types.js'\n\nexport type ToolbarGroup = ToolbarButtonsGroup | ToolbarDropdownGroup\n\nexport type ToolbarDropdownGroup = {\n /**\n * The dropdown toolbar ChildComponent allows you to pass in a React Component which will be displayed within the dropdown button.\n */\n ChildComponent?: React.FC\n /**\n * If true, the dropdown items will only show icons (text labels are hidden via CSS) and tooltips will be displayed on hover.\n */\n iconOnly?: boolean\n /**\n * This is optional and controls if the toolbar group is highlighted or not.\n */\n isEnabled?: ({\n editor,\n editorConfigContext,\n selection,\n }: {\n editor: LexicalEditor\n editorConfigContext: EditorConfigContextType\n selection: BaseSelection\n }) => boolean\n /**\n * All toolbar items part of this toolbar group need to be added here.\n */\n items: Array<ToolbarGroupItem>\n /**\n * Each toolbar group needs to have a unique key. Groups with the same keys will have their items merged together.\n */\n key: string\n /**\n * The maximum number of active items that can be selected at once.\n * Increasing this will hurt performance, as more nodes need to be checked for their active state.\n *\n * E.g. if this is 1, we can stop checking nodes once we find an active node.\n *\n * @default 1\n */\n maxActiveItems?: number\n /**\n * Determines where the toolbar group will be.\n */\n order?: number\n /**\n * Controls the toolbar group type. Set to `dropdown` to create a buttons toolbar group, which displays toolbar items vertically using their icons and labels, if the dropdown is open.\n */\n type: 'dropdown'\n}\n\nexport type ToolbarButtonsGroup = {\n /**\n * All toolbar items part of this toolbar group need to be added here.\n */\n items: Array<ToolbarGroupItem>\n /**\n * Each toolbar group needs to have a unique key. Groups with the same keys will have their items merged together.\n */\n key: string\n /**\n * Determines where the toolbar group will be.\n */\n order?: number\n /**\n * Controls the toolbar group type. Set to `buttons` to create a buttons toolbar group, which displays toolbar items horizontally using only their icons.\n */\n type: 'buttons'\n}\n\nexport type ToolbarGroupItem = {\n /** A React component which is rendered within your toolbar item's default button component. Usually, you want this to be an icon. */\n ChildComponent?: React.FC\n /** A React component which is rendered in place of the toolbar item's default button component, thus completely replacing it. The `ChildComponent` and `onSelect` properties will be ignored. */\n Component?: React.FC<{\n active?: boolean\n anchorElem: HTMLElement\n editor: LexicalEditor\n enabled?: boolean\n item: ToolbarGroupItem\n }>\n /** This is optional and controls if the toolbar item is highlighted or not. */\n isActive?: ({\n editor,\n editorConfigContext,\n selection,\n }: {\n editor: LexicalEditor\n editorConfigContext: EditorConfigContextType\n selection: BaseSelection\n }) => boolean\n /** This is optional and controls if the toolbar item is clickable or not. If `false` is returned here, it will be grayed out and unclickable. */\n isEnabled?: ({\n editor,\n editorConfigContext,\n selection,\n }: {\n editor: LexicalEditor\n editorConfigContext: EditorConfigContextType\n selection: BaseSelection\n }) => boolean\n /** Each toolbar item needs to have a unique key. */\n key: string\n /** The label will be displayed in your toolbar item, if it's within a dropdown group. In order to make use of i18n, this can be a function. */\n label?:\n | ((args: {\n featureClientSchemaMap: FeatureClientSchemaMap\n i18n: I18nClient<{}, string>\n schemaPath: string\n }) => string)\n | string\n /** Each toolbar item needs to have a unique key. */\n onSelect?: ({ editor, isActive }: { editor: LexicalEditor; isActive: boolean }) => void\n order?: number\n}\n\nexport type CustomGroups = Record<\n string,\n | Partial<Omit<ToolbarButtonsGroup, 'items' | 'key'>>\n | Partial<Omit<ToolbarDropdownGroup, 'isEnabled' | 'items' | 'key'>>\n>\n"],"mappings":"AA0HA","ignoreList":[]}
@@ -5,7 +5,6 @@ import type { Field, FieldSchemaMap, ImportMapGenerators, JsonObject, PayloadCom
5
5
  import type { ServerEditorConfig } from '../lexical/config/types.js';
6
6
  import type { Transformer } from '../packages/@lexical/markdown/index.js';
7
7
  import type { LexicalRichTextField } from '../types.js';
8
- import type { HTMLConverter } from './converters/lexicalToHtml_deprecated/converter/types.js';
9
8
  import type { BaseClientFeatureProps } from './typesClient.js';
10
9
  export type PopulationPromise<T extends SerializedLexicalNode = SerializedLexicalNode> = (args: {
11
10
  context: RequestContext;
@@ -152,18 +151,6 @@ export type AfterChangeNodeHook<T extends SerializedLexicalNode> = (args: AfterC
152
151
  export type BeforeChangeNodeHook<T extends SerializedLexicalNode> = (args: BaseNodeHookArgs<T> & BeforeChangeNodeHookArgs<T>) => Promise<T> | T;
153
152
  export type BeforeValidateNodeHook<T extends SerializedLexicalNode> = (args: BaseNodeHookArgs<T> & BeforeValidateNodeHookArgs<T>) => Promise<T> | T;
154
153
  export type NodeWithHooks<T extends LexicalNode = any> = {
155
- /**
156
- * Allows you to define how a node can be serialized into different formats. Currently, only supports html.
157
- * Markdown converters are defined in `markdownTransformers` and not here.
158
- *
159
- * @deprecated - will be removed in 4.0
160
- */
161
- converters?: {
162
- /**
163
- * @deprecated - will be removed in 4.0
164
- */
165
- html?: HTMLConverter<ReturnType<ReplaceAny<T, LexicalNode>['exportJSON']>>;
166
- };
167
154
  /**
168
155
  * If a node includes sub-fields (e.g. block and link nodes), passing those subFields here will make payload
169
156
  * automatically populate, run hooks, and generate component import maps for them
@@ -283,10 +270,6 @@ export type ResolvedServerFeature<ServerProps, ClientFeatureProps> = {
283
270
  export type ResolvedServerFeatureMap = Map<string, ResolvedServerFeature<any, any>>;
284
271
  export type ServerFeatureProviderMap = Map<string, FeatureProviderServer<any, any, any>>;
285
272
  export type SanitizedServerFeatures = {
286
- /** The node types mapped to their converters */
287
- converters: {
288
- html: HTMLConverter[];
289
- };
290
273
  /** The keys of all enabled features */
291
274
  enabledFeatures: string[];
292
275
  generatedTypes: {