@yltrcc/vditor 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 (651) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +693 -0
  3. package/dist/css/content-theme/ant-design.css +210 -0
  4. package/dist/css/content-theme/dark.css +123 -0
  5. package/dist/css/content-theme/light.css +101 -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 +1834 -0
  27. package/dist/index.d.ts +82 -0
  28. package/dist/index.js +16005 -0
  29. package/dist/index.min.js +1 -0
  30. package/dist/js/abcjs/abcjs_basic.min.js +3 -0
  31. package/dist/js/echarts/echarts.min.js +45 -0
  32. package/dist/js/flowchart.js/flowchart.min.js +8 -0
  33. package/dist/js/graphviz/full.render.js +90 -0
  34. package/dist/js/graphviz/viz.js +333 -0
  35. package/dist/js/highlight.js/LICENSE +29 -0
  36. package/dist/js/highlight.js/highlight.min.js +3835 -0
  37. package/dist/js/highlight.js/styles/a11y-dark.min.css +7 -0
  38. package/dist/js/highlight.js/styles/a11y-light.min.css +7 -0
  39. package/dist/js/highlight.js/styles/agate.min.css +20 -0
  40. package/dist/js/highlight.js/styles/an-old-hope.min.css +9 -0
  41. package/dist/js/highlight.js/styles/androidstudio.min.css +1 -0
  42. package/dist/js/highlight.js/styles/ant-design.min.css +84 -0
  43. package/dist/js/highlight.js/styles/arduino-light.min.css +1 -0
  44. package/dist/js/highlight.js/styles/arta.min.css +1 -0
  45. package/dist/js/highlight.js/styles/ascetic.min.css +1 -0
  46. package/dist/js/highlight.js/styles/atom-one-dark-reasonable.min.css +1 -0
  47. package/dist/js/highlight.js/styles/atom-one-dark.min.css +1 -0
  48. package/dist/js/highlight.js/styles/atom-one-light.min.css +1 -0
  49. package/dist/js/highlight.js/styles/base16/3024.min.css +7 -0
  50. package/dist/js/highlight.js/styles/base16/apathy.min.css +7 -0
  51. package/dist/js/highlight.js/styles/base16/apprentice.min.css +7 -0
  52. package/dist/js/highlight.js/styles/base16/ashes.min.css +7 -0
  53. package/dist/js/highlight.js/styles/base16/atelier-cave-light.min.css +7 -0
  54. package/dist/js/highlight.js/styles/base16/atelier-cave.min.css +7 -0
  55. package/dist/js/highlight.js/styles/base16/atelier-dune-light.min.css +7 -0
  56. package/dist/js/highlight.js/styles/base16/atelier-dune.min.css +7 -0
  57. package/dist/js/highlight.js/styles/base16/atelier-estuary-light.min.css +7 -0
  58. package/dist/js/highlight.js/styles/base16/atelier-estuary.min.css +7 -0
  59. package/dist/js/highlight.js/styles/base16/atelier-forest-light.min.css +7 -0
  60. package/dist/js/highlight.js/styles/base16/atelier-forest.min.css +7 -0
  61. package/dist/js/highlight.js/styles/base16/atelier-heath-light.min.css +7 -0
  62. package/dist/js/highlight.js/styles/base16/atelier-heath.min.css +7 -0
  63. package/dist/js/highlight.js/styles/base16/atelier-lakeside-light.min.css +7 -0
  64. package/dist/js/highlight.js/styles/base16/atelier-lakeside.min.css +7 -0
  65. package/dist/js/highlight.js/styles/base16/atelier-plateau-light.min.css +7 -0
  66. package/dist/js/highlight.js/styles/base16/atelier-plateau.min.css +7 -0
  67. package/dist/js/highlight.js/styles/base16/atelier-savanna-light.min.css +7 -0
  68. package/dist/js/highlight.js/styles/base16/atelier-savanna.min.css +7 -0
  69. package/dist/js/highlight.js/styles/base16/atelier-seaside-light.min.css +7 -0
  70. package/dist/js/highlight.js/styles/base16/atelier-seaside.min.css +7 -0
  71. package/dist/js/highlight.js/styles/base16/atelier-sulphurpool-light.min.css +7 -0
  72. package/dist/js/highlight.js/styles/base16/atelier-sulphurpool.min.css +7 -0
  73. package/dist/js/highlight.js/styles/base16/atlas.min.css +7 -0
  74. package/dist/js/highlight.js/styles/base16/bespin.min.css +7 -0
  75. package/dist/js/highlight.js/styles/base16/black-metal-bathory.min.css +7 -0
  76. package/dist/js/highlight.js/styles/base16/black-metal-burzum.min.css +7 -0
  77. package/dist/js/highlight.js/styles/base16/black-metal-dark-funeral.min.css +7 -0
  78. package/dist/js/highlight.js/styles/base16/black-metal-gorgoroth.min.css +7 -0
  79. package/dist/js/highlight.js/styles/base16/black-metal-immortal.min.css +7 -0
  80. package/dist/js/highlight.js/styles/base16/black-metal-khold.min.css +7 -0
  81. package/dist/js/highlight.js/styles/base16/black-metal-marduk.min.css +7 -0
  82. package/dist/js/highlight.js/styles/base16/black-metal-mayhem.min.css +7 -0
  83. package/dist/js/highlight.js/styles/base16/black-metal-nile.min.css +7 -0
  84. package/dist/js/highlight.js/styles/base16/black-metal-venom.min.css +7 -0
  85. package/dist/js/highlight.js/styles/base16/black-metal.min.css +7 -0
  86. package/dist/js/highlight.js/styles/base16/brewer.min.css +7 -0
  87. package/dist/js/highlight.js/styles/base16/bright.min.css +7 -0
  88. package/dist/js/highlight.js/styles/base16/brogrammer.min.css +7 -0
  89. package/dist/js/highlight.js/styles/base16/brush-trees-dark.min.css +7 -0
  90. package/dist/js/highlight.js/styles/base16/brush-trees.min.css +7 -0
  91. package/dist/js/highlight.js/styles/base16/chalk.min.css +7 -0
  92. package/dist/js/highlight.js/styles/base16/circus.min.css +7 -0
  93. package/dist/js/highlight.js/styles/base16/classic-dark.min.css +7 -0
  94. package/dist/js/highlight.js/styles/base16/classic-light.min.css +7 -0
  95. package/dist/js/highlight.js/styles/base16/codeschool.min.css +7 -0
  96. package/dist/js/highlight.js/styles/base16/colors.min.css +7 -0
  97. package/dist/js/highlight.js/styles/base16/cupcake.min.css +7 -0
  98. package/dist/js/highlight.js/styles/base16/cupertino.min.css +7 -0
  99. package/dist/js/highlight.js/styles/base16/danqing.min.css +7 -0
  100. package/dist/js/highlight.js/styles/base16/darcula.min.css +7 -0
  101. package/dist/js/highlight.js/styles/base16/dark-violet.min.css +7 -0
  102. package/dist/js/highlight.js/styles/base16/darkmoss.min.css +7 -0
  103. package/dist/js/highlight.js/styles/base16/darktooth.min.css +7 -0
  104. package/dist/js/highlight.js/styles/base16/decaf.min.css +7 -0
  105. package/dist/js/highlight.js/styles/base16/default-dark.min.css +7 -0
  106. package/dist/js/highlight.js/styles/base16/default-light.min.css +7 -0
  107. package/dist/js/highlight.js/styles/base16/dirtysea.min.css +7 -0
  108. package/dist/js/highlight.js/styles/base16/dracula.min.css +7 -0
  109. package/dist/js/highlight.js/styles/base16/edge-dark.min.css +7 -0
  110. package/dist/js/highlight.js/styles/base16/edge-light.min.css +7 -0
  111. package/dist/js/highlight.js/styles/base16/eighties.min.css +7 -0
  112. package/dist/js/highlight.js/styles/base16/embers.min.css +7 -0
  113. package/dist/js/highlight.js/styles/base16/equilibrium-dark.min.css +7 -0
  114. package/dist/js/highlight.js/styles/base16/equilibrium-gray-dark.min.css +7 -0
  115. package/dist/js/highlight.js/styles/base16/equilibrium-gray-light.min.css +7 -0
  116. package/dist/js/highlight.js/styles/base16/equilibrium-light.min.css +7 -0
  117. package/dist/js/highlight.js/styles/base16/espresso.min.css +7 -0
  118. package/dist/js/highlight.js/styles/base16/eva-dim.min.css +7 -0
  119. package/dist/js/highlight.js/styles/base16/eva.min.css +7 -0
  120. package/dist/js/highlight.js/styles/base16/flat.min.css +7 -0
  121. package/dist/js/highlight.js/styles/base16/framer.min.css +7 -0
  122. package/dist/js/highlight.js/styles/base16/fruit-soda.min.css +7 -0
  123. package/dist/js/highlight.js/styles/base16/gigavolt.min.css +7 -0
  124. package/dist/js/highlight.js/styles/base16/github.min.css +7 -0
  125. package/dist/js/highlight.js/styles/base16/google-dark.min.css +7 -0
  126. package/dist/js/highlight.js/styles/base16/google-light.min.css +7 -0
  127. package/dist/js/highlight.js/styles/base16/grayscale-dark.min.css +7 -0
  128. package/dist/js/highlight.js/styles/base16/grayscale-light.min.css +7 -0
  129. package/dist/js/highlight.js/styles/base16/green-screen.min.css +7 -0
  130. package/dist/js/highlight.js/styles/base16/gruvbox-dark-hard.min.css +7 -0
  131. package/dist/js/highlight.js/styles/base16/gruvbox-dark-medium.min.css +7 -0
  132. package/dist/js/highlight.js/styles/base16/gruvbox-dark-pale.min.css +7 -0
  133. package/dist/js/highlight.js/styles/base16/gruvbox-dark-soft.min.css +7 -0
  134. package/dist/js/highlight.js/styles/base16/gruvbox-light-hard.min.css +7 -0
  135. package/dist/js/highlight.js/styles/base16/gruvbox-light-medium.min.css +7 -0
  136. package/dist/js/highlight.js/styles/base16/gruvbox-light-soft.min.css +7 -0
  137. package/dist/js/highlight.js/styles/base16/hardcore.min.css +7 -0
  138. package/dist/js/highlight.js/styles/base16/harmonic16-dark.min.css +7 -0
  139. package/dist/js/highlight.js/styles/base16/harmonic16-light.min.css +7 -0
  140. package/dist/js/highlight.js/styles/base16/heetch-dark.min.css +7 -0
  141. package/dist/js/highlight.js/styles/base16/heetch-light.min.css +7 -0
  142. package/dist/js/highlight.js/styles/base16/helios.min.css +7 -0
  143. package/dist/js/highlight.js/styles/base16/hopscotch.min.css +7 -0
  144. package/dist/js/highlight.js/styles/base16/horizon-dark.min.css +7 -0
  145. package/dist/js/highlight.js/styles/base16/horizon-light.min.css +7 -0
  146. package/dist/js/highlight.js/styles/base16/humanoid-dark.min.css +7 -0
  147. package/dist/js/highlight.js/styles/base16/humanoid-light.min.css +7 -0
  148. package/dist/js/highlight.js/styles/base16/ia-dark.min.css +7 -0
  149. package/dist/js/highlight.js/styles/base16/ia-light.min.css +7 -0
  150. package/dist/js/highlight.js/styles/base16/icy-dark.min.css +7 -0
  151. package/dist/js/highlight.js/styles/base16/ir-black.min.css +7 -0
  152. package/dist/js/highlight.js/styles/base16/isotope.min.css +7 -0
  153. package/dist/js/highlight.js/styles/base16/kimber.min.css +7 -0
  154. package/dist/js/highlight.js/styles/base16/london-tube.min.css +7 -0
  155. package/dist/js/highlight.js/styles/base16/macintosh.min.css +7 -0
  156. package/dist/js/highlight.js/styles/base16/marrakesh.min.css +7 -0
  157. package/dist/js/highlight.js/styles/base16/materia.min.css +7 -0
  158. package/dist/js/highlight.js/styles/base16/material-darker.min.css +7 -0
  159. package/dist/js/highlight.js/styles/base16/material-lighter.min.css +7 -0
  160. package/dist/js/highlight.js/styles/base16/material-palenight.min.css +7 -0
  161. package/dist/js/highlight.js/styles/base16/material-vivid.min.css +7 -0
  162. package/dist/js/highlight.js/styles/base16/material.min.css +7 -0
  163. package/dist/js/highlight.js/styles/base16/mellow-purple.min.css +7 -0
  164. package/dist/js/highlight.js/styles/base16/mexico-light.min.css +7 -0
  165. package/dist/js/highlight.js/styles/base16/mocha.min.css +7 -0
  166. package/dist/js/highlight.js/styles/base16/monokai.min.css +7 -0
  167. package/dist/js/highlight.js/styles/base16/nebula.min.css +7 -0
  168. package/dist/js/highlight.js/styles/base16/nord.min.css +7 -0
  169. package/dist/js/highlight.js/styles/base16/nova.min.css +7 -0
  170. package/dist/js/highlight.js/styles/base16/ocean.min.css +7 -0
  171. package/dist/js/highlight.js/styles/base16/oceanicnext.min.css +7 -0
  172. package/dist/js/highlight.js/styles/base16/one-light.min.css +7 -0
  173. package/dist/js/highlight.js/styles/base16/onedark.min.css +7 -0
  174. package/dist/js/highlight.js/styles/base16/outrun-dark.min.css +7 -0
  175. package/dist/js/highlight.js/styles/base16/papercolor-dark.min.css +7 -0
  176. package/dist/js/highlight.js/styles/base16/papercolor-light.min.css +7 -0
  177. package/dist/js/highlight.js/styles/base16/paraiso.min.css +7 -0
  178. package/dist/js/highlight.js/styles/base16/pasque.min.css +7 -0
  179. package/dist/js/highlight.js/styles/base16/phd.min.css +7 -0
  180. package/dist/js/highlight.js/styles/base16/pico.min.css +7 -0
  181. package/dist/js/highlight.js/styles/base16/pop.min.css +7 -0
  182. package/dist/js/highlight.js/styles/base16/porple.min.css +7 -0
  183. package/dist/js/highlight.js/styles/base16/qualia.min.css +7 -0
  184. package/dist/js/highlight.js/styles/base16/railscasts.min.css +7 -0
  185. package/dist/js/highlight.js/styles/base16/rebecca.min.css +7 -0
  186. package/dist/js/highlight.js/styles/base16/ros-pine-dawn.min.css +7 -0
  187. package/dist/js/highlight.js/styles/base16/ros-pine-moon.min.css +7 -0
  188. package/dist/js/highlight.js/styles/base16/ros-pine.min.css +7 -0
  189. package/dist/js/highlight.js/styles/base16/sagelight.min.css +7 -0
  190. package/dist/js/highlight.js/styles/base16/sandcastle.min.css +7 -0
  191. package/dist/js/highlight.js/styles/base16/seti-ui.min.css +7 -0
  192. package/dist/js/highlight.js/styles/base16/shapeshifter.min.css +7 -0
  193. package/dist/js/highlight.js/styles/base16/silk-dark.min.css +7 -0
  194. package/dist/js/highlight.js/styles/base16/silk-light.min.css +7 -0
  195. package/dist/js/highlight.js/styles/base16/snazzy.min.css +7 -0
  196. package/dist/js/highlight.js/styles/base16/solar-flare-light.min.css +7 -0
  197. package/dist/js/highlight.js/styles/base16/solar-flare.min.css +7 -0
  198. package/dist/js/highlight.js/styles/base16/solarized-dark.min.css +7 -0
  199. package/dist/js/highlight.js/styles/base16/solarized-light.min.css +7 -0
  200. package/dist/js/highlight.js/styles/base16/spacemacs.min.css +7 -0
  201. package/dist/js/highlight.js/styles/base16/summercamp.min.css +7 -0
  202. package/dist/js/highlight.js/styles/base16/summerfruit-dark.min.css +7 -0
  203. package/dist/js/highlight.js/styles/base16/summerfruit-light.min.css +7 -0
  204. package/dist/js/highlight.js/styles/base16/synth-midnight-terminal-dark.min.css +7 -0
  205. package/dist/js/highlight.js/styles/base16/synth-midnight-terminal-light.min.css +7 -0
  206. package/dist/js/highlight.js/styles/base16/tango.min.css +7 -0
  207. package/dist/js/highlight.js/styles/base16/tender.min.css +7 -0
  208. package/dist/js/highlight.js/styles/base16/tomorrow-night.min.css +7 -0
  209. package/dist/js/highlight.js/styles/base16/tomorrow.min.css +7 -0
  210. package/dist/js/highlight.js/styles/base16/twilight.min.css +7 -0
  211. package/dist/js/highlight.js/styles/base16/unikitty-dark.min.css +7 -0
  212. package/dist/js/highlight.js/styles/base16/unikitty-light.min.css +7 -0
  213. package/dist/js/highlight.js/styles/base16/vulcan.min.css +7 -0
  214. package/dist/js/highlight.js/styles/base16/windows-10-light.min.css +7 -0
  215. package/dist/js/highlight.js/styles/base16/windows-10.min.css +7 -0
  216. package/dist/js/highlight.js/styles/base16/windows-95-light.min.css +7 -0
  217. package/dist/js/highlight.js/styles/base16/windows-95.min.css +7 -0
  218. package/dist/js/highlight.js/styles/base16/windows-high-contrast-light.min.css +7 -0
  219. package/dist/js/highlight.js/styles/base16/windows-high-contrast.min.css +7 -0
  220. package/dist/js/highlight.js/styles/base16/windows-nt-light.min.css +7 -0
  221. package/dist/js/highlight.js/styles/base16/windows-nt.min.css +7 -0
  222. package/dist/js/highlight.js/styles/base16/woodland.min.css +7 -0
  223. package/dist/js/highlight.js/styles/base16/xcode-dusk.min.css +7 -0
  224. package/dist/js/highlight.js/styles/base16/zenburn.min.css +7 -0
  225. package/dist/js/highlight.js/styles/brown-paper.min.css +1 -0
  226. package/dist/js/highlight.js/styles/brown-papersq.png +0 -0
  227. package/dist/js/highlight.js/styles/codepen-embed.min.css +1 -0
  228. package/dist/js/highlight.js/styles/color-brewer.min.css +1 -0
  229. package/dist/js/highlight.js/styles/dark.min.css +1 -0
  230. package/dist/js/highlight.js/styles/default.min.css +9 -0
  231. package/dist/js/highlight.js/styles/devibeans.min.css +7 -0
  232. package/dist/js/highlight.js/styles/docco.min.css +1 -0
  233. package/dist/js/highlight.js/styles/far.min.css +1 -0
  234. package/dist/js/highlight.js/styles/felipec.min.css +7 -0
  235. package/dist/js/highlight.js/styles/foundation.min.css +1 -0
  236. package/dist/js/highlight.js/styles/github-dark-dimmed.min.css +9 -0
  237. package/dist/js/highlight.js/styles/github-dark.min.css +10 -0
  238. package/dist/js/highlight.js/styles/github.min.css +10 -0
  239. package/dist/js/highlight.js/styles/gml.min.css +1 -0
  240. package/dist/js/highlight.js/styles/googlecode.min.css +1 -0
  241. package/dist/js/highlight.js/styles/gradient-dark.min.css +1 -0
  242. package/dist/js/highlight.js/styles/gradient-light.min.css +1 -0
  243. package/dist/js/highlight.js/styles/grayscale.min.css +1 -0
  244. package/dist/js/highlight.js/styles/hybrid.min.css +1 -0
  245. package/dist/js/highlight.js/styles/idea.min.css +1 -0
  246. package/dist/js/highlight.js/styles/intellij-light.min.css +1 -0
  247. package/dist/js/highlight.js/styles/ir-black.min.css +1 -0
  248. package/dist/js/highlight.js/styles/isbl-editor-dark.min.css +1 -0
  249. package/dist/js/highlight.js/styles/isbl-editor-light.min.css +1 -0
  250. package/dist/js/highlight.js/styles/kimbie-dark.min.css +1 -0
  251. package/dist/js/highlight.js/styles/kimbie-light.min.css +1 -0
  252. package/dist/js/highlight.js/styles/lightfair.min.css +1 -0
  253. package/dist/js/highlight.js/styles/lioshi.min.css +1 -0
  254. package/dist/js/highlight.js/styles/magula.min.css +1 -0
  255. package/dist/js/highlight.js/styles/mono-blue.min.css +1 -0
  256. package/dist/js/highlight.js/styles/monokai-sublime.min.css +1 -0
  257. package/dist/js/highlight.js/styles/monokai.min.css +1 -0
  258. package/dist/js/highlight.js/styles/night-owl.min.css +1 -0
  259. package/dist/js/highlight.js/styles/nnfx-dark.min.css +10 -0
  260. package/dist/js/highlight.js/styles/nnfx-light.min.css +10 -0
  261. package/dist/js/highlight.js/styles/nord.min.css +1 -0
  262. package/dist/js/highlight.js/styles/obsidian.min.css +1 -0
  263. package/dist/js/highlight.js/styles/panda-syntax-dark.min.css +1 -0
  264. package/dist/js/highlight.js/styles/panda-syntax-light.min.css +1 -0
  265. package/dist/js/highlight.js/styles/paraiso-dark.min.css +1 -0
  266. package/dist/js/highlight.js/styles/paraiso-light.min.css +1 -0
  267. package/dist/js/highlight.js/styles/pojoaque.jpg +0 -0
  268. package/dist/js/highlight.js/styles/pojoaque.min.css +1 -0
  269. package/dist/js/highlight.js/styles/purebasic.min.css +1 -0
  270. package/dist/js/highlight.js/styles/qtcreator-dark.min.css +1 -0
  271. package/dist/js/highlight.js/styles/qtcreator-light.min.css +1 -0
  272. package/dist/js/highlight.js/styles/rainbow.min.css +1 -0
  273. package/dist/js/highlight.js/styles/routeros.min.css +1 -0
  274. package/dist/js/highlight.js/styles/school-book.min.css +1 -0
  275. package/dist/js/highlight.js/styles/shades-of-purple.min.css +1 -0
  276. package/dist/js/highlight.js/styles/srcery.min.css +1 -0
  277. package/dist/js/highlight.js/styles/stackoverflow-dark.min.css +13 -0
  278. package/dist/js/highlight.js/styles/stackoverflow-light.min.css +13 -0
  279. package/dist/js/highlight.js/styles/sunburst.min.css +1 -0
  280. package/dist/js/highlight.js/styles/tokyo-night-dark.min.css +8 -0
  281. package/dist/js/highlight.js/styles/tokyo-night-light.min.css +8 -0
  282. package/dist/js/highlight.js/styles/tomorrow-night-blue.min.css +1 -0
  283. package/dist/js/highlight.js/styles/tomorrow-night-bright.min.css +1 -0
  284. package/dist/js/highlight.js/styles/vs.min.css +1 -0
  285. package/dist/js/highlight.js/styles/vs2015.min.css +1 -0
  286. package/dist/js/highlight.js/styles/xcode.min.css +1 -0
  287. package/dist/js/highlight.js/styles/xt256.min.css +1 -0
  288. package/dist/js/highlight.js/third-languages.js +135 -0
  289. package/dist/js/i18n/de_DE.js +86 -0
  290. package/dist/js/i18n/en_US.js +86 -0
  291. package/dist/js/i18n/es_ES.js +86 -0
  292. package/dist/js/i18n/fr_FR.js +86 -0
  293. package/dist/js/i18n/ja_JP.js +86 -0
  294. package/dist/js/i18n/ko_KR.js +86 -0
  295. package/dist/js/i18n/pt_BR.js +86 -0
  296. package/dist/js/i18n/ru_RU.js +86 -0
  297. package/dist/js/i18n/sv_SE.js +86 -0
  298. package/dist/js/i18n/vi_VN.js +86 -0
  299. package/dist/js/i18n/zh_CN.js +86 -0
  300. package/dist/js/i18n/zh_TW.js +86 -0
  301. package/dist/js/icons/ant.js +174 -0
  302. package/dist/js/icons/material.js +195 -0
  303. package/dist/js/katex/fonts/KaTeX_AMS-Regular.ttf +0 -0
  304. package/dist/js/katex/fonts/KaTeX_AMS-Regular.woff +0 -0
  305. package/dist/js/katex/fonts/KaTeX_AMS-Regular.woff2 +0 -0
  306. package/dist/js/katex/fonts/KaTeX_Caligraphic-Bold.ttf +0 -0
  307. package/dist/js/katex/fonts/KaTeX_Caligraphic-Bold.woff +0 -0
  308. package/dist/js/katex/fonts/KaTeX_Caligraphic-Bold.woff2 +0 -0
  309. package/dist/js/katex/fonts/KaTeX_Caligraphic-Regular.ttf +0 -0
  310. package/dist/js/katex/fonts/KaTeX_Caligraphic-Regular.woff +0 -0
  311. package/dist/js/katex/fonts/KaTeX_Caligraphic-Regular.woff2 +0 -0
  312. package/dist/js/katex/fonts/KaTeX_Fraktur-Bold.ttf +0 -0
  313. package/dist/js/katex/fonts/KaTeX_Fraktur-Bold.woff +0 -0
  314. package/dist/js/katex/fonts/KaTeX_Fraktur-Bold.woff2 +0 -0
  315. package/dist/js/katex/fonts/KaTeX_Fraktur-Regular.ttf +0 -0
  316. package/dist/js/katex/fonts/KaTeX_Fraktur-Regular.woff +0 -0
  317. package/dist/js/katex/fonts/KaTeX_Fraktur-Regular.woff2 +0 -0
  318. package/dist/js/katex/fonts/KaTeX_Main-Bold.ttf +0 -0
  319. package/dist/js/katex/fonts/KaTeX_Main-Bold.woff +0 -0
  320. package/dist/js/katex/fonts/KaTeX_Main-Bold.woff2 +0 -0
  321. package/dist/js/katex/fonts/KaTeX_Main-BoldItalic.ttf +0 -0
  322. package/dist/js/katex/fonts/KaTeX_Main-BoldItalic.woff +0 -0
  323. package/dist/js/katex/fonts/KaTeX_Main-BoldItalic.woff2 +0 -0
  324. package/dist/js/katex/fonts/KaTeX_Main-Italic.ttf +0 -0
  325. package/dist/js/katex/fonts/KaTeX_Main-Italic.woff +0 -0
  326. package/dist/js/katex/fonts/KaTeX_Main-Italic.woff2 +0 -0
  327. package/dist/js/katex/fonts/KaTeX_Main-Regular.ttf +0 -0
  328. package/dist/js/katex/fonts/KaTeX_Main-Regular.woff +0 -0
  329. package/dist/js/katex/fonts/KaTeX_Main-Regular.woff2 +0 -0
  330. package/dist/js/katex/fonts/KaTeX_Math-BoldItalic.ttf +0 -0
  331. package/dist/js/katex/fonts/KaTeX_Math-BoldItalic.woff +0 -0
  332. package/dist/js/katex/fonts/KaTeX_Math-BoldItalic.woff2 +0 -0
  333. package/dist/js/katex/fonts/KaTeX_Math-Italic.ttf +0 -0
  334. package/dist/js/katex/fonts/KaTeX_Math-Italic.woff +0 -0
  335. package/dist/js/katex/fonts/KaTeX_Math-Italic.woff2 +0 -0
  336. package/dist/js/katex/fonts/KaTeX_SansSerif-Bold.ttf +0 -0
  337. package/dist/js/katex/fonts/KaTeX_SansSerif-Bold.woff +0 -0
  338. package/dist/js/katex/fonts/KaTeX_SansSerif-Bold.woff2 +0 -0
  339. package/dist/js/katex/fonts/KaTeX_SansSerif-Italic.ttf +0 -0
  340. package/dist/js/katex/fonts/KaTeX_SansSerif-Italic.woff +0 -0
  341. package/dist/js/katex/fonts/KaTeX_SansSerif-Italic.woff2 +0 -0
  342. package/dist/js/katex/fonts/KaTeX_SansSerif-Regular.ttf +0 -0
  343. package/dist/js/katex/fonts/KaTeX_SansSerif-Regular.woff +0 -0
  344. package/dist/js/katex/fonts/KaTeX_SansSerif-Regular.woff2 +0 -0
  345. package/dist/js/katex/fonts/KaTeX_Script-Regular.ttf +0 -0
  346. package/dist/js/katex/fonts/KaTeX_Script-Regular.woff +0 -0
  347. package/dist/js/katex/fonts/KaTeX_Script-Regular.woff2 +0 -0
  348. package/dist/js/katex/fonts/KaTeX_Size1-Regular.ttf +0 -0
  349. package/dist/js/katex/fonts/KaTeX_Size1-Regular.woff +0 -0
  350. package/dist/js/katex/fonts/KaTeX_Size1-Regular.woff2 +0 -0
  351. package/dist/js/katex/fonts/KaTeX_Size2-Regular.ttf +0 -0
  352. package/dist/js/katex/fonts/KaTeX_Size2-Regular.woff +0 -0
  353. package/dist/js/katex/fonts/KaTeX_Size2-Regular.woff2 +0 -0
  354. package/dist/js/katex/fonts/KaTeX_Size3-Regular.ttf +0 -0
  355. package/dist/js/katex/fonts/KaTeX_Size3-Regular.woff +0 -0
  356. package/dist/js/katex/fonts/KaTeX_Size3-Regular.woff2 +0 -0
  357. package/dist/js/katex/fonts/KaTeX_Size4-Regular.ttf +0 -0
  358. package/dist/js/katex/fonts/KaTeX_Size4-Regular.woff +0 -0
  359. package/dist/js/katex/fonts/KaTeX_Size4-Regular.woff2 +0 -0
  360. package/dist/js/katex/fonts/KaTeX_Typewriter-Regular.ttf +0 -0
  361. package/dist/js/katex/fonts/KaTeX_Typewriter-Regular.woff +0 -0
  362. package/dist/js/katex/fonts/KaTeX_Typewriter-Regular.woff2 +0 -0
  363. package/dist/js/katex/katex.min.css +1 -0
  364. package/dist/js/katex/katex.min.js +1 -0
  365. package/dist/js/katex/mhchem.min.js +1 -0
  366. package/dist/js/lute/lute.min.js +72 -0
  367. package/dist/js/markmap/katex.min.css +1 -0
  368. package/dist/js/markmap/markmap.min.js +8251 -0
  369. package/dist/js/markmap/prism.css +140 -0
  370. package/dist/js/mathjax/LICENSE +202 -0
  371. package/dist/js/mathjax/a11y/assistive-mml.js +1 -0
  372. package/dist/js/mathjax/a11y/complexity.js +1 -0
  373. package/dist/js/mathjax/a11y/explorer.js +1 -0
  374. package/dist/js/mathjax/a11y/semantic-enrich.js +1 -0
  375. package/dist/js/mathjax/input/asciimath.js +1 -0
  376. package/dist/js/mathjax/input/mml/entities.js +1 -0
  377. package/dist/js/mathjax/input/mml.js +1 -0
  378. package/dist/js/mathjax/input/tex/extensions/action.js +1 -0
  379. package/dist/js/mathjax/input/tex/extensions/all-packages.js +1 -0
  380. package/dist/js/mathjax/input/tex/extensions/ams.js +1 -0
  381. package/dist/js/mathjax/input/tex/extensions/amscd.js +1 -0
  382. package/dist/js/mathjax/input/tex/extensions/autoload.js +1 -0
  383. package/dist/js/mathjax/input/tex/extensions/bbox.js +1 -0
  384. package/dist/js/mathjax/input/tex/extensions/boldsymbol.js +1 -0
  385. package/dist/js/mathjax/input/tex/extensions/braket.js +1 -0
  386. package/dist/js/mathjax/input/tex/extensions/bussproofs.js +1 -0
  387. package/dist/js/mathjax/input/tex/extensions/cancel.js +1 -0
  388. package/dist/js/mathjax/input/tex/extensions/color.js +1 -0
  389. package/dist/js/mathjax/input/tex/extensions/colorV2.js +1 -0
  390. package/dist/js/mathjax/input/tex/extensions/configMacros.js +1 -0
  391. package/dist/js/mathjax/input/tex/extensions/enclose.js +1 -0
  392. package/dist/js/mathjax/input/tex/extensions/extpfeil.js +1 -0
  393. package/dist/js/mathjax/input/tex/extensions/html.js +1 -0
  394. package/dist/js/mathjax/input/tex/extensions/mhchem.js +1 -0
  395. package/dist/js/mathjax/input/tex/extensions/newcommand.js +1 -0
  396. package/dist/js/mathjax/input/tex/extensions/noerrors.js +1 -0
  397. package/dist/js/mathjax/input/tex/extensions/noundefined.js +1 -0
  398. package/dist/js/mathjax/input/tex/extensions/physics.js +1 -0
  399. package/dist/js/mathjax/input/tex/extensions/require.js +1 -0
  400. package/dist/js/mathjax/input/tex/extensions/tagFormat.js +1 -0
  401. package/dist/js/mathjax/input/tex/extensions/textmacros.js +1 -0
  402. package/dist/js/mathjax/input/tex/extensions/unicode.js +1 -0
  403. package/dist/js/mathjax/input/tex/extensions/verb.js +1 -0
  404. package/dist/js/mathjax/input/tex-base.js +1 -0
  405. package/dist/js/mathjax/input/tex-full.js +1 -0
  406. package/dist/js/mathjax/input/tex.js +1 -0
  407. package/dist/js/mathjax/sre/mathmaps/de.js +104 -0
  408. package/dist/js/mathjax/sre/mathmaps/en.js +110 -0
  409. package/dist/js/mathjax/sre/mathmaps/es.js +104 -0
  410. package/dist/js/mathjax/sre/mathmaps/fr.js +104 -0
  411. package/dist/js/mathjax/sre/mathmaps/mathmaps_ie.js +518 -0
  412. package/dist/js/mathjax/sre/mathmaps/nemeth.js +104 -0
  413. package/dist/js/mathjax/sre/sre-node.js +11 -0
  414. package/dist/js/mathjax/sre/sre_browser.js +1633 -0
  415. package/dist/js/mathjax/tex-svg-full.js +1 -0
  416. package/dist/js/mermaid/mermaid.min.js +2694 -0
  417. package/dist/js/plantuml/plantuml-encoder.min.js +1 -0
  418. package/dist/js/smiles-drawer/smiles-drawer.min.js +71 -0
  419. package/dist/method.d.ts +51 -0
  420. package/dist/method.js +2675 -0
  421. package/dist/method.min.js +1 -0
  422. package/dist/ts/constants.d.ts +47 -0
  423. package/dist/ts/devtools/index.d.ts +7 -0
  424. package/dist/ts/export/index.d.ts +4 -0
  425. package/dist/ts/hint/index.d.ts +14 -0
  426. package/dist/ts/ir/expandMarker.d.ts +1 -0
  427. package/dist/ts/ir/highlightToolbarIR.d.ts +1 -0
  428. package/dist/ts/ir/index.d.ts +13 -0
  429. package/dist/ts/ir/input.d.ts +1 -0
  430. package/dist/ts/ir/process.d.ts +8 -0
  431. package/dist/ts/ir/processKeydown.d.ts +1 -0
  432. package/dist/ts/markdown/SMILESRender.d.ts +1 -0
  433. package/dist/ts/markdown/abcRender.d.ts +1 -0
  434. package/dist/ts/markdown/adapterRender.d.ts +41 -0
  435. package/dist/ts/markdown/anchorRender.d.ts +1 -0
  436. package/dist/ts/markdown/chartRender.d.ts +1 -0
  437. package/dist/ts/markdown/codeRender.d.ts +1 -0
  438. package/dist/ts/markdown/flowchartRender.d.ts +1 -0
  439. package/dist/ts/markdown/getHTML.d.ts +1 -0
  440. package/dist/ts/markdown/getMarkdown.d.ts +1 -0
  441. package/dist/ts/markdown/graphvizRender.d.ts +1 -0
  442. package/dist/ts/markdown/highlightRender.d.ts +1 -0
  443. package/dist/ts/markdown/lazyLoadImageRender.d.ts +6 -0
  444. package/dist/ts/markdown/markmapRender.d.ts +1 -0
  445. package/dist/ts/markdown/mathRender.d.ts +9 -0
  446. package/dist/ts/markdown/mediaRender.d.ts +1 -0
  447. package/dist/ts/markdown/mermaidRender.d.ts +1 -0
  448. package/dist/ts/markdown/mindmapRender.d.ts +1 -0
  449. package/dist/ts/markdown/outlineRender.d.ts +1 -0
  450. package/dist/ts/markdown/plantumlRender.d.ts +1 -0
  451. package/dist/ts/markdown/previewRender.d.ts +2 -0
  452. package/dist/ts/markdown/setLute.d.ts +1 -0
  453. package/dist/ts/markdown/speechRender.d.ts +6 -0
  454. package/dist/ts/outline/index.d.ts +7 -0
  455. package/dist/ts/preview/image.d.ts +1 -0
  456. package/dist/ts/preview/index.d.ts +10 -0
  457. package/dist/ts/resize/index.d.ts +6 -0
  458. package/dist/ts/sv/combineFootnote.d.ts +6 -0
  459. package/dist/ts/sv/index.d.ts +13 -0
  460. package/dist/ts/sv/inputEvent.d.ts +1 -0
  461. package/dist/ts/sv/process.d.ts +11 -0
  462. package/dist/ts/sv/processKeydown.d.ts +1 -0
  463. package/dist/ts/tip/index.d.ts +6 -0
  464. package/dist/ts/toolbar/Both.d.ts +5 -0
  465. package/dist/ts/toolbar/Br.d.ts +4 -0
  466. package/dist/ts/toolbar/CodeTheme.d.ts +6 -0
  467. package/dist/ts/toolbar/ContentTheme.d.ts +6 -0
  468. package/dist/ts/toolbar/Counter.d.ts +6 -0
  469. package/dist/ts/toolbar/Custom.d.ts +5 -0
  470. package/dist/ts/toolbar/Devtools.d.ts +5 -0
  471. package/dist/ts/toolbar/Divider.d.ts +4 -0
  472. package/dist/ts/toolbar/EditMode.d.ts +8 -0
  473. package/dist/ts/toolbar/Emoji.d.ts +7 -0
  474. package/dist/ts/toolbar/Export.d.ts +6 -0
  475. package/dist/ts/toolbar/Fullscreen.d.ts +6 -0
  476. package/dist/ts/toolbar/Headings.d.ts +7 -0
  477. package/dist/ts/toolbar/Help.d.ts +5 -0
  478. package/dist/ts/toolbar/Indent.d.ts +5 -0
  479. package/dist/ts/toolbar/Info.d.ts +5 -0
  480. package/dist/ts/toolbar/InsertAfter.d.ts +5 -0
  481. package/dist/ts/toolbar/InsertBefore.d.ts +5 -0
  482. package/dist/ts/toolbar/MenuItem.d.ts +5 -0
  483. package/dist/ts/toolbar/Outdent.d.ts +5 -0
  484. package/dist/ts/toolbar/Outline.d.ts +5 -0
  485. package/dist/ts/toolbar/Preview.d.ts +6 -0
  486. package/dist/ts/toolbar/Record.d.ts +6 -0
  487. package/dist/ts/toolbar/Redo.d.ts +5 -0
  488. package/dist/ts/toolbar/Undo.d.ts +5 -0
  489. package/dist/ts/toolbar/Upload.d.ts +6 -0
  490. package/dist/ts/toolbar/index.d.ts +10 -0
  491. package/dist/ts/toolbar/setToolbar.d.ts +20 -0
  492. package/dist/ts/ui/initUI.d.ts +4 -0
  493. package/dist/ts/ui/setCodeTheme.d.ts +1 -0
  494. package/dist/ts/ui/setContentTheme.d.ts +1 -0
  495. package/dist/ts/ui/setPreviewMode.d.ts +1 -0
  496. package/dist/ts/ui/setTheme.d.ts +1 -0
  497. package/dist/ts/undo/index.d.ts +19 -0
  498. package/dist/ts/upload/getElement.d.ts +1 -0
  499. package/dist/ts/upload/index.d.ts +8 -0
  500. package/dist/ts/upload/setHeaders.d.ts +1 -0
  501. package/dist/ts/util/Options.d.ts +8 -0
  502. package/dist/ts/util/RecordMedia.d.ts +18 -0
  503. package/dist/ts/util/addScript.d.ts +2 -0
  504. package/dist/ts/util/addStyle.d.ts +1 -0
  505. package/dist/ts/util/code160to32.d.ts +1 -0
  506. package/dist/ts/util/compatibility.d.ts +7 -0
  507. package/dist/ts/util/editorCommonEvent.d.ts +9 -0
  508. package/dist/ts/util/fixBrowserBehavior.d.ts +39 -0
  509. package/dist/ts/util/function.d.ts +3 -0
  510. package/dist/ts/util/getSelectText.d.ts +1 -0
  511. package/dist/ts/util/hasClosest.d.ts +9 -0
  512. package/dist/ts/util/hasClosestByHeadings.d.ts +2 -0
  513. package/dist/ts/util/highlightToolbar.d.ts +1 -0
  514. package/dist/ts/util/hotKey.d.ts +1 -0
  515. package/dist/ts/util/log.d.ts +1 -0
  516. package/dist/ts/util/merge.d.ts +1 -0
  517. package/dist/ts/util/processCode.d.ts +2 -0
  518. package/dist/ts/util/selection.d.ts +14 -0
  519. package/dist/ts/util/toc.d.ts +5 -0
  520. package/dist/ts/wysiwyg/afterRenderEvent.d.ts +5 -0
  521. package/dist/ts/wysiwyg/highlightToolbarWYSIWYG.d.ts +4 -0
  522. package/dist/ts/wysiwyg/index.d.ts +22 -0
  523. package/dist/ts/wysiwyg/inlineTag.d.ts +10 -0
  524. package/dist/ts/wysiwyg/input.d.ts +1 -0
  525. package/dist/ts/wysiwyg/processKeydown.d.ts +2 -0
  526. package/dist/ts/wysiwyg/renderDomByMd.d.ts +5 -0
  527. package/dist/ts/wysiwyg/setHeading.d.ts +2 -0
  528. package/dist/ts/wysiwyg/showCode.d.ts +1 -0
  529. package/dist/ts/wysiwyg/toolbarEvent.d.ts +1 -0
  530. package/dist/types/index.d.ts +925 -0
  531. package/package.json +79 -0
  532. package/src/assets/less/_content.less +279 -0
  533. package/src/assets/less/_hint.less +67 -0
  534. package/src/assets/less/_ir.less +275 -0
  535. package/src/assets/less/_panel.less +110 -0
  536. package/src/assets/less/_reset.less +632 -0
  537. package/src/assets/less/_sv.less +132 -0
  538. package/src/assets/less/_toolbar.less +180 -0
  539. package/src/assets/less/_tooltipped.less +171 -0
  540. package/src/assets/less/_wysiwyg.less +195 -0
  541. package/src/assets/less/index.less +88 -0
  542. package/src/index.ts +566 -0
  543. package/src/method.ts +71 -0
  544. package/src/ts/constants.ts +90 -0
  545. package/src/ts/devtools/index.ts +83 -0
  546. package/src/ts/export/index.ts +84 -0
  547. package/src/ts/hint/index.ts +276 -0
  548. package/src/ts/ir/expandMarker.ts +79 -0
  549. package/src/ts/ir/highlightToolbarIR.ts +97 -0
  550. package/src/ts/ir/index.ts +265 -0
  551. package/src/ts/ir/input.ts +246 -0
  552. package/src/ts/ir/process.ts +222 -0
  553. package/src/ts/ir/processKeydown.ts +238 -0
  554. package/src/ts/markdown/SMILESRender.ts +29 -0
  555. package/src/ts/markdown/abcRender.ts +27 -0
  556. package/src/ts/markdown/adapterRender.ts +41 -0
  557. package/src/ts/markdown/anchorRender.ts +19 -0
  558. package/src/ts/markdown/chartRender.ts +38 -0
  559. package/src/ts/markdown/codeRender.ts +60 -0
  560. package/src/ts/markdown/flowchartRender.ts +25 -0
  561. package/src/ts/markdown/getHTML.ts +11 -0
  562. package/src/ts/markdown/getMarkdown.ts +12 -0
  563. package/src/ts/markdown/graphvizRender.ts +49 -0
  564. package/src/ts/markdown/highlightRender.ts +94 -0
  565. package/src/ts/markdown/lazyLoadImageRender.ts +56 -0
  566. package/src/ts/markdown/markmapRender.ts +56 -0
  567. package/src/ts/markdown/mathRender.ts +148 -0
  568. package/src/ts/markdown/mediaRender.ts +105 -0
  569. package/src/ts/markdown/mermaidRender.ts +60 -0
  570. package/src/ts/markdown/mindmapRender.ts +74 -0
  571. package/src/ts/markdown/outlineRender.ts +110 -0
  572. package/src/ts/markdown/plantumlRender.ts +32 -0
  573. package/src/ts/markdown/previewRender.ts +171 -0
  574. package/src/ts/markdown/setLute.ts +26 -0
  575. package/src/ts/markdown/speechRender.ts +107 -0
  576. package/src/ts/outline/index.ts +45 -0
  577. package/src/ts/preview/image.ts +50 -0
  578. package/src/ts/preview/index.ts +287 -0
  579. package/src/ts/resize/index.ts +57 -0
  580. package/src/ts/sv/combineFootnote.ts +27 -0
  581. package/src/ts/sv/index.ts +125 -0
  582. package/src/ts/sv/inputEvent.ts +188 -0
  583. package/src/ts/sv/process.ts +215 -0
  584. package/src/ts/sv/processKeydown.ts +202 -0
  585. package/src/ts/tip/index.ts +39 -0
  586. package/src/ts/toolbar/Both.ts +28 -0
  587. package/src/ts/toolbar/Br.ts +8 -0
  588. package/src/ts/toolbar/CodeTheme.ts +36 -0
  589. package/src/ts/toolbar/ContentTheme.ts +35 -0
  590. package/src/ts/toolbar/Counter.ts +40 -0
  591. package/src/ts/toolbar/Custom.ts +17 -0
  592. package/src/ts/toolbar/Devtools.ts +28 -0
  593. package/src/ts/toolbar/Divider.ts +8 -0
  594. package/src/ts/toolbar/EditMode.ts +195 -0
  595. package/src/ts/toolbar/Emoji.ts +79 -0
  596. package/src/ts/toolbar/Export.ts +41 -0
  597. package/src/ts/toolbar/Fullscreen.ts +66 -0
  598. package/src/ts/toolbar/Headings.ts +73 -0
  599. package/src/ts/toolbar/Help.ts +30 -0
  600. package/src/ts/toolbar/Indent.ts +25 -0
  601. package/src/ts/toolbar/Info.ts +43 -0
  602. package/src/ts/toolbar/InsertAfter.ts +18 -0
  603. package/src/ts/toolbar/InsertBefore.ts +18 -0
  604. package/src/ts/toolbar/MenuItem.ts +54 -0
  605. package/src/ts/toolbar/Outdent.ts +24 -0
  606. package/src/ts/toolbar/Outline.ts +21 -0
  607. package/src/ts/toolbar/Preview.ts +55 -0
  608. package/src/ts/toolbar/Record.ts +60 -0
  609. package/src/ts/toolbar/Redo.ts +18 -0
  610. package/src/ts/toolbar/Undo.ts +18 -0
  611. package/src/ts/toolbar/Upload.ts +41 -0
  612. package/src/ts/toolbar/index.ts +192 -0
  613. package/src/ts/toolbar/setToolbar.ts +120 -0
  614. package/src/ts/ui/initUI.ts +180 -0
  615. package/src/ts/ui/setCodeTheme.ts +16 -0
  616. package/src/ts/ui/setContentTheme.ts +15 -0
  617. package/src/ts/ui/setPreviewMode.ts +31 -0
  618. package/src/ts/ui/setTheme.ts +7 -0
  619. package/src/ts/undo/index.ts +270 -0
  620. package/src/ts/upload/getElement.ts +10 -0
  621. package/src/ts/upload/index.ts +273 -0
  622. package/src/ts/upload/setHeaders.ts +10 -0
  623. package/src/ts/util/Options.ts +454 -0
  624. package/src/ts/util/RecordMedia.ts +170 -0
  625. package/src/ts/util/addScript.ts +43 -0
  626. package/src/ts/util/addStyle.ts +10 -0
  627. package/src/ts/util/code160to32.ts +4 -0
  628. package/src/ts/util/compatibility.ts +67 -0
  629. package/src/ts/util/editorCommonEvent.ts +264 -0
  630. package/src/ts/util/fixBrowserBehavior.ts +1569 -0
  631. package/src/ts/util/function.ts +15 -0
  632. package/src/ts/util/getSelectText.ts +8 -0
  633. package/src/ts/util/hasClosest.ts +154 -0
  634. package/src/ts/util/hasClosestByHeadings.ts +27 -0
  635. package/src/ts/util/highlightToolbar.ts +10 -0
  636. package/src/ts/util/hotKey.ts +54 -0
  637. package/src/ts/util/log.ts +6 -0
  638. package/src/ts/util/merge.ts +18 -0
  639. package/src/ts/util/processCode.ts +101 -0
  640. package/src/ts/util/selection.ts +280 -0
  641. package/src/ts/util/toc.ts +83 -0
  642. package/src/ts/wysiwyg/afterRenderEvent.ts +41 -0
  643. package/src/ts/wysiwyg/highlightToolbarWYSIWYG.ts +1156 -0
  644. package/src/ts/wysiwyg/index.ts +578 -0
  645. package/src/ts/wysiwyg/inlineTag.ts +129 -0
  646. package/src/ts/wysiwyg/input.ts +212 -0
  647. package/src/ts/wysiwyg/processKeydown.ts +363 -0
  648. package/src/ts/wysiwyg/renderDomByMd.ts +18 -0
  649. package/src/ts/wysiwyg/setHeading.ts +43 -0
  650. package/src/ts/wysiwyg/showCode.ts +32 -0
  651. package/src/ts/wysiwyg/toolbarEvent.ts +333 -0
@@ -0,0 +1,1569 @@
1
+ import {Constants} from "../constants";
2
+ import {input as IRInput} from "../ir/input";
3
+ import {processAfterRender} from "../ir/process";
4
+ import {processAfterRender as processSVAfterRender, processPaste} from "../sv/process";
5
+ import {uploadFiles} from "../upload/index";
6
+ import {setHeaders} from "../upload/setHeaders";
7
+ import {afterRenderEvent} from "../wysiwyg/afterRenderEvent";
8
+ import {input} from "../wysiwyg/input";
9
+ import {isCtrl, isFirefox} from "./compatibility";
10
+ import {scrollCenter} from "./editorCommonEvent";
11
+ import {
12
+ getTopList,
13
+ hasClosestBlock,
14
+ hasClosestByAttribute,
15
+ hasClosestByClassName,
16
+ hasClosestByMatchTag,
17
+ } from "./hasClosest";
18
+ import {getLastNode} from "./hasClosest";
19
+ import {highlightToolbar} from "./highlightToolbar";
20
+ import {matchHotKey} from "./hotKey";
21
+ import {processCodeRender, processPasteCode} from "./processCode";
22
+ import {
23
+ getEditorRange,
24
+ getSelectPosition,
25
+ insertHTML,
26
+ setRangeByWbr,
27
+ setSelectionByPosition, setSelectionFocus,
28
+ } from "./selection";
29
+
30
+ // https://github.com/Vanessa219/vditor/issues/508 软键盘无法删除空块
31
+ export const fixGSKeyBackspace = (event: KeyboardEvent, vditor: IVditor, startContainer: Node) => {
32
+ if (event.keyCode === 229 && event.code === "" && event.key === "Unidentified" && vditor.currentMode !== "sv") {
33
+ const blockElement = hasClosestBlock(startContainer);
34
+ // 移动端的标点符号都显示为 299,因此需限定为空删除的条件
35
+ if (blockElement && blockElement.textContent.trim() === "") {
36
+ vditor[vditor.currentMode].composingLock = true;
37
+ return false;
38
+ }
39
+ }
40
+ return true;
41
+ };
42
+
43
+ // https://github.com/Vanessa219/vditor/issues/361 代码块后输入中文
44
+ export const fixCJKPosition = (range: Range, vditor: IVditor, event: KeyboardEvent) => {
45
+ if (event.key === "Enter" || event.key === "Tab" || event.key === "Backspace" || event.key.indexOf("Arrow") > -1
46
+ || isCtrl(event) || event.key === "Escape" || event.shiftKey || event.altKey) {
47
+ return;
48
+ }
49
+ const pLiElement = hasClosestByMatchTag(range.startContainer, "P") ||
50
+ hasClosestByMatchTag(range.startContainer, "LI");
51
+ if (pLiElement && getSelectPosition(pLiElement, vditor[vditor.currentMode].element, range).start === 0) {
52
+
53
+ // https://github.com/Vanessa219/vditor/issues/1289 WKWebView切换输入法产生六分之一空格,造成光标错位
54
+ if (pLiElement.nodeValue) {
55
+ pLiElement.nodeValue = pLiElement.nodeValue.replace(/\u2006/g, "");
56
+ }
57
+
58
+ const zwspNode = document.createTextNode(Constants.ZWSP);
59
+ range.insertNode(zwspNode);
60
+ range.setStartAfter(zwspNode);
61
+ }
62
+ };
63
+
64
+ // https://github.com/Vanessa219/vditor/issues/381 光标在内联数学公式中无法向下移动
65
+ export const fixCursorDownInlineMath = (range: Range, key: string) => {
66
+ if (key === "ArrowDown" || key === "ArrowUp") {
67
+ const inlineElement = hasClosestByAttribute(range.startContainer, "data-type", "math-inline") ||
68
+ hasClosestByAttribute(range.startContainer, "data-type", "html-entity") ||
69
+ hasClosestByAttribute(range.startContainer, "data-type", "html-inline");
70
+ if (inlineElement) {
71
+ if (key === "ArrowDown") {
72
+ range.setStartAfter(inlineElement.parentElement);
73
+ }
74
+ if (key === "ArrowUp") {
75
+ range.setStartBefore(inlineElement.parentElement);
76
+ }
77
+ }
78
+ }
79
+ };
80
+
81
+ export const insertEmptyBlock = (vditor: IVditor, position: InsertPosition) => {
82
+ const range = getEditorRange(vditor);
83
+ const blockElement = hasClosestBlock(range.startContainer);
84
+ if (blockElement) {
85
+ blockElement.insertAdjacentHTML(position, `<p data-block="0">${Constants.ZWSP}<wbr>\n</p>`);
86
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
87
+ highlightToolbar(vditor);
88
+ execAfterRender(vditor);
89
+ }
90
+ };
91
+
92
+ export const isFirstCell = (cellElement: HTMLElement) => {
93
+ const tableElement = hasClosestByMatchTag(cellElement, "TABLE") as HTMLTableElement;
94
+ if (tableElement && tableElement.rows[0].cells[0].isSameNode(cellElement)) {
95
+ return tableElement;
96
+ }
97
+ return false;
98
+ };
99
+
100
+ export const isLastCell = (cellElement: HTMLElement) => {
101
+ const tableElement = hasClosestByMatchTag(cellElement, "TABLE") as HTMLTableElement;
102
+ if (tableElement && tableElement.lastElementChild.lastElementChild.lastElementChild.isSameNode(cellElement)) {
103
+ return tableElement;
104
+ }
105
+ return false;
106
+ };
107
+
108
+ // 光标设置到前一个表格中
109
+ const goPreviousCell = (cellElement: HTMLElement, range: Range, isSelected = true) => {
110
+ let previousElement = cellElement.previousElementSibling;
111
+ if (!previousElement) {
112
+ if (cellElement.parentElement.previousElementSibling) {
113
+ previousElement = cellElement.parentElement.previousElementSibling.lastElementChild;
114
+ } else if (cellElement.parentElement.parentElement.tagName === "TBODY" &&
115
+ cellElement.parentElement.parentElement.previousElementSibling) {
116
+ previousElement = cellElement.parentElement
117
+ .parentElement.previousElementSibling.lastElementChild.lastElementChild;
118
+ } else {
119
+ previousElement = null;
120
+ }
121
+ }
122
+ if (previousElement) {
123
+ range.selectNodeContents(previousElement);
124
+ if (!isSelected) {
125
+ range.collapse(false);
126
+ }
127
+ setSelectionFocus(range);
128
+ }
129
+ return previousElement;
130
+ };
131
+
132
+ export const insertAfterBlock = (vditor: IVditor, event: KeyboardEvent, range: Range, element: HTMLElement,
133
+ blockElement: HTMLElement) => {
134
+ const position = getSelectPosition(element, vditor[vditor.currentMode].element, range);
135
+ if ((event.key === "ArrowDown" && element.textContent.trimRight().substr(position.start).indexOf("\n") === -1) ||
136
+ (event.key === "ArrowRight" && position.start >= element.textContent.trimRight().length)) {
137
+ const nextElement = blockElement.nextElementSibling;
138
+ if (!nextElement ||
139
+ (nextElement && (nextElement.tagName === "TABLE" || nextElement.getAttribute("data-type")))) {
140
+ blockElement.insertAdjacentHTML("afterend",
141
+ `<p data-block="0">${Constants.ZWSP}<wbr></p>`);
142
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
143
+ } else {
144
+ range.selectNodeContents(nextElement);
145
+ range.collapse(true);
146
+ setSelectionFocus(range);
147
+ }
148
+ event.preventDefault();
149
+ return true;
150
+ }
151
+ return false;
152
+ };
153
+
154
+ export const insertBeforeBlock = (vditor: IVditor, event: KeyboardEvent, range: Range, element: HTMLElement,
155
+ blockElement: HTMLElement) => {
156
+ const position = getSelectPosition(element, vditor[vditor.currentMode].element, range);
157
+ if ((event.key === "ArrowUp" && element.textContent.substr(0, position.start).indexOf("\n") === -1) ||
158
+ ((event.key === "ArrowLeft" || (event.key === "Backspace" && range.toString() === "")) &&
159
+ position.start === 0)) {
160
+ const previousElement = blockElement.previousElementSibling;
161
+ // table || code
162
+ if (!previousElement ||
163
+ (previousElement && (previousElement.tagName === "TABLE" || previousElement.getAttribute("data-type")))) {
164
+ blockElement.insertAdjacentHTML("beforebegin",
165
+ `<p data-block="0">${Constants.ZWSP}<wbr></p>`);
166
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
167
+ } else {
168
+ range.selectNodeContents(previousElement);
169
+ range.collapse(false);
170
+ setSelectionFocus(range);
171
+ }
172
+ event.preventDefault();
173
+ return true;
174
+ }
175
+ return false;
176
+ };
177
+
178
+ export const listToggle = (vditor: IVditor, range: Range, type: string, cancel = true) => {
179
+ const itemElement = hasClosestByMatchTag(range.startContainer, "LI");
180
+ vditor[vditor.currentMode].element.querySelectorAll("wbr").forEach((wbr) => {
181
+ wbr.remove();
182
+ });
183
+ range.insertNode(document.createElement("wbr"));
184
+
185
+ if (cancel && itemElement) {
186
+ // 取消
187
+ let pHTML = "";
188
+ for (let i = 0; i < itemElement.parentElement.childElementCount; i++) {
189
+ const inputElement = itemElement.parentElement.children[i].querySelector("input");
190
+ if (inputElement) {
191
+ inputElement.remove();
192
+ }
193
+ pHTML += `<p data-block="0">${itemElement.parentElement.children[i].innerHTML.trimLeft()}</p>`;
194
+ }
195
+ itemElement.parentElement.insertAdjacentHTML("beforebegin", pHTML);
196
+ itemElement.parentElement.remove();
197
+ } else {
198
+ if (!itemElement) {
199
+ // 添加
200
+ let blockElement = hasClosestByAttribute(range.startContainer, "data-block", "0");
201
+ if (!blockElement) {
202
+ vditor[vditor.currentMode].element.querySelector("wbr").remove();
203
+ blockElement = vditor[vditor.currentMode].element.querySelector("p");
204
+ blockElement.innerHTML = "<wbr>";
205
+ }
206
+ if (type === "check") {
207
+ blockElement.insertAdjacentHTML("beforebegin",
208
+ `<ul data-block="0"><li class="vditor-task"><input type="checkbox" /> ${blockElement.innerHTML}</li></ul>`);
209
+ blockElement.remove();
210
+ } else if (type === "list") {
211
+ blockElement.insertAdjacentHTML("beforebegin",
212
+ `<ul data-block="0"><li>${blockElement.innerHTML}</li></ul>`);
213
+ blockElement.remove();
214
+ } else if (type === "ordered-list") {
215
+ blockElement.insertAdjacentHTML("beforebegin",
216
+ `<ol data-block="0"><li>${blockElement.innerHTML}</li></ol>`);
217
+ blockElement.remove();
218
+ }
219
+ } else {
220
+ // 切换
221
+ if (type === "check") {
222
+ itemElement.parentElement.querySelectorAll("li").forEach((item) => {
223
+ item.insertAdjacentHTML("afterbegin",
224
+ `<input type="checkbox" />${item.textContent.indexOf(" ") === 0 ? "" : " "}`);
225
+ item.classList.add("vditor-task");
226
+ });
227
+ } else {
228
+ if (itemElement.querySelector("input")) {
229
+ itemElement.parentElement.querySelectorAll("li").forEach((item) => {
230
+ item.querySelector("input").remove();
231
+ item.classList.remove("vditor-task");
232
+ });
233
+ }
234
+ let element;
235
+ if (type === "list") {
236
+ element = document.createElement("ul");
237
+ element.setAttribute("data-marker", "*");
238
+ } else {
239
+ element = document.createElement("ol");
240
+ element.setAttribute("data-marker", "1.");
241
+ }
242
+ element.setAttribute("data-block", "0");
243
+ element.setAttribute("data-tight", itemElement.parentElement.getAttribute("data-tight"));
244
+ element.innerHTML = itemElement.parentElement.innerHTML;
245
+ itemElement.parentElement.parentNode.replaceChild(element, itemElement.parentElement);
246
+ }
247
+ }
248
+ }
249
+ };
250
+
251
+ export const listIndent = (vditor: IVditor, liElement: HTMLElement, range: Range) => {
252
+ const previousElement = liElement.previousElementSibling;
253
+ if (liElement && previousElement) {
254
+ const liElements: HTMLElement[] = [liElement];
255
+ Array.from(range.cloneContents().children).forEach((item, index) => {
256
+ if (item.nodeType !== 3 && liElement && item.textContent.trim() !== ""
257
+ && liElement.getAttribute("data-node-id") === item.getAttribute("data-node-id")) {
258
+ if (index !== 0) {
259
+ liElements.push(liElement);
260
+ }
261
+ liElement = liElement.nextElementSibling as HTMLElement;
262
+ }
263
+ });
264
+
265
+ vditor[vditor.currentMode].element.querySelectorAll("wbr").forEach((wbr) => {
266
+ wbr.remove();
267
+ });
268
+ range.insertNode(document.createElement("wbr"));
269
+ const liParentElement = previousElement.parentElement;
270
+
271
+ let liHTML = "";
272
+ liElements.forEach((item: HTMLElement) => {
273
+ let marker = item.getAttribute("data-marker");
274
+ if (marker.length !== 1) {
275
+ marker = `1${marker.slice(-1)}`;
276
+ }
277
+ liHTML += `<li data-node-id="${item.getAttribute("data-node-id")}" data-marker="${marker}">${item.innerHTML}</li>`;
278
+ item.remove();
279
+ });
280
+ previousElement.insertAdjacentHTML("beforeend",
281
+ `<${liParentElement.tagName} data-block="0">${liHTML}</${liParentElement.tagName}>`);
282
+
283
+ if (vditor.currentMode === "wysiwyg") {
284
+ liParentElement.outerHTML = vditor.lute.SpinVditorDOM(liParentElement.outerHTML);
285
+ } else {
286
+ liParentElement.outerHTML = vditor.lute.SpinVditorIRDOM(liParentElement.outerHTML);
287
+ }
288
+
289
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
290
+ const tempTopListElement = getTopList(range.startContainer);
291
+ if (tempTopListElement) {
292
+ tempTopListElement.querySelectorAll(`.vditor-${vditor.currentMode}__preview[data-render='2']`)
293
+ .forEach((item: HTMLElement) => {
294
+ processCodeRender(item, vditor);
295
+ if (vditor.currentMode === "wysiwyg") {
296
+ item.previousElementSibling.setAttribute("style", "display:none");
297
+ }
298
+ });
299
+ }
300
+ execAfterRender(vditor);
301
+ highlightToolbar(vditor);
302
+ } else {
303
+ vditor[vditor.currentMode].element.focus();
304
+ }
305
+ };
306
+
307
+ export const listOutdent = (vditor: IVditor, liElement: HTMLElement, range: Range, topListElement: HTMLElement) => {
308
+ const liParentLiElement = hasClosestByMatchTag(liElement.parentElement, "LI");
309
+ if (liParentLiElement) {
310
+ vditor[vditor.currentMode].element.querySelectorAll("wbr").forEach((wbr) => {
311
+ wbr.remove();
312
+ });
313
+ range.insertNode(document.createElement("wbr"));
314
+
315
+ const liParentElement = liElement.parentElement;
316
+ const liParentAfterElement = liParentElement.cloneNode() as HTMLElement;
317
+ const liElements: HTMLElement[] = [liElement];
318
+ Array.from(range.cloneContents().children).forEach((item, index) => {
319
+ if (item.nodeType !== 3 && liElement && item.textContent.trim() !== "" &&
320
+ liElement.getAttribute("data-node-id") === item.getAttribute("data-node-id")) {
321
+ if (index !== 0) {
322
+ liElements.push(liElement);
323
+ }
324
+ liElement = liElement.nextElementSibling as HTMLElement;
325
+ }
326
+ });
327
+ let isMatch = false;
328
+ let afterHTML = "";
329
+ liParentElement.querySelectorAll("li").forEach((item) => {
330
+ if (isMatch) {
331
+ afterHTML += item.outerHTML;
332
+ if (!item.nextElementSibling && !item.previousElementSibling) {
333
+ item.parentElement.remove();
334
+ } else {
335
+ item.remove();
336
+ }
337
+ }
338
+ if (item.isSameNode(liElements[liElements.length - 1])) {
339
+ isMatch = true;
340
+ }
341
+ });
342
+
343
+ liElements.reverse().forEach((item) => {
344
+ liParentLiElement.insertAdjacentElement("afterend", item);
345
+ });
346
+
347
+ if (afterHTML) {
348
+ liParentAfterElement.innerHTML = afterHTML;
349
+ liElements[0].insertAdjacentElement("beforeend", liParentAfterElement);
350
+ }
351
+
352
+ if (vditor.currentMode === "wysiwyg") {
353
+ topListElement.outerHTML = vditor.lute.SpinVditorDOM(topListElement.outerHTML);
354
+ } else {
355
+ topListElement.outerHTML = vditor.lute.SpinVditorIRDOM(topListElement.outerHTML);
356
+ }
357
+
358
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
359
+ const tempTopListElement = getTopList(range.startContainer);
360
+ if (tempTopListElement) {
361
+ tempTopListElement.querySelectorAll(`.vditor-${vditor.currentMode}__preview[data-render='2']`)
362
+ .forEach((item: HTMLElement) => {
363
+ processCodeRender(item, vditor);
364
+ if (vditor.currentMode === "wysiwyg") {
365
+ item.previousElementSibling.setAttribute("style", "display:none");
366
+ }
367
+ });
368
+ }
369
+ execAfterRender(vditor);
370
+ highlightToolbar(vditor);
371
+ } else {
372
+ vditor[vditor.currentMode].element.focus();
373
+ }
374
+ };
375
+
376
+ export const setTableAlign = (tableElement: HTMLTableElement, type: string) => {
377
+ const cell = getSelection().getRangeAt(0).startContainer.parentElement;
378
+
379
+ const columnCnt = tableElement.rows[0].cells.length;
380
+ const rowCnt = tableElement.rows.length;
381
+ let currentColumn = 0;
382
+
383
+ for (let i = 0; i < rowCnt; i++) {
384
+ for (let j = 0; j < columnCnt; j++) {
385
+ if (tableElement.rows[i].cells[j].isSameNode(cell)) {
386
+ currentColumn = j;
387
+ break;
388
+ }
389
+ }
390
+ }
391
+ for (let k = 0; k < rowCnt; k++) {
392
+ tableElement.rows[k].cells[currentColumn].setAttribute("align", type);
393
+ }
394
+ };
395
+
396
+ export const isHrMD = (text: string) => {
397
+ // - _ *
398
+ const marker = text.trimRight().split("\n").pop();
399
+ if (marker === "") {
400
+ return false;
401
+ }
402
+ if (marker.replace(/ |-/g, "") === ""
403
+ || marker.replace(/ |_/g, "") === ""
404
+ || marker.replace(/ |\*/g, "") === "") {
405
+ if (marker.replace(/ /g, "").length > 2) {
406
+ if (marker.indexOf("-") > -1 && marker.trimLeft().indexOf(" ") === -1
407
+ && text.trimRight().split("\n").length > 1) {
408
+ // 满足 heading
409
+ return false;
410
+ }
411
+ if (marker.indexOf(" ") === 0 || marker.indexOf("\t") === 0) {
412
+ // 代码块
413
+ return false;
414
+ }
415
+ return true;
416
+ }
417
+ return false;
418
+ }
419
+ return false;
420
+ };
421
+
422
+ export const isHeadingMD = (text: string) => {
423
+ // - =
424
+ const textArray = text.trimRight().split("\n");
425
+ text = textArray.pop();
426
+
427
+ if (text.indexOf(" ") === 0 || text.indexOf("\t") === 0) {
428
+ return false;
429
+ }
430
+
431
+ text = text.trimLeft();
432
+ if (text === "" || textArray.length === 0) {
433
+ return false;
434
+ }
435
+ if (text.replace(/-/g, "") === ""
436
+ || text.replace(/=/g, "") === "") {
437
+ return true;
438
+ }
439
+ return false;
440
+ };
441
+
442
+ export const execAfterRender = (vditor: IVditor, options = {
443
+ enableAddUndoStack: true,
444
+ enableHint: false,
445
+ enableInput: true,
446
+ }) => {
447
+ if (vditor.currentMode === "wysiwyg") {
448
+ afterRenderEvent(vditor, options);
449
+ } else if (vditor.currentMode === "ir") {
450
+ processAfterRender(vditor, options);
451
+ } else if (vditor.currentMode === "sv") {
452
+ processSVAfterRender(vditor, options);
453
+ }
454
+ };
455
+
456
+ export const fixList = (range: Range, vditor: IVditor, pElement: HTMLElement | false, event: KeyboardEvent) => {
457
+ const startContainer = range.startContainer;
458
+ const liElement = hasClosestByMatchTag(startContainer, "LI");
459
+ if (liElement) {
460
+ if (!isCtrl(event) && !event.altKey && event.key === "Enter" &&
461
+ // fix li 中有多个 P 时,在第一个 P 中换行会在下方生成新的 li
462
+ (!event.shiftKey && pElement && liElement.contains(pElement) && pElement.nextElementSibling)) {
463
+ if (liElement && !liElement.textContent.endsWith("\n")) {
464
+ // li 结尾需 \n
465
+ liElement.insertAdjacentText("beforeend", "\n");
466
+ }
467
+ range.insertNode(document.createTextNode("\n\n"));
468
+ range.collapse(false);
469
+ execAfterRender(vditor);
470
+ event.preventDefault();
471
+ return true;
472
+ }
473
+
474
+ if (!isCtrl(event) && !event.shiftKey && !event.altKey && event.key === "Backspace" &&
475
+ !liElement.previousElementSibling && range.toString() === "" &&
476
+ getSelectPosition(liElement, vditor[vditor.currentMode].element, range).start === 0) {
477
+ // 光标位于点和第一个字符中间时,无法删除 li 元素
478
+ if (liElement.nextElementSibling) {
479
+ liElement.parentElement.insertAdjacentHTML("beforebegin",
480
+ `<p data-block="0"><wbr>${liElement.innerHTML}</p>`);
481
+ liElement.remove();
482
+ } else {
483
+ liElement.parentElement.outerHTML = `<p data-block="0"><wbr>${liElement.innerHTML}</p>`;
484
+ }
485
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
486
+ execAfterRender(vditor);
487
+ event.preventDefault();
488
+ return true;
489
+ }
490
+
491
+ // 空列表删除后与上一级段落对齐
492
+ if (!isCtrl(event) && !event.shiftKey && !event.altKey && event.key === "Backspace" &&
493
+ liElement.textContent.trim().replace(Constants.ZWSP, "") === "" &&
494
+ range.toString() === "" && liElement.previousElementSibling?.tagName === "LI") {
495
+ liElement.previousElementSibling.insertAdjacentText("beforeend", "\n\n");
496
+ range.selectNodeContents(liElement.previousElementSibling);
497
+ range.collapse(false);
498
+ liElement.remove();
499
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
500
+ execAfterRender(vditor);
501
+ event.preventDefault();
502
+ return true;
503
+ }
504
+
505
+ if (!isCtrl(event) && !event.altKey && event.key === "Tab") {
506
+ // 光标位于第一/零字符时,tab 用于列表的缩进
507
+ let isFirst = false;
508
+ if (range.startOffset === 0
509
+ && ((startContainer.nodeType === 3 && !startContainer.previousSibling)
510
+ || (startContainer.nodeType !== 3 && startContainer.nodeName === "LI"))) {
511
+ // 有序/无序列表
512
+ isFirst = true;
513
+ } else if (liElement.classList.contains("vditor-task") && range.startOffset === 1
514
+ && startContainer.previousSibling.nodeType !== 3
515
+ && (startContainer.previousSibling as HTMLElement).tagName === "INPUT") {
516
+ // 任务列表
517
+ isFirst = true;
518
+ }
519
+
520
+ if (isFirst || range.toString() !== "") {
521
+ if (event.shiftKey) {
522
+ listOutdent(vditor, liElement, range, liElement.parentElement);
523
+ } else {
524
+ listIndent(vditor, liElement, range);
525
+ }
526
+ event.preventDefault();
527
+ return true;
528
+ }
529
+ }
530
+ }
531
+ return false;
532
+ };
533
+
534
+ // tab 处理: block code render, table, 列表第一个字符中的 tab 处理单独写在上面
535
+ export const fixTab = (vditor: IVditor, range: Range, event: KeyboardEvent) => {
536
+ if (vditor.options.tab && event.key === "Tab") {
537
+ if (event.shiftKey) {
538
+ // TODO shift+tab
539
+ } else {
540
+ if (range.toString() === "") {
541
+ range.insertNode(document.createTextNode(vditor.options.tab));
542
+ range.collapse(false);
543
+ } else {
544
+ range.extractContents();
545
+ range.insertNode(document.createTextNode(vditor.options.tab));
546
+ range.collapse(false);
547
+ }
548
+ }
549
+ setSelectionFocus(range);
550
+ execAfterRender(vditor);
551
+ event.preventDefault();
552
+ return true;
553
+ }
554
+ };
555
+
556
+ export const fixMarkdown = (event: KeyboardEvent, vditor: IVditor, pElement: HTMLElement | false, range: Range) => {
557
+ if (!pElement) {
558
+ return;
559
+ }
560
+ if (!isCtrl(event) && !event.altKey && event.key === "Enter") {
561
+ const pText = String.raw`${pElement.textContent}`.replace(/\\\|/g, "").trim();
562
+ const pTextList = pText.split("|");
563
+ if (pText.startsWith("|") && pText.endsWith("|") && pTextList.length > 3) {
564
+ // table 自动完成
565
+ let tableHeaderMD = pTextList.map(() => "---").join("|");
566
+ tableHeaderMD =
567
+ pElement.textContent + "\n" + tableHeaderMD.substring(3, tableHeaderMD.length - 3) + "\n|<wbr>";
568
+ pElement.outerHTML = vditor.lute.SpinVditorDOM(tableHeaderMD);
569
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
570
+ execAfterRender(vditor);
571
+ scrollCenter(vditor);
572
+ event.preventDefault();
573
+ return true;
574
+ }
575
+
576
+ // hr 渲染
577
+ if (isHrMD(pElement.innerHTML) && pElement.previousElementSibling) {
578
+ // 软换行后 hr 前有内容
579
+ let pInnerHTML = "";
580
+ const innerHTMLList = pElement.innerHTML.trimRight().split("\n");
581
+ if (innerHTMLList.length > 1) {
582
+ innerHTMLList.pop();
583
+ pInnerHTML = `<p data-block="0">${innerHTMLList.join("\n")}</p>`;
584
+ }
585
+
586
+ pElement.insertAdjacentHTML("afterend",
587
+ `${pInnerHTML}<hr data-block="0"><p data-block="0"><wbr>\n</p>`);
588
+ pElement.remove();
589
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
590
+ execAfterRender(vditor);
591
+ scrollCenter(vditor);
592
+ event.preventDefault();
593
+ return true;
594
+ }
595
+
596
+ if (isHeadingMD(pElement.innerHTML)) {
597
+ // heading 渲染
598
+ if (vditor.currentMode === "wysiwyg") {
599
+ pElement.outerHTML = vditor.lute.SpinVditorDOM(pElement.innerHTML + '<p data-block="0"><wbr>\n</p>');
600
+ } else {
601
+ pElement.outerHTML = vditor.lute.SpinVditorIRDOM(pElement.innerHTML + '<p data-block="0"><wbr>\n</p>');
602
+ }
603
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
604
+ execAfterRender(vditor);
605
+ scrollCenter(vditor);
606
+ event.preventDefault();
607
+ return true;
608
+ }
609
+ }
610
+
611
+ // 软换行会被切割 https://github.com/Vanessa219/vditor/issues/220
612
+ if (range.collapsed && pElement.previousElementSibling && event.key === "Backspace" &&
613
+ !isCtrl(event) && !event.altKey && !event.shiftKey &&
614
+ pElement.textContent.trimRight().split("\n").length > 1 &&
615
+ getSelectPosition(pElement, vditor[vditor.currentMode].element, range).start === 0) {
616
+ const lastElement = getLastNode(pElement.previousElementSibling) as HTMLElement;
617
+ if (!lastElement.textContent.endsWith("\n")) {
618
+ lastElement.textContent = lastElement.textContent + "\n";
619
+ }
620
+ lastElement.parentElement.insertAdjacentHTML("beforeend", `<wbr>${pElement.innerHTML}`);
621
+ pElement.remove();
622
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
623
+ return false;
624
+ }
625
+ return false;
626
+ };
627
+
628
+ export const insertRow = (vditor: IVditor, range: Range, cellElement: HTMLElement) => {
629
+ let rowHTML = "";
630
+ for (let m = 0; m < cellElement.parentElement.childElementCount; m++) {
631
+ rowHTML += `<td align="${cellElement.parentElement.children[m].getAttribute("align")}"> </td>`;
632
+ }
633
+ if (cellElement.tagName === "TH") {
634
+ cellElement.parentElement.parentElement.insertAdjacentHTML("afterend",
635
+ `<tbody><tr>${rowHTML}</tr></tbody>`);
636
+ } else {
637
+ cellElement.parentElement.insertAdjacentHTML("afterend", `<tr>${rowHTML}</tr>`);
638
+ }
639
+ execAfterRender(vditor);
640
+ };
641
+
642
+ export const insertRowAbove = (vditor: IVditor, range: Range, cellElement: HTMLElement) => {
643
+ let rowHTML = "";
644
+ for (let m = 0; m < cellElement.parentElement.childElementCount; m++) {
645
+ if (cellElement.tagName === "TH") {
646
+ rowHTML += `<th align="${cellElement.parentElement.children[m].getAttribute("align")}"> </th>`;
647
+ } else {
648
+ rowHTML += `<td align="${cellElement.parentElement.children[m].getAttribute("align")}"> </td>`;
649
+ }
650
+ }
651
+ if (cellElement.tagName === "TH") {
652
+ cellElement.parentElement.parentElement.insertAdjacentHTML("beforebegin", `<thead><tr>${rowHTML}</tr></thead>`);
653
+
654
+ range.insertNode(document.createElement("wbr"));
655
+ const theadHTML = cellElement.parentElement.innerHTML.replace(/<th>/g, "<td>").replace(/<\/th>/g, "</td>");
656
+ cellElement.parentElement.parentElement.nextElementSibling.insertAdjacentHTML("afterbegin", theadHTML);
657
+
658
+ cellElement.parentElement.parentElement.remove();
659
+ setRangeByWbr(vditor.ir.element, range);
660
+ } else {
661
+ cellElement.parentElement.insertAdjacentHTML("beforebegin", `<tr>${rowHTML}</tr>`);
662
+ }
663
+ execAfterRender(vditor);
664
+ };
665
+
666
+ export const insertColumn =
667
+ (vditor: IVditor, tableElement: HTMLTableElement, cellElement: HTMLElement, type: InsertPosition = "afterend") => {
668
+ let index = 0;
669
+ let previousElement = cellElement.previousElementSibling;
670
+ while (previousElement) {
671
+ index++;
672
+ previousElement = previousElement.previousElementSibling;
673
+ }
674
+ for (let i = 0; i < tableElement.rows.length; i++) {
675
+ if (i === 0) {
676
+ tableElement.rows[i].cells[index].insertAdjacentHTML(type, "<th> </th>");
677
+ } else {
678
+ tableElement.rows[i].cells[index].insertAdjacentHTML(type, "<td> </td>");
679
+ }
680
+ }
681
+ execAfterRender(vditor);
682
+ };
683
+ export const deleteRow = (vditor: IVditor, range: Range, cellElement: HTMLElement) => {
684
+ if (cellElement.tagName === "TD") {
685
+ const tbodyElement = cellElement.parentElement.parentElement;
686
+ if (cellElement.parentElement.previousElementSibling) {
687
+ range.selectNodeContents(cellElement.parentElement.previousElementSibling.lastElementChild);
688
+ } else {
689
+ range.selectNodeContents(tbodyElement.previousElementSibling.lastElementChild.lastElementChild);
690
+ }
691
+
692
+ if (tbodyElement.childElementCount === 1) {
693
+ tbodyElement.remove();
694
+ } else {
695
+ cellElement.parentElement.remove();
696
+ }
697
+
698
+ range.collapse(false);
699
+ setSelectionFocus(range);
700
+ execAfterRender(vditor);
701
+ }
702
+ };
703
+
704
+ export const deleteColumn =
705
+ (vditor: IVditor, range: Range, tableElement: HTMLTableElement, cellElement: HTMLElement) => {
706
+ let index = 0;
707
+ let previousElement = cellElement.previousElementSibling;
708
+ while (previousElement) {
709
+ index++;
710
+ previousElement = previousElement.previousElementSibling;
711
+ }
712
+ if (cellElement.previousElementSibling || cellElement.nextElementSibling) {
713
+ range.selectNodeContents(cellElement.previousElementSibling || cellElement.nextElementSibling);
714
+ range.collapse(true);
715
+ }
716
+ for (let i = 0; i < tableElement.rows.length; i++) {
717
+ const cells = tableElement.rows[i].cells;
718
+ if (cells.length === 1) {
719
+ tableElement.remove();
720
+ highlightToolbar(vditor);
721
+ break;
722
+ }
723
+ cells[index].remove();
724
+ }
725
+ setSelectionFocus(range);
726
+ execAfterRender(vditor);
727
+ };
728
+
729
+ export const fixTable = (vditor: IVditor, event: KeyboardEvent, range: Range) => {
730
+ const startContainer = range.startContainer;
731
+ const cellElement = hasClosestByMatchTag(startContainer, "TD") ||
732
+ hasClosestByMatchTag(startContainer, "TH");
733
+ if (cellElement) {
734
+ // 换行或软换行:在 cell 中添加 br
735
+ if (!isCtrl(event) && !event.altKey && event.key === "Enter") {
736
+ if (!cellElement.lastElementChild ||
737
+ (cellElement.lastElementChild && (!cellElement.lastElementChild.isSameNode(cellElement.lastChild) ||
738
+ cellElement.lastElementChild.tagName !== "BR"))) {
739
+ cellElement.insertAdjacentHTML("beforeend", "<br>");
740
+ }
741
+ const brElement = document.createElement("br");
742
+ range.insertNode(brElement);
743
+ range.setStartAfter(brElement);
744
+ execAfterRender(vditor);
745
+ scrollCenter(vditor);
746
+ event.preventDefault();
747
+ return true;
748
+ }
749
+
750
+ // tab:光标移向下一个 cell
751
+ if (event.key === "Tab") {
752
+ if (event.shiftKey) {
753
+ // shift + tab 光标移动到前一个 cell
754
+ goPreviousCell(cellElement, range);
755
+ event.preventDefault();
756
+ return true;
757
+ }
758
+
759
+ let nextElement = cellElement.nextElementSibling;
760
+ if (!nextElement) {
761
+ if (cellElement.parentElement.nextElementSibling) {
762
+ nextElement = cellElement.parentElement.nextElementSibling.firstElementChild;
763
+ } else if (cellElement.parentElement.parentElement.tagName === "THEAD" &&
764
+ cellElement.parentElement.parentElement.nextElementSibling) {
765
+ nextElement =
766
+ cellElement.parentElement.parentElement.nextElementSibling.firstElementChild.firstElementChild;
767
+ } else {
768
+ nextElement = null;
769
+ }
770
+ }
771
+ if (nextElement) {
772
+ range.selectNodeContents(nextElement);
773
+ setSelectionFocus(range);
774
+ }
775
+ event.preventDefault();
776
+ return true;
777
+ }
778
+
779
+ const tableElement = cellElement.parentElement.parentElement.parentElement as HTMLTableElement;
780
+ if (event.key === "ArrowUp") {
781
+ event.preventDefault();
782
+ if (cellElement.tagName === "TH") {
783
+ if (tableElement.previousElementSibling) {
784
+ range.selectNodeContents(tableElement.previousElementSibling);
785
+ range.collapse(false);
786
+ setSelectionFocus(range);
787
+ } else {
788
+ insertEmptyBlock(vditor, "beforebegin");
789
+ }
790
+ return true;
791
+ }
792
+
793
+ let m = 0;
794
+ const trElement = cellElement.parentElement as HTMLTableRowElement;
795
+ for (; m < trElement.cells.length; m++) {
796
+ if (trElement.cells[m].isSameNode(cellElement)) {
797
+ break;
798
+ }
799
+ }
800
+
801
+ let previousElement = trElement.previousElementSibling as HTMLTableRowElement;
802
+ if (!previousElement) {
803
+ previousElement = trElement.parentElement.previousElementSibling.firstChild as HTMLTableRowElement;
804
+ }
805
+ range.selectNodeContents(previousElement.cells[m]);
806
+ range.collapse(false);
807
+ setSelectionFocus(range);
808
+ return true;
809
+ }
810
+
811
+ if (event.key === "ArrowDown") {
812
+ event.preventDefault();
813
+ const trElement = cellElement.parentElement as HTMLTableRowElement;
814
+ if (!trElement.nextElementSibling && cellElement.tagName === "TD") {
815
+ if (tableElement.nextElementSibling) {
816
+ range.selectNodeContents(tableElement.nextElementSibling);
817
+ range.collapse(true);
818
+ setSelectionFocus(range);
819
+ } else {
820
+ insertEmptyBlock(vditor, "afterend");
821
+ }
822
+ return true;
823
+ }
824
+
825
+ let m = 0;
826
+ for (; m < trElement.cells.length; m++) {
827
+ if (trElement.cells[m].isSameNode(cellElement)) {
828
+ break;
829
+ }
830
+ }
831
+
832
+ let nextElement = trElement.nextElementSibling as HTMLTableRowElement;
833
+ if (!nextElement) {
834
+ nextElement = trElement.parentElement.nextElementSibling.firstChild as HTMLTableRowElement;
835
+ }
836
+ range.selectNodeContents(nextElement.cells[m]);
837
+ range.collapse(true);
838
+ setSelectionFocus(range);
839
+ return true;
840
+ }
841
+
842
+ // focus row input, only wysiwyg
843
+ if (vditor.currentMode === "wysiwyg" &&
844
+ !isCtrl(event) && event.key === "Enter" && !event.shiftKey && event.altKey) {
845
+ const inputElement = (vditor.wysiwyg.popover.querySelector(".vditor-input") as HTMLInputElement);
846
+ inputElement.focus();
847
+ inputElement.select();
848
+ event.preventDefault();
849
+ return true;
850
+ }
851
+
852
+ // Backspace:光标移动到前一个 cell
853
+ if (!isCtrl(event) && !event.shiftKey && !event.altKey && event.key === "Backspace"
854
+ && range.startOffset === 0 && range.toString() === "") {
855
+ const previousCellElement = goPreviousCell(cellElement, range, false);
856
+ if (!previousCellElement && tableElement) {
857
+ if (tableElement.textContent.trim() === "") {
858
+ tableElement.outerHTML = `<p data-block="0"><wbr>\n</p>`;
859
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
860
+ } else {
861
+ range.setStartBefore(tableElement);
862
+ range.collapse(true);
863
+ }
864
+ execAfterRender(vditor);
865
+ }
866
+ event.preventDefault();
867
+ return true;
868
+ }
869
+ // 上方新添加一行
870
+ if (matchHotKey("⇧⌘F", event)) {
871
+ insertRowAbove(vditor, range, cellElement);
872
+ event.preventDefault();
873
+ return true;
874
+ }
875
+
876
+ // 下方新添加一行 https://github.com/Vanessa219/vditor/issues/46
877
+ if (matchHotKey("⌘=", event)) {
878
+ insertRow(vditor, range, cellElement);
879
+ event.preventDefault();
880
+ return true;
881
+ }
882
+
883
+ // 左方新添加一列
884
+ if (matchHotKey("⇧⌘G", event)) {
885
+ insertColumn(vditor, tableElement, cellElement, "beforebegin");
886
+ event.preventDefault();
887
+ return true;
888
+ }
889
+
890
+ // 后方新添加一列
891
+ if (matchHotKey("⇧⌘=", event)) {
892
+ insertColumn(vditor, tableElement, cellElement);
893
+ event.preventDefault();
894
+ return true;
895
+ }
896
+
897
+ // 删除当前行
898
+ if (matchHotKey("⌘-", event)) {
899
+ deleteRow(vditor, range, cellElement);
900
+ event.preventDefault();
901
+ return true;
902
+ }
903
+
904
+ // 删除当前列
905
+ if (matchHotKey("⇧⌘-", event)) {
906
+ deleteColumn(vditor, range, tableElement, cellElement);
907
+ event.preventDefault();
908
+ return true;
909
+ }
910
+
911
+ // 剧左
912
+ if (matchHotKey("⇧⌘L", event)) {
913
+ if (vditor.currentMode === "ir") {
914
+ setTableAlign(tableElement, "left");
915
+ execAfterRender(vditor);
916
+ event.preventDefault();
917
+ return true;
918
+ } else {
919
+ const itemElement: HTMLElement = vditor.wysiwyg.popover.querySelector('[data-type="left"]');
920
+ if (itemElement) {
921
+ itemElement.click();
922
+ event.preventDefault();
923
+ return true;
924
+ }
925
+ }
926
+ }
927
+
928
+ // 剧中
929
+ if (matchHotKey("⇧⌘C", event)) {
930
+ if (vditor.currentMode === "ir") {
931
+ setTableAlign(tableElement, "center");
932
+ execAfterRender(vditor);
933
+ event.preventDefault();
934
+ return true;
935
+ } else {
936
+ const itemElement: HTMLElement = vditor.wysiwyg.popover.querySelector('[data-type="center"]');
937
+ if (itemElement) {
938
+ itemElement.click();
939
+ event.preventDefault();
940
+ return true;
941
+ }
942
+ }
943
+ }
944
+ // 剧右
945
+ if (matchHotKey("⇧⌘R", event)) {
946
+ if (vditor.currentMode === "ir") {
947
+ setTableAlign(tableElement, "right");
948
+ execAfterRender(vditor);
949
+ event.preventDefault();
950
+ return true;
951
+ } else {
952
+ const itemElement: HTMLElement = vditor.wysiwyg.popover.querySelector('[data-type="right"]');
953
+ if (itemElement) {
954
+ itemElement.click();
955
+ event.preventDefault();
956
+ return true;
957
+ }
958
+ }
959
+ }
960
+ }
961
+ return false;
962
+ };
963
+
964
+ export const fixCodeBlock = (vditor: IVditor, event: KeyboardEvent, codeRenderElement: HTMLElement, range: Range) => {
965
+ // 行级代码块中 command + a,近对当前代码块进行全选
966
+ if (codeRenderElement.tagName === "PRE" && matchHotKey("⌘A", event)) {
967
+ range.selectNodeContents(codeRenderElement.firstElementChild);
968
+ event.preventDefault();
969
+ return true;
970
+ }
971
+
972
+ // tab
973
+ // TODO shift + tab, shift and 选中文字
974
+ if (vditor.options.tab && event.key === "Tab" && !event.shiftKey && range.toString() === "") {
975
+ range.insertNode(document.createTextNode(vditor.options.tab));
976
+ range.collapse(false);
977
+ execAfterRender(vditor);
978
+ event.preventDefault();
979
+ return true;
980
+ }
981
+
982
+ // Backspace: 光标位于第零个字符,仅删除代码块标签
983
+ if (event.key === "Backspace" && !isCtrl(event) && !event.shiftKey && !event.altKey) {
984
+ const codePosition = getSelectPosition(codeRenderElement, vditor[vditor.currentMode].element, range);
985
+ if ((codePosition.start === 0 ||
986
+ (codePosition.start === 1 && codeRenderElement.innerText === "\n")) // 空代码块,光标在 \n 后
987
+ && range.toString() === "") {
988
+ codeRenderElement.parentElement.outerHTML =
989
+ `<p data-block="0"><wbr>${codeRenderElement.firstElementChild.innerHTML}</p>`;
990
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
991
+ execAfterRender(vditor);
992
+ event.preventDefault();
993
+ return true;
994
+ }
995
+ }
996
+
997
+ // 换行
998
+ if (!isCtrl(event) && !event.altKey && event.key === "Enter") {
999
+ if (!codeRenderElement.firstElementChild.textContent.endsWith("\n")) {
1000
+ codeRenderElement.firstElementChild.insertAdjacentText("beforeend", "\n");
1001
+ }
1002
+ range.extractContents();
1003
+ range.insertNode(document.createTextNode("\n"));
1004
+ range.collapse(false);
1005
+ setSelectionFocus(range);
1006
+ if (!isFirefox()) {
1007
+ if (vditor.currentMode === "wysiwyg") {
1008
+ input(vditor, range);
1009
+ } else {
1010
+ IRInput(vditor, range);
1011
+ }
1012
+ }
1013
+ scrollCenter(vditor);
1014
+ event.preventDefault();
1015
+ return true;
1016
+ }
1017
+ return false;
1018
+ };
1019
+
1020
+ export const fixBlockquote = (vditor: IVditor, range: Range, event: KeyboardEvent, pElement: HTMLElement | false) => {
1021
+ const startContainer = range.startContainer;
1022
+ const blockquoteElement = hasClosestByMatchTag(startContainer, "BLOCKQUOTE");
1023
+ if (blockquoteElement && range.toString() === "") {
1024
+ if (event.key === "Backspace" && !isCtrl(event) && !event.shiftKey && !event.altKey &&
1025
+ getSelectPosition(blockquoteElement, vditor[vditor.currentMode].element, range).start === 0) {
1026
+ // Backspace: 光标位于引用中的第零个字符,仅删除引用标签
1027
+ range.insertNode(document.createElement("wbr"));
1028
+ blockquoteElement.outerHTML = blockquoteElement.innerHTML;
1029
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1030
+ execAfterRender(vditor);
1031
+ event.preventDefault();
1032
+ return true;
1033
+ }
1034
+
1035
+ if (pElement && event.key === "Enter" && !isCtrl(event) && !event.shiftKey && !event.altKey
1036
+ && pElement.parentElement.tagName === "BLOCKQUOTE") {
1037
+ // Enter: 空行回车应逐层跳出
1038
+ let isEmpty = false;
1039
+ if (pElement.innerHTML.replace(Constants.ZWSP, "") === "\n" ||
1040
+ pElement.innerHTML.replace(Constants.ZWSP, "") === "") {
1041
+ // 空 P
1042
+ isEmpty = true;
1043
+ pElement.remove();
1044
+ } else if (pElement.innerHTML.endsWith("\n\n") &&
1045
+ getSelectPosition(pElement, vditor[vditor.currentMode].element, range).start ===
1046
+ pElement.textContent.length - 1) {
1047
+ // 软换行
1048
+ pElement.innerHTML = pElement.innerHTML.substr(0, pElement.innerHTML.length - 2);
1049
+ isEmpty = true;
1050
+ }
1051
+ if (isEmpty) {
1052
+ // 需添加零宽字符,否则的话无法记录 undo
1053
+ blockquoteElement.insertAdjacentHTML("afterend", `<p data-block="0">${Constants.ZWSP}<wbr>\n</p>`);
1054
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1055
+ execAfterRender(vditor);
1056
+ event.preventDefault();
1057
+ return true;
1058
+ }
1059
+ }
1060
+ const blockElement = hasClosestBlock(startContainer);
1061
+ if (vditor.currentMode === "wysiwyg" && blockElement && matchHotKey("⇧⌘;", event)) {
1062
+ // 插入 blockquote
1063
+ range.insertNode(document.createElement("wbr"));
1064
+ blockElement.outerHTML = `<blockquote data-block="0">${blockElement.outerHTML}</blockquote>`;
1065
+ setRangeByWbr(vditor.wysiwyg.element, range);
1066
+ afterRenderEvent(vditor);
1067
+ event.preventDefault();
1068
+ return true;
1069
+ }
1070
+
1071
+ if (insertAfterBlock(vditor, event, range, blockquoteElement, blockquoteElement)) {
1072
+ return true;
1073
+ }
1074
+ if (insertBeforeBlock(vditor, event, range, blockquoteElement, blockquoteElement)) {
1075
+ return true;
1076
+ }
1077
+ }
1078
+ return false;
1079
+ };
1080
+
1081
+ export const fixTask = (vditor: IVditor, range: Range, event: KeyboardEvent) => {
1082
+ const startContainer = range.startContainer;
1083
+ const taskItemElement = hasClosestByMatchTag(startContainer, "LI");
1084
+ if (taskItemElement && taskItemElement.classList.contains("vditor-task")) {
1085
+ if (matchHotKey("⇧⌘J", event)) {
1086
+ // ctrl + shift: toggle checked
1087
+ const inputElement = taskItemElement.firstElementChild as HTMLInputElement;
1088
+ if (inputElement.checked) {
1089
+ inputElement.removeAttribute("checked");
1090
+ } else {
1091
+ inputElement.setAttribute("checked", "checked");
1092
+ }
1093
+ execAfterRender(vditor);
1094
+ event.preventDefault();
1095
+ return true;
1096
+ }
1097
+
1098
+ // Backspace: 在选择框前进行删除
1099
+ if (event.key === "Backspace" && !isCtrl(event) && !event.shiftKey && !event.altKey && range.toString() === ""
1100
+ && range.startOffset === 1
1101
+ && ((startContainer.nodeType === 3 && startContainer.previousSibling &&
1102
+ (startContainer.previousSibling as HTMLElement).tagName === "INPUT")
1103
+ || startContainer.nodeType !== 3)) {
1104
+ const previousElement = taskItemElement.previousElementSibling;
1105
+ taskItemElement.querySelector("input").remove();
1106
+ if (previousElement) {
1107
+ const lastNode = getLastNode(previousElement);
1108
+ lastNode.parentElement.insertAdjacentHTML("beforeend", "<wbr>" + taskItemElement.innerHTML.trim());
1109
+ taskItemElement.remove();
1110
+ } else {
1111
+ taskItemElement.parentElement.insertAdjacentHTML("beforebegin",
1112
+ `<p data-block="0"><wbr>${taskItemElement.innerHTML.trim() || "\n"}</p>`);
1113
+ if (taskItemElement.nextElementSibling) {
1114
+ taskItemElement.remove();
1115
+ } else {
1116
+ taskItemElement.parentElement.remove();
1117
+ }
1118
+ }
1119
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1120
+ execAfterRender(vditor);
1121
+ event.preventDefault();
1122
+ return true;
1123
+ }
1124
+
1125
+ if (event.key === "Enter" && !isCtrl(event) && !event.shiftKey && !event.altKey) {
1126
+ if (taskItemElement.textContent.trim() === "") {
1127
+ // 当前任务列表无文字
1128
+ if (hasClosestByClassName(taskItemElement.parentElement, "vditor-task")) {
1129
+ // 为子元素时,需进行反向缩进
1130
+ const topListElement = getTopList(startContainer);
1131
+ if (topListElement) {
1132
+ listOutdent(vditor, taskItemElement, range, topListElement);
1133
+ }
1134
+ } else {
1135
+ // 仅有一级任务列表
1136
+ if (taskItemElement.nextElementSibling) {
1137
+ // 任务列表下方还有元素,需要使用用段落隔断
1138
+ let afterHTML = "";
1139
+ let beforeHTML = "";
1140
+ let isAfter = false;
1141
+ Array.from(taskItemElement.parentElement.children).forEach((taskItem) => {
1142
+ if (taskItemElement.isSameNode(taskItem)) {
1143
+ isAfter = true;
1144
+ } else {
1145
+ if (isAfter) {
1146
+ afterHTML += taskItem.outerHTML;
1147
+ } else {
1148
+ beforeHTML += taskItem.outerHTML;
1149
+ }
1150
+ }
1151
+ });
1152
+ const parentTagName = taskItemElement.parentElement.tagName;
1153
+ const dataMarker = taskItemElement.parentElement.tagName === "OL" ? "" : ` data-marker="${taskItemElement.parentElement.getAttribute("data-marker")}"`;
1154
+ let startAttribute = "";
1155
+ if (beforeHTML) {
1156
+ startAttribute = taskItemElement.parentElement.tagName === "UL" ? "" : ` start="1"`;
1157
+ beforeHTML = `<${parentTagName} data-tight="true"${dataMarker} data-block="0">${beforeHTML}</${parentTagName}>`;
1158
+ }
1159
+ // <p data-block="0">\n<wbr></p> => <p data-block="0"><wbr>\n</p>
1160
+ // https://github.com/Vanessa219/vditor/issues/430
1161
+ taskItemElement.parentElement.outerHTML = `${beforeHTML}<p data-block="0"><wbr>\n</p><${parentTagName}
1162
+ data-tight="true"${dataMarker} data-block="0"${startAttribute}>${afterHTML}</${parentTagName}>`;
1163
+ } else {
1164
+ // 任务列表下方无任务列表元素
1165
+ taskItemElement.parentElement.insertAdjacentHTML("afterend", `<p data-block="0"><wbr>\n</p>`);
1166
+ if (taskItemElement.parentElement.querySelectorAll("li").length === 1) {
1167
+ // 任务列表仅有一项时,使用 p 元素替换
1168
+ taskItemElement.parentElement.remove();
1169
+ } else {
1170
+ // 任务列表有多项时,当前任务列表位于最后一项,移除该任务列表
1171
+ taskItemElement.remove();
1172
+ }
1173
+ }
1174
+ }
1175
+ } else if (startContainer.nodeType !== 3 && range.startOffset === 0 &&
1176
+ (startContainer.firstChild as HTMLElement).tagName === "INPUT") {
1177
+ // 光标位于 input 之前
1178
+ range.setStart(startContainer.childNodes[1], 1);
1179
+ } else {
1180
+ // 当前任务列表有文字,光标后的文字需添加到新任务列表中
1181
+ range.setEndAfter(taskItemElement.lastChild);
1182
+ taskItemElement.insertAdjacentHTML("afterend", `<li class="vditor-task" data-marker="${taskItemElement.getAttribute("data-marker")}"><input type="checkbox"> <wbr></li>`);
1183
+ document.querySelector("wbr").after(range.extractContents());
1184
+ }
1185
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1186
+ execAfterRender(vditor);
1187
+ scrollCenter(vditor);
1188
+ event.preventDefault();
1189
+ return true;
1190
+ }
1191
+ }
1192
+ return false;
1193
+ };
1194
+
1195
+ export const fixDelete = (vditor: IVditor, range: Range, event: KeyboardEvent, pElement: HTMLElement | false) => {
1196
+ if (range.startContainer.nodeType !== 3) {
1197
+ // 光标位于 hr 前,hr 前有内容
1198
+ const rangeElement = (range.startContainer as HTMLElement).children[range.startOffset];
1199
+ if (rangeElement && rangeElement.tagName === "HR") {
1200
+ range.selectNodeContents(rangeElement.previousElementSibling);
1201
+ range.collapse(false);
1202
+ event.preventDefault();
1203
+ return true;
1204
+ }
1205
+ }
1206
+
1207
+ if (pElement) {
1208
+ const previousElement = pElement.previousElementSibling;
1209
+ if (previousElement && getSelectPosition(pElement, vditor[vditor.currentMode].element, range).start === 0 &&
1210
+ ((isFirefox() && previousElement.tagName === "HR") || previousElement.tagName === "TABLE")) {
1211
+ if (previousElement.tagName === "TABLE") {
1212
+ // table 后删除 https://github.com/Vanessa219/vditor/issues/243
1213
+ const lastCellElement = previousElement.lastElementChild.lastElementChild.lastElementChild;
1214
+ lastCellElement.innerHTML =
1215
+ lastCellElement.innerHTML.trimLeft() + "<wbr>" + pElement.textContent.trim();
1216
+ pElement.remove();
1217
+ } else {
1218
+ // 光标位于 hr 后进行删除
1219
+ previousElement.remove();
1220
+ }
1221
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1222
+ execAfterRender(vditor);
1223
+ event.preventDefault();
1224
+ return true;
1225
+ }
1226
+ }
1227
+ return false;
1228
+ };
1229
+
1230
+ export const fixHR = (range: Range) => {
1231
+ if (isFirefox() && range.startContainer.nodeType !== 3 &&
1232
+ (range.startContainer as HTMLElement).tagName === "HR") {
1233
+ range.setStartBefore(range.startContainer);
1234
+ }
1235
+ };
1236
+
1237
+ // firefox https://github.com/Vanessa219/vditor/issues/407
1238
+ export const fixFirefoxArrowUpTable = (event: KeyboardEvent, blockElement: false | HTMLElement, range: Range) => {
1239
+ if (!isFirefox()) {
1240
+ return false;
1241
+ }
1242
+ if (event.key === "ArrowUp" && blockElement && blockElement.previousElementSibling?.tagName === "TABLE") {
1243
+ const tableElement = blockElement.previousElementSibling as HTMLTableElement;
1244
+ range.selectNodeContents(tableElement.rows[tableElement.rows.length - 1].lastElementChild);
1245
+ range.collapse(false);
1246
+ event.preventDefault();
1247
+ return true;
1248
+ }
1249
+ if (event.key === "ArrowDown" && blockElement && blockElement.nextElementSibling?.tagName === "TABLE") {
1250
+ range.selectNodeContents((blockElement.nextElementSibling as HTMLTableElement).rows[0].cells[0]);
1251
+ range.collapse(true);
1252
+ event.preventDefault();
1253
+ return true;
1254
+ }
1255
+ return false;
1256
+ };
1257
+
1258
+ export const paste = async (vditor: IVditor, event: (ClipboardEvent | DragEvent) & {target: HTMLElement}, callback: {
1259
+ pasteCode(code: string): void,
1260
+ }) => {
1261
+ if (vditor[vditor.currentMode].element.getAttribute("contenteditable") !== "true") {
1262
+ return;
1263
+ }
1264
+ event.stopPropagation();
1265
+ event.preventDefault();
1266
+ let textHTML;
1267
+ let textPlain;
1268
+ let files;
1269
+
1270
+ if ("clipboardData" in event) {
1271
+ textHTML = event.clipboardData.getData("text/html");
1272
+ textPlain = event.clipboardData.getData("text/plain");
1273
+ files = event.clipboardData.files;
1274
+ } else {
1275
+ textHTML = event.dataTransfer.getData("text/html");
1276
+ textPlain = event.dataTransfer.getData("text/plain");
1277
+ if (event.dataTransfer.types.includes("Files")) {
1278
+ files = event.dataTransfer.items;
1279
+ }
1280
+ }
1281
+ const renderers: {
1282
+ HTML2VditorDOM?: ILuteRender,
1283
+ HTML2VditorIRDOM?: ILuteRender,
1284
+ Md2VditorDOM?: ILuteRender,
1285
+ Md2VditorIRDOM?: ILuteRender,
1286
+ Md2VditorSVDOM?: ILuteRender,
1287
+ } = {};
1288
+ const renderLinkDest: ILuteRenderCallback = (node, entering) => {
1289
+ if (!entering) {
1290
+ return ["", Lute.WalkContinue];
1291
+ }
1292
+
1293
+ if (vditor.options.upload.renderLinkDest) {
1294
+ return vditor.options.upload.renderLinkDest(vditor, node, entering);
1295
+ }
1296
+
1297
+ const src = node.TokensStr();
1298
+ if (node.__internal_object__.Parent.Type === 34 && src && src.indexOf("file://") === -1 &&
1299
+ vditor.options.upload.linkToImgUrl) {
1300
+ const xhr = new XMLHttpRequest();
1301
+ xhr.open("POST", vditor.options.upload.linkToImgUrl);
1302
+ if (vditor.options.upload.token) {
1303
+ xhr.setRequestHeader("X-Upload-Token", vditor.options.upload.token);
1304
+ }
1305
+ if (vditor.options.upload.withCredentials) {
1306
+ xhr.withCredentials = true;
1307
+ }
1308
+ setHeaders(vditor, xhr);
1309
+ xhr.setRequestHeader("Content-Type", "application/json; charset=utf-8");
1310
+ xhr.onreadystatechange = () => {
1311
+ if (xhr.readyState === XMLHttpRequest.DONE) {
1312
+ if (xhr.status === 200) {
1313
+ let responseText = xhr.responseText;
1314
+ if (vditor.options.upload.linkToImgFormat) {
1315
+ responseText = vditor.options.upload.linkToImgFormat(xhr.responseText);
1316
+ }
1317
+ const responseJSON = JSON.parse(responseText);
1318
+ if (responseJSON.code !== 0) {
1319
+ vditor.tip.show(responseJSON.msg);
1320
+ return;
1321
+ }
1322
+ const original = responseJSON.data.originalURL;
1323
+ if (vditor.currentMode === "sv") {
1324
+ vditor.sv.element.querySelectorAll(".vditor-sv__marker--link")
1325
+ .forEach((item: HTMLElement) => {
1326
+ if (item.textContent === original) {
1327
+ item.textContent = responseJSON.data.url;
1328
+ }
1329
+ });
1330
+ } else {
1331
+ const imgElement: HTMLImageElement =
1332
+ vditor[vditor.currentMode].element.querySelector(`img[src="${original}"]`);
1333
+ imgElement.src = responseJSON.data.url;
1334
+ if (vditor.currentMode === "ir") {
1335
+ imgElement.previousElementSibling.previousElementSibling.innerHTML =
1336
+ responseJSON.data.url;
1337
+ }
1338
+ }
1339
+ execAfterRender(vditor);
1340
+ } else {
1341
+ vditor.tip.show(xhr.responseText);
1342
+ }
1343
+ if (vditor.options.upload.linkToImgCallback) {
1344
+ vditor.options.upload.linkToImgCallback(xhr.responseText);
1345
+ }
1346
+ }
1347
+ };
1348
+ xhr.send(JSON.stringify({url: src}));
1349
+ }
1350
+ if (vditor.currentMode === "ir") {
1351
+ return [`<span class="vditor-ir__marker vditor-ir__marker--link">${Lute.EscapeHTMLStr(src)}</span>`, Lute.WalkContinue];
1352
+ } else if (vditor.currentMode === "wysiwyg") {
1353
+ return ["", Lute.WalkContinue];
1354
+ } else {
1355
+ return [`<span class="vditor-sv__marker--link">${Lute.EscapeHTMLStr(src)}</span>`, Lute.WalkContinue];
1356
+ }
1357
+ };
1358
+
1359
+ // 浏览器地址栏拷贝处理
1360
+ if (textHTML.replace(/&amp;/g, "&").replace(/<(|\/)(html|body|meta)[^>]*?>/ig, "").trim() ===
1361
+ `<a href="${textPlain}">${textPlain}</a>` ||
1362
+ textHTML.replace(/&amp;/g, "&").replace(/<(|\/)(html|body|meta)[^>]*?>/ig, "").trim() ===
1363
+ `<!--StartFragment--><a href="${textPlain}">${textPlain}</a><!--EndFragment-->`) {
1364
+ textHTML = "";
1365
+ }
1366
+
1367
+ // process word
1368
+ const doc = new DOMParser().parseFromString(textHTML, "text/html");
1369
+ if (doc.body) {
1370
+ textHTML = doc.body.innerHTML;
1371
+ }
1372
+ textHTML = Lute.Sanitize(textHTML);
1373
+ vditor.wysiwyg.getComments(vditor);
1374
+
1375
+ // process code
1376
+ const height = vditor[vditor.currentMode].element.scrollHeight;
1377
+ const code = processPasteCode(textHTML, textPlain, vditor.currentMode);
1378
+ const codeElement = vditor.currentMode === "sv" ?
1379
+ hasClosestByAttribute(event.target, "data-type", "code-block") :
1380
+ hasClosestByMatchTag(event.target, "CODE");
1381
+ if (codeElement) {
1382
+ // 粘贴在代码位置
1383
+ if (vditor.currentMode === "sv") {
1384
+ document.execCommand("insertHTML", false, textPlain.replace(/&/g, "&amp;").replace(/</g, "&lt;"));
1385
+ } else {
1386
+ const position = getSelectPosition(event.target, vditor[vditor.currentMode].element);
1387
+ if (codeElement.parentElement.tagName !== "PRE") {
1388
+ // https://github.com/Vanessa219/vditor/issues/463
1389
+ textPlain += Constants.ZWSP;
1390
+ }
1391
+ codeElement.textContent = codeElement.textContent.substring(0, position.start)
1392
+ + textPlain + codeElement.textContent.substring(position.end);
1393
+ setSelectionByPosition(position.start + textPlain.length, position.start + textPlain.length,
1394
+ codeElement.parentElement);
1395
+ if (codeElement.parentElement?.nextElementSibling.classList
1396
+ .contains(`vditor-${vditor.currentMode}__preview`)) {
1397
+ codeElement.parentElement.nextElementSibling.innerHTML = codeElement.outerHTML;
1398
+ processCodeRender(codeElement.parentElement.nextElementSibling as HTMLElement, vditor);
1399
+ }
1400
+ }
1401
+ } else if (code) {
1402
+ callback.pasteCode(code);
1403
+ } else {
1404
+ if (textHTML.trim() !== "") {
1405
+ const tempElement = document.createElement("div");
1406
+ tempElement.innerHTML = textHTML;
1407
+ if (!vditor.options.upload.base64ToLink) {
1408
+ // word 复制的图文混合,替换为 link: <v:imagedata src="file:///C:/Users/ADMINI~1/AppData/Local/Temp/msohtmlclip1/01/clip_image001.png" o:title="">
1409
+ await processVMLImage(vditor, tempElement, ("clipboardData" in event ? event.clipboardData : event.dataTransfer).getData("text/rtf"));
1410
+ }
1411
+
1412
+ tempElement.querySelectorAll("[style]").forEach((e) => {
1413
+ e.removeAttribute("style");
1414
+ });
1415
+ tempElement.querySelectorAll(".vditor-copy").forEach((e) => {
1416
+ e.remove();
1417
+ });
1418
+ if (vditor.currentMode === "ir") {
1419
+ renderers.HTML2VditorIRDOM = {renderLinkDest};
1420
+ vditor.lute.SetJSRenderers({renderers});
1421
+ insertHTML(vditor.lute.HTML2VditorIRDOM(tempElement.innerHTML), vditor);
1422
+ } else if (vditor.currentMode === "wysiwyg") {
1423
+ renderers.HTML2VditorDOM = {renderLinkDest};
1424
+ vditor.lute.SetJSRenderers({renderers});
1425
+ insertHTML(vditor.lute.HTML2VditorDOM(tempElement.innerHTML), vditor);
1426
+ } else {
1427
+ renderers.Md2VditorSVDOM = {renderLinkDest};
1428
+ vditor.lute.SetJSRenderers({renderers});
1429
+ processPaste(vditor, vditor.lute.HTML2Md(tempElement.innerHTML).trimRight());
1430
+ }
1431
+ vditor.outline.render(vditor);
1432
+ } else if (files.length > 0) {
1433
+ if (vditor.options.upload.url || vditor.options.upload.handler) {
1434
+ await uploadFiles(vditor, files);
1435
+ } else {
1436
+ const fileReader = new FileReader();
1437
+ let file: File;
1438
+ if ("clipboardData" in event) {
1439
+ files = event.clipboardData.files;
1440
+ file = files[0];
1441
+ } else if (event.dataTransfer.types.includes("Files")) {
1442
+ files = event.dataTransfer.items;
1443
+ file = files[0].getAsFile();
1444
+ }
1445
+ if (file && file.type.startsWith("image")) {
1446
+ fileReader.readAsDataURL(file);
1447
+ fileReader.onload = () => {
1448
+ let imgHTML = "";
1449
+ if (vditor.currentMode === "wysiwyg") {
1450
+ imgHTML += `<img alt="${file.name}" src="${fileReader.result.toString()}">\n`;
1451
+ } else {
1452
+ imgHTML += `![${file.name}](${fileReader.result.toString()})\n`;
1453
+ }
1454
+ document.execCommand("insertHTML", false, imgHTML);
1455
+ };
1456
+ }
1457
+ }
1458
+ } else if (textPlain.trim() !== "" && files.length === 0) {
1459
+ const range = getEditorRange(vditor);
1460
+ if (range.toString() !== "" && vditor.lute.IsValidLinkDest(textPlain)) {
1461
+ textPlain = `[${range.toString()}](${textPlain})`;
1462
+ }
1463
+ if (vditor.currentMode === "ir") {
1464
+ renderers.Md2VditorIRDOM = {renderLinkDest};
1465
+ vditor.lute.SetJSRenderers({renderers});
1466
+ insertHTML(Lute.Sanitize(vditor.lute.Md2VditorIRDOM(textPlain)), vditor);
1467
+ } else if (vditor.currentMode === "wysiwyg") {
1468
+ renderers.Md2VditorDOM = {renderLinkDest};
1469
+ vditor.lute.SetJSRenderers({renderers});
1470
+ insertHTML(Lute.Sanitize(vditor.lute.Md2VditorDOM(textPlain)), vditor);
1471
+ } else {
1472
+ renderers.Md2VditorSVDOM = {renderLinkDest};
1473
+ vditor.lute.SetJSRenderers({renderers});
1474
+ processPaste(vditor, textPlain);
1475
+ }
1476
+ vditor.outline.render(vditor);
1477
+ }
1478
+ }
1479
+ if (vditor.currentMode !== "sv") {
1480
+ const blockElement = hasClosestBlock(getEditorRange(vditor).startContainer);
1481
+ if (blockElement) {
1482
+ // https://github.com/Vanessa219/vditor/issues/591
1483
+ const range = getEditorRange(vditor);
1484
+ vditor[vditor.currentMode].element.querySelectorAll("wbr").forEach((wbr) => {
1485
+ wbr.remove();
1486
+ });
1487
+ range.insertNode(document.createElement("wbr"));
1488
+ if (vditor.currentMode === "wysiwyg") {
1489
+ blockElement.outerHTML = vditor.lute.SpinVditorDOM(blockElement.outerHTML);
1490
+ } else {
1491
+ blockElement.outerHTML = vditor.lute.SpinVditorIRDOM(blockElement.outerHTML);
1492
+ }
1493
+ setRangeByWbr(vditor[vditor.currentMode].element, range);
1494
+ }
1495
+ vditor[vditor.currentMode].element.querySelectorAll(`.vditor-${vditor.currentMode}__preview[data-render='2']`)
1496
+ .forEach((item: HTMLElement) => {
1497
+ processCodeRender(item, vditor);
1498
+ });
1499
+ }
1500
+ vditor.wysiwyg.triggerRemoveComment(vditor);
1501
+ execAfterRender(vditor);
1502
+ if (vditor[vditor.currentMode].element.scrollHeight - height >
1503
+ Math.min(vditor[vditor.currentMode].element.clientHeight, window.innerHeight) / 2) {
1504
+ scrollCenter(vditor);
1505
+ }
1506
+ };
1507
+
1508
+ const processVMLImage = async (vditor: IVditor, root: Element, rtfData: string) => {
1509
+ if (!rtfData) {
1510
+ return;
1511
+
1512
+ }
1513
+
1514
+ const regexPictureHeader = /{\\pict[\s\S]+?\\bliptag-?\d+(\\blipupi-?\d+)?({\\\*\\blipuid\s?[\da-fA-F]+)?[\s}]*?/;
1515
+ const regexPicture = new RegExp("(?:(" + regexPictureHeader.source + "))([\\da-fA-F\\s]+)\\}", "g");
1516
+ const regImages = rtfData.match(regexPicture);
1517
+ const images = [];
1518
+ if (regImages) {
1519
+ for (const image of regImages) {
1520
+ let imageType;
1521
+
1522
+ if (image.includes("\\pngblip")) {
1523
+ imageType = "image/png";
1524
+ } else if (image.includes("\\jpegblip")) {
1525
+ imageType = "image/jpeg";
1526
+ }
1527
+
1528
+ if (imageType) {
1529
+ images.push({
1530
+ hex: image.replace(regexPictureHeader, "").replace(/[^\da-fA-F]/g, ""),
1531
+ type: imageType,
1532
+ });
1533
+ }
1534
+ }
1535
+ }
1536
+
1537
+ const shapes: Array<{shape: Element, img: Element}> = [];
1538
+ walk(root, (child: Element) => {
1539
+ if (child.tagName === "V:SHAPE") {
1540
+ walk(child, (sub) => {
1541
+ if (sub.tagName === "V:IMAGEDATA") shapes.push({shape: child, img: sub});
1542
+ });
1543
+ return false;
1544
+ }
1545
+ });
1546
+ for (let i = 0; i < shapes.length; i++) {
1547
+ const img = document.createElement("img");
1548
+ const newSrc = "data:" + images[i].type + ";base64," + btoa((images[i].hex.match(/\w{2}/g) || []).map(char => {
1549
+ return String.fromCharCode(parseInt(char, 16));
1550
+ }).join(""));
1551
+ img.src = newSrc;
1552
+ img.title = shapes[i].img.getAttribute("title");
1553
+ shapes[i].shape.parentNode.replaceChild(img, shapes[i].shape);
1554
+ }
1555
+
1556
+ const imgs = root.querySelectorAll("img");
1557
+ for (let i = 0; i < imgs.length; i++) {
1558
+ const src = imgs[i].src || "";
1559
+ if (src) imgs[i].src = await vditor.options.upload.base64ToLink(src);
1560
+ }
1561
+ };
1562
+
1563
+ const walk = (el: Element, fn: (el: Element) => boolean | void) => {
1564
+ const goNext = fn(el);
1565
+ if (goNext !== false)
1566
+ for (let i = 0; i < el.children.length; i++) {
1567
+ walk(el.children[i], fn);
1568
+ }
1569
+ };