@8btc/mditor 0.0.1

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 (663) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +623 -0
  3. package/dist/css/content-theme/ant-design.css +210 -0
  4. package/dist/css/content-theme/dark.css +177 -0
  5. package/dist/css/content-theme/light.css +136 -0
  6. package/dist/css/content-theme/wechat.css +94 -0
  7. package/dist/images/emoji/b3log.png +0 -0
  8. package/dist/images/emoji/chainbook.png +0 -0
  9. package/dist/images/emoji/doge.png +0 -0
  10. package/dist/images/emoji/hacpai.png +0 -0
  11. package/dist/images/emoji/huaji.gif +0 -0
  12. package/dist/images/emoji/latke.png +0 -0
  13. package/dist/images/emoji/liandi.png +0 -0
  14. package/dist/images/emoji/lute.png +0 -0
  15. package/dist/images/emoji/octocat.png +0 -0
  16. package/dist/images/emoji/pipe.png +0 -0
  17. package/dist/images/emoji/siyuan.png +0 -0
  18. package/dist/images/emoji/solo.png +0 -0
  19. package/dist/images/emoji/sym.png +0 -0
  20. package/dist/images/emoji/trollface.png +0 -0
  21. package/dist/images/emoji/vditor.png +0 -0
  22. package/dist/images/emoji/wide.png +0 -0
  23. package/dist/images/emoji/wulian.png +0 -0
  24. package/dist/images/img-loading.svg +1 -0
  25. package/dist/images/logo.png +0 -0
  26. package/dist/index.css +1919 -0
  27. package/dist/index.d.ts +82 -0
  28. package/dist/index.js +18263 -0
  29. package/dist/index.min.js +1 -0
  30. package/dist/js/abcjs/abcjs_basic.min.js +3 -0
  31. package/dist/js/color-picker/color-picker.min.css +6 -0
  32. package/dist/js/color-picker/color-picker.nano.css +2 -0
  33. package/dist/js/color-picker/color-picker.nano.js +3 -0
  34. package/dist/js/docx/docx.min.js +1 -0
  35. package/dist/js/echarts/echarts.min.js +45 -0
  36. package/dist/js/flowchart.js/flowchart.min.js +8 -0
  37. package/dist/js/graphviz/full.render.js +90 -0
  38. package/dist/js/graphviz/viz.js +333 -0
  39. package/dist/js/highlight.js/LICENSE +29 -0
  40. package/dist/js/highlight.js/highlight.min.js +3835 -0
  41. package/dist/js/highlight.js/styles/a11y-dark.min.css +7 -0
  42. package/dist/js/highlight.js/styles/a11y-light.min.css +7 -0
  43. package/dist/js/highlight.js/styles/agate.min.css +20 -0
  44. package/dist/js/highlight.js/styles/an-old-hope.min.css +9 -0
  45. package/dist/js/highlight.js/styles/androidstudio.min.css +1 -0
  46. package/dist/js/highlight.js/styles/ant-design.min.css +84 -0
  47. package/dist/js/highlight.js/styles/arduino-light.min.css +1 -0
  48. package/dist/js/highlight.js/styles/arta.min.css +1 -0
  49. package/dist/js/highlight.js/styles/ascetic.min.css +1 -0
  50. package/dist/js/highlight.js/styles/atom-one-dark-reasonable.min.css +1 -0
  51. package/dist/js/highlight.js/styles/atom-one-dark.min.css +1 -0
  52. package/dist/js/highlight.js/styles/atom-one-light.min.css +1 -0
  53. package/dist/js/highlight.js/styles/base16/3024.min.css +7 -0
  54. package/dist/js/highlight.js/styles/base16/apathy.min.css +7 -0
  55. package/dist/js/highlight.js/styles/base16/apprentice.min.css +7 -0
  56. package/dist/js/highlight.js/styles/base16/ashes.min.css +7 -0
  57. package/dist/js/highlight.js/styles/base16/atelier-cave-light.min.css +7 -0
  58. package/dist/js/highlight.js/styles/base16/atelier-cave.min.css +7 -0
  59. package/dist/js/highlight.js/styles/base16/atelier-dune-light.min.css +7 -0
  60. package/dist/js/highlight.js/styles/base16/atelier-dune.min.css +7 -0
  61. package/dist/js/highlight.js/styles/base16/atelier-estuary-light.min.css +7 -0
  62. package/dist/js/highlight.js/styles/base16/atelier-estuary.min.css +7 -0
  63. package/dist/js/highlight.js/styles/base16/atelier-forest-light.min.css +7 -0
  64. package/dist/js/highlight.js/styles/base16/atelier-forest.min.css +7 -0
  65. package/dist/js/highlight.js/styles/base16/atelier-heath-light.min.css +7 -0
  66. package/dist/js/highlight.js/styles/base16/atelier-heath.min.css +7 -0
  67. package/dist/js/highlight.js/styles/base16/atelier-lakeside-light.min.css +7 -0
  68. package/dist/js/highlight.js/styles/base16/atelier-lakeside.min.css +7 -0
  69. package/dist/js/highlight.js/styles/base16/atelier-plateau-light.min.css +7 -0
  70. package/dist/js/highlight.js/styles/base16/atelier-plateau.min.css +7 -0
  71. package/dist/js/highlight.js/styles/base16/atelier-savanna-light.min.css +7 -0
  72. package/dist/js/highlight.js/styles/base16/atelier-savanna.min.css +7 -0
  73. package/dist/js/highlight.js/styles/base16/atelier-seaside-light.min.css +7 -0
  74. package/dist/js/highlight.js/styles/base16/atelier-seaside.min.css +7 -0
  75. package/dist/js/highlight.js/styles/base16/atelier-sulphurpool-light.min.css +7 -0
  76. package/dist/js/highlight.js/styles/base16/atelier-sulphurpool.min.css +7 -0
  77. package/dist/js/highlight.js/styles/base16/atlas.min.css +7 -0
  78. package/dist/js/highlight.js/styles/base16/bespin.min.css +7 -0
  79. package/dist/js/highlight.js/styles/base16/black-metal-bathory.min.css +7 -0
  80. package/dist/js/highlight.js/styles/base16/black-metal-burzum.min.css +7 -0
  81. package/dist/js/highlight.js/styles/base16/black-metal-dark-funeral.min.css +7 -0
  82. package/dist/js/highlight.js/styles/base16/black-metal-gorgoroth.min.css +7 -0
  83. package/dist/js/highlight.js/styles/base16/black-metal-immortal.min.css +7 -0
  84. package/dist/js/highlight.js/styles/base16/black-metal-khold.min.css +7 -0
  85. package/dist/js/highlight.js/styles/base16/black-metal-marduk.min.css +7 -0
  86. package/dist/js/highlight.js/styles/base16/black-metal-mayhem.min.css +7 -0
  87. package/dist/js/highlight.js/styles/base16/black-metal-nile.min.css +7 -0
  88. package/dist/js/highlight.js/styles/base16/black-metal-venom.min.css +7 -0
  89. package/dist/js/highlight.js/styles/base16/black-metal.min.css +7 -0
  90. package/dist/js/highlight.js/styles/base16/brewer.min.css +7 -0
  91. package/dist/js/highlight.js/styles/base16/bright.min.css +7 -0
  92. package/dist/js/highlight.js/styles/base16/brogrammer.min.css +7 -0
  93. package/dist/js/highlight.js/styles/base16/brush-trees-dark.min.css +7 -0
  94. package/dist/js/highlight.js/styles/base16/brush-trees.min.css +7 -0
  95. package/dist/js/highlight.js/styles/base16/chalk.min.css +7 -0
  96. package/dist/js/highlight.js/styles/base16/circus.min.css +7 -0
  97. package/dist/js/highlight.js/styles/base16/classic-dark.min.css +7 -0
  98. package/dist/js/highlight.js/styles/base16/classic-light.min.css +7 -0
  99. package/dist/js/highlight.js/styles/base16/codeschool.min.css +7 -0
  100. package/dist/js/highlight.js/styles/base16/colors.min.css +7 -0
  101. package/dist/js/highlight.js/styles/base16/cupcake.min.css +7 -0
  102. package/dist/js/highlight.js/styles/base16/cupertino.min.css +7 -0
  103. package/dist/js/highlight.js/styles/base16/danqing.min.css +7 -0
  104. package/dist/js/highlight.js/styles/base16/darcula.min.css +7 -0
  105. package/dist/js/highlight.js/styles/base16/dark-violet.min.css +7 -0
  106. package/dist/js/highlight.js/styles/base16/darkmoss.min.css +7 -0
  107. package/dist/js/highlight.js/styles/base16/darktooth.min.css +7 -0
  108. package/dist/js/highlight.js/styles/base16/decaf.min.css +7 -0
  109. package/dist/js/highlight.js/styles/base16/default-dark.min.css +7 -0
  110. package/dist/js/highlight.js/styles/base16/default-light.min.css +7 -0
  111. package/dist/js/highlight.js/styles/base16/dirtysea.min.css +7 -0
  112. package/dist/js/highlight.js/styles/base16/dracula.min.css +7 -0
  113. package/dist/js/highlight.js/styles/base16/edge-dark.min.css +7 -0
  114. package/dist/js/highlight.js/styles/base16/edge-light.min.css +7 -0
  115. package/dist/js/highlight.js/styles/base16/eighties.min.css +7 -0
  116. package/dist/js/highlight.js/styles/base16/embers.min.css +7 -0
  117. package/dist/js/highlight.js/styles/base16/equilibrium-dark.min.css +7 -0
  118. package/dist/js/highlight.js/styles/base16/equilibrium-gray-dark.min.css +7 -0
  119. package/dist/js/highlight.js/styles/base16/equilibrium-gray-light.min.css +7 -0
  120. package/dist/js/highlight.js/styles/base16/equilibrium-light.min.css +7 -0
  121. package/dist/js/highlight.js/styles/base16/espresso.min.css +7 -0
  122. package/dist/js/highlight.js/styles/base16/eva-dim.min.css +7 -0
  123. package/dist/js/highlight.js/styles/base16/eva.min.css +7 -0
  124. package/dist/js/highlight.js/styles/base16/flat.min.css +7 -0
  125. package/dist/js/highlight.js/styles/base16/framer.min.css +7 -0
  126. package/dist/js/highlight.js/styles/base16/fruit-soda.min.css +7 -0
  127. package/dist/js/highlight.js/styles/base16/gigavolt.min.css +7 -0
  128. package/dist/js/highlight.js/styles/base16/github.min.css +7 -0
  129. package/dist/js/highlight.js/styles/base16/google-dark.min.css +7 -0
  130. package/dist/js/highlight.js/styles/base16/google-light.min.css +7 -0
  131. package/dist/js/highlight.js/styles/base16/grayscale-dark.min.css +7 -0
  132. package/dist/js/highlight.js/styles/base16/grayscale-light.min.css +7 -0
  133. package/dist/js/highlight.js/styles/base16/green-screen.min.css +7 -0
  134. package/dist/js/highlight.js/styles/base16/gruvbox-dark-hard.min.css +7 -0
  135. package/dist/js/highlight.js/styles/base16/gruvbox-dark-medium.min.css +7 -0
  136. package/dist/js/highlight.js/styles/base16/gruvbox-dark-pale.min.css +7 -0
  137. package/dist/js/highlight.js/styles/base16/gruvbox-dark-soft.min.css +7 -0
  138. package/dist/js/highlight.js/styles/base16/gruvbox-light-hard.min.css +7 -0
  139. package/dist/js/highlight.js/styles/base16/gruvbox-light-medium.min.css +7 -0
  140. package/dist/js/highlight.js/styles/base16/gruvbox-light-soft.min.css +7 -0
  141. package/dist/js/highlight.js/styles/base16/hardcore.min.css +7 -0
  142. package/dist/js/highlight.js/styles/base16/harmonic16-dark.min.css +7 -0
  143. package/dist/js/highlight.js/styles/base16/harmonic16-light.min.css +7 -0
  144. package/dist/js/highlight.js/styles/base16/heetch-dark.min.css +7 -0
  145. package/dist/js/highlight.js/styles/base16/heetch-light.min.css +7 -0
  146. package/dist/js/highlight.js/styles/base16/helios.min.css +7 -0
  147. package/dist/js/highlight.js/styles/base16/hopscotch.min.css +7 -0
  148. package/dist/js/highlight.js/styles/base16/horizon-dark.min.css +7 -0
  149. package/dist/js/highlight.js/styles/base16/horizon-light.min.css +7 -0
  150. package/dist/js/highlight.js/styles/base16/humanoid-dark.min.css +7 -0
  151. package/dist/js/highlight.js/styles/base16/humanoid-light.min.css +7 -0
  152. package/dist/js/highlight.js/styles/base16/ia-dark.min.css +7 -0
  153. package/dist/js/highlight.js/styles/base16/ia-light.min.css +7 -0
  154. package/dist/js/highlight.js/styles/base16/icy-dark.min.css +7 -0
  155. package/dist/js/highlight.js/styles/base16/ir-black.min.css +7 -0
  156. package/dist/js/highlight.js/styles/base16/isotope.min.css +7 -0
  157. package/dist/js/highlight.js/styles/base16/kimber.min.css +7 -0
  158. package/dist/js/highlight.js/styles/base16/london-tube.min.css +7 -0
  159. package/dist/js/highlight.js/styles/base16/macintosh.min.css +7 -0
  160. package/dist/js/highlight.js/styles/base16/marrakesh.min.css +7 -0
  161. package/dist/js/highlight.js/styles/base16/materia.min.css +7 -0
  162. package/dist/js/highlight.js/styles/base16/material-darker.min.css +7 -0
  163. package/dist/js/highlight.js/styles/base16/material-lighter.min.css +7 -0
  164. package/dist/js/highlight.js/styles/base16/material-palenight.min.css +7 -0
  165. package/dist/js/highlight.js/styles/base16/material-vivid.min.css +7 -0
  166. package/dist/js/highlight.js/styles/base16/material.min.css +7 -0
  167. package/dist/js/highlight.js/styles/base16/mellow-purple.min.css +7 -0
  168. package/dist/js/highlight.js/styles/base16/mexico-light.min.css +7 -0
  169. package/dist/js/highlight.js/styles/base16/mocha.min.css +7 -0
  170. package/dist/js/highlight.js/styles/base16/monokai.min.css +7 -0
  171. package/dist/js/highlight.js/styles/base16/nebula.min.css +7 -0
  172. package/dist/js/highlight.js/styles/base16/nord.min.css +7 -0
  173. package/dist/js/highlight.js/styles/base16/nova.min.css +7 -0
  174. package/dist/js/highlight.js/styles/base16/ocean.min.css +7 -0
  175. package/dist/js/highlight.js/styles/base16/oceanicnext.min.css +7 -0
  176. package/dist/js/highlight.js/styles/base16/one-light.min.css +7 -0
  177. package/dist/js/highlight.js/styles/base16/onedark.min.css +7 -0
  178. package/dist/js/highlight.js/styles/base16/outrun-dark.min.css +7 -0
  179. package/dist/js/highlight.js/styles/base16/papercolor-dark.min.css +7 -0
  180. package/dist/js/highlight.js/styles/base16/papercolor-light.min.css +7 -0
  181. package/dist/js/highlight.js/styles/base16/paraiso.min.css +7 -0
  182. package/dist/js/highlight.js/styles/base16/pasque.min.css +7 -0
  183. package/dist/js/highlight.js/styles/base16/phd.min.css +7 -0
  184. package/dist/js/highlight.js/styles/base16/pico.min.css +7 -0
  185. package/dist/js/highlight.js/styles/base16/pop.min.css +7 -0
  186. package/dist/js/highlight.js/styles/base16/porple.min.css +7 -0
  187. package/dist/js/highlight.js/styles/base16/qualia.min.css +7 -0
  188. package/dist/js/highlight.js/styles/base16/railscasts.min.css +7 -0
  189. package/dist/js/highlight.js/styles/base16/rebecca.min.css +7 -0
  190. package/dist/js/highlight.js/styles/base16/ros-pine-dawn.min.css +7 -0
  191. package/dist/js/highlight.js/styles/base16/ros-pine-moon.min.css +7 -0
  192. package/dist/js/highlight.js/styles/base16/ros-pine.min.css +7 -0
  193. package/dist/js/highlight.js/styles/base16/sagelight.min.css +7 -0
  194. package/dist/js/highlight.js/styles/base16/sandcastle.min.css +7 -0
  195. package/dist/js/highlight.js/styles/base16/seti-ui.min.css +7 -0
  196. package/dist/js/highlight.js/styles/base16/shapeshifter.min.css +7 -0
  197. package/dist/js/highlight.js/styles/base16/silk-dark.min.css +7 -0
  198. package/dist/js/highlight.js/styles/base16/silk-light.min.css +7 -0
  199. package/dist/js/highlight.js/styles/base16/snazzy.min.css +7 -0
  200. package/dist/js/highlight.js/styles/base16/solar-flare-light.min.css +7 -0
  201. package/dist/js/highlight.js/styles/base16/solar-flare.min.css +7 -0
  202. package/dist/js/highlight.js/styles/base16/solarized-dark.min.css +7 -0
  203. package/dist/js/highlight.js/styles/base16/solarized-light.min.css +7 -0
  204. package/dist/js/highlight.js/styles/base16/spacemacs.min.css +7 -0
  205. package/dist/js/highlight.js/styles/base16/summercamp.min.css +7 -0
  206. package/dist/js/highlight.js/styles/base16/summerfruit-dark.min.css +7 -0
  207. package/dist/js/highlight.js/styles/base16/summerfruit-light.min.css +7 -0
  208. package/dist/js/highlight.js/styles/base16/synth-midnight-terminal-dark.min.css +7 -0
  209. package/dist/js/highlight.js/styles/base16/synth-midnight-terminal-light.min.css +7 -0
  210. package/dist/js/highlight.js/styles/base16/tango.min.css +7 -0
  211. package/dist/js/highlight.js/styles/base16/tender.min.css +7 -0
  212. package/dist/js/highlight.js/styles/base16/tomorrow-night.min.css +7 -0
  213. package/dist/js/highlight.js/styles/base16/tomorrow.min.css +7 -0
  214. package/dist/js/highlight.js/styles/base16/twilight.min.css +7 -0
  215. package/dist/js/highlight.js/styles/base16/unikitty-dark.min.css +7 -0
  216. package/dist/js/highlight.js/styles/base16/unikitty-light.min.css +7 -0
  217. package/dist/js/highlight.js/styles/base16/vulcan.min.css +7 -0
  218. package/dist/js/highlight.js/styles/base16/windows-10-light.min.css +7 -0
  219. package/dist/js/highlight.js/styles/base16/windows-10.min.css +7 -0
  220. package/dist/js/highlight.js/styles/base16/windows-95-light.min.css +7 -0
  221. package/dist/js/highlight.js/styles/base16/windows-95.min.css +7 -0
  222. package/dist/js/highlight.js/styles/base16/windows-high-contrast-light.min.css +7 -0
  223. package/dist/js/highlight.js/styles/base16/windows-high-contrast.min.css +7 -0
  224. package/dist/js/highlight.js/styles/base16/windows-nt-light.min.css +7 -0
  225. package/dist/js/highlight.js/styles/base16/windows-nt.min.css +7 -0
  226. package/dist/js/highlight.js/styles/base16/woodland.min.css +7 -0
  227. package/dist/js/highlight.js/styles/base16/xcode-dusk.min.css +7 -0
  228. package/dist/js/highlight.js/styles/base16/zenburn.min.css +7 -0
  229. package/dist/js/highlight.js/styles/brown-paper.min.css +1 -0
  230. package/dist/js/highlight.js/styles/brown-papersq.png +0 -0
  231. package/dist/js/highlight.js/styles/codepen-embed.min.css +1 -0
  232. package/dist/js/highlight.js/styles/color-brewer.min.css +1 -0
  233. package/dist/js/highlight.js/styles/dark.min.css +1 -0
  234. package/dist/js/highlight.js/styles/default.min.css +9 -0
  235. package/dist/js/highlight.js/styles/devibeans.min.css +7 -0
  236. package/dist/js/highlight.js/styles/docco.min.css +1 -0
  237. package/dist/js/highlight.js/styles/far.min.css +1 -0
  238. package/dist/js/highlight.js/styles/felipec.min.css +7 -0
  239. package/dist/js/highlight.js/styles/foundation.min.css +1 -0
  240. package/dist/js/highlight.js/styles/github-dark-dimmed.min.css +9 -0
  241. package/dist/js/highlight.js/styles/github-dark.min.css +10 -0
  242. package/dist/js/highlight.js/styles/github.min.css +10 -0
  243. package/dist/js/highlight.js/styles/gml.min.css +1 -0
  244. package/dist/js/highlight.js/styles/googlecode.min.css +1 -0
  245. package/dist/js/highlight.js/styles/gradient-dark.min.css +1 -0
  246. package/dist/js/highlight.js/styles/gradient-light.min.css +1 -0
  247. package/dist/js/highlight.js/styles/grayscale.min.css +1 -0
  248. package/dist/js/highlight.js/styles/hybrid.min.css +1 -0
  249. package/dist/js/highlight.js/styles/idea.min.css +1 -0
  250. package/dist/js/highlight.js/styles/intellij-light.min.css +1 -0
  251. package/dist/js/highlight.js/styles/ir-black.min.css +1 -0
  252. package/dist/js/highlight.js/styles/isbl-editor-dark.min.css +1 -0
  253. package/dist/js/highlight.js/styles/isbl-editor-light.min.css +1 -0
  254. package/dist/js/highlight.js/styles/kimbie-dark.min.css +1 -0
  255. package/dist/js/highlight.js/styles/kimbie-light.min.css +1 -0
  256. package/dist/js/highlight.js/styles/lightfair.min.css +1 -0
  257. package/dist/js/highlight.js/styles/lioshi.min.css +1 -0
  258. package/dist/js/highlight.js/styles/magula.min.css +1 -0
  259. package/dist/js/highlight.js/styles/mono-blue.min.css +1 -0
  260. package/dist/js/highlight.js/styles/monokai-sublime.min.css +1 -0
  261. package/dist/js/highlight.js/styles/monokai.min.css +1 -0
  262. package/dist/js/highlight.js/styles/night-owl.min.css +1 -0
  263. package/dist/js/highlight.js/styles/nnfx-dark.min.css +10 -0
  264. package/dist/js/highlight.js/styles/nnfx-light.min.css +10 -0
  265. package/dist/js/highlight.js/styles/nord.min.css +1 -0
  266. package/dist/js/highlight.js/styles/obsidian.min.css +1 -0
  267. package/dist/js/highlight.js/styles/panda-syntax-dark.min.css +1 -0
  268. package/dist/js/highlight.js/styles/panda-syntax-light.min.css +1 -0
  269. package/dist/js/highlight.js/styles/paraiso-dark.min.css +1 -0
  270. package/dist/js/highlight.js/styles/paraiso-light.min.css +1 -0
  271. package/dist/js/highlight.js/styles/pojoaque.jpg +0 -0
  272. package/dist/js/highlight.js/styles/pojoaque.min.css +1 -0
  273. package/dist/js/highlight.js/styles/purebasic.min.css +1 -0
  274. package/dist/js/highlight.js/styles/qtcreator-dark.min.css +1 -0
  275. package/dist/js/highlight.js/styles/qtcreator-light.min.css +1 -0
  276. package/dist/js/highlight.js/styles/rainbow.min.css +1 -0
  277. package/dist/js/highlight.js/styles/routeros.min.css +1 -0
  278. package/dist/js/highlight.js/styles/school-book.min.css +1 -0
  279. package/dist/js/highlight.js/styles/shades-of-purple.min.css +1 -0
  280. package/dist/js/highlight.js/styles/srcery.min.css +1 -0
  281. package/dist/js/highlight.js/styles/stackoverflow-dark.min.css +13 -0
  282. package/dist/js/highlight.js/styles/stackoverflow-light.min.css +13 -0
  283. package/dist/js/highlight.js/styles/sunburst.min.css +1 -0
  284. package/dist/js/highlight.js/styles/tokyo-night-dark.min.css +8 -0
  285. package/dist/js/highlight.js/styles/tokyo-night-light.min.css +8 -0
  286. package/dist/js/highlight.js/styles/tomorrow-night-blue.min.css +1 -0
  287. package/dist/js/highlight.js/styles/tomorrow-night-bright.min.css +1 -0
  288. package/dist/js/highlight.js/styles/vs.min.css +1 -0
  289. package/dist/js/highlight.js/styles/vs2015.min.css +1 -0
  290. package/dist/js/highlight.js/styles/xcode.min.css +1 -0
  291. package/dist/js/highlight.js/styles/xt256.min.css +1 -0
  292. package/dist/js/highlight.js/third-languages.js +135 -0
  293. package/dist/js/html2canvas/html2canvas.min.20251104.js +20 -0
  294. package/dist/js/html2canvas/html2canvas.min.js +20 -0
  295. package/dist/js/i18n/de_DE.js +86 -0
  296. package/dist/js/i18n/en_US.js +86 -0
  297. package/dist/js/i18n/es_ES.js +86 -0
  298. package/dist/js/i18n/fr_FR.js +86 -0
  299. package/dist/js/i18n/ja_JP.js +86 -0
  300. package/dist/js/i18n/ko_KR.js +86 -0
  301. package/dist/js/i18n/pt_BR.js +86 -0
  302. package/dist/js/i18n/ru_RU.js +86 -0
  303. package/dist/js/i18n/sv_SE.js +86 -0
  304. package/dist/js/i18n/vi_VN.js +86 -0
  305. package/dist/js/i18n/zh_CN.js +86 -0
  306. package/dist/js/i18n/zh_TW.js +86 -0
  307. package/dist/js/icons/ant.js +174 -0
  308. package/dist/js/icons/material.js +195 -0
  309. package/dist/js/jspdf/jspdf.umd.min.20251104.js +398 -0
  310. package/dist/js/jspdf/jspdf.umd.min.js +398 -0
  311. package/dist/js/katex/fonts/KaTeX_AMS-Regular.ttf +0 -0
  312. package/dist/js/katex/fonts/KaTeX_AMS-Regular.woff +0 -0
  313. package/dist/js/katex/fonts/KaTeX_AMS-Regular.woff2 +0 -0
  314. package/dist/js/katex/fonts/KaTeX_Caligraphic-Bold.ttf +0 -0
  315. package/dist/js/katex/fonts/KaTeX_Caligraphic-Bold.woff +0 -0
  316. package/dist/js/katex/fonts/KaTeX_Caligraphic-Bold.woff2 +0 -0
  317. package/dist/js/katex/fonts/KaTeX_Caligraphic-Regular.ttf +0 -0
  318. package/dist/js/katex/fonts/KaTeX_Caligraphic-Regular.woff +0 -0
  319. package/dist/js/katex/fonts/KaTeX_Caligraphic-Regular.woff2 +0 -0
  320. package/dist/js/katex/fonts/KaTeX_Fraktur-Bold.ttf +0 -0
  321. package/dist/js/katex/fonts/KaTeX_Fraktur-Bold.woff +0 -0
  322. package/dist/js/katex/fonts/KaTeX_Fraktur-Bold.woff2 +0 -0
  323. package/dist/js/katex/fonts/KaTeX_Fraktur-Regular.ttf +0 -0
  324. package/dist/js/katex/fonts/KaTeX_Fraktur-Regular.woff +0 -0
  325. package/dist/js/katex/fonts/KaTeX_Fraktur-Regular.woff2 +0 -0
  326. package/dist/js/katex/fonts/KaTeX_Main-Bold.ttf +0 -0
  327. package/dist/js/katex/fonts/KaTeX_Main-Bold.woff +0 -0
  328. package/dist/js/katex/fonts/KaTeX_Main-Bold.woff2 +0 -0
  329. package/dist/js/katex/fonts/KaTeX_Main-BoldItalic.ttf +0 -0
  330. package/dist/js/katex/fonts/KaTeX_Main-BoldItalic.woff +0 -0
  331. package/dist/js/katex/fonts/KaTeX_Main-BoldItalic.woff2 +0 -0
  332. package/dist/js/katex/fonts/KaTeX_Main-Italic.ttf +0 -0
  333. package/dist/js/katex/fonts/KaTeX_Main-Italic.woff +0 -0
  334. package/dist/js/katex/fonts/KaTeX_Main-Italic.woff2 +0 -0
  335. package/dist/js/katex/fonts/KaTeX_Main-Regular.ttf +0 -0
  336. package/dist/js/katex/fonts/KaTeX_Main-Regular.woff +0 -0
  337. package/dist/js/katex/fonts/KaTeX_Main-Regular.woff2 +0 -0
  338. package/dist/js/katex/fonts/KaTeX_Math-BoldItalic.ttf +0 -0
  339. package/dist/js/katex/fonts/KaTeX_Math-BoldItalic.woff +0 -0
  340. package/dist/js/katex/fonts/KaTeX_Math-BoldItalic.woff2 +0 -0
  341. package/dist/js/katex/fonts/KaTeX_Math-Italic.ttf +0 -0
  342. package/dist/js/katex/fonts/KaTeX_Math-Italic.woff +0 -0
  343. package/dist/js/katex/fonts/KaTeX_Math-Italic.woff2 +0 -0
  344. package/dist/js/katex/fonts/KaTeX_SansSerif-Bold.ttf +0 -0
  345. package/dist/js/katex/fonts/KaTeX_SansSerif-Bold.woff +0 -0
  346. package/dist/js/katex/fonts/KaTeX_SansSerif-Bold.woff2 +0 -0
  347. package/dist/js/katex/fonts/KaTeX_SansSerif-Italic.ttf +0 -0
  348. package/dist/js/katex/fonts/KaTeX_SansSerif-Italic.woff +0 -0
  349. package/dist/js/katex/fonts/KaTeX_SansSerif-Italic.woff2 +0 -0
  350. package/dist/js/katex/fonts/KaTeX_SansSerif-Regular.ttf +0 -0
  351. package/dist/js/katex/fonts/KaTeX_SansSerif-Regular.woff +0 -0
  352. package/dist/js/katex/fonts/KaTeX_SansSerif-Regular.woff2 +0 -0
  353. package/dist/js/katex/fonts/KaTeX_Script-Regular.ttf +0 -0
  354. package/dist/js/katex/fonts/KaTeX_Script-Regular.woff +0 -0
  355. package/dist/js/katex/fonts/KaTeX_Script-Regular.woff2 +0 -0
  356. package/dist/js/katex/fonts/KaTeX_Size1-Regular.ttf +0 -0
  357. package/dist/js/katex/fonts/KaTeX_Size1-Regular.woff +0 -0
  358. package/dist/js/katex/fonts/KaTeX_Size1-Regular.woff2 +0 -0
  359. package/dist/js/katex/fonts/KaTeX_Size2-Regular.ttf +0 -0
  360. package/dist/js/katex/fonts/KaTeX_Size2-Regular.woff +0 -0
  361. package/dist/js/katex/fonts/KaTeX_Size2-Regular.woff2 +0 -0
  362. package/dist/js/katex/fonts/KaTeX_Size3-Regular.ttf +0 -0
  363. package/dist/js/katex/fonts/KaTeX_Size3-Regular.woff +0 -0
  364. package/dist/js/katex/fonts/KaTeX_Size3-Regular.woff2 +0 -0
  365. package/dist/js/katex/fonts/KaTeX_Size4-Regular.ttf +0 -0
  366. package/dist/js/katex/fonts/KaTeX_Size4-Regular.woff +0 -0
  367. package/dist/js/katex/fonts/KaTeX_Size4-Regular.woff2 +0 -0
  368. package/dist/js/katex/fonts/KaTeX_Typewriter-Regular.ttf +0 -0
  369. package/dist/js/katex/fonts/KaTeX_Typewriter-Regular.woff +0 -0
  370. package/dist/js/katex/fonts/KaTeX_Typewriter-Regular.woff2 +0 -0
  371. package/dist/js/katex/katex.min.css +1 -0
  372. package/dist/js/katex/katex.min.js +1 -0
  373. package/dist/js/katex/mhchem.min.js +1 -0
  374. package/dist/js/lute/lute.min.js +1 -0
  375. package/dist/js/markmap/katex.min.css +1 -0
  376. package/dist/js/markmap/markmap.min.js +8251 -0
  377. package/dist/js/markmap/prism.css +140 -0
  378. package/dist/js/mathjax/LICENSE +202 -0
  379. package/dist/js/mathjax/a11y/assistive-mml.js +1 -0
  380. package/dist/js/mathjax/a11y/complexity.js +1 -0
  381. package/dist/js/mathjax/a11y/explorer.js +1 -0
  382. package/dist/js/mathjax/a11y/semantic-enrich.js +1 -0
  383. package/dist/js/mathjax/input/asciimath.js +1 -0
  384. package/dist/js/mathjax/input/mml/entities.js +1 -0
  385. package/dist/js/mathjax/input/mml.js +1 -0
  386. package/dist/js/mathjax/input/tex/extensions/action.js +1 -0
  387. package/dist/js/mathjax/input/tex/extensions/all-packages.js +1 -0
  388. package/dist/js/mathjax/input/tex/extensions/ams.js +1 -0
  389. package/dist/js/mathjax/input/tex/extensions/amscd.js +1 -0
  390. package/dist/js/mathjax/input/tex/extensions/autoload.js +1 -0
  391. package/dist/js/mathjax/input/tex/extensions/bbox.js +1 -0
  392. package/dist/js/mathjax/input/tex/extensions/boldsymbol.js +1 -0
  393. package/dist/js/mathjax/input/tex/extensions/braket.js +1 -0
  394. package/dist/js/mathjax/input/tex/extensions/bussproofs.js +1 -0
  395. package/dist/js/mathjax/input/tex/extensions/cancel.js +1 -0
  396. package/dist/js/mathjax/input/tex/extensions/color.js +1 -0
  397. package/dist/js/mathjax/input/tex/extensions/colorV2.js +1 -0
  398. package/dist/js/mathjax/input/tex/extensions/configMacros.js +1 -0
  399. package/dist/js/mathjax/input/tex/extensions/enclose.js +1 -0
  400. package/dist/js/mathjax/input/tex/extensions/extpfeil.js +1 -0
  401. package/dist/js/mathjax/input/tex/extensions/html.js +1 -0
  402. package/dist/js/mathjax/input/tex/extensions/mhchem.js +1 -0
  403. package/dist/js/mathjax/input/tex/extensions/newcommand.js +1 -0
  404. package/dist/js/mathjax/input/tex/extensions/noerrors.js +1 -0
  405. package/dist/js/mathjax/input/tex/extensions/noundefined.js +1 -0
  406. package/dist/js/mathjax/input/tex/extensions/physics.js +1 -0
  407. package/dist/js/mathjax/input/tex/extensions/require.js +1 -0
  408. package/dist/js/mathjax/input/tex/extensions/tagFormat.js +1 -0
  409. package/dist/js/mathjax/input/tex/extensions/textmacros.js +1 -0
  410. package/dist/js/mathjax/input/tex/extensions/unicode.js +1 -0
  411. package/dist/js/mathjax/input/tex/extensions/verb.js +1 -0
  412. package/dist/js/mathjax/input/tex-base.js +1 -0
  413. package/dist/js/mathjax/input/tex-full.js +1 -0
  414. package/dist/js/mathjax/input/tex.js +1 -0
  415. package/dist/js/mathjax/sre/mathmaps/de.js +104 -0
  416. package/dist/js/mathjax/sre/mathmaps/en.js +110 -0
  417. package/dist/js/mathjax/sre/mathmaps/es.js +104 -0
  418. package/dist/js/mathjax/sre/mathmaps/fr.js +104 -0
  419. package/dist/js/mathjax/sre/mathmaps/mathmaps_ie.js +518 -0
  420. package/dist/js/mathjax/sre/mathmaps/nemeth.js +104 -0
  421. package/dist/js/mathjax/sre/sre-node.js +11 -0
  422. package/dist/js/mathjax/sre/sre_browser.js +1633 -0
  423. package/dist/js/mathjax/tex-svg-full.js +1 -0
  424. package/dist/js/mermaid/mermaid.min.js +2694 -0
  425. package/dist/js/plantuml/plantuml-encoder.min.js +1 -0
  426. package/dist/js/smiles-drawer/smiles-drawer.min.js +71 -0
  427. package/dist/method.d.ts +51 -0
  428. package/dist/method.js +4532 -0
  429. package/dist/method.min.js +1 -0
  430. package/dist/ts/constants.d.ts +46 -0
  431. package/dist/ts/devtools/index.d.ts +6 -0
  432. package/dist/ts/export/index.d.ts +4 -0
  433. package/dist/ts/hint/index.d.ts +13 -0
  434. package/dist/ts/ir/expandMarker.d.ts +1 -0
  435. package/dist/ts/ir/highlightToolbarIR.d.ts +1 -0
  436. package/dist/ts/ir/index.d.ts +12 -0
  437. package/dist/ts/ir/input.d.ts +1 -0
  438. package/dist/ts/ir/process.d.ts +8 -0
  439. package/dist/ts/ir/processKeydown.d.ts +1 -0
  440. package/dist/ts/markdown/SMILESRender.d.ts +1 -0
  441. package/dist/ts/markdown/abcRender.d.ts +1 -0
  442. package/dist/ts/markdown/adapterRender.d.ts +51 -0
  443. package/dist/ts/markdown/anchorRender.d.ts +1 -0
  444. package/dist/ts/markdown/chartRender.d.ts +1 -0
  445. package/dist/ts/markdown/codeRender.d.ts +1 -0
  446. package/dist/ts/markdown/flowchartRender.d.ts +1 -0
  447. package/dist/ts/markdown/getHTML.d.ts +1 -0
  448. package/dist/ts/markdown/getMarkdown.d.ts +1 -0
  449. package/dist/ts/markdown/graphvizRender.d.ts +1 -0
  450. package/dist/ts/markdown/highlightRender.d.ts +1 -0
  451. package/dist/ts/markdown/lazyLoadImageRender.d.ts +6 -0
  452. package/dist/ts/markdown/markmapRender.d.ts +1 -0
  453. package/dist/ts/markdown/mathContextMenu.d.ts +17 -0
  454. package/dist/ts/markdown/mathRender.d.ts +19 -0
  455. package/dist/ts/markdown/mediaRender.d.ts +1 -0
  456. package/dist/ts/markdown/mermaidRender.d.ts +1 -0
  457. package/dist/ts/markdown/mindmapRender.d.ts +1 -0
  458. package/dist/ts/markdown/outlineRender.d.ts +1 -0
  459. package/dist/ts/markdown/plantumlRender.d.ts +1 -0
  460. package/dist/ts/markdown/previewRender.d.ts +2 -0
  461. package/dist/ts/markdown/setLute.d.ts +1 -0
  462. package/dist/ts/markdown/speechRender.d.ts +6 -0
  463. package/dist/ts/outline/index.d.ts +6 -0
  464. package/dist/ts/preview/image.d.ts +1 -0
  465. package/dist/ts/preview/index.d.ts +26 -0
  466. package/dist/ts/resize/index.d.ts +5 -0
  467. package/dist/ts/sv/combineFootnote.d.ts +6 -0
  468. package/dist/ts/sv/index.d.ts +12 -0
  469. package/dist/ts/sv/inputEvent.d.ts +1 -0
  470. package/dist/ts/sv/process.d.ts +11 -0
  471. package/dist/ts/sv/processKeydown.d.ts +1 -0
  472. package/dist/ts/tip/index.d.ts +6 -0
  473. package/dist/ts/toolbar/Both.d.ts +4 -0
  474. package/dist/ts/toolbar/Br.d.ts +4 -0
  475. package/dist/ts/toolbar/CodeTheme.d.ts +5 -0
  476. package/dist/ts/toolbar/ContentTheme.d.ts +5 -0
  477. package/dist/ts/toolbar/Counter.d.ts +5 -0
  478. package/dist/ts/toolbar/Custom.d.ts +4 -0
  479. package/dist/ts/toolbar/Devtools.d.ts +4 -0
  480. package/dist/ts/toolbar/Divider.d.ts +4 -0
  481. package/dist/ts/toolbar/EditMode.d.ts +7 -0
  482. package/dist/ts/toolbar/Emoji.d.ts +6 -0
  483. package/dist/ts/toolbar/Export.d.ts +5 -0
  484. package/dist/ts/toolbar/Fullscreen.d.ts +5 -0
  485. package/dist/ts/toolbar/Headings.d.ts +6 -0
  486. package/dist/ts/toolbar/Help.d.ts +4 -0
  487. package/dist/ts/toolbar/Indent.d.ts +4 -0
  488. package/dist/ts/toolbar/Info.d.ts +4 -0
  489. package/dist/ts/toolbar/InsertAfter.d.ts +4 -0
  490. package/dist/ts/toolbar/InsertBefore.d.ts +4 -0
  491. package/dist/ts/toolbar/MenuItem.d.ts +4 -0
  492. package/dist/ts/toolbar/Outdent.d.ts +4 -0
  493. package/dist/ts/toolbar/Outline.d.ts +4 -0
  494. package/dist/ts/toolbar/Preview.d.ts +5 -0
  495. package/dist/ts/toolbar/Record.d.ts +5 -0
  496. package/dist/ts/toolbar/Redo.d.ts +4 -0
  497. package/dist/ts/toolbar/Undo.d.ts +4 -0
  498. package/dist/ts/toolbar/Upload.d.ts +5 -0
  499. package/dist/ts/toolbar/index.d.ts +9 -0
  500. package/dist/ts/toolbar/setToolbar.d.ts +20 -0
  501. package/dist/ts/ui/initUI.d.ts +4 -0
  502. package/dist/ts/ui/setCodeTheme.d.ts +1 -0
  503. package/dist/ts/ui/setContentTheme.d.ts +1 -0
  504. package/dist/ts/ui/setPreviewMode.d.ts +1 -0
  505. package/dist/ts/ui/setTheme.d.ts +6 -0
  506. package/dist/ts/undo/index.d.ts +18 -0
  507. package/dist/ts/upload/getElement.d.ts +1 -0
  508. package/dist/ts/upload/index.d.ts +8 -0
  509. package/dist/ts/upload/setHeaders.d.ts +1 -0
  510. package/dist/ts/util/Options.d.ts +19 -0
  511. package/dist/ts/util/RecordMedia.d.ts +18 -0
  512. package/dist/ts/util/addScript.d.ts +2 -0
  513. package/dist/ts/util/addStyle.d.ts +1 -0
  514. package/dist/ts/util/code160to32.d.ts +1 -0
  515. package/dist/ts/util/compatibility.d.ts +7 -0
  516. package/dist/ts/util/editorCommonEvent.d.ts +13 -0
  517. package/dist/ts/util/fixBrowserBehavior.d.ts +39 -0
  518. package/dist/ts/util/function.d.ts +3 -0
  519. package/dist/ts/util/getSelectText.d.ts +1 -0
  520. package/dist/ts/util/hasClosest.d.ts +9 -0
  521. package/dist/ts/util/hasClosestByHeadings.d.ts +2 -0
  522. package/dist/ts/util/highlightToolbar.d.ts +1 -0
  523. package/dist/ts/util/hotKey.d.ts +1 -0
  524. package/dist/ts/util/log.d.ts +1 -0
  525. package/dist/ts/util/merge.d.ts +1 -0
  526. package/dist/ts/util/processCode.d.ts +2 -0
  527. package/dist/ts/util/selection.d.ts +14 -0
  528. package/dist/ts/util/toc.d.ts +5 -0
  529. package/dist/ts/wysiwyg/afterRenderEvent.d.ts +5 -0
  530. package/dist/ts/wysiwyg/highlightToolbarWYSIWYG.d.ts +9 -0
  531. package/dist/ts/wysiwyg/index.d.ts +27 -0
  532. package/dist/ts/wysiwyg/inlineTag.d.ts +10 -0
  533. package/dist/ts/wysiwyg/input.d.ts +1 -0
  534. package/dist/ts/wysiwyg/processKeydown.d.ts +2 -0
  535. package/dist/ts/wysiwyg/renderDomByMd.d.ts +5 -0
  536. package/dist/ts/wysiwyg/setHeading.d.ts +2 -0
  537. package/dist/ts/wysiwyg/showCode.d.ts +1 -0
  538. package/dist/ts/wysiwyg/toolbarEvent.d.ts +1 -0
  539. package/dist/types/index.d.ts +930 -0
  540. package/package.json +63 -0
  541. package/src/assets/less/_content.less +247 -0
  542. package/src/assets/less/_hint.less +67 -0
  543. package/src/assets/less/_ir.less +282 -0
  544. package/src/assets/less/_line-number.less +30 -0
  545. package/src/assets/less/_math-menu.less +78 -0
  546. package/src/assets/less/_panel.less +110 -0
  547. package/src/assets/less/_reset.less +628 -0
  548. package/src/assets/less/_sv.less +132 -0
  549. package/src/assets/less/_toolbar.less +180 -0
  550. package/src/assets/less/_tooltipped.less +171 -0
  551. package/src/assets/less/_wysiwyg.less +215 -0
  552. package/src/assets/less/index.less +99 -0
  553. package/src/index.ts +641 -0
  554. package/src/method.ts +71 -0
  555. package/src/ts/constants.ts +350 -0
  556. package/src/ts/devtools/index.ts +83 -0
  557. package/src/ts/export/index.ts +84 -0
  558. package/src/ts/hint/index.ts +276 -0
  559. package/src/ts/ir/expandMarker.ts +79 -0
  560. package/src/ts/ir/highlightToolbarIR.ts +97 -0
  561. package/src/ts/ir/index.ts +268 -0
  562. package/src/ts/ir/input.ts +250 -0
  563. package/src/ts/ir/process.ts +222 -0
  564. package/src/ts/ir/processKeydown.ts +238 -0
  565. package/src/ts/markdown/SMILESRender.ts +29 -0
  566. package/src/ts/markdown/abcRender.ts +27 -0
  567. package/src/ts/markdown/adapterRender.ts +96 -0
  568. package/src/ts/markdown/anchorRender.ts +19 -0
  569. package/src/ts/markdown/chartRender.ts +1153 -0
  570. package/src/ts/markdown/codeRender.ts +60 -0
  571. package/src/ts/markdown/flowchartRender.ts +25 -0
  572. package/src/ts/markdown/getHTML.ts +11 -0
  573. package/src/ts/markdown/getMarkdown.ts +12 -0
  574. package/src/ts/markdown/graphvizRender.ts +49 -0
  575. package/src/ts/markdown/highlightRender.ts +94 -0
  576. package/src/ts/markdown/lazyLoadImageRender.ts +56 -0
  577. package/src/ts/markdown/markmapRender.ts +56 -0
  578. package/src/ts/markdown/mathContextMenu.ts +423 -0
  579. package/src/ts/markdown/mathRender.ts +281 -0
  580. package/src/ts/markdown/mediaRender.ts +105 -0
  581. package/src/ts/markdown/mermaidRender.ts +60 -0
  582. package/src/ts/markdown/mindmapRender.ts +74 -0
  583. package/src/ts/markdown/outlineRender.ts +110 -0
  584. package/src/ts/markdown/plantumlRender.ts +32 -0
  585. package/src/ts/markdown/previewRender.ts +171 -0
  586. package/src/ts/markdown/setLute.ts +26 -0
  587. package/src/ts/markdown/speechRender.ts +107 -0
  588. package/src/ts/outline/index.ts +45 -0
  589. package/src/ts/preview/image.ts +50 -0
  590. package/src/ts/preview/index.ts +299 -0
  591. package/src/ts/resize/index.ts +57 -0
  592. package/src/ts/sv/combineFootnote.ts +27 -0
  593. package/src/ts/sv/index.ts +128 -0
  594. package/src/ts/sv/inputEvent.ts +188 -0
  595. package/src/ts/sv/process.ts +215 -0
  596. package/src/ts/sv/processKeydown.ts +202 -0
  597. package/src/ts/tip/index.ts +39 -0
  598. package/src/ts/toolbar/Both.ts +28 -0
  599. package/src/ts/toolbar/Br.ts +8 -0
  600. package/src/ts/toolbar/CodeTheme.ts +36 -0
  601. package/src/ts/toolbar/ContentTheme.ts +44 -0
  602. package/src/ts/toolbar/Counter.ts +40 -0
  603. package/src/ts/toolbar/Custom.ts +17 -0
  604. package/src/ts/toolbar/Devtools.ts +28 -0
  605. package/src/ts/toolbar/Divider.ts +8 -0
  606. package/src/ts/toolbar/EditMode.ts +198 -0
  607. package/src/ts/toolbar/Emoji.ts +79 -0
  608. package/src/ts/toolbar/Export.ts +41 -0
  609. package/src/ts/toolbar/Fullscreen.ts +66 -0
  610. package/src/ts/toolbar/Headings.ts +73 -0
  611. package/src/ts/toolbar/Help.ts +30 -0
  612. package/src/ts/toolbar/Indent.ts +25 -0
  613. package/src/ts/toolbar/Info.ts +28 -0
  614. package/src/ts/toolbar/InsertAfter.ts +18 -0
  615. package/src/ts/toolbar/InsertBefore.ts +18 -0
  616. package/src/ts/toolbar/MenuItem.ts +54 -0
  617. package/src/ts/toolbar/Outdent.ts +24 -0
  618. package/src/ts/toolbar/Outline.ts +21 -0
  619. package/src/ts/toolbar/Preview.ts +55 -0
  620. package/src/ts/toolbar/Record.ts +60 -0
  621. package/src/ts/toolbar/Redo.ts +18 -0
  622. package/src/ts/toolbar/Undo.ts +18 -0
  623. package/src/ts/toolbar/Upload.ts +41 -0
  624. package/src/ts/toolbar/index.ts +195 -0
  625. package/src/ts/toolbar/setToolbar.ts +120 -0
  626. package/src/ts/ui/initUI.ts +214 -0
  627. package/src/ts/ui/setCodeTheme.ts +16 -0
  628. package/src/ts/ui/setContentTheme.ts +15 -0
  629. package/src/ts/ui/setPreviewMode.ts +31 -0
  630. package/src/ts/ui/setTheme.ts +14 -0
  631. package/src/ts/undo/index.ts +270 -0
  632. package/src/ts/upload/getElement.ts +10 -0
  633. package/src/ts/upload/index.ts +273 -0
  634. package/src/ts/upload/setHeaders.ts +10 -0
  635. package/src/ts/util/Options.ts +458 -0
  636. package/src/ts/util/RecordMedia.ts +170 -0
  637. package/src/ts/util/addScript.ts +43 -0
  638. package/src/ts/util/addStyle.ts +10 -0
  639. package/src/ts/util/code160to32.ts +4 -0
  640. package/src/ts/util/compatibility.ts +67 -0
  641. package/src/ts/util/editorCommonEvent.ts +270 -0
  642. package/src/ts/util/fixBrowserBehavior.ts +2234 -0
  643. package/src/ts/util/function.ts +15 -0
  644. package/src/ts/util/getSelectText.ts +8 -0
  645. package/src/ts/util/hasClosest.ts +154 -0
  646. package/src/ts/util/hasClosestByHeadings.ts +27 -0
  647. package/src/ts/util/highlightToolbar.ts +10 -0
  648. package/src/ts/util/hotKey.ts +54 -0
  649. package/src/ts/util/log.ts +6 -0
  650. package/src/ts/util/merge.ts +18 -0
  651. package/src/ts/util/processCode.ts +218 -0
  652. package/src/ts/util/selection.ts +349 -0
  653. package/src/ts/util/toc.ts +83 -0
  654. package/src/ts/wysiwyg/afterRenderEvent.ts +41 -0
  655. package/src/ts/wysiwyg/highlightToolbarWYSIWYG.ts +1169 -0
  656. package/src/ts/wysiwyg/index.ts +604 -0
  657. package/src/ts/wysiwyg/inlineTag.ts +129 -0
  658. package/src/ts/wysiwyg/input.ts +212 -0
  659. package/src/ts/wysiwyg/processKeydown.ts +363 -0
  660. package/src/ts/wysiwyg/renderDomByMd.ts +18 -0
  661. package/src/ts/wysiwyg/setHeading.ts +43 -0
  662. package/src/ts/wysiwyg/showCode.ts +32 -0
  663. package/src/ts/wysiwyg/toolbarEvent.ts +333 -0
@@ -0,0 +1,2234 @@
1
+ import { Constants } from "../constants";
2
+ import { input as IRInput } from "../ir/input";
3
+ import { processAfterRender } from "../ir/process";
4
+ import {
5
+ processAfterRender as processSVAfterRender,
6
+ processPaste,
7
+ } from "../sv/process";
8
+ import { uploadFiles } from "../upload/index";
9
+ import { setHeaders } from "../upload/setHeaders";
10
+ import { afterRenderEvent } from "../wysiwyg/afterRenderEvent";
11
+ import { input } from "../wysiwyg/input";
12
+ import { isCtrl, isFirefox } from "./compatibility";
13
+ import { scrollCenter } from "./editorCommonEvent";
14
+ import {
15
+ getTopList,
16
+ hasClosestBlock,
17
+ hasClosestByAttribute,
18
+ hasClosestByClassName,
19
+ hasClosestByMatchTag,
20
+ } from "./hasClosest";
21
+ import { getLastNode } from "./hasClosest";
22
+ import { highlightToolbar } from "./highlightToolbar";
23
+ import { matchHotKey } from "./hotKey";
24
+ import { processCodeRender, processPasteCode } from "./processCode";
25
+ import {
26
+ getEditorRange,
27
+ getSelectPosition,
28
+ insertHTML,
29
+ setRangeByWbr,
30
+ setSelectionByPosition,
31
+ setSelectionFocus,
32
+ } from "./selection";
33
+
34
+ // https://github.com/Vanessa219/vditor/issues/508 软键盘无法删除空块
35
+ export const fixGSKeyBackspace = (
36
+ event: KeyboardEvent,
37
+ vditor: IVditor,
38
+ startContainer: Node
39
+ ) => {
40
+ if (
41
+ event.keyCode === 229 &&
42
+ event.code === "" &&
43
+ event.key === "Unidentified" &&
44
+ vditor.currentMode !== "sv"
45
+ ) {
46
+ const blockElement = hasClosestBlock(startContainer);
47
+ // 移动端的标点符号都显示为 299,因此需限定为空删除的条件
48
+ if (blockElement && blockElement.textContent.trim() === "") {
49
+ vditor[vditor.currentMode].composingLock = true;
50
+ return false;
51
+ }
52
+ }
53
+ return true;
54
+ };
55
+
56
+ // https://github.com/Vanessa219/vditor/issues/361 代码块后输入中文
57
+ export const fixCJKPosition = (
58
+ range: Range,
59
+ vditor: IVditor,
60
+ event: KeyboardEvent
61
+ ) => {
62
+ if (
63
+ event.key === "Enter" ||
64
+ event.key === "Tab" ||
65
+ event.key === "Backspace" ||
66
+ event.key.indexOf("Arrow") > -1 ||
67
+ isCtrl(event) ||
68
+ event.key === "Escape" ||
69
+ event.shiftKey ||
70
+ event.altKey
71
+ ) {
72
+ return;
73
+ }
74
+ const pLiElement =
75
+ hasClosestByMatchTag(range.startContainer, "P") ||
76
+ hasClosestByMatchTag(range.startContainer, "LI");
77
+ if (
78
+ pLiElement &&
79
+ getSelectPosition(pLiElement, vditor[vditor.currentMode].element, range)
80
+ .start === 0
81
+ ) {
82
+ // https://github.com/Vanessa219/vditor/issues/1289 WKWebView切换输入法产生六分之一空格,造成光标错位
83
+ if (pLiElement.nodeValue) {
84
+ pLiElement.nodeValue = pLiElement.nodeValue.replace(/\u2006/g, "");
85
+ }
86
+
87
+ const zwspNode = document.createTextNode(Constants.ZWSP);
88
+ range.insertNode(zwspNode);
89
+ range.setStartAfter(zwspNode);
90
+ }
91
+ };
92
+
93
+ // https://github.com/Vanessa219/vditor/issues/381 光标在内联数学公式中无法向下移动
94
+ export const fixCursorDownInlineMath = (range: Range, key: string) => {
95
+ if (key === "ArrowDown" || key === "ArrowUp") {
96
+ const inlineElement =
97
+ hasClosestByAttribute(
98
+ range.startContainer,
99
+ "data-type",
100
+ "math-inline"
101
+ ) ||
102
+ hasClosestByAttribute(
103
+ range.startContainer,
104
+ "data-type",
105
+ "html-entity"
106
+ ) ||
107
+ hasClosestByAttribute(
108
+ range.startContainer,
109
+ "data-type",
110
+ "html-inline"
111
+ );
112
+ if (inlineElement) {
113
+ if (key === "ArrowDown") {
114
+ range.setStartAfter(inlineElement.parentElement);
115
+ }
116
+ if (key === "ArrowUp") {
117
+ range.setStartBefore(inlineElement.parentElement);
118
+ }
119
+ }
120
+ }
121
+ };
122
+
123
+ export const insertEmptyBlock = (vditor: IVditor, position: InsertPosition) => {
124
+ const range = getEditorRange(vditor);
125
+ const blockElement = hasClosestBlock(range.startContainer);
126
+ if (blockElement) {
127
+ blockElement.insertAdjacentHTML(
128
+ position,
129
+ `<p data-block="0">${Constants.ZWSP}<wbr>\n</p>`
130
+ );
131
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
132
+ highlightToolbar(vditor);
133
+ execAfterRender(vditor);
134
+ }
135
+ };
136
+
137
+ export const isFirstCell = (cellElement: HTMLElement) => {
138
+ const tableElement = hasClosestByMatchTag(
139
+ cellElement,
140
+ "TABLE"
141
+ ) as HTMLTableElement;
142
+ if (tableElement && tableElement.rows[0].cells[0].isSameNode(cellElement)) {
143
+ return tableElement;
144
+ }
145
+ return false;
146
+ };
147
+
148
+ export const isLastCell = (cellElement: HTMLElement) => {
149
+ const tableElement = hasClosestByMatchTag(
150
+ cellElement,
151
+ "TABLE"
152
+ ) as HTMLTableElement;
153
+ if (
154
+ tableElement &&
155
+ tableElement.lastElementChild.lastElementChild.lastElementChild.isSameNode(
156
+ cellElement
157
+ )
158
+ ) {
159
+ return tableElement;
160
+ }
161
+ return false;
162
+ };
163
+
164
+ // 光标设置到前一个表格中
165
+ const goPreviousCell = (
166
+ cellElement: HTMLElement,
167
+ range: Range,
168
+ isSelected = true
169
+ ) => {
170
+ let previousElement = cellElement.previousElementSibling;
171
+ if (!previousElement) {
172
+ if (cellElement.parentElement.previousElementSibling) {
173
+ previousElement =
174
+ cellElement.parentElement.previousElementSibling
175
+ .lastElementChild;
176
+ } else if (
177
+ cellElement.parentElement.parentElement.tagName === "TBODY" &&
178
+ cellElement.parentElement.parentElement.previousElementSibling
179
+ ) {
180
+ previousElement =
181
+ cellElement.parentElement.parentElement.previousElementSibling
182
+ .lastElementChild.lastElementChild;
183
+ } else {
184
+ previousElement = null;
185
+ }
186
+ }
187
+ if (previousElement) {
188
+ range.selectNodeContents(previousElement);
189
+ if (!isSelected) {
190
+ range.collapse(false);
191
+ }
192
+ setSelectionFocus(range);
193
+ }
194
+ return previousElement;
195
+ };
196
+
197
+ export const insertAfterBlock = (
198
+ vditor: IVditor,
199
+ event: KeyboardEvent,
200
+ range: Range,
201
+ element: HTMLElement,
202
+ blockElement: HTMLElement
203
+ ) => {
204
+ const position = getSelectPosition(
205
+ element,
206
+ vditor[vditor.currentMode].element,
207
+ range
208
+ );
209
+ if (
210
+ (event.key === "ArrowDown" &&
211
+ element.textContent
212
+ .trimRight()
213
+ .substr(position.start)
214
+ .indexOf("\n") === -1) ||
215
+ (event.key === "ArrowRight" &&
216
+ position.start >= element.textContent.trimRight().length)
217
+ ) {
218
+ const nextElement = blockElement.nextElementSibling;
219
+ if (
220
+ !nextElement ||
221
+ (nextElement &&
222
+ (nextElement.tagName === "TABLE" ||
223
+ nextElement.getAttribute("data-type")))
224
+ ) {
225
+ blockElement.insertAdjacentHTML(
226
+ "afterend",
227
+ `<p data-block="0">${Constants.ZWSP}<wbr></p>`
228
+ );
229
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
230
+ } else {
231
+ range.selectNodeContents(nextElement);
232
+ range.collapse(true);
233
+ setSelectionFocus(range);
234
+ }
235
+ event.preventDefault();
236
+ return true;
237
+ }
238
+ return false;
239
+ };
240
+
241
+ export const insertBeforeBlock = (
242
+ vditor: IVditor,
243
+ event: KeyboardEvent,
244
+ range: Range,
245
+ element: HTMLElement,
246
+ blockElement: HTMLElement
247
+ ) => {
248
+ const position = getSelectPosition(
249
+ element,
250
+ vditor[vditor.currentMode].element,
251
+ range
252
+ );
253
+ if (
254
+ (event.key === "ArrowUp" &&
255
+ element.textContent.substr(0, position.start).indexOf("\n") ===
256
+ -1) ||
257
+ ((event.key === "ArrowLeft" ||
258
+ (event.key === "Backspace" && range.toString() === "")) &&
259
+ position.start === 0)
260
+ ) {
261
+ const previousElement = blockElement.previousElementSibling;
262
+ // table || code
263
+ if (
264
+ !previousElement ||
265
+ (previousElement &&
266
+ (previousElement.tagName === "TABLE" ||
267
+ previousElement.getAttribute("data-type")))
268
+ ) {
269
+ blockElement.insertAdjacentHTML(
270
+ "beforebegin",
271
+ `<p data-block="0">${Constants.ZWSP}<wbr></p>`
272
+ );
273
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
274
+ } else {
275
+ range.selectNodeContents(previousElement);
276
+ range.collapse(false);
277
+ setSelectionFocus(range);
278
+ }
279
+ event.preventDefault();
280
+ return true;
281
+ }
282
+ return false;
283
+ };
284
+
285
+ export const listToggle = (
286
+ vditor: IVditor,
287
+ range: Range,
288
+ type: string,
289
+ cancel = true
290
+ ) => {
291
+ const itemElement = hasClosestByMatchTag(range.startContainer, "LI");
292
+ vditor[vditor.currentMode].element
293
+ .querySelectorAll("wbr")
294
+ .forEach((wbr) => {
295
+ wbr.remove();
296
+ });
297
+ range.insertNode(document.createElement("wbr"));
298
+
299
+ if (cancel && itemElement) {
300
+ // 取消
301
+ let pHTML = "";
302
+ for (let i = 0; i < itemElement.parentElement.childElementCount; i++) {
303
+ const inputElement =
304
+ itemElement.parentElement.children[i].querySelector("input");
305
+ if (inputElement) {
306
+ inputElement.remove();
307
+ }
308
+ pHTML += `<p data-block="0">${itemElement.parentElement.children[i].innerHTML.trimLeft()}</p>`;
309
+ }
310
+ itemElement.parentElement.insertAdjacentHTML("beforebegin", pHTML);
311
+ itemElement.parentElement.remove();
312
+ } else {
313
+ if (!itemElement) {
314
+ // 添加
315
+ let blockElement = hasClosestByAttribute(
316
+ range.startContainer,
317
+ "data-block",
318
+ "0"
319
+ );
320
+ if (!blockElement) {
321
+ vditor[vditor.currentMode].element
322
+ .querySelector("wbr")
323
+ .remove();
324
+ blockElement =
325
+ vditor[vditor.currentMode].element.querySelector("p");
326
+ blockElement.innerHTML = "<wbr>";
327
+ }
328
+ if (type === "check") {
329
+ blockElement.insertAdjacentHTML(
330
+ "beforebegin",
331
+ `<ul data-block="0"><li class="vditor-task"><input type="checkbox" /> ${blockElement.innerHTML}</li></ul>`
332
+ );
333
+ blockElement.remove();
334
+ } else if (type === "list") {
335
+ blockElement.insertAdjacentHTML(
336
+ "beforebegin",
337
+ `<ul data-block="0"><li>${blockElement.innerHTML}</li></ul>`
338
+ );
339
+ blockElement.remove();
340
+ } else if (type === "ordered-list") {
341
+ blockElement.insertAdjacentHTML(
342
+ "beforebegin",
343
+ `<ol data-block="0"><li>${blockElement.innerHTML}</li></ol>`
344
+ );
345
+ blockElement.remove();
346
+ }
347
+ } else {
348
+ // 切换
349
+ if (type === "check") {
350
+ itemElement.parentElement
351
+ .querySelectorAll("li")
352
+ .forEach((item) => {
353
+ item.insertAdjacentHTML(
354
+ "afterbegin",
355
+ `<input type="checkbox" />${item.textContent.indexOf(" ") === 0 ? "" : " "}`
356
+ );
357
+ item.classList.add("vditor-task");
358
+ });
359
+ } else {
360
+ if (itemElement.querySelector("input")) {
361
+ itemElement.parentElement
362
+ .querySelectorAll("li")
363
+ .forEach((item) => {
364
+ item.querySelector("input").remove();
365
+ item.classList.remove("vditor-task");
366
+ });
367
+ }
368
+ let element;
369
+ if (type === "list") {
370
+ element = document.createElement("ul");
371
+ element.setAttribute("data-marker", "*");
372
+ } else {
373
+ element = document.createElement("ol");
374
+ element.setAttribute("data-marker", "1.");
375
+ }
376
+ element.setAttribute("data-block", "0");
377
+ element.setAttribute(
378
+ "data-tight",
379
+ itemElement.parentElement.getAttribute("data-tight")
380
+ );
381
+ element.innerHTML = itemElement.parentElement.innerHTML;
382
+ itemElement.parentElement.parentNode.replaceChild(
383
+ element,
384
+ itemElement.parentElement
385
+ );
386
+ }
387
+ }
388
+ }
389
+ };
390
+
391
+ export const listIndent = (
392
+ vditor: IVditor,
393
+ liElement: HTMLElement,
394
+ range: Range
395
+ ) => {
396
+ const previousElement = liElement.previousElementSibling;
397
+ if (liElement && previousElement) {
398
+ const liElements: HTMLElement[] = [liElement];
399
+ Array.from(range.cloneContents().children).forEach((item, index) => {
400
+ if (
401
+ item.nodeType !== 3 &&
402
+ liElement &&
403
+ item.textContent.trim() !== "" &&
404
+ liElement.getAttribute("data-node-id") ===
405
+ item.getAttribute("data-node-id")
406
+ ) {
407
+ if (index !== 0) {
408
+ liElements.push(liElement);
409
+ }
410
+ liElement = liElement.nextElementSibling as HTMLElement;
411
+ }
412
+ });
413
+
414
+ vditor[vditor.currentMode].element
415
+ .querySelectorAll("wbr")
416
+ .forEach((wbr) => {
417
+ wbr.remove();
418
+ });
419
+ range.insertNode(document.createElement("wbr"));
420
+ const liParentElement = previousElement.parentElement;
421
+
422
+ let liHTML = "";
423
+ liElements.forEach((item: HTMLElement) => {
424
+ let marker = item.getAttribute("data-marker");
425
+ if (marker.length !== 1) {
426
+ marker = `1${marker.slice(-1)}`;
427
+ }
428
+ liHTML += `<li data-node-id="${item.getAttribute("data-node-id")}" data-marker="${marker}">${item.innerHTML}</li>`;
429
+ item.remove();
430
+ });
431
+ previousElement.insertAdjacentHTML(
432
+ "beforeend",
433
+ `<${liParentElement.tagName} data-block="0">${liHTML}</${liParentElement.tagName}>`
434
+ );
435
+
436
+ if (vditor.currentMode === "wysiwyg") {
437
+ liParentElement.outerHTML = vditor.lute.SpinVditorDOM(
438
+ liParentElement.outerHTML
439
+ );
440
+ } else {
441
+ liParentElement.outerHTML = vditor.lute.SpinVditorIRDOM(
442
+ liParentElement.outerHTML
443
+ );
444
+ }
445
+
446
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
447
+ const tempTopListElement = getTopList(range.startContainer);
448
+ if (tempTopListElement) {
449
+ tempTopListElement
450
+ .querySelectorAll(
451
+ `.vditor-${vditor.currentMode}__preview[data-render='2']`
452
+ )
453
+ .forEach((item: HTMLElement) => {
454
+ processCodeRender(item, vditor);
455
+ if (vditor.currentMode === "wysiwyg") {
456
+ item.previousElementSibling.setAttribute(
457
+ "style",
458
+ "display:none"
459
+ );
460
+ }
461
+ });
462
+ }
463
+ execAfterRender(vditor);
464
+ highlightToolbar(vditor);
465
+ } else {
466
+ vditor[vditor.currentMode].element.focus();
467
+ }
468
+ };
469
+
470
+ export const listOutdent = (
471
+ vditor: IVditor,
472
+ liElement: HTMLElement,
473
+ range: Range,
474
+ topListElement: HTMLElement
475
+ ) => {
476
+ const liParentLiElement = hasClosestByMatchTag(
477
+ liElement.parentElement,
478
+ "LI"
479
+ );
480
+ if (liParentLiElement) {
481
+ vditor[vditor.currentMode].element
482
+ .querySelectorAll("wbr")
483
+ .forEach((wbr) => {
484
+ wbr.remove();
485
+ });
486
+ range.insertNode(document.createElement("wbr"));
487
+
488
+ const liParentElement = liElement.parentElement;
489
+ const liParentAfterElement = liParentElement.cloneNode() as HTMLElement;
490
+ const liElements: HTMLElement[] = [liElement];
491
+ Array.from(range.cloneContents().children).forEach((item, index) => {
492
+ if (
493
+ item.nodeType !== 3 &&
494
+ liElement &&
495
+ item.textContent.trim() !== "" &&
496
+ liElement.getAttribute("data-node-id") ===
497
+ item.getAttribute("data-node-id")
498
+ ) {
499
+ if (index !== 0) {
500
+ liElements.push(liElement);
501
+ }
502
+ liElement = liElement.nextElementSibling as HTMLElement;
503
+ }
504
+ });
505
+ let isMatch = false;
506
+ let afterHTML = "";
507
+ liParentElement.querySelectorAll("li").forEach((item) => {
508
+ if (isMatch) {
509
+ afterHTML += item.outerHTML;
510
+ if (!item.nextElementSibling && !item.previousElementSibling) {
511
+ item.parentElement.remove();
512
+ } else {
513
+ item.remove();
514
+ }
515
+ }
516
+ if (item.isSameNode(liElements[liElements.length - 1])) {
517
+ isMatch = true;
518
+ }
519
+ });
520
+
521
+ liElements.reverse().forEach((item) => {
522
+ liParentLiElement.insertAdjacentElement("afterend", item);
523
+ });
524
+
525
+ if (afterHTML) {
526
+ liParentAfterElement.innerHTML = afterHTML;
527
+ liElements[0].insertAdjacentElement(
528
+ "beforeend",
529
+ liParentAfterElement
530
+ );
531
+ }
532
+
533
+ if (vditor.currentMode === "wysiwyg") {
534
+ topListElement.outerHTML = vditor.lute.SpinVditorDOM(
535
+ topListElement.outerHTML
536
+ );
537
+ } else {
538
+ topListElement.outerHTML = vditor.lute.SpinVditorIRDOM(
539
+ topListElement.outerHTML
540
+ );
541
+ }
542
+
543
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
544
+ const tempTopListElement = getTopList(range.startContainer);
545
+ if (tempTopListElement) {
546
+ tempTopListElement
547
+ .querySelectorAll(
548
+ `.vditor-${vditor.currentMode}__preview[data-render='2']`
549
+ )
550
+ .forEach((item: HTMLElement) => {
551
+ processCodeRender(item, vditor);
552
+ if (vditor.currentMode === "wysiwyg") {
553
+ item.previousElementSibling.setAttribute(
554
+ "style",
555
+ "display:none"
556
+ );
557
+ }
558
+ });
559
+ }
560
+ execAfterRender(vditor);
561
+ highlightToolbar(vditor);
562
+ } else {
563
+ vditor[vditor.currentMode].element.focus();
564
+ }
565
+ };
566
+
567
+ export const setTableAlign = (tableElement: HTMLTableElement, type: string) => {
568
+ const cell = getSelection().getRangeAt(0).startContainer.parentElement;
569
+
570
+ const columnCnt = tableElement.rows[0].cells.length;
571
+ const rowCnt = tableElement.rows.length;
572
+ let currentColumn = 0;
573
+
574
+ for (let i = 0; i < rowCnt; i++) {
575
+ for (let j = 0; j < columnCnt; j++) {
576
+ if (tableElement.rows[i].cells[j].isSameNode(cell)) {
577
+ currentColumn = j;
578
+ break;
579
+ }
580
+ }
581
+ }
582
+ for (let k = 0; k < rowCnt; k++) {
583
+ tableElement.rows[k].cells[currentColumn].setAttribute("align", type);
584
+ }
585
+ };
586
+
587
+ export const isHrMD = (text: string) => {
588
+ // - _ *
589
+ const marker = text.trimRight().split("\n").pop();
590
+ if (marker === "") {
591
+ return false;
592
+ }
593
+ if (
594
+ marker.replace(/ |-/g, "") === "" ||
595
+ marker.replace(/ |_/g, "") === "" ||
596
+ marker.replace(/ |\*/g, "") === ""
597
+ ) {
598
+ if (marker.replace(/ /g, "").length > 2) {
599
+ if (
600
+ marker.indexOf("-") > -1 &&
601
+ marker.trimLeft().indexOf(" ") === -1 &&
602
+ text.trimRight().split("\n").length > 1
603
+ ) {
604
+ // 满足 heading
605
+ return false;
606
+ }
607
+ if (marker.indexOf(" ") === 0 || marker.indexOf("\t") === 0) {
608
+ // 代码块
609
+ return false;
610
+ }
611
+ return true;
612
+ }
613
+ return false;
614
+ }
615
+ return false;
616
+ };
617
+
618
+ export const isHeadingMD = (text: string) => {
619
+ // - =
620
+ const textArray = text.trimRight().split("\n");
621
+ text = textArray.pop();
622
+
623
+ if (text.indexOf(" ") === 0 || text.indexOf("\t") === 0) {
624
+ return false;
625
+ }
626
+
627
+ text = text.trimLeft();
628
+ if (text === "" || textArray.length === 0) {
629
+ return false;
630
+ }
631
+ if (text.replace(/-/g, "") === "" || text.replace(/=/g, "") === "") {
632
+ return true;
633
+ }
634
+ return false;
635
+ };
636
+
637
+ export const execAfterRender = (
638
+ vditor: IVditor,
639
+ options = {
640
+ enableAddUndoStack: true,
641
+ enableHint: false,
642
+ enableInput: true,
643
+ }
644
+ ) => {
645
+ if (vditor.currentMode === "wysiwyg") {
646
+ afterRenderEvent(vditor, options);
647
+ } else if (vditor.currentMode === "ir") {
648
+ processAfterRender(vditor, options);
649
+ } else if (vditor.currentMode === "sv") {
650
+ processSVAfterRender(vditor, options);
651
+ }
652
+ };
653
+
654
+ export const fixList = (
655
+ range: Range,
656
+ vditor: IVditor,
657
+ pElement: HTMLElement | false,
658
+ event: KeyboardEvent
659
+ ) => {
660
+ const startContainer = range.startContainer;
661
+ const liElement = hasClosestByMatchTag(startContainer, "LI");
662
+ if (liElement) {
663
+ if (
664
+ !isCtrl(event) &&
665
+ !event.altKey &&
666
+ event.key === "Enter" &&
667
+ // fix li 中有多个 P 时,在第一个 P 中换行会在下方生成新的 li
668
+ !event.shiftKey &&
669
+ pElement &&
670
+ liElement.contains(pElement) &&
671
+ pElement.nextElementSibling
672
+ ) {
673
+ if (liElement && !liElement.textContent.endsWith("\n")) {
674
+ // li 结尾需 \n
675
+ liElement.insertAdjacentText("beforeend", "\n");
676
+ }
677
+ range.insertNode(document.createTextNode("\n\n"));
678
+ range.collapse(false);
679
+ execAfterRender(vditor);
680
+ event.preventDefault();
681
+ return true;
682
+ }
683
+
684
+ if (
685
+ !isCtrl(event) &&
686
+ !event.shiftKey &&
687
+ !event.altKey &&
688
+ event.key === "Backspace" &&
689
+ !liElement.previousElementSibling &&
690
+ range.toString() === "" &&
691
+ getSelectPosition(
692
+ liElement,
693
+ vditor[vditor.currentMode].element,
694
+ range
695
+ ).start === 0
696
+ ) {
697
+ // 光标位于点和第一个字符中间时,无法删除 li 元素
698
+ if (liElement.nextElementSibling) {
699
+ liElement.parentElement.insertAdjacentHTML(
700
+ "beforebegin",
701
+ `<p data-block="0"><wbr>${liElement.innerHTML}</p>`
702
+ );
703
+ liElement.remove();
704
+ } else {
705
+ liElement.parentElement.outerHTML = `<p data-block="0"><wbr>${liElement.innerHTML}</p>`;
706
+ }
707
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
708
+ execAfterRender(vditor);
709
+ event.preventDefault();
710
+ return true;
711
+ }
712
+
713
+ // 空列表删除后与上一级段落对齐
714
+ if (
715
+ !isCtrl(event) &&
716
+ !event.shiftKey &&
717
+ !event.altKey &&
718
+ event.key === "Backspace" &&
719
+ liElement.textContent.trim().replace(Constants.ZWSP, "") === "" &&
720
+ range.toString() === "" &&
721
+ liElement.previousElementSibling?.tagName === "LI"
722
+ ) {
723
+ liElement.previousElementSibling.insertAdjacentText(
724
+ "beforeend",
725
+ "\n\n"
726
+ );
727
+ range.selectNodeContents(liElement.previousElementSibling);
728
+ range.collapse(false);
729
+ liElement.remove();
730
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
731
+ execAfterRender(vditor);
732
+ event.preventDefault();
733
+ return true;
734
+ }
735
+
736
+ if (!isCtrl(event) && !event.altKey && event.key === "Tab") {
737
+ // 光标位于第一/零字符时,tab 用于列表的缩进
738
+ let isFirst = false;
739
+ if (
740
+ range.startOffset === 0 &&
741
+ ((startContainer.nodeType === 3 &&
742
+ !startContainer.previousSibling) ||
743
+ (startContainer.nodeType !== 3 &&
744
+ startContainer.nodeName === "LI"))
745
+ ) {
746
+ // 有序/无序列表
747
+ isFirst = true;
748
+ } else if (
749
+ liElement.classList.contains("vditor-task") &&
750
+ range.startOffset === 1 &&
751
+ startContainer.previousSibling.nodeType !== 3 &&
752
+ (startContainer.previousSibling as HTMLElement).tagName ===
753
+ "INPUT"
754
+ ) {
755
+ // 任务列表
756
+ isFirst = true;
757
+ }
758
+
759
+ if (isFirst || range.toString() !== "") {
760
+ if (event.shiftKey) {
761
+ listOutdent(
762
+ vditor,
763
+ liElement,
764
+ range,
765
+ liElement.parentElement
766
+ );
767
+ } else {
768
+ listIndent(vditor, liElement, range);
769
+ }
770
+ event.preventDefault();
771
+ return true;
772
+ }
773
+ }
774
+ }
775
+ return false;
776
+ };
777
+
778
+ // tab 处理: block code render, table, 列表第一个字符中的 tab 处理单独写在上面
779
+ export const fixTab = (vditor: IVditor, range: Range, event: KeyboardEvent) => {
780
+ if (vditor.options.tab && event.key === "Tab") {
781
+ if (event.shiftKey) {
782
+ // TODO shift+tab
783
+ } else {
784
+ if (range.toString() === "") {
785
+ range.insertNode(document.createTextNode(vditor.options.tab));
786
+ range.collapse(false);
787
+ } else {
788
+ range.extractContents();
789
+ range.insertNode(document.createTextNode(vditor.options.tab));
790
+ range.collapse(false);
791
+ }
792
+ }
793
+ setSelectionFocus(range);
794
+ execAfterRender(vditor);
795
+ event.preventDefault();
796
+ return true;
797
+ }
798
+ };
799
+
800
+ export const fixMarkdown = (
801
+ event: KeyboardEvent,
802
+ vditor: IVditor,
803
+ pElement: HTMLElement | false,
804
+ range: Range
805
+ ) => {
806
+ if (!pElement) {
807
+ return;
808
+ }
809
+ if (!isCtrl(event) && !event.altKey && event.key === "Enter") {
810
+ const pText = String.raw`${pElement.textContent}`
811
+ .replace(/\\\|/g, "")
812
+ .trim();
813
+ const pTextList = pText.split("|");
814
+ if (
815
+ pText.startsWith("|") &&
816
+ pText.endsWith("|") &&
817
+ pTextList.length > 3
818
+ ) {
819
+ // table 自动完成
820
+ let tableHeaderMD = pTextList.map(() => "---").join("|");
821
+ tableHeaderMD =
822
+ pElement.textContent +
823
+ "\n" +
824
+ tableHeaderMD.substring(3, tableHeaderMD.length - 3) +
825
+ "\n|<wbr>";
826
+ pElement.outerHTML = vditor.lute.SpinVditorDOM(tableHeaderMD);
827
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
828
+ execAfterRender(vditor);
829
+ scrollCenter(vditor);
830
+ event.preventDefault();
831
+ return true;
832
+ }
833
+
834
+ // hr 渲染
835
+ if (isHrMD(pElement.innerHTML) && pElement.previousElementSibling) {
836
+ // 软换行后 hr 前有内容
837
+ let pInnerHTML = "";
838
+ const innerHTMLList = pElement.innerHTML.trimRight().split("\n");
839
+ if (innerHTMLList.length > 1) {
840
+ innerHTMLList.pop();
841
+ pInnerHTML = `<p data-block="0">${innerHTMLList.join("\n")}</p>`;
842
+ }
843
+
844
+ pElement.insertAdjacentHTML(
845
+ "afterend",
846
+ `${pInnerHTML}<hr data-block="0"><p data-block="0"><wbr>\n</p>`
847
+ );
848
+ pElement.remove();
849
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
850
+ execAfterRender(vditor);
851
+ scrollCenter(vditor);
852
+ event.preventDefault();
853
+ return true;
854
+ }
855
+
856
+ if (isHeadingMD(pElement.innerHTML)) {
857
+ // heading 渲染
858
+ if (vditor.currentMode === "wysiwyg") {
859
+ pElement.outerHTML = vditor.lute.SpinVditorDOM(
860
+ pElement.innerHTML + '<p data-block="0"><wbr>\n</p>'
861
+ );
862
+ } else {
863
+ pElement.outerHTML = vditor.lute.SpinVditorIRDOM(
864
+ pElement.innerHTML + '<p data-block="0"><wbr>\n</p>'
865
+ );
866
+ }
867
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
868
+ execAfterRender(vditor);
869
+ scrollCenter(vditor);
870
+ event.preventDefault();
871
+ return true;
872
+ }
873
+ }
874
+
875
+ // 软换行会被切割 https://github.com/Vanessa219/vditor/issues/220
876
+ if (
877
+ range.collapsed &&
878
+ pElement.previousElementSibling &&
879
+ event.key === "Backspace" &&
880
+ !isCtrl(event) &&
881
+ !event.altKey &&
882
+ !event.shiftKey &&
883
+ pElement.textContent.trimRight().split("\n").length > 1 &&
884
+ getSelectPosition(pElement, vditor[vditor.currentMode].element, range)
885
+ .start === 0
886
+ ) {
887
+ const lastElement = getLastNode(
888
+ pElement.previousElementSibling
889
+ ) as HTMLElement;
890
+ if (!lastElement.textContent.endsWith("\n")) {
891
+ lastElement.textContent = lastElement.textContent + "\n";
892
+ }
893
+ lastElement.parentElement.insertAdjacentHTML(
894
+ "beforeend",
895
+ `<wbr>${pElement.innerHTML}`
896
+ );
897
+ pElement.remove();
898
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
899
+ return false;
900
+ }
901
+ return false;
902
+ };
903
+
904
+ export const insertRow = (
905
+ vditor: IVditor,
906
+ range: Range,
907
+ cellElement: HTMLElement
908
+ ) => {
909
+ let rowHTML = "";
910
+ for (let m = 0; m < cellElement.parentElement.childElementCount; m++) {
911
+ rowHTML += `<td align="${cellElement.parentElement.children[m].getAttribute("align")}"> </td>`;
912
+ }
913
+ if (cellElement.tagName === "TH") {
914
+ cellElement.parentElement.parentElement.insertAdjacentHTML(
915
+ "afterend",
916
+ `<tbody><tr>${rowHTML}</tr></tbody>`
917
+ );
918
+ } else {
919
+ cellElement.parentElement.insertAdjacentHTML(
920
+ "afterend",
921
+ `<tr>${rowHTML}</tr>`
922
+ );
923
+ }
924
+ execAfterRender(vditor);
925
+ };
926
+
927
+ export const insertRowAbove = (
928
+ vditor: IVditor,
929
+ range: Range,
930
+ cellElement: HTMLElement
931
+ ) => {
932
+ let rowHTML = "";
933
+ for (let m = 0; m < cellElement.parentElement.childElementCount; m++) {
934
+ if (cellElement.tagName === "TH") {
935
+ rowHTML += `<th align="${cellElement.parentElement.children[m].getAttribute("align")}"> </th>`;
936
+ } else {
937
+ rowHTML += `<td align="${cellElement.parentElement.children[m].getAttribute("align")}"> </td>`;
938
+ }
939
+ }
940
+ if (cellElement.tagName === "TH") {
941
+ cellElement.parentElement.parentElement.insertAdjacentHTML(
942
+ "beforebegin",
943
+ `<thead><tr>${rowHTML}</tr></thead>`
944
+ );
945
+
946
+ range.insertNode(document.createElement("wbr"));
947
+ const theadHTML = cellElement.parentElement.innerHTML
948
+ .replace(/<th>/g, "<td>")
949
+ .replace(/<\/th>/g, "</td>");
950
+ cellElement.parentElement.parentElement.nextElementSibling.insertAdjacentHTML(
951
+ "afterbegin",
952
+ theadHTML
953
+ );
954
+
955
+ cellElement.parentElement.parentElement.remove();
956
+ setRangeByWbr(vditor.ir.element, range);
957
+ } else {
958
+ cellElement.parentElement.insertAdjacentHTML(
959
+ "beforebegin",
960
+ `<tr>${rowHTML}</tr>`
961
+ );
962
+ }
963
+ execAfterRender(vditor);
964
+ };
965
+
966
+ export const insertColumn = (
967
+ vditor: IVditor,
968
+ tableElement: HTMLTableElement,
969
+ cellElement: HTMLElement,
970
+ type: InsertPosition = "afterend"
971
+ ) => {
972
+ let index = 0;
973
+ let previousElement = cellElement.previousElementSibling;
974
+ while (previousElement) {
975
+ index++;
976
+ previousElement = previousElement.previousElementSibling;
977
+ }
978
+ for (let i = 0; i < tableElement.rows.length; i++) {
979
+ if (i === 0) {
980
+ tableElement.rows[i].cells[index].insertAdjacentHTML(
981
+ type,
982
+ "<th> </th>"
983
+ );
984
+ } else {
985
+ tableElement.rows[i].cells[index].insertAdjacentHTML(
986
+ type,
987
+ "<td> </td>"
988
+ );
989
+ }
990
+ }
991
+ execAfterRender(vditor);
992
+ };
993
+ export const deleteRow = (
994
+ vditor: IVditor,
995
+ range: Range,
996
+ cellElement: HTMLElement
997
+ ) => {
998
+ if (cellElement.tagName === "TD") {
999
+ const tbodyElement = cellElement.parentElement.parentElement;
1000
+ if (cellElement.parentElement.previousElementSibling) {
1001
+ range.selectNodeContents(
1002
+ cellElement.parentElement.previousElementSibling
1003
+ .lastElementChild
1004
+ );
1005
+ } else {
1006
+ range.selectNodeContents(
1007
+ tbodyElement.previousElementSibling.lastElementChild
1008
+ .lastElementChild
1009
+ );
1010
+ }
1011
+
1012
+ if (tbodyElement.childElementCount === 1) {
1013
+ tbodyElement.remove();
1014
+ } else {
1015
+ cellElement.parentElement.remove();
1016
+ }
1017
+
1018
+ range.collapse(false);
1019
+ setSelectionFocus(range);
1020
+ execAfterRender(vditor);
1021
+ }
1022
+ };
1023
+
1024
+ export const deleteColumn = (
1025
+ vditor: IVditor,
1026
+ range: Range,
1027
+ tableElement: HTMLTableElement,
1028
+ cellElement: HTMLElement
1029
+ ) => {
1030
+ let index = 0;
1031
+ let previousElement = cellElement.previousElementSibling;
1032
+ while (previousElement) {
1033
+ index++;
1034
+ previousElement = previousElement.previousElementSibling;
1035
+ }
1036
+ if (cellElement.previousElementSibling || cellElement.nextElementSibling) {
1037
+ range.selectNodeContents(
1038
+ cellElement.previousElementSibling || cellElement.nextElementSibling
1039
+ );
1040
+ range.collapse(true);
1041
+ }
1042
+ for (let i = 0; i < tableElement.rows.length; i++) {
1043
+ const cells = tableElement.rows[i].cells;
1044
+ if (cells.length === 1) {
1045
+ tableElement.remove();
1046
+ highlightToolbar(vditor);
1047
+ break;
1048
+ }
1049
+ cells[index].remove();
1050
+ }
1051
+ setSelectionFocus(range);
1052
+ execAfterRender(vditor);
1053
+ };
1054
+
1055
+ export const fixTable = (
1056
+ vditor: IVditor,
1057
+ event: KeyboardEvent,
1058
+ range: Range
1059
+ ) => {
1060
+ const startContainer = range.startContainer;
1061
+ const cellElement =
1062
+ hasClosestByMatchTag(startContainer, "TD") ||
1063
+ hasClosestByMatchTag(startContainer, "TH");
1064
+ if (cellElement) {
1065
+ // 换行或软换行:在 cell 中添加 br
1066
+ if (!isCtrl(event) && !event.altKey && event.key === "Enter") {
1067
+ if (
1068
+ !cellElement.lastElementChild ||
1069
+ (cellElement.lastElementChild &&
1070
+ (!cellElement.lastElementChild.isSameNode(
1071
+ cellElement.lastChild
1072
+ ) ||
1073
+ cellElement.lastElementChild.tagName !== "BR"))
1074
+ ) {
1075
+ cellElement.insertAdjacentHTML("beforeend", "<br>");
1076
+ }
1077
+ const brElement = document.createElement("br");
1078
+ range.insertNode(brElement);
1079
+ range.setStartAfter(brElement);
1080
+ execAfterRender(vditor);
1081
+ scrollCenter(vditor);
1082
+ event.preventDefault();
1083
+ return true;
1084
+ }
1085
+
1086
+ // tab:光标移向下一个 cell
1087
+ if (event.key === "Tab") {
1088
+ if (event.shiftKey) {
1089
+ // shift + tab 光标移动到前一个 cell
1090
+ goPreviousCell(cellElement, range);
1091
+ event.preventDefault();
1092
+ return true;
1093
+ }
1094
+
1095
+ let nextElement = cellElement.nextElementSibling;
1096
+ if (!nextElement) {
1097
+ if (cellElement.parentElement.nextElementSibling) {
1098
+ nextElement =
1099
+ cellElement.parentElement.nextElementSibling
1100
+ .firstElementChild;
1101
+ } else if (
1102
+ cellElement.parentElement.parentElement.tagName ===
1103
+ "THEAD" &&
1104
+ cellElement.parentElement.parentElement.nextElementSibling
1105
+ ) {
1106
+ nextElement =
1107
+ cellElement.parentElement.parentElement
1108
+ .nextElementSibling.firstElementChild
1109
+ .firstElementChild;
1110
+ } else {
1111
+ nextElement = null;
1112
+ }
1113
+ }
1114
+ if (nextElement) {
1115
+ range.selectNodeContents(nextElement);
1116
+ setSelectionFocus(range);
1117
+ }
1118
+ event.preventDefault();
1119
+ return true;
1120
+ }
1121
+
1122
+ const tableElement = cellElement.parentElement.parentElement
1123
+ .parentElement as HTMLTableElement;
1124
+ if (event.key === "ArrowUp") {
1125
+ event.preventDefault();
1126
+ if (cellElement.tagName === "TH") {
1127
+ if (tableElement.previousElementSibling) {
1128
+ range.selectNodeContents(
1129
+ tableElement.previousElementSibling
1130
+ );
1131
+ range.collapse(false);
1132
+ setSelectionFocus(range);
1133
+ } else {
1134
+ insertEmptyBlock(vditor, "beforebegin");
1135
+ }
1136
+ return true;
1137
+ }
1138
+
1139
+ let m = 0;
1140
+ const trElement = cellElement.parentElement as HTMLTableRowElement;
1141
+ for (; m < trElement.cells.length; m++) {
1142
+ if (trElement.cells[m].isSameNode(cellElement)) {
1143
+ break;
1144
+ }
1145
+ }
1146
+
1147
+ let previousElement =
1148
+ trElement.previousElementSibling as HTMLTableRowElement;
1149
+ if (!previousElement) {
1150
+ previousElement = trElement.parentElement.previousElementSibling
1151
+ .firstChild as HTMLTableRowElement;
1152
+ }
1153
+ range.selectNodeContents(previousElement.cells[m]);
1154
+ range.collapse(false);
1155
+ setSelectionFocus(range);
1156
+ return true;
1157
+ }
1158
+
1159
+ if (event.key === "ArrowDown") {
1160
+ event.preventDefault();
1161
+ const trElement = cellElement.parentElement as HTMLTableRowElement;
1162
+ if (!trElement.nextElementSibling && cellElement.tagName === "TD") {
1163
+ if (tableElement.nextElementSibling) {
1164
+ range.selectNodeContents(tableElement.nextElementSibling);
1165
+ range.collapse(true);
1166
+ setSelectionFocus(range);
1167
+ } else {
1168
+ insertEmptyBlock(vditor, "afterend");
1169
+ }
1170
+ return true;
1171
+ }
1172
+
1173
+ let m = 0;
1174
+ for (; m < trElement.cells.length; m++) {
1175
+ if (trElement.cells[m].isSameNode(cellElement)) {
1176
+ break;
1177
+ }
1178
+ }
1179
+
1180
+ let nextElement =
1181
+ trElement.nextElementSibling as HTMLTableRowElement;
1182
+ if (!nextElement) {
1183
+ nextElement = trElement.parentElement.nextElementSibling
1184
+ .firstChild as HTMLTableRowElement;
1185
+ }
1186
+ range.selectNodeContents(nextElement.cells[m]);
1187
+ range.collapse(true);
1188
+ setSelectionFocus(range);
1189
+ return true;
1190
+ }
1191
+
1192
+ // focus row input, only wysiwyg
1193
+ if (
1194
+ vditor.currentMode === "wysiwyg" &&
1195
+ !isCtrl(event) &&
1196
+ event.key === "Enter" &&
1197
+ !event.shiftKey &&
1198
+ event.altKey
1199
+ ) {
1200
+ const inputElement = vditor.wysiwyg.popover.querySelector(
1201
+ ".vditor-input"
1202
+ ) as HTMLInputElement;
1203
+ inputElement.focus();
1204
+ inputElement.select();
1205
+ event.preventDefault();
1206
+ return true;
1207
+ }
1208
+
1209
+ // Backspace:光标移动到前一个 cell
1210
+ if (
1211
+ !isCtrl(event) &&
1212
+ !event.shiftKey &&
1213
+ !event.altKey &&
1214
+ event.key === "Backspace" &&
1215
+ range.startOffset === 0 &&
1216
+ range.toString() === ""
1217
+ ) {
1218
+ const previousCellElement = goPreviousCell(
1219
+ cellElement,
1220
+ range,
1221
+ false
1222
+ );
1223
+ if (!previousCellElement && tableElement) {
1224
+ if (tableElement.textContent.trim() === "") {
1225
+ tableElement.outerHTML = `<p data-block="0"><wbr>\n</p>`;
1226
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1227
+ } else {
1228
+ range.setStartBefore(tableElement);
1229
+ range.collapse(true);
1230
+ }
1231
+ execAfterRender(vditor);
1232
+ }
1233
+ event.preventDefault();
1234
+ return true;
1235
+ }
1236
+ // 上方新添加一行
1237
+ if (matchHotKey("⇧⌘F", event)) {
1238
+ insertRowAbove(vditor, range, cellElement);
1239
+ event.preventDefault();
1240
+ return true;
1241
+ }
1242
+
1243
+ // 下方新添加一行 https://github.com/Vanessa219/vditor/issues/46
1244
+ if (matchHotKey("⌘=", event)) {
1245
+ insertRow(vditor, range, cellElement);
1246
+ event.preventDefault();
1247
+ return true;
1248
+ }
1249
+
1250
+ // 左方新添加一列
1251
+ if (matchHotKey("⇧⌘G", event)) {
1252
+ insertColumn(vditor, tableElement, cellElement, "beforebegin");
1253
+ event.preventDefault();
1254
+ return true;
1255
+ }
1256
+
1257
+ // 后方新添加一列
1258
+ if (matchHotKey("⇧⌘=", event)) {
1259
+ insertColumn(vditor, tableElement, cellElement);
1260
+ event.preventDefault();
1261
+ return true;
1262
+ }
1263
+
1264
+ // 删除当前行
1265
+ if (matchHotKey("⌘-", event)) {
1266
+ deleteRow(vditor, range, cellElement);
1267
+ event.preventDefault();
1268
+ return true;
1269
+ }
1270
+
1271
+ // 删除当前列
1272
+ if (matchHotKey("⇧⌘-", event)) {
1273
+ deleteColumn(vditor, range, tableElement, cellElement);
1274
+ event.preventDefault();
1275
+ return true;
1276
+ }
1277
+
1278
+ // 剧左
1279
+ if (matchHotKey("⇧⌘L", event)) {
1280
+ if (vditor.currentMode === "ir") {
1281
+ setTableAlign(tableElement, "left");
1282
+ execAfterRender(vditor);
1283
+ event.preventDefault();
1284
+ return true;
1285
+ } else {
1286
+ const itemElement: HTMLElement =
1287
+ vditor.wysiwyg.popover.querySelector('[data-type="left"]');
1288
+ if (itemElement) {
1289
+ itemElement.click();
1290
+ event.preventDefault();
1291
+ return true;
1292
+ }
1293
+ }
1294
+ }
1295
+
1296
+ // 剧中
1297
+ if (matchHotKey("⇧⌘C", event)) {
1298
+ if (vditor.currentMode === "ir") {
1299
+ setTableAlign(tableElement, "center");
1300
+ execAfterRender(vditor);
1301
+ event.preventDefault();
1302
+ return true;
1303
+ } else {
1304
+ const itemElement: HTMLElement =
1305
+ vditor.wysiwyg.popover.querySelector(
1306
+ '[data-type="center"]'
1307
+ );
1308
+ if (itemElement) {
1309
+ itemElement.click();
1310
+ event.preventDefault();
1311
+ return true;
1312
+ }
1313
+ }
1314
+ }
1315
+ // 剧右
1316
+ if (matchHotKey("⇧⌘R", event)) {
1317
+ if (vditor.currentMode === "ir") {
1318
+ setTableAlign(tableElement, "right");
1319
+ execAfterRender(vditor);
1320
+ event.preventDefault();
1321
+ return true;
1322
+ } else {
1323
+ const itemElement: HTMLElement =
1324
+ vditor.wysiwyg.popover.querySelector('[data-type="right"]');
1325
+ if (itemElement) {
1326
+ itemElement.click();
1327
+ event.preventDefault();
1328
+ return true;
1329
+ }
1330
+ }
1331
+ }
1332
+ }
1333
+ return false;
1334
+ };
1335
+
1336
+ export const fixCodeBlock = (
1337
+ vditor: IVditor,
1338
+ event: KeyboardEvent,
1339
+ codeRenderElement: HTMLElement,
1340
+ range: Range
1341
+ ) => {
1342
+ // 行级代码块中 command + a,近对当前代码块进行全选
1343
+ if (codeRenderElement.tagName === "PRE" && matchHotKey("⌘A", event)) {
1344
+ range.selectNodeContents(codeRenderElement.firstElementChild);
1345
+ event.preventDefault();
1346
+ return true;
1347
+ }
1348
+
1349
+ // tab
1350
+ // TODO shift + tab, shift and 选中文字
1351
+ if (
1352
+ vditor.options.tab &&
1353
+ event.key === "Tab" &&
1354
+ !event.shiftKey &&
1355
+ range.toString() === ""
1356
+ ) {
1357
+ range.insertNode(document.createTextNode(vditor.options.tab));
1358
+ range.collapse(false);
1359
+ execAfterRender(vditor);
1360
+ event.preventDefault();
1361
+ return true;
1362
+ }
1363
+
1364
+ // Backspace: 光标位于第零个字符,仅删除代码块标签
1365
+ if (
1366
+ event.key === "Backspace" &&
1367
+ !isCtrl(event) &&
1368
+ !event.shiftKey &&
1369
+ !event.altKey
1370
+ ) {
1371
+ const codePosition = getSelectPosition(
1372
+ codeRenderElement,
1373
+ vditor[vditor.currentMode].element,
1374
+ range
1375
+ );
1376
+ if (
1377
+ (codePosition.start === 0 ||
1378
+ (codePosition.start === 1 &&
1379
+ codeRenderElement.innerText === "\n")) && // 空代码块,光标在 \n 后
1380
+ range.toString() === ""
1381
+ ) {
1382
+ codeRenderElement.parentElement.outerHTML = `<p data-block="0"><wbr>${codeRenderElement.firstElementChild.innerHTML}</p>`;
1383
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1384
+ execAfterRender(vditor);
1385
+ event.preventDefault();
1386
+ return true;
1387
+ }
1388
+ }
1389
+
1390
+ // 换行
1391
+ if (!isCtrl(event) && !event.altKey && event.key === "Enter") {
1392
+ if (!codeRenderElement.firstElementChild.textContent.endsWith("\n")) {
1393
+ codeRenderElement.firstElementChild.insertAdjacentText(
1394
+ "beforeend",
1395
+ "\n"
1396
+ );
1397
+ }
1398
+ range.extractContents();
1399
+ range.insertNode(document.createTextNode("\n"));
1400
+ range.collapse(false);
1401
+ setSelectionFocus(range);
1402
+ if (!isFirefox()) {
1403
+ if (vditor.currentMode === "wysiwyg") {
1404
+ input(vditor, range);
1405
+ } else {
1406
+ IRInput(vditor, range);
1407
+ }
1408
+ }
1409
+ scrollCenter(vditor);
1410
+ event.preventDefault();
1411
+ return true;
1412
+ }
1413
+ return false;
1414
+ };
1415
+
1416
+ export const fixBlockquote = (
1417
+ vditor: IVditor,
1418
+ range: Range,
1419
+ event: KeyboardEvent,
1420
+ pElement: HTMLElement | false
1421
+ ) => {
1422
+ const startContainer = range.startContainer;
1423
+ const blockquoteElement = hasClosestByMatchTag(
1424
+ startContainer,
1425
+ "BLOCKQUOTE"
1426
+ );
1427
+ if (blockquoteElement && range.toString() === "") {
1428
+ if (
1429
+ event.key === "Backspace" &&
1430
+ !isCtrl(event) &&
1431
+ !event.shiftKey &&
1432
+ !event.altKey &&
1433
+ getSelectPosition(
1434
+ blockquoteElement,
1435
+ vditor[vditor.currentMode].element,
1436
+ range
1437
+ ).start === 0
1438
+ ) {
1439
+ // Backspace: 光标位于引用中的第零个字符,仅删除引用标签
1440
+ range.insertNode(document.createElement("wbr"));
1441
+ blockquoteElement.outerHTML = blockquoteElement.innerHTML;
1442
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1443
+ execAfterRender(vditor);
1444
+ event.preventDefault();
1445
+ return true;
1446
+ }
1447
+
1448
+ if (
1449
+ pElement &&
1450
+ event.key === "Enter" &&
1451
+ !isCtrl(event) &&
1452
+ !event.shiftKey &&
1453
+ !event.altKey &&
1454
+ pElement.parentElement.tagName === "BLOCKQUOTE"
1455
+ ) {
1456
+ // Enter: 空行回车应逐层跳出
1457
+ let isEmpty = false;
1458
+ if (
1459
+ pElement.innerHTML.replace(Constants.ZWSP, "") === "\n" ||
1460
+ pElement.innerHTML.replace(Constants.ZWSP, "") === ""
1461
+ ) {
1462
+ // 空 P
1463
+ isEmpty = true;
1464
+ pElement.remove();
1465
+ } else if (
1466
+ pElement.innerHTML.endsWith("\n\n") &&
1467
+ getSelectPosition(
1468
+ pElement,
1469
+ vditor[vditor.currentMode].element,
1470
+ range
1471
+ ).start ===
1472
+ pElement.textContent.length - 1
1473
+ ) {
1474
+ // 软换行
1475
+ pElement.innerHTML = pElement.innerHTML.substr(
1476
+ 0,
1477
+ pElement.innerHTML.length - 2
1478
+ );
1479
+ isEmpty = true;
1480
+ }
1481
+ if (isEmpty) {
1482
+ // 需添加零宽字符,否则的话无法记录 undo
1483
+ blockquoteElement.insertAdjacentHTML(
1484
+ "afterend",
1485
+ `<p data-block="0">${Constants.ZWSP}<wbr>\n</p>`
1486
+ );
1487
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1488
+ execAfterRender(vditor);
1489
+ event.preventDefault();
1490
+ return true;
1491
+ }
1492
+ }
1493
+ const blockElement = hasClosestBlock(startContainer);
1494
+ if (
1495
+ vditor.currentMode === "wysiwyg" &&
1496
+ blockElement &&
1497
+ matchHotKey("⇧⌘;", event)
1498
+ ) {
1499
+ // 插入 blockquote
1500
+ range.insertNode(document.createElement("wbr"));
1501
+ blockElement.outerHTML = `<blockquote data-block="0">${blockElement.outerHTML}</blockquote>`;
1502
+ setRangeByWbr(vditor.wysiwyg.element, range);
1503
+ afterRenderEvent(vditor);
1504
+ event.preventDefault();
1505
+ return true;
1506
+ }
1507
+
1508
+ if (
1509
+ insertAfterBlock(
1510
+ vditor,
1511
+ event,
1512
+ range,
1513
+ blockquoteElement,
1514
+ blockquoteElement
1515
+ )
1516
+ ) {
1517
+ return true;
1518
+ }
1519
+ if (
1520
+ insertBeforeBlock(
1521
+ vditor,
1522
+ event,
1523
+ range,
1524
+ blockquoteElement,
1525
+ blockquoteElement
1526
+ )
1527
+ ) {
1528
+ return true;
1529
+ }
1530
+ }
1531
+ return false;
1532
+ };
1533
+
1534
+ export const fixTask = (
1535
+ vditor: IVditor,
1536
+ range: Range,
1537
+ event: KeyboardEvent
1538
+ ) => {
1539
+ const startContainer = range.startContainer;
1540
+ const taskItemElement = hasClosestByMatchTag(startContainer, "LI");
1541
+ if (taskItemElement && taskItemElement.classList.contains("vditor-task")) {
1542
+ if (matchHotKey("⇧⌘J", event)) {
1543
+ // ctrl + shift: toggle checked
1544
+ const inputElement =
1545
+ taskItemElement.firstElementChild as HTMLInputElement;
1546
+ if (inputElement.checked) {
1547
+ inputElement.removeAttribute("checked");
1548
+ } else {
1549
+ inputElement.setAttribute("checked", "checked");
1550
+ }
1551
+ execAfterRender(vditor);
1552
+ event.preventDefault();
1553
+ return true;
1554
+ }
1555
+
1556
+ // Backspace: 在选择框前进行删除
1557
+ if (
1558
+ event.key === "Backspace" &&
1559
+ !isCtrl(event) &&
1560
+ !event.shiftKey &&
1561
+ !event.altKey &&
1562
+ range.toString() === "" &&
1563
+ range.startOffset === 1 &&
1564
+ ((startContainer.nodeType === 3 &&
1565
+ startContainer.previousSibling &&
1566
+ (startContainer.previousSibling as HTMLElement).tagName ===
1567
+ "INPUT") ||
1568
+ startContainer.nodeType !== 3)
1569
+ ) {
1570
+ const previousElement = taskItemElement.previousElementSibling;
1571
+ taskItemElement.querySelector("input").remove();
1572
+ if (previousElement) {
1573
+ const lastNode = getLastNode(previousElement);
1574
+ lastNode.parentElement.insertAdjacentHTML(
1575
+ "beforeend",
1576
+ "<wbr>" + taskItemElement.innerHTML.trim()
1577
+ );
1578
+ taskItemElement.remove();
1579
+ } else {
1580
+ taskItemElement.parentElement.insertAdjacentHTML(
1581
+ "beforebegin",
1582
+ `<p data-block="0"><wbr>${taskItemElement.innerHTML.trim() || "\n"}</p>`
1583
+ );
1584
+ if (taskItemElement.nextElementSibling) {
1585
+ taskItemElement.remove();
1586
+ } else {
1587
+ taskItemElement.parentElement.remove();
1588
+ }
1589
+ }
1590
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1591
+ execAfterRender(vditor);
1592
+ event.preventDefault();
1593
+ return true;
1594
+ }
1595
+
1596
+ if (
1597
+ event.key === "Enter" &&
1598
+ !isCtrl(event) &&
1599
+ !event.shiftKey &&
1600
+ !event.altKey
1601
+ ) {
1602
+ if (taskItemElement.textContent.trim() === "") {
1603
+ // 当前任务列表无文字
1604
+ if (
1605
+ hasClosestByClassName(
1606
+ taskItemElement.parentElement,
1607
+ "vditor-task"
1608
+ )
1609
+ ) {
1610
+ // 为子元素时,需进行反向缩进
1611
+ const topListElement = getTopList(startContainer);
1612
+ if (topListElement) {
1613
+ listOutdent(
1614
+ vditor,
1615
+ taskItemElement,
1616
+ range,
1617
+ topListElement
1618
+ );
1619
+ }
1620
+ } else {
1621
+ // 仅有一级任务列表
1622
+ if (taskItemElement.nextElementSibling) {
1623
+ // 任务列表下方还有元素,需要使用用段落隔断
1624
+ let afterHTML = "";
1625
+ let beforeHTML = "";
1626
+ let isAfter = false;
1627
+ Array.from(
1628
+ taskItemElement.parentElement.children
1629
+ ).forEach((taskItem) => {
1630
+ if (taskItemElement.isSameNode(taskItem)) {
1631
+ isAfter = true;
1632
+ } else {
1633
+ if (isAfter) {
1634
+ afterHTML += taskItem.outerHTML;
1635
+ } else {
1636
+ beforeHTML += taskItem.outerHTML;
1637
+ }
1638
+ }
1639
+ });
1640
+ const parentTagName =
1641
+ taskItemElement.parentElement.tagName;
1642
+ const dataMarker =
1643
+ taskItemElement.parentElement.tagName === "OL"
1644
+ ? ""
1645
+ : ` data-marker="${taskItemElement.parentElement.getAttribute("data-marker")}"`;
1646
+ let startAttribute = "";
1647
+ if (beforeHTML) {
1648
+ startAttribute =
1649
+ taskItemElement.parentElement.tagName === "UL"
1650
+ ? ""
1651
+ : ` start="1"`;
1652
+ beforeHTML = `<${parentTagName} data-tight="true"${dataMarker} data-block="0">${beforeHTML}</${parentTagName}>`;
1653
+ }
1654
+ // <p data-block="0">\n<wbr></p> => <p data-block="0"><wbr>\n</p>
1655
+ // https://github.com/Vanessa219/vditor/issues/430
1656
+ taskItemElement.parentElement.outerHTML = `${beforeHTML}<p data-block="0"><wbr>\n</p><${parentTagName}
1657
+ data-tight="true"${dataMarker} data-block="0"${startAttribute}>${afterHTML}</${parentTagName}>`;
1658
+ } else {
1659
+ // 任务列表下方无任务列表元素
1660
+ taskItemElement.parentElement.insertAdjacentHTML(
1661
+ "afterend",
1662
+ `<p data-block="0"><wbr>\n</p>`
1663
+ );
1664
+ if (
1665
+ taskItemElement.parentElement.querySelectorAll("li")
1666
+ .length === 1
1667
+ ) {
1668
+ // 任务列表仅有一项时,使用 p 元素替换
1669
+ taskItemElement.parentElement.remove();
1670
+ } else {
1671
+ // 任务列表有多项时,当前任务列表位于最后一项,移除该任务列表
1672
+ taskItemElement.remove();
1673
+ }
1674
+ }
1675
+ }
1676
+ } else if (
1677
+ startContainer.nodeType !== 3 &&
1678
+ range.startOffset === 0 &&
1679
+ (startContainer.firstChild as HTMLElement).tagName === "INPUT"
1680
+ ) {
1681
+ // 光标位于 input 之前
1682
+ range.setStart(startContainer.childNodes[1], 1);
1683
+ } else {
1684
+ // 当前任务列表有文字,光标后的文字需添加到新任务列表中
1685
+ range.setEndAfter(taskItemElement.lastChild);
1686
+ taskItemElement.insertAdjacentHTML(
1687
+ "afterend",
1688
+ `<li class="vditor-task" data-marker="${taskItemElement.getAttribute("data-marker")}"><input type="checkbox"> <wbr></li>`
1689
+ );
1690
+ document.querySelector("wbr").after(range.extractContents());
1691
+ }
1692
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1693
+ execAfterRender(vditor);
1694
+ scrollCenter(vditor);
1695
+ event.preventDefault();
1696
+ return true;
1697
+ }
1698
+ }
1699
+ return false;
1700
+ };
1701
+
1702
+ export const fixDelete = (
1703
+ vditor: IVditor,
1704
+ range: Range,
1705
+ event: KeyboardEvent,
1706
+ pElement: HTMLElement | false
1707
+ ) => {
1708
+ if (range.startContainer.nodeType !== 3) {
1709
+ // 光标位于 hr 前,hr 前有内容
1710
+ const rangeElement = (range.startContainer as HTMLElement).children[
1711
+ range.startOffset
1712
+ ];
1713
+ if (rangeElement && rangeElement.tagName === "HR") {
1714
+ range.selectNodeContents(rangeElement.previousElementSibling);
1715
+ range.collapse(false);
1716
+ event.preventDefault();
1717
+ return true;
1718
+ }
1719
+ }
1720
+
1721
+ if (pElement) {
1722
+ const previousElement = pElement.previousElementSibling;
1723
+ if (
1724
+ previousElement &&
1725
+ getSelectPosition(
1726
+ pElement,
1727
+ vditor[vditor.currentMode].element,
1728
+ range
1729
+ ).start === 0 &&
1730
+ ((isFirefox() && previousElement.tagName === "HR") ||
1731
+ previousElement.tagName === "TABLE")
1732
+ ) {
1733
+ if (previousElement.tagName === "TABLE") {
1734
+ // table 后删除 https://github.com/Vanessa219/vditor/issues/243
1735
+ const lastCellElement =
1736
+ previousElement.lastElementChild.lastElementChild
1737
+ .lastElementChild;
1738
+ lastCellElement.innerHTML =
1739
+ lastCellElement.innerHTML.trimLeft() +
1740
+ "<wbr>" +
1741
+ pElement.textContent.trim();
1742
+ pElement.remove();
1743
+ } else {
1744
+ // 光标位于 hr 后进行删除
1745
+ previousElement.remove();
1746
+ }
1747
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1748
+ execAfterRender(vditor);
1749
+ event.preventDefault();
1750
+ return true;
1751
+ }
1752
+ }
1753
+ return false;
1754
+ };
1755
+
1756
+ export const fixHR = (range: Range) => {
1757
+ if (
1758
+ isFirefox() &&
1759
+ range.startContainer.nodeType !== 3 &&
1760
+ (range.startContainer as HTMLElement).tagName === "HR"
1761
+ ) {
1762
+ range.setStartBefore(range.startContainer);
1763
+ }
1764
+ };
1765
+
1766
+ // firefox https://github.com/Vanessa219/vditor/issues/407
1767
+ export const fixFirefoxArrowUpTable = (
1768
+ event: KeyboardEvent,
1769
+ blockElement: false | HTMLElement,
1770
+ range: Range
1771
+ ) => {
1772
+ if (!isFirefox()) {
1773
+ return false;
1774
+ }
1775
+ if (
1776
+ event.key === "ArrowUp" &&
1777
+ blockElement &&
1778
+ blockElement.previousElementSibling?.tagName === "TABLE"
1779
+ ) {
1780
+ const tableElement =
1781
+ blockElement.previousElementSibling as HTMLTableElement;
1782
+ range.selectNodeContents(
1783
+ tableElement.rows[tableElement.rows.length - 1].lastElementChild
1784
+ );
1785
+ range.collapse(false);
1786
+ event.preventDefault();
1787
+ return true;
1788
+ }
1789
+ if (
1790
+ event.key === "ArrowDown" &&
1791
+ blockElement &&
1792
+ blockElement.nextElementSibling?.tagName === "TABLE"
1793
+ ) {
1794
+ range.selectNodeContents(
1795
+ (blockElement.nextElementSibling as HTMLTableElement).rows[0]
1796
+ .cells[0]
1797
+ );
1798
+ range.collapse(true);
1799
+ event.preventDefault();
1800
+ return true;
1801
+ }
1802
+ return false;
1803
+ };
1804
+
1805
+ export const paste = async (
1806
+ vditor: IVditor,
1807
+ event: (ClipboardEvent | DragEvent) & { target: HTMLElement },
1808
+ callback: {
1809
+ pasteCode(code: string): void;
1810
+ }
1811
+ ) => {
1812
+ if (
1813
+ vditor[vditor.currentMode].element.getAttribute("contenteditable") !==
1814
+ "true"
1815
+ ) {
1816
+ return;
1817
+ }
1818
+ event.stopPropagation();
1819
+ event.preventDefault();
1820
+ let textHTML;
1821
+ let textPlain;
1822
+ let files;
1823
+
1824
+ if ("clipboardData" in event) {
1825
+ textHTML = event.clipboardData.getData("text/html");
1826
+ textPlain = event.clipboardData.getData("text/plain");
1827
+ files = event.clipboardData.files;
1828
+ } else {
1829
+ textHTML = event.dataTransfer.getData("text/html");
1830
+ textPlain = event.dataTransfer.getData("text/plain");
1831
+ if (event.dataTransfer.types.includes("Files")) {
1832
+ files = event.dataTransfer.items;
1833
+ }
1834
+ }
1835
+ const renderers: {
1836
+ HTML2VditorDOM?: ILuteRender;
1837
+ HTML2VditorIRDOM?: ILuteRender;
1838
+ Md2VditorDOM?: ILuteRender;
1839
+ Md2VditorIRDOM?: ILuteRender;
1840
+ Md2VditorSVDOM?: ILuteRender;
1841
+ } = {};
1842
+ const renderLinkDest: ILuteRenderCallback = (node, entering) => {
1843
+ if (!entering) {
1844
+ return ["", Lute.WalkContinue];
1845
+ }
1846
+
1847
+ if (vditor.options.upload.renderLinkDest) {
1848
+ return vditor.options.upload.renderLinkDest(vditor, node, entering);
1849
+ }
1850
+
1851
+ const src = node.TokensStr();
1852
+ if (
1853
+ node.__internal_object__.Parent.Type === 34 &&
1854
+ src &&
1855
+ src.indexOf("file://") === -1 &&
1856
+ vditor.options.upload.linkToImgUrl
1857
+ ) {
1858
+ const xhr = new XMLHttpRequest();
1859
+ xhr.open("POST", vditor.options.upload.linkToImgUrl);
1860
+ if (vditor.options.upload.token) {
1861
+ xhr.setRequestHeader(
1862
+ "X-Upload-Token",
1863
+ vditor.options.upload.token
1864
+ );
1865
+ }
1866
+ if (vditor.options.upload.withCredentials) {
1867
+ xhr.withCredentials = true;
1868
+ }
1869
+ setHeaders(vditor, xhr);
1870
+ xhr.setRequestHeader(
1871
+ "Content-Type",
1872
+ "application/json; charset=utf-8"
1873
+ );
1874
+ xhr.onreadystatechange = () => {
1875
+ if (xhr.readyState === XMLHttpRequest.DONE) {
1876
+ if (xhr.status === 200) {
1877
+ let responseText = xhr.responseText;
1878
+ if (vditor.options.upload.linkToImgFormat) {
1879
+ responseText =
1880
+ vditor.options.upload.linkToImgFormat(
1881
+ xhr.responseText
1882
+ );
1883
+ }
1884
+ const responseJSON = JSON.parse(responseText);
1885
+ if (responseJSON.code !== 0) {
1886
+ vditor.tip.show(responseJSON.msg);
1887
+ return;
1888
+ }
1889
+ const original = responseJSON.data.originalURL;
1890
+ if (vditor.currentMode === "sv") {
1891
+ vditor.sv.element
1892
+ .querySelectorAll(".vditor-sv__marker--link")
1893
+ .forEach((item: HTMLElement) => {
1894
+ if (item.textContent === original) {
1895
+ item.textContent =
1896
+ responseJSON.data.url;
1897
+ }
1898
+ });
1899
+ } else {
1900
+ const imgElement: HTMLImageElement = vditor[
1901
+ vditor.currentMode
1902
+ ].element.querySelector(`img[src="${original}"]`);
1903
+ imgElement.src = responseJSON.data.url;
1904
+ if (vditor.currentMode === "ir") {
1905
+ imgElement.previousElementSibling.previousElementSibling.innerHTML =
1906
+ responseJSON.data.url;
1907
+ }
1908
+ }
1909
+ execAfterRender(vditor);
1910
+ } else {
1911
+ vditor.tip.show(xhr.responseText);
1912
+ }
1913
+ if (vditor.options.upload.linkToImgCallback) {
1914
+ vditor.options.upload.linkToImgCallback(
1915
+ xhr.responseText
1916
+ );
1917
+ }
1918
+ }
1919
+ };
1920
+ xhr.send(JSON.stringify({ url: src }));
1921
+ }
1922
+ if (vditor.currentMode === "ir") {
1923
+ return [
1924
+ `<span class="vditor-ir__marker vditor-ir__marker--link">${Lute.EscapeHTMLStr(src)}</span>`,
1925
+ Lute.WalkContinue,
1926
+ ];
1927
+ } else if (vditor.currentMode === "wysiwyg") {
1928
+ return ["", Lute.WalkContinue];
1929
+ } else {
1930
+ return [
1931
+ `<span class="vditor-sv__marker--link">${Lute.EscapeHTMLStr(src)}</span>`,
1932
+ Lute.WalkContinue,
1933
+ ];
1934
+ }
1935
+ };
1936
+
1937
+ // 浏览器地址栏拷贝处理
1938
+ if (
1939
+ textHTML
1940
+ .replace(/&amp;/g, "&")
1941
+ .replace(/<(|\/)(html|body|meta)[^>]*?>/gi, "")
1942
+ .trim() === `<a href="${textPlain}">${textPlain}</a>` ||
1943
+ textHTML
1944
+ .replace(/&amp;/g, "&")
1945
+ .replace(/<(|\/)(html|body|meta)[^>]*?>/gi, "")
1946
+ .trim() ===
1947
+ `<!--StartFragment--><a href="${textPlain}">${textPlain}</a><!--EndFragment-->`
1948
+ ) {
1949
+ textHTML = "";
1950
+ }
1951
+
1952
+ // process word
1953
+ const doc = new DOMParser().parseFromString(textHTML, "text/html");
1954
+ if (doc.body) {
1955
+ textHTML = doc.body.innerHTML;
1956
+ }
1957
+ textHTML = Lute.Sanitize(textHTML);
1958
+ vditor.wysiwyg.getComments(vditor);
1959
+
1960
+ // process code
1961
+ const height = vditor[vditor.currentMode].element.scrollHeight;
1962
+ const code = processPasteCode(textHTML, textPlain, vditor.currentMode);
1963
+ const codeElement =
1964
+ vditor.currentMode === "sv"
1965
+ ? hasClosestByAttribute(event.target, "data-type", "code-block")
1966
+ : hasClosestByMatchTag(event.target, "CODE");
1967
+ if (codeElement) {
1968
+ // 粘贴在代码位置
1969
+ if (vditor.currentMode === "sv") {
1970
+ document.execCommand(
1971
+ "insertHTML",
1972
+ false,
1973
+ textPlain.replace(/&/g, "&amp;").replace(/</g, "&lt;")
1974
+ );
1975
+ } else {
1976
+ const position = getSelectPosition(
1977
+ event.target,
1978
+ vditor[vditor.currentMode].element
1979
+ );
1980
+ if (codeElement.parentElement.tagName !== "PRE") {
1981
+ // https://github.com/Vanessa219/vditor/issues/463
1982
+ textPlain += Constants.ZWSP;
1983
+ }
1984
+ codeElement.textContent =
1985
+ codeElement.textContent.substring(0, position.start) +
1986
+ textPlain +
1987
+ codeElement.textContent.substring(position.end);
1988
+ setSelectionByPosition(
1989
+ position.start + textPlain.length,
1990
+ position.start + textPlain.length,
1991
+ codeElement.parentElement
1992
+ );
1993
+ if (
1994
+ codeElement.parentElement?.nextElementSibling.classList.contains(
1995
+ `vditor-${vditor.currentMode}__preview`
1996
+ )
1997
+ ) {
1998
+ codeElement.parentElement.nextElementSibling.innerHTML =
1999
+ codeElement.outerHTML;
2000
+ processCodeRender(
2001
+ codeElement.parentElement.nextElementSibling as HTMLElement,
2002
+ vditor
2003
+ );
2004
+ }
2005
+ }
2006
+ } else if (code) {
2007
+ callback.pasteCode(code);
2008
+ } else {
2009
+ if (textHTML.trim() !== "") {
2010
+ const tempElement = document.createElement("div");
2011
+ tempElement.innerHTML = textHTML;
2012
+ if (!vditor.options.upload.base64ToLink) {
2013
+ // word 复制的图文混合,替换为 link: <v:imagedata src="file:///C:/Users/ADMINI~1/AppData/Local/Temp/msohtmlclip1/01/clip_image001.png" o:title="">
2014
+ await processVMLImage(
2015
+ vditor,
2016
+ tempElement,
2017
+ ("clipboardData" in event
2018
+ ? event.clipboardData
2019
+ : event.dataTransfer
2020
+ ).getData("text/rtf")
2021
+ );
2022
+ }
2023
+
2024
+ tempElement.querySelectorAll("[style]").forEach((e) => {
2025
+ e.removeAttribute("style");
2026
+ });
2027
+ tempElement.querySelectorAll(".vditor-copy").forEach((e) => {
2028
+ e.remove();
2029
+ });
2030
+ if (vditor.currentMode === "ir") {
2031
+ renderers.HTML2VditorIRDOM = { renderLinkDest };
2032
+ vditor.lute.SetJSRenderers({ renderers });
2033
+ insertHTML(
2034
+ vditor.lute.HTML2VditorIRDOM(tempElement.innerHTML),
2035
+ vditor
2036
+ );
2037
+ } else if (vditor.currentMode === "wysiwyg") {
2038
+ renderers.HTML2VditorDOM = { renderLinkDest };
2039
+ vditor.lute.SetJSRenderers({ renderers });
2040
+ insertHTML(
2041
+ vditor.lute.HTML2VditorDOM(tempElement.innerHTML),
2042
+ vditor
2043
+ );
2044
+ } else {
2045
+ renderers.Md2VditorSVDOM = { renderLinkDest };
2046
+ vditor.lute.SetJSRenderers({ renderers });
2047
+ processPaste(
2048
+ vditor,
2049
+ vditor.lute.HTML2Md(tempElement.innerHTML).trimRight()
2050
+ );
2051
+ }
2052
+ vditor.outline.render(vditor);
2053
+ } else if (files.length > 0) {
2054
+ if (vditor.options.upload.url || vditor.options.upload.handler) {
2055
+ await uploadFiles(vditor, files);
2056
+ } else {
2057
+ const fileReader = new FileReader();
2058
+ let file: File;
2059
+ if ("clipboardData" in event) {
2060
+ files = event.clipboardData.files;
2061
+ file = files[0];
2062
+ } else if (event.dataTransfer.types.includes("Files")) {
2063
+ files = event.dataTransfer.items;
2064
+ file = files[0].getAsFile();
2065
+ }
2066
+ if (file && file.type.startsWith("image")) {
2067
+ fileReader.readAsDataURL(file);
2068
+ fileReader.onload = () => {
2069
+ let imgHTML = "";
2070
+ if (vditor.currentMode === "wysiwyg") {
2071
+ imgHTML += `<img alt="${file.name}" src="${fileReader.result.toString()}">\n`;
2072
+ } else {
2073
+ imgHTML += `![${file.name}](${fileReader.result.toString()})\n`;
2074
+ }
2075
+ document.execCommand("insertHTML", false, imgHTML);
2076
+ };
2077
+ }
2078
+ }
2079
+ } else if (textPlain.trim() !== "" && files.length === 0) {
2080
+ const range = getEditorRange(vditor);
2081
+ if (
2082
+ range.toString() !== "" &&
2083
+ vditor.lute.IsValidLinkDest(textPlain)
2084
+ ) {
2085
+ textPlain = `[${range.toString()}](${textPlain})`;
2086
+ }
2087
+ if (vditor.currentMode === "ir") {
2088
+ renderers.Md2VditorIRDOM = { renderLinkDest };
2089
+ vditor.lute.SetJSRenderers({ renderers });
2090
+ insertHTML(
2091
+ Lute.Sanitize(vditor.lute.Md2VditorIRDOM(textPlain)),
2092
+ vditor
2093
+ );
2094
+ } else if (vditor.currentMode === "wysiwyg") {
2095
+ renderers.Md2VditorDOM = { renderLinkDest };
2096
+ vditor.lute.SetJSRenderers({ renderers });
2097
+ insertHTML(
2098
+ Lute.Sanitize(vditor.lute.Md2VditorDOM(textPlain)),
2099
+ vditor
2100
+ );
2101
+ } else {
2102
+ renderers.Md2VditorSVDOM = { renderLinkDest };
2103
+ vditor.lute.SetJSRenderers({ renderers });
2104
+ processPaste(vditor, textPlain);
2105
+ }
2106
+ vditor.outline.render(vditor);
2107
+ }
2108
+ }
2109
+ if (vditor.currentMode !== "sv") {
2110
+ const blockElement = hasClosestBlock(
2111
+ getEditorRange(vditor).startContainer
2112
+ );
2113
+ if (blockElement) {
2114
+ // https://github.com/Vanessa219/vditor/issues/591
2115
+ const range = getEditorRange(vditor);
2116
+ vditor[vditor.currentMode].element
2117
+ .querySelectorAll("wbr")
2118
+ .forEach((wbr) => {
2119
+ wbr.remove();
2120
+ });
2121
+ range.insertNode(document.createElement("wbr"));
2122
+ if (vditor.currentMode === "wysiwyg") {
2123
+ blockElement.outerHTML = vditor.lute.SpinVditorDOM(
2124
+ blockElement.outerHTML
2125
+ );
2126
+ } else {
2127
+ blockElement.outerHTML = vditor.lute.SpinVditorIRDOM(
2128
+ blockElement.outerHTML
2129
+ );
2130
+ }
2131
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
2132
+ }
2133
+ vditor[vditor.currentMode].element
2134
+ .querySelectorAll(
2135
+ `.vditor-${vditor.currentMode}__preview[data-render='2']`
2136
+ )
2137
+ .forEach((item: HTMLElement) => {
2138
+ processCodeRender(item, vditor);
2139
+ });
2140
+ }
2141
+ vditor.wysiwyg.triggerRemoveComment(vditor);
2142
+ execAfterRender(vditor);
2143
+ if (
2144
+ vditor[vditor.currentMode].element.scrollHeight - height >
2145
+ Math.min(
2146
+ vditor[vditor.currentMode].element.clientHeight,
2147
+ window.innerHeight
2148
+ ) /
2149
+ 2
2150
+ ) {
2151
+ scrollCenter(vditor);
2152
+ }
2153
+ };
2154
+
2155
+ const processVMLImage = async (
2156
+ vditor: IVditor,
2157
+ root: Element,
2158
+ rtfData: string
2159
+ ) => {
2160
+ if (!rtfData) {
2161
+ return;
2162
+ }
2163
+
2164
+ const regexPictureHeader =
2165
+ /{\\pict[\s\S]+?\\bliptag-?\d+(\\blipupi-?\d+)?({\\\*\\blipuid\s?[\da-fA-F]+)?[\s}]*?/;
2166
+ const regexPicture = new RegExp(
2167
+ "(?:(" + regexPictureHeader.source + "))([\\da-fA-F\\s]+)\\}",
2168
+ "g"
2169
+ );
2170
+ const regImages = rtfData.match(regexPicture);
2171
+ const images = [];
2172
+ if (regImages) {
2173
+ for (const image of regImages) {
2174
+ let imageType;
2175
+
2176
+ if (image.includes("\\pngblip")) {
2177
+ imageType = "image/png";
2178
+ } else if (image.includes("\\jpegblip")) {
2179
+ imageType = "image/jpeg";
2180
+ }
2181
+
2182
+ if (imageType) {
2183
+ images.push({
2184
+ hex: image
2185
+ .replace(regexPictureHeader, "")
2186
+ .replace(/[^\da-fA-F]/g, ""),
2187
+ type: imageType,
2188
+ });
2189
+ }
2190
+ }
2191
+ }
2192
+
2193
+ const shapes: Array<{ shape: Element; img: Element }> = [];
2194
+ walk(root, (child: Element) => {
2195
+ if (child.tagName === "V:SHAPE") {
2196
+ walk(child, (sub) => {
2197
+ if (sub.tagName === "V:IMAGEDATA")
2198
+ shapes.push({ shape: child, img: sub });
2199
+ });
2200
+ return false;
2201
+ }
2202
+ });
2203
+ for (let i = 0; i < shapes.length; i++) {
2204
+ const img = document.createElement("img");
2205
+ const newSrc =
2206
+ "data:" +
2207
+ images[i].type +
2208
+ ";base64," +
2209
+ btoa(
2210
+ (images[i].hex.match(/\w{2}/g) || [])
2211
+ .map((char) => {
2212
+ return String.fromCharCode(parseInt(char, 16));
2213
+ })
2214
+ .join("")
2215
+ );
2216
+ img.src = newSrc;
2217
+ img.title = shapes[i].img.getAttribute("title");
2218
+ shapes[i].shape.parentNode.replaceChild(img, shapes[i].shape);
2219
+ }
2220
+
2221
+ const imgs = root.querySelectorAll("img");
2222
+ for (let i = 0; i < imgs.length; i++) {
2223
+ const src = imgs[i].src || "";
2224
+ if (src) imgs[i].src = await vditor.options.upload.base64ToLink(src);
2225
+ }
2226
+ };
2227
+
2228
+ const walk = (el: Element, fn: (el: Element) => boolean | void) => {
2229
+ const goNext = fn(el);
2230
+ if (goNext !== false)
2231
+ for (let i = 0; i < el.children.length; i++) {
2232
+ walk(el.children[i], fn);
2233
+ }
2234
+ };