@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,77 +0,0 @@
1
- .seafile-simple-editor {
2
- flex: 1;
3
- display: flex;
4
- flex-direction: column;
5
- height: 100%;
6
- min-width: 768px;
7
- overflow: hidden;
8
- border: 1px solid #e5e5e5;
9
- }
10
-
11
- .seafile-simple-editor .seafile-editor-topbar {
12
- width: 100%;
13
- background-color: #fff;
14
- border-bottom: 1px solid #e5e5e5;
15
- box-shadow: 0 3px 2px -2px rgba(200,200,200,.15);
16
- user-select: none;
17
- position: relative;
18
- z-index: 3;
19
- display: flex;
20
- justify-content: space-between;
21
- }
22
-
23
- .seafile-simple-editor .seafile-editor-topbar .use-help-icon {
24
- background-color: #fff;
25
- box-sizing: border-box;
26
- }
27
-
28
- .seafile-simple-editor .seafile-editor-topbar .editor-btn-group {
29
- height: 100%;
30
- padding: 5px 0 5px 5px;
31
- font-size: 0.75rem;
32
- border-right: 1px solid #e5e5e5;
33
- color: #555555;
34
- }
35
-
36
- .seafile-simple-editor .header-list-container {
37
- border-left: 0;
38
- }
39
-
40
- .seafile-simple-editor .editor {
41
- margin: 0;
42
- padding: 10px;
43
- height: 100%;
44
- border: none;
45
- }
46
-
47
- /*set scroll bar*/
48
- .seafile-simple-editor ::-webkit-scrollbar{
49
- width: 8px;
50
- height: 8px;
51
- }
52
-
53
- .seafile-simple-editor ::-webkit-scrollbar-button {
54
- display: none;
55
- }
56
-
57
- .seafile-simple-editor ::-webkit-scrollbar-thumb {
58
- background-color: rgb(206, 206, 212);
59
- border-radius: 10px;
60
- }
61
-
62
- .editor-container {
63
- /* this container is needed to show the scroll bar */
64
- height: 100%;
65
- overflow-y: auto;
66
- flex: 1 1 auto;
67
- position: relative;
68
- }
69
-
70
- .editor {
71
- min-height: calc(100% - 40px);
72
- background: #fff;
73
- padding: 40px 60px;
74
- margin: 20px 40px;
75
- border: 1px solid rgb(230,230,221);
76
- overflow-x: hidden;
77
- }
@@ -1,46 +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
- var ClickOutside = /*#__PURE__*/function (_React$Component) {
7
- _inherits(ClickOutside, _React$Component);
8
- var _super = _createSuper(ClickOutside);
9
- function ClickOutside(props) {
10
- var _this;
11
- _classCallCheck(this, ClickOutside);
12
- _this = _super.call(this, props);
13
- _this.handleDocumentMouseDown = function () {
14
- if (_this.isClickedInside) {
15
- _this.isClickedInside = false;
16
- return;
17
- }
18
- _this.props.clickOutside();
19
- };
20
- _this.handleMouseDown = function (e) {
21
- _this.isClickedInside = true;
22
- };
23
- _this.isClickedInside = false;
24
- return _this;
25
- }
26
- _createClass(ClickOutside, [{
27
- key: "componentDidMount",
28
- value: function componentDidMount() {
29
- document.addEventListener('mousedown', this.handleDocumentMouseDown);
30
- }
31
- }, {
32
- key: "componentWillUnmount",
33
- value: function componentWillUnmount() {
34
- document.removeEventListener('mousedown', this.handleDocumentMouseDown);
35
- }
36
- }, {
37
- key: "render",
38
- value: function render() {
39
- return React.cloneElement(React.Children.only(this.props.children), {
40
- onMouseDownCapture: this.handleMouseDown
41
- });
42
- }
43
- }]);
44
- return ClickOutside;
45
- }(React.Component);
46
- export default ClickOutside;
@@ -1,97 +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
- var ContextMenu = /*#__PURE__*/function (_React$Component) {
8
- _inherits(ContextMenu, _React$Component);
9
- var _super = _createSuper(ContextMenu);
10
- function ContextMenu(props) {
11
- var _this;
12
- _classCallCheck(this, ContextMenu);
13
- _this = _super.call(this, props);
14
- _this.setMenuPosition = function () {
15
- var menuHeight = _this.menu.offsetHeight;
16
- // get height of context menu when the menu is drawing completed in this page
17
- if (menuHeight === 0) {
18
- requestAnimationFrame(_this.setMenuPosition);
19
- }
20
- var top = 0;
21
- if (_this.position.top + menuHeight > document.body.clientHeight) {
22
- top = document.body.clientHeight - menuHeight - 5;
23
- } else {
24
- top = _this.position.top;
25
- }
26
- var left = _this.position.left + 3;
27
- _this.setState({
28
- contextStyle: {
29
- top: top,
30
- left: left,
31
- zIndex: '1071',
32
- display: 'block'
33
- }
34
- });
35
- };
36
- _this.state = {
37
- contextStyle: {}
38
- };
39
- _this.tableUtils = props.tableUtils;
40
- return _this;
41
- }
42
- _createClass(ContextMenu, [{
43
- key: "componentDidMount",
44
- value: function componentDidMount() {
45
- this.position = this.props.contextMenuPosition;
46
- this.setMenuPosition();
47
- }
48
- }, {
49
- key: "componentWillUnmount",
50
- value: function componentWillUnmount() {
51
- this.menu = null;
52
- }
53
- }, {
54
- key: "render",
55
- value: function render() {
56
- var _this2 = this;
57
- return /*#__PURE__*/React.createElement("div", {
58
- role: 'menu',
59
- style: this.state.contextStyle,
60
- ref: function ref(_ref) {
61
- return _this2.menu = _ref;
62
- },
63
- className: 'seafile-contextmenu dropdown-menu'
64
- }, /*#__PURE__*/React.createElement("button", {
65
- onMouseDown: function onMouseDown(event) {
66
- return _this2.tableUtils.insertRow('before');
67
- },
68
- className: 'seafile-contextmenu-item dropdown-item'
69
- }, this.props.t('Insert_Row_Before')), /*#__PURE__*/React.createElement("button", {
70
- onMouseDown: function onMouseDown(event) {
71
- return _this2.tableUtils.insertRow('after');
72
- },
73
- className: 'seafile-contextmenu-item dropdown-item'
74
- }, this.props.t('Insert_Row_After')), /*#__PURE__*/React.createElement("button", {
75
- onMouseDown: function onMouseDown(event) {
76
- return _this2.tableUtils.insertColumn('before');
77
- },
78
- className: 'seafile-contextmenu-item dropdown-item'
79
- }, this.props.t('Insert_Column_Before')), /*#__PURE__*/React.createElement("button", {
80
- onMouseDown: function onMouseDown(event) {
81
- return _this2.tableUtils.insertColumn('after');
82
- },
83
- className: 'seafile-contextmenu-item dropdown-item'
84
- }, this.props.t('Insert_Column_After')), /*#__PURE__*/React.createElement("div", {
85
- className: 'seafile-divider dropdown-divider'
86
- }), /*#__PURE__*/React.createElement("button", {
87
- onMouseDown: this.tableUtils.removeRow,
88
- className: 'seafile-contextmenu-item dropdown-item'
89
- }, this.props.t('Remove_Row')), /*#__PURE__*/React.createElement("button", {
90
- onMouseDown: this.tableUtils.removeColumn,
91
- className: 'seafile-contextmenu-item dropdown-item'
92
- }, this.props.t('Remove_Column')));
93
- }
94
- }]);
95
- return ContextMenu;
96
- }(React.Component);
97
- export default withTranslation('seafile-editor')(ContextMenu);
@@ -1,116 +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, { Fragment } from 'react';
6
- import { Button, Modal, ModalHeader, ModalBody, ModalFooter, Input } from 'reactstrap';
7
- import { withTranslation } from 'react-i18next';
8
- import { Editor } from 'slate';
9
- import EditorContext from '../../containers/editor-context';
10
- var AddFormulaDialog = /*#__PURE__*/function (_React$PureComponent) {
11
- _inherits(AddFormulaDialog, _React$PureComponent);
12
- var _super = _createSuper(AddFormulaDialog);
13
- function AddFormulaDialog(props) {
14
- var _this;
15
- _classCallCheck(this, AddFormulaDialog);
16
- _this = _super.call(this, props);
17
- _this.setInitialValue = function () {
18
- var editor = EditorContext.getEditor();
19
- var nodes = Editor.match(editor, editor.selection, {
20
- type: 'formula'
21
- });
22
- if (nodes) {
23
- var data = nodes[0].data;
24
- _this.setState({
25
- formula: data.formula
26
- });
27
- _this.formulaNode = nodes;
28
- }
29
- };
30
- _this.handleFormulaChange = function (event) {
31
- _this.renderFormula(event.target.value);
32
- _this.setState({
33
- formula: event.target.value
34
- });
35
- };
36
- _this.renderFormula = function (formula) {
37
- _this.formulaPreviewer.innerHTML = '';
38
- var dom = window.MathJax.tex2svg(formula);
39
- _this.formulaPreviewer.appendChild(dom);
40
- };
41
- _this.handleSubmit = function (event) {
42
- event.preventDefault();
43
- var formula = _this.state.formula;
44
- if (_this.formulaNode) {
45
- _this.editorUtils.setFormula({
46
- formula: formula,
47
- at: _this.formulaNode[1]
48
- });
49
- } else {
50
- _this.editorUtils.addFormula({
51
- formula: formula,
52
- at: _this.editorSelection
53
- });
54
- }
55
- _this.props.toggleFormulaDialog();
56
- };
57
- _this.state = {
58
- formula: ''
59
- };
60
- _this.formulaNode = null;
61
- _this.editorSelection = null;
62
- _this.editorUtils = EditorContext.getEditorUtils();
63
- return _this;
64
- }
65
- _createClass(AddFormulaDialog, [{
66
- key: "componentWillMount",
67
- value: function componentWillMount() {
68
- this.setInitialValue();
69
- }
70
- }, {
71
- key: "componentDidMount",
72
- value: function componentDidMount() {
73
- var editor = EditorContext.getEditor();
74
- this.editorSelection = editor.selection;
75
- if (this.formulaNode) {
76
- this.renderFormula(this.state.formula);
77
- }
78
- }
79
- }, {
80
- key: "render",
81
- value: function render() {
82
- var _this2 = this;
83
- return /*#__PURE__*/React.createElement(Modal, {
84
- isOpen: true,
85
- toggle: this.props.toggleFormulaDialog,
86
- className: this.props.className,
87
- returnFocusAfterClose: false
88
- }, /*#__PURE__*/React.createElement(ModalHeader, {
89
- toggle: this.props.toggleFormulaDialog
90
- }, this.props.t('insert_formula')), /*#__PURE__*/React.createElement(ModalBody, null, /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement("div", {
91
- className: "form-group"
92
- }, /*#__PURE__*/React.createElement("label", {
93
- className: "form-check-label"
94
- }, this.props.t('formula')), /*#__PURE__*/React.createElement(Input, {
95
- type: "textarea",
96
- className: "form-control",
97
- value: this.state.formula,
98
- onChange: this.handleFormulaChange
99
- })), /*#__PURE__*/React.createElement("div", {
100
- ref: function ref(_ref) {
101
- return _this2.formulaPreviewer = _ref;
102
- },
103
- className: "formula-preview"
104
- }))), /*#__PURE__*/React.createElement(ModalFooter, null, /*#__PURE__*/React.createElement(Button, {
105
- color: "secondary",
106
- onClick: this.props.toggleFormulaDialog
107
- }, this.props.t('cancel')), /*#__PURE__*/React.createElement(Button, {
108
- color: "primary",
109
- disabled: false,
110
- onClick: this.handleSubmit
111
- }, this.props.t('insert_formula'))));
112
- }
113
- }]);
114
- return AddFormulaDialog;
115
- }(React.PureComponent);
116
- export default withTranslation('seafile-editor')(AddFormulaDialog);
@@ -1,69 +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 { Button, Modal, ModalHeader, ModalBody, ModalFooter, Form, FormGroup, Label, Input } from 'reactstrap';
7
- import { withTranslation } from 'react-i18next';
8
- import EditorContext from '../../containers/editor-context';
9
- var AddImageDialog = /*#__PURE__*/function (_React$PureComponent) {
10
- _inherits(AddImageDialog, _React$PureComponent);
11
- var _super = _createSuper(AddImageDialog);
12
- function AddImageDialog(props) {
13
- var _this;
14
- _classCallCheck(this, AddImageDialog);
15
- _this = _super.call(this, props);
16
- _this.handleUrlChange = function (event) {
17
- _this.setState({
18
- url: event.target.value
19
- });
20
- };
21
- _this.handleSubmit = function (event) {
22
- _this.props.insertImage({
23
- url: _this.state.url,
24
- selection: _this.editorSelection
25
- });
26
- _this.props.onToggleImageDialog();
27
- };
28
- _this.state = {
29
- url: ''
30
- };
31
- _this.editorSelection = null;
32
- return _this;
33
- }
34
- _createClass(AddImageDialog, [{
35
- key: "componentDidMount",
36
- value: function componentDidMount() {
37
- var editor = EditorContext.getEditor();
38
- this.editorSelection = editor.selection;
39
- }
40
- }, {
41
- key: "render",
42
- value: function render() {
43
- return /*#__PURE__*/React.createElement(Modal, {
44
- isOpen: true,
45
- toggle: this.props.onToggleImageDialog,
46
- className: this.props.className,
47
- zIndex: 1071
48
- }, /*#__PURE__*/React.createElement(ModalHeader, {
49
- toggle: this.props.onToggleImageDialog
50
- }, this.props.t('insert_image')), /*#__PURE__*/React.createElement(ModalBody, null, /*#__PURE__*/React.createElement(Form, null, /*#__PURE__*/React.createElement(FormGroup, null, /*#__PURE__*/React.createElement(Label, {
51
- for: "columnName"
52
- }, this.props.t('image_address')), /*#__PURE__*/React.createElement(Input, {
53
- id: "columnName",
54
- value: this.state.value,
55
- onChange: this.handleUrlChange,
56
- autoFocus: true
57
- })))), /*#__PURE__*/React.createElement(ModalFooter, null, /*#__PURE__*/React.createElement(Button, {
58
- color: "secondary",
59
- onClick: this.props.onToggleImageDialog
60
- }, this.props.t('cancel')), /*#__PURE__*/React.createElement(Button, {
61
- color: "primary",
62
- disabled: this.state.url.length === 0,
63
- onClick: this.handleSubmit
64
- }, this.props.t('submit')), ' '));
65
- }
66
- }]);
67
- return AddImageDialog;
68
- }(React.PureComponent);
69
- export default withTranslation('seafile-editor')(AddImageDialog);
@@ -1,133 +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, { Fragment } from 'react';
6
- import { Button, Modal, ModalHeader, ModalBody, ModalFooter } from 'reactstrap';
7
- import { withTranslation } from 'react-i18next';
8
- import EditorContext from '../../containers/editor-context';
9
- var AddLinkDialog = /*#__PURE__*/function (_React$PureComponent) {
10
- _inherits(AddLinkDialog, _React$PureComponent);
11
- var _super = _createSuper(AddLinkDialog);
12
- function AddLinkDialog(props) {
13
- var _this;
14
- _classCallCheck(this, AddLinkDialog);
15
- _this = _super.call(this, props);
16
- _this.setInitialValue = function () {
17
- var text = _this.editorUtils.getSelectedText();
18
- if (_this.isLinkActive) {
19
- var linkNode = _this.editorUtils.getCurrentLinkNode();
20
- _this.setState({
21
- title: _this.editorUtils.getLinkText(linkNode),
22
- url: linkNode.data.href
23
- });
24
- } else {
25
- _this.setState({
26
- title: text,
27
- url: ''
28
- });
29
- }
30
- };
31
- _this.handleUrlChange = function (event) {
32
- _this.setState({
33
- url: event.target.value
34
- });
35
- };
36
- _this.handleTitleChange = function (event) {
37
- _this.setState({
38
- title: event.target.value
39
- });
40
- };
41
- _this.handleSubmit = function (event) {
42
- event.preventDefault();
43
- if (_this.state.title.length === 0 || _this.state.url.length === 0) return;
44
- if (!_this.isLinkActive) {
45
- _this.editorUtils.insertLink({
46
- text: _this.state.title,
47
- url: _this.state.url,
48
- selection: _this.editorSelection
49
- });
50
- } else {
51
- _this.editorUtils.setLink({
52
- text: _this.state.title,
53
- url: _this.state.url,
54
- selection: _this.editorSelection
55
- });
56
- }
57
- _this.props.toggleLinkDialog();
58
- };
59
- _this.onKeyDown = function (e) {
60
- if (e.keyCode === 13) {
61
- _this.handleSubmit(e);
62
- }
63
- };
64
- _this.editorUtils = EditorContext.getEditorUtils();
65
- _this.isLinkActive = _this.editorUtils.isLinkActive();
66
- _this.editorSelection = null;
67
- _this.state = {
68
- url: '',
69
- title: ''
70
- };
71
- return _this;
72
- }
73
- _createClass(AddLinkDialog, [{
74
- key: "componentWillMount",
75
- value: function componentWillMount() {
76
- this.setInitialValue();
77
- }
78
- }, {
79
- key: "componentDidMount",
80
- value: function componentDidMount() {
81
- var editor = EditorContext.getEditor();
82
- this.editorSelection = editor.selection;
83
- }
84
- }, {
85
- key: "render",
86
- value: function render() {
87
- return /*#__PURE__*/React.createElement(Modal, {
88
- isOpen: true,
89
- autoFocus: false,
90
- toggle: this.props.toggleLinkDialog,
91
- className: this.props.className,
92
- zIndex: 1071,
93
- returnFocusAfterClose: false
94
- }, /*#__PURE__*/React.createElement(ModalHeader, {
95
- toggle: this.props.toggleLinkDialog
96
- }, this.props.t('insert_link')), /*#__PURE__*/React.createElement(ModalBody, null, /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement("div", {
97
- className: "form-group"
98
- }, /*#__PURE__*/React.createElement("label", {
99
- className: "form-check-label",
100
- htmlFor: "addLink"
101
- }, this.props.t('link_address')), /*#__PURE__*/React.createElement("input", {
102
- onKeyDown: this.onKeyDown,
103
- autoFocus: true,
104
- type: "url",
105
- className: "form-control",
106
- id: "addLink",
107
- value: this.state.url,
108
- onChange: this.handleUrlChange
109
- })), /*#__PURE__*/React.createElement("div", {
110
- className: "form-group"
111
- }, /*#__PURE__*/React.createElement("label", {
112
- className: "form-check-label",
113
- htmlFor: "addTitle"
114
- }, this.props.t('link_title')), /*#__PURE__*/React.createElement("input", {
115
- onKeyDown: this.onKeyDown,
116
- type: "text",
117
- className: "form-control",
118
- id: "addTitle",
119
- value: this.state.title,
120
- onChange: this.handleTitleChange
121
- })))), /*#__PURE__*/React.createElement(ModalFooter, null, /*#__PURE__*/React.createElement(Button, {
122
- color: "secondary",
123
- onClick: this.props.toggleLinkDialog
124
- }, this.props.t('cancel')), /*#__PURE__*/React.createElement(Button, {
125
- color: "primary",
126
- disabled: false,
127
- onClick: this.handleSubmit
128
- }, this.props.t('add_link'))));
129
- }
130
- }]);
131
- return AddLinkDialog;
132
- }(React.PureComponent);
133
- export default withTranslation('seafile-editor')(AddLinkDialog);
@@ -1,97 +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 { Button } from 'reactstrap';
8
- import { processor } from '../../utils/seafile-markdown2html';
9
- import '../../assets/css/comment-dialog.css';
10
- var CommentDialog = /*#__PURE__*/function (_React$Component) {
11
- _inherits(CommentDialog, _React$Component);
12
- var _super = _createSuper(CommentDialog);
13
- function CommentDialog(props) {
14
- var _this;
15
- _classCallCheck(this, CommentDialog);
16
- _this = _super.call(this, props);
17
- _this.handleCommentChange = function (event) {
18
- var comment = event.target.value;
19
- _this.setState({
20
- comment: comment
21
- });
22
- };
23
- _this.submitComment = function () {
24
- var comment = _this.state.comment.trim();
25
- if (comment.length > 0 && _this.props.quote.length > 0) {
26
- var detail = {
27
- quote: _this.props.quote,
28
- position: _this.props.commentPosition
29
- };
30
- var detailJSON = JSON.stringify(detail);
31
- _this.props.editorApi.postComment(comment, detailJSON).then(function (res) {
32
- _this.props.onCommentAdded();
33
- });
34
- }
35
- };
36
- _this.setQuoteText = function (mdQuote) {
37
- processor.process(mdQuote).then(function (result) {
38
- var quote = String(result);
39
- _this.setState({
40
- quote: quote
41
- });
42
- });
43
- };
44
- _this.state = {
45
- comment: '',
46
- quote: ''
47
- };
48
- return _this;
49
- }
50
- _createClass(CommentDialog, [{
51
- key: "componentDidMount",
52
- value: function componentDidMount() {
53
- this.setQuoteText(this.props.quote);
54
- }
55
- }, {
56
- key: "componentWillReceiveProps",
57
- value: function componentWillReceiveProps(nextProps) {
58
- if (this.props.quote !== nextProps.quote) {
59
- this.setQuoteText(nextProps.quote);
60
- }
61
- }
62
- }, {
63
- key: "render",
64
- value: function render() {
65
- var t = this.props.t;
66
- var _this$state = this.state,
67
- comment = _this$state.comment,
68
- quote = _this$state.quote;
69
- return /*#__PURE__*/React.createElement("div", {
70
- className: "seafile-editor-comment comment-dialog"
71
- }, /*#__PURE__*/React.createElement("div", null, this.props.editorApi.name), /*#__PURE__*/React.createElement("blockquote", {
72
- className: "comment-dialog-quote"
73
- }, /*#__PURE__*/React.createElement("div", {
74
- dangerouslySetInnerHTML: {
75
- __html: quote
76
- }
77
- })), /*#__PURE__*/React.createElement("textarea", {
78
- value: comment,
79
- onChange: this.handleCommentChange
80
- }), /*#__PURE__*/React.createElement("div", {
81
- className: "button-group"
82
- }, /*#__PURE__*/React.createElement(Button, {
83
- size: "sm",
84
- color: "primary",
85
- onClick: this.submitComment
86
- }, t('submit')), /*#__PURE__*/React.createElement(Button, {
87
- size: "sm",
88
- color: "secondary",
89
- onClick: this.props.toggleCommentDialog
90
- }, t('cancel'))), /*#__PURE__*/React.createElement("span", {
91
- className: "comment-dialog-triangle"
92
- }));
93
- }
94
- }]);
95
- return CommentDialog;
96
- }(React.Component);
97
- export default withTranslation('seafile-editor')(CommentDialog);