@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,1156 @@
1
+ import {Constants} from "../constants";
2
+ import {disableToolbar} from "../toolbar/setToolbar";
3
+ import {enableToolbar} from "../toolbar/setToolbar";
4
+ import {removeCurrentToolbar} from "../toolbar/setToolbar";
5
+ import {setCurrentToolbar} from "../toolbar/setToolbar";
6
+ import {isCtrl, updateHotkeyTip} from "../util/compatibility";
7
+ import {scrollCenter} from "../util/editorCommonEvent";
8
+ import {
9
+ deleteColumn,
10
+ deleteRow,
11
+ insertColumn,
12
+ insertRow,
13
+ insertRowAbove,
14
+ setTableAlign,
15
+ } from "../util/fixBrowserBehavior";
16
+ import {
17
+ hasClosestByAttribute,
18
+ hasClosestByClassName,
19
+ hasClosestByMatchTag,
20
+ } from "../util/hasClosest";
21
+ import {
22
+ hasClosestByHeadings,
23
+ hasClosestByTag,
24
+ } from "../util/hasClosestByHeadings";
25
+ import {processCodeRender} from "../util/processCode";
26
+ import {
27
+ getEditorRange,
28
+ selectIsEditor,
29
+ setRangeByWbr,
30
+ setSelectionFocus,
31
+ } from "../util/selection";
32
+ import {afterRenderEvent} from "./afterRenderEvent";
33
+ import {removeBlockElement} from "./processKeydown";
34
+ import {renderToc} from "../util/toc";
35
+ import {getMarkdown} from "../markdown/getMarkdown";
36
+
37
+ export const highlightToolbarWYSIWYG = (vditor: IVditor) => {
38
+ clearTimeout(vditor.wysiwyg.hlToolbarTimeoutId);
39
+ vditor.wysiwyg.hlToolbarTimeoutId = window.setTimeout(() => {
40
+ if (
41
+ vditor.wysiwyg.element.getAttribute("contenteditable") === "false"
42
+ ) {
43
+ return;
44
+ }
45
+ if (!selectIsEditor(vditor.wysiwyg.element)) {
46
+ return;
47
+ }
48
+
49
+ removeCurrentToolbar(vditor.toolbar.elements, Constants.EDIT_TOOLBARS);
50
+ enableToolbar(vditor.toolbar.elements, Constants.EDIT_TOOLBARS);
51
+
52
+ const range = getSelection().getRangeAt(0);
53
+ let typeElement = range.startContainer as HTMLElement;
54
+ if (range.startContainer.nodeType === 3) {
55
+ typeElement = range.startContainer.parentElement;
56
+ } else {
57
+ typeElement = typeElement.childNodes[
58
+ range.startOffset >= typeElement.childNodes.length
59
+ ? typeElement.childNodes.length - 1
60
+ : range.startOffset
61
+ ] as HTMLElement;
62
+ }
63
+
64
+ const footnotesElement = hasClosestByAttribute(typeElement, "data-type", "footnotes-block");
65
+ if (footnotesElement) {
66
+ vditor.wysiwyg.popover.innerHTML = "";
67
+ genClose(footnotesElement, vditor);
68
+ customWysiwygToolbar(vditor, "footnotes-block")
69
+ setPopoverPosition(vditor, footnotesElement);
70
+ return;
71
+ }
72
+
73
+ // 工具栏高亮和禁用
74
+ const liElement = hasClosestByMatchTag(typeElement, "LI");
75
+ if (liElement) {
76
+ if (liElement.classList.contains("vditor-task")) {
77
+ setCurrentToolbar(vditor.toolbar.elements, ["check"]);
78
+ } else if (liElement.parentElement.tagName === "OL") {
79
+ setCurrentToolbar(vditor.toolbar.elements, ["ordered-list"]);
80
+ } else if (liElement.parentElement.tagName === "UL") {
81
+ setCurrentToolbar(vditor.toolbar.elements, ["list"]);
82
+ }
83
+ enableToolbar(vditor.toolbar.elements, ["outdent", "indent"]);
84
+ } else {
85
+ disableToolbar(vditor.toolbar.elements, ["outdent", "indent"]);
86
+ }
87
+
88
+ if (hasClosestByMatchTag(typeElement, "BLOCKQUOTE")) {
89
+ setCurrentToolbar(vditor.toolbar.elements, ["quote"]);
90
+ }
91
+
92
+ if (
93
+ hasClosestByMatchTag(typeElement, "B") ||
94
+ hasClosestByMatchTag(typeElement, "STRONG")
95
+ ) {
96
+ setCurrentToolbar(vditor.toolbar.elements, ["bold"]);
97
+ }
98
+
99
+ if (
100
+ hasClosestByMatchTag(typeElement, "I") ||
101
+ hasClosestByMatchTag(typeElement, "EM")
102
+ ) {
103
+ setCurrentToolbar(vditor.toolbar.elements, ["italic"]);
104
+ }
105
+
106
+ if (
107
+ hasClosestByMatchTag(typeElement, "STRIKE") ||
108
+ hasClosestByMatchTag(typeElement, "S")
109
+ ) {
110
+ setCurrentToolbar(vditor.toolbar.elements, ["strike"]);
111
+ }
112
+
113
+ // comments
114
+ vditor.wysiwyg.element
115
+ .querySelectorAll(".vditor-comment--focus")
116
+ .forEach((item) => {
117
+ item.classList.remove("vditor-comment--focus");
118
+ });
119
+ const commentElement = hasClosestByClassName(typeElement, "vditor-comment");
120
+ if (commentElement) {
121
+ let ids = commentElement.getAttribute("data-cmtids").split(" ");
122
+ if (ids.length > 1 && commentElement.nextSibling.isSameNode(commentElement.nextElementSibling)) {
123
+ const nextIds = commentElement.nextElementSibling
124
+ .getAttribute("data-cmtids")
125
+ .split(" ");
126
+ ids.find((id) => {
127
+ if (nextIds.includes(id)) {
128
+ ids = [id];
129
+ return true;
130
+ }
131
+ });
132
+ }
133
+ vditor.wysiwyg.element
134
+ .querySelectorAll(".vditor-comment")
135
+ .forEach((item) => {
136
+ if (item.getAttribute("data-cmtids").indexOf(ids[0]) > -1) {
137
+ item.classList.add("vditor-comment--focus");
138
+ }
139
+ });
140
+ }
141
+
142
+ const aElement = hasClosestByMatchTag(typeElement, "A");
143
+ if (aElement) {
144
+ setCurrentToolbar(vditor.toolbar.elements, ["link"]);
145
+ }
146
+ const tableElement = hasClosestByMatchTag(typeElement, "TABLE") as HTMLTableElement;
147
+ const headingElement = hasClosestByHeadings(typeElement) as HTMLElement;
148
+ if (hasClosestByMatchTag(typeElement, "CODE")) {
149
+ if (hasClosestByMatchTag(typeElement, "PRE")) {
150
+ disableToolbar(vditor.toolbar.elements, [
151
+ "headings",
152
+ "bold",
153
+ "italic",
154
+ "strike",
155
+ "line",
156
+ "quote",
157
+ "list",
158
+ "ordered-list",
159
+ "check",
160
+ "code",
161
+ "inline-code",
162
+ "upload",
163
+ "link",
164
+ "table",
165
+ "record",
166
+ ]);
167
+ setCurrentToolbar(vditor.toolbar.elements, ["code"]);
168
+ } else {
169
+ disableToolbar(vditor.toolbar.elements, [
170
+ "headings",
171
+ "bold",
172
+ "italic",
173
+ "strike",
174
+ "line",
175
+ "quote",
176
+ "list",
177
+ "ordered-list",
178
+ "check",
179
+ "code",
180
+ "upload",
181
+ "link",
182
+ "table",
183
+ "record",
184
+ ]);
185
+ setCurrentToolbar(vditor.toolbar.elements, ["inline-code"]);
186
+ }
187
+ } else if (headingElement) {
188
+ disableToolbar(vditor.toolbar.elements, ["bold"]);
189
+ setCurrentToolbar(vditor.toolbar.elements, ["headings"]);
190
+ } else if (tableElement) {
191
+ disableToolbar(vditor.toolbar.elements, ["table"]);
192
+ }
193
+
194
+ // toc popover
195
+ const tocElement = hasClosestByClassName(typeElement, "vditor-toc") as HTMLElement;
196
+ if (tocElement) {
197
+ vditor.wysiwyg.popover.innerHTML = "";
198
+ genClose(tocElement, vditor);
199
+ customWysiwygToolbar(vditor, "vditor-toc")
200
+ setPopoverPosition(vditor, tocElement);
201
+ return;
202
+ }
203
+
204
+ // quote popover
205
+ const blockquoteElement = hasClosestByTag(typeElement, "BLOCKQUOTE") as HTMLTableElement;
206
+ if (blockquoteElement) {
207
+ vditor.wysiwyg.popover.innerHTML = "";
208
+ genUp(range, blockquoteElement, vditor);
209
+ genDown(range, blockquoteElement, vditor);
210
+ genClose(blockquoteElement, vditor);
211
+ customWysiwygToolbar(vditor, "blockquote")
212
+ setPopoverPosition(vditor, blockquoteElement);
213
+ }
214
+
215
+ // list item popover
216
+ if (liElement) {
217
+ vditor.wysiwyg.popover.innerHTML = "";
218
+
219
+ genUp(range, liElement, vditor);
220
+ genDown(range, liElement, vditor);
221
+ genClose(liElement, vditor);
222
+ customWysiwygToolbar(vditor, "li")
223
+ setPopoverPosition(vditor, liElement);
224
+ }
225
+
226
+ // table popover
227
+ if (tableElement) {
228
+ const lang: keyof II18n | "" = vditor.options.lang;
229
+ const options: IOptions = vditor.options;
230
+ vditor.wysiwyg.popover.innerHTML = "";
231
+ const updateTable = () => {
232
+ const oldRow = tableElement.rows.length;
233
+ const oldColumn = tableElement.rows[0].cells.length;
234
+ const row = parseInt(input.value, 10) || oldRow;
235
+ const column = parseInt(input2.value, 10) || oldColumn;
236
+
237
+ if (row === oldRow && oldColumn === column) {
238
+ return;
239
+ }
240
+
241
+ if (oldColumn !== column) {
242
+ const columnDiff = column - oldColumn;
243
+ for (let i = 0; i < tableElement.rows.length; i++) {
244
+ if (columnDiff > 0) {
245
+ for (let j = 0; j < columnDiff; j++) {
246
+ if (i === 0) {
247
+ tableElement.rows[i].lastElementChild.insertAdjacentHTML("afterend", "<th> </th>");
248
+ } else {
249
+ tableElement.rows[i].lastElementChild.insertAdjacentHTML("afterend", "<td> </td>");
250
+ }
251
+ }
252
+ } else {
253
+ for (let k = oldColumn - 1; k >= column; k--) {
254
+ tableElement.rows[i].cells[k].remove();
255
+ }
256
+ }
257
+ }
258
+ }
259
+
260
+ if (oldRow !== row) {
261
+ const rowDiff = row - oldRow;
262
+ if (rowDiff > 0) {
263
+ let rowHTML = "<tr>";
264
+ for (let m = 0; m < column; m++) {
265
+ rowHTML += "<td> </td>";
266
+ }
267
+ for (let l = 0; l < rowDiff; l++) {
268
+ if (tableElement.querySelector("tbody")) {
269
+ tableElement
270
+ .querySelector("tbody")
271
+ .insertAdjacentHTML("beforeend", rowHTML);
272
+ } else {
273
+ tableElement
274
+ .querySelector("thead")
275
+ .insertAdjacentHTML("afterend", rowHTML + "</tr>");
276
+ }
277
+ }
278
+ } else {
279
+ for (let m = oldRow - 1; m >= row; m--) {
280
+ tableElement.rows[m].remove();
281
+ if (tableElement.rows.length === 1) {
282
+ tableElement.querySelector("tbody").remove();
283
+ }
284
+ }
285
+ }
286
+ }
287
+ if (typeof vditor.options.input === "function") {
288
+ vditor.options.input(getMarkdown(vditor));
289
+ }
290
+ };
291
+
292
+ const setAlign = (type: string) => {
293
+ setTableAlign(tableElement, type);
294
+ if (type === "right") {
295
+ left.classList.remove("vditor-icon--current");
296
+ center.classList.remove("vditor-icon--current");
297
+ right.classList.add("vditor-icon--current");
298
+ } else if (type === "center") {
299
+ left.classList.remove("vditor-icon--current");
300
+ right.classList.remove("vditor-icon--current");
301
+ center.classList.add("vditor-icon--current");
302
+ } else {
303
+ center.classList.remove("vditor-icon--current");
304
+ right.classList.remove("vditor-icon--current");
305
+ left.classList.add("vditor-icon--current");
306
+ }
307
+ setSelectionFocus(range);
308
+ afterRenderEvent(vditor);
309
+ };
310
+
311
+ const td = hasClosestByMatchTag(typeElement, "TD");
312
+ const th = hasClosestByMatchTag(typeElement, "TH");
313
+ let alignType = "left";
314
+ if (td) {
315
+ alignType = td.getAttribute("align") || "left";
316
+ } else if (th) {
317
+ alignType = th.getAttribute("align") || "center";
318
+ }
319
+
320
+ const left = document.createElement("button");
321
+ left.setAttribute("type", "button");
322
+ left.setAttribute("aria-label", window.VditorI18n.alignLeft + "<" + updateHotkeyTip("⇧⌘L") + ">");
323
+ left.setAttribute("data-type", "left");
324
+ left.innerHTML =
325
+ '<svg><use xlink:href="#vditor-icon-align-left"></use></svg>';
326
+ left.className =
327
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n" +
328
+ (alignType === "left" ? " vditor-icon--current" : "");
329
+ left.onclick = () => {
330
+ setAlign("left");
331
+ };
332
+
333
+ const center = document.createElement("button");
334
+ center.setAttribute("type", "button");
335
+ center.setAttribute("aria-label", window.VditorI18n.alignCenter + "<" + updateHotkeyTip("⇧⌘C") + ">");
336
+ center.setAttribute("data-type", "center");
337
+ center.innerHTML =
338
+ '<svg><use xlink:href="#vditor-icon-align-center"></use></svg>';
339
+ center.className =
340
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n" +
341
+ (alignType === "center" ? " vditor-icon--current" : "");
342
+ center.onclick = () => {
343
+ setAlign("center");
344
+ };
345
+
346
+ const right = document.createElement("button");
347
+ right.setAttribute("type", "button");
348
+ right.setAttribute("aria-label", window.VditorI18n.alignRight + "<" + updateHotkeyTip("⇧⌘R") + ">");
349
+ right.setAttribute("data-type", "right");
350
+ right.innerHTML =
351
+ '<svg><use xlink:href="#vditor-icon-align-right"></use></svg>';
352
+ right.className =
353
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n" +
354
+ (alignType === "right" ? " vditor-icon--current" : "");
355
+ right.onclick = () => {
356
+ setAlign("right");
357
+ };
358
+
359
+ const insertRowElement = document.createElement("button");
360
+ insertRowElement.setAttribute("type", "button");
361
+ insertRowElement.setAttribute("aria-label", window.VditorI18n.insertRowBelow + "<" + updateHotkeyTip("⌘=") + ">");
362
+ insertRowElement.setAttribute("data-type", "insertRow");
363
+ insertRowElement.innerHTML =
364
+ '<svg><use xlink:href="#vditor-icon-insert-row"></use></svg>';
365
+ insertRowElement.className =
366
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n";
367
+ insertRowElement.onclick = () => {
368
+ const startContainer = getSelection().getRangeAt(0)
369
+ .startContainer;
370
+ const cellElement =
371
+ hasClosestByMatchTag(startContainer, "TD") ||
372
+ hasClosestByMatchTag(startContainer, "TH");
373
+ if (cellElement) {
374
+ insertRow(vditor, range, cellElement);
375
+ }
376
+ };
377
+
378
+ const insertRowBElement = document.createElement("button");
379
+ insertRowBElement.setAttribute("type", "button");
380
+ insertRowBElement.setAttribute("aria-label",
381
+ window.VditorI18n.insertRowAbove + "<" + updateHotkeyTip("⇧⌘F") + ">");
382
+ insertRowBElement.setAttribute("data-type", "insertRow");
383
+ insertRowBElement.innerHTML =
384
+ '<svg><use xlink:href="#vditor-icon-insert-rowb"></use></svg>';
385
+ insertRowBElement.className =
386
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n";
387
+ insertRowBElement.onclick = () => {
388
+ const startContainer = getSelection().getRangeAt(0)
389
+ .startContainer;
390
+ const cellElement =
391
+ hasClosestByMatchTag(startContainer, "TD") ||
392
+ hasClosestByMatchTag(startContainer, "TH");
393
+ if (cellElement) {
394
+ insertRowAbove(vditor, range, cellElement);
395
+ }
396
+ };
397
+
398
+ const insertColumnElement = document.createElement("button");
399
+ insertColumnElement.setAttribute("type", "button");
400
+ insertColumnElement.setAttribute("aria-label", window.VditorI18n.insertColumnRight + "<" + updateHotkeyTip("⇧⌘=") + ">");
401
+ insertColumnElement.setAttribute("data-type", "insertColumn");
402
+ insertColumnElement.innerHTML =
403
+ '<svg><use xlink:href="#vditor-icon-insert-column"></use></svg>';
404
+ insertColumnElement.className =
405
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n";
406
+ insertColumnElement.onclick = () => {
407
+ const startContainer = getSelection().getRangeAt(0)
408
+ .startContainer;
409
+ const cellElement =
410
+ hasClosestByMatchTag(startContainer, "TD") ||
411
+ hasClosestByMatchTag(startContainer, "TH");
412
+ if (cellElement) {
413
+ insertColumn(vditor, tableElement, cellElement);
414
+ }
415
+ };
416
+
417
+ const insertColumnBElement = document.createElement("button");
418
+ insertColumnBElement.setAttribute("type", "button");
419
+ insertColumnBElement.setAttribute("aria-label", window.VditorI18n.insertColumnLeft + "<" + updateHotkeyTip("⇧⌘G") + ">");
420
+ insertColumnBElement.setAttribute("data-type", "insertColumn");
421
+ insertColumnBElement.innerHTML =
422
+ '<svg><use xlink:href="#vditor-icon-insert-columnb"></use></svg>';
423
+ insertColumnBElement.className =
424
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n";
425
+ insertColumnBElement.onclick = () => {
426
+ const startContainer = getSelection().getRangeAt(0)
427
+ .startContainer;
428
+ const cellElement =
429
+ hasClosestByMatchTag(startContainer, "TD") ||
430
+ hasClosestByMatchTag(startContainer, "TH");
431
+ if (cellElement) {
432
+ insertColumn(vditor, tableElement, cellElement, "beforebegin");
433
+ }
434
+ };
435
+
436
+ const deleteRowElement = document.createElement("button");
437
+ deleteRowElement.setAttribute("type", "button");
438
+ deleteRowElement.setAttribute("aria-label", window.VditorI18n["delete-row"] + "<" + updateHotkeyTip("⌘-") + ">");
439
+ deleteRowElement.setAttribute("data-type", "deleteRow");
440
+ deleteRowElement.innerHTML =
441
+ '<svg><use xlink:href="#vditor-icon-delete-row"></use></svg>';
442
+ deleteRowElement.className =
443
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n";
444
+ deleteRowElement.onclick = () => {
445
+ const startContainer = getSelection().getRangeAt(0)
446
+ .startContainer;
447
+ const cellElement =
448
+ hasClosestByMatchTag(startContainer, "TD") ||
449
+ hasClosestByMatchTag(startContainer, "TH");
450
+ if (cellElement) {
451
+ deleteRow(vditor, range, cellElement);
452
+ }
453
+ };
454
+
455
+ const deleteColumnElement = document.createElement("button");
456
+ deleteColumnElement.setAttribute("type", "button");
457
+ deleteColumnElement.setAttribute("aria-label", window.VditorI18n["delete-column"] + "<" + updateHotkeyTip("⇧⌘-") + ">");
458
+ deleteColumnElement.setAttribute("data-type", "deleteColumn");
459
+ deleteColumnElement.innerHTML =
460
+ '<svg><use xlink:href="#vditor-icon-delete-column"></use></svg>';
461
+ deleteColumnElement.className =
462
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n";
463
+ deleteColumnElement.onclick = () => {
464
+ const startContainer = getSelection().getRangeAt(0)
465
+ .startContainer;
466
+ const cellElement =
467
+ hasClosestByMatchTag(startContainer, "TD") ||
468
+ hasClosestByMatchTag(startContainer, "TH");
469
+ if (cellElement) {
470
+ deleteColumn(vditor, range, tableElement, cellElement);
471
+ }
472
+ };
473
+
474
+ const inputWrap = document.createElement("span");
475
+ inputWrap.setAttribute("aria-label", window.VditorI18n.row);
476
+ inputWrap.className = "vditor-tooltipped vditor-tooltipped__n";
477
+ const input = document.createElement("input");
478
+ inputWrap.appendChild(input);
479
+ input.type = "number";
480
+ input.min = "1";
481
+ input.className = "vditor-input";
482
+ input.style.width = "42px";
483
+ input.style.textAlign = "center";
484
+ input.setAttribute("placeholder", window.VditorI18n.row);
485
+ input.value = tableElement.rows.length.toString();
486
+ input.oninput = () => {
487
+ updateTable();
488
+ };
489
+ input.onkeydown = (event) => {
490
+ if (event.isComposing) {
491
+ return;
492
+ }
493
+ if (event.key === "Tab") {
494
+ input2.focus();
495
+ input2.select();
496
+ event.preventDefault();
497
+ return;
498
+ }
499
+ if (removeBlockElement(vditor, event)) {
500
+ return;
501
+ }
502
+ if (focusToElement(event, range)) {
503
+ return;
504
+ }
505
+ };
506
+
507
+ const input2Wrap = document.createElement("span");
508
+ input2Wrap.setAttribute("aria-label", window.VditorI18n.column);
509
+ input2Wrap.className = "vditor-tooltipped vditor-tooltipped__n";
510
+ const input2 = document.createElement("input");
511
+ input2Wrap.appendChild(input2);
512
+ input2.type = "number";
513
+ input2.min = "1";
514
+ input2.className = "vditor-input";
515
+ input2.style.width = "42px";
516
+ input2.style.textAlign = "center";
517
+ input2.setAttribute("placeholder", window.VditorI18n.column);
518
+ input2.value = tableElement.rows[0].cells.length.toString();
519
+ input2.oninput = () => {
520
+ updateTable();
521
+ };
522
+ input2.onkeydown = (event) => {
523
+ if (event.isComposing) {
524
+ return;
525
+ }
526
+ if (event.key === "Tab") {
527
+ input.focus();
528
+ input.select();
529
+ event.preventDefault();
530
+ return;
531
+ }
532
+ if (removeBlockElement(vditor, event)) {
533
+ return;
534
+ }
535
+ if (focusToElement(event, range)) {
536
+ return;
537
+ }
538
+ };
539
+
540
+ genUp(range, tableElement, vditor);
541
+ genDown(range, tableElement, vditor);
542
+ genClose(tableElement, vditor);
543
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", left);
544
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", center);
545
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", right);
546
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", insertRowBElement);
547
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", insertRowElement);
548
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", insertColumnBElement);
549
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", insertColumnElement);
550
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", deleteRowElement);
551
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", deleteColumnElement);
552
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", inputWrap);
553
+ vditor.wysiwyg.popover.insertAdjacentHTML("beforeend", " x ");
554
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", input2Wrap);
555
+ customWysiwygToolbar(vditor, "table")
556
+ setPopoverPosition(vditor, tableElement);
557
+ }
558
+
559
+ // link ref popover
560
+ const linkRefElement = hasClosestByAttribute(typeElement, "data-type", "link-ref");
561
+ if (linkRefElement) {
562
+ genLinkRefPopover(vditor, linkRefElement, range);
563
+ }
564
+
565
+ // footnote popover
566
+ const footnotesRefElement = hasClosestByAttribute(typeElement, "data-type", "footnotes-ref");
567
+ if (footnotesRefElement) {
568
+ const lang: keyof II18n | "" = vditor.options.lang;
569
+ const options: IOptions = vditor.options;
570
+ vditor.wysiwyg.popover.innerHTML = "";
571
+
572
+ const inputWrap = document.createElement("span");
573
+ inputWrap.setAttribute("aria-label", window.VditorI18n.footnoteRef + "<" + updateHotkeyTip("⌥Enter") + ">");
574
+ inputWrap.className = "vditor-tooltipped vditor-tooltipped__n";
575
+ const input = document.createElement("input");
576
+ inputWrap.appendChild(input);
577
+ input.className = "vditor-input";
578
+ input.setAttribute("placeholder", window.VditorI18n.footnoteRef + "<" + updateHotkeyTip("⌥Enter") + ">");
579
+ input.style.width = "120px";
580
+ input.value = footnotesRefElement.getAttribute("data-footnotes-label");
581
+ input.oninput = () => {
582
+ if (input.value.trim() !== "") {
583
+ footnotesRefElement.setAttribute("data-footnotes-label", input.value);
584
+ }
585
+ if (typeof vditor.options.input === "function") {
586
+ vditor.options.input(getMarkdown(vditor));
587
+ }
588
+ };
589
+ input.onkeydown = (event) => {
590
+ if (event.isComposing) {
591
+ return;
592
+ }
593
+ if (removeBlockElement(vditor, event)) {
594
+ return;
595
+ }
596
+ if (focusToElement(event, range)) {
597
+ return;
598
+ }
599
+ };
600
+
601
+ genClose(footnotesRefElement, vditor);
602
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", inputWrap);
603
+ customWysiwygToolbar(vditor, "footnotes-ref")
604
+ setPopoverPosition(vditor, footnotesRefElement);
605
+ }
606
+
607
+ // block popover: math-inline, math-block, html-block, html-inline, code-block, html-entity
608
+ let blockRenderElement = hasClosestByClassName(typeElement, "vditor-wysiwyg__block") as HTMLElement;
609
+ const isBlock = blockRenderElement ? blockRenderElement.getAttribute("data-type").indexOf("block") > -1 : false;
610
+ vditor.wysiwyg.element
611
+ .querySelectorAll(".vditor-wysiwyg__preview")
612
+ .forEach((itemElement) => {
613
+ if (!blockRenderElement || (blockRenderElement && isBlock && !blockRenderElement.contains(itemElement))) {
614
+ const previousElement = itemElement.previousElementSibling as HTMLElement;
615
+ previousElement.style.display = "none";
616
+ }
617
+ });
618
+ if (blockRenderElement && isBlock) {
619
+ vditor.wysiwyg.popover.innerHTML = "";
620
+ genUp(range, blockRenderElement, vditor);
621
+ genDown(range, blockRenderElement, vditor);
622
+ genClose(blockRenderElement, vditor);
623
+
624
+ if (blockRenderElement.getAttribute("data-type") === "code-block") {
625
+ const languageWrap = document.createElement("span");
626
+ languageWrap.setAttribute("aria-label", window.VditorI18n.language + "<" + updateHotkeyTip("⌥Enter") + ">");
627
+ languageWrap.className = "vditor-tooltipped vditor-tooltipped__n";
628
+ const language = document.createElement("input");
629
+ languageWrap.appendChild(language);
630
+
631
+ const codeElement =
632
+ blockRenderElement.firstElementChild.firstElementChild;
633
+
634
+ language.className = "vditor-input";
635
+ language.setAttribute("placeholder",
636
+ window.VditorI18n.language + "<" + updateHotkeyTip("⌥Enter") + ">");
637
+ language.value =
638
+ codeElement.className.indexOf("language-") > -1
639
+ ? codeElement.className.split("-")[1].split(" ")[0]
640
+ : "";
641
+ language.oninput = (e: InputEvent) => {
642
+ if (language.value.trim() !== "") {
643
+ codeElement.className = `language-${language.value}`;
644
+ } else {
645
+ codeElement.className = "";
646
+ vditor.hint.recentLanguage = "";
647
+ }
648
+ if (blockRenderElement.lastElementChild.classList.contains("vditor-wysiwyg__preview")) {
649
+ blockRenderElement.lastElementChild.innerHTML =
650
+ blockRenderElement.firstElementChild.innerHTML;
651
+ processCodeRender(blockRenderElement.lastElementChild as HTMLElement, vditor);
652
+ }
653
+ afterRenderEvent(vditor);
654
+ // 当鼠标点选语言时,触发自定义input事件
655
+ if (e.detail === 1) {
656
+ // 选择语言后,输入焦点切换到代码输入框
657
+ range.setStart(codeElement.firstChild, 0);
658
+ range.collapse(true);
659
+ setSelectionFocus(range);
660
+ }
661
+ };
662
+ language.onkeydown = (event: KeyboardEvent) => {
663
+ if (event.isComposing) {
664
+ return;
665
+ }
666
+ if (removeBlockElement(vditor, event)) {
667
+ return;
668
+ }
669
+ if (
670
+ event.key === "Escape" &&
671
+ vditor.hint.element.style.display === "block"
672
+ ) {
673
+ vditor.hint.element.style.display = "none";
674
+ event.preventDefault();
675
+ return;
676
+ }
677
+ vditor.hint.select(event, vditor);
678
+ focusToElement(event, range);
679
+ };
680
+ language.onkeyup = (event: KeyboardEvent) => {
681
+ if (
682
+ event.isComposing ||
683
+ event.key === "Enter" ||
684
+ event.key === "ArrowUp" ||
685
+ event.key === "Escape" ||
686
+ event.key === "ArrowDown"
687
+ ) {
688
+ return;
689
+ }
690
+ const matchLangData: IHintData[] = [];
691
+ const key = language.value.substring(0, language.selectionStart);
692
+ (vditor.options.preview.hljs.langs || Constants.ALIAS_CODE_LANGUAGES.concat((window.hljs?.listLanguages() ?? []).sort())).forEach((keyName) => {
693
+ if (keyName.indexOf(key.toLowerCase()) > -1) {
694
+ matchLangData.push({
695
+ html: keyName,
696
+ value: keyName,
697
+ });
698
+ }
699
+ });
700
+ vditor.hint.genHTML(matchLangData, key, vditor);
701
+ event.preventDefault();
702
+ };
703
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", languageWrap);
704
+ customWysiwygToolbar(vditor, "code-block")
705
+ } else {
706
+ customWysiwygToolbar(vditor, "block")
707
+ }
708
+ setPopoverPosition(vditor, blockRenderElement);
709
+ } else {
710
+ blockRenderElement = undefined;
711
+ }
712
+ if (headingElement) {
713
+ vditor.wysiwyg.popover.innerHTML = "";
714
+
715
+ const inputWrap = document.createElement("span");
716
+ inputWrap.setAttribute("aria-label", "ID" + "<" + updateHotkeyTip("⌥Enter") + ">");
717
+ inputWrap.className = "vditor-tooltipped vditor-tooltipped__n";
718
+ const input = document.createElement("input");
719
+ inputWrap.appendChild(input);
720
+ input.className = "vditor-input";
721
+ input.setAttribute("placeholder", "ID" + "<" + updateHotkeyTip("⌥Enter") + ">");
722
+ input.style.width = "120px";
723
+ input.value = headingElement.getAttribute("data-id") || "";
724
+ input.oninput = () => {
725
+ headingElement.setAttribute("data-id", input.value);
726
+ if (typeof vditor.options.input === "function") {
727
+ vditor.options.input(getMarkdown(vditor));
728
+ }
729
+ };
730
+ input.onkeydown = (event) => {
731
+ if (event.isComposing) {
732
+ return;
733
+ }
734
+ if (removeBlockElement(vditor, event)) {
735
+ return;
736
+ }
737
+ if (focusToElement(event, range)) {
738
+ return;
739
+ }
740
+ };
741
+
742
+ genUp(range, headingElement, vditor);
743
+ genDown(range, headingElement, vditor);
744
+ genClose(headingElement, vditor);
745
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", inputWrap);
746
+ customWysiwygToolbar(vditor, "heading")
747
+ setPopoverPosition(vditor, headingElement);
748
+ }
749
+
750
+ // a popover
751
+ if (aElement) {
752
+ genAPopover(vditor, aElement, range);
753
+ }
754
+
755
+ if (
756
+ !blockquoteElement &&
757
+ !liElement &&
758
+ !tableElement &&
759
+ !blockRenderElement &&
760
+ !aElement &&
761
+ !linkRefElement &&
762
+ !footnotesRefElement &&
763
+ !headingElement &&
764
+ !tocElement
765
+ ) {
766
+ const blockElement = hasClosestByAttribute(typeElement, "data-block", "0");
767
+ if (
768
+ blockElement &&
769
+ blockElement.parentElement.isEqualNode(vditor.wysiwyg.element)
770
+ ) {
771
+ vditor.wysiwyg.popover.innerHTML = "";
772
+ genUp(range, blockElement, vditor);
773
+ genDown(range, blockElement, vditor);
774
+ genClose(blockElement, vditor);
775
+ customWysiwygToolbar(vditor, "block")
776
+ setPopoverPosition(vditor, blockElement);
777
+ } else {
778
+ vditor.wysiwyg.popover.style.display = "none";
779
+ }
780
+ }
781
+
782
+ // 反斜杠特殊处理
783
+ vditor.wysiwyg.element
784
+ .querySelectorAll('span[data-type="backslash"] > span')
785
+ .forEach((item: HTMLElement) => {
786
+ item.style.display = "none";
787
+ });
788
+ const backslashElement = hasClosestByAttribute(range.startContainer, "data-type", "backslash");
789
+ if (backslashElement) {
790
+ backslashElement.querySelector("span").style.display = "inline";
791
+ }
792
+ }, 200);
793
+ };
794
+
795
+ const setPopoverPosition = (vditor: IVditor, element: HTMLElement) => {
796
+ let targetElement = element;
797
+ const tableElement = hasClosestByMatchTag(element, "TABLE");
798
+ if (tableElement) {
799
+ targetElement = tableElement;
800
+ }
801
+ vditor.wysiwyg.popover.style.left = "0";
802
+ vditor.wysiwyg.popover.style.display = "block";
803
+ vditor.wysiwyg.popover.style.top =
804
+ Math.max(-8, targetElement.offsetTop - 21 - vditor.wysiwyg.element.scrollTop) + "px";
805
+ vditor.wysiwyg.popover.style.left =
806
+ Math.min(targetElement.offsetLeft, vditor.wysiwyg.element.clientWidth - vditor.wysiwyg.popover.clientWidth) + "px";
807
+ vditor.wysiwyg.popover.setAttribute("data-top", (targetElement.offsetTop - 21).toString());
808
+ };
809
+
810
+ export const genLinkRefPopover = (vditor: IVditor, linkRefElement: HTMLElement, range = getSelection().getRangeAt(0)) => {
811
+ vditor.wysiwyg.popover.innerHTML = "";
812
+ const updateLinkRef = () => {
813
+ if (input.value.trim() !== "") {
814
+ if (linkRefElement.tagName === "IMG") {
815
+ linkRefElement.setAttribute("alt", input.value);
816
+ } else {
817
+ linkRefElement.textContent = input.value;
818
+ }
819
+ }
820
+ // data-link-label
821
+ if (input1.value.trim() !== "") {
822
+ linkRefElement.setAttribute("data-link-label", input1.value);
823
+ }
824
+ if (typeof vditor.options.input === "function") {
825
+ vditor.options.input(getMarkdown(vditor));
826
+ }
827
+ };
828
+
829
+ const inputWrap = document.createElement("span");
830
+ inputWrap.setAttribute("aria-label", window.VditorI18n.textIsNotEmpty);
831
+ inputWrap.className = "vditor-tooltipped vditor-tooltipped__n";
832
+ const input = document.createElement("input");
833
+ inputWrap.appendChild(input);
834
+ input.className = "vditor-input";
835
+ input.setAttribute("placeholder", window.VditorI18n.textIsNotEmpty);
836
+ input.style.width = "120px";
837
+ input.value =
838
+ linkRefElement.getAttribute("alt") || linkRefElement.textContent;
839
+ input.oninput = () => {
840
+ updateLinkRef();
841
+ };
842
+ input.onkeydown = (event) => {
843
+ if (removeBlockElement(vditor, event)) {
844
+ return;
845
+ }
846
+ if (focusToElement(event, range)) {
847
+ return;
848
+ }
849
+ linkHotkey(vditor, linkRefElement, event, input1);
850
+ };
851
+
852
+ const input1Wrap = document.createElement("span");
853
+ input1Wrap.setAttribute("aria-label", window.VditorI18n.linkRef);
854
+ input1Wrap.className = "vditor-tooltipped vditor-tooltipped__n";
855
+ const input1 = document.createElement("input");
856
+ input1Wrap.appendChild(input1);
857
+ input1.className = "vditor-input";
858
+ input1.setAttribute("placeholder", window.VditorI18n.linkRef);
859
+ input1.value = linkRefElement.getAttribute("data-link-label");
860
+ input1.oninput = () => {
861
+ updateLinkRef();
862
+ };
863
+ input1.onkeydown = (event) => {
864
+ if (removeBlockElement(vditor, event)) {
865
+ return;
866
+ }
867
+ if (focusToElement(event, range)) {
868
+ return;
869
+ }
870
+ linkHotkey(vditor, linkRefElement, event, input);
871
+ };
872
+
873
+ genClose(linkRefElement, vditor);
874
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", inputWrap);
875
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", input1Wrap);
876
+ customWysiwygToolbar(vditor, "link-ref")
877
+ setPopoverPosition(vditor, linkRefElement);
878
+ };
879
+
880
+ const genUp = (range: Range, element: HTMLElement, vditor: IVditor) => {
881
+ const previousElement = element.previousElementSibling;
882
+ if (
883
+ !previousElement ||
884
+ (!element.parentElement.isEqualNode(vditor.wysiwyg.element) &&
885
+ element.tagName !== "LI")
886
+ ) {
887
+ return;
888
+ }
889
+ const upElement = document.createElement("button");
890
+ upElement.setAttribute("type", "button");
891
+ upElement.setAttribute("data-type", "up");
892
+ upElement.setAttribute("aria-label", window.VditorI18n.up + "<" + updateHotkeyTip("⇧⌘U") + ">");
893
+ upElement.innerHTML = '<svg><use xlink:href="#vditor-icon-up"></use></svg>';
894
+ upElement.className = "vditor-icon vditor-tooltipped vditor-tooltipped__n";
895
+ upElement.onclick = () => {
896
+ range.insertNode(document.createElement("wbr"));
897
+ previousElement.insertAdjacentElement("beforebegin", element);
898
+ setRangeByWbr(vditor.wysiwyg.element, range);
899
+ afterRenderEvent(vditor);
900
+ highlightToolbarWYSIWYG(vditor);
901
+ scrollCenter(vditor);
902
+ };
903
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", upElement);
904
+ };
905
+
906
+ const genDown = (range: Range, element: HTMLElement, vditor: IVditor) => {
907
+ const nextElement = element.nextElementSibling;
908
+ if (
909
+ !nextElement ||
910
+ (!element.parentElement.isEqualNode(vditor.wysiwyg.element) &&
911
+ element.tagName !== "LI")
912
+ ) {
913
+ return;
914
+ }
915
+ const downElement = document.createElement("button");
916
+ downElement.setAttribute("type", "button");
917
+ downElement.setAttribute("data-type", "down");
918
+ downElement.setAttribute("aria-label", window.VditorI18n.down + "<" + updateHotkeyTip("⇧⌘D") + ">");
919
+ downElement.innerHTML =
920
+ '<svg><use xlink:href="#vditor-icon-down"></use></svg>';
921
+ downElement.className =
922
+ "vditor-icon vditor-tooltipped vditor-tooltipped__n";
923
+ downElement.onclick = () => {
924
+ range.insertNode(document.createElement("wbr"));
925
+ nextElement.insertAdjacentElement("afterend", element);
926
+ setRangeByWbr(vditor.wysiwyg.element, range);
927
+ afterRenderEvent(vditor);
928
+ highlightToolbarWYSIWYG(vditor);
929
+ scrollCenter(vditor);
930
+ };
931
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", downElement);
932
+ };
933
+
934
+ const genClose = (element: HTMLElement, vditor: IVditor) => {
935
+ const close = document.createElement("button");
936
+ close.setAttribute("type", "button");
937
+ close.setAttribute("data-type", "remove");
938
+ close.setAttribute("aria-label", window.VditorI18n.remove + "<" + updateHotkeyTip("⇧⌘X") + ">");
939
+ close.innerHTML =
940
+ '<svg><use xlink:href="#vditor-icon-trashcan"></use></svg>';
941
+ close.className = "vditor-icon vditor-tooltipped vditor-tooltipped__n";
942
+ close.onclick = () => {
943
+ const range = getEditorRange(vditor);
944
+ range.setStartAfter(element);
945
+ setSelectionFocus(range);
946
+ element.remove();
947
+ afterRenderEvent(vditor);
948
+ highlightToolbarWYSIWYG(vditor);
949
+ if (["H1", "H2", "H3", "H4", "H5", "H6"].includes(element.tagName)) {
950
+ renderToc(vditor);
951
+ }
952
+ };
953
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", close);
954
+ };
955
+
956
+ const linkHotkey = (
957
+ vditor: IVditor,
958
+ element: HTMLElement,
959
+ event: KeyboardEvent,
960
+ nextInputElement: HTMLInputElement,
961
+ ) => {
962
+ if (event.isComposing) {
963
+ return;
964
+ }
965
+ if (event.key === "Tab") {
966
+ nextInputElement.focus();
967
+ nextInputElement.select();
968
+ event.preventDefault();
969
+ return;
970
+ }
971
+ if (
972
+ !isCtrl(event) &&
973
+ !event.shiftKey &&
974
+ event.altKey &&
975
+ event.key === "Enter"
976
+ ) {
977
+ const range = getEditorRange(vditor);
978
+ // firefox 不会打断 link https://github.com/Vanessa219/vditor/issues/193
979
+ element.insertAdjacentHTML("afterend", Constants.ZWSP);
980
+ range.setStartAfter(element.nextSibling);
981
+ range.collapse(true);
982
+ setSelectionFocus(range);
983
+ event.preventDefault();
984
+ }
985
+ };
986
+
987
+ export const genAPopover = (vditor: IVditor, aElement: HTMLElement, range: Range) => {
988
+ vditor.wysiwyg.popover.innerHTML = "";
989
+
990
+ const updateA = () => {
991
+ if (input.value.trim() !== "") {
992
+ aElement.innerHTML = input.value;
993
+ }
994
+ aElement.setAttribute("href", input1.value);
995
+ aElement.setAttribute("title", input2.value);
996
+ afterRenderEvent(vditor);
997
+ };
998
+
999
+ aElement.querySelectorAll("[data-marker]").forEach((item: HTMLElement) => {
1000
+ item.removeAttribute("data-marker");
1001
+ });
1002
+ const inputWrap = document.createElement("span");
1003
+ inputWrap.setAttribute("aria-label", window.VditorI18n.textIsNotEmpty);
1004
+ inputWrap.className = "vditor-tooltipped vditor-tooltipped__n";
1005
+ const input = document.createElement("input");
1006
+ inputWrap.appendChild(input);
1007
+ input.className = "vditor-input";
1008
+ input.setAttribute("placeholder", window.VditorI18n.textIsNotEmpty);
1009
+ input.style.width = "120px";
1010
+ input.value = aElement.innerHTML || "";
1011
+ input.oninput = () => {
1012
+ updateA();
1013
+ };
1014
+ input.onkeydown = (event) => {
1015
+ if (removeBlockElement(vditor, event)) {
1016
+ return;
1017
+ }
1018
+ if (focusToElement(event, range)) {
1019
+ return;
1020
+ }
1021
+ linkHotkey(vditor, aElement, event, input1);
1022
+ };
1023
+
1024
+ const input1Wrap = document.createElement("span");
1025
+ input1Wrap.setAttribute("aria-label", window.VditorI18n.link);
1026
+ input1Wrap.className = "vditor-tooltipped vditor-tooltipped__n";
1027
+ const input1 = document.createElement("input");
1028
+ input1Wrap.appendChild(input1);
1029
+ input1.className = "vditor-input";
1030
+ input1.setAttribute("placeholder", window.VditorI18n.link);
1031
+ input1.value = aElement.getAttribute("href") || "";
1032
+ input1.oninput = () => {
1033
+ updateA();
1034
+ };
1035
+ input1.onkeydown = (event) => {
1036
+ if (removeBlockElement(vditor, event)) {
1037
+ return;
1038
+ }
1039
+ if (focusToElement(event, range)) {
1040
+ return;
1041
+ }
1042
+ linkHotkey(vditor, aElement, event, input2);
1043
+ };
1044
+
1045
+ const input2Wrap = document.createElement("span");
1046
+ input2Wrap.setAttribute("aria-label", window.VditorI18n.tooltipText);
1047
+ input2Wrap.className = "vditor-tooltipped vditor-tooltipped__n";
1048
+ const input2 = document.createElement("input");
1049
+ input2Wrap.appendChild(input2);
1050
+ input2.className = "vditor-input";
1051
+ input2.setAttribute("placeholder", window.VditorI18n.tooltipText);
1052
+ input2.style.width = "60px";
1053
+ input2.value = aElement.getAttribute("title") || "";
1054
+ input2.oninput = () => {
1055
+ updateA();
1056
+ };
1057
+ input2.onkeydown = (event) => {
1058
+ if (removeBlockElement(vditor, event)) {
1059
+ return;
1060
+ }
1061
+ if (focusToElement(event, range)) {
1062
+ return;
1063
+ }
1064
+ linkHotkey(vditor, aElement, event, input);
1065
+ };
1066
+
1067
+ genClose(aElement, vditor);
1068
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", inputWrap);
1069
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", input1Wrap);
1070
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", input2Wrap);
1071
+ customWysiwygToolbar(vditor, "a")
1072
+ setPopoverPosition(vditor, aElement);
1073
+ };
1074
+
1075
+ export const genImagePopover = (event: Event, vditor: IVditor) => {
1076
+ const imgElement = event.target as HTMLImageElement;
1077
+ vditor.wysiwyg.popover.innerHTML = "";
1078
+ const updateImg = () => {
1079
+ imgElement.setAttribute("src", inputElement.value);
1080
+ imgElement.setAttribute("alt", alt.value);
1081
+ imgElement.setAttribute("title", title.value);
1082
+ if (typeof vditor.options.input === "function") {
1083
+ vditor.options.input(getMarkdown(vditor));
1084
+ }
1085
+ };
1086
+
1087
+ const inputWrap = document.createElement("span");
1088
+ inputWrap.setAttribute("aria-label", window.VditorI18n.imageURL);
1089
+ inputWrap.className = "vditor-tooltipped vditor-tooltipped__n";
1090
+ const inputElement = document.createElement("input");
1091
+ inputWrap.appendChild(inputElement);
1092
+ inputElement.className = "vditor-input";
1093
+ inputElement.setAttribute("placeholder", window.VditorI18n.imageURL);
1094
+ inputElement.value = imgElement.getAttribute("src") || "";
1095
+ inputElement.oninput = () => {
1096
+ updateImg();
1097
+ };
1098
+ inputElement.onkeydown = (elementEvent) => {
1099
+ removeBlockElement(vditor, elementEvent);
1100
+ };
1101
+
1102
+ const altWrap = document.createElement("span");
1103
+ altWrap.setAttribute("aria-label", window.VditorI18n.alternateText);
1104
+ altWrap.className = "vditor-tooltipped vditor-tooltipped__n";
1105
+ const alt = document.createElement("input");
1106
+ altWrap.appendChild(alt);
1107
+ alt.className = "vditor-input";
1108
+ alt.setAttribute("placeholder", window.VditorI18n.alternateText);
1109
+ alt.style.width = "52px";
1110
+ alt.value = imgElement.getAttribute("alt") || "";
1111
+ alt.oninput = () => {
1112
+ updateImg();
1113
+ };
1114
+ alt.onkeydown = (elementEvent) => {
1115
+ removeBlockElement(vditor, elementEvent);
1116
+ };
1117
+
1118
+ const titleWrap = document.createElement("span");
1119
+ titleWrap.setAttribute("aria-label", window.VditorI18n.title);
1120
+ titleWrap.className = "vditor-tooltipped vditor-tooltipped__n";
1121
+ const title = document.createElement("input");
1122
+ titleWrap.appendChild(title);
1123
+ title.className = "vditor-input";
1124
+ title.setAttribute("placeholder", window.VditorI18n.title);
1125
+ title.value = imgElement.getAttribute("title") || "";
1126
+ title.oninput = () => {
1127
+ updateImg();
1128
+ };
1129
+ title.onkeydown = (elementEvent) => {
1130
+ removeBlockElement(vditor, elementEvent);
1131
+ };
1132
+ genClose(imgElement, vditor);
1133
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", inputWrap);
1134
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", altWrap);
1135
+ vditor.wysiwyg.popover.insertAdjacentElement("beforeend", titleWrap);
1136
+ customWysiwygToolbar(vditor, "image")
1137
+ setPopoverPosition(vditor, imgElement);
1138
+ };
1139
+
1140
+
1141
+ const focusToElement = (event: KeyboardEvent, range: Range) => {
1142
+ if ((!isCtrl(event) && !event.shiftKey && event.key === "Enter") || event.key === "Escape") {
1143
+ if (range) {
1144
+ setSelectionFocus(range);
1145
+ }
1146
+ event.preventDefault();
1147
+ event.stopPropagation();
1148
+ return true;
1149
+ }
1150
+ };
1151
+
1152
+ const customWysiwygToolbar = (vditor: IVditor, type: TWYSISYGToolbar) => {
1153
+ if (vditor.options.customWysiwygToolbar) {
1154
+ vditor.options.customWysiwygToolbar(type, vditor.wysiwyg.popover);
1155
+ }
1156
+ };