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,41 +0,0 @@
1
- import { ActionButton, IconComponent, Popover, PopoverContent, PopoverTrigger } from '@/components';
2
- import FormEditLinkTwitter from '@/extensions/Twitter/components/FormEditLinkTwitter';
3
- import type { ButtonViewReturnComponentProps } from '@/types';
4
-
5
- interface IPropsTwitterActiveButton {
6
- editor: any
7
- icon?: any
8
- title?: string
9
- tooltip?: string
10
- disabled?: boolean
11
- shortcutKeys?: string[]
12
- isActive?: ButtonViewReturnComponentProps['isActive']
13
- action?: ButtonViewReturnComponentProps['action']
14
- }
15
-
16
- function TwitterActiveButton(props: IPropsTwitterActiveButton) {
17
- function onSetLink(src: string) {
18
- if (props.action) {
19
- props.action(src);
20
- }
21
- }
22
-
23
- return (
24
- <Popover modal>
25
- <PopoverTrigger disabled={props?.disabled} asChild>
26
- <ActionButton
27
- tooltip={props?.tooltip}
28
- isActive={props?.isActive}
29
- disabled={props?.disabled}
30
- >
31
- <IconComponent name={props?.icon} />
32
- </ActionButton>
33
- </PopoverTrigger>
34
- <PopoverContent hideWhenDetached className="w-full" align="start" side="bottom">
35
- <FormEditLinkTwitter editor={props.editor} onSetLink={onSetLink} />
36
- </PopoverContent>
37
- </Popover>
38
- );
39
- }
40
-
41
- export default TwitterActiveButton;
@@ -1 +0,0 @@
1
- export * from './Twitter';
@@ -1,30 +0,0 @@
1
- import type { UnderlineOptions as TiptapUnderlineOptions } from '@tiptap/extension-underline';
2
- import TiptapUnderline from '@tiptap/extension-underline';
3
-
4
- import { ActionButton } from '@/components';
5
- import type { GeneralOptions } from '@/types';
6
-
7
- export interface UnderlineOptions
8
- extends TiptapUnderlineOptions,
9
- GeneralOptions<UnderlineOptions> {}
10
-
11
- export const Underline = TiptapUnderline.extend<UnderlineOptions>({
12
- addOptions() {
13
- return {
14
- ...this.parent?.(),
15
- button({ editor, t }: any) {
16
- return {
17
- component: ActionButton,
18
- componentProps: {
19
- action: () => editor.commands.toggleUnderline(),
20
- isActive: () => editor.isActive('underline') || false,
21
- disabled: !editor.can().toggleUnderline(),
22
- icon: 'Underline',
23
- shortcutKeys: ['mod', 'U'],
24
- tooltip: t('editor.underline.tooltip'),
25
- },
26
- };
27
- },
28
- };
29
- },
30
- });
@@ -1 +0,0 @@
1
- export * from './Underline';
@@ -1,204 +0,0 @@
1
- import { Node } from '@tiptap/core';
2
-
3
- import { VIDEO_SIZE } from '@/constants';
4
- import ActionVideoButton from '@/extensions/Video/components/ActiveVideoButton';
5
- import type { GeneralOptions } from '@/types';
6
- import { getCssUnitWithDefault } from '@/utils/utils';
7
-
8
- /**
9
- * Represents the interface for video options, extending GeneralOptions.
10
- */
11
- export interface VideoOptions extends GeneralOptions<VideoOptions> {
12
- /**
13
- * Indicates whether fullscreen play is allowed
14
- *
15
- * @default true
16
- */
17
- allowFullscreen: boolean
18
- /**
19
- * Indicates whether to display the frameborder
20
- *
21
- * @default false
22
- */
23
- frameborder: boolean
24
- /**
25
- * Width of the video, can be a number or string
26
- *
27
- * @default VIDEO_SIZE['size-medium']
28
- */
29
- width: number | string
30
- /** HTML attributes object for passing additional attributes */
31
- HTMLAttributes: {
32
- [key: string]: any
33
- }
34
- /** Function for uploading files */
35
- upload?: (file: File) => Promise<string>
36
-
37
- /** The source URL of the video */
38
- resourceVideo: 'upload' | 'link' | 'both'
39
- }
40
-
41
- /**
42
- * Represents the type for setting video options
43
- */
44
- interface SetVideoOptions {
45
- /** The source URL of the video */
46
- src: string
47
- /** The width of the video */
48
- width: string | number
49
- }
50
-
51
- declare module '@tiptap/core' {
52
- interface Commands<ReturnType> {
53
- video: {
54
- /**
55
- * Add an video
56
- */
57
- setVideo: (options: Partial<SetVideoOptions>) => ReturnType
58
- /**
59
- * Update an video
60
- */
61
- updateVideo: (options: Partial<SetVideoOptions>) => ReturnType
62
- }
63
- }
64
- }
65
-
66
- function linkConvert(src: string) {
67
- // Convert youtube links
68
- src = src
69
- .replace('https://youtu.be/', 'https://www.youtube.com/watch?v=')
70
- .replace('watch?v=', 'embed/');
71
-
72
- // Convert vimeo links
73
- src = src.replace('https://vimeo.com/', 'https://player.vimeo.com/video/');
74
-
75
- // Convert bilibili links
76
- const isBilibiliLink = /^https?:\/\/www.bilibili.com\/video\/.*/i.test(src);
77
- if (isBilibiliLink) {
78
- src = src
79
- .replace(/\?.*$/, '')
80
- .replace('https://www.bilibili.com/video/', 'https://player.bilibili.com/player.html?bvid=');
81
- }
82
-
83
- // Convert google drive links
84
- if (src.includes('drive.google.com')) {
85
- src = src.replace('/view', '/preview');
86
- }
87
-
88
- return src;
89
- }
90
-
91
- export const Video = Node.create<VideoOptions>({
92
- name: 'video',
93
- group: 'block',
94
- atom: true,
95
- draggable: true,
96
-
97
- addOptions() {
98
- return {
99
- divider: false,
100
- spacer: false,
101
- allowFullscreen: true,
102
- upload: undefined,
103
- frameborder: false,
104
- resourceVideo: 'both',
105
- width: VIDEO_SIZE['size-medium'],
106
- HTMLAttributes: {
107
- class: 'iframe-wrapper',
108
- style: 'display: flex;justify-content: center;',
109
- },
110
- button: ({ editor, t }: any) => {
111
- return {
112
- component: ActionVideoButton,
113
- componentProps: {
114
- action: () => {
115
- return;
116
- },
117
- isActive: () => editor.isActive('video') || false,
118
- /* If setVideo is not available(when Video Component is not imported), the button is disabled */
119
- disabled: !editor.can().setVideo?.({}),
120
- icon: 'Video',
121
- tooltip: t('editor.video.tooltip'),
122
- editor,
123
- },
124
- };
125
- },
126
- };
127
- },
128
-
129
- addAttributes() {
130
- return {
131
- src: {
132
- default: null,
133
- renderHTML: ({ src }) => ({
134
- src: src ? linkConvert(src) : null,
135
- }),
136
- },
137
- width: {
138
- default: this.options.width,
139
- renderHTML: ({ width }) => ({
140
- width: getCssUnitWithDefault(width),
141
- }),
142
- },
143
- frameborder: {
144
- default: this.options.frameborder ? 1 : 0,
145
- parseHTML: () => (this.options.frameborder ? 1 : 0),
146
- },
147
- allowfullscreen: {
148
- default: this.options.allowFullscreen,
149
- parseHTML: () => this.options.allowFullscreen,
150
- },
151
- };
152
- },
153
-
154
- parseHTML() {
155
- return [
156
- {
157
- tag: 'div[data-video] iframe',
158
- },
159
- ];
160
- },
161
-
162
- renderHTML({ HTMLAttributes }) {
163
- const { width = '100%' } = HTMLAttributes ?? {};
164
-
165
- const iframeHTMLAttributes = {
166
- ...HTMLAttributes,
167
- width: '100%',
168
- height: '100%',
169
- };
170
-
171
- const responsiveStyle = `position: relative;overflow: hidden;display: flex;flex: 1;max-width: ${width};`;
172
- const responsiveSizesStyle = `flex: 1;padding-bottom: ${(9 / 16) * 100}%;`;
173
-
174
- const iframeDOM = ['iframe', iframeHTMLAttributes];
175
- const sizesDOM = ['div', { style: responsiveSizesStyle }];
176
- const responsiveDOM = ['div', { style: responsiveStyle }, sizesDOM, iframeDOM];
177
-
178
- const divAttrs = {
179
- ...this.options.HTMLAttributes,
180
- 'data-video': '',
181
- };
182
-
183
- return ['div', divAttrs, responsiveDOM];
184
- },
185
-
186
- addCommands() {
187
- return {
188
- setVideo:
189
- options =>
190
- ({ commands }) => {
191
- return commands.insertContent({
192
- type: this.name,
193
- attrs: options,
194
- });
195
- },
196
- updateVideo:
197
- options =>
198
- ({ commands }) => {
199
- return commands.updateAttributes(this.name, options);
200
- },
201
- };
202
- },
203
-
204
- });
@@ -1,191 +0,0 @@
1
- import { useEffect, useMemo, useRef, useState } from 'react';
2
-
3
- import { ActionButton, Button, Input, Tabs, TabsContent, TabsList, TabsTrigger } from '@/components';
4
- import { Dialog, DialogContent, DialogTitle, DialogTrigger } from '@/components/ui/dialog';
5
- import { Video } from '@/extensions/Video/Video';
6
- import { useLocale } from '@/locales';
7
- import { listenEvent } from '@/utils/customEvents/customEvents';
8
- import { EVENTS } from '@/utils/customEvents/events.constant';
9
-
10
- function checkIsVideo(url: string) {
11
- return /\.(?:mp4|webm|ogg|mov)$/i.test(url);
12
- }
13
-
14
- function ActionVideoButton(props: any) {
15
- const { t } = useLocale();
16
-
17
- const [link, setLink] = useState<string>('');
18
- const fileInput = useRef<HTMLInputElement>(null);
19
-
20
- const [error, setError] = useState<string>('');
21
-
22
- const [open, setOpen] = useState(false);
23
-
24
- const handleUploadVideo = (evt: any) => {
25
- setOpen(evt.detail);
26
- };
27
-
28
- useEffect(() => {
29
- const rm1 = listenEvent(EVENTS.UPLOAD_VIDEO(props.editor.id), handleUploadVideo);
30
-
31
- return () => {
32
- rm1();
33
- };
34
- }, []);
35
-
36
- const uploadOptions = useMemo(() => {
37
- const uploadOptions = props.editor.extensionManager.extensions.find(
38
- (extension: any) => extension.name === Video.name,
39
- )?.options;
40
-
41
- return uploadOptions;
42
- }, [props.editor]);
43
-
44
- async function handleFile(event: any) {
45
- const files = event?.target?.files;
46
- if (!props.editor || props.editor.isDestroyed || files.length === 0) {
47
- return;
48
- }
49
- const file = files[0];
50
-
51
- let src = '';
52
- if (uploadOptions.upload) {
53
- src = await uploadOptions.upload(file);
54
- } else {
55
- src = URL.createObjectURL(file);
56
- }
57
-
58
- props.editor
59
- .chain()
60
- .focus()
61
- .setVideo({
62
- src,
63
- width: '100%',
64
- })
65
- .run();
66
- setOpen(false);
67
- }
68
- function handleLink(e: any) {
69
- e.preventDefault();
70
- e.stopPropagation();
71
-
72
- if (!link) {
73
- return;
74
- }
75
-
76
- props.editor
77
- .chain()
78
- .focus()
79
- .setVideo({
80
- src: link,
81
- width: '100%',
82
- })
83
- .run();
84
- setOpen(false);
85
- }
86
-
87
- function handleClick(e: any) {
88
- e.preventDefault();
89
- fileInput.current?.click();
90
- }
91
-
92
- return (
93
- <Dialog onOpenChange={setOpen}
94
- open={open}
95
- >
96
- <DialogTrigger asChild>
97
- <ActionButton
98
- action={() => setOpen(true)}
99
- icon={props.icon}
100
- tooltip={props.tooltip}
101
- />
102
- </DialogTrigger>
103
-
104
- <DialogContent>
105
- <DialogTitle>
106
- {t('editor.video.dialog.title')}
107
- </DialogTitle>
108
-
109
- <Tabs
110
- activationMode="manual"
111
- defaultValue={
112
- (uploadOptions?.resourceVideo === 'both' || uploadOptions?.resourceVideo === 'upload') ? 'upload' : 'link'
113
- }
114
- >
115
- <TabsList className="grid w-full grid-cols-2">
116
- {(uploadOptions?.resourceVideo === 'both' || uploadOptions?.resourceVideo === 'upload') && (
117
- <TabsTrigger value="upload">
118
- {t('editor.video.dialog.tab.upload')}
119
- </TabsTrigger>
120
- )}
121
-
122
- {(uploadOptions?.resourceVideo === 'both' || uploadOptions?.resourceVideo === 'link') && (
123
- <TabsTrigger value="link">
124
- {t('editor.video.dialog.link')}
125
- </TabsTrigger>
126
- )}
127
- </TabsList>
128
-
129
- <TabsContent value="upload">
130
- <div className="flex items-center gap-[10px]">
131
- <Button className="mt-1 w-full"
132
- onClick={handleClick}
133
- size="sm"
134
- >
135
- {t('editor.video.dialog.tab.upload')}
136
- </Button>
137
- </div>
138
-
139
- <input
140
- accept="video/*"
141
- multiple
142
- onChange={handleFile}
143
- ref={fileInput}
144
- type="file"
145
- style={{
146
- display: 'none',
147
- }}
148
- />
149
- </TabsContent>
150
-
151
- <TabsContent value="link">
152
- <form onSubmit={handleLink}>
153
- <div className="flex items-center gap-2">
154
- <Input
155
- autoFocus
156
- placeholder={t('editor.video.dialog.placeholder')}
157
- required
158
- type="url"
159
- value={link}
160
- onChange={(e) => {
161
- const url = e.target.value;
162
-
163
- const isVideoUrl = checkIsVideo(url);
164
-
165
- if (!isVideoUrl) {
166
- setError('Invalid video URL');
167
- setLink('');
168
- return;
169
- }
170
- setError('');
171
- setLink(url);
172
- }}
173
- />
174
-
175
- <Button type="submit">
176
- {t('editor.video.dialog.button.apply')}
177
- </Button>
178
- </div>
179
- </form>
180
-
181
- {error && <div className="my-[5px] text-red-500">
182
- {error}
183
- </div>}
184
- </TabsContent>
185
- </Tabs>
186
- </DialogContent>
187
- </Dialog>
188
- );
189
- }
190
-
191
- export default ActionVideoButton;
@@ -1 +0,0 @@
1
- export * from './Video';
@@ -1,15 +0,0 @@
1
- import { useStoreUploadVideo } from '@/store/store';
2
- import { dispatchEvent } from '@/utils/customEvents/customEvents';
3
- import { EVENTS } from '@/utils/customEvents/events.constant';
4
-
5
- export function useDialogVideo() {
6
- const [v] = useStoreUploadVideo(store => store.value);
7
-
8
- return v;
9
- }
10
-
11
- export const actionDialogVideo = {
12
- setOpen: (id: any, value: boolean) => {
13
- dispatchEvent(EVENTS.UPLOAD_VIDEO(id), value);
14
- },
15
- };
@@ -1,122 +0,0 @@
1
- export { Bold } from './Bold';
2
- export type { BoldOptions } from './Bold';
3
-
4
- export { Italic } from './Italic';
5
- export type { ItalicOptions } from './Italic';
6
-
7
- export { Underline } from './UnderLine';
8
- export type { UnderlineOptions } from './UnderLine';
9
-
10
- export { Strike } from './Strike';
11
- export type { StrikeOptions } from './Strike';
12
-
13
- export { Code } from './Code';
14
- export type { CodeOptions } from './Code';
15
-
16
- export { CodeBlock } from './CodeBlock';
17
- export type { CodeBlockOptions } from './CodeBlock';
18
-
19
- export { FontFamily } from './FontFamily';
20
-
21
- export { Heading } from './Heading';
22
- export type { HeadingOptions } from './Heading';
23
-
24
- export { TextAlign } from './TextAlign';
25
- export type { TextAlignOptions } from './TextAlign';
26
-
27
- export { FontSize } from './FontSize';
28
- export type { FontSizeOptions } from './FontSize';
29
-
30
- export { Color } from './Color';
31
- export type { ColorOptions } from './Color';
32
-
33
- export { Highlight } from './Highlight';
34
- export type { HighlightOptions } from './Highlight';
35
-
36
- export { BulletList } from './BulletList';
37
- export type { BulletListOptions } from './BulletList';
38
-
39
- export { Clear } from './Clear';
40
- export type { ClearOptions } from './Clear';
41
-
42
- export { OrderedList } from './OrderedList';
43
- export type { OrderedListOptions } from './OrderedList';
44
-
45
- export { TaskList } from './TaskList';
46
- export type { TaskListOptions } from './TaskList';
47
-
48
- export { Blockquote } from './Blockquote';
49
- export type { BlockquoteOptions } from './Blockquote';
50
-
51
- export { Link } from './Link';
52
- export type { LinkOptions } from './Link';
53
-
54
- export { HorizontalRule } from './HorizontalRule';
55
- export type { HorizontalRuleOptions } from './HorizontalRule';
56
-
57
- export { History } from './History';
58
- export type { HistoryOptions } from './History';
59
-
60
- export { BaseKit } from './BaseKit';
61
- export type { BaseKitOptions } from './BaseKit';
62
-
63
- export { SubAndSuperScript } from './Subscript';
64
-
65
- export type { SubAndSuperScriptOptions } from './Subscript';
66
- export type { MoreMarkOptions } from './MoreMark';
67
- export { MoreMark } from './MoreMark';
68
-
69
- export { Indent } from './Indent';
70
- export type { IndentOptions } from './Indent';
71
-
72
- export { LineHeight } from './LineHeight';
73
- export type { LineHeightOptions } from './LineHeight';
74
-
75
- export { SlashCommand } from './SlashCommand';
76
-
77
- export { Image } from './Image';
78
- export type { SetImageAttrsOptions } from './Image';
79
-
80
- export { Video } from './Video/Video';
81
- export type { VideoOptions } from './Video';
82
-
83
- export { Table } from './Table';
84
-
85
- export type { TableOptions } from './Table';
86
-
87
- export { FormatPainter } from './FormatPainter';
88
- export type { FormatPainterOptions } from './FormatPainter';
89
-
90
- export { Column, MultiColumn, ColumnActionButton } from './MultiColumn';
91
-
92
- export { Iframe } from './Iframe';
93
-
94
- export { SearchAndReplace } from './SearchAndReplace';
95
-
96
- export { Emoji } from './Emoji';
97
-
98
- export { Katex } from './Katex';
99
-
100
- export { ExportPdf } from './ExportPdf';
101
-
102
- export { ImportWord } from './ImportWord';
103
-
104
- export { ExportWord } from './ExportWord';
105
-
106
- export { TableOfContents } from './TableOfContent';
107
-
108
- export { Excalidraw } from './Excalidraw';
109
-
110
- export { TextDirection } from './TextDirection';
111
-
112
- export { Mention } from './Mention';
113
-
114
- export { Attachment } from './Attachment';
115
-
116
- export { ImageGif } from './ImageGif';
117
-
118
- export { Mermaid } from './Mermaid';
119
-
120
- export { Twitter } from './Twitter';
121
-
122
- export { Drawer } from './Drawer';
@@ -1,24 +0,0 @@
1
- /* eslint-disable prefer-spread */
2
- import { useEffect, useState } from 'react';
3
-
4
- import type { Editor } from '@tiptap/core';
5
-
6
- export function useActive(editor: Editor, ...args: any[]) {
7
- const [active, toggleActive] = useState(false);
8
-
9
- useEffect(() => {
10
- const listener = () => {
11
- toggleActive(editor.isActive.apply(editor, args as any));
12
- };
13
-
14
- editor.on('selectionUpdate', listener);
15
- editor.on('transaction', listener);
16
-
17
- return () => {
18
- editor.off('selectionUpdate', listener);
19
- editor.off('transaction', listener);
20
- };
21
- }, [editor, args, toggleActive]);
22
-
23
- return active;
24
- }
@@ -1,45 +0,0 @@
1
- /* eslint-disable @typescript-eslint/ban-ts-comment */
2
- import { useEffect, useRef, useState } from 'react';
3
-
4
- import type { Editor } from '@tiptap/core';
5
- import deepEqual from 'deep-equal';
6
-
7
- type MapFn<T, R> = (arg: T) => R;
8
-
9
- function mapSelf<T>(d: T): T {
10
- return d;
11
- }
12
-
13
- export function useAttributes<T, R = T>(editor: Editor, attrbute: string, defaultValue?: T, map?: (arg: T) => R) {
14
- const mapFn = (map || mapSelf) as MapFn<T, R>;
15
- const [value, setValue] = useState<R>(mapFn(defaultValue as any));
16
- const prevValueCache = useRef<R>(value);
17
-
18
- useEffect(() => {
19
- const listener = () => {
20
- const attrs = { ...defaultValue, ...editor.getAttributes(attrbute) } as any;
21
- Object.keys(attrs).forEach((key) => {
22
- if (attrs[key] === null || attrs[key] === undefined) {
23
- // @ts-ignore
24
- attrs[key] = defaultValue ? defaultValue[key] : null;
25
- }
26
- });
27
- const nextAttrs = mapFn(attrs);
28
- if (deepEqual(prevValueCache.current, nextAttrs)) {
29
- return;
30
- }
31
- setValue(nextAttrs);
32
- prevValueCache.current = nextAttrs;
33
- };
34
-
35
- editor.on('selectionUpdate', listener);
36
- editor.on('transaction', listener);
37
-
38
- return () => {
39
- editor.off('selectionUpdate', listener);
40
- editor.off('transaction', listener);
41
- };
42
- }, [editor, defaultValue, attrbute, mapFn]);
43
-
44
- return value;
45
- }