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,104 +0,0 @@
1
- import { useCallback, useState } from 'react';
2
-
3
- import type { Editor } from '@tiptap/react';
4
- import { debounce } from 'lodash-es';
5
-
6
- import { ActionButton, Button, ColorPicker } from '@/components';
7
- import { IconComponent } from '@/components/icons';
8
- import type { ButtonViewReturnComponentProps } from '@/types';
9
-
10
- interface ColorActionButtonProps {
11
- editor: Editor
12
- colors?: string[]
13
- defaultColor?: string
14
- icon?: React.ReactNode
15
- tooltip?: string
16
- disabled?: boolean
17
- action?: ButtonViewReturnComponentProps['action']
18
- isActive?: ButtonViewReturnComponentProps['isActive']
19
- }
20
-
21
- interface IconCProps {
22
- fill?: string
23
- }
24
-
25
- function IconC({ fill }: IconCProps) {
26
- return (
27
- <svg
28
- width="18px"
29
- height="18px"
30
- viewBox="0 0 240 240"
31
- version="1.1"
32
- xmlns="http://www.w3.org/2000/svg"
33
- >
34
- <g stroke="none" strokeWidth={1} fill="none" fillRule="evenodd">
35
- <g transform="translate(0.000000, 0.500000)">
36
- <g transform="translate(39.000000, 17.353553)">
37
- <path
38
- d="M11,201.146447 L167,201.146447 C173.075132,201.146447 178,206.071314 178,212.146447 C178,218.221579 173.075132,223.146447 167,223.146447 L11,223.146447 C4.92486775,223.146447 7.43989126e-16,218.221579 0,212.146447 C-7.43989126e-16,206.071314 4.92486775,201.146447 11,201.146447 Z"
39
- id="矩形"
40
- fill={fill || '#DF2A3F'}
41
- fillRule="evenodd"
42
- />
43
- <path
44
- d="M72.3425855,16.8295583 C75.799482,7.50883712 86.1577877,2.75526801 95.4785089,6.21216449 C100.284516,7.99463061 104.096358,11.7387855 105.968745,16.4968188 L106.112518,16.8745422 L159.385152,161.694068 C161.291848,166.877345 158.635655,172.624903 153.452378,174.531599 C148.358469,176.405421 142.719567,173.872338 140.716873,168.864661 L140.614848,168.598825 L89.211,28.86 L37.3759214,168.623816 C35.4885354,173.712715 29.8981043,176.351047 24.7909589,174.617647 L24.5226307,174.522368 C19.4337312,172.634982 16.7953993,167.044551 18.5287999,161.937406 L18.6240786,161.669077 L72.3425855,16.8295583 Z"
45
- id="路径-21"
46
- fill="currentColor"
47
- fillRule="nonzero"
48
- />
49
- <path
50
- d="M121,103.146447 C126.522847,103.146447 131,107.623599 131,113.146447 C131,118.575687 126.673329,122.994378 121.279905,123.142605 L121,123.146447 L55,123.146447 C49.4771525,123.146447 45,118.669294 45,113.146447 C45,107.717207 49.3266708,103.298515 54.7200952,103.150288 L55,103.146447 L121,103.146447 Z"
51
- id="路径-22"
52
- fill="currentColor"
53
- fillRule="nonzero"
54
- />
55
- </g>
56
- </g>
57
- </g>
58
- </svg>
59
- );
60
- }
61
-
62
- function ColorActionButton(props: ColorActionButtonProps) {
63
- const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);
64
-
65
- function onChange(color: string | undefined) {
66
- props.action?.(color);
67
- }
68
-
69
- function toggleColor() {
70
- props.action?.(selectedColor);
71
- }
72
-
73
- const setSelectedColorDebounce = useCallback(
74
- debounce((color: string | undefined) => {
75
- setSelectedColor(color);
76
- }, 350),
77
- [],
78
- );
79
-
80
- return (
81
- <div className="flex items-center h-[32px]">
82
- <ActionButton tooltip={props?.tooltip} disabled={props?.disabled} action={toggleColor}>
83
- <span className="flex items-center justify-center text-sm">
84
- <IconC fill={selectedColor} />
85
- </span>
86
- </ActionButton>
87
-
88
- <ColorPicker
89
- selectedColor={selectedColor}
90
- setSelectedColor={setSelectedColorDebounce}
91
- onChange={onChange}
92
- disabled={props?.disabled}
93
- colors={props?.colors}
94
- defaultColor={props?.defaultColor}
95
- >
96
- <Button variant="ghost" size="icon" className="r!ichtext-h-[32px] !w-3" disabled={props?.disabled}>
97
- <IconComponent className="!w-3 !h-3 text-zinc-500" name="MenuDown" />
98
- </Button>
99
- </ColorPicker>
100
- </div>
101
- );
102
- }
103
-
104
- export default ColorActionButton;
@@ -1 +0,0 @@
1
- export * from './Color';
@@ -1,8 +0,0 @@
1
- import { Document as TiptapDocument } from '@tiptap/extension-document';
2
-
3
- export const Document = TiptapDocument.extend({
4
- content: '(block|columns)+',
5
- // echo editor is a block editor
6
- });
7
-
8
- export default Document;
@@ -1 +0,0 @@
1
- export * from './Document';
@@ -1,177 +0,0 @@
1
- /* eslint-disable @typescript-eslint/ban-ts-comment */
2
- import type { CommandProps } from '@tiptap/core';
3
- import { mergeAttributes } from '@tiptap/core';
4
- import TiptapImage from '@tiptap/extension-image';
5
- import { ReactNodeViewRenderer } from '@tiptap/react';
6
-
7
- import { DrawerActiveButton } from '@/extensions/Drawer/components/DrawerActiveButton';
8
- import { NodeViewDrawer } from '@/extensions/Drawer/components/NodeViewDrawer/NodeViewDrawer';
9
- import type { GeneralOptions } from '@/types';
10
-
11
- declare module '@tiptap/core' {
12
- interface Commands<ReturnType> {
13
- drawer: {
14
- setDrawer: (options: any, replace?: any) => ReturnType
15
- setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType
16
- }
17
- }
18
- }
19
-
20
- export interface DrawerOptions extends GeneralOptions<DrawerOptions> {
21
- /** Function for uploading files */
22
- upload?: (file: File) => Promise<string>
23
- }
24
-
25
- export const Drawer = TiptapImage.extend<DrawerOptions>({
26
- name: 'drawer',
27
-
28
- addOptions() {
29
- return {
30
- ...this.parent?.(),
31
- inline: false,
32
- content: '',
33
- marks: '',
34
- group: 'block',
35
- draggable: false,
36
- selectable: true,
37
- atom: true,
38
- HTMLAttributes: {
39
- class: 'drawer',
40
- },
41
- button: ({ editor, t, extension }: any) => ({
42
- component: DrawerActiveButton,
43
- componentProps: {
44
- action: () => {
45
- return true;
46
- },
47
- isActive: () => false,
48
- disabled: false,
49
- editor,
50
- icon: 'PencilRuler',
51
- tooltip: t('editor.drawer.tooltip'),
52
- upload: extension?.options?.upload,
53
- },
54
- }),
55
- };
56
- },
57
-
58
- addAttributes() {
59
- return {
60
- ...this.parent?.(),
61
- width: {
62
- default: null,
63
- parseHTML: (element) => {
64
- const img = element.querySelector('img') as any;
65
-
66
- const width = img?.getAttribute('width');
67
-
68
- return width ? Number.parseInt(width, 10) : 320;
69
- },
70
- renderHTML: (attributes) => {
71
- return {
72
- width: attributes.width,
73
- };
74
- },
75
- },
76
- height: {
77
- default: null,
78
- parseHTML: (element) => {
79
- const img = element.querySelector('img') as any;
80
-
81
- const height = img?.getAttribute('height');
82
-
83
- return height ? Number.parseInt(height, 10) : 212;
84
- },
85
- renderHTML: (attributes) => {
86
- return {
87
- height: attributes.height,
88
- };
89
- },
90
- },
91
- align: {
92
- default: 'center',
93
- parseHTML: element => element.getAttribute('align'),
94
- renderHTML: (attributes) => {
95
- return {
96
- align: attributes.align,
97
- };
98
- },
99
- },
100
- };
101
- },
102
-
103
- addNodeView() {
104
- return ReactNodeViewRenderer(NodeViewDrawer);
105
- },
106
-
107
- // @ts-ignore
108
- addCommands() {
109
- return {
110
- setDrawer:
111
- (
112
- options: { src: string, alt?: string },
113
- replace?: boolean,
114
- ) =>
115
- ({ commands, editor }: CommandProps) => {
116
- if (replace) {
117
- return commands.insertContent({
118
- type: this.name,
119
- attrs: options,
120
- });
121
- }
122
- return commands.insertContentAt(editor.state.selection.anchor, {
123
- type: this.name,
124
- attrs: options,
125
- });
126
- },
127
-
128
- setAlignImageDrawer:
129
- (align: any) =>
130
- ({ commands }: any) => {
131
- return commands.updateAttributes(this.name, { align });
132
- },
133
- };
134
- },
135
-
136
- renderHTML({ HTMLAttributes }) {
137
- const { align } = HTMLAttributes;
138
- const style = align ? `text-align: ${align};` : '';
139
-
140
- return [
141
- 'div', // Parent element
142
- {
143
- style,
144
- class: 'imageDrawer',
145
- },
146
- [
147
- 'img',
148
- mergeAttributes(
149
- // @ts-ignore
150
- this.options.HTMLAttributes,
151
- HTMLAttributes,
152
- ),
153
- ],
154
- ];
155
- },
156
- parseHTML() {
157
- return [
158
- {
159
- tag: 'div[class=imageDrawer]',
160
- getAttrs: (element) => {
161
- const img = element.querySelector('img');
162
-
163
- const width = img?.getAttribute('width');
164
- const height = img?.getAttribute('height');
165
-
166
- return {
167
- src: img?.getAttribute('src'),
168
- alt: img?.getAttribute('alt'),
169
- width: width ? Number.parseInt(width, 10) : null,
170
- height: height ? Number.parseInt(height, 10) : null,
171
- align: img?.getAttribute('align') || element.style.textAlign || null,
172
- };
173
- },
174
- },
175
- ];
176
- },
177
- });
@@ -1,85 +0,0 @@
1
- .wrapper {
2
- background-color: white;
3
- border-radius: 10px;
4
- cursor: pointer;
5
- position: absolute;
6
- top: 0;
7
- left: 0;
8
- z-index: 1000;
9
- padding: 10px;
10
- gap: 10px;
11
- z-index: 100;
12
- border: 1px solid #eeeeee;
13
- box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
14
- border-radius: 10px;
15
- }
16
-
17
- .tool {
18
- outline: none;
19
- border: none;
20
- background-color: white;
21
- border-radius: 5px;
22
- padding: 5px;
23
- cursor: pointer;
24
- transition: all 0.3s;
25
- color: rgb(89, 83, 83) !important;
26
- }
27
-
28
-
29
- .tool svg {
30
- width: 20px;
31
- height: 20px;
32
- }
33
-
34
- .tool:hover {
35
- background-color: #f5f5f5;
36
- }
37
-
38
- .active {
39
- background-color: #eeeeee !important;
40
- }
41
-
42
- .pen {
43
- display: flex;
44
- gap: 4px;
45
- align-items: center;
46
- flex-wrap: wrap;
47
- }
48
-
49
- .line {
50
- height: 20px;
51
- width: 1px;
52
- background-color: rgb(188, 185, 185);
53
- margin: 0 6px;
54
- transform: rotate(18deg);
55
- }
56
-
57
- .options {
58
- margin-top: 10px;
59
- padding: 10px 0 0;
60
- border-top: 1px dashed #eeeeee;
61
- display: flex;
62
- gap: 4px;
63
- align-items: center;
64
- flex-wrap: wrap;
65
- }
66
-
67
- .colorWrap {
68
- display: flex;
69
- gap: 8px;
70
- align-items: center;
71
- margin: 4px 0;
72
- }
73
- .color {
74
- outline: none !important;
75
- border: none !important;
76
- border-radius: 4px;
77
- cursor: pointer;
78
- width: 20px;
79
- height: 20px;
80
- border: 1px solid #eeeeee;
81
- }
82
-
83
- .colorActive {
84
- outline: 2px solid #2576B9 !important;
85
- }