@seafile/seafile-editor 0.4.8 → 1.0.0

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 (441) hide show
  1. package/.babelrc +5 -0
  2. package/.eslintignore +19 -0
  3. package/.eslintrc.json +52 -0
  4. package/.github/workflows/nodejs.yml +25 -0
  5. package/.vscode/settings.json +5 -0
  6. package/config/config.common.js +157 -0
  7. package/config/config.dev.js +53 -0
  8. package/config/jest/cssTransform.js +16 -0
  9. package/config/jest/fileTransform.js +40 -0
  10. package/config/utils/theme.css.js +103 -0
  11. package/config.js +61 -0
  12. package/dev-server.js +145 -0
  13. package/jest.config.js +16 -0
  14. package/package.json +81 -131
  15. package/public/locales/en/seafile-editor.json +145 -148
  16. package/public/locales/zh-CN/seafile-editor.json +123 -135
  17. package/public/media/seafile-ui.css +6 -11166
  18. package/scripts/ejs.js +16 -0
  19. package/site/_i18n/index.js +35 -0
  20. package/site/api/index.js +212 -0
  21. package/site/app.js +21 -0
  22. package/site/assets/css/app.css +47 -0
  23. package/site/assets/css/seafile-editor.css +33 -0
  24. package/site/commons/loading/index.js +14 -0
  25. package/site/commons/loading/style.css +49 -0
  26. package/site/commons/switch/index.css +14 -0
  27. package/site/commons/switch/index.js +37 -0
  28. package/site/commons/toast/alert.js +106 -0
  29. package/site/commons/toast/index.js +5 -0
  30. package/site/commons/toast/toast.js +195 -0
  31. package/site/commons/toast/toastManager.js +138 -0
  32. package/site/commons/toast/toaster.js +64 -0
  33. package/site/index.html +23 -0
  34. package/site/index.js +21 -0
  35. package/site/pages/home.js +21 -0
  36. package/site/pages/plain-markdown-view.js +6 -0
  37. package/site/pages/rich-seafile-editor.js +72 -0
  38. package/site/pages/seafile-editor.js +39 -0
  39. package/site/pages/seafile-viewer.js +45 -0
  40. package/site/pages/simple-editor.js +44 -0
  41. package/site/pages/wiki-viewer.js +7 -0
  42. package/site/setting.js +36 -0
  43. package/site/setting.local.dist.js +23 -0
  44. package/src/assets/css/slate-editor.css +57 -0
  45. package/src/constants/event-types.js +11 -0
  46. package/src/constants/hot-keys.js +47 -0
  47. package/src/containers/article-info/index.js +49 -0
  48. package/src/containers/article-info/style.css +52 -0
  49. package/src/containers/custom/get-event-transfer.js +28 -0
  50. package/{dist → src}/containers/custom/set-event-transfer.js +13 -11
  51. package/src/containers/hotkeys-helper/classify-hotkeys.js +30 -0
  52. package/src/containers/hotkeys-helper/index.js +43 -0
  53. package/{dist/assets/css/user-help.css → src/containers/hotkeys-helper/style.css} +37 -29
  54. package/src/containers/loading/index.js +14 -0
  55. package/src/containers/loading/style.css +49 -0
  56. package/src/containers/outline/index.js +75 -0
  57. package/src/containers/outline/outline-item.js +28 -0
  58. package/src/containers/outline/style.css +45 -0
  59. package/src/editors/plain-markdown-editor/code-mirror.css +8 -0
  60. package/src/editors/plain-markdown-editor/code-mirror.js +73 -0
  61. package/src/editors/plain-markdown-editor/index.js +136 -0
  62. package/{dist/assets/editor/plain-editor.css → src/editors/plain-markdown-editor/style.css} +12 -4
  63. package/src/editors/simple-slate-editor /index.js +71 -0
  64. package/src/editors/simple-slate-editor /with-props-editor.js +15 -0
  65. package/src/editors/slate-editor/editor-help/index.js +46 -0
  66. package/src/editors/slate-editor/editor-help/style.css +15 -0
  67. package/src/editors/slate-editor/index.js +77 -0
  68. package/src/editors/slate-editor/with-props-editor.js +15 -0
  69. package/src/editors/slate-viewer/index.js +35 -0
  70. package/src/editors/slate-viewer/style.css +40 -0
  71. package/src/extension/commons/element-popover/index.js +52 -0
  72. package/src/extension/commons/index.js +10 -0
  73. package/src/extension/commons/menu/index.js +9 -0
  74. package/src/extension/commons/menu/menu-drop-down.js +110 -0
  75. package/src/extension/commons/menu/menu-group.js +20 -0
  76. package/src/extension/commons/menu/menu-item.js +60 -0
  77. package/src/extension/commons/menu/menu.css +120 -0
  78. package/src/extension/commons/tooltip/index.css +21 -0
  79. package/src/extension/commons/tooltip/index.js +26 -0
  80. package/src/extension/constants/element-types.js +23 -0
  81. package/src/extension/constants/index.js +37 -0
  82. package/src/extension/constants/keyboard.js +29 -0
  83. package/src/extension/constants/menus-config.js +149 -0
  84. package/src/extension/core/index.js +3 -0
  85. package/src/extension/core/queries/index.js +410 -0
  86. package/src/extension/core/transforms/focus-editor.js +12 -0
  87. package/src/extension/core/transforms/index.js +4 -0
  88. package/src/extension/core/transforms/move-children.js +23 -0
  89. package/src/extension/core/transforms/remove-node-children.js +8 -0
  90. package/src/extension/core/transforms/replace-node-children.js +14 -0
  91. package/src/extension/core/utils/index.js +76 -0
  92. package/src/extension/editor.js +14 -0
  93. package/src/extension/index.js +15 -0
  94. package/src/extension/plugins/blockquote/helpers.js +65 -0
  95. package/src/extension/plugins/blockquote/index.js +13 -0
  96. package/src/extension/plugins/blockquote/menu/index.js +31 -0
  97. package/src/extension/plugins/blockquote/plugin.js +64 -0
  98. package/src/extension/plugins/blockquote/render-elem.js +9 -0
  99. package/src/extension/plugins/check-list/helper.js +34 -0
  100. package/src/extension/plugins/check-list/index.js +14 -0
  101. package/src/extension/plugins/check-list/menu/index.js +44 -0
  102. package/src/extension/plugins/check-list/plugin.js +46 -0
  103. package/src/extension/plugins/check-list/render-elem.js +23 -0
  104. package/src/extension/plugins/clear-format/helpers.js +48 -0
  105. package/src/extension/plugins/clear-format/menu/index.js +39 -0
  106. package/src/extension/plugins/code-block/helpers.js +107 -0
  107. package/src/extension/plugins/code-block/index.js +14 -0
  108. package/src/extension/plugins/code-block/menu/index.js +40 -0
  109. package/src/extension/plugins/code-block/plugin.js +210 -0
  110. package/src/extension/plugins/code-block/render-elem/constant.js +17 -0
  111. package/src/extension/plugins/code-block/render-elem/index.js +55 -0
  112. package/src/extension/plugins/code-block/render-elem/language-selector.js +38 -0
  113. package/src/extension/plugins/code-block/render-elem/style.css +27 -0
  114. package/src/extension/plugins/formula/formula.css +22 -0
  115. package/src/extension/plugins/formula/helper.js +68 -0
  116. package/src/extension/plugins/formula/index.js +14 -0
  117. package/src/extension/plugins/formula/menu/formula-modal.js +73 -0
  118. package/src/extension/plugins/formula/menu/index.js +63 -0
  119. package/src/extension/plugins/formula/plugin.js +18 -0
  120. package/src/extension/plugins/formula/render-elem.js +40 -0
  121. package/src/extension/plugins/header/helper.js +47 -0
  122. package/src/extension/plugins/header/index.js +14 -0
  123. package/src/extension/plugins/header/menu/index.js +114 -0
  124. package/src/extension/plugins/header/menu/style.css +115 -0
  125. package/src/extension/plugins/header/plugin.js +134 -0
  126. package/src/extension/plugins/header/render-elem.js +31 -0
  127. package/src/extension/plugins/image/helper.js +50 -0
  128. package/src/extension/plugins/image/index.js +14 -0
  129. package/src/extension/plugins/image/menu/image-menu-dialog.js +68 -0
  130. package/src/extension/plugins/image/menu/image-menu-popover.js +76 -0
  131. package/src/extension/plugins/image/menu/index.js +61 -0
  132. package/src/extension/plugins/image/menu/style.css +36 -0
  133. package/src/extension/plugins/image/plugin.js +23 -0
  134. package/src/extension/plugins/image/render-element/image-previewer.js +71 -0
  135. package/src/extension/plugins/image/render-element/index.js +94 -0
  136. package/src/extension/plugins/image/render-element/style.css +60 -0
  137. package/src/extension/plugins/index.js +47 -0
  138. package/src/extension/plugins/link/helper.js +161 -0
  139. package/src/extension/plugins/link/index.js +14 -0
  140. package/src/extension/plugins/link/menu/index.js +82 -0
  141. package/src/extension/plugins/link/menu/link-modal.js +135 -0
  142. package/src/extension/plugins/link/plugin.js +85 -0
  143. package/src/extension/plugins/link/render-elem/index.js +69 -0
  144. package/src/extension/plugins/link/render-elem/link-popover.js +79 -0
  145. package/src/extension/plugins/link/render-elem/style.css +60 -0
  146. package/src/extension/plugins/list/constant.js +3 -0
  147. package/src/extension/plugins/list/helpers.js +53 -0
  148. package/src/extension/plugins/list/index.js +14 -0
  149. package/src/extension/plugins/list/menu/index.js +48 -0
  150. package/src/extension/plugins/list/plugin/index.js +48 -0
  151. package/src/extension/plugins/list/plugin/insert-break-list.js +25 -0
  152. package/src/extension/plugins/list/plugin/insert-fragment-list.js +162 -0
  153. package/src/extension/plugins/list/plugin/normalize-list.js +64 -0
  154. package/src/extension/plugins/list/plugin/on-tab-handle.js +34 -0
  155. package/src/extension/plugins/list/queries/index.js +39 -0
  156. package/src/extension/plugins/list/render-elem/index.js +26 -0
  157. package/src/extension/plugins/list/render-elem/style.css +6 -0
  158. package/src/extension/plugins/list/transforms/index.js +23 -0
  159. package/src/extension/plugins/list/transforms/insert-list-item.js +65 -0
  160. package/src/extension/plugins/list/transforms/move-list-item-down.js +40 -0
  161. package/src/extension/plugins/list/transforms/move-list-item-up.js +105 -0
  162. package/src/extension/plugins/list/transforms/move-list-items-to-list.js +58 -0
  163. package/src/extension/plugins/list/transforms/move-list-items.js +76 -0
  164. package/src/extension/plugins/list/transforms/normalize-list-item.js +92 -0
  165. package/src/extension/plugins/list/transforms/normalize-nested-list.js +31 -0
  166. package/src/extension/plugins/list/transforms/remove-first-list-item.js +11 -0
  167. package/src/extension/plugins/list/transforms/transforms-to-list.js +91 -0
  168. package/src/extension/plugins/list/transforms/unwrap-list.js +44 -0
  169. package/src/extension/plugins/node-id/constants.js +18 -0
  170. package/src/extension/plugins/node-id/helpers.js +61 -0
  171. package/src/extension/plugins/node-id/index.js +7 -0
  172. package/src/extension/plugins/node-id/with-node-id.js +37 -0
  173. package/src/extension/plugins/paragraph/helper.js +9 -0
  174. package/src/extension/plugins/paragraph/index.js +12 -0
  175. package/src/extension/plugins/paragraph/plugin.js +40 -0
  176. package/src/extension/plugins/paragraph/render-elem.js +11 -0
  177. package/src/extension/plugins/table/constant.js +3 -0
  178. package/src/extension/plugins/table/helper.js +175 -0
  179. package/src/extension/plugins/table/index.js +15 -0
  180. package/src/extension/plugins/table/menu/index.js +69 -0
  181. package/src/extension/plugins/table/menu/style.css +32 -0
  182. package/src/extension/plugins/table/menu/table-operator.js +101 -0
  183. package/src/extension/plugins/table/menu/table-size-selector.js +71 -0
  184. package/src/extension/plugins/table/model.js +69 -0
  185. package/src/extension/plugins/table/plugin.js +159 -0
  186. package/src/extension/plugins/table/render-elem/context-menu.js +78 -0
  187. package/src/extension/plugins/table/render-elem/index.js +157 -0
  188. package/src/extension/plugins/table/render-elem/style.css +94 -0
  189. package/src/extension/plugins/table/table-operations.js +162 -0
  190. package/src/extension/plugins/text-style/helpers.js +38 -0
  191. package/src/extension/plugins/text-style/index.js +12 -0
  192. package/src/extension/plugins/text-style/menu/index.js +41 -0
  193. package/src/extension/plugins/text-style/plugin.js +37 -0
  194. package/src/extension/plugins/text-style/render-elem.js +45 -0
  195. package/src/extension/render/render-element.js +82 -0
  196. package/src/extension/render/render-leaf.js +16 -0
  197. package/src/extension/toolbar/header-toolbar/index.js +129 -0
  198. package/src/extension/toolbar/header-toolbar/style.css +41 -0
  199. package/src/extension/toolbar/index.js +5 -0
  200. package/src/extension/toolbar/user-help/shortcut-dialog.js +144 -0
  201. package/src/hooks/use-mathjax.js +44 -0
  202. package/src/hooks/use-scroll-context.js +14 -0
  203. package/src/hooks/use-selection-update.js +14 -0
  204. package/src/index.js +22 -0
  205. package/src/pages/markdown-editor.js +53 -0
  206. package/src/pages/markdown-view.js +36 -0
  207. package/src/pages/rich-markdown-editor.js +95 -0
  208. package/src/pages/simple-editor.js +52 -0
  209. package/src/slate-convert/html-to-slate/constants.js +54 -0
  210. package/src/slate-convert/html-to-slate/helper.js +22 -0
  211. package/src/slate-convert/html-to-slate/index.js +144 -0
  212. package/src/slate-convert/html-to-slate/rules/blockquote.js +16 -0
  213. package/src/slate-convert/html-to-slate/rules/check-list.js +22 -0
  214. package/src/slate-convert/html-to-slate/rules/code-block.js +91 -0
  215. package/src/slate-convert/html-to-slate/rules/header.js +18 -0
  216. package/src/slate-convert/html-to-slate/rules/image.js +18 -0
  217. package/src/slate-convert/html-to-slate/rules/index.js +23 -0
  218. package/src/slate-convert/html-to-slate/rules/link.js +24 -0
  219. package/src/slate-convert/html-to-slate/rules/list.js +52 -0
  220. package/src/slate-convert/html-to-slate/rules/paragraph.js +16 -0
  221. package/src/slate-convert/html-to-slate/rules/table.js +37 -0
  222. package/src/slate-convert/html-to-slate/rules/text.js +63 -0
  223. package/src/slate-convert/index.js +11 -0
  224. package/src/slate-convert/md-to-html/index.js +44 -0
  225. package/src/slate-convert/md-to-html/sanitize-schema.js +41 -0
  226. package/src/slate-convert/md-to-slate/index.js +42 -0
  227. package/src/slate-convert/md-to-slate/transform.js +336 -0
  228. package/src/slate-convert/slate-to-md/index.js +44 -0
  229. package/src/slate-convert/slate-to-md/transform.js +248 -0
  230. package/src/utils/common.js +30 -0
  231. package/src/utils/deserialize-html.js +174 -0
  232. package/src/utils/dom-utils.js +45 -0
  233. package/src/utils/event-bus.js +37 -0
  234. package/src/utils/event-handler.js +36 -0
  235. package/src/utils/object-utils.js +51 -0
  236. package/tests/core/constants/index.js +54 -0
  237. package/tests/core/index.js +11 -0
  238. package/tests/core/jsx/index.js +9 -0
  239. package/tests/core/stub-editor/index.js +26 -0
  240. package/tests/core/utils.js +58 -0
  241. package/tests/extension/plugins/list/insert-block.test.js +40 -0
  242. package/tests/extension/plugins/list/insert-fragment-list.test.js +392 -0
  243. package/tests/extension/plugins/list/toggle-list.test.js +160 -0
  244. package/tests/extension/plugins/text/text.test.js +29 -0
  245. package/tests/extension/plugins/text-style/toggle-text-style.test.js +148 -0
  246. package/tests/slate-convert/html-to-slate/blockquote.test.js +107 -0
  247. package/tests/slate-convert/html-to-slate/code-block.test.js +32 -0
  248. package/tests/slate-convert/html-to-slate/header.test.js +56 -0
  249. package/tests/slate-convert/html-to-slate/link.test.js +77 -0
  250. package/tests/slate-convert/html-to-slate/list.test.js +190 -0
  251. package/tests/slate-convert/html-to-slate/paragraph.test.js +40 -0
  252. package/tests/slate-convert/html-to-slate/text.test.js +131 -0
  253. package/tests/slate-convert/md-to-html/blockquote.test.js +110 -0
  254. package/tests/slate-convert/md-to-html/check-list.test.js +19 -0
  255. package/tests/slate-convert/md-to-html/code-block.test.js +19 -0
  256. package/tests/slate-convert/md-to-html/header.test.js +20 -0
  257. package/tests/slate-convert/md-to-html/image.test.js +17 -0
  258. package/tests/slate-convert/md-to-html/image_reference.test.js +17 -0
  259. package/tests/slate-convert/md-to-html/link.test.js +15 -0
  260. package/tests/slate-convert/md-to-html/link_reference.test.js +15 -0
  261. package/tests/slate-convert/md-to-html/list-ordered.test.js +22 -0
  262. package/tests/slate-convert/md-to-html/list-unordered.test.js +22 -0
  263. package/tests/slate-convert/md-to-html/paragraph.test.js +15 -0
  264. package/tests/slate-convert/md-to-html/table.test.js +29 -0
  265. package/tests/slate-convert/md-to-html/text_base.test.js +14 -0
  266. package/tests/slate-convert/md-to-html/text_bold.test.js +14 -0
  267. package/tests/slate-convert/md-to-html/text_bold_italic.test.js +15 -0
  268. package/tests/slate-convert/md-to-html/text_code.test.js +14 -0
  269. package/tests/slate-convert/md-to-html/text_code_bold.test.js +14 -0
  270. package/tests/slate-convert/md-to-html/text_code_bold_italic.test.js +14 -0
  271. package/tests/slate-convert/md-to-html/text_code_italic.test.js +14 -0
  272. package/tests/slate-convert/md-to-html/text_italic.test.js +14 -0
  273. package/tests/slate-convert/md-to-slate/blockquote.test.js +200 -0
  274. package/tests/slate-convert/md-to-slate/check-list.test.js +34 -0
  275. package/tests/slate-convert/md-to-slate/code-block.test.js +32 -0
  276. package/tests/slate-convert/md-to-slate/header.test.js +49 -0
  277. package/tests/slate-convert/md-to-slate/image.test.js +31 -0
  278. package/tests/slate-convert/md-to-slate/link.test.js +30 -0
  279. package/tests/slate-convert/md-to-slate/list-ordered.test.js +42 -0
  280. package/tests/slate-convert/md-to-slate/list-unordered.test.js +42 -0
  281. package/tests/slate-convert/md-to-slate/paragraph.test.js +19 -0
  282. package/tests/slate-convert/md-to-slate/table.test.js +34 -0
  283. package/tests/slate-convert/md-to-slate/text_base.test.js +19 -0
  284. package/tests/slate-convert/md-to-slate/text_bold.test.js +22 -0
  285. package/tests/slate-convert/md-to-slate/text_bold_italic.test.js +23 -0
  286. package/tests/slate-convert/md-to-slate/text_code.test.js +22 -0
  287. package/tests/slate-convert/md-to-slate/text_code_bold.test.js +23 -0
  288. package/tests/slate-convert/md-to-slate/text_code_bold_italic.test.js +24 -0
  289. package/tests/slate-convert/md-to-slate/text_code_italic.test.js +23 -0
  290. package/tests/slate-convert/md-to-slate/text_italic.test.js +22 -0
  291. package/tests/slate-convert/slate-to-md/blockquote.test.js +416 -0
  292. package/tests/slate-convert/slate-to-md/check-list.test.js +96 -0
  293. package/tests/slate-convert/slate-to-md/code-block.test.js +35 -0
  294. package/tests/slate-convert/slate-to-md/formula.test.js +26 -0
  295. package/tests/slate-convert/slate-to-md/header.test.js +109 -0
  296. package/tests/slate-convert/slate-to-md/image.test.js +98 -0
  297. package/tests/slate-convert/slate-to-md/link.test.js +52 -0
  298. package/tests/slate-convert/slate-to-md/list-ordered.test.js +87 -0
  299. package/tests/slate-convert/slate-to-md/list-unordered.test.js +81 -0
  300. package/tests/slate-convert/slate-to-md/paragraph.test.js +28 -0
  301. package/tests/slate-convert/slate-to-md/table.test.js +56 -0
  302. package/tests/slate-convert/slate-to-md/text_base.test.js +28 -0
  303. package/tests/slate-convert/slate-to-md/text_bold.test.js +36 -0
  304. package/tests/slate-convert/slate-to-md/text_bold_italic.test.js +42 -0
  305. package/tests/slate-convert/slate-to-md/text_code.test.js +31 -0
  306. package/tests/slate-convert/slate-to-md/text_code_bold.test.js +37 -0
  307. package/tests/slate-convert/slate-to-md/text_code_bold_italic.test.js +43 -0
  308. package/tests/slate-convert/slate-to-md/text_code_italic.test.js +37 -0
  309. package/tests/slate-convert/slate-to-md/text_italic.test.js +36 -0
  310. package/README.md +0 -52
  311. package/TODO.md +0 -55
  312. package/dist/assets/css/diff-viewer.css +0 -105
  313. package/dist/assets/css/formula.css +0 -19
  314. package/dist/assets/css/history-viewer.css +0 -104
  315. package/dist/assets/css/image.css +0 -134
  316. package/dist/assets/css/link.css +0 -7
  317. package/dist/assets/css/markdown-editor.css +0 -12
  318. package/dist/assets/css/markdown-viewer.css +0 -69
  319. package/dist/assets/css/navbar-imgbutton.css +0 -83
  320. package/dist/assets/css/outline.css +0 -29
  321. package/dist/assets/css/table.css +0 -57
  322. package/dist/assets/css/textlink-hovermenu.css +0 -47
  323. package/dist/assets/css/topbar.css +0 -350
  324. package/dist/assets/css/tree-view.css +0 -67
  325. package/dist/assets/editor/seatable-editor.css +0 -77
  326. package/dist/assets/editor/simple-editor.css +0 -77
  327. package/dist/components/click-outside.js +0 -46
  328. package/dist/components/context-menu.js +0 -97
  329. package/dist/components/dialogs/add-formula-dialog.js +0 -116
  330. package/dist/components/dialogs/add-image-dialog.js +0 -69
  331. package/dist/components/dialogs/add-link-dialog.js +0 -133
  332. package/dist/components/dialogs/shortcut-dialog.js +0 -131
  333. package/dist/components/error-boundary.js +0 -28
  334. package/dist/components/load-script/index.js +0 -69
  335. package/dist/components/loading.js +0 -25
  336. package/dist/components/menu/index.js +0 -4
  337. package/dist/components/menu/item.js +0 -49
  338. package/dist/components/menu/menu.js +0 -38
  339. package/dist/components/menu/style.css +0 -42
  340. package/dist/components/modal-portal.js +0 -38
  341. package/dist/components/outline/index.js +0 -92
  342. package/dist/components/outline/outline-item.js +0 -58
  343. package/dist/components/select/_option.js +0 -44
  344. package/dist/components/select/field-setting.js +0 -106
  345. package/dist/components/select/index.js +0 -149
  346. package/dist/components/select/style.css +0 -144
  347. package/dist/components/svg-icons/check-mark-icon.js +0 -14
  348. package/dist/components/svg-icons/column-icon.js +0 -17
  349. package/dist/components/svg-icons/text-icon.js +0 -34
  350. package/dist/components/text-link-hover-menu/index.js +0 -123
  351. package/dist/components/toast/alert.js +0 -138
  352. package/dist/components/toast/index.js +0 -3
  353. package/dist/components/toast/toast.js +0 -159
  354. package/dist/components/toast/toastManager.js +0 -139
  355. package/dist/components/toast/toaster.js +0 -65
  356. package/dist/components/toolbar/header-list.js +0 -114
  357. package/dist/components/toolbar/help-group.js +0 -33
  358. package/dist/components/toolbar/index.js +0 -4
  359. package/dist/components/toolbar/insert-image.js +0 -106
  360. package/dist/components/toolbar/insert-table.js +0 -136
  361. package/dist/components/toolbar/table-group.js +0 -74
  362. package/dist/components/toolbar/toolbar.js +0 -317
  363. package/dist/components/toolbar/widgets/button-group.js +0 -24
  364. package/dist/components/toolbar/widgets/button-item.js +0 -129
  365. package/dist/components/toolbar/widgets/drop-list.js +0 -88
  366. package/dist/components/user-help/index.js +0 -179
  367. package/dist/config.js +0 -15
  368. package/dist/constants/cell-types.js +0 -29
  369. package/dist/constants/column.js +0 -4
  370. package/dist/containers/code-highlight-package.js +0 -14
  371. package/dist/containers/controller/block-element-controller.js +0 -375
  372. package/dist/containers/controller/index.js +0 -5
  373. package/dist/containers/controller/inline-element-controller.js +0 -134
  374. package/dist/containers/controller/normalize-controller.js +0 -95
  375. package/dist/containers/controller/shortcut-controller.js +0 -385
  376. package/dist/containers/controller/void-element-controller.js +0 -9
  377. package/dist/containers/custom/custom.js +0 -18
  378. package/dist/containers/custom/get-event-transfer.js +0 -33
  379. package/dist/containers/custom/getNodesByTypeAtRange.js +0 -57
  380. package/dist/containers/custom/insertNodes.js +0 -120
  381. package/dist/containers/custom/is-empty-paragraph.js +0 -9
  382. package/dist/containers/custom/split-nodes-at-point.js +0 -136
  383. package/dist/containers/custom/unwrap-node-by-type-at-range.js +0 -70
  384. package/dist/containers/editor-context.js +0 -85
  385. package/dist/containers/editor-utils/block-element-utils/blockquote-utils.js +0 -80
  386. package/dist/containers/editor-utils/block-element-utils/code-utils.js +0 -145
  387. package/dist/containers/editor-utils/block-element-utils/formula-utils.js +0 -51
  388. package/dist/containers/editor-utils/block-element-utils/index.js +0 -31
  389. package/dist/containers/editor-utils/block-element-utils/list-utils.js +0 -395
  390. package/dist/containers/editor-utils/block-element-utils/table-utils.js +0 -412
  391. package/dist/containers/editor-utils/clear-format-utils.js +0 -84
  392. package/dist/containers/editor-utils/common-editor-utils.js +0 -492
  393. package/dist/containers/editor-utils/inline-element-utils/index.js +0 -95
  394. package/dist/containers/editor-utils/mark-utils.js +0 -20
  395. package/dist/containers/editor-utils/range-utils.js +0 -7
  396. package/dist/containers/editor-utils/selection-utils.js +0 -30
  397. package/dist/containers/editor-utils/text-utils.js +0 -117
  398. package/dist/containers/editor-widgets/check-list-item.js +0 -53
  399. package/dist/containers/editor-widgets/code-block.js +0 -128
  400. package/dist/containers/editor-widgets/column.js +0 -100
  401. package/dist/containers/editor-widgets/formula.js +0 -67
  402. package/dist/containers/editor-widgets/image.js +0 -237
  403. package/dist/containers/editor-widgets/link.js +0 -9
  404. package/dist/containers/editor-widgets/table.js +0 -144
  405. package/dist/containers/element-model/blockquote.js +0 -13
  406. package/dist/containers/element-model/column.js +0 -19
  407. package/dist/containers/element-model/image.js +0 -16
  408. package/dist/containers/element-model/link.js +0 -16
  409. package/dist/containers/element-model/table.js +0 -57
  410. package/dist/containers/element-model/text.js +0 -10
  411. package/dist/containers/render-utils/common-utils.js +0 -80
  412. package/dist/containers/render-utils/editor-utils.js +0 -133
  413. package/dist/containers/render-utils/viewer-utils.js +0 -198
  414. package/dist/containers/viewer-widgets/viewer-formula/index.js +0 -54
  415. package/dist/containers/viewer-widgets/viewer-image/index.js +0 -70
  416. package/dist/containers/viewer-widgets/viewer-image/viewer-image.css +0 -3
  417. package/dist/editors/index.js +0 -78
  418. package/dist/editors/markdown-editor.js +0 -206
  419. package/dist/editors/plain-markdown-editor.js +0 -285
  420. package/dist/editors/seatable-editor.js +0 -210
  421. package/dist/editors/simple-editor.js +0 -200
  422. package/dist/index.js +0 -11
  423. package/dist/setting.local.js +0 -14
  424. package/dist/utils/deserialize-html.js +0 -260
  425. package/dist/utils/diff/compare-strings.js +0 -35
  426. package/dist/utils/diff/diff.js +0 -769
  427. package/dist/utils/diff/index.js +0 -2
  428. package/dist/utils/seafile-markdown2html.js +0 -52
  429. package/dist/utils/slate2markdown/deserialize.js +0 -588
  430. package/dist/utils/slate2markdown/index.js +0 -3
  431. package/dist/utils/slate2markdown/serialize.js +0 -366
  432. package/dist/utils/utils.js +0 -68
  433. package/dist/viewer/diff-viewer.js +0 -85
  434. package/dist/viewer/index.js +0 -4
  435. package/dist/viewer/markdown-viewer.js +0 -121
  436. package/dist/viewer/seatable-viewer.js +0 -63
  437. package/dist/viewer/slate-viewer.js +0 -71
  438. package/public/index.html +0 -45
  439. package/public/manifest.json +0 -15
  440. package/public/media/seafile-logo.png +0 -0
  441. /package/{dist/assets/css/keyboard-shortcuts.css → src/extension/toolbar/user-help/style.css} +0 -0
@@ -0,0 +1,82 @@
1
+ import React from 'react';
2
+ import { useSlateStatic } from 'slate-react';
3
+ import * as ElementType from '../constants/element-types';
4
+ import { BlockquotePlugin, HeaderPlugin, ParagraphPlugin, ImagePlugin, LinkPlugin, CodeBlockPlugin, CheckListPlugin, ListPlugin, TablePlugin, FormulaPlugin } from '../plugins';
5
+
6
+ const SlateElement = (props) => {
7
+ const { element } = props;
8
+
9
+ const editor = useSlateStatic();
10
+
11
+ switch (element.type) {
12
+ case ElementType.BLOCKQUOTE: {
13
+ const [renderBlockquote] = BlockquotePlugin.renderElements;
14
+ return renderBlockquote(props);
15
+ }
16
+ case ElementType.HEADER1:
17
+ case ElementType.HEADER2:
18
+ case ElementType.HEADER3:
19
+ case ElementType.HEADER4:
20
+ case ElementType.HEADER5:
21
+ case ElementType.HEADER6: {
22
+ const [renderHeader] = HeaderPlugin.renderElements;
23
+ return renderHeader(props, editor);
24
+ }
25
+ case ElementType.IMAGE: {
26
+ const [renderImage] = ImagePlugin.renderElements;
27
+ return renderImage(props, editor);
28
+ }
29
+ case ElementType.LINK: {
30
+ const [renderLink] = LinkPlugin.renderElements;
31
+ return renderLink(props, editor);
32
+ }
33
+ case ElementType.CODE_BLOCK: {
34
+ const [renderCodeBlock] = CodeBlockPlugin.renderElements;
35
+ return renderCodeBlock(props);
36
+ }
37
+ case ElementType.CODE_LINE: {
38
+ const [, renderCodeLine] = CodeBlockPlugin.renderElements;
39
+ return renderCodeLine(props, editor);
40
+ }
41
+ case ElementType.CHECK_LIST_ITEM: {
42
+ const [renderCheckListItem] = CheckListPlugin.renderElements;
43
+ return renderCheckListItem(props, editor);
44
+ }
45
+ case ElementType.ORDERED_LIST:
46
+ case ElementType.UNORDERED_LIST: {
47
+ const [renderList] = ListPlugin.renderElements;
48
+ return renderList(props, editor);
49
+ }
50
+ case ElementType.LIST_ITEM: {
51
+ const [, renderListItem] = ListPlugin.renderElements;
52
+ return renderListItem(props, editor);
53
+ }
54
+ case ElementType.TABLE_CELL: {
55
+ const [renderTableCell] = TablePlugin.renderElements;
56
+ return renderTableCell(props);
57
+ }
58
+ case ElementType.TABLE_ROW: {
59
+ const [, renderTableRow] = TablePlugin.renderElements;
60
+ return renderTableRow(props);
61
+ }
62
+ case ElementType.TABLE: {
63
+ const [, , renderTable] = TablePlugin.renderElements;
64
+ return renderTable(props, editor);
65
+ }
66
+ case ElementType.FORMULA: {
67
+ const [renderFormula] = FormulaPlugin.renderElements;
68
+ return renderFormula(props, editor);
69
+ }
70
+ default: {
71
+ const [renderParagraph] = ParagraphPlugin.renderElements;
72
+ return renderParagraph(props);
73
+ }
74
+ }
75
+
76
+ };
77
+
78
+ const renderElement = (props) => {
79
+ return <SlateElement {...props} />;
80
+ };
81
+
82
+ export default renderElement;
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ import { useSlateStatic } from 'slate-react';
3
+ import { TextPlugin } from '../plugins';
4
+
5
+ const CustomLeaf = (props) => {
6
+ const editor = useSlateStatic();
7
+ const [renderText] = TextPlugin.renderElements;
8
+ return renderText(props, editor);
9
+ };
10
+
11
+ const renderLeaf = (props) => {
12
+ return <CustomLeaf {...props} />;
13
+ };
14
+
15
+ export default renderLeaf;
16
+
@@ -0,0 +1,129 @@
1
+ import React, { useCallback, useEffect, useMemo, useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import classNames from 'classnames';
4
+ import { EXTERNAL_EVENTS, INTERNAL_EVENTS } from '../../../constants/event-types';
5
+ import useSelectionUpdate from '../../../hooks/use-selection-update';
6
+ import EventBus from '../../../utils/event-bus';
7
+ import { MenuGroup } from '../../commons';
8
+ import QuoteMenu from '../../plugins/blockquote/menu';
9
+ import HeaderMenu from '../../plugins/header/menu';
10
+ import TextStyleMenu from '../../plugins/text-style/menu';
11
+ import LinkMenu from '../../plugins/link/menu';
12
+ import { TEXT_STYLE_MAP } from '../../constants';
13
+ import ImageMenu from '../../plugins/image/menu';
14
+ import CodeBlockMenu from '../../plugins/code-block/menu';
15
+ import CheckListMenu from '../../plugins/check-list/menu';
16
+ import ListMenu from '../../plugins/list/menu';
17
+ import { ORDERED_LIST, UNORDERED_LIST } from '../../constants/element-types';
18
+ import TableMenu from '../../plugins/table/menu';
19
+ import { AlignmentDropDown, ColumnOperationDropDownList, RowOperationDropDownList, RemoveTableMenu } from '../../plugins/table/menu/table-operator';
20
+ import { isInTable } from '../../plugins/table/helper';
21
+ import FormulaMenu from '../../plugins/formula/menu';
22
+ import ClearFormatMenu from '../../plugins/clear-format/menu';
23
+ import KeyboardShortcuts from '../user-help/shortcut-dialog';
24
+
25
+ import './style.css';
26
+
27
+ const Toolbar = ({ editor, readonly = false, isRichEditor = false, isSupportFormula = false }) => {
28
+ useSelectionUpdate();
29
+
30
+ const [isShowArticleInfo, setIsShowArticleInfo] = useState(false);
31
+ // eslint-disable-next-line react-hooks/exhaustive-deps
32
+ const isShowSubTableMenu = useMemo(() => isInTable(editor), [editor.selection]);
33
+ const updateArticleInfoState = useCallback(() => {
34
+ const newState = !isShowArticleInfo;
35
+ setIsShowArticleInfo(newState);
36
+ const eventBus = EventBus.getInstance();
37
+ eventBus.dispatch(INTERNAL_EVENTS.ON_ARTICLE_INFO_TOGGLE, newState);
38
+ }, [isShowArticleInfo]);
39
+
40
+ const onHelpInfoToggle = useCallback((state) => {
41
+ if (state) setIsShowArticleInfo(false);
42
+ }, []);
43
+
44
+ useEffect(() => {
45
+ const eventBus = EventBus.getInstance();
46
+ // Trigger external events and close article info
47
+ const unsubscribeHelpInfo = eventBus.subscribe(EXTERNAL_EVENTS.ON_HELP_INFO_TOGGLE, onHelpInfoToggle);
48
+ return () => {
49
+ unsubscribeHelpInfo();
50
+ };
51
+ // eslint-disable-next-line react-hooks/exhaustive-deps
52
+ }, []);
53
+
54
+ const [isShowHelpModal, setIsShowHelpModal] = useState(false);
55
+ const onHelpIconToggle = useCallback(() => {
56
+ setIsShowHelpModal(!isShowHelpModal);
57
+ }, [isShowHelpModal]);
58
+
59
+ const sideIconClass = classNames('iconfont', {
60
+ 'icon-angle-double-left': !isShowArticleInfo,
61
+ 'icon-angle-double-right': isShowArticleInfo,
62
+ });
63
+
64
+ const commonProps = { editor, readonly, isRichEditor };
65
+
66
+ return (
67
+ <div className='sf-slate-editor-toolbar'>
68
+ <MenuGroup></MenuGroup>
69
+ <MenuGroup >
70
+ <HeaderMenu {...commonProps} />
71
+ </MenuGroup>
72
+ <MenuGroup >
73
+ <TextStyleMenu {...commonProps} type={TEXT_STYLE_MAP.BOLD} />
74
+ <TextStyleMenu {...commonProps} type={TEXT_STYLE_MAP.ITALIC} />
75
+ <TextStyleMenu {...commonProps} type={TEXT_STYLE_MAP.CODE} />
76
+ <LinkMenu {...commonProps} />
77
+ </MenuGroup>
78
+ <MenuGroup>
79
+ <QuoteMenu {...commonProps} />
80
+ <CheckListMenu {...commonProps} />
81
+ <ListMenu {...commonProps} type={ORDERED_LIST} />
82
+ <ListMenu {...commonProps} type={UNORDERED_LIST} />
83
+ </MenuGroup>
84
+ <MenuGroup>
85
+ <CodeBlockMenu {...commonProps} />
86
+ <TableMenu {...commonProps} />
87
+ <ImageMenu {...commonProps} />
88
+ {isSupportFormula && <FormulaMenu {...commonProps} />}
89
+ </MenuGroup>
90
+ {isShowSubTableMenu && (
91
+ <MenuGroup>
92
+ <AlignmentDropDown {...commonProps} />
93
+ <ColumnOperationDropDownList {...commonProps} />
94
+ <RowOperationDropDownList {...commonProps} />
95
+ <RemoveTableMenu {...commonProps} />
96
+ </MenuGroup>
97
+ )}
98
+ <MenuGroup>
99
+ <ClearFormatMenu {...commonProps} />
100
+ </MenuGroup>
101
+ {isRichEditor && (
102
+ <div className='sf-slate-article-info-control' onClick={updateArticleInfoState}>
103
+ <span className={sideIconClass}></span>
104
+ </div>
105
+ )}
106
+ {!isRichEditor && (
107
+ <div className='sf-slate-help-info-control' onClick={onHelpIconToggle}>
108
+ <span className="iconfont icon-use-help"></span>
109
+ </div>
110
+ )}
111
+ {isShowHelpModal && (
112
+ <KeyboardShortcuts
113
+ toggleShortcutDialog={onHelpIconToggle}
114
+ />
115
+ )}
116
+ </div>
117
+ );
118
+ };
119
+
120
+ Toolbar.defaultProps = {
121
+ readonly: false,
122
+ };
123
+
124
+ Toolbar.propTypes = {
125
+ readonly: PropTypes.bool,
126
+ editor: PropTypes.object,
127
+ };
128
+
129
+ export default Toolbar;
@@ -0,0 +1,41 @@
1
+ .sf-slate-editor-toolbar {
2
+ position: relative;
3
+ background-color: #fcfcfc;
4
+ }
5
+
6
+ .sf-slate-editor-toolbar .sf-slate-article-info-control {
7
+ position: absolute;
8
+ right: 20px;
9
+ height: 30px;
10
+ width: 30px;
11
+ line-height: 30px;
12
+ display: flex;
13
+ justify-content: center;
14
+ cursor: pointer;
15
+ color: #555;
16
+ }
17
+
18
+ .sf-slate-editor-toolbar .sf-slate-article-info-control:hover {
19
+ background-color: #e5e5e5;
20
+ }
21
+
22
+ .sf-slate-editor-toolbar .sf-slate-help-info-control {
23
+ position: absolute;
24
+ right: 20px;
25
+ height: 30px;
26
+ width: 30px;
27
+ line-height: 30px;
28
+ display: flex;
29
+ justify-content: center;
30
+ cursor: pointer;
31
+ color: #555;
32
+ }
33
+
34
+ .sf-slate-editor-toolbar .sf-slate-help-info-control > span:hover {
35
+ cursor: pointer;
36
+ color: #333;
37
+ }
38
+
39
+ .sf-slate-editor-toolbar .sf-slate-article-info-control .iconfont {
40
+ font-size: 14px;
41
+ }
@@ -0,0 +1,5 @@
1
+ import Toolbar from './header-toolbar';
2
+
3
+ export {
4
+ Toolbar
5
+ };
@@ -0,0 +1,144 @@
1
+ import React, { Fragment } from 'react';
2
+ import { Modal, ModalHeader, ModalBody } from 'reactstrap';
3
+ import { withTranslation } from 'react-i18next';
4
+
5
+ import './style.css';
6
+
7
+ const isMac = window.navigator.platform.indexOf('Win') < 0 ? true : false;
8
+ const controlKey = isMac ? '⌘' : 'CTRL';
9
+
10
+ class KeyboardShortcuts extends React.PureComponent {
11
+
12
+ renderShortcut = (keys) => {
13
+ return (
14
+ <Fragment>
15
+ <span className="keyboard-shortcut">
16
+ {keys.map((key, index) => {
17
+ return <kbd key={index}>{key}</kbd>;
18
+ })}
19
+ </span><br/>
20
+ </Fragment>
21
+ );
22
+ };
23
+
24
+ renderContainer = (keys, description) => {
25
+ return (
26
+ <div className="keyboard-shortcut-container">
27
+ <div className="col-4">{this.renderShortcut(keys)}</div>
28
+ <div className="col-8">{description}</div>
29
+ </div>
30
+ );
31
+ };
32
+
33
+ render() {
34
+ let { t, toggleShortcutDialog } = this.props;
35
+ const userHelp = t('userHelp', { returnObjects: true });
36
+ const userHelpData = userHelp.userHelpData;
37
+ return (
38
+ <Modal isOpen={true} toggle={toggleShortcutDialog} className="keyboard-shortcut-dialog" zIndex={1071}>
39
+ <ModalHeader toggle={toggleShortcutDialog}>
40
+ <span className="mr-2">{t(userHelp.title)}</span>
41
+ </ModalHeader>
42
+ <ModalBody>
43
+ <div>
44
+ {/* Title */}
45
+ <div className="pb-2">
46
+ <div className="keyboard-shortcut-title pb-1">{t(userHelpData[1]['shortcutType'])}</div>
47
+ {this.renderContainer(['#', 'space'], t(userHelpData[1].shortcutData['Heading_1']))}
48
+ {this.renderContainer(['##', 'space'], t(userHelpData[1].shortcutData['Heading_2']))}
49
+ {this.renderContainer(['###', 'space'], t(userHelpData[1].shortcutData['Heading_3']))}
50
+ {this.renderContainer(['####', 'space'], t(userHelpData[1].shortcutData['Heading_4']))}
51
+ {this.renderContainer(['#####', 'space'], t(userHelpData[1].shortcutData['Heading_5']))}
52
+ {this.renderContainer(['######', 'space'], t(userHelpData[1].shortcutData['Heading_6']))}
53
+ </div>
54
+ {/* List */}
55
+ <div className="pb-2">
56
+ <div className="keyboard-shortcut-title pb-1">{t(userHelpData[0]['shortcutType'])}</div>
57
+ <div className="keyboard-shortcut-container">
58
+ <div className="col-4">
59
+ {this.renderShortcut(['*', 'space'])}
60
+ {this.renderShortcut(['-', 'space'])}
61
+ </div>
62
+ <div className="col-8">{t(userHelpData[0].shortcutData['Make_list'])}</div>
63
+ </div>
64
+ <div className="keyboard-shortcut-container">
65
+ <div className="col-4">
66
+ {this.renderShortcut(['1.', 'space'])}
67
+ </div>
68
+ <div className="col-8">{t(userHelpData[0].shortcutData['Make_ordered_list'])}</div>
69
+ </div>
70
+ {this.renderContainer(['Tab'], t(userHelpData[0].shortcutData['Increase_depth']))}
71
+ {this.renderContainer(['Shift', 'Enter'], t(userHelpData[0].shortcutData['Insert_child_in_item']))}
72
+ {this.renderContainer(['Enter'], t(userHelpData[0].shortcutData['Insert_new_item']))}
73
+ </div>
74
+ {/* Inline */}
75
+ <div className="pb-2">
76
+ <div className="keyboard-shortcut-title pb-1">{t(userHelpData[6]['shortcutType'])}</div>
77
+ <div className="keyboard-shortcut-container">
78
+ <div className="col-4">
79
+ {this.renderShortcut(['**bold**', 'space'])}
80
+ {this.renderShortcut(['__bold__', 'space'])}
81
+ </div>
82
+ <div className="col-8">{t(userHelpData[6].shortcutData['Bold'])}</div>
83
+ </div>
84
+ <div className="keyboard-shortcut-container">
85
+ <div className="col-4">
86
+ {this.renderShortcut(['*italic*', 'space'])}
87
+ {this.renderShortcut(['_italic_', 'space'])}
88
+ </div>
89
+ <div className="col-8">{t(userHelpData[6].shortcutData['Italic'])}</div>
90
+ </div>
91
+ <div className="keyboard-shortcut-container">
92
+ <div className="col-4">
93
+ {this.renderShortcut(['***italic***', 'space'])}
94
+ {this.renderShortcut(['___italic___', 'space'])}
95
+ </div>
96
+ <div className="col-8">{t(userHelpData[6].shortcutData['Italic_Bold'])}</div>
97
+ </div>
98
+ {this.renderContainer(['`code`', 'space'], t(userHelpData[6].shortcutData['Inline_code']))}
99
+ </div>
100
+ {/* Code block */}
101
+ <div className="pb-2">
102
+ <div className="keyboard-shortcut-title pb-1">{t(userHelpData[2]['shortcutType'])}</div>
103
+ <div className="keyboard-shortcut-container">
104
+ <div className="col-4">
105
+ {this.renderShortcut(['```'])}
106
+ {this.renderShortcut(['space*4'])}
107
+ </div>
108
+ <div className="col-8">{t(userHelpData[2].shortcutData['Make_code_block'])}</div>
109
+ </div>
110
+ {this.renderContainer(['Tab'], t(userHelpData[2].shortcutData['Insert_indent']))}
111
+ {this.renderContainer(['Enter'], t(userHelpData[2].shortcutData['Insert_new_line']))}
112
+ {this.renderContainer([controlKey, 'Enter'], t(userHelpData[2].shortcutData['Escape_code_block']))}
113
+ </div>
114
+ {/* Block quote */}
115
+ <div className="pb-2">
116
+ <div className="keyboard-shortcut-title pb-1">{t(userHelpData[3]['shortcutType'])}</div>
117
+ {this.renderContainer(['>', 'space'], t(userHelpData[3].shortcutData['Make_Block_quote']))}
118
+ {this.renderContainer(['Enter'], t(userHelpData[3].shortcutData['Escape_Block_quote']))}
119
+ </div>
120
+ {/* Table */}
121
+ <div className="pb-2">
122
+ <div className="keyboard-shortcut-title pb-1">{t(userHelpData[4]['shortcutType'])}</div>
123
+ {this.renderContainer(['Enter'], t(userHelpData[4].shortcutData['Insert_Table_Row']))}
124
+ {this.renderContainer([controlKey, 'Enter'], t(userHelpData[4].shortcutData['Escape_table']))}
125
+ </div>
126
+ {/* Save */}
127
+ <div className="pb-2">
128
+ <div className="keyboard-shortcut-title pb-1">{t(userHelpData[7]['shortcutType'])}</div>
129
+ {this.renderContainer([controlKey, 's'], t(userHelpData[7].shortcutData['Save_file']))}
130
+ </div>
131
+ {/* Image */}
132
+ <div className="pb-2">
133
+ <div className="keyboard-shortcut-title pb-1">{t(userHelpData[8]['shortcutType'])}</div>
134
+ {this.renderContainer([controlKey, 'v'], t(userHelpData[8].shortcutData['Paste_screen_shot']))}
135
+ </div>
136
+ </div>
137
+ </ModalBody>
138
+ </Modal>
139
+ );
140
+ }
141
+ }
142
+
143
+ export default withTranslation('seafile-editor')(KeyboardShortcuts);
144
+
@@ -0,0 +1,44 @@
1
+ import { useEffect, useState } from 'react';
2
+
3
+ const useMathJax = (mathJaxSource) => {
4
+ const [isLoading, setIsLoading] = useState(true);
5
+ useEffect(() => {
6
+ if (!mathJaxSource) {
7
+ setIsLoading(false);
8
+ return;
9
+ }
10
+ window.MathJax = {
11
+ options: {
12
+ enableMenu: false
13
+ },
14
+ tex: {
15
+ inlineMath: [['$', '$']],
16
+ displayMath: [['$$', '$$']]
17
+ },
18
+ svg: {
19
+ fontCache: 'global'
20
+ }
21
+ };
22
+ if (!document.querySelector('#mathjax')) {
23
+ const script = document.createElement('script');
24
+ script.src = mathJaxSource;
25
+ script.id = 'mathjax';
26
+ document.body.appendChild(script);
27
+ script.onload = () => {
28
+ setIsLoading(false);
29
+ };
30
+ }
31
+
32
+ return () => {
33
+ const script = document.getElementById('mathjax');
34
+ script && script.parentNode.removeChild(script);
35
+ };
36
+ // eslint-disable-next-line react-hooks/exhaustive-deps
37
+ }, []);
38
+
39
+ return {
40
+ isLoadingMathJax: isLoading,
41
+ };
42
+ };
43
+
44
+ export default useMathJax;
@@ -0,0 +1,14 @@
1
+ import React, { useContext } from 'react';
2
+
3
+ export const ScrollContext = React.createContext(null);
4
+
5
+ export const useScrollContext = () => {
6
+ const context = useContext(ScrollContext);
7
+
8
+ if (!context) {
9
+ throw new Error('The \`useScrollContext\` hook must be used inside the <ScrollContext> component\'s context.');
10
+ }
11
+
12
+ const { scrollRef } = context;
13
+ return scrollRef;
14
+ };
@@ -0,0 +1,14 @@
1
+ import { useEffect, useState } from 'react';
2
+ import EventBus from '../utils/event-bus';
3
+
4
+ export default function useSelectionUpdate() {
5
+ const [, update] = useState({});
6
+ useEffect(() => {
7
+ const onChange = () => update({});
8
+ const eventBus = EventBus.getInstance();
9
+ const unsubscribe = eventBus.subscribe('change', onChange);
10
+ return () => {
11
+ unsubscribe();
12
+ };
13
+ }, []);
14
+ }
package/src/index.js ADDED
@@ -0,0 +1,22 @@
1
+ import { EXTERNAL_EVENTS } from './constants/event-types';
2
+ import PlainMarkdownEditor from './editors/plain-markdown-editor';
3
+ import RichMarkdownEditor from './pages/rich-markdown-editor';
4
+ import MarkdownEditor from './pages/markdown-editor';
5
+ import MarkdownViewer from './pages/markdown-view';
6
+ import SimpleEditor from './pages/simple-editor';
7
+ import EventBus from './utils/event-bus';
8
+ import { mdStringToSlate, slateToMdString, deserializeHtml, processor } from './slate-convert';
9
+
10
+ export {
11
+ MarkdownEditor,
12
+ PlainMarkdownEditor,
13
+ RichMarkdownEditor,
14
+ MarkdownViewer,
15
+ SimpleEditor,
16
+ EXTERNAL_EVENTS,
17
+ EventBus,
18
+ mdStringToSlate,
19
+ slateToMdString,
20
+ deserializeHtml,
21
+ processor,
22
+ };
@@ -0,0 +1,53 @@
1
+ import React, { forwardRef, useCallback, useEffect, useImperativeHandle, useState } from 'react';
2
+ import Loading from '../containers/loading';
3
+ import { mdStringToSlate, slateToMdString } from '../slate-convert';
4
+ import useMathJax from '../hooks/use-mathjax';
5
+ import SlateEditor from '../editors/slate-editor';
6
+
7
+ const SimpleEditor = forwardRef(({ isFetching, value, editorApi, mathJaxSource, onValueChanged = () => {}, children }, ref) => {
8
+
9
+ const [richValue, setRichValue] = useState([]);
10
+ const [isLoading, setIsLoading] = useState(true);
11
+ const { isLoadingMathJax } = useMathJax(mathJaxSource);
12
+
13
+ useImperativeHandle(ref, () => {
14
+ return {
15
+ getValue: () => {
16
+ const mdStringValue = slateToMdString(richValue);
17
+ return mdStringValue;
18
+ },
19
+ };
20
+ }, [richValue]);
21
+
22
+ useEffect(() => {
23
+ if (!isFetching) {
24
+ const richValue = mdStringToSlate(value);
25
+ setRichValue(richValue);
26
+ setIsLoading(false);
27
+ }
28
+ // eslint-disable-next-line react-hooks/exhaustive-deps
29
+ }, [isFetching]);
30
+
31
+ const onSave = useCallback((content) => {
32
+ setRichValue(content);
33
+ onValueChanged && onValueChanged();
34
+ }, [onValueChanged]);
35
+
36
+ const props = {
37
+ isSupportFormula: !!mathJaxSource,
38
+ value: richValue,
39
+ editorApi: editorApi,
40
+ onSave: onSave,
41
+ children: children,
42
+ };
43
+
44
+ if (isFetching || isLoading || isLoadingMathJax) {
45
+ return <Loading />;
46
+ }
47
+
48
+ return (
49
+ <SlateEditor {...props} />
50
+ );
51
+ });
52
+
53
+ export default SimpleEditor;
@@ -0,0 +1,36 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import Loading from '../containers/loading';
3
+ import { mdStringToSlate } from '../slate-convert';
4
+ import useMathJax from '../hooks/use-mathjax';
5
+ import SlateViewer from '../editors/slate-viewer';
6
+
7
+ export default function MarkdownViewer({ isFetching, value, mathJaxSource, isShowOutline, beforeRenderCallback }) {
8
+
9
+ const [richValue, setRichValue] = useState([]);
10
+ const [isLoading, setIsLoading] = useState(true);
11
+ const { isLoadingMathJax } = useMathJax(mathJaxSource);
12
+
13
+ useEffect(() => {
14
+ if (!isFetching) {
15
+ const richValue = mdStringToSlate(value);
16
+ beforeRenderCallback && beforeRenderCallback(richValue);
17
+ setRichValue(richValue);
18
+ setIsLoading(false);
19
+ }
20
+ // eslint-disable-next-line react-hooks/exhaustive-deps
21
+ }, [isFetching]);
22
+
23
+ const props = {
24
+ isSupportFormula: !!mathJaxSource,
25
+ value: richValue,
26
+ isShowOutline: isShowOutline,
27
+ };
28
+
29
+ if (isFetching || isLoading || isLoadingMathJax) {
30
+ return <Loading />;
31
+ }
32
+
33
+ return (
34
+ <SlateViewer {...props} />
35
+ );
36
+ }