reactjs-tiptap-editor-pro 0.2.30 → 0.2.32

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 (333) hide show
  1. package/lib/RichTextEditor-BwbqJLnA.cjs +141 -0
  2. package/lib/RichTextEditor-iGJ6-rbq.js +8833 -0
  3. package/lib/extension-bundle.cjs +33 -0
  4. package/lib/extension-bundle.d.cts +947 -0
  5. package/lib/extension-bundle.d.ts +947 -0
  6. package/lib/extension-bundle.js +5755 -0
  7. package/lib/index-DV-nXpU1.cjs +1 -0
  8. package/lib/index-M6H3FoBi.js +1147 -0
  9. package/lib/index.cjs +1 -0
  10. package/lib/index.d.cts +513 -0
  11. package/lib/index.d.ts +513 -0
  12. package/lib/index.js +16 -0
  13. package/lib/locale-bundle.cjs +1 -0
  14. package/lib/locale-bundle.d.cts +1140 -0
  15. package/lib/locale-bundle.d.ts +1140 -0
  16. package/lib/locale-bundle.js +9 -0
  17. package/lib/style.css +1 -0
  18. package/lib/tiptap-DkWHMWDt.js +6061 -0
  19. package/lib/tiptap-gBG-1T-V.cjs +116 -0
  20. package/lib/vendor-BJ0Yf78E.cjs +8114 -0
  21. package/lib/vendor-Cpa6z-M0.js +67575 -0
  22. package/package.json +60 -4
  23. package/src/components/ActionButton.tsx +0 -103
  24. package/src/components/ActionMenuButton.tsx +0 -76
  25. package/src/components/BubbleMenu.tsx +0 -93
  26. package/src/components/CharactorCount.tsx +0 -50
  27. package/src/components/ColorPicker.tsx +0 -272
  28. package/src/components/RichTextEditor.tsx +0 -212
  29. package/src/components/SizeSetter/SizeSetter.tsx +0 -102
  30. package/src/components/Toolbar.tsx +0 -108
  31. package/src/components/icons/Activity.tsx +0 -19
  32. package/src/components/icons/Animas.tsx +0 -24
  33. package/src/components/icons/AspectRatio.tsx +0 -13
  34. package/src/components/icons/Blockquote.tsx +0 -17
  35. package/src/components/icons/ColumnAddLeft.tsx +0 -7
  36. package/src/components/icons/ColumnAddRight.tsx +0 -7
  37. package/src/components/icons/DeleteColumn.tsx +0 -26
  38. package/src/components/icons/DeleteRow.tsx +0 -26
  39. package/src/components/icons/Direction.tsx +0 -7
  40. package/src/components/icons/Excalidraw.tsx +0 -7
  41. package/src/components/icons/ExportPdf.tsx +0 -8
  42. package/src/components/icons/ExportWord.tsx +0 -24
  43. package/src/components/icons/FileWordOutline.tsx +0 -13
  44. package/src/components/icons/Flag.tsx +0 -19
  45. package/src/components/icons/Food.tsx +0 -20
  46. package/src/components/icons/GIfIcon.tsx +0 -10
  47. package/src/components/icons/Icon.tsx +0 -30
  48. package/src/components/icons/ImportWord.tsx +0 -23
  49. package/src/components/icons/LeftToRight.tsx +0 -7
  50. package/src/components/icons/LineHeight.tsx +0 -13
  51. package/src/components/icons/MenuDown.tsx +0 -24
  52. package/src/components/icons/Mermaid.tsx +0 -13
  53. package/src/components/icons/NoFill.tsx +0 -7
  54. package/src/components/icons/Object.tsx +0 -24
  55. package/src/components/icons/RightToLeft.tsx +0 -7
  56. package/src/components/icons/SizeL.tsx +0 -9
  57. package/src/components/icons/SizeM.tsx +0 -13
  58. package/src/components/icons/SizeS.tsx +0 -13
  59. package/src/components/icons/Symbol.tsx +0 -19
  60. package/src/components/icons/Travel.tsx +0 -24
  61. package/src/components/icons/Twitter.tsx +0 -7
  62. package/src/components/icons/icons.ts +0 -212
  63. package/src/components/icons/index.ts +0 -12
  64. package/src/components/index.ts +0 -9
  65. package/src/components/menus/bubble.ts +0 -395
  66. package/src/components/menus/components/BubbleMenuContent.tsx +0 -15
  67. package/src/components/menus/components/BubbleMenuDrawer.tsx +0 -128
  68. package/src/components/menus/components/BubbleMenuExcalidraw.tsx +0 -91
  69. package/src/components/menus/components/BubbleMenuIframe.tsx +0 -143
  70. package/src/components/menus/components/BubbleMenuKatex.tsx +0 -136
  71. package/src/components/menus/components/BubbleMenuLink.tsx +0 -99
  72. package/src/components/menus/components/BubbleMenuMedia.tsx +0 -235
  73. package/src/components/menus/components/BubbleMenuMermaid.tsx +0 -128
  74. package/src/components/menus/components/BubbleMenuText.tsx +0 -102
  75. package/src/components/menus/components/BubbleMenuTwitter.tsx +0 -91
  76. package/src/components/menus/components/ColumnsBubbleMenu.tsx +0 -59
  77. package/src/components/menus/components/ContentMenu.tsx +0 -396
  78. package/src/components/menus/components/TableBubbleMenu.tsx +0 -362
  79. package/src/components/menus/index.ts +0 -7
  80. package/src/components/ui/button.tsx +0 -56
  81. package/src/components/ui/checkbox.tsx +0 -30
  82. package/src/components/ui/dialog.tsx +0 -128
  83. package/src/components/ui/dropdown-menu.tsx +0 -203
  84. package/src/components/ui/emoji-picker.tsx +0 -166
  85. package/src/components/ui/index.ts +0 -14
  86. package/src/components/ui/input.tsx +0 -25
  87. package/src/components/ui/label.tsx +0 -26
  88. package/src/components/ui/popover.tsx +0 -31
  89. package/src/components/ui/select.tsx +0 -162
  90. package/src/components/ui/separator.tsx +0 -31
  91. package/src/components/ui/switch.tsx +0 -29
  92. package/src/components/ui/tabs.tsx +0 -55
  93. package/src/components/ui/textarea.tsx +0 -24
  94. package/src/components/ui/toast.tsx +0 -129
  95. package/src/components/ui/toaster.tsx +0 -44
  96. package/src/components/ui/toggle.tsx +0 -45
  97. package/src/components/ui/tooltip.tsx +0 -30
  98. package/src/components/ui/use-toast.ts +0 -197
  99. package/src/constants/index.ts +0 -223
  100. package/src/constants/resetCSS.ts +0 -139
  101. package/src/extension-bundle.ts +0 -2
  102. package/src/extensions/Attachment/Attachment.ts +0 -144
  103. package/src/extensions/Attachment/components/NodeViewAttachment/FileIcon.tsx +0 -69
  104. package/src/extensions/Attachment/components/NodeViewAttachment/FileIconString.ts +0 -28
  105. package/src/extensions/Attachment/components/NodeViewAttachment/NodeViewAttachment.tsx +0 -155
  106. package/src/extensions/Attachment/components/NodeViewAttachment/index.module.scss +0 -23
  107. package/src/extensions/Attachment/index.ts +0 -1
  108. package/src/extensions/BaseKit.ts +0 -253
  109. package/src/extensions/Blockquote/Blockquote.ts +0 -31
  110. package/src/extensions/Blockquote/index.ts +0 -1
  111. package/src/extensions/Bold/Bold.ts +0 -26
  112. package/src/extensions/Bold/index.ts +0 -1
  113. package/src/extensions/BulletList/BulletList.ts +0 -28
  114. package/src/extensions/BulletList/index.ts +0 -1
  115. package/src/extensions/Clear/Clear.ts +0 -24
  116. package/src/extensions/Clear/index.ts +0 -1
  117. package/src/extensions/Code/Code.ts +0 -26
  118. package/src/extensions/Code/index.ts +0 -1
  119. package/src/extensions/CodeBlock/CodeBlock.ts +0 -54
  120. package/src/extensions/CodeBlock/components/CodeBlockActiveButton.tsx +0 -66
  121. package/src/extensions/CodeBlock/components/NodeViewCodeBlock/NodeViewCodeBlock.tsx +0 -89
  122. package/src/extensions/CodeBlock/components/NodeViewCodeBlock/index.module.scss +0 -81
  123. package/src/extensions/CodeBlock/highlighter.ts +0 -132
  124. package/src/extensions/CodeBlock/index.ts +0 -1
  125. package/src/extensions/CodeBlock/shiki-plugin.ts +0 -213
  126. package/src/extensions/Color/Color.ts +0 -52
  127. package/src/extensions/Color/components/ColorActionButton.tsx +0 -104
  128. package/src/extensions/Color/index.ts +0 -1
  129. package/src/extensions/Document/Document.ts +0 -8
  130. package/src/extensions/Document/index.ts +0 -1
  131. package/src/extensions/Drawer/Drawer.ts +0 -177
  132. package/src/extensions/Drawer/components/ControlDrawer/ControlDrawer.module.scss +0 -85
  133. package/src/extensions/Drawer/components/ControlDrawer/ControlDrawer.tsx +0 -598
  134. package/src/extensions/Drawer/components/ControlDrawer/icon.tsx +0 -500
  135. package/src/extensions/Drawer/components/DrawerActiveButton.tsx +0 -239
  136. package/src/extensions/Drawer/components/EditDrawerBlock.tsx +0 -238
  137. package/src/extensions/Drawer/components/NodeViewDrawer/NodeViewDrawer.tsx +0 -260
  138. package/src/extensions/Drawer/index.ts +0 -1
  139. package/src/extensions/Emoji/Emoji.ts +0 -146
  140. package/src/extensions/Emoji/components/EmojiList/EmojiList.tsx +0 -103
  141. package/src/extensions/Emoji/components/EmojiList/emojis.ts +0 -1858
  142. package/src/extensions/Emoji/components/EmojiPicker/EmojiPicker.tsx +0 -61
  143. package/src/extensions/Emoji/index.ts +0 -1
  144. package/src/extensions/Excalidraw/Excalidraw.ts +0 -123
  145. package/src/extensions/Excalidraw/components/ExcalidrawActiveButton.tsx +0 -138
  146. package/src/extensions/Excalidraw/components/NodeViewExcalidraw/NodeViewExcalidraw.tsx +0 -178
  147. package/src/extensions/Excalidraw/components/NodeViewExcalidraw/index.module.scss +0 -43
  148. package/src/extensions/Excalidraw/index.ts +0 -1
  149. package/src/extensions/ExportPdf/ExportPdf.ts +0 -25
  150. package/src/extensions/ExportPdf/index.ts +0 -1
  151. package/src/extensions/ExportWord/ExportWord.ts +0 -87
  152. package/src/extensions/ExportWord/index.ts +0 -1
  153. package/src/extensions/FontFamily/FontFamily.ts +0 -64
  154. package/src/extensions/FontFamily/components/FontFamilyButton.tsx +0 -97
  155. package/src/extensions/FontFamily/index.ts +0 -1
  156. package/src/extensions/FontSize/FontSize.ts +0 -119
  157. package/src/extensions/FontSize/components/FontSizeMenuButton.tsx +0 -84
  158. package/src/extensions/FontSize/index.ts +0 -1
  159. package/src/extensions/FormatPainter/FormatPainter.ts +0 -121
  160. package/src/extensions/FormatPainter/index.ts +0 -1
  161. package/src/extensions/Heading/Heading.ts +0 -57
  162. package/src/extensions/Heading/components/HeadingButton.tsx +0 -96
  163. package/src/extensions/Heading/index.ts +0 -1
  164. package/src/extensions/Highlight/Highlight.ts +0 -36
  165. package/src/extensions/Highlight/components/HighlightActionButton.tsx +0 -108
  166. package/src/extensions/Highlight/index.ts +0 -1
  167. package/src/extensions/History/History.ts +0 -39
  168. package/src/extensions/History/components/HistoryActionButton.tsx +0 -74
  169. package/src/extensions/History/index.ts +0 -1
  170. package/src/extensions/HorizontalRule/HorizontalRule.ts +0 -42
  171. package/src/extensions/HorizontalRule/index.ts +0 -1
  172. package/src/extensions/Iframe/Iframe.ts +0 -140
  173. package/src/extensions/Iframe/components/IframeNodeView.tsx +0 -92
  174. package/src/extensions/Iframe/components/index.module.scss +0 -40
  175. package/src/extensions/Iframe/embed.ts +0 -487
  176. package/src/extensions/Iframe/index.ts +0 -1
  177. package/src/extensions/Image/Image.ts +0 -303
  178. package/src/extensions/Image/components/ActionImageButton.tsx +0 -186
  179. package/src/extensions/Image/components/ImageCropper.tsx +0 -198
  180. package/src/extensions/Image/components/ImageView.tsx +0 -271
  181. package/src/extensions/Image/index.ts +0 -1
  182. package/src/extensions/Image/store.ts +0 -15
  183. package/src/extensions/ImageGif/ImageGif.ts +0 -176
  184. package/src/extensions/ImageGif/components/ImageGifActionButton.tsx +0 -138
  185. package/src/extensions/ImageGif/components/ImageGifView.tsx +0 -260
  186. package/src/extensions/ImageGif/index.ts +0 -1
  187. package/src/extensions/ImportWord/ImportWord.ts +0 -52
  188. package/src/extensions/ImportWord/components/ImportWordButton.tsx +0 -151
  189. package/src/extensions/ImportWord/index.ts +0 -1
  190. package/src/extensions/Indent/Indent.ts +0 -110
  191. package/src/extensions/Indent/index.ts +0 -1
  192. package/src/extensions/Italic/Italic.ts +0 -29
  193. package/src/extensions/Italic/index.ts +0 -1
  194. package/src/extensions/Katex/Katex.ts +0 -109
  195. package/src/extensions/Katex/components/KatexActiveButton.tsx +0 -117
  196. package/src/extensions/Katex/components/KatexWrapper.tsx +0 -53
  197. package/src/extensions/Katex/index.ts +0 -1
  198. package/src/extensions/LineHeight/LineHeight.ts +0 -76
  199. package/src/extensions/LineHeight/components/LineHeightDropdown.tsx +0 -93
  200. package/src/extensions/LineHeight/index.ts +0 -1
  201. package/src/extensions/Link/Link.ts +0 -92
  202. package/src/extensions/Link/components/LinkEditBlock.tsx +0 -110
  203. package/src/extensions/Link/components/LinkEditPopover.tsx +0 -46
  204. package/src/extensions/Link/components/LinkViewBlock.tsx +0 -54
  205. package/src/extensions/Link/index.ts +0 -1
  206. package/src/extensions/ListItem/ListItem.ts +0 -1
  207. package/src/extensions/ListItem/index.ts +0 -1
  208. package/src/extensions/Mention/Mention.ts +0 -100
  209. package/src/extensions/Mention/components/NodeViewMentionList/NodeViewMentionList.tsx +0 -94
  210. package/src/extensions/Mention/components/NodeViewMentionList/index.module.scss +0 -38
  211. package/src/extensions/Mention/index.ts +0 -1
  212. package/src/extensions/Mermaid/Mermaid.ts +0 -177
  213. package/src/extensions/Mermaid/components/EditMermaidBlock.tsx +0 -155
  214. package/src/extensions/Mermaid/components/MermaidActiveButton.tsx +0 -151
  215. package/src/extensions/Mermaid/components/NodeViewMermaid/NodeViewMermaid.tsx +0 -260
  216. package/src/extensions/Mermaid/index.ts +0 -1
  217. package/src/extensions/MoreMark/MoreMark.ts +0 -102
  218. package/src/extensions/MoreMark/components/ActionMoreButton.tsx +0 -97
  219. package/src/extensions/MoreMark/index.ts +0 -1
  220. package/src/extensions/MultiColumn/Column.ts +0 -36
  221. package/src/extensions/MultiColumn/MultiColumn.ts +0 -111
  222. package/src/extensions/MultiColumn/components/ColumnActionButton.ts +0 -22
  223. package/src/extensions/MultiColumn/index.ts +0 -3
  224. package/src/extensions/OrderedList/OrderedList.ts +0 -28
  225. package/src/extensions/OrderedList/index.ts +0 -1
  226. package/src/extensions/SearchAndReplace/SearchAndReplace.ts +0 -395
  227. package/src/extensions/SearchAndReplace/components/SearchAndReplaceButton.tsx +0 -190
  228. package/src/extensions/SearchAndReplace/index.ts +0 -1
  229. package/src/extensions/Selection/Selection.ts +0 -32
  230. package/src/extensions/Selection/index.ts +0 -1
  231. package/src/extensions/SlashCommand/SlashCommand.ts +0 -255
  232. package/src/extensions/SlashCommand/components/CommandsList.tsx +0 -180
  233. package/src/extensions/SlashCommand/groups.ts +0 -183
  234. package/src/extensions/SlashCommand/index.ts +0 -1
  235. package/src/extensions/SlashCommand/types.ts +0 -24
  236. package/src/extensions/Strike/Strike.ts +0 -26
  237. package/src/extensions/Strike/index.ts +0 -1
  238. package/src/extensions/Subscript/Subscript.ts +0 -88
  239. package/src/extensions/Subscript/index.ts +0 -1
  240. package/src/extensions/Table/Cell.ts +0 -131
  241. package/src/extensions/Table/Header.ts +0 -93
  242. package/src/extensions/Table/Row.ts +0 -8
  243. package/src/extensions/Table/Table.ts +0 -60
  244. package/src/extensions/Table/cell-background.ts +0 -112
  245. package/src/extensions/Table/components/CreateTablePopover.tsx +0 -132
  246. package/src/extensions/Table/components/TableActionButton.tsx +0 -42
  247. package/src/extensions/Table/index.ts +0 -6
  248. package/src/extensions/Table/utils.ts +0 -352
  249. package/src/extensions/TableOfContent/TableOfContent.ts +0 -124
  250. package/src/extensions/TableOfContent/components/NodeViewTableOfContent.tsx +0 -116
  251. package/src/extensions/TableOfContent/components/TableOfContentActionButton.tsx +0 -27
  252. package/src/extensions/TableOfContent/components/index.module.scss +0 -40
  253. package/src/extensions/TableOfContent/index.ts +0 -1
  254. package/src/extensions/TaskList/TaskList.ts +0 -46
  255. package/src/extensions/TaskList/index.ts +0 -1
  256. package/src/extensions/TextAlign/TextAlign.ts +0 -68
  257. package/src/extensions/TextAlign/components/TextAlignMenuButton.tsx +0 -103
  258. package/src/extensions/TextAlign/index.ts +0 -1
  259. package/src/extensions/TextBubble/TextBubble.ts +0 -22
  260. package/src/extensions/TextBubble/components/TextDropdown.tsx +0 -146
  261. package/src/extensions/TextBubble/index.ts +0 -1
  262. package/src/extensions/TextDirection/TextDirection.ts +0 -97
  263. package/src/extensions/TextDirection/components/TextDirectionButton.tsx +0 -103
  264. package/src/extensions/TextDirection/index.ts +0 -1
  265. package/src/extensions/TrailingNode/TrailingNode.ts +0 -71
  266. package/src/extensions/TrailingNode/index.ts +0 -1
  267. package/src/extensions/Twitter/Twitter.ts +0 -161
  268. package/src/extensions/Twitter/components/FormEditLinkTwitter.tsx +0 -68
  269. package/src/extensions/Twitter/components/NodeViewTweet.tsx +0 -30
  270. package/src/extensions/Twitter/components/TwitterActiveButton.tsx +0 -41
  271. package/src/extensions/Twitter/index.ts +0 -1
  272. package/src/extensions/UnderLine/Underline.ts +0 -30
  273. package/src/extensions/UnderLine/index.ts +0 -1
  274. package/src/extensions/Video/Video.ts +0 -204
  275. package/src/extensions/Video/components/ActiveVideoButton.tsx +0 -191
  276. package/src/extensions/Video/index.ts +0 -1
  277. package/src/extensions/Video/store.ts +0 -15
  278. package/src/extensions/index.ts +0 -122
  279. package/src/hooks/useActive.tsx +0 -24
  280. package/src/hooks/useAttributes.tsx +0 -45
  281. package/src/hooks/useCopy.tsx +0 -20
  282. package/src/hooks/useEditorState.tsx +0 -23
  283. package/src/hooks/useExtension.tsx +0 -29
  284. package/src/index.ts +0 -8
  285. package/src/lib/utils.ts +0 -7
  286. package/src/locale-bundle.ts +0 -3
  287. package/src/locales/en.ts +0 -173
  288. package/src/locales/hu.ts +0 -173
  289. package/src/locales/index.tsx +0 -163
  290. package/src/locales/pt-br.ts +0 -173
  291. package/src/locales/vi.ts +0 -173
  292. package/src/locales/zh-cn.ts +0 -173
  293. package/src/plugins/DragHandle/index.ts +0 -375
  294. package/src/plugins/DragHandle/range.ts +0 -114
  295. package/src/plugins/DragHandle/utils.ts +0 -80
  296. package/src/plugins/image-upload.ts +0 -160
  297. package/src/store/ProviderRichText.tsx +0 -53
  298. package/src/store/editableEditor.ts +0 -15
  299. package/src/store/fast-context.tsx +0 -70
  300. package/src/store/store.ts +0 -35
  301. package/src/styles/ProseMirror.scss +0 -176
  302. package/src/styles/columns.scss +0 -23
  303. package/src/styles/editor.scss +0 -411
  304. package/src/styles/global.scss +0 -87
  305. package/src/styles/index.scss +0 -5
  306. package/src/styles/mention.scss +0 -6
  307. package/src/theme/theme.ts +0 -15
  308. package/src/types.ts +0 -271
  309. package/src/utils/_event.ts +0 -55
  310. package/src/utils/color.ts +0 -67
  311. package/src/utils/columns.ts +0 -142
  312. package/src/utils/customEvents/customEvents.ts +0 -18
  313. package/src/utils/customEvents/events.constant.ts +0 -11
  314. package/src/utils/delete-node.ts +0 -46
  315. package/src/utils/dom-dataset.ts +0 -121
  316. package/src/utils/download.ts +0 -17
  317. package/src/utils/dynamicCSS.ts +0 -192
  318. package/src/utils/editor-container-size.ts +0 -28
  319. package/src/utils/file.ts +0 -112
  320. package/src/utils/getRenderContainer.ts +0 -41
  321. package/src/utils/indent.ts +0 -99
  322. package/src/utils/is-mobile.ts +0 -57
  323. package/src/utils/json.ts +0 -18
  324. package/src/utils/line-height.ts +0 -109
  325. package/src/utils/lru-cache.ts +0 -145
  326. package/src/utils/mitt.ts +0 -114
  327. package/src/utils/node.ts +0 -92
  328. package/src/utils/pdf.ts +0 -72
  329. package/src/utils/plateform.ts +0 -49
  330. package/src/utils/shortId.ts +0 -5
  331. package/src/utils/storage.ts +0 -18
  332. package/src/utils/utils.ts +0 -71
  333. package/src/vite-env.d.ts +0 -3
@@ -1,143 +0,0 @@
1
- import { useCallback, useEffect, useState } from 'react';
2
-
3
- import { BubbleMenu } from '@tiptap/react';
4
- import { useAttributes } from '@/hooks/useAttributes';
5
- import { ActionButton } from '@/components/ActionButton';
6
- import { Dialog, DialogContent, DialogFooter, DialogHeader, DialogTitle, DialogTrigger } from '@/components/ui/dialog';
7
- import { Button, Input } from '@/components/ui';
8
- import { SizeSetter } from '@/components/SizeSetter/SizeSetter';
9
- import { useLocale } from '@/locales';
10
- import type { IIframeAttrs } from '@/extensions/Iframe';
11
- import { Iframe } from '@/extensions/Iframe';
12
- import { deleteNode } from '@/utils/delete-node';
13
-
14
- export function BubbleMenuIframe({ editor }: any) {
15
- const { t } = useLocale();
16
- const { width, height, url } = useAttributes<IIframeAttrs>(editor, Iframe.name, {
17
- width: 0,
18
- height: 0,
19
- url: '',
20
- defaultShowPicker: false,
21
- });
22
- const [visible, toggleVisible] = useState(false);
23
- const [formUrl, setFormUrl] = useState('');
24
-
25
- const handleCancel = useCallback(() => {
26
- toggleVisible(false);
27
- }, [toggleVisible]);
28
-
29
- useEffect(() => {
30
- if (visible)
31
- setFormUrl(url as any);
32
- }, [visible, url]);
33
-
34
- const handleOk = useCallback(() => {
35
- editor
36
- .chain()
37
- .updateAttributes(Iframe.name, {
38
- url: formUrl,
39
- })
40
- .setNodeSelection(editor.state.selection.from)
41
- .focus()
42
- .run();
43
- toggleVisible(false);
44
- }, [editor, formUrl, toggleVisible]);
45
-
46
- const visitLink = useCallback(() => {
47
- window.open(url, '_blank');
48
- }, [url]);
49
-
50
- const openEditLinkModal = useCallback(() => {
51
- toggleVisible(true);
52
- }, [toggleVisible]);
53
-
54
- const setSize = useCallback(
55
- (size: any) => {
56
- editor.chain().updateAttributes(Iframe.name, size).setNodeSelection(editor.state.selection.from).focus().run();
57
- },
58
- [editor],
59
- );
60
- const shouldShow = useCallback(() => editor.isActive(Iframe.name) && !url, [editor, url]);
61
- const deleteMe = useCallback(() => deleteNode(Iframe.name, editor), [editor]);
62
-
63
- return (
64
- <>
65
- <BubbleMenu
66
- className="bubble-menu"
67
- editor={editor}
68
- pluginKey="iframe-bubble-menu"
69
- shouldShow={shouldShow}
70
- tippyOptions={{
71
- popperOptions: {
72
- modifiers: [{ name: 'flip', enabled: false }],
73
- },
74
- placement: 'bottom-start',
75
- offset: [-2, 16],
76
- zIndex: 9999,
77
- // onHidden: () => {
78
- // toggleVisible(false)
79
- // },
80
- }}
81
- >
82
-
83
- <div className="w-auto px-3 py-2 transition-all !border rounded-sm shadow-sm pointer-events-auto select-none border-neutral-200 dark:border-neutral-800 bg-background">
84
- <ActionButton
85
- action={visitLink}
86
- icon="Eye"
87
- tooltip="Visit Link"
88
- />
89
- <ActionButton
90
- action={openEditLinkModal}
91
- icon="Pencil"
92
- tooltip="Open Edit Link"
93
- />
94
-
95
- <SizeSetter width={width as any} height={height as any} onOk={setSize}>
96
- <ActionButton
97
- icon="Settings"
98
- tooltip={t('editor.settings')}
99
- />
100
- </SizeSetter>
101
-
102
- <ActionButton
103
- action={deleteMe}
104
- icon="Trash2"
105
- tooltip={t('editor.delete')}
106
- />
107
- </div>
108
- </BubbleMenu>
109
-
110
- <Dialog
111
- open={visible}
112
- onOpenChange={toggleVisible}
113
- >
114
- <DialogTrigger />
115
-
116
- <DialogContent>
117
- <DialogHeader>
118
- <DialogTitle>
119
- Edit Link Iframe
120
- </DialogTitle>
121
- </DialogHeader>
122
-
123
- <Input
124
- value={formUrl}
125
- onInput={(e: any) => setFormUrl(e.target.value)}
126
- type="url"
127
- autoFocus
128
- placeholder="Enter link"
129
- />
130
-
131
- <DialogFooter>
132
- <Button onClick={handleCancel}>
133
- Cancel
134
- </Button>
135
- <Button onClick={handleOk}>
136
- OK
137
- </Button>
138
- </DialogFooter>
139
- </DialogContent>
140
- </Dialog>
141
- </>
142
- );
143
- }
@@ -1,136 +0,0 @@
1
- import { BubbleMenu } from '@tiptap/react';
2
- import React, { useCallback, useEffect, useMemo, useState } from 'react';
3
- import { HelpCircle, Pencil, Trash2 } from 'lucide-react';
4
- import katex from 'katex';
5
- import { Katex } from '@/extensions';
6
- import { deleteNode } from '@/utils/delete-node';
7
- import { useAttributes } from '@/hooks/useAttributes';
8
- import type { IKatexAttrs } from '@/extensions/Katex';
9
- import { Textarea } from '@/components/ui/textarea';
10
- import { ActionButton } from '@/components/ActionButton';
11
- import { Button } from '@/components/ui';
12
-
13
- function BubbleMenuKatex({ editor, ...props }: any) {
14
- const attrs = useAttributes<IKatexAttrs>(editor, Katex.name, {
15
- text: '',
16
- defaultShowPicker: false,
17
- });
18
- const { text, defaultShowPicker } = attrs;
19
-
20
- const [currentValue, setCurrentValue] = useState('');
21
- const [visible, toggleVisible] = useState(false);
22
-
23
- const shouldShow = useCallback(() => editor.isActive(Katex.name), [editor]);
24
-
25
- const deleteMe = useCallback(() => deleteNode(Katex.name, editor), [editor]);
26
-
27
- const submit = useCallback(() => {
28
- editor.chain().focus().setKatex({ text: currentValue }).run();
29
- toggleVisible(false);
30
- }, [editor, currentValue]);
31
-
32
- useEffect(() => {
33
- if (defaultShowPicker) {
34
- toggleVisible(true);
35
- editor.chain().updateAttributes(Katex.name, { defaultShowPicker: false }).focus().run();
36
- }
37
- }, [editor, defaultShowPicker, toggleVisible]);
38
-
39
- useEffect(() => {
40
- if (visible)
41
- setCurrentValue(text || '');
42
- }, [visible]);
43
-
44
- const formatText = useMemo(() => {
45
- try {
46
- return katex.renderToString(`${currentValue}`);
47
- } catch {
48
- return currentValue;
49
- }
50
- }, [currentValue]);
51
-
52
- const previewContent = useMemo(
53
- () => {
54
- if (`${currentValue}`.trim()) {
55
- return (
56
- <span contentEditable={false} dangerouslySetInnerHTML={{ __html: formatText || '' }}></span>
57
- );
58
- }
59
-
60
- return null;
61
- },
62
- [currentValue, formatText],
63
- );
64
-
65
- return (
66
- <BubbleMenu
67
- editor={editor}
68
- pluginKey="Katex-bubble-menu"
69
- shouldShow={shouldShow}
70
- tippyOptions={{
71
- popperOptions: {
72
- modifiers: [{ name: 'flip', enabled: false }],
73
- },
74
- placement: 'bottom-start',
75
- offset: [-2, 16],
76
- zIndex: 9999,
77
- onHidden: () => {
78
- toggleVisible(false);
79
- },
80
- }}
81
- >
82
- {props?.disabled
83
- ? (
84
- <></>
85
- )
86
- : (
87
- <div className="p-2 bg-white !border rounded-lg shadow-sm dark:bg-black border-neutral-200 dark:border-neutral-800">
88
- {visible
89
- ? (
90
- <>
91
- <Textarea
92
- value={currentValue}
93
- onChange={e => setCurrentValue(e.target.value)}
94
- autoFocus
95
- placeholder="Formula text"
96
- rows={3}
97
- defaultValue={text}
98
- style={{ marginBottom: 8 }}
99
- />
100
-
101
- {previewContent && (
102
- <div className="my-[10px] p-[10px] rounded-[6px] !border-[1px] whitespace-nowrap overflow-auto">
103
- {previewContent}
104
- </div>
105
- )}
106
-
107
- <div className="flex items-center justify-between gap-[6px]">
108
- <Button onClick={submit} className="flex-1">
109
- Submit
110
- </Button>
111
-
112
- <a href="https://katex.org/docs/supported" target="_blank" rel="noreferrer noopener">
113
- <HelpCircle size={16} />
114
- </a>
115
- </div>
116
- </>
117
- )
118
- : (
119
- <div className="flex items-center justify-center gap-[6px]">
120
- <ActionButton tooltip="Edit" action={() => toggleVisible(!visible)}>
121
- <Pencil size={16} />
122
- </ActionButton>
123
-
124
- <ActionButton tooltip="Delete" action={deleteMe}>
125
- <Trash2 size={16} />
126
- </ActionButton>
127
- </div>
128
- )}
129
- </div>
130
- )}
131
-
132
- </BubbleMenu>
133
- );
134
- }
135
-
136
- export default BubbleMenuKatex;
@@ -1,99 +0,0 @@
1
- import { useCallback, useMemo, useState } from 'react';
2
-
3
- import type { Editor } from '@tiptap/react';
4
- import { BubbleMenu } from '@tiptap/react';
5
-
6
- import LinkEditBlock from '@/extensions/Link/components/LinkEditBlock';
7
- import LinkViewBlock from '@/extensions/Link/components/LinkViewBlock';
8
-
9
- export interface BubbleMenuLinkProps {
10
- editor: Editor
11
- disabled?: boolean
12
- }
13
-
14
- function BubbleMenuLink({ editor, disabled }: BubbleMenuLinkProps) {
15
- const [showEdit, setShowEdit] = useState(false);
16
-
17
- const link = useMemo(() => {
18
- const { href: link } = editor.getAttributes('link');
19
- return link as string;
20
- }, [editor]);
21
-
22
- const shouldShow = useCallback(({ editor }: { editor: Editor }) => {
23
- const isActive = editor.isActive('link');
24
- return isActive;
25
- }, []);
26
-
27
- const onSetLink = (url: string, text?: string, openInNewTab?: boolean) => {
28
- editor
29
- .chain()
30
- .extendMarkRange('link')
31
- .insertContent({
32
- type: 'text',
33
- text,
34
- marks: [
35
- {
36
- type: 'link',
37
- attrs: {
38
- href: url,
39
- target: openInNewTab ? '_blank' : '',
40
- },
41
- },
42
- ],
43
- })
44
- .setLink({ href: url })
45
- .focus()
46
- .run();
47
- setShowEdit(false);
48
- };
49
-
50
- const unSetLink = useCallback(() => {
51
- editor.chain().extendMarkRange('link').unsetLink().focus().run();
52
- setShowEdit(false);
53
- }, [editor]);
54
-
55
- return (
56
- <>
57
- <BubbleMenu
58
- editor={editor}
59
- shouldShow={shouldShow}
60
- tippyOptions={{
61
- popperOptions: {
62
- modifiers: [{ name: 'flip', enabled: false }],
63
- },
64
- placement: 'bottom-start',
65
- offset: [-2, 16],
66
- zIndex: 9999,
67
- onHidden: () => {
68
- setShowEdit(false);
69
- },
70
- }}
71
- >
72
- {disabled
73
- ? (
74
- <></>
75
- )
76
- : (
77
- <>
78
- {showEdit
79
- ? (
80
- <LinkEditBlock onSetLink={onSetLink} editor={editor} />
81
- )
82
- : (
83
- <LinkViewBlock
84
- editor={editor}
85
- onClear={unSetLink}
86
- onEdit={() => {
87
- setShowEdit(true);
88
- }}
89
- link={link}
90
- />
91
- )}
92
- </>
93
- )}
94
- </BubbleMenu>
95
- </>
96
- );
97
- }
98
-
99
- export { BubbleMenuLink };
@@ -1,235 +0,0 @@
1
- import { Fragment, useMemo } from 'react';
2
-
3
- import type { Editor } from '@tiptap/react';
4
- import { BubbleMenu as BubbleMenuReact } from '@tiptap/react';
5
-
6
- import { Separator, getBubbleImage, getBubbleImageGif, getBubbleVideo } from '@/components';
7
- import { Image, ImageGif, Video } from '@/extensions';
8
- import { useLocale } from '@/locales';
9
-
10
- interface IPropsBubbleMenu {
11
- editor: Editor
12
- disabled?: boolean
13
- }
14
-
15
- const tippyOptions = {
16
- maxWidth: 'auto',
17
- zIndex: 20,
18
- appendTo: 'parent',
19
- moveTransition: 'transform 0.1s ease-out',
20
- };
21
-
22
- function ItemA({ item, disabled, editor }: any) {
23
- const Comp = item.component;
24
-
25
- if (!Comp) {
26
- return <></>;
27
- }
28
-
29
- return (
30
- <Fragment>
31
- {item.type === 'divider'
32
- ? (
33
- <Separator className="!mx-1 !my-2 !h-[16px]"
34
- orientation="vertical"
35
- />
36
- )
37
- : (
38
- <Comp
39
- {...item.componentProps}
40
- disabled={disabled || item?.componentProps?.disabled}
41
- editor={editor}
42
- />
43
- )}
44
- </Fragment>
45
- );
46
- }
47
-
48
- function isImageNode(node: any) {
49
- return node.type.name === Image.name;
50
- }
51
-
52
- function isImageGifNode(node: any) {
53
- return node.type.name === ImageGif.name;
54
- }
55
-
56
- function isVideoNode(node: any) {
57
- return node.type.name === Video.name;
58
- }
59
-
60
- function BubbleMenuImage(props: IPropsBubbleMenu) {
61
- const { lang } = useLocale();
62
-
63
- const shouldShow = ({ editor }: any) => {
64
- const { selection } = editor.view.state;
65
- const { $from, to } = selection;
66
- let isImage = false;
67
-
68
- editor.view.state.doc.nodesBetween($from.pos, to, (node: any) => {
69
- if (isImageNode(node)) {
70
- isImage = true;
71
- return false; // Stop iteration if an image is found
72
- }
73
- });
74
-
75
- return isImage;
76
- };
77
-
78
- const items = useMemo(() => {
79
- if (props.disabled) {
80
- return [];
81
- }
82
- return getBubbleImage(props.editor);
83
- // eslint-disable-next-line react-hooks/exhaustive-deps
84
- }, [props.disabled, props.editor, lang]);
85
-
86
- return (
87
- <>
88
- <BubbleMenuReact
89
- editor={props?.editor}
90
- shouldShow={shouldShow}
91
- tippyOptions={tippyOptions as any}
92
- >
93
- {items?.length
94
- ? (
95
- <div className="pointer-events-auto w-auto select-none rounded-sm !border border-neutral-200 bg-background px-3 py-2 shadow-sm transition-all dark:border-neutral-800">
96
- <div className="relative flex h-[26px] flex-nowrap items-center justify-start whitespace-nowrap">
97
- {items?.map((item: any, key: any) => {
98
- return (
99
- <ItemA
100
- disabled={props.disabled}
101
- editor={props.editor}
102
- item={item}
103
- key={`bubbleMenu-image-${key}`}
104
- />
105
- );
106
- })}
107
- </div>
108
- </div>
109
- )
110
- : (
111
- <></>
112
- )}
113
- </BubbleMenuReact>
114
- </>
115
- );
116
- }
117
-
118
- function BubbleMenuImageGif(props: IPropsBubbleMenu) {
119
- const { lang } = useLocale();
120
-
121
- const shouldShow = ({ editor }: any) => {
122
- const { selection } = editor.view.state;
123
- const { $from, to } = selection;
124
- let isImage = false;
125
-
126
- editor.view.state.doc.nodesBetween($from.pos, to, (node: any) => {
127
- if (isImageGifNode(node)) {
128
- isImage = true;
129
- return false; // Stop iteration if an image is found
130
- }
131
- });
132
-
133
- return isImage;
134
- };
135
-
136
- const items = useMemo(() => {
137
- if (props.disabled) {
138
- return [];
139
- }
140
- return getBubbleImageGif(props.editor);
141
- // eslint-disable-next-line react-hooks/exhaustive-deps
142
- }, [props.disabled, props.editor, lang]);
143
-
144
- return (
145
- <>
146
- <BubbleMenuReact
147
- editor={props?.editor}
148
- shouldShow={shouldShow}
149
- tippyOptions={tippyOptions as any}
150
- >
151
- {items?.length
152
- ? (
153
- <div className="pointer-events-auto w-auto select-none rounded-sm !border border-neutral-200 bg-background px-3 py-2 shadow-sm transition-all dark:border-neutral-800">
154
- <div className="relative flex h-[26px] flex-nowrap items-center justify-start whitespace-nowrap">
155
- {items?.map((item: any, key: any) => {
156
- return (
157
- <ItemA
158
- disabled={props.disabled}
159
- editor={props.editor}
160
- item={item}
161
- key={`bubbleMenu-image-gif-${key}`}
162
- />
163
- );
164
- })}
165
- </div>
166
- </div>
167
- )
168
- : (
169
- <></>
170
- )}
171
- </BubbleMenuReact>
172
- </>
173
- );
174
- }
175
-
176
- function BubbleMenuVideo(props: IPropsBubbleMenu) {
177
- const { lang } = useLocale();
178
-
179
- const shouldShow = ({ editor }: any) => {
180
- const { selection } = editor.view.state;
181
- const { $from, to } = selection;
182
- let isVideo = false;
183
-
184
- editor.view.state.doc.nodesBetween($from.pos, to, (node: any) => {
185
- if (isVideoNode(node)) {
186
- isVideo = true;
187
- return false;
188
- }
189
- });
190
-
191
- return isVideo;
192
- };
193
-
194
- const items = useMemo(() => {
195
- if (props.disabled) {
196
- return [];
197
- }
198
-
199
- return getBubbleVideo(props.editor);
200
- // eslint-disable-next-line react-hooks/exhaustive-deps
201
- }, [props.editor, props.disabled, lang]);
202
-
203
- return (
204
- <>
205
- <BubbleMenuReact
206
- editor={props?.editor}
207
- shouldShow={shouldShow}
208
- tippyOptions={tippyOptions as any}
209
- >
210
- {items?.length
211
- ? (
212
- <div className="pointer-events-auto w-auto select-none rounded-sm !border border-neutral-200 bg-background px-3 py-2 shadow-sm transition-all dark:border-neutral-800">
213
- <div className="relative flex h-[26px] flex-nowrap items-center justify-start whitespace-nowrap">
214
- {items?.map((item: any, key: any) => {
215
- return (
216
- <ItemA
217
- disabled={props.disabled}
218
- editor={props.editor}
219
- item={item}
220
- key={`bubbleMenu-video-${key}`}
221
- />
222
- );
223
- })}
224
- </div>
225
- </div>
226
- )
227
- : (
228
- <></>
229
- )}
230
- </BubbleMenuReact>
231
- </>
232
- );
233
- }
234
-
235
- export { BubbleMenuImage, BubbleMenuVideo, BubbleMenuImageGif };