reactjs-tiptap-editor-pro 0.2.31 → 0.2.33

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 (331) hide show
  1. package/lib/ColorPicker-MEAh4MhG.js +28181 -0
  2. package/lib/ColorPicker-ZncOwjAP.cjs +142 -0
  3. package/lib/extension-bundle.cjs +133 -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 +23921 -0
  7. package/lib/index.cjs +140 -0
  8. package/lib/index.d.cts +513 -0
  9. package/lib/index.d.ts +513 -0
  10. package/lib/index.js +3700 -0
  11. package/lib/locale-bundle-DiqW5jwb.cjs +1 -0
  12. package/lib/locale-bundle-DxCAtRDI.js +1487 -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/lucide-react-BFZtMawV.js +30462 -0
  18. package/lib/lucide-react-CMPhLW1m.cjs +7851 -0
  19. package/lib/style.css +1 -0
  20. package/package.json +58 -5
  21. package/src/components/ActionButton.tsx +0 -103
  22. package/src/components/ActionMenuButton.tsx +0 -76
  23. package/src/components/BubbleMenu.tsx +0 -93
  24. package/src/components/CharactorCount.tsx +0 -50
  25. package/src/components/ColorPicker.tsx +0 -272
  26. package/src/components/RichTextEditor.tsx +0 -212
  27. package/src/components/SizeSetter/SizeSetter.tsx +0 -102
  28. package/src/components/Toolbar.tsx +0 -108
  29. package/src/components/icons/Activity.tsx +0 -19
  30. package/src/components/icons/Animas.tsx +0 -24
  31. package/src/components/icons/AspectRatio.tsx +0 -13
  32. package/src/components/icons/Blockquote.tsx +0 -17
  33. package/src/components/icons/ColumnAddLeft.tsx +0 -7
  34. package/src/components/icons/ColumnAddRight.tsx +0 -7
  35. package/src/components/icons/DeleteColumn.tsx +0 -26
  36. package/src/components/icons/DeleteRow.tsx +0 -26
  37. package/src/components/icons/Direction.tsx +0 -7
  38. package/src/components/icons/Excalidraw.tsx +0 -7
  39. package/src/components/icons/ExportPdf.tsx +0 -8
  40. package/src/components/icons/ExportWord.tsx +0 -24
  41. package/src/components/icons/FileWordOutline.tsx +0 -13
  42. package/src/components/icons/Flag.tsx +0 -19
  43. package/src/components/icons/Food.tsx +0 -20
  44. package/src/components/icons/GIfIcon.tsx +0 -10
  45. package/src/components/icons/Icon.tsx +0 -30
  46. package/src/components/icons/ImportWord.tsx +0 -23
  47. package/src/components/icons/LeftToRight.tsx +0 -7
  48. package/src/components/icons/LineHeight.tsx +0 -13
  49. package/src/components/icons/MenuDown.tsx +0 -24
  50. package/src/components/icons/Mermaid.tsx +0 -13
  51. package/src/components/icons/NoFill.tsx +0 -7
  52. package/src/components/icons/Object.tsx +0 -24
  53. package/src/components/icons/RightToLeft.tsx +0 -7
  54. package/src/components/icons/SizeL.tsx +0 -9
  55. package/src/components/icons/SizeM.tsx +0 -13
  56. package/src/components/icons/SizeS.tsx +0 -13
  57. package/src/components/icons/Symbol.tsx +0 -19
  58. package/src/components/icons/Travel.tsx +0 -24
  59. package/src/components/icons/Twitter.tsx +0 -7
  60. package/src/components/icons/icons.ts +0 -212
  61. package/src/components/icons/index.ts +0 -12
  62. package/src/components/index.ts +0 -9
  63. package/src/components/menus/bubble.ts +0 -395
  64. package/src/components/menus/components/BubbleMenuContent.tsx +0 -15
  65. package/src/components/menus/components/BubbleMenuDrawer.tsx +0 -128
  66. package/src/components/menus/components/BubbleMenuExcalidraw.tsx +0 -91
  67. package/src/components/menus/components/BubbleMenuIframe.tsx +0 -143
  68. package/src/components/menus/components/BubbleMenuKatex.tsx +0 -136
  69. package/src/components/menus/components/BubbleMenuLink.tsx +0 -99
  70. package/src/components/menus/components/BubbleMenuMedia.tsx +0 -235
  71. package/src/components/menus/components/BubbleMenuMermaid.tsx +0 -128
  72. package/src/components/menus/components/BubbleMenuText.tsx +0 -102
  73. package/src/components/menus/components/BubbleMenuTwitter.tsx +0 -91
  74. package/src/components/menus/components/ColumnsBubbleMenu.tsx +0 -59
  75. package/src/components/menus/components/ContentMenu.tsx +0 -396
  76. package/src/components/menus/components/TableBubbleMenu.tsx +0 -362
  77. package/src/components/menus/index.ts +0 -7
  78. package/src/components/ui/button.tsx +0 -56
  79. package/src/components/ui/checkbox.tsx +0 -30
  80. package/src/components/ui/dialog.tsx +0 -128
  81. package/src/components/ui/dropdown-menu.tsx +0 -203
  82. package/src/components/ui/emoji-picker.tsx +0 -166
  83. package/src/components/ui/index.ts +0 -14
  84. package/src/components/ui/input.tsx +0 -25
  85. package/src/components/ui/label.tsx +0 -26
  86. package/src/components/ui/popover.tsx +0 -31
  87. package/src/components/ui/select.tsx +0 -162
  88. package/src/components/ui/separator.tsx +0 -31
  89. package/src/components/ui/switch.tsx +0 -29
  90. package/src/components/ui/tabs.tsx +0 -55
  91. package/src/components/ui/textarea.tsx +0 -24
  92. package/src/components/ui/toast.tsx +0 -129
  93. package/src/components/ui/toaster.tsx +0 -44
  94. package/src/components/ui/toggle.tsx +0 -45
  95. package/src/components/ui/tooltip.tsx +0 -30
  96. package/src/components/ui/use-toast.ts +0 -197
  97. package/src/constants/index.ts +0 -223
  98. package/src/constants/resetCSS.ts +0 -139
  99. package/src/extension-bundle.ts +0 -2
  100. package/src/extensions/Attachment/Attachment.ts +0 -144
  101. package/src/extensions/Attachment/components/NodeViewAttachment/FileIcon.tsx +0 -69
  102. package/src/extensions/Attachment/components/NodeViewAttachment/FileIconString.ts +0 -28
  103. package/src/extensions/Attachment/components/NodeViewAttachment/NodeViewAttachment.tsx +0 -155
  104. package/src/extensions/Attachment/components/NodeViewAttachment/index.module.scss +0 -23
  105. package/src/extensions/Attachment/index.ts +0 -1
  106. package/src/extensions/BaseKit.ts +0 -253
  107. package/src/extensions/Blockquote/Blockquote.ts +0 -31
  108. package/src/extensions/Blockquote/index.ts +0 -1
  109. package/src/extensions/Bold/Bold.ts +0 -26
  110. package/src/extensions/Bold/index.ts +0 -1
  111. package/src/extensions/BulletList/BulletList.ts +0 -28
  112. package/src/extensions/BulletList/index.ts +0 -1
  113. package/src/extensions/Clear/Clear.ts +0 -24
  114. package/src/extensions/Clear/index.ts +0 -1
  115. package/src/extensions/Code/Code.ts +0 -26
  116. package/src/extensions/Code/index.ts +0 -1
  117. package/src/extensions/CodeBlock/CodeBlock.ts +0 -54
  118. package/src/extensions/CodeBlock/components/CodeBlockActiveButton.tsx +0 -66
  119. package/src/extensions/CodeBlock/components/NodeViewCodeBlock/NodeViewCodeBlock.tsx +0 -89
  120. package/src/extensions/CodeBlock/components/NodeViewCodeBlock/index.module.scss +0 -81
  121. package/src/extensions/CodeBlock/highlighter.ts +0 -132
  122. package/src/extensions/CodeBlock/index.ts +0 -1
  123. package/src/extensions/CodeBlock/shiki-plugin.ts +0 -213
  124. package/src/extensions/Color/Color.ts +0 -52
  125. package/src/extensions/Color/components/ColorActionButton.tsx +0 -104
  126. package/src/extensions/Color/index.ts +0 -1
  127. package/src/extensions/Document/Document.ts +0 -8
  128. package/src/extensions/Document/index.ts +0 -1
  129. package/src/extensions/Drawer/Drawer.ts +0 -177
  130. package/src/extensions/Drawer/components/ControlDrawer/ControlDrawer.module.scss +0 -85
  131. package/src/extensions/Drawer/components/ControlDrawer/ControlDrawer.tsx +0 -598
  132. package/src/extensions/Drawer/components/ControlDrawer/icon.tsx +0 -500
  133. package/src/extensions/Drawer/components/DrawerActiveButton.tsx +0 -239
  134. package/src/extensions/Drawer/components/EditDrawerBlock.tsx +0 -238
  135. package/src/extensions/Drawer/components/NodeViewDrawer/NodeViewDrawer.tsx +0 -260
  136. package/src/extensions/Drawer/index.ts +0 -1
  137. package/src/extensions/Emoji/Emoji.ts +0 -146
  138. package/src/extensions/Emoji/components/EmojiList/EmojiList.tsx +0 -103
  139. package/src/extensions/Emoji/components/EmojiList/emojis.ts +0 -1858
  140. package/src/extensions/Emoji/components/EmojiPicker/EmojiPicker.tsx +0 -61
  141. package/src/extensions/Emoji/index.ts +0 -1
  142. package/src/extensions/Excalidraw/Excalidraw.ts +0 -123
  143. package/src/extensions/Excalidraw/components/ExcalidrawActiveButton.tsx +0 -138
  144. package/src/extensions/Excalidraw/components/NodeViewExcalidraw/NodeViewExcalidraw.tsx +0 -178
  145. package/src/extensions/Excalidraw/components/NodeViewExcalidraw/index.module.scss +0 -43
  146. package/src/extensions/Excalidraw/index.ts +0 -1
  147. package/src/extensions/ExportPdf/ExportPdf.ts +0 -25
  148. package/src/extensions/ExportPdf/index.ts +0 -1
  149. package/src/extensions/ExportWord/ExportWord.ts +0 -87
  150. package/src/extensions/ExportWord/index.ts +0 -1
  151. package/src/extensions/FontFamily/FontFamily.ts +0 -64
  152. package/src/extensions/FontFamily/components/FontFamilyButton.tsx +0 -97
  153. package/src/extensions/FontFamily/index.ts +0 -1
  154. package/src/extensions/FontSize/FontSize.ts +0 -119
  155. package/src/extensions/FontSize/components/FontSizeMenuButton.tsx +0 -84
  156. package/src/extensions/FontSize/index.ts +0 -1
  157. package/src/extensions/FormatPainter/FormatPainter.ts +0 -121
  158. package/src/extensions/FormatPainter/index.ts +0 -1
  159. package/src/extensions/Heading/Heading.ts +0 -57
  160. package/src/extensions/Heading/components/HeadingButton.tsx +0 -96
  161. package/src/extensions/Heading/index.ts +0 -1
  162. package/src/extensions/Highlight/Highlight.ts +0 -36
  163. package/src/extensions/Highlight/components/HighlightActionButton.tsx +0 -108
  164. package/src/extensions/Highlight/index.ts +0 -1
  165. package/src/extensions/History/History.ts +0 -39
  166. package/src/extensions/History/components/HistoryActionButton.tsx +0 -74
  167. package/src/extensions/History/index.ts +0 -1
  168. package/src/extensions/HorizontalRule/HorizontalRule.ts +0 -42
  169. package/src/extensions/HorizontalRule/index.ts +0 -1
  170. package/src/extensions/Iframe/Iframe.ts +0 -140
  171. package/src/extensions/Iframe/components/IframeNodeView.tsx +0 -92
  172. package/src/extensions/Iframe/components/index.module.scss +0 -40
  173. package/src/extensions/Iframe/embed.ts +0 -487
  174. package/src/extensions/Iframe/index.ts +0 -1
  175. package/src/extensions/Image/Image.ts +0 -303
  176. package/src/extensions/Image/components/ActionImageButton.tsx +0 -186
  177. package/src/extensions/Image/components/ImageCropper.tsx +0 -198
  178. package/src/extensions/Image/components/ImageView.tsx +0 -271
  179. package/src/extensions/Image/index.ts +0 -1
  180. package/src/extensions/Image/store.ts +0 -15
  181. package/src/extensions/ImageGif/ImageGif.ts +0 -176
  182. package/src/extensions/ImageGif/components/ImageGifActionButton.tsx +0 -138
  183. package/src/extensions/ImageGif/components/ImageGifView.tsx +0 -260
  184. package/src/extensions/ImageGif/index.ts +0 -1
  185. package/src/extensions/ImportWord/ImportWord.ts +0 -52
  186. package/src/extensions/ImportWord/components/ImportWordButton.tsx +0 -151
  187. package/src/extensions/ImportWord/index.ts +0 -1
  188. package/src/extensions/Indent/Indent.ts +0 -110
  189. package/src/extensions/Indent/index.ts +0 -1
  190. package/src/extensions/Italic/Italic.ts +0 -29
  191. package/src/extensions/Italic/index.ts +0 -1
  192. package/src/extensions/Katex/Katex.ts +0 -109
  193. package/src/extensions/Katex/components/KatexActiveButton.tsx +0 -117
  194. package/src/extensions/Katex/components/KatexWrapper.tsx +0 -53
  195. package/src/extensions/Katex/index.ts +0 -1
  196. package/src/extensions/LineHeight/LineHeight.ts +0 -76
  197. package/src/extensions/LineHeight/components/LineHeightDropdown.tsx +0 -93
  198. package/src/extensions/LineHeight/index.ts +0 -1
  199. package/src/extensions/Link/Link.ts +0 -92
  200. package/src/extensions/Link/components/LinkEditBlock.tsx +0 -110
  201. package/src/extensions/Link/components/LinkEditPopover.tsx +0 -46
  202. package/src/extensions/Link/components/LinkViewBlock.tsx +0 -54
  203. package/src/extensions/Link/index.ts +0 -1
  204. package/src/extensions/ListItem/ListItem.ts +0 -1
  205. package/src/extensions/ListItem/index.ts +0 -1
  206. package/src/extensions/Mention/Mention.ts +0 -100
  207. package/src/extensions/Mention/components/NodeViewMentionList/NodeViewMentionList.tsx +0 -94
  208. package/src/extensions/Mention/components/NodeViewMentionList/index.module.scss +0 -38
  209. package/src/extensions/Mention/index.ts +0 -1
  210. package/src/extensions/Mermaid/Mermaid.ts +0 -177
  211. package/src/extensions/Mermaid/components/EditMermaidBlock.tsx +0 -155
  212. package/src/extensions/Mermaid/components/MermaidActiveButton.tsx +0 -151
  213. package/src/extensions/Mermaid/components/NodeViewMermaid/NodeViewMermaid.tsx +0 -260
  214. package/src/extensions/Mermaid/index.ts +0 -1
  215. package/src/extensions/MoreMark/MoreMark.ts +0 -102
  216. package/src/extensions/MoreMark/components/ActionMoreButton.tsx +0 -97
  217. package/src/extensions/MoreMark/index.ts +0 -1
  218. package/src/extensions/MultiColumn/Column.ts +0 -36
  219. package/src/extensions/MultiColumn/MultiColumn.ts +0 -111
  220. package/src/extensions/MultiColumn/components/ColumnActionButton.ts +0 -22
  221. package/src/extensions/MultiColumn/index.ts +0 -3
  222. package/src/extensions/OrderedList/OrderedList.ts +0 -28
  223. package/src/extensions/OrderedList/index.ts +0 -1
  224. package/src/extensions/SearchAndReplace/SearchAndReplace.ts +0 -395
  225. package/src/extensions/SearchAndReplace/components/SearchAndReplaceButton.tsx +0 -190
  226. package/src/extensions/SearchAndReplace/index.ts +0 -1
  227. package/src/extensions/Selection/Selection.ts +0 -32
  228. package/src/extensions/Selection/index.ts +0 -1
  229. package/src/extensions/SlashCommand/SlashCommand.ts +0 -255
  230. package/src/extensions/SlashCommand/components/CommandsList.tsx +0 -180
  231. package/src/extensions/SlashCommand/groups.ts +0 -183
  232. package/src/extensions/SlashCommand/index.ts +0 -1
  233. package/src/extensions/SlashCommand/types.ts +0 -24
  234. package/src/extensions/Strike/Strike.ts +0 -26
  235. package/src/extensions/Strike/index.ts +0 -1
  236. package/src/extensions/Subscript/Subscript.ts +0 -88
  237. package/src/extensions/Subscript/index.ts +0 -1
  238. package/src/extensions/Table/Cell.ts +0 -131
  239. package/src/extensions/Table/Header.ts +0 -93
  240. package/src/extensions/Table/Row.ts +0 -8
  241. package/src/extensions/Table/Table.ts +0 -60
  242. package/src/extensions/Table/cell-background.ts +0 -112
  243. package/src/extensions/Table/components/CreateTablePopover.tsx +0 -132
  244. package/src/extensions/Table/components/TableActionButton.tsx +0 -42
  245. package/src/extensions/Table/index.ts +0 -6
  246. package/src/extensions/Table/utils.ts +0 -352
  247. package/src/extensions/TableOfContent/TableOfContent.ts +0 -124
  248. package/src/extensions/TableOfContent/components/NodeViewTableOfContent.tsx +0 -116
  249. package/src/extensions/TableOfContent/components/TableOfContentActionButton.tsx +0 -27
  250. package/src/extensions/TableOfContent/components/index.module.scss +0 -40
  251. package/src/extensions/TableOfContent/index.ts +0 -1
  252. package/src/extensions/TaskList/TaskList.ts +0 -46
  253. package/src/extensions/TaskList/index.ts +0 -1
  254. package/src/extensions/TextAlign/TextAlign.ts +0 -68
  255. package/src/extensions/TextAlign/components/TextAlignMenuButton.tsx +0 -103
  256. package/src/extensions/TextAlign/index.ts +0 -1
  257. package/src/extensions/TextBubble/TextBubble.ts +0 -22
  258. package/src/extensions/TextBubble/components/TextDropdown.tsx +0 -146
  259. package/src/extensions/TextBubble/index.ts +0 -1
  260. package/src/extensions/TextDirection/TextDirection.ts +0 -97
  261. package/src/extensions/TextDirection/components/TextDirectionButton.tsx +0 -103
  262. package/src/extensions/TextDirection/index.ts +0 -1
  263. package/src/extensions/TrailingNode/TrailingNode.ts +0 -71
  264. package/src/extensions/TrailingNode/index.ts +0 -1
  265. package/src/extensions/Twitter/Twitter.ts +0 -161
  266. package/src/extensions/Twitter/components/FormEditLinkTwitter.tsx +0 -68
  267. package/src/extensions/Twitter/components/NodeViewTweet.tsx +0 -30
  268. package/src/extensions/Twitter/components/TwitterActiveButton.tsx +0 -41
  269. package/src/extensions/Twitter/index.ts +0 -1
  270. package/src/extensions/UnderLine/Underline.ts +0 -30
  271. package/src/extensions/UnderLine/index.ts +0 -1
  272. package/src/extensions/Video/Video.ts +0 -204
  273. package/src/extensions/Video/components/ActiveVideoButton.tsx +0 -191
  274. package/src/extensions/Video/index.ts +0 -1
  275. package/src/extensions/Video/store.ts +0 -15
  276. package/src/extensions/index.ts +0 -122
  277. package/src/hooks/useActive.tsx +0 -24
  278. package/src/hooks/useAttributes.tsx +0 -45
  279. package/src/hooks/useCopy.tsx +0 -20
  280. package/src/hooks/useEditorState.tsx +0 -23
  281. package/src/hooks/useExtension.tsx +0 -29
  282. package/src/index.ts +0 -8
  283. package/src/lib/utils.ts +0 -7
  284. package/src/locale-bundle.ts +0 -3
  285. package/src/locales/en.ts +0 -173
  286. package/src/locales/hu.ts +0 -173
  287. package/src/locales/index.tsx +0 -163
  288. package/src/locales/pt-br.ts +0 -173
  289. package/src/locales/vi.ts +0 -173
  290. package/src/locales/zh-cn.ts +0 -173
  291. package/src/plugins/DragHandle/index.ts +0 -375
  292. package/src/plugins/DragHandle/range.ts +0 -114
  293. package/src/plugins/DragHandle/utils.ts +0 -80
  294. package/src/plugins/image-upload.ts +0 -160
  295. package/src/store/ProviderRichText.tsx +0 -53
  296. package/src/store/editableEditor.ts +0 -15
  297. package/src/store/fast-context.tsx +0 -70
  298. package/src/store/store.ts +0 -35
  299. package/src/styles/ProseMirror.scss +0 -176
  300. package/src/styles/columns.scss +0 -23
  301. package/src/styles/editor.scss +0 -411
  302. package/src/styles/global.scss +0 -87
  303. package/src/styles/index.scss +0 -5
  304. package/src/styles/mention.scss +0 -6
  305. package/src/theme/theme.ts +0 -15
  306. package/src/types.ts +0 -271
  307. package/src/utils/_event.ts +0 -55
  308. package/src/utils/color.ts +0 -67
  309. package/src/utils/columns.ts +0 -142
  310. package/src/utils/customEvents/customEvents.ts +0 -18
  311. package/src/utils/customEvents/events.constant.ts +0 -11
  312. package/src/utils/delete-node.ts +0 -46
  313. package/src/utils/dom-dataset.ts +0 -121
  314. package/src/utils/download.ts +0 -17
  315. package/src/utils/dynamicCSS.ts +0 -192
  316. package/src/utils/editor-container-size.ts +0 -28
  317. package/src/utils/file.ts +0 -112
  318. package/src/utils/getRenderContainer.ts +0 -41
  319. package/src/utils/indent.ts +0 -99
  320. package/src/utils/is-mobile.ts +0 -57
  321. package/src/utils/json.ts +0 -18
  322. package/src/utils/line-height.ts +0 -109
  323. package/src/utils/lru-cache.ts +0 -145
  324. package/src/utils/mitt.ts +0 -114
  325. package/src/utils/node.ts +0 -92
  326. package/src/utils/pdf.ts +0 -72
  327. package/src/utils/plateform.ts +0 -49
  328. package/src/utils/shortId.ts +0 -5
  329. package/src/utils/storage.ts +0 -18
  330. package/src/utils/utils.ts +0 -71
  331. package/src/vite-env.d.ts +0 -3
@@ -1,146 +0,0 @@
1
- import React, { useMemo } from 'react';
2
-
3
- import { ChevronDown } from 'lucide-react';
4
-
5
- import { Button, DropdownMenu, DropdownMenuCheckboxItem, DropdownMenuContent, DropdownMenuTrigger, icons } from 'reactjs-tiptap-editor-pro/components';
6
- import { useLocale } from 'reactjs-tiptap-editor-pro/locales';
7
-
8
- interface IPropsTextDropdown {
9
- editor: any
10
- disabled?: boolean
11
- color?: string
12
- maxHeight?: string | number
13
- icon?: any
14
- tooltip?: string
15
- }
16
-
17
- function TextDropdown(props: IPropsTextDropdown) {
18
- const { t } = useLocale();
19
-
20
- const menus = useMemo(() => {
21
- return [
22
- {
23
- name: 'paragraph',
24
- label: t('editor.paragraph.tooltip'),
25
- iconName: 'Heading1',
26
- isActive: () =>
27
- props.editor.isActive('paragraph')
28
- && !props.editor.isActive('orderedList')
29
- && !props.editor.isActive('bulletList')
30
- && !props.editor.isActive('taskList'),
31
- action: () => props.editor.chain().focus().clearNodes().run(),
32
- },
33
- {
34
- name: 'heading1',
35
- label: t('editor.heading.h1.tooltip'),
36
- isActive: () => props.editor.isActive('heading', { level: 1 }),
37
- iconName: 'Heading1',
38
- action: () => props.editor.chain().focus().clearNodes().toggleHeading({ level: 1 }).run(),
39
- },
40
- {
41
- name: 'heading2',
42
- label: t('editor.heading.h2.tooltip'),
43
- isActive: () => props.editor.isActive('heading', { level: 2 }),
44
- iconName: 'Heading2',
45
- action: () => props.editor.chain().focus().clearNodes().toggleHeading({ level: 2 }).run(),
46
- },
47
- {
48
- name: 'heading3',
49
- label: t('editor.heading.h3.tooltip'),
50
- isActive: () => props.editor.isActive('heading', { level: 3 }),
51
- iconName: 'Heading3',
52
- action: () => props.editor.chain().focus().clearNodes().toggleHeading({ level: 3 }).run(),
53
- },
54
- {
55
- name: 'bulletList',
56
- label: t('editor.bulletlist.tooltip'),
57
- isActive: () => props.editor.isActive('bulletList'),
58
- iconName: 'List',
59
- action: () => props.editor.chain().focus().clearNodes().toggleBulletList().run(),
60
- },
61
- {
62
- name: 'numberedList',
63
- label: t('editor.orderedlist.tooltip'),
64
- isActive: () => props.editor.isActive('orderedList'),
65
- iconName: 'ListOrdered',
66
- action: () => props.editor.chain().focus().clearNodes().toggleOrderedList().run(),
67
- },
68
- {
69
- name: 'taskList',
70
- label: t('editor.tasklist.tooltip'),
71
- isActive: () => props.editor.isActive('taskList'),
72
- iconName: 'ListTodo',
73
- action: () => props.editor.chain().focus().clearNodes().toggleTaskList().run(),
74
- },
75
- {
76
- name: 'blockquote',
77
- label: t('editor.blockquote.tooltip'),
78
- isActive: () => props.editor.isActive('blockquote'),
79
- iconName: 'TextQuote',
80
- action: () => props.editor.chain().focus().clearNodes().toggleBlockquote().run(),
81
- },
82
- {
83
- name: 'codeBlock',
84
- label: t('editor.codeblock.tooltip'),
85
- isActive: () => props.editor.isActive('codeBlock'),
86
- iconName: 'Code2',
87
- action: () => props.editor.chain().focus().clearNodes().toggleCodeBlock().run(),
88
- },
89
- ];
90
- }, [props.editor, t]);
91
-
92
- const activeItem = useMemo(() => {
93
- return (
94
- menus.findLast(item => item.isActive()) ?? {
95
- label: 'Empty',
96
- }
97
- );
98
- }, [menus]);
99
-
100
- return (
101
- <DropdownMenu>
102
- <DropdownMenuTrigger asChild>
103
- <Button className="flex h-[32px] gap-1 px-1.5"
104
- variant="ghost"
105
- >
106
- <span className="whitespace-nowrap text-sm font-normal">
107
- {' '}
108
- {activeItem?.label}
109
- </span>
110
-
111
- <ChevronDown className="size-4" />
112
- </Button>
113
- </DropdownMenuTrigger>
114
-
115
- <DropdownMenuContent align="start"
116
- className="w-full p-1"
117
- hideWhenDetached
118
- sideOffset={5}
119
- >
120
- {menus.map((item, index) => {
121
- const Icon = icons[item.iconName as any];
122
-
123
- return (
124
- <DropdownMenuCheckboxItem
125
- checked={item.isActive?.() || false}
126
- className="cursor-pointer"
127
- key={`text-bubble-${index}`}
128
- onClick={() => item.action()}
129
- >
130
- <div className="flex items-center gap-2 px-2">
131
- <Icon className="h3 w-3" />
132
-
133
- <span>
134
- {' '}
135
- {item.label}
136
- </span>
137
- </div>
138
- </DropdownMenuCheckboxItem>
139
- );
140
- })}
141
- </DropdownMenuContent>
142
- </DropdownMenu>
143
- );
144
- }
145
-
146
- export default TextDropdown;
@@ -1 +0,0 @@
1
- export * from './TextBubble';
@@ -1,97 +0,0 @@
1
- /* eslint-disable @typescript-eslint/ban-ts-comment */
2
- import { Extension } from '@tiptap/core';
3
-
4
- import TextDirectionButton from 'reactjs-tiptap-editor-pro/extensions/TextDirection/components/TextDirectionButton';
5
-
6
- const TextDirection = Extension.create({
7
- name: 'text-direction',
8
- addOptions() {
9
- return {
10
- ...this.parent?.(),
11
- types: ['heading', 'paragraph'],
12
- directions: ['auto', 'ltr', 'rtl'],
13
- defaultDirection: 'auto',
14
- button({
15
- editor,
16
- extension,
17
- t,
18
- }: {
19
- editor: any
20
- extension: Extension
21
- t: (...args: any[]) => string
22
- }) {
23
- const directions = (extension.options?.directions as any[]) || [];
24
-
25
- const iconMap = {
26
- auto: 'TextDirection',
27
- ltr: 'LeftToRight',
28
- rtl: 'RightToLeft',
29
- } as any;
30
-
31
- const items = directions.map(k => ({
32
- title: t(`editor.textDirection.${k}.tooltip`),
33
- icon: iconMap[k],
34
- isActive: () => false,
35
- action: () => {
36
- if (k === 'auto') {
37
- editor.commands?.unsetTextDirection?.();
38
- return;
39
- }
40
-
41
- editor.commands?.setTextDirection?.(k);
42
- },
43
- disabled: false,
44
- }));
45
- const disabled = items.filter(k => k.disabled).length === items.length;
46
-
47
- return {
48
- component: TextDirectionButton,
49
- componentProps: {
50
- icon: 'TextDirection',
51
- tooltip: t('editor.textDirection.tooltip'),
52
- disabled,
53
- items,
54
- },
55
- };
56
- },
57
- };
58
- },
59
- addGlobalAttributes() {
60
- return [
61
- {
62
- types: this.options.types,
63
- attributes: {
64
- dir: {
65
- default: this.options.defaultDirection,
66
- parseHTML: (element: any) => {
67
- if (element.attributes.dir && this.options.directions.includes(element.attributes.dir)) {
68
- return element.attributes.dir.value;
69
- } else {
70
- return this.options.defaultDirection;
71
- }
72
- },
73
- renderHTML: (attributes) => {
74
- return { dir: attributes.dir };
75
- },
76
- },
77
- },
78
- },
79
- ];
80
- },
81
- // @ts-expect-error
82
- addCommands() {
83
- return {
84
- setTextDirection: (direction: any) => ({ commands }: any) => {
85
- if (!this.options.directions.includes(direction)) {
86
- return false;
87
- }
88
- return this.options.types.every((type: any) => commands.updateAttributes(type, { dir: direction }));
89
- },
90
- unsetTextDirection: () => ({ commands }: any) => {
91
- return this.options.types.every((type: any) => commands.resetAttributes(type, 'dir'));
92
- },
93
- };
94
- },
95
- });
96
-
97
- export { TextDirection };
@@ -1,103 +0,0 @@
1
- import React, { useMemo } from 'react';
2
-
3
- import { ActionButton, IconComponent } from 'reactjs-tiptap-editor-pro/components';
4
- import { Popover, PopoverContent, PopoverTrigger, Toggle, Tooltip, TooltipContent, TooltipTrigger } from 'reactjs-tiptap-editor-pro/components/ui';
5
- import type { ButtonViewReturnComponentProps } from 'reactjs-tiptap-editor-pro/types';
6
- import { getShortcutKey } from 'reactjs-tiptap-editor-pro/utils/plateform';
7
-
8
- export interface Item {
9
- title: string
10
- icon?: any
11
- isActive: NonNullable<ButtonViewReturnComponentProps['isActive']>
12
- action?: ButtonViewReturnComponentProps['action']
13
- style?: React.CSSProperties
14
- shortcutKeys?: string[]
15
- disabled?: boolean
16
- divider?: boolean
17
- default?: boolean
18
- }
19
- interface IPropsTextDirectionButton {
20
- editor: any
21
- disabled?: boolean
22
- color?: string
23
- maxHeight?: string | number
24
- icon?: any
25
- tooltip?: string
26
- items?: Item[]
27
- }
28
-
29
- function TextDirectionButton(props: IPropsTextDirectionButton) {
30
- const active = useMemo(() => {
31
- const find: any = props?.items?.find((k: any) => k.isActive());
32
- if (find && !find.default) {
33
- return {
34
- ...find,
35
- icon: find.icon ? find.icon : props.icon,
36
- };
37
- }
38
- const item: Item = {
39
- title: props?.tooltip as any,
40
- icon: props.icon,
41
- isActive: () => false,
42
- };
43
-
44
- return item;
45
- }, [props]);
46
-
47
- return (
48
- <Popover modal>
49
- <PopoverTrigger asChild
50
- disabled={props?.disabled}
51
- >
52
- <ActionButton
53
- customClass="!w-12 h-12"
54
- disabled={props?.disabled}
55
- icon={props?.icon}
56
- tooltip={props?.tooltip}
57
- >
58
- <IconComponent className="ml-1 size-3 text-zinc-500"
59
- name="MenuDown"
60
- />
61
- </ActionButton>
62
- </PopoverTrigger>
63
-
64
- <PopoverContent
65
- align="start"
66
- className="flex w-full min-w-4 flex-row gap-1 !p-[4px]"
67
- side="bottom"
68
- >
69
- {props?.items?.map((item, index) => {
70
- return (
71
- <Tooltip key={`text-align-${index}`}>
72
- <TooltipTrigger asChild>
73
- <Toggle
74
- className="size-7 p-1"
75
- data-state={active.title === item.title ? 'on' : 'off'}
76
- onClick={item?.action}
77
- pressed={active.title === item.title}
78
- size="sm"
79
- >
80
- {item?.icon && <IconComponent name={item.icon} />}
81
- </Toggle>
82
- </TooltipTrigger>
83
-
84
- <TooltipContent className="flex flex-col items-center">
85
- <span>
86
- {item.title}
87
- </span>
88
-
89
- {!!item.shortcutKeys?.length && (
90
- <span>
91
- {item.shortcutKeys?.map(item => getShortcutKey(item)).join(' ')}
92
- </span>
93
- )}
94
- </TooltipContent>
95
- </Tooltip>
96
- );
97
- })}
98
- </PopoverContent>
99
- </Popover>
100
- );
101
- }
102
-
103
- export default TextDirectionButton;
@@ -1 +0,0 @@
1
- export * from './TextDirection';
@@ -1,71 +0,0 @@
1
- /* eslint-disable @typescript-eslint/ban-ts-comment */
2
- import { Extension } from '@tiptap/core';
3
- import { Plugin, PluginKey } from '@tiptap/pm/state';
4
-
5
- // @ts-ignore
6
- function nodeEqualsType({ types, node }) {
7
- return (Array.isArray(types) && types.includes(node.type)) || node.type === types;
8
- }
9
-
10
- /**
11
- * Extension based on:
12
- * - https://github.com/ueberdosis/tiptap/blob/v1/packages/tiptap-extensions/src/extensions/TrailingNode.js
13
- * - https://github.com/remirror/remirror/blob/e0f1bec4a1e8073ce8f5500d62193e52321155b9/packages/prosemirror-trailing-node/src/trailing-node-plugin.ts
14
- */
15
-
16
- export interface TrailingNodeOptions {
17
- node: string
18
- notAfter: string[]
19
- }
20
-
21
- export const TrailingNode = Extension.create<TrailingNodeOptions>({
22
- name: 'trailingNode',
23
-
24
- addOptions() {
25
- return {
26
- node: 'paragraph',
27
- notAfter: ['paragraph'],
28
- };
29
- },
30
-
31
- addProseMirrorPlugins() {
32
- const plugin = new PluginKey(this.name);
33
- const disabledNodes = Object.entries(this.editor.schema.nodes)
34
- .map(([, value]) => value)
35
- .filter(node => this.options.notAfter.includes(node.name));
36
-
37
- return [
38
- new Plugin({
39
- key: plugin,
40
- appendTransaction: (_, __, state) => {
41
- const { doc, tr, schema } = state;
42
- const shouldInsertNodeAtEnd = plugin.getState(state);
43
- const endPosition = doc.content.size;
44
- const type = schema.nodes[this.options.node];
45
-
46
- if (!shouldInsertNodeAtEnd) {
47
- return;
48
- }
49
-
50
- return tr.insert(endPosition, type.create());
51
- },
52
- state: {
53
- init: (_, state) => {
54
- const lastNode = state.tr.doc.lastChild;
55
-
56
- return !nodeEqualsType({ node: lastNode, types: disabledNodes });
57
- },
58
- apply: (tr, value) => {
59
- if (!tr.docChanged) {
60
- return value;
61
- }
62
-
63
- const lastNode = tr.doc.lastChild;
64
-
65
- return !nodeEqualsType({ node: lastNode, types: disabledNodes });
66
- },
67
- },
68
- }),
69
- ];
70
- },
71
- });
@@ -1 +0,0 @@
1
- export * from './TrailingNode';
@@ -1,161 +0,0 @@
1
- import { Node, mergeAttributes, nodePasteRule } from '@tiptap/core';
2
- import { ReactNodeViewRenderer } from '@tiptap/react';
3
- import NodeViewTweet from 'reactjs-tiptap-editor-pro/extensions/Twitter/components/NodeViewTweet';
4
- import TwitterActiveButton from 'reactjs-tiptap-editor-pro/extensions/Twitter/components/TwitterActiveButton';
5
-
6
- const TWITTER_REGEX_GLOBAL = /(https?:\/\/)?(www\.)?x\.com\/(\w{1,15})(\/status\/(\d+))?(\/\S*)?/g;
7
- const TWITTER_REGEX = /^https?:\/\/(www\.)?x\.com\/(\w{1,15})(\/status\/(\d+))?(\/\S*)?$/;
8
-
9
- function isValidTwitterUrl(url: string) {
10
- return url.match(TWITTER_REGEX);
11
- }
12
-
13
- interface TwitterOptions {
14
- /**
15
- * Controls if the paste handler for tweets should be added.
16
- * @default true
17
- * @example false
18
- */
19
- addPasteHandler: boolean
20
-
21
- // biome-ignore lint/suspicious/noExplicitAny: <explanation>
22
- HTMLAttributes: Record<string, any>
23
-
24
- /**
25
- * Controls if the twitter node should be inline or not.
26
- * @default false
27
- * @example true
28
- */
29
- inline: boolean
30
-
31
- /**
32
- * The origin of the tweet.
33
- * @default ''
34
- * @example 'https://tiptap.dev'
35
- */
36
- origin: string
37
- }
38
-
39
- /**
40
- * The options for setting a tweet.
41
- */
42
- interface SetTweetOptions {
43
- src: string
44
- }
45
-
46
- declare module '@tiptap/core' {
47
- interface Commands<ReturnType> {
48
- twitter: {
49
- /**
50
- * Insert a tweet
51
- * @param options The tweet attributes
52
- * @example editor.commands.setTweet({ src: 'https://x.com/seanpk/status/1800145949580517852' })
53
- */
54
- setTweet: (options: SetTweetOptions) => ReturnType
55
- updateTweet: (options: SetTweetOptions) => ReturnType
56
- }
57
- }
58
- }
59
-
60
- /**
61
- * This extension adds support for tweets.
62
- */
63
- export const Twitter = Node.create<TwitterOptions>({
64
- name: 'twitter',
65
- draggable: true,
66
- selectable: true,
67
-
68
- addOptions() {
69
- return {
70
- addPasteHandler: true,
71
- HTMLAttributes: {},
72
- inline: false,
73
- origin: '',
74
- button: ({ editor, t }: any) => ({
75
- component: TwitterActiveButton,
76
- componentProps: {
77
- action: (src: string) => {
78
- editor.commands.setTweet({ src });
79
- },
80
- isActive: () => false,
81
- disabled: false,
82
- icon: 'Twitter',
83
- tooltip: t('editor.twitter.tooltip'),
84
- editor,
85
- },
86
- }),
87
- };
88
- },
89
-
90
- addNodeView() {
91
- return ReactNodeViewRenderer(NodeViewTweet, { attrs: this.options.HTMLAttributes });
92
- },
93
-
94
- inline() {
95
- return this.options.inline;
96
- },
97
-
98
- group() {
99
- return this.options.inline ? 'inline' : 'block';
100
- },
101
-
102
- addAttributes() {
103
- return {
104
- src: {
105
- default: null,
106
- },
107
- };
108
- },
109
-
110
- parseHTML() {
111
- return [
112
- {
113
- tag: 'div[data-twitter]',
114
- },
115
- ];
116
- },
117
-
118
- addCommands() {
119
- return {
120
- setTweet:
121
- (options: SetTweetOptions) =>
122
- ({ commands }) => {
123
- if (!isValidTwitterUrl(options.src)) {
124
- return false;
125
- }
126
-
127
- return commands.insertContent({
128
- type: this.name,
129
- attrs: options,
130
- });
131
- },
132
- updateTweet: (options: SetTweetOptions) => ({ commands }: any) => {
133
- if (!isValidTwitterUrl(options.src)) {
134
- return false;
135
- }
136
-
137
- return commands.updateAttributes(this.name, { src: options.src });
138
- },
139
- };
140
- },
141
-
142
- addPasteRules() {
143
- if (!this.options.addPasteHandler) {
144
- return [];
145
- }
146
-
147
- return [
148
- nodePasteRule({
149
- find: TWITTER_REGEX_GLOBAL,
150
- type: this.type,
151
- getAttributes: (match) => {
152
- return { src: match.input };
153
- },
154
- }),
155
- ];
156
- },
157
-
158
- renderHTML({ HTMLAttributes }) {
159
- return ['div', mergeAttributes({ 'data-twitter': '' }, HTMLAttributes)];
160
- },
161
- });
@@ -1,68 +0,0 @@
1
- /* eslint-disable no-unsafe-optional-chaining */
2
- /* eslint-disable @typescript-eslint/no-unsafe-call */
3
- /* eslint-disable @typescript-eslint/no-unsafe-member-access */
4
- import { useEffect, useState } from 'react';
5
-
6
- import { Button, Input, Label } from 'reactjs-tiptap-editor-pro/components';
7
- import { Twitter } from 'reactjs-tiptap-editor-pro/extensions/Twitter/Twitter';
8
- import { useLocale } from 'reactjs-tiptap-editor-pro/locales';
9
-
10
- interface IPropsFormEditLinkTwitter {
11
- editor: any
12
- onSetLink: (src: string) => void
13
- }
14
-
15
- function FormEditLinkTwitter(props: IPropsFormEditLinkTwitter) {
16
- const { t } = useLocale();
17
-
18
- const [src, setSrc] = useState('');
19
-
20
- useEffect(() => {
21
- if (props?.editor) {
22
- const { src: srcInit } = props.editor?.getAttributes(Twitter.name);
23
-
24
- if (srcInit) {
25
- setSrc(srcInit);
26
- }
27
- }
28
- }, [props?.editor]);
29
-
30
- function handleSubmit(event: any) {
31
- event.preventDefault();
32
- event.stopPropagation();
33
- props?.onSetLink(src);
34
- }
35
-
36
- return (
37
- <div className="border-neutral-200 rounded-lg !border bg-white p-2 shadow-sm dark:border-neutral-800 dark:bg-black">
38
- <form className="flex flex-col gap-2"
39
- onSubmit={handleSubmit}
40
- >
41
- <Label className="mb-[6px]">
42
- {t('editor.link.dialog.text')}
43
- </Label>
44
-
45
- <div className="mb-[10px] flex w-full max-w-sm items-center gap-1.5">
46
- <div className="relative w-full max-w-sm items-center">
47
- <Input
48
- className="w-80"
49
- onChange={e => setSrc(e.target.value)}
50
- placeholder="Text"
51
- required
52
- type="text"
53
- value={src}
54
- />
55
- </div>
56
- </div>
57
-
58
- <Button className="mt-2 self-end"
59
- type="submit"
60
- >
61
- {t('editor.link.dialog.button.apply')}
62
- </Button>
63
- </form>
64
- </div>
65
- );
66
- }
67
-
68
- export default FormEditLinkTwitter;
@@ -1,30 +0,0 @@
1
- /* eslint-disable @typescript-eslint/ban-ts-comment */
2
- import { NodeViewWrapper, type ReactNodeViewRendererOptions } from '@tiptap/react';
3
- import { Tweet } from 'react-tweet';
4
-
5
- export const TWITTER_REGEX_GLOBAL = /(https?:\/\/)?(www\.)?x\.com\/(\w{1,15})(\/status\/(\d+))?(\/\S*)?/g;
6
- export const TWITTER_REGEX = /^https?:\/\/(www\.)?x\.com\/(\w{1,15})(\/status\/(\d+))?(\/\S*)?$/;
7
-
8
- export function isValidTwitterUrl(url: string) {
9
- return url.match(TWITTER_REGEX);
10
- }
11
-
12
- function NodeViewTweet({ node }: { node: Partial<ReactNodeViewRendererOptions> }) {
13
- // @ts-expect-error
14
- const url = node?.attrs?.src || '';
15
- const tweetId = url?.split('/').pop();
16
-
17
- if (!tweetId) {
18
- return null;
19
- }
20
-
21
- return (
22
- <NodeViewWrapper>
23
- <div data-twitter="">
24
- <Tweet id={tweetId} />
25
- </div>
26
- </NodeViewWrapper>
27
- );
28
- }
29
-
30
- export default NodeViewTweet;