update interface button styles
This commit is contained in:
47
index.html
47
index.html
@ -30,7 +30,7 @@
|
||||
}
|
||||
</style>
|
||||
<body>
|
||||
<header class="text-white bg-black">
|
||||
<header class="hidden xl:block text-white bg-black">
|
||||
<div class="mx-auto flex flex-wrap pl-2 py-1 flex-row items-center">
|
||||
<a class="flex title-font font-medium items-center text-black mb-0">
|
||||
<svg xmlns="http://www.w3.org/2000/svg" fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" class="w-10 h-10 text-black p-2 bg-white rounded-full" viewBox="0 0 24 24">
|
||||
@ -42,17 +42,17 @@
|
||||
</a>
|
||||
<nav class="py-0 flex flex-wrap items-center text-base absolute right-0">
|
||||
<span id="clockviewer" class="mr-6 py-2 bg-white text-black rounded align-center text-xs px-2">Clock</span>
|
||||
<a id="play-button" class="mr-5 hover:text-gray-900">
|
||||
<a id="play-button-1" class="mr-5">
|
||||
<svg class="w-6 h-6" fill="currentColor" viewBox="0 0 14 16">
|
||||
<path d="M0 .984v14.032a1 1 0 0 0 1.506.845l12.006-7.016a.974.974 0 0 0 0-1.69L1.506.139A1 1 0 0 0 0 .984Z"/>
|
||||
</svg>
|
||||
</a>
|
||||
<a id="pause-button" class="mr-5 hover:text-gray-900">
|
||||
<a id="pause-button-1" class="mr-5 hover:text-gray-900">
|
||||
<svg class="fill-orange-300 w-6 h-6 text-gray-800 dark:text-white" fill="currentColor" viewBox="0 0 20 20">
|
||||
<path d="M10 .5a9.5 9.5 0 1 0 9.5 9.5A9.51 9.51 0 0 0 10 .5ZM9 13a1 1 0 0 1-2 0V7a1 1 0 0 1 2 0v6Zm4 0a1 1 0 0 1-2 0V7a1 1 0 0 1 2 0v6Z"/>
|
||||
</svg>
|
||||
</a>
|
||||
<a id="clear-button" class="mr-5 hover:text-gray-900">
|
||||
<a id="clear-button-1" class="mr-5 hover:text-gray-900">
|
||||
<svg class="w-6 h-6 text-gray-800 dark:text-white" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" fill="currentColor" viewBox="0 0 17 20">
|
||||
<path d="M7.958 19.393a7.7 7.7 0 0 1-6.715-3.439c-2.868-4.832 0-9.376.944-10.654l.091-.122a3.286 3.286 0 0 0 .765-3.288A1 1 0 0 1 4.6.8c.133.1.313.212.525.347A10.451 10.451 0 0 1 10.6 9.3c.5-1.06.772-2.213.8-3.385a1 1 0 0 1 1.592-.758c1.636 1.205 4.638 6.081 2.019 10.441a8.177 8.177 0 0 1-7.053 3.795Z"/>
|
||||
</svg>
|
||||
@ -83,11 +83,12 @@
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="flex min-h-screen flex flex-col">
|
||||
<div id="modal-container" class="motion-safe:animate-pulse flex min-h-screen flex flex-col">
|
||||
<div id="modal" class="bg-black bg-opacity-50 flex justify-center items-center absolute top-0 right-0 bottom-0 left-0">
|
||||
<div id="start-button" class="bg-white px-16 py-14 rounded-md text-center">
|
||||
<h1 class="text-xl mb-4 font-bold text-black">Topos Prototype</h1>
|
||||
<div id="disclaimer" class="pb-4">
|
||||
<h1 class="text-xl mb-4 font-bold text-black">Topos Prototype</h1>
|
||||
<div id="disclaimer" class="pb-4">
|
||||
|
||||
<p>This is Topos, an experimental live coding platform.</p>
|
||||
<p>Have fun, press <b>Enter/Space</b> to get started!</p>
|
||||
</div>
|
||||
@ -96,27 +97,45 @@
|
||||
|
||||
<div class="flex flex-row">
|
||||
<aside class="flex flex-col items-center w-14 h-screen py-2 overflow-y-auto bg-white border-r rtl:border-l rtl:border-r-0 dark:bg-black dark:border-gray-700">
|
||||
<nav class="flex flex-col space-y-6">
|
||||
|
||||
<a id="local-button" class="pl-2.5 p-1.5 text-gray-700 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-gray-100">
|
||||
<nav class="flex flex-col space-y-6">
|
||||
<a id="local-button" class="pl-2 p-1.5 text-gray-700 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-gray-100">
|
||||
<svg class="w-8 h-8 text-orange-300" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" fill="currentColor" viewBox="0 0 20 20">
|
||||
<path d="M10 15a5 5 0 1 0 0-10 5 5 0 0 0 0 10Zm0-11a1 1 0 0 0 1-1V1a1 1 0 0 0-2 0v2a1 1 0 0 0 1 1Zm0 12a1 1 0 0 0-1 1v2a1 1 0 1 0 2 0v-2a1 1 0 0 0-1-1ZM4.343 5.757a1 1 0 0 0 1.414-1.414L4.343 2.929a1 1 0 0 0-1.414 1.414l1.414 1.414Zm11.314 8.486a1 1 0 0 0-1.414 1.414l1.414 1.414a1 1 0 0 0 1.414-1.414l-1.414-1.414ZM4 10a1 1 0 0 0-1-1H1a1 1 0 0 0 0 2h2a1 1 0 0 0 1-1Zm15-1h-2a1 1 0 1 0 0 2h2a1 1 0 0 0 0-2ZM4.343 14.243l-1.414 1.414a1 1 0 1 0 1.414 1.414l1.414-1.414a1 1 0 0 0-1.414-1.414ZM14.95 6.05a1 1 0 0 0 .707-.293l1.414-1.414a1 1 0 1 0-1.414-1.414l-1.414 1.414a1 1 0 0 0 .707 1.707Z"/>
|
||||
</svg>
|
||||
</a>
|
||||
|
||||
<a id="global-button" class="pl-2.5 p-1.5 text-gray-700 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-gray-100">
|
||||
<a id="global-button" class="pl-2 p-1.5 text-gray-700 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-gray-100">
|
||||
<svg class="w-8 h-8 text-white" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" fill="currentColor" viewBox="0 0 18 20">
|
||||
<path d="M17.8 13.75a1 1 0 0 0-.859-.5A7.488 7.488 0 0 1 10.52 2a1 1 0 0 0 0-.969A1.035 1.035 0 0 0 9.687.5h-.113a9.5 9.5 0 1 0 8.222 14.247 1 1 0 0 0 .004-.997Z"/>
|
||||
</svg>
|
||||
</a>
|
||||
|
||||
<a id="init-button" class="pl-2.5 p-1.5 text-gray-700 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-gray-100">
|
||||
<a id="init-button" class="pl-2 p-1.5 text-gray-700 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-gray-100">
|
||||
<svg class="w-8 h-8 text-white " aria-hidden="true" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 21 20">
|
||||
<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6.487 1.746c0 4.192 3.592 1.66 4.592 5.754 0 .828 1 1.5 2 1.5s2-.672 2-1.5a1.5 1.5 0 0 1 1.5-1.5h1.5m-16.02.471c4.02 2.248 1.776 4.216 4.878 5.645C10.18 13.61 9 19 9 19m9.366-6h-2.287a3 3 0 0 0-3 3v2m6-8a9 9 0 1 1-18 0 9 9 0 0 1 18 0Z"/>
|
||||
</svg>
|
||||
</a>
|
||||
|
||||
<a href="#" class="p-1.5 text-gray-700 absolute bottom-2 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:bg-gray-800 bg-gray-100">
|
||||
|
||||
|
||||
<a id="play-button-2" class="pl-2 p-1.5 text-gray-700 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-gray-100">
|
||||
<svg class="w-8 h-8 text-white block xl:hidden" fill="currentColor" viewBox="0 0 14 16">
|
||||
<path d="M0 .984v14.032a1 1 0 0 0 1.506.845l12.006-7.016a.974.974 0 0 0 0-1.69L1.506.139A1 1 0 0 0 0 .984Z"/>
|
||||
</svg>
|
||||
</a>
|
||||
|
||||
<a id="pause-button-2" class="pl-2 p-1.5 text-gray-700 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-gray-100">
|
||||
<svg class="fill-orange-300 w-8 h-8 block xl:hidden" fill="currentColor" viewBox="0 0 20 20">
|
||||
<path d="M10 .5a9.5 9.5 0 1 0 9.5 9.5A9.51 9.51 0 0 0 10 .5ZM9 13a1 1 0 0 1-2 0V7a1 1 0 0 1 2 0v6Zm4 0a1 1 0 0 1-2 0V7a1 1 0 0 1 2 0v6Z"/>
|
||||
</svg>
|
||||
</a>
|
||||
|
||||
<a id="clear-button-2" class="pl-2 p-1.5 text-gray-700 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:hover:bg-gray-800 hover:bg-gray-100">
|
||||
<svg class="w-8 h-8 text-white block xl:hidden" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" fill="currentColor" viewBox="0 0 17 20">
|
||||
<path d="M7.958 19.393a7.7 7.7 0 0 1-6.715-3.439c-2.868-4.832 0-9.376.944-10.654l.091-.122a3.286 3.286 0 0 0 .765-3.288A1 1 0 0 1 4.6.8c.133.1.313.212.525.347A10.451 10.451 0 0 1 10.6 9.3c.5-1.06.772-2.213.8-3.385a1 1 0 0 1 1.592-.758c1.636 1.205 4.638 6.081 2.019 10.441a8.177 8.177 0 0 1-7.053 3.795Z"/>
|
||||
</svg>
|
||||
</a>
|
||||
|
||||
<a id="settings-button" class="p-2 text-gray-700 ml-1 absolute bottom-2 focus:outline-nones transition-colors duration-200 rounded-lg dark:text-gray-200 dark:bg-gray-800 bg-gray-100">
|
||||
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="w-6 h-6">
|
||||
<path stroke-linecap="round" stroke-linejoin="round" d="M10.343 3.94c.09-.542.56-.94 1.11-.94h1.093c.55 0 1.02.398 1.11.94l.149.894c.07.424.384.764.78.93.398.164.855.142 1.205-.108l.737-.527a1.125 1.125 0 011.45.12l.773.774c.39.389.44 1.002.12 1.45l-.527.737c-.25.35-.272.806-.107 1.204.165.397.505.71.93.78l.893.15c.543.09.94.56.94 1.109v1.094c0 .55-.397 1.02-.94 1.11l-.893.149c-.425.07-.765.383-.93.78-.165.398-.143.854.107 1.204l.527.738c.32.447.269 1.06-.12 1.45l-.774.773a1.125 1.125 0 01-1.449.12l-.738-.527c-.35-.25-.806-.272-1.203-.107-.397.165-.71.505-.781.929l-.149.894c-.09.542-.56.94-1.11.94h-1.094c-.55 0-1.019-.398-1.11-.94l-.148-.894c-.071-.424-.384-.764-.781-.93-.398-.164-.854-.142-1.204.108l-.738.527c-.447.32-1.06.269-1.45-.12l-.773-.774a1.125 1.125 0 01-.12-1.45l.527-.737c.25-.35.273-.806.108-1.204-.165-.397-.505-.71-.93-.78l-.894-.15c-.542-.09-.94-.56-.94-1.109v-1.094c0-.55.398-1.02.94-1.11l.894-.149c.424-.07.765-.383.93-.78.165-.398.143-.854-.107-1.204l-.527-.738a1.125 1.125 0 01.12-1.45l.773-.773a1.125 1.125 0 011.45-.12l.737.527c.35.25.807.272 1.204.107.397-.165.71-.505.78-.929l.15-.894z" />
|
||||
<path stroke-linecap="round" stroke-linejoin="round" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z" />
|
||||
|
||||
1
node_modules/.bin/autoprefixer
generated
vendored
Symbolic link
1
node_modules/.bin/autoprefixer
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../autoprefixer/bin/autoprefixer
|
||||
1
node_modules/.bin/browserslist
generated
vendored
Symbolic link
1
node_modules/.bin/browserslist
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../browserslist/cli.js
|
||||
1
node_modules/.bin/cssesc
generated
vendored
Symbolic link
1
node_modules/.bin/cssesc
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../cssesc/bin/cssesc
|
||||
1
node_modules/.bin/esbuild
generated
vendored
Symbolic link
1
node_modules/.bin/esbuild
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../esbuild/bin/esbuild
|
||||
1
node_modules/.bin/jiti
generated
vendored
Symbolic link
1
node_modules/.bin/jiti
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../jiti/bin/jiti.js
|
||||
1
node_modules/.bin/nanoid
generated
vendored
Symbolic link
1
node_modules/.bin/nanoid
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../nanoid/bin/nanoid.cjs
|
||||
1
node_modules/.bin/resolve
generated
vendored
Symbolic link
1
node_modules/.bin/resolve
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../resolve/bin/resolve
|
||||
1
node_modules/.bin/rollup
generated
vendored
Symbolic link
1
node_modules/.bin/rollup
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../rollup/dist/bin/rollup
|
||||
1
node_modules/.bin/sucrase
generated
vendored
Symbolic link
1
node_modules/.bin/sucrase
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../sucrase/bin/sucrase
|
||||
1
node_modules/.bin/sucrase-node
generated
vendored
Symbolic link
1
node_modules/.bin/sucrase-node
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../sucrase/bin/sucrase-node
|
||||
1
node_modules/.bin/tailwind
generated
vendored
Symbolic link
1
node_modules/.bin/tailwind
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../tailwindcss/lib/cli.js
|
||||
1
node_modules/.bin/tailwindcss
generated
vendored
Symbolic link
1
node_modules/.bin/tailwindcss
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../tailwindcss/lib/cli.js
|
||||
1
node_modules/.bin/tsc
generated
vendored
Symbolic link
1
node_modules/.bin/tsc
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../typescript/bin/tsc
|
||||
1
node_modules/.bin/tsserver
generated
vendored
Symbolic link
1
node_modules/.bin/tsserver
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../typescript/bin/tsserver
|
||||
1
node_modules/.bin/update-browserslist-db
generated
vendored
Symbolic link
1
node_modules/.bin/update-browserslist-db
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../update-browserslist-db/cli.js
|
||||
1
node_modules/.bin/vite
generated
vendored
Symbolic link
1
node_modules/.bin/vite
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
||||
../vite/bin/vite.js
|
||||
69
node_modules/.vite/deps/@codemirror_autocomplete.js
generated
vendored
Normal file
69
node_modules/.vite/deps/@codemirror_autocomplete.js
generated
vendored
Normal file
@ -0,0 +1,69 @@
|
||||
import {
|
||||
CompletionContext,
|
||||
acceptCompletion,
|
||||
autocompletion,
|
||||
clearSnippet,
|
||||
closeBrackets,
|
||||
closeBracketsKeymap,
|
||||
closeCompletion,
|
||||
completeAnyWord,
|
||||
completeFromList,
|
||||
completionKeymap,
|
||||
completionStatus,
|
||||
currentCompletions,
|
||||
deleteBracketPair,
|
||||
hasNextSnippetField,
|
||||
hasPrevSnippetField,
|
||||
ifIn,
|
||||
ifNotIn,
|
||||
insertBracket,
|
||||
insertCompletionText,
|
||||
moveCompletionSelection,
|
||||
nextSnippetField,
|
||||
pickedCompletion,
|
||||
prevSnippetField,
|
||||
selectedCompletion,
|
||||
selectedCompletionIndex,
|
||||
setSelectedCompletion,
|
||||
snippet,
|
||||
snippetCompletion,
|
||||
snippetKeymap,
|
||||
startCompletion
|
||||
} from "./chunk-UFI6XSZR.js";
|
||||
import "./chunk-D63OSQ34.js";
|
||||
import "./chunk-LORPBXGU.js";
|
||||
import "./chunk-MKFMOIK6.js";
|
||||
import "./chunk-BSVZPYOD.js";
|
||||
export {
|
||||
CompletionContext,
|
||||
acceptCompletion,
|
||||
autocompletion,
|
||||
clearSnippet,
|
||||
closeBrackets,
|
||||
closeBracketsKeymap,
|
||||
closeCompletion,
|
||||
completeAnyWord,
|
||||
completeFromList,
|
||||
completionKeymap,
|
||||
completionStatus,
|
||||
currentCompletions,
|
||||
deleteBracketPair,
|
||||
hasNextSnippetField,
|
||||
hasPrevSnippetField,
|
||||
ifIn,
|
||||
ifNotIn,
|
||||
insertBracket,
|
||||
insertCompletionText,
|
||||
moveCompletionSelection,
|
||||
nextSnippetField,
|
||||
pickedCompletion,
|
||||
prevSnippetField,
|
||||
selectedCompletion,
|
||||
selectedCompletionIndex,
|
||||
setSelectedCompletion,
|
||||
snippet,
|
||||
snippetCompletion,
|
||||
snippetKeymap,
|
||||
startCompletion
|
||||
};
|
||||
//# sourceMappingURL=@codemirror_autocomplete.js.map
|
||||
7
node_modules/.vite/deps/@codemirror_autocomplete.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@codemirror_autocomplete.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": [],
|
||||
"sourcesContent": [],
|
||||
"mappings": "",
|
||||
"names": []
|
||||
}
|
||||
205
node_modules/.vite/deps/@codemirror_commands.js
generated
vendored
Normal file
205
node_modules/.vite/deps/@codemirror_commands.js
generated
vendored
Normal file
@ -0,0 +1,205 @@
|
||||
import {
|
||||
blockComment,
|
||||
blockUncomment,
|
||||
copyLineDown,
|
||||
copyLineUp,
|
||||
cursorCharBackward,
|
||||
cursorCharForward,
|
||||
cursorCharLeft,
|
||||
cursorCharRight,
|
||||
cursorDocEnd,
|
||||
cursorDocStart,
|
||||
cursorGroupBackward,
|
||||
cursorGroupForward,
|
||||
cursorGroupLeft,
|
||||
cursorGroupRight,
|
||||
cursorLineBoundaryBackward,
|
||||
cursorLineBoundaryForward,
|
||||
cursorLineBoundaryLeft,
|
||||
cursorLineBoundaryRight,
|
||||
cursorLineDown,
|
||||
cursorLineEnd,
|
||||
cursorLineStart,
|
||||
cursorLineUp,
|
||||
cursorMatchingBracket,
|
||||
cursorPageDown,
|
||||
cursorPageUp,
|
||||
cursorSubwordBackward,
|
||||
cursorSubwordForward,
|
||||
cursorSyntaxLeft,
|
||||
cursorSyntaxRight,
|
||||
defaultKeymap,
|
||||
deleteCharBackward,
|
||||
deleteCharForward,
|
||||
deleteGroupBackward,
|
||||
deleteGroupForward,
|
||||
deleteLine,
|
||||
deleteToLineEnd,
|
||||
deleteToLineStart,
|
||||
deleteTrailingWhitespace,
|
||||
emacsStyleKeymap,
|
||||
history,
|
||||
historyField,
|
||||
historyKeymap,
|
||||
indentLess,
|
||||
indentMore,
|
||||
indentSelection,
|
||||
indentWithTab,
|
||||
insertBlankLine,
|
||||
insertNewline,
|
||||
insertNewlineAndIndent,
|
||||
insertTab,
|
||||
invertedEffects,
|
||||
isolateHistory,
|
||||
lineComment,
|
||||
lineUncomment,
|
||||
moveLineDown,
|
||||
moveLineUp,
|
||||
redo,
|
||||
redoDepth,
|
||||
redoSelection,
|
||||
selectAll,
|
||||
selectCharBackward,
|
||||
selectCharForward,
|
||||
selectCharLeft,
|
||||
selectCharRight,
|
||||
selectDocEnd,
|
||||
selectDocStart,
|
||||
selectGroupBackward,
|
||||
selectGroupForward,
|
||||
selectGroupLeft,
|
||||
selectGroupRight,
|
||||
selectLine,
|
||||
selectLineBoundaryBackward,
|
||||
selectLineBoundaryForward,
|
||||
selectLineBoundaryLeft,
|
||||
selectLineBoundaryRight,
|
||||
selectLineDown,
|
||||
selectLineEnd,
|
||||
selectLineStart,
|
||||
selectLineUp,
|
||||
selectMatchingBracket,
|
||||
selectPageDown,
|
||||
selectPageUp,
|
||||
selectParentSyntax,
|
||||
selectSubwordBackward,
|
||||
selectSubwordForward,
|
||||
selectSyntaxLeft,
|
||||
selectSyntaxRight,
|
||||
simplifySelection,
|
||||
splitLine,
|
||||
standardKeymap,
|
||||
toggleBlockComment,
|
||||
toggleBlockCommentByLine,
|
||||
toggleComment,
|
||||
toggleLineComment,
|
||||
transposeChars,
|
||||
undo,
|
||||
undoDepth,
|
||||
undoSelection
|
||||
} from "./chunk-TRAAS4SM.js";
|
||||
import "./chunk-D63OSQ34.js";
|
||||
import "./chunk-LORPBXGU.js";
|
||||
import "./chunk-MKFMOIK6.js";
|
||||
import "./chunk-BSVZPYOD.js";
|
||||
export {
|
||||
blockComment,
|
||||
blockUncomment,
|
||||
copyLineDown,
|
||||
copyLineUp,
|
||||
cursorCharBackward,
|
||||
cursorCharForward,
|
||||
cursorCharLeft,
|
||||
cursorCharRight,
|
||||
cursorDocEnd,
|
||||
cursorDocStart,
|
||||
cursorGroupBackward,
|
||||
cursorGroupForward,
|
||||
cursorGroupLeft,
|
||||
cursorGroupRight,
|
||||
cursorLineBoundaryBackward,
|
||||
cursorLineBoundaryForward,
|
||||
cursorLineBoundaryLeft,
|
||||
cursorLineBoundaryRight,
|
||||
cursorLineDown,
|
||||
cursorLineEnd,
|
||||
cursorLineStart,
|
||||
cursorLineUp,
|
||||
cursorMatchingBracket,
|
||||
cursorPageDown,
|
||||
cursorPageUp,
|
||||
cursorSubwordBackward,
|
||||
cursorSubwordForward,
|
||||
cursorSyntaxLeft,
|
||||
cursorSyntaxRight,
|
||||
defaultKeymap,
|
||||
deleteCharBackward,
|
||||
deleteCharForward,
|
||||
deleteGroupBackward,
|
||||
deleteGroupForward,
|
||||
deleteLine,
|
||||
deleteToLineEnd,
|
||||
deleteToLineStart,
|
||||
deleteTrailingWhitespace,
|
||||
emacsStyleKeymap,
|
||||
history,
|
||||
historyField,
|
||||
historyKeymap,
|
||||
indentLess,
|
||||
indentMore,
|
||||
indentSelection,
|
||||
indentWithTab,
|
||||
insertBlankLine,
|
||||
insertNewline,
|
||||
insertNewlineAndIndent,
|
||||
insertTab,
|
||||
invertedEffects,
|
||||
isolateHistory,
|
||||
lineComment,
|
||||
lineUncomment,
|
||||
moveLineDown,
|
||||
moveLineUp,
|
||||
redo,
|
||||
redoDepth,
|
||||
redoSelection,
|
||||
selectAll,
|
||||
selectCharBackward,
|
||||
selectCharForward,
|
||||
selectCharLeft,
|
||||
selectCharRight,
|
||||
selectDocEnd,
|
||||
selectDocStart,
|
||||
selectGroupBackward,
|
||||
selectGroupForward,
|
||||
selectGroupLeft,
|
||||
selectGroupRight,
|
||||
selectLine,
|
||||
selectLineBoundaryBackward,
|
||||
selectLineBoundaryForward,
|
||||
selectLineBoundaryLeft,
|
||||
selectLineBoundaryRight,
|
||||
selectLineDown,
|
||||
selectLineEnd,
|
||||
selectLineStart,
|
||||
selectLineUp,
|
||||
selectMatchingBracket,
|
||||
selectPageDown,
|
||||
selectPageUp,
|
||||
selectParentSyntax,
|
||||
selectSubwordBackward,
|
||||
selectSubwordForward,
|
||||
selectSyntaxLeft,
|
||||
selectSyntaxRight,
|
||||
simplifySelection,
|
||||
splitLine,
|
||||
standardKeymap,
|
||||
toggleBlockComment,
|
||||
toggleBlockCommentByLine,
|
||||
toggleComment,
|
||||
toggleLineComment,
|
||||
transposeChars,
|
||||
undo,
|
||||
undoDepth,
|
||||
undoSelection
|
||||
};
|
||||
//# sourceMappingURL=@codemirror_commands.js.map
|
||||
7
node_modules/.vite/deps/@codemirror_commands.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@codemirror_commands.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": [],
|
||||
"sourcesContent": [],
|
||||
"mappings": "",
|
||||
"names": []
|
||||
}
|
||||
2264
node_modules/.vite/deps/@codemirror_lang-javascript.js
generated
vendored
Normal file
2264
node_modules/.vite/deps/@codemirror_lang-javascript.js
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
7
node_modules/.vite/deps/@codemirror_lang-javascript.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@codemirror_lang-javascript.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
114
node_modules/.vite/deps/@codemirror_language.js
generated
vendored
Normal file
114
node_modules/.vite/deps/@codemirror_language.js
generated
vendored
Normal file
@ -0,0 +1,114 @@
|
||||
import {
|
||||
DocInput,
|
||||
HighlightStyle,
|
||||
IndentContext,
|
||||
LRLanguage,
|
||||
Language,
|
||||
LanguageDescription,
|
||||
LanguageSupport,
|
||||
ParseContext,
|
||||
StreamLanguage,
|
||||
StringStream,
|
||||
TreeIndentContext,
|
||||
bracketMatching,
|
||||
bracketMatchingHandle,
|
||||
codeFolding,
|
||||
continuedIndent,
|
||||
defaultHighlightStyle,
|
||||
defineLanguageFacet,
|
||||
delimitedIndent,
|
||||
ensureSyntaxTree,
|
||||
flatIndent,
|
||||
foldAll,
|
||||
foldCode,
|
||||
foldEffect,
|
||||
foldGutter,
|
||||
foldInside,
|
||||
foldKeymap,
|
||||
foldNodeProp,
|
||||
foldService,
|
||||
foldState,
|
||||
foldable,
|
||||
foldedRanges,
|
||||
forceParsing,
|
||||
getIndentUnit,
|
||||
getIndentation,
|
||||
highlightingFor,
|
||||
indentNodeProp,
|
||||
indentOnInput,
|
||||
indentRange,
|
||||
indentService,
|
||||
indentString,
|
||||
indentUnit,
|
||||
language,
|
||||
languageDataProp,
|
||||
matchBrackets,
|
||||
sublanguageProp,
|
||||
syntaxHighlighting,
|
||||
syntaxParserRunning,
|
||||
syntaxTree,
|
||||
syntaxTreeAvailable,
|
||||
toggleFold,
|
||||
unfoldAll,
|
||||
unfoldCode,
|
||||
unfoldEffect
|
||||
} from "./chunk-D63OSQ34.js";
|
||||
import "./chunk-LORPBXGU.js";
|
||||
import "./chunk-MKFMOIK6.js";
|
||||
import "./chunk-BSVZPYOD.js";
|
||||
export {
|
||||
DocInput,
|
||||
HighlightStyle,
|
||||
IndentContext,
|
||||
LRLanguage,
|
||||
Language,
|
||||
LanguageDescription,
|
||||
LanguageSupport,
|
||||
ParseContext,
|
||||
StreamLanguage,
|
||||
StringStream,
|
||||
TreeIndentContext,
|
||||
bracketMatching,
|
||||
bracketMatchingHandle,
|
||||
codeFolding,
|
||||
continuedIndent,
|
||||
defaultHighlightStyle,
|
||||
defineLanguageFacet,
|
||||
delimitedIndent,
|
||||
ensureSyntaxTree,
|
||||
flatIndent,
|
||||
foldAll,
|
||||
foldCode,
|
||||
foldEffect,
|
||||
foldGutter,
|
||||
foldInside,
|
||||
foldKeymap,
|
||||
foldNodeProp,
|
||||
foldService,
|
||||
foldState,
|
||||
foldable,
|
||||
foldedRanges,
|
||||
forceParsing,
|
||||
getIndentUnit,
|
||||
getIndentation,
|
||||
highlightingFor,
|
||||
indentNodeProp,
|
||||
indentOnInput,
|
||||
indentRange,
|
||||
indentService,
|
||||
indentString,
|
||||
indentUnit,
|
||||
language,
|
||||
languageDataProp,
|
||||
matchBrackets,
|
||||
sublanguageProp,
|
||||
syntaxHighlighting,
|
||||
syntaxParserRunning,
|
||||
syntaxTree,
|
||||
syntaxTreeAvailable,
|
||||
toggleFold,
|
||||
unfoldAll,
|
||||
unfoldCode,
|
||||
unfoldEffect
|
||||
};
|
||||
//# sourceMappingURL=@codemirror_language.js.map
|
||||
7
node_modules/.vite/deps/@codemirror_language.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@codemirror_language.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": [],
|
||||
"sourcesContent": [],
|
||||
"mappings": "",
|
||||
"names": []
|
||||
}
|
||||
32
node_modules/.vite/deps/@codemirror_lint.js
generated
vendored
Normal file
32
node_modules/.vite/deps/@codemirror_lint.js
generated
vendored
Normal file
@ -0,0 +1,32 @@
|
||||
import {
|
||||
closeLintPanel,
|
||||
diagnosticCount,
|
||||
forEachDiagnostic,
|
||||
forceLinting,
|
||||
lintGutter,
|
||||
lintKeymap,
|
||||
linter,
|
||||
nextDiagnostic,
|
||||
openLintPanel,
|
||||
previousDiagnostic,
|
||||
setDiagnostics,
|
||||
setDiagnosticsEffect
|
||||
} from "./chunk-P2DAGASU.js";
|
||||
import "./chunk-B45MRPPJ.js";
|
||||
import "./chunk-LORPBXGU.js";
|
||||
import "./chunk-MKFMOIK6.js";
|
||||
export {
|
||||
closeLintPanel,
|
||||
diagnosticCount,
|
||||
forEachDiagnostic,
|
||||
forceLinting,
|
||||
lintGutter,
|
||||
lintKeymap,
|
||||
linter,
|
||||
nextDiagnostic,
|
||||
openLintPanel,
|
||||
previousDiagnostic,
|
||||
setDiagnostics,
|
||||
setDiagnosticsEffect
|
||||
};
|
||||
//# sourceMappingURL=@codemirror_lint.js.map
|
||||
7
node_modules/.vite/deps/@codemirror_lint.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@codemirror_lint.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": [],
|
||||
"sourcesContent": [],
|
||||
"mappings": "",
|
||||
"names": []
|
||||
}
|
||||
46
node_modules/.vite/deps/@codemirror_search.js
generated
vendored
Normal file
46
node_modules/.vite/deps/@codemirror_search.js
generated
vendored
Normal file
@ -0,0 +1,46 @@
|
||||
import {
|
||||
RegExpCursor,
|
||||
SearchCursor,
|
||||
SearchQuery,
|
||||
closeSearchPanel,
|
||||
findNext,
|
||||
findPrevious,
|
||||
getSearchQuery,
|
||||
gotoLine,
|
||||
highlightSelectionMatches,
|
||||
openSearchPanel,
|
||||
replaceAll,
|
||||
replaceNext,
|
||||
search,
|
||||
searchKeymap,
|
||||
searchPanelOpen,
|
||||
selectMatches,
|
||||
selectNextOccurrence,
|
||||
selectSelectionMatches,
|
||||
setSearchQuery
|
||||
} from "./chunk-JOEDLCIZ.js";
|
||||
import "./chunk-B45MRPPJ.js";
|
||||
import "./chunk-LORPBXGU.js";
|
||||
import "./chunk-MKFMOIK6.js";
|
||||
export {
|
||||
RegExpCursor,
|
||||
SearchCursor,
|
||||
SearchQuery,
|
||||
closeSearchPanel,
|
||||
findNext,
|
||||
findPrevious,
|
||||
getSearchQuery,
|
||||
gotoLine,
|
||||
highlightSelectionMatches,
|
||||
openSearchPanel,
|
||||
replaceAll,
|
||||
replaceNext,
|
||||
search,
|
||||
searchKeymap,
|
||||
searchPanelOpen,
|
||||
selectMatches,
|
||||
selectNextOccurrence,
|
||||
selectSelectionMatches,
|
||||
setSearchQuery
|
||||
};
|
||||
//# sourceMappingURL=@codemirror_search.js.map
|
||||
7
node_modules/.vite/deps/@codemirror_search.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@codemirror_search.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": [],
|
||||
"sourcesContent": [],
|
||||
"mappings": "",
|
||||
"names": []
|
||||
}
|
||||
63
node_modules/.vite/deps/@codemirror_state.js
generated
vendored
Normal file
63
node_modules/.vite/deps/@codemirror_state.js
generated
vendored
Normal file
@ -0,0 +1,63 @@
|
||||
import {
|
||||
Annotation,
|
||||
AnnotationType,
|
||||
ChangeDesc,
|
||||
ChangeSet,
|
||||
CharCategory,
|
||||
Compartment,
|
||||
EditorSelection,
|
||||
EditorState,
|
||||
Facet,
|
||||
Line,
|
||||
MapMode,
|
||||
Prec,
|
||||
Range,
|
||||
RangeSet,
|
||||
RangeSetBuilder,
|
||||
RangeValue,
|
||||
SelectionRange,
|
||||
StateEffect,
|
||||
StateEffectType,
|
||||
StateField,
|
||||
Text,
|
||||
Transaction,
|
||||
codePointAt,
|
||||
codePointSize,
|
||||
combineConfig,
|
||||
countColumn,
|
||||
findClusterBreak,
|
||||
findColumn,
|
||||
fromCodePoint
|
||||
} from "./chunk-MKFMOIK6.js";
|
||||
export {
|
||||
Annotation,
|
||||
AnnotationType,
|
||||
ChangeDesc,
|
||||
ChangeSet,
|
||||
CharCategory,
|
||||
Compartment,
|
||||
EditorSelection,
|
||||
EditorState,
|
||||
Facet,
|
||||
Line,
|
||||
MapMode,
|
||||
Prec,
|
||||
Range,
|
||||
RangeSet,
|
||||
RangeSetBuilder,
|
||||
RangeValue,
|
||||
SelectionRange,
|
||||
StateEffect,
|
||||
StateEffectType,
|
||||
StateField,
|
||||
Text,
|
||||
Transaction,
|
||||
codePointAt,
|
||||
codePointSize,
|
||||
combineConfig,
|
||||
countColumn,
|
||||
findClusterBreak,
|
||||
findColumn,
|
||||
fromCodePoint
|
||||
};
|
||||
//# sourceMappingURL=@codemirror_state.js.map
|
||||
7
node_modules/.vite/deps/@codemirror_state.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@codemirror_state.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": [],
|
||||
"sourcesContent": [],
|
||||
"mappings": "",
|
||||
"names": []
|
||||
}
|
||||
92
node_modules/.vite/deps/@codemirror_view.js
generated
vendored
Normal file
92
node_modules/.vite/deps/@codemirror_view.js
generated
vendored
Normal file
@ -0,0 +1,92 @@
|
||||
import {
|
||||
BidiSpan,
|
||||
BlockInfo,
|
||||
BlockType,
|
||||
Decoration,
|
||||
Direction,
|
||||
EditorView,
|
||||
GutterMarker,
|
||||
MatchDecorator,
|
||||
RectangleMarker,
|
||||
ViewPlugin,
|
||||
ViewUpdate,
|
||||
WidgetType,
|
||||
__test,
|
||||
closeHoverTooltips,
|
||||
crosshairCursor,
|
||||
drawSelection,
|
||||
dropCursor,
|
||||
getPanel,
|
||||
getTooltip,
|
||||
gutter,
|
||||
gutterLineClass,
|
||||
gutters,
|
||||
hasHoverTooltips,
|
||||
highlightActiveLine,
|
||||
highlightActiveLineGutter,
|
||||
highlightSpecialChars,
|
||||
highlightTrailingWhitespace,
|
||||
highlightWhitespace,
|
||||
hoverTooltip,
|
||||
keymap,
|
||||
layer,
|
||||
lineNumberMarkers,
|
||||
lineNumbers,
|
||||
logException,
|
||||
panels,
|
||||
placeholder,
|
||||
rectangularSelection,
|
||||
repositionTooltips,
|
||||
runScopeHandlers,
|
||||
scrollPastEnd,
|
||||
showPanel,
|
||||
showTooltip,
|
||||
tooltips
|
||||
} from "./chunk-LORPBXGU.js";
|
||||
import "./chunk-MKFMOIK6.js";
|
||||
export {
|
||||
BidiSpan,
|
||||
BlockInfo,
|
||||
BlockType,
|
||||
Decoration,
|
||||
Direction,
|
||||
EditorView,
|
||||
GutterMarker,
|
||||
MatchDecorator,
|
||||
RectangleMarker,
|
||||
ViewPlugin,
|
||||
ViewUpdate,
|
||||
WidgetType,
|
||||
__test,
|
||||
closeHoverTooltips,
|
||||
crosshairCursor,
|
||||
drawSelection,
|
||||
dropCursor,
|
||||
getPanel,
|
||||
getTooltip,
|
||||
gutter,
|
||||
gutterLineClass,
|
||||
gutters,
|
||||
hasHoverTooltips,
|
||||
highlightActiveLine,
|
||||
highlightActiveLineGutter,
|
||||
highlightSpecialChars,
|
||||
highlightTrailingWhitespace,
|
||||
highlightWhitespace,
|
||||
hoverTooltip,
|
||||
keymap,
|
||||
layer,
|
||||
lineNumberMarkers,
|
||||
lineNumbers,
|
||||
logException,
|
||||
panels,
|
||||
placeholder,
|
||||
rectangularSelection,
|
||||
repositionTooltips,
|
||||
runScopeHandlers,
|
||||
scrollPastEnd,
|
||||
showPanel,
|
||||
showTooltip,
|
||||
tooltips
|
||||
};
|
||||
//# sourceMappingURL=@codemirror_view.js.map
|
||||
7
node_modules/.vite/deps/@codemirror_view.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@codemirror_view.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": [],
|
||||
"sourcesContent": [],
|
||||
"mappings": "",
|
||||
"names": []
|
||||
}
|
||||
19
node_modules/.vite/deps/@lezer_highlight.js
generated
vendored
Normal file
19
node_modules/.vite/deps/@lezer_highlight.js
generated
vendored
Normal file
@ -0,0 +1,19 @@
|
||||
import {
|
||||
Tag,
|
||||
classHighlighter,
|
||||
getStyleTags,
|
||||
highlightTree,
|
||||
styleTags,
|
||||
tagHighlighter,
|
||||
tags
|
||||
} from "./chunk-BSVZPYOD.js";
|
||||
export {
|
||||
Tag,
|
||||
classHighlighter,
|
||||
getStyleTags,
|
||||
highlightTree,
|
||||
styleTags,
|
||||
tagHighlighter,
|
||||
tags
|
||||
};
|
||||
//# sourceMappingURL=@lezer_highlight.js.map
|
||||
7
node_modules/.vite/deps/@lezer_highlight.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@lezer_highlight.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": [],
|
||||
"sourcesContent": [],
|
||||
"mappings": "",
|
||||
"names": []
|
||||
}
|
||||
7238
node_modules/.vite/deps/@replit_codemirror-vim.js
generated
vendored
Normal file
7238
node_modules/.vite/deps/@replit_codemirror-vim.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7
node_modules/.vite/deps/@replit_codemirror-vim.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/@replit_codemirror-vim.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
107
node_modules/.vite/deps/_metadata.json
generated
vendored
Normal file
107
node_modules/.vite/deps/_metadata.json
generated
vendored
Normal file
@ -0,0 +1,107 @@
|
||||
{
|
||||
"hash": "28ccedc6",
|
||||
"browserHash": "c391915d",
|
||||
"optimized": {
|
||||
"@codemirror/autocomplete": {
|
||||
"src": "../../@codemirror/autocomplete/dist/index.js",
|
||||
"file": "@codemirror_autocomplete.js",
|
||||
"fileHash": "f0ba3f48",
|
||||
"needsInterop": false
|
||||
},
|
||||
"@codemirror/commands": {
|
||||
"src": "../../@codemirror/commands/dist/index.js",
|
||||
"file": "@codemirror_commands.js",
|
||||
"fileHash": "bf5d0d66",
|
||||
"needsInterop": false
|
||||
},
|
||||
"@codemirror/lang-javascript": {
|
||||
"src": "../../@codemirror/lang-javascript/dist/index.js",
|
||||
"file": "@codemirror_lang-javascript.js",
|
||||
"fileHash": "526d6ab6",
|
||||
"needsInterop": false
|
||||
},
|
||||
"@codemirror/language": {
|
||||
"src": "../../@codemirror/language/dist/index.js",
|
||||
"file": "@codemirror_language.js",
|
||||
"fileHash": "d13d9419",
|
||||
"needsInterop": false
|
||||
},
|
||||
"@codemirror/lint": {
|
||||
"src": "../../@codemirror/lint/dist/index.js",
|
||||
"file": "@codemirror_lint.js",
|
||||
"fileHash": "6d1e1d91",
|
||||
"needsInterop": false
|
||||
},
|
||||
"@codemirror/search": {
|
||||
"src": "../../@codemirror/search/dist/index.js",
|
||||
"file": "@codemirror_search.js",
|
||||
"fileHash": "a87f8d7f",
|
||||
"needsInterop": false
|
||||
},
|
||||
"@codemirror/state": {
|
||||
"src": "../../@codemirror/state/dist/index.js",
|
||||
"file": "@codemirror_state.js",
|
||||
"fileHash": "fcdd8f0f",
|
||||
"needsInterop": false
|
||||
},
|
||||
"@codemirror/view": {
|
||||
"src": "../../@codemirror/view/dist/index.js",
|
||||
"file": "@codemirror_view.js",
|
||||
"fileHash": "b6577eae",
|
||||
"needsInterop": false
|
||||
},
|
||||
"@lezer/highlight": {
|
||||
"src": "../../@lezer/highlight/dist/index.js",
|
||||
"file": "@lezer_highlight.js",
|
||||
"fileHash": "d1c1ebfc",
|
||||
"needsInterop": false
|
||||
},
|
||||
"@replit/codemirror-vim": {
|
||||
"src": "../../@replit/codemirror-vim/dist/index.js",
|
||||
"file": "@replit_codemirror-vim.js",
|
||||
"fileHash": "232e9358",
|
||||
"needsInterop": false
|
||||
},
|
||||
"codemirror": {
|
||||
"src": "../../codemirror/dist/index.js",
|
||||
"file": "codemirror.js",
|
||||
"fileHash": "f624d563",
|
||||
"needsInterop": false
|
||||
},
|
||||
"zzfx": {
|
||||
"src": "../../zzfx/ZzFX.js",
|
||||
"file": "zzfx.js",
|
||||
"fileHash": "f344322d",
|
||||
"needsInterop": false
|
||||
}
|
||||
},
|
||||
"chunks": {
|
||||
"chunk-TRAAS4SM": {
|
||||
"file": "chunk-TRAAS4SM.js"
|
||||
},
|
||||
"chunk-UFI6XSZR": {
|
||||
"file": "chunk-UFI6XSZR.js"
|
||||
},
|
||||
"chunk-D63OSQ34": {
|
||||
"file": "chunk-D63OSQ34.js"
|
||||
},
|
||||
"chunk-P2DAGASU": {
|
||||
"file": "chunk-P2DAGASU.js"
|
||||
},
|
||||
"chunk-JOEDLCIZ": {
|
||||
"file": "chunk-JOEDLCIZ.js"
|
||||
},
|
||||
"chunk-B45MRPPJ": {
|
||||
"file": "chunk-B45MRPPJ.js"
|
||||
},
|
||||
"chunk-LORPBXGU": {
|
||||
"file": "chunk-LORPBXGU.js"
|
||||
},
|
||||
"chunk-MKFMOIK6": {
|
||||
"file": "chunk-MKFMOIK6.js"
|
||||
},
|
||||
"chunk-BSVZPYOD": {
|
||||
"file": "chunk-BSVZPYOD.js"
|
||||
}
|
||||
}
|
||||
}
|
||||
39
node_modules/.vite/deps/chunk-B45MRPPJ.js
generated
vendored
Normal file
39
node_modules/.vite/deps/chunk-B45MRPPJ.js
generated
vendored
Normal file
@ -0,0 +1,39 @@
|
||||
// node_modules/crelt/index.js
|
||||
function crelt() {
|
||||
var elt = arguments[0];
|
||||
if (typeof elt == "string")
|
||||
elt = document.createElement(elt);
|
||||
var i = 1, next = arguments[1];
|
||||
if (next && typeof next == "object" && next.nodeType == null && !Array.isArray(next)) {
|
||||
for (var name in next)
|
||||
if (Object.prototype.hasOwnProperty.call(next, name)) {
|
||||
var value = next[name];
|
||||
if (typeof value == "string")
|
||||
elt.setAttribute(name, value);
|
||||
else if (value != null)
|
||||
elt[name] = value;
|
||||
}
|
||||
i++;
|
||||
}
|
||||
for (; i < arguments.length; i++)
|
||||
add(elt, arguments[i]);
|
||||
return elt;
|
||||
}
|
||||
function add(elt, child) {
|
||||
if (typeof child == "string") {
|
||||
elt.appendChild(document.createTextNode(child));
|
||||
} else if (child == null) {
|
||||
} else if (child.nodeType != null) {
|
||||
elt.appendChild(child);
|
||||
} else if (Array.isArray(child)) {
|
||||
for (var i = 0; i < child.length; i++)
|
||||
add(elt, child[i]);
|
||||
} else {
|
||||
throw new RangeError("Unsupported child node: " + child);
|
||||
}
|
||||
}
|
||||
|
||||
export {
|
||||
crelt
|
||||
};
|
||||
//# sourceMappingURL=chunk-B45MRPPJ.js.map
|
||||
7
node_modules/.vite/deps/chunk-B45MRPPJ.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/chunk-B45MRPPJ.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": ["../../crelt/index.js"],
|
||||
"sourcesContent": ["export default function crelt() {\n var elt = arguments[0]\n if (typeof elt == \"string\") elt = document.createElement(elt)\n var i = 1, next = arguments[1]\n if (next && typeof next == \"object\" && next.nodeType == null && !Array.isArray(next)) {\n for (var name in next) if (Object.prototype.hasOwnProperty.call(next, name)) {\n var value = next[name]\n if (typeof value == \"string\") elt.setAttribute(name, value)\n else if (value != null) elt[name] = value\n }\n i++\n }\n for (; i < arguments.length; i++) add(elt, arguments[i])\n return elt\n}\n\nfunction add(elt, child) {\n if (typeof child == \"string\") {\n elt.appendChild(document.createTextNode(child))\n } else if (child == null) {\n } else if (child.nodeType != null) {\n elt.appendChild(child)\n } else if (Array.isArray(child)) {\n for (var i = 0; i < child.length; i++) add(elt, child[i])\n } else {\n throw new RangeError(\"Unsupported child node: \" + child)\n }\n}\n"],
|
||||
"mappings": ";AAAe,SAAR,QAAyB;AAC9B,MAAI,MAAM,UAAU,CAAC;AACrB,MAAI,OAAO,OAAO;AAAU,UAAM,SAAS,cAAc,GAAG;AAC5D,MAAI,IAAI,GAAG,OAAO,UAAU,CAAC;AAC7B,MAAI,QAAQ,OAAO,QAAQ,YAAY,KAAK,YAAY,QAAQ,CAAC,MAAM,QAAQ,IAAI,GAAG;AACpF,aAAS,QAAQ;AAAM,UAAI,OAAO,UAAU,eAAe,KAAK,MAAM,IAAI,GAAG;AAC3E,YAAI,QAAQ,KAAK,IAAI;AACrB,YAAI,OAAO,SAAS;AAAU,cAAI,aAAa,MAAM,KAAK;AAAA,iBACjD,SAAS;AAAM,cAAI,IAAI,IAAI;AAAA,MACtC;AACA;AAAA,EACF;AACA,SAAO,IAAI,UAAU,QAAQ;AAAK,QAAI,KAAK,UAAU,CAAC,CAAC;AACvD,SAAO;AACT;AAEA,SAAS,IAAI,KAAK,OAAO;AACvB,MAAI,OAAO,SAAS,UAAU;AAC5B,QAAI,YAAY,SAAS,eAAe,KAAK,CAAC;AAAA,EAChD,WAAW,SAAS,MAAM;AAAA,EAC1B,WAAW,MAAM,YAAY,MAAM;AACjC,QAAI,YAAY,KAAK;AAAA,EACvB,WAAW,MAAM,QAAQ,KAAK,GAAG;AAC/B,aAAS,IAAI,GAAG,IAAI,MAAM,QAAQ;AAAK,UAAI,KAAK,MAAM,CAAC,CAAC;AAAA,EAC1D,OAAO;AACL,UAAM,IAAI,WAAW,6BAA6B,KAAK;AAAA,EACzD;AACF;",
|
||||
"names": []
|
||||
}
|
||||
2155
node_modules/.vite/deps/chunk-BSVZPYOD.js
generated
vendored
Normal file
2155
node_modules/.vite/deps/chunk-BSVZPYOD.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7
node_modules/.vite/deps/chunk-BSVZPYOD.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/chunk-BSVZPYOD.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
2211
node_modules/.vite/deps/chunk-D63OSQ34.js
generated
vendored
Normal file
2211
node_modules/.vite/deps/chunk-D63OSQ34.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7
node_modules/.vite/deps/chunk-D63OSQ34.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/chunk-D63OSQ34.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
1138
node_modules/.vite/deps/chunk-JOEDLCIZ.js
generated
vendored
Normal file
1138
node_modules/.vite/deps/chunk-JOEDLCIZ.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7
node_modules/.vite/deps/chunk-JOEDLCIZ.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/chunk-JOEDLCIZ.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
9286
node_modules/.vite/deps/chunk-LORPBXGU.js
generated
vendored
Normal file
9286
node_modules/.vite/deps/chunk-LORPBXGU.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7
node_modules/.vite/deps/chunk-LORPBXGU.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/chunk-LORPBXGU.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
3380
node_modules/.vite/deps/chunk-MKFMOIK6.js
generated
vendored
Normal file
3380
node_modules/.vite/deps/chunk-MKFMOIK6.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7
node_modules/.vite/deps/chunk-MKFMOIK6.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/chunk-MKFMOIK6.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
764
node_modules/.vite/deps/chunk-P2DAGASU.js
generated
vendored
Normal file
764
node_modules/.vite/deps/chunk-P2DAGASU.js
generated
vendored
Normal file
@ -0,0 +1,764 @@
|
||||
import {
|
||||
crelt
|
||||
} from "./chunk-B45MRPPJ.js";
|
||||
import {
|
||||
Decoration,
|
||||
EditorView,
|
||||
GutterMarker,
|
||||
ViewPlugin,
|
||||
WidgetType,
|
||||
getPanel,
|
||||
gutter,
|
||||
hoverTooltip,
|
||||
logException,
|
||||
showPanel,
|
||||
showTooltip
|
||||
} from "./chunk-LORPBXGU.js";
|
||||
import {
|
||||
Facet,
|
||||
RangeSet,
|
||||
StateEffect,
|
||||
StateField,
|
||||
combineConfig
|
||||
} from "./chunk-MKFMOIK6.js";
|
||||
|
||||
// node_modules/@codemirror/lint/dist/index.js
|
||||
var SelectedDiagnostic = class {
|
||||
constructor(from, to, diagnostic) {
|
||||
this.from = from;
|
||||
this.to = to;
|
||||
this.diagnostic = diagnostic;
|
||||
}
|
||||
};
|
||||
var LintState = class _LintState {
|
||||
constructor(diagnostics, panel, selected) {
|
||||
this.diagnostics = diagnostics;
|
||||
this.panel = panel;
|
||||
this.selected = selected;
|
||||
}
|
||||
static init(diagnostics, panel, state) {
|
||||
let markedDiagnostics = diagnostics;
|
||||
let diagnosticFilter = state.facet(lintConfig).markerFilter;
|
||||
if (diagnosticFilter)
|
||||
markedDiagnostics = diagnosticFilter(markedDiagnostics);
|
||||
let ranges = Decoration.set(markedDiagnostics.map((d) => {
|
||||
return d.from == d.to || d.from == d.to - 1 && state.doc.lineAt(d.from).to == d.from ? Decoration.widget({
|
||||
widget: new DiagnosticWidget(d),
|
||||
diagnostic: d
|
||||
}).range(d.from) : Decoration.mark({
|
||||
attributes: { class: "cm-lintRange cm-lintRange-" + d.severity + (d.markClass ? " " + d.markClass : "") },
|
||||
diagnostic: d
|
||||
}).range(d.from, d.to);
|
||||
}), true);
|
||||
return new _LintState(ranges, panel, findDiagnostic(ranges));
|
||||
}
|
||||
};
|
||||
function findDiagnostic(diagnostics, diagnostic = null, after = 0) {
|
||||
let found = null;
|
||||
diagnostics.between(after, 1e9, (from, to, { spec }) => {
|
||||
if (diagnostic && spec.diagnostic != diagnostic)
|
||||
return;
|
||||
found = new SelectedDiagnostic(from, to, spec.diagnostic);
|
||||
return false;
|
||||
});
|
||||
return found;
|
||||
}
|
||||
function hideTooltip(tr, tooltip) {
|
||||
let line = tr.startState.doc.lineAt(tooltip.pos);
|
||||
return !!(tr.effects.some((e) => e.is(setDiagnosticsEffect)) || tr.changes.touchesRange(line.from, line.to));
|
||||
}
|
||||
function maybeEnableLint(state, effects) {
|
||||
return state.field(lintState, false) ? effects : effects.concat(StateEffect.appendConfig.of(lintExtensions));
|
||||
}
|
||||
function setDiagnostics(state, diagnostics) {
|
||||
return {
|
||||
effects: maybeEnableLint(state, [setDiagnosticsEffect.of(diagnostics)])
|
||||
};
|
||||
}
|
||||
var setDiagnosticsEffect = StateEffect.define();
|
||||
var togglePanel = StateEffect.define();
|
||||
var movePanelSelection = StateEffect.define();
|
||||
var lintState = StateField.define({
|
||||
create() {
|
||||
return new LintState(Decoration.none, null, null);
|
||||
},
|
||||
update(value, tr) {
|
||||
if (tr.docChanged) {
|
||||
let mapped = value.diagnostics.map(tr.changes), selected = null;
|
||||
if (value.selected) {
|
||||
let selPos = tr.changes.mapPos(value.selected.from, 1);
|
||||
selected = findDiagnostic(mapped, value.selected.diagnostic, selPos) || findDiagnostic(mapped, null, selPos);
|
||||
}
|
||||
value = new LintState(mapped, value.panel, selected);
|
||||
}
|
||||
for (let effect of tr.effects) {
|
||||
if (effect.is(setDiagnosticsEffect)) {
|
||||
value = LintState.init(effect.value, value.panel, tr.state);
|
||||
} else if (effect.is(togglePanel)) {
|
||||
value = new LintState(value.diagnostics, effect.value ? LintPanel.open : null, value.selected);
|
||||
} else if (effect.is(movePanelSelection)) {
|
||||
value = new LintState(value.diagnostics, value.panel, effect.value);
|
||||
}
|
||||
}
|
||||
return value;
|
||||
},
|
||||
provide: (f) => [
|
||||
showPanel.from(f, (val) => val.panel),
|
||||
EditorView.decorations.from(f, (s) => s.diagnostics)
|
||||
]
|
||||
});
|
||||
function diagnosticCount(state) {
|
||||
let lint = state.field(lintState, false);
|
||||
return lint ? lint.diagnostics.size : 0;
|
||||
}
|
||||
var activeMark = Decoration.mark({ class: "cm-lintRange cm-lintRange-active" });
|
||||
function lintTooltip(view, pos, side) {
|
||||
let { diagnostics } = view.state.field(lintState);
|
||||
let found = [], stackStart = 2e8, stackEnd = 0;
|
||||
diagnostics.between(pos - (side < 0 ? 1 : 0), pos + (side > 0 ? 1 : 0), (from, to, { spec }) => {
|
||||
if (pos >= from && pos <= to && (from == to || (pos > from || side > 0) && (pos < to || side < 0))) {
|
||||
found.push(spec.diagnostic);
|
||||
stackStart = Math.min(from, stackStart);
|
||||
stackEnd = Math.max(to, stackEnd);
|
||||
}
|
||||
});
|
||||
let diagnosticFilter = view.state.facet(lintConfig).tooltipFilter;
|
||||
if (diagnosticFilter)
|
||||
found = diagnosticFilter(found);
|
||||
if (!found.length)
|
||||
return null;
|
||||
return {
|
||||
pos: stackStart,
|
||||
end: stackEnd,
|
||||
above: view.state.doc.lineAt(stackStart).to < stackEnd,
|
||||
create() {
|
||||
return { dom: diagnosticsTooltip(view, found) };
|
||||
}
|
||||
};
|
||||
}
|
||||
function diagnosticsTooltip(view, diagnostics) {
|
||||
return crelt("ul", { class: "cm-tooltip-lint" }, diagnostics.map((d) => renderDiagnostic(view, d, false)));
|
||||
}
|
||||
var openLintPanel = (view) => {
|
||||
let field = view.state.field(lintState, false);
|
||||
if (!field || !field.panel)
|
||||
view.dispatch({ effects: maybeEnableLint(view.state, [togglePanel.of(true)]) });
|
||||
let panel = getPanel(view, LintPanel.open);
|
||||
if (panel)
|
||||
panel.dom.querySelector(".cm-panel-lint ul").focus();
|
||||
return true;
|
||||
};
|
||||
var closeLintPanel = (view) => {
|
||||
let field = view.state.field(lintState, false);
|
||||
if (!field || !field.panel)
|
||||
return false;
|
||||
view.dispatch({ effects: togglePanel.of(false) });
|
||||
return true;
|
||||
};
|
||||
var nextDiagnostic = (view) => {
|
||||
let field = view.state.field(lintState, false);
|
||||
if (!field)
|
||||
return false;
|
||||
let sel = view.state.selection.main, next = field.diagnostics.iter(sel.to + 1);
|
||||
if (!next.value) {
|
||||
next = field.diagnostics.iter(0);
|
||||
if (!next.value || next.from == sel.from && next.to == sel.to)
|
||||
return false;
|
||||
}
|
||||
view.dispatch({ selection: { anchor: next.from, head: next.to }, scrollIntoView: true });
|
||||
return true;
|
||||
};
|
||||
var previousDiagnostic = (view) => {
|
||||
let { state } = view, field = state.field(lintState, false);
|
||||
if (!field)
|
||||
return false;
|
||||
let sel = state.selection.main;
|
||||
let prevFrom, prevTo, lastFrom, lastTo;
|
||||
field.diagnostics.between(0, state.doc.length, (from, to) => {
|
||||
if (to < sel.to && (prevFrom == null || prevFrom < from)) {
|
||||
prevFrom = from;
|
||||
prevTo = to;
|
||||
}
|
||||
if (lastFrom == null || from > lastFrom) {
|
||||
lastFrom = from;
|
||||
lastTo = to;
|
||||
}
|
||||
});
|
||||
if (lastFrom == null || prevFrom == null && lastFrom == sel.from)
|
||||
return false;
|
||||
view.dispatch({ selection: { anchor: prevFrom !== null && prevFrom !== void 0 ? prevFrom : lastFrom, head: prevTo !== null && prevTo !== void 0 ? prevTo : lastTo }, scrollIntoView: true });
|
||||
return true;
|
||||
};
|
||||
var lintKeymap = [
|
||||
{ key: "Mod-Shift-m", run: openLintPanel, preventDefault: true },
|
||||
{ key: "F8", run: nextDiagnostic }
|
||||
];
|
||||
var lintPlugin = ViewPlugin.fromClass(class {
|
||||
constructor(view) {
|
||||
this.view = view;
|
||||
this.timeout = -1;
|
||||
this.set = true;
|
||||
let { delay } = view.state.facet(lintConfig);
|
||||
this.lintTime = Date.now() + delay;
|
||||
this.run = this.run.bind(this);
|
||||
this.timeout = setTimeout(this.run, delay);
|
||||
}
|
||||
run() {
|
||||
let now = Date.now();
|
||||
if (now < this.lintTime - 10) {
|
||||
setTimeout(this.run, this.lintTime - now);
|
||||
} else {
|
||||
this.set = false;
|
||||
let { state } = this.view, { sources } = state.facet(lintConfig);
|
||||
Promise.all(sources.map((source) => Promise.resolve(source(this.view)))).then((annotations) => {
|
||||
let all = annotations.reduce((a, b) => a.concat(b));
|
||||
if (this.view.state.doc == state.doc)
|
||||
this.view.dispatch(setDiagnostics(this.view.state, all));
|
||||
}, (error) => {
|
||||
logException(this.view.state, error);
|
||||
});
|
||||
}
|
||||
}
|
||||
update(update) {
|
||||
let config = update.state.facet(lintConfig);
|
||||
if (update.docChanged || config != update.startState.facet(lintConfig) || config.needsRefresh && config.needsRefresh(update)) {
|
||||
this.lintTime = Date.now() + config.delay;
|
||||
if (!this.set) {
|
||||
this.set = true;
|
||||
this.timeout = setTimeout(this.run, config.delay);
|
||||
}
|
||||
}
|
||||
}
|
||||
force() {
|
||||
if (this.set) {
|
||||
this.lintTime = Date.now();
|
||||
this.run();
|
||||
}
|
||||
}
|
||||
destroy() {
|
||||
clearTimeout(this.timeout);
|
||||
}
|
||||
});
|
||||
var lintConfig = Facet.define({
|
||||
combine(input) {
|
||||
return Object.assign({ sources: input.map((i) => i.source) }, combineConfig(input.map((i) => i.config), {
|
||||
delay: 750,
|
||||
markerFilter: null,
|
||||
tooltipFilter: null,
|
||||
needsRefresh: null
|
||||
}, {
|
||||
needsRefresh: (a, b) => !a ? b : !b ? a : (u) => a(u) || b(u)
|
||||
}));
|
||||
}
|
||||
});
|
||||
function linter(source, config = {}) {
|
||||
return [
|
||||
lintConfig.of({ source, config }),
|
||||
lintPlugin,
|
||||
lintExtensions
|
||||
];
|
||||
}
|
||||
function forceLinting(view) {
|
||||
let plugin = view.plugin(lintPlugin);
|
||||
if (plugin)
|
||||
plugin.force();
|
||||
}
|
||||
function assignKeys(actions) {
|
||||
let assigned = [];
|
||||
if (actions)
|
||||
actions:
|
||||
for (let { name } of actions) {
|
||||
for (let i = 0; i < name.length; i++) {
|
||||
let ch = name[i];
|
||||
if (/[a-zA-Z]/.test(ch) && !assigned.some((c) => c.toLowerCase() == ch.toLowerCase())) {
|
||||
assigned.push(ch);
|
||||
continue actions;
|
||||
}
|
||||
}
|
||||
assigned.push("");
|
||||
}
|
||||
return assigned;
|
||||
}
|
||||
function renderDiagnostic(view, diagnostic, inPanel) {
|
||||
var _a;
|
||||
let keys = inPanel ? assignKeys(diagnostic.actions) : [];
|
||||
return crelt("li", { class: "cm-diagnostic cm-diagnostic-" + diagnostic.severity }, crelt("span", { class: "cm-diagnosticText" }, diagnostic.renderMessage ? diagnostic.renderMessage() : diagnostic.message), (_a = diagnostic.actions) === null || _a === void 0 ? void 0 : _a.map((action, i) => {
|
||||
let fired = false, click = (e) => {
|
||||
e.preventDefault();
|
||||
if (fired)
|
||||
return;
|
||||
fired = true;
|
||||
let found = findDiagnostic(view.state.field(lintState).diagnostics, diagnostic);
|
||||
if (found)
|
||||
action.apply(view, found.from, found.to);
|
||||
};
|
||||
let { name } = action, keyIndex = keys[i] ? name.indexOf(keys[i]) : -1;
|
||||
let nameElt = keyIndex < 0 ? name : [
|
||||
name.slice(0, keyIndex),
|
||||
crelt("u", name.slice(keyIndex, keyIndex + 1)),
|
||||
name.slice(keyIndex + 1)
|
||||
];
|
||||
return crelt("button", {
|
||||
type: "button",
|
||||
class: "cm-diagnosticAction",
|
||||
onclick: click,
|
||||
onmousedown: click,
|
||||
"aria-label": ` Action: ${name}${keyIndex < 0 ? "" : ` (access key "${keys[i]})"`}.`
|
||||
}, nameElt);
|
||||
}), diagnostic.source && crelt("div", { class: "cm-diagnosticSource" }, diagnostic.source));
|
||||
}
|
||||
var DiagnosticWidget = class extends WidgetType {
|
||||
constructor(diagnostic) {
|
||||
super();
|
||||
this.diagnostic = diagnostic;
|
||||
}
|
||||
eq(other) {
|
||||
return other.diagnostic == this.diagnostic;
|
||||
}
|
||||
toDOM() {
|
||||
return crelt("span", { class: "cm-lintPoint cm-lintPoint-" + this.diagnostic.severity });
|
||||
}
|
||||
};
|
||||
var PanelItem = class {
|
||||
constructor(view, diagnostic) {
|
||||
this.diagnostic = diagnostic;
|
||||
this.id = "item_" + Math.floor(Math.random() * 4294967295).toString(16);
|
||||
this.dom = renderDiagnostic(view, diagnostic, true);
|
||||
this.dom.id = this.id;
|
||||
this.dom.setAttribute("role", "option");
|
||||
}
|
||||
};
|
||||
var LintPanel = class _LintPanel {
|
||||
constructor(view) {
|
||||
this.view = view;
|
||||
this.items = [];
|
||||
let onkeydown = (event) => {
|
||||
if (event.keyCode == 27) {
|
||||
closeLintPanel(this.view);
|
||||
this.view.focus();
|
||||
} else if (event.keyCode == 38 || event.keyCode == 33) {
|
||||
this.moveSelection((this.selectedIndex - 1 + this.items.length) % this.items.length);
|
||||
} else if (event.keyCode == 40 || event.keyCode == 34) {
|
||||
this.moveSelection((this.selectedIndex + 1) % this.items.length);
|
||||
} else if (event.keyCode == 36) {
|
||||
this.moveSelection(0);
|
||||
} else if (event.keyCode == 35) {
|
||||
this.moveSelection(this.items.length - 1);
|
||||
} else if (event.keyCode == 13) {
|
||||
this.view.focus();
|
||||
} else if (event.keyCode >= 65 && event.keyCode <= 90 && this.selectedIndex >= 0) {
|
||||
let { diagnostic } = this.items[this.selectedIndex], keys = assignKeys(diagnostic.actions);
|
||||
for (let i = 0; i < keys.length; i++)
|
||||
if (keys[i].toUpperCase().charCodeAt(0) == event.keyCode) {
|
||||
let found = findDiagnostic(this.view.state.field(lintState).diagnostics, diagnostic);
|
||||
if (found)
|
||||
diagnostic.actions[i].apply(view, found.from, found.to);
|
||||
}
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
event.preventDefault();
|
||||
};
|
||||
let onclick = (event) => {
|
||||
for (let i = 0; i < this.items.length; i++) {
|
||||
if (this.items[i].dom.contains(event.target))
|
||||
this.moveSelection(i);
|
||||
}
|
||||
};
|
||||
this.list = crelt("ul", {
|
||||
tabIndex: 0,
|
||||
role: "listbox",
|
||||
"aria-label": this.view.state.phrase("Diagnostics"),
|
||||
onkeydown,
|
||||
onclick
|
||||
});
|
||||
this.dom = crelt("div", { class: "cm-panel-lint" }, this.list, crelt("button", {
|
||||
type: "button",
|
||||
name: "close",
|
||||
"aria-label": this.view.state.phrase("close"),
|
||||
onclick: () => closeLintPanel(this.view)
|
||||
}, "×"));
|
||||
this.update();
|
||||
}
|
||||
get selectedIndex() {
|
||||
let selected = this.view.state.field(lintState).selected;
|
||||
if (!selected)
|
||||
return -1;
|
||||
for (let i = 0; i < this.items.length; i++)
|
||||
if (this.items[i].diagnostic == selected.diagnostic)
|
||||
return i;
|
||||
return -1;
|
||||
}
|
||||
update() {
|
||||
let { diagnostics, selected } = this.view.state.field(lintState);
|
||||
let i = 0, needsSync = false, newSelectedItem = null;
|
||||
diagnostics.between(0, this.view.state.doc.length, (_start, _end, { spec }) => {
|
||||
let found = -1, item;
|
||||
for (let j = i; j < this.items.length; j++)
|
||||
if (this.items[j].diagnostic == spec.diagnostic) {
|
||||
found = j;
|
||||
break;
|
||||
}
|
||||
if (found < 0) {
|
||||
item = new PanelItem(this.view, spec.diagnostic);
|
||||
this.items.splice(i, 0, item);
|
||||
needsSync = true;
|
||||
} else {
|
||||
item = this.items[found];
|
||||
if (found > i) {
|
||||
this.items.splice(i, found - i);
|
||||
needsSync = true;
|
||||
}
|
||||
}
|
||||
if (selected && item.diagnostic == selected.diagnostic) {
|
||||
if (!item.dom.hasAttribute("aria-selected")) {
|
||||
item.dom.setAttribute("aria-selected", "true");
|
||||
newSelectedItem = item;
|
||||
}
|
||||
} else if (item.dom.hasAttribute("aria-selected")) {
|
||||
item.dom.removeAttribute("aria-selected");
|
||||
}
|
||||
i++;
|
||||
});
|
||||
while (i < this.items.length && !(this.items.length == 1 && this.items[0].diagnostic.from < 0)) {
|
||||
needsSync = true;
|
||||
this.items.pop();
|
||||
}
|
||||
if (this.items.length == 0) {
|
||||
this.items.push(new PanelItem(this.view, {
|
||||
from: -1,
|
||||
to: -1,
|
||||
severity: "info",
|
||||
message: this.view.state.phrase("No diagnostics")
|
||||
}));
|
||||
needsSync = true;
|
||||
}
|
||||
if (newSelectedItem) {
|
||||
this.list.setAttribute("aria-activedescendant", newSelectedItem.id);
|
||||
this.view.requestMeasure({
|
||||
key: this,
|
||||
read: () => ({ sel: newSelectedItem.dom.getBoundingClientRect(), panel: this.list.getBoundingClientRect() }),
|
||||
write: ({ sel, panel }) => {
|
||||
if (sel.top < panel.top)
|
||||
this.list.scrollTop -= panel.top - sel.top;
|
||||
else if (sel.bottom > panel.bottom)
|
||||
this.list.scrollTop += sel.bottom - panel.bottom;
|
||||
}
|
||||
});
|
||||
} else if (this.selectedIndex < 0) {
|
||||
this.list.removeAttribute("aria-activedescendant");
|
||||
}
|
||||
if (needsSync)
|
||||
this.sync();
|
||||
}
|
||||
sync() {
|
||||
let domPos = this.list.firstChild;
|
||||
function rm() {
|
||||
let prev = domPos;
|
||||
domPos = prev.nextSibling;
|
||||
prev.remove();
|
||||
}
|
||||
for (let item of this.items) {
|
||||
if (item.dom.parentNode == this.list) {
|
||||
while (domPos != item.dom)
|
||||
rm();
|
||||
domPos = item.dom.nextSibling;
|
||||
} else {
|
||||
this.list.insertBefore(item.dom, domPos);
|
||||
}
|
||||
}
|
||||
while (domPos)
|
||||
rm();
|
||||
}
|
||||
moveSelection(selectedIndex) {
|
||||
if (this.selectedIndex < 0)
|
||||
return;
|
||||
let field = this.view.state.field(lintState);
|
||||
let selection = findDiagnostic(field.diagnostics, this.items[selectedIndex].diagnostic);
|
||||
if (!selection)
|
||||
return;
|
||||
this.view.dispatch({
|
||||
selection: { anchor: selection.from, head: selection.to },
|
||||
scrollIntoView: true,
|
||||
effects: movePanelSelection.of(selection)
|
||||
});
|
||||
}
|
||||
static open(view) {
|
||||
return new _LintPanel(view);
|
||||
}
|
||||
};
|
||||
function svg(content, attrs = `viewBox="0 0 40 40"`) {
|
||||
return `url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" ${attrs}>${encodeURIComponent(content)}</svg>')`;
|
||||
}
|
||||
function underline(color) {
|
||||
return svg(`<path d="m0 2.5 l2 -1.5 l1 0 l2 1.5 l1 0" stroke="${color}" fill="none" stroke-width=".7"/>`, `width="6" height="3"`);
|
||||
}
|
||||
var baseTheme = EditorView.baseTheme({
|
||||
".cm-diagnostic": {
|
||||
padding: "3px 6px 3px 8px",
|
||||
marginLeft: "-1px",
|
||||
display: "block",
|
||||
whiteSpace: "pre-wrap"
|
||||
},
|
||||
".cm-diagnostic-error": { borderLeft: "5px solid #d11" },
|
||||
".cm-diagnostic-warning": { borderLeft: "5px solid orange" },
|
||||
".cm-diagnostic-info": { borderLeft: "5px solid #999" },
|
||||
".cm-diagnostic-hint": { borderLeft: "5px solid #66d" },
|
||||
".cm-diagnosticAction": {
|
||||
font: "inherit",
|
||||
border: "none",
|
||||
padding: "2px 4px",
|
||||
backgroundColor: "#444",
|
||||
color: "white",
|
||||
borderRadius: "3px",
|
||||
marginLeft: "8px",
|
||||
cursor: "pointer"
|
||||
},
|
||||
".cm-diagnosticSource": {
|
||||
fontSize: "70%",
|
||||
opacity: 0.7
|
||||
},
|
||||
".cm-lintRange": {
|
||||
backgroundPosition: "left bottom",
|
||||
backgroundRepeat: "repeat-x",
|
||||
paddingBottom: "0.7px"
|
||||
},
|
||||
".cm-lintRange-error": { backgroundImage: underline("#d11") },
|
||||
".cm-lintRange-warning": { backgroundImage: underline("orange") },
|
||||
".cm-lintRange-info": { backgroundImage: underline("#999") },
|
||||
".cm-lintRange-hint": { backgroundImage: underline("#66d") },
|
||||
".cm-lintRange-active": { backgroundColor: "#ffdd9980" },
|
||||
".cm-tooltip-lint": {
|
||||
padding: 0,
|
||||
margin: 0
|
||||
},
|
||||
".cm-lintPoint": {
|
||||
position: "relative",
|
||||
"&:after": {
|
||||
content: '""',
|
||||
position: "absolute",
|
||||
bottom: 0,
|
||||
left: "-2px",
|
||||
borderLeft: "3px solid transparent",
|
||||
borderRight: "3px solid transparent",
|
||||
borderBottom: "4px solid #d11"
|
||||
}
|
||||
},
|
||||
".cm-lintPoint-warning": {
|
||||
"&:after": { borderBottomColor: "orange" }
|
||||
},
|
||||
".cm-lintPoint-info": {
|
||||
"&:after": { borderBottomColor: "#999" }
|
||||
},
|
||||
".cm-lintPoint-hint": {
|
||||
"&:after": { borderBottomColor: "#66d" }
|
||||
},
|
||||
".cm-panel.cm-panel-lint": {
|
||||
position: "relative",
|
||||
"& ul": {
|
||||
maxHeight: "100px",
|
||||
overflowY: "auto",
|
||||
"& [aria-selected]": {
|
||||
backgroundColor: "#ddd",
|
||||
"& u": { textDecoration: "underline" }
|
||||
},
|
||||
"&:focus [aria-selected]": {
|
||||
background_fallback: "#bdf",
|
||||
backgroundColor: "Highlight",
|
||||
color_fallback: "white",
|
||||
color: "HighlightText"
|
||||
},
|
||||
"& u": { textDecoration: "none" },
|
||||
padding: 0,
|
||||
margin: 0
|
||||
},
|
||||
"& [name=close]": {
|
||||
position: "absolute",
|
||||
top: "0",
|
||||
right: "2px",
|
||||
background: "inherit",
|
||||
border: "none",
|
||||
font: "inherit",
|
||||
padding: 0,
|
||||
margin: 0
|
||||
}
|
||||
}
|
||||
});
|
||||
function severityWeight(sev) {
|
||||
return sev == "error" ? 4 : sev == "warning" ? 3 : sev == "info" ? 2 : 1;
|
||||
}
|
||||
var LintGutterMarker = class extends GutterMarker {
|
||||
constructor(diagnostics) {
|
||||
super();
|
||||
this.diagnostics = diagnostics;
|
||||
this.severity = diagnostics.reduce((max, d) => severityWeight(max) < severityWeight(d.severity) ? d.severity : max, "hint");
|
||||
}
|
||||
toDOM(view) {
|
||||
let elt = document.createElement("div");
|
||||
elt.className = "cm-lint-marker cm-lint-marker-" + this.severity;
|
||||
let diagnostics = this.diagnostics;
|
||||
let diagnosticsFilter = view.state.facet(lintGutterConfig).tooltipFilter;
|
||||
if (diagnosticsFilter)
|
||||
diagnostics = diagnosticsFilter(diagnostics);
|
||||
if (diagnostics.length)
|
||||
elt.onmouseover = () => gutterMarkerMouseOver(view, elt, diagnostics);
|
||||
return elt;
|
||||
}
|
||||
};
|
||||
function trackHoverOn(view, marker) {
|
||||
let mousemove = (event) => {
|
||||
let rect = marker.getBoundingClientRect();
|
||||
if (event.clientX > rect.left - 10 && event.clientX < rect.right + 10 && event.clientY > rect.top - 10 && event.clientY < rect.bottom + 10)
|
||||
return;
|
||||
for (let target = event.target; target; target = target.parentNode) {
|
||||
if (target.nodeType == 1 && target.classList.contains("cm-tooltip-lint"))
|
||||
return;
|
||||
}
|
||||
window.removeEventListener("mousemove", mousemove);
|
||||
if (view.state.field(lintGutterTooltip))
|
||||
view.dispatch({ effects: setLintGutterTooltip.of(null) });
|
||||
};
|
||||
window.addEventListener("mousemove", mousemove);
|
||||
}
|
||||
function gutterMarkerMouseOver(view, marker, diagnostics) {
|
||||
function hovered() {
|
||||
let line = view.elementAtHeight(marker.getBoundingClientRect().top + 5 - view.documentTop);
|
||||
const linePos = view.coordsAtPos(line.from);
|
||||
if (linePos) {
|
||||
view.dispatch({ effects: setLintGutterTooltip.of({
|
||||
pos: line.from,
|
||||
above: false,
|
||||
create() {
|
||||
return {
|
||||
dom: diagnosticsTooltip(view, diagnostics),
|
||||
getCoords: () => marker.getBoundingClientRect()
|
||||
};
|
||||
}
|
||||
}) });
|
||||
}
|
||||
marker.onmouseout = marker.onmousemove = null;
|
||||
trackHoverOn(view, marker);
|
||||
}
|
||||
let { hoverTime } = view.state.facet(lintGutterConfig);
|
||||
let hoverTimeout = setTimeout(hovered, hoverTime);
|
||||
marker.onmouseout = () => {
|
||||
clearTimeout(hoverTimeout);
|
||||
marker.onmouseout = marker.onmousemove = null;
|
||||
};
|
||||
marker.onmousemove = () => {
|
||||
clearTimeout(hoverTimeout);
|
||||
hoverTimeout = setTimeout(hovered, hoverTime);
|
||||
};
|
||||
}
|
||||
function markersForDiagnostics(doc, diagnostics) {
|
||||
let byLine = /* @__PURE__ */ Object.create(null);
|
||||
for (let diagnostic of diagnostics) {
|
||||
let line = doc.lineAt(diagnostic.from);
|
||||
(byLine[line.from] || (byLine[line.from] = [])).push(diagnostic);
|
||||
}
|
||||
let markers = [];
|
||||
for (let line in byLine) {
|
||||
markers.push(new LintGutterMarker(byLine[line]).range(+line));
|
||||
}
|
||||
return RangeSet.of(markers, true);
|
||||
}
|
||||
var lintGutterExtension = gutter({
|
||||
class: "cm-gutter-lint",
|
||||
markers: (view) => view.state.field(lintGutterMarkers)
|
||||
});
|
||||
var lintGutterMarkers = StateField.define({
|
||||
create() {
|
||||
return RangeSet.empty;
|
||||
},
|
||||
update(markers, tr) {
|
||||
markers = markers.map(tr.changes);
|
||||
let diagnosticFilter = tr.state.facet(lintGutterConfig).markerFilter;
|
||||
for (let effect of tr.effects) {
|
||||
if (effect.is(setDiagnosticsEffect)) {
|
||||
let diagnostics = effect.value;
|
||||
if (diagnosticFilter)
|
||||
diagnostics = diagnosticFilter(diagnostics || []);
|
||||
markers = markersForDiagnostics(tr.state.doc, diagnostics.slice(0));
|
||||
}
|
||||
}
|
||||
return markers;
|
||||
}
|
||||
});
|
||||
var setLintGutterTooltip = StateEffect.define();
|
||||
var lintGutterTooltip = StateField.define({
|
||||
create() {
|
||||
return null;
|
||||
},
|
||||
update(tooltip, tr) {
|
||||
if (tooltip && tr.docChanged)
|
||||
tooltip = hideTooltip(tr, tooltip) ? null : Object.assign(Object.assign({}, tooltip), { pos: tr.changes.mapPos(tooltip.pos) });
|
||||
return tr.effects.reduce((t, e) => e.is(setLintGutterTooltip) ? e.value : t, tooltip);
|
||||
},
|
||||
provide: (field) => showTooltip.from(field)
|
||||
});
|
||||
var lintGutterTheme = EditorView.baseTheme({
|
||||
".cm-gutter-lint": {
|
||||
width: "1.4em",
|
||||
"& .cm-gutterElement": {
|
||||
padding: ".2em"
|
||||
}
|
||||
},
|
||||
".cm-lint-marker": {
|
||||
width: "1em",
|
||||
height: "1em"
|
||||
},
|
||||
".cm-lint-marker-info": {
|
||||
content: svg(`<path fill="#aaf" stroke="#77e" stroke-width="6" stroke-linejoin="round" d="M5 5L35 5L35 35L5 35Z"/>`)
|
||||
},
|
||||
".cm-lint-marker-warning": {
|
||||
content: svg(`<path fill="#fe8" stroke="#fd7" stroke-width="6" stroke-linejoin="round" d="M20 6L37 35L3 35Z"/>`)
|
||||
},
|
||||
".cm-lint-marker-error": {
|
||||
content: svg(`<circle cx="20" cy="20" r="15" fill="#f87" stroke="#f43" stroke-width="6"/>`)
|
||||
}
|
||||
});
|
||||
var lintExtensions = [
|
||||
lintState,
|
||||
EditorView.decorations.compute([lintState], (state) => {
|
||||
let { selected, panel } = state.field(lintState);
|
||||
return !selected || !panel || selected.from == selected.to ? Decoration.none : Decoration.set([
|
||||
activeMark.range(selected.from, selected.to)
|
||||
]);
|
||||
}),
|
||||
hoverTooltip(lintTooltip, { hideOn: hideTooltip }),
|
||||
baseTheme
|
||||
];
|
||||
var lintGutterConfig = Facet.define({
|
||||
combine(configs) {
|
||||
return combineConfig(configs, {
|
||||
hoverTime: 300,
|
||||
markerFilter: null,
|
||||
tooltipFilter: null
|
||||
});
|
||||
}
|
||||
});
|
||||
function lintGutter(config = {}) {
|
||||
return [lintGutterConfig.of(config), lintGutterMarkers, lintGutterExtension, lintGutterTheme, lintGutterTooltip];
|
||||
}
|
||||
function forEachDiagnostic(state, f) {
|
||||
let lState = state.field(lintState, false);
|
||||
if (lState && lState.diagnostics.size)
|
||||
for (let iter = RangeSet.iter([lState.diagnostics]); iter.value; iter.next())
|
||||
f(iter.value.spec.diagnostic, iter.from, iter.to);
|
||||
}
|
||||
|
||||
export {
|
||||
setDiagnostics,
|
||||
setDiagnosticsEffect,
|
||||
diagnosticCount,
|
||||
openLintPanel,
|
||||
closeLintPanel,
|
||||
nextDiagnostic,
|
||||
previousDiagnostic,
|
||||
lintKeymap,
|
||||
linter,
|
||||
forceLinting,
|
||||
lintGutter,
|
||||
forEachDiagnostic
|
||||
};
|
||||
//# sourceMappingURL=chunk-P2DAGASU.js.map
|
||||
7
node_modules/.vite/deps/chunk-P2DAGASU.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/chunk-P2DAGASU.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
1281
node_modules/.vite/deps/chunk-TRAAS4SM.js
generated
vendored
Normal file
1281
node_modules/.vite/deps/chunk-TRAAS4SM.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7
node_modules/.vite/deps/chunk-TRAAS4SM.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/chunk-TRAAS4SM.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
1876
node_modules/.vite/deps/chunk-UFI6XSZR.js
generated
vendored
Normal file
1876
node_modules/.vite/deps/chunk-UFI6XSZR.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7
node_modules/.vite/deps/chunk-UFI6XSZR.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/chunk-UFI6XSZR.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
89
node_modules/.vite/deps/codemirror.js
generated
vendored
Normal file
89
node_modules/.vite/deps/codemirror.js
generated
vendored
Normal file
@ -0,0 +1,89 @@
|
||||
import {
|
||||
defaultKeymap,
|
||||
history,
|
||||
historyKeymap
|
||||
} from "./chunk-TRAAS4SM.js";
|
||||
import {
|
||||
autocompletion,
|
||||
closeBrackets,
|
||||
closeBracketsKeymap,
|
||||
completionKeymap
|
||||
} from "./chunk-UFI6XSZR.js";
|
||||
import {
|
||||
bracketMatching,
|
||||
defaultHighlightStyle,
|
||||
foldGutter,
|
||||
foldKeymap,
|
||||
indentOnInput,
|
||||
syntaxHighlighting
|
||||
} from "./chunk-D63OSQ34.js";
|
||||
import {
|
||||
lintKeymap
|
||||
} from "./chunk-P2DAGASU.js";
|
||||
import {
|
||||
highlightSelectionMatches,
|
||||
searchKeymap
|
||||
} from "./chunk-JOEDLCIZ.js";
|
||||
import "./chunk-B45MRPPJ.js";
|
||||
import {
|
||||
EditorView,
|
||||
crosshairCursor,
|
||||
drawSelection,
|
||||
dropCursor,
|
||||
highlightActiveLine,
|
||||
highlightActiveLineGutter,
|
||||
highlightSpecialChars,
|
||||
keymap,
|
||||
lineNumbers,
|
||||
rectangularSelection
|
||||
} from "./chunk-LORPBXGU.js";
|
||||
import {
|
||||
EditorState
|
||||
} from "./chunk-MKFMOIK6.js";
|
||||
import "./chunk-BSVZPYOD.js";
|
||||
|
||||
// node_modules/codemirror/dist/index.js
|
||||
var basicSetup = (() => [
|
||||
lineNumbers(),
|
||||
highlightActiveLineGutter(),
|
||||
highlightSpecialChars(),
|
||||
history(),
|
||||
foldGutter(),
|
||||
drawSelection(),
|
||||
dropCursor(),
|
||||
EditorState.allowMultipleSelections.of(true),
|
||||
indentOnInput(),
|
||||
syntaxHighlighting(defaultHighlightStyle, { fallback: true }),
|
||||
bracketMatching(),
|
||||
closeBrackets(),
|
||||
autocompletion(),
|
||||
rectangularSelection(),
|
||||
crosshairCursor(),
|
||||
highlightActiveLine(),
|
||||
highlightSelectionMatches(),
|
||||
keymap.of([
|
||||
...closeBracketsKeymap,
|
||||
...defaultKeymap,
|
||||
...searchKeymap,
|
||||
...historyKeymap,
|
||||
...foldKeymap,
|
||||
...completionKeymap,
|
||||
...lintKeymap
|
||||
])
|
||||
])();
|
||||
var minimalSetup = (() => [
|
||||
highlightSpecialChars(),
|
||||
history(),
|
||||
drawSelection(),
|
||||
syntaxHighlighting(defaultHighlightStyle, { fallback: true }),
|
||||
keymap.of([
|
||||
...defaultKeymap,
|
||||
...historyKeymap
|
||||
])
|
||||
])();
|
||||
export {
|
||||
EditorView,
|
||||
basicSetup,
|
||||
minimalSetup
|
||||
};
|
||||
//# sourceMappingURL=codemirror.js.map
|
||||
7
node_modules/.vite/deps/codemirror.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/codemirror.js.map
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"version": 3,
|
||||
"sources": ["../../codemirror/dist/index.js"],
|
||||
"sourcesContent": ["import { lineNumbers, highlightActiveLineGutter, highlightSpecialChars, drawSelection, dropCursor, rectangularSelection, crosshairCursor, highlightActiveLine, keymap } from '@codemirror/view';\nexport { EditorView } from '@codemirror/view';\nimport { EditorState } from '@codemirror/state';\nimport { foldGutter, indentOnInput, syntaxHighlighting, defaultHighlightStyle, bracketMatching, foldKeymap } from '@codemirror/language';\nimport { history, defaultKeymap, historyKeymap } from '@codemirror/commands';\nimport { highlightSelectionMatches, searchKeymap } from '@codemirror/search';\nimport { closeBrackets, autocompletion, closeBracketsKeymap, completionKeymap } from '@codemirror/autocomplete';\nimport { lintKeymap } from '@codemirror/lint';\n\n// (The superfluous function calls around the list of extensions work\n// around current limitations in tree-shaking software.)\n/**\nThis is an extension value that just pulls together a number of\nextensions that you might want in a basic editor. It is meant as a\nconvenient helper to quickly set up CodeMirror without installing\nand importing a lot of separate packages.\n\nSpecifically, it includes...\n\n - [the default command bindings](https://codemirror.net/6/docs/ref/#commands.defaultKeymap)\n - [line numbers](https://codemirror.net/6/docs/ref/#view.lineNumbers)\n - [special character highlighting](https://codemirror.net/6/docs/ref/#view.highlightSpecialChars)\n - [the undo history](https://codemirror.net/6/docs/ref/#commands.history)\n - [a fold gutter](https://codemirror.net/6/docs/ref/#language.foldGutter)\n - [custom selection drawing](https://codemirror.net/6/docs/ref/#view.drawSelection)\n - [drop cursor](https://codemirror.net/6/docs/ref/#view.dropCursor)\n - [multiple selections](https://codemirror.net/6/docs/ref/#state.EditorState^allowMultipleSelections)\n - [reindentation on input](https://codemirror.net/6/docs/ref/#language.indentOnInput)\n - [the default highlight style](https://codemirror.net/6/docs/ref/#language.defaultHighlightStyle) (as fallback)\n - [bracket matching](https://codemirror.net/6/docs/ref/#language.bracketMatching)\n - [bracket closing](https://codemirror.net/6/docs/ref/#autocomplete.closeBrackets)\n - [autocompletion](https://codemirror.net/6/docs/ref/#autocomplete.autocompletion)\n - [rectangular selection](https://codemirror.net/6/docs/ref/#view.rectangularSelection) and [crosshair cursor](https://codemirror.net/6/docs/ref/#view.crosshairCursor)\n - [active line highlighting](https://codemirror.net/6/docs/ref/#view.highlightActiveLine)\n - [active line gutter highlighting](https://codemirror.net/6/docs/ref/#view.highlightActiveLineGutter)\n - [selection match highlighting](https://codemirror.net/6/docs/ref/#search.highlightSelectionMatches)\n - [search](https://codemirror.net/6/docs/ref/#search.searchKeymap)\n - [linting](https://codemirror.net/6/docs/ref/#lint.lintKeymap)\n\n(You'll probably want to add some language package to your setup\ntoo.)\n\nThis extension does not allow customization. The idea is that,\nonce you decide you want to configure your editor more precisely,\nyou take this package's source (which is just a bunch of imports\nand an array literal), copy it into your own code, and adjust it\nas desired.\n*/\nconst basicSetup = /*@__PURE__*/(() => [\n lineNumbers(),\n highlightActiveLineGutter(),\n highlightSpecialChars(),\n history(),\n foldGutter(),\n drawSelection(),\n dropCursor(),\n EditorState.allowMultipleSelections.of(true),\n indentOnInput(),\n syntaxHighlighting(defaultHighlightStyle, { fallback: true }),\n bracketMatching(),\n closeBrackets(),\n autocompletion(),\n rectangularSelection(),\n crosshairCursor(),\n highlightActiveLine(),\n highlightSelectionMatches(),\n keymap.of([\n ...closeBracketsKeymap,\n ...defaultKeymap,\n ...searchKeymap,\n ...historyKeymap,\n ...foldKeymap,\n ...completionKeymap,\n ...lintKeymap\n ])\n])();\n/**\nA minimal set of extensions to create a functional editor. Only\nincludes [the default keymap](https://codemirror.net/6/docs/ref/#commands.defaultKeymap), [undo\nhistory](https://codemirror.net/6/docs/ref/#commands.history), [special character\nhighlighting](https://codemirror.net/6/docs/ref/#view.highlightSpecialChars), [custom selection\ndrawing](https://codemirror.net/6/docs/ref/#view.drawSelection), and [default highlight\nstyle](https://codemirror.net/6/docs/ref/#language.defaultHighlightStyle).\n*/\nconst minimalSetup = /*@__PURE__*/(() => [\n highlightSpecialChars(),\n history(),\n drawSelection(),\n syntaxHighlighting(defaultHighlightStyle, { fallback: true }),\n keymap.of([\n ...defaultKeymap,\n ...historyKeymap,\n ])\n])();\n\nexport { basicSetup, minimalSetup };\n"],
|
||||
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgDA,IAAM,cAA2B,MAAM;AAAA,EACnC,YAAY;AAAA,EACZ,0BAA0B;AAAA,EAC1B,sBAAsB;AAAA,EACtB,QAAQ;AAAA,EACR,WAAW;AAAA,EACX,cAAc;AAAA,EACd,WAAW;AAAA,EACX,YAAY,wBAAwB,GAAG,IAAI;AAAA,EAC3C,cAAc;AAAA,EACd,mBAAmB,uBAAuB,EAAE,UAAU,KAAK,CAAC;AAAA,EAC5D,gBAAgB;AAAA,EAChB,cAAc;AAAA,EACd,eAAe;AAAA,EACf,qBAAqB;AAAA,EACrB,gBAAgB;AAAA,EAChB,oBAAoB;AAAA,EACpB,0BAA0B;AAAA,EAC1B,OAAO,GAAG;AAAA,IACN,GAAG;AAAA,IACH,GAAG;AAAA,IACH,GAAG;AAAA,IACH,GAAG;AAAA,IACH,GAAG;AAAA,IACH,GAAG;AAAA,IACH,GAAG;AAAA,EACP,CAAC;AACL,GAAG;AASH,IAAM,gBAA6B,MAAM;AAAA,EACrC,sBAAsB;AAAA,EACtB,QAAQ;AAAA,EACR,cAAc;AAAA,EACd,mBAAmB,uBAAuB,EAAE,UAAU,KAAK,CAAC;AAAA,EAC5D,OAAO,GAAG;AAAA,IACN,GAAG;AAAA,IACH,GAAG;AAAA,EACP,CAAC;AACL,GAAG;",
|
||||
"names": []
|
||||
}
|
||||
3
node_modules/.vite/deps/package.json
generated
vendored
Normal file
3
node_modules/.vite/deps/package.json
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
{
|
||||
"type": "module"
|
||||
}
|
||||
112
node_modules/.vite/deps/zzfx.js
generated
vendored
Normal file
112
node_modules/.vite/deps/zzfx.js
generated
vendored
Normal file
@ -0,0 +1,112 @@
|
||||
// node_modules/zzfx/ZzFX.js
|
||||
function zzfx(...parameters) {
|
||||
return ZZFX.play(...parameters);
|
||||
}
|
||||
var ZZFX = {
|
||||
// master volume scale
|
||||
volume: 0.3,
|
||||
// sample rate for audio
|
||||
sampleRate: 44100,
|
||||
// create shared audio context
|
||||
x: new AudioContext(),
|
||||
// play a sound from zzfx paramerters
|
||||
play: function(...parameters) {
|
||||
return this.playSamples(this.buildSamples(...parameters));
|
||||
},
|
||||
// play an array of samples
|
||||
playSamples: function(...samples) {
|
||||
const buffer = this.x.createBuffer(samples.length, samples[0].length, this.sampleRate), source = this.x.createBufferSource();
|
||||
samples.map((d, i) => buffer.getChannelData(i).set(d));
|
||||
source.buffer = buffer;
|
||||
source.connect(this.x.destination);
|
||||
source.start();
|
||||
return source;
|
||||
},
|
||||
// build an array of samples
|
||||
buildSamples: function(volume = 1, randomness = 0.05, frequency = 220, attack = 0, sustain = 0, release = 0.1, shape = 0, shapeCurve = 1, slide = 0, deltaSlide = 0, pitchJump = 0, pitchJumpTime = 0, repeatTime = 0, noise = 0, modulation = 0, bitCrush = 0, delay = 0, sustainVolume = 1, decay = 0, tremolo = 0) {
|
||||
let PI2 = Math.PI * 2, sampleRate = this.sampleRate, sign = (v) => v > 0 ? 1 : -1, startSlide = slide *= 500 * PI2 / sampleRate / sampleRate, startFrequency = frequency *= (1 + randomness * 2 * Math.random() - randomness) * PI2 / sampleRate, b = [], t = 0, tm = 0, i = 0, j = 1, r = 0, c = 0, s = 0, f, length;
|
||||
attack = attack * sampleRate + 9;
|
||||
decay *= sampleRate;
|
||||
sustain *= sampleRate;
|
||||
release *= sampleRate;
|
||||
delay *= sampleRate;
|
||||
deltaSlide *= 500 * PI2 / sampleRate ** 3;
|
||||
modulation *= PI2 / sampleRate;
|
||||
pitchJump *= PI2 / sampleRate;
|
||||
pitchJumpTime *= sampleRate;
|
||||
repeatTime = repeatTime * sampleRate | 0;
|
||||
for (length = attack + decay + sustain + release + delay | 0; i < length; b[i++] = s) {
|
||||
if (!(++c % (bitCrush * 100 | 0))) {
|
||||
s = shape ? shape > 1 ? shape > 2 ? shape > 3 ? (
|
||||
// wave shape
|
||||
Math.sin((t % PI2) ** 3)
|
||||
) : (
|
||||
// 4 noise
|
||||
Math.max(Math.min(Math.tan(t), 1), -1)
|
||||
) : (
|
||||
// 3 tan
|
||||
1 - (2 * t / PI2 % 2 + 2) % 2
|
||||
) : (
|
||||
// 2 saw
|
||||
1 - 4 * Math.abs(Math.round(t / PI2) - t / PI2)
|
||||
) : (
|
||||
// 1 triangle
|
||||
Math.sin(t)
|
||||
);
|
||||
s = (repeatTime ? 1 - tremolo + tremolo * Math.sin(PI2 * i / repeatTime) : 1) * sign(s) * Math.abs(s) ** shapeCurve * // curve 0=square, 2=pointy
|
||||
volume * this.volume * // envelope
|
||||
(i < attack ? i / attack : (
|
||||
// attack
|
||||
i < attack + decay ? (
|
||||
// decay
|
||||
1 - (i - attack) / decay * (1 - sustainVolume)
|
||||
) : (
|
||||
// decay falloff
|
||||
i < attack + decay + sustain ? (
|
||||
// sustain
|
||||
sustainVolume
|
||||
) : (
|
||||
// sustain volume
|
||||
i < length - delay ? (
|
||||
// release
|
||||
(length - i - delay) / release * // release falloff
|
||||
sustainVolume
|
||||
) : (
|
||||
// release volume
|
||||
0
|
||||
)
|
||||
)
|
||||
)
|
||||
));
|
||||
s = delay ? s / 2 + (delay > i ? 0 : (
|
||||
// delay
|
||||
(i < length - delay ? 1 : (length - i) / delay) * // release delay
|
||||
b[i - delay | 0] / 2
|
||||
)) : s;
|
||||
}
|
||||
f = (frequency += slide += deltaSlide) * // frequency
|
||||
Math.cos(modulation * tm++);
|
||||
t += f - f * noise * (1 - (Math.sin(i) + 1) * 1e9 % 2);
|
||||
if (j && ++j > pitchJumpTime) {
|
||||
frequency += pitchJump;
|
||||
startFrequency += pitchJump;
|
||||
j = 0;
|
||||
}
|
||||
if (repeatTime && !(++r % repeatTime)) {
|
||||
frequency = startFrequency;
|
||||
slide = startSlide;
|
||||
j || (j = 1);
|
||||
}
|
||||
}
|
||||
return b;
|
||||
},
|
||||
// get frequency of a musical note on a diatonic scale
|
||||
getNote: function(semitoneOffset = 0, rootNoteFrequency = 440) {
|
||||
return rootNoteFrequency * 2 ** (semitoneOffset / 12);
|
||||
}
|
||||
};
|
||||
export {
|
||||
ZZFX,
|
||||
zzfx
|
||||
};
|
||||
//# sourceMappingURL=zzfx.js.map
|
||||
7
node_modules/.vite/deps/zzfx.js.map
generated
vendored
Normal file
7
node_modules/.vite/deps/zzfx.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
180
node_modules/.yarn-integrity
generated
vendored
Normal file
180
node_modules/.yarn-integrity
generated
vendored
Normal file
@ -0,0 +1,180 @@
|
||||
{
|
||||
"systemParams": "darwin-x64-115",
|
||||
"modulesFolders": [
|
||||
"node_modules"
|
||||
],
|
||||
"flags": [],
|
||||
"linkedModules": [],
|
||||
"topLevelPatterns": [
|
||||
"@codemirror/lang-javascript@^6.1.9",
|
||||
"@replit/codemirror-vim@^6.0.14",
|
||||
"autoprefixer@^10.4.14",
|
||||
"codemirror@^6.0.1",
|
||||
"postcss@^8.4.27",
|
||||
"tailwindcss@^3.3.3",
|
||||
"typescript@^5.0.2",
|
||||
"vite@^4.4.5",
|
||||
"zzfx@^1.2.0"
|
||||
],
|
||||
"lockfileEntries": {
|
||||
"@alloc/quick-lru@^5.2.0": "https://registry.yarnpkg.com/@alloc/quick-lru/-/quick-lru-5.2.0.tgz#7bf68b20c0a350f936915fcae06f58e32007ce30",
|
||||
"@codemirror/autocomplete@^6.0.0": "https://registry.yarnpkg.com/@codemirror/autocomplete/-/autocomplete-6.9.0.tgz#1a1e63122288b8f8e1e9d7aff2eb39a83e04d8a9",
|
||||
"@codemirror/commands@^6.0.0": "https://registry.yarnpkg.com/@codemirror/commands/-/commands-6.2.4.tgz#b8a0e5ce72448c092ba4c4b1d902e6f183948aec",
|
||||
"@codemirror/lang-javascript@^6.1.9": "https://registry.yarnpkg.com/@codemirror/lang-javascript/-/lang-javascript-6.1.9.tgz#19065ad32db7b3797829eca01b8d9c69da5fd0d6",
|
||||
"@codemirror/language@^6.0.0": "https://registry.yarnpkg.com/@codemirror/language/-/language-6.8.0.tgz#f2d7eea6b338c25593d800f2293b062d9f9856db",
|
||||
"@codemirror/language@^6.6.0": "https://registry.yarnpkg.com/@codemirror/language/-/language-6.8.0.tgz#f2d7eea6b338c25593d800f2293b062d9f9856db",
|
||||
"@codemirror/lint@^6.0.0": "https://registry.yarnpkg.com/@codemirror/lint/-/lint-6.4.0.tgz#3507e937aa9415ef0831ff04734ef0e736e75014",
|
||||
"@codemirror/search@^6.0.0": "https://registry.yarnpkg.com/@codemirror/search/-/search-6.5.0.tgz#308f9968434e0e6ed59c9ec36a0239eb1dfc5d92",
|
||||
"@codemirror/state@^6.0.0": "https://registry.yarnpkg.com/@codemirror/state/-/state-6.2.1.tgz#6dc8d8e5abb26b875e3164191872d69a5e85bd73",
|
||||
"@codemirror/state@^6.1.4": "https://registry.yarnpkg.com/@codemirror/state/-/state-6.2.1.tgz#6dc8d8e5abb26b875e3164191872d69a5e85bd73",
|
||||
"@codemirror/state@^6.2.0": "https://registry.yarnpkg.com/@codemirror/state/-/state-6.2.1.tgz#6dc8d8e5abb26b875e3164191872d69a5e85bd73",
|
||||
"@codemirror/view@^6.0.0": "https://registry.yarnpkg.com/@codemirror/view/-/view-6.15.3.tgz#b26dac3e1812821daa6da25f59ffb26c9b9b75f3",
|
||||
"@codemirror/view@^6.6.0": "https://registry.yarnpkg.com/@codemirror/view/-/view-6.15.3.tgz#b26dac3e1812821daa6da25f59ffb26c9b9b75f3",
|
||||
"@esbuild/android-arm64@0.18.16": "https://registry.yarnpkg.com/@esbuild/android-arm64/-/android-arm64-0.18.16.tgz#34f562abc0015933aabd41b3d50d8d3359e30155",
|
||||
"@esbuild/android-arm@0.18.16": "https://registry.yarnpkg.com/@esbuild/android-arm/-/android-arm-0.18.16.tgz#ef6f9aa59a79a9b9330a2e73f7eb402c6630c267",
|
||||
"@esbuild/android-x64@0.18.16": "https://registry.yarnpkg.com/@esbuild/android-x64/-/android-x64-0.18.16.tgz#ed7444cb17542932c67b15e20528686853239cfd",
|
||||
"@esbuild/darwin-arm64@0.18.16": "https://registry.yarnpkg.com/@esbuild/darwin-arm64/-/darwin-arm64-0.18.16.tgz#3c5a083e6e08a50f478fa243939989d86be1c6bf",
|
||||
"@esbuild/darwin-x64@0.18.16": "https://registry.yarnpkg.com/@esbuild/darwin-x64/-/darwin-x64-0.18.16.tgz#a8f3b61bee2807131cbe28eb164ad2b0333b59f5",
|
||||
"@esbuild/freebsd-arm64@0.18.16": "https://registry.yarnpkg.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.18.16.tgz#9bdbb3f0e5f0842b21c9b8602e70c106174ac24c",
|
||||
"@esbuild/freebsd-x64@0.18.16": "https://registry.yarnpkg.com/@esbuild/freebsd-x64/-/freebsd-x64-0.18.16.tgz#24f73956436495cc7a5a4bf06be6b661aea6a2c1",
|
||||
"@esbuild/linux-arm64@0.18.16": "https://registry.yarnpkg.com/@esbuild/linux-arm64/-/linux-arm64-0.18.16.tgz#244569757f9cbd912f5a595a8ad8144f8c915f13",
|
||||
"@esbuild/linux-arm@0.18.16": "https://registry.yarnpkg.com/@esbuild/linux-arm/-/linux-arm-0.18.16.tgz#d63923c63af534032cc5ea0b2a0b3de10f8357f5",
|
||||
"@esbuild/linux-ia32@0.18.16": "https://registry.yarnpkg.com/@esbuild/linux-ia32/-/linux-ia32-0.18.16.tgz#a8825ccea6309f0bccfc5d87b43163ba804c2f20",
|
||||
"@esbuild/linux-loong64@0.18.16": "https://registry.yarnpkg.com/@esbuild/linux-loong64/-/linux-loong64-0.18.16.tgz#f530e820fc3c61cf2206155b994aeab53b6d25be",
|
||||
"@esbuild/linux-mips64el@0.18.16": "https://registry.yarnpkg.com/@esbuild/linux-mips64el/-/linux-mips64el-0.18.16.tgz#2d47ace539257896865d243641bd6716684a1e82",
|
||||
"@esbuild/linux-ppc64@0.18.16": "https://registry.yarnpkg.com/@esbuild/linux-ppc64/-/linux-ppc64-0.18.16.tgz#d6913e7e9be9e242a6a20402800141bdbe7009f7",
|
||||
"@esbuild/linux-riscv64@0.18.16": "https://registry.yarnpkg.com/@esbuild/linux-riscv64/-/linux-riscv64-0.18.16.tgz#8f33b627389c8234fe61f4636c134f17fb1d9b09",
|
||||
"@esbuild/linux-s390x@0.18.16": "https://registry.yarnpkg.com/@esbuild/linux-s390x/-/linux-s390x-0.18.16.tgz#4d44c030f78962cf410f604f92fcc1505e4afdde",
|
||||
"@esbuild/linux-x64@0.18.16": "https://registry.yarnpkg.com/@esbuild/linux-x64/-/linux-x64-0.18.16.tgz#8846d00e16b1e93eb488c8b4dd51c946adfc236f",
|
||||
"@esbuild/netbsd-x64@0.18.16": "https://registry.yarnpkg.com/@esbuild/netbsd-x64/-/netbsd-x64-0.18.16.tgz#6514a86bd07744f3100d2813ea2fb6520d53e72e",
|
||||
"@esbuild/openbsd-x64@0.18.16": "https://registry.yarnpkg.com/@esbuild/openbsd-x64/-/openbsd-x64-0.18.16.tgz#ae67ce766d58aab6c0e6037f1a76f15df4a2a5fe",
|
||||
"@esbuild/sunos-x64@0.18.16": "https://registry.yarnpkg.com/@esbuild/sunos-x64/-/sunos-x64-0.18.16.tgz#998efe8a58374b7351ac710455051639a6ce6a05",
|
||||
"@esbuild/win32-arm64@0.18.16": "https://registry.yarnpkg.com/@esbuild/win32-arm64/-/win32-arm64-0.18.16.tgz#8de33682243508eef8d4de1816df2c05adad2b21",
|
||||
"@esbuild/win32-ia32@0.18.16": "https://registry.yarnpkg.com/@esbuild/win32-ia32/-/win32-ia32-0.18.16.tgz#95c9f4274fb3ef9e449d464ffe3e3b7fa091503b",
|
||||
"@esbuild/win32-x64@0.18.16": "https://registry.yarnpkg.com/@esbuild/win32-x64/-/win32-x64-0.18.16.tgz#5be58d31d0120c68af8e38b702e6937ce764cd68",
|
||||
"@jridgewell/gen-mapping@^0.3.2": "https://registry.yarnpkg.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz#7e02e6eb5df901aaedb08514203b096614024098",
|
||||
"@jridgewell/resolve-uri@3.1.0": "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz#2203b118c157721addfe69d47b70465463066d78",
|
||||
"@jridgewell/set-array@^1.0.1": "https://registry.yarnpkg.com/@jridgewell/set-array/-/set-array-1.1.2.tgz#7c6cf998d6d20b914c0a55a91ae928ff25965e72",
|
||||
"@jridgewell/sourcemap-codec@1.4.14": "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz#add4c98d341472a289190b424efbdb096991bb24",
|
||||
"@jridgewell/sourcemap-codec@^1.4.10": "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz#d7c6e6755c78567a951e04ab52ef0fd26de59f32",
|
||||
"@jridgewell/trace-mapping@^0.3.9": "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz#25783b2086daf6ff1dcb53c9249ae480e4dd4cd6",
|
||||
"@lezer/common@^1.0.0": "https://registry.yarnpkg.com/@lezer/common/-/common-1.0.3.tgz#1808f70e2b0a7b1fdcbaf5c074723d2d4ed1e4c5",
|
||||
"@lezer/highlight@^1.0.0": "https://registry.yarnpkg.com/@lezer/highlight/-/highlight-1.1.6.tgz#87e56468c0f43c2a8b3dc7f0b7c2804b34901556",
|
||||
"@lezer/highlight@^1.1.3": "https://registry.yarnpkg.com/@lezer/highlight/-/highlight-1.1.6.tgz#87e56468c0f43c2a8b3dc7f0b7c2804b34901556",
|
||||
"@lezer/javascript@^1.0.0": "https://registry.yarnpkg.com/@lezer/javascript/-/javascript-1.4.4.tgz#f876c1ad2ecc2a52d9e33b5f5c0bd9935ea2d8c0",
|
||||
"@lezer/lr@^1.0.0": "https://registry.yarnpkg.com/@lezer/lr/-/lr-1.3.9.tgz#cb299816d1c58efcca23ebbeb70bb4204fdd001b",
|
||||
"@lezer/lr@^1.3.0": "https://registry.yarnpkg.com/@lezer/lr/-/lr-1.3.9.tgz#cb299816d1c58efcca23ebbeb70bb4204fdd001b",
|
||||
"@nodelib/fs.scandir@2.1.5": "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5",
|
||||
"@nodelib/fs.stat@2.0.5": "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b",
|
||||
"@nodelib/fs.stat@^2.0.2": "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b",
|
||||
"@nodelib/fs.walk@^1.2.3": "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a",
|
||||
"@replit/codemirror-vim@^6.0.14": "https://registry.yarnpkg.com/@replit/codemirror-vim/-/codemirror-vim-6.0.14.tgz#8f44740b0497406b551726946c9b30f21c867671",
|
||||
"any-promise@^1.0.0": "https://registry.yarnpkg.com/any-promise/-/any-promise-1.3.0.tgz#abc6afeedcea52e809cdc0376aed3ce39635d17f",
|
||||
"anymatch@~3.1.2": "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.3.tgz#790c58b19ba1720a84205b57c618d5ad8524973e",
|
||||
"arg@^5.0.2": "https://registry.yarnpkg.com/arg/-/arg-5.0.2.tgz#c81433cc427c92c4dcf4865142dbca6f15acd59c",
|
||||
"autoprefixer@^10.4.14": "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-10.4.14.tgz#e28d49902f8e759dd25b153264e862df2705f79d",
|
||||
"balanced-match@^1.0.0": "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee",
|
||||
"binary-extensions@^2.0.0": "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d",
|
||||
"brace-expansion@^1.1.7": "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd",
|
||||
"braces@^3.0.2": "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107",
|
||||
"braces@~3.0.2": "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107",
|
||||
"browserslist@^4.21.5": "https://registry.yarnpkg.com/browserslist/-/browserslist-4.21.9.tgz#e11bdd3c313d7e2a9e87e8b4b0c7872b13897635",
|
||||
"camelcase-css@^2.0.1": "https://registry.yarnpkg.com/camelcase-css/-/camelcase-css-2.0.1.tgz#ee978f6947914cc30c6b44741b6ed1df7f043fd5",
|
||||
"caniuse-lite@^1.0.30001464": "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001517.tgz#90fabae294215c3495807eb24fc809e11dc2f0a8",
|
||||
"caniuse-lite@^1.0.30001503": "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001517.tgz#90fabae294215c3495807eb24fc809e11dc2f0a8",
|
||||
"chokidar@^3.5.3": "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.3.tgz#1cf37c8707b932bd1af1ae22c0432e2acd1903bd",
|
||||
"codemirror@^6.0.1": "https://registry.yarnpkg.com/codemirror/-/codemirror-6.0.1.tgz#62b91142d45904547ee3e0e0e4c1a79158035a29",
|
||||
"commander@^4.0.0": "https://registry.yarnpkg.com/commander/-/commander-4.1.1.tgz#9fd602bd936294e9e9ef46a3f4d6964044b18068",
|
||||
"concat-map@0.0.1": "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b",
|
||||
"crelt@^1.0.5": "https://registry.yarnpkg.com/crelt/-/crelt-1.0.6.tgz#7cc898ea74e190fb6ef9dae57f8f81cf7302df72",
|
||||
"cssesc@^3.0.0": "https://registry.yarnpkg.com/cssesc/-/cssesc-3.0.0.tgz#37741919903b868565e1c09ea747445cd18983ee",
|
||||
"didyoumean@^1.2.2": "https://registry.yarnpkg.com/didyoumean/-/didyoumean-1.2.2.tgz#989346ffe9e839b4555ecf5666edea0d3e8ad037",
|
||||
"dlv@^1.1.3": "https://registry.yarnpkg.com/dlv/-/dlv-1.1.3.tgz#5c198a8a11453596e751494d49874bc7732f2e79",
|
||||
"electron-to-chromium@^1.4.431": "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.468.tgz#3cbf64ad67d9f12bfe69fefe5eb1935ec4f6ab7a",
|
||||
"esbuild@^0.18.10": "https://registry.yarnpkg.com/esbuild/-/esbuild-0.18.16.tgz#bbeb058c556152bcbff4e8168e7c93020ccf09c3",
|
||||
"escalade@^3.1.1": "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40",
|
||||
"fast-glob@^3.2.12": "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.3.1.tgz#784b4e897340f3dbbef17413b3f11acf03c874c4",
|
||||
"fastq@^1.6.0": "https://registry.yarnpkg.com/fastq/-/fastq-1.15.0.tgz#d04d07c6a2a68fe4599fea8d2e103a937fae6b3a",
|
||||
"fill-range@^7.0.1": "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40",
|
||||
"fraction.js@^4.2.0": "https://registry.yarnpkg.com/fraction.js/-/fraction.js-4.2.0.tgz#448e5109a313a3527f5a3ab2119ec4cf0e0e2950",
|
||||
"fs.realpath@^1.0.0": "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f",
|
||||
"fsevents@~2.3.2": "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a",
|
||||
"function-bind@^1.1.1": "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d",
|
||||
"glob-parent@^5.1.2": "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4",
|
||||
"glob-parent@^6.0.2": "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3",
|
||||
"glob-parent@~5.1.2": "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4",
|
||||
"glob@7.1.6": "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6",
|
||||
"has@^1.0.3": "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796",
|
||||
"inflight@^1.0.4": "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9",
|
||||
"inherits@2": "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c",
|
||||
"is-binary-path@~2.1.0": "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09",
|
||||
"is-core-module@^2.11.0": "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.12.1.tgz#0c0b6885b6f80011c71541ce15c8d66cf5a4f9fd",
|
||||
"is-extglob@^2.1.1": "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2",
|
||||
"is-glob@^4.0.1": "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084",
|
||||
"is-glob@^4.0.3": "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084",
|
||||
"is-glob@~4.0.1": "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084",
|
||||
"is-number@^7.0.0": "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b",
|
||||
"jiti@^1.18.2": "https://registry.yarnpkg.com/jiti/-/jiti-1.19.1.tgz#fa99e4b76a23053e0e7cde098efe1704a14c16f1",
|
||||
"lilconfig@^2.0.5": "https://registry.yarnpkg.com/lilconfig/-/lilconfig-2.1.0.tgz#78e23ac89ebb7e1bfbf25b18043de756548e7f52",
|
||||
"lilconfig@^2.1.0": "https://registry.yarnpkg.com/lilconfig/-/lilconfig-2.1.0.tgz#78e23ac89ebb7e1bfbf25b18043de756548e7f52",
|
||||
"lines-and-columns@^1.1.6": "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz#eca284f75d2965079309dc0ad9255abb2ebc1632",
|
||||
"merge2@^1.3.0": "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae",
|
||||
"micromatch@^4.0.4": "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6",
|
||||
"micromatch@^4.0.5": "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6",
|
||||
"minimatch@^3.0.4": "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b",
|
||||
"mz@^2.7.0": "https://registry.yarnpkg.com/mz/-/mz-2.7.0.tgz#95008057a56cafadc2bc63dde7f9ff6955948e32",
|
||||
"nanoid@^3.3.6": "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.6.tgz#443380c856d6e9f9824267d960b4236ad583ea4c",
|
||||
"node-releases@^2.0.12": "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.13.tgz#d5ed1627c23e3461e819b02e57b75e4899b1c81d",
|
||||
"normalize-path@^3.0.0": "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65",
|
||||
"normalize-path@~3.0.0": "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65",
|
||||
"normalize-range@^0.1.2": "https://registry.yarnpkg.com/normalize-range/-/normalize-range-0.1.2.tgz#2d10c06bdfd312ea9777695a4d28439456b75942",
|
||||
"object-assign@^4.0.1": "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863",
|
||||
"object-hash@^3.0.0": "https://registry.yarnpkg.com/object-hash/-/object-hash-3.0.0.tgz#73f97f753e7baffc0e2cc9d6e079079744ac82e9",
|
||||
"once@^1.3.0": "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1",
|
||||
"path-is-absolute@^1.0.0": "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f",
|
||||
"path-parse@^1.0.7": "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735",
|
||||
"picocolors@^1.0.0": "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c",
|
||||
"picomatch@^2.0.4": "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42",
|
||||
"picomatch@^2.2.1": "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42",
|
||||
"picomatch@^2.3.1": "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42",
|
||||
"pify@^2.3.0": "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c",
|
||||
"pirates@^4.0.1": "https://registry.yarnpkg.com/pirates/-/pirates-4.0.6.tgz#3018ae32ecfcff6c29ba2267cbf21166ac1f36b9",
|
||||
"postcss-import@^15.1.0": "https://registry.yarnpkg.com/postcss-import/-/postcss-import-15.1.0.tgz#41c64ed8cc0e23735a9698b3249ffdbf704adc70",
|
||||
"postcss-js@^4.0.1": "https://registry.yarnpkg.com/postcss-js/-/postcss-js-4.0.1.tgz#61598186f3703bab052f1c4f7d805f3991bee9d2",
|
||||
"postcss-load-config@^4.0.1": "https://registry.yarnpkg.com/postcss-load-config/-/postcss-load-config-4.0.1.tgz#152383f481c2758274404e4962743191d73875bd",
|
||||
"postcss-nested@^6.0.1": "https://registry.yarnpkg.com/postcss-nested/-/postcss-nested-6.0.1.tgz#f83dc9846ca16d2f4fa864f16e9d9f7d0961662c",
|
||||
"postcss-selector-parser@^6.0.11": "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-6.0.13.tgz#d05d8d76b1e8e173257ef9d60b706a8e5e99bf1b",
|
||||
"postcss-value-parser@^4.0.0": "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz#723c09920836ba6d3e5af019f92bc0971c02e514",
|
||||
"postcss-value-parser@^4.2.0": "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz#723c09920836ba6d3e5af019f92bc0971c02e514",
|
||||
"postcss@^8.4.23": "https://registry.yarnpkg.com/postcss/-/postcss-8.4.27.tgz#234d7e4b72e34ba5a92c29636734349e0d9c3057",
|
||||
"postcss@^8.4.26": "https://registry.yarnpkg.com/postcss/-/postcss-8.4.27.tgz#234d7e4b72e34ba5a92c29636734349e0d9c3057",
|
||||
"postcss@^8.4.27": "https://registry.yarnpkg.com/postcss/-/postcss-8.4.27.tgz#234d7e4b72e34ba5a92c29636734349e0d9c3057",
|
||||
"queue-microtask@^1.2.2": "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243",
|
||||
"read-cache@^1.0.0": "https://registry.yarnpkg.com/read-cache/-/read-cache-1.0.0.tgz#e664ef31161166c9751cdbe8dbcf86b5fb58f774",
|
||||
"readdirp@~3.6.0": "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7",
|
||||
"resolve@^1.1.7": "https://registry.yarnpkg.com/resolve/-/resolve-1.22.2.tgz#0ed0943d4e301867955766c9f3e1ae6d01c6845f",
|
||||
"resolve@^1.22.2": "https://registry.yarnpkg.com/resolve/-/resolve-1.22.2.tgz#0ed0943d4e301867955766c9f3e1ae6d01c6845f",
|
||||
"reusify@^1.0.4": "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76",
|
||||
"rollup@^3.25.2": "https://registry.yarnpkg.com/rollup/-/rollup-3.26.3.tgz#bbc8818cadd0aebca348dbb3d68d296d220967b8",
|
||||
"run-parallel@^1.1.9": "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee",
|
||||
"source-map-js@^1.0.2": "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c",
|
||||
"style-mod@^4.0.0": "https://registry.yarnpkg.com/style-mod/-/style-mod-4.0.3.tgz#136c4abc905f82a866a18b39df4dc08ec762b1ad",
|
||||
"sucrase@^3.32.0": "https://registry.yarnpkg.com/sucrase/-/sucrase-3.34.0.tgz#1e0e2d8fcf07f8b9c3569067d92fbd8690fb576f",
|
||||
"supports-preserve-symlinks-flag@^1.0.0": "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09",
|
||||
"tailwindcss@^3.3.3": "https://registry.yarnpkg.com/tailwindcss/-/tailwindcss-3.3.3.tgz#90da807393a2859189e48e9e7000e6880a736daf",
|
||||
"thenify-all@^1.0.0": "https://registry.yarnpkg.com/thenify-all/-/thenify-all-1.6.0.tgz#1a1918d402d8fc3f98fbf234db0bcc8cc10e9726",
|
||||
"thenify@>= 3.1.0 < 4": "https://registry.yarnpkg.com/thenify/-/thenify-3.3.1.tgz#8932e686a4066038a016dd9e2ca46add9838a95f",
|
||||
"to-regex-range@^5.0.1": "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4",
|
||||
"ts-interface-checker@^0.1.9": "https://registry.yarnpkg.com/ts-interface-checker/-/ts-interface-checker-0.1.13.tgz#784fd3d679722bc103b1b4b8030bcddb5db2a699",
|
||||
"typescript@^5.0.2": "https://registry.yarnpkg.com/typescript/-/typescript-5.1.6.tgz#02f8ac202b6dad2c0dd5e0913745b47a37998274",
|
||||
"update-browserslist-db@^1.0.11": "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz#9a2a641ad2907ae7b3616506f4b977851db5b940",
|
||||
"util-deprecate@^1.0.2": "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf",
|
||||
"vite@^4.4.5": "https://registry.yarnpkg.com/vite/-/vite-4.4.6.tgz#97a0a43868ec773fd88980d7c323c80233521cf1",
|
||||
"w3c-keyname@^2.2.4": "https://registry.yarnpkg.com/w3c-keyname/-/w3c-keyname-2.2.8.tgz#7b17c8c6883d4e8b86ac8aba79d39e880f8869c5",
|
||||
"wrappy@1": "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f",
|
||||
"yaml@^2.1.1": "https://registry.yarnpkg.com/yaml/-/yaml-2.3.1.tgz#02fe0975d23cd441242aa7204e09fc28ac2ac33b",
|
||||
"zzfx@^1.2.0": "https://registry.yarnpkg.com/zzfx/-/zzfx-1.2.0.tgz#021e5df8e1605f507e2dde15608eba22798b424b"
|
||||
},
|
||||
"files": [],
|
||||
"artifacts": {}
|
||||
}
|
||||
128
node_modules/@alloc/quick-lru/index.d.ts
generated
vendored
Normal file
128
node_modules/@alloc/quick-lru/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,128 @@
|
||||
declare namespace QuickLRU {
|
||||
interface Options<KeyType, ValueType> {
|
||||
/**
|
||||
The maximum number of milliseconds an item should remain in the cache.
|
||||
|
||||
@default Infinity
|
||||
|
||||
By default, `maxAge` will be `Infinity`, which means that items will never expire.
|
||||
Lazy expiration upon the next write or read call.
|
||||
|
||||
Individual expiration of an item can be specified by the `set(key, value, maxAge)` method.
|
||||
*/
|
||||
readonly maxAge?: number;
|
||||
|
||||
/**
|
||||
The maximum number of items before evicting the least recently used items.
|
||||
*/
|
||||
readonly maxSize: number;
|
||||
|
||||
/**
|
||||
Called right before an item is evicted from the cache.
|
||||
|
||||
Useful for side effects or for items like object URLs that need explicit cleanup (`revokeObjectURL`).
|
||||
*/
|
||||
onEviction?: (key: KeyType, value: ValueType) => void;
|
||||
}
|
||||
}
|
||||
|
||||
declare class QuickLRU<KeyType, ValueType>
|
||||
implements Iterable<[KeyType, ValueType]> {
|
||||
/**
|
||||
The stored item count.
|
||||
*/
|
||||
readonly size: number;
|
||||
|
||||
/**
|
||||
Simple ["Least Recently Used" (LRU) cache](https://en.m.wikipedia.org/wiki/Cache_replacement_policies#Least_Recently_Used_.28LRU.29).
|
||||
|
||||
The instance is [`iterable`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Iteration_protocols) so you can use it directly in a [`for…of`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Statements/for...of) loop.
|
||||
|
||||
@example
|
||||
```
|
||||
import QuickLRU = require('quick-lru');
|
||||
|
||||
const lru = new QuickLRU({maxSize: 1000});
|
||||
|
||||
lru.set('🦄', '🌈');
|
||||
|
||||
lru.has('🦄');
|
||||
//=> true
|
||||
|
||||
lru.get('🦄');
|
||||
//=> '🌈'
|
||||
```
|
||||
*/
|
||||
constructor(options: QuickLRU.Options<KeyType, ValueType>);
|
||||
|
||||
[Symbol.iterator](): IterableIterator<[KeyType, ValueType]>;
|
||||
|
||||
/**
|
||||
Set an item. Returns the instance.
|
||||
|
||||
Individual expiration of an item can be specified with the `maxAge` option. If not specified, the global `maxAge` value will be used in case it is specified in the constructor, otherwise the item will never expire.
|
||||
|
||||
@returns The list instance.
|
||||
*/
|
||||
set(key: KeyType, value: ValueType, options?: {maxAge?: number}): this;
|
||||
|
||||
/**
|
||||
Get an item.
|
||||
|
||||
@returns The stored item or `undefined`.
|
||||
*/
|
||||
get(key: KeyType): ValueType | undefined;
|
||||
|
||||
/**
|
||||
Check if an item exists.
|
||||
*/
|
||||
has(key: KeyType): boolean;
|
||||
|
||||
/**
|
||||
Get an item without marking it as recently used.
|
||||
|
||||
@returns The stored item or `undefined`.
|
||||
*/
|
||||
peek(key: KeyType): ValueType | undefined;
|
||||
|
||||
/**
|
||||
Delete an item.
|
||||
|
||||
@returns `true` if the item is removed or `false` if the item doesn't exist.
|
||||
*/
|
||||
delete(key: KeyType): boolean;
|
||||
|
||||
/**
|
||||
Delete all items.
|
||||
*/
|
||||
clear(): void;
|
||||
|
||||
/**
|
||||
Update the `maxSize` in-place, discarding items as necessary. Insertion order is mostly preserved, though this is not a strong guarantee.
|
||||
|
||||
Useful for on-the-fly tuning of cache sizes in live systems.
|
||||
*/
|
||||
resize(maxSize: number): void;
|
||||
|
||||
/**
|
||||
Iterable for all the keys.
|
||||
*/
|
||||
keys(): IterableIterator<KeyType>;
|
||||
|
||||
/**
|
||||
Iterable for all the values.
|
||||
*/
|
||||
values(): IterableIterator<ValueType>;
|
||||
|
||||
/**
|
||||
Iterable for all entries, starting with the oldest (ascending in recency).
|
||||
*/
|
||||
entriesAscending(): IterableIterator<[KeyType, ValueType]>;
|
||||
|
||||
/**
|
||||
Iterable for all entries, starting with the newest (descending in recency).
|
||||
*/
|
||||
entriesDescending(): IterableIterator<[KeyType, ValueType]>;
|
||||
}
|
||||
|
||||
export = QuickLRU;
|
||||
263
node_modules/@alloc/quick-lru/index.js
generated
vendored
Normal file
263
node_modules/@alloc/quick-lru/index.js
generated
vendored
Normal file
@ -0,0 +1,263 @@
|
||||
'use strict';
|
||||
|
||||
class QuickLRU {
|
||||
constructor(options = {}) {
|
||||
if (!(options.maxSize && options.maxSize > 0)) {
|
||||
throw new TypeError('`maxSize` must be a number greater than 0');
|
||||
}
|
||||
|
||||
if (typeof options.maxAge === 'number' && options.maxAge === 0) {
|
||||
throw new TypeError('`maxAge` must be a number greater than 0');
|
||||
}
|
||||
|
||||
this.maxSize = options.maxSize;
|
||||
this.maxAge = options.maxAge || Infinity;
|
||||
this.onEviction = options.onEviction;
|
||||
this.cache = new Map();
|
||||
this.oldCache = new Map();
|
||||
this._size = 0;
|
||||
}
|
||||
|
||||
_emitEvictions(cache) {
|
||||
if (typeof this.onEviction !== 'function') {
|
||||
return;
|
||||
}
|
||||
|
||||
for (const [key, item] of cache) {
|
||||
this.onEviction(key, item.value);
|
||||
}
|
||||
}
|
||||
|
||||
_deleteIfExpired(key, item) {
|
||||
if (typeof item.expiry === 'number' && item.expiry <= Date.now()) {
|
||||
if (typeof this.onEviction === 'function') {
|
||||
this.onEviction(key, item.value);
|
||||
}
|
||||
|
||||
return this.delete(key);
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
_getOrDeleteIfExpired(key, item) {
|
||||
const deleted = this._deleteIfExpired(key, item);
|
||||
if (deleted === false) {
|
||||
return item.value;
|
||||
}
|
||||
}
|
||||
|
||||
_getItemValue(key, item) {
|
||||
return item.expiry ? this._getOrDeleteIfExpired(key, item) : item.value;
|
||||
}
|
||||
|
||||
_peek(key, cache) {
|
||||
const item = cache.get(key);
|
||||
|
||||
return this._getItemValue(key, item);
|
||||
}
|
||||
|
||||
_set(key, value) {
|
||||
this.cache.set(key, value);
|
||||
this._size++;
|
||||
|
||||
if (this._size >= this.maxSize) {
|
||||
this._size = 0;
|
||||
this._emitEvictions(this.oldCache);
|
||||
this.oldCache = this.cache;
|
||||
this.cache = new Map();
|
||||
}
|
||||
}
|
||||
|
||||
_moveToRecent(key, item) {
|
||||
this.oldCache.delete(key);
|
||||
this._set(key, item);
|
||||
}
|
||||
|
||||
* _entriesAscending() {
|
||||
for (const item of this.oldCache) {
|
||||
const [key, value] = item;
|
||||
if (!this.cache.has(key)) {
|
||||
const deleted = this._deleteIfExpired(key, value);
|
||||
if (deleted === false) {
|
||||
yield item;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
for (const item of this.cache) {
|
||||
const [key, value] = item;
|
||||
const deleted = this._deleteIfExpired(key, value);
|
||||
if (deleted === false) {
|
||||
yield item;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
get(key) {
|
||||
if (this.cache.has(key)) {
|
||||
const item = this.cache.get(key);
|
||||
|
||||
return this._getItemValue(key, item);
|
||||
}
|
||||
|
||||
if (this.oldCache.has(key)) {
|
||||
const item = this.oldCache.get(key);
|
||||
if (this._deleteIfExpired(key, item) === false) {
|
||||
this._moveToRecent(key, item);
|
||||
return item.value;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
set(key, value, {maxAge = this.maxAge === Infinity ? undefined : Date.now() + this.maxAge} = {}) {
|
||||
if (this.cache.has(key)) {
|
||||
this.cache.set(key, {
|
||||
value,
|
||||
maxAge
|
||||
});
|
||||
} else {
|
||||
this._set(key, {value, expiry: maxAge});
|
||||
}
|
||||
}
|
||||
|
||||
has(key) {
|
||||
if (this.cache.has(key)) {
|
||||
return !this._deleteIfExpired(key, this.cache.get(key));
|
||||
}
|
||||
|
||||
if (this.oldCache.has(key)) {
|
||||
return !this._deleteIfExpired(key, this.oldCache.get(key));
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
peek(key) {
|
||||
if (this.cache.has(key)) {
|
||||
return this._peek(key, this.cache);
|
||||
}
|
||||
|
||||
if (this.oldCache.has(key)) {
|
||||
return this._peek(key, this.oldCache);
|
||||
}
|
||||
}
|
||||
|
||||
delete(key) {
|
||||
const deleted = this.cache.delete(key);
|
||||
if (deleted) {
|
||||
this._size--;
|
||||
}
|
||||
|
||||
return this.oldCache.delete(key) || deleted;
|
||||
}
|
||||
|
||||
clear() {
|
||||
this.cache.clear();
|
||||
this.oldCache.clear();
|
||||
this._size = 0;
|
||||
}
|
||||
|
||||
resize(newSize) {
|
||||
if (!(newSize && newSize > 0)) {
|
||||
throw new TypeError('`maxSize` must be a number greater than 0');
|
||||
}
|
||||
|
||||
const items = [...this._entriesAscending()];
|
||||
const removeCount = items.length - newSize;
|
||||
if (removeCount < 0) {
|
||||
this.cache = new Map(items);
|
||||
this.oldCache = new Map();
|
||||
this._size = items.length;
|
||||
} else {
|
||||
if (removeCount > 0) {
|
||||
this._emitEvictions(items.slice(0, removeCount));
|
||||
}
|
||||
|
||||
this.oldCache = new Map(items.slice(removeCount));
|
||||
this.cache = new Map();
|
||||
this._size = 0;
|
||||
}
|
||||
|
||||
this.maxSize = newSize;
|
||||
}
|
||||
|
||||
* keys() {
|
||||
for (const [key] of this) {
|
||||
yield key;
|
||||
}
|
||||
}
|
||||
|
||||
* values() {
|
||||
for (const [, value] of this) {
|
||||
yield value;
|
||||
}
|
||||
}
|
||||
|
||||
* [Symbol.iterator]() {
|
||||
for (const item of this.cache) {
|
||||
const [key, value] = item;
|
||||
const deleted = this._deleteIfExpired(key, value);
|
||||
if (deleted === false) {
|
||||
yield [key, value.value];
|
||||
}
|
||||
}
|
||||
|
||||
for (const item of this.oldCache) {
|
||||
const [key, value] = item;
|
||||
if (!this.cache.has(key)) {
|
||||
const deleted = this._deleteIfExpired(key, value);
|
||||
if (deleted === false) {
|
||||
yield [key, value.value];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
* entriesDescending() {
|
||||
let items = [...this.cache];
|
||||
for (let i = items.length - 1; i >= 0; --i) {
|
||||
const item = items[i];
|
||||
const [key, value] = item;
|
||||
const deleted = this._deleteIfExpired(key, value);
|
||||
if (deleted === false) {
|
||||
yield [key, value.value];
|
||||
}
|
||||
}
|
||||
|
||||
items = [...this.oldCache];
|
||||
for (let i = items.length - 1; i >= 0; --i) {
|
||||
const item = items[i];
|
||||
const [key, value] = item;
|
||||
if (!this.cache.has(key)) {
|
||||
const deleted = this._deleteIfExpired(key, value);
|
||||
if (deleted === false) {
|
||||
yield [key, value.value];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
* entriesAscending() {
|
||||
for (const [key, value] of this._entriesAscending()) {
|
||||
yield [key, value.value];
|
||||
}
|
||||
}
|
||||
|
||||
get size() {
|
||||
if (!this._size) {
|
||||
return this.oldCache.size;
|
||||
}
|
||||
|
||||
let oldCacheSize = 0;
|
||||
for (const key of this.oldCache.keys()) {
|
||||
if (!this.cache.has(key)) {
|
||||
oldCacheSize++;
|
||||
}
|
||||
}
|
||||
|
||||
return Math.min(this._size + oldCacheSize, this.maxSize);
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = QuickLRU;
|
||||
9
node_modules/@alloc/quick-lru/license
generated
vendored
Normal file
9
node_modules/@alloc/quick-lru/license
generated
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com)
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
43
node_modules/@alloc/quick-lru/package.json
generated
vendored
Normal file
43
node_modules/@alloc/quick-lru/package.json
generated
vendored
Normal file
@ -0,0 +1,43 @@
|
||||
{
|
||||
"name": "@alloc/quick-lru",
|
||||
"version": "5.2.0",
|
||||
"description": "Simple “Least Recently Used” (LRU) cache",
|
||||
"license": "MIT",
|
||||
"repository": "sindresorhus/quick-lru",
|
||||
"funding": "https://github.com/sponsors/sindresorhus",
|
||||
"author": {
|
||||
"name": "Sindre Sorhus",
|
||||
"email": "sindresorhus@gmail.com",
|
||||
"url": "https://sindresorhus.com"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=10"
|
||||
},
|
||||
"scripts": {
|
||||
"test": "xo && nyc ava && tsd"
|
||||
},
|
||||
"files": [
|
||||
"index.js",
|
||||
"index.d.ts"
|
||||
],
|
||||
"keywords": [
|
||||
"lru",
|
||||
"quick",
|
||||
"cache",
|
||||
"caching",
|
||||
"least",
|
||||
"recently",
|
||||
"used",
|
||||
"fast",
|
||||
"map",
|
||||
"hash",
|
||||
"buffer"
|
||||
],
|
||||
"devDependencies": {
|
||||
"ava": "^2.0.0",
|
||||
"coveralls": "^3.0.3",
|
||||
"nyc": "^15.0.0",
|
||||
"tsd": "^0.11.0",
|
||||
"xo": "^0.26.0"
|
||||
}
|
||||
}
|
||||
139
node_modules/@alloc/quick-lru/readme.md
generated
vendored
Normal file
139
node_modules/@alloc/quick-lru/readme.md
generated
vendored
Normal file
@ -0,0 +1,139 @@
|
||||
# quick-lru [](https://travis-ci.org/sindresorhus/quick-lru) [](https://coveralls.io/github/sindresorhus/quick-lru?branch=master)
|
||||
|
||||
> Simple [“Least Recently Used” (LRU) cache](https://en.m.wikipedia.org/wiki/Cache_replacement_policies#Least_Recently_Used_.28LRU.29)
|
||||
|
||||
Useful when you need to cache something and limit memory usage.
|
||||
|
||||
Inspired by the [`hashlru` algorithm](https://github.com/dominictarr/hashlru#algorithm), but instead uses [`Map`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Map) to support keys of any type, not just strings, and values can be `undefined`.
|
||||
|
||||
## Install
|
||||
|
||||
```
|
||||
$ npm install quick-lru
|
||||
```
|
||||
|
||||
## Usage
|
||||
|
||||
```js
|
||||
const QuickLRU = require('quick-lru');
|
||||
|
||||
const lru = new QuickLRU({maxSize: 1000});
|
||||
|
||||
lru.set('🦄', '🌈');
|
||||
|
||||
lru.has('🦄');
|
||||
//=> true
|
||||
|
||||
lru.get('🦄');
|
||||
//=> '🌈'
|
||||
```
|
||||
|
||||
## API
|
||||
|
||||
### new QuickLRU(options?)
|
||||
|
||||
Returns a new instance.
|
||||
|
||||
### options
|
||||
|
||||
Type: `object`
|
||||
|
||||
#### maxSize
|
||||
|
||||
*Required*\
|
||||
Type: `number`
|
||||
|
||||
The maximum number of items before evicting the least recently used items.
|
||||
|
||||
#### maxAge
|
||||
|
||||
Type: `number`\
|
||||
Default: `Infinity`
|
||||
|
||||
The maximum number of milliseconds an item should remain in cache.
|
||||
By default maxAge will be Infinity, which means that items will never expire.
|
||||
|
||||
Lazy expiration happens upon the next `write` or `read` call.
|
||||
|
||||
Individual expiration of an item can be specified by the `set(key, value, options)` method.
|
||||
|
||||
#### onEviction
|
||||
|
||||
*Optional*\
|
||||
Type: `(key, value) => void`
|
||||
|
||||
Called right before an item is evicted from the cache.
|
||||
|
||||
Useful for side effects or for items like object URLs that need explicit cleanup (`revokeObjectURL`).
|
||||
|
||||
### Instance
|
||||
|
||||
The instance is [`iterable`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Iteration_protocols) so you can use it directly in a [`for…of`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Statements/for...of) loop.
|
||||
|
||||
Both `key` and `value` can be of any type.
|
||||
|
||||
#### .set(key, value, options?)
|
||||
|
||||
Set an item. Returns the instance.
|
||||
|
||||
Individual expiration of an item can be specified with the `maxAge` option. If not specified, the global `maxAge` value will be used in case it is specified on the constructor, otherwise the item will never expire.
|
||||
|
||||
#### .get(key)
|
||||
|
||||
Get an item.
|
||||
|
||||
#### .has(key)
|
||||
|
||||
Check if an item exists.
|
||||
|
||||
#### .peek(key)
|
||||
|
||||
Get an item without marking it as recently used.
|
||||
|
||||
#### .delete(key)
|
||||
|
||||
Delete an item.
|
||||
|
||||
Returns `true` if the item is removed or `false` if the item doesn't exist.
|
||||
|
||||
#### .clear()
|
||||
|
||||
Delete all items.
|
||||
|
||||
#### .resize(maxSize)
|
||||
|
||||
Update the `maxSize`, discarding items as necessary. Insertion order is mostly preserved, though this is not a strong guarantee.
|
||||
|
||||
Useful for on-the-fly tuning of cache sizes in live systems.
|
||||
|
||||
#### .keys()
|
||||
|
||||
Iterable for all the keys.
|
||||
|
||||
#### .values()
|
||||
|
||||
Iterable for all the values.
|
||||
|
||||
#### .entriesAscending()
|
||||
|
||||
Iterable for all entries, starting with the oldest (ascending in recency).
|
||||
|
||||
#### .entriesDescending()
|
||||
|
||||
Iterable for all entries, starting with the newest (descending in recency).
|
||||
|
||||
#### .size
|
||||
|
||||
The stored item count.
|
||||
|
||||
---
|
||||
|
||||
<div align="center">
|
||||
<b>
|
||||
<a href="https://tidelift.com/subscription/pkg/npm-quick-lru?utm_source=npm-quick-lru&utm_medium=referral&utm_campaign=readme">Get professional support for this package with a Tidelift subscription</a>
|
||||
</b>
|
||||
<br>
|
||||
<sub>
|
||||
Tidelift helps make open source sustainable for maintainers while giving companies<br>assurances about security, maintenance, and licensing for their dependencies.
|
||||
</sub>
|
||||
</div>
|
||||
16
node_modules/@codemirror/autocomplete/.github/workflows/dispatch.yml
generated
vendored
Normal file
16
node_modules/@codemirror/autocomplete/.github/workflows/dispatch.yml
generated
vendored
Normal file
@ -0,0 +1,16 @@
|
||||
name: Trigger CI
|
||||
on: push
|
||||
|
||||
jobs:
|
||||
build:
|
||||
name: Dispatch to main repo
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Emit repository_dispatch
|
||||
uses: mvasigh/dispatch-action@main
|
||||
with:
|
||||
# You should create a personal access token and store it in your repository
|
||||
token: ${{ secrets.DISPATCH_AUTH }}
|
||||
repo: dev
|
||||
owner: codemirror
|
||||
event_type: push
|
||||
446
node_modules/@codemirror/autocomplete/CHANGELOG.md
generated
vendored
Normal file
446
node_modules/@codemirror/autocomplete/CHANGELOG.md
generated
vendored
Normal file
@ -0,0 +1,446 @@
|
||||
## 6.9.0 (2023-07-18)
|
||||
|
||||
### New features
|
||||
|
||||
Completions may now provide a `displayLabel` property that overrides the way they are displayed in the completion list.
|
||||
|
||||
## 6.8.1 (2023-06-23)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
`acceptCompletion` now returns false (allowing other handlers to take effect) when the completion popup is open but disabled.
|
||||
|
||||
## 6.8.0 (2023-06-12)
|
||||
|
||||
### New features
|
||||
|
||||
The result of `Completion.info` may now include a `destroy` method that will be called when the tooltip is removed.
|
||||
|
||||
## 6.7.1 (2023-05-13)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that cause incorrect ordering of completions when some results covered input text and others didn't.
|
||||
|
||||
## 6.7.0 (2023-05-11)
|
||||
|
||||
### New features
|
||||
|
||||
The new `hasNextSnippetField` and `hasPrevSnippetField` functions can be used to figure out if the snippet-field-motion commands apply to a given state.
|
||||
|
||||
## 6.6.1 (2023-05-03)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that made the editor use the completion's original position, rather than its current position, when changes happened in the document while a result was active.
|
||||
|
||||
## 6.6.0 (2023-04-27)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug in `insertCompletionText` that caused it to replace the wrong range when a result set's `to` fell after the cursor.
|
||||
|
||||
### New features
|
||||
|
||||
Functions returned by `snippet` can now be called without a completion object.
|
||||
|
||||
## 6.5.1 (2023-04-13)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Keep completions open when interaction with an info tooltip moves focus out of the editor.
|
||||
|
||||
## 6.5.0 (2023-04-13)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
When `closeBrackets` skips a bracket, it now generates a change that overwrites the bracket.
|
||||
|
||||
Replace the entire selected range when picking a completion with a non-cursor selection active.
|
||||
|
||||
### New features
|
||||
|
||||
Completions can now provide a `section` field that is used to group them into sections.
|
||||
|
||||
The new `positionInfo` option can be used to provide custom logic for positioning the info tooltips.
|
||||
|
||||
## 6.4.2 (2023-02-17)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug where the apply method created by `snippet` didn't add a `pickedCompletion` annotation to the transactions it created.
|
||||
|
||||
## 6.4.1 (2023-02-14)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Don't consider node names in trees that aren't the same language as the one at the completion position in `ifIn` and `ifNotIn`.
|
||||
|
||||
Make sure completions that exactly match the input get a higher score than those that don't (so that even if the latter has a score boost, it ends up lower in the list).
|
||||
|
||||
## 6.4.0 (2022-12-14)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where the extension would sometimes try to draw a disabled dialog at an outdated position, leading to plugin crashes.
|
||||
|
||||
### New features
|
||||
|
||||
A `tooltipClass` option to autocompletion can now be used to add additional CSS classes to the completion tooltip.
|
||||
|
||||
## 6.3.4 (2022-11-24)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where completion lists could end up being higher than the tooltip they were in.
|
||||
|
||||
## 6.3.3 (2022-11-18)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Set an explicit `box-sizing` style on completion icons so CSS resets don't mess them up.
|
||||
|
||||
Allow closing braces in templates to be escaped with a backslash.
|
||||
|
||||
## 6.3.2 (2022-11-15)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a regression that could cause the completion dialog to stick around when it should be hidden.
|
||||
|
||||
## 6.3.1 (2022-11-14)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a regression where transactions for picking a completion (without custom `apply` method) no longer had the `pickedCompletion` annotation.
|
||||
|
||||
Reduce flickering for completion sources without `validFor` info by temporarily showing a disabled tooltip while the completion updates.
|
||||
|
||||
Make sure completion info tooltips are kept within the space provided by the `tooltipSpace` option.
|
||||
|
||||
## 6.3.0 (2022-09-22)
|
||||
|
||||
### New features
|
||||
|
||||
Close bracket configuration now supports a `stringPrefixes` property that can be used to allow autoclosing of prefixed strings.
|
||||
|
||||
## 6.2.0 (2022-09-13)
|
||||
|
||||
### New features
|
||||
|
||||
Autocompletion now takes an `interactionDelay` option that can be used to control the delay between the time where completion opens and the time where commands like `acceptCompletion` affect it.
|
||||
|
||||
## 6.1.1 (2022-09-08)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that prevented transactions produced by `deleteBracketPair` from being marked as deletion user events.
|
||||
|
||||
Improve positioning of completion info tooltips so they are less likely to stick out of the screen on small displays.
|
||||
|
||||
## 6.1.0 (2022-07-19)
|
||||
|
||||
### New features
|
||||
|
||||
You can now provide a `compareCompletions` option to autocompletion to influence the way completions with the same match score are sorted.
|
||||
|
||||
The `selectOnOpen` option to autocompletion can be used to require explicitly selecting a completion option before `acceptCompletion` does anything.
|
||||
|
||||
## 6.0.4 (2022-07-07)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Remove a leftover `console.log` in bracket closing code.
|
||||
|
||||
## 6.0.3 (2022-07-04)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that caused `closeBrackets` to not close quotes when at the end of a syntactic construct that starts with a similar quote.
|
||||
|
||||
## 6.0.2 (2022-06-15)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Declare package dependencies as peer dependencies as an attempt to avoid duplicated package issues.
|
||||
|
||||
## 6.0.1 (2022-06-09)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Support escaping `${` or `#{` in snippets.
|
||||
|
||||
## 6.0.0 (2022-06-08)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Scroll the cursor into view when inserting a snippet.
|
||||
|
||||
## 0.20.3 (2022-05-30)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Add an aria-label to the completion listbox.
|
||||
|
||||
Fix a regression that caused transactions generated for completion to not have a `userEvent` annotation.
|
||||
|
||||
## 0.20.2 (2022-05-24)
|
||||
|
||||
### New features
|
||||
|
||||
The package now exports an `insertCompletionText` helper that implements the default behavior for applying a completion.
|
||||
|
||||
## 0.20.1 (2022-05-16)
|
||||
|
||||
### New features
|
||||
|
||||
The new `closeOnBlur` option determines whether the completion tooltip is closed when the editor loses focus.
|
||||
|
||||
`CompletionResult` objects with `filter: false` may now have a `getMatch` property that determines the matched range in the options.
|
||||
|
||||
## 0.20.0 (2022-04-20)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
`CompletionResult.span` has been renamed to `validFor`, and may now hold a function as well as a regular expression.
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Remove code that dropped any options beyond the 300th one when matching and sorting option lists.
|
||||
|
||||
Completion will now apply to all cursors when there are multiple cursors.
|
||||
|
||||
### New features
|
||||
|
||||
`CompletionResult.update` can now be used to implement quick autocompletion updates in a synchronous way.
|
||||
|
||||
The @codemirror/closebrackets package was merged into this one.
|
||||
|
||||
## 0.19.15 (2022-03-23)
|
||||
|
||||
### New features
|
||||
|
||||
The `selectedCompletionIndex` function tells you the position of the currently selected completion.
|
||||
|
||||
The new `setSelectionCompletion` function creates a state effect that moves the selected completion to a given index.
|
||||
|
||||
A completion's `info` method may now return null to indicate that no further info is available.
|
||||
|
||||
## 0.19.14 (2022-03-10)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make the ARIA attributes added to the editor during autocompletion spec-compliant.
|
||||
|
||||
## 0.19.13 (2022-02-18)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where the completion tooltip stayed open if it was explicitly opened and the user backspaced past its start.
|
||||
|
||||
Stop snippet filling when a change happens across one of the snippet fields' boundaries.
|
||||
|
||||
## 0.19.12 (2022-01-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix completion navigation with PageUp/Down when the completion tooltip isn't part of the view DOM.
|
||||
|
||||
## 0.19.11 (2022-01-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that caused page up/down to only move the selection by two options in the completion tooltip.
|
||||
|
||||
## 0.19.10 (2022-01-05)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make sure the info tooltip is hidden when the selected option is scrolled out of view.
|
||||
|
||||
Fix a bug in the completion ranking that would sometimes give options that match the input by word start chars higher scores than appropriate.
|
||||
|
||||
Options are now sorted (ascending) by length when their match score is otherwise identical.
|
||||
|
||||
## 0.19.9 (2021-11-26)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where info tooltips would be visible in an inappropriate position when there was no room to place them properly.
|
||||
|
||||
## 0.19.8 (2021-11-17)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Give the completion tooltip a minimal width, and show ellipsis when completions overflow the tooltip width.
|
||||
|
||||
### New features
|
||||
|
||||
`autocompletion` now accepts an `aboveCursor` option to make the completion tooltip show up above the cursor.
|
||||
|
||||
## 0.19.7 (2021-11-16)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make option deduplication less aggressive, so that options with different `type` or `apply` fields don't get merged.
|
||||
|
||||
## 0.19.6 (2021-11-12)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where parsing a snippet with a field that was labeled only by a number crashed.
|
||||
|
||||
## 0.19.5 (2021-11-09)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make sure info tooltips don't stick out of the bottom of the page.
|
||||
|
||||
### New features
|
||||
|
||||
The package exports a new function `selectedCompletion`, which can be used to find out which completion is currently selected.
|
||||
|
||||
Transactions created by picking a completion now have an annotation (`pickedCompletion`) holding the original completion.
|
||||
|
||||
## 0.19.4 (2021-10-24)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Don't rely on the platform's highlight colors for the active completion, since those are inconsistent and may not be appropriate for the theme.
|
||||
|
||||
Fix incorrect match underline for some kinds of matched completions.
|
||||
|
||||
## 0.19.3 (2021-08-31)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Improve the sorting of completions by using `localeCompare`.
|
||||
|
||||
Fix reading of autocompletions in NVDA screen reader.
|
||||
|
||||
### New features
|
||||
|
||||
The new `icons` option can be used to turn off icons in the completion list.
|
||||
|
||||
The `optionClass` option can now be used to add CSS classes to the options in the completion list.
|
||||
|
||||
It is now possible to inject additional content into rendered completion options with the `addToOptions` configuration option.
|
||||
|
||||
## 0.19.2 (2021-08-25)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where `completeAnyWord` would return results when there was no query and `explicit` was false.
|
||||
|
||||
## 0.19.1 (2021-08-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix incorrect versions for @lezer dependencies.
|
||||
|
||||
## 0.19.0 (2021-08-11)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
Update dependencies to 0.19.0
|
||||
|
||||
## 0.18.8 (2021-06-30)
|
||||
|
||||
### New features
|
||||
|
||||
Add an `ifIn` helper function that constrains a completion source to only fire when in a given syntax node. Add support for unfiltered completions
|
||||
|
||||
A completion result can now set a `filter: false` property to disable filtering and sorting of completions, when it already did so itself.
|
||||
|
||||
## 0.18.7 (2021-06-14)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Don't treat continued completions when typing after an explicit completion as explicit.
|
||||
|
||||
## 0.18.6 (2021-06-03)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Adding or reconfiguring completion sources will now cause them to be activated right away if a completion was active.
|
||||
|
||||
### New features
|
||||
|
||||
You can now specify multiple types in `Completion.type` by separating them by spaces. Small doc comment tweak for Completion.type
|
||||
|
||||
## 0.18.5 (2021-04-23)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a regression where snippet field selection didn't work with @codemirror/state 0.18.6.
|
||||
|
||||
Fix a bug where snippet fields with different position numbers were inappropriately merged.
|
||||
|
||||
## 0.18.4 (2021-04-20)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a crash in Safari when moving the selection during composition.
|
||||
|
||||
## 0.18.3 (2021-03-15)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Adjust to updated @codemirror/tooltip interface.
|
||||
|
||||
## 0.18.2 (2021-03-14)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix unintended ES2020 output (the package contains ES6 code again).
|
||||
|
||||
## 0.18.1 (2021-03-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Stop active completion when all sources resolve without producing any matches.
|
||||
|
||||
### New features
|
||||
|
||||
`Completion.info` may now return a promise.
|
||||
|
||||
## 0.18.0 (2021-03-03)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Only preserve selected option across updates when it isn't the first option.
|
||||
|
||||
## 0.17.4 (2021-01-18)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a styling issue where the selection had become invisible inside snippet fields (when using `drawSelection`).
|
||||
|
||||
### New features
|
||||
|
||||
Snippet fields can now be selected with the pointing device (so that they are usable on touch devices).
|
||||
|
||||
## 0.17.3 (2021-01-18)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug where uppercase completions would be incorrectly matched against the typed input.
|
||||
|
||||
## 0.17.2 (2021-01-12)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Don't bind Cmd-Space on macOS, since that already has a system default binding. Use Ctrl-Space for autocompletion.
|
||||
|
||||
## 0.17.1 (2021-01-06)
|
||||
|
||||
### New features
|
||||
|
||||
The package now also exports a CommonJS module.
|
||||
|
||||
## 0.17.0 (2020-12-29)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
First numbered release.
|
||||
|
||||
21
node_modules/@codemirror/autocomplete/LICENSE
generated
vendored
Normal file
21
node_modules/@codemirror/autocomplete/LICENSE
generated
vendored
Normal file
@ -0,0 +1,21 @@
|
||||
MIT License
|
||||
|
||||
Copyright (C) 2018-2021 by Marijn Haverbeke <marijn@haverbeke.berlin> and others
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
18
node_modules/@codemirror/autocomplete/README.md
generated
vendored
Normal file
18
node_modules/@codemirror/autocomplete/README.md
generated
vendored
Normal file
@ -0,0 +1,18 @@
|
||||
# @codemirror/autocomplete [](https://www.npmjs.org/package/@codemirror/autocomplete)
|
||||
|
||||
[ [**WEBSITE**](https://codemirror.net/) | [**DOCS**](https://codemirror.net/docs/ref/#autocomplete) | [**ISSUES**](https://github.com/codemirror/dev/issues) | [**FORUM**](https://discuss.codemirror.net/c/next/) | [**CHANGELOG**](https://github.com/codemirror/autocomplete/blob/main/CHANGELOG.md) ]
|
||||
|
||||
This package implements autocompletion for the
|
||||
[CodeMirror](https://codemirror.net/) code editor.
|
||||
|
||||
The [project page](https://codemirror.net/) has more information, a
|
||||
number of [examples](https://codemirror.net/examples/) and the
|
||||
[documentation](https://codemirror.net/docs/).
|
||||
|
||||
This code is released under an
|
||||
[MIT license](https://github.com/codemirror/autocomplete/tree/main/LICENSE).
|
||||
|
||||
We aim to be an inclusive, welcoming community. To make that explicit,
|
||||
we have a [code of
|
||||
conduct](http://contributor-covenant.org/version/1/1/0/) that applies
|
||||
to communication around the project.
|
||||
1996
node_modules/@codemirror/autocomplete/dist/index.cjs
generated
vendored
Normal file
1996
node_modules/@codemirror/autocomplete/dist/index.cjs
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
567
node_modules/@codemirror/autocomplete/dist/index.d.cts
generated
vendored
Normal file
567
node_modules/@codemirror/autocomplete/dist/index.d.cts
generated
vendored
Normal file
@ -0,0 +1,567 @@
|
||||
import * as _codemirror_state from '@codemirror/state';
|
||||
import { EditorState, TransactionSpec, Transaction, StateCommand, Facet, Extension, StateEffect } from '@codemirror/state';
|
||||
import { EditorView, Rect, KeyBinding, Command } from '@codemirror/view';
|
||||
import * as _lezer_common from '@lezer/common';
|
||||
|
||||
/**
|
||||
Objects type used to represent individual completions.
|
||||
*/
|
||||
interface Completion {
|
||||
/**
|
||||
The label to show in the completion picker. This is what input
|
||||
is matched agains to determine whether a completion matches (and
|
||||
how well it matches).
|
||||
*/
|
||||
label: string;
|
||||
/**
|
||||
An optional override for the completion's visible label. When
|
||||
using this, matched characters will only be highlighted if you
|
||||
provide a [`getMatch`](https://codemirror.net/6/docs/ref/#autocomplete.CompletionResult.getMatch)
|
||||
function.
|
||||
*/
|
||||
displayLabel?: string;
|
||||
/**
|
||||
An optional short piece of information to show (with a different
|
||||
style) after the label.
|
||||
*/
|
||||
detail?: string;
|
||||
/**
|
||||
Additional info to show when the completion is selected. Can be
|
||||
a plain string or a function that'll render the DOM structure to
|
||||
show when invoked.
|
||||
*/
|
||||
info?: string | ((completion: Completion) => CompletionInfo | Promise<CompletionInfo>);
|
||||
/**
|
||||
How to apply the completion. The default is to replace it with
|
||||
its [label](https://codemirror.net/6/docs/ref/#autocomplete.Completion.label). When this holds a
|
||||
string, the completion range is replaced by that string. When it
|
||||
is a function, that function is called to perform the
|
||||
completion. If it fires a transaction, it is responsible for
|
||||
adding the [`pickedCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.pickedCompletion)
|
||||
annotation to it.
|
||||
*/
|
||||
apply?: string | ((view: EditorView, completion: Completion, from: number, to: number) => void);
|
||||
/**
|
||||
The type of the completion. This is used to pick an icon to show
|
||||
for the completion. Icons are styled with a CSS class created by
|
||||
appending the type name to `"cm-completionIcon-"`. You can
|
||||
define or restyle icons by defining these selectors. The base
|
||||
library defines simple icons for `class`, `constant`, `enum`,
|
||||
`function`, `interface`, `keyword`, `method`, `namespace`,
|
||||
`property`, `text`, `type`, and `variable`.
|
||||
|
||||
Multiple types can be provided by separating them with spaces.
|
||||
*/
|
||||
type?: string;
|
||||
/**
|
||||
When given, should be a number from -99 to 99 that adjusts how
|
||||
this completion is ranked compared to other completions that
|
||||
match the input as well as this one. A negative number moves it
|
||||
down the list, a positive number moves it up.
|
||||
*/
|
||||
boost?: number;
|
||||
/**
|
||||
Can be used to divide the completion list into sections.
|
||||
Completions in a given section (matched by name) will be grouped
|
||||
together, with a heading above them. Options without section
|
||||
will appear above all sections. A string value is equivalent to
|
||||
a `{name}` object.
|
||||
*/
|
||||
section?: string | CompletionSection;
|
||||
}
|
||||
/**
|
||||
The type returned from
|
||||
[`Completion.info`](https://codemirror.net/6/docs/ref/#autocomplete.Completion.info). May be a DOM
|
||||
node, null to indicate there is no info, or an object with an
|
||||
optional `destroy` method that cleans up the node.
|
||||
*/
|
||||
declare type CompletionInfo = Node | null | {
|
||||
dom: Node;
|
||||
destroy?(): void;
|
||||
};
|
||||
/**
|
||||
Object used to describe a completion
|
||||
[section](https://codemirror.net/6/docs/ref/#autocomplete.Completion.section). It is recommended to
|
||||
create a shared object used by all the completions in a given
|
||||
section.
|
||||
*/
|
||||
interface CompletionSection {
|
||||
/**
|
||||
The name of the section. If no `render` method is present, this
|
||||
will be displayed above the options.
|
||||
*/
|
||||
name: string;
|
||||
/**
|
||||
An optional function that renders the section header. Since the
|
||||
headers are shown inside a list, you should make sure the
|
||||
resulting element has a `display: list-item` style.
|
||||
*/
|
||||
header?: (section: CompletionSection) => HTMLElement;
|
||||
/**
|
||||
By default, sections are ordered alphabetically by name. To
|
||||
specify an explicit order, `rank` can be used. Sections with a
|
||||
lower rank will be shown above sections with a higher rank.
|
||||
*/
|
||||
rank?: number;
|
||||
}
|
||||
/**
|
||||
An instance of this is passed to completion source functions.
|
||||
*/
|
||||
declare class CompletionContext {
|
||||
/**
|
||||
The editor state that the completion happens in.
|
||||
*/
|
||||
readonly state: EditorState;
|
||||
/**
|
||||
The position at which the completion is happening.
|
||||
*/
|
||||
readonly pos: number;
|
||||
/**
|
||||
Indicates whether completion was activated explicitly, or
|
||||
implicitly by typing. The usual way to respond to this is to
|
||||
only return completions when either there is part of a
|
||||
completable entity before the cursor, or `explicit` is true.
|
||||
*/
|
||||
readonly explicit: boolean;
|
||||
/**
|
||||
Create a new completion context. (Mostly useful for testing
|
||||
completion sources—in the editor, the extension will create
|
||||
these for you.)
|
||||
*/
|
||||
constructor(
|
||||
/**
|
||||
The editor state that the completion happens in.
|
||||
*/
|
||||
state: EditorState,
|
||||
/**
|
||||
The position at which the completion is happening.
|
||||
*/
|
||||
pos: number,
|
||||
/**
|
||||
Indicates whether completion was activated explicitly, or
|
||||
implicitly by typing. The usual way to respond to this is to
|
||||
only return completions when either there is part of a
|
||||
completable entity before the cursor, or `explicit` is true.
|
||||
*/
|
||||
explicit: boolean);
|
||||
/**
|
||||
Get the extent, content, and (if there is a token) type of the
|
||||
token before `this.pos`.
|
||||
*/
|
||||
tokenBefore(types: readonly string[]): {
|
||||
from: number;
|
||||
to: number;
|
||||
text: string;
|
||||
type: _lezer_common.NodeType;
|
||||
} | null;
|
||||
/**
|
||||
Get the match of the given expression directly before the
|
||||
cursor.
|
||||
*/
|
||||
matchBefore(expr: RegExp): {
|
||||
from: number;
|
||||
to: number;
|
||||
text: string;
|
||||
} | null;
|
||||
/**
|
||||
Yields true when the query has been aborted. Can be useful in
|
||||
asynchronous queries to avoid doing work that will be ignored.
|
||||
*/
|
||||
get aborted(): boolean;
|
||||
/**
|
||||
Allows you to register abort handlers, which will be called when
|
||||
the query is
|
||||
[aborted](https://codemirror.net/6/docs/ref/#autocomplete.CompletionContext.aborted).
|
||||
*/
|
||||
addEventListener(type: "abort", listener: () => void): void;
|
||||
}
|
||||
/**
|
||||
Given a a fixed array of options, return an autocompleter that
|
||||
completes them.
|
||||
*/
|
||||
declare function completeFromList(list: readonly (string | Completion)[]): CompletionSource;
|
||||
/**
|
||||
Wrap the given completion source so that it will only fire when the
|
||||
cursor is in a syntax node with one of the given names.
|
||||
*/
|
||||
declare function ifIn(nodes: readonly string[], source: CompletionSource): CompletionSource;
|
||||
/**
|
||||
Wrap the given completion source so that it will not fire when the
|
||||
cursor is in a syntax node with one of the given names.
|
||||
*/
|
||||
declare function ifNotIn(nodes: readonly string[], source: CompletionSource): CompletionSource;
|
||||
/**
|
||||
The function signature for a completion source. Such a function
|
||||
may return its [result](https://codemirror.net/6/docs/ref/#autocomplete.CompletionResult)
|
||||
synchronously or as a promise. Returning null indicates no
|
||||
completions are available.
|
||||
*/
|
||||
declare type CompletionSource = (context: CompletionContext) => CompletionResult | null | Promise<CompletionResult | null>;
|
||||
/**
|
||||
Interface for objects returned by completion sources.
|
||||
*/
|
||||
interface CompletionResult {
|
||||
/**
|
||||
The start of the range that is being completed.
|
||||
*/
|
||||
from: number;
|
||||
/**
|
||||
The end of the range that is being completed. Defaults to the
|
||||
main cursor position.
|
||||
*/
|
||||
to?: number;
|
||||
/**
|
||||
The completions returned. These don't have to be compared with
|
||||
the input by the source—the autocompletion system will do its
|
||||
own matching (against the text between `from` and `to`) and
|
||||
sorting.
|
||||
*/
|
||||
options: readonly Completion[];
|
||||
/**
|
||||
When given, further typing or deletion that causes the part of
|
||||
the document between ([mapped](https://codemirror.net/6/docs/ref/#state.ChangeDesc.mapPos)) `from`
|
||||
and `to` to match this regular expression or predicate function
|
||||
will not query the completion source again, but continue with
|
||||
this list of options. This can help a lot with responsiveness,
|
||||
since it allows the completion list to be updated synchronously.
|
||||
*/
|
||||
validFor?: RegExp | ((text: string, from: number, to: number, state: EditorState) => boolean);
|
||||
/**
|
||||
By default, the library filters and scores completions. Set
|
||||
`filter` to `false` to disable this, and cause your completions
|
||||
to all be included, in the order they were given. When there are
|
||||
other sources, unfiltered completions appear at the top of the
|
||||
list of completions. `validFor` must not be given when `filter`
|
||||
is `false`, because it only works when filtering.
|
||||
*/
|
||||
filter?: boolean;
|
||||
/**
|
||||
When [`filter`](https://codemirror.net/6/docs/ref/#autocomplete.CompletionResult.filter) is set to
|
||||
`false` or a completion has a
|
||||
[`displayLabel`](https://codemirror.net/6/docs/ref/#autocomplete.Completion.displayLabel), this
|
||||
may be provided to compute the ranges on the label that match
|
||||
the input. Should return an array of numbers where each pair of
|
||||
adjacent numbers provide the start and end of a range. The
|
||||
second argument, the match found by the library, is only passed
|
||||
when `filter` isn't `false`.
|
||||
*/
|
||||
getMatch?: (completion: Completion, matched?: readonly number[]) => readonly number[];
|
||||
/**
|
||||
Synchronously update the completion result after typing or
|
||||
deletion. If given, this should not do any expensive work, since
|
||||
it will be called during editor state updates. The function
|
||||
should make sure (similar to
|
||||
[`validFor`](https://codemirror.net/6/docs/ref/#autocomplete.CompletionResult.validFor)) that the
|
||||
completion still applies in the new state.
|
||||
*/
|
||||
update?: (current: CompletionResult, from: number, to: number, context: CompletionContext) => CompletionResult | null;
|
||||
}
|
||||
/**
|
||||
This annotation is added to transactions that are produced by
|
||||
picking a completion.
|
||||
*/
|
||||
declare const pickedCompletion: _codemirror_state.AnnotationType<Completion>;
|
||||
/**
|
||||
Helper function that returns a transaction spec which inserts a
|
||||
completion's text in the main selection range, and any other
|
||||
selection range that has the same text in front of it.
|
||||
*/
|
||||
declare function insertCompletionText(state: EditorState, text: string, from: number, to: number): TransactionSpec;
|
||||
|
||||
interface CompletionConfig {
|
||||
/**
|
||||
When enabled (defaults to true), autocompletion will start
|
||||
whenever the user types something that can be completed.
|
||||
*/
|
||||
activateOnTyping?: boolean;
|
||||
/**
|
||||
By default, when completion opens, the first option is selected
|
||||
and can be confirmed with
|
||||
[`acceptCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.acceptCompletion). When this
|
||||
is set to false, the completion widget starts with no completion
|
||||
selected, and the user has to explicitly move to a completion
|
||||
before you can confirm one.
|
||||
*/
|
||||
selectOnOpen?: boolean;
|
||||
/**
|
||||
Override the completion sources used. By default, they will be
|
||||
taken from the `"autocomplete"` [language
|
||||
data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt) (which should hold
|
||||
[completion sources](https://codemirror.net/6/docs/ref/#autocomplete.CompletionSource) or arrays
|
||||
of [completions](https://codemirror.net/6/docs/ref/#autocomplete.Completion)).
|
||||
*/
|
||||
override?: readonly CompletionSource[] | null;
|
||||
/**
|
||||
Determines whether the completion tooltip is closed when the
|
||||
editor loses focus. Defaults to true.
|
||||
*/
|
||||
closeOnBlur?: boolean;
|
||||
/**
|
||||
The maximum number of options to render to the DOM.
|
||||
*/
|
||||
maxRenderedOptions?: number;
|
||||
/**
|
||||
Set this to false to disable the [default completion
|
||||
keymap](https://codemirror.net/6/docs/ref/#autocomplete.completionKeymap). (This requires you to
|
||||
add bindings to control completion yourself. The bindings should
|
||||
probably have a higher precedence than other bindings for the
|
||||
same keys.)
|
||||
*/
|
||||
defaultKeymap?: boolean;
|
||||
/**
|
||||
By default, completions are shown below the cursor when there is
|
||||
space. Setting this to true will make the extension put the
|
||||
completions above the cursor when possible.
|
||||
*/
|
||||
aboveCursor?: boolean;
|
||||
/**
|
||||
When given, this may return an additional CSS class to add to
|
||||
the completion dialog element.
|
||||
*/
|
||||
tooltipClass?: (state: EditorState) => string;
|
||||
/**
|
||||
This can be used to add additional CSS classes to completion
|
||||
options.
|
||||
*/
|
||||
optionClass?: (completion: Completion) => string;
|
||||
/**
|
||||
By default, the library will render icons based on the
|
||||
completion's [type](https://codemirror.net/6/docs/ref/#autocomplete.Completion.type) in front of
|
||||
each option. Set this to false to turn that off.
|
||||
*/
|
||||
icons?: boolean;
|
||||
/**
|
||||
This option can be used to inject additional content into
|
||||
options. The `render` function will be called for each visible
|
||||
completion, and should produce a DOM node to show. `position`
|
||||
determines where in the DOM the result appears, relative to
|
||||
other added widgets and the standard content. The default icons
|
||||
have position 20, the label position 50, and the detail position
|
||||
80.
|
||||
*/
|
||||
addToOptions?: {
|
||||
render: (completion: Completion, state: EditorState) => Node | null;
|
||||
position: number;
|
||||
}[];
|
||||
/**
|
||||
By default, [info](https://codemirror.net/6/docs/ref/#autocomplet.Completion.info) tooltips are
|
||||
placed to the side of the selected. This option can be used to
|
||||
override that. It will be given rectangles for the list of
|
||||
completions, the selected option, the info element, and the
|
||||
availble [tooltip space](https://codemirror.net/6/docs/ref/#view.tooltips^config.tooltipSpace),
|
||||
and should return style and/or class strings for the info
|
||||
element.
|
||||
*/
|
||||
positionInfo?: (view: EditorView, list: Rect, option: Rect, info: Rect, space: Rect) => {
|
||||
style?: string;
|
||||
class?: string;
|
||||
};
|
||||
/**
|
||||
The comparison function to use when sorting completions with the same
|
||||
match score. Defaults to using
|
||||
[`localeCompare`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/localeCompare).
|
||||
*/
|
||||
compareCompletions?: (a: Completion, b: Completion) => number;
|
||||
/**
|
||||
By default, commands relating to an open completion only take
|
||||
effect 75 milliseconds after the completion opened, so that key
|
||||
presses made before the user is aware of the tooltip don't go to
|
||||
the tooltip. This option can be used to configure that delay.
|
||||
*/
|
||||
interactionDelay?: number;
|
||||
}
|
||||
|
||||
/**
|
||||
Convert a snippet template to a function that can
|
||||
[apply](https://codemirror.net/6/docs/ref/#autocomplete.Completion.apply) it. Snippets are written
|
||||
using syntax like this:
|
||||
|
||||
"for (let ${index} = 0; ${index} < ${end}; ${index}++) {\n\t${}\n}"
|
||||
|
||||
Each `${}` placeholder (you may also use `#{}`) indicates a field
|
||||
that the user can fill in. Its name, if any, will be the default
|
||||
content for the field.
|
||||
|
||||
When the snippet is activated by calling the returned function,
|
||||
the code is inserted at the given position. Newlines in the
|
||||
template are indented by the indentation of the start line, plus
|
||||
one [indent unit](https://codemirror.net/6/docs/ref/#language.indentUnit) per tab character after
|
||||
the newline.
|
||||
|
||||
On activation, (all instances of) the first field are selected.
|
||||
The user can move between fields with Tab and Shift-Tab as long as
|
||||
the fields are active. Moving to the last field or moving the
|
||||
cursor out of the current field deactivates the fields.
|
||||
|
||||
The order of fields defaults to textual order, but you can add
|
||||
numbers to placeholders (`${1}` or `${1:defaultText}`) to provide
|
||||
a custom order.
|
||||
|
||||
To include a literal `{` or `}` in your template, put a backslash
|
||||
in front of it. This will be removed and the brace will not be
|
||||
interpreted as indicating a placeholder.
|
||||
*/
|
||||
declare function snippet(template: string): (editor: {
|
||||
state: EditorState;
|
||||
dispatch: (tr: Transaction) => void;
|
||||
}, completion: Completion | null, from: number, to: number) => void;
|
||||
/**
|
||||
A command that clears the active snippet, if any.
|
||||
*/
|
||||
declare const clearSnippet: StateCommand;
|
||||
/**
|
||||
Move to the next snippet field, if available.
|
||||
*/
|
||||
declare const nextSnippetField: StateCommand;
|
||||
/**
|
||||
Move to the previous snippet field, if available.
|
||||
*/
|
||||
declare const prevSnippetField: StateCommand;
|
||||
/**
|
||||
Check if there is an active snippet with a next field for
|
||||
`nextSnippetField` to move to.
|
||||
*/
|
||||
declare function hasNextSnippetField(state: EditorState): boolean;
|
||||
/**
|
||||
Returns true if there is an active snippet and a previous field
|
||||
for `prevSnippetField` to move to.
|
||||
*/
|
||||
declare function hasPrevSnippetField(state: EditorState): boolean;
|
||||
/**
|
||||
A facet that can be used to configure the key bindings used by
|
||||
snippets. The default binds Tab to
|
||||
[`nextSnippetField`](https://codemirror.net/6/docs/ref/#autocomplete.nextSnippetField), Shift-Tab to
|
||||
[`prevSnippetField`](https://codemirror.net/6/docs/ref/#autocomplete.prevSnippetField), and Escape
|
||||
to [`clearSnippet`](https://codemirror.net/6/docs/ref/#autocomplete.clearSnippet).
|
||||
*/
|
||||
declare const snippetKeymap: Facet<readonly KeyBinding[], readonly KeyBinding[]>;
|
||||
/**
|
||||
Create a completion from a snippet. Returns an object with the
|
||||
properties from `completion`, plus an `apply` function that
|
||||
applies the snippet.
|
||||
*/
|
||||
declare function snippetCompletion(template: string, completion: Completion): Completion;
|
||||
|
||||
/**
|
||||
Returns a command that moves the completion selection forward or
|
||||
backward by the given amount.
|
||||
*/
|
||||
declare function moveCompletionSelection(forward: boolean, by?: "option" | "page"): Command;
|
||||
/**
|
||||
Accept the current completion.
|
||||
*/
|
||||
declare const acceptCompletion: Command;
|
||||
/**
|
||||
Explicitly start autocompletion.
|
||||
*/
|
||||
declare const startCompletion: Command;
|
||||
/**
|
||||
Close the currently active completion.
|
||||
*/
|
||||
declare const closeCompletion: Command;
|
||||
|
||||
/**
|
||||
A completion source that will scan the document for words (using a
|
||||
[character categorizer](https://codemirror.net/6/docs/ref/#state.EditorState.charCategorizer)), and
|
||||
return those as completions.
|
||||
*/
|
||||
declare const completeAnyWord: CompletionSource;
|
||||
|
||||
/**
|
||||
Configures bracket closing behavior for a syntax (via
|
||||
[language data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt)) using the `"closeBrackets"`
|
||||
identifier.
|
||||
*/
|
||||
interface CloseBracketConfig {
|
||||
/**
|
||||
The opening brackets to close. Defaults to `["(", "[", "{", "'",
|
||||
'"']`. Brackets may be single characters or a triple of quotes
|
||||
(as in `"''''"`).
|
||||
*/
|
||||
brackets?: string[];
|
||||
/**
|
||||
Characters in front of which newly opened brackets are
|
||||
automatically closed. Closing always happens in front of
|
||||
whitespace. Defaults to `")]}:;>"`.
|
||||
*/
|
||||
before?: string;
|
||||
/**
|
||||
When determining whether a given node may be a string, recognize
|
||||
these prefixes before the opening quote.
|
||||
*/
|
||||
stringPrefixes?: string[];
|
||||
}
|
||||
/**
|
||||
Extension to enable bracket-closing behavior. When a closeable
|
||||
bracket is typed, its closing bracket is immediately inserted
|
||||
after the cursor. When closing a bracket directly in front of a
|
||||
closing bracket inserted by the extension, the cursor moves over
|
||||
that bracket.
|
||||
*/
|
||||
declare function closeBrackets(): Extension;
|
||||
/**
|
||||
Command that implements deleting a pair of matching brackets when
|
||||
the cursor is between them.
|
||||
*/
|
||||
declare const deleteBracketPair: StateCommand;
|
||||
/**
|
||||
Close-brackets related key bindings. Binds Backspace to
|
||||
[`deleteBracketPair`](https://codemirror.net/6/docs/ref/#autocomplete.deleteBracketPair).
|
||||
*/
|
||||
declare const closeBracketsKeymap: readonly KeyBinding[];
|
||||
/**
|
||||
Implements the extension's behavior on text insertion. If the
|
||||
given string counts as a bracket in the language around the
|
||||
selection, and replacing the selection with it requires custom
|
||||
behavior (inserting a closing version or skipping past a
|
||||
previously-closed bracket), this function returns a transaction
|
||||
representing that custom behavior. (You only need this if you want
|
||||
to programmatically insert brackets—the
|
||||
[`closeBrackets`](https://codemirror.net/6/docs/ref/#autocomplete.closeBrackets) extension will
|
||||
take care of running this for user input.)
|
||||
*/
|
||||
declare function insertBracket(state: EditorState, bracket: string): Transaction | null;
|
||||
|
||||
/**
|
||||
Returns an extension that enables autocompletion.
|
||||
*/
|
||||
declare function autocompletion(config?: CompletionConfig): Extension;
|
||||
/**
|
||||
Basic keybindings for autocompletion.
|
||||
|
||||
- Ctrl-Space: [`startCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.startCompletion)
|
||||
- Escape: [`closeCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.closeCompletion)
|
||||
- ArrowDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true)`
|
||||
- ArrowUp: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(false)`
|
||||
- PageDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true, "page")`
|
||||
- PageDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true, "page")`
|
||||
- Enter: [`acceptCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.acceptCompletion)
|
||||
*/
|
||||
declare const completionKeymap: readonly KeyBinding[];
|
||||
/**
|
||||
Get the current completion status. When completions are available,
|
||||
this will return `"active"`. When completions are pending (in the
|
||||
process of being queried), this returns `"pending"`. Otherwise, it
|
||||
returns `null`.
|
||||
*/
|
||||
declare function completionStatus(state: EditorState): null | "active" | "pending";
|
||||
/**
|
||||
Returns the available completions as an array.
|
||||
*/
|
||||
declare function currentCompletions(state: EditorState): readonly Completion[];
|
||||
/**
|
||||
Return the currently selected completion, if any.
|
||||
*/
|
||||
declare function selectedCompletion(state: EditorState): Completion | null;
|
||||
/**
|
||||
Returns the currently selected position in the active completion
|
||||
list, or null if no completions are active.
|
||||
*/
|
||||
declare function selectedCompletionIndex(state: EditorState): number | null;
|
||||
/**
|
||||
Create an effect that can be attached to a transaction to change
|
||||
the currently selected completion.
|
||||
*/
|
||||
declare function setSelectedCompletion(index: number): StateEffect<unknown>;
|
||||
|
||||
export { CloseBracketConfig, Completion, CompletionContext, CompletionInfo, CompletionResult, CompletionSection, CompletionSource, acceptCompletion, autocompletion, clearSnippet, closeBrackets, closeBracketsKeymap, closeCompletion, completeAnyWord, completeFromList, completionKeymap, completionStatus, currentCompletions, deleteBracketPair, hasNextSnippetField, hasPrevSnippetField, ifIn, ifNotIn, insertBracket, insertCompletionText, moveCompletionSelection, nextSnippetField, pickedCompletion, prevSnippetField, selectedCompletion, selectedCompletionIndex, setSelectedCompletion, snippet, snippetCompletion, snippetKeymap, startCompletion };
|
||||
567
node_modules/@codemirror/autocomplete/dist/index.d.ts
generated
vendored
Normal file
567
node_modules/@codemirror/autocomplete/dist/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,567 @@
|
||||
import * as _codemirror_state from '@codemirror/state';
|
||||
import { EditorState, TransactionSpec, Transaction, StateCommand, Facet, Extension, StateEffect } from '@codemirror/state';
|
||||
import { EditorView, Rect, KeyBinding, Command } from '@codemirror/view';
|
||||
import * as _lezer_common from '@lezer/common';
|
||||
|
||||
/**
|
||||
Objects type used to represent individual completions.
|
||||
*/
|
||||
interface Completion {
|
||||
/**
|
||||
The label to show in the completion picker. This is what input
|
||||
is matched agains to determine whether a completion matches (and
|
||||
how well it matches).
|
||||
*/
|
||||
label: string;
|
||||
/**
|
||||
An optional override for the completion's visible label. When
|
||||
using this, matched characters will only be highlighted if you
|
||||
provide a [`getMatch`](https://codemirror.net/6/docs/ref/#autocomplete.CompletionResult.getMatch)
|
||||
function.
|
||||
*/
|
||||
displayLabel?: string;
|
||||
/**
|
||||
An optional short piece of information to show (with a different
|
||||
style) after the label.
|
||||
*/
|
||||
detail?: string;
|
||||
/**
|
||||
Additional info to show when the completion is selected. Can be
|
||||
a plain string or a function that'll render the DOM structure to
|
||||
show when invoked.
|
||||
*/
|
||||
info?: string | ((completion: Completion) => CompletionInfo | Promise<CompletionInfo>);
|
||||
/**
|
||||
How to apply the completion. The default is to replace it with
|
||||
its [label](https://codemirror.net/6/docs/ref/#autocomplete.Completion.label). When this holds a
|
||||
string, the completion range is replaced by that string. When it
|
||||
is a function, that function is called to perform the
|
||||
completion. If it fires a transaction, it is responsible for
|
||||
adding the [`pickedCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.pickedCompletion)
|
||||
annotation to it.
|
||||
*/
|
||||
apply?: string | ((view: EditorView, completion: Completion, from: number, to: number) => void);
|
||||
/**
|
||||
The type of the completion. This is used to pick an icon to show
|
||||
for the completion. Icons are styled with a CSS class created by
|
||||
appending the type name to `"cm-completionIcon-"`. You can
|
||||
define or restyle icons by defining these selectors. The base
|
||||
library defines simple icons for `class`, `constant`, `enum`,
|
||||
`function`, `interface`, `keyword`, `method`, `namespace`,
|
||||
`property`, `text`, `type`, and `variable`.
|
||||
|
||||
Multiple types can be provided by separating them with spaces.
|
||||
*/
|
||||
type?: string;
|
||||
/**
|
||||
When given, should be a number from -99 to 99 that adjusts how
|
||||
this completion is ranked compared to other completions that
|
||||
match the input as well as this one. A negative number moves it
|
||||
down the list, a positive number moves it up.
|
||||
*/
|
||||
boost?: number;
|
||||
/**
|
||||
Can be used to divide the completion list into sections.
|
||||
Completions in a given section (matched by name) will be grouped
|
||||
together, with a heading above them. Options without section
|
||||
will appear above all sections. A string value is equivalent to
|
||||
a `{name}` object.
|
||||
*/
|
||||
section?: string | CompletionSection;
|
||||
}
|
||||
/**
|
||||
The type returned from
|
||||
[`Completion.info`](https://codemirror.net/6/docs/ref/#autocomplete.Completion.info). May be a DOM
|
||||
node, null to indicate there is no info, or an object with an
|
||||
optional `destroy` method that cleans up the node.
|
||||
*/
|
||||
declare type CompletionInfo = Node | null | {
|
||||
dom: Node;
|
||||
destroy?(): void;
|
||||
};
|
||||
/**
|
||||
Object used to describe a completion
|
||||
[section](https://codemirror.net/6/docs/ref/#autocomplete.Completion.section). It is recommended to
|
||||
create a shared object used by all the completions in a given
|
||||
section.
|
||||
*/
|
||||
interface CompletionSection {
|
||||
/**
|
||||
The name of the section. If no `render` method is present, this
|
||||
will be displayed above the options.
|
||||
*/
|
||||
name: string;
|
||||
/**
|
||||
An optional function that renders the section header. Since the
|
||||
headers are shown inside a list, you should make sure the
|
||||
resulting element has a `display: list-item` style.
|
||||
*/
|
||||
header?: (section: CompletionSection) => HTMLElement;
|
||||
/**
|
||||
By default, sections are ordered alphabetically by name. To
|
||||
specify an explicit order, `rank` can be used. Sections with a
|
||||
lower rank will be shown above sections with a higher rank.
|
||||
*/
|
||||
rank?: number;
|
||||
}
|
||||
/**
|
||||
An instance of this is passed to completion source functions.
|
||||
*/
|
||||
declare class CompletionContext {
|
||||
/**
|
||||
The editor state that the completion happens in.
|
||||
*/
|
||||
readonly state: EditorState;
|
||||
/**
|
||||
The position at which the completion is happening.
|
||||
*/
|
||||
readonly pos: number;
|
||||
/**
|
||||
Indicates whether completion was activated explicitly, or
|
||||
implicitly by typing. The usual way to respond to this is to
|
||||
only return completions when either there is part of a
|
||||
completable entity before the cursor, or `explicit` is true.
|
||||
*/
|
||||
readonly explicit: boolean;
|
||||
/**
|
||||
Create a new completion context. (Mostly useful for testing
|
||||
completion sources—in the editor, the extension will create
|
||||
these for you.)
|
||||
*/
|
||||
constructor(
|
||||
/**
|
||||
The editor state that the completion happens in.
|
||||
*/
|
||||
state: EditorState,
|
||||
/**
|
||||
The position at which the completion is happening.
|
||||
*/
|
||||
pos: number,
|
||||
/**
|
||||
Indicates whether completion was activated explicitly, or
|
||||
implicitly by typing. The usual way to respond to this is to
|
||||
only return completions when either there is part of a
|
||||
completable entity before the cursor, or `explicit` is true.
|
||||
*/
|
||||
explicit: boolean);
|
||||
/**
|
||||
Get the extent, content, and (if there is a token) type of the
|
||||
token before `this.pos`.
|
||||
*/
|
||||
tokenBefore(types: readonly string[]): {
|
||||
from: number;
|
||||
to: number;
|
||||
text: string;
|
||||
type: _lezer_common.NodeType;
|
||||
} | null;
|
||||
/**
|
||||
Get the match of the given expression directly before the
|
||||
cursor.
|
||||
*/
|
||||
matchBefore(expr: RegExp): {
|
||||
from: number;
|
||||
to: number;
|
||||
text: string;
|
||||
} | null;
|
||||
/**
|
||||
Yields true when the query has been aborted. Can be useful in
|
||||
asynchronous queries to avoid doing work that will be ignored.
|
||||
*/
|
||||
get aborted(): boolean;
|
||||
/**
|
||||
Allows you to register abort handlers, which will be called when
|
||||
the query is
|
||||
[aborted](https://codemirror.net/6/docs/ref/#autocomplete.CompletionContext.aborted).
|
||||
*/
|
||||
addEventListener(type: "abort", listener: () => void): void;
|
||||
}
|
||||
/**
|
||||
Given a a fixed array of options, return an autocompleter that
|
||||
completes them.
|
||||
*/
|
||||
declare function completeFromList(list: readonly (string | Completion)[]): CompletionSource;
|
||||
/**
|
||||
Wrap the given completion source so that it will only fire when the
|
||||
cursor is in a syntax node with one of the given names.
|
||||
*/
|
||||
declare function ifIn(nodes: readonly string[], source: CompletionSource): CompletionSource;
|
||||
/**
|
||||
Wrap the given completion source so that it will not fire when the
|
||||
cursor is in a syntax node with one of the given names.
|
||||
*/
|
||||
declare function ifNotIn(nodes: readonly string[], source: CompletionSource): CompletionSource;
|
||||
/**
|
||||
The function signature for a completion source. Such a function
|
||||
may return its [result](https://codemirror.net/6/docs/ref/#autocomplete.CompletionResult)
|
||||
synchronously or as a promise. Returning null indicates no
|
||||
completions are available.
|
||||
*/
|
||||
declare type CompletionSource = (context: CompletionContext) => CompletionResult | null | Promise<CompletionResult | null>;
|
||||
/**
|
||||
Interface for objects returned by completion sources.
|
||||
*/
|
||||
interface CompletionResult {
|
||||
/**
|
||||
The start of the range that is being completed.
|
||||
*/
|
||||
from: number;
|
||||
/**
|
||||
The end of the range that is being completed. Defaults to the
|
||||
main cursor position.
|
||||
*/
|
||||
to?: number;
|
||||
/**
|
||||
The completions returned. These don't have to be compared with
|
||||
the input by the source—the autocompletion system will do its
|
||||
own matching (against the text between `from` and `to`) and
|
||||
sorting.
|
||||
*/
|
||||
options: readonly Completion[];
|
||||
/**
|
||||
When given, further typing or deletion that causes the part of
|
||||
the document between ([mapped](https://codemirror.net/6/docs/ref/#state.ChangeDesc.mapPos)) `from`
|
||||
and `to` to match this regular expression or predicate function
|
||||
will not query the completion source again, but continue with
|
||||
this list of options. This can help a lot with responsiveness,
|
||||
since it allows the completion list to be updated synchronously.
|
||||
*/
|
||||
validFor?: RegExp | ((text: string, from: number, to: number, state: EditorState) => boolean);
|
||||
/**
|
||||
By default, the library filters and scores completions. Set
|
||||
`filter` to `false` to disable this, and cause your completions
|
||||
to all be included, in the order they were given. When there are
|
||||
other sources, unfiltered completions appear at the top of the
|
||||
list of completions. `validFor` must not be given when `filter`
|
||||
is `false`, because it only works when filtering.
|
||||
*/
|
||||
filter?: boolean;
|
||||
/**
|
||||
When [`filter`](https://codemirror.net/6/docs/ref/#autocomplete.CompletionResult.filter) is set to
|
||||
`false` or a completion has a
|
||||
[`displayLabel`](https://codemirror.net/6/docs/ref/#autocomplete.Completion.displayLabel), this
|
||||
may be provided to compute the ranges on the label that match
|
||||
the input. Should return an array of numbers where each pair of
|
||||
adjacent numbers provide the start and end of a range. The
|
||||
second argument, the match found by the library, is only passed
|
||||
when `filter` isn't `false`.
|
||||
*/
|
||||
getMatch?: (completion: Completion, matched?: readonly number[]) => readonly number[];
|
||||
/**
|
||||
Synchronously update the completion result after typing or
|
||||
deletion. If given, this should not do any expensive work, since
|
||||
it will be called during editor state updates. The function
|
||||
should make sure (similar to
|
||||
[`validFor`](https://codemirror.net/6/docs/ref/#autocomplete.CompletionResult.validFor)) that the
|
||||
completion still applies in the new state.
|
||||
*/
|
||||
update?: (current: CompletionResult, from: number, to: number, context: CompletionContext) => CompletionResult | null;
|
||||
}
|
||||
/**
|
||||
This annotation is added to transactions that are produced by
|
||||
picking a completion.
|
||||
*/
|
||||
declare const pickedCompletion: _codemirror_state.AnnotationType<Completion>;
|
||||
/**
|
||||
Helper function that returns a transaction spec which inserts a
|
||||
completion's text in the main selection range, and any other
|
||||
selection range that has the same text in front of it.
|
||||
*/
|
||||
declare function insertCompletionText(state: EditorState, text: string, from: number, to: number): TransactionSpec;
|
||||
|
||||
interface CompletionConfig {
|
||||
/**
|
||||
When enabled (defaults to true), autocompletion will start
|
||||
whenever the user types something that can be completed.
|
||||
*/
|
||||
activateOnTyping?: boolean;
|
||||
/**
|
||||
By default, when completion opens, the first option is selected
|
||||
and can be confirmed with
|
||||
[`acceptCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.acceptCompletion). When this
|
||||
is set to false, the completion widget starts with no completion
|
||||
selected, and the user has to explicitly move to a completion
|
||||
before you can confirm one.
|
||||
*/
|
||||
selectOnOpen?: boolean;
|
||||
/**
|
||||
Override the completion sources used. By default, they will be
|
||||
taken from the `"autocomplete"` [language
|
||||
data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt) (which should hold
|
||||
[completion sources](https://codemirror.net/6/docs/ref/#autocomplete.CompletionSource) or arrays
|
||||
of [completions](https://codemirror.net/6/docs/ref/#autocomplete.Completion)).
|
||||
*/
|
||||
override?: readonly CompletionSource[] | null;
|
||||
/**
|
||||
Determines whether the completion tooltip is closed when the
|
||||
editor loses focus. Defaults to true.
|
||||
*/
|
||||
closeOnBlur?: boolean;
|
||||
/**
|
||||
The maximum number of options to render to the DOM.
|
||||
*/
|
||||
maxRenderedOptions?: number;
|
||||
/**
|
||||
Set this to false to disable the [default completion
|
||||
keymap](https://codemirror.net/6/docs/ref/#autocomplete.completionKeymap). (This requires you to
|
||||
add bindings to control completion yourself. The bindings should
|
||||
probably have a higher precedence than other bindings for the
|
||||
same keys.)
|
||||
*/
|
||||
defaultKeymap?: boolean;
|
||||
/**
|
||||
By default, completions are shown below the cursor when there is
|
||||
space. Setting this to true will make the extension put the
|
||||
completions above the cursor when possible.
|
||||
*/
|
||||
aboveCursor?: boolean;
|
||||
/**
|
||||
When given, this may return an additional CSS class to add to
|
||||
the completion dialog element.
|
||||
*/
|
||||
tooltipClass?: (state: EditorState) => string;
|
||||
/**
|
||||
This can be used to add additional CSS classes to completion
|
||||
options.
|
||||
*/
|
||||
optionClass?: (completion: Completion) => string;
|
||||
/**
|
||||
By default, the library will render icons based on the
|
||||
completion's [type](https://codemirror.net/6/docs/ref/#autocomplete.Completion.type) in front of
|
||||
each option. Set this to false to turn that off.
|
||||
*/
|
||||
icons?: boolean;
|
||||
/**
|
||||
This option can be used to inject additional content into
|
||||
options. The `render` function will be called for each visible
|
||||
completion, and should produce a DOM node to show. `position`
|
||||
determines where in the DOM the result appears, relative to
|
||||
other added widgets and the standard content. The default icons
|
||||
have position 20, the label position 50, and the detail position
|
||||
80.
|
||||
*/
|
||||
addToOptions?: {
|
||||
render: (completion: Completion, state: EditorState) => Node | null;
|
||||
position: number;
|
||||
}[];
|
||||
/**
|
||||
By default, [info](https://codemirror.net/6/docs/ref/#autocomplet.Completion.info) tooltips are
|
||||
placed to the side of the selected. This option can be used to
|
||||
override that. It will be given rectangles for the list of
|
||||
completions, the selected option, the info element, and the
|
||||
availble [tooltip space](https://codemirror.net/6/docs/ref/#view.tooltips^config.tooltipSpace),
|
||||
and should return style and/or class strings for the info
|
||||
element.
|
||||
*/
|
||||
positionInfo?: (view: EditorView, list: Rect, option: Rect, info: Rect, space: Rect) => {
|
||||
style?: string;
|
||||
class?: string;
|
||||
};
|
||||
/**
|
||||
The comparison function to use when sorting completions with the same
|
||||
match score. Defaults to using
|
||||
[`localeCompare`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/localeCompare).
|
||||
*/
|
||||
compareCompletions?: (a: Completion, b: Completion) => number;
|
||||
/**
|
||||
By default, commands relating to an open completion only take
|
||||
effect 75 milliseconds after the completion opened, so that key
|
||||
presses made before the user is aware of the tooltip don't go to
|
||||
the tooltip. This option can be used to configure that delay.
|
||||
*/
|
||||
interactionDelay?: number;
|
||||
}
|
||||
|
||||
/**
|
||||
Convert a snippet template to a function that can
|
||||
[apply](https://codemirror.net/6/docs/ref/#autocomplete.Completion.apply) it. Snippets are written
|
||||
using syntax like this:
|
||||
|
||||
"for (let ${index} = 0; ${index} < ${end}; ${index}++) {\n\t${}\n}"
|
||||
|
||||
Each `${}` placeholder (you may also use `#{}`) indicates a field
|
||||
that the user can fill in. Its name, if any, will be the default
|
||||
content for the field.
|
||||
|
||||
When the snippet is activated by calling the returned function,
|
||||
the code is inserted at the given position. Newlines in the
|
||||
template are indented by the indentation of the start line, plus
|
||||
one [indent unit](https://codemirror.net/6/docs/ref/#language.indentUnit) per tab character after
|
||||
the newline.
|
||||
|
||||
On activation, (all instances of) the first field are selected.
|
||||
The user can move between fields with Tab and Shift-Tab as long as
|
||||
the fields are active. Moving to the last field or moving the
|
||||
cursor out of the current field deactivates the fields.
|
||||
|
||||
The order of fields defaults to textual order, but you can add
|
||||
numbers to placeholders (`${1}` or `${1:defaultText}`) to provide
|
||||
a custom order.
|
||||
|
||||
To include a literal `{` or `}` in your template, put a backslash
|
||||
in front of it. This will be removed and the brace will not be
|
||||
interpreted as indicating a placeholder.
|
||||
*/
|
||||
declare function snippet(template: string): (editor: {
|
||||
state: EditorState;
|
||||
dispatch: (tr: Transaction) => void;
|
||||
}, completion: Completion | null, from: number, to: number) => void;
|
||||
/**
|
||||
A command that clears the active snippet, if any.
|
||||
*/
|
||||
declare const clearSnippet: StateCommand;
|
||||
/**
|
||||
Move to the next snippet field, if available.
|
||||
*/
|
||||
declare const nextSnippetField: StateCommand;
|
||||
/**
|
||||
Move to the previous snippet field, if available.
|
||||
*/
|
||||
declare const prevSnippetField: StateCommand;
|
||||
/**
|
||||
Check if there is an active snippet with a next field for
|
||||
`nextSnippetField` to move to.
|
||||
*/
|
||||
declare function hasNextSnippetField(state: EditorState): boolean;
|
||||
/**
|
||||
Returns true if there is an active snippet and a previous field
|
||||
for `prevSnippetField` to move to.
|
||||
*/
|
||||
declare function hasPrevSnippetField(state: EditorState): boolean;
|
||||
/**
|
||||
A facet that can be used to configure the key bindings used by
|
||||
snippets. The default binds Tab to
|
||||
[`nextSnippetField`](https://codemirror.net/6/docs/ref/#autocomplete.nextSnippetField), Shift-Tab to
|
||||
[`prevSnippetField`](https://codemirror.net/6/docs/ref/#autocomplete.prevSnippetField), and Escape
|
||||
to [`clearSnippet`](https://codemirror.net/6/docs/ref/#autocomplete.clearSnippet).
|
||||
*/
|
||||
declare const snippetKeymap: Facet<readonly KeyBinding[], readonly KeyBinding[]>;
|
||||
/**
|
||||
Create a completion from a snippet. Returns an object with the
|
||||
properties from `completion`, plus an `apply` function that
|
||||
applies the snippet.
|
||||
*/
|
||||
declare function snippetCompletion(template: string, completion: Completion): Completion;
|
||||
|
||||
/**
|
||||
Returns a command that moves the completion selection forward or
|
||||
backward by the given amount.
|
||||
*/
|
||||
declare function moveCompletionSelection(forward: boolean, by?: "option" | "page"): Command;
|
||||
/**
|
||||
Accept the current completion.
|
||||
*/
|
||||
declare const acceptCompletion: Command;
|
||||
/**
|
||||
Explicitly start autocompletion.
|
||||
*/
|
||||
declare const startCompletion: Command;
|
||||
/**
|
||||
Close the currently active completion.
|
||||
*/
|
||||
declare const closeCompletion: Command;
|
||||
|
||||
/**
|
||||
A completion source that will scan the document for words (using a
|
||||
[character categorizer](https://codemirror.net/6/docs/ref/#state.EditorState.charCategorizer)), and
|
||||
return those as completions.
|
||||
*/
|
||||
declare const completeAnyWord: CompletionSource;
|
||||
|
||||
/**
|
||||
Configures bracket closing behavior for a syntax (via
|
||||
[language data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt)) using the `"closeBrackets"`
|
||||
identifier.
|
||||
*/
|
||||
interface CloseBracketConfig {
|
||||
/**
|
||||
The opening brackets to close. Defaults to `["(", "[", "{", "'",
|
||||
'"']`. Brackets may be single characters or a triple of quotes
|
||||
(as in `"''''"`).
|
||||
*/
|
||||
brackets?: string[];
|
||||
/**
|
||||
Characters in front of which newly opened brackets are
|
||||
automatically closed. Closing always happens in front of
|
||||
whitespace. Defaults to `")]}:;>"`.
|
||||
*/
|
||||
before?: string;
|
||||
/**
|
||||
When determining whether a given node may be a string, recognize
|
||||
these prefixes before the opening quote.
|
||||
*/
|
||||
stringPrefixes?: string[];
|
||||
}
|
||||
/**
|
||||
Extension to enable bracket-closing behavior. When a closeable
|
||||
bracket is typed, its closing bracket is immediately inserted
|
||||
after the cursor. When closing a bracket directly in front of a
|
||||
closing bracket inserted by the extension, the cursor moves over
|
||||
that bracket.
|
||||
*/
|
||||
declare function closeBrackets(): Extension;
|
||||
/**
|
||||
Command that implements deleting a pair of matching brackets when
|
||||
the cursor is between them.
|
||||
*/
|
||||
declare const deleteBracketPair: StateCommand;
|
||||
/**
|
||||
Close-brackets related key bindings. Binds Backspace to
|
||||
[`deleteBracketPair`](https://codemirror.net/6/docs/ref/#autocomplete.deleteBracketPair).
|
||||
*/
|
||||
declare const closeBracketsKeymap: readonly KeyBinding[];
|
||||
/**
|
||||
Implements the extension's behavior on text insertion. If the
|
||||
given string counts as a bracket in the language around the
|
||||
selection, and replacing the selection with it requires custom
|
||||
behavior (inserting a closing version or skipping past a
|
||||
previously-closed bracket), this function returns a transaction
|
||||
representing that custom behavior. (You only need this if you want
|
||||
to programmatically insert brackets—the
|
||||
[`closeBrackets`](https://codemirror.net/6/docs/ref/#autocomplete.closeBrackets) extension will
|
||||
take care of running this for user input.)
|
||||
*/
|
||||
declare function insertBracket(state: EditorState, bracket: string): Transaction | null;
|
||||
|
||||
/**
|
||||
Returns an extension that enables autocompletion.
|
||||
*/
|
||||
declare function autocompletion(config?: CompletionConfig): Extension;
|
||||
/**
|
||||
Basic keybindings for autocompletion.
|
||||
|
||||
- Ctrl-Space: [`startCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.startCompletion)
|
||||
- Escape: [`closeCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.closeCompletion)
|
||||
- ArrowDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true)`
|
||||
- ArrowUp: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(false)`
|
||||
- PageDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true, "page")`
|
||||
- PageDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true, "page")`
|
||||
- Enter: [`acceptCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.acceptCompletion)
|
||||
*/
|
||||
declare const completionKeymap: readonly KeyBinding[];
|
||||
/**
|
||||
Get the current completion status. When completions are available,
|
||||
this will return `"active"`. When completions are pending (in the
|
||||
process of being queried), this returns `"pending"`. Otherwise, it
|
||||
returns `null`.
|
||||
*/
|
||||
declare function completionStatus(state: EditorState): null | "active" | "pending";
|
||||
/**
|
||||
Returns the available completions as an array.
|
||||
*/
|
||||
declare function currentCompletions(state: EditorState): readonly Completion[];
|
||||
/**
|
||||
Return the currently selected completion, if any.
|
||||
*/
|
||||
declare function selectedCompletion(state: EditorState): Completion | null;
|
||||
/**
|
||||
Returns the currently selected position in the active completion
|
||||
list, or null if no completions are active.
|
||||
*/
|
||||
declare function selectedCompletionIndex(state: EditorState): number | null;
|
||||
/**
|
||||
Create an effect that can be attached to a transaction to change
|
||||
the currently selected completion.
|
||||
*/
|
||||
declare function setSelectedCompletion(index: number): StateEffect<unknown>;
|
||||
|
||||
export { CloseBracketConfig, Completion, CompletionContext, CompletionInfo, CompletionResult, CompletionSection, CompletionSource, acceptCompletion, autocompletion, clearSnippet, closeBrackets, closeBracketsKeymap, closeCompletion, completeAnyWord, completeFromList, completionKeymap, completionStatus, currentCompletions, deleteBracketPair, hasNextSnippetField, hasPrevSnippetField, ifIn, ifNotIn, insertBracket, insertCompletionText, moveCompletionSelection, nextSnippetField, pickedCompletion, prevSnippetField, selectedCompletion, selectedCompletionIndex, setSelectedCompletion, snippet, snippetCompletion, snippetKeymap, startCompletion };
|
||||
1963
node_modules/@codemirror/autocomplete/dist/index.js
generated
vendored
Normal file
1963
node_modules/@codemirror/autocomplete/dist/index.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
47
node_modules/@codemirror/autocomplete/package.json
generated
vendored
Normal file
47
node_modules/@codemirror/autocomplete/package.json
generated
vendored
Normal file
@ -0,0 +1,47 @@
|
||||
{
|
||||
"name": "@codemirror/autocomplete",
|
||||
"version": "6.9.0",
|
||||
"description": "Autocompletion for the CodeMirror code editor",
|
||||
"scripts": {
|
||||
"test": "cm-runtests",
|
||||
"prepare": "cm-buildhelper src/index.ts"
|
||||
},
|
||||
"keywords": [
|
||||
"editor",
|
||||
"code"
|
||||
],
|
||||
"author": {
|
||||
"name": "Marijn Haverbeke",
|
||||
"email": "marijn@haverbeke.berlin",
|
||||
"url": "http://marijnhaverbeke.nl"
|
||||
},
|
||||
"type": "module",
|
||||
"main": "dist/index.cjs",
|
||||
"exports": {
|
||||
"import": "./dist/index.js",
|
||||
"require": "./dist/index.cjs"
|
||||
},
|
||||
"types": "dist/index.d.ts",
|
||||
"module": "dist/index.js",
|
||||
"sideEffects": false,
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"@codemirror/language": "^6.0.0",
|
||||
"@codemirror/state": "^6.0.0",
|
||||
"@codemirror/view": "^6.6.0",
|
||||
"@lezer/common": "^1.0.0"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"@codemirror/language": "^6.0.0",
|
||||
"@codemirror/state": "^6.0.0",
|
||||
"@codemirror/view": "^6.0.0",
|
||||
"@lezer/common": "^1.0.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@codemirror/buildhelper": "^1.0.0"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/codemirror/autocomplete.git"
|
||||
}
|
||||
}
|
||||
16
node_modules/@codemirror/commands/.github/workflows/dispatch.yml
generated
vendored
Normal file
16
node_modules/@codemirror/commands/.github/workflows/dispatch.yml
generated
vendored
Normal file
@ -0,0 +1,16 @@
|
||||
name: Trigger CI
|
||||
on: push
|
||||
|
||||
jobs:
|
||||
build:
|
||||
name: Dispatch to main repo
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Emit repository_dispatch
|
||||
uses: mvasigh/dispatch-action@main
|
||||
with:
|
||||
# You should create a personal access token and store it in your repository
|
||||
token: ${{ secrets.DISPATCH_AUTH }}
|
||||
repo: dev
|
||||
owner: codemirror
|
||||
event_type: push
|
||||
244
node_modules/@codemirror/commands/CHANGELOG.md
generated
vendored
Normal file
244
node_modules/@codemirror/commands/CHANGELOG.md
generated
vendored
Normal file
@ -0,0 +1,244 @@
|
||||
## 6.2.4 (2023-05-03)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
The by-subword motion commands now properly treat dashes, underscores, and similar as subword separators.
|
||||
|
||||
## 6.2.3 (2023-04-19)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Block commenting the selection no longer includes indentation on the first line.
|
||||
|
||||
## 6.2.2 (2023-03-10)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug where line commenting got confused when commenting a range that crossed language boundaries.
|
||||
|
||||
## 6.2.1 (2023-02-15)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Keep cursor position stable in `cursorPageUp`/`cursorPageDown` when there are panels or other scroll margins active.
|
||||
|
||||
Make sure `toggleComment` doesn't get thrown off by local language nesting, by fetching the language data for the start of the selection line.
|
||||
|
||||
## 6.2.0 (2023-01-18)
|
||||
|
||||
### New features
|
||||
|
||||
The new `joinToEvent` history configuration option allows you to provide custom logic that determines whether a new transaction is added to an existing history event.
|
||||
|
||||
## 6.1.3 (2022-12-26)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Preserve selection bidi level when extending the selection, to prevent shift-selection from getting stuck in some kinds of bidirectional text.
|
||||
|
||||
## 6.1.2 (2022-10-13)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that caused deletion commands on non-empty ranges to incorrectly return false and do nothing, causing the editor to fall back to native behavior.
|
||||
|
||||
## 6.1.1 (2022-09-28)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make sure the selection endpoints are moved out of atomic ranges when applying a deletion command to a non-empty selection.
|
||||
|
||||
## 6.1.0 (2022-08-18)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Prevent native behavior on Ctrl/Cmd-ArrowLeft/ArrowRight bindings, so that browsers with odd bidi behavior won't do the wrong thing at start/end of line.
|
||||
|
||||
Cmd-ArrowLeft/Right on macOS now moves the cursor in the direction of the arrow even in right-to-left content.
|
||||
|
||||
### New features
|
||||
|
||||
The new `cursorLineBoundaryLeft`/`Right` and `selectLineBoundaryLeft`/`Right` commands allow directional motion to line boundaries.
|
||||
|
||||
## 6.0.1 (2022-06-30)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Announce to the screen reader when the selection is deleted.
|
||||
|
||||
Also bind Ctrl-Shift-z to redo on Linux.
|
||||
|
||||
## 6.0.0 (2022-06-08)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug where by-page selection commands sometimes moved one line too far.
|
||||
|
||||
## 0.20.0 (2022-04-20)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
There is no longer a separate `commentKeymap`. Those bindings are now part of `defaultKeymap`.
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make `cursorPageUp` and `cursorPageDown` move by window height when the editor is higher than the window.
|
||||
|
||||
Make sure the default behavior of Home/End is prevented, since it could produce unexpected results on macOS.
|
||||
|
||||
### New features
|
||||
|
||||
The exports from @codemirror/comment are now available in this package.
|
||||
|
||||
The exports from the @codemirror/history package are now available from this package.
|
||||
|
||||
## 0.19.8 (2022-01-26)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
`deleteCharBackward` now removes extending characters one at a time, rather than deleting the entire glyph at once.
|
||||
|
||||
Alt-v is no longer bound in `emacsStyleKeymap` and macOS's `standardKeymap`, because macOS doesn't bind it by default and it conflicts with some keyboard layouts.
|
||||
|
||||
## 0.19.7 (2022-01-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Don't bind Alt-\< and Alt-> on macOS by default, since those interfere with some keyboard layouts. Make cursorPageUp/Down scroll the view to keep the cursor in place
|
||||
|
||||
`cursorPageUp` and `cursorPageDown` now scroll the view by the amount that the cursor moved.
|
||||
|
||||
## 0.19.6 (2021-12-10)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
The standard keymap no longer overrides Shift-Delete, in order to allow the native behavior of that key to happen on platforms that support it.
|
||||
|
||||
## 0.19.5 (2021-09-21)
|
||||
|
||||
### New features
|
||||
|
||||
Adds an `insertBlankLine` command which creates an empty line below the selection, and binds it to Mod-Enter in the default keymap.
|
||||
|
||||
## 0.19.4 (2021-09-13)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make commands that affect the editor's content check `state.readOnly` and return false when that is true.
|
||||
|
||||
## 0.19.3 (2021-09-09)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make by-line cursor motion commands move the cursor to the start/end of the document when they hit the first/last line.
|
||||
|
||||
Fix a bug where `deleteCharForward`/`Backward` behaved incorrectly when deleting directly before or after an atomic range.
|
||||
|
||||
## 0.19.2 (2021-08-24)
|
||||
|
||||
### New features
|
||||
|
||||
New commands `cursorSubwordForward`, `cursorSubwordBackward`, `selectSubwordForward`, and `selectSubwordBackward` which implement motion by camel case subword.
|
||||
|
||||
## 0.19.1 (2021-08-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix incorrect versions for @lezer dependencies.
|
||||
|
||||
## 0.19.0 (2021-08-11)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
Change default binding for backspace to `deleteCharBackward`, drop `deleteCodePointBackward`/`Forward` from the library.
|
||||
|
||||
`defaultTabBinding` was removed.
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Drop Alt-d, Alt-f, and Alt-b bindings from `emacsStyleKeymap` (and thus from the default macOS bindings).
|
||||
|
||||
`deleteCharBackward` and `deleteCharForward` now take atomic ranges into account.
|
||||
|
||||
### New features
|
||||
|
||||
Attach more granular user event strings to transactions.
|
||||
|
||||
The module exports a new binding `indentWithTab` that binds tab and shift-tab to `indentMore` and `indentLess`.
|
||||
|
||||
## 0.18.3 (2021-06-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
`moveLineDown` will no longer incorrectly grow the selection.
|
||||
|
||||
Line-based commands will no longer include lines where a range selection ends right at the start of the line.
|
||||
|
||||
## 0.18.2 (2021-05-06)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Use Ctrl-l, not Alt-l, to bind `selectLine` on macOS, to avoid conflicting with special-character-insertion bindings.
|
||||
|
||||
Make the macOS Command-ArrowLeft/Right commands behave more like their native versions.
|
||||
|
||||
## 0.18.1 (2021-04-08)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Also bind Shift-Backspace and Shift-Delete in the default keymap (to do the same thing as the Shift-less binding).
|
||||
|
||||
### New features
|
||||
|
||||
Adds a `deleteToLineStart` command.
|
||||
|
||||
Adds bindings for Cmd-Delete and Cmd-Backspace on macOS.
|
||||
|
||||
## 0.18.0 (2021-03-03)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
Update dependencies to 0.18.
|
||||
|
||||
## 0.17.5 (2021-02-25)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Use Alt-l for the default `selectLine` binding, because Mod-l already has an important meaning in the browser.
|
||||
|
||||
Make `deleteGroupBackward`/`deleteGroupForward` delete groups of whitespace when bigger than a single space.
|
||||
|
||||
Don't change lines that have the end of a range selection directly at their start in `indentLess`, `indentMore`, and `indentSelection`.
|
||||
|
||||
## 0.17.4 (2021-02-18)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug where `deleteToLineEnd` would delete the rest of the document when at the end of a line.
|
||||
|
||||
## 0.17.3 (2021-02-16)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where `insertNewlineAndIndent` behaved strangely with the cursor between brackets that sat on different lines.
|
||||
|
||||
## 0.17.2 (2021-01-22)
|
||||
|
||||
### New features
|
||||
|
||||
The new `insertTab` command inserts a tab when nothing is selected, and defers to `indentMore` otherwise.
|
||||
|
||||
The package now exports a `defaultTabBinding` object that provides a recommended binding for tab (if you must bind tab).
|
||||
|
||||
## 0.17.1 (2021-01-06)
|
||||
|
||||
### New features
|
||||
|
||||
The package now also exports a CommonJS module.
|
||||
|
||||
## 0.17.0 (2020-12-29)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
First numbered release.
|
||||
|
||||
21
node_modules/@codemirror/commands/LICENSE
generated
vendored
Normal file
21
node_modules/@codemirror/commands/LICENSE
generated
vendored
Normal file
@ -0,0 +1,21 @@
|
||||
MIT License
|
||||
|
||||
Copyright (C) 2018-2021 by Marijn Haverbeke <marijn@haverbeke.berlin> and others
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
18
node_modules/@codemirror/commands/README.md
generated
vendored
Normal file
18
node_modules/@codemirror/commands/README.md
generated
vendored
Normal file
@ -0,0 +1,18 @@
|
||||
# @codemirror/commands [](https://www.npmjs.org/package/@codemirror/commands)
|
||||
|
||||
[ [**WEBSITE**](https://codemirror.net/) | [**DOCS**](https://codemirror.net/docs/ref/#commands) | [**ISSUES**](https://github.com/codemirror/dev/issues) | [**FORUM**](https://discuss.codemirror.net/c/next/) | [**CHANGELOG**](https://github.com/codemirror/commands/blob/main/CHANGELOG.md) ]
|
||||
|
||||
This package implements a collection of editing commands for the
|
||||
[CodeMirror](https://codemirror.net/) code editor.
|
||||
|
||||
The [project page](https://codemirror.net/) has more information, a
|
||||
number of [examples](https://codemirror.net/examples/) and the
|
||||
[documentation](https://codemirror.net/docs/).
|
||||
|
||||
This code is released under an
|
||||
[MIT license](https://github.com/codemirror/commands/tree/main/LICENSE).
|
||||
|
||||
We aim to be an inclusive, welcoming community. To make that explicit,
|
||||
we have a [code of
|
||||
conduct](http://contributor-covenant.org/version/1/1/0/) that applies
|
||||
to communication around the project.
|
||||
1694
node_modules/@codemirror/commands/dist/index.cjs
generated
vendored
Normal file
1694
node_modules/@codemirror/commands/dist/index.cjs
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
566
node_modules/@codemirror/commands/dist/index.d.ts
generated
vendored
Normal file
566
node_modules/@codemirror/commands/dist/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,566 @@
|
||||
import * as _codemirror_state from '@codemirror/state';
|
||||
import { StateCommand, Facet, Transaction, StateEffect, Extension, StateField, EditorState } from '@codemirror/state';
|
||||
import { KeyBinding, Command } from '@codemirror/view';
|
||||
|
||||
/**
|
||||
An object of this type can be provided as [language
|
||||
data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt) under a `"commentTokens"`
|
||||
property to configure comment syntax for a language.
|
||||
*/
|
||||
interface CommentTokens {
|
||||
/**
|
||||
The block comment syntax, if any. For example, for HTML
|
||||
you'd provide `{open: "<!--", close: "-->"}`.
|
||||
*/
|
||||
block?: {
|
||||
open: string;
|
||||
close: string;
|
||||
};
|
||||
/**
|
||||
The line comment syntax. For example `"//"`.
|
||||
*/
|
||||
line?: string;
|
||||
}
|
||||
/**
|
||||
Comment or uncomment the current selection. Will use line comments
|
||||
if available, otherwise falling back to block comments.
|
||||
*/
|
||||
declare const toggleComment: StateCommand;
|
||||
/**
|
||||
Comment or uncomment the current selection using line comments.
|
||||
The line comment syntax is taken from the
|
||||
[`commentTokens`](https://codemirror.net/6/docs/ref/#commands.CommentTokens) [language
|
||||
data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt).
|
||||
*/
|
||||
declare const toggleLineComment: StateCommand;
|
||||
/**
|
||||
Comment the current selection using line comments.
|
||||
*/
|
||||
declare const lineComment: StateCommand;
|
||||
/**
|
||||
Uncomment the current selection using line comments.
|
||||
*/
|
||||
declare const lineUncomment: StateCommand;
|
||||
/**
|
||||
Comment or uncomment the current selection using block comments.
|
||||
The block comment syntax is taken from the
|
||||
[`commentTokens`](https://codemirror.net/6/docs/ref/#commands.CommentTokens) [language
|
||||
data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt).
|
||||
*/
|
||||
declare const toggleBlockComment: StateCommand;
|
||||
/**
|
||||
Comment the current selection using block comments.
|
||||
*/
|
||||
declare const blockComment: StateCommand;
|
||||
/**
|
||||
Uncomment the current selection using block comments.
|
||||
*/
|
||||
declare const blockUncomment: StateCommand;
|
||||
/**
|
||||
Comment or uncomment the lines around the current selection using
|
||||
block comments.
|
||||
*/
|
||||
declare const toggleBlockCommentByLine: StateCommand;
|
||||
|
||||
/**
|
||||
Transaction annotation that will prevent that transaction from
|
||||
being combined with other transactions in the undo history. Given
|
||||
`"before"`, it'll prevent merging with previous transactions. With
|
||||
`"after"`, subsequent transactions won't be combined with this
|
||||
one. With `"full"`, the transaction is isolated on both sides.
|
||||
*/
|
||||
declare const isolateHistory: _codemirror_state.AnnotationType<"after" | "before" | "full">;
|
||||
/**
|
||||
This facet provides a way to register functions that, given a
|
||||
transaction, provide a set of effects that the history should
|
||||
store when inverting the transaction. This can be used to
|
||||
integrate some kinds of effects in the history, so that they can
|
||||
be undone (and redone again).
|
||||
*/
|
||||
declare const invertedEffects: Facet<(tr: Transaction) => readonly StateEffect<any>[], readonly ((tr: Transaction) => readonly StateEffect<any>[])[]>;
|
||||
interface HistoryConfig {
|
||||
/**
|
||||
The minimum depth (amount of events) to store. Defaults to 100.
|
||||
*/
|
||||
minDepth?: number;
|
||||
/**
|
||||
The maximum time (in milliseconds) that adjacent events can be
|
||||
apart and still be grouped together. Defaults to 500.
|
||||
*/
|
||||
newGroupDelay?: number;
|
||||
/**
|
||||
By default, when close enough together in time, changes are
|
||||
joined into an existing undo event if they touch any of the
|
||||
changed ranges from that event. You can pass a custom predicate
|
||||
here to influence that logic.
|
||||
*/
|
||||
joinToEvent?: (tr: Transaction, isAdjacent: boolean) => boolean;
|
||||
}
|
||||
/**
|
||||
Create a history extension with the given configuration.
|
||||
*/
|
||||
declare function history(config?: HistoryConfig): Extension;
|
||||
/**
|
||||
The state field used to store the history data. Should probably
|
||||
only be used when you want to
|
||||
[serialize](https://codemirror.net/6/docs/ref/#state.EditorState.toJSON) or
|
||||
[deserialize](https://codemirror.net/6/docs/ref/#state.EditorState^fromJSON) state objects in a way
|
||||
that preserves history.
|
||||
*/
|
||||
declare const historyField: StateField<unknown>;
|
||||
/**
|
||||
Undo a single group of history events. Returns false if no group
|
||||
was available.
|
||||
*/
|
||||
declare const undo: StateCommand;
|
||||
/**
|
||||
Redo a group of history events. Returns false if no group was
|
||||
available.
|
||||
*/
|
||||
declare const redo: StateCommand;
|
||||
/**
|
||||
Undo a change or selection change.
|
||||
*/
|
||||
declare const undoSelection: StateCommand;
|
||||
/**
|
||||
Redo a change or selection change.
|
||||
*/
|
||||
declare const redoSelection: StateCommand;
|
||||
/**
|
||||
The amount of undoable change events available in a given state.
|
||||
*/
|
||||
declare const undoDepth: (state: EditorState) => number;
|
||||
/**
|
||||
The amount of redoable change events available in a given state.
|
||||
*/
|
||||
declare const redoDepth: (state: EditorState) => number;
|
||||
/**
|
||||
Default key bindings for the undo history.
|
||||
|
||||
- Mod-z: [`undo`](https://codemirror.net/6/docs/ref/#commands.undo).
|
||||
- Mod-y (Mod-Shift-z on macOS) + Ctrl-Shift-z on Linux: [`redo`](https://codemirror.net/6/docs/ref/#commands.redo).
|
||||
- Mod-u: [`undoSelection`](https://codemirror.net/6/docs/ref/#commands.undoSelection).
|
||||
- Alt-u (Mod-Shift-u on macOS): [`redoSelection`](https://codemirror.net/6/docs/ref/#commands.redoSelection).
|
||||
*/
|
||||
declare const historyKeymap: readonly KeyBinding[];
|
||||
|
||||
/**
|
||||
Move the selection one character to the left (which is backward in
|
||||
left-to-right text, forward in right-to-left text).
|
||||
*/
|
||||
declare const cursorCharLeft: Command;
|
||||
/**
|
||||
Move the selection one character to the right.
|
||||
*/
|
||||
declare const cursorCharRight: Command;
|
||||
/**
|
||||
Move the selection one character forward.
|
||||
*/
|
||||
declare const cursorCharForward: Command;
|
||||
/**
|
||||
Move the selection one character backward.
|
||||
*/
|
||||
declare const cursorCharBackward: Command;
|
||||
/**
|
||||
Move the selection to the left across one group of word or
|
||||
non-word (but also non-space) characters.
|
||||
*/
|
||||
declare const cursorGroupLeft: Command;
|
||||
/**
|
||||
Move the selection one group to the right.
|
||||
*/
|
||||
declare const cursorGroupRight: Command;
|
||||
/**
|
||||
Move the selection one group forward.
|
||||
*/
|
||||
declare const cursorGroupForward: Command;
|
||||
/**
|
||||
Move the selection one group backward.
|
||||
*/
|
||||
declare const cursorGroupBackward: Command;
|
||||
/**
|
||||
Move the selection one group or camel-case subword forward.
|
||||
*/
|
||||
declare const cursorSubwordForward: Command;
|
||||
/**
|
||||
Move the selection one group or camel-case subword backward.
|
||||
*/
|
||||
declare const cursorSubwordBackward: Command;
|
||||
/**
|
||||
Move the cursor over the next syntactic element to the left.
|
||||
*/
|
||||
declare const cursorSyntaxLeft: Command;
|
||||
/**
|
||||
Move the cursor over the next syntactic element to the right.
|
||||
*/
|
||||
declare const cursorSyntaxRight: Command;
|
||||
/**
|
||||
Move the selection one line up.
|
||||
*/
|
||||
declare const cursorLineUp: Command;
|
||||
/**
|
||||
Move the selection one line down.
|
||||
*/
|
||||
declare const cursorLineDown: Command;
|
||||
/**
|
||||
Move the selection one page up.
|
||||
*/
|
||||
declare const cursorPageUp: Command;
|
||||
/**
|
||||
Move the selection one page down.
|
||||
*/
|
||||
declare const cursorPageDown: Command;
|
||||
/**
|
||||
Move the selection to the next line wrap point, or to the end of
|
||||
the line if there isn't one left on this line.
|
||||
*/
|
||||
declare const cursorLineBoundaryForward: Command;
|
||||
/**
|
||||
Move the selection to previous line wrap point, or failing that to
|
||||
the start of the line. If the line is indented, and the cursor
|
||||
isn't already at the end of the indentation, this will move to the
|
||||
end of the indentation instead of the start of the line.
|
||||
*/
|
||||
declare const cursorLineBoundaryBackward: Command;
|
||||
/**
|
||||
Move the selection one line wrap point to the left.
|
||||
*/
|
||||
declare const cursorLineBoundaryLeft: Command;
|
||||
/**
|
||||
Move the selection one line wrap point to the right.
|
||||
*/
|
||||
declare const cursorLineBoundaryRight: Command;
|
||||
/**
|
||||
Move the selection to the start of the line.
|
||||
*/
|
||||
declare const cursorLineStart: Command;
|
||||
/**
|
||||
Move the selection to the end of the line.
|
||||
*/
|
||||
declare const cursorLineEnd: Command;
|
||||
/**
|
||||
Move the selection to the bracket matching the one it is currently
|
||||
on, if any.
|
||||
*/
|
||||
declare const cursorMatchingBracket: StateCommand;
|
||||
/**
|
||||
Extend the selection to the bracket matching the one the selection
|
||||
head is currently on, if any.
|
||||
*/
|
||||
declare const selectMatchingBracket: StateCommand;
|
||||
/**
|
||||
Move the selection head one character to the left, while leaving
|
||||
the anchor in place.
|
||||
*/
|
||||
declare const selectCharLeft: Command;
|
||||
/**
|
||||
Move the selection head one character to the right.
|
||||
*/
|
||||
declare const selectCharRight: Command;
|
||||
/**
|
||||
Move the selection head one character forward.
|
||||
*/
|
||||
declare const selectCharForward: Command;
|
||||
/**
|
||||
Move the selection head one character backward.
|
||||
*/
|
||||
declare const selectCharBackward: Command;
|
||||
/**
|
||||
Move the selection head one [group](https://codemirror.net/6/docs/ref/#commands.cursorGroupLeft) to
|
||||
the left.
|
||||
*/
|
||||
declare const selectGroupLeft: Command;
|
||||
/**
|
||||
Move the selection head one group to the right.
|
||||
*/
|
||||
declare const selectGroupRight: Command;
|
||||
/**
|
||||
Move the selection head one group forward.
|
||||
*/
|
||||
declare const selectGroupForward: Command;
|
||||
/**
|
||||
Move the selection head one group backward.
|
||||
*/
|
||||
declare const selectGroupBackward: Command;
|
||||
/**
|
||||
Move the selection head one group or camel-case subword forward.
|
||||
*/
|
||||
declare const selectSubwordForward: Command;
|
||||
/**
|
||||
Move the selection head one group or subword backward.
|
||||
*/
|
||||
declare const selectSubwordBackward: Command;
|
||||
/**
|
||||
Move the selection head over the next syntactic element to the left.
|
||||
*/
|
||||
declare const selectSyntaxLeft: Command;
|
||||
/**
|
||||
Move the selection head over the next syntactic element to the right.
|
||||
*/
|
||||
declare const selectSyntaxRight: Command;
|
||||
/**
|
||||
Move the selection head one line up.
|
||||
*/
|
||||
declare const selectLineUp: Command;
|
||||
/**
|
||||
Move the selection head one line down.
|
||||
*/
|
||||
declare const selectLineDown: Command;
|
||||
/**
|
||||
Move the selection head one page up.
|
||||
*/
|
||||
declare const selectPageUp: Command;
|
||||
/**
|
||||
Move the selection head one page down.
|
||||
*/
|
||||
declare const selectPageDown: Command;
|
||||
/**
|
||||
Move the selection head to the next line boundary.
|
||||
*/
|
||||
declare const selectLineBoundaryForward: Command;
|
||||
/**
|
||||
Move the selection head to the previous line boundary.
|
||||
*/
|
||||
declare const selectLineBoundaryBackward: Command;
|
||||
/**
|
||||
Move the selection head one line boundary to the left.
|
||||
*/
|
||||
declare const selectLineBoundaryLeft: Command;
|
||||
/**
|
||||
Move the selection head one line boundary to the right.
|
||||
*/
|
||||
declare const selectLineBoundaryRight: Command;
|
||||
/**
|
||||
Move the selection head to the start of the line.
|
||||
*/
|
||||
declare const selectLineStart: Command;
|
||||
/**
|
||||
Move the selection head to the end of the line.
|
||||
*/
|
||||
declare const selectLineEnd: Command;
|
||||
/**
|
||||
Move the selection to the start of the document.
|
||||
*/
|
||||
declare const cursorDocStart: StateCommand;
|
||||
/**
|
||||
Move the selection to the end of the document.
|
||||
*/
|
||||
declare const cursorDocEnd: StateCommand;
|
||||
/**
|
||||
Move the selection head to the start of the document.
|
||||
*/
|
||||
declare const selectDocStart: StateCommand;
|
||||
/**
|
||||
Move the selection head to the end of the document.
|
||||
*/
|
||||
declare const selectDocEnd: StateCommand;
|
||||
/**
|
||||
Select the entire document.
|
||||
*/
|
||||
declare const selectAll: StateCommand;
|
||||
/**
|
||||
Expand the selection to cover entire lines.
|
||||
*/
|
||||
declare const selectLine: StateCommand;
|
||||
/**
|
||||
Select the next syntactic construct that is larger than the
|
||||
selection. Note that this will only work insofar as the language
|
||||
[provider](https://codemirror.net/6/docs/ref/#language.language) you use builds up a full
|
||||
syntax tree.
|
||||
*/
|
||||
declare const selectParentSyntax: StateCommand;
|
||||
/**
|
||||
Simplify the current selection. When multiple ranges are selected,
|
||||
reduce it to its main range. Otherwise, if the selection is
|
||||
non-empty, convert it to a cursor selection.
|
||||
*/
|
||||
declare const simplifySelection: StateCommand;
|
||||
/**
|
||||
Delete the selection, or, for cursor selections, the character
|
||||
before the cursor.
|
||||
*/
|
||||
declare const deleteCharBackward: Command;
|
||||
/**
|
||||
Delete the selection or the character after the cursor.
|
||||
*/
|
||||
declare const deleteCharForward: Command;
|
||||
/**
|
||||
Delete the selection or backward until the end of the next
|
||||
[group](https://codemirror.net/6/docs/ref/#view.EditorView.moveByGroup), only skipping groups of
|
||||
whitespace when they consist of a single space.
|
||||
*/
|
||||
declare const deleteGroupBackward: StateCommand;
|
||||
/**
|
||||
Delete the selection or forward until the end of the next group.
|
||||
*/
|
||||
declare const deleteGroupForward: StateCommand;
|
||||
/**
|
||||
Delete the selection, or, if it is a cursor selection, delete to
|
||||
the end of the line. If the cursor is directly at the end of the
|
||||
line, delete the line break after it.
|
||||
*/
|
||||
declare const deleteToLineEnd: Command;
|
||||
/**
|
||||
Delete the selection, or, if it is a cursor selection, delete to
|
||||
the start of the line. If the cursor is directly at the start of the
|
||||
line, delete the line break before it.
|
||||
*/
|
||||
declare const deleteToLineStart: Command;
|
||||
/**
|
||||
Delete all whitespace directly before a line end from the
|
||||
document.
|
||||
*/
|
||||
declare const deleteTrailingWhitespace: StateCommand;
|
||||
/**
|
||||
Replace each selection range with a line break, leaving the cursor
|
||||
on the line before the break.
|
||||
*/
|
||||
declare const splitLine: StateCommand;
|
||||
/**
|
||||
Flip the characters before and after the cursor(s).
|
||||
*/
|
||||
declare const transposeChars: StateCommand;
|
||||
/**
|
||||
Move the selected lines up one line.
|
||||
*/
|
||||
declare const moveLineUp: StateCommand;
|
||||
/**
|
||||
Move the selected lines down one line.
|
||||
*/
|
||||
declare const moveLineDown: StateCommand;
|
||||
/**
|
||||
Create a copy of the selected lines. Keep the selection in the top copy.
|
||||
*/
|
||||
declare const copyLineUp: StateCommand;
|
||||
/**
|
||||
Create a copy of the selected lines. Keep the selection in the bottom copy.
|
||||
*/
|
||||
declare const copyLineDown: StateCommand;
|
||||
/**
|
||||
Delete selected lines.
|
||||
*/
|
||||
declare const deleteLine: Command;
|
||||
/**
|
||||
Replace the selection with a newline.
|
||||
*/
|
||||
declare const insertNewline: StateCommand;
|
||||
/**
|
||||
Replace the selection with a newline and indent the newly created
|
||||
line(s). If the current line consists only of whitespace, this
|
||||
will also delete that whitespace. When the cursor is between
|
||||
matching brackets, an additional newline will be inserted after
|
||||
the cursor.
|
||||
*/
|
||||
declare const insertNewlineAndIndent: StateCommand;
|
||||
/**
|
||||
Create a blank, indented line below the current line.
|
||||
*/
|
||||
declare const insertBlankLine: StateCommand;
|
||||
/**
|
||||
Auto-indent the selected lines. This uses the [indentation service
|
||||
facet](https://codemirror.net/6/docs/ref/#language.indentService) as source for auto-indent
|
||||
information.
|
||||
*/
|
||||
declare const indentSelection: StateCommand;
|
||||
/**
|
||||
Add a [unit](https://codemirror.net/6/docs/ref/#language.indentUnit) of indentation to all selected
|
||||
lines.
|
||||
*/
|
||||
declare const indentMore: StateCommand;
|
||||
/**
|
||||
Remove a [unit](https://codemirror.net/6/docs/ref/#language.indentUnit) of indentation from all
|
||||
selected lines.
|
||||
*/
|
||||
declare const indentLess: StateCommand;
|
||||
/**
|
||||
Insert a tab character at the cursor or, if something is selected,
|
||||
use [`indentMore`](https://codemirror.net/6/docs/ref/#commands.indentMore) to indent the entire
|
||||
selection.
|
||||
*/
|
||||
declare const insertTab: StateCommand;
|
||||
/**
|
||||
Array of key bindings containing the Emacs-style bindings that are
|
||||
available on macOS by default.
|
||||
|
||||
- Ctrl-b: [`cursorCharLeft`](https://codemirror.net/6/docs/ref/#commands.cursorCharLeft) ([`selectCharLeft`](https://codemirror.net/6/docs/ref/#commands.selectCharLeft) with Shift)
|
||||
- Ctrl-f: [`cursorCharRight`](https://codemirror.net/6/docs/ref/#commands.cursorCharRight) ([`selectCharRight`](https://codemirror.net/6/docs/ref/#commands.selectCharRight) with Shift)
|
||||
- Ctrl-p: [`cursorLineUp`](https://codemirror.net/6/docs/ref/#commands.cursorLineUp) ([`selectLineUp`](https://codemirror.net/6/docs/ref/#commands.selectLineUp) with Shift)
|
||||
- Ctrl-n: [`cursorLineDown`](https://codemirror.net/6/docs/ref/#commands.cursorLineDown) ([`selectLineDown`](https://codemirror.net/6/docs/ref/#commands.selectLineDown) with Shift)
|
||||
- Ctrl-a: [`cursorLineStart`](https://codemirror.net/6/docs/ref/#commands.cursorLineStart) ([`selectLineStart`](https://codemirror.net/6/docs/ref/#commands.selectLineStart) with Shift)
|
||||
- Ctrl-e: [`cursorLineEnd`](https://codemirror.net/6/docs/ref/#commands.cursorLineEnd) ([`selectLineEnd`](https://codemirror.net/6/docs/ref/#commands.selectLineEnd) with Shift)
|
||||
- Ctrl-d: [`deleteCharForward`](https://codemirror.net/6/docs/ref/#commands.deleteCharForward)
|
||||
- Ctrl-h: [`deleteCharBackward`](https://codemirror.net/6/docs/ref/#commands.deleteCharBackward)
|
||||
- Ctrl-k: [`deleteToLineEnd`](https://codemirror.net/6/docs/ref/#commands.deleteToLineEnd)
|
||||
- Ctrl-Alt-h: [`deleteGroupBackward`](https://codemirror.net/6/docs/ref/#commands.deleteGroupBackward)
|
||||
- Ctrl-o: [`splitLine`](https://codemirror.net/6/docs/ref/#commands.splitLine)
|
||||
- Ctrl-t: [`transposeChars`](https://codemirror.net/6/docs/ref/#commands.transposeChars)
|
||||
- Ctrl-v: [`cursorPageDown`](https://codemirror.net/6/docs/ref/#commands.cursorPageDown)
|
||||
- Alt-v: [`cursorPageUp`](https://codemirror.net/6/docs/ref/#commands.cursorPageUp)
|
||||
*/
|
||||
declare const emacsStyleKeymap: readonly KeyBinding[];
|
||||
/**
|
||||
An array of key bindings closely sticking to platform-standard or
|
||||
widely used bindings. (This includes the bindings from
|
||||
[`emacsStyleKeymap`](https://codemirror.net/6/docs/ref/#commands.emacsStyleKeymap), with their `key`
|
||||
property changed to `mac`.)
|
||||
|
||||
- ArrowLeft: [`cursorCharLeft`](https://codemirror.net/6/docs/ref/#commands.cursorCharLeft) ([`selectCharLeft`](https://codemirror.net/6/docs/ref/#commands.selectCharLeft) with Shift)
|
||||
- ArrowRight: [`cursorCharRight`](https://codemirror.net/6/docs/ref/#commands.cursorCharRight) ([`selectCharRight`](https://codemirror.net/6/docs/ref/#commands.selectCharRight) with Shift)
|
||||
- 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)
|
||||
- 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)
|
||||
- Cmd-ArrowLeft (on macOS): [`cursorLineStart`](https://codemirror.net/6/docs/ref/#commands.cursorLineStart) ([`selectLineStart`](https://codemirror.net/6/docs/ref/#commands.selectLineStart) with Shift)
|
||||
- Cmd-ArrowRight (on macOS): [`cursorLineEnd`](https://codemirror.net/6/docs/ref/#commands.cursorLineEnd) ([`selectLineEnd`](https://codemirror.net/6/docs/ref/#commands.selectLineEnd) with Shift)
|
||||
- ArrowUp: [`cursorLineUp`](https://codemirror.net/6/docs/ref/#commands.cursorLineUp) ([`selectLineUp`](https://codemirror.net/6/docs/ref/#commands.selectLineUp) with Shift)
|
||||
- ArrowDown: [`cursorLineDown`](https://codemirror.net/6/docs/ref/#commands.cursorLineDown) ([`selectLineDown`](https://codemirror.net/6/docs/ref/#commands.selectLineDown) with Shift)
|
||||
- Cmd-ArrowUp (on macOS): [`cursorDocStart`](https://codemirror.net/6/docs/ref/#commands.cursorDocStart) ([`selectDocStart`](https://codemirror.net/6/docs/ref/#commands.selectDocStart) with Shift)
|
||||
- Cmd-ArrowDown (on macOS): [`cursorDocEnd`](https://codemirror.net/6/docs/ref/#commands.cursorDocEnd) ([`selectDocEnd`](https://codemirror.net/6/docs/ref/#commands.selectDocEnd) with Shift)
|
||||
- Ctrl-ArrowUp (on macOS): [`cursorPageUp`](https://codemirror.net/6/docs/ref/#commands.cursorPageUp) ([`selectPageUp`](https://codemirror.net/6/docs/ref/#commands.selectPageUp) with Shift)
|
||||
- Ctrl-ArrowDown (on macOS): [`cursorPageDown`](https://codemirror.net/6/docs/ref/#commands.cursorPageDown) ([`selectPageDown`](https://codemirror.net/6/docs/ref/#commands.selectPageDown) with Shift)
|
||||
- PageUp: [`cursorPageUp`](https://codemirror.net/6/docs/ref/#commands.cursorPageUp) ([`selectPageUp`](https://codemirror.net/6/docs/ref/#commands.selectPageUp) with Shift)
|
||||
- PageDown: [`cursorPageDown`](https://codemirror.net/6/docs/ref/#commands.cursorPageDown) ([`selectPageDown`](https://codemirror.net/6/docs/ref/#commands.selectPageDown) with Shift)
|
||||
- Home: [`cursorLineBoundaryBackward`](https://codemirror.net/6/docs/ref/#commands.cursorLineBoundaryBackward) ([`selectLineBoundaryBackward`](https://codemirror.net/6/docs/ref/#commands.selectLineBoundaryBackward) with Shift)
|
||||
- End: [`cursorLineBoundaryForward`](https://codemirror.net/6/docs/ref/#commands.cursorLineBoundaryForward) ([`selectLineBoundaryForward`](https://codemirror.net/6/docs/ref/#commands.selectLineBoundaryForward) with Shift)
|
||||
- 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)
|
||||
- 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)
|
||||
- Enter: [`insertNewlineAndIndent`](https://codemirror.net/6/docs/ref/#commands.insertNewlineAndIndent)
|
||||
- Ctrl-a (Cmd-a on macOS): [`selectAll`](https://codemirror.net/6/docs/ref/#commands.selectAll)
|
||||
- Backspace: [`deleteCharBackward`](https://codemirror.net/6/docs/ref/#commands.deleteCharBackward)
|
||||
- Delete: [`deleteCharForward`](https://codemirror.net/6/docs/ref/#commands.deleteCharForward)
|
||||
- Ctrl-Backspace (Alt-Backspace on macOS): [`deleteGroupBackward`](https://codemirror.net/6/docs/ref/#commands.deleteGroupBackward)
|
||||
- Ctrl-Delete (Alt-Delete on macOS): [`deleteGroupForward`](https://codemirror.net/6/docs/ref/#commands.deleteGroupForward)
|
||||
- Cmd-Backspace (macOS): [`deleteToLineStart`](https://codemirror.net/6/docs/ref/#commands.deleteToLineStart).
|
||||
- Cmd-Delete (macOS): [`deleteToLineEnd`](https://codemirror.net/6/docs/ref/#commands.deleteToLineEnd).
|
||||
*/
|
||||
declare const standardKeymap: readonly KeyBinding[];
|
||||
/**
|
||||
The default keymap. Includes all bindings from
|
||||
[`standardKeymap`](https://codemirror.net/6/docs/ref/#commands.standardKeymap) plus the following:
|
||||
|
||||
- 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)
|
||||
- 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)
|
||||
- Alt-ArrowUp: [`moveLineUp`](https://codemirror.net/6/docs/ref/#commands.moveLineUp)
|
||||
- Alt-ArrowDown: [`moveLineDown`](https://codemirror.net/6/docs/ref/#commands.moveLineDown)
|
||||
- Shift-Alt-ArrowUp: [`copyLineUp`](https://codemirror.net/6/docs/ref/#commands.copyLineUp)
|
||||
- Shift-Alt-ArrowDown: [`copyLineDown`](https://codemirror.net/6/docs/ref/#commands.copyLineDown)
|
||||
- Escape: [`simplifySelection`](https://codemirror.net/6/docs/ref/#commands.simplifySelection)
|
||||
- Ctrl-Enter (Cmd-Enter on macOS): [`insertBlankLine`](https://codemirror.net/6/docs/ref/#commands.insertBlankLine)
|
||||
- Alt-l (Ctrl-l on macOS): [`selectLine`](https://codemirror.net/6/docs/ref/#commands.selectLine)
|
||||
- Ctrl-i (Cmd-i on macOS): [`selectParentSyntax`](https://codemirror.net/6/docs/ref/#commands.selectParentSyntax)
|
||||
- Ctrl-[ (Cmd-[ on macOS): [`indentLess`](https://codemirror.net/6/docs/ref/#commands.indentLess)
|
||||
- Ctrl-] (Cmd-] on macOS): [`indentMore`](https://codemirror.net/6/docs/ref/#commands.indentMore)
|
||||
- Ctrl-Alt-\\ (Cmd-Alt-\\ on macOS): [`indentSelection`](https://codemirror.net/6/docs/ref/#commands.indentSelection)
|
||||
- Shift-Ctrl-k (Shift-Cmd-k on macOS): [`deleteLine`](https://codemirror.net/6/docs/ref/#commands.deleteLine)
|
||||
- Shift-Ctrl-\\ (Shift-Cmd-\\ on macOS): [`cursorMatchingBracket`](https://codemirror.net/6/docs/ref/#commands.cursorMatchingBracket)
|
||||
- Ctrl-/ (Cmd-/ on macOS): [`toggleComment`](https://codemirror.net/6/docs/ref/#commands.toggleComment).
|
||||
- Shift-Alt-a: [`toggleBlockComment`](https://codemirror.net/6/docs/ref/#commands.toggleBlockComment).
|
||||
*/
|
||||
declare const defaultKeymap: readonly KeyBinding[];
|
||||
/**
|
||||
A binding that binds Tab to [`indentMore`](https://codemirror.net/6/docs/ref/#commands.indentMore) and
|
||||
Shift-Tab to [`indentLess`](https://codemirror.net/6/docs/ref/#commands.indentLess).
|
||||
Please see the [Tab example](../../examples/tab/) before using
|
||||
this.
|
||||
*/
|
||||
declare const indentWithTab: KeyBinding;
|
||||
|
||||
export { CommentTokens, blockComment, blockUncomment, copyLineDown, copyLineUp, cursorCharBackward, cursorCharForward, cursorCharLeft, cursorCharRight, cursorDocEnd, cursorDocStart, cursorGroupBackward, cursorGroupForward, cursorGroupLeft, cursorGroupRight, cursorLineBoundaryBackward, cursorLineBoundaryForward, cursorLineBoundaryLeft, cursorLineBoundaryRight, cursorLineDown, cursorLineEnd, cursorLineStart, cursorLineUp, cursorMatchingBracket, cursorPageDown, cursorPageUp, cursorSubwordBackward, cursorSubwordForward, cursorSyntaxLeft, cursorSyntaxRight, defaultKeymap, deleteCharBackward, deleteCharForward, deleteGroupBackward, deleteGroupForward, deleteLine, deleteToLineEnd, deleteToLineStart, deleteTrailingWhitespace, emacsStyleKeymap, history, historyField, historyKeymap, indentLess, indentMore, indentSelection, indentWithTab, insertBlankLine, insertNewline, insertNewlineAndIndent, insertTab, invertedEffects, isolateHistory, lineComment, lineUncomment, moveLineDown, moveLineUp, redo, redoDepth, redoSelection, selectAll, selectCharBackward, selectCharForward, selectCharLeft, selectCharRight, selectDocEnd, selectDocStart, selectGroupBackward, selectGroupForward, selectGroupLeft, selectGroupRight, selectLine, selectLineBoundaryBackward, selectLineBoundaryForward, selectLineBoundaryLeft, selectLineBoundaryRight, selectLineDown, selectLineEnd, selectLineStart, selectLineUp, selectMatchingBracket, selectPageDown, selectPageUp, selectParentSyntax, selectSubwordBackward, selectSubwordForward, selectSyntaxLeft, selectSyntaxRight, simplifySelection, splitLine, standardKeymap, toggleBlockComment, toggleBlockCommentByLine, toggleComment, toggleLineComment, transposeChars, undo, undoDepth, undoSelection };
|
||||
1593
node_modules/@codemirror/commands/dist/index.js
generated
vendored
Normal file
1593
node_modules/@codemirror/commands/dist/index.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
42
node_modules/@codemirror/commands/package.json
generated
vendored
Normal file
42
node_modules/@codemirror/commands/package.json
generated
vendored
Normal file
@ -0,0 +1,42 @@
|
||||
{
|
||||
"name": "@codemirror/commands",
|
||||
"version": "6.2.4",
|
||||
"description": "Collection of editing commands for the CodeMirror code editor",
|
||||
"scripts": {
|
||||
"test": "cm-runtests",
|
||||
"prepare": "cm-buildhelper src/commands.ts"
|
||||
},
|
||||
"keywords": [
|
||||
"editor",
|
||||
"code"
|
||||
],
|
||||
"author": {
|
||||
"name": "Marijn Haverbeke",
|
||||
"email": "marijn@haverbeke.berlin",
|
||||
"url": "http://marijnhaverbeke.nl"
|
||||
},
|
||||
"type": "module",
|
||||
"main": "dist/index.cjs",
|
||||
"exports": {
|
||||
"import": "./dist/index.js",
|
||||
"require": "./dist/index.cjs"
|
||||
},
|
||||
"types": "dist/index.d.ts",
|
||||
"module": "dist/index.js",
|
||||
"sideEffects": false,
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"@codemirror/language": "^6.0.0",
|
||||
"@codemirror/state": "^6.2.0",
|
||||
"@codemirror/view": "^6.0.0",
|
||||
"@lezer/common": "^1.0.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@codemirror/buildhelper": "^0.1.5",
|
||||
"@codemirror/lang-javascript": "^6.0.0"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/codemirror/commands.git"
|
||||
}
|
||||
}
|
||||
16
node_modules/@codemirror/lang-javascript/.github/workflows/dispatch.yml
generated
vendored
Normal file
16
node_modules/@codemirror/lang-javascript/.github/workflows/dispatch.yml
generated
vendored
Normal file
@ -0,0 +1,16 @@
|
||||
name: Trigger CI
|
||||
on: push
|
||||
|
||||
jobs:
|
||||
build:
|
||||
name: Dispatch to main repo
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Emit repository_dispatch
|
||||
uses: mvasigh/dispatch-action@main
|
||||
with:
|
||||
# You should create a personal access token and store it in your repository
|
||||
token: ${{ secrets.DISPATCH_AUTH }}
|
||||
repo: dev
|
||||
owner: codemirror
|
||||
event_type: push
|
||||
166
node_modules/@codemirror/lang-javascript/CHANGELOG.md
generated
vendored
Normal file
166
node_modules/@codemirror/lang-javascript/CHANGELOG.md
generated
vendored
Normal file
@ -0,0 +1,166 @@
|
||||
## 6.1.9 (2023-06-02)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make sure `scopeCompletionSource` doesn't try to complete property names that aren't simple identifier (such as numeric indices).
|
||||
|
||||
## 6.1.8 (2023-05-13)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Stop completing keywords after `.` tokens.
|
||||
|
||||
## 6.1.7 (2023-04-19)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix overeager JSX tag closing inside attribute values and in self-closing tags.
|
||||
|
||||
## 6.1.6 (2023-04-13)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that allowed `autoCloseTags` to close JSX tags in JavaScript context.
|
||||
|
||||
## 6.1.5 (2023-04-04)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make TypeScript object type syntax foldable.
|
||||
|
||||
## 6.1.4 (2023-02-13)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make sure code in JSX context can be commented correctly.
|
||||
|
||||
## 6.1.3 (2023-02-02)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix auto-closing of JSX fragments.
|
||||
|
||||
## 6.1.2 (2022-12-07)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Automatic tag closing in JSX now works for namespaced and member-expression tag names.
|
||||
|
||||
## 6.1.1 (2022-10-24)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make `completionPath` handle `?.` syntax.
|
||||
|
||||
## 6.1.0 (2022-09-20)
|
||||
|
||||
### New features
|
||||
|
||||
The `completionPath` helper can now be used to find the object path to complete at a given position.
|
||||
|
||||
`scopeCompletionSource` provides a completion source based on a scope object.
|
||||
|
||||
## 6.0.2 (2022-07-21)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix the `source` field in ESLint diagnostics to properly hold `"eslint"`.
|
||||
|
||||
Fix (non-)auto indentation in template strings and comments.
|
||||
|
||||
## 6.0.1 (2022-06-29)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Avoid completing variables/keywords in property or definition positions.
|
||||
|
||||
Fix a bug that broke local variable completion if JavaScript was parsed an overlay in an outer language.
|
||||
|
||||
## 6.0.0 (2022-06-08)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
Update dependencies to 6.0.0
|
||||
|
||||
## 0.20.1 (2022-06-01)
|
||||
|
||||
### New features
|
||||
|
||||
`localCompletionSource` (included in the support extensions returned from `javascript`) now provides a way to complete locally-defined names.
|
||||
|
||||
## 0.20.0 (2022-04-20)
|
||||
|
||||
### New features
|
||||
|
||||
The new `autoCloseTags` extension (included by default in the `javascript` language extension when `jsx` is configured) finishes JSX closing tags when you type a `>` or `/` character.
|
||||
|
||||
## 0.19.7 (2022-01-28)
|
||||
|
||||
## 0.19.6 (2022-01-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Remove accidentally released unfinished changes.
|
||||
|
||||
## 0.19.5 (2022-01-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Add the `function` highlight modifier to variables used in tagged template expressions.
|
||||
|
||||
## 0.19.4 (2022-01-03)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix highlighting of TypeScript private/public/protected keywords.
|
||||
|
||||
## 0.19.3 (2021-11-12)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Add styling for private properties.
|
||||
|
||||
## 0.19.2 (2021-09-23)
|
||||
|
||||
### New features
|
||||
|
||||
Use more specific highlighting tags for JSX attribute names and values.
|
||||
|
||||
## 0.19.1 (2021-08-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix incorrect versions for @lezer dependencies.
|
||||
|
||||
## 0.19.0 (2021-08-11)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
Update dependencies to 0.19.0
|
||||
|
||||
## 0.18.0 (2021-03-03)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Extend `indentOnInput` expression to cover closing JSX tags.
|
||||
|
||||
## 0.17.2 (2021-02-15)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Improve highlighting tag specificity of defined function and class names. Add indentation information for JSX constructs
|
||||
|
||||
Support smart indent for JSX syntax.
|
||||
|
||||
## 0.17.1 (2021-01-06)
|
||||
|
||||
### New features
|
||||
|
||||
The package now also exports a CommonJS module.
|
||||
|
||||
## 0.17.0 (2020-12-29)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
First numbered release.
|
||||
|
||||
21
node_modules/@codemirror/lang-javascript/LICENSE
generated
vendored
Normal file
21
node_modules/@codemirror/lang-javascript/LICENSE
generated
vendored
Normal file
@ -0,0 +1,21 @@
|
||||
MIT License
|
||||
|
||||
Copyright (C) 2018-2021 by Marijn Haverbeke <marijn@haverbeke.berlin> and others
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
106
node_modules/@codemirror/lang-javascript/README.md
generated
vendored
Normal file
106
node_modules/@codemirror/lang-javascript/README.md
generated
vendored
Normal file
@ -0,0 +1,106 @@
|
||||
<!-- NOTE: README.md is generated from src/README.md -->
|
||||
|
||||
# @codemirror/lang-javascript [](https://www.npmjs.org/package/@codemirror/lang-javascript)
|
||||
|
||||
[ [**WEBSITE**](https://codemirror.net/) | [**ISSUES**](https://github.com/codemirror/dev/issues) | [**FORUM**](https://discuss.codemirror.net/c/next/) | [**CHANGELOG**](https://github.com/codemirror/lang-javascript/blob/main/CHANGELOG.md) ]
|
||||
|
||||
This package implements JavaScript language support for the
|
||||
[CodeMirror](https://codemirror.net/) code editor.
|
||||
|
||||
The [project page](https://codemirror.net/) has more information, a
|
||||
number of [examples](https://codemirror.net/examples/) and the
|
||||
[documentation](https://codemirror.net/docs/).
|
||||
|
||||
This code is released under an
|
||||
[MIT license](https://github.com/codemirror/lang-javascript/tree/main/LICENSE).
|
||||
|
||||
We aim to be an inclusive, welcoming community. To make that explicit,
|
||||
we have a [code of
|
||||
conduct](http://contributor-covenant.org/version/1/1/0/) that applies
|
||||
to communication around the project.
|
||||
|
||||
## API Reference
|
||||
|
||||
<dl>
|
||||
<dt id="user-content-javascript">
|
||||
<code><strong><a href="#user-content-javascript">javascript</a></strong>(<a id="user-content-javascript^config" href="#user-content-javascript^config">config</a>⁠?: {jsx⁠?: <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a>, typescript⁠?: <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a>} = {}) → <a href="https://codemirror.net/docs/ref#language.LanguageSupport">LanguageSupport</a></code></dt>
|
||||
|
||||
<dd><p>JavaScript support. Includes <a href="#user-content-snippets">snippet</a>
|
||||
completion.</p>
|
||||
</dd>
|
||||
<dt id="user-content-javascriptlanguage">
|
||||
<code><strong><a href="#user-content-javascriptlanguage">javascriptLanguage</a></strong>: <a href="https://codemirror.net/docs/ref#language.LRLanguage">LRLanguage</a></code></dt>
|
||||
|
||||
<dd><p>A language provider based on the <a href="https://github.com/lezer-parser/javascript">Lezer JavaScript
|
||||
parser</a>, extended with
|
||||
highlighting and indentation information.</p>
|
||||
</dd>
|
||||
<dt id="user-content-typescriptlanguage">
|
||||
<code><strong><a href="#user-content-typescriptlanguage">typescriptLanguage</a></strong>: <a href="https://codemirror.net/docs/ref#language.LRLanguage">LRLanguage</a></code></dt>
|
||||
|
||||
<dd><p>A language provider for TypeScript.</p>
|
||||
</dd>
|
||||
<dt id="user-content-jsxlanguage">
|
||||
<code><strong><a href="#user-content-jsxlanguage">jsxLanguage</a></strong>: <a href="https://codemirror.net/docs/ref#language.LRLanguage">LRLanguage</a></code></dt>
|
||||
|
||||
<dd><p>Language provider for JSX.</p>
|
||||
</dd>
|
||||
<dt id="user-content-tsxlanguage">
|
||||
<code><strong><a href="#user-content-tsxlanguage">tsxLanguage</a></strong>: <a href="https://codemirror.net/docs/ref#language.LRLanguage">LRLanguage</a></code></dt>
|
||||
|
||||
<dd><p>Language provider for JSX + TypeScript.</p>
|
||||
</dd>
|
||||
<dt id="user-content-autoclosetags">
|
||||
<code><strong><a href="#user-content-autoclosetags">autoCloseTags</a></strong>: <a href="https://codemirror.net/docs/ref#state.Extension">Extension</a></code></dt>
|
||||
|
||||
<dd><p>Extension that will automatically insert JSX close tags when a <code>></code> or
|
||||
<code>/</code> is typed.</p>
|
||||
</dd>
|
||||
<dt id="user-content-snippets">
|
||||
<code><strong><a href="#user-content-snippets">snippets</a></strong>: readonly <a href="https://codemirror.net/docs/ref#autocomplete.Completion">Completion</a>[]</code></dt>
|
||||
|
||||
<dd><p>A collection of JavaScript-related
|
||||
<a href="https://codemirror.net/docs/ref/#autocomplete.snippet">snippets</a>.</p>
|
||||
</dd>
|
||||
<dt id="user-content-localcompletionsource">
|
||||
<code><strong><a href="#user-content-localcompletionsource">localCompletionSource</a></strong>(<a id="user-content-localcompletionsource^context" href="#user-content-localcompletionsource^context">context</a>: <a href="https://codemirror.net/docs/ref#autocomplete.CompletionContext">CompletionContext</a>) → <a href="https://codemirror.net/docs/ref#autocomplete.CompletionResult">CompletionResult</a> | <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/null">null</a></code></dt>
|
||||
|
||||
<dd><p>Completion source that looks up locally defined names in
|
||||
JavaScript code.</p>
|
||||
</dd>
|
||||
<dt id="user-content-completionpath">
|
||||
<code><strong><a href="#user-content-completionpath">completionPath</a></strong>(<a id="user-content-completionpath^context" href="#user-content-completionpath^context">context</a>: <a href="https://codemirror.net/docs/ref#autocomplete.CompletionContext">CompletionContext</a>) → {path: readonly <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>[], name: <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>} | <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/null">null</a></code></dt>
|
||||
|
||||
<dd><p>Helper function for defining JavaScript completion sources. It
|
||||
returns the completable name and object path for a completion
|
||||
context, or null if no name/property completion should happen at
|
||||
that position. For example, when completing after <code>a.b.c</code> it will
|
||||
return <code>{path: ["a", "b"], name: "c"}</code>. When completing after <code>x</code>
|
||||
it will return <code>{path: [], name: "x"}</code>. When not in a property or
|
||||
name, it will return null if <code>context.explicit</code> is false, and
|
||||
<code>{path: [], name: ""}</code> otherwise.</p>
|
||||
</dd>
|
||||
<dt id="user-content-scopecompletionsource">
|
||||
<code><strong><a href="#user-content-scopecompletionsource">scopeCompletionSource</a></strong>(<a id="user-content-scopecompletionsource^scope" href="#user-content-scopecompletionsource^scope">scope</a>: any) → <a href="https://codemirror.net/docs/ref#autocomplete.CompletionSource">CompletionSource</a></code></dt>
|
||||
|
||||
<dd><p>Defines a <a href="https://codemirror.net/docs/ref/#autocomplete.CompletionSource">completion source</a> that
|
||||
completes from the given scope object (for example <code>globalThis</code>).
|
||||
Will enter properties of the object when completing properties on
|
||||
a directly-named path.</p>
|
||||
</dd>
|
||||
<dt id="user-content-eslint">
|
||||
<code><strong><a href="#user-content-eslint">esLint</a></strong>(<a id="user-content-eslint^eslint" href="#user-content-eslint^eslint">eslint</a>: any, <a id="user-content-eslint^config" href="#user-content-eslint^config">config</a>⁠?: any) → fn(<a id="user-content-eslint^returns^view" href="#user-content-eslint^returns^view">view</a>: <a href="https://codemirror.net/docs/ref#view.EditorView">EditorView</a>) → <a href="https://codemirror.net/docs/ref#lint.Diagnostic">Diagnostic</a>[]</code></dt>
|
||||
|
||||
<dd><p>Connects an <a href="https://eslint.org/">ESLint</a> linter to CodeMirror's
|
||||
<a href="https://codemirror.net/docs/ref/#lint">lint</a> integration. <code>eslint</code> should be an instance of the
|
||||
<a href="https://eslint.org/docs/developer-guide/nodejs-api#linter"><code>Linter</code></a>
|
||||
class, and <code>config</code> an optional ESLint configuration. The return
|
||||
value of this function can be passed to <a href="https://codemirror.net/docs/ref/#lint.linter"><code>linter</code></a>
|
||||
to create a JavaScript linting extension.</p>
|
||||
<p>Note that ESLint targets node, and is tricky to run in the
|
||||
browser. The
|
||||
<a href="https://github.com/UziTech/eslint-linter-browserify">eslint-linter-browserify</a>
|
||||
package may help with that (see
|
||||
<a href="https://github.com/UziTech/eslint-linter-browserify/blob/master/example/script.js">example</a>).</p>
|
||||
</dd>
|
||||
</dl>
|
||||
486
node_modules/@codemirror/lang-javascript/dist/index.cjs
generated
vendored
Normal file
486
node_modules/@codemirror/lang-javascript/dist/index.cjs
generated
vendored
Normal file
@ -0,0 +1,486 @@
|
||||
'use strict';
|
||||
|
||||
Object.defineProperty(exports, '__esModule', { value: true });
|
||||
|
||||
var javascript$1 = require('@lezer/javascript');
|
||||
var language = require('@codemirror/language');
|
||||
var state = require('@codemirror/state');
|
||||
var view = require('@codemirror/view');
|
||||
var autocomplete = require('@codemirror/autocomplete');
|
||||
var common = require('@lezer/common');
|
||||
|
||||
/**
|
||||
A collection of JavaScript-related
|
||||
[snippets](https://codemirror.net/6/docs/ref/#autocomplete.snippet).
|
||||
*/
|
||||
const snippets = [
|
||||
autocomplete.snippetCompletion("function ${name}(${params}) {\n\t${}\n}", {
|
||||
label: "function",
|
||||
detail: "definition",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("for (let ${index} = 0; ${index} < ${bound}; ${index}++) {\n\t${}\n}", {
|
||||
label: "for",
|
||||
detail: "loop",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("for (let ${name} of ${collection}) {\n\t${}\n}", {
|
||||
label: "for",
|
||||
detail: "of loop",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("do {\n\t${}\n} while (${})", {
|
||||
label: "do",
|
||||
detail: "loop",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("while (${}) {\n\t${}\n}", {
|
||||
label: "while",
|
||||
detail: "loop",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("try {\n\t${}\n} catch (${error}) {\n\t${}\n}", {
|
||||
label: "try",
|
||||
detail: "/ catch block",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("if (${}) {\n\t${}\n}", {
|
||||
label: "if",
|
||||
detail: "block",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("if (${}) {\n\t${}\n} else {\n\t${}\n}", {
|
||||
label: "if",
|
||||
detail: "/ else block",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("class ${name} {\n\tconstructor(${params}) {\n\t\t${}\n\t}\n}", {
|
||||
label: "class",
|
||||
detail: "definition",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("import {${names}} from \"${module}\"\n${}", {
|
||||
label: "import",
|
||||
detail: "named",
|
||||
type: "keyword"
|
||||
}),
|
||||
autocomplete.snippetCompletion("import ${name} from \"${module}\"\n${}", {
|
||||
label: "import",
|
||||
detail: "default",
|
||||
type: "keyword"
|
||||
})
|
||||
];
|
||||
|
||||
const cache = new common.NodeWeakMap();
|
||||
const ScopeNodes = new Set([
|
||||
"Script", "Block",
|
||||
"FunctionExpression", "FunctionDeclaration", "ArrowFunction", "MethodDeclaration",
|
||||
"ForStatement"
|
||||
]);
|
||||
function defID(type) {
|
||||
return (node, def) => {
|
||||
let id = node.node.getChild("VariableDefinition");
|
||||
if (id)
|
||||
def(id, type);
|
||||
return true;
|
||||
};
|
||||
}
|
||||
const functionContext = ["FunctionDeclaration"];
|
||||
const gatherCompletions = {
|
||||
FunctionDeclaration: defID("function"),
|
||||
ClassDeclaration: defID("class"),
|
||||
ClassExpression: () => true,
|
||||
EnumDeclaration: defID("constant"),
|
||||
TypeAliasDeclaration: defID("type"),
|
||||
NamespaceDeclaration: defID("namespace"),
|
||||
VariableDefinition(node, def) { if (!node.matchContext(functionContext))
|
||||
def(node, "variable"); },
|
||||
TypeDefinition(node, def) { def(node, "type"); },
|
||||
__proto__: null
|
||||
};
|
||||
function getScope(doc, node) {
|
||||
let cached = cache.get(node);
|
||||
if (cached)
|
||||
return cached;
|
||||
let completions = [], top = true;
|
||||
function def(node, type) {
|
||||
let name = doc.sliceString(node.from, node.to);
|
||||
completions.push({ label: name, type });
|
||||
}
|
||||
node.cursor(common.IterMode.IncludeAnonymous).iterate(node => {
|
||||
if (top) {
|
||||
top = false;
|
||||
}
|
||||
else if (node.name) {
|
||||
let gather = gatherCompletions[node.name];
|
||||
if (gather && gather(node, def) || ScopeNodes.has(node.name))
|
||||
return false;
|
||||
}
|
||||
else if (node.to - node.from > 8192) {
|
||||
// Allow caching for bigger internal nodes
|
||||
for (let c of getScope(doc, node.node))
|
||||
completions.push(c);
|
||||
return false;
|
||||
}
|
||||
});
|
||||
cache.set(node, completions);
|
||||
return completions;
|
||||
}
|
||||
const Identifier = /^[\w$\xa1-\uffff][\w$\d\xa1-\uffff]*$/;
|
||||
const dontComplete = [
|
||||
"TemplateString", "String", "RegExp",
|
||||
"LineComment", "BlockComment",
|
||||
"VariableDefinition", "TypeDefinition", "Label",
|
||||
"PropertyDefinition", "PropertyName",
|
||||
"PrivatePropertyDefinition", "PrivatePropertyName",
|
||||
".", "?."
|
||||
];
|
||||
/**
|
||||
Completion source that looks up locally defined names in
|
||||
JavaScript code.
|
||||
*/
|
||||
function localCompletionSource(context) {
|
||||
let inner = language.syntaxTree(context.state).resolveInner(context.pos, -1);
|
||||
if (dontComplete.indexOf(inner.name) > -1)
|
||||
return null;
|
||||
let isWord = inner.name == "VariableName" ||
|
||||
inner.to - inner.from < 20 && Identifier.test(context.state.sliceDoc(inner.from, inner.to));
|
||||
if (!isWord && !context.explicit)
|
||||
return null;
|
||||
let options = [];
|
||||
for (let pos = inner; pos; pos = pos.parent) {
|
||||
if (ScopeNodes.has(pos.name))
|
||||
options = options.concat(getScope(context.state.doc, pos));
|
||||
}
|
||||
return {
|
||||
options,
|
||||
from: isWord ? inner.from : context.pos,
|
||||
validFor: Identifier
|
||||
};
|
||||
}
|
||||
function pathFor(read, member, name) {
|
||||
var _a;
|
||||
let path = [];
|
||||
for (;;) {
|
||||
let obj = member.firstChild, prop;
|
||||
if ((obj === null || obj === void 0 ? void 0 : obj.name) == "VariableName") {
|
||||
path.push(read(obj));
|
||||
return { path: path.reverse(), name };
|
||||
}
|
||||
else if ((obj === null || obj === void 0 ? void 0 : obj.name) == "MemberExpression" && ((_a = (prop = obj.lastChild)) === null || _a === void 0 ? void 0 : _a.name) == "PropertyName") {
|
||||
path.push(read(prop));
|
||||
member = obj;
|
||||
}
|
||||
else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
}
|
||||
/**
|
||||
Helper function for defining JavaScript completion sources. It
|
||||
returns the completable name and object path for a completion
|
||||
context, or null if no name/property completion should happen at
|
||||
that position. For example, when completing after `a.b.c` it will
|
||||
return `{path: ["a", "b"], name: "c"}`. When completing after `x`
|
||||
it will return `{path: [], name: "x"}`. When not in a property or
|
||||
name, it will return null if `context.explicit` is false, and
|
||||
`{path: [], name: ""}` otherwise.
|
||||
*/
|
||||
function completionPath(context) {
|
||||
let read = (node) => context.state.doc.sliceString(node.from, node.to);
|
||||
let inner = language.syntaxTree(context.state).resolveInner(context.pos, -1);
|
||||
if (inner.name == "PropertyName") {
|
||||
return pathFor(read, inner.parent, read(inner));
|
||||
}
|
||||
else if ((inner.name == "." || inner.name == "?.") && inner.parent.name == "MemberExpression") {
|
||||
return pathFor(read, inner.parent, "");
|
||||
}
|
||||
else if (dontComplete.indexOf(inner.name) > -1) {
|
||||
return null;
|
||||
}
|
||||
else if (inner.name == "VariableName" || inner.to - inner.from < 20 && Identifier.test(read(inner))) {
|
||||
return { path: [], name: read(inner) };
|
||||
}
|
||||
else if (inner.name == "MemberExpression") {
|
||||
return pathFor(read, inner, "");
|
||||
}
|
||||
else {
|
||||
return context.explicit ? { path: [], name: "" } : null;
|
||||
}
|
||||
}
|
||||
function enumeratePropertyCompletions(obj, top) {
|
||||
let options = [], seen = new Set;
|
||||
for (let depth = 0;; depth++) {
|
||||
for (let name of (Object.getOwnPropertyNames || Object.keys)(obj)) {
|
||||
if (!/^[a-zA-Z_$][\w$]*$/.test(name) || seen.has(name))
|
||||
continue;
|
||||
seen.add(name);
|
||||
let value;
|
||||
try {
|
||||
value = obj[name];
|
||||
}
|
||||
catch (_) {
|
||||
continue;
|
||||
}
|
||||
options.push({
|
||||
label: name,
|
||||
type: typeof value == "function" ? (/^[A-Z]/.test(name) ? "class" : top ? "function" : "method")
|
||||
: top ? "variable" : "property",
|
||||
boost: -depth
|
||||
});
|
||||
}
|
||||
let next = Object.getPrototypeOf(obj);
|
||||
if (!next)
|
||||
return options;
|
||||
obj = next;
|
||||
}
|
||||
}
|
||||
/**
|
||||
Defines a [completion source](https://codemirror.net/6/docs/ref/#autocomplete.CompletionSource) that
|
||||
completes from the given scope object (for example `globalThis`).
|
||||
Will enter properties of the object when completing properties on
|
||||
a directly-named path.
|
||||
*/
|
||||
function scopeCompletionSource(scope) {
|
||||
let cache = new Map;
|
||||
return (context) => {
|
||||
let path = completionPath(context);
|
||||
if (!path)
|
||||
return null;
|
||||
let target = scope;
|
||||
for (let step of path.path) {
|
||||
target = target[step];
|
||||
if (!target)
|
||||
return null;
|
||||
}
|
||||
let options = cache.get(target);
|
||||
if (!options)
|
||||
cache.set(target, options = enumeratePropertyCompletions(target, !path.path.length));
|
||||
return {
|
||||
from: context.pos - path.name.length,
|
||||
options,
|
||||
validFor: Identifier
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
A language provider based on the [Lezer JavaScript
|
||||
parser](https://github.com/lezer-parser/javascript), extended with
|
||||
highlighting and indentation information.
|
||||
*/
|
||||
const javascriptLanguage = language.LRLanguage.define({
|
||||
name: "javascript",
|
||||
parser: javascript$1.parser.configure({
|
||||
props: [
|
||||
language.indentNodeProp.add({
|
||||
IfStatement: language.continuedIndent({ except: /^\s*({|else\b)/ }),
|
||||
TryStatement: language.continuedIndent({ except: /^\s*({|catch\b|finally\b)/ }),
|
||||
LabeledStatement: language.flatIndent,
|
||||
SwitchBody: context => {
|
||||
let after = context.textAfter, closed = /^\s*\}/.test(after), isCase = /^\s*(case|default)\b/.test(after);
|
||||
return context.baseIndent + (closed ? 0 : isCase ? 1 : 2) * context.unit;
|
||||
},
|
||||
Block: language.delimitedIndent({ closing: "}" }),
|
||||
ArrowFunction: cx => cx.baseIndent + cx.unit,
|
||||
"TemplateString BlockComment": () => null,
|
||||
"Statement Property": language.continuedIndent({ except: /^{/ }),
|
||||
JSXElement(context) {
|
||||
let closed = /^\s*<\//.test(context.textAfter);
|
||||
return context.lineIndent(context.node.from) + (closed ? 0 : context.unit);
|
||||
},
|
||||
JSXEscape(context) {
|
||||
let closed = /\s*\}/.test(context.textAfter);
|
||||
return context.lineIndent(context.node.from) + (closed ? 0 : context.unit);
|
||||
},
|
||||
"JSXOpenTag JSXSelfClosingTag"(context) {
|
||||
return context.column(context.node.from) + context.unit;
|
||||
}
|
||||
}),
|
||||
language.foldNodeProp.add({
|
||||
"Block ClassBody SwitchBody EnumBody ObjectExpression ArrayExpression ObjectType": language.foldInside,
|
||||
BlockComment(tree) { return { from: tree.from + 2, to: tree.to - 2 }; }
|
||||
})
|
||||
]
|
||||
}),
|
||||
languageData: {
|
||||
closeBrackets: { brackets: ["(", "[", "{", "'", '"', "`"] },
|
||||
commentTokens: { line: "//", block: { open: "/*", close: "*/" } },
|
||||
indentOnInput: /^\s*(?:case |default:|\{|\}|<\/)$/,
|
||||
wordChars: "$"
|
||||
}
|
||||
});
|
||||
const jsxSublanguage = {
|
||||
test: node => /^JSX/.test(node.name),
|
||||
facet: language.defineLanguageFacet({ commentTokens: { block: { open: "{/*", close: "*/}" } } })
|
||||
};
|
||||
/**
|
||||
A language provider for TypeScript.
|
||||
*/
|
||||
const typescriptLanguage = javascriptLanguage.configure({ dialect: "ts" }, "typescript");
|
||||
/**
|
||||
Language provider for JSX.
|
||||
*/
|
||||
const jsxLanguage = javascriptLanguage.configure({
|
||||
dialect: "jsx",
|
||||
props: [language.sublanguageProp.add(n => n.isTop ? [jsxSublanguage] : undefined)]
|
||||
});
|
||||
/**
|
||||
Language provider for JSX + TypeScript.
|
||||
*/
|
||||
const tsxLanguage = javascriptLanguage.configure({
|
||||
dialect: "jsx ts",
|
||||
props: [language.sublanguageProp.add(n => n.isTop ? [jsxSublanguage] : undefined)]
|
||||
}, "typescript");
|
||||
const keywords = "break case const continue default delete export extends false finally in instanceof let new return static super switch this throw true typeof var yield".split(" ").map(kw => ({ label: kw, type: "keyword" }));
|
||||
/**
|
||||
JavaScript support. Includes [snippet](https://codemirror.net/6/docs/ref/#lang-javascript.snippets)
|
||||
completion.
|
||||
*/
|
||||
function javascript(config = {}) {
|
||||
let lang = config.jsx ? (config.typescript ? tsxLanguage : jsxLanguage)
|
||||
: config.typescript ? typescriptLanguage : javascriptLanguage;
|
||||
return new language.LanguageSupport(lang, [
|
||||
javascriptLanguage.data.of({
|
||||
autocomplete: autocomplete.ifNotIn(dontComplete, autocomplete.completeFromList(snippets.concat(keywords)))
|
||||
}),
|
||||
javascriptLanguage.data.of({
|
||||
autocomplete: localCompletionSource
|
||||
}),
|
||||
config.jsx ? autoCloseTags : [],
|
||||
]);
|
||||
}
|
||||
function findOpenTag(node) {
|
||||
for (;;) {
|
||||
if (node.name == "JSXOpenTag" || node.name == "JSXSelfClosingTag" || node.name == "JSXFragmentTag")
|
||||
return node;
|
||||
if (node.name == "JSXEscape" || !node.parent)
|
||||
return null;
|
||||
node = node.parent;
|
||||
}
|
||||
}
|
||||
function elementName(doc, tree, max = doc.length) {
|
||||
for (let ch = tree === null || tree === void 0 ? void 0 : tree.firstChild; ch; ch = ch.nextSibling) {
|
||||
if (ch.name == "JSXIdentifier" || ch.name == "JSXBuiltin" || ch.name == "JSXNamespacedName" ||
|
||||
ch.name == "JSXMemberExpression")
|
||||
return doc.sliceString(ch.from, Math.min(ch.to, max));
|
||||
}
|
||||
return "";
|
||||
}
|
||||
function isEndTag(node) {
|
||||
return node && (node.name == "JSXEndTag" || node.name == "JSXSelfCloseEndTag");
|
||||
}
|
||||
const android = typeof navigator == "object" && /Android\b/.test(navigator.userAgent);
|
||||
/**
|
||||
Extension that will automatically insert JSX close tags when a `>` or
|
||||
`/` is typed.
|
||||
*/
|
||||
const autoCloseTags = view.EditorView.inputHandler.of((view, from, to, text) => {
|
||||
if ((android ? view.composing : view.compositionStarted) || view.state.readOnly ||
|
||||
from != to || (text != ">" && text != "/") ||
|
||||
!javascriptLanguage.isActiveAt(view.state, from, -1))
|
||||
return false;
|
||||
let { state: state$1 } = view;
|
||||
let changes = state$1.changeByRange(range => {
|
||||
var _a;
|
||||
let { head } = range, around = language.syntaxTree(state$1).resolveInner(head, -1), name;
|
||||
if (around.name == "JSXStartTag")
|
||||
around = around.parent;
|
||||
if (around.name == "JSXAttributeValue" && around.to > head) ;
|
||||
else if (text == ">" && around.name == "JSXFragmentTag") {
|
||||
return { range: state.EditorSelection.cursor(head + 1), changes: { from: head, insert: `></>` } };
|
||||
}
|
||||
else if (text == "/" && around.name == "JSXFragmentTag") {
|
||||
let empty = around.parent, base = empty === null || empty === void 0 ? void 0 : empty.parent;
|
||||
if (empty.from == head - 1 && ((_a = base.lastChild) === null || _a === void 0 ? void 0 : _a.name) != "JSXEndTag" &&
|
||||
(name = elementName(state$1.doc, base === null || base === void 0 ? void 0 : base.firstChild, head))) {
|
||||
let insert = `/${name}>`;
|
||||
return { range: state.EditorSelection.cursor(head + insert.length), changes: { from: head, insert } };
|
||||
}
|
||||
}
|
||||
else if (text == ">") {
|
||||
let openTag = findOpenTag(around);
|
||||
if (openTag && !isEndTag(openTag.lastChild) &&
|
||||
state$1.sliceDoc(head, head + 2) != "</" &&
|
||||
(name = elementName(state$1.doc, openTag, head)))
|
||||
return { range: state.EditorSelection.cursor(head + 1), changes: { from: head, insert: `></${name}>` } };
|
||||
}
|
||||
return { range };
|
||||
});
|
||||
if (changes.changes.empty)
|
||||
return false;
|
||||
view.dispatch(changes, { userEvent: "input.type", scrollIntoView: true });
|
||||
return true;
|
||||
});
|
||||
|
||||
/**
|
||||
Connects an [ESLint](https://eslint.org/) linter to CodeMirror's
|
||||
[lint](https://codemirror.net/6/docs/ref/#lint) integration. `eslint` should be an instance of the
|
||||
[`Linter`](https://eslint.org/docs/developer-guide/nodejs-api#linter)
|
||||
class, and `config` an optional ESLint configuration. The return
|
||||
value of this function can be passed to [`linter`](https://codemirror.net/6/docs/ref/#lint.linter)
|
||||
to create a JavaScript linting extension.
|
||||
|
||||
Note that ESLint targets node, and is tricky to run in the
|
||||
browser. The
|
||||
[eslint-linter-browserify](https://github.com/UziTech/eslint-linter-browserify)
|
||||
package may help with that (see
|
||||
[example](https://github.com/UziTech/eslint-linter-browserify/blob/master/example/script.js)).
|
||||
*/
|
||||
function esLint(eslint, config) {
|
||||
if (!config) {
|
||||
config = {
|
||||
parserOptions: { ecmaVersion: 2019, sourceType: "module" },
|
||||
env: { browser: true, node: true, es6: true, es2015: true, es2017: true, es2020: true },
|
||||
rules: {}
|
||||
};
|
||||
eslint.getRules().forEach((desc, name) => {
|
||||
if (desc.meta.docs.recommended)
|
||||
config.rules[name] = 2;
|
||||
});
|
||||
}
|
||||
return (view) => {
|
||||
let { state } = view, found = [];
|
||||
for (let { from, to } of javascriptLanguage.findRegions(state)) {
|
||||
let fromLine = state.doc.lineAt(from), offset = { line: fromLine.number - 1, col: from - fromLine.from, pos: from };
|
||||
for (let d of eslint.verify(state.sliceDoc(from, to), config))
|
||||
found.push(translateDiagnostic(d, state.doc, offset));
|
||||
}
|
||||
return found;
|
||||
};
|
||||
}
|
||||
function mapPos(line, col, doc, offset) {
|
||||
return doc.line(line + offset.line).from + col + (line == 1 ? offset.col - 1 : -1);
|
||||
}
|
||||
function translateDiagnostic(input, doc, offset) {
|
||||
let start = mapPos(input.line, input.column, doc, offset);
|
||||
let result = {
|
||||
from: start,
|
||||
to: input.endLine != null && input.endColumn != 1 ? mapPos(input.endLine, input.endColumn, doc, offset) : start,
|
||||
message: input.message,
|
||||
source: input.ruleId ? "eslint:" + input.ruleId : "eslint",
|
||||
severity: input.severity == 1 ? "warning" : "error",
|
||||
};
|
||||
if (input.fix) {
|
||||
let { range, text } = input.fix, from = range[0] + offset.pos - start, to = range[1] + offset.pos - start;
|
||||
result.actions = [{
|
||||
name: "fix",
|
||||
apply(view, start) {
|
||||
view.dispatch({ changes: { from: start + from, to: start + to, insert: text }, scrollIntoView: true });
|
||||
}
|
||||
}];
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
exports.autoCloseTags = autoCloseTags;
|
||||
exports.completionPath = completionPath;
|
||||
exports.esLint = esLint;
|
||||
exports.javascript = javascript;
|
||||
exports.javascriptLanguage = javascriptLanguage;
|
||||
exports.jsxLanguage = jsxLanguage;
|
||||
exports.localCompletionSource = localCompletionSource;
|
||||
exports.scopeCompletionSource = scopeCompletionSource;
|
||||
exports.snippets = snippets;
|
||||
exports.tsxLanguage = tsxLanguage;
|
||||
exports.typescriptLanguage = typescriptLanguage;
|
||||
88
node_modules/@codemirror/lang-javascript/dist/index.d.cts
generated
vendored
Normal file
88
node_modules/@codemirror/lang-javascript/dist/index.d.cts
generated
vendored
Normal file
@ -0,0 +1,88 @@
|
||||
import * as _codemirror_state from '@codemirror/state';
|
||||
import { LRLanguage, LanguageSupport } from '@codemirror/language';
|
||||
import { Completion, CompletionContext, CompletionResult, CompletionSource } from '@codemirror/autocomplete';
|
||||
import { Diagnostic } from '@codemirror/lint';
|
||||
import { EditorView } from '@codemirror/view';
|
||||
|
||||
/**
|
||||
A language provider based on the [Lezer JavaScript
|
||||
parser](https://github.com/lezer-parser/javascript), extended with
|
||||
highlighting and indentation information.
|
||||
*/
|
||||
declare const javascriptLanguage: LRLanguage;
|
||||
/**
|
||||
A language provider for TypeScript.
|
||||
*/
|
||||
declare const typescriptLanguage: LRLanguage;
|
||||
/**
|
||||
Language provider for JSX.
|
||||
*/
|
||||
declare const jsxLanguage: LRLanguage;
|
||||
/**
|
||||
Language provider for JSX + TypeScript.
|
||||
*/
|
||||
declare const tsxLanguage: LRLanguage;
|
||||
/**
|
||||
JavaScript support. Includes [snippet](https://codemirror.net/6/docs/ref/#lang-javascript.snippets)
|
||||
completion.
|
||||
*/
|
||||
declare function javascript(config?: {
|
||||
jsx?: boolean;
|
||||
typescript?: boolean;
|
||||
}): LanguageSupport;
|
||||
/**
|
||||
Extension that will automatically insert JSX close tags when a `>` or
|
||||
`/` is typed.
|
||||
*/
|
||||
declare const autoCloseTags: _codemirror_state.Extension;
|
||||
|
||||
/**
|
||||
A collection of JavaScript-related
|
||||
[snippets](https://codemirror.net/6/docs/ref/#autocomplete.snippet).
|
||||
*/
|
||||
declare const snippets: readonly Completion[];
|
||||
|
||||
/**
|
||||
Connects an [ESLint](https://eslint.org/) linter to CodeMirror's
|
||||
[lint](https://codemirror.net/6/docs/ref/#lint) integration. `eslint` should be an instance of the
|
||||
[`Linter`](https://eslint.org/docs/developer-guide/nodejs-api#linter)
|
||||
class, and `config` an optional ESLint configuration. The return
|
||||
value of this function can be passed to [`linter`](https://codemirror.net/6/docs/ref/#lint.linter)
|
||||
to create a JavaScript linting extension.
|
||||
|
||||
Note that ESLint targets node, and is tricky to run in the
|
||||
browser. The
|
||||
[eslint-linter-browserify](https://github.com/UziTech/eslint-linter-browserify)
|
||||
package may help with that (see
|
||||
[example](https://github.com/UziTech/eslint-linter-browserify/blob/master/example/script.js)).
|
||||
*/
|
||||
declare function esLint(eslint: any, config?: any): (view: EditorView) => Diagnostic[];
|
||||
|
||||
/**
|
||||
Completion source that looks up locally defined names in
|
||||
JavaScript code.
|
||||
*/
|
||||
declare function localCompletionSource(context: CompletionContext): CompletionResult | null;
|
||||
/**
|
||||
Helper function for defining JavaScript completion sources. It
|
||||
returns the completable name and object path for a completion
|
||||
context, or null if no name/property completion should happen at
|
||||
that position. For example, when completing after `a.b.c` it will
|
||||
return `{path: ["a", "b"], name: "c"}`. When completing after `x`
|
||||
it will return `{path: [], name: "x"}`. When not in a property or
|
||||
name, it will return null if `context.explicit` is false, and
|
||||
`{path: [], name: ""}` otherwise.
|
||||
*/
|
||||
declare function completionPath(context: CompletionContext): {
|
||||
path: readonly string[];
|
||||
name: string;
|
||||
} | null;
|
||||
/**
|
||||
Defines a [completion source](https://codemirror.net/6/docs/ref/#autocomplete.CompletionSource) that
|
||||
completes from the given scope object (for example `globalThis`).
|
||||
Will enter properties of the object when completing properties on
|
||||
a directly-named path.
|
||||
*/
|
||||
declare function scopeCompletionSource(scope: any): CompletionSource;
|
||||
|
||||
export { autoCloseTags, completionPath, esLint, javascript, javascriptLanguage, jsxLanguage, localCompletionSource, scopeCompletionSource, snippets, tsxLanguage, typescriptLanguage };
|
||||
88
node_modules/@codemirror/lang-javascript/dist/index.d.ts
generated
vendored
Normal file
88
node_modules/@codemirror/lang-javascript/dist/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,88 @@
|
||||
import * as _codemirror_state from '@codemirror/state';
|
||||
import { LRLanguage, LanguageSupport } from '@codemirror/language';
|
||||
import { Completion, CompletionContext, CompletionResult, CompletionSource } from '@codemirror/autocomplete';
|
||||
import { Diagnostic } from '@codemirror/lint';
|
||||
import { EditorView } from '@codemirror/view';
|
||||
|
||||
/**
|
||||
A language provider based on the [Lezer JavaScript
|
||||
parser](https://github.com/lezer-parser/javascript), extended with
|
||||
highlighting and indentation information.
|
||||
*/
|
||||
declare const javascriptLanguage: LRLanguage;
|
||||
/**
|
||||
A language provider for TypeScript.
|
||||
*/
|
||||
declare const typescriptLanguage: LRLanguage;
|
||||
/**
|
||||
Language provider for JSX.
|
||||
*/
|
||||
declare const jsxLanguage: LRLanguage;
|
||||
/**
|
||||
Language provider for JSX + TypeScript.
|
||||
*/
|
||||
declare const tsxLanguage: LRLanguage;
|
||||
/**
|
||||
JavaScript support. Includes [snippet](https://codemirror.net/6/docs/ref/#lang-javascript.snippets)
|
||||
completion.
|
||||
*/
|
||||
declare function javascript(config?: {
|
||||
jsx?: boolean;
|
||||
typescript?: boolean;
|
||||
}): LanguageSupport;
|
||||
/**
|
||||
Extension that will automatically insert JSX close tags when a `>` or
|
||||
`/` is typed.
|
||||
*/
|
||||
declare const autoCloseTags: _codemirror_state.Extension;
|
||||
|
||||
/**
|
||||
A collection of JavaScript-related
|
||||
[snippets](https://codemirror.net/6/docs/ref/#autocomplete.snippet).
|
||||
*/
|
||||
declare const snippets: readonly Completion[];
|
||||
|
||||
/**
|
||||
Connects an [ESLint](https://eslint.org/) linter to CodeMirror's
|
||||
[lint](https://codemirror.net/6/docs/ref/#lint) integration. `eslint` should be an instance of the
|
||||
[`Linter`](https://eslint.org/docs/developer-guide/nodejs-api#linter)
|
||||
class, and `config` an optional ESLint configuration. The return
|
||||
value of this function can be passed to [`linter`](https://codemirror.net/6/docs/ref/#lint.linter)
|
||||
to create a JavaScript linting extension.
|
||||
|
||||
Note that ESLint targets node, and is tricky to run in the
|
||||
browser. The
|
||||
[eslint-linter-browserify](https://github.com/UziTech/eslint-linter-browserify)
|
||||
package may help with that (see
|
||||
[example](https://github.com/UziTech/eslint-linter-browserify/blob/master/example/script.js)).
|
||||
*/
|
||||
declare function esLint(eslint: any, config?: any): (view: EditorView) => Diagnostic[];
|
||||
|
||||
/**
|
||||
Completion source that looks up locally defined names in
|
||||
JavaScript code.
|
||||
*/
|
||||
declare function localCompletionSource(context: CompletionContext): CompletionResult | null;
|
||||
/**
|
||||
Helper function for defining JavaScript completion sources. It
|
||||
returns the completable name and object path for a completion
|
||||
context, or null if no name/property completion should happen at
|
||||
that position. For example, when completing after `a.b.c` it will
|
||||
return `{path: ["a", "b"], name: "c"}`. When completing after `x`
|
||||
it will return `{path: [], name: "x"}`. When not in a property or
|
||||
name, it will return null if `context.explicit` is false, and
|
||||
`{path: [], name: ""}` otherwise.
|
||||
*/
|
||||
declare function completionPath(context: CompletionContext): {
|
||||
path: readonly string[];
|
||||
name: string;
|
||||
} | null;
|
||||
/**
|
||||
Defines a [completion source](https://codemirror.net/6/docs/ref/#autocomplete.CompletionSource) that
|
||||
completes from the given scope object (for example `globalThis`).
|
||||
Will enter properties of the object when completing properties on
|
||||
a directly-named path.
|
||||
*/
|
||||
declare function scopeCompletionSource(scope: any): CompletionSource;
|
||||
|
||||
export { autoCloseTags, completionPath, esLint, javascript, javascriptLanguage, jsxLanguage, localCompletionSource, scopeCompletionSource, snippets, tsxLanguage, typescriptLanguage };
|
||||
472
node_modules/@codemirror/lang-javascript/dist/index.js
generated
vendored
Normal file
472
node_modules/@codemirror/lang-javascript/dist/index.js
generated
vendored
Normal file
@ -0,0 +1,472 @@
|
||||
import { parser } from '@lezer/javascript';
|
||||
import { syntaxTree, LRLanguage, indentNodeProp, continuedIndent, flatIndent, delimitedIndent, foldNodeProp, foldInside, defineLanguageFacet, sublanguageProp, LanguageSupport } from '@codemirror/language';
|
||||
import { EditorSelection } from '@codemirror/state';
|
||||
import { EditorView } from '@codemirror/view';
|
||||
import { snippetCompletion, ifNotIn, completeFromList } from '@codemirror/autocomplete';
|
||||
import { NodeWeakMap, IterMode } from '@lezer/common';
|
||||
|
||||
/**
|
||||
A collection of JavaScript-related
|
||||
[snippets](https://codemirror.net/6/docs/ref/#autocomplete.snippet).
|
||||
*/
|
||||
const snippets = [
|
||||
/*@__PURE__*/snippetCompletion("function ${name}(${params}) {\n\t${}\n}", {
|
||||
label: "function",
|
||||
detail: "definition",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("for (let ${index} = 0; ${index} < ${bound}; ${index}++) {\n\t${}\n}", {
|
||||
label: "for",
|
||||
detail: "loop",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("for (let ${name} of ${collection}) {\n\t${}\n}", {
|
||||
label: "for",
|
||||
detail: "of loop",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("do {\n\t${}\n} while (${})", {
|
||||
label: "do",
|
||||
detail: "loop",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("while (${}) {\n\t${}\n}", {
|
||||
label: "while",
|
||||
detail: "loop",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("try {\n\t${}\n} catch (${error}) {\n\t${}\n}", {
|
||||
label: "try",
|
||||
detail: "/ catch block",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("if (${}) {\n\t${}\n}", {
|
||||
label: "if",
|
||||
detail: "block",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("if (${}) {\n\t${}\n} else {\n\t${}\n}", {
|
||||
label: "if",
|
||||
detail: "/ else block",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("class ${name} {\n\tconstructor(${params}) {\n\t\t${}\n\t}\n}", {
|
||||
label: "class",
|
||||
detail: "definition",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("import {${names}} from \"${module}\"\n${}", {
|
||||
label: "import",
|
||||
detail: "named",
|
||||
type: "keyword"
|
||||
}),
|
||||
/*@__PURE__*/snippetCompletion("import ${name} from \"${module}\"\n${}", {
|
||||
label: "import",
|
||||
detail: "default",
|
||||
type: "keyword"
|
||||
})
|
||||
];
|
||||
|
||||
const cache = /*@__PURE__*/new NodeWeakMap();
|
||||
const ScopeNodes = /*@__PURE__*/new Set([
|
||||
"Script", "Block",
|
||||
"FunctionExpression", "FunctionDeclaration", "ArrowFunction", "MethodDeclaration",
|
||||
"ForStatement"
|
||||
]);
|
||||
function defID(type) {
|
||||
return (node, def) => {
|
||||
let id = node.node.getChild("VariableDefinition");
|
||||
if (id)
|
||||
def(id, type);
|
||||
return true;
|
||||
};
|
||||
}
|
||||
const functionContext = ["FunctionDeclaration"];
|
||||
const gatherCompletions = {
|
||||
FunctionDeclaration: /*@__PURE__*/defID("function"),
|
||||
ClassDeclaration: /*@__PURE__*/defID("class"),
|
||||
ClassExpression: () => true,
|
||||
EnumDeclaration: /*@__PURE__*/defID("constant"),
|
||||
TypeAliasDeclaration: /*@__PURE__*/defID("type"),
|
||||
NamespaceDeclaration: /*@__PURE__*/defID("namespace"),
|
||||
VariableDefinition(node, def) { if (!node.matchContext(functionContext))
|
||||
def(node, "variable"); },
|
||||
TypeDefinition(node, def) { def(node, "type"); },
|
||||
__proto__: null
|
||||
};
|
||||
function getScope(doc, node) {
|
||||
let cached = cache.get(node);
|
||||
if (cached)
|
||||
return cached;
|
||||
let completions = [], top = true;
|
||||
function def(node, type) {
|
||||
let name = doc.sliceString(node.from, node.to);
|
||||
completions.push({ label: name, type });
|
||||
}
|
||||
node.cursor(IterMode.IncludeAnonymous).iterate(node => {
|
||||
if (top) {
|
||||
top = false;
|
||||
}
|
||||
else if (node.name) {
|
||||
let gather = gatherCompletions[node.name];
|
||||
if (gather && gather(node, def) || ScopeNodes.has(node.name))
|
||||
return false;
|
||||
}
|
||||
else if (node.to - node.from > 8192) {
|
||||
// Allow caching for bigger internal nodes
|
||||
for (let c of getScope(doc, node.node))
|
||||
completions.push(c);
|
||||
return false;
|
||||
}
|
||||
});
|
||||
cache.set(node, completions);
|
||||
return completions;
|
||||
}
|
||||
const Identifier = /^[\w$\xa1-\uffff][\w$\d\xa1-\uffff]*$/;
|
||||
const dontComplete = [
|
||||
"TemplateString", "String", "RegExp",
|
||||
"LineComment", "BlockComment",
|
||||
"VariableDefinition", "TypeDefinition", "Label",
|
||||
"PropertyDefinition", "PropertyName",
|
||||
"PrivatePropertyDefinition", "PrivatePropertyName",
|
||||
".", "?."
|
||||
];
|
||||
/**
|
||||
Completion source that looks up locally defined names in
|
||||
JavaScript code.
|
||||
*/
|
||||
function localCompletionSource(context) {
|
||||
let inner = syntaxTree(context.state).resolveInner(context.pos, -1);
|
||||
if (dontComplete.indexOf(inner.name) > -1)
|
||||
return null;
|
||||
let isWord = inner.name == "VariableName" ||
|
||||
inner.to - inner.from < 20 && Identifier.test(context.state.sliceDoc(inner.from, inner.to));
|
||||
if (!isWord && !context.explicit)
|
||||
return null;
|
||||
let options = [];
|
||||
for (let pos = inner; pos; pos = pos.parent) {
|
||||
if (ScopeNodes.has(pos.name))
|
||||
options = options.concat(getScope(context.state.doc, pos));
|
||||
}
|
||||
return {
|
||||
options,
|
||||
from: isWord ? inner.from : context.pos,
|
||||
validFor: Identifier
|
||||
};
|
||||
}
|
||||
function pathFor(read, member, name) {
|
||||
var _a;
|
||||
let path = [];
|
||||
for (;;) {
|
||||
let obj = member.firstChild, prop;
|
||||
if ((obj === null || obj === void 0 ? void 0 : obj.name) == "VariableName") {
|
||||
path.push(read(obj));
|
||||
return { path: path.reverse(), name };
|
||||
}
|
||||
else if ((obj === null || obj === void 0 ? void 0 : obj.name) == "MemberExpression" && ((_a = (prop = obj.lastChild)) === null || _a === void 0 ? void 0 : _a.name) == "PropertyName") {
|
||||
path.push(read(prop));
|
||||
member = obj;
|
||||
}
|
||||
else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
}
|
||||
/**
|
||||
Helper function for defining JavaScript completion sources. It
|
||||
returns the completable name and object path for a completion
|
||||
context, or null if no name/property completion should happen at
|
||||
that position. For example, when completing after `a.b.c` it will
|
||||
return `{path: ["a", "b"], name: "c"}`. When completing after `x`
|
||||
it will return `{path: [], name: "x"}`. When not in a property or
|
||||
name, it will return null if `context.explicit` is false, and
|
||||
`{path: [], name: ""}` otherwise.
|
||||
*/
|
||||
function completionPath(context) {
|
||||
let read = (node) => context.state.doc.sliceString(node.from, node.to);
|
||||
let inner = syntaxTree(context.state).resolveInner(context.pos, -1);
|
||||
if (inner.name == "PropertyName") {
|
||||
return pathFor(read, inner.parent, read(inner));
|
||||
}
|
||||
else if ((inner.name == "." || inner.name == "?.") && inner.parent.name == "MemberExpression") {
|
||||
return pathFor(read, inner.parent, "");
|
||||
}
|
||||
else if (dontComplete.indexOf(inner.name) > -1) {
|
||||
return null;
|
||||
}
|
||||
else if (inner.name == "VariableName" || inner.to - inner.from < 20 && Identifier.test(read(inner))) {
|
||||
return { path: [], name: read(inner) };
|
||||
}
|
||||
else if (inner.name == "MemberExpression") {
|
||||
return pathFor(read, inner, "");
|
||||
}
|
||||
else {
|
||||
return context.explicit ? { path: [], name: "" } : null;
|
||||
}
|
||||
}
|
||||
function enumeratePropertyCompletions(obj, top) {
|
||||
let options = [], seen = new Set;
|
||||
for (let depth = 0;; depth++) {
|
||||
for (let name of (Object.getOwnPropertyNames || Object.keys)(obj)) {
|
||||
if (!/^[a-zA-Z_$][\w$]*$/.test(name) || seen.has(name))
|
||||
continue;
|
||||
seen.add(name);
|
||||
let value;
|
||||
try {
|
||||
value = obj[name];
|
||||
}
|
||||
catch (_) {
|
||||
continue;
|
||||
}
|
||||
options.push({
|
||||
label: name,
|
||||
type: typeof value == "function" ? (/^[A-Z]/.test(name) ? "class" : top ? "function" : "method")
|
||||
: top ? "variable" : "property",
|
||||
boost: -depth
|
||||
});
|
||||
}
|
||||
let next = Object.getPrototypeOf(obj);
|
||||
if (!next)
|
||||
return options;
|
||||
obj = next;
|
||||
}
|
||||
}
|
||||
/**
|
||||
Defines a [completion source](https://codemirror.net/6/docs/ref/#autocomplete.CompletionSource) that
|
||||
completes from the given scope object (for example `globalThis`).
|
||||
Will enter properties of the object when completing properties on
|
||||
a directly-named path.
|
||||
*/
|
||||
function scopeCompletionSource(scope) {
|
||||
let cache = new Map;
|
||||
return (context) => {
|
||||
let path = completionPath(context);
|
||||
if (!path)
|
||||
return null;
|
||||
let target = scope;
|
||||
for (let step of path.path) {
|
||||
target = target[step];
|
||||
if (!target)
|
||||
return null;
|
||||
}
|
||||
let options = cache.get(target);
|
||||
if (!options)
|
||||
cache.set(target, options = enumeratePropertyCompletions(target, !path.path.length));
|
||||
return {
|
||||
from: context.pos - path.name.length,
|
||||
options,
|
||||
validFor: Identifier
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
A language provider based on the [Lezer JavaScript
|
||||
parser](https://github.com/lezer-parser/javascript), extended with
|
||||
highlighting and indentation information.
|
||||
*/
|
||||
const javascriptLanguage = /*@__PURE__*/LRLanguage.define({
|
||||
name: "javascript",
|
||||
parser: /*@__PURE__*/parser.configure({
|
||||
props: [
|
||||
/*@__PURE__*/indentNodeProp.add({
|
||||
IfStatement: /*@__PURE__*/continuedIndent({ except: /^\s*({|else\b)/ }),
|
||||
TryStatement: /*@__PURE__*/continuedIndent({ except: /^\s*({|catch\b|finally\b)/ }),
|
||||
LabeledStatement: flatIndent,
|
||||
SwitchBody: context => {
|
||||
let after = context.textAfter, closed = /^\s*\}/.test(after), isCase = /^\s*(case|default)\b/.test(after);
|
||||
return context.baseIndent + (closed ? 0 : isCase ? 1 : 2) * context.unit;
|
||||
},
|
||||
Block: /*@__PURE__*/delimitedIndent({ closing: "}" }),
|
||||
ArrowFunction: cx => cx.baseIndent + cx.unit,
|
||||
"TemplateString BlockComment": () => null,
|
||||
"Statement Property": /*@__PURE__*/continuedIndent({ except: /^{/ }),
|
||||
JSXElement(context) {
|
||||
let closed = /^\s*<\//.test(context.textAfter);
|
||||
return context.lineIndent(context.node.from) + (closed ? 0 : context.unit);
|
||||
},
|
||||
JSXEscape(context) {
|
||||
let closed = /\s*\}/.test(context.textAfter);
|
||||
return context.lineIndent(context.node.from) + (closed ? 0 : context.unit);
|
||||
},
|
||||
"JSXOpenTag JSXSelfClosingTag"(context) {
|
||||
return context.column(context.node.from) + context.unit;
|
||||
}
|
||||
}),
|
||||
/*@__PURE__*/foldNodeProp.add({
|
||||
"Block ClassBody SwitchBody EnumBody ObjectExpression ArrayExpression ObjectType": foldInside,
|
||||
BlockComment(tree) { return { from: tree.from + 2, to: tree.to - 2 }; }
|
||||
})
|
||||
]
|
||||
}),
|
||||
languageData: {
|
||||
closeBrackets: { brackets: ["(", "[", "{", "'", '"', "`"] },
|
||||
commentTokens: { line: "//", block: { open: "/*", close: "*/" } },
|
||||
indentOnInput: /^\s*(?:case |default:|\{|\}|<\/)$/,
|
||||
wordChars: "$"
|
||||
}
|
||||
});
|
||||
const jsxSublanguage = {
|
||||
test: node => /^JSX/.test(node.name),
|
||||
facet: /*@__PURE__*/defineLanguageFacet({ commentTokens: { block: { open: "{/*", close: "*/}" } } })
|
||||
};
|
||||
/**
|
||||
A language provider for TypeScript.
|
||||
*/
|
||||
const typescriptLanguage = /*@__PURE__*/javascriptLanguage.configure({ dialect: "ts" }, "typescript");
|
||||
/**
|
||||
Language provider for JSX.
|
||||
*/
|
||||
const jsxLanguage = /*@__PURE__*/javascriptLanguage.configure({
|
||||
dialect: "jsx",
|
||||
props: [/*@__PURE__*/sublanguageProp.add(n => n.isTop ? [jsxSublanguage] : undefined)]
|
||||
});
|
||||
/**
|
||||
Language provider for JSX + TypeScript.
|
||||
*/
|
||||
const tsxLanguage = /*@__PURE__*/javascriptLanguage.configure({
|
||||
dialect: "jsx ts",
|
||||
props: [/*@__PURE__*/sublanguageProp.add(n => n.isTop ? [jsxSublanguage] : undefined)]
|
||||
}, "typescript");
|
||||
const keywords = /*@__PURE__*/"break case const continue default delete export extends false finally in instanceof let new return static super switch this throw true typeof var yield".split(" ").map(kw => ({ label: kw, type: "keyword" }));
|
||||
/**
|
||||
JavaScript support. Includes [snippet](https://codemirror.net/6/docs/ref/#lang-javascript.snippets)
|
||||
completion.
|
||||
*/
|
||||
function javascript(config = {}) {
|
||||
let lang = config.jsx ? (config.typescript ? tsxLanguage : jsxLanguage)
|
||||
: config.typescript ? typescriptLanguage : javascriptLanguage;
|
||||
return new LanguageSupport(lang, [
|
||||
javascriptLanguage.data.of({
|
||||
autocomplete: ifNotIn(dontComplete, completeFromList(snippets.concat(keywords)))
|
||||
}),
|
||||
javascriptLanguage.data.of({
|
||||
autocomplete: localCompletionSource
|
||||
}),
|
||||
config.jsx ? autoCloseTags : [],
|
||||
]);
|
||||
}
|
||||
function findOpenTag(node) {
|
||||
for (;;) {
|
||||
if (node.name == "JSXOpenTag" || node.name == "JSXSelfClosingTag" || node.name == "JSXFragmentTag")
|
||||
return node;
|
||||
if (node.name == "JSXEscape" || !node.parent)
|
||||
return null;
|
||||
node = node.parent;
|
||||
}
|
||||
}
|
||||
function elementName(doc, tree, max = doc.length) {
|
||||
for (let ch = tree === null || tree === void 0 ? void 0 : tree.firstChild; ch; ch = ch.nextSibling) {
|
||||
if (ch.name == "JSXIdentifier" || ch.name == "JSXBuiltin" || ch.name == "JSXNamespacedName" ||
|
||||
ch.name == "JSXMemberExpression")
|
||||
return doc.sliceString(ch.from, Math.min(ch.to, max));
|
||||
}
|
||||
return "";
|
||||
}
|
||||
function isEndTag(node) {
|
||||
return node && (node.name == "JSXEndTag" || node.name == "JSXSelfCloseEndTag");
|
||||
}
|
||||
const android = typeof navigator == "object" && /*@__PURE__*//Android\b/.test(navigator.userAgent);
|
||||
/**
|
||||
Extension that will automatically insert JSX close tags when a `>` or
|
||||
`/` is typed.
|
||||
*/
|
||||
const autoCloseTags = /*@__PURE__*/EditorView.inputHandler.of((view, from, to, text) => {
|
||||
if ((android ? view.composing : view.compositionStarted) || view.state.readOnly ||
|
||||
from != to || (text != ">" && text != "/") ||
|
||||
!javascriptLanguage.isActiveAt(view.state, from, -1))
|
||||
return false;
|
||||
let { state } = view;
|
||||
let changes = state.changeByRange(range => {
|
||||
var _a;
|
||||
let { head } = range, around = syntaxTree(state).resolveInner(head, -1), name;
|
||||
if (around.name == "JSXStartTag")
|
||||
around = around.parent;
|
||||
if (around.name == "JSXAttributeValue" && around.to > head) ;
|
||||
else if (text == ">" && around.name == "JSXFragmentTag") {
|
||||
return { range: EditorSelection.cursor(head + 1), changes: { from: head, insert: `></>` } };
|
||||
}
|
||||
else if (text == "/" && around.name == "JSXFragmentTag") {
|
||||
let empty = around.parent, base = empty === null || empty === void 0 ? void 0 : empty.parent;
|
||||
if (empty.from == head - 1 && ((_a = base.lastChild) === null || _a === void 0 ? void 0 : _a.name) != "JSXEndTag" &&
|
||||
(name = elementName(state.doc, base === null || base === void 0 ? void 0 : base.firstChild, head))) {
|
||||
let insert = `/${name}>`;
|
||||
return { range: EditorSelection.cursor(head + insert.length), changes: { from: head, insert } };
|
||||
}
|
||||
}
|
||||
else if (text == ">") {
|
||||
let openTag = findOpenTag(around);
|
||||
if (openTag && !isEndTag(openTag.lastChild) &&
|
||||
state.sliceDoc(head, head + 2) != "</" &&
|
||||
(name = elementName(state.doc, openTag, head)))
|
||||
return { range: EditorSelection.cursor(head + 1), changes: { from: head, insert: `></${name}>` } };
|
||||
}
|
||||
return { range };
|
||||
});
|
||||
if (changes.changes.empty)
|
||||
return false;
|
||||
view.dispatch(changes, { userEvent: "input.type", scrollIntoView: true });
|
||||
return true;
|
||||
});
|
||||
|
||||
/**
|
||||
Connects an [ESLint](https://eslint.org/) linter to CodeMirror's
|
||||
[lint](https://codemirror.net/6/docs/ref/#lint) integration. `eslint` should be an instance of the
|
||||
[`Linter`](https://eslint.org/docs/developer-guide/nodejs-api#linter)
|
||||
class, and `config` an optional ESLint configuration. The return
|
||||
value of this function can be passed to [`linter`](https://codemirror.net/6/docs/ref/#lint.linter)
|
||||
to create a JavaScript linting extension.
|
||||
|
||||
Note that ESLint targets node, and is tricky to run in the
|
||||
browser. The
|
||||
[eslint-linter-browserify](https://github.com/UziTech/eslint-linter-browserify)
|
||||
package may help with that (see
|
||||
[example](https://github.com/UziTech/eslint-linter-browserify/blob/master/example/script.js)).
|
||||
*/
|
||||
function esLint(eslint, config) {
|
||||
if (!config) {
|
||||
config = {
|
||||
parserOptions: { ecmaVersion: 2019, sourceType: "module" },
|
||||
env: { browser: true, node: true, es6: true, es2015: true, es2017: true, es2020: true },
|
||||
rules: {}
|
||||
};
|
||||
eslint.getRules().forEach((desc, name) => {
|
||||
if (desc.meta.docs.recommended)
|
||||
config.rules[name] = 2;
|
||||
});
|
||||
}
|
||||
return (view) => {
|
||||
let { state } = view, found = [];
|
||||
for (let { from, to } of javascriptLanguage.findRegions(state)) {
|
||||
let fromLine = state.doc.lineAt(from), offset = { line: fromLine.number - 1, col: from - fromLine.from, pos: from };
|
||||
for (let d of eslint.verify(state.sliceDoc(from, to), config))
|
||||
found.push(translateDiagnostic(d, state.doc, offset));
|
||||
}
|
||||
return found;
|
||||
};
|
||||
}
|
||||
function mapPos(line, col, doc, offset) {
|
||||
return doc.line(line + offset.line).from + col + (line == 1 ? offset.col - 1 : -1);
|
||||
}
|
||||
function translateDiagnostic(input, doc, offset) {
|
||||
let start = mapPos(input.line, input.column, doc, offset);
|
||||
let result = {
|
||||
from: start,
|
||||
to: input.endLine != null && input.endColumn != 1 ? mapPos(input.endLine, input.endColumn, doc, offset) : start,
|
||||
message: input.message,
|
||||
source: input.ruleId ? "eslint:" + input.ruleId : "eslint",
|
||||
severity: input.severity == 1 ? "warning" : "error",
|
||||
};
|
||||
if (input.fix) {
|
||||
let { range, text } = input.fix, from = range[0] + offset.pos - start, to = range[1] + offset.pos - start;
|
||||
result.actions = [{
|
||||
name: "fix",
|
||||
apply(view, start) {
|
||||
view.dispatch({ changes: { from: start + from, to: start + to, insert: text }, scrollIntoView: true });
|
||||
}
|
||||
}];
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
export { autoCloseTags, completionPath, esLint, javascript, javascriptLanguage, jsxLanguage, localCompletionSource, scopeCompletionSource, snippets, tsxLanguage, typescriptLanguage };
|
||||
45
node_modules/@codemirror/lang-javascript/package.json
generated
vendored
Normal file
45
node_modules/@codemirror/lang-javascript/package.json
generated
vendored
Normal file
@ -0,0 +1,45 @@
|
||||
{
|
||||
"name": "@codemirror/lang-javascript",
|
||||
"version": "6.1.9",
|
||||
"description": "JavaScript language support for the CodeMirror code editor",
|
||||
"scripts": {
|
||||
"test": "cm-runtests",
|
||||
"prepare": "cm-buildhelper src/index.ts"
|
||||
},
|
||||
"keywords": [
|
||||
"editor",
|
||||
"code"
|
||||
],
|
||||
"author": {
|
||||
"name": "Marijn Haverbeke",
|
||||
"email": "marijn@haverbeke.berlin",
|
||||
"url": "http://marijnhaverbeke.nl"
|
||||
},
|
||||
"type": "module",
|
||||
"main": "dist/index.cjs",
|
||||
"exports": {
|
||||
"import": "./dist/index.js",
|
||||
"require": "./dist/index.cjs"
|
||||
},
|
||||
"types": "dist/index.d.ts",
|
||||
"module": "dist/index.js",
|
||||
"sideEffects": false,
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"@codemirror/autocomplete": "^6.0.0",
|
||||
"@codemirror/language": "^6.6.0",
|
||||
"@codemirror/lint": "^6.0.0",
|
||||
"@codemirror/state": "^6.0.0",
|
||||
"@codemirror/view": "^6.0.0",
|
||||
"@lezer/common": "^1.0.0",
|
||||
"@lezer/javascript": "^1.0.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@codemirror/buildhelper": "^1.0.0",
|
||||
"@lezer/lr": "^1.0.0"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/codemirror/lang-javascript.git"
|
||||
}
|
||||
}
|
||||
16
node_modules/@codemirror/language/.github/workflows/dispatch.yml
generated
vendored
Normal file
16
node_modules/@codemirror/language/.github/workflows/dispatch.yml
generated
vendored
Normal file
@ -0,0 +1,16 @@
|
||||
name: Trigger CI
|
||||
on: push
|
||||
|
||||
jobs:
|
||||
build:
|
||||
name: Dispatch to main repo
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Emit repository_dispatch
|
||||
uses: mvasigh/dispatch-action@main
|
||||
with:
|
||||
# You should create a personal access token and store it in your repository
|
||||
token: ${{ secrets.DISPATCH_AUTH }}
|
||||
repo: dev
|
||||
owner: codemirror
|
||||
event_type: push
|
||||
276
node_modules/@codemirror/language/CHANGELOG.md
generated
vendored
Normal file
276
node_modules/@codemirror/language/CHANGELOG.md
generated
vendored
Normal file
@ -0,0 +1,276 @@
|
||||
## 6.8.0 (2023-06-12)
|
||||
|
||||
### New features
|
||||
|
||||
The new `baseIndentFor` method in `TreeIndentContext` can be used to find the base indentation for an arbitrary node.
|
||||
|
||||
## 6.7.0 (2023-05-19)
|
||||
|
||||
### New features
|
||||
|
||||
Export `DocInput` class for feeding editor documents to a Lezer parser.
|
||||
|
||||
## 6.6.0 (2023-02-13)
|
||||
|
||||
### New features
|
||||
|
||||
Syntax-driven language data queries now support sublanguages, which make it possible to return different data for specific parts of the tree produced by a single language.
|
||||
|
||||
## 6.5.0 (2023-02-07)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make indentation for stream languages more reliable by having `StringStream.indentation` return overridden indentations from the indent context.
|
||||
|
||||
### New features
|
||||
|
||||
The `toggleFold` command folds or unfolds depending on whether there's an existing folded range on the current line.
|
||||
|
||||
`indentUnit` now accepts any (repeated) whitespace character, not just spaces and tabs.
|
||||
|
||||
## 6.4.0 (2023-01-12)
|
||||
|
||||
### New features
|
||||
|
||||
The `bracketMatchingHandle` node prop can now be used to limit bracket matching behavior for larger nodes to a single subnode (for example the tag name of an HTML tag).
|
||||
|
||||
## 6.3.2 (2022-12-16)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that caused `ensureSyntaxTree` to return incomplete trees when using a viewport-aware parser like `StreamLanguage`.
|
||||
|
||||
## 6.3.1 (2022-11-14)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make syntax-based folding include syntax nodes that start right at the end of a line as potential fold targets.
|
||||
|
||||
Fix the `indentService` protocol to allow a distinction between declining to handle the indentation and returning null to indicate the line has no definite indentation.
|
||||
|
||||
## 6.3.0 (2022-10-24)
|
||||
|
||||
### New features
|
||||
|
||||
`HighlightStyle` objects now have a `specs` property holding the tag styles that were used to define them.
|
||||
|
||||
`Language` objects now have a `name` field holding the language name.
|
||||
|
||||
## 6.2.1 (2022-07-21)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug where `bracketMatching` would incorrectly match nested brackets in syntax trees that put multiple pairs of brackets in the same parent node.
|
||||
|
||||
Fix a bug that could cause `indentRange` to loop infinitely.
|
||||
|
||||
## 6.2.0 (2022-06-30)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that prevented bracket matching to recognize plain brackets inside a language parsed as an overlay.
|
||||
|
||||
### New features
|
||||
|
||||
The `indentRange` function provides an easy way to programatically auto-indent a range of the document.
|
||||
|
||||
## 6.1.0 (2022-06-20)
|
||||
|
||||
### New features
|
||||
|
||||
The `foldState` field is now public, and can be used to serialize and deserialize the fold state.
|
||||
|
||||
## 6.0.0 (2022-06-08)
|
||||
|
||||
### New features
|
||||
|
||||
The `foldingChanged` option to `foldGutter` can now be used to trigger a recomputation of the fold markers.
|
||||
|
||||
## 0.20.2 (2022-05-20)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
List style-mod as a dependency.
|
||||
|
||||
## 0.20.1 (2022-05-18)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make sure `all` styles in the CSS generated for a `HighlightStyle` have a lower precedence than the other rules defined for the style. Use a shorthand property
|
||||
|
||||
## 0.20.0 (2022-04-20)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
`HighlightStyle.get` is now called `highlightingFor`.
|
||||
|
||||
`HighlightStyles` no longer function as extensions (to improve tree shaking), and must be wrapped with `syntaxHighlighting` to add to an editor configuration.
|
||||
|
||||
`Language` objects no longer have a `topNode` property.
|
||||
|
||||
### New features
|
||||
|
||||
`HighlightStyle` and `defaultHighlightStyle` from the now-removed @codemirror/highlight package now live in this package.
|
||||
|
||||
The new `forceParsing` function can be used to run the parser forward on an editor view.
|
||||
|
||||
The exports that used to live in @codemirror/matchbrackets are now exported from this package.
|
||||
|
||||
The @codemirror/fold package has been merged into this one.
|
||||
|
||||
The exports from the old @codemirror/stream-parser package now live in this package.
|
||||
|
||||
## 0.19.10 (2022-03-31)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Autocompletion may now also trigger automatic indentation on input.
|
||||
|
||||
## 0.19.9 (2022-03-30)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Make sure nodes that end at the end of a partial parse aren't treated as valid fold targets.
|
||||
|
||||
Fix an issue where the parser sometimes wouldn't reuse parsing work done in the background on transactions.
|
||||
|
||||
## 0.19.8 (2022-03-03)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue that could cause indentation logic to use the wrong line content when indenting multiple lines at once.
|
||||
|
||||
## 0.19.7 (2021-12-02)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where the parse worker could incorrectly stop working when the parse tree has skipped gaps in it.
|
||||
|
||||
## 0.19.6 (2021-11-26)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fixes an issue where the background parse work would be scheduled too aggressively, degrading responsiveness on a newly-created editor with a large document.
|
||||
|
||||
Improve initial highlight for mixed-language editors and limit the amount of parsing done on state creation for faster startup.
|
||||
|
||||
## 0.19.5 (2021-11-17)
|
||||
|
||||
### New features
|
||||
|
||||
The new function `syntaxTreeAvailable` can be used to check if a fully-parsed syntax tree is available up to a given document position.
|
||||
|
||||
The module now exports `syntaxParserRunning`, which tells you whether the background parser is still planning to do more work for a given editor view.
|
||||
|
||||
## 0.19.4 (2021-11-13)
|
||||
|
||||
### New features
|
||||
|
||||
`LanguageDescription.of` now takes an optional already-loaded extension.
|
||||
|
||||
## 0.19.3 (2021-09-13)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where a parse that skipped content with `skipUntilInView` would in some cases not be restarted when the range came into view.
|
||||
|
||||
## 0.19.2 (2021-08-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug that caused `indentOnInput` to fire for the wrong kinds of transactions.
|
||||
|
||||
Fix a bug that could cause `indentOnInput` to apply its changes incorrectly.
|
||||
|
||||
## 0.19.1 (2021-08-11)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix incorrect versions for @lezer dependencies.
|
||||
|
||||
## 0.19.0 (2021-08-11)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
CodeMirror now uses lezer 0.15, which means different package names (scoped with @lezer) and some breaking changes in the library.
|
||||
|
||||
`EditorParseContext` is now called `ParseContext`. It is no longer passed to parsers, but must be retrieved with `ParseContext.get`.
|
||||
|
||||
`IndentContext.lineIndent` now takes a position, not a `Line` object, as argument.
|
||||
|
||||
`LezerLanguage` was renamed to `LRLanguage` (because all languages must emit Lezer-style trees, the name was misleading).
|
||||
|
||||
`Language.parseString` no longer exists. You can just call `.parser.parse(...)` instead.
|
||||
|
||||
### New features
|
||||
|
||||
New `IndentContext.lineAt` method to access lines in a way that is aware of simulated line breaks.
|
||||
|
||||
`IndentContext` now provides a `simulatedBreak` property through which client code can query whether the context has a simulated line break.
|
||||
|
||||
## 0.18.2 (2021-06-01)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where asynchronous re-parsing (with dynamically loaded languages) sometimes failed to fully happen.
|
||||
|
||||
## 0.18.1 (2021-03-31)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
`EditorParseContext.getSkippingParser` now replaces `EditorParseContext.skippingParser` and allows you to provide a promise that'll cause parsing to start again. (The old property remains available until the next major release.)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix an issue where nested parsers could see past the end of the nested region.
|
||||
|
||||
## 0.18.0 (2021-03-03)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
Update dependencies to 0.18.
|
||||
|
||||
### Breaking changes
|
||||
|
||||
The `Language` constructor takes an additional argument that provides the top node type.
|
||||
|
||||
### New features
|
||||
|
||||
`Language` instances now have a `topNode` property giving their top node type.
|
||||
|
||||
`TreeIndentContext` now has a `continue` method that allows an indenter to defer to the indentation of the parent nodes.
|
||||
|
||||
## 0.17.5 (2021-02-19)
|
||||
|
||||
### New features
|
||||
|
||||
This package now exports a `foldInside` helper function, a fold function that should work for most delimited node types.
|
||||
|
||||
## 0.17.4 (2021-01-15)
|
||||
|
||||
## 0.17.3 (2021-01-15)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Parse scheduling has been improved to reduce the likelyhood of the user looking at unparsed code in big documents.
|
||||
|
||||
Prevent parser from running too far past the current viewport in huge documents.
|
||||
|
||||
## 0.17.2 (2021-01-06)
|
||||
|
||||
### New features
|
||||
|
||||
The package now also exports a CommonJS module.
|
||||
|
||||
## 0.17.1 (2020-12-30)
|
||||
|
||||
### Bug fixes
|
||||
|
||||
Fix a bug where changing the editor configuration wouldn't update the language parser used.
|
||||
|
||||
## 0.17.0 (2020-12-29)
|
||||
|
||||
### Breaking changes
|
||||
|
||||
First numbered release.
|
||||
|
||||
21
node_modules/@codemirror/language/LICENSE
generated
vendored
Normal file
21
node_modules/@codemirror/language/LICENSE
generated
vendored
Normal file
@ -0,0 +1,21 @@
|
||||
MIT License
|
||||
|
||||
Copyright (C) 2018-2021 by Marijn Haverbeke <marijn@haverbeke.berlin> and others
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
18
node_modules/@codemirror/language/README.md
generated
vendored
Normal file
18
node_modules/@codemirror/language/README.md
generated
vendored
Normal file
@ -0,0 +1,18 @@
|
||||
# @codemirror/language [](https://www.npmjs.org/package/@codemirror/language)
|
||||
|
||||
[ [**WEBSITE**](https://codemirror.net/) | [**DOCS**](https://codemirror.net/docs/ref/#language) | [**ISSUES**](https://github.com/codemirror/dev/issues) | [**FORUM**](https://discuss.codemirror.net/c/next/) | [**CHANGELOG**](https://github.com/codemirror/language/blob/main/CHANGELOG.md) ]
|
||||
|
||||
This package implements the language support infrastructure for the
|
||||
[CodeMirror](https://codemirror.net/) code editor.
|
||||
|
||||
The [project page](https://codemirror.net/) has more information, a
|
||||
number of [examples](https://codemirror.net/examples/) and the
|
||||
[documentation](https://codemirror.net/docs/).
|
||||
|
||||
This code is released under an
|
||||
[MIT license](https://github.com/codemirror/language/tree/main/LICENSE).
|
||||
|
||||
We aim to be an inclusive, welcoming community. To make that explicit,
|
||||
we have a [code of
|
||||
conduct](http://contributor-covenant.org/version/1/1/0/) that applies
|
||||
to communication around the project.
|
||||
2549
node_modules/@codemirror/language/dist/index.cjs
generated
vendored
Normal file
2549
node_modules/@codemirror/language/dist/index.cjs
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1185
node_modules/@codemirror/language/dist/index.d.cts
generated
vendored
Normal file
1185
node_modules/@codemirror/language/dist/index.d.cts
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1185
node_modules/@codemirror/language/dist/index.d.ts
generated
vendored
Normal file
1185
node_modules/@codemirror/language/dist/index.d.ts
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user