@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,36 @@
1
+ /** (1/4) initialize config object */
2
+ let config = {
3
+ serviceUrl: 'https://dev.seafile.com/seahub',
4
+ username: '**',
5
+ password: '***',
6
+ name: '***',
7
+ contact_email: '**',
8
+ lib_name: '个人资料',
9
+ repoID: '2a77b4e3-0040-4c77-86e2-306cc8f53264',
10
+ // seafileCollabServer: 'http://127.0.0.1:4000',
11
+ dirPath: '/',
12
+ filePath: '/aaa.md',
13
+ fileName: 'aaa.md',
14
+ };
15
+
16
+ /** (2/4) load local development settings ./setting.local.js (if exist) */
17
+ try {
18
+ config.local = require('./setting.local.js').default || {};
19
+ config = {...config, ...{loadVerbose: true}, ...config.local};
20
+ config.loadVerbose && console.log('[SeaTable Plugin Development] Configuration merged with "./src/setting.local.js" (this message can be disabled by adding `loadVerbose: false` to the local development settings)');
21
+ delete config.local;
22
+ delete config.loadVerbose;
23
+ } catch (error) {
24
+ // fall-through by intention
25
+ console.error('[SeaTable Plugin Development] Please create "./src/setting.local.js" (from `setting.local.dist.js`)');
26
+ throw error;
27
+ }
28
+
29
+ /** (3/4) remove server trailing slash(es) (if any, common configuration error)*/
30
+ if (config.serviceUrl !== config.serviceUrl.replace(/\/+$/, '')) {
31
+ console.log(`[SeaTable Plugin Development] Server "${config.server}" trailing slash(es) removed (this message will go away by correcting the \`server: ...\` entry in the local development settings)`);
32
+ config.serviceUrl = config.serviceUrl.replace(/\/+$/, '');
33
+ }
34
+
35
+ /* (4/4) init window.dtablePluginConfig */
36
+ export { config as serverConfig };
@@ -0,0 +1,23 @@
1
+ const config = {
2
+ serviceUrl: 'http://127.0.0.1', // required
3
+ name: '**', // required, current user's name
4
+ username: '**', // required
5
+ password: '**', // required
6
+ avatarURL: '**', // required, current user's avatar_url
7
+ contact_email: '**',
8
+ lib_name: '**',
9
+ repoID: '8c911722-6a67-420d-a52d-aa6e8dcd6279', // required
10
+ dirPath: '/', // required
11
+ docPath: '/aaa.sdoc', // required
12
+ docName: 'aaa.sdoc', // required
13
+ docUuid: '66d73184-4a41-4ee9-9e12-3a64c3527fbb', // required
14
+ sdocServer: 'http://127.0.0.1:7070', // required
15
+ accessToken: '',
16
+ isDevelopment: true,
17
+ isOpenSocket: false, // required
18
+ lang: 'en', // optional
19
+ assetsUrl: '/api/v2.1/seadoc/download-image/bf93b0a6-2d02-431a-9de5-9ec7a6f357c9', // required
20
+ isShowInternalLink: false, // required
21
+ }
22
+
23
+ export default config;
@@ -0,0 +1,57 @@
1
+ .sf-slate-editor-container {
2
+ flex: 1;
3
+ display: flex;
4
+ flex-direction: column;
5
+ min-height: 0;
6
+ }
7
+
8
+ .sf-slate-editor-container .sf-slate-editor-toolbar {
9
+ display: flex;
10
+ justify-content: center;
11
+ height: 44px;
12
+ align-items: center;
13
+ padding: 0 10px;
14
+ background-color: #fff;
15
+ user-select: none;
16
+ border-bottom: 1px solid #e5e6e8;
17
+ position: relative;
18
+ z-index: 102;
19
+ }
20
+
21
+ .sf-slate-editor-container .sf-slate-editor-content {
22
+ width: 100%;
23
+ height: calc(100% - 44px);
24
+ display: flex;
25
+ background: #f5f5f5;
26
+ position: relative;
27
+ min-height: 0;
28
+ }
29
+
30
+ .sf-slate-editor-container .sf-slate-scroll-container {
31
+ height: 100%;
32
+ width: 100%;
33
+ overflow: auto;
34
+ }
35
+
36
+ .sf-slate-editor-container .sf-slate-article-container {
37
+ flex: 1;
38
+ position: relative;
39
+ max-width: 950px;
40
+ min-width: 400px;
41
+ margin: 0 auto;
42
+ padding-top: 20px;
43
+ padding-bottom: 20px;
44
+ }
45
+
46
+ .sf-slate-editor-container .sf-slate-editor-content .article {
47
+ max-width: 950px;
48
+ min-height: 1200px;
49
+ padding: 40px 60px;
50
+ background-color: #fff;
51
+ border: 1px solid #e5e6e8;
52
+ box-shadow: 0 0 15px rgba(0, 0, 0, 0.06);
53
+ }
54
+
55
+ .sf-slate-editor-container .sf-slate-editor-content .article div:first-child {
56
+ outline: none;
57
+ }
@@ -0,0 +1,11 @@
1
+ export const INTERNAL_EVENTS = {
2
+ ON_ARTICLE_INFO_TOGGLE: 'on_article_info_toggle',
3
+ ON_MOUSE_ENTER_BLOCK: 'on_mouse_enter_block',
4
+ ON_OPEN_LINK_POPOVER: 'on_open_link_popover',
5
+ ON_CLOSE_LINK_POPOVER: 'on_close_link_popover',
6
+ ON_OPEN_FORMULA_DIALOG: 'on_open_formula_dialog',
7
+ };
8
+
9
+ export const EXTERNAL_EVENTS = {
10
+ ON_HELP_INFO_TOGGLE: 'on_help_info_toggle'
11
+ };
@@ -0,0 +1,47 @@
1
+ export const HELPER_HOTKEYS = [
2
+ {
3
+ 'Make_list': [['*/-', 'space']],
4
+ 'Make_ordered_list': [['1.', 'space']],
5
+ 'Insert_new_item': [['Enter']],
6
+ 'Insert_child_in_item': [['Shift', 'Enter']],
7
+ 'Increase_depth': [['Tab']]
8
+ },
9
+ {
10
+ 'Heading_1': [['#', 'space']],
11
+ 'Heading_2': [['##', 'space']],
12
+ 'Heading_3': [['###', 'space']],
13
+ 'Heading_4': [['####', 'space']],
14
+ 'Heading_5': [['#####', 'space']],
15
+ 'Heading_6': [['######', 'space']]
16
+ },
17
+ {
18
+ 'Make_code_block': [['```']],
19
+ 'Insert_new_line': [['Enter']],
20
+ 'Escape_code_block': [['Ctrl', 'Enter'], ['Cmd', 'Enter']],
21
+ 'Insert_indent': [['Tab']]
22
+ },
23
+ {
24
+ 'Make_block_quote': [['>', 'space']],
25
+ 'Escape_block_quote': [['Enter']],
26
+ },
27
+ {
28
+ 'Insert_table_row': [['Enter']],
29
+ 'Escape_table': [['Ctrl', 'Enter'], ['Cmd', 'Enter']]
30
+ },
31
+ {
32
+ 'Insert_formula': [['Ctrl', '$'], ['Cmd', '$']],
33
+ },
34
+ {
35
+ 'Bold': [['**bold** / __bold__', 'space']],
36
+ 'Italic': [['*italic* / _italic_', 'space']],
37
+ 'Italic_bold': [['***italic*** / ___italic___', 'space']],
38
+ 'Inline_code': [['`code`', 'space']]
39
+ },
40
+ {
41
+ 'Save_file': [['Ctrl', 's'], ['Cmd', 's']],
42
+ },
43
+ {
44
+ 'Paste_screen_shot': [['Ctrl', 'v'], ['Cmd', 'v']],
45
+ 'Drag_image_from_anywhere_to_upload_it': []
46
+ }
47
+ ];
@@ -0,0 +1,49 @@
1
+ import React, { useCallback, useState } from 'react';
2
+ import Outline from '../outline';
3
+ import { useSlateStatic } from 'slate-react';
4
+
5
+ import './style.css';
6
+
7
+ const TAB_TYPES = {
8
+ OUTLINE: 'outline',
9
+ FILE_DETAIL: 'file_detail',
10
+ };
11
+
12
+ export default function ArticleInfo({ children }) {
13
+ const editor = useSlateStatic();
14
+ const [activeTab, setActiveTab] = useState(TAB_TYPES.OUTLINE);
15
+ const onOutlineClick = useCallback(() => {
16
+ if (activeTab === TAB_TYPES.OUTLINE) return;
17
+ setActiveTab(TAB_TYPES.OUTLINE);
18
+ }, [activeTab]);
19
+
20
+ const onDetailClick = useCallback(() => {
21
+ if (activeTab === TAB_TYPES.FILE_DETAIL) return;
22
+ setActiveTab(TAB_TYPES.FILE_DETAIL);
23
+ }, [activeTab]);
24
+
25
+ console.log(children);
26
+
27
+ return (
28
+ <div className="sf-article-info-container">
29
+ <ul className="sf-article-info-nav nav">
30
+ <li className="nav-item">
31
+ <span className={`nav-link ${activeTab === TAB_TYPES.OUTLINE && 'active'}`} onClick={onOutlineClick}><i className="iconfont icon-list-ul"/></span>
32
+ </li>
33
+ <li className="nav-item">
34
+ <span className={`nav-link ${activeTab === TAB_TYPES.FILE_DETAIL && 'active'}`} onClick={onDetailClick}><i className={'iconfont icon-info-circle'}/></span>
35
+ </li>
36
+ </ul>
37
+ <div className="sf-article-info-content">
38
+ {activeTab === TAB_TYPES.OUTLINE && (
39
+ <Outline editor={editor} />
40
+ )}
41
+ {activeTab === TAB_TYPES.FILE_DETAIL && (
42
+ <>
43
+ { children }
44
+ </>
45
+ )}
46
+ </div>
47
+ </div>
48
+ );
49
+ }
@@ -0,0 +1,52 @@
1
+ .sf-article-info-container {
2
+ flex: 1;
3
+ display: flex;
4
+ flex-direction: column;
5
+ background-color: #f5f5f5;
6
+ user-select: none;
7
+ }
8
+
9
+ .sf-article-info-container .nav {
10
+ padding: 10px 0;
11
+ min-width: 125px;
12
+ height: 36px;
13
+ border-bottom: 1px solid #eee;
14
+ background-color: #fff;
15
+ justify-content: space-around;
16
+ flex-wrap: nowrap;
17
+ flex-shrink: 0;
18
+ }
19
+
20
+ .sf-article-info-container .nav .nav-item {
21
+ padding: 0 0.75rem;
22
+ }
23
+
24
+ .sf-article-info-container .nav .nav-link {
25
+ padding: 0 0.75rem;
26
+ transition: 0.3s color;
27
+ margin-right: 0;
28
+ }
29
+
30
+ .sf-article-info-container .nav-link {
31
+ color: #888;
32
+ }
33
+
34
+ .sf-article-info-container .nav .nav-link.active {
35
+ color: #ff9800;
36
+ border-bottom: 0;
37
+ }
38
+
39
+ .sf-article-info-container .nav .iconfont {
40
+ font-weight: 700;
41
+ font-size: 0.875rem;
42
+ }
43
+
44
+ .sf-article-info-container .sf-article-info-content {
45
+ flex: 1;
46
+ font-size: 0.937rem;
47
+ overflow: hidden;
48
+ }
49
+
50
+ .sf-article-info-container .sf-article-info-content:hover {
51
+ overflow: auto;
52
+ }
@@ -0,0 +1,28 @@
1
+ const getEventTransfer = (data) => {
2
+ const fragmentString = data.getData('application/x-slate-fragment');
3
+ const textContent = data.getData('text') || data.getData('text/plain') || '';
4
+ let fragmentContent = fragmentString ? JSON.parse(decodeURIComponent(window.atob(fragmentString))) : null;
5
+ const htmlContent = data.getData('text/html') || '';
6
+ const hasRtfContent = data.types.includes('text/rtf');
7
+
8
+ /**
9
+ * compat old version slate: if clipboard content is old version slate fragment
10
+ * return html content
11
+ */
12
+ const files = data.files;
13
+ let type = 'text';
14
+ // Paste rtf format content which copied from PPT or Word or Excel as text to document
15
+ if (hasRtfContent) {
16
+ type = 'text';
17
+ } else if (files.length > 0) {
18
+ type = 'file';
19
+ } else if (fragmentContent && Array.isArray(fragmentContent)) {
20
+ type = 'fragment';
21
+ } else if (htmlContent) {
22
+ type = 'html';
23
+ }
24
+
25
+ return { text: textContent, html: htmlContent, fragment: fragmentContent, type, files: files };
26
+ };
27
+
28
+ export default getEventTransfer;
@@ -1,22 +1,23 @@
1
1
  import { Node } from 'slate';
2
- var TRANSFER_TYPES = {
2
+
3
+ const TRANSFER_TYPES = {
3
4
  fragment: 'application/x-slate-fragment',
4
5
  html: 'text/html',
5
- text: 'text/plain'
6
+ text: 'text/plain',
6
7
  };
7
8
 
8
- // tranfrom slate fragment and write to clipboard
9
+ // transform slate fragment and write to clipboard
9
10
  function setEventTransfer(event, type, content) {
10
- var mime = TRANSFER_TYPES[type];
11
- var transfer = event.dataTransfer || event.clipboardData;
11
+ const mime = TRANSFER_TYPES[type];
12
+ const transfer = event.dataTransfer || event.clipboardData;
12
13
  if (type === 'fragment') {
13
14
  // use the same encoding as slate
14
- var encodedContent = window.btoa(encodeURIComponent(JSON.stringify(content)));
15
+ const encodedContent = window.btoa(encodeURIComponent(JSON.stringify(content)));
15
16
  transfer.setData(mime, encodedContent);
16
- var texts = '';
17
- var textItem = '';
18
- content.forEach(function (element) {
19
- textItem = Node.text(element).replace(/\ufeff/, '');
17
+ let texts = '';
18
+ let textItem = '';
19
+ content.forEach(element => {
20
+ textItem = Node.string(element).replace(/\ufeff/, '');
20
21
  texts += textItem + '\r\n';
21
22
  });
22
23
  transfer.setData('text', texts);
@@ -27,4 +28,5 @@ function setEventTransfer(event, type, content) {
27
28
  transfer.setData('text', content);
28
29
  }
29
30
  }
30
- export default setEventTransfer;
31
+
32
+ export default setEventTransfer;
@@ -0,0 +1,30 @@
1
+ import React from 'react';
2
+ import { isMac } from '../../utils/common';
3
+
4
+ export default function ClassifyHotkeys({ title, shortcutData, shortcutDataNames }) {
5
+ return (
6
+ <div className='sf-editor-classify-hotkeys'>
7
+ <h5 className='hotkey-type'>{title}</h5>
8
+ <ul className='hotkey-list'>
9
+ {Object.keys(shortcutData).map(key => {
10
+ const shortcutName = shortcutDataNames[key];
11
+ let hotkeys = shortcutData[key];
12
+ if (hotkeys.length !== 0) {
13
+ hotkeys = hotkeys.length > 1 && isMac() ? hotkeys[1] : hotkeys[0];
14
+ }
15
+ return (
16
+ <li className='hotkey-shortcuts' key={shortcutName}>
17
+ <div className='hotkey-shortcuts-left'>
18
+ {shortcutName}
19
+ </div>
20
+ <div className='hotkey-shortcuts-right'>
21
+ {hotkeys[0] && <div className='key hotkey-first'>{hotkeys[0]}</div>}
22
+ {hotkeys[1] && <div className='key hotkey-second'>{hotkeys[1]}</div>}
23
+ </div>
24
+ </li>
25
+ );
26
+ })}
27
+ </ul>
28
+ </div>
29
+ );
30
+ }
@@ -0,0 +1,43 @@
1
+ import React, { useCallback } from 'react';
2
+ import { useTranslation } from 'react-i18next';
3
+ import ClassifyHotkeys from './classify-hotkeys';
4
+ import { HELPER_HOTKEYS } from '../../constants/hot-keys';
5
+ import { EXTERNAL_EVENTS } from '../../constants/event-types';
6
+ import EventBus from '../../utils/event-bus';
7
+
8
+ import './style.css';
9
+
10
+ export default function HotkeysHelper() {
11
+ const { t } = useTranslation();
12
+ const useHelp = t('userHelp', { returnObjects: true });
13
+ const { title, userHelpData } = useHelp;
14
+
15
+ const onCloseClick = useCallback(() => {
16
+ const eventBus = EventBus.getInstance();
17
+ eventBus.dispatch(EXTERNAL_EVENTS.ON_HELP_INFO_TOGGLE, false);
18
+ }, []);
19
+
20
+ return (
21
+ <div className='sf-editor-helper'>
22
+ <div className='sf-editor-helper__header'>
23
+ <div className='title'>{title}</div>
24
+ <div className="help-close" onClick={onCloseClick}><i className="iconfont icon-times-circle"></i></div>
25
+ </div>
26
+ <div className='sf-editor-helper__content'>
27
+ {userHelpData.map((item, index) => {
28
+ const shortcutData = HELPER_HOTKEYS[index];
29
+ const { shortcutType: title, shortcutData: shortcutDataNames } = item;
30
+
31
+ return (
32
+ <ClassifyHotkeys
33
+ key={`use-hotkey-${index}`}
34
+ title={title}
35
+ shortcutData={shortcutData}
36
+ shortcutDataNames={shortcutDataNames}
37
+ />
38
+ );
39
+ })}
40
+ </div>
41
+ </div>
42
+ );
43
+ }
@@ -1,17 +1,17 @@
1
1
 
2
- .seafile-editor-help {
3
- width: 250px;
2
+ .sf-editor-helper {
4
3
  height: 100%;
5
- flex: 0 0 350px;
4
+ flex: 1 0 350px;
6
5
  background-color: #fff;
7
6
  overflow-y: auto;
8
7
  overflow-x: hidden;
9
8
  border-left: 1px solid #eee;
10
9
  }
11
10
 
12
- .seafile-editor-help .help-header{
11
+ .sf-editor-helper__header {
13
12
  height: 50px;
14
13
  background-color: rgb(250,250,249);
14
+ display: flex;
15
15
  justify-content: space-between;
16
16
  padding: 0 10px;
17
17
  box-sizing: border-box;
@@ -20,21 +20,16 @@
20
20
  font-size: 1rem;
21
21
  }
22
22
 
23
- .seafile-editor-help .help-title {
23
+ .sf-editor-helper__header .title {
24
24
  font-weight: bolder;
25
25
  margin-bottom: 0;
26
26
  }
27
27
 
28
- .seafile-editor-help .help-close {
29
- font-weight: normal;
30
- color: #b9b9b9;
31
- }
32
-
33
- .seafile-editor-help .help-close:hover {
34
- color: #888;
28
+ .sf-editor-helper__header .help-close {
29
+ cursor: pointer;
35
30
  }
36
31
 
37
- .seafile-editor-help .help-content {
32
+ .sf-editor-helper__content {
38
33
  height: calc(100% - 50px);
39
34
  overflow-y: auto;
40
35
  padding: 0 15px;
@@ -42,28 +37,45 @@
42
37
  font-size: 0.8rem;
43
38
  }
44
39
 
45
- .seafile-editor-help .help-shortcut {
40
+ .sf-editor-helper .sf-editor-classify-hotkeys {
46
41
  display: flex;
47
- border-bottom: 1px solid #eee;
42
+ flex-direction: column;
48
43
  justify-content: space-between;
49
44
  color: #2c2d30;
45
+ /* border-bottom: 1px solid #eee; */
46
+ /* padding: 10px 0; */
47
+ }
48
+
49
+ .sf-editor-helper .sf-editor-classify-hotkeys .hotkey-type {
50
+ border-bottom: 1px solid #eee;
51
+ line-height: 2;
52
+ font-weight: bolder;
53
+ margin: 10px 0 0 0;
54
+ }
55
+
56
+ .sf-editor-helper .sf-editor-classify-hotkeys .hotkey-list {
57
+ list-style: none;
58
+ padding: 0;
59
+ }
60
+
61
+ .sf-editor-helper .sf-editor-classify-hotkeys .hotkey-shortcuts {
62
+ display: flex;
63
+ justify-content: space-between;
50
64
  padding: 10px 0;
65
+ border-bottom: 1px solid #eee;
66
+ color: #2c2d30;
51
67
  }
52
68
 
53
- .seafile-editor-help .help-shortcut-left {
69
+ .sf-editor-helper .sf-editor-classify-hotkeys .hotkey-shortcuts-left {
54
70
  word-break: break-all;
55
71
  line-height: 30px;
56
72
  }
57
73
 
58
- .seafile-editor-help .help-content .help-shortcut-type {
59
- border-bottom: 1px solid #eee;
60
- /*height: 50px;*/
61
- line-height: 2;
62
- font-weight: bolder;
63
- margin: 10px 0 0 0;
74
+ .sf-editor-helper .sf-editor-classify-hotkeys .hotkey-shortcuts-right {
75
+ min-width: max-content;
64
76
  }
65
77
 
66
- .seafile-editor-help .help-shortcut .key {
78
+ .sf-editor-helper .sf-editor-classify-hotkeys .hotkey-shortcuts-right .key {
67
79
  display: inline-block;
68
80
  border-radius: 3px;
69
81
  background-color: #e8e8e8;
@@ -75,10 +87,6 @@
75
87
  line-height: 20px;
76
88
  }
77
89
 
78
- .seafile-editor-help .help-shortcut-right {
79
- min-width: max-content;
80
- }
81
-
82
- .seafile-editor-help .help-shortcut-right-container:not(:first-child) {
90
+ /* .sf-editor-helper .sf-editor-classify-hotkeys .hotkey-shortcuts-right:not(:first-child) {
83
91
  margin-top: 10px;
84
- }
92
+ } */
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ import './style.css';
3
+
4
+ class Loading extends React.Component {
5
+ render() {
6
+ return (
7
+ <div className="empty-loading-page">
8
+ <div className="lds-ripple page-centered"><div></div><div></div></div>
9
+ </div>
10
+ );
11
+ }
12
+ }
13
+
14
+ export default Loading;
@@ -0,0 +1,49 @@
1
+ .empty-loading-page {
2
+ position: fixed;
3
+ height: 100%;
4
+ width: 100%;
5
+ }
6
+
7
+ .page-centered {
8
+ position: fixed;
9
+ top: 50%;
10
+ left: 50%;
11
+ /* bring your own prefixes */
12
+ transform: translate(-50%, -50%);
13
+ }
14
+
15
+ .lds-ripple {
16
+ display: inline-block;
17
+ position: relative;
18
+ width: 64px;
19
+ height: 64px;
20
+ }
21
+
22
+ .lds-ripple div {
23
+ position: absolute;
24
+ border: 4px solid #eb8205;
25
+ opacity: 1;
26
+ border-radius: 50%;
27
+ animation: lds-ripple 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;
28
+ }
29
+
30
+ .lds-ripple div:nth-child(2) {
31
+ animation-delay: -0.5s;
32
+ }
33
+
34
+ @keyframes lds-ripple {
35
+ 0% {
36
+ top: 28px;
37
+ left: 28px;
38
+ width: 0;
39
+ height: 0;
40
+ opacity: 1;
41
+ }
42
+ 100% {
43
+ top: -1px;
44
+ left: -1px;
45
+ width: 58px;
46
+ height: 58px;
47
+ opacity: 0;
48
+ }
49
+ }
@@ -0,0 +1,75 @@
1
+ import React, { useCallback, useEffect, useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { useTranslation } from 'react-i18next';
4
+ import OutlineItem from './outline-item';
5
+ import { useScrollContext } from '../../hooks/use-scroll-context';
6
+
7
+ import './style.css';
8
+
9
+ const getHeaderList = (children) => {
10
+ const headerList = [];
11
+ children.forEach((node) => {
12
+ if (node.type === 'header2' || node.type === 'header3') {
13
+ headerList.push(node);
14
+ }
15
+ });
16
+ return headerList;
17
+ };
18
+
19
+ const Outline = ({ editor }) => {
20
+ const { t } = useTranslation();
21
+ const scrollRef = useScrollContext();
22
+ const [headerList, setHeaderList] = useState([]);
23
+ const [activeId, setActiveId] = useState('');
24
+
25
+ useEffect(() => {
26
+ const headerList = getHeaderList(editor.children);
27
+ setHeaderList(headerList);
28
+ }, [editor.children]);
29
+
30
+ const handleScroll = useCallback((e) => {
31
+ const scrollTop = scrollRef.current.scrollTop;
32
+ const styles = getComputedStyle(scrollRef?.current);
33
+ const paddingTop = parseInt(styles.paddingTop);
34
+ for (let i = 0; i < headerList.length; i++) {
35
+ const headerItem = headerList[i];
36
+ const dom = document.getElementById(headerItem.id);
37
+ const { offsetTop, offsetHeight } = dom;
38
+ const styles = getComputedStyle(dom);
39
+ const marginTop = parseInt(styles.marginTop);
40
+ if (offsetTop + offsetHeight + marginTop > scrollTop - paddingTop) {
41
+ setActiveId(headerItem.id);
42
+ break;
43
+ }
44
+ }
45
+ }, [headerList, scrollRef]);
46
+
47
+ useEffect(() => {
48
+ let observerRefValue = null;
49
+ if (scrollRef.current) {
50
+ scrollRef.current.addEventListener('scroll', handleScroll);
51
+ observerRefValue = scrollRef.current;
52
+ }
53
+
54
+ return () => {
55
+ observerRefValue.removeEventListener('scroll', handleScroll);
56
+ };
57
+ }, [handleScroll, scrollRef]);
58
+
59
+ return (
60
+ <div className="sf-editor-outline">
61
+ {headerList.length === 0 && (
62
+ <div className="empty-container">{t('No_out_line')}</div>
63
+ )}
64
+ {headerList.length > 0 && headerList.map((node, index) => {
65
+ return <OutlineItem key={index} node={node} activeId={activeId} />;
66
+ })}
67
+ </div>
68
+ );
69
+ };
70
+
71
+ Outline.propTypes = {
72
+ editor: PropTypes.object,
73
+ };
74
+
75
+ export default Outline;