@axdspub/axiom-ui-forms 0.2.8 → 0.2.9

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 (392) hide show
  1. package/library/axiom-ui-forms.d.ts +36 -4
  2. package/library/esm/_virtual/index10.js +2 -2
  3. package/library/esm/_virtual/index11.js +2 -2
  4. package/library/esm/_virtual/index12.js +6 -2
  5. package/library/esm/_virtual/index12.js.map +1 -1
  6. package/library/esm/_virtual/index13.js +6 -2
  7. package/library/esm/_virtual/index13.js.map +1 -1
  8. package/library/esm/_virtual/index14.js +2 -2
  9. package/library/esm/_virtual/index15.js +4 -0
  10. package/library/esm/_virtual/index15.js.map +1 -0
  11. package/library/esm/_virtual/index16.js +4 -0
  12. package/library/esm/_virtual/index16.js.map +1 -0
  13. package/library/esm/_virtual/index17.js +4 -0
  14. package/library/esm/_virtual/index17.js.map +1 -0
  15. package/library/esm/_virtual/index6.js +2 -2
  16. package/library/esm/_virtual/index6.js.map +1 -1
  17. package/library/esm/_virtual/index7.js +2 -2
  18. package/library/esm/_virtual/index7.js.map +1 -1
  19. package/library/esm/_virtual/index8.js +2 -2
  20. package/library/esm/_virtual/index9.js +2 -2
  21. package/library/esm/_virtual/utilities.js +4 -0
  22. package/library/esm/_virtual/utilities.js.map +1 -0
  23. package/library/esm/node_modules/@axdspub/axiom-ui-utilities/library/index.js +241 -9
  24. package/library/esm/node_modules/@axdspub/axiom-ui-utilities/library/index.js.map +1 -1
  25. package/library/esm/node_modules/@babel/runtime/helpers/esm/extends.js +12 -0
  26. package/library/esm/node_modules/@babel/runtime/helpers/esm/extends.js.map +1 -0
  27. package/library/esm/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js +12 -0
  28. package/library/esm/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js.map +1 -0
  29. package/library/esm/node_modules/@codemirror/autocomplete/dist/index.js +1652 -0
  30. package/library/esm/node_modules/@codemirror/autocomplete/dist/index.js.map +1 -0
  31. package/library/esm/node_modules/@codemirror/commands/dist/index.js +1444 -0
  32. package/library/esm/node_modules/@codemirror/commands/dist/index.js.map +1 -0
  33. package/library/esm/node_modules/@codemirror/lang-json/dist/index.js +33 -0
  34. package/library/esm/node_modules/@codemirror/lang-json/dist/index.js.map +1 -0
  35. package/library/esm/node_modules/@codemirror/lang-yaml/dist/index.js +59 -0
  36. package/library/esm/node_modules/@codemirror/lang-yaml/dist/index.js.map +1 -0
  37. package/library/esm/node_modules/@codemirror/language/dist/index.js +1821 -0
  38. package/library/esm/node_modules/@codemirror/language/dist/index.js.map +1 -0
  39. package/library/esm/node_modules/@codemirror/lint/dist/index.js +589 -0
  40. package/library/esm/node_modules/@codemirror/lint/dist/index.js.map +1 -0
  41. package/library/esm/node_modules/@codemirror/search/dist/index.js +1227 -0
  42. package/library/esm/node_modules/@codemirror/search/dist/index.js.map +1 -0
  43. package/library/esm/node_modules/@codemirror/state/dist/index.js +3882 -0
  44. package/library/esm/node_modules/@codemirror/state/dist/index.js.map +1 -0
  45. package/library/esm/node_modules/@codemirror/theme-one-dark/dist/index.js +114 -0
  46. package/library/esm/node_modules/@codemirror/theme-one-dark/dist/index.js.map +1 -0
  47. package/library/esm/node_modules/@codemirror/view/dist/index.js +11052 -0
  48. package/library/esm/node_modules/@codemirror/view/dist/index.js.map +1 -0
  49. package/library/esm/node_modules/@lezer/common/dist/index.js +1704 -0
  50. package/library/esm/node_modules/@lezer/common/dist/index.js.map +1 -0
  51. package/library/esm/node_modules/@lezer/highlight/dist/index.js +876 -0
  52. package/library/esm/node_modules/@lezer/highlight/dist/index.js.map +1 -0
  53. package/library/esm/node_modules/@lezer/json/dist/index.js +38 -0
  54. package/library/esm/node_modules/@lezer/json/dist/index.js.map +1 -0
  55. package/library/esm/node_modules/@lezer/lr/dist/index.js +1855 -0
  56. package/library/esm/node_modules/@lezer/lr/dist/index.js.map +1 -0
  57. package/library/esm/node_modules/@lezer/yaml/dist/index.js +392 -0
  58. package/library/esm/node_modules/@lezer/yaml/dist/index.js.map +1 -0
  59. package/library/esm/node_modules/@marijn/find-cluster-break/src/index.js +83 -0
  60. package/library/esm/node_modules/@marijn/find-cluster-break/src/index.js.map +1 -0
  61. package/library/esm/node_modules/@radix-ui/react-icons/dist/react-icons.esm.js +67 -1
  62. package/library/esm/node_modules/@radix-ui/react-icons/dist/react-icons.esm.js.map +1 -1
  63. package/library/esm/node_modules/@uiw/codemirror-extensions-basic-setup/esm/index.js +100 -0
  64. package/library/esm/node_modules/@uiw/codemirror-extensions-basic-setup/esm/index.js.map +1 -0
  65. package/library/esm/node_modules/@uiw/react-codemirror/esm/getDefaultExtensions.js +58 -0
  66. package/library/esm/node_modules/@uiw/react-codemirror/esm/getDefaultExtensions.js.map +1 -0
  67. package/library/esm/node_modules/@uiw/react-codemirror/esm/index.js +89 -0
  68. package/library/esm/node_modules/@uiw/react-codemirror/esm/index.js.map +1 -0
  69. package/library/esm/node_modules/@uiw/react-codemirror/esm/theme/light.js +12 -0
  70. package/library/esm/node_modules/@uiw/react-codemirror/esm/theme/light.js.map +1 -0
  71. package/library/esm/node_modules/@uiw/react-codemirror/esm/useCodeMirror.js +151 -0
  72. package/library/esm/node_modules/@uiw/react-codemirror/esm/useCodeMirror.js.map +1 -0
  73. package/library/esm/node_modules/@uiw/react-codemirror/esm/utils.js +19 -0
  74. package/library/esm/node_modules/@uiw/react-codemirror/esm/utils.js.map +1 -0
  75. package/library/esm/node_modules/@ungap/structured-clone/esm/deserialize.js +77 -0
  76. package/library/esm/node_modules/@ungap/structured-clone/esm/deserialize.js.map +1 -0
  77. package/library/esm/node_modules/@ungap/structured-clone/esm/index.js +25 -0
  78. package/library/esm/node_modules/@ungap/structured-clone/esm/index.js.map +1 -0
  79. package/library/esm/node_modules/@ungap/structured-clone/esm/serialize.js +159 -0
  80. package/library/esm/node_modules/@ungap/structured-clone/esm/serialize.js.map +1 -0
  81. package/library/esm/node_modules/@ungap/structured-clone/esm/types.js +14 -0
  82. package/library/esm/node_modules/@ungap/structured-clone/esm/types.js.map +1 -0
  83. package/library/esm/node_modules/ajv/dist/compile/index.js +1 -1
  84. package/library/esm/node_modules/ajv/dist/vocabularies/applicator/index.js +1 -1
  85. package/library/esm/node_modules/ajv/dist/vocabularies/core/index.js +1 -1
  86. package/library/esm/node_modules/ajv/dist/vocabularies/format/index.js +1 -1
  87. package/library/esm/node_modules/ajv/dist/vocabularies/validation/index.js +1 -1
  88. package/library/esm/node_modules/bail/index.js +15 -0
  89. package/library/esm/node_modules/bail/index.js.map +1 -0
  90. package/library/esm/node_modules/comma-separated-tokens/index.js +37 -0
  91. package/library/esm/node_modules/comma-separated-tokens/index.js.map +1 -0
  92. package/library/esm/node_modules/crelt/index.js +30 -0
  93. package/library/esm/node_modules/crelt/index.js.map +1 -0
  94. package/library/esm/node_modules/decode-named-character-reference/index.dom.js +39 -0
  95. package/library/esm/node_modules/decode-named-character-reference/index.dom.js.map +1 -0
  96. package/library/esm/node_modules/devlop/lib/default.js +6 -0
  97. package/library/esm/node_modules/devlop/lib/default.js.map +1 -0
  98. package/library/esm/node_modules/estree-util-is-identifier-name/lib/index.js +31 -0
  99. package/library/esm/node_modules/estree-util-is-identifier-name/lib/index.js.map +1 -0
  100. package/library/esm/node_modules/extend/index.js +127 -0
  101. package/library/esm/node_modules/extend/index.js.map +1 -0
  102. package/library/esm/node_modules/fast-uri/index.js +1 -1
  103. package/library/esm/node_modules/hast-util-to-jsx-runtime/lib/index.js +791 -0
  104. package/library/esm/node_modules/hast-util-to-jsx-runtime/lib/index.js.map +1 -0
  105. package/library/esm/node_modules/hast-util-whitespace/lib/index.js +37 -0
  106. package/library/esm/node_modules/hast-util-whitespace/lib/index.js.map +1 -0
  107. package/library/esm/node_modules/html-url-attributes/lib/index.js +34 -0
  108. package/library/esm/node_modules/html-url-attributes/lib/index.js.map +1 -0
  109. package/library/esm/node_modules/inline-style-parser/index.js +268 -0
  110. package/library/esm/node_modules/inline-style-parser/index.js.map +1 -0
  111. package/library/esm/node_modules/js-yaml/dist/js-yaml.js +3850 -0
  112. package/library/esm/node_modules/js-yaml/dist/js-yaml.js.map +1 -0
  113. package/library/esm/node_modules/json-schema-traverse/index.js +1 -1
  114. package/library/esm/node_modules/mdast-util-from-markdown/lib/index.js +1181 -0
  115. package/library/esm/node_modules/mdast-util-from-markdown/lib/index.js.map +1 -0
  116. package/library/esm/node_modules/mdast-util-to-hast/lib/footer.js +197 -0
  117. package/library/esm/node_modules/mdast-util-to-hast/lib/footer.js.map +1 -0
  118. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/blockquote.js +31 -0
  119. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/blockquote.js.map +1 -0
  120. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/break.js +27 -0
  121. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/break.js.map +1 -0
  122. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/code.js +51 -0
  123. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/code.js.map +1 -0
  124. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/delete.js +31 -0
  125. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/delete.js.map +1 -0
  126. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/emphasis.js +31 -0
  127. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/emphasis.js.map +1 -0
  128. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/footnote-reference.js +74 -0
  129. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/footnote-reference.js.map +1 -0
  130. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/heading.js +31 -0
  131. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/heading.js.map +1 -0
  132. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/html.js +32 -0
  133. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/html.js.map +1 -0
  134. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/image-reference.js +45 -0
  135. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/image-reference.js.map +1 -0
  136. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/image.js +40 -0
  137. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/image.js.map +1 -0
  138. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/index.js +67 -0
  139. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/index.js.map +1 -0
  140. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/inline-code.js +36 -0
  141. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/inline-code.js.map +1 -0
  142. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/link-reference.js +50 -0
  143. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/link-reference.js.map +1 -0
  144. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/link.js +41 -0
  145. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/link.js.map +1 -0
  146. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/list-item.js +126 -0
  147. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/list-item.js.map +1 -0
  148. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/list.js +57 -0
  149. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/list.js.map +1 -0
  150. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/paragraph.js +31 -0
  151. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/paragraph.js.map +1 -0
  152. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/root.js +27 -0
  153. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/root.js.map +1 -0
  154. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/strong.js +31 -0
  155. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/strong.js.map +1 -0
  156. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/table-cell.js +33 -0
  157. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/table-cell.js.map +1 -0
  158. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/table-row.js +70 -0
  159. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/table-row.js.map +1 -0
  160. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/table.js +65 -0
  161. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/table.js.map +1 -0
  162. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/text.js +29 -0
  163. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/text.js.map +1 -0
  164. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/thematic-break.js +31 -0
  165. package/library/esm/node_modules/mdast-util-to-hast/lib/handlers/thematic-break.js.map +1 -0
  166. package/library/esm/node_modules/mdast-util-to-hast/lib/index.js +105 -0
  167. package/library/esm/node_modules/mdast-util-to-hast/lib/index.js.map +1 -0
  168. package/library/esm/node_modules/mdast-util-to-hast/lib/revert.js +56 -0
  169. package/library/esm/node_modules/mdast-util-to-hast/lib/revert.js.map +1 -0
  170. package/library/esm/node_modules/mdast-util-to-hast/lib/state.js +322 -0
  171. package/library/esm/node_modules/mdast-util-to-hast/lib/state.js.map +1 -0
  172. package/library/esm/node_modules/mdast-util-to-string/lib/index.js +111 -0
  173. package/library/esm/node_modules/mdast-util-to-string/lib/index.js.map +1 -0
  174. package/library/esm/node_modules/micromark/lib/constructs.js +108 -0
  175. package/library/esm/node_modules/micromark/lib/constructs.js.map +1 -0
  176. package/library/esm/node_modules/micromark/lib/create-tokenizer.js +576 -0
  177. package/library/esm/node_modules/micromark/lib/create-tokenizer.js.map +1 -0
  178. package/library/esm/node_modules/micromark/lib/initialize/content.js +83 -0
  179. package/library/esm/node_modules/micromark/lib/initialize/content.js.map +1 -0
  180. package/library/esm/node_modules/micromark/lib/initialize/document.js +361 -0
  181. package/library/esm/node_modules/micromark/lib/initialize/document.js.map +1 -0
  182. package/library/esm/node_modules/micromark/lib/initialize/flow.js +62 -0
  183. package/library/esm/node_modules/micromark/lib/initialize/flow.js.map +1 -0
  184. package/library/esm/node_modules/micromark/lib/initialize/text.js +213 -0
  185. package/library/esm/node_modules/micromark/lib/initialize/text.js.map +1 -0
  186. package/library/esm/node_modules/micromark/lib/parse.js +60 -0
  187. package/library/esm/node_modules/micromark/lib/parse.js.map +1 -0
  188. package/library/esm/node_modules/micromark/lib/postprocess.js +22 -0
  189. package/library/esm/node_modules/micromark/lib/postprocess.js.map +1 -0
  190. package/library/esm/node_modules/micromark/lib/preprocess.js +118 -0
  191. package/library/esm/node_modules/micromark/lib/preprocess.js.map +1 -0
  192. package/library/esm/node_modules/micromark-core-commonmark/lib/attention.js +245 -0
  193. package/library/esm/node_modules/micromark-core-commonmark/lib/attention.js.map +1 -0
  194. package/library/esm/node_modules/micromark-core-commonmark/lib/autolink.js +237 -0
  195. package/library/esm/node_modules/micromark-core-commonmark/lib/autolink.js.map +1 -0
  196. package/library/esm/node_modules/micromark-core-commonmark/lib/blank-line.js +65 -0
  197. package/library/esm/node_modules/micromark-core-commonmark/lib/blank-line.js.map +1 -0
  198. package/library/esm/node_modules/micromark-core-commonmark/lib/block-quote.js +147 -0
  199. package/library/esm/node_modules/micromark-core-commonmark/lib/block-quote.js.map +1 -0
  200. package/library/esm/node_modules/micromark-core-commonmark/lib/character-escape.js +68 -0
  201. package/library/esm/node_modules/micromark-core-commonmark/lib/character-escape.js.map +1 -0
  202. package/library/esm/node_modules/micromark-core-commonmark/lib/character-reference.js +153 -0
  203. package/library/esm/node_modules/micromark-core-commonmark/lib/character-reference.js.map +1 -0
  204. package/library/esm/node_modules/micromark-core-commonmark/lib/code-fenced.js +464 -0
  205. package/library/esm/node_modules/micromark-core-commonmark/lib/code-fenced.js.map +1 -0
  206. package/library/esm/node_modules/micromark-core-commonmark/lib/code-indented.js +181 -0
  207. package/library/esm/node_modules/micromark-core-commonmark/lib/code-indented.js.map +1 -0
  208. package/library/esm/node_modules/micromark-core-commonmark/lib/code-text.js +228 -0
  209. package/library/esm/node_modules/micromark-core-commonmark/lib/code-text.js.map +1 -0
  210. package/library/esm/node_modules/micromark-core-commonmark/lib/content.js +167 -0
  211. package/library/esm/node_modules/micromark-core-commonmark/lib/content.js.map +1 -0
  212. package/library/esm/node_modules/micromark-core-commonmark/lib/definition.js +258 -0
  213. package/library/esm/node_modules/micromark-core-commonmark/lib/definition.js.map +1 -0
  214. package/library/esm/node_modules/micromark-core-commonmark/lib/hard-break-escape.js +64 -0
  215. package/library/esm/node_modules/micromark-core-commonmark/lib/hard-break-escape.js.map +1 -0
  216. package/library/esm/node_modules/micromark-core-commonmark/lib/heading-atx.js +199 -0
  217. package/library/esm/node_modules/micromark-core-commonmark/lib/heading-atx.js.map +1 -0
  218. package/library/esm/node_modules/micromark-core-commonmark/lib/html-flow.js +880 -0
  219. package/library/esm/node_modules/micromark-core-commonmark/lib/html-flow.js.map +1 -0
  220. package/library/esm/node_modules/micromark-core-commonmark/lib/html-text.js +682 -0
  221. package/library/esm/node_modules/micromark-core-commonmark/lib/html-text.js.map +1 -0
  222. package/library/esm/node_modules/micromark-core-commonmark/lib/label-end.js +564 -0
  223. package/library/esm/node_modules/micromark-core-commonmark/lib/label-end.js.map +1 -0
  224. package/library/esm/node_modules/micromark-core-commonmark/lib/label-start-image.js +106 -0
  225. package/library/esm/node_modules/micromark-core-commonmark/lib/label-start-image.js.map +1 -0
  226. package/library/esm/node_modules/micromark-core-commonmark/lib/label-start-link.js +59 -0
  227. package/library/esm/node_modules/micromark-core-commonmark/lib/label-start-link.js.map +1 -0
  228. package/library/esm/node_modules/micromark-core-commonmark/lib/line-ending.js +36 -0
  229. package/library/esm/node_modules/micromark-core-commonmark/lib/line-ending.js.map +1 -0
  230. package/library/esm/node_modules/micromark-core-commonmark/lib/list.js +217 -0
  231. package/library/esm/node_modules/micromark-core-commonmark/lib/list.js.map +1 -0
  232. package/library/esm/node_modules/micromark-core-commonmark/lib/setext-underline.js +189 -0
  233. package/library/esm/node_modules/micromark-core-commonmark/lib/setext-underline.js.map +1 -0
  234. package/library/esm/node_modules/micromark-core-commonmark/lib/thematic-break.js +106 -0
  235. package/library/esm/node_modules/micromark-core-commonmark/lib/thematic-break.js.map +1 -0
  236. package/library/esm/node_modules/micromark-factory-destination/index.js +210 -0
  237. package/library/esm/node_modules/micromark-factory-destination/index.js.map +1 -0
  238. package/library/esm/node_modules/micromark-factory-label/index.js +152 -0
  239. package/library/esm/node_modules/micromark-factory-label/index.js.map +1 -0
  240. package/library/esm/node_modules/micromark-factory-space/index.js +68 -0
  241. package/library/esm/node_modules/micromark-factory-space/index.js.map +1 -0
  242. package/library/esm/node_modules/micromark-factory-title/index.js +162 -0
  243. package/library/esm/node_modules/micromark-factory-title/index.js.map +1 -0
  244. package/library/esm/node_modules/micromark-factory-whitespace/index.js +48 -0
  245. package/library/esm/node_modules/micromark-factory-whitespace/index.js.map +1 -0
  246. package/library/esm/node_modules/micromark-util-character/index.js +249 -0
  247. package/library/esm/node_modules/micromark-util-character/index.js.map +1 -0
  248. package/library/esm/node_modules/micromark-util-chunked/index.js +84 -0
  249. package/library/esm/node_modules/micromark-util-chunked/index.js.map +1 -0
  250. package/library/esm/node_modules/micromark-util-classify-character/index.js +31 -0
  251. package/library/esm/node_modules/micromark-util-classify-character/index.js.map +1 -0
  252. package/library/esm/node_modules/micromark-util-combine-extensions/index.js +96 -0
  253. package/library/esm/node_modules/micromark-util-combine-extensions/index.js.map +1 -0
  254. package/library/esm/node_modules/micromark-util-decode-numeric-character-reference/index.js +35 -0
  255. package/library/esm/node_modules/micromark-util-decode-numeric-character-reference/index.js.map +1 -0
  256. package/library/esm/node_modules/micromark-util-decode-string/index.js +49 -0
  257. package/library/esm/node_modules/micromark-util-decode-string/index.js.map +1 -0
  258. package/library/esm/node_modules/micromark-util-html-tag-name/index.js +96 -0
  259. package/library/esm/node_modules/micromark-util-html-tag-name/index.js.map +1 -0
  260. package/library/esm/node_modules/micromark-util-normalize-identifier/index.js +36 -0
  261. package/library/esm/node_modules/micromark-util-normalize-identifier/index.js.map +1 -0
  262. package/library/esm/node_modules/micromark-util-resolve-all/index.js +35 -0
  263. package/library/esm/node_modules/micromark-util-resolve-all/index.js.map +1 -0
  264. package/library/esm/node_modules/micromark-util-sanitize-uri/index.js +67 -0
  265. package/library/esm/node_modules/micromark-util-sanitize-uri/index.js.map +1 -0
  266. package/library/esm/node_modules/micromark-util-subtokenize/index.js +227 -0
  267. package/library/esm/node_modules/micromark-util-subtokenize/index.js.map +1 -0
  268. package/library/esm/node_modules/micromark-util-subtokenize/lib/splice-buffer.js +254 -0
  269. package/library/esm/node_modules/micromark-util-subtokenize/lib/splice-buffer.js.map +1 -0
  270. package/library/esm/node_modules/property-information/index.js +16 -0
  271. package/library/esm/node_modules/property-information/index.js.map +1 -0
  272. package/library/esm/node_modules/property-information/lib/aria.js +64 -0
  273. package/library/esm/node_modules/property-information/lib/aria.js.map +1 -0
  274. package/library/esm/node_modules/property-information/lib/find.js +101 -0
  275. package/library/esm/node_modules/property-information/lib/find.js.map +1 -0
  276. package/library/esm/node_modules/property-information/lib/hast-to-react.js +33 -0
  277. package/library/esm/node_modules/property-information/lib/hast-to-react.js.map +1 -0
  278. package/library/esm/node_modules/property-information/lib/html.js +318 -0
  279. package/library/esm/node_modules/property-information/lib/html.js.map +1 -0
  280. package/library/esm/node_modules/property-information/lib/normalize.js +15 -0
  281. package/library/esm/node_modules/property-information/lib/normalize.js.map +1 -0
  282. package/library/esm/node_modules/property-information/lib/svg.js +564 -0
  283. package/library/esm/node_modules/property-information/lib/svg.js.map +1 -0
  284. package/library/esm/node_modules/property-information/lib/util/case-insensitive-transform.js +16 -0
  285. package/library/esm/node_modules/property-information/lib/util/case-insensitive-transform.js.map +1 -0
  286. package/library/esm/node_modules/property-information/lib/util/case-sensitive-transform.js +14 -0
  287. package/library/esm/node_modules/property-information/lib/util/case-sensitive-transform.js.map +1 -0
  288. package/library/esm/node_modules/property-information/lib/util/create.js +47 -0
  289. package/library/esm/node_modules/property-information/lib/util/create.js.map +1 -0
  290. package/library/esm/node_modules/property-information/lib/util/defined-info.js +64 -0
  291. package/library/esm/node_modules/property-information/lib/util/defined-info.js.map +1 -0
  292. package/library/esm/node_modules/property-information/lib/util/info.js +35 -0
  293. package/library/esm/node_modules/property-information/lib/util/info.js.map +1 -0
  294. package/library/esm/node_modules/property-information/lib/util/merge.js +31 -0
  295. package/library/esm/node_modules/property-information/lib/util/merge.js.map +1 -0
  296. package/library/esm/node_modules/property-information/lib/util/schema.js +32 -0
  297. package/library/esm/node_modules/property-information/lib/util/schema.js.map +1 -0
  298. package/library/esm/node_modules/property-information/lib/util/types.js +16 -0
  299. package/library/esm/node_modules/property-information/lib/util/types.js.map +1 -0
  300. package/library/esm/node_modules/property-information/lib/xlink.js +20 -0
  301. package/library/esm/node_modules/property-information/lib/xlink.js.map +1 -0
  302. package/library/esm/node_modules/property-information/lib/xml.js +12 -0
  303. package/library/esm/node_modules/property-information/lib/xml.js.map +1 -0
  304. package/library/esm/node_modules/property-information/lib/xmlns.js +12 -0
  305. package/library/esm/node_modules/property-information/lib/xmlns.js.map +1 -0
  306. package/library/esm/node_modules/react-markdown/lib/index.js +267 -0
  307. package/library/esm/node_modules/react-markdown/lib/index.js.map +1 -0
  308. package/library/esm/node_modules/react-router/dist/development/chunk-HA7DTUK3.js +1 -1
  309. package/library/esm/node_modules/react-router/node_modules/cookie/dist/index.js +1 -1
  310. package/library/esm/node_modules/remark-parse/lib/index.js +43 -0
  311. package/library/esm/node_modules/remark-parse/lib/index.js.map +1 -0
  312. package/library/esm/node_modules/remark-rehype/lib/index.js +132 -0
  313. package/library/esm/node_modules/remark-rehype/lib/index.js.map +1 -0
  314. package/library/esm/node_modules/space-separated-tokens/index.js +23 -0
  315. package/library/esm/node_modules/space-separated-tokens/index.js.map +1 -0
  316. package/library/esm/node_modules/style-mod/src/style-mod.js +175 -0
  317. package/library/esm/node_modules/style-mod/src/style-mod.js.map +1 -0
  318. package/library/esm/node_modules/style-to-js/cjs/index.js +38 -0
  319. package/library/esm/node_modules/style-to-js/cjs/index.js.map +1 -0
  320. package/library/esm/node_modules/style-to-js/cjs/utilities.js +58 -0
  321. package/library/esm/node_modules/style-to-js/cjs/utilities.js.map +1 -0
  322. package/library/esm/node_modules/style-to-object/cjs/index.js +56 -0
  323. package/library/esm/node_modules/style-to-object/cjs/index.js.map +1 -0
  324. package/library/esm/node_modules/trim-lines/index.js +72 -0
  325. package/library/esm/node_modules/trim-lines/index.js.map +1 -0
  326. package/library/esm/node_modules/trough/lib/index.js +209 -0
  327. package/library/esm/node_modules/trough/lib/index.js.map +1 -0
  328. package/library/esm/node_modules/unified/lib/callable-instance.js +47 -0
  329. package/library/esm/node_modules/unified/lib/callable-instance.js.map +1 -0
  330. package/library/esm/node_modules/unified/lib/index.js +979 -0
  331. package/library/esm/node_modules/unified/lib/index.js.map +1 -0
  332. package/library/esm/node_modules/unified/node_modules/is-plain-obj/index.js +11 -0
  333. package/library/esm/node_modules/unified/node_modules/is-plain-obj/index.js.map +1 -0
  334. package/library/esm/node_modules/unist-util-is/lib/index.js +179 -0
  335. package/library/esm/node_modules/unist-util-is/lib/index.js.map +1 -0
  336. package/library/esm/node_modules/unist-util-position/lib/index.js +98 -0
  337. package/library/esm/node_modules/unist-util-position/lib/index.js.map +1 -0
  338. package/library/esm/node_modules/unist-util-stringify-position/lib/index.js +87 -0
  339. package/library/esm/node_modules/unist-util-stringify-position/lib/index.js.map +1 -0
  340. package/library/esm/node_modules/unist-util-visit/lib/index.js +95 -0
  341. package/library/esm/node_modules/unist-util-visit/lib/index.js.map +1 -0
  342. package/library/esm/node_modules/unist-util-visit-parents/lib/color.js +10 -0
  343. package/library/esm/node_modules/unist-util-visit-parents/lib/color.js.map +1 -0
  344. package/library/esm/node_modules/unist-util-visit-parents/lib/index.js +188 -0
  345. package/library/esm/node_modules/unist-util-visit-parents/lib/index.js.map +1 -0
  346. package/library/esm/node_modules/vfile/lib/index.js +644 -0
  347. package/library/esm/node_modules/vfile/lib/index.js.map +1 -0
  348. package/library/esm/node_modules/vfile/lib/minpath.browser.js +427 -0
  349. package/library/esm/node_modules/vfile/lib/minpath.browser.js.map +1 -0
  350. package/library/esm/node_modules/vfile/lib/minproc.browser.js +11 -0
  351. package/library/esm/node_modules/vfile/lib/minproc.browser.js.map +1 -0
  352. package/library/esm/node_modules/vfile/lib/minurl.browser.js +77 -0
  353. package/library/esm/node_modules/vfile/lib/minurl.browser.js.map +1 -0
  354. package/library/esm/node_modules/vfile/lib/minurl.shared.js +34 -0
  355. package/library/esm/node_modules/vfile/lib/minurl.shared.js.map +1 -0
  356. package/library/esm/node_modules/vfile-message/lib/index.js +305 -0
  357. package/library/esm/node_modules/vfile-message/lib/index.js.map +1 -0
  358. package/library/esm/node_modules/w3c-keyname/index.js +122 -0
  359. package/library/esm/node_modules/w3c-keyname/index.js.map +1 -0
  360. package/library/esm/src/Form/Components/FieldLabel.js +13 -3
  361. package/library/esm/src/Form/Components/FieldLabel.js.map +1 -1
  362. package/library/esm/src/Form/Components/InlineMarkdown.js +15 -0
  363. package/library/esm/src/Form/Components/InlineMarkdown.js.map +1 -0
  364. package/library/esm/src/Form/Components/Inputs/Boolean.js +5 -2
  365. package/library/esm/src/Form/Components/Inputs/Boolean.js.map +1 -1
  366. package/library/esm/src/Form/Components/Inputs/GeoJSONInputLoader.js +1 -1
  367. package/library/esm/src/Form/Components/Inputs/Geometry.js +290 -329
  368. package/library/esm/src/Form/Components/Inputs/Geometry.js.map +1 -1
  369. package/library/esm/src/Form/Components/Inputs/JSON.js +132 -0
  370. package/library/esm/src/Form/Components/Inputs/JSON.js.map +1 -0
  371. package/library/esm/src/Form/Components/Inputs/JSONInputLoader.js +19 -0
  372. package/library/esm/src/Form/Components/Inputs/JSONInputLoader.js.map +1 -0
  373. package/library/esm/src/Form/Components/Inputs/Number.js +78 -8
  374. package/library/esm/src/Form/Components/Inputs/Number.js.map +1 -1
  375. package/library/esm/src/Form/Components/Inputs/inputMap.js +2 -2
  376. package/library/esm/src/Form/Components/Inputs/inputMap.js.map +1 -1
  377. package/library/esm/src/Form/Creator/FormCreator.js +6 -2
  378. package/library/esm/src/Form/Creator/FormCreator.js.map +1 -1
  379. package/library/esm/src/Form/Creator/FormHeader.js +7 -5
  380. package/library/esm/src/Form/Creator/FormHeader.js.map +1 -1
  381. package/library/esm/src/Form/Creator/Page.js +4 -3
  382. package/library/esm/src/Form/Creator/Page.js.map +1 -1
  383. package/library/esm/src/Form/Manage/CopyableJSONOutput.js +41 -0
  384. package/library/esm/src/Form/Manage/CopyableJSONOutput.js.map +1 -0
  385. package/library/esm/src/Form/helpers.js +1 -1
  386. package/library/esm/src/Form/helpers.js.map +1 -1
  387. package/library/esm/src/Form/schemaToFormHelpers.js +87 -1
  388. package/library/esm/src/Form/schemaToFormHelpers.js.map +1 -1
  389. package/library/esm/src/library.js +1 -1
  390. package/package.json +7 -1
  391. package/library/esm/src/Form/Components/Inputs/JSONString.js +0 -34
  392. package/library/esm/src/Form/Components/Inputs/JSONString.js.map +0 -1
@@ -0,0 +1,1444 @@
1
+ import { EditorSelection, countColumn, Text, StateField, Facet, findClusterBreak, Annotation, Transaction, combineConfig, StateEffect, ChangeSet, ChangeDesc } from '../../state/dist/index.js';
2
+ import { EditorView, Direction } from '../../view/dist/index.js';
3
+ import { IndentContext, getIndentation, indentString, syntaxTree, matchBrackets, getIndentUnit, indentUnit } from '../../language/dist/index.js';
4
+ import { NodeProp } from '../../../@lezer/common/dist/index.js';
5
+
6
+ /**
7
+ Comment or uncomment the current selection. Will use line comments
8
+ if available, otherwise falling back to block comments.
9
+ */
10
+ const toggleComment = target => {
11
+ let { state } = target, line = state.doc.lineAt(state.selection.main.from), config = getConfig(target.state, line.from);
12
+ return config.line ? toggleLineComment(target) : config.block ? toggleBlockCommentByLine(target) : false;
13
+ };
14
+ function command(f, option) {
15
+ return ({ state, dispatch }) => {
16
+ if (state.readOnly)
17
+ return false;
18
+ let tr = f(option, state);
19
+ if (!tr)
20
+ return false;
21
+ dispatch(state.update(tr));
22
+ return true;
23
+ };
24
+ }
25
+ /**
26
+ Comment or uncomment the current selection using line comments.
27
+ The line comment syntax is taken from the
28
+ [`commentTokens`](https://codemirror.net/6/docs/ref/#commands.CommentTokens) [language
29
+ data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt).
30
+ */
31
+ const toggleLineComment = /*@__PURE__*/command(changeLineComment, 0 /* CommentOption.Toggle */);
32
+ /**
33
+ Comment or uncomment the current selection using block comments.
34
+ The block comment syntax is taken from the
35
+ [`commentTokens`](https://codemirror.net/6/docs/ref/#commands.CommentTokens) [language
36
+ data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt).
37
+ */
38
+ const toggleBlockComment = /*@__PURE__*/command(changeBlockComment, 0 /* CommentOption.Toggle */);
39
+ /**
40
+ Comment or uncomment the lines around the current selection using
41
+ block comments.
42
+ */
43
+ const toggleBlockCommentByLine = /*@__PURE__*/command((o, s) => changeBlockComment(o, s, selectedLineRanges(s)), 0 /* CommentOption.Toggle */);
44
+ function getConfig(state, pos) {
45
+ let data = state.languageDataAt("commentTokens", pos, 1);
46
+ return data.length ? data[0] : {};
47
+ }
48
+ const SearchMargin = 50;
49
+ /**
50
+ Determines if the given range is block-commented in the given
51
+ state.
52
+ */
53
+ function findBlockComment(state, { open, close }, from, to) {
54
+ let textBefore = state.sliceDoc(from - SearchMargin, from);
55
+ let textAfter = state.sliceDoc(to, to + SearchMargin);
56
+ let spaceBefore = /\s*$/.exec(textBefore)[0].length, spaceAfter = /^\s*/.exec(textAfter)[0].length;
57
+ let beforeOff = textBefore.length - spaceBefore;
58
+ if (textBefore.slice(beforeOff - open.length, beforeOff) == open &&
59
+ textAfter.slice(spaceAfter, spaceAfter + close.length) == close) {
60
+ return { open: { pos: from - spaceBefore, margin: spaceBefore && 1 },
61
+ close: { pos: to + spaceAfter, margin: spaceAfter && 1 } };
62
+ }
63
+ let startText, endText;
64
+ if (to - from <= 2 * SearchMargin) {
65
+ startText = endText = state.sliceDoc(from, to);
66
+ }
67
+ else {
68
+ startText = state.sliceDoc(from, from + SearchMargin);
69
+ endText = state.sliceDoc(to - SearchMargin, to);
70
+ }
71
+ let startSpace = /^\s*/.exec(startText)[0].length, endSpace = /\s*$/.exec(endText)[0].length;
72
+ let endOff = endText.length - endSpace - close.length;
73
+ if (startText.slice(startSpace, startSpace + open.length) == open &&
74
+ endText.slice(endOff, endOff + close.length) == close) {
75
+ return { open: { pos: from + startSpace + open.length,
76
+ margin: /\s/.test(startText.charAt(startSpace + open.length)) ? 1 : 0 },
77
+ close: { pos: to - endSpace - close.length,
78
+ margin: /\s/.test(endText.charAt(endOff - 1)) ? 1 : 0 } };
79
+ }
80
+ return null;
81
+ }
82
+ function selectedLineRanges(state) {
83
+ let ranges = [];
84
+ for (let r of state.selection.ranges) {
85
+ let fromLine = state.doc.lineAt(r.from);
86
+ let toLine = r.to <= fromLine.to ? fromLine : state.doc.lineAt(r.to);
87
+ if (toLine.from > fromLine.from && toLine.from == r.to)
88
+ toLine = r.to == fromLine.to + 1 ? fromLine : state.doc.lineAt(r.to - 1);
89
+ let last = ranges.length - 1;
90
+ if (last >= 0 && ranges[last].to > fromLine.from)
91
+ ranges[last].to = toLine.to;
92
+ else
93
+ ranges.push({ from: fromLine.from + /^\s*/.exec(fromLine.text)[0].length, to: toLine.to });
94
+ }
95
+ return ranges;
96
+ }
97
+ // Performs toggle, comment and uncomment of block comments in
98
+ // languages that support them.
99
+ function changeBlockComment(option, state, ranges = state.selection.ranges) {
100
+ let tokens = ranges.map(r => getConfig(state, r.from).block);
101
+ if (!tokens.every(c => c))
102
+ return null;
103
+ let comments = ranges.map((r, i) => findBlockComment(state, tokens[i], r.from, r.to));
104
+ if (option != 2 /* CommentOption.Uncomment */ && !comments.every(c => c)) {
105
+ return { changes: state.changes(ranges.map((range, i) => {
106
+ if (comments[i])
107
+ return [];
108
+ return [{ from: range.from, insert: tokens[i].open + " " }, { from: range.to, insert: " " + tokens[i].close }];
109
+ })) };
110
+ }
111
+ else if (option != 1 /* CommentOption.Comment */ && comments.some(c => c)) {
112
+ let changes = [];
113
+ for (let i = 0, comment; i < comments.length; i++)
114
+ if (comment = comments[i]) {
115
+ let token = tokens[i], { open, close } = comment;
116
+ changes.push({ from: open.pos - token.open.length, to: open.pos + open.margin }, { from: close.pos - close.margin, to: close.pos + token.close.length });
117
+ }
118
+ return { changes };
119
+ }
120
+ return null;
121
+ }
122
+ // Performs toggle, comment and uncomment of line comments.
123
+ function changeLineComment(option, state, ranges = state.selection.ranges) {
124
+ let lines = [];
125
+ let prevLine = -1;
126
+ for (let { from, to } of ranges) {
127
+ let startI = lines.length, minIndent = 1e9;
128
+ let token = getConfig(state, from).line;
129
+ if (!token)
130
+ continue;
131
+ for (let pos = from; pos <= to;) {
132
+ let line = state.doc.lineAt(pos);
133
+ if (line.from > prevLine && (from == to || to > line.from)) {
134
+ prevLine = line.from;
135
+ let indent = /^\s*/.exec(line.text)[0].length;
136
+ let empty = indent == line.length;
137
+ let comment = line.text.slice(indent, indent + token.length) == token ? indent : -1;
138
+ if (indent < line.text.length && indent < minIndent)
139
+ minIndent = indent;
140
+ lines.push({ line, comment, token, indent, empty, single: false });
141
+ }
142
+ pos = line.to + 1;
143
+ }
144
+ if (minIndent < 1e9)
145
+ for (let i = startI; i < lines.length; i++)
146
+ if (lines[i].indent < lines[i].line.text.length)
147
+ lines[i].indent = minIndent;
148
+ if (lines.length == startI + 1)
149
+ lines[startI].single = true;
150
+ }
151
+ if (option != 2 /* CommentOption.Uncomment */ && lines.some(l => l.comment < 0 && (!l.empty || l.single))) {
152
+ let changes = [];
153
+ for (let { line, token, indent, empty, single } of lines)
154
+ if (single || !empty)
155
+ changes.push({ from: line.from + indent, insert: token + " " });
156
+ let changeSet = state.changes(changes);
157
+ return { changes: changeSet, selection: state.selection.map(changeSet, 1) };
158
+ }
159
+ else if (option != 1 /* CommentOption.Comment */ && lines.some(l => l.comment >= 0)) {
160
+ let changes = [];
161
+ for (let { line, comment, token } of lines)
162
+ if (comment >= 0) {
163
+ let from = line.from + comment, to = from + token.length;
164
+ if (line.text[to - line.from] == " ")
165
+ to++;
166
+ changes.push({ from, to });
167
+ }
168
+ return { changes };
169
+ }
170
+ return null;
171
+ }
172
+
173
+ const fromHistory = /*@__PURE__*/Annotation.define();
174
+ /**
175
+ Transaction annotation that will prevent that transaction from
176
+ being combined with other transactions in the undo history. Given
177
+ `"before"`, it'll prevent merging with previous transactions. With
178
+ `"after"`, subsequent transactions won't be combined with this
179
+ one. With `"full"`, the transaction is isolated on both sides.
180
+ */
181
+ const isolateHistory = /*@__PURE__*/Annotation.define();
182
+ /**
183
+ This facet provides a way to register functions that, given a
184
+ transaction, provide a set of effects that the history should
185
+ store when inverting the transaction. This can be used to
186
+ integrate some kinds of effects in the history, so that they can
187
+ be undone (and redone again).
188
+ */
189
+ const invertedEffects = /*@__PURE__*/Facet.define();
190
+ const historyConfig = /*@__PURE__*/Facet.define({
191
+ combine(configs) {
192
+ return combineConfig(configs, {
193
+ minDepth: 100,
194
+ newGroupDelay: 500,
195
+ joinToEvent: (_t, isAdjacent) => isAdjacent,
196
+ }, {
197
+ minDepth: Math.max,
198
+ newGroupDelay: Math.min,
199
+ joinToEvent: (a, b) => (tr, adj) => a(tr, adj) || b(tr, adj)
200
+ });
201
+ }
202
+ });
203
+ const historyField_ = /*@__PURE__*/StateField.define({
204
+ create() {
205
+ return HistoryState.empty;
206
+ },
207
+ update(state, tr) {
208
+ let config = tr.state.facet(historyConfig);
209
+ let fromHist = tr.annotation(fromHistory);
210
+ if (fromHist) {
211
+ let item = HistEvent.fromTransaction(tr, fromHist.selection), from = fromHist.side;
212
+ let other = from == 0 /* BranchName.Done */ ? state.undone : state.done;
213
+ if (item)
214
+ other = updateBranch(other, other.length, config.minDepth, item);
215
+ else
216
+ other = addSelection(other, tr.startState.selection);
217
+ return new HistoryState(from == 0 /* BranchName.Done */ ? fromHist.rest : other, from == 0 /* BranchName.Done */ ? other : fromHist.rest);
218
+ }
219
+ let isolate = tr.annotation(isolateHistory);
220
+ if (isolate == "full" || isolate == "before")
221
+ state = state.isolate();
222
+ if (tr.annotation(Transaction.addToHistory) === false)
223
+ return !tr.changes.empty ? state.addMapping(tr.changes.desc) : state;
224
+ let event = HistEvent.fromTransaction(tr);
225
+ let time = tr.annotation(Transaction.time), userEvent = tr.annotation(Transaction.userEvent);
226
+ if (event)
227
+ state = state.addChanges(event, time, userEvent, config, tr);
228
+ else if (tr.selection)
229
+ state = state.addSelection(tr.startState.selection, time, userEvent, config.newGroupDelay);
230
+ if (isolate == "full" || isolate == "after")
231
+ state = state.isolate();
232
+ return state;
233
+ },
234
+ toJSON(value) {
235
+ return { done: value.done.map(e => e.toJSON()), undone: value.undone.map(e => e.toJSON()) };
236
+ },
237
+ fromJSON(json) {
238
+ return new HistoryState(json.done.map(HistEvent.fromJSON), json.undone.map(HistEvent.fromJSON));
239
+ }
240
+ });
241
+ /**
242
+ Create a history extension with the given configuration.
243
+ */
244
+ function history(config = {}) {
245
+ return [
246
+ historyField_,
247
+ historyConfig.of(config),
248
+ EditorView.domEventHandlers({
249
+ beforeinput(e, view) {
250
+ let command = e.inputType == "historyUndo" ? undo : e.inputType == "historyRedo" ? redo : null;
251
+ if (!command)
252
+ return false;
253
+ e.preventDefault();
254
+ return command(view);
255
+ }
256
+ })
257
+ ];
258
+ }
259
+ function cmd(side, selection) {
260
+ return function ({ state, dispatch }) {
261
+ if (!selection && state.readOnly)
262
+ return false;
263
+ let historyState = state.field(historyField_, false);
264
+ if (!historyState)
265
+ return false;
266
+ let tr = historyState.pop(side, state, selection);
267
+ if (!tr)
268
+ return false;
269
+ dispatch(tr);
270
+ return true;
271
+ };
272
+ }
273
+ /**
274
+ Undo a single group of history events. Returns false if no group
275
+ was available.
276
+ */
277
+ const undo = /*@__PURE__*/cmd(0 /* BranchName.Done */, false);
278
+ /**
279
+ Redo a group of history events. Returns false if no group was
280
+ available.
281
+ */
282
+ const redo = /*@__PURE__*/cmd(1 /* BranchName.Undone */, false);
283
+ /**
284
+ Undo a change or selection change.
285
+ */
286
+ const undoSelection = /*@__PURE__*/cmd(0 /* BranchName.Done */, true);
287
+ /**
288
+ Redo a change or selection change.
289
+ */
290
+ const redoSelection = /*@__PURE__*/cmd(1 /* BranchName.Undone */, true);
291
+ // History events store groups of changes or effects that need to be
292
+ // undone/redone together.
293
+ class HistEvent {
294
+ constructor(
295
+ // The changes in this event. Normal events hold at least one
296
+ // change or effect. But it may be necessary to store selection
297
+ // events before the first change, in which case a special type of
298
+ // instance is created which doesn't hold any changes, with
299
+ // changes == startSelection == undefined
300
+ changes,
301
+ // The effects associated with this event
302
+ effects,
303
+ // Accumulated mapping (from addToHistory==false) that should be
304
+ // applied to events below this one.
305
+ mapped,
306
+ // The selection before this event
307
+ startSelection,
308
+ // Stores selection changes after this event, to be used for
309
+ // selection undo/redo.
310
+ selectionsAfter) {
311
+ this.changes = changes;
312
+ this.effects = effects;
313
+ this.mapped = mapped;
314
+ this.startSelection = startSelection;
315
+ this.selectionsAfter = selectionsAfter;
316
+ }
317
+ setSelAfter(after) {
318
+ return new HistEvent(this.changes, this.effects, this.mapped, this.startSelection, after);
319
+ }
320
+ toJSON() {
321
+ var _a, _b, _c;
322
+ return {
323
+ changes: (_a = this.changes) === null || _a === void 0 ? void 0 : _a.toJSON(),
324
+ mapped: (_b = this.mapped) === null || _b === void 0 ? void 0 : _b.toJSON(),
325
+ startSelection: (_c = this.startSelection) === null || _c === void 0 ? void 0 : _c.toJSON(),
326
+ selectionsAfter: this.selectionsAfter.map(s => s.toJSON())
327
+ };
328
+ }
329
+ static fromJSON(json) {
330
+ return new HistEvent(json.changes && ChangeSet.fromJSON(json.changes), [], json.mapped && ChangeDesc.fromJSON(json.mapped), json.startSelection && EditorSelection.fromJSON(json.startSelection), json.selectionsAfter.map(EditorSelection.fromJSON));
331
+ }
332
+ // This does not check `addToHistory` and such, it assumes the
333
+ // transaction needs to be converted to an item. Returns null when
334
+ // there are no changes or effects in the transaction.
335
+ static fromTransaction(tr, selection) {
336
+ let effects = none;
337
+ for (let invert of tr.startState.facet(invertedEffects)) {
338
+ let result = invert(tr);
339
+ if (result.length)
340
+ effects = effects.concat(result);
341
+ }
342
+ if (!effects.length && tr.changes.empty)
343
+ return null;
344
+ return new HistEvent(tr.changes.invert(tr.startState.doc), effects, undefined, selection || tr.startState.selection, none);
345
+ }
346
+ static selection(selections) {
347
+ return new HistEvent(undefined, none, undefined, undefined, selections);
348
+ }
349
+ }
350
+ function updateBranch(branch, to, maxLen, newEvent) {
351
+ let start = to + 1 > maxLen + 20 ? to - maxLen - 1 : 0;
352
+ let newBranch = branch.slice(start, to);
353
+ newBranch.push(newEvent);
354
+ return newBranch;
355
+ }
356
+ function isAdjacent(a, b) {
357
+ let ranges = [], isAdjacent = false;
358
+ a.iterChangedRanges((f, t) => ranges.push(f, t));
359
+ b.iterChangedRanges((_f, _t, f, t) => {
360
+ for (let i = 0; i < ranges.length;) {
361
+ let from = ranges[i++], to = ranges[i++];
362
+ if (t >= from && f <= to)
363
+ isAdjacent = true;
364
+ }
365
+ });
366
+ return isAdjacent;
367
+ }
368
+ function eqSelectionShape(a, b) {
369
+ return a.ranges.length == b.ranges.length &&
370
+ a.ranges.filter((r, i) => r.empty != b.ranges[i].empty).length === 0;
371
+ }
372
+ function conc(a, b) {
373
+ return !a.length ? b : !b.length ? a : a.concat(b);
374
+ }
375
+ const none = [];
376
+ const MaxSelectionsPerEvent = 200;
377
+ function addSelection(branch, selection) {
378
+ if (!branch.length) {
379
+ return [HistEvent.selection([selection])];
380
+ }
381
+ else {
382
+ let lastEvent = branch[branch.length - 1];
383
+ let sels = lastEvent.selectionsAfter.slice(Math.max(0, lastEvent.selectionsAfter.length - MaxSelectionsPerEvent));
384
+ if (sels.length && sels[sels.length - 1].eq(selection))
385
+ return branch;
386
+ sels.push(selection);
387
+ return updateBranch(branch, branch.length - 1, 1e9, lastEvent.setSelAfter(sels));
388
+ }
389
+ }
390
+ // Assumes the top item has one or more selectionAfter values
391
+ function popSelection(branch) {
392
+ let last = branch[branch.length - 1];
393
+ let newBranch = branch.slice();
394
+ newBranch[branch.length - 1] = last.setSelAfter(last.selectionsAfter.slice(0, last.selectionsAfter.length - 1));
395
+ return newBranch;
396
+ }
397
+ // Add a mapping to the top event in the given branch. If this maps
398
+ // away all the changes and effects in that item, drop it and
399
+ // propagate the mapping to the next item.
400
+ function addMappingToBranch(branch, mapping) {
401
+ if (!branch.length)
402
+ return branch;
403
+ let length = branch.length, selections = none;
404
+ while (length) {
405
+ let event = mapEvent(branch[length - 1], mapping, selections);
406
+ if (event.changes && !event.changes.empty || event.effects.length) { // Event survived mapping
407
+ let result = branch.slice(0, length);
408
+ result[length - 1] = event;
409
+ return result;
410
+ }
411
+ else { // Drop this event, since there's no changes or effects left
412
+ mapping = event.mapped;
413
+ length--;
414
+ selections = event.selectionsAfter;
415
+ }
416
+ }
417
+ return selections.length ? [HistEvent.selection(selections)] : none;
418
+ }
419
+ function mapEvent(event, mapping, extraSelections) {
420
+ let selections = conc(event.selectionsAfter.length ? event.selectionsAfter.map(s => s.map(mapping)) : none, extraSelections);
421
+ // Change-less events don't store mappings (they are always the last event in a branch)
422
+ if (!event.changes)
423
+ return HistEvent.selection(selections);
424
+ let mappedChanges = event.changes.map(mapping), before = mapping.mapDesc(event.changes, true);
425
+ let fullMapping = event.mapped ? event.mapped.composeDesc(before) : before;
426
+ return new HistEvent(mappedChanges, StateEffect.mapEffects(event.effects, mapping), fullMapping, event.startSelection.map(before), selections);
427
+ }
428
+ const joinableUserEvent = /^(input\.type|delete)($|\.)/;
429
+ class HistoryState {
430
+ constructor(done, undone, prevTime = 0, prevUserEvent = undefined) {
431
+ this.done = done;
432
+ this.undone = undone;
433
+ this.prevTime = prevTime;
434
+ this.prevUserEvent = prevUserEvent;
435
+ }
436
+ isolate() {
437
+ return this.prevTime ? new HistoryState(this.done, this.undone) : this;
438
+ }
439
+ addChanges(event, time, userEvent, config, tr) {
440
+ let done = this.done, lastEvent = done[done.length - 1];
441
+ if (lastEvent && lastEvent.changes && !lastEvent.changes.empty && event.changes &&
442
+ (!userEvent || joinableUserEvent.test(userEvent)) &&
443
+ ((!lastEvent.selectionsAfter.length &&
444
+ time - this.prevTime < config.newGroupDelay &&
445
+ config.joinToEvent(tr, isAdjacent(lastEvent.changes, event.changes))) ||
446
+ // For compose (but not compose.start) events, always join with previous event
447
+ userEvent == "input.type.compose")) {
448
+ done = updateBranch(done, done.length - 1, config.minDepth, new HistEvent(event.changes.compose(lastEvent.changes), conc(StateEffect.mapEffects(event.effects, lastEvent.changes), lastEvent.effects), lastEvent.mapped, lastEvent.startSelection, none));
449
+ }
450
+ else {
451
+ done = updateBranch(done, done.length, config.minDepth, event);
452
+ }
453
+ return new HistoryState(done, none, time, userEvent);
454
+ }
455
+ addSelection(selection, time, userEvent, newGroupDelay) {
456
+ let last = this.done.length ? this.done[this.done.length - 1].selectionsAfter : none;
457
+ if (last.length > 0 &&
458
+ time - this.prevTime < newGroupDelay &&
459
+ userEvent == this.prevUserEvent && userEvent && /^select($|\.)/.test(userEvent) &&
460
+ eqSelectionShape(last[last.length - 1], selection))
461
+ return this;
462
+ return new HistoryState(addSelection(this.done, selection), this.undone, time, userEvent);
463
+ }
464
+ addMapping(mapping) {
465
+ return new HistoryState(addMappingToBranch(this.done, mapping), addMappingToBranch(this.undone, mapping), this.prevTime, this.prevUserEvent);
466
+ }
467
+ pop(side, state, onlySelection) {
468
+ let branch = side == 0 /* BranchName.Done */ ? this.done : this.undone;
469
+ if (branch.length == 0)
470
+ return null;
471
+ let event = branch[branch.length - 1], selection = event.selectionsAfter[0] || state.selection;
472
+ if (onlySelection && event.selectionsAfter.length) {
473
+ return state.update({
474
+ selection: event.selectionsAfter[event.selectionsAfter.length - 1],
475
+ annotations: fromHistory.of({ side, rest: popSelection(branch), selection }),
476
+ userEvent: side == 0 /* BranchName.Done */ ? "select.undo" : "select.redo",
477
+ scrollIntoView: true
478
+ });
479
+ }
480
+ else if (!event.changes) {
481
+ return null;
482
+ }
483
+ else {
484
+ let rest = branch.length == 1 ? none : branch.slice(0, branch.length - 1);
485
+ if (event.mapped)
486
+ rest = addMappingToBranch(rest, event.mapped);
487
+ return state.update({
488
+ changes: event.changes,
489
+ selection: event.startSelection,
490
+ effects: event.effects,
491
+ annotations: fromHistory.of({ side, rest, selection }),
492
+ filter: false,
493
+ userEvent: side == 0 /* BranchName.Done */ ? "undo" : "redo",
494
+ scrollIntoView: true
495
+ });
496
+ }
497
+ }
498
+ }
499
+ HistoryState.empty = /*@__PURE__*/new HistoryState(none, none);
500
+ /**
501
+ Default key bindings for the undo history.
502
+
503
+ - Mod-z: [`undo`](https://codemirror.net/6/docs/ref/#commands.undo).
504
+ - Mod-y (Mod-Shift-z on macOS) + Ctrl-Shift-z on Linux: [`redo`](https://codemirror.net/6/docs/ref/#commands.redo).
505
+ - Mod-u: [`undoSelection`](https://codemirror.net/6/docs/ref/#commands.undoSelection).
506
+ - Alt-u (Mod-Shift-u on macOS): [`redoSelection`](https://codemirror.net/6/docs/ref/#commands.redoSelection).
507
+ */
508
+ const historyKeymap = [
509
+ { key: "Mod-z", run: undo, preventDefault: true },
510
+ { key: "Mod-y", mac: "Mod-Shift-z", run: redo, preventDefault: true },
511
+ { linux: "Ctrl-Shift-z", run: redo, preventDefault: true },
512
+ { key: "Mod-u", run: undoSelection, preventDefault: true },
513
+ { key: "Alt-u", mac: "Mod-Shift-u", run: redoSelection, preventDefault: true }
514
+ ];
515
+
516
+ function updateSel(sel, by) {
517
+ return EditorSelection.create(sel.ranges.map(by), sel.mainIndex);
518
+ }
519
+ function setSel(state, selection) {
520
+ return state.update({ selection, scrollIntoView: true, userEvent: "select" });
521
+ }
522
+ function moveSel({ state, dispatch }, how) {
523
+ let selection = updateSel(state.selection, how);
524
+ if (selection.eq(state.selection, true))
525
+ return false;
526
+ dispatch(setSel(state, selection));
527
+ return true;
528
+ }
529
+ function rangeEnd(range, forward) {
530
+ return EditorSelection.cursor(forward ? range.to : range.from);
531
+ }
532
+ function cursorByChar(view, forward) {
533
+ return moveSel(view, range => range.empty ? view.moveByChar(range, forward) : rangeEnd(range, forward));
534
+ }
535
+ function ltrAtCursor(view) {
536
+ return view.textDirectionAt(view.state.selection.main.head) == Direction.LTR;
537
+ }
538
+ /**
539
+ Move the selection one character to the left (which is backward in
540
+ left-to-right text, forward in right-to-left text).
541
+ */
542
+ const cursorCharLeft = view => cursorByChar(view, !ltrAtCursor(view));
543
+ /**
544
+ Move the selection one character to the right.
545
+ */
546
+ const cursorCharRight = view => cursorByChar(view, ltrAtCursor(view));
547
+ function cursorByGroup(view, forward) {
548
+ return moveSel(view, range => range.empty ? view.moveByGroup(range, forward) : rangeEnd(range, forward));
549
+ }
550
+ /**
551
+ Move the selection to the left across one group of word or
552
+ non-word (but also non-space) characters.
553
+ */
554
+ const cursorGroupLeft = view => cursorByGroup(view, !ltrAtCursor(view));
555
+ /**
556
+ Move the selection one group to the right.
557
+ */
558
+ const cursorGroupRight = view => cursorByGroup(view, ltrAtCursor(view));
559
+ function interestingNode(state, node, bracketProp) {
560
+ if (node.type.prop(bracketProp))
561
+ return true;
562
+ let len = node.to - node.from;
563
+ return len && (len > 2 || /[^\s,.;:]/.test(state.sliceDoc(node.from, node.to))) || node.firstChild;
564
+ }
565
+ function moveBySyntax(state, start, forward) {
566
+ let pos = syntaxTree(state).resolveInner(start.head);
567
+ let bracketProp = forward ? NodeProp.closedBy : NodeProp.openedBy;
568
+ // Scan forward through child nodes to see if there's an interesting
569
+ // node ahead.
570
+ for (let at = start.head;;) {
571
+ let next = forward ? pos.childAfter(at) : pos.childBefore(at);
572
+ if (!next)
573
+ break;
574
+ if (interestingNode(state, next, bracketProp))
575
+ pos = next;
576
+ else
577
+ at = forward ? next.to : next.from;
578
+ }
579
+ let bracket = pos.type.prop(bracketProp), match, newPos;
580
+ if (bracket && (match = forward ? matchBrackets(state, pos.from, 1) : matchBrackets(state, pos.to, -1)) && match.matched)
581
+ newPos = forward ? match.end.to : match.end.from;
582
+ else
583
+ newPos = forward ? pos.to : pos.from;
584
+ return EditorSelection.cursor(newPos, forward ? -1 : 1);
585
+ }
586
+ /**
587
+ Move the cursor over the next syntactic element to the left.
588
+ */
589
+ const cursorSyntaxLeft = view => moveSel(view, range => moveBySyntax(view.state, range, !ltrAtCursor(view)));
590
+ /**
591
+ Move the cursor over the next syntactic element to the right.
592
+ */
593
+ const cursorSyntaxRight = view => moveSel(view, range => moveBySyntax(view.state, range, ltrAtCursor(view)));
594
+ function cursorByLine(view, forward) {
595
+ return moveSel(view, range => {
596
+ if (!range.empty)
597
+ return rangeEnd(range, forward);
598
+ let moved = view.moveVertically(range, forward);
599
+ return moved.head != range.head ? moved : view.moveToLineBoundary(range, forward);
600
+ });
601
+ }
602
+ /**
603
+ Move the selection one line up.
604
+ */
605
+ const cursorLineUp = view => cursorByLine(view, false);
606
+ /**
607
+ Move the selection one line down.
608
+ */
609
+ const cursorLineDown = view => cursorByLine(view, true);
610
+ function pageInfo(view) {
611
+ let selfScroll = view.scrollDOM.clientHeight < view.scrollDOM.scrollHeight - 2;
612
+ let marginTop = 0, marginBottom = 0, height;
613
+ if (selfScroll) {
614
+ for (let source of view.state.facet(EditorView.scrollMargins)) {
615
+ let margins = source(view);
616
+ if (margins === null || margins === void 0 ? void 0 : margins.top)
617
+ marginTop = Math.max(margins === null || margins === void 0 ? void 0 : margins.top, marginTop);
618
+ if (margins === null || margins === void 0 ? void 0 : margins.bottom)
619
+ marginBottom = Math.max(margins === null || margins === void 0 ? void 0 : margins.bottom, marginBottom);
620
+ }
621
+ height = view.scrollDOM.clientHeight - marginTop - marginBottom;
622
+ }
623
+ else {
624
+ height = (view.dom.ownerDocument.defaultView || window).innerHeight;
625
+ }
626
+ return { marginTop, marginBottom, selfScroll,
627
+ height: Math.max(view.defaultLineHeight, height - 5) };
628
+ }
629
+ function cursorByPage(view, forward) {
630
+ let page = pageInfo(view);
631
+ let { state } = view, selection = updateSel(state.selection, range => {
632
+ return range.empty ? view.moveVertically(range, forward, page.height)
633
+ : rangeEnd(range, forward);
634
+ });
635
+ if (selection.eq(state.selection))
636
+ return false;
637
+ let effect;
638
+ if (page.selfScroll) {
639
+ let startPos = view.coordsAtPos(state.selection.main.head);
640
+ let scrollRect = view.scrollDOM.getBoundingClientRect();
641
+ let scrollTop = scrollRect.top + page.marginTop, scrollBottom = scrollRect.bottom - page.marginBottom;
642
+ if (startPos && startPos.top > scrollTop && startPos.bottom < scrollBottom)
643
+ effect = EditorView.scrollIntoView(selection.main.head, { y: "start", yMargin: startPos.top - scrollTop });
644
+ }
645
+ view.dispatch(setSel(state, selection), { effects: effect });
646
+ return true;
647
+ }
648
+ /**
649
+ Move the selection one page up.
650
+ */
651
+ const cursorPageUp = view => cursorByPage(view, false);
652
+ /**
653
+ Move the selection one page down.
654
+ */
655
+ const cursorPageDown = view => cursorByPage(view, true);
656
+ function moveByLineBoundary(view, start, forward) {
657
+ let line = view.lineBlockAt(start.head), moved = view.moveToLineBoundary(start, forward);
658
+ if (moved.head == start.head && moved.head != (forward ? line.to : line.from))
659
+ moved = view.moveToLineBoundary(start, forward, false);
660
+ if (!forward && moved.head == line.from && line.length) {
661
+ let space = /^\s*/.exec(view.state.sliceDoc(line.from, Math.min(line.from + 100, line.to)))[0].length;
662
+ if (space && start.head != line.from + space)
663
+ moved = EditorSelection.cursor(line.from + space);
664
+ }
665
+ return moved;
666
+ }
667
+ /**
668
+ Move the selection to the next line wrap point, or to the end of
669
+ the line if there isn't one left on this line.
670
+ */
671
+ const cursorLineBoundaryForward = view => moveSel(view, range => moveByLineBoundary(view, range, true));
672
+ /**
673
+ Move the selection to previous line wrap point, or failing that to
674
+ the start of the line. If the line is indented, and the cursor
675
+ isn't already at the end of the indentation, this will move to the
676
+ end of the indentation instead of the start of the line.
677
+ */
678
+ const cursorLineBoundaryBackward = view => moveSel(view, range => moveByLineBoundary(view, range, false));
679
+ /**
680
+ Move the selection one line wrap point to the left.
681
+ */
682
+ const cursorLineBoundaryLeft = view => moveSel(view, range => moveByLineBoundary(view, range, !ltrAtCursor(view)));
683
+ /**
684
+ Move the selection one line wrap point to the right.
685
+ */
686
+ const cursorLineBoundaryRight = view => moveSel(view, range => moveByLineBoundary(view, range, ltrAtCursor(view)));
687
+ /**
688
+ Move the selection to the start of the line.
689
+ */
690
+ const cursorLineStart = view => moveSel(view, range => EditorSelection.cursor(view.lineBlockAt(range.head).from, 1));
691
+ /**
692
+ Move the selection to the end of the line.
693
+ */
694
+ const cursorLineEnd = view => moveSel(view, range => EditorSelection.cursor(view.lineBlockAt(range.head).to, -1));
695
+ function toMatchingBracket(state, dispatch, extend) {
696
+ let found = false, selection = updateSel(state.selection, range => {
697
+ let matching = matchBrackets(state, range.head, -1)
698
+ || matchBrackets(state, range.head, 1)
699
+ || (range.head > 0 && matchBrackets(state, range.head - 1, 1))
700
+ || (range.head < state.doc.length && matchBrackets(state, range.head + 1, -1));
701
+ if (!matching || !matching.end)
702
+ return range;
703
+ found = true;
704
+ let head = matching.start.from == range.head ? matching.end.to : matching.end.from;
705
+ return EditorSelection.cursor(head);
706
+ });
707
+ if (!found)
708
+ return false;
709
+ dispatch(setSel(state, selection));
710
+ return true;
711
+ }
712
+ /**
713
+ Move the selection to the bracket matching the one it is currently
714
+ on, if any.
715
+ */
716
+ const cursorMatchingBracket = ({ state, dispatch }) => toMatchingBracket(state, dispatch);
717
+ function extendSel(target, how) {
718
+ let selection = updateSel(target.state.selection, range => {
719
+ let head = how(range);
720
+ return EditorSelection.range(range.anchor, head.head, head.goalColumn, head.bidiLevel || undefined);
721
+ });
722
+ if (selection.eq(target.state.selection))
723
+ return false;
724
+ target.dispatch(setSel(target.state, selection));
725
+ return true;
726
+ }
727
+ function selectByChar(view, forward) {
728
+ return extendSel(view, range => view.moveByChar(range, forward));
729
+ }
730
+ /**
731
+ Move the selection head one character to the left, while leaving
732
+ the anchor in place.
733
+ */
734
+ const selectCharLeft = view => selectByChar(view, !ltrAtCursor(view));
735
+ /**
736
+ Move the selection head one character to the right.
737
+ */
738
+ const selectCharRight = view => selectByChar(view, ltrAtCursor(view));
739
+ function selectByGroup(view, forward) {
740
+ return extendSel(view, range => view.moveByGroup(range, forward));
741
+ }
742
+ /**
743
+ Move the selection head one [group](https://codemirror.net/6/docs/ref/#commands.cursorGroupLeft) to
744
+ the left.
745
+ */
746
+ const selectGroupLeft = view => selectByGroup(view, !ltrAtCursor(view));
747
+ /**
748
+ Move the selection head one group to the right.
749
+ */
750
+ const selectGroupRight = view => selectByGroup(view, ltrAtCursor(view));
751
+ /**
752
+ Move the selection head over the next syntactic element to the left.
753
+ */
754
+ const selectSyntaxLeft = view => extendSel(view, range => moveBySyntax(view.state, range, !ltrAtCursor(view)));
755
+ /**
756
+ Move the selection head over the next syntactic element to the right.
757
+ */
758
+ const selectSyntaxRight = view => extendSel(view, range => moveBySyntax(view.state, range, ltrAtCursor(view)));
759
+ function selectByLine(view, forward) {
760
+ return extendSel(view, range => view.moveVertically(range, forward));
761
+ }
762
+ /**
763
+ Move the selection head one line up.
764
+ */
765
+ const selectLineUp = view => selectByLine(view, false);
766
+ /**
767
+ Move the selection head one line down.
768
+ */
769
+ const selectLineDown = view => selectByLine(view, true);
770
+ function selectByPage(view, forward) {
771
+ return extendSel(view, range => view.moveVertically(range, forward, pageInfo(view).height));
772
+ }
773
+ /**
774
+ Move the selection head one page up.
775
+ */
776
+ const selectPageUp = view => selectByPage(view, false);
777
+ /**
778
+ Move the selection head one page down.
779
+ */
780
+ const selectPageDown = view => selectByPage(view, true);
781
+ /**
782
+ Move the selection head to the next line boundary.
783
+ */
784
+ const selectLineBoundaryForward = view => extendSel(view, range => moveByLineBoundary(view, range, true));
785
+ /**
786
+ Move the selection head to the previous line boundary.
787
+ */
788
+ const selectLineBoundaryBackward = view => extendSel(view, range => moveByLineBoundary(view, range, false));
789
+ /**
790
+ Move the selection head one line boundary to the left.
791
+ */
792
+ const selectLineBoundaryLeft = view => extendSel(view, range => moveByLineBoundary(view, range, !ltrAtCursor(view)));
793
+ /**
794
+ Move the selection head one line boundary to the right.
795
+ */
796
+ const selectLineBoundaryRight = view => extendSel(view, range => moveByLineBoundary(view, range, ltrAtCursor(view)));
797
+ /**
798
+ Move the selection head to the start of the line.
799
+ */
800
+ const selectLineStart = view => extendSel(view, range => EditorSelection.cursor(view.lineBlockAt(range.head).from));
801
+ /**
802
+ Move the selection head to the end of the line.
803
+ */
804
+ const selectLineEnd = view => extendSel(view, range => EditorSelection.cursor(view.lineBlockAt(range.head).to));
805
+ /**
806
+ Move the selection to the start of the document.
807
+ */
808
+ const cursorDocStart = ({ state, dispatch }) => {
809
+ dispatch(setSel(state, { anchor: 0 }));
810
+ return true;
811
+ };
812
+ /**
813
+ Move the selection to the end of the document.
814
+ */
815
+ const cursorDocEnd = ({ state, dispatch }) => {
816
+ dispatch(setSel(state, { anchor: state.doc.length }));
817
+ return true;
818
+ };
819
+ /**
820
+ Move the selection head to the start of the document.
821
+ */
822
+ const selectDocStart = ({ state, dispatch }) => {
823
+ dispatch(setSel(state, { anchor: state.selection.main.anchor, head: 0 }));
824
+ return true;
825
+ };
826
+ /**
827
+ Move the selection head to the end of the document.
828
+ */
829
+ const selectDocEnd = ({ state, dispatch }) => {
830
+ dispatch(setSel(state, { anchor: state.selection.main.anchor, head: state.doc.length }));
831
+ return true;
832
+ };
833
+ /**
834
+ Select the entire document.
835
+ */
836
+ const selectAll = ({ state, dispatch }) => {
837
+ dispatch(state.update({ selection: { anchor: 0, head: state.doc.length }, userEvent: "select" }));
838
+ return true;
839
+ };
840
+ /**
841
+ Expand the selection to cover entire lines.
842
+ */
843
+ const selectLine = ({ state, dispatch }) => {
844
+ let ranges = selectedLineBlocks(state).map(({ from, to }) => EditorSelection.range(from, Math.min(to + 1, state.doc.length)));
845
+ dispatch(state.update({ selection: EditorSelection.create(ranges), userEvent: "select" }));
846
+ return true;
847
+ };
848
+ /**
849
+ Select the next syntactic construct that is larger than the
850
+ selection. Note that this will only work insofar as the language
851
+ [provider](https://codemirror.net/6/docs/ref/#language.language) you use builds up a full
852
+ syntax tree.
853
+ */
854
+ const selectParentSyntax = ({ state, dispatch }) => {
855
+ let selection = updateSel(state.selection, range => {
856
+ let tree = syntaxTree(state), stack = tree.resolveStack(range.from, 1);
857
+ if (range.empty) {
858
+ let stackBefore = tree.resolveStack(range.from, -1);
859
+ if (stackBefore.node.from >= stack.node.from && stackBefore.node.to <= stack.node.to)
860
+ stack = stackBefore;
861
+ }
862
+ for (let cur = stack; cur; cur = cur.next) {
863
+ let { node } = cur;
864
+ if (((node.from < range.from && node.to >= range.to) ||
865
+ (node.to > range.to && node.from <= range.from)) &&
866
+ cur.next)
867
+ return EditorSelection.range(node.to, node.from);
868
+ }
869
+ return range;
870
+ });
871
+ if (selection.eq(state.selection))
872
+ return false;
873
+ dispatch(setSel(state, selection));
874
+ return true;
875
+ };
876
+ /**
877
+ Simplify the current selection. When multiple ranges are selected,
878
+ reduce it to its main range. Otherwise, if the selection is
879
+ non-empty, convert it to a cursor selection.
880
+ */
881
+ const simplifySelection = ({ state, dispatch }) => {
882
+ let cur = state.selection, selection = null;
883
+ if (cur.ranges.length > 1)
884
+ selection = EditorSelection.create([cur.main]);
885
+ else if (!cur.main.empty)
886
+ selection = EditorSelection.create([EditorSelection.cursor(cur.main.head)]);
887
+ if (!selection)
888
+ return false;
889
+ dispatch(setSel(state, selection));
890
+ return true;
891
+ };
892
+ function deleteBy(target, by) {
893
+ if (target.state.readOnly)
894
+ return false;
895
+ let event = "delete.selection", { state } = target;
896
+ let changes = state.changeByRange(range => {
897
+ let { from, to } = range;
898
+ if (from == to) {
899
+ let towards = by(range);
900
+ if (towards < from) {
901
+ event = "delete.backward";
902
+ towards = skipAtomic(target, towards, false);
903
+ }
904
+ else if (towards > from) {
905
+ event = "delete.forward";
906
+ towards = skipAtomic(target, towards, true);
907
+ }
908
+ from = Math.min(from, towards);
909
+ to = Math.max(to, towards);
910
+ }
911
+ else {
912
+ from = skipAtomic(target, from, false);
913
+ to = skipAtomic(target, to, true);
914
+ }
915
+ return from == to ? { range } : { changes: { from, to }, range: EditorSelection.cursor(from, from < range.head ? -1 : 1) };
916
+ });
917
+ if (changes.changes.empty)
918
+ return false;
919
+ target.dispatch(state.update(changes, {
920
+ scrollIntoView: true,
921
+ userEvent: event,
922
+ effects: event == "delete.selection" ? EditorView.announce.of(state.phrase("Selection deleted")) : undefined
923
+ }));
924
+ return true;
925
+ }
926
+ function skipAtomic(target, pos, forward) {
927
+ if (target instanceof EditorView)
928
+ for (let ranges of target.state.facet(EditorView.atomicRanges).map(f => f(target)))
929
+ ranges.between(pos, pos, (from, to) => {
930
+ if (from < pos && to > pos)
931
+ pos = forward ? to : from;
932
+ });
933
+ return pos;
934
+ }
935
+ const deleteByChar = (target, forward, byIndentUnit) => deleteBy(target, range => {
936
+ let pos = range.from, { state } = target, line = state.doc.lineAt(pos), before, targetPos;
937
+ if (byIndentUnit && !forward && pos > line.from && pos < line.from + 200 &&
938
+ !/[^ \t]/.test(before = line.text.slice(0, pos - line.from))) {
939
+ if (before[before.length - 1] == "\t")
940
+ return pos - 1;
941
+ let col = countColumn(before, state.tabSize), drop = col % getIndentUnit(state) || getIndentUnit(state);
942
+ for (let i = 0; i < drop && before[before.length - 1 - i] == " "; i++)
943
+ pos--;
944
+ targetPos = pos;
945
+ }
946
+ else {
947
+ targetPos = findClusterBreak(line.text, pos - line.from, forward, forward) + line.from;
948
+ if (targetPos == pos && line.number != (forward ? state.doc.lines : 1))
949
+ targetPos += forward ? 1 : -1;
950
+ else if (!forward && /[\ufe00-\ufe0f]/.test(line.text.slice(targetPos - line.from, pos - line.from)))
951
+ targetPos = findClusterBreak(line.text, targetPos - line.from, false, false) + line.from;
952
+ }
953
+ return targetPos;
954
+ });
955
+ /**
956
+ Delete the selection, or, for cursor selections, the character or
957
+ indentation unit before the cursor.
958
+ */
959
+ const deleteCharBackward = view => deleteByChar(view, false, true);
960
+ /**
961
+ Delete the selection or the character after the cursor.
962
+ */
963
+ const deleteCharForward = view => deleteByChar(view, true, false);
964
+ const deleteByGroup = (target, forward) => deleteBy(target, range => {
965
+ let pos = range.head, { state } = target, line = state.doc.lineAt(pos);
966
+ let categorize = state.charCategorizer(pos);
967
+ for (let cat = null;;) {
968
+ if (pos == (forward ? line.to : line.from)) {
969
+ if (pos == range.head && line.number != (forward ? state.doc.lines : 1))
970
+ pos += forward ? 1 : -1;
971
+ break;
972
+ }
973
+ let next = findClusterBreak(line.text, pos - line.from, forward) + line.from;
974
+ let nextChar = line.text.slice(Math.min(pos, next) - line.from, Math.max(pos, next) - line.from);
975
+ let nextCat = categorize(nextChar);
976
+ if (cat != null && nextCat != cat)
977
+ break;
978
+ if (nextChar != " " || pos != range.head)
979
+ cat = nextCat;
980
+ pos = next;
981
+ }
982
+ return pos;
983
+ });
984
+ /**
985
+ Delete the selection or backward until the end of the next
986
+ [group](https://codemirror.net/6/docs/ref/#view.EditorView.moveByGroup), only skipping groups of
987
+ whitespace when they consist of a single space.
988
+ */
989
+ const deleteGroupBackward = target => deleteByGroup(target, false);
990
+ /**
991
+ Delete the selection or forward until the end of the next group.
992
+ */
993
+ const deleteGroupForward = target => deleteByGroup(target, true);
994
+ /**
995
+ Delete the selection, or, if it is a cursor selection, delete to
996
+ the end of the line. If the cursor is directly at the end of the
997
+ line, delete the line break after it.
998
+ */
999
+ const deleteToLineEnd = view => deleteBy(view, range => {
1000
+ let lineEnd = view.lineBlockAt(range.head).to;
1001
+ return range.head < lineEnd ? lineEnd : Math.min(view.state.doc.length, range.head + 1);
1002
+ });
1003
+ /**
1004
+ Delete the selection, or, if it is a cursor selection, delete to
1005
+ the start of the line or the next line wrap before the cursor.
1006
+ */
1007
+ const deleteLineBoundaryBackward = view => deleteBy(view, range => {
1008
+ let lineStart = view.moveToLineBoundary(range, false).head;
1009
+ return range.head > lineStart ? lineStart : Math.max(0, range.head - 1);
1010
+ });
1011
+ /**
1012
+ Delete the selection, or, if it is a cursor selection, delete to
1013
+ the end of the line or the next line wrap after the cursor.
1014
+ */
1015
+ const deleteLineBoundaryForward = view => deleteBy(view, range => {
1016
+ let lineStart = view.moveToLineBoundary(range, true).head;
1017
+ return range.head < lineStart ? lineStart : Math.min(view.state.doc.length, range.head + 1);
1018
+ });
1019
+ /**
1020
+ Replace each selection range with a line break, leaving the cursor
1021
+ on the line before the break.
1022
+ */
1023
+ const splitLine = ({ state, dispatch }) => {
1024
+ if (state.readOnly)
1025
+ return false;
1026
+ let changes = state.changeByRange(range => {
1027
+ return { changes: { from: range.from, to: range.to, insert: Text.of(["", ""]) },
1028
+ range: EditorSelection.cursor(range.from) };
1029
+ });
1030
+ dispatch(state.update(changes, { scrollIntoView: true, userEvent: "input" }));
1031
+ return true;
1032
+ };
1033
+ /**
1034
+ Flip the characters before and after the cursor(s).
1035
+ */
1036
+ const transposeChars = ({ state, dispatch }) => {
1037
+ if (state.readOnly)
1038
+ return false;
1039
+ let changes = state.changeByRange(range => {
1040
+ if (!range.empty || range.from == 0 || range.from == state.doc.length)
1041
+ return { range };
1042
+ let pos = range.from, line = state.doc.lineAt(pos);
1043
+ let from = pos == line.from ? pos - 1 : findClusterBreak(line.text, pos - line.from, false) + line.from;
1044
+ let to = pos == line.to ? pos + 1 : findClusterBreak(line.text, pos - line.from, true) + line.from;
1045
+ return { changes: { from, to, insert: state.doc.slice(pos, to).append(state.doc.slice(from, pos)) },
1046
+ range: EditorSelection.cursor(to) };
1047
+ });
1048
+ if (changes.changes.empty)
1049
+ return false;
1050
+ dispatch(state.update(changes, { scrollIntoView: true, userEvent: "move.character" }));
1051
+ return true;
1052
+ };
1053
+ function selectedLineBlocks(state) {
1054
+ let blocks = [], upto = -1;
1055
+ for (let range of state.selection.ranges) {
1056
+ let startLine = state.doc.lineAt(range.from), endLine = state.doc.lineAt(range.to);
1057
+ if (!range.empty && range.to == endLine.from)
1058
+ endLine = state.doc.lineAt(range.to - 1);
1059
+ if (upto >= startLine.number) {
1060
+ let prev = blocks[blocks.length - 1];
1061
+ prev.to = endLine.to;
1062
+ prev.ranges.push(range);
1063
+ }
1064
+ else {
1065
+ blocks.push({ from: startLine.from, to: endLine.to, ranges: [range] });
1066
+ }
1067
+ upto = endLine.number + 1;
1068
+ }
1069
+ return blocks;
1070
+ }
1071
+ function moveLine(state, dispatch, forward) {
1072
+ if (state.readOnly)
1073
+ return false;
1074
+ let changes = [], ranges = [];
1075
+ for (let block of selectedLineBlocks(state)) {
1076
+ if (forward ? block.to == state.doc.length : block.from == 0)
1077
+ continue;
1078
+ let nextLine = state.doc.lineAt(forward ? block.to + 1 : block.from - 1);
1079
+ let size = nextLine.length + 1;
1080
+ if (forward) {
1081
+ changes.push({ from: block.to, to: nextLine.to }, { from: block.from, insert: nextLine.text + state.lineBreak });
1082
+ for (let r of block.ranges)
1083
+ ranges.push(EditorSelection.range(Math.min(state.doc.length, r.anchor + size), Math.min(state.doc.length, r.head + size)));
1084
+ }
1085
+ else {
1086
+ changes.push({ from: nextLine.from, to: block.from }, { from: block.to, insert: state.lineBreak + nextLine.text });
1087
+ for (let r of block.ranges)
1088
+ ranges.push(EditorSelection.range(r.anchor - size, r.head - size));
1089
+ }
1090
+ }
1091
+ if (!changes.length)
1092
+ return false;
1093
+ dispatch(state.update({
1094
+ changes,
1095
+ scrollIntoView: true,
1096
+ selection: EditorSelection.create(ranges, state.selection.mainIndex),
1097
+ userEvent: "move.line"
1098
+ }));
1099
+ return true;
1100
+ }
1101
+ /**
1102
+ Move the selected lines up one line.
1103
+ */
1104
+ const moveLineUp = ({ state, dispatch }) => moveLine(state, dispatch, false);
1105
+ /**
1106
+ Move the selected lines down one line.
1107
+ */
1108
+ const moveLineDown = ({ state, dispatch }) => moveLine(state, dispatch, true);
1109
+ function copyLine(state, dispatch, forward) {
1110
+ if (state.readOnly)
1111
+ return false;
1112
+ let changes = [];
1113
+ for (let block of selectedLineBlocks(state)) {
1114
+ if (forward)
1115
+ changes.push({ from: block.from, insert: state.doc.slice(block.from, block.to) + state.lineBreak });
1116
+ else
1117
+ changes.push({ from: block.to, insert: state.lineBreak + state.doc.slice(block.from, block.to) });
1118
+ }
1119
+ dispatch(state.update({ changes, scrollIntoView: true, userEvent: "input.copyline" }));
1120
+ return true;
1121
+ }
1122
+ /**
1123
+ Create a copy of the selected lines. Keep the selection in the top copy.
1124
+ */
1125
+ const copyLineUp = ({ state, dispatch }) => copyLine(state, dispatch, false);
1126
+ /**
1127
+ Create a copy of the selected lines. Keep the selection in the bottom copy.
1128
+ */
1129
+ const copyLineDown = ({ state, dispatch }) => copyLine(state, dispatch, true);
1130
+ /**
1131
+ Delete selected lines.
1132
+ */
1133
+ const deleteLine = view => {
1134
+ if (view.state.readOnly)
1135
+ return false;
1136
+ let { state } = view, changes = state.changes(selectedLineBlocks(state).map(({ from, to }) => {
1137
+ if (from > 0)
1138
+ from--;
1139
+ else if (to < state.doc.length)
1140
+ to++;
1141
+ return { from, to };
1142
+ }));
1143
+ let selection = updateSel(state.selection, range => {
1144
+ let dist = undefined;
1145
+ if (view.lineWrapping) {
1146
+ let block = view.lineBlockAt(range.head), pos = view.coordsAtPos(range.head, range.assoc || 1);
1147
+ if (pos)
1148
+ dist = (block.bottom + view.documentTop) - pos.bottom + view.defaultLineHeight / 2;
1149
+ }
1150
+ return view.moveVertically(range, true, dist);
1151
+ }).map(changes);
1152
+ view.dispatch({ changes, selection, scrollIntoView: true, userEvent: "delete.line" });
1153
+ return true;
1154
+ };
1155
+ function isBetweenBrackets(state, pos) {
1156
+ if (/\(\)|\[\]|\{\}/.test(state.sliceDoc(pos - 1, pos + 1)))
1157
+ return { from: pos, to: pos };
1158
+ let context = syntaxTree(state).resolveInner(pos);
1159
+ let before = context.childBefore(pos), after = context.childAfter(pos), closedBy;
1160
+ if (before && after && before.to <= pos && after.from >= pos &&
1161
+ (closedBy = before.type.prop(NodeProp.closedBy)) && closedBy.indexOf(after.name) > -1 &&
1162
+ state.doc.lineAt(before.to).from == state.doc.lineAt(after.from).from &&
1163
+ !/\S/.test(state.sliceDoc(before.to, after.from)))
1164
+ return { from: before.to, to: after.from };
1165
+ return null;
1166
+ }
1167
+ /**
1168
+ Replace the selection with a newline and indent the newly created
1169
+ line(s). If the current line consists only of whitespace, this
1170
+ will also delete that whitespace. When the cursor is between
1171
+ matching brackets, an additional newline will be inserted after
1172
+ the cursor.
1173
+ */
1174
+ const insertNewlineAndIndent = /*@__PURE__*/newlineAndIndent(false);
1175
+ /**
1176
+ Create a blank, indented line below the current line.
1177
+ */
1178
+ const insertBlankLine = /*@__PURE__*/newlineAndIndent(true);
1179
+ function newlineAndIndent(atEof) {
1180
+ return ({ state, dispatch }) => {
1181
+ if (state.readOnly)
1182
+ return false;
1183
+ let changes = state.changeByRange(range => {
1184
+ let { from, to } = range, line = state.doc.lineAt(from);
1185
+ let explode = !atEof && from == to && isBetweenBrackets(state, from);
1186
+ if (atEof)
1187
+ from = to = (to <= line.to ? line : state.doc.lineAt(to)).to;
1188
+ let cx = new IndentContext(state, { simulateBreak: from, simulateDoubleBreak: !!explode });
1189
+ let indent = getIndentation(cx, from);
1190
+ if (indent == null)
1191
+ indent = countColumn(/^\s*/.exec(state.doc.lineAt(from).text)[0], state.tabSize);
1192
+ while (to < line.to && /\s/.test(line.text[to - line.from]))
1193
+ to++;
1194
+ if (explode)
1195
+ ({ from, to } = explode);
1196
+ else if (from > line.from && from < line.from + 100 && !/\S/.test(line.text.slice(0, from)))
1197
+ from = line.from;
1198
+ let insert = ["", indentString(state, indent)];
1199
+ if (explode)
1200
+ insert.push(indentString(state, cx.lineIndent(line.from, -1)));
1201
+ return { changes: { from, to, insert: Text.of(insert) },
1202
+ range: EditorSelection.cursor(from + 1 + insert[1].length) };
1203
+ });
1204
+ dispatch(state.update(changes, { scrollIntoView: true, userEvent: "input" }));
1205
+ return true;
1206
+ };
1207
+ }
1208
+ function changeBySelectedLine(state, f) {
1209
+ let atLine = -1;
1210
+ return state.changeByRange(range => {
1211
+ let changes = [];
1212
+ for (let pos = range.from; pos <= range.to;) {
1213
+ let line = state.doc.lineAt(pos);
1214
+ if (line.number > atLine && (range.empty || range.to > line.from)) {
1215
+ f(line, changes, range);
1216
+ atLine = line.number;
1217
+ }
1218
+ pos = line.to + 1;
1219
+ }
1220
+ let changeSet = state.changes(changes);
1221
+ return { changes,
1222
+ range: EditorSelection.range(changeSet.mapPos(range.anchor, 1), changeSet.mapPos(range.head, 1)) };
1223
+ });
1224
+ }
1225
+ /**
1226
+ Auto-indent the selected lines. This uses the [indentation service
1227
+ facet](https://codemirror.net/6/docs/ref/#language.indentService) as source for auto-indent
1228
+ information.
1229
+ */
1230
+ const indentSelection = ({ state, dispatch }) => {
1231
+ if (state.readOnly)
1232
+ return false;
1233
+ let updated = Object.create(null);
1234
+ let context = new IndentContext(state, { overrideIndentation: start => {
1235
+ let found = updated[start];
1236
+ return found == null ? -1 : found;
1237
+ } });
1238
+ let changes = changeBySelectedLine(state, (line, changes, range) => {
1239
+ let indent = getIndentation(context, line.from);
1240
+ if (indent == null)
1241
+ return;
1242
+ if (!/\S/.test(line.text))
1243
+ indent = 0;
1244
+ let cur = /^\s*/.exec(line.text)[0];
1245
+ let norm = indentString(state, indent);
1246
+ if (cur != norm || range.from < line.from + cur.length) {
1247
+ updated[line.from] = indent;
1248
+ changes.push({ from: line.from, to: line.from + cur.length, insert: norm });
1249
+ }
1250
+ });
1251
+ if (!changes.changes.empty)
1252
+ dispatch(state.update(changes, { userEvent: "indent" }));
1253
+ return true;
1254
+ };
1255
+ /**
1256
+ Add a [unit](https://codemirror.net/6/docs/ref/#language.indentUnit) of indentation to all selected
1257
+ lines.
1258
+ */
1259
+ const indentMore = ({ state, dispatch }) => {
1260
+ if (state.readOnly)
1261
+ return false;
1262
+ dispatch(state.update(changeBySelectedLine(state, (line, changes) => {
1263
+ changes.push({ from: line.from, insert: state.facet(indentUnit) });
1264
+ }), { userEvent: "input.indent" }));
1265
+ return true;
1266
+ };
1267
+ /**
1268
+ Remove a [unit](https://codemirror.net/6/docs/ref/#language.indentUnit) of indentation from all
1269
+ selected lines.
1270
+ */
1271
+ const indentLess = ({ state, dispatch }) => {
1272
+ if (state.readOnly)
1273
+ return false;
1274
+ dispatch(state.update(changeBySelectedLine(state, (line, changes) => {
1275
+ let space = /^\s*/.exec(line.text)[0];
1276
+ if (!space)
1277
+ return;
1278
+ let col = countColumn(space, state.tabSize), keep = 0;
1279
+ let insert = indentString(state, Math.max(0, col - getIndentUnit(state)));
1280
+ while (keep < space.length && keep < insert.length && space.charCodeAt(keep) == insert.charCodeAt(keep))
1281
+ keep++;
1282
+ changes.push({ from: line.from + keep, to: line.from + space.length, insert: insert.slice(keep) });
1283
+ }), { userEvent: "delete.dedent" }));
1284
+ return true;
1285
+ };
1286
+ /**
1287
+ Enables or disables
1288
+ [tab-focus mode](https://codemirror.net/6/docs/ref/#view.EditorView.setTabFocusMode). While on, this
1289
+ prevents the editor's key bindings from capturing Tab or
1290
+ Shift-Tab, making it possible for the user to move focus out of
1291
+ the editor with the keyboard.
1292
+ */
1293
+ const toggleTabFocusMode = view => {
1294
+ view.setTabFocusMode();
1295
+ return true;
1296
+ };
1297
+ /**
1298
+ Array of key bindings containing the Emacs-style bindings that are
1299
+ available on macOS by default.
1300
+
1301
+ - Ctrl-b: [`cursorCharLeft`](https://codemirror.net/6/docs/ref/#commands.cursorCharLeft) ([`selectCharLeft`](https://codemirror.net/6/docs/ref/#commands.selectCharLeft) with Shift)
1302
+ - Ctrl-f: [`cursorCharRight`](https://codemirror.net/6/docs/ref/#commands.cursorCharRight) ([`selectCharRight`](https://codemirror.net/6/docs/ref/#commands.selectCharRight) with Shift)
1303
+ - Ctrl-p: [`cursorLineUp`](https://codemirror.net/6/docs/ref/#commands.cursorLineUp) ([`selectLineUp`](https://codemirror.net/6/docs/ref/#commands.selectLineUp) with Shift)
1304
+ - Ctrl-n: [`cursorLineDown`](https://codemirror.net/6/docs/ref/#commands.cursorLineDown) ([`selectLineDown`](https://codemirror.net/6/docs/ref/#commands.selectLineDown) with Shift)
1305
+ - Ctrl-a: [`cursorLineStart`](https://codemirror.net/6/docs/ref/#commands.cursorLineStart) ([`selectLineStart`](https://codemirror.net/6/docs/ref/#commands.selectLineStart) with Shift)
1306
+ - Ctrl-e: [`cursorLineEnd`](https://codemirror.net/6/docs/ref/#commands.cursorLineEnd) ([`selectLineEnd`](https://codemirror.net/6/docs/ref/#commands.selectLineEnd) with Shift)
1307
+ - Ctrl-d: [`deleteCharForward`](https://codemirror.net/6/docs/ref/#commands.deleteCharForward)
1308
+ - Ctrl-h: [`deleteCharBackward`](https://codemirror.net/6/docs/ref/#commands.deleteCharBackward)
1309
+ - Ctrl-k: [`deleteToLineEnd`](https://codemirror.net/6/docs/ref/#commands.deleteToLineEnd)
1310
+ - Ctrl-Alt-h: [`deleteGroupBackward`](https://codemirror.net/6/docs/ref/#commands.deleteGroupBackward)
1311
+ - Ctrl-o: [`splitLine`](https://codemirror.net/6/docs/ref/#commands.splitLine)
1312
+ - Ctrl-t: [`transposeChars`](https://codemirror.net/6/docs/ref/#commands.transposeChars)
1313
+ - Ctrl-v: [`cursorPageDown`](https://codemirror.net/6/docs/ref/#commands.cursorPageDown)
1314
+ - Alt-v: [`cursorPageUp`](https://codemirror.net/6/docs/ref/#commands.cursorPageUp)
1315
+ */
1316
+ const emacsStyleKeymap = [
1317
+ { key: "Ctrl-b", run: cursorCharLeft, shift: selectCharLeft, preventDefault: true },
1318
+ { key: "Ctrl-f", run: cursorCharRight, shift: selectCharRight },
1319
+ { key: "Ctrl-p", run: cursorLineUp, shift: selectLineUp },
1320
+ { key: "Ctrl-n", run: cursorLineDown, shift: selectLineDown },
1321
+ { key: "Ctrl-a", run: cursorLineStart, shift: selectLineStart },
1322
+ { key: "Ctrl-e", run: cursorLineEnd, shift: selectLineEnd },
1323
+ { key: "Ctrl-d", run: deleteCharForward },
1324
+ { key: "Ctrl-h", run: deleteCharBackward },
1325
+ { key: "Ctrl-k", run: deleteToLineEnd },
1326
+ { key: "Ctrl-Alt-h", run: deleteGroupBackward },
1327
+ { key: "Ctrl-o", run: splitLine },
1328
+ { key: "Ctrl-t", run: transposeChars },
1329
+ { key: "Ctrl-v", run: cursorPageDown },
1330
+ ];
1331
+ /**
1332
+ An array of key bindings closely sticking to platform-standard or
1333
+ widely used bindings. (This includes the bindings from
1334
+ [`emacsStyleKeymap`](https://codemirror.net/6/docs/ref/#commands.emacsStyleKeymap), with their `key`
1335
+ property changed to `mac`.)
1336
+
1337
+ - ArrowLeft: [`cursorCharLeft`](https://codemirror.net/6/docs/ref/#commands.cursorCharLeft) ([`selectCharLeft`](https://codemirror.net/6/docs/ref/#commands.selectCharLeft) with Shift)
1338
+ - ArrowRight: [`cursorCharRight`](https://codemirror.net/6/docs/ref/#commands.cursorCharRight) ([`selectCharRight`](https://codemirror.net/6/docs/ref/#commands.selectCharRight) with Shift)
1339
+ - Ctrl-ArrowLeft (Alt-ArrowLeft on macOS): [`cursorGroupLeft`](https://codemirror.net/6/docs/ref/#commands.cursorGroupLeft) ([`selectGroupLeft`](https://codemirror.net/6/docs/ref/#commands.selectGroupLeft) with Shift)
1340
+ - Ctrl-ArrowRight (Alt-ArrowRight on macOS): [`cursorGroupRight`](https://codemirror.net/6/docs/ref/#commands.cursorGroupRight) ([`selectGroupRight`](https://codemirror.net/6/docs/ref/#commands.selectGroupRight) with Shift)
1341
+ - Cmd-ArrowLeft (on macOS): [`cursorLineStart`](https://codemirror.net/6/docs/ref/#commands.cursorLineStart) ([`selectLineStart`](https://codemirror.net/6/docs/ref/#commands.selectLineStart) with Shift)
1342
+ - Cmd-ArrowRight (on macOS): [`cursorLineEnd`](https://codemirror.net/6/docs/ref/#commands.cursorLineEnd) ([`selectLineEnd`](https://codemirror.net/6/docs/ref/#commands.selectLineEnd) with Shift)
1343
+ - ArrowUp: [`cursorLineUp`](https://codemirror.net/6/docs/ref/#commands.cursorLineUp) ([`selectLineUp`](https://codemirror.net/6/docs/ref/#commands.selectLineUp) with Shift)
1344
+ - ArrowDown: [`cursorLineDown`](https://codemirror.net/6/docs/ref/#commands.cursorLineDown) ([`selectLineDown`](https://codemirror.net/6/docs/ref/#commands.selectLineDown) with Shift)
1345
+ - Cmd-ArrowUp (on macOS): [`cursorDocStart`](https://codemirror.net/6/docs/ref/#commands.cursorDocStart) ([`selectDocStart`](https://codemirror.net/6/docs/ref/#commands.selectDocStart) with Shift)
1346
+ - Cmd-ArrowDown (on macOS): [`cursorDocEnd`](https://codemirror.net/6/docs/ref/#commands.cursorDocEnd) ([`selectDocEnd`](https://codemirror.net/6/docs/ref/#commands.selectDocEnd) with Shift)
1347
+ - Ctrl-ArrowUp (on macOS): [`cursorPageUp`](https://codemirror.net/6/docs/ref/#commands.cursorPageUp) ([`selectPageUp`](https://codemirror.net/6/docs/ref/#commands.selectPageUp) with Shift)
1348
+ - Ctrl-ArrowDown (on macOS): [`cursorPageDown`](https://codemirror.net/6/docs/ref/#commands.cursorPageDown) ([`selectPageDown`](https://codemirror.net/6/docs/ref/#commands.selectPageDown) with Shift)
1349
+ - PageUp: [`cursorPageUp`](https://codemirror.net/6/docs/ref/#commands.cursorPageUp) ([`selectPageUp`](https://codemirror.net/6/docs/ref/#commands.selectPageUp) with Shift)
1350
+ - PageDown: [`cursorPageDown`](https://codemirror.net/6/docs/ref/#commands.cursorPageDown) ([`selectPageDown`](https://codemirror.net/6/docs/ref/#commands.selectPageDown) with Shift)
1351
+ - Home: [`cursorLineBoundaryBackward`](https://codemirror.net/6/docs/ref/#commands.cursorLineBoundaryBackward) ([`selectLineBoundaryBackward`](https://codemirror.net/6/docs/ref/#commands.selectLineBoundaryBackward) with Shift)
1352
+ - End: [`cursorLineBoundaryForward`](https://codemirror.net/6/docs/ref/#commands.cursorLineBoundaryForward) ([`selectLineBoundaryForward`](https://codemirror.net/6/docs/ref/#commands.selectLineBoundaryForward) with Shift)
1353
+ - Ctrl-Home (Cmd-Home on macOS): [`cursorDocStart`](https://codemirror.net/6/docs/ref/#commands.cursorDocStart) ([`selectDocStart`](https://codemirror.net/6/docs/ref/#commands.selectDocStart) with Shift)
1354
+ - Ctrl-End (Cmd-Home on macOS): [`cursorDocEnd`](https://codemirror.net/6/docs/ref/#commands.cursorDocEnd) ([`selectDocEnd`](https://codemirror.net/6/docs/ref/#commands.selectDocEnd) with Shift)
1355
+ - Enter and Shift-Enter: [`insertNewlineAndIndent`](https://codemirror.net/6/docs/ref/#commands.insertNewlineAndIndent)
1356
+ - Ctrl-a (Cmd-a on macOS): [`selectAll`](https://codemirror.net/6/docs/ref/#commands.selectAll)
1357
+ - Backspace: [`deleteCharBackward`](https://codemirror.net/6/docs/ref/#commands.deleteCharBackward)
1358
+ - Delete: [`deleteCharForward`](https://codemirror.net/6/docs/ref/#commands.deleteCharForward)
1359
+ - Ctrl-Backspace (Alt-Backspace on macOS): [`deleteGroupBackward`](https://codemirror.net/6/docs/ref/#commands.deleteGroupBackward)
1360
+ - Ctrl-Delete (Alt-Delete on macOS): [`deleteGroupForward`](https://codemirror.net/6/docs/ref/#commands.deleteGroupForward)
1361
+ - Cmd-Backspace (macOS): [`deleteLineBoundaryBackward`](https://codemirror.net/6/docs/ref/#commands.deleteLineBoundaryBackward).
1362
+ - Cmd-Delete (macOS): [`deleteLineBoundaryForward`](https://codemirror.net/6/docs/ref/#commands.deleteLineBoundaryForward).
1363
+ */
1364
+ const standardKeymap = /*@__PURE__*/[
1365
+ { key: "ArrowLeft", run: cursorCharLeft, shift: selectCharLeft, preventDefault: true },
1366
+ { key: "Mod-ArrowLeft", mac: "Alt-ArrowLeft", run: cursorGroupLeft, shift: selectGroupLeft, preventDefault: true },
1367
+ { mac: "Cmd-ArrowLeft", run: cursorLineBoundaryLeft, shift: selectLineBoundaryLeft, preventDefault: true },
1368
+ { key: "ArrowRight", run: cursorCharRight, shift: selectCharRight, preventDefault: true },
1369
+ { key: "Mod-ArrowRight", mac: "Alt-ArrowRight", run: cursorGroupRight, shift: selectGroupRight, preventDefault: true },
1370
+ { mac: "Cmd-ArrowRight", run: cursorLineBoundaryRight, shift: selectLineBoundaryRight, preventDefault: true },
1371
+ { key: "ArrowUp", run: cursorLineUp, shift: selectLineUp, preventDefault: true },
1372
+ { mac: "Cmd-ArrowUp", run: cursorDocStart, shift: selectDocStart },
1373
+ { mac: "Ctrl-ArrowUp", run: cursorPageUp, shift: selectPageUp },
1374
+ { key: "ArrowDown", run: cursorLineDown, shift: selectLineDown, preventDefault: true },
1375
+ { mac: "Cmd-ArrowDown", run: cursorDocEnd, shift: selectDocEnd },
1376
+ { mac: "Ctrl-ArrowDown", run: cursorPageDown, shift: selectPageDown },
1377
+ { key: "PageUp", run: cursorPageUp, shift: selectPageUp },
1378
+ { key: "PageDown", run: cursorPageDown, shift: selectPageDown },
1379
+ { key: "Home", run: cursorLineBoundaryBackward, shift: selectLineBoundaryBackward, preventDefault: true },
1380
+ { key: "Mod-Home", run: cursorDocStart, shift: selectDocStart },
1381
+ { key: "End", run: cursorLineBoundaryForward, shift: selectLineBoundaryForward, preventDefault: true },
1382
+ { key: "Mod-End", run: cursorDocEnd, shift: selectDocEnd },
1383
+ { key: "Enter", run: insertNewlineAndIndent, shift: insertNewlineAndIndent },
1384
+ { key: "Mod-a", run: selectAll },
1385
+ { key: "Backspace", run: deleteCharBackward, shift: deleteCharBackward },
1386
+ { key: "Delete", run: deleteCharForward },
1387
+ { key: "Mod-Backspace", mac: "Alt-Backspace", run: deleteGroupBackward },
1388
+ { key: "Mod-Delete", mac: "Alt-Delete", run: deleteGroupForward },
1389
+ { mac: "Mod-Backspace", run: deleteLineBoundaryBackward },
1390
+ { mac: "Mod-Delete", run: deleteLineBoundaryForward }
1391
+ ].concat(/*@__PURE__*/emacsStyleKeymap.map(b => ({ mac: b.key, run: b.run, shift: b.shift })));
1392
+ /**
1393
+ The default keymap. Includes all bindings from
1394
+ [`standardKeymap`](https://codemirror.net/6/docs/ref/#commands.standardKeymap) plus the following:
1395
+
1396
+ - Alt-ArrowLeft (Ctrl-ArrowLeft on macOS): [`cursorSyntaxLeft`](https://codemirror.net/6/docs/ref/#commands.cursorSyntaxLeft) ([`selectSyntaxLeft`](https://codemirror.net/6/docs/ref/#commands.selectSyntaxLeft) with Shift)
1397
+ - Alt-ArrowRight (Ctrl-ArrowRight on macOS): [`cursorSyntaxRight`](https://codemirror.net/6/docs/ref/#commands.cursorSyntaxRight) ([`selectSyntaxRight`](https://codemirror.net/6/docs/ref/#commands.selectSyntaxRight) with Shift)
1398
+ - Alt-ArrowUp: [`moveLineUp`](https://codemirror.net/6/docs/ref/#commands.moveLineUp)
1399
+ - Alt-ArrowDown: [`moveLineDown`](https://codemirror.net/6/docs/ref/#commands.moveLineDown)
1400
+ - Shift-Alt-ArrowUp: [`copyLineUp`](https://codemirror.net/6/docs/ref/#commands.copyLineUp)
1401
+ - Shift-Alt-ArrowDown: [`copyLineDown`](https://codemirror.net/6/docs/ref/#commands.copyLineDown)
1402
+ - Escape: [`simplifySelection`](https://codemirror.net/6/docs/ref/#commands.simplifySelection)
1403
+ - Ctrl-Enter (Cmd-Enter on macOS): [`insertBlankLine`](https://codemirror.net/6/docs/ref/#commands.insertBlankLine)
1404
+ - Alt-l (Ctrl-l on macOS): [`selectLine`](https://codemirror.net/6/docs/ref/#commands.selectLine)
1405
+ - Ctrl-i (Cmd-i on macOS): [`selectParentSyntax`](https://codemirror.net/6/docs/ref/#commands.selectParentSyntax)
1406
+ - Ctrl-[ (Cmd-[ on macOS): [`indentLess`](https://codemirror.net/6/docs/ref/#commands.indentLess)
1407
+ - Ctrl-] (Cmd-] on macOS): [`indentMore`](https://codemirror.net/6/docs/ref/#commands.indentMore)
1408
+ - Ctrl-Alt-\\ (Cmd-Alt-\\ on macOS): [`indentSelection`](https://codemirror.net/6/docs/ref/#commands.indentSelection)
1409
+ - Shift-Ctrl-k (Shift-Cmd-k on macOS): [`deleteLine`](https://codemirror.net/6/docs/ref/#commands.deleteLine)
1410
+ - Shift-Ctrl-\\ (Shift-Cmd-\\ on macOS): [`cursorMatchingBracket`](https://codemirror.net/6/docs/ref/#commands.cursorMatchingBracket)
1411
+ - Ctrl-/ (Cmd-/ on macOS): [`toggleComment`](https://codemirror.net/6/docs/ref/#commands.toggleComment).
1412
+ - Shift-Alt-a: [`toggleBlockComment`](https://codemirror.net/6/docs/ref/#commands.toggleBlockComment).
1413
+ - Ctrl-m (Alt-Shift-m on macOS): [`toggleTabFocusMode`](https://codemirror.net/6/docs/ref/#commands.toggleTabFocusMode).
1414
+ */
1415
+ const defaultKeymap = /*@__PURE__*/[
1416
+ { key: "Alt-ArrowLeft", mac: "Ctrl-ArrowLeft", run: cursorSyntaxLeft, shift: selectSyntaxLeft },
1417
+ { key: "Alt-ArrowRight", mac: "Ctrl-ArrowRight", run: cursorSyntaxRight, shift: selectSyntaxRight },
1418
+ { key: "Alt-ArrowUp", run: moveLineUp },
1419
+ { key: "Shift-Alt-ArrowUp", run: copyLineUp },
1420
+ { key: "Alt-ArrowDown", run: moveLineDown },
1421
+ { key: "Shift-Alt-ArrowDown", run: copyLineDown },
1422
+ { key: "Escape", run: simplifySelection },
1423
+ { key: "Mod-Enter", run: insertBlankLine },
1424
+ { key: "Alt-l", mac: "Ctrl-l", run: selectLine },
1425
+ { key: "Mod-i", run: selectParentSyntax, preventDefault: true },
1426
+ { key: "Mod-[", run: indentLess },
1427
+ { key: "Mod-]", run: indentMore },
1428
+ { key: "Mod-Alt-\\", run: indentSelection },
1429
+ { key: "Shift-Mod-k", run: deleteLine },
1430
+ { key: "Shift-Mod-\\", run: cursorMatchingBracket },
1431
+ { key: "Mod-/", run: toggleComment },
1432
+ { key: "Alt-A", run: toggleBlockComment },
1433
+ { key: "Ctrl-m", mac: "Shift-Alt-m", run: toggleTabFocusMode },
1434
+ ].concat(standardKeymap);
1435
+ /**
1436
+ A binding that binds Tab to [`indentMore`](https://codemirror.net/6/docs/ref/#commands.indentMore) and
1437
+ Shift-Tab to [`indentLess`](https://codemirror.net/6/docs/ref/#commands.indentLess).
1438
+ Please see the [Tab example](../../examples/tab/) before using
1439
+ this.
1440
+ */
1441
+ const indentWithTab = { key: "Tab", run: indentMore, shift: indentLess };
1442
+
1443
+ export { copyLineDown, copyLineUp, cursorCharLeft, cursorCharRight, cursorDocEnd, cursorDocStart, cursorGroupLeft, cursorGroupRight, cursorLineBoundaryBackward, cursorLineBoundaryForward, cursorLineBoundaryLeft, cursorLineBoundaryRight, cursorLineDown, cursorLineEnd, cursorLineStart, cursorLineUp, cursorMatchingBracket, cursorPageDown, cursorPageUp, cursorSyntaxLeft, cursorSyntaxRight, defaultKeymap, deleteCharBackward, deleteCharForward, deleteGroupBackward, deleteGroupForward, deleteLine, deleteLineBoundaryBackward, deleteLineBoundaryForward, deleteToLineEnd, emacsStyleKeymap, history, historyKeymap, indentLess, indentMore, indentSelection, indentWithTab, insertBlankLine, insertNewlineAndIndent, invertedEffects, isolateHistory, moveLineDown, moveLineUp, redo, redoSelection, selectAll, selectCharLeft, selectCharRight, selectDocEnd, selectDocStart, selectGroupLeft, selectGroupRight, selectLine, selectLineBoundaryBackward, selectLineBoundaryForward, selectLineBoundaryLeft, selectLineBoundaryRight, selectLineDown, selectLineEnd, selectLineStart, selectLineUp, selectPageDown, selectPageUp, selectParentSyntax, selectSyntaxLeft, selectSyntaxRight, simplifySelection, splitLine, standardKeymap, toggleBlockComment, toggleBlockCommentByLine, toggleComment, toggleLineComment, toggleTabFocusMode, transposeChars, undo, undoSelection };
1444
+ //# sourceMappingURL=index.js.map