@opentiny/fluent-editor 3.20.2-alpha.0 → 3.20.2

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 (530) hide show
  1. package/dist/package.json +52 -0
  2. package/package.json +3 -3
  3. package/scripts/pre-release.js +34 -0
  4. package/src/assets/better-table.scss +367 -0
  5. package/src/assets/common.scss +279 -0
  6. package/src/assets/counter.scss +19 -0
  7. package/src/assets/custom-image.scss +20 -0
  8. package/src/assets/editor.scss +365 -0
  9. package/src/assets/emoji/emoji.scss +461 -0
  10. package/src/assets/emoji/style.scss +252 -0
  11. package/src/assets/fileBar.scss +116 -0
  12. package/src/assets/font.scss +36 -0
  13. package/src/assets/fullscreen.scss +21 -0
  14. package/src/assets/iconfont/iconfont.ttf +0 -0
  15. package/src/assets/iconfont/iconfont.woff +0 -0
  16. package/src/assets/iconfont/iconfont.woff2 +0 -0
  17. package/src/assets/image1.png +0 -0
  18. package/src/assets/lineHeight.scss +16 -0
  19. package/src/assets/link.scss +130 -0
  20. package/src/assets/mention.scss +48 -0
  21. package/src/assets/screenshot.scss +78 -0
  22. package/src/assets/size.scss +13 -0
  23. package/src/assets/style.scss +39 -0
  24. package/src/assets/tasklist.scss +76 -0
  25. package/src/assets/toolbar.scss +416 -0
  26. package/src/attributors/font-size.ts +6 -0
  27. package/src/attributors/font-style.ts +6 -0
  28. package/src/attributors/index.ts +4 -0
  29. package/src/attributors/line-height.ts +6 -0
  30. package/src/attributors/text-indent.ts +6 -0
  31. package/src/config/base64-image.ts +8 -0
  32. package/src/config/editor.config.ts +88 -0
  33. package/src/config/editor.utils.ts +199 -0
  34. package/src/config/i18n/en-us.ts +106 -0
  35. package/src/config/i18n/zh-cn.ts +104 -0
  36. package/src/config/icons.config.ts +297 -0
  37. package/src/config/index.ts +171 -0
  38. package/src/config/types/additional-toolbar-item.interface.ts +8 -0
  39. package/src/config/types/content-change.interface.ts +13 -0
  40. package/src/config/types/content-save.interface.ts +6 -0
  41. package/src/config/types/counter-option.interface.ts +9 -0
  42. package/src/config/types/editor-config.interface.ts +22 -0
  43. package/src/config/types/editor-modules.interface.ts +41 -0
  44. package/src/config/types/file-operation.interface.ts +12 -0
  45. package/src/config/types/focus-change.interface.ts +4 -0
  46. package/src/config/types/fullscreen-module.interface.ts +4 -0
  47. package/src/config/types/help-panel-item.interface.ts +5 -0
  48. package/src/config/types/help-panel-option.interface.ts +7 -0
  49. package/src/config/types/image-module.interface.ts +3 -0
  50. package/src/config/types/image-upload.interface.ts +7 -0
  51. package/src/config/types/index.ts +22 -0
  52. package/src/config/types/load-on-demand-module.interface.ts +5 -0
  53. package/src/config/types/mention-module.interface.ts +8 -0
  54. package/src/config/types/paste-change.interface.ts +6 -0
  55. package/src/config/types/quick-menu-module.interface.ts +3 -0
  56. package/src/config/types/range.interface.ts +4 -0
  57. package/src/config/types/registry-options.interface.ts +5 -0
  58. package/src/config/types/selection-change.interface.ts +8 -0
  59. package/src/config/types/toolbar-item.interface.ts +13 -0
  60. package/src/config/types/type.ts +5 -0
  61. package/src/config/types/validate-error.interface.ts +11 -0
  62. package/src/counter/index.ts +69 -0
  63. package/src/custom-clipboard.ts +633 -0
  64. package/src/custom-image/BlotFormatter.ts +167 -0
  65. package/src/custom-image/Options.ts +150 -0
  66. package/src/custom-image/actions/Action.ts +13 -0
  67. package/src/custom-image/actions/CustomResizeAction.ts +207 -0
  68. package/src/custom-image/actions/DeleteAction.ts +29 -0
  69. package/src/custom-image/image.ts +118 -0
  70. package/src/custom-image/specs/BlotSpec.ts +30 -0
  71. package/src/custom-image/specs/CustomImageSpec.ts +139 -0
  72. package/src/custom-image/specs/ImageSpec.ts +33 -0
  73. package/src/custom-uploader.ts +199 -0
  74. package/src/emoji/emoji-list/index.ts +1 -0
  75. package/src/emoji/emoji-list/people.ts +111 -0
  76. package/src/emoji/emoji-list.ts +9 -0
  77. package/src/emoji/emoji-map.ts +9 -0
  78. package/src/emoji/formats/emoji-blot.ts +54 -0
  79. package/src/emoji/index.ts +5 -0
  80. package/src/emoji/modules/emoji.ts +318 -0
  81. package/src/emoji/modules/toolbar-emoji.ts +182 -0
  82. package/src/emoji/utils.ts +15 -0
  83. package/src/file/formats/file.ts +67 -0
  84. package/src/file/index.ts +38 -0
  85. package/src/file/modules/file-bar.ts +146 -0
  86. package/src/fluent-editor.ts +164 -0
  87. package/src/format-painter/index.ts +79 -0
  88. package/src/global-link/constants.ts +3 -0
  89. package/src/global-link/formats/customer-widget-link.ts +36 -0
  90. package/src/global-link/formats/doc-link.ts +55 -0
  91. package/src/global-link/formats/wiki-link.ts +45 -0
  92. package/src/global-link/formats/work-item-link.ts +47 -0
  93. package/src/global-link/global-link-panel.ts +20 -0
  94. package/src/global-link/index.ts +165 -0
  95. package/src/global-link/utils/createTable.ts +54 -0
  96. package/src/index.ts +5 -0
  97. package/src/link/formats/link.ts +44 -0
  98. package/src/link/index.ts +35 -0
  99. package/src/link/modules/tooltip.ts +318 -0
  100. package/src/mention/Mention.ts +406 -0
  101. package/src/mention/MentionLink.ts +51 -0
  102. package/src/mention/constants.ts +3 -0
  103. package/src/quick-menu/index.ts +100 -0
  104. package/src/screenshot/index.ts +231 -0
  105. package/src/soft-break/index.ts +34 -0
  106. package/src/strike/index.ts +16 -0
  107. package/src/syntax/index.ts +35 -0
  108. package/src/table/better-table.ts +553 -0
  109. package/src/table/formats/header.ts +129 -0
  110. package/src/table/formats/list.ts +229 -0
  111. package/src/table/formats/table.ts +1272 -0
  112. package/src/table/modules/table-column-tool.ts +492 -0
  113. package/src/table/modules/table-operation-menu.ts +584 -0
  114. package/src/table/modules/table-scroll-bar.ts +248 -0
  115. package/src/table/modules/table-selection.ts +387 -0
  116. package/src/table/table-config.ts +42 -0
  117. package/src/table/utils/index.ts +62 -0
  118. package/src/table/utils/node-matchers.ts +359 -0
  119. package/src/toolbar/better-picker.ts +370 -0
  120. package/src/toolbar/index.ts +180 -0
  121. package/src/utils/debounce.ts +149 -0
  122. package/src/utils/image.ts +22 -0
  123. package/src/utils/method.ts +82 -0
  124. package/src/utils/scroll-lock.ts +52 -0
  125. package/src/video/index.ts +62 -0
  126. package/tsconfig.json +26 -0
  127. package/vite.config.theme.ts +20 -0
  128. package/vite.config.ts +56 -0
  129. /package/{README.md → dist/README.md} +0 -0
  130. /package/{es → dist/es}/attributors/font-size.es.js +0 -0
  131. /package/{es → dist/es}/attributors/font-size.es.js.map +0 -0
  132. /package/{es → dist/es}/attributors/font-style.es.js +0 -0
  133. /package/{es → dist/es}/attributors/font-style.es.js.map +0 -0
  134. /package/{es → dist/es}/attributors/index.es.js +0 -0
  135. /package/{es → dist/es}/attributors/index.es.js.map +0 -0
  136. /package/{es → dist/es}/attributors/line-height.es.js +0 -0
  137. /package/{es → dist/es}/attributors/line-height.es.js.map +0 -0
  138. /package/{es → dist/es}/attributors/text-indent.es.js +0 -0
  139. /package/{es → dist/es}/attributors/text-indent.es.js.map +0 -0
  140. /package/{es → dist/es}/config/base64-image.es.js +0 -0
  141. /package/{es → dist/es}/config/base64-image.es.js.map +0 -0
  142. /package/{es → dist/es}/config/editor.config.es.js +0 -0
  143. /package/{es → dist/es}/config/editor.config.es.js.map +0 -0
  144. /package/{es → dist/es}/config/editor.utils.es.js +0 -0
  145. /package/{es → dist/es}/config/editor.utils.es.js.map +0 -0
  146. /package/{es → dist/es}/config/i18n/en-us.es.js +0 -0
  147. /package/{es → dist/es}/config/i18n/en-us.es.js.map +0 -0
  148. /package/{es → dist/es}/config/i18n/zh-cn.es.js +0 -0
  149. /package/{es → dist/es}/config/i18n/zh-cn.es.js.map +0 -0
  150. /package/{es → dist/es}/config/icons.config.es.js +0 -0
  151. /package/{es → dist/es}/config/icons.config.es.js.map +0 -0
  152. /package/{es → dist/es}/config/index.es.js +0 -0
  153. /package/{es → dist/es}/config/index.es.js.map +0 -0
  154. /package/{es → dist/es}/config/types/additional-toolbar-item.interface.es.js +0 -0
  155. /package/{es → dist/es}/config/types/additional-toolbar-item.interface.es.js.map +0 -0
  156. /package/{es → dist/es}/config/types/content-change.interface.es.js +0 -0
  157. /package/{es → dist/es}/config/types/content-change.interface.es.js.map +0 -0
  158. /package/{es → dist/es}/config/types/content-save.interface.es.js +0 -0
  159. /package/{es → dist/es}/config/types/content-save.interface.es.js.map +0 -0
  160. /package/{es → dist/es}/config/types/counter-option.interface.es.js +0 -0
  161. /package/{es → dist/es}/config/types/counter-option.interface.es.js.map +0 -0
  162. /package/{es → dist/es}/config/types/editor-config.interface.es.js +0 -0
  163. /package/{es → dist/es}/config/types/editor-config.interface.es.js.map +0 -0
  164. /package/{es → dist/es}/config/types/editor-modules.interface.es.js +0 -0
  165. /package/{es → dist/es}/config/types/editor-modules.interface.es.js.map +0 -0
  166. /package/{es → dist/es}/config/types/file-operation.interface.es.js +0 -0
  167. /package/{es → dist/es}/config/types/file-operation.interface.es.js.map +0 -0
  168. /package/{es → dist/es}/config/types/focus-change.interface.es.js +0 -0
  169. /package/{es → dist/es}/config/types/focus-change.interface.es.js.map +0 -0
  170. /package/{es → dist/es}/config/types/fullscreen-module.interface.es.js +0 -0
  171. /package/{es → dist/es}/config/types/fullscreen-module.interface.es.js.map +0 -0
  172. /package/{es → dist/es}/config/types/help-panel-item.interface.es.js +0 -0
  173. /package/{es → dist/es}/config/types/help-panel-item.interface.es.js.map +0 -0
  174. /package/{es → dist/es}/config/types/help-panel-option.interface.es.js +0 -0
  175. /package/{es → dist/es}/config/types/help-panel-option.interface.es.js.map +0 -0
  176. /package/{es → dist/es}/config/types/image-module.interface.es.js +0 -0
  177. /package/{es → dist/es}/config/types/image-module.interface.es.js.map +0 -0
  178. /package/{es → dist/es}/config/types/image-upload.interface.es.js +0 -0
  179. /package/{es → dist/es}/config/types/image-upload.interface.es.js.map +0 -0
  180. /package/{es → dist/es}/config/types/index.es.js +0 -0
  181. /package/{es → dist/es}/config/types/index.es.js.map +0 -0
  182. /package/{es → dist/es}/config/types/load-on-demand-module.interface.es.js +0 -0
  183. /package/{es → dist/es}/config/types/load-on-demand-module.interface.es.js.map +0 -0
  184. /package/{es → dist/es}/config/types/mention-module.interface.es.js +0 -0
  185. /package/{es → dist/es}/config/types/mention-module.interface.es.js.map +0 -0
  186. /package/{es → dist/es}/config/types/paste-change.interface.es.js +0 -0
  187. /package/{es → dist/es}/config/types/paste-change.interface.es.js.map +0 -0
  188. /package/{es → dist/es}/config/types/quick-menu-module.interface.es.js +0 -0
  189. /package/{es → dist/es}/config/types/quick-menu-module.interface.es.js.map +0 -0
  190. /package/{es → dist/es}/config/types/range.interface.es.js +0 -0
  191. /package/{es → dist/es}/config/types/range.interface.es.js.map +0 -0
  192. /package/{es → dist/es}/config/types/registry-options.interface.es.js +0 -0
  193. /package/{es → dist/es}/config/types/registry-options.interface.es.js.map +0 -0
  194. /package/{es → dist/es}/config/types/selection-change.interface.es.js +0 -0
  195. /package/{es → dist/es}/config/types/selection-change.interface.es.js.map +0 -0
  196. /package/{es → dist/es}/config/types/toolbar-item.interface.es.js +0 -0
  197. /package/{es → dist/es}/config/types/toolbar-item.interface.es.js.map +0 -0
  198. /package/{es → dist/es}/config/types/type.es.js +0 -0
  199. /package/{es → dist/es}/config/types/type.es.js.map +0 -0
  200. /package/{es → dist/es}/config/types/validate-error.interface.es.js +0 -0
  201. /package/{es → dist/es}/config/types/validate-error.interface.es.js.map +0 -0
  202. /package/{es → dist/es}/counter/index.es.js +0 -0
  203. /package/{es → dist/es}/counter/index.es.js.map +0 -0
  204. /package/{es → dist/es}/custom-clipboard.es.js +0 -0
  205. /package/{es → dist/es}/custom-clipboard.es.js.map +0 -0
  206. /package/{es → dist/es}/custom-image/BlotFormatter.es.js +0 -0
  207. /package/{es → dist/es}/custom-image/BlotFormatter.es.js.map +0 -0
  208. /package/{es → dist/es}/custom-image/Options.es.js +0 -0
  209. /package/{es → dist/es}/custom-image/Options.es.js.map +0 -0
  210. /package/{es → dist/es}/custom-image/actions/Action.es.js +0 -0
  211. /package/{es → dist/es}/custom-image/actions/Action.es.js.map +0 -0
  212. /package/{es → dist/es}/custom-image/actions/CustomResizeAction.es.js +0 -0
  213. /package/{es → dist/es}/custom-image/actions/CustomResizeAction.es.js.map +0 -0
  214. /package/{es → dist/es}/custom-image/actions/DeleteAction.es.js +0 -0
  215. /package/{es → dist/es}/custom-image/actions/DeleteAction.es.js.map +0 -0
  216. /package/{es → dist/es}/custom-image/image.es.js +0 -0
  217. /package/{es → dist/es}/custom-image/image.es.js.map +0 -0
  218. /package/{es → dist/es}/custom-image/specs/BlotSpec.es.js +0 -0
  219. /package/{es → dist/es}/custom-image/specs/BlotSpec.es.js.map +0 -0
  220. /package/{es → dist/es}/custom-image/specs/CustomImageSpec.es.js +0 -0
  221. /package/{es → dist/es}/custom-image/specs/CustomImageSpec.es.js.map +0 -0
  222. /package/{es → dist/es}/custom-image/specs/ImageSpec.es.js +0 -0
  223. /package/{es → dist/es}/custom-image/specs/ImageSpec.es.js.map +0 -0
  224. /package/{es → dist/es}/custom-uploader.es.js +0 -0
  225. /package/{es → dist/es}/custom-uploader.es.js.map +0 -0
  226. /package/{es → dist/es}/emoji/emoji-list/index.es.js +0 -0
  227. /package/{es → dist/es}/emoji/emoji-list/index.es.js.map +0 -0
  228. /package/{es → dist/es}/emoji/emoji-list/people.es.js +0 -0
  229. /package/{es → dist/es}/emoji/emoji-list/people.es.js.map +0 -0
  230. /package/{es → dist/es}/emoji/emoji-list.es.js +0 -0
  231. /package/{es → dist/es}/emoji/emoji-list.es.js.map +0 -0
  232. /package/{es → dist/es}/emoji/emoji-map.es.js +0 -0
  233. /package/{es → dist/es}/emoji/emoji-map.es.js.map +0 -0
  234. /package/{es → dist/es}/emoji/formats/emoji-blot.es.js +0 -0
  235. /package/{es → dist/es}/emoji/formats/emoji-blot.es.js.map +0 -0
  236. /package/{es → dist/es}/emoji/index.es.js +0 -0
  237. /package/{es → dist/es}/emoji/index.es.js.map +0 -0
  238. /package/{es → dist/es}/emoji/modules/emoji.es.js +0 -0
  239. /package/{es → dist/es}/emoji/modules/emoji.es.js.map +0 -0
  240. /package/{es → dist/es}/emoji/modules/toolbar-emoji.es.js +0 -0
  241. /package/{es → dist/es}/emoji/modules/toolbar-emoji.es.js.map +0 -0
  242. /package/{es → dist/es}/emoji/utils.es.js +0 -0
  243. /package/{es → dist/es}/emoji/utils.es.js.map +0 -0
  244. /package/{es → dist/es}/file/formats/file.es.js +0 -0
  245. /package/{es → dist/es}/file/formats/file.es.js.map +0 -0
  246. /package/{es → dist/es}/file/index.es.js +0 -0
  247. /package/{es → dist/es}/file/index.es.js.map +0 -0
  248. /package/{es → dist/es}/file/modules/file-bar.es.js +0 -0
  249. /package/{es → dist/es}/file/modules/file-bar.es.js.map +0 -0
  250. /package/{es → dist/es}/fluent-editor.es.js +0 -0
  251. /package/{es → dist/es}/fluent-editor.es.js.map +0 -0
  252. /package/{es → dist/es}/format-painter/index.es.js +0 -0
  253. /package/{es → dist/es}/format-painter/index.es.js.map +0 -0
  254. /package/{es → dist/es}/global-link/constants.es.js +0 -0
  255. /package/{es → dist/es}/global-link/constants.es.js.map +0 -0
  256. /package/{es → dist/es}/global-link/formats/customer-widget-link.es.js +0 -0
  257. /package/{es → dist/es}/global-link/formats/customer-widget-link.es.js.map +0 -0
  258. /package/{es → dist/es}/global-link/formats/doc-link.es.js +0 -0
  259. /package/{es → dist/es}/global-link/formats/doc-link.es.js.map +0 -0
  260. /package/{es → dist/es}/global-link/formats/wiki-link.es.js +0 -0
  261. /package/{es → dist/es}/global-link/formats/wiki-link.es.js.map +0 -0
  262. /package/{es → dist/es}/global-link/formats/work-item-link.es.js +0 -0
  263. /package/{es → dist/es}/global-link/formats/work-item-link.es.js.map +0 -0
  264. /package/{es → dist/es}/global-link/global-link-panel.es.js +0 -0
  265. /package/{es → dist/es}/global-link/global-link-panel.es.js.map +0 -0
  266. /package/{es → dist/es}/global-link/index.es.js +0 -0
  267. /package/{es → dist/es}/global-link/index.es.js.map +0 -0
  268. /package/{es → dist/es}/global-link/utils/createTable.es.js +0 -0
  269. /package/{es → dist/es}/global-link/utils/createTable.es.js.map +0 -0
  270. /package/{es → dist/es}/index.es.js +0 -0
  271. /package/{es → dist/es}/index.es.js.map +0 -0
  272. /package/{es → dist/es}/link/formats/link.es.js +0 -0
  273. /package/{es → dist/es}/link/formats/link.es.js.map +0 -0
  274. /package/{es → dist/es}/link/index.es.js +0 -0
  275. /package/{es → dist/es}/link/index.es.js.map +0 -0
  276. /package/{es → dist/es}/link/modules/tooltip.es.js +0 -0
  277. /package/{es → dist/es}/link/modules/tooltip.es.js.map +0 -0
  278. /package/{es → dist/es}/mention/Mention.es.js +0 -0
  279. /package/{es → dist/es}/mention/Mention.es.js.map +0 -0
  280. /package/{es → dist/es}/mention/MentionLink.es.js +0 -0
  281. /package/{es → dist/es}/mention/MentionLink.es.js.map +0 -0
  282. /package/{es → dist/es}/mention/constants.es.js +0 -0
  283. /package/{es → dist/es}/mention/constants.es.js.map +0 -0
  284. /package/{es → dist/es}/quick-menu/index.es.js +0 -0
  285. /package/{es → dist/es}/quick-menu/index.es.js.map +0 -0
  286. /package/{es → dist/es}/screenshot/index.es.js +0 -0
  287. /package/{es → dist/es}/screenshot/index.es.js.map +0 -0
  288. /package/{es → dist/es}/soft-break/index.es.js +0 -0
  289. /package/{es → dist/es}/soft-break/index.es.js.map +0 -0
  290. /package/{es → dist/es}/strike/index.es.js +0 -0
  291. /package/{es → dist/es}/strike/index.es.js.map +0 -0
  292. /package/{es → dist/es}/syntax/index.es.js +0 -0
  293. /package/{es → dist/es}/syntax/index.es.js.map +0 -0
  294. /package/{es → dist/es}/table/better-table.es.js +0 -0
  295. /package/{es → dist/es}/table/better-table.es.js.map +0 -0
  296. /package/{es → dist/es}/table/formats/header.es.js +0 -0
  297. /package/{es → dist/es}/table/formats/header.es.js.map +0 -0
  298. /package/{es → dist/es}/table/formats/list.es.js +0 -0
  299. /package/{es → dist/es}/table/formats/list.es.js.map +0 -0
  300. /package/{es → dist/es}/table/formats/table.es.js +0 -0
  301. /package/{es → dist/es}/table/formats/table.es.js.map +0 -0
  302. /package/{es → dist/es}/table/modules/table-column-tool.es.js +0 -0
  303. /package/{es → dist/es}/table/modules/table-column-tool.es.js.map +0 -0
  304. /package/{es → dist/es}/table/modules/table-operation-menu.es.js +0 -0
  305. /package/{es → dist/es}/table/modules/table-operation-menu.es.js.map +0 -0
  306. /package/{es → dist/es}/table/modules/table-scroll-bar.es.js +0 -0
  307. /package/{es → dist/es}/table/modules/table-scroll-bar.es.js.map +0 -0
  308. /package/{es → dist/es}/table/modules/table-selection.es.js +0 -0
  309. /package/{es → dist/es}/table/modules/table-selection.es.js.map +0 -0
  310. /package/{es → dist/es}/table/table-config.es.js +0 -0
  311. /package/{es → dist/es}/table/table-config.es.js.map +0 -0
  312. /package/{es → dist/es}/table/utils/index.es.js +0 -0
  313. /package/{es → dist/es}/table/utils/index.es.js.map +0 -0
  314. /package/{es → dist/es}/table/utils/node-matchers.es.js +0 -0
  315. /package/{es → dist/es}/table/utils/node-matchers.es.js.map +0 -0
  316. /package/{es → dist/es}/toolbar/better-picker.es.js +0 -0
  317. /package/{es → dist/es}/toolbar/better-picker.es.js.map +0 -0
  318. /package/{es → dist/es}/toolbar/index.es.js +0 -0
  319. /package/{es → dist/es}/toolbar/index.es.js.map +0 -0
  320. /package/{es → dist/es}/utils/debounce.es.js +0 -0
  321. /package/{es → dist/es}/utils/debounce.es.js.map +0 -0
  322. /package/{es → dist/es}/utils/image.es.js +0 -0
  323. /package/{es → dist/es}/utils/image.es.js.map +0 -0
  324. /package/{es → dist/es}/utils/method.es.js +0 -0
  325. /package/{es → dist/es}/utils/method.es.js.map +0 -0
  326. /package/{es → dist/es}/utils/scroll-lock.es.js +0 -0
  327. /package/{es → dist/es}/utils/scroll-lock.es.js.map +0 -0
  328. /package/{es → dist/es}/video/index.es.js +0 -0
  329. /package/{es → dist/es}/video/index.es.js.map +0 -0
  330. /package/{lib → dist/lib}/attributors/font-size.cjs.js +0 -0
  331. /package/{lib → dist/lib}/attributors/font-size.cjs.js.map +0 -0
  332. /package/{lib → dist/lib}/attributors/font-style.cjs.js +0 -0
  333. /package/{lib → dist/lib}/attributors/font-style.cjs.js.map +0 -0
  334. /package/{lib → dist/lib}/attributors/index.cjs.js +0 -0
  335. /package/{lib → dist/lib}/attributors/index.cjs.js.map +0 -0
  336. /package/{lib → dist/lib}/attributors/line-height.cjs.js +0 -0
  337. /package/{lib → dist/lib}/attributors/line-height.cjs.js.map +0 -0
  338. /package/{lib → dist/lib}/attributors/text-indent.cjs.js +0 -0
  339. /package/{lib → dist/lib}/attributors/text-indent.cjs.js.map +0 -0
  340. /package/{lib → dist/lib}/config/base64-image.cjs.js +0 -0
  341. /package/{lib → dist/lib}/config/base64-image.cjs.js.map +0 -0
  342. /package/{lib → dist/lib}/config/editor.config.cjs.js +0 -0
  343. /package/{lib → dist/lib}/config/editor.config.cjs.js.map +0 -0
  344. /package/{lib → dist/lib}/config/editor.utils.cjs.js +0 -0
  345. /package/{lib → dist/lib}/config/editor.utils.cjs.js.map +0 -0
  346. /package/{lib → dist/lib}/config/i18n/en-us.cjs.js +0 -0
  347. /package/{lib → dist/lib}/config/i18n/en-us.cjs.js.map +0 -0
  348. /package/{lib → dist/lib}/config/i18n/zh-cn.cjs.js +0 -0
  349. /package/{lib → dist/lib}/config/i18n/zh-cn.cjs.js.map +0 -0
  350. /package/{lib → dist/lib}/config/icons.config.cjs.js +0 -0
  351. /package/{lib → dist/lib}/config/icons.config.cjs.js.map +0 -0
  352. /package/{lib → dist/lib}/config/index.cjs.js +0 -0
  353. /package/{lib → dist/lib}/config/index.cjs.js.map +0 -0
  354. /package/{lib → dist/lib}/config/types/additional-toolbar-item.interface.cjs.js +0 -0
  355. /package/{lib → dist/lib}/config/types/additional-toolbar-item.interface.cjs.js.map +0 -0
  356. /package/{lib → dist/lib}/config/types/content-change.interface.cjs.js +0 -0
  357. /package/{lib → dist/lib}/config/types/content-change.interface.cjs.js.map +0 -0
  358. /package/{lib → dist/lib}/config/types/content-save.interface.cjs.js +0 -0
  359. /package/{lib → dist/lib}/config/types/content-save.interface.cjs.js.map +0 -0
  360. /package/{lib → dist/lib}/config/types/counter-option.interface.cjs.js +0 -0
  361. /package/{lib → dist/lib}/config/types/counter-option.interface.cjs.js.map +0 -0
  362. /package/{lib → dist/lib}/config/types/editor-config.interface.cjs.js +0 -0
  363. /package/{lib → dist/lib}/config/types/editor-config.interface.cjs.js.map +0 -0
  364. /package/{lib → dist/lib}/config/types/editor-modules.interface.cjs.js +0 -0
  365. /package/{lib → dist/lib}/config/types/editor-modules.interface.cjs.js.map +0 -0
  366. /package/{lib → dist/lib}/config/types/file-operation.interface.cjs.js +0 -0
  367. /package/{lib → dist/lib}/config/types/file-operation.interface.cjs.js.map +0 -0
  368. /package/{lib → dist/lib}/config/types/focus-change.interface.cjs.js +0 -0
  369. /package/{lib → dist/lib}/config/types/focus-change.interface.cjs.js.map +0 -0
  370. /package/{lib → dist/lib}/config/types/fullscreen-module.interface.cjs.js +0 -0
  371. /package/{lib → dist/lib}/config/types/fullscreen-module.interface.cjs.js.map +0 -0
  372. /package/{lib → dist/lib}/config/types/help-panel-item.interface.cjs.js +0 -0
  373. /package/{lib → dist/lib}/config/types/help-panel-item.interface.cjs.js.map +0 -0
  374. /package/{lib → dist/lib}/config/types/help-panel-option.interface.cjs.js +0 -0
  375. /package/{lib → dist/lib}/config/types/help-panel-option.interface.cjs.js.map +0 -0
  376. /package/{lib → dist/lib}/config/types/image-module.interface.cjs.js +0 -0
  377. /package/{lib → dist/lib}/config/types/image-module.interface.cjs.js.map +0 -0
  378. /package/{lib → dist/lib}/config/types/image-upload.interface.cjs.js +0 -0
  379. /package/{lib → dist/lib}/config/types/image-upload.interface.cjs.js.map +0 -0
  380. /package/{lib → dist/lib}/config/types/index.cjs.js +0 -0
  381. /package/{lib → dist/lib}/config/types/index.cjs.js.map +0 -0
  382. /package/{lib → dist/lib}/config/types/load-on-demand-module.interface.cjs.js +0 -0
  383. /package/{lib → dist/lib}/config/types/load-on-demand-module.interface.cjs.js.map +0 -0
  384. /package/{lib → dist/lib}/config/types/mention-module.interface.cjs.js +0 -0
  385. /package/{lib → dist/lib}/config/types/mention-module.interface.cjs.js.map +0 -0
  386. /package/{lib → dist/lib}/config/types/paste-change.interface.cjs.js +0 -0
  387. /package/{lib → dist/lib}/config/types/paste-change.interface.cjs.js.map +0 -0
  388. /package/{lib → dist/lib}/config/types/quick-menu-module.interface.cjs.js +0 -0
  389. /package/{lib → dist/lib}/config/types/quick-menu-module.interface.cjs.js.map +0 -0
  390. /package/{lib → dist/lib}/config/types/range.interface.cjs.js +0 -0
  391. /package/{lib → dist/lib}/config/types/range.interface.cjs.js.map +0 -0
  392. /package/{lib → dist/lib}/config/types/registry-options.interface.cjs.js +0 -0
  393. /package/{lib → dist/lib}/config/types/registry-options.interface.cjs.js.map +0 -0
  394. /package/{lib → dist/lib}/config/types/selection-change.interface.cjs.js +0 -0
  395. /package/{lib → dist/lib}/config/types/selection-change.interface.cjs.js.map +0 -0
  396. /package/{lib → dist/lib}/config/types/toolbar-item.interface.cjs.js +0 -0
  397. /package/{lib → dist/lib}/config/types/toolbar-item.interface.cjs.js.map +0 -0
  398. /package/{lib → dist/lib}/config/types/type.cjs.js +0 -0
  399. /package/{lib → dist/lib}/config/types/type.cjs.js.map +0 -0
  400. /package/{lib → dist/lib}/config/types/validate-error.interface.cjs.js +0 -0
  401. /package/{lib → dist/lib}/config/types/validate-error.interface.cjs.js.map +0 -0
  402. /package/{lib → dist/lib}/counter/index.cjs.js +0 -0
  403. /package/{lib → dist/lib}/counter/index.cjs.js.map +0 -0
  404. /package/{lib → dist/lib}/custom-clipboard.cjs.js +0 -0
  405. /package/{lib → dist/lib}/custom-clipboard.cjs.js.map +0 -0
  406. /package/{lib → dist/lib}/custom-image/BlotFormatter.cjs.js +0 -0
  407. /package/{lib → dist/lib}/custom-image/BlotFormatter.cjs.js.map +0 -0
  408. /package/{lib → dist/lib}/custom-image/Options.cjs.js +0 -0
  409. /package/{lib → dist/lib}/custom-image/Options.cjs.js.map +0 -0
  410. /package/{lib → dist/lib}/custom-image/actions/Action.cjs.js +0 -0
  411. /package/{lib → dist/lib}/custom-image/actions/Action.cjs.js.map +0 -0
  412. /package/{lib → dist/lib}/custom-image/actions/CustomResizeAction.cjs.js +0 -0
  413. /package/{lib → dist/lib}/custom-image/actions/CustomResizeAction.cjs.js.map +0 -0
  414. /package/{lib → dist/lib}/custom-image/actions/DeleteAction.cjs.js +0 -0
  415. /package/{lib → dist/lib}/custom-image/actions/DeleteAction.cjs.js.map +0 -0
  416. /package/{lib → dist/lib}/custom-image/image.cjs.js +0 -0
  417. /package/{lib → dist/lib}/custom-image/image.cjs.js.map +0 -0
  418. /package/{lib → dist/lib}/custom-image/specs/BlotSpec.cjs.js +0 -0
  419. /package/{lib → dist/lib}/custom-image/specs/BlotSpec.cjs.js.map +0 -0
  420. /package/{lib → dist/lib}/custom-image/specs/CustomImageSpec.cjs.js +0 -0
  421. /package/{lib → dist/lib}/custom-image/specs/CustomImageSpec.cjs.js.map +0 -0
  422. /package/{lib → dist/lib}/custom-image/specs/ImageSpec.cjs.js +0 -0
  423. /package/{lib → dist/lib}/custom-image/specs/ImageSpec.cjs.js.map +0 -0
  424. /package/{lib → dist/lib}/custom-uploader.cjs.js +0 -0
  425. /package/{lib → dist/lib}/custom-uploader.cjs.js.map +0 -0
  426. /package/{lib → dist/lib}/emoji/emoji-list/index.cjs.js +0 -0
  427. /package/{lib → dist/lib}/emoji/emoji-list/index.cjs.js.map +0 -0
  428. /package/{lib → dist/lib}/emoji/emoji-list/people.cjs.js +0 -0
  429. /package/{lib → dist/lib}/emoji/emoji-list/people.cjs.js.map +0 -0
  430. /package/{lib → dist/lib}/emoji/emoji-list.cjs.js +0 -0
  431. /package/{lib → dist/lib}/emoji/emoji-list.cjs.js.map +0 -0
  432. /package/{lib → dist/lib}/emoji/emoji-map.cjs.js +0 -0
  433. /package/{lib → dist/lib}/emoji/emoji-map.cjs.js.map +0 -0
  434. /package/{lib → dist/lib}/emoji/formats/emoji-blot.cjs.js +0 -0
  435. /package/{lib → dist/lib}/emoji/formats/emoji-blot.cjs.js.map +0 -0
  436. /package/{lib → dist/lib}/emoji/index.cjs.js +0 -0
  437. /package/{lib → dist/lib}/emoji/index.cjs.js.map +0 -0
  438. /package/{lib → dist/lib}/emoji/modules/emoji.cjs.js +0 -0
  439. /package/{lib → dist/lib}/emoji/modules/emoji.cjs.js.map +0 -0
  440. /package/{lib → dist/lib}/emoji/modules/toolbar-emoji.cjs.js +0 -0
  441. /package/{lib → dist/lib}/emoji/modules/toolbar-emoji.cjs.js.map +0 -0
  442. /package/{lib → dist/lib}/emoji/utils.cjs.js +0 -0
  443. /package/{lib → dist/lib}/emoji/utils.cjs.js.map +0 -0
  444. /package/{lib → dist/lib}/file/formats/file.cjs.js +0 -0
  445. /package/{lib → dist/lib}/file/formats/file.cjs.js.map +0 -0
  446. /package/{lib → dist/lib}/file/index.cjs.js +0 -0
  447. /package/{lib → dist/lib}/file/index.cjs.js.map +0 -0
  448. /package/{lib → dist/lib}/file/modules/file-bar.cjs.js +0 -0
  449. /package/{lib → dist/lib}/file/modules/file-bar.cjs.js.map +0 -0
  450. /package/{lib → dist/lib}/fluent-editor.cjs.js +0 -0
  451. /package/{lib → dist/lib}/fluent-editor.cjs.js.map +0 -0
  452. /package/{lib → dist/lib}/format-painter/index.cjs.js +0 -0
  453. /package/{lib → dist/lib}/format-painter/index.cjs.js.map +0 -0
  454. /package/{lib → dist/lib}/global-link/constants.cjs.js +0 -0
  455. /package/{lib → dist/lib}/global-link/constants.cjs.js.map +0 -0
  456. /package/{lib → dist/lib}/global-link/formats/customer-widget-link.cjs.js +0 -0
  457. /package/{lib → dist/lib}/global-link/formats/customer-widget-link.cjs.js.map +0 -0
  458. /package/{lib → dist/lib}/global-link/formats/doc-link.cjs.js +0 -0
  459. /package/{lib → dist/lib}/global-link/formats/doc-link.cjs.js.map +0 -0
  460. /package/{lib → dist/lib}/global-link/formats/wiki-link.cjs.js +0 -0
  461. /package/{lib → dist/lib}/global-link/formats/wiki-link.cjs.js.map +0 -0
  462. /package/{lib → dist/lib}/global-link/formats/work-item-link.cjs.js +0 -0
  463. /package/{lib → dist/lib}/global-link/formats/work-item-link.cjs.js.map +0 -0
  464. /package/{lib → dist/lib}/global-link/global-link-panel.cjs.js +0 -0
  465. /package/{lib → dist/lib}/global-link/global-link-panel.cjs.js.map +0 -0
  466. /package/{lib → dist/lib}/global-link/index.cjs.js +0 -0
  467. /package/{lib → dist/lib}/global-link/index.cjs.js.map +0 -0
  468. /package/{lib → dist/lib}/global-link/utils/createTable.cjs.js +0 -0
  469. /package/{lib → dist/lib}/global-link/utils/createTable.cjs.js.map +0 -0
  470. /package/{lib → dist/lib}/index.cjs.js +0 -0
  471. /package/{lib → dist/lib}/index.cjs.js.map +0 -0
  472. /package/{lib → dist/lib}/link/formats/link.cjs.js +0 -0
  473. /package/{lib → dist/lib}/link/formats/link.cjs.js.map +0 -0
  474. /package/{lib → dist/lib}/link/index.cjs.js +0 -0
  475. /package/{lib → dist/lib}/link/index.cjs.js.map +0 -0
  476. /package/{lib → dist/lib}/link/modules/tooltip.cjs.js +0 -0
  477. /package/{lib → dist/lib}/link/modules/tooltip.cjs.js.map +0 -0
  478. /package/{lib → dist/lib}/mention/Mention.cjs.js +0 -0
  479. /package/{lib → dist/lib}/mention/Mention.cjs.js.map +0 -0
  480. /package/{lib → dist/lib}/mention/MentionLink.cjs.js +0 -0
  481. /package/{lib → dist/lib}/mention/MentionLink.cjs.js.map +0 -0
  482. /package/{lib → dist/lib}/mention/constants.cjs.js +0 -0
  483. /package/{lib → dist/lib}/mention/constants.cjs.js.map +0 -0
  484. /package/{lib → dist/lib}/quick-menu/index.cjs.js +0 -0
  485. /package/{lib → dist/lib}/quick-menu/index.cjs.js.map +0 -0
  486. /package/{lib → dist/lib}/screenshot/index.cjs.js +0 -0
  487. /package/{lib → dist/lib}/screenshot/index.cjs.js.map +0 -0
  488. /package/{lib → dist/lib}/soft-break/index.cjs.js +0 -0
  489. /package/{lib → dist/lib}/soft-break/index.cjs.js.map +0 -0
  490. /package/{lib → dist/lib}/strike/index.cjs.js +0 -0
  491. /package/{lib → dist/lib}/strike/index.cjs.js.map +0 -0
  492. /package/{lib → dist/lib}/syntax/index.cjs.js +0 -0
  493. /package/{lib → dist/lib}/syntax/index.cjs.js.map +0 -0
  494. /package/{lib → dist/lib}/table/better-table.cjs.js +0 -0
  495. /package/{lib → dist/lib}/table/better-table.cjs.js.map +0 -0
  496. /package/{lib → dist/lib}/table/formats/header.cjs.js +0 -0
  497. /package/{lib → dist/lib}/table/formats/header.cjs.js.map +0 -0
  498. /package/{lib → dist/lib}/table/formats/list.cjs.js +0 -0
  499. /package/{lib → dist/lib}/table/formats/list.cjs.js.map +0 -0
  500. /package/{lib → dist/lib}/table/formats/table.cjs.js +0 -0
  501. /package/{lib → dist/lib}/table/formats/table.cjs.js.map +0 -0
  502. /package/{lib → dist/lib}/table/modules/table-column-tool.cjs.js +0 -0
  503. /package/{lib → dist/lib}/table/modules/table-column-tool.cjs.js.map +0 -0
  504. /package/{lib → dist/lib}/table/modules/table-operation-menu.cjs.js +0 -0
  505. /package/{lib → dist/lib}/table/modules/table-operation-menu.cjs.js.map +0 -0
  506. /package/{lib → dist/lib}/table/modules/table-scroll-bar.cjs.js +0 -0
  507. /package/{lib → dist/lib}/table/modules/table-scroll-bar.cjs.js.map +0 -0
  508. /package/{lib → dist/lib}/table/modules/table-selection.cjs.js +0 -0
  509. /package/{lib → dist/lib}/table/modules/table-selection.cjs.js.map +0 -0
  510. /package/{lib → dist/lib}/table/table-config.cjs.js +0 -0
  511. /package/{lib → dist/lib}/table/table-config.cjs.js.map +0 -0
  512. /package/{lib → dist/lib}/table/utils/index.cjs.js +0 -0
  513. /package/{lib → dist/lib}/table/utils/index.cjs.js.map +0 -0
  514. /package/{lib → dist/lib}/table/utils/node-matchers.cjs.js +0 -0
  515. /package/{lib → dist/lib}/table/utils/node-matchers.cjs.js.map +0 -0
  516. /package/{lib → dist/lib}/toolbar/better-picker.cjs.js +0 -0
  517. /package/{lib → dist/lib}/toolbar/better-picker.cjs.js.map +0 -0
  518. /package/{lib → dist/lib}/toolbar/index.cjs.js +0 -0
  519. /package/{lib → dist/lib}/toolbar/index.cjs.js.map +0 -0
  520. /package/{lib → dist/lib}/utils/debounce.cjs.js +0 -0
  521. /package/{lib → dist/lib}/utils/debounce.cjs.js.map +0 -0
  522. /package/{lib → dist/lib}/utils/image.cjs.js +0 -0
  523. /package/{lib → dist/lib}/utils/image.cjs.js.map +0 -0
  524. /package/{lib → dist/lib}/utils/method.cjs.js +0 -0
  525. /package/{lib → dist/lib}/utils/method.cjs.js.map +0 -0
  526. /package/{lib → dist/lib}/utils/scroll-lock.cjs.js +0 -0
  527. /package/{lib → dist/lib}/utils/scroll-lock.cjs.js.map +0 -0
  528. /package/{lib → dist/lib}/video/index.cjs.js +0 -0
  529. /package/{lib → dist/lib}/video/index.cjs.js.map +0 -0
  530. /package/{style.css → dist/style.css} +0 -0
@@ -0,0 +1,248 @@
1
+ import { SCROLL_BAR_PANEL_HEIGHT } from '../table-config'
2
+ import { css } from '../utils'
3
+
4
+ export default class TableScrollBar {
5
+ table: any
6
+ quill: any
7
+ modulesContainer: any
8
+ domNode: any
9
+ oldRootScrollTop: any
10
+ // @ts-ignore
11
+ prev: number
12
+ columnToolDomNode: any
13
+ columnCtrlPanel: any
14
+ leftMask: any
15
+ tableViewRect: any
16
+ tableRect: any
17
+ containerRect: any
18
+ subscriber: any
19
+ // @ts-ignore
20
+ tableMoveDistance: number
21
+ // @ts-ignore
22
+ maxBarLeft: number
23
+ // @ts-ignore
24
+ scrollBar: Element
25
+ // @ts-ignore
26
+ isTableOverflow: boolean // 表格是否溢出开关,判断开关值后只改变样式一次,不重复修改
27
+
28
+ constructor(table, quill, dom) {
29
+ if (!table) {
30
+ return
31
+ }
32
+ this.table = table
33
+ this.quill = quill
34
+ this.modulesContainer = dom
35
+ this.domNode = null
36
+ this.oldRootScrollTop = this.quill.root.scrollTop
37
+ this.prev = 0
38
+
39
+ const betterTableModule = this.quill.getModule('better-table')
40
+ const tableColumnTool = betterTableModule.columnTool
41
+ this.columnToolDomNode = tableColumnTool.domNode
42
+ this.columnCtrlPanel = tableColumnTool.columnCtrlPanel
43
+ this.leftMask = tableColumnTool.leftMask
44
+
45
+ this.updateScrollBar()
46
+
47
+ if (this.quill.root === this.quill.scrollingContainer) {
48
+ this.quill.root.addEventListener('scroll', this.handleQuillRootScroll.bind(this))
49
+ }
50
+ }
51
+
52
+ handleQuillRootScroll() {
53
+ if (!this.domNode) {
54
+ return
55
+ }
56
+ const curTableRect = this.table.getBoundingClientRect()
57
+ const curContainerRect = this.quill.root.parentNode.getBoundingClientRect()
58
+ const tableTop = curTableRect.top + SCROLL_BAR_PANEL_HEIGHT
59
+ const tableBottom = curTableRect.top + curTableRect.height - 1
60
+ const containerBottom = curContainerRect.top + curContainerRect.height
61
+ if (containerBottom < tableBottom && containerBottom > tableTop) { // 表格下端溢出容器下端
62
+ if (!this.isTableOverflow) {
63
+ this.isTableOverflow = true
64
+ css(this.domNode, {
65
+ display: 'block',
66
+ top: `${this.containerRect.height - SCROLL_BAR_PANEL_HEIGHT}px`,
67
+ marginTop: '0px',
68
+ })
69
+ }
70
+ }
71
+ else if (containerBottom <= tableTop) { // 表格上端溢出容器下端
72
+ this.isTableOverflow = false
73
+ this.domNode.style.display = 'none'
74
+ }
75
+ else { // 表格下端在容器内
76
+ this.setScrollBarToBottom()
77
+ css(this.domNode, { marginTop: `${this.oldRootScrollTop - this.quill.root.scrollTop}px` })
78
+ }
79
+ }
80
+
81
+ setScrollBarToBottom() {
82
+ if (this.isTableOverflow) {
83
+ this.isTableOverflow = false
84
+ const barPos = this.tableRect.top + this.tableRect.height - this.containerRect.top - 1
85
+ css(this.domNode, { display: 'block', top: `${barPos}px` })
86
+ }
87
+ }
88
+
89
+ resetTableHeight(table) {
90
+ if (this.domNode) {
91
+ // 表格的高度改变,重置初始化tableRect的高度,但不重置其他坐标值
92
+ this.tableRect.height = table.getBoundingClientRect().height
93
+ this.isTableOverflow = !this.isTableOverflow
94
+ this.handleQuillRootScroll()
95
+ }
96
+ }
97
+
98
+ setScrollBarMove(pos, isMouse) {
99
+ // 获取当前滑块左边距和鼠标两次事件节点之间的位移差,计算当前滑块位置及是否显示左右遮罩层,通过比例计算表格位移并赋值
100
+ const currentBarLeft = Number.parseInt(getComputedStyle(this.scrollBar).left, 10)
101
+ let left = isMouse ? pos - this.prev + currentBarLeft : currentBarLeft + pos
102
+ this.showMask(left)
103
+ left = this.getLimitedDistance(left)
104
+ const scale = this.tableViewRect.width / this.tableRect.width
105
+ const move = left / scale
106
+ const columnCtrlPanelLeft = this.tableViewRect.left - this.containerRect.left - move
107
+ css(this.scrollBar, { left: `${left}px` }) // 移动表格滚动条
108
+ css(this.columnCtrlPanel, { left: `${columnCtrlPanelLeft}px` }) // 移动顶部列宽控制条
109
+ this.table.parentNode.scrollLeft = move // 移动表格
110
+ if (isMouse) {
111
+ this.prev = pos
112
+ }
113
+
114
+ // fix: 拖动滚动条时修正选区位置
115
+ const tableSelection = this.quill.getModule('better-table').tableSelection
116
+ if (tableSelection && tableSelection.selectedTds.length) {
117
+ tableSelection.refreshHelpLinesPosition()
118
+ }
119
+ }
120
+
121
+ handleScrollBarMouseDown(mouseDownEvent) {
122
+ mouseDownEvent.preventDefault()
123
+
124
+ this.prev = mouseDownEvent.clientX
125
+ this.subscriber = (mouseMoveEvent: any) => {
126
+ mouseMoveEvent.preventDefault()
127
+ mouseMoveEvent.stopPropagation()
128
+ this.setScrollBarMove(mouseMoveEvent.clientX, true)
129
+ }
130
+ this.quill.root.parentNode.addEventListener('mousemove', this.subscriber, false)
131
+ document.addEventListener('mouseup', this.handleScrollBarMouseup.bind(this), false)
132
+ }
133
+
134
+ handleScrollBarMouseup(event) {
135
+ event.preventDefault()
136
+ this.quill.root.parentNode.removeEventListener('mousemove', this.subscriber)
137
+ document.removeEventListener('mouseup', this.handleScrollBarMouseup.bind(this), false)
138
+ }
139
+
140
+ handleWheel(event) {
141
+ // 按住 Shift 滚动鼠标滚轮,可以对表格进行横向滚动
142
+ if (event.shiftKey) {
143
+ const { deltaY } = event // 每次滚动鼠标滚轮移动的距离
144
+ this.setScrollBarMove(deltaY, false)
145
+ }
146
+ }
147
+
148
+ showMask(distance) {
149
+ // 根据当前滑块左边距判断是否显示左右遮罩层
150
+ if (distance >= Math.floor(this.maxBarLeft)) {
151
+ css(this.leftMask, { display: 'block' })
152
+ }
153
+ else if (distance <= 0) {
154
+ css(this.leftMask, { display: 'none' })
155
+ }
156
+ else {
157
+ css(this.leftMask, { display: 'block' })
158
+ }
159
+ }
160
+
161
+ getLimitedDistance(distance) {
162
+ if (distance >= Math.floor(this.maxBarLeft)) {
163
+ distance = this.maxBarLeft
164
+ }
165
+ else if (distance <= 0) {
166
+ distance = 0
167
+ }
168
+ return distance
169
+ }
170
+
171
+ updateScrollBar() {
172
+ if (!this.table?.parentNode) {
173
+ return
174
+ }
175
+ // 获取表格尺寸和表格容器尺寸
176
+ const tableRect = this.table.getBoundingClientRect()
177
+ const tableViewRect = this.table.parentNode.getBoundingClientRect()
178
+ const tableMoveDistance = tableRect.width - tableViewRect.width // 表格最大移动距离
179
+ this.tableRect = tableRect
180
+ this.tableViewRect = tableViewRect
181
+ this.tableMoveDistance = tableMoveDistance
182
+ this.oldRootScrollTop = this.quill.root.scrollTop
183
+
184
+ if (tableMoveDistance > 0) {
185
+ this.createScrollBar()
186
+ }
187
+ else {
188
+ this.destroyScrollBar()
189
+ }
190
+ }
191
+
192
+ createScrollBar() {
193
+ // 列控制条增加表格相应位移
194
+ const parent = this.quill.root.parentNode
195
+ const containerRect = parent.getBoundingClientRect() // 编辑器容器宽度
196
+ this.containerRect = containerRect
197
+ css(this.columnCtrlPanel, {
198
+ left: `${this.tableViewRect.left - containerRect.left - this.table.parentNode.scrollLeft}px`,
199
+ })
200
+
201
+ // 创建滚动条
202
+ if (this.domNode) {
203
+ this.domNode.remove()
204
+ }
205
+ this.domNode = document.createElement('div')
206
+ this.domNode.classList.add('qlbt-table-scroll-bar-panel')
207
+ this.scrollBar = document.createElement('div')
208
+ this.scrollBar.classList.add('qlbt-table-scroll-bar')
209
+ this.scrollBar.addEventListener('mousedown', this.handleScrollBarMouseDown.bind(this), false)
210
+ const scale = this.tableViewRect.width / this.tableRect.width
211
+ const barWidth = this.tableViewRect.width - this.tableMoveDistance * scale // 滑块宽度
212
+ css(this.scrollBar, { width: `${barWidth}px` })
213
+ this.domNode.appendChild(this.scrollBar)
214
+
215
+ // 判断当前表格是否存在位移,如存在通过比例计算滑块当前位移并赋值
216
+ const tableScrollLeft = this.table.parentNode.scrollLeft
217
+ this.maxBarLeft = this.tableMoveDistance * scale // 滑块最大移动距离
218
+ if (tableScrollLeft) {
219
+ const barLeft = tableScrollLeft * scale
220
+ this.showMask(barLeft)
221
+ css(this.scrollBar, { left: `${this.getLimitedDistance(barLeft)}px` })
222
+ }
223
+
224
+ // 将滚动条插入到 table control panel 中
225
+ const barPos = this.tableRect.top + this.tableRect.height - containerRect.top - 1
226
+ this.isTableOverflow = containerRect.top + containerRect.height < this.tableRect.top + this.tableRect.height
227
+ this.modulesContainer.appendChild(this.domNode)
228
+ css(this.domNode, { top: `${Math.min(containerRect.height - SCROLL_BAR_PANEL_HEIGHT, barPos)}px` })
229
+
230
+ // 绑定鼠标滚轮事件:Shift+鼠标滚轮,滚动表格横向滚动条
231
+ document.addEventListener('wheel', this.handleWheel.bind(this))
232
+ }
233
+
234
+ destroyScrollBar() {
235
+ css(this.leftMask, { display: 'none' })
236
+ this.columnCtrlPanel.removeAttribute('style')
237
+ this.maxBarLeft = null
238
+ this.destroy()
239
+ }
240
+
241
+ destroy() {
242
+ if (this.domNode) {
243
+ this.domNode.remove()
244
+ }
245
+ this.quill.root.removeEventListener('scroll', this.handleQuillRootScroll.bind(this))
246
+ document.removeEventListener('wheel', this.handleWheel.bind(this))
247
+ }
248
+ }
@@ -0,0 +1,387 @@
1
+ import Quill from 'quill'
2
+ import { TableCell } from '../formats/table'
3
+ import { ERROR_LIMIT, LINE_POSITIONS, PRIMARY_COLOR } from '../table-config'
4
+ import { css, getRelativeRect } from '../utils'
5
+
6
+ export default class TableSelection {
7
+ table: any
8
+ quill: any
9
+ modulesContainer: any
10
+ parent: any
11
+ boundary: any
12
+ // @ts-ignore
13
+ selectedTds: any[]
14
+ // @ts-ignore
15
+ dragging: boolean
16
+ preSelectedTable: any
17
+ oldRootScrollTop: any
18
+ selectingHandler: any
19
+ tdEditHandler: any
20
+ tdResizeHandler: any
21
+ endTd: any
22
+ startTd: any
23
+ editTd: any
24
+ left: any
25
+ bottom: any
26
+ top: any
27
+ right: any
28
+
29
+ constructor(table, quill, dom) {
30
+ if (!table) {
31
+ return null
32
+ }
33
+ this.table = table
34
+ this.quill = quill
35
+ this.modulesContainer = dom
36
+ this.parent = this.quill.root.parentNode
37
+ this.boundary = {} // params for selected square
38
+ this.selectedTds = [] // array for selected table-cells
39
+ this.dragging = false
40
+ this.preSelectedTable = null
41
+ this.oldRootScrollTop = this.quill.root.scrollTop
42
+
43
+ this.selectingHandler = this.mouseDownHandler.bind(this)
44
+
45
+ this.tdEditHandler = this.setTdEditable.bind(this)
46
+ this.tdResizeHandler = this.resizeTd.bind(this)
47
+
48
+ this.helpLinesInitial()
49
+ this.isEditorHasScrollBar()
50
+
51
+ this.quill.root.parentNode.addEventListener('mousedown', this.selectingHandler, false)
52
+ this.quill.on('text-change', this.tdResizeHandler)
53
+ if (this.quill.root === this.quill.scrollingContainer) {
54
+ this.quill.root.addEventListener('scroll', this.handleQuillRootScroll.bind(this))
55
+ }
56
+ }
57
+
58
+ handleQuillRootScroll() {
59
+ LINE_POSITIONS.forEach((direction) => {
60
+ const selectionLine = this[direction]
61
+ if (selectionLine) {
62
+ selectionLine.style.marginTop = `${this.oldRootScrollTop - this.quill.root.scrollTop}px`
63
+ }
64
+ })
65
+ }
66
+
67
+ isEditorHasScrollBar() {
68
+ if (this.quill.root.scrollHeight > this.quill.root.clientHeight) {
69
+ css(this.modulesContainer, { width: 'calc(100% - 23px)' })
70
+ }
71
+ else {
72
+ this.modulesContainer.removeAttribute('style')
73
+ }
74
+ }
75
+
76
+ helpLinesInitial() {
77
+ LINE_POSITIONS.forEach((direction) => {
78
+ this[direction] = document.createElement('div')
79
+ this[direction].classList.add('qlbt-selection-line')
80
+ if (direction === 'left') {
81
+ this[direction].classList.add('qlbt-selection-line-first')
82
+ const ctrlPointLeft = document.createElement('div')
83
+ this[direction].appendChild(ctrlPointLeft)
84
+ }
85
+ if (direction === 'bottom') {
86
+ this[direction].classList.add('qlbt-selection-line-last')
87
+ const ctrlPointRight = document.createElement('div')
88
+ this[direction].appendChild(ctrlPointRight)
89
+ }
90
+ css(this[direction], {
91
+ 'position': 'absolute',
92
+ 'display': 'none',
93
+ 'background-color': PRIMARY_COLOR,
94
+ })
95
+ this.modulesContainer.appendChild(this[direction])
96
+ })
97
+ }
98
+
99
+ mouseDownHandler(e) {
100
+ if (e.button !== 0) {
101
+ return
102
+ }
103
+ const self: any = this
104
+ const betterTableModule = this.quill.getModule('better-table')
105
+ const tableColumnTool = betterTableModule.columnTool
106
+ if (tableColumnTool.activeToolCell) {
107
+ tableColumnTool.activeToolCell.classList.remove('qlbt-tool-cell-on')
108
+ tableColumnTool.activeToolCell = null
109
+ }
110
+ if (e.target.closest('.quill-better-table')) {
111
+ if (e.shiftKey) {
112
+ this.endTd = e.target.closest('td[data-row]')
113
+ this.drawSelection(this, true)
114
+ // avoid select text in multiple table-cell
115
+ if (this.startTd !== this.endTd) {
116
+ this.quill.blur()
117
+ }
118
+ }
119
+ else {
120
+ this.startTd = e.target.closest('td[data-row]')
121
+ this.drawSelection(this, false)
122
+ this.dragging = true
123
+
124
+ this.parent.addEventListener('mousemove', mouseMoveHandler, false)
125
+ document.addEventListener('mouseup', mouseUpHandler, false)
126
+ }
127
+ }
128
+ else if (e.target.closest('.qlbt-selection-line')) {
129
+ this.parent.addEventListener('mousemove', mouseMoveHandler, false)
130
+ document.addEventListener('mouseup', mouseUpHandler, false)
131
+ }
132
+
133
+ function mouseMoveHandler(event) {
134
+ event.stopPropagation()
135
+
136
+ if (event.button !== 0 || !event.target.closest('.quill-better-table')) {
137
+ return
138
+ }
139
+ self.endTd = event.target.closest('td[data-row]')
140
+ if (!self.endTd) {
141
+ return
142
+ }
143
+ self.drawSelection(self, true)
144
+ // avoid select text in multiple table-cell
145
+ if (self.startTd !== self.endTd) {
146
+ self.quill.blur()
147
+ }
148
+ }
149
+
150
+ function mouseUpHandler() {
151
+ self.parent.removeEventListener('mousemove', mouseMoveHandler, false)
152
+ document.removeEventListener('mouseup', mouseUpHandler, false)
153
+ self.dragging = false
154
+ }
155
+ }
156
+
157
+ drawSelection(self, end) {
158
+ // fix: 如果滚动条拖动,startTd的位置已经改变了,需要重置startTdRect
159
+ self.startTdRect = getRelativeRect(self.startTd.getBoundingClientRect(), self.quill.root.parentNode)
160
+ let endTdRect = self.startTdRect
161
+ if (end) {
162
+ self.endTdRect = getRelativeRect(self.endTd.getBoundingClientRect(), self.quill.root.parentNode)
163
+ endTdRect = self.endTdRect
164
+ }
165
+ self.boundary = computeBoundaryFromRects(self.startTdRect, endTdRect)
166
+ self.selectedTds = self.computeSelectedTds()
167
+ self.repositionHelpLines()
168
+ }
169
+
170
+ setTdEditable(e) {
171
+ if (!this.editTd) {
172
+ return
173
+ }
174
+ this.parent.removeEventListener('keypress', this.tdEditHandler, false)
175
+ const dom = this.editTd.domNode
176
+ dom.removeEventListener('click', this.tdEditHandler, false)
177
+ dom.classList.add('editing-select-able')
178
+ dom.setAttribute('contenteditable', true)
179
+ if (e.type === 'keypress') {
180
+ if (dom.childNodes.length > 1 || dom.firstChild.innerHTML !== '<br>') {
181
+ const blank = dom.firstChild.cloneNode()
182
+ blank.innerHTML = '<br>'
183
+ dom.innerHTML = ''
184
+ dom.appendChild(blank)
185
+ }
186
+ dom.focus()
187
+ }
188
+ }
189
+
190
+ resizeTd() {
191
+ if (!this.editTd || (this.left && !this.left.offsetParent)) {
192
+ return
193
+ }
194
+ if (this.selectedTds.length > 1) {
195
+ this.refreshHelpLinesPosition()
196
+ }
197
+ else {
198
+ const dom = this.editTd.domNode
199
+ const domRect = getRelativeRect(dom.getBoundingClientRect(), this.quill.root.parentNode)
200
+ this.boundary = computeBoundaryFromRects(domRect, domRect)
201
+ this.repositionHelpLines()
202
+ }
203
+
204
+ // 判断编辑器是否有滚动条,调整遮罩宽度
205
+ this.isEditorHasScrollBar()
206
+
207
+ // 更新行高 更新滑块位置
208
+ const betterTableModule = this.quill.getModule('better-table')
209
+ const tableColumnTool = betterTableModule.columnTool
210
+ if (tableColumnTool) {
211
+ tableColumnTool.updateRowToolCells()
212
+ const tableViewRect = this.table.parentNode.getBoundingClientRect()
213
+ if (tableColumnTool.leftMask) {
214
+ css(tableColumnTool.leftMask, { height: `${tableViewRect.height + 50}px` })
215
+ }
216
+ }
217
+
218
+ const tableScrollBar = betterTableModule.tableScrollBar
219
+ tableScrollBar.resetTableHeight(this.table)
220
+ }
221
+
222
+ resetTd(e) {
223
+ const dom = e.target
224
+ dom.classList.remove('editing-select-able')
225
+ dom.setAttribute('contenteditable', false)
226
+ dom.removeAttribute('contenteditable')
227
+ }
228
+
229
+ correctBoundary() {
230
+ const tableContainer = Quill.find(this.table)
231
+ const tableCells = tableContainer.descendants(TableCell)
232
+
233
+ tableCells.forEach((tableCell) => {
234
+ const { x, y, width, height } = getRelativeRect(tableCell.domNode.getBoundingClientRect(), this.quill.root.parentNode)
235
+ const isCellIntersected
236
+ = ((x + ERROR_LIMIT >= this.boundary.x && x + ERROR_LIMIT <= this.boundary.x1)
237
+ || (x - ERROR_LIMIT + width >= this.boundary.x && x - ERROR_LIMIT + width <= this.boundary.x1))
238
+ && ((y + ERROR_LIMIT >= this.boundary.y && y + ERROR_LIMIT <= this.boundary.y1)
239
+ || (y - ERROR_LIMIT + height >= this.boundary.y && y - ERROR_LIMIT + height <= this.boundary.y1))
240
+ if (isCellIntersected) {
241
+ this.boundary = computeBoundaryFromRects(this.boundary, { x, y, width, height })
242
+ }
243
+ })
244
+ }
245
+
246
+ computeSelectedTds() {
247
+ const tableContainer = Quill.find(this.table)
248
+ const tableCells = tableContainer.descendants(TableCell)
249
+
250
+ const result = tableCells.reduce((selectedCells, tableCell) => {
251
+ const { x, y, width, height } = getRelativeRect(tableCell.domNode.getBoundingClientRect(), this.quill.root.parentNode)
252
+ const isCellIncluded
253
+ = x + ERROR_LIMIT >= this.boundary.x
254
+ && x - ERROR_LIMIT + width <= this.boundary.x1
255
+ && y + ERROR_LIMIT >= this.boundary.y
256
+ && y - ERROR_LIMIT + height <= this.boundary.y1
257
+
258
+ if (isCellIncluded) {
259
+ selectedCells.push(tableCell)
260
+ }
261
+
262
+ return selectedCells
263
+ }, [])
264
+
265
+ if (result.length === 1 && this.editTd !== result[0]) {
266
+ const resetTds = this.table.querySelectorAll('td[contenteditable=true]')
267
+ resetTds.forEach(td => this.resetTd({ target: td }))
268
+ this.editTd = result[0]
269
+ this.editTd.domNode.addEventListener('mousedown', this.tdEditHandler, false)
270
+ this.parent.addEventListener('keypress', this.tdEditHandler, false)
271
+ }
272
+
273
+ return result
274
+ }
275
+
276
+ repositionHelpLines() {
277
+ this.oldRootScrollTop = this.quill.root.scrollTop
278
+ if (!this.left) {
279
+ return
280
+ }
281
+
282
+ css(this.left, {
283
+ 'display': 'block',
284
+ 'left': `${this.boundary.x - 1}px`,
285
+ 'top': `${this.boundary.y}px`,
286
+ 'height': `${this.boundary.height + 1}px`,
287
+ 'width': '1px',
288
+ 'margin-top': '0px',
289
+ })
290
+
291
+ css(this.right, {
292
+ 'display': 'block',
293
+ 'left': `${this.boundary.x1}px`,
294
+ 'top': `${this.boundary.y - 1}px`,
295
+ 'height': `${this.boundary.height + 1}px`,
296
+ 'width': '1px',
297
+ 'margin-top': '0px',
298
+ })
299
+
300
+ css(this.top, {
301
+ 'display': 'block',
302
+ 'left': `${this.boundary.x - 1}px`,
303
+ 'top': `${this.boundary.y - 1}px`,
304
+ 'width': `${this.boundary.width + 1}px`,
305
+ 'height': '1px',
306
+ 'margin-top': '0px',
307
+ })
308
+
309
+ css(this.bottom, {
310
+ 'display': 'block',
311
+ 'left': `${this.boundary.x - 1}px`,
312
+ 'top': `${this.boundary.y1}px`,
313
+ 'width': `${this.boundary.width + 1}px`,
314
+ 'height': '1px',
315
+ 'margin-top': '0px',
316
+ })
317
+ }
318
+
319
+ // based on selectedTds compute positions of help lines
320
+ // It is useful when selectedTds are not changed
321
+ refreshHelpLinesPosition() {
322
+ const startRect = getRelativeRect(this.selectedTds[0].domNode.getBoundingClientRect(), this.quill.root.parentNode)
323
+ const endRect = getRelativeRect(
324
+ this.selectedTds[this.selectedTds.length - 1].domNode.getBoundingClientRect(),
325
+ this.quill.root.parentNode,
326
+ )
327
+ this.boundary = computeBoundaryFromRects(startRect, endRect)
328
+ this.repositionHelpLines()
329
+ }
330
+
331
+ destroy() {
332
+ const resetTds = this.table.querySelectorAll('td[contenteditable=true]')
333
+ resetTds.forEach(td => this.resetTd({ target: td }))
334
+
335
+ LINE_POSITIONS.forEach((direction) => {
336
+ if (this[direction]) {
337
+ this[direction].remove()
338
+ this[direction] = null
339
+ }
340
+ })
341
+
342
+ this.quill.root.parentNode.removeEventListener('mousedown', this.selectingHandler, false)
343
+
344
+ delete this.editTd
345
+
346
+ return null
347
+ }
348
+
349
+ setSelection(startRect, endRect) {
350
+ this.boundary = computeBoundaryFromRects(
351
+ getRelativeRect(startRect, this.quill.root.parentNode),
352
+ getRelativeRect(endRect, this.quill.root.parentNode),
353
+ )
354
+ this.correctBoundary()
355
+ this.selectedTds = this.computeSelectedTds()
356
+ this.repositionHelpLines()
357
+ }
358
+
359
+ clearSelection() {
360
+ const resetTds = this.table.querySelectorAll('td[contenteditable=true]')
361
+ resetTds.forEach(td => this.resetTd({ target: td }))
362
+ this.boundary = {}
363
+ this.selectedTds = []
364
+ LINE_POSITIONS.forEach((direction) => {
365
+ if (this[direction]) {
366
+ css(this[direction], {
367
+ display: 'none',
368
+ })
369
+ }
370
+ })
371
+ }
372
+ }
373
+
374
+ function computeBoundaryFromRects(startRect, endRect) {
375
+ const x = Math.min(startRect.x, endRect.x, startRect.x + startRect.width - 1, endRect.x + endRect.width - 1)
376
+
377
+ const x1 = Math.max(startRect.x, endRect.x, startRect.x + startRect.width - 1, endRect.x + endRect.width - 1)
378
+
379
+ const y = Math.min(startRect.y, endRect.y, startRect.y + startRect.height - 1, endRect.y + endRect.height - 1)
380
+
381
+ const y1 = Math.max(startRect.y, endRect.y, startRect.y + startRect.height - 1, endRect.y + endRect.height - 1)
382
+
383
+ const width = x1 - x
384
+ const height = y1 - y
385
+
386
+ return { x, x1, y, y1, width, height }
387
+ }
@@ -0,0 +1,42 @@
1
+ export const TABLE_CELL_LINE_CLASS = 'qlrte__better-table-cell-line'
2
+ export const ROW_TOOL_CLASS = 'qlrte__row-tool'
3
+ export const ROW_TOOL_CELL_CLASS = 'qlrte__row-tool-cell'
4
+ export const ROW_TOOL_CELL_HOLDER_CLASS = 'qlrte__row-tool-cell-holder'
5
+ export const COL_TOOL_CLASS = 'qlrte__col-tool'
6
+ export const COL_TOOL_CELL_CLASS = 'qlrte__col-tool-cell'
7
+ export const COL_TOOL_CELL_HOLDER_CLASS = 'qlrte__col-tool-cell-holder'
8
+ export const SELECT_LINE_CLASS = 'qlrte__selection-line'
9
+ export const OPERATE_MENU_CLASS = 'qlrte__op-menu'
10
+ export const OPERATE_MENU_ITEM_CLASS = 'qlrte__op-menu-item'
11
+ export const OPERATE_MENU_ICON_CLASS = 'qlrte__op-menu-icon'
12
+ export const OPERATE_MENU_ICON_PREFIX_CLASS = 'qlrte__op-menu-icon-prefix'
13
+ export const OPERATE_MENU_TEXT_CLASS = 'qlrte__op-menu-text'
14
+ export const OPERATE_MENU_DIVIDING_CLASS = 'qlrte__op-menu-dividing'
15
+ export const OPERATE_MENU_SUBTITLE_CLASS = 'qlrte__op-menu-subtitle'
16
+ export const OPERATE_MENU_COLORPICKER_CLASS = 'qlrte__op-menu-color-picker'
17
+ export const OPERATE_MENU_COLORPICKER_ITEM_CLASS
18
+ = 'qlrte__op-menu-color-picker-item'
19
+ export const COL_ATTRIBUTES = ['width']
20
+ export const COL_DEFAULT = {
21
+ width: 100,
22
+ }
23
+ export const CELL_IDENTITY_KEYS = ['row', 'cell']
24
+ export const CELL_ATTRIBUTES = ['rowspan', 'colspan', 'cell-bg', 'list']
25
+ export const CELL_DEFAULT = {
26
+ rowspan: 1,
27
+ colspan: 1,
28
+ }
29
+ export const ERROR_LIMIT = 5
30
+
31
+ export const SCROLL_BAR_PANEL_HEIGHT = 32
32
+ export const ROW_TOOL_WIDTH = 16
33
+ export const COL_TOOL_HEIGHT = 16
34
+ export const CELL_MIN_WIDTH = 50
35
+ export const CELL_MIN_HEIGHT = 29
36
+ export const PRIMARY_COLOR = ['#5170ff', 'var(--brand-1, #5170ff)']
37
+
38
+ export const MENU_ITEM_HEIGHT = 40
39
+ export const MENU_MIN_HEIGHT = 150
40
+ export const MENU_WIDTH = 205
41
+
42
+ export const LINE_POSITIONS = ['left', 'right', 'top', 'bottom']