@seafile/seafile-editor 0.4.7 → 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 (443) 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 -132
  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/comment-dialog.css +0 -50
  313. package/dist/assets/css/diff-viewer.css +0 -105
  314. package/dist/assets/css/formula.css +0 -19
  315. package/dist/assets/css/history-viewer.css +0 -104
  316. package/dist/assets/css/image.css +0 -134
  317. package/dist/assets/css/issue-card.css +0 -43
  318. package/dist/assets/css/link.css +0 -7
  319. package/dist/assets/css/markdown-editor.css +0 -12
  320. package/dist/assets/css/markdown-viewer.css +0 -69
  321. package/dist/assets/css/navbar-imgbutton.css +0 -83
  322. package/dist/assets/css/outline.css +0 -29
  323. package/dist/assets/css/table.css +0 -57
  324. package/dist/assets/css/textlink-hovermenu.css +0 -47
  325. package/dist/assets/css/topbar.css +0 -350
  326. package/dist/assets/css/tree-view.css +0 -67
  327. package/dist/assets/editor/seatable-editor.css +0 -77
  328. package/dist/assets/editor/simple-editor.css +0 -77
  329. package/dist/components/click-outside.js +0 -46
  330. package/dist/components/context-menu.js +0 -97
  331. package/dist/components/dialogs/add-formula-dialog.js +0 -116
  332. package/dist/components/dialogs/add-image-dialog.js +0 -69
  333. package/dist/components/dialogs/add-link-dialog.js +0 -133
  334. package/dist/components/dialogs/comment-dialog.js +0 -97
  335. package/dist/components/dialogs/shortcut-dialog.js +0 -131
  336. package/dist/components/error-boundary.js +0 -28
  337. package/dist/components/load-script/index.js +0 -69
  338. package/dist/components/loading.js +0 -25
  339. package/dist/components/markdown-lint.js +0 -72
  340. package/dist/components/menu/index.js +0 -4
  341. package/dist/components/menu/item.js +0 -49
  342. package/dist/components/menu/menu.js +0 -38
  343. package/dist/components/menu/style.css +0 -42
  344. package/dist/components/modal-portal.js +0 -38
  345. package/dist/components/outline/index.js +0 -92
  346. package/dist/components/outline/outline-item.js +0 -58
  347. package/dist/components/select/_option.js +0 -44
  348. package/dist/components/select/field-setting.js +0 -106
  349. package/dist/components/select/index.js +0 -149
  350. package/dist/components/select/style.css +0 -144
  351. package/dist/components/svg-icons/check-mark-icon.js +0 -14
  352. package/dist/components/svg-icons/column-icon.js +0 -17
  353. package/dist/components/svg-icons/text-icon.js +0 -34
  354. package/dist/components/text-link-hover-menu/index.js +0 -123
  355. package/dist/components/toast/alert.js +0 -138
  356. package/dist/components/toast/index.js +0 -3
  357. package/dist/components/toast/toast.js +0 -159
  358. package/dist/components/toast/toastManager.js +0 -139
  359. package/dist/components/toast/toaster.js +0 -65
  360. package/dist/components/toolbar/header-list.js +0 -114
  361. package/dist/components/toolbar/help-group.js +0 -33
  362. package/dist/components/toolbar/index.js +0 -4
  363. package/dist/components/toolbar/insert-image.js +0 -106
  364. package/dist/components/toolbar/insert-table.js +0 -136
  365. package/dist/components/toolbar/table-group.js +0 -74
  366. package/dist/components/toolbar/toolbar.js +0 -317
  367. package/dist/components/toolbar/widgets/button-group.js +0 -24
  368. package/dist/components/toolbar/widgets/button-item.js +0 -129
  369. package/dist/components/toolbar/widgets/drop-list.js +0 -88
  370. package/dist/components/user-help/index.js +0 -179
  371. package/dist/constants/cell-types.js +0 -29
  372. package/dist/constants/column.js +0 -4
  373. package/dist/containers/code-highlight-package.js +0 -14
  374. package/dist/containers/controller/block-element-controller.js +0 -375
  375. package/dist/containers/controller/index.js +0 -5
  376. package/dist/containers/controller/inline-element-controller.js +0 -134
  377. package/dist/containers/controller/normalize-controller.js +0 -95
  378. package/dist/containers/controller/shortcut-controller.js +0 -385
  379. package/dist/containers/controller/void-element-controller.js +0 -9
  380. package/dist/containers/custom/custom.js +0 -18
  381. package/dist/containers/custom/get-event-transfer.js +0 -33
  382. package/dist/containers/custom/getNodesByTypeAtRange.js +0 -57
  383. package/dist/containers/custom/insertNodes.js +0 -120
  384. package/dist/containers/custom/is-empty-paragraph.js +0 -9
  385. package/dist/containers/custom/split-nodes-at-point.js +0 -136
  386. package/dist/containers/custom/unwrap-node-by-type-at-range.js +0 -70
  387. package/dist/containers/editor-context.js +0 -85
  388. package/dist/containers/editor-utils/block-element-utils/blockquote-utils.js +0 -80
  389. package/dist/containers/editor-utils/block-element-utils/code-utils.js +0 -145
  390. package/dist/containers/editor-utils/block-element-utils/formula-utils.js +0 -51
  391. package/dist/containers/editor-utils/block-element-utils/index.js +0 -31
  392. package/dist/containers/editor-utils/block-element-utils/list-utils.js +0 -395
  393. package/dist/containers/editor-utils/block-element-utils/table-utils.js +0 -412
  394. package/dist/containers/editor-utils/clear-format-utils.js +0 -84
  395. package/dist/containers/editor-utils/common-editor-utils.js +0 -492
  396. package/dist/containers/editor-utils/inline-element-utils/index.js +0 -95
  397. package/dist/containers/editor-utils/mark-utils.js +0 -20
  398. package/dist/containers/editor-utils/range-utils.js +0 -7
  399. package/dist/containers/editor-utils/selection-utils.js +0 -30
  400. package/dist/containers/editor-utils/text-utils.js +0 -117
  401. package/dist/containers/editor-widgets/check-list-item.js +0 -53
  402. package/dist/containers/editor-widgets/code-block.js +0 -128
  403. package/dist/containers/editor-widgets/column.js +0 -100
  404. package/dist/containers/editor-widgets/formula.js +0 -67
  405. package/dist/containers/editor-widgets/image.js +0 -237
  406. package/dist/containers/editor-widgets/link.js +0 -9
  407. package/dist/containers/editor-widgets/table.js +0 -144
  408. package/dist/containers/element-model/blockquote.js +0 -13
  409. package/dist/containers/element-model/column.js +0 -19
  410. package/dist/containers/element-model/image.js +0 -16
  411. package/dist/containers/element-model/link.js +0 -16
  412. package/dist/containers/element-model/table.js +0 -57
  413. package/dist/containers/element-model/text.js +0 -10
  414. package/dist/containers/render-utils/common-utils.js +0 -80
  415. package/dist/containers/render-utils/editor-utils.js +0 -133
  416. package/dist/containers/render-utils/viewer-utils.js +0 -198
  417. package/dist/containers/viewer-widgets/viewer-formula/index.js +0 -54
  418. package/dist/containers/viewer-widgets/viewer-image/index.js +0 -70
  419. package/dist/containers/viewer-widgets/viewer-image/viewer-image.css +0 -3
  420. package/dist/editors/index.js +0 -78
  421. package/dist/editors/markdown-editor.js +0 -280
  422. package/dist/editors/plain-markdown-editor.js +0 -285
  423. package/dist/editors/seatable-editor.js +0 -210
  424. package/dist/editors/simple-editor.js +0 -200
  425. package/dist/index.js +0 -11
  426. package/dist/utils/deserialize-html.js +0 -260
  427. package/dist/utils/diff/compare-strings.js +0 -35
  428. package/dist/utils/diff/diff.js +0 -769
  429. package/dist/utils/diff/index.js +0 -2
  430. package/dist/utils/seafile-markdown2html.js +0 -52
  431. package/dist/utils/slate2markdown/deserialize.js +0 -588
  432. package/dist/utils/slate2markdown/index.js +0 -3
  433. package/dist/utils/slate2markdown/serialize.js +0 -366
  434. package/dist/utils/utils.js +0 -68
  435. package/dist/viewer/diff-viewer.js +0 -85
  436. package/dist/viewer/index.js +0 -4
  437. package/dist/viewer/markdown-viewer.js +0 -121
  438. package/dist/viewer/seatable-viewer.js +0 -63
  439. package/dist/viewer/slate-viewer.js +0 -71
  440. package/public/index.html +0 -45
  441. package/public/manifest.json +0 -15
  442. package/public/media/seafile-logo.png +0 -0
  443. /package/{dist/assets/css/keyboard-shortcuts.css → src/extension/toolbar/user-help/style.css} +0 -0
@@ -1,138 +0,0 @@
1
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
2
- import _createClass from "@babel/runtime/helpers/esm/createClass";
3
- import _inherits from "@babel/runtime/helpers/esm/inherits";
4
- import _createSuper from "@babel/runtime/helpers/esm/createSuper";
5
- import React from 'react';
6
- import { css } from 'glamor';
7
- var Alert = /*#__PURE__*/function (_React$PureComponent) {
8
- _inherits(Alert, _React$PureComponent);
9
- var _super = _createSuper(Alert);
10
- function Alert(props) {
11
- var _this;
12
- _classCallCheck(this, Alert);
13
- _this = _super.call(this, props);
14
- _this.containerStyle = css({
15
- borderRadius: '3px',
16
- backgroundColor: '#fff',
17
- padding: '10px 16px',
18
- display: 'flex',
19
- boxSizing: 'border-box',
20
- boxShadow: 'rgba(67, 90, 111, 0.3) 0px 0px 1px, rgba(67, 90, 111, 0.47) 0px 8px 10px -4px',
21
- justifyContent: 'space-between',
22
- flexDirection: 'row'
23
- });
24
- _this.containerBorderSuccess = css({
25
- borderLeft: '3px solid rgb(71, 184, 129)'
26
- });
27
- _this.containerBorderWarn = css({
28
- borderLeft: '3px solid rgb(217, 130, 43)'
29
- });
30
- _this.containerBorderDanger = css({
31
- borderLeft: '3px solid rgb(236, 76, 71)'
32
- });
33
- _this.containerBorderNotify = css({
34
- borderLeft: '3px solid rgb(16, 112, 202)'
35
- });
36
- _this.toastTextTitle = css({
37
- fontWeight: '600',
38
- fontSize: '14px',
39
- color: '#435a6f',
40
- margin: '0'
41
- });
42
- _this.toastTextChild = css({
43
- fontSize: '14px',
44
- color: '#999',
45
- margin: '0'
46
- });
47
- _this.toastClose = css({
48
- marginLeft: '15px',
49
- height: '24px',
50
- width: '24px',
51
- lineHeight: '22px',
52
- fontWeight: '700',
53
- textAlign: 'center',
54
- fontSize: '20px',
55
- color: '#000',
56
- cursor: 'pointer',
57
- opacity: '0.5',
58
- ':hover': {
59
- opacity: 1
60
- }
61
- });
62
- _this.toastIcon = css({
63
- marginRight: '10px',
64
- width: '14px',
65
- height: '20px',
66
- lineHeight: '20px'
67
- });
68
- return _this;
69
- }
70
- _createClass(Alert, [{
71
- key: "getContainerStyle",
72
- value: function getContainerStyle(intent) {
73
- switch (intent) {
74
- case 'success':
75
- return {
76
- borderStyle: this.containerBorderSuccess,
77
- iconColor: css({
78
- color: 'rgb(71, 184, 129)'
79
- }),
80
- iconClass: 'iconfont icon-check-circle'
81
- };
82
- case 'warning':
83
- return {
84
- borderStyle: this.containerBorderWarn,
85
- iconColor: css({
86
- color: 'rgb(217, 130, 43)'
87
- }),
88
- iconClass: 'iconfont icon-exclamation-triangle'
89
- };
90
- case 'none':
91
- return {
92
- borderStyle: this.containerBorderNotify,
93
- iconColor: css({
94
- color: 'rgb(16, 112, 202)'
95
- }),
96
- iconClass: 'iconfont icon-exclamation-circle'
97
- };
98
- case 'danger':
99
- return {
100
- borderStyle: this.containerBorderDanger,
101
- iconColor: css({
102
- color: 'rgb(236, 76, 71)'
103
- }),
104
- iconClass: 'iconfont icon-exclamation-circle'
105
- };
106
- default:
107
- return {
108
- borderStyle: this.containerBorderNotify,
109
- iconColor: css({
110
- color: 'rgb(16, 112, 202)'
111
- }),
112
- iconClass: 'iconfont icon-exclamation-circle'
113
- };
114
- }
115
- }
116
- }, {
117
- key: "render",
118
- value: function render() {
119
- var toastStyle = this.getContainerStyle(this.props.intent);
120
- return /*#__PURE__*/React.createElement("div", css(toastStyle.borderStyle, this.containerStyle), /*#__PURE__*/React.createElement("div", {
121
- className: this.toastIcon
122
- }, /*#__PURE__*/React.createElement("i", Object.assign({
123
- className: toastStyle.iconClass
124
- }, toastStyle.iconColor))), /*#__PURE__*/React.createElement("div", {
125
- className: this.toastTextContainer
126
- }, /*#__PURE__*/React.createElement("p", {
127
- className: this.toastTextTitle
128
- }, this.props.title), this.props.children ? /*#__PURE__*/React.createElement("p", {
129
- className: this.toastTextChild
130
- }, this.props.children) : null), /*#__PURE__*/React.createElement("div", {
131
- onClick: this.props.onRemove,
132
- className: this.toastClose
133
- }, /*#__PURE__*/React.createElement("span", null, "\xD7")));
134
- }
135
- }]);
136
- return Alert;
137
- }(React.PureComponent);
138
- export default Alert;
@@ -1,3 +0,0 @@
1
- import Toaster from './toaster';
2
- var toaster = new Toaster();
3
- export default toaster;
@@ -1,159 +0,0 @@
1
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
2
- import _createClass from "@babel/runtime/helpers/esm/createClass";
3
- import _inherits from "@babel/runtime/helpers/esm/inherits";
4
- import _createSuper from "@babel/runtime/helpers/esm/createSuper";
5
- import React from 'react';
6
- import { css } from 'glamor';
7
- import Transition from 'react-transition-group/Transition';
8
- import Alert from './alert';
9
- var animationEasing = {
10
- deceleration: 'cubic-bezier(0.0, 0.0, 0.2, 1)',
11
- acceleration: 'cubic-bezier(0.4, 0.0, 1, 1)',
12
- spring: 'cubic-bezier(0.175, 0.885, 0.320, 1.175)'
13
- };
14
- var ANIMATION_DURATION = 240;
15
- var openAnimation = css.keyframes('openAnimation', {
16
- from: {
17
- opacity: 0,
18
- transform: 'translateY(-120%)'
19
- },
20
- to: {
21
- transform: 'translateY(0)'
22
- }
23
- });
24
- var closeAnimation = css.keyframes('closeAnimation', {
25
- from: {
26
- transform: 'scale(1)',
27
- opacity: 1
28
- },
29
- to: {
30
- transform: 'scale(0.9)',
31
- opacity: 0
32
- }
33
- });
34
- var animationStyles = css({
35
- display: 'flex',
36
- flexDirection: 'column',
37
- alignItems: 'center',
38
- height: 0,
39
- transition: "all ".concat(ANIMATION_DURATION, "ms ").concat(animationEasing.deceleration),
40
- '&[data-state="entering"], &[data-state="entered"]': {
41
- animation: "".concat(openAnimation, " ").concat(ANIMATION_DURATION, "ms ").concat(animationEasing.spring, " both")
42
- },
43
- '&[data-state="exiting"]': {
44
- animation: "".concat(closeAnimation, " 120ms ").concat(animationEasing.acceleration, " both")
45
- }
46
- });
47
- var Toast = /*#__PURE__*/function (_React$PureComponent) {
48
- _inherits(Toast, _React$PureComponent);
49
- var _super = _createSuper(Toast);
50
- function Toast() {
51
- var _this;
52
- _classCallCheck(this, Toast);
53
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
54
- args[_key] = arguments[_key];
55
- }
56
- _this = _super.call.apply(_super, [this].concat(args));
57
- _this.state = {
58
- isShown: true,
59
- height: 0
60
- };
61
- _this.close = function () {
62
- _this.clearCloseTimer();
63
- _this.setState({
64
- isShown: false
65
- });
66
- };
67
- _this.startCloseTimer = function () {
68
- if (_this.props.duration) {
69
- _this.closeTimer = setTimeout(function () {
70
- _this.close();
71
- }, _this.props.duration * 1000);
72
- }
73
- };
74
- _this.clearCloseTimer = function () {
75
- if (_this.closeTimer) {
76
- clearTimeout(_this.closeTimer);
77
- _this.closeTimer = null;
78
- }
79
- };
80
- _this.handleMouseEnter = function () {
81
- _this.clearCloseTimer();
82
- };
83
- _this.handleMouseLeave = function () {
84
- _this.startCloseTimer();
85
- };
86
- _this.onRef = function (ref) {
87
- if (ref === null) return;
88
- var _ref$getBoundingClien = ref.getBoundingClientRect(),
89
- height = _ref$getBoundingClien.height;
90
- _this.setState({
91
- height: height
92
- });
93
- };
94
- return _this;
95
- }
96
- _createClass(Toast, [{
97
- key: "componentDidUpdate",
98
- value: function componentDidUpdate(prevProps) {
99
- if (prevProps.isShown !== this.props.isShown) {
100
- // eslint-disable-next-line react/no-did-update-set-state
101
- this.setState({
102
- isShown: this.props.isShown
103
- });
104
- }
105
- }
106
- }, {
107
- key: "componentDidMount",
108
- value: function componentDidMount() {
109
- this.startCloseTimer();
110
- }
111
- }, {
112
- key: "componentWillUnmount",
113
- value: function componentWillUnmount() {
114
- this.clearCloseTimer();
115
- }
116
- }, {
117
- key: "render",
118
- value: function render() {
119
- var _this2 = this;
120
- return /*#__PURE__*/React.createElement(Transition, {
121
- appear: true,
122
- unmountOnExit: true,
123
- timeout: ANIMATION_DURATION,
124
- in: this.state.isShown,
125
- onExited: this.props.onRemove
126
- }, function (state) {
127
- return /*#__PURE__*/React.createElement("div", {
128
- "data-state": state,
129
- className: animationStyles,
130
- onMouseEnter: _this2.handleMouseEnter,
131
- onMouseLeave: _this2.handleMouseLeave,
132
- style: {
133
- height: _this2.state.height,
134
- zIndex: _this2.props.zIndex,
135
- marginBottom: _this2.state.isShown ? 0 : -_this2.state.height
136
- }
137
- }, /*#__PURE__*/React.createElement("div", {
138
- ref: _this2.onRef,
139
- style: {
140
- padding: 8
141
- }
142
- }, /*#__PURE__*/React.createElement(Alert, {
143
- intent: _this2.props.intent,
144
- title: _this2.props.title,
145
- children: _this2.props.children,
146
- isRemoveable: _this2.props.hasCloseButton,
147
- onRemove: function onRemove() {
148
- return _this2.close();
149
- }
150
- })));
151
- });
152
- }
153
- }]);
154
- return Toast;
155
- }(React.PureComponent);
156
- Toast.defaultProps = {
157
- intent: 'none'
158
- };
159
- export { Toast as default };
@@ -1,139 +0,0 @@
1
- import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
2
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
3
- import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
4
- import _createForOfIteratorHelper from "@babel/runtime/helpers/esm/createForOfIteratorHelper";
5
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
6
- import _createClass from "@babel/runtime/helpers/esm/createClass";
7
- import _inherits from "@babel/runtime/helpers/esm/inherits";
8
- import _createSuper from "@babel/runtime/helpers/esm/createSuper";
9
- var _excluded = ["id", "description"];
10
- import React from 'react';
11
- import { css } from 'glamor';
12
- import Toast from './toast';
13
- var wrapperClass = css({
14
- maxWidth: 560,
15
- margin: '0 auto',
16
- top: 0,
17
- left: 0,
18
- right: 0,
19
- position: 'fixed',
20
- zIndex: 30
21
- });
22
- var hasCustomId = function hasCustomId(settings) {
23
- return Object.hasOwnProperty.call(settings, 'id');
24
- };
25
- var ToastManager = /*#__PURE__*/function (_React$PureComponent) {
26
- _inherits(ToastManager, _React$PureComponent);
27
- var _super = _createSuper(ToastManager);
28
- function ToastManager(props, context) {
29
- var _this;
30
- _classCallCheck(this, ToastManager);
31
- _this = _super.call(this, props, context);
32
- _this.getToasts = function () {
33
- return _this.state.toasts;
34
- };
35
- _this.closeAll = function () {
36
- _this.getToasts().forEach(function (toast) {
37
- return toast.close();
38
- });
39
- };
40
- _this.notify = function (title, settings) {
41
- // If there's a custom toast ID passed, close existing toasts with the same custom ID
42
- if (hasCustomId(settings)) {
43
- var _iterator = _createForOfIteratorHelper(_this.state.toasts),
44
- _step;
45
- try {
46
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
47
- var toast = _step.value;
48
- // Since unique ID is still appended to a custom ID, skip the unique ID and check only prefix
49
- if (String(toast.id).startsWith(settings.id)) {
50
- _this.closeToast(toast.id);
51
- }
52
- }
53
- } catch (err) {
54
- _iterator.e(err);
55
- } finally {
56
- _iterator.f();
57
- }
58
- }
59
- var instance = _this.createToastInstance(title, settings);
60
- _this.setState(function (previousState) {
61
- return {
62
- toasts: [instance].concat(_toConsumableArray(previousState.toasts))
63
- };
64
- });
65
- return instance;
66
- };
67
- _this.createToastInstance = function (title, settings) {
68
- var uniqueId = ++ToastManager.idCounter;
69
- var id = hasCustomId(settings) ? "".concat(settings.id, "-").concat(uniqueId) : uniqueId;
70
- return {
71
- id: id,
72
- title: title,
73
- description: settings.description,
74
- hasCloseButton: settings.hasCloseButton || true,
75
- duration: settings.duration || 2,
76
- close: function close() {
77
- return _this.closeToast(id);
78
- },
79
- intent: settings.intent
80
- };
81
- };
82
- /**
83
- * This will set isShown on the Toast which will close the toast.
84
- * It won't remove the toast until onExited triggers onRemove.
85
- */
86
- _this.closeToast = function (id) {
87
- _this.setState(function (previousState) {
88
- return {
89
- toasts: previousState.toasts.map(function (toast) {
90
- if (toast.id === id) {
91
- return _objectSpread(_objectSpread({}, toast), {}, {
92
- isShown: false
93
- });
94
- }
95
- return toast;
96
- })
97
- };
98
- });
99
- };
100
- _this.removeToast = function (id) {
101
- _this.setState(function (previousState) {
102
- return {
103
- toasts: previousState.toasts.filter(function (toast) {
104
- return toast.id !== id;
105
- })
106
- };
107
- });
108
- };
109
- props.bindNotify(_this.notify);
110
- props.bindGetToasts(_this.getToasts);
111
- props.bindCloseAll(_this.closeAll);
112
- _this.state = {
113
- toasts: []
114
- };
115
- return _this;
116
- }
117
- _createClass(ToastManager, [{
118
- key: "render",
119
- value: function render() {
120
- var _this2 = this;
121
- return /*#__PURE__*/React.createElement("span", {
122
- className: wrapperClass
123
- }, this.state.toasts.map(function (_ref) {
124
- var id = _ref.id,
125
- description = _ref.description,
126
- props = _objectWithoutProperties(_ref, _excluded);
127
- return /*#__PURE__*/React.createElement(Toast, Object.assign({
128
- key: id,
129
- onRemove: function onRemove() {
130
- return _this2.removeToast(id);
131
- }
132
- }, props), description);
133
- }));
134
- }
135
- }]);
136
- return ToastManager;
137
- }(React.PureComponent);
138
- ToastManager.idCounter = 0;
139
- export { ToastManager as default };
@@ -1,65 +0,0 @@
1
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
- import _createClass from "@babel/runtime/helpers/esm/createClass";
3
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
4
- import React from 'react';
5
- import ReactDom from 'react-dom';
6
- import ToastManager from './toastManager';
7
- var isBrowser = typeof window !== 'undefined' && typeof window.document !== 'undefined';
8
-
9
- /**
10
- * The Toaster manages the interactionsb between
11
- * the ToasterManger and the toast API.
12
- */
13
- var Toaster = /*#__PURE__*/_createClass(function Toaster() {
14
- var _this = this;
15
- _classCallCheck(this, Toaster);
16
- this._bindNotify = function (handler) {
17
- _this.notifyHandler = handler;
18
- };
19
- this._bindGetToasts = function (handler) {
20
- _this.getToastsHandler = handler;
21
- };
22
- this._bindCloseAll = function (handler) {
23
- _this.closeAllHandler = handler;
24
- };
25
- this.getToasts = function () {
26
- return _this.getToastsHandler();
27
- };
28
- this.closeAll = function () {
29
- return _this.closeAllHandler();
30
- };
31
- this.notify = function (title) {
32
- var settings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
33
- return _this.notifyHandler(title, _objectSpread(_objectSpread({}, settings), {}, {
34
- intent: 'none'
35
- }));
36
- };
37
- this.success = function (title) {
38
- var settings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
39
- return _this.notifyHandler(title, _objectSpread(_objectSpread({}, settings), {}, {
40
- intent: 'success'
41
- }));
42
- };
43
- this.warning = function (title) {
44
- var settings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
45
- return _this.notifyHandler(title, _objectSpread(_objectSpread({}, settings), {}, {
46
- intent: 'warning'
47
- }));
48
- };
49
- this.danger = function (title) {
50
- var settings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
51
- return _this.notifyHandler(title, _objectSpread(_objectSpread({}, settings), {}, {
52
- intent: 'danger'
53
- }));
54
- };
55
- if (!isBrowser) return;
56
- var container = document.createElement('div');
57
- container.setAttribute('data-evergreen-toaster-container', '');
58
- document.body.appendChild(container);
59
- ReactDom.render( /*#__PURE__*/React.createElement(ToastManager, {
60
- bindNotify: this._bindNotify,
61
- bindGetToasts: this._bindGetToasts,
62
- bindCloseAll: this._bindCloseAll
63
- }), container);
64
- });
65
- export { Toaster as default };
@@ -1,114 +0,0 @@
1
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
2
- import _createClass from "@babel/runtime/helpers/esm/createClass";
3
- import _inherits from "@babel/runtime/helpers/esm/inherits";
4
- import _createSuper from "@babel/runtime/helpers/esm/createSuper";
5
- import React from 'react';
6
- import ReactDOM from 'react-dom';
7
- import { withTranslation } from 'react-i18next';
8
- var HeaderList = /*#__PURE__*/function (_React$PureComponent) {
9
- _inherits(HeaderList, _React$PureComponent);
10
- var _super = _createSuper(HeaderList);
11
- function HeaderList(props) {
12
- var _this;
13
- _classCallCheck(this, HeaderList);
14
- _this = _super.call(this, props);
15
- _this.handleClick = function (event) {
16
- if (_this.props.disabled) return;
17
- var container = _this.getContainer();
18
- if (container.contains(event.target)) {
19
- _this.toggle();
20
- } else {
21
- if (_this.state.dropdownOpen) {
22
- _this.setState({
23
- dropdownOpen: !_this.state.dropdownOpen
24
- });
25
- }
26
- }
27
- };
28
- _this.toggle = function () {
29
- _this.setState({
30
- dropdownOpen: !_this.state.dropdownOpen
31
- });
32
- };
33
- _this.state = {
34
- dropdownOpen: false
35
- };
36
- return _this;
37
- }
38
- _createClass(HeaderList, [{
39
- key: "getContainer",
40
- value: function getContainer() {
41
- return ReactDOM.findDOMNode(this);
42
- }
43
- }, {
44
- key: "componentDidMount",
45
- value: function componentDidMount() {
46
- document.addEventListener('click', this.handleClick);
47
- }
48
- }, {
49
- key: "componentWillUnmount",
50
- value: function componentWillUnmount() {
51
- document.removeEventListener('click', this.handleClick);
52
- }
53
- }, {
54
- key: "render",
55
- value: function render() {
56
- var _this2 = this;
57
- /*
58
- * here need to use click event in DropdownItem instead of onMouseDown, reactStrap listen click, keyUp, to trigger toggle function,
59
- * if we listen mouseDown event the tool bar will render,the position of the component will change
60
- * and then the click event of this component will not be triggered
61
- * */
62
- return /*#__PURE__*/React.createElement("div", {
63
- className: 'header-list'
64
- }, /*#__PURE__*/React.createElement("div", {
65
- className: 'list-body ' + (this.props.disabled ? '' : 'header-list-body-hover') + (this.state.dropdownOpen ? ' header-list-body-highlight' : '')
66
- }, /*#__PURE__*/React.createElement("div", {
67
- className: 'list-title'
68
- }, this.props.t(this.props.headerType)), /*#__PURE__*/React.createElement("div", {
69
- className: 'list-caret'
70
- }, /*#__PURE__*/React.createElement("i", {
71
- className: this.state.dropdownOpen ? 'iconfont icon-caret-up' : 'iconfont icon-drop-down'
72
- }))), this.state.dropdownOpen && /*#__PURE__*/React.createElement("div", {
73
- className: 'list-dropdown'
74
- }, /*#__PURE__*/React.createElement("div", {
75
- className: 'list-dropdown-item',
76
- onClick: function onClick(event) {
77
- _this2.props.onClickHeader(event, 'paragraph');
78
- }
79
- }, this.props.t('paragraph')), /*#__PURE__*/React.createElement("div", {
80
- className: 'list-dropdown-item',
81
- onClick: function onClick(event) {
82
- _this2.props.onClickHeader(event, 'header_one');
83
- }
84
- }, this.props.t('header_one')), /*#__PURE__*/React.createElement("div", {
85
- className: 'list-dropdown-item',
86
- onClick: function onClick(event) {
87
- _this2.props.onClickHeader(event, 'header_two');
88
- }
89
- }, this.props.t('header_two')), /*#__PURE__*/React.createElement("div", {
90
- className: 'list-dropdown-item',
91
- onClick: function onClick(event) {
92
- _this2.props.onClickHeader(event, 'header_three');
93
- }
94
- }, this.props.t('header_three')), /*#__PURE__*/React.createElement("div", {
95
- className: 'list-dropdown-item',
96
- onClick: function onClick(event) {
97
- _this2.props.onClickHeader(event, 'header_four');
98
- }
99
- }, this.props.t('header_four')), /*#__PURE__*/React.createElement("div", {
100
- className: 'list-dropdown-item',
101
- onClick: function onClick(event) {
102
- _this2.props.onClickHeader(event, 'header_five');
103
- }
104
- }, this.props.t('header_five')), /*#__PURE__*/React.createElement("div", {
105
- className: 'list-dropdown-item',
106
- onClick: function onClick(event) {
107
- _this2.props.onClickHeader(event, 'header_six');
108
- }
109
- }, this.props.t('header_six'))));
110
- }
111
- }]);
112
- return HeaderList;
113
- }(React.PureComponent);
114
- export default withTranslation('seafile-editor')(HeaderList);
@@ -1,33 +0,0 @@
1
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
2
- import _createClass from "@babel/runtime/helpers/esm/createClass";
3
- import _inherits from "@babel/runtime/helpers/esm/inherits";
4
- import _createSuper from "@babel/runtime/helpers/esm/createSuper";
5
- import React from 'react';
6
- import { withTranslation } from 'react-i18next';
7
- import ButtonItem from './widgets/button-item';
8
- var HelpGroup = /*#__PURE__*/function (_React$Component) {
9
- _inherits(HelpGroup, _React$Component);
10
- var _super = _createSuper(HelpGroup);
11
- function HelpGroup() {
12
- _classCallCheck(this, HelpGroup);
13
- return _super.apply(this, arguments);
14
- }
15
- _createClass(HelpGroup, [{
16
- key: "render",
17
- value: function render() {
18
- var t = this.props.t;
19
- return /*#__PURE__*/React.createElement("div", {
20
- className: 'btn-group editor-btn-group'
21
- }, /*#__PURE__*/React.createElement(ButtonItem, {
22
- isRichEditor: true,
23
- text: t('Shortcut_help'),
24
- id: 'helpIcon',
25
- className: 'use-help-icon',
26
- icon: 'iconfont icon-use-help',
27
- onMouseDown: this.props.onHelpToggle
28
- }));
29
- }
30
- }]);
31
- return HelpGroup;
32
- }(React.Component);
33
- export default withTranslation('seafile-editor')(HelpGroup);
@@ -1,4 +0,0 @@
1
- import Toolbar from './toolbar';
2
- import HelpGroup from './help-group';
3
- export default Toolbar;
4
- export { HelpGroup };