@seafile/seafile-editor 1.0.0 → 1.0.2

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 (478) hide show
  1. package/dist/constants/event-types.js +16 -0
  2. package/dist/constants/hot-keys.js +43 -0
  3. package/dist/containers/article-info/index.js +57 -0
  4. package/dist/containers/custom/get-event-transfer.js +38 -0
  5. package/dist/containers/custom/set-event-transfer.js +36 -0
  6. package/dist/containers/hotkeys-helper/classify-hotkeys.js +39 -0
  7. package/dist/containers/hotkeys-helper/index.js +52 -0
  8. package/dist/containers/loading/index.js +33 -0
  9. package/dist/containers/outline/index.js +80 -0
  10. package/dist/containers/outline/outline-item.js +30 -0
  11. package/dist/editors/plain-markdown-editor/code-mirror.js +84 -0
  12. package/dist/editors/plain-markdown-editor/index.js +149 -0
  13. package/dist/editors/simple-slate-editor /index.js +90 -0
  14. package/dist/editors/simple-slate-editor /with-props-editor.js +18 -0
  15. package/dist/editors/slate-editor/editor-help/index.js +53 -0
  16. package/dist/editors/slate-editor/index.js +102 -0
  17. package/dist/editors/slate-editor/with-props-editor.js +18 -0
  18. package/dist/editors/slate-viewer/index.js +42 -0
  19. package/dist/extension/commons/element-popover/index.js +64 -0
  20. package/dist/extension/commons/index.js +26 -0
  21. package/dist/extension/commons/menu/index.js +21 -0
  22. package/dist/extension/commons/menu/menu-drop-down.js +104 -0
  23. package/dist/extension/commons/menu/menu-group.js +18 -0
  24. package/dist/extension/commons/menu/menu-item.js +54 -0
  25. package/dist/extension/commons/tooltip/index.js +26 -0
  26. package/dist/extension/constants/element-types.js +29 -0
  27. package/dist/extension/constants/index.js +46 -0
  28. package/dist/extension/constants/keyboard.js +33 -0
  29. package/dist/extension/constants/menus-config.js +121 -0
  30. package/dist/extension/core/index.js +38 -0
  31. package/dist/extension/core/queries/index.js +479 -0
  32. package/dist/extension/core/transforms/focus-editor.js +17 -0
  33. package/dist/extension/core/transforms/index.js +49 -0
  34. package/dist/extension/core/transforms/move-children.js +35 -0
  35. package/dist/extension/core/transforms/remove-node-children.js +31 -0
  36. package/dist/extension/core/transforms/replace-node-children.js +22 -0
  37. package/dist/extension/core/utils/index.js +103 -0
  38. package/dist/extension/editor.js +19 -0
  39. package/dist/extension/index.js +48 -0
  40. package/dist/extension/plugins/blockquote/helpers.js +77 -0
  41. package/dist/extension/plugins/blockquote/index.js +18 -0
  42. package/dist/extension/plugins/blockquote/menu/index.js +33 -0
  43. package/dist/extension/plugins/blockquote/plugin.js +70 -0
  44. package/dist/extension/plugins/blockquote/render-elem.js +18 -0
  45. package/dist/extension/plugins/check-list/helper.js +35 -0
  46. package/dist/extension/plugins/check-list/index.js +19 -0
  47. package/dist/extension/plugins/check-list/menu/index.js +40 -0
  48. package/dist/extension/plugins/check-list/plugin.js +50 -0
  49. package/dist/extension/plugins/check-list/render-elem.js +44 -0
  50. package/dist/extension/plugins/clear-format/helpers.js +65 -0
  51. package/dist/extension/plugins/clear-format/menu/index.js +34 -0
  52. package/dist/extension/plugins/code-block/helpers.js +175 -0
  53. package/dist/extension/plugins/code-block/index.js +20 -0
  54. package/dist/extension/plugins/code-block/menu/index.js +37 -0
  55. package/dist/extension/plugins/code-block/plugin.js +270 -0
  56. package/dist/extension/plugins/code-block/render-elem/constant.js +12 -0
  57. package/dist/extension/plugins/code-block/render-elem/index.js +62 -0
  58. package/dist/extension/plugins/code-block/render-elem/language-selector.js +39 -0
  59. package/dist/extension/plugins/formula/helper.js +74 -0
  60. package/dist/extension/plugins/formula/index.js +19 -0
  61. package/dist/extension/plugins/formula/menu/formula-modal.js +97 -0
  62. package/dist/extension/plugins/formula/menu/index.js +71 -0
  63. package/dist/extension/plugins/formula/plugin.js +18 -0
  64. package/dist/extension/plugins/formula/render-elem.js +48 -0
  65. package/dist/extension/plugins/header/helper.js +57 -0
  66. package/dist/extension/plugins/header/index.js +19 -0
  67. package/dist/extension/plugins/header/menu/index.js +110 -0
  68. package/dist/extension/plugins/header/plugin.js +146 -0
  69. package/dist/extension/plugins/header/render-elem.js +34 -0
  70. package/dist/extension/plugins/image/helper.js +62 -0
  71. package/dist/extension/plugins/image/index.js +19 -0
  72. package/dist/extension/plugins/image/menu/image-menu-dialog.js +79 -0
  73. package/dist/extension/plugins/image/menu/image-menu-popover.js +96 -0
  74. package/dist/extension/plugins/image/menu/index.js +58 -0
  75. package/dist/extension/plugins/image/plugin.js +24 -0
  76. package/dist/extension/plugins/image/render-element/image-previewer.js +78 -0
  77. package/dist/extension/plugins/image/render-element/index.js +122 -0
  78. package/dist/extension/plugins/index.js +95 -0
  79. package/dist/extension/plugins/link/helper.js +235 -0
  80. package/dist/extension/plugins/link/index.js +19 -0
  81. package/dist/extension/plugins/link/menu/index.js +98 -0
  82. package/dist/extension/plugins/link/menu/link-modal.js +163 -0
  83. package/dist/extension/plugins/link/plugin.js +104 -0
  84. package/dist/extension/plugins/link/render-elem/index.js +83 -0
  85. package/dist/extension/plugins/link/render-elem/link-popover.js +77 -0
  86. package/dist/extension/plugins/list/constant.js +8 -0
  87. package/dist/extension/plugins/list/helpers.js +78 -0
  88. package/dist/extension/plugins/list/index.js +19 -0
  89. package/dist/extension/plugins/list/menu/index.js +46 -0
  90. package/dist/extension/plugins/list/plugin/index.js +48 -0
  91. package/dist/extension/plugins/list/plugin/insert-break-list.js +28 -0
  92. package/dist/extension/plugins/list/plugin/insert-fragment-list.js +190 -0
  93. package/dist/extension/plugins/list/plugin/normalize-list.js +81 -0
  94. package/dist/extension/plugins/list/plugin/on-tab-handle.js +52 -0
  95. package/dist/extension/plugins/list/queries/index.js +51 -0
  96. package/dist/extension/plugins/list/render-elem/index.js +38 -0
  97. package/dist/extension/plugins/list/transforms/index.js +75 -0
  98. package/dist/extension/plugins/list/transforms/insert-list-item.js +100 -0
  99. package/dist/extension/plugins/list/transforms/move-list-item-down.js +51 -0
  100. package/dist/extension/plugins/list/transforms/move-list-item-up.js +124 -0
  101. package/dist/extension/plugins/list/transforms/move-list-items-to-list.js +62 -0
  102. package/dist/extension/plugins/list/transforms/move-list-items.js +73 -0
  103. package/dist/extension/plugins/list/transforms/normalize-list-item.js +125 -0
  104. package/dist/extension/plugins/list/transforms/normalize-nested-list.js +40 -0
  105. package/dist/extension/plugins/list/transforms/remove-first-list-item.js +24 -0
  106. package/dist/extension/plugins/list/transforms/transforms-to-list.js +148 -0
  107. package/dist/extension/plugins/list/transforms/unwrap-list.js +50 -0
  108. package/dist/extension/plugins/node-id/constants.js +24 -0
  109. package/dist/extension/plugins/node-id/helpers.js +69 -0
  110. package/dist/extension/plugins/node-id/index.js +12 -0
  111. package/dist/extension/plugins/node-id/with-node-id.js +39 -0
  112. package/dist/extension/plugins/paragraph/helper.js +16 -0
  113. package/dist/extension/plugins/paragraph/index.js +17 -0
  114. package/dist/extension/plugins/paragraph/plugin.js +47 -0
  115. package/dist/extension/plugins/paragraph/render-elem.js +18 -0
  116. package/dist/extension/plugins/table/constant.js +9 -0
  117. package/dist/extension/plugins/table/helper.js +232 -0
  118. package/dist/extension/plugins/table/index.js +21 -0
  119. package/dist/extension/plugins/table/menu/index.js +64 -0
  120. package/dist/extension/plugins/table/menu/table-operator.js +98 -0
  121. package/dist/extension/plugins/table/menu/table-size-selector.js +100 -0
  122. package/dist/extension/plugins/table/model.js +95 -0
  123. package/dist/extension/plugins/table/plugin.js +173 -0
  124. package/dist/extension/plugins/table/render-elem/context-menu.js +93 -0
  125. package/dist/extension/plugins/table/render-elem/index.js +189 -0
  126. package/dist/extension/plugins/table/table-operations.js +187 -0
  127. package/dist/extension/plugins/text-style/helpers.js +44 -0
  128. package/dist/extension/plugins/text-style/index.js +17 -0
  129. package/dist/extension/plugins/text-style/menu/index.js +34 -0
  130. package/dist/extension/plugins/text-style/plugin.js +36 -0
  131. package/dist/extension/plugins/text-style/render-elem.js +52 -0
  132. package/dist/extension/render/render-element.js +113 -0
  133. package/dist/extension/render/render-leaf.js +21 -0
  134. package/dist/extension/toolbar/header-toolbar/index.js +113 -0
  135. package/dist/extension/toolbar/index.js +13 -0
  136. package/dist/extension/toolbar/user-help/shortcut-dialog.js +141 -0
  137. package/dist/hooks/use-mathjax.js +51 -0
  138. package/dist/hooks/use-scroll-context.js +17 -0
  139. package/dist/hooks/use-selection-update.js +25 -0
  140. package/dist/index.js +80 -0
  141. package/dist/pages/markdown-editor.js +65 -0
  142. package/dist/pages/markdown-view.js +49 -0
  143. package/dist/pages/rich-markdown-editor.js +111 -0
  144. package/dist/pages/simple-editor.js +63 -0
  145. package/dist/slate-convert/html-to-slate/constants.js +40 -0
  146. package/dist/slate-convert/html-to-slate/helper.js +60 -0
  147. package/dist/slate-convert/html-to-slate/index.js +138 -0
  148. package/dist/slate-convert/html-to-slate/rules/blockquote.js +22 -0
  149. package/dist/slate-convert/html-to-slate/rules/check-list.js +25 -0
  150. package/dist/slate-convert/html-to-slate/rules/code-block.js +93 -0
  151. package/dist/slate-convert/html-to-slate/rules/header.js +22 -0
  152. package/dist/slate-convert/html-to-slate/rules/image.js +27 -0
  153. package/dist/slate-convert/html-to-slate/rules/index.js +18 -0
  154. package/dist/slate-convert/html-to-slate/rules/link.js +27 -0
  155. package/dist/slate-convert/html-to-slate/rules/list.js +55 -0
  156. package/dist/slate-convert/html-to-slate/rules/paragraph.js +22 -0
  157. package/dist/slate-convert/html-to-slate/rules/table.js +39 -0
  158. package/dist/slate-convert/html-to-slate/rules/text.js +61 -0
  159. package/dist/slate-convert/index.js +34 -0
  160. package/dist/slate-convert/md-to-html/index.js +53 -0
  161. package/dist/slate-convert/md-to-html/sanitize-schema.js +24 -0
  162. package/dist/slate-convert/md-to-slate/index.js +44 -0
  163. package/dist/slate-convert/md-to-slate/transform.js +326 -0
  164. package/dist/slate-convert/slate-to-md/index.js +43 -0
  165. package/dist/slate-convert/slate-to-md/transform.js +269 -0
  166. package/dist/utils/common.js +26 -0
  167. package/dist/utils/deserialize-html.js +260 -0
  168. package/dist/utils/dom-utils.js +51 -0
  169. package/dist/utils/event-bus.js +54 -0
  170. package/dist/utils/event-handler.js +40 -0
  171. package/dist/utils/object-utils.js +73 -0
  172. package/package.json +7 -2
  173. package/.babelrc +0 -5
  174. package/.eslintignore +0 -19
  175. package/.eslintrc.json +0 -52
  176. package/.github/workflows/nodejs.yml +0 -25
  177. package/.vscode/settings.json +0 -5
  178. package/config/config.common.js +0 -157
  179. package/config/config.dev.js +0 -53
  180. package/config/jest/cssTransform.js +0 -16
  181. package/config/jest/fileTransform.js +0 -40
  182. package/config/utils/theme.css.js +0 -103
  183. package/config.js +0 -61
  184. package/dev-server.js +0 -145
  185. package/jest.config.js +0 -16
  186. package/scripts/ejs.js +0 -16
  187. package/site/_i18n/index.js +0 -35
  188. package/site/api/index.js +0 -212
  189. package/site/app.js +0 -21
  190. package/site/assets/css/app.css +0 -47
  191. package/site/assets/css/seafile-editor.css +0 -33
  192. package/site/commons/loading/index.js +0 -14
  193. package/site/commons/switch/index.css +0 -14
  194. package/site/commons/switch/index.js +0 -37
  195. package/site/commons/toast/alert.js +0 -106
  196. package/site/commons/toast/index.js +0 -5
  197. package/site/commons/toast/toast.js +0 -195
  198. package/site/commons/toast/toastManager.js +0 -138
  199. package/site/commons/toast/toaster.js +0 -64
  200. package/site/index.html +0 -23
  201. package/site/index.js +0 -21
  202. package/site/pages/home.js +0 -21
  203. package/site/pages/plain-markdown-view.js +0 -6
  204. package/site/pages/rich-seafile-editor.js +0 -72
  205. package/site/pages/seafile-editor.js +0 -39
  206. package/site/pages/seafile-viewer.js +0 -45
  207. package/site/pages/simple-editor.js +0 -44
  208. package/site/pages/wiki-viewer.js +0 -7
  209. package/site/setting.js +0 -36
  210. package/site/setting.local.dist.js +0 -23
  211. package/src/constants/event-types.js +0 -11
  212. package/src/constants/hot-keys.js +0 -47
  213. package/src/containers/article-info/index.js +0 -49
  214. package/src/containers/custom/get-event-transfer.js +0 -28
  215. package/src/containers/custom/set-event-transfer.js +0 -32
  216. package/src/containers/hotkeys-helper/classify-hotkeys.js +0 -30
  217. package/src/containers/hotkeys-helper/index.js +0 -43
  218. package/src/containers/loading/index.js +0 -14
  219. package/src/containers/loading/style.css +0 -49
  220. package/src/containers/outline/index.js +0 -75
  221. package/src/containers/outline/outline-item.js +0 -28
  222. package/src/editors/plain-markdown-editor/code-mirror.js +0 -73
  223. package/src/editors/plain-markdown-editor/index.js +0 -136
  224. package/src/editors/simple-slate-editor /index.js +0 -71
  225. package/src/editors/simple-slate-editor /with-props-editor.js +0 -15
  226. package/src/editors/slate-editor/editor-help/index.js +0 -46
  227. package/src/editors/slate-editor/index.js +0 -77
  228. package/src/editors/slate-editor/with-props-editor.js +0 -15
  229. package/src/editors/slate-viewer/index.js +0 -35
  230. package/src/extension/commons/element-popover/index.js +0 -52
  231. package/src/extension/commons/index.js +0 -10
  232. package/src/extension/commons/menu/index.js +0 -9
  233. package/src/extension/commons/menu/menu-drop-down.js +0 -110
  234. package/src/extension/commons/menu/menu-group.js +0 -20
  235. package/src/extension/commons/menu/menu-item.js +0 -60
  236. package/src/extension/commons/tooltip/index.js +0 -26
  237. package/src/extension/constants/element-types.js +0 -23
  238. package/src/extension/constants/index.js +0 -37
  239. package/src/extension/constants/keyboard.js +0 -29
  240. package/src/extension/constants/menus-config.js +0 -149
  241. package/src/extension/core/index.js +0 -3
  242. package/src/extension/core/queries/index.js +0 -410
  243. package/src/extension/core/transforms/focus-editor.js +0 -12
  244. package/src/extension/core/transforms/index.js +0 -4
  245. package/src/extension/core/transforms/move-children.js +0 -23
  246. package/src/extension/core/transforms/remove-node-children.js +0 -8
  247. package/src/extension/core/transforms/replace-node-children.js +0 -14
  248. package/src/extension/core/utils/index.js +0 -76
  249. package/src/extension/editor.js +0 -14
  250. package/src/extension/index.js +0 -15
  251. package/src/extension/plugins/blockquote/helpers.js +0 -65
  252. package/src/extension/plugins/blockquote/index.js +0 -13
  253. package/src/extension/plugins/blockquote/menu/index.js +0 -31
  254. package/src/extension/plugins/blockquote/plugin.js +0 -64
  255. package/src/extension/plugins/blockquote/render-elem.js +0 -9
  256. package/src/extension/plugins/check-list/helper.js +0 -34
  257. package/src/extension/plugins/check-list/index.js +0 -14
  258. package/src/extension/plugins/check-list/menu/index.js +0 -44
  259. package/src/extension/plugins/check-list/plugin.js +0 -46
  260. package/src/extension/plugins/check-list/render-elem.js +0 -23
  261. package/src/extension/plugins/clear-format/helpers.js +0 -48
  262. package/src/extension/plugins/clear-format/menu/index.js +0 -39
  263. package/src/extension/plugins/code-block/helpers.js +0 -107
  264. package/src/extension/plugins/code-block/index.js +0 -14
  265. package/src/extension/plugins/code-block/menu/index.js +0 -40
  266. package/src/extension/plugins/code-block/plugin.js +0 -210
  267. package/src/extension/plugins/code-block/render-elem/constant.js +0 -17
  268. package/src/extension/plugins/code-block/render-elem/index.js +0 -55
  269. package/src/extension/plugins/code-block/render-elem/language-selector.js +0 -38
  270. package/src/extension/plugins/formula/helper.js +0 -68
  271. package/src/extension/plugins/formula/index.js +0 -14
  272. package/src/extension/plugins/formula/menu/formula-modal.js +0 -73
  273. package/src/extension/plugins/formula/menu/index.js +0 -63
  274. package/src/extension/plugins/formula/plugin.js +0 -18
  275. package/src/extension/plugins/formula/render-elem.js +0 -40
  276. package/src/extension/plugins/header/helper.js +0 -47
  277. package/src/extension/plugins/header/index.js +0 -14
  278. package/src/extension/plugins/header/menu/index.js +0 -114
  279. package/src/extension/plugins/header/plugin.js +0 -134
  280. package/src/extension/plugins/header/render-elem.js +0 -31
  281. package/src/extension/plugins/image/helper.js +0 -50
  282. package/src/extension/plugins/image/index.js +0 -14
  283. package/src/extension/plugins/image/menu/image-menu-dialog.js +0 -68
  284. package/src/extension/plugins/image/menu/image-menu-popover.js +0 -76
  285. package/src/extension/plugins/image/menu/index.js +0 -61
  286. package/src/extension/plugins/image/plugin.js +0 -23
  287. package/src/extension/plugins/image/render-element/image-previewer.js +0 -71
  288. package/src/extension/plugins/image/render-element/index.js +0 -94
  289. package/src/extension/plugins/index.js +0 -47
  290. package/src/extension/plugins/link/helper.js +0 -161
  291. package/src/extension/plugins/link/index.js +0 -14
  292. package/src/extension/plugins/link/menu/index.js +0 -82
  293. package/src/extension/plugins/link/menu/link-modal.js +0 -135
  294. package/src/extension/plugins/link/plugin.js +0 -85
  295. package/src/extension/plugins/link/render-elem/index.js +0 -69
  296. package/src/extension/plugins/link/render-elem/link-popover.js +0 -79
  297. package/src/extension/plugins/list/constant.js +0 -3
  298. package/src/extension/plugins/list/helpers.js +0 -53
  299. package/src/extension/plugins/list/index.js +0 -14
  300. package/src/extension/plugins/list/menu/index.js +0 -48
  301. package/src/extension/plugins/list/plugin/index.js +0 -48
  302. package/src/extension/plugins/list/plugin/insert-break-list.js +0 -25
  303. package/src/extension/plugins/list/plugin/insert-fragment-list.js +0 -162
  304. package/src/extension/plugins/list/plugin/normalize-list.js +0 -64
  305. package/src/extension/plugins/list/plugin/on-tab-handle.js +0 -34
  306. package/src/extension/plugins/list/queries/index.js +0 -39
  307. package/src/extension/plugins/list/render-elem/index.js +0 -26
  308. package/src/extension/plugins/list/transforms/index.js +0 -23
  309. package/src/extension/plugins/list/transforms/insert-list-item.js +0 -65
  310. package/src/extension/plugins/list/transforms/move-list-item-down.js +0 -40
  311. package/src/extension/plugins/list/transforms/move-list-item-up.js +0 -105
  312. package/src/extension/plugins/list/transforms/move-list-items-to-list.js +0 -58
  313. package/src/extension/plugins/list/transforms/move-list-items.js +0 -76
  314. package/src/extension/plugins/list/transforms/normalize-list-item.js +0 -92
  315. package/src/extension/plugins/list/transforms/normalize-nested-list.js +0 -31
  316. package/src/extension/plugins/list/transforms/remove-first-list-item.js +0 -11
  317. package/src/extension/plugins/list/transforms/transforms-to-list.js +0 -91
  318. package/src/extension/plugins/list/transforms/unwrap-list.js +0 -44
  319. package/src/extension/plugins/node-id/constants.js +0 -18
  320. package/src/extension/plugins/node-id/helpers.js +0 -61
  321. package/src/extension/plugins/node-id/index.js +0 -7
  322. package/src/extension/plugins/node-id/with-node-id.js +0 -37
  323. package/src/extension/plugins/paragraph/helper.js +0 -9
  324. package/src/extension/plugins/paragraph/index.js +0 -12
  325. package/src/extension/plugins/paragraph/plugin.js +0 -40
  326. package/src/extension/plugins/paragraph/render-elem.js +0 -11
  327. package/src/extension/plugins/table/constant.js +0 -3
  328. package/src/extension/plugins/table/helper.js +0 -175
  329. package/src/extension/plugins/table/index.js +0 -15
  330. package/src/extension/plugins/table/menu/index.js +0 -69
  331. package/src/extension/plugins/table/menu/table-operator.js +0 -101
  332. package/src/extension/plugins/table/menu/table-size-selector.js +0 -71
  333. package/src/extension/plugins/table/model.js +0 -69
  334. package/src/extension/plugins/table/plugin.js +0 -159
  335. package/src/extension/plugins/table/render-elem/context-menu.js +0 -78
  336. package/src/extension/plugins/table/render-elem/index.js +0 -157
  337. package/src/extension/plugins/table/table-operations.js +0 -162
  338. package/src/extension/plugins/text-style/helpers.js +0 -38
  339. package/src/extension/plugins/text-style/index.js +0 -12
  340. package/src/extension/plugins/text-style/menu/index.js +0 -41
  341. package/src/extension/plugins/text-style/plugin.js +0 -37
  342. package/src/extension/plugins/text-style/render-elem.js +0 -45
  343. package/src/extension/render/render-element.js +0 -82
  344. package/src/extension/render/render-leaf.js +0 -16
  345. package/src/extension/toolbar/header-toolbar/index.js +0 -129
  346. package/src/extension/toolbar/index.js +0 -5
  347. package/src/extension/toolbar/user-help/shortcut-dialog.js +0 -144
  348. package/src/hooks/use-mathjax.js +0 -44
  349. package/src/hooks/use-scroll-context.js +0 -14
  350. package/src/hooks/use-selection-update.js +0 -14
  351. package/src/index.js +0 -22
  352. package/src/pages/markdown-editor.js +0 -53
  353. package/src/pages/markdown-view.js +0 -36
  354. package/src/pages/rich-markdown-editor.js +0 -95
  355. package/src/pages/simple-editor.js +0 -52
  356. package/src/slate-convert/html-to-slate/constants.js +0 -54
  357. package/src/slate-convert/html-to-slate/helper.js +0 -22
  358. package/src/slate-convert/html-to-slate/index.js +0 -144
  359. package/src/slate-convert/html-to-slate/rules/blockquote.js +0 -16
  360. package/src/slate-convert/html-to-slate/rules/check-list.js +0 -22
  361. package/src/slate-convert/html-to-slate/rules/code-block.js +0 -91
  362. package/src/slate-convert/html-to-slate/rules/header.js +0 -18
  363. package/src/slate-convert/html-to-slate/rules/image.js +0 -18
  364. package/src/slate-convert/html-to-slate/rules/index.js +0 -23
  365. package/src/slate-convert/html-to-slate/rules/link.js +0 -24
  366. package/src/slate-convert/html-to-slate/rules/list.js +0 -52
  367. package/src/slate-convert/html-to-slate/rules/paragraph.js +0 -16
  368. package/src/slate-convert/html-to-slate/rules/table.js +0 -37
  369. package/src/slate-convert/html-to-slate/rules/text.js +0 -63
  370. package/src/slate-convert/index.js +0 -11
  371. package/src/slate-convert/md-to-html/index.js +0 -44
  372. package/src/slate-convert/md-to-html/sanitize-schema.js +0 -41
  373. package/src/slate-convert/md-to-slate/index.js +0 -42
  374. package/src/slate-convert/md-to-slate/transform.js +0 -336
  375. package/src/slate-convert/slate-to-md/index.js +0 -44
  376. package/src/slate-convert/slate-to-md/transform.js +0 -248
  377. package/src/utils/common.js +0 -30
  378. package/src/utils/deserialize-html.js +0 -174
  379. package/src/utils/dom-utils.js +0 -45
  380. package/src/utils/event-bus.js +0 -37
  381. package/src/utils/event-handler.js +0 -36
  382. package/src/utils/object-utils.js +0 -51
  383. package/tests/core/constants/index.js +0 -54
  384. package/tests/core/index.js +0 -11
  385. package/tests/core/jsx/index.js +0 -9
  386. package/tests/core/stub-editor/index.js +0 -26
  387. package/tests/core/utils.js +0 -58
  388. package/tests/extension/plugins/list/insert-block.test.js +0 -40
  389. package/tests/extension/plugins/list/insert-fragment-list.test.js +0 -392
  390. package/tests/extension/plugins/list/toggle-list.test.js +0 -160
  391. package/tests/extension/plugins/text/text.test.js +0 -29
  392. package/tests/extension/plugins/text-style/toggle-text-style.test.js +0 -148
  393. package/tests/slate-convert/html-to-slate/blockquote.test.js +0 -107
  394. package/tests/slate-convert/html-to-slate/code-block.test.js +0 -32
  395. package/tests/slate-convert/html-to-slate/header.test.js +0 -56
  396. package/tests/slate-convert/html-to-slate/link.test.js +0 -77
  397. package/tests/slate-convert/html-to-slate/list.test.js +0 -190
  398. package/tests/slate-convert/html-to-slate/paragraph.test.js +0 -40
  399. package/tests/slate-convert/html-to-slate/text.test.js +0 -131
  400. package/tests/slate-convert/md-to-html/blockquote.test.js +0 -110
  401. package/tests/slate-convert/md-to-html/check-list.test.js +0 -19
  402. package/tests/slate-convert/md-to-html/code-block.test.js +0 -19
  403. package/tests/slate-convert/md-to-html/header.test.js +0 -20
  404. package/tests/slate-convert/md-to-html/image.test.js +0 -17
  405. package/tests/slate-convert/md-to-html/image_reference.test.js +0 -17
  406. package/tests/slate-convert/md-to-html/link.test.js +0 -15
  407. package/tests/slate-convert/md-to-html/link_reference.test.js +0 -15
  408. package/tests/slate-convert/md-to-html/list-ordered.test.js +0 -22
  409. package/tests/slate-convert/md-to-html/list-unordered.test.js +0 -22
  410. package/tests/slate-convert/md-to-html/paragraph.test.js +0 -15
  411. package/tests/slate-convert/md-to-html/table.test.js +0 -29
  412. package/tests/slate-convert/md-to-html/text_base.test.js +0 -14
  413. package/tests/slate-convert/md-to-html/text_bold.test.js +0 -14
  414. package/tests/slate-convert/md-to-html/text_bold_italic.test.js +0 -15
  415. package/tests/slate-convert/md-to-html/text_code.test.js +0 -14
  416. package/tests/slate-convert/md-to-html/text_code_bold.test.js +0 -14
  417. package/tests/slate-convert/md-to-html/text_code_bold_italic.test.js +0 -14
  418. package/tests/slate-convert/md-to-html/text_code_italic.test.js +0 -14
  419. package/tests/slate-convert/md-to-html/text_italic.test.js +0 -14
  420. package/tests/slate-convert/md-to-slate/blockquote.test.js +0 -200
  421. package/tests/slate-convert/md-to-slate/check-list.test.js +0 -34
  422. package/tests/slate-convert/md-to-slate/code-block.test.js +0 -32
  423. package/tests/slate-convert/md-to-slate/header.test.js +0 -49
  424. package/tests/slate-convert/md-to-slate/image.test.js +0 -31
  425. package/tests/slate-convert/md-to-slate/link.test.js +0 -30
  426. package/tests/slate-convert/md-to-slate/list-ordered.test.js +0 -42
  427. package/tests/slate-convert/md-to-slate/list-unordered.test.js +0 -42
  428. package/tests/slate-convert/md-to-slate/paragraph.test.js +0 -19
  429. package/tests/slate-convert/md-to-slate/table.test.js +0 -34
  430. package/tests/slate-convert/md-to-slate/text_base.test.js +0 -19
  431. package/tests/slate-convert/md-to-slate/text_bold.test.js +0 -22
  432. package/tests/slate-convert/md-to-slate/text_bold_italic.test.js +0 -23
  433. package/tests/slate-convert/md-to-slate/text_code.test.js +0 -22
  434. package/tests/slate-convert/md-to-slate/text_code_bold.test.js +0 -23
  435. package/tests/slate-convert/md-to-slate/text_code_bold_italic.test.js +0 -24
  436. package/tests/slate-convert/md-to-slate/text_code_italic.test.js +0 -23
  437. package/tests/slate-convert/md-to-slate/text_italic.test.js +0 -22
  438. package/tests/slate-convert/slate-to-md/blockquote.test.js +0 -416
  439. package/tests/slate-convert/slate-to-md/check-list.test.js +0 -96
  440. package/tests/slate-convert/slate-to-md/code-block.test.js +0 -35
  441. package/tests/slate-convert/slate-to-md/formula.test.js +0 -26
  442. package/tests/slate-convert/slate-to-md/header.test.js +0 -109
  443. package/tests/slate-convert/slate-to-md/image.test.js +0 -98
  444. package/tests/slate-convert/slate-to-md/link.test.js +0 -52
  445. package/tests/slate-convert/slate-to-md/list-ordered.test.js +0 -87
  446. package/tests/slate-convert/slate-to-md/list-unordered.test.js +0 -81
  447. package/tests/slate-convert/slate-to-md/paragraph.test.js +0 -28
  448. package/tests/slate-convert/slate-to-md/table.test.js +0 -56
  449. package/tests/slate-convert/slate-to-md/text_base.test.js +0 -28
  450. package/tests/slate-convert/slate-to-md/text_bold.test.js +0 -36
  451. package/tests/slate-convert/slate-to-md/text_bold_italic.test.js +0 -42
  452. package/tests/slate-convert/slate-to-md/text_code.test.js +0 -31
  453. package/tests/slate-convert/slate-to-md/text_code_bold.test.js +0 -37
  454. package/tests/slate-convert/slate-to-md/text_code_bold_italic.test.js +0 -43
  455. package/tests/slate-convert/slate-to-md/text_code_italic.test.js +0 -37
  456. package/tests/slate-convert/slate-to-md/text_italic.test.js +0 -36
  457. /package/{src → dist}/assets/css/slate-editor.css +0 -0
  458. /package/{src → dist}/containers/article-info/style.css +0 -0
  459. /package/{src → dist}/containers/hotkeys-helper/style.css +0 -0
  460. /package/{site/commons → dist/containers}/loading/style.css +0 -0
  461. /package/{src → dist}/containers/outline/style.css +0 -0
  462. /package/{src → dist}/editors/plain-markdown-editor/code-mirror.css +0 -0
  463. /package/{src → dist}/editors/plain-markdown-editor/style.css +0 -0
  464. /package/{src → dist}/editors/slate-editor/editor-help/style.css +0 -0
  465. /package/{src → dist}/editors/slate-viewer/style.css +0 -0
  466. /package/{src → dist}/extension/commons/menu/menu.css +0 -0
  467. /package/{src → dist}/extension/commons/tooltip/index.css +0 -0
  468. /package/{src → dist}/extension/plugins/code-block/render-elem/style.css +0 -0
  469. /package/{src → dist}/extension/plugins/formula/formula.css +0 -0
  470. /package/{src → dist}/extension/plugins/header/menu/style.css +0 -0
  471. /package/{src → dist}/extension/plugins/image/menu/style.css +0 -0
  472. /package/{src → dist}/extension/plugins/image/render-element/style.css +0 -0
  473. /package/{src → dist}/extension/plugins/link/render-elem/style.css +0 -0
  474. /package/{src → dist}/extension/plugins/list/render-elem/style.css +0 -0
  475. /package/{src → dist}/extension/plugins/table/menu/style.css +0 -0
  476. /package/{src → dist}/extension/plugins/table/render-elem/style.css +0 -0
  477. /package/{src → dist}/extension/toolbar/header-toolbar/style.css +0 -0
  478. /package/{src → dist}/extension/toolbar/user-help/style.css +0 -0
@@ -1,210 +0,0 @@
1
- import isHotkey from 'is-hotkey';
2
- import { Transforms, Node, Range, Editor } from 'slate';
3
- import { getNodeType, isLastNode, getSelectedNodeByType, generateEmptyElement, generateElement } from '../../core';
4
- import { getCodeBlockNodeEntry } from './helpers';
5
- import { CODE_BLOCK, CODE_LINE, PARAGRAPH } from '../../constants/element-types';
6
-
7
- const withCodeBlock = (editor) => {
8
- const { normalizeNode, insertFragment, insertText, insertBreak, insertData, insertNode, onHotKeyDown } = editor;
9
- const newEditor = editor;
10
-
11
- newEditor.insertData = (data) => {
12
- if (data.types.includes('text/code-block') && !getSelectedNodeByType(editor, CODE_BLOCK)) {
13
- const codeBlockNode = JSON.parse(data.getData('text/code-block'));
14
- return insertNode(codeBlockNode);
15
- }
16
- insertData(data);
17
- };
18
-
19
- newEditor.insertFragment = (data) => {
20
- // only selected code block content
21
- if (data.length === 1 && data[0].type === CODE_BLOCK && !getSelectedNodeByType(editor, CODE_BLOCK)) {
22
- data.forEach((node, index) => {
23
- if (node.type === CODE_BLOCK) {
24
- const newBlock = node.children.map(line => {
25
- const text = Node.string(line);
26
- const children = generateElement(PARAGRAPH, { childrenOrText: text });
27
- return children;
28
- });
29
- data.splice(index, 1, ...newBlock);
30
- }
31
- });
32
- return insertFragment(data);
33
- } else {
34
- if (getSelectedNodeByType(editor, CODE_BLOCK)) {
35
- // Paste into code block
36
-
37
- // Pasted data is code block split with code-line
38
- data.forEach((node, index) => {
39
- if (node.type === CODE_BLOCK) {
40
- const codeLineArr = node.children.map(line => line);
41
- data.splice(index, 1, ...codeLineArr);
42
- }
43
- });
44
- const insertCodeLines = data.map(node => {
45
- const text = Node.string(node);
46
- const codeLine = generateElement(CODE_LINE, { childrenOrText: text });
47
- return codeLine;
48
- });
49
-
50
- // Current focus code-line string not empty
51
- const string = Editor.string(newEditor, newEditor.selection.focus.path);
52
- if (string.length !== 0 && Range.isCollapsed(newEditor.selection)) {
53
- const [node, ...restNode] = insertCodeLines;
54
- const text = Node.string(node);
55
- insertText(text);
56
- if (restNode.length !== 0) {
57
- insertBreak();
58
- insertFragment(restNode);
59
- }
60
- return;
61
- }
62
- return insertFragment(insertCodeLines);
63
- } else {
64
- // Paste into not a code block
65
- return insertFragment(data);
66
- }
67
- }
68
- };
69
-
70
- // Rewrite normalizeNode
71
- newEditor.normalizeNode = ([node, path]) => {
72
- const type = getNodeType(node);
73
-
74
- if (type === CODE_LINE && path.length <= 1) {
75
- Transforms.setNodes(newEditor, { type: PARAGRAPH }, { at: path });
76
- return;
77
- }
78
-
79
- if (type === CODE_BLOCK) {
80
- if (node.children.length === 0) {
81
- Transforms.delete(newEditor, { at: path });
82
- return;
83
- }
84
-
85
- // code-block is the last node in the editor and needs to be followed by a p node
86
- const isLast = isLastNode(newEditor, node);
87
- if (isLast) {
88
- const paragraph = generateEmptyElement(PARAGRAPH);
89
- Transforms.insertNodes(newEditor, paragraph, { at: [path[0] + 1] });
90
- }
91
-
92
- // Here must be a code node below code-block
93
- if (getNodeType(node.children[0]) !== CODE_LINE) {
94
- Transforms.unwrapNodes(newEditor);
95
- Transforms.setNodes(newEditor, { type: PARAGRAPH }, { mode: 'highest' });
96
- }
97
-
98
- if (node.children.length > 1) {
99
- node.children.forEach((child, index) => {
100
- if (child.type !== CODE_LINE) {
101
- Transforms.setNodes(newEditor, { type: CODE_LINE }, { at: [...path, index] });
102
- }
103
- });
104
- }
105
- }
106
-
107
- // Perform default behavior
108
- return normalizeNode([node, path]);
109
- };
110
-
111
- newEditor.onHotKeyDown = (event) => {
112
- const wrapperCodeBlock = getCodeBlockNodeEntry(newEditor);
113
- if (!wrapperCodeBlock) return onHotKeyDown && onHotKeyDown(event);
114
-
115
- if (isHotkey('mod+enter', event)) {
116
- event.preventDefault();
117
- if (newEditor.selection && !Range.isExpanded(newEditor.selection)) {
118
- const path = Editor.path(newEditor, newEditor.selection);
119
- const newParagraphPath = [path[0] + 1];
120
- const newParagraph = generateEmptyElement(PARAGRAPH);
121
- Transforms.insertNodes(newEditor, newParagraph, { at: newParagraphPath });
122
- Transforms.select(newEditor, newParagraphPath);
123
- }
124
- return true;
125
- }
126
-
127
- if (isHotkey('tab', event)) {
128
- event.preventDefault();
129
- const nodeEntries = Editor.nodes(newEditor, {
130
- mode: 'lowest',
131
- match: node => node.type === CODE_LINE,
132
- });
133
- const nodeEntryList = Array.from(nodeEntries);
134
- for (const nodeEntry of nodeEntryList) {
135
- const [, path] = nodeEntry;
136
- // Insert 4 spaces for easier remove space
137
- Transforms.insertText(newEditor, ' '.repeat(4), { at: { path: [...path, 0], offset: 0 } });
138
- }
139
- const firstCodeLinePath = nodeEntryList.at(0)[1].concat(0);
140
- const lastCodeLinePath = nodeEntryList.at(-1)[1].concat(0);
141
- const newRange = Editor.range(newEditor, firstCodeLinePath, lastCodeLinePath);
142
- nodeEntryList.length > 1 ? Transforms.select(newEditor, newRange) : Transforms.select(newEditor);
143
- return true;
144
- }
145
-
146
- if (isHotkey('shift+tab', event)) {
147
- event.preventDefault();
148
- // Match the beginning of the line space, delete up to 4 spaces at a time
149
- const originSelection = newEditor.selection;
150
- const matchBeginSpace = /^\s*/;
151
- const nodeEntries = Editor.nodes(newEditor, {
152
- mode: 'lowest',
153
- match: node => node.type === CODE_LINE,
154
- });
155
- const nodeEntryList = Array.from(nodeEntries);
156
- let removedSpaceCount = 0;
157
-
158
- for (const nodeEntry of nodeEntryList) {
159
- const [node, path] = nodeEntry;
160
- const spaceNum = Node.string(node).match(matchBeginSpace);
161
- // skip empty line and no space begining line
162
- if (!spaceNum || !spaceNum[0].length) continue;
163
- const deleteNum = Math.min(spaceNum[0].length, 4);
164
- removedSpaceCount += deleteNum;
165
- for (let i = 0; i < deleteNum; i++) {
166
- Transforms.select(newEditor, { path: [...path, 0], offset: 0 });
167
- Editor.deleteForward(newEditor, { unit: 'character' });
168
- }
169
- }
170
- // Select multiple rows when operating more then one line
171
- // Keep cursor location when operating one line
172
- if (nodeEntryList.length > 1) {
173
- const firstCodeLinePath = nodeEntryList.at(0)[1].concat(0);
174
- const lastCodeLinePath = nodeEntryList.at(-1)[1].concat(0);
175
- const selectLocation = Editor.range(newEditor, firstCodeLinePath, lastCodeLinePath);
176
- Transforms.select(newEditor, selectLocation);
177
- } else {
178
- const { anchor, focus } = originSelection;
179
- const isCollapsed = Range.isCollapsed(originSelection);
180
- if (isCollapsed) {
181
- const selectLocation = { ...originSelection.focus, offset: originSelection.focus.offset - removedSpaceCount };
182
- Transforms.select(newEditor, selectLocation);
183
- } else {
184
- const selectLocation = {
185
- anchor: { ...anchor, offset: anchor.offset - removedSpaceCount },
186
- focus: { ...focus, offset: focus.offset - removedSpaceCount }
187
- };
188
- Transforms.select(newEditor, selectLocation);
189
- }
190
- }
191
- return true;
192
- }
193
-
194
- if (isHotkey('mod+a', event)) {
195
- event.preventDefault();
196
- const codeBlockEntry = Editor.nodes(newEditor, {
197
- mode: 'highest',
198
- match: node => node.type === CODE_BLOCK,
199
- });
200
- if (!codeBlockEntry) return;
201
- const codeBlockEntryList = Array.from(...codeBlockEntry);
202
- Transforms.select(newEditor, codeBlockEntryList[1]);
203
- return true;
204
- }
205
- };
206
-
207
- return newEditor;
208
- };
209
-
210
- export default withCodeBlock;
@@ -1,17 +0,0 @@
1
- // Default language key name
2
- export const EXPLAIN_TEXT = 'none';
3
-
4
- export const LANGUAGE_MAP = {
5
- [EXPLAIN_TEXT]: ' Text',
6
- html: ' HTML',
7
- css: ' CSS',
8
- javascript: ' Javascript',
9
- c: ' C',
10
- cpp: ' C++',
11
- csharp: ' C#',
12
- java: ' Java',
13
- python: ' Python',
14
- sql: ' Sql',
15
- swift: ' Swift',
16
- json: ' JSON'
17
- };
@@ -1,55 +0,0 @@
1
- /* eslint-disable react-hooks/rules-of-hooks */
2
- import React, { useCallback, useEffect, useRef, useState } from 'react';
3
- import { useSlate } from 'slate-react';
4
- import LanguageSelector from './language-selector';
5
- import { isInCodeBlock } from '../helpers';
6
-
7
- const renderCodeBlock = ({ attributes, children, element }) => {
8
- const editor = useSlate();
9
- const [isShowLanguageSelector, setIsShowLanguageSelector] = useState(true);
10
- const codeBlockRef = useRef(null);
11
-
12
- useEffect(() => {
13
- if (isShowLanguageSelector && !isInCodeBlock(editor)) onHideLanguageSelector();
14
- if (!isShowLanguageSelector && isInCodeBlock(editor)) registerEventHandler();
15
- // eslint-disable-next-line react-hooks/exhaustive-deps
16
- }, [editor.selection]);
17
-
18
- const onHideLanguageSelector = useCallback((e) => {
19
- if (codeBlockRef?.current?.contains(e?.target)) return;
20
- setIsShowLanguageSelector(false);
21
- unregisterEventHandler();
22
- // eslint-disable-next-line react-hooks/exhaustive-deps
23
- }, [setIsShowLanguageSelector]);
24
- const registerEventHandler = useCallback(() => {
25
- setIsShowLanguageSelector(true);
26
- document.addEventListener('click', onHideLanguageSelector, true);
27
- }, [onHideLanguageSelector]);
28
-
29
- const unregisterEventHandler = useCallback(() => {
30
- document.removeEventListener('click', onHideLanguageSelector);
31
- }, [onHideLanguageSelector]);
32
-
33
- return (
34
- <div
35
- ref={codeBlockRef}
36
- className='sf-code-block-container'
37
- >
38
- <pre {...attributes}>
39
- <code>{children}</code>
40
- </pre>
41
- {isShowLanguageSelector && <LanguageSelector lang={element.lang} />}
42
- </div>
43
- );
44
- };
45
-
46
- export default renderCodeBlock;
47
-
48
- export const renderCodeLine = (props, editor) => {
49
- const { element, attributes, children } = props;
50
- return (
51
- <div data-id={element.id} {...attributes} className={'sf-code-line'}>
52
- {children}
53
- </div>
54
- );
55
- };
@@ -1,38 +0,0 @@
1
- import React, { useMemo } from 'react';
2
- import { useSlate } from 'slate-react';
3
- import PropTypes from 'prop-types';
4
- import { EXPLAIN_TEXT, LANGUAGE_MAP } from './constant';
5
- import { setCodeBlockLanguage } from '../helpers';
6
-
7
- import './style.css';
8
-
9
- const LanguageSelector = ({ lang = EXPLAIN_TEXT }) => {
10
- const editor = useSlate();
11
- const langOptions = useMemo(() => {
12
- const options = [];
13
- for (const value in LANGUAGE_MAP) {
14
- if (Object.hasOwnProperty.call(LANGUAGE_MAP, value)) {
15
- const name = LANGUAGE_MAP[value];
16
- options.push(<option key={value} value={value}>{name}</option>);
17
- }
18
- }
19
- return options;
20
- }, []);
21
-
22
- return (
23
- <select
24
- name='language'
25
- className='sf-lang-selector'
26
- value={lang}
27
- onChange={e => setCodeBlockLanguage(editor, e.target.value)}
28
- >
29
- {langOptions}
30
- </select>
31
- );
32
- };
33
-
34
- LanguageSelector.propTypes = {
35
- lang: PropTypes.string.isRequired,
36
- };
37
-
38
- export default LanguageSelector;
@@ -1,68 +0,0 @@
1
- import { Editor, Transforms } from 'slate';
2
- import slugid from 'slugid';
3
- import { getNodeType, getSelectedElems } from '../../core/queries';
4
- import { focusEditor } from '../../core/transforms/focus-editor';
5
- import { ELementTypes } from '../../constants';
6
- import { FORMULA } from '../../constants/element-types';
7
- import { generateDefaultText } from '../../core';
8
-
9
- export const isMenuDisabled = (editor, readonly = false) => {
10
- if (readonly) return true;
11
- const { selection } = editor;
12
- if (!selection) return false;
13
- const selectedElems = getSelectedElems(editor);
14
- // Check if the selected element is illegal
15
- const isSelectedIllegalElement = selectedElems.some(elem => {
16
- const { type } = elem;
17
- if (editor.isVoid(elem)) return true;
18
- const unSupportTypes = [
19
- ELementTypes.CODE_BLOCK,
20
- ELementTypes.CODE_LINE,
21
- ELementTypes.TABLE,
22
- ELementTypes.TABLE_CELL,
23
- ELementTypes.TABLE_ROW,
24
- ELementTypes.HEADER1,
25
- ELementTypes.HEADER2,
26
- ELementTypes.HEADER3,
27
- ELementTypes.HEADER4,
28
- ELementTypes.HEADER5,
29
- ELementTypes.HEADER6,
30
- ELementTypes.LIST_ITEM,
31
- ELementTypes.UNORDERED_LIST,
32
- ELementTypes.ORDERED_LIST,
33
- ];
34
- if (unSupportTypes.includes(type)) return true;
35
- return false;
36
- });
37
- if (isSelectedIllegalElement) return true;
38
- return false;
39
- };
40
-
41
- export const isFormulaActive = (editor) => {
42
- return isFormulaType(editor);
43
- };
44
-
45
- export const isFormulaType = (editor) => {
46
- const [match] = Editor.nodes(editor, {
47
- match: n => getNodeType(n) === ELementTypes.FORMULA,
48
- universal: true,
49
- });
50
- return !!match;
51
- };
52
-
53
- export const insertFormula = (editor, data) => {
54
- const formula = {
55
- id: slugid.nice(),
56
- type: FORMULA,
57
- data: { formula: data.formula },
58
- children: [generateDefaultText()],
59
- };
60
- Transforms.insertNodes(editor, formula, { at: data.at, void: true });
61
- focusEditor(editor);
62
- };
63
-
64
- export const updateFormula = (editor, data) => {
65
- const { formula, at } = data;
66
- Transforms.setNodes(editor, { data: { formula } }, { at: at, void: true });
67
- focusEditor(editor);
68
- };
@@ -1,14 +0,0 @@
1
- import { FORMULA } from '../../constants/element-types';
2
- import FormulaMenu from './menu';
3
- import withFormula from './plugin';
4
- import renderFormula from './render-elem';
5
-
6
- const FormulaPlugin = {
7
- type: FORMULA,
8
- nodeType: 'element',
9
- editorMenus: [FormulaMenu],
10
- editorPlugin: withFormula,
11
- renderElements: [renderFormula],
12
- };
13
-
14
- export default FormulaPlugin;
@@ -1,73 +0,0 @@
1
- import React, { useCallback, useEffect, useRef, useState } from 'react';
2
- import { Button, Modal, ModalHeader, ModalBody, ModalFooter, Input } from 'reactstrap';
3
- import { useTranslation } from 'react-i18next';
4
- import { insertFormula, updateFormula } from '../helper';
5
- import { getAboveBlockNode } from '../../../core';
6
-
7
- const FormulaModal = ({ editor, formula, onCloseModal }) => {
8
- const oldFormulaRef = useRef(formula);
9
- const [newFormula, setNewFormula] = useState(formula);
10
- const [modifyPath, setModifyPath] = useState(null);
11
- const [isDisabled, setIsDisabled] = useState(true);
12
- const formulaPreviewRef = useRef(null);
13
- const { t } = useTranslation('seafile-editor');
14
-
15
- // record current selection position
16
- useEffect(() => {
17
- const node = getAboveBlockNode(editor);
18
- if (node) {
19
- setModifyPath(node[1]);
20
- return;
21
- }
22
- // eslint-disable-next-line react-hooks/exhaustive-deps
23
- }, []);
24
-
25
- useEffect(() => {
26
- if (formulaPreviewRef.current) {
27
- formulaPreviewRef.current.innerHTML = '';
28
- const dom = window.MathJax.tex2svg(newFormula);
29
- formulaPreviewRef.current.appendChild(dom);
30
- }
31
- });
32
-
33
- const onFormulaChange = useCallback((event) => {
34
- setIsDisabled(false);
35
- setNewFormula(event.target.value);
36
- }, []);
37
-
38
- const handleUpdateFormula = useCallback(() => {
39
-
40
- const data = { formula: newFormula, at: modifyPath };
41
- if (oldFormulaRef.current) {
42
- updateFormula(editor, data);
43
- } else {
44
- insertFormula(editor, data);
45
- }
46
- onCloseModal();
47
- }, [editor, modifyPath, newFormula, onCloseModal]);
48
-
49
- return (
50
- <Modal isOpen={true} toggle={onCloseModal} autoFocus={false} wrapClassName='formula-dialog-wrapper'>
51
- <ModalHeader toggle={onCloseModal}>{t('insert_formula')}</ModalHeader>
52
- <ModalBody>
53
- <div className="form-group">
54
- <label className="form-check-label">{t('Formula')}</label>
55
- <Input
56
- type="textarea"
57
- className="form-control"
58
- value={newFormula}
59
- autoFocus={true}
60
- onChange={onFormulaChange}
61
- />
62
- </div>
63
- <div ref={formulaPreviewRef} className="formula-preview"></div>
64
- </ModalBody>
65
- <ModalFooter>
66
- <Button color="secondary" onClick={onCloseModal}>{t('Cancel')}</Button>
67
- <Button color="primary" disabled={isDisabled} onClick={handleUpdateFormula}>{t('Insert_formula')}</Button>
68
- </ModalFooter>
69
- </Modal>
70
- );
71
- };
72
-
73
- export default FormulaModal;
@@ -1,63 +0,0 @@
1
- import React, { useCallback, useEffect, useMemo, useState } from 'react';
2
- import { INTERNAL_EVENTS } from '../../../../constants/event-types';
3
- import { MENUS_CONFIG_MAP } from '../../../constants/menus-config';
4
- import { FORMULA } from '../../../constants/element-types';
5
- import MenuItem from '../../../commons/menu/menu-item';
6
- import { isFormulaActive, isMenuDisabled } from '../helper';
7
- import EventBus from '../../../../utils/event-bus';
8
- import FormulaModal from './formula-modal';
9
-
10
- const menuConfig = MENUS_CONFIG_MAP[FORMULA];
11
-
12
- const FormulaMenu = ({ isRichEditor, className, readonly, editor }) => {
13
- const [isOpenFormulaModal, setIsOpenFormulaModal] = useState(false);
14
- const [formula, setFormula] = useState('');
15
- // eslint-disable-next-line react-hooks/exhaustive-deps
16
- const isMenuActive = useMemo(() => isFormulaActive(editor), [editor.selection]);
17
-
18
- useEffect(() => {
19
- const eventBus = EventBus.getInstance();
20
- const unsubscribe = eventBus.subscribe(INTERNAL_EVENTS.ON_OPEN_FORMULA_DIALOG, handleOpenLinkModal);
21
- return () => unsubscribe();
22
- // eslint-disable-next-line react-hooks/exhaustive-deps
23
- }, []);
24
-
25
- const onMouseDown = useCallback(() => {
26
- setIsOpenFormulaModal(true);
27
- }, []);
28
-
29
- const handleOpenLinkModal = useCallback((formulaElement) => {
30
- if (formulaElement) {
31
- const { formula } = formulaElement.data || {};
32
- setFormula(formula);
33
- setIsOpenFormulaModal(true);
34
- }
35
- }, []);
36
-
37
- const onCloseModal = useCallback(() => {
38
- setIsOpenFormulaModal(false);
39
- setFormula('');
40
- }, []);
41
-
42
- return (
43
- <>
44
- <MenuItem
45
- isRichEditor={isRichEditor}
46
- className={className}
47
- disabled={isMenuDisabled(editor, readonly)}
48
- isActive={isMenuActive}
49
- onMouseDown={onMouseDown}
50
- {...menuConfig}
51
- />
52
- {isOpenFormulaModal && (
53
- <FormulaModal
54
- editor={editor}
55
- formula={formula}
56
- onCloseModal={onCloseModal}
57
- />
58
- )}
59
- </>
60
- );
61
- };
62
-
63
- export default FormulaMenu;
@@ -1,18 +0,0 @@
1
- import { ELementTypes } from '../../constants';
2
-
3
- const withFormula = (editor) => {
4
- const { isVoid } = editor;
5
- const newEditor = editor;
6
-
7
-
8
- newEditor.isVoid = (element) => {
9
- const { type } = element;
10
-
11
- if (type === ELementTypes.FORMULA) return true;
12
- return isVoid(element);
13
- };
14
-
15
- return newEditor;
16
- };
17
-
18
- export default withFormula;
@@ -1,40 +0,0 @@
1
- import React, { useCallback, useEffect, useRef } from 'react';
2
- import { useSelected } from 'slate-react';
3
- import { INTERNAL_EVENTS } from '../../../constants/event-types';
4
- import EventBus from '../../../utils/event-bus';
5
-
6
- import './formula.css';
7
-
8
- const Formula = ({ attributes, element, children }) => {
9
-
10
- const isSelected = useSelected();
11
- const formulaContainerRef = useRef(null);
12
-
13
- useEffect(() => {
14
- const { formula = '' } = element.data || {};
15
- if (!formula) return;
16
- if (formulaContainerRef.current && window.MathJax) {
17
- formulaContainerRef.current.innerHTML = '';
18
- const dom = window.MathJax.tex2svg(formula);
19
- formulaContainerRef.current.appendChild(dom);
20
- }
21
- }, [element]);
22
-
23
- const toggleFormulaEditor = useCallback(() => {
24
- const eventBus = EventBus.getInstance();
25
- eventBus.dispatch(INTERNAL_EVENTS.ON_OPEN_FORMULA_DIALOG, element);
26
- }, [element]);
27
-
28
- return (
29
- <span onDoubleClick={toggleFormulaEditor} className={'sf-block-formula ' + (isSelected ? ' sf-selected-formula' : '')} {...attributes}>
30
- <span contentEditable={false} ref={formulaContainerRef}></span>
31
- <span contentEditable={false}>{children}</span>
32
- </span>
33
- );
34
- };
35
-
36
- const renderFormula = (props) => {
37
- return <Formula {...props} />;
38
- };
39
-
40
- export default renderFormula;
@@ -1,47 +0,0 @@
1
- import { Editor, Transforms } from 'slate';
2
- import { getNodeType, getParentNode, isTextNode } from '../../core/queries';
3
- import { ELementTypes } from '../../constants';
4
- import { focusEditor } from '../../core';
5
-
6
- export const isMenuDisabled = (editor, readonly = false) => {
7
- if (readonly) return true;
8
- if (!editor.selection) return true;
9
- const [match] = Editor.nodes(
10
- editor,
11
- {
12
- match(node, path) {
13
- let type = getNodeType(node);
14
- if (!type && isTextNode(node) && node.id) {
15
- const parentNode = getParentNode(node, node.id);
16
- type = getNodeType(parentNode);
17
- }
18
- if (type === ELementTypes.PARAGRAPH) return true;
19
- if (type.startsWith(ELementTypes.HEADER)) return true;
20
- return false;
21
- },
22
- universal: true,
23
- mode: 'highest',
24
- },
25
- );
26
- return !match;
27
- };
28
-
29
- export const getHeaderType = (editor) => {
30
- const [match] = Editor.nodes(editor, {
31
- match: node => {
32
- const nodeType = getNodeType(node);
33
- if (nodeType.includes(ELementTypes.HEADER)) return true;
34
- return false;
35
- },
36
- universal: true,
37
- });
38
- if (!match) return;
39
- const [matchedNode] = match;
40
- return getNodeType(matchedNode);
41
- };
42
-
43
- export const setHeaderType = (editor, type) => {
44
- if (!type) return;
45
- Transforms.setNodes(editor, { type });
46
- focusEditor(editor);
47
- };
@@ -1,14 +0,0 @@
1
- import { ELementTypes } from '../../constants';
2
- import { renderHeader } from './render-elem';
3
- import withHeader from './plugin';
4
- import HeaderMenu from './menu';
5
-
6
- const HeaderPlugin = {
7
- type: ELementTypes.HEADER,
8
- nodeType: 'element',
9
- editorMenus: [HeaderMenu],
10
- editorPlugin: withHeader,
11
- renderElements: [renderHeader],
12
- };
13
-
14
- export default HeaderPlugin;