@seafile/seafile-editor 0.4.8 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (441) hide show
  1. package/.babelrc +5 -0
  2. package/.eslintignore +19 -0
  3. package/.eslintrc.json +52 -0
  4. package/.github/workflows/nodejs.yml +25 -0
  5. package/.vscode/settings.json +5 -0
  6. package/config/config.common.js +157 -0
  7. package/config/config.dev.js +53 -0
  8. package/config/jest/cssTransform.js +16 -0
  9. package/config/jest/fileTransform.js +40 -0
  10. package/config/utils/theme.css.js +103 -0
  11. package/config.js +61 -0
  12. package/dev-server.js +145 -0
  13. package/jest.config.js +16 -0
  14. package/package.json +81 -131
  15. package/public/locales/en/seafile-editor.json +145 -148
  16. package/public/locales/zh-CN/seafile-editor.json +123 -135
  17. package/public/media/seafile-ui.css +6 -11166
  18. package/scripts/ejs.js +16 -0
  19. package/site/_i18n/index.js +35 -0
  20. package/site/api/index.js +212 -0
  21. package/site/app.js +21 -0
  22. package/site/assets/css/app.css +47 -0
  23. package/site/assets/css/seafile-editor.css +33 -0
  24. package/site/commons/loading/index.js +14 -0
  25. package/site/commons/loading/style.css +49 -0
  26. package/site/commons/switch/index.css +14 -0
  27. package/site/commons/switch/index.js +37 -0
  28. package/site/commons/toast/alert.js +106 -0
  29. package/site/commons/toast/index.js +5 -0
  30. package/site/commons/toast/toast.js +195 -0
  31. package/site/commons/toast/toastManager.js +138 -0
  32. package/site/commons/toast/toaster.js +64 -0
  33. package/site/index.html +23 -0
  34. package/site/index.js +21 -0
  35. package/site/pages/home.js +21 -0
  36. package/site/pages/plain-markdown-view.js +6 -0
  37. package/site/pages/rich-seafile-editor.js +72 -0
  38. package/site/pages/seafile-editor.js +39 -0
  39. package/site/pages/seafile-viewer.js +45 -0
  40. package/site/pages/simple-editor.js +44 -0
  41. package/site/pages/wiki-viewer.js +7 -0
  42. package/site/setting.js +36 -0
  43. package/site/setting.local.dist.js +23 -0
  44. package/src/assets/css/slate-editor.css +57 -0
  45. package/src/constants/event-types.js +11 -0
  46. package/src/constants/hot-keys.js +47 -0
  47. package/src/containers/article-info/index.js +49 -0
  48. package/src/containers/article-info/style.css +52 -0
  49. package/src/containers/custom/get-event-transfer.js +28 -0
  50. package/{dist → src}/containers/custom/set-event-transfer.js +13 -11
  51. package/src/containers/hotkeys-helper/classify-hotkeys.js +30 -0
  52. package/src/containers/hotkeys-helper/index.js +43 -0
  53. package/{dist/assets/css/user-help.css → src/containers/hotkeys-helper/style.css} +37 -29
  54. package/src/containers/loading/index.js +14 -0
  55. package/src/containers/loading/style.css +49 -0
  56. package/src/containers/outline/index.js +75 -0
  57. package/src/containers/outline/outline-item.js +28 -0
  58. package/src/containers/outline/style.css +45 -0
  59. package/src/editors/plain-markdown-editor/code-mirror.css +8 -0
  60. package/src/editors/plain-markdown-editor/code-mirror.js +73 -0
  61. package/src/editors/plain-markdown-editor/index.js +136 -0
  62. package/{dist/assets/editor/plain-editor.css → src/editors/plain-markdown-editor/style.css} +12 -4
  63. package/src/editors/simple-slate-editor /index.js +71 -0
  64. package/src/editors/simple-slate-editor /with-props-editor.js +15 -0
  65. package/src/editors/slate-editor/editor-help/index.js +46 -0
  66. package/src/editors/slate-editor/editor-help/style.css +15 -0
  67. package/src/editors/slate-editor/index.js +77 -0
  68. package/src/editors/slate-editor/with-props-editor.js +15 -0
  69. package/src/editors/slate-viewer/index.js +35 -0
  70. package/src/editors/slate-viewer/style.css +40 -0
  71. package/src/extension/commons/element-popover/index.js +52 -0
  72. package/src/extension/commons/index.js +10 -0
  73. package/src/extension/commons/menu/index.js +9 -0
  74. package/src/extension/commons/menu/menu-drop-down.js +110 -0
  75. package/src/extension/commons/menu/menu-group.js +20 -0
  76. package/src/extension/commons/menu/menu-item.js +60 -0
  77. package/src/extension/commons/menu/menu.css +120 -0
  78. package/src/extension/commons/tooltip/index.css +21 -0
  79. package/src/extension/commons/tooltip/index.js +26 -0
  80. package/src/extension/constants/element-types.js +23 -0
  81. package/src/extension/constants/index.js +37 -0
  82. package/src/extension/constants/keyboard.js +29 -0
  83. package/src/extension/constants/menus-config.js +149 -0
  84. package/src/extension/core/index.js +3 -0
  85. package/src/extension/core/queries/index.js +410 -0
  86. package/src/extension/core/transforms/focus-editor.js +12 -0
  87. package/src/extension/core/transforms/index.js +4 -0
  88. package/src/extension/core/transforms/move-children.js +23 -0
  89. package/src/extension/core/transforms/remove-node-children.js +8 -0
  90. package/src/extension/core/transforms/replace-node-children.js +14 -0
  91. package/src/extension/core/utils/index.js +76 -0
  92. package/src/extension/editor.js +14 -0
  93. package/src/extension/index.js +15 -0
  94. package/src/extension/plugins/blockquote/helpers.js +65 -0
  95. package/src/extension/plugins/blockquote/index.js +13 -0
  96. package/src/extension/plugins/blockquote/menu/index.js +31 -0
  97. package/src/extension/plugins/blockquote/plugin.js +64 -0
  98. package/src/extension/plugins/blockquote/render-elem.js +9 -0
  99. package/src/extension/plugins/check-list/helper.js +34 -0
  100. package/src/extension/plugins/check-list/index.js +14 -0
  101. package/src/extension/plugins/check-list/menu/index.js +44 -0
  102. package/src/extension/plugins/check-list/plugin.js +46 -0
  103. package/src/extension/plugins/check-list/render-elem.js +23 -0
  104. package/src/extension/plugins/clear-format/helpers.js +48 -0
  105. package/src/extension/plugins/clear-format/menu/index.js +39 -0
  106. package/src/extension/plugins/code-block/helpers.js +107 -0
  107. package/src/extension/plugins/code-block/index.js +14 -0
  108. package/src/extension/plugins/code-block/menu/index.js +40 -0
  109. package/src/extension/plugins/code-block/plugin.js +210 -0
  110. package/src/extension/plugins/code-block/render-elem/constant.js +17 -0
  111. package/src/extension/plugins/code-block/render-elem/index.js +55 -0
  112. package/src/extension/plugins/code-block/render-elem/language-selector.js +38 -0
  113. package/src/extension/plugins/code-block/render-elem/style.css +27 -0
  114. package/src/extension/plugins/formula/formula.css +22 -0
  115. package/src/extension/plugins/formula/helper.js +68 -0
  116. package/src/extension/plugins/formula/index.js +14 -0
  117. package/src/extension/plugins/formula/menu/formula-modal.js +73 -0
  118. package/src/extension/plugins/formula/menu/index.js +63 -0
  119. package/src/extension/plugins/formula/plugin.js +18 -0
  120. package/src/extension/plugins/formula/render-elem.js +40 -0
  121. package/src/extension/plugins/header/helper.js +47 -0
  122. package/src/extension/plugins/header/index.js +14 -0
  123. package/src/extension/plugins/header/menu/index.js +114 -0
  124. package/src/extension/plugins/header/menu/style.css +115 -0
  125. package/src/extension/plugins/header/plugin.js +134 -0
  126. package/src/extension/plugins/header/render-elem.js +31 -0
  127. package/src/extension/plugins/image/helper.js +50 -0
  128. package/src/extension/plugins/image/index.js +14 -0
  129. package/src/extension/plugins/image/menu/image-menu-dialog.js +68 -0
  130. package/src/extension/plugins/image/menu/image-menu-popover.js +76 -0
  131. package/src/extension/plugins/image/menu/index.js +61 -0
  132. package/src/extension/plugins/image/menu/style.css +36 -0
  133. package/src/extension/plugins/image/plugin.js +23 -0
  134. package/src/extension/plugins/image/render-element/image-previewer.js +71 -0
  135. package/src/extension/plugins/image/render-element/index.js +94 -0
  136. package/src/extension/plugins/image/render-element/style.css +60 -0
  137. package/src/extension/plugins/index.js +47 -0
  138. package/src/extension/plugins/link/helper.js +161 -0
  139. package/src/extension/plugins/link/index.js +14 -0
  140. package/src/extension/plugins/link/menu/index.js +82 -0
  141. package/src/extension/plugins/link/menu/link-modal.js +135 -0
  142. package/src/extension/plugins/link/plugin.js +85 -0
  143. package/src/extension/plugins/link/render-elem/index.js +69 -0
  144. package/src/extension/plugins/link/render-elem/link-popover.js +79 -0
  145. package/src/extension/plugins/link/render-elem/style.css +60 -0
  146. package/src/extension/plugins/list/constant.js +3 -0
  147. package/src/extension/plugins/list/helpers.js +53 -0
  148. package/src/extension/plugins/list/index.js +14 -0
  149. package/src/extension/plugins/list/menu/index.js +48 -0
  150. package/src/extension/plugins/list/plugin/index.js +48 -0
  151. package/src/extension/plugins/list/plugin/insert-break-list.js +25 -0
  152. package/src/extension/plugins/list/plugin/insert-fragment-list.js +162 -0
  153. package/src/extension/plugins/list/plugin/normalize-list.js +64 -0
  154. package/src/extension/plugins/list/plugin/on-tab-handle.js +34 -0
  155. package/src/extension/plugins/list/queries/index.js +39 -0
  156. package/src/extension/plugins/list/render-elem/index.js +26 -0
  157. package/src/extension/plugins/list/render-elem/style.css +6 -0
  158. package/src/extension/plugins/list/transforms/index.js +23 -0
  159. package/src/extension/plugins/list/transforms/insert-list-item.js +65 -0
  160. package/src/extension/plugins/list/transforms/move-list-item-down.js +40 -0
  161. package/src/extension/plugins/list/transforms/move-list-item-up.js +105 -0
  162. package/src/extension/plugins/list/transforms/move-list-items-to-list.js +58 -0
  163. package/src/extension/plugins/list/transforms/move-list-items.js +76 -0
  164. package/src/extension/plugins/list/transforms/normalize-list-item.js +92 -0
  165. package/src/extension/plugins/list/transforms/normalize-nested-list.js +31 -0
  166. package/src/extension/plugins/list/transforms/remove-first-list-item.js +11 -0
  167. package/src/extension/plugins/list/transforms/transforms-to-list.js +91 -0
  168. package/src/extension/plugins/list/transforms/unwrap-list.js +44 -0
  169. package/src/extension/plugins/node-id/constants.js +18 -0
  170. package/src/extension/plugins/node-id/helpers.js +61 -0
  171. package/src/extension/plugins/node-id/index.js +7 -0
  172. package/src/extension/plugins/node-id/with-node-id.js +37 -0
  173. package/src/extension/plugins/paragraph/helper.js +9 -0
  174. package/src/extension/plugins/paragraph/index.js +12 -0
  175. package/src/extension/plugins/paragraph/plugin.js +40 -0
  176. package/src/extension/plugins/paragraph/render-elem.js +11 -0
  177. package/src/extension/plugins/table/constant.js +3 -0
  178. package/src/extension/plugins/table/helper.js +175 -0
  179. package/src/extension/plugins/table/index.js +15 -0
  180. package/src/extension/plugins/table/menu/index.js +69 -0
  181. package/src/extension/plugins/table/menu/style.css +32 -0
  182. package/src/extension/plugins/table/menu/table-operator.js +101 -0
  183. package/src/extension/plugins/table/menu/table-size-selector.js +71 -0
  184. package/src/extension/plugins/table/model.js +69 -0
  185. package/src/extension/plugins/table/plugin.js +159 -0
  186. package/src/extension/plugins/table/render-elem/context-menu.js +78 -0
  187. package/src/extension/plugins/table/render-elem/index.js +157 -0
  188. package/src/extension/plugins/table/render-elem/style.css +94 -0
  189. package/src/extension/plugins/table/table-operations.js +162 -0
  190. package/src/extension/plugins/text-style/helpers.js +38 -0
  191. package/src/extension/plugins/text-style/index.js +12 -0
  192. package/src/extension/plugins/text-style/menu/index.js +41 -0
  193. package/src/extension/plugins/text-style/plugin.js +37 -0
  194. package/src/extension/plugins/text-style/render-elem.js +45 -0
  195. package/src/extension/render/render-element.js +82 -0
  196. package/src/extension/render/render-leaf.js +16 -0
  197. package/src/extension/toolbar/header-toolbar/index.js +129 -0
  198. package/src/extension/toolbar/header-toolbar/style.css +41 -0
  199. package/src/extension/toolbar/index.js +5 -0
  200. package/src/extension/toolbar/user-help/shortcut-dialog.js +144 -0
  201. package/src/hooks/use-mathjax.js +44 -0
  202. package/src/hooks/use-scroll-context.js +14 -0
  203. package/src/hooks/use-selection-update.js +14 -0
  204. package/src/index.js +22 -0
  205. package/src/pages/markdown-editor.js +53 -0
  206. package/src/pages/markdown-view.js +36 -0
  207. package/src/pages/rich-markdown-editor.js +95 -0
  208. package/src/pages/simple-editor.js +52 -0
  209. package/src/slate-convert/html-to-slate/constants.js +54 -0
  210. package/src/slate-convert/html-to-slate/helper.js +22 -0
  211. package/src/slate-convert/html-to-slate/index.js +144 -0
  212. package/src/slate-convert/html-to-slate/rules/blockquote.js +16 -0
  213. package/src/slate-convert/html-to-slate/rules/check-list.js +22 -0
  214. package/src/slate-convert/html-to-slate/rules/code-block.js +91 -0
  215. package/src/slate-convert/html-to-slate/rules/header.js +18 -0
  216. package/src/slate-convert/html-to-slate/rules/image.js +18 -0
  217. package/src/slate-convert/html-to-slate/rules/index.js +23 -0
  218. package/src/slate-convert/html-to-slate/rules/link.js +24 -0
  219. package/src/slate-convert/html-to-slate/rules/list.js +52 -0
  220. package/src/slate-convert/html-to-slate/rules/paragraph.js +16 -0
  221. package/src/slate-convert/html-to-slate/rules/table.js +37 -0
  222. package/src/slate-convert/html-to-slate/rules/text.js +63 -0
  223. package/src/slate-convert/index.js +11 -0
  224. package/src/slate-convert/md-to-html/index.js +44 -0
  225. package/src/slate-convert/md-to-html/sanitize-schema.js +41 -0
  226. package/src/slate-convert/md-to-slate/index.js +42 -0
  227. package/src/slate-convert/md-to-slate/transform.js +336 -0
  228. package/src/slate-convert/slate-to-md/index.js +44 -0
  229. package/src/slate-convert/slate-to-md/transform.js +248 -0
  230. package/src/utils/common.js +30 -0
  231. package/src/utils/deserialize-html.js +174 -0
  232. package/src/utils/dom-utils.js +45 -0
  233. package/src/utils/event-bus.js +37 -0
  234. package/src/utils/event-handler.js +36 -0
  235. package/src/utils/object-utils.js +51 -0
  236. package/tests/core/constants/index.js +54 -0
  237. package/tests/core/index.js +11 -0
  238. package/tests/core/jsx/index.js +9 -0
  239. package/tests/core/stub-editor/index.js +26 -0
  240. package/tests/core/utils.js +58 -0
  241. package/tests/extension/plugins/list/insert-block.test.js +40 -0
  242. package/tests/extension/plugins/list/insert-fragment-list.test.js +392 -0
  243. package/tests/extension/plugins/list/toggle-list.test.js +160 -0
  244. package/tests/extension/plugins/text/text.test.js +29 -0
  245. package/tests/extension/plugins/text-style/toggle-text-style.test.js +148 -0
  246. package/tests/slate-convert/html-to-slate/blockquote.test.js +107 -0
  247. package/tests/slate-convert/html-to-slate/code-block.test.js +32 -0
  248. package/tests/slate-convert/html-to-slate/header.test.js +56 -0
  249. package/tests/slate-convert/html-to-slate/link.test.js +77 -0
  250. package/tests/slate-convert/html-to-slate/list.test.js +190 -0
  251. package/tests/slate-convert/html-to-slate/paragraph.test.js +40 -0
  252. package/tests/slate-convert/html-to-slate/text.test.js +131 -0
  253. package/tests/slate-convert/md-to-html/blockquote.test.js +110 -0
  254. package/tests/slate-convert/md-to-html/check-list.test.js +19 -0
  255. package/tests/slate-convert/md-to-html/code-block.test.js +19 -0
  256. package/tests/slate-convert/md-to-html/header.test.js +20 -0
  257. package/tests/slate-convert/md-to-html/image.test.js +17 -0
  258. package/tests/slate-convert/md-to-html/image_reference.test.js +17 -0
  259. package/tests/slate-convert/md-to-html/link.test.js +15 -0
  260. package/tests/slate-convert/md-to-html/link_reference.test.js +15 -0
  261. package/tests/slate-convert/md-to-html/list-ordered.test.js +22 -0
  262. package/tests/slate-convert/md-to-html/list-unordered.test.js +22 -0
  263. package/tests/slate-convert/md-to-html/paragraph.test.js +15 -0
  264. package/tests/slate-convert/md-to-html/table.test.js +29 -0
  265. package/tests/slate-convert/md-to-html/text_base.test.js +14 -0
  266. package/tests/slate-convert/md-to-html/text_bold.test.js +14 -0
  267. package/tests/slate-convert/md-to-html/text_bold_italic.test.js +15 -0
  268. package/tests/slate-convert/md-to-html/text_code.test.js +14 -0
  269. package/tests/slate-convert/md-to-html/text_code_bold.test.js +14 -0
  270. package/tests/slate-convert/md-to-html/text_code_bold_italic.test.js +14 -0
  271. package/tests/slate-convert/md-to-html/text_code_italic.test.js +14 -0
  272. package/tests/slate-convert/md-to-html/text_italic.test.js +14 -0
  273. package/tests/slate-convert/md-to-slate/blockquote.test.js +200 -0
  274. package/tests/slate-convert/md-to-slate/check-list.test.js +34 -0
  275. package/tests/slate-convert/md-to-slate/code-block.test.js +32 -0
  276. package/tests/slate-convert/md-to-slate/header.test.js +49 -0
  277. package/tests/slate-convert/md-to-slate/image.test.js +31 -0
  278. package/tests/slate-convert/md-to-slate/link.test.js +30 -0
  279. package/tests/slate-convert/md-to-slate/list-ordered.test.js +42 -0
  280. package/tests/slate-convert/md-to-slate/list-unordered.test.js +42 -0
  281. package/tests/slate-convert/md-to-slate/paragraph.test.js +19 -0
  282. package/tests/slate-convert/md-to-slate/table.test.js +34 -0
  283. package/tests/slate-convert/md-to-slate/text_base.test.js +19 -0
  284. package/tests/slate-convert/md-to-slate/text_bold.test.js +22 -0
  285. package/tests/slate-convert/md-to-slate/text_bold_italic.test.js +23 -0
  286. package/tests/slate-convert/md-to-slate/text_code.test.js +22 -0
  287. package/tests/slate-convert/md-to-slate/text_code_bold.test.js +23 -0
  288. package/tests/slate-convert/md-to-slate/text_code_bold_italic.test.js +24 -0
  289. package/tests/slate-convert/md-to-slate/text_code_italic.test.js +23 -0
  290. package/tests/slate-convert/md-to-slate/text_italic.test.js +22 -0
  291. package/tests/slate-convert/slate-to-md/blockquote.test.js +416 -0
  292. package/tests/slate-convert/slate-to-md/check-list.test.js +96 -0
  293. package/tests/slate-convert/slate-to-md/code-block.test.js +35 -0
  294. package/tests/slate-convert/slate-to-md/formula.test.js +26 -0
  295. package/tests/slate-convert/slate-to-md/header.test.js +109 -0
  296. package/tests/slate-convert/slate-to-md/image.test.js +98 -0
  297. package/tests/slate-convert/slate-to-md/link.test.js +52 -0
  298. package/tests/slate-convert/slate-to-md/list-ordered.test.js +87 -0
  299. package/tests/slate-convert/slate-to-md/list-unordered.test.js +81 -0
  300. package/tests/slate-convert/slate-to-md/paragraph.test.js +28 -0
  301. package/tests/slate-convert/slate-to-md/table.test.js +56 -0
  302. package/tests/slate-convert/slate-to-md/text_base.test.js +28 -0
  303. package/tests/slate-convert/slate-to-md/text_bold.test.js +36 -0
  304. package/tests/slate-convert/slate-to-md/text_bold_italic.test.js +42 -0
  305. package/tests/slate-convert/slate-to-md/text_code.test.js +31 -0
  306. package/tests/slate-convert/slate-to-md/text_code_bold.test.js +37 -0
  307. package/tests/slate-convert/slate-to-md/text_code_bold_italic.test.js +43 -0
  308. package/tests/slate-convert/slate-to-md/text_code_italic.test.js +37 -0
  309. package/tests/slate-convert/slate-to-md/text_italic.test.js +36 -0
  310. package/README.md +0 -52
  311. package/TODO.md +0 -55
  312. package/dist/assets/css/diff-viewer.css +0 -105
  313. package/dist/assets/css/formula.css +0 -19
  314. package/dist/assets/css/history-viewer.css +0 -104
  315. package/dist/assets/css/image.css +0 -134
  316. package/dist/assets/css/link.css +0 -7
  317. package/dist/assets/css/markdown-editor.css +0 -12
  318. package/dist/assets/css/markdown-viewer.css +0 -69
  319. package/dist/assets/css/navbar-imgbutton.css +0 -83
  320. package/dist/assets/css/outline.css +0 -29
  321. package/dist/assets/css/table.css +0 -57
  322. package/dist/assets/css/textlink-hovermenu.css +0 -47
  323. package/dist/assets/css/topbar.css +0 -350
  324. package/dist/assets/css/tree-view.css +0 -67
  325. package/dist/assets/editor/seatable-editor.css +0 -77
  326. package/dist/assets/editor/simple-editor.css +0 -77
  327. package/dist/components/click-outside.js +0 -46
  328. package/dist/components/context-menu.js +0 -97
  329. package/dist/components/dialogs/add-formula-dialog.js +0 -116
  330. package/dist/components/dialogs/add-image-dialog.js +0 -69
  331. package/dist/components/dialogs/add-link-dialog.js +0 -133
  332. package/dist/components/dialogs/shortcut-dialog.js +0 -131
  333. package/dist/components/error-boundary.js +0 -28
  334. package/dist/components/load-script/index.js +0 -69
  335. package/dist/components/loading.js +0 -25
  336. package/dist/components/menu/index.js +0 -4
  337. package/dist/components/menu/item.js +0 -49
  338. package/dist/components/menu/menu.js +0 -38
  339. package/dist/components/menu/style.css +0 -42
  340. package/dist/components/modal-portal.js +0 -38
  341. package/dist/components/outline/index.js +0 -92
  342. package/dist/components/outline/outline-item.js +0 -58
  343. package/dist/components/select/_option.js +0 -44
  344. package/dist/components/select/field-setting.js +0 -106
  345. package/dist/components/select/index.js +0 -149
  346. package/dist/components/select/style.css +0 -144
  347. package/dist/components/svg-icons/check-mark-icon.js +0 -14
  348. package/dist/components/svg-icons/column-icon.js +0 -17
  349. package/dist/components/svg-icons/text-icon.js +0 -34
  350. package/dist/components/text-link-hover-menu/index.js +0 -123
  351. package/dist/components/toast/alert.js +0 -138
  352. package/dist/components/toast/index.js +0 -3
  353. package/dist/components/toast/toast.js +0 -159
  354. package/dist/components/toast/toastManager.js +0 -139
  355. package/dist/components/toast/toaster.js +0 -65
  356. package/dist/components/toolbar/header-list.js +0 -114
  357. package/dist/components/toolbar/help-group.js +0 -33
  358. package/dist/components/toolbar/index.js +0 -4
  359. package/dist/components/toolbar/insert-image.js +0 -106
  360. package/dist/components/toolbar/insert-table.js +0 -136
  361. package/dist/components/toolbar/table-group.js +0 -74
  362. package/dist/components/toolbar/toolbar.js +0 -317
  363. package/dist/components/toolbar/widgets/button-group.js +0 -24
  364. package/dist/components/toolbar/widgets/button-item.js +0 -129
  365. package/dist/components/toolbar/widgets/drop-list.js +0 -88
  366. package/dist/components/user-help/index.js +0 -179
  367. package/dist/config.js +0 -15
  368. package/dist/constants/cell-types.js +0 -29
  369. package/dist/constants/column.js +0 -4
  370. package/dist/containers/code-highlight-package.js +0 -14
  371. package/dist/containers/controller/block-element-controller.js +0 -375
  372. package/dist/containers/controller/index.js +0 -5
  373. package/dist/containers/controller/inline-element-controller.js +0 -134
  374. package/dist/containers/controller/normalize-controller.js +0 -95
  375. package/dist/containers/controller/shortcut-controller.js +0 -385
  376. package/dist/containers/controller/void-element-controller.js +0 -9
  377. package/dist/containers/custom/custom.js +0 -18
  378. package/dist/containers/custom/get-event-transfer.js +0 -33
  379. package/dist/containers/custom/getNodesByTypeAtRange.js +0 -57
  380. package/dist/containers/custom/insertNodes.js +0 -120
  381. package/dist/containers/custom/is-empty-paragraph.js +0 -9
  382. package/dist/containers/custom/split-nodes-at-point.js +0 -136
  383. package/dist/containers/custom/unwrap-node-by-type-at-range.js +0 -70
  384. package/dist/containers/editor-context.js +0 -85
  385. package/dist/containers/editor-utils/block-element-utils/blockquote-utils.js +0 -80
  386. package/dist/containers/editor-utils/block-element-utils/code-utils.js +0 -145
  387. package/dist/containers/editor-utils/block-element-utils/formula-utils.js +0 -51
  388. package/dist/containers/editor-utils/block-element-utils/index.js +0 -31
  389. package/dist/containers/editor-utils/block-element-utils/list-utils.js +0 -395
  390. package/dist/containers/editor-utils/block-element-utils/table-utils.js +0 -412
  391. package/dist/containers/editor-utils/clear-format-utils.js +0 -84
  392. package/dist/containers/editor-utils/common-editor-utils.js +0 -492
  393. package/dist/containers/editor-utils/inline-element-utils/index.js +0 -95
  394. package/dist/containers/editor-utils/mark-utils.js +0 -20
  395. package/dist/containers/editor-utils/range-utils.js +0 -7
  396. package/dist/containers/editor-utils/selection-utils.js +0 -30
  397. package/dist/containers/editor-utils/text-utils.js +0 -117
  398. package/dist/containers/editor-widgets/check-list-item.js +0 -53
  399. package/dist/containers/editor-widgets/code-block.js +0 -128
  400. package/dist/containers/editor-widgets/column.js +0 -100
  401. package/dist/containers/editor-widgets/formula.js +0 -67
  402. package/dist/containers/editor-widgets/image.js +0 -237
  403. package/dist/containers/editor-widgets/link.js +0 -9
  404. package/dist/containers/editor-widgets/table.js +0 -144
  405. package/dist/containers/element-model/blockquote.js +0 -13
  406. package/dist/containers/element-model/column.js +0 -19
  407. package/dist/containers/element-model/image.js +0 -16
  408. package/dist/containers/element-model/link.js +0 -16
  409. package/dist/containers/element-model/table.js +0 -57
  410. package/dist/containers/element-model/text.js +0 -10
  411. package/dist/containers/render-utils/common-utils.js +0 -80
  412. package/dist/containers/render-utils/editor-utils.js +0 -133
  413. package/dist/containers/render-utils/viewer-utils.js +0 -198
  414. package/dist/containers/viewer-widgets/viewer-formula/index.js +0 -54
  415. package/dist/containers/viewer-widgets/viewer-image/index.js +0 -70
  416. package/dist/containers/viewer-widgets/viewer-image/viewer-image.css +0 -3
  417. package/dist/editors/index.js +0 -78
  418. package/dist/editors/markdown-editor.js +0 -206
  419. package/dist/editors/plain-markdown-editor.js +0 -285
  420. package/dist/editors/seatable-editor.js +0 -210
  421. package/dist/editors/simple-editor.js +0 -200
  422. package/dist/index.js +0 -11
  423. package/dist/setting.local.js +0 -14
  424. package/dist/utils/deserialize-html.js +0 -260
  425. package/dist/utils/diff/compare-strings.js +0 -35
  426. package/dist/utils/diff/diff.js +0 -769
  427. package/dist/utils/diff/index.js +0 -2
  428. package/dist/utils/seafile-markdown2html.js +0 -52
  429. package/dist/utils/slate2markdown/deserialize.js +0 -588
  430. package/dist/utils/slate2markdown/index.js +0 -3
  431. package/dist/utils/slate2markdown/serialize.js +0 -366
  432. package/dist/utils/utils.js +0 -68
  433. package/dist/viewer/diff-viewer.js +0 -85
  434. package/dist/viewer/index.js +0 -4
  435. package/dist/viewer/markdown-viewer.js +0 -121
  436. package/dist/viewer/seatable-viewer.js +0 -63
  437. package/dist/viewer/slate-viewer.js +0 -71
  438. package/public/index.html +0 -45
  439. package/public/manifest.json +0 -15
  440. package/public/media/seafile-logo.png +0 -0
  441. /package/{dist/assets/css/keyboard-shortcuts.css → src/extension/toolbar/user-help/style.css} +0 -0
@@ -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 };
@@ -1,106 +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 { Dropdown, DropdownToggle, DropdownMenu, DropdownItem, Tooltip, Label, Input } from 'reactstrap';
7
- import { withTranslation } from 'react-i18next';
8
- import EditorContext from '../../containers/editor-context';
9
- var InsertImage = /*#__PURE__*/function (_React$Component) {
10
- _inherits(InsertImage, _React$Component);
11
- var _super = _createSuper(InsertImage);
12
- function InsertImage() {
13
- var _this;
14
- _classCallCheck(this, InsertImage);
15
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
16
- args[_key] = arguments[_key];
17
- }
18
- _this = _super.call.apply(_super, [this].concat(args));
19
- _this.state = {
20
- dropdownOpen: false,
21
- tooltipOpen: false
22
- };
23
- _this.imgToggle = function () {
24
- _this.setState({
25
- dropdownOpen: !_this.state.dropdownOpen
26
- });
27
- };
28
- _this.toggle = function () {
29
- if (_this.props.disabled) {
30
- _this.setState({
31
- tooltipOpen: false
32
- });
33
- return;
34
- }
35
- _this.setState({
36
- tooltipOpen: !_this.state.tooltipOpen
37
- });
38
- };
39
- _this.uploadLocalImage = function (event) {
40
- var editor = EditorContext.getEditor();
41
- if (editor.editorApi.uploadLocalImage) {
42
- editor.editorApi.uploadLocalImage(event.target.files[0]).then(function (res) {
43
- _this.props.onInsertImage({
44
- url: res
45
- });
46
- });
47
- }
48
- };
49
- _this.handleFileChange = function (event) {
50
- _this.uploadLocalImage(event);
51
- _this.setState({
52
- dropdownOpen: false
53
- });
54
- };
55
- _this.onInputFile = function (event) {
56
- event.target.value = null;
57
- event.nativeEvent.stopImmediatePropagation();
58
- event.stopPropagation();
59
- };
60
- return _this;
61
- }
62
- _createClass(InsertImage, [{
63
- key: "render",
64
- value: function render() {
65
- var t = this.props.t;
66
- return /*#__PURE__*/React.createElement(Dropdown, {
67
- isOpen: this.state.dropdownOpen,
68
- toggle: this.imgToggle,
69
- className: this.props.disabled ? 'upload-localimg upload-localimg-disabled' : 'upload-localimg upload-localimg-hover'
70
- }, /*#__PURE__*/React.createElement(DropdownToggle, {
71
- id: this.props.id,
72
- disabled: this.props.disabled
73
- }, /*#__PURE__*/React.createElement("i", {
74
- className: "iconfont icon-image"
75
- }), /*#__PURE__*/React.createElement(Tooltip, {
76
- toggle: this.toggle,
77
- delay: {
78
- show: 0,
79
- hide: 0
80
- },
81
- target: this.props.id,
82
- placement: "bottom",
83
- isOpen: this.state.tooltipOpen
84
- }, t('insert_image'))), /*#__PURE__*/React.createElement(DropdownMenu, null, /*#__PURE__*/React.createElement(DropdownItem, {
85
- onClick: this.props.onToggleImageDialog
86
- }, t('insert_network_image')), !!this.props.insertRepoFile && /*#__PURE__*/React.createElement(DropdownItem, {
87
- onMouseDown: this.props.insertRepoFile
88
- }, t('Insert_library_image')), /*#__PURE__*/React.createElement(DropdownItem, {
89
- className: "image-uploader-btn"
90
- }, /*#__PURE__*/React.createElement(Label, {
91
- className: "image-uploader-label",
92
- for: "image-uploader",
93
- onClick: this.onInputFile
94
- }, t('upload_local_image')), /*#__PURE__*/React.createElement(Input, {
95
- type: "file",
96
- accept: "image/*",
97
- onChange: this.handleFileChange,
98
- onClick: this.onInputFile,
99
- className: "image-uploader",
100
- id: "image-uploader"
101
- }))));
102
- }
103
- }]);
104
- return InsertImage;
105
- }(React.Component);
106
- export default withTranslation('seafile-editor')(InsertImage);
@@ -1,136 +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, { Component } from 'react';
6
- import ClickOutside from '../click-outside';
7
- import ButtonItem from './widgets/button-item';
8
- var InsertTable = /*#__PURE__*/function (_Component) {
9
- _inherits(InsertTable, _Component);
10
- var _super = _createSuper(InsertTable);
11
- function InsertTable(props) {
12
- var _this;
13
- _classCallCheck(this, InsertTable);
14
- _this = _super.call(this, props);
15
- _this.toggleCard = function (event) {
16
- if (event) {
17
- event.stopPropagation();
18
- event.nativeEvent.stopImmediatePropagation();
19
- }
20
- _this.setState({
21
- showCard: !_this.state.showCard,
22
- columnCount: -1,
23
- rowCount: -1
24
- });
25
- };
26
- _this.createTableCells = function () {
27
- var rows = [];
28
- var _this$state = _this.state,
29
- columnCount = _this$state.columnCount,
30
- rowCount = _this$state.rowCount,
31
- currentMaxColumnCount = _this$state.currentMaxColumnCount,
32
- currentMaxRowCount = _this$state.currentMaxRowCount;
33
- var _loop = function _loop(rowIndex) {
34
- var cells = [];
35
- var _loop2 = function _loop2(columnIndex) {
36
- var isActive = columnIndex <= columnCount - 1 && rowIndex <= rowCount - 1;
37
- var vDom = /*#__PURE__*/React.createElement("div", {
38
- onMouseEnter: function onMouseEnter() {
39
- return _this.onTableCellMouseEnter(rowIndex, columnIndex);
40
- },
41
- key: "table-row-".concat(rowIndex, "-").concat(columnIndex),
42
- className: "sf-editor-table-card-cell ".concat(isActive ? 'sf-editor-table-card-active-cell' : '')
43
- });
44
- cells.push(vDom);
45
- };
46
- for (var columnIndex = 0; columnIndex < currentMaxColumnCount; columnIndex++) {
47
- _loop2(columnIndex);
48
- }
49
- var row = /*#__PURE__*/React.createElement("div", {
50
- key: "table-row-".concat(rowIndex),
51
- className: "sf-editor-table-card-row"
52
- }, cells);
53
- rows.push(row);
54
- };
55
- for (var rowIndex = 0; rowIndex < currentMaxRowCount; rowIndex++) {
56
- _loop(rowIndex);
57
- }
58
- return /*#__PURE__*/React.createElement("div", {
59
- onClick: function onClick(event) {
60
- return _this.onAddTable(event, rowCount, columnCount);
61
- },
62
- className: "sf-editor-table-card"
63
- }, rows);
64
- };
65
- _this.onAddTable = function (event, rowCount, columnCount) {
66
- _this.props.onAddTable(event, rowCount, columnCount);
67
- _this.toggleCard();
68
- };
69
- _this.onTableCellMouseEnter = function (rowIndex, columnIndex) {
70
- var columnCount = columnIndex + 1,
71
- rowCount = rowIndex + 1;
72
- var currentMaxRowCount = rowCount + 1,
73
- currentMaxColumnCount = columnCount + 1;
74
- if (currentMaxColumnCount > 10) {
75
- currentMaxColumnCount = 10;
76
- } else if (currentMaxColumnCount < 4) {
77
- currentMaxColumnCount = 4;
78
- }
79
- if (currentMaxRowCount > 10) {
80
- currentMaxRowCount = 10;
81
- } else if (currentMaxRowCount < 4) {
82
- currentMaxRowCount = 4;
83
- }
84
- _this.setState({
85
- columnCount: columnCount,
86
- rowCount: rowCount,
87
- currentMaxColumnCount: currentMaxColumnCount,
88
- currentMaxRowCount: currentMaxRowCount
89
- });
90
- };
91
- _this.state = {
92
- showCard: false,
93
- currentMaxColumnCount: 4,
94
- currentMaxRowCount: 4,
95
- columnCount: -1,
96
- rowCount: -1
97
- };
98
- return _this;
99
- }
100
- _createClass(InsertTable, [{
101
- key: "createTableScaleCard",
102
- value: function createTableScaleCard(props) {
103
- var _this$state2 = this.state,
104
- columnCount = _this$state2.columnCount,
105
- rowCount = _this$state2.rowCount;
106
- return /*#__PURE__*/React.createElement("div", {
107
- className: "sf-editor-table-count-card"
108
- }, /*#__PURE__*/React.createElement("div", {
109
- className: "sf-editor-table-cells-header"
110
- }, "".concat(columnCount < 0 ? 0 : columnCount, " x ").concat(rowCount < 0 ? 0 : rowCount)), this.createTableCells());
111
- }
112
- }, {
113
- key: "render",
114
- value: function render() {
115
- var _this$props = this.props,
116
- disabled = _this$props.disabled,
117
- isRichEditor = _this$props.isRichEditor,
118
- text = _this$props.text;
119
- var showCard = this.state.showCard;
120
- return /*#__PURE__*/React.createElement("div", {
121
- className: "sf-editor-table-btn-wrapper"
122
- }, /*#__PURE__*/React.createElement(ButtonItem, {
123
- disabled: disabled,
124
- isRichEditor: isRichEditor,
125
- text: text,
126
- id: 'tableButton',
127
- icon: 'iconfont icon-table',
128
- onMouseDown: this.toggleCard
129
- }), showCard && /*#__PURE__*/React.createElement(ClickOutside, {
130
- clickOutside: this.toggleCard
131
- }, this.createTableScaleCard()));
132
- }
133
- }]);
134
- return InsertTable;
135
- }(Component);
136
- export default InsertTable;
@@ -1,74 +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 ButtonGroup from './widgets/button-group';
8
- import ButtonItem from './widgets/button-item';
9
- import DropList from './widgets/drop-list';
10
- var InsertTable = /*#__PURE__*/function (_React$PureComponent) {
11
- _inherits(InsertTable, _React$PureComponent);
12
- var _super = _createSuper(InsertTable);
13
- function InsertTable() {
14
- _classCallCheck(this, InsertTable);
15
- return _super.apply(this, arguments);
16
- }
17
- _createClass(InsertTable, [{
18
- key: "render",
19
- value: function render() {
20
- var _this = this;
21
- return /*#__PURE__*/React.createElement(ButtonGroup, {
22
- className: 'editor-btn-group'
23
- }, /*#__PURE__*/React.createElement(DropList, {
24
- icon: 'iconfont icon-left-alignment',
25
- items: [{
26
- handle: function handle(e) {
27
- _this.props.onSetAlign(e, 'left');
28
- },
29
- icon: 'iconfont icon-left-alignment',
30
- text: this.props.t('left')
31
- }, {
32
- handle: function handle(e) {
33
- _this.props.onSetAlign(e, 'center');
34
- },
35
- icon: 'iconfont icon-center-horizontally',
36
- text: this.props.t('center')
37
- }, {
38
- handle: function handle(e) {
39
- _this.props.onSetAlign(e, 'right');
40
- },
41
- icon: 'iconfont icon-align-right',
42
- text: this.props.t('right')
43
- }]
44
- }), /*#__PURE__*/React.createElement(DropList, {
45
- icon: 'iconfont icon-column',
46
- items: [{
47
- handle: this.props.onInsertColumn,
48
- text: this.props.t('Insert_Column')
49
- }, {
50
- handle: this.props.onRemoveColumn,
51
- text: this.props.t('Remove_Column')
52
- }]
53
- }), /*#__PURE__*/React.createElement(DropList, {
54
- icon: 'iconfont icon-row',
55
- items: [{
56
- handle: this.props.onInsertRow,
57
- text: this.props.t('Insert_Row')
58
- }, {
59
- handle: this.props.onRemoveRow,
60
- text: this.props.t('Remove_Row')
61
- }]
62
- }), /*#__PURE__*/React.createElement(ButtonItem, {
63
- disabled: false,
64
- isRichEditor: true,
65
- text: this.props.t('remove_table'),
66
- id: 'removeTable',
67
- icon: 'iconfont icon-delete-table',
68
- onMouseDown: this.props.onRemoveTable
69
- }));
70
- }
71
- }]);
72
- return InsertTable;
73
- }(React.PureComponent);
74
- export default withTranslation('seafile-editor')(InsertTable);