@vc-shell/framework 2.0.0-alpha.1 → 2.0.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (290) hide show
  1. package/dist/tsconfig.tsbuildinfo +1 -1
  2. package/package.json +8 -5
  3. package/dist/assets/042c75b764bc78a7.svg +0 -1
  4. package/dist/assets/0ba156439a339f2a.svg +0 -1
  5. package/dist/assets/0be560bfb22d0e72.woff2 +0 -0
  6. package/dist/assets/0d67e9e056b4c500.woff +0 -0
  7. package/dist/assets/0f590f8a94577092.svg +0 -1
  8. package/dist/assets/0fc5820f8be53a1b.svg +0 -1
  9. package/dist/assets/105efd028edc1dfe.woff +0 -0
  10. package/dist/assets/10768e2cc79fc60b.svg +0 -1
  11. package/dist/assets/11b3d25a56fd9a21.woff2 +0 -0
  12. package/dist/assets/131b34336aedaf47.woff +0 -0
  13. package/dist/assets/154365acf3010d96.woff2 +0 -0
  14. package/dist/assets/157b8721e0600ea8.svg +0 -1
  15. package/dist/assets/15e91cdd649cde9a.svg +0 -1
  16. package/dist/assets/19275e398ae57130.woff2 +0 -0
  17. package/dist/assets/19bb1c668a5db39f.woff2 +0 -0
  18. package/dist/assets/1a3e84b2457f709a.woff +0 -0
  19. package/dist/assets/1de63eb118636cce.svg +0 -1
  20. package/dist/assets/1ea01de36eb5491b.svg +0 -1
  21. package/dist/assets/2010ada3e82156ed.woff +0 -0
  22. package/dist/assets/204eaf512fde2023.svg +0 -1
  23. package/dist/assets/2088983edf42e153.svg +0 -1
  24. package/dist/assets/208f810a9321a327.svg +0 -1
  25. package/dist/assets/21220a9d10e6c558.svg +0 -1
  26. package/dist/assets/220db345a102045d.woff2 +0 -0
  27. package/dist/assets/225da11d23968333.svg +0 -1
  28. package/dist/assets/226f862dd81bdc13.woff2 +0 -0
  29. package/dist/assets/23a2d53395ddb14f.woff +0 -0
  30. package/dist/assets/259e6ad461a52ad7.svg +0 -1
  31. package/dist/assets/261e6dec4d53b9ac.woff +0 -0
  32. package/dist/assets/262f46a0b6d94bb6.svg +0 -1
  33. package/dist/assets/2857c513073467da.svg +0 -1
  34. package/dist/assets/2b3be7889467d98f.woff +0 -0
  35. package/dist/assets/2d4e6190eec72737.svg +0 -1
  36. package/dist/assets/2eba973185078bc8.woff +0 -0
  37. package/dist/assets/334d3f6bc766c516.woff +0 -0
  38. package/dist/assets/34ff7dd0c2285956.svg +0 -1
  39. package/dist/assets/3d26b7c1ab78bbe2.woff +0 -0
  40. package/dist/assets/3d892965ab4f1cbb.woff2 +0 -0
  41. package/dist/assets/3f8c4cc8099e34b6.woff2 +0 -0
  42. package/dist/assets/3fc09a6113184f16.woff +0 -0
  43. package/dist/assets/40a0e53b79ce63c6.woff2 +0 -0
  44. package/dist/assets/41275bcb979cb650.svg +0 -1
  45. package/dist/assets/434f7982590e462f.woff +0 -0
  46. package/dist/assets/475937116ee3314a.woff2 +0 -0
  47. package/dist/assets/477e1881a0394cc5.woff +0 -0
  48. package/dist/assets/489710fb710e73f0.woff +0 -0
  49. package/dist/assets/49791943b3872376.woff2 +0 -0
  50. package/dist/assets/4ae5f23e0ca888e7.woff2 +0 -0
  51. package/dist/assets/4d7a77b0e5373992.svg +0 -1
  52. package/dist/assets/4e43c74354534fb3.svg +0 -1
  53. package/dist/assets/4fe75f5117100705.svg +0 -1
  54. package/dist/assets/52e261a005074e1b.woff +0 -0
  55. package/dist/assets/5304c3d05a5f9789.woff2 +0 -0
  56. package/dist/assets/54cda5482c6c9218.woff +0 -0
  57. package/dist/assets/550f52072e8ccafe.woff2 +0 -0
  58. package/dist/assets/572bb1bb4156a9c1.svg +0 -1
  59. package/dist/assets/6075995d7e74da46.woff2 +0 -0
  60. package/dist/assets/617c4736236e199e.woff +0 -0
  61. package/dist/assets/67230f05dc94a265.svg +0 -1
  62. package/dist/assets/6798e4dd4add9b48.svg +0 -1
  63. package/dist/assets/686d4077c1e26876.woff2 +0 -0
  64. package/dist/assets/698ec6c722d4cb05.woff2 +0 -0
  65. package/dist/assets/6a3e73faf406cf33.svg +0 -1
  66. package/dist/assets/72de3a63bc0b70dd.svg +0 -1
  67. package/dist/assets/74c6a6ab81bb6340.woff2 +0 -0
  68. package/dist/assets/74ed5f8a78e71106.svg +0 -1
  69. package/dist/assets/7a5aa5abd625137f.ttf +0 -0
  70. package/dist/assets/7ce0c166fd6a1204.woff +0 -0
  71. package/dist/assets/7d55399c2a7bc985.svg +0 -1
  72. package/dist/assets/7d970675c69fca1d.woff +0 -0
  73. package/dist/assets/7eda727273fd98d3.svg +0 -1
  74. package/dist/assets/7f6ebfd707b76ca2.woff +0 -0
  75. package/dist/assets/7fa898d213fcc7bc.woff2 +0 -0
  76. package/dist/assets/861e6b7192b3b6c7.woff +0 -0
  77. package/dist/assets/8bbcde81ba21ecb2.woff2 +0 -0
  78. package/dist/assets/8f6657e5e0b8d3e4.woff +0 -0
  79. package/dist/assets/910b0d99b9e26568.svg +0 -1
  80. package/dist/assets/91fe94e424323d61.woff +0 -0
  81. package/dist/assets/92508f8707159b51.svg +0 -1
  82. package/dist/assets/9392bf1d591e1abb.svg +0 -1
  83. package/dist/assets/97e8d4984ba0713a.woff2 +0 -0
  84. package/dist/assets/9cb83236f6bb7ab1.svg +0 -1
  85. package/dist/assets/9d37314695c0b68d.woff +0 -0
  86. package/dist/assets/a03cdcd8da5bb987.woff +0 -0
  87. package/dist/assets/a18404194e3f9047.svg +0 -1
  88. package/dist/assets/a2017fe7f0a26510.svg +0 -1
  89. package/dist/assets/ab6e7190bb1492d5.woff2 +0 -0
  90. package/dist/assets/abf88f301a0730f4.svg +0 -1
  91. package/dist/assets/ac1a99b3d05d8232.woff +0 -0
  92. package/dist/assets/aed17cb6fdad2ada.woff2 +0 -0
  93. package/dist/assets/b1a596e31ad1185a.svg +0 -1
  94. package/dist/assets/b27767411c8427be.woff +0 -0
  95. package/dist/assets/b325adcae33bbe7a.svg +0 -1
  96. package/dist/assets/b372390551ca2fa1.svg +0 -1
  97. package/dist/assets/b5bb1e8fc975decd.svg +0 -1
  98. package/dist/assets/b645a4a2181b9dc1.svg +0 -1
  99. package/dist/assets/b6499ddce0a4ef7d.svg +0 -1
  100. package/dist/assets/b7ffde2383bb16ba.woff2 +0 -0
  101. package/dist/assets/b94421fadd23b0f2.svg +0 -1
  102. package/dist/assets/bb28fb0f27f1c11b.svg +0 -1
  103. package/dist/assets/c5195215cb712e9c.woff2 +0 -0
  104. package/dist/assets/c9191b638a10f67b.woff2 +0 -0
  105. package/dist/assets/c97328b91ac5cc66.woff +0 -0
  106. package/dist/assets/ca791c5ca5848a03.svg +0 -1
  107. package/dist/assets/cb32840ce330103f.woff +0 -0
  108. package/dist/assets/ccc878931d74181b.woff2 +0 -0
  109. package/dist/assets/cdc69f8b549c866d.woff2 +0 -0
  110. package/dist/assets/d084bda16abe8a56.svg +0 -1
  111. package/dist/assets/d32b129cae2fffd6.svg +0 -1
  112. package/dist/assets/d35a4c7113315758.woff2 +0 -0
  113. package/dist/assets/d3f792f54ae4c307.svg +0 -1
  114. package/dist/assets/d5a5b8630120073d.svg +0 -1
  115. package/dist/assets/d5eb20bcdcf5616a.woff2 +0 -0
  116. package/dist/assets/d5f9664ebbfb104b.svg +0 -1
  117. package/dist/assets/d84247b59449dd88.woff2 +0 -0
  118. package/dist/assets/da4b7f5883fe7743.woff2 +0 -0
  119. package/dist/assets/dceaf3b39091e6a4.woff +0 -0
  120. package/dist/assets/dd05d43ff0df2fc7.svg +0 -1
  121. package/dist/assets/e2ad5b3428289141.woff +0 -0
  122. package/dist/assets/e38acaa1757232e0.svg +0 -1
  123. package/dist/assets/e4a8550f1c7ffe36.svg +0 -1
  124. package/dist/assets/e5adb5ae3a3698f6.svg +0 -1
  125. package/dist/assets/e61a1889bac955f4.woff2 +0 -0
  126. package/dist/assets/e72bb11356af94c7.svg +0 -1
  127. package/dist/assets/e98196a9f8dcb2f0.svg +0 -1
  128. package/dist/assets/ebec912a42ad49ff.woff +0 -0
  129. package/dist/assets/ee6983981ffcbb41.woff2 +0 -0
  130. package/dist/assets/f09d89268e4c0317.svg +0 -1
  131. package/dist/assets/f239394367fcf005.woff2 +0 -0
  132. package/dist/assets/f5722262b6e7214e.woff2 +0 -0
  133. package/dist/assets/f7fc8bf46089d8b2.svg +0 -1
  134. package/dist/assets/fc829e3f399b70e0.woff2 +0 -0
  135. package/dist/assets/fe141d99763f5d2b.woff +0 -0
  136. package/dist/assets/fed13b0d59903483.svg +0 -1
  137. package/dist/assets/fed757d2c2344ead.woff2 +0 -0
  138. package/dist/assets/ffc438f20e79ce73.woff +0 -0
  139. package/dist/framework.css +0 -9
  140. package/dist/framework.js +0 -36471
  141. package/dist/vendor-boolbase-D2i1C8XR.js +0 -18
  142. package/dist/vendor-cheerio-DrsWhxJH.js +0 -1053
  143. package/dist/vendor-cheerio-select-jw4C2SiT.js +0 -191
  144. package/dist/vendor-core-js-Do_NZFHx.js +0 -880
  145. package/dist/vendor-css-select-BwGMmTuc.js +0 -622
  146. package/dist/vendor-css-what-CZZaquJM.js +0 -267
  147. package/dist/vendor-cypress-signalr-mock-itnm2wpA.js +0 -781
  148. package/dist/vendor-d3-array-9cpTrqlO.js +0 -149
  149. package/dist/vendor-d3-axis-D1_DbKLz.js +0 -74
  150. package/dist/vendor-d3-brush-CcKeJp9e.js +0 -1
  151. package/dist/vendor-d3-color-BOYE6h_9.js +0 -306
  152. package/dist/vendor-d3-dispatch-fx-WMg0D.js +0 -64
  153. package/dist/vendor-d3-ease-Cr34gv04.js +0 -8
  154. package/dist/vendor-d3-format-DaIwZvFc.js +0 -182
  155. package/dist/vendor-d3-interpolate-BYG2gvO4.js +0 -177
  156. package/dist/vendor-d3-interpolate-path-CpGLvKgS.js +0 -299
  157. package/dist/vendor-d3-path-DJOTitNW.js +0 -64
  158. package/dist/vendor-d3-scale-CC5rtdt5.js +0 -561
  159. package/dist/vendor-d3-selection-CNMxsYiL.js +0 -603
  160. package/dist/vendor-d3-shape-DBhCDMiV.js +0 -925
  161. package/dist/vendor-d3-time-DAPP210_.js +0 -212
  162. package/dist/vendor-d3-time-format-hD7iE2WG.js +0 -491
  163. package/dist/vendor-d3-timer-C1cUWKPz.js +0 -67
  164. package/dist/vendor-d3-transition-BbNQT7qF.js +0 -524
  165. package/dist/vendor-d3-zoom-CcKeJp9e.js +0 -1
  166. package/dist/vendor-date-fns-BKO3x1R1.js +0 -3102
  167. package/dist/vendor-dom-serializer-BbVuF1MQ.js +0 -213
  168. package/dist/vendor-domelementtype-B3sFIGaC.js +0 -21
  169. package/dist/vendor-domhandler-Kufn9M_V.js +0 -311
  170. package/dist/vendor-dompurify-M2Bspgo5.js +0 -553
  171. package/dist/vendor-domutils-DDRq_ial.js +0 -386
  172. package/dist/vendor-emotion-cache-eEZT5l-Q.js +0 -274
  173. package/dist/vendor-emotion-hash-DImMRhyK.js +0 -22
  174. package/dist/vendor-emotion-memoize-BcEUCz8q.js +0 -9
  175. package/dist/vendor-emotion-serialize-BSDW8NwU.js +0 -123
  176. package/dist/vendor-emotion-sheet-CS8ZBl9s.js +0 -44
  177. package/dist/vendor-emotion-unitless-B7u1PU6w.js +0 -53
  178. package/dist/vendor-emotion-utils-D7refZTM.js +0 -28
  179. package/dist/vendor-entities-J86Og8IU.js +0 -364
  180. package/dist/vendor-floating-ui-core-BoHdh92a.js +0 -432
  181. package/dist/vendor-floating-ui-dom-BvVXFZ4B.js +0 -398
  182. package/dist/vendor-floating-ui-utils-CidJRIm2.js +0 -257
  183. package/dist/vendor-floating-ui-vue-sCrhit51.js +0 -121
  184. package/dist/vendor-gridstack-Dkfw452e.js +0 -3390
  185. package/dist/vendor-headlessui-vue-Cn-RMs4E.js +0 -961
  186. package/dist/vendor-htmlparser2-BxKKzWLL.js +0 -735
  187. package/dist/vendor-internmap-Q5729_cS.js +0 -35
  188. package/dist/vendor-intlify-core-base-BmIo1dK4.js +0 -1141
  189. package/dist/vendor-intlify-message-compiler-D9VOavkL.js +0 -960
  190. package/dist/vendor-intlify-shared-SCAs3ybf.js +0 -144
  191. package/dist/vendor-iso-639-1-rPqx9HMT.js +0 -786
  192. package/dist/vendor-juggle-resize-observer-DiSiNbbT.js +0 -286
  193. package/dist/vendor-linkify-it-LzoUhj6C.js +0 -199
  194. package/dist/vendor-linkifyjs-dCH9UYes.js +0 -701
  195. package/dist/vendor-lodash-es-BtnfG6xF.js +0 -4829
  196. package/dist/vendor-lucide-vue-next-CPgeDcFj.js +0 -33093
  197. package/dist/vendor-markdown-it-Bs9KEWkF.js +0 -2266
  198. package/dist/vendor-markdown-it-task-lists-CHCnS7dl.js +0 -69
  199. package/dist/vendor-mdurl-DZFDNdqC.js +0 -192
  200. package/dist/vendor-microsoft-applicationinsights-analytics-js-DFu_cVaY.js +0 -1207
  201. package/dist/vendor-microsoft-applicationinsights-cfgsync-js-DRQLN2Ue.js +0 -261
  202. package/dist/vendor-microsoft-applicationinsights-channel-js-BIJDcP3D.js +0 -1822
  203. package/dist/vendor-microsoft-applicationinsights-common-CJjmnDMb.js +0 -1921
  204. package/dist/vendor-microsoft-applicationinsights-core-js-BOc_o46i.js +0 -4276
  205. package/dist/vendor-microsoft-applicationinsights-dependencies-js-DDz502id.js +0 -1407
  206. package/dist/vendor-microsoft-applicationinsights-properties-js-9aDWHwXJ.js +0 -572
  207. package/dist/vendor-microsoft-applicationinsights-shims-Dton8Vqy.js +0 -43
  208. package/dist/vendor-microsoft-applicationinsights-web-DTa5YN-h.js +0 -487
  209. package/dist/vendor-microsoft-dynamicproto-js-89GEKjvR.js +0 -147
  210. package/dist/vendor-microsoft-signalr-Bgpbb4fW.js +0 -1761
  211. package/dist/vendor-module-federation-enhanced-CV1CNdJy.js +0 -22
  212. package/dist/vendor-module-federation-error-codes-DdVwX11j.js +0 -55
  213. package/dist/vendor-module-federation-runtime-CVH_lWgu.js +0 -91
  214. package/dist/vendor-module-federation-runtime-core-D5G-s9nP.js +0 -2202
  215. package/dist/vendor-module-federation-runtime-tools-CQbtw-RJ.js +0 -18
  216. package/dist/vendor-module-federation-sdk-DM4AJRa7.js +0 -683
  217. package/dist/vendor-nevware21-ts-async-D4qa7g-U.js +0 -261
  218. package/dist/vendor-nevware21-ts-utils-DII8jruI.js +0 -853
  219. package/dist/vendor-nth-check-CGMdQf59.js +0 -45
  220. package/dist/vendor-orderedmap-B3SOk52B.js +0 -103
  221. package/dist/vendor-parse5-htmlparser2-tree-adapter-BUDJ887-.js +0 -143
  222. package/dist/vendor-parse5-zq5Hn0y9.js +0 -5749
  223. package/dist/vendor-prettier-CoRReRqw.js +0 -5215
  224. package/dist/vendor-prosemirror-commands-Bv4ChObl.js +0 -385
  225. package/dist/vendor-prosemirror-dropcursor-kF5UKNFM.js +0 -86
  226. package/dist/vendor-prosemirror-gapcursor-S3ikcYX6.js +0 -203
  227. package/dist/vendor-prosemirror-history-CQYKHz3u.js +0 -248
  228. package/dist/vendor-prosemirror-keymap-CAfQyvJ7.js +0 -62
  229. package/dist/vendor-prosemirror-markdown-rpUTSG_Q.js +0 -663
  230. package/dist/vendor-prosemirror-model-DAA3avbR.js +0 -2730
  231. package/dist/vendor-prosemirror-schema-list-BNJkECdS.js +0 -87
  232. package/dist/vendor-prosemirror-state-IeimrELV.js +0 -821
  233. package/dist/vendor-prosemirror-tables-zVUKdbdQ.js +0 -1414
  234. package/dist/vendor-prosemirror-transform-BUjWd5Tb.js +0 -1525
  235. package/dist/vendor-prosemirror-view-DFpBkGRq.js +0 -3794
  236. package/dist/vendor-punycode-js-CgGegfA_.js +0 -133
  237. package/dist/vendor-rope-sequence-BWC2FSrq.js +0 -100
  238. package/dist/vendor-semver-Dar8oU3V.js +0 -1023
  239. package/dist/vendor-striptags-BrHtQQiF.js +0 -120
  240. package/dist/vendor-stylis-ClfDrgKE.js +0 -334
  241. package/dist/vendor-swiper-1bp0oJwt.js +0 -3387
  242. package/dist/vendor-tanstack-vue-virtual-CD9yLWd7.js +0 -1
  243. package/dist/vendor-throttle-debounce-CX0imT7m.js +0 -28
  244. package/dist/vendor-tiptap-core-CDScflP1.js +0 -3921
  245. package/dist/vendor-tiptap-extension-blockquote-ChRAwuus.js +0 -55
  246. package/dist/vendor-tiptap-extension-bold-BwoVpOFS.js +0 -74
  247. package/dist/vendor-tiptap-extension-code-DOlgG3ih.js +0 -52
  248. package/dist/vendor-tiptap-extension-code-block-CMeTs87s.js +0 -215
  249. package/dist/vendor-tiptap-extension-document-DO8oly70.js +0 -12
  250. package/dist/vendor-tiptap-extension-hard-break-BgDl2sHf.js +0 -59
  251. package/dist/vendor-tiptap-extension-heading-DFuYlwHi.js +0 -63
  252. package/dist/vendor-tiptap-extension-horizontal-rule-uyfttMp9.js +0 -56
  253. package/dist/vendor-tiptap-extension-image-DPeBaTE3.js +0 -128
  254. package/dist/vendor-tiptap-extension-italic-C9-3jNxO.js +0 -73
  255. package/dist/vendor-tiptap-extension-link-B57VzStq.js +0 -312
  256. package/dist/vendor-tiptap-extension-list-spvOF7Mz.js +0 -722
  257. package/dist/vendor-tiptap-extension-paragraph-Cj7auQB7.js +0 -44
  258. package/dist/vendor-tiptap-extension-placeholder-DhwvmZ6Y.js +0 -1
  259. package/dist/vendor-tiptap-extension-strike-yj6UvnkO.js +0 -64
  260. package/dist/vendor-tiptap-extension-table-cell-CQpTPSvF.js +0 -1
  261. package/dist/vendor-tiptap-extension-table-ex1kZQ-9.js +0 -374
  262. package/dist/vendor-tiptap-extension-table-header-CQpTPSvF.js +0 -1
  263. package/dist/vendor-tiptap-extension-table-row-CQpTPSvF.js +0 -1
  264. package/dist/vendor-tiptap-extension-text-C8FG4KnI.js +0 -13
  265. package/dist/vendor-tiptap-extension-text-style-DsQDXowp.js +0 -235
  266. package/dist/vendor-tiptap-extension-underline-HB3fg6Dc.js +0 -65
  267. package/dist/vendor-tiptap-extensions-CUGwjzl5.js +0 -296
  268. package/dist/vendor-tiptap-markdown-DLzeP3KU.js +0 -826
  269. package/dist/vendor-tiptap-pm-DSHuSumV.js +0 -1
  270. package/dist/vendor-tiptap-starter-kit-C42PcJ7J.js +0 -28
  271. package/dist/vendor-tiptap-vue-3-BxWCzu9Z.js +0 -157
  272. package/dist/vendor-truncate-html-r2r8GKvW.js +0 -145
  273. package/dist/vendor-uc-micro-4lbSaZOs.js +0 -17
  274. package/dist/vendor-unovis-ts-Bue71Kwt.js +0 -2382
  275. package/dist/vendor-unovis-vue-C_K1g5KH.js +0 -446
  276. package/dist/vendor-vee-validate-i18n-zT8NxX3R.js +0 -93
  277. package/dist/vendor-vee-validate-rules-4oWUZPpG.js +0 -316
  278. package/dist/vendor-vue-currency-input-CckB4kjx.js +0 -317
  279. package/dist/vendor-vue-demi-CD9yLWd7.js +0 -1
  280. package/dist/vendor-vue-devtools-api-aVYGocXp.js +0 -93
  281. package/dist/vendor-vue-i18n-DeO9Fa9I.js +0 -1387
  282. package/dist/vendor-vue-router-R3V0tq8_.js +0 -6
  283. package/dist/vendor-vue3-application-insights-BmJCYUcp.js +0 -69
  284. package/dist/vendor-vue3-touch-events-DqysuuWh.js +0 -169
  285. package/dist/vendor-vuepic-vue-datepicker-CaZ_qpJp.js +0 -4998
  286. package/dist/vendor-vueuse-components-Be490f6P.js +0 -542
  287. package/dist/vendor-vueuse-core-BW8bO6-j.js +0 -5135
  288. package/dist/vendor-vueuse-shared-bmkWEEYZ.js +0 -1169
  289. package/dist/vendor-w3c-keyname-CLxH8j-f.js +0 -92
  290. package/dist/vendor-web-vitals-vrpLO1bu.js +0 -207
@@ -1,1525 +0,0 @@
1
- import { S as g, R as se, F as w, M as oe, a as le } from "./vendor-prosemirror-model-DAA3avbR.js";
2
- const Q = 65535, U = Math.pow(2, 16);
3
- function ae(s, e) {
4
- return s + e * U;
5
- }
6
- function H(s) {
7
- return s & Q;
8
- }
9
- function he(s) {
10
- return (s - (s & Q)) / U;
11
- }
12
- const V = 1, X = 2, J = 4, Y = 8;
13
- class L {
14
- /**
15
- @internal
16
- */
17
- constructor(e, t, r) {
18
- this.pos = e, this.delInfo = t, this.recover = r;
19
- }
20
- /**
21
- Tells you whether the position was deleted, that is, whether the
22
- step removed the token on the side queried (via the `assoc`)
23
- argument from the document.
24
- */
25
- get deleted() {
26
- return (this.delInfo & Y) > 0;
27
- }
28
- /**
29
- Tells you whether the token before the mapped position was deleted.
30
- */
31
- get deletedBefore() {
32
- return (this.delInfo & (V | J)) > 0;
33
- }
34
- /**
35
- True when the token after the mapped position was deleted.
36
- */
37
- get deletedAfter() {
38
- return (this.delInfo & (X | J)) > 0;
39
- }
40
- /**
41
- Tells whether any of the steps mapped through deletes across the
42
- position (including both the token before and after the
43
- position).
44
- */
45
- get deletedAcross() {
46
- return (this.delInfo & J) > 0;
47
- }
48
- }
49
- class S {
50
- /**
51
- Create a position map. The modifications to the document are
52
- represented as an array of numbers, in which each group of three
53
- represents a modified chunk as `[start, oldSize, newSize]`.
54
- */
55
- constructor(e, t = !1) {
56
- if (this.ranges = e, this.inverted = t, !e.length && S.empty)
57
- return S.empty;
58
- }
59
- /**
60
- @internal
61
- */
62
- recover(e) {
63
- let t = 0, r = H(e);
64
- if (!this.inverted)
65
- for (let n = 0; n < r; n++)
66
- t += this.ranges[n * 3 + 2] - this.ranges[n * 3 + 1];
67
- return this.ranges[r * 3] + t + he(e);
68
- }
69
- mapResult(e, t = 1) {
70
- return this._map(e, t, !1);
71
- }
72
- map(e, t = 1) {
73
- return this._map(e, t, !0);
74
- }
75
- /**
76
- @internal
77
- */
78
- _map(e, t, r) {
79
- let n = 0, i = this.inverted ? 2 : 1, o = this.inverted ? 1 : 2;
80
- for (let l = 0; l < this.ranges.length; l += 3) {
81
- let a = this.ranges[l] - (this.inverted ? n : 0);
82
- if (a > e)
83
- break;
84
- let h = this.ranges[l + i], p = this.ranges[l + o], c = a + h;
85
- if (e <= c) {
86
- let f = h ? e == a ? -1 : e == c ? 1 : t : t, d = a + n + (f < 0 ? 0 : p);
87
- if (r)
88
- return d;
89
- let u = e == (t < 0 ? a : c) ? null : ae(l / 3, e - a), m = e == a ? X : e == c ? V : J;
90
- return (t < 0 ? e != a : e != c) && (m |= Y), new L(d, m, u);
91
- }
92
- n += p - h;
93
- }
94
- return r ? e + n : new L(e + n, 0, null);
95
- }
96
- /**
97
- @internal
98
- */
99
- touches(e, t) {
100
- let r = 0, n = H(t), i = this.inverted ? 2 : 1, o = this.inverted ? 1 : 2;
101
- for (let l = 0; l < this.ranges.length; l += 3) {
102
- let a = this.ranges[l] - (this.inverted ? r : 0);
103
- if (a > e)
104
- break;
105
- let h = this.ranges[l + i], p = a + h;
106
- if (e <= p && l == n * 3)
107
- return !0;
108
- r += this.ranges[l + o] - h;
109
- }
110
- return !1;
111
- }
112
- /**
113
- Calls the given function on each of the changed ranges included in
114
- this map.
115
- */
116
- forEach(e) {
117
- let t = this.inverted ? 2 : 1, r = this.inverted ? 1 : 2;
118
- for (let n = 0, i = 0; n < this.ranges.length; n += 3) {
119
- let o = this.ranges[n], l = o - (this.inverted ? i : 0), a = o + (this.inverted ? 0 : i), h = this.ranges[n + t], p = this.ranges[n + r];
120
- e(l, l + h, a, a + p), i += p - h;
121
- }
122
- }
123
- /**
124
- Create an inverted version of this map. The result can be used to
125
- map positions in the post-step document to the pre-step document.
126
- */
127
- invert() {
128
- return new S(this.ranges, !this.inverted);
129
- }
130
- /**
131
- @internal
132
- */
133
- toString() {
134
- return (this.inverted ? "-" : "") + JSON.stringify(this.ranges);
135
- }
136
- /**
137
- Create a map that moves all positions by offset `n` (which may be
138
- negative). This can be useful when applying steps meant for a
139
- sub-document to a larger document, or vice-versa.
140
- */
141
- static offset(e) {
142
- return e == 0 ? S.empty : new S(e < 0 ? [0, -e, 0] : [0, 0, e]);
143
- }
144
- }
145
- S.empty = new S([]);
146
- class A {
147
- /**
148
- Create a new mapping with the given position maps.
149
- */
150
- constructor(e, t, r = 0, n = e ? e.length : 0) {
151
- this.mirror = t, this.from = r, this.to = n, this._maps = e || [], this.ownData = !(e || t);
152
- }
153
- /**
154
- The step maps in this mapping.
155
- */
156
- get maps() {
157
- return this._maps;
158
- }
159
- /**
160
- Create a mapping that maps only through a part of this one.
161
- */
162
- slice(e = 0, t = this.maps.length) {
163
- return new A(this._maps, this.mirror, e, t);
164
- }
165
- /**
166
- Add a step map to the end of this mapping. If `mirrors` is
167
- given, it should be the index of the step map that is the mirror
168
- image of this one.
169
- */
170
- appendMap(e, t) {
171
- this.ownData || (this._maps = this._maps.slice(), this.mirror = this.mirror && this.mirror.slice(), this.ownData = !0), this.to = this._maps.push(e), t != null && this.setMirror(this._maps.length - 1, t);
172
- }
173
- /**
174
- Add all the step maps in a given mapping to this one (preserving
175
- mirroring information).
176
- */
177
- appendMapping(e) {
178
- for (let t = 0, r = this._maps.length; t < e._maps.length; t++) {
179
- let n = e.getMirror(t);
180
- this.appendMap(e._maps[t], n != null && n < t ? r + n : void 0);
181
- }
182
- }
183
- /**
184
- Finds the offset of the step map that mirrors the map at the
185
- given offset, in this mapping (as per the second argument to
186
- `appendMap`).
187
- */
188
- getMirror(e) {
189
- if (this.mirror) {
190
- for (let t = 0; t < this.mirror.length; t++)
191
- if (this.mirror[t] == e)
192
- return this.mirror[t + (t % 2 ? -1 : 1)];
193
- }
194
- }
195
- /**
196
- @internal
197
- */
198
- setMirror(e, t) {
199
- this.mirror || (this.mirror = []), this.mirror.push(e, t);
200
- }
201
- /**
202
- Append the inverse of the given mapping to this one.
203
- */
204
- appendMappingInverted(e) {
205
- for (let t = e.maps.length - 1, r = this._maps.length + e._maps.length; t >= 0; t--) {
206
- let n = e.getMirror(t);
207
- this.appendMap(e._maps[t].invert(), n != null && n > t ? r - n - 1 : void 0);
208
- }
209
- }
210
- /**
211
- Create an inverted version of this mapping.
212
- */
213
- invert() {
214
- let e = new A();
215
- return e.appendMappingInverted(this), e;
216
- }
217
- /**
218
- Map a position through this mapping.
219
- */
220
- map(e, t = 1) {
221
- if (this.mirror)
222
- return this._map(e, t, !0);
223
- for (let r = this.from; r < this.to; r++)
224
- e = this._maps[r].map(e, t);
225
- return e;
226
- }
227
- /**
228
- Map a position through this mapping, returning a mapping
229
- result.
230
- */
231
- mapResult(e, t = 1) {
232
- return this._map(e, t, !1);
233
- }
234
- /**
235
- @internal
236
- */
237
- _map(e, t, r) {
238
- let n = 0;
239
- for (let i = this.from; i < this.to; i++) {
240
- let o = this._maps[i], l = o.mapResult(e, t);
241
- if (l.recover != null) {
242
- let a = this.getMirror(i);
243
- if (a != null && a > i && a < this.to) {
244
- i = a, e = this._maps[a].recover(l.recover);
245
- continue;
246
- }
247
- }
248
- n |= l.delInfo, e = l.pos;
249
- }
250
- return r ? e : new L(e, n, null);
251
- }
252
- }
253
- const B = /* @__PURE__ */ Object.create(null);
254
- class k {
255
- /**
256
- Get the step map that represents the changes made by this step,
257
- and which can be used to transform between positions in the old
258
- and the new document.
259
- */
260
- getMap() {
261
- return S.empty;
262
- }
263
- /**
264
- Try to merge this step with another one, to be applied directly
265
- after it. Returns the merged step when possible, null if the
266
- steps can't be merged.
267
- */
268
- merge(e) {
269
- return null;
270
- }
271
- /**
272
- Deserialize a step from its JSON representation. Will call
273
- through to the step class' own implementation of this method.
274
- */
275
- static fromJSON(e, t) {
276
- if (!t || !t.stepType)
277
- throw new RangeError("Invalid input for Step.fromJSON");
278
- let r = B[t.stepType];
279
- if (!r)
280
- throw new RangeError(`No step type ${t.stepType} defined`);
281
- return r.fromJSON(e, t);
282
- }
283
- /**
284
- To be able to serialize steps to JSON, each step needs a string
285
- ID to attach to its JSON representation. Use this method to
286
- register an ID for your step classes. Try to pick something
287
- that's unlikely to clash with steps from other modules.
288
- */
289
- static jsonID(e, t) {
290
- if (e in B)
291
- throw new RangeError("Duplicate use of step JSON ID " + e);
292
- return B[e] = t, t.prototype.jsonID = e, t;
293
- }
294
- }
295
- class y {
296
- /**
297
- @internal
298
- */
299
- constructor(e, t) {
300
- this.doc = e, this.failed = t;
301
- }
302
- /**
303
- Create a successful step result.
304
- */
305
- static ok(e) {
306
- return new y(e, null);
307
- }
308
- /**
309
- Create a failed step result.
310
- */
311
- static fail(e) {
312
- return new y(null, e);
313
- }
314
- /**
315
- Call [`Node.replace`](https://prosemirror.net/docs/ref/#model.Node.replace) with the given
316
- arguments. Create a successful result if it succeeds, and a
317
- failed one if it throws a `ReplaceError`.
318
- */
319
- static fromReplace(e, t, r, n) {
320
- try {
321
- return y.ok(e.replace(t, r, n));
322
- } catch (i) {
323
- if (i instanceof se)
324
- return y.fail(i.message);
325
- throw i;
326
- }
327
- }
328
- }
329
- function P(s, e, t) {
330
- let r = [];
331
- for (let n = 0; n < s.childCount; n++) {
332
- let i = s.child(n);
333
- i.content.size && (i = i.copy(P(i.content, e, i))), i.isInline && (i = e(i, t, n)), r.push(i);
334
- }
335
- return w.fromArray(r);
336
- }
337
- class C extends k {
338
- /**
339
- Create a mark step.
340
- */
341
- constructor(e, t, r) {
342
- super(), this.from = e, this.to = t, this.mark = r;
343
- }
344
- apply(e) {
345
- let t = e.slice(this.from, this.to), r = e.resolve(this.from), n = r.node(r.sharedDepth(this.to)), i = new g(P(t.content, (o, l) => !o.isAtom || !l.type.allowsMarkType(this.mark.type) ? o : o.mark(this.mark.addToSet(o.marks)), n), t.openStart, t.openEnd);
346
- return y.fromReplace(e, this.from, this.to, i);
347
- }
348
- invert() {
349
- return new b(this.from, this.to, this.mark);
350
- }
351
- map(e) {
352
- let t = e.mapResult(this.from, 1), r = e.mapResult(this.to, -1);
353
- return t.deleted && r.deleted || t.pos >= r.pos ? null : new C(t.pos, r.pos, this.mark);
354
- }
355
- merge(e) {
356
- return e instanceof C && e.mark.eq(this.mark) && this.from <= e.to && this.to >= e.from ? new C(Math.min(this.from, e.from), Math.max(this.to, e.to), this.mark) : null;
357
- }
358
- toJSON() {
359
- return {
360
- stepType: "addMark",
361
- mark: this.mark.toJSON(),
362
- from: this.from,
363
- to: this.to
364
- };
365
- }
366
- /**
367
- @internal
368
- */
369
- static fromJSON(e, t) {
370
- if (typeof t.from != "number" || typeof t.to != "number")
371
- throw new RangeError("Invalid input for AddMarkStep.fromJSON");
372
- return new C(t.from, t.to, e.markFromJSON(t.mark));
373
- }
374
- }
375
- k.jsonID("addMark", C);
376
- class b extends k {
377
- /**
378
- Create a mark-removing step.
379
- */
380
- constructor(e, t, r) {
381
- super(), this.from = e, this.to = t, this.mark = r;
382
- }
383
- apply(e) {
384
- let t = e.slice(this.from, this.to), r = new g(P(t.content, (n) => n.mark(this.mark.removeFromSet(n.marks)), e), t.openStart, t.openEnd);
385
- return y.fromReplace(e, this.from, this.to, r);
386
- }
387
- invert() {
388
- return new C(this.from, this.to, this.mark);
389
- }
390
- map(e) {
391
- let t = e.mapResult(this.from, 1), r = e.mapResult(this.to, -1);
392
- return t.deleted && r.deleted || t.pos >= r.pos ? null : new b(t.pos, r.pos, this.mark);
393
- }
394
- merge(e) {
395
- return e instanceof b && e.mark.eq(this.mark) && this.from <= e.to && this.to >= e.from ? new b(Math.min(this.from, e.from), Math.max(this.to, e.to), this.mark) : null;
396
- }
397
- toJSON() {
398
- return {
399
- stepType: "removeMark",
400
- mark: this.mark.toJSON(),
401
- from: this.from,
402
- to: this.to
403
- };
404
- }
405
- /**
406
- @internal
407
- */
408
- static fromJSON(e, t) {
409
- if (typeof t.from != "number" || typeof t.to != "number")
410
- throw new RangeError("Invalid input for RemoveMarkStep.fromJSON");
411
- return new b(t.from, t.to, e.markFromJSON(t.mark));
412
- }
413
- }
414
- k.jsonID("removeMark", b);
415
- class N extends k {
416
- /**
417
- Create a node mark step.
418
- */
419
- constructor(e, t) {
420
- super(), this.pos = e, this.mark = t;
421
- }
422
- apply(e) {
423
- let t = e.nodeAt(this.pos);
424
- if (!t)
425
- return y.fail("No node at mark step's position");
426
- let r = t.type.create(t.attrs, null, this.mark.addToSet(t.marks));
427
- return y.fromReplace(e, this.pos, this.pos + 1, new g(w.from(r), 0, t.isLeaf ? 0 : 1));
428
- }
429
- invert(e) {
430
- let t = e.nodeAt(this.pos);
431
- if (t) {
432
- let r = this.mark.addToSet(t.marks);
433
- if (r.length == t.marks.length) {
434
- for (let n = 0; n < t.marks.length; n++)
435
- if (!t.marks[n].isInSet(r))
436
- return new N(this.pos, t.marks[n]);
437
- return new N(this.pos, this.mark);
438
- }
439
- }
440
- return new I(this.pos, this.mark);
441
- }
442
- map(e) {
443
- let t = e.mapResult(this.pos, 1);
444
- return t.deletedAfter ? null : new N(t.pos, this.mark);
445
- }
446
- toJSON() {
447
- return { stepType: "addNodeMark", pos: this.pos, mark: this.mark.toJSON() };
448
- }
449
- /**
450
- @internal
451
- */
452
- static fromJSON(e, t) {
453
- if (typeof t.pos != "number")
454
- throw new RangeError("Invalid input for AddNodeMarkStep.fromJSON");
455
- return new N(t.pos, e.markFromJSON(t.mark));
456
- }
457
- }
458
- k.jsonID("addNodeMark", N);
459
- class I extends k {
460
- /**
461
- Create a mark-removing step.
462
- */
463
- constructor(e, t) {
464
- super(), this.pos = e, this.mark = t;
465
- }
466
- apply(e) {
467
- let t = e.nodeAt(this.pos);
468
- if (!t)
469
- return y.fail("No node at mark step's position");
470
- let r = t.type.create(t.attrs, null, this.mark.removeFromSet(t.marks));
471
- return y.fromReplace(e, this.pos, this.pos + 1, new g(w.from(r), 0, t.isLeaf ? 0 : 1));
472
- }
473
- invert(e) {
474
- let t = e.nodeAt(this.pos);
475
- return !t || !this.mark.isInSet(t.marks) ? this : new N(this.pos, this.mark);
476
- }
477
- map(e) {
478
- let t = e.mapResult(this.pos, 1);
479
- return t.deletedAfter ? null : new I(t.pos, this.mark);
480
- }
481
- toJSON() {
482
- return { stepType: "removeNodeMark", pos: this.pos, mark: this.mark.toJSON() };
483
- }
484
- /**
485
- @internal
486
- */
487
- static fromJSON(e, t) {
488
- if (typeof t.pos != "number")
489
- throw new RangeError("Invalid input for RemoveNodeMarkStep.fromJSON");
490
- return new I(t.pos, e.markFromJSON(t.mark));
491
- }
492
- }
493
- k.jsonID("removeNodeMark", I);
494
- class v extends k {
495
- /**
496
- The given `slice` should fit the 'gap' between `from` and
497
- `to`—the depths must line up, and the surrounding nodes must be
498
- able to be joined with the open sides of the slice. When
499
- `structure` is true, the step will fail if the content between
500
- from and to is not just a sequence of closing and then opening
501
- tokens (this is to guard against rebased replace steps
502
- overwriting something they weren't supposed to).
503
- */
504
- constructor(e, t, r, n = !1) {
505
- super(), this.from = e, this.to = t, this.slice = r, this.structure = n;
506
- }
507
- apply(e) {
508
- return this.structure && q(e, this.from, this.to) ? y.fail("Structure replace would overwrite content") : y.fromReplace(e, this.from, this.to, this.slice);
509
- }
510
- getMap() {
511
- return new S([this.from, this.to - this.from, this.slice.size]);
512
- }
513
- invert(e) {
514
- return new v(this.from, this.from + this.slice.size, e.slice(this.from, this.to));
515
- }
516
- map(e) {
517
- let t = e.mapResult(this.from, 1), r = e.mapResult(this.to, -1);
518
- return t.deletedAcross && r.deletedAcross ? null : new v(t.pos, Math.max(t.pos, r.pos), this.slice, this.structure);
519
- }
520
- merge(e) {
521
- if (!(e instanceof v) || e.structure || this.structure)
522
- return null;
523
- if (this.from + this.slice.size == e.from && !this.slice.openEnd && !e.slice.openStart) {
524
- let t = this.slice.size + e.slice.size == 0 ? g.empty : new g(this.slice.content.append(e.slice.content), this.slice.openStart, e.slice.openEnd);
525
- return new v(this.from, this.to + (e.to - e.from), t, this.structure);
526
- } else if (e.to == this.from && !this.slice.openStart && !e.slice.openEnd) {
527
- let t = this.slice.size + e.slice.size == 0 ? g.empty : new g(e.slice.content.append(this.slice.content), e.slice.openStart, this.slice.openEnd);
528
- return new v(e.from, this.to, t, this.structure);
529
- } else
530
- return null;
531
- }
532
- toJSON() {
533
- let e = { stepType: "replace", from: this.from, to: this.to };
534
- return this.slice.size && (e.slice = this.slice.toJSON()), this.structure && (e.structure = !0), e;
535
- }
536
- /**
537
- @internal
538
- */
539
- static fromJSON(e, t) {
540
- if (typeof t.from != "number" || typeof t.to != "number")
541
- throw new RangeError("Invalid input for ReplaceStep.fromJSON");
542
- return new v(t.from, t.to, g.fromJSON(e, t.slice), !!t.structure);
543
- }
544
- }
545
- k.jsonID("replace", v);
546
- class M extends k {
547
- /**
548
- Create a replace-around step with the given range and gap.
549
- `insert` should be the point in the slice into which the content
550
- of the gap should be moved. `structure` has the same meaning as
551
- it has in the [`ReplaceStep`](https://prosemirror.net/docs/ref/#transform.ReplaceStep) class.
552
- */
553
- constructor(e, t, r, n, i, o, l = !1) {
554
- super(), this.from = e, this.to = t, this.gapFrom = r, this.gapTo = n, this.slice = i, this.insert = o, this.structure = l;
555
- }
556
- apply(e) {
557
- if (this.structure && (q(e, this.from, this.gapFrom) || q(e, this.gapTo, this.to)))
558
- return y.fail("Structure gap-replace would overwrite content");
559
- let t = e.slice(this.gapFrom, this.gapTo);
560
- if (t.openStart || t.openEnd)
561
- return y.fail("Gap is not a flat range");
562
- let r = this.slice.insertAt(this.insert, t.content);
563
- return r ? y.fromReplace(e, this.from, this.to, r) : y.fail("Content does not fit in gap");
564
- }
565
- getMap() {
566
- return new S([
567
- this.from,
568
- this.gapFrom - this.from,
569
- this.insert,
570
- this.gapTo,
571
- this.to - this.gapTo,
572
- this.slice.size - this.insert
573
- ]);
574
- }
575
- invert(e) {
576
- let t = this.gapTo - this.gapFrom;
577
- return new M(this.from, this.from + this.slice.size + t, this.from + this.insert, this.from + this.insert + t, e.slice(this.from, this.to).removeBetween(this.gapFrom - this.from, this.gapTo - this.from), this.gapFrom - this.from, this.structure);
578
- }
579
- map(e) {
580
- let t = e.mapResult(this.from, 1), r = e.mapResult(this.to, -1), n = this.from == this.gapFrom ? t.pos : e.map(this.gapFrom, -1), i = this.to == this.gapTo ? r.pos : e.map(this.gapTo, 1);
581
- return t.deletedAcross && r.deletedAcross || n < t.pos || i > r.pos ? null : new M(t.pos, r.pos, n, i, this.slice, this.insert, this.structure);
582
- }
583
- toJSON() {
584
- let e = {
585
- stepType: "replaceAround",
586
- from: this.from,
587
- to: this.to,
588
- gapFrom: this.gapFrom,
589
- gapTo: this.gapTo,
590
- insert: this.insert
591
- };
592
- return this.slice.size && (e.slice = this.slice.toJSON()), this.structure && (e.structure = !0), e;
593
- }
594
- /**
595
- @internal
596
- */
597
- static fromJSON(e, t) {
598
- if (typeof t.from != "number" || typeof t.to != "number" || typeof t.gapFrom != "number" || typeof t.gapTo != "number" || typeof t.insert != "number")
599
- throw new RangeError("Invalid input for ReplaceAroundStep.fromJSON");
600
- return new M(t.from, t.to, t.gapFrom, t.gapTo, g.fromJSON(e, t.slice), t.insert, !!t.structure);
601
- }
602
- }
603
- k.jsonID("replaceAround", M);
604
- function q(s, e, t) {
605
- let r = s.resolve(e), n = t - e, i = r.depth;
606
- for (; n > 0 && i > 0 && r.indexAfter(i) == r.node(i).childCount; )
607
- i--, n--;
608
- if (n > 0) {
609
- let o = r.node(i).maybeChild(r.indexAfter(i));
610
- for (; n > 0; ) {
611
- if (!o || o.isLeaf)
612
- return !0;
613
- o = o.firstChild, n--;
614
- }
615
- }
616
- return !1;
617
- }
618
- function pe(s, e, t, r) {
619
- let n = [], i = [], o, l;
620
- s.doc.nodesBetween(e, t, (a, h, p) => {
621
- if (!a.isInline)
622
- return;
623
- let c = a.marks;
624
- if (!r.isInSet(c) && p.type.allowsMarkType(r.type)) {
625
- let f = Math.max(h, e), d = Math.min(h + a.nodeSize, t), u = r.addToSet(c);
626
- for (let m = 0; m < c.length; m++)
627
- c[m].isInSet(u) || (o && o.to == f && o.mark.eq(c[m]) ? o.to = d : n.push(o = new b(f, d, c[m])));
628
- l && l.to == f ? l.to = d : i.push(l = new C(f, d, r));
629
- }
630
- }), n.forEach((a) => s.step(a)), i.forEach((a) => s.step(a));
631
- }
632
- function fe(s, e, t, r) {
633
- let n = [], i = 0;
634
- s.doc.nodesBetween(e, t, (o, l) => {
635
- if (!o.isInline)
636
- return;
637
- i++;
638
- let a = null;
639
- if (r instanceof le) {
640
- let h = o.marks, p;
641
- for (; p = r.isInSet(h); )
642
- (a || (a = [])).push(p), h = p.removeFromSet(h);
643
- } else r ? r.isInSet(o.marks) && (a = [r]) : a = o.marks;
644
- if (a && a.length) {
645
- let h = Math.min(l + o.nodeSize, t);
646
- for (let p = 0; p < a.length; p++) {
647
- let c = a[p], f;
648
- for (let d = 0; d < n.length; d++) {
649
- let u = n[d];
650
- u.step == i - 1 && c.eq(n[d].style) && (f = u);
651
- }
652
- f ? (f.to = h, f.step = i) : n.push({ style: c, from: Math.max(l, e), to: h, step: i });
653
- }
654
- }
655
- }), n.forEach((o) => s.step(new b(o.from, o.to, o.style)));
656
- }
657
- function $(s, e, t, r = t.contentMatch, n = !0) {
658
- let i = s.doc.nodeAt(e), o = [], l = e + 1;
659
- for (let a = 0; a < i.childCount; a++) {
660
- let h = i.child(a), p = l + h.nodeSize, c = r.matchType(h.type);
661
- if (!c)
662
- o.push(new v(l, p, g.empty));
663
- else {
664
- r = c;
665
- for (let f = 0; f < h.marks.length; f++)
666
- t.allowsMarkType(h.marks[f].type) || s.step(new b(l, p, h.marks[f]));
667
- if (n && h.isText && t.whitespace != "pre") {
668
- let f, d = /\r?\n|\r/g, u;
669
- for (; f = d.exec(h.text); )
670
- u || (u = new g(w.from(t.schema.text(" ", t.allowedMarks(h.marks))), 0, 0)), o.push(new v(l + f.index, l + f.index + f[0].length, u));
671
- }
672
- }
673
- l = p;
674
- }
675
- if (!r.validEnd) {
676
- let a = r.fillBefore(w.empty, !0);
677
- s.replace(l, l, new g(a, 0, 0));
678
- }
679
- for (let a = o.length - 1; a >= 0; a--)
680
- s.step(o[a]);
681
- }
682
- function ce(s, e, t) {
683
- return (e == 0 || s.canReplace(e, s.childCount)) && (t == s.childCount || s.canReplace(0, t));
684
- }
685
- function Fe(s) {
686
- let t = s.parent.content.cutByIndex(s.startIndex, s.endIndex);
687
- for (let r = s.depth, n = 0, i = 0; ; --r) {
688
- let o = s.$from.node(r), l = s.$from.index(r) + n, a = s.$to.indexAfter(r) - i;
689
- if (r < s.depth && o.canReplace(l, a, t))
690
- return r;
691
- if (r == 0 || o.type.spec.isolating || !ce(o, l, a))
692
- break;
693
- l && (n = 1), a < o.childCount && (i = 1);
694
- }
695
- return null;
696
- }
697
- function de(s, e, t) {
698
- let { $from: r, $to: n, depth: i } = e, o = r.before(i + 1), l = n.after(i + 1), a = o, h = l, p = w.empty, c = 0;
699
- for (let u = i, m = !1; u > t; u--)
700
- m || r.index(u) > 0 ? (m = !0, p = w.from(r.node(u).copy(p)), c++) : a--;
701
- let f = w.empty, d = 0;
702
- for (let u = i, m = !1; u > t; u--)
703
- m || n.after(u + 1) < n.end(u) ? (m = !0, f = w.from(n.node(u).copy(f)), d++) : h++;
704
- s.step(new M(a, h, o, l, new g(p.append(f), c, d), p.size - c, !0));
705
- }
706
- function ze(s, e, t = null, r = s) {
707
- let n = ue(s, e), i = n && me(r, e);
708
- return i ? n.map(K).concat({ type: e, attrs: t }).concat(i.map(K)) : null;
709
- }
710
- function K(s) {
711
- return { type: s, attrs: null };
712
- }
713
- function ue(s, e) {
714
- let { parent: t, startIndex: r, endIndex: n } = s, i = t.contentMatchAt(r).findWrapping(e);
715
- if (!i)
716
- return null;
717
- let o = i.length ? i[0] : e;
718
- return t.canReplaceWith(r, n, o) ? i : null;
719
- }
720
- function me(s, e) {
721
- let { parent: t, startIndex: r, endIndex: n } = s, i = t.child(r), o = e.contentMatch.findWrapping(i.type);
722
- if (!o)
723
- return null;
724
- let a = (o.length ? o[o.length - 1] : e).contentMatch;
725
- for (let h = r; a && h < n; h++)
726
- a = a.matchType(t.child(h).type);
727
- return !a || !a.validEnd ? null : o;
728
- }
729
- function ge(s, e, t) {
730
- let r = w.empty;
731
- for (let o = t.length - 1; o >= 0; o--) {
732
- if (r.size) {
733
- let l = t[o].type.contentMatch.matchFragment(r);
734
- if (!l || !l.validEnd)
735
- throw new RangeError("Wrapper type given to Transform.wrap does not form valid content of its parent wrapper");
736
- }
737
- r = w.from(t[o].type.create(t[o].attrs, r));
738
- }
739
- let n = e.start, i = e.end;
740
- s.step(new M(n, i, n, i, new g(r, 0, 0), t.length, !0));
741
- }
742
- function we(s, e, t, r, n) {
743
- if (!r.isTextblock)
744
- throw new RangeError("Type given to setBlockType should be a textblock");
745
- let i = s.steps.length;
746
- s.doc.nodesBetween(e, t, (o, l) => {
747
- let a = typeof n == "function" ? n(o) : n;
748
- if (o.isTextblock && !o.hasMarkup(r, a) && ye(s.doc, s.mapping.slice(i).map(l), r)) {
749
- let h = null;
750
- if (r.schema.linebreakReplacement) {
751
- let d = r.whitespace == "pre", u = !!r.contentMatch.matchType(r.schema.linebreakReplacement);
752
- d && !u ? h = !1 : !d && u && (h = !0);
753
- }
754
- h === !1 && _(s, o, l, i), $(s, s.mapping.slice(i).map(l, 1), r, void 0, h === null);
755
- let p = s.mapping.slice(i), c = p.map(l, 1), f = p.map(l + o.nodeSize, 1);
756
- return s.step(new M(c, f, c + 1, f - 1, new g(w.from(r.create(a, null, o.marks)), 0, 0), 1, !0)), h === !0 && Z(s, o, l, i), !1;
757
- }
758
- });
759
- }
760
- function Z(s, e, t, r) {
761
- e.forEach((n, i) => {
762
- if (n.isText) {
763
- let o, l = /\r?\n|\r/g;
764
- for (; o = l.exec(n.text); ) {
765
- let a = s.mapping.slice(r).map(t + 1 + i + o.index);
766
- s.replaceWith(a, a + 1, e.type.schema.linebreakReplacement.create());
767
- }
768
- }
769
- });
770
- }
771
- function _(s, e, t, r) {
772
- e.forEach((n, i) => {
773
- if (n.type == n.type.schema.linebreakReplacement) {
774
- let o = s.mapping.slice(r).map(t + 1 + i);
775
- s.replaceWith(o, o + 1, e.type.schema.text(`
776
- `));
777
- }
778
- });
779
- }
780
- function ye(s, e, t) {
781
- let r = s.resolve(e), n = r.index();
782
- return r.parent.canReplaceWith(n, n + 1, t);
783
- }
784
- function ke(s, e, t, r, n) {
785
- let i = s.doc.nodeAt(e);
786
- if (!i)
787
- throw new RangeError("No node at given position");
788
- t || (t = i.type);
789
- let o = t.create(r, null, n || i.marks);
790
- if (i.isLeaf)
791
- return s.replaceWith(e, e + i.nodeSize, o);
792
- if (!t.validContent(i.content))
793
- throw new RangeError("Invalid content for node type " + t.name);
794
- s.step(new M(e, e + i.nodeSize, e + 1, e + i.nodeSize - 1, new g(w.from(o), 0, 0), 1, !0));
795
- }
796
- function Je(s, e, t = 1, r) {
797
- let n = s.resolve(e), i = n.depth - t, o = r && r[r.length - 1] || n.parent;
798
- if (i < 0 || n.parent.type.spec.isolating || !n.parent.canReplace(n.index(), n.parent.childCount) || !o.type.validContent(n.parent.content.cutByIndex(n.index(), n.parent.childCount)))
799
- return !1;
800
- for (let h = n.depth - 1, p = t - 2; h > i; h--, p--) {
801
- let c = n.node(h), f = n.index(h);
802
- if (c.type.spec.isolating)
803
- return !1;
804
- let d = c.content.cutByIndex(f, c.childCount), u = r && r[p + 1];
805
- u && (d = d.replaceChild(0, u.type.create(u.attrs)));
806
- let m = r && r[p] || c;
807
- if (!c.canReplace(f + 1, c.childCount) || !m.type.validContent(d))
808
- return !1;
809
- }
810
- let l = n.indexAfter(i), a = r && r[0];
811
- return n.node(i).canReplaceWith(l, l, a ? a.type : n.node(i + 1).type);
812
- }
813
- function ve(s, e, t = 1, r) {
814
- let n = s.doc.resolve(e), i = w.empty, o = w.empty;
815
- for (let l = n.depth, a = n.depth - t, h = t - 1; l > a; l--, h--) {
816
- i = w.from(n.node(l).copy(i));
817
- let p = r && r[h];
818
- o = w.from(p ? p.type.create(p.attrs, o) : n.node(l).copy(o));
819
- }
820
- s.step(new v(e, e, new g(i.append(o), t, t), !0));
821
- }
822
- function Ae(s, e) {
823
- let t = s.resolve(e), r = t.index();
824
- return j(t.nodeBefore, t.nodeAfter) && t.parent.canReplace(r, r + 1);
825
- }
826
- function xe(s, e) {
827
- e.content.size || s.type.compatibleContent(e.type);
828
- let t = s.contentMatchAt(s.childCount), { linebreakReplacement: r } = s.type.schema;
829
- for (let n = 0; n < e.childCount; n++) {
830
- let i = e.child(n), o = i.type == r ? s.type.schema.nodes.text : i.type;
831
- if (t = t.matchType(o), !t || !s.type.allowsMarks(i.marks))
832
- return !1;
833
- }
834
- return t.validEnd;
835
- }
836
- function j(s, e) {
837
- return !!(s && e && !s.isLeaf && xe(s, e));
838
- }
839
- function Be(s, e, t = -1) {
840
- let r = s.resolve(e);
841
- for (let n = r.depth; ; n--) {
842
- let i, o, l = r.index(n);
843
- if (n == r.depth ? (i = r.nodeBefore, o = r.nodeAfter) : t > 0 ? (i = r.node(n + 1), l++, o = r.node(n).maybeChild(l)) : (i = r.node(n).maybeChild(l - 1), o = r.node(n + 1)), i && !i.isTextblock && j(i, o) && r.node(n).canReplace(l, l + 1))
844
- return e;
845
- if (n == 0)
846
- break;
847
- e = t < 0 ? r.before(n) : r.after(n);
848
- }
849
- }
850
- function Se(s, e, t) {
851
- let r = null, { linebreakReplacement: n } = s.doc.type.schema, i = s.doc.resolve(e - t), o = i.node().type;
852
- if (n && o.inlineContent) {
853
- let p = o.whitespace == "pre", c = !!o.contentMatch.matchType(n);
854
- p && !c ? r = !1 : !p && c && (r = !0);
855
- }
856
- let l = s.steps.length;
857
- if (r === !1) {
858
- let p = s.doc.resolve(e + t);
859
- _(s, p.node(), p.before(), l);
860
- }
861
- o.inlineContent && $(s, e + t - 1, o, i.node().contentMatchAt(i.index()), r == null);
862
- let a = s.mapping.slice(l), h = a.map(e - t);
863
- if (s.step(new v(h, a.map(e + t, -1), g.empty, !0)), r === !0) {
864
- let p = s.doc.resolve(h);
865
- Z(s, p.node(), p.before(), s.steps.length);
866
- }
867
- return s;
868
- }
869
- function be(s, e, t) {
870
- let r = s.resolve(e);
871
- if (r.parent.canReplaceWith(r.index(), r.index(), t))
872
- return e;
873
- if (r.parentOffset == 0)
874
- for (let n = r.depth - 1; n >= 0; n--) {
875
- let i = r.index(n);
876
- if (r.node(n).canReplaceWith(i, i, t))
877
- return r.before(n + 1);
878
- if (i > 0)
879
- return null;
880
- }
881
- if (r.parentOffset == r.parent.content.size)
882
- for (let n = r.depth - 1; n >= 0; n--) {
883
- let i = r.indexAfter(n);
884
- if (r.node(n).canReplaceWith(i, i, t))
885
- return r.after(n + 1);
886
- if (i < r.node(n).childCount)
887
- return null;
888
- }
889
- return null;
890
- }
891
- function We(s, e, t) {
892
- let r = s.resolve(e);
893
- if (!t.content.size)
894
- return e;
895
- let n = t.content;
896
- for (let i = 0; i < t.openStart; i++)
897
- n = n.firstChild.content;
898
- for (let i = 1; i <= (t.openStart == 0 && t.size ? 2 : 1); i++)
899
- for (let o = r.depth; o >= 0; o--) {
900
- let l = o == r.depth ? 0 : r.pos <= (r.start(o + 1) + r.end(o + 1)) / 2 ? -1 : 1, a = r.index(o) + (l > 0 ? 1 : 0), h = r.node(o), p = !1;
901
- if (i == 1)
902
- p = h.canReplace(a, a, n);
903
- else {
904
- let c = h.contentMatchAt(a).findWrapping(n.firstChild.type);
905
- p = c && h.canReplaceWith(a, a, c[0]);
906
- }
907
- if (p)
908
- return l == 0 ? r.pos : l < 0 ? r.before(o + 1) : r.after(o + 1);
909
- }
910
- return null;
911
- }
912
- function Me(s, e, t = e, r = g.empty) {
913
- if (e == t && !r.size)
914
- return null;
915
- let n = s.resolve(e), i = s.resolve(t);
916
- return ee(n, i, r) ? new v(e, t, r) : new Ce(n, i, r).fit();
917
- }
918
- function ee(s, e, t) {
919
- return !t.openStart && !t.openEnd && s.start() == e.start() && s.parent.canReplace(s.index(), e.index(), t.content);
920
- }
921
- class Ce {
922
- constructor(e, t, r) {
923
- this.$from = e, this.$to = t, this.unplaced = r, this.frontier = [], this.placed = w.empty;
924
- for (let n = 0; n <= e.depth; n++) {
925
- let i = e.node(n);
926
- this.frontier.push({
927
- type: i.type,
928
- match: i.contentMatchAt(e.indexAfter(n))
929
- });
930
- }
931
- for (let n = e.depth; n > 0; n--)
932
- this.placed = w.from(e.node(n).copy(this.placed));
933
- }
934
- get depth() {
935
- return this.frontier.length - 1;
936
- }
937
- fit() {
938
- for (; this.unplaced.size; ) {
939
- let h = this.findFittable();
940
- h ? this.placeNodes(h) : this.openMore() || this.dropNode();
941
- }
942
- let e = this.mustMoveInline(), t = this.placed.size - this.depth - this.$from.depth, r = this.$from, n = this.close(e < 0 ? this.$to : r.doc.resolve(e));
943
- if (!n)
944
- return null;
945
- let i = this.placed, o = r.depth, l = n.depth;
946
- for (; o && l && i.childCount == 1; )
947
- i = i.firstChild.content, o--, l--;
948
- let a = new g(i, o, l);
949
- return e > -1 ? new M(r.pos, e, this.$to.pos, this.$to.end(), a, t) : a.size || r.pos != this.$to.pos ? new v(r.pos, n.pos, a) : null;
950
- }
951
- // Find a position on the start spine of `this.unplaced` that has
952
- // content that can be moved somewhere on the frontier. Returns two
953
- // depths, one for the slice and one for the frontier.
954
- findFittable() {
955
- let e = this.unplaced.openStart;
956
- for (let t = this.unplaced.content, r = 0, n = this.unplaced.openEnd; r < e; r++) {
957
- let i = t.firstChild;
958
- if (t.childCount > 1 && (n = 0), i.type.spec.isolating && n <= r) {
959
- e = r;
960
- break;
961
- }
962
- t = i.content;
963
- }
964
- for (let t = 1; t <= 2; t++)
965
- for (let r = t == 1 ? e : this.unplaced.openStart; r >= 0; r--) {
966
- let n, i = null;
967
- r ? (i = W(this.unplaced.content, r - 1).firstChild, n = i.content) : n = this.unplaced.content;
968
- let o = n.firstChild;
969
- for (let l = this.depth; l >= 0; l--) {
970
- let { type: a, match: h } = this.frontier[l], p, c = null;
971
- if (t == 1 && (o ? h.matchType(o.type) || (c = h.fillBefore(w.from(o), !1)) : i && a.compatibleContent(i.type)))
972
- return { sliceDepth: r, frontierDepth: l, parent: i, inject: c };
973
- if (t == 2 && o && (p = h.findWrapping(o.type)))
974
- return { sliceDepth: r, frontierDepth: l, parent: i, wrap: p };
975
- if (i && h.matchType(i.type))
976
- break;
977
- }
978
- }
979
- }
980
- openMore() {
981
- let { content: e, openStart: t, openEnd: r } = this.unplaced, n = W(e, t);
982
- return !n.childCount || n.firstChild.isLeaf ? !1 : (this.unplaced = new g(e, t + 1, Math.max(r, n.size + t >= e.size - r ? t + 1 : 0)), !0);
983
- }
984
- dropNode() {
985
- let { content: e, openStart: t, openEnd: r } = this.unplaced, n = W(e, t);
986
- if (n.childCount <= 1 && t > 0) {
987
- let i = e.size - t <= t + n.size;
988
- this.unplaced = new g(O(e, t - 1, 1), t - 1, i ? t - 1 : r);
989
- } else
990
- this.unplaced = new g(O(e, t, 1), t, r);
991
- }
992
- // Move content from the unplaced slice at `sliceDepth` to the
993
- // frontier node at `frontierDepth`. Close that frontier node when
994
- // applicable.
995
- placeNodes({ sliceDepth: e, frontierDepth: t, parent: r, inject: n, wrap: i }) {
996
- for (; this.depth > t; )
997
- this.closeFrontierNode();
998
- if (i)
999
- for (let m = 0; m < i.length; m++)
1000
- this.openFrontierNode(i[m]);
1001
- let o = this.unplaced, l = r ? r.content : o.content, a = o.openStart - e, h = 0, p = [], { match: c, type: f } = this.frontier[t];
1002
- if (n) {
1003
- for (let m = 0; m < n.childCount; m++)
1004
- p.push(n.child(m));
1005
- c = c.matchFragment(n);
1006
- }
1007
- let d = l.size + e - (o.content.size - o.openEnd);
1008
- for (; h < l.childCount; ) {
1009
- let m = l.child(h), x = c.matchType(m.type);
1010
- if (!x)
1011
- break;
1012
- h++, (h > 1 || a == 0 || m.content.size) && (c = x, p.push(te(m.mark(f.allowedMarks(m.marks)), h == 1 ? a : 0, h == l.childCount ? d : -1)));
1013
- }
1014
- let u = h == l.childCount;
1015
- u || (d = -1), this.placed = F(this.placed, t, w.from(p)), this.frontier[t].match = c, u && d < 0 && r && r.type == this.frontier[this.depth].type && this.frontier.length > 1 && this.closeFrontierNode();
1016
- for (let m = 0, x = l; m < d; m++) {
1017
- let R = x.lastChild;
1018
- this.frontier.push({ type: R.type, match: R.contentMatchAt(R.childCount) }), x = R.content;
1019
- }
1020
- this.unplaced = u ? e == 0 ? g.empty : new g(O(o.content, e - 1, 1), e - 1, d < 0 ? o.openEnd : e - 1) : new g(O(o.content, e, h), o.openStart, o.openEnd);
1021
- }
1022
- mustMoveInline() {
1023
- if (!this.$to.parent.isTextblock)
1024
- return -1;
1025
- let e = this.frontier[this.depth], t;
1026
- if (!e.type.isTextblock || !D(this.$to, this.$to.depth, e.type, e.match, !1) || this.$to.depth == this.depth && (t = this.findCloseLevel(this.$to)) && t.depth == this.depth)
1027
- return -1;
1028
- let { depth: r } = this.$to, n = this.$to.after(r);
1029
- for (; r > 1 && n == this.$to.end(--r); )
1030
- ++n;
1031
- return n;
1032
- }
1033
- findCloseLevel(e) {
1034
- e: for (let t = Math.min(this.depth, e.depth); t >= 0; t--) {
1035
- let { match: r, type: n } = this.frontier[t], i = t < e.depth && e.end(t + 1) == e.pos + (e.depth - (t + 1)), o = D(e, t, n, r, i);
1036
- if (o) {
1037
- for (let l = t - 1; l >= 0; l--) {
1038
- let { match: a, type: h } = this.frontier[l], p = D(e, l, h, a, !0);
1039
- if (!p || p.childCount)
1040
- continue e;
1041
- }
1042
- return { depth: t, fit: o, move: i ? e.doc.resolve(e.after(t + 1)) : e };
1043
- }
1044
- }
1045
- }
1046
- close(e) {
1047
- let t = this.findCloseLevel(e);
1048
- if (!t)
1049
- return null;
1050
- for (; this.depth > t.depth; )
1051
- this.closeFrontierNode();
1052
- t.fit.childCount && (this.placed = F(this.placed, t.depth, t.fit)), e = t.move;
1053
- for (let r = t.depth + 1; r <= e.depth; r++) {
1054
- let n = e.node(r), i = n.type.contentMatch.fillBefore(n.content, !0, e.index(r));
1055
- this.openFrontierNode(n.type, n.attrs, i);
1056
- }
1057
- return e;
1058
- }
1059
- openFrontierNode(e, t = null, r) {
1060
- let n = this.frontier[this.depth];
1061
- n.match = n.match.matchType(e), this.placed = F(this.placed, this.depth, w.from(e.create(t, r))), this.frontier.push({ type: e, match: e.contentMatch });
1062
- }
1063
- closeFrontierNode() {
1064
- let t = this.frontier.pop().match.fillBefore(w.empty, !0);
1065
- t.childCount && (this.placed = F(this.placed, this.frontier.length, t));
1066
- }
1067
- }
1068
- function O(s, e, t) {
1069
- return e == 0 ? s.cutByIndex(t, s.childCount) : s.replaceChild(0, s.firstChild.copy(O(s.firstChild.content, e - 1, t)));
1070
- }
1071
- function F(s, e, t) {
1072
- return e == 0 ? s.append(t) : s.replaceChild(s.childCount - 1, s.lastChild.copy(F(s.lastChild.content, e - 1, t)));
1073
- }
1074
- function W(s, e) {
1075
- for (let t = 0; t < e; t++)
1076
- s = s.firstChild.content;
1077
- return s;
1078
- }
1079
- function te(s, e, t) {
1080
- if (e <= 0)
1081
- return s;
1082
- let r = s.content;
1083
- return e > 1 && (r = r.replaceChild(0, te(r.firstChild, e - 1, r.childCount == 1 ? t - 1 : 0))), e > 0 && (r = s.type.contentMatch.fillBefore(r).append(r), t <= 0 && (r = r.append(s.type.contentMatch.matchFragment(r).fillBefore(w.empty, !0)))), s.copy(r);
1084
- }
1085
- function D(s, e, t, r, n) {
1086
- let i = s.node(e), o = n ? s.indexAfter(e) : s.index(e);
1087
- if (o == i.childCount && !t.compatibleContent(i.type))
1088
- return null;
1089
- let l = r.fillBefore(i.content, !0, o);
1090
- return l && !Ne(t, i.content, o) ? l : null;
1091
- }
1092
- function Ne(s, e, t) {
1093
- for (let r = t; r < e.childCount; r++)
1094
- if (!s.allowsMarks(e.child(r).marks))
1095
- return !0;
1096
- return !1;
1097
- }
1098
- function Re(s) {
1099
- return s.spec.defining || s.spec.definingForContent;
1100
- }
1101
- function Ie(s, e, t, r) {
1102
- if (!r.size)
1103
- return s.deleteRange(e, t);
1104
- let n = s.doc.resolve(e), i = s.doc.resolve(t);
1105
- if (ee(n, i, r))
1106
- return s.step(new v(e, t, r));
1107
- let o = ne(n, i);
1108
- o[o.length - 1] == 0 && o.pop();
1109
- let l = -(n.depth + 1);
1110
- o.unshift(l);
1111
- for (let f = n.depth, d = n.pos - 1; f > 0; f--, d--) {
1112
- let u = n.node(f).type.spec;
1113
- if (u.defining || u.definingAsContext || u.isolating)
1114
- break;
1115
- o.indexOf(f) > -1 ? l = f : n.before(f) == d && o.splice(1, 0, -f);
1116
- }
1117
- let a = o.indexOf(l), h = [], p = r.openStart;
1118
- for (let f = r.content, d = 0; ; d++) {
1119
- let u = f.firstChild;
1120
- if (h.push(u), d == r.openStart)
1121
- break;
1122
- f = u.content;
1123
- }
1124
- for (let f = p - 1; f >= 0; f--) {
1125
- let d = h[f], u = Re(d.type);
1126
- if (u && !d.sameMarkup(n.node(Math.abs(l) - 1)))
1127
- p = f;
1128
- else if (u || !d.type.isTextblock)
1129
- break;
1130
- }
1131
- for (let f = r.openStart; f >= 0; f--) {
1132
- let d = (f + p + 1) % (r.openStart + 1), u = h[d];
1133
- if (u)
1134
- for (let m = 0; m < o.length; m++) {
1135
- let x = o[(m + a) % o.length], R = !0;
1136
- x < 0 && (R = !1, x = -x);
1137
- let ie = n.node(x - 1), G = n.index(x - 1);
1138
- if (ie.canReplaceWith(G, G, u.type, u.marks))
1139
- return s.replace(n.before(x), R ? i.after(x) : t, new g(re(r.content, 0, r.openStart, d), d, r.openEnd));
1140
- }
1141
- }
1142
- let c = s.steps.length;
1143
- for (let f = o.length - 1; f >= 0 && (s.replace(e, t, r), !(s.steps.length > c)); f--) {
1144
- let d = o[f];
1145
- d < 0 || (e = n.before(d), t = i.after(d));
1146
- }
1147
- }
1148
- function re(s, e, t, r, n) {
1149
- if (e < t) {
1150
- let i = s.firstChild;
1151
- s = s.replaceChild(0, i.copy(re(i.content, e + 1, t, r, i)));
1152
- }
1153
- if (e > r) {
1154
- let i = n.contentMatchAt(0), o = i.fillBefore(s).append(s);
1155
- s = o.append(i.matchFragment(o).fillBefore(w.empty, !0));
1156
- }
1157
- return s;
1158
- }
1159
- function Ee(s, e, t, r) {
1160
- if (!r.isInline && e == t && s.doc.resolve(e).parent.content.size) {
1161
- let n = be(s.doc, e, r.type);
1162
- n != null && (e = t = n);
1163
- }
1164
- s.replaceRange(e, t, new g(w.from(r), 0, 0));
1165
- }
1166
- function Te(s, e, t) {
1167
- let r = s.doc.resolve(e), n = s.doc.resolve(t), i = ne(r, n);
1168
- for (let o = 0; o < i.length; o++) {
1169
- let l = i[o], a = o == i.length - 1;
1170
- if (a && l == 0 || r.node(l).type.contentMatch.validEnd)
1171
- return s.delete(r.start(l), n.end(l));
1172
- if (l > 0 && (a || r.node(l - 1).canReplace(r.index(l - 1), n.indexAfter(l - 1))))
1173
- return s.delete(r.before(l), n.after(l));
1174
- }
1175
- for (let o = 1; o <= r.depth && o <= n.depth; o++)
1176
- if (e - r.start(o) == r.depth - o && t > r.end(o) && n.end(o) - t != n.depth - o && r.start(o - 1) == n.start(o - 1) && r.node(o - 1).canReplace(r.index(o - 1), n.index(o - 1)))
1177
- return s.delete(r.before(o), t);
1178
- s.delete(e, t);
1179
- }
1180
- function ne(s, e) {
1181
- let t = [], r = Math.min(s.depth, e.depth);
1182
- for (let n = r; n >= 0; n--) {
1183
- let i = s.start(n);
1184
- if (i < s.pos - (s.depth - n) || e.end(n) > e.pos + (e.depth - n) || s.node(n).type.spec.isolating || e.node(n).type.spec.isolating)
1185
- break;
1186
- (i == e.start(n) || n == s.depth && n == e.depth && s.parent.inlineContent && e.parent.inlineContent && n && e.start(n - 1) == i - 1) && t.push(n);
1187
- }
1188
- return t;
1189
- }
1190
- class E extends k {
1191
- /**
1192
- Construct an attribute step.
1193
- */
1194
- constructor(e, t, r) {
1195
- super(), this.pos = e, this.attr = t, this.value = r;
1196
- }
1197
- apply(e) {
1198
- let t = e.nodeAt(this.pos);
1199
- if (!t)
1200
- return y.fail("No node at attribute step's position");
1201
- let r = /* @__PURE__ */ Object.create(null);
1202
- for (let i in t.attrs)
1203
- r[i] = t.attrs[i];
1204
- r[this.attr] = this.value;
1205
- let n = t.type.create(r, null, t.marks);
1206
- return y.fromReplace(e, this.pos, this.pos + 1, new g(w.from(n), 0, t.isLeaf ? 0 : 1));
1207
- }
1208
- getMap() {
1209
- return S.empty;
1210
- }
1211
- invert(e) {
1212
- return new E(this.pos, this.attr, e.nodeAt(this.pos).attrs[this.attr]);
1213
- }
1214
- map(e) {
1215
- let t = e.mapResult(this.pos, 1);
1216
- return t.deletedAfter ? null : new E(t.pos, this.attr, this.value);
1217
- }
1218
- toJSON() {
1219
- return { stepType: "attr", pos: this.pos, attr: this.attr, value: this.value };
1220
- }
1221
- static fromJSON(e, t) {
1222
- if (typeof t.pos != "number" || typeof t.attr != "string")
1223
- throw new RangeError("Invalid input for AttrStep.fromJSON");
1224
- return new E(t.pos, t.attr, t.value);
1225
- }
1226
- }
1227
- k.jsonID("attr", E);
1228
- class z extends k {
1229
- /**
1230
- Construct an attribute step.
1231
- */
1232
- constructor(e, t) {
1233
- super(), this.attr = e, this.value = t;
1234
- }
1235
- apply(e) {
1236
- let t = /* @__PURE__ */ Object.create(null);
1237
- for (let n in e.attrs)
1238
- t[n] = e.attrs[n];
1239
- t[this.attr] = this.value;
1240
- let r = e.type.create(t, e.content, e.marks);
1241
- return y.ok(r);
1242
- }
1243
- getMap() {
1244
- return S.empty;
1245
- }
1246
- invert(e) {
1247
- return new z(this.attr, e.attrs[this.attr]);
1248
- }
1249
- map(e) {
1250
- return this;
1251
- }
1252
- toJSON() {
1253
- return { stepType: "docAttr", attr: this.attr, value: this.value };
1254
- }
1255
- static fromJSON(e, t) {
1256
- if (typeof t.attr != "string")
1257
- throw new RangeError("Invalid input for DocAttrStep.fromJSON");
1258
- return new z(t.attr, t.value);
1259
- }
1260
- }
1261
- k.jsonID("docAttr", z);
1262
- let T = class extends Error {
1263
- };
1264
- T = function s(e) {
1265
- let t = Error.call(this, e);
1266
- return t.__proto__ = s.prototype, t;
1267
- };
1268
- T.prototype = Object.create(Error.prototype);
1269
- T.prototype.constructor = T;
1270
- T.prototype.name = "TransformError";
1271
- class De {
1272
- /**
1273
- Create a transform that starts with the given document.
1274
- */
1275
- constructor(e) {
1276
- this.doc = e, this.steps = [], this.docs = [], this.mapping = new A();
1277
- }
1278
- /**
1279
- The starting document.
1280
- */
1281
- get before() {
1282
- return this.docs.length ? this.docs[0] : this.doc;
1283
- }
1284
- /**
1285
- Apply a new step in this transform, saving the result. Throws an
1286
- error when the step fails.
1287
- */
1288
- step(e) {
1289
- let t = this.maybeStep(e);
1290
- if (t.failed)
1291
- throw new T(t.failed);
1292
- return this;
1293
- }
1294
- /**
1295
- Try to apply a step in this transformation, ignoring it if it
1296
- fails. Returns the step result.
1297
- */
1298
- maybeStep(e) {
1299
- let t = e.apply(this.doc);
1300
- return t.failed || this.addStep(e, t.doc), t;
1301
- }
1302
- /**
1303
- True when the document has been changed (when there are any
1304
- steps).
1305
- */
1306
- get docChanged() {
1307
- return this.steps.length > 0;
1308
- }
1309
- /**
1310
- Return a single range, in post-transform document positions,
1311
- that covers all content changed by this transform. Returns null
1312
- if no replacements are made. Note that this will ignore changes
1313
- that add/remove marks without replacing the underlying content.
1314
- */
1315
- changedRange() {
1316
- let e = 1e9, t = -1e9;
1317
- for (let r = 0; r < this.mapping.maps.length; r++) {
1318
- let n = this.mapping.maps[r];
1319
- r && (e = n.map(e, 1), t = n.map(t, -1)), n.forEach((i, o, l, a) => {
1320
- e = Math.min(e, l), t = Math.max(t, a);
1321
- });
1322
- }
1323
- return e == 1e9 ? null : { from: e, to: t };
1324
- }
1325
- /**
1326
- @internal
1327
- */
1328
- addStep(e, t) {
1329
- this.docs.push(this.doc), this.steps.push(e), this.mapping.appendMap(e.getMap()), this.doc = t;
1330
- }
1331
- /**
1332
- Replace the part of the document between `from` and `to` with the
1333
- given `slice`.
1334
- */
1335
- replace(e, t = e, r = g.empty) {
1336
- let n = Me(this.doc, e, t, r);
1337
- return n && this.step(n), this;
1338
- }
1339
- /**
1340
- Replace the given range with the given content, which may be a
1341
- fragment, node, or array of nodes.
1342
- */
1343
- replaceWith(e, t, r) {
1344
- return this.replace(e, t, new g(w.from(r), 0, 0));
1345
- }
1346
- /**
1347
- Delete the content between the given positions.
1348
- */
1349
- delete(e, t) {
1350
- return this.replace(e, t, g.empty);
1351
- }
1352
- /**
1353
- Insert the given content at the given position.
1354
- */
1355
- insert(e, t) {
1356
- return this.replaceWith(e, e, t);
1357
- }
1358
- /**
1359
- Replace a range of the document with a given slice, using
1360
- `from`, `to`, and the slice's
1361
- [`openStart`](https://prosemirror.net/docs/ref/#model.Slice.openStart) property as hints, rather
1362
- than fixed start and end points. This method may grow the
1363
- replaced area or close open nodes in the slice in order to get a
1364
- fit that is more in line with WYSIWYG expectations, by dropping
1365
- fully covered parent nodes of the replaced region when they are
1366
- marked [non-defining as
1367
- context](https://prosemirror.net/docs/ref/#model.NodeSpec.definingAsContext), or including an
1368
- open parent node from the slice that _is_ marked as [defining
1369
- its content](https://prosemirror.net/docs/ref/#model.NodeSpec.definingForContent).
1370
-
1371
- This is the method, for example, to handle paste. The similar
1372
- [`replace`](https://prosemirror.net/docs/ref/#transform.Transform.replace) method is a more
1373
- primitive tool which will _not_ move the start and end of its given
1374
- range, and is useful in situations where you need more precise
1375
- control over what happens.
1376
- */
1377
- replaceRange(e, t, r) {
1378
- return Ie(this, e, t, r), this;
1379
- }
1380
- /**
1381
- Replace the given range with a node, but use `from` and `to` as
1382
- hints, rather than precise positions. When from and to are the same
1383
- and are at the start or end of a parent node in which the given
1384
- node doesn't fit, this method may _move_ them out towards a parent
1385
- that does allow the given node to be placed. When the given range
1386
- completely covers a parent node, this method may completely replace
1387
- that parent node.
1388
- */
1389
- replaceRangeWith(e, t, r) {
1390
- return Ee(this, e, t, r), this;
1391
- }
1392
- /**
1393
- Delete the given range, expanding it to cover fully covered
1394
- parent nodes until a valid replace is found.
1395
- */
1396
- deleteRange(e, t) {
1397
- return Te(this, e, t), this;
1398
- }
1399
- /**
1400
- Split the content in the given range off from its parent, if there
1401
- is sibling content before or after it, and move it up the tree to
1402
- the depth specified by `target`. You'll probably want to use
1403
- [`liftTarget`](https://prosemirror.net/docs/ref/#transform.liftTarget) to compute `target`, to make
1404
- sure the lift is valid.
1405
- */
1406
- lift(e, t) {
1407
- return de(this, e, t), this;
1408
- }
1409
- /**
1410
- Join the blocks around the given position. If depth is 2, their
1411
- last and first siblings are also joined, and so on.
1412
- */
1413
- join(e, t = 1) {
1414
- return Se(this, e, t), this;
1415
- }
1416
- /**
1417
- Wrap the given [range](https://prosemirror.net/docs/ref/#model.NodeRange) in the given set of wrappers.
1418
- The wrappers are assumed to be valid in this position, and should
1419
- probably be computed with [`findWrapping`](https://prosemirror.net/docs/ref/#transform.findWrapping).
1420
- */
1421
- wrap(e, t) {
1422
- return ge(this, e, t), this;
1423
- }
1424
- /**
1425
- Set the type of all textblocks (partly) between `from` and `to` to
1426
- the given node type with the given attributes.
1427
- */
1428
- setBlockType(e, t = e, r, n = null) {
1429
- return we(this, e, t, r, n), this;
1430
- }
1431
- /**
1432
- Change the type, attributes, and/or marks of the node at `pos`.
1433
- When `type` isn't given, the existing node type is preserved,
1434
- */
1435
- setNodeMarkup(e, t, r = null, n) {
1436
- return ke(this, e, t, r, n), this;
1437
- }
1438
- /**
1439
- Set a single attribute on a given node to a new value.
1440
- The `pos` addresses the document content. Use `setDocAttribute`
1441
- to set attributes on the document itself.
1442
- */
1443
- setNodeAttribute(e, t, r) {
1444
- return this.step(new E(e, t, r)), this;
1445
- }
1446
- /**
1447
- Set a single attribute on the document to a new value.
1448
- */
1449
- setDocAttribute(e, t) {
1450
- return this.step(new z(e, t)), this;
1451
- }
1452
- /**
1453
- Add a mark to the node at position `pos`.
1454
- */
1455
- addNodeMark(e, t) {
1456
- return this.step(new N(e, t)), this;
1457
- }
1458
- /**
1459
- Remove a mark (or all marks of the given type) from the node at
1460
- position `pos`.
1461
- */
1462
- removeNodeMark(e, t) {
1463
- let r = this.doc.nodeAt(e);
1464
- if (!r)
1465
- throw new RangeError("No node at position " + e);
1466
- if (t instanceof oe)
1467
- t.isInSet(r.marks) && this.step(new I(e, t));
1468
- else {
1469
- let n = r.marks, i, o = [];
1470
- for (; i = t.isInSet(n); )
1471
- o.push(new I(e, i)), n = i.removeFromSet(n);
1472
- for (let l = o.length - 1; l >= 0; l--)
1473
- this.step(o[l]);
1474
- }
1475
- return this;
1476
- }
1477
- /**
1478
- Split the node at the given position, and optionally, if `depth` is
1479
- greater than one, any number of nodes above that. By default, the
1480
- parts split off will inherit the node type of the original node.
1481
- This can be changed by passing an array of types and attributes to
1482
- use after the split (with the outermost nodes coming first).
1483
- */
1484
- split(e, t = 1, r) {
1485
- return ve(this, e, t, r), this;
1486
- }
1487
- /**
1488
- Add the given mark to the inline content between `from` and `to`.
1489
- */
1490
- addMark(e, t, r) {
1491
- return pe(this, e, t, r), this;
1492
- }
1493
- /**
1494
- Remove marks from inline nodes between `from` and `to`. When
1495
- `mark` is a single mark, remove precisely that mark. When it is
1496
- a mark type, remove all marks of that type. When it is null,
1497
- remove all marks of any type.
1498
- */
1499
- removeMark(e, t, r) {
1500
- return fe(this, e, t, r), this;
1501
- }
1502
- /**
1503
- Removes all marks and nodes from the content of the node at
1504
- `pos` that don't match the given new parent node type. Accepts
1505
- an optional starting [content match](https://prosemirror.net/docs/ref/#model.ContentMatch) as
1506
- third argument.
1507
- */
1508
- clearIncompatible(e, t, r) {
1509
- return $(this, e, t, r), this;
1510
- }
1511
- }
1512
- export {
1513
- A as M,
1514
- v as R,
1515
- De as T,
1516
- M as a,
1517
- Je as b,
1518
- Ae as c,
1519
- We as d,
1520
- b as e,
1521
- ze as f,
1522
- Be as j,
1523
- Fe as l,
1524
- Me as r
1525
- };