@winspan/claude-forge 8.28.2 → 8.33.0

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 (248) hide show
  1. package/README.md +68 -215
  2. package/dist/capability/execution-manager.d.ts +96 -0
  3. package/dist/capability/execution-manager.d.ts.map +1 -0
  4. package/dist/capability/execution-manager.js +260 -0
  5. package/dist/capability/execution-manager.js.map +1 -0
  6. package/dist/capability/executor/background-executor.d.ts +58 -0
  7. package/dist/capability/executor/background-executor.d.ts.map +1 -0
  8. package/dist/capability/executor/background-executor.js +322 -0
  9. package/dist/capability/executor/background-executor.js.map +1 -0
  10. package/dist/capability/executor/foreground-executor.d.ts +26 -0
  11. package/dist/capability/executor/foreground-executor.d.ts.map +1 -0
  12. package/dist/capability/executor/foreground-executor.js +82 -0
  13. package/dist/capability/executor/foreground-executor.js.map +1 -0
  14. package/dist/capability/executor/orchestrator.d.ts +38 -0
  15. package/dist/capability/executor/orchestrator.d.ts.map +1 -0
  16. package/dist/capability/executor/orchestrator.js +158 -0
  17. package/dist/capability/executor/orchestrator.js.map +1 -0
  18. package/dist/capability/executor/stream-parser.d.ts +73 -0
  19. package/dist/capability/executor/stream-parser.d.ts.map +1 -0
  20. package/dist/capability/executor/stream-parser.js +56 -0
  21. package/dist/capability/executor/stream-parser.js.map +1 -0
  22. package/dist/capability/executor/types.d.ts +44 -0
  23. package/dist/capability/executor/types.d.ts.map +1 -0
  24. package/dist/capability/executor/types.js +9 -0
  25. package/dist/capability/executor/types.js.map +1 -0
  26. package/dist/capability/executor/worker-auth-probe.d.ts +30 -0
  27. package/dist/capability/executor/worker-auth-probe.d.ts.map +1 -0
  28. package/dist/capability/executor/worker-auth-probe.js +108 -0
  29. package/dist/capability/executor/worker-auth-probe.js.map +1 -0
  30. package/dist/capability/methodologies/bmad.yaml +17 -5
  31. package/dist/capability/methodologies/code-quality-audit.yaml +26 -0
  32. package/dist/capability/methodologies/harness-engineering.yaml +12 -6
  33. package/dist/capability/methodologies/test-coverage-scan.yaml +26 -0
  34. package/dist/capability/methodology-planner.d.ts +17 -1
  35. package/dist/capability/methodology-planner.d.ts.map +1 -1
  36. package/dist/capability/methodology-planner.js +125 -0
  37. package/dist/capability/methodology-planner.js.map +1 -1
  38. package/dist/capability/methodology-registry.d.ts.map +1 -1
  39. package/dist/capability/methodology-registry.js +21 -5
  40. package/dist/capability/methodology-registry.js.map +1 -1
  41. package/dist/capability/types.d.ts +12 -1
  42. package/dist/capability/types.d.ts.map +1 -1
  43. package/dist/core/ai/provider.d.ts +17 -9
  44. package/dist/core/ai/provider.d.ts.map +1 -1
  45. package/dist/core/ai/provider.js +130 -23
  46. package/dist/core/ai/provider.js.map +1 -1
  47. package/dist/core/ai/types.d.ts +26 -5
  48. package/dist/core/ai/types.d.ts.map +1 -1
  49. package/dist/core/storage/rows.d.ts +153 -0
  50. package/dist/core/storage/rows.d.ts.map +1 -0
  51. package/dist/core/storage/rows.js +14 -0
  52. package/dist/core/storage/rows.js.map +1 -0
  53. package/dist/core/storage/schema.sql +26 -2
  54. package/dist/core/storage/sqlite.d.ts +112 -6
  55. package/dist/core/storage/sqlite.d.ts.map +1 -1
  56. package/dist/core/storage/sqlite.js +480 -22
  57. package/dist/core/storage/sqlite.js.map +1 -1
  58. package/dist/core/utils/token-tracker.d.ts +40 -0
  59. package/dist/core/utils/token-tracker.d.ts.map +1 -0
  60. package/dist/core/utils/token-tracker.js +70 -0
  61. package/dist/core/utils/token-tracker.js.map +1 -0
  62. package/dist/daemon/handlers/methodology-formatter.d.ts +7 -0
  63. package/dist/daemon/handlers/methodology-formatter.d.ts.map +1 -1
  64. package/dist/daemon/handlers/methodology-formatter.js +46 -0
  65. package/dist/daemon/handlers/methodology-formatter.js.map +1 -1
  66. package/dist/daemon/handlers/post-tool-use.d.ts +1 -0
  67. package/dist/daemon/handlers/post-tool-use.d.ts.map +1 -1
  68. package/dist/daemon/handlers/post-tool-use.js +7 -0
  69. package/dist/daemon/handlers/post-tool-use.js.map +1 -1
  70. package/dist/daemon/handlers/stop.d.ts +17 -1
  71. package/dist/daemon/handlers/stop.d.ts.map +1 -1
  72. package/dist/daemon/handlers/stop.js +97 -1
  73. package/dist/daemon/handlers/stop.js.map +1 -1
  74. package/dist/daemon/handlers/user-prompt.d.ts.map +1 -1
  75. package/dist/daemon/handlers/user-prompt.js +97 -5
  76. package/dist/daemon/handlers/user-prompt.js.map +1 -1
  77. package/dist/daemon/idle-detector.d.ts +35 -0
  78. package/dist/daemon/idle-detector.d.ts.map +1 -0
  79. package/dist/daemon/idle-detector.js +56 -0
  80. package/dist/daemon/idle-detector.js.map +1 -0
  81. package/dist/daemon/idle-trigger.d.ts +53 -0
  82. package/dist/daemon/idle-trigger.d.ts.map +1 -0
  83. package/dist/daemon/idle-trigger.js +153 -0
  84. package/dist/daemon/idle-trigger.js.map +1 -0
  85. package/dist/daemon/index.d.ts.map +1 -1
  86. package/dist/daemon/index.js +49 -2
  87. package/dist/daemon/index.js.map +1 -1
  88. package/dist/daemon/methodology-pending-queue.d.ts +33 -0
  89. package/dist/daemon/methodology-pending-queue.d.ts.map +1 -0
  90. package/dist/daemon/methodology-pending-queue.js +120 -0
  91. package/dist/daemon/methodology-pending-queue.js.map +1 -0
  92. package/dist/daemon/routing-observer.d.ts +2 -1
  93. package/dist/daemon/routing-observer.d.ts.map +1 -1
  94. package/dist/daemon/routing-observer.js +117 -39
  95. package/dist/daemon/routing-observer.js.map +1 -1
  96. package/dist/engine/agent-router.d.ts +6 -0
  97. package/dist/engine/agent-router.d.ts.map +1 -1
  98. package/dist/engine/agent-router.js +13 -1
  99. package/dist/engine/agent-router.js.map +1 -1
  100. package/dist/engine/conventions/routing.yaml +15 -0
  101. package/dist/engine/dsl/compiler.d.ts.map +1 -1
  102. package/dist/engine/dsl/compiler.js +85 -3
  103. package/dist/engine/dsl/compiler.js.map +1 -1
  104. package/dist/engine/recommender.d.ts.map +1 -1
  105. package/dist/engine/recommender.js +10 -1
  106. package/dist/engine/recommender.js.map +1 -1
  107. package/dist/intelligence/classifier.d.ts +6 -0
  108. package/dist/intelligence/classifier.d.ts.map +1 -1
  109. package/dist/intelligence/classifier.js +57 -0
  110. package/dist/intelligence/classifier.js.map +1 -1
  111. package/dist/skills/registry.d.ts +6 -0
  112. package/dist/skills/registry.d.ts.map +1 -1
  113. package/dist/skills/registry.js +49 -14
  114. package/dist/skills/registry.js.map +1 -1
  115. package/dist/skills/semantic-matcher.d.ts +1 -0
  116. package/dist/skills/semantic-matcher.d.ts.map +1 -1
  117. package/dist/skills/semantic-matcher.js +6 -1
  118. package/dist/skills/semantic-matcher.js.map +1 -1
  119. package/dist/web/auth-middleware.d.ts +22 -0
  120. package/dist/web/auth-middleware.d.ts.map +1 -0
  121. package/dist/web/auth-middleware.js +51 -0
  122. package/dist/web/auth-middleware.js.map +1 -0
  123. package/dist/web/routes/agents.d.ts +7 -0
  124. package/dist/web/routes/agents.d.ts.map +1 -0
  125. package/dist/web/routes/agents.js +192 -0
  126. package/dist/web/routes/agents.js.map +1 -0
  127. package/dist/web/routes/ai.d.ts +10 -0
  128. package/dist/web/routes/ai.d.ts.map +1 -0
  129. package/dist/web/routes/ai.js +197 -0
  130. package/dist/web/routes/ai.js.map +1 -0
  131. package/dist/web/routes/auth.d.ts +12 -0
  132. package/dist/web/routes/auth.d.ts.map +1 -0
  133. package/dist/web/routes/auth.js +20 -0
  134. package/dist/web/routes/auth.js.map +1 -0
  135. package/dist/web/routes/events.d.ts +11 -0
  136. package/dist/web/routes/events.d.ts.map +1 -0
  137. package/dist/web/routes/events.js +43 -0
  138. package/dist/web/routes/events.js.map +1 -0
  139. package/dist/web/routes/execution-trace.d.ts +13 -0
  140. package/dist/web/routes/execution-trace.d.ts.map +1 -0
  141. package/dist/web/routes/execution-trace.js +308 -0
  142. package/dist/web/routes/execution-trace.js.map +1 -0
  143. package/dist/web/routes/experiments.d.ts +15 -0
  144. package/dist/web/routes/experiments.d.ts.map +1 -0
  145. package/dist/web/routes/experiments.js +187 -0
  146. package/dist/web/routes/experiments.js.map +1 -0
  147. package/dist/web/routes/methodology.d.ts +12 -0
  148. package/dist/web/routes/methodology.d.ts.map +1 -0
  149. package/dist/web/routes/methodology.js +228 -0
  150. package/dist/web/routes/methodology.js.map +1 -0
  151. package/dist/web/routes/patch.d.ts +7 -0
  152. package/dist/web/routes/patch.d.ts.map +1 -0
  153. package/dist/web/routes/patch.js +106 -0
  154. package/dist/web/routes/patch.js.map +1 -0
  155. package/dist/web/routes/routing.d.ts +17 -0
  156. package/dist/web/routes/routing.d.ts.map +1 -0
  157. package/dist/web/routes/routing.js +582 -0
  158. package/dist/web/routes/routing.js.map +1 -0
  159. package/dist/web/routes/rules.d.ts +7 -0
  160. package/dist/web/routes/rules.d.ts.map +1 -0
  161. package/dist/web/routes/rules.js +105 -0
  162. package/dist/web/routes/rules.js.map +1 -0
  163. package/dist/web/routes/sessions.d.ts +10 -0
  164. package/dist/web/routes/sessions.d.ts.map +1 -0
  165. package/dist/web/routes/sessions.js +234 -0
  166. package/dist/web/routes/sessions.js.map +1 -0
  167. package/dist/web/routes/skills.d.ts +10 -0
  168. package/dist/web/routes/skills.d.ts.map +1 -0
  169. package/dist/web/routes/skills.js +272 -0
  170. package/dist/web/routes/skills.js.map +1 -0
  171. package/dist/web/routes/static.d.ts +19 -0
  172. package/dist/web/routes/static.d.ts.map +1 -0
  173. package/dist/web/routes/static.js +61 -0
  174. package/dist/web/routes/static.js.map +1 -0
  175. package/dist/web/routes/status.d.ts +7 -0
  176. package/dist/web/routes/status.d.ts.map +1 -0
  177. package/dist/web/routes/status.js +28 -0
  178. package/dist/web/routes/status.js.map +1 -0
  179. package/dist/web/routes/token-usage.d.ts +7 -0
  180. package/dist/web/routes/token-usage.d.ts.map +1 -0
  181. package/dist/web/routes/token-usage.js +33 -0
  182. package/dist/web/routes/token-usage.js.map +1 -0
  183. package/dist/web/routes/types.d.ts +40 -0
  184. package/dist/web/routes/types.d.ts.map +1 -0
  185. package/dist/web/routes/types.js +52 -0
  186. package/dist/web/routes/types.js.map +1 -0
  187. package/dist/web/server.d.ts +13 -4
  188. package/dist/web/server.d.ts.map +1 -1
  189. package/dist/web/server.js +60 -2210
  190. package/dist/web/server.js.map +1 -1
  191. package/dist/web/ssrf-guard.d.ts +35 -0
  192. package/dist/web/ssrf-guard.d.ts.map +1 -0
  193. package/dist/web/ssrf-guard.js +93 -0
  194. package/dist/web/ssrf-guard.js.map +1 -0
  195. package/dist/web/static/assets/AIConfig-D-vrYoJ3.js +2 -0
  196. package/dist/web/static/assets/AIConfig-D-vrYoJ3.js.map +1 -0
  197. package/dist/web/static/assets/Agents-DAGWYsJj.js +2 -0
  198. package/dist/web/static/assets/Agents-DAGWYsJj.js.map +1 -0
  199. package/dist/web/static/assets/CodeBlock--H53gk46.js +2 -0
  200. package/dist/web/static/assets/CodeBlock--H53gk46.js.map +1 -0
  201. package/dist/web/static/assets/Dashboard-qUCxXFSI.js +2 -0
  202. package/dist/web/static/assets/Dashboard-qUCxXFSI.js.map +1 -0
  203. package/dist/web/static/assets/Drawer-DeKukfwJ.js +2 -0
  204. package/dist/web/static/assets/Drawer-DeKukfwJ.js.map +1 -0
  205. package/dist/web/static/assets/Events-BoQ8Fo5k.js +2 -0
  206. package/dist/web/static/assets/Events-BoQ8Fo5k.js.map +1 -0
  207. package/dist/web/static/assets/ExecutionTrace-sFZ_vHNf.js +2 -0
  208. package/dist/web/static/assets/ExecutionTrace-sFZ_vHNf.js.map +1 -0
  209. package/dist/web/static/assets/MarkdownRenderer-CCIz1MOz.js +2 -0
  210. package/dist/web/static/assets/MarkdownRenderer-CCIz1MOz.js.map +1 -0
  211. package/dist/web/static/assets/Methodologies-C0-Keokj.js +5 -0
  212. package/dist/web/static/assets/Methodologies-C0-Keokj.js.map +1 -0
  213. package/dist/web/static/assets/MethodologyDetail-Do1taSKM.js +2 -0
  214. package/dist/web/static/assets/MethodologyDetail-Do1taSKM.js.map +1 -0
  215. package/dist/web/static/assets/Routing-CFmM7JuB.js +2 -0
  216. package/dist/web/static/assets/Routing-CFmM7JuB.js.map +1 -0
  217. package/dist/web/static/assets/SessionDetail-DzTue2xK.js +2 -0
  218. package/dist/web/static/assets/SessionDetail-DzTue2xK.js.map +1 -0
  219. package/dist/web/static/assets/Sessions-Bjf-Mvwb.js +2 -0
  220. package/dist/web/static/assets/Sessions-Bjf-Mvwb.js.map +1 -0
  221. package/dist/web/static/assets/Skills-CrLshkrJ.js +2 -0
  222. package/dist/web/static/assets/Skills-CrLshkrJ.js.map +1 -0
  223. package/dist/web/static/assets/charts-CLrM0_uM.js +37 -0
  224. package/dist/web/static/assets/charts-CLrM0_uM.js.map +1 -0
  225. package/dist/web/static/assets/date-fns-CZ_bHujz.js +2 -0
  226. package/dist/web/static/assets/date-fns-CZ_bHujz.js.map +1 -0
  227. package/dist/web/static/assets/export-CEzDNM66.js +4 -0
  228. package/dist/web/static/assets/export-CEzDNM66.js.map +1 -0
  229. package/dist/web/static/assets/index-D23sAOAt.js +3 -0
  230. package/dist/web/static/assets/index-D23sAOAt.js.map +1 -0
  231. package/dist/web/static/assets/index-Drpf7sLl.css +1 -0
  232. package/dist/web/static/assets/lucide-DjB4fWNj.js +227 -0
  233. package/dist/web/static/assets/lucide-DjB4fWNj.js.map +1 -0
  234. package/dist/web/static/assets/query-C99w429o.js +2 -0
  235. package/dist/web/static/assets/query-C99w429o.js.map +1 -0
  236. package/dist/web/static/assets/react-router-I-HqunH7.js +20 -0
  237. package/dist/web/static/assets/react-router-I-HqunH7.js.map +1 -0
  238. package/dist/web/static/assets/react-vendor-CSp-GLFF.js +49 -0
  239. package/dist/web/static/assets/react-vendor-CSp-GLFF.js.map +1 -0
  240. package/dist/web/static/assets/syntax-highlighter-44FakypI.js +9 -0
  241. package/dist/web/static/assets/syntax-highlighter-44FakypI.js.map +1 -0
  242. package/dist/web/static/assets/vendor-CMMjVdZs.js +64 -0
  243. package/dist/web/static/assets/vendor-CMMjVdZs.js.map +1 -0
  244. package/dist/web/static/index.html +8 -2
  245. package/package.json +3 -2
  246. package/dist/web/static/assets/index-CtylfoaN.css +0 -1
  247. package/dist/web/static/assets/index-DnaQt27h.js +0 -388
  248. package/dist/web/static/assets/index-DnaQt27h.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vendor-CMMjVdZs.js","sources":["../../node_modules/@remix-run/router/dist/router.js","../../node_modules/clsx/dist/clsx.mjs","../../node_modules/es-toolkit/dist/_internal/isUnsafeProperty.js","../../node_modules/es-toolkit/dist/compat/_internal/isDeepKey.js","../../node_modules/es-toolkit/dist/compat/_internal/toKey.js","../../node_modules/es-toolkit/dist/compat/util/toString.js","../../node_modules/es-toolkit/dist/compat/util/toPath.js","../../node_modules/es-toolkit/dist/compat/object/get.js","../../node_modules/es-toolkit/compat/get.js","../../node_modules/es-toolkit/dist/array/uniqBy.js","../../node_modules/es-toolkit/dist/function/ary.js","../../node_modules/es-toolkit/dist/function/identity.js","../../node_modules/es-toolkit/dist/predicate/isLength.js","../../node_modules/es-toolkit/dist/compat/predicate/isArrayLike.js","../../node_modules/es-toolkit/dist/compat/predicate/isObjectLike.js","../../node_modules/es-toolkit/dist/compat/predicate/isArrayLikeObject.js","../../node_modules/es-toolkit/dist/compat/object/property.js","../../node_modules/es-toolkit/dist/compat/predicate/isObject.js","../../node_modules/es-toolkit/dist/predicate/isPrimitive.js","../../node_modules/es-toolkit/dist/_internal/isEqualsSameValueZero.js","../../node_modules/es-toolkit/dist/compat/predicate/isMatchWith.js","../../node_modules/es-toolkit/dist/compat/predicate/isMatch.js","../../node_modules/es-toolkit/dist/compat/_internal/getSymbols.js","../../node_modules/es-toolkit/dist/compat/_internal/getTag.js","../../node_modules/es-toolkit/dist/compat/_internal/tags.js","../../node_modules/es-toolkit/dist/_internal/globalThis.js","../../node_modules/es-toolkit/dist/predicate/isBuffer.js","../../node_modules/es-toolkit/dist/predicate/isTypedArray.js","../../node_modules/es-toolkit/dist/object/cloneDeepWith.js","../../node_modules/es-toolkit/dist/object/cloneDeep.js","../../node_modules/es-toolkit/dist/compat/predicate/matches.js","../../node_modules/es-toolkit/dist/compat/object/cloneDeepWith.js","../../node_modules/es-toolkit/dist/compat/object/cloneDeep.js","../../node_modules/es-toolkit/dist/compat/_internal/isIndex.js","../../node_modules/es-toolkit/dist/compat/predicate/isArguments.js","../../node_modules/es-toolkit/dist/compat/object/has.js","../../node_modules/es-toolkit/dist/compat/predicate/matchesProperty.js","../../node_modules/es-toolkit/dist/compat/util/iteratee.js","../../node_modules/es-toolkit/dist/compat/array/uniqBy.js","../../node_modules/es-toolkit/compat/uniqBy.js","../../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.js","../../node_modules/use-sync-external-store/shim/index.js","../../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.js","../../node_modules/use-sync-external-store/shim/with-selector.js","../../node_modules/reselect/dist/reselect.mjs","../../node_modules/es-toolkit/dist/compat/_internal/compareValues.js","../../node_modules/es-toolkit/dist/compat/predicate/isSymbol.js","../../node_modules/es-toolkit/dist/compat/_internal/isKey.js","../../node_modules/es-toolkit/dist/compat/array/orderBy.js","../../node_modules/es-toolkit/dist/array/flatten.js","../../node_modules/es-toolkit/dist/compat/_internal/isIterateeCall.js","../../node_modules/es-toolkit/dist/compat/array/sortBy.js","../../node_modules/es-toolkit/compat/sortBy.js","../../node_modules/redux/dist/redux.mjs","../../node_modules/@reduxjs/toolkit/node_modules/immer/dist/immer.mjs","../../node_modules/redux-thunk/dist/redux-thunk.mjs","../../node_modules/@reduxjs/toolkit/dist/redux-toolkit.modern.mjs","../../node_modules/es-toolkit/dist/function/debounce.js","../../node_modules/es-toolkit/dist/compat/function/debounce.js","../../node_modules/es-toolkit/dist/compat/function/throttle.js","../../node_modules/es-toolkit/compat/throttle.js","../../node_modules/immer/dist/immer.mjs","../../node_modules/use-sync-external-store/cjs/use-sync-external-store-with-selector.production.js","../../node_modules/react-redux/dist/react-redux.mjs","../../node_modules/es-toolkit/dist/compat/util/toNumber.js","../../node_modules/es-toolkit/dist/compat/util/toFinite.js","../../node_modules/es-toolkit/dist/compat/math/range.js","../../node_modules/es-toolkit/compat/range.js","../../node_modules/decimal.js-light/decimal.mjs","../../node_modules/internmap/src/index.js","../../node_modules/eventemitter3/index.js","../../node_modules/es-toolkit/dist/compat/predicate/isPlainObject.js","../../node_modules/es-toolkit/compat/isPlainObject.js","../../node_modules/tiny-invariant/dist/esm/tiny-invariant.js","../../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../../node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../../node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../../node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../../node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../../node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../../node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../../node_modules/@babel/runtime/helpers/esm/typeof.js","../../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","../../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","../../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../../node_modules/@babel/runtime/helpers/esm/extends.js","../../node_modules/property-information/lib/util/schema.js","../../node_modules/property-information/lib/util/merge.js","../../node_modules/property-information/lib/normalize.js","../../node_modules/property-information/lib/util/info.js","../../node_modules/property-information/lib/util/types.js","../../node_modules/property-information/lib/util/defined-info.js","../../node_modules/property-information/lib/util/create.js","../../node_modules/property-information/lib/aria.js","../../node_modules/property-information/lib/util/case-sensitive-transform.js","../../node_modules/property-information/lib/util/case-insensitive-transform.js","../../node_modules/property-information/lib/html.js","../../node_modules/property-information/lib/svg.js","../../node_modules/property-information/lib/xlink.js","../../node_modules/property-information/lib/xmlns.js","../../node_modules/property-information/lib/xml.js","../../node_modules/property-information/lib/hast-to-react.js","../../node_modules/property-information/lib/find.js","../../node_modules/property-information/index.js","../../node_modules/comma-separated-tokens/index.js","../../node_modules/hast-util-parse-selector/lib/index.js","../../node_modules/space-separated-tokens/index.js","../../node_modules/hastscript/lib/create-h.js","../../node_modules/hastscript/lib/svg-case-sensitive-tag-names.js","../../node_modules/hastscript/lib/index.js","../../node_modules/character-entities-legacy/index.js","../../node_modules/character-reference-invalid/index.js","../../node_modules/is-decimal/index.js","../../node_modules/is-hexadecimal/index.js","../../node_modules/is-alphabetical/index.js","../../node_modules/is-alphanumerical/index.js","../../node_modules/decode-named-character-reference/index.dom.js","../../node_modules/parse-entities/lib/index.js","../../node_modules/estree-util-is-identifier-name/lib/index.js","../../node_modules/hast-util-whitespace/lib/index.js","../../node_modules/inline-style-parser/cjs/index.js","../../node_modules/style-to-object/cjs/index.js","../../node_modules/style-to-js/cjs/utilities.js","../../node_modules/style-to-js/cjs/index.js","../../node_modules/unist-util-position/lib/index.js","../../node_modules/unist-util-stringify-position/lib/index.js","../../node_modules/vfile-message/lib/index.js","../../node_modules/hast-util-to-jsx-runtime/lib/index.js","../../node_modules/html-url-attributes/lib/index.js","../../node_modules/mdast-util-to-string/lib/index.js","../../node_modules/micromark-util-chunked/index.js","../../node_modules/micromark-util-combine-extensions/index.js","../../node_modules/micromark-util-decode-numeric-character-reference/index.js","../../node_modules/micromark-util-normalize-identifier/index.js","../../node_modules/micromark-util-character/index.js","../../node_modules/micromark-util-sanitize-uri/index.js","../../node_modules/micromark-factory-space/index.js","../../node_modules/micromark/lib/initialize/content.js","../../node_modules/micromark/lib/initialize/document.js","../../node_modules/micromark-util-classify-character/index.js","../../node_modules/micromark-util-resolve-all/index.js","../../node_modules/micromark-core-commonmark/lib/attention.js","../../node_modules/micromark-core-commonmark/lib/autolink.js","../../node_modules/micromark-core-commonmark/lib/blank-line.js","../../node_modules/micromark-core-commonmark/lib/block-quote.js","../../node_modules/micromark-core-commonmark/lib/character-escape.js","../../node_modules/micromark-core-commonmark/lib/character-reference.js","../../node_modules/micromark-core-commonmark/lib/code-fenced.js","../../node_modules/micromark-core-commonmark/lib/code-indented.js","../../node_modules/micromark-core-commonmark/lib/code-text.js","../../node_modules/micromark-util-subtokenize/lib/splice-buffer.js","../../node_modules/micromark-util-subtokenize/index.js","../../node_modules/micromark-core-commonmark/lib/content.js","../../node_modules/micromark-factory-destination/index.js","../../node_modules/micromark-factory-label/index.js","../../node_modules/micromark-factory-title/index.js","../../node_modules/micromark-factory-whitespace/index.js","../../node_modules/micromark-core-commonmark/lib/definition.js","../../node_modules/micromark-core-commonmark/lib/hard-break-escape.js","../../node_modules/micromark-core-commonmark/lib/heading-atx.js","../../node_modules/micromark-util-html-tag-name/index.js","../../node_modules/micromark-core-commonmark/lib/html-flow.js","../../node_modules/micromark-core-commonmark/lib/html-text.js","../../node_modules/micromark-core-commonmark/lib/label-end.js","../../node_modules/micromark-core-commonmark/lib/label-start-image.js","../../node_modules/micromark-core-commonmark/lib/label-start-link.js","../../node_modules/micromark-core-commonmark/lib/line-ending.js","../../node_modules/micromark-core-commonmark/lib/thematic-break.js","../../node_modules/micromark-core-commonmark/lib/list.js","../../node_modules/micromark-core-commonmark/lib/setext-underline.js","../../node_modules/micromark/lib/initialize/flow.js","../../node_modules/micromark/lib/initialize/text.js","../../node_modules/micromark/lib/constructs.js","../../node_modules/micromark/lib/create-tokenizer.js","../../node_modules/micromark/lib/parse.js","../../node_modules/micromark/lib/postprocess.js","../../node_modules/micromark/lib/preprocess.js","../../node_modules/micromark-util-decode-string/index.js","../../node_modules/mdast-util-from-markdown/lib/index.js","../../node_modules/remark-parse/lib/index.js","../../node_modules/mdast-util-to-hast/lib/handlers/blockquote.js","../../node_modules/mdast-util-to-hast/lib/handlers/break.js","../../node_modules/mdast-util-to-hast/lib/handlers/code.js","../../node_modules/mdast-util-to-hast/lib/handlers/delete.js","../../node_modules/mdast-util-to-hast/lib/handlers/emphasis.js","../../node_modules/mdast-util-to-hast/lib/handlers/footnote-reference.js","../../node_modules/mdast-util-to-hast/lib/handlers/heading.js","../../node_modules/mdast-util-to-hast/lib/handlers/html.js","../../node_modules/mdast-util-to-hast/lib/revert.js","../../node_modules/mdast-util-to-hast/lib/handlers/image-reference.js","../../node_modules/mdast-util-to-hast/lib/handlers/image.js","../../node_modules/mdast-util-to-hast/lib/handlers/inline-code.js","../../node_modules/mdast-util-to-hast/lib/handlers/link-reference.js","../../node_modules/mdast-util-to-hast/lib/handlers/link.js","../../node_modules/mdast-util-to-hast/lib/handlers/list-item.js","../../node_modules/mdast-util-to-hast/lib/handlers/list.js","../../node_modules/mdast-util-to-hast/lib/handlers/paragraph.js","../../node_modules/mdast-util-to-hast/lib/handlers/root.js","../../node_modules/mdast-util-to-hast/lib/handlers/strong.js","../../node_modules/mdast-util-to-hast/lib/handlers/table.js","../../node_modules/mdast-util-to-hast/lib/handlers/table-row.js","../../node_modules/mdast-util-to-hast/lib/handlers/table-cell.js","../../node_modules/trim-lines/index.js","../../node_modules/mdast-util-to-hast/lib/handlers/text.js","../../node_modules/mdast-util-to-hast/lib/handlers/thematic-break.js","../../node_modules/mdast-util-to-hast/lib/handlers/index.js","../../node_modules/@ungap/structured-clone/esm/types.js","../../node_modules/@ungap/structured-clone/esm/deserialize.js","../../node_modules/@ungap/structured-clone/esm/serialize.js","../../node_modules/@ungap/structured-clone/esm/index.js","../../node_modules/mdast-util-to-hast/lib/footer.js","../../node_modules/unist-util-is/lib/index.js","../../node_modules/unist-util-visit-parents/lib/index.js","../../node_modules/unist-util-visit/lib/index.js","../../node_modules/mdast-util-to-hast/lib/state.js","../../node_modules/mdast-util-to-hast/lib/index.js","../../node_modules/remark-rehype/lib/index.js","../../node_modules/bail/index.js","../../node_modules/extend/index.js","../../node_modules/is-plain-obj/index.js","../../node_modules/trough/lib/index.js","../../node_modules/vfile/lib/minpath.browser.js","../../node_modules/vfile/lib/minproc.browser.js","../../node_modules/vfile/lib/minurl.shared.js","../../node_modules/vfile/lib/minurl.browser.js","../../node_modules/vfile/lib/index.js","../../node_modules/unified/lib/callable-instance.js","../../node_modules/unified/lib/index.js","../../node_modules/react-markdown/lib/index.js","../../node_modules/ccount/index.js","../../node_modules/escape-string-regexp/index.js","../../node_modules/mdast-util-find-and-replace/lib/index.js","../../node_modules/mdast-util-gfm-autolink-literal/lib/index.js","../../node_modules/mdast-util-gfm-footnote/lib/index.js","../../node_modules/mdast-util-gfm-strikethrough/lib/index.js","../../node_modules/markdown-table/index.js","../../node_modules/mdast-util-to-markdown/lib/handle/blockquote.js","../../node_modules/mdast-util-to-markdown/lib/util/pattern-in-scope.js","../../node_modules/mdast-util-to-markdown/lib/handle/break.js","../../node_modules/longest-streak/index.js","../../node_modules/mdast-util-to-markdown/lib/util/format-code-as-indented.js","../../node_modules/mdast-util-to-markdown/lib/util/check-fence.js","../../node_modules/mdast-util-to-markdown/lib/handle/code.js","../../node_modules/mdast-util-to-markdown/lib/util/check-quote.js","../../node_modules/mdast-util-to-markdown/lib/handle/definition.js","../../node_modules/mdast-util-to-markdown/lib/util/check-emphasis.js","../../node_modules/mdast-util-to-markdown/lib/util/encode-character-reference.js","../../node_modules/mdast-util-to-markdown/lib/util/encode-info.js","../../node_modules/mdast-util-to-markdown/lib/handle/emphasis.js","../../node_modules/mdast-util-to-markdown/lib/util/format-heading-as-setext.js","../../node_modules/mdast-util-to-markdown/lib/handle/heading.js","../../node_modules/mdast-util-to-markdown/lib/handle/html.js","../../node_modules/mdast-util-to-markdown/lib/handle/image.js","../../node_modules/mdast-util-to-markdown/lib/handle/image-reference.js","../../node_modules/mdast-util-to-markdown/lib/handle/inline-code.js","../../node_modules/mdast-util-to-markdown/lib/util/format-link-as-autolink.js","../../node_modules/mdast-util-to-markdown/lib/handle/link.js","../../node_modules/mdast-util-to-markdown/lib/handle/link-reference.js","../../node_modules/mdast-util-to-markdown/lib/util/check-bullet.js","../../node_modules/mdast-util-to-markdown/lib/util/check-bullet-other.js","../../node_modules/mdast-util-to-markdown/lib/util/check-bullet-ordered.js","../../node_modules/mdast-util-to-markdown/lib/util/check-rule.js","../../node_modules/mdast-util-to-markdown/lib/handle/list.js","../../node_modules/mdast-util-to-markdown/lib/util/check-list-item-indent.js","../../node_modules/mdast-util-to-markdown/lib/handle/list-item.js","../../node_modules/mdast-util-to-markdown/lib/handle/paragraph.js","../../node_modules/mdast-util-phrasing/lib/index.js","../../node_modules/mdast-util-to-markdown/lib/handle/root.js","../../node_modules/mdast-util-to-markdown/lib/util/check-strong.js","../../node_modules/mdast-util-to-markdown/lib/handle/strong.js","../../node_modules/mdast-util-to-markdown/lib/handle/text.js","../../node_modules/mdast-util-to-markdown/lib/util/check-rule-repetition.js","../../node_modules/mdast-util-to-markdown/lib/handle/thematic-break.js","../../node_modules/mdast-util-to-markdown/lib/handle/index.js","../../node_modules/mdast-util-gfm-table/lib/index.js","../../node_modules/mdast-util-gfm-task-list-item/lib/index.js","../../node_modules/mdast-util-gfm/lib/index.js","../../node_modules/micromark-extension-gfm-autolink-literal/lib/syntax.js","../../node_modules/micromark-extension-gfm-footnote/lib/syntax.js","../../node_modules/micromark-extension-gfm-strikethrough/lib/syntax.js","../../node_modules/micromark-extension-gfm-table/lib/edit-map.js","../../node_modules/micromark-extension-gfm-table/lib/infer.js","../../node_modules/micromark-extension-gfm-table/lib/syntax.js","../../node_modules/micromark-extension-gfm-task-list-item/lib/syntax.js","../../node_modules/micromark-extension-gfm/index.js","../../node_modules/remark-gfm/lib/index.js"],"sourcesContent":["/**\n * @remix-run/router v1.23.2\n *\n * Copyright (c) Remix Software Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.md file in the root directory of this source tree.\n *\n * @license MIT\n */\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Types and Constants\n////////////////////////////////////////////////////////////////////////////////\n/**\n * Actions represent the type of change to a location value.\n */\nvar Action;\n(function (Action) {\n /**\n * A POP indicates a change to an arbitrary index in the history stack, such\n * as a back or forward navigation. It does not describe the direction of the\n * navigation, only that the current index changed.\n *\n * Note: This is the default action for newly created history objects.\n */\n Action[\"Pop\"] = \"POP\";\n /**\n * A PUSH indicates a new entry being added to the history stack, such as when\n * a link is clicked and a new page loads. When this happens, all subsequent\n * entries in the stack are lost.\n */\n Action[\"Push\"] = \"PUSH\";\n /**\n * A REPLACE indicates the entry at the current index in the history stack\n * being replaced by a new one.\n */\n Action[\"Replace\"] = \"REPLACE\";\n})(Action || (Action = {}));\nconst PopStateEventType = \"popstate\";\n/**\n * Memory history stores the current location in memory. It is designed for use\n * in stateful non-browser environments like tests and React Native.\n */\nfunction createMemoryHistory(options) {\n if (options === void 0) {\n options = {};\n }\n let {\n initialEntries = [\"/\"],\n initialIndex,\n v5Compat = false\n } = options;\n let entries; // Declare so we can access from createMemoryLocation\n entries = initialEntries.map((entry, index) => createMemoryLocation(entry, typeof entry === \"string\" ? null : entry.state, index === 0 ? \"default\" : undefined));\n let index = clampIndex(initialIndex == null ? entries.length - 1 : initialIndex);\n let action = Action.Pop;\n let listener = null;\n function clampIndex(n) {\n return Math.min(Math.max(n, 0), entries.length - 1);\n }\n function getCurrentLocation() {\n return entries[index];\n }\n function createMemoryLocation(to, state, key) {\n if (state === void 0) {\n state = null;\n }\n let location = createLocation(entries ? getCurrentLocation().pathname : \"/\", to, state, key);\n warning(location.pathname.charAt(0) === \"/\", \"relative pathnames are not supported in memory history: \" + JSON.stringify(to));\n return location;\n }\n function createHref(to) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n let history = {\n get index() {\n return index;\n },\n get action() {\n return action;\n },\n get location() {\n return getCurrentLocation();\n },\n createHref,\n createURL(to) {\n return new URL(createHref(to), \"http://localhost\");\n },\n encodeLocation(to) {\n let path = typeof to === \"string\" ? parsePath(to) : to;\n return {\n pathname: path.pathname || \"\",\n search: path.search || \"\",\n hash: path.hash || \"\"\n };\n },\n push(to, state) {\n action = Action.Push;\n let nextLocation = createMemoryLocation(to, state);\n index += 1;\n entries.splice(index, entries.length, nextLocation);\n if (v5Compat && listener) {\n listener({\n action,\n location: nextLocation,\n delta: 1\n });\n }\n },\n replace(to, state) {\n action = Action.Replace;\n let nextLocation = createMemoryLocation(to, state);\n entries[index] = nextLocation;\n if (v5Compat && listener) {\n listener({\n action,\n location: nextLocation,\n delta: 0\n });\n }\n },\n go(delta) {\n action = Action.Pop;\n let nextIndex = clampIndex(index + delta);\n let nextLocation = entries[nextIndex];\n index = nextIndex;\n if (listener) {\n listener({\n action,\n location: nextLocation,\n delta\n });\n }\n },\n listen(fn) {\n listener = fn;\n return () => {\n listener = null;\n };\n }\n };\n return history;\n}\n/**\n * Browser history stores the location in regular URLs. This is the standard for\n * most web apps, but it requires some configuration on the server to ensure you\n * serve the same app at multiple URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createbrowserhistory\n */\nfunction createBrowserHistory(options) {\n if (options === void 0) {\n options = {};\n }\n function createBrowserLocation(window, globalHistory) {\n let {\n pathname,\n search,\n hash\n } = window.location;\n return createLocation(\"\", {\n pathname,\n search,\n hash\n },\n // state defaults to `null` because `window.history.state` does\n globalHistory.state && globalHistory.state.usr || null, globalHistory.state && globalHistory.state.key || \"default\");\n }\n function createBrowserHref(window, to) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n return getUrlBasedHistory(createBrowserLocation, createBrowserHref, null, options);\n}\n/**\n * Hash history stores the location in window.location.hash. This makes it ideal\n * for situations where you don't want to send the location to the server for\n * some reason, either because you do cannot configure it or the URL space is\n * reserved for something else.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createhashhistory\n */\nfunction createHashHistory(options) {\n if (options === void 0) {\n options = {};\n }\n function createHashLocation(window, globalHistory) {\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\"\n } = parsePath(window.location.hash.substr(1));\n // Hash URL should always have a leading / just like window.location.pathname\n // does, so if an app ends up at a route like /#something then we add a\n // leading slash so all of our path-matching behaves the same as if it would\n // in a browser router. This is particularly important when there exists a\n // root splat route (<Route path=\"*\">) since that matches internally against\n // \"/*\" and we'd expect /#something to 404 in a hash router app.\n if (!pathname.startsWith(\"/\") && !pathname.startsWith(\".\")) {\n pathname = \"/\" + pathname;\n }\n return createLocation(\"\", {\n pathname,\n search,\n hash\n },\n // state defaults to `null` because `window.history.state` does\n globalHistory.state && globalHistory.state.usr || null, globalHistory.state && globalHistory.state.key || \"default\");\n }\n function createHashHref(window, to) {\n let base = window.document.querySelector(\"base\");\n let href = \"\";\n if (base && base.getAttribute(\"href\")) {\n let url = window.location.href;\n let hashIndex = url.indexOf(\"#\");\n href = hashIndex === -1 ? url : url.slice(0, hashIndex);\n }\n return href + \"#\" + (typeof to === \"string\" ? to : createPath(to));\n }\n function validateHashLocation(location, to) {\n warning(location.pathname.charAt(0) === \"/\", \"relative pathnames are not supported in hash history.push(\" + JSON.stringify(to) + \")\");\n }\n return getUrlBasedHistory(createHashLocation, createHashHref, validateHashLocation, options);\n}\nfunction invariant(value, message) {\n if (value === false || value === null || typeof value === \"undefined\") {\n throw new Error(message);\n }\n}\nfunction warning(cond, message) {\n if (!cond) {\n // eslint-disable-next-line no-console\n if (typeof console !== \"undefined\") console.warn(message);\n try {\n // Welcome to debugging history!\n //\n // This error is thrown as a convenience, so you can more easily\n // find the source for a warning that appears in the console by\n // enabling \"pause on exceptions\" in your JavaScript debugger.\n throw new Error(message);\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n}\nfunction createKey() {\n return Math.random().toString(36).substr(2, 8);\n}\n/**\n * For browser-based histories, we combine the state and key into an object\n */\nfunction getHistoryState(location, index) {\n return {\n usr: location.state,\n key: location.key,\n idx: index\n };\n}\n/**\n * Creates a Location object with a unique key from the given Path\n */\nfunction createLocation(current, to, state, key) {\n if (state === void 0) {\n state = null;\n }\n let location = _extends({\n pathname: typeof current === \"string\" ? current : current.pathname,\n search: \"\",\n hash: \"\"\n }, typeof to === \"string\" ? parsePath(to) : to, {\n state,\n // TODO: This could be cleaned up. push/replace should probably just take\n // full Locations now and avoid the need to run through this flow at all\n // But that's a pretty big refactor to the current test suite so going to\n // keep as is for the time being and just let any incoming keys take precedence\n key: to && to.key || key || createKey()\n });\n return location;\n}\n/**\n * Creates a string URL path from the given pathname, search, and hash components.\n */\nfunction createPath(_ref) {\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\"\n } = _ref;\n if (search && search !== \"?\") pathname += search.charAt(0) === \"?\" ? search : \"?\" + search;\n if (hash && hash !== \"#\") pathname += hash.charAt(0) === \"#\" ? hash : \"#\" + hash;\n return pathname;\n}\n/**\n * Parses a string URL path into its separate pathname, search, and hash components.\n */\nfunction parsePath(path) {\n let parsedPath = {};\n if (path) {\n let hashIndex = path.indexOf(\"#\");\n if (hashIndex >= 0) {\n parsedPath.hash = path.substr(hashIndex);\n path = path.substr(0, hashIndex);\n }\n let searchIndex = path.indexOf(\"?\");\n if (searchIndex >= 0) {\n parsedPath.search = path.substr(searchIndex);\n path = path.substr(0, searchIndex);\n }\n if (path) {\n parsedPath.pathname = path;\n }\n }\n return parsedPath;\n}\nfunction getUrlBasedHistory(getLocation, createHref, validateLocation, options) {\n if (options === void 0) {\n options = {};\n }\n let {\n window = document.defaultView,\n v5Compat = false\n } = options;\n let globalHistory = window.history;\n let action = Action.Pop;\n let listener = null;\n let index = getIndex();\n // Index should only be null when we initialize. If not, it's because the\n // user called history.pushState or history.replaceState directly, in which\n // case we should log a warning as it will result in bugs.\n if (index == null) {\n index = 0;\n globalHistory.replaceState(_extends({}, globalHistory.state, {\n idx: index\n }), \"\");\n }\n function getIndex() {\n let state = globalHistory.state || {\n idx: null\n };\n return state.idx;\n }\n function handlePop() {\n action = Action.Pop;\n let nextIndex = getIndex();\n let delta = nextIndex == null ? null : nextIndex - index;\n index = nextIndex;\n if (listener) {\n listener({\n action,\n location: history.location,\n delta\n });\n }\n }\n function push(to, state) {\n action = Action.Push;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n index = getIndex() + 1;\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n // try...catch because iOS limits us to 100 pushState calls :/\n try {\n globalHistory.pushState(historyState, \"\", url);\n } catch (error) {\n // If the exception is because `state` can't be serialized, let that throw\n // outwards just like a replace call would so the dev knows the cause\n // https://html.spec.whatwg.org/multipage/nav-history-apis.html#shared-history-push/replace-state-steps\n // https://html.spec.whatwg.org/multipage/structured-data.html#structuredserializeinternal\n if (error instanceof DOMException && error.name === \"DataCloneError\") {\n throw error;\n }\n // They are going to lose state here, but there is no real\n // way to warn them about it since the page will refresh...\n window.location.assign(url);\n }\n if (v5Compat && listener) {\n listener({\n action,\n location: history.location,\n delta: 1\n });\n }\n }\n function replace(to, state) {\n action = Action.Replace;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n index = getIndex();\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n globalHistory.replaceState(historyState, \"\", url);\n if (v5Compat && listener) {\n listener({\n action,\n location: history.location,\n delta: 0\n });\n }\n }\n function createURL(to) {\n // window.location.origin is \"null\" (the literal string value) in Firefox\n // under certain conditions, notably when serving from a local HTML file\n // See https://bugzilla.mozilla.org/show_bug.cgi?id=878297\n let base = window.location.origin !== \"null\" ? window.location.origin : window.location.href;\n let href = typeof to === \"string\" ? to : createPath(to);\n // Treating this as a full URL will strip any trailing spaces so we need to\n // pre-encode them since they might be part of a matching splat param from\n // an ancestor route\n href = href.replace(/ $/, \"%20\");\n invariant(base, \"No window.location.(origin|href) available to create URL for href: \" + href);\n return new URL(href, base);\n }\n let history = {\n get action() {\n return action;\n },\n get location() {\n return getLocation(window, globalHistory);\n },\n listen(fn) {\n if (listener) {\n throw new Error(\"A history only accepts one active listener\");\n }\n window.addEventListener(PopStateEventType, handlePop);\n listener = fn;\n return () => {\n window.removeEventListener(PopStateEventType, handlePop);\n listener = null;\n };\n },\n createHref(to) {\n return createHref(window, to);\n },\n createURL,\n encodeLocation(to) {\n // Encode a Location the same way window.location would\n let url = createURL(to);\n return {\n pathname: url.pathname,\n search: url.search,\n hash: url.hash\n };\n },\n push,\n replace,\n go(n) {\n return globalHistory.go(n);\n }\n };\n return history;\n}\n//#endregion\n\nvar ResultType;\n(function (ResultType) {\n ResultType[\"data\"] = \"data\";\n ResultType[\"deferred\"] = \"deferred\";\n ResultType[\"redirect\"] = \"redirect\";\n ResultType[\"error\"] = \"error\";\n})(ResultType || (ResultType = {}));\nconst immutableRouteKeys = new Set([\"lazy\", \"caseSensitive\", \"path\", \"id\", \"index\", \"children\"]);\nfunction isIndexRoute(route) {\n return route.index === true;\n}\n// Walk the route tree generating unique IDs where necessary, so we are working\n// solely with AgnosticDataRouteObject's within the Router\nfunction convertRoutesToDataRoutes(routes, mapRouteProperties, parentPath, manifest) {\n if (parentPath === void 0) {\n parentPath = [];\n }\n if (manifest === void 0) {\n manifest = {};\n }\n return routes.map((route, index) => {\n let treePath = [...parentPath, String(index)];\n let id = typeof route.id === \"string\" ? route.id : treePath.join(\"-\");\n invariant(route.index !== true || !route.children, \"Cannot specify children on an index route\");\n invariant(!manifest[id], \"Found a route id collision on id \\\"\" + id + \"\\\". Route \" + \"id's must be globally unique within Data Router usages\");\n if (isIndexRoute(route)) {\n let indexRoute = _extends({}, route, mapRouteProperties(route), {\n id\n });\n manifest[id] = indexRoute;\n return indexRoute;\n } else {\n let pathOrLayoutRoute = _extends({}, route, mapRouteProperties(route), {\n id,\n children: undefined\n });\n manifest[id] = pathOrLayoutRoute;\n if (route.children) {\n pathOrLayoutRoute.children = convertRoutesToDataRoutes(route.children, mapRouteProperties, treePath, manifest);\n }\n return pathOrLayoutRoute;\n }\n });\n}\n/**\n * Matches the given routes to a location and returns the match data.\n *\n * @see https://reactrouter.com/v6/utils/match-routes\n */\nfunction matchRoutes(routes, locationArg, basename) {\n if (basename === void 0) {\n basename = \"/\";\n }\n return matchRoutesImpl(routes, locationArg, basename, false);\n}\nfunction matchRoutesImpl(routes, locationArg, basename, allowPartial) {\n let location = typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n let pathname = stripBasename(location.pathname || \"/\", basename);\n if (pathname == null) {\n return null;\n }\n let branches = flattenRoutes(routes);\n rankRouteBranches(branches);\n let matches = null;\n for (let i = 0; matches == null && i < branches.length; ++i) {\n // Incoming pathnames are generally encoded from either window.location\n // or from router.navigate, but we want to match against the unencoded\n // paths in the route definitions. Memory router locations won't be\n // encoded here but there also shouldn't be anything to decode so this\n // should be a safe operation. This avoids needing matchRoutes to be\n // history-aware.\n let decoded = decodePath(pathname);\n matches = matchRouteBranch(branches[i], decoded, allowPartial);\n }\n return matches;\n}\nfunction convertRouteMatchToUiMatch(match, loaderData) {\n let {\n route,\n pathname,\n params\n } = match;\n return {\n id: route.id,\n pathname,\n params,\n data: loaderData[route.id],\n handle: route.handle\n };\n}\nfunction flattenRoutes(routes, branches, parentsMeta, parentPath) {\n if (branches === void 0) {\n branches = [];\n }\n if (parentsMeta === void 0) {\n parentsMeta = [];\n }\n if (parentPath === void 0) {\n parentPath = \"\";\n }\n let flattenRoute = (route, index, relativePath) => {\n let meta = {\n relativePath: relativePath === undefined ? route.path || \"\" : relativePath,\n caseSensitive: route.caseSensitive === true,\n childrenIndex: index,\n route\n };\n if (meta.relativePath.startsWith(\"/\")) {\n invariant(meta.relativePath.startsWith(parentPath), \"Absolute route path \\\"\" + meta.relativePath + \"\\\" nested under path \" + (\"\\\"\" + parentPath + \"\\\" is not valid. An absolute child route path \") + \"must start with the combined path of all its parent routes.\");\n meta.relativePath = meta.relativePath.slice(parentPath.length);\n }\n let path = joinPaths([parentPath, meta.relativePath]);\n let routesMeta = parentsMeta.concat(meta);\n // Add the children before adding this route to the array, so we traverse the\n // route tree depth-first and child routes appear before their parents in\n // the \"flattened\" version.\n if (route.children && route.children.length > 0) {\n invariant(\n // Our types know better, but runtime JS may not!\n // @ts-expect-error\n route.index !== true, \"Index routes must not have child routes. Please remove \" + (\"all child routes from route path \\\"\" + path + \"\\\".\"));\n flattenRoutes(route.children, branches, routesMeta, path);\n }\n // Routes without a path shouldn't ever match by themselves unless they are\n // index routes, so don't add them to the list of possible branches.\n if (route.path == null && !route.index) {\n return;\n }\n branches.push({\n path,\n score: computeScore(path, route.index),\n routesMeta\n });\n };\n routes.forEach((route, index) => {\n var _route$path;\n // coarse-grain check for optional params\n if (route.path === \"\" || !((_route$path = route.path) != null && _route$path.includes(\"?\"))) {\n flattenRoute(route, index);\n } else {\n for (let exploded of explodeOptionalSegments(route.path)) {\n flattenRoute(route, index, exploded);\n }\n }\n });\n return branches;\n}\n/**\n * Computes all combinations of optional path segments for a given path,\n * excluding combinations that are ambiguous and of lower priority.\n *\n * For example, `/one/:two?/three/:four?/:five?` explodes to:\n * - `/one/three`\n * - `/one/:two/three`\n * - `/one/three/:four`\n * - `/one/three/:five`\n * - `/one/:two/three/:four`\n * - `/one/:two/three/:five`\n * - `/one/three/:four/:five`\n * - `/one/:two/three/:four/:five`\n */\nfunction explodeOptionalSegments(path) {\n let segments = path.split(\"/\");\n if (segments.length === 0) return [];\n let [first, ...rest] = segments;\n // Optional path segments are denoted by a trailing `?`\n let isOptional = first.endsWith(\"?\");\n // Compute the corresponding required segment: `foo?` -> `foo`\n let required = first.replace(/\\?$/, \"\");\n if (rest.length === 0) {\n // Intepret empty string as omitting an optional segment\n // `[\"one\", \"\", \"three\"]` corresponds to omitting `:two` from `/one/:two?/three` -> `/one/three`\n return isOptional ? [required, \"\"] : [required];\n }\n let restExploded = explodeOptionalSegments(rest.join(\"/\"));\n let result = [];\n // All child paths with the prefix. Do this for all children before the\n // optional version for all children, so we get consistent ordering where the\n // parent optional aspect is preferred as required. Otherwise, we can get\n // child sections interspersed where deeper optional segments are higher than\n // parent optional segments, where for example, /:two would explode _earlier_\n // then /:one. By always including the parent as required _for all children_\n // first, we avoid this issue\n result.push(...restExploded.map(subpath => subpath === \"\" ? required : [required, subpath].join(\"/\")));\n // Then, if this is an optional value, add all child versions without\n if (isOptional) {\n result.push(...restExploded);\n }\n // for absolute paths, ensure `/` instead of empty segment\n return result.map(exploded => path.startsWith(\"/\") && exploded === \"\" ? \"/\" : exploded);\n}\nfunction rankRouteBranches(branches) {\n branches.sort((a, b) => a.score !== b.score ? b.score - a.score // Higher score first\n : compareIndexes(a.routesMeta.map(meta => meta.childrenIndex), b.routesMeta.map(meta => meta.childrenIndex)));\n}\nconst paramRe = /^:[\\w-]+$/;\nconst dynamicSegmentValue = 3;\nconst indexRouteValue = 2;\nconst emptySegmentValue = 1;\nconst staticSegmentValue = 10;\nconst splatPenalty = -2;\nconst isSplat = s => s === \"*\";\nfunction computeScore(path, index) {\n let segments = path.split(\"/\");\n let initialScore = segments.length;\n if (segments.some(isSplat)) {\n initialScore += splatPenalty;\n }\n if (index) {\n initialScore += indexRouteValue;\n }\n return segments.filter(s => !isSplat(s)).reduce((score, segment) => score + (paramRe.test(segment) ? dynamicSegmentValue : segment === \"\" ? emptySegmentValue : staticSegmentValue), initialScore);\n}\nfunction compareIndexes(a, b) {\n let siblings = a.length === b.length && a.slice(0, -1).every((n, i) => n === b[i]);\n return siblings ?\n // If two routes are siblings, we should try to match the earlier sibling\n // first. This allows people to have fine-grained control over the matching\n // behavior by simply putting routes with identical paths in the order they\n // want them tried.\n a[a.length - 1] - b[b.length - 1] :\n // Otherwise, it doesn't really make sense to rank non-siblings by index,\n // so they sort equally.\n 0;\n}\nfunction matchRouteBranch(branch, pathname, allowPartial) {\n if (allowPartial === void 0) {\n allowPartial = false;\n }\n let {\n routesMeta\n } = branch;\n let matchedParams = {};\n let matchedPathname = \"/\";\n let matches = [];\n for (let i = 0; i < routesMeta.length; ++i) {\n let meta = routesMeta[i];\n let end = i === routesMeta.length - 1;\n let remainingPathname = matchedPathname === \"/\" ? pathname : pathname.slice(matchedPathname.length) || \"/\";\n let match = matchPath({\n path: meta.relativePath,\n caseSensitive: meta.caseSensitive,\n end\n }, remainingPathname);\n let route = meta.route;\n if (!match && end && allowPartial && !routesMeta[routesMeta.length - 1].route.index) {\n match = matchPath({\n path: meta.relativePath,\n caseSensitive: meta.caseSensitive,\n end: false\n }, remainingPathname);\n }\n if (!match) {\n return null;\n }\n Object.assign(matchedParams, match.params);\n matches.push({\n // TODO: Can this as be avoided?\n params: matchedParams,\n pathname: joinPaths([matchedPathname, match.pathname]),\n pathnameBase: normalizePathname(joinPaths([matchedPathname, match.pathnameBase])),\n route\n });\n if (match.pathnameBase !== \"/\") {\n matchedPathname = joinPaths([matchedPathname, match.pathnameBase]);\n }\n }\n return matches;\n}\n/**\n * Returns a path with params interpolated.\n *\n * @see https://reactrouter.com/v6/utils/generate-path\n */\nfunction generatePath(originalPath, params) {\n if (params === void 0) {\n params = {};\n }\n let path = originalPath;\n if (path.endsWith(\"*\") && path !== \"*\" && !path.endsWith(\"/*\")) {\n warning(false, \"Route path \\\"\" + path + \"\\\" will be treated as if it were \" + (\"\\\"\" + path.replace(/\\*$/, \"/*\") + \"\\\" because the `*` character must \") + \"always follow a `/` in the pattern. To get rid of this warning, \" + (\"please change the route path to \\\"\" + path.replace(/\\*$/, \"/*\") + \"\\\".\"));\n path = path.replace(/\\*$/, \"/*\");\n }\n // ensure `/` is added at the beginning if the path is absolute\n const prefix = path.startsWith(\"/\") ? \"/\" : \"\";\n const stringify = p => p == null ? \"\" : typeof p === \"string\" ? p : String(p);\n const segments = path.split(/\\/+/).map((segment, index, array) => {\n const isLastSegment = index === array.length - 1;\n // only apply the splat if it's the last segment\n if (isLastSegment && segment === \"*\") {\n const star = \"*\";\n // Apply the splat\n return stringify(params[star]);\n }\n const keyMatch = segment.match(/^:([\\w-]+)(\\??)$/);\n if (keyMatch) {\n const [, key, optional] = keyMatch;\n let param = params[key];\n invariant(optional === \"?\" || param != null, \"Missing \\\":\" + key + \"\\\" param\");\n return stringify(param);\n }\n // Remove any optional markers from optional static segments\n return segment.replace(/\\?$/g, \"\");\n })\n // Remove empty segments\n .filter(segment => !!segment);\n return prefix + segments.join(\"/\");\n}\n/**\n * Performs pattern matching on a URL pathname and returns information about\n * the match.\n *\n * @see https://reactrouter.com/v6/utils/match-path\n */\nfunction matchPath(pattern, pathname) {\n if (typeof pattern === \"string\") {\n pattern = {\n path: pattern,\n caseSensitive: false,\n end: true\n };\n }\n let [matcher, compiledParams] = compilePath(pattern.path, pattern.caseSensitive, pattern.end);\n let match = pathname.match(matcher);\n if (!match) return null;\n let matchedPathname = match[0];\n let pathnameBase = matchedPathname.replace(/(.)\\/+$/, \"$1\");\n let captureGroups = match.slice(1);\n let params = compiledParams.reduce((memo, _ref, index) => {\n let {\n paramName,\n isOptional\n } = _ref;\n // We need to compute the pathnameBase here using the raw splat value\n // instead of using params[\"*\"] later because it will be decoded then\n if (paramName === \"*\") {\n let splatValue = captureGroups[index] || \"\";\n pathnameBase = matchedPathname.slice(0, matchedPathname.length - splatValue.length).replace(/(.)\\/+$/, \"$1\");\n }\n const value = captureGroups[index];\n if (isOptional && !value) {\n memo[paramName] = undefined;\n } else {\n memo[paramName] = (value || \"\").replace(/%2F/g, \"/\");\n }\n return memo;\n }, {});\n return {\n params,\n pathname: matchedPathname,\n pathnameBase,\n pattern\n };\n}\nfunction compilePath(path, caseSensitive, end) {\n if (caseSensitive === void 0) {\n caseSensitive = false;\n }\n if (end === void 0) {\n end = true;\n }\n warning(path === \"*\" || !path.endsWith(\"*\") || path.endsWith(\"/*\"), \"Route path \\\"\" + path + \"\\\" will be treated as if it were \" + (\"\\\"\" + path.replace(/\\*$/, \"/*\") + \"\\\" because the `*` character must \") + \"always follow a `/` in the pattern. To get rid of this warning, \" + (\"please change the route path to \\\"\" + path.replace(/\\*$/, \"/*\") + \"\\\".\"));\n let params = [];\n let regexpSource = \"^\" + path.replace(/\\/*\\*?$/, \"\") // Ignore trailing / and /*, we'll handle it below\n .replace(/^\\/*/, \"/\") // Make sure it has a leading /\n .replace(/[\\\\.*+^${}|()[\\]]/g, \"\\\\$&\") // Escape special regex chars\n .replace(/\\/:([\\w-]+)(\\?)?/g, (_, paramName, isOptional) => {\n params.push({\n paramName,\n isOptional: isOptional != null\n });\n return isOptional ? \"/?([^\\\\/]+)?\" : \"/([^\\\\/]+)\";\n });\n if (path.endsWith(\"*\")) {\n params.push({\n paramName: \"*\"\n });\n regexpSource += path === \"*\" || path === \"/*\" ? \"(.*)$\" // Already matched the initial /, just match the rest\n : \"(?:\\\\/(.+)|\\\\/*)$\"; // Don't include the / in params[\"*\"]\n } else if (end) {\n // When matching to the end, ignore trailing slashes\n regexpSource += \"\\\\/*$\";\n } else if (path !== \"\" && path !== \"/\") {\n // If our path is non-empty and contains anything beyond an initial slash,\n // then we have _some_ form of path in our regex, so we should expect to\n // match only if we find the end of this path segment. Look for an optional\n // non-captured trailing slash (to match a portion of the URL) or the end\n // of the path (if we've matched to the end). We used to do this with a\n // word boundary but that gives false positives on routes like\n // /user-preferences since `-` counts as a word boundary.\n regexpSource += \"(?:(?=\\\\/|$))\";\n } else ;\n let matcher = new RegExp(regexpSource, caseSensitive ? undefined : \"i\");\n return [matcher, params];\n}\nfunction decodePath(value) {\n try {\n return value.split(\"/\").map(v => decodeURIComponent(v).replace(/\\//g, \"%2F\")).join(\"/\");\n } catch (error) {\n warning(false, \"The URL path \\\"\" + value + \"\\\" could not be decoded because it is is a \" + \"malformed URL segment. This is probably due to a bad percent \" + (\"encoding (\" + error + \").\"));\n return value;\n }\n}\n/**\n * @private\n */\nfunction stripBasename(pathname, basename) {\n if (basename === \"/\") return pathname;\n if (!pathname.toLowerCase().startsWith(basename.toLowerCase())) {\n return null;\n }\n // We want to leave trailing slash behavior in the user's control, so if they\n // specify a basename with a trailing slash, we should support it\n let startIndex = basename.endsWith(\"/\") ? basename.length - 1 : basename.length;\n let nextChar = pathname.charAt(startIndex);\n if (nextChar && nextChar !== \"/\") {\n // pathname does not start with basename/\n return null;\n }\n return pathname.slice(startIndex) || \"/\";\n}\nconst ABSOLUTE_URL_REGEX$1 = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\nconst isAbsoluteUrl = url => ABSOLUTE_URL_REGEX$1.test(url);\n/**\n * Returns a resolved path object relative to the given pathname.\n *\n * @see https://reactrouter.com/v6/utils/resolve-path\n */\nfunction resolvePath(to, fromPathname) {\n if (fromPathname === void 0) {\n fromPathname = \"/\";\n }\n let {\n pathname: toPathname,\n search = \"\",\n hash = \"\"\n } = typeof to === \"string\" ? parsePath(to) : to;\n let pathname;\n if (toPathname) {\n if (isAbsoluteUrl(toPathname)) {\n pathname = toPathname;\n } else {\n if (toPathname.includes(\"//\")) {\n let oldPathname = toPathname;\n toPathname = toPathname.replace(/\\/\\/+/g, \"/\");\n warning(false, \"Pathnames cannot have embedded double slashes - normalizing \" + (oldPathname + \" -> \" + toPathname));\n }\n if (toPathname.startsWith(\"/\")) {\n pathname = resolvePathname(toPathname.substring(1), \"/\");\n } else {\n pathname = resolvePathname(toPathname, fromPathname);\n }\n }\n } else {\n pathname = fromPathname;\n }\n return {\n pathname,\n search: normalizeSearch(search),\n hash: normalizeHash(hash)\n };\n}\nfunction resolvePathname(relativePath, fromPathname) {\n let segments = fromPathname.replace(/\\/+$/, \"\").split(\"/\");\n let relativeSegments = relativePath.split(\"/\");\n relativeSegments.forEach(segment => {\n if (segment === \"..\") {\n // Keep the root \"\" segment so the pathname starts at /\n if (segments.length > 1) segments.pop();\n } else if (segment !== \".\") {\n segments.push(segment);\n }\n });\n return segments.length > 1 ? segments.join(\"/\") : \"/\";\n}\nfunction getInvalidPathError(char, field, dest, path) {\n return \"Cannot include a '\" + char + \"' character in a manually specified \" + (\"`to.\" + field + \"` field [\" + JSON.stringify(path) + \"]. Please separate it out to the \") + (\"`to.\" + dest + \"` field. Alternatively you may provide the full path as \") + \"a string in <Link to=\\\"...\\\"> and the router will parse it for you.\";\n}\n/**\n * @private\n *\n * When processing relative navigation we want to ignore ancestor routes that\n * do not contribute to the path, such that index/pathless layout routes don't\n * interfere.\n *\n * For example, when moving a route element into an index route and/or a\n * pathless layout route, relative link behavior contained within should stay\n * the same. Both of the following examples should link back to the root:\n *\n * <Route path=\"/\">\n * <Route path=\"accounts\" element={<Link to=\"..\"}>\n * </Route>\n *\n * <Route path=\"/\">\n * <Route path=\"accounts\">\n * <Route element={<AccountsLayout />}> // <-- Does not contribute\n * <Route index element={<Link to=\"..\"} /> // <-- Does not contribute\n * </Route\n * </Route>\n * </Route>\n */\nfunction getPathContributingMatches(matches) {\n return matches.filter((match, index) => index === 0 || match.route.path && match.route.path.length > 0);\n}\n// Return the array of pathnames for the current route matches - used to\n// generate the routePathnames input for resolveTo()\nfunction getResolveToMatches(matches, v7_relativeSplatPath) {\n let pathMatches = getPathContributingMatches(matches);\n // When v7_relativeSplatPath is enabled, use the full pathname for the leaf\n // match so we include splat values for \".\" links. See:\n // https://github.com/remix-run/react-router/issues/11052#issuecomment-1836589329\n if (v7_relativeSplatPath) {\n return pathMatches.map((match, idx) => idx === pathMatches.length - 1 ? match.pathname : match.pathnameBase);\n }\n return pathMatches.map(match => match.pathnameBase);\n}\n/**\n * @private\n */\nfunction resolveTo(toArg, routePathnames, locationPathname, isPathRelative) {\n if (isPathRelative === void 0) {\n isPathRelative = false;\n }\n let to;\n if (typeof toArg === \"string\") {\n to = parsePath(toArg);\n } else {\n to = _extends({}, toArg);\n invariant(!to.pathname || !to.pathname.includes(\"?\"), getInvalidPathError(\"?\", \"pathname\", \"search\", to));\n invariant(!to.pathname || !to.pathname.includes(\"#\"), getInvalidPathError(\"#\", \"pathname\", \"hash\", to));\n invariant(!to.search || !to.search.includes(\"#\"), getInvalidPathError(\"#\", \"search\", \"hash\", to));\n }\n let isEmptyPath = toArg === \"\" || to.pathname === \"\";\n let toPathname = isEmptyPath ? \"/\" : to.pathname;\n let from;\n // Routing is relative to the current pathname if explicitly requested.\n //\n // If a pathname is explicitly provided in `to`, it should be relative to the\n // route context. This is explained in `Note on `<Link to>` values` in our\n // migration guide from v5 as a means of disambiguation between `to` values\n // that begin with `/` and those that do not. However, this is problematic for\n // `to` values that do not provide a pathname. `to` can simply be a search or\n // hash string, in which case we should assume that the navigation is relative\n // to the current location's pathname and *not* the route pathname.\n if (toPathname == null) {\n from = locationPathname;\n } else {\n let routePathnameIndex = routePathnames.length - 1;\n // With relative=\"route\" (the default), each leading .. segment means\n // \"go up one route\" instead of \"go up one URL segment\". This is a key\n // difference from how <a href> works and a major reason we call this a\n // \"to\" value instead of a \"href\".\n if (!isPathRelative && toPathname.startsWith(\"..\")) {\n let toSegments = toPathname.split(\"/\");\n while (toSegments[0] === \"..\") {\n toSegments.shift();\n routePathnameIndex -= 1;\n }\n to.pathname = toSegments.join(\"/\");\n }\n from = routePathnameIndex >= 0 ? routePathnames[routePathnameIndex] : \"/\";\n }\n let path = resolvePath(to, from);\n // Ensure the pathname has a trailing slash if the original \"to\" had one\n let hasExplicitTrailingSlash = toPathname && toPathname !== \"/\" && toPathname.endsWith(\"/\");\n // Or if this was a link to the current path which has a trailing slash\n let hasCurrentTrailingSlash = (isEmptyPath || toPathname === \".\") && locationPathname.endsWith(\"/\");\n if (!path.pathname.endsWith(\"/\") && (hasExplicitTrailingSlash || hasCurrentTrailingSlash)) {\n path.pathname += \"/\";\n }\n return path;\n}\n/**\n * @private\n */\nfunction getToPathname(to) {\n // Empty strings should be treated the same as / paths\n return to === \"\" || to.pathname === \"\" ? \"/\" : typeof to === \"string\" ? parsePath(to).pathname : to.pathname;\n}\n/**\n * @private\n */\nconst joinPaths = paths => paths.join(\"/\").replace(/\\/\\/+/g, \"/\");\n/**\n * @private\n */\nconst normalizePathname = pathname => pathname.replace(/\\/+$/, \"\").replace(/^\\/*/, \"/\");\n/**\n * @private\n */\nconst normalizeSearch = search => !search || search === \"?\" ? \"\" : search.startsWith(\"?\") ? search : \"?\" + search;\n/**\n * @private\n */\nconst normalizeHash = hash => !hash || hash === \"#\" ? \"\" : hash.startsWith(\"#\") ? hash : \"#\" + hash;\n/**\n * This is a shortcut for creating `application/json` responses. Converts `data`\n * to JSON and sets the `Content-Type` header.\n *\n * @deprecated The `json` method is deprecated in favor of returning raw objects.\n * This method will be removed in v7.\n */\nconst json = function json(data, init) {\n if (init === void 0) {\n init = {};\n }\n let responseInit = typeof init === \"number\" ? {\n status: init\n } : init;\n let headers = new Headers(responseInit.headers);\n if (!headers.has(\"Content-Type\")) {\n headers.set(\"Content-Type\", \"application/json; charset=utf-8\");\n }\n return new Response(JSON.stringify(data), _extends({}, responseInit, {\n headers\n }));\n};\nclass DataWithResponseInit {\n constructor(data, init) {\n this.type = \"DataWithResponseInit\";\n this.data = data;\n this.init = init || null;\n }\n}\n/**\n * Create \"responses\" that contain `status`/`headers` without forcing\n * serialization into an actual `Response` - used by Remix single fetch\n */\nfunction data(data, init) {\n return new DataWithResponseInit(data, typeof init === \"number\" ? {\n status: init\n } : init);\n}\nclass AbortedDeferredError extends Error {}\nclass DeferredData {\n constructor(data, responseInit) {\n this.pendingKeysSet = new Set();\n this.subscribers = new Set();\n this.deferredKeys = [];\n invariant(data && typeof data === \"object\" && !Array.isArray(data), \"defer() only accepts plain objects\");\n // Set up an AbortController + Promise we can race against to exit early\n // cancellation\n let reject;\n this.abortPromise = new Promise((_, r) => reject = r);\n this.controller = new AbortController();\n let onAbort = () => reject(new AbortedDeferredError(\"Deferred data aborted\"));\n this.unlistenAbortSignal = () => this.controller.signal.removeEventListener(\"abort\", onAbort);\n this.controller.signal.addEventListener(\"abort\", onAbort);\n this.data = Object.entries(data).reduce((acc, _ref2) => {\n let [key, value] = _ref2;\n return Object.assign(acc, {\n [key]: this.trackPromise(key, value)\n });\n }, {});\n if (this.done) {\n // All incoming values were resolved\n this.unlistenAbortSignal();\n }\n this.init = responseInit;\n }\n trackPromise(key, value) {\n if (!(value instanceof Promise)) {\n return value;\n }\n this.deferredKeys.push(key);\n this.pendingKeysSet.add(key);\n // We store a little wrapper promise that will be extended with\n // _data/_error props upon resolve/reject\n let promise = Promise.race([value, this.abortPromise]).then(data => this.onSettle(promise, key, undefined, data), error => this.onSettle(promise, key, error));\n // Register rejection listeners to avoid uncaught promise rejections on\n // errors or aborted deferred values\n promise.catch(() => {});\n Object.defineProperty(promise, \"_tracked\", {\n get: () => true\n });\n return promise;\n }\n onSettle(promise, key, error, data) {\n if (this.controller.signal.aborted && error instanceof AbortedDeferredError) {\n this.unlistenAbortSignal();\n Object.defineProperty(promise, \"_error\", {\n get: () => error\n });\n return Promise.reject(error);\n }\n this.pendingKeysSet.delete(key);\n if (this.done) {\n // Nothing left to abort!\n this.unlistenAbortSignal();\n }\n // If the promise was resolved/rejected with undefined, we'll throw an error as you\n // should always resolve with a value or null\n if (error === undefined && data === undefined) {\n let undefinedError = new Error(\"Deferred data for key \\\"\" + key + \"\\\" resolved/rejected with `undefined`, \" + \"you must resolve/reject with a value or `null`.\");\n Object.defineProperty(promise, \"_error\", {\n get: () => undefinedError\n });\n this.emit(false, key);\n return Promise.reject(undefinedError);\n }\n if (data === undefined) {\n Object.defineProperty(promise, \"_error\", {\n get: () => error\n });\n this.emit(false, key);\n return Promise.reject(error);\n }\n Object.defineProperty(promise, \"_data\", {\n get: () => data\n });\n this.emit(false, key);\n return data;\n }\n emit(aborted, settledKey) {\n this.subscribers.forEach(subscriber => subscriber(aborted, settledKey));\n }\n subscribe(fn) {\n this.subscribers.add(fn);\n return () => this.subscribers.delete(fn);\n }\n cancel() {\n this.controller.abort();\n this.pendingKeysSet.forEach((v, k) => this.pendingKeysSet.delete(k));\n this.emit(true);\n }\n async resolveData(signal) {\n let aborted = false;\n if (!this.done) {\n let onAbort = () => this.cancel();\n signal.addEventListener(\"abort\", onAbort);\n aborted = await new Promise(resolve => {\n this.subscribe(aborted => {\n signal.removeEventListener(\"abort\", onAbort);\n if (aborted || this.done) {\n resolve(aborted);\n }\n });\n });\n }\n return aborted;\n }\n get done() {\n return this.pendingKeysSet.size === 0;\n }\n get unwrappedData() {\n invariant(this.data !== null && this.done, \"Can only unwrap data on initialized and settled deferreds\");\n return Object.entries(this.data).reduce((acc, _ref3) => {\n let [key, value] = _ref3;\n return Object.assign(acc, {\n [key]: unwrapTrackedPromise(value)\n });\n }, {});\n }\n get pendingKeys() {\n return Array.from(this.pendingKeysSet);\n }\n}\nfunction isTrackedPromise(value) {\n return value instanceof Promise && value._tracked === true;\n}\nfunction unwrapTrackedPromise(value) {\n if (!isTrackedPromise(value)) {\n return value;\n }\n if (value._error) {\n throw value._error;\n }\n return value._data;\n}\n/**\n * @deprecated The `defer` method is deprecated in favor of returning raw\n * objects. This method will be removed in v7.\n */\nconst defer = function defer(data, init) {\n if (init === void 0) {\n init = {};\n }\n let responseInit = typeof init === \"number\" ? {\n status: init\n } : init;\n return new DeferredData(data, responseInit);\n};\n/**\n * A redirect response. Sets the status code and the `Location` header.\n * Defaults to \"302 Found\".\n */\nconst redirect = function redirect(url, init) {\n if (init === void 0) {\n init = 302;\n }\n let responseInit = init;\n if (typeof responseInit === \"number\") {\n responseInit = {\n status: responseInit\n };\n } else if (typeof responseInit.status === \"undefined\") {\n responseInit.status = 302;\n }\n let headers = new Headers(responseInit.headers);\n headers.set(\"Location\", url);\n return new Response(null, _extends({}, responseInit, {\n headers\n }));\n};\n/**\n * A redirect response that will force a document reload to the new location.\n * Sets the status code and the `Location` header.\n * Defaults to \"302 Found\".\n */\nconst redirectDocument = (url, init) => {\n let response = redirect(url, init);\n response.headers.set(\"X-Remix-Reload-Document\", \"true\");\n return response;\n};\n/**\n * A redirect response that will perform a `history.replaceState` instead of a\n * `history.pushState` for client-side navigation redirects.\n * Sets the status code and the `Location` header.\n * Defaults to \"302 Found\".\n */\nconst replace = (url, init) => {\n let response = redirect(url, init);\n response.headers.set(\"X-Remix-Replace\", \"true\");\n return response;\n};\n/**\n * @private\n * Utility class we use to hold auto-unwrapped 4xx/5xx Response bodies\n *\n * We don't export the class for public use since it's an implementation\n * detail, but we export the interface above so folks can build their own\n * abstractions around instances via isRouteErrorResponse()\n */\nclass ErrorResponseImpl {\n constructor(status, statusText, data, internal) {\n if (internal === void 0) {\n internal = false;\n }\n this.status = status;\n this.statusText = statusText || \"\";\n this.internal = internal;\n if (data instanceof Error) {\n this.data = data.toString();\n this.error = data;\n } else {\n this.data = data;\n }\n }\n}\n/**\n * Check if the given error is an ErrorResponse generated from a 4xx/5xx\n * Response thrown from an action/loader\n */\nfunction isRouteErrorResponse(error) {\n return error != null && typeof error.status === \"number\" && typeof error.statusText === \"string\" && typeof error.internal === \"boolean\" && \"data\" in error;\n}\n\nconst validMutationMethodsArr = [\"post\", \"put\", \"patch\", \"delete\"];\nconst validMutationMethods = new Set(validMutationMethodsArr);\nconst validRequestMethodsArr = [\"get\", ...validMutationMethodsArr];\nconst validRequestMethods = new Set(validRequestMethodsArr);\nconst redirectStatusCodes = new Set([301, 302, 303, 307, 308]);\nconst redirectPreserveMethodStatusCodes = new Set([307, 308]);\nconst IDLE_NAVIGATION = {\n state: \"idle\",\n location: undefined,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined\n};\nconst IDLE_FETCHER = {\n state: \"idle\",\n data: undefined,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined\n};\nconst IDLE_BLOCKER = {\n state: \"unblocked\",\n proceed: undefined,\n reset: undefined,\n location: undefined\n};\nconst ABSOLUTE_URL_REGEX = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\nconst defaultMapRouteProperties = route => ({\n hasErrorBoundary: Boolean(route.hasErrorBoundary)\n});\nconst TRANSITIONS_STORAGE_KEY = \"remix-router-transitions\";\n//#endregion\n////////////////////////////////////////////////////////////////////////////////\n//#region createRouter\n////////////////////////////////////////////////////////////////////////////////\n/**\n * Create a router and listen to history POP navigations\n */\nfunction createRouter(init) {\n const routerWindow = init.window ? init.window : typeof window !== \"undefined\" ? window : undefined;\n const isBrowser = typeof routerWindow !== \"undefined\" && typeof routerWindow.document !== \"undefined\" && typeof routerWindow.document.createElement !== \"undefined\";\n const isServer = !isBrowser;\n invariant(init.routes.length > 0, \"You must provide a non-empty routes array to createRouter\");\n let mapRouteProperties;\n if (init.mapRouteProperties) {\n mapRouteProperties = init.mapRouteProperties;\n } else if (init.detectErrorBoundary) {\n // If they are still using the deprecated version, wrap it with the new API\n let detectErrorBoundary = init.detectErrorBoundary;\n mapRouteProperties = route => ({\n hasErrorBoundary: detectErrorBoundary(route)\n });\n } else {\n mapRouteProperties = defaultMapRouteProperties;\n }\n // Routes keyed by ID\n let manifest = {};\n // Routes in tree format for matching\n let dataRoutes = convertRoutesToDataRoutes(init.routes, mapRouteProperties, undefined, manifest);\n let inFlightDataRoutes;\n let basename = init.basename || \"/\";\n let dataStrategyImpl = init.dataStrategy || defaultDataStrategy;\n let patchRoutesOnNavigationImpl = init.patchRoutesOnNavigation;\n // Config driven behavior flags\n let future = _extends({\n v7_fetcherPersist: false,\n v7_normalizeFormMethod: false,\n v7_partialHydration: false,\n v7_prependBasename: false,\n v7_relativeSplatPath: false,\n v7_skipActionErrorRevalidation: false\n }, init.future);\n // Cleanup function for history\n let unlistenHistory = null;\n // Externally-provided functions to call on all state changes\n let subscribers = new Set();\n // Externally-provided object to hold scroll restoration locations during routing\n let savedScrollPositions = null;\n // Externally-provided function to get scroll restoration keys\n let getScrollRestorationKey = null;\n // Externally-provided function to get current scroll position\n let getScrollPosition = null;\n // One-time flag to control the initial hydration scroll restoration. Because\n // we don't get the saved positions from <ScrollRestoration /> until _after_\n // the initial render, we need to manually trigger a separate updateState to\n // send along the restoreScrollPosition\n // Set to true if we have `hydrationData` since we assume we were SSR'd and that\n // SSR did the initial scroll restoration.\n let initialScrollRestored = init.hydrationData != null;\n let initialMatches = matchRoutes(dataRoutes, init.history.location, basename);\n let initialMatchesIsFOW = false;\n let initialErrors = null;\n if (initialMatches == null && !patchRoutesOnNavigationImpl) {\n // If we do not match a user-provided-route, fall back to the root\n // to allow the error boundary to take over\n let error = getInternalRouterError(404, {\n pathname: init.history.location.pathname\n });\n let {\n matches,\n route\n } = getShortCircuitMatches(dataRoutes);\n initialMatches = matches;\n initialErrors = {\n [route.id]: error\n };\n }\n // In SPA apps, if the user provided a patchRoutesOnNavigation implementation and\n // our initial match is a splat route, clear them out so we run through lazy\n // discovery on hydration in case there's a more accurate lazy route match.\n // In SSR apps (with `hydrationData`), we expect that the server will send\n // up the proper matched routes so we don't want to run lazy discovery on\n // initial hydration and want to hydrate into the splat route.\n if (initialMatches && !init.hydrationData) {\n let fogOfWar = checkFogOfWar(initialMatches, dataRoutes, init.history.location.pathname);\n if (fogOfWar.active) {\n initialMatches = null;\n }\n }\n let initialized;\n if (!initialMatches) {\n initialized = false;\n initialMatches = [];\n // If partial hydration and fog of war is enabled, we will be running\n // `patchRoutesOnNavigation` during hydration so include any partial matches as\n // the initial matches so we can properly render `HydrateFallback`'s\n if (future.v7_partialHydration) {\n let fogOfWar = checkFogOfWar(null, dataRoutes, init.history.location.pathname);\n if (fogOfWar.active && fogOfWar.matches) {\n initialMatchesIsFOW = true;\n initialMatches = fogOfWar.matches;\n }\n }\n } else if (initialMatches.some(m => m.route.lazy)) {\n // All initialMatches need to be loaded before we're ready. If we have lazy\n // functions around still then we'll need to run them in initialize()\n initialized = false;\n } else if (!initialMatches.some(m => m.route.loader)) {\n // If we've got no loaders to run, then we're good to go\n initialized = true;\n } else if (future.v7_partialHydration) {\n // If partial hydration is enabled, we're initialized so long as we were\n // provided with hydrationData for every route with a loader, and no loaders\n // were marked for explicit hydration\n let loaderData = init.hydrationData ? init.hydrationData.loaderData : null;\n let errors = init.hydrationData ? init.hydrationData.errors : null;\n // If errors exist, don't consider routes below the boundary\n if (errors) {\n let idx = initialMatches.findIndex(m => errors[m.route.id] !== undefined);\n initialized = initialMatches.slice(0, idx + 1).every(m => !shouldLoadRouteOnHydration(m.route, loaderData, errors));\n } else {\n initialized = initialMatches.every(m => !shouldLoadRouteOnHydration(m.route, loaderData, errors));\n }\n } else {\n // Without partial hydration - we're initialized if we were provided any\n // hydrationData - which is expected to be complete\n initialized = init.hydrationData != null;\n }\n let router;\n let state = {\n historyAction: init.history.action,\n location: init.history.location,\n matches: initialMatches,\n initialized,\n navigation: IDLE_NAVIGATION,\n // Don't restore on initial updateState() if we were SSR'd\n restoreScrollPosition: init.hydrationData != null ? false : null,\n preventScrollReset: false,\n revalidation: \"idle\",\n loaderData: init.hydrationData && init.hydrationData.loaderData || {},\n actionData: init.hydrationData && init.hydrationData.actionData || null,\n errors: init.hydrationData && init.hydrationData.errors || initialErrors,\n fetchers: new Map(),\n blockers: new Map()\n };\n // -- Stateful internal variables to manage navigations --\n // Current navigation in progress (to be committed in completeNavigation)\n let pendingAction = Action.Pop;\n // Should the current navigation prevent the scroll reset if scroll cannot\n // be restored?\n let pendingPreventScrollReset = false;\n // AbortController for the active navigation\n let pendingNavigationController;\n // Should the current navigation enable document.startViewTransition?\n let pendingViewTransitionEnabled = false;\n // Store applied view transitions so we can apply them on POP\n let appliedViewTransitions = new Map();\n // Cleanup function for persisting applied transitions to sessionStorage\n let removePageHideEventListener = null;\n // We use this to avoid touching history in completeNavigation if a\n // revalidation is entirely uninterrupted\n let isUninterruptedRevalidation = false;\n // Use this internal flag to force revalidation of all loaders:\n // - submissions (completed or interrupted)\n // - useRevalidator()\n // - X-Remix-Revalidate (from redirect)\n let isRevalidationRequired = false;\n // Use this internal array to capture routes that require revalidation due\n // to a cancelled deferred on action submission\n let cancelledDeferredRoutes = [];\n // Use this internal array to capture fetcher loads that were cancelled by an\n // action navigation and require revalidation\n let cancelledFetcherLoads = new Set();\n // AbortControllers for any in-flight fetchers\n let fetchControllers = new Map();\n // Track loads based on the order in which they started\n let incrementingLoadId = 0;\n // Track the outstanding pending navigation data load to be compared against\n // the globally incrementing load when a fetcher load lands after a completed\n // navigation\n let pendingNavigationLoadId = -1;\n // Fetchers that triggered data reloads as a result of their actions\n let fetchReloadIds = new Map();\n // Fetchers that triggered redirect navigations\n let fetchRedirectIds = new Set();\n // Most recent href/match for fetcher.load calls for fetchers\n let fetchLoadMatches = new Map();\n // Ref-count mounted fetchers so we know when it's ok to clean them up\n let activeFetchers = new Map();\n // Fetchers that have requested a delete when using v7_fetcherPersist,\n // they'll be officially removed after they return to idle\n let deletedFetchers = new Set();\n // Store DeferredData instances for active route matches. When a\n // route loader returns defer() we stick one in here. Then, when a nested\n // promise resolves we update loaderData. If a new navigation starts we\n // cancel active deferreds for eliminated routes.\n let activeDeferreds = new Map();\n // Store blocker functions in a separate Map outside of router state since\n // we don't need to update UI state if they change\n let blockerFunctions = new Map();\n // Flag to ignore the next history update, so we can revert the URL change on\n // a POP navigation that was blocked by the user without touching router state\n let unblockBlockerHistoryUpdate = undefined;\n // Initialize the router, all side effects should be kicked off from here.\n // Implemented as a Fluent API for ease of:\n // let router = createRouter(init).initialize();\n function initialize() {\n // If history informs us of a POP navigation, start the navigation but do not update\n // state. We'll update our own state once the navigation completes\n unlistenHistory = init.history.listen(_ref => {\n let {\n action: historyAction,\n location,\n delta\n } = _ref;\n // Ignore this event if it was just us resetting the URL from a\n // blocked POP navigation\n if (unblockBlockerHistoryUpdate) {\n unblockBlockerHistoryUpdate();\n unblockBlockerHistoryUpdate = undefined;\n return;\n }\n warning(blockerFunctions.size === 0 || delta != null, \"You are trying to use a blocker on a POP navigation to a location \" + \"that was not created by @remix-run/router. This will fail silently in \" + \"production. This can happen if you are navigating outside the router \" + \"via `window.history.pushState`/`window.location.hash` instead of using \" + \"router navigation APIs. This can also happen if you are using \" + \"createHashRouter and the user manually changes the URL.\");\n let blockerKey = shouldBlockNavigation({\n currentLocation: state.location,\n nextLocation: location,\n historyAction\n });\n if (blockerKey && delta != null) {\n // Restore the URL to match the current UI, but don't update router state\n let nextHistoryUpdatePromise = new Promise(resolve => {\n unblockBlockerHistoryUpdate = resolve;\n });\n init.history.go(delta * -1);\n // Put the blocker into a blocked state\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location,\n proceed() {\n updateBlocker(blockerKey, {\n state: \"proceeding\",\n proceed: undefined,\n reset: undefined,\n location\n });\n // Re-do the same POP navigation we just blocked, after the url\n // restoration is also complete. See:\n // https://github.com/remix-run/react-router/issues/11613\n nextHistoryUpdatePromise.then(() => init.history.go(delta));\n },\n reset() {\n let blockers = new Map(state.blockers);\n blockers.set(blockerKey, IDLE_BLOCKER);\n updateState({\n blockers\n });\n }\n });\n return;\n }\n return startNavigation(historyAction, location);\n });\n if (isBrowser) {\n // FIXME: This feels gross. How can we cleanup the lines between\n // scrollRestoration/appliedTransitions persistance?\n restoreAppliedTransitions(routerWindow, appliedViewTransitions);\n let _saveAppliedTransitions = () => persistAppliedTransitions(routerWindow, appliedViewTransitions);\n routerWindow.addEventListener(\"pagehide\", _saveAppliedTransitions);\n removePageHideEventListener = () => routerWindow.removeEventListener(\"pagehide\", _saveAppliedTransitions);\n }\n // Kick off initial data load if needed. Use Pop to avoid modifying history\n // Note we don't do any handling of lazy here. For SPA's it'll get handled\n // in the normal navigation flow. For SSR it's expected that lazy modules are\n // resolved prior to router creation since we can't go into a fallbackElement\n // UI for SSR'd apps\n if (!state.initialized) {\n startNavigation(Action.Pop, state.location, {\n initialHydration: true\n });\n }\n return router;\n }\n // Clean up a router and it's side effects\n function dispose() {\n if (unlistenHistory) {\n unlistenHistory();\n }\n if (removePageHideEventListener) {\n removePageHideEventListener();\n }\n subscribers.clear();\n pendingNavigationController && pendingNavigationController.abort();\n state.fetchers.forEach((_, key) => deleteFetcher(key));\n state.blockers.forEach((_, key) => deleteBlocker(key));\n }\n // Subscribe to state updates for the router\n function subscribe(fn) {\n subscribers.add(fn);\n return () => subscribers.delete(fn);\n }\n // Update our state and notify the calling context of the change\n function updateState(newState, opts) {\n if (opts === void 0) {\n opts = {};\n }\n state = _extends({}, state, newState);\n // Prep fetcher cleanup so we can tell the UI which fetcher data entries\n // can be removed\n let completedFetchers = [];\n let deletedFetchersKeys = [];\n if (future.v7_fetcherPersist) {\n state.fetchers.forEach((fetcher, key) => {\n if (fetcher.state === \"idle\") {\n if (deletedFetchers.has(key)) {\n // Unmounted from the UI and can be totally removed\n deletedFetchersKeys.push(key);\n } else {\n // Returned to idle but still mounted in the UI, so semi-remains for\n // revalidations and such\n completedFetchers.push(key);\n }\n }\n });\n }\n // Remove any lingering deleted fetchers that have already been removed\n // from state.fetchers\n deletedFetchers.forEach(key => {\n if (!state.fetchers.has(key) && !fetchControllers.has(key)) {\n deletedFetchersKeys.push(key);\n }\n });\n // Iterate over a local copy so that if flushSync is used and we end up\n // removing and adding a new subscriber due to the useCallback dependencies,\n // we don't get ourselves into a loop calling the new subscriber immediately\n [...subscribers].forEach(subscriber => subscriber(state, {\n deletedFetchers: deletedFetchersKeys,\n viewTransitionOpts: opts.viewTransitionOpts,\n flushSync: opts.flushSync === true\n }));\n // Remove idle fetchers from state since we only care about in-flight fetchers.\n if (future.v7_fetcherPersist) {\n completedFetchers.forEach(key => state.fetchers.delete(key));\n deletedFetchersKeys.forEach(key => deleteFetcher(key));\n } else {\n // We already called deleteFetcher() on these, can remove them from this\n // Set now that we've handed the keys off to the data layer\n deletedFetchersKeys.forEach(key => deletedFetchers.delete(key));\n }\n }\n // Complete a navigation returning the state.navigation back to the IDLE_NAVIGATION\n // and setting state.[historyAction/location/matches] to the new route.\n // - Location is a required param\n // - Navigation will always be set to IDLE_NAVIGATION\n // - Can pass any other state in newState\n function completeNavigation(location, newState, _temp) {\n var _location$state, _location$state2;\n let {\n flushSync\n } = _temp === void 0 ? {} : _temp;\n // Deduce if we're in a loading/actionReload state:\n // - We have committed actionData in the store\n // - The current navigation was a mutation submission\n // - We're past the submitting state and into the loading state\n // - The location being loaded is not the result of a redirect\n let isActionReload = state.actionData != null && state.navigation.formMethod != null && isMutationMethod(state.navigation.formMethod) && state.navigation.state === \"loading\" && ((_location$state = location.state) == null ? void 0 : _location$state._isRedirect) !== true;\n let actionData;\n if (newState.actionData) {\n if (Object.keys(newState.actionData).length > 0) {\n actionData = newState.actionData;\n } else {\n // Empty actionData -> clear prior actionData due to an action error\n actionData = null;\n }\n } else if (isActionReload) {\n // Keep the current data if we're wrapping up the action reload\n actionData = state.actionData;\n } else {\n // Clear actionData on any other completed navigations\n actionData = null;\n }\n // Always preserve any existing loaderData from re-used routes\n let loaderData = newState.loaderData ? mergeLoaderData(state.loaderData, newState.loaderData, newState.matches || [], newState.errors) : state.loaderData;\n // On a successful navigation we can assume we got through all blockers\n // so we can start fresh\n let blockers = state.blockers;\n if (blockers.size > 0) {\n blockers = new Map(blockers);\n blockers.forEach((_, k) => blockers.set(k, IDLE_BLOCKER));\n }\n // Always respect the user flag. Otherwise don't reset on mutation\n // submission navigations unless they redirect\n let preventScrollReset = pendingPreventScrollReset === true || state.navigation.formMethod != null && isMutationMethod(state.navigation.formMethod) && ((_location$state2 = location.state) == null ? void 0 : _location$state2._isRedirect) !== true;\n // Commit any in-flight routes at the end of the HMR revalidation \"navigation\"\n if (inFlightDataRoutes) {\n dataRoutes = inFlightDataRoutes;\n inFlightDataRoutes = undefined;\n }\n if (isUninterruptedRevalidation) ; else if (pendingAction === Action.Pop) ; else if (pendingAction === Action.Push) {\n init.history.push(location, location.state);\n } else if (pendingAction === Action.Replace) {\n init.history.replace(location, location.state);\n }\n let viewTransitionOpts;\n // On POP, enable transitions if they were enabled on the original navigation\n if (pendingAction === Action.Pop) {\n // Forward takes precedence so they behave like the original navigation\n let priorPaths = appliedViewTransitions.get(state.location.pathname);\n if (priorPaths && priorPaths.has(location.pathname)) {\n viewTransitionOpts = {\n currentLocation: state.location,\n nextLocation: location\n };\n } else if (appliedViewTransitions.has(location.pathname)) {\n // If we don't have a previous forward nav, assume we're popping back to\n // the new location and enable if that location previously enabled\n viewTransitionOpts = {\n currentLocation: location,\n nextLocation: state.location\n };\n }\n } else if (pendingViewTransitionEnabled) {\n // Store the applied transition on PUSH/REPLACE\n let toPaths = appliedViewTransitions.get(state.location.pathname);\n if (toPaths) {\n toPaths.add(location.pathname);\n } else {\n toPaths = new Set([location.pathname]);\n appliedViewTransitions.set(state.location.pathname, toPaths);\n }\n viewTransitionOpts = {\n currentLocation: state.location,\n nextLocation: location\n };\n }\n updateState(_extends({}, newState, {\n actionData,\n loaderData,\n historyAction: pendingAction,\n location,\n initialized: true,\n navigation: IDLE_NAVIGATION,\n revalidation: \"idle\",\n restoreScrollPosition: getSavedScrollPosition(location, newState.matches || state.matches),\n preventScrollReset,\n blockers\n }), {\n viewTransitionOpts,\n flushSync: flushSync === true\n });\n // Reset stateful navigation vars\n pendingAction = Action.Pop;\n pendingPreventScrollReset = false;\n pendingViewTransitionEnabled = false;\n isUninterruptedRevalidation = false;\n isRevalidationRequired = false;\n cancelledDeferredRoutes = [];\n }\n // Trigger a navigation event, which can either be a numerical POP or a PUSH\n // replace with an optional submission\n async function navigate(to, opts) {\n if (typeof to === \"number\") {\n init.history.go(to);\n return;\n }\n let normalizedPath = normalizeTo(state.location, state.matches, basename, future.v7_prependBasename, to, future.v7_relativeSplatPath, opts == null ? void 0 : opts.fromRouteId, opts == null ? void 0 : opts.relative);\n let {\n path,\n submission,\n error\n } = normalizeNavigateOptions(future.v7_normalizeFormMethod, false, normalizedPath, opts);\n let currentLocation = state.location;\n let nextLocation = createLocation(state.location, path, opts && opts.state);\n // When using navigate as a PUSH/REPLACE we aren't reading an already-encoded\n // URL from window.location, so we need to encode it here so the behavior\n // remains the same as POP and non-data-router usages. new URL() does all\n // the same encoding we'd get from a history.pushState/window.location read\n // without having to touch history\n nextLocation = _extends({}, nextLocation, init.history.encodeLocation(nextLocation));\n let userReplace = opts && opts.replace != null ? opts.replace : undefined;\n let historyAction = Action.Push;\n if (userReplace === true) {\n historyAction = Action.Replace;\n } else if (userReplace === false) ; else if (submission != null && isMutationMethod(submission.formMethod) && submission.formAction === state.location.pathname + state.location.search) {\n // By default on submissions to the current location we REPLACE so that\n // users don't have to double-click the back button to get to the prior\n // location. If the user redirects to a different location from the\n // action/loader this will be ignored and the redirect will be a PUSH\n historyAction = Action.Replace;\n }\n let preventScrollReset = opts && \"preventScrollReset\" in opts ? opts.preventScrollReset === true : undefined;\n let flushSync = (opts && opts.flushSync) === true;\n let blockerKey = shouldBlockNavigation({\n currentLocation,\n nextLocation,\n historyAction\n });\n if (blockerKey) {\n // Put the blocker into a blocked state\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location: nextLocation,\n proceed() {\n updateBlocker(blockerKey, {\n state: \"proceeding\",\n proceed: undefined,\n reset: undefined,\n location: nextLocation\n });\n // Send the same navigation through\n navigate(to, opts);\n },\n reset() {\n let blockers = new Map(state.blockers);\n blockers.set(blockerKey, IDLE_BLOCKER);\n updateState({\n blockers\n });\n }\n });\n return;\n }\n return await startNavigation(historyAction, nextLocation, {\n submission,\n // Send through the formData serialization error if we have one so we can\n // render at the right error boundary after we match routes\n pendingError: error,\n preventScrollReset,\n replace: opts && opts.replace,\n enableViewTransition: opts && opts.viewTransition,\n flushSync\n });\n }\n // Revalidate all current loaders. If a navigation is in progress or if this\n // is interrupted by a navigation, allow this to \"succeed\" by calling all\n // loaders during the next loader round\n function revalidate() {\n interruptActiveLoads();\n updateState({\n revalidation: \"loading\"\n });\n // If we're currently submitting an action, we don't need to start a new\n // navigation, we'll just let the follow up loader execution call all loaders\n if (state.navigation.state === \"submitting\") {\n return;\n }\n // If we're currently in an idle state, start a new navigation for the current\n // action/location and mark it as uninterrupted, which will skip the history\n // update in completeNavigation\n if (state.navigation.state === \"idle\") {\n startNavigation(state.historyAction, state.location, {\n startUninterruptedRevalidation: true\n });\n return;\n }\n // Otherwise, if we're currently in a loading state, just start a new\n // navigation to the navigation.location but do not trigger an uninterrupted\n // revalidation so that history correctly updates once the navigation completes\n startNavigation(pendingAction || state.historyAction, state.navigation.location, {\n overrideNavigation: state.navigation,\n // Proxy through any rending view transition\n enableViewTransition: pendingViewTransitionEnabled === true\n });\n }\n // Start a navigation to the given action/location. Can optionally provide a\n // overrideNavigation which will override the normalLoad in the case of a redirect\n // navigation\n async function startNavigation(historyAction, location, opts) {\n // Abort any in-progress navigations and start a new one. Unset any ongoing\n // uninterrupted revalidations unless told otherwise, since we want this\n // new navigation to update history normally\n pendingNavigationController && pendingNavigationController.abort();\n pendingNavigationController = null;\n pendingAction = historyAction;\n isUninterruptedRevalidation = (opts && opts.startUninterruptedRevalidation) === true;\n // Save the current scroll position every time we start a new navigation,\n // and track whether we should reset scroll on completion\n saveScrollPosition(state.location, state.matches);\n pendingPreventScrollReset = (opts && opts.preventScrollReset) === true;\n pendingViewTransitionEnabled = (opts && opts.enableViewTransition) === true;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let loadingNavigation = opts && opts.overrideNavigation;\n let matches = opts != null && opts.initialHydration && state.matches && state.matches.length > 0 && !initialMatchesIsFOW ?\n // `matchRoutes()` has already been called if we're in here via `router.initialize()`\n state.matches : matchRoutes(routesToUse, location, basename);\n let flushSync = (opts && opts.flushSync) === true;\n // Short circuit if it's only a hash change and not a revalidation or\n // mutation submission.\n //\n // Ignore on initial page loads because since the initial hydration will always\n // be \"same hash\". For example, on /page#hash and submit a <Form method=\"post\">\n // which will default to a navigation to /page\n if (matches && state.initialized && !isRevalidationRequired && isHashChangeOnly(state.location, location) && !(opts && opts.submission && isMutationMethod(opts.submission.formMethod))) {\n completeNavigation(location, {\n matches\n }, {\n flushSync\n });\n return;\n }\n let fogOfWar = checkFogOfWar(matches, routesToUse, location.pathname);\n if (fogOfWar.active && fogOfWar.matches) {\n matches = fogOfWar.matches;\n }\n // Short circuit with a 404 on the root error boundary if we match nothing\n if (!matches) {\n let {\n error,\n notFoundMatches,\n route\n } = handleNavigational404(location.pathname);\n completeNavigation(location, {\n matches: notFoundMatches,\n loaderData: {},\n errors: {\n [route.id]: error\n }\n }, {\n flushSync\n });\n return;\n }\n // Create a controller/Request for this navigation\n pendingNavigationController = new AbortController();\n let request = createClientSideRequest(init.history, location, pendingNavigationController.signal, opts && opts.submission);\n let pendingActionResult;\n if (opts && opts.pendingError) {\n // If we have a pendingError, it means the user attempted a GET submission\n // with binary FormData so assign here and skip to handleLoaders. That\n // way we handle calling loaders above the boundary etc. It's not really\n // different from an actionError in that sense.\n pendingActionResult = [findNearestBoundary(matches).route.id, {\n type: ResultType.error,\n error: opts.pendingError\n }];\n } else if (opts && opts.submission && isMutationMethod(opts.submission.formMethod)) {\n // Call action if we received an action submission\n let actionResult = await handleAction(request, location, opts.submission, matches, fogOfWar.active, {\n replace: opts.replace,\n flushSync\n });\n if (actionResult.shortCircuited) {\n return;\n }\n // If we received a 404 from handleAction, it's because we couldn't lazily\n // discover the destination route so we don't want to call loaders\n if (actionResult.pendingActionResult) {\n let [routeId, result] = actionResult.pendingActionResult;\n if (isErrorResult(result) && isRouteErrorResponse(result.error) && result.error.status === 404) {\n pendingNavigationController = null;\n completeNavigation(location, {\n matches: actionResult.matches,\n loaderData: {},\n errors: {\n [routeId]: result.error\n }\n });\n return;\n }\n }\n matches = actionResult.matches || matches;\n pendingActionResult = actionResult.pendingActionResult;\n loadingNavigation = getLoadingNavigation(location, opts.submission);\n flushSync = false;\n // No need to do fog of war matching again on loader execution\n fogOfWar.active = false;\n // Create a GET request for the loaders\n request = createClientSideRequest(init.history, request.url, request.signal);\n }\n // Call loaders\n let {\n shortCircuited,\n matches: updatedMatches,\n loaderData,\n errors\n } = await handleLoaders(request, location, matches, fogOfWar.active, loadingNavigation, opts && opts.submission, opts && opts.fetcherSubmission, opts && opts.replace, opts && opts.initialHydration === true, flushSync, pendingActionResult);\n if (shortCircuited) {\n return;\n }\n // Clean up now that the action/loaders have completed. Don't clean up if\n // we short circuited because pendingNavigationController will have already\n // been assigned to a new controller for the next navigation\n pendingNavigationController = null;\n completeNavigation(location, _extends({\n matches: updatedMatches || matches\n }, getActionDataForCommit(pendingActionResult), {\n loaderData,\n errors\n }));\n }\n // Call the action matched by the leaf route for this navigation and handle\n // redirects/errors\n async function handleAction(request, location, submission, matches, isFogOfWar, opts) {\n if (opts === void 0) {\n opts = {};\n }\n interruptActiveLoads();\n // Put us in a submitting state\n let navigation = getSubmittingNavigation(location, submission);\n updateState({\n navigation\n }, {\n flushSync: opts.flushSync === true\n });\n if (isFogOfWar) {\n let discoverResult = await discoverRoutes(matches, location.pathname, request.signal);\n if (discoverResult.type === \"aborted\") {\n return {\n shortCircuited: true\n };\n } else if (discoverResult.type === \"error\") {\n let boundaryId = findNearestBoundary(discoverResult.partialMatches).route.id;\n return {\n matches: discoverResult.partialMatches,\n pendingActionResult: [boundaryId, {\n type: ResultType.error,\n error: discoverResult.error\n }]\n };\n } else if (!discoverResult.matches) {\n let {\n notFoundMatches,\n error,\n route\n } = handleNavigational404(location.pathname);\n return {\n matches: notFoundMatches,\n pendingActionResult: [route.id, {\n type: ResultType.error,\n error\n }]\n };\n } else {\n matches = discoverResult.matches;\n }\n }\n // Call our action and get the result\n let result;\n let actionMatch = getTargetMatch(matches, location);\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n result = {\n type: ResultType.error,\n error: getInternalRouterError(405, {\n method: request.method,\n pathname: location.pathname,\n routeId: actionMatch.route.id\n })\n };\n } else {\n let results = await callDataStrategy(\"action\", state, request, [actionMatch], matches, null);\n result = results[actionMatch.route.id];\n if (request.signal.aborted) {\n return {\n shortCircuited: true\n };\n }\n }\n if (isRedirectResult(result)) {\n let replace;\n if (opts && opts.replace != null) {\n replace = opts.replace;\n } else {\n // If the user didn't explicity indicate replace behavior, replace if\n // we redirected to the exact same location we're currently at to avoid\n // double back-buttons\n let location = normalizeRedirectLocation(result.response.headers.get(\"Location\"), new URL(request.url), basename, init.history);\n replace = location === state.location.pathname + state.location.search;\n }\n await startRedirectNavigation(request, result, true, {\n submission,\n replace\n });\n return {\n shortCircuited: true\n };\n }\n if (isDeferredResult(result)) {\n throw getInternalRouterError(400, {\n type: \"defer-action\"\n });\n }\n if (isErrorResult(result)) {\n // Store off the pending error - we use it to determine which loaders\n // to call and will commit it when we complete the navigation\n let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);\n // By default, all submissions to the current location are REPLACE\n // navigations, but if the action threw an error that'll be rendered in\n // an errorElement, we fall back to PUSH so that the user can use the\n // back button to get back to the pre-submission form location to try\n // again\n if ((opts && opts.replace) !== true) {\n pendingAction = Action.Push;\n }\n return {\n matches,\n pendingActionResult: [boundaryMatch.route.id, result]\n };\n }\n return {\n matches,\n pendingActionResult: [actionMatch.route.id, result]\n };\n }\n // Call all applicable loaders for the given matches, handling redirects,\n // errors, etc.\n async function handleLoaders(request, location, matches, isFogOfWar, overrideNavigation, submission, fetcherSubmission, replace, initialHydration, flushSync, pendingActionResult) {\n // Figure out the right navigation we want to use for data loading\n let loadingNavigation = overrideNavigation || getLoadingNavigation(location, submission);\n // If this was a redirect from an action we don't have a \"submission\" but\n // we have it on the loading navigation so use that if available\n let activeSubmission = submission || fetcherSubmission || getSubmissionFromNavigation(loadingNavigation);\n // If this is an uninterrupted revalidation, we remain in our current idle\n // state. If not, we need to switch to our loading state and load data,\n // preserving any new action data or existing action data (in the case of\n // a revalidation interrupting an actionReload)\n // If we have partialHydration enabled, then don't update the state for the\n // initial data load since it's not a \"navigation\"\n let shouldUpdateNavigationState = !isUninterruptedRevalidation && (!future.v7_partialHydration || !initialHydration);\n // When fog of war is enabled, we enter our `loading` state earlier so we\n // can discover new routes during the `loading` state. We skip this if\n // we've already run actions since we would have done our matching already.\n // If the children() function threw then, we want to proceed with the\n // partial matches it discovered.\n if (isFogOfWar) {\n if (shouldUpdateNavigationState) {\n let actionData = getUpdatedActionData(pendingActionResult);\n updateState(_extends({\n navigation: loadingNavigation\n }, actionData !== undefined ? {\n actionData\n } : {}), {\n flushSync\n });\n }\n let discoverResult = await discoverRoutes(matches, location.pathname, request.signal);\n if (discoverResult.type === \"aborted\") {\n return {\n shortCircuited: true\n };\n } else if (discoverResult.type === \"error\") {\n let boundaryId = findNearestBoundary(discoverResult.partialMatches).route.id;\n return {\n matches: discoverResult.partialMatches,\n loaderData: {},\n errors: {\n [boundaryId]: discoverResult.error\n }\n };\n } else if (!discoverResult.matches) {\n let {\n error,\n notFoundMatches,\n route\n } = handleNavigational404(location.pathname);\n return {\n matches: notFoundMatches,\n loaderData: {},\n errors: {\n [route.id]: error\n }\n };\n } else {\n matches = discoverResult.matches;\n }\n }\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(init.history, state, matches, activeSubmission, location, future.v7_partialHydration && initialHydration === true, future.v7_skipActionErrorRevalidation, isRevalidationRequired, cancelledDeferredRoutes, cancelledFetcherLoads, deletedFetchers, fetchLoadMatches, fetchRedirectIds, routesToUse, basename, pendingActionResult);\n // Cancel pending deferreds for no-longer-matched routes or routes we're\n // about to reload. Note that if this is an action reload we would have\n // already cancelled all pending deferreds so this would be a no-op\n cancelActiveDeferreds(routeId => !(matches && matches.some(m => m.route.id === routeId)) || matchesToLoad && matchesToLoad.some(m => m.route.id === routeId));\n pendingNavigationLoadId = ++incrementingLoadId;\n // Short circuit if we have no loaders to run\n if (matchesToLoad.length === 0 && revalidatingFetchers.length === 0) {\n let updatedFetchers = markFetchRedirectsDone();\n completeNavigation(location, _extends({\n matches,\n loaderData: {},\n // Commit pending error if we're short circuiting\n errors: pendingActionResult && isErrorResult(pendingActionResult[1]) ? {\n [pendingActionResult[0]]: pendingActionResult[1].error\n } : null\n }, getActionDataForCommit(pendingActionResult), updatedFetchers ? {\n fetchers: new Map(state.fetchers)\n } : {}), {\n flushSync\n });\n return {\n shortCircuited: true\n };\n }\n if (shouldUpdateNavigationState) {\n let updates = {};\n if (!isFogOfWar) {\n // Only update navigation/actionNData if we didn't already do it above\n updates.navigation = loadingNavigation;\n let actionData = getUpdatedActionData(pendingActionResult);\n if (actionData !== undefined) {\n updates.actionData = actionData;\n }\n }\n if (revalidatingFetchers.length > 0) {\n updates.fetchers = getUpdatedRevalidatingFetchers(revalidatingFetchers);\n }\n updateState(updates, {\n flushSync\n });\n }\n revalidatingFetchers.forEach(rf => {\n abortFetcher(rf.key);\n if (rf.controller) {\n // Fetchers use an independent AbortController so that aborting a fetcher\n // (via deleteFetcher) does not abort the triggering navigation that\n // triggered the revalidation\n fetchControllers.set(rf.key, rf.controller);\n }\n });\n // Proxy navigation abort through to revalidation fetchers\n let abortPendingFetchRevalidations = () => revalidatingFetchers.forEach(f => abortFetcher(f.key));\n if (pendingNavigationController) {\n pendingNavigationController.signal.addEventListener(\"abort\", abortPendingFetchRevalidations);\n }\n let {\n loaderResults,\n fetcherResults\n } = await callLoadersAndMaybeResolveData(state, matches, matchesToLoad, revalidatingFetchers, request);\n if (request.signal.aborted) {\n return {\n shortCircuited: true\n };\n }\n // Clean up _after_ loaders have completed. Don't clean up if we short\n // circuited because fetchControllers would have been aborted and\n // reassigned to new controllers for the next navigation\n if (pendingNavigationController) {\n pendingNavigationController.signal.removeEventListener(\"abort\", abortPendingFetchRevalidations);\n }\n revalidatingFetchers.forEach(rf => fetchControllers.delete(rf.key));\n // If any loaders returned a redirect Response, start a new REPLACE navigation\n let redirect = findRedirect(loaderResults);\n if (redirect) {\n await startRedirectNavigation(request, redirect.result, true, {\n replace\n });\n return {\n shortCircuited: true\n };\n }\n redirect = findRedirect(fetcherResults);\n if (redirect) {\n // If this redirect came from a fetcher make sure we mark it in\n // fetchRedirectIds so it doesn't get revalidated on the next set of\n // loader executions\n fetchRedirectIds.add(redirect.key);\n await startRedirectNavigation(request, redirect.result, true, {\n replace\n });\n return {\n shortCircuited: true\n };\n }\n // Process and commit output from loaders\n let {\n loaderData,\n errors\n } = processLoaderData(state, matches, loaderResults, pendingActionResult, revalidatingFetchers, fetcherResults, activeDeferreds);\n // Wire up subscribers to update loaderData as promises settle\n activeDeferreds.forEach((deferredData, routeId) => {\n deferredData.subscribe(aborted => {\n // Note: No need to updateState here since the TrackedPromise on\n // loaderData is stable across resolve/reject\n // Remove this instance if we were aborted or if promises have settled\n if (aborted || deferredData.done) {\n activeDeferreds.delete(routeId);\n }\n });\n });\n // Preserve SSR errors during partial hydration\n if (future.v7_partialHydration && initialHydration && state.errors) {\n errors = _extends({}, state.errors, errors);\n }\n let updatedFetchers = markFetchRedirectsDone();\n let didAbortFetchLoads = abortStaleFetchLoads(pendingNavigationLoadId);\n let shouldUpdateFetchers = updatedFetchers || didAbortFetchLoads || revalidatingFetchers.length > 0;\n return _extends({\n matches,\n loaderData,\n errors\n }, shouldUpdateFetchers ? {\n fetchers: new Map(state.fetchers)\n } : {});\n }\n function getUpdatedActionData(pendingActionResult) {\n if (pendingActionResult && !isErrorResult(pendingActionResult[1])) {\n // This is cast to `any` currently because `RouteData`uses any and it\n // would be a breaking change to use any.\n // TODO: v7 - change `RouteData` to use `unknown` instead of `any`\n return {\n [pendingActionResult[0]]: pendingActionResult[1].data\n };\n } else if (state.actionData) {\n if (Object.keys(state.actionData).length === 0) {\n return null;\n } else {\n return state.actionData;\n }\n }\n }\n function getUpdatedRevalidatingFetchers(revalidatingFetchers) {\n revalidatingFetchers.forEach(rf => {\n let fetcher = state.fetchers.get(rf.key);\n let revalidatingFetcher = getLoadingFetcher(undefined, fetcher ? fetcher.data : undefined);\n state.fetchers.set(rf.key, revalidatingFetcher);\n });\n return new Map(state.fetchers);\n }\n // Trigger a fetcher load/submit for the given fetcher key\n function fetch(key, routeId, href, opts) {\n if (isServer) {\n throw new Error(\"router.fetch() was called during the server render, but it shouldn't be. \" + \"You are likely calling a useFetcher() method in the body of your component. \" + \"Try moving it to a useEffect or a callback.\");\n }\n abortFetcher(key);\n let flushSync = (opts && opts.flushSync) === true;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let normalizedPath = normalizeTo(state.location, state.matches, basename, future.v7_prependBasename, href, future.v7_relativeSplatPath, routeId, opts == null ? void 0 : opts.relative);\n let matches = matchRoutes(routesToUse, normalizedPath, basename);\n let fogOfWar = checkFogOfWar(matches, routesToUse, normalizedPath);\n if (fogOfWar.active && fogOfWar.matches) {\n matches = fogOfWar.matches;\n }\n if (!matches) {\n setFetcherError(key, routeId, getInternalRouterError(404, {\n pathname: normalizedPath\n }), {\n flushSync\n });\n return;\n }\n let {\n path,\n submission,\n error\n } = normalizeNavigateOptions(future.v7_normalizeFormMethod, true, normalizedPath, opts);\n if (error) {\n setFetcherError(key, routeId, error, {\n flushSync\n });\n return;\n }\n let match = getTargetMatch(matches, path);\n let preventScrollReset = (opts && opts.preventScrollReset) === true;\n if (submission && isMutationMethod(submission.formMethod)) {\n handleFetcherAction(key, routeId, path, match, matches, fogOfWar.active, flushSync, preventScrollReset, submission);\n return;\n }\n // Store off the match so we can call it's shouldRevalidate on subsequent\n // revalidations\n fetchLoadMatches.set(key, {\n routeId,\n path\n });\n handleFetcherLoader(key, routeId, path, match, matches, fogOfWar.active, flushSync, preventScrollReset, submission);\n }\n // Call the action for the matched fetcher.submit(), and then handle redirects,\n // errors, and revalidation\n async function handleFetcherAction(key, routeId, path, match, requestMatches, isFogOfWar, flushSync, preventScrollReset, submission) {\n interruptActiveLoads();\n fetchLoadMatches.delete(key);\n function detectAndHandle405Error(m) {\n if (!m.route.action && !m.route.lazy) {\n let error = getInternalRouterError(405, {\n method: submission.formMethod,\n pathname: path,\n routeId: routeId\n });\n setFetcherError(key, routeId, error, {\n flushSync\n });\n return true;\n }\n return false;\n }\n if (!isFogOfWar && detectAndHandle405Error(match)) {\n return;\n }\n // Put this fetcher into it's submitting state\n let existingFetcher = state.fetchers.get(key);\n updateFetcherState(key, getSubmittingFetcher(submission, existingFetcher), {\n flushSync\n });\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(init.history, path, abortController.signal, submission);\n if (isFogOfWar) {\n let discoverResult = await discoverRoutes(requestMatches, new URL(fetchRequest.url).pathname, fetchRequest.signal, key);\n if (discoverResult.type === \"aborted\") {\n return;\n } else if (discoverResult.type === \"error\") {\n setFetcherError(key, routeId, discoverResult.error, {\n flushSync\n });\n return;\n } else if (!discoverResult.matches) {\n setFetcherError(key, routeId, getInternalRouterError(404, {\n pathname: path\n }), {\n flushSync\n });\n return;\n } else {\n requestMatches = discoverResult.matches;\n match = getTargetMatch(requestMatches, path);\n if (detectAndHandle405Error(match)) {\n return;\n }\n }\n }\n // Call the action for the fetcher\n fetchControllers.set(key, abortController);\n let originatingLoadId = incrementingLoadId;\n let actionResults = await callDataStrategy(\"action\", state, fetchRequest, [match], requestMatches, key);\n let actionResult = actionResults[match.route.id];\n if (fetchRequest.signal.aborted) {\n // We can delete this so long as we weren't aborted by our own fetcher\n // re-submit which would have put _new_ controller is in fetchControllers\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n return;\n }\n // When using v7_fetcherPersist, we don't want errors bubbling up to the UI\n // or redirects processed for unmounted fetchers so we just revert them to\n // idle\n if (future.v7_fetcherPersist && deletedFetchers.has(key)) {\n if (isRedirectResult(actionResult) || isErrorResult(actionResult)) {\n updateFetcherState(key, getDoneFetcher(undefined));\n return;\n }\n // Let SuccessResult's fall through for revalidation\n } else {\n if (isRedirectResult(actionResult)) {\n fetchControllers.delete(key);\n if (pendingNavigationLoadId > originatingLoadId) {\n // A new navigation was kicked off after our action started, so that\n // should take precedence over this redirect navigation. We already\n // set isRevalidationRequired so all loaders for the new route should\n // fire unless opted out via shouldRevalidate\n updateFetcherState(key, getDoneFetcher(undefined));\n return;\n } else {\n fetchRedirectIds.add(key);\n updateFetcherState(key, getLoadingFetcher(submission));\n return startRedirectNavigation(fetchRequest, actionResult, false, {\n fetcherSubmission: submission,\n preventScrollReset\n });\n }\n }\n // Process any non-redirect errors thrown\n if (isErrorResult(actionResult)) {\n setFetcherError(key, routeId, actionResult.error);\n return;\n }\n }\n if (isDeferredResult(actionResult)) {\n throw getInternalRouterError(400, {\n type: \"defer-action\"\n });\n }\n // Start the data load for current matches, or the next location if we're\n // in the middle of a navigation\n let nextLocation = state.navigation.location || state.location;\n let revalidationRequest = createClientSideRequest(init.history, nextLocation, abortController.signal);\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let matches = state.navigation.state !== \"idle\" ? matchRoutes(routesToUse, state.navigation.location, basename) : state.matches;\n invariant(matches, \"Didn't find any matches after fetcher action\");\n let loadId = ++incrementingLoadId;\n fetchReloadIds.set(key, loadId);\n let loadFetcher = getLoadingFetcher(submission, actionResult.data);\n state.fetchers.set(key, loadFetcher);\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(init.history, state, matches, submission, nextLocation, false, future.v7_skipActionErrorRevalidation, isRevalidationRequired, cancelledDeferredRoutes, cancelledFetcherLoads, deletedFetchers, fetchLoadMatches, fetchRedirectIds, routesToUse, basename, [match.route.id, actionResult]);\n // Put all revalidating fetchers into the loading state, except for the\n // current fetcher which we want to keep in it's current loading state which\n // contains it's action submission info + action data\n revalidatingFetchers.filter(rf => rf.key !== key).forEach(rf => {\n let staleKey = rf.key;\n let existingFetcher = state.fetchers.get(staleKey);\n let revalidatingFetcher = getLoadingFetcher(undefined, existingFetcher ? existingFetcher.data : undefined);\n state.fetchers.set(staleKey, revalidatingFetcher);\n abortFetcher(staleKey);\n if (rf.controller) {\n fetchControllers.set(staleKey, rf.controller);\n }\n });\n updateState({\n fetchers: new Map(state.fetchers)\n });\n let abortPendingFetchRevalidations = () => revalidatingFetchers.forEach(rf => abortFetcher(rf.key));\n abortController.signal.addEventListener(\"abort\", abortPendingFetchRevalidations);\n let {\n loaderResults,\n fetcherResults\n } = await callLoadersAndMaybeResolveData(state, matches, matchesToLoad, revalidatingFetchers, revalidationRequest);\n if (abortController.signal.aborted) {\n return;\n }\n abortController.signal.removeEventListener(\"abort\", abortPendingFetchRevalidations);\n fetchReloadIds.delete(key);\n fetchControllers.delete(key);\n revalidatingFetchers.forEach(r => fetchControllers.delete(r.key));\n let redirect = findRedirect(loaderResults);\n if (redirect) {\n return startRedirectNavigation(revalidationRequest, redirect.result, false, {\n preventScrollReset\n });\n }\n redirect = findRedirect(fetcherResults);\n if (redirect) {\n // If this redirect came from a fetcher make sure we mark it in\n // fetchRedirectIds so it doesn't get revalidated on the next set of\n // loader executions\n fetchRedirectIds.add(redirect.key);\n return startRedirectNavigation(revalidationRequest, redirect.result, false, {\n preventScrollReset\n });\n }\n // Process and commit output from loaders\n let {\n loaderData,\n errors\n } = processLoaderData(state, matches, loaderResults, undefined, revalidatingFetchers, fetcherResults, activeDeferreds);\n // Since we let revalidations complete even if the submitting fetcher was\n // deleted, only put it back to idle if it hasn't been deleted\n if (state.fetchers.has(key)) {\n let doneFetcher = getDoneFetcher(actionResult.data);\n state.fetchers.set(key, doneFetcher);\n }\n abortStaleFetchLoads(loadId);\n // If we are currently in a navigation loading state and this fetcher is\n // more recent than the navigation, we want the newer data so abort the\n // navigation and complete it with the fetcher data\n if (state.navigation.state === \"loading\" && loadId > pendingNavigationLoadId) {\n invariant(pendingAction, \"Expected pending action\");\n pendingNavigationController && pendingNavigationController.abort();\n completeNavigation(state.navigation.location, {\n matches,\n loaderData,\n errors,\n fetchers: new Map(state.fetchers)\n });\n } else {\n // otherwise just update with the fetcher data, preserving any existing\n // loaderData for loaders that did not need to reload. We have to\n // manually merge here since we aren't going through completeNavigation\n updateState({\n errors,\n loaderData: mergeLoaderData(state.loaderData, loaderData, matches, errors),\n fetchers: new Map(state.fetchers)\n });\n isRevalidationRequired = false;\n }\n }\n // Call the matched loader for fetcher.load(), handling redirects, errors, etc.\n async function handleFetcherLoader(key, routeId, path, match, matches, isFogOfWar, flushSync, preventScrollReset, submission) {\n let existingFetcher = state.fetchers.get(key);\n updateFetcherState(key, getLoadingFetcher(submission, existingFetcher ? existingFetcher.data : undefined), {\n flushSync\n });\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(init.history, path, abortController.signal);\n if (isFogOfWar) {\n let discoverResult = await discoverRoutes(matches, new URL(fetchRequest.url).pathname, fetchRequest.signal, key);\n if (discoverResult.type === \"aborted\") {\n return;\n } else if (discoverResult.type === \"error\") {\n setFetcherError(key, routeId, discoverResult.error, {\n flushSync\n });\n return;\n } else if (!discoverResult.matches) {\n setFetcherError(key, routeId, getInternalRouterError(404, {\n pathname: path\n }), {\n flushSync\n });\n return;\n } else {\n matches = discoverResult.matches;\n match = getTargetMatch(matches, path);\n }\n }\n // Call the loader for this fetcher route match\n fetchControllers.set(key, abortController);\n let originatingLoadId = incrementingLoadId;\n let results = await callDataStrategy(\"loader\", state, fetchRequest, [match], matches, key);\n let result = results[match.route.id];\n // Deferred isn't supported for fetcher loads, await everything and treat it\n // as a normal load. resolveDeferredData will return undefined if this\n // fetcher gets aborted, so we just leave result untouched and short circuit\n // below if that happens\n if (isDeferredResult(result)) {\n result = (await resolveDeferredData(result, fetchRequest.signal, true)) || result;\n }\n // We can delete this so long as we weren't aborted by our our own fetcher\n // re-load which would have put _new_ controller is in fetchControllers\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n if (fetchRequest.signal.aborted) {\n return;\n }\n // We don't want errors bubbling up or redirects followed for unmounted\n // fetchers, so short circuit here if it was removed from the UI\n if (deletedFetchers.has(key)) {\n updateFetcherState(key, getDoneFetcher(undefined));\n return;\n }\n // If the loader threw a redirect Response, start a new REPLACE navigation\n if (isRedirectResult(result)) {\n if (pendingNavigationLoadId > originatingLoadId) {\n // A new navigation was kicked off after our loader started, so that\n // should take precedence over this redirect navigation\n updateFetcherState(key, getDoneFetcher(undefined));\n return;\n } else {\n fetchRedirectIds.add(key);\n await startRedirectNavigation(fetchRequest, result, false, {\n preventScrollReset\n });\n return;\n }\n }\n // Process any non-redirect errors thrown\n if (isErrorResult(result)) {\n setFetcherError(key, routeId, result.error);\n return;\n }\n invariant(!isDeferredResult(result), \"Unhandled fetcher deferred data\");\n // Put the fetcher back into an idle state\n updateFetcherState(key, getDoneFetcher(result.data));\n }\n /**\n * Utility function to handle redirects returned from an action or loader.\n * Normally, a redirect \"replaces\" the navigation that triggered it. So, for\n * example:\n *\n * - user is on /a\n * - user clicks a link to /b\n * - loader for /b redirects to /c\n *\n * In a non-JS app the browser would track the in-flight navigation to /b and\n * then replace it with /c when it encountered the redirect response. In\n * the end it would only ever update the URL bar with /c.\n *\n * In client-side routing using pushState/replaceState, we aim to emulate\n * this behavior and we also do not update history until the end of the\n * navigation (including processed redirects). This means that we never\n * actually touch history until we've processed redirects, so we just use\n * the history action from the original navigation (PUSH or REPLACE).\n */\n async function startRedirectNavigation(request, redirect, isNavigation, _temp2) {\n let {\n submission,\n fetcherSubmission,\n preventScrollReset,\n replace\n } = _temp2 === void 0 ? {} : _temp2;\n if (redirect.response.headers.has(\"X-Remix-Revalidate\")) {\n isRevalidationRequired = true;\n }\n let location = redirect.response.headers.get(\"Location\");\n invariant(location, \"Expected a Location header on the redirect Response\");\n location = normalizeRedirectLocation(location, new URL(request.url), basename, init.history);\n let redirectLocation = createLocation(state.location, location, {\n _isRedirect: true\n });\n if (isBrowser) {\n let isDocumentReload = false;\n if (redirect.response.headers.has(\"X-Remix-Reload-Document\")) {\n // Hard reload if the response contained X-Remix-Reload-Document\n isDocumentReload = true;\n } else if (ABSOLUTE_URL_REGEX.test(location)) {\n const url = init.history.createURL(location);\n isDocumentReload =\n // Hard reload if it's an absolute URL to a new origin\n url.origin !== routerWindow.location.origin ||\n // Hard reload if it's an absolute URL that does not match our basename\n stripBasename(url.pathname, basename) == null;\n }\n if (isDocumentReload) {\n if (replace) {\n routerWindow.location.replace(location);\n } else {\n routerWindow.location.assign(location);\n }\n return;\n }\n }\n // There's no need to abort on redirects, since we don't detect the\n // redirect until the action/loaders have settled\n pendingNavigationController = null;\n let redirectHistoryAction = replace === true || redirect.response.headers.has(\"X-Remix-Replace\") ? Action.Replace : Action.Push;\n // Use the incoming submission if provided, fallback on the active one in\n // state.navigation\n let {\n formMethod,\n formAction,\n formEncType\n } = state.navigation;\n if (!submission && !fetcherSubmission && formMethod && formAction && formEncType) {\n submission = getSubmissionFromNavigation(state.navigation);\n }\n // If this was a 307/308 submission we want to preserve the HTTP method and\n // re-submit the GET/POST/PUT/PATCH/DELETE as a submission navigation to the\n // redirected location\n let activeSubmission = submission || fetcherSubmission;\n if (redirectPreserveMethodStatusCodes.has(redirect.response.status) && activeSubmission && isMutationMethod(activeSubmission.formMethod)) {\n await startNavigation(redirectHistoryAction, redirectLocation, {\n submission: _extends({}, activeSubmission, {\n formAction: location\n }),\n // Preserve these flags across redirects\n preventScrollReset: preventScrollReset || pendingPreventScrollReset,\n enableViewTransition: isNavigation ? pendingViewTransitionEnabled : undefined\n });\n } else {\n // If we have a navigation submission, we will preserve it through the\n // redirect navigation\n let overrideNavigation = getLoadingNavigation(redirectLocation, submission);\n await startNavigation(redirectHistoryAction, redirectLocation, {\n overrideNavigation,\n // Send fetcher submissions through for shouldRevalidate\n fetcherSubmission,\n // Preserve these flags across redirects\n preventScrollReset: preventScrollReset || pendingPreventScrollReset,\n enableViewTransition: isNavigation ? pendingViewTransitionEnabled : undefined\n });\n }\n }\n // Utility wrapper for calling dataStrategy client-side without having to\n // pass around the manifest, mapRouteProperties, etc.\n async function callDataStrategy(type, state, request, matchesToLoad, matches, fetcherKey) {\n let results;\n let dataResults = {};\n try {\n results = await callDataStrategyImpl(dataStrategyImpl, type, state, request, matchesToLoad, matches, fetcherKey, manifest, mapRouteProperties);\n } catch (e) {\n // If the outer dataStrategy method throws, just return the error for all\n // matches - and it'll naturally bubble to the root\n matchesToLoad.forEach(m => {\n dataResults[m.route.id] = {\n type: ResultType.error,\n error: e\n };\n });\n return dataResults;\n }\n for (let [routeId, result] of Object.entries(results)) {\n if (isRedirectDataStrategyResultResult(result)) {\n let response = result.result;\n dataResults[routeId] = {\n type: ResultType.redirect,\n response: normalizeRelativeRoutingRedirectResponse(response, request, routeId, matches, basename, future.v7_relativeSplatPath)\n };\n } else {\n dataResults[routeId] = await convertDataStrategyResultToDataResult(result);\n }\n }\n return dataResults;\n }\n async function callLoadersAndMaybeResolveData(state, matches, matchesToLoad, fetchersToLoad, request) {\n let currentMatches = state.matches;\n // Kick off loaders and fetchers in parallel\n let loaderResultsPromise = callDataStrategy(\"loader\", state, request, matchesToLoad, matches, null);\n let fetcherResultsPromise = Promise.all(fetchersToLoad.map(async f => {\n if (f.matches && f.match && f.controller) {\n let results = await callDataStrategy(\"loader\", state, createClientSideRequest(init.history, f.path, f.controller.signal), [f.match], f.matches, f.key);\n let result = results[f.match.route.id];\n // Fetcher results are keyed by fetcher key from here on out, not routeId\n return {\n [f.key]: result\n };\n } else {\n return Promise.resolve({\n [f.key]: {\n type: ResultType.error,\n error: getInternalRouterError(404, {\n pathname: f.path\n })\n }\n });\n }\n }));\n let loaderResults = await loaderResultsPromise;\n let fetcherResults = (await fetcherResultsPromise).reduce((acc, r) => Object.assign(acc, r), {});\n await Promise.all([resolveNavigationDeferredResults(matches, loaderResults, request.signal, currentMatches, state.loaderData), resolveFetcherDeferredResults(matches, fetcherResults, fetchersToLoad)]);\n return {\n loaderResults,\n fetcherResults\n };\n }\n function interruptActiveLoads() {\n // Every interruption triggers a revalidation\n isRevalidationRequired = true;\n // Cancel pending route-level deferreds and mark cancelled routes for\n // revalidation\n cancelledDeferredRoutes.push(...cancelActiveDeferreds());\n // Abort in-flight fetcher loads\n fetchLoadMatches.forEach((_, key) => {\n if (fetchControllers.has(key)) {\n cancelledFetcherLoads.add(key);\n }\n abortFetcher(key);\n });\n }\n function updateFetcherState(key, fetcher, opts) {\n if (opts === void 0) {\n opts = {};\n }\n state.fetchers.set(key, fetcher);\n updateState({\n fetchers: new Map(state.fetchers)\n }, {\n flushSync: (opts && opts.flushSync) === true\n });\n }\n function setFetcherError(key, routeId, error, opts) {\n if (opts === void 0) {\n opts = {};\n }\n let boundaryMatch = findNearestBoundary(state.matches, routeId);\n deleteFetcher(key);\n updateState({\n errors: {\n [boundaryMatch.route.id]: error\n },\n fetchers: new Map(state.fetchers)\n }, {\n flushSync: (opts && opts.flushSync) === true\n });\n }\n function getFetcher(key) {\n activeFetchers.set(key, (activeFetchers.get(key) || 0) + 1);\n // If this fetcher was previously marked for deletion, unmark it since we\n // have a new instance\n if (deletedFetchers.has(key)) {\n deletedFetchers.delete(key);\n }\n return state.fetchers.get(key) || IDLE_FETCHER;\n }\n function deleteFetcher(key) {\n let fetcher = state.fetchers.get(key);\n // Don't abort the controller if this is a deletion of a fetcher.submit()\n // in it's loading phase since - we don't want to abort the corresponding\n // revalidation and want them to complete and land\n if (fetchControllers.has(key) && !(fetcher && fetcher.state === \"loading\" && fetchReloadIds.has(key))) {\n abortFetcher(key);\n }\n fetchLoadMatches.delete(key);\n fetchReloadIds.delete(key);\n fetchRedirectIds.delete(key);\n // If we opted into the flag we can clear this now since we're calling\n // deleteFetcher() at the end of updateState() and we've already handed the\n // deleted fetcher keys off to the data layer.\n // If not, we're eagerly calling deleteFetcher() and we need to keep this\n // Set populated until the next updateState call, and we'll clear\n // `deletedFetchers` then\n if (future.v7_fetcherPersist) {\n deletedFetchers.delete(key);\n }\n cancelledFetcherLoads.delete(key);\n state.fetchers.delete(key);\n }\n function deleteFetcherAndUpdateState(key) {\n let count = (activeFetchers.get(key) || 0) - 1;\n if (count <= 0) {\n activeFetchers.delete(key);\n deletedFetchers.add(key);\n if (!future.v7_fetcherPersist) {\n deleteFetcher(key);\n }\n } else {\n activeFetchers.set(key, count);\n }\n updateState({\n fetchers: new Map(state.fetchers)\n });\n }\n function abortFetcher(key) {\n let controller = fetchControllers.get(key);\n if (controller) {\n controller.abort();\n fetchControllers.delete(key);\n }\n }\n function markFetchersDone(keys) {\n for (let key of keys) {\n let fetcher = getFetcher(key);\n let doneFetcher = getDoneFetcher(fetcher.data);\n state.fetchers.set(key, doneFetcher);\n }\n }\n function markFetchRedirectsDone() {\n let doneKeys = [];\n let updatedFetchers = false;\n for (let key of fetchRedirectIds) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, \"Expected fetcher: \" + key);\n if (fetcher.state === \"loading\") {\n fetchRedirectIds.delete(key);\n doneKeys.push(key);\n updatedFetchers = true;\n }\n }\n markFetchersDone(doneKeys);\n return updatedFetchers;\n }\n function abortStaleFetchLoads(landedId) {\n let yeetedKeys = [];\n for (let [key, id] of fetchReloadIds) {\n if (id < landedId) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, \"Expected fetcher: \" + key);\n if (fetcher.state === \"loading\") {\n abortFetcher(key);\n fetchReloadIds.delete(key);\n yeetedKeys.push(key);\n }\n }\n }\n markFetchersDone(yeetedKeys);\n return yeetedKeys.length > 0;\n }\n function getBlocker(key, fn) {\n let blocker = state.blockers.get(key) || IDLE_BLOCKER;\n if (blockerFunctions.get(key) !== fn) {\n blockerFunctions.set(key, fn);\n }\n return blocker;\n }\n function deleteBlocker(key) {\n state.blockers.delete(key);\n blockerFunctions.delete(key);\n }\n // Utility function to update blockers, ensuring valid state transitions\n function updateBlocker(key, newBlocker) {\n let blocker = state.blockers.get(key) || IDLE_BLOCKER;\n // Poor mans state machine :)\n // https://mermaid.live/edit#pako:eNqVkc9OwzAMxl8l8nnjAYrEtDIOHEBIgwvKJTReGy3_lDpIqO27k6awMG0XcrLlnz87nwdonESogKXXBuE79rq75XZO3-yHds0RJVuv70YrPlUrCEe2HfrORS3rubqZfuhtpg5C9wk5tZ4VKcRUq88q9Z8RS0-48cE1iHJkL0ugbHuFLus9L6spZy8nX9MP2CNdomVaposqu3fGayT8T8-jJQwhepo_UtpgBQaDEUom04dZhAN1aJBDlUKJBxE1ceB2Smj0Mln-IBW5AFU2dwUiktt_2Qaq2dBfaKdEup85UV7Yd-dKjlnkabl2Pvr0DTkTreM\n invariant(blocker.state === \"unblocked\" && newBlocker.state === \"blocked\" || blocker.state === \"blocked\" && newBlocker.state === \"blocked\" || blocker.state === \"blocked\" && newBlocker.state === \"proceeding\" || blocker.state === \"blocked\" && newBlocker.state === \"unblocked\" || blocker.state === \"proceeding\" && newBlocker.state === \"unblocked\", \"Invalid blocker state transition: \" + blocker.state + \" -> \" + newBlocker.state);\n let blockers = new Map(state.blockers);\n blockers.set(key, newBlocker);\n updateState({\n blockers\n });\n }\n function shouldBlockNavigation(_ref2) {\n let {\n currentLocation,\n nextLocation,\n historyAction\n } = _ref2;\n if (blockerFunctions.size === 0) {\n return;\n }\n // We ony support a single active blocker at the moment since we don't have\n // any compelling use cases for multi-blocker yet\n if (blockerFunctions.size > 1) {\n warning(false, \"A router only supports one blocker at a time\");\n }\n let entries = Array.from(blockerFunctions.entries());\n let [blockerKey, blockerFunction] = entries[entries.length - 1];\n let blocker = state.blockers.get(blockerKey);\n if (blocker && blocker.state === \"proceeding\") {\n // If the blocker is currently proceeding, we don't need to re-check\n // it and can let this navigation continue\n return;\n }\n // At this point, we know we're unblocked/blocked so we need to check the\n // user-provided blocker function\n if (blockerFunction({\n currentLocation,\n nextLocation,\n historyAction\n })) {\n return blockerKey;\n }\n }\n function handleNavigational404(pathname) {\n let error = getInternalRouterError(404, {\n pathname\n });\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let {\n matches,\n route\n } = getShortCircuitMatches(routesToUse);\n // Cancel all pending deferred on 404s since we don't keep any routes\n cancelActiveDeferreds();\n return {\n notFoundMatches: matches,\n route,\n error\n };\n }\n function cancelActiveDeferreds(predicate) {\n let cancelledRouteIds = [];\n activeDeferreds.forEach((dfd, routeId) => {\n if (!predicate || predicate(routeId)) {\n // Cancel the deferred - but do not remove from activeDeferreds here -\n // we rely on the subscribers to do that so our tests can assert proper\n // cleanup via _internalActiveDeferreds\n dfd.cancel();\n cancelledRouteIds.push(routeId);\n activeDeferreds.delete(routeId);\n }\n });\n return cancelledRouteIds;\n }\n // Opt in to capturing and reporting scroll positions during navigations,\n // used by the <ScrollRestoration> component\n function enableScrollRestoration(positions, getPosition, getKey) {\n savedScrollPositions = positions;\n getScrollPosition = getPosition;\n getScrollRestorationKey = getKey || null;\n // Perform initial hydration scroll restoration, since we miss the boat on\n // the initial updateState() because we've not yet rendered <ScrollRestoration/>\n // and therefore have no savedScrollPositions available\n if (!initialScrollRestored && state.navigation === IDLE_NAVIGATION) {\n initialScrollRestored = true;\n let y = getSavedScrollPosition(state.location, state.matches);\n if (y != null) {\n updateState({\n restoreScrollPosition: y\n });\n }\n }\n return () => {\n savedScrollPositions = null;\n getScrollPosition = null;\n getScrollRestorationKey = null;\n };\n }\n function getScrollKey(location, matches) {\n if (getScrollRestorationKey) {\n let key = getScrollRestorationKey(location, matches.map(m => convertRouteMatchToUiMatch(m, state.loaderData)));\n return key || location.key;\n }\n return location.key;\n }\n function saveScrollPosition(location, matches) {\n if (savedScrollPositions && getScrollPosition) {\n let key = getScrollKey(location, matches);\n savedScrollPositions[key] = getScrollPosition();\n }\n }\n function getSavedScrollPosition(location, matches) {\n if (savedScrollPositions) {\n let key = getScrollKey(location, matches);\n let y = savedScrollPositions[key];\n if (typeof y === \"number\") {\n return y;\n }\n }\n return null;\n }\n function checkFogOfWar(matches, routesToUse, pathname) {\n if (patchRoutesOnNavigationImpl) {\n if (!matches) {\n let fogMatches = matchRoutesImpl(routesToUse, pathname, basename, true);\n return {\n active: true,\n matches: fogMatches || []\n };\n } else {\n if (Object.keys(matches[0].params).length > 0) {\n // If we matched a dynamic param or a splat, it might only be because\n // we haven't yet discovered other routes that would match with a\n // higher score. Call patchRoutesOnNavigation just to be sure\n let partialMatches = matchRoutesImpl(routesToUse, pathname, basename, true);\n return {\n active: true,\n matches: partialMatches\n };\n }\n }\n }\n return {\n active: false,\n matches: null\n };\n }\n async function discoverRoutes(matches, pathname, signal, fetcherKey) {\n if (!patchRoutesOnNavigationImpl) {\n return {\n type: \"success\",\n matches\n };\n }\n let partialMatches = matches;\n while (true) {\n let isNonHMR = inFlightDataRoutes == null;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let localManifest = manifest;\n try {\n await patchRoutesOnNavigationImpl({\n signal,\n path: pathname,\n matches: partialMatches,\n fetcherKey,\n patch: (routeId, children) => {\n if (signal.aborted) return;\n patchRoutesImpl(routeId, children, routesToUse, localManifest, mapRouteProperties);\n }\n });\n } catch (e) {\n return {\n type: \"error\",\n error: e,\n partialMatches\n };\n } finally {\n // If we are not in the middle of an HMR revalidation and we changed the\n // routes, provide a new identity so when we `updateState` at the end of\n // this navigation/fetch `router.routes` will be a new identity and\n // trigger a re-run of memoized `router.routes` dependencies.\n // HMR will already update the identity and reflow when it lands\n // `inFlightDataRoutes` in `completeNavigation`\n if (isNonHMR && !signal.aborted) {\n dataRoutes = [...dataRoutes];\n }\n }\n if (signal.aborted) {\n return {\n type: \"aborted\"\n };\n }\n let newMatches = matchRoutes(routesToUse, pathname, basename);\n if (newMatches) {\n return {\n type: \"success\",\n matches: newMatches\n };\n }\n let newPartialMatches = matchRoutesImpl(routesToUse, pathname, basename, true);\n // Avoid loops if the second pass results in the same partial matches\n if (!newPartialMatches || partialMatches.length === newPartialMatches.length && partialMatches.every((m, i) => m.route.id === newPartialMatches[i].route.id)) {\n return {\n type: \"success\",\n matches: null\n };\n }\n partialMatches = newPartialMatches;\n }\n }\n function _internalSetRoutes(newRoutes) {\n manifest = {};\n inFlightDataRoutes = convertRoutesToDataRoutes(newRoutes, mapRouteProperties, undefined, manifest);\n }\n function patchRoutes(routeId, children) {\n let isNonHMR = inFlightDataRoutes == null;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n patchRoutesImpl(routeId, children, routesToUse, manifest, mapRouteProperties);\n // If we are not in the middle of an HMR revalidation and we changed the\n // routes, provide a new identity and trigger a reflow via `updateState`\n // to re-run memoized `router.routes` dependencies.\n // HMR will already update the identity and reflow when it lands\n // `inFlightDataRoutes` in `completeNavigation`\n if (isNonHMR) {\n dataRoutes = [...dataRoutes];\n updateState({});\n }\n }\n router = {\n get basename() {\n return basename;\n },\n get future() {\n return future;\n },\n get state() {\n return state;\n },\n get routes() {\n return dataRoutes;\n },\n get window() {\n return routerWindow;\n },\n initialize,\n subscribe,\n enableScrollRestoration,\n navigate,\n fetch,\n revalidate,\n // Passthrough to history-aware createHref used by useHref so we get proper\n // hash-aware URLs in DOM paths\n createHref: to => init.history.createHref(to),\n encodeLocation: to => init.history.encodeLocation(to),\n getFetcher,\n deleteFetcher: deleteFetcherAndUpdateState,\n dispose,\n getBlocker,\n deleteBlocker,\n patchRoutes,\n _internalFetchControllers: fetchControllers,\n _internalActiveDeferreds: activeDeferreds,\n // TODO: Remove setRoutes, it's temporary to avoid dealing with\n // updating the tree while validating the update algorithm.\n _internalSetRoutes\n };\n return router;\n}\n//#endregion\n////////////////////////////////////////////////////////////////////////////////\n//#region createStaticHandler\n////////////////////////////////////////////////////////////////////////////////\nconst UNSAFE_DEFERRED_SYMBOL = Symbol(\"deferred\");\nfunction createStaticHandler(routes, opts) {\n invariant(routes.length > 0, \"You must provide a non-empty routes array to createStaticHandler\");\n let manifest = {};\n let basename = (opts ? opts.basename : null) || \"/\";\n let mapRouteProperties;\n if (opts != null && opts.mapRouteProperties) {\n mapRouteProperties = opts.mapRouteProperties;\n } else if (opts != null && opts.detectErrorBoundary) {\n // If they are still using the deprecated version, wrap it with the new API\n let detectErrorBoundary = opts.detectErrorBoundary;\n mapRouteProperties = route => ({\n hasErrorBoundary: detectErrorBoundary(route)\n });\n } else {\n mapRouteProperties = defaultMapRouteProperties;\n }\n // Config driven behavior flags\n let future = _extends({\n v7_relativeSplatPath: false,\n v7_throwAbortReason: false\n }, opts ? opts.future : null);\n let dataRoutes = convertRoutesToDataRoutes(routes, mapRouteProperties, undefined, manifest);\n /**\n * The query() method is intended for document requests, in which we want to\n * call an optional action and potentially multiple loaders for all nested\n * routes. It returns a StaticHandlerContext object, which is very similar\n * to the router state (location, loaderData, actionData, errors, etc.) and\n * also adds SSR-specific information such as the statusCode and headers\n * from action/loaders Responses.\n *\n * It _should_ never throw and should report all errors through the\n * returned context.errors object, properly associating errors to their error\n * boundary. Additionally, it tracks _deepestRenderedBoundaryId which can be\n * used to emulate React error boundaries during SSr by performing a second\n * pass only down to the boundaryId.\n *\n * The one exception where we do not return a StaticHandlerContext is when a\n * redirect response is returned or thrown from any action/loader. We\n * propagate that out and return the raw Response so the HTTP server can\n * return it directly.\n *\n * - `opts.requestContext` is an optional server context that will be passed\n * to actions/loaders in the `context` parameter\n * - `opts.skipLoaderErrorBubbling` is an optional parameter that will prevent\n * the bubbling of errors which allows single-fetch-type implementations\n * where the client will handle the bubbling and we may need to return data\n * for the handling route\n */\n async function query(request, _temp3) {\n let {\n requestContext,\n skipLoaderErrorBubbling,\n dataStrategy\n } = _temp3 === void 0 ? {} : _temp3;\n let url = new URL(request.url);\n let method = request.method;\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n // SSR supports HEAD requests while SPA doesn't\n if (!isValidMethod(method) && method !== \"HEAD\") {\n let error = getInternalRouterError(405, {\n method\n });\n let {\n matches: methodNotAllowedMatches,\n route\n } = getShortCircuitMatches(dataRoutes);\n return {\n basename,\n location,\n matches: methodNotAllowedMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null\n };\n } else if (!matches) {\n let error = getInternalRouterError(404, {\n pathname: location.pathname\n });\n let {\n matches: notFoundMatches,\n route\n } = getShortCircuitMatches(dataRoutes);\n return {\n basename,\n location,\n matches: notFoundMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null\n };\n }\n let result = await queryImpl(request, location, matches, requestContext, dataStrategy || null, skipLoaderErrorBubbling === true, null);\n if (isResponse(result)) {\n return result;\n }\n // When returning StaticHandlerContext, we patch back in the location here\n // since we need it for React Context. But this helps keep our submit and\n // loadRouteData operating on a Request instead of a Location\n return _extends({\n location,\n basename\n }, result);\n }\n /**\n * The queryRoute() method is intended for targeted route requests, either\n * for fetch ?_data requests or resource route requests. In this case, we\n * are only ever calling a single action or loader, and we are returning the\n * returned value directly. In most cases, this will be a Response returned\n * from the action/loader, but it may be a primitive or other value as well -\n * and in such cases the calling context should handle that accordingly.\n *\n * We do respect the throw/return differentiation, so if an action/loader\n * throws, then this method will throw the value. This is important so we\n * can do proper boundary identification in Remix where a thrown Response\n * must go to the Catch Boundary but a returned Response is happy-path.\n *\n * One thing to note is that any Router-initiated Errors that make sense\n * to associate with a status code will be thrown as an ErrorResponse\n * instance which include the raw Error, such that the calling context can\n * serialize the error as they see fit while including the proper response\n * code. Examples here are 404 and 405 errors that occur prior to reaching\n * any user-defined loaders.\n *\n * - `opts.routeId` allows you to specify the specific route handler to call.\n * If not provided the handler will determine the proper route by matching\n * against `request.url`\n * - `opts.requestContext` is an optional server context that will be passed\n * to actions/loaders in the `context` parameter\n */\n async function queryRoute(request, _temp4) {\n let {\n routeId,\n requestContext,\n dataStrategy\n } = _temp4 === void 0 ? {} : _temp4;\n let url = new URL(request.url);\n let method = request.method;\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n // SSR supports HEAD requests while SPA doesn't\n if (!isValidMethod(method) && method !== \"HEAD\" && method !== \"OPTIONS\") {\n throw getInternalRouterError(405, {\n method\n });\n } else if (!matches) {\n throw getInternalRouterError(404, {\n pathname: location.pathname\n });\n }\n let match = routeId ? matches.find(m => m.route.id === routeId) : getTargetMatch(matches, location);\n if (routeId && !match) {\n throw getInternalRouterError(403, {\n pathname: location.pathname,\n routeId\n });\n } else if (!match) {\n // This should never hit I don't think?\n throw getInternalRouterError(404, {\n pathname: location.pathname\n });\n }\n let result = await queryImpl(request, location, matches, requestContext, dataStrategy || null, false, match);\n if (isResponse(result)) {\n return result;\n }\n let error = result.errors ? Object.values(result.errors)[0] : undefined;\n if (error !== undefined) {\n // If we got back result.errors, that means the loader/action threw\n // _something_ that wasn't a Response, but it's not guaranteed/required\n // to be an `instanceof Error` either, so we have to use throw here to\n // preserve the \"error\" state outside of queryImpl.\n throw error;\n }\n // Pick off the right state value to return\n if (result.actionData) {\n return Object.values(result.actionData)[0];\n }\n if (result.loaderData) {\n var _result$activeDeferre;\n let data = Object.values(result.loaderData)[0];\n if ((_result$activeDeferre = result.activeDeferreds) != null && _result$activeDeferre[match.route.id]) {\n data[UNSAFE_DEFERRED_SYMBOL] = result.activeDeferreds[match.route.id];\n }\n return data;\n }\n return undefined;\n }\n async function queryImpl(request, location, matches, requestContext, dataStrategy, skipLoaderErrorBubbling, routeMatch) {\n invariant(request.signal, \"query()/queryRoute() requests must contain an AbortController signal\");\n try {\n if (isMutationMethod(request.method.toLowerCase())) {\n let result = await submit(request, matches, routeMatch || getTargetMatch(matches, location), requestContext, dataStrategy, skipLoaderErrorBubbling, routeMatch != null);\n return result;\n }\n let result = await loadRouteData(request, matches, requestContext, dataStrategy, skipLoaderErrorBubbling, routeMatch);\n return isResponse(result) ? result : _extends({}, result, {\n actionData: null,\n actionHeaders: {}\n });\n } catch (e) {\n // If the user threw/returned a Response in callLoaderOrAction for a\n // `queryRoute` call, we throw the `DataStrategyResult` to bail out early\n // and then return or throw the raw Response here accordingly\n if (isDataStrategyResult(e) && isResponse(e.result)) {\n if (e.type === ResultType.error) {\n throw e.result;\n }\n return e.result;\n }\n // Redirects are always returned since they don't propagate to catch\n // boundaries\n if (isRedirectResponse(e)) {\n return e;\n }\n throw e;\n }\n }\n async function submit(request, matches, actionMatch, requestContext, dataStrategy, skipLoaderErrorBubbling, isRouteRequest) {\n let result;\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n let error = getInternalRouterError(405, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: actionMatch.route.id\n });\n if (isRouteRequest) {\n throw error;\n }\n result = {\n type: ResultType.error,\n error\n };\n } else {\n let results = await callDataStrategy(\"action\", request, [actionMatch], matches, isRouteRequest, requestContext, dataStrategy);\n result = results[actionMatch.route.id];\n if (request.signal.aborted) {\n throwStaticHandlerAbortedError(request, isRouteRequest, future);\n }\n }\n if (isRedirectResult(result)) {\n // Uhhhh - this should never happen, we should always throw these from\n // callLoaderOrAction, but the type narrowing here keeps TS happy and we\n // can get back on the \"throw all redirect responses\" train here should\n // this ever happen :/\n throw new Response(null, {\n status: result.response.status,\n headers: {\n Location: result.response.headers.get(\"Location\")\n }\n });\n }\n if (isDeferredResult(result)) {\n let error = getInternalRouterError(400, {\n type: \"defer-action\"\n });\n if (isRouteRequest) {\n throw error;\n }\n result = {\n type: ResultType.error,\n error\n };\n }\n if (isRouteRequest) {\n // Note: This should only be non-Response values if we get here, since\n // isRouteRequest should throw any Response received in callLoaderOrAction\n if (isErrorResult(result)) {\n throw result.error;\n }\n return {\n matches: [actionMatch],\n loaderData: {},\n actionData: {\n [actionMatch.route.id]: result.data\n },\n errors: null,\n // Note: statusCode + headers are unused here since queryRoute will\n // return the raw Response or value\n statusCode: 200,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null\n };\n }\n // Create a GET request for the loaders\n let loaderRequest = new Request(request.url, {\n headers: request.headers,\n redirect: request.redirect,\n signal: request.signal\n });\n if (isErrorResult(result)) {\n // Store off the pending error - we use it to determine which loaders\n // to call and will commit it when we complete the navigation\n let boundaryMatch = skipLoaderErrorBubbling ? actionMatch : findNearestBoundary(matches, actionMatch.route.id);\n let context = await loadRouteData(loaderRequest, matches, requestContext, dataStrategy, skipLoaderErrorBubbling, null, [boundaryMatch.route.id, result]);\n // action status codes take precedence over loader status codes\n return _extends({}, context, {\n statusCode: isRouteErrorResponse(result.error) ? result.error.status : result.statusCode != null ? result.statusCode : 500,\n actionData: null,\n actionHeaders: _extends({}, result.headers ? {\n [actionMatch.route.id]: result.headers\n } : {})\n });\n }\n let context = await loadRouteData(loaderRequest, matches, requestContext, dataStrategy, skipLoaderErrorBubbling, null);\n return _extends({}, context, {\n actionData: {\n [actionMatch.route.id]: result.data\n }\n }, result.statusCode ? {\n statusCode: result.statusCode\n } : {}, {\n actionHeaders: result.headers ? {\n [actionMatch.route.id]: result.headers\n } : {}\n });\n }\n async function loadRouteData(request, matches, requestContext, dataStrategy, skipLoaderErrorBubbling, routeMatch, pendingActionResult) {\n let isRouteRequest = routeMatch != null;\n // Short circuit if we have no loaders to run (queryRoute())\n if (isRouteRequest && !(routeMatch != null && routeMatch.route.loader) && !(routeMatch != null && routeMatch.route.lazy)) {\n throw getInternalRouterError(400, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: routeMatch == null ? void 0 : routeMatch.route.id\n });\n }\n let requestMatches = routeMatch ? [routeMatch] : pendingActionResult && isErrorResult(pendingActionResult[1]) ? getLoaderMatchesUntilBoundary(matches, pendingActionResult[0]) : matches;\n let matchesToLoad = requestMatches.filter(m => m.route.loader || m.route.lazy);\n // Short circuit if we have no loaders to run (query())\n if (matchesToLoad.length === 0) {\n return {\n matches,\n // Add a null for all matched routes for proper revalidation on the client\n loaderData: matches.reduce((acc, m) => Object.assign(acc, {\n [m.route.id]: null\n }), {}),\n errors: pendingActionResult && isErrorResult(pendingActionResult[1]) ? {\n [pendingActionResult[0]]: pendingActionResult[1].error\n } : null,\n statusCode: 200,\n loaderHeaders: {},\n activeDeferreds: null\n };\n }\n let results = await callDataStrategy(\"loader\", request, matchesToLoad, matches, isRouteRequest, requestContext, dataStrategy);\n if (request.signal.aborted) {\n throwStaticHandlerAbortedError(request, isRouteRequest, future);\n }\n // Process and commit output from loaders\n let activeDeferreds = new Map();\n let context = processRouteLoaderData(matches, results, pendingActionResult, activeDeferreds, skipLoaderErrorBubbling);\n // Add a null for any non-loader matches for proper revalidation on the client\n let executedLoaders = new Set(matchesToLoad.map(match => match.route.id));\n matches.forEach(match => {\n if (!executedLoaders.has(match.route.id)) {\n context.loaderData[match.route.id] = null;\n }\n });\n return _extends({}, context, {\n matches,\n activeDeferreds: activeDeferreds.size > 0 ? Object.fromEntries(activeDeferreds.entries()) : null\n });\n }\n // Utility wrapper for calling dataStrategy server-side without having to\n // pass around the manifest, mapRouteProperties, etc.\n async function callDataStrategy(type, request, matchesToLoad, matches, isRouteRequest, requestContext, dataStrategy) {\n let results = await callDataStrategyImpl(dataStrategy || defaultDataStrategy, type, null, request, matchesToLoad, matches, null, manifest, mapRouteProperties, requestContext);\n let dataResults = {};\n await Promise.all(matches.map(async match => {\n if (!(match.route.id in results)) {\n return;\n }\n let result = results[match.route.id];\n if (isRedirectDataStrategyResultResult(result)) {\n let response = result.result;\n // Throw redirects and let the server handle them with an HTTP redirect\n throw normalizeRelativeRoutingRedirectResponse(response, request, match.route.id, matches, basename, future.v7_relativeSplatPath);\n }\n if (isResponse(result.result) && isRouteRequest) {\n // For SSR single-route requests, we want to hand Responses back\n // directly without unwrapping\n throw result;\n }\n dataResults[match.route.id] = await convertDataStrategyResultToDataResult(result);\n }));\n return dataResults;\n }\n return {\n dataRoutes,\n query,\n queryRoute\n };\n}\n//#endregion\n////////////////////////////////////////////////////////////////////////////////\n//#region Helpers\n////////////////////////////////////////////////////////////////////////////////\n/**\n * Given an existing StaticHandlerContext and an error thrown at render time,\n * provide an updated StaticHandlerContext suitable for a second SSR render\n */\nfunction getStaticContextFromError(routes, context, error) {\n let newContext = _extends({}, context, {\n statusCode: isRouteErrorResponse(error) ? error.status : 500,\n errors: {\n [context._deepestRenderedBoundaryId || routes[0].id]: error\n }\n });\n return newContext;\n}\nfunction throwStaticHandlerAbortedError(request, isRouteRequest, future) {\n if (future.v7_throwAbortReason && request.signal.reason !== undefined) {\n throw request.signal.reason;\n }\n let method = isRouteRequest ? \"queryRoute\" : \"query\";\n throw new Error(method + \"() call aborted: \" + request.method + \" \" + request.url);\n}\nfunction isSubmissionNavigation(opts) {\n return opts != null && (\"formData\" in opts && opts.formData != null || \"body\" in opts && opts.body !== undefined);\n}\nfunction normalizeTo(location, matches, basename, prependBasename, to, v7_relativeSplatPath, fromRouteId, relative) {\n let contextualMatches;\n let activeRouteMatch;\n if (fromRouteId) {\n // Grab matches up to the calling route so our route-relative logic is\n // relative to the correct source route\n contextualMatches = [];\n for (let match of matches) {\n contextualMatches.push(match);\n if (match.route.id === fromRouteId) {\n activeRouteMatch = match;\n break;\n }\n }\n } else {\n contextualMatches = matches;\n activeRouteMatch = matches[matches.length - 1];\n }\n // Resolve the relative path\n let path = resolveTo(to ? to : \".\", getResolveToMatches(contextualMatches, v7_relativeSplatPath), stripBasename(location.pathname, basename) || location.pathname, relative === \"path\");\n // When `to` is not specified we inherit search/hash from the current\n // location, unlike when to=\".\" and we just inherit the path.\n // See https://github.com/remix-run/remix/issues/927\n if (to == null) {\n path.search = location.search;\n path.hash = location.hash;\n }\n // Account for `?index` params when routing to the current location\n if ((to == null || to === \"\" || to === \".\") && activeRouteMatch) {\n let nakedIndex = hasNakedIndexQuery(path.search);\n if (activeRouteMatch.route.index && !nakedIndex) {\n // Add one when we're targeting an index route\n path.search = path.search ? path.search.replace(/^\\?/, \"?index&\") : \"?index\";\n } else if (!activeRouteMatch.route.index && nakedIndex) {\n // Remove existing ones when we're not\n let params = new URLSearchParams(path.search);\n let indexValues = params.getAll(\"index\");\n params.delete(\"index\");\n indexValues.filter(v => v).forEach(v => params.append(\"index\", v));\n let qs = params.toString();\n path.search = qs ? \"?\" + qs : \"\";\n }\n }\n // If we're operating within a basename, prepend it to the pathname. If\n // this is a root navigation, then just use the raw basename which allows\n // the basename to have full control over the presence of a trailing slash\n // on root actions\n if (prependBasename && basename !== \"/\") {\n path.pathname = path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n }\n return createPath(path);\n}\n// Normalize navigation options by converting formMethod=GET formData objects to\n// URLSearchParams so they behave identically to links with query params\nfunction normalizeNavigateOptions(normalizeFormMethod, isFetcher, path, opts) {\n // Return location verbatim on non-submission navigations\n if (!opts || !isSubmissionNavigation(opts)) {\n return {\n path\n };\n }\n if (opts.formMethod && !isValidMethod(opts.formMethod)) {\n return {\n path,\n error: getInternalRouterError(405, {\n method: opts.formMethod\n })\n };\n }\n let getInvalidBodyError = () => ({\n path,\n error: getInternalRouterError(400, {\n type: \"invalid-body\"\n })\n });\n // Create a Submission on non-GET navigations\n let rawFormMethod = opts.formMethod || \"get\";\n let formMethod = normalizeFormMethod ? rawFormMethod.toUpperCase() : rawFormMethod.toLowerCase();\n let formAction = stripHashFromPath(path);\n if (opts.body !== undefined) {\n if (opts.formEncType === \"text/plain\") {\n // text only support POST/PUT/PATCH/DELETE submissions\n if (!isMutationMethod(formMethod)) {\n return getInvalidBodyError();\n }\n let text = typeof opts.body === \"string\" ? opts.body : opts.body instanceof FormData || opts.body instanceof URLSearchParams ?\n // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#plain-text-form-data\n Array.from(opts.body.entries()).reduce((acc, _ref3) => {\n let [name, value] = _ref3;\n return \"\" + acc + name + \"=\" + value + \"\\n\";\n }, \"\") : String(opts.body);\n return {\n path,\n submission: {\n formMethod,\n formAction,\n formEncType: opts.formEncType,\n formData: undefined,\n json: undefined,\n text\n }\n };\n } else if (opts.formEncType === \"application/json\") {\n // json only supports POST/PUT/PATCH/DELETE submissions\n if (!isMutationMethod(formMethod)) {\n return getInvalidBodyError();\n }\n try {\n let json = typeof opts.body === \"string\" ? JSON.parse(opts.body) : opts.body;\n return {\n path,\n submission: {\n formMethod,\n formAction,\n formEncType: opts.formEncType,\n formData: undefined,\n json,\n text: undefined\n }\n };\n } catch (e) {\n return getInvalidBodyError();\n }\n }\n }\n invariant(typeof FormData === \"function\", \"FormData is not available in this environment\");\n let searchParams;\n let formData;\n if (opts.formData) {\n searchParams = convertFormDataToSearchParams(opts.formData);\n formData = opts.formData;\n } else if (opts.body instanceof FormData) {\n searchParams = convertFormDataToSearchParams(opts.body);\n formData = opts.body;\n } else if (opts.body instanceof URLSearchParams) {\n searchParams = opts.body;\n formData = convertSearchParamsToFormData(searchParams);\n } else if (opts.body == null) {\n searchParams = new URLSearchParams();\n formData = new FormData();\n } else {\n try {\n searchParams = new URLSearchParams(opts.body);\n formData = convertSearchParamsToFormData(searchParams);\n } catch (e) {\n return getInvalidBodyError();\n }\n }\n let submission = {\n formMethod,\n formAction,\n formEncType: opts && opts.formEncType || \"application/x-www-form-urlencoded\",\n formData,\n json: undefined,\n text: undefined\n };\n if (isMutationMethod(submission.formMethod)) {\n return {\n path,\n submission\n };\n }\n // Flatten submission onto URLSearchParams for GET submissions\n let parsedPath = parsePath(path);\n // On GET navigation submissions we can drop the ?index param from the\n // resulting location since all loaders will run. But fetcher GET submissions\n // only run a single loader so we need to preserve any incoming ?index params\n if (isFetcher && parsedPath.search && hasNakedIndexQuery(parsedPath.search)) {\n searchParams.append(\"index\", \"\");\n }\n parsedPath.search = \"?\" + searchParams;\n return {\n path: createPath(parsedPath),\n submission\n };\n}\n// Filter out all routes at/below any caught error as they aren't going to\n// render so we don't need to load them\nfunction getLoaderMatchesUntilBoundary(matches, boundaryId, includeBoundary) {\n if (includeBoundary === void 0) {\n includeBoundary = false;\n }\n let index = matches.findIndex(m => m.route.id === boundaryId);\n if (index >= 0) {\n return matches.slice(0, includeBoundary ? index + 1 : index);\n }\n return matches;\n}\nfunction getMatchesToLoad(history, state, matches, submission, location, initialHydration, skipActionErrorRevalidation, isRevalidationRequired, cancelledDeferredRoutes, cancelledFetcherLoads, deletedFetchers, fetchLoadMatches, fetchRedirectIds, routesToUse, basename, pendingActionResult) {\n let actionResult = pendingActionResult ? isErrorResult(pendingActionResult[1]) ? pendingActionResult[1].error : pendingActionResult[1].data : undefined;\n let currentUrl = history.createURL(state.location);\n let nextUrl = history.createURL(location);\n // Pick navigation matches that are net-new or qualify for revalidation\n let boundaryMatches = matches;\n if (initialHydration && state.errors) {\n // On initial hydration, only consider matches up to _and including_ the boundary.\n // This is inclusive to handle cases where a server loader ran successfully,\n // a child server loader bubbled up to this route, but this route has\n // `clientLoader.hydrate` so we want to still run the `clientLoader` so that\n // we have a complete version of `loaderData`\n boundaryMatches = getLoaderMatchesUntilBoundary(matches, Object.keys(state.errors)[0], true);\n } else if (pendingActionResult && isErrorResult(pendingActionResult[1])) {\n // If an action threw an error, we call loaders up to, but not including the\n // boundary\n boundaryMatches = getLoaderMatchesUntilBoundary(matches, pendingActionResult[0]);\n }\n // Don't revalidate loaders by default after action 4xx/5xx responses\n // when the flag is enabled. They can still opt-into revalidation via\n // `shouldRevalidate` via `actionResult`\n let actionStatus = pendingActionResult ? pendingActionResult[1].statusCode : undefined;\n let shouldSkipRevalidation = skipActionErrorRevalidation && actionStatus && actionStatus >= 400;\n let navigationMatches = boundaryMatches.filter((match, index) => {\n let {\n route\n } = match;\n if (route.lazy) {\n // We haven't loaded this route yet so we don't know if it's got a loader!\n return true;\n }\n if (route.loader == null) {\n return false;\n }\n if (initialHydration) {\n return shouldLoadRouteOnHydration(route, state.loaderData, state.errors);\n }\n // Always call the loader on new route instances and pending defer cancellations\n if (isNewLoader(state.loaderData, state.matches[index], match) || cancelledDeferredRoutes.some(id => id === match.route.id)) {\n return true;\n }\n // This is the default implementation for when we revalidate. If the route\n // provides it's own implementation, then we give them full control but\n // provide this value so they can leverage it if needed after they check\n // their own specific use cases\n let currentRouteMatch = state.matches[index];\n let nextRouteMatch = match;\n return shouldRevalidateLoader(match, _extends({\n currentUrl,\n currentParams: currentRouteMatch.params,\n nextUrl,\n nextParams: nextRouteMatch.params\n }, submission, {\n actionResult,\n actionStatus,\n defaultShouldRevalidate: shouldSkipRevalidation ? false :\n // Forced revalidation due to submission, useRevalidator, or X-Remix-Revalidate\n isRevalidationRequired || currentUrl.pathname + currentUrl.search === nextUrl.pathname + nextUrl.search ||\n // Search params affect all loaders\n currentUrl.search !== nextUrl.search || isNewRouteInstance(currentRouteMatch, nextRouteMatch)\n }));\n });\n // Pick fetcher.loads that need to be revalidated\n let revalidatingFetchers = [];\n fetchLoadMatches.forEach((f, key) => {\n // Don't revalidate:\n // - on initial hydration (shouldn't be any fetchers then anyway)\n // - if fetcher won't be present in the subsequent render\n // - no longer matches the URL (v7_fetcherPersist=false)\n // - was unmounted but persisted due to v7_fetcherPersist=true\n if (initialHydration || !matches.some(m => m.route.id === f.routeId) || deletedFetchers.has(key)) {\n return;\n }\n let fetcherMatches = matchRoutes(routesToUse, f.path, basename);\n // If the fetcher path no longer matches, push it in with null matches so\n // we can trigger a 404 in callLoadersAndMaybeResolveData. Note this is\n // currently only a use-case for Remix HMR where the route tree can change\n // at runtime and remove a route previously loaded via a fetcher\n if (!fetcherMatches) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: null,\n match: null,\n controller: null\n });\n return;\n }\n // Revalidating fetchers are decoupled from the route matches since they\n // load from a static href. They revalidate based on explicit revalidation\n // (submission, useRevalidator, or X-Remix-Revalidate)\n let fetcher = state.fetchers.get(key);\n let fetcherMatch = getTargetMatch(fetcherMatches, f.path);\n let shouldRevalidate = false;\n if (fetchRedirectIds.has(key)) {\n // Never trigger a revalidation of an actively redirecting fetcher\n shouldRevalidate = false;\n } else if (cancelledFetcherLoads.has(key)) {\n // Always mark for revalidation if the fetcher was cancelled\n cancelledFetcherLoads.delete(key);\n shouldRevalidate = true;\n } else if (fetcher && fetcher.state !== \"idle\" && fetcher.data === undefined) {\n // If the fetcher hasn't ever completed loading yet, then this isn't a\n // revalidation, it would just be a brand new load if an explicit\n // revalidation is required\n shouldRevalidate = isRevalidationRequired;\n } else {\n // Otherwise fall back on any user-defined shouldRevalidate, defaulting\n // to explicit revalidations only\n shouldRevalidate = shouldRevalidateLoader(fetcherMatch, _extends({\n currentUrl,\n currentParams: state.matches[state.matches.length - 1].params,\n nextUrl,\n nextParams: matches[matches.length - 1].params\n }, submission, {\n actionResult,\n actionStatus,\n defaultShouldRevalidate: shouldSkipRevalidation ? false : isRevalidationRequired\n }));\n }\n if (shouldRevalidate) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: fetcherMatches,\n match: fetcherMatch,\n controller: new AbortController()\n });\n }\n });\n return [navigationMatches, revalidatingFetchers];\n}\nfunction shouldLoadRouteOnHydration(route, loaderData, errors) {\n // We dunno if we have a loader - gotta find out!\n if (route.lazy) {\n return true;\n }\n // No loader, nothing to initialize\n if (!route.loader) {\n return false;\n }\n let hasData = loaderData != null && loaderData[route.id] !== undefined;\n let hasError = errors != null && errors[route.id] !== undefined;\n // Don't run if we error'd during SSR\n if (!hasData && hasError) {\n return false;\n }\n // Explicitly opting-in to running on hydration\n if (typeof route.loader === \"function\" && route.loader.hydrate === true) {\n return true;\n }\n // Otherwise, run if we're not yet initialized with anything\n return !hasData && !hasError;\n}\nfunction isNewLoader(currentLoaderData, currentMatch, match) {\n let isNew =\n // [a] -> [a, b]\n !currentMatch ||\n // [a, b] -> [a, c]\n match.route.id !== currentMatch.route.id;\n // Handle the case that we don't have data for a re-used route, potentially\n // from a prior error or from a cancelled pending deferred\n let isMissingData = currentLoaderData[match.route.id] === undefined;\n // Always load if this is a net-new route or we don't yet have data\n return isNew || isMissingData;\n}\nfunction isNewRouteInstance(currentMatch, match) {\n let currentPath = currentMatch.route.path;\n return (\n // param change for this match, /users/123 -> /users/456\n currentMatch.pathname !== match.pathname ||\n // splat param changed, which is not present in match.path\n // e.g. /files/images/avatar.jpg -> files/finances.xls\n currentPath != null && currentPath.endsWith(\"*\") && currentMatch.params[\"*\"] !== match.params[\"*\"]\n );\n}\nfunction shouldRevalidateLoader(loaderMatch, arg) {\n if (loaderMatch.route.shouldRevalidate) {\n let routeChoice = loaderMatch.route.shouldRevalidate(arg);\n if (typeof routeChoice === \"boolean\") {\n return routeChoice;\n }\n }\n return arg.defaultShouldRevalidate;\n}\nfunction patchRoutesImpl(routeId, children, routesToUse, manifest, mapRouteProperties) {\n var _childrenToPatch;\n let childrenToPatch;\n if (routeId) {\n let route = manifest[routeId];\n invariant(route, \"No route found to patch children into: routeId = \" + routeId);\n if (!route.children) {\n route.children = [];\n }\n childrenToPatch = route.children;\n } else {\n childrenToPatch = routesToUse;\n }\n // Don't patch in routes we already know about so that `patch` is idempotent\n // to simplify user-land code. This is useful because we re-call the\n // `patchRoutesOnNavigation` function for matched routes with params.\n let uniqueChildren = children.filter(newRoute => !childrenToPatch.some(existingRoute => isSameRoute(newRoute, existingRoute)));\n let newRoutes = convertRoutesToDataRoutes(uniqueChildren, mapRouteProperties, [routeId || \"_\", \"patch\", String(((_childrenToPatch = childrenToPatch) == null ? void 0 : _childrenToPatch.length) || \"0\")], manifest);\n childrenToPatch.push(...newRoutes);\n}\nfunction isSameRoute(newRoute, existingRoute) {\n // Most optimal check is by id\n if (\"id\" in newRoute && \"id\" in existingRoute && newRoute.id === existingRoute.id) {\n return true;\n }\n // Second is by pathing differences\n if (!(newRoute.index === existingRoute.index && newRoute.path === existingRoute.path && newRoute.caseSensitive === existingRoute.caseSensitive)) {\n return false;\n }\n // Pathless layout routes are trickier since we need to check children.\n // If they have no children then they're the same as far as we can tell\n if ((!newRoute.children || newRoute.children.length === 0) && (!existingRoute.children || existingRoute.children.length === 0)) {\n return true;\n }\n // Otherwise, we look to see if every child in the new route is already\n // represented in the existing route's children\n return newRoute.children.every((aChild, i) => {\n var _existingRoute$childr;\n return (_existingRoute$childr = existingRoute.children) == null ? void 0 : _existingRoute$childr.some(bChild => isSameRoute(aChild, bChild));\n });\n}\n/**\n * Execute route.lazy() methods to lazily load route modules (loader, action,\n * shouldRevalidate) and update the routeManifest in place which shares objects\n * with dataRoutes so those get updated as well.\n */\nasync function loadLazyRouteModule(route, mapRouteProperties, manifest) {\n if (!route.lazy) {\n return;\n }\n let lazyRoute = await route.lazy();\n // If the lazy route function was executed and removed by another parallel\n // call then we can return - first lazy() to finish wins because the return\n // value of lazy is expected to be static\n if (!route.lazy) {\n return;\n }\n let routeToUpdate = manifest[route.id];\n invariant(routeToUpdate, \"No route found in manifest\");\n // Update the route in place. This should be safe because there's no way\n // we could yet be sitting on this route as we can't get there without\n // resolving lazy() first.\n //\n // This is different than the HMR \"update\" use-case where we may actively be\n // on the route being updated. The main concern boils down to \"does this\n // mutation affect any ongoing navigations or any current state.matches\n // values?\". If not, it should be safe to update in place.\n let routeUpdates = {};\n for (let lazyRouteProperty in lazyRoute) {\n let staticRouteValue = routeToUpdate[lazyRouteProperty];\n let isPropertyStaticallyDefined = staticRouteValue !== undefined &&\n // This property isn't static since it should always be updated based\n // on the route updates\n lazyRouteProperty !== \"hasErrorBoundary\";\n warning(!isPropertyStaticallyDefined, \"Route \\\"\" + routeToUpdate.id + \"\\\" has a static property \\\"\" + lazyRouteProperty + \"\\\" \" + \"defined but its lazy function is also returning a value for this property. \" + (\"The lazy route property \\\"\" + lazyRouteProperty + \"\\\" will be ignored.\"));\n if (!isPropertyStaticallyDefined && !immutableRouteKeys.has(lazyRouteProperty)) {\n routeUpdates[lazyRouteProperty] = lazyRoute[lazyRouteProperty];\n }\n }\n // Mutate the route with the provided updates. Do this first so we pass\n // the updated version to mapRouteProperties\n Object.assign(routeToUpdate, routeUpdates);\n // Mutate the `hasErrorBoundary` property on the route based on the route\n // updates and remove the `lazy` function so we don't resolve the lazy\n // route again.\n Object.assign(routeToUpdate, _extends({}, mapRouteProperties(routeToUpdate), {\n lazy: undefined\n }));\n}\n// Default implementation of `dataStrategy` which fetches all loaders in parallel\nasync function defaultDataStrategy(_ref4) {\n let {\n matches\n } = _ref4;\n let matchesToLoad = matches.filter(m => m.shouldLoad);\n let results = await Promise.all(matchesToLoad.map(m => m.resolve()));\n return results.reduce((acc, result, i) => Object.assign(acc, {\n [matchesToLoad[i].route.id]: result\n }), {});\n}\nasync function callDataStrategyImpl(dataStrategyImpl, type, state, request, matchesToLoad, matches, fetcherKey, manifest, mapRouteProperties, requestContext) {\n let loadRouteDefinitionsPromises = matches.map(m => m.route.lazy ? loadLazyRouteModule(m.route, mapRouteProperties, manifest) : undefined);\n let dsMatches = matches.map((match, i) => {\n let loadRoutePromise = loadRouteDefinitionsPromises[i];\n let shouldLoad = matchesToLoad.some(m => m.route.id === match.route.id);\n // `resolve` encapsulates route.lazy(), executing the loader/action,\n // and mapping return values/thrown errors to a `DataStrategyResult`. Users\n // can pass a callback to take fine-grained control over the execution\n // of the loader/action\n let resolve = async handlerOverride => {\n if (handlerOverride && request.method === \"GET\" && (match.route.lazy || match.route.loader)) {\n shouldLoad = true;\n }\n return shouldLoad ? callLoaderOrAction(type, request, match, loadRoutePromise, handlerOverride, requestContext) : Promise.resolve({\n type: ResultType.data,\n result: undefined\n });\n };\n return _extends({}, match, {\n shouldLoad,\n resolve\n });\n });\n // Send all matches here to allow for a middleware-type implementation.\n // handler will be a no-op for unneeded routes and we filter those results\n // back out below.\n let results = await dataStrategyImpl({\n matches: dsMatches,\n request,\n params: matches[0].params,\n fetcherKey,\n context: requestContext\n });\n // Wait for all routes to load here but 'swallow the error since we want\n // it to bubble up from the `await loadRoutePromise` in `callLoaderOrAction` -\n // called from `match.resolve()`\n try {\n await Promise.all(loadRouteDefinitionsPromises);\n } catch (e) {\n // No-op\n }\n return results;\n}\n// Default logic for calling a loader/action is the user has no specified a dataStrategy\nasync function callLoaderOrAction(type, request, match, loadRoutePromise, handlerOverride, staticContext) {\n let result;\n let onReject;\n let runHandler = handler => {\n // Setup a promise we can race against so that abort signals short circuit\n let reject;\n // This will never resolve so safe to type it as Promise<DataStrategyResult> to\n // satisfy the function return value\n let abortPromise = new Promise((_, r) => reject = r);\n onReject = () => reject();\n request.signal.addEventListener(\"abort\", onReject);\n let actualHandler = ctx => {\n if (typeof handler !== \"function\") {\n return Promise.reject(new Error(\"You cannot call the handler for a route which defines a boolean \" + (\"\\\"\" + type + \"\\\" [routeId: \" + match.route.id + \"]\")));\n }\n return handler({\n request,\n params: match.params,\n context: staticContext\n }, ...(ctx !== undefined ? [ctx] : []));\n };\n let handlerPromise = (async () => {\n try {\n let val = await (handlerOverride ? handlerOverride(ctx => actualHandler(ctx)) : actualHandler());\n return {\n type: \"data\",\n result: val\n };\n } catch (e) {\n return {\n type: \"error\",\n result: e\n };\n }\n })();\n return Promise.race([handlerPromise, abortPromise]);\n };\n try {\n let handler = match.route[type];\n // If we have a route.lazy promise, await that first\n if (loadRoutePromise) {\n if (handler) {\n // Run statically defined handler in parallel with lazy()\n let handlerError;\n let [value] = await Promise.all([\n // If the handler throws, don't let it immediately bubble out,\n // since we need to let the lazy() execution finish so we know if this\n // route has a boundary that can handle the error\n runHandler(handler).catch(e => {\n handlerError = e;\n }), loadRoutePromise]);\n if (handlerError !== undefined) {\n throw handlerError;\n }\n result = value;\n } else {\n // Load lazy route module, then run any returned handler\n await loadRoutePromise;\n handler = match.route[type];\n if (handler) {\n // Handler still runs even if we got interrupted to maintain consistency\n // with un-abortable behavior of handler execution on non-lazy or\n // previously-lazy-loaded routes\n result = await runHandler(handler);\n } else if (type === \"action\") {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(405, {\n method: request.method,\n pathname,\n routeId: match.route.id\n });\n } else {\n // lazy() route has no loader to run. Short circuit here so we don't\n // hit the invariant below that errors on returning undefined.\n return {\n type: ResultType.data,\n result: undefined\n };\n }\n }\n } else if (!handler) {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(404, {\n pathname\n });\n } else {\n result = await runHandler(handler);\n }\n invariant(result.result !== undefined, \"You defined \" + (type === \"action\" ? \"an action\" : \"a loader\") + \" for route \" + (\"\\\"\" + match.route.id + \"\\\" but didn't return anything from your `\" + type + \"` \") + \"function. Please return a value or `null`.\");\n } catch (e) {\n // We should already be catching and converting normal handler executions to\n // DataStrategyResults and returning them, so anything that throws here is an\n // unexpected error we still need to wrap\n return {\n type: ResultType.error,\n result: e\n };\n } finally {\n if (onReject) {\n request.signal.removeEventListener(\"abort\", onReject);\n }\n }\n return result;\n}\nasync function convertDataStrategyResultToDataResult(dataStrategyResult) {\n let {\n result,\n type\n } = dataStrategyResult;\n if (isResponse(result)) {\n let data;\n try {\n let contentType = result.headers.get(\"Content-Type\");\n // Check between word boundaries instead of startsWith() due to the last\n // paragraph of https://httpwg.org/specs/rfc9110.html#field.content-type\n if (contentType && /\\bapplication\\/json\\b/.test(contentType)) {\n if (result.body == null) {\n data = null;\n } else {\n data = await result.json();\n }\n } else {\n data = await result.text();\n }\n } catch (e) {\n return {\n type: ResultType.error,\n error: e\n };\n }\n if (type === ResultType.error) {\n return {\n type: ResultType.error,\n error: new ErrorResponseImpl(result.status, result.statusText, data),\n statusCode: result.status,\n headers: result.headers\n };\n }\n return {\n type: ResultType.data,\n data,\n statusCode: result.status,\n headers: result.headers\n };\n }\n if (type === ResultType.error) {\n if (isDataWithResponseInit(result)) {\n var _result$init3, _result$init4;\n if (result.data instanceof Error) {\n var _result$init, _result$init2;\n return {\n type: ResultType.error,\n error: result.data,\n statusCode: (_result$init = result.init) == null ? void 0 : _result$init.status,\n headers: (_result$init2 = result.init) != null && _result$init2.headers ? new Headers(result.init.headers) : undefined\n };\n }\n // Convert thrown data() to ErrorResponse instances\n return {\n type: ResultType.error,\n error: new ErrorResponseImpl(((_result$init3 = result.init) == null ? void 0 : _result$init3.status) || 500, undefined, result.data),\n statusCode: isRouteErrorResponse(result) ? result.status : undefined,\n headers: (_result$init4 = result.init) != null && _result$init4.headers ? new Headers(result.init.headers) : undefined\n };\n }\n return {\n type: ResultType.error,\n error: result,\n statusCode: isRouteErrorResponse(result) ? result.status : undefined\n };\n }\n if (isDeferredData(result)) {\n var _result$init5, _result$init6;\n return {\n type: ResultType.deferred,\n deferredData: result,\n statusCode: (_result$init5 = result.init) == null ? void 0 : _result$init5.status,\n headers: ((_result$init6 = result.init) == null ? void 0 : _result$init6.headers) && new Headers(result.init.headers)\n };\n }\n if (isDataWithResponseInit(result)) {\n var _result$init7, _result$init8;\n return {\n type: ResultType.data,\n data: result.data,\n statusCode: (_result$init7 = result.init) == null ? void 0 : _result$init7.status,\n headers: (_result$init8 = result.init) != null && _result$init8.headers ? new Headers(result.init.headers) : undefined\n };\n }\n return {\n type: ResultType.data,\n data: result\n };\n}\n// Support relative routing in internal redirects\nfunction normalizeRelativeRoutingRedirectResponse(response, request, routeId, matches, basename, v7_relativeSplatPath) {\n let location = response.headers.get(\"Location\");\n invariant(location, \"Redirects returned/thrown from loaders/actions must have a Location header\");\n if (!ABSOLUTE_URL_REGEX.test(location)) {\n let trimmedMatches = matches.slice(0, matches.findIndex(m => m.route.id === routeId) + 1);\n location = normalizeTo(new URL(request.url), trimmedMatches, basename, true, location, v7_relativeSplatPath);\n response.headers.set(\"Location\", location);\n }\n return response;\n}\nfunction normalizeRedirectLocation(location, currentUrl, basename, historyInstance) {\n // Match Chrome's behavior:\n // https://github.com/chromium/chromium/blob/216dbeb61db0c667e62082e5f5400a32d6983df3/content/public/common/url_utils.cc#L82\n let invalidProtocols = [\"about:\", \"blob:\", \"chrome:\", \"chrome-untrusted:\", \"content:\", \"data:\", \"devtools:\", \"file:\", \"filesystem:\",\n // eslint-disable-next-line no-script-url\n \"javascript:\"];\n if (ABSOLUTE_URL_REGEX.test(location)) {\n // Strip off the protocol+origin for same-origin + same-basename absolute redirects\n let normalizedLocation = location;\n let url = normalizedLocation.startsWith(\"//\") ? new URL(currentUrl.protocol + normalizedLocation) : new URL(normalizedLocation);\n if (invalidProtocols.includes(url.protocol)) {\n throw new Error(\"Invalid redirect location\");\n }\n let isSameBasename = stripBasename(url.pathname, basename) != null;\n if (url.origin === currentUrl.origin && isSameBasename) {\n return url.pathname + url.search + url.hash;\n }\n }\n try {\n let url = historyInstance.createURL(location);\n if (invalidProtocols.includes(url.protocol)) {\n throw new Error(\"Invalid redirect location\");\n }\n } catch (e) {}\n return location;\n}\n// Utility method for creating the Request instances for loaders/actions during\n// client-side navigations and fetches. During SSR we will always have a\n// Request instance from the static handler (query/queryRoute)\nfunction createClientSideRequest(history, location, signal, submission) {\n let url = history.createURL(stripHashFromPath(location)).toString();\n let init = {\n signal\n };\n if (submission && isMutationMethod(submission.formMethod)) {\n let {\n formMethod,\n formEncType\n } = submission;\n // Didn't think we needed this but it turns out unlike other methods, patch\n // won't be properly normalized to uppercase and results in a 405 error.\n // See: https://fetch.spec.whatwg.org/#concept-method\n init.method = formMethod.toUpperCase();\n if (formEncType === \"application/json\") {\n init.headers = new Headers({\n \"Content-Type\": formEncType\n });\n init.body = JSON.stringify(submission.json);\n } else if (formEncType === \"text/plain\") {\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n init.body = submission.text;\n } else if (formEncType === \"application/x-www-form-urlencoded\" && submission.formData) {\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n init.body = convertFormDataToSearchParams(submission.formData);\n } else {\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n init.body = submission.formData;\n }\n }\n return new Request(url, init);\n}\nfunction convertFormDataToSearchParams(formData) {\n let searchParams = new URLSearchParams();\n for (let [key, value] of formData.entries()) {\n // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#converting-an-entry-list-to-a-list-of-name-value-pairs\n searchParams.append(key, typeof value === \"string\" ? value : value.name);\n }\n return searchParams;\n}\nfunction convertSearchParamsToFormData(searchParams) {\n let formData = new FormData();\n for (let [key, value] of searchParams.entries()) {\n formData.append(key, value);\n }\n return formData;\n}\nfunction processRouteLoaderData(matches, results, pendingActionResult, activeDeferreds, skipLoaderErrorBubbling) {\n // Fill in loaderData/errors from our loaders\n let loaderData = {};\n let errors = null;\n let statusCode;\n let foundError = false;\n let loaderHeaders = {};\n let pendingError = pendingActionResult && isErrorResult(pendingActionResult[1]) ? pendingActionResult[1].error : undefined;\n // Process loader results into state.loaderData/state.errors\n matches.forEach(match => {\n if (!(match.route.id in results)) {\n return;\n }\n let id = match.route.id;\n let result = results[id];\n invariant(!isRedirectResult(result), \"Cannot handle redirect results in processLoaderData\");\n if (isErrorResult(result)) {\n let error = result.error;\n // If we have a pending action error, we report it at the highest-route\n // that throws a loader error, and then clear it out to indicate that\n // it was consumed\n if (pendingError !== undefined) {\n error = pendingError;\n pendingError = undefined;\n }\n errors = errors || {};\n if (skipLoaderErrorBubbling) {\n errors[id] = error;\n } else {\n // Look upwards from the matched route for the closest ancestor error\n // boundary, defaulting to the root match. Prefer higher error values\n // if lower errors bubble to the same boundary\n let boundaryMatch = findNearestBoundary(matches, id);\n if (errors[boundaryMatch.route.id] == null) {\n errors[boundaryMatch.route.id] = error;\n }\n }\n // Clear our any prior loaderData for the throwing route\n loaderData[id] = undefined;\n // Once we find our first (highest) error, we set the status code and\n // prevent deeper status codes from overriding\n if (!foundError) {\n foundError = true;\n statusCode = isRouteErrorResponse(result.error) ? result.error.status : 500;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n } else {\n if (isDeferredResult(result)) {\n activeDeferreds.set(id, result.deferredData);\n loaderData[id] = result.deferredData.data;\n // Error status codes always override success status codes, but if all\n // loaders are successful we take the deepest status code.\n if (result.statusCode != null && result.statusCode !== 200 && !foundError) {\n statusCode = result.statusCode;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n } else {\n loaderData[id] = result.data;\n // Error status codes always override success status codes, but if all\n // loaders are successful we take the deepest status code.\n if (result.statusCode && result.statusCode !== 200 && !foundError) {\n statusCode = result.statusCode;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n }\n }\n });\n // If we didn't consume the pending action error (i.e., all loaders\n // resolved), then consume it here. Also clear out any loaderData for the\n // throwing route\n if (pendingError !== undefined && pendingActionResult) {\n errors = {\n [pendingActionResult[0]]: pendingError\n };\n loaderData[pendingActionResult[0]] = undefined;\n }\n return {\n loaderData,\n errors,\n statusCode: statusCode || 200,\n loaderHeaders\n };\n}\nfunction processLoaderData(state, matches, results, pendingActionResult, revalidatingFetchers, fetcherResults, activeDeferreds) {\n let {\n loaderData,\n errors\n } = processRouteLoaderData(matches, results, pendingActionResult, activeDeferreds, false // This method is only called client side so we always want to bubble\n );\n // Process results from our revalidating fetchers\n revalidatingFetchers.forEach(rf => {\n let {\n key,\n match,\n controller\n } = rf;\n let result = fetcherResults[key];\n invariant(result, \"Did not find corresponding fetcher result\");\n // Process fetcher non-redirect errors\n if (controller && controller.signal.aborted) {\n // Nothing to do for aborted fetchers\n return;\n } else if (isErrorResult(result)) {\n let boundaryMatch = findNearestBoundary(state.matches, match == null ? void 0 : match.route.id);\n if (!(errors && errors[boundaryMatch.route.id])) {\n errors = _extends({}, errors, {\n [boundaryMatch.route.id]: result.error\n });\n }\n state.fetchers.delete(key);\n } else if (isRedirectResult(result)) {\n // Should never get here, redirects should get processed above, but we\n // keep this to type narrow to a success result in the else\n invariant(false, \"Unhandled fetcher revalidation redirect\");\n } else if (isDeferredResult(result)) {\n // Should never get here, deferred data should be awaited for fetchers\n // in resolveDeferredResults\n invariant(false, \"Unhandled fetcher deferred data\");\n } else {\n let doneFetcher = getDoneFetcher(result.data);\n state.fetchers.set(key, doneFetcher);\n }\n });\n return {\n loaderData,\n errors\n };\n}\nfunction mergeLoaderData(loaderData, newLoaderData, matches, errors) {\n let mergedLoaderData = _extends({}, newLoaderData);\n for (let match of matches) {\n let id = match.route.id;\n if (newLoaderData.hasOwnProperty(id)) {\n if (newLoaderData[id] !== undefined) {\n mergedLoaderData[id] = newLoaderData[id];\n }\n } else if (loaderData[id] !== undefined && match.route.loader) {\n // Preserve existing keys not included in newLoaderData and where a loader\n // wasn't removed by HMR\n mergedLoaderData[id] = loaderData[id];\n }\n if (errors && errors.hasOwnProperty(id)) {\n // Don't keep any loader data below the boundary\n break;\n }\n }\n return mergedLoaderData;\n}\nfunction getActionDataForCommit(pendingActionResult) {\n if (!pendingActionResult) {\n return {};\n }\n return isErrorResult(pendingActionResult[1]) ? {\n // Clear out prior actionData on errors\n actionData: {}\n } : {\n actionData: {\n [pendingActionResult[0]]: pendingActionResult[1].data\n }\n };\n}\n// Find the nearest error boundary, looking upwards from the leaf route (or the\n// route specified by routeId) for the closest ancestor error boundary,\n// defaulting to the root match\nfunction findNearestBoundary(matches, routeId) {\n let eligibleMatches = routeId ? matches.slice(0, matches.findIndex(m => m.route.id === routeId) + 1) : [...matches];\n return eligibleMatches.reverse().find(m => m.route.hasErrorBoundary === true) || matches[0];\n}\nfunction getShortCircuitMatches(routes) {\n // Prefer a root layout route if present, otherwise shim in a route object\n let route = routes.length === 1 ? routes[0] : routes.find(r => r.index || !r.path || r.path === \"/\") || {\n id: \"__shim-error-route__\"\n };\n return {\n matches: [{\n params: {},\n pathname: \"\",\n pathnameBase: \"\",\n route\n }],\n route\n };\n}\nfunction getInternalRouterError(status, _temp5) {\n let {\n pathname,\n routeId,\n method,\n type,\n message\n } = _temp5 === void 0 ? {} : _temp5;\n let statusText = \"Unknown Server Error\";\n let errorMessage = \"Unknown @remix-run/router error\";\n if (status === 400) {\n statusText = \"Bad Request\";\n if (method && pathname && routeId) {\n errorMessage = \"You made a \" + method + \" request to \\\"\" + pathname + \"\\\" but \" + (\"did not provide a `loader` for route \\\"\" + routeId + \"\\\", \") + \"so there is no way to handle the request.\";\n } else if (type === \"defer-action\") {\n errorMessage = \"defer() is not supported in actions\";\n } else if (type === \"invalid-body\") {\n errorMessage = \"Unable to encode submission body\";\n }\n } else if (status === 403) {\n statusText = \"Forbidden\";\n errorMessage = \"Route \\\"\" + routeId + \"\\\" does not match URL \\\"\" + pathname + \"\\\"\";\n } else if (status === 404) {\n statusText = \"Not Found\";\n errorMessage = \"No route matches URL \\\"\" + pathname + \"\\\"\";\n } else if (status === 405) {\n statusText = \"Method Not Allowed\";\n if (method && pathname && routeId) {\n errorMessage = \"You made a \" + method.toUpperCase() + \" request to \\\"\" + pathname + \"\\\" but \" + (\"did not provide an `action` for route \\\"\" + routeId + \"\\\", \") + \"so there is no way to handle the request.\";\n } else if (method) {\n errorMessage = \"Invalid request method \\\"\" + method.toUpperCase() + \"\\\"\";\n }\n }\n return new ErrorResponseImpl(status || 500, statusText, new Error(errorMessage), true);\n}\n// Find any returned redirect errors, starting from the lowest match\nfunction findRedirect(results) {\n let entries = Object.entries(results);\n for (let i = entries.length - 1; i >= 0; i--) {\n let [key, result] = entries[i];\n if (isRedirectResult(result)) {\n return {\n key,\n result\n };\n }\n }\n}\nfunction stripHashFromPath(path) {\n let parsedPath = typeof path === \"string\" ? parsePath(path) : path;\n return createPath(_extends({}, parsedPath, {\n hash: \"\"\n }));\n}\nfunction isHashChangeOnly(a, b) {\n if (a.pathname !== b.pathname || a.search !== b.search) {\n return false;\n }\n if (a.hash === \"\") {\n // /page -> /page#hash\n return b.hash !== \"\";\n } else if (a.hash === b.hash) {\n // /page#hash -> /page#hash\n return true;\n } else if (b.hash !== \"\") {\n // /page#hash -> /page#other\n return true;\n }\n // If the hash is removed the browser will re-perform a request to the server\n // /page#hash -> /page\n return false;\n}\nfunction isDataStrategyResult(result) {\n return result != null && typeof result === \"object\" && \"type\" in result && \"result\" in result && (result.type === ResultType.data || result.type === ResultType.error);\n}\nfunction isRedirectDataStrategyResultResult(result) {\n return isResponse(result.result) && redirectStatusCodes.has(result.result.status);\n}\nfunction isDeferredResult(result) {\n return result.type === ResultType.deferred;\n}\nfunction isErrorResult(result) {\n return result.type === ResultType.error;\n}\nfunction isRedirectResult(result) {\n return (result && result.type) === ResultType.redirect;\n}\nfunction isDataWithResponseInit(value) {\n return typeof value === \"object\" && value != null && \"type\" in value && \"data\" in value && \"init\" in value && value.type === \"DataWithResponseInit\";\n}\nfunction isDeferredData(value) {\n let deferred = value;\n return deferred && typeof deferred === \"object\" && typeof deferred.data === \"object\" && typeof deferred.subscribe === \"function\" && typeof deferred.cancel === \"function\" && typeof deferred.resolveData === \"function\";\n}\nfunction isResponse(value) {\n return value != null && typeof value.status === \"number\" && typeof value.statusText === \"string\" && typeof value.headers === \"object\" && typeof value.body !== \"undefined\";\n}\nfunction isRedirectResponse(result) {\n if (!isResponse(result)) {\n return false;\n }\n let status = result.status;\n let location = result.headers.get(\"Location\");\n return status >= 300 && status <= 399 && location != null;\n}\nfunction isValidMethod(method) {\n return validRequestMethods.has(method.toLowerCase());\n}\nfunction isMutationMethod(method) {\n return validMutationMethods.has(method.toLowerCase());\n}\nasync function resolveNavigationDeferredResults(matches, results, signal, currentMatches, currentLoaderData) {\n let entries = Object.entries(results);\n for (let index = 0; index < entries.length; index++) {\n let [routeId, result] = entries[index];\n let match = matches.find(m => (m == null ? void 0 : m.route.id) === routeId);\n // If we don't have a match, then we can have a deferred result to do\n // anything with. This is for revalidating fetchers where the route was\n // removed during HMR\n if (!match) {\n continue;\n }\n let currentMatch = currentMatches.find(m => m.route.id === match.route.id);\n let isRevalidatingLoader = currentMatch != null && !isNewRouteInstance(currentMatch, match) && (currentLoaderData && currentLoaderData[match.route.id]) !== undefined;\n if (isDeferredResult(result) && isRevalidatingLoader) {\n // Note: we do not have to touch activeDeferreds here since we race them\n // against the signal in resolveDeferredData and they'll get aborted\n // there if needed\n await resolveDeferredData(result, signal, false).then(result => {\n if (result) {\n results[routeId] = result;\n }\n });\n }\n }\n}\nasync function resolveFetcherDeferredResults(matches, results, revalidatingFetchers) {\n for (let index = 0; index < revalidatingFetchers.length; index++) {\n let {\n key,\n routeId,\n controller\n } = revalidatingFetchers[index];\n let result = results[key];\n let match = matches.find(m => (m == null ? void 0 : m.route.id) === routeId);\n // If we don't have a match, then we can have a deferred result to do\n // anything with. This is for revalidating fetchers where the route was\n // removed during HMR\n if (!match) {\n continue;\n }\n if (isDeferredResult(result)) {\n // Note: we do not have to touch activeDeferreds here since we race them\n // against the signal in resolveDeferredData and they'll get aborted\n // there if needed\n invariant(controller, \"Expected an AbortController for revalidating fetcher deferred result\");\n await resolveDeferredData(result, controller.signal, true).then(result => {\n if (result) {\n results[key] = result;\n }\n });\n }\n }\n}\nasync function resolveDeferredData(result, signal, unwrap) {\n if (unwrap === void 0) {\n unwrap = false;\n }\n let aborted = await result.deferredData.resolveData(signal);\n if (aborted) {\n return;\n }\n if (unwrap) {\n try {\n return {\n type: ResultType.data,\n data: result.deferredData.unwrappedData\n };\n } catch (e) {\n // Handle any TrackedPromise._error values encountered while unwrapping\n return {\n type: ResultType.error,\n error: e\n };\n }\n }\n return {\n type: ResultType.data,\n data: result.deferredData.data\n };\n}\nfunction hasNakedIndexQuery(search) {\n return new URLSearchParams(search).getAll(\"index\").some(v => v === \"\");\n}\nfunction getTargetMatch(matches, location) {\n let search = typeof location === \"string\" ? parsePath(location).search : location.search;\n if (matches[matches.length - 1].route.index && hasNakedIndexQuery(search || \"\")) {\n // Return the leaf index route when index is present\n return matches[matches.length - 1];\n }\n // Otherwise grab the deepest \"path contributing\" match (ignoring index and\n // pathless layout routes)\n let pathMatches = getPathContributingMatches(matches);\n return pathMatches[pathMatches.length - 1];\n}\nfunction getSubmissionFromNavigation(navigation) {\n let {\n formMethod,\n formAction,\n formEncType,\n text,\n formData,\n json\n } = navigation;\n if (!formMethod || !formAction || !formEncType) {\n return;\n }\n if (text != null) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData: undefined,\n json: undefined,\n text\n };\n } else if (formData != null) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData,\n json: undefined,\n text: undefined\n };\n } else if (json !== undefined) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData: undefined,\n json,\n text: undefined\n };\n }\n}\nfunction getLoadingNavigation(location, submission) {\n if (submission) {\n let navigation = {\n state: \"loading\",\n location,\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text\n };\n return navigation;\n } else {\n let navigation = {\n state: \"loading\",\n location,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined\n };\n return navigation;\n }\n}\nfunction getSubmittingNavigation(location, submission) {\n let navigation = {\n state: \"submitting\",\n location,\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text\n };\n return navigation;\n}\nfunction getLoadingFetcher(submission, data) {\n if (submission) {\n let fetcher = {\n state: \"loading\",\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n data\n };\n return fetcher;\n } else {\n let fetcher = {\n state: \"loading\",\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n data\n };\n return fetcher;\n }\n}\nfunction getSubmittingFetcher(submission, existingFetcher) {\n let fetcher = {\n state: \"submitting\",\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n data: existingFetcher ? existingFetcher.data : undefined\n };\n return fetcher;\n}\nfunction getDoneFetcher(data) {\n let fetcher = {\n state: \"idle\",\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n data\n };\n return fetcher;\n}\nfunction restoreAppliedTransitions(_window, transitions) {\n try {\n let sessionPositions = _window.sessionStorage.getItem(TRANSITIONS_STORAGE_KEY);\n if (sessionPositions) {\n let json = JSON.parse(sessionPositions);\n for (let [k, v] of Object.entries(json || {})) {\n if (v && Array.isArray(v)) {\n transitions.set(k, new Set(v || []));\n }\n }\n }\n } catch (e) {\n // no-op, use default empty object\n }\n}\nfunction persistAppliedTransitions(_window, transitions) {\n if (transitions.size > 0) {\n let json = {};\n for (let [k, v] of transitions) {\n json[k] = [...v];\n }\n try {\n _window.sessionStorage.setItem(TRANSITIONS_STORAGE_KEY, JSON.stringify(json));\n } catch (error) {\n warning(false, \"Failed to save applied view transitions in sessionStorage (\" + error + \").\");\n }\n }\n}\n//#endregion\n\nexport { AbortedDeferredError, Action, IDLE_BLOCKER, IDLE_FETCHER, IDLE_NAVIGATION, UNSAFE_DEFERRED_SYMBOL, DeferredData as UNSAFE_DeferredData, ErrorResponseImpl as UNSAFE_ErrorResponseImpl, convertRouteMatchToUiMatch as UNSAFE_convertRouteMatchToUiMatch, convertRoutesToDataRoutes as UNSAFE_convertRoutesToDataRoutes, decodePath as UNSAFE_decodePath, getResolveToMatches as UNSAFE_getResolveToMatches, invariant as UNSAFE_invariant, warning as UNSAFE_warning, createBrowserHistory, createHashHistory, createMemoryHistory, createPath, createRouter, createStaticHandler, data, defer, generatePath, getStaticContextFromError, getToPathname, isDataWithResponseInit, isDeferredData, isRouteErrorResponse, joinPaths, json, matchPath, matchRoutes, normalizePathname, parsePath, redirect, redirectDocument, replace, resolvePath, resolveTo, stripBasename };\n//# sourceMappingURL=router.js.map\n","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isUnsafeProperty(key) {\n return key === '__proto__';\n}\n\nexports.isUnsafeProperty = isUnsafeProperty;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isDeepKey(key) {\n switch (typeof key) {\n case 'number':\n case 'symbol': {\n return false;\n }\n case 'string': {\n return key.includes('.') || key.includes('[') || key.includes(']');\n }\n }\n}\n\nexports.isDeepKey = isDeepKey;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction toKey(value) {\n if (typeof value === 'string' || typeof value === 'symbol') {\n return value;\n }\n if (Object.is(value?.valueOf?.(), -0)) {\n return '-0';\n }\n return String(value);\n}\n\nexports.toKey = toKey;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction toString(value) {\n if (value == null) {\n return '';\n }\n if (typeof value === 'string') {\n return value;\n }\n if (Array.isArray(value)) {\n return value.map(toString).join(',');\n }\n const result = String(value);\n if (result === '0' && Object.is(Number(value), -0)) {\n return '-0';\n }\n return result;\n}\n\nexports.toString = toString;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst toString = require('./toString.js');\nconst toKey = require('../_internal/toKey.js');\n\nfunction toPath(deepKey) {\n if (Array.isArray(deepKey)) {\n return deepKey.map(toKey.toKey);\n }\n if (typeof deepKey === 'symbol') {\n return [deepKey];\n }\n deepKey = toString.toString(deepKey);\n const result = [];\n const length = deepKey.length;\n if (length === 0) {\n return result;\n }\n let index = 0;\n let key = '';\n let quoteChar = '';\n let bracket = false;\n if (deepKey.charCodeAt(0) === 46) {\n result.push('');\n index++;\n }\n while (index < length) {\n const char = deepKey[index];\n if (quoteChar) {\n if (char === '\\\\' && index + 1 < length) {\n index++;\n key += deepKey[index];\n }\n else if (char === quoteChar) {\n quoteChar = '';\n }\n else {\n key += char;\n }\n }\n else if (bracket) {\n if (char === '\"' || char === \"'\") {\n quoteChar = char;\n }\n else if (char === ']') {\n bracket = false;\n result.push(key);\n key = '';\n }\n else {\n key += char;\n }\n }\n else {\n if (char === '[') {\n bracket = true;\n if (key) {\n result.push(key);\n key = '';\n }\n }\n else if (char === '.') {\n if (key) {\n result.push(key);\n key = '';\n }\n }\n else {\n key += char;\n }\n }\n index++;\n }\n if (key) {\n result.push(key);\n }\n return result;\n}\n\nexports.toPath = toPath;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isUnsafeProperty = require('../../_internal/isUnsafeProperty.js');\nconst isDeepKey = require('../_internal/isDeepKey.js');\nconst toKey = require('../_internal/toKey.js');\nconst toPath = require('../util/toPath.js');\n\nfunction get(object, path, defaultValue) {\n if (object == null) {\n return defaultValue;\n }\n switch (typeof path) {\n case 'string': {\n if (isUnsafeProperty.isUnsafeProperty(path)) {\n return defaultValue;\n }\n const result = object[path];\n if (result === undefined) {\n if (isDeepKey.isDeepKey(path)) {\n return get(object, toPath.toPath(path), defaultValue);\n }\n else {\n return defaultValue;\n }\n }\n return result;\n }\n case 'number':\n case 'symbol': {\n if (typeof path === 'number') {\n path = toKey.toKey(path);\n }\n const result = object[path];\n if (result === undefined) {\n return defaultValue;\n }\n return result;\n }\n default: {\n if (Array.isArray(path)) {\n return getWithPath(object, path, defaultValue);\n }\n if (Object.is(path?.valueOf(), -0)) {\n path = '-0';\n }\n else {\n path = String(path);\n }\n if (isUnsafeProperty.isUnsafeProperty(path)) {\n return defaultValue;\n }\n const result = object[path];\n if (result === undefined) {\n return defaultValue;\n }\n return result;\n }\n }\n}\nfunction getWithPath(object, path, defaultValue) {\n if (path.length === 0) {\n return defaultValue;\n }\n let current = object;\n for (let index = 0; index < path.length; index++) {\n if (current == null) {\n return defaultValue;\n }\n if (isUnsafeProperty.isUnsafeProperty(path[index])) {\n return defaultValue;\n }\n current = current[path[index]];\n }\n if (current === undefined) {\n return defaultValue;\n }\n return current;\n}\n\nexports.get = get;\n","module.exports = require('../dist/compat/object/get.js').get;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction uniqBy(arr, mapper) {\n const map = new Map();\n for (let i = 0; i < arr.length; i++) {\n const item = arr[i];\n const key = mapper(item, i, arr);\n if (!map.has(key)) {\n map.set(key, item);\n }\n }\n return Array.from(map.values());\n}\n\nexports.uniqBy = uniqBy;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction ary(func, n) {\n return function (...args) {\n return func.apply(this, args.slice(0, n));\n };\n}\n\nexports.ary = ary;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction identity(x) {\n return x;\n}\n\nexports.identity = identity;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isLength(value) {\n return Number.isSafeInteger(value) && value >= 0;\n}\n\nexports.isLength = isLength;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isLength = require('../../predicate/isLength.js');\n\nfunction isArrayLike(value) {\n return value != null && typeof value !== 'function' && isLength.isLength(value.length);\n}\n\nexports.isArrayLike = isArrayLike;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isObjectLike(value) {\n return typeof value === 'object' && value !== null;\n}\n\nexports.isObjectLike = isObjectLike;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isArrayLike = require('./isArrayLike.js');\nconst isObjectLike = require('./isObjectLike.js');\n\nfunction isArrayLikeObject(value) {\n return isObjectLike.isObjectLike(value) && isArrayLike.isArrayLike(value);\n}\n\nexports.isArrayLikeObject = isArrayLikeObject;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst get = require('./get.js');\n\nfunction property(path) {\n return function (object) {\n return get.get(object, path);\n };\n}\n\nexports.property = property;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isObject(value) {\n return value !== null && (typeof value === 'object' || typeof value === 'function');\n}\n\nexports.isObject = isObject;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isPrimitive(value) {\n return value == null || (typeof value !== 'object' && typeof value !== 'function');\n}\n\nexports.isPrimitive = isPrimitive;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isEqualsSameValueZero(value, other) {\n return value === other || (Number.isNaN(value) && Number.isNaN(other));\n}\n\nexports.isEqualsSameValueZero = isEqualsSameValueZero;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isObject = require('./isObject.js');\nconst isPrimitive = require('../../predicate/isPrimitive.js');\nconst isEqualsSameValueZero = require('../../_internal/isEqualsSameValueZero.js');\n\nfunction isMatchWith(target, source, compare) {\n if (typeof compare !== 'function') {\n return isMatchWith(target, source, () => undefined);\n }\n return isMatchWithInternal(target, source, function doesMatch(objValue, srcValue, key, object, source, stack) {\n const isEqual = compare(objValue, srcValue, key, object, source, stack);\n if (isEqual !== undefined) {\n return Boolean(isEqual);\n }\n return isMatchWithInternal(objValue, srcValue, doesMatch, stack);\n }, new Map());\n}\nfunction isMatchWithInternal(target, source, compare, stack) {\n if (source === target) {\n return true;\n }\n switch (typeof source) {\n case 'object': {\n return isObjectMatch(target, source, compare, stack);\n }\n case 'function': {\n const sourceKeys = Object.keys(source);\n if (sourceKeys.length > 0) {\n return isMatchWithInternal(target, { ...source }, compare, stack);\n }\n return isEqualsSameValueZero.isEqualsSameValueZero(target, source);\n }\n default: {\n if (!isObject.isObject(target)) {\n return isEqualsSameValueZero.isEqualsSameValueZero(target, source);\n }\n if (typeof source === 'string') {\n return source === '';\n }\n return true;\n }\n }\n}\nfunction isObjectMatch(target, source, compare, stack) {\n if (source == null) {\n return true;\n }\n if (Array.isArray(source)) {\n return isArrayMatch(target, source, compare, stack);\n }\n if (source instanceof Map) {\n return isMapMatch(target, source, compare, stack);\n }\n if (source instanceof Set) {\n return isSetMatch(target, source, compare, stack);\n }\n const keys = Object.keys(source);\n if (target == null || isPrimitive.isPrimitive(target)) {\n return keys.length === 0;\n }\n if (keys.length === 0) {\n return true;\n }\n if (stack?.has(source)) {\n return stack.get(source) === target;\n }\n stack?.set(source, target);\n try {\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n if (!isPrimitive.isPrimitive(target) && !(key in target)) {\n return false;\n }\n if (source[key] === undefined && target[key] !== undefined) {\n return false;\n }\n if (source[key] === null && target[key] !== null) {\n return false;\n }\n const isEqual = compare(target[key], source[key], key, target, source, stack);\n if (!isEqual) {\n return false;\n }\n }\n return true;\n }\n finally {\n stack?.delete(source);\n }\n}\nfunction isMapMatch(target, source, compare, stack) {\n if (source.size === 0) {\n return true;\n }\n if (!(target instanceof Map)) {\n return false;\n }\n for (const [key, sourceValue] of source.entries()) {\n const targetValue = target.get(key);\n const isEqual = compare(targetValue, sourceValue, key, target, source, stack);\n if (isEqual === false) {\n return false;\n }\n }\n return true;\n}\nfunction isArrayMatch(target, source, compare, stack) {\n if (source.length === 0) {\n return true;\n }\n if (!Array.isArray(target)) {\n return false;\n }\n const countedIndex = new Set();\n for (let i = 0; i < source.length; i++) {\n const sourceItem = source[i];\n let found = false;\n for (let j = 0; j < target.length; j++) {\n if (countedIndex.has(j)) {\n continue;\n }\n const targetItem = target[j];\n let matches = false;\n const isEqual = compare(targetItem, sourceItem, i, target, source, stack);\n if (isEqual) {\n matches = true;\n }\n if (matches) {\n countedIndex.add(j);\n found = true;\n break;\n }\n }\n if (!found) {\n return false;\n }\n }\n return true;\n}\nfunction isSetMatch(target, source, compare, stack) {\n if (source.size === 0) {\n return true;\n }\n if (!(target instanceof Set)) {\n return false;\n }\n return isArrayMatch([...target], [...source], compare, stack);\n}\n\nexports.isMatchWith = isMatchWith;\nexports.isSetMatch = isSetMatch;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isMatchWith = require('./isMatchWith.js');\n\nfunction isMatch(target, source) {\n return isMatchWith.isMatchWith(target, source, () => undefined);\n}\n\nexports.isMatch = isMatch;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction getSymbols(object) {\n return Object.getOwnPropertySymbols(object).filter(symbol => Object.prototype.propertyIsEnumerable.call(object, symbol));\n}\n\nexports.getSymbols = getSymbols;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction getTag(value) {\n if (value == null) {\n return value === undefined ? '[object Undefined]' : '[object Null]';\n }\n return Object.prototype.toString.call(value);\n}\n\nexports.getTag = getTag;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst regexpTag = '[object RegExp]';\nconst stringTag = '[object String]';\nconst numberTag = '[object Number]';\nconst booleanTag = '[object Boolean]';\nconst argumentsTag = '[object Arguments]';\nconst symbolTag = '[object Symbol]';\nconst dateTag = '[object Date]';\nconst mapTag = '[object Map]';\nconst setTag = '[object Set]';\nconst arrayTag = '[object Array]';\nconst functionTag = '[object Function]';\nconst arrayBufferTag = '[object ArrayBuffer]';\nconst objectTag = '[object Object]';\nconst errorTag = '[object Error]';\nconst dataViewTag = '[object DataView]';\nconst uint8ArrayTag = '[object Uint8Array]';\nconst uint8ClampedArrayTag = '[object Uint8ClampedArray]';\nconst uint16ArrayTag = '[object Uint16Array]';\nconst uint32ArrayTag = '[object Uint32Array]';\nconst bigUint64ArrayTag = '[object BigUint64Array]';\nconst int8ArrayTag = '[object Int8Array]';\nconst int16ArrayTag = '[object Int16Array]';\nconst int32ArrayTag = '[object Int32Array]';\nconst bigInt64ArrayTag = '[object BigInt64Array]';\nconst float32ArrayTag = '[object Float32Array]';\nconst float64ArrayTag = '[object Float64Array]';\n\nexports.argumentsTag = argumentsTag;\nexports.arrayBufferTag = arrayBufferTag;\nexports.arrayTag = arrayTag;\nexports.bigInt64ArrayTag = bigInt64ArrayTag;\nexports.bigUint64ArrayTag = bigUint64ArrayTag;\nexports.booleanTag = booleanTag;\nexports.dataViewTag = dataViewTag;\nexports.dateTag = dateTag;\nexports.errorTag = errorTag;\nexports.float32ArrayTag = float32ArrayTag;\nexports.float64ArrayTag = float64ArrayTag;\nexports.functionTag = functionTag;\nexports.int16ArrayTag = int16ArrayTag;\nexports.int32ArrayTag = int32ArrayTag;\nexports.int8ArrayTag = int8ArrayTag;\nexports.mapTag = mapTag;\nexports.numberTag = numberTag;\nexports.objectTag = objectTag;\nexports.regexpTag = regexpTag;\nexports.setTag = setTag;\nexports.stringTag = stringTag;\nexports.symbolTag = symbolTag;\nexports.uint16ArrayTag = uint16ArrayTag;\nexports.uint32ArrayTag = uint32ArrayTag;\nexports.uint8ArrayTag = uint8ArrayTag;\nexports.uint8ClampedArrayTag = uint8ClampedArrayTag;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst globalThis_ = (typeof globalThis === 'object' && globalThis) ||\n (typeof window === 'object' && window) ||\n (typeof self === 'object' && self) ||\n (typeof global === 'object' && global) ||\n (function () {\n return this;\n })() ||\n Function('return this')();\n\nexports.globalThis = globalThis_;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst globalThis = require('../_internal/globalThis.js');\n\nfunction isBuffer(x) {\n return typeof globalThis.globalThis.Buffer !== 'undefined' && globalThis.globalThis.Buffer.isBuffer(x);\n}\n\nexports.isBuffer = isBuffer;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isTypedArray(x) {\n return ArrayBuffer.isView(x) && !(x instanceof DataView);\n}\n\nexports.isTypedArray = isTypedArray;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst getSymbols = require('../compat/_internal/getSymbols.js');\nconst getTag = require('../compat/_internal/getTag.js');\nconst tags = require('../compat/_internal/tags.js');\nconst isBuffer = require('../predicate/isBuffer.js');\nconst isPrimitive = require('../predicate/isPrimitive.js');\nconst isTypedArray = require('../predicate/isTypedArray.js');\n\nfunction cloneDeepWith(obj, cloneValue) {\n return cloneDeepWithImpl(obj, undefined, obj, new Map(), cloneValue);\n}\nfunction cloneDeepWithImpl(valueToClone, keyToClone, objectToClone, stack = new Map(), cloneValue = undefined) {\n const cloned = cloneValue?.(valueToClone, keyToClone, objectToClone, stack);\n if (cloned !== undefined) {\n return cloned;\n }\n if (isPrimitive.isPrimitive(valueToClone)) {\n return valueToClone;\n }\n if (stack.has(valueToClone)) {\n return stack.get(valueToClone);\n }\n if (Array.isArray(valueToClone)) {\n const result = new Array(valueToClone.length);\n stack.set(valueToClone, result);\n for (let i = 0; i < valueToClone.length; i++) {\n result[i] = cloneDeepWithImpl(valueToClone[i], i, objectToClone, stack, cloneValue);\n }\n if (Object.hasOwn(valueToClone, 'index')) {\n result.index = valueToClone.index;\n }\n if (Object.hasOwn(valueToClone, 'input')) {\n result.input = valueToClone.input;\n }\n return result;\n }\n if (valueToClone instanceof Date) {\n return new Date(valueToClone.getTime());\n }\n if (valueToClone instanceof RegExp) {\n const result = new RegExp(valueToClone.source, valueToClone.flags);\n result.lastIndex = valueToClone.lastIndex;\n return result;\n }\n if (valueToClone instanceof Map) {\n const result = new Map();\n stack.set(valueToClone, result);\n for (const [key, value] of valueToClone) {\n result.set(key, cloneDeepWithImpl(value, key, objectToClone, stack, cloneValue));\n }\n return result;\n }\n if (valueToClone instanceof Set) {\n const result = new Set();\n stack.set(valueToClone, result);\n for (const value of valueToClone) {\n result.add(cloneDeepWithImpl(value, undefined, objectToClone, stack, cloneValue));\n }\n return result;\n }\n if (isBuffer.isBuffer(valueToClone)) {\n return valueToClone.subarray();\n }\n if (isTypedArray.isTypedArray(valueToClone)) {\n const result = new (Object.getPrototypeOf(valueToClone).constructor)(valueToClone.length);\n stack.set(valueToClone, result);\n for (let i = 0; i < valueToClone.length; i++) {\n result[i] = cloneDeepWithImpl(valueToClone[i], i, objectToClone, stack, cloneValue);\n }\n return result;\n }\n if (valueToClone instanceof ArrayBuffer ||\n (typeof SharedArrayBuffer !== 'undefined' && valueToClone instanceof SharedArrayBuffer)) {\n return valueToClone.slice(0);\n }\n if (valueToClone instanceof DataView) {\n const result = new DataView(valueToClone.buffer.slice(0), valueToClone.byteOffset, valueToClone.byteLength);\n stack.set(valueToClone, result);\n copyProperties(result, valueToClone, objectToClone, stack, cloneValue);\n return result;\n }\n if (typeof File !== 'undefined' && valueToClone instanceof File) {\n const result = new File([valueToClone], valueToClone.name, {\n type: valueToClone.type,\n });\n stack.set(valueToClone, result);\n copyProperties(result, valueToClone, objectToClone, stack, cloneValue);\n return result;\n }\n if (typeof Blob !== 'undefined' && valueToClone instanceof Blob) {\n const result = new Blob([valueToClone], { type: valueToClone.type });\n stack.set(valueToClone, result);\n copyProperties(result, valueToClone, objectToClone, stack, cloneValue);\n return result;\n }\n if (valueToClone instanceof Error) {\n const result = structuredClone(valueToClone);\n stack.set(valueToClone, result);\n result.message = valueToClone.message;\n result.name = valueToClone.name;\n result.stack = valueToClone.stack;\n result.cause = valueToClone.cause;\n result.constructor = valueToClone.constructor;\n copyProperties(result, valueToClone, objectToClone, stack, cloneValue);\n return result;\n }\n if (valueToClone instanceof Boolean) {\n const result = new Boolean(valueToClone.valueOf());\n stack.set(valueToClone, result);\n copyProperties(result, valueToClone, objectToClone, stack, cloneValue);\n return result;\n }\n if (valueToClone instanceof Number) {\n const result = new Number(valueToClone.valueOf());\n stack.set(valueToClone, result);\n copyProperties(result, valueToClone, objectToClone, stack, cloneValue);\n return result;\n }\n if (valueToClone instanceof String) {\n const result = new String(valueToClone.valueOf());\n stack.set(valueToClone, result);\n copyProperties(result, valueToClone, objectToClone, stack, cloneValue);\n return result;\n }\n if (typeof valueToClone === 'object' && isCloneableObject(valueToClone)) {\n const result = Object.create(Object.getPrototypeOf(valueToClone));\n stack.set(valueToClone, result);\n copyProperties(result, valueToClone, objectToClone, stack, cloneValue);\n return result;\n }\n return valueToClone;\n}\nfunction copyProperties(target, source, objectToClone = target, stack, cloneValue) {\n const keys = [...Object.keys(source), ...getSymbols.getSymbols(source)];\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n const descriptor = Object.getOwnPropertyDescriptor(target, key);\n if (descriptor == null || descriptor.writable) {\n target[key] = cloneDeepWithImpl(source[key], key, objectToClone, stack, cloneValue);\n }\n }\n}\nfunction isCloneableObject(object) {\n switch (getTag.getTag(object)) {\n case tags.argumentsTag:\n case tags.arrayTag:\n case tags.arrayBufferTag:\n case tags.dataViewTag:\n case tags.booleanTag:\n case tags.dateTag:\n case tags.float32ArrayTag:\n case tags.float64ArrayTag:\n case tags.int8ArrayTag:\n case tags.int16ArrayTag:\n case tags.int32ArrayTag:\n case tags.mapTag:\n case tags.numberTag:\n case tags.objectTag:\n case tags.regexpTag:\n case tags.setTag:\n case tags.stringTag:\n case tags.symbolTag:\n case tags.uint8ArrayTag:\n case tags.uint8ClampedArrayTag:\n case tags.uint16ArrayTag:\n case tags.uint32ArrayTag: {\n return true;\n }\n default: {\n return false;\n }\n }\n}\n\nexports.cloneDeepWith = cloneDeepWith;\nexports.cloneDeepWithImpl = cloneDeepWithImpl;\nexports.copyProperties = copyProperties;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst cloneDeepWith = require('./cloneDeepWith.js');\n\nfunction cloneDeep(obj) {\n return cloneDeepWith.cloneDeepWithImpl(obj, undefined, obj, new Map(), undefined);\n}\n\nexports.cloneDeep = cloneDeep;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isMatch = require('./isMatch.js');\nconst cloneDeep = require('../../object/cloneDeep.js');\n\nfunction matches(source) {\n source = cloneDeep.cloneDeep(source);\n return (target) => {\n return isMatch.isMatch(target, source);\n };\n}\n\nexports.matches = matches;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst cloneDeepWith$1 = require('../../object/cloneDeepWith.js');\nconst getTag = require('../_internal/getTag.js');\nconst tags = require('../_internal/tags.js');\n\nfunction cloneDeepWith(obj, customizer) {\n return cloneDeepWith$1.cloneDeepWith(obj, (value, key, object, stack) => {\n const cloned = customizer?.(value, key, object, stack);\n if (cloned !== undefined) {\n return cloned;\n }\n if (typeof obj !== 'object') {\n return undefined;\n }\n if (getTag.getTag(obj) === tags.objectTag && typeof obj.constructor !== 'function') {\n const result = {};\n stack.set(obj, result);\n cloneDeepWith$1.copyProperties(result, obj, object, stack);\n return result;\n }\n switch (Object.prototype.toString.call(obj)) {\n case tags.numberTag:\n case tags.stringTag:\n case tags.booleanTag: {\n const result = new obj.constructor(obj?.valueOf());\n cloneDeepWith$1.copyProperties(result, obj);\n return result;\n }\n case tags.argumentsTag: {\n const result = {};\n cloneDeepWith$1.copyProperties(result, obj);\n result.length = obj.length;\n result[Symbol.iterator] = obj[Symbol.iterator];\n return result;\n }\n default: {\n return undefined;\n }\n }\n });\n}\n\nexports.cloneDeepWith = cloneDeepWith;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst cloneDeepWith = require('./cloneDeepWith.js');\n\nfunction cloneDeep(obj) {\n return cloneDeepWith.cloneDeepWith(obj);\n}\n\nexports.cloneDeep = cloneDeep;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst IS_UNSIGNED_INTEGER = /^(?:0|[1-9]\\d*)$/;\nfunction isIndex(value, length = Number.MAX_SAFE_INTEGER) {\n switch (typeof value) {\n case 'number': {\n return Number.isInteger(value) && value >= 0 && value < length;\n }\n case 'symbol': {\n return false;\n }\n case 'string': {\n return IS_UNSIGNED_INTEGER.test(value);\n }\n }\n}\n\nexports.isIndex = isIndex;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst getTag = require('../_internal/getTag.js');\n\nfunction isArguments(value) {\n return value !== null && typeof value === 'object' && getTag.getTag(value) === '[object Arguments]';\n}\n\nexports.isArguments = isArguments;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isDeepKey = require('../_internal/isDeepKey.js');\nconst isIndex = require('../_internal/isIndex.js');\nconst isArguments = require('../predicate/isArguments.js');\nconst toPath = require('../util/toPath.js');\n\nfunction has(object, path) {\n let resolvedPath;\n if (Array.isArray(path)) {\n resolvedPath = path;\n }\n else if (typeof path === 'string' && isDeepKey.isDeepKey(path) && object?.[path] == null) {\n resolvedPath = toPath.toPath(path);\n }\n else {\n resolvedPath = [path];\n }\n if (resolvedPath.length === 0) {\n return false;\n }\n let current = object;\n for (let i = 0; i < resolvedPath.length; i++) {\n const key = resolvedPath[i];\n if (current == null || !Object.hasOwn(current, key)) {\n const isSparseIndex = (Array.isArray(current) || isArguments.isArguments(current)) && isIndex.isIndex(key) && key < current.length;\n if (!isSparseIndex) {\n return false;\n }\n }\n current = current[key];\n }\n return true;\n}\n\nexports.has = has;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isMatch = require('./isMatch.js');\nconst toKey = require('../_internal/toKey.js');\nconst cloneDeep = require('../object/cloneDeep.js');\nconst get = require('../object/get.js');\nconst has = require('../object/has.js');\n\nfunction matchesProperty(property, source) {\n switch (typeof property) {\n case 'object': {\n if (Object.is(property?.valueOf(), -0)) {\n property = '-0';\n }\n break;\n }\n case 'number': {\n property = toKey.toKey(property);\n break;\n }\n }\n source = cloneDeep.cloneDeep(source);\n return function (target) {\n const result = get.get(target, property);\n if (result === undefined) {\n return has.has(target, property);\n }\n if (source === undefined) {\n return result === undefined;\n }\n return isMatch.isMatch(result, source);\n };\n}\n\nexports.matchesProperty = matchesProperty;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst identity = require('../../function/identity.js');\nconst property = require('../object/property.js');\nconst matches = require('../predicate/matches.js');\nconst matchesProperty = require('../predicate/matchesProperty.js');\n\nfunction iteratee(value) {\n if (value == null) {\n return identity.identity;\n }\n switch (typeof value) {\n case 'function': {\n return value;\n }\n case 'object': {\n if (Array.isArray(value) && value.length === 2) {\n return matchesProperty.matchesProperty(value[0], value[1]);\n }\n return matches.matches(value);\n }\n case 'string':\n case 'symbol':\n case 'number': {\n return property.property(value);\n }\n }\n}\n\nexports.iteratee = iteratee;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst uniqBy$1 = require('../../array/uniqBy.js');\nconst ary = require('../../function/ary.js');\nconst identity = require('../../function/identity.js');\nconst isArrayLikeObject = require('../predicate/isArrayLikeObject.js');\nconst iteratee = require('../util/iteratee.js');\n\nfunction uniqBy(array, iteratee$1 = identity.identity) {\n if (!isArrayLikeObject.isArrayLikeObject(array)) {\n return [];\n }\n return uniqBy$1.uniqBy(Array.from(array), ary.ary(iteratee.iteratee(iteratee$1), 1));\n}\n\nexports.uniqBy = uniqBy;\n","module.exports = require('../dist/compat/array/uniqBy.js').uniqBy;\n","/**\n * @license React\n * use-sync-external-store-shim.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar React = require(\"react\");\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useState = React.useState,\n useEffect = React.useEffect,\n useLayoutEffect = React.useLayoutEffect,\n useDebugValue = React.useDebugValue;\nfunction useSyncExternalStore$2(subscribe, getSnapshot) {\n var value = getSnapshot(),\n _useState = useState({ inst: { value: value, getSnapshot: getSnapshot } }),\n inst = _useState[0].inst,\n forceUpdate = _useState[1];\n useLayoutEffect(\n function () {\n inst.value = value;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n },\n [subscribe, value, getSnapshot]\n );\n useEffect(\n function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n return subscribe(function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n });\n },\n [subscribe]\n );\n useDebugValue(value);\n return value;\n}\nfunction checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n}\nfunction useSyncExternalStore$1(subscribe, getSnapshot) {\n return getSnapshot();\n}\nvar shim =\n \"undefined\" === typeof window ||\n \"undefined\" === typeof window.document ||\n \"undefined\" === typeof window.document.createElement\n ? useSyncExternalStore$1\n : useSyncExternalStore$2;\nexports.useSyncExternalStore =\n void 0 !== React.useSyncExternalStore ? React.useSyncExternalStore : shim;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.production.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.development.js');\n}\n","/**\n * @license React\n * use-sync-external-store-shim/with-selector.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar React = require(\"react\"),\n shim = require(\"use-sync-external-store/shim\");\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useSyncExternalStore = shim.useSyncExternalStore,\n useRef = React.useRef,\n useEffect = React.useEffect,\n useMemo = React.useMemo,\n useDebugValue = React.useDebugValue;\nexports.useSyncExternalStoreWithSelector = function (\n subscribe,\n getSnapshot,\n getServerSnapshot,\n selector,\n isEqual\n) {\n var instRef = useRef(null);\n if (null === instRef.current) {\n var inst = { hasValue: !1, value: null };\n instRef.current = inst;\n } else inst = instRef.current;\n instRef = useMemo(\n function () {\n function memoizedSelector(nextSnapshot) {\n if (!hasMemo) {\n hasMemo = !0;\n memoizedSnapshot = nextSnapshot;\n nextSnapshot = selector(nextSnapshot);\n if (void 0 !== isEqual && inst.hasValue) {\n var currentSelection = inst.value;\n if (isEqual(currentSelection, nextSnapshot))\n return (memoizedSelection = currentSelection);\n }\n return (memoizedSelection = nextSnapshot);\n }\n currentSelection = memoizedSelection;\n if (objectIs(memoizedSnapshot, nextSnapshot)) return currentSelection;\n var nextSelection = selector(nextSnapshot);\n if (void 0 !== isEqual && isEqual(currentSelection, nextSelection))\n return (memoizedSnapshot = nextSnapshot), currentSelection;\n memoizedSnapshot = nextSnapshot;\n return (memoizedSelection = nextSelection);\n }\n var hasMemo = !1,\n memoizedSnapshot,\n memoizedSelection,\n maybeGetServerSnapshot =\n void 0 === getServerSnapshot ? null : getServerSnapshot;\n return [\n function () {\n return memoizedSelector(getSnapshot());\n },\n null === maybeGetServerSnapshot\n ? void 0\n : function () {\n return memoizedSelector(maybeGetServerSnapshot());\n }\n ];\n },\n [getSnapshot, getServerSnapshot, selector, isEqual]\n );\n var value = useSyncExternalStore(subscribe, instRef[0], instRef[1]);\n useEffect(\n function () {\n inst.hasValue = !0;\n inst.value = value;\n },\n [value]\n );\n useDebugValue(value);\n return value;\n};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.production.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.development.js');\n}\n","// src/devModeChecks/identityFunctionCheck.ts\nvar runIdentityFunctionCheck = (resultFunc, inputSelectorsResults, outputSelectorResult) => {\n if (inputSelectorsResults.length === 1 && inputSelectorsResults[0] === outputSelectorResult) {\n let isInputSameAsOutput = false;\n try {\n const emptyObject = {};\n if (resultFunc(emptyObject) === emptyObject)\n isInputSameAsOutput = true;\n } catch {\n }\n if (isInputSameAsOutput) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"The result function returned its own inputs without modification. e.g\\n`createSelector([state => state.todos], todos => todos)`\\nThis could lead to inefficient memoization and unnecessary re-renders.\\nEnsure transformation logic is in the result function, and extraction logic is in the input selectors.\",\n { stack }\n );\n }\n }\n};\n\n// src/devModeChecks/inputStabilityCheck.ts\nvar runInputStabilityCheck = (inputSelectorResultsObject, options, inputSelectorArgs) => {\n const { memoize, memoizeOptions } = options;\n const { inputSelectorResults, inputSelectorResultsCopy } = inputSelectorResultsObject;\n const createAnEmptyObject = memoize(() => ({}), ...memoizeOptions);\n const areInputSelectorResultsEqual = createAnEmptyObject.apply(null, inputSelectorResults) === createAnEmptyObject.apply(null, inputSelectorResultsCopy);\n if (!areInputSelectorResultsEqual) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"An input selector returned a different result when passed same arguments.\\nThis means your output selector will likely run more frequently than intended.\\nAvoid returning a new reference inside your input selector, e.g.\\n`createSelector([state => state.todos.map(todo => todo.id)], todoIds => todoIds.length)`\",\n {\n arguments: inputSelectorArgs,\n firstInputs: inputSelectorResults,\n secondInputs: inputSelectorResultsCopy,\n stack\n }\n );\n }\n};\n\n// src/devModeChecks/setGlobalDevModeChecks.ts\nvar globalDevModeChecks = {\n inputStabilityCheck: \"once\",\n identityFunctionCheck: \"once\"\n};\nvar setGlobalDevModeChecks = (devModeChecks) => {\n Object.assign(globalDevModeChecks, devModeChecks);\n};\n\n// src/utils.ts\nvar NOT_FOUND = /* @__PURE__ */ Symbol(\"NOT_FOUND\");\nfunction assertIsFunction(func, errorMessage = `expected a function, instead received ${typeof func}`) {\n if (typeof func !== \"function\") {\n throw new TypeError(errorMessage);\n }\n}\nfunction assertIsObject(object, errorMessage = `expected an object, instead received ${typeof object}`) {\n if (typeof object !== \"object\") {\n throw new TypeError(errorMessage);\n }\n}\nfunction assertIsArrayOfFunctions(array, errorMessage = `expected all items to be functions, instead received the following types: `) {\n if (!array.every((item) => typeof item === \"function\")) {\n const itemTypes = array.map(\n (item) => typeof item === \"function\" ? `function ${item.name || \"unnamed\"}()` : typeof item\n ).join(\", \");\n throw new TypeError(`${errorMessage}[${itemTypes}]`);\n }\n}\nvar ensureIsArray = (item) => {\n return Array.isArray(item) ? item : [item];\n};\nfunction getDependencies(createSelectorArgs) {\n const dependencies = Array.isArray(createSelectorArgs[0]) ? createSelectorArgs[0] : createSelectorArgs;\n assertIsArrayOfFunctions(\n dependencies,\n `createSelector expects all input-selectors to be functions, but received the following types: `\n );\n return dependencies;\n}\nfunction collectInputSelectorResults(dependencies, inputSelectorArgs) {\n const inputSelectorResults = [];\n const { length } = dependencies;\n for (let i = 0; i < length; i++) {\n inputSelectorResults.push(dependencies[i].apply(null, inputSelectorArgs));\n }\n return inputSelectorResults;\n}\nvar getDevModeChecksExecutionInfo = (firstRun, devModeChecks) => {\n const { identityFunctionCheck, inputStabilityCheck } = {\n ...globalDevModeChecks,\n ...devModeChecks\n };\n return {\n identityFunctionCheck: {\n shouldRun: identityFunctionCheck === \"always\" || identityFunctionCheck === \"once\" && firstRun,\n run: runIdentityFunctionCheck\n },\n inputStabilityCheck: {\n shouldRun: inputStabilityCheck === \"always\" || inputStabilityCheck === \"once\" && firstRun,\n run: runInputStabilityCheck\n }\n };\n};\n\n// src/autotrackMemoize/autotracking.ts\nvar $REVISION = 0;\nvar CURRENT_TRACKER = null;\nvar Cell = class {\n revision = $REVISION;\n _value;\n _lastValue;\n _isEqual = tripleEq;\n constructor(initialValue, isEqual = tripleEq) {\n this._value = this._lastValue = initialValue;\n this._isEqual = isEqual;\n }\n // Whenever a storage value is read, it'll add itself to the current tracker if\n // one exists, entangling its state with that cache.\n get value() {\n CURRENT_TRACKER?.add(this);\n return this._value;\n }\n // Whenever a storage value is updated, we bump the global revision clock,\n // assign the revision for this storage to the new value, _and_ we schedule a\n // rerender. This is important, and it's what makes autotracking _pull_\n // based. We don't actively tell the caches which depend on the storage that\n // anything has happened. Instead, we recompute the caches when needed.\n set value(newValue) {\n if (this.value === newValue)\n return;\n this._value = newValue;\n this.revision = ++$REVISION;\n }\n};\nfunction tripleEq(a, b) {\n return a === b;\n}\nvar TrackingCache = class {\n _cachedValue;\n _cachedRevision = -1;\n _deps = [];\n hits = 0;\n fn;\n constructor(fn) {\n this.fn = fn;\n }\n clear() {\n this._cachedValue = void 0;\n this._cachedRevision = -1;\n this._deps = [];\n this.hits = 0;\n }\n get value() {\n if (this.revision > this._cachedRevision) {\n const { fn } = this;\n const currentTracker = /* @__PURE__ */ new Set();\n const prevTracker = CURRENT_TRACKER;\n CURRENT_TRACKER = currentTracker;\n this._cachedValue = fn();\n CURRENT_TRACKER = prevTracker;\n this.hits++;\n this._deps = Array.from(currentTracker);\n this._cachedRevision = this.revision;\n }\n CURRENT_TRACKER?.add(this);\n return this._cachedValue;\n }\n get revision() {\n return Math.max(...this._deps.map((d) => d.revision), 0);\n }\n};\nfunction getValue(cell) {\n if (!(cell instanceof Cell)) {\n console.warn(\"Not a valid cell! \", cell);\n }\n return cell.value;\n}\nfunction setValue(storage, value) {\n if (!(storage instanceof Cell)) {\n throw new TypeError(\n \"setValue must be passed a tracked store created with `createStorage`.\"\n );\n }\n storage.value = storage._lastValue = value;\n}\nfunction createCell(initialValue, isEqual = tripleEq) {\n return new Cell(initialValue, isEqual);\n}\nfunction createCache(fn) {\n assertIsFunction(\n fn,\n \"the first parameter to `createCache` must be a function\"\n );\n return new TrackingCache(fn);\n}\n\n// src/autotrackMemoize/tracking.ts\nvar neverEq = (a, b) => false;\nfunction createTag() {\n return createCell(null, neverEq);\n}\nfunction dirtyTag(tag, value) {\n setValue(tag, value);\n}\nvar consumeCollection = (node) => {\n let tag = node.collectionTag;\n if (tag === null) {\n tag = node.collectionTag = createTag();\n }\n getValue(tag);\n};\nvar dirtyCollection = (node) => {\n const tag = node.collectionTag;\n if (tag !== null) {\n dirtyTag(tag, null);\n }\n};\n\n// src/autotrackMemoize/proxy.ts\nvar REDUX_PROXY_LABEL = Symbol();\nvar nextId = 0;\nvar proto = Object.getPrototypeOf({});\nvar ObjectTreeNode = class {\n constructor(value) {\n this.value = value;\n this.value = value;\n this.tag.value = value;\n }\n proxy = new Proxy(this, objectProxyHandler);\n tag = createTag();\n tags = {};\n children = {};\n collectionTag = null;\n id = nextId++;\n};\nvar objectProxyHandler = {\n get(node, key) {\n function calculateResult() {\n const { value } = node;\n const childValue = Reflect.get(value, key);\n if (typeof key === \"symbol\") {\n return childValue;\n }\n if (key in proto) {\n return childValue;\n }\n if (typeof childValue === \"object\" && childValue !== null) {\n let childNode = node.children[key];\n if (childNode === void 0) {\n childNode = node.children[key] = createNode(childValue);\n }\n if (childNode.tag) {\n getValue(childNode.tag);\n }\n return childNode.proxy;\n } else {\n let tag = node.tags[key];\n if (tag === void 0) {\n tag = node.tags[key] = createTag();\n tag.value = childValue;\n }\n getValue(tag);\n return childValue;\n }\n }\n const res = calculateResult();\n return res;\n },\n ownKeys(node) {\n consumeCollection(node);\n return Reflect.ownKeys(node.value);\n },\n getOwnPropertyDescriptor(node, prop) {\n return Reflect.getOwnPropertyDescriptor(node.value, prop);\n },\n has(node, prop) {\n return Reflect.has(node.value, prop);\n }\n};\nvar ArrayTreeNode = class {\n constructor(value) {\n this.value = value;\n this.value = value;\n this.tag.value = value;\n }\n proxy = new Proxy([this], arrayProxyHandler);\n tag = createTag();\n tags = {};\n children = {};\n collectionTag = null;\n id = nextId++;\n};\nvar arrayProxyHandler = {\n get([node], key) {\n if (key === \"length\") {\n consumeCollection(node);\n }\n return objectProxyHandler.get(node, key);\n },\n ownKeys([node]) {\n return objectProxyHandler.ownKeys(node);\n },\n getOwnPropertyDescriptor([node], prop) {\n return objectProxyHandler.getOwnPropertyDescriptor(node, prop);\n },\n has([node], prop) {\n return objectProxyHandler.has(node, prop);\n }\n};\nfunction createNode(value) {\n if (Array.isArray(value)) {\n return new ArrayTreeNode(value);\n }\n return new ObjectTreeNode(value);\n}\nfunction updateNode(node, newValue) {\n const { value, tags, children } = node;\n node.value = newValue;\n if (Array.isArray(value) && Array.isArray(newValue) && value.length !== newValue.length) {\n dirtyCollection(node);\n } else {\n if (value !== newValue) {\n let oldKeysSize = 0;\n let newKeysSize = 0;\n let anyKeysAdded = false;\n for (const _key in value) {\n oldKeysSize++;\n }\n for (const key in newValue) {\n newKeysSize++;\n if (!(key in value)) {\n anyKeysAdded = true;\n break;\n }\n }\n const isDifferent = anyKeysAdded || oldKeysSize !== newKeysSize;\n if (isDifferent) {\n dirtyCollection(node);\n }\n }\n }\n for (const key in tags) {\n const childValue = value[key];\n const newChildValue = newValue[key];\n if (childValue !== newChildValue) {\n dirtyCollection(node);\n dirtyTag(tags[key], newChildValue);\n }\n if (typeof newChildValue === \"object\" && newChildValue !== null) {\n delete tags[key];\n }\n }\n for (const key in children) {\n const childNode = children[key];\n const newChildValue = newValue[key];\n const childValue = childNode.value;\n if (childValue === newChildValue) {\n continue;\n } else if (typeof newChildValue === \"object\" && newChildValue !== null) {\n updateNode(childNode, newChildValue);\n } else {\n deleteNode(childNode);\n delete children[key];\n }\n }\n}\nfunction deleteNode(node) {\n if (node.tag) {\n dirtyTag(node.tag, null);\n }\n dirtyCollection(node);\n for (const key in node.tags) {\n dirtyTag(node.tags[key], null);\n }\n for (const key in node.children) {\n deleteNode(node.children[key]);\n }\n}\n\n// src/lruMemoize.ts\nfunction createSingletonCache(equals) {\n let entry;\n return {\n get(key) {\n if (entry && equals(entry.key, key)) {\n return entry.value;\n }\n return NOT_FOUND;\n },\n put(key, value) {\n entry = { key, value };\n },\n getEntries() {\n return entry ? [entry] : [];\n },\n clear() {\n entry = void 0;\n }\n };\n}\nfunction createLruCache(maxSize, equals) {\n let entries = [];\n function get(key) {\n const cacheIndex = entries.findIndex((entry) => equals(key, entry.key));\n if (cacheIndex > -1) {\n const entry = entries[cacheIndex];\n if (cacheIndex > 0) {\n entries.splice(cacheIndex, 1);\n entries.unshift(entry);\n }\n return entry.value;\n }\n return NOT_FOUND;\n }\n function put(key, value) {\n if (get(key) === NOT_FOUND) {\n entries.unshift({ key, value });\n if (entries.length > maxSize) {\n entries.pop();\n }\n }\n }\n function getEntries() {\n return entries;\n }\n function clear() {\n entries = [];\n }\n return { get, put, getEntries, clear };\n}\nvar referenceEqualityCheck = (a, b) => a === b;\nfunction createCacheKeyComparator(equalityCheck) {\n return function areArgumentsShallowlyEqual(prev, next) {\n if (prev === null || next === null || prev.length !== next.length) {\n return false;\n }\n const { length } = prev;\n for (let i = 0; i < length; i++) {\n if (!equalityCheck(prev[i], next[i])) {\n return false;\n }\n }\n return true;\n };\n}\nfunction lruMemoize(func, equalityCheckOrOptions) {\n const providedOptions = typeof equalityCheckOrOptions === \"object\" ? equalityCheckOrOptions : { equalityCheck: equalityCheckOrOptions };\n const {\n equalityCheck = referenceEqualityCheck,\n maxSize = 1,\n resultEqualityCheck\n } = providedOptions;\n const comparator = createCacheKeyComparator(equalityCheck);\n let resultsCount = 0;\n const cache = maxSize <= 1 ? createSingletonCache(comparator) : createLruCache(maxSize, comparator);\n function memoized() {\n let value = cache.get(arguments);\n if (value === NOT_FOUND) {\n value = func.apply(null, arguments);\n resultsCount++;\n if (resultEqualityCheck) {\n const entries = cache.getEntries();\n const matchingEntry = entries.find(\n (entry) => resultEqualityCheck(entry.value, value)\n );\n if (matchingEntry) {\n value = matchingEntry.value;\n resultsCount !== 0 && resultsCount--;\n }\n }\n cache.put(arguments, value);\n }\n return value;\n }\n memoized.clearCache = () => {\n cache.clear();\n memoized.resetResultsCount();\n };\n memoized.resultsCount = () => resultsCount;\n memoized.resetResultsCount = () => {\n resultsCount = 0;\n };\n return memoized;\n}\n\n// src/autotrackMemoize/autotrackMemoize.ts\nfunction autotrackMemoize(func) {\n const node = createNode(\n []\n );\n let lastArgs = null;\n const shallowEqual = createCacheKeyComparator(referenceEqualityCheck);\n const cache = createCache(() => {\n const res = func.apply(null, node.proxy);\n return res;\n });\n function memoized() {\n if (!shallowEqual(lastArgs, arguments)) {\n updateNode(node, arguments);\n lastArgs = arguments;\n }\n return cache.value;\n }\n memoized.clearCache = () => {\n return cache.clear();\n };\n return memoized;\n}\n\n// src/weakMapMemoize.ts\nvar StrongRef = class {\n constructor(value) {\n this.value = value;\n }\n deref() {\n return this.value;\n }\n};\nvar Ref = typeof WeakRef !== \"undefined\" ? WeakRef : StrongRef;\nvar UNTERMINATED = 0;\nvar TERMINATED = 1;\nfunction createCacheNode() {\n return {\n s: UNTERMINATED,\n v: void 0,\n o: null,\n p: null\n };\n}\nfunction weakMapMemoize(func, options = {}) {\n let fnNode = createCacheNode();\n const { resultEqualityCheck } = options;\n let lastResult;\n let resultsCount = 0;\n function memoized() {\n let cacheNode = fnNode;\n const { length } = arguments;\n for (let i = 0, l = length; i < l; i++) {\n const arg = arguments[i];\n if (typeof arg === \"function\" || typeof arg === \"object\" && arg !== null) {\n let objectCache = cacheNode.o;\n if (objectCache === null) {\n cacheNode.o = objectCache = /* @__PURE__ */ new WeakMap();\n }\n const objectNode = objectCache.get(arg);\n if (objectNode === void 0) {\n cacheNode = createCacheNode();\n objectCache.set(arg, cacheNode);\n } else {\n cacheNode = objectNode;\n }\n } else {\n let primitiveCache = cacheNode.p;\n if (primitiveCache === null) {\n cacheNode.p = primitiveCache = /* @__PURE__ */ new Map();\n }\n const primitiveNode = primitiveCache.get(arg);\n if (primitiveNode === void 0) {\n cacheNode = createCacheNode();\n primitiveCache.set(arg, cacheNode);\n } else {\n cacheNode = primitiveNode;\n }\n }\n }\n const terminatedNode = cacheNode;\n let result;\n if (cacheNode.s === TERMINATED) {\n result = cacheNode.v;\n } else {\n result = func.apply(null, arguments);\n resultsCount++;\n if (resultEqualityCheck) {\n const lastResultValue = lastResult?.deref?.() ?? lastResult;\n if (lastResultValue != null && resultEqualityCheck(lastResultValue, result)) {\n result = lastResultValue;\n resultsCount !== 0 && resultsCount--;\n }\n const needsWeakRef = typeof result === \"object\" && result !== null || typeof result === \"function\";\n lastResult = needsWeakRef ? new Ref(result) : result;\n }\n }\n terminatedNode.s = TERMINATED;\n terminatedNode.v = result;\n return result;\n }\n memoized.clearCache = () => {\n fnNode = createCacheNode();\n memoized.resetResultsCount();\n };\n memoized.resultsCount = () => resultsCount;\n memoized.resetResultsCount = () => {\n resultsCount = 0;\n };\n return memoized;\n}\n\n// src/createSelectorCreator.ts\nfunction createSelectorCreator(memoizeOrOptions, ...memoizeOptionsFromArgs) {\n const createSelectorCreatorOptions = typeof memoizeOrOptions === \"function\" ? {\n memoize: memoizeOrOptions,\n memoizeOptions: memoizeOptionsFromArgs\n } : memoizeOrOptions;\n const createSelector2 = (...createSelectorArgs) => {\n let recomputations = 0;\n let dependencyRecomputations = 0;\n let lastResult;\n let directlyPassedOptions = {};\n let resultFunc = createSelectorArgs.pop();\n if (typeof resultFunc === \"object\") {\n directlyPassedOptions = resultFunc;\n resultFunc = createSelectorArgs.pop();\n }\n assertIsFunction(\n resultFunc,\n `createSelector expects an output function after the inputs, but received: [${typeof resultFunc}]`\n );\n const combinedOptions = {\n ...createSelectorCreatorOptions,\n ...directlyPassedOptions\n };\n const {\n memoize,\n memoizeOptions = [],\n argsMemoize = weakMapMemoize,\n argsMemoizeOptions = [],\n devModeChecks = {}\n } = combinedOptions;\n const finalMemoizeOptions = ensureIsArray(memoizeOptions);\n const finalArgsMemoizeOptions = ensureIsArray(argsMemoizeOptions);\n const dependencies = getDependencies(createSelectorArgs);\n const memoizedResultFunc = memoize(function recomputationWrapper() {\n recomputations++;\n return resultFunc.apply(\n null,\n arguments\n );\n }, ...finalMemoizeOptions);\n let firstRun = true;\n const selector = argsMemoize(function dependenciesChecker() {\n dependencyRecomputations++;\n const inputSelectorResults = collectInputSelectorResults(\n dependencies,\n arguments\n );\n lastResult = memoizedResultFunc.apply(null, inputSelectorResults);\n if (process.env.NODE_ENV !== \"production\") {\n const { identityFunctionCheck, inputStabilityCheck } = getDevModeChecksExecutionInfo(firstRun, devModeChecks);\n if (identityFunctionCheck.shouldRun) {\n identityFunctionCheck.run(\n resultFunc,\n inputSelectorResults,\n lastResult\n );\n }\n if (inputStabilityCheck.shouldRun) {\n const inputSelectorResultsCopy = collectInputSelectorResults(\n dependencies,\n arguments\n );\n inputStabilityCheck.run(\n { inputSelectorResults, inputSelectorResultsCopy },\n { memoize, memoizeOptions: finalMemoizeOptions },\n arguments\n );\n }\n if (firstRun)\n firstRun = false;\n }\n return lastResult;\n }, ...finalArgsMemoizeOptions);\n return Object.assign(selector, {\n resultFunc,\n memoizedResultFunc,\n dependencies,\n dependencyRecomputations: () => dependencyRecomputations,\n resetDependencyRecomputations: () => {\n dependencyRecomputations = 0;\n },\n lastResult: () => lastResult,\n recomputations: () => recomputations,\n resetRecomputations: () => {\n recomputations = 0;\n },\n memoize,\n argsMemoize\n });\n };\n Object.assign(createSelector2, {\n withTypes: () => createSelector2\n });\n return createSelector2;\n}\nvar createSelector = /* @__PURE__ */ createSelectorCreator(weakMapMemoize);\n\n// src/createStructuredSelector.ts\nvar createStructuredSelector = Object.assign(\n (inputSelectorsObject, selectorCreator = createSelector) => {\n assertIsObject(\n inputSelectorsObject,\n `createStructuredSelector expects first argument to be an object where each property is a selector, instead received a ${typeof inputSelectorsObject}`\n );\n const inputSelectorKeys = Object.keys(inputSelectorsObject);\n const dependencies = inputSelectorKeys.map(\n (key) => inputSelectorsObject[key]\n );\n const structuredSelector = selectorCreator(\n dependencies,\n (...inputSelectorResults) => {\n return inputSelectorResults.reduce((composition, value, index) => {\n composition[inputSelectorKeys[index]] = value;\n return composition;\n }, {});\n }\n );\n return structuredSelector;\n },\n { withTypes: () => createStructuredSelector }\n);\nexport {\n createSelector,\n createSelectorCreator,\n createStructuredSelector,\n lruMemoize,\n referenceEqualityCheck,\n setGlobalDevModeChecks,\n autotrackMemoize as unstable_autotrackMemoize,\n weakMapMemoize\n};\n//# sourceMappingURL=reselect.mjs.map","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction getPriority(a) {\n if (typeof a === 'symbol') {\n return 1;\n }\n if (a === null) {\n return 2;\n }\n if (a === undefined) {\n return 3;\n }\n if (a !== a) {\n return 4;\n }\n return 0;\n}\nconst compareValues = (a, b, order) => {\n if (a !== b) {\n const aPriority = getPriority(a);\n const bPriority = getPriority(b);\n if (aPriority === bPriority && aPriority === 0) {\n if (a < b) {\n return order === 'desc' ? 1 : -1;\n }\n if (a > b) {\n return order === 'desc' ? -1 : 1;\n }\n }\n return order === 'desc' ? bPriority - aPriority : aPriority - bPriority;\n }\n return 0;\n};\n\nexports.compareValues = compareValues;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isSymbol(value) {\n return typeof value === 'symbol' || value instanceof Symbol;\n}\n\nexports.isSymbol = isSymbol;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isSymbol = require('../predicate/isSymbol.js');\n\nconst regexIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/;\nconst regexIsPlainProp = /^\\w*$/;\nfunction isKey(value, object) {\n if (Array.isArray(value)) {\n return false;\n }\n if (typeof value === 'number' || typeof value === 'boolean' || value == null || isSymbol.isSymbol(value)) {\n return true;\n }\n return ((typeof value === 'string' && (regexIsPlainProp.test(value) || !regexIsDeepProp.test(value))) ||\n (object != null && Object.hasOwn(object, value)));\n}\n\nexports.isKey = isKey;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst compareValues = require('../_internal/compareValues.js');\nconst isKey = require('../_internal/isKey.js');\nconst toPath = require('../util/toPath.js');\n\nfunction orderBy(collection, criteria, orders, guard) {\n if (collection == null) {\n return [];\n }\n orders = guard ? undefined : orders;\n if (!Array.isArray(collection)) {\n collection = Object.values(collection);\n }\n if (!Array.isArray(criteria)) {\n criteria = criteria == null ? [null] : [criteria];\n }\n if (criteria.length === 0) {\n criteria = [null];\n }\n if (!Array.isArray(orders)) {\n orders = orders == null ? [] : [orders];\n }\n orders = orders.map(order => String(order));\n const getValueByNestedPath = (object, path) => {\n let target = object;\n for (let i = 0; i < path.length && target != null; ++i) {\n target = target[path[i]];\n }\n return target;\n };\n const getValueByCriterion = (criterion, object) => {\n if (object == null || criterion == null) {\n return object;\n }\n if (typeof criterion === 'object' && 'key' in criterion) {\n if (Object.hasOwn(object, criterion.key)) {\n return object[criterion.key];\n }\n return getValueByNestedPath(object, criterion.path);\n }\n if (typeof criterion === 'function') {\n return criterion(object);\n }\n if (Array.isArray(criterion)) {\n return getValueByNestedPath(object, criterion);\n }\n if (typeof object === 'object') {\n return object[criterion];\n }\n return object;\n };\n const preparedCriteria = criteria.map((criterion) => {\n if (Array.isArray(criterion) && criterion.length === 1) {\n criterion = criterion[0];\n }\n if (criterion == null || typeof criterion === 'function' || Array.isArray(criterion) || isKey.isKey(criterion)) {\n return criterion;\n }\n return { key: criterion, path: toPath.toPath(criterion) };\n });\n const preparedCollection = collection.map(item => ({\n original: item,\n criteria: preparedCriteria.map((criterion) => getValueByCriterion(criterion, item)),\n }));\n return preparedCollection\n .slice()\n .sort((a, b) => {\n for (let i = 0; i < preparedCriteria.length; i++) {\n const comparedResult = compareValues.compareValues(a.criteria[i], b.criteria[i], orders[i]);\n if (comparedResult !== 0) {\n return comparedResult;\n }\n }\n return 0;\n })\n .map(item => item.original);\n}\n\nexports.orderBy = orderBy;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction flatten(arr, depth = 1) {\n const result = [];\n const flooredDepth = Math.floor(depth);\n const recursive = (arr, currentDepth) => {\n for (let i = 0; i < arr.length; i++) {\n const item = arr[i];\n if (Array.isArray(item) && currentDepth < flooredDepth) {\n recursive(item, currentDepth + 1);\n }\n else {\n result.push(item);\n }\n }\n };\n recursive(arr, 0);\n return result;\n}\n\nexports.flatten = flatten;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isIndex = require('./isIndex.js');\nconst isArrayLike = require('../predicate/isArrayLike.js');\nconst isObject = require('../predicate/isObject.js');\nconst isEqualsSameValueZero = require('../../_internal/isEqualsSameValueZero.js');\n\nfunction isIterateeCall(value, index, object) {\n if (!isObject.isObject(object)) {\n return false;\n }\n if ((typeof index === 'number' && isArrayLike.isArrayLike(object) && isIndex.isIndex(index) && index < object.length) ||\n (typeof index === 'string' && index in object)) {\n return isEqualsSameValueZero.isEqualsSameValueZero(object[index], value);\n }\n return false;\n}\n\nexports.isIterateeCall = isIterateeCall;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst orderBy = require('./orderBy.js');\nconst flatten = require('../../array/flatten.js');\nconst isIterateeCall = require('../_internal/isIterateeCall.js');\n\nfunction sortBy(collection, ...criteria) {\n const length = criteria.length;\n if (length > 1 && isIterateeCall.isIterateeCall(collection, criteria[0], criteria[1])) {\n criteria = [];\n }\n else if (length > 2 && isIterateeCall.isIterateeCall(criteria[0], criteria[1], criteria[2])) {\n criteria = [criteria[0]];\n }\n return orderBy.orderBy(collection, flatten.flatten(criteria), ['asc']);\n}\n\nexports.sortBy = sortBy;\n","module.exports = require('../dist/compat/array/sortBy.js').sortBy;\n","// src/utils/formatProdErrorMessage.ts\nfunction formatProdErrorMessage(code) {\n return `Minified Redux error #${code}; visit https://redux.js.org/Errors?code=${code} for the full message or use the non-minified dev environment for full errors. `;\n}\n\n// src/utils/symbol-observable.ts\nvar $$observable = /* @__PURE__ */ (() => typeof Symbol === \"function\" && Symbol.observable || \"@@observable\")();\nvar symbol_observable_default = $$observable;\n\n// src/utils/actionTypes.ts\nvar randomString = () => Math.random().toString(36).substring(7).split(\"\").join(\".\");\nvar ActionTypes = {\n INIT: `@@redux/INIT${/* @__PURE__ */ randomString()}`,\n REPLACE: `@@redux/REPLACE${/* @__PURE__ */ randomString()}`,\n PROBE_UNKNOWN_ACTION: () => `@@redux/PROBE_UNKNOWN_ACTION${randomString()}`\n};\nvar actionTypes_default = ActionTypes;\n\n// src/utils/isPlainObject.ts\nfunction isPlainObject(obj) {\n if (typeof obj !== \"object\" || obj === null)\n return false;\n let proto = obj;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(obj) === proto || Object.getPrototypeOf(obj) === null;\n}\n\n// src/utils/kindOf.ts\nfunction miniKindOf(val) {\n if (val === void 0)\n return \"undefined\";\n if (val === null)\n return \"null\";\n const type = typeof val;\n switch (type) {\n case \"boolean\":\n case \"string\":\n case \"number\":\n case \"symbol\":\n case \"function\": {\n return type;\n }\n }\n if (Array.isArray(val))\n return \"array\";\n if (isDate(val))\n return \"date\";\n if (isError(val))\n return \"error\";\n const constructorName = ctorName(val);\n switch (constructorName) {\n case \"Symbol\":\n case \"Promise\":\n case \"WeakMap\":\n case \"WeakSet\":\n case \"Map\":\n case \"Set\":\n return constructorName;\n }\n return Object.prototype.toString.call(val).slice(8, -1).toLowerCase().replace(/\\s/g, \"\");\n}\nfunction ctorName(val) {\n return typeof val.constructor === \"function\" ? val.constructor.name : null;\n}\nfunction isError(val) {\n return val instanceof Error || typeof val.message === \"string\" && val.constructor && typeof val.constructor.stackTraceLimit === \"number\";\n}\nfunction isDate(val) {\n if (val instanceof Date)\n return true;\n return typeof val.toDateString === \"function\" && typeof val.getDate === \"function\" && typeof val.setDate === \"function\";\n}\nfunction kindOf(val) {\n let typeOfVal = typeof val;\n if (process.env.NODE_ENV !== \"production\") {\n typeOfVal = miniKindOf(val);\n }\n return typeOfVal;\n}\n\n// src/createStore.ts\nfunction createStore(reducer, preloadedState, enhancer) {\n if (typeof reducer !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(2) : `Expected the root reducer to be a function. Instead, received: '${kindOf(reducer)}'`);\n }\n if (typeof preloadedState === \"function\" && typeof enhancer === \"function\" || typeof enhancer === \"function\" && typeof arguments[3] === \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(0) : \"It looks like you are passing several store enhancers to createStore(). This is not supported. Instead, compose them together to a single function. See https://redux.js.org/tutorials/fundamentals/part-4-store#creating-a-store-with-enhancers for an example.\");\n }\n if (typeof preloadedState === \"function\" && typeof enhancer === \"undefined\") {\n enhancer = preloadedState;\n preloadedState = void 0;\n }\n if (typeof enhancer !== \"undefined\") {\n if (typeof enhancer !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(1) : `Expected the enhancer to be a function. Instead, received: '${kindOf(enhancer)}'`);\n }\n return enhancer(createStore)(reducer, preloadedState);\n }\n let currentReducer = reducer;\n let currentState = preloadedState;\n let currentListeners = /* @__PURE__ */ new Map();\n let nextListeners = currentListeners;\n let listenerIdCounter = 0;\n let isDispatching = false;\n function ensureCanMutateNextListeners() {\n if (nextListeners === currentListeners) {\n nextListeners = /* @__PURE__ */ new Map();\n currentListeners.forEach((listener, key) => {\n nextListeners.set(key, listener);\n });\n }\n }\n function getState() {\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(3) : \"You may not call store.getState() while the reducer is executing. The reducer has already received the state as an argument. Pass it down from the top reducer instead of reading it from the store.\");\n }\n return currentState;\n }\n function subscribe(listener) {\n if (typeof listener !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(4) : `Expected the listener to be a function. Instead, received: '${kindOf(listener)}'`);\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(5) : \"You may not call store.subscribe() while the reducer is executing. If you would like to be notified after the store has been updated, subscribe from a component and invoke store.getState() in the callback to access the latest state. See https://redux.js.org/api/store#subscribelistener for more details.\");\n }\n let isSubscribed = true;\n ensureCanMutateNextListeners();\n const listenerId = listenerIdCounter++;\n nextListeners.set(listenerId, listener);\n return function unsubscribe() {\n if (!isSubscribed) {\n return;\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(6) : \"You may not unsubscribe from a store listener while the reducer is executing. See https://redux.js.org/api/store#subscribelistener for more details.\");\n }\n isSubscribed = false;\n ensureCanMutateNextListeners();\n nextListeners.delete(listenerId);\n currentListeners = null;\n };\n }\n function dispatch(action) {\n if (!isPlainObject(action)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(7) : `Actions must be plain objects. Instead, the actual type was: '${kindOf(action)}'. You may need to add middleware to your store setup to handle dispatching other values, such as 'redux-thunk' to handle dispatching functions. See https://redux.js.org/tutorials/fundamentals/part-4-store#middleware and https://redux.js.org/tutorials/fundamentals/part-6-async-logic#using-the-redux-thunk-middleware for examples.`);\n }\n if (typeof action.type === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(8) : 'Actions may not have an undefined \"type\" property. You may have misspelled an action type string constant.');\n }\n if (typeof action.type !== \"string\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(17) : `Action \"type\" property must be a string. Instead, the actual type was: '${kindOf(action.type)}'. Value was: '${action.type}' (stringified)`);\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(9) : \"Reducers may not dispatch actions.\");\n }\n try {\n isDispatching = true;\n currentState = currentReducer(currentState, action);\n } finally {\n isDispatching = false;\n }\n const listeners = currentListeners = nextListeners;\n listeners.forEach((listener) => {\n listener();\n });\n return action;\n }\n function replaceReducer(nextReducer) {\n if (typeof nextReducer !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(10) : `Expected the nextReducer to be a function. Instead, received: '${kindOf(nextReducer)}`);\n }\n currentReducer = nextReducer;\n dispatch({\n type: actionTypes_default.REPLACE\n });\n }\n function observable() {\n const outerSubscribe = subscribe;\n return {\n /**\n * The minimal observable subscription method.\n * @param observer Any object that can be used as an observer.\n * The observer object should have a `next` method.\n * @returns An object with an `unsubscribe` method that can\n * be used to unsubscribe the observable from the store, and prevent further\n * emission of values from the observable.\n */\n subscribe(observer) {\n if (typeof observer !== \"object\" || observer === null) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(11) : `Expected the observer to be an object. Instead, received: '${kindOf(observer)}'`);\n }\n function observeState() {\n const observerAsObserver = observer;\n if (observerAsObserver.next) {\n observerAsObserver.next(getState());\n }\n }\n observeState();\n const unsubscribe = outerSubscribe(observeState);\n return {\n unsubscribe\n };\n },\n [symbol_observable_default]() {\n return this;\n }\n };\n }\n dispatch({\n type: actionTypes_default.INIT\n });\n const store = {\n dispatch,\n subscribe,\n getState,\n replaceReducer,\n [symbol_observable_default]: observable\n };\n return store;\n}\nfunction legacy_createStore(reducer, preloadedState, enhancer) {\n return createStore(reducer, preloadedState, enhancer);\n}\n\n// src/utils/warning.ts\nfunction warning(message) {\n if (typeof console !== \"undefined\" && typeof console.error === \"function\") {\n console.error(message);\n }\n try {\n throw new Error(message);\n } catch (e) {\n }\n}\n\n// src/combineReducers.ts\nfunction getUnexpectedStateShapeWarningMessage(inputState, reducers, action, unexpectedKeyCache) {\n const reducerKeys = Object.keys(reducers);\n const argumentName = action && action.type === actionTypes_default.INIT ? \"preloadedState argument passed to createStore\" : \"previous state received by the reducer\";\n if (reducerKeys.length === 0) {\n return \"Store does not have a valid reducer. Make sure the argument passed to combineReducers is an object whose values are reducers.\";\n }\n if (!isPlainObject(inputState)) {\n return `The ${argumentName} has unexpected type of \"${kindOf(inputState)}\". Expected argument to be an object with the following keys: \"${reducerKeys.join('\", \"')}\"`;\n }\n const unexpectedKeys = Object.keys(inputState).filter((key) => !reducers.hasOwnProperty(key) && !unexpectedKeyCache[key]);\n unexpectedKeys.forEach((key) => {\n unexpectedKeyCache[key] = true;\n });\n if (action && action.type === actionTypes_default.REPLACE)\n return;\n if (unexpectedKeys.length > 0) {\n return `Unexpected ${unexpectedKeys.length > 1 ? \"keys\" : \"key\"} \"${unexpectedKeys.join('\", \"')}\" found in ${argumentName}. Expected to find one of the known reducer keys instead: \"${reducerKeys.join('\", \"')}\". Unexpected keys will be ignored.`;\n }\n}\nfunction assertReducerShape(reducers) {\n Object.keys(reducers).forEach((key) => {\n const reducer = reducers[key];\n const initialState = reducer(void 0, {\n type: actionTypes_default.INIT\n });\n if (typeof initialState === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(12) : `The slice reducer for key \"${key}\" returned undefined during initialization. If the state passed to the reducer is undefined, you must explicitly return the initial state. The initial state may not be undefined. If you don't want to set a value for this reducer, you can use null instead of undefined.`);\n }\n if (typeof reducer(void 0, {\n type: actionTypes_default.PROBE_UNKNOWN_ACTION()\n }) === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(13) : `The slice reducer for key \"${key}\" returned undefined when probed with a random type. Don't try to handle '${actionTypes_default.INIT}' or other actions in \"redux/*\" namespace. They are considered private. Instead, you must return the current state for any unknown actions, unless it is undefined, in which case you must return the initial state, regardless of the action type. The initial state may not be undefined, but can be null.`);\n }\n });\n}\nfunction combineReducers(reducers) {\n const reducerKeys = Object.keys(reducers);\n const finalReducers = {};\n for (let i = 0; i < reducerKeys.length; i++) {\n const key = reducerKeys[i];\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof reducers[key] === \"undefined\") {\n warning(`No reducer provided for key \"${key}\"`);\n }\n }\n if (typeof reducers[key] === \"function\") {\n finalReducers[key] = reducers[key];\n }\n }\n const finalReducerKeys = Object.keys(finalReducers);\n let unexpectedKeyCache;\n if (process.env.NODE_ENV !== \"production\") {\n unexpectedKeyCache = {};\n }\n let shapeAssertionError;\n try {\n assertReducerShape(finalReducers);\n } catch (e) {\n shapeAssertionError = e;\n }\n return function combination(state = {}, action) {\n if (shapeAssertionError) {\n throw shapeAssertionError;\n }\n if (process.env.NODE_ENV !== \"production\") {\n const warningMessage = getUnexpectedStateShapeWarningMessage(state, finalReducers, action, unexpectedKeyCache);\n if (warningMessage) {\n warning(warningMessage);\n }\n }\n let hasChanged = false;\n const nextState = {};\n for (let i = 0; i < finalReducerKeys.length; i++) {\n const key = finalReducerKeys[i];\n const reducer = finalReducers[key];\n const previousStateForKey = state[key];\n const nextStateForKey = reducer(previousStateForKey, action);\n if (typeof nextStateForKey === \"undefined\") {\n const actionType = action && action.type;\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(14) : `When called with an action of type ${actionType ? `\"${String(actionType)}\"` : \"(unknown type)\"}, the slice reducer for key \"${key}\" returned undefined. To ignore an action, you must explicitly return the previous state. If you want this reducer to hold no value, you can return null instead of undefined.`);\n }\n nextState[key] = nextStateForKey;\n hasChanged = hasChanged || nextStateForKey !== previousStateForKey;\n }\n hasChanged = hasChanged || finalReducerKeys.length !== Object.keys(state).length;\n return hasChanged ? nextState : state;\n };\n}\n\n// src/bindActionCreators.ts\nfunction bindActionCreator(actionCreator, dispatch) {\n return function(...args) {\n return dispatch(actionCreator.apply(this, args));\n };\n}\nfunction bindActionCreators(actionCreators, dispatch) {\n if (typeof actionCreators === \"function\") {\n return bindActionCreator(actionCreators, dispatch);\n }\n if (typeof actionCreators !== \"object\" || actionCreators === null) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(16) : `bindActionCreators expected an object or a function, but instead received: '${kindOf(actionCreators)}'. Did you write \"import ActionCreators from\" instead of \"import * as ActionCreators from\"?`);\n }\n const boundActionCreators = {};\n for (const key in actionCreators) {\n const actionCreator = actionCreators[key];\n if (typeof actionCreator === \"function\") {\n boundActionCreators[key] = bindActionCreator(actionCreator, dispatch);\n }\n }\n return boundActionCreators;\n}\n\n// src/compose.ts\nfunction compose(...funcs) {\n if (funcs.length === 0) {\n return (arg) => arg;\n }\n if (funcs.length === 1) {\n return funcs[0];\n }\n return funcs.reduce((a, b) => (...args) => a(b(...args)));\n}\n\n// src/applyMiddleware.ts\nfunction applyMiddleware(...middlewares) {\n return (createStore2) => (reducer, preloadedState) => {\n const store = createStore2(reducer, preloadedState);\n let dispatch = () => {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(15) : \"Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.\");\n };\n const middlewareAPI = {\n getState: store.getState,\n dispatch: (action, ...args) => dispatch(action, ...args)\n };\n const chain = middlewares.map((middleware) => middleware(middlewareAPI));\n dispatch = compose(...chain)(store.dispatch);\n return {\n ...store,\n dispatch\n };\n };\n}\n\n// src/utils/isAction.ts\nfunction isAction(action) {\n return isPlainObject(action) && \"type\" in action && typeof action.type === \"string\";\n}\nexport {\n actionTypes_default as __DO_NOT_USE__ActionTypes,\n applyMiddleware,\n bindActionCreators,\n combineReducers,\n compose,\n createStore,\n isAction,\n isPlainObject,\n legacy_createStore\n};\n//# sourceMappingURL=redux.mjs.map","// src/utils/env.ts\nvar NOTHING = Symbol.for(\"immer-nothing\");\nvar DRAFTABLE = Symbol.for(\"immer-draftable\");\nvar DRAFT_STATE = Symbol.for(\"immer-state\");\n\n// src/utils/errors.ts\nvar errors = process.env.NODE_ENV !== \"production\" ? [\n // All error codes, starting by 0:\n function(plugin) {\n return `The plugin for '${plugin}' has not been loaded into Immer. To enable the plugin, import and call \\`enable${plugin}()\\` when initializing your application.`;\n },\n function(thing) {\n return `produce can only be called on things that are draftable: plain objects, arrays, Map, Set or classes that are marked with '[immerable]: true'. Got '${thing}'`;\n },\n \"This object has been frozen and should not be mutated\",\n function(data) {\n return \"Cannot use a proxy that has been revoked. Did you pass an object from inside an immer function to an async process? \" + data;\n },\n \"An immer producer returned a new value *and* modified its draft. Either return a new value *or* modify the draft.\",\n \"Immer forbids circular references\",\n \"The first or second argument to `produce` must be a function\",\n \"The third argument to `produce` must be a function or undefined\",\n \"First argument to `createDraft` must be a plain object, an array, or an immerable object\",\n \"First argument to `finishDraft` must be a draft returned by `createDraft`\",\n function(thing) {\n return `'current' expects a draft, got: ${thing}`;\n },\n \"Object.defineProperty() cannot be used on an Immer draft\",\n \"Object.setPrototypeOf() cannot be used on an Immer draft\",\n \"Immer only supports deleting array indices\",\n \"Immer only supports setting array indices and the 'length' property\",\n function(thing) {\n return `'original' expects a draft, got: ${thing}`;\n }\n // Note: if more errors are added, the errorOffset in Patches.ts should be increased\n // See Patches.ts for additional errors\n] : [];\nfunction die(error, ...args) {\n if (process.env.NODE_ENV !== \"production\") {\n const e = errors[error];\n const msg = isFunction(e) ? e.apply(null, args) : e;\n throw new Error(`[Immer] ${msg}`);\n }\n throw new Error(\n `[Immer] minified error nr: ${error}. Full error at: https://bit.ly/3cXEKWf`\n );\n}\n\n// src/utils/common.ts\nvar O = Object;\nvar getPrototypeOf = O.getPrototypeOf;\nvar CONSTRUCTOR = \"constructor\";\nvar PROTOTYPE = \"prototype\";\nvar CONFIGURABLE = \"configurable\";\nvar ENUMERABLE = \"enumerable\";\nvar WRITABLE = \"writable\";\nvar VALUE = \"value\";\nvar isDraft = (value) => !!value && !!value[DRAFT_STATE];\nfunction isDraftable(value) {\n if (!value)\n return false;\n return isPlainObject(value) || isArray(value) || !!value[DRAFTABLE] || !!value[CONSTRUCTOR]?.[DRAFTABLE] || isMap(value) || isSet(value);\n}\nvar objectCtorString = O[PROTOTYPE][CONSTRUCTOR].toString();\nvar cachedCtorStrings = /* @__PURE__ */ new WeakMap();\nfunction isPlainObject(value) {\n if (!value || !isObjectish(value))\n return false;\n const proto = getPrototypeOf(value);\n if (proto === null || proto === O[PROTOTYPE])\n return true;\n const Ctor = O.hasOwnProperty.call(proto, CONSTRUCTOR) && proto[CONSTRUCTOR];\n if (Ctor === Object)\n return true;\n if (!isFunction(Ctor))\n return false;\n let ctorString = cachedCtorStrings.get(Ctor);\n if (ctorString === void 0) {\n ctorString = Function.toString.call(Ctor);\n cachedCtorStrings.set(Ctor, ctorString);\n }\n return ctorString === objectCtorString;\n}\nfunction original(value) {\n if (!isDraft(value))\n die(15, value);\n return value[DRAFT_STATE].base_;\n}\nfunction each(obj, iter, strict = true) {\n if (getArchtype(obj) === 0 /* Object */) {\n const keys = strict ? Reflect.ownKeys(obj) : O.keys(obj);\n keys.forEach((key) => {\n iter(key, obj[key], obj);\n });\n } else {\n obj.forEach((entry, index) => iter(index, entry, obj));\n }\n}\nfunction getArchtype(thing) {\n const state = thing[DRAFT_STATE];\n return state ? state.type_ : isArray(thing) ? 1 /* Array */ : isMap(thing) ? 2 /* Map */ : isSet(thing) ? 3 /* Set */ : 0 /* Object */;\n}\nvar has = (thing, prop, type = getArchtype(thing)) => type === 2 /* Map */ ? thing.has(prop) : O[PROTOTYPE].hasOwnProperty.call(thing, prop);\nvar get = (thing, prop, type = getArchtype(thing)) => (\n // @ts-ignore\n type === 2 /* Map */ ? thing.get(prop) : thing[prop]\n);\nvar set = (thing, propOrOldValue, value, type = getArchtype(thing)) => {\n if (type === 2 /* Map */)\n thing.set(propOrOldValue, value);\n else if (type === 3 /* Set */) {\n thing.add(value);\n } else\n thing[propOrOldValue] = value;\n};\nfunction is(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\nvar isArray = Array.isArray;\nvar isMap = (target) => target instanceof Map;\nvar isSet = (target) => target instanceof Set;\nvar isObjectish = (target) => typeof target === \"object\";\nvar isFunction = (target) => typeof target === \"function\";\nvar isBoolean = (target) => typeof target === \"boolean\";\nfunction isArrayIndex(value) {\n const n = +value;\n return Number.isInteger(n) && String(n) === value;\n}\nvar getProxyDraft = (value) => {\n if (!isObjectish(value))\n return null;\n return value?.[DRAFT_STATE];\n};\nvar latest = (state) => state.copy_ || state.base_;\nvar getValue = (value) => {\n const proxyDraft = getProxyDraft(value);\n return proxyDraft ? proxyDraft.copy_ ?? proxyDraft.base_ : value;\n};\nvar getFinalValue = (state) => state.modified_ ? state.copy_ : state.base_;\nfunction shallowCopy(base, strict) {\n if (isMap(base)) {\n return new Map(base);\n }\n if (isSet(base)) {\n return new Set(base);\n }\n if (isArray(base))\n return Array[PROTOTYPE].slice.call(base);\n const isPlain = isPlainObject(base);\n if (strict === true || strict === \"class_only\" && !isPlain) {\n const descriptors = O.getOwnPropertyDescriptors(base);\n delete descriptors[DRAFT_STATE];\n let keys = Reflect.ownKeys(descriptors);\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n const desc = descriptors[key];\n if (desc[WRITABLE] === false) {\n desc[WRITABLE] = true;\n desc[CONFIGURABLE] = true;\n }\n if (desc.get || desc.set)\n descriptors[key] = {\n [CONFIGURABLE]: true,\n [WRITABLE]: true,\n // could live with !!desc.set as well here...\n [ENUMERABLE]: desc[ENUMERABLE],\n [VALUE]: base[key]\n };\n }\n return O.create(getPrototypeOf(base), descriptors);\n } else {\n const proto = getPrototypeOf(base);\n if (proto !== null && isPlain) {\n return { ...base };\n }\n const obj = O.create(proto);\n return O.assign(obj, base);\n }\n}\nfunction freeze(obj, deep = false) {\n if (isFrozen(obj) || isDraft(obj) || !isDraftable(obj))\n return obj;\n if (getArchtype(obj) > 1) {\n O.defineProperties(obj, {\n set: dontMutateMethodOverride,\n add: dontMutateMethodOverride,\n clear: dontMutateMethodOverride,\n delete: dontMutateMethodOverride\n });\n }\n O.freeze(obj);\n if (deep)\n each(\n obj,\n (_key, value) => {\n freeze(value, true);\n },\n false\n );\n return obj;\n}\nfunction dontMutateFrozenCollections() {\n die(2);\n}\nvar dontMutateMethodOverride = {\n [VALUE]: dontMutateFrozenCollections\n};\nfunction isFrozen(obj) {\n if (obj === null || !isObjectish(obj))\n return true;\n return O.isFrozen(obj);\n}\n\n// src/utils/plugins.ts\nvar PluginMapSet = \"MapSet\";\nvar PluginPatches = \"Patches\";\nvar PluginArrayMethods = \"ArrayMethods\";\nvar plugins = {};\nfunction getPlugin(pluginKey) {\n const plugin = plugins[pluginKey];\n if (!plugin) {\n die(0, pluginKey);\n }\n return plugin;\n}\nvar isPluginLoaded = (pluginKey) => !!plugins[pluginKey];\nfunction loadPlugin(pluginKey, implementation) {\n if (!plugins[pluginKey])\n plugins[pluginKey] = implementation;\n}\n\n// src/core/scope.ts\nvar currentScope;\nvar getCurrentScope = () => currentScope;\nvar createScope = (parent_, immer_) => ({\n drafts_: [],\n parent_,\n immer_,\n // Whenever the modified draft contains a draft from another scope, we\n // need to prevent auto-freezing so the unowned draft can be finalized.\n canAutoFreeze_: true,\n unfinalizedDrafts_: 0,\n handledSet_: /* @__PURE__ */ new Set(),\n processedForPatches_: /* @__PURE__ */ new Set(),\n mapSetPlugin_: isPluginLoaded(PluginMapSet) ? getPlugin(PluginMapSet) : void 0,\n arrayMethodsPlugin_: isPluginLoaded(PluginArrayMethods) ? getPlugin(PluginArrayMethods) : void 0\n});\nfunction usePatchesInScope(scope, patchListener) {\n if (patchListener) {\n scope.patchPlugin_ = getPlugin(PluginPatches);\n scope.patches_ = [];\n scope.inversePatches_ = [];\n scope.patchListener_ = patchListener;\n }\n}\nfunction revokeScope(scope) {\n leaveScope(scope);\n scope.drafts_.forEach(revokeDraft);\n scope.drafts_ = null;\n}\nfunction leaveScope(scope) {\n if (scope === currentScope) {\n currentScope = scope.parent_;\n }\n}\nvar enterScope = (immer2) => currentScope = createScope(currentScope, immer2);\nfunction revokeDraft(draft) {\n const state = draft[DRAFT_STATE];\n if (state.type_ === 0 /* Object */ || state.type_ === 1 /* Array */)\n state.revoke_();\n else\n state.revoked_ = true;\n}\n\n// src/core/finalize.ts\nfunction processResult(result, scope) {\n scope.unfinalizedDrafts_ = scope.drafts_.length;\n const baseDraft = scope.drafts_[0];\n const isReplaced = result !== void 0 && result !== baseDraft;\n if (isReplaced) {\n if (baseDraft[DRAFT_STATE].modified_) {\n revokeScope(scope);\n die(4);\n }\n if (isDraftable(result)) {\n result = finalize(scope, result);\n }\n const { patchPlugin_ } = scope;\n if (patchPlugin_) {\n patchPlugin_.generateReplacementPatches_(\n baseDraft[DRAFT_STATE].base_,\n result,\n scope\n );\n }\n } else {\n result = finalize(scope, baseDraft);\n }\n maybeFreeze(scope, result, true);\n revokeScope(scope);\n if (scope.patches_) {\n scope.patchListener_(scope.patches_, scope.inversePatches_);\n }\n return result !== NOTHING ? result : void 0;\n}\nfunction finalize(rootScope, value) {\n if (isFrozen(value))\n return value;\n const state = value[DRAFT_STATE];\n if (!state) {\n const finalValue = handleValue(value, rootScope.handledSet_, rootScope);\n return finalValue;\n }\n if (!isSameScope(state, rootScope)) {\n return value;\n }\n if (!state.modified_) {\n return state.base_;\n }\n if (!state.finalized_) {\n const { callbacks_ } = state;\n if (callbacks_) {\n while (callbacks_.length > 0) {\n const callback = callbacks_.pop();\n callback(rootScope);\n }\n }\n generatePatchesAndFinalize(state, rootScope);\n }\n return state.copy_;\n}\nfunction maybeFreeze(scope, value, deep = false) {\n if (!scope.parent_ && scope.immer_.autoFreeze_ && scope.canAutoFreeze_) {\n freeze(value, deep);\n }\n}\nfunction markStateFinalized(state) {\n state.finalized_ = true;\n state.scope_.unfinalizedDrafts_--;\n}\nvar isSameScope = (state, rootScope) => state.scope_ === rootScope;\nvar EMPTY_LOCATIONS_RESULT = [];\nfunction updateDraftInParent(parent, draftValue, finalizedValue, originalKey) {\n const parentCopy = latest(parent);\n const parentType = parent.type_;\n if (originalKey !== void 0) {\n const currentValue = get(parentCopy, originalKey, parentType);\n if (currentValue === draftValue) {\n set(parentCopy, originalKey, finalizedValue, parentType);\n return;\n }\n }\n if (!parent.draftLocations_) {\n const draftLocations = parent.draftLocations_ = /* @__PURE__ */ new Map();\n each(parentCopy, (key, value) => {\n if (isDraft(value)) {\n const keys = draftLocations.get(value) || [];\n keys.push(key);\n draftLocations.set(value, keys);\n }\n });\n }\n const locations = parent.draftLocations_.get(draftValue) ?? EMPTY_LOCATIONS_RESULT;\n for (const location of locations) {\n set(parentCopy, location, finalizedValue, parentType);\n }\n}\nfunction registerChildFinalizationCallback(parent, child, key) {\n parent.callbacks_.push(function childCleanup(rootScope) {\n const state = child;\n if (!state || !isSameScope(state, rootScope)) {\n return;\n }\n rootScope.mapSetPlugin_?.fixSetContents(state);\n const finalizedValue = getFinalValue(state);\n updateDraftInParent(parent, state.draft_ ?? state, finalizedValue, key);\n generatePatchesAndFinalize(state, rootScope);\n });\n}\nfunction generatePatchesAndFinalize(state, rootScope) {\n const shouldFinalize = state.modified_ && !state.finalized_ && (state.type_ === 3 /* Set */ || state.type_ === 1 /* Array */ && state.allIndicesReassigned_ || (state.assigned_?.size ?? 0) > 0);\n if (shouldFinalize) {\n const { patchPlugin_ } = rootScope;\n if (patchPlugin_) {\n const basePath = patchPlugin_.getPath(state);\n if (basePath) {\n patchPlugin_.generatePatches_(state, basePath, rootScope);\n }\n }\n markStateFinalized(state);\n }\n}\nfunction handleCrossReference(target, key, value) {\n const { scope_ } = target;\n if (isDraft(value)) {\n const state = value[DRAFT_STATE];\n if (isSameScope(state, scope_)) {\n state.callbacks_.push(function crossReferenceCleanup() {\n prepareCopy(target);\n const finalizedValue = getFinalValue(state);\n updateDraftInParent(target, value, finalizedValue, key);\n });\n }\n } else if (isDraftable(value)) {\n target.callbacks_.push(function nestedDraftCleanup() {\n const targetCopy = latest(target);\n if (target.type_ === 3 /* Set */) {\n if (targetCopy.has(value)) {\n handleValue(value, scope_.handledSet_, scope_);\n }\n } else {\n if (get(targetCopy, key, target.type_) === value) {\n if (scope_.drafts_.length > 1 && (target.assigned_.get(key) ?? false) === true && target.copy_) {\n handleValue(\n get(target.copy_, key, target.type_),\n scope_.handledSet_,\n scope_\n );\n }\n }\n }\n });\n }\n}\nfunction handleValue(target, handledSet, rootScope) {\n if (!rootScope.immer_.autoFreeze_ && rootScope.unfinalizedDrafts_ < 1) {\n return target;\n }\n if (isDraft(target) || handledSet.has(target) || !isDraftable(target) || isFrozen(target)) {\n return target;\n }\n handledSet.add(target);\n each(target, (key, value) => {\n if (isDraft(value)) {\n const state = value[DRAFT_STATE];\n if (isSameScope(state, rootScope)) {\n const updatedValue = getFinalValue(state);\n set(target, key, updatedValue, target.type_);\n markStateFinalized(state);\n }\n } else if (isDraftable(value)) {\n handleValue(value, handledSet, rootScope);\n }\n });\n return target;\n}\n\n// src/core/proxy.ts\nfunction createProxyProxy(base, parent) {\n const baseIsArray = isArray(base);\n const state = {\n type_: baseIsArray ? 1 /* Array */ : 0 /* Object */,\n // Track which produce call this is associated with.\n scope_: parent ? parent.scope_ : getCurrentScope(),\n // True for both shallow and deep changes.\n modified_: false,\n // Used during finalization.\n finalized_: false,\n // Track which properties have been assigned (true) or deleted (false).\n // actually instantiated in `prepareCopy()`\n assigned_: void 0,\n // The parent draft state.\n parent_: parent,\n // The base state.\n base_: base,\n // The base proxy.\n draft_: null,\n // set below\n // The base copy with any updated values.\n copy_: null,\n // Called by the `produce` function.\n revoke_: null,\n isManual_: false,\n // `callbacks` actually gets assigned in `createProxy`\n callbacks_: void 0\n };\n let target = state;\n let traps = objectTraps;\n if (baseIsArray) {\n target = [state];\n traps = arrayTraps;\n }\n const { revoke, proxy } = Proxy.revocable(target, traps);\n state.draft_ = proxy;\n state.revoke_ = revoke;\n return [proxy, state];\n}\nvar objectTraps = {\n get(state, prop) {\n if (prop === DRAFT_STATE)\n return state;\n let arrayPlugin = state.scope_.arrayMethodsPlugin_;\n const isArrayWithStringProp = state.type_ === 1 /* Array */ && typeof prop === \"string\";\n if (isArrayWithStringProp) {\n if (arrayPlugin?.isArrayOperationMethod(prop)) {\n return arrayPlugin.createMethodInterceptor(state, prop);\n }\n }\n const source = latest(state);\n if (!has(source, prop, state.type_)) {\n return readPropFromProto(state, source, prop);\n }\n const value = source[prop];\n if (state.finalized_ || !isDraftable(value)) {\n return value;\n }\n if (isArrayWithStringProp && state.operationMethod && arrayPlugin?.isMutatingArrayMethod(\n state.operationMethod\n ) && isArrayIndex(prop)) {\n return value;\n }\n if (value === peek(state.base_, prop)) {\n prepareCopy(state);\n const childKey = state.type_ === 1 /* Array */ ? +prop : prop;\n const childDraft = createProxy(state.scope_, value, state, childKey);\n return state.copy_[childKey] = childDraft;\n }\n return value;\n },\n has(state, prop) {\n return prop in latest(state);\n },\n ownKeys(state) {\n return Reflect.ownKeys(latest(state));\n },\n set(state, prop, value) {\n const desc = getDescriptorFromProto(latest(state), prop);\n if (desc?.set) {\n desc.set.call(state.draft_, value);\n return true;\n }\n if (!state.modified_) {\n const current2 = peek(latest(state), prop);\n const currentState = current2?.[DRAFT_STATE];\n if (currentState && currentState.base_ === value) {\n state.copy_[prop] = value;\n state.assigned_.set(prop, false);\n return true;\n }\n if (is(value, current2) && (value !== void 0 || has(state.base_, prop, state.type_)))\n return true;\n prepareCopy(state);\n markChanged(state);\n }\n if (state.copy_[prop] === value && // special case: handle new props with value 'undefined'\n (value !== void 0 || prop in state.copy_) || // special case: NaN\n Number.isNaN(value) && Number.isNaN(state.copy_[prop]))\n return true;\n state.copy_[prop] = value;\n state.assigned_.set(prop, true);\n handleCrossReference(state, prop, value);\n return true;\n },\n deleteProperty(state, prop) {\n prepareCopy(state);\n if (peek(state.base_, prop) !== void 0 || prop in state.base_) {\n state.assigned_.set(prop, false);\n markChanged(state);\n } else {\n state.assigned_.delete(prop);\n }\n if (state.copy_) {\n delete state.copy_[prop];\n }\n return true;\n },\n // Note: We never coerce `desc.value` into an Immer draft, because we can't make\n // the same guarantee in ES5 mode.\n getOwnPropertyDescriptor(state, prop) {\n const owner = latest(state);\n const desc = Reflect.getOwnPropertyDescriptor(owner, prop);\n if (!desc)\n return desc;\n return {\n [WRITABLE]: true,\n [CONFIGURABLE]: state.type_ !== 1 /* Array */ || prop !== \"length\",\n [ENUMERABLE]: desc[ENUMERABLE],\n [VALUE]: owner[prop]\n };\n },\n defineProperty() {\n die(11);\n },\n getPrototypeOf(state) {\n return getPrototypeOf(state.base_);\n },\n setPrototypeOf() {\n die(12);\n }\n};\nvar arrayTraps = {};\nfor (let key in objectTraps) {\n let fn = objectTraps[key];\n arrayTraps[key] = function() {\n const args = arguments;\n args[0] = args[0][0];\n return fn.apply(this, args);\n };\n}\narrayTraps.deleteProperty = function(state, prop) {\n if (process.env.NODE_ENV !== \"production\" && isNaN(parseInt(prop)))\n die(13);\n return arrayTraps.set.call(this, state, prop, void 0);\n};\narrayTraps.set = function(state, prop, value) {\n if (process.env.NODE_ENV !== \"production\" && prop !== \"length\" && isNaN(parseInt(prop)))\n die(14);\n return objectTraps.set.call(this, state[0], prop, value, state[0]);\n};\nfunction peek(draft, prop) {\n const state = draft[DRAFT_STATE];\n const source = state ? latest(state) : draft;\n return source[prop];\n}\nfunction readPropFromProto(state, source, prop) {\n const desc = getDescriptorFromProto(source, prop);\n return desc ? VALUE in desc ? desc[VALUE] : (\n // This is a very special case, if the prop is a getter defined by the\n // prototype, we should invoke it with the draft as context!\n desc.get?.call(state.draft_)\n ) : void 0;\n}\nfunction getDescriptorFromProto(source, prop) {\n if (!(prop in source))\n return void 0;\n let proto = getPrototypeOf(source);\n while (proto) {\n const desc = Object.getOwnPropertyDescriptor(proto, prop);\n if (desc)\n return desc;\n proto = getPrototypeOf(proto);\n }\n return void 0;\n}\nfunction markChanged(state) {\n if (!state.modified_) {\n state.modified_ = true;\n if (state.parent_) {\n markChanged(state.parent_);\n }\n }\n}\nfunction prepareCopy(state) {\n if (!state.copy_) {\n state.assigned_ = /* @__PURE__ */ new Map();\n state.copy_ = shallowCopy(\n state.base_,\n state.scope_.immer_.useStrictShallowCopy_\n );\n }\n}\n\n// src/core/immerClass.ts\nvar Immer2 = class {\n constructor(config) {\n this.autoFreeze_ = true;\n this.useStrictShallowCopy_ = false;\n this.useStrictIteration_ = false;\n /**\n * The `produce` function takes a value and a \"recipe function\" (whose\n * return value often depends on the base state). The recipe function is\n * free to mutate its first argument however it wants. All mutations are\n * only ever applied to a __copy__ of the base state.\n *\n * Pass only a function to create a \"curried producer\" which relieves you\n * from passing the recipe function every time.\n *\n * Only plain objects and arrays are made mutable. All other objects are\n * considered uncopyable.\n *\n * Note: This function is __bound__ to its `Immer` instance.\n *\n * @param {any} base - the initial state\n * @param {Function} recipe - function that receives a proxy of the base state as first argument and which can be freely modified\n * @param {Function} patchListener - optional function that will be called with all the patches produced here\n * @returns {any} a new state, or the initial state if nothing was modified\n */\n this.produce = (base, recipe, patchListener) => {\n if (isFunction(base) && !isFunction(recipe)) {\n const defaultBase = recipe;\n recipe = base;\n const self = this;\n return function curriedProduce(base2 = defaultBase, ...args) {\n return self.produce(base2, (draft) => recipe.call(this, draft, ...args));\n };\n }\n if (!isFunction(recipe))\n die(6);\n if (patchListener !== void 0 && !isFunction(patchListener))\n die(7);\n let result;\n if (isDraftable(base)) {\n const scope = enterScope(this);\n const proxy = createProxy(scope, base, void 0);\n let hasError = true;\n try {\n result = recipe(proxy);\n hasError = false;\n } finally {\n if (hasError)\n revokeScope(scope);\n else\n leaveScope(scope);\n }\n usePatchesInScope(scope, patchListener);\n return processResult(result, scope);\n } else if (!base || !isObjectish(base)) {\n result = recipe(base);\n if (result === void 0)\n result = base;\n if (result === NOTHING)\n result = void 0;\n if (this.autoFreeze_)\n freeze(result, true);\n if (patchListener) {\n const p = [];\n const ip = [];\n getPlugin(PluginPatches).generateReplacementPatches_(base, result, {\n patches_: p,\n inversePatches_: ip\n });\n patchListener(p, ip);\n }\n return result;\n } else\n die(1, base);\n };\n this.produceWithPatches = (base, recipe) => {\n if (isFunction(base)) {\n return (state, ...args) => this.produceWithPatches(state, (draft) => base(draft, ...args));\n }\n let patches, inversePatches;\n const result = this.produce(base, recipe, (p, ip) => {\n patches = p;\n inversePatches = ip;\n });\n return [result, patches, inversePatches];\n };\n if (isBoolean(config?.autoFreeze))\n this.setAutoFreeze(config.autoFreeze);\n if (isBoolean(config?.useStrictShallowCopy))\n this.setUseStrictShallowCopy(config.useStrictShallowCopy);\n if (isBoolean(config?.useStrictIteration))\n this.setUseStrictIteration(config.useStrictIteration);\n }\n createDraft(base) {\n if (!isDraftable(base))\n die(8);\n if (isDraft(base))\n base = current(base);\n const scope = enterScope(this);\n const proxy = createProxy(scope, base, void 0);\n proxy[DRAFT_STATE].isManual_ = true;\n leaveScope(scope);\n return proxy;\n }\n finishDraft(draft, patchListener) {\n const state = draft && draft[DRAFT_STATE];\n if (!state || !state.isManual_)\n die(9);\n const { scope_: scope } = state;\n usePatchesInScope(scope, patchListener);\n return processResult(void 0, scope);\n }\n /**\n * Pass true to automatically freeze all copies created by Immer.\n *\n * By default, auto-freezing is enabled.\n */\n setAutoFreeze(value) {\n this.autoFreeze_ = value;\n }\n /**\n * Pass true to enable strict shallow copy.\n *\n * By default, immer does not copy the object descriptors such as getter, setter and non-enumrable properties.\n */\n setUseStrictShallowCopy(value) {\n this.useStrictShallowCopy_ = value;\n }\n /**\n * Pass false to use faster iteration that skips non-enumerable properties\n * but still handles symbols for compatibility.\n *\n * By default, strict iteration is enabled (includes all own properties).\n */\n setUseStrictIteration(value) {\n this.useStrictIteration_ = value;\n }\n shouldUseStrictIteration() {\n return this.useStrictIteration_;\n }\n applyPatches(base, patches) {\n let i;\n for (i = patches.length - 1; i >= 0; i--) {\n const patch = patches[i];\n if (patch.path.length === 0 && patch.op === \"replace\") {\n base = patch.value;\n break;\n }\n }\n if (i > -1) {\n patches = patches.slice(i + 1);\n }\n const applyPatchesImpl = getPlugin(PluginPatches).applyPatches_;\n if (isDraft(base)) {\n return applyPatchesImpl(base, patches);\n }\n return this.produce(\n base,\n (draft) => applyPatchesImpl(draft, patches)\n );\n }\n};\nfunction createProxy(rootScope, value, parent, key) {\n const [draft, state] = isMap(value) ? getPlugin(PluginMapSet).proxyMap_(value, parent) : isSet(value) ? getPlugin(PluginMapSet).proxySet_(value, parent) : createProxyProxy(value, parent);\n const scope = parent?.scope_ ?? getCurrentScope();\n scope.drafts_.push(draft);\n state.callbacks_ = parent?.callbacks_ ?? [];\n state.key_ = key;\n if (parent && key !== void 0) {\n registerChildFinalizationCallback(parent, state, key);\n } else {\n state.callbacks_.push(function rootDraftCleanup(rootScope2) {\n rootScope2.mapSetPlugin_?.fixSetContents(state);\n const { patchPlugin_ } = rootScope2;\n if (state.modified_ && patchPlugin_) {\n patchPlugin_.generatePatches_(state, [], rootScope2);\n }\n });\n }\n return draft;\n}\n\n// src/core/current.ts\nfunction current(value) {\n if (!isDraft(value))\n die(10, value);\n return currentImpl(value);\n}\nfunction currentImpl(value) {\n if (!isDraftable(value) || isFrozen(value))\n return value;\n const state = value[DRAFT_STATE];\n let copy;\n let strict = true;\n if (state) {\n if (!state.modified_)\n return state.base_;\n state.finalized_ = true;\n copy = shallowCopy(value, state.scope_.immer_.useStrictShallowCopy_);\n strict = state.scope_.immer_.shouldUseStrictIteration();\n } else {\n copy = shallowCopy(value, true);\n }\n each(\n copy,\n (key, childValue) => {\n set(copy, key, currentImpl(childValue));\n },\n strict\n );\n if (state) {\n state.finalized_ = false;\n }\n return copy;\n}\n\n// src/plugins/patches.ts\nfunction enablePatches() {\n const errorOffset = 16;\n if (process.env.NODE_ENV !== \"production\") {\n errors.push(\n 'Sets cannot have \"replace\" patches.',\n function(op) {\n return \"Unsupported patch operation: \" + op;\n },\n function(path) {\n return \"Cannot apply patch, path doesn't resolve: \" + path;\n },\n \"Patching reserved attributes like __proto__, prototype and constructor is not allowed\"\n );\n }\n function getPath(state, path = []) {\n if (state.key_ !== void 0) {\n const parentCopy = state.parent_.copy_ ?? state.parent_.base_;\n const proxyDraft = getProxyDraft(get(parentCopy, state.key_));\n const valueAtKey = get(parentCopy, state.key_);\n if (valueAtKey === void 0) {\n return null;\n }\n if (valueAtKey !== state.draft_ && valueAtKey !== state.base_ && valueAtKey !== state.copy_) {\n return null;\n }\n if (proxyDraft != null && proxyDraft.base_ !== state.base_) {\n return null;\n }\n const isSet2 = state.parent_.type_ === 3 /* Set */;\n let key;\n if (isSet2) {\n const setParent = state.parent_;\n key = Array.from(setParent.drafts_.keys()).indexOf(state.key_);\n } else {\n key = state.key_;\n }\n if (!(isSet2 && parentCopy.size > key || has(parentCopy, key))) {\n return null;\n }\n path.push(key);\n }\n if (state.parent_) {\n return getPath(state.parent_, path);\n }\n path.reverse();\n try {\n resolvePath(state.copy_, path);\n } catch (e) {\n return null;\n }\n return path;\n }\n function resolvePath(base, path) {\n let current2 = base;\n for (let i = 0; i < path.length - 1; i++) {\n const key = path[i];\n current2 = get(current2, key);\n if (!isObjectish(current2) || current2 === null) {\n throw new Error(`Cannot resolve path at '${path.join(\"/\")}'`);\n }\n }\n return current2;\n }\n const REPLACE = \"replace\";\n const ADD = \"add\";\n const REMOVE = \"remove\";\n function generatePatches_(state, basePath, scope) {\n if (state.scope_.processedForPatches_.has(state)) {\n return;\n }\n state.scope_.processedForPatches_.add(state);\n const { patches_, inversePatches_ } = scope;\n switch (state.type_) {\n case 0 /* Object */:\n case 2 /* Map */:\n return generatePatchesFromAssigned(\n state,\n basePath,\n patches_,\n inversePatches_\n );\n case 1 /* Array */:\n return generateArrayPatches(\n state,\n basePath,\n patches_,\n inversePatches_\n );\n case 3 /* Set */:\n return generateSetPatches(\n state,\n basePath,\n patches_,\n inversePatches_\n );\n }\n }\n function generateArrayPatches(state, basePath, patches, inversePatches) {\n let { base_, assigned_ } = state;\n let copy_ = state.copy_;\n if (copy_.length < base_.length) {\n ;\n [base_, copy_] = [copy_, base_];\n [patches, inversePatches] = [inversePatches, patches];\n }\n const allReassigned = state.allIndicesReassigned_ === true;\n for (let i = 0; i < base_.length; i++) {\n const copiedItem = copy_[i];\n const baseItem = base_[i];\n const isAssigned = allReassigned || assigned_?.get(i.toString());\n if (isAssigned && copiedItem !== baseItem) {\n const childState = copiedItem?.[DRAFT_STATE];\n if (childState && childState.modified_) {\n continue;\n }\n const path = basePath.concat([i]);\n patches.push({\n op: REPLACE,\n path,\n // Need to maybe clone it, as it can in fact be the original value\n // due to the base/copy inversion at the start of this function\n value: clonePatchValueIfNeeded(copiedItem)\n });\n inversePatches.push({\n op: REPLACE,\n path,\n value: clonePatchValueIfNeeded(baseItem)\n });\n }\n }\n for (let i = base_.length; i < copy_.length; i++) {\n const path = basePath.concat([i]);\n patches.push({\n op: ADD,\n path,\n // Need to maybe clone it, as it can in fact be the original value\n // due to the base/copy inversion at the start of this function\n value: clonePatchValueIfNeeded(copy_[i])\n });\n }\n for (let i = copy_.length - 1; base_.length <= i; --i) {\n const path = basePath.concat([i]);\n inversePatches.push({\n op: REMOVE,\n path\n });\n }\n }\n function generatePatchesFromAssigned(state, basePath, patches, inversePatches) {\n const { base_, copy_, type_ } = state;\n each(state.assigned_, (key, assignedValue) => {\n const origValue = get(base_, key, type_);\n const value = get(copy_, key, type_);\n const op = !assignedValue ? REMOVE : has(base_, key) ? REPLACE : ADD;\n if (origValue === value && op === REPLACE)\n return;\n const path = basePath.concat(key);\n patches.push(\n op === REMOVE ? { op, path } : { op, path, value: clonePatchValueIfNeeded(value) }\n );\n inversePatches.push(\n op === ADD ? { op: REMOVE, path } : op === REMOVE ? { op: ADD, path, value: clonePatchValueIfNeeded(origValue) } : { op: REPLACE, path, value: clonePatchValueIfNeeded(origValue) }\n );\n });\n }\n function generateSetPatches(state, basePath, patches, inversePatches) {\n let { base_, copy_ } = state;\n let i = 0;\n base_.forEach((value) => {\n if (!copy_.has(value)) {\n const path = basePath.concat([i]);\n patches.push({\n op: REMOVE,\n path,\n value\n });\n inversePatches.unshift({\n op: ADD,\n path,\n value\n });\n }\n i++;\n });\n i = 0;\n copy_.forEach((value) => {\n if (!base_.has(value)) {\n const path = basePath.concat([i]);\n patches.push({\n op: ADD,\n path,\n value\n });\n inversePatches.unshift({\n op: REMOVE,\n path,\n value\n });\n }\n i++;\n });\n }\n function generateReplacementPatches_(baseValue, replacement, scope) {\n const { patches_, inversePatches_ } = scope;\n patches_.push({\n op: REPLACE,\n path: [],\n value: replacement === NOTHING ? void 0 : replacement\n });\n inversePatches_.push({\n op: REPLACE,\n path: [],\n value: baseValue\n });\n }\n function applyPatches_(draft, patches) {\n patches.forEach((patch) => {\n const { path, op } = patch;\n let base = draft;\n for (let i = 0; i < path.length - 1; i++) {\n const parentType = getArchtype(base);\n let p = path[i];\n if (typeof p !== \"string\" && typeof p !== \"number\") {\n p = \"\" + p;\n }\n if ((parentType === 0 /* Object */ || parentType === 1 /* Array */) && (p === \"__proto__\" || p === CONSTRUCTOR))\n die(errorOffset + 3);\n if (isFunction(base) && p === PROTOTYPE)\n die(errorOffset + 3);\n base = get(base, p);\n if (!isObjectish(base))\n die(errorOffset + 2, path.join(\"/\"));\n }\n const type = getArchtype(base);\n const value = deepClonePatchValue(patch.value);\n const key = path[path.length - 1];\n switch (op) {\n case REPLACE:\n switch (type) {\n case 2 /* Map */:\n return base.set(key, value);\n case 3 /* Set */:\n die(errorOffset);\n default:\n return base[key] = value;\n }\n case ADD:\n switch (type) {\n case 1 /* Array */:\n return key === \"-\" ? base.push(value) : base.splice(key, 0, value);\n case 2 /* Map */:\n return base.set(key, value);\n case 3 /* Set */:\n return base.add(value);\n default:\n return base[key] = value;\n }\n case REMOVE:\n switch (type) {\n case 1 /* Array */:\n return base.splice(key, 1);\n case 2 /* Map */:\n return base.delete(key);\n case 3 /* Set */:\n return base.delete(patch.value);\n default:\n return delete base[key];\n }\n default:\n die(errorOffset + 1, op);\n }\n });\n return draft;\n }\n function deepClonePatchValue(obj) {\n if (!isDraftable(obj))\n return obj;\n if (isArray(obj))\n return obj.map(deepClonePatchValue);\n if (isMap(obj))\n return new Map(\n Array.from(obj.entries()).map(([k, v]) => [k, deepClonePatchValue(v)])\n );\n if (isSet(obj))\n return new Set(Array.from(obj).map(deepClonePatchValue));\n const cloned = Object.create(getPrototypeOf(obj));\n for (const key in obj)\n cloned[key] = deepClonePatchValue(obj[key]);\n if (has(obj, DRAFTABLE))\n cloned[DRAFTABLE] = obj[DRAFTABLE];\n return cloned;\n }\n function clonePatchValueIfNeeded(obj) {\n if (isDraft(obj)) {\n return deepClonePatchValue(obj);\n } else\n return obj;\n }\n loadPlugin(PluginPatches, {\n applyPatches_,\n generatePatches_,\n generateReplacementPatches_,\n getPath\n });\n}\n\n// src/plugins/mapset.ts\nfunction enableMapSet() {\n class DraftMap extends Map {\n constructor(target, parent) {\n super();\n this[DRAFT_STATE] = {\n type_: 2 /* Map */,\n parent_: parent,\n scope_: parent ? parent.scope_ : getCurrentScope(),\n modified_: false,\n finalized_: false,\n copy_: void 0,\n assigned_: void 0,\n base_: target,\n draft_: this,\n isManual_: false,\n revoked_: false,\n callbacks_: []\n };\n }\n get size() {\n return latest(this[DRAFT_STATE]).size;\n }\n has(key) {\n return latest(this[DRAFT_STATE]).has(key);\n }\n set(key, value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!latest(state).has(key) || latest(state).get(key) !== value) {\n prepareMapCopy(state);\n markChanged(state);\n state.assigned_.set(key, true);\n state.copy_.set(key, value);\n state.assigned_.set(key, true);\n handleCrossReference(state, key, value);\n }\n return this;\n }\n delete(key) {\n if (!this.has(key)) {\n return false;\n }\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareMapCopy(state);\n markChanged(state);\n if (state.base_.has(key)) {\n state.assigned_.set(key, false);\n } else {\n state.assigned_.delete(key);\n }\n state.copy_.delete(key);\n return true;\n }\n clear() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (latest(state).size) {\n prepareMapCopy(state);\n markChanged(state);\n state.assigned_ = /* @__PURE__ */ new Map();\n each(state.base_, (key) => {\n state.assigned_.set(key, false);\n });\n state.copy_.clear();\n }\n }\n forEach(cb, thisArg) {\n const state = this[DRAFT_STATE];\n latest(state).forEach((_value, key, _map) => {\n cb.call(thisArg, this.get(key), key, this);\n });\n }\n get(key) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n const value = latest(state).get(key);\n if (state.finalized_ || !isDraftable(value)) {\n return value;\n }\n if (value !== state.base_.get(key)) {\n return value;\n }\n const draft = createProxy(state.scope_, value, state, key);\n prepareMapCopy(state);\n state.copy_.set(key, draft);\n return draft;\n }\n keys() {\n return latest(this[DRAFT_STATE]).keys();\n }\n values() {\n const iterator = this.keys();\n return {\n [Symbol.iterator]: () => this.values(),\n next: () => {\n const r = iterator.next();\n if (r.done)\n return r;\n const value = this.get(r.value);\n return {\n done: false,\n value\n };\n }\n };\n }\n entries() {\n const iterator = this.keys();\n return {\n [Symbol.iterator]: () => this.entries(),\n next: () => {\n const r = iterator.next();\n if (r.done)\n return r;\n const value = this.get(r.value);\n return {\n done: false,\n value: [r.value, value]\n };\n }\n };\n }\n [(DRAFT_STATE, Symbol.iterator)]() {\n return this.entries();\n }\n }\n function proxyMap_(target, parent) {\n const map = new DraftMap(target, parent);\n return [map, map[DRAFT_STATE]];\n }\n function prepareMapCopy(state) {\n if (!state.copy_) {\n state.assigned_ = /* @__PURE__ */ new Map();\n state.copy_ = new Map(state.base_);\n }\n }\n class DraftSet extends Set {\n constructor(target, parent) {\n super();\n this[DRAFT_STATE] = {\n type_: 3 /* Set */,\n parent_: parent,\n scope_: parent ? parent.scope_ : getCurrentScope(),\n modified_: false,\n finalized_: false,\n copy_: void 0,\n base_: target,\n draft_: this,\n drafts_: /* @__PURE__ */ new Map(),\n revoked_: false,\n isManual_: false,\n assigned_: void 0,\n callbacks_: []\n };\n }\n get size() {\n return latest(this[DRAFT_STATE]).size;\n }\n has(value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!state.copy_) {\n return state.base_.has(value);\n }\n if (state.copy_.has(value))\n return true;\n if (state.drafts_.has(value) && state.copy_.has(state.drafts_.get(value)))\n return true;\n return false;\n }\n add(value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!this.has(value)) {\n prepareSetCopy(state);\n markChanged(state);\n state.copy_.add(value);\n handleCrossReference(state, value, value);\n }\n return this;\n }\n delete(value) {\n if (!this.has(value)) {\n return false;\n }\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n markChanged(state);\n return state.copy_.delete(value) || (state.drafts_.has(value) ? state.copy_.delete(state.drafts_.get(value)) : (\n /* istanbul ignore next */\n false\n ));\n }\n clear() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (latest(state).size) {\n prepareSetCopy(state);\n markChanged(state);\n state.copy_.clear();\n }\n }\n values() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n return state.copy_.values();\n }\n entries() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n return state.copy_.entries();\n }\n keys() {\n return this.values();\n }\n [(DRAFT_STATE, Symbol.iterator)]() {\n return this.values();\n }\n forEach(cb, thisArg) {\n const iterator = this.values();\n let result = iterator.next();\n while (!result.done) {\n cb.call(thisArg, result.value, result.value, this);\n result = iterator.next();\n }\n }\n }\n function proxySet_(target, parent) {\n const set2 = new DraftSet(target, parent);\n return [set2, set2[DRAFT_STATE]];\n }\n function prepareSetCopy(state) {\n if (!state.copy_) {\n state.copy_ = /* @__PURE__ */ new Set();\n state.base_.forEach((value) => {\n if (isDraftable(value)) {\n const draft = createProxy(state.scope_, value, state, value);\n state.drafts_.set(value, draft);\n state.copy_.add(draft);\n } else {\n state.copy_.add(value);\n }\n });\n }\n }\n function assertUnrevoked(state) {\n if (state.revoked_)\n die(3, JSON.stringify(latest(state)));\n }\n function fixSetContents(target) {\n if (target.type_ === 3 /* Set */ && target.copy_) {\n const copy = new Set(target.copy_);\n target.copy_.clear();\n copy.forEach((value) => {\n target.copy_.add(getValue(value));\n });\n }\n }\n loadPlugin(PluginMapSet, { proxyMap_, proxySet_, fixSetContents });\n}\n\n// src/plugins/arrayMethods.ts\nfunction enableArrayMethods() {\n const SHIFTING_METHODS = /* @__PURE__ */ new Set([\"shift\", \"unshift\"]);\n const QUEUE_METHODS = /* @__PURE__ */ new Set([\"push\", \"pop\"]);\n const RESULT_RETURNING_METHODS = /* @__PURE__ */ new Set([\n ...QUEUE_METHODS,\n ...SHIFTING_METHODS\n ]);\n const REORDERING_METHODS = /* @__PURE__ */ new Set([\"reverse\", \"sort\"]);\n const MUTATING_METHODS = /* @__PURE__ */ new Set([\n ...RESULT_RETURNING_METHODS,\n ...REORDERING_METHODS,\n \"splice\"\n ]);\n const FIND_METHODS = /* @__PURE__ */ new Set([\"find\", \"findLast\"]);\n const NON_MUTATING_METHODS = /* @__PURE__ */ new Set([\n \"filter\",\n \"slice\",\n \"concat\",\n \"flat\",\n ...FIND_METHODS,\n \"findIndex\",\n \"findLastIndex\",\n \"some\",\n \"every\",\n \"indexOf\",\n \"lastIndexOf\",\n \"includes\",\n \"join\",\n \"toString\",\n \"toLocaleString\"\n ]);\n function isMutatingArrayMethod(method) {\n return MUTATING_METHODS.has(method);\n }\n function isNonMutatingArrayMethod(method) {\n return NON_MUTATING_METHODS.has(method);\n }\n function isArrayOperationMethod(method) {\n return isMutatingArrayMethod(method) || isNonMutatingArrayMethod(method);\n }\n function enterOperation(state, method) {\n state.operationMethod = method;\n }\n function exitOperation(state) {\n state.operationMethod = void 0;\n }\n function executeArrayMethod(state, operation, markLength = true) {\n prepareCopy(state);\n const result = operation();\n markChanged(state);\n if (markLength)\n state.assigned_.set(\"length\", true);\n return result;\n }\n function markAllIndicesReassigned(state) {\n state.allIndicesReassigned_ = true;\n }\n function normalizeSliceIndex(index, length) {\n if (index < 0) {\n return Math.max(length + index, 0);\n }\n return Math.min(index, length);\n }\n function handleInsertedValues(state, startIndex, values) {\n for (let i = 0; i < values.length; i++) {\n const index = startIndex + i;\n state.assigned_.set(index, true);\n handleCrossReference(state, index, values[i]);\n }\n }\n function handleSimpleOperation(state, method, args) {\n return executeArrayMethod(state, () => {\n const lengthBefore = state.copy_.length;\n const result = state.copy_[method](...args);\n if (SHIFTING_METHODS.has(method)) {\n markAllIndicesReassigned(state);\n }\n if (method === \"push\" && args.length > 0) {\n handleInsertedValues(state, lengthBefore, args);\n } else if (method === \"unshift\" && args.length > 0) {\n handleInsertedValues(state, 0, args);\n }\n return RESULT_RETURNING_METHODS.has(method) ? result : state.draft_;\n });\n }\n function handleReorderingOperation(state, method, args) {\n return executeArrayMethod(\n state,\n () => {\n ;\n state.copy_[method](...args);\n markAllIndicesReassigned(state);\n return state.draft_;\n },\n false\n );\n }\n function createMethodInterceptor(state, originalMethod) {\n return function interceptedMethod(...args) {\n const method = originalMethod;\n enterOperation(state, method);\n try {\n if (isMutatingArrayMethod(method)) {\n if (RESULT_RETURNING_METHODS.has(method)) {\n return handleSimpleOperation(state, method, args);\n }\n if (REORDERING_METHODS.has(method)) {\n return handleReorderingOperation(state, method, args);\n }\n if (method === \"splice\") {\n const res = executeArrayMethod(\n state,\n () => state.copy_.splice(...args)\n );\n markAllIndicesReassigned(state);\n if (args.length > 2) {\n const startIndex = normalizeSliceIndex(\n args[0] ?? 0,\n state.copy_.length\n );\n handleInsertedValues(state, startIndex, args.slice(2));\n }\n return res;\n }\n } else {\n return handleNonMutatingOperation(state, method, args);\n }\n } finally {\n exitOperation(state);\n }\n };\n }\n function handleNonMutatingOperation(state, method, args) {\n const source = latest(state);\n if (method === \"filter\") {\n const predicate = args[0];\n const result = [];\n for (let i = 0; i < source.length; i++) {\n if (predicate(source[i], i, source)) {\n result.push(state.draft_[i]);\n }\n }\n return result;\n }\n if (FIND_METHODS.has(method)) {\n const predicate = args[0];\n const isForward = method === \"find\";\n const step = isForward ? 1 : -1;\n const start = isForward ? 0 : source.length - 1;\n for (let i = start; i >= 0 && i < source.length; i += step) {\n if (predicate(source[i], i, source)) {\n return state.draft_[i];\n }\n }\n return void 0;\n }\n if (method === \"slice\") {\n const rawStart = args[0] ?? 0;\n const rawEnd = args[1] ?? source.length;\n const start = normalizeSliceIndex(rawStart, source.length);\n const end = normalizeSliceIndex(rawEnd, source.length);\n const result = [];\n for (let i = start; i < end; i++) {\n result.push(state.draft_[i]);\n }\n return result;\n }\n return source[method](...args);\n }\n loadPlugin(PluginArrayMethods, {\n createMethodInterceptor,\n isArrayOperationMethod,\n isMutatingArrayMethod\n });\n}\n\n// src/immer.ts\nvar immer = new Immer2();\nvar produce = immer.produce;\nvar produceWithPatches = /* @__PURE__ */ immer.produceWithPatches.bind(immer);\nvar setAutoFreeze = /* @__PURE__ */ immer.setAutoFreeze.bind(immer);\nvar setUseStrictShallowCopy = /* @__PURE__ */ immer.setUseStrictShallowCopy.bind(immer);\nvar setUseStrictIteration = /* @__PURE__ */ immer.setUseStrictIteration.bind(immer);\nvar applyPatches = /* @__PURE__ */ immer.applyPatches.bind(immer);\nvar createDraft = /* @__PURE__ */ immer.createDraft.bind(immer);\nvar finishDraft = /* @__PURE__ */ immer.finishDraft.bind(immer);\nvar castDraft = (value) => value;\nvar castImmutable = (value) => value;\nexport {\n Immer2 as Immer,\n applyPatches,\n castDraft,\n castImmutable,\n createDraft,\n current,\n enableArrayMethods,\n enableMapSet,\n enablePatches,\n finishDraft,\n freeze,\n DRAFTABLE as immerable,\n isDraft,\n isDraftable,\n NOTHING as nothing,\n original,\n produce,\n produceWithPatches,\n setAutoFreeze,\n setUseStrictIteration,\n setUseStrictShallowCopy\n};\n//# sourceMappingURL=immer.mjs.map","// src/index.ts\nfunction createThunkMiddleware(extraArgument) {\n const middleware = ({ dispatch, getState }) => (next) => (action) => {\n if (typeof action === \"function\") {\n return action(dispatch, getState, extraArgument);\n }\n return next(action);\n };\n return middleware;\n}\nvar thunk = createThunkMiddleware();\nvar withExtraArgument = createThunkMiddleware;\nexport {\n thunk,\n withExtraArgument\n};\n","// src/index.ts\nexport * from \"redux\";\nimport { freeze, original as original2 } from \"immer\";\n\n// src/immerImports.ts\nimport { current, isDraft, produce, isDraftable, setUseStrictIteration } from \"immer\";\n\n// src/index.ts\nimport { createSelector, lruMemoize } from \"reselect\";\n\n// src/reselectImports.ts\nimport { createSelectorCreator, weakMapMemoize } from \"reselect\";\n\n// src/createDraftSafeSelector.ts\nvar createDraftSafeSelectorCreator = (...args) => {\n const createSelector2 = createSelectorCreator(...args);\n const createDraftSafeSelector2 = Object.assign((...args2) => {\n const selector = createSelector2(...args2);\n const wrappedSelector = (value, ...rest) => selector(isDraft(value) ? current(value) : value, ...rest);\n Object.assign(wrappedSelector, selector);\n return wrappedSelector;\n }, {\n withTypes: () => createDraftSafeSelector2\n });\n return createDraftSafeSelector2;\n};\nvar createDraftSafeSelector = /* @__PURE__ */ createDraftSafeSelectorCreator(weakMapMemoize);\n\n// src/reduxImports.ts\nimport { createStore, combineReducers, applyMiddleware, compose, isPlainObject, isAction } from \"redux\";\n\n// src/devtoolsExtension.ts\nvar composeWithDevTools = typeof window !== \"undefined\" && window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ ? window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ : function() {\n if (arguments.length === 0) return void 0;\n if (typeof arguments[0] === \"object\") return compose;\n return compose.apply(null, arguments);\n};\nvar devToolsEnhancer = typeof window !== \"undefined\" && window.__REDUX_DEVTOOLS_EXTENSION__ ? window.__REDUX_DEVTOOLS_EXTENSION__ : function() {\n return function(noop3) {\n return noop3;\n };\n};\n\n// src/getDefaultMiddleware.ts\nimport { thunk as thunkMiddleware, withExtraArgument } from \"redux-thunk\";\n\n// src/tsHelpers.ts\nvar hasMatchFunction = (v) => {\n return v && typeof v.match === \"function\";\n};\n\n// src/createAction.ts\nfunction createAction(type, prepareAction) {\n function actionCreator(...args) {\n if (prepareAction) {\n let prepared = prepareAction(...args);\n if (!prepared) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(0) : \"prepareAction did not return an object\");\n }\n return {\n type,\n payload: prepared.payload,\n ...\"meta\" in prepared && {\n meta: prepared.meta\n },\n ...\"error\" in prepared && {\n error: prepared.error\n }\n };\n }\n return {\n type,\n payload: args[0]\n };\n }\n actionCreator.toString = () => `${type}`;\n actionCreator.type = type;\n actionCreator.match = (action) => isAction(action) && action.type === type;\n return actionCreator;\n}\nfunction isActionCreator(action) {\n return typeof action === \"function\" && \"type\" in action && // hasMatchFunction only wants Matchers but I don't see the point in rewriting it\n hasMatchFunction(action);\n}\nfunction isFSA(action) {\n return isAction(action) && Object.keys(action).every(isValidKey);\n}\nfunction isValidKey(key) {\n return [\"type\", \"payload\", \"error\", \"meta\"].indexOf(key) > -1;\n}\n\n// src/actionCreatorInvariantMiddleware.ts\nfunction getMessage(type) {\n const splitType = type ? `${type}`.split(\"/\") : [];\n const actionName = splitType[splitType.length - 1] || \"actionCreator\";\n return `Detected an action creator with type \"${type || \"unknown\"}\" being dispatched. \nMake sure you're calling the action creator before dispatching, i.e. \\`dispatch(${actionName}())\\` instead of \\`dispatch(${actionName})\\`. This is necessary even if the action has no payload.`;\n}\nfunction createActionCreatorInvariantMiddleware(options = {}) {\n if (process.env.NODE_ENV === \"production\") {\n return () => (next) => (action) => next(action);\n }\n const {\n isActionCreator: isActionCreator2 = isActionCreator\n } = options;\n return () => (next) => (action) => {\n if (isActionCreator2(action)) {\n console.warn(getMessage(action.type));\n }\n return next(action);\n };\n}\n\n// src/utils.ts\nfunction getTimeMeasureUtils(maxDelay, fnName) {\n let elapsed = 0;\n return {\n measureTime(fn) {\n const started = Date.now();\n try {\n return fn();\n } finally {\n const finished = Date.now();\n elapsed += finished - started;\n }\n },\n warnIfExceeded() {\n if (elapsed > maxDelay) {\n console.warn(`${fnName} took ${elapsed}ms, which is more than the warning threshold of ${maxDelay}ms. \nIf your state or actions are very large, you may want to disable the middleware as it might cause too much of a slowdown in development mode. See https://redux-toolkit.js.org/api/getDefaultMiddleware for instructions.\nIt is disabled in production builds, so you don't need to worry about that.`);\n }\n }\n };\n}\nvar Tuple = class _Tuple extends Array {\n constructor(...items) {\n super(...items);\n Object.setPrototypeOf(this, _Tuple.prototype);\n }\n static get [Symbol.species]() {\n return _Tuple;\n }\n concat(...arr) {\n return super.concat.apply(this, arr);\n }\n prepend(...arr) {\n if (arr.length === 1 && Array.isArray(arr[0])) {\n return new _Tuple(...arr[0].concat(this));\n }\n return new _Tuple(...arr.concat(this));\n }\n};\nfunction freezeDraftable(val) {\n return isDraftable(val) ? produce(val, () => {\n }) : val;\n}\nfunction getOrInsertComputed(map, key, compute) {\n if (map.has(key)) return map.get(key);\n return map.set(key, compute(key)).get(key);\n}\n\n// src/immutableStateInvariantMiddleware.ts\nfunction isImmutableDefault(value) {\n return typeof value !== \"object\" || value == null || Object.isFrozen(value);\n}\nfunction trackForMutations(isImmutable, ignoredPaths, obj) {\n const trackedProperties = trackProperties(isImmutable, ignoredPaths, obj);\n return {\n detectMutations() {\n return detectMutations(isImmutable, ignoredPaths, trackedProperties, obj);\n }\n };\n}\nfunction trackProperties(isImmutable, ignoredPaths = [], obj, path = \"\", checkedObjects = /* @__PURE__ */ new Set()) {\n const tracked = {\n value: obj\n };\n if (!isImmutable(obj) && !checkedObjects.has(obj)) {\n checkedObjects.add(obj);\n tracked.children = {};\n const hasIgnoredPaths = ignoredPaths.length > 0;\n for (const key in obj) {\n const nestedPath = path ? path + \".\" + key : key;\n if (hasIgnoredPaths) {\n const hasMatches = ignoredPaths.some((ignored) => {\n if (ignored instanceof RegExp) {\n return ignored.test(nestedPath);\n }\n return nestedPath === ignored;\n });\n if (hasMatches) {\n continue;\n }\n }\n tracked.children[key] = trackProperties(isImmutable, ignoredPaths, obj[key], nestedPath);\n }\n }\n return tracked;\n}\nfunction detectMutations(isImmutable, ignoredPaths = [], trackedProperty, obj, sameParentRef = false, path = \"\") {\n const prevObj = trackedProperty ? trackedProperty.value : void 0;\n const sameRef = prevObj === obj;\n if (sameParentRef && !sameRef && !Number.isNaN(obj)) {\n return {\n wasMutated: true,\n path\n };\n }\n if (isImmutable(prevObj) || isImmutable(obj)) {\n return {\n wasMutated: false\n };\n }\n const keysToDetect = {};\n for (let key in trackedProperty.children) {\n keysToDetect[key] = true;\n }\n for (let key in obj) {\n keysToDetect[key] = true;\n }\n const hasIgnoredPaths = ignoredPaths.length > 0;\n for (let key in keysToDetect) {\n const nestedPath = path ? path + \".\" + key : key;\n if (hasIgnoredPaths) {\n const hasMatches = ignoredPaths.some((ignored) => {\n if (ignored instanceof RegExp) {\n return ignored.test(nestedPath);\n }\n return nestedPath === ignored;\n });\n if (hasMatches) {\n continue;\n }\n }\n const result = detectMutations(isImmutable, ignoredPaths, trackedProperty.children[key], obj[key], sameRef, nestedPath);\n if (result.wasMutated) {\n return result;\n }\n }\n return {\n wasMutated: false\n };\n}\nfunction createImmutableStateInvariantMiddleware(options = {}) {\n if (process.env.NODE_ENV === \"production\") {\n return () => (next) => (action) => next(action);\n } else {\n let stringify2 = function(obj, serializer, indent, decycler) {\n return JSON.stringify(obj, getSerialize2(serializer, decycler), indent);\n }, getSerialize2 = function(serializer, decycler) {\n let stack = [], keys = [];\n if (!decycler) decycler = function(_, value) {\n if (stack[0] === value) return \"[Circular ~]\";\n return \"[Circular ~.\" + keys.slice(0, stack.indexOf(value)).join(\".\") + \"]\";\n };\n return function(key, value) {\n if (stack.length > 0) {\n var thisPos = stack.indexOf(this);\n ~thisPos ? stack.splice(thisPos + 1) : stack.push(this);\n ~thisPos ? keys.splice(thisPos, Infinity, key) : keys.push(key);\n if (~stack.indexOf(value)) value = decycler.call(this, key, value);\n } else stack.push(value);\n return serializer == null ? value : serializer.call(this, key, value);\n };\n };\n var stringify = stringify2, getSerialize = getSerialize2;\n let {\n isImmutable = isImmutableDefault,\n ignoredPaths,\n warnAfter = 32\n } = options;\n const track = trackForMutations.bind(null, isImmutable, ignoredPaths);\n return ({\n getState\n }) => {\n let state = getState();\n let tracker = track(state);\n let result;\n return (next) => (action) => {\n const measureUtils = getTimeMeasureUtils(warnAfter, \"ImmutableStateInvariantMiddleware\");\n measureUtils.measureTime(() => {\n state = getState();\n result = tracker.detectMutations();\n tracker = track(state);\n if (result.wasMutated) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(19) : `A state mutation was detected between dispatches, in the path '${result.path || \"\"}'. This may cause incorrect behavior. (https://redux.js.org/style-guide/style-guide#do-not-mutate-state)`);\n }\n });\n const dispatchedAction = next(action);\n measureUtils.measureTime(() => {\n state = getState();\n result = tracker.detectMutations();\n tracker = track(state);\n if (result.wasMutated) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(20) : `A state mutation was detected inside a dispatch, in the path: ${result.path || \"\"}. Take a look at the reducer(s) handling the action ${stringify2(action)}. (https://redux.js.org/style-guide/style-guide#do-not-mutate-state)`);\n }\n });\n measureUtils.warnIfExceeded();\n return dispatchedAction;\n };\n };\n }\n}\n\n// src/serializableStateInvariantMiddleware.ts\nfunction isPlain(val) {\n const type = typeof val;\n return val == null || type === \"string\" || type === \"boolean\" || type === \"number\" || Array.isArray(val) || isPlainObject(val);\n}\nfunction findNonSerializableValue(value, path = \"\", isSerializable = isPlain, getEntries, ignoredPaths = [], cache) {\n let foundNestedSerializable;\n if (!isSerializable(value)) {\n return {\n keyPath: path || \"<root>\",\n value\n };\n }\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n if (cache?.has(value)) return false;\n const entries = getEntries != null ? getEntries(value) : Object.entries(value);\n const hasIgnoredPaths = ignoredPaths.length > 0;\n for (const [key, nestedValue] of entries) {\n const nestedPath = path ? path + \".\" + key : key;\n if (hasIgnoredPaths) {\n const hasMatches = ignoredPaths.some((ignored) => {\n if (ignored instanceof RegExp) {\n return ignored.test(nestedPath);\n }\n return nestedPath === ignored;\n });\n if (hasMatches) {\n continue;\n }\n }\n if (!isSerializable(nestedValue)) {\n return {\n keyPath: nestedPath,\n value: nestedValue\n };\n }\n if (typeof nestedValue === \"object\") {\n foundNestedSerializable = findNonSerializableValue(nestedValue, nestedPath, isSerializable, getEntries, ignoredPaths, cache);\n if (foundNestedSerializable) {\n return foundNestedSerializable;\n }\n }\n }\n if (cache && isNestedFrozen(value)) cache.add(value);\n return false;\n}\nfunction isNestedFrozen(value) {\n if (!Object.isFrozen(value)) return false;\n for (const nestedValue of Object.values(value)) {\n if (typeof nestedValue !== \"object\" || nestedValue === null) continue;\n if (!isNestedFrozen(nestedValue)) return false;\n }\n return true;\n}\nfunction createSerializableStateInvariantMiddleware(options = {}) {\n if (process.env.NODE_ENV === \"production\") {\n return () => (next) => (action) => next(action);\n } else {\n const {\n isSerializable = isPlain,\n getEntries,\n ignoredActions = [],\n ignoredActionPaths = [\"meta.arg\", \"meta.baseQueryMeta\"],\n ignoredPaths = [],\n warnAfter = 32,\n ignoreState = false,\n ignoreActions = false,\n disableCache = false\n } = options;\n const cache = !disableCache && WeakSet ? /* @__PURE__ */ new WeakSet() : void 0;\n return (storeAPI) => (next) => (action) => {\n if (!isAction(action)) {\n return next(action);\n }\n const result = next(action);\n const measureUtils = getTimeMeasureUtils(warnAfter, \"SerializableStateInvariantMiddleware\");\n if (!ignoreActions && !(ignoredActions.length && ignoredActions.indexOf(action.type) !== -1)) {\n measureUtils.measureTime(() => {\n const foundActionNonSerializableValue = findNonSerializableValue(action, \"\", isSerializable, getEntries, ignoredActionPaths, cache);\n if (foundActionNonSerializableValue) {\n const {\n keyPath,\n value\n } = foundActionNonSerializableValue;\n console.error(`A non-serializable value was detected in an action, in the path: \\`${keyPath}\\`. Value:`, value, \"\\nTake a look at the logic that dispatched this action: \", action, \"\\n(See https://redux.js.org/faq/actions#why-should-type-be-a-string-or-at-least-serializable-why-should-my-action-types-be-constants)\", \"\\n(To allow non-serializable values see: https://redux-toolkit.js.org/usage/usage-guide#working-with-non-serializable-data)\");\n }\n });\n }\n if (!ignoreState) {\n measureUtils.measureTime(() => {\n const state = storeAPI.getState();\n const foundStateNonSerializableValue = findNonSerializableValue(state, \"\", isSerializable, getEntries, ignoredPaths, cache);\n if (foundStateNonSerializableValue) {\n const {\n keyPath,\n value\n } = foundStateNonSerializableValue;\n console.error(`A non-serializable value was detected in the state, in the path: \\`${keyPath}\\`. Value:`, value, `\nTake a look at the reducer(s) handling this action type: ${action.type}.\n(See https://redux.js.org/faq/organizing-state#can-i-put-functions-promises-or-other-non-serializable-items-in-my-store-state)`);\n }\n });\n measureUtils.warnIfExceeded();\n }\n return result;\n };\n }\n}\n\n// src/getDefaultMiddleware.ts\nfunction isBoolean(x) {\n return typeof x === \"boolean\";\n}\nvar buildGetDefaultMiddleware = () => function getDefaultMiddleware(options) {\n const {\n thunk = true,\n immutableCheck = true,\n serializableCheck = true,\n actionCreatorCheck = true\n } = options ?? {};\n let middlewareArray = new Tuple();\n if (thunk) {\n if (isBoolean(thunk)) {\n middlewareArray.push(thunkMiddleware);\n } else {\n middlewareArray.push(withExtraArgument(thunk.extraArgument));\n }\n }\n if (process.env.NODE_ENV !== \"production\") {\n if (immutableCheck) {\n let immutableOptions = {};\n if (!isBoolean(immutableCheck)) {\n immutableOptions = immutableCheck;\n }\n middlewareArray.unshift(createImmutableStateInvariantMiddleware(immutableOptions));\n }\n if (serializableCheck) {\n let serializableOptions = {};\n if (!isBoolean(serializableCheck)) {\n serializableOptions = serializableCheck;\n }\n middlewareArray.push(createSerializableStateInvariantMiddleware(serializableOptions));\n }\n if (actionCreatorCheck) {\n let actionCreatorOptions = {};\n if (!isBoolean(actionCreatorCheck)) {\n actionCreatorOptions = actionCreatorCheck;\n }\n middlewareArray.unshift(createActionCreatorInvariantMiddleware(actionCreatorOptions));\n }\n }\n return middlewareArray;\n};\n\n// src/autoBatchEnhancer.ts\nvar SHOULD_AUTOBATCH = \"RTK_autoBatch\";\nvar prepareAutoBatched = () => (payload) => ({\n payload,\n meta: {\n [SHOULD_AUTOBATCH]: true\n }\n});\nvar createQueueWithTimer = (timeout) => {\n return (notify) => {\n setTimeout(notify, timeout);\n };\n};\nvar autoBatchEnhancer = (options = {\n type: \"raf\"\n}) => (next) => (...args) => {\n const store = next(...args);\n let notifying = true;\n let shouldNotifyAtEndOfTick = false;\n let notificationQueued = false;\n const listeners = /* @__PURE__ */ new Set();\n const queueCallback = options.type === \"tick\" ? queueMicrotask : options.type === \"raf\" ? (\n // requestAnimationFrame won't exist in SSR environments. Fall back to a vague approximation just to keep from erroring.\n typeof window !== \"undefined\" && window.requestAnimationFrame ? window.requestAnimationFrame : createQueueWithTimer(10)\n ) : options.type === \"callback\" ? options.queueNotification : createQueueWithTimer(options.timeout);\n const notifyListeners = () => {\n notificationQueued = false;\n if (shouldNotifyAtEndOfTick) {\n shouldNotifyAtEndOfTick = false;\n listeners.forEach((l) => l());\n }\n };\n return Object.assign({}, store, {\n // Override the base `store.subscribe` method to keep original listeners\n // from running if we're delaying notifications\n subscribe(listener2) {\n const wrappedListener = () => notifying && listener2();\n const unsubscribe = store.subscribe(wrappedListener);\n listeners.add(listener2);\n return () => {\n unsubscribe();\n listeners.delete(listener2);\n };\n },\n // Override the base `store.dispatch` method so that we can check actions\n // for the `shouldAutoBatch` flag and determine if batching is active\n dispatch(action) {\n try {\n notifying = !action?.meta?.[SHOULD_AUTOBATCH];\n shouldNotifyAtEndOfTick = !notifying;\n if (shouldNotifyAtEndOfTick) {\n if (!notificationQueued) {\n notificationQueued = true;\n queueCallback(notifyListeners);\n }\n }\n return store.dispatch(action);\n } finally {\n notifying = true;\n }\n }\n });\n};\n\n// src/getDefaultEnhancers.ts\nvar buildGetDefaultEnhancers = (middlewareEnhancer) => function getDefaultEnhancers(options) {\n const {\n autoBatch = true\n } = options ?? {};\n let enhancerArray = new Tuple(middlewareEnhancer);\n if (autoBatch) {\n enhancerArray.push(autoBatchEnhancer(typeof autoBatch === \"object\" ? autoBatch : void 0));\n }\n return enhancerArray;\n};\n\n// src/configureStore.ts\nfunction configureStore(options) {\n const getDefaultMiddleware = buildGetDefaultMiddleware();\n const {\n reducer = void 0,\n middleware,\n devTools = true,\n duplicateMiddlewareCheck = true,\n preloadedState = void 0,\n enhancers = void 0\n } = options || {};\n let rootReducer;\n if (typeof reducer === \"function\") {\n rootReducer = reducer;\n } else if (isPlainObject(reducer)) {\n rootReducer = combineReducers(reducer);\n } else {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(1) : \"`reducer` is a required argument, and must be a function or an object of functions that can be passed to combineReducers\");\n }\n if (process.env.NODE_ENV !== \"production\" && middleware && typeof middleware !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(2) : \"`middleware` field must be a callback\");\n }\n let finalMiddleware;\n if (typeof middleware === \"function\") {\n finalMiddleware = middleware(getDefaultMiddleware);\n if (process.env.NODE_ENV !== \"production\" && !Array.isArray(finalMiddleware)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(3) : \"when using a middleware builder function, an array of middleware must be returned\");\n }\n } else {\n finalMiddleware = getDefaultMiddleware();\n }\n if (process.env.NODE_ENV !== \"production\" && finalMiddleware.some((item) => typeof item !== \"function\")) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(4) : \"each middleware provided to configureStore must be a function\");\n }\n if (process.env.NODE_ENV !== \"production\" && duplicateMiddlewareCheck) {\n let middlewareReferences = /* @__PURE__ */ new Set();\n finalMiddleware.forEach((middleware2) => {\n if (middlewareReferences.has(middleware2)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(42) : \"Duplicate middleware references found when creating the store. Ensure that each middleware is only included once.\");\n }\n middlewareReferences.add(middleware2);\n });\n }\n let finalCompose = compose;\n if (devTools) {\n finalCompose = composeWithDevTools({\n // Enable capture of stack traces for dispatched Redux actions\n trace: process.env.NODE_ENV !== \"production\",\n ...typeof devTools === \"object\" && devTools\n });\n }\n const middlewareEnhancer = applyMiddleware(...finalMiddleware);\n const getDefaultEnhancers = buildGetDefaultEnhancers(middlewareEnhancer);\n if (process.env.NODE_ENV !== \"production\" && enhancers && typeof enhancers !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(5) : \"`enhancers` field must be a callback\");\n }\n let storeEnhancers = typeof enhancers === \"function\" ? enhancers(getDefaultEnhancers) : getDefaultEnhancers();\n if (process.env.NODE_ENV !== \"production\" && !Array.isArray(storeEnhancers)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(6) : \"`enhancers` callback must return an array\");\n }\n if (process.env.NODE_ENV !== \"production\" && storeEnhancers.some((item) => typeof item !== \"function\")) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(7) : \"each enhancer provided to configureStore must be a function\");\n }\n if (process.env.NODE_ENV !== \"production\" && finalMiddleware.length && !storeEnhancers.includes(middlewareEnhancer)) {\n console.error(\"middlewares were provided, but middleware enhancer was not included in final enhancers - make sure to call `getDefaultEnhancers`\");\n }\n const composedEnhancer = finalCompose(...storeEnhancers);\n return createStore(rootReducer, preloadedState, composedEnhancer);\n}\n\n// src/mapBuilders.ts\nfunction executeReducerBuilderCallback(builderCallback) {\n const actionsMap = {};\n const actionMatchers = [];\n let defaultCaseReducer;\n const builder = {\n addCase(typeOrActionCreator, reducer) {\n if (process.env.NODE_ENV !== \"production\") {\n if (actionMatchers.length > 0) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(26) : \"`builder.addCase` should only be called before calling `builder.addMatcher`\");\n }\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(27) : \"`builder.addCase` should only be called before calling `builder.addDefaultCase`\");\n }\n }\n const type = typeof typeOrActionCreator === \"string\" ? typeOrActionCreator : typeOrActionCreator.type;\n if (!type) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(28) : \"`builder.addCase` cannot be called with an empty action type\");\n }\n if (type in actionsMap) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(29) : `\\`builder.addCase\\` cannot be called with two reducers for the same action type '${type}'`);\n }\n actionsMap[type] = reducer;\n return builder;\n },\n addAsyncThunk(asyncThunk, reducers) {\n if (process.env.NODE_ENV !== \"production\") {\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(43) : \"`builder.addAsyncThunk` should only be called before calling `builder.addDefaultCase`\");\n }\n }\n if (reducers.pending) actionsMap[asyncThunk.pending.type] = reducers.pending;\n if (reducers.rejected) actionsMap[asyncThunk.rejected.type] = reducers.rejected;\n if (reducers.fulfilled) actionsMap[asyncThunk.fulfilled.type] = reducers.fulfilled;\n if (reducers.settled) actionMatchers.push({\n matcher: asyncThunk.settled,\n reducer: reducers.settled\n });\n return builder;\n },\n addMatcher(matcher, reducer) {\n if (process.env.NODE_ENV !== \"production\") {\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(30) : \"`builder.addMatcher` should only be called before calling `builder.addDefaultCase`\");\n }\n }\n actionMatchers.push({\n matcher,\n reducer\n });\n return builder;\n },\n addDefaultCase(reducer) {\n if (process.env.NODE_ENV !== \"production\") {\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(31) : \"`builder.addDefaultCase` can only be called once\");\n }\n }\n defaultCaseReducer = reducer;\n return builder;\n }\n };\n builderCallback(builder);\n return [actionsMap, actionMatchers, defaultCaseReducer];\n}\n\n// src/createReducer.ts\nfunction isStateFunction(x) {\n return typeof x === \"function\";\n}\nfunction createReducer(initialState, mapOrBuilderCallback) {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof mapOrBuilderCallback === \"object\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(8) : \"The object notation for `createReducer` has been removed. Please use the 'builder callback' notation instead: https://redux-toolkit.js.org/api/createReducer\");\n }\n }\n let [actionsMap, finalActionMatchers, finalDefaultCaseReducer] = executeReducerBuilderCallback(mapOrBuilderCallback);\n let getInitialState;\n if (isStateFunction(initialState)) {\n getInitialState = () => freezeDraftable(initialState());\n } else {\n const frozenInitialState = freezeDraftable(initialState);\n getInitialState = () => frozenInitialState;\n }\n function reducer(state = getInitialState(), action) {\n let caseReducers = [actionsMap[action.type], ...finalActionMatchers.filter(({\n matcher\n }) => matcher(action)).map(({\n reducer: reducer2\n }) => reducer2)];\n if (caseReducers.filter((cr) => !!cr).length === 0) {\n caseReducers = [finalDefaultCaseReducer];\n }\n return caseReducers.reduce((previousState, caseReducer) => {\n if (caseReducer) {\n if (isDraft(previousState)) {\n const draft = previousState;\n const result = caseReducer(draft, action);\n if (result === void 0) {\n return previousState;\n }\n return result;\n } else if (!isDraftable(previousState)) {\n const result = caseReducer(previousState, action);\n if (result === void 0) {\n if (previousState === null) {\n return previousState;\n }\n throw Error(\"A case reducer on a non-draftable value must not return undefined\");\n }\n return result;\n } else {\n return produce(previousState, (draft) => {\n return caseReducer(draft, action);\n });\n }\n }\n return previousState;\n }, state);\n }\n reducer.getInitialState = getInitialState;\n return reducer;\n}\n\n// src/matchers.ts\nvar matches = (matcher, action) => {\n if (hasMatchFunction(matcher)) {\n return matcher.match(action);\n } else {\n return matcher(action);\n }\n};\nfunction isAnyOf(...matchers) {\n return (action) => {\n return matchers.some((matcher) => matches(matcher, action));\n };\n}\nfunction isAllOf(...matchers) {\n return (action) => {\n return matchers.every((matcher) => matches(matcher, action));\n };\n}\nfunction hasExpectedRequestMetadata(action, validStatus) {\n if (!action || !action.meta) return false;\n const hasValidRequestId = typeof action.meta.requestId === \"string\";\n const hasValidRequestStatus = validStatus.indexOf(action.meta.requestStatus) > -1;\n return hasValidRequestId && hasValidRequestStatus;\n}\nfunction isAsyncThunkArray(a) {\n return typeof a[0] === \"function\" && \"pending\" in a[0] && \"fulfilled\" in a[0] && \"rejected\" in a[0];\n}\nfunction isPending(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"pending\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isPending()(asyncThunks[0]);\n }\n return isAnyOf(...asyncThunks.map((asyncThunk) => asyncThunk.pending));\n}\nfunction isRejected(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"rejected\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isRejected()(asyncThunks[0]);\n }\n return isAnyOf(...asyncThunks.map((asyncThunk) => asyncThunk.rejected));\n}\nfunction isRejectedWithValue(...asyncThunks) {\n const hasFlag = (action) => {\n return action && action.meta && action.meta.rejectedWithValue;\n };\n if (asyncThunks.length === 0) {\n return isAllOf(isRejected(...asyncThunks), hasFlag);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isRejectedWithValue()(asyncThunks[0]);\n }\n return isAllOf(isRejected(...asyncThunks), hasFlag);\n}\nfunction isFulfilled(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"fulfilled\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isFulfilled()(asyncThunks[0]);\n }\n return isAnyOf(...asyncThunks.map((asyncThunk) => asyncThunk.fulfilled));\n}\nfunction isAsyncThunkAction(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"pending\", \"fulfilled\", \"rejected\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isAsyncThunkAction()(asyncThunks[0]);\n }\n return isAnyOf(...asyncThunks.flatMap((asyncThunk) => [asyncThunk.pending, asyncThunk.rejected, asyncThunk.fulfilled]));\n}\n\n// src/nanoid.ts\nvar urlAlphabet = \"ModuleSymbhasOwnPr-0123456789ABCDEFGHNRVfgctiUvz_KqYTJkLxpZXIjQW\";\nvar nanoid = (size = 21) => {\n let id = \"\";\n let i = size;\n while (i--) {\n id += urlAlphabet[Math.random() * 64 | 0];\n }\n return id;\n};\n\n// src/createAsyncThunk.ts\nvar commonProperties = [\"name\", \"message\", \"stack\", \"code\"];\nvar RejectWithValue = class {\n constructor(payload, meta) {\n this.payload = payload;\n this.meta = meta;\n }\n /*\n type-only property to distinguish between RejectWithValue and FulfillWithMeta\n does not exist at runtime\n */\n _type;\n};\nvar FulfillWithMeta = class {\n constructor(payload, meta) {\n this.payload = payload;\n this.meta = meta;\n }\n /*\n type-only property to distinguish between RejectWithValue and FulfillWithMeta\n does not exist at runtime\n */\n _type;\n};\nvar miniSerializeError = (value) => {\n if (typeof value === \"object\" && value !== null) {\n const simpleError = {};\n for (const property of commonProperties) {\n if (typeof value[property] === \"string\") {\n simpleError[property] = value[property];\n }\n }\n return simpleError;\n }\n return {\n message: String(value)\n };\n};\nvar externalAbortMessage = \"External signal was aborted\";\nvar createAsyncThunk = /* @__PURE__ */ (() => {\n function createAsyncThunk2(typePrefix, payloadCreator, options) {\n const fulfilled = createAction(typePrefix + \"/fulfilled\", (payload, requestId, arg, meta) => ({\n payload,\n meta: {\n ...meta || {},\n arg,\n requestId,\n requestStatus: \"fulfilled\"\n }\n }));\n const pending = createAction(typePrefix + \"/pending\", (requestId, arg, meta) => ({\n payload: void 0,\n meta: {\n ...meta || {},\n arg,\n requestId,\n requestStatus: \"pending\"\n }\n }));\n const rejected = createAction(typePrefix + \"/rejected\", (error, requestId, arg, payload, meta) => ({\n payload,\n error: (options && options.serializeError || miniSerializeError)(error || \"Rejected\"),\n meta: {\n ...meta || {},\n arg,\n requestId,\n rejectedWithValue: !!payload,\n requestStatus: \"rejected\",\n aborted: error?.name === \"AbortError\",\n condition: error?.name === \"ConditionError\"\n }\n }));\n function actionCreator(arg, {\n signal\n } = {}) {\n return (dispatch, getState, extra) => {\n const requestId = options?.idGenerator ? options.idGenerator(arg) : nanoid();\n const abortController = new AbortController();\n let abortHandler;\n let abortReason;\n function abort(reason) {\n abortReason = reason;\n abortController.abort();\n }\n if (signal) {\n if (signal.aborted) {\n abort(externalAbortMessage);\n } else {\n signal.addEventListener(\"abort\", () => abort(externalAbortMessage), {\n once: true\n });\n }\n }\n const promise = async function() {\n let finalAction;\n try {\n let conditionResult = options?.condition?.(arg, {\n getState,\n extra\n });\n if (isThenable(conditionResult)) {\n conditionResult = await conditionResult;\n }\n if (conditionResult === false || abortController.signal.aborted) {\n throw {\n name: \"ConditionError\",\n message: \"Aborted due to condition callback returning false.\"\n };\n }\n const abortedPromise = new Promise((_, reject) => {\n abortHandler = () => {\n reject({\n name: \"AbortError\",\n message: abortReason || \"Aborted\"\n });\n };\n abortController.signal.addEventListener(\"abort\", abortHandler, {\n once: true\n });\n });\n dispatch(pending(requestId, arg, options?.getPendingMeta?.({\n requestId,\n arg\n }, {\n getState,\n extra\n })));\n finalAction = await Promise.race([abortedPromise, Promise.resolve(payloadCreator(arg, {\n dispatch,\n getState,\n extra,\n requestId,\n signal: abortController.signal,\n abort,\n rejectWithValue: (value, meta) => {\n return new RejectWithValue(value, meta);\n },\n fulfillWithValue: (value, meta) => {\n return new FulfillWithMeta(value, meta);\n }\n })).then((result) => {\n if (result instanceof RejectWithValue) {\n throw result;\n }\n if (result instanceof FulfillWithMeta) {\n return fulfilled(result.payload, requestId, arg, result.meta);\n }\n return fulfilled(result, requestId, arg);\n })]);\n } catch (err) {\n finalAction = err instanceof RejectWithValue ? rejected(null, requestId, arg, err.payload, err.meta) : rejected(err, requestId, arg);\n } finally {\n if (abortHandler) {\n abortController.signal.removeEventListener(\"abort\", abortHandler);\n }\n }\n const skipDispatch = options && !options.dispatchConditionRejection && rejected.match(finalAction) && finalAction.meta.condition;\n if (!skipDispatch) {\n dispatch(finalAction);\n }\n return finalAction;\n }();\n return Object.assign(promise, {\n abort,\n requestId,\n arg,\n unwrap() {\n return promise.then(unwrapResult);\n }\n });\n };\n }\n return Object.assign(actionCreator, {\n pending,\n rejected,\n fulfilled,\n settled: isAnyOf(rejected, fulfilled),\n typePrefix\n });\n }\n createAsyncThunk2.withTypes = () => createAsyncThunk2;\n return createAsyncThunk2;\n})();\nfunction unwrapResult(action) {\n if (action.meta && action.meta.rejectedWithValue) {\n throw action.payload;\n }\n if (action.error) {\n throw action.error;\n }\n return action.payload;\n}\nfunction isThenable(value) {\n return value !== null && typeof value === \"object\" && typeof value.then === \"function\";\n}\n\n// src/createSlice.ts\nvar asyncThunkSymbol = /* @__PURE__ */ Symbol.for(\"rtk-slice-createasyncthunk\");\nvar asyncThunkCreator = {\n [asyncThunkSymbol]: createAsyncThunk\n};\nvar ReducerType = /* @__PURE__ */ ((ReducerType2) => {\n ReducerType2[\"reducer\"] = \"reducer\";\n ReducerType2[\"reducerWithPrepare\"] = \"reducerWithPrepare\";\n ReducerType2[\"asyncThunk\"] = \"asyncThunk\";\n return ReducerType2;\n})(ReducerType || {});\nfunction getType(slice, actionKey) {\n return `${slice}/${actionKey}`;\n}\nfunction buildCreateSlice({\n creators\n} = {}) {\n const cAT = creators?.asyncThunk?.[asyncThunkSymbol];\n return function createSlice2(options) {\n const {\n name,\n reducerPath = name\n } = options;\n if (!name) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(11) : \"`name` is a required option for createSlice\");\n }\n if (typeof process !== \"undefined\" && process.env.NODE_ENV === \"development\") {\n if (options.initialState === void 0) {\n console.error(\"You must provide an `initialState` value that is not `undefined`. You may have misspelled `initialState`\");\n }\n }\n const reducers = (typeof options.reducers === \"function\" ? options.reducers(buildReducerCreators()) : options.reducers) || {};\n const reducerNames = Object.keys(reducers);\n const context = {\n sliceCaseReducersByName: {},\n sliceCaseReducersByType: {},\n actionCreators: {},\n sliceMatchers: []\n };\n const contextMethods = {\n addCase(typeOrActionCreator, reducer2) {\n const type = typeof typeOrActionCreator === \"string\" ? typeOrActionCreator : typeOrActionCreator.type;\n if (!type) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(12) : \"`context.addCase` cannot be called with an empty action type\");\n }\n if (type in context.sliceCaseReducersByType) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(13) : \"`context.addCase` cannot be called with two reducers for the same action type: \" + type);\n }\n context.sliceCaseReducersByType[type] = reducer2;\n return contextMethods;\n },\n addMatcher(matcher, reducer2) {\n context.sliceMatchers.push({\n matcher,\n reducer: reducer2\n });\n return contextMethods;\n },\n exposeAction(name2, actionCreator) {\n context.actionCreators[name2] = actionCreator;\n return contextMethods;\n },\n exposeCaseReducer(name2, reducer2) {\n context.sliceCaseReducersByName[name2] = reducer2;\n return contextMethods;\n }\n };\n reducerNames.forEach((reducerName) => {\n const reducerDefinition = reducers[reducerName];\n const reducerDetails = {\n reducerName,\n type: getType(name, reducerName),\n createNotation: typeof options.reducers === \"function\"\n };\n if (isAsyncThunkSliceReducerDefinition(reducerDefinition)) {\n handleThunkCaseReducerDefinition(reducerDetails, reducerDefinition, contextMethods, cAT);\n } else {\n handleNormalReducerDefinition(reducerDetails, reducerDefinition, contextMethods);\n }\n });\n function buildReducer() {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof options.extraReducers === \"object\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(14) : \"The object notation for `createSlice.extraReducers` has been removed. Please use the 'builder callback' notation instead: https://redux-toolkit.js.org/api/createSlice\");\n }\n }\n const [extraReducers = {}, actionMatchers = [], defaultCaseReducer = void 0] = typeof options.extraReducers === \"function\" ? executeReducerBuilderCallback(options.extraReducers) : [options.extraReducers];\n const finalCaseReducers = {\n ...extraReducers,\n ...context.sliceCaseReducersByType\n };\n return createReducer(options.initialState, (builder) => {\n for (let key in finalCaseReducers) {\n builder.addCase(key, finalCaseReducers[key]);\n }\n for (let sM of context.sliceMatchers) {\n builder.addMatcher(sM.matcher, sM.reducer);\n }\n for (let m of actionMatchers) {\n builder.addMatcher(m.matcher, m.reducer);\n }\n if (defaultCaseReducer) {\n builder.addDefaultCase(defaultCaseReducer);\n }\n });\n }\n const selectSelf = (state) => state;\n const injectedSelectorCache = /* @__PURE__ */ new Map();\n const injectedStateCache = /* @__PURE__ */ new WeakMap();\n let _reducer;\n function reducer(state, action) {\n if (!_reducer) _reducer = buildReducer();\n return _reducer(state, action);\n }\n function getInitialState() {\n if (!_reducer) _reducer = buildReducer();\n return _reducer.getInitialState();\n }\n function makeSelectorProps(reducerPath2, injected = false) {\n function selectSlice(state) {\n let sliceState = state[reducerPath2];\n if (typeof sliceState === \"undefined\") {\n if (injected) {\n sliceState = getOrInsertComputed(injectedStateCache, selectSlice, getInitialState);\n } else if (process.env.NODE_ENV !== \"production\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(15) : \"selectSlice returned undefined for an uninjected slice reducer\");\n }\n }\n return sliceState;\n }\n function getSelectors(selectState = selectSelf) {\n const selectorCache = getOrInsertComputed(injectedSelectorCache, injected, () => /* @__PURE__ */ new WeakMap());\n return getOrInsertComputed(selectorCache, selectState, () => {\n const map = {};\n for (const [name2, selector] of Object.entries(options.selectors ?? {})) {\n map[name2] = wrapSelector(selector, selectState, () => getOrInsertComputed(injectedStateCache, selectState, getInitialState), injected);\n }\n return map;\n });\n }\n return {\n reducerPath: reducerPath2,\n getSelectors,\n get selectors() {\n return getSelectors(selectSlice);\n },\n selectSlice\n };\n }\n const slice = {\n name,\n reducer,\n actions: context.actionCreators,\n caseReducers: context.sliceCaseReducersByName,\n getInitialState,\n ...makeSelectorProps(reducerPath),\n injectInto(injectable, {\n reducerPath: pathOpt,\n ...config\n } = {}) {\n const newReducerPath = pathOpt ?? reducerPath;\n injectable.inject({\n reducerPath: newReducerPath,\n reducer\n }, config);\n return {\n ...slice,\n ...makeSelectorProps(newReducerPath, true)\n };\n }\n };\n return slice;\n };\n}\nfunction wrapSelector(selector, selectState, getInitialState, injected) {\n function wrapper(rootState, ...args) {\n let sliceState = selectState(rootState);\n if (typeof sliceState === \"undefined\") {\n if (injected) {\n sliceState = getInitialState();\n } else if (process.env.NODE_ENV !== \"production\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(16) : \"selectState returned undefined for an uninjected slice reducer\");\n }\n }\n return selector(sliceState, ...args);\n }\n wrapper.unwrapped = selector;\n return wrapper;\n}\nvar createSlice = /* @__PURE__ */ buildCreateSlice();\nfunction buildReducerCreators() {\n function asyncThunk(payloadCreator, config) {\n return {\n _reducerDefinitionType: \"asyncThunk\" /* asyncThunk */,\n payloadCreator,\n ...config\n };\n }\n asyncThunk.withTypes = () => asyncThunk;\n return {\n reducer(caseReducer) {\n return Object.assign({\n // hack so the wrapping function has the same name as the original\n // we need to create a wrapper so the `reducerDefinitionType` is not assigned to the original\n [caseReducer.name](...args) {\n return caseReducer(...args);\n }\n }[caseReducer.name], {\n _reducerDefinitionType: \"reducer\" /* reducer */\n });\n },\n preparedReducer(prepare, reducer) {\n return {\n _reducerDefinitionType: \"reducerWithPrepare\" /* reducerWithPrepare */,\n prepare,\n reducer\n };\n },\n asyncThunk\n };\n}\nfunction handleNormalReducerDefinition({\n type,\n reducerName,\n createNotation\n}, maybeReducerWithPrepare, context) {\n let caseReducer;\n let prepareCallback;\n if (\"reducer\" in maybeReducerWithPrepare) {\n if (createNotation && !isCaseReducerWithPrepareDefinition(maybeReducerWithPrepare)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(17) : \"Please use the `create.preparedReducer` notation for prepared action creators with the `create` notation.\");\n }\n caseReducer = maybeReducerWithPrepare.reducer;\n prepareCallback = maybeReducerWithPrepare.prepare;\n } else {\n caseReducer = maybeReducerWithPrepare;\n }\n context.addCase(type, caseReducer).exposeCaseReducer(reducerName, caseReducer).exposeAction(reducerName, prepareCallback ? createAction(type, prepareCallback) : createAction(type));\n}\nfunction isAsyncThunkSliceReducerDefinition(reducerDefinition) {\n return reducerDefinition._reducerDefinitionType === \"asyncThunk\" /* asyncThunk */;\n}\nfunction isCaseReducerWithPrepareDefinition(reducerDefinition) {\n return reducerDefinition._reducerDefinitionType === \"reducerWithPrepare\" /* reducerWithPrepare */;\n}\nfunction handleThunkCaseReducerDefinition({\n type,\n reducerName\n}, reducerDefinition, context, cAT) {\n if (!cAT) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(18) : \"Cannot use `create.asyncThunk` in the built-in `createSlice`. Use `buildCreateSlice({ creators: { asyncThunk: asyncThunkCreator } })` to create a customised version of `createSlice`.\");\n }\n const {\n payloadCreator,\n fulfilled,\n pending,\n rejected,\n settled,\n options\n } = reducerDefinition;\n const thunk = cAT(type, payloadCreator, options);\n context.exposeAction(reducerName, thunk);\n if (fulfilled) {\n context.addCase(thunk.fulfilled, fulfilled);\n }\n if (pending) {\n context.addCase(thunk.pending, pending);\n }\n if (rejected) {\n context.addCase(thunk.rejected, rejected);\n }\n if (settled) {\n context.addMatcher(thunk.settled, settled);\n }\n context.exposeCaseReducer(reducerName, {\n fulfilled: fulfilled || noop,\n pending: pending || noop,\n rejected: rejected || noop,\n settled: settled || noop\n });\n}\nfunction noop() {\n}\n\n// src/entities/entity_state.ts\nfunction getInitialEntityState() {\n return {\n ids: [],\n entities: {}\n };\n}\nfunction createInitialStateFactory(stateAdapter) {\n function getInitialState(additionalState = {}, entities) {\n const state = Object.assign(getInitialEntityState(), additionalState);\n return entities ? stateAdapter.setAll(state, entities) : state;\n }\n return {\n getInitialState\n };\n}\n\n// src/entities/state_selectors.ts\nfunction createSelectorsFactory() {\n function getSelectors(selectState, options = {}) {\n const {\n createSelector: createSelector2 = createDraftSafeSelector\n } = options;\n const selectIds = (state) => state.ids;\n const selectEntities = (state) => state.entities;\n const selectAll = createSelector2(selectIds, selectEntities, (ids, entities) => ids.map((id) => entities[id]));\n const selectId = (_, id) => id;\n const selectById = (entities, id) => entities[id];\n const selectTotal = createSelector2(selectIds, (ids) => ids.length);\n if (!selectState) {\n return {\n selectIds,\n selectEntities,\n selectAll,\n selectTotal,\n selectById: createSelector2(selectEntities, selectId, selectById)\n };\n }\n const selectGlobalizedEntities = createSelector2(selectState, selectEntities);\n return {\n selectIds: createSelector2(selectState, selectIds),\n selectEntities: selectGlobalizedEntities,\n selectAll: createSelector2(selectState, selectAll),\n selectTotal: createSelector2(selectState, selectTotal),\n selectById: createSelector2(selectGlobalizedEntities, selectId, selectById)\n };\n }\n return {\n getSelectors\n };\n}\n\n// src/entities/state_adapter.ts\nvar isDraftTyped = isDraft;\nfunction createSingleArgumentStateOperator(mutator) {\n const operator = createStateOperator((_, state) => mutator(state));\n return function operation(state) {\n return operator(state, void 0);\n };\n}\nfunction createStateOperator(mutator) {\n return function operation(state, arg) {\n function isPayloadActionArgument(arg2) {\n return isFSA(arg2);\n }\n const runMutator = (draft) => {\n if (isPayloadActionArgument(arg)) {\n mutator(arg.payload, draft);\n } else {\n mutator(arg, draft);\n }\n };\n if (isDraftTyped(state)) {\n runMutator(state);\n return state;\n }\n return produce(state, runMutator);\n };\n}\n\n// src/entities/utils.ts\nfunction selectIdValue(entity, selectId) {\n const key = selectId(entity);\n if (process.env.NODE_ENV !== \"production\" && key === void 0) {\n console.warn(\"The entity passed to the `selectId` implementation returned undefined.\", \"You should probably provide your own `selectId` implementation.\", \"The entity that was passed:\", entity, \"The `selectId` implementation:\", selectId.toString());\n }\n return key;\n}\nfunction ensureEntitiesArray(entities) {\n if (!Array.isArray(entities)) {\n entities = Object.values(entities);\n }\n return entities;\n}\nfunction getCurrent(value) {\n return isDraft(value) ? current(value) : value;\n}\nfunction splitAddedUpdatedEntities(newEntities, selectId, state) {\n newEntities = ensureEntitiesArray(newEntities);\n const existingIdsArray = getCurrent(state.ids);\n const existingIds = new Set(existingIdsArray);\n const added = [];\n const addedIds = /* @__PURE__ */ new Set([]);\n const updated = [];\n for (const entity of newEntities) {\n const id = selectIdValue(entity, selectId);\n if (existingIds.has(id) || addedIds.has(id)) {\n updated.push({\n id,\n changes: entity\n });\n } else {\n addedIds.add(id);\n added.push(entity);\n }\n }\n return [added, updated, existingIdsArray];\n}\n\n// src/entities/unsorted_state_adapter.ts\nfunction createUnsortedStateAdapter(selectId) {\n function addOneMutably(entity, state) {\n const key = selectIdValue(entity, selectId);\n if (key in state.entities) {\n return;\n }\n state.ids.push(key);\n state.entities[key] = entity;\n }\n function addManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n for (const entity of newEntities) {\n addOneMutably(entity, state);\n }\n }\n function setOneMutably(entity, state) {\n const key = selectIdValue(entity, selectId);\n if (!(key in state.entities)) {\n state.ids.push(key);\n }\n ;\n state.entities[key] = entity;\n }\n function setManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n for (const entity of newEntities) {\n setOneMutably(entity, state);\n }\n }\n function setAllMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n state.ids = [];\n state.entities = {};\n addManyMutably(newEntities, state);\n }\n function removeOneMutably(key, state) {\n return removeManyMutably([key], state);\n }\n function removeManyMutably(keys, state) {\n let didMutate = false;\n keys.forEach((key) => {\n if (key in state.entities) {\n delete state.entities[key];\n didMutate = true;\n }\n });\n if (didMutate) {\n state.ids = state.ids.filter((id) => id in state.entities);\n }\n }\n function removeAllMutably(state) {\n Object.assign(state, {\n ids: [],\n entities: {}\n });\n }\n function takeNewKey(keys, update, state) {\n const original3 = state.entities[update.id];\n if (original3 === void 0) {\n return false;\n }\n const updated = Object.assign({}, original3, update.changes);\n const newKey = selectIdValue(updated, selectId);\n const hasNewKey = newKey !== update.id;\n if (hasNewKey) {\n keys[update.id] = newKey;\n delete state.entities[update.id];\n }\n ;\n state.entities[newKey] = updated;\n return hasNewKey;\n }\n function updateOneMutably(update, state) {\n return updateManyMutably([update], state);\n }\n function updateManyMutably(updates, state) {\n const newKeys = {};\n const updatesPerEntity = {};\n updates.forEach((update) => {\n if (update.id in state.entities) {\n updatesPerEntity[update.id] = {\n id: update.id,\n // Spreads ignore falsy values, so this works even if there isn't\n // an existing update already at this key\n changes: {\n ...updatesPerEntity[update.id]?.changes,\n ...update.changes\n }\n };\n }\n });\n updates = Object.values(updatesPerEntity);\n const didMutateEntities = updates.length > 0;\n if (didMutateEntities) {\n const didMutateIds = updates.filter((update) => takeNewKey(newKeys, update, state)).length > 0;\n if (didMutateIds) {\n state.ids = Object.values(state.entities).map((e) => selectIdValue(e, selectId));\n }\n }\n }\n function upsertOneMutably(entity, state) {\n return upsertManyMutably([entity], state);\n }\n function upsertManyMutably(newEntities, state) {\n const [added, updated] = splitAddedUpdatedEntities(newEntities, selectId, state);\n addManyMutably(added, state);\n updateManyMutably(updated, state);\n }\n return {\n removeAll: createSingleArgumentStateOperator(removeAllMutably),\n addOne: createStateOperator(addOneMutably),\n addMany: createStateOperator(addManyMutably),\n setOne: createStateOperator(setOneMutably),\n setMany: createStateOperator(setManyMutably),\n setAll: createStateOperator(setAllMutably),\n updateOne: createStateOperator(updateOneMutably),\n updateMany: createStateOperator(updateManyMutably),\n upsertOne: createStateOperator(upsertOneMutably),\n upsertMany: createStateOperator(upsertManyMutably),\n removeOne: createStateOperator(removeOneMutably),\n removeMany: createStateOperator(removeManyMutably)\n };\n}\n\n// src/entities/sorted_state_adapter.ts\nfunction findInsertIndex(sortedItems, item, comparisonFunction) {\n let lowIndex = 0;\n let highIndex = sortedItems.length;\n while (lowIndex < highIndex) {\n let middleIndex = lowIndex + highIndex >>> 1;\n const currentItem = sortedItems[middleIndex];\n const res = comparisonFunction(item, currentItem);\n if (res >= 0) {\n lowIndex = middleIndex + 1;\n } else {\n highIndex = middleIndex;\n }\n }\n return lowIndex;\n}\nfunction insert(sortedItems, item, comparisonFunction) {\n const insertAtIndex = findInsertIndex(sortedItems, item, comparisonFunction);\n sortedItems.splice(insertAtIndex, 0, item);\n return sortedItems;\n}\nfunction createSortedStateAdapter(selectId, comparer) {\n const {\n removeOne,\n removeMany,\n removeAll\n } = createUnsortedStateAdapter(selectId);\n function addOneMutably(entity, state) {\n return addManyMutably([entity], state);\n }\n function addManyMutably(newEntities, state, existingIds) {\n newEntities = ensureEntitiesArray(newEntities);\n const existingKeys = new Set(existingIds ?? getCurrent(state.ids));\n const addedKeys = /* @__PURE__ */ new Set();\n const models = newEntities.filter((model) => {\n const modelId = selectIdValue(model, selectId);\n const notAdded = !addedKeys.has(modelId);\n if (notAdded) addedKeys.add(modelId);\n return !existingKeys.has(modelId) && notAdded;\n });\n if (models.length !== 0) {\n mergeFunction(state, models);\n }\n }\n function setOneMutably(entity, state) {\n return setManyMutably([entity], state);\n }\n function setManyMutably(newEntities, state) {\n let deduplicatedEntities = {};\n newEntities = ensureEntitiesArray(newEntities);\n if (newEntities.length !== 0) {\n for (const item of newEntities) {\n const entityId = selectId(item);\n deduplicatedEntities[entityId] = item;\n delete state.entities[entityId];\n }\n newEntities = ensureEntitiesArray(deduplicatedEntities);\n mergeFunction(state, newEntities);\n }\n }\n function setAllMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n state.entities = {};\n state.ids = [];\n addManyMutably(newEntities, state, []);\n }\n function updateOneMutably(update, state) {\n return updateManyMutably([update], state);\n }\n function updateManyMutably(updates, state) {\n let appliedUpdates = false;\n let replacedIds = false;\n for (let update of updates) {\n const entity = state.entities[update.id];\n if (!entity) {\n continue;\n }\n appliedUpdates = true;\n Object.assign(entity, update.changes);\n const newId = selectId(entity);\n if (update.id !== newId) {\n replacedIds = true;\n delete state.entities[update.id];\n const oldIndex = state.ids.indexOf(update.id);\n state.ids[oldIndex] = newId;\n state.entities[newId] = entity;\n }\n }\n if (appliedUpdates) {\n mergeFunction(state, [], appliedUpdates, replacedIds);\n }\n }\n function upsertOneMutably(entity, state) {\n return upsertManyMutably([entity], state);\n }\n function upsertManyMutably(newEntities, state) {\n const [added, updated, existingIdsArray] = splitAddedUpdatedEntities(newEntities, selectId, state);\n if (added.length) {\n addManyMutably(added, state, existingIdsArray);\n }\n if (updated.length) {\n updateManyMutably(updated, state);\n }\n }\n function areArraysEqual(a, b) {\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0; i < a.length; i++) {\n if (a[i] === b[i]) {\n continue;\n }\n return false;\n }\n return true;\n }\n const mergeFunction = (state, addedItems, appliedUpdates, replacedIds) => {\n const currentEntities = getCurrent(state.entities);\n const currentIds = getCurrent(state.ids);\n const stateEntities = state.entities;\n let ids = currentIds;\n if (replacedIds) {\n ids = new Set(currentIds);\n }\n let sortedEntities = [];\n for (const id of ids) {\n const entity = currentEntities[id];\n if (entity) {\n sortedEntities.push(entity);\n }\n }\n const wasPreviouslyEmpty = sortedEntities.length === 0;\n for (const item of addedItems) {\n stateEntities[selectId(item)] = item;\n if (!wasPreviouslyEmpty) {\n insert(sortedEntities, item, comparer);\n }\n }\n if (wasPreviouslyEmpty) {\n sortedEntities = addedItems.slice().sort(comparer);\n } else if (appliedUpdates) {\n sortedEntities.sort(comparer);\n }\n const newSortedIds = sortedEntities.map(selectId);\n if (!areArraysEqual(currentIds, newSortedIds)) {\n state.ids = newSortedIds;\n }\n };\n return {\n removeOne,\n removeMany,\n removeAll,\n addOne: createStateOperator(addOneMutably),\n updateOne: createStateOperator(updateOneMutably),\n upsertOne: createStateOperator(upsertOneMutably),\n setOne: createStateOperator(setOneMutably),\n setMany: createStateOperator(setManyMutably),\n setAll: createStateOperator(setAllMutably),\n addMany: createStateOperator(addManyMutably),\n updateMany: createStateOperator(updateManyMutably),\n upsertMany: createStateOperator(upsertManyMutably)\n };\n}\n\n// src/entities/create_adapter.ts\nfunction createEntityAdapter(options = {}) {\n const {\n selectId,\n sortComparer\n } = {\n sortComparer: false,\n selectId: (instance) => instance.id,\n ...options\n };\n const stateAdapter = sortComparer ? createSortedStateAdapter(selectId, sortComparer) : createUnsortedStateAdapter(selectId);\n const stateFactory = createInitialStateFactory(stateAdapter);\n const selectorsFactory = createSelectorsFactory();\n return {\n selectId,\n sortComparer,\n ...stateFactory,\n ...selectorsFactory,\n ...stateAdapter\n };\n}\n\n// src/listenerMiddleware/exceptions.ts\nvar task = \"task\";\nvar listener = \"listener\";\nvar completed = \"completed\";\nvar cancelled = \"cancelled\";\nvar taskCancelled = `task-${cancelled}`;\nvar taskCompleted = `task-${completed}`;\nvar listenerCancelled = `${listener}-${cancelled}`;\nvar listenerCompleted = `${listener}-${completed}`;\nvar TaskAbortError = class {\n constructor(code) {\n this.code = code;\n this.message = `${task} ${cancelled} (reason: ${code})`;\n }\n name = \"TaskAbortError\";\n message;\n};\n\n// src/listenerMiddleware/utils.ts\nvar assertFunction = (func, expected) => {\n if (typeof func !== \"function\") {\n throw new TypeError(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(32) : `${expected} is not a function`);\n }\n};\nvar noop2 = () => {\n};\nvar catchRejection = (promise, onError = noop2) => {\n promise.catch(onError);\n return promise;\n};\nvar addAbortSignalListener = (abortSignal, callback) => {\n abortSignal.addEventListener(\"abort\", callback, {\n once: true\n });\n return () => abortSignal.removeEventListener(\"abort\", callback);\n};\n\n// src/listenerMiddleware/task.ts\nvar validateActive = (signal) => {\n if (signal.aborted) {\n throw new TaskAbortError(signal.reason);\n }\n};\nfunction raceWithSignal(signal, promise) {\n let cleanup = noop2;\n return new Promise((resolve, reject) => {\n const notifyRejection = () => reject(new TaskAbortError(signal.reason));\n if (signal.aborted) {\n notifyRejection();\n return;\n }\n cleanup = addAbortSignalListener(signal, notifyRejection);\n promise.finally(() => cleanup()).then(resolve, reject);\n }).finally(() => {\n cleanup = noop2;\n });\n}\nvar runTask = async (task2, cleanUp) => {\n try {\n await Promise.resolve();\n const value = await task2();\n return {\n status: \"ok\",\n value\n };\n } catch (error) {\n return {\n status: error instanceof TaskAbortError ? \"cancelled\" : \"rejected\",\n error\n };\n } finally {\n cleanUp?.();\n }\n};\nvar createPause = (signal) => {\n return (promise) => {\n return catchRejection(raceWithSignal(signal, promise).then((output) => {\n validateActive(signal);\n return output;\n }));\n };\n};\nvar createDelay = (signal) => {\n const pause = createPause(signal);\n return (timeoutMs) => {\n return pause(new Promise((resolve) => setTimeout(resolve, timeoutMs)));\n };\n};\n\n// src/listenerMiddleware/index.ts\nvar {\n assign\n} = Object;\nvar INTERNAL_NIL_TOKEN = {};\nvar alm = \"listenerMiddleware\";\nvar createFork = (parentAbortSignal, parentBlockingPromises) => {\n const linkControllers = (controller) => addAbortSignalListener(parentAbortSignal, () => controller.abort(parentAbortSignal.reason));\n return (taskExecutor, opts) => {\n assertFunction(taskExecutor, \"taskExecutor\");\n const childAbortController = new AbortController();\n linkControllers(childAbortController);\n const result = runTask(async () => {\n validateActive(parentAbortSignal);\n validateActive(childAbortController.signal);\n const result2 = await taskExecutor({\n pause: createPause(childAbortController.signal),\n delay: createDelay(childAbortController.signal),\n signal: childAbortController.signal\n });\n validateActive(childAbortController.signal);\n return result2;\n }, () => childAbortController.abort(taskCompleted));\n if (opts?.autoJoin) {\n parentBlockingPromises.push(result.catch(noop2));\n }\n return {\n result: createPause(parentAbortSignal)(result),\n cancel() {\n childAbortController.abort(taskCancelled);\n }\n };\n };\n};\nvar createTakePattern = (startListening, signal) => {\n const take = async (predicate, timeout) => {\n validateActive(signal);\n let unsubscribe = () => {\n };\n const tuplePromise = new Promise((resolve, reject) => {\n let stopListening = startListening({\n predicate,\n effect: (action, listenerApi) => {\n listenerApi.unsubscribe();\n resolve([action, listenerApi.getState(), listenerApi.getOriginalState()]);\n }\n });\n unsubscribe = () => {\n stopListening();\n reject();\n };\n });\n const promises = [tuplePromise];\n if (timeout != null) {\n promises.push(new Promise((resolve) => setTimeout(resolve, timeout, null)));\n }\n try {\n const output = await raceWithSignal(signal, Promise.race(promises));\n validateActive(signal);\n return output;\n } finally {\n unsubscribe();\n }\n };\n return (predicate, timeout) => catchRejection(take(predicate, timeout));\n};\nvar getListenerEntryPropsFrom = (options) => {\n let {\n type,\n actionCreator,\n matcher,\n predicate,\n effect\n } = options;\n if (type) {\n predicate = createAction(type).match;\n } else if (actionCreator) {\n type = actionCreator.type;\n predicate = actionCreator.match;\n } else if (matcher) {\n predicate = matcher;\n } else if (predicate) {\n } else {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(21) : \"Creating or removing a listener requires one of the known fields for matching an action\");\n }\n assertFunction(effect, \"options.listener\");\n return {\n predicate,\n type,\n effect\n };\n};\nvar createListenerEntry = /* @__PURE__ */ assign((options) => {\n const {\n type,\n predicate,\n effect\n } = getListenerEntryPropsFrom(options);\n const entry = {\n id: nanoid(),\n effect,\n type,\n predicate,\n pending: /* @__PURE__ */ new Set(),\n unsubscribe: () => {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(22) : \"Unsubscribe not initialized\");\n }\n };\n return entry;\n}, {\n withTypes: () => createListenerEntry\n});\nvar findListenerEntry = (listenerMap, options) => {\n const {\n type,\n effect,\n predicate\n } = getListenerEntryPropsFrom(options);\n return Array.from(listenerMap.values()).find((entry) => {\n const matchPredicateOrType = typeof type === \"string\" ? entry.type === type : entry.predicate === predicate;\n return matchPredicateOrType && entry.effect === effect;\n });\n};\nvar cancelActiveListeners = (entry) => {\n entry.pending.forEach((controller) => {\n controller.abort(listenerCancelled);\n });\n};\nvar createClearListenerMiddleware = (listenerMap, executingListeners) => {\n return () => {\n for (const listener2 of executingListeners.keys()) {\n cancelActiveListeners(listener2);\n }\n listenerMap.clear();\n };\n};\nvar safelyNotifyError = (errorHandler, errorToNotify, errorInfo) => {\n try {\n errorHandler(errorToNotify, errorInfo);\n } catch (errorHandlerError) {\n setTimeout(() => {\n throw errorHandlerError;\n }, 0);\n }\n};\nvar addListener = /* @__PURE__ */ assign(/* @__PURE__ */ createAction(`${alm}/add`), {\n withTypes: () => addListener\n});\nvar clearAllListeners = /* @__PURE__ */ createAction(`${alm}/removeAll`);\nvar removeListener = /* @__PURE__ */ assign(/* @__PURE__ */ createAction(`${alm}/remove`), {\n withTypes: () => removeListener\n});\nvar defaultErrorHandler = (...args) => {\n console.error(`${alm}/error`, ...args);\n};\nvar createListenerMiddleware = (middlewareOptions = {}) => {\n const listenerMap = /* @__PURE__ */ new Map();\n const executingListeners = /* @__PURE__ */ new Map();\n const trackExecutingListener = (entry) => {\n const count = executingListeners.get(entry) ?? 0;\n executingListeners.set(entry, count + 1);\n };\n const untrackExecutingListener = (entry) => {\n const count = executingListeners.get(entry) ?? 1;\n if (count === 1) {\n executingListeners.delete(entry);\n } else {\n executingListeners.set(entry, count - 1);\n }\n };\n const {\n extra,\n onError = defaultErrorHandler\n } = middlewareOptions;\n assertFunction(onError, \"onError\");\n const insertEntry = (entry) => {\n entry.unsubscribe = () => listenerMap.delete(entry.id);\n listenerMap.set(entry.id, entry);\n return (cancelOptions) => {\n entry.unsubscribe();\n if (cancelOptions?.cancelActive) {\n cancelActiveListeners(entry);\n }\n };\n };\n const startListening = (options) => {\n const entry = findListenerEntry(listenerMap, options) ?? createListenerEntry(options);\n return insertEntry(entry);\n };\n assign(startListening, {\n withTypes: () => startListening\n });\n const stopListening = (options) => {\n const entry = findListenerEntry(listenerMap, options);\n if (entry) {\n entry.unsubscribe();\n if (options.cancelActive) {\n cancelActiveListeners(entry);\n }\n }\n return !!entry;\n };\n assign(stopListening, {\n withTypes: () => stopListening\n });\n const notifyListener = async (entry, action, api, getOriginalState) => {\n const internalTaskController = new AbortController();\n const take = createTakePattern(startListening, internalTaskController.signal);\n const autoJoinPromises = [];\n try {\n entry.pending.add(internalTaskController);\n trackExecutingListener(entry);\n await Promise.resolve(entry.effect(\n action,\n // Use assign() rather than ... to avoid extra helper functions added to bundle\n assign({}, api, {\n getOriginalState,\n condition: (predicate, timeout) => take(predicate, timeout).then(Boolean),\n take,\n delay: createDelay(internalTaskController.signal),\n pause: createPause(internalTaskController.signal),\n extra,\n signal: internalTaskController.signal,\n fork: createFork(internalTaskController.signal, autoJoinPromises),\n unsubscribe: entry.unsubscribe,\n subscribe: () => {\n listenerMap.set(entry.id, entry);\n },\n cancelActiveListeners: () => {\n entry.pending.forEach((controller, _, set) => {\n if (controller !== internalTaskController) {\n controller.abort(listenerCancelled);\n set.delete(controller);\n }\n });\n },\n cancel: () => {\n internalTaskController.abort(listenerCancelled);\n entry.pending.delete(internalTaskController);\n },\n throwIfCancelled: () => {\n validateActive(internalTaskController.signal);\n }\n })\n ));\n } catch (listenerError) {\n if (!(listenerError instanceof TaskAbortError)) {\n safelyNotifyError(onError, listenerError, {\n raisedBy: \"effect\"\n });\n }\n } finally {\n await Promise.all(autoJoinPromises);\n internalTaskController.abort(listenerCompleted);\n untrackExecutingListener(entry);\n entry.pending.delete(internalTaskController);\n }\n };\n const clearListenerMiddleware = createClearListenerMiddleware(listenerMap, executingListeners);\n const middleware = (api) => (next) => (action) => {\n if (!isAction(action)) {\n return next(action);\n }\n if (addListener.match(action)) {\n return startListening(action.payload);\n }\n if (clearAllListeners.match(action)) {\n clearListenerMiddleware();\n return;\n }\n if (removeListener.match(action)) {\n return stopListening(action.payload);\n }\n let originalState = api.getState();\n const getOriginalState = () => {\n if (originalState === INTERNAL_NIL_TOKEN) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(23) : `${alm}: getOriginalState can only be called synchronously`);\n }\n return originalState;\n };\n let result;\n try {\n result = next(action);\n if (listenerMap.size > 0) {\n const currentState = api.getState();\n const listenerEntries = Array.from(listenerMap.values());\n for (const entry of listenerEntries) {\n let runListener = false;\n try {\n runListener = entry.predicate(action, currentState, originalState);\n } catch (predicateError) {\n runListener = false;\n safelyNotifyError(onError, predicateError, {\n raisedBy: \"predicate\"\n });\n }\n if (!runListener) {\n continue;\n }\n notifyListener(entry, action, api, getOriginalState);\n }\n }\n } finally {\n originalState = INTERNAL_NIL_TOKEN;\n }\n return result;\n };\n return {\n middleware,\n startListening,\n stopListening,\n clearListeners: clearListenerMiddleware\n };\n};\n\n// src/dynamicMiddleware/index.ts\nvar createMiddlewareEntry = (middleware) => ({\n middleware,\n applied: /* @__PURE__ */ new Map()\n});\nvar matchInstance = (instanceId) => (action) => action?.meta?.instanceId === instanceId;\nvar createDynamicMiddleware = () => {\n const instanceId = nanoid();\n const middlewareMap = /* @__PURE__ */ new Map();\n const withMiddleware = Object.assign(createAction(\"dynamicMiddleware/add\", (...middlewares) => ({\n payload: middlewares,\n meta: {\n instanceId\n }\n })), {\n withTypes: () => withMiddleware\n });\n const addMiddleware = Object.assign(function addMiddleware2(...middlewares) {\n middlewares.forEach((middleware2) => {\n getOrInsertComputed(middlewareMap, middleware2, createMiddlewareEntry);\n });\n }, {\n withTypes: () => addMiddleware\n });\n const getFinalMiddleware = (api) => {\n const appliedMiddleware = Array.from(middlewareMap.values()).map((entry) => getOrInsertComputed(entry.applied, api, entry.middleware));\n return compose(...appliedMiddleware);\n };\n const isWithMiddleware = isAllOf(withMiddleware, matchInstance(instanceId));\n const middleware = (api) => (next) => (action) => {\n if (isWithMiddleware(action)) {\n addMiddleware(...action.payload);\n return api.dispatch;\n }\n return getFinalMiddleware(api)(next)(action);\n };\n return {\n middleware,\n addMiddleware,\n withMiddleware,\n instanceId\n };\n};\n\n// src/combineSlices.ts\nimport { combineReducers as combineReducers2 } from \"redux\";\nvar isSliceLike = (maybeSliceLike) => \"reducerPath\" in maybeSliceLike && typeof maybeSliceLike.reducerPath === \"string\";\nvar getReducers = (slices) => slices.flatMap((sliceOrMap) => isSliceLike(sliceOrMap) ? [[sliceOrMap.reducerPath, sliceOrMap.reducer]] : Object.entries(sliceOrMap));\nvar ORIGINAL_STATE = Symbol.for(\"rtk-state-proxy-original\");\nvar isStateProxy = (value) => !!value && !!value[ORIGINAL_STATE];\nvar stateProxyMap = /* @__PURE__ */ new WeakMap();\nvar createStateProxy = (state, reducerMap, initialStateCache) => getOrInsertComputed(stateProxyMap, state, () => new Proxy(state, {\n get: (target, prop, receiver) => {\n if (prop === ORIGINAL_STATE) return target;\n const result = Reflect.get(target, prop, receiver);\n if (typeof result === \"undefined\") {\n const cached = initialStateCache[prop];\n if (typeof cached !== \"undefined\") return cached;\n const reducer = reducerMap[prop];\n if (reducer) {\n const reducerResult = reducer(void 0, {\n type: nanoid()\n });\n if (typeof reducerResult === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(24) : `The slice reducer for key \"${prop.toString()}\" returned undefined when called for selector(). If the state passed to the reducer is undefined, you must explicitly return the initial state. The initial state may not be undefined. If you don't want to set a value for this reducer, you can use null instead of undefined.`);\n }\n initialStateCache[prop] = reducerResult;\n return reducerResult;\n }\n }\n return result;\n }\n}));\nvar original = (state) => {\n if (!isStateProxy(state)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(25) : \"original must be used on state Proxy\");\n }\n return state[ORIGINAL_STATE];\n};\nvar emptyObject = {};\nvar noopReducer = (state = emptyObject) => state;\nfunction combineSlices(...slices) {\n const reducerMap = Object.fromEntries(getReducers(slices));\n const getReducer = () => Object.keys(reducerMap).length ? combineReducers2(reducerMap) : noopReducer;\n let reducer = getReducer();\n function combinedReducer(state, action) {\n return reducer(state, action);\n }\n combinedReducer.withLazyLoadedSlices = () => combinedReducer;\n const initialStateCache = {};\n const inject = (slice, config = {}) => {\n const {\n reducerPath,\n reducer: reducerToInject\n } = slice;\n const currentReducer = reducerMap[reducerPath];\n if (!config.overrideExisting && currentReducer && currentReducer !== reducerToInject) {\n if (typeof process !== \"undefined\" && process.env.NODE_ENV === \"development\") {\n console.error(`called \\`inject\\` to override already-existing reducer ${reducerPath} without specifying \\`overrideExisting: true\\``);\n }\n return combinedReducer;\n }\n if (config.overrideExisting && currentReducer !== reducerToInject) {\n delete initialStateCache[reducerPath];\n }\n reducerMap[reducerPath] = reducerToInject;\n reducer = getReducer();\n return combinedReducer;\n };\n const selector = Object.assign(function makeSelector(selectorFn, selectState) {\n return function selector2(state, ...args) {\n return selectorFn(createStateProxy(selectState ? selectState(state, ...args) : state, reducerMap, initialStateCache), ...args);\n };\n }, {\n original\n });\n return Object.assign(combinedReducer, {\n inject,\n selector\n });\n}\n\n// src/formatProdErrorMessage.ts\nfunction formatProdErrorMessage(code) {\n return `Minified Redux Toolkit error #${code}; visit https://redux-toolkit.js.org/Errors?code=${code} for the full message or use the non-minified dev environment for full errors. `;\n}\nexport {\n ReducerType,\n SHOULD_AUTOBATCH,\n TaskAbortError,\n Tuple,\n addListener,\n asyncThunkCreator,\n autoBatchEnhancer,\n buildCreateSlice,\n clearAllListeners,\n combineSlices,\n configureStore,\n createAction,\n createActionCreatorInvariantMiddleware,\n createAsyncThunk,\n createDraftSafeSelector,\n createDraftSafeSelectorCreator,\n createDynamicMiddleware,\n createEntityAdapter,\n createImmutableStateInvariantMiddleware,\n createListenerMiddleware,\n produce as createNextState,\n createReducer,\n createSelector,\n createSelectorCreator,\n createSerializableStateInvariantMiddleware,\n createSlice,\n current,\n findNonSerializableValue,\n formatProdErrorMessage,\n freeze,\n isActionCreator,\n isAllOf,\n isAnyOf,\n isAsyncThunkAction,\n isDraft,\n isFSA as isFluxStandardAction,\n isFulfilled,\n isImmutableDefault,\n isPending,\n isPlain,\n isRejected,\n isRejectedWithValue,\n lruMemoize,\n miniSerializeError,\n nanoid,\n original2 as original,\n prepareAutoBatched,\n removeListener,\n unwrapResult,\n weakMapMemoize\n};\n//# sourceMappingURL=redux-toolkit.modern.mjs.map","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction debounce(func, debounceMs, { signal, edges } = {}) {\n let pendingThis = undefined;\n let pendingArgs = null;\n const leading = edges != null && edges.includes('leading');\n const trailing = edges == null || edges.includes('trailing');\n const invoke = () => {\n if (pendingArgs !== null) {\n func.apply(pendingThis, pendingArgs);\n pendingThis = undefined;\n pendingArgs = null;\n }\n };\n const onTimerEnd = () => {\n if (trailing) {\n invoke();\n }\n cancel();\n };\n let timeoutId = null;\n const schedule = () => {\n if (timeoutId != null) {\n clearTimeout(timeoutId);\n }\n timeoutId = setTimeout(() => {\n timeoutId = null;\n onTimerEnd();\n }, debounceMs);\n };\n const cancelTimer = () => {\n if (timeoutId !== null) {\n clearTimeout(timeoutId);\n timeoutId = null;\n }\n };\n const cancel = () => {\n cancelTimer();\n pendingThis = undefined;\n pendingArgs = null;\n };\n const flush = () => {\n invoke();\n };\n const debounced = function (...args) {\n if (signal?.aborted) {\n return;\n }\n pendingThis = this;\n pendingArgs = args;\n const isFirstCall = timeoutId == null;\n schedule();\n if (leading && isFirstCall) {\n invoke();\n }\n };\n debounced.schedule = schedule;\n debounced.cancel = cancel;\n debounced.flush = flush;\n signal?.addEventListener('abort', cancel, { once: true });\n return debounced;\n}\n\nexports.debounce = debounce;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debounce$1 = require('../../function/debounce.js');\n\nfunction debounce(func, debounceMs = 0, options = {}) {\n if (typeof options !== 'object') {\n options = {};\n }\n const { leading = false, trailing = true, maxWait } = options;\n const edges = Array(2);\n if (leading) {\n edges[0] = 'leading';\n }\n if (trailing) {\n edges[1] = 'trailing';\n }\n let result = undefined;\n let pendingAt = null;\n const _debounced = debounce$1.debounce(function (...args) {\n result = func.apply(this, args);\n pendingAt = null;\n }, debounceMs, { edges });\n const debounced = function (...args) {\n if (maxWait != null) {\n if (pendingAt === null) {\n pendingAt = Date.now();\n }\n if (Date.now() - pendingAt >= maxWait) {\n result = func.apply(this, args);\n pendingAt = Date.now();\n _debounced.cancel();\n _debounced.schedule();\n return result;\n }\n }\n _debounced.apply(this, args);\n return result;\n };\n const flush = () => {\n _debounced.flush();\n return result;\n };\n debounced.cancel = _debounced.cancel;\n debounced.flush = flush;\n return debounced;\n}\n\nexports.debounce = debounce;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debounce = require('./debounce.js');\n\nfunction throttle(func, throttleMs = 0, options = {}) {\n const { leading = true, trailing = true } = options;\n return debounce.debounce(func, throttleMs, {\n leading,\n maxWait: throttleMs,\n trailing,\n });\n}\n\nexports.throttle = throttle;\n","module.exports = require('../dist/compat/function/throttle.js').throttle;\n","// src/utils/env.ts\nvar NOTHING = Symbol.for(\"immer-nothing\");\nvar DRAFTABLE = Symbol.for(\"immer-draftable\");\nvar DRAFT_STATE = Symbol.for(\"immer-state\");\n\n// src/utils/errors.ts\nvar errors = process.env.NODE_ENV !== \"production\" ? [\n // All error codes, starting by 0:\n function(plugin) {\n return `The plugin for '${plugin}' has not been loaded into Immer. To enable the plugin, import and call \\`enable${plugin}()\\` when initializing your application.`;\n },\n function(thing) {\n return `produce can only be called on things that are draftable: plain objects, arrays, Map, Set or classes that are marked with '[immerable]: true'. Got '${thing}'`;\n },\n \"This object has been frozen and should not be mutated\",\n function(data) {\n return \"Cannot use a proxy that has been revoked. Did you pass an object from inside an immer function to an async process? \" + data;\n },\n \"An immer producer returned a new value *and* modified its draft. Either return a new value *or* modify the draft.\",\n \"Immer forbids circular references\",\n \"The first or second argument to `produce` must be a function\",\n \"The third argument to `produce` must be a function or undefined\",\n \"First argument to `createDraft` must be a plain object, an array, or an immerable object\",\n \"First argument to `finishDraft` must be a draft returned by `createDraft`\",\n function(thing) {\n return `'current' expects a draft, got: ${thing}`;\n },\n \"Object.defineProperty() cannot be used on an Immer draft\",\n \"Object.setPrototypeOf() cannot be used on an Immer draft\",\n \"Immer only supports deleting array indices\",\n \"Immer only supports setting array indices and the 'length' property\",\n function(thing) {\n return `'original' expects a draft, got: ${thing}`;\n }\n // Note: if more errors are added, the errorOffset in Patches.ts should be increased\n // See Patches.ts for additional errors\n] : [];\nfunction die(error, ...args) {\n if (process.env.NODE_ENV !== \"production\") {\n const e = errors[error];\n const msg = typeof e === \"function\" ? e.apply(null, args) : e;\n throw new Error(`[Immer] ${msg}`);\n }\n throw new Error(\n `[Immer] minified error nr: ${error}. Full error at: https://bit.ly/3cXEKWf`\n );\n}\n\n// src/utils/common.ts\nvar getPrototypeOf = Object.getPrototypeOf;\nfunction isDraft(value) {\n return !!value && !!value[DRAFT_STATE];\n}\nfunction isDraftable(value) {\n if (!value)\n return false;\n return isPlainObject(value) || Array.isArray(value) || !!value[DRAFTABLE] || !!value.constructor?.[DRAFTABLE] || isMap(value) || isSet(value);\n}\nvar objectCtorString = Object.prototype.constructor.toString();\nvar cachedCtorStrings = /* @__PURE__ */ new WeakMap();\nfunction isPlainObject(value) {\n if (!value || typeof value !== \"object\")\n return false;\n const proto = Object.getPrototypeOf(value);\n if (proto === null || proto === Object.prototype)\n return true;\n const Ctor = Object.hasOwnProperty.call(proto, \"constructor\") && proto.constructor;\n if (Ctor === Object)\n return true;\n if (typeof Ctor !== \"function\")\n return false;\n let ctorString = cachedCtorStrings.get(Ctor);\n if (ctorString === void 0) {\n ctorString = Function.toString.call(Ctor);\n cachedCtorStrings.set(Ctor, ctorString);\n }\n return ctorString === objectCtorString;\n}\nfunction original(value) {\n if (!isDraft(value))\n die(15, value);\n return value[DRAFT_STATE].base_;\n}\nfunction each(obj, iter, strict = true) {\n if (getArchtype(obj) === 0 /* Object */) {\n const keys = strict ? Reflect.ownKeys(obj) : Object.keys(obj);\n keys.forEach((key) => {\n iter(key, obj[key], obj);\n });\n } else {\n obj.forEach((entry, index) => iter(index, entry, obj));\n }\n}\nfunction getArchtype(thing) {\n const state = thing[DRAFT_STATE];\n return state ? state.type_ : Array.isArray(thing) ? 1 /* Array */ : isMap(thing) ? 2 /* Map */ : isSet(thing) ? 3 /* Set */ : 0 /* Object */;\n}\nfunction has(thing, prop) {\n return getArchtype(thing) === 2 /* Map */ ? thing.has(prop) : Object.prototype.hasOwnProperty.call(thing, prop);\n}\nfunction get(thing, prop) {\n return getArchtype(thing) === 2 /* Map */ ? thing.get(prop) : thing[prop];\n}\nfunction set(thing, propOrOldValue, value) {\n const t = getArchtype(thing);\n if (t === 2 /* Map */)\n thing.set(propOrOldValue, value);\n else if (t === 3 /* Set */) {\n thing.add(value);\n } else\n thing[propOrOldValue] = value;\n}\nfunction is(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\nfunction isMap(target) {\n return target instanceof Map;\n}\nfunction isSet(target) {\n return target instanceof Set;\n}\nfunction latest(state) {\n return state.copy_ || state.base_;\n}\nfunction shallowCopy(base, strict) {\n if (isMap(base)) {\n return new Map(base);\n }\n if (isSet(base)) {\n return new Set(base);\n }\n if (Array.isArray(base))\n return Array.prototype.slice.call(base);\n const isPlain = isPlainObject(base);\n if (strict === true || strict === \"class_only\" && !isPlain) {\n const descriptors = Object.getOwnPropertyDescriptors(base);\n delete descriptors[DRAFT_STATE];\n let keys = Reflect.ownKeys(descriptors);\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n const desc = descriptors[key];\n if (desc.writable === false) {\n desc.writable = true;\n desc.configurable = true;\n }\n if (desc.get || desc.set)\n descriptors[key] = {\n configurable: true,\n writable: true,\n // could live with !!desc.set as well here...\n enumerable: desc.enumerable,\n value: base[key]\n };\n }\n return Object.create(getPrototypeOf(base), descriptors);\n } else {\n const proto = getPrototypeOf(base);\n if (proto !== null && isPlain) {\n return { ...base };\n }\n const obj = Object.create(proto);\n return Object.assign(obj, base);\n }\n}\nfunction freeze(obj, deep = false) {\n if (isFrozen(obj) || isDraft(obj) || !isDraftable(obj))\n return obj;\n if (getArchtype(obj) > 1) {\n Object.defineProperties(obj, {\n set: dontMutateMethodOverride,\n add: dontMutateMethodOverride,\n clear: dontMutateMethodOverride,\n delete: dontMutateMethodOverride\n });\n }\n Object.freeze(obj);\n if (deep)\n Object.values(obj).forEach((value) => freeze(value, true));\n return obj;\n}\nfunction dontMutateFrozenCollections() {\n die(2);\n}\nvar dontMutateMethodOverride = {\n value: dontMutateFrozenCollections\n};\nfunction isFrozen(obj) {\n if (obj === null || typeof obj !== \"object\")\n return true;\n return Object.isFrozen(obj);\n}\n\n// src/utils/plugins.ts\nvar plugins = {};\nfunction getPlugin(pluginKey) {\n const plugin = plugins[pluginKey];\n if (!plugin) {\n die(0, pluginKey);\n }\n return plugin;\n}\nfunction loadPlugin(pluginKey, implementation) {\n if (!plugins[pluginKey])\n plugins[pluginKey] = implementation;\n}\n\n// src/core/scope.ts\nvar currentScope;\nfunction getCurrentScope() {\n return currentScope;\n}\nfunction createScope(parent_, immer_) {\n return {\n drafts_: [],\n parent_,\n immer_,\n // Whenever the modified draft contains a draft from another scope, we\n // need to prevent auto-freezing so the unowned draft can be finalized.\n canAutoFreeze_: true,\n unfinalizedDrafts_: 0\n };\n}\nfunction usePatchesInScope(scope, patchListener) {\n if (patchListener) {\n getPlugin(\"Patches\");\n scope.patches_ = [];\n scope.inversePatches_ = [];\n scope.patchListener_ = patchListener;\n }\n}\nfunction revokeScope(scope) {\n leaveScope(scope);\n scope.drafts_.forEach(revokeDraft);\n scope.drafts_ = null;\n}\nfunction leaveScope(scope) {\n if (scope === currentScope) {\n currentScope = scope.parent_;\n }\n}\nfunction enterScope(immer2) {\n return currentScope = createScope(currentScope, immer2);\n}\nfunction revokeDraft(draft) {\n const state = draft[DRAFT_STATE];\n if (state.type_ === 0 /* Object */ || state.type_ === 1 /* Array */)\n state.revoke_();\n else\n state.revoked_ = true;\n}\n\n// src/core/finalize.ts\nfunction processResult(result, scope) {\n scope.unfinalizedDrafts_ = scope.drafts_.length;\n const baseDraft = scope.drafts_[0];\n const isReplaced = result !== void 0 && result !== baseDraft;\n if (isReplaced) {\n if (baseDraft[DRAFT_STATE].modified_) {\n revokeScope(scope);\n die(4);\n }\n if (isDraftable(result)) {\n result = finalize(scope, result);\n if (!scope.parent_)\n maybeFreeze(scope, result);\n }\n if (scope.patches_) {\n getPlugin(\"Patches\").generateReplacementPatches_(\n baseDraft[DRAFT_STATE].base_,\n result,\n scope.patches_,\n scope.inversePatches_\n );\n }\n } else {\n result = finalize(scope, baseDraft, []);\n }\n revokeScope(scope);\n if (scope.patches_) {\n scope.patchListener_(scope.patches_, scope.inversePatches_);\n }\n return result !== NOTHING ? result : void 0;\n}\nfunction finalize(rootScope, value, path) {\n if (isFrozen(value))\n return value;\n const useStrictIteration = rootScope.immer_.shouldUseStrictIteration();\n const state = value[DRAFT_STATE];\n if (!state) {\n each(\n value,\n (key, childValue) => finalizeProperty(rootScope, state, value, key, childValue, path),\n useStrictIteration\n );\n return value;\n }\n if (state.scope_ !== rootScope)\n return value;\n if (!state.modified_) {\n maybeFreeze(rootScope, state.base_, true);\n return state.base_;\n }\n if (!state.finalized_) {\n state.finalized_ = true;\n state.scope_.unfinalizedDrafts_--;\n const result = state.copy_;\n let resultEach = result;\n let isSet2 = false;\n if (state.type_ === 3 /* Set */) {\n resultEach = new Set(result);\n result.clear();\n isSet2 = true;\n }\n each(\n resultEach,\n (key, childValue) => finalizeProperty(\n rootScope,\n state,\n result,\n key,\n childValue,\n path,\n isSet2\n ),\n useStrictIteration\n );\n maybeFreeze(rootScope, result, false);\n if (path && rootScope.patches_) {\n getPlugin(\"Patches\").generatePatches_(\n state,\n path,\n rootScope.patches_,\n rootScope.inversePatches_\n );\n }\n }\n return state.copy_;\n}\nfunction finalizeProperty(rootScope, parentState, targetObject, prop, childValue, rootPath, targetIsSet) {\n if (childValue == null) {\n return;\n }\n if (typeof childValue !== \"object\" && !targetIsSet) {\n return;\n }\n const childIsFrozen = isFrozen(childValue);\n if (childIsFrozen && !targetIsSet) {\n return;\n }\n if (process.env.NODE_ENV !== \"production\" && childValue === targetObject)\n die(5);\n if (isDraft(childValue)) {\n const path = rootPath && parentState && parentState.type_ !== 3 /* Set */ && // Set objects are atomic since they have no keys.\n !has(parentState.assigned_, prop) ? rootPath.concat(prop) : void 0;\n const res = finalize(rootScope, childValue, path);\n set(targetObject, prop, res);\n if (isDraft(res)) {\n rootScope.canAutoFreeze_ = false;\n } else\n return;\n } else if (targetIsSet) {\n targetObject.add(childValue);\n }\n if (isDraftable(childValue) && !childIsFrozen) {\n if (!rootScope.immer_.autoFreeze_ && rootScope.unfinalizedDrafts_ < 1) {\n return;\n }\n if (parentState && parentState.base_ && parentState.base_[prop] === childValue && childIsFrozen) {\n return;\n }\n finalize(rootScope, childValue);\n if ((!parentState || !parentState.scope_.parent_) && typeof prop !== \"symbol\" && (isMap(targetObject) ? targetObject.has(prop) : Object.prototype.propertyIsEnumerable.call(targetObject, prop)))\n maybeFreeze(rootScope, childValue);\n }\n}\nfunction maybeFreeze(scope, value, deep = false) {\n if (!scope.parent_ && scope.immer_.autoFreeze_ && scope.canAutoFreeze_) {\n freeze(value, deep);\n }\n}\n\n// src/core/proxy.ts\nfunction createProxyProxy(base, parent) {\n const isArray = Array.isArray(base);\n const state = {\n type_: isArray ? 1 /* Array */ : 0 /* Object */,\n // Track which produce call this is associated with.\n scope_: parent ? parent.scope_ : getCurrentScope(),\n // True for both shallow and deep changes.\n modified_: false,\n // Used during finalization.\n finalized_: false,\n // Track which properties have been assigned (true) or deleted (false).\n assigned_: {},\n // The parent draft state.\n parent_: parent,\n // The base state.\n base_: base,\n // The base proxy.\n draft_: null,\n // set below\n // The base copy with any updated values.\n copy_: null,\n // Called by the `produce` function.\n revoke_: null,\n isManual_: false\n };\n let target = state;\n let traps = objectTraps;\n if (isArray) {\n target = [state];\n traps = arrayTraps;\n }\n const { revoke, proxy } = Proxy.revocable(target, traps);\n state.draft_ = proxy;\n state.revoke_ = revoke;\n return proxy;\n}\nvar objectTraps = {\n get(state, prop) {\n if (prop === DRAFT_STATE)\n return state;\n const source = latest(state);\n if (!has(source, prop)) {\n return readPropFromProto(state, source, prop);\n }\n const value = source[prop];\n if (state.finalized_ || !isDraftable(value)) {\n return value;\n }\n if (value === peek(state.base_, prop)) {\n prepareCopy(state);\n return state.copy_[prop] = createProxy(value, state);\n }\n return value;\n },\n has(state, prop) {\n return prop in latest(state);\n },\n ownKeys(state) {\n return Reflect.ownKeys(latest(state));\n },\n set(state, prop, value) {\n const desc = getDescriptorFromProto(latest(state), prop);\n if (desc?.set) {\n desc.set.call(state.draft_, value);\n return true;\n }\n if (!state.modified_) {\n const current2 = peek(latest(state), prop);\n const currentState = current2?.[DRAFT_STATE];\n if (currentState && currentState.base_ === value) {\n state.copy_[prop] = value;\n state.assigned_[prop] = false;\n return true;\n }\n if (is(value, current2) && (value !== void 0 || has(state.base_, prop)))\n return true;\n prepareCopy(state);\n markChanged(state);\n }\n if (state.copy_[prop] === value && // special case: handle new props with value 'undefined'\n (value !== void 0 || prop in state.copy_) || // special case: NaN\n Number.isNaN(value) && Number.isNaN(state.copy_[prop]))\n return true;\n state.copy_[prop] = value;\n state.assigned_[prop] = true;\n return true;\n },\n deleteProperty(state, prop) {\n if (peek(state.base_, prop) !== void 0 || prop in state.base_) {\n state.assigned_[prop] = false;\n prepareCopy(state);\n markChanged(state);\n } else {\n delete state.assigned_[prop];\n }\n if (state.copy_) {\n delete state.copy_[prop];\n }\n return true;\n },\n // Note: We never coerce `desc.value` into an Immer draft, because we can't make\n // the same guarantee in ES5 mode.\n getOwnPropertyDescriptor(state, prop) {\n const owner = latest(state);\n const desc = Reflect.getOwnPropertyDescriptor(owner, prop);\n if (!desc)\n return desc;\n return {\n writable: true,\n configurable: state.type_ !== 1 /* Array */ || prop !== \"length\",\n enumerable: desc.enumerable,\n value: owner[prop]\n };\n },\n defineProperty() {\n die(11);\n },\n getPrototypeOf(state) {\n return getPrototypeOf(state.base_);\n },\n setPrototypeOf() {\n die(12);\n }\n};\nvar arrayTraps = {};\neach(objectTraps, (key, fn) => {\n arrayTraps[key] = function() {\n arguments[0] = arguments[0][0];\n return fn.apply(this, arguments);\n };\n});\narrayTraps.deleteProperty = function(state, prop) {\n if (process.env.NODE_ENV !== \"production\" && isNaN(parseInt(prop)))\n die(13);\n return arrayTraps.set.call(this, state, prop, void 0);\n};\narrayTraps.set = function(state, prop, value) {\n if (process.env.NODE_ENV !== \"production\" && prop !== \"length\" && isNaN(parseInt(prop)))\n die(14);\n return objectTraps.set.call(this, state[0], prop, value, state[0]);\n};\nfunction peek(draft, prop) {\n const state = draft[DRAFT_STATE];\n const source = state ? latest(state) : draft;\n return source[prop];\n}\nfunction readPropFromProto(state, source, prop) {\n const desc = getDescriptorFromProto(source, prop);\n return desc ? `value` in desc ? desc.value : (\n // This is a very special case, if the prop is a getter defined by the\n // prototype, we should invoke it with the draft as context!\n desc.get?.call(state.draft_)\n ) : void 0;\n}\nfunction getDescriptorFromProto(source, prop) {\n if (!(prop in source))\n return void 0;\n let proto = getPrototypeOf(source);\n while (proto) {\n const desc = Object.getOwnPropertyDescriptor(proto, prop);\n if (desc)\n return desc;\n proto = getPrototypeOf(proto);\n }\n return void 0;\n}\nfunction markChanged(state) {\n if (!state.modified_) {\n state.modified_ = true;\n if (state.parent_) {\n markChanged(state.parent_);\n }\n }\n}\nfunction prepareCopy(state) {\n if (!state.copy_) {\n state.copy_ = shallowCopy(\n state.base_,\n state.scope_.immer_.useStrictShallowCopy_\n );\n }\n}\n\n// src/core/immerClass.ts\nvar Immer2 = class {\n constructor(config) {\n this.autoFreeze_ = true;\n this.useStrictShallowCopy_ = false;\n this.useStrictIteration_ = true;\n /**\n * The `produce` function takes a value and a \"recipe function\" (whose\n * return value often depends on the base state). The recipe function is\n * free to mutate its first argument however it wants. All mutations are\n * only ever applied to a __copy__ of the base state.\n *\n * Pass only a function to create a \"curried producer\" which relieves you\n * from passing the recipe function every time.\n *\n * Only plain objects and arrays are made mutable. All other objects are\n * considered uncopyable.\n *\n * Note: This function is __bound__ to its `Immer` instance.\n *\n * @param {any} base - the initial state\n * @param {Function} recipe - function that receives a proxy of the base state as first argument and which can be freely modified\n * @param {Function} patchListener - optional function that will be called with all the patches produced here\n * @returns {any} a new state, or the initial state if nothing was modified\n */\n this.produce = (base, recipe, patchListener) => {\n if (typeof base === \"function\" && typeof recipe !== \"function\") {\n const defaultBase = recipe;\n recipe = base;\n const self = this;\n return function curriedProduce(base2 = defaultBase, ...args) {\n return self.produce(base2, (draft) => recipe.call(this, draft, ...args));\n };\n }\n if (typeof recipe !== \"function\")\n die(6);\n if (patchListener !== void 0 && typeof patchListener !== \"function\")\n die(7);\n let result;\n if (isDraftable(base)) {\n const scope = enterScope(this);\n const proxy = createProxy(base, void 0);\n let hasError = true;\n try {\n result = recipe(proxy);\n hasError = false;\n } finally {\n if (hasError)\n revokeScope(scope);\n else\n leaveScope(scope);\n }\n usePatchesInScope(scope, patchListener);\n return processResult(result, scope);\n } else if (!base || typeof base !== \"object\") {\n result = recipe(base);\n if (result === void 0)\n result = base;\n if (result === NOTHING)\n result = void 0;\n if (this.autoFreeze_)\n freeze(result, true);\n if (patchListener) {\n const p = [];\n const ip = [];\n getPlugin(\"Patches\").generateReplacementPatches_(base, result, p, ip);\n patchListener(p, ip);\n }\n return result;\n } else\n die(1, base);\n };\n this.produceWithPatches = (base, recipe) => {\n if (typeof base === \"function\") {\n return (state, ...args) => this.produceWithPatches(state, (draft) => base(draft, ...args));\n }\n let patches, inversePatches;\n const result = this.produce(base, recipe, (p, ip) => {\n patches = p;\n inversePatches = ip;\n });\n return [result, patches, inversePatches];\n };\n if (typeof config?.autoFreeze === \"boolean\")\n this.setAutoFreeze(config.autoFreeze);\n if (typeof config?.useStrictShallowCopy === \"boolean\")\n this.setUseStrictShallowCopy(config.useStrictShallowCopy);\n if (typeof config?.useStrictIteration === \"boolean\")\n this.setUseStrictIteration(config.useStrictIteration);\n }\n createDraft(base) {\n if (!isDraftable(base))\n die(8);\n if (isDraft(base))\n base = current(base);\n const scope = enterScope(this);\n const proxy = createProxy(base, void 0);\n proxy[DRAFT_STATE].isManual_ = true;\n leaveScope(scope);\n return proxy;\n }\n finishDraft(draft, patchListener) {\n const state = draft && draft[DRAFT_STATE];\n if (!state || !state.isManual_)\n die(9);\n const { scope_: scope } = state;\n usePatchesInScope(scope, patchListener);\n return processResult(void 0, scope);\n }\n /**\n * Pass true to automatically freeze all copies created by Immer.\n *\n * By default, auto-freezing is enabled.\n */\n setAutoFreeze(value) {\n this.autoFreeze_ = value;\n }\n /**\n * Pass true to enable strict shallow copy.\n *\n * By default, immer does not copy the object descriptors such as getter, setter and non-enumrable properties.\n */\n setUseStrictShallowCopy(value) {\n this.useStrictShallowCopy_ = value;\n }\n /**\n * Pass false to use faster iteration that skips non-enumerable properties\n * but still handles symbols for compatibility.\n *\n * By default, strict iteration is enabled (includes all own properties).\n */\n setUseStrictIteration(value) {\n this.useStrictIteration_ = value;\n }\n shouldUseStrictIteration() {\n return this.useStrictIteration_;\n }\n applyPatches(base, patches) {\n let i;\n for (i = patches.length - 1; i >= 0; i--) {\n const patch = patches[i];\n if (patch.path.length === 0 && patch.op === \"replace\") {\n base = patch.value;\n break;\n }\n }\n if (i > -1) {\n patches = patches.slice(i + 1);\n }\n const applyPatchesImpl = getPlugin(\"Patches\").applyPatches_;\n if (isDraft(base)) {\n return applyPatchesImpl(base, patches);\n }\n return this.produce(\n base,\n (draft) => applyPatchesImpl(draft, patches)\n );\n }\n};\nfunction createProxy(value, parent) {\n const draft = isMap(value) ? getPlugin(\"MapSet\").proxyMap_(value, parent) : isSet(value) ? getPlugin(\"MapSet\").proxySet_(value, parent) : createProxyProxy(value, parent);\n const scope = parent ? parent.scope_ : getCurrentScope();\n scope.drafts_.push(draft);\n return draft;\n}\n\n// src/core/current.ts\nfunction current(value) {\n if (!isDraft(value))\n die(10, value);\n return currentImpl(value);\n}\nfunction currentImpl(value) {\n if (!isDraftable(value) || isFrozen(value))\n return value;\n const state = value[DRAFT_STATE];\n let copy;\n let strict = true;\n if (state) {\n if (!state.modified_)\n return state.base_;\n state.finalized_ = true;\n copy = shallowCopy(value, state.scope_.immer_.useStrictShallowCopy_);\n strict = state.scope_.immer_.shouldUseStrictIteration();\n } else {\n copy = shallowCopy(value, true);\n }\n each(\n copy,\n (key, childValue) => {\n set(copy, key, currentImpl(childValue));\n },\n strict\n );\n if (state) {\n state.finalized_ = false;\n }\n return copy;\n}\n\n// src/plugins/patches.ts\nfunction enablePatches() {\n const errorOffset = 16;\n if (process.env.NODE_ENV !== \"production\") {\n errors.push(\n 'Sets cannot have \"replace\" patches.',\n function(op) {\n return \"Unsupported patch operation: \" + op;\n },\n function(path) {\n return \"Cannot apply patch, path doesn't resolve: \" + path;\n },\n \"Patching reserved attributes like __proto__, prototype and constructor is not allowed\"\n );\n }\n const REPLACE = \"replace\";\n const ADD = \"add\";\n const REMOVE = \"remove\";\n function generatePatches_(state, basePath, patches, inversePatches) {\n switch (state.type_) {\n case 0 /* Object */:\n case 2 /* Map */:\n return generatePatchesFromAssigned(\n state,\n basePath,\n patches,\n inversePatches\n );\n case 1 /* Array */:\n return generateArrayPatches(state, basePath, patches, inversePatches);\n case 3 /* Set */:\n return generateSetPatches(\n state,\n basePath,\n patches,\n inversePatches\n );\n }\n }\n function generateArrayPatches(state, basePath, patches, inversePatches) {\n let { base_, assigned_ } = state;\n let copy_ = state.copy_;\n if (copy_.length < base_.length) {\n ;\n [base_, copy_] = [copy_, base_];\n [patches, inversePatches] = [inversePatches, patches];\n }\n for (let i = 0; i < base_.length; i++) {\n if (assigned_[i] && copy_[i] !== base_[i]) {\n const path = basePath.concat([i]);\n patches.push({\n op: REPLACE,\n path,\n // Need to maybe clone it, as it can in fact be the original value\n // due to the base/copy inversion at the start of this function\n value: clonePatchValueIfNeeded(copy_[i])\n });\n inversePatches.push({\n op: REPLACE,\n path,\n value: clonePatchValueIfNeeded(base_[i])\n });\n }\n }\n for (let i = base_.length; i < copy_.length; i++) {\n const path = basePath.concat([i]);\n patches.push({\n op: ADD,\n path,\n // Need to maybe clone it, as it can in fact be the original value\n // due to the base/copy inversion at the start of this function\n value: clonePatchValueIfNeeded(copy_[i])\n });\n }\n for (let i = copy_.length - 1; base_.length <= i; --i) {\n const path = basePath.concat([i]);\n inversePatches.push({\n op: REMOVE,\n path\n });\n }\n }\n function generatePatchesFromAssigned(state, basePath, patches, inversePatches) {\n const { base_, copy_ } = state;\n each(state.assigned_, (key, assignedValue) => {\n const origValue = get(base_, key);\n const value = get(copy_, key);\n const op = !assignedValue ? REMOVE : has(base_, key) ? REPLACE : ADD;\n if (origValue === value && op === REPLACE)\n return;\n const path = basePath.concat(key);\n patches.push(op === REMOVE ? { op, path } : { op, path, value });\n inversePatches.push(\n op === ADD ? { op: REMOVE, path } : op === REMOVE ? { op: ADD, path, value: clonePatchValueIfNeeded(origValue) } : { op: REPLACE, path, value: clonePatchValueIfNeeded(origValue) }\n );\n });\n }\n function generateSetPatches(state, basePath, patches, inversePatches) {\n let { base_, copy_ } = state;\n let i = 0;\n base_.forEach((value) => {\n if (!copy_.has(value)) {\n const path = basePath.concat([i]);\n patches.push({\n op: REMOVE,\n path,\n value\n });\n inversePatches.unshift({\n op: ADD,\n path,\n value\n });\n }\n i++;\n });\n i = 0;\n copy_.forEach((value) => {\n if (!base_.has(value)) {\n const path = basePath.concat([i]);\n patches.push({\n op: ADD,\n path,\n value\n });\n inversePatches.unshift({\n op: REMOVE,\n path,\n value\n });\n }\n i++;\n });\n }\n function generateReplacementPatches_(baseValue, replacement, patches, inversePatches) {\n patches.push({\n op: REPLACE,\n path: [],\n value: replacement === NOTHING ? void 0 : replacement\n });\n inversePatches.push({\n op: REPLACE,\n path: [],\n value: baseValue\n });\n }\n function applyPatches_(draft, patches) {\n patches.forEach((patch) => {\n const { path, op } = patch;\n let base = draft;\n for (let i = 0; i < path.length - 1; i++) {\n const parentType = getArchtype(base);\n let p = path[i];\n if (typeof p !== \"string\" && typeof p !== \"number\") {\n p = \"\" + p;\n }\n if ((parentType === 0 /* Object */ || parentType === 1 /* Array */) && (p === \"__proto__\" || p === \"constructor\"))\n die(errorOffset + 3);\n if (typeof base === \"function\" && p === \"prototype\")\n die(errorOffset + 3);\n base = get(base, p);\n if (typeof base !== \"object\")\n die(errorOffset + 2, path.join(\"/\"));\n }\n const type = getArchtype(base);\n const value = deepClonePatchValue(patch.value);\n const key = path[path.length - 1];\n switch (op) {\n case REPLACE:\n switch (type) {\n case 2 /* Map */:\n return base.set(key, value);\n case 3 /* Set */:\n die(errorOffset);\n default:\n return base[key] = value;\n }\n case ADD:\n switch (type) {\n case 1 /* Array */:\n return key === \"-\" ? base.push(value) : base.splice(key, 0, value);\n case 2 /* Map */:\n return base.set(key, value);\n case 3 /* Set */:\n return base.add(value);\n default:\n return base[key] = value;\n }\n case REMOVE:\n switch (type) {\n case 1 /* Array */:\n return base.splice(key, 1);\n case 2 /* Map */:\n return base.delete(key);\n case 3 /* Set */:\n return base.delete(patch.value);\n default:\n return delete base[key];\n }\n default:\n die(errorOffset + 1, op);\n }\n });\n return draft;\n }\n function deepClonePatchValue(obj) {\n if (!isDraftable(obj))\n return obj;\n if (Array.isArray(obj))\n return obj.map(deepClonePatchValue);\n if (isMap(obj))\n return new Map(\n Array.from(obj.entries()).map(([k, v]) => [k, deepClonePatchValue(v)])\n );\n if (isSet(obj))\n return new Set(Array.from(obj).map(deepClonePatchValue));\n const cloned = Object.create(getPrototypeOf(obj));\n for (const key in obj)\n cloned[key] = deepClonePatchValue(obj[key]);\n if (has(obj, DRAFTABLE))\n cloned[DRAFTABLE] = obj[DRAFTABLE];\n return cloned;\n }\n function clonePatchValueIfNeeded(obj) {\n if (isDraft(obj)) {\n return deepClonePatchValue(obj);\n } else\n return obj;\n }\n loadPlugin(\"Patches\", {\n applyPatches_,\n generatePatches_,\n generateReplacementPatches_\n });\n}\n\n// src/plugins/mapset.ts\nfunction enableMapSet() {\n class DraftMap extends Map {\n constructor(target, parent) {\n super();\n this[DRAFT_STATE] = {\n type_: 2 /* Map */,\n parent_: parent,\n scope_: parent ? parent.scope_ : getCurrentScope(),\n modified_: false,\n finalized_: false,\n copy_: void 0,\n assigned_: void 0,\n base_: target,\n draft_: this,\n isManual_: false,\n revoked_: false\n };\n }\n get size() {\n return latest(this[DRAFT_STATE]).size;\n }\n has(key) {\n return latest(this[DRAFT_STATE]).has(key);\n }\n set(key, value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!latest(state).has(key) || latest(state).get(key) !== value) {\n prepareMapCopy(state);\n markChanged(state);\n state.assigned_.set(key, true);\n state.copy_.set(key, value);\n state.assigned_.set(key, true);\n }\n return this;\n }\n delete(key) {\n if (!this.has(key)) {\n return false;\n }\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareMapCopy(state);\n markChanged(state);\n if (state.base_.has(key)) {\n state.assigned_.set(key, false);\n } else {\n state.assigned_.delete(key);\n }\n state.copy_.delete(key);\n return true;\n }\n clear() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (latest(state).size) {\n prepareMapCopy(state);\n markChanged(state);\n state.assigned_ = /* @__PURE__ */ new Map();\n each(state.base_, (key) => {\n state.assigned_.set(key, false);\n });\n state.copy_.clear();\n }\n }\n forEach(cb, thisArg) {\n const state = this[DRAFT_STATE];\n latest(state).forEach((_value, key, _map) => {\n cb.call(thisArg, this.get(key), key, this);\n });\n }\n get(key) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n const value = latest(state).get(key);\n if (state.finalized_ || !isDraftable(value)) {\n return value;\n }\n if (value !== state.base_.get(key)) {\n return value;\n }\n const draft = createProxy(value, state);\n prepareMapCopy(state);\n state.copy_.set(key, draft);\n return draft;\n }\n keys() {\n return latest(this[DRAFT_STATE]).keys();\n }\n values() {\n const iterator = this.keys();\n return {\n [Symbol.iterator]: () => this.values(),\n next: () => {\n const r = iterator.next();\n if (r.done)\n return r;\n const value = this.get(r.value);\n return {\n done: false,\n value\n };\n }\n };\n }\n entries() {\n const iterator = this.keys();\n return {\n [Symbol.iterator]: () => this.entries(),\n next: () => {\n const r = iterator.next();\n if (r.done)\n return r;\n const value = this.get(r.value);\n return {\n done: false,\n value: [r.value, value]\n };\n }\n };\n }\n [(DRAFT_STATE, Symbol.iterator)]() {\n return this.entries();\n }\n }\n function proxyMap_(target, parent) {\n return new DraftMap(target, parent);\n }\n function prepareMapCopy(state) {\n if (!state.copy_) {\n state.assigned_ = /* @__PURE__ */ new Map();\n state.copy_ = new Map(state.base_);\n }\n }\n class DraftSet extends Set {\n constructor(target, parent) {\n super();\n this[DRAFT_STATE] = {\n type_: 3 /* Set */,\n parent_: parent,\n scope_: parent ? parent.scope_ : getCurrentScope(),\n modified_: false,\n finalized_: false,\n copy_: void 0,\n base_: target,\n draft_: this,\n drafts_: /* @__PURE__ */ new Map(),\n revoked_: false,\n isManual_: false\n };\n }\n get size() {\n return latest(this[DRAFT_STATE]).size;\n }\n has(value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!state.copy_) {\n return state.base_.has(value);\n }\n if (state.copy_.has(value))\n return true;\n if (state.drafts_.has(value) && state.copy_.has(state.drafts_.get(value)))\n return true;\n return false;\n }\n add(value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!this.has(value)) {\n prepareSetCopy(state);\n markChanged(state);\n state.copy_.add(value);\n }\n return this;\n }\n delete(value) {\n if (!this.has(value)) {\n return false;\n }\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n markChanged(state);\n return state.copy_.delete(value) || (state.drafts_.has(value) ? state.copy_.delete(state.drafts_.get(value)) : (\n /* istanbul ignore next */\n false\n ));\n }\n clear() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (latest(state).size) {\n prepareSetCopy(state);\n markChanged(state);\n state.copy_.clear();\n }\n }\n values() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n return state.copy_.values();\n }\n entries() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n return state.copy_.entries();\n }\n keys() {\n return this.values();\n }\n [(DRAFT_STATE, Symbol.iterator)]() {\n return this.values();\n }\n forEach(cb, thisArg) {\n const iterator = this.values();\n let result = iterator.next();\n while (!result.done) {\n cb.call(thisArg, result.value, result.value, this);\n result = iterator.next();\n }\n }\n }\n function proxySet_(target, parent) {\n return new DraftSet(target, parent);\n }\n function prepareSetCopy(state) {\n if (!state.copy_) {\n state.copy_ = /* @__PURE__ */ new Set();\n state.base_.forEach((value) => {\n if (isDraftable(value)) {\n const draft = createProxy(value, state);\n state.drafts_.set(value, draft);\n state.copy_.add(draft);\n } else {\n state.copy_.add(value);\n }\n });\n }\n }\n function assertUnrevoked(state) {\n if (state.revoked_)\n die(3, JSON.stringify(latest(state)));\n }\n loadPlugin(\"MapSet\", { proxyMap_, proxySet_ });\n}\n\n// src/immer.ts\nvar immer = new Immer2();\nvar produce = immer.produce;\nvar produceWithPatches = /* @__PURE__ */ immer.produceWithPatches.bind(\n immer\n);\nvar setAutoFreeze = /* @__PURE__ */ immer.setAutoFreeze.bind(immer);\nvar setUseStrictShallowCopy = /* @__PURE__ */ immer.setUseStrictShallowCopy.bind(\n immer\n);\nvar setUseStrictIteration = /* @__PURE__ */ immer.setUseStrictIteration.bind(\n immer\n);\nvar applyPatches = /* @__PURE__ */ immer.applyPatches.bind(immer);\nvar createDraft = /* @__PURE__ */ immer.createDraft.bind(immer);\nvar finishDraft = /* @__PURE__ */ immer.finishDraft.bind(immer);\nfunction castDraft(value) {\n return value;\n}\nfunction castImmutable(value) {\n return value;\n}\nexport {\n Immer2 as Immer,\n applyPatches,\n castDraft,\n castImmutable,\n createDraft,\n current,\n enableMapSet,\n enablePatches,\n finishDraft,\n freeze,\n DRAFTABLE as immerable,\n isDraft,\n isDraftable,\n NOTHING as nothing,\n original,\n produce,\n produceWithPatches,\n setAutoFreeze,\n setUseStrictIteration,\n setUseStrictShallowCopy\n};\n//# sourceMappingURL=immer.mjs.map","/**\n * @license React\n * use-sync-external-store-with-selector.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar React = require(\"react\");\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useSyncExternalStore = React.useSyncExternalStore,\n useRef = React.useRef,\n useEffect = React.useEffect,\n useMemo = React.useMemo,\n useDebugValue = React.useDebugValue;\nexports.useSyncExternalStoreWithSelector = function (\n subscribe,\n getSnapshot,\n getServerSnapshot,\n selector,\n isEqual\n) {\n var instRef = useRef(null);\n if (null === instRef.current) {\n var inst = { hasValue: !1, value: null };\n instRef.current = inst;\n } else inst = instRef.current;\n instRef = useMemo(\n function () {\n function memoizedSelector(nextSnapshot) {\n if (!hasMemo) {\n hasMemo = !0;\n memoizedSnapshot = nextSnapshot;\n nextSnapshot = selector(nextSnapshot);\n if (void 0 !== isEqual && inst.hasValue) {\n var currentSelection = inst.value;\n if (isEqual(currentSelection, nextSnapshot))\n return (memoizedSelection = currentSelection);\n }\n return (memoizedSelection = nextSnapshot);\n }\n currentSelection = memoizedSelection;\n if (objectIs(memoizedSnapshot, nextSnapshot)) return currentSelection;\n var nextSelection = selector(nextSnapshot);\n if (void 0 !== isEqual && isEqual(currentSelection, nextSelection))\n return (memoizedSnapshot = nextSnapshot), currentSelection;\n memoizedSnapshot = nextSnapshot;\n return (memoizedSelection = nextSelection);\n }\n var hasMemo = !1,\n memoizedSnapshot,\n memoizedSelection,\n maybeGetServerSnapshot =\n void 0 === getServerSnapshot ? null : getServerSnapshot;\n return [\n function () {\n return memoizedSelector(getSnapshot());\n },\n null === maybeGetServerSnapshot\n ? void 0\n : function () {\n return memoizedSelector(maybeGetServerSnapshot());\n }\n ];\n },\n [getSnapshot, getServerSnapshot, selector, isEqual]\n );\n var value = useSyncExternalStore(subscribe, instRef[0], instRef[1]);\n useEffect(\n function () {\n inst.hasValue = !0;\n inst.value = value;\n },\n [value]\n );\n useDebugValue(value);\n return value;\n};\n","// src/utils/react.ts\nimport * as React from \"react\";\n\n// src/utils/react-is.ts\nvar IS_REACT_19 = /* @__PURE__ */ React.version.startsWith(\"19\");\nvar REACT_ELEMENT_TYPE = /* @__PURE__ */ Symbol.for(\n IS_REACT_19 ? \"react.transitional.element\" : \"react.element\"\n);\nvar REACT_PORTAL_TYPE = /* @__PURE__ */ Symbol.for(\"react.portal\");\nvar REACT_FRAGMENT_TYPE = /* @__PURE__ */ Symbol.for(\"react.fragment\");\nvar REACT_STRICT_MODE_TYPE = /* @__PURE__ */ Symbol.for(\"react.strict_mode\");\nvar REACT_PROFILER_TYPE = /* @__PURE__ */ Symbol.for(\"react.profiler\");\nvar REACT_CONSUMER_TYPE = /* @__PURE__ */ Symbol.for(\"react.consumer\");\nvar REACT_CONTEXT_TYPE = /* @__PURE__ */ Symbol.for(\"react.context\");\nvar REACT_FORWARD_REF_TYPE = /* @__PURE__ */ Symbol.for(\"react.forward_ref\");\nvar REACT_SUSPENSE_TYPE = /* @__PURE__ */ Symbol.for(\"react.suspense\");\nvar REACT_SUSPENSE_LIST_TYPE = /* @__PURE__ */ Symbol.for(\n \"react.suspense_list\"\n);\nvar REACT_MEMO_TYPE = /* @__PURE__ */ Symbol.for(\"react.memo\");\nvar REACT_LAZY_TYPE = /* @__PURE__ */ Symbol.for(\"react.lazy\");\nvar REACT_OFFSCREEN_TYPE = /* @__PURE__ */ Symbol.for(\"react.offscreen\");\nvar REACT_CLIENT_REFERENCE = /* @__PURE__ */ Symbol.for(\n \"react.client.reference\"\n);\nvar ForwardRef = REACT_FORWARD_REF_TYPE;\nvar Memo = REACT_MEMO_TYPE;\nfunction isValidElementType(type) {\n return typeof type === \"string\" || typeof type === \"function\" || type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || type === REACT_OFFSCREEN_TYPE || typeof type === \"object\" && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_CONSUMER_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_CLIENT_REFERENCE || type.getModuleId !== void 0) ? true : false;\n}\nfunction typeOf(object) {\n if (typeof object === \"object\" && object !== null) {\n const { $$typeof } = object;\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n switch (object = object.type, object) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n return object;\n default:\n switch (object = object && object.$$typeof, object) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n return object;\n case REACT_CONSUMER_TYPE:\n return object;\n default:\n return $$typeof;\n }\n }\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n}\nfunction isContextConsumer(object) {\n return IS_REACT_19 ? typeOf(object) === REACT_CONSUMER_TYPE : typeOf(object) === REACT_CONTEXT_TYPE;\n}\nfunction isMemo(object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n}\n\n// src/utils/warning.ts\nfunction warning(message) {\n if (typeof console !== \"undefined\" && typeof console.error === \"function\") {\n console.error(message);\n }\n try {\n throw new Error(message);\n } catch (e) {\n }\n}\n\n// src/connect/verifySubselectors.ts\nfunction verify(selector, methodName) {\n if (!selector) {\n throw new Error(`Unexpected value for ${methodName} in connect.`);\n } else if (methodName === \"mapStateToProps\" || methodName === \"mapDispatchToProps\") {\n if (!Object.prototype.hasOwnProperty.call(selector, \"dependsOnOwnProps\")) {\n warning(\n `The selector for ${methodName} of connect did not specify a value for dependsOnOwnProps.`\n );\n }\n }\n}\nfunction verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps) {\n verify(mapStateToProps, \"mapStateToProps\");\n verify(mapDispatchToProps, \"mapDispatchToProps\");\n verify(mergeProps, \"mergeProps\");\n}\n\n// src/connect/selectorFactory.ts\nfunction pureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, {\n areStatesEqual,\n areOwnPropsEqual,\n areStatePropsEqual\n}) {\n let hasRunAtLeastOnce = false;\n let state;\n let ownProps;\n let stateProps;\n let dispatchProps;\n let mergedProps;\n function handleFirstCall(firstState, firstOwnProps) {\n state = firstState;\n ownProps = firstOwnProps;\n stateProps = mapStateToProps(state, ownProps);\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n hasRunAtLeastOnce = true;\n return mergedProps;\n }\n function handleNewPropsAndNewState() {\n stateProps = mapStateToProps(state, ownProps);\n if (mapDispatchToProps.dependsOnOwnProps)\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n function handleNewProps() {\n if (mapStateToProps.dependsOnOwnProps)\n stateProps = mapStateToProps(state, ownProps);\n if (mapDispatchToProps.dependsOnOwnProps)\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n function handleNewState() {\n const nextStateProps = mapStateToProps(state, ownProps);\n const statePropsChanged = !areStatePropsEqual(nextStateProps, stateProps);\n stateProps = nextStateProps;\n if (statePropsChanged)\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n function handleSubsequentCalls(nextState, nextOwnProps) {\n const propsChanged = !areOwnPropsEqual(nextOwnProps, ownProps);\n const stateChanged = !areStatesEqual(\n nextState,\n state,\n nextOwnProps,\n ownProps\n );\n state = nextState;\n ownProps = nextOwnProps;\n if (propsChanged && stateChanged) return handleNewPropsAndNewState();\n if (propsChanged) return handleNewProps();\n if (stateChanged) return handleNewState();\n return mergedProps;\n }\n return function pureFinalPropsSelector(nextState, nextOwnProps) {\n return hasRunAtLeastOnce ? handleSubsequentCalls(nextState, nextOwnProps) : handleFirstCall(nextState, nextOwnProps);\n };\n}\nfunction finalPropsSelectorFactory(dispatch, {\n initMapStateToProps,\n initMapDispatchToProps,\n initMergeProps,\n ...options\n}) {\n const mapStateToProps = initMapStateToProps(dispatch, options);\n const mapDispatchToProps = initMapDispatchToProps(dispatch, options);\n const mergeProps = initMergeProps(dispatch, options);\n if (process.env.NODE_ENV !== \"production\") {\n verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps);\n }\n return pureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, options);\n}\n\n// src/utils/bindActionCreators.ts\nfunction bindActionCreators(actionCreators, dispatch) {\n const boundActionCreators = {};\n for (const key in actionCreators) {\n const actionCreator = actionCreators[key];\n if (typeof actionCreator === \"function\") {\n boundActionCreators[key] = (...args) => dispatch(actionCreator(...args));\n }\n }\n return boundActionCreators;\n}\n\n// src/utils/isPlainObject.ts\nfunction isPlainObject(obj) {\n if (typeof obj !== \"object\" || obj === null) return false;\n const proto = Object.getPrototypeOf(obj);\n if (proto === null) return true;\n let baseProto = proto;\n while (Object.getPrototypeOf(baseProto) !== null) {\n baseProto = Object.getPrototypeOf(baseProto);\n }\n return proto === baseProto;\n}\n\n// src/utils/verifyPlainObject.ts\nfunction verifyPlainObject(value, displayName, methodName) {\n if (!isPlainObject(value)) {\n warning(\n `${methodName}() in ${displayName} must return a plain object. Instead received ${value}.`\n );\n }\n}\n\n// src/connect/wrapMapToProps.ts\nfunction wrapMapToPropsConstant(getConstant) {\n return function initConstantSelector(dispatch) {\n const constant = getConstant(dispatch);\n function constantSelector() {\n return constant;\n }\n constantSelector.dependsOnOwnProps = false;\n return constantSelector;\n };\n}\nfunction getDependsOnOwnProps(mapToProps) {\n return mapToProps.dependsOnOwnProps ? Boolean(mapToProps.dependsOnOwnProps) : mapToProps.length !== 1;\n}\nfunction wrapMapToPropsFunc(mapToProps, methodName) {\n return function initProxySelector(dispatch, { displayName }) {\n const proxy = function mapToPropsProxy(stateOrDispatch, ownProps) {\n return proxy.dependsOnOwnProps ? proxy.mapToProps(stateOrDispatch, ownProps) : proxy.mapToProps(stateOrDispatch, void 0);\n };\n proxy.dependsOnOwnProps = true;\n proxy.mapToProps = function detectFactoryAndVerify(stateOrDispatch, ownProps) {\n proxy.mapToProps = mapToProps;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(mapToProps);\n let props = proxy(stateOrDispatch, ownProps);\n if (typeof props === \"function\") {\n proxy.mapToProps = props;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(props);\n props = proxy(stateOrDispatch, ownProps);\n }\n if (process.env.NODE_ENV !== \"production\")\n verifyPlainObject(props, displayName, methodName);\n return props;\n };\n return proxy;\n };\n}\n\n// src/connect/invalidArgFactory.ts\nfunction createInvalidArgFactory(arg, name) {\n return (dispatch, options) => {\n throw new Error(\n `Invalid value of type ${typeof arg} for ${name} argument when connecting component ${options.wrappedComponentName}.`\n );\n };\n}\n\n// src/connect/mapDispatchToProps.ts\nfunction mapDispatchToPropsFactory(mapDispatchToProps) {\n return mapDispatchToProps && typeof mapDispatchToProps === \"object\" ? wrapMapToPropsConstant(\n (dispatch) => (\n // @ts-ignore\n bindActionCreators(mapDispatchToProps, dispatch)\n )\n ) : !mapDispatchToProps ? wrapMapToPropsConstant((dispatch) => ({\n dispatch\n })) : typeof mapDispatchToProps === \"function\" ? (\n // @ts-ignore\n wrapMapToPropsFunc(mapDispatchToProps, \"mapDispatchToProps\")\n ) : createInvalidArgFactory(mapDispatchToProps, \"mapDispatchToProps\");\n}\n\n// src/connect/mapStateToProps.ts\nfunction mapStateToPropsFactory(mapStateToProps) {\n return !mapStateToProps ? wrapMapToPropsConstant(() => ({})) : typeof mapStateToProps === \"function\" ? (\n // @ts-ignore\n wrapMapToPropsFunc(mapStateToProps, \"mapStateToProps\")\n ) : createInvalidArgFactory(mapStateToProps, \"mapStateToProps\");\n}\n\n// src/connect/mergeProps.ts\nfunction defaultMergeProps(stateProps, dispatchProps, ownProps) {\n return { ...ownProps, ...stateProps, ...dispatchProps };\n}\nfunction wrapMergePropsFunc(mergeProps) {\n return function initMergePropsProxy(dispatch, { displayName, areMergedPropsEqual }) {\n let hasRunOnce = false;\n let mergedProps;\n return function mergePropsProxy(stateProps, dispatchProps, ownProps) {\n const nextMergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n if (hasRunOnce) {\n if (!areMergedPropsEqual(nextMergedProps, mergedProps))\n mergedProps = nextMergedProps;\n } else {\n hasRunOnce = true;\n mergedProps = nextMergedProps;\n if (process.env.NODE_ENV !== \"production\")\n verifyPlainObject(mergedProps, displayName, \"mergeProps\");\n }\n return mergedProps;\n };\n };\n}\nfunction mergePropsFactory(mergeProps) {\n return !mergeProps ? () => defaultMergeProps : typeof mergeProps === \"function\" ? wrapMergePropsFunc(mergeProps) : createInvalidArgFactory(mergeProps, \"mergeProps\");\n}\n\n// src/utils/batch.ts\nfunction defaultNoopBatch(callback) {\n callback();\n}\n\n// src/utils/Subscription.ts\nfunction createListenerCollection() {\n let first = null;\n let last = null;\n return {\n clear() {\n first = null;\n last = null;\n },\n notify() {\n defaultNoopBatch(() => {\n let listener = first;\n while (listener) {\n listener.callback();\n listener = listener.next;\n }\n });\n },\n get() {\n const listeners = [];\n let listener = first;\n while (listener) {\n listeners.push(listener);\n listener = listener.next;\n }\n return listeners;\n },\n subscribe(callback) {\n let isSubscribed = true;\n const listener = last = {\n callback,\n next: null,\n prev: last\n };\n if (listener.prev) {\n listener.prev.next = listener;\n } else {\n first = listener;\n }\n return function unsubscribe() {\n if (!isSubscribed || first === null) return;\n isSubscribed = false;\n if (listener.next) {\n listener.next.prev = listener.prev;\n } else {\n last = listener.prev;\n }\n if (listener.prev) {\n listener.prev.next = listener.next;\n } else {\n first = listener.next;\n }\n };\n }\n };\n}\nvar nullListeners = {\n notify() {\n },\n get: () => []\n};\nfunction createSubscription(store, parentSub) {\n let unsubscribe;\n let listeners = nullListeners;\n let subscriptionsAmount = 0;\n let selfSubscribed = false;\n function addNestedSub(listener) {\n trySubscribe();\n const cleanupListener = listeners.subscribe(listener);\n let removed = false;\n return () => {\n if (!removed) {\n removed = true;\n cleanupListener();\n tryUnsubscribe();\n }\n };\n }\n function notifyNestedSubs() {\n listeners.notify();\n }\n function handleChangeWrapper() {\n if (subscription.onStateChange) {\n subscription.onStateChange();\n }\n }\n function isSubscribed() {\n return selfSubscribed;\n }\n function trySubscribe() {\n subscriptionsAmount++;\n if (!unsubscribe) {\n unsubscribe = parentSub ? parentSub.addNestedSub(handleChangeWrapper) : store.subscribe(handleChangeWrapper);\n listeners = createListenerCollection();\n }\n }\n function tryUnsubscribe() {\n subscriptionsAmount--;\n if (unsubscribe && subscriptionsAmount === 0) {\n unsubscribe();\n unsubscribe = void 0;\n listeners.clear();\n listeners = nullListeners;\n }\n }\n function trySubscribeSelf() {\n if (!selfSubscribed) {\n selfSubscribed = true;\n trySubscribe();\n }\n }\n function tryUnsubscribeSelf() {\n if (selfSubscribed) {\n selfSubscribed = false;\n tryUnsubscribe();\n }\n }\n const subscription = {\n addNestedSub,\n notifyNestedSubs,\n handleChangeWrapper,\n isSubscribed,\n trySubscribe: trySubscribeSelf,\n tryUnsubscribe: tryUnsubscribeSelf,\n getListeners: () => listeners\n };\n return subscription;\n}\n\n// src/utils/useIsomorphicLayoutEffect.ts\nvar canUseDOM = () => !!(typeof window !== \"undefined\" && typeof window.document !== \"undefined\" && typeof window.document.createElement !== \"undefined\");\nvar isDOM = /* @__PURE__ */ canUseDOM();\nvar isRunningInReactNative = () => typeof navigator !== \"undefined\" && navigator.product === \"ReactNative\";\nvar isReactNative = /* @__PURE__ */ isRunningInReactNative();\nvar getUseIsomorphicLayoutEffect = () => isDOM || isReactNative ? React.useLayoutEffect : React.useEffect;\nvar useIsomorphicLayoutEffect = /* @__PURE__ */ getUseIsomorphicLayoutEffect();\n\n// src/utils/shallowEqual.ts\nfunction is(x, y) {\n if (x === y) {\n return x !== 0 || y !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\nfunction shallowEqual(objA, objB) {\n if (is(objA, objB)) return true;\n if (typeof objA !== \"object\" || objA === null || typeof objB !== \"object\" || objB === null) {\n return false;\n }\n const keysA = Object.keys(objA);\n const keysB = Object.keys(objB);\n if (keysA.length !== keysB.length) return false;\n for (let i = 0; i < keysA.length; i++) {\n if (!Object.prototype.hasOwnProperty.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {\n return false;\n }\n }\n return true;\n}\n\n// src/utils/hoistStatics.ts\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n $$typeof: true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n $$typeof: true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {\n [ForwardRef]: FORWARD_REF_STATICS,\n [Memo]: MEMO_STATICS\n};\nfunction getStatics(component) {\n if (isMemo(component)) {\n return MEMO_STATICS;\n }\n return TYPE_STATICS[component[\"$$typeof\"]] || REACT_STATICS;\n}\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent) {\n if (typeof sourceComponent !== \"string\") {\n if (objectPrototype) {\n const inheritedComponent = getPrototypeOf(sourceComponent);\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent);\n }\n }\n let keys = getOwnPropertyNames(sourceComponent);\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n const targetStatics = getStatics(targetComponent);\n const sourceStatics = getStatics(sourceComponent);\n for (let i = 0; i < keys.length; ++i) {\n const key = keys[i];\n if (!KNOWN_STATICS[key] && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n const descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n try {\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {\n }\n }\n }\n }\n return targetComponent;\n}\n\n// src/components/Context.ts\nvar ContextKey = /* @__PURE__ */ Symbol.for(`react-redux-context`);\nvar gT = typeof globalThis !== \"undefined\" ? globalThis : (\n /* fall back to a per-module scope (pre-8.1 behaviour) if `globalThis` is not available */\n {}\n);\nfunction getContext() {\n if (!React.createContext) return {};\n const contextMap = gT[ContextKey] ??= /* @__PURE__ */ new Map();\n let realContext = contextMap.get(React.createContext);\n if (!realContext) {\n realContext = React.createContext(\n null\n );\n if (process.env.NODE_ENV !== \"production\") {\n realContext.displayName = \"ReactRedux\";\n }\n contextMap.set(React.createContext, realContext);\n }\n return realContext;\n}\nvar ReactReduxContext = /* @__PURE__ */ getContext();\n\n// src/components/connect.tsx\nvar NO_SUBSCRIPTION_ARRAY = [null, null];\nvar stringifyComponent = (Comp) => {\n try {\n return JSON.stringify(Comp);\n } catch (err) {\n return String(Comp);\n }\n};\nfunction useIsomorphicLayoutEffectWithArgs(effectFunc, effectArgs, dependencies) {\n useIsomorphicLayoutEffect(() => effectFunc(...effectArgs), dependencies);\n}\nfunction captureWrapperProps(lastWrapperProps, lastChildProps, renderIsScheduled, wrapperProps, childPropsFromStoreUpdate, notifyNestedSubs) {\n lastWrapperProps.current = wrapperProps;\n renderIsScheduled.current = false;\n if (childPropsFromStoreUpdate.current) {\n childPropsFromStoreUpdate.current = null;\n notifyNestedSubs();\n }\n}\nfunction subscribeUpdates(shouldHandleStateChanges, store, subscription, childPropsSelector, lastWrapperProps, lastChildProps, renderIsScheduled, isMounted, childPropsFromStoreUpdate, notifyNestedSubs, additionalSubscribeListener) {\n if (!shouldHandleStateChanges) return () => {\n };\n let didUnsubscribe = false;\n let lastThrownError = null;\n const checkForUpdates = () => {\n if (didUnsubscribe || !isMounted.current) {\n return;\n }\n const latestStoreState = store.getState();\n let newChildProps, error;\n try {\n newChildProps = childPropsSelector(\n latestStoreState,\n lastWrapperProps.current\n );\n } catch (e) {\n error = e;\n lastThrownError = e;\n }\n if (!error) {\n lastThrownError = null;\n }\n if (newChildProps === lastChildProps.current) {\n if (!renderIsScheduled.current) {\n notifyNestedSubs();\n }\n } else {\n lastChildProps.current = newChildProps;\n childPropsFromStoreUpdate.current = newChildProps;\n renderIsScheduled.current = true;\n additionalSubscribeListener();\n }\n };\n subscription.onStateChange = checkForUpdates;\n subscription.trySubscribe();\n checkForUpdates();\n const unsubscribeWrapper = () => {\n didUnsubscribe = true;\n subscription.tryUnsubscribe();\n subscription.onStateChange = null;\n if (lastThrownError) {\n throw lastThrownError;\n }\n };\n return unsubscribeWrapper;\n}\nfunction strictEqual(a, b) {\n return a === b;\n}\nvar hasWarnedAboutDeprecatedPureOption = false;\nfunction connect(mapStateToProps, mapDispatchToProps, mergeProps, {\n // The `pure` option has been removed, so TS doesn't like us destructuring this to check its existence.\n // @ts-ignore\n pure,\n areStatesEqual = strictEqual,\n areOwnPropsEqual = shallowEqual,\n areStatePropsEqual = shallowEqual,\n areMergedPropsEqual = shallowEqual,\n // use React's forwardRef to expose a ref of the wrapped component\n forwardRef = false,\n // the context consumer to use\n context = ReactReduxContext\n} = {}) {\n if (process.env.NODE_ENV !== \"production\") {\n if (pure !== void 0 && !hasWarnedAboutDeprecatedPureOption) {\n hasWarnedAboutDeprecatedPureOption = true;\n warning(\n 'The `pure` option has been removed. `connect` is now always a \"pure/memoized\" component'\n );\n }\n }\n const Context = context;\n const initMapStateToProps = mapStateToPropsFactory(mapStateToProps);\n const initMapDispatchToProps = mapDispatchToPropsFactory(mapDispatchToProps);\n const initMergeProps = mergePropsFactory(mergeProps);\n const shouldHandleStateChanges = Boolean(mapStateToProps);\n const wrapWithConnect = (WrappedComponent) => {\n if (process.env.NODE_ENV !== \"production\") {\n const isValid = /* @__PURE__ */ isValidElementType(WrappedComponent);\n if (!isValid)\n throw new Error(\n `You must pass a component to the function returned by connect. Instead received ${stringifyComponent(\n WrappedComponent\n )}`\n );\n }\n const wrappedComponentName = WrappedComponent.displayName || WrappedComponent.name || \"Component\";\n const displayName = `Connect(${wrappedComponentName})`;\n const selectorFactoryOptions = {\n shouldHandleStateChanges,\n displayName,\n wrappedComponentName,\n WrappedComponent,\n // @ts-ignore\n initMapStateToProps,\n initMapDispatchToProps,\n initMergeProps,\n areStatesEqual,\n areStatePropsEqual,\n areOwnPropsEqual,\n areMergedPropsEqual\n };\n function ConnectFunction(props) {\n const [propsContext, reactReduxForwardedRef, wrapperProps] = React.useMemo(() => {\n const { reactReduxForwardedRef: reactReduxForwardedRef2, ...wrapperProps2 } = props;\n return [props.context, reactReduxForwardedRef2, wrapperProps2];\n }, [props]);\n const ContextToUse = React.useMemo(() => {\n let ResultContext = Context;\n if (propsContext?.Consumer) {\n if (process.env.NODE_ENV !== \"production\") {\n const isValid = /* @__PURE__ */ isContextConsumer(\n // @ts-ignore\n /* @__PURE__ */ React.createElement(propsContext.Consumer, null)\n );\n if (!isValid) {\n throw new Error(\n \"You must pass a valid React context consumer as `props.context`\"\n );\n }\n ResultContext = propsContext;\n }\n }\n return ResultContext;\n }, [propsContext, Context]);\n const contextValue = React.useContext(ContextToUse);\n const didStoreComeFromProps = Boolean(props.store) && Boolean(props.store.getState) && Boolean(props.store.dispatch);\n const didStoreComeFromContext = Boolean(contextValue) && Boolean(contextValue.store);\n if (process.env.NODE_ENV !== \"production\" && !didStoreComeFromProps && !didStoreComeFromContext) {\n throw new Error(\n `Could not find \"store\" in the context of \"${displayName}\". Either wrap the root component in a <Provider>, or pass a custom React context provider to <Provider> and the corresponding React context consumer to ${displayName} in connect options.`\n );\n }\n const store = didStoreComeFromProps ? props.store : contextValue.store;\n const getServerState = didStoreComeFromContext ? contextValue.getServerState : store.getState;\n const childPropsSelector = React.useMemo(() => {\n return finalPropsSelectorFactory(store.dispatch, selectorFactoryOptions);\n }, [store]);\n const [subscription, notifyNestedSubs] = React.useMemo(() => {\n if (!shouldHandleStateChanges) return NO_SUBSCRIPTION_ARRAY;\n const subscription2 = createSubscription(\n store,\n didStoreComeFromProps ? void 0 : contextValue.subscription\n );\n const notifyNestedSubs2 = subscription2.notifyNestedSubs.bind(subscription2);\n return [subscription2, notifyNestedSubs2];\n }, [store, didStoreComeFromProps, contextValue]);\n const overriddenContextValue = React.useMemo(() => {\n if (didStoreComeFromProps) {\n return contextValue;\n }\n return {\n ...contextValue,\n subscription\n };\n }, [didStoreComeFromProps, contextValue, subscription]);\n const lastChildProps = React.useRef(void 0);\n const lastWrapperProps = React.useRef(wrapperProps);\n const childPropsFromStoreUpdate = React.useRef(void 0);\n const renderIsScheduled = React.useRef(false);\n const isMounted = React.useRef(false);\n const latestSubscriptionCallbackError = React.useRef(\n void 0\n );\n useIsomorphicLayoutEffect(() => {\n isMounted.current = true;\n return () => {\n isMounted.current = false;\n };\n }, []);\n const actualChildPropsSelector = React.useMemo(() => {\n const selector = () => {\n if (childPropsFromStoreUpdate.current && wrapperProps === lastWrapperProps.current) {\n return childPropsFromStoreUpdate.current;\n }\n return childPropsSelector(store.getState(), wrapperProps);\n };\n return selector;\n }, [store, wrapperProps]);\n const subscribeForReact = React.useMemo(() => {\n const subscribe = (reactListener) => {\n if (!subscription) {\n return () => {\n };\n }\n return subscribeUpdates(\n shouldHandleStateChanges,\n store,\n subscription,\n // @ts-ignore\n childPropsSelector,\n lastWrapperProps,\n lastChildProps,\n renderIsScheduled,\n isMounted,\n childPropsFromStoreUpdate,\n notifyNestedSubs,\n reactListener\n );\n };\n return subscribe;\n }, [subscription]);\n useIsomorphicLayoutEffectWithArgs(captureWrapperProps, [\n lastWrapperProps,\n lastChildProps,\n renderIsScheduled,\n wrapperProps,\n childPropsFromStoreUpdate,\n notifyNestedSubs\n ]);\n let actualChildProps;\n try {\n actualChildProps = React.useSyncExternalStore(\n // TODO We're passing through a big wrapper that does a bunch of extra side effects besides subscribing\n subscribeForReact,\n // TODO This is incredibly hacky. We've already processed the store update and calculated new child props,\n // TODO and we're just passing that through so it triggers a re-render for us rather than relying on `uSES`.\n actualChildPropsSelector,\n getServerState ? () => childPropsSelector(getServerState(), wrapperProps) : actualChildPropsSelector\n );\n } catch (err) {\n if (latestSubscriptionCallbackError.current) {\n ;\n err.message += `\nThe error may be correlated with this previous error:\n${latestSubscriptionCallbackError.current.stack}\n\n`;\n }\n throw err;\n }\n useIsomorphicLayoutEffect(() => {\n latestSubscriptionCallbackError.current = void 0;\n childPropsFromStoreUpdate.current = void 0;\n lastChildProps.current = actualChildProps;\n });\n const renderedWrappedComponent = React.useMemo(() => {\n return (\n // @ts-ignore\n /* @__PURE__ */ React.createElement(\n WrappedComponent,\n {\n ...actualChildProps,\n ref: reactReduxForwardedRef\n }\n )\n );\n }, [reactReduxForwardedRef, WrappedComponent, actualChildProps]);\n const renderedChild = React.useMemo(() => {\n if (shouldHandleStateChanges) {\n return /* @__PURE__ */ React.createElement(ContextToUse.Provider, { value: overriddenContextValue }, renderedWrappedComponent);\n }\n return renderedWrappedComponent;\n }, [ContextToUse, renderedWrappedComponent, overriddenContextValue]);\n return renderedChild;\n }\n const _Connect = React.memo(ConnectFunction);\n const Connect = _Connect;\n Connect.WrappedComponent = WrappedComponent;\n Connect.displayName = ConnectFunction.displayName = displayName;\n if (forwardRef) {\n const _forwarded = React.forwardRef(\n function forwardConnectRef(props, ref) {\n return /* @__PURE__ */ React.createElement(Connect, { ...props, reactReduxForwardedRef: ref });\n }\n );\n const forwarded = _forwarded;\n forwarded.displayName = displayName;\n forwarded.WrappedComponent = WrappedComponent;\n return /* @__PURE__ */ hoistNonReactStatics(forwarded, WrappedComponent);\n }\n return /* @__PURE__ */ hoistNonReactStatics(Connect, WrappedComponent);\n };\n return wrapWithConnect;\n}\nvar connect_default = connect;\n\n// src/components/Provider.tsx\nfunction Provider(providerProps) {\n const { children, context, serverState, store } = providerProps;\n const contextValue = React.useMemo(() => {\n const subscription = createSubscription(store);\n const baseContextValue = {\n store,\n subscription,\n getServerState: serverState ? () => serverState : void 0\n };\n if (process.env.NODE_ENV === \"production\") {\n return baseContextValue;\n } else {\n const { identityFunctionCheck = \"once\", stabilityCheck = \"once\" } = providerProps;\n return /* @__PURE__ */ Object.assign(baseContextValue, {\n stabilityCheck,\n identityFunctionCheck\n });\n }\n }, [store, serverState]);\n const previousState = React.useMemo(() => store.getState(), [store]);\n useIsomorphicLayoutEffect(() => {\n const { subscription } = contextValue;\n subscription.onStateChange = subscription.notifyNestedSubs;\n subscription.trySubscribe();\n if (previousState !== store.getState()) {\n subscription.notifyNestedSubs();\n }\n return () => {\n subscription.tryUnsubscribe();\n subscription.onStateChange = void 0;\n };\n }, [contextValue, previousState]);\n const Context = context || ReactReduxContext;\n return /* @__PURE__ */ React.createElement(Context.Provider, { value: contextValue }, children);\n}\nvar Provider_default = Provider;\n\n// src/hooks/useReduxContext.ts\nfunction createReduxContextHook(context = ReactReduxContext) {\n return function useReduxContext2() {\n const contextValue = React.useContext(context);\n if (process.env.NODE_ENV !== \"production\" && !contextValue) {\n throw new Error(\n \"could not find react-redux context value; please ensure the component is wrapped in a <Provider>\"\n );\n }\n return contextValue;\n };\n}\nvar useReduxContext = /* @__PURE__ */ createReduxContextHook();\n\n// src/hooks/useStore.ts\nfunction createStoreHook(context = ReactReduxContext) {\n const useReduxContext2 = context === ReactReduxContext ? useReduxContext : (\n // @ts-ignore\n createReduxContextHook(context)\n );\n const useStore2 = () => {\n const { store } = useReduxContext2();\n return store;\n };\n Object.assign(useStore2, {\n withTypes: () => useStore2\n });\n return useStore2;\n}\nvar useStore = /* @__PURE__ */ createStoreHook();\n\n// src/hooks/useDispatch.ts\nfunction createDispatchHook(context = ReactReduxContext) {\n const useStore2 = context === ReactReduxContext ? useStore : createStoreHook(context);\n const useDispatch2 = () => {\n const store = useStore2();\n return store.dispatch;\n };\n Object.assign(useDispatch2, {\n withTypes: () => useDispatch2\n });\n return useDispatch2;\n}\nvar useDispatch = /* @__PURE__ */ createDispatchHook();\n\n// src/hooks/useSelector.ts\nimport { useSyncExternalStoreWithSelector } from \"use-sync-external-store/with-selector.js\";\nvar refEquality = (a, b) => a === b;\nfunction createSelectorHook(context = ReactReduxContext) {\n const useReduxContext2 = context === ReactReduxContext ? useReduxContext : createReduxContextHook(context);\n const useSelector2 = (selector, equalityFnOrOptions = {}) => {\n const { equalityFn = refEquality } = typeof equalityFnOrOptions === \"function\" ? { equalityFn: equalityFnOrOptions } : equalityFnOrOptions;\n if (process.env.NODE_ENV !== \"production\") {\n if (!selector) {\n throw new Error(`You must pass a selector to useSelector`);\n }\n if (typeof selector !== \"function\") {\n throw new Error(`You must pass a function as a selector to useSelector`);\n }\n if (typeof equalityFn !== \"function\") {\n throw new Error(\n `You must pass a function as an equality function to useSelector`\n );\n }\n }\n const reduxContext = useReduxContext2();\n const { store, subscription, getServerState } = reduxContext;\n const firstRun = React.useRef(true);\n const wrappedSelector = React.useCallback(\n {\n [selector.name](state) {\n const selected = selector(state);\n if (process.env.NODE_ENV !== \"production\") {\n const { devModeChecks = {} } = typeof equalityFnOrOptions === \"function\" ? {} : equalityFnOrOptions;\n const { identityFunctionCheck, stabilityCheck } = reduxContext;\n const {\n identityFunctionCheck: finalIdentityFunctionCheck,\n stabilityCheck: finalStabilityCheck\n } = {\n stabilityCheck,\n identityFunctionCheck,\n ...devModeChecks\n };\n if (finalStabilityCheck === \"always\" || finalStabilityCheck === \"once\" && firstRun.current) {\n const toCompare = selector(state);\n if (!equalityFn(selected, toCompare)) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"Selector \" + (selector.name || \"unknown\") + \" returned a different result when called with the same parameters. This can lead to unnecessary rerenders.\\nSelectors that return a new reference (such as an object or an array) should be memoized: https://redux.js.org/usage/deriving-data-selectors#optimizing-selectors-with-memoization\",\n {\n state,\n selected,\n selected2: toCompare,\n stack\n }\n );\n }\n }\n if (finalIdentityFunctionCheck === \"always\" || finalIdentityFunctionCheck === \"once\" && firstRun.current) {\n if (selected === state) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"Selector \" + (selector.name || \"unknown\") + \" returned the root state when called. This can lead to unnecessary rerenders.\\nSelectors that return the entire state are almost certainly a mistake, as they will cause a rerender whenever *anything* in state changes.\",\n { stack }\n );\n }\n }\n if (firstRun.current) firstRun.current = false;\n }\n return selected;\n }\n }[selector.name],\n [selector]\n );\n const selectedState = useSyncExternalStoreWithSelector(\n subscription.addNestedSub,\n store.getState,\n getServerState || store.getState,\n wrappedSelector,\n equalityFn\n );\n React.useDebugValue(selectedState);\n return selectedState;\n };\n Object.assign(useSelector2, {\n withTypes: () => useSelector2\n });\n return useSelector2;\n}\nvar useSelector = /* @__PURE__ */ createSelectorHook();\n\n// src/exports.ts\nvar batch = defaultNoopBatch;\nexport {\n Provider_default as Provider,\n ReactReduxContext,\n batch,\n connect_default as connect,\n createDispatchHook,\n createSelectorHook,\n createStoreHook,\n shallowEqual,\n useDispatch,\n useSelector,\n useStore\n};\n//# sourceMappingURL=react-redux.mjs.map","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isSymbol = require('../predicate/isSymbol.js');\n\nfunction toNumber(value) {\n if (isSymbol.isSymbol(value)) {\n return NaN;\n }\n return Number(value);\n}\n\nexports.toNumber = toNumber;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst toNumber = require('./toNumber.js');\n\nfunction toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber.toNumber(value);\n if (value === Infinity || value === -Infinity) {\n const sign = value < 0 ? -1 : 1;\n return sign * Number.MAX_VALUE;\n }\n return value === value ? value : 0;\n}\n\nexports.toFinite = toFinite;\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst isIterateeCall = require('../_internal/isIterateeCall.js');\nconst toFinite = require('../util/toFinite.js');\n\nfunction range(start, end, step) {\n if (step && typeof step !== 'number' && isIterateeCall.isIterateeCall(start, end, step)) {\n end = step = undefined;\n }\n start = toFinite.toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n }\n else {\n end = toFinite.toFinite(end);\n }\n step = step === undefined ? (start < end ? 1 : -1) : toFinite.toFinite(step);\n const length = Math.max(Math.ceil((end - start) / (step || 1)), 0);\n const result = new Array(length);\n for (let index = 0; index < length; index++) {\n result[index] = start;\n start += step;\n }\n return result;\n}\n\nexports.range = range;\n","module.exports = require('../dist/compat/math/range.js').range;\n","/*\r\n * decimal.js-light v2.5.1\r\n * An arbitrary-precision Decimal type for JavaScript.\r\n * https://github.com/MikeMcl/decimal.js-light\r\n * Copyright (c) 2020 Michael Mclaughlin <M8ch88l@gmail.com>\r\n * MIT Expat Licence\r\n */\r\n\r\n\r\n// ------------------------------------ EDITABLE DEFAULTS ------------------------------------- //\r\n\r\n\r\n// The limit on the value of `precision`, and on the value of the first argument to\r\n// `toDecimalPlaces`, `toExponential`, `toFixed`, `toPrecision` and `toSignificantDigits`.\r\nvar MAX_DIGITS = 1e9, // 0 to 1e9\r\n\r\n\r\n // The initial configuration properties of the Decimal constructor.\r\n defaults = {\r\n\r\n // These values must be integers within the stated ranges (inclusive).\r\n // Most of these values can be changed during run-time using `Decimal.config`.\r\n\r\n // The maximum number of significant digits of the result of a calculation or base conversion.\r\n // E.g. `Decimal.config({ precision: 20 });`\r\n precision: 20, // 1 to MAX_DIGITS\r\n\r\n // The rounding mode used by default by `toInteger`, `toDecimalPlaces`, `toExponential`,\r\n // `toFixed`, `toPrecision` and `toSignificantDigits`.\r\n //\r\n // ROUND_UP 0 Away from zero.\r\n // ROUND_DOWN 1 Towards zero.\r\n // ROUND_CEIL 2 Towards +Infinity.\r\n // ROUND_FLOOR 3 Towards -Infinity.\r\n // ROUND_HALF_UP 4 Towards nearest neighbour. If equidistant, up.\r\n // ROUND_HALF_DOWN 5 Towards nearest neighbour. If equidistant, down.\r\n // ROUND_HALF_EVEN 6 Towards nearest neighbour. If equidistant, towards even neighbour.\r\n // ROUND_HALF_CEIL 7 Towards nearest neighbour. If equidistant, towards +Infinity.\r\n // ROUND_HALF_FLOOR 8 Towards nearest neighbour. If equidistant, towards -Infinity.\r\n //\r\n // E.g.\r\n // `Decimal.rounding = 4;`\r\n // `Decimal.rounding = Decimal.ROUND_HALF_UP;`\r\n rounding: 4, // 0 to 8\r\n\r\n // The exponent value at and beneath which `toString` returns exponential notation.\r\n // JavaScript numbers: -7\r\n toExpNeg: -7, // 0 to -MAX_E\r\n\r\n // The exponent value at and above which `toString` returns exponential notation.\r\n // JavaScript numbers: 21\r\n toExpPos: 21, // 0 to MAX_E\r\n\r\n // The natural logarithm of 10.\r\n // 115 digits\r\n LN10: '2.302585092994045684017991454684364207601101488628772976033327900967572609677352480235997205089598298341967784042286'\r\n },\r\n\r\n\r\n// ------------------------------------ END OF EDITABLE DEFAULTS -------------------------------- //\r\n\r\n\r\n Decimal,\r\n external = true,\r\n\r\n decimalError = '[DecimalError] ',\r\n invalidArgument = decimalError + 'Invalid argument: ',\r\n exponentOutOfRange = decimalError + 'Exponent out of range: ',\r\n\r\n mathfloor = Math.floor,\r\n mathpow = Math.pow,\r\n\r\n isDecimal = /^(\\d+(\\.\\d*)?|\\.\\d+)(e[+-]?\\d+)?$/i,\r\n\r\n ONE,\r\n BASE = 1e7,\r\n LOG_BASE = 7,\r\n MAX_SAFE_INTEGER = 9007199254740991,\r\n MAX_E = mathfloor(MAX_SAFE_INTEGER / LOG_BASE), // 1286742750677284\r\n\r\n // Decimal.prototype object\r\n P = {};\r\n\r\n\r\n// Decimal prototype methods\r\n\r\n\r\n/*\r\n * absoluteValue abs\r\n * comparedTo cmp\r\n * decimalPlaces dp\r\n * dividedBy div\r\n * dividedToIntegerBy idiv\r\n * equals eq\r\n * exponent\r\n * greaterThan gt\r\n * greaterThanOrEqualTo gte\r\n * isInteger isint\r\n * isNegative isneg\r\n * isPositive ispos\r\n * isZero\r\n * lessThan lt\r\n * lessThanOrEqualTo lte\r\n * logarithm log\r\n * minus sub\r\n * modulo mod\r\n * naturalExponential exp\r\n * naturalLogarithm ln\r\n * negated neg\r\n * plus add\r\n * precision sd\r\n * squareRoot sqrt\r\n * times mul\r\n * toDecimalPlaces todp\r\n * toExponential\r\n * toFixed\r\n * toInteger toint\r\n * toNumber\r\n * toPower pow\r\n * toPrecision\r\n * toSignificantDigits tosd\r\n * toString\r\n * valueOf val\r\n */\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the absolute value of this Decimal.\r\n *\r\n */\r\nP.absoluteValue = P.abs = function () {\r\n var x = new this.constructor(this);\r\n if (x.s) x.s = 1;\r\n return x;\r\n};\r\n\r\n\r\n/*\r\n * Return\r\n * 1 if the value of this Decimal is greater than the value of `y`,\r\n * -1 if the value of this Decimal is less than the value of `y`,\r\n * 0 if they have the same value\r\n *\r\n */\r\nP.comparedTo = P.cmp = function (y) {\r\n var i, j, xdL, ydL,\r\n x = this;\r\n\r\n y = new x.constructor(y);\r\n\r\n // Signs differ?\r\n if (x.s !== y.s) return x.s || -y.s;\r\n\r\n // Compare exponents.\r\n if (x.e !== y.e) return x.e > y.e ^ x.s < 0 ? 1 : -1;\r\n\r\n xdL = x.d.length;\r\n ydL = y.d.length;\r\n\r\n // Compare digit by digit.\r\n for (i = 0, j = xdL < ydL ? xdL : ydL; i < j; ++i) {\r\n if (x.d[i] !== y.d[i]) return x.d[i] > y.d[i] ^ x.s < 0 ? 1 : -1;\r\n }\r\n\r\n // Compare lengths.\r\n return xdL === ydL ? 0 : xdL > ydL ^ x.s < 0 ? 1 : -1;\r\n};\r\n\r\n\r\n/*\r\n * Return the number of decimal places of the value of this Decimal.\r\n *\r\n */\r\nP.decimalPlaces = P.dp = function () {\r\n var x = this,\r\n w = x.d.length - 1,\r\n dp = (w - x.e) * LOG_BASE;\r\n\r\n // Subtract the number of trailing zeros of the last word.\r\n w = x.d[w];\r\n if (w) for (; w % 10 == 0; w /= 10) dp--;\r\n\r\n return dp < 0 ? 0 : dp;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal divided by `y`, truncated to\r\n * `precision` significant digits.\r\n *\r\n */\r\nP.dividedBy = P.div = function (y) {\r\n return divide(this, new this.constructor(y));\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the integer part of dividing the value of this Decimal\r\n * by the value of `y`, truncated to `precision` significant digits.\r\n *\r\n */\r\nP.dividedToIntegerBy = P.idiv = function (y) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n return round(divide(x, new Ctor(y), 0, 1), Ctor.precision);\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is equal to the value of `y`, otherwise return false.\r\n *\r\n */\r\nP.equals = P.eq = function (y) {\r\n return !this.cmp(y);\r\n};\r\n\r\n\r\n/*\r\n * Return the (base 10) exponent value of this Decimal (this.e is the base 10000000 exponent).\r\n *\r\n */\r\nP.exponent = function () {\r\n return getBase10Exponent(this);\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is greater than the value of `y`, otherwise return\r\n * false.\r\n *\r\n */\r\nP.greaterThan = P.gt = function (y) {\r\n return this.cmp(y) > 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is greater than or equal to the value of `y`,\r\n * otherwise return false.\r\n *\r\n */\r\nP.greaterThanOrEqualTo = P.gte = function (y) {\r\n return this.cmp(y) >= 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is an integer, otherwise return false.\r\n *\r\n */\r\nP.isInteger = P.isint = function () {\r\n return this.e > this.d.length - 2;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is negative, otherwise return false.\r\n *\r\n */\r\nP.isNegative = P.isneg = function () {\r\n return this.s < 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is positive, otherwise return false.\r\n *\r\n */\r\nP.isPositive = P.ispos = function () {\r\n return this.s > 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is 0, otherwise return false.\r\n *\r\n */\r\nP.isZero = function () {\r\n return this.s === 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is less than `y`, otherwise return false.\r\n *\r\n */\r\nP.lessThan = P.lt = function (y) {\r\n return this.cmp(y) < 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is less than or equal to `y`, otherwise return false.\r\n *\r\n */\r\nP.lessThanOrEqualTo = P.lte = function (y) {\r\n return this.cmp(y) < 1;\r\n};\r\n\r\n\r\n/*\r\n * Return the logarithm of the value of this Decimal to the specified base, truncated to\r\n * `precision` significant digits.\r\n *\r\n * If no base is specified, return log[10](x).\r\n *\r\n * log[base](x) = ln(x) / ln(base)\r\n *\r\n * The maximum error of the result is 1 ulp (unit in the last place).\r\n *\r\n * [base] {number|string|Decimal} The base of the logarithm.\r\n *\r\n */\r\nP.logarithm = P.log = function (base) {\r\n var r,\r\n x = this,\r\n Ctor = x.constructor,\r\n pr = Ctor.precision,\r\n wpr = pr + 5;\r\n\r\n // Default base is 10.\r\n if (base === void 0) {\r\n base = new Ctor(10);\r\n } else {\r\n base = new Ctor(base);\r\n\r\n // log[-b](x) = NaN\r\n // log[0](x) = NaN\r\n // log[1](x) = NaN\r\n if (base.s < 1 || base.eq(ONE)) throw Error(decimalError + 'NaN');\r\n }\r\n\r\n // log[b](-x) = NaN\r\n // log[b](0) = -Infinity\r\n if (x.s < 1) throw Error(decimalError + (x.s ? 'NaN' : '-Infinity'));\r\n\r\n // log[b](1) = 0\r\n if (x.eq(ONE)) return new Ctor(0);\r\n\r\n external = false;\r\n r = divide(ln(x, wpr), ln(base, wpr), wpr);\r\n external = true;\r\n\r\n return round(r, pr);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal minus `y`, truncated to\r\n * `precision` significant digits.\r\n *\r\n */\r\nP.minus = P.sub = function (y) {\r\n var x = this;\r\n y = new x.constructor(y);\r\n return x.s == y.s ? subtract(x, y) : add(x, (y.s = -y.s, y));\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal modulo `y`, truncated to\r\n * `precision` significant digits.\r\n *\r\n */\r\nP.modulo = P.mod = function (y) {\r\n var q,\r\n x = this,\r\n Ctor = x.constructor,\r\n pr = Ctor.precision;\r\n\r\n y = new Ctor(y);\r\n\r\n // x % 0 = NaN\r\n if (!y.s) throw Error(decimalError + 'NaN');\r\n\r\n // Return x if x is 0.\r\n if (!x.s) return round(new Ctor(x), pr);\r\n\r\n // Prevent rounding of intermediate calculations.\r\n external = false;\r\n q = divide(x, y, 0, 1).times(y);\r\n external = true;\r\n\r\n return x.minus(q);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural exponential of the value of this Decimal,\r\n * i.e. the base e raised to the power the value of this Decimal, truncated to `precision`\r\n * significant digits.\r\n *\r\n */\r\nP.naturalExponential = P.exp = function () {\r\n return exp(this);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural logarithm of the value of this Decimal,\r\n * truncated to `precision` significant digits.\r\n *\r\n */\r\nP.naturalLogarithm = P.ln = function () {\r\n return ln(this);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal negated, i.e. as if multiplied by\r\n * -1.\r\n *\r\n */\r\nP.negated = P.neg = function () {\r\n var x = new this.constructor(this);\r\n x.s = -x.s || 0;\r\n return x;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal plus `y`, truncated to\r\n * `precision` significant digits.\r\n *\r\n */\r\nP.plus = P.add = function (y) {\r\n var x = this;\r\n y = new x.constructor(y);\r\n return x.s == y.s ? add(x, y) : subtract(x, (y.s = -y.s, y));\r\n};\r\n\r\n\r\n/*\r\n * Return the number of significant digits of the value of this Decimal.\r\n *\r\n * [z] {boolean|number} Whether to count integer-part trailing zeros: true, false, 1 or 0.\r\n *\r\n */\r\nP.precision = P.sd = function (z) {\r\n var e, sd, w,\r\n x = this;\r\n\r\n if (z !== void 0 && z !== !!z && z !== 1 && z !== 0) throw Error(invalidArgument + z);\r\n\r\n e = getBase10Exponent(x) + 1;\r\n w = x.d.length - 1;\r\n sd = w * LOG_BASE + 1;\r\n w = x.d[w];\r\n\r\n // If non-zero...\r\n if (w) {\r\n\r\n // Subtract the number of trailing zeros of the last word.\r\n for (; w % 10 == 0; w /= 10) sd--;\r\n\r\n // Add the number of digits of the first word.\r\n for (w = x.d[0]; w >= 10; w /= 10) sd++;\r\n }\r\n\r\n return z && e > sd ? e : sd;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the square root of this Decimal, truncated to `precision`\r\n * significant digits.\r\n *\r\n */\r\nP.squareRoot = P.sqrt = function () {\r\n var e, n, pr, r, s, t, wpr,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n // Negative or zero?\r\n if (x.s < 1) {\r\n if (!x.s) return new Ctor(0);\r\n\r\n // sqrt(-x) = NaN\r\n throw Error(decimalError + 'NaN');\r\n }\r\n\r\n e = getBase10Exponent(x);\r\n external = false;\r\n\r\n // Initial estimate.\r\n s = Math.sqrt(+x);\r\n\r\n // Math.sqrt underflow/overflow?\r\n // Pass x to Math.sqrt as integer, then adjust the exponent of the result.\r\n if (s == 0 || s == 1 / 0) {\r\n n = digitsToString(x.d);\r\n if ((n.length + e) % 2 == 0) n += '0';\r\n s = Math.sqrt(n);\r\n e = mathfloor((e + 1) / 2) - (e < 0 || e % 2);\r\n\r\n if (s == 1 / 0) {\r\n n = '5e' + e;\r\n } else {\r\n n = s.toExponential();\r\n n = n.slice(0, n.indexOf('e') + 1) + e;\r\n }\r\n\r\n r = new Ctor(n);\r\n } else {\r\n r = new Ctor(s.toString());\r\n }\r\n\r\n pr = Ctor.precision;\r\n s = wpr = pr + 3;\r\n\r\n // Newton-Raphson iteration.\r\n for (;;) {\r\n t = r;\r\n r = t.plus(divide(x, t, wpr + 2)).times(0.5);\r\n\r\n if (digitsToString(t.d).slice(0, wpr) === (n = digitsToString(r.d)).slice(0, wpr)) {\r\n n = n.slice(wpr - 3, wpr + 1);\r\n\r\n // The 4th rounding digit may be in error by -1 so if the 4 rounding digits are 9999 or\r\n // 4999, i.e. approaching a rounding boundary, continue the iteration.\r\n if (s == wpr && n == '4999') {\r\n\r\n // On the first iteration only, check to see if rounding up gives the exact result as the\r\n // nines may infinitely repeat.\r\n round(t, pr + 1, 0);\r\n\r\n if (t.times(t).eq(x)) {\r\n r = t;\r\n break;\r\n }\r\n } else if (n != '9999') {\r\n break;\r\n }\r\n\r\n wpr += 4;\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return round(r, pr);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal times `y`, truncated to\r\n * `precision` significant digits.\r\n *\r\n */\r\nP.times = P.mul = function (y) {\r\n var carry, e, i, k, r, rL, t, xdL, ydL,\r\n x = this,\r\n Ctor = x.constructor,\r\n xd = x.d,\r\n yd = (y = new Ctor(y)).d;\r\n\r\n // Return 0 if either is 0.\r\n if (!x.s || !y.s) return new Ctor(0);\r\n\r\n y.s *= x.s;\r\n e = x.e + y.e;\r\n xdL = xd.length;\r\n ydL = yd.length;\r\n\r\n // Ensure xd points to the longer array.\r\n if (xdL < ydL) {\r\n r = xd;\r\n xd = yd;\r\n yd = r;\r\n rL = xdL;\r\n xdL = ydL;\r\n ydL = rL;\r\n }\r\n\r\n // Initialise the result array with zeros.\r\n r = [];\r\n rL = xdL + ydL;\r\n for (i = rL; i--;) r.push(0);\r\n\r\n // Multiply!\r\n for (i = ydL; --i >= 0;) {\r\n carry = 0;\r\n for (k = xdL + i; k > i;) {\r\n t = r[k] + yd[i] * xd[k - i - 1] + carry;\r\n r[k--] = t % BASE | 0;\r\n carry = t / BASE | 0;\r\n }\r\n\r\n r[k] = (r[k] + carry) % BASE | 0;\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (; !r[--rL];) r.pop();\r\n\r\n if (carry) ++e;\r\n else r.shift();\r\n\r\n y.d = r;\r\n y.e = e;\r\n\r\n return external ? round(y, Ctor.precision) : y;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a maximum of `dp`\r\n * decimal places using rounding mode `rm` or `rounding` if `rm` is omitted.\r\n *\r\n * If `dp` is omitted, return a new Decimal whose value is the value of this Decimal.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toDecimalPlaces = P.todp = function (dp, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n x = new Ctor(x);\r\n if (dp === void 0) return x;\r\n\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n return round(x, dp + getBase10Exponent(x) + 1, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in exponential notation rounded to\r\n * `dp` fixed decimal places using rounding mode `rounding`.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toExponential = function (dp, rm) {\r\n var str,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (dp === void 0) {\r\n str = toString(x, true);\r\n } else {\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n x = round(new Ctor(x), dp + 1, rm);\r\n str = toString(x, true, dp + 1);\r\n }\r\n\r\n return str;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in normal (fixed-point) notation to\r\n * `dp` fixed decimal places and rounded using rounding mode `rm` or `rounding` if `rm` is\r\n * omitted.\r\n *\r\n * As with JavaScript numbers, (-0).toFixed(0) is '0', but e.g. (-0.00001).toFixed(0) is '-0'.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * (-0).toFixed(0) is '0', but (-0.1).toFixed(0) is '-0'.\r\n * (-0).toFixed(1) is '0.0', but (-0.01).toFixed(1) is '-0.0'.\r\n * (-0).toFixed(3) is '0.000'.\r\n * (-0.5).toFixed(0) is '-0'.\r\n *\r\n */\r\nP.toFixed = function (dp, rm) {\r\n var str, y,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (dp === void 0) return toString(x);\r\n\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n y = round(new Ctor(x), dp + getBase10Exponent(x) + 1, rm);\r\n str = toString(y.abs(), false, dp + getBase10Exponent(y) + 1);\r\n\r\n // To determine whether to add the minus sign look at the value before it was rounded,\r\n // i.e. look at `x` rather than `y`.\r\n return x.isneg() && !x.isZero() ? '-' + str : str;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number using\r\n * rounding mode `rounding`.\r\n *\r\n */\r\nP.toInteger = P.toint = function () {\r\n var x = this,\r\n Ctor = x.constructor;\r\n return round(new Ctor(x), getBase10Exponent(x) + 1, Ctor.rounding);\r\n};\r\n\r\n\r\n/*\r\n * Return the value of this Decimal converted to a number primitive.\r\n *\r\n */\r\nP.toNumber = function () {\r\n return +this;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal raised to the power `y`,\r\n * truncated to `precision` significant digits.\r\n *\r\n * For non-integer or very large exponents pow(x, y) is calculated using\r\n *\r\n * x^y = exp(y*ln(x))\r\n *\r\n * The maximum error is 1 ulp (unit in last place).\r\n *\r\n * y {number|string|Decimal} The power to which to raise this Decimal.\r\n *\r\n */\r\nP.toPower = P.pow = function (y) {\r\n var e, k, pr, r, sign, yIsInt,\r\n x = this,\r\n Ctor = x.constructor,\r\n guard = 12,\r\n yn = +(y = new Ctor(y));\r\n\r\n // pow(x, 0) = 1\r\n if (!y.s) return new Ctor(ONE);\r\n\r\n x = new Ctor(x);\r\n\r\n // pow(0, y > 0) = 0\r\n // pow(0, y < 0) = Infinity\r\n if (!x.s) {\r\n if (y.s < 1) throw Error(decimalError + 'Infinity');\r\n return x;\r\n }\r\n\r\n // pow(1, y) = 1\r\n if (x.eq(ONE)) return x;\r\n\r\n pr = Ctor.precision;\r\n\r\n // pow(x, 1) = x\r\n if (y.eq(ONE)) return round(x, pr);\r\n\r\n e = y.e;\r\n k = y.d.length - 1;\r\n yIsInt = e >= k;\r\n sign = x.s;\r\n\r\n if (!yIsInt) {\r\n\r\n // pow(x < 0, y non-integer) = NaN\r\n if (sign < 0) throw Error(decimalError + 'NaN');\r\n\r\n // If y is a small integer use the 'exponentiation by squaring' algorithm.\r\n } else if ((k = yn < 0 ? -yn : yn) <= MAX_SAFE_INTEGER) {\r\n r = new Ctor(ONE);\r\n\r\n // Max k of 9007199254740991 takes 53 loop iterations.\r\n // Maximum digits array length; leaves [28, 34] guard digits.\r\n e = Math.ceil(pr / LOG_BASE + 4);\r\n\r\n external = false;\r\n\r\n for (;;) {\r\n if (k % 2) {\r\n r = r.times(x);\r\n truncate(r.d, e);\r\n }\r\n\r\n k = mathfloor(k / 2);\r\n if (k === 0) break;\r\n\r\n x = x.times(x);\r\n truncate(x.d, e);\r\n }\r\n\r\n external = true;\r\n\r\n return y.s < 0 ? new Ctor(ONE).div(r) : round(r, pr);\r\n }\r\n\r\n // Result is negative if x is negative and the last digit of integer y is odd.\r\n sign = sign < 0 && y.d[Math.max(e, k)] & 1 ? -1 : 1;\r\n\r\n x.s = 1;\r\n external = false;\r\n r = y.times(ln(x, pr + guard));\r\n external = true;\r\n r = exp(r);\r\n r.s = sign;\r\n\r\n return r;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal rounded to `sd` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * Return exponential notation if `sd` is less than the number of digits necessary to represent\r\n * the integer part of the value in normal notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toPrecision = function (sd, rm) {\r\n var e, str,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (sd === void 0) {\r\n e = getBase10Exponent(x);\r\n str = toString(x, e <= Ctor.toExpNeg || e >= Ctor.toExpPos);\r\n } else {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n x = round(new Ctor(x), sd, rm);\r\n e = getBase10Exponent(x);\r\n str = toString(x, sd <= e || e <= Ctor.toExpNeg, sd);\r\n }\r\n\r\n return str;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a maximum of `sd`\r\n * significant digits using rounding mode `rm`, or to `precision` and `rounding` respectively if\r\n * omitted.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toSignificantDigits = P.tosd = function (sd, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n if (sd === void 0) {\r\n sd = Ctor.precision;\r\n rm = Ctor.rounding;\r\n } else {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n }\r\n\r\n return round(new Ctor(x), sd, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal.\r\n *\r\n * Return exponential notation if this Decimal has a positive exponent equal to or greater than\r\n * `toExpPos`, or a negative exponent equal to or less than `toExpNeg`.\r\n *\r\n */\r\nP.toString = P.valueOf = P.val = P.toJSON = P[Symbol.for('nodejs.util.inspect.custom')] = function () {\r\n var x = this,\r\n e = getBase10Exponent(x),\r\n Ctor = x.constructor;\r\n\r\n return toString(x, e <= Ctor.toExpNeg || e >= Ctor.toExpPos);\r\n};\r\n\r\n\r\n// Helper functions for Decimal.prototype (P) and/or Decimal methods, and their callers.\r\n\r\n\r\n/*\r\n * add P.minus, P.plus\r\n * checkInt32 P.todp, P.toExponential, P.toFixed, P.toPrecision, P.tosd\r\n * digitsToString P.log, P.sqrt, P.pow, toString, exp, ln\r\n * divide P.div, P.idiv, P.log, P.mod, P.sqrt, exp, ln\r\n * exp P.exp, P.pow\r\n * getBase10Exponent P.exponent, P.sd, P.toint, P.sqrt, P.todp, P.toFixed, P.toPrecision,\r\n * P.toString, divide, round, toString, exp, ln\r\n * getLn10 P.log, ln\r\n * getZeroString digitsToString, toString\r\n * ln P.log, P.ln, P.pow, exp\r\n * parseDecimal Decimal\r\n * round P.abs, P.idiv, P.log, P.minus, P.mod, P.neg, P.plus, P.toint, P.sqrt,\r\n * P.times, P.todp, P.toExponential, P.toFixed, P.pow, P.toPrecision, P.tosd,\r\n * divide, getLn10, exp, ln\r\n * subtract P.minus, P.plus\r\n * toString P.toExponential, P.toFixed, P.toPrecision, P.toString, P.valueOf\r\n * truncate P.pow\r\n *\r\n * Throws: P.log, P.mod, P.sd, P.sqrt, P.pow, checkInt32, divide, round,\r\n * getLn10, exp, ln, parseDecimal, Decimal, config\r\n */\r\n\r\n\r\nfunction add(x, y) {\r\n var carry, d, e, i, k, len, xd, yd,\r\n Ctor = x.constructor,\r\n pr = Ctor.precision;\r\n\r\n // If either is zero...\r\n if (!x.s || !y.s) {\r\n\r\n // Return x if y is zero.\r\n // Return y if y is non-zero.\r\n if (!y.s) y = new Ctor(x);\r\n return external ? round(y, pr) : y;\r\n }\r\n\r\n xd = x.d;\r\n yd = y.d;\r\n\r\n // x and y are finite, non-zero numbers with the same sign.\r\n\r\n k = x.e;\r\n e = y.e;\r\n xd = xd.slice();\r\n i = k - e;\r\n\r\n // If base 1e7 exponents differ...\r\n if (i) {\r\n if (i < 0) {\r\n d = xd;\r\n i = -i;\r\n len = yd.length;\r\n } else {\r\n d = yd;\r\n e = k;\r\n len = xd.length;\r\n }\r\n\r\n // Limit number of zeros prepended to max(ceil(pr / LOG_BASE), len) + 1.\r\n k = Math.ceil(pr / LOG_BASE);\r\n len = k > len ? k + 1 : len + 1;\r\n\r\n if (i > len) {\r\n i = len;\r\n d.length = 1;\r\n }\r\n\r\n // Prepend zeros to equalise exponents. Note: Faster to use reverse then do unshifts.\r\n d.reverse();\r\n for (; i--;) d.push(0);\r\n d.reverse();\r\n }\r\n\r\n len = xd.length;\r\n i = yd.length;\r\n\r\n // If yd is longer than xd, swap xd and yd so xd points to the longer array.\r\n if (len - i < 0) {\r\n i = len;\r\n d = yd;\r\n yd = xd;\r\n xd = d;\r\n }\r\n\r\n // Only start adding at yd.length - 1 as the further digits of xd can be left as they are.\r\n for (carry = 0; i;) {\r\n carry = (xd[--i] = xd[i] + yd[i] + carry) / BASE | 0;\r\n xd[i] %= BASE;\r\n }\r\n\r\n if (carry) {\r\n xd.unshift(carry);\r\n ++e;\r\n }\r\n\r\n // Remove trailing zeros.\r\n // No need to check for zero, as +x + +y != 0 && -x + -y != 0\r\n for (len = xd.length; xd[--len] == 0;) xd.pop();\r\n\r\n y.d = xd;\r\n y.e = e;\r\n\r\n return external ? round(y, pr) : y;\r\n}\r\n\r\n\r\nfunction checkInt32(i, min, max) {\r\n if (i !== ~~i || i < min || i > max) {\r\n throw Error(invalidArgument + i);\r\n }\r\n}\r\n\r\n\r\nfunction digitsToString(d) {\r\n var i, k, ws,\r\n indexOfLastWord = d.length - 1,\r\n str = '',\r\n w = d[0];\r\n\r\n if (indexOfLastWord > 0) {\r\n str += w;\r\n for (i = 1; i < indexOfLastWord; i++) {\r\n ws = d[i] + '';\r\n k = LOG_BASE - ws.length;\r\n if (k) str += getZeroString(k);\r\n str += ws;\r\n }\r\n\r\n w = d[i];\r\n ws = w + '';\r\n k = LOG_BASE - ws.length;\r\n if (k) str += getZeroString(k);\r\n } else if (w === 0) {\r\n return '0';\r\n }\r\n\r\n // Remove trailing zeros of last w.\r\n for (; w % 10 === 0;) w /= 10;\r\n\r\n return str + w;\r\n}\r\n\r\n\r\nvar divide = (function () {\r\n\r\n // Assumes non-zero x and k, and hence non-zero result.\r\n function multiplyInteger(x, k) {\r\n var temp,\r\n carry = 0,\r\n i = x.length;\r\n\r\n for (x = x.slice(); i--;) {\r\n temp = x[i] * k + carry;\r\n x[i] = temp % BASE | 0;\r\n carry = temp / BASE | 0;\r\n }\r\n\r\n if (carry) x.unshift(carry);\r\n\r\n return x;\r\n }\r\n\r\n function compare(a, b, aL, bL) {\r\n var i, r;\r\n\r\n if (aL != bL) {\r\n r = aL > bL ? 1 : -1;\r\n } else {\r\n for (i = r = 0; i < aL; i++) {\r\n if (a[i] != b[i]) {\r\n r = a[i] > b[i] ? 1 : -1;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return r;\r\n }\r\n\r\n function subtract(a, b, aL) {\r\n var i = 0;\r\n\r\n // Subtract b from a.\r\n for (; aL--;) {\r\n a[aL] -= i;\r\n i = a[aL] < b[aL] ? 1 : 0;\r\n a[aL] = i * BASE + a[aL] - b[aL];\r\n }\r\n\r\n // Remove leading zeros.\r\n for (; !a[0] && a.length > 1;) a.shift();\r\n }\r\n\r\n return function (x, y, pr, dp) {\r\n var cmp, e, i, k, prod, prodL, q, qd, rem, remL, rem0, sd, t, xi, xL, yd0, yL, yz,\r\n Ctor = x.constructor,\r\n sign = x.s == y.s ? 1 : -1,\r\n xd = x.d,\r\n yd = y.d;\r\n\r\n // Either 0?\r\n if (!x.s) return new Ctor(x);\r\n if (!y.s) throw Error(decimalError + 'Division by zero');\r\n\r\n e = x.e - y.e;\r\n yL = yd.length;\r\n xL = xd.length;\r\n q = new Ctor(sign);\r\n qd = q.d = [];\r\n\r\n // Result exponent may be one less than e.\r\n for (i = 0; yd[i] == (xd[i] || 0); ) ++i;\r\n if (yd[i] > (xd[i] || 0)) --e;\r\n\r\n if (pr == null) {\r\n sd = pr = Ctor.precision;\r\n } else if (dp) {\r\n sd = pr + (getBase10Exponent(x) - getBase10Exponent(y)) + 1;\r\n } else {\r\n sd = pr;\r\n }\r\n\r\n if (sd < 0) return new Ctor(0);\r\n\r\n // Convert precision in number of base 10 digits to base 1e7 digits.\r\n sd = sd / LOG_BASE + 2 | 0;\r\n i = 0;\r\n\r\n // divisor < 1e7\r\n if (yL == 1) {\r\n k = 0;\r\n yd = yd[0];\r\n sd++;\r\n\r\n // k is the carry.\r\n for (; (i < xL || k) && sd--; i++) {\r\n t = k * BASE + (xd[i] || 0);\r\n qd[i] = t / yd | 0;\r\n k = t % yd | 0;\r\n }\r\n\r\n // divisor >= 1e7\r\n } else {\r\n\r\n // Normalise xd and yd so highest order digit of yd is >= BASE/2\r\n k = BASE / (yd[0] + 1) | 0;\r\n\r\n if (k > 1) {\r\n yd = multiplyInteger(yd, k);\r\n xd = multiplyInteger(xd, k);\r\n yL = yd.length;\r\n xL = xd.length;\r\n }\r\n\r\n xi = yL;\r\n rem = xd.slice(0, yL);\r\n remL = rem.length;\r\n\r\n // Add zeros to make remainder as long as divisor.\r\n for (; remL < yL;) rem[remL++] = 0;\r\n\r\n yz = yd.slice();\r\n yz.unshift(0);\r\n yd0 = yd[0];\r\n\r\n if (yd[1] >= BASE / 2) ++yd0;\r\n\r\n do {\r\n k = 0;\r\n\r\n // Compare divisor and remainder.\r\n cmp = compare(yd, rem, yL, remL);\r\n\r\n // If divisor < remainder.\r\n if (cmp < 0) {\r\n\r\n // Calculate trial digit, k.\r\n rem0 = rem[0];\r\n if (yL != remL) rem0 = rem0 * BASE + (rem[1] || 0);\r\n\r\n // k will be how many times the divisor goes into the current remainder.\r\n k = rem0 / yd0 | 0;\r\n\r\n // Algorithm:\r\n // 1. product = divisor * trial digit (k)\r\n // 2. if product > remainder: product -= divisor, k--\r\n // 3. remainder -= product\r\n // 4. if product was < remainder at 2:\r\n // 5. compare new remainder and divisor\r\n // 6. If remainder > divisor: remainder -= divisor, k++\r\n\r\n if (k > 1) {\r\n if (k >= BASE) k = BASE - 1;\r\n\r\n // product = divisor * trial digit.\r\n prod = multiplyInteger(yd, k);\r\n prodL = prod.length;\r\n remL = rem.length;\r\n\r\n // Compare product and remainder.\r\n cmp = compare(prod, rem, prodL, remL);\r\n\r\n // product > remainder.\r\n if (cmp == 1) {\r\n k--;\r\n\r\n // Subtract divisor from product.\r\n subtract(prod, yL < prodL ? yz : yd, prodL);\r\n }\r\n } else {\r\n\r\n // cmp is -1.\r\n // If k is 0, there is no need to compare yd and rem again below, so change cmp to 1\r\n // to avoid it. If k is 1 there is a need to compare yd and rem again below.\r\n if (k == 0) cmp = k = 1;\r\n prod = yd.slice();\r\n }\r\n\r\n prodL = prod.length;\r\n if (prodL < remL) prod.unshift(0);\r\n\r\n // Subtract product from remainder.\r\n subtract(rem, prod, remL);\r\n\r\n // If product was < previous remainder.\r\n if (cmp == -1) {\r\n remL = rem.length;\r\n\r\n // Compare divisor and new remainder.\r\n cmp = compare(yd, rem, yL, remL);\r\n\r\n // If divisor < new remainder, subtract divisor from remainder.\r\n if (cmp < 1) {\r\n k++;\r\n\r\n // Subtract divisor from remainder.\r\n subtract(rem, yL < remL ? yz : yd, remL);\r\n }\r\n }\r\n\r\n remL = rem.length;\r\n } else if (cmp === 0) {\r\n k++;\r\n rem = [0];\r\n } // if cmp === 1, k will be 0\r\n\r\n // Add the next digit, k, to the result array.\r\n qd[i++] = k;\r\n\r\n // Update the remainder.\r\n if (cmp && rem[0]) {\r\n rem[remL++] = xd[xi] || 0;\r\n } else {\r\n rem = [xd[xi]];\r\n remL = 1;\r\n }\r\n\r\n } while ((xi++ < xL || rem[0] !== void 0) && sd--);\r\n }\r\n\r\n // Leading zero?\r\n if (!qd[0]) qd.shift();\r\n\r\n q.e = e;\r\n\r\n return round(q, dp ? pr + getBase10Exponent(q) + 1 : pr);\r\n };\r\n})();\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural exponential of `x` truncated to `sd`\r\n * significant digits.\r\n *\r\n * Taylor/Maclaurin series.\r\n *\r\n * exp(x) = x^0/0! + x^1/1! + x^2/2! + x^3/3! + ...\r\n *\r\n * Argument reduction:\r\n * Repeat x = x / 32, k += 5, until |x| < 0.1\r\n * exp(x) = exp(x / 2^k)^(2^k)\r\n *\r\n * Previously, the argument was initially reduced by\r\n * exp(x) = exp(r) * 10^k where r = x - k * ln10, k = floor(x / ln10)\r\n * to first put r in the range [0, ln10], before dividing by 32 until |x| < 0.1, but this was\r\n * found to be slower than just dividing repeatedly by 32 as above.\r\n *\r\n * (Math object integer min/max: Math.exp(709) = 8.2e+307, Math.exp(-745) = 5e-324)\r\n *\r\n * exp(x) is non-terminating for any finite, non-zero x.\r\n *\r\n */\r\nfunction exp(x, sd) {\r\n var denominator, guard, pow, sum, t, wpr,\r\n i = 0,\r\n k = 0,\r\n Ctor = x.constructor,\r\n pr = Ctor.precision;\r\n\r\n if (getBase10Exponent(x) > 16) throw Error(exponentOutOfRange + getBase10Exponent(x));\r\n\r\n // exp(0) = 1\r\n if (!x.s) return new Ctor(ONE);\r\n\r\n if (sd == null) {\r\n external = false;\r\n wpr = pr;\r\n } else {\r\n wpr = sd;\r\n }\r\n\r\n t = new Ctor(0.03125);\r\n\r\n while (x.abs().gte(0.1)) {\r\n x = x.times(t); // x = x / 2^5\r\n k += 5;\r\n }\r\n\r\n // Estimate the precision increase necessary to ensure the first 4 rounding digits are correct.\r\n guard = Math.log(mathpow(2, k)) / Math.LN10 * 2 + 5 | 0;\r\n wpr += guard;\r\n denominator = pow = sum = new Ctor(ONE);\r\n Ctor.precision = wpr;\r\n\r\n for (;;) {\r\n pow = round(pow.times(x), wpr);\r\n denominator = denominator.times(++i);\r\n t = sum.plus(divide(pow, denominator, wpr));\r\n\r\n if (digitsToString(t.d).slice(0, wpr) === digitsToString(sum.d).slice(0, wpr)) {\r\n while (k--) sum = round(sum.times(sum), wpr);\r\n Ctor.precision = pr;\r\n return sd == null ? (external = true, round(sum, pr)) : sum;\r\n }\r\n\r\n sum = t;\r\n }\r\n}\r\n\r\n\r\n// Calculate the base 10 exponent from the base 1e7 exponent.\r\nfunction getBase10Exponent(x) {\r\n var e = x.e * LOG_BASE,\r\n w = x.d[0];\r\n\r\n // Add the number of digits of the first word of the digits array.\r\n for (; w >= 10; w /= 10) e++;\r\n return e;\r\n}\r\n\r\n\r\nfunction getLn10(Ctor, sd, pr) {\r\n\r\n if (sd > Ctor.LN10.sd()) {\r\n\r\n\r\n // Reset global state in case the exception is caught.\r\n external = true;\r\n if (pr) Ctor.precision = pr;\r\n throw Error(decimalError + 'LN10 precision limit exceeded');\r\n }\r\n\r\n return round(new Ctor(Ctor.LN10), sd);\r\n}\r\n\r\n\r\nfunction getZeroString(k) {\r\n var zs = '';\r\n for (; k--;) zs += '0';\r\n return zs;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural logarithm of `x` truncated to `sd` significant\r\n * digits.\r\n *\r\n * ln(n) is non-terminating (n != 1)\r\n *\r\n */\r\nfunction ln(y, sd) {\r\n var c, c0, denominator, e, numerator, sum, t, wpr, x2,\r\n n = 1,\r\n guard = 10,\r\n x = y,\r\n xd = x.d,\r\n Ctor = x.constructor,\r\n pr = Ctor.precision;\r\n\r\n // ln(-x) = NaN\r\n // ln(0) = -Infinity\r\n if (x.s < 1) throw Error(decimalError + (x.s ? 'NaN' : '-Infinity'));\r\n\r\n // ln(1) = 0\r\n if (x.eq(ONE)) return new Ctor(0);\r\n\r\n if (sd == null) {\r\n external = false;\r\n wpr = pr;\r\n } else {\r\n wpr = sd;\r\n }\r\n\r\n if (x.eq(10)) {\r\n if (sd == null) external = true;\r\n return getLn10(Ctor, wpr);\r\n }\r\n\r\n wpr += guard;\r\n Ctor.precision = wpr;\r\n c = digitsToString(xd);\r\n c0 = c.charAt(0);\r\n e = getBase10Exponent(x);\r\n\r\n if (Math.abs(e) < 1.5e15) {\r\n\r\n // Argument reduction.\r\n // The series converges faster the closer the argument is to 1, so using\r\n // ln(a^b) = b * ln(a), ln(a) = ln(a^b) / b\r\n // multiply the argument by itself until the leading digits of the significand are 7, 8, 9,\r\n // 10, 11, 12 or 13, recording the number of multiplications so the sum of the series can\r\n // later be divided by this number, then separate out the power of 10 using\r\n // ln(a*10^b) = ln(a) + b*ln(10).\r\n\r\n // max n is 21 (gives 0.9, 1.0 or 1.1) (9e15 / 21 = 4.2e14).\r\n //while (c0 < 9 && c0 != 1 || c0 == 1 && c.charAt(1) > 1) {\r\n // max n is 6 (gives 0.7 - 1.3)\r\n while (c0 < 7 && c0 != 1 || c0 == 1 && c.charAt(1) > 3) {\r\n x = x.times(y);\r\n c = digitsToString(x.d);\r\n c0 = c.charAt(0);\r\n n++;\r\n }\r\n\r\n e = getBase10Exponent(x);\r\n\r\n if (c0 > 1) {\r\n x = new Ctor('0.' + c);\r\n e++;\r\n } else {\r\n x = new Ctor(c0 + '.' + c.slice(1));\r\n }\r\n } else {\r\n\r\n // The argument reduction method above may result in overflow if the argument y is a massive\r\n // number with exponent >= 1500000000000000 (9e15 / 6 = 1.5e15), so instead recall this\r\n // function using ln(x*10^e) = ln(x) + e*ln(10).\r\n t = getLn10(Ctor, wpr + 2, pr).times(e + '');\r\n x = ln(new Ctor(c0 + '.' + c.slice(1)), wpr - guard).plus(t);\r\n\r\n Ctor.precision = pr;\r\n return sd == null ? (external = true, round(x, pr)) : x;\r\n }\r\n\r\n // x is reduced to a value near 1.\r\n\r\n // Taylor series.\r\n // ln(y) = ln((1 + x)/(1 - x)) = 2(x + x^3/3 + x^5/5 + x^7/7 + ...)\r\n // where x = (y - 1)/(y + 1) (|x| < 1)\r\n sum = numerator = x = divide(x.minus(ONE), x.plus(ONE), wpr);\r\n x2 = round(x.times(x), wpr);\r\n denominator = 3;\r\n\r\n for (;;) {\r\n numerator = round(numerator.times(x2), wpr);\r\n t = sum.plus(divide(numerator, new Ctor(denominator), wpr));\r\n\r\n if (digitsToString(t.d).slice(0, wpr) === digitsToString(sum.d).slice(0, wpr)) {\r\n sum = sum.times(2);\r\n\r\n // Reverse the argument reduction.\r\n if (e !== 0) sum = sum.plus(getLn10(Ctor, wpr + 2, pr).times(e + ''));\r\n sum = divide(sum, new Ctor(n), wpr);\r\n\r\n Ctor.precision = pr;\r\n return sd == null ? (external = true, round(sum, pr)) : sum;\r\n }\r\n\r\n sum = t;\r\n denominator += 2;\r\n }\r\n}\r\n\r\n\r\n/*\r\n * Parse the value of a new Decimal `x` from string `str`.\r\n */\r\nfunction parseDecimal(x, str) {\r\n var e, i, len;\r\n\r\n // Decimal point?\r\n if ((e = str.indexOf('.')) > -1) str = str.replace('.', '');\r\n\r\n // Exponential form?\r\n if ((i = str.search(/e/i)) > 0) {\r\n\r\n // Determine exponent.\r\n if (e < 0) e = i;\r\n e += +str.slice(i + 1);\r\n str = str.substring(0, i);\r\n } else if (e < 0) {\r\n\r\n // Integer.\r\n e = str.length;\r\n }\r\n\r\n // Determine leading zeros.\r\n for (i = 0; str.charCodeAt(i) === 48;) ++i;\r\n\r\n // Determine trailing zeros.\r\n for (len = str.length; str.charCodeAt(len - 1) === 48;) --len;\r\n str = str.slice(i, len);\r\n\r\n if (str) {\r\n len -= i;\r\n e = e - i - 1;\r\n x.e = mathfloor(e / LOG_BASE);\r\n x.d = [];\r\n\r\n // Transform base\r\n\r\n // e is the base 10 exponent.\r\n // i is where to slice str to get the first word of the digits array.\r\n i = (e + 1) % LOG_BASE;\r\n if (e < 0) i += LOG_BASE;\r\n\r\n if (i < len) {\r\n if (i) x.d.push(+str.slice(0, i));\r\n for (len -= LOG_BASE; i < len;) x.d.push(+str.slice(i, i += LOG_BASE));\r\n str = str.slice(i);\r\n i = LOG_BASE - str.length;\r\n } else {\r\n i -= len;\r\n }\r\n\r\n for (; i--;) str += '0';\r\n x.d.push(+str);\r\n\r\n if (external && (x.e > MAX_E || x.e < -MAX_E)) throw Error(exponentOutOfRange + e);\r\n } else {\r\n\r\n // Zero.\r\n x.s = 0;\r\n x.e = 0;\r\n x.d = [0];\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\n/*\r\n * Round `x` to `sd` significant digits, using rounding mode `rm` if present (truncate otherwise).\r\n */\r\n function round(x, sd, rm) {\r\n var i, j, k, n, rd, doRound, w, xdi,\r\n xd = x.d;\r\n\r\n // rd: the rounding digit, i.e. the digit after the digit that may be rounded up.\r\n // w: the word of xd which contains the rounding digit, a base 1e7 number.\r\n // xdi: the index of w within xd.\r\n // n: the number of digits of w.\r\n // i: what would be the index of rd within w if all the numbers were 7 digits long (i.e. if\r\n // they had leading zeros)\r\n // j: if > 0, the actual index of rd within w (if < 0, rd is a leading zero).\r\n\r\n // Get the length of the first word of the digits array xd.\r\n for (n = 1, k = xd[0]; k >= 10; k /= 10) n++;\r\n i = sd - n;\r\n\r\n // Is the rounding digit in the first word of xd?\r\n if (i < 0) {\r\n i += LOG_BASE;\r\n j = sd;\r\n w = xd[xdi = 0];\r\n } else {\r\n xdi = Math.ceil((i + 1) / LOG_BASE);\r\n k = xd.length;\r\n if (xdi >= k) return x;\r\n w = k = xd[xdi];\r\n\r\n // Get the number of digits of w.\r\n for (n = 1; k >= 10; k /= 10) n++;\r\n\r\n // Get the index of rd within w.\r\n i %= LOG_BASE;\r\n\r\n // Get the index of rd within w, adjusted for leading zeros.\r\n // The number of leading zeros of w is given by LOG_BASE - n.\r\n j = i - LOG_BASE + n;\r\n }\r\n\r\n if (rm !== void 0) {\r\n k = mathpow(10, n - j - 1);\r\n\r\n // Get the rounding digit at index j of w.\r\n rd = w / k % 10 | 0;\r\n\r\n // Are there any non-zero digits after the rounding digit?\r\n doRound = sd < 0 || xd[xdi + 1] !== void 0 || w % k;\r\n\r\n // The expression `w % mathpow(10, n - j - 1)` returns all the digits of w to the right of the\r\n // digit at (left-to-right) index j, e.g. if w is 908714 and j is 2, the expression will give\r\n // 714.\r\n\r\n doRound = rm < 4\r\n ? (rd || doRound) && (rm == 0 || rm == (x.s < 0 ? 3 : 2))\r\n : rd > 5 || rd == 5 && (rm == 4 || doRound || rm == 6 &&\r\n\r\n // Check whether the digit to the left of the rounding digit is odd.\r\n ((i > 0 ? j > 0 ? w / mathpow(10, n - j) : 0 : xd[xdi - 1]) % 10) & 1 ||\r\n rm == (x.s < 0 ? 8 : 7));\r\n }\r\n\r\n if (sd < 1 || !xd[0]) {\r\n if (doRound) {\r\n k = getBase10Exponent(x);\r\n xd.length = 1;\r\n\r\n // Convert sd to decimal places.\r\n sd = sd - k - 1;\r\n\r\n // 1, 0.1, 0.01, 0.001, 0.0001 etc.\r\n xd[0] = mathpow(10, (LOG_BASE - sd % LOG_BASE) % LOG_BASE);\r\n x.e = mathfloor(-sd / LOG_BASE) || 0;\r\n } else {\r\n xd.length = 1;\r\n\r\n // Zero.\r\n xd[0] = x.e = x.s = 0;\r\n }\r\n\r\n return x;\r\n }\r\n\r\n // Remove excess digits.\r\n if (i == 0) {\r\n xd.length = xdi;\r\n k = 1;\r\n xdi--;\r\n } else {\r\n xd.length = xdi + 1;\r\n k = mathpow(10, LOG_BASE - i);\r\n\r\n // E.g. 56700 becomes 56000 if 7 is the rounding digit.\r\n // j > 0 means i > number of leading zeros of w.\r\n xd[xdi] = j > 0 ? (w / mathpow(10, n - j) % mathpow(10, j) | 0) * k : 0;\r\n }\r\n\r\n if (doRound) {\r\n for (;;) {\r\n\r\n // Is the digit to be rounded up in the first word of xd?\r\n if (xdi == 0) {\r\n if ((xd[0] += k) == BASE) {\r\n xd[0] = 1;\r\n ++x.e;\r\n }\r\n\r\n break;\r\n } else {\r\n xd[xdi] += k;\r\n if (xd[xdi] != BASE) break;\r\n xd[xdi--] = 0;\r\n k = 1;\r\n }\r\n }\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (i = xd.length; xd[--i] === 0;) xd.pop();\r\n\r\n if (external && (x.e > MAX_E || x.e < -MAX_E)) {\r\n throw Error(exponentOutOfRange + getBase10Exponent(x));\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\nfunction subtract(x, y) {\r\n var d, e, i, j, k, len, xd, xe, xLTy, yd,\r\n Ctor = x.constructor,\r\n pr = Ctor.precision;\r\n\r\n // Return y negated if x is zero.\r\n // Return x if y is zero and x is non-zero.\r\n if (!x.s || !y.s) {\r\n if (y.s) y.s = -y.s;\r\n else y = new Ctor(x);\r\n return external ? round(y, pr) : y;\r\n }\r\n\r\n xd = x.d;\r\n yd = y.d;\r\n\r\n // x and y are non-zero numbers with the same sign.\r\n\r\n e = y.e;\r\n xe = x.e;\r\n xd = xd.slice();\r\n k = xe - e;\r\n\r\n // If exponents differ...\r\n if (k) {\r\n xLTy = k < 0;\r\n\r\n if (xLTy) {\r\n d = xd;\r\n k = -k;\r\n len = yd.length;\r\n } else {\r\n d = yd;\r\n e = xe;\r\n len = xd.length;\r\n }\r\n\r\n // Numbers with massively different exponents would result in a very high number of zeros\r\n // needing to be prepended, but this can be avoided while still ensuring correct rounding by\r\n // limiting the number of zeros to `Math.ceil(pr / LOG_BASE) + 2`.\r\n i = Math.max(Math.ceil(pr / LOG_BASE), len) + 2;\r\n\r\n if (k > i) {\r\n k = i;\r\n d.length = 1;\r\n }\r\n\r\n // Prepend zeros to equalise exponents.\r\n d.reverse();\r\n for (i = k; i--;) d.push(0);\r\n d.reverse();\r\n\r\n // Base 1e7 exponents equal.\r\n } else {\r\n\r\n // Check digits to determine which is the bigger number.\r\n\r\n i = xd.length;\r\n len = yd.length;\r\n xLTy = i < len;\r\n if (xLTy) len = i;\r\n\r\n for (i = 0; i < len; i++) {\r\n if (xd[i] != yd[i]) {\r\n xLTy = xd[i] < yd[i];\r\n break;\r\n }\r\n }\r\n\r\n k = 0;\r\n }\r\n\r\n if (xLTy) {\r\n d = xd;\r\n xd = yd;\r\n yd = d;\r\n y.s = -y.s;\r\n }\r\n\r\n len = xd.length;\r\n\r\n // Append zeros to xd if shorter.\r\n // Don't add zeros to yd if shorter as subtraction only needs to start at yd length.\r\n for (i = yd.length - len; i > 0; --i) xd[len++] = 0;\r\n\r\n // Subtract yd from xd.\r\n for (i = yd.length; i > k;) {\r\n if (xd[--i] < yd[i]) {\r\n for (j = i; j && xd[--j] === 0;) xd[j] = BASE - 1;\r\n --xd[j];\r\n xd[i] += BASE;\r\n }\r\n\r\n xd[i] -= yd[i];\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (; xd[--len] === 0;) xd.pop();\r\n\r\n // Remove leading zeros and adjust exponent accordingly.\r\n for (; xd[0] === 0; xd.shift()) --e;\r\n\r\n // Zero?\r\n if (!xd[0]) return new Ctor(0);\r\n\r\n y.d = xd;\r\n y.e = e;\r\n\r\n //return external && xd.length >= pr / LOG_BASE ? round(y, pr) : y;\r\n return external ? round(y, pr) : y;\r\n}\r\n\r\n\r\nfunction toString(x, isExp, sd) {\r\n var k,\r\n e = getBase10Exponent(x),\r\n str = digitsToString(x.d),\r\n len = str.length;\r\n\r\n if (isExp) {\r\n if (sd && (k = sd - len) > 0) {\r\n str = str.charAt(0) + '.' + str.slice(1) + getZeroString(k);\r\n } else if (len > 1) {\r\n str = str.charAt(0) + '.' + str.slice(1);\r\n }\r\n\r\n str = str + (e < 0 ? 'e' : 'e+') + e;\r\n } else if (e < 0) {\r\n str = '0.' + getZeroString(-e - 1) + str;\r\n if (sd && (k = sd - len) > 0) str += getZeroString(k);\r\n } else if (e >= len) {\r\n str += getZeroString(e + 1 - len);\r\n if (sd && (k = sd - e - 1) > 0) str = str + '.' + getZeroString(k);\r\n } else {\r\n if ((k = e + 1) < len) str = str.slice(0, k) + '.' + str.slice(k);\r\n if (sd && (k = sd - len) > 0) {\r\n if (e + 1 === len) str += '.';\r\n str += getZeroString(k);\r\n }\r\n }\r\n\r\n return x.s < 0 ? '-' + str : str;\r\n}\r\n\r\n\r\n// Does not strip trailing zeros.\r\nfunction truncate(arr, len) {\r\n if (arr.length > len) {\r\n arr.length = len;\r\n return true;\r\n }\r\n}\r\n\r\n\r\n// Decimal methods\r\n\r\n\r\n/*\r\n * clone\r\n * config/set\r\n */\r\n\r\n\r\n/*\r\n * Create and return a Decimal constructor with the same configuration properties as this Decimal\r\n * constructor.\r\n *\r\n */\r\nfunction clone(obj) {\r\n var i, p, ps;\r\n\r\n /*\r\n * The Decimal constructor and exported function.\r\n * Return a new Decimal instance.\r\n *\r\n * value {number|string|Decimal} A numeric value.\r\n *\r\n */\r\n function Decimal(value) {\r\n var x = this;\r\n\r\n // Decimal called without new.\r\n if (!(x instanceof Decimal)) return new Decimal(value);\r\n\r\n // Retain a reference to this Decimal constructor, and shadow Decimal.prototype.constructor\r\n // which points to Object.\r\n x.constructor = Decimal;\r\n\r\n // Duplicate.\r\n if (value instanceof Decimal) {\r\n x.s = value.s;\r\n x.e = value.e;\r\n x.d = (value = value.d) ? value.slice() : value;\r\n return;\r\n }\r\n\r\n if (typeof value === 'number') {\r\n\r\n // Reject Infinity/NaN.\r\n if (value * 0 !== 0) {\r\n throw Error(invalidArgument + value);\r\n }\r\n\r\n if (value > 0) {\r\n x.s = 1;\r\n } else if (value < 0) {\r\n value = -value;\r\n x.s = -1;\r\n } else {\r\n x.s = 0;\r\n x.e = 0;\r\n x.d = [0];\r\n return;\r\n }\r\n\r\n // Fast path for small integers.\r\n if (value === ~~value && value < 1e7) {\r\n x.e = 0;\r\n x.d = [value];\r\n return;\r\n }\r\n\r\n return parseDecimal(x, value.toString());\r\n } else if (typeof value !== 'string') {\r\n throw Error(invalidArgument + value);\r\n }\r\n\r\n // Minus sign?\r\n if (value.charCodeAt(0) === 45) {\r\n value = value.slice(1);\r\n x.s = -1;\r\n } else {\r\n x.s = 1;\r\n }\r\n\r\n if (isDecimal.test(value)) parseDecimal(x, value);\r\n else throw Error(invalidArgument + value);\r\n }\r\n\r\n Decimal.prototype = P;\r\n\r\n Decimal.ROUND_UP = 0;\r\n Decimal.ROUND_DOWN = 1;\r\n Decimal.ROUND_CEIL = 2;\r\n Decimal.ROUND_FLOOR = 3;\r\n Decimal.ROUND_HALF_UP = 4;\r\n Decimal.ROUND_HALF_DOWN = 5;\r\n Decimal.ROUND_HALF_EVEN = 6;\r\n Decimal.ROUND_HALF_CEIL = 7;\r\n Decimal.ROUND_HALF_FLOOR = 8;\r\n\r\n Decimal.clone = clone;\r\n Decimal.config = Decimal.set = config;\r\n\r\n if (obj === void 0) obj = {};\r\n if (obj) {\r\n ps = ['precision', 'rounding', 'toExpNeg', 'toExpPos', 'LN10'];\r\n for (i = 0; i < ps.length;) if (!obj.hasOwnProperty(p = ps[i++])) obj[p] = this[p];\r\n }\r\n\r\n Decimal.config(obj);\r\n\r\n return Decimal;\r\n}\r\n\r\n\r\n/*\r\n * Configure global settings for a Decimal constructor.\r\n *\r\n * `obj` is an object with one or more of the following properties,\r\n *\r\n * precision {number}\r\n * rounding {number}\r\n * toExpNeg {number}\r\n * toExpPos {number}\r\n *\r\n * E.g. Decimal.config({ precision: 20, rounding: 4 })\r\n *\r\n */\r\nfunction config(obj) {\r\n if (!obj || typeof obj !== 'object') {\r\n throw Error(decimalError + 'Object expected');\r\n }\r\n var i, p, v,\r\n ps = [\r\n 'precision', 1, MAX_DIGITS,\r\n 'rounding', 0, 8,\r\n 'toExpNeg', -1 / 0, 0,\r\n 'toExpPos', 0, 1 / 0\r\n ];\r\n\r\n for (i = 0; i < ps.length; i += 3) {\r\n if ((v = obj[p = ps[i]]) !== void 0) {\r\n if (mathfloor(v) === v && v >= ps[i + 1] && v <= ps[i + 2]) this[p] = v;\r\n else throw Error(invalidArgument + p + ': ' + v);\r\n }\r\n }\r\n\r\n if ((v = obj[p = 'LN10']) !== void 0) {\r\n if (v == Math.LN10) this[p] = new this(v);\r\n else throw Error(invalidArgument + p + ': ' + v);\r\n }\r\n\r\n return this;\r\n}\r\n\r\n\r\n// Create and configure initial Decimal constructor.\r\nexport var Decimal = clone(defaults);\r\n\r\n// Internal constant.\r\nONE = new Decimal(1);\r\n\r\nexport default Decimal;\r\n","export class InternMap extends Map {\n constructor(entries, key = keyof) {\n super();\n Object.defineProperties(this, {_intern: {value: new Map()}, _key: {value: key}});\n if (entries != null) for (const [key, value] of entries) this.set(key, value);\n }\n get(key) {\n return super.get(intern_get(this, key));\n }\n has(key) {\n return super.has(intern_get(this, key));\n }\n set(key, value) {\n return super.set(intern_set(this, key), value);\n }\n delete(key) {\n return super.delete(intern_delete(this, key));\n }\n}\n\nexport class InternSet extends Set {\n constructor(values, key = keyof) {\n super();\n Object.defineProperties(this, {_intern: {value: new Map()}, _key: {value: key}});\n if (values != null) for (const value of values) this.add(value);\n }\n has(value) {\n return super.has(intern_get(this, value));\n }\n add(value) {\n return super.add(intern_set(this, value));\n }\n delete(value) {\n return super.delete(intern_delete(this, value));\n }\n}\n\nfunction intern_get({_intern, _key}, value) {\n const key = _key(value);\n return _intern.has(key) ? _intern.get(key) : value;\n}\n\nfunction intern_set({_intern, _key}, value) {\n const key = _key(value);\n if (_intern.has(key)) return _intern.get(key);\n _intern.set(key, value);\n return value;\n}\n\nfunction intern_delete({_intern, _key}, value) {\n const key = _key(value);\n if (_intern.has(key)) {\n value = _intern.get(key);\n _intern.delete(key);\n }\n return value;\n}\n\nfunction keyof(value) {\n return value !== null && typeof value === \"object\" ? value.valueOf() : value;\n}\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","'use strict';\n\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nfunction isPlainObject(object) {\n if (typeof object !== 'object') {\n return false;\n }\n if (object == null) {\n return false;\n }\n if (Object.getPrototypeOf(object) === null) {\n return true;\n }\n if (Object.prototype.toString.call(object) !== '[object Object]') {\n const tag = object[Symbol.toStringTag];\n if (tag == null) {\n return false;\n }\n const isTagReadonly = !Object.getOwnPropertyDescriptor(object, Symbol.toStringTag)?.writable;\n if (isTagReadonly) {\n return false;\n }\n return object.toString() === `[object ${tag}]`;\n }\n let proto = object;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(object) === proto;\n}\n\nexports.isPlainObject = isPlainObject;\n","module.exports = require('../dist/compat/predicate/isPlainObject.js').isPlainObject;\n","var isProduction = process.env.NODE_ENV === 'production';\nvar prefix = 'Invariant failed';\nfunction invariant(condition, message) {\n if (condition) {\n return;\n }\n if (isProduction) {\n throw new Error(prefix);\n }\n var provided = typeof message === 'function' ? message() : message;\n var value = provided ? \"\".concat(prefix, \": \").concat(provided) : prefix;\n throw new Error(value);\n}\n\nexport { invariant as default };\n","function _objectWithoutPropertiesLoose(r, e) {\n if (null == r) return {};\n var t = {};\n for (var n in r) if ({}.hasOwnProperty.call(r, n)) {\n if (-1 !== e.indexOf(n)) continue;\n t[n] = r[n];\n }\n return t;\n}\nexport { _objectWithoutPropertiesLoose as default };","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose.js\";\nfunction _objectWithoutProperties(e, t) {\n if (null == e) return {};\n var o,\n r,\n i = objectWithoutPropertiesLoose(e, t);\n if (Object.getOwnPropertySymbols) {\n var n = Object.getOwnPropertySymbols(e);\n for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]);\n }\n return i;\n}\nexport { _objectWithoutProperties as default };","function _arrayLikeToArray(r, a) {\n (null == a || a > r.length) && (a = r.length);\n for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];\n return n;\n}\nexport { _arrayLikeToArray as default };","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nfunction _arrayWithoutHoles(r) {\n if (Array.isArray(r)) return arrayLikeToArray(r);\n}\nexport { _arrayWithoutHoles as default };","function _iterableToArray(r) {\n if (\"undefined\" != typeof Symbol && null != r[Symbol.iterator] || null != r[\"@@iterator\"]) return Array.from(r);\n}\nexport { _iterableToArray as default };","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nfunction _unsupportedIterableToArray(r, a) {\n if (r) {\n if (\"string\" == typeof r) return arrayLikeToArray(r, a);\n var t = {}.toString.call(r).slice(8, -1);\n return \"Object\" === t && r.constructor && (t = r.constructor.name), \"Map\" === t || \"Set\" === t ? Array.from(r) : \"Arguments\" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? arrayLikeToArray(r, a) : void 0;\n }\n}\nexport { _unsupportedIterableToArray as default };","function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nexport { _nonIterableSpread as default };","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nfunction _toConsumableArray(r) {\n return arrayWithoutHoles(r) || iterableToArray(r) || unsupportedIterableToArray(r) || nonIterableSpread();\n}\nexport { _toConsumableArray as default };","function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}\nexport { _typeof as default };","import _typeof from \"./typeof.js\";\nfunction toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}\nexport { toPrimitive as default };","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nfunction toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nexport { toPropertyKey as default };","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperty(e, r, t) {\n return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n value: t,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }) : e[r] = t, e;\n}\nexport { _defineProperty as default };","function _extends() {\n return _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, _extends.apply(null, arguments);\n}\nexport { _extends as default };","/**\n * @import {Schema as SchemaType, Space} from 'property-information'\n */\n\n/** @type {SchemaType} */\nexport class Schema {\n /**\n * @param {SchemaType['property']} property\n * Property.\n * @param {SchemaType['normal']} normal\n * Normal.\n * @param {Space | undefined} [space]\n * Space.\n * @returns\n * Schema.\n */\n constructor(property, normal, space) {\n this.normal = normal\n this.property = property\n\n if (space) {\n this.space = space\n }\n }\n}\n\nSchema.prototype.normal = {}\nSchema.prototype.property = {}\nSchema.prototype.space = undefined\n","/**\n * @import {Info, Space} from 'property-information'\n */\n\nimport {Schema} from './schema.js'\n\n/**\n * @param {ReadonlyArray<Schema>} definitions\n * Definitions.\n * @param {Space | undefined} [space]\n * Space.\n * @returns {Schema}\n * Schema.\n */\nexport function merge(definitions, space) {\n /** @type {Record<string, Info>} */\n const property = {}\n /** @type {Record<string, string>} */\n const normal = {}\n\n for (const definition of definitions) {\n Object.assign(property, definition.property)\n Object.assign(normal, definition.normal)\n }\n\n return new Schema(property, normal, space)\n}\n","/**\n * Get the cleaned case insensitive form of an attribute or property.\n *\n * @param {string} value\n * An attribute-like or property-like name.\n * @returns {string}\n * Value that can be used to look up the properly cased property on a\n * `Schema`.\n */\nexport function normalize(value) {\n return value.toLowerCase()\n}\n","/**\n * @import {Info as InfoType} from 'property-information'\n */\n\n/** @type {InfoType} */\nexport class Info {\n /**\n * @param {string} property\n * Property.\n * @param {string} attribute\n * Attribute.\n * @returns\n * Info.\n */\n constructor(property, attribute) {\n this.attribute = attribute\n this.property = property\n }\n}\n\nInfo.prototype.attribute = ''\nInfo.prototype.booleanish = false\nInfo.prototype.boolean = false\nInfo.prototype.commaOrSpaceSeparated = false\nInfo.prototype.commaSeparated = false\nInfo.prototype.defined = false\nInfo.prototype.mustUseProperty = false\nInfo.prototype.number = false\nInfo.prototype.overloadedBoolean = false\nInfo.prototype.property = ''\nInfo.prototype.spaceSeparated = false\nInfo.prototype.space = undefined\n","let powers = 0\n\nexport const boolean = increment()\nexport const booleanish = increment()\nexport const overloadedBoolean = increment()\nexport const number = increment()\nexport const spaceSeparated = increment()\nexport const commaSeparated = increment()\nexport const commaOrSpaceSeparated = increment()\n\nfunction increment() {\n return 2 ** ++powers\n}\n","/**\n * @import {Space} from 'property-information'\n */\n\nimport {Info} from './info.js'\nimport * as types from './types.js'\n\nconst checks = /** @type {ReadonlyArray<keyof typeof types>} */ (\n Object.keys(types)\n)\n\nexport class DefinedInfo extends Info {\n /**\n * @constructor\n * @param {string} property\n * Property.\n * @param {string} attribute\n * Attribute.\n * @param {number | null | undefined} [mask]\n * Mask.\n * @param {Space | undefined} [space]\n * Space.\n * @returns\n * Info.\n */\n constructor(property, attribute, mask, space) {\n let index = -1\n\n super(property, attribute)\n\n mark(this, 'space', space)\n\n if (typeof mask === 'number') {\n while (++index < checks.length) {\n const check = checks[index]\n mark(this, checks[index], (mask & types[check]) === types[check])\n }\n }\n }\n}\n\nDefinedInfo.prototype.defined = true\n\n/**\n * @template {keyof DefinedInfo} Key\n * Key type.\n * @param {DefinedInfo} values\n * Info.\n * @param {Key} key\n * Key.\n * @param {DefinedInfo[Key]} value\n * Value.\n * @returns {undefined}\n * Nothing.\n */\nfunction mark(values, key, value) {\n if (value) {\n values[key] = value\n }\n}\n","/**\n * @import {Info, Space} from 'property-information'\n */\n\n/**\n * @typedef Definition\n * Definition of a schema.\n * @property {Record<string, string> | undefined} [attributes]\n * Normalzed names to special attribute case.\n * @property {ReadonlyArray<string> | undefined} [mustUseProperty]\n * Normalized names that must be set as properties.\n * @property {Record<string, number | null>} properties\n * Property names to their types.\n * @property {Space | undefined} [space]\n * Space.\n * @property {Transform} transform\n * Transform a property name.\n */\n\n/**\n * @callback Transform\n * Transform.\n * @param {Record<string, string>} attributes\n * Attributes.\n * @param {string} property\n * Property.\n * @returns {string}\n * Attribute.\n */\n\nimport {normalize} from '../normalize.js'\nimport {DefinedInfo} from './defined-info.js'\nimport {Schema} from './schema.js'\n\n/**\n * @param {Definition} definition\n * Definition.\n * @returns {Schema}\n * Schema.\n */\nexport function create(definition) {\n /** @type {Record<string, Info>} */\n const properties = {}\n /** @type {Record<string, string>} */\n const normals = {}\n\n for (const [property, value] of Object.entries(definition.properties)) {\n const info = new DefinedInfo(\n property,\n definition.transform(definition.attributes || {}, property),\n value,\n definition.space\n )\n\n if (\n definition.mustUseProperty &&\n definition.mustUseProperty.includes(property)\n ) {\n info.mustUseProperty = true\n }\n\n properties[property] = info\n\n normals[normalize(property)] = property\n normals[normalize(info.attribute)] = property\n }\n\n return new Schema(properties, normals, definition.space)\n}\n","import {create} from './util/create.js'\nimport {booleanish, number, spaceSeparated} from './util/types.js'\n\nexport const aria = create({\n properties: {\n ariaActiveDescendant: null,\n ariaAtomic: booleanish,\n ariaAutoComplete: null,\n ariaBusy: booleanish,\n ariaChecked: booleanish,\n ariaColCount: number,\n ariaColIndex: number,\n ariaColSpan: number,\n ariaControls: spaceSeparated,\n ariaCurrent: null,\n ariaDescribedBy: spaceSeparated,\n ariaDetails: null,\n ariaDisabled: booleanish,\n ariaDropEffect: spaceSeparated,\n ariaErrorMessage: null,\n ariaExpanded: booleanish,\n ariaFlowTo: spaceSeparated,\n ariaGrabbed: booleanish,\n ariaHasPopup: null,\n ariaHidden: booleanish,\n ariaInvalid: null,\n ariaKeyShortcuts: null,\n ariaLabel: null,\n ariaLabelledBy: spaceSeparated,\n ariaLevel: number,\n ariaLive: null,\n ariaModal: booleanish,\n ariaMultiLine: booleanish,\n ariaMultiSelectable: booleanish,\n ariaOrientation: null,\n ariaOwns: spaceSeparated,\n ariaPlaceholder: null,\n ariaPosInSet: number,\n ariaPressed: booleanish,\n ariaReadOnly: booleanish,\n ariaRelevant: null,\n ariaRequired: booleanish,\n ariaRoleDescription: spaceSeparated,\n ariaRowCount: number,\n ariaRowIndex: number,\n ariaRowSpan: number,\n ariaSelected: booleanish,\n ariaSetSize: number,\n ariaSort: null,\n ariaValueMax: number,\n ariaValueMin: number,\n ariaValueNow: number,\n ariaValueText: null,\n role: null\n },\n transform(_, property) {\n return property === 'role'\n ? property\n : 'aria-' + property.slice(4).toLowerCase()\n }\n})\n","/**\n * @param {Record<string, string>} attributes\n * Attributes.\n * @param {string} attribute\n * Attribute.\n * @returns {string}\n * Transformed attribute.\n */\nexport function caseSensitiveTransform(attributes, attribute) {\n return attribute in attributes ? attributes[attribute] : attribute\n}\n","import {caseSensitiveTransform} from './case-sensitive-transform.js'\n\n/**\n * @param {Record<string, string>} attributes\n * Attributes.\n * @param {string} property\n * Property.\n * @returns {string}\n * Transformed property.\n */\nexport function caseInsensitiveTransform(attributes, property) {\n return caseSensitiveTransform(attributes, property.toLowerCase())\n}\n","import {caseInsensitiveTransform} from './util/case-insensitive-transform.js'\nimport {create} from './util/create.js'\nimport {\n booleanish,\n boolean,\n commaSeparated,\n number,\n overloadedBoolean,\n spaceSeparated\n} from './util/types.js'\n\nexport const html = create({\n attributes: {\n acceptcharset: 'accept-charset',\n classname: 'class',\n htmlfor: 'for',\n httpequiv: 'http-equiv'\n },\n mustUseProperty: ['checked', 'multiple', 'muted', 'selected'],\n properties: {\n // Standard Properties.\n abbr: null,\n accept: commaSeparated,\n acceptCharset: spaceSeparated,\n accessKey: spaceSeparated,\n action: null,\n allow: null,\n allowFullScreen: boolean,\n allowPaymentRequest: boolean,\n allowUserMedia: boolean,\n alt: null,\n as: null,\n async: boolean,\n autoCapitalize: null,\n autoComplete: spaceSeparated,\n autoFocus: boolean,\n autoPlay: boolean,\n blocking: spaceSeparated,\n capture: null,\n charSet: null,\n checked: boolean,\n cite: null,\n className: spaceSeparated,\n cols: number,\n colSpan: null,\n content: null,\n contentEditable: booleanish,\n controls: boolean,\n controlsList: spaceSeparated,\n coords: number | commaSeparated,\n crossOrigin: null,\n data: null,\n dateTime: null,\n decoding: null,\n default: boolean,\n defer: boolean,\n dir: null,\n dirName: null,\n disabled: boolean,\n download: overloadedBoolean,\n draggable: booleanish,\n encType: null,\n enterKeyHint: null,\n fetchPriority: null,\n form: null,\n formAction: null,\n formEncType: null,\n formMethod: null,\n formNoValidate: boolean,\n formTarget: null,\n headers: spaceSeparated,\n height: number,\n hidden: overloadedBoolean,\n high: number,\n href: null,\n hrefLang: null,\n htmlFor: spaceSeparated,\n httpEquiv: spaceSeparated,\n id: null,\n imageSizes: null,\n imageSrcSet: null,\n inert: boolean,\n inputMode: null,\n integrity: null,\n is: null,\n isMap: boolean,\n itemId: null,\n itemProp: spaceSeparated,\n itemRef: spaceSeparated,\n itemScope: boolean,\n itemType: spaceSeparated,\n kind: null,\n label: null,\n lang: null,\n language: null,\n list: null,\n loading: null,\n loop: boolean,\n low: number,\n manifest: null,\n max: null,\n maxLength: number,\n media: null,\n method: null,\n min: null,\n minLength: number,\n multiple: boolean,\n muted: boolean,\n name: null,\n nonce: null,\n noModule: boolean,\n noValidate: boolean,\n onAbort: null,\n onAfterPrint: null,\n onAuxClick: null,\n onBeforeMatch: null,\n onBeforePrint: null,\n onBeforeToggle: null,\n onBeforeUnload: null,\n onBlur: null,\n onCancel: null,\n onCanPlay: null,\n onCanPlayThrough: null,\n onChange: null,\n onClick: null,\n onClose: null,\n onContextLost: null,\n onContextMenu: null,\n onContextRestored: null,\n onCopy: null,\n onCueChange: null,\n onCut: null,\n onDblClick: null,\n onDrag: null,\n onDragEnd: null,\n onDragEnter: null,\n onDragExit: null,\n onDragLeave: null,\n onDragOver: null,\n onDragStart: null,\n onDrop: null,\n onDurationChange: null,\n onEmptied: null,\n onEnded: null,\n onError: null,\n onFocus: null,\n onFormData: null,\n onHashChange: null,\n onInput: null,\n onInvalid: null,\n onKeyDown: null,\n onKeyPress: null,\n onKeyUp: null,\n onLanguageChange: null,\n onLoad: null,\n onLoadedData: null,\n onLoadedMetadata: null,\n onLoadEnd: null,\n onLoadStart: null,\n onMessage: null,\n onMessageError: null,\n onMouseDown: null,\n onMouseEnter: null,\n onMouseLeave: null,\n onMouseMove: null,\n onMouseOut: null,\n onMouseOver: null,\n onMouseUp: null,\n onOffline: null,\n onOnline: null,\n onPageHide: null,\n onPageShow: null,\n onPaste: null,\n onPause: null,\n onPlay: null,\n onPlaying: null,\n onPopState: null,\n onProgress: null,\n onRateChange: null,\n onRejectionHandled: null,\n onReset: null,\n onResize: null,\n onScroll: null,\n onScrollEnd: null,\n onSecurityPolicyViolation: null,\n onSeeked: null,\n onSeeking: null,\n onSelect: null,\n onSlotChange: null,\n onStalled: null,\n onStorage: null,\n onSubmit: null,\n onSuspend: null,\n onTimeUpdate: null,\n onToggle: null,\n onUnhandledRejection: null,\n onUnload: null,\n onVolumeChange: null,\n onWaiting: null,\n onWheel: null,\n open: boolean,\n optimum: number,\n pattern: null,\n ping: spaceSeparated,\n placeholder: null,\n playsInline: boolean,\n popover: null,\n popoverTarget: null,\n popoverTargetAction: null,\n poster: null,\n preload: null,\n readOnly: boolean,\n referrerPolicy: null,\n rel: spaceSeparated,\n required: boolean,\n reversed: boolean,\n rows: number,\n rowSpan: number,\n sandbox: spaceSeparated,\n scope: null,\n scoped: boolean,\n seamless: boolean,\n selected: boolean,\n shadowRootClonable: boolean,\n shadowRootDelegatesFocus: boolean,\n shadowRootMode: null,\n shape: null,\n size: number,\n sizes: null,\n slot: null,\n span: number,\n spellCheck: booleanish,\n src: null,\n srcDoc: null,\n srcLang: null,\n srcSet: null,\n start: number,\n step: null,\n style: null,\n tabIndex: number,\n target: null,\n title: null,\n translate: null,\n type: null,\n typeMustMatch: boolean,\n useMap: null,\n value: booleanish,\n width: number,\n wrap: null,\n writingSuggestions: null,\n\n // Legacy.\n // See: https://html.spec.whatwg.org/#other-elements,-attributes-and-apis\n align: null, // Several. Use CSS `text-align` instead,\n aLink: null, // `<body>`. Use CSS `a:active {color}` instead\n archive: spaceSeparated, // `<object>`. List of URIs to archives\n axis: null, // `<td>` and `<th>`. Use `scope` on `<th>`\n background: null, // `<body>`. Use CSS `background-image` instead\n bgColor: null, // `<body>` and table elements. Use CSS `background-color` instead\n border: number, // `<table>`. Use CSS `border-width` instead,\n borderColor: null, // `<table>`. Use CSS `border-color` instead,\n bottomMargin: number, // `<body>`\n cellPadding: null, // `<table>`\n cellSpacing: null, // `<table>`\n char: null, // Several table elements. When `align=char`, sets the character to align on\n charOff: null, // Several table elements. When `char`, offsets the alignment\n classId: null, // `<object>`\n clear: null, // `<br>`. Use CSS `clear` instead\n code: null, // `<object>`\n codeBase: null, // `<object>`\n codeType: null, // `<object>`\n color: null, // `<font>` and `<hr>`. Use CSS instead\n compact: boolean, // Lists. Use CSS to reduce space between items instead\n declare: boolean, // `<object>`\n event: null, // `<script>`\n face: null, // `<font>`. Use CSS instead\n frame: null, // `<table>`\n frameBorder: null, // `<iframe>`. Use CSS `border` instead\n hSpace: number, // `<img>` and `<object>`\n leftMargin: number, // `<body>`\n link: null, // `<body>`. Use CSS `a:link {color: *}` instead\n longDesc: null, // `<frame>`, `<iframe>`, and `<img>`. Use an `<a>`\n lowSrc: null, // `<img>`. Use a `<picture>`\n marginHeight: number, // `<body>`\n marginWidth: number, // `<body>`\n noResize: boolean, // `<frame>`\n noHref: boolean, // `<area>`. Use no href instead of an explicit `nohref`\n noShade: boolean, // `<hr>`. Use background-color and height instead of borders\n noWrap: boolean, // `<td>` and `<th>`\n object: null, // `<applet>`\n profile: null, // `<head>`\n prompt: null, // `<isindex>`\n rev: null, // `<link>`\n rightMargin: number, // `<body>`\n rules: null, // `<table>`\n scheme: null, // `<meta>`\n scrolling: booleanish, // `<frame>`. Use overflow in the child context\n standby: null, // `<object>`\n summary: null, // `<table>`\n text: null, // `<body>`. Use CSS `color` instead\n topMargin: number, // `<body>`\n valueType: null, // `<param>`\n version: null, // `<html>`. Use a doctype.\n vAlign: null, // Several. Use CSS `vertical-align` instead\n vLink: null, // `<body>`. Use CSS `a:visited {color}` instead\n vSpace: number, // `<img>` and `<object>`\n\n // Non-standard Properties.\n allowTransparency: null,\n autoCorrect: null,\n autoSave: null,\n disablePictureInPicture: boolean,\n disableRemotePlayback: boolean,\n prefix: null,\n property: null,\n results: number,\n security: null,\n unselectable: null\n },\n space: 'html',\n transform: caseInsensitiveTransform\n})\n","import {caseSensitiveTransform} from './util/case-sensitive-transform.js'\nimport {create} from './util/create.js'\nimport {\n boolean,\n commaOrSpaceSeparated,\n commaSeparated,\n number,\n spaceSeparated\n} from './util/types.js'\n\nexport const svg = create({\n attributes: {\n accentHeight: 'accent-height',\n alignmentBaseline: 'alignment-baseline',\n arabicForm: 'arabic-form',\n baselineShift: 'baseline-shift',\n capHeight: 'cap-height',\n className: 'class',\n clipPath: 'clip-path',\n clipRule: 'clip-rule',\n colorInterpolation: 'color-interpolation',\n colorInterpolationFilters: 'color-interpolation-filters',\n colorProfile: 'color-profile',\n colorRendering: 'color-rendering',\n crossOrigin: 'crossorigin',\n dataType: 'datatype',\n dominantBaseline: 'dominant-baseline',\n enableBackground: 'enable-background',\n fillOpacity: 'fill-opacity',\n fillRule: 'fill-rule',\n floodColor: 'flood-color',\n floodOpacity: 'flood-opacity',\n fontFamily: 'font-family',\n fontSize: 'font-size',\n fontSizeAdjust: 'font-size-adjust',\n fontStretch: 'font-stretch',\n fontStyle: 'font-style',\n fontVariant: 'font-variant',\n fontWeight: 'font-weight',\n glyphName: 'glyph-name',\n glyphOrientationHorizontal: 'glyph-orientation-horizontal',\n glyphOrientationVertical: 'glyph-orientation-vertical',\n hrefLang: 'hreflang',\n horizAdvX: 'horiz-adv-x',\n horizOriginX: 'horiz-origin-x',\n horizOriginY: 'horiz-origin-y',\n imageRendering: 'image-rendering',\n letterSpacing: 'letter-spacing',\n lightingColor: 'lighting-color',\n markerEnd: 'marker-end',\n markerMid: 'marker-mid',\n markerStart: 'marker-start',\n navDown: 'nav-down',\n navDownLeft: 'nav-down-left',\n navDownRight: 'nav-down-right',\n navLeft: 'nav-left',\n navNext: 'nav-next',\n navPrev: 'nav-prev',\n navRight: 'nav-right',\n navUp: 'nav-up',\n navUpLeft: 'nav-up-left',\n navUpRight: 'nav-up-right',\n onAbort: 'onabort',\n onActivate: 'onactivate',\n onAfterPrint: 'onafterprint',\n onBeforePrint: 'onbeforeprint',\n onBegin: 'onbegin',\n onCancel: 'oncancel',\n onCanPlay: 'oncanplay',\n onCanPlayThrough: 'oncanplaythrough',\n onChange: 'onchange',\n onClick: 'onclick',\n onClose: 'onclose',\n onCopy: 'oncopy',\n onCueChange: 'oncuechange',\n onCut: 'oncut',\n onDblClick: 'ondblclick',\n onDrag: 'ondrag',\n onDragEnd: 'ondragend',\n onDragEnter: 'ondragenter',\n onDragExit: 'ondragexit',\n onDragLeave: 'ondragleave',\n onDragOver: 'ondragover',\n onDragStart: 'ondragstart',\n onDrop: 'ondrop',\n onDurationChange: 'ondurationchange',\n onEmptied: 'onemptied',\n onEnd: 'onend',\n onEnded: 'onended',\n onError: 'onerror',\n onFocus: 'onfocus',\n onFocusIn: 'onfocusin',\n onFocusOut: 'onfocusout',\n onHashChange: 'onhashchange',\n onInput: 'oninput',\n onInvalid: 'oninvalid',\n onKeyDown: 'onkeydown',\n onKeyPress: 'onkeypress',\n onKeyUp: 'onkeyup',\n onLoad: 'onload',\n onLoadedData: 'onloadeddata',\n onLoadedMetadata: 'onloadedmetadata',\n onLoadStart: 'onloadstart',\n onMessage: 'onmessage',\n onMouseDown: 'onmousedown',\n onMouseEnter: 'onmouseenter',\n onMouseLeave: 'onmouseleave',\n onMouseMove: 'onmousemove',\n onMouseOut: 'onmouseout',\n onMouseOver: 'onmouseover',\n onMouseUp: 'onmouseup',\n onMouseWheel: 'onmousewheel',\n onOffline: 'onoffline',\n onOnline: 'ononline',\n onPageHide: 'onpagehide',\n onPageShow: 'onpageshow',\n onPaste: 'onpaste',\n onPause: 'onpause',\n onPlay: 'onplay',\n onPlaying: 'onplaying',\n onPopState: 'onpopstate',\n onProgress: 'onprogress',\n onRateChange: 'onratechange',\n onRepeat: 'onrepeat',\n onReset: 'onreset',\n onResize: 'onresize',\n onScroll: 'onscroll',\n onSeeked: 'onseeked',\n onSeeking: 'onseeking',\n onSelect: 'onselect',\n onShow: 'onshow',\n onStalled: 'onstalled',\n onStorage: 'onstorage',\n onSubmit: 'onsubmit',\n onSuspend: 'onsuspend',\n onTimeUpdate: 'ontimeupdate',\n onToggle: 'ontoggle',\n onUnload: 'onunload',\n onVolumeChange: 'onvolumechange',\n onWaiting: 'onwaiting',\n onZoom: 'onzoom',\n overlinePosition: 'overline-position',\n overlineThickness: 'overline-thickness',\n paintOrder: 'paint-order',\n panose1: 'panose-1',\n pointerEvents: 'pointer-events',\n referrerPolicy: 'referrerpolicy',\n renderingIntent: 'rendering-intent',\n shapeRendering: 'shape-rendering',\n stopColor: 'stop-color',\n stopOpacity: 'stop-opacity',\n strikethroughPosition: 'strikethrough-position',\n strikethroughThickness: 'strikethrough-thickness',\n strokeDashArray: 'stroke-dasharray',\n strokeDashOffset: 'stroke-dashoffset',\n strokeLineCap: 'stroke-linecap',\n strokeLineJoin: 'stroke-linejoin',\n strokeMiterLimit: 'stroke-miterlimit',\n strokeOpacity: 'stroke-opacity',\n strokeWidth: 'stroke-width',\n tabIndex: 'tabindex',\n textAnchor: 'text-anchor',\n textDecoration: 'text-decoration',\n textRendering: 'text-rendering',\n transformOrigin: 'transform-origin',\n typeOf: 'typeof',\n underlinePosition: 'underline-position',\n underlineThickness: 'underline-thickness',\n unicodeBidi: 'unicode-bidi',\n unicodeRange: 'unicode-range',\n unitsPerEm: 'units-per-em',\n vAlphabetic: 'v-alphabetic',\n vHanging: 'v-hanging',\n vIdeographic: 'v-ideographic',\n vMathematical: 'v-mathematical',\n vectorEffect: 'vector-effect',\n vertAdvY: 'vert-adv-y',\n vertOriginX: 'vert-origin-x',\n vertOriginY: 'vert-origin-y',\n wordSpacing: 'word-spacing',\n writingMode: 'writing-mode',\n xHeight: 'x-height',\n // These were camelcased in Tiny. Now lowercased in SVG 2\n playbackOrder: 'playbackorder',\n timelineBegin: 'timelinebegin'\n },\n properties: {\n about: commaOrSpaceSeparated,\n accentHeight: number,\n accumulate: null,\n additive: null,\n alignmentBaseline: null,\n alphabetic: number,\n amplitude: number,\n arabicForm: null,\n ascent: number,\n attributeName: null,\n attributeType: null,\n azimuth: number,\n bandwidth: null,\n baselineShift: null,\n baseFrequency: null,\n baseProfile: null,\n bbox: null,\n begin: null,\n bias: number,\n by: null,\n calcMode: null,\n capHeight: number,\n className: spaceSeparated,\n clip: null,\n clipPath: null,\n clipPathUnits: null,\n clipRule: null,\n color: null,\n colorInterpolation: null,\n colorInterpolationFilters: null,\n colorProfile: null,\n colorRendering: null,\n content: null,\n contentScriptType: null,\n contentStyleType: null,\n crossOrigin: null,\n cursor: null,\n cx: null,\n cy: null,\n d: null,\n dataType: null,\n defaultAction: null,\n descent: number,\n diffuseConstant: number,\n direction: null,\n display: null,\n dur: null,\n divisor: number,\n dominantBaseline: null,\n download: boolean,\n dx: null,\n dy: null,\n edgeMode: null,\n editable: null,\n elevation: number,\n enableBackground: null,\n end: null,\n event: null,\n exponent: number,\n externalResourcesRequired: null,\n fill: null,\n fillOpacity: number,\n fillRule: null,\n filter: null,\n filterRes: null,\n filterUnits: null,\n floodColor: null,\n floodOpacity: null,\n focusable: null,\n focusHighlight: null,\n fontFamily: null,\n fontSize: null,\n fontSizeAdjust: null,\n fontStretch: null,\n fontStyle: null,\n fontVariant: null,\n fontWeight: null,\n format: null,\n fr: null,\n from: null,\n fx: null,\n fy: null,\n g1: commaSeparated,\n g2: commaSeparated,\n glyphName: commaSeparated,\n glyphOrientationHorizontal: null,\n glyphOrientationVertical: null,\n glyphRef: null,\n gradientTransform: null,\n gradientUnits: null,\n handler: null,\n hanging: number,\n hatchContentUnits: null,\n hatchUnits: null,\n height: null,\n href: null,\n hrefLang: null,\n horizAdvX: number,\n horizOriginX: number,\n horizOriginY: number,\n id: null,\n ideographic: number,\n imageRendering: null,\n initialVisibility: null,\n in: null,\n in2: null,\n intercept: number,\n k: number,\n k1: number,\n k2: number,\n k3: number,\n k4: number,\n kernelMatrix: commaOrSpaceSeparated,\n kernelUnitLength: null,\n keyPoints: null, // SEMI_COLON_SEPARATED\n keySplines: null, // SEMI_COLON_SEPARATED\n keyTimes: null, // SEMI_COLON_SEPARATED\n kerning: null,\n lang: null,\n lengthAdjust: null,\n letterSpacing: null,\n lightingColor: null,\n limitingConeAngle: number,\n local: null,\n markerEnd: null,\n markerMid: null,\n markerStart: null,\n markerHeight: null,\n markerUnits: null,\n markerWidth: null,\n mask: null,\n maskContentUnits: null,\n maskUnits: null,\n mathematical: null,\n max: null,\n media: null,\n mediaCharacterEncoding: null,\n mediaContentEncodings: null,\n mediaSize: number,\n mediaTime: null,\n method: null,\n min: null,\n mode: null,\n name: null,\n navDown: null,\n navDownLeft: null,\n navDownRight: null,\n navLeft: null,\n navNext: null,\n navPrev: null,\n navRight: null,\n navUp: null,\n navUpLeft: null,\n navUpRight: null,\n numOctaves: null,\n observer: null,\n offset: null,\n onAbort: null,\n onActivate: null,\n onAfterPrint: null,\n onBeforePrint: null,\n onBegin: null,\n onCancel: null,\n onCanPlay: null,\n onCanPlayThrough: null,\n onChange: null,\n onClick: null,\n onClose: null,\n onCopy: null,\n onCueChange: null,\n onCut: null,\n onDblClick: null,\n onDrag: null,\n onDragEnd: null,\n onDragEnter: null,\n onDragExit: null,\n onDragLeave: null,\n onDragOver: null,\n onDragStart: null,\n onDrop: null,\n onDurationChange: null,\n onEmptied: null,\n onEnd: null,\n onEnded: null,\n onError: null,\n onFocus: null,\n onFocusIn: null,\n onFocusOut: null,\n onHashChange: null,\n onInput: null,\n onInvalid: null,\n onKeyDown: null,\n onKeyPress: null,\n onKeyUp: null,\n onLoad: null,\n onLoadedData: null,\n onLoadedMetadata: null,\n onLoadStart: null,\n onMessage: null,\n onMouseDown: null,\n onMouseEnter: null,\n onMouseLeave: null,\n onMouseMove: null,\n onMouseOut: null,\n onMouseOver: null,\n onMouseUp: null,\n onMouseWheel: null,\n onOffline: null,\n onOnline: null,\n onPageHide: null,\n onPageShow: null,\n onPaste: null,\n onPause: null,\n onPlay: null,\n onPlaying: null,\n onPopState: null,\n onProgress: null,\n onRateChange: null,\n onRepeat: null,\n onReset: null,\n onResize: null,\n onScroll: null,\n onSeeked: null,\n onSeeking: null,\n onSelect: null,\n onShow: null,\n onStalled: null,\n onStorage: null,\n onSubmit: null,\n onSuspend: null,\n onTimeUpdate: null,\n onToggle: null,\n onUnload: null,\n onVolumeChange: null,\n onWaiting: null,\n onZoom: null,\n opacity: null,\n operator: null,\n order: null,\n orient: null,\n orientation: null,\n origin: null,\n overflow: null,\n overlay: null,\n overlinePosition: number,\n overlineThickness: number,\n paintOrder: null,\n panose1: null,\n path: null,\n pathLength: number,\n patternContentUnits: null,\n patternTransform: null,\n patternUnits: null,\n phase: null,\n ping: spaceSeparated,\n pitch: null,\n playbackOrder: null,\n pointerEvents: null,\n points: null,\n pointsAtX: number,\n pointsAtY: number,\n pointsAtZ: number,\n preserveAlpha: null,\n preserveAspectRatio: null,\n primitiveUnits: null,\n propagate: null,\n property: commaOrSpaceSeparated,\n r: null,\n radius: null,\n referrerPolicy: null,\n refX: null,\n refY: null,\n rel: commaOrSpaceSeparated,\n rev: commaOrSpaceSeparated,\n renderingIntent: null,\n repeatCount: null,\n repeatDur: null,\n requiredExtensions: commaOrSpaceSeparated,\n requiredFeatures: commaOrSpaceSeparated,\n requiredFonts: commaOrSpaceSeparated,\n requiredFormats: commaOrSpaceSeparated,\n resource: null,\n restart: null,\n result: null,\n rotate: null,\n rx: null,\n ry: null,\n scale: null,\n seed: null,\n shapeRendering: null,\n side: null,\n slope: null,\n snapshotTime: null,\n specularConstant: number,\n specularExponent: number,\n spreadMethod: null,\n spacing: null,\n startOffset: null,\n stdDeviation: null,\n stemh: null,\n stemv: null,\n stitchTiles: null,\n stopColor: null,\n stopOpacity: null,\n strikethroughPosition: number,\n strikethroughThickness: number,\n string: null,\n stroke: null,\n strokeDashArray: commaOrSpaceSeparated,\n strokeDashOffset: null,\n strokeLineCap: null,\n strokeLineJoin: null,\n strokeMiterLimit: number,\n strokeOpacity: number,\n strokeWidth: null,\n style: null,\n surfaceScale: number,\n syncBehavior: null,\n syncBehaviorDefault: null,\n syncMaster: null,\n syncTolerance: null,\n syncToleranceDefault: null,\n systemLanguage: commaOrSpaceSeparated,\n tabIndex: number,\n tableValues: null,\n target: null,\n targetX: number,\n targetY: number,\n textAnchor: null,\n textDecoration: null,\n textRendering: null,\n textLength: null,\n timelineBegin: null,\n title: null,\n transformBehavior: null,\n type: null,\n typeOf: commaOrSpaceSeparated,\n to: null,\n transform: null,\n transformOrigin: null,\n u1: null,\n u2: null,\n underlinePosition: number,\n underlineThickness: number,\n unicode: null,\n unicodeBidi: null,\n unicodeRange: null,\n unitsPerEm: number,\n values: null,\n vAlphabetic: number,\n vMathematical: number,\n vectorEffect: null,\n vHanging: number,\n vIdeographic: number,\n version: null,\n vertAdvY: number,\n vertOriginX: number,\n vertOriginY: number,\n viewBox: null,\n viewTarget: null,\n visibility: null,\n width: null,\n widths: null,\n wordSpacing: null,\n writingMode: null,\n x: null,\n x1: null,\n x2: null,\n xChannelSelector: null,\n xHeight: number,\n y: null,\n y1: null,\n y2: null,\n yChannelSelector: null,\n z: null,\n zoomAndPan: null\n },\n space: 'svg',\n transform: caseSensitiveTransform\n})\n","import {create} from './util/create.js'\n\nexport const xlink = create({\n properties: {\n xLinkActuate: null,\n xLinkArcRole: null,\n xLinkHref: null,\n xLinkRole: null,\n xLinkShow: null,\n xLinkTitle: null,\n xLinkType: null\n },\n space: 'xlink',\n transform(_, property) {\n return 'xlink:' + property.slice(5).toLowerCase()\n }\n})\n","import {create} from './util/create.js'\nimport {caseInsensitiveTransform} from './util/case-insensitive-transform.js'\n\nexport const xmlns = create({\n attributes: {xmlnsxlink: 'xmlns:xlink'},\n properties: {xmlnsXLink: null, xmlns: null},\n space: 'xmlns',\n transform: caseInsensitiveTransform\n})\n","import {create} from './util/create.js'\n\nexport const xml = create({\n properties: {xmlBase: null, xmlLang: null, xmlSpace: null},\n space: 'xml',\n transform(_, property) {\n return 'xml:' + property.slice(3).toLowerCase()\n }\n})\n","/**\n * Special cases for React (`Record<string, string>`).\n *\n * `hast` is close to `React` but differs in a couple of cases.\n * To get a React property from a hast property,\n * check if it is in `hastToReact`.\n * If it is, use the corresponding value;\n * otherwise, use the hast property.\n *\n * @type {Record<string, string>}\n */\nexport const hastToReact = {\n classId: 'classID',\n dataType: 'datatype',\n itemId: 'itemID',\n strokeDashArray: 'strokeDasharray',\n strokeDashOffset: 'strokeDashoffset',\n strokeLineCap: 'strokeLinecap',\n strokeLineJoin: 'strokeLinejoin',\n strokeMiterLimit: 'strokeMiterlimit',\n typeOf: 'typeof',\n xLinkActuate: 'xlinkActuate',\n xLinkArcRole: 'xlinkArcrole',\n xLinkHref: 'xlinkHref',\n xLinkRole: 'xlinkRole',\n xLinkShow: 'xlinkShow',\n xLinkTitle: 'xlinkTitle',\n xLinkType: 'xlinkType',\n xmlnsXLink: 'xmlnsXlink'\n}\n","/**\n * @import {Schema} from 'property-information'\n */\n\nimport {DefinedInfo} from './util/defined-info.js'\nimport {Info} from './util/info.js'\nimport {normalize} from './normalize.js'\n\nconst cap = /[A-Z]/g\nconst dash = /-[a-z]/g\nconst valid = /^data[-\\w.:]+$/i\n\n/**\n * Look up info on a property.\n *\n * In most cases the given `schema` contains info on the property.\n * All standard,\n * most legacy,\n * and some non-standard properties are supported.\n * For these cases,\n * the returned `Info` has hints about the value of the property.\n *\n * `name` can also be a valid data attribute or property,\n * in which case an `Info` object with the correctly cased `attribute` and\n * `property` is returned.\n *\n * `name` can be an unknown attribute,\n * in which case an `Info` object with `attribute` and `property` set to the\n * given name is returned.\n * It is not recommended to provide unsupported legacy or recently specced\n * properties.\n *\n *\n * @param {Schema} schema\n * Schema;\n * either the `html` or `svg` export.\n * @param {string} value\n * An attribute-like or property-like name;\n * it will be passed through `normalize` to hopefully find the correct info.\n * @returns {Info}\n * Info.\n */\nexport function find(schema, value) {\n const normal = normalize(value)\n let property = value\n let Type = Info\n\n if (normal in schema.normal) {\n return schema.property[schema.normal[normal]]\n }\n\n if (normal.length > 4 && normal.slice(0, 4) === 'data' && valid.test(value)) {\n // Attribute or property.\n if (value.charAt(4) === '-') {\n // Turn it into a property.\n const rest = value.slice(5).replace(dash, camelcase)\n property = 'data' + rest.charAt(0).toUpperCase() + rest.slice(1)\n } else {\n // Turn it into an attribute.\n const rest = value.slice(4)\n\n if (!dash.test(rest)) {\n let dashes = rest.replace(cap, kebab)\n\n if (dashes.charAt(0) !== '-') {\n dashes = '-' + dashes\n }\n\n value = 'data' + dashes\n }\n }\n\n Type = DefinedInfo\n }\n\n return new Type(property, value)\n}\n\n/**\n * @param {string} $0\n * Value.\n * @returns {string}\n * Kebab.\n */\nfunction kebab($0) {\n return '-' + $0.toLowerCase()\n}\n\n/**\n * @param {string} $0\n * Value.\n * @returns {string}\n * Camel.\n */\nfunction camelcase($0) {\n return $0.charAt(1).toUpperCase()\n}\n","// Note: types exposed from `index.d.ts`.\nimport {merge} from './lib/util/merge.js'\nimport {aria} from './lib/aria.js'\nimport {html as htmlBase} from './lib/html.js'\nimport {svg as svgBase} from './lib/svg.js'\nimport {xlink} from './lib/xlink.js'\nimport {xmlns} from './lib/xmlns.js'\nimport {xml} from './lib/xml.js'\n\nexport {hastToReact} from './lib/hast-to-react.js'\n\nexport const html = merge([aria, htmlBase, xlink, xmlns, xml], 'html')\n\nexport {find} from './lib/find.js'\nexport {normalize} from './lib/normalize.js'\n\nexport const svg = merge([aria, svgBase, xlink, xmlns, xml], 'svg')\n","/**\n * @typedef Options\n * Configuration for `stringify`.\n * @property {boolean} [padLeft=true]\n * Whether to pad a space before a token.\n * @property {boolean} [padRight=false]\n * Whether to pad a space after a token.\n */\n\n/**\n * @typedef {Options} StringifyOptions\n * Please use `StringifyOptions` instead.\n */\n\n/**\n * Parse comma-separated tokens to an array.\n *\n * @param {string} value\n * Comma-separated tokens.\n * @returns {Array<string>}\n * List of tokens.\n */\nexport function parse(value) {\n /** @type {Array<string>} */\n const tokens = []\n const input = String(value || '')\n let index = input.indexOf(',')\n let start = 0\n /** @type {boolean} */\n let end = false\n\n while (!end) {\n if (index === -1) {\n index = input.length\n end = true\n }\n\n const token = input.slice(start, index).trim()\n\n if (token || !end) {\n tokens.push(token)\n }\n\n start = index + 1\n index = input.indexOf(',', start)\n }\n\n return tokens\n}\n\n/**\n * Serialize an array of strings or numbers to comma-separated tokens.\n *\n * @param {Array<string|number>} values\n * List of tokens.\n * @param {Options} [options]\n * Configuration for `stringify` (optional).\n * @returns {string}\n * Comma-separated tokens.\n */\nexport function stringify(values, options) {\n const settings = options || {}\n\n // Ensure the last empty entry is seen.\n const input = values[values.length - 1] === '' ? [...values, ''] : values\n\n return input\n .join(\n (settings.padRight ? ' ' : '') +\n ',' +\n (settings.padLeft === false ? '' : ' ')\n )\n .trim()\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n */\n\n/**\n * @template {string} SimpleSelector\n * Selector type.\n * @template {string} DefaultTagName\n * Default tag name.\n * @typedef {(\n * SimpleSelector extends ''\n * ? DefaultTagName\n * : SimpleSelector extends `${infer TagName}.${infer Rest}`\n * ? ExtractTagName<TagName, DefaultTagName>\n * : SimpleSelector extends `${infer TagName}#${infer Rest}`\n * ? ExtractTagName<TagName, DefaultTagName>\n * : SimpleSelector extends string\n * ? SimpleSelector\n * : DefaultTagName\n * )} ExtractTagName\n * Extract tag name from a simple selector.\n */\n\nconst search = /[#.]/g\n\n/**\n * Create a hast element from a simple CSS selector.\n *\n * @template {string} Selector\n * Type of selector.\n * @template {string} [DefaultTagName='div']\n * Type of default tag name (default: `'div'`).\n * @param {Selector | null | undefined} [selector]\n * Simple CSS selector (optional).\n *\n * Can contain a tag name (`foo`), classes (`.bar`), and an ID (`#baz`).\n * Multiple classes are allowed.\n * Uses the last ID if multiple IDs are found.\n * @param {DefaultTagName | null | undefined} [defaultTagName='div']\n * Tag name to use if `selector` does not specify one (default: `'div'`).\n * @returns {Element & {tagName: ExtractTagName<Selector, DefaultTagName>}}\n * Built element.\n */\nexport function parseSelector(selector, defaultTagName) {\n const value = selector || ''\n /** @type {Properties} */\n const props = {}\n let start = 0\n /** @type {string | undefined} */\n let previous\n /** @type {string | undefined} */\n let tagName\n\n while (start < value.length) {\n search.lastIndex = start\n const match = search.exec(value)\n const subvalue = value.slice(start, match ? match.index : value.length)\n\n if (subvalue) {\n if (!previous) {\n tagName = subvalue\n } else if (previous === '#') {\n props.id = subvalue\n } else if (Array.isArray(props.className)) {\n props.className.push(subvalue)\n } else {\n props.className = [subvalue]\n }\n\n start += subvalue.length\n }\n\n if (match) {\n previous = match[0]\n start++\n }\n }\n\n return {\n type: 'element',\n // @ts-expect-error: tag name is parsed.\n tagName: tagName || defaultTagName || 'div',\n properties: props,\n children: []\n }\n}\n","/**\n * Parse space-separated tokens to an array of strings.\n *\n * @param {string} value\n * Space-separated tokens.\n * @returns {Array<string>}\n * List of tokens.\n */\nexport function parse(value) {\n const input = String(value || '').trim()\n return input ? input.split(/[ \\t\\n\\r\\f]+/g) : []\n}\n\n/**\n * Serialize an array of strings as space separated-tokens.\n *\n * @param {Array<string|number>} values\n * List of tokens.\n * @returns {string}\n * Space-separated tokens.\n */\nexport function stringify(values) {\n return values.join(' ').trim()\n}\n","/**\n * @import {Element, Nodes, RootContent, Root} from 'hast'\n * @import {Info, Schema} from 'property-information'\n */\n\n/**\n * @typedef {Array<Nodes | PrimitiveChild>} ArrayChildNested\n * List of children (deep).\n */\n\n/**\n * @typedef {Array<ArrayChildNested | Nodes | PrimitiveChild>} ArrayChild\n * List of children.\n */\n\n/**\n * @typedef {Array<number | string>} ArrayValue\n * List of property values for space- or comma separated values (such as `className`).\n */\n\n/**\n * @typedef {ArrayChild | Nodes | PrimitiveChild} Child\n * Acceptable child value.\n */\n\n/**\n * @typedef {number | string | null | undefined} PrimitiveChild\n * Primitive children, either ignored (nullish), or turned into text nodes.\n */\n\n/**\n * @typedef {boolean | number | string | null | undefined} PrimitiveValue\n * Primitive property value.\n */\n\n/**\n * @typedef {Record<string, PropertyValue | Style>} Properties\n * Acceptable value for element properties.\n */\n\n/**\n * @typedef {ArrayValue | PrimitiveValue} PropertyValue\n * Primitive value or list value.\n */\n\n/**\n * @typedef {Element | Root} Result\n * Result from a `h` (or `s`) call.\n */\n\n/**\n * @typedef {number | string} StyleValue\n * Value for a CSS style field.\n */\n\n/**\n * @typedef {Record<string, StyleValue>} Style\n * Supported value of a `style` prop.\n */\n\nimport {parse as parseCommas} from 'comma-separated-tokens'\nimport {parseSelector} from 'hast-util-parse-selector'\nimport {find, normalize} from 'property-information'\nimport {parse as parseSpaces} from 'space-separated-tokens'\n\n/**\n * @param {Schema} schema\n * Schema to use.\n * @param {string} defaultTagName\n * Default tag name.\n * @param {ReadonlyArray<string> | undefined} [caseSensitive]\n * Case-sensitive tag names (default: `undefined`).\n * @returns\n * `h`.\n */\nexport function createH(schema, defaultTagName, caseSensitive) {\n const adjust = caseSensitive ? createAdjustMap(caseSensitive) : undefined\n\n /**\n * Hyperscript compatible DSL for creating virtual hast trees.\n *\n * @overload\n * @param {null | undefined} [selector]\n * @param {...Child} children\n * @returns {Root}\n *\n * @overload\n * @param {string} selector\n * @param {Properties} properties\n * @param {...Child} children\n * @returns {Element}\n *\n * @overload\n * @param {string} selector\n * @param {...Child} children\n * @returns {Element}\n *\n * @param {string | null | undefined} [selector]\n * Selector.\n * @param {Child | Properties | null | undefined} [properties]\n * Properties (or first child) (default: `undefined`).\n * @param {...Child} children\n * Children.\n * @returns {Result}\n * Result.\n */\n function h(selector, properties, ...children) {\n /** @type {Result} */\n let node\n\n if (selector === null || selector === undefined) {\n node = {type: 'root', children: []}\n // Properties are not supported for roots.\n const child = /** @type {Child} */ (properties)\n children.unshift(child)\n } else {\n node = parseSelector(selector, defaultTagName)\n // Normalize the name.\n const lower = node.tagName.toLowerCase()\n const adjusted = adjust ? adjust.get(lower) : undefined\n node.tagName = adjusted || lower\n\n // Handle properties.\n if (isChild(properties)) {\n children.unshift(properties)\n } else {\n for (const [key, value] of Object.entries(properties)) {\n addProperty(schema, node.properties, key, value)\n }\n }\n }\n\n // Handle children.\n for (const child of children) {\n addChild(node.children, child)\n }\n\n if (node.type === 'element' && node.tagName === 'template') {\n node.content = {type: 'root', children: node.children}\n node.children = []\n }\n\n return node\n }\n\n return h\n}\n\n/**\n * Check if something is properties or a child.\n *\n * @param {Child | Properties} value\n * Value to check.\n * @returns {value is Child}\n * Whether `value` is definitely a child.\n */\nfunction isChild(value) {\n // Never properties if not an object.\n if (value === null || typeof value !== 'object' || Array.isArray(value)) {\n return true\n }\n\n // Never node without `type`; that’s the main discriminator.\n if (typeof value.type !== 'string') return false\n\n // Slower check: never property value if object or array with\n // non-number/strings.\n const record = /** @type {Record<string, unknown>} */ (value)\n const keys = Object.keys(value)\n\n for (const key of keys) {\n const value = record[key]\n\n if (value && typeof value === 'object') {\n if (!Array.isArray(value)) return true\n\n const list = /** @type {ReadonlyArray<unknown>} */ (value)\n\n for (const item of list) {\n if (typeof item !== 'number' && typeof item !== 'string') {\n return true\n }\n }\n }\n }\n\n // Also see empty `children` as a node.\n if ('children' in value && Array.isArray(value.children)) {\n return true\n }\n\n // Default to properties, someone can always pass an empty object,\n // put `data: {}` in a node,\n // or wrap it in an array.\n return false\n}\n\n/**\n * @param {Schema} schema\n * Schema.\n * @param {Properties} properties\n * Properties object.\n * @param {string} key\n * Property name.\n * @param {PropertyValue | Style} value\n * Property value.\n * @returns {undefined}\n * Nothing.\n */\nfunction addProperty(schema, properties, key, value) {\n const info = find(schema, key)\n /** @type {PropertyValue} */\n let result\n\n // Ignore nullish and NaN values.\n if (value === null || value === undefined) return\n\n if (typeof value === 'number') {\n // Ignore NaN.\n if (Number.isNaN(value)) return\n\n result = value\n }\n // Booleans.\n else if (typeof value === 'boolean') {\n result = value\n }\n // Handle list values.\n else if (typeof value === 'string') {\n if (info.spaceSeparated) {\n result = parseSpaces(value)\n } else if (info.commaSeparated) {\n result = parseCommas(value)\n } else if (info.commaOrSpaceSeparated) {\n result = parseSpaces(parseCommas(value).join(' '))\n } else {\n result = parsePrimitive(info, info.property, value)\n }\n } else if (Array.isArray(value)) {\n result = [...value]\n } else {\n result = info.property === 'style' ? style(value) : String(value)\n }\n\n if (Array.isArray(result)) {\n /** @type {Array<number | string>} */\n const finalResult = []\n\n for (const item of result) {\n // Assume no booleans in array.\n finalResult.push(\n /** @type {number | string} */ (\n parsePrimitive(info, info.property, item)\n )\n )\n }\n\n result = finalResult\n }\n\n // Class names (which can be added both on the `selector` and here).\n if (info.property === 'className' && Array.isArray(properties.className)) {\n // Assume no booleans in `className`.\n result = properties.className.concat(\n /** @type {Array<number | string> | number | string} */ (result)\n )\n }\n\n properties[info.property] = result\n}\n\n/**\n * @param {Array<RootContent>} nodes\n * Children.\n * @param {Child} value\n * Child.\n * @returns {undefined}\n * Nothing.\n */\nfunction addChild(nodes, value) {\n if (value === null || value === undefined) {\n // Empty.\n } else if (typeof value === 'number' || typeof value === 'string') {\n nodes.push({type: 'text', value: String(value)})\n } else if (Array.isArray(value)) {\n for (const child of value) {\n addChild(nodes, child)\n }\n } else if (typeof value === 'object' && 'type' in value) {\n if (value.type === 'root') {\n addChild(nodes, value.children)\n } else {\n nodes.push(value)\n }\n } else {\n throw new Error('Expected node, nodes, or string, got `' + value + '`')\n }\n}\n\n/**\n * Parse a single primitives.\n *\n * @param {Info} info\n * Property information.\n * @param {string} name\n * Property name.\n * @param {PrimitiveValue} value\n * Property value.\n * @returns {PrimitiveValue}\n * Property value.\n */\nfunction parsePrimitive(info, name, value) {\n if (typeof value === 'string') {\n if (info.number && value && !Number.isNaN(Number(value))) {\n return Number(value)\n }\n\n if (\n (info.boolean || info.overloadedBoolean) &&\n (value === '' || normalize(value) === normalize(name))\n ) {\n return true\n }\n }\n\n return value\n}\n\n/**\n * Serialize a `style` object as a string.\n *\n * @param {Style} styles\n * Style object.\n * @returns {string}\n * CSS string.\n */\nfunction style(styles) {\n /** @type {Array<string>} */\n const result = []\n\n for (const [key, value] of Object.entries(styles)) {\n result.push([key, value].join(': '))\n }\n\n return result.join('; ')\n}\n\n/**\n * Create a map to adjust casing.\n *\n * @param {ReadonlyArray<string>} values\n * List of properly cased keys.\n * @returns {Map<string, string>}\n * Map of lowercase keys to uppercase keys.\n */\nfunction createAdjustMap(values) {\n /** @type {Map<string, string>} */\n const result = new Map()\n\n for (const value of values) {\n result.set(value.toLowerCase(), value)\n }\n\n return result\n}\n","/**\n * List of case-sensitive SVG tag names.\n *\n * @type {ReadonlyArray<string>}\n */\nexport const svgCaseSensitiveTagNames = [\n 'altGlyph',\n 'altGlyphDef',\n 'altGlyphItem',\n 'animateColor',\n 'animateMotion',\n 'animateTransform',\n 'clipPath',\n 'feBlend',\n 'feColorMatrix',\n 'feComponentTransfer',\n 'feComposite',\n 'feConvolveMatrix',\n 'feDiffuseLighting',\n 'feDisplacementMap',\n 'feDistantLight',\n 'feDropShadow',\n 'feFlood',\n 'feFuncA',\n 'feFuncB',\n 'feFuncG',\n 'feFuncR',\n 'feGaussianBlur',\n 'feImage',\n 'feMerge',\n 'feMergeNode',\n 'feMorphology',\n 'feOffset',\n 'fePointLight',\n 'feSpecularLighting',\n 'feSpotLight',\n 'feTile',\n 'feTurbulence',\n 'foreignObject',\n 'glyphRef',\n 'linearGradient',\n 'radialGradient',\n 'solidColor',\n 'textArea',\n 'textPath'\n]\n","// Register the JSX namespace on `h`.\n/**\n * @typedef {import('./jsx-classic.js').Element} h.JSX.Element\n * @typedef {import('./jsx-classic.js').ElementChildrenAttribute} h.JSX.ElementChildrenAttribute\n * @typedef {import('./jsx-classic.js').IntrinsicAttributes} h.JSX.IntrinsicAttributes\n * @typedef {import('./jsx-classic.js').IntrinsicElements} h.JSX.IntrinsicElements\n */\n\n// Register the JSX namespace on `s`.\n/**\n * @typedef {import('./jsx-classic.js').Element} s.JSX.Element\n * @typedef {import('./jsx-classic.js').ElementChildrenAttribute} s.JSX.ElementChildrenAttribute\n * @typedef {import('./jsx-classic.js').IntrinsicAttributes} s.JSX.IntrinsicAttributes\n * @typedef {import('./jsx-classic.js').IntrinsicElements} s.JSX.IntrinsicElements\n */\n\nimport {html, svg} from 'property-information'\nimport {createH} from './create-h.js'\nimport {svgCaseSensitiveTagNames} from './svg-case-sensitive-tag-names.js'\n\n// Note: this explicit type is needed, otherwise TS creates broken types.\n/** @type {ReturnType<createH>} */\nexport const h = createH(html, 'div')\n\n// Note: this explicit type is needed, otherwise TS creates broken types.\n/** @type {ReturnType<createH>} */\nexport const s = createH(svg, 'g', svgCaseSensitiveTagNames)\n","/**\n * List of legacy HTML named character references that don’t need a trailing semicolon.\n *\n * @type {Array<string>}\n */\nexport const characterEntitiesLegacy = [\n 'AElig',\n 'AMP',\n 'Aacute',\n 'Acirc',\n 'Agrave',\n 'Aring',\n 'Atilde',\n 'Auml',\n 'COPY',\n 'Ccedil',\n 'ETH',\n 'Eacute',\n 'Ecirc',\n 'Egrave',\n 'Euml',\n 'GT',\n 'Iacute',\n 'Icirc',\n 'Igrave',\n 'Iuml',\n 'LT',\n 'Ntilde',\n 'Oacute',\n 'Ocirc',\n 'Ograve',\n 'Oslash',\n 'Otilde',\n 'Ouml',\n 'QUOT',\n 'REG',\n 'THORN',\n 'Uacute',\n 'Ucirc',\n 'Ugrave',\n 'Uuml',\n 'Yacute',\n 'aacute',\n 'acirc',\n 'acute',\n 'aelig',\n 'agrave',\n 'amp',\n 'aring',\n 'atilde',\n 'auml',\n 'brvbar',\n 'ccedil',\n 'cedil',\n 'cent',\n 'copy',\n 'curren',\n 'deg',\n 'divide',\n 'eacute',\n 'ecirc',\n 'egrave',\n 'eth',\n 'euml',\n 'frac12',\n 'frac14',\n 'frac34',\n 'gt',\n 'iacute',\n 'icirc',\n 'iexcl',\n 'igrave',\n 'iquest',\n 'iuml',\n 'laquo',\n 'lt',\n 'macr',\n 'micro',\n 'middot',\n 'nbsp',\n 'not',\n 'ntilde',\n 'oacute',\n 'ocirc',\n 'ograve',\n 'ordf',\n 'ordm',\n 'oslash',\n 'otilde',\n 'ouml',\n 'para',\n 'plusmn',\n 'pound',\n 'quot',\n 'raquo',\n 'reg',\n 'sect',\n 'shy',\n 'sup1',\n 'sup2',\n 'sup3',\n 'szlig',\n 'thorn',\n 'times',\n 'uacute',\n 'ucirc',\n 'ugrave',\n 'uml',\n 'uuml',\n 'yacute',\n 'yen',\n 'yuml'\n]\n","/**\n * Map of invalid numeric character references to their replacements, according to HTML.\n *\n * @type {Record<number, string>}\n */\nexport const characterReferenceInvalid = {\n 0: '�',\n 128: '€',\n 130: '‚',\n 131: 'ƒ',\n 132: '„',\n 133: '…',\n 134: '†',\n 135: '‡',\n 136: 'ˆ',\n 137: '‰',\n 138: 'Š',\n 139: '‹',\n 140: 'Œ',\n 142: 'Ž',\n 145: '‘',\n 146: '’',\n 147: '“',\n 148: '”',\n 149: '•',\n 150: '–',\n 151: '—',\n 152: '˜',\n 153: '™',\n 154: 'š',\n 155: '›',\n 156: 'œ',\n 158: 'ž',\n 159: 'Ÿ'\n}\n","/**\n * Check if the given character code, or the character code at the first\n * character, is decimal.\n *\n * @param {string|number} character\n * @returns {boolean} Whether `character` is a decimal\n */\nexport function isDecimal(character) {\n const code =\n typeof character === 'string' ? character.charCodeAt(0) : character\n\n return code >= 48 && code <= 57 /* 0-9 */\n}\n","/**\n * Check if the given character code, or the character code at the first\n * character, is hexadecimal.\n *\n * @param {string|number} character\n * @returns {boolean} Whether `character` is hexadecimal\n */\nexport function isHexadecimal(character) {\n const code =\n typeof character === 'string' ? character.charCodeAt(0) : character\n\n return (\n (code >= 97 /* a */ && code <= 102) /* z */ ||\n (code >= 65 /* A */ && code <= 70) /* Z */ ||\n (code >= 48 /* A */ && code <= 57) /* Z */\n )\n}\n","/**\n * Check if the given character code, or the character code at the first\n * character, is alphabetical.\n *\n * @param {string|number} character\n * @returns {boolean} Whether `character` is alphabetical.\n */\nexport function isAlphabetical(character) {\n const code =\n typeof character === 'string' ? character.charCodeAt(0) : character\n\n return (\n (code >= 97 && code <= 122) /* a-z */ ||\n (code >= 65 && code <= 90) /* A-Z */\n )\n}\n","import {isAlphabetical} from 'is-alphabetical'\nimport {isDecimal} from 'is-decimal'\n\n/**\n * Check if the given character code, or the character code at the first\n * character, is alphanumerical.\n *\n * @param {string|number} character\n * @returns {boolean} Whether `character` is alphanumerical.\n */\nexport function isAlphanumerical(character) {\n return isAlphabetical(character) || isDecimal(character)\n}\n","/// <reference lib=\"dom\" />\n\n/* global document */\n\nconst element = document.createElement('i')\n\n/**\n * @param {string} value\n * @returns {string | false}\n */\nexport function decodeNamedCharacterReference(value) {\n const characterReference = '&' + value + ';'\n element.innerHTML = characterReference\n const character = element.textContent\n\n // Some named character references do not require the closing semicolon\n // (`&not`, for instance), which leads to situations where parsing the assumed\n // named reference of `&notit;` will result in the string `¬it;`.\n // When we encounter a trailing semicolon after parsing, and the character\n // reference to decode was not a semicolon (`&semi;`), we can assume that the\n // matching was not complete.\n if (\n character.charCodeAt(character.length - 1) === 59 /* `;` */ &&\n value !== 'semi'\n ) {\n return false\n }\n\n // If the decoded string is equal to the input, the character reference was\n // not valid.\n return character === characterReference ? false : character\n}\n","/**\n * @import {Point} from 'unist'\n * @import {Options} from '../index.js'\n */\n\nimport {characterEntitiesLegacy} from 'character-entities-legacy'\nimport {characterReferenceInvalid} from 'character-reference-invalid'\nimport {isDecimal} from 'is-decimal'\nimport {isHexadecimal} from 'is-hexadecimal'\nimport {isAlphanumerical} from 'is-alphanumerical'\nimport {decodeNamedCharacterReference} from 'decode-named-character-reference'\n\n// Warning messages.\nconst messages = [\n '',\n /* 1: Non terminated (named) */\n 'Named character references must be terminated by a semicolon',\n /* 2: Non terminated (numeric) */\n 'Numeric character references must be terminated by a semicolon',\n /* 3: Empty (named) */\n 'Named character references cannot be empty',\n /* 4: Empty (numeric) */\n 'Numeric character references cannot be empty',\n /* 5: Unknown (named) */\n 'Named character references must be known',\n /* 6: Disallowed (numeric) */\n 'Numeric character references cannot be disallowed',\n /* 7: Prohibited (numeric) */\n 'Numeric character references cannot be outside the permissible Unicode range'\n]\n\n/**\n * Parse HTML character references.\n *\n * @param {string} value\n * @param {Readonly<Options> | null | undefined} [options]\n */\nexport function parseEntities(value, options) {\n const settings = options || {}\n const additional =\n typeof settings.additional === 'string'\n ? settings.additional.charCodeAt(0)\n : settings.additional\n /** @type {Array<string>} */\n const result = []\n let index = 0\n let lines = -1\n let queue = ''\n /** @type {Point | undefined} */\n let point\n /** @type {Array<number>|undefined} */\n let indent\n\n if (settings.position) {\n if ('start' in settings.position || 'indent' in settings.position) {\n // @ts-expect-error: points don’t have indent.\n indent = settings.position.indent\n // @ts-expect-error: points don’t have indent.\n point = settings.position.start\n } else {\n point = settings.position\n }\n }\n\n let line = (point ? point.line : 0) || 1\n let column = (point ? point.column : 0) || 1\n\n // Cache the current point.\n let previous = now()\n /** @type {number|undefined} */\n let character\n\n // Ensure the algorithm walks over the first character (inclusive).\n index--\n\n while (++index <= value.length) {\n // If the previous character was a newline.\n if (character === 10 /* `\\n` */) {\n column = (indent ? indent[lines] : 0) || 1\n }\n\n character = value.charCodeAt(index)\n\n if (character === 38 /* `&` */) {\n const following = value.charCodeAt(index + 1)\n\n // The behavior depends on the identity of the next character.\n if (\n following === 9 /* `\\t` */ ||\n following === 10 /* `\\n` */ ||\n following === 12 /* `\\f` */ ||\n following === 32 /* ` ` */ ||\n following === 38 /* `&` */ ||\n following === 60 /* `<` */ ||\n Number.isNaN(following) ||\n (additional && following === additional)\n ) {\n // Not a character reference.\n // No characters are consumed, and nothing is returned.\n // This is not an error, either.\n queue += String.fromCharCode(character)\n column++\n continue\n }\n\n const start = index + 1\n let begin = start\n let end = start\n /** @type {string} */\n let type\n\n if (following === 35 /* `#` */) {\n // Numerical reference.\n end = ++begin\n\n // The behavior further depends on the next character.\n const following = value.charCodeAt(end)\n\n if (following === 88 /* `X` */ || following === 120 /* `x` */) {\n // ASCII hexadecimal digits.\n type = 'hexadecimal'\n end = ++begin\n } else {\n // ASCII decimal digits.\n type = 'decimal'\n }\n } else {\n // Named reference.\n type = 'named'\n }\n\n let characterReferenceCharacters = ''\n let characterReference = ''\n let characters = ''\n // Each type of character reference accepts different characters.\n // This test is used to detect whether a reference has ended (as the semicolon\n // is not strictly needed).\n const test =\n type === 'named'\n ? isAlphanumerical\n : type === 'decimal'\n ? isDecimal\n : isHexadecimal\n\n end--\n\n while (++end <= value.length) {\n const following = value.charCodeAt(end)\n\n if (!test(following)) {\n break\n }\n\n characters += String.fromCharCode(following)\n\n // Check if we can match a legacy named reference.\n // If so, we cache that as the last viable named reference.\n // This ensures we do not need to walk backwards later.\n if (type === 'named' && characterEntitiesLegacy.includes(characters)) {\n characterReferenceCharacters = characters\n // @ts-expect-error: always able to decode.\n characterReference = decodeNamedCharacterReference(characters)\n }\n }\n\n let terminated = value.charCodeAt(end) === 59 /* `;` */\n\n if (terminated) {\n end++\n\n const namedReference =\n type === 'named' ? decodeNamedCharacterReference(characters) : false\n\n if (namedReference) {\n characterReferenceCharacters = characters\n characterReference = namedReference\n }\n }\n\n let diff = 1 + end - start\n let reference = ''\n\n if (!terminated && settings.nonTerminated === false) {\n // Empty.\n } else if (!characters) {\n // An empty (possible) reference is valid, unless it’s numeric (thus an\n // ampersand followed by an octothorp).\n if (type !== 'named') {\n warning(4 /* Empty (numeric) */, diff)\n }\n } else if (type === 'named') {\n // An ampersand followed by anything unknown, and not terminated, is\n // invalid.\n if (terminated && !characterReference) {\n warning(5 /* Unknown (named) */, 1)\n } else {\n // If there’s something after an named reference which is not known,\n // cap the reference.\n if (characterReferenceCharacters !== characters) {\n end = begin + characterReferenceCharacters.length\n diff = 1 + end - begin\n terminated = false\n }\n\n // If the reference is not terminated, warn.\n if (!terminated) {\n const reason = characterReferenceCharacters\n ? 1 /* Non terminated (named) */\n : 3 /* Empty (named) */\n\n if (settings.attribute) {\n const following = value.charCodeAt(end)\n\n if (following === 61 /* `=` */) {\n warning(reason, diff)\n characterReference = ''\n } else if (isAlphanumerical(following)) {\n characterReference = ''\n } else {\n warning(reason, diff)\n }\n } else {\n warning(reason, diff)\n }\n }\n }\n\n reference = characterReference\n } else {\n if (!terminated) {\n // All nonterminated numeric references are not rendered, and emit a\n // warning.\n warning(2 /* Non terminated (numeric) */, diff)\n }\n\n // When terminated and numerical, parse as either hexadecimal or\n // decimal.\n let referenceCode = Number.parseInt(\n characters,\n type === 'hexadecimal' ? 16 : 10\n )\n\n // Emit a warning when the parsed number is prohibited, and replace with\n // replacement character.\n if (prohibited(referenceCode)) {\n warning(7 /* Prohibited (numeric) */, diff)\n reference = String.fromCharCode(65533 /* `�` */)\n } else if (referenceCode in characterReferenceInvalid) {\n // Emit a warning when the parsed number is disallowed, and replace by\n // an alternative.\n warning(6 /* Disallowed (numeric) */, diff)\n reference = characterReferenceInvalid[referenceCode]\n } else {\n // Parse the number.\n let output = ''\n\n // Emit a warning when the parsed number should not be used.\n if (disallowed(referenceCode)) {\n warning(6 /* Disallowed (numeric) */, diff)\n }\n\n // Serialize the number.\n if (referenceCode > 0xffff) {\n referenceCode -= 0x10000\n output += String.fromCharCode(\n (referenceCode >>> (10 & 0x3ff)) | 0xd800\n )\n referenceCode = 0xdc00 | (referenceCode & 0x3ff)\n }\n\n reference = output + String.fromCharCode(referenceCode)\n }\n }\n\n // Found it!\n // First eat the queued characters as normal text, then eat a reference.\n if (reference) {\n flush()\n\n previous = now()\n index = end - 1\n column += end - start + 1\n result.push(reference)\n const next = now()\n next.offset++\n\n if (settings.reference) {\n settings.reference.call(\n settings.referenceContext || undefined,\n reference,\n {start: previous, end: next},\n value.slice(start - 1, end)\n )\n }\n\n previous = next\n } else {\n // If we could not find a reference, queue the checked characters (as\n // normal characters), and move the pointer to their end.\n // This is possible because we can be certain neither newlines nor\n // ampersands are included.\n characters = value.slice(start - 1, end)\n queue += characters\n column += characters.length\n index = end - 1\n }\n } else {\n // Handle anything other than an ampersand, including newlines and EOF.\n if (character === 10 /* `\\n` */) {\n line++\n lines++\n column = 0\n }\n\n if (Number.isNaN(character)) {\n flush()\n } else {\n queue += String.fromCharCode(character)\n column++\n }\n }\n }\n\n // Return the reduced nodes.\n return result.join('')\n\n // Get current position.\n function now() {\n return {\n line,\n column,\n offset: index + ((point ? point.offset : 0) || 0)\n }\n }\n\n /**\n * Handle the warning.\n *\n * @param {1|2|3|4|5|6|7} code\n * @param {number} offset\n */\n function warning(code, offset) {\n /** @type {ReturnType<now>} */\n let position\n\n if (settings.warning) {\n position = now()\n position.column += offset\n position.offset += offset\n\n settings.warning.call(\n settings.warningContext || undefined,\n messages[code],\n position,\n code\n )\n }\n }\n\n /**\n * Flush `queue` (normal text).\n * Macro invoked before each reference and at the end of `value`.\n * Does nothing when `queue` is empty.\n */\n function flush() {\n if (queue) {\n result.push(queue)\n\n if (settings.text) {\n settings.text.call(settings.textContext || undefined, queue, {\n start: previous,\n end: now()\n })\n }\n\n queue = ''\n }\n }\n}\n\n/**\n * Check if `character` is outside the permissible unicode range.\n *\n * @param {number} code\n * @returns {boolean}\n */\nfunction prohibited(code) {\n return (code >= 0xd800 && code <= 0xdfff) || code > 0x10ffff\n}\n\n/**\n * Check if `character` is disallowed.\n *\n * @param {number} code\n * @returns {boolean}\n */\nfunction disallowed(code) {\n return (\n (code >= 0x0001 && code <= 0x0008) ||\n code === 0x000b ||\n (code >= 0x000d && code <= 0x001f) ||\n (code >= 0x007f && code <= 0x009f) ||\n (code >= 0xfdd0 && code <= 0xfdef) ||\n (code & 0xffff) === 0xffff ||\n (code & 0xffff) === 0xfffe\n )\n}\n","/**\n * @typedef Options\n * Configuration.\n * @property {boolean | null | undefined} [jsx=false]\n * Support JSX identifiers (default: `false`).\n */\n\nconst startRe = /[$_\\p{ID_Start}]/u\nconst contRe = /[$_\\u{200C}\\u{200D}\\p{ID_Continue}]/u\nconst contReJsx = /[-$_\\u{200C}\\u{200D}\\p{ID_Continue}]/u\nconst nameRe = /^[$_\\p{ID_Start}][$_\\u{200C}\\u{200D}\\p{ID_Continue}]*$/u\nconst nameReJsx = /^[$_\\p{ID_Start}][-$_\\u{200C}\\u{200D}\\p{ID_Continue}]*$/u\n\n/** @type {Options} */\nconst emptyOptions = {}\n\n/**\n * Checks if the given code point can start an identifier.\n *\n * @param {number | undefined} code\n * Code point to check.\n * @returns {boolean}\n * Whether `code` can start an identifier.\n */\n// Note: `undefined` is supported so you can pass the result from `''.codePointAt`.\nexport function start(code) {\n return code ? startRe.test(String.fromCodePoint(code)) : false\n}\n\n/**\n * Checks if the given code point can continue an identifier.\n *\n * @param {number | undefined} code\n * Code point to check.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {boolean}\n * Whether `code` can continue an identifier.\n */\n// Note: `undefined` is supported so you can pass the result from `''.codePointAt`.\nexport function cont(code, options) {\n const settings = options || emptyOptions\n const re = settings.jsx ? contReJsx : contRe\n return code ? re.test(String.fromCodePoint(code)) : false\n}\n\n/**\n * Checks if the given value is a valid identifier name.\n *\n * @param {string} name\n * Identifier to check.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {boolean}\n * Whether `name` can be an identifier.\n */\nexport function name(name, options) {\n const settings = options || emptyOptions\n const re = settings.jsx ? nameReJsx : nameRe\n return re.test(name)\n}\n","/**\n * @typedef {import('hast').Nodes} Nodes\n */\n\n// HTML whitespace expression.\n// See <https://infra.spec.whatwg.org/#ascii-whitespace>.\nconst re = /[ \\t\\n\\f\\r]/g\n\n/**\n * Check if the given value is *inter-element whitespace*.\n *\n * @param {Nodes | string} thing\n * Thing to check (`Node` or `string`).\n * @returns {boolean}\n * Whether the `value` is inter-element whitespace (`boolean`): consisting of\n * zero or more of space, tab (`\\t`), line feed (`\\n`), carriage return\n * (`\\r`), or form feed (`\\f`); if a node is passed it must be a `Text` node,\n * whose `value` field is checked.\n */\nexport function whitespace(thing) {\n return typeof thing === 'object'\n ? thing.type === 'text'\n ? empty(thing.value)\n : false\n : empty(thing)\n}\n\n/**\n * @param {string} value\n * @returns {boolean}\n */\nfunction empty(value) {\n return value.replace(re, '') === ''\n}\n","'use strict';\n\n// http://www.w3.org/TR/CSS21/grammar.html\n// https://github.com/visionmedia/css-parse/pull/49#issuecomment-30088027\nvar COMMENT_REGEX = /\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\//g;\n\nvar NEWLINE_REGEX = /\\n/g;\nvar WHITESPACE_REGEX = /^\\s*/;\n\n// declaration\nvar PROPERTY_REGEX = /^(\\*?[-#/*\\\\\\w]+(\\[[0-9a-z_-]+\\])?)\\s*/;\nvar COLON_REGEX = /^:\\s*/;\nvar VALUE_REGEX = /^((?:'(?:\\\\'|.)*?'|\"(?:\\\\\"|.)*?\"|\\([^)]*?\\)|[^};])+)/;\nvar SEMICOLON_REGEX = /^[;\\s]*/;\n\n// https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String/Trim#Polyfill\nvar TRIM_REGEX = /^\\s+|\\s+$/g;\n\n// strings\nvar NEWLINE = '\\n';\nvar FORWARD_SLASH = '/';\nvar ASTERISK = '*';\nvar EMPTY_STRING = '';\n\n// types\nvar TYPE_COMMENT = 'comment';\nvar TYPE_DECLARATION = 'declaration';\n\n/**\n * @param {String} style\n * @param {Object} [options]\n * @return {Object[]}\n * @throws {TypeError}\n * @throws {Error}\n */\nfunction index (style, options) {\n if (typeof style !== 'string') {\n throw new TypeError('First argument must be a string');\n }\n\n if (!style) return [];\n\n options = options || {};\n\n /**\n * Positional.\n */\n var lineno = 1;\n var column = 1;\n\n /**\n * Update lineno and column based on `str`.\n *\n * @param {String} str\n */\n function updatePosition(str) {\n var lines = str.match(NEWLINE_REGEX);\n if (lines) lineno += lines.length;\n var i = str.lastIndexOf(NEWLINE);\n column = ~i ? str.length - i : column + str.length;\n }\n\n /**\n * Mark position and patch `node.position`.\n *\n * @return {Function}\n */\n function position() {\n var start = { line: lineno, column: column };\n return function (node) {\n node.position = new Position(start);\n whitespace();\n return node;\n };\n }\n\n /**\n * Store position information for a node.\n *\n * @constructor\n * @property {Object} start\n * @property {Object} end\n * @property {undefined|String} source\n */\n function Position(start) {\n this.start = start;\n this.end = { line: lineno, column: column };\n this.source = options.source;\n }\n\n /**\n * Non-enumerable source string.\n */\n Position.prototype.content = style;\n\n /**\n * Error `msg`.\n *\n * @param {String} msg\n * @throws {Error}\n */\n function error(msg) {\n var err = new Error(\n options.source + ':' + lineno + ':' + column + ': ' + msg\n );\n err.reason = msg;\n err.filename = options.source;\n err.line = lineno;\n err.column = column;\n err.source = style;\n\n if (options.silent) ; else {\n throw err;\n }\n }\n\n /**\n * Match `re` and return captures.\n *\n * @param {RegExp} re\n * @return {undefined|Array}\n */\n function match(re) {\n var m = re.exec(style);\n if (!m) return;\n var str = m[0];\n updatePosition(str);\n style = style.slice(str.length);\n return m;\n }\n\n /**\n * Parse whitespace.\n */\n function whitespace() {\n match(WHITESPACE_REGEX);\n }\n\n /**\n * Parse comments.\n *\n * @param {Object[]} [rules]\n * @return {Object[]}\n */\n function comments(rules) {\n var c;\n rules = rules || [];\n while ((c = comment())) {\n if (c !== false) {\n rules.push(c);\n }\n }\n return rules;\n }\n\n /**\n * Parse comment.\n *\n * @return {Object}\n * @throws {Error}\n */\n function comment() {\n var pos = position();\n if (FORWARD_SLASH != style.charAt(0) || ASTERISK != style.charAt(1)) return;\n\n var i = 2;\n while (\n EMPTY_STRING != style.charAt(i) &&\n (ASTERISK != style.charAt(i) || FORWARD_SLASH != style.charAt(i + 1))\n ) {\n ++i;\n }\n i += 2;\n\n if (EMPTY_STRING === style.charAt(i - 1)) {\n return error('End of comment missing');\n }\n\n var str = style.slice(2, i - 2);\n column += 2;\n updatePosition(str);\n style = style.slice(i);\n column += 2;\n\n return pos({\n type: TYPE_COMMENT,\n comment: str\n });\n }\n\n /**\n * Parse declaration.\n *\n * @return {Object}\n * @throws {Error}\n */\n function declaration() {\n var pos = position();\n\n // prop\n var prop = match(PROPERTY_REGEX);\n if (!prop) return;\n comment();\n\n // :\n if (!match(COLON_REGEX)) return error(\"property missing ':'\");\n\n // val\n var val = match(VALUE_REGEX);\n\n var ret = pos({\n type: TYPE_DECLARATION,\n property: trim(prop[0].replace(COMMENT_REGEX, EMPTY_STRING)),\n value: val\n ? trim(val[0].replace(COMMENT_REGEX, EMPTY_STRING))\n : EMPTY_STRING\n });\n\n // ;\n match(SEMICOLON_REGEX);\n\n return ret;\n }\n\n /**\n * Parse declarations.\n *\n * @return {Object[]}\n */\n function declarations() {\n var decls = [];\n\n comments(decls);\n\n // declarations\n var decl;\n while ((decl = declaration())) {\n if (decl !== false) {\n decls.push(decl);\n comments(decls);\n }\n }\n\n return decls;\n }\n\n whitespace();\n return declarations();\n}\n\n/**\n * Trim `str`.\n *\n * @param {String} str\n * @return {String}\n */\nfunction trim(str) {\n return str ? str.replace(TRIM_REGEX, EMPTY_STRING) : EMPTY_STRING;\n}\n\nmodule.exports = index;\n//# sourceMappingURL=index.js.map\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.default = StyleToObject;\nconst inline_style_parser_1 = __importDefault(require(\"inline-style-parser\"));\n/**\n * Parses inline style to object.\n *\n * @param style - Inline style.\n * @param iterator - Iterator.\n * @returns - Style object or null.\n *\n * @example Parsing inline style to object:\n *\n * ```js\n * import parse from 'style-to-object';\n * parse('line-height: 42;'); // { 'line-height': '42' }\n * ```\n */\nfunction StyleToObject(style, iterator) {\n let styleObject = null;\n if (!style || typeof style !== 'string') {\n return styleObject;\n }\n const declarations = (0, inline_style_parser_1.default)(style);\n const hasIterator = typeof iterator === 'function';\n declarations.forEach((declaration) => {\n if (declaration.type !== 'declaration') {\n return;\n }\n const { property, value } = declaration;\n if (hasIterator) {\n iterator(property, value, declaration);\n }\n else if (value) {\n styleObject = styleObject || {};\n styleObject[property] = value;\n }\n });\n return styleObject;\n}\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.camelCase = void 0;\nvar CUSTOM_PROPERTY_REGEX = /^--[a-zA-Z0-9_-]+$/;\nvar HYPHEN_REGEX = /-([a-z])/g;\nvar NO_HYPHEN_REGEX = /^[^-]+$/;\nvar VENDOR_PREFIX_REGEX = /^-(webkit|moz|ms|o|khtml)-/;\nvar MS_VENDOR_PREFIX_REGEX = /^-(ms)-/;\n/**\n * Checks whether to skip camelCase.\n */\nvar skipCamelCase = function (property) {\n return !property ||\n NO_HYPHEN_REGEX.test(property) ||\n CUSTOM_PROPERTY_REGEX.test(property);\n};\n/**\n * Replacer that capitalizes first character.\n */\nvar capitalize = function (match, character) {\n return character.toUpperCase();\n};\n/**\n * Replacer that removes beginning hyphen of vendor prefix property.\n */\nvar trimHyphen = function (match, prefix) { return \"\".concat(prefix, \"-\"); };\n/**\n * CamelCases a CSS property.\n */\nvar camelCase = function (property, options) {\n if (options === void 0) { options = {}; }\n if (skipCamelCase(property)) {\n return property;\n }\n property = property.toLowerCase();\n if (options.reactCompat) {\n // `-ms` vendor prefix should not be capitalized\n property = property.replace(MS_VENDOR_PREFIX_REGEX, trimHyphen);\n }\n else {\n // for non-React, remove first hyphen so vendor prefix is not capitalized\n property = property.replace(VENDOR_PREFIX_REGEX, trimHyphen);\n }\n return property.replace(HYPHEN_REGEX, capitalize);\n};\nexports.camelCase = camelCase;\n//# sourceMappingURL=utilities.js.map","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nvar style_to_object_1 = __importDefault(require(\"style-to-object\"));\nvar utilities_1 = require(\"./utilities\");\n/**\n * Parses CSS inline style to JavaScript object (camelCased).\n */\nfunction StyleToJS(style, options) {\n var output = {};\n if (!style || typeof style !== 'string') {\n return output;\n }\n (0, style_to_object_1.default)(style, function (property, value) {\n // skip CSS comment\n if (property && value) {\n output[(0, utilities_1.camelCase)(property, options)] = value;\n }\n });\n return output;\n}\nStyleToJS.default = StyleToJS;\nmodule.exports = StyleToJS;\n//# sourceMappingURL=index.js.map","/**\n * @typedef {import('unist').Node} Node\n * @typedef {import('unist').Point} Point\n * @typedef {import('unist').Position} Position\n */\n\n/**\n * @typedef NodeLike\n * @property {string} type\n * @property {PositionLike | null | undefined} [position]\n *\n * @typedef PositionLike\n * @property {PointLike | null | undefined} [start]\n * @property {PointLike | null | undefined} [end]\n *\n * @typedef PointLike\n * @property {number | null | undefined} [line]\n * @property {number | null | undefined} [column]\n * @property {number | null | undefined} [offset]\n */\n\n/**\n * Get the ending point of `node`.\n *\n * @param node\n * Node.\n * @returns\n * Point.\n */\nexport const pointEnd = point('end')\n\n/**\n * Get the starting point of `node`.\n *\n * @param node\n * Node.\n * @returns\n * Point.\n */\nexport const pointStart = point('start')\n\n/**\n * Get the positional info of `node`.\n *\n * @param {'end' | 'start'} type\n * Side.\n * @returns\n * Getter.\n */\nfunction point(type) {\n return point\n\n /**\n * Get the point info of `node` at a bound side.\n *\n * @param {Node | NodeLike | null | undefined} [node]\n * @returns {Point | undefined}\n */\n function point(node) {\n const point = (node && node.position && node.position[type]) || {}\n\n if (\n typeof point.line === 'number' &&\n point.line > 0 &&\n typeof point.column === 'number' &&\n point.column > 0\n ) {\n return {\n line: point.line,\n column: point.column,\n offset:\n typeof point.offset === 'number' && point.offset > -1\n ? point.offset\n : undefined\n }\n }\n }\n}\n\n/**\n * Get the positional info of `node`.\n *\n * @param {Node | NodeLike | null | undefined} [node]\n * Node.\n * @returns {Position | undefined}\n * Position.\n */\nexport function position(node) {\n const start = pointStart(node)\n const end = pointEnd(node)\n\n if (start && end) {\n return {start, end}\n }\n}\n","/**\n * @typedef {import('unist').Node} Node\n * @typedef {import('unist').Point} Point\n * @typedef {import('unist').Position} Position\n */\n\n/**\n * @typedef NodeLike\n * @property {string} type\n * @property {PositionLike | null | undefined} [position]\n *\n * @typedef PointLike\n * @property {number | null | undefined} [line]\n * @property {number | null | undefined} [column]\n * @property {number | null | undefined} [offset]\n *\n * @typedef PositionLike\n * @property {PointLike | null | undefined} [start]\n * @property {PointLike | null | undefined} [end]\n */\n\n/**\n * Serialize the positional info of a point, position (start and end points),\n * or node.\n *\n * @param {Node | NodeLike | Point | PointLike | Position | PositionLike | null | undefined} [value]\n * Node, position, or point.\n * @returns {string}\n * Pretty printed positional info of a node (`string`).\n *\n * In the format of a range `ls:cs-le:ce` (when given `node` or `position`)\n * or a point `l:c` (when given `point`), where `l` stands for line, `c` for\n * column, `s` for `start`, and `e` for end.\n * An empty string (`''`) is returned if the given value is neither `node`,\n * `position`, nor `point`.\n */\nexport function stringifyPosition(value) {\n // Nothing.\n if (!value || typeof value !== 'object') {\n return ''\n }\n\n // Node.\n if ('position' in value || 'type' in value) {\n return position(value.position)\n }\n\n // Position.\n if ('start' in value || 'end' in value) {\n return position(value)\n }\n\n // Point.\n if ('line' in value || 'column' in value) {\n return point(value)\n }\n\n // ?\n return ''\n}\n\n/**\n * @param {Point | PointLike | null | undefined} point\n * @returns {string}\n */\nfunction point(point) {\n return index(point && point.line) + ':' + index(point && point.column)\n}\n\n/**\n * @param {Position | PositionLike | null | undefined} pos\n * @returns {string}\n */\nfunction position(pos) {\n return point(pos && pos.start) + '-' + point(pos && pos.end)\n}\n\n/**\n * @param {number | null | undefined} value\n * @returns {number}\n */\nfunction index(value) {\n return value && typeof value === 'number' ? value : 1\n}\n","/**\n * @import {Node, Point, Position} from 'unist'\n */\n\n/**\n * @typedef {object & {type: string, position?: Position | undefined}} NodeLike\n *\n * @typedef Options\n * Configuration.\n * @property {Array<Node> | null | undefined} [ancestors]\n * Stack of (inclusive) ancestor nodes surrounding the message (optional).\n * @property {Error | null | undefined} [cause]\n * Original error cause of the message (optional).\n * @property {Point | Position | null | undefined} [place]\n * Place of message (optional).\n * @property {string | null | undefined} [ruleId]\n * Category of message (optional, example: `'my-rule'`).\n * @property {string | null | undefined} [source]\n * Namespace of who sent the message (optional, example: `'my-package'`).\n */\n\nimport {stringifyPosition} from 'unist-util-stringify-position'\n\n/**\n * Message.\n */\nexport class VFileMessage extends Error {\n /**\n * Create a message for `reason`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {Options | null | undefined} [options]\n * @returns\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | Options | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns\n * Instance of `VFileMessage`.\n */\n // eslint-disable-next-line complexity\n constructor(causeOrReason, optionsOrParentOrPlace, origin) {\n super()\n\n if (typeof optionsOrParentOrPlace === 'string') {\n origin = optionsOrParentOrPlace\n optionsOrParentOrPlace = undefined\n }\n\n /** @type {string} */\n let reason = ''\n /** @type {Options} */\n let options = {}\n let legacyCause = false\n\n if (optionsOrParentOrPlace) {\n // Point.\n if (\n 'line' in optionsOrParentOrPlace &&\n 'column' in optionsOrParentOrPlace\n ) {\n options = {place: optionsOrParentOrPlace}\n }\n // Position.\n else if (\n 'start' in optionsOrParentOrPlace &&\n 'end' in optionsOrParentOrPlace\n ) {\n options = {place: optionsOrParentOrPlace}\n }\n // Node.\n else if ('type' in optionsOrParentOrPlace) {\n options = {\n ancestors: [optionsOrParentOrPlace],\n place: optionsOrParentOrPlace.position\n }\n }\n // Options.\n else {\n options = {...optionsOrParentOrPlace}\n }\n }\n\n if (typeof causeOrReason === 'string') {\n reason = causeOrReason\n }\n // Error.\n else if (!options.cause && causeOrReason) {\n legacyCause = true\n reason = causeOrReason.message\n options.cause = causeOrReason\n }\n\n if (!options.ruleId && !options.source && typeof origin === 'string') {\n const index = origin.indexOf(':')\n\n if (index === -1) {\n options.ruleId = origin\n } else {\n options.source = origin.slice(0, index)\n options.ruleId = origin.slice(index + 1)\n }\n }\n\n if (!options.place && options.ancestors && options.ancestors) {\n const parent = options.ancestors[options.ancestors.length - 1]\n\n if (parent) {\n options.place = parent.position\n }\n }\n\n const start =\n options.place && 'start' in options.place\n ? options.place.start\n : options.place\n\n /**\n * Stack of ancestor nodes surrounding the message.\n *\n * @type {Array<Node> | undefined}\n */\n this.ancestors = options.ancestors || undefined\n\n /**\n * Original error cause of the message.\n *\n * @type {Error | undefined}\n */\n this.cause = options.cause || undefined\n\n /**\n * Starting column of message.\n *\n * @type {number | undefined}\n */\n this.column = start ? start.column : undefined\n\n /**\n * State of problem.\n *\n * * `true` — error, file not usable\n * * `false` — warning, change may be needed\n * * `undefined` — change likely not needed\n *\n * @type {boolean | null | undefined}\n */\n this.fatal = undefined\n\n /**\n * Path of a file (used throughout the `VFile` ecosystem).\n *\n * @type {string | undefined}\n */\n this.file = ''\n\n // Field from `Error`.\n /**\n * Reason for message.\n *\n * @type {string}\n */\n this.message = reason\n\n /**\n * Starting line of error.\n *\n * @type {number | undefined}\n */\n this.line = start ? start.line : undefined\n\n // Field from `Error`.\n /**\n * Serialized positional info of message.\n *\n * On normal errors, this would be something like `ParseError`, buit in\n * `VFile` messages we use this space to show where an error happened.\n */\n this.name = stringifyPosition(options.place) || '1:1'\n\n /**\n * Place of message.\n *\n * @type {Point | Position | undefined}\n */\n this.place = options.place || undefined\n\n /**\n * Reason for message, should use markdown.\n *\n * @type {string}\n */\n this.reason = this.message\n\n /**\n * Category of message (example: `'my-rule'`).\n *\n * @type {string | undefined}\n */\n this.ruleId = options.ruleId || undefined\n\n /**\n * Namespace of message (example: `'my-package'`).\n *\n * @type {string | undefined}\n */\n this.source = options.source || undefined\n\n // Field from `Error`.\n /**\n * Stack of message.\n *\n * This is used by normal errors to show where something happened in\n * programming code, irrelevant for `VFile` messages,\n *\n * @type {string}\n */\n this.stack =\n legacyCause && options.cause && typeof options.cause.stack === 'string'\n ? options.cause.stack\n : ''\n\n // The following fields are “well known”.\n // Not standard.\n // Feel free to add other non-standard fields to your messages.\n\n /**\n * Specify the source value that’s being reported, which is deemed\n * incorrect.\n *\n * @type {string | undefined}\n */\n this.actual = undefined\n\n /**\n * Suggest acceptable values that can be used instead of `actual`.\n *\n * @type {Array<string> | undefined}\n */\n this.expected = undefined\n\n /**\n * Long form description of the message (you should use markdown).\n *\n * @type {string | undefined}\n */\n this.note = undefined\n\n /**\n * Link to docs for the message.\n *\n * > 👉 **Note**: this must be an absolute URL that can be passed as `x`\n * > to `new URL(x)`.\n *\n * @type {string | undefined}\n */\n this.url = undefined\n }\n}\n\nVFileMessage.prototype.file = ''\nVFileMessage.prototype.name = ''\nVFileMessage.prototype.reason = ''\nVFileMessage.prototype.message = ''\nVFileMessage.prototype.stack = ''\nVFileMessage.prototype.column = undefined\nVFileMessage.prototype.line = undefined\nVFileMessage.prototype.ancestors = undefined\nVFileMessage.prototype.cause = undefined\nVFileMessage.prototype.fatal = undefined\nVFileMessage.prototype.place = undefined\nVFileMessage.prototype.ruleId = undefined\nVFileMessage.prototype.source = undefined\n","/**\n * @import {Identifier, Literal, MemberExpression} from 'estree'\n * @import {Jsx, JsxDev, Options, Props} from 'hast-util-to-jsx-runtime'\n * @import {Element, Nodes, Parents, Root, Text} from 'hast'\n * @import {MdxFlowExpressionHast, MdxTextExpressionHast} from 'mdast-util-mdx-expression'\n * @import {MdxJsxFlowElementHast, MdxJsxTextElementHast} from 'mdast-util-mdx-jsx'\n * @import {MdxjsEsmHast} from 'mdast-util-mdxjs-esm'\n * @import {Position} from 'unist'\n * @import {Child, Create, Field, JsxElement, State, Style} from './types.js'\n */\n\nimport {stringify as commas} from 'comma-separated-tokens'\nimport {ok as assert} from 'devlop'\nimport {name as isIdentifierName} from 'estree-util-is-identifier-name'\nimport {whitespace} from 'hast-util-whitespace'\nimport {find, hastToReact, html, svg} from 'property-information'\nimport {stringify as spaces} from 'space-separated-tokens'\nimport styleToJs from 'style-to-js'\nimport {pointStart} from 'unist-util-position'\nimport {VFileMessage} from 'vfile-message'\n\n// To do: next major: `Object.hasOwn`.\nconst own = {}.hasOwnProperty\n\n/** @type {Map<string, number>} */\nconst emptyMap = new Map()\n\nconst cap = /[A-Z]/g\n\n// `react-dom` triggers a warning for *any* white space in tables.\n// To follow GFM, `mdast-util-to-hast` injects line endings between elements.\n// Other tools might do so too, but they don’t do here, so we remove all of\n// that.\n\n// See: <https://github.com/facebook/react/pull/7081>.\n// See: <https://github.com/facebook/react/pull/7515>.\n// See: <https://github.com/remarkjs/remark-react/issues/64>.\n// See: <https://github.com/rehypejs/rehype-react/pull/29>.\n// See: <https://github.com/rehypejs/rehype-react/pull/32>.\n// See: <https://github.com/rehypejs/rehype-react/pull/45>.\nconst tableElements = new Set(['table', 'tbody', 'thead', 'tfoot', 'tr'])\n\nconst tableCellElement = new Set(['td', 'th'])\n\nconst docs = 'https://github.com/syntax-tree/hast-util-to-jsx-runtime'\n\n/**\n * Transform a hast tree to preact, react, solid, svelte, vue, etc.,\n * with an automatic JSX runtime.\n *\n * @param {Nodes} tree\n * Tree to transform.\n * @param {Options} options\n * Configuration (required).\n * @returns {JsxElement}\n * JSX element.\n */\n\nexport function toJsxRuntime(tree, options) {\n if (!options || options.Fragment === undefined) {\n throw new TypeError('Expected `Fragment` in options')\n }\n\n const filePath = options.filePath || undefined\n /** @type {Create} */\n let create\n\n if (options.development) {\n if (typeof options.jsxDEV !== 'function') {\n throw new TypeError(\n 'Expected `jsxDEV` in options when `development: true`'\n )\n }\n\n create = developmentCreate(filePath, options.jsxDEV)\n } else {\n if (typeof options.jsx !== 'function') {\n throw new TypeError('Expected `jsx` in production options')\n }\n\n if (typeof options.jsxs !== 'function') {\n throw new TypeError('Expected `jsxs` in production options')\n }\n\n create = productionCreate(filePath, options.jsx, options.jsxs)\n }\n\n /** @type {State} */\n const state = {\n Fragment: options.Fragment,\n ancestors: [],\n components: options.components || {},\n create,\n elementAttributeNameCase: options.elementAttributeNameCase || 'react',\n evaluater: options.createEvaluater ? options.createEvaluater() : undefined,\n filePath,\n ignoreInvalidStyle: options.ignoreInvalidStyle || false,\n passKeys: options.passKeys !== false,\n passNode: options.passNode || false,\n schema: options.space === 'svg' ? svg : html,\n stylePropertyNameCase: options.stylePropertyNameCase || 'dom',\n tableCellAlignToStyle: options.tableCellAlignToStyle !== false\n }\n\n const result = one(state, tree, undefined)\n\n // JSX element.\n if (result && typeof result !== 'string') {\n return result\n }\n\n // Text node or something that turned into nothing.\n return state.create(\n tree,\n state.Fragment,\n {children: result || undefined},\n undefined\n )\n}\n\n/**\n * Transform a node.\n *\n * @param {State} state\n * Info passed around.\n * @param {Nodes} node\n * Current node.\n * @param {string | undefined} key\n * Key.\n * @returns {Child | undefined}\n * Child, optional.\n */\nfunction one(state, node, key) {\n if (node.type === 'element') {\n return element(state, node, key)\n }\n\n if (node.type === 'mdxFlowExpression' || node.type === 'mdxTextExpression') {\n return mdxExpression(state, node)\n }\n\n if (node.type === 'mdxJsxFlowElement' || node.type === 'mdxJsxTextElement') {\n return mdxJsxElement(state, node, key)\n }\n\n if (node.type === 'mdxjsEsm') {\n return mdxEsm(state, node)\n }\n\n if (node.type === 'root') {\n return root(state, node, key)\n }\n\n if (node.type === 'text') {\n return text(state, node)\n }\n}\n\n/**\n * Handle element.\n *\n * @param {State} state\n * Info passed around.\n * @param {Element} node\n * Current node.\n * @param {string | undefined} key\n * Key.\n * @returns {Child | undefined}\n * Child, optional.\n */\nfunction element(state, node, key) {\n const parentSchema = state.schema\n let schema = parentSchema\n\n if (node.tagName.toLowerCase() === 'svg' && parentSchema.space === 'html') {\n schema = svg\n state.schema = schema\n }\n\n state.ancestors.push(node)\n\n const type = findComponentFromName(state, node.tagName, false)\n const props = createElementProps(state, node)\n let children = createChildren(state, node)\n\n if (tableElements.has(node.tagName)) {\n children = children.filter(function (child) {\n return typeof child === 'string' ? !whitespace(child) : true\n })\n }\n\n addNode(state, props, type, node)\n addChildren(props, children)\n\n // Restore.\n state.ancestors.pop()\n state.schema = parentSchema\n\n return state.create(node, type, props, key)\n}\n\n/**\n * Handle MDX expression.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdxFlowExpressionHast | MdxTextExpressionHast} node\n * Current node.\n * @returns {Child | undefined}\n * Child, optional.\n */\nfunction mdxExpression(state, node) {\n if (node.data && node.data.estree && state.evaluater) {\n const program = node.data.estree\n const expression = program.body[0]\n assert(expression.type === 'ExpressionStatement')\n\n // Assume result is a child.\n return /** @type {Child | undefined} */ (\n state.evaluater.evaluateExpression(expression.expression)\n )\n }\n\n crashEstree(state, node.position)\n}\n\n/**\n * Handle MDX ESM.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdxjsEsmHast} node\n * Current node.\n * @returns {Child | undefined}\n * Child, optional.\n */\nfunction mdxEsm(state, node) {\n if (node.data && node.data.estree && state.evaluater) {\n // Assume result is a child.\n return /** @type {Child | undefined} */ (\n state.evaluater.evaluateProgram(node.data.estree)\n )\n }\n\n crashEstree(state, node.position)\n}\n\n/**\n * Handle MDX JSX.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdxJsxFlowElementHast | MdxJsxTextElementHast} node\n * Current node.\n * @param {string | undefined} key\n * Key.\n * @returns {Child | undefined}\n * Child, optional.\n */\nfunction mdxJsxElement(state, node, key) {\n const parentSchema = state.schema\n let schema = parentSchema\n\n if (node.name === 'svg' && parentSchema.space === 'html') {\n schema = svg\n state.schema = schema\n }\n\n state.ancestors.push(node)\n\n const type =\n node.name === null\n ? state.Fragment\n : findComponentFromName(state, node.name, true)\n const props = createJsxElementProps(state, node)\n const children = createChildren(state, node)\n\n addNode(state, props, type, node)\n addChildren(props, children)\n\n // Restore.\n state.ancestors.pop()\n state.schema = parentSchema\n\n return state.create(node, type, props, key)\n}\n\n/**\n * Handle root.\n *\n * @param {State} state\n * Info passed around.\n * @param {Root} node\n * Current node.\n * @param {string | undefined} key\n * Key.\n * @returns {Child | undefined}\n * Child, optional.\n */\nfunction root(state, node, key) {\n /** @type {Props} */\n const props = {}\n\n addChildren(props, createChildren(state, node))\n\n return state.create(node, state.Fragment, props, key)\n}\n\n/**\n * Handle text.\n *\n * @param {State} _\n * Info passed around.\n * @param {Text} node\n * Current node.\n * @returns {Child | undefined}\n * Child, optional.\n */\nfunction text(_, node) {\n return node.value\n}\n\n/**\n * Add `node` to props.\n *\n * @param {State} state\n * Info passed around.\n * @param {Props} props\n * Props.\n * @param {unknown} type\n * Type.\n * @param {Element | MdxJsxFlowElementHast | MdxJsxTextElementHast} node\n * Node.\n * @returns {undefined}\n * Nothing.\n */\nfunction addNode(state, props, type, node) {\n // If this is swapped out for a component:\n if (typeof type !== 'string' && type !== state.Fragment && state.passNode) {\n props.node = node\n }\n}\n\n/**\n * Add children to props.\n *\n * @param {Props} props\n * Props.\n * @param {Array<Child>} children\n * Children.\n * @returns {undefined}\n * Nothing.\n */\nfunction addChildren(props, children) {\n if (children.length > 0) {\n const value = children.length > 1 ? children : children[0]\n\n if (value) {\n props.children = value\n }\n }\n}\n\n/**\n * @param {string | undefined} _\n * Path to file.\n * @param {Jsx} jsx\n * Dynamic.\n * @param {Jsx} jsxs\n * Static.\n * @returns {Create}\n * Create a production element.\n */\nfunction productionCreate(_, jsx, jsxs) {\n return create\n /** @type {Create} */\n function create(_, type, props, key) {\n // Only an array when there are 2 or more children.\n const isStaticChildren = Array.isArray(props.children)\n const fn = isStaticChildren ? jsxs : jsx\n return key ? fn(type, props, key) : fn(type, props)\n }\n}\n\n/**\n * @param {string | undefined} filePath\n * Path to file.\n * @param {JsxDev} jsxDEV\n * Development.\n * @returns {Create}\n * Create a development element.\n */\nfunction developmentCreate(filePath, jsxDEV) {\n return create\n /** @type {Create} */\n function create(node, type, props, key) {\n // Only an array when there are 2 or more children.\n const isStaticChildren = Array.isArray(props.children)\n const point = pointStart(node)\n return jsxDEV(\n type,\n props,\n key,\n isStaticChildren,\n {\n columnNumber: point ? point.column - 1 : undefined,\n fileName: filePath,\n lineNumber: point ? point.line : undefined\n },\n undefined\n )\n }\n}\n\n/**\n * Create props from an element.\n *\n * @param {State} state\n * Info passed around.\n * @param {Element} node\n * Current element.\n * @returns {Props}\n * Props.\n */\nfunction createElementProps(state, node) {\n /** @type {Props} */\n const props = {}\n /** @type {string | undefined} */\n let alignValue\n /** @type {string} */\n let prop\n\n for (prop in node.properties) {\n if (prop !== 'children' && own.call(node.properties, prop)) {\n const result = createProperty(state, prop, node.properties[prop])\n\n if (result) {\n const [key, value] = result\n\n if (\n state.tableCellAlignToStyle &&\n key === 'align' &&\n typeof value === 'string' &&\n tableCellElement.has(node.tagName)\n ) {\n alignValue = value\n } else {\n props[key] = value\n }\n }\n }\n }\n\n if (alignValue) {\n // Assume style is an object.\n const style = /** @type {Style} */ (props.style || (props.style = {}))\n style[state.stylePropertyNameCase === 'css' ? 'text-align' : 'textAlign'] =\n alignValue\n }\n\n return props\n}\n\n/**\n * Create props from a JSX element.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdxJsxFlowElementHast | MdxJsxTextElementHast} node\n * Current JSX element.\n * @returns {Props}\n * Props.\n */\nfunction createJsxElementProps(state, node) {\n /** @type {Props} */\n const props = {}\n\n for (const attribute of node.attributes) {\n if (attribute.type === 'mdxJsxExpressionAttribute') {\n if (attribute.data && attribute.data.estree && state.evaluater) {\n const program = attribute.data.estree\n const expression = program.body[0]\n assert(expression.type === 'ExpressionStatement')\n const objectExpression = expression.expression\n assert(objectExpression.type === 'ObjectExpression')\n const property = objectExpression.properties[0]\n assert(property.type === 'SpreadElement')\n\n Object.assign(\n props,\n state.evaluater.evaluateExpression(property.argument)\n )\n } else {\n crashEstree(state, node.position)\n }\n } else {\n // For JSX, the author is responsible of passing in the correct values.\n const name = attribute.name\n /** @type {unknown} */\n let value\n\n if (attribute.value && typeof attribute.value === 'object') {\n if (\n attribute.value.data &&\n attribute.value.data.estree &&\n state.evaluater\n ) {\n const program = attribute.value.data.estree\n const expression = program.body[0]\n assert(expression.type === 'ExpressionStatement')\n value = state.evaluater.evaluateExpression(expression.expression)\n } else {\n crashEstree(state, node.position)\n }\n } else {\n value = attribute.value === null ? true : attribute.value\n }\n\n // Assume a prop.\n props[name] = /** @type {Props[keyof Props]} */ (value)\n }\n }\n\n return props\n}\n\n/**\n * Create children.\n *\n * @param {State} state\n * Info passed around.\n * @param {Parents} node\n * Current element.\n * @returns {Array<Child>}\n * Children.\n */\nfunction createChildren(state, node) {\n /** @type {Array<Child>} */\n const children = []\n let index = -1\n /** @type {Map<string, number>} */\n // Note: test this when Solid doesn’t want to merge my upcoming PR.\n /* c8 ignore next */\n const countsByName = state.passKeys ? new Map() : emptyMap\n\n while (++index < node.children.length) {\n const child = node.children[index]\n /** @type {string | undefined} */\n let key\n\n if (state.passKeys) {\n const name =\n child.type === 'element'\n ? child.tagName\n : child.type === 'mdxJsxFlowElement' ||\n child.type === 'mdxJsxTextElement'\n ? child.name\n : undefined\n\n if (name) {\n const count = countsByName.get(name) || 0\n key = name + '-' + count\n countsByName.set(name, count + 1)\n }\n }\n\n const result = one(state, child, key)\n if (result !== undefined) children.push(result)\n }\n\n return children\n}\n\n/**\n * Handle a property.\n *\n * @param {State} state\n * Info passed around.\n * @param {string} prop\n * Key.\n * @param {Array<number | string> | boolean | number | string | null | undefined} value\n * hast property value.\n * @returns {Field | undefined}\n * Field for runtime, optional.\n */\nfunction createProperty(state, prop, value) {\n const info = find(state.schema, prop)\n\n // Ignore nullish and `NaN` values.\n if (\n value === null ||\n value === undefined ||\n (typeof value === 'number' && Number.isNaN(value))\n ) {\n return\n }\n\n if (Array.isArray(value)) {\n // Accept `array`.\n // Most props are space-separated.\n value = info.commaSeparated ? commas(value) : spaces(value)\n }\n\n // React only accepts `style` as object.\n if (info.property === 'style') {\n let styleObject =\n typeof value === 'object' ? value : parseStyle(state, String(value))\n\n if (state.stylePropertyNameCase === 'css') {\n styleObject = transformStylesToCssCasing(styleObject)\n }\n\n return ['style', styleObject]\n }\n\n return [\n state.elementAttributeNameCase === 'react' && info.space\n ? hastToReact[info.property] || info.property\n : info.attribute,\n value\n ]\n}\n\n/**\n * Parse a CSS declaration to an object.\n *\n * @param {State} state\n * Info passed around.\n * @param {string} value\n * CSS declarations.\n * @returns {Style}\n * Properties.\n * @throws\n * Throws `VFileMessage` when CSS cannot be parsed.\n */\nfunction parseStyle(state, value) {\n try {\n return styleToJs(value, {reactCompat: true})\n } catch (error) {\n if (state.ignoreInvalidStyle) {\n return {}\n }\n\n const cause = /** @type {Error} */ (error)\n const message = new VFileMessage('Cannot parse `style` attribute', {\n ancestors: state.ancestors,\n cause,\n ruleId: 'style',\n source: 'hast-util-to-jsx-runtime'\n })\n message.file = state.filePath || undefined\n message.url = docs + '#cannot-parse-style-attribute'\n\n throw message\n }\n}\n\n/**\n * Create a JSX name from a string.\n *\n * @param {State} state\n * To do.\n * @param {string} name\n * Name.\n * @param {boolean} allowExpression\n * Allow member expressions and identifiers.\n * @returns {unknown}\n * To do.\n */\nfunction findComponentFromName(state, name, allowExpression) {\n /** @type {Identifier | Literal | MemberExpression} */\n let result\n\n if (!allowExpression) {\n result = {type: 'Literal', value: name}\n } else if (name.includes('.')) {\n const identifiers = name.split('.')\n let index = -1\n /** @type {Identifier | Literal | MemberExpression | undefined} */\n let node\n\n while (++index < identifiers.length) {\n /** @type {Identifier | Literal} */\n const prop = isIdentifierName(identifiers[index])\n ? {type: 'Identifier', name: identifiers[index]}\n : {type: 'Literal', value: identifiers[index]}\n node = node\n ? {\n type: 'MemberExpression',\n object: node,\n property: prop,\n computed: Boolean(index && prop.type === 'Literal'),\n optional: false\n }\n : prop\n }\n\n assert(node, 'always a result')\n result = node\n } else {\n result =\n isIdentifierName(name) && !/^[a-z]/.test(name)\n ? {type: 'Identifier', name}\n : {type: 'Literal', value: name}\n }\n\n // Only literals can be passed in `components` currently.\n // No identifiers / member expressions.\n if (result.type === 'Literal') {\n const name = /** @type {string | number} */ (result.value)\n return own.call(state.components, name) ? state.components[name] : name\n }\n\n // Assume component.\n if (state.evaluater) {\n return state.evaluater.evaluateExpression(result)\n }\n\n crashEstree(state)\n}\n\n/**\n * @param {State} state\n * @param {Position | undefined} [place]\n * @returns {never}\n */\nfunction crashEstree(state, place) {\n const message = new VFileMessage(\n 'Cannot handle MDX estrees without `createEvaluater`',\n {\n ancestors: state.ancestors,\n place,\n ruleId: 'mdx-estree',\n source: 'hast-util-to-jsx-runtime'\n }\n )\n message.file = state.filePath || undefined\n message.url = docs + '#cannot-handle-mdx-estrees-without-createevaluater'\n\n throw message\n}\n\n/**\n * Transform a DOM casing style object to a CSS casing style object.\n *\n * @param {Style} domCasing\n * @returns {Style}\n */\nfunction transformStylesToCssCasing(domCasing) {\n /** @type {Style} */\n const cssCasing = {}\n /** @type {string} */\n let from\n\n for (from in domCasing) {\n if (own.call(domCasing, from)) {\n cssCasing[transformStyleToCssCasing(from)] = domCasing[from]\n }\n }\n\n return cssCasing\n}\n\n/**\n * Transform a DOM casing style field to a CSS casing style field.\n *\n * @param {string} from\n * @returns {string}\n */\nfunction transformStyleToCssCasing(from) {\n let to = from.replace(cap, toDash)\n // Handle `ms-xxx` -> `-ms-xxx`.\n if (to.slice(0, 3) === 'ms-') to = '-' + to\n return to\n}\n\n/**\n * Make `$0` dash cased.\n *\n * @param {string} $0\n * Capitalized ASCII leter.\n * @returns {string}\n * Dash and lower letter.\n */\nfunction toDash($0) {\n return '-' + $0.toLowerCase()\n}\n","/**\n * HTML URL properties.\n *\n * Each key is a property name and each value is a list of tag names it applies\n * to or `null` if it applies to all elements.\n *\n * @type {Record<string, Array<string> | null>}\n */\nexport const urlAttributes = {\n action: ['form'],\n cite: ['blockquote', 'del', 'ins', 'q'],\n data: ['object'],\n formAction: ['button', 'input'],\n href: ['a', 'area', 'base', 'link'],\n icon: ['menuitem'],\n itemId: null,\n manifest: ['html'],\n ping: ['a', 'area'],\n poster: ['video'],\n src: [\n 'audio',\n 'embed',\n 'iframe',\n 'img',\n 'input',\n 'script',\n 'source',\n 'track',\n 'video'\n ]\n}\n","/**\n * @typedef {import('mdast').Nodes} Nodes\n *\n * @typedef Options\n * Configuration (optional).\n * @property {boolean | null | undefined} [includeImageAlt=true]\n * Whether to use `alt` for `image`s (default: `true`).\n * @property {boolean | null | undefined} [includeHtml=true]\n * Whether to use `value` of HTML (default: `true`).\n */\n\n/** @type {Options} */\nconst emptyOptions = {}\n\n/**\n * Get the text content of a node or list of nodes.\n *\n * Prefers the node’s plain-text fields, otherwise serializes its children,\n * and if the given value is an array, serialize the nodes in it.\n *\n * @param {unknown} [value]\n * Thing to serialize, typically `Node`.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {string}\n * Serialized `value`.\n */\nexport function toString(value, options) {\n const settings = options || emptyOptions\n const includeImageAlt =\n typeof settings.includeImageAlt === 'boolean'\n ? settings.includeImageAlt\n : true\n const includeHtml =\n typeof settings.includeHtml === 'boolean' ? settings.includeHtml : true\n\n return one(value, includeImageAlt, includeHtml)\n}\n\n/**\n * One node or several nodes.\n *\n * @param {unknown} value\n * Thing to serialize.\n * @param {boolean} includeImageAlt\n * Include image `alt`s.\n * @param {boolean} includeHtml\n * Include HTML.\n * @returns {string}\n * Serialized node.\n */\nfunction one(value, includeImageAlt, includeHtml) {\n if (node(value)) {\n if ('value' in value) {\n return value.type === 'html' && !includeHtml ? '' : value.value\n }\n\n if (includeImageAlt && 'alt' in value && value.alt) {\n return value.alt\n }\n\n if ('children' in value) {\n return all(value.children, includeImageAlt, includeHtml)\n }\n }\n\n if (Array.isArray(value)) {\n return all(value, includeImageAlt, includeHtml)\n }\n\n return ''\n}\n\n/**\n * Serialize a list of nodes.\n *\n * @param {Array<unknown>} values\n * Thing to serialize.\n * @param {boolean} includeImageAlt\n * Include image `alt`s.\n * @param {boolean} includeHtml\n * Include HTML.\n * @returns {string}\n * Serialized nodes.\n */\nfunction all(values, includeImageAlt, includeHtml) {\n /** @type {Array<string>} */\n const result = []\n let index = -1\n\n while (++index < values.length) {\n result[index] = one(values[index], includeImageAlt, includeHtml)\n }\n\n return result.join('')\n}\n\n/**\n * Check if `value` looks like a node.\n *\n * @param {unknown} value\n * Thing.\n * @returns {value is Nodes}\n * Whether `value` is a node.\n */\nfunction node(value) {\n return Boolean(value && typeof value === 'object')\n}\n","/**\n * Like `Array#splice`, but smarter for giant arrays.\n *\n * `Array#splice` takes all items to be inserted as individual argument which\n * causes a stack overflow in V8 when trying to insert 100k items for instance.\n *\n * Otherwise, this does not return the removed items, and takes `items` as an\n * array instead of rest parameters.\n *\n * @template {unknown} T\n * Item type.\n * @param {Array<T>} list\n * List to operate on.\n * @param {number} start\n * Index to remove/insert at (can be negative).\n * @param {number} remove\n * Number of items to remove.\n * @param {Array<T>} items\n * Items to inject into `list`.\n * @returns {undefined}\n * Nothing.\n */\nexport function splice(list, start, remove, items) {\n const end = list.length;\n let chunkStart = 0;\n /** @type {Array<unknown>} */\n let parameters;\n\n // Make start between zero and `end` (included).\n if (start < 0) {\n start = -start > end ? 0 : end + start;\n } else {\n start = start > end ? end : start;\n }\n remove = remove > 0 ? remove : 0;\n\n // No need to chunk the items if there’s only a couple (10k) items.\n if (items.length < 10000) {\n parameters = Array.from(items);\n parameters.unshift(start, remove);\n // @ts-expect-error Hush, it’s fine.\n list.splice(...parameters);\n } else {\n // Delete `remove` items starting from `start`\n if (remove) list.splice(start, remove);\n\n // Insert the items in chunks to not cause stack overflows.\n while (chunkStart < items.length) {\n parameters = items.slice(chunkStart, chunkStart + 10000);\n parameters.unshift(start, 0);\n // @ts-expect-error Hush, it’s fine.\n list.splice(...parameters);\n chunkStart += 10000;\n start += 10000;\n }\n }\n}\n\n/**\n * Append `items` (an array) at the end of `list` (another array).\n * When `list` was empty, returns `items` instead.\n *\n * This prevents a potentially expensive operation when `list` is empty,\n * and adds items in batches to prevent V8 from hanging.\n *\n * @template {unknown} T\n * Item type.\n * @param {Array<T>} list\n * List to operate on.\n * @param {Array<T>} items\n * Items to add to `list`.\n * @returns {Array<T>}\n * Either `list` or `items`.\n */\nexport function push(list, items) {\n if (list.length > 0) {\n splice(list, list.length, 0, items);\n return list;\n }\n return items;\n}","/**\n * @import {\n * Extension,\n * Handles,\n * HtmlExtension,\n * NormalizedExtension\n * } from 'micromark-util-types'\n */\n\nimport {splice} from 'micromark-util-chunked'\n\nconst hasOwnProperty = {}.hasOwnProperty\n\n/**\n * Combine multiple syntax extensions into one.\n *\n * @param {ReadonlyArray<Extension>} extensions\n * List of syntax extensions.\n * @returns {NormalizedExtension}\n * A single combined extension.\n */\nexport function combineExtensions(extensions) {\n /** @type {NormalizedExtension} */\n const all = {}\n let index = -1\n\n while (++index < extensions.length) {\n syntaxExtension(all, extensions[index])\n }\n\n return all\n}\n\n/**\n * Merge `extension` into `all`.\n *\n * @param {NormalizedExtension} all\n * Extension to merge into.\n * @param {Extension} extension\n * Extension to merge.\n * @returns {undefined}\n * Nothing.\n */\nfunction syntaxExtension(all, extension) {\n /** @type {keyof Extension} */\n let hook\n\n for (hook in extension) {\n const maybe = hasOwnProperty.call(all, hook) ? all[hook] : undefined\n /** @type {Record<string, unknown>} */\n const left = maybe || (all[hook] = {})\n /** @type {Record<string, unknown> | undefined} */\n const right = extension[hook]\n /** @type {string} */\n let code\n\n if (right) {\n for (code in right) {\n if (!hasOwnProperty.call(left, code)) left[code] = []\n const value = right[code]\n constructs(\n // @ts-expect-error Looks like a list.\n left[code],\n Array.isArray(value) ? value : value ? [value] : []\n )\n }\n }\n }\n}\n\n/**\n * Merge `list` into `existing` (both lists of constructs).\n * Mutates `existing`.\n *\n * @param {Array<unknown>} existing\n * List of constructs to merge into.\n * @param {Array<unknown>} list\n * List of constructs to merge.\n * @returns {undefined}\n * Nothing.\n */\nfunction constructs(existing, list) {\n let index = -1\n /** @type {Array<unknown>} */\n const before = []\n\n while (++index < list.length) {\n // @ts-expect-error Looks like an object.\n ;(list[index].add === 'after' ? existing : before).push(list[index])\n }\n\n splice(existing, 0, 0, before)\n}\n\n/**\n * Combine multiple HTML extensions into one.\n *\n * @param {ReadonlyArray<HtmlExtension>} htmlExtensions\n * List of HTML extensions.\n * @returns {HtmlExtension}\n * Single combined HTML extension.\n */\nexport function combineHtmlExtensions(htmlExtensions) {\n /** @type {HtmlExtension} */\n const handlers = {}\n let index = -1\n\n while (++index < htmlExtensions.length) {\n htmlExtension(handlers, htmlExtensions[index])\n }\n\n return handlers\n}\n\n/**\n * Merge `extension` into `all`.\n *\n * @param {HtmlExtension} all\n * Extension to merge into.\n * @param {HtmlExtension} extension\n * Extension to merge.\n * @returns {undefined}\n * Nothing.\n */\nfunction htmlExtension(all, extension) {\n /** @type {keyof HtmlExtension} */\n let hook\n\n for (hook in extension) {\n const maybe = hasOwnProperty.call(all, hook) ? all[hook] : undefined\n const left = maybe || (all[hook] = {})\n const right = extension[hook]\n /** @type {keyof Handles} */\n let type\n\n if (right) {\n for (type in right) {\n // @ts-expect-error assume document vs regular handler are managed correctly.\n left[type] = right[type]\n }\n }\n }\n}\n","/**\n * Turn the number (in string form as either hexa- or plain decimal) coming from\n * a numeric character reference into a character.\n *\n * Sort of like `String.fromCodePoint(Number.parseInt(value, base))`, but makes\n * non-characters and control characters safe.\n *\n * @param {string} value\n * Value to decode.\n * @param {number} base\n * Numeric base.\n * @returns {string}\n * Character.\n */\nexport function decodeNumericCharacterReference(value, base) {\n const code = Number.parseInt(value, base);\n if (\n // C0 except for HT, LF, FF, CR, space.\n code < 9 || code === 11 || code > 13 && code < 32 ||\n // Control character (DEL) of C0, and C1 controls.\n code > 126 && code < 160 ||\n // Lone high surrogates and low surrogates.\n code > 55_295 && code < 57_344 ||\n // Noncharacters.\n code > 64_975 && code < 65_008 || /* eslint-disable no-bitwise */\n (code & 65_535) === 65_535 || (code & 65_535) === 65_534 || /* eslint-enable no-bitwise */\n // Out of range\n code > 1_114_111) {\n return \"\\uFFFD\";\n }\n return String.fromCodePoint(code);\n}","/**\n * Normalize an identifier (as found in references, definitions).\n *\n * Collapses markdown whitespace, trim, and then lower- and uppercase.\n *\n * Some characters are considered “uppercase”, such as U+03F4 (`ϴ`), but if their\n * lowercase counterpart (U+03B8 (`θ`)) is uppercased will result in a different\n * uppercase character (U+0398 (`Θ`)).\n * So, to get a canonical form, we perform both lower- and uppercase.\n *\n * Using uppercase last makes sure keys will never interact with default\n * prototypal values (such as `constructor`): nothing in the prototype of\n * `Object` is uppercase.\n *\n * @param {string} value\n * Identifier to normalize.\n * @returns {string}\n * Normalized identifier.\n */\nexport function normalizeIdentifier(value) {\n return value\n // Collapse markdown whitespace.\n .replace(/[\\t\\n\\r ]+/g, \" \")\n // Trim.\n .replace(/^ | $/g, '')\n // Some characters are considered “uppercase”, but if their lowercase\n // counterpart is uppercased will result in a different uppercase\n // character.\n // Hence, to get that form, we perform both lower- and uppercase.\n // Upper case makes sure keys will not interact with default prototypal\n // methods: no method is uppercase.\n .toLowerCase().toUpperCase();\n}","/**\n * @import {Code} from 'micromark-util-types'\n */\n\n/**\n * Check whether the character code represents an ASCII alpha (`a` through `z`,\n * case insensitive).\n *\n * An **ASCII alpha** is an ASCII upper alpha or ASCII lower alpha.\n *\n * An **ASCII upper alpha** is a character in the inclusive range U+0041 (`A`)\n * to U+005A (`Z`).\n *\n * An **ASCII lower alpha** is a character in the inclusive range U+0061 (`a`)\n * to U+007A (`z`).\n *\n * @param code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport const asciiAlpha = regexCheck(/[A-Za-z]/);\n\n/**\n * Check whether the character code represents an ASCII alphanumeric (`a`\n * through `z`, case insensitive, or `0` through `9`).\n *\n * An **ASCII alphanumeric** is an ASCII digit (see `asciiDigit`) or ASCII alpha\n * (see `asciiAlpha`).\n *\n * @param code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport const asciiAlphanumeric = regexCheck(/[\\dA-Za-z]/);\n\n/**\n * Check whether the character code represents an ASCII atext.\n *\n * atext is an ASCII alphanumeric (see `asciiAlphanumeric`), or a character in\n * the inclusive ranges U+0023 NUMBER SIGN (`#`) to U+0027 APOSTROPHE (`'`),\n * U+002A ASTERISK (`*`), U+002B PLUS SIGN (`+`), U+002D DASH (`-`), U+002F\n * SLASH (`/`), U+003D EQUALS TO (`=`), U+003F QUESTION MARK (`?`), U+005E\n * CARET (`^`) to U+0060 GRAVE ACCENT (`` ` ``), or U+007B LEFT CURLY BRACE\n * (`{`) to U+007E TILDE (`~`).\n *\n * See:\n * **\\[RFC5322]**:\n * [Internet Message Format](https://tools.ietf.org/html/rfc5322).\n * P. Resnick.\n * IETF.\n *\n * @param code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport const asciiAtext = regexCheck(/[#-'*+\\--9=?A-Z^-~]/);\n\n/**\n * Check whether a character code is an ASCII control character.\n *\n * An **ASCII control** is a character in the inclusive range U+0000 NULL (NUL)\n * to U+001F (US), or U+007F (DEL).\n *\n * @param {Code} code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport function asciiControl(code) {\n return (\n // Special whitespace codes (which have negative values), C0 and Control\n // character DEL\n code !== null && (code < 32 || code === 127)\n );\n}\n\n/**\n * Check whether the character code represents an ASCII digit (`0` through `9`).\n *\n * An **ASCII digit** is a character in the inclusive range U+0030 (`0`) to\n * U+0039 (`9`).\n *\n * @param code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport const asciiDigit = regexCheck(/\\d/);\n\n/**\n * Check whether the character code represents an ASCII hex digit (`a` through\n * `f`, case insensitive, or `0` through `9`).\n *\n * An **ASCII hex digit** is an ASCII digit (see `asciiDigit`), ASCII upper hex\n * digit, or an ASCII lower hex digit.\n *\n * An **ASCII upper hex digit** is a character in the inclusive range U+0041\n * (`A`) to U+0046 (`F`).\n *\n * An **ASCII lower hex digit** is a character in the inclusive range U+0061\n * (`a`) to U+0066 (`f`).\n *\n * @param code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport const asciiHexDigit = regexCheck(/[\\dA-Fa-f]/);\n\n/**\n * Check whether the character code represents ASCII punctuation.\n *\n * An **ASCII punctuation** is a character in the inclusive ranges U+0021\n * EXCLAMATION MARK (`!`) to U+002F SLASH (`/`), U+003A COLON (`:`) to U+0040 AT\n * SIGN (`@`), U+005B LEFT SQUARE BRACKET (`[`) to U+0060 GRAVE ACCENT\n * (`` ` ``), or U+007B LEFT CURLY BRACE (`{`) to U+007E TILDE (`~`).\n *\n * @param code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport const asciiPunctuation = regexCheck(/[!-/:-@[-`{-~]/);\n\n/**\n * Check whether a character code is a markdown line ending.\n *\n * A **markdown line ending** is the virtual characters M-0003 CARRIAGE RETURN\n * LINE FEED (CRLF), M-0004 LINE FEED (LF) and M-0005 CARRIAGE RETURN (CR).\n *\n * In micromark, the actual character U+000A LINE FEED (LF) and U+000D CARRIAGE\n * RETURN (CR) are replaced by these virtual characters depending on whether\n * they occurred together.\n *\n * @param {Code} code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport function markdownLineEnding(code) {\n return code !== null && code < -2;\n}\n\n/**\n * Check whether a character code is a markdown line ending (see\n * `markdownLineEnding`) or markdown space (see `markdownSpace`).\n *\n * @param {Code} code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport function markdownLineEndingOrSpace(code) {\n return code !== null && (code < 0 || code === 32);\n}\n\n/**\n * Check whether a character code is a markdown space.\n *\n * A **markdown space** is the concrete character U+0020 SPACE (SP) and the\n * virtual characters M-0001 VIRTUAL SPACE (VS) and M-0002 HORIZONTAL TAB (HT).\n *\n * In micromark, the actual character U+0009 CHARACTER TABULATION (HT) is\n * replaced by one M-0002 HORIZONTAL TAB (HT) and between 0 and 3 M-0001 VIRTUAL\n * SPACE (VS) characters, depending on the column at which the tab occurred.\n *\n * @param {Code} code\n * Code.\n * @returns {boolean}\n * Whether it matches.\n */\nexport function markdownSpace(code) {\n return code === -2 || code === -1 || code === 32;\n}\n\n// Size note: removing ASCII from the regex and using `asciiPunctuation` here\n// In fact adds to the bundle size.\n/**\n * Check whether the character code represents Unicode punctuation.\n *\n * A **Unicode punctuation** is a character in the Unicode `Pc` (Punctuation,\n * Connector), `Pd` (Punctuation, Dash), `Pe` (Punctuation, Close), `Pf`\n * (Punctuation, Final quote), `Pi` (Punctuation, Initial quote), `Po`\n * (Punctuation, Other), or `Ps` (Punctuation, Open) categories, or an ASCII\n * punctuation (see `asciiPunctuation`).\n *\n * See:\n * **\\[UNICODE]**:\n * [The Unicode Standard](https://www.unicode.org/versions/).\n * Unicode Consortium.\n *\n * @param code\n * Code.\n * @returns\n * Whether it matches.\n */\nexport const unicodePunctuation = regexCheck(/\\p{P}|\\p{S}/u);\n\n/**\n * Check whether the character code represents Unicode whitespace.\n *\n * Note that this does handle micromark specific markdown whitespace characters.\n * See `markdownLineEndingOrSpace` to check that.\n *\n * A **Unicode whitespace** is a character in the Unicode `Zs` (Separator,\n * Space) category, or U+0009 CHARACTER TABULATION (HT), U+000A LINE FEED (LF),\n * U+000C (FF), or U+000D CARRIAGE RETURN (CR) (**\\[UNICODE]**).\n *\n * See:\n * **\\[UNICODE]**:\n * [The Unicode Standard](https://www.unicode.org/versions/).\n * Unicode Consortium.\n *\n * @param code\n * Code.\n * @returns\n * Whether it matches.\n */\nexport const unicodeWhitespace = regexCheck(/\\s/);\n\n/**\n * Create a code check from a regex.\n *\n * @param {RegExp} regex\n * Expression.\n * @returns {(code: Code) => boolean}\n * Check.\n */\nfunction regexCheck(regex) {\n return check;\n\n /**\n * Check whether a code matches the bound regex.\n *\n * @param {Code} code\n * Character code.\n * @returns {boolean}\n * Whether the character code matches the bound regex.\n */\n function check(code) {\n return code !== null && code > -1 && regex.test(String.fromCharCode(code));\n }\n}","import { asciiAlphanumeric } from 'micromark-util-character';\nimport { encode } from 'micromark-util-encode';\n/**\n * Make a value safe for injection as a URL.\n *\n * This encodes unsafe characters with percent-encoding and skips already\n * encoded sequences (see `normalizeUri`).\n * Further unsafe characters are encoded as character references (see\n * `micromark-util-encode`).\n *\n * A regex of allowed protocols can be given, in which case the URL is\n * sanitized.\n * For example, `/^(https?|ircs?|mailto|xmpp)$/i` can be used for `a[href]`, or\n * `/^https?$/i` for `img[src]` (this is what `github.com` allows).\n * If the URL includes an unknown protocol (one not matched by `protocol`, such\n * as a dangerous example, `javascript:`), the value is ignored.\n *\n * @param {string | null | undefined} url\n * URI to sanitize.\n * @param {RegExp | null | undefined} [protocol]\n * Allowed protocols.\n * @returns {string}\n * Sanitized URI.\n */\nexport function sanitizeUri(url, protocol) {\n const value = encode(normalizeUri(url || ''));\n if (!protocol) {\n return value;\n }\n const colon = value.indexOf(':');\n const questionMark = value.indexOf('?');\n const numberSign = value.indexOf('#');\n const slash = value.indexOf('/');\n if (\n // If there is no protocol, it’s relative.\n colon < 0 ||\n // If the first colon is after a `?`, `#`, or `/`, it’s not a protocol.\n slash > -1 && colon > slash || questionMark > -1 && colon > questionMark || numberSign > -1 && colon > numberSign ||\n // It is a protocol, it should be allowed.\n protocol.test(value.slice(0, colon))) {\n return value;\n }\n return '';\n}\n\n/**\n * Normalize a URL.\n *\n * Encode unsafe characters with percent-encoding, skipping already encoded\n * sequences.\n *\n * @param {string} value\n * URI to normalize.\n * @returns {string}\n * Normalized URI.\n */\nexport function normalizeUri(value) {\n /** @type {Array<string>} */\n const result = [];\n let index = -1;\n let start = 0;\n let skip = 0;\n while (++index < value.length) {\n const code = value.charCodeAt(index);\n /** @type {string} */\n let replace = '';\n\n // A correct percent encoded value.\n if (code === 37 && asciiAlphanumeric(value.charCodeAt(index + 1)) && asciiAlphanumeric(value.charCodeAt(index + 2))) {\n skip = 2;\n }\n // ASCII.\n else if (code < 128) {\n if (!/[!#$&-;=?-Z_a-z~]/.test(String.fromCharCode(code))) {\n replace = String.fromCharCode(code);\n }\n }\n // Astral.\n else if (code > 55_295 && code < 57_344) {\n const next = value.charCodeAt(index + 1);\n\n // A correct surrogate pair.\n if (code < 56_320 && next > 56_319 && next < 57_344) {\n replace = String.fromCharCode(code, next);\n skip = 1;\n }\n // Lone surrogate.\n else {\n replace = \"\\uFFFD\";\n }\n }\n // Unicode.\n else {\n replace = String.fromCharCode(code);\n }\n if (replace) {\n result.push(value.slice(start, index), encodeURIComponent(replace));\n start = index + skip + 1;\n replace = '';\n }\n if (skip) {\n index += skip;\n skip = 0;\n }\n }\n return result.join('') + value.slice(start);\n}","/**\n * @import {Effects, State, TokenType} from 'micromark-util-types'\n */\n\nimport { markdownSpace } from 'micromark-util-character';\n\n// To do: implement `spaceOrTab`, `spaceOrTabMinMax`, `spaceOrTabWithOptions`.\n\n/**\n * Parse spaces and tabs.\n *\n * There is no `nok` parameter:\n *\n * * spaces in markdown are often optional, in which case this factory can be\n * used and `ok` will be switched to whether spaces were found or not\n * * one line ending or space can be detected with `markdownSpace(code)` right\n * before using `factorySpace`\n *\n * ###### Examples\n *\n * Where `␉` represents a tab (plus how much it expands) and `␠` represents a\n * single space.\n *\n * ```markdown\n * ␉\n * ␠␠␠␠\n * ␉␠\n * ```\n *\n * @param {Effects} effects\n * Context.\n * @param {State} ok\n * State switched to when successful.\n * @param {TokenType} type\n * Type (`' \\t'`).\n * @param {number | undefined} [max=Infinity]\n * Max (exclusive).\n * @returns {State}\n * Start state.\n */\nexport function factorySpace(effects, ok, type, max) {\n const limit = max ? max - 1 : Number.POSITIVE_INFINITY;\n let size = 0;\n return start;\n\n /** @type {State} */\n function start(code) {\n if (markdownSpace(code)) {\n effects.enter(type);\n return prefix(code);\n }\n return ok(code);\n }\n\n /** @type {State} */\n function prefix(code) {\n if (markdownSpace(code) && size++ < limit) {\n effects.consume(code);\n return prefix;\n }\n effects.exit(type);\n return ok(code);\n }\n}","/**\n * @import {\n * InitialConstruct,\n * Initializer,\n * State,\n * TokenizeContext,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {InitialConstruct} */\nexport const content = {\n tokenize: initializeContent\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Initializer}\n * Content.\n */\nfunction initializeContent(effects) {\n const contentStart = effects.attempt(this.parser.constructs.contentInitial, afterContentStartConstruct, paragraphInitial);\n /** @type {Token} */\n let previous;\n return contentStart;\n\n /** @type {State} */\n function afterContentStartConstruct(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return factorySpace(effects, contentStart, \"linePrefix\");\n }\n\n /** @type {State} */\n function paragraphInitial(code) {\n effects.enter(\"paragraph\");\n return lineStart(code);\n }\n\n /** @type {State} */\n function lineStart(code) {\n const token = effects.enter(\"chunkText\", {\n contentType: \"text\",\n previous\n });\n if (previous) {\n previous.next = token;\n }\n previous = token;\n return data(code);\n }\n\n /** @type {State} */\n function data(code) {\n if (code === null) {\n effects.exit(\"chunkText\");\n effects.exit(\"paragraph\");\n effects.consume(code);\n return;\n }\n if (markdownLineEnding(code)) {\n effects.consume(code);\n effects.exit(\"chunkText\");\n return lineStart;\n }\n\n // Data.\n effects.consume(code);\n return data;\n }\n}","/**\n * @import {\n * Construct,\n * ContainerState,\n * InitialConstruct,\n * Initializer,\n * Point,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\n/**\n * @typedef {[Construct, ContainerState]} StackItem\n * Construct and its state.\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\nimport { splice } from 'micromark-util-chunked';\n/** @type {InitialConstruct} */\nexport const document = {\n tokenize: initializeDocument\n};\n\n/** @type {Construct} */\nconst containerConstruct = {\n tokenize: tokenizeContainer\n};\n\n/**\n * @this {TokenizeContext}\n * Self.\n * @type {Initializer}\n * Initializer.\n */\nfunction initializeDocument(effects) {\n const self = this;\n /** @type {Array<StackItem>} */\n const stack = [];\n let continued = 0;\n /** @type {TokenizeContext | undefined} */\n let childFlow;\n /** @type {Token | undefined} */\n let childToken;\n /** @type {number} */\n let lineStartOffset;\n return start;\n\n /** @type {State} */\n function start(code) {\n // First we iterate through the open blocks, starting with the root\n // document, and descending through last children down to the last open\n // block.\n // Each block imposes a condition that the line must satisfy if the block is\n // to remain open.\n // For example, a block quote requires a `>` character.\n // A paragraph requires a non-blank line.\n // In this phase we may match all or just some of the open blocks.\n // But we cannot close unmatched blocks yet, because we may have a lazy\n // continuation line.\n if (continued < stack.length) {\n const item = stack[continued];\n self.containerState = item[1];\n return effects.attempt(item[0].continuation, documentContinue, checkNewContainers)(code);\n }\n\n // Done.\n return checkNewContainers(code);\n }\n\n /** @type {State} */\n function documentContinue(code) {\n continued++;\n\n // Note: this field is called `_closeFlow` but it also closes containers.\n // Perhaps a good idea to rename it but it’s already used in the wild by\n // extensions.\n if (self.containerState._closeFlow) {\n self.containerState._closeFlow = undefined;\n if (childFlow) {\n closeFlow();\n }\n\n // Note: this algorithm for moving events around is similar to the\n // algorithm when dealing with lazy lines in `writeToChild`.\n const indexBeforeExits = self.events.length;\n let indexBeforeFlow = indexBeforeExits;\n /** @type {Point | undefined} */\n let point;\n\n // Find the flow chunk.\n while (indexBeforeFlow--) {\n if (self.events[indexBeforeFlow][0] === 'exit' && self.events[indexBeforeFlow][1].type === \"chunkFlow\") {\n point = self.events[indexBeforeFlow][1].end;\n break;\n }\n }\n exitContainers(continued);\n\n // Fix positions.\n let index = indexBeforeExits;\n while (index < self.events.length) {\n self.events[index][1].end = {\n ...point\n };\n index++;\n }\n\n // Inject the exits earlier (they’re still also at the end).\n splice(self.events, indexBeforeFlow + 1, 0, self.events.slice(indexBeforeExits));\n\n // Discard the duplicate exits.\n self.events.length = index;\n return checkNewContainers(code);\n }\n return start(code);\n }\n\n /** @type {State} */\n function checkNewContainers(code) {\n // Next, after consuming the continuation markers for existing blocks, we\n // look for new block starts (e.g. `>` for a block quote).\n // If we encounter a new block start, we close any blocks unmatched in\n // step 1 before creating the new block as a child of the last matched\n // block.\n if (continued === stack.length) {\n // No need to `check` whether there’s a container, of `exitContainers`\n // would be moot.\n // We can instead immediately `attempt` to parse one.\n if (!childFlow) {\n return documentContinued(code);\n }\n\n // If we have concrete content, such as block HTML or fenced code,\n // we can’t have containers “pierce” into them, so we can immediately\n // start.\n if (childFlow.currentConstruct && childFlow.currentConstruct.concrete) {\n return flowStart(code);\n }\n\n // If we do have flow, it could still be a blank line,\n // but we’d be interrupting it w/ a new container if there’s a current\n // construct.\n // To do: next major: remove `_gfmTableDynamicInterruptHack` (no longer\n // needed in micromark-extension-gfm-table@1.0.6).\n self.interrupt = Boolean(childFlow.currentConstruct && !childFlow._gfmTableDynamicInterruptHack);\n }\n\n // Check if there is a new container.\n self.containerState = {};\n return effects.check(containerConstruct, thereIsANewContainer, thereIsNoNewContainer)(code);\n }\n\n /** @type {State} */\n function thereIsANewContainer(code) {\n if (childFlow) closeFlow();\n exitContainers(continued);\n return documentContinued(code);\n }\n\n /** @type {State} */\n function thereIsNoNewContainer(code) {\n self.parser.lazy[self.now().line] = continued !== stack.length;\n lineStartOffset = self.now().offset;\n return flowStart(code);\n }\n\n /** @type {State} */\n function documentContinued(code) {\n // Try new containers.\n self.containerState = {};\n return effects.attempt(containerConstruct, containerContinue, flowStart)(code);\n }\n\n /** @type {State} */\n function containerContinue(code) {\n continued++;\n stack.push([self.currentConstruct, self.containerState]);\n // Try another.\n return documentContinued(code);\n }\n\n /** @type {State} */\n function flowStart(code) {\n if (code === null) {\n if (childFlow) closeFlow();\n exitContainers(0);\n effects.consume(code);\n return;\n }\n childFlow = childFlow || self.parser.flow(self.now());\n effects.enter(\"chunkFlow\", {\n _tokenizer: childFlow,\n contentType: \"flow\",\n previous: childToken\n });\n return flowContinue(code);\n }\n\n /** @type {State} */\n function flowContinue(code) {\n if (code === null) {\n writeToChild(effects.exit(\"chunkFlow\"), true);\n exitContainers(0);\n effects.consume(code);\n return;\n }\n if (markdownLineEnding(code)) {\n effects.consume(code);\n writeToChild(effects.exit(\"chunkFlow\"));\n // Get ready for the next line.\n continued = 0;\n self.interrupt = undefined;\n return start;\n }\n effects.consume(code);\n return flowContinue;\n }\n\n /**\n * @param {Token} token\n * Token.\n * @param {boolean | undefined} [endOfFile]\n * Whether the token is at the end of the file (default: `false`).\n * @returns {undefined}\n * Nothing.\n */\n function writeToChild(token, endOfFile) {\n const stream = self.sliceStream(token);\n if (endOfFile) stream.push(null);\n token.previous = childToken;\n if (childToken) childToken.next = token;\n childToken = token;\n childFlow.defineSkip(token.start);\n childFlow.write(stream);\n\n // Alright, so we just added a lazy line:\n //\n // ```markdown\n // > a\n // b.\n //\n // Or:\n //\n // > ~~~c\n // d\n //\n // Or:\n //\n // > | e |\n // f\n // ```\n //\n // The construct in the second example (fenced code) does not accept lazy\n // lines, so it marked itself as done at the end of its first line, and\n // then the content construct parses `d`.\n // Most constructs in markdown match on the first line: if the first line\n // forms a construct, a non-lazy line can’t “unmake” it.\n //\n // The construct in the third example is potentially a GFM table, and\n // those are *weird*.\n // It *could* be a table, from the first line, if the following line\n // matches a condition.\n // In this case, that second line is lazy, which “unmakes” the first line\n // and turns the whole into one content block.\n //\n // We’ve now parsed the non-lazy and the lazy line, and can figure out\n // whether the lazy line started a new flow block.\n // If it did, we exit the current containers between the two flow blocks.\n if (self.parser.lazy[token.start.line]) {\n let index = childFlow.events.length;\n while (index--) {\n if (\n // The token starts before the line ending…\n childFlow.events[index][1].start.offset < lineStartOffset && (\n // …and either is not ended yet…\n !childFlow.events[index][1].end ||\n // …or ends after it.\n childFlow.events[index][1].end.offset > lineStartOffset)) {\n // Exit: there’s still something open, which means it’s a lazy line\n // part of something.\n return;\n }\n }\n\n // Note: this algorithm for moving events around is similar to the\n // algorithm when closing flow in `documentContinue`.\n const indexBeforeExits = self.events.length;\n let indexBeforeFlow = indexBeforeExits;\n /** @type {boolean | undefined} */\n let seen;\n /** @type {Point | undefined} */\n let point;\n\n // Find the previous chunk (the one before the lazy line).\n while (indexBeforeFlow--) {\n if (self.events[indexBeforeFlow][0] === 'exit' && self.events[indexBeforeFlow][1].type === \"chunkFlow\") {\n if (seen) {\n point = self.events[indexBeforeFlow][1].end;\n break;\n }\n seen = true;\n }\n }\n exitContainers(continued);\n\n // Fix positions.\n index = indexBeforeExits;\n while (index < self.events.length) {\n self.events[index][1].end = {\n ...point\n };\n index++;\n }\n\n // Inject the exits earlier (they’re still also at the end).\n splice(self.events, indexBeforeFlow + 1, 0, self.events.slice(indexBeforeExits));\n\n // Discard the duplicate exits.\n self.events.length = index;\n }\n }\n\n /**\n * @param {number} size\n * Size.\n * @returns {undefined}\n * Nothing.\n */\n function exitContainers(size) {\n let index = stack.length;\n\n // Exit open containers.\n while (index-- > size) {\n const entry = stack[index];\n self.containerState = entry[1];\n entry[0].exit.call(self, effects);\n }\n stack.length = size;\n }\n function closeFlow() {\n childFlow.write([null]);\n childToken = undefined;\n childFlow = undefined;\n self.containerState._closeFlow = undefined;\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n * Tokenizer.\n */\nfunction tokenizeContainer(effects, ok, nok) {\n // Always populated by defaults.\n\n return factorySpace(effects, effects.attempt(this.parser.constructs.document, ok, nok), \"linePrefix\", this.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4);\n}","/**\n * @import {Code} from 'micromark-util-types'\n */\n\nimport { markdownLineEndingOrSpace, unicodePunctuation, unicodeWhitespace } from 'micromark-util-character';\n/**\n * Classify whether a code represents whitespace, punctuation, or something\n * else.\n *\n * Used for attention (emphasis, strong), whose sequences can open or close\n * based on the class of surrounding characters.\n *\n * > 👉 **Note**: eof (`null`) is seen as whitespace.\n *\n * @param {Code} code\n * Code.\n * @returns {typeof constants.characterGroupWhitespace | typeof constants.characterGroupPunctuation | undefined}\n * Group.\n */\nexport function classifyCharacter(code) {\n if (code === null || markdownLineEndingOrSpace(code) || unicodeWhitespace(code)) {\n return 1;\n }\n if (unicodePunctuation(code)) {\n return 2;\n }\n}","/**\n * @import {Event, Resolver, TokenizeContext} from 'micromark-util-types'\n */\n\n/**\n * Call all `resolveAll`s.\n *\n * @param {ReadonlyArray<{resolveAll?: Resolver | undefined}>} constructs\n * List of constructs, optionally with `resolveAll`s.\n * @param {Array<Event>} events\n * List of events.\n * @param {TokenizeContext} context\n * Context used by `tokenize`.\n * @returns {Array<Event>}\n * Changed events.\n */\nexport function resolveAll(constructs, events, context) {\n /** @type {Array<Resolver>} */\n const called = []\n let index = -1\n\n while (++index < constructs.length) {\n const resolve = constructs[index].resolveAll\n\n if (resolve && !called.includes(resolve)) {\n events = resolve(events, context)\n called.push(resolve)\n }\n }\n\n return events\n}\n","/**\n * @import {\n * Code,\n * Construct,\n * Event,\n * Point,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { push, splice } from 'micromark-util-chunked';\nimport { classifyCharacter } from 'micromark-util-classify-character';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/** @type {Construct} */\nexport const attention = {\n name: 'attention',\n resolveAll: resolveAllAttention,\n tokenize: tokenizeAttention\n};\n\n/**\n * Take all events and resolve attention to emphasis or strong.\n *\n * @type {Resolver}\n */\n// eslint-disable-next-line complexity\nfunction resolveAllAttention(events, context) {\n let index = -1;\n /** @type {number} */\n let open;\n /** @type {Token} */\n let group;\n /** @type {Token} */\n let text;\n /** @type {Token} */\n let openingSequence;\n /** @type {Token} */\n let closingSequence;\n /** @type {number} */\n let use;\n /** @type {Array<Event>} */\n let nextEvents;\n /** @type {number} */\n let offset;\n\n // Walk through all events.\n //\n // Note: performance of this is fine on an mb of normal markdown, but it’s\n // a bottleneck for malicious stuff.\n while (++index < events.length) {\n // Find a token that can close.\n if (events[index][0] === 'enter' && events[index][1].type === 'attentionSequence' && events[index][1]._close) {\n open = index;\n\n // Now walk back to find an opener.\n while (open--) {\n // Find a token that can open the closer.\n if (events[open][0] === 'exit' && events[open][1].type === 'attentionSequence' && events[open][1]._open &&\n // If the markers are the same:\n context.sliceSerialize(events[open][1]).charCodeAt(0) === context.sliceSerialize(events[index][1]).charCodeAt(0)) {\n // If the opening can close or the closing can open,\n // and the close size *is not* a multiple of three,\n // but the sum of the opening and closing size *is* multiple of three,\n // then don’t match.\n if ((events[open][1]._close || events[index][1]._open) && (events[index][1].end.offset - events[index][1].start.offset) % 3 && !((events[open][1].end.offset - events[open][1].start.offset + events[index][1].end.offset - events[index][1].start.offset) % 3)) {\n continue;\n }\n\n // Number of markers to use from the sequence.\n use = events[open][1].end.offset - events[open][1].start.offset > 1 && events[index][1].end.offset - events[index][1].start.offset > 1 ? 2 : 1;\n const start = {\n ...events[open][1].end\n };\n const end = {\n ...events[index][1].start\n };\n movePoint(start, -use);\n movePoint(end, use);\n openingSequence = {\n type: use > 1 ? \"strongSequence\" : \"emphasisSequence\",\n start,\n end: {\n ...events[open][1].end\n }\n };\n closingSequence = {\n type: use > 1 ? \"strongSequence\" : \"emphasisSequence\",\n start: {\n ...events[index][1].start\n },\n end\n };\n text = {\n type: use > 1 ? \"strongText\" : \"emphasisText\",\n start: {\n ...events[open][1].end\n },\n end: {\n ...events[index][1].start\n }\n };\n group = {\n type: use > 1 ? \"strong\" : \"emphasis\",\n start: {\n ...openingSequence.start\n },\n end: {\n ...closingSequence.end\n }\n };\n events[open][1].end = {\n ...openingSequence.start\n };\n events[index][1].start = {\n ...closingSequence.end\n };\n nextEvents = [];\n\n // If there are more markers in the opening, add them before.\n if (events[open][1].end.offset - events[open][1].start.offset) {\n nextEvents = push(nextEvents, [['enter', events[open][1], context], ['exit', events[open][1], context]]);\n }\n\n // Opening.\n nextEvents = push(nextEvents, [['enter', group, context], ['enter', openingSequence, context], ['exit', openingSequence, context], ['enter', text, context]]);\n\n // Always populated by defaults.\n\n // Between.\n nextEvents = push(nextEvents, resolveAll(context.parser.constructs.insideSpan.null, events.slice(open + 1, index), context));\n\n // Closing.\n nextEvents = push(nextEvents, [['exit', text, context], ['enter', closingSequence, context], ['exit', closingSequence, context], ['exit', group, context]]);\n\n // If there are more markers in the closing, add them after.\n if (events[index][1].end.offset - events[index][1].start.offset) {\n offset = 2;\n nextEvents = push(nextEvents, [['enter', events[index][1], context], ['exit', events[index][1], context]]);\n } else {\n offset = 0;\n }\n splice(events, open - 1, index - open + 3, nextEvents);\n index = open + nextEvents.length - offset - 2;\n break;\n }\n }\n }\n }\n\n // Remove remaining sequences.\n index = -1;\n while (++index < events.length) {\n if (events[index][1].type === 'attentionSequence') {\n events[index][1].type = 'data';\n }\n }\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeAttention(effects, ok) {\n const attentionMarkers = this.parser.constructs.attentionMarkers.null;\n const previous = this.previous;\n const before = classifyCharacter(previous);\n\n /** @type {NonNullable<Code>} */\n let marker;\n return start;\n\n /**\n * Before a sequence.\n *\n * ```markdown\n * > | **\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n marker = code;\n effects.enter('attentionSequence');\n return inside(code);\n }\n\n /**\n * In a sequence.\n *\n * ```markdown\n * > | **\n * ^^\n * ```\n *\n * @type {State}\n */\n function inside(code) {\n if (code === marker) {\n effects.consume(code);\n return inside;\n }\n const token = effects.exit('attentionSequence');\n\n // To do: next major: move this to resolver, just like `markdown-rs`.\n const after = classifyCharacter(code);\n\n // Always populated by defaults.\n\n const open = !after || after === 2 && before || attentionMarkers.includes(code);\n const close = !before || before === 2 && after || attentionMarkers.includes(previous);\n token._open = Boolean(marker === 42 ? open : open && (before || !close));\n token._close = Boolean(marker === 42 ? close : close && (after || !open));\n return ok(code);\n }\n}\n\n/**\n * Move a point a bit.\n *\n * Note: `move` only works inside lines! It’s not possible to move past other\n * chunks (replacement characters, tabs, or line endings).\n *\n * @param {Point} point\n * Point.\n * @param {number} offset\n * Amount to move.\n * @returns {undefined}\n * Nothing.\n */\nfunction movePoint(point, offset) {\n point.column += offset;\n point.offset += offset;\n point._bufferIndex += offset;\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { asciiAlphanumeric, asciiAlpha, asciiAtext, asciiControl } from 'micromark-util-character';\n/** @type {Construct} */\nexport const autolink = {\n name: 'autolink',\n tokenize: tokenizeAutolink\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeAutolink(effects, ok, nok) {\n let size = 0;\n return start;\n\n /**\n * Start of an autolink.\n *\n * ```markdown\n * > | a<https://example.com>b\n * ^\n * > | a<user@example.com>b\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"autolink\");\n effects.enter(\"autolinkMarker\");\n effects.consume(code);\n effects.exit(\"autolinkMarker\");\n effects.enter(\"autolinkProtocol\");\n return open;\n }\n\n /**\n * After `<`, at protocol or atext.\n *\n * ```markdown\n * > | a<https://example.com>b\n * ^\n * > | a<user@example.com>b\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (asciiAlpha(code)) {\n effects.consume(code);\n return schemeOrEmailAtext;\n }\n if (code === 64) {\n return nok(code);\n }\n return emailAtext(code);\n }\n\n /**\n * At second byte of protocol or atext.\n *\n * ```markdown\n * > | a<https://example.com>b\n * ^\n * > | a<user@example.com>b\n * ^\n * ```\n *\n * @type {State}\n */\n function schemeOrEmailAtext(code) {\n // ASCII alphanumeric and `+`, `-`, and `.`.\n if (code === 43 || code === 45 || code === 46 || asciiAlphanumeric(code)) {\n // Count the previous alphabetical from `open` too.\n size = 1;\n return schemeInsideOrEmailAtext(code);\n }\n return emailAtext(code);\n }\n\n /**\n * In ambiguous protocol or atext.\n *\n * ```markdown\n * > | a<https://example.com>b\n * ^\n * > | a<user@example.com>b\n * ^\n * ```\n *\n * @type {State}\n */\n function schemeInsideOrEmailAtext(code) {\n if (code === 58) {\n effects.consume(code);\n size = 0;\n return urlInside;\n }\n\n // ASCII alphanumeric and `+`, `-`, and `.`.\n if ((code === 43 || code === 45 || code === 46 || asciiAlphanumeric(code)) && size++ < 32) {\n effects.consume(code);\n return schemeInsideOrEmailAtext;\n }\n size = 0;\n return emailAtext(code);\n }\n\n /**\n * After protocol, in URL.\n *\n * ```markdown\n * > | a<https://example.com>b\n * ^\n * ```\n *\n * @type {State}\n */\n function urlInside(code) {\n if (code === 62) {\n effects.exit(\"autolinkProtocol\");\n effects.enter(\"autolinkMarker\");\n effects.consume(code);\n effects.exit(\"autolinkMarker\");\n effects.exit(\"autolink\");\n return ok;\n }\n\n // ASCII control, space, or `<`.\n if (code === null || code === 32 || code === 60 || asciiControl(code)) {\n return nok(code);\n }\n effects.consume(code);\n return urlInside;\n }\n\n /**\n * In email atext.\n *\n * ```markdown\n * > | a<user.name@example.com>b\n * ^\n * ```\n *\n * @type {State}\n */\n function emailAtext(code) {\n if (code === 64) {\n effects.consume(code);\n return emailAtSignOrDot;\n }\n if (asciiAtext(code)) {\n effects.consume(code);\n return emailAtext;\n }\n return nok(code);\n }\n\n /**\n * In label, after at-sign or dot.\n *\n * ```markdown\n * > | a<user.name@example.com>b\n * ^ ^\n * ```\n *\n * @type {State}\n */\n function emailAtSignOrDot(code) {\n return asciiAlphanumeric(code) ? emailLabel(code) : nok(code);\n }\n\n /**\n * In label, where `.` and `>` are allowed.\n *\n * ```markdown\n * > | a<user.name@example.com>b\n * ^\n * ```\n *\n * @type {State}\n */\n function emailLabel(code) {\n if (code === 46) {\n effects.consume(code);\n size = 0;\n return emailAtSignOrDot;\n }\n if (code === 62) {\n // Exit, then change the token type.\n effects.exit(\"autolinkProtocol\").type = \"autolinkEmail\";\n effects.enter(\"autolinkMarker\");\n effects.consume(code);\n effects.exit(\"autolinkMarker\");\n effects.exit(\"autolink\");\n return ok;\n }\n return emailValue(code);\n }\n\n /**\n * In label, where `.` and `>` are *not* allowed.\n *\n * Though, this is also used in `emailLabel` to parse other values.\n *\n * ```markdown\n * > | a<user.name@ex-ample.com>b\n * ^\n * ```\n *\n * @type {State}\n */\n function emailValue(code) {\n // ASCII alphanumeric or `-`.\n if ((code === 45 || asciiAlphanumeric(code)) && size++ < 63) {\n const next = code === 45 ? emailValue : emailLabel;\n effects.consume(code);\n return next;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const blankLine = {\n partial: true,\n tokenize: tokenizeBlankLine\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeBlankLine(effects, ok, nok) {\n return start;\n\n /**\n * Start of blank line.\n *\n * > 👉 **Note**: `␠` represents a space character.\n *\n * ```markdown\n * > | ␠␠␊\n * ^\n * > | ␊\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n return markdownSpace(code) ? factorySpace(effects, after, \"linePrefix\")(code) : after(code);\n }\n\n /**\n * At eof/eol, after optional whitespace.\n *\n * > 👉 **Note**: `␠` represents a space character.\n *\n * ```markdown\n * > | ␠␠␊\n * ^\n * > | ␊\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n return code === null || markdownLineEnding(code) ? ok(code) : nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * Exiter,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const blockQuote = {\n continuation: {\n tokenize: tokenizeBlockQuoteContinuation\n },\n exit,\n name: 'blockQuote',\n tokenize: tokenizeBlockQuoteStart\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeBlockQuoteStart(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of block quote.\n *\n * ```markdown\n * > | > a\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n if (code === 62) {\n const state = self.containerState;\n if (!state.open) {\n effects.enter(\"blockQuote\", {\n _container: true\n });\n state.open = true;\n }\n effects.enter(\"blockQuotePrefix\");\n effects.enter(\"blockQuoteMarker\");\n effects.consume(code);\n effects.exit(\"blockQuoteMarker\");\n return after;\n }\n return nok(code);\n }\n\n /**\n * After `>`, before optional whitespace.\n *\n * ```markdown\n * > | > a\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n if (markdownSpace(code)) {\n effects.enter(\"blockQuotePrefixWhitespace\");\n effects.consume(code);\n effects.exit(\"blockQuotePrefixWhitespace\");\n effects.exit(\"blockQuotePrefix\");\n return ok;\n }\n effects.exit(\"blockQuotePrefix\");\n return ok(code);\n }\n}\n\n/**\n * Start of block quote continuation.\n *\n * ```markdown\n * | > a\n * > | > b\n * ^\n * ```\n *\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeBlockQuoteContinuation(effects, ok, nok) {\n const self = this;\n return contStart;\n\n /**\n * Start of block quote continuation.\n *\n * Also used to parse the first block quote opening.\n *\n * ```markdown\n * | > a\n * > | > b\n * ^\n * ```\n *\n * @type {State}\n */\n function contStart(code) {\n if (markdownSpace(code)) {\n // Always populated by defaults.\n\n return factorySpace(effects, contBefore, \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code);\n }\n return contBefore(code);\n }\n\n /**\n * At `>`, after optional whitespace.\n *\n * Also used to parse the first block quote opening.\n *\n * ```markdown\n * | > a\n * > | > b\n * ^\n * ```\n *\n * @type {State}\n */\n function contBefore(code) {\n return effects.attempt(blockQuote, ok, nok)(code);\n }\n}\n\n/** @type {Exiter} */\nfunction exit(effects) {\n effects.exit(\"blockQuote\");\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { asciiPunctuation } from 'micromark-util-character';\n/** @type {Construct} */\nexport const characterEscape = {\n name: 'characterEscape',\n tokenize: tokenizeCharacterEscape\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeCharacterEscape(effects, ok, nok) {\n return start;\n\n /**\n * Start of character escape.\n *\n * ```markdown\n * > | a\\*b\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"characterEscape\");\n effects.enter(\"escapeMarker\");\n effects.consume(code);\n effects.exit(\"escapeMarker\");\n return inside;\n }\n\n /**\n * After `\\`, at punctuation.\n *\n * ```markdown\n * > | a\\*b\n * ^\n * ```\n *\n * @type {State}\n */\n function inside(code) {\n // ASCII punctuation.\n if (asciiPunctuation(code)) {\n effects.enter(\"characterEscapeValue\");\n effects.consume(code);\n effects.exit(\"characterEscapeValue\");\n effects.exit(\"characterEscape\");\n return ok;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { asciiAlphanumeric, asciiDigit, asciiHexDigit } from 'micromark-util-character';\n/** @type {Construct} */\nexport const characterReference = {\n name: 'characterReference',\n tokenize: tokenizeCharacterReference\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeCharacterReference(effects, ok, nok) {\n const self = this;\n let size = 0;\n /** @type {number} */\n let max;\n /** @type {(code: Code) => boolean} */\n let test;\n return start;\n\n /**\n * Start of character reference.\n *\n * ```markdown\n * > | a&amp;b\n * ^\n * > | a&#123;b\n * ^\n * > | a&#x9;b\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"characterReference\");\n effects.enter(\"characterReferenceMarker\");\n effects.consume(code);\n effects.exit(\"characterReferenceMarker\");\n return open;\n }\n\n /**\n * After `&`, at `#` for numeric references or alphanumeric for named\n * references.\n *\n * ```markdown\n * > | a&amp;b\n * ^\n * > | a&#123;b\n * ^\n * > | a&#x9;b\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 35) {\n effects.enter(\"characterReferenceMarkerNumeric\");\n effects.consume(code);\n effects.exit(\"characterReferenceMarkerNumeric\");\n return numeric;\n }\n effects.enter(\"characterReferenceValue\");\n max = 31;\n test = asciiAlphanumeric;\n return value(code);\n }\n\n /**\n * After `#`, at `x` for hexadecimals or digit for decimals.\n *\n * ```markdown\n * > | a&#123;b\n * ^\n * > | a&#x9;b\n * ^\n * ```\n *\n * @type {State}\n */\n function numeric(code) {\n if (code === 88 || code === 120) {\n effects.enter(\"characterReferenceMarkerHexadecimal\");\n effects.consume(code);\n effects.exit(\"characterReferenceMarkerHexadecimal\");\n effects.enter(\"characterReferenceValue\");\n max = 6;\n test = asciiHexDigit;\n return value;\n }\n effects.enter(\"characterReferenceValue\");\n max = 7;\n test = asciiDigit;\n return value(code);\n }\n\n /**\n * After markers (`&#x`, `&#`, or `&`), in value, before `;`.\n *\n * The character reference kind defines what and how many characters are\n * allowed.\n *\n * ```markdown\n * > | a&amp;b\n * ^^^\n * > | a&#123;b\n * ^^^\n * > | a&#x9;b\n * ^\n * ```\n *\n * @type {State}\n */\n function value(code) {\n if (code === 59 && size) {\n const token = effects.exit(\"characterReferenceValue\");\n if (test === asciiAlphanumeric && !decodeNamedCharacterReference(self.sliceSerialize(token))) {\n return nok(code);\n }\n\n // To do: `markdown-rs` uses a different name:\n // `CharacterReferenceMarkerSemi`.\n effects.enter(\"characterReferenceMarker\");\n effects.consume(code);\n effects.exit(\"characterReferenceMarker\");\n effects.exit(\"characterReference\");\n return ok;\n }\n if (test(code) && size++ < max) {\n effects.consume(code);\n return value;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nconst nonLazyContinuation = {\n partial: true,\n tokenize: tokenizeNonLazyContinuation\n};\n\n/** @type {Construct} */\nexport const codeFenced = {\n concrete: true,\n name: 'codeFenced',\n tokenize: tokenizeCodeFenced\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeCodeFenced(effects, ok, nok) {\n const self = this;\n /** @type {Construct} */\n const closeStart = {\n partial: true,\n tokenize: tokenizeCloseStart\n };\n let initialPrefix = 0;\n let sizeOpen = 0;\n /** @type {NonNullable<Code>} */\n let marker;\n return start;\n\n /**\n * Start of code.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // To do: parse whitespace like `markdown-rs`.\n return beforeSequenceOpen(code);\n }\n\n /**\n * In opening fence, after prefix, at sequence.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function beforeSequenceOpen(code) {\n const tail = self.events[self.events.length - 1];\n initialPrefix = tail && tail[1].type === \"linePrefix\" ? tail[2].sliceSerialize(tail[1], true).length : 0;\n marker = code;\n effects.enter(\"codeFenced\");\n effects.enter(\"codeFencedFence\");\n effects.enter(\"codeFencedFenceSequence\");\n return sequenceOpen(code);\n }\n\n /**\n * In opening fence sequence.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function sequenceOpen(code) {\n if (code === marker) {\n sizeOpen++;\n effects.consume(code);\n return sequenceOpen;\n }\n if (sizeOpen < 3) {\n return nok(code);\n }\n effects.exit(\"codeFencedFenceSequence\");\n return markdownSpace(code) ? factorySpace(effects, infoBefore, \"whitespace\")(code) : infoBefore(code);\n }\n\n /**\n * In opening fence, after the sequence (and optional whitespace), before info.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function infoBefore(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"codeFencedFence\");\n return self.interrupt ? ok(code) : effects.check(nonLazyContinuation, atNonLazyBreak, after)(code);\n }\n effects.enter(\"codeFencedFenceInfo\");\n effects.enter(\"chunkString\", {\n contentType: \"string\"\n });\n return info(code);\n }\n\n /**\n * In info.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function info(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"chunkString\");\n effects.exit(\"codeFencedFenceInfo\");\n return infoBefore(code);\n }\n if (markdownSpace(code)) {\n effects.exit(\"chunkString\");\n effects.exit(\"codeFencedFenceInfo\");\n return factorySpace(effects, metaBefore, \"whitespace\")(code);\n }\n if (code === 96 && code === marker) {\n return nok(code);\n }\n effects.consume(code);\n return info;\n }\n\n /**\n * In opening fence, after info and whitespace, before meta.\n *\n * ```markdown\n * > | ~~~js eval\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function metaBefore(code) {\n if (code === null || markdownLineEnding(code)) {\n return infoBefore(code);\n }\n effects.enter(\"codeFencedFenceMeta\");\n effects.enter(\"chunkString\", {\n contentType: \"string\"\n });\n return meta(code);\n }\n\n /**\n * In meta.\n *\n * ```markdown\n * > | ~~~js eval\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function meta(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"chunkString\");\n effects.exit(\"codeFencedFenceMeta\");\n return infoBefore(code);\n }\n if (code === 96 && code === marker) {\n return nok(code);\n }\n effects.consume(code);\n return meta;\n }\n\n /**\n * At eol/eof in code, before a non-lazy closing fence or content.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * > | alert(1)\n * ^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function atNonLazyBreak(code) {\n return effects.attempt(closeStart, after, contentBefore)(code);\n }\n\n /**\n * Before code content, not a closing fence, at eol.\n *\n * ```markdown\n * | ~~~js\n * > | alert(1)\n * ^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function contentBefore(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return contentStart;\n }\n\n /**\n * Before code content, not a closing fence.\n *\n * ```markdown\n * | ~~~js\n * > | alert(1)\n * ^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function contentStart(code) {\n return initialPrefix > 0 && markdownSpace(code) ? factorySpace(effects, beforeContentChunk, \"linePrefix\", initialPrefix + 1)(code) : beforeContentChunk(code);\n }\n\n /**\n * Before code content, after optional prefix.\n *\n * ```markdown\n * | ~~~js\n * > | alert(1)\n * ^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function beforeContentChunk(code) {\n if (code === null || markdownLineEnding(code)) {\n return effects.check(nonLazyContinuation, atNonLazyBreak, after)(code);\n }\n effects.enter(\"codeFlowValue\");\n return contentChunk(code);\n }\n\n /**\n * In code content.\n *\n * ```markdown\n * | ~~~js\n * > | alert(1)\n * ^^^^^^^^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function contentChunk(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"codeFlowValue\");\n return beforeContentChunk(code);\n }\n effects.consume(code);\n return contentChunk;\n }\n\n /**\n * After code.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n effects.exit(\"codeFenced\");\n return ok(code);\n }\n\n /**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\n function tokenizeCloseStart(effects, ok, nok) {\n let size = 0;\n return startBefore;\n\n /**\n *\n *\n * @type {State}\n */\n function startBefore(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return start;\n }\n\n /**\n * Before closing fence, at optional whitespace.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // Always populated by defaults.\n\n // To do: `enter` here or in next state?\n effects.enter(\"codeFencedFence\");\n return markdownSpace(code) ? factorySpace(effects, beforeSequenceClose, \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code) : beforeSequenceClose(code);\n }\n\n /**\n * In closing fence, after optional whitespace, at sequence.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function beforeSequenceClose(code) {\n if (code === marker) {\n effects.enter(\"codeFencedFenceSequence\");\n return sequenceClose(code);\n }\n return nok(code);\n }\n\n /**\n * In closing fence sequence.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceClose(code) {\n if (code === marker) {\n size++;\n effects.consume(code);\n return sequenceClose;\n }\n if (size >= sizeOpen) {\n effects.exit(\"codeFencedFenceSequence\");\n return markdownSpace(code) ? factorySpace(effects, sequenceCloseAfter, \"whitespace\")(code) : sequenceCloseAfter(code);\n }\n return nok(code);\n }\n\n /**\n * After closing fence sequence, after optional whitespace.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceCloseAfter(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"codeFencedFence\");\n return ok(code);\n }\n return nok(code);\n }\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeNonLazyContinuation(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n *\n *\n * @type {State}\n */\n function start(code) {\n if (code === null) {\n return nok(code);\n }\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return lineStart;\n }\n\n /**\n *\n *\n * @type {State}\n */\n function lineStart(code) {\n return self.parser.lazy[self.now().line] ? nok(code) : ok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const codeIndented = {\n name: 'codeIndented',\n tokenize: tokenizeCodeIndented\n};\n\n/** @type {Construct} */\nconst furtherStart = {\n partial: true,\n tokenize: tokenizeFurtherStart\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeCodeIndented(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of code (indented).\n *\n * > **Parsing note**: it is not needed to check if this first line is a\n * > filled line (that it has a non-whitespace character), because blank lines\n * > are parsed already, so we never run into that.\n *\n * ```markdown\n * > | aaa\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // To do: manually check if interrupting like `markdown-rs`.\n\n effects.enter(\"codeIndented\");\n // To do: use an improved `space_or_tab` function like `markdown-rs`,\n // so that we can drop the next state.\n return factorySpace(effects, afterPrefix, \"linePrefix\", 4 + 1)(code);\n }\n\n /**\n * At start, after 1 or 4 spaces.\n *\n * ```markdown\n * > | aaa\n * ^\n * ```\n *\n * @type {State}\n */\n function afterPrefix(code) {\n const tail = self.events[self.events.length - 1];\n return tail && tail[1].type === \"linePrefix\" && tail[2].sliceSerialize(tail[1], true).length >= 4 ? atBreak(code) : nok(code);\n }\n\n /**\n * At a break.\n *\n * ```markdown\n * > | aaa\n * ^ ^\n * ```\n *\n * @type {State}\n */\n function atBreak(code) {\n if (code === null) {\n return after(code);\n }\n if (markdownLineEnding(code)) {\n return effects.attempt(furtherStart, atBreak, after)(code);\n }\n effects.enter(\"codeFlowValue\");\n return inside(code);\n }\n\n /**\n * In code content.\n *\n * ```markdown\n * > | aaa\n * ^^^^\n * ```\n *\n * @type {State}\n */\n function inside(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"codeFlowValue\");\n return atBreak(code);\n }\n effects.consume(code);\n return inside;\n }\n\n /** @type {State} */\n function after(code) {\n effects.exit(\"codeIndented\");\n // To do: allow interrupting like `markdown-rs`.\n // Feel free to interrupt.\n // tokenizer.interrupt = false\n return ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeFurtherStart(effects, ok, nok) {\n const self = this;\n return furtherStart;\n\n /**\n * At eol, trying to parse another indent.\n *\n * ```markdown\n * > | aaa\n * ^\n * | bbb\n * ```\n *\n * @type {State}\n */\n function furtherStart(code) {\n // To do: improve `lazy` / `pierce` handling.\n // If this is a lazy line, it can’t be code.\n if (self.parser.lazy[self.now().line]) {\n return nok(code);\n }\n if (markdownLineEnding(code)) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return furtherStart;\n }\n\n // To do: the code here in `micromark-js` is a bit different from\n // `markdown-rs` because there it can attempt spaces.\n // We can’t yet.\n //\n // To do: use an improved `space_or_tab` function like `markdown-rs`,\n // so that we can drop the next state.\n return factorySpace(effects, afterPrefix, \"linePrefix\", 4 + 1)(code);\n }\n\n /**\n * At start, after 1 or 4 spaces.\n *\n * ```markdown\n * > | aaa\n * ^\n * ```\n *\n * @type {State}\n */\n function afterPrefix(code) {\n const tail = self.events[self.events.length - 1];\n return tail && tail[1].type === \"linePrefix\" && tail[2].sliceSerialize(tail[1], true).length >= 4 ? ok(code) : markdownLineEnding(code) ? furtherStart(code) : nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * Previous,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {Construct} */\nexport const codeText = {\n name: 'codeText',\n previous,\n resolve: resolveCodeText,\n tokenize: tokenizeCodeText\n};\n\n// To do: next major: don’t resolve, like `markdown-rs`.\n/** @type {Resolver} */\nfunction resolveCodeText(events) {\n let tailExitIndex = events.length - 4;\n let headEnterIndex = 3;\n /** @type {number} */\n let index;\n /** @type {number | undefined} */\n let enter;\n\n // If we start and end with an EOL or a space.\n if ((events[headEnterIndex][1].type === \"lineEnding\" || events[headEnterIndex][1].type === 'space') && (events[tailExitIndex][1].type === \"lineEnding\" || events[tailExitIndex][1].type === 'space')) {\n index = headEnterIndex;\n\n // And we have data.\n while (++index < tailExitIndex) {\n if (events[index][1].type === \"codeTextData\") {\n // Then we have padding.\n events[headEnterIndex][1].type = \"codeTextPadding\";\n events[tailExitIndex][1].type = \"codeTextPadding\";\n headEnterIndex += 2;\n tailExitIndex -= 2;\n break;\n }\n }\n }\n\n // Merge adjacent spaces and data.\n index = headEnterIndex - 1;\n tailExitIndex++;\n while (++index <= tailExitIndex) {\n if (enter === undefined) {\n if (index !== tailExitIndex && events[index][1].type !== \"lineEnding\") {\n enter = index;\n }\n } else if (index === tailExitIndex || events[index][1].type === \"lineEnding\") {\n events[enter][1].type = \"codeTextData\";\n if (index !== enter + 2) {\n events[enter][1].end = events[index - 1][1].end;\n events.splice(enter + 2, index - enter - 2);\n tailExitIndex -= index - enter - 2;\n index = enter + 2;\n }\n enter = undefined;\n }\n }\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Previous}\n */\nfunction previous(code) {\n // If there is a previous code, there will always be a tail.\n return code !== 96 || this.events[this.events.length - 1][1].type === \"characterEscape\";\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeCodeText(effects, ok, nok) {\n const self = this;\n let sizeOpen = 0;\n /** @type {number} */\n let size;\n /** @type {Token} */\n let token;\n return start;\n\n /**\n * Start of code (text).\n *\n * ```markdown\n * > | `a`\n * ^\n * > | \\`a`\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"codeText\");\n effects.enter(\"codeTextSequence\");\n return sequenceOpen(code);\n }\n\n /**\n * In opening sequence.\n *\n * ```markdown\n * > | `a`\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceOpen(code) {\n if (code === 96) {\n effects.consume(code);\n sizeOpen++;\n return sequenceOpen;\n }\n effects.exit(\"codeTextSequence\");\n return between(code);\n }\n\n /**\n * Between something and something else.\n *\n * ```markdown\n * > | `a`\n * ^^\n * ```\n *\n * @type {State}\n */\n function between(code) {\n // EOF.\n if (code === null) {\n return nok(code);\n }\n\n // To do: next major: don’t do spaces in resolve, but when compiling,\n // like `markdown-rs`.\n // Tabs don’t work, and virtual spaces don’t make sense.\n if (code === 32) {\n effects.enter('space');\n effects.consume(code);\n effects.exit('space');\n return between;\n }\n\n // Closing fence? Could also be data.\n if (code === 96) {\n token = effects.enter(\"codeTextSequence\");\n size = 0;\n return sequenceClose(code);\n }\n if (markdownLineEnding(code)) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return between;\n }\n\n // Data.\n effects.enter(\"codeTextData\");\n return data(code);\n }\n\n /**\n * In data.\n *\n * ```markdown\n * > | `a`\n * ^\n * ```\n *\n * @type {State}\n */\n function data(code) {\n if (code === null || code === 32 || code === 96 || markdownLineEnding(code)) {\n effects.exit(\"codeTextData\");\n return between(code);\n }\n effects.consume(code);\n return data;\n }\n\n /**\n * In closing sequence.\n *\n * ```markdown\n * > | `a`\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceClose(code) {\n // More.\n if (code === 96) {\n effects.consume(code);\n size++;\n return sequenceClose;\n }\n\n // Done!\n if (size === sizeOpen) {\n effects.exit(\"codeTextSequence\");\n effects.exit(\"codeText\");\n return ok(code);\n }\n\n // More or less accents: mark as data.\n token.type = \"codeTextData\";\n return data(code);\n }\n}","/**\n * Some of the internal operations of micromark do lots of editing\n * operations on very large arrays. This runs into problems with two\n * properties of most circa-2020 JavaScript interpreters:\n *\n * - Array-length modifications at the high end of an array (push/pop) are\n * expected to be common and are implemented in (amortized) time\n * proportional to the number of elements added or removed, whereas\n * other operations (shift/unshift and splice) are much less efficient.\n * - Function arguments are passed on the stack, so adding tens of thousands\n * of elements to an array with `arr.push(...newElements)` will frequently\n * cause stack overflows. (see <https://stackoverflow.com/questions/22123769/rangeerror-maximum-call-stack-size-exceeded-why>)\n *\n * SpliceBuffers are an implementation of gap buffers, which are a\n * generalization of the \"queue made of two stacks\" idea. The splice buffer\n * maintains a cursor, and moving the cursor has cost proportional to the\n * distance the cursor moves, but inserting, deleting, or splicing in\n * new information at the cursor is as efficient as the push/pop operation.\n * This allows for an efficient sequence of splices (or pushes, pops, shifts,\n * or unshifts) as long such edits happen at the same part of the array or\n * generally sweep through the array from the beginning to the end.\n *\n * The interface for splice buffers also supports large numbers of inputs by\n * passing a single array argument rather passing multiple arguments on the\n * function call stack.\n *\n * @template T\n * Item type.\n */\nexport class SpliceBuffer {\n /**\n * @param {ReadonlyArray<T> | null | undefined} [initial]\n * Initial items (optional).\n * @returns\n * Splice buffer.\n */\n constructor(initial) {\n /** @type {Array<T>} */\n this.left = initial ? [...initial] : [];\n /** @type {Array<T>} */\n this.right = [];\n }\n\n /**\n * Array access;\n * does not move the cursor.\n *\n * @param {number} index\n * Index.\n * @return {T}\n * Item.\n */\n get(index) {\n if (index < 0 || index >= this.left.length + this.right.length) {\n throw new RangeError('Cannot access index `' + index + '` in a splice buffer of size `' + (this.left.length + this.right.length) + '`');\n }\n if (index < this.left.length) return this.left[index];\n return this.right[this.right.length - index + this.left.length - 1];\n }\n\n /**\n * The length of the splice buffer, one greater than the largest index in the\n * array.\n */\n get length() {\n return this.left.length + this.right.length;\n }\n\n /**\n * Remove and return `list[0]`;\n * moves the cursor to `0`.\n *\n * @returns {T | undefined}\n * Item, optional.\n */\n shift() {\n this.setCursor(0);\n return this.right.pop();\n }\n\n /**\n * Slice the buffer to get an array;\n * does not move the cursor.\n *\n * @param {number} start\n * Start.\n * @param {number | null | undefined} [end]\n * End (optional).\n * @returns {Array<T>}\n * Array of items.\n */\n slice(start, end) {\n /** @type {number} */\n const stop = end === null || end === undefined ? Number.POSITIVE_INFINITY : end;\n if (stop < this.left.length) {\n return this.left.slice(start, stop);\n }\n if (start > this.left.length) {\n return this.right.slice(this.right.length - stop + this.left.length, this.right.length - start + this.left.length).reverse();\n }\n return this.left.slice(start).concat(this.right.slice(this.right.length - stop + this.left.length).reverse());\n }\n\n /**\n * Mimics the behavior of Array.prototype.splice() except for the change of\n * interface necessary to avoid segfaults when patching in very large arrays.\n *\n * This operation moves cursor is moved to `start` and results in the cursor\n * placed after any inserted items.\n *\n * @param {number} start\n * Start;\n * zero-based index at which to start changing the array;\n * negative numbers count backwards from the end of the array and values\n * that are out-of bounds are clamped to the appropriate end of the array.\n * @param {number | null | undefined} [deleteCount=0]\n * Delete count (default: `0`);\n * maximum number of elements to delete, starting from start.\n * @param {Array<T> | null | undefined} [items=[]]\n * Items to include in place of the deleted items (default: `[]`).\n * @return {Array<T>}\n * Any removed items.\n */\n splice(start, deleteCount, items) {\n /** @type {number} */\n const count = deleteCount || 0;\n this.setCursor(Math.trunc(start));\n const removed = this.right.splice(this.right.length - count, Number.POSITIVE_INFINITY);\n if (items) chunkedPush(this.left, items);\n return removed.reverse();\n }\n\n /**\n * Remove and return the highest-numbered item in the array, so\n * `list[list.length - 1]`;\n * Moves the cursor to `length`.\n *\n * @returns {T | undefined}\n * Item, optional.\n */\n pop() {\n this.setCursor(Number.POSITIVE_INFINITY);\n return this.left.pop();\n }\n\n /**\n * Inserts a single item to the high-numbered side of the array;\n * moves the cursor to `length`.\n *\n * @param {T} item\n * Item.\n * @returns {undefined}\n * Nothing.\n */\n push(item) {\n this.setCursor(Number.POSITIVE_INFINITY);\n this.left.push(item);\n }\n\n /**\n * Inserts many items to the high-numbered side of the array.\n * Moves the cursor to `length`.\n *\n * @param {Array<T>} items\n * Items.\n * @returns {undefined}\n * Nothing.\n */\n pushMany(items) {\n this.setCursor(Number.POSITIVE_INFINITY);\n chunkedPush(this.left, items);\n }\n\n /**\n * Inserts a single item to the low-numbered side of the array;\n * Moves the cursor to `0`.\n *\n * @param {T} item\n * Item.\n * @returns {undefined}\n * Nothing.\n */\n unshift(item) {\n this.setCursor(0);\n this.right.push(item);\n }\n\n /**\n * Inserts many items to the low-numbered side of the array;\n * moves the cursor to `0`.\n *\n * @param {Array<T>} items\n * Items.\n * @returns {undefined}\n * Nothing.\n */\n unshiftMany(items) {\n this.setCursor(0);\n chunkedPush(this.right, items.reverse());\n }\n\n /**\n * Move the cursor to a specific position in the array. Requires\n * time proportional to the distance moved.\n *\n * If `n < 0`, the cursor will end up at the beginning.\n * If `n > length`, the cursor will end up at the end.\n *\n * @param {number} n\n * Position.\n * @return {undefined}\n * Nothing.\n */\n setCursor(n) {\n if (n === this.left.length || n > this.left.length && this.right.length === 0 || n < 0 && this.left.length === 0) return;\n if (n < this.left.length) {\n // Move cursor to the this.left\n const removed = this.left.splice(n, Number.POSITIVE_INFINITY);\n chunkedPush(this.right, removed.reverse());\n } else {\n // Move cursor to the this.right\n const removed = this.right.splice(this.left.length + this.right.length - n, Number.POSITIVE_INFINITY);\n chunkedPush(this.left, removed.reverse());\n }\n }\n}\n\n/**\n * Avoid stack overflow by pushing items onto the stack in segments\n *\n * @template T\n * Item type.\n * @param {Array<T>} list\n * List to inject into.\n * @param {ReadonlyArray<T>} right\n * Items to inject.\n * @return {undefined}\n * Nothing.\n */\nfunction chunkedPush(list, right) {\n /** @type {number} */\n let chunkStart = 0;\n if (right.length < 10000) {\n list.push(...right);\n } else {\n while (chunkStart < right.length) {\n list.push(...right.slice(chunkStart, chunkStart + 10000));\n chunkStart += 10000;\n }\n }\n}","/**\n * @import {Chunk, Event, Token} from 'micromark-util-types'\n */\n\nimport { splice } from 'micromark-util-chunked';\nimport { SpliceBuffer } from './lib/splice-buffer.js';\n\n// Hidden API exposed for testing.\nexport { SpliceBuffer } from './lib/splice-buffer.js';\n\n/**\n * Tokenize subcontent.\n *\n * @param {Array<Event>} eventsArray\n * List of events.\n * @returns {boolean}\n * Whether subtokens were found.\n */\n// eslint-disable-next-line complexity\nexport function subtokenize(eventsArray) {\n /** @type {Record<string, number>} */\n const jumps = {};\n let index = -1;\n /** @type {Event} */\n let event;\n /** @type {number | undefined} */\n let lineIndex;\n /** @type {number} */\n let otherIndex;\n /** @type {Event} */\n let otherEvent;\n /** @type {Array<Event>} */\n let parameters;\n /** @type {Array<Event>} */\n let subevents;\n /** @type {boolean | undefined} */\n let more;\n const events = new SpliceBuffer(eventsArray);\n while (++index < events.length) {\n while (index in jumps) {\n index = jumps[index];\n }\n event = events.get(index);\n\n // Add a hook for the GFM tasklist extension, which needs to know if text\n // is in the first content of a list item.\n if (index && event[1].type === \"chunkFlow\" && events.get(index - 1)[1].type === \"listItemPrefix\") {\n subevents = event[1]._tokenizer.events;\n otherIndex = 0;\n if (otherIndex < subevents.length && subevents[otherIndex][1].type === \"lineEndingBlank\") {\n otherIndex += 2;\n }\n if (otherIndex < subevents.length && subevents[otherIndex][1].type === \"content\") {\n while (++otherIndex < subevents.length) {\n if (subevents[otherIndex][1].type === \"content\") {\n break;\n }\n if (subevents[otherIndex][1].type === \"chunkText\") {\n subevents[otherIndex][1]._isInFirstContentOfListItem = true;\n otherIndex++;\n }\n }\n }\n }\n\n // Enter.\n if (event[0] === 'enter') {\n if (event[1].contentType) {\n Object.assign(jumps, subcontent(events, index));\n index = jumps[index];\n more = true;\n }\n }\n // Exit.\n else if (event[1]._container) {\n otherIndex = index;\n lineIndex = undefined;\n while (otherIndex--) {\n otherEvent = events.get(otherIndex);\n if (otherEvent[1].type === \"lineEnding\" || otherEvent[1].type === \"lineEndingBlank\") {\n if (otherEvent[0] === 'enter') {\n if (lineIndex) {\n events.get(lineIndex)[1].type = \"lineEndingBlank\";\n }\n otherEvent[1].type = \"lineEnding\";\n lineIndex = otherIndex;\n }\n } else if (otherEvent[1].type === \"linePrefix\" || otherEvent[1].type === \"listItemIndent\") {\n // Move past.\n } else {\n break;\n }\n }\n if (lineIndex) {\n // Fix position.\n event[1].end = {\n ...events.get(lineIndex)[1].start\n };\n\n // Switch container exit w/ line endings.\n parameters = events.slice(lineIndex, index);\n parameters.unshift(event);\n events.splice(lineIndex, index - lineIndex + 1, parameters);\n }\n }\n }\n\n // The changes to the `events` buffer must be copied back into the eventsArray\n splice(eventsArray, 0, Number.POSITIVE_INFINITY, events.slice(0));\n return !more;\n}\n\n/**\n * Tokenize embedded tokens.\n *\n * @param {SpliceBuffer<Event>} events\n * Events.\n * @param {number} eventIndex\n * Index.\n * @returns {Record<string, number>}\n * Gaps.\n */\nfunction subcontent(events, eventIndex) {\n const token = events.get(eventIndex)[1];\n const context = events.get(eventIndex)[2];\n let startPosition = eventIndex - 1;\n /** @type {Array<number>} */\n const startPositions = [];\n let tokenizer = token._tokenizer;\n if (!tokenizer) {\n tokenizer = context.parser[token.contentType](token.start);\n if (token._contentTypeTextTrailing) {\n tokenizer._contentTypeTextTrailing = true;\n }\n }\n const childEvents = tokenizer.events;\n /** @type {Array<[number, number]>} */\n const jumps = [];\n /** @type {Record<string, number>} */\n const gaps = {};\n /** @type {Array<Chunk>} */\n let stream;\n /** @type {Token | undefined} */\n let previous;\n let index = -1;\n /** @type {Token | undefined} */\n let current = token;\n let adjust = 0;\n let start = 0;\n const breaks = [start];\n\n // Loop forward through the linked tokens to pass them in order to the\n // subtokenizer.\n while (current) {\n // Find the position of the event for this token.\n while (events.get(++startPosition)[1] !== current) {\n // Empty.\n }\n startPositions.push(startPosition);\n if (!current._tokenizer) {\n stream = context.sliceStream(current);\n if (!current.next) {\n stream.push(null);\n }\n if (previous) {\n tokenizer.defineSkip(current.start);\n }\n if (current._isInFirstContentOfListItem) {\n tokenizer._gfmTasklistFirstContentOfListItem = true;\n }\n tokenizer.write(stream);\n if (current._isInFirstContentOfListItem) {\n tokenizer._gfmTasklistFirstContentOfListItem = undefined;\n }\n }\n\n // Unravel the next token.\n previous = current;\n current = current.next;\n }\n\n // Now, loop back through all events (and linked tokens), to figure out which\n // parts belong where.\n current = token;\n while (++index < childEvents.length) {\n if (\n // Find a void token that includes a break.\n childEvents[index][0] === 'exit' && childEvents[index - 1][0] === 'enter' && childEvents[index][1].type === childEvents[index - 1][1].type && childEvents[index][1].start.line !== childEvents[index][1].end.line) {\n start = index + 1;\n breaks.push(start);\n // Help GC.\n current._tokenizer = undefined;\n current.previous = undefined;\n current = current.next;\n }\n }\n\n // Help GC.\n tokenizer.events = [];\n\n // If there’s one more token (which is the cases for lines that end in an\n // EOF), that’s perfect: the last point we found starts it.\n // If there isn’t then make sure any remaining content is added to it.\n if (current) {\n // Help GC.\n current._tokenizer = undefined;\n current.previous = undefined;\n } else {\n breaks.pop();\n }\n\n // Now splice the events from the subtokenizer into the current events,\n // moving back to front so that splice indices aren’t affected.\n index = breaks.length;\n while (index--) {\n const slice = childEvents.slice(breaks[index], breaks[index + 1]);\n const start = startPositions.pop();\n jumps.push([start, start + slice.length - 1]);\n events.splice(start, 2, slice);\n }\n jumps.reverse();\n index = -1;\n while (++index < jumps.length) {\n gaps[adjust + jumps[index][0]] = adjust + jumps[index][1];\n adjust += jumps[index][1] - jumps[index][0] - 1;\n }\n return gaps;\n}","/**\n * @import {\n * Construct,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\nimport { subtokenize } from 'micromark-util-subtokenize';\n/**\n * No name because it must not be turned off.\n * @type {Construct}\n */\nexport const content = {\n resolve: resolveContent,\n tokenize: tokenizeContent\n};\n\n/** @type {Construct} */\nconst continuationConstruct = {\n partial: true,\n tokenize: tokenizeContinuation\n};\n\n/**\n * Content is transparent: it’s parsed right now. That way, definitions are also\n * parsed right now: before text in paragraphs (specifically, media) are parsed.\n *\n * @type {Resolver}\n */\nfunction resolveContent(events) {\n subtokenize(events);\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeContent(effects, ok) {\n /** @type {Token | undefined} */\n let previous;\n return chunkStart;\n\n /**\n * Before a content chunk.\n *\n * ```markdown\n * > | abc\n * ^\n * ```\n *\n * @type {State}\n */\n function chunkStart(code) {\n effects.enter(\"content\");\n previous = effects.enter(\"chunkContent\", {\n contentType: \"content\"\n });\n return chunkInside(code);\n }\n\n /**\n * In a content chunk.\n *\n * ```markdown\n * > | abc\n * ^^^\n * ```\n *\n * @type {State}\n */\n function chunkInside(code) {\n if (code === null) {\n return contentEnd(code);\n }\n\n // To do: in `markdown-rs`, each line is parsed on its own, and everything\n // is stitched together resolving.\n if (markdownLineEnding(code)) {\n return effects.check(continuationConstruct, contentContinue, contentEnd)(code);\n }\n\n // Data.\n effects.consume(code);\n return chunkInside;\n }\n\n /**\n *\n *\n * @type {State}\n */\n function contentEnd(code) {\n effects.exit(\"chunkContent\");\n effects.exit(\"content\");\n return ok(code);\n }\n\n /**\n *\n *\n * @type {State}\n */\n function contentContinue(code) {\n effects.consume(code);\n effects.exit(\"chunkContent\");\n previous.next = effects.enter(\"chunkContent\", {\n contentType: \"content\",\n previous\n });\n previous = previous.next;\n return chunkInside;\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeContinuation(effects, ok, nok) {\n const self = this;\n return startLookahead;\n\n /**\n *\n *\n * @type {State}\n */\n function startLookahead(code) {\n effects.exit(\"chunkContent\");\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return factorySpace(effects, prefixed, \"linePrefix\");\n }\n\n /**\n *\n *\n * @type {State}\n */\n function prefixed(code) {\n if (code === null || markdownLineEnding(code)) {\n return nok(code);\n }\n\n // Always populated by defaults.\n\n const tail = self.events[self.events.length - 1];\n if (!self.parser.constructs.disable.null.includes('codeIndented') && tail && tail[1].type === \"linePrefix\" && tail[2].sliceSerialize(tail[1], true).length >= 4) {\n return ok(code);\n }\n return effects.interrupt(self.parser.constructs.flow, nok, ok)(code);\n }\n}","/**\n * @import {Effects, State, TokenType} from 'micromark-util-types'\n */\n\nimport { asciiControl, markdownLineEndingOrSpace, markdownLineEnding } from 'micromark-util-character';\n/**\n * Parse destinations.\n *\n * ###### Examples\n *\n * ```markdown\n * <a>\n * <a\\>b>\n * <a b>\n * <a)>\n * a\n * a\\)b\n * a(b)c\n * a(b)\n * ```\n *\n * @param {Effects} effects\n * Context.\n * @param {State} ok\n * State switched to when successful.\n * @param {State} nok\n * State switched to when unsuccessful.\n * @param {TokenType} type\n * Type for whole (`<a>` or `b`).\n * @param {TokenType} literalType\n * Type when enclosed (`<a>`).\n * @param {TokenType} literalMarkerType\n * Type for enclosing (`<` and `>`).\n * @param {TokenType} rawType\n * Type when not enclosed (`b`).\n * @param {TokenType} stringType\n * Type for the value (`a` or `b`).\n * @param {number | undefined} [max=Infinity]\n * Depth of nested parens (inclusive).\n * @returns {State}\n * Start state.\n */\nexport function factoryDestination(effects, ok, nok, type, literalType, literalMarkerType, rawType, stringType, max) {\n const limit = max || Number.POSITIVE_INFINITY;\n let balance = 0;\n return start;\n\n /**\n * Start of destination.\n *\n * ```markdown\n * > | <aa>\n * ^\n * > | aa\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n if (code === 60) {\n effects.enter(type);\n effects.enter(literalType);\n effects.enter(literalMarkerType);\n effects.consume(code);\n effects.exit(literalMarkerType);\n return enclosedBefore;\n }\n\n // ASCII control, space, closing paren.\n if (code === null || code === 32 || code === 41 || asciiControl(code)) {\n return nok(code);\n }\n effects.enter(type);\n effects.enter(rawType);\n effects.enter(stringType);\n effects.enter(\"chunkString\", {\n contentType: \"string\"\n });\n return raw(code);\n }\n\n /**\n * After `<`, at an enclosed destination.\n *\n * ```markdown\n * > | <aa>\n * ^\n * ```\n *\n * @type {State}\n */\n function enclosedBefore(code) {\n if (code === 62) {\n effects.enter(literalMarkerType);\n effects.consume(code);\n effects.exit(literalMarkerType);\n effects.exit(literalType);\n effects.exit(type);\n return ok;\n }\n effects.enter(stringType);\n effects.enter(\"chunkString\", {\n contentType: \"string\"\n });\n return enclosed(code);\n }\n\n /**\n * In enclosed destination.\n *\n * ```markdown\n * > | <aa>\n * ^\n * ```\n *\n * @type {State}\n */\n function enclosed(code) {\n if (code === 62) {\n effects.exit(\"chunkString\");\n effects.exit(stringType);\n return enclosedBefore(code);\n }\n if (code === null || code === 60 || markdownLineEnding(code)) {\n return nok(code);\n }\n effects.consume(code);\n return code === 92 ? enclosedEscape : enclosed;\n }\n\n /**\n * After `\\`, at a special character.\n *\n * ```markdown\n * > | <a\\*a>\n * ^\n * ```\n *\n * @type {State}\n */\n function enclosedEscape(code) {\n if (code === 60 || code === 62 || code === 92) {\n effects.consume(code);\n return enclosed;\n }\n return enclosed(code);\n }\n\n /**\n * In raw destination.\n *\n * ```markdown\n * > | aa\n * ^\n * ```\n *\n * @type {State}\n */\n function raw(code) {\n if (!balance && (code === null || code === 41 || markdownLineEndingOrSpace(code))) {\n effects.exit(\"chunkString\");\n effects.exit(stringType);\n effects.exit(rawType);\n effects.exit(type);\n return ok(code);\n }\n if (balance < limit && code === 40) {\n effects.consume(code);\n balance++;\n return raw;\n }\n if (code === 41) {\n effects.consume(code);\n balance--;\n return raw;\n }\n\n // ASCII control (but *not* `\\0`) and space and `(`.\n // Note: in `markdown-rs`, `\\0` exists in codes, in `micromark-js` it\n // doesn’t.\n if (code === null || code === 32 || code === 40 || asciiControl(code)) {\n return nok(code);\n }\n effects.consume(code);\n return code === 92 ? rawEscape : raw;\n }\n\n /**\n * After `\\`, at special character.\n *\n * ```markdown\n * > | a\\*a\n * ^\n * ```\n *\n * @type {State}\n */\n function rawEscape(code) {\n if (code === 40 || code === 41 || code === 92) {\n effects.consume(code);\n return raw;\n }\n return raw(code);\n }\n}","/**\n * @import {\n * Effects,\n * State,\n * TokenizeContext,\n * TokenType\n * } from 'micromark-util-types'\n */\n\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/**\n * Parse labels.\n *\n * > 👉 **Note**: labels in markdown are capped at 999 characters in the string.\n *\n * ###### Examples\n *\n * ```markdown\n * [a]\n * [a\n * b]\n * [a\\]b]\n * ```\n *\n * @this {TokenizeContext}\n * Tokenize context.\n * @param {Effects} effects\n * Context.\n * @param {State} ok\n * State switched to when successful.\n * @param {State} nok\n * State switched to when unsuccessful.\n * @param {TokenType} type\n * Type of the whole label (`[a]`).\n * @param {TokenType} markerType\n * Type for the markers (`[` and `]`).\n * @param {TokenType} stringType\n * Type for the identifier (`a`).\n * @returns {State}\n * Start state.\n */\nexport function factoryLabel(effects, ok, nok, type, markerType, stringType) {\n const self = this;\n let size = 0;\n /** @type {boolean} */\n let seen;\n return start;\n\n /**\n * Start of label.\n *\n * ```markdown\n * > | [a]\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(type);\n effects.enter(markerType);\n effects.consume(code);\n effects.exit(markerType);\n effects.enter(stringType);\n return atBreak;\n }\n\n /**\n * In label, at something, before something else.\n *\n * ```markdown\n * > | [a]\n * ^\n * ```\n *\n * @type {State}\n */\n function atBreak(code) {\n if (size > 999 || code === null || code === 91 || code === 93 && !seen ||\n // To do: remove in the future once we’ve switched from\n // `micromark-extension-footnote` to `micromark-extension-gfm-footnote`,\n // which doesn’t need this.\n // Hidden footnotes hook.\n /* c8 ignore next 3 */\n code === 94 && !size && '_hiddenFootnoteSupport' in self.parser.constructs) {\n return nok(code);\n }\n if (code === 93) {\n effects.exit(stringType);\n effects.enter(markerType);\n effects.consume(code);\n effects.exit(markerType);\n effects.exit(type);\n return ok;\n }\n\n // To do: indent? Link chunks and EOLs together?\n if (markdownLineEnding(code)) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return atBreak;\n }\n effects.enter(\"chunkString\", {\n contentType: \"string\"\n });\n return labelInside(code);\n }\n\n /**\n * In label, in text.\n *\n * ```markdown\n * > | [a]\n * ^\n * ```\n *\n * @type {State}\n */\n function labelInside(code) {\n if (code === null || code === 91 || code === 93 || markdownLineEnding(code) || size++ > 999) {\n effects.exit(\"chunkString\");\n return atBreak(code);\n }\n effects.consume(code);\n if (!seen) seen = !markdownSpace(code);\n return code === 92 ? labelEscape : labelInside;\n }\n\n /**\n * After `\\`, at a special character.\n *\n * ```markdown\n * > | [a\\*a]\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEscape(code) {\n if (code === 91 || code === 92 || code === 93) {\n effects.consume(code);\n size++;\n return labelInside;\n }\n return labelInside(code);\n }\n}","/**\n * @import {\n * Code,\n * Effects,\n * State,\n * TokenType\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\n/**\n * Parse titles.\n *\n * ###### Examples\n *\n * ```markdown\n * \"a\"\n * 'b'\n * (c)\n * \"a\n * b\"\n * 'a\n * b'\n * (a\\)b)\n * ```\n *\n * @param {Effects} effects\n * Context.\n * @param {State} ok\n * State switched to when successful.\n * @param {State} nok\n * State switched to when unsuccessful.\n * @param {TokenType} type\n * Type of the whole title (`\"a\"`, `'b'`, `(c)`).\n * @param {TokenType} markerType\n * Type for the markers (`\"`, `'`, `(`, and `)`).\n * @param {TokenType} stringType\n * Type for the value (`a`).\n * @returns {State}\n * Start state.\n */\nexport function factoryTitle(effects, ok, nok, type, markerType, stringType) {\n /** @type {NonNullable<Code>} */\n let marker;\n return start;\n\n /**\n * Start of title.\n *\n * ```markdown\n * > | \"a\"\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n if (code === 34 || code === 39 || code === 40) {\n effects.enter(type);\n effects.enter(markerType);\n effects.consume(code);\n effects.exit(markerType);\n marker = code === 40 ? 41 : code;\n return begin;\n }\n return nok(code);\n }\n\n /**\n * After opening marker.\n *\n * This is also used at the closing marker.\n *\n * ```markdown\n * > | \"a\"\n * ^\n * ```\n *\n * @type {State}\n */\n function begin(code) {\n if (code === marker) {\n effects.enter(markerType);\n effects.consume(code);\n effects.exit(markerType);\n effects.exit(type);\n return ok;\n }\n effects.enter(stringType);\n return atBreak(code);\n }\n\n /**\n * At something, before something else.\n *\n * ```markdown\n * > | \"a\"\n * ^\n * ```\n *\n * @type {State}\n */\n function atBreak(code) {\n if (code === marker) {\n effects.exit(stringType);\n return begin(marker);\n }\n if (code === null) {\n return nok(code);\n }\n\n // Note: blank lines can’t exist in content.\n if (markdownLineEnding(code)) {\n // To do: use `space_or_tab_eol_with_options`, connect.\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return factorySpace(effects, atBreak, \"linePrefix\");\n }\n effects.enter(\"chunkString\", {\n contentType: \"string\"\n });\n return inside(code);\n }\n\n /**\n *\n *\n * @type {State}\n */\n function inside(code) {\n if (code === marker || code === null || markdownLineEnding(code)) {\n effects.exit(\"chunkString\");\n return atBreak(code);\n }\n effects.consume(code);\n return code === 92 ? escape : inside;\n }\n\n /**\n * After `\\`, at a special character.\n *\n * ```markdown\n * > | \"a\\*b\"\n * ^\n * ```\n *\n * @type {State}\n */\n function escape(code) {\n if (code === marker || code === 92) {\n effects.consume(code);\n return inside;\n }\n return inside(code);\n }\n}","/**\n * @import {Effects, State} from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/**\n * Parse spaces and tabs.\n *\n * There is no `nok` parameter:\n *\n * * line endings or spaces in markdown are often optional, in which case this\n * factory can be used and `ok` will be switched to whether spaces were found\n * or not\n * * one line ending or space can be detected with\n * `markdownLineEndingOrSpace(code)` right before using `factoryWhitespace`\n *\n * @param {Effects} effects\n * Context.\n * @param {State} ok\n * State switched to when successful.\n * @returns {State}\n * Start state.\n */\nexport function factoryWhitespace(effects, ok) {\n /** @type {boolean} */\n let seen;\n return start;\n\n /** @type {State} */\n function start(code) {\n if (markdownLineEnding(code)) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n seen = true;\n return start;\n }\n if (markdownSpace(code)) {\n return factorySpace(effects, start, seen ? \"linePrefix\" : \"lineSuffix\")(code);\n }\n return ok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factoryDestination } from 'micromark-factory-destination';\nimport { factoryLabel } from 'micromark-factory-label';\nimport { factorySpace } from 'micromark-factory-space';\nimport { factoryTitle } from 'micromark-factory-title';\nimport { factoryWhitespace } from 'micromark-factory-whitespace';\nimport { markdownLineEndingOrSpace, markdownLineEnding, markdownSpace } from 'micromark-util-character';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\n/** @type {Construct} */\nexport const definition = {\n name: 'definition',\n tokenize: tokenizeDefinition\n};\n\n/** @type {Construct} */\nconst titleBefore = {\n partial: true,\n tokenize: tokenizeTitleBefore\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeDefinition(effects, ok, nok) {\n const self = this;\n /** @type {string} */\n let identifier;\n return start;\n\n /**\n * At start of a definition.\n *\n * ```markdown\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // Do not interrupt paragraphs (but do follow definitions).\n // To do: do `interrupt` the way `markdown-rs` does.\n // To do: parse whitespace the way `markdown-rs` does.\n effects.enter(\"definition\");\n return before(code);\n }\n\n /**\n * After optional whitespace, at `[`.\n *\n * ```markdown\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function before(code) {\n // To do: parse whitespace the way `markdown-rs` does.\n\n return factoryLabel.call(self, effects, labelAfter,\n // Note: we don’t need to reset the way `markdown-rs` does.\n nok, \"definitionLabel\", \"definitionLabelMarker\", \"definitionLabelString\")(code);\n }\n\n /**\n * After label.\n *\n * ```markdown\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function labelAfter(code) {\n identifier = normalizeIdentifier(self.sliceSerialize(self.events[self.events.length - 1][1]).slice(1, -1));\n if (code === 58) {\n effects.enter(\"definitionMarker\");\n effects.consume(code);\n effects.exit(\"definitionMarker\");\n return markerAfter;\n }\n return nok(code);\n }\n\n /**\n * After marker.\n *\n * ```markdown\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function markerAfter(code) {\n // Note: whitespace is optional.\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, destinationBefore)(code) : destinationBefore(code);\n }\n\n /**\n * Before destination.\n *\n * ```markdown\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function destinationBefore(code) {\n return factoryDestination(effects, destinationAfter,\n // Note: we don’t need to reset the way `markdown-rs` does.\n nok, \"definitionDestination\", \"definitionDestinationLiteral\", \"definitionDestinationLiteralMarker\", \"definitionDestinationRaw\", \"definitionDestinationString\")(code);\n }\n\n /**\n * After destination.\n *\n * ```markdown\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function destinationAfter(code) {\n return effects.attempt(titleBefore, after, after)(code);\n }\n\n /**\n * After definition.\n *\n * ```markdown\n * > | [a]: b\n * ^\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n return markdownSpace(code) ? factorySpace(effects, afterWhitespace, \"whitespace\")(code) : afterWhitespace(code);\n }\n\n /**\n * After definition, after optional whitespace.\n *\n * ```markdown\n * > | [a]: b\n * ^\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function afterWhitespace(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"definition\");\n\n // Note: we don’t care about uniqueness.\n // It’s likely that that doesn’t happen very frequently.\n // It is more likely that it wastes precious time.\n self.parser.defined.push(identifier);\n\n // To do: `markdown-rs` interrupt.\n // // You’d be interrupting.\n // tokenizer.interrupt = true\n return ok(code);\n }\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeTitleBefore(effects, ok, nok) {\n return titleBefore;\n\n /**\n * After destination, at whitespace.\n *\n * ```markdown\n * > | [a]: b\n * ^\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function titleBefore(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, beforeMarker)(code) : nok(code);\n }\n\n /**\n * At title.\n *\n * ```markdown\n * | [a]: b\n * > | \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function beforeMarker(code) {\n return factoryTitle(effects, titleAfter, nok, \"definitionTitle\", \"definitionTitleMarker\", \"definitionTitleString\")(code);\n }\n\n /**\n * After title.\n *\n * ```markdown\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function titleAfter(code) {\n return markdownSpace(code) ? factorySpace(effects, titleAfterOptionalWhitespace, \"whitespace\")(code) : titleAfterOptionalWhitespace(code);\n }\n\n /**\n * After title, after optional whitespace.\n *\n * ```markdown\n * > | [a]: b \"c\"\n * ^\n * ```\n *\n * @type {State}\n */\n function titleAfterOptionalWhitespace(code) {\n return code === null || markdownLineEnding(code) ? ok(code) : nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {Construct} */\nexport const hardBreakEscape = {\n name: 'hardBreakEscape',\n tokenize: tokenizeHardBreakEscape\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeHardBreakEscape(effects, ok, nok) {\n return start;\n\n /**\n * Start of a hard break (escape).\n *\n * ```markdown\n * > | a\\\n * ^\n * | b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"hardBreakEscape\");\n effects.consume(code);\n return after;\n }\n\n /**\n * After `\\`, at eol.\n *\n * ```markdown\n * > | a\\\n * ^\n * | b\n * ```\n *\n * @type {State}\n */\n function after(code) {\n if (markdownLineEnding(code)) {\n effects.exit(\"hardBreakEscape\");\n return ok(code);\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEndingOrSpace, markdownLineEnding, markdownSpace } from 'micromark-util-character';\nimport { splice } from 'micromark-util-chunked';\n/** @type {Construct} */\nexport const headingAtx = {\n name: 'headingAtx',\n resolve: resolveHeadingAtx,\n tokenize: tokenizeHeadingAtx\n};\n\n/** @type {Resolver} */\nfunction resolveHeadingAtx(events, context) {\n let contentEnd = events.length - 2;\n let contentStart = 3;\n /** @type {Token} */\n let content;\n /** @type {Token} */\n let text;\n\n // Prefix whitespace, part of the opening.\n if (events[contentStart][1].type === \"whitespace\") {\n contentStart += 2;\n }\n\n // Suffix whitespace, part of the closing.\n if (contentEnd - 2 > contentStart && events[contentEnd][1].type === \"whitespace\") {\n contentEnd -= 2;\n }\n if (events[contentEnd][1].type === \"atxHeadingSequence\" && (contentStart === contentEnd - 1 || contentEnd - 4 > contentStart && events[contentEnd - 2][1].type === \"whitespace\")) {\n contentEnd -= contentStart + 1 === contentEnd ? 2 : 4;\n }\n if (contentEnd > contentStart) {\n content = {\n type: \"atxHeadingText\",\n start: events[contentStart][1].start,\n end: events[contentEnd][1].end\n };\n text = {\n type: \"chunkText\",\n start: events[contentStart][1].start,\n end: events[contentEnd][1].end,\n contentType: \"text\"\n };\n splice(events, contentStart, contentEnd - contentStart + 1, [['enter', content, context], ['enter', text, context], ['exit', text, context], ['exit', content, context]]);\n }\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeHeadingAtx(effects, ok, nok) {\n let size = 0;\n return start;\n\n /**\n * Start of a heading (atx).\n *\n * ```markdown\n * > | ## aa\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // To do: parse indent like `markdown-rs`.\n effects.enter(\"atxHeading\");\n return before(code);\n }\n\n /**\n * After optional whitespace, at `#`.\n *\n * ```markdown\n * > | ## aa\n * ^\n * ```\n *\n * @type {State}\n */\n function before(code) {\n effects.enter(\"atxHeadingSequence\");\n return sequenceOpen(code);\n }\n\n /**\n * In opening sequence.\n *\n * ```markdown\n * > | ## aa\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceOpen(code) {\n if (code === 35 && size++ < 6) {\n effects.consume(code);\n return sequenceOpen;\n }\n\n // Always at least one `#`.\n if (code === null || markdownLineEndingOrSpace(code)) {\n effects.exit(\"atxHeadingSequence\");\n return atBreak(code);\n }\n return nok(code);\n }\n\n /**\n * After something, before something else.\n *\n * ```markdown\n * > | ## aa\n * ^\n * ```\n *\n * @type {State}\n */\n function atBreak(code) {\n if (code === 35) {\n effects.enter(\"atxHeadingSequence\");\n return sequenceFurther(code);\n }\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"atxHeading\");\n // To do: interrupt like `markdown-rs`.\n // // Feel free to interrupt.\n // tokenizer.interrupt = false\n return ok(code);\n }\n if (markdownSpace(code)) {\n return factorySpace(effects, atBreak, \"whitespace\")(code);\n }\n\n // To do: generate `data` tokens, add the `text` token later.\n // Needs edit map, see: `markdown.rs`.\n effects.enter(\"atxHeadingText\");\n return data(code);\n }\n\n /**\n * In further sequence (after whitespace).\n *\n * Could be normal “visible” hashes in the heading or a final sequence.\n *\n * ```markdown\n * > | ## aa ##\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceFurther(code) {\n if (code === 35) {\n effects.consume(code);\n return sequenceFurther;\n }\n effects.exit(\"atxHeadingSequence\");\n return atBreak(code);\n }\n\n /**\n * In text.\n *\n * ```markdown\n * > | ## aa\n * ^\n * ```\n *\n * @type {State}\n */\n function data(code) {\n if (code === null || code === 35 || markdownLineEndingOrSpace(code)) {\n effects.exit(\"atxHeadingText\");\n return atBreak(code);\n }\n effects.consume(code);\n return data;\n }\n}","/**\n * List of lowercase HTML “block” tag names.\n *\n * The list, when parsing HTML (flow), results in more relaxed rules (condition\n * 6).\n * Because they are known blocks, the HTML-like syntax doesn’t have to be\n * strictly parsed.\n * For tag names not in this list, a more strict algorithm (condition 7) is used\n * to detect whether the HTML-like syntax is seen as HTML (flow) or not.\n *\n * This is copied from:\n * <https://spec.commonmark.org/0.30/#html-blocks>.\n *\n * > 👉 **Note**: `search` was added in `CommonMark@0.31`.\n */\nexport const htmlBlockNames = [\n 'address',\n 'article',\n 'aside',\n 'base',\n 'basefont',\n 'blockquote',\n 'body',\n 'caption',\n 'center',\n 'col',\n 'colgroup',\n 'dd',\n 'details',\n 'dialog',\n 'dir',\n 'div',\n 'dl',\n 'dt',\n 'fieldset',\n 'figcaption',\n 'figure',\n 'footer',\n 'form',\n 'frame',\n 'frameset',\n 'h1',\n 'h2',\n 'h3',\n 'h4',\n 'h5',\n 'h6',\n 'head',\n 'header',\n 'hr',\n 'html',\n 'iframe',\n 'legend',\n 'li',\n 'link',\n 'main',\n 'menu',\n 'menuitem',\n 'nav',\n 'noframes',\n 'ol',\n 'optgroup',\n 'option',\n 'p',\n 'param',\n 'search',\n 'section',\n 'summary',\n 'table',\n 'tbody',\n 'td',\n 'tfoot',\n 'th',\n 'thead',\n 'title',\n 'tr',\n 'track',\n 'ul'\n]\n\n/**\n * List of lowercase HTML “raw” tag names.\n *\n * The list, when parsing HTML (flow), results in HTML that can include lines\n * without exiting, until a closing tag also in this list is found (condition\n * 1).\n *\n * This module is copied from:\n * <https://spec.commonmark.org/0.30/#html-blocks>.\n *\n * > 👉 **Note**: `textarea` was added in `CommonMark@0.30`.\n */\nexport const htmlRawNames = ['pre', 'script', 'style', 'textarea']\n","/**\n * @import {\n * Code,\n * Construct,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { asciiAlphanumeric, asciiAlpha, markdownLineEndingOrSpace, markdownLineEnding, markdownSpace } from 'micromark-util-character';\nimport { htmlBlockNames, htmlRawNames } from 'micromark-util-html-tag-name';\nimport { blankLine } from './blank-line.js';\n\n/** @type {Construct} */\nexport const htmlFlow = {\n concrete: true,\n name: 'htmlFlow',\n resolveTo: resolveToHtmlFlow,\n tokenize: tokenizeHtmlFlow\n};\n\n/** @type {Construct} */\nconst blankLineBefore = {\n partial: true,\n tokenize: tokenizeBlankLineBefore\n};\nconst nonLazyContinuationStart = {\n partial: true,\n tokenize: tokenizeNonLazyContinuationStart\n};\n\n/** @type {Resolver} */\nfunction resolveToHtmlFlow(events) {\n let index = events.length;\n while (index--) {\n if (events[index][0] === 'enter' && events[index][1].type === \"htmlFlow\") {\n break;\n }\n }\n if (index > 1 && events[index - 2][1].type === \"linePrefix\") {\n // Add the prefix start to the HTML token.\n events[index][1].start = events[index - 2][1].start;\n // Add the prefix start to the HTML line token.\n events[index + 1][1].start = events[index - 2][1].start;\n // Remove the line prefix.\n events.splice(index - 2, 2);\n }\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeHtmlFlow(effects, ok, nok) {\n const self = this;\n /** @type {number} */\n let marker;\n /** @type {boolean} */\n let closingTag;\n /** @type {string} */\n let buffer;\n /** @type {number} */\n let index;\n /** @type {Code} */\n let markerB;\n return start;\n\n /**\n * Start of HTML (flow).\n *\n * ```markdown\n * > | <x />\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // To do: parse indent like `markdown-rs`.\n return before(code);\n }\n\n /**\n * At `<`, after optional whitespace.\n *\n * ```markdown\n * > | <x />\n * ^\n * ```\n *\n * @type {State}\n */\n function before(code) {\n effects.enter(\"htmlFlow\");\n effects.enter(\"htmlFlowData\");\n effects.consume(code);\n return open;\n }\n\n /**\n * After `<`, at tag name or other stuff.\n *\n * ```markdown\n * > | <x />\n * ^\n * > | <!doctype>\n * ^\n * > | <!--xxx-->\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 33) {\n effects.consume(code);\n return declarationOpen;\n }\n if (code === 47) {\n effects.consume(code);\n closingTag = true;\n return tagCloseStart;\n }\n if (code === 63) {\n effects.consume(code);\n marker = 3;\n // To do:\n // tokenizer.concrete = true\n // To do: use `markdown-rs` style interrupt.\n // While we’re in an instruction instead of a declaration, we’re on a `?`\n // right now, so we do need to search for `>`, similar to declarations.\n return self.interrupt ? ok : continuationDeclarationInside;\n }\n\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n // Always the case.\n effects.consume(code);\n buffer = String.fromCharCode(code);\n return tagName;\n }\n return nok(code);\n }\n\n /**\n * After `<!`, at declaration, comment, or CDATA.\n *\n * ```markdown\n * > | <!doctype>\n * ^\n * > | <!--xxx-->\n * ^\n * > | <![CDATA[>&<]]>\n * ^\n * ```\n *\n * @type {State}\n */\n function declarationOpen(code) {\n if (code === 45) {\n effects.consume(code);\n marker = 2;\n return commentOpenInside;\n }\n if (code === 91) {\n effects.consume(code);\n marker = 5;\n index = 0;\n return cdataOpenInside;\n }\n\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n effects.consume(code);\n marker = 4;\n // // Do not form containers.\n // tokenizer.concrete = true\n return self.interrupt ? ok : continuationDeclarationInside;\n }\n return nok(code);\n }\n\n /**\n * After `<!-`, inside a comment, at another `-`.\n *\n * ```markdown\n * > | <!--xxx-->\n * ^\n * ```\n *\n * @type {State}\n */\n function commentOpenInside(code) {\n if (code === 45) {\n effects.consume(code);\n // // Do not form containers.\n // tokenizer.concrete = true\n return self.interrupt ? ok : continuationDeclarationInside;\n }\n return nok(code);\n }\n\n /**\n * After `<![`, inside CDATA, expecting `CDATA[`.\n *\n * ```markdown\n * > | <![CDATA[>&<]]>\n * ^^^^^^\n * ```\n *\n * @type {State}\n */\n function cdataOpenInside(code) {\n const value = \"CDATA[\";\n if (code === value.charCodeAt(index++)) {\n effects.consume(code);\n if (index === value.length) {\n // // Do not form containers.\n // tokenizer.concrete = true\n return self.interrupt ? ok : continuation;\n }\n return cdataOpenInside;\n }\n return nok(code);\n }\n\n /**\n * After `</`, in closing tag, at tag name.\n *\n * ```markdown\n * > | </x>\n * ^\n * ```\n *\n * @type {State}\n */\n function tagCloseStart(code) {\n if (asciiAlpha(code)) {\n // Always the case.\n effects.consume(code);\n buffer = String.fromCharCode(code);\n return tagName;\n }\n return nok(code);\n }\n\n /**\n * In tag name.\n *\n * ```markdown\n * > | <ab>\n * ^^\n * > | </ab>\n * ^^\n * ```\n *\n * @type {State}\n */\n function tagName(code) {\n if (code === null || code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n const slash = code === 47;\n const name = buffer.toLowerCase();\n if (!slash && !closingTag && htmlRawNames.includes(name)) {\n marker = 1;\n // // Do not form containers.\n // tokenizer.concrete = true\n return self.interrupt ? ok(code) : continuation(code);\n }\n if (htmlBlockNames.includes(buffer.toLowerCase())) {\n marker = 6;\n if (slash) {\n effects.consume(code);\n return basicSelfClosing;\n }\n\n // // Do not form containers.\n // tokenizer.concrete = true\n return self.interrupt ? ok(code) : continuation(code);\n }\n marker = 7;\n // Do not support complete HTML when interrupting.\n return self.interrupt && !self.parser.lazy[self.now().line] ? nok(code) : closingTag ? completeClosingTagAfter(code) : completeAttributeNameBefore(code);\n }\n\n // ASCII alphanumerical and `-`.\n if (code === 45 || asciiAlphanumeric(code)) {\n effects.consume(code);\n buffer += String.fromCharCode(code);\n return tagName;\n }\n return nok(code);\n }\n\n /**\n * After closing slash of a basic tag name.\n *\n * ```markdown\n * > | <div/>\n * ^\n * ```\n *\n * @type {State}\n */\n function basicSelfClosing(code) {\n if (code === 62) {\n effects.consume(code);\n // // Do not form containers.\n // tokenizer.concrete = true\n return self.interrupt ? ok : continuation;\n }\n return nok(code);\n }\n\n /**\n * After closing slash of a complete tag name.\n *\n * ```markdown\n * > | <x/>\n * ^\n * ```\n *\n * @type {State}\n */\n function completeClosingTagAfter(code) {\n if (markdownSpace(code)) {\n effects.consume(code);\n return completeClosingTagAfter;\n }\n return completeEnd(code);\n }\n\n /**\n * At an attribute name.\n *\n * At first, this state is used after a complete tag name, after whitespace,\n * where it expects optional attributes or the end of the tag.\n * It is also reused after attributes, when expecting more optional\n * attributes.\n *\n * ```markdown\n * > | <a />\n * ^\n * > | <a :b>\n * ^\n * > | <a _b>\n * ^\n * > | <a b>\n * ^\n * > | <a >\n * ^\n * ```\n *\n * @type {State}\n */\n function completeAttributeNameBefore(code) {\n if (code === 47) {\n effects.consume(code);\n return completeEnd;\n }\n\n // ASCII alphanumerical and `:` and `_`.\n if (code === 58 || code === 95 || asciiAlpha(code)) {\n effects.consume(code);\n return completeAttributeName;\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return completeAttributeNameBefore;\n }\n return completeEnd(code);\n }\n\n /**\n * In attribute name.\n *\n * ```markdown\n * > | <a :b>\n * ^\n * > | <a _b>\n * ^\n * > | <a b>\n * ^\n * ```\n *\n * @type {State}\n */\n function completeAttributeName(code) {\n // ASCII alphanumerical and `-`, `.`, `:`, and `_`.\n if (code === 45 || code === 46 || code === 58 || code === 95 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return completeAttributeName;\n }\n return completeAttributeNameAfter(code);\n }\n\n /**\n * After attribute name, at an optional initializer, the end of the tag, or\n * whitespace.\n *\n * ```markdown\n * > | <a b>\n * ^\n * > | <a b=c>\n * ^\n * ```\n *\n * @type {State}\n */\n function completeAttributeNameAfter(code) {\n if (code === 61) {\n effects.consume(code);\n return completeAttributeValueBefore;\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return completeAttributeNameAfter;\n }\n return completeAttributeNameBefore(code);\n }\n\n /**\n * Before unquoted, double quoted, or single quoted attribute value, allowing\n * whitespace.\n *\n * ```markdown\n * > | <a b=c>\n * ^\n * > | <a b=\"c\">\n * ^\n * ```\n *\n * @type {State}\n */\n function completeAttributeValueBefore(code) {\n if (code === null || code === 60 || code === 61 || code === 62 || code === 96) {\n return nok(code);\n }\n if (code === 34 || code === 39) {\n effects.consume(code);\n markerB = code;\n return completeAttributeValueQuoted;\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return completeAttributeValueBefore;\n }\n return completeAttributeValueUnquoted(code);\n }\n\n /**\n * In double or single quoted attribute value.\n *\n * ```markdown\n * > | <a b=\"c\">\n * ^\n * > | <a b='c'>\n * ^\n * ```\n *\n * @type {State}\n */\n function completeAttributeValueQuoted(code) {\n if (code === markerB) {\n effects.consume(code);\n markerB = null;\n return completeAttributeValueQuotedAfter;\n }\n if (code === null || markdownLineEnding(code)) {\n return nok(code);\n }\n effects.consume(code);\n return completeAttributeValueQuoted;\n }\n\n /**\n * In unquoted attribute value.\n *\n * ```markdown\n * > | <a b=c>\n * ^\n * ```\n *\n * @type {State}\n */\n function completeAttributeValueUnquoted(code) {\n if (code === null || code === 34 || code === 39 || code === 47 || code === 60 || code === 61 || code === 62 || code === 96 || markdownLineEndingOrSpace(code)) {\n return completeAttributeNameAfter(code);\n }\n effects.consume(code);\n return completeAttributeValueUnquoted;\n }\n\n /**\n * After double or single quoted attribute value, before whitespace or the\n * end of the tag.\n *\n * ```markdown\n * > | <a b=\"c\">\n * ^\n * ```\n *\n * @type {State}\n */\n function completeAttributeValueQuotedAfter(code) {\n if (code === 47 || code === 62 || markdownSpace(code)) {\n return completeAttributeNameBefore(code);\n }\n return nok(code);\n }\n\n /**\n * In certain circumstances of a complete tag where only an `>` is allowed.\n *\n * ```markdown\n * > | <a b=\"c\">\n * ^\n * ```\n *\n * @type {State}\n */\n function completeEnd(code) {\n if (code === 62) {\n effects.consume(code);\n return completeAfter;\n }\n return nok(code);\n }\n\n /**\n * After `>` in a complete tag.\n *\n * ```markdown\n * > | <x>\n * ^\n * ```\n *\n * @type {State}\n */\n function completeAfter(code) {\n if (code === null || markdownLineEnding(code)) {\n // // Do not form containers.\n // tokenizer.concrete = true\n return continuation(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return completeAfter;\n }\n return nok(code);\n }\n\n /**\n * In continuation of any HTML kind.\n *\n * ```markdown\n * > | <!--xxx-->\n * ^\n * ```\n *\n * @type {State}\n */\n function continuation(code) {\n if (code === 45 && marker === 2) {\n effects.consume(code);\n return continuationCommentInside;\n }\n if (code === 60 && marker === 1) {\n effects.consume(code);\n return continuationRawTagOpen;\n }\n if (code === 62 && marker === 4) {\n effects.consume(code);\n return continuationClose;\n }\n if (code === 63 && marker === 3) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n if (code === 93 && marker === 5) {\n effects.consume(code);\n return continuationCdataInside;\n }\n if (markdownLineEnding(code) && (marker === 6 || marker === 7)) {\n effects.exit(\"htmlFlowData\");\n return effects.check(blankLineBefore, continuationAfter, continuationStart)(code);\n }\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"htmlFlowData\");\n return continuationStart(code);\n }\n effects.consume(code);\n return continuation;\n }\n\n /**\n * In continuation, at eol.\n *\n * ```markdown\n * > | <x>\n * ^\n * | asd\n * ```\n *\n * @type {State}\n */\n function continuationStart(code) {\n return effects.check(nonLazyContinuationStart, continuationStartNonLazy, continuationAfter)(code);\n }\n\n /**\n * In continuation, at eol, before non-lazy content.\n *\n * ```markdown\n * > | <x>\n * ^\n * | asd\n * ```\n *\n * @type {State}\n */\n function continuationStartNonLazy(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return continuationBefore;\n }\n\n /**\n * In continuation, before non-lazy content.\n *\n * ```markdown\n * | <x>\n * > | asd\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationBefore(code) {\n if (code === null || markdownLineEnding(code)) {\n return continuationStart(code);\n }\n effects.enter(\"htmlFlowData\");\n return continuation(code);\n }\n\n /**\n * In comment continuation, after one `-`, expecting another.\n *\n * ```markdown\n * > | <!--xxx-->\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationCommentInside(code) {\n if (code === 45) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n return continuation(code);\n }\n\n /**\n * In raw continuation, after `<`, at `/`.\n *\n * ```markdown\n * > | <script>console.log(1)</script>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationRawTagOpen(code) {\n if (code === 47) {\n effects.consume(code);\n buffer = '';\n return continuationRawEndTag;\n }\n return continuation(code);\n }\n\n /**\n * In raw continuation, after `</`, in a raw tag name.\n *\n * ```markdown\n * > | <script>console.log(1)</script>\n * ^^^^^^\n * ```\n *\n * @type {State}\n */\n function continuationRawEndTag(code) {\n if (code === 62) {\n const name = buffer.toLowerCase();\n if (htmlRawNames.includes(name)) {\n effects.consume(code);\n return continuationClose;\n }\n return continuation(code);\n }\n if (asciiAlpha(code) && buffer.length < 8) {\n // Always the case.\n effects.consume(code);\n buffer += String.fromCharCode(code);\n return continuationRawEndTag;\n }\n return continuation(code);\n }\n\n /**\n * In cdata continuation, after `]`, expecting `]>`.\n *\n * ```markdown\n * > | <![CDATA[>&<]]>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationCdataInside(code) {\n if (code === 93) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n return continuation(code);\n }\n\n /**\n * In declaration or instruction continuation, at `>`.\n *\n * ```markdown\n * > | <!-->\n * ^\n * > | <?>\n * ^\n * > | <!q>\n * ^\n * > | <!--ab-->\n * ^\n * > | <![CDATA[>&<]]>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationDeclarationInside(code) {\n if (code === 62) {\n effects.consume(code);\n return continuationClose;\n }\n\n // More dashes.\n if (code === 45 && marker === 2) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n return continuation(code);\n }\n\n /**\n * In closed continuation: everything we get until the eol/eof is part of it.\n *\n * ```markdown\n * > | <!doctype>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationClose(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"htmlFlowData\");\n return continuationAfter(code);\n }\n effects.consume(code);\n return continuationClose;\n }\n\n /**\n * Done.\n *\n * ```markdown\n * > | <!doctype>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationAfter(code) {\n effects.exit(\"htmlFlow\");\n // // Feel free to interrupt.\n // tokenizer.interrupt = false\n // // No longer concrete.\n // tokenizer.concrete = false\n return ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeNonLazyContinuationStart(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * At eol, before continuation.\n *\n * ```markdown\n * > | * ```js\n * ^\n * | b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n if (markdownLineEnding(code)) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return after;\n }\n return nok(code);\n }\n\n /**\n * A continuation.\n *\n * ```markdown\n * | * ```js\n * > | b\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n return self.parser.lazy[self.now().line] ? nok(code) : ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeBlankLineBefore(effects, ok, nok) {\n return start;\n\n /**\n * Before eol, expecting blank line.\n *\n * ```markdown\n * > | <div>\n * ^\n * |\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return effects.attempt(blankLine, ok, nok);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { asciiAlphanumeric, asciiAlpha, markdownLineEndingOrSpace, markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const htmlText = {\n name: 'htmlText',\n tokenize: tokenizeHtmlText\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeHtmlText(effects, ok, nok) {\n const self = this;\n /** @type {NonNullable<Code> | undefined} */\n let marker;\n /** @type {number} */\n let index;\n /** @type {State} */\n let returnState;\n return start;\n\n /**\n * Start of HTML (text).\n *\n * ```markdown\n * > | a <b> c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"htmlText\");\n effects.enter(\"htmlTextData\");\n effects.consume(code);\n return open;\n }\n\n /**\n * After `<`, at tag name or other stuff.\n *\n * ```markdown\n * > | a <b> c\n * ^\n * > | a <!doctype> c\n * ^\n * > | a <!--b--> c\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 33) {\n effects.consume(code);\n return declarationOpen;\n }\n if (code === 47) {\n effects.consume(code);\n return tagCloseStart;\n }\n if (code === 63) {\n effects.consume(code);\n return instruction;\n }\n\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n effects.consume(code);\n return tagOpen;\n }\n return nok(code);\n }\n\n /**\n * After `<!`, at declaration, comment, or CDATA.\n *\n * ```markdown\n * > | a <!doctype> c\n * ^\n * > | a <!--b--> c\n * ^\n * > | a <![CDATA[>&<]]> c\n * ^\n * ```\n *\n * @type {State}\n */\n function declarationOpen(code) {\n if (code === 45) {\n effects.consume(code);\n return commentOpenInside;\n }\n if (code === 91) {\n effects.consume(code);\n index = 0;\n return cdataOpenInside;\n }\n if (asciiAlpha(code)) {\n effects.consume(code);\n return declaration;\n }\n return nok(code);\n }\n\n /**\n * In a comment, after `<!-`, at another `-`.\n *\n * ```markdown\n * > | a <!--b--> c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentOpenInside(code) {\n if (code === 45) {\n effects.consume(code);\n return commentEnd;\n }\n return nok(code);\n }\n\n /**\n * In comment.\n *\n * ```markdown\n * > | a <!--b--> c\n * ^\n * ```\n *\n * @type {State}\n */\n function comment(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 45) {\n effects.consume(code);\n return commentClose;\n }\n if (markdownLineEnding(code)) {\n returnState = comment;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return comment;\n }\n\n /**\n * In comment, after `-`.\n *\n * ```markdown\n * > | a <!--b--> c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentClose(code) {\n if (code === 45) {\n effects.consume(code);\n return commentEnd;\n }\n return comment(code);\n }\n\n /**\n * In comment, after `--`.\n *\n * ```markdown\n * > | a <!--b--> c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentEnd(code) {\n return code === 62 ? end(code) : code === 45 ? commentClose(code) : comment(code);\n }\n\n /**\n * After `<![`, in CDATA, expecting `CDATA[`.\n *\n * ```markdown\n * > | a <![CDATA[>&<]]> b\n * ^^^^^^\n * ```\n *\n * @type {State}\n */\n function cdataOpenInside(code) {\n const value = \"CDATA[\";\n if (code === value.charCodeAt(index++)) {\n effects.consume(code);\n return index === value.length ? cdata : cdataOpenInside;\n }\n return nok(code);\n }\n\n /**\n * In CDATA.\n *\n * ```markdown\n * > | a <![CDATA[>&<]]> b\n * ^^^\n * ```\n *\n * @type {State}\n */\n function cdata(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 93) {\n effects.consume(code);\n return cdataClose;\n }\n if (markdownLineEnding(code)) {\n returnState = cdata;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return cdata;\n }\n\n /**\n * In CDATA, after `]`, at another `]`.\n *\n * ```markdown\n * > | a <![CDATA[>&<]]> b\n * ^\n * ```\n *\n * @type {State}\n */\n function cdataClose(code) {\n if (code === 93) {\n effects.consume(code);\n return cdataEnd;\n }\n return cdata(code);\n }\n\n /**\n * In CDATA, after `]]`, at `>`.\n *\n * ```markdown\n * > | a <![CDATA[>&<]]> b\n * ^\n * ```\n *\n * @type {State}\n */\n function cdataEnd(code) {\n if (code === 62) {\n return end(code);\n }\n if (code === 93) {\n effects.consume(code);\n return cdataEnd;\n }\n return cdata(code);\n }\n\n /**\n * In declaration.\n *\n * ```markdown\n * > | a <!b> c\n * ^\n * ```\n *\n * @type {State}\n */\n function declaration(code) {\n if (code === null || code === 62) {\n return end(code);\n }\n if (markdownLineEnding(code)) {\n returnState = declaration;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return declaration;\n }\n\n /**\n * In instruction.\n *\n * ```markdown\n * > | a <?b?> c\n * ^\n * ```\n *\n * @type {State}\n */\n function instruction(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 63) {\n effects.consume(code);\n return instructionClose;\n }\n if (markdownLineEnding(code)) {\n returnState = instruction;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return instruction;\n }\n\n /**\n * In instruction, after `?`, at `>`.\n *\n * ```markdown\n * > | a <?b?> c\n * ^\n * ```\n *\n * @type {State}\n */\n function instructionClose(code) {\n return code === 62 ? end(code) : instruction(code);\n }\n\n /**\n * After `</`, in closing tag, at tag name.\n *\n * ```markdown\n * > | a </b> c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagCloseStart(code) {\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n effects.consume(code);\n return tagClose;\n }\n return nok(code);\n }\n\n /**\n * After `</x`, in a tag name.\n *\n * ```markdown\n * > | a </b> c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagClose(code) {\n // ASCII alphanumerical and `-`.\n if (code === 45 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagClose;\n }\n return tagCloseBetween(code);\n }\n\n /**\n * In closing tag, after tag name.\n *\n * ```markdown\n * > | a </b> c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagCloseBetween(code) {\n if (markdownLineEnding(code)) {\n returnState = tagCloseBetween;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagCloseBetween;\n }\n return end(code);\n }\n\n /**\n * After `<x`, in opening tag name.\n *\n * ```markdown\n * > | a <b> c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpen(code) {\n // ASCII alphanumerical and `-`.\n if (code === 45 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagOpen;\n }\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n return nok(code);\n }\n\n /**\n * In opening tag, after tag name.\n *\n * ```markdown\n * > | a <b> c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenBetween(code) {\n if (code === 47) {\n effects.consume(code);\n return end;\n }\n\n // ASCII alphabetical and `:` and `_`.\n if (code === 58 || code === 95 || asciiAlpha(code)) {\n effects.consume(code);\n return tagOpenAttributeName;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenBetween;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenBetween;\n }\n return end(code);\n }\n\n /**\n * In attribute name.\n *\n * ```markdown\n * > | a <b c> d\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeName(code) {\n // ASCII alphabetical and `-`, `.`, `:`, and `_`.\n if (code === 45 || code === 46 || code === 58 || code === 95 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagOpenAttributeName;\n }\n return tagOpenAttributeNameAfter(code);\n }\n\n /**\n * After attribute name, before initializer, the end of the tag, or\n * whitespace.\n *\n * ```markdown\n * > | a <b c> d\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeNameAfter(code) {\n if (code === 61) {\n effects.consume(code);\n return tagOpenAttributeValueBefore;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeNameAfter;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenAttributeNameAfter;\n }\n return tagOpenBetween(code);\n }\n\n /**\n * Before unquoted, double quoted, or single quoted attribute value, allowing\n * whitespace.\n *\n * ```markdown\n * > | a <b c=d> e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueBefore(code) {\n if (code === null || code === 60 || code === 61 || code === 62 || code === 96) {\n return nok(code);\n }\n if (code === 34 || code === 39) {\n effects.consume(code);\n marker = code;\n return tagOpenAttributeValueQuoted;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeValueBefore;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenAttributeValueBefore;\n }\n effects.consume(code);\n return tagOpenAttributeValueUnquoted;\n }\n\n /**\n * In double or single quoted attribute value.\n *\n * ```markdown\n * > | a <b c=\"d\"> e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueQuoted(code) {\n if (code === marker) {\n effects.consume(code);\n marker = undefined;\n return tagOpenAttributeValueQuotedAfter;\n }\n if (code === null) {\n return nok(code);\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeValueQuoted;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return tagOpenAttributeValueQuoted;\n }\n\n /**\n * In unquoted attribute value.\n *\n * ```markdown\n * > | a <b c=d> e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueUnquoted(code) {\n if (code === null || code === 34 || code === 39 || code === 60 || code === 61 || code === 96) {\n return nok(code);\n }\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n effects.consume(code);\n return tagOpenAttributeValueUnquoted;\n }\n\n /**\n * After double or single quoted attribute value, before whitespace or the end\n * of the tag.\n *\n * ```markdown\n * > | a <b c=\"d\"> e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueQuotedAfter(code) {\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n return nok(code);\n }\n\n /**\n * In certain circumstances of a tag where only an `>` is allowed.\n *\n * ```markdown\n * > | a <b c=\"d\"> e\n * ^\n * ```\n *\n * @type {State}\n */\n function end(code) {\n if (code === 62) {\n effects.consume(code);\n effects.exit(\"htmlTextData\");\n effects.exit(\"htmlText\");\n return ok;\n }\n return nok(code);\n }\n\n /**\n * At eol.\n *\n * > 👉 **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * > | a <!--a\n * ^\n * | b-->\n * ```\n *\n * @type {State}\n */\n function lineEndingBefore(code) {\n effects.exit(\"htmlTextData\");\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return lineEndingAfter;\n }\n\n /**\n * After eol, at optional whitespace.\n *\n * > 👉 **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * | a <!--a\n * > | b-->\n * ^\n * ```\n *\n * @type {State}\n */\n function lineEndingAfter(code) {\n // Always populated by defaults.\n\n return markdownSpace(code) ? factorySpace(effects, lineEndingAfterPrefix, \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code) : lineEndingAfterPrefix(code);\n }\n\n /**\n * After eol, after optional whitespace.\n *\n * > 👉 **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * | a <!--a\n * > | b-->\n * ^\n * ```\n *\n * @type {State}\n */\n function lineEndingAfterPrefix(code) {\n effects.enter(\"htmlTextData\");\n return returnState(code);\n }\n}","/**\n * @import {\n * Construct,\n * Event,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { factoryDestination } from 'micromark-factory-destination';\nimport { factoryLabel } from 'micromark-factory-label';\nimport { factoryTitle } from 'micromark-factory-title';\nimport { factoryWhitespace } from 'micromark-factory-whitespace';\nimport { markdownLineEndingOrSpace } from 'micromark-util-character';\nimport { push, splice } from 'micromark-util-chunked';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/** @type {Construct} */\nexport const labelEnd = {\n name: 'labelEnd',\n resolveAll: resolveAllLabelEnd,\n resolveTo: resolveToLabelEnd,\n tokenize: tokenizeLabelEnd\n};\n\n/** @type {Construct} */\nconst resourceConstruct = {\n tokenize: tokenizeResource\n};\n/** @type {Construct} */\nconst referenceFullConstruct = {\n tokenize: tokenizeReferenceFull\n};\n/** @type {Construct} */\nconst referenceCollapsedConstruct = {\n tokenize: tokenizeReferenceCollapsed\n};\n\n/** @type {Resolver} */\nfunction resolveAllLabelEnd(events) {\n let index = -1;\n /** @type {Array<Event>} */\n const newEvents = [];\n while (++index < events.length) {\n const token = events[index][1];\n newEvents.push(events[index]);\n if (token.type === \"labelImage\" || token.type === \"labelLink\" || token.type === \"labelEnd\") {\n // Remove the marker.\n const offset = token.type === \"labelImage\" ? 4 : 2;\n token.type = \"data\";\n index += offset;\n }\n }\n\n // If the events are equal, we don't have to copy newEvents to events\n if (events.length !== newEvents.length) {\n splice(events, 0, events.length, newEvents);\n }\n return events;\n}\n\n/** @type {Resolver} */\nfunction resolveToLabelEnd(events, context) {\n let index = events.length;\n let offset = 0;\n /** @type {Token} */\n let token;\n /** @type {number | undefined} */\n let open;\n /** @type {number | undefined} */\n let close;\n /** @type {Array<Event>} */\n let media;\n\n // Find an opening.\n while (index--) {\n token = events[index][1];\n if (open) {\n // If we see another link, or inactive link label, we’ve been here before.\n if (token.type === \"link\" || token.type === \"labelLink\" && token._inactive) {\n break;\n }\n\n // Mark other link openings as inactive, as we can’t have links in\n // links.\n if (events[index][0] === 'enter' && token.type === \"labelLink\") {\n token._inactive = true;\n }\n } else if (close) {\n if (events[index][0] === 'enter' && (token.type === \"labelImage\" || token.type === \"labelLink\") && !token._balanced) {\n open = index;\n if (token.type !== \"labelLink\") {\n offset = 2;\n break;\n }\n }\n } else if (token.type === \"labelEnd\") {\n close = index;\n }\n }\n const group = {\n type: events[open][1].type === \"labelLink\" ? \"link\" : \"image\",\n start: {\n ...events[open][1].start\n },\n end: {\n ...events[events.length - 1][1].end\n }\n };\n const label = {\n type: \"label\",\n start: {\n ...events[open][1].start\n },\n end: {\n ...events[close][1].end\n }\n };\n const text = {\n type: \"labelText\",\n start: {\n ...events[open + offset + 2][1].end\n },\n end: {\n ...events[close - 2][1].start\n }\n };\n media = [['enter', group, context], ['enter', label, context]];\n\n // Opening marker.\n media = push(media, events.slice(open + 1, open + offset + 3));\n\n // Text open.\n media = push(media, [['enter', text, context]]);\n\n // Always populated by defaults.\n\n // Between.\n media = push(media, resolveAll(context.parser.constructs.insideSpan.null, events.slice(open + offset + 4, close - 3), context));\n\n // Text close, marker close, label close.\n media = push(media, [['exit', text, context], events[close - 2], events[close - 1], ['exit', label, context]]);\n\n // Reference, resource, or so.\n media = push(media, events.slice(close + 1));\n\n // Media close.\n media = push(media, [['exit', group, context]]);\n splice(events, open, events.length, media);\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelEnd(effects, ok, nok) {\n const self = this;\n let index = self.events.length;\n /** @type {Token} */\n let labelStart;\n /** @type {boolean} */\n let defined;\n\n // Find an opening.\n while (index--) {\n if ((self.events[index][1].type === \"labelImage\" || self.events[index][1].type === \"labelLink\") && !self.events[index][1]._balanced) {\n labelStart = self.events[index][1];\n break;\n }\n }\n return start;\n\n /**\n * Start of label end.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // If there is not an okay opening.\n if (!labelStart) {\n return nok(code);\n }\n\n // If the corresponding label (link) start is marked as inactive,\n // it means we’d be wrapping a link, like this:\n //\n // ```markdown\n // > | a [b [c](d) e](f) g.\n // ^\n // ```\n //\n // We can’t have that, so it’s just balanced brackets.\n if (labelStart._inactive) {\n return labelEndNok(code);\n }\n defined = self.parser.defined.includes(normalizeIdentifier(self.sliceSerialize({\n start: labelStart.end,\n end: self.now()\n })));\n effects.enter(\"labelEnd\");\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelEnd\");\n return after;\n }\n\n /**\n * After `]`.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // Note: `markdown-rs` also parses GFM footnotes here, which for us is in\n // an extension.\n\n // Resource (`[asd](fgh)`)?\n if (code === 40) {\n return effects.attempt(resourceConstruct, labelEndOk, defined ? labelEndOk : labelEndNok)(code);\n }\n\n // Full (`[asd][fgh]`) or collapsed (`[asd][]`) reference?\n if (code === 91) {\n return effects.attempt(referenceFullConstruct, labelEndOk, defined ? referenceNotFull : labelEndNok)(code);\n }\n\n // Shortcut (`[asd]`) reference?\n return defined ? labelEndOk(code) : labelEndNok(code);\n }\n\n /**\n * After `]`, at `[`, but not at a full reference.\n *\n * > 👉 **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceNotFull(code) {\n return effects.attempt(referenceCollapsedConstruct, labelEndOk, labelEndNok)(code);\n }\n\n /**\n * Done, we found something.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEndOk(code) {\n // Note: `markdown-rs` does a bunch of stuff here.\n return ok(code);\n }\n\n /**\n * Done, it’s nothing.\n *\n * There was an okay opening, but we didn’t match anything.\n *\n * ```markdown\n * > | [a](b c\n * ^\n * > | [a][b c\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEndNok(code) {\n labelStart._balanced = true;\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeResource(effects, ok, nok) {\n return resourceStart;\n\n /**\n * At a resource.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceStart(code) {\n effects.enter(\"resource\");\n effects.enter(\"resourceMarker\");\n effects.consume(code);\n effects.exit(\"resourceMarker\");\n return resourceBefore;\n }\n\n /**\n * In resource, after `(`, at optional whitespace.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceBefore(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceOpen)(code) : resourceOpen(code);\n }\n\n /**\n * In resource, after optional whitespace, at `)` or a destination.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceOpen(code) {\n if (code === 41) {\n return resourceEnd(code);\n }\n return factoryDestination(effects, resourceDestinationAfter, resourceDestinationMissing, \"resourceDestination\", \"resourceDestinationLiteral\", \"resourceDestinationLiteralMarker\", \"resourceDestinationRaw\", \"resourceDestinationString\", 32)(code);\n }\n\n /**\n * In resource, after destination, at optional whitespace.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceDestinationAfter(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceBetween)(code) : resourceEnd(code);\n }\n\n /**\n * At invalid destination.\n *\n * ```markdown\n * > | [a](<<) b\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceDestinationMissing(code) {\n return nok(code);\n }\n\n /**\n * In resource, after destination and whitespace, at `(` or title.\n *\n * ```markdown\n * > | [a](b ) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceBetween(code) {\n if (code === 34 || code === 39 || code === 40) {\n return factoryTitle(effects, resourceTitleAfter, nok, \"resourceTitle\", \"resourceTitleMarker\", \"resourceTitleString\")(code);\n }\n return resourceEnd(code);\n }\n\n /**\n * In resource, after title, at optional whitespace.\n *\n * ```markdown\n * > | [a](b \"c\") d\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceTitleAfter(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceEnd)(code) : resourceEnd(code);\n }\n\n /**\n * In resource, at `)`.\n *\n * ```markdown\n * > | [a](b) d\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceEnd(code) {\n if (code === 41) {\n effects.enter(\"resourceMarker\");\n effects.consume(code);\n effects.exit(\"resourceMarker\");\n effects.exit(\"resource\");\n return ok;\n }\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeReferenceFull(effects, ok, nok) {\n const self = this;\n return referenceFull;\n\n /**\n * In a reference (full), at the `[`.\n *\n * ```markdown\n * > | [a][b] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFull(code) {\n return factoryLabel.call(self, effects, referenceFullAfter, referenceFullMissing, \"reference\", \"referenceMarker\", \"referenceString\")(code);\n }\n\n /**\n * In a reference (full), after `]`.\n *\n * ```markdown\n * > | [a][b] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFullAfter(code) {\n return self.parser.defined.includes(normalizeIdentifier(self.sliceSerialize(self.events[self.events.length - 1][1]).slice(1, -1))) ? ok(code) : nok(code);\n }\n\n /**\n * In reference (full) that was missing.\n *\n * ```markdown\n * > | [a][b d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFullMissing(code) {\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeReferenceCollapsed(effects, ok, nok) {\n return referenceCollapsedStart;\n\n /**\n * In reference (collapsed), at `[`.\n *\n * > 👉 **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceCollapsedStart(code) {\n // We only attempt a collapsed label if there’s a `[`.\n\n effects.enter(\"reference\");\n effects.enter(\"referenceMarker\");\n effects.consume(code);\n effects.exit(\"referenceMarker\");\n return referenceCollapsedOpen;\n }\n\n /**\n * In reference (collapsed), at `]`.\n *\n * > 👉 **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceCollapsedOpen(code) {\n if (code === 93) {\n effects.enter(\"referenceMarker\");\n effects.consume(code);\n effects.exit(\"referenceMarker\");\n effects.exit(\"reference\");\n return ok;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { labelEnd } from './label-end.js';\n\n/** @type {Construct} */\nexport const labelStartImage = {\n name: 'labelStartImage',\n resolveAll: labelEnd.resolveAll,\n tokenize: tokenizeLabelStartImage\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelStartImage(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of label (image) start.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"labelImage\");\n effects.enter(\"labelImageMarker\");\n effects.consume(code);\n effects.exit(\"labelImageMarker\");\n return open;\n }\n\n /**\n * After `!`, at `[`.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 91) {\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelImage\");\n return after;\n }\n return nok(code);\n }\n\n /**\n * After `![`.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * This is needed in because, when GFM footnotes are enabled, images never\n * form when started with a `^`.\n * Instead, links form:\n *\n * ```markdown\n * ![^a](b)\n *\n * ![^a][b]\n *\n * [b]: c\n * ```\n *\n * ```html\n * <p>!<a href=\\\"b\\\">^a</a></p>\n * <p>!<a href=\\\"c\\\">^a</a></p>\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // To do: use a new field to do this, this is still needed for\n // `micromark-extension-gfm-footnote`, but the `label-start-link`\n // behavior isn’t.\n // Hidden footnotes hook.\n /* c8 ignore next 3 */\n return code === 94 && '_hiddenFootnoteSupport' in self.parser.constructs ? nok(code) : ok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { labelEnd } from './label-end.js';\n\n/** @type {Construct} */\nexport const labelStartLink = {\n name: 'labelStartLink',\n resolveAll: labelEnd.resolveAll,\n tokenize: tokenizeLabelStartLink\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelStartLink(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of label (link) start.\n *\n * ```markdown\n * > | a [b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"labelLink\");\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelLink\");\n return after;\n }\n\n /** @type {State} */\n function after(code) {\n // To do: this isn’t needed in `micromark-extension-gfm-footnote`,\n // remove.\n // Hidden footnotes hook.\n /* c8 ignore next 3 */\n return code === 94 && '_hiddenFootnoteSupport' in self.parser.constructs ? nok(code) : ok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {Construct} */\nexport const lineEnding = {\n name: 'lineEnding',\n tokenize: tokenizeLineEnding\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLineEnding(effects, ok) {\n return start;\n\n /** @type {State} */\n function start(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return factorySpace(effects, ok, \"linePrefix\");\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const thematicBreak = {\n name: 'thematicBreak',\n tokenize: tokenizeThematicBreak\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeThematicBreak(effects, ok, nok) {\n let size = 0;\n /** @type {NonNullable<Code>} */\n let marker;\n return start;\n\n /**\n * Start of thematic break.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"thematicBreak\");\n // To do: parse indent like `markdown-rs`.\n return before(code);\n }\n\n /**\n * After optional whitespace, at marker.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function before(code) {\n marker = code;\n return atBreak(code);\n }\n\n /**\n * After something, before something else.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function atBreak(code) {\n if (code === marker) {\n effects.enter(\"thematicBreakSequence\");\n return sequence(code);\n }\n if (size >= 3 && (code === null || markdownLineEnding(code))) {\n effects.exit(\"thematicBreak\");\n return ok(code);\n }\n return nok(code);\n }\n\n /**\n * In sequence.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function sequence(code) {\n if (code === marker) {\n effects.consume(code);\n size++;\n return sequence;\n }\n effects.exit(\"thematicBreakSequence\");\n return markdownSpace(code) ? factorySpace(effects, atBreak, \"whitespace\")(code) : atBreak(code);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * Exiter,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { asciiDigit, markdownSpace } from 'micromark-util-character';\nimport { blankLine } from './blank-line.js';\nimport { thematicBreak } from './thematic-break.js';\n\n/** @type {Construct} */\nexport const list = {\n continuation: {\n tokenize: tokenizeListContinuation\n },\n exit: tokenizeListEnd,\n name: 'list',\n tokenize: tokenizeListStart\n};\n\n/** @type {Construct} */\nconst listItemPrefixWhitespaceConstruct = {\n partial: true,\n tokenize: tokenizeListItemPrefixWhitespace\n};\n\n/** @type {Construct} */\nconst indentConstruct = {\n partial: true,\n tokenize: tokenizeIndent\n};\n\n// To do: `markdown-rs` parses list items on their own and later stitches them\n// together.\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeListStart(effects, ok, nok) {\n const self = this;\n const tail = self.events[self.events.length - 1];\n let initialSize = tail && tail[1].type === \"linePrefix\" ? tail[2].sliceSerialize(tail[1], true).length : 0;\n let size = 0;\n return start;\n\n /** @type {State} */\n function start(code) {\n const kind = self.containerState.type || (code === 42 || code === 43 || code === 45 ? \"listUnordered\" : \"listOrdered\");\n if (kind === \"listUnordered\" ? !self.containerState.marker || code === self.containerState.marker : asciiDigit(code)) {\n if (!self.containerState.type) {\n self.containerState.type = kind;\n effects.enter(kind, {\n _container: true\n });\n }\n if (kind === \"listUnordered\") {\n effects.enter(\"listItemPrefix\");\n return code === 42 || code === 45 ? effects.check(thematicBreak, nok, atMarker)(code) : atMarker(code);\n }\n if (!self.interrupt || code === 49) {\n effects.enter(\"listItemPrefix\");\n effects.enter(\"listItemValue\");\n return inside(code);\n }\n }\n return nok(code);\n }\n\n /** @type {State} */\n function inside(code) {\n if (asciiDigit(code) && ++size < 10) {\n effects.consume(code);\n return inside;\n }\n if ((!self.interrupt || size < 2) && (self.containerState.marker ? code === self.containerState.marker : code === 41 || code === 46)) {\n effects.exit(\"listItemValue\");\n return atMarker(code);\n }\n return nok(code);\n }\n\n /**\n * @type {State}\n **/\n function atMarker(code) {\n effects.enter(\"listItemMarker\");\n effects.consume(code);\n effects.exit(\"listItemMarker\");\n self.containerState.marker = self.containerState.marker || code;\n return effects.check(blankLine,\n // Can’t be empty when interrupting.\n self.interrupt ? nok : onBlank, effects.attempt(listItemPrefixWhitespaceConstruct, endOfPrefix, otherPrefix));\n }\n\n /** @type {State} */\n function onBlank(code) {\n self.containerState.initialBlankLine = true;\n initialSize++;\n return endOfPrefix(code);\n }\n\n /** @type {State} */\n function otherPrefix(code) {\n if (markdownSpace(code)) {\n effects.enter(\"listItemPrefixWhitespace\");\n effects.consume(code);\n effects.exit(\"listItemPrefixWhitespace\");\n return endOfPrefix;\n }\n return nok(code);\n }\n\n /** @type {State} */\n function endOfPrefix(code) {\n self.containerState.size = initialSize + self.sliceSerialize(effects.exit(\"listItemPrefix\"), true).length;\n return ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeListContinuation(effects, ok, nok) {\n const self = this;\n self.containerState._closeFlow = undefined;\n return effects.check(blankLine, onBlank, notBlank);\n\n /** @type {State} */\n function onBlank(code) {\n self.containerState.furtherBlankLines = self.containerState.furtherBlankLines || self.containerState.initialBlankLine;\n\n // We have a blank line.\n // Still, try to consume at most the items size.\n return factorySpace(effects, ok, \"listItemIndent\", self.containerState.size + 1)(code);\n }\n\n /** @type {State} */\n function notBlank(code) {\n if (self.containerState.furtherBlankLines || !markdownSpace(code)) {\n self.containerState.furtherBlankLines = undefined;\n self.containerState.initialBlankLine = undefined;\n return notInCurrentItem(code);\n }\n self.containerState.furtherBlankLines = undefined;\n self.containerState.initialBlankLine = undefined;\n return effects.attempt(indentConstruct, ok, notInCurrentItem)(code);\n }\n\n /** @type {State} */\n function notInCurrentItem(code) {\n // While we do continue, we signal that the flow should be closed.\n self.containerState._closeFlow = true;\n // As we’re closing flow, we’re no longer interrupting.\n self.interrupt = undefined;\n // Always populated by defaults.\n\n return factorySpace(effects, effects.attempt(list, ok, nok), \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeIndent(effects, ok, nok) {\n const self = this;\n return factorySpace(effects, afterPrefix, \"listItemIndent\", self.containerState.size + 1);\n\n /** @type {State} */\n function afterPrefix(code) {\n const tail = self.events[self.events.length - 1];\n return tail && tail[1].type === \"listItemIndent\" && tail[2].sliceSerialize(tail[1], true).length === self.containerState.size ? ok(code) : nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Exiter}\n */\nfunction tokenizeListEnd(effects) {\n effects.exit(this.containerState.type);\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeListItemPrefixWhitespace(effects, ok, nok) {\n const self = this;\n\n // Always populated by defaults.\n\n return factorySpace(effects, afterPrefix, \"listItemPrefixWhitespace\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4 + 1);\n\n /** @type {State} */\n function afterPrefix(code) {\n const tail = self.events[self.events.length - 1];\n return !markdownSpace(code) && tail && tail[1].type === \"listItemPrefixWhitespace\" ? ok(code) : nok(code);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const setextUnderline = {\n name: 'setextUnderline',\n resolveTo: resolveToSetextUnderline,\n tokenize: tokenizeSetextUnderline\n};\n\n/** @type {Resolver} */\nfunction resolveToSetextUnderline(events, context) {\n // To do: resolve like `markdown-rs`.\n let index = events.length;\n /** @type {number | undefined} */\n let content;\n /** @type {number | undefined} */\n let text;\n /** @type {number | undefined} */\n let definition;\n\n // Find the opening of the content.\n // It’ll always exist: we don’t tokenize if it isn’t there.\n while (index--) {\n if (events[index][0] === 'enter') {\n if (events[index][1].type === \"content\") {\n content = index;\n break;\n }\n if (events[index][1].type === \"paragraph\") {\n text = index;\n }\n }\n // Exit\n else {\n if (events[index][1].type === \"content\") {\n // Remove the content end (if needed we’ll add it later)\n events.splice(index, 1);\n }\n if (!definition && events[index][1].type === \"definition\") {\n definition = index;\n }\n }\n }\n const heading = {\n type: \"setextHeading\",\n start: {\n ...events[content][1].start\n },\n end: {\n ...events[events.length - 1][1].end\n }\n };\n\n // Change the paragraph to setext heading text.\n events[text][1].type = \"setextHeadingText\";\n\n // If we have definitions in the content, we’ll keep on having content,\n // but we need move it.\n if (definition) {\n events.splice(text, 0, ['enter', heading, context]);\n events.splice(definition + 1, 0, ['exit', events[content][1], context]);\n events[content][1].end = {\n ...events[definition][1].end\n };\n } else {\n events[content][1] = heading;\n }\n\n // Add the heading exit at the end.\n events.push(['exit', heading, context]);\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeSetextUnderline(effects, ok, nok) {\n const self = this;\n /** @type {NonNullable<Code>} */\n let marker;\n return start;\n\n /**\n * At start of heading (setext) underline.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n let index = self.events.length;\n /** @type {boolean | undefined} */\n let paragraph;\n // Find an opening.\n while (index--) {\n // Skip enter/exit of line ending, line prefix, and content.\n // We can now either have a definition or a paragraph.\n if (self.events[index][1].type !== \"lineEnding\" && self.events[index][1].type !== \"linePrefix\" && self.events[index][1].type !== \"content\") {\n paragraph = self.events[index][1].type === \"paragraph\";\n break;\n }\n }\n\n // To do: handle lazy/pierce like `markdown-rs`.\n // To do: parse indent like `markdown-rs`.\n if (!self.parser.lazy[self.now().line] && (self.interrupt || paragraph)) {\n effects.enter(\"setextHeadingLine\");\n marker = code;\n return before(code);\n }\n return nok(code);\n }\n\n /**\n * After optional whitespace, at `-` or `=`.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function before(code) {\n effects.enter(\"setextHeadingLineSequence\");\n return inside(code);\n }\n\n /**\n * In sequence.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function inside(code) {\n if (code === marker) {\n effects.consume(code);\n return inside;\n }\n effects.exit(\"setextHeadingLineSequence\");\n return markdownSpace(code) ? factorySpace(effects, after, \"lineSuffix\")(code) : after(code);\n }\n\n /**\n * After sequence, after optional whitespace.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"setextHeadingLine\");\n return ok(code);\n }\n return nok(code);\n }\n}","/**\n * @import {\n * InitialConstruct,\n * Initializer,\n * State,\n * TokenizeContext\n * } from 'micromark-util-types'\n */\n\nimport { blankLine, content } from 'micromark-core-commonmark';\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {InitialConstruct} */\nexport const flow = {\n tokenize: initializeFlow\n};\n\n/**\n * @this {TokenizeContext}\n * Self.\n * @type {Initializer}\n * Initializer.\n */\nfunction initializeFlow(effects) {\n const self = this;\n const initial = effects.attempt(\n // Try to parse a blank line.\n blankLine, atBlankEnding,\n // Try to parse initial flow (essentially, only code).\n effects.attempt(this.parser.constructs.flowInitial, afterConstruct, factorySpace(effects, effects.attempt(this.parser.constructs.flow, afterConstruct, effects.attempt(content, afterConstruct)), \"linePrefix\")));\n return initial;\n\n /** @type {State} */\n function atBlankEnding(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"lineEndingBlank\");\n effects.consume(code);\n effects.exit(\"lineEndingBlank\");\n self.currentConstruct = undefined;\n return initial;\n }\n\n /** @type {State} */\n function afterConstruct(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n self.currentConstruct = undefined;\n return initial;\n }\n}","/**\n * @import {\n * Code,\n * InitialConstruct,\n * Initializer,\n * Resolver,\n * State,\n * TokenizeContext\n * } from 'micromark-util-types'\n */\n\nexport const resolver = {\n resolveAll: createResolver()\n};\nexport const string = initializeFactory('string');\nexport const text = initializeFactory('text');\n\n/**\n * @param {'string' | 'text'} field\n * Field.\n * @returns {InitialConstruct}\n * Construct.\n */\nfunction initializeFactory(field) {\n return {\n resolveAll: createResolver(field === 'text' ? resolveAllLineSuffixes : undefined),\n tokenize: initializeText\n };\n\n /**\n * @this {TokenizeContext}\n * Context.\n * @type {Initializer}\n */\n function initializeText(effects) {\n const self = this;\n const constructs = this.parser.constructs[field];\n const text = effects.attempt(constructs, start, notText);\n return start;\n\n /** @type {State} */\n function start(code) {\n return atBreak(code) ? text(code) : notText(code);\n }\n\n /** @type {State} */\n function notText(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"data\");\n effects.consume(code);\n return data;\n }\n\n /** @type {State} */\n function data(code) {\n if (atBreak(code)) {\n effects.exit(\"data\");\n return text(code);\n }\n\n // Data.\n effects.consume(code);\n return data;\n }\n\n /**\n * @param {Code} code\n * Code.\n * @returns {boolean}\n * Whether the code is a break.\n */\n function atBreak(code) {\n if (code === null) {\n return true;\n }\n const list = constructs[code];\n let index = -1;\n if (list) {\n // Always populated by defaults.\n\n while (++index < list.length) {\n const item = list[index];\n if (!item.previous || item.previous.call(self, self.previous)) {\n return true;\n }\n }\n }\n return false;\n }\n }\n}\n\n/**\n * @param {Resolver | undefined} [extraResolver]\n * Resolver.\n * @returns {Resolver}\n * Resolver.\n */\nfunction createResolver(extraResolver) {\n return resolveAllText;\n\n /** @type {Resolver} */\n function resolveAllText(events, context) {\n let index = -1;\n /** @type {number | undefined} */\n let enter;\n\n // A rather boring computation (to merge adjacent `data` events) which\n // improves mm performance by 29%.\n while (++index <= events.length) {\n if (enter === undefined) {\n if (events[index] && events[index][1].type === \"data\") {\n enter = index;\n index++;\n }\n } else if (!events[index] || events[index][1].type !== \"data\") {\n // Don’t do anything if there is one data token.\n if (index !== enter + 2) {\n events[enter][1].end = events[index - 1][1].end;\n events.splice(enter + 2, index - enter - 2);\n index = enter + 2;\n }\n enter = undefined;\n }\n }\n return extraResolver ? extraResolver(events, context) : events;\n }\n}\n\n/**\n * A rather ugly set of instructions which again looks at chunks in the input\n * stream.\n * The reason to do this here is that it is *much* faster to parse in reverse.\n * And that we can’t hook into `null` to split the line suffix before an EOF.\n * To do: figure out if we can make this into a clean utility, or even in core.\n * As it will be useful for GFMs literal autolink extension (and maybe even\n * tables?)\n *\n * @type {Resolver}\n */\nfunction resolveAllLineSuffixes(events, context) {\n let eventIndex = 0; // Skip first.\n\n while (++eventIndex <= events.length) {\n if ((eventIndex === events.length || events[eventIndex][1].type === \"lineEnding\") && events[eventIndex - 1][1].type === \"data\") {\n const data = events[eventIndex - 1][1];\n const chunks = context.sliceStream(data);\n let index = chunks.length;\n let bufferIndex = -1;\n let size = 0;\n /** @type {boolean | undefined} */\n let tabs;\n while (index--) {\n const chunk = chunks[index];\n if (typeof chunk === 'string') {\n bufferIndex = chunk.length;\n while (chunk.charCodeAt(bufferIndex - 1) === 32) {\n size++;\n bufferIndex--;\n }\n if (bufferIndex) break;\n bufferIndex = -1;\n }\n // Number\n else if (chunk === -2) {\n tabs = true;\n size++;\n } else if (chunk === -1) {\n // Empty\n } else {\n // Replacement character, exit.\n index++;\n break;\n }\n }\n\n // Allow final trailing whitespace.\n if (context._contentTypeTextTrailing && eventIndex === events.length) {\n size = 0;\n }\n if (size) {\n const token = {\n type: eventIndex === events.length || tabs || size < 2 ? \"lineSuffix\" : \"hardBreakTrailing\",\n start: {\n _bufferIndex: index ? bufferIndex : data.start._bufferIndex + bufferIndex,\n _index: data.start._index + index,\n line: data.end.line,\n column: data.end.column - size,\n offset: data.end.offset - size\n },\n end: {\n ...data.end\n }\n };\n data.end = {\n ...token.start\n };\n if (data.start.offset === data.end.offset) {\n Object.assign(data, token);\n } else {\n events.splice(eventIndex, 0, ['enter', token, context], ['exit', token, context]);\n eventIndex += 2;\n }\n }\n eventIndex++;\n }\n }\n return events;\n}","/**\n * @import {Extension} from 'micromark-util-types'\n */\n\nimport { attention, autolink, blockQuote, characterEscape, characterReference, codeFenced, codeIndented, codeText, definition, hardBreakEscape, headingAtx, htmlFlow, htmlText, labelEnd, labelStartImage, labelStartLink, lineEnding, list, setextUnderline, thematicBreak } from 'micromark-core-commonmark';\nimport { resolver as resolveText } from './initialize/text.js';\n\n/** @satisfies {Extension['document']} */\nexport const document = {\n [42]: list,\n [43]: list,\n [45]: list,\n [48]: list,\n [49]: list,\n [50]: list,\n [51]: list,\n [52]: list,\n [53]: list,\n [54]: list,\n [55]: list,\n [56]: list,\n [57]: list,\n [62]: blockQuote\n};\n\n/** @satisfies {Extension['contentInitial']} */\nexport const contentInitial = {\n [91]: definition\n};\n\n/** @satisfies {Extension['flowInitial']} */\nexport const flowInitial = {\n [-2]: codeIndented,\n [-1]: codeIndented,\n [32]: codeIndented\n};\n\n/** @satisfies {Extension['flow']} */\nexport const flow = {\n [35]: headingAtx,\n [42]: thematicBreak,\n [45]: [setextUnderline, thematicBreak],\n [60]: htmlFlow,\n [61]: setextUnderline,\n [95]: thematicBreak,\n [96]: codeFenced,\n [126]: codeFenced\n};\n\n/** @satisfies {Extension['string']} */\nexport const string = {\n [38]: characterReference,\n [92]: characterEscape\n};\n\n/** @satisfies {Extension['text']} */\nexport const text = {\n [-5]: lineEnding,\n [-4]: lineEnding,\n [-3]: lineEnding,\n [33]: labelStartImage,\n [38]: characterReference,\n [42]: attention,\n [60]: [autolink, htmlText],\n [91]: labelStartLink,\n [92]: [hardBreakEscape, characterEscape],\n [93]: labelEnd,\n [95]: attention,\n [96]: codeText\n};\n\n/** @satisfies {Extension['insideSpan']} */\nexport const insideSpan = {\n null: [attention, resolveText]\n};\n\n/** @satisfies {Extension['attentionMarkers']} */\nexport const attentionMarkers = {\n null: [42, 95]\n};\n\n/** @satisfies {Extension['disable']} */\nexport const disable = {\n null: []\n};","/**\n * @import {\n * Chunk,\n * Code,\n * ConstructRecord,\n * Construct,\n * Effects,\n * InitialConstruct,\n * ParseContext,\n * Point,\n * State,\n * TokenizeContext,\n * Token\n * } from 'micromark-util-types'\n */\n\n/**\n * @callback Restore\n * Restore the state.\n * @returns {undefined}\n * Nothing.\n *\n * @typedef Info\n * Info.\n * @property {Restore} restore\n * Restore.\n * @property {number} from\n * From.\n *\n * @callback ReturnHandle\n * Handle a successful run.\n * @param {Construct} construct\n * Construct.\n * @param {Info} info\n * Info.\n * @returns {undefined}\n * Nothing.\n */\n\nimport { markdownLineEnding } from 'micromark-util-character';\nimport { push, splice } from 'micromark-util-chunked';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/**\n * Create a tokenizer.\n * Tokenizers deal with one type of data (e.g., containers, flow, text).\n * The parser is the object dealing with it all.\n * `initialize` works like other constructs, except that only its `tokenize`\n * function is used, in which case it doesn’t receive an `ok` or `nok`.\n * `from` can be given to set the point before the first character, although\n * when further lines are indented, they must be set with `defineSkip`.\n *\n * @param {ParseContext} parser\n * Parser.\n * @param {InitialConstruct} initialize\n * Construct.\n * @param {Omit<Point, '_bufferIndex' | '_index'> | undefined} [from]\n * Point (optional).\n * @returns {TokenizeContext}\n * Context.\n */\nexport function createTokenizer(parser, initialize, from) {\n /** @type {Point} */\n let point = {\n _bufferIndex: -1,\n _index: 0,\n line: from && from.line || 1,\n column: from && from.column || 1,\n offset: from && from.offset || 0\n };\n /** @type {Record<string, number>} */\n const columnStart = {};\n /** @type {Array<Construct>} */\n const resolveAllConstructs = [];\n /** @type {Array<Chunk>} */\n let chunks = [];\n /** @type {Array<Token>} */\n let stack = [];\n /** @type {boolean | undefined} */\n let consumed = true;\n\n /**\n * Tools used for tokenizing.\n *\n * @type {Effects}\n */\n const effects = {\n attempt: constructFactory(onsuccessfulconstruct),\n check: constructFactory(onsuccessfulcheck),\n consume,\n enter,\n exit,\n interrupt: constructFactory(onsuccessfulcheck, {\n interrupt: true\n })\n };\n\n /**\n * State and tools for resolving and serializing.\n *\n * @type {TokenizeContext}\n */\n const context = {\n code: null,\n containerState: {},\n defineSkip,\n events: [],\n now,\n parser,\n previous: null,\n sliceSerialize,\n sliceStream,\n write\n };\n\n /**\n * The state function.\n *\n * @type {State | undefined}\n */\n let state = initialize.tokenize.call(context, effects);\n\n /**\n * Track which character we expect to be consumed, to catch bugs.\n *\n * @type {Code}\n */\n let expectedCode;\n if (initialize.resolveAll) {\n resolveAllConstructs.push(initialize);\n }\n return context;\n\n /** @type {TokenizeContext['write']} */\n function write(slice) {\n chunks = push(chunks, slice);\n main();\n\n // Exit if we’re not done, resolve might change stuff.\n if (chunks[chunks.length - 1] !== null) {\n return [];\n }\n addResult(initialize, 0);\n\n // Otherwise, resolve, and exit.\n context.events = resolveAll(resolveAllConstructs, context.events, context);\n return context.events;\n }\n\n //\n // Tools.\n //\n\n /** @type {TokenizeContext['sliceSerialize']} */\n function sliceSerialize(token, expandTabs) {\n return serializeChunks(sliceStream(token), expandTabs);\n }\n\n /** @type {TokenizeContext['sliceStream']} */\n function sliceStream(token) {\n return sliceChunks(chunks, token);\n }\n\n /** @type {TokenizeContext['now']} */\n function now() {\n // This is a hot path, so we clone manually instead of `Object.assign({}, point)`\n const {\n _bufferIndex,\n _index,\n line,\n column,\n offset\n } = point;\n return {\n _bufferIndex,\n _index,\n line,\n column,\n offset\n };\n }\n\n /** @type {TokenizeContext['defineSkip']} */\n function defineSkip(value) {\n columnStart[value.line] = value.column;\n accountForPotentialSkip();\n }\n\n //\n // State management.\n //\n\n /**\n * Main loop (note that `_index` and `_bufferIndex` in `point` are modified by\n * `consume`).\n * Here is where we walk through the chunks, which either include strings of\n * several characters, or numerical character codes.\n * The reason to do this in a loop instead of a call is so the stack can\n * drain.\n *\n * @returns {undefined}\n * Nothing.\n */\n function main() {\n /** @type {number} */\n let chunkIndex;\n while (point._index < chunks.length) {\n const chunk = chunks[point._index];\n\n // If we’re in a buffer chunk, loop through it.\n if (typeof chunk === 'string') {\n chunkIndex = point._index;\n if (point._bufferIndex < 0) {\n point._bufferIndex = 0;\n }\n while (point._index === chunkIndex && point._bufferIndex < chunk.length) {\n go(chunk.charCodeAt(point._bufferIndex));\n }\n } else {\n go(chunk);\n }\n }\n }\n\n /**\n * Deal with one code.\n *\n * @param {Code} code\n * Code.\n * @returns {undefined}\n * Nothing.\n */\n function go(code) {\n consumed = undefined;\n expectedCode = code;\n state = state(code);\n }\n\n /** @type {Effects['consume']} */\n function consume(code) {\n if (markdownLineEnding(code)) {\n point.line++;\n point.column = 1;\n point.offset += code === -3 ? 2 : 1;\n accountForPotentialSkip();\n } else if (code !== -1) {\n point.column++;\n point.offset++;\n }\n\n // Not in a string chunk.\n if (point._bufferIndex < 0) {\n point._index++;\n } else {\n point._bufferIndex++;\n\n // At end of string chunk.\n if (point._bufferIndex ===\n // Points w/ non-negative `_bufferIndex` reference\n // strings.\n /** @type {string} */\n chunks[point._index].length) {\n point._bufferIndex = -1;\n point._index++;\n }\n }\n\n // Expose the previous character.\n context.previous = code;\n\n // Mark as consumed.\n consumed = true;\n }\n\n /** @type {Effects['enter']} */\n function enter(type, fields) {\n /** @type {Token} */\n // @ts-expect-error Patch instead of assign required fields to help GC.\n const token = fields || {};\n token.type = type;\n token.start = now();\n context.events.push(['enter', token, context]);\n stack.push(token);\n return token;\n }\n\n /** @type {Effects['exit']} */\n function exit(type) {\n const token = stack.pop();\n token.end = now();\n context.events.push(['exit', token, context]);\n return token;\n }\n\n /**\n * Use results.\n *\n * @type {ReturnHandle}\n */\n function onsuccessfulconstruct(construct, info) {\n addResult(construct, info.from);\n }\n\n /**\n * Discard results.\n *\n * @type {ReturnHandle}\n */\n function onsuccessfulcheck(_, info) {\n info.restore();\n }\n\n /**\n * Factory to attempt/check/interrupt.\n *\n * @param {ReturnHandle} onreturn\n * Callback.\n * @param {{interrupt?: boolean | undefined} | undefined} [fields]\n * Fields.\n */\n function constructFactory(onreturn, fields) {\n return hook;\n\n /**\n * Handle either an object mapping codes to constructs, a list of\n * constructs, or a single construct.\n *\n * @param {Array<Construct> | ConstructRecord | Construct} constructs\n * Constructs.\n * @param {State} returnState\n * State.\n * @param {State | undefined} [bogusState]\n * State.\n * @returns {State}\n * State.\n */\n function hook(constructs, returnState, bogusState) {\n /** @type {ReadonlyArray<Construct>} */\n let listOfConstructs;\n /** @type {number} */\n let constructIndex;\n /** @type {Construct} */\n let currentConstruct;\n /** @type {Info} */\n let info;\n return Array.isArray(constructs) ? /* c8 ignore next 1 */\n handleListOfConstructs(constructs) : 'tokenize' in constructs ?\n // Looks like a construct.\n handleListOfConstructs([(/** @type {Construct} */constructs)]) : handleMapOfConstructs(constructs);\n\n /**\n * Handle a list of construct.\n *\n * @param {ConstructRecord} map\n * Constructs.\n * @returns {State}\n * State.\n */\n function handleMapOfConstructs(map) {\n return start;\n\n /** @type {State} */\n function start(code) {\n const left = code !== null && map[code];\n const all = code !== null && map.null;\n const list = [\n // To do: add more extension tests.\n /* c8 ignore next 2 */\n ...(Array.isArray(left) ? left : left ? [left] : []), ...(Array.isArray(all) ? all : all ? [all] : [])];\n return handleListOfConstructs(list)(code);\n }\n }\n\n /**\n * Handle a list of construct.\n *\n * @param {ReadonlyArray<Construct>} list\n * Constructs.\n * @returns {State}\n * State.\n */\n function handleListOfConstructs(list) {\n listOfConstructs = list;\n constructIndex = 0;\n if (list.length === 0) {\n return bogusState;\n }\n return handleConstruct(list[constructIndex]);\n }\n\n /**\n * Handle a single construct.\n *\n * @param {Construct} construct\n * Construct.\n * @returns {State}\n * State.\n */\n function handleConstruct(construct) {\n return start;\n\n /** @type {State} */\n function start(code) {\n // To do: not needed to store if there is no bogus state, probably?\n // Currently doesn’t work because `inspect` in document does a check\n // w/o a bogus, which doesn’t make sense. But it does seem to help perf\n // by not storing.\n info = store();\n currentConstruct = construct;\n if (!construct.partial) {\n context.currentConstruct = construct;\n }\n\n // Always populated by defaults.\n\n if (construct.name && context.parser.constructs.disable.null.includes(construct.name)) {\n return nok(code);\n }\n return construct.tokenize.call(\n // If we do have fields, create an object w/ `context` as its\n // prototype.\n // This allows a “live binding”, which is needed for `interrupt`.\n fields ? Object.assign(Object.create(context), fields) : context, effects, ok, nok)(code);\n }\n }\n\n /** @type {State} */\n function ok(code) {\n consumed = true;\n onreturn(currentConstruct, info);\n return returnState;\n }\n\n /** @type {State} */\n function nok(code) {\n consumed = true;\n info.restore();\n if (++constructIndex < listOfConstructs.length) {\n return handleConstruct(listOfConstructs[constructIndex]);\n }\n return bogusState;\n }\n }\n }\n\n /**\n * @param {Construct} construct\n * Construct.\n * @param {number} from\n * From.\n * @returns {undefined}\n * Nothing.\n */\n function addResult(construct, from) {\n if (construct.resolveAll && !resolveAllConstructs.includes(construct)) {\n resolveAllConstructs.push(construct);\n }\n if (construct.resolve) {\n splice(context.events, from, context.events.length - from, construct.resolve(context.events.slice(from), context));\n }\n if (construct.resolveTo) {\n context.events = construct.resolveTo(context.events, context);\n }\n }\n\n /**\n * Store state.\n *\n * @returns {Info}\n * Info.\n */\n function store() {\n const startPoint = now();\n const startPrevious = context.previous;\n const startCurrentConstruct = context.currentConstruct;\n const startEventsIndex = context.events.length;\n const startStack = Array.from(stack);\n return {\n from: startEventsIndex,\n restore\n };\n\n /**\n * Restore state.\n *\n * @returns {undefined}\n * Nothing.\n */\n function restore() {\n point = startPoint;\n context.previous = startPrevious;\n context.currentConstruct = startCurrentConstruct;\n context.events.length = startEventsIndex;\n stack = startStack;\n accountForPotentialSkip();\n }\n }\n\n /**\n * Move the current point a bit forward in the line when it’s on a column\n * skip.\n *\n * @returns {undefined}\n * Nothing.\n */\n function accountForPotentialSkip() {\n if (point.line in columnStart && point.column < 2) {\n point.column = columnStart[point.line];\n point.offset += columnStart[point.line] - 1;\n }\n }\n}\n\n/**\n * Get the chunks from a slice of chunks in the range of a token.\n *\n * @param {ReadonlyArray<Chunk>} chunks\n * Chunks.\n * @param {Pick<Token, 'end' | 'start'>} token\n * Token.\n * @returns {Array<Chunk>}\n * Chunks.\n */\nfunction sliceChunks(chunks, token) {\n const startIndex = token.start._index;\n const startBufferIndex = token.start._bufferIndex;\n const endIndex = token.end._index;\n const endBufferIndex = token.end._bufferIndex;\n /** @type {Array<Chunk>} */\n let view;\n if (startIndex === endIndex) {\n // @ts-expect-error `_bufferIndex` is used on string chunks.\n view = [chunks[startIndex].slice(startBufferIndex, endBufferIndex)];\n } else {\n view = chunks.slice(startIndex, endIndex);\n if (startBufferIndex > -1) {\n const head = view[0];\n if (typeof head === 'string') {\n view[0] = head.slice(startBufferIndex);\n /* c8 ignore next 4 -- used to be used, no longer */\n } else {\n view.shift();\n }\n }\n if (endBufferIndex > 0) {\n // @ts-expect-error `_bufferIndex` is used on string chunks.\n view.push(chunks[endIndex].slice(0, endBufferIndex));\n }\n }\n return view;\n}\n\n/**\n * Get the string value of a slice of chunks.\n *\n * @param {ReadonlyArray<Chunk>} chunks\n * Chunks.\n * @param {boolean | undefined} [expandTabs=false]\n * Whether to expand tabs (default: `false`).\n * @returns {string}\n * Result.\n */\nfunction serializeChunks(chunks, expandTabs) {\n let index = -1;\n /** @type {Array<string>} */\n const result = [];\n /** @type {boolean | undefined} */\n let atTab;\n while (++index < chunks.length) {\n const chunk = chunks[index];\n /** @type {string} */\n let value;\n if (typeof chunk === 'string') {\n value = chunk;\n } else switch (chunk) {\n case -5:\n {\n value = \"\\r\";\n break;\n }\n case -4:\n {\n value = \"\\n\";\n break;\n }\n case -3:\n {\n value = \"\\r\" + \"\\n\";\n break;\n }\n case -2:\n {\n value = expandTabs ? \" \" : \"\\t\";\n break;\n }\n case -1:\n {\n if (!expandTabs && atTab) continue;\n value = \" \";\n break;\n }\n default:\n {\n // Currently only replacement character.\n value = String.fromCharCode(chunk);\n }\n }\n atTab = chunk === -2;\n result.push(value);\n }\n return result.join('');\n}","/**\n * @import {\n * Create,\n * FullNormalizedExtension,\n * InitialConstruct,\n * ParseContext,\n * ParseOptions\n * } from 'micromark-util-types'\n */\n\nimport { combineExtensions } from 'micromark-util-combine-extensions';\nimport { content } from './initialize/content.js';\nimport { document } from './initialize/document.js';\nimport { flow } from './initialize/flow.js';\nimport { string, text } from './initialize/text.js';\nimport * as defaultConstructs from './constructs.js';\nimport { createTokenizer } from './create-tokenizer.js';\n\n/**\n * @param {ParseOptions | null | undefined} [options]\n * Configuration (optional).\n * @returns {ParseContext}\n * Parser.\n */\nexport function parse(options) {\n const settings = options || {};\n const constructs = /** @type {FullNormalizedExtension} */\n combineExtensions([defaultConstructs, ...(settings.extensions || [])]);\n\n /** @type {ParseContext} */\n const parser = {\n constructs,\n content: create(content),\n defined: [],\n document: create(document),\n flow: create(flow),\n lazy: {},\n string: create(string),\n text: create(text)\n };\n return parser;\n\n /**\n * @param {InitialConstruct} initial\n * Construct to start with.\n * @returns {Create}\n * Create a tokenizer.\n */\n function create(initial) {\n return creator;\n /** @type {Create} */\n function creator(from) {\n return createTokenizer(parser, initial, from);\n }\n }\n}","/**\n * @import {Event} from 'micromark-util-types'\n */\n\nimport { subtokenize } from 'micromark-util-subtokenize';\n\n/**\n * @param {Array<Event>} events\n * Events.\n * @returns {Array<Event>}\n * Events.\n */\nexport function postprocess(events) {\n while (!subtokenize(events)) {\n // Empty\n }\n return events;\n}","/**\n * @import {Chunk, Code, Encoding, Value} from 'micromark-util-types'\n */\n\n/**\n * @callback Preprocessor\n * Preprocess a value.\n * @param {Value} value\n * Value.\n * @param {Encoding | null | undefined} [encoding]\n * Encoding when `value` is a typed array (optional).\n * @param {boolean | null | undefined} [end=false]\n * Whether this is the last chunk (default: `false`).\n * @returns {Array<Chunk>}\n * Chunks.\n */\n\nconst search = /[\\0\\t\\n\\r]/g;\n\n/**\n * @returns {Preprocessor}\n * Preprocess a value.\n */\nexport function preprocess() {\n let column = 1;\n let buffer = '';\n /** @type {boolean | undefined} */\n let start = true;\n /** @type {boolean | undefined} */\n let atCarriageReturn;\n return preprocessor;\n\n /** @type {Preprocessor} */\n // eslint-disable-next-line complexity\n function preprocessor(value, encoding, end) {\n /** @type {Array<Chunk>} */\n const chunks = [];\n /** @type {RegExpMatchArray | null} */\n let match;\n /** @type {number} */\n let next;\n /** @type {number} */\n let startPosition;\n /** @type {number} */\n let endPosition;\n /** @type {Code} */\n let code;\n value = buffer + (typeof value === 'string' ? value.toString() : new TextDecoder(encoding || undefined).decode(value));\n startPosition = 0;\n buffer = '';\n if (start) {\n // To do: `markdown-rs` actually parses BOMs (byte order mark).\n if (value.charCodeAt(0) === 65279) {\n startPosition++;\n }\n start = undefined;\n }\n while (startPosition < value.length) {\n search.lastIndex = startPosition;\n match = search.exec(value);\n endPosition = match && match.index !== undefined ? match.index : value.length;\n code = value.charCodeAt(endPosition);\n if (!match) {\n buffer = value.slice(startPosition);\n break;\n }\n if (code === 10 && startPosition === endPosition && atCarriageReturn) {\n chunks.push(-3);\n atCarriageReturn = undefined;\n } else {\n if (atCarriageReturn) {\n chunks.push(-5);\n atCarriageReturn = undefined;\n }\n if (startPosition < endPosition) {\n chunks.push(value.slice(startPosition, endPosition));\n column += endPosition - startPosition;\n }\n switch (code) {\n case 0:\n {\n chunks.push(65533);\n column++;\n break;\n }\n case 9:\n {\n next = Math.ceil(column / 4) * 4;\n chunks.push(-2);\n while (column++ < next) chunks.push(-1);\n break;\n }\n case 10:\n {\n chunks.push(-4);\n column = 1;\n break;\n }\n default:\n {\n atCarriageReturn = true;\n column = 1;\n }\n }\n }\n startPosition = endPosition + 1;\n }\n if (end) {\n if (atCarriageReturn) chunks.push(-5);\n if (buffer) chunks.push(buffer);\n chunks.push(null);\n }\n return chunks;\n }\n}","import { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { decodeNumericCharacterReference } from 'micromark-util-decode-numeric-character-reference';\nconst characterEscapeOrReference = /\\\\([!-/:-@[-`{-~])|&(#(?:\\d{1,7}|x[\\da-f]{1,6})|[\\da-z]{1,31});/gi;\n\n/**\n * Decode markdown strings (which occur in places such as fenced code info\n * strings, destinations, labels, and titles).\n *\n * The “string” content type allows character escapes and -references.\n * This decodes those.\n *\n * @param {string} value\n * Value to decode.\n * @returns {string}\n * Decoded value.\n */\nexport function decodeString(value) {\n return value.replace(characterEscapeOrReference, decode);\n}\n\n/**\n * @param {string} $0\n * Match.\n * @param {string} $1\n * Character escape.\n * @param {string} $2\n * Character reference.\n * @returns {string}\n * Decoded value\n */\nfunction decode($0, $1, $2) {\n if ($1) {\n // Escape.\n return $1;\n }\n\n // Reference.\n const head = $2.charCodeAt(0);\n if (head === 35) {\n const head = $2.charCodeAt(1);\n const hex = head === 120 || head === 88;\n return decodeNumericCharacterReference($2.slice(hex ? 2 : 1), hex ? 16 : 10);\n }\n return decodeNamedCharacterReference($2) || $0;\n}","/**\n * @import {\n * Break,\n * Blockquote,\n * Code,\n * Definition,\n * Emphasis,\n * Heading,\n * Html,\n * Image,\n * InlineCode,\n * Link,\n * ListItem,\n * List,\n * Nodes,\n * Paragraph,\n * PhrasingContent,\n * ReferenceType,\n * Root,\n * Strong,\n * Text,\n * ThematicBreak\n * } from 'mdast'\n * @import {\n * Encoding,\n * Event,\n * Token,\n * Value\n * } from 'micromark-util-types'\n * @import {Point} from 'unist'\n * @import {\n * CompileContext,\n * CompileData,\n * Config,\n * Extension,\n * Handle,\n * OnEnterError,\n * Options\n * } from './types.js'\n */\n\nimport { toString } from 'mdast-util-to-string';\nimport { parse, postprocess, preprocess } from 'micromark';\nimport { decodeNumericCharacterReference } from 'micromark-util-decode-numeric-character-reference';\nimport { decodeString } from 'micromark-util-decode-string';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\nimport { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { stringifyPosition } from 'unist-util-stringify-position';\nconst own = {}.hasOwnProperty;\n\n/**\n * Turn markdown into a syntax tree.\n *\n * @overload\n * @param {Value} value\n * @param {Encoding | null | undefined} [encoding]\n * @param {Options | null | undefined} [options]\n * @returns {Root}\n *\n * @overload\n * @param {Value} value\n * @param {Options | null | undefined} [options]\n * @returns {Root}\n *\n * @param {Value} value\n * Markdown to parse.\n * @param {Encoding | Options | null | undefined} [encoding]\n * Character encoding for when `value` is `Buffer`.\n * @param {Options | null | undefined} [options]\n * Configuration.\n * @returns {Root}\n * mdast tree.\n */\nexport function fromMarkdown(value, encoding, options) {\n if (encoding && typeof encoding === 'object') {\n options = encoding;\n encoding = undefined;\n }\n return compiler(options)(postprocess(parse(options).document().write(preprocess()(value, encoding, true))));\n}\n\n/**\n * Note this compiler only understand complete buffering, not streaming.\n *\n * @param {Options | null | undefined} [options]\n */\nfunction compiler(options) {\n /** @type {Config} */\n const config = {\n transforms: [],\n canContainEols: ['emphasis', 'fragment', 'heading', 'paragraph', 'strong'],\n enter: {\n autolink: opener(link),\n autolinkProtocol: onenterdata,\n autolinkEmail: onenterdata,\n atxHeading: opener(heading),\n blockQuote: opener(blockQuote),\n characterEscape: onenterdata,\n characterReference: onenterdata,\n codeFenced: opener(codeFlow),\n codeFencedFenceInfo: buffer,\n codeFencedFenceMeta: buffer,\n codeIndented: opener(codeFlow, buffer),\n codeText: opener(codeText, buffer),\n codeTextData: onenterdata,\n data: onenterdata,\n codeFlowValue: onenterdata,\n definition: opener(definition),\n definitionDestinationString: buffer,\n definitionLabelString: buffer,\n definitionTitleString: buffer,\n emphasis: opener(emphasis),\n hardBreakEscape: opener(hardBreak),\n hardBreakTrailing: opener(hardBreak),\n htmlFlow: opener(html, buffer),\n htmlFlowData: onenterdata,\n htmlText: opener(html, buffer),\n htmlTextData: onenterdata,\n image: opener(image),\n label: buffer,\n link: opener(link),\n listItem: opener(listItem),\n listItemValue: onenterlistitemvalue,\n listOrdered: opener(list, onenterlistordered),\n listUnordered: opener(list),\n paragraph: opener(paragraph),\n reference: onenterreference,\n referenceString: buffer,\n resourceDestinationString: buffer,\n resourceTitleString: buffer,\n setextHeading: opener(heading),\n strong: opener(strong),\n thematicBreak: opener(thematicBreak)\n },\n exit: {\n atxHeading: closer(),\n atxHeadingSequence: onexitatxheadingsequence,\n autolink: closer(),\n autolinkEmail: onexitautolinkemail,\n autolinkProtocol: onexitautolinkprotocol,\n blockQuote: closer(),\n characterEscapeValue: onexitdata,\n characterReferenceMarkerHexadecimal: onexitcharacterreferencemarker,\n characterReferenceMarkerNumeric: onexitcharacterreferencemarker,\n characterReferenceValue: onexitcharacterreferencevalue,\n characterReference: onexitcharacterreference,\n codeFenced: closer(onexitcodefenced),\n codeFencedFence: onexitcodefencedfence,\n codeFencedFenceInfo: onexitcodefencedfenceinfo,\n codeFencedFenceMeta: onexitcodefencedfencemeta,\n codeFlowValue: onexitdata,\n codeIndented: closer(onexitcodeindented),\n codeText: closer(onexitcodetext),\n codeTextData: onexitdata,\n data: onexitdata,\n definition: closer(),\n definitionDestinationString: onexitdefinitiondestinationstring,\n definitionLabelString: onexitdefinitionlabelstring,\n definitionTitleString: onexitdefinitiontitlestring,\n emphasis: closer(),\n hardBreakEscape: closer(onexithardbreak),\n hardBreakTrailing: closer(onexithardbreak),\n htmlFlow: closer(onexithtmlflow),\n htmlFlowData: onexitdata,\n htmlText: closer(onexithtmltext),\n htmlTextData: onexitdata,\n image: closer(onexitimage),\n label: onexitlabel,\n labelText: onexitlabeltext,\n lineEnding: onexitlineending,\n link: closer(onexitlink),\n listItem: closer(),\n listOrdered: closer(),\n listUnordered: closer(),\n paragraph: closer(),\n referenceString: onexitreferencestring,\n resourceDestinationString: onexitresourcedestinationstring,\n resourceTitleString: onexitresourcetitlestring,\n resource: onexitresource,\n setextHeading: closer(onexitsetextheading),\n setextHeadingLineSequence: onexitsetextheadinglinesequence,\n setextHeadingText: onexitsetextheadingtext,\n strong: closer(),\n thematicBreak: closer()\n }\n };\n configure(config, (options || {}).mdastExtensions || []);\n\n /** @type {CompileData} */\n const data = {};\n return compile;\n\n /**\n * Turn micromark events into an mdast tree.\n *\n * @param {Array<Event>} events\n * Events.\n * @returns {Root}\n * mdast tree.\n */\n function compile(events) {\n /** @type {Root} */\n let tree = {\n type: 'root',\n children: []\n };\n /** @type {Omit<CompileContext, 'sliceSerialize'>} */\n const context = {\n stack: [tree],\n tokenStack: [],\n config,\n enter,\n exit,\n buffer,\n resume,\n data\n };\n /** @type {Array<number>} */\n const listStack = [];\n let index = -1;\n while (++index < events.length) {\n // We preprocess lists to add `listItem` tokens, and to infer whether\n // items the list itself are spread out.\n if (events[index][1].type === \"listOrdered\" || events[index][1].type === \"listUnordered\") {\n if (events[index][0] === 'enter') {\n listStack.push(index);\n } else {\n const tail = listStack.pop();\n index = prepareList(events, tail, index);\n }\n }\n }\n index = -1;\n while (++index < events.length) {\n const handler = config[events[index][0]];\n if (own.call(handler, events[index][1].type)) {\n handler[events[index][1].type].call(Object.assign({\n sliceSerialize: events[index][2].sliceSerialize\n }, context), events[index][1]);\n }\n }\n\n // Handle tokens still being open.\n if (context.tokenStack.length > 0) {\n const tail = context.tokenStack[context.tokenStack.length - 1];\n const handler = tail[1] || defaultOnError;\n handler.call(context, undefined, tail[0]);\n }\n\n // Figure out `root` position.\n tree.position = {\n start: point(events.length > 0 ? events[0][1].start : {\n line: 1,\n column: 1,\n offset: 0\n }),\n end: point(events.length > 0 ? events[events.length - 2][1].end : {\n line: 1,\n column: 1,\n offset: 0\n })\n };\n\n // Call transforms.\n index = -1;\n while (++index < config.transforms.length) {\n tree = config.transforms[index](tree) || tree;\n }\n return tree;\n }\n\n /**\n * @param {Array<Event>} events\n * @param {number} start\n * @param {number} length\n * @returns {number}\n */\n function prepareList(events, start, length) {\n let index = start - 1;\n let containerBalance = -1;\n let listSpread = false;\n /** @type {Token | undefined} */\n let listItem;\n /** @type {number | undefined} */\n let lineIndex;\n /** @type {number | undefined} */\n let firstBlankLineIndex;\n /** @type {boolean | undefined} */\n let atMarker;\n while (++index <= length) {\n const event = events[index];\n switch (event[1].type) {\n case \"listUnordered\":\n case \"listOrdered\":\n case \"blockQuote\":\n {\n if (event[0] === 'enter') {\n containerBalance++;\n } else {\n containerBalance--;\n }\n atMarker = undefined;\n break;\n }\n case \"lineEndingBlank\":\n {\n if (event[0] === 'enter') {\n if (listItem && !atMarker && !containerBalance && !firstBlankLineIndex) {\n firstBlankLineIndex = index;\n }\n atMarker = undefined;\n }\n break;\n }\n case \"linePrefix\":\n case \"listItemValue\":\n case \"listItemMarker\":\n case \"listItemPrefix\":\n case \"listItemPrefixWhitespace\":\n {\n // Empty.\n\n break;\n }\n default:\n {\n atMarker = undefined;\n }\n }\n if (!containerBalance && event[0] === 'enter' && event[1].type === \"listItemPrefix\" || containerBalance === -1 && event[0] === 'exit' && (event[1].type === \"listUnordered\" || event[1].type === \"listOrdered\")) {\n if (listItem) {\n let tailIndex = index;\n lineIndex = undefined;\n while (tailIndex--) {\n const tailEvent = events[tailIndex];\n if (tailEvent[1].type === \"lineEnding\" || tailEvent[1].type === \"lineEndingBlank\") {\n if (tailEvent[0] === 'exit') continue;\n if (lineIndex) {\n events[lineIndex][1].type = \"lineEndingBlank\";\n listSpread = true;\n }\n tailEvent[1].type = \"lineEnding\";\n lineIndex = tailIndex;\n } else if (tailEvent[1].type === \"linePrefix\" || tailEvent[1].type === \"blockQuotePrefix\" || tailEvent[1].type === \"blockQuotePrefixWhitespace\" || tailEvent[1].type === \"blockQuoteMarker\" || tailEvent[1].type === \"listItemIndent\") {\n // Empty\n } else {\n break;\n }\n }\n if (firstBlankLineIndex && (!lineIndex || firstBlankLineIndex < lineIndex)) {\n listItem._spread = true;\n }\n\n // Fix position.\n listItem.end = Object.assign({}, lineIndex ? events[lineIndex][1].start : event[1].end);\n events.splice(lineIndex || index, 0, ['exit', listItem, event[2]]);\n index++;\n length++;\n }\n\n // Create a new list item.\n if (event[1].type === \"listItemPrefix\") {\n /** @type {Token} */\n const item = {\n type: 'listItem',\n _spread: false,\n start: Object.assign({}, event[1].start),\n // @ts-expect-error: we’ll add `end` in a second.\n end: undefined\n };\n listItem = item;\n events.splice(index, 0, ['enter', item, event[2]]);\n index++;\n length++;\n firstBlankLineIndex = undefined;\n atMarker = true;\n }\n }\n }\n events[start][1]._spread = listSpread;\n return length;\n }\n\n /**\n * Create an opener handle.\n *\n * @param {(token: Token) => Nodes} create\n * Create a node.\n * @param {Handle | undefined} [and]\n * Optional function to also run.\n * @returns {Handle}\n * Handle.\n */\n function opener(create, and) {\n return open;\n\n /**\n * @this {CompileContext}\n * @param {Token} token\n * @returns {undefined}\n */\n function open(token) {\n enter.call(this, create(token), token);\n if (and) and.call(this, token);\n }\n }\n\n /**\n * @type {CompileContext['buffer']}\n */\n function buffer() {\n this.stack.push({\n type: 'fragment',\n children: []\n });\n }\n\n /**\n * @type {CompileContext['enter']}\n */\n function enter(node, token, errorHandler) {\n const parent = this.stack[this.stack.length - 1];\n /** @type {Array<Nodes>} */\n const siblings = parent.children;\n siblings.push(node);\n this.stack.push(node);\n this.tokenStack.push([token, errorHandler || undefined]);\n node.position = {\n start: point(token.start),\n // @ts-expect-error: `end` will be patched later.\n end: undefined\n };\n }\n\n /**\n * Create a closer handle.\n *\n * @param {Handle | undefined} [and]\n * Optional function to also run.\n * @returns {Handle}\n * Handle.\n */\n function closer(and) {\n return close;\n\n /**\n * @this {CompileContext}\n * @param {Token} token\n * @returns {undefined}\n */\n function close(token) {\n if (and) and.call(this, token);\n exit.call(this, token);\n }\n }\n\n /**\n * @type {CompileContext['exit']}\n */\n function exit(token, onExitError) {\n const node = this.stack.pop();\n const open = this.tokenStack.pop();\n if (!open) {\n throw new Error('Cannot close `' + token.type + '` (' + stringifyPosition({\n start: token.start,\n end: token.end\n }) + '): it’s not open');\n } else if (open[0].type !== token.type) {\n if (onExitError) {\n onExitError.call(this, token, open[0]);\n } else {\n const handler = open[1] || defaultOnError;\n handler.call(this, token, open[0]);\n }\n }\n node.position.end = point(token.end);\n }\n\n /**\n * @type {CompileContext['resume']}\n */\n function resume() {\n return toString(this.stack.pop());\n }\n\n //\n // Handlers.\n //\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onenterlistordered() {\n this.data.expectingFirstListItemValue = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onenterlistitemvalue(token) {\n if (this.data.expectingFirstListItemValue) {\n const ancestor = this.stack[this.stack.length - 2];\n ancestor.start = Number.parseInt(this.sliceSerialize(token), 10);\n this.data.expectingFirstListItemValue = undefined;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfenceinfo() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.lang = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfencemeta() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.meta = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfence() {\n // Exit if this is the closing fence.\n if (this.data.flowCodeInside) return;\n this.buffer();\n this.data.flowCodeInside = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefenced() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data.replace(/^(\\r?\\n|\\r)|(\\r?\\n|\\r)$/g, '');\n this.data.flowCodeInside = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodeindented() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data.replace(/(\\r?\\n|\\r)$/g, '');\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitionlabelstring(token) {\n const label = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.label = label;\n node.identifier = normalizeIdentifier(this.sliceSerialize(token)).toLowerCase();\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitiontitlestring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.title = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitiondestinationstring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.url = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitatxheadingsequence(token) {\n const node = this.stack[this.stack.length - 1];\n if (!node.depth) {\n const depth = this.sliceSerialize(token).length;\n node.depth = depth;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheadingtext() {\n this.data.setextHeadingSlurpLineEnding = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheadinglinesequence(token) {\n const node = this.stack[this.stack.length - 1];\n node.depth = this.sliceSerialize(token).codePointAt(0) === 61 ? 1 : 2;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheading() {\n this.data.setextHeadingSlurpLineEnding = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onenterdata(token) {\n const node = this.stack[this.stack.length - 1];\n /** @type {Array<Nodes>} */\n const siblings = node.children;\n let tail = siblings[siblings.length - 1];\n if (!tail || tail.type !== 'text') {\n // Add a new text node.\n tail = text();\n tail.position = {\n start: point(token.start),\n // @ts-expect-error: we’ll add `end` later.\n end: undefined\n };\n siblings.push(tail);\n }\n this.stack.push(tail);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitdata(token) {\n const tail = this.stack.pop();\n tail.value += this.sliceSerialize(token);\n tail.position.end = point(token.end);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlineending(token) {\n const context = this.stack[this.stack.length - 1];\n // If we’re at a hard break, include the line ending in there.\n if (this.data.atHardBreak) {\n const tail = context.children[context.children.length - 1];\n tail.position.end = point(token.end);\n this.data.atHardBreak = undefined;\n return;\n }\n if (!this.data.setextHeadingSlurpLineEnding && config.canContainEols.includes(context.type)) {\n onenterdata.call(this, token);\n onexitdata.call(this, token);\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithardbreak() {\n this.data.atHardBreak = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithtmlflow() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithtmltext() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitcodetext() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlink() {\n const node = this.stack[this.stack.length - 1];\n // Note: there are also `identifier` and `label` fields on this link node!\n // These are used / cleaned here.\n\n // To do: clean.\n if (this.data.inReference) {\n /** @type {ReferenceType} */\n const referenceType = this.data.referenceType || 'shortcut';\n node.type += 'Reference';\n // @ts-expect-error: mutate.\n node.referenceType = referenceType;\n // @ts-expect-error: mutate.\n delete node.url;\n delete node.title;\n } else {\n // @ts-expect-error: mutate.\n delete node.identifier;\n // @ts-expect-error: mutate.\n delete node.label;\n }\n this.data.referenceType = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitimage() {\n const node = this.stack[this.stack.length - 1];\n // Note: there are also `identifier` and `label` fields on this link node!\n // These are used / cleaned here.\n\n // To do: clean.\n if (this.data.inReference) {\n /** @type {ReferenceType} */\n const referenceType = this.data.referenceType || 'shortcut';\n node.type += 'Reference';\n // @ts-expect-error: mutate.\n node.referenceType = referenceType;\n // @ts-expect-error: mutate.\n delete node.url;\n delete node.title;\n } else {\n // @ts-expect-error: mutate.\n delete node.identifier;\n // @ts-expect-error: mutate.\n delete node.label;\n }\n this.data.referenceType = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlabeltext(token) {\n const string = this.sliceSerialize(token);\n const ancestor = this.stack[this.stack.length - 2];\n // @ts-expect-error: stash this on the node, as it might become a reference\n // later.\n ancestor.label = decodeString(string);\n // @ts-expect-error: same as above.\n ancestor.identifier = normalizeIdentifier(string).toLowerCase();\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlabel() {\n const fragment = this.stack[this.stack.length - 1];\n const value = this.resume();\n const node = this.stack[this.stack.length - 1];\n // Assume a reference.\n this.data.inReference = true;\n if (node.type === 'link') {\n /** @type {Array<PhrasingContent>} */\n const children = fragment.children;\n node.children = children;\n } else {\n node.alt = value;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresourcedestinationstring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.url = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresourcetitlestring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.title = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresource() {\n this.data.inReference = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onenterreference() {\n this.data.referenceType = 'collapsed';\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitreferencestring(token) {\n const label = this.resume();\n const node = this.stack[this.stack.length - 1];\n // @ts-expect-error: stash this on the node, as it might become a reference\n // later.\n node.label = label;\n // @ts-expect-error: same as above.\n node.identifier = normalizeIdentifier(this.sliceSerialize(token)).toLowerCase();\n this.data.referenceType = 'full';\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitcharacterreferencemarker(token) {\n this.data.characterReferenceType = token.type;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcharacterreferencevalue(token) {\n const data = this.sliceSerialize(token);\n const type = this.data.characterReferenceType;\n /** @type {string} */\n let value;\n if (type) {\n value = decodeNumericCharacterReference(data, type === \"characterReferenceMarkerNumeric\" ? 10 : 16);\n this.data.characterReferenceType = undefined;\n } else {\n const result = decodeNamedCharacterReference(data);\n value = result;\n }\n const tail = this.stack[this.stack.length - 1];\n tail.value += value;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcharacterreference(token) {\n const tail = this.stack.pop();\n tail.position.end = point(token.end);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitautolinkprotocol(token) {\n onexitdata.call(this, token);\n const node = this.stack[this.stack.length - 1];\n node.url = this.sliceSerialize(token);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitautolinkemail(token) {\n onexitdata.call(this, token);\n const node = this.stack[this.stack.length - 1];\n node.url = 'mailto:' + this.sliceSerialize(token);\n }\n\n //\n // Creaters.\n //\n\n /** @returns {Blockquote} */\n function blockQuote() {\n return {\n type: 'blockquote',\n children: []\n };\n }\n\n /** @returns {Code} */\n function codeFlow() {\n return {\n type: 'code',\n lang: null,\n meta: null,\n value: ''\n };\n }\n\n /** @returns {InlineCode} */\n function codeText() {\n return {\n type: 'inlineCode',\n value: ''\n };\n }\n\n /** @returns {Definition} */\n function definition() {\n return {\n type: 'definition',\n identifier: '',\n label: null,\n title: null,\n url: ''\n };\n }\n\n /** @returns {Emphasis} */\n function emphasis() {\n return {\n type: 'emphasis',\n children: []\n };\n }\n\n /** @returns {Heading} */\n function heading() {\n return {\n type: 'heading',\n // @ts-expect-error `depth` will be set later.\n depth: 0,\n children: []\n };\n }\n\n /** @returns {Break} */\n function hardBreak() {\n return {\n type: 'break'\n };\n }\n\n /** @returns {Html} */\n function html() {\n return {\n type: 'html',\n value: ''\n };\n }\n\n /** @returns {Image} */\n function image() {\n return {\n type: 'image',\n title: null,\n url: '',\n alt: null\n };\n }\n\n /** @returns {Link} */\n function link() {\n return {\n type: 'link',\n title: null,\n url: '',\n children: []\n };\n }\n\n /**\n * @param {Token} token\n * @returns {List}\n */\n function list(token) {\n return {\n type: 'list',\n ordered: token.type === 'listOrdered',\n start: null,\n spread: token._spread,\n children: []\n };\n }\n\n /**\n * @param {Token} token\n * @returns {ListItem}\n */\n function listItem(token) {\n return {\n type: 'listItem',\n spread: token._spread,\n checked: null,\n children: []\n };\n }\n\n /** @returns {Paragraph} */\n function paragraph() {\n return {\n type: 'paragraph',\n children: []\n };\n }\n\n /** @returns {Strong} */\n function strong() {\n return {\n type: 'strong',\n children: []\n };\n }\n\n /** @returns {Text} */\n function text() {\n return {\n type: 'text',\n value: ''\n };\n }\n\n /** @returns {ThematicBreak} */\n function thematicBreak() {\n return {\n type: 'thematicBreak'\n };\n }\n}\n\n/**\n * Copy a point-like value.\n *\n * @param {Point} d\n * Point-like value.\n * @returns {Point}\n * unist point.\n */\nfunction point(d) {\n return {\n line: d.line,\n column: d.column,\n offset: d.offset\n };\n}\n\n/**\n * @param {Config} combined\n * @param {Array<Array<Extension> | Extension>} extensions\n * @returns {undefined}\n */\nfunction configure(combined, extensions) {\n let index = -1;\n while (++index < extensions.length) {\n const value = extensions[index];\n if (Array.isArray(value)) {\n configure(combined, value);\n } else {\n extension(combined, value);\n }\n }\n}\n\n/**\n * @param {Config} combined\n * @param {Extension} extension\n * @returns {undefined}\n */\nfunction extension(combined, extension) {\n /** @type {keyof Extension} */\n let key;\n for (key in extension) {\n if (own.call(extension, key)) {\n switch (key) {\n case 'canContainEols':\n {\n const right = extension[key];\n if (right) {\n combined[key].push(...right);\n }\n break;\n }\n case 'transforms':\n {\n const right = extension[key];\n if (right) {\n combined[key].push(...right);\n }\n break;\n }\n case 'enter':\n case 'exit':\n {\n const right = extension[key];\n if (right) {\n Object.assign(combined[key], right);\n }\n break;\n }\n // No default\n }\n }\n }\n}\n\n/** @type {OnEnterError} */\nfunction defaultOnError(left, right) {\n if (left) {\n throw new Error('Cannot close `' + left.type + '` (' + stringifyPosition({\n start: left.start,\n end: left.end\n }) + '): a different token (`' + right.type + '`, ' + stringifyPosition({\n start: right.start,\n end: right.end\n }) + ') is open');\n } else {\n throw new Error('Cannot close document, a token (`' + right.type + '`, ' + stringifyPosition({\n start: right.start,\n end: right.end\n }) + ') is still open');\n }\n}","/**\n * @typedef {import('mdast').Root} Root\n * @typedef {import('mdast-util-from-markdown').Options} FromMarkdownOptions\n * @typedef {import('unified').Parser<Root>} Parser\n * @typedef {import('unified').Processor<Root>} Processor\n */\n\n/**\n * @typedef {Omit<FromMarkdownOptions, 'extensions' | 'mdastExtensions'>} Options\n */\n\nimport {fromMarkdown} from 'mdast-util-from-markdown'\n\n/**\n * Aadd support for parsing from markdown.\n *\n * @param {Readonly<Options> | null | undefined} [options]\n * Configuration (optional).\n * @returns {undefined}\n * Nothing.\n */\nexport default function remarkParse(options) {\n /** @type {Processor} */\n // @ts-expect-error: TS in JSDoc generates wrong types if `this` is typed regularly.\n const self = this\n\n self.parser = parser\n\n /**\n * @type {Parser}\n */\n function parser(doc) {\n return fromMarkdown(doc, {\n ...self.data('settings'),\n ...options,\n // Note: these options are not in the readme.\n // The goal is for them to be set by plugins on `data` instead of being\n // passed by users.\n extensions: self.data('micromarkExtensions') || [],\n mdastExtensions: self.data('fromMarkdownExtensions') || []\n })\n }\n}\n","/**\n * @import {Element} from 'hast'\n * @import {Blockquote} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `blockquote` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Blockquote} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function blockquote(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'blockquote',\n properties: {},\n children: state.wrap(state.all(node), true)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element, Text} from 'hast'\n * @import {Break} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `break` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Break} node\n * mdast node.\n * @returns {Array<Element | Text>}\n * hast element content.\n */\nexport function hardBreak(state, node) {\n /** @type {Element} */\n const result = {type: 'element', tagName: 'br', properties: {}, children: []}\n state.patch(node, result)\n return [state.applyData(node, result), {type: 'text', value: '\\n'}]\n}\n","/**\n * @import {Element, Properties} from 'hast'\n * @import {Code} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `code` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Code} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function code(state, node) {\n const value = node.value ? node.value + '\\n' : ''\n /** @type {Properties} */\n const properties = {}\n // Someone can write `js&#x20;python&#x9;ruby`.\n const language = node.lang ? node.lang.split(/\\s+/) : []\n\n // GH/CM still drop the non-first languages.\n if (language.length > 0) {\n properties.className = ['language-' + language[0]]\n }\n\n // Create `<code>`.\n /** @type {Element} */\n let result = {\n type: 'element',\n tagName: 'code',\n properties,\n children: [{type: 'text', value}]\n }\n\n if (node.meta) {\n result.data = {meta: node.meta}\n }\n\n state.patch(node, result)\n result = state.applyData(node, result)\n\n // Create `<pre>`.\n result = {type: 'element', tagName: 'pre', properties: {}, children: [result]}\n state.patch(node, result)\n return result\n}\n","/**\n * @import {Element} from 'hast'\n * @import {Delete} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `delete` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Delete} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function strikethrough(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'del',\n properties: {},\n children: state.all(node)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element} from 'hast'\n * @import {Emphasis} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `emphasis` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Emphasis} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function emphasis(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'em',\n properties: {},\n children: state.all(node)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element} from 'hast'\n * @import {FootnoteReference} from 'mdast'\n * @import {State} from '../state.js'\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `footnoteReference` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {FootnoteReference} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function footnoteReference(state, node) {\n const clobberPrefix =\n typeof state.options.clobberPrefix === 'string'\n ? state.options.clobberPrefix\n : 'user-content-'\n const id = String(node.identifier).toUpperCase()\n const safeId = normalizeUri(id.toLowerCase())\n const index = state.footnoteOrder.indexOf(id)\n /** @type {number} */\n let counter\n\n let reuseCounter = state.footnoteCounts.get(id)\n\n if (reuseCounter === undefined) {\n reuseCounter = 0\n state.footnoteOrder.push(id)\n counter = state.footnoteOrder.length\n } else {\n counter = index + 1\n }\n\n reuseCounter += 1\n state.footnoteCounts.set(id, reuseCounter)\n\n /** @type {Element} */\n const link = {\n type: 'element',\n tagName: 'a',\n properties: {\n href: '#' + clobberPrefix + 'fn-' + safeId,\n id:\n clobberPrefix +\n 'fnref-' +\n safeId +\n (reuseCounter > 1 ? '-' + reuseCounter : ''),\n dataFootnoteRef: true,\n ariaDescribedBy: ['footnote-label']\n },\n children: [{type: 'text', value: String(counter)}]\n }\n state.patch(node, link)\n\n /** @type {Element} */\n const sup = {\n type: 'element',\n tagName: 'sup',\n properties: {},\n children: [link]\n }\n state.patch(node, sup)\n return state.applyData(node, sup)\n}\n","/**\n * @import {Element} from 'hast'\n * @import {Heading} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `heading` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Heading} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function heading(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'h' + node.depth,\n properties: {},\n children: state.all(node)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element} from 'hast'\n * @import {Html} from 'mdast'\n * @import {State} from '../state.js'\n * @import {Raw} from '../../index.js'\n */\n\n/**\n * Turn an mdast `html` node into hast (`raw` node in dangerous mode, otherwise\n * nothing).\n *\n * @param {State} state\n * Info passed around.\n * @param {Html} node\n * mdast node.\n * @returns {Element | Raw | undefined}\n * hast node.\n */\nexport function html(state, node) {\n if (state.options.allowDangerousHtml) {\n /** @type {Raw} */\n const result = {type: 'raw', value: node.value}\n state.patch(node, result)\n return state.applyData(node, result)\n }\n\n return undefined\n}\n","/**\n * @import {ElementContent} from 'hast'\n * @import {Reference, Nodes} from 'mdast'\n * @import {State} from './state.js'\n */\n\n/**\n * Return the content of a reference without definition as plain text.\n *\n * @param {State} state\n * Info passed around.\n * @param {Extract<Nodes, Reference>} node\n * Reference node (image, link).\n * @returns {Array<ElementContent>}\n * hast content.\n */\nexport function revert(state, node) {\n const subtype = node.referenceType\n let suffix = ']'\n\n if (subtype === 'collapsed') {\n suffix += '[]'\n } else if (subtype === 'full') {\n suffix += '[' + (node.label || node.identifier) + ']'\n }\n\n if (node.type === 'imageReference') {\n return [{type: 'text', value: '![' + node.alt + suffix}]\n }\n\n const contents = state.all(node)\n const head = contents[0]\n\n if (head && head.type === 'text') {\n head.value = '[' + head.value\n } else {\n contents.unshift({type: 'text', value: '['})\n }\n\n const tail = contents[contents.length - 1]\n\n if (tail && tail.type === 'text') {\n tail.value += suffix\n } else {\n contents.push({type: 'text', value: suffix})\n }\n\n return contents\n}\n","/**\n * @import {ElementContent, Element, Properties} from 'hast'\n * @import {ImageReference} from 'mdast'\n * @import {State} from '../state.js'\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\nimport {revert} from '../revert.js'\n\n/**\n * Turn an mdast `imageReference` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {ImageReference} node\n * mdast node.\n * @returns {Array<ElementContent> | ElementContent}\n * hast node.\n */\nexport function imageReference(state, node) {\n const id = String(node.identifier).toUpperCase()\n const definition = state.definitionById.get(id)\n\n if (!definition) {\n return revert(state, node)\n }\n\n /** @type {Properties} */\n const properties = {src: normalizeUri(definition.url || ''), alt: node.alt}\n\n if (definition.title !== null && definition.title !== undefined) {\n properties.title = definition.title\n }\n\n /** @type {Element} */\n const result = {type: 'element', tagName: 'img', properties, children: []}\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element, Properties} from 'hast'\n * @import {Image} from 'mdast'\n * @import {State} from '../state.js'\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `image` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Image} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function image(state, node) {\n /** @type {Properties} */\n const properties = {src: normalizeUri(node.url)}\n\n if (node.alt !== null && node.alt !== undefined) {\n properties.alt = node.alt\n }\n\n if (node.title !== null && node.title !== undefined) {\n properties.title = node.title\n }\n\n /** @type {Element} */\n const result = {type: 'element', tagName: 'img', properties, children: []}\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element, Text} from 'hast'\n * @import {InlineCode} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `inlineCode` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {InlineCode} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function inlineCode(state, node) {\n /** @type {Text} */\n const text = {type: 'text', value: node.value.replace(/\\r?\\n|\\r/g, ' ')}\n state.patch(node, text)\n\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'code',\n properties: {},\n children: [text]\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {ElementContent, Element, Properties} from 'hast'\n * @import {LinkReference} from 'mdast'\n * @import {State} from '../state.js'\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\nimport {revert} from '../revert.js'\n\n/**\n * Turn an mdast `linkReference` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {LinkReference} node\n * mdast node.\n * @returns {Array<ElementContent> | ElementContent}\n * hast node.\n */\nexport function linkReference(state, node) {\n const id = String(node.identifier).toUpperCase()\n const definition = state.definitionById.get(id)\n\n if (!definition) {\n return revert(state, node)\n }\n\n /** @type {Properties} */\n const properties = {href: normalizeUri(definition.url || '')}\n\n if (definition.title !== null && definition.title !== undefined) {\n properties.title = definition.title\n }\n\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'a',\n properties,\n children: state.all(node)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element, Properties} from 'hast'\n * @import {Link} from 'mdast'\n * @import {State} from '../state.js'\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `link` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Link} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function link(state, node) {\n /** @type {Properties} */\n const properties = {href: normalizeUri(node.url)}\n\n if (node.title !== null && node.title !== undefined) {\n properties.title = node.title\n }\n\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'a',\n properties,\n children: state.all(node)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {ElementContent, Element, Properties} from 'hast'\n * @import {ListItem, Parents} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `listItem` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {ListItem} node\n * mdast node.\n * @param {Parents | undefined} parent\n * Parent of `node`.\n * @returns {Element}\n * hast node.\n */\nexport function listItem(state, node, parent) {\n const results = state.all(node)\n const loose = parent ? listLoose(parent) : listItemLoose(node)\n /** @type {Properties} */\n const properties = {}\n /** @type {Array<ElementContent>} */\n const children = []\n\n if (typeof node.checked === 'boolean') {\n const head = results[0]\n /** @type {Element} */\n let paragraph\n\n if (head && head.type === 'element' && head.tagName === 'p') {\n paragraph = head\n } else {\n paragraph = {type: 'element', tagName: 'p', properties: {}, children: []}\n results.unshift(paragraph)\n }\n\n if (paragraph.children.length > 0) {\n paragraph.children.unshift({type: 'text', value: ' '})\n }\n\n paragraph.children.unshift({\n type: 'element',\n tagName: 'input',\n properties: {type: 'checkbox', checked: node.checked, disabled: true},\n children: []\n })\n\n // According to github-markdown-css, this class hides bullet.\n // See: <https://github.com/sindresorhus/github-markdown-css>.\n properties.className = ['task-list-item']\n }\n\n let index = -1\n\n while (++index < results.length) {\n const child = results[index]\n\n // Add eols before nodes, except if this is a loose, first paragraph.\n if (\n loose ||\n index !== 0 ||\n child.type !== 'element' ||\n child.tagName !== 'p'\n ) {\n children.push({type: 'text', value: '\\n'})\n }\n\n if (child.type === 'element' && child.tagName === 'p' && !loose) {\n children.push(...child.children)\n } else {\n children.push(child)\n }\n }\n\n const tail = results[results.length - 1]\n\n // Add a final eol.\n if (tail && (loose || tail.type !== 'element' || tail.tagName !== 'p')) {\n children.push({type: 'text', value: '\\n'})\n }\n\n /** @type {Element} */\n const result = {type: 'element', tagName: 'li', properties, children}\n state.patch(node, result)\n return state.applyData(node, result)\n}\n\n/**\n * @param {Parents} node\n * @return {Boolean}\n */\nfunction listLoose(node) {\n let loose = false\n if (node.type === 'list') {\n loose = node.spread || false\n const children = node.children\n let index = -1\n\n while (!loose && ++index < children.length) {\n loose = listItemLoose(children[index])\n }\n }\n\n return loose\n}\n\n/**\n * @param {ListItem} node\n * @return {Boolean}\n */\nfunction listItemLoose(node) {\n const spread = node.spread\n\n return spread === null || spread === undefined\n ? node.children.length > 1\n : spread\n}\n","/**\n * @import {Element, Properties} from 'hast'\n * @import {List} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `list` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {List} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function list(state, node) {\n /** @type {Properties} */\n const properties = {}\n const results = state.all(node)\n let index = -1\n\n if (typeof node.start === 'number' && node.start !== 1) {\n properties.start = node.start\n }\n\n // Like GitHub, add a class for custom styling.\n while (++index < results.length) {\n const child = results[index]\n\n if (\n child.type === 'element' &&\n child.tagName === 'li' &&\n child.properties &&\n Array.isArray(child.properties.className) &&\n child.properties.className.includes('task-list-item')\n ) {\n properties.className = ['contains-task-list']\n break\n }\n }\n\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: node.ordered ? 'ol' : 'ul',\n properties,\n children: state.wrap(results, true)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element} from 'hast'\n * @import {Paragraph} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `paragraph` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Paragraph} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function paragraph(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'p',\n properties: {},\n children: state.all(node)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Parents as HastParents, Root as HastRoot} from 'hast'\n * @import {Root as MdastRoot} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `root` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdastRoot} node\n * mdast node.\n * @returns {HastParents}\n * hast node.\n */\nexport function root(state, node) {\n /** @type {HastRoot} */\n const result = {type: 'root', children: state.wrap(state.all(node))}\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element} from 'hast'\n * @import {Strong} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `strong` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Strong} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function strong(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'strong',\n properties: {},\n children: state.all(node)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Table} from 'mdast'\n * @import {Element} from 'hast'\n * @import {State} from '../state.js'\n */\n\nimport {pointEnd, pointStart} from 'unist-util-position'\n\n/**\n * Turn an mdast `table` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Table} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function table(state, node) {\n const rows = state.all(node)\n const firstRow = rows.shift()\n /** @type {Array<Element>} */\n const tableContent = []\n\n if (firstRow) {\n /** @type {Element} */\n const head = {\n type: 'element',\n tagName: 'thead',\n properties: {},\n children: state.wrap([firstRow], true)\n }\n state.patch(node.children[0], head)\n tableContent.push(head)\n }\n\n if (rows.length > 0) {\n /** @type {Element} */\n const body = {\n type: 'element',\n tagName: 'tbody',\n properties: {},\n children: state.wrap(rows, true)\n }\n\n const start = pointStart(node.children[1])\n const end = pointEnd(node.children[node.children.length - 1])\n if (start && end) body.position = {start, end}\n tableContent.push(body)\n }\n\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'table',\n properties: {},\n children: state.wrap(tableContent, true)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element, ElementContent, Properties} from 'hast'\n * @import {Parents, TableRow} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `tableRow` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {TableRow} node\n * mdast node.\n * @param {Parents | undefined} parent\n * Parent of `node`.\n * @returns {Element}\n * hast node.\n */\nexport function tableRow(state, node, parent) {\n const siblings = parent ? parent.children : undefined\n // Generate a body row when without parent.\n const rowIndex = siblings ? siblings.indexOf(node) : 1\n const tagName = rowIndex === 0 ? 'th' : 'td'\n // To do: option to use `style`?\n const align = parent && parent.type === 'table' ? parent.align : undefined\n const length = align ? align.length : node.children.length\n let cellIndex = -1\n /** @type {Array<ElementContent>} */\n const cells = []\n\n while (++cellIndex < length) {\n // Note: can also be undefined.\n const cell = node.children[cellIndex]\n /** @type {Properties} */\n const properties = {}\n const alignValue = align ? align[cellIndex] : undefined\n\n if (alignValue) {\n properties.align = alignValue\n }\n\n /** @type {Element} */\n let result = {type: 'element', tagName, properties, children: []}\n\n if (cell) {\n result.children = state.all(cell)\n state.patch(cell, result)\n result = state.applyData(cell, result)\n }\n\n cells.push(result)\n }\n\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'tr',\n properties: {},\n children: state.wrap(cells, true)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element} from 'hast'\n * @import {TableCell} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `tableCell` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {TableCell} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function tableCell(state, node) {\n // Note: this function is normally not called: see `table-row` for how rows\n // and their cells are compiled.\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'td', // Assume body cell.\n properties: {},\n children: state.all(node)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","const tab = 9 /* `\\t` */\nconst space = 32 /* ` ` */\n\n/**\n * Remove initial and final spaces and tabs at the line breaks in `value`.\n * Does not trim initial and final spaces and tabs of the value itself.\n *\n * @param {string} value\n * Value to trim.\n * @returns {string}\n * Trimmed value.\n */\nexport function trimLines(value) {\n const source = String(value)\n const search = /\\r?\\n|\\r/g\n let match = search.exec(source)\n let last = 0\n /** @type {Array<string>} */\n const lines = []\n\n while (match) {\n lines.push(\n trimLine(source.slice(last, match.index), last > 0, true),\n match[0]\n )\n\n last = match.index + match[0].length\n match = search.exec(source)\n }\n\n lines.push(trimLine(source.slice(last), last > 0, false))\n\n return lines.join('')\n}\n\n/**\n * @param {string} value\n * Line to trim.\n * @param {boolean} start\n * Whether to trim the start of the line.\n * @param {boolean} end\n * Whether to trim the end of the line.\n * @returns {string}\n * Trimmed line.\n */\nfunction trimLine(value, start, end) {\n let startIndex = 0\n let endIndex = value.length\n\n if (start) {\n let code = value.codePointAt(startIndex)\n\n while (code === tab || code === space) {\n startIndex++\n code = value.codePointAt(startIndex)\n }\n }\n\n if (end) {\n let code = value.codePointAt(endIndex - 1)\n\n while (code === tab || code === space) {\n endIndex--\n code = value.codePointAt(endIndex - 1)\n }\n }\n\n return endIndex > startIndex ? value.slice(startIndex, endIndex) : ''\n}\n","/**\n * @import {Element as HastElement, Text as HastText} from 'hast'\n * @import {Text as MdastText} from 'mdast'\n * @import {State} from '../state.js'\n */\n\nimport {trimLines} from 'trim-lines'\n\n/**\n * Turn an mdast `text` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdastText} node\n * mdast node.\n * @returns {HastElement | HastText}\n * hast node.\n */\nexport function text(state, node) {\n /** @type {HastText} */\n const result = {type: 'text', value: trimLines(String(node.value))}\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Element} from 'hast'\n * @import {ThematicBreak} from 'mdast'\n * @import {State} from '../state.js'\n */\n\n/**\n * Turn an mdast `thematicBreak` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {ThematicBreak} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function thematicBreak(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'hr',\n properties: {},\n children: []\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @import {Handlers} from '../state.js'\n */\n\nimport {blockquote} from './blockquote.js'\nimport {hardBreak} from './break.js'\nimport {code} from './code.js'\nimport {strikethrough} from './delete.js'\nimport {emphasis} from './emphasis.js'\nimport {footnoteReference} from './footnote-reference.js'\nimport {heading} from './heading.js'\nimport {html} from './html.js'\nimport {imageReference} from './image-reference.js'\nimport {image} from './image.js'\nimport {inlineCode} from './inline-code.js'\nimport {linkReference} from './link-reference.js'\nimport {link} from './link.js'\nimport {listItem} from './list-item.js'\nimport {list} from './list.js'\nimport {paragraph} from './paragraph.js'\nimport {root} from './root.js'\nimport {strong} from './strong.js'\nimport {table} from './table.js'\nimport {tableRow} from './table-row.js'\nimport {tableCell} from './table-cell.js'\nimport {text} from './text.js'\nimport {thematicBreak} from './thematic-break.js'\n\n/**\n * Default handlers for nodes.\n *\n * @satisfies {Handlers}\n */\nexport const handlers = {\n blockquote,\n break: hardBreak,\n code,\n delete: strikethrough,\n emphasis,\n footnoteReference,\n heading,\n html,\n imageReference,\n image,\n inlineCode,\n linkReference,\n link,\n listItem,\n list,\n paragraph,\n // @ts-expect-error: root is different, but hard to type.\n root,\n strong,\n table,\n tableCell,\n tableRow,\n text,\n thematicBreak,\n toml: ignore,\n yaml: ignore,\n definition: ignore,\n footnoteDefinition: ignore\n}\n\n// Return nothing for nodes that are ignored.\nfunction ignore() {\n return undefined\n}\n","export const VOID = -1;\nexport const PRIMITIVE = 0;\nexport const ARRAY = 1;\nexport const OBJECT = 2;\nexport const DATE = 3;\nexport const REGEXP = 4;\nexport const MAP = 5;\nexport const SET = 6;\nexport const ERROR = 7;\nexport const BIGINT = 8;\n// export const SYMBOL = 9;\n","import {\n VOID, PRIMITIVE,\n ARRAY, OBJECT,\n DATE, REGEXP, MAP, SET,\n ERROR, BIGINT\n} from './types.js';\n\nconst env = typeof self === 'object' ? self : globalThis;\n\nconst guard = (name, init) => {\n switch (name) {\n case 'Function':\n case 'SharedWorker':\n case 'Worker':\n case 'eval':\n case 'setInterval':\n case 'setTimeout':\n throw new TypeError('unable to deserialize ' + name);\n }\n return new env[name](init);\n};\n\nconst deserializer = ($, _) => {\n const as = (out, index) => {\n $.set(index, out);\n return out;\n };\n\n const unpair = index => {\n if ($.has(index))\n return $.get(index);\n\n const [type, value] = _[index];\n switch (type) {\n case PRIMITIVE:\n case VOID:\n return as(value, index);\n case ARRAY: {\n const arr = as([], index);\n for (const index of value)\n arr.push(unpair(index));\n return arr;\n }\n case OBJECT: {\n const object = as({}, index);\n for (const [key, index] of value)\n object[unpair(key)] = unpair(index);\n return object;\n }\n case DATE:\n return as(new Date(value), index);\n case REGEXP: {\n const {source, flags} = value;\n return as(new RegExp(source, flags), index);\n }\n case MAP: {\n const map = as(new Map, index);\n for (const [key, index] of value)\n map.set(unpair(key), unpair(index));\n return map;\n }\n case SET: {\n const set = as(new Set, index);\n for (const index of value)\n set.add(unpair(index));\n return set;\n }\n case ERROR: {\n const {name, message} = value;\n return as(guard(name, message), index);\n }\n case BIGINT:\n return as(BigInt(value), index);\n case 'BigInt':\n return as(Object(BigInt(value)), index);\n case 'ArrayBuffer':\n return as(new Uint8Array(value).buffer, value);\n case 'DataView': {\n const { buffer } = new Uint8Array(value);\n return as(new DataView(buffer), value);\n }\n }\n return as(guard(type, value), index);\n };\n\n return unpair;\n};\n\n/**\n * @typedef {Array<string,any>} Record a type representation\n */\n\n/**\n * Returns a deserialized value from a serialized array of Records.\n * @param {Record[]} serialized a previously serialized value.\n * @returns {any}\n */\nexport const deserialize = serialized => deserializer(new Map, serialized)(0);\n","import {\n VOID, PRIMITIVE,\n ARRAY, OBJECT,\n DATE, REGEXP, MAP, SET,\n ERROR, BIGINT\n} from './types.js';\n\nconst EMPTY = '';\n\nconst {toString} = {};\nconst {keys} = Object;\n\nconst typeOf = value => {\n const type = typeof value;\n if (type !== 'object' || !value)\n return [PRIMITIVE, type];\n\n const asString = toString.call(value).slice(8, -1);\n switch (asString) {\n case 'Array':\n return [ARRAY, EMPTY];\n case 'Object':\n return [OBJECT, EMPTY];\n case 'Date':\n return [DATE, EMPTY];\n case 'RegExp':\n return [REGEXP, EMPTY];\n case 'Map':\n return [MAP, EMPTY];\n case 'Set':\n return [SET, EMPTY];\n case 'DataView':\n return [ARRAY, asString];\n }\n\n if (asString.includes('Array'))\n return [ARRAY, asString];\n\n if (asString.includes('Error'))\n return [ERROR, asString];\n\n return [OBJECT, asString];\n};\n\nconst shouldSkip = ([TYPE, type]) => (\n TYPE === PRIMITIVE &&\n (type === 'function' || type === 'symbol')\n);\n\nconst serializer = (strict, json, $, _) => {\n\n const as = (out, value) => {\n const index = _.push(out) - 1;\n $.set(value, index);\n return index;\n };\n\n const pair = value => {\n if ($.has(value))\n return $.get(value);\n\n let [TYPE, type] = typeOf(value);\n switch (TYPE) {\n case PRIMITIVE: {\n let entry = value;\n switch (type) {\n case 'bigint':\n TYPE = BIGINT;\n entry = value.toString();\n break;\n case 'function':\n case 'symbol':\n if (strict)\n throw new TypeError('unable to serialize ' + type);\n entry = null;\n break;\n case 'undefined':\n return as([VOID], value);\n }\n return as([TYPE, entry], value);\n }\n case ARRAY: {\n if (type) {\n let spread = value;\n if (type === 'DataView') {\n spread = new Uint8Array(value.buffer);\n }\n else if (type === 'ArrayBuffer') {\n spread = new Uint8Array(value);\n }\n return as([type, [...spread]], value);\n }\n\n const arr = [];\n const index = as([TYPE, arr], value);\n for (const entry of value)\n arr.push(pair(entry));\n return index;\n }\n case OBJECT: {\n if (type) {\n switch (type) {\n case 'BigInt':\n return as([type, value.toString()], value);\n case 'Boolean':\n case 'Number':\n case 'String':\n return as([type, value.valueOf()], value);\n }\n }\n\n if (json && ('toJSON' in value))\n return pair(value.toJSON());\n\n const entries = [];\n const index = as([TYPE, entries], value);\n for (const key of keys(value)) {\n if (strict || !shouldSkip(typeOf(value[key])))\n entries.push([pair(key), pair(value[key])]);\n }\n return index;\n }\n case DATE:\n return as([TYPE, value.toISOString()], value);\n case REGEXP: {\n const {source, flags} = value;\n return as([TYPE, {source, flags}], value);\n }\n case MAP: {\n const entries = [];\n const index = as([TYPE, entries], value);\n for (const [key, entry] of value) {\n if (strict || !(shouldSkip(typeOf(key)) || shouldSkip(typeOf(entry))))\n entries.push([pair(key), pair(entry)]);\n }\n return index;\n }\n case SET: {\n const entries = [];\n const index = as([TYPE, entries], value);\n for (const entry of value) {\n if (strict || !shouldSkip(typeOf(entry)))\n entries.push(pair(entry));\n }\n return index;\n }\n }\n\n const {message} = value;\n return as([TYPE, {name: type, message}], value);\n };\n\n return pair;\n};\n\n/**\n * @typedef {Array<string,any>} Record a type representation\n */\n\n/**\n * Returns an array of serialized Records.\n * @param {any} value a serializable value.\n * @param {{json?: boolean, lossy?: boolean}?} options an object with a `lossy` or `json` property that,\n * if `true`, will not throw errors on incompatible types, and behave more\n * like JSON stringify would behave. Symbol and Function will be discarded.\n * @returns {Record[]}\n */\n export const serialize = (value, {json, lossy} = {}) => {\n const _ = [];\n return serializer(!(json || lossy), !!json, new Map, _)(value), _;\n};\n","import {deserialize} from './deserialize.js';\nimport {serialize} from './serialize.js';\n\n/**\n * @typedef {Array<string,any>} Record a type representation\n */\n\n/**\n * Returns an array of serialized Records.\n * @param {any} any a serializable value.\n * @param {{transfer?: any[], json?: boolean, lossy?: boolean}?} options an object with\n * a transfer option (ignored when polyfilled) and/or non standard fields that\n * fallback to the polyfill if present.\n * @returns {Record[]}\n */\nexport default typeof structuredClone === \"function\" ?\n /* c8 ignore start */\n (any, options) => (\n options && ('json' in options || 'lossy' in options) ?\n deserialize(serialize(any, options)) : structuredClone(any)\n ) :\n (any, options) => deserialize(serialize(any, options));\n /* c8 ignore stop */\n\nexport {deserialize, serialize};\n","/**\n * @import {ElementContent, Element} from 'hast'\n * @import {State} from './state.js'\n */\n\n/**\n * @callback FootnoteBackContentTemplate\n * Generate content for the backreference dynamically.\n *\n * For the following markdown:\n *\n * ```markdown\n * Alpha[^micromark], bravo[^micromark], and charlie[^remark].\n *\n * [^remark]: things about remark\n * [^micromark]: things about micromark\n * ```\n *\n * This function will be called with:\n *\n * * `0` and `0` for the backreference from `things about micromark` to\n * `alpha`, as it is the first used definition, and the first call to it\n * * `0` and `1` for the backreference from `things about micromark` to\n * `bravo`, as it is the first used definition, and the second call to it\n * * `1` and `0` for the backreference from `things about remark` to\n * `charlie`, as it is the second used definition\n * @param {number} referenceIndex\n * Index of the definition in the order that they are first referenced,\n * 0-indexed.\n * @param {number} rereferenceIndex\n * Index of calls to the same definition, 0-indexed.\n * @returns {Array<ElementContent> | ElementContent | string}\n * Content for the backreference when linking back from definitions to their\n * reference.\n *\n * @callback FootnoteBackLabelTemplate\n * Generate a back label dynamically.\n *\n * For the following markdown:\n *\n * ```markdown\n * Alpha[^micromark], bravo[^micromark], and charlie[^remark].\n *\n * [^remark]: things about remark\n * [^micromark]: things about micromark\n * ```\n *\n * This function will be called with:\n *\n * * `0` and `0` for the backreference from `things about micromark` to\n * `alpha`, as it is the first used definition, and the first call to it\n * * `0` and `1` for the backreference from `things about micromark` to\n * `bravo`, as it is the first used definition, and the second call to it\n * * `1` and `0` for the backreference from `things about remark` to\n * `charlie`, as it is the second used definition\n * @param {number} referenceIndex\n * Index of the definition in the order that they are first referenced,\n * 0-indexed.\n * @param {number} rereferenceIndex\n * Index of calls to the same definition, 0-indexed.\n * @returns {string}\n * Back label to use when linking back from definitions to their reference.\n */\n\nimport structuredClone from '@ungap/structured-clone'\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Generate the default content that GitHub uses on backreferences.\n *\n * @param {number} _\n * Index of the definition in the order that they are first referenced,\n * 0-indexed.\n * @param {number} rereferenceIndex\n * Index of calls to the same definition, 0-indexed.\n * @returns {Array<ElementContent>}\n * Content.\n */\nexport function defaultFootnoteBackContent(_, rereferenceIndex) {\n /** @type {Array<ElementContent>} */\n const result = [{type: 'text', value: '↩'}]\n\n if (rereferenceIndex > 1) {\n result.push({\n type: 'element',\n tagName: 'sup',\n properties: {},\n children: [{type: 'text', value: String(rereferenceIndex)}]\n })\n }\n\n return result\n}\n\n/**\n * Generate the default label that GitHub uses on backreferences.\n *\n * @param {number} referenceIndex\n * Index of the definition in the order that they are first referenced,\n * 0-indexed.\n * @param {number} rereferenceIndex\n * Index of calls to the same definition, 0-indexed.\n * @returns {string}\n * Label.\n */\nexport function defaultFootnoteBackLabel(referenceIndex, rereferenceIndex) {\n return (\n 'Back to reference ' +\n (referenceIndex + 1) +\n (rereferenceIndex > 1 ? '-' + rereferenceIndex : '')\n )\n}\n\n/**\n * Generate a hast footer for called footnote definitions.\n *\n * @param {State} state\n * Info passed around.\n * @returns {Element | undefined}\n * `section` element or `undefined`.\n */\n// eslint-disable-next-line complexity\nexport function footer(state) {\n const clobberPrefix =\n typeof state.options.clobberPrefix === 'string'\n ? state.options.clobberPrefix\n : 'user-content-'\n const footnoteBackContent =\n state.options.footnoteBackContent || defaultFootnoteBackContent\n const footnoteBackLabel =\n state.options.footnoteBackLabel || defaultFootnoteBackLabel\n const footnoteLabel = state.options.footnoteLabel || 'Footnotes'\n const footnoteLabelTagName = state.options.footnoteLabelTagName || 'h2'\n const footnoteLabelProperties = state.options.footnoteLabelProperties || {\n className: ['sr-only']\n }\n /** @type {Array<ElementContent>} */\n const listItems = []\n let referenceIndex = -1\n\n while (++referenceIndex < state.footnoteOrder.length) {\n const definition = state.footnoteById.get(\n state.footnoteOrder[referenceIndex]\n )\n\n if (!definition) {\n continue\n }\n\n const content = state.all(definition)\n const id = String(definition.identifier).toUpperCase()\n const safeId = normalizeUri(id.toLowerCase())\n let rereferenceIndex = 0\n /** @type {Array<ElementContent>} */\n const backReferences = []\n const counts = state.footnoteCounts.get(id)\n\n // eslint-disable-next-line no-unmodified-loop-condition\n while (counts !== undefined && ++rereferenceIndex <= counts) {\n if (backReferences.length > 0) {\n backReferences.push({type: 'text', value: ' '})\n }\n\n let children =\n typeof footnoteBackContent === 'string'\n ? footnoteBackContent\n : footnoteBackContent(referenceIndex, rereferenceIndex)\n\n if (typeof children === 'string') {\n children = {type: 'text', value: children}\n }\n\n backReferences.push({\n type: 'element',\n tagName: 'a',\n properties: {\n href:\n '#' +\n clobberPrefix +\n 'fnref-' +\n safeId +\n (rereferenceIndex > 1 ? '-' + rereferenceIndex : ''),\n dataFootnoteBackref: '',\n ariaLabel:\n typeof footnoteBackLabel === 'string'\n ? footnoteBackLabel\n : footnoteBackLabel(referenceIndex, rereferenceIndex),\n className: ['data-footnote-backref']\n },\n children: Array.isArray(children) ? children : [children]\n })\n }\n\n const tail = content[content.length - 1]\n\n if (tail && tail.type === 'element' && tail.tagName === 'p') {\n const tailTail = tail.children[tail.children.length - 1]\n if (tailTail && tailTail.type === 'text') {\n tailTail.value += ' '\n } else {\n tail.children.push({type: 'text', value: ' '})\n }\n\n tail.children.push(...backReferences)\n } else {\n content.push(...backReferences)\n }\n\n /** @type {Element} */\n const listItem = {\n type: 'element',\n tagName: 'li',\n properties: {id: clobberPrefix + 'fn-' + safeId},\n children: state.wrap(content, true)\n }\n\n state.patch(definition, listItem)\n\n listItems.push(listItem)\n }\n\n if (listItems.length === 0) {\n return\n }\n\n return {\n type: 'element',\n tagName: 'section',\n properties: {dataFootnotes: true, className: ['footnotes']},\n children: [\n {\n type: 'element',\n tagName: footnoteLabelTagName,\n properties: {\n ...structuredClone(footnoteLabelProperties),\n id: 'footnote-label'\n },\n children: [{type: 'text', value: footnoteLabel}]\n },\n {type: 'text', value: '\\n'},\n {\n type: 'element',\n tagName: 'ol',\n properties: {},\n children: state.wrap(listItems, true)\n },\n {type: 'text', value: '\\n'}\n ]\n }\n}\n","/**\n * @import {Node, Parent} from 'unist'\n */\n\n/**\n * @template Fn\n * @template Fallback\n * @typedef {Fn extends (value: any) => value is infer Thing ? Thing : Fallback} Predicate\n */\n\n/**\n * @callback Check\n * Check that an arbitrary value is a node.\n * @param {unknown} this\n * The given context.\n * @param {unknown} [node]\n * Anything (typically a node).\n * @param {number | null | undefined} [index]\n * The node’s position in its parent.\n * @param {Parent | null | undefined} [parent]\n * The node’s parent.\n * @returns {boolean}\n * Whether this is a node and passes a test.\n *\n * @typedef {Record<string, unknown> | Node} Props\n * Object to check for equivalence.\n *\n * Note: `Node` is included as it is common but is not indexable.\n *\n * @typedef {Array<Props | TestFunction | string> | ReadonlyArray<Props | TestFunction | string> | Props | TestFunction | string | null | undefined} Test\n * Check for an arbitrary node.\n *\n * @callback TestFunction\n * Check if a node passes a test.\n * @param {unknown} this\n * The given context.\n * @param {Node} node\n * A node.\n * @param {number | undefined} [index]\n * The node’s position in its parent.\n * @param {Parent | undefined} [parent]\n * The node’s parent.\n * @returns {boolean | undefined | void}\n * Whether this node passes the test.\n *\n * Note: `void` is included until TS sees no return as `undefined`.\n */\n\n/**\n * Check if `node` is a `Node` and whether it passes the given test.\n *\n * @param {unknown} node\n * Thing to check, typically `Node`.\n * @param {Test} test\n * A check for a specific node.\n * @param {number | null | undefined} index\n * The node’s position in its parent.\n * @param {Parent | null | undefined} parent\n * The node’s parent.\n * @param {unknown} context\n * Context object (`this`) to pass to `test` functions.\n * @returns {boolean}\n * Whether `node` is a node and passes a test.\n */\nexport const is =\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * (<Condition extends ReadonlyArray<string>>(node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition[number]}) &\n * (<Condition extends Array<string>>(node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition[number]}) &\n * (<Condition extends string>(node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition}) &\n * (<Condition extends Props>(node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Condition) &\n * (<Condition extends TestFunction>(node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Predicate<Condition, Node>) &\n * ((node?: null | undefined) => false) &\n * ((node: unknown, test?: null | undefined, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node) &\n * ((node: unknown, test?: Test, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => boolean)\n * )}\n */\n (\n /**\n * @param {unknown} [node]\n * @param {Test} [test]\n * @param {number | null | undefined} [index]\n * @param {Parent | null | undefined} [parent]\n * @param {unknown} [context]\n * @returns {boolean}\n */\n // eslint-disable-next-line max-params\n function (node, test, index, parent, context) {\n const check = convert(test)\n\n if (\n index !== undefined &&\n index !== null &&\n (typeof index !== 'number' ||\n index < 0 ||\n index === Number.POSITIVE_INFINITY)\n ) {\n throw new Error('Expected positive finite index')\n }\n\n if (\n parent !== undefined &&\n parent !== null &&\n (!is(parent) || !parent.children)\n ) {\n throw new Error('Expected parent node')\n }\n\n if (\n (parent === undefined || parent === null) !==\n (index === undefined || index === null)\n ) {\n throw new Error('Expected both parent and index')\n }\n\n return looksLikeANode(node)\n ? check.call(context, node, index, parent)\n : false\n }\n )\n\n/**\n * Generate an assertion from a test.\n *\n * Useful if you’re going to test many nodes, for example when creating a\n * utility where something else passes a compatible test.\n *\n * The created function is a bit faster because it expects valid input only:\n * a `node`, `index`, and `parent`.\n *\n * @param {Test} test\n * * when nullish, checks if `node` is a `Node`.\n * * when `string`, works like passing `(node) => node.type === test`.\n * * when `function` checks if function passed the node is true.\n * * when `object`, checks that all keys in test are in node, and that they have (strictly) equal values.\n * * when `array`, checks if any one of the subtests pass.\n * @returns {Check}\n * An assertion.\n */\nexport const convert =\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * (<Condition extends string>(test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition}) &\n * (<Condition extends Props>(test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Condition) &\n * (<Condition extends TestFunction>(test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Predicate<Condition, Node>) &\n * ((test?: null | undefined) => (node?: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node) &\n * ((test?: Test) => Check)\n * )}\n */\n (\n /**\n * @param {Test} [test]\n * @returns {Check}\n */\n function (test) {\n if (test === null || test === undefined) {\n return ok\n }\n\n if (typeof test === 'function') {\n return castFactory(test)\n }\n\n if (typeof test === 'object') {\n return Array.isArray(test)\n ? anyFactory(test)\n : // Cast because `ReadonlyArray` goes into the above but `isArray`\n // narrows to `Array`.\n propertiesFactory(/** @type {Props} */ (test))\n }\n\n if (typeof test === 'string') {\n return typeFactory(test)\n }\n\n throw new Error('Expected function, string, or object as test')\n }\n )\n\n/**\n * @param {Array<Props | TestFunction | string>} tests\n * @returns {Check}\n */\nfunction anyFactory(tests) {\n /** @type {Array<Check>} */\n const checks = []\n let index = -1\n\n while (++index < tests.length) {\n checks[index] = convert(tests[index])\n }\n\n return castFactory(any)\n\n /**\n * @this {unknown}\n * @type {TestFunction}\n */\n function any(...parameters) {\n let index = -1\n\n while (++index < checks.length) {\n if (checks[index].apply(this, parameters)) return true\n }\n\n return false\n }\n}\n\n/**\n * Turn an object into a test for a node with a certain fields.\n *\n * @param {Props} check\n * @returns {Check}\n */\nfunction propertiesFactory(check) {\n const checkAsRecord = /** @type {Record<string, unknown>} */ (check)\n\n return castFactory(all)\n\n /**\n * @param {Node} node\n * @returns {boolean}\n */\n function all(node) {\n const nodeAsRecord = /** @type {Record<string, unknown>} */ (\n /** @type {unknown} */ (node)\n )\n\n /** @type {string} */\n let key\n\n for (key in check) {\n if (nodeAsRecord[key] !== checkAsRecord[key]) return false\n }\n\n return true\n }\n}\n\n/**\n * Turn a string into a test for a node with a certain type.\n *\n * @param {string} check\n * @returns {Check}\n */\nfunction typeFactory(check) {\n return castFactory(type)\n\n /**\n * @param {Node} node\n */\n function type(node) {\n return node && node.type === check\n }\n}\n\n/**\n * Turn a custom test into a test for a node that passes that test.\n *\n * @param {TestFunction} testFunction\n * @returns {Check}\n */\nfunction castFactory(testFunction) {\n return check\n\n /**\n * @this {unknown}\n * @type {Check}\n */\n function check(value, index, parent) {\n return Boolean(\n looksLikeANode(value) &&\n testFunction.call(\n this,\n value,\n typeof index === 'number' ? index : undefined,\n parent || undefined\n )\n )\n }\n}\n\nfunction ok() {\n return true\n}\n\n/**\n * @param {unknown} value\n * @returns {value is Node}\n */\nfunction looksLikeANode(value) {\n return value !== null && typeof value === 'object' && 'type' in value\n}\n","/**\n * @import {Node as UnistNode, Parent as UnistParent} from 'unist'\n */\n\n/**\n * @typedef {Exclude<import('unist-util-is').Test, undefined> | undefined} Test\n * Test from `unist-util-is`.\n *\n * Note: we have remove and add `undefined`, because otherwise when generating\n * automatic `.d.ts` files, TS tries to flatten paths from a local perspective,\n * which doesn’t work when publishing on npm.\n */\n\n/**\n * @typedef {(\n * Fn extends (value: any) => value is infer Thing\n * ? Thing\n * : Fallback\n * )} Predicate\n * Get the value of a type guard `Fn`.\n * @template Fn\n * Value; typically function that is a type guard (such as `(x): x is Y`).\n * @template Fallback\n * Value to yield if `Fn` is not a type guard.\n */\n\n/**\n * @typedef {(\n * Check extends null | undefined // No test.\n * ? Value\n * : Value extends {type: Check} // String (type) test.\n * ? Value\n * : Value extends Check // Partial test.\n * ? Value\n * : Check extends Function // Function test.\n * ? Predicate<Check, Value> extends Value\n * ? Predicate<Check, Value>\n * : never\n * : never // Some other test?\n * )} MatchesOne\n * Check whether a node matches a primitive check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test, but not arrays.\n */\n\n/**\n * @typedef {(\n * Check extends ReadonlyArray<infer T>\n * ? MatchesOne<Value, T>\n * : Check extends Array<infer T>\n * ? MatchesOne<Value, T>\n * : MatchesOne<Value, Check>\n * )} Matches\n * Check whether a node matches a check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test.\n */\n\n/**\n * @typedef {0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10} Uint\n * Number; capped reasonably.\n */\n\n/**\n * @typedef {I extends 0 ? 1 : I extends 1 ? 2 : I extends 2 ? 3 : I extends 3 ? 4 : I extends 4 ? 5 : I extends 5 ? 6 : I extends 6 ? 7 : I extends 7 ? 8 : I extends 8 ? 9 : 10} Increment\n * Increment a number in the type system.\n * @template {Uint} [I=0]\n * Index.\n */\n\n/**\n * @typedef {(\n * Node extends UnistParent\n * ? Node extends {children: Array<infer Children>}\n * ? Child extends Children ? Node : never\n * : never\n * : never\n * )} InternalParent\n * Collect nodes that can be parents of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {InternalParent<InclusiveDescendant<Tree>, Child>} Parent\n * Collect nodes in `Tree` that can be parents of `Child`.\n * @template {UnistNode} Tree\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {(\n * Depth extends Max\n * ? never\n * :\n * | InternalParent<Node, Child>\n * | InternalAncestor<Node, InternalParent<Node, Child>, Max, Increment<Depth>>\n * )} InternalAncestor\n * Collect nodes in `Tree` that can be ancestors of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @typedef {InternalAncestor<InclusiveDescendant<Tree>, Child>} Ancestor\n * Collect nodes in `Tree` that can be ancestors of `Child`.\n * @template {UnistNode} Tree\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {(\n * Tree extends UnistParent\n * ? Depth extends Max\n * ? Tree\n * : Tree | InclusiveDescendant<Tree['children'][number], Max, Increment<Depth>>\n * : Tree\n * )} InclusiveDescendant\n * Collect all (inclusive) descendants of `Tree`.\n *\n * > 👉 **Note**: for performance reasons, this seems to be the fastest way to\n * > recurse without actually running into an infinite loop, which the\n * > previous version did.\n * >\n * > Practically, a max of `2` is typically enough assuming a `Root` is\n * > passed, but it doesn’t improve performance.\n * > It gets higher with `List > ListItem > Table > TableRow > TableCell`.\n * > Using up to `10` doesn’t hurt or help either.\n * @template {UnistNode} Tree\n * Tree type.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @typedef {'skip' | boolean} Action\n * Union of the action types.\n *\n * @typedef {number} Index\n * Move to the sibling at `index` next (after node itself is completely\n * traversed).\n *\n * Useful if mutating the tree, such as removing the node the visitor is\n * currently on, or any of its previous siblings.\n * Results less than 0 or greater than or equal to `children.length` stop\n * traversing the parent.\n *\n * @typedef {[(Action | null | undefined | void)?, (Index | null | undefined)?]} ActionTuple\n * List with one or two values, the first an action, the second an index.\n *\n * @typedef {Action | ActionTuple | Index | null | undefined | void} VisitorResult\n * Any value that can be returned from a visitor.\n */\n\n/**\n * @callback Visitor\n * Handle a node (matching `test`, if given).\n *\n * Visitors are free to transform `node`.\n * They can also transform the parent of node (the last of `ancestors`).\n *\n * Replacing `node` itself, if `SKIP` is not returned, still causes its\n * descendants to be walked (which is a bug).\n *\n * When adding or removing previous siblings of `node` (or next siblings, in\n * case of reverse), the `Visitor` should return a new `Index` to specify the\n * sibling to traverse after `node` is traversed.\n * Adding or removing next siblings of `node` (or previous siblings, in case\n * of reverse) is handled as expected without needing to return a new `Index`.\n *\n * Removing the children property of an ancestor still results in them being\n * traversed.\n * @param {Visited} node\n * Found node.\n * @param {Array<VisitedParents>} ancestors\n * Ancestors of `node`.\n * @returns {VisitorResult}\n * What to do next.\n *\n * An `Index` is treated as a tuple of `[CONTINUE, Index]`.\n * An `Action` is treated as a tuple of `[Action]`.\n *\n * Passing a tuple back only makes sense if the `Action` is `SKIP`.\n * When the `Action` is `EXIT`, that action can be returned.\n * When the `Action` is `CONTINUE`, `Index` can be returned.\n * @template {UnistNode} [Visited=UnistNode]\n * Visited node type.\n * @template {UnistParent} [VisitedParents=UnistParent]\n * Ancestor type.\n */\n\n/**\n * @typedef {Visitor<Matches<InclusiveDescendant<Tree>, Check>, Ancestor<Tree, Matches<InclusiveDescendant<Tree>, Check>>>} BuildVisitor\n * Build a typed `Visitor` function from a tree and a test.\n *\n * It will infer which values are passed as `node` and which as `parents`.\n * @template {UnistNode} [Tree=UnistNode]\n * Tree type.\n * @template {Test} [Check=Test]\n * Test type.\n */\n\nimport {convert} from 'unist-util-is'\nimport {color} from 'unist-util-visit-parents/do-not-use-color'\n\n/** @type {Readonly<ActionTuple>} */\nconst empty = []\n\n/**\n * Continue traversing as normal.\n */\nexport const CONTINUE = true\n\n/**\n * Stop traversing immediately.\n */\nexport const EXIT = false\n\n/**\n * Do not traverse this node’s children.\n */\nexport const SKIP = 'skip'\n\n/**\n * Visit nodes, with ancestral information.\n *\n * This algorithm performs *depth-first* *tree traversal* in *preorder*\n * (**NLR**) or if `reverse` is given, in *reverse preorder* (**NRL**).\n *\n * You can choose for which nodes `visitor` is called by passing a `test`.\n * For complex tests, you should test yourself in `visitor`, as it will be\n * faster and will have improved type information.\n *\n * Walking the tree is an intensive task.\n * Make use of the return values of the visitor when possible.\n * Instead of walking a tree multiple times, walk it once, use `unist-util-is`\n * to check if a node matches, and then perform different operations.\n *\n * You can change the tree.\n * See `Visitor` for more info.\n *\n * @overload\n * @param {Tree} tree\n * @param {Check} check\n * @param {BuildVisitor<Tree, Check>} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @overload\n * @param {Tree} tree\n * @param {BuildVisitor<Tree>} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @param {UnistNode} tree\n * Tree to traverse.\n * @param {Visitor | Test} test\n * `unist-util-is`-compatible test\n * @param {Visitor | boolean | null | undefined} [visitor]\n * Handle each node.\n * @param {boolean | null | undefined} [reverse]\n * Traverse in reverse preorder (NRL) instead of the default preorder (NLR).\n * @returns {undefined}\n * Nothing.\n *\n * @template {UnistNode} Tree\n * Node type.\n * @template {Test} Check\n * `unist-util-is`-compatible test.\n */\nexport function visitParents(tree, test, visitor, reverse) {\n /** @type {Test} */\n let check\n\n if (typeof test === 'function' && typeof visitor !== 'function') {\n reverse = visitor\n // @ts-expect-error no visitor given, so `visitor` is test.\n visitor = test\n } else {\n // @ts-expect-error visitor given, so `test` isn’t a visitor.\n check = test\n }\n\n const is = convert(check)\n const step = reverse ? -1 : 1\n\n factory(tree, undefined, [])()\n\n /**\n * @param {UnistNode} node\n * @param {number | undefined} index\n * @param {Array<UnistParent>} parents\n */\n function factory(node, index, parents) {\n const value = /** @type {Record<string, unknown>} */ (\n node && typeof node === 'object' ? node : {}\n )\n\n if (typeof value.type === 'string') {\n const name =\n // `hast`\n typeof value.tagName === 'string'\n ? value.tagName\n : // `xast`\n typeof value.name === 'string'\n ? value.name\n : undefined\n\n Object.defineProperty(visit, 'name', {\n value:\n 'node (' + color(node.type + (name ? '<' + name + '>' : '')) + ')'\n })\n }\n\n return visit\n\n function visit() {\n /** @type {Readonly<ActionTuple>} */\n let result = empty\n /** @type {Readonly<ActionTuple>} */\n let subresult\n /** @type {number} */\n let offset\n /** @type {Array<UnistParent>} */\n let grandparents\n\n if (!test || is(node, index, parents[parents.length - 1] || undefined)) {\n // @ts-expect-error: `visitor` is now a visitor.\n result = toResult(visitor(node, parents))\n\n if (result[0] === EXIT) {\n return result\n }\n }\n\n if ('children' in node && node.children) {\n const nodeAsParent = /** @type {UnistParent} */ (node)\n\n if (nodeAsParent.children && result[0] !== SKIP) {\n offset = (reverse ? nodeAsParent.children.length : -1) + step\n grandparents = parents.concat(nodeAsParent)\n\n while (offset > -1 && offset < nodeAsParent.children.length) {\n const child = nodeAsParent.children[offset]\n\n subresult = factory(child, offset, grandparents)()\n\n if (subresult[0] === EXIT) {\n return subresult\n }\n\n offset =\n typeof subresult[1] === 'number' ? subresult[1] : offset + step\n }\n }\n }\n\n return result\n }\n }\n}\n\n/**\n * Turn a return value into a clean result.\n *\n * @param {VisitorResult} value\n * Valid return values from visitors.\n * @returns {Readonly<ActionTuple>}\n * Clean result.\n */\nfunction toResult(value) {\n if (Array.isArray(value)) {\n return value\n }\n\n if (typeof value === 'number') {\n return [CONTINUE, value]\n }\n\n return value === null || value === undefined ? empty : [value]\n}\n","/**\n * @import {Node as UnistNode, Parent as UnistParent} from 'unist'\n * @import {VisitorResult} from 'unist-util-visit-parents'\n */\n\n/**\n * @typedef {Exclude<import('unist-util-is').Test, undefined> | undefined} Test\n * Test from `unist-util-is`.\n *\n * Note: we have remove and add `undefined`, because otherwise when generating\n * automatic `.d.ts` files, TS tries to flatten paths from a local perspective,\n * which doesn’t work when publishing on npm.\n */\n\n// To do: use types from `unist-util-visit-parents` when it’s released.\n\n/**\n * @typedef {(\n * Fn extends (value: any) => value is infer Thing\n * ? Thing\n * : Fallback\n * )} Predicate\n * Get the value of a type guard `Fn`.\n * @template Fn\n * Value; typically function that is a type guard (such as `(x): x is Y`).\n * @template Fallback\n * Value to yield if `Fn` is not a type guard.\n */\n\n/**\n * @typedef {(\n * Check extends null | undefined // No test.\n * ? Value\n * : Value extends {type: Check} // String (type) test.\n * ? Value\n * : Value extends Check // Partial test.\n * ? Value\n * : Check extends Function // Function test.\n * ? Predicate<Check, Value> extends Value\n * ? Predicate<Check, Value>\n * : never\n * : never // Some other test?\n * )} MatchesOne\n * Check whether a node matches a primitive check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test, but not arrays.\n */\n\n/**\n * @typedef {(\n * Check extends ReadonlyArray<any>\n * ? MatchesOne<Value, Check[number]>\n * : MatchesOne<Value, Check>\n * )} Matches\n * Check whether a node matches a check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test.\n */\n\n/**\n * @typedef {0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10} Uint\n * Number; capped reasonably.\n */\n\n/**\n * @typedef {I extends 0 ? 1 : I extends 1 ? 2 : I extends 2 ? 3 : I extends 3 ? 4 : I extends 4 ? 5 : I extends 5 ? 6 : I extends 6 ? 7 : I extends 7 ? 8 : I extends 8 ? 9 : 10} Increment\n * Increment a number in the type system.\n * @template {Uint} [I=0]\n * Index.\n */\n\n/**\n * @typedef {(\n * Node extends UnistParent\n * ? Node extends {children: Array<infer Children>}\n * ? Child extends Children ? Node : never\n * : never\n * : never\n * )} InternalParent\n * Collect nodes that can be parents of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {InternalParent<InclusiveDescendant<Tree>, Child>} Parent\n * Collect nodes in `Tree` that can be parents of `Child`.\n * @template {UnistNode} Tree\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {(\n * Depth extends Max\n * ? never\n * :\n * | InternalParent<Node, Child>\n * | InternalAncestor<Node, InternalParent<Node, Child>, Max, Increment<Depth>>\n * )} InternalAncestor\n * Collect nodes in `Tree` that can be ancestors of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @typedef {(\n * Tree extends UnistParent\n * ? Depth extends Max\n * ? Tree\n * : Tree | InclusiveDescendant<Tree['children'][number], Max, Increment<Depth>>\n * : Tree\n * )} InclusiveDescendant\n * Collect all (inclusive) descendants of `Tree`.\n *\n * > 👉 **Note**: for performance reasons, this seems to be the fastest way to\n * > recurse without actually running into an infinite loop, which the\n * > previous version did.\n * >\n * > Practically, a max of `2` is typically enough assuming a `Root` is\n * > passed, but it doesn’t improve performance.\n * > It gets higher with `List > ListItem > Table > TableRow > TableCell`.\n * > Using up to `10` doesn’t hurt or help either.\n * @template {UnistNode} Tree\n * Tree type.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @callback Visitor\n * Handle a node (matching `test`, if given).\n *\n * Visitors are free to transform `node`.\n * They can also transform `parent`.\n *\n * Replacing `node` itself, if `SKIP` is not returned, still causes its\n * descendants to be walked (which is a bug).\n *\n * When adding or removing previous siblings of `node` (or next siblings, in\n * case of reverse), the `Visitor` should return a new `Index` to specify the\n * sibling to traverse after `node` is traversed.\n * Adding or removing next siblings of `node` (or previous siblings, in case\n * of reverse) is handled as expected without needing to return a new `Index`.\n *\n * Removing the children property of `parent` still results in them being\n * traversed.\n * @param {Visited} node\n * Found node.\n * @param {Visited extends UnistNode ? number | undefined : never} index\n * Index of `node` in `parent`.\n * @param {Ancestor extends UnistParent ? Ancestor | undefined : never} parent\n * Parent of `node`.\n * @returns {VisitorResult}\n * What to do next.\n *\n * An `Index` is treated as a tuple of `[CONTINUE, Index]`.\n * An `Action` is treated as a tuple of `[Action]`.\n *\n * Passing a tuple back only makes sense if the `Action` is `SKIP`.\n * When the `Action` is `EXIT`, that action can be returned.\n * When the `Action` is `CONTINUE`, `Index` can be returned.\n * @template {UnistNode} [Visited=UnistNode]\n * Visited node type.\n * @template {UnistParent} [Ancestor=UnistParent]\n * Ancestor type.\n */\n\n/**\n * @typedef {Visitor<Visited, Parent<Ancestor, Visited>>} BuildVisitorFromMatch\n * Build a typed `Visitor` function from a node and all possible parents.\n *\n * It will infer which values are passed as `node` and which as `parent`.\n * @template {UnistNode} Visited\n * Node type.\n * @template {UnistParent} Ancestor\n * Parent type.\n */\n\n/**\n * @typedef {(\n * BuildVisitorFromMatch<\n * Matches<Descendant, Check>,\n * Extract<Descendant, UnistParent>\n * >\n * )} BuildVisitorFromDescendants\n * Build a typed `Visitor` function from a list of descendants and a test.\n *\n * It will infer which values are passed as `node` and which as `parent`.\n * @template {UnistNode} Descendant\n * Node type.\n * @template {Test} Check\n * Test type.\n */\n\n/**\n * @typedef {(\n * BuildVisitorFromDescendants<\n * InclusiveDescendant<Tree>,\n * Check\n * >\n * )} BuildVisitor\n * Build a typed `Visitor` function from a tree and a test.\n *\n * It will infer which values are passed as `node` and which as `parent`.\n * @template {UnistNode} [Tree=UnistNode]\n * Node type.\n * @template {Test} [Check=Test]\n * Test type.\n */\n\nimport {visitParents} from 'unist-util-visit-parents'\n\nexport {CONTINUE, EXIT, SKIP} from 'unist-util-visit-parents'\n\n/**\n * Visit nodes.\n *\n * This algorithm performs *depth-first* *tree traversal* in *preorder*\n * (**NLR**) or if `reverse` is given, in *reverse preorder* (**NRL**).\n *\n * You can choose for which nodes `visitor` is called by passing a `test`.\n * For complex tests, you should test yourself in `visitor`, as it will be\n * faster and will have improved type information.\n *\n * Walking the tree is an intensive task.\n * Make use of the return values of the visitor when possible.\n * Instead of walking a tree multiple times, walk it once, use `unist-util-is`\n * to check if a node matches, and then perform different operations.\n *\n * You can change the tree.\n * See `Visitor` for more info.\n *\n * @overload\n * @param {Tree} tree\n * @param {Check} check\n * @param {BuildVisitor<Tree, Check>} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @overload\n * @param {Tree} tree\n * @param {BuildVisitor<Tree>} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @param {UnistNode} tree\n * Tree to traverse.\n * @param {Visitor | Test} testOrVisitor\n * `unist-util-is`-compatible test (optional, omit to pass a visitor).\n * @param {Visitor | boolean | null | undefined} [visitorOrReverse]\n * Handle each node (when test is omitted, pass `reverse`).\n * @param {boolean | null | undefined} [maybeReverse=false]\n * Traverse in reverse preorder (NRL) instead of the default preorder (NLR).\n * @returns {undefined}\n * Nothing.\n *\n * @template {UnistNode} Tree\n * Node type.\n * @template {Test} Check\n * `unist-util-is`-compatible test.\n */\nexport function visit(tree, testOrVisitor, visitorOrReverse, maybeReverse) {\n /** @type {boolean | null | undefined} */\n let reverse\n /** @type {Test} */\n let test\n /** @type {Visitor} */\n let visitor\n\n if (\n typeof testOrVisitor === 'function' &&\n typeof visitorOrReverse !== 'function'\n ) {\n test = undefined\n visitor = testOrVisitor\n reverse = visitorOrReverse\n } else {\n // @ts-expect-error: assume the overload with test was given.\n test = testOrVisitor\n // @ts-expect-error: assume the overload with test was given.\n visitor = visitorOrReverse\n reverse = maybeReverse\n }\n\n visitParents(tree, test, overload, reverse)\n\n /**\n * @param {UnistNode} node\n * @param {Array<UnistParent>} parents\n */\n function overload(node, parents) {\n const parent = parents[parents.length - 1]\n const index = parent ? parent.children.indexOf(node) : undefined\n return visitor(node, index, parent)\n }\n}\n","/**\n * @import {\n * ElementContent as HastElementContent,\n * Element as HastElement,\n * Nodes as HastNodes,\n * Properties as HastProperties,\n * RootContent as HastRootContent,\n * Text as HastText\n * } from 'hast'\n * @import {\n * Definition as MdastDefinition,\n * FootnoteDefinition as MdastFootnoteDefinition,\n * Nodes as MdastNodes,\n * Parents as MdastParents\n * } from 'mdast'\n * @import {VFile} from 'vfile'\n * @import {\n * FootnoteBackContentTemplate,\n * FootnoteBackLabelTemplate\n * } from './footer.js'\n */\n\n/**\n * @callback Handler\n * Handle a node.\n * @param {State} state\n * Info passed around.\n * @param {any} node\n * mdast node to handle.\n * @param {MdastParents | undefined} parent\n * Parent of `node`.\n * @returns {Array<HastElementContent> | HastElementContent | undefined}\n * hast node.\n *\n * @typedef {Partial<Record<MdastNodes['type'], Handler>>} Handlers\n * Handle nodes.\n *\n * @typedef Options\n * Configuration (optional).\n * @property {boolean | null | undefined} [allowDangerousHtml=false]\n * Whether to persist raw HTML in markdown in the hast tree (default:\n * `false`).\n * @property {string | null | undefined} [clobberPrefix='user-content-']\n * Prefix to use before the `id` property on footnotes to prevent them from\n * *clobbering* (default: `'user-content-'`).\n *\n * Pass `''` for trusted markdown and when you are careful with\n * polyfilling.\n * You could pass a different prefix.\n *\n * DOM clobbering is this:\n *\n * ```html\n * <p id=\"x\"></p>\n * <script>alert(x) // `x` now refers to the `p#x` DOM element</script>\n * ```\n *\n * The above example shows that elements are made available by browsers, by\n * their ID, on the `window` object.\n * This is a security risk because you might be expecting some other variable\n * at that place.\n * It can also break polyfills.\n * Using a prefix solves these problems.\n * @property {VFile | null | undefined} [file]\n * Corresponding virtual file representing the input document (optional).\n * @property {FootnoteBackContentTemplate | string | null | undefined} [footnoteBackContent]\n * Content of the backreference back to references (default: `defaultFootnoteBackContent`).\n *\n * The default value is:\n *\n * ```js\n * function defaultFootnoteBackContent(_, rereferenceIndex) {\n * const result = [{type: 'text', value: '↩'}]\n *\n * if (rereferenceIndex > 1) {\n * result.push({\n * type: 'element',\n * tagName: 'sup',\n * properties: {},\n * children: [{type: 'text', value: String(rereferenceIndex)}]\n * })\n * }\n *\n * return result\n * }\n * ```\n *\n * This content is used in the `a` element of each backreference (the `↩`\n * links).\n * @property {FootnoteBackLabelTemplate | string | null | undefined} [footnoteBackLabel]\n * Label to describe the backreference back to references (default:\n * `defaultFootnoteBackLabel`).\n *\n * The default value is:\n *\n * ```js\n * function defaultFootnoteBackLabel(referenceIndex, rereferenceIndex) {\n * return (\n * 'Back to reference ' +\n * (referenceIndex + 1) +\n * (rereferenceIndex > 1 ? '-' + rereferenceIndex : '')\n * )\n * }\n * ```\n *\n * Change it when the markdown is not in English.\n *\n * This label is used in the `ariaLabel` property on each backreference\n * (the `↩` links).\n * It affects users of assistive technology.\n * @property {string | null | undefined} [footnoteLabel='Footnotes']\n * Textual label to use for the footnotes section (default: `'Footnotes'`).\n *\n * Change it when the markdown is not in English.\n *\n * This label is typically hidden visually (assuming a `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass different properties with the `footnoteLabelProperties` option.\n * @property {HastProperties | null | undefined} [footnoteLabelProperties={className: ['sr-only']}]\n * Properties to use on the footnote label (default: `{className:\n * ['sr-only']}`).\n *\n * Change it to show the label and add other properties.\n *\n * This label is typically hidden visually (assuming an `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass an empty string.\n * You can also add different properties.\n *\n * > **Note**: `id: 'footnote-label'` is always added, because footnote\n * > calls use it with `aria-describedby` to provide an accessible label.\n * @property {string | null | undefined} [footnoteLabelTagName='h2']\n * HTML tag name to use for the footnote label element (default: `'h2'`).\n *\n * Change it to match your document structure.\n *\n * This label is typically hidden visually (assuming a `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass different properties with the `footnoteLabelProperties` option.\n * @property {Handlers | null | undefined} [handlers]\n * Extra handlers for nodes (optional).\n * @property {Array<MdastNodes['type']> | null | undefined} [passThrough]\n * List of custom mdast node types to pass through (keep) in hast (note that\n * the node itself is passed, but eventual children are transformed)\n * (optional).\n * @property {Handler | null | undefined} [unknownHandler]\n * Handler for all unknown nodes (optional).\n *\n * @typedef State\n * Info passed around.\n * @property {(node: MdastNodes) => Array<HastElementContent>} all\n * Transform the children of an mdast parent to hast.\n * @property {<Type extends HastNodes>(from: MdastNodes, to: Type) => HastElement | Type} applyData\n * Honor the `data` of `from`, and generate an element instead of `node`.\n * @property {Map<string, MdastDefinition>} definitionById\n * Definitions by their identifier.\n * @property {Map<string, MdastFootnoteDefinition>} footnoteById\n * Footnote definitions by their identifier.\n * @property {Map<string, number>} footnoteCounts\n * Counts for how often the same footnote was called.\n * @property {Array<string>} footnoteOrder\n * Identifiers of order when footnote calls first appear in tree order.\n * @property {Handlers} handlers\n * Applied handlers.\n * @property {(node: MdastNodes, parent: MdastParents | undefined) => Array<HastElementContent> | HastElementContent | undefined} one\n * Transform an mdast node to hast.\n * @property {Options} options\n * Configuration.\n * @property {(from: MdastNodes, node: HastNodes) => undefined} patch\n * Copy a node’s positional info.\n * @property {<Type extends HastRootContent>(nodes: Array<Type>, loose?: boolean | undefined) => Array<HastText | Type>} wrap\n * Wrap `nodes` with line endings between each node, adds initial/final line endings when `loose`.\n */\n\nimport structuredClone from '@ungap/structured-clone'\nimport {visit} from 'unist-util-visit'\nimport {position} from 'unist-util-position'\nimport {handlers as defaultHandlers} from './handlers/index.js'\n\nconst own = {}.hasOwnProperty\n\n/** @type {Options} */\nconst emptyOptions = {}\n\n/**\n * Create `state` from an mdast tree.\n *\n * @param {MdastNodes} tree\n * mdast node to transform.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {State}\n * `state` function.\n */\nexport function createState(tree, options) {\n const settings = options || emptyOptions\n /** @type {Map<string, MdastDefinition>} */\n const definitionById = new Map()\n /** @type {Map<string, MdastFootnoteDefinition>} */\n const footnoteById = new Map()\n /** @type {Map<string, number>} */\n const footnoteCounts = new Map()\n /** @type {Handlers} */\n // @ts-expect-error: the root handler returns a root.\n // Hard to type.\n const handlers = {...defaultHandlers, ...settings.handlers}\n\n /** @type {State} */\n const state = {\n all,\n applyData,\n definitionById,\n footnoteById,\n footnoteCounts,\n footnoteOrder: [],\n handlers,\n one,\n options: settings,\n patch,\n wrap\n }\n\n visit(tree, function (node) {\n if (node.type === 'definition' || node.type === 'footnoteDefinition') {\n const map = node.type === 'definition' ? definitionById : footnoteById\n const id = String(node.identifier).toUpperCase()\n\n // Mimick CM behavior of link definitions.\n // See: <https://github.com/syntax-tree/mdast-util-definitions/blob/9032189/lib/index.js#L20-L21>.\n if (!map.has(id)) {\n // @ts-expect-error: node type matches map.\n map.set(id, node)\n }\n }\n })\n\n return state\n\n /**\n * Transform an mdast node into a hast node.\n *\n * @param {MdastNodes} node\n * mdast node.\n * @param {MdastParents | undefined} [parent]\n * Parent of `node`.\n * @returns {Array<HastElementContent> | HastElementContent | undefined}\n * Resulting hast node.\n */\n function one(node, parent) {\n const type = node.type\n const handle = state.handlers[type]\n\n if (own.call(state.handlers, type) && handle) {\n return handle(state, node, parent)\n }\n\n if (state.options.passThrough && state.options.passThrough.includes(type)) {\n if ('children' in node) {\n const {children, ...shallow} = node\n const result = structuredClone(shallow)\n // @ts-expect-error: TS doesn’t understand…\n result.children = state.all(node)\n // @ts-expect-error: TS doesn’t understand…\n return result\n }\n\n // @ts-expect-error: it’s custom.\n return structuredClone(node)\n }\n\n const unknown = state.options.unknownHandler || defaultUnknownHandler\n\n return unknown(state, node, parent)\n }\n\n /**\n * Transform the children of an mdast node into hast nodes.\n *\n * @param {MdastNodes} parent\n * mdast node to compile\n * @returns {Array<HastElementContent>}\n * Resulting hast nodes.\n */\n function all(parent) {\n /** @type {Array<HastElementContent>} */\n const values = []\n\n if ('children' in parent) {\n const nodes = parent.children\n let index = -1\n while (++index < nodes.length) {\n const result = state.one(nodes[index], parent)\n\n // To do: see if we van clean this? Can we merge texts?\n if (result) {\n if (index && nodes[index - 1].type === 'break') {\n if (!Array.isArray(result) && result.type === 'text') {\n result.value = trimMarkdownSpaceStart(result.value)\n }\n\n if (!Array.isArray(result) && result.type === 'element') {\n const head = result.children[0]\n\n if (head && head.type === 'text') {\n head.value = trimMarkdownSpaceStart(head.value)\n }\n }\n }\n\n if (Array.isArray(result)) {\n values.push(...result)\n } else {\n values.push(result)\n }\n }\n }\n }\n\n return values\n }\n}\n\n/**\n * Copy a node’s positional info.\n *\n * @param {MdastNodes} from\n * mdast node to copy from.\n * @param {HastNodes} to\n * hast node to copy into.\n * @returns {undefined}\n * Nothing.\n */\nfunction patch(from, to) {\n if (from.position) to.position = position(from)\n}\n\n/**\n * Honor the `data` of `from` and maybe generate an element instead of `to`.\n *\n * @template {HastNodes} Type\n * Node type.\n * @param {MdastNodes} from\n * mdast node to use data from.\n * @param {Type} to\n * hast node to change.\n * @returns {HastElement | Type}\n * Nothing.\n */\nfunction applyData(from, to) {\n /** @type {HastElement | Type} */\n let result = to\n\n // Handle `data.hName`, `data.hProperties, `data.hChildren`.\n if (from && from.data) {\n const hName = from.data.hName\n const hChildren = from.data.hChildren\n const hProperties = from.data.hProperties\n\n if (typeof hName === 'string') {\n // Transforming the node resulted in an element with a different name\n // than wanted:\n if (result.type === 'element') {\n result.tagName = hName\n }\n // Transforming the node resulted in a non-element, which happens for\n // raw, text, and root nodes (unless custom handlers are passed).\n // The intent of `hName` is to create an element, but likely also to keep\n // the content around (otherwise: pass `hChildren`).\n else {\n /** @type {Array<HastElementContent>} */\n // @ts-expect-error: assume no doctypes in `root`.\n const children = 'children' in result ? result.children : [result]\n result = {type: 'element', tagName: hName, properties: {}, children}\n }\n }\n\n if (result.type === 'element' && hProperties) {\n Object.assign(result.properties, structuredClone(hProperties))\n }\n\n if (\n 'children' in result &&\n result.children &&\n hChildren !== null &&\n hChildren !== undefined\n ) {\n result.children = hChildren\n }\n }\n\n return result\n}\n\n/**\n * Transform an unknown node.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdastNodes} node\n * Unknown mdast node.\n * @returns {HastElement | HastText}\n * Resulting hast node.\n */\nfunction defaultUnknownHandler(state, node) {\n const data = node.data || {}\n /** @type {HastElement | HastText} */\n const result =\n 'value' in node &&\n !(own.call(data, 'hProperties') || own.call(data, 'hChildren'))\n ? {type: 'text', value: node.value}\n : {\n type: 'element',\n tagName: 'div',\n properties: {},\n children: state.all(node)\n }\n\n state.patch(node, result)\n return state.applyData(node, result)\n}\n\n/**\n * Wrap `nodes` with line endings between each node.\n *\n * @template {HastRootContent} Type\n * Node type.\n * @param {Array<Type>} nodes\n * List of nodes to wrap.\n * @param {boolean | undefined} [loose=false]\n * Whether to add line endings at start and end (default: `false`).\n * @returns {Array<HastText | Type>}\n * Wrapped nodes.\n */\nexport function wrap(nodes, loose) {\n /** @type {Array<HastText | Type>} */\n const result = []\n let index = -1\n\n if (loose) {\n result.push({type: 'text', value: '\\n'})\n }\n\n while (++index < nodes.length) {\n if (index) result.push({type: 'text', value: '\\n'})\n result.push(nodes[index])\n }\n\n if (loose && nodes.length > 0) {\n result.push({type: 'text', value: '\\n'})\n }\n\n return result\n}\n\n/**\n * Trim spaces and tabs at the start of `value`.\n *\n * @param {string} value\n * Value to trim.\n * @returns {string}\n * Result.\n */\nfunction trimMarkdownSpaceStart(value) {\n let index = 0\n let code = value.charCodeAt(index)\n\n while (code === 9 || code === 32) {\n index++\n code = value.charCodeAt(index)\n }\n\n return value.slice(index)\n}\n","/**\n * @import {Nodes as HastNodes} from 'hast'\n * @import {Nodes as MdastNodes} from 'mdast'\n * @import {Options} from './state.js'\n */\n\nimport {ok as assert} from 'devlop'\nimport {footer} from './footer.js'\nimport {createState} from './state.js'\n\n/**\n * Transform mdast to hast.\n *\n * ##### Notes\n *\n * ###### HTML\n *\n * Raw HTML is available in mdast as `html` nodes and can be embedded in hast\n * as semistandard `raw` nodes.\n * Most utilities ignore `raw` nodes but two notable ones don’t:\n *\n * * `hast-util-to-html` also has an option `allowDangerousHtml` which will\n * output the raw HTML.\n * This is typically discouraged as noted by the option name but is useful\n * if you completely trust authors\n * * `hast-util-raw` can handle the raw embedded HTML strings by parsing them\n * into standard hast nodes (`element`, `text`, etc).\n * This is a heavy task as it needs a full HTML parser, but it is the only\n * way to support untrusted content\n *\n * ###### Footnotes\n *\n * Many options supported here relate to footnotes.\n * Footnotes are not specified by CommonMark, which we follow by default.\n * They are supported by GitHub, so footnotes can be enabled in markdown with\n * `mdast-util-gfm`.\n *\n * The options `footnoteBackLabel` and `footnoteLabel` define natural language\n * that explains footnotes, which is hidden for sighted users but shown to\n * assistive technology.\n * When your page is not in English, you must define translated values.\n *\n * Back references use ARIA attributes, but the section label itself uses a\n * heading that is hidden with an `sr-only` class.\n * To show it to sighted users, define different attributes in\n * `footnoteLabelProperties`.\n *\n * ###### Clobbering\n *\n * Footnotes introduces a problem, as it links footnote calls to footnote\n * definitions on the page through `id` attributes generated from user content,\n * which results in DOM clobbering.\n *\n * DOM clobbering is this:\n *\n * ```html\n * <p id=x></p>\n * <script>alert(x) // `x` now refers to the DOM `p#x` element</script>\n * ```\n *\n * Elements by their ID are made available by browsers on the `window` object,\n * which is a security risk.\n * Using a prefix solves this problem.\n *\n * More information on how to handle clobbering and the prefix is explained in\n * Example: headings (DOM clobbering) in `rehype-sanitize`.\n *\n * ###### Unknown nodes\n *\n * Unknown nodes are nodes with a type that isn’t in `handlers` or `passThrough`.\n * The default behavior for unknown nodes is:\n *\n * * when the node has a `value` (and doesn’t have `data.hName`,\n * `data.hProperties`, or `data.hChildren`, see later), create a hast `text`\n * node\n * * otherwise, create a `<div>` element (which could be changed with\n * `data.hName`), with its children mapped from mdast to hast as well\n *\n * This behavior can be changed by passing an `unknownHandler`.\n *\n * @param {MdastNodes} tree\n * mdast tree.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {HastNodes}\n * hast tree.\n */\nexport function toHast(tree, options) {\n const state = createState(tree, options)\n const node = state.one(tree, undefined)\n const foot = footer(state)\n /** @type {HastNodes} */\n const result = Array.isArray(node)\n ? {type: 'root', children: node}\n : node || {type: 'root', children: []}\n\n if (foot) {\n // If there’s a footer, there were definitions, meaning block\n // content.\n // So `result` is a parent node.\n assert('children' in result)\n result.children.push({type: 'text', value: '\\n'}, foot)\n }\n\n return result\n}\n","/**\n * @import {Root as HastRoot} from 'hast'\n * @import {Root as MdastRoot} from 'mdast'\n * @import {Options as ToHastOptions} from 'mdast-util-to-hast'\n * @import {Processor} from 'unified'\n * @import {VFile} from 'vfile'\n */\n\n/**\n * @typedef {Omit<ToHastOptions, 'file'>} Options\n *\n * @callback TransformBridge\n * Bridge-mode.\n *\n * Runs the destination with the new hast tree.\n * Discards result.\n * @param {MdastRoot} tree\n * Tree.\n * @param {VFile} file\n * File.\n * @returns {Promise<undefined>}\n * Nothing.\n *\n * @callback TransformMutate\n * Mutate-mode.\n *\n * Further transformers run on the hast tree.\n * @param {MdastRoot} tree\n * Tree.\n * @param {VFile} file\n * File.\n * @returns {HastRoot}\n * Tree (hast).\n */\n\nimport {toHast} from 'mdast-util-to-hast'\n\n/**\n * Turn markdown into HTML.\n *\n * ##### Notes\n *\n * ###### Signature\n *\n * * if a processor is given,\n * runs the (rehype) plugins used on it with a hast tree,\n * then discards the result (*bridge mode*)\n * * otherwise,\n * returns a hast tree,\n * the plugins used after `remarkRehype` are rehype plugins (*mutate mode*)\n *\n * > 👉 **Note**:\n * > It’s highly unlikely that you want to pass a `processor`.\n *\n * ###### HTML\n *\n * Raw HTML is available in mdast as `html` nodes and can be embedded in hast\n * as semistandard `raw` nodes.\n * Most plugins ignore `raw` nodes but two notable ones don’t:\n *\n * * `rehype-stringify` also has an option `allowDangerousHtml` which will\n * output the raw HTML.\n * This is typically discouraged as noted by the option name but is useful if\n * you completely trust authors\n * * `rehype-raw` can handle the raw embedded HTML strings by parsing them\n * into standard hast nodes (`element`, `text`, etc);\n * this is a heavy task as it needs a full HTML parser,\n * but it is the only way to support untrusted content\n *\n * ###### Footnotes\n *\n * Many options supported here relate to footnotes.\n * Footnotes are not specified by CommonMark,\n * which we follow by default.\n * They are supported by GitHub,\n * so footnotes can be enabled in markdown with `remark-gfm`.\n *\n * The options `footnoteBackLabel` and `footnoteLabel` define natural language\n * that explains footnotes,\n * which is hidden for sighted users but shown to assistive technology.\n * When your page is not in English,\n * you must define translated values.\n *\n * Back references use ARIA attributes,\n * but the section label itself uses a heading that is hidden with an\n * `sr-only` class.\n * To show it to sighted users,\n * define different attributes in `footnoteLabelProperties`.\n *\n * ###### Clobbering\n *\n * Footnotes introduces a problem,\n * as it links footnote calls to footnote definitions on the page through `id`\n * attributes generated from user content,\n * which results in DOM clobbering.\n *\n * DOM clobbering is this:\n *\n * ```html\n * <p id=x></p>\n * <script>alert(x) // `x` now refers to the DOM `p#x` element</script>\n * ```\n *\n * Elements by their ID are made available by browsers on the `window` object,\n * which is a security risk.\n * Using a prefix solves this problem.\n *\n * More information on how to handle clobbering and the prefix is explained in\n * *Example: headings (DOM clobbering)* in `rehype-sanitize`.\n *\n * ###### Unknown nodes\n *\n * Unknown nodes are nodes with a type that isn’t in `handlers` or `passThrough`.\n * The default behavior for unknown nodes is:\n *\n * * when the node has a `value`\n * (and doesn’t have `data.hName`, `data.hProperties`, or `data.hChildren`,\n * see later),\n * create a hast `text` node\n * * otherwise,\n * create a `<div>` element (which could be changed with `data.hName`),\n * with its children mapped from mdast to hast as well\n *\n * This behavior can be changed by passing an `unknownHandler`.\n *\n * @overload\n * @param {Processor} processor\n * @param {Readonly<Options> | null | undefined} [options]\n * @returns {TransformBridge}\n *\n * @overload\n * @param {Readonly<Options> | null | undefined} [options]\n * @returns {TransformMutate}\n *\n * @overload\n * @param {Readonly<Options> | Processor | null | undefined} [destination]\n * @param {Readonly<Options> | null | undefined} [options]\n * @returns {TransformBridge | TransformMutate}\n *\n * @param {Readonly<Options> | Processor | null | undefined} [destination]\n * Processor or configuration (optional).\n * @param {Readonly<Options> | null | undefined} [options]\n * When a processor was given,\n * configuration (optional).\n * @returns {TransformBridge | TransformMutate}\n * Transform.\n */\nexport default function remarkRehype(destination, options) {\n if (destination && 'run' in destination) {\n /**\n * @type {TransformBridge}\n */\n return async function (tree, file) {\n // Cast because root in -> root out.\n const hastTree = /** @type {HastRoot} */ (\n toHast(tree, {file, ...options})\n )\n await destination.run(hastTree, file)\n }\n }\n\n /**\n * @type {TransformMutate}\n */\n return function (tree, file) {\n // Cast because root in -> root out.\n // To do: in the future, disallow ` || options` fallback.\n // With `unified-engine`, `destination` can be `undefined` but\n // `options` will be the file set.\n // We should not pass that as `options`.\n return /** @type {HastRoot} */ (\n toHast(tree, {file, ...(destination || options)})\n )\n }\n}\n","/**\n * Throw a given error.\n *\n * @param {Error|null|undefined} [error]\n * Maybe error.\n * @returns {asserts error is null|undefined}\n */\nexport function bail(error) {\n if (error) {\n throw error\n }\n}\n","'use strict';\n\nvar hasOwn = Object.prototype.hasOwnProperty;\nvar toStr = Object.prototype.toString;\nvar defineProperty = Object.defineProperty;\nvar gOPD = Object.getOwnPropertyDescriptor;\n\nvar isArray = function isArray(arr) {\n\tif (typeof Array.isArray === 'function') {\n\t\treturn Array.isArray(arr);\n\t}\n\n\treturn toStr.call(arr) === '[object Array]';\n};\n\nvar isPlainObject = function isPlainObject(obj) {\n\tif (!obj || toStr.call(obj) !== '[object Object]') {\n\t\treturn false;\n\t}\n\n\tvar hasOwnConstructor = hasOwn.call(obj, 'constructor');\n\tvar hasIsPrototypeOf = obj.constructor && obj.constructor.prototype && hasOwn.call(obj.constructor.prototype, 'isPrototypeOf');\n\t// Not own constructor property must be Object\n\tif (obj.constructor && !hasOwnConstructor && !hasIsPrototypeOf) {\n\t\treturn false;\n\t}\n\n\t// Own properties are enumerated firstly, so to speed up,\n\t// if last one is own, then all properties are own.\n\tvar key;\n\tfor (key in obj) { /**/ }\n\n\treturn typeof key === 'undefined' || hasOwn.call(obj, key);\n};\n\n// If name is '__proto__', and Object.defineProperty is available, define __proto__ as an own property on target\nvar setProperty = function setProperty(target, options) {\n\tif (defineProperty && options.name === '__proto__') {\n\t\tdefineProperty(target, options.name, {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: true,\n\t\t\tvalue: options.newValue,\n\t\t\twritable: true\n\t\t});\n\t} else {\n\t\ttarget[options.name] = options.newValue;\n\t}\n};\n\n// Return undefined instead of __proto__ if '__proto__' is not an own property\nvar getProperty = function getProperty(obj, name) {\n\tif (name === '__proto__') {\n\t\tif (!hasOwn.call(obj, name)) {\n\t\t\treturn void 0;\n\t\t} else if (gOPD) {\n\t\t\t// In early versions of node, obj['__proto__'] is buggy when obj has\n\t\t\t// __proto__ as an own property. Object.getOwnPropertyDescriptor() works.\n\t\t\treturn gOPD(obj, name).value;\n\t\t}\n\t}\n\n\treturn obj[name];\n};\n\nmodule.exports = function extend() {\n\tvar options, name, src, copy, copyIsArray, clone;\n\tvar target = arguments[0];\n\tvar i = 1;\n\tvar length = arguments.length;\n\tvar deep = false;\n\n\t// Handle a deep copy situation\n\tif (typeof target === 'boolean') {\n\t\tdeep = target;\n\t\ttarget = arguments[1] || {};\n\t\t// skip the boolean and the target\n\t\ti = 2;\n\t}\n\tif (target == null || (typeof target !== 'object' && typeof target !== 'function')) {\n\t\ttarget = {};\n\t}\n\n\tfor (; i < length; ++i) {\n\t\toptions = arguments[i];\n\t\t// Only deal with non-null/undefined values\n\t\tif (options != null) {\n\t\t\t// Extend the base object\n\t\t\tfor (name in options) {\n\t\t\t\tsrc = getProperty(target, name);\n\t\t\t\tcopy = getProperty(options, name);\n\n\t\t\t\t// Prevent never-ending loop\n\t\t\t\tif (target !== copy) {\n\t\t\t\t\t// Recurse if we're merging plain objects or arrays\n\t\t\t\t\tif (deep && copy && (isPlainObject(copy) || (copyIsArray = isArray(copy)))) {\n\t\t\t\t\t\tif (copyIsArray) {\n\t\t\t\t\t\t\tcopyIsArray = false;\n\t\t\t\t\t\t\tclone = src && isArray(src) ? src : [];\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tclone = src && isPlainObject(src) ? src : {};\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Never move original objects, clone them\n\t\t\t\t\t\tsetProperty(target, { name: name, newValue: extend(deep, clone, copy) });\n\n\t\t\t\t\t// Don't bring in undefined values\n\t\t\t\t\t} else if (typeof copy !== 'undefined') {\n\t\t\t\t\t\tsetProperty(target, { name: name, newValue: copy });\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Return the modified object\n\treturn target;\n};\n","export default function isPlainObject(value) {\n\tif (typeof value !== 'object' || value === null) {\n\t\treturn false;\n\t}\n\n\tconst prototype = Object.getPrototypeOf(value);\n\treturn (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in value) && !(Symbol.iterator in value);\n}\n","// To do: remove `void`s\n// To do: remove `null` from output of our APIs, allow it as user APIs.\n\n/**\n * @typedef {(error?: Error | null | undefined, ...output: Array<any>) => void} Callback\n * Callback.\n *\n * @typedef {(...input: Array<any>) => any} Middleware\n * Ware.\n *\n * @typedef Pipeline\n * Pipeline.\n * @property {Run} run\n * Run the pipeline.\n * @property {Use} use\n * Add middleware.\n *\n * @typedef {(...input: Array<any>) => void} Run\n * Call all middleware.\n *\n * Calls `done` on completion with either an error or the output of the\n * last middleware.\n *\n * > 👉 **Note**: as the length of input defines whether async functions get a\n * > `next` function,\n * > it’s recommended to keep `input` at one value normally.\n\n *\n * @typedef {(fn: Middleware) => Pipeline} Use\n * Add middleware.\n */\n\n/**\n * Create new middleware.\n *\n * @returns {Pipeline}\n * Pipeline.\n */\nexport function trough() {\n /** @type {Array<Middleware>} */\n const fns = []\n /** @type {Pipeline} */\n const pipeline = {run, use}\n\n return pipeline\n\n /** @type {Run} */\n function run(...values) {\n let middlewareIndex = -1\n /** @type {Callback} */\n const callback = values.pop()\n\n if (typeof callback !== 'function') {\n throw new TypeError('Expected function as last argument, not ' + callback)\n }\n\n next(null, ...values)\n\n /**\n * Run the next `fn`, or we’re done.\n *\n * @param {Error | null | undefined} error\n * @param {Array<any>} output\n */\n function next(error, ...output) {\n const fn = fns[++middlewareIndex]\n let index = -1\n\n if (error) {\n callback(error)\n return\n }\n\n // Copy non-nullish input into values.\n while (++index < values.length) {\n if (output[index] === null || output[index] === undefined) {\n output[index] = values[index]\n }\n }\n\n // Save the newly created `output` for the next call.\n values = output\n\n // Next or done.\n if (fn) {\n wrap(fn, next)(...output)\n } else {\n callback(null, ...output)\n }\n }\n }\n\n /** @type {Use} */\n function use(middelware) {\n if (typeof middelware !== 'function') {\n throw new TypeError(\n 'Expected `middelware` to be a function, not ' + middelware\n )\n }\n\n fns.push(middelware)\n return pipeline\n }\n}\n\n/**\n * Wrap `middleware` into a uniform interface.\n *\n * You can pass all input to the resulting function.\n * `callback` is then called with the output of `middleware`.\n *\n * If `middleware` accepts more arguments than the later given in input,\n * an extra `done` function is passed to it after that input,\n * which must be called by `middleware`.\n *\n * The first value in `input` is the main input value.\n * All other input values are the rest input values.\n * The values given to `callback` are the input values,\n * merged with every non-nullish output value.\n *\n * * if `middleware` throws an error,\n * returns a promise that is rejected,\n * or calls the given `done` function with an error,\n * `callback` is called with that error\n * * if `middleware` returns a value or returns a promise that is resolved,\n * that value is the main output value\n * * if `middleware` calls `done`,\n * all non-nullish values except for the first one (the error) overwrite the\n * output values\n *\n * @param {Middleware} middleware\n * Function to wrap.\n * @param {Callback} callback\n * Callback called with the output of `middleware`.\n * @returns {Run}\n * Wrapped middleware.\n */\nexport function wrap(middleware, callback) {\n /** @type {boolean} */\n let called\n\n return wrapped\n\n /**\n * Call `middleware`.\n * @this {any}\n * @param {Array<any>} parameters\n * @returns {void}\n */\n function wrapped(...parameters) {\n const fnExpectsCallback = middleware.length > parameters.length\n /** @type {any} */\n let result\n\n if (fnExpectsCallback) {\n parameters.push(done)\n }\n\n try {\n result = middleware.apply(this, parameters)\n } catch (error) {\n const exception = /** @type {Error} */ (error)\n\n // Well, this is quite the pickle.\n // `middleware` received a callback and called it synchronously, but that\n // threw an error.\n // The only thing left to do is to throw the thing instead.\n if (fnExpectsCallback && called) {\n throw exception\n }\n\n return done(exception)\n }\n\n if (!fnExpectsCallback) {\n if (result && result.then && typeof result.then === 'function') {\n result.then(then, done)\n } else if (result instanceof Error) {\n done(result)\n } else {\n then(result)\n }\n }\n }\n\n /**\n * Call `callback`, only once.\n *\n * @type {Callback}\n */\n function done(error, ...output) {\n if (!called) {\n called = true\n callback(error, ...output)\n }\n }\n\n /**\n * Call `done` with one value.\n *\n * @param {any} [value]\n */\n function then(value) {\n done(null, value)\n }\n}\n","// A derivative work based on:\n// <https://github.com/browserify/path-browserify>.\n// Which is licensed:\n//\n// MIT License\n//\n// Copyright (c) 2013 James Halliday\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of\n// this software and associated documentation files (the \"Software\"), to deal in\n// the Software without restriction, including without limitation the rights to\n// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of\n// the Software, and to permit persons to whom the Software is furnished to do so,\n// subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\n// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\n// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\n// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\n// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n// A derivative work based on:\n//\n// Parts of that are extracted from Node’s internal `path` module:\n// <https://github.com/nodejs/node/blob/master/lib/path.js>.\n// Which is licensed:\n//\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nexport const minpath = {basename, dirname, extname, join, sep: '/'}\n\n/* eslint-disable max-depth, complexity */\n\n/**\n * Get the basename from a path.\n *\n * @param {string} path\n * File path.\n * @param {string | null | undefined} [extname]\n * Extension to strip.\n * @returns {string}\n * Stem or basename.\n */\nfunction basename(path, extname) {\n if (extname !== undefined && typeof extname !== 'string') {\n throw new TypeError('\"ext\" argument must be a string')\n }\n\n assertPath(path)\n let start = 0\n let end = -1\n let index = path.length\n /** @type {boolean | undefined} */\n let seenNonSlash\n\n if (\n extname === undefined ||\n extname.length === 0 ||\n extname.length > path.length\n ) {\n while (index--) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (seenNonSlash) {\n start = index + 1\n break\n }\n } else if (end < 0) {\n // We saw the first non-path separator, mark this as the end of our\n // path component.\n seenNonSlash = true\n end = index + 1\n }\n }\n\n return end < 0 ? '' : path.slice(start, end)\n }\n\n if (extname === path) {\n return ''\n }\n\n let firstNonSlashEnd = -1\n let extnameIndex = extname.length - 1\n\n while (index--) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (seenNonSlash) {\n start = index + 1\n break\n }\n } else {\n if (firstNonSlashEnd < 0) {\n // We saw the first non-path separator, remember this index in case\n // we need it if the extension ends up not matching.\n seenNonSlash = true\n firstNonSlashEnd = index + 1\n }\n\n if (extnameIndex > -1) {\n // Try to match the explicit extension.\n if (path.codePointAt(index) === extname.codePointAt(extnameIndex--)) {\n if (extnameIndex < 0) {\n // We matched the extension, so mark this as the end of our path\n // component\n end = index\n }\n } else {\n // Extension does not match, so our result is the entire path\n // component\n extnameIndex = -1\n end = firstNonSlashEnd\n }\n }\n }\n }\n\n if (start === end) {\n end = firstNonSlashEnd\n } else if (end < 0) {\n end = path.length\n }\n\n return path.slice(start, end)\n}\n\n/**\n * Get the dirname from a path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * File path.\n */\nfunction dirname(path) {\n assertPath(path)\n\n if (path.length === 0) {\n return '.'\n }\n\n let end = -1\n let index = path.length\n /** @type {boolean | undefined} */\n let unmatchedSlash\n\n // Prefix `--` is important to not run on `0`.\n while (--index) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n if (unmatchedSlash) {\n end = index\n break\n }\n } else if (!unmatchedSlash) {\n // We saw the first non-path separator\n unmatchedSlash = true\n }\n }\n\n return end < 0\n ? path.codePointAt(0) === 47 /* `/` */\n ? '/'\n : '.'\n : end === 1 && path.codePointAt(0) === 47 /* `/` */\n ? '//'\n : path.slice(0, end)\n}\n\n/**\n * Get an extname from a path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * Extname.\n */\nfunction extname(path) {\n assertPath(path)\n\n let index = path.length\n\n let end = -1\n let startPart = 0\n let startDot = -1\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find.\n let preDotState = 0\n /** @type {boolean | undefined} */\n let unmatchedSlash\n\n while (index--) {\n const code = path.codePointAt(index)\n\n if (code === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (unmatchedSlash) {\n startPart = index + 1\n break\n }\n\n continue\n }\n\n if (end < 0) {\n // We saw the first non-path separator, mark this as the end of our\n // extension.\n unmatchedSlash = true\n end = index + 1\n }\n\n if (code === 46 /* `.` */) {\n // If this is our first dot, mark it as the start of our extension.\n if (startDot < 0) {\n startDot = index\n } else if (preDotState !== 1) {\n preDotState = 1\n }\n } else if (startDot > -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension.\n preDotState = -1\n }\n }\n\n if (\n startDot < 0 ||\n end < 0 ||\n // We saw a non-dot character immediately before the dot.\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly `..`.\n (preDotState === 1 && startDot === end - 1 && startDot === startPart + 1)\n ) {\n return ''\n }\n\n return path.slice(startDot, end)\n}\n\n/**\n * Join segments from a path.\n *\n * @param {Array<string>} segments\n * Path segments.\n * @returns {string}\n * File path.\n */\nfunction join(...segments) {\n let index = -1\n /** @type {string | undefined} */\n let joined\n\n while (++index < segments.length) {\n assertPath(segments[index])\n\n if (segments[index]) {\n joined =\n joined === undefined ? segments[index] : joined + '/' + segments[index]\n }\n }\n\n return joined === undefined ? '.' : normalize(joined)\n}\n\n/**\n * Normalize a basic file path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * File path.\n */\n// Note: `normalize` is not exposed as `path.normalize`, so some code is\n// manually removed from it.\nfunction normalize(path) {\n assertPath(path)\n\n const absolute = path.codePointAt(0) === 47 /* `/` */\n\n // Normalize the path according to POSIX rules.\n let value = normalizeString(path, !absolute)\n\n if (value.length === 0 && !absolute) {\n value = '.'\n }\n\n if (value.length > 0 && path.codePointAt(path.length - 1) === 47 /* / */) {\n value += '/'\n }\n\n return absolute ? '/' + value : value\n}\n\n/**\n * Resolve `.` and `..` elements in a path with directory names.\n *\n * @param {string} path\n * File path.\n * @param {boolean} allowAboveRoot\n * Whether `..` can move above root.\n * @returns {string}\n * File path.\n */\nfunction normalizeString(path, allowAboveRoot) {\n let result = ''\n let lastSegmentLength = 0\n let lastSlash = -1\n let dots = 0\n let index = -1\n /** @type {number | undefined} */\n let code\n /** @type {number} */\n let lastSlashIndex\n\n while (++index <= path.length) {\n if (index < path.length) {\n code = path.codePointAt(index)\n } else if (code === 47 /* `/` */) {\n break\n } else {\n code = 47 /* `/` */\n }\n\n if (code === 47 /* `/` */) {\n if (lastSlash === index - 1 || dots === 1) {\n // Empty.\n } else if (lastSlash !== index - 1 && dots === 2) {\n if (\n result.length < 2 ||\n lastSegmentLength !== 2 ||\n result.codePointAt(result.length - 1) !== 46 /* `.` */ ||\n result.codePointAt(result.length - 2) !== 46 /* `.` */\n ) {\n if (result.length > 2) {\n lastSlashIndex = result.lastIndexOf('/')\n\n if (lastSlashIndex !== result.length - 1) {\n if (lastSlashIndex < 0) {\n result = ''\n lastSegmentLength = 0\n } else {\n result = result.slice(0, lastSlashIndex)\n lastSegmentLength = result.length - 1 - result.lastIndexOf('/')\n }\n\n lastSlash = index\n dots = 0\n continue\n }\n } else if (result.length > 0) {\n result = ''\n lastSegmentLength = 0\n lastSlash = index\n dots = 0\n continue\n }\n }\n\n if (allowAboveRoot) {\n result = result.length > 0 ? result + '/..' : '..'\n lastSegmentLength = 2\n }\n } else {\n if (result.length > 0) {\n result += '/' + path.slice(lastSlash + 1, index)\n } else {\n result = path.slice(lastSlash + 1, index)\n }\n\n lastSegmentLength = index - lastSlash - 1\n }\n\n lastSlash = index\n dots = 0\n } else if (code === 46 /* `.` */ && dots > -1) {\n dots++\n } else {\n dots = -1\n }\n }\n\n return result\n}\n\n/**\n * Make sure `path` is a string.\n *\n * @param {string} path\n * File path.\n * @returns {asserts path is string}\n * Nothing.\n */\nfunction assertPath(path) {\n if (typeof path !== 'string') {\n throw new TypeError(\n 'Path must be a string. Received ' + JSON.stringify(path)\n )\n }\n}\n\n/* eslint-enable max-depth, complexity */\n","// Somewhat based on:\n// <https://github.com/defunctzombie/node-process/blob/master/browser.js>.\n// But I don’t think one tiny line of code can be copyrighted. 😅\nexport const minproc = {cwd}\n\nfunction cwd() {\n return '/'\n}\n","/**\n * Checks if a value has the shape of a WHATWG URL object.\n *\n * Using a symbol or instanceof would not be able to recognize URL objects\n * coming from other implementations (e.g. in Electron), so instead we are\n * checking some well known properties for a lack of a better test.\n *\n * We use `href` and `protocol` as they are the only properties that are\n * easy to retrieve and calculate due to the lazy nature of the getters.\n *\n * We check for auth attribute to distinguish legacy url instance with\n * WHATWG URL instance.\n *\n * @param {unknown} fileUrlOrPath\n * File path or URL.\n * @returns {fileUrlOrPath is URL}\n * Whether it’s a URL.\n */\n// From: <https://github.com/nodejs/node/blob/6a3403c/lib/internal/url.js#L720>\nexport function isUrl(fileUrlOrPath) {\n return Boolean(\n fileUrlOrPath !== null &&\n typeof fileUrlOrPath === 'object' &&\n 'href' in fileUrlOrPath &&\n fileUrlOrPath.href &&\n 'protocol' in fileUrlOrPath &&\n fileUrlOrPath.protocol &&\n // @ts-expect-error: indexing is fine.\n fileUrlOrPath.auth === undefined\n )\n}\n","import {isUrl} from './minurl.shared.js'\n\nexport {isUrl} from './minurl.shared.js'\n\n// See: <https://github.com/nodejs/node/blob/6a3403c/lib/internal/url.js>\n\n/**\n * @param {URL | string} path\n * File URL.\n * @returns {string}\n * File URL.\n */\nexport function urlToPath(path) {\n if (typeof path === 'string') {\n path = new URL(path)\n } else if (!isUrl(path)) {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'The \"path\" argument must be of type string or an instance of URL. Received `' +\n path +\n '`'\n )\n error.code = 'ERR_INVALID_ARG_TYPE'\n throw error\n }\n\n if (path.protocol !== 'file:') {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError('The URL must be of scheme file')\n error.code = 'ERR_INVALID_URL_SCHEME'\n throw error\n }\n\n return getPathFromURLPosix(path)\n}\n\n/**\n * Get a path from a POSIX URL.\n *\n * @param {URL} url\n * URL.\n * @returns {string}\n * File path.\n */\nfunction getPathFromURLPosix(url) {\n if (url.hostname !== '') {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'File URL host must be \"localhost\" or empty on darwin'\n )\n error.code = 'ERR_INVALID_FILE_URL_HOST'\n throw error\n }\n\n const pathname = url.pathname\n let index = -1\n\n while (++index < pathname.length) {\n if (\n pathname.codePointAt(index) === 37 /* `%` */ &&\n pathname.codePointAt(index + 1) === 50 /* `2` */\n ) {\n const third = pathname.codePointAt(index + 2)\n if (third === 70 /* `F` */ || third === 102 /* `f` */) {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'File URL path must not include encoded / characters'\n )\n error.code = 'ERR_INVALID_FILE_URL_PATH'\n throw error\n }\n }\n }\n\n return decodeURIComponent(pathname)\n}\n","/**\n * @import {Node, Point, Position} from 'unist'\n * @import {Options as MessageOptions} from 'vfile-message'\n * @import {Compatible, Data, Map, Options, Value} from 'vfile'\n */\n\n/**\n * @typedef {object & {type: string, position?: Position | undefined}} NodeLike\n */\n\nimport {VFileMessage} from 'vfile-message'\nimport {minpath} from '#minpath'\nimport {minproc} from '#minproc'\nimport {urlToPath, isUrl} from '#minurl'\n\n/**\n * Order of setting (least specific to most), we need this because otherwise\n * `{stem: 'a', path: '~/b.js'}` would throw, as a path is needed before a\n * stem can be set.\n */\nconst order = /** @type {const} */ ([\n 'history',\n 'path',\n 'basename',\n 'stem',\n 'extname',\n 'dirname'\n])\n\nexport class VFile {\n /**\n * Create a new virtual file.\n *\n * `options` is treated as:\n *\n * * `string` or `Uint8Array` — `{value: options}`\n * * `URL` — `{path: options}`\n * * `VFile` — shallow copies its data over to the new file\n * * `object` — all fields are shallow copied over to the new file\n *\n * Path related fields are set in the following order (least specific to\n * most specific): `history`, `path`, `basename`, `stem`, `extname`,\n * `dirname`.\n *\n * You cannot set `dirname` or `extname` without setting either `history`,\n * `path`, `basename`, or `stem` too.\n *\n * @param {Compatible | null | undefined} [value]\n * File value.\n * @returns\n * New instance.\n */\n constructor(value) {\n /** @type {Options | VFile} */\n let options\n\n if (!value) {\n options = {}\n } else if (isUrl(value)) {\n options = {path: value}\n } else if (typeof value === 'string' || isUint8Array(value)) {\n options = {value}\n } else {\n options = value\n }\n\n /* eslint-disable no-unused-expressions */\n\n /**\n * Base of `path` (default: `process.cwd()` or `'/'` in browsers).\n *\n * @type {string}\n */\n // Prevent calling `cwd` (which could be expensive) if it’s not needed;\n // the empty string will be overridden in the next block.\n this.cwd = 'cwd' in options ? '' : minproc.cwd()\n\n /**\n * Place to store custom info (default: `{}`).\n *\n * It’s OK to store custom data directly on the file but moving it to\n * `data` is recommended.\n *\n * @type {Data}\n */\n this.data = {}\n\n /**\n * List of file paths the file moved between.\n *\n * The first is the original path and the last is the current path.\n *\n * @type {Array<string>}\n */\n this.history = []\n\n /**\n * List of messages associated with the file.\n *\n * @type {Array<VFileMessage>}\n */\n this.messages = []\n\n /**\n * Raw value.\n *\n * @type {Value}\n */\n this.value\n\n // The below are non-standard, they are “well-known”.\n // As in, used in several tools.\n /**\n * Source map.\n *\n * This type is equivalent to the `RawSourceMap` type from the `source-map`\n * module.\n *\n * @type {Map | null | undefined}\n */\n this.map\n\n /**\n * Custom, non-string, compiled, representation.\n *\n * This is used by unified to store non-string results.\n * One example is when turning markdown into React nodes.\n *\n * @type {unknown}\n */\n this.result\n\n /**\n * Whether a file was saved to disk.\n *\n * This is used by vfile reporters.\n *\n * @type {boolean}\n */\n this.stored\n /* eslint-enable no-unused-expressions */\n\n // Set path related properties in the correct order.\n let index = -1\n\n while (++index < order.length) {\n const field = order[index]\n\n // Note: we specifically use `in` instead of `hasOwnProperty` to accept\n // `vfile`s too.\n if (\n field in options &&\n options[field] !== undefined &&\n options[field] !== null\n ) {\n // @ts-expect-error: TS doesn’t understand basic reality.\n this[field] = field === 'history' ? [...options[field]] : options[field]\n }\n }\n\n /** @type {string} */\n let field\n\n // Set non-path related properties.\n for (field in options) {\n // @ts-expect-error: fine to set other things.\n if (!order.includes(field)) {\n // @ts-expect-error: fine to set other things.\n this[field] = options[field]\n }\n }\n }\n\n /**\n * Get the basename (including extname) (example: `'index.min.js'`).\n *\n * @returns {string | undefined}\n * Basename.\n */\n get basename() {\n return typeof this.path === 'string'\n ? minpath.basename(this.path)\n : undefined\n }\n\n /**\n * Set basename (including extname) (`'index.min.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n *\n * @param {string} basename\n * Basename.\n * @returns {undefined}\n * Nothing.\n */\n set basename(basename) {\n assertNonEmpty(basename, 'basename')\n assertPart(basename, 'basename')\n this.path = minpath.join(this.dirname || '', basename)\n }\n\n /**\n * Get the parent path (example: `'~'`).\n *\n * @returns {string | undefined}\n * Dirname.\n */\n get dirname() {\n return typeof this.path === 'string'\n ? minpath.dirname(this.path)\n : undefined\n }\n\n /**\n * Set the parent path (example: `'~'`).\n *\n * Cannot be set if there’s no `path` yet.\n *\n * @param {string | undefined} dirname\n * Dirname.\n * @returns {undefined}\n * Nothing.\n */\n set dirname(dirname) {\n assertPath(this.basename, 'dirname')\n this.path = minpath.join(dirname || '', this.basename)\n }\n\n /**\n * Get the extname (including dot) (example: `'.js'`).\n *\n * @returns {string | undefined}\n * Extname.\n */\n get extname() {\n return typeof this.path === 'string'\n ? minpath.extname(this.path)\n : undefined\n }\n\n /**\n * Set the extname (including dot) (example: `'.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be set if there’s no `path` yet.\n *\n * @param {string | undefined} extname\n * Extname.\n * @returns {undefined}\n * Nothing.\n */\n set extname(extname) {\n assertPart(extname, 'extname')\n assertPath(this.dirname, 'extname')\n\n if (extname) {\n if (extname.codePointAt(0) !== 46 /* `.` */) {\n throw new Error('`extname` must start with `.`')\n }\n\n if (extname.includes('.', 1)) {\n throw new Error('`extname` cannot contain multiple dots')\n }\n }\n\n this.path = minpath.join(this.dirname, this.stem + (extname || ''))\n }\n\n /**\n * Get the full path (example: `'~/index.min.js'`).\n *\n * @returns {string}\n * Path.\n */\n get path() {\n return this.history[this.history.length - 1]\n }\n\n /**\n * Set the full path (example: `'~/index.min.js'`).\n *\n * Cannot be nullified.\n * You can set a file URL (a `URL` object with a `file:` protocol) which will\n * be turned into a path with `url.fileURLToPath`.\n *\n * @param {URL | string} path\n * Path.\n * @returns {undefined}\n * Nothing.\n */\n set path(path) {\n if (isUrl(path)) {\n path = urlToPath(path)\n }\n\n assertNonEmpty(path, 'path')\n\n if (this.path !== path) {\n this.history.push(path)\n }\n }\n\n /**\n * Get the stem (basename w/o extname) (example: `'index.min'`).\n *\n * @returns {string | undefined}\n * Stem.\n */\n get stem() {\n return typeof this.path === 'string'\n ? minpath.basename(this.path, this.extname)\n : undefined\n }\n\n /**\n * Set the stem (basename w/o extname) (example: `'index.min'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n *\n * @param {string} stem\n * Stem.\n * @returns {undefined}\n * Nothing.\n */\n set stem(stem) {\n assertNonEmpty(stem, 'stem')\n assertPart(stem, 'stem')\n this.path = minpath.join(this.dirname || '', stem + (this.extname || ''))\n }\n\n // Normal prototypal methods.\n /**\n * Create a fatal message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `true` (error; file not usable)\n * and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {never}\n * Never.\n * @throws {VFileMessage}\n * Message.\n */\n fail(causeOrReason, optionsOrParentOrPlace, origin) {\n // @ts-expect-error: the overloads are fine.\n const message = this.message(causeOrReason, optionsOrParentOrPlace, origin)\n\n message.fatal = true\n\n throw message\n }\n\n /**\n * Create an info message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `undefined` (info; change\n * likely not needed) and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */\n info(causeOrReason, optionsOrParentOrPlace, origin) {\n // @ts-expect-error: the overloads are fine.\n const message = this.message(causeOrReason, optionsOrParentOrPlace, origin)\n\n message.fatal = undefined\n\n return message\n }\n\n /**\n * Create a message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `false` (warning; change may be\n * needed) and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */\n message(causeOrReason, optionsOrParentOrPlace, origin) {\n const message = new VFileMessage(\n // @ts-expect-error: the overloads are fine.\n causeOrReason,\n optionsOrParentOrPlace,\n origin\n )\n\n if (this.path) {\n message.name = this.path + ':' + message.name\n message.file = this.path\n }\n\n message.fatal = false\n\n this.messages.push(message)\n\n return message\n }\n\n /**\n * Serialize the file.\n *\n * > **Note**: which encodings are supported depends on the engine.\n * > For info on Node.js, see:\n * > <https://nodejs.org/api/util.html#whatwg-supported-encodings>.\n *\n * @param {string | null | undefined} [encoding='utf8']\n * Character encoding to understand `value` as when it’s a `Uint8Array`\n * (default: `'utf-8'`).\n * @returns {string}\n * Serialized file.\n */\n toString(encoding) {\n if (this.value === undefined) {\n return ''\n }\n\n if (typeof this.value === 'string') {\n return this.value\n }\n\n const decoder = new TextDecoder(encoding || undefined)\n return decoder.decode(this.value)\n }\n}\n\n/**\n * Assert that `part` is not a path (as in, does not contain `path.sep`).\n *\n * @param {string | null | undefined} part\n * File path part.\n * @param {string} name\n * Part name.\n * @returns {undefined}\n * Nothing.\n */\nfunction assertPart(part, name) {\n if (part && part.includes(minpath.sep)) {\n throw new Error(\n '`' + name + '` cannot be a path: did not expect `' + minpath.sep + '`'\n )\n }\n}\n\n/**\n * Assert that `part` is not empty.\n *\n * @param {string | undefined} part\n * Thing.\n * @param {string} name\n * Part name.\n * @returns {asserts part is string}\n * Nothing.\n */\nfunction assertNonEmpty(part, name) {\n if (!part) {\n throw new Error('`' + name + '` cannot be empty')\n }\n}\n\n/**\n * Assert `path` exists.\n *\n * @param {string | undefined} path\n * Path.\n * @param {string} name\n * Dependency name.\n * @returns {asserts path is string}\n * Nothing.\n */\nfunction assertPath(path, name) {\n if (!path) {\n throw new Error('Setting `' + name + '` requires `path` to be set too')\n }\n}\n\n/**\n * Assert `value` is an `Uint8Array`.\n *\n * @param {unknown} value\n * thing.\n * @returns {value is Uint8Array}\n * Whether `value` is an `Uint8Array`.\n */\nfunction isUint8Array(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'byteLength' in value &&\n 'byteOffset' in value\n )\n}\n","export const CallableInstance =\n /**\n * @type {new <Parameters extends Array<unknown>, Result>(property: string | symbol) => (...parameters: Parameters) => Result}\n */\n (\n /** @type {unknown} */\n (\n /**\n * @this {Function}\n * @param {string | symbol} property\n * @returns {(...parameters: Array<unknown>) => unknown}\n */\n function (property) {\n const self = this\n const constr = self.constructor\n const proto = /** @type {Record<string | symbol, Function>} */ (\n // Prototypes do exist.\n // type-coverage:ignore-next-line\n constr.prototype\n )\n const value = proto[property]\n /** @type {(...parameters: Array<unknown>) => unknown} */\n const apply = function () {\n return value.apply(apply, arguments)\n }\n\n Object.setPrototypeOf(apply, proto)\n\n // Not needed for us in `unified`: we only call this on the `copy`\n // function,\n // and we don't need to add its fields (`length`, `name`)\n // over.\n // See also: GH-246.\n // const names = Object.getOwnPropertyNames(value)\n //\n // for (const p of names) {\n // const descriptor = Object.getOwnPropertyDescriptor(value, p)\n // if (descriptor) Object.defineProperty(apply, p, descriptor)\n // }\n\n return apply\n }\n )\n )\n","/**\n * @typedef {import('trough').Pipeline} Pipeline\n *\n * @typedef {import('unist').Node} Node\n *\n * @typedef {import('vfile').Compatible} Compatible\n * @typedef {import('vfile').Value} Value\n *\n * @typedef {import('../index.js').CompileResultMap} CompileResultMap\n * @typedef {import('../index.js').Data} Data\n * @typedef {import('../index.js').Settings} Settings\n */\n\n/**\n * @typedef {CompileResultMap[keyof CompileResultMap]} CompileResults\n * Acceptable results from compilers.\n *\n * To register custom results, add them to\n * {@linkcode CompileResultMap}.\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The node that the compiler receives (default: `Node`).\n * @template {CompileResults} [Result=CompileResults]\n * The thing that the compiler yields (default: `CompileResults`).\n * @callback Compiler\n * A **compiler** handles the compiling of a syntax tree to something else\n * (in most cases, text) (TypeScript type).\n *\n * It is used in the stringify phase and called with a {@linkcode Node}\n * and {@linkcode VFile} representation of the document to compile.\n * It should return the textual representation of the given tree (typically\n * `string`).\n *\n * > **Note**: unified typically compiles by serializing: most compilers\n * > return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n * @param {Tree} tree\n * Tree to compile.\n * @param {VFile} file\n * File associated with `tree`.\n * @returns {Result}\n * New content: compiled text (`string` or `Uint8Array`, for `file.value`) or\n * something else (for `file.result`).\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The node that the parser yields (default: `Node`)\n * @callback Parser\n * A **parser** handles the parsing of text to a syntax tree.\n *\n * It is used in the parse phase and is called with a `string` and\n * {@linkcode VFile} of the document to parse.\n * It must return the syntax tree representation of the given file\n * ({@linkcode Node}).\n * @param {string} document\n * Document to parse.\n * @param {VFile} file\n * File associated with `document`.\n * @returns {Tree}\n * Node representing the given file.\n */\n\n/**\n * @typedef {(\n * Plugin<Array<any>, any, any> |\n * PluginTuple<Array<any>, any, any> |\n * Preset\n * )} Pluggable\n * Union of the different ways to add plugins and settings.\n */\n\n/**\n * @typedef {Array<Pluggable>} PluggableList\n * List of plugins and presets.\n */\n\n// Note: we can’t use `callback` yet as it messes up `this`:\n// <https://github.com/microsoft/TypeScript/issues/55197>.\n/**\n * @template {Array<unknown>} [PluginParameters=[]]\n * Arguments passed to the plugin (default: `[]`, the empty tuple).\n * @template {Node | string | undefined} [Input=Node]\n * Value that is expected as input (default: `Node`).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node it expects.\n * * If the plugin sets a {@linkcode Parser}, this should be\n * `string`.\n * * If the plugin sets a {@linkcode Compiler}, this should be the\n * node it expects.\n * @template [Output=Input]\n * Value that is yielded as output (default: `Input`).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node that that yields.\n * * If the plugin sets a {@linkcode Parser}, this should be the\n * node that it yields.\n * * If the plugin sets a {@linkcode Compiler}, this should be\n * result it yields.\n * @typedef {(\n * (this: Processor, ...parameters: PluginParameters) =>\n * Input extends string ? // Parser.\n * Output extends Node | undefined ? undefined | void : never :\n * Output extends CompileResults ? // Compiler.\n * Input extends Node | undefined ? undefined | void : never :\n * Transformer<\n * Input extends Node ? Input : Node,\n * Output extends Node ? Output : Node\n * > | undefined | void\n * )} Plugin\n * Single plugin.\n *\n * Plugins configure the processors they are applied on in the following\n * ways:\n *\n * * they change the processor, such as the parser, the compiler, or by\n * configuring data\n * * they specify how to handle trees and files\n *\n * In practice, they are functions that can receive options and configure the\n * processor (`this`).\n *\n * > **Note**: plugins are called when the processor is *frozen*, not when\n * > they are applied.\n */\n\n/**\n * Tuple of a plugin and its configuration.\n *\n * The first item is a plugin, the rest are its parameters.\n *\n * @template {Array<unknown>} [TupleParameters=[]]\n * Arguments passed to the plugin (default: `[]`, the empty tuple).\n * @template {Node | string | undefined} [Input=undefined]\n * Value that is expected as input (optional).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node it expects.\n * * If the plugin sets a {@linkcode Parser}, this should be\n * `string`.\n * * If the plugin sets a {@linkcode Compiler}, this should be the\n * node it expects.\n * @template [Output=undefined] (optional).\n * Value that is yielded as output.\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node that that yields.\n * * If the plugin sets a {@linkcode Parser}, this should be the\n * node that it yields.\n * * If the plugin sets a {@linkcode Compiler}, this should be\n * result it yields.\n * @typedef {(\n * [\n * plugin: Plugin<TupleParameters, Input, Output>,\n * ...parameters: TupleParameters\n * ]\n * )} PluginTuple\n */\n\n/**\n * @typedef Preset\n * Sharable configuration.\n *\n * They can contain plugins and settings.\n * @property {PluggableList | undefined} [plugins]\n * List of plugins and presets (optional).\n * @property {Settings | undefined} [settings]\n * Shared settings for parsers and compilers (optional).\n */\n\n/**\n * @template {VFile} [File=VFile]\n * The file that the callback receives (default: `VFile`).\n * @callback ProcessCallback\n * Callback called when the process is done.\n *\n * Called with either an error or a result.\n * @param {Error | undefined} [error]\n * Fatal error (optional).\n * @param {File | undefined} [file]\n * Processed file (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The tree that the callback receives (default: `Node`).\n * @callback RunCallback\n * Callback called when transformers are done.\n *\n * Called with either an error or results.\n * @param {Error | undefined} [error]\n * Fatal error (optional).\n * @param {Tree | undefined} [tree]\n * Transformed tree (optional).\n * @param {VFile | undefined} [file]\n * File (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Output=Node]\n * Node type that the transformer yields (default: `Node`).\n * @callback TransformCallback\n * Callback passed to transforms.\n *\n * If the signature of a `transformer` accepts a third argument, the\n * transformer may perform asynchronous operations, and must call it.\n * @param {Error | undefined} [error]\n * Fatal error to stop the process (optional).\n * @param {Output | undefined} [tree]\n * New, changed, tree (optional).\n * @param {VFile | undefined} [file]\n * New, changed, file (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Input=Node]\n * Node type that the transformer expects (default: `Node`).\n * @template {Node} [Output=Input]\n * Node type that the transformer yields (default: `Input`).\n * @callback Transformer\n * Transformers handle syntax trees and files.\n *\n * They are functions that are called each time a syntax tree and file are\n * passed through the run phase.\n * When an error occurs in them (either because it’s thrown, returned,\n * rejected, or passed to `next`), the process stops.\n *\n * The run phase is handled by [`trough`][trough], see its documentation for\n * the exact semantics of these functions.\n *\n * > **Note**: you should likely ignore `next`: don’t accept it.\n * > it supports callback-style async work.\n * > But promises are likely easier to reason about.\n *\n * [trough]: https://github.com/wooorm/trough#function-fninput-next\n * @param {Input} tree\n * Tree to handle.\n * @param {VFile} file\n * File to handle.\n * @param {TransformCallback<Output>} next\n * Callback.\n * @returns {(\n * Promise<Output | undefined | void> |\n * Promise<never> | // For some reason this is needed separately.\n * Output |\n * Error |\n * undefined |\n * void\n * )}\n * If you accept `next`, nothing.\n * Otherwise:\n *\n * * `Error` — fatal error to stop the process\n * * `Promise<undefined>` or `undefined` — the next transformer keeps using\n * same tree\n * * `Promise<Node>` or `Node` — new, changed, tree\n */\n\n/**\n * @template {Node | undefined} ParseTree\n * Output of `parse`.\n * @template {Node | undefined} HeadTree\n * Input for `run`.\n * @template {Node | undefined} TailTree\n * Output for `run`.\n * @template {Node | undefined} CompileTree\n * Input of `stringify`.\n * @template {CompileResults | undefined} CompileResult\n * Output of `stringify`.\n * @template {Node | string | undefined} Input\n * Input of plugin.\n * @template Output\n * Output of plugin (optional).\n * @typedef {(\n * Input extends string\n * ? Output extends Node | undefined\n * ? // Parser.\n * Processor<\n * Output extends undefined ? ParseTree : Output,\n * HeadTree,\n * TailTree,\n * CompileTree,\n * CompileResult\n * >\n * : // Unknown.\n * Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>\n * : Output extends CompileResults\n * ? Input extends Node | undefined\n * ? // Compiler.\n * Processor<\n * ParseTree,\n * HeadTree,\n * TailTree,\n * Input extends undefined ? CompileTree : Input,\n * Output extends undefined ? CompileResult : Output\n * >\n * : // Unknown.\n * Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>\n * : Input extends Node | undefined\n * ? Output extends Node | undefined\n * ? // Transform.\n * Processor<\n * ParseTree,\n * HeadTree extends undefined ? Input : HeadTree,\n * Output extends undefined ? TailTree : Output,\n * CompileTree,\n * CompileResult\n * >\n * : // Unknown.\n * Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>\n * : // Unknown.\n * Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>\n * )} UsePlugin\n * Create a processor based on the input/output of a {@link Plugin plugin}.\n */\n\n/**\n * @template {CompileResults | undefined} Result\n * Node type that the transformer yields.\n * @typedef {(\n * Result extends Value | undefined ?\n * VFile :\n * VFile & {result: Result}\n * )} VFileWithOutput\n * Type to generate a {@linkcode VFile} corresponding to a compiler result.\n *\n * If a result that is not acceptable on a `VFile` is used, that will\n * be stored on the `result` field of {@linkcode VFile}.\n */\n\nimport {bail} from 'bail'\nimport extend from 'extend'\nimport {ok as assert} from 'devlop'\nimport isPlainObj from 'is-plain-obj'\nimport {trough} from 'trough'\nimport {VFile} from 'vfile'\nimport {CallableInstance} from './callable-instance.js'\n\n// To do: next major: drop `Compiler`, `Parser`: prefer lowercase.\n\n// To do: we could start yielding `never` in TS when a parser is missing and\n// `parse` is called.\n// Currently, we allow directly setting `processor.parser`, which is untyped.\n\nconst own = {}.hasOwnProperty\n\n/**\n * @template {Node | undefined} [ParseTree=undefined]\n * Output of `parse` (optional).\n * @template {Node | undefined} [HeadTree=undefined]\n * Input for `run` (optional).\n * @template {Node | undefined} [TailTree=undefined]\n * Output for `run` (optional).\n * @template {Node | undefined} [CompileTree=undefined]\n * Input of `stringify` (optional).\n * @template {CompileResults | undefined} [CompileResult=undefined]\n * Output of `stringify` (optional).\n * @extends {CallableInstance<[], Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>>}\n */\nexport class Processor extends CallableInstance {\n /**\n * Create a processor.\n */\n constructor() {\n // If `Processor()` is called (w/o new), `copy` is called instead.\n super('copy')\n\n /**\n * Compiler to use (deprecated).\n *\n * @deprecated\n * Use `compiler` instead.\n * @type {(\n * Compiler<\n * CompileTree extends undefined ? Node : CompileTree,\n * CompileResult extends undefined ? CompileResults : CompileResult\n * > |\n * undefined\n * )}\n */\n this.Compiler = undefined\n\n /**\n * Parser to use (deprecated).\n *\n * @deprecated\n * Use `parser` instead.\n * @type {(\n * Parser<ParseTree extends undefined ? Node : ParseTree> |\n * undefined\n * )}\n */\n this.Parser = undefined\n\n // Note: the following fields are considered private.\n // However, they are needed for tests, and TSC generates an untyped\n // `private freezeIndex` field for, which trips `type-coverage` up.\n // Instead, we use `@deprecated` to visualize that they shouldn’t be used.\n /**\n * Internal list of configured plugins.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Array<PluginTuple<Array<unknown>>>}\n */\n this.attachers = []\n\n /**\n * Compiler to use.\n *\n * @type {(\n * Compiler<\n * CompileTree extends undefined ? Node : CompileTree,\n * CompileResult extends undefined ? CompileResults : CompileResult\n * > |\n * undefined\n * )}\n */\n this.compiler = undefined\n\n /**\n * Internal state to track where we are while freezing.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {number}\n */\n this.freezeIndex = -1\n\n /**\n * Internal state to track whether we’re frozen.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {boolean | undefined}\n */\n this.frozen = undefined\n\n /**\n * Internal state.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Data}\n */\n this.namespace = {}\n\n /**\n * Parser to use.\n *\n * @type {(\n * Parser<ParseTree extends undefined ? Node : ParseTree> |\n * undefined\n * )}\n */\n this.parser = undefined\n\n /**\n * Internal list of configured transformers.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Pipeline}\n */\n this.transformers = trough()\n }\n\n /**\n * Copy a processor.\n *\n * @deprecated\n * This is a private internal method and should not be used.\n * @returns {Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>}\n * New *unfrozen* processor ({@linkcode Processor}) that is\n * configured to work the same as its ancestor.\n * When the descendant processor is configured in the future it does not\n * affect the ancestral processor.\n */\n copy() {\n // Cast as the type parameters will be the same after attaching.\n const destination =\n /** @type {Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>} */ (\n new Processor()\n )\n let index = -1\n\n while (++index < this.attachers.length) {\n const attacher = this.attachers[index]\n destination.use(...attacher)\n }\n\n destination.data(extend(true, {}, this.namespace))\n\n return destination\n }\n\n /**\n * Configure the processor with info available to all plugins.\n * Information is stored in an object.\n *\n * Typically, options can be given to a specific plugin, but sometimes it\n * makes sense to have information shared with several plugins.\n * For example, a list of HTML elements that are self-closing, which is\n * needed during all phases.\n *\n * > **Note**: setting information cannot occur on *frozen* processors.\n * > Call the processor first to create a new unfrozen processor.\n *\n * > **Note**: to register custom data in TypeScript, augment the\n * > {@linkcode Data} interface.\n *\n * @example\n * This example show how to get and set info:\n *\n * ```js\n * import {unified} from 'unified'\n *\n * const processor = unified().data('alpha', 'bravo')\n *\n * processor.data('alpha') // => 'bravo'\n *\n * processor.data() // => {alpha: 'bravo'}\n *\n * processor.data({charlie: 'delta'})\n *\n * processor.data() // => {charlie: 'delta'}\n * ```\n *\n * @template {keyof Data} Key\n *\n * @overload\n * @returns {Data}\n *\n * @overload\n * @param {Data} dataset\n * @returns {Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>}\n *\n * @overload\n * @param {Key} key\n * @returns {Data[Key]}\n *\n * @overload\n * @param {Key} key\n * @param {Data[Key]} value\n * @returns {Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>}\n *\n * @param {Data | Key} [key]\n * Key to get or set, or entire dataset to set, or nothing to get the\n * entire dataset (optional).\n * @param {Data[Key]} [value]\n * Value to set (optional).\n * @returns {unknown}\n * The current processor when setting, the value at `key` when getting, or\n * the entire dataset when getting without key.\n */\n data(key, value) {\n if (typeof key === 'string') {\n // Set `key`.\n if (arguments.length === 2) {\n assertUnfrozen('data', this.frozen)\n this.namespace[key] = value\n return this\n }\n\n // Get `key`.\n return (own.call(this.namespace, key) && this.namespace[key]) || undefined\n }\n\n // Set space.\n if (key) {\n assertUnfrozen('data', this.frozen)\n this.namespace = key\n return this\n }\n\n // Get space.\n return this.namespace\n }\n\n /**\n * Freeze a processor.\n *\n * Frozen processors are meant to be extended and not to be configured\n * directly.\n *\n * When a processor is frozen it cannot be unfrozen.\n * New processors working the same way can be created by calling the\n * processor.\n *\n * It’s possible to freeze processors explicitly by calling `.freeze()`.\n * Processors freeze automatically when `.parse()`, `.run()`, `.runSync()`,\n * `.stringify()`, `.process()`, or `.processSync()` are called.\n *\n * @returns {Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>}\n * The current processor.\n */\n freeze() {\n if (this.frozen) {\n return this\n }\n\n // Cast so that we can type plugins easier.\n // Plugins are supposed to be usable on different processors, not just on\n // this exact processor.\n const self = /** @type {Processor} */ (/** @type {unknown} */ (this))\n\n while (++this.freezeIndex < this.attachers.length) {\n const [attacher, ...options] = this.attachers[this.freezeIndex]\n\n if (options[0] === false) {\n continue\n }\n\n if (options[0] === true) {\n options[0] = undefined\n }\n\n const transformer = attacher.call(self, ...options)\n\n if (typeof transformer === 'function') {\n this.transformers.use(transformer)\n }\n }\n\n this.frozen = true\n this.freezeIndex = Number.POSITIVE_INFINITY\n\n return this\n }\n\n /**\n * Parse text to a syntax tree.\n *\n * > **Note**: `parse` freezes the processor if not already *frozen*.\n *\n * > **Note**: `parse` performs the parse phase, not the run phase or other\n * > phases.\n *\n * @param {Compatible | undefined} [file]\n * file to parse (optional); typically `string` or `VFile`; any value\n * accepted as `x` in `new VFile(x)`.\n * @returns {ParseTree extends undefined ? Node : ParseTree}\n * Syntax tree representing `file`.\n */\n parse(file) {\n this.freeze()\n const realFile = vfile(file)\n const parser = this.parser || this.Parser\n assertParser('parse', parser)\n return parser(String(realFile), realFile)\n }\n\n /**\n * Process the given file as configured on the processor.\n *\n * > **Note**: `process` freezes the processor if not already *frozen*.\n *\n * > **Note**: `process` performs the parse, run, and stringify phases.\n *\n * @overload\n * @param {Compatible | undefined} file\n * @param {ProcessCallback<VFileWithOutput<CompileResult>>} done\n * @returns {undefined}\n *\n * @overload\n * @param {Compatible | undefined} [file]\n * @returns {Promise<VFileWithOutput<CompileResult>>}\n *\n * @param {Compatible | undefined} [file]\n * File (optional); typically `string` or `VFile`]; any value accepted as\n * `x` in `new VFile(x)`.\n * @param {ProcessCallback<VFileWithOutput<CompileResult>> | undefined} [done]\n * Callback (optional).\n * @returns {Promise<VFile> | undefined}\n * Nothing if `done` is given.\n * Otherwise a promise, rejected with a fatal error or resolved with the\n * processed file.\n *\n * The parsed, transformed, and compiled value is available at\n * `file.value` (see note).\n *\n * > **Note**: unified typically compiles by serializing: most\n * > compilers return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n process(file, done) {\n const self = this\n\n this.freeze()\n assertParser('process', this.parser || this.Parser)\n assertCompiler('process', this.compiler || this.Compiler)\n\n return done ? executor(undefined, done) : new Promise(executor)\n\n // Note: `void`s needed for TS.\n /**\n * @param {((file: VFileWithOutput<CompileResult>) => undefined | void) | undefined} resolve\n * @param {(error: Error | undefined) => undefined | void} reject\n * @returns {undefined}\n */\n function executor(resolve, reject) {\n const realFile = vfile(file)\n // Assume `ParseTree` (the result of the parser) matches `HeadTree` (the\n // input of the first transform).\n const parseTree =\n /** @type {HeadTree extends undefined ? Node : HeadTree} */ (\n /** @type {unknown} */ (self.parse(realFile))\n )\n\n self.run(parseTree, realFile, function (error, tree, file) {\n if (error || !tree || !file) {\n return realDone(error)\n }\n\n // Assume `TailTree` (the output of the last transform) matches\n // `CompileTree` (the input of the compiler).\n const compileTree =\n /** @type {CompileTree extends undefined ? Node : CompileTree} */ (\n /** @type {unknown} */ (tree)\n )\n\n const compileResult = self.stringify(compileTree, file)\n\n if (looksLikeAValue(compileResult)) {\n file.value = compileResult\n } else {\n file.result = compileResult\n }\n\n realDone(error, /** @type {VFileWithOutput<CompileResult>} */ (file))\n })\n\n /**\n * @param {Error | undefined} error\n * @param {VFileWithOutput<CompileResult> | undefined} [file]\n * @returns {undefined}\n */\n function realDone(error, file) {\n if (error || !file) {\n reject(error)\n } else if (resolve) {\n resolve(file)\n } else {\n assert(done, '`done` is defined if `resolve` is not')\n done(undefined, file)\n }\n }\n }\n }\n\n /**\n * Process the given file as configured on the processor.\n *\n * An error is thrown if asynchronous transforms are configured.\n *\n * > **Note**: `processSync` freezes the processor if not already *frozen*.\n *\n * > **Note**: `processSync` performs the parse, run, and stringify phases.\n *\n * @param {Compatible | undefined} [file]\n * File (optional); typically `string` or `VFile`; any value accepted as\n * `x` in `new VFile(x)`.\n * @returns {VFileWithOutput<CompileResult>}\n * The processed file.\n *\n * The parsed, transformed, and compiled value is available at\n * `file.value` (see note).\n *\n * > **Note**: unified typically compiles by serializing: most\n * > compilers return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n processSync(file) {\n /** @type {boolean} */\n let complete = false\n /** @type {VFileWithOutput<CompileResult> | undefined} */\n let result\n\n this.freeze()\n assertParser('processSync', this.parser || this.Parser)\n assertCompiler('processSync', this.compiler || this.Compiler)\n\n this.process(file, realDone)\n assertDone('processSync', 'process', complete)\n assert(result, 'we either bailed on an error or have a tree')\n\n return result\n\n /**\n * @type {ProcessCallback<VFileWithOutput<CompileResult>>}\n */\n function realDone(error, file) {\n complete = true\n bail(error)\n result = file\n }\n }\n\n /**\n * Run *transformers* on a syntax tree.\n *\n * > **Note**: `run` freezes the processor if not already *frozen*.\n *\n * > **Note**: `run` performs the run phase, not other phases.\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {RunCallback<TailTree extends undefined ? Node : TailTree>} done\n * @returns {undefined}\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {Compatible | undefined} file\n * @param {RunCallback<TailTree extends undefined ? Node : TailTree>} done\n * @returns {undefined}\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {Compatible | undefined} [file]\n * @returns {Promise<TailTree extends undefined ? Node : TailTree>}\n *\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * Tree to transform and inspect.\n * @param {(\n * RunCallback<TailTree extends undefined ? Node : TailTree> |\n * Compatible\n * )} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @param {RunCallback<TailTree extends undefined ? Node : TailTree>} [done]\n * Callback (optional).\n * @returns {Promise<TailTree extends undefined ? Node : TailTree> | undefined}\n * Nothing if `done` is given.\n * Otherwise, a promise rejected with a fatal error or resolved with the\n * transformed tree.\n */\n run(tree, file, done) {\n assertNode(tree)\n this.freeze()\n\n const transformers = this.transformers\n\n if (!done && typeof file === 'function') {\n done = file\n file = undefined\n }\n\n return done ? executor(undefined, done) : new Promise(executor)\n\n // Note: `void`s needed for TS.\n /**\n * @param {(\n * ((tree: TailTree extends undefined ? Node : TailTree) => undefined | void) |\n * undefined\n * )} resolve\n * @param {(error: Error) => undefined | void} reject\n * @returns {undefined}\n */\n function executor(resolve, reject) {\n assert(\n typeof file !== 'function',\n '`file` can’t be a `done` anymore, we checked'\n )\n const realFile = vfile(file)\n transformers.run(tree, realFile, realDone)\n\n /**\n * @param {Error | undefined} error\n * @param {Node} outputTree\n * @param {VFile} file\n * @returns {undefined}\n */\n function realDone(error, outputTree, file) {\n const resultingTree =\n /** @type {TailTree extends undefined ? Node : TailTree} */ (\n outputTree || tree\n )\n\n if (error) {\n reject(error)\n } else if (resolve) {\n resolve(resultingTree)\n } else {\n assert(done, '`done` is defined if `resolve` is not')\n done(undefined, resultingTree, file)\n }\n }\n }\n }\n\n /**\n * Run *transformers* on a syntax tree.\n *\n * An error is thrown if asynchronous transforms are configured.\n *\n * > **Note**: `runSync` freezes the processor if not already *frozen*.\n *\n * > **Note**: `runSync` performs the run phase, not other phases.\n *\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * Tree to transform and inspect.\n * @param {Compatible | undefined} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @returns {TailTree extends undefined ? Node : TailTree}\n * Transformed tree.\n */\n runSync(tree, file) {\n /** @type {boolean} */\n let complete = false\n /** @type {(TailTree extends undefined ? Node : TailTree) | undefined} */\n let result\n\n this.run(tree, file, realDone)\n\n assertDone('runSync', 'run', complete)\n assert(result, 'we either bailed on an error or have a tree')\n return result\n\n /**\n * @type {RunCallback<TailTree extends undefined ? Node : TailTree>}\n */\n function realDone(error, tree) {\n bail(error)\n result = tree\n complete = true\n }\n }\n\n /**\n * Compile a syntax tree.\n *\n * > **Note**: `stringify` freezes the processor if not already *frozen*.\n *\n * > **Note**: `stringify` performs the stringify phase, not the run phase\n * > or other phases.\n *\n * @param {CompileTree extends undefined ? Node : CompileTree} tree\n * Tree to compile.\n * @param {Compatible | undefined} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @returns {CompileResult extends undefined ? Value : CompileResult}\n * Textual representation of the tree (see note).\n *\n * > **Note**: unified typically compiles by serializing: most compilers\n * > return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n stringify(tree, file) {\n this.freeze()\n const realFile = vfile(file)\n const compiler = this.compiler || this.Compiler\n assertCompiler('stringify', compiler)\n assertNode(tree)\n\n return compiler(tree, realFile)\n }\n\n /**\n * Configure the processor to use a plugin, a list of usable values, or a\n * preset.\n *\n * If the processor is already using a plugin, the previous plugin\n * configuration is changed based on the options that are passed in.\n * In other words, the plugin is not added a second time.\n *\n * > **Note**: `use` cannot be called on *frozen* processors.\n * > Call the processor first to create a new unfrozen processor.\n *\n * @example\n * There are many ways to pass plugins to `.use()`.\n * This example gives an overview:\n *\n * ```js\n * import {unified} from 'unified'\n *\n * unified()\n * // Plugin with options:\n * .use(pluginA, {x: true, y: true})\n * // Passing the same plugin again merges configuration (to `{x: true, y: false, z: true}`):\n * .use(pluginA, {y: false, z: true})\n * // Plugins:\n * .use([pluginB, pluginC])\n * // Two plugins, the second with options:\n * .use([pluginD, [pluginE, {}]])\n * // Preset with plugins and settings:\n * .use({plugins: [pluginF, [pluginG, {}]], settings: {position: false}})\n * // Settings only:\n * .use({settings: {position: false}})\n * ```\n *\n * @template {Array<unknown>} [Parameters=[]]\n * @template {Node | string | undefined} [Input=undefined]\n * @template [Output=Input]\n *\n * @overload\n * @param {Preset | null | undefined} [preset]\n * @returns {Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>}\n *\n * @overload\n * @param {PluggableList} list\n * @returns {Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>}\n *\n * @overload\n * @param {Plugin<Parameters, Input, Output>} plugin\n * @param {...(Parameters | [boolean])} parameters\n * @returns {UsePlugin<ParseTree, HeadTree, TailTree, CompileTree, CompileResult, Input, Output>}\n *\n * @param {PluggableList | Plugin | Preset | null | undefined} value\n * Usable value.\n * @param {...unknown} parameters\n * Parameters, when a plugin is given as a usable value.\n * @returns {Processor<ParseTree, HeadTree, TailTree, CompileTree, CompileResult>}\n * Current processor.\n */\n use(value, ...parameters) {\n const attachers = this.attachers\n const namespace = this.namespace\n\n assertUnfrozen('use', this.frozen)\n\n if (value === null || value === undefined) {\n // Empty.\n } else if (typeof value === 'function') {\n addPlugin(value, parameters)\n } else if (typeof value === 'object') {\n if (Array.isArray(value)) {\n addList(value)\n } else {\n addPreset(value)\n }\n } else {\n throw new TypeError('Expected usable value, not `' + value + '`')\n }\n\n return this\n\n /**\n * @param {Pluggable} value\n * @returns {undefined}\n */\n function add(value) {\n if (typeof value === 'function') {\n addPlugin(value, [])\n } else if (typeof value === 'object') {\n if (Array.isArray(value)) {\n const [plugin, ...parameters] =\n /** @type {PluginTuple<Array<unknown>>} */ (value)\n addPlugin(plugin, parameters)\n } else {\n addPreset(value)\n }\n } else {\n throw new TypeError('Expected usable value, not `' + value + '`')\n }\n }\n\n /**\n * @param {Preset} result\n * @returns {undefined}\n */\n function addPreset(result) {\n if (!('plugins' in result) && !('settings' in result)) {\n throw new Error(\n 'Expected usable value but received an empty preset, which is probably a mistake: presets typically come with `plugins` and sometimes with `settings`, but this has neither'\n )\n }\n\n addList(result.plugins)\n\n if (result.settings) {\n namespace.settings = extend(true, namespace.settings, result.settings)\n }\n }\n\n /**\n * @param {PluggableList | null | undefined} plugins\n * @returns {undefined}\n */\n function addList(plugins) {\n let index = -1\n\n if (plugins === null || plugins === undefined) {\n // Empty.\n } else if (Array.isArray(plugins)) {\n while (++index < plugins.length) {\n const thing = plugins[index]\n add(thing)\n }\n } else {\n throw new TypeError('Expected a list of plugins, not `' + plugins + '`')\n }\n }\n\n /**\n * @param {Plugin} plugin\n * @param {Array<unknown>} parameters\n * @returns {undefined}\n */\n function addPlugin(plugin, parameters) {\n let index = -1\n let entryIndex = -1\n\n while (++index < attachers.length) {\n if (attachers[index][0] === plugin) {\n entryIndex = index\n break\n }\n }\n\n if (entryIndex === -1) {\n attachers.push([plugin, ...parameters])\n }\n // Only set if there was at least a `primary` value, otherwise we’d change\n // `arguments.length`.\n else if (parameters.length > 0) {\n let [primary, ...rest] = parameters\n const currentPrimary = attachers[entryIndex][1]\n if (isPlainObj(currentPrimary) && isPlainObj(primary)) {\n primary = extend(true, currentPrimary, primary)\n }\n\n attachers[entryIndex] = [plugin, primary, ...rest]\n }\n }\n }\n}\n\n// Note: this returns a *callable* instance.\n// That’s why it’s documented as a function.\n/**\n * Create a new processor.\n *\n * @example\n * This example shows how a new processor can be created (from `remark`) and linked\n * to **stdin**(4) and **stdout**(4).\n *\n * ```js\n * import process from 'node:process'\n * import concatStream from 'concat-stream'\n * import {remark} from 'remark'\n *\n * process.stdin.pipe(\n * concatStream(function (buf) {\n * process.stdout.write(String(remark().processSync(buf)))\n * })\n * )\n * ```\n *\n * @returns\n * New *unfrozen* processor (`processor`).\n *\n * This processor is configured to work the same as its ancestor.\n * When the descendant processor is configured in the future it does not\n * affect the ancestral processor.\n */\nexport const unified = new Processor().freeze()\n\n/**\n * Assert a parser is available.\n *\n * @param {string} name\n * @param {unknown} value\n * @returns {asserts value is Parser}\n */\nfunction assertParser(name, value) {\n if (typeof value !== 'function') {\n throw new TypeError('Cannot `' + name + '` without `parser`')\n }\n}\n\n/**\n * Assert a compiler is available.\n *\n * @param {string} name\n * @param {unknown} value\n * @returns {asserts value is Compiler}\n */\nfunction assertCompiler(name, value) {\n if (typeof value !== 'function') {\n throw new TypeError('Cannot `' + name + '` without `compiler`')\n }\n}\n\n/**\n * Assert the processor is not frozen.\n *\n * @param {string} name\n * @param {unknown} frozen\n * @returns {asserts frozen is false}\n */\nfunction assertUnfrozen(name, frozen) {\n if (frozen) {\n throw new Error(\n 'Cannot call `' +\n name +\n '` on a frozen processor.\\nCreate a new processor first, by calling it: use `processor()` instead of `processor`.'\n )\n }\n}\n\n/**\n * Assert `node` is a unist node.\n *\n * @param {unknown} node\n * @returns {asserts node is Node}\n */\nfunction assertNode(node) {\n // `isPlainObj` unfortunately uses `any` instead of `unknown`.\n // type-coverage:ignore-next-line\n if (!isPlainObj(node) || typeof node.type !== 'string') {\n throw new TypeError('Expected node, got `' + node + '`')\n // Fine.\n }\n}\n\n/**\n * Assert that `complete` is `true`.\n *\n * @param {string} name\n * @param {string} asyncName\n * @param {unknown} complete\n * @returns {asserts complete is true}\n */\nfunction assertDone(name, asyncName, complete) {\n if (!complete) {\n throw new Error(\n '`' + name + '` finished async. Use `' + asyncName + '` instead'\n )\n }\n}\n\n/**\n * @param {Compatible | undefined} [value]\n * @returns {VFile}\n */\nfunction vfile(value) {\n return looksLikeAVFile(value) ? value : new VFile(value)\n}\n\n/**\n * @param {Compatible | undefined} [value]\n * @returns {value is VFile}\n */\nfunction looksLikeAVFile(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'message' in value &&\n 'messages' in value\n )\n}\n\n/**\n * @param {unknown} [value]\n * @returns {value is Value}\n */\nfunction looksLikeAValue(value) {\n return typeof value === 'string' || isUint8Array(value)\n}\n\n/**\n * Assert `value` is an `Uint8Array`.\n *\n * @param {unknown} value\n * thing.\n * @returns {value is Uint8Array}\n * Whether `value` is an `Uint8Array`.\n */\nfunction isUint8Array(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'byteLength' in value &&\n 'byteOffset' in value\n )\n}\n","/**\n * @import {Element, Nodes, Parents, Root} from 'hast'\n * @import {Root as MdastRoot} from 'mdast'\n * @import {ComponentType, JSX, ReactElement, ReactNode} from 'react'\n * @import {Options as RemarkRehypeOptions} from 'remark-rehype'\n * @import {BuildVisitor} from 'unist-util-visit'\n * @import {PluggableList, Processor} from 'unified'\n */\n\n/**\n * @callback AllowElement\n * Filter elements.\n * @param {Readonly<Element>} element\n * Element to check.\n * @param {number} index\n * Index of `element` in `parent`.\n * @param {Readonly<Parents> | undefined} parent\n * Parent of `element`.\n * @returns {boolean | null | undefined}\n * Whether to allow `element` (default: `false`).\n */\n\n/**\n * @typedef ExtraProps\n * Extra fields we pass.\n * @property {Element | undefined} [node]\n * passed when `passNode` is on.\n */\n\n/**\n * @typedef {{\n * [Key in keyof JSX.IntrinsicElements]?: ComponentType<JSX.IntrinsicElements[Key] & ExtraProps> | keyof JSX.IntrinsicElements\n * }} Components\n * Map tag names to components.\n */\n\n/**\n * @typedef Deprecation\n * Deprecation.\n * @property {string} from\n * Old field.\n * @property {string} id\n * ID in readme.\n * @property {keyof Options} [to]\n * New field.\n */\n\n/**\n * @typedef Options\n * Configuration.\n * @property {AllowElement | null | undefined} [allowElement]\n * Filter elements (optional);\n * `allowedElements` / `disallowedElements` is used first.\n * @property {ReadonlyArray<string> | null | undefined} [allowedElements]\n * Tag names to allow (default: all tag names);\n * cannot combine w/ `disallowedElements`.\n * @property {string | null | undefined} [children]\n * Markdown.\n * @property {Components | null | undefined} [components]\n * Map tag names to components.\n * @property {ReadonlyArray<string> | null | undefined} [disallowedElements]\n * Tag names to disallow (default: `[]`);\n * cannot combine w/ `allowedElements`.\n * @property {PluggableList | null | undefined} [rehypePlugins]\n * List of rehype plugins to use.\n * @property {PluggableList | null | undefined} [remarkPlugins]\n * List of remark plugins to use.\n * @property {Readonly<RemarkRehypeOptions> | null | undefined} [remarkRehypeOptions]\n * Options to pass through to `remark-rehype`.\n * @property {boolean | null | undefined} [skipHtml=false]\n * Ignore HTML in markdown completely (default: `false`).\n * @property {boolean | null | undefined} [unwrapDisallowed=false]\n * Extract (unwrap) what’s in disallowed elements (default: `false`);\n * normally when say `strong` is not allowed, it and it’s children are dropped,\n * with `unwrapDisallowed` the element itself is replaced by its children.\n * @property {UrlTransform | null | undefined} [urlTransform]\n * Change URLs (default: `defaultUrlTransform`)\n */\n\n/**\n * @typedef HooksOptionsOnly\n * Configuration specifically for {@linkcode MarkdownHooks}.\n * @property {ReactNode | null | undefined} [fallback]\n * Content to render while the processor processing the markdown (optional).\n */\n\n/**\n * @typedef {Options & HooksOptionsOnly} HooksOptions\n * Configuration for {@linkcode MarkdownHooks};\n * extends the regular {@linkcode Options} with a `fallback` prop.\n */\n\n/**\n * @callback UrlTransform\n * Transform all URLs.\n * @param {string} url\n * URL.\n * @param {string} key\n * Property name (example: `'href'`).\n * @param {Readonly<Element>} node\n * Node.\n * @returns {string | null | undefined}\n * Transformed URL (optional).\n */\n\nimport {unreachable} from 'devlop'\nimport {toJsxRuntime} from 'hast-util-to-jsx-runtime'\nimport {urlAttributes} from 'html-url-attributes'\nimport {Fragment, jsx, jsxs} from 'react/jsx-runtime'\nimport {useEffect, useState} from 'react'\nimport remarkParse from 'remark-parse'\nimport remarkRehype from 'remark-rehype'\nimport {unified} from 'unified'\nimport {visit} from 'unist-util-visit'\nimport {VFile} from 'vfile'\n\nconst changelog =\n 'https://github.com/remarkjs/react-markdown/blob/main/changelog.md'\n\n/** @type {PluggableList} */\nconst emptyPlugins = []\n/** @type {Readonly<RemarkRehypeOptions>} */\nconst emptyRemarkRehypeOptions = {allowDangerousHtml: true}\nconst safeProtocol = /^(https?|ircs?|mailto|xmpp)$/i\n\n// Mutable because we `delete` any time it’s used and a message is sent.\n/** @type {ReadonlyArray<Readonly<Deprecation>>} */\nconst deprecations = [\n {from: 'astPlugins', id: 'remove-buggy-html-in-markdown-parser'},\n {from: 'allowDangerousHtml', id: 'remove-buggy-html-in-markdown-parser'},\n {\n from: 'allowNode',\n id: 'replace-allownode-allowedtypes-and-disallowedtypes',\n to: 'allowElement'\n },\n {\n from: 'allowedTypes',\n id: 'replace-allownode-allowedtypes-and-disallowedtypes',\n to: 'allowedElements'\n },\n {from: 'className', id: 'remove-classname'},\n {\n from: 'disallowedTypes',\n id: 'replace-allownode-allowedtypes-and-disallowedtypes',\n to: 'disallowedElements'\n },\n {from: 'escapeHtml', id: 'remove-buggy-html-in-markdown-parser'},\n {from: 'includeElementIndex', id: '#remove-includeelementindex'},\n {\n from: 'includeNodeIndex',\n id: 'change-includenodeindex-to-includeelementindex'\n },\n {from: 'linkTarget', id: 'remove-linktarget'},\n {from: 'plugins', id: 'change-plugins-to-remarkplugins', to: 'remarkPlugins'},\n {from: 'rawSourcePos', id: '#remove-rawsourcepos'},\n {from: 'renderers', id: 'change-renderers-to-components', to: 'components'},\n {from: 'source', id: 'change-source-to-children', to: 'children'},\n {from: 'sourcePos', id: '#remove-sourcepos'},\n {from: 'transformImageUri', id: '#add-urltransform', to: 'urlTransform'},\n {from: 'transformLinkUri', id: '#add-urltransform', to: 'urlTransform'}\n]\n\n/**\n * Component to render markdown.\n *\n * This is a synchronous component.\n * When using async plugins,\n * see {@linkcode MarkdownAsync} or {@linkcode MarkdownHooks}.\n *\n * @param {Readonly<Options>} options\n * Props.\n * @returns {ReactElement}\n * React element.\n */\nexport function Markdown(options) {\n const processor = createProcessor(options)\n const file = createFile(options)\n return post(processor.runSync(processor.parse(file), file), options)\n}\n\n/**\n * Component to render markdown with support for async plugins\n * through async/await.\n *\n * Components returning promises are supported on the server.\n * For async support on the client,\n * see {@linkcode MarkdownHooks}.\n *\n * @param {Readonly<Options>} options\n * Props.\n * @returns {Promise<ReactElement>}\n * Promise to a React element.\n */\nexport async function MarkdownAsync(options) {\n const processor = createProcessor(options)\n const file = createFile(options)\n const tree = await processor.run(processor.parse(file), file)\n return post(tree, options)\n}\n\n/**\n * Component to render markdown with support for async plugins through hooks.\n *\n * This uses `useEffect` and `useState` hooks.\n * Hooks run on the client and do not immediately render something.\n * For async support on the server,\n * see {@linkcode MarkdownAsync}.\n *\n * @param {Readonly<HooksOptions>} options\n * Props.\n * @returns {ReactNode}\n * React node.\n */\nexport function MarkdownHooks(options) {\n const processor = createProcessor(options)\n const [error, setError] = useState(\n /** @type {Error | undefined} */ (undefined)\n )\n const [tree, setTree] = useState(/** @type {Root | undefined} */ (undefined))\n\n useEffect(\n function () {\n let cancelled = false\n const file = createFile(options)\n\n processor.run(processor.parse(file), file, function (error, tree) {\n if (!cancelled) {\n setError(error)\n setTree(tree)\n }\n })\n\n /**\n * @returns {undefined}\n * Nothing.\n */\n return function () {\n cancelled = true\n }\n },\n [\n options.children,\n options.rehypePlugins,\n options.remarkPlugins,\n options.remarkRehypeOptions\n ]\n )\n\n if (error) throw error\n\n return tree ? post(tree, options) : options.fallback\n}\n\n/**\n * Set up the `unified` processor.\n *\n * @param {Readonly<Options>} options\n * Props.\n * @returns {Processor<MdastRoot, MdastRoot, Root, undefined, undefined>}\n * Result.\n */\nfunction createProcessor(options) {\n const rehypePlugins = options.rehypePlugins || emptyPlugins\n const remarkPlugins = options.remarkPlugins || emptyPlugins\n const remarkRehypeOptions = options.remarkRehypeOptions\n ? {...options.remarkRehypeOptions, ...emptyRemarkRehypeOptions}\n : emptyRemarkRehypeOptions\n\n const processor = unified()\n .use(remarkParse)\n .use(remarkPlugins)\n .use(remarkRehype, remarkRehypeOptions)\n .use(rehypePlugins)\n\n return processor\n}\n\n/**\n * Set up the virtual file.\n *\n * @param {Readonly<Options>} options\n * Props.\n * @returns {VFile}\n * Result.\n */\nfunction createFile(options) {\n const children = options.children || ''\n const file = new VFile()\n\n if (typeof children === 'string') {\n file.value = children\n } else {\n unreachable(\n 'Unexpected value `' +\n children +\n '` for `children` prop, expected `string`'\n )\n }\n\n return file\n}\n\n/**\n * Process the result from unified some more.\n *\n * @param {Nodes} tree\n * Tree.\n * @param {Readonly<Options>} options\n * Props.\n * @returns {ReactElement}\n * React element.\n */\nfunction post(tree, options) {\n const allowedElements = options.allowedElements\n const allowElement = options.allowElement\n const components = options.components\n const disallowedElements = options.disallowedElements\n const skipHtml = options.skipHtml\n const unwrapDisallowed = options.unwrapDisallowed\n const urlTransform = options.urlTransform || defaultUrlTransform\n\n for (const deprecation of deprecations) {\n if (Object.hasOwn(options, deprecation.from)) {\n unreachable(\n 'Unexpected `' +\n deprecation.from +\n '` prop, ' +\n (deprecation.to\n ? 'use `' + deprecation.to + '` instead'\n : 'remove it') +\n ' (see <' +\n changelog +\n '#' +\n deprecation.id +\n '> for more info)'\n )\n }\n }\n\n if (allowedElements && disallowedElements) {\n unreachable(\n 'Unexpected combined `allowedElements` and `disallowedElements`, expected one or the other'\n )\n }\n\n visit(tree, transform)\n\n return toJsxRuntime(tree, {\n Fragment,\n components,\n ignoreInvalidStyle: true,\n jsx,\n jsxs,\n passKeys: true,\n passNode: true\n })\n\n /** @type {BuildVisitor<Root>} */\n function transform(node, index, parent) {\n if (node.type === 'raw' && parent && typeof index === 'number') {\n if (skipHtml) {\n parent.children.splice(index, 1)\n } else {\n parent.children[index] = {type: 'text', value: node.value}\n }\n\n return index\n }\n\n if (node.type === 'element') {\n /** @type {string} */\n let key\n\n for (key in urlAttributes) {\n if (\n Object.hasOwn(urlAttributes, key) &&\n Object.hasOwn(node.properties, key)\n ) {\n const value = node.properties[key]\n const test = urlAttributes[key]\n if (test === null || test.includes(node.tagName)) {\n node.properties[key] = urlTransform(String(value || ''), key, node)\n }\n }\n }\n }\n\n if (node.type === 'element') {\n let remove = allowedElements\n ? !allowedElements.includes(node.tagName)\n : disallowedElements\n ? disallowedElements.includes(node.tagName)\n : false\n\n if (!remove && allowElement && typeof index === 'number') {\n remove = !allowElement(node, index, parent)\n }\n\n if (remove && parent && typeof index === 'number') {\n if (unwrapDisallowed && node.children) {\n parent.children.splice(index, 1, ...node.children)\n } else {\n parent.children.splice(index, 1)\n }\n\n return index\n }\n }\n }\n}\n\n/**\n * Make a URL safe.\n *\n * @satisfies {UrlTransform}\n * @param {string} value\n * URL.\n * @returns {string}\n * Safe URL.\n */\nexport function defaultUrlTransform(value) {\n // Same as:\n // <https://github.com/micromark/micromark/blob/929275e/packages/micromark-util-sanitize-uri/dev/index.js#L34>\n // But without the `encode` part.\n const colon = value.indexOf(':')\n const questionMark = value.indexOf('?')\n const numberSign = value.indexOf('#')\n const slash = value.indexOf('/')\n\n if (\n // If there is no protocol, it’s relative.\n colon === -1 ||\n // If the first colon is after a `?`, `#`, or `/`, it’s not a protocol.\n (slash !== -1 && colon > slash) ||\n (questionMark !== -1 && colon > questionMark) ||\n (numberSign !== -1 && colon > numberSign) ||\n // It is a protocol, it should be allowed.\n safeProtocol.test(value.slice(0, colon))\n ) {\n return value\n }\n\n return ''\n}\n","/**\n * Count how often a character (or substring) is used in a string.\n *\n * @param {string} value\n * Value to search in.\n * @param {string} character\n * Character (or substring) to look for.\n * @return {number}\n * Number of times `character` occurred in `value`.\n */\nexport function ccount(value, character) {\n const source = String(value)\n\n if (typeof character !== 'string') {\n throw new TypeError('Expected character')\n }\n\n let count = 0\n let index = source.indexOf(character)\n\n while (index !== -1) {\n count++\n index = source.indexOf(character, index + character.length)\n }\n\n return count\n}\n","export default function escapeStringRegexp(string) {\n\tif (typeof string !== 'string') {\n\t\tthrow new TypeError('Expected a string');\n\t}\n\n\t// Escape characters with special meaning either inside or outside character sets.\n\t// Use a simple backslash escape when it’s always valid, and a `\\xnn` escape when the simpler form would be disallowed by Unicode patterns’ stricter grammar.\n\treturn string\n\t\t.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&')\n\t\t.replace(/-/g, '\\\\x2d');\n}\n","/**\n * @import {Nodes, Parents, PhrasingContent, Root, Text} from 'mdast'\n * @import {BuildVisitor, Test, VisitorResult} from 'unist-util-visit-parents'\n */\n\n/**\n * @typedef RegExpMatchObject\n * Info on the match.\n * @property {number} index\n * The index of the search at which the result was found.\n * @property {string} input\n * A copy of the search string in the text node.\n * @property {[...Array<Parents>, Text]} stack\n * All ancestors of the text node, where the last node is the text itself.\n *\n * @typedef {RegExp | string} Find\n * Pattern to find.\n *\n * Strings are escaped and then turned into global expressions.\n *\n * @typedef {Array<FindAndReplaceTuple>} FindAndReplaceList\n * Several find and replaces, in array form.\n *\n * @typedef {[Find, Replace?]} FindAndReplaceTuple\n * Find and replace in tuple form.\n *\n * @typedef {ReplaceFunction | string | null | undefined} Replace\n * Thing to replace with.\n *\n * @callback ReplaceFunction\n * Callback called when a search matches.\n * @param {...any} parameters\n * The parameters are the result of corresponding search expression:\n *\n * * `value` (`string`) — whole match\n * * `...capture` (`Array<string>`) — matches from regex capture groups\n * * `match` (`RegExpMatchObject`) — info on the match\n * @returns {Array<PhrasingContent> | PhrasingContent | string | false | null | undefined}\n * Thing to replace with.\n *\n * * when `null`, `undefined`, `''`, remove the match\n * * …or when `false`, do not replace at all\n * * …or when `string`, replace with a text node of that value\n * * …or when `Node` or `Array<Node>`, replace with those nodes\n *\n * @typedef {[RegExp, ReplaceFunction]} Pair\n * Normalized find and replace.\n *\n * @typedef {Array<Pair>} Pairs\n * All find and replaced.\n *\n * @typedef Options\n * Configuration.\n * @property {Test | null | undefined} [ignore]\n * Test for which nodes to ignore (optional).\n */\n\nimport escape from 'escape-string-regexp'\nimport {visitParents} from 'unist-util-visit-parents'\nimport {convert} from 'unist-util-is'\n\n/**\n * Find patterns in a tree and replace them.\n *\n * The algorithm searches the tree in *preorder* for complete values in `Text`\n * nodes.\n * Partial matches are not supported.\n *\n * @param {Nodes} tree\n * Tree to change.\n * @param {FindAndReplaceList | FindAndReplaceTuple} list\n * Patterns to find.\n * @param {Options | null | undefined} [options]\n * Configuration (when `find` is not `Find`).\n * @returns {undefined}\n * Nothing.\n */\nexport function findAndReplace(tree, list, options) {\n const settings = options || {}\n const ignored = convert(settings.ignore || [])\n const pairs = toPairs(list)\n let pairIndex = -1\n\n while (++pairIndex < pairs.length) {\n visitParents(tree, 'text', visitor)\n }\n\n /** @type {BuildVisitor<Root, 'text'>} */\n function visitor(node, parents) {\n let index = -1\n /** @type {Parents | undefined} */\n let grandparent\n\n while (++index < parents.length) {\n const parent = parents[index]\n /** @type {Array<Nodes> | undefined} */\n const siblings = grandparent ? grandparent.children : undefined\n\n if (\n ignored(\n parent,\n siblings ? siblings.indexOf(parent) : undefined,\n grandparent\n )\n ) {\n return\n }\n\n grandparent = parent\n }\n\n if (grandparent) {\n return handler(node, parents)\n }\n }\n\n /**\n * Handle a text node which is not in an ignored parent.\n *\n * @param {Text} node\n * Text node.\n * @param {Array<Parents>} parents\n * Parents.\n * @returns {VisitorResult}\n * Result.\n */\n function handler(node, parents) {\n const parent = parents[parents.length - 1]\n const find = pairs[pairIndex][0]\n const replace = pairs[pairIndex][1]\n let start = 0\n /** @type {Array<Nodes>} */\n const siblings = parent.children\n const index = siblings.indexOf(node)\n let change = false\n /** @type {Array<PhrasingContent>} */\n let nodes = []\n\n find.lastIndex = 0\n\n let match = find.exec(node.value)\n\n while (match) {\n const position = match.index\n /** @type {RegExpMatchObject} */\n const matchObject = {\n index: match.index,\n input: match.input,\n stack: [...parents, node]\n }\n let value = replace(...match, matchObject)\n\n if (typeof value === 'string') {\n value = value.length > 0 ? {type: 'text', value} : undefined\n }\n\n // It wasn’t a match after all.\n if (value === false) {\n // False acts as if there was no match.\n // So we need to reset `lastIndex`, which currently being at the end of\n // the current match, to the beginning.\n find.lastIndex = position + 1\n } else {\n if (start !== position) {\n nodes.push({\n type: 'text',\n value: node.value.slice(start, position)\n })\n }\n\n if (Array.isArray(value)) {\n nodes.push(...value)\n } else if (value) {\n nodes.push(value)\n }\n\n start = position + match[0].length\n change = true\n }\n\n if (!find.global) {\n break\n }\n\n match = find.exec(node.value)\n }\n\n if (change) {\n if (start < node.value.length) {\n nodes.push({type: 'text', value: node.value.slice(start)})\n }\n\n parent.children.splice(index, 1, ...nodes)\n } else {\n nodes = [node]\n }\n\n return index + nodes.length\n }\n}\n\n/**\n * Turn a tuple or a list of tuples into pairs.\n *\n * @param {FindAndReplaceList | FindAndReplaceTuple} tupleOrList\n * Schema.\n * @returns {Pairs}\n * Clean pairs.\n */\nfunction toPairs(tupleOrList) {\n /** @type {Pairs} */\n const result = []\n\n if (!Array.isArray(tupleOrList)) {\n throw new TypeError('Expected find and replace tuple or list of tuples')\n }\n\n /** @type {FindAndReplaceList} */\n // @ts-expect-error: correct.\n const list =\n !tupleOrList[0] || Array.isArray(tupleOrList[0])\n ? tupleOrList\n : [tupleOrList]\n\n let index = -1\n\n while (++index < list.length) {\n const tuple = list[index]\n result.push([toExpression(tuple[0]), toFunction(tuple[1])])\n }\n\n return result\n}\n\n/**\n * Turn a find into an expression.\n *\n * @param {Find} find\n * Find.\n * @returns {RegExp}\n * Expression.\n */\nfunction toExpression(find) {\n return typeof find === 'string' ? new RegExp(escape(find), 'g') : find\n}\n\n/**\n * Turn a replace into a function.\n *\n * @param {Replace} replace\n * Replace.\n * @returns {ReplaceFunction}\n * Function.\n */\nfunction toFunction(replace) {\n return typeof replace === 'function'\n ? replace\n : function () {\n return replace\n }\n}\n","/**\n * @import {RegExpMatchObject, ReplaceFunction} from 'mdast-util-find-and-replace'\n * @import {CompileContext, Extension as FromMarkdownExtension, Handle as FromMarkdownHandle, Transform as FromMarkdownTransform} from 'mdast-util-from-markdown'\n * @import {ConstructName, Options as ToMarkdownExtension} from 'mdast-util-to-markdown'\n * @import {Link, PhrasingContent} from 'mdast'\n */\n\nimport {ccount} from 'ccount'\nimport {ok as assert} from 'devlop'\nimport {unicodePunctuation, unicodeWhitespace} from 'micromark-util-character'\nimport {findAndReplace} from 'mdast-util-find-and-replace'\n\n/** @type {ConstructName} */\nconst inConstruct = 'phrasing'\n/** @type {Array<ConstructName>} */\nconst notInConstruct = ['autolink', 'link', 'image', 'label']\n\n/**\n * Create an extension for `mdast-util-from-markdown` to enable GFM autolink\n * literals in markdown.\n *\n * @returns {FromMarkdownExtension}\n * Extension for `mdast-util-to-markdown` to enable GFM autolink literals.\n */\nexport function gfmAutolinkLiteralFromMarkdown() {\n return {\n transforms: [transformGfmAutolinkLiterals],\n enter: {\n literalAutolink: enterLiteralAutolink,\n literalAutolinkEmail: enterLiteralAutolinkValue,\n literalAutolinkHttp: enterLiteralAutolinkValue,\n literalAutolinkWww: enterLiteralAutolinkValue\n },\n exit: {\n literalAutolink: exitLiteralAutolink,\n literalAutolinkEmail: exitLiteralAutolinkEmail,\n literalAutolinkHttp: exitLiteralAutolinkHttp,\n literalAutolinkWww: exitLiteralAutolinkWww\n }\n }\n}\n\n/**\n * Create an extension for `mdast-util-to-markdown` to enable GFM autolink\n * literals in markdown.\n *\n * @returns {ToMarkdownExtension}\n * Extension for `mdast-util-to-markdown` to enable GFM autolink literals.\n */\nexport function gfmAutolinkLiteralToMarkdown() {\n return {\n unsafe: [\n {\n character: '@',\n before: '[+\\\\-.\\\\w]',\n after: '[\\\\-.\\\\w]',\n inConstruct,\n notInConstruct\n },\n {\n character: '.',\n before: '[Ww]',\n after: '[\\\\-.\\\\w]',\n inConstruct,\n notInConstruct\n },\n {\n character: ':',\n before: '[ps]',\n after: '\\\\/',\n inConstruct,\n notInConstruct\n }\n ]\n }\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterLiteralAutolink(token) {\n this.enter({type: 'link', title: null, url: '', children: []}, token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterLiteralAutolinkValue(token) {\n this.config.enter.autolinkProtocol.call(this, token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitLiteralAutolinkHttp(token) {\n this.config.exit.autolinkProtocol.call(this, token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitLiteralAutolinkWww(token) {\n this.config.exit.data.call(this, token)\n const node = this.stack[this.stack.length - 1]\n assert(node.type === 'link')\n node.url = 'http://' + this.sliceSerialize(token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitLiteralAutolinkEmail(token) {\n this.config.exit.autolinkEmail.call(this, token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitLiteralAutolink(token) {\n this.exit(token)\n}\n\n/** @type {FromMarkdownTransform} */\nfunction transformGfmAutolinkLiterals(tree) {\n findAndReplace(\n tree,\n [\n [/(https?:\\/\\/|www(?=\\.))([-.\\w]+)([^ \\t\\r\\n]*)/gi, findUrl],\n [/(?<=^|\\s|\\p{P}|\\p{S})([-.\\w+]+)@([-\\w]+(?:\\.[-\\w]+)+)/gu, findEmail]\n ],\n {ignore: ['link', 'linkReference']}\n )\n}\n\n/**\n * @type {ReplaceFunction}\n * @param {string} _\n * @param {string} protocol\n * @param {string} domain\n * @param {string} path\n * @param {RegExpMatchObject} match\n * @returns {Array<PhrasingContent> | Link | false}\n */\n// eslint-disable-next-line max-params\nfunction findUrl(_, protocol, domain, path, match) {\n let prefix = ''\n\n // Not an expected previous character.\n if (!previous(match)) {\n return false\n }\n\n // Treat `www` as part of the domain.\n if (/^w/i.test(protocol)) {\n domain = protocol + domain\n protocol = ''\n prefix = 'http://'\n }\n\n if (!isCorrectDomain(domain)) {\n return false\n }\n\n const parts = splitUrl(domain + path)\n\n if (!parts[0]) return false\n\n /** @type {Link} */\n const result = {\n type: 'link',\n title: null,\n url: prefix + protocol + parts[0],\n children: [{type: 'text', value: protocol + parts[0]}]\n }\n\n if (parts[1]) {\n return [result, {type: 'text', value: parts[1]}]\n }\n\n return result\n}\n\n/**\n * @type {ReplaceFunction}\n * @param {string} _\n * @param {string} atext\n * @param {string} label\n * @param {RegExpMatchObject} match\n * @returns {Link | false}\n */\nfunction findEmail(_, atext, label, match) {\n if (\n // Not an expected previous character.\n !previous(match, true) ||\n // Label ends in not allowed character.\n /[-\\d_]$/.test(label)\n ) {\n return false\n }\n\n return {\n type: 'link',\n title: null,\n url: 'mailto:' + atext + '@' + label,\n children: [{type: 'text', value: atext + '@' + label}]\n }\n}\n\n/**\n * @param {string} domain\n * @returns {boolean}\n */\nfunction isCorrectDomain(domain) {\n const parts = domain.split('.')\n\n if (\n parts.length < 2 ||\n (parts[parts.length - 1] &&\n (/_/.test(parts[parts.length - 1]) ||\n !/[a-zA-Z\\d]/.test(parts[parts.length - 1]))) ||\n (parts[parts.length - 2] &&\n (/_/.test(parts[parts.length - 2]) ||\n !/[a-zA-Z\\d]/.test(parts[parts.length - 2])))\n ) {\n return false\n }\n\n return true\n}\n\n/**\n * @param {string} url\n * @returns {[string, string | undefined]}\n */\nfunction splitUrl(url) {\n const trailExec = /[!\"&'),.:;<>?\\]}]+$/.exec(url)\n\n if (!trailExec) {\n return [url, undefined]\n }\n\n url = url.slice(0, trailExec.index)\n\n let trail = trailExec[0]\n let closingParenIndex = trail.indexOf(')')\n const openingParens = ccount(url, '(')\n let closingParens = ccount(url, ')')\n\n while (closingParenIndex !== -1 && openingParens > closingParens) {\n url += trail.slice(0, closingParenIndex + 1)\n trail = trail.slice(closingParenIndex + 1)\n closingParenIndex = trail.indexOf(')')\n closingParens++\n }\n\n return [url, trail]\n}\n\n/**\n * @param {RegExpMatchObject} match\n * @param {boolean | null | undefined} [email=false]\n * @returns {boolean}\n */\nfunction previous(match, email) {\n const code = match.input.charCodeAt(match.index - 1)\n\n return (\n (match.index === 0 ||\n unicodeWhitespace(code) ||\n unicodePunctuation(code)) &&\n // If it’s an email, the previous character should not be a slash.\n (!email || code !== 47)\n )\n}\n","/**\n * @import {\n * CompileContext,\n * Extension as FromMarkdownExtension,\n * Handle as FromMarkdownHandle\n * } from 'mdast-util-from-markdown'\n * @import {ToMarkdownOptions} from 'mdast-util-gfm-footnote'\n * @import {\n * Handle as ToMarkdownHandle,\n * Map,\n * Options as ToMarkdownExtension\n * } from 'mdast-util-to-markdown'\n * @import {FootnoteDefinition, FootnoteReference} from 'mdast'\n */\n\nimport {ok as assert} from 'devlop'\nimport {normalizeIdentifier} from 'micromark-util-normalize-identifier'\n\nfootnoteReference.peek = footnoteReferencePeek\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterFootnoteCallString() {\n this.buffer()\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterFootnoteCall(token) {\n this.enter({type: 'footnoteReference', identifier: '', label: ''}, token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterFootnoteDefinitionLabelString() {\n this.buffer()\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterFootnoteDefinition(token) {\n this.enter(\n {type: 'footnoteDefinition', identifier: '', label: '', children: []},\n token\n )\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitFootnoteCallString(token) {\n const label = this.resume()\n const node = this.stack[this.stack.length - 1]\n assert(node.type === 'footnoteReference')\n node.identifier = normalizeIdentifier(\n this.sliceSerialize(token)\n ).toLowerCase()\n node.label = label\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitFootnoteCall(token) {\n this.exit(token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitFootnoteDefinitionLabelString(token) {\n const label = this.resume()\n const node = this.stack[this.stack.length - 1]\n assert(node.type === 'footnoteDefinition')\n node.identifier = normalizeIdentifier(\n this.sliceSerialize(token)\n ).toLowerCase()\n node.label = label\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitFootnoteDefinition(token) {\n this.exit(token)\n}\n\n/** @type {ToMarkdownHandle} */\nfunction footnoteReferencePeek() {\n return '['\n}\n\n/**\n * @type {ToMarkdownHandle}\n * @param {FootnoteReference} node\n */\nfunction footnoteReference(node, _, state, info) {\n const tracker = state.createTracker(info)\n let value = tracker.move('[^')\n const exit = state.enter('footnoteReference')\n const subexit = state.enter('reference')\n value += tracker.move(\n state.safe(state.associationId(node), {after: ']', before: value})\n )\n subexit()\n exit()\n value += tracker.move(']')\n return value\n}\n\n/**\n * Create an extension for `mdast-util-from-markdown` to enable GFM footnotes\n * in markdown.\n *\n * @returns {FromMarkdownExtension}\n * Extension for `mdast-util-from-markdown`.\n */\nexport function gfmFootnoteFromMarkdown() {\n return {\n enter: {\n gfmFootnoteCallString: enterFootnoteCallString,\n gfmFootnoteCall: enterFootnoteCall,\n gfmFootnoteDefinitionLabelString: enterFootnoteDefinitionLabelString,\n gfmFootnoteDefinition: enterFootnoteDefinition\n },\n exit: {\n gfmFootnoteCallString: exitFootnoteCallString,\n gfmFootnoteCall: exitFootnoteCall,\n gfmFootnoteDefinitionLabelString: exitFootnoteDefinitionLabelString,\n gfmFootnoteDefinition: exitFootnoteDefinition\n }\n }\n}\n\n/**\n * Create an extension for `mdast-util-to-markdown` to enable GFM footnotes\n * in markdown.\n *\n * @param {ToMarkdownOptions | null | undefined} [options]\n * Configuration (optional).\n * @returns {ToMarkdownExtension}\n * Extension for `mdast-util-to-markdown`.\n */\nexport function gfmFootnoteToMarkdown(options) {\n // To do: next major: change default.\n let firstLineBlank = false\n\n if (options && options.firstLineBlank) {\n firstLineBlank = true\n }\n\n return {\n handlers: {footnoteDefinition, footnoteReference},\n // This is on by default already.\n unsafe: [{character: '[', inConstruct: ['label', 'phrasing', 'reference']}]\n }\n\n /**\n * @type {ToMarkdownHandle}\n * @param {FootnoteDefinition} node\n */\n function footnoteDefinition(node, _, state, info) {\n const tracker = state.createTracker(info)\n let value = tracker.move('[^')\n const exit = state.enter('footnoteDefinition')\n const subexit = state.enter('label')\n value += tracker.move(\n state.safe(state.associationId(node), {before: value, after: ']'})\n )\n subexit()\n\n value += tracker.move(']:')\n\n if (node.children && node.children.length > 0) {\n tracker.shift(4)\n\n value += tracker.move(\n (firstLineBlank ? '\\n' : ' ') +\n state.indentLines(\n state.containerFlow(node, tracker.current()),\n firstLineBlank ? mapAll : mapExceptFirst\n )\n )\n }\n\n exit()\n\n return value\n }\n}\n\n/** @type {Map} */\nfunction mapExceptFirst(line, index, blank) {\n return index === 0 ? line : mapAll(line, index, blank)\n}\n\n/** @type {Map} */\nfunction mapAll(line, index, blank) {\n return (blank ? '' : ' ') + line\n}\n","/**\n * @typedef {import('mdast').Delete} Delete\n *\n * @typedef {import('mdast-util-from-markdown').CompileContext} CompileContext\n * @typedef {import('mdast-util-from-markdown').Extension} FromMarkdownExtension\n * @typedef {import('mdast-util-from-markdown').Handle} FromMarkdownHandle\n *\n * @typedef {import('mdast-util-to-markdown').ConstructName} ConstructName\n * @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle\n * @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension\n */\n\n/**\n * List of constructs that occur in phrasing (paragraphs, headings), but cannot\n * contain strikethrough.\n * So they sort of cancel each other out.\n * Note: could use a better name.\n *\n * Note: keep in sync with: <https://github.com/syntax-tree/mdast-util-to-markdown/blob/8ce8dbf/lib/unsafe.js#L14>\n *\n * @type {Array<ConstructName>}\n */\nconst constructsWithoutStrikethrough = [\n 'autolink',\n 'destinationLiteral',\n 'destinationRaw',\n 'reference',\n 'titleQuote',\n 'titleApostrophe'\n]\n\nhandleDelete.peek = peekDelete\n\n/**\n * Create an extension for `mdast-util-from-markdown` to enable GFM\n * strikethrough in markdown.\n *\n * @returns {FromMarkdownExtension}\n * Extension for `mdast-util-from-markdown` to enable GFM strikethrough.\n */\nexport function gfmStrikethroughFromMarkdown() {\n return {\n canContainEols: ['delete'],\n enter: {strikethrough: enterStrikethrough},\n exit: {strikethrough: exitStrikethrough}\n }\n}\n\n/**\n * Create an extension for `mdast-util-to-markdown` to enable GFM\n * strikethrough in markdown.\n *\n * @returns {ToMarkdownExtension}\n * Extension for `mdast-util-to-markdown` to enable GFM strikethrough.\n */\nexport function gfmStrikethroughToMarkdown() {\n return {\n unsafe: [\n {\n character: '~',\n inConstruct: 'phrasing',\n notInConstruct: constructsWithoutStrikethrough\n }\n ],\n handlers: {delete: handleDelete}\n }\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterStrikethrough(token) {\n this.enter({type: 'delete', children: []}, token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitStrikethrough(token) {\n this.exit(token)\n}\n\n/**\n * @type {ToMarkdownHandle}\n * @param {Delete} node\n */\nfunction handleDelete(node, _, state, info) {\n const tracker = state.createTracker(info)\n const exit = state.enter('strikethrough')\n let value = tracker.move('~~')\n value += state.containerPhrasing(node, {\n ...tracker.current(),\n before: value,\n after: '~'\n })\n value += tracker.move('~~')\n exit()\n return value\n}\n\n/** @type {ToMarkdownHandle} */\nfunction peekDelete() {\n return '~'\n}\n","// To do: next major: remove.\n/**\n * @typedef {Options} MarkdownTableOptions\n * Configuration.\n */\n\n/**\n * @typedef Options\n * Configuration.\n * @property {boolean | null | undefined} [alignDelimiters=true]\n * Whether to align the delimiters (default: `true`);\n * they are aligned by default:\n *\n * ```markdown\n * | Alpha | B |\n * | ----- | ----- |\n * | C | Delta |\n * ```\n *\n * Pass `false` to make them staggered:\n *\n * ```markdown\n * | Alpha | B |\n * | - | - |\n * | C | Delta |\n * ```\n * @property {ReadonlyArray<string | null | undefined> | string | null | undefined} [align]\n * How to align columns (default: `''`);\n * one style for all columns or styles for their respective columns;\n * each style is either `'l'` (left), `'r'` (right), or `'c'` (center);\n * other values are treated as `''`, which doesn’t place the colon in the\n * alignment row but does align left;\n * *only the lowercased first character is used, so `Right` is fine.*\n * @property {boolean | null | undefined} [delimiterEnd=true]\n * Whether to end each row with the delimiter (default: `true`).\n *\n * > 👉 **Note**: please don’t use this: it could create fragile structures\n * > that aren’t understandable to some markdown parsers.\n *\n * When `true`, there are ending delimiters:\n *\n * ```markdown\n * | Alpha | B |\n * | ----- | ----- |\n * | C | Delta |\n * ```\n *\n * When `false`, there are no ending delimiters:\n *\n * ```markdown\n * | Alpha | B\n * | ----- | -----\n * | C | Delta\n * ```\n * @property {boolean | null | undefined} [delimiterStart=true]\n * Whether to begin each row with the delimiter (default: `true`).\n *\n * > 👉 **Note**: please don’t use this: it could create fragile structures\n * > that aren’t understandable to some markdown parsers.\n *\n * When `true`, there are starting delimiters:\n *\n * ```markdown\n * | Alpha | B |\n * | ----- | ----- |\n * | C | Delta |\n * ```\n *\n * When `false`, there are no starting delimiters:\n *\n * ```markdown\n * Alpha | B |\n * ----- | ----- |\n * C | Delta |\n * ```\n * @property {boolean | null | undefined} [padding=true]\n * Whether to add a space of padding between delimiters and cells\n * (default: `true`).\n *\n * When `true`, there is padding:\n *\n * ```markdown\n * | Alpha | B |\n * | ----- | ----- |\n * | C | Delta |\n * ```\n *\n * When `false`, there is no padding:\n *\n * ```markdown\n * |Alpha|B |\n * |-----|-----|\n * |C |Delta|\n * ```\n * @property {((value: string) => number) | null | undefined} [stringLength]\n * Function to detect the length of table cell content (optional);\n * this is used when aligning the delimiters (`|`) between table cells;\n * full-width characters and emoji mess up delimiter alignment when viewing\n * the markdown source;\n * to fix this, you can pass this function,\n * which receives the cell content and returns its “visible” size;\n * note that what is and isn’t visible depends on where the text is displayed.\n *\n * Without such a function, the following:\n *\n * ```js\n * markdownTable([\n * ['Alpha', 'Bravo'],\n * ['中文', 'Charlie'],\n * ['👩‍❤️‍👩', 'Delta']\n * ])\n * ```\n *\n * Yields:\n *\n * ```markdown\n * | Alpha | Bravo |\n * | - | - |\n * | 中文 | Charlie |\n * | 👩‍❤️‍👩 | Delta |\n * ```\n *\n * With [`string-width`](https://github.com/sindresorhus/string-width):\n *\n * ```js\n * import stringWidth from 'string-width'\n *\n * markdownTable(\n * [\n * ['Alpha', 'Bravo'],\n * ['中文', 'Charlie'],\n * ['👩‍❤️‍👩', 'Delta']\n * ],\n * {stringLength: stringWidth}\n * )\n * ```\n *\n * Yields:\n *\n * ```markdown\n * | Alpha | Bravo |\n * | ----- | ------- |\n * | 中文 | Charlie |\n * | 👩‍❤️‍👩 | Delta |\n * ```\n */\n\n/**\n * @param {string} value\n * Cell value.\n * @returns {number}\n * Cell size.\n */\nfunction defaultStringLength(value) {\n return value.length\n}\n\n/**\n * Generate a markdown\n * ([GFM](https://docs.github.com/en/github/writing-on-github/working-with-advanced-formatting/organizing-information-with-tables))\n * table.\n *\n * @param {ReadonlyArray<ReadonlyArray<string | null | undefined>>} table\n * Table data (matrix of strings).\n * @param {Readonly<Options> | null | undefined} [options]\n * Configuration (optional).\n * @returns {string}\n * Result.\n */\nexport function markdownTable(table, options) {\n const settings = options || {}\n // To do: next major: change to spread.\n const align = (settings.align || []).concat()\n const stringLength = settings.stringLength || defaultStringLength\n /** @type {Array<number>} Character codes as symbols for alignment per column. */\n const alignments = []\n /** @type {Array<Array<string>>} Cells per row. */\n const cellMatrix = []\n /** @type {Array<Array<number>>} Sizes of each cell per row. */\n const sizeMatrix = []\n /** @type {Array<number>} */\n const longestCellByColumn = []\n let mostCellsPerRow = 0\n let rowIndex = -1\n\n // This is a superfluous loop if we don’t align delimiters, but otherwise we’d\n // do superfluous work when aligning, so optimize for aligning.\n while (++rowIndex < table.length) {\n /** @type {Array<string>} */\n const row = []\n /** @type {Array<number>} */\n const sizes = []\n let columnIndex = -1\n\n if (table[rowIndex].length > mostCellsPerRow) {\n mostCellsPerRow = table[rowIndex].length\n }\n\n while (++columnIndex < table[rowIndex].length) {\n const cell = serialize(table[rowIndex][columnIndex])\n\n if (settings.alignDelimiters !== false) {\n const size = stringLength(cell)\n sizes[columnIndex] = size\n\n if (\n longestCellByColumn[columnIndex] === undefined ||\n size > longestCellByColumn[columnIndex]\n ) {\n longestCellByColumn[columnIndex] = size\n }\n }\n\n row.push(cell)\n }\n\n cellMatrix[rowIndex] = row\n sizeMatrix[rowIndex] = sizes\n }\n\n // Figure out which alignments to use.\n let columnIndex = -1\n\n if (typeof align === 'object' && 'length' in align) {\n while (++columnIndex < mostCellsPerRow) {\n alignments[columnIndex] = toAlignment(align[columnIndex])\n }\n } else {\n const code = toAlignment(align)\n\n while (++columnIndex < mostCellsPerRow) {\n alignments[columnIndex] = code\n }\n }\n\n // Inject the alignment row.\n columnIndex = -1\n /** @type {Array<string>} */\n const row = []\n /** @type {Array<number>} */\n const sizes = []\n\n while (++columnIndex < mostCellsPerRow) {\n const code = alignments[columnIndex]\n let before = ''\n let after = ''\n\n if (code === 99 /* `c` */) {\n before = ':'\n after = ':'\n } else if (code === 108 /* `l` */) {\n before = ':'\n } else if (code === 114 /* `r` */) {\n after = ':'\n }\n\n // There *must* be at least one hyphen-minus in each alignment cell.\n let size =\n settings.alignDelimiters === false\n ? 1\n : Math.max(\n 1,\n longestCellByColumn[columnIndex] - before.length - after.length\n )\n\n const cell = before + '-'.repeat(size) + after\n\n if (settings.alignDelimiters !== false) {\n size = before.length + size + after.length\n\n if (size > longestCellByColumn[columnIndex]) {\n longestCellByColumn[columnIndex] = size\n }\n\n sizes[columnIndex] = size\n }\n\n row[columnIndex] = cell\n }\n\n // Inject the alignment row.\n cellMatrix.splice(1, 0, row)\n sizeMatrix.splice(1, 0, sizes)\n\n rowIndex = -1\n /** @type {Array<string>} */\n const lines = []\n\n while (++rowIndex < cellMatrix.length) {\n const row = cellMatrix[rowIndex]\n const sizes = sizeMatrix[rowIndex]\n columnIndex = -1\n /** @type {Array<string>} */\n const line = []\n\n while (++columnIndex < mostCellsPerRow) {\n const cell = row[columnIndex] || ''\n let before = ''\n let after = ''\n\n if (settings.alignDelimiters !== false) {\n const size =\n longestCellByColumn[columnIndex] - (sizes[columnIndex] || 0)\n const code = alignments[columnIndex]\n\n if (code === 114 /* `r` */) {\n before = ' '.repeat(size)\n } else if (code === 99 /* `c` */) {\n if (size % 2) {\n before = ' '.repeat(size / 2 + 0.5)\n after = ' '.repeat(size / 2 - 0.5)\n } else {\n before = ' '.repeat(size / 2)\n after = before\n }\n } else {\n after = ' '.repeat(size)\n }\n }\n\n if (settings.delimiterStart !== false && !columnIndex) {\n line.push('|')\n }\n\n if (\n settings.padding !== false &&\n // Don’t add the opening space if we’re not aligning and the cell is\n // empty: there will be a closing space.\n !(settings.alignDelimiters === false && cell === '') &&\n (settings.delimiterStart !== false || columnIndex)\n ) {\n line.push(' ')\n }\n\n if (settings.alignDelimiters !== false) {\n line.push(before)\n }\n\n line.push(cell)\n\n if (settings.alignDelimiters !== false) {\n line.push(after)\n }\n\n if (settings.padding !== false) {\n line.push(' ')\n }\n\n if (\n settings.delimiterEnd !== false ||\n columnIndex !== mostCellsPerRow - 1\n ) {\n line.push('|')\n }\n }\n\n lines.push(\n settings.delimiterEnd === false\n ? line.join('').replace(/ +$/, '')\n : line.join('')\n )\n }\n\n return lines.join('\\n')\n}\n\n/**\n * @param {string | null | undefined} [value]\n * Value to serialize.\n * @returns {string}\n * Result.\n */\nfunction serialize(value) {\n return value === null || value === undefined ? '' : String(value)\n}\n\n/**\n * @param {string | null | undefined} value\n * Value.\n * @returns {number}\n * Alignment.\n */\nfunction toAlignment(value) {\n const code = typeof value === 'string' ? value.codePointAt(0) : 0\n\n return code === 67 /* `C` */ || code === 99 /* `c` */\n ? 99 /* `c` */\n : code === 76 /* `L` */ || code === 108 /* `l` */\n ? 108 /* `l` */\n : code === 82 /* `R` */ || code === 114 /* `r` */\n ? 114 /* `r` */\n : 0\n}\n","/**\n * @import {Blockquote, Parents} from 'mdast'\n * @import {Info, Map, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {Blockquote} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function blockquote(node, _, state, info) {\n const exit = state.enter('blockquote')\n const tracker = state.createTracker(info)\n tracker.move('> ')\n tracker.shift(2)\n const value = state.indentLines(\n state.containerFlow(node, tracker.current()),\n map\n )\n exit()\n return value\n}\n\n/** @type {Map} */\nfunction map(line, _, blank) {\n return '>' + (blank ? '' : ' ') + line\n}\n","/**\n * @import {ConstructName, Unsafe} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {Array<ConstructName>} stack\n * @param {Unsafe} pattern\n * @returns {boolean}\n */\nexport function patternInScope(stack, pattern) {\n return (\n listInScope(stack, pattern.inConstruct, true) &&\n !listInScope(stack, pattern.notInConstruct, false)\n )\n}\n\n/**\n * @param {Array<ConstructName>} stack\n * @param {Unsafe['inConstruct']} list\n * @param {boolean} none\n * @returns {boolean}\n */\nfunction listInScope(stack, list, none) {\n if (typeof list === 'string') {\n list = [list]\n }\n\n if (!list || list.length === 0) {\n return none\n }\n\n let index = -1\n\n while (++index < list.length) {\n if (stack.includes(list[index])) {\n return true\n }\n }\n\n return false\n}\n","/**\n * @import {Break, Parents} from 'mdast'\n * @import {Info, State} from 'mdast-util-to-markdown'\n */\n\nimport {patternInScope} from '../util/pattern-in-scope.js'\n\n/**\n * @param {Break} _\n * @param {Parents | undefined} _1\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function hardBreak(_, _1, state, info) {\n let index = -1\n\n while (++index < state.unsafe.length) {\n // If we can’t put eols in this construct (setext headings, tables), use a\n // space instead.\n if (\n state.unsafe[index].character === '\\n' &&\n patternInScope(state.stack, state.unsafe[index])\n ) {\n return /[ \\t]/.test(info.before) ? '' : ' '\n }\n }\n\n return '\\\\\\n'\n}\n","/**\n * Get the count of the longest repeating streak of `substring` in `value`.\n *\n * @param {string} value\n * Content to search in.\n * @param {string} substring\n * Substring to look for, typically one character.\n * @returns {number}\n * Count of most frequent adjacent `substring`s in `value`.\n */\nexport function longestStreak(value, substring) {\n const source = String(value)\n let index = source.indexOf(substring)\n let expected = index\n let count = 0\n let max = 0\n\n if (typeof substring !== 'string') {\n throw new TypeError('Expected substring')\n }\n\n while (index !== -1) {\n if (index === expected) {\n if (++count > max) {\n max = count\n }\n } else {\n count = 1\n }\n\n expected = index + substring.length\n index = source.indexOf(substring, expected)\n }\n\n return max\n}\n","/**\n * @import {State} from 'mdast-util-to-markdown'\n * @import {Code} from 'mdast'\n */\n\n/**\n * @param {Code} node\n * @param {State} state\n * @returns {boolean}\n */\nexport function formatCodeAsIndented(node, state) {\n return Boolean(\n state.options.fences === false &&\n node.value &&\n // If there’s no info…\n !node.lang &&\n // And there’s a non-whitespace character…\n /[^ \\r\\n]/.test(node.value) &&\n // And the value doesn’t start or end in a blank…\n !/^[\\t ]*(?:[\\r\\n]|$)|(?:^|[\\r\\n])[\\t ]*$/.test(node.value)\n )\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['fence'], null | undefined>}\n */\nexport function checkFence(state) {\n const marker = state.options.fence || '`'\n\n if (marker !== '`' && marker !== '~') {\n throw new Error(\n 'Cannot serialize code with `' +\n marker +\n '` for `options.fence`, expected `` ` `` or `~`'\n )\n }\n\n return marker\n}\n","/**\n * @import {Info, Map, State} from 'mdast-util-to-markdown'\n * @import {Code, Parents} from 'mdast'\n */\n\nimport {longestStreak} from 'longest-streak'\nimport {formatCodeAsIndented} from '../util/format-code-as-indented.js'\nimport {checkFence} from '../util/check-fence.js'\n\n/**\n * @param {Code} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function code(node, _, state, info) {\n const marker = checkFence(state)\n const raw = node.value || ''\n const suffix = marker === '`' ? 'GraveAccent' : 'Tilde'\n\n if (formatCodeAsIndented(node, state)) {\n const exit = state.enter('codeIndented')\n const value = state.indentLines(raw, map)\n exit()\n return value\n }\n\n const tracker = state.createTracker(info)\n const sequence = marker.repeat(Math.max(longestStreak(raw, marker) + 1, 3))\n const exit = state.enter('codeFenced')\n let value = tracker.move(sequence)\n\n if (node.lang) {\n const subexit = state.enter(`codeFencedLang${suffix}`)\n value += tracker.move(\n state.safe(node.lang, {\n before: value,\n after: ' ',\n encode: ['`'],\n ...tracker.current()\n })\n )\n subexit()\n }\n\n if (node.lang && node.meta) {\n const subexit = state.enter(`codeFencedMeta${suffix}`)\n value += tracker.move(' ')\n value += tracker.move(\n state.safe(node.meta, {\n before: value,\n after: '\\n',\n encode: ['`'],\n ...tracker.current()\n })\n )\n subexit()\n }\n\n value += tracker.move('\\n')\n\n if (raw) {\n value += tracker.move(raw + '\\n')\n }\n\n value += tracker.move(sequence)\n exit()\n return value\n}\n\n/** @type {Map} */\nfunction map(line, _, blank) {\n return (blank ? '' : ' ') + line\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['quote'], null | undefined>}\n */\nexport function checkQuote(state) {\n const marker = state.options.quote || '\"'\n\n if (marker !== '\"' && marker !== \"'\") {\n throw new Error(\n 'Cannot serialize title with `' +\n marker +\n '` for `options.quote`, expected `\"`, or `\\'`'\n )\n }\n\n return marker\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {Definition, Parents} from 'mdast'\n */\n\nimport {checkQuote} from '../util/check-quote.js'\n\n/**\n * @param {Definition} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function definition(node, _, state, info) {\n const quote = checkQuote(state)\n const suffix = quote === '\"' ? 'Quote' : 'Apostrophe'\n const exit = state.enter('definition')\n let subexit = state.enter('label')\n const tracker = state.createTracker(info)\n let value = tracker.move('[')\n value += tracker.move(\n state.safe(state.associationId(node), {\n before: value,\n after: ']',\n ...tracker.current()\n })\n )\n value += tracker.move(']: ')\n\n subexit()\n\n if (\n // If there’s no url, or…\n !node.url ||\n // If there are control characters or whitespace.\n /[\\0- \\u007F]/.test(node.url)\n ) {\n subexit = state.enter('destinationLiteral')\n value += tracker.move('<')\n value += tracker.move(\n state.safe(node.url, {before: value, after: '>', ...tracker.current()})\n )\n value += tracker.move('>')\n } else {\n // No whitespace, raw is prettier.\n subexit = state.enter('destinationRaw')\n value += tracker.move(\n state.safe(node.url, {\n before: value,\n after: node.title ? ' ' : '\\n',\n ...tracker.current()\n })\n )\n }\n\n subexit()\n\n if (node.title) {\n subexit = state.enter(`title${suffix}`)\n value += tracker.move(' ' + quote)\n value += tracker.move(\n state.safe(node.title, {\n before: value,\n after: quote,\n ...tracker.current()\n })\n )\n value += tracker.move(quote)\n subexit()\n }\n\n exit()\n\n return value\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['emphasis'], null | undefined>}\n */\nexport function checkEmphasis(state) {\n const marker = state.options.emphasis || '*'\n\n if (marker !== '*' && marker !== '_') {\n throw new Error(\n 'Cannot serialize emphasis with `' +\n marker +\n '` for `options.emphasis`, expected `*`, or `_`'\n )\n }\n\n return marker\n}\n","/**\n * Encode a code point as a character reference.\n *\n * @param {number} code\n * Code point to encode.\n * @returns {string}\n * Encoded character reference.\n */\nexport function encodeCharacterReference(code) {\n return '&#x' + code.toString(16).toUpperCase() + ';'\n}\n","/**\n * @import {EncodeSides} from '../types.js'\n */\n\nimport {classifyCharacter} from 'micromark-util-classify-character'\n\n/**\n * Check whether to encode (as a character reference) the characters\n * surrounding an attention run.\n *\n * Which characters are around an attention run influence whether it works or\n * not.\n *\n * See <https://github.com/orgs/syntax-tree/discussions/60> for more info.\n * See this markdown in a particular renderer to see what works:\n *\n * ```markdown\n * | | A (letter inside) | B (punctuation inside) | C (whitespace inside) | D (nothing inside) |\n * | ----------------------- | ----------------- | ---------------------- | --------------------- | ------------------ |\n * | 1 (letter outside) | x*y*z | x*.*z | x* *z | x**z |\n * | 2 (punctuation outside) | .*y*. | .*.*. | .* *. | .**. |\n * | 3 (whitespace outside) | x *y* z | x *.* z | x * * z | x ** z |\n * | 4 (nothing outside) | *x* | *.* | * * | ** |\n * ```\n *\n * @param {number} outside\n * Code point on the outer side of the run.\n * @param {number} inside\n * Code point on the inner side of the run.\n * @param {'*' | '_'} marker\n * Marker of the run.\n * Underscores are handled more strictly (they form less often) than\n * asterisks.\n * @returns {EncodeSides}\n * Whether to encode characters.\n */\n// Important: punctuation must never be encoded.\n// Punctuation is solely used by markdown constructs.\n// And by encoding itself.\n// Encoding them will break constructs or double encode things.\nexport function encodeInfo(outside, inside, marker) {\n const outsideKind = classifyCharacter(outside)\n const insideKind = classifyCharacter(inside)\n\n // Letter outside:\n if (outsideKind === undefined) {\n return insideKind === undefined\n ? // Letter inside:\n // we have to encode *both* letters for `_` as it is looser.\n // it already forms for `*` (and GFMs `~`).\n marker === '_'\n ? {inside: true, outside: true}\n : {inside: false, outside: false}\n : insideKind === 1\n ? // Whitespace inside: encode both (letter, whitespace).\n {inside: true, outside: true}\n : // Punctuation inside: encode outer (letter)\n {inside: false, outside: true}\n }\n\n // Whitespace outside:\n if (outsideKind === 1) {\n return insideKind === undefined\n ? // Letter inside: already forms.\n {inside: false, outside: false}\n : insideKind === 1\n ? // Whitespace inside: encode both (whitespace).\n {inside: true, outside: true}\n : // Punctuation inside: already forms.\n {inside: false, outside: false}\n }\n\n // Punctuation outside:\n return insideKind === undefined\n ? // Letter inside: already forms.\n {inside: false, outside: false}\n : insideKind === 1\n ? // Whitespace inside: encode inner (whitespace).\n {inside: true, outside: false}\n : // Punctuation inside: already forms.\n {inside: false, outside: false}\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {Emphasis, Parents} from 'mdast'\n */\n\nimport {checkEmphasis} from '../util/check-emphasis.js'\nimport {encodeCharacterReference} from '../util/encode-character-reference.js'\nimport {encodeInfo} from '../util/encode-info.js'\n\nemphasis.peek = emphasisPeek\n\n/**\n * @param {Emphasis} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function emphasis(node, _, state, info) {\n const marker = checkEmphasis(state)\n const exit = state.enter('emphasis')\n const tracker = state.createTracker(info)\n const before = tracker.move(marker)\n\n let between = tracker.move(\n state.containerPhrasing(node, {\n after: marker,\n before,\n ...tracker.current()\n })\n )\n const betweenHead = between.charCodeAt(0)\n const open = encodeInfo(\n info.before.charCodeAt(info.before.length - 1),\n betweenHead,\n marker\n )\n\n if (open.inside) {\n between = encodeCharacterReference(betweenHead) + between.slice(1)\n }\n\n const betweenTail = between.charCodeAt(between.length - 1)\n const close = encodeInfo(info.after.charCodeAt(0), betweenTail, marker)\n\n if (close.inside) {\n between = between.slice(0, -1) + encodeCharacterReference(betweenTail)\n }\n\n const after = tracker.move(marker)\n\n exit()\n\n state.attentionEncodeSurroundingInfo = {\n after: close.outside,\n before: open.outside\n }\n return before + between + after\n}\n\n/**\n * @param {Emphasis} _\n * @param {Parents | undefined} _1\n * @param {State} state\n * @returns {string}\n */\nfunction emphasisPeek(_, _1, state) {\n return state.options.emphasis || '*'\n}\n","/**\n * @import {State} from 'mdast-util-to-markdown'\n * @import {Heading} from 'mdast'\n */\n\nimport {EXIT, visit} from 'unist-util-visit'\nimport {toString} from 'mdast-util-to-string'\n\n/**\n * @param {Heading} node\n * @param {State} state\n * @returns {boolean}\n */\nexport function formatHeadingAsSetext(node, state) {\n let literalWithBreak = false\n\n // Look for literals with a line break.\n // Note that this also\n visit(node, function (node) {\n if (\n ('value' in node && /\\r?\\n|\\r/.test(node.value)) ||\n node.type === 'break'\n ) {\n literalWithBreak = true\n return EXIT\n }\n })\n\n return Boolean(\n (!node.depth || node.depth < 3) &&\n toString(node) &&\n (state.options.setext || literalWithBreak)\n )\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {Heading, Parents} from 'mdast'\n */\n\nimport {encodeCharacterReference} from '../util/encode-character-reference.js'\nimport {formatHeadingAsSetext} from '../util/format-heading-as-setext.js'\n\n/**\n * @param {Heading} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function heading(node, _, state, info) {\n const rank = Math.max(Math.min(6, node.depth || 1), 1)\n const tracker = state.createTracker(info)\n\n if (formatHeadingAsSetext(node, state)) {\n const exit = state.enter('headingSetext')\n const subexit = state.enter('phrasing')\n const value = state.containerPhrasing(node, {\n ...tracker.current(),\n before: '\\n',\n after: '\\n'\n })\n subexit()\n exit()\n\n return (\n value +\n '\\n' +\n (rank === 1 ? '=' : '-').repeat(\n // The whole size…\n value.length -\n // Minus the position of the character after the last EOL (or\n // 0 if there is none)…\n (Math.max(value.lastIndexOf('\\r'), value.lastIndexOf('\\n')) + 1)\n )\n )\n }\n\n const sequence = '#'.repeat(rank)\n const exit = state.enter('headingAtx')\n const subexit = state.enter('phrasing')\n\n // Note: for proper tracking, we should reset the output positions when there\n // is no content returned, because then the space is not output.\n // Practically, in that case, there is no content, so it doesn’t matter that\n // we’ve tracked one too many characters.\n tracker.move(sequence + ' ')\n\n let value = state.containerPhrasing(node, {\n before: '# ',\n after: '\\n',\n ...tracker.current()\n })\n\n if (/^[\\t ]/.test(value)) {\n // To do: what effect has the character reference on tracking?\n value = encodeCharacterReference(value.charCodeAt(0)) + value.slice(1)\n }\n\n value = value ? sequence + ' ' + value : sequence\n\n if (state.options.closeAtx) {\n value += ' ' + sequence\n }\n\n subexit()\n exit()\n\n return value\n}\n","/**\n * @import {Html} from 'mdast'\n */\n\nhtml.peek = htmlPeek\n\n/**\n * @param {Html} node\n * @returns {string}\n */\nexport function html(node) {\n return node.value || ''\n}\n\n/**\n * @returns {string}\n */\nfunction htmlPeek() {\n return '<'\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {Image, Parents} from 'mdast'\n */\n\nimport {checkQuote} from '../util/check-quote.js'\n\nimage.peek = imagePeek\n\n/**\n * @param {Image} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function image(node, _, state, info) {\n const quote = checkQuote(state)\n const suffix = quote === '\"' ? 'Quote' : 'Apostrophe'\n const exit = state.enter('image')\n let subexit = state.enter('label')\n const tracker = state.createTracker(info)\n let value = tracker.move('![')\n value += tracker.move(\n state.safe(node.alt, {before: value, after: ']', ...tracker.current()})\n )\n value += tracker.move('](')\n\n subexit()\n\n if (\n // If there’s no url but there is a title…\n (!node.url && node.title) ||\n // If there are control characters or whitespace.\n /[\\0- \\u007F]/.test(node.url)\n ) {\n subexit = state.enter('destinationLiteral')\n value += tracker.move('<')\n value += tracker.move(\n state.safe(node.url, {before: value, after: '>', ...tracker.current()})\n )\n value += tracker.move('>')\n } else {\n // No whitespace, raw is prettier.\n subexit = state.enter('destinationRaw')\n value += tracker.move(\n state.safe(node.url, {\n before: value,\n after: node.title ? ' ' : ')',\n ...tracker.current()\n })\n )\n }\n\n subexit()\n\n if (node.title) {\n subexit = state.enter(`title${suffix}`)\n value += tracker.move(' ' + quote)\n value += tracker.move(\n state.safe(node.title, {\n before: value,\n after: quote,\n ...tracker.current()\n })\n )\n value += tracker.move(quote)\n subexit()\n }\n\n value += tracker.move(')')\n exit()\n\n return value\n}\n\n/**\n * @returns {string}\n */\nfunction imagePeek() {\n return '!'\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {ImageReference, Parents} from 'mdast'\n */\n\nimageReference.peek = imageReferencePeek\n\n/**\n * @param {ImageReference} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function imageReference(node, _, state, info) {\n const type = node.referenceType\n const exit = state.enter('imageReference')\n let subexit = state.enter('label')\n const tracker = state.createTracker(info)\n let value = tracker.move('![')\n const alt = state.safe(node.alt, {\n before: value,\n after: ']',\n ...tracker.current()\n })\n value += tracker.move(alt + '][')\n\n subexit()\n // Hide the fact that we’re in phrasing, because escapes don’t work.\n const stack = state.stack\n state.stack = []\n subexit = state.enter('reference')\n // Note: for proper tracking, we should reset the output positions when we end\n // up making a `shortcut` reference, because then there is no brace output.\n // Practically, in that case, there is no content, so it doesn’t matter that\n // we’ve tracked one too many characters.\n const reference = state.safe(state.associationId(node), {\n before: value,\n after: ']',\n ...tracker.current()\n })\n subexit()\n state.stack = stack\n exit()\n\n if (type === 'full' || !alt || alt !== reference) {\n value += tracker.move(reference + ']')\n } else if (type === 'shortcut') {\n // Remove the unwanted `[`.\n value = value.slice(0, -1)\n } else {\n value += tracker.move(']')\n }\n\n return value\n}\n\n/**\n * @returns {string}\n */\nfunction imageReferencePeek() {\n return '!'\n}\n","/**\n * @import {State} from 'mdast-util-to-markdown'\n * @import {InlineCode, Parents} from 'mdast'\n */\n\ninlineCode.peek = inlineCodePeek\n\n/**\n * @param {InlineCode} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @returns {string}\n */\nexport function inlineCode(node, _, state) {\n let value = node.value || ''\n let sequence = '`'\n let index = -1\n\n // If there is a single grave accent on its own in the code, use a fence of\n // two.\n // If there are two in a row, use one.\n while (new RegExp('(^|[^`])' + sequence + '([^`]|$)').test(value)) {\n sequence += '`'\n }\n\n // If this is not just spaces or eols (tabs don’t count), and either the\n // first or last character are a space, eol, or tick, then pad with spaces.\n if (\n /[^ \\r\\n]/.test(value) &&\n ((/^[ \\r\\n]/.test(value) && /[ \\r\\n]$/.test(value)) || /^`|`$/.test(value))\n ) {\n value = ' ' + value + ' '\n }\n\n // We have a potential problem: certain characters after eols could result in\n // blocks being seen.\n // For example, if someone injected the string `'\\n# b'`, then that would\n // result in an ATX heading.\n // We can’t escape characters in `inlineCode`, but because eols are\n // transformed to spaces when going from markdown to HTML anyway, we can swap\n // them out.\n while (++index < state.unsafe.length) {\n const pattern = state.unsafe[index]\n const expression = state.compilePattern(pattern)\n /** @type {RegExpExecArray | null} */\n let match\n\n // Only look for `atBreak`s.\n // Btw: note that `atBreak` patterns will always start the regex at LF or\n // CR.\n if (!pattern.atBreak) continue\n\n while ((match = expression.exec(value))) {\n let position = match.index\n\n // Support CRLF (patterns only look for one of the characters).\n if (\n value.charCodeAt(position) === 10 /* `\\n` */ &&\n value.charCodeAt(position - 1) === 13 /* `\\r` */\n ) {\n position--\n }\n\n value = value.slice(0, position) + ' ' + value.slice(match.index + 1)\n }\n }\n\n return sequence + value + sequence\n}\n\n/**\n * @returns {string}\n */\nfunction inlineCodePeek() {\n return '`'\n}\n","/**\n * @import {State} from 'mdast-util-to-markdown'\n * @import {Link} from 'mdast'\n */\n\nimport {toString} from 'mdast-util-to-string'\n\n/**\n * @param {Link} node\n * @param {State} state\n * @returns {boolean}\n */\nexport function formatLinkAsAutolink(node, state) {\n const raw = toString(node)\n\n return Boolean(\n !state.options.resourceLink &&\n // If there’s a url…\n node.url &&\n // And there’s a no title…\n !node.title &&\n // And the content of `node` is a single text node…\n node.children &&\n node.children.length === 1 &&\n node.children[0].type === 'text' &&\n // And if the url is the same as the content…\n (raw === node.url || 'mailto:' + raw === node.url) &&\n // And that starts w/ a protocol…\n /^[a-z][a-z+.-]+:/i.test(node.url) &&\n // And that doesn’t contain ASCII control codes (character escapes and\n // references don’t work), space, or angle brackets…\n !/[\\0- <>\\u007F]/.test(node.url)\n )\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {Link, Parents} from 'mdast'\n * @import {Exit} from '../types.js'\n */\n\nimport {checkQuote} from '../util/check-quote.js'\nimport {formatLinkAsAutolink} from '../util/format-link-as-autolink.js'\n\nlink.peek = linkPeek\n\n/**\n * @param {Link} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function link(node, _, state, info) {\n const quote = checkQuote(state)\n const suffix = quote === '\"' ? 'Quote' : 'Apostrophe'\n const tracker = state.createTracker(info)\n /** @type {Exit} */\n let exit\n /** @type {Exit} */\n let subexit\n\n if (formatLinkAsAutolink(node, state)) {\n // Hide the fact that we’re in phrasing, because escapes don’t work.\n const stack = state.stack\n state.stack = []\n exit = state.enter('autolink')\n let value = tracker.move('<')\n value += tracker.move(\n state.containerPhrasing(node, {\n before: value,\n after: '>',\n ...tracker.current()\n })\n )\n value += tracker.move('>')\n exit()\n state.stack = stack\n return value\n }\n\n exit = state.enter('link')\n subexit = state.enter('label')\n let value = tracker.move('[')\n value += tracker.move(\n state.containerPhrasing(node, {\n before: value,\n after: '](',\n ...tracker.current()\n })\n )\n value += tracker.move('](')\n subexit()\n\n if (\n // If there’s no url but there is a title…\n (!node.url && node.title) ||\n // If there are control characters or whitespace.\n /[\\0- \\u007F]/.test(node.url)\n ) {\n subexit = state.enter('destinationLiteral')\n value += tracker.move('<')\n value += tracker.move(\n state.safe(node.url, {before: value, after: '>', ...tracker.current()})\n )\n value += tracker.move('>')\n } else {\n // No whitespace, raw is prettier.\n subexit = state.enter('destinationRaw')\n value += tracker.move(\n state.safe(node.url, {\n before: value,\n after: node.title ? ' ' : ')',\n ...tracker.current()\n })\n )\n }\n\n subexit()\n\n if (node.title) {\n subexit = state.enter(`title${suffix}`)\n value += tracker.move(' ' + quote)\n value += tracker.move(\n state.safe(node.title, {\n before: value,\n after: quote,\n ...tracker.current()\n })\n )\n value += tracker.move(quote)\n subexit()\n }\n\n value += tracker.move(')')\n\n exit()\n return value\n}\n\n/**\n * @param {Link} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @returns {string}\n */\nfunction linkPeek(node, _, state) {\n return formatLinkAsAutolink(node, state) ? '<' : '['\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {LinkReference, Parents} from 'mdast'\n */\n\nlinkReference.peek = linkReferencePeek\n\n/**\n * @param {LinkReference} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function linkReference(node, _, state, info) {\n const type = node.referenceType\n const exit = state.enter('linkReference')\n let subexit = state.enter('label')\n const tracker = state.createTracker(info)\n let value = tracker.move('[')\n const text = state.containerPhrasing(node, {\n before: value,\n after: ']',\n ...tracker.current()\n })\n value += tracker.move(text + '][')\n\n subexit()\n // Hide the fact that we’re in phrasing, because escapes don’t work.\n const stack = state.stack\n state.stack = []\n subexit = state.enter('reference')\n // Note: for proper tracking, we should reset the output positions when we end\n // up making a `shortcut` reference, because then there is no brace output.\n // Practically, in that case, there is no content, so it doesn’t matter that\n // we’ve tracked one too many characters.\n const reference = state.safe(state.associationId(node), {\n before: value,\n after: ']',\n ...tracker.current()\n })\n subexit()\n state.stack = stack\n exit()\n\n if (type === 'full' || !text || text !== reference) {\n value += tracker.move(reference + ']')\n } else if (type === 'shortcut') {\n // Remove the unwanted `[`.\n value = value.slice(0, -1)\n } else {\n value += tracker.move(']')\n }\n\n return value\n}\n\n/**\n * @returns {string}\n */\nfunction linkReferencePeek() {\n return '['\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['bullet'], null | undefined>}\n */\nexport function checkBullet(state) {\n const marker = state.options.bullet || '*'\n\n if (marker !== '*' && marker !== '+' && marker !== '-') {\n throw new Error(\n 'Cannot serialize items with `' +\n marker +\n '` for `options.bullet`, expected `*`, `+`, or `-`'\n )\n }\n\n return marker\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\nimport {checkBullet} from './check-bullet.js'\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['bullet'], null | undefined>}\n */\nexport function checkBulletOther(state) {\n const bullet = checkBullet(state)\n const bulletOther = state.options.bulletOther\n\n if (!bulletOther) {\n return bullet === '*' ? '-' : '*'\n }\n\n if (bulletOther !== '*' && bulletOther !== '+' && bulletOther !== '-') {\n throw new Error(\n 'Cannot serialize items with `' +\n bulletOther +\n '` for `options.bulletOther`, expected `*`, `+`, or `-`'\n )\n }\n\n if (bulletOther === bullet) {\n throw new Error(\n 'Expected `bullet` (`' +\n bullet +\n '`) and `bulletOther` (`' +\n bulletOther +\n '`) to be different'\n )\n }\n\n return bulletOther\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['bulletOrdered'], null | undefined>}\n */\nexport function checkBulletOrdered(state) {\n const marker = state.options.bulletOrdered || '.'\n\n if (marker !== '.' && marker !== ')') {\n throw new Error(\n 'Cannot serialize items with `' +\n marker +\n '` for `options.bulletOrdered`, expected `.` or `)`'\n )\n }\n\n return marker\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['rule'], null | undefined>}\n */\nexport function checkRule(state) {\n const marker = state.options.rule || '*'\n\n if (marker !== '*' && marker !== '-' && marker !== '_') {\n throw new Error(\n 'Cannot serialize rules with `' +\n marker +\n '` for `options.rule`, expected `*`, `-`, or `_`'\n )\n }\n\n return marker\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {List, Parents} from 'mdast'\n */\n\nimport {checkBullet} from '../util/check-bullet.js'\nimport {checkBulletOther} from '../util/check-bullet-other.js'\nimport {checkBulletOrdered} from '../util/check-bullet-ordered.js'\nimport {checkRule} from '../util/check-rule.js'\n\n/**\n * @param {List} node\n * @param {Parents | undefined} parent\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function list(node, parent, state, info) {\n const exit = state.enter('list')\n const bulletCurrent = state.bulletCurrent\n /** @type {string} */\n let bullet = node.ordered ? checkBulletOrdered(state) : checkBullet(state)\n /** @type {string} */\n const bulletOther = node.ordered\n ? bullet === '.'\n ? ')'\n : '.'\n : checkBulletOther(state)\n let useDifferentMarker =\n parent && state.bulletLastUsed ? bullet === state.bulletLastUsed : false\n\n if (!node.ordered) {\n const firstListItem = node.children ? node.children[0] : undefined\n\n // If there’s an empty first list item directly in two list items,\n // we have to use a different bullet:\n //\n // ```markdown\n // * - *\n // ```\n //\n // …because otherwise it would become one big thematic break.\n if (\n // Bullet could be used as a thematic break marker:\n (bullet === '*' || bullet === '-') &&\n // Empty first list item:\n firstListItem &&\n (!firstListItem.children || !firstListItem.children[0]) &&\n // Directly in two other list items:\n state.stack[state.stack.length - 1] === 'list' &&\n state.stack[state.stack.length - 2] === 'listItem' &&\n state.stack[state.stack.length - 3] === 'list' &&\n state.stack[state.stack.length - 4] === 'listItem' &&\n // That are each the first child.\n state.indexStack[state.indexStack.length - 1] === 0 &&\n state.indexStack[state.indexStack.length - 2] === 0 &&\n state.indexStack[state.indexStack.length - 3] === 0\n ) {\n useDifferentMarker = true\n }\n\n // If there’s a thematic break at the start of the first list item,\n // we have to use a different bullet:\n //\n // ```markdown\n // * ---\n // ```\n //\n // …because otherwise it would become one big thematic break.\n if (checkRule(state) === bullet && firstListItem) {\n let index = -1\n\n while (++index < node.children.length) {\n const item = node.children[index]\n\n if (\n item &&\n item.type === 'listItem' &&\n item.children &&\n item.children[0] &&\n item.children[0].type === 'thematicBreak'\n ) {\n useDifferentMarker = true\n break\n }\n }\n }\n }\n\n if (useDifferentMarker) {\n bullet = bulletOther\n }\n\n state.bulletCurrent = bullet\n const value = state.containerFlow(node, info)\n state.bulletLastUsed = bullet\n state.bulletCurrent = bulletCurrent\n exit()\n return value\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['listItemIndent'], null | undefined>}\n */\nexport function checkListItemIndent(state) {\n const style = state.options.listItemIndent || 'one'\n\n if (style !== 'tab' && style !== 'one' && style !== 'mixed') {\n throw new Error(\n 'Cannot serialize items with `' +\n style +\n '` for `options.listItemIndent`, expected `tab`, `one`, or `mixed`'\n )\n }\n\n return style\n}\n","/**\n * @import {Info, Map, State} from 'mdast-util-to-markdown'\n * @import {ListItem, Parents} from 'mdast'\n */\n\nimport {checkBullet} from '../util/check-bullet.js'\nimport {checkListItemIndent} from '../util/check-list-item-indent.js'\n\n/**\n * @param {ListItem} node\n * @param {Parents | undefined} parent\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function listItem(node, parent, state, info) {\n const listItemIndent = checkListItemIndent(state)\n let bullet = state.bulletCurrent || checkBullet(state)\n\n // Add the marker value for ordered lists.\n if (parent && parent.type === 'list' && parent.ordered) {\n bullet =\n (typeof parent.start === 'number' && parent.start > -1\n ? parent.start\n : 1) +\n (state.options.incrementListMarker === false\n ? 0\n : parent.children.indexOf(node)) +\n bullet\n }\n\n let size = bullet.length + 1\n\n if (\n listItemIndent === 'tab' ||\n (listItemIndent === 'mixed' &&\n ((parent && parent.type === 'list' && parent.spread) || node.spread))\n ) {\n size = Math.ceil(size / 4) * 4\n }\n\n const tracker = state.createTracker(info)\n tracker.move(bullet + ' '.repeat(size - bullet.length))\n tracker.shift(size)\n const exit = state.enter('listItem')\n const value = state.indentLines(\n state.containerFlow(node, tracker.current()),\n map\n )\n exit()\n\n return value\n\n /** @type {Map} */\n function map(line, index, blank) {\n if (index) {\n return (blank ? '' : ' '.repeat(size)) + line\n }\n\n return (blank ? bullet : bullet + ' '.repeat(size - bullet.length)) + line\n }\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {Paragraph, Parents} from 'mdast'\n */\n\n/**\n * @param {Paragraph} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function paragraph(node, _, state, info) {\n const exit = state.enter('paragraph')\n const subexit = state.enter('phrasing')\n const value = state.containerPhrasing(node, info)\n subexit()\n exit()\n return value\n}\n","/**\n * @typedef {import('mdast').Html} Html\n * @typedef {import('mdast').PhrasingContent} PhrasingContent\n */\n\nimport {convert} from 'unist-util-is'\n\n/**\n * Check if the given value is *phrasing content*.\n *\n * > 👉 **Note**: Excludes `html`, which can be both phrasing or flow.\n *\n * @param node\n * Thing to check, typically `Node`.\n * @returns\n * Whether `value` is phrasing content.\n */\n\nexport const phrasing =\n /** @type {(node?: unknown) => node is Exclude<PhrasingContent, Html>} */\n (\n convert([\n 'break',\n 'delete',\n 'emphasis',\n // To do: next major: removed since footnotes were added to GFM.\n 'footnote',\n 'footnoteReference',\n 'image',\n 'imageReference',\n 'inlineCode',\n // Enabled by `mdast-util-math`:\n 'inlineMath',\n 'link',\n 'linkReference',\n // Enabled by `mdast-util-mdx`:\n 'mdxJsxTextElement',\n // Enabled by `mdast-util-mdx`:\n 'mdxTextExpression',\n 'strong',\n 'text',\n // Enabled by `mdast-util-directive`:\n 'textDirective'\n ])\n )\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {Parents, Root} from 'mdast'\n */\n\nimport {phrasing} from 'mdast-util-phrasing'\n\n/**\n * @param {Root} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function root(node, _, state, info) {\n // Note: `html` nodes are ambiguous.\n const hasPhrasing = node.children.some(function (d) {\n return phrasing(d)\n })\n\n const container = hasPhrasing ? state.containerPhrasing : state.containerFlow\n return container.call(state, node, info)\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['strong'], null | undefined>}\n */\nexport function checkStrong(state) {\n const marker = state.options.strong || '*'\n\n if (marker !== '*' && marker !== '_') {\n throw new Error(\n 'Cannot serialize strong with `' +\n marker +\n '` for `options.strong`, expected `*`, or `_`'\n )\n }\n\n return marker\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {Parents, Strong} from 'mdast'\n */\n\nimport {checkStrong} from '../util/check-strong.js'\nimport {encodeCharacterReference} from '../util/encode-character-reference.js'\nimport {encodeInfo} from '../util/encode-info.js'\n\nstrong.peek = strongPeek\n\n/**\n * @param {Strong} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function strong(node, _, state, info) {\n const marker = checkStrong(state)\n const exit = state.enter('strong')\n const tracker = state.createTracker(info)\n const before = tracker.move(marker + marker)\n\n let between = tracker.move(\n state.containerPhrasing(node, {\n after: marker,\n before,\n ...tracker.current()\n })\n )\n const betweenHead = between.charCodeAt(0)\n const open = encodeInfo(\n info.before.charCodeAt(info.before.length - 1),\n betweenHead,\n marker\n )\n\n if (open.inside) {\n between = encodeCharacterReference(betweenHead) + between.slice(1)\n }\n\n const betweenTail = between.charCodeAt(between.length - 1)\n const close = encodeInfo(info.after.charCodeAt(0), betweenTail, marker)\n\n if (close.inside) {\n between = between.slice(0, -1) + encodeCharacterReference(betweenTail)\n }\n\n const after = tracker.move(marker + marker)\n\n exit()\n\n state.attentionEncodeSurroundingInfo = {\n after: close.outside,\n before: open.outside\n }\n return before + between + after\n}\n\n/**\n * @param {Strong} _\n * @param {Parents | undefined} _1\n * @param {State} state\n * @returns {string}\n */\nfunction strongPeek(_, _1, state) {\n return state.options.strong || '*'\n}\n","/**\n * @import {Info, State} from 'mdast-util-to-markdown'\n * @import {Parents, Text} from 'mdast'\n */\n\n/**\n * @param {Text} node\n * @param {Parents | undefined} _\n * @param {State} state\n * @param {Info} info\n * @returns {string}\n */\nexport function text(node, _, state, info) {\n return state.safe(node.value, info)\n}\n","/**\n * @import {Options, State} from 'mdast-util-to-markdown'\n */\n\n/**\n * @param {State} state\n * @returns {Exclude<Options['ruleRepetition'], null | undefined>}\n */\nexport function checkRuleRepetition(state) {\n const repetition = state.options.ruleRepetition || 3\n\n if (repetition < 3) {\n throw new Error(\n 'Cannot serialize rules with repetition `' +\n repetition +\n '` for `options.ruleRepetition`, expected `3` or more'\n )\n }\n\n return repetition\n}\n","/**\n * @import {State} from 'mdast-util-to-markdown'\n * @import {Parents, ThematicBreak} from 'mdast'\n */\n\nimport {checkRuleRepetition} from '../util/check-rule-repetition.js'\nimport {checkRule} from '../util/check-rule.js'\n\n/**\n * @param {ThematicBreak} _\n * @param {Parents | undefined} _1\n * @param {State} state\n * @returns {string}\n */\nexport function thematicBreak(_, _1, state) {\n const value = (\n checkRule(state) + (state.options.ruleSpaces ? ' ' : '')\n ).repeat(checkRuleRepetition(state))\n\n return state.options.ruleSpaces ? value.slice(0, -1) : value\n}\n","import {blockquote} from './blockquote.js'\nimport {hardBreak} from './break.js'\nimport {code} from './code.js'\nimport {definition} from './definition.js'\nimport {emphasis} from './emphasis.js'\nimport {heading} from './heading.js'\nimport {html} from './html.js'\nimport {image} from './image.js'\nimport {imageReference} from './image-reference.js'\nimport {inlineCode} from './inline-code.js'\nimport {link} from './link.js'\nimport {linkReference} from './link-reference.js'\nimport {list} from './list.js'\nimport {listItem} from './list-item.js'\nimport {paragraph} from './paragraph.js'\nimport {root} from './root.js'\nimport {strong} from './strong.js'\nimport {text} from './text.js'\nimport {thematicBreak} from './thematic-break.js'\n\n/**\n * Default (CommonMark) handlers.\n */\nexport const handle = {\n blockquote,\n break: hardBreak,\n code,\n definition,\n emphasis,\n hardBreak,\n heading,\n html,\n image,\n imageReference,\n inlineCode,\n link,\n linkReference,\n list,\n listItem,\n paragraph,\n root,\n strong,\n text,\n thematicBreak\n}\n","/**\n * @typedef {import('mdast').InlineCode} InlineCode\n * @typedef {import('mdast').Table} Table\n * @typedef {import('mdast').TableCell} TableCell\n * @typedef {import('mdast').TableRow} TableRow\n *\n * @typedef {import('markdown-table').Options} MarkdownTableOptions\n *\n * @typedef {import('mdast-util-from-markdown').CompileContext} CompileContext\n * @typedef {import('mdast-util-from-markdown').Extension} FromMarkdownExtension\n * @typedef {import('mdast-util-from-markdown').Handle} FromMarkdownHandle\n *\n * @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension\n * @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle\n * @typedef {import('mdast-util-to-markdown').State} State\n * @typedef {import('mdast-util-to-markdown').Info} Info\n */\n\n/**\n * @typedef Options\n * Configuration.\n * @property {boolean | null | undefined} [tableCellPadding=true]\n * Whether to add a space of padding between delimiters and cells (default:\n * `true`).\n * @property {boolean | null | undefined} [tablePipeAlign=true]\n * Whether to align the delimiters (default: `true`).\n * @property {MarkdownTableOptions['stringLength'] | null | undefined} [stringLength]\n * Function to detect the length of table cell content, used when aligning\n * the delimiters between cells (optional).\n */\n\nimport {ok as assert} from 'devlop'\nimport {markdownTable} from 'markdown-table'\nimport {defaultHandlers} from 'mdast-util-to-markdown'\n\n/**\n * Create an extension for `mdast-util-from-markdown` to enable GFM tables in\n * markdown.\n *\n * @returns {FromMarkdownExtension}\n * Extension for `mdast-util-from-markdown` to enable GFM tables.\n */\nexport function gfmTableFromMarkdown() {\n return {\n enter: {\n table: enterTable,\n tableData: enterCell,\n tableHeader: enterCell,\n tableRow: enterRow\n },\n exit: {\n codeText: exitCodeText,\n table: exitTable,\n tableData: exit,\n tableHeader: exit,\n tableRow: exit\n }\n }\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterTable(token) {\n const align = token._align\n assert(align, 'expected `_align` on table')\n this.enter(\n {\n type: 'table',\n align: align.map(function (d) {\n return d === 'none' ? null : d\n }),\n children: []\n },\n token\n )\n this.data.inTable = true\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitTable(token) {\n this.exit(token)\n this.data.inTable = undefined\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterRow(token) {\n this.enter({type: 'tableRow', children: []}, token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exit(token) {\n this.exit(token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterCell(token) {\n this.enter({type: 'tableCell', children: []}, token)\n}\n\n// Overwrite the default code text data handler to unescape escaped pipes when\n// they are in tables.\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitCodeText(token) {\n let value = this.resume()\n\n if (this.data.inTable) {\n value = value.replace(/\\\\([\\\\|])/g, replace)\n }\n\n const node = this.stack[this.stack.length - 1]\n assert(node.type === 'inlineCode')\n node.value = value\n this.exit(token)\n}\n\n/**\n * @param {string} $0\n * @param {string} $1\n * @returns {string}\n */\nfunction replace($0, $1) {\n // Pipes work, backslashes don’t (but can’t escape pipes).\n return $1 === '|' ? $1 : $0\n}\n\n/**\n * Create an extension for `mdast-util-to-markdown` to enable GFM tables in\n * markdown.\n *\n * @param {Options | null | undefined} [options]\n * Configuration.\n * @returns {ToMarkdownExtension}\n * Extension for `mdast-util-to-markdown` to enable GFM tables.\n */\nexport function gfmTableToMarkdown(options) {\n const settings = options || {}\n const padding = settings.tableCellPadding\n const alignDelimiters = settings.tablePipeAlign\n const stringLength = settings.stringLength\n const around = padding ? ' ' : '|'\n\n return {\n unsafe: [\n {character: '\\r', inConstruct: 'tableCell'},\n {character: '\\n', inConstruct: 'tableCell'},\n // A pipe, when followed by a tab or space (padding), or a dash or colon\n // (unpadded delimiter row), could result in a table.\n {atBreak: true, character: '|', after: '[\\t :-]'},\n // A pipe in a cell must be encoded.\n {character: '|', inConstruct: 'tableCell'},\n // A colon must be followed by a dash, in which case it could start a\n // delimiter row.\n {atBreak: true, character: ':', after: '-'},\n // A delimiter row can also start with a dash, when followed by more\n // dashes, a colon, or a pipe.\n // This is a stricter version than the built in check for lists, thematic\n // breaks, and setex heading underlines though:\n // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/51a2038/lib/unsafe.js#L57>\n {atBreak: true, character: '-', after: '[:|-]'}\n ],\n handlers: {\n inlineCode: inlineCodeWithTable,\n table: handleTable,\n tableCell: handleTableCell,\n tableRow: handleTableRow\n }\n }\n\n /**\n * @type {ToMarkdownHandle}\n * @param {Table} node\n */\n function handleTable(node, _, state, info) {\n return serializeData(handleTableAsData(node, state, info), node.align)\n }\n\n /**\n * This function isn’t really used normally, because we handle rows at the\n * table level.\n * But, if someone passes in a table row, this ensures we make somewhat sense.\n *\n * @type {ToMarkdownHandle}\n * @param {TableRow} node\n */\n function handleTableRow(node, _, state, info) {\n const row = handleTableRowAsData(node, state, info)\n const value = serializeData([row])\n // `markdown-table` will always add an align row\n return value.slice(0, value.indexOf('\\n'))\n }\n\n /**\n * @type {ToMarkdownHandle}\n * @param {TableCell} node\n */\n function handleTableCell(node, _, state, info) {\n const exit = state.enter('tableCell')\n const subexit = state.enter('phrasing')\n const value = state.containerPhrasing(node, {\n ...info,\n before: around,\n after: around\n })\n subexit()\n exit()\n return value\n }\n\n /**\n * @param {Array<Array<string>>} matrix\n * @param {Array<string | null | undefined> | null | undefined} [align]\n */\n function serializeData(matrix, align) {\n return markdownTable(matrix, {\n align,\n // @ts-expect-error: `markdown-table` types should support `null`.\n alignDelimiters,\n // @ts-expect-error: `markdown-table` types should support `null`.\n padding,\n // @ts-expect-error: `markdown-table` types should support `null`.\n stringLength\n })\n }\n\n /**\n * @param {Table} node\n * @param {State} state\n * @param {Info} info\n */\n function handleTableAsData(node, state, info) {\n const children = node.children\n let index = -1\n /** @type {Array<Array<string>>} */\n const result = []\n const subexit = state.enter('table')\n\n while (++index < children.length) {\n result[index] = handleTableRowAsData(children[index], state, info)\n }\n\n subexit()\n\n return result\n }\n\n /**\n * @param {TableRow} node\n * @param {State} state\n * @param {Info} info\n */\n function handleTableRowAsData(node, state, info) {\n const children = node.children\n let index = -1\n /** @type {Array<string>} */\n const result = []\n const subexit = state.enter('tableRow')\n\n while (++index < children.length) {\n // Note: the positional info as used here is incorrect.\n // Making it correct would be impossible due to aligning cells?\n // And it would need copy/pasting `markdown-table` into this project.\n result[index] = handleTableCell(children[index], node, state, info)\n }\n\n subexit()\n\n return result\n }\n\n /**\n * @type {ToMarkdownHandle}\n * @param {InlineCode} node\n */\n function inlineCodeWithTable(node, parent, state) {\n let value = defaultHandlers.inlineCode(node, parent, state)\n\n if (state.stack.includes('tableCell')) {\n value = value.replace(/\\|/g, '\\\\$&')\n }\n\n return value\n }\n}\n","/**\n * @typedef {import('mdast').ListItem} ListItem\n * @typedef {import('mdast').Paragraph} Paragraph\n * @typedef {import('mdast-util-from-markdown').CompileContext} CompileContext\n * @typedef {import('mdast-util-from-markdown').Extension} FromMarkdownExtension\n * @typedef {import('mdast-util-from-markdown').Handle} FromMarkdownHandle\n * @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension\n * @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle\n */\n\nimport {ok as assert} from 'devlop'\nimport {defaultHandlers} from 'mdast-util-to-markdown'\n\n/**\n * Create an extension for `mdast-util-from-markdown` to enable GFM task\n * list items in markdown.\n *\n * @returns {FromMarkdownExtension}\n * Extension for `mdast-util-from-markdown` to enable GFM task list items.\n */\nexport function gfmTaskListItemFromMarkdown() {\n return {\n exit: {\n taskListCheckValueChecked: exitCheck,\n taskListCheckValueUnchecked: exitCheck,\n paragraph: exitParagraphWithTaskListItem\n }\n }\n}\n\n/**\n * Create an extension for `mdast-util-to-markdown` to enable GFM task list\n * items in markdown.\n *\n * @returns {ToMarkdownExtension}\n * Extension for `mdast-util-to-markdown` to enable GFM task list items.\n */\nexport function gfmTaskListItemToMarkdown() {\n return {\n unsafe: [{atBreak: true, character: '-', after: '[:|-]'}],\n handlers: {listItem: listItemWithTaskListItem}\n }\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitCheck(token) {\n // We’re always in a paragraph, in a list item.\n const node = this.stack[this.stack.length - 2]\n assert(node.type === 'listItem')\n node.checked = token.type === 'taskListCheckValueChecked'\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitParagraphWithTaskListItem(token) {\n const parent = this.stack[this.stack.length - 2]\n\n if (\n parent &&\n parent.type === 'listItem' &&\n typeof parent.checked === 'boolean'\n ) {\n const node = this.stack[this.stack.length - 1]\n assert(node.type === 'paragraph')\n const head = node.children[0]\n\n if (head && head.type === 'text') {\n const siblings = parent.children\n let index = -1\n /** @type {Paragraph | undefined} */\n let firstParaghraph\n\n while (++index < siblings.length) {\n const sibling = siblings[index]\n if (sibling.type === 'paragraph') {\n firstParaghraph = sibling\n break\n }\n }\n\n if (firstParaghraph === node) {\n // Must start with a space or a tab.\n head.value = head.value.slice(1)\n\n if (head.value.length === 0) {\n node.children.shift()\n } else if (\n node.position &&\n head.position &&\n typeof head.position.start.offset === 'number'\n ) {\n head.position.start.column++\n head.position.start.offset++\n node.position.start = Object.assign({}, head.position.start)\n }\n }\n }\n }\n\n this.exit(token)\n}\n\n/**\n * @type {ToMarkdownHandle}\n * @param {ListItem} node\n */\nfunction listItemWithTaskListItem(node, parent, state, info) {\n const head = node.children[0]\n const checkable =\n typeof node.checked === 'boolean' && head && head.type === 'paragraph'\n const checkbox = '[' + (node.checked ? 'x' : ' ') + '] '\n const tracker = state.createTracker(info)\n\n if (checkable) {\n tracker.move(checkbox)\n }\n\n let value = defaultHandlers.listItem(node, parent, state, {\n ...info,\n ...tracker.current()\n })\n\n if (checkable) {\n value = value.replace(/^(?:[*+-]|\\d+\\.)([\\r\\n]| {1,3})/, check)\n }\n\n return value\n\n /**\n * @param {string} $0\n * @returns {string}\n */\n function check($0) {\n return $0 + checkbox\n }\n}\n","/**\n * @import {Extension as FromMarkdownExtension} from 'mdast-util-from-markdown'\n * @import {Options} from 'mdast-util-gfm'\n * @import {Options as ToMarkdownExtension} from 'mdast-util-to-markdown'\n */\n\nimport {\n gfmAutolinkLiteralFromMarkdown,\n gfmAutolinkLiteralToMarkdown\n} from 'mdast-util-gfm-autolink-literal'\nimport {\n gfmFootnoteFromMarkdown,\n gfmFootnoteToMarkdown\n} from 'mdast-util-gfm-footnote'\nimport {\n gfmStrikethroughFromMarkdown,\n gfmStrikethroughToMarkdown\n} from 'mdast-util-gfm-strikethrough'\nimport {gfmTableFromMarkdown, gfmTableToMarkdown} from 'mdast-util-gfm-table'\nimport {\n gfmTaskListItemFromMarkdown,\n gfmTaskListItemToMarkdown\n} from 'mdast-util-gfm-task-list-item'\n\n/**\n * Create an extension for `mdast-util-from-markdown` to enable GFM (autolink\n * literals, footnotes, strikethrough, tables, tasklists).\n *\n * @returns {Array<FromMarkdownExtension>}\n * Extension for `mdast-util-from-markdown` to enable GFM (autolink literals,\n * footnotes, strikethrough, tables, tasklists).\n */\nexport function gfmFromMarkdown() {\n return [\n gfmAutolinkLiteralFromMarkdown(),\n gfmFootnoteFromMarkdown(),\n gfmStrikethroughFromMarkdown(),\n gfmTableFromMarkdown(),\n gfmTaskListItemFromMarkdown()\n ]\n}\n\n/**\n * Create an extension for `mdast-util-to-markdown` to enable GFM (autolink\n * literals, footnotes, strikethrough, tables, tasklists).\n *\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {ToMarkdownExtension}\n * Extension for `mdast-util-to-markdown` to enable GFM (autolink literals,\n * footnotes, strikethrough, tables, tasklists).\n */\nexport function gfmToMarkdown(options) {\n return {\n extensions: [\n gfmAutolinkLiteralToMarkdown(),\n gfmFootnoteToMarkdown(options),\n gfmStrikethroughToMarkdown(),\n gfmTableToMarkdown(options),\n gfmTaskListItemToMarkdown()\n ]\n }\n}\n","/**\n * @import {Code, ConstructRecord, Event, Extension, Previous, State, TokenizeContext, Tokenizer} from 'micromark-util-types'\n */\n\nimport { asciiAlpha, asciiAlphanumeric, asciiControl, markdownLineEndingOrSpace, unicodePunctuation, unicodeWhitespace } from 'micromark-util-character';\nconst wwwPrefix = {\n tokenize: tokenizeWwwPrefix,\n partial: true\n};\nconst domain = {\n tokenize: tokenizeDomain,\n partial: true\n};\nconst path = {\n tokenize: tokenizePath,\n partial: true\n};\nconst trail = {\n tokenize: tokenizeTrail,\n partial: true\n};\nconst emailDomainDotTrail = {\n tokenize: tokenizeEmailDomainDotTrail,\n partial: true\n};\nconst wwwAutolink = {\n name: 'wwwAutolink',\n tokenize: tokenizeWwwAutolink,\n previous: previousWww\n};\nconst protocolAutolink = {\n name: 'protocolAutolink',\n tokenize: tokenizeProtocolAutolink,\n previous: previousProtocol\n};\nconst emailAutolink = {\n name: 'emailAutolink',\n tokenize: tokenizeEmailAutolink,\n previous: previousEmail\n};\n\n/** @type {ConstructRecord} */\nconst text = {};\n\n/**\n * Create an extension for `micromark` to support GitHub autolink literal\n * syntax.\n *\n * @returns {Extension}\n * Extension for `micromark` that can be passed in `extensions` to enable GFM\n * autolink literal syntax.\n */\nexport function gfmAutolinkLiteral() {\n return {\n text\n };\n}\n\n/** @type {Code} */\nlet code = 48;\n\n// Add alphanumerics.\nwhile (code < 123) {\n text[code] = emailAutolink;\n code++;\n if (code === 58) code = 65;else if (code === 91) code = 97;\n}\ntext[43] = emailAutolink;\ntext[45] = emailAutolink;\ntext[46] = emailAutolink;\ntext[95] = emailAutolink;\ntext[72] = [emailAutolink, protocolAutolink];\ntext[104] = [emailAutolink, protocolAutolink];\ntext[87] = [emailAutolink, wwwAutolink];\ntext[119] = [emailAutolink, wwwAutolink];\n\n// To do: perform email autolink literals on events, afterwards.\n// That’s where `markdown-rs` and `cmark-gfm` perform it.\n// It should look for `@`, then for atext backwards, and then for a label\n// forwards.\n// To do: `mailto:`, `xmpp:` protocol as prefix.\n\n/**\n * Email autolink literal.\n *\n * ```markdown\n * > | a contact@example.org b\n * ^^^^^^^^^^^^^^^^^^^\n * ```\n *\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeEmailAutolink(effects, ok, nok) {\n const self = this;\n /** @type {boolean | undefined} */\n let dot;\n /** @type {boolean} */\n let data;\n return start;\n\n /**\n * Start of email autolink literal.\n *\n * ```markdown\n * > | a contact@example.org b\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n if (!gfmAtext(code) || !previousEmail.call(self, self.previous) || previousUnbalanced(self.events)) {\n return nok(code);\n }\n effects.enter('literalAutolink');\n effects.enter('literalAutolinkEmail');\n return atext(code);\n }\n\n /**\n * In email atext.\n *\n * ```markdown\n * > | a contact@example.org b\n * ^\n * ```\n *\n * @type {State}\n */\n function atext(code) {\n if (gfmAtext(code)) {\n effects.consume(code);\n return atext;\n }\n if (code === 64) {\n effects.consume(code);\n return emailDomain;\n }\n return nok(code);\n }\n\n /**\n * In email domain.\n *\n * The reference code is a bit overly complex as it handles the `@`, of which\n * there may be just one.\n * Source: <https://github.com/github/cmark-gfm/blob/ef1cfcb/extensions/autolink.c#L318>\n *\n * ```markdown\n * > | a contact@example.org b\n * ^\n * ```\n *\n * @type {State}\n */\n function emailDomain(code) {\n // Dot followed by alphanumerical (not `-` or `_`).\n if (code === 46) {\n return effects.check(emailDomainDotTrail, emailDomainAfter, emailDomainDot)(code);\n }\n\n // Alphanumerical, `-`, and `_`.\n if (code === 45 || code === 95 || asciiAlphanumeric(code)) {\n data = true;\n effects.consume(code);\n return emailDomain;\n }\n\n // To do: `/` if xmpp.\n\n // Note: normally we’d truncate trailing punctuation from the link.\n // However, email autolink literals cannot contain any of those markers,\n // except for `.`, but that can only occur if it isn’t trailing.\n // So we can ignore truncating!\n return emailDomainAfter(code);\n }\n\n /**\n * In email domain, on dot that is not a trail.\n *\n * ```markdown\n * > | a contact@example.org b\n * ^\n * ```\n *\n * @type {State}\n */\n function emailDomainDot(code) {\n effects.consume(code);\n dot = true;\n return emailDomain;\n }\n\n /**\n * After email domain.\n *\n * ```markdown\n * > | a contact@example.org b\n * ^\n * ```\n *\n * @type {State}\n */\n function emailDomainAfter(code) {\n // Domain must not be empty, must include a dot, and must end in alphabetical.\n // Source: <https://github.com/github/cmark-gfm/blob/ef1cfcb/extensions/autolink.c#L332>.\n if (data && dot && asciiAlpha(self.previous)) {\n effects.exit('literalAutolinkEmail');\n effects.exit('literalAutolink');\n return ok(code);\n }\n return nok(code);\n }\n}\n\n/**\n * `www` autolink literal.\n *\n * ```markdown\n * > | a www.example.org b\n * ^^^^^^^^^^^^^^^\n * ```\n *\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeWwwAutolink(effects, ok, nok) {\n const self = this;\n return wwwStart;\n\n /**\n * Start of www autolink literal.\n *\n * ```markdown\n * > | www.example.com/a?b#c\n * ^\n * ```\n *\n * @type {State}\n */\n function wwwStart(code) {\n if (code !== 87 && code !== 119 || !previousWww.call(self, self.previous) || previousUnbalanced(self.events)) {\n return nok(code);\n }\n effects.enter('literalAutolink');\n effects.enter('literalAutolinkWww');\n // Note: we *check*, so we can discard the `www.` we parsed.\n // If it worked, we consider it as a part of the domain.\n return effects.check(wwwPrefix, effects.attempt(domain, effects.attempt(path, wwwAfter), nok), nok)(code);\n }\n\n /**\n * After a www autolink literal.\n *\n * ```markdown\n * > | www.example.com/a?b#c\n * ^\n * ```\n *\n * @type {State}\n */\n function wwwAfter(code) {\n effects.exit('literalAutolinkWww');\n effects.exit('literalAutolink');\n return ok(code);\n }\n}\n\n/**\n * Protocol autolink literal.\n *\n * ```markdown\n * > | a https://example.org b\n * ^^^^^^^^^^^^^^^^^^^\n * ```\n *\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeProtocolAutolink(effects, ok, nok) {\n const self = this;\n let buffer = '';\n let seen = false;\n return protocolStart;\n\n /**\n * Start of protocol autolink literal.\n *\n * ```markdown\n * > | https://example.com/a?b#c\n * ^\n * ```\n *\n * @type {State}\n */\n function protocolStart(code) {\n if ((code === 72 || code === 104) && previousProtocol.call(self, self.previous) && !previousUnbalanced(self.events)) {\n effects.enter('literalAutolink');\n effects.enter('literalAutolinkHttp');\n buffer += String.fromCodePoint(code);\n effects.consume(code);\n return protocolPrefixInside;\n }\n return nok(code);\n }\n\n /**\n * In protocol.\n *\n * ```markdown\n * > | https://example.com/a?b#c\n * ^^^^^\n * ```\n *\n * @type {State}\n */\n function protocolPrefixInside(code) {\n // `5` is size of `https`\n if (asciiAlpha(code) && buffer.length < 5) {\n // @ts-expect-error: definitely number.\n buffer += String.fromCodePoint(code);\n effects.consume(code);\n return protocolPrefixInside;\n }\n if (code === 58) {\n const protocol = buffer.toLowerCase();\n if (protocol === 'http' || protocol === 'https') {\n effects.consume(code);\n return protocolSlashesInside;\n }\n }\n return nok(code);\n }\n\n /**\n * In slashes.\n *\n * ```markdown\n * > | https://example.com/a?b#c\n * ^^\n * ```\n *\n * @type {State}\n */\n function protocolSlashesInside(code) {\n if (code === 47) {\n effects.consume(code);\n if (seen) {\n return afterProtocol;\n }\n seen = true;\n return protocolSlashesInside;\n }\n return nok(code);\n }\n\n /**\n * After protocol, before domain.\n *\n * ```markdown\n * > | https://example.com/a?b#c\n * ^\n * ```\n *\n * @type {State}\n */\n function afterProtocol(code) {\n // To do: this is different from `markdown-rs`:\n // https://github.com/wooorm/markdown-rs/blob/b3a921c761309ae00a51fe348d8a43adbc54b518/src/construct/gfm_autolink_literal.rs#L172-L182\n return code === null || asciiControl(code) || markdownLineEndingOrSpace(code) || unicodeWhitespace(code) || unicodePunctuation(code) ? nok(code) : effects.attempt(domain, effects.attempt(path, protocolAfter), nok)(code);\n }\n\n /**\n * After a protocol autolink literal.\n *\n * ```markdown\n * > | https://example.com/a?b#c\n * ^\n * ```\n *\n * @type {State}\n */\n function protocolAfter(code) {\n effects.exit('literalAutolinkHttp');\n effects.exit('literalAutolink');\n return ok(code);\n }\n}\n\n/**\n * `www` prefix.\n *\n * ```markdown\n * > | a www.example.org b\n * ^^^^\n * ```\n *\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeWwwPrefix(effects, ok, nok) {\n let size = 0;\n return wwwPrefixInside;\n\n /**\n * In www prefix.\n *\n * ```markdown\n * > | www.example.com\n * ^^^^\n * ```\n *\n * @type {State}\n */\n function wwwPrefixInside(code) {\n if ((code === 87 || code === 119) && size < 3) {\n size++;\n effects.consume(code);\n return wwwPrefixInside;\n }\n if (code === 46 && size === 3) {\n effects.consume(code);\n return wwwPrefixAfter;\n }\n return nok(code);\n }\n\n /**\n * After www prefix.\n *\n * ```markdown\n * > | www.example.com\n * ^\n * ```\n *\n * @type {State}\n */\n function wwwPrefixAfter(code) {\n // If there is *anything*, we can link.\n return code === null ? nok(code) : ok(code);\n }\n}\n\n/**\n * Domain.\n *\n * ```markdown\n * > | a https://example.org b\n * ^^^^^^^^^^^\n * ```\n *\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeDomain(effects, ok, nok) {\n /** @type {boolean | undefined} */\n let underscoreInLastSegment;\n /** @type {boolean | undefined} */\n let underscoreInLastLastSegment;\n /** @type {boolean | undefined} */\n let seen;\n return domainInside;\n\n /**\n * In domain.\n *\n * ```markdown\n * > | https://example.com/a\n * ^^^^^^^^^^^\n * ```\n *\n * @type {State}\n */\n function domainInside(code) {\n // Check whether this marker, which is a trailing punctuation\n // marker, optionally followed by more trailing markers, and then\n // followed by an end.\n if (code === 46 || code === 95) {\n return effects.check(trail, domainAfter, domainAtPunctuation)(code);\n }\n\n // GH documents that only alphanumerics (other than `-`, `.`, and `_`) can\n // occur, which sounds like ASCII only, but they also support `www.點看.com`,\n // so that’s Unicode.\n // Instead of some new production for Unicode alphanumerics, markdown\n // already has that for Unicode punctuation and whitespace, so use those.\n // Source: <https://github.com/github/cmark-gfm/blob/ef1cfcb/extensions/autolink.c#L12>.\n if (code === null || markdownLineEndingOrSpace(code) || unicodeWhitespace(code) || code !== 45 && unicodePunctuation(code)) {\n return domainAfter(code);\n }\n seen = true;\n effects.consume(code);\n return domainInside;\n }\n\n /**\n * In domain, at potential trailing punctuation, that was not trailing.\n *\n * ```markdown\n * > | https://example.com\n * ^\n * ```\n *\n * @type {State}\n */\n function domainAtPunctuation(code) {\n // There is an underscore in the last segment of the domain\n if (code === 95) {\n underscoreInLastSegment = true;\n }\n // Otherwise, it’s a `.`: save the last segment underscore in the\n // penultimate segment slot.\n else {\n underscoreInLastLastSegment = underscoreInLastSegment;\n underscoreInLastSegment = undefined;\n }\n effects.consume(code);\n return domainInside;\n }\n\n /**\n * After domain.\n *\n * ```markdown\n * > | https://example.com/a\n * ^\n * ```\n *\n * @type {State} */\n function domainAfter(code) {\n // Note: that’s GH says a dot is needed, but it’s not true:\n // <https://github.com/github/cmark-gfm/issues/279>\n if (underscoreInLastLastSegment || underscoreInLastSegment || !seen) {\n return nok(code);\n }\n return ok(code);\n }\n}\n\n/**\n * Path.\n *\n * ```markdown\n * > | a https://example.org/stuff b\n * ^^^^^^\n * ```\n *\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizePath(effects, ok) {\n let sizeOpen = 0;\n let sizeClose = 0;\n return pathInside;\n\n /**\n * In path.\n *\n * ```markdown\n * > | https://example.com/a\n * ^^\n * ```\n *\n * @type {State}\n */\n function pathInside(code) {\n if (code === 40) {\n sizeOpen++;\n effects.consume(code);\n return pathInside;\n }\n\n // To do: `markdown-rs` also needs this.\n // If this is a paren, and there are less closings than openings,\n // we don’t check for a trail.\n if (code === 41 && sizeClose < sizeOpen) {\n return pathAtPunctuation(code);\n }\n\n // Check whether this trailing punctuation marker is optionally\n // followed by more trailing markers, and then followed\n // by an end.\n if (code === 33 || code === 34 || code === 38 || code === 39 || code === 41 || code === 42 || code === 44 || code === 46 || code === 58 || code === 59 || code === 60 || code === 63 || code === 93 || code === 95 || code === 126) {\n return effects.check(trail, ok, pathAtPunctuation)(code);\n }\n if (code === null || markdownLineEndingOrSpace(code) || unicodeWhitespace(code)) {\n return ok(code);\n }\n effects.consume(code);\n return pathInside;\n }\n\n /**\n * In path, at potential trailing punctuation, that was not trailing.\n *\n * ```markdown\n * > | https://example.com/a\"b\n * ^\n * ```\n *\n * @type {State}\n */\n function pathAtPunctuation(code) {\n // Count closing parens.\n if (code === 41) {\n sizeClose++;\n }\n effects.consume(code);\n return pathInside;\n }\n}\n\n/**\n * Trail.\n *\n * This calls `ok` if this *is* the trail, followed by an end, which means\n * the entire trail is not part of the link.\n * It calls `nok` if this *is* part of the link.\n *\n * ```markdown\n * > | https://example.com\").\n * ^^^\n * ```\n *\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeTrail(effects, ok, nok) {\n return trail;\n\n /**\n * In trail of domain or path.\n *\n * ```markdown\n * > | https://example.com\").\n * ^\n * ```\n *\n * @type {State}\n */\n function trail(code) {\n // Regular trailing punctuation.\n if (code === 33 || code === 34 || code === 39 || code === 41 || code === 42 || code === 44 || code === 46 || code === 58 || code === 59 || code === 63 || code === 95 || code === 126) {\n effects.consume(code);\n return trail;\n }\n\n // `&` followed by one or more alphabeticals and then a `;`, is\n // as a whole considered as trailing punctuation.\n // In all other cases, it is considered as continuation of the URL.\n if (code === 38) {\n effects.consume(code);\n return trailCharacterReferenceStart;\n }\n\n // Needed because we allow literals after `[`, as we fix:\n // <https://github.com/github/cmark-gfm/issues/278>.\n // Check that it is not followed by `(` or `[`.\n if (code === 93) {\n effects.consume(code);\n return trailBracketAfter;\n }\n if (\n // `<` is an end.\n code === 60 ||\n // So is whitespace.\n code === null || markdownLineEndingOrSpace(code) || unicodeWhitespace(code)) {\n return ok(code);\n }\n return nok(code);\n }\n\n /**\n * In trail, after `]`.\n *\n * > 👉 **Note**: this deviates from `cmark-gfm` to fix a bug.\n * > See end of <https://github.com/github/cmark-gfm/issues/278> for more.\n *\n * ```markdown\n * > | https://example.com](\n * ^\n * ```\n *\n * @type {State}\n */\n function trailBracketAfter(code) {\n // Whitespace or something that could start a resource or reference is the end.\n // Switch back to trail otherwise.\n if (code === null || code === 40 || code === 91 || markdownLineEndingOrSpace(code) || unicodeWhitespace(code)) {\n return ok(code);\n }\n return trail(code);\n }\n\n /**\n * In character-reference like trail, after `&`.\n *\n * ```markdown\n * > | https://example.com&amp;).\n * ^\n * ```\n *\n * @type {State}\n */\n function trailCharacterReferenceStart(code) {\n // When non-alpha, it’s not a trail.\n return asciiAlpha(code) ? trailCharacterReferenceInside(code) : nok(code);\n }\n\n /**\n * In character-reference like trail.\n *\n * ```markdown\n * > | https://example.com&amp;).\n * ^\n * ```\n *\n * @type {State}\n */\n function trailCharacterReferenceInside(code) {\n // Switch back to trail if this is well-formed.\n if (code === 59) {\n effects.consume(code);\n return trail;\n }\n if (asciiAlpha(code)) {\n effects.consume(code);\n return trailCharacterReferenceInside;\n }\n\n // It’s not a trail.\n return nok(code);\n }\n}\n\n/**\n * Dot in email domain trail.\n *\n * This calls `ok` if this *is* the trail, followed by an end, which means\n * the trail is not part of the link.\n * It calls `nok` if this *is* part of the link.\n *\n * ```markdown\n * > | contact@example.org.\n * ^\n * ```\n *\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeEmailDomainDotTrail(effects, ok, nok) {\n return start;\n\n /**\n * Dot.\n *\n * ```markdown\n * > | contact@example.org.\n * ^ ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // Must be dot.\n effects.consume(code);\n return after;\n }\n\n /**\n * After dot.\n *\n * ```markdown\n * > | contact@example.org.\n * ^ ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // Not a trail if alphanumeric.\n return asciiAlphanumeric(code) ? nok(code) : ok(code);\n }\n}\n\n/**\n * See:\n * <https://github.com/github/cmark-gfm/blob/ef1cfcb/extensions/autolink.c#L156>.\n *\n * @type {Previous}\n */\nfunction previousWww(code) {\n return code === null || code === 40 || code === 42 || code === 95 || code === 91 || code === 93 || code === 126 || markdownLineEndingOrSpace(code);\n}\n\n/**\n * See:\n * <https://github.com/github/cmark-gfm/blob/ef1cfcb/extensions/autolink.c#L214>.\n *\n * @type {Previous}\n */\nfunction previousProtocol(code) {\n return !asciiAlpha(code);\n}\n\n/**\n * @this {TokenizeContext}\n * @type {Previous}\n */\nfunction previousEmail(code) {\n // Do not allow a slash “inside” atext.\n // The reference code is a bit weird, but that’s what it results in.\n // Source: <https://github.com/github/cmark-gfm/blob/ef1cfcb/extensions/autolink.c#L307>.\n // Other than slash, every preceding character is allowed.\n return !(code === 47 || gfmAtext(code));\n}\n\n/**\n * @param {Code} code\n * @returns {boolean}\n */\nfunction gfmAtext(code) {\n return code === 43 || code === 45 || code === 46 || code === 95 || asciiAlphanumeric(code);\n}\n\n/**\n * @param {Array<Event>} events\n * @returns {boolean}\n */\nfunction previousUnbalanced(events) {\n let index = events.length;\n let result = false;\n while (index--) {\n const token = events[index][1];\n if ((token.type === 'labelLink' || token.type === 'labelImage') && !token._balanced) {\n result = true;\n break;\n }\n\n // If we’ve seen this token, and it was marked as not having any unbalanced\n // bracket before it, we can exit.\n if (token._gfmAutolinkLiteralWalkedInto) {\n result = false;\n break;\n }\n }\n if (events.length > 0 && !result) {\n // Mark the last token as “walked into” w/o finding\n // anything.\n events[events.length - 1][1]._gfmAutolinkLiteralWalkedInto = true;\n }\n return result;\n}","/**\n * @import {Event, Exiter, Extension, Resolver, State, Token, TokenizeContext, Tokenizer} from 'micromark-util-types'\n */\n\nimport { blankLine } from 'micromark-core-commonmark';\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEndingOrSpace } from 'micromark-util-character';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\nconst indent = {\n tokenize: tokenizeIndent,\n partial: true\n};\n\n// To do: micromark should support a `_hiddenGfmFootnoteSupport`, which only\n// affects label start (image).\n// That will let us drop `tokenizePotentialGfmFootnote*`.\n// It currently has a `_hiddenFootnoteSupport`, which affects that and more.\n// That can be removed when `micromark-extension-footnote` is archived.\n\n/**\n * Create an extension for `micromark` to enable GFM footnote syntax.\n *\n * @returns {Extension}\n * Extension for `micromark` that can be passed in `extensions` to\n * enable GFM footnote syntax.\n */\nexport function gfmFootnote() {\n /** @type {Extension} */\n return {\n document: {\n [91]: {\n name: 'gfmFootnoteDefinition',\n tokenize: tokenizeDefinitionStart,\n continuation: {\n tokenize: tokenizeDefinitionContinuation\n },\n exit: gfmFootnoteDefinitionEnd\n }\n },\n text: {\n [91]: {\n name: 'gfmFootnoteCall',\n tokenize: tokenizeGfmFootnoteCall\n },\n [93]: {\n name: 'gfmPotentialFootnoteCall',\n add: 'after',\n tokenize: tokenizePotentialGfmFootnoteCall,\n resolveTo: resolveToPotentialGfmFootnoteCall\n }\n }\n };\n}\n\n// To do: remove after micromark update.\n/**\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizePotentialGfmFootnoteCall(effects, ok, nok) {\n const self = this;\n let index = self.events.length;\n const defined = self.parser.gfmFootnotes || (self.parser.gfmFootnotes = []);\n /** @type {Token} */\n let labelStart;\n\n // Find an opening.\n while (index--) {\n const token = self.events[index][1];\n if (token.type === \"labelImage\") {\n labelStart = token;\n break;\n }\n\n // Exit if we’ve walked far enough.\n if (token.type === 'gfmFootnoteCall' || token.type === \"labelLink\" || token.type === \"label\" || token.type === \"image\" || token.type === \"link\") {\n break;\n }\n }\n return start;\n\n /**\n * @type {State}\n */\n function start(code) {\n if (!labelStart || !labelStart._balanced) {\n return nok(code);\n }\n const id = normalizeIdentifier(self.sliceSerialize({\n start: labelStart.end,\n end: self.now()\n }));\n if (id.codePointAt(0) !== 94 || !defined.includes(id.slice(1))) {\n return nok(code);\n }\n effects.enter('gfmFootnoteCallLabelMarker');\n effects.consume(code);\n effects.exit('gfmFootnoteCallLabelMarker');\n return ok(code);\n }\n}\n\n// To do: remove after micromark update.\n/** @type {Resolver} */\nfunction resolveToPotentialGfmFootnoteCall(events, context) {\n let index = events.length;\n /** @type {Token | undefined} */\n let labelStart;\n\n // Find an opening.\n while (index--) {\n if (events[index][1].type === \"labelImage\" && events[index][0] === 'enter') {\n labelStart = events[index][1];\n break;\n }\n }\n // Change the `labelImageMarker` to a `data`.\n events[index + 1][1].type = \"data\";\n events[index + 3][1].type = 'gfmFootnoteCallLabelMarker';\n\n // The whole (without `!`):\n /** @type {Token} */\n const call = {\n type: 'gfmFootnoteCall',\n start: Object.assign({}, events[index + 3][1].start),\n end: Object.assign({}, events[events.length - 1][1].end)\n };\n // The `^` marker\n /** @type {Token} */\n const marker = {\n type: 'gfmFootnoteCallMarker',\n start: Object.assign({}, events[index + 3][1].end),\n end: Object.assign({}, events[index + 3][1].end)\n };\n // Increment the end 1 character.\n marker.end.column++;\n marker.end.offset++;\n marker.end._bufferIndex++;\n /** @type {Token} */\n const string = {\n type: 'gfmFootnoteCallString',\n start: Object.assign({}, marker.end),\n end: Object.assign({}, events[events.length - 1][1].start)\n };\n /** @type {Token} */\n const chunk = {\n type: \"chunkString\",\n contentType: 'string',\n start: Object.assign({}, string.start),\n end: Object.assign({}, string.end)\n };\n\n /** @type {Array<Event>} */\n const replacement = [\n // Take the `labelImageMarker` (now `data`, the `!`)\n events[index + 1], events[index + 2], ['enter', call, context],\n // The `[`\n events[index + 3], events[index + 4],\n // The `^`.\n ['enter', marker, context], ['exit', marker, context],\n // Everything in between.\n ['enter', string, context], ['enter', chunk, context], ['exit', chunk, context], ['exit', string, context],\n // The ending (`]`, properly parsed and labelled).\n events[events.length - 2], events[events.length - 1], ['exit', call, context]];\n events.splice(index, events.length - index + 1, ...replacement);\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeGfmFootnoteCall(effects, ok, nok) {\n const self = this;\n const defined = self.parser.gfmFootnotes || (self.parser.gfmFootnotes = []);\n let size = 0;\n /** @type {boolean} */\n let data;\n\n // Note: the implementation of `markdown-rs` is different, because it houses\n // core *and* extensions in one project.\n // Therefore, it can include footnote logic inside `label-end`.\n // We can’t do that, but luckily, we can parse footnotes in a simpler way than\n // needed for labels.\n return start;\n\n /**\n * Start of footnote label.\n *\n * ```markdown\n * > | a [^b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter('gfmFootnoteCall');\n effects.enter('gfmFootnoteCallLabelMarker');\n effects.consume(code);\n effects.exit('gfmFootnoteCallLabelMarker');\n return callStart;\n }\n\n /**\n * After `[`, at `^`.\n *\n * ```markdown\n * > | a [^b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function callStart(code) {\n if (code !== 94) return nok(code);\n effects.enter('gfmFootnoteCallMarker');\n effects.consume(code);\n effects.exit('gfmFootnoteCallMarker');\n effects.enter('gfmFootnoteCallString');\n effects.enter('chunkString').contentType = 'string';\n return callData;\n }\n\n /**\n * In label.\n *\n * ```markdown\n * > | a [^b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function callData(code) {\n if (\n // Too long.\n size > 999 ||\n // Closing brace with nothing.\n code === 93 && !data ||\n // Space or tab is not supported by GFM for some reason.\n // `\\n` and `[` not being supported makes sense.\n code === null || code === 91 || markdownLineEndingOrSpace(code)) {\n return nok(code);\n }\n if (code === 93) {\n effects.exit('chunkString');\n const token = effects.exit('gfmFootnoteCallString');\n if (!defined.includes(normalizeIdentifier(self.sliceSerialize(token)))) {\n return nok(code);\n }\n effects.enter('gfmFootnoteCallLabelMarker');\n effects.consume(code);\n effects.exit('gfmFootnoteCallLabelMarker');\n effects.exit('gfmFootnoteCall');\n return ok;\n }\n if (!markdownLineEndingOrSpace(code)) {\n data = true;\n }\n size++;\n effects.consume(code);\n return code === 92 ? callEscape : callData;\n }\n\n /**\n * On character after escape.\n *\n * ```markdown\n * > | a [^b\\c] d\n * ^\n * ```\n *\n * @type {State}\n */\n function callEscape(code) {\n if (code === 91 || code === 92 || code === 93) {\n effects.consume(code);\n size++;\n return callData;\n }\n return callData(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeDefinitionStart(effects, ok, nok) {\n const self = this;\n const defined = self.parser.gfmFootnotes || (self.parser.gfmFootnotes = []);\n /** @type {string} */\n let identifier;\n let size = 0;\n /** @type {boolean | undefined} */\n let data;\n return start;\n\n /**\n * Start of GFM footnote definition.\n *\n * ```markdown\n * > | [^a]: b\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter('gfmFootnoteDefinition')._container = true;\n effects.enter('gfmFootnoteDefinitionLabel');\n effects.enter('gfmFootnoteDefinitionLabelMarker');\n effects.consume(code);\n effects.exit('gfmFootnoteDefinitionLabelMarker');\n return labelAtMarker;\n }\n\n /**\n * In label, at caret.\n *\n * ```markdown\n * > | [^a]: b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelAtMarker(code) {\n if (code === 94) {\n effects.enter('gfmFootnoteDefinitionMarker');\n effects.consume(code);\n effects.exit('gfmFootnoteDefinitionMarker');\n effects.enter('gfmFootnoteDefinitionLabelString');\n effects.enter('chunkString').contentType = 'string';\n return labelInside;\n }\n return nok(code);\n }\n\n /**\n * In label.\n *\n * > 👉 **Note**: `cmark-gfm` prevents whitespace from occurring in footnote\n * > definition labels.\n *\n * ```markdown\n * > | [^a]: b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelInside(code) {\n if (\n // Too long.\n size > 999 ||\n // Closing brace with nothing.\n code === 93 && !data ||\n // Space or tab is not supported by GFM for some reason.\n // `\\n` and `[` not being supported makes sense.\n code === null || code === 91 || markdownLineEndingOrSpace(code)) {\n return nok(code);\n }\n if (code === 93) {\n effects.exit('chunkString');\n const token = effects.exit('gfmFootnoteDefinitionLabelString');\n identifier = normalizeIdentifier(self.sliceSerialize(token));\n effects.enter('gfmFootnoteDefinitionLabelMarker');\n effects.consume(code);\n effects.exit('gfmFootnoteDefinitionLabelMarker');\n effects.exit('gfmFootnoteDefinitionLabel');\n return labelAfter;\n }\n if (!markdownLineEndingOrSpace(code)) {\n data = true;\n }\n size++;\n effects.consume(code);\n return code === 92 ? labelEscape : labelInside;\n }\n\n /**\n * After `\\`, at a special character.\n *\n * > 👉 **Note**: `cmark-gfm` currently does not support escaped brackets:\n * > <https://github.com/github/cmark-gfm/issues/240>\n *\n * ```markdown\n * > | [^a\\*b]: c\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEscape(code) {\n if (code === 91 || code === 92 || code === 93) {\n effects.consume(code);\n size++;\n return labelInside;\n }\n return labelInside(code);\n }\n\n /**\n * After definition label.\n *\n * ```markdown\n * > | [^a]: b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelAfter(code) {\n if (code === 58) {\n effects.enter('definitionMarker');\n effects.consume(code);\n effects.exit('definitionMarker');\n if (!defined.includes(identifier)) {\n defined.push(identifier);\n }\n\n // Any whitespace after the marker is eaten, forming indented code\n // is not possible.\n // No space is also fine, just like a block quote marker.\n return factorySpace(effects, whitespaceAfter, 'gfmFootnoteDefinitionWhitespace');\n }\n return nok(code);\n }\n\n /**\n * After definition prefix.\n *\n * ```markdown\n * > | [^a]: b\n * ^\n * ```\n *\n * @type {State}\n */\n function whitespaceAfter(code) {\n // `markdown-rs` has a wrapping token for the prefix that is closed here.\n return ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeDefinitionContinuation(effects, ok, nok) {\n /// Start of footnote definition continuation.\n ///\n /// ```markdown\n /// | [^a]: b\n /// > | c\n /// ^\n /// ```\n //\n // Either a blank line, which is okay, or an indented thing.\n return effects.check(blankLine, ok, effects.attempt(indent, ok, nok));\n}\n\n/** @type {Exiter} */\nfunction gfmFootnoteDefinitionEnd(effects) {\n effects.exit('gfmFootnoteDefinition');\n}\n\n/**\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeIndent(effects, ok, nok) {\n const self = this;\n return factorySpace(effects, afterPrefix, 'gfmFootnoteDefinitionIndent', 4 + 1);\n\n /**\n * @type {State}\n */\n function afterPrefix(code) {\n const tail = self.events[self.events.length - 1];\n return tail && tail[1].type === 'gfmFootnoteDefinitionIndent' && tail[2].sliceSerialize(tail[1], true).length === 4 ? ok(code) : nok(code);\n }\n}","/**\n * @import {Options} from 'micromark-extension-gfm-strikethrough'\n * @import {Event, Extension, Resolver, State, Token, TokenizeContext, Tokenizer} from 'micromark-util-types'\n */\n\nimport { splice } from 'micromark-util-chunked';\nimport { classifyCharacter } from 'micromark-util-classify-character';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/**\n * Create an extension for `micromark` to enable GFM strikethrough syntax.\n *\n * @param {Options | null | undefined} [options={}]\n * Configuration.\n * @returns {Extension}\n * Extension for `micromark` that can be passed in `extensions`, to\n * enable GFM strikethrough syntax.\n */\nexport function gfmStrikethrough(options) {\n const options_ = options || {};\n let single = options_.singleTilde;\n const tokenizer = {\n name: 'strikethrough',\n tokenize: tokenizeStrikethrough,\n resolveAll: resolveAllStrikethrough\n };\n if (single === null || single === undefined) {\n single = true;\n }\n return {\n text: {\n [126]: tokenizer\n },\n insideSpan: {\n null: [tokenizer]\n },\n attentionMarkers: {\n null: [126]\n }\n };\n\n /**\n * Take events and resolve strikethrough.\n *\n * @type {Resolver}\n */\n function resolveAllStrikethrough(events, context) {\n let index = -1;\n\n // Walk through all events.\n while (++index < events.length) {\n // Find a token that can close.\n if (events[index][0] === 'enter' && events[index][1].type === 'strikethroughSequenceTemporary' && events[index][1]._close) {\n let open = index;\n\n // Now walk back to find an opener.\n while (open--) {\n // Find a token that can open the closer.\n if (events[open][0] === 'exit' && events[open][1].type === 'strikethroughSequenceTemporary' && events[open][1]._open &&\n // If the sizes are the same:\n events[index][1].end.offset - events[index][1].start.offset === events[open][1].end.offset - events[open][1].start.offset) {\n events[index][1].type = 'strikethroughSequence';\n events[open][1].type = 'strikethroughSequence';\n\n /** @type {Token} */\n const strikethrough = {\n type: 'strikethrough',\n start: Object.assign({}, events[open][1].start),\n end: Object.assign({}, events[index][1].end)\n };\n\n /** @type {Token} */\n const text = {\n type: 'strikethroughText',\n start: Object.assign({}, events[open][1].end),\n end: Object.assign({}, events[index][1].start)\n };\n\n // Opening.\n /** @type {Array<Event>} */\n const nextEvents = [['enter', strikethrough, context], ['enter', events[open][1], context], ['exit', events[open][1], context], ['enter', text, context]];\n const insideSpan = context.parser.constructs.insideSpan.null;\n if (insideSpan) {\n // Between.\n splice(nextEvents, nextEvents.length, 0, resolveAll(insideSpan, events.slice(open + 1, index), context));\n }\n\n // Closing.\n splice(nextEvents, nextEvents.length, 0, [['exit', text, context], ['enter', events[index][1], context], ['exit', events[index][1], context], ['exit', strikethrough, context]]);\n splice(events, open - 1, index - open + 3, nextEvents);\n index = open + nextEvents.length - 2;\n break;\n }\n }\n }\n }\n index = -1;\n while (++index < events.length) {\n if (events[index][1].type === 'strikethroughSequenceTemporary') {\n events[index][1].type = \"data\";\n }\n }\n return events;\n }\n\n /**\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\n function tokenizeStrikethrough(effects, ok, nok) {\n const previous = this.previous;\n const events = this.events;\n let size = 0;\n return start;\n\n /** @type {State} */\n function start(code) {\n if (previous === 126 && events[events.length - 1][1].type !== \"characterEscape\") {\n return nok(code);\n }\n effects.enter('strikethroughSequenceTemporary');\n return more(code);\n }\n\n /** @type {State} */\n function more(code) {\n const before = classifyCharacter(previous);\n if (code === 126) {\n // If this is the third marker, exit.\n if (size > 1) return nok(code);\n effects.consume(code);\n size++;\n return more;\n }\n if (size < 2 && !single) return nok(code);\n const token = effects.exit('strikethroughSequenceTemporary');\n const after = classifyCharacter(code);\n token._open = !after || after === 2 && Boolean(before);\n token._close = !before || before === 2 && Boolean(after);\n return ok(code);\n }\n }\n}","/**\n * @import {Event} from 'micromark-util-types'\n */\n\n// Port of `edit_map.rs` from `markdown-rs`.\n// This should move to `markdown-js` later.\n\n// Deal with several changes in events, batching them together.\n//\n// Preferably, changes should be kept to a minimum.\n// Sometimes, it’s needed to change the list of events, because parsing can be\n// messy, and it helps to expose a cleaner interface of events to the compiler\n// and other users.\n// It can also help to merge many adjacent similar events.\n// And, in other cases, it’s needed to parse subcontent: pass some events\n// through another tokenizer and inject the result.\n\n/**\n * @typedef {[number, number, Array<Event>]} Change\n * @typedef {[number, number, number]} Jump\n */\n\n/**\n * Tracks a bunch of edits.\n */\nexport class EditMap {\n /**\n * Create a new edit map.\n */\n constructor() {\n /**\n * Record of changes.\n *\n * @type {Array<Change>}\n */\n this.map = [];\n }\n\n /**\n * Create an edit: a remove and/or add at a certain place.\n *\n * @param {number} index\n * @param {number} remove\n * @param {Array<Event>} add\n * @returns {undefined}\n */\n add(index, remove, add) {\n addImplementation(this, index, remove, add);\n }\n\n // To do: add this when moving to `micromark`.\n // /**\n // * Create an edit: but insert `add` before existing additions.\n // *\n // * @param {number} index\n // * @param {number} remove\n // * @param {Array<Event>} add\n // * @returns {undefined}\n // */\n // addBefore(index, remove, add) {\n // addImplementation(this, index, remove, add, true)\n // }\n\n /**\n * Done, change the events.\n *\n * @param {Array<Event>} events\n * @returns {undefined}\n */\n consume(events) {\n this.map.sort(function (a, b) {\n return a[0] - b[0];\n });\n\n /* c8 ignore next 3 -- `resolve` is never called without tables, so without edits. */\n if (this.map.length === 0) {\n return;\n }\n\n // To do: if links are added in events, like they are in `markdown-rs`,\n // this is needed.\n // // Calculate jumps: where items in the current list move to.\n // /** @type {Array<Jump>} */\n // const jumps = []\n // let index = 0\n // let addAcc = 0\n // let removeAcc = 0\n // while (index < this.map.length) {\n // const [at, remove, add] = this.map[index]\n // removeAcc += remove\n // addAcc += add.length\n // jumps.push([at, removeAcc, addAcc])\n // index += 1\n // }\n //\n // . shiftLinks(events, jumps)\n\n let index = this.map.length;\n /** @type {Array<Array<Event>>} */\n const vecs = [];\n while (index > 0) {\n index -= 1;\n vecs.push(events.slice(this.map[index][0] + this.map[index][1]), this.map[index][2]);\n\n // Truncate rest.\n events.length = this.map[index][0];\n }\n vecs.push(events.slice());\n events.length = 0;\n let slice = vecs.pop();\n while (slice) {\n for (const element of slice) {\n events.push(element);\n }\n slice = vecs.pop();\n }\n\n // Truncate everything.\n this.map.length = 0;\n }\n}\n\n/**\n * Create an edit.\n *\n * @param {EditMap} editMap\n * @param {number} at\n * @param {number} remove\n * @param {Array<Event>} add\n * @returns {undefined}\n */\nfunction addImplementation(editMap, at, remove, add) {\n let index = 0;\n\n /* c8 ignore next 3 -- `resolve` is never called without tables, so without edits. */\n if (remove === 0 && add.length === 0) {\n return;\n }\n while (index < editMap.map.length) {\n if (editMap.map[index][0] === at) {\n editMap.map[index][1] += remove;\n\n // To do: before not used by tables, use when moving to micromark.\n // if (before) {\n // add.push(...editMap.map[index][2])\n // editMap.map[index][2] = add\n // } else {\n editMap.map[index][2].push(...add);\n // }\n\n return;\n }\n index += 1;\n }\n editMap.map.push([at, remove, add]);\n}\n\n// /**\n// * Shift `previous` and `next` links according to `jumps`.\n// *\n// * This fixes links in case there are events removed or added between them.\n// *\n// * @param {Array<Event>} events\n// * @param {Array<Jump>} jumps\n// */\n// function shiftLinks(events, jumps) {\n// let jumpIndex = 0\n// let index = 0\n// let add = 0\n// let rm = 0\n\n// while (index < events.length) {\n// const rmCurr = rm\n\n// while (jumpIndex < jumps.length && jumps[jumpIndex][0] <= index) {\n// add = jumps[jumpIndex][2]\n// rm = jumps[jumpIndex][1]\n// jumpIndex += 1\n// }\n\n// // Ignore items that will be removed.\n// if (rm > rmCurr) {\n// index += rm - rmCurr\n// } else {\n// // ?\n// // if let Some(link) = &events[index].link {\n// // if let Some(next) = link.next {\n// // events[next].link.as_mut().unwrap().previous = Some(index + add - rm);\n// // while jumpIndex < jumps.len() && jumps[jumpIndex].0 <= next {\n// // add = jumps[jumpIndex].2;\n// // rm = jumps[jumpIndex].1;\n// // jumpIndex += 1;\n// // }\n// // events[index].link.as_mut().unwrap().next = Some(next + add - rm);\n// // index = next;\n// // continue;\n// // }\n// // }\n// index += 1\n// }\n// }\n// }","/**\n * @import {Event} from 'micromark-util-types'\n */\n\n/**\n * @typedef {'center' | 'left' | 'none' | 'right'} Align\n */\n\n/**\n * Figure out the alignment of a GFM table.\n *\n * @param {Readonly<Array<Event>>} events\n * List of events.\n * @param {number} index\n * Table enter event.\n * @returns {Array<Align>}\n * List of aligns.\n */\nexport function gfmTableAlign(events, index) {\n let inDelimiterRow = false;\n /** @type {Array<Align>} */\n const align = [];\n while (index < events.length) {\n const event = events[index];\n if (inDelimiterRow) {\n if (event[0] === 'enter') {\n // Start of alignment value: set a new column.\n // To do: `markdown-rs` uses `tableDelimiterCellValue`.\n if (event[1].type === 'tableContent') {\n align.push(events[index + 1][1].type === 'tableDelimiterMarker' ? 'left' : 'none');\n }\n }\n // Exits:\n // End of alignment value: change the column.\n // To do: `markdown-rs` uses `tableDelimiterCellValue`.\n else if (event[1].type === 'tableContent') {\n if (events[index - 1][1].type === 'tableDelimiterMarker') {\n const alignIndex = align.length - 1;\n align[alignIndex] = align[alignIndex] === 'left' ? 'center' : 'right';\n }\n }\n // Done!\n else if (event[1].type === 'tableDelimiterRow') {\n break;\n }\n } else if (event[0] === 'enter' && event[1].type === 'tableDelimiterRow') {\n inDelimiterRow = true;\n }\n index += 1;\n }\n return align;\n}","/**\n * @import {Event, Extension, Point, Resolver, State, Token, TokenizeContext, Tokenizer} from 'micromark-util-types'\n */\n\n/**\n * @typedef {[number, number, number, number]} Range\n * Cell info.\n *\n * @typedef {0 | 1 | 2 | 3} RowKind\n * Where we are: `1` for head row, `2` for delimiter row, `3` for body row.\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownLineEndingOrSpace, markdownSpace } from 'micromark-util-character';\nimport { EditMap } from './edit-map.js';\nimport { gfmTableAlign } from './infer.js';\n\n/**\n * Create an HTML extension for `micromark` to support GitHub tables syntax.\n *\n * @returns {Extension}\n * Extension for `micromark` that can be passed in `extensions` to enable GFM\n * table syntax.\n */\nexport function gfmTable() {\n return {\n flow: {\n null: {\n name: 'table',\n tokenize: tokenizeTable,\n resolveAll: resolveTable\n }\n }\n };\n}\n\n/**\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeTable(effects, ok, nok) {\n const self = this;\n let size = 0;\n let sizeB = 0;\n /** @type {boolean | undefined} */\n let seen;\n return start;\n\n /**\n * Start of a GFM table.\n *\n * If there is a valid table row or table head before, then we try to parse\n * another row.\n * Otherwise, we try to parse a head.\n *\n * ```markdown\n * > | | a |\n * ^\n * | | - |\n * > | | b |\n * ^\n * ```\n * @type {State}\n */\n function start(code) {\n let index = self.events.length - 1;\n while (index > -1) {\n const type = self.events[index][1].type;\n if (type === \"lineEnding\" ||\n // Note: markdown-rs uses `whitespace` instead of `linePrefix`\n type === \"linePrefix\") index--;else break;\n }\n const tail = index > -1 ? self.events[index][1].type : null;\n const next = tail === 'tableHead' || tail === 'tableRow' ? bodyRowStart : headRowBefore;\n\n // Don’t allow lazy body rows.\n if (next === bodyRowStart && self.parser.lazy[self.now().line]) {\n return nok(code);\n }\n return next(code);\n }\n\n /**\n * Before table head row.\n *\n * ```markdown\n * > | | a |\n * ^\n * | | - |\n * | | b |\n * ```\n *\n * @type {State}\n */\n function headRowBefore(code) {\n effects.enter('tableHead');\n effects.enter('tableRow');\n return headRowStart(code);\n }\n\n /**\n * Before table head row, after whitespace.\n *\n * ```markdown\n * > | | a |\n * ^\n * | | - |\n * | | b |\n * ```\n *\n * @type {State}\n */\n function headRowStart(code) {\n if (code === 124) {\n return headRowBreak(code);\n }\n\n // To do: micromark-js should let us parse our own whitespace in extensions,\n // like `markdown-rs`:\n //\n // ```js\n // // 4+ spaces.\n // if (markdownSpace(code)) {\n // return nok(code)\n // }\n // ```\n\n seen = true;\n // Count the first character, that isn’t a pipe, double.\n sizeB += 1;\n return headRowBreak(code);\n }\n\n /**\n * At break in table head row.\n *\n * ```markdown\n * > | | a |\n * ^\n * ^\n * ^\n * | | - |\n * | | b |\n * ```\n *\n * @type {State}\n */\n function headRowBreak(code) {\n if (code === null) {\n // Note: in `markdown-rs`, we need to reset, in `micromark-js` we don‘t.\n return nok(code);\n }\n if (markdownLineEnding(code)) {\n // If anything other than one pipe (ignoring whitespace) was used, it’s fine.\n if (sizeB > 1) {\n sizeB = 0;\n // To do: check if this works.\n // Feel free to interrupt:\n self.interrupt = true;\n effects.exit('tableRow');\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return headDelimiterStart;\n }\n\n // Note: in `markdown-rs`, we need to reset, in `micromark-js` we don‘t.\n return nok(code);\n }\n if (markdownSpace(code)) {\n // To do: check if this is fine.\n // effects.attempt(State::Next(StateName::GfmTableHeadRowBreak), State::Nok)\n // State::Retry(space_or_tab(tokenizer))\n return factorySpace(effects, headRowBreak, \"whitespace\")(code);\n }\n sizeB += 1;\n if (seen) {\n seen = false;\n // Header cell count.\n size += 1;\n }\n if (code === 124) {\n effects.enter('tableCellDivider');\n effects.consume(code);\n effects.exit('tableCellDivider');\n // Whether a delimiter was seen.\n seen = true;\n return headRowBreak;\n }\n\n // Anything else is cell data.\n effects.enter(\"data\");\n return headRowData(code);\n }\n\n /**\n * In table head row data.\n *\n * ```markdown\n * > | | a |\n * ^\n * | | - |\n * | | b |\n * ```\n *\n * @type {State}\n */\n function headRowData(code) {\n if (code === null || code === 124 || markdownLineEndingOrSpace(code)) {\n effects.exit(\"data\");\n return headRowBreak(code);\n }\n effects.consume(code);\n return code === 92 ? headRowEscape : headRowData;\n }\n\n /**\n * In table head row escape.\n *\n * ```markdown\n * > | | a\\-b |\n * ^\n * | | ---- |\n * | | c |\n * ```\n *\n * @type {State}\n */\n function headRowEscape(code) {\n if (code === 92 || code === 124) {\n effects.consume(code);\n return headRowData;\n }\n return headRowData(code);\n }\n\n /**\n * Before delimiter row.\n *\n * ```markdown\n * | | a |\n * > | | - |\n * ^\n * | | b |\n * ```\n *\n * @type {State}\n */\n function headDelimiterStart(code) {\n // Reset `interrupt`.\n self.interrupt = false;\n\n // Note: in `markdown-rs`, we need to handle piercing here too.\n if (self.parser.lazy[self.now().line]) {\n return nok(code);\n }\n effects.enter('tableDelimiterRow');\n // Track if we’ve seen a `:` or `|`.\n seen = false;\n if (markdownSpace(code)) {\n return factorySpace(effects, headDelimiterBefore, \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code);\n }\n return headDelimiterBefore(code);\n }\n\n /**\n * Before delimiter row, after optional whitespace.\n *\n * Reused when a `|` is found later, to parse another cell.\n *\n * ```markdown\n * | | a |\n * > | | - |\n * ^\n * | | b |\n * ```\n *\n * @type {State}\n */\n function headDelimiterBefore(code) {\n if (code === 45 || code === 58) {\n return headDelimiterValueBefore(code);\n }\n if (code === 124) {\n seen = true;\n // If we start with a pipe, we open a cell marker.\n effects.enter('tableCellDivider');\n effects.consume(code);\n effects.exit('tableCellDivider');\n return headDelimiterCellBefore;\n }\n\n // More whitespace / empty row not allowed at start.\n return headDelimiterNok(code);\n }\n\n /**\n * After `|`, before delimiter cell.\n *\n * ```markdown\n * | | a |\n * > | | - |\n * ^\n * ```\n *\n * @type {State}\n */\n function headDelimiterCellBefore(code) {\n if (markdownSpace(code)) {\n return factorySpace(effects, headDelimiterValueBefore, \"whitespace\")(code);\n }\n return headDelimiterValueBefore(code);\n }\n\n /**\n * Before delimiter cell value.\n *\n * ```markdown\n * | | a |\n * > | | - |\n * ^\n * ```\n *\n * @type {State}\n */\n function headDelimiterValueBefore(code) {\n // Align: left.\n if (code === 58) {\n sizeB += 1;\n seen = true;\n effects.enter('tableDelimiterMarker');\n effects.consume(code);\n effects.exit('tableDelimiterMarker');\n return headDelimiterLeftAlignmentAfter;\n }\n\n // Align: none.\n if (code === 45) {\n sizeB += 1;\n // To do: seems weird that this *isn’t* left aligned, but that state is used?\n return headDelimiterLeftAlignmentAfter(code);\n }\n if (code === null || markdownLineEnding(code)) {\n return headDelimiterCellAfter(code);\n }\n return headDelimiterNok(code);\n }\n\n /**\n * After delimiter cell left alignment marker.\n *\n * ```markdown\n * | | a |\n * > | | :- |\n * ^\n * ```\n *\n * @type {State}\n */\n function headDelimiterLeftAlignmentAfter(code) {\n if (code === 45) {\n effects.enter('tableDelimiterFiller');\n return headDelimiterFiller(code);\n }\n\n // Anything else is not ok after the left-align colon.\n return headDelimiterNok(code);\n }\n\n /**\n * In delimiter cell filler.\n *\n * ```markdown\n * | | a |\n * > | | - |\n * ^\n * ```\n *\n * @type {State}\n */\n function headDelimiterFiller(code) {\n if (code === 45) {\n effects.consume(code);\n return headDelimiterFiller;\n }\n\n // Align is `center` if it was `left`, `right` otherwise.\n if (code === 58) {\n seen = true;\n effects.exit('tableDelimiterFiller');\n effects.enter('tableDelimiterMarker');\n effects.consume(code);\n effects.exit('tableDelimiterMarker');\n return headDelimiterRightAlignmentAfter;\n }\n effects.exit('tableDelimiterFiller');\n return headDelimiterRightAlignmentAfter(code);\n }\n\n /**\n * After delimiter cell right alignment marker.\n *\n * ```markdown\n * | | a |\n * > | | -: |\n * ^\n * ```\n *\n * @type {State}\n */\n function headDelimiterRightAlignmentAfter(code) {\n if (markdownSpace(code)) {\n return factorySpace(effects, headDelimiterCellAfter, \"whitespace\")(code);\n }\n return headDelimiterCellAfter(code);\n }\n\n /**\n * After delimiter cell.\n *\n * ```markdown\n * | | a |\n * > | | -: |\n * ^\n * ```\n *\n * @type {State}\n */\n function headDelimiterCellAfter(code) {\n if (code === 124) {\n return headDelimiterBefore(code);\n }\n if (code === null || markdownLineEnding(code)) {\n // Exit when:\n // * there was no `:` or `|` at all (it’s a thematic break or setext\n // underline instead)\n // * the header cell count is not the delimiter cell count\n if (!seen || size !== sizeB) {\n return headDelimiterNok(code);\n }\n\n // Note: in markdown-rs`, a reset is needed here.\n effects.exit('tableDelimiterRow');\n effects.exit('tableHead');\n // To do: in `markdown-rs`, resolvers need to be registered manually.\n // effects.register_resolver(ResolveName::GfmTable)\n return ok(code);\n }\n return headDelimiterNok(code);\n }\n\n /**\n * In delimiter row, at a disallowed byte.\n *\n * ```markdown\n * | | a |\n * > | | x |\n * ^\n * ```\n *\n * @type {State}\n */\n function headDelimiterNok(code) {\n // Note: in `markdown-rs`, we need to reset, in `micromark-js` we don‘t.\n return nok(code);\n }\n\n /**\n * Before table body row.\n *\n * ```markdown\n * | | a |\n * | | - |\n * > | | b |\n * ^\n * ```\n *\n * @type {State}\n */\n function bodyRowStart(code) {\n // Note: in `markdown-rs` we need to manually take care of a prefix,\n // but in `micromark-js` that is done for us, so if we’re here, we’re\n // never at whitespace.\n effects.enter('tableRow');\n return bodyRowBreak(code);\n }\n\n /**\n * At break in table body row.\n *\n * ```markdown\n * | | a |\n * | | - |\n * > | | b |\n * ^\n * ^\n * ^\n * ```\n *\n * @type {State}\n */\n function bodyRowBreak(code) {\n if (code === 124) {\n effects.enter('tableCellDivider');\n effects.consume(code);\n effects.exit('tableCellDivider');\n return bodyRowBreak;\n }\n if (code === null || markdownLineEnding(code)) {\n effects.exit('tableRow');\n return ok(code);\n }\n if (markdownSpace(code)) {\n return factorySpace(effects, bodyRowBreak, \"whitespace\")(code);\n }\n\n // Anything else is cell content.\n effects.enter(\"data\");\n return bodyRowData(code);\n }\n\n /**\n * In table body row data.\n *\n * ```markdown\n * | | a |\n * | | - |\n * > | | b |\n * ^\n * ```\n *\n * @type {State}\n */\n function bodyRowData(code) {\n if (code === null || code === 124 || markdownLineEndingOrSpace(code)) {\n effects.exit(\"data\");\n return bodyRowBreak(code);\n }\n effects.consume(code);\n return code === 92 ? bodyRowEscape : bodyRowData;\n }\n\n /**\n * In table body row escape.\n *\n * ```markdown\n * | | a |\n * | | ---- |\n * > | | b\\-c |\n * ^\n * ```\n *\n * @type {State}\n */\n function bodyRowEscape(code) {\n if (code === 92 || code === 124) {\n effects.consume(code);\n return bodyRowData;\n }\n return bodyRowData(code);\n }\n}\n\n/** @type {Resolver} */\n\nfunction resolveTable(events, context) {\n let index = -1;\n let inFirstCellAwaitingPipe = true;\n /** @type {RowKind} */\n let rowKind = 0;\n /** @type {Range} */\n let lastCell = [0, 0, 0, 0];\n /** @type {Range} */\n let cell = [0, 0, 0, 0];\n let afterHeadAwaitingFirstBodyRow = false;\n let lastTableEnd = 0;\n /** @type {Token | undefined} */\n let currentTable;\n /** @type {Token | undefined} */\n let currentBody;\n /** @type {Token | undefined} */\n let currentCell;\n const map = new EditMap();\n while (++index < events.length) {\n const event = events[index];\n const token = event[1];\n if (event[0] === 'enter') {\n // Start of head.\n if (token.type === 'tableHead') {\n afterHeadAwaitingFirstBodyRow = false;\n\n // Inject previous (body end and) table end.\n if (lastTableEnd !== 0) {\n flushTableEnd(map, context, lastTableEnd, currentTable, currentBody);\n currentBody = undefined;\n lastTableEnd = 0;\n }\n\n // Inject table start.\n currentTable = {\n type: 'table',\n start: Object.assign({}, token.start),\n // Note: correct end is set later.\n end: Object.assign({}, token.end)\n };\n map.add(index, 0, [['enter', currentTable, context]]);\n } else if (token.type === 'tableRow' || token.type === 'tableDelimiterRow') {\n inFirstCellAwaitingPipe = true;\n currentCell = undefined;\n lastCell = [0, 0, 0, 0];\n cell = [0, index + 1, 0, 0];\n\n // Inject table body start.\n if (afterHeadAwaitingFirstBodyRow) {\n afterHeadAwaitingFirstBodyRow = false;\n currentBody = {\n type: 'tableBody',\n start: Object.assign({}, token.start),\n // Note: correct end is set later.\n end: Object.assign({}, token.end)\n };\n map.add(index, 0, [['enter', currentBody, context]]);\n }\n rowKind = token.type === 'tableDelimiterRow' ? 2 : currentBody ? 3 : 1;\n }\n // Cell data.\n else if (rowKind && (token.type === \"data\" || token.type === 'tableDelimiterMarker' || token.type === 'tableDelimiterFiller')) {\n inFirstCellAwaitingPipe = false;\n\n // First value in cell.\n if (cell[2] === 0) {\n if (lastCell[1] !== 0) {\n cell[0] = cell[1];\n currentCell = flushCell(map, context, lastCell, rowKind, undefined, currentCell);\n lastCell = [0, 0, 0, 0];\n }\n cell[2] = index;\n }\n } else if (token.type === 'tableCellDivider') {\n if (inFirstCellAwaitingPipe) {\n inFirstCellAwaitingPipe = false;\n } else {\n if (lastCell[1] !== 0) {\n cell[0] = cell[1];\n currentCell = flushCell(map, context, lastCell, rowKind, undefined, currentCell);\n }\n lastCell = cell;\n cell = [lastCell[1], index, 0, 0];\n }\n }\n }\n // Exit events.\n else if (token.type === 'tableHead') {\n afterHeadAwaitingFirstBodyRow = true;\n lastTableEnd = index;\n } else if (token.type === 'tableRow' || token.type === 'tableDelimiterRow') {\n lastTableEnd = index;\n if (lastCell[1] !== 0) {\n cell[0] = cell[1];\n currentCell = flushCell(map, context, lastCell, rowKind, index, currentCell);\n } else if (cell[1] !== 0) {\n currentCell = flushCell(map, context, cell, rowKind, index, currentCell);\n }\n rowKind = 0;\n } else if (rowKind && (token.type === \"data\" || token.type === 'tableDelimiterMarker' || token.type === 'tableDelimiterFiller')) {\n cell[3] = index;\n }\n }\n if (lastTableEnd !== 0) {\n flushTableEnd(map, context, lastTableEnd, currentTable, currentBody);\n }\n map.consume(context.events);\n\n // To do: move this into `html`, when events are exposed there.\n // That’s what `markdown-rs` does.\n // That needs updates to `mdast-util-gfm-table`.\n index = -1;\n while (++index < context.events.length) {\n const event = context.events[index];\n if (event[0] === 'enter' && event[1].type === 'table') {\n event[1]._align = gfmTableAlign(context.events, index);\n }\n }\n return events;\n}\n\n/**\n * Generate a cell.\n *\n * @param {EditMap} map\n * @param {Readonly<TokenizeContext>} context\n * @param {Readonly<Range>} range\n * @param {RowKind} rowKind\n * @param {number | undefined} rowEnd\n * @param {Token | undefined} previousCell\n * @returns {Token | undefined}\n */\n// eslint-disable-next-line max-params\nfunction flushCell(map, context, range, rowKind, rowEnd, previousCell) {\n // `markdown-rs` uses:\n // rowKind === 2 ? 'tableDelimiterCell' : 'tableCell'\n const groupName = rowKind === 1 ? 'tableHeader' : rowKind === 2 ? 'tableDelimiter' : 'tableData';\n // `markdown-rs` uses:\n // rowKind === 2 ? 'tableDelimiterCellValue' : 'tableCellText'\n const valueName = 'tableContent';\n\n // Insert an exit for the previous cell, if there is one.\n //\n // ```markdown\n // > | | aa | bb | cc |\n // ^-- exit\n // ^^^^-- this cell\n // ```\n if (range[0] !== 0) {\n previousCell.end = Object.assign({}, getPoint(context.events, range[0]));\n map.add(range[0], 0, [['exit', previousCell, context]]);\n }\n\n // Insert enter of this cell.\n //\n // ```markdown\n // > | | aa | bb | cc |\n // ^-- enter\n // ^^^^-- this cell\n // ```\n const now = getPoint(context.events, range[1]);\n previousCell = {\n type: groupName,\n start: Object.assign({}, now),\n // Note: correct end is set later.\n end: Object.assign({}, now)\n };\n map.add(range[1], 0, [['enter', previousCell, context]]);\n\n // Insert text start at first data start and end at last data end, and\n // remove events between.\n //\n // ```markdown\n // > | | aa | bb | cc |\n // ^-- enter\n // ^-- exit\n // ^^^^-- this cell\n // ```\n if (range[2] !== 0) {\n const relatedStart = getPoint(context.events, range[2]);\n const relatedEnd = getPoint(context.events, range[3]);\n /** @type {Token} */\n const valueToken = {\n type: valueName,\n start: Object.assign({}, relatedStart),\n end: Object.assign({}, relatedEnd)\n };\n map.add(range[2], 0, [['enter', valueToken, context]]);\n if (rowKind !== 2) {\n // Fix positional info on remaining events\n const start = context.events[range[2]];\n const end = context.events[range[3]];\n start[1].end = Object.assign({}, end[1].end);\n start[1].type = \"chunkText\";\n start[1].contentType = \"text\";\n\n // Remove if needed.\n if (range[3] > range[2] + 1) {\n const a = range[2] + 1;\n const b = range[3] - range[2] - 1;\n map.add(a, b, []);\n }\n }\n map.add(range[3] + 1, 0, [['exit', valueToken, context]]);\n }\n\n // Insert an exit for the last cell, if at the row end.\n //\n // ```markdown\n // > | | aa | bb | cc |\n // ^-- exit\n // ^^^^^^-- this cell (the last one contains two “between” parts)\n // ```\n if (rowEnd !== undefined) {\n previousCell.end = Object.assign({}, getPoint(context.events, rowEnd));\n map.add(rowEnd, 0, [['exit', previousCell, context]]);\n previousCell = undefined;\n }\n return previousCell;\n}\n\n/**\n * Generate table end (and table body end).\n *\n * @param {Readonly<EditMap>} map\n * @param {Readonly<TokenizeContext>} context\n * @param {number} index\n * @param {Token} table\n * @param {Token | undefined} tableBody\n */\n// eslint-disable-next-line max-params\nfunction flushTableEnd(map, context, index, table, tableBody) {\n /** @type {Array<Event>} */\n const exits = [];\n const related = getPoint(context.events, index);\n if (tableBody) {\n tableBody.end = Object.assign({}, related);\n exits.push(['exit', tableBody, context]);\n }\n table.end = Object.assign({}, related);\n exits.push(['exit', table, context]);\n map.add(index + 1, 0, exits);\n}\n\n/**\n * @param {Readonly<Array<Event>>} events\n * @param {number} index\n * @returns {Readonly<Point>}\n */\nfunction getPoint(events, index) {\n const event = events[index];\n const side = event[0] === 'enter' ? 'start' : 'end';\n return event[1][side];\n}","/**\n * @import {Extension, State, TokenizeContext, Tokenizer} from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownLineEndingOrSpace, markdownSpace } from 'micromark-util-character';\nconst tasklistCheck = {\n name: 'tasklistCheck',\n tokenize: tokenizeTasklistCheck\n};\n\n/**\n * Create an HTML extension for `micromark` to support GFM task list items\n * syntax.\n *\n * @returns {Extension}\n * Extension for `micromark` that can be passed in `htmlExtensions` to\n * support GFM task list items when serializing to HTML.\n */\nexport function gfmTaskListItem() {\n return {\n text: {\n [91]: tasklistCheck\n }\n };\n}\n\n/**\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction tokenizeTasklistCheck(effects, ok, nok) {\n const self = this;\n return open;\n\n /**\n * At start of task list item check.\n *\n * ```markdown\n * > | * [x] y.\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (\n // Exit if there’s stuff before.\n self.previous !== null ||\n // Exit if not in the first content that is the first child of a list\n // item.\n !self._gfmTasklistFirstContentOfListItem) {\n return nok(code);\n }\n effects.enter('taskListCheck');\n effects.enter('taskListCheckMarker');\n effects.consume(code);\n effects.exit('taskListCheckMarker');\n return inside;\n }\n\n /**\n * In task list item check.\n *\n * ```markdown\n * > | * [x] y.\n * ^\n * ```\n *\n * @type {State}\n */\n function inside(code) {\n // Currently we match how GH works in files.\n // To match how GH works in comments, use `markdownSpace` (`[\\t ]`) instead\n // of `markdownLineEndingOrSpace` (`[\\t\\n\\r ]`).\n if (markdownLineEndingOrSpace(code)) {\n effects.enter('taskListCheckValueUnchecked');\n effects.consume(code);\n effects.exit('taskListCheckValueUnchecked');\n return close;\n }\n if (code === 88 || code === 120) {\n effects.enter('taskListCheckValueChecked');\n effects.consume(code);\n effects.exit('taskListCheckValueChecked');\n return close;\n }\n return nok(code);\n }\n\n /**\n * At close of task list item check.\n *\n * ```markdown\n * > | * [x] y.\n * ^\n * ```\n *\n * @type {State}\n */\n function close(code) {\n if (code === 93) {\n effects.enter('taskListCheckMarker');\n effects.consume(code);\n effects.exit('taskListCheckMarker');\n effects.exit('taskListCheck');\n return after;\n }\n return nok(code);\n }\n\n /**\n * @type {State}\n */\n function after(code) {\n // EOL in paragraph means there must be something else after it.\n if (markdownLineEnding(code)) {\n return ok(code);\n }\n\n // Space or tab?\n // Check what comes after.\n if (markdownSpace(code)) {\n return effects.check({\n tokenize: spaceThenNonSpace\n }, ok, nok)(code);\n }\n\n // EOF, or non-whitespace, both wrong.\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * @type {Tokenizer}\n */\nfunction spaceThenNonSpace(effects, ok, nok) {\n return factorySpace(effects, after, \"whitespace\");\n\n /**\n * After whitespace, after task list item check.\n *\n * ```markdown\n * > | * [x] y.\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // EOF means there was nothing, so bad.\n // EOL means there’s content after it, so good.\n // Impossible to have more spaces.\n // Anything else is good.\n return code === null ? nok(code) : ok(code);\n }\n}","/**\n * @typedef {import('micromark-extension-gfm-footnote').HtmlOptions} HtmlOptions\n * @typedef {import('micromark-extension-gfm-strikethrough').Options} Options\n * @typedef {import('micromark-util-types').Extension} Extension\n * @typedef {import('micromark-util-types').HtmlExtension} HtmlExtension\n */\n\nimport {\n combineExtensions,\n combineHtmlExtensions\n} from 'micromark-util-combine-extensions'\nimport {\n gfmAutolinkLiteral,\n gfmAutolinkLiteralHtml\n} from 'micromark-extension-gfm-autolink-literal'\nimport {gfmFootnote, gfmFootnoteHtml} from 'micromark-extension-gfm-footnote'\nimport {\n gfmStrikethrough,\n gfmStrikethroughHtml\n} from 'micromark-extension-gfm-strikethrough'\nimport {gfmTable, gfmTableHtml} from 'micromark-extension-gfm-table'\nimport {gfmTagfilterHtml} from 'micromark-extension-gfm-tagfilter'\nimport {\n gfmTaskListItem,\n gfmTaskListItemHtml\n} from 'micromark-extension-gfm-task-list-item'\n\n/**\n * Create an extension for `micromark` to enable GFM syntax.\n *\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n *\n * Passed to `micromark-extens-gfm-strikethrough`.\n * @returns {Extension}\n * Extension for `micromark` that can be passed in `extensions` to enable GFM\n * syntax.\n */\nexport function gfm(options) {\n return combineExtensions([\n gfmAutolinkLiteral(),\n gfmFootnote(),\n gfmStrikethrough(options),\n gfmTable(),\n gfmTaskListItem()\n ])\n}\n\n/**\n * Create an extension for `micromark` to support GFM when serializing to HTML.\n *\n * @param {HtmlOptions | null | undefined} [options]\n * Configuration (optional).\n *\n * Passed to `micromark-extens-gfm-footnote`.\n * @returns {HtmlExtension}\n * Extension for `micromark` that can be passed in `htmlExtensions` to\n * support GFM when serializing to HTML.\n */\nexport function gfmHtml(options) {\n return combineHtmlExtensions([\n gfmAutolinkLiteralHtml(),\n gfmFootnoteHtml(options),\n gfmStrikethroughHtml(),\n gfmTableHtml(),\n gfmTagfilterHtml(),\n gfmTaskListItemHtml()\n ])\n}\n","/**\n * @import {Root} from 'mdast'\n * @import {Options} from 'remark-gfm'\n * @import {} from 'remark-parse'\n * @import {} from 'remark-stringify'\n * @import {Processor} from 'unified'\n */\n\nimport {gfmFromMarkdown, gfmToMarkdown} from 'mdast-util-gfm'\nimport {gfm} from 'micromark-extension-gfm'\n\n/** @type {Options} */\nconst emptyOptions = {}\n\n/**\n * Add support GFM (autolink literals, footnotes, strikethrough, tables,\n * tasklists).\n *\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {undefined}\n * Nothing.\n */\nexport default function remarkGfm(options) {\n // @ts-expect-error: TS is wrong about `this`.\n // eslint-disable-next-line unicorn/no-this-assignment\n const self = /** @type {Processor<Root>} */ (this)\n const settings = options || emptyOptions\n const data = self.data()\n\n const micromarkExtensions =\n data.micromarkExtensions || (data.micromarkExtensions = [])\n const fromMarkdownExtensions =\n data.fromMarkdownExtensions || (data.fromMarkdownExtensions = [])\n const toMarkdownExtensions =\n data.toMarkdownExtensions || (data.toMarkdownExtensions = [])\n\n micromarkExtensions.push(gfm(settings))\n fromMarkdownExtensions.push(gfmFromMarkdown())\n toMarkdownExtensions.push(gfmToMarkdown(settings))\n}\n"],"names":["_extends","target","i","source","key","Action","PopStateEventType","createBrowserHistory","options","createBrowserLocation","window","globalHistory","pathname","search","hash","createLocation","createBrowserHref","to","createPath","getUrlBasedHistory","invariant","value","message","warning","cond","createKey","getHistoryState","location","index","current","state","parsePath","_ref","path","parsedPath","hashIndex","searchIndex","getLocation","createHref","validateLocation","v5Compat","action","listener","getIndex","handlePop","nextIndex","delta","history","push","historyState","url","error","replace","createURL","base","href","fn","n","ResultType","matchRoutes","routes","locationArg","basename","matchRoutesImpl","allowPartial","stripBasename","branches","flattenRoutes","rankRouteBranches","matches","decoded","decodePath","matchRouteBranch","parentsMeta","parentPath","flattenRoute","route","relativePath","meta","joinPaths","routesMeta","computeScore","_route$path","exploded","explodeOptionalSegments","segments","first","rest","isOptional","required","restExploded","result","subpath","a","b","compareIndexes","paramRe","dynamicSegmentValue","indexRouteValue","emptySegmentValue","staticSegmentValue","splatPenalty","isSplat","s","initialScore","score","segment","branch","matchedParams","matchedPathname","end","remainingPathname","match","matchPath","normalizePathname","pattern","matcher","compiledParams","compilePath","pathnameBase","captureGroups","memo","paramName","splatValue","caseSensitive","params","regexpSource","_","v","startIndex","nextChar","ABSOLUTE_URL_REGEX$1","isAbsoluteUrl","resolvePath","fromPathname","toPathname","oldPathname","resolvePathname","normalizeSearch","normalizeHash","getInvalidPathError","char","field","dest","getPathContributingMatches","getResolveToMatches","v7_relativeSplatPath","pathMatches","idx","resolveTo","toArg","routePathnames","locationPathname","isPathRelative","isEmptyPath","from","routePathnameIndex","toSegments","hasExplicitTrailingSlash","hasCurrentTrailingSlash","paths","isRouteErrorResponse","validMutationMethodsArr","validRequestMethodsArr","r","f","o","clsx","exports","isUnsafeProperty","isDeepKey","toKey","_a","toString","require$$0","require$$1","toPath","deepKey","length","quoteChar","bracket","require$$2","require$$3","get","object","defaultValue","getWithPath","uniqBy","arr","mapper","map","item","ary","func","args","identity","x","isLength","isArrayLike","isObjectLike","isArrayLikeObject","property","isObject","isPrimitive","isEqualsSameValueZero","other","isMatchWith","compare","isMatchWithInternal","doesMatch","objValue","srcValue","stack","isEqual","isObjectMatch","isArrayMatch","isMapMatch","isSetMatch","keys","sourceValue","targetValue","countedIndex","sourceItem","found","j","targetItem","isMatch","getSymbols","symbol","getTag","regexpTag","stringTag","numberTag","booleanTag","argumentsTag","symbolTag","dateTag","mapTag","setTag","arrayTag","functionTag","arrayBufferTag","objectTag","errorTag","dataViewTag","uint8ArrayTag","uint8ClampedArrayTag","uint16ArrayTag","uint32ArrayTag","bigUint64ArrayTag","int8ArrayTag","int16ArrayTag","int32ArrayTag","bigInt64ArrayTag","float32ArrayTag","float64ArrayTag","globalThis_","global","globalThis","isBuffer","isTypedArray","tags","require$$4","require$$5","cloneDeepWith","obj","cloneValue","cloneDeepWithImpl","valueToClone","keyToClone","objectToClone","cloned","copyProperties","isCloneableObject","descriptor","cloneDeep","cloneDeepWith$1","customizer","IS_UNSIGNED_INTEGER","isIndex","isArguments","has","resolvedPath","matchesProperty","iteratee","uniqBy$1","array","iteratee$1","React","is","y","objectIs","useState","useEffect","useLayoutEffect","useDebugValue","useSyncExternalStore$2","subscribe","getSnapshot","_useState","inst","forceUpdate","checkIfSnapshotChanged","latestGetSnapshot","nextValue","useSyncExternalStore$1","shim","useSyncExternalStoreShim_production","shimModule","useSyncExternalStore","useRef","useMemo","withSelector_production","getServerSnapshot","selector","instRef","memoizedSelector","nextSnapshot","hasMemo","memoizedSnapshot","currentSelection","memoizedSelection","nextSelection","maybeGetServerSnapshot","withSelectorModule","assertIsFunction","errorMessage","assertIsObject","assertIsArrayOfFunctions","itemTypes","ensureIsArray","getDependencies","createSelectorArgs","dependencies","collectInputSelectorResults","inputSelectorArgs","inputSelectorResults","StrongRef","Ref","UNTERMINATED","TERMINATED","createCacheNode","weakMapMemoize","fnNode","resultEqualityCheck","lastResult","resultsCount","memoized","cacheNode","l","arg","objectCache","objectNode","primitiveCache","primitiveNode","terminatedNode","lastResultValue","createSelectorCreator","memoizeOrOptions","memoizeOptionsFromArgs","createSelectorCreatorOptions","createSelector2","recomputations","dependencyRecomputations","directlyPassedOptions","resultFunc","combinedOptions","memoize","memoizeOptions","argsMemoize","argsMemoizeOptions","finalMemoizeOptions","finalArgsMemoizeOptions","memoizedResultFunc","createSelector","createStructuredSelector","inputSelectorsObject","selectorCreator","inputSelectorKeys","composition","getPriority","compareValues","order","aPriority","bPriority","isSymbol","regexIsDeepProp","regexIsPlainProp","isKey","orderBy","collection","criteria","orders","guard","getValueByNestedPath","getValueByCriterion","criterion","preparedCriteria","comparedResult","flatten","depth","flooredDepth","recursive","currentDepth","isIterateeCall","sortBy","formatProdErrorMessage","code","$$observable","symbol_observable_default","randomString","ActionTypes","actionTypes_default","isPlainObject","proto","createStore","reducer","preloadedState","enhancer","currentReducer","currentState","currentListeners","nextListeners","listenerIdCounter","isDispatching","ensureCanMutateNextListeners","getState","isSubscribed","listenerId","dispatch","replaceReducer","nextReducer","observable","outerSubscribe","observer","observeState","observerAsObserver","assertReducerShape","reducers","combineReducers","reducerKeys","finalReducers","finalReducerKeys","shapeAssertionError","e","hasChanged","nextState","previousStateForKey","nextStateForKey","compose","funcs","applyMiddleware","middlewares","createStore2","store","middlewareAPI","chain","middleware","isAction","NOTHING","DRAFTABLE","DRAFT_STATE","die","O","getPrototypeOf","CONSTRUCTOR","PROTOTYPE","CONFIGURABLE","ENUMERABLE","WRITABLE","VALUE","isDraft","isDraftable","isArray","isMap","isSet","objectCtorString","cachedCtorStrings","isObjectish","Ctor","isFunction","ctorString","each","iter","strict","getArchtype","entry","thing","prop","type","set","propOrOldValue","isBoolean","isArrayIndex","latest","getFinalValue","shallowCopy","isPlain","descriptors","desc","freeze","deep","isFrozen","dontMutateMethodOverride","_key","dontMutateFrozenCollections","PluginMapSet","PluginPatches","PluginArrayMethods","plugins","getPlugin","pluginKey","plugin","isPluginLoaded","currentScope","getCurrentScope","createScope","parent_","immer_","usePatchesInScope","scope","patchListener","revokeScope","leaveScope","revokeDraft","enterScope","immer2","draft","processResult","baseDraft","finalize","patchPlugin_","maybeFreeze","rootScope","handleValue","isSameScope","callbacks_","generatePatchesAndFinalize","markStateFinalized","EMPTY_LOCATIONS_RESULT","updateDraftInParent","parent","draftValue","finalizedValue","originalKey","parentCopy","parentType","draftLocations","locations","registerChildFinalizationCallback","child","basePath","handleCrossReference","scope_","prepareCopy","targetCopy","handledSet","updatedValue","createProxyProxy","baseIsArray","traps","objectTraps","arrayTraps","revoke","proxy","arrayPlugin","isArrayWithStringProp","readPropFromProto","peek","childKey","childDraft","createProxy","getDescriptorFromProto","current2","markChanged","owner","Immer2","config","recipe","defaultBase","self","base2","hasError","p","ip","patches","inversePatches","patch","applyPatchesImpl","rootScope2","currentImpl","copy","childValue","immer","produce","createThunkMiddleware","extraArgument","next","thunk","withExtraArgument","composeWithDevTools","createAction","prepareAction","actionCreator","prepared","Tuple","_Tuple","items","freezeDraftable","val","getOrInsertComputed","compute","buildGetDefaultMiddleware","immutableCheck","serializableCheck","actionCreatorCheck","middlewareArray","thunkMiddleware","SHOULD_AUTOBATCH","prepareAutoBatched","payload","createQueueWithTimer","timeout","notify","autoBatchEnhancer","notifying","shouldNotifyAtEndOfTick","notificationQueued","listeners","queueCallback","notifyListeners","listener2","wrappedListener","unsubscribe","buildGetDefaultEnhancers","middlewareEnhancer","autoBatch","enhancerArray","configureStore","getDefaultMiddleware","devTools","enhancers","rootReducer","finalMiddleware","finalCompose","getDefaultEnhancers","storeEnhancers","composedEnhancer","executeReducerBuilderCallback","builderCallback","actionsMap","actionMatchers","defaultCaseReducer","builder","typeOrActionCreator","asyncThunk","isStateFunction","createReducer","initialState","mapOrBuilderCallback","finalActionMatchers","finalDefaultCaseReducer","getInitialState","frozenInitialState","caseReducers","reducer2","cr","previousState","caseReducer","urlAlphabet","nanoid","size","id","asyncThunkSymbol","getType","slice","actionKey","buildCreateSlice","creators","cAT","name","reducerPath","buildReducerCreators","reducerNames","context","contextMethods","name2","reducerName","reducerDefinition","reducerDetails","isAsyncThunkSliceReducerDefinition","handleThunkCaseReducerDefinition","handleNormalReducerDefinition","buildReducer","extraReducers","finalCaseReducers","sM","m","selectSelf","injectedSelectorCache","injectedStateCache","_reducer","makeSelectorProps","reducerPath2","injected","selectSlice","sliceState","getSelectors","selectState","selectorCache","wrapSelector","injectable","pathOpt","newReducerPath","wrapper","rootState","createSlice","payloadCreator","prepare","createNotation","maybeReducerWithPrepare","prepareCallback","isCaseReducerWithPrepareDefinition","fulfilled","pending","rejected","settled","noop","task","completed","cancelled","taskCancelled","taskCompleted","listenerCancelled","listenerCompleted","TaskAbortError","__publicField","assertFunction","expected","noop2","catchRejection","promise","onError","addAbortSignalListener","abortSignal","callback","validateActive","signal","raceWithSignal","cleanup","resolve","reject","notifyRejection","runTask","task2","cleanUp","createPause","output","createDelay","pause","timeoutMs","assign","INTERNAL_NIL_TOKEN","alm","createFork","parentAbortSignal","parentBlockingPromises","linkControllers","controller","taskExecutor","opts","childAbortController","result2","createTakePattern","startListening","take","predicate","promises","stopListening","listenerApi","getListenerEntryPropsFrom","effect","createListenerEntry","findListenerEntry","listenerMap","cancelActiveListeners","createClearListenerMiddleware","executingListeners","safelyNotifyError","errorHandler","errorToNotify","errorInfo","errorHandlerError","addListener","clearAllListeners","removeListener","defaultErrorHandler","createListenerMiddleware","middlewareOptions","trackExecutingListener","count","untrackExecutingListener","extra","insertEntry","cancelOptions","notifyListener","api","getOriginalState","internalTaskController","autoJoinPromises","listenerError","clearListenerMiddleware","originalState","listenerEntries","runListener","predicateError","debounce","debounceMs","edges","pendingThis","pendingArgs","leading","trailing","invoke","onTimerEnd","cancel","timeoutId","schedule","cancelTimer","flush","debounced","isFirstCall","debounce$1","maxWait","pendingAt","_debounced","throttle","throttleMs","t","useStrictIteration","finalizeProperty","resultEach","isSet2","parentState","targetObject","rootPath","targetIsSet","childIsFrozen","res","castDraft","useSyncExternalStoreWithSelector_production","defaultNoopBatch","createListenerCollection","last","nullListeners","createSubscription","parentSub","subscriptionsAmount","selfSubscribed","addNestedSub","trySubscribe","cleanupListener","removed","tryUnsubscribe","notifyNestedSubs","handleChangeWrapper","subscription","trySubscribeSelf","tryUnsubscribeSelf","canUseDOM","isDOM","isRunningInReactNative","isReactNative","getUseIsomorphicLayoutEffect","React.useLayoutEffect","React.useEffect","useIsomorphicLayoutEffect","shallowEqual","objA","objB","keysA","keysB","ContextKey","gT","getContext","React.createContext","contextMap","realContext","ReactReduxContext","Provider","providerProps","children","serverState","contextValue","React.useMemo","Context","React.createElement","Provider_default","toNumber","toFinite","range","start","step","MAX_DIGITS","defaults","Decimal","external","decimalError","invalidArgument","exponentOutOfRange","mathfloor","mathpow","isDecimal","ONE","BASE","LOG_BASE","MAX_SAFE_INTEGER","MAX_E","P","xdL","ydL","w","dp","divide","round","getBase10Exponent","pr","wpr","ln","subtract","add","q","exp","z","sd","digitsToString","carry","k","rL","xd","yd","rm","checkInt32","str","sign","yIsInt","yn","truncate","d","len","min","max","ws","indexOfLastWord","getZeroString","multiplyInteger","temp","aL","bL","cmp","prod","prodL","qd","rem","remL","rem0","xi","xL","yd0","yL","yz","denominator","pow","sum","getLn10","zs","c","c0","numerator","x2","parseDecimal","rd","doRound","xdi","xe","xLTy","isExp","clone","ps","Decimal$1","InternMap","entries","keyof","intern_get","intern_set","intern_delete","_intern","prefix","Events","EE","once","emitter","event","evt","clearEvent","EventEmitter","names","events","handlers","ee","a1","a2","a3","a4","a5","module","tag","condition","_objectWithoutPropertiesLoose","_objectWithoutProperties","objectWithoutPropertiesLoose","_arrayLikeToArray","_arrayWithoutHoles","arrayLikeToArray","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","_toConsumableArray","arrayWithoutHoles","iterableToArray","unsupportedIterableToArray","nonIterableSpread","_typeof","toPrimitive","toPropertyKey","_defineProperty","Schema","normal","space","merge","definitions","definition","normalize","Info","attribute","powers","boolean","increment","booleanish","overloadedBoolean","number","spaceSeparated","commaSeparated","commaOrSpaceSeparated","checks","types","DefinedInfo","mask","mark","check","values","create","properties","normals","info","aria","caseSensitiveTransform","attributes","caseInsensitiveTransform","html","svg","xlink","xmlns","xml","hastToReact","cap","dash","valid","find","schema","Type","camelcase","dashes","kebab","$0","htmlBase","svgBase","parse","tokens","input","token","stringify","settings","parseSelector","defaultTagName","props","previous","tagName","subvalue","createH","adjust","createAdjustMap","h","node","lower","adjusted","isChild","addProperty","addChild","record","list","parseSpaces","parseCommas","parsePrimitive","style","finalResult","nodes","styles","svgCaseSensitiveTagNames","characterEntitiesLegacy","characterReferenceInvalid","character","isHexadecimal","isAlphabetical","isAlphanumerical","element","decodeNamedCharacterReference","characterReference","messages","parseEntities","additional","lines","queue","point","indent","line","column","now","following","begin","characterReferenceCharacters","characters","test","terminated","namedReference","diff","reference","reason","referenceCode","prohibited","disallowed","offset","position","nameRe","nameReJsx","emptyOptions","re","whitespace","empty","COMMENT_REGEX","NEWLINE_REGEX","WHITESPACE_REGEX","PROPERTY_REGEX","COLON_REGEX","VALUE_REGEX","SEMICOLON_REGEX","TRIM_REGEX","NEWLINE","FORWARD_SLASH","ASTERISK","EMPTY_STRING","TYPE_COMMENT","TYPE_DECLARATION","lineno","updatePosition","Position","msg","err","comments","rules","comment","pos","declaration","ret","trim","declarations","decls","decl","cjs","__importDefault","this","mod","StyleToObject","inline_style_parser_1","iterator","styleObject","hasIterator","utilities","CUSTOM_PROPERTY_REGEX","HYPHEN_REGEX","NO_HYPHEN_REGEX","VENDOR_PREFIX_REGEX","MS_VENDOR_PREFIX_REGEX","skipCamelCase","capitalize","trimHyphen","camelCase","style_to_object_1","utilities_1","StyleToJS","pointEnd","pointStart","stringifyPosition","VFileMessage","causeOrReason","optionsOrParentOrPlace","origin","legacyCause","own","emptyMap","tableElements","tableCellElement","docs","toJsxRuntime","tree","filePath","developmentCreate","productionCreate","one","mdxExpression","mdxJsxElement","mdxEsm","root","text","parentSchema","findComponentFromName","createElementProps","createChildren","addNode","addChildren","expression","assert","crashEstree","createJsxElementProps","jsx","jsxs","jsxDEV","isStaticChildren","alignValue","createProperty","objectExpression","countsByName","commas","spaces","parseStyle","transformStylesToCssCasing","styleToJs","cause","allowExpression","identifiers","isIdentifierName","place","domCasing","cssCasing","transformStyleToCssCasing","toDash","urlAttributes","includeImageAlt","includeHtml","all","splice","remove","chunkStart","parameters","hasOwnProperty","combineExtensions","extensions","syntaxExtension","extension","hook","left","right","constructs","existing","before","decodeNumericCharacterReference","normalizeIdentifier","asciiAlpha","regexCheck","asciiAlphanumeric","asciiAtext","asciiControl","asciiDigit","asciiHexDigit","asciiPunctuation","markdownLineEnding","markdownLineEndingOrSpace","markdownSpace","unicodePunctuation","unicodeWhitespace","regex","normalizeUri","skip","factorySpace","effects","ok","limit","content","initializeContent","contentStart","afterContentStartConstruct","paragraphInitial","lineStart","data","document","initializeDocument","containerConstruct","tokenizeContainer","continued","childFlow","childToken","lineStartOffset","documentContinue","checkNewContainers","closeFlow","indexBeforeExits","indexBeforeFlow","exitContainers","documentContinued","flowStart","thereIsANewContainer","thereIsNoNewContainer","containerContinue","flowContinue","writeToChild","endOfFile","stream","seen","nok","classifyCharacter","resolveAll","called","attention","resolveAllAttention","tokenizeAttention","open","group","openingSequence","closingSequence","use","nextEvents","movePoint","attentionMarkers","marker","inside","after","close","autolink","tokenizeAutolink","schemeOrEmailAtext","emailAtext","schemeInsideOrEmailAtext","urlInside","emailAtSignOrDot","emailLabel","emailValue","blankLine","tokenizeBlankLine","blockQuote","tokenizeBlockQuoteContinuation","exit","tokenizeBlockQuoteStart","contStart","contBefore","characterEscape","tokenizeCharacterEscape","tokenizeCharacterReference","numeric","nonLazyContinuation","tokenizeNonLazyContinuation","codeFenced","tokenizeCodeFenced","closeStart","tokenizeCloseStart","initialPrefix","sizeOpen","beforeSequenceOpen","tail","sequenceOpen","infoBefore","atNonLazyBreak","metaBefore","contentBefore","beforeContentChunk","contentChunk","startBefore","beforeSequenceClose","sequenceClose","sequenceCloseAfter","codeIndented","tokenizeCodeIndented","furtherStart","tokenizeFurtherStart","afterPrefix","atBreak","codeText","resolveCodeText","tokenizeCodeText","tailExitIndex","headEnterIndex","enter","between","SpliceBuffer","initial","stop","deleteCount","chunkedPush","subtokenize","eventsArray","jumps","lineIndex","otherIndex","otherEvent","subevents","more","subcontent","eventIndex","startPosition","startPositions","tokenizer","childEvents","gaps","breaks","resolveContent","tokenizeContent","continuationConstruct","tokenizeContinuation","chunkInside","contentEnd","contentContinue","startLookahead","prefixed","factoryDestination","literalType","literalMarkerType","rawType","stringType","balance","enclosedBefore","raw","enclosed","enclosedEscape","rawEscape","factoryLabel","markerType","labelInside","labelEscape","factoryTitle","escape","factoryWhitespace","tokenizeDefinition","titleBefore","tokenizeTitleBefore","identifier","labelAfter","markerAfter","destinationBefore","destinationAfter","afterWhitespace","beforeMarker","titleAfter","titleAfterOptionalWhitespace","hardBreakEscape","tokenizeHardBreakEscape","headingAtx","resolveHeadingAtx","tokenizeHeadingAtx","sequenceFurther","htmlBlockNames","htmlRawNames","htmlFlow","resolveToHtmlFlow","tokenizeHtmlFlow","blankLineBefore","tokenizeBlankLineBefore","nonLazyContinuationStart","tokenizeNonLazyContinuationStart","closingTag","buffer","markerB","declarationOpen","tagCloseStart","continuationDeclarationInside","commentOpenInside","cdataOpenInside","continuation","slash","basicSelfClosing","completeClosingTagAfter","completeAttributeNameBefore","completeEnd","completeAttributeName","completeAttributeNameAfter","completeAttributeValueBefore","completeAttributeValueQuoted","completeAttributeValueUnquoted","completeAttributeValueQuotedAfter","completeAfter","continuationCommentInside","continuationRawTagOpen","continuationClose","continuationCdataInside","continuationAfter","continuationStart","continuationStartNonLazy","continuationBefore","continuationRawEndTag","htmlText","tokenizeHtmlText","returnState","instruction","tagOpen","commentEnd","commentClose","lineEndingBefore","cdata","cdataClose","cdataEnd","instructionClose","tagClose","tagCloseBetween","tagOpenBetween","tagOpenAttributeName","tagOpenAttributeNameAfter","tagOpenAttributeValueBefore","tagOpenAttributeValueQuoted","tagOpenAttributeValueUnquoted","tagOpenAttributeValueQuotedAfter","lineEndingAfter","lineEndingAfterPrefix","labelEnd","resolveAllLabelEnd","resolveToLabelEnd","tokenizeLabelEnd","resourceConstruct","tokenizeResource","referenceFullConstruct","tokenizeReferenceFull","referenceCollapsedConstruct","tokenizeReferenceCollapsed","newEvents","media","label","labelStart","defined","labelEndNok","labelEndOk","referenceNotFull","resourceStart","resourceBefore","resourceOpen","resourceEnd","resourceDestinationAfter","resourceDestinationMissing","resourceBetween","resourceTitleAfter","referenceFull","referenceFullAfter","referenceFullMissing","referenceCollapsedStart","referenceCollapsedOpen","labelStartImage","tokenizeLabelStartImage","labelStartLink","tokenizeLabelStartLink","lineEnding","tokenizeLineEnding","thematicBreak","tokenizeThematicBreak","sequence","tokenizeListContinuation","tokenizeListEnd","tokenizeListStart","listItemPrefixWhitespaceConstruct","tokenizeListItemPrefixWhitespace","indentConstruct","tokenizeIndent","initialSize","kind","atMarker","onBlank","endOfPrefix","otherPrefix","notBlank","notInCurrentItem","setextUnderline","resolveToSetextUnderline","tokenizeSetextUnderline","heading","paragraph","flow","initializeFlow","atBlankEnding","afterConstruct","resolver","createResolver","string","initializeFactory","resolveAllLineSuffixes","initializeText","notText","extraResolver","resolveAllText","chunks","bufferIndex","tabs","chunk","contentInitial","flowInitial","insideSpan","resolveText","disable","createTokenizer","parser","initialize","columnStart","resolveAllConstructs","constructFactory","onsuccessfulconstruct","onsuccessfulcheck","consume","defineSkip","sliceSerialize","sliceStream","write","main","addResult","expandTabs","serializeChunks","sliceChunks","_bufferIndex","_index","accountForPotentialSkip","chunkIndex","go","fields","construct","onreturn","bogusState","listOfConstructs","constructIndex","currentConstruct","handleListOfConstructs","handleMapOfConstructs","handleConstruct","startPoint","startPrevious","startCurrentConstruct","startEventsIndex","startStack","restore","startBufferIndex","endIndex","endBufferIndex","view","head","atTab","defaultConstructs","creator","postprocess","preprocess","atCarriageReturn","preprocessor","encoding","endPosition","characterEscapeOrReference","decodeString","decode","$1","$2","hex","fromMarkdown","compiler","opener","link","onenterdata","codeFlow","emphasis","hardBreak","image","listItem","onenterlistitemvalue","onenterlistordered","onenterreference","strong","closer","onexitatxheadingsequence","onexitautolinkemail","onexitautolinkprotocol","onexitdata","onexitcharacterreferencemarker","onexitcharacterreferencevalue","onexitcharacterreference","onexitcodefenced","onexitcodefencedfence","onexitcodefencedfenceinfo","onexitcodefencedfencemeta","onexitcodeindented","onexitcodetext","onexitdefinitiondestinationstring","onexitdefinitionlabelstring","onexitdefinitiontitlestring","onexithardbreak","onexithtmlflow","onexithtmltext","onexitimage","onexitlabel","onexitlabeltext","onexitlineending","onexitlink","onexitreferencestring","onexitresourcedestinationstring","onexitresourcetitlestring","onexitresource","onexitsetextheading","onexitsetextheadinglinesequence","onexitsetextheadingtext","configure","compile","resume","listStack","prepareList","handler","defaultOnError","containerBalance","listSpread","firstBlankLineIndex","tailIndex","tailEvent","and","onExitError","ancestor","siblings","referenceType","fragment","combined","remarkParse","doc","blockquote","language","strikethrough","footnoteReference","clobberPrefix","safeId","counter","reuseCounter","sup","revert","subtype","suffix","contents","imageReference","inlineCode","linkReference","results","loose","listLoose","listItemLoose","spread","table","rows","firstRow","tableContent","body","tableRow","align","cellIndex","cells","cell","tableCell","tab","trimLines","trimLine","ignore","VOID","PRIMITIVE","ARRAY","OBJECT","DATE","REGEXP","MAP","SET","ERROR","BIGINT","env","init","deserializer","$","as","out","unpair","flags","deserialize","serialized","EMPTY","typeOf","asString","shouldSkip","TYPE","serializer","json","pair","serialize","lossy","structuredClone$1","any","defaultFootnoteBackContent","rereferenceIndex","defaultFootnoteBackLabel","referenceIndex","footer","footnoteBackContent","footnoteBackLabel","footnoteLabel","footnoteLabelTagName","footnoteLabelProperties","listItems","backReferences","counts","tailTail","structuredClone","convert","castFactory","anyFactory","propertiesFactory","typeFactory","tests","checkAsRecord","nodeAsRecord","testFunction","looksLikeANode","CONTINUE","EXIT","SKIP","visitParents","visitor","reverse","factory","parents","visit","subresult","grandparents","toResult","nodeAsParent","testOrVisitor","visitorOrReverse","maybeReverse","overload","createState","definitionById","footnoteById","footnoteCounts","defaultHandlers","applyData","wrap","handle","shallow","defaultUnknownHandler","trimMarkdownSpaceStart","hName","hChildren","hProperties","toHast","foot","remarkRehype","destination","file","hastTree","bail","hasOwn","toStr","defineProperty","gOPD","hasOwnConstructor","hasIsPrototypeOf","setProperty","getProperty","extend","src","copyIsArray","prototype","trough","fns","pipeline","run","middlewareIndex","middelware","wrapped","fnExpectsCallback","done","exception","then","minpath","dirname","extname","join","assertPath","seenNonSlash","firstNonSlashEnd","extnameIndex","unmatchedSlash","startPart","startDot","preDotState","joined","absolute","normalizeString","allowAboveRoot","lastSegmentLength","lastSlash","dots","lastSlashIndex","minproc","cwd","isUrl","fileUrlOrPath","urlToPath","getPathFromURLPosix","third","VFile","isUint8Array","assertNonEmpty","assertPart","stem","part","CallableInstance","apply","Processor","attacher","assertUnfrozen","transformer","realFile","vfile","assertParser","assertCompiler","executor","parseTree","realDone","compileTree","compileResult","looksLikeAValue","complete","assertDone","assertNode","transformers","outputTree","resultingTree","attachers","namespace","addPlugin","addList","addPreset","entryIndex","primary","currentPrimary","isPlainObj","unified","frozen","asyncName","looksLikeAVFile","changelog","emptyPlugins","emptyRemarkRehypeOptions","safeProtocol","deprecations","Markdown","processor","createProcessor","createFile","post","rehypePlugins","remarkPlugins","remarkRehypeOptions","allowedElements","allowElement","components","disallowedElements","skipHtml","unwrapDisallowed","urlTransform","defaultUrlTransform","deprecation","transform","Fragment","colon","questionMark","numberSign","ccount","escapeStringRegexp","findAndReplace","ignored","pairs","toPairs","pairIndex","grandparent","change","matchObject","tupleOrList","tuple","toExpression","toFunction","inConstruct","notInConstruct","gfmAutolinkLiteralFromMarkdown","transformGfmAutolinkLiterals","enterLiteralAutolink","enterLiteralAutolinkValue","exitLiteralAutolink","exitLiteralAutolinkEmail","exitLiteralAutolinkHttp","exitLiteralAutolinkWww","gfmAutolinkLiteralToMarkdown","findUrl","findEmail","protocol","domain","isCorrectDomain","parts","splitUrl","atext","trailExec","trail","closingParenIndex","openingParens","closingParens","email","footnoteReferencePeek","enterFootnoteCallString","enterFootnoteCall","enterFootnoteDefinitionLabelString","enterFootnoteDefinition","exitFootnoteCallString","exitFootnoteCall","exitFootnoteDefinitionLabelString","exitFootnoteDefinition","tracker","subexit","gfmFootnoteFromMarkdown","gfmFootnoteToMarkdown","firstLineBlank","footnoteDefinition","mapAll","mapExceptFirst","blank","constructsWithoutStrikethrough","handleDelete","peekDelete","gfmStrikethroughFromMarkdown","enterStrikethrough","exitStrikethrough","gfmStrikethroughToMarkdown","defaultStringLength","markdownTable","stringLength","alignments","cellMatrix","sizeMatrix","longestCellByColumn","mostCellsPerRow","rowIndex","row","sizes","columnIndex","toAlignment","patternInScope","listInScope","none","_1","longestStreak","substring","formatCodeAsIndented","checkFence","checkQuote","quote","checkEmphasis","encodeCharacterReference","encodeInfo","outside","outsideKind","insideKind","emphasisPeek","betweenHead","betweenTail","formatHeadingAsSetext","literalWithBreak","rank","htmlPeek","imagePeek","imageReferencePeek","alt","inlineCodePeek","formatLinkAsAutolink","linkPeek","linkReferencePeek","checkBullet","checkBulletOther","bullet","bulletOther","checkBulletOrdered","checkRule","bulletCurrent","useDifferentMarker","firstListItem","checkListItemIndent","listItemIndent","phrasing","checkStrong","strongPeek","checkRuleRepetition","repetition","gfmTableFromMarkdown","enterTable","enterCell","enterRow","exitCodeText","exitTable","gfmTableToMarkdown","padding","alignDelimiters","around","inlineCodeWithTable","handleTable","handleTableCell","handleTableRow","serializeData","handleTableAsData","handleTableRowAsData","matrix","gfmTaskListItemFromMarkdown","exitCheck","exitParagraphWithTaskListItem","gfmTaskListItemToMarkdown","listItemWithTaskListItem","firstParaghraph","sibling","checkable","checkbox","gfmFromMarkdown","gfmToMarkdown","wwwPrefix","tokenizeWwwPrefix","tokenizeDomain","tokenizePath","tokenizeTrail","emailDomainDotTrail","tokenizeEmailDomainDotTrail","wwwAutolink","tokenizeWwwAutolink","previousWww","protocolAutolink","tokenizeProtocolAutolink","previousProtocol","emailAutolink","tokenizeEmailAutolink","previousEmail","gfmAutolinkLiteral","dot","gfmAtext","previousUnbalanced","emailDomain","emailDomainAfter","emailDomainDot","wwwStart","wwwAfter","protocolStart","protocolPrefixInside","protocolSlashesInside","afterProtocol","protocolAfter","wwwPrefixInside","wwwPrefixAfter","underscoreInLastSegment","underscoreInLastLastSegment","domainInside","domainAfter","domainAtPunctuation","sizeClose","pathInside","pathAtPunctuation","trailCharacterReferenceStart","trailBracketAfter","trailCharacterReferenceInside","gfmFootnote","tokenizeDefinitionStart","tokenizeDefinitionContinuation","gfmFootnoteDefinitionEnd","tokenizeGfmFootnoteCall","tokenizePotentialGfmFootnoteCall","resolveToPotentialGfmFootnoteCall","call","replacement","callStart","callData","callEscape","labelAtMarker","whitespaceAfter","gfmStrikethrough","single","tokenizeStrikethrough","resolveAllStrikethrough","EditMap","addImplementation","vecs","editMap","at","gfmTableAlign","inDelimiterRow","alignIndex","gfmTable","tokenizeTable","resolveTable","sizeB","bodyRowStart","headRowBefore","headRowStart","headRowBreak","headDelimiterStart","headRowData","headRowEscape","headDelimiterBefore","headDelimiterValueBefore","headDelimiterCellBefore","headDelimiterNok","headDelimiterLeftAlignmentAfter","headDelimiterCellAfter","headDelimiterFiller","headDelimiterRightAlignmentAfter","bodyRowBreak","bodyRowData","bodyRowEscape","inFirstCellAwaitingPipe","rowKind","lastCell","afterHeadAwaitingFirstBodyRow","lastTableEnd","currentTable","currentBody","currentCell","flushTableEnd","flushCell","rowEnd","previousCell","groupName","valueName","getPoint","relatedStart","relatedEnd","valueToken","tableBody","exits","related","side","tasklistCheck","tokenizeTasklistCheck","gfmTaskListItem","spaceThenNonSpace","gfm","remarkGfm","micromarkExtensions","fromMarkdownExtensions","toMarkdownExtensions"],"mappings":"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CAAK,EAAE,KAAK,IAAI,CAAC,EAGrC,OAAOsE,EAAO,KAAK,IAAI,CACzB,CAUA,SAASk/B,GAAgBzC,EAAQ,CAE/B,MAAMz8B,EAAS,IAAI,IAEnB,UAAWtE,KAAS+gC,EAClBz8B,EAAO,IAAItE,EAAM,YAAW,EAAIA,CAAK,EAGvC,OAAOsE,CACT,CCvWO,MAAMmgC,GAA2B,CACtC,WACA,cACA,eACA,eACA,gBACA,mBACA,WACA,UACA,gBACA,sBACA,cACA,mBACA,oBACA,oBACA,iBACA,eACA,UACA,UACA,UACA,UACA,UACA,iBACA,UACA,UACA,cACA,eACA,WACA,eACA,qBACA,cACA,SACA,eACA,gBACA,WACA,iBACA,iBACA,aACA,WACA,UACF,ECvBahB,GAAIH,GAAQ9B,GAAM,KAAK,EAInB8B,GAAQ7B,GAAK,IAAKgD,EAAwB,ECrBpD,MAAMC,GAA0B,CACrC,QACA,MACA,SACA,QACA,SACA,QACA,SACA,OACA,OACA,SACA,MACA,SACA,QACA,SACA,OACA,KACA,SACA,QACA,SACA,OACA,KACA,SACA,SACA,QACA,SACA,SACA,SACA,OACA,OACA,MACA,QACA,SACA,QACA,SACA,OACA,SACA,SACA,QACA,QACA,QACA,SACA,MACA,QACA,SACA,OACA,SACA,SACA,QACA,OACA,OACA,SACA,MACA,SACA,SACA,QACA,SACA,MACA,OACA,SACA,SACA,SACA,KACA,SACA,QACA,QACA,SACA,SACA,OACA,QACA,KACA,OACA,QACA,SACA,OACA,MACA,SACA,SACA,QACA,SACA,OACA,OACA,SACA,SACA,OACA,OACA,SACA,QACA,OACA,QACA,MACA,OACA,MACA,OACA,OACA,OACA,QACA,QACA,QACA,SACA,QACA,SACA,MACA,OACA,SACA,MACA,MACF,EC3GaC,GAA4B,CACvC,EAAG,IACH,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IAC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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,256,257,258,259,260,261,262,263,264,265,266,267,268,269,270,271,272,273,274,275,276,277,278,279,280,281,282,283,284,285,286]}