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,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 '@/components';
6
- import { useLocale } from '@/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 '@/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 '@/components';
4
- import { Popover, PopoverContent, PopoverTrigger, Toggle, Tooltip, TooltipContent, TooltipTrigger } from '@/components/ui';
5
- import type { ButtonViewReturnComponentProps } from '@/types';
6
- import { getShortcutKey } from '@/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 '@/extensions/Twitter/components/NodeViewTweet';
4
- import TwitterActiveButton from '@/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 '@/components';
7
- import { Twitter } from '@/extensions/Twitter/Twitter';
8
- import { useLocale } from '@/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;