Update dependencies & directly include editor
This commit is contained in:
parent
f23e0417ed
commit
858914a73e
6 changed files with 838 additions and 647 deletions
|
|
@ -11,58 +11,60 @@
|
|||
"devDependencies": {
|
||||
"@fontsource/fira-mono": "^5.0.13",
|
||||
"@json-feed-types/1_1": "^1.0.2",
|
||||
"@rollup/plugin-commonjs": "^25.0.7",
|
||||
"@rollup/plugin-commonjs": "^25.0.8",
|
||||
"@rollup/plugin-dynamic-import-vars": "^2.1.2",
|
||||
"@rollup/plugin-node-resolve": "^15.2.3",
|
||||
"@sveltejs/adapter-auto": "^3.2.0",
|
||||
"@sveltejs/adapter-node": "^5.0.1",
|
||||
"@sveltejs/kit": "^2.5.7",
|
||||
"@sveltejs/vite-plugin-svelte": "^3.1.0",
|
||||
"@types/node": "^20.12.7",
|
||||
"@sveltejs/adapter-auto": "^3.2.2",
|
||||
"@sveltejs/adapter-node": "^5.1.1",
|
||||
"@sveltejs/kit": "^2.5.16",
|
||||
"@sveltejs/vite-plugin-svelte": "^3.1.1",
|
||||
"@types/node": "^20.14.2",
|
||||
"@types/sharedworker": "^0.0.115",
|
||||
"glob": "^10.3.12",
|
||||
"mdsvex": "^0.11.0",
|
||||
"glob": "^10.4.1",
|
||||
"mdsvex": "^0.11.2",
|
||||
"rehype-slug": "^6.0.0",
|
||||
"remark-frontmatter": "^5.0.0",
|
||||
"remark-gfm": "^4.0.0",
|
||||
"remark-math": "^6.0.0",
|
||||
"remark-wiki-link": "^2.0.1",
|
||||
"rollup": "^4.17.0",
|
||||
"rollup": "^4.18.0",
|
||||
"rollup-plugin-type-as-json-schema": "^0.2.6",
|
||||
"sharp": "^0.33.3",
|
||||
"svelte": "^4.2.15",
|
||||
"svelte-check": "^3.7.0",
|
||||
"svelte-seo": "^1.6.0",
|
||||
"sharp": "^0.33.4",
|
||||
"svelte": "^4.2.18",
|
||||
"svelte-check": "^3.8.0",
|
||||
"svelte-seo": "^1.6.1",
|
||||
"sveltekit-html-minifier": "^1.0.3",
|
||||
"svgo": "^3.2.0",
|
||||
"tslib": "^2.6.2",
|
||||
"svgo": "^3.3.2",
|
||||
"tslib": "^2.6.3",
|
||||
"typescript": "^5.4.5",
|
||||
"unified": "^11.0.4",
|
||||
"vite": "^5.2.10",
|
||||
"vite": "^5.3.1",
|
||||
"vite-plugin-dynamic-import": "^1.5.0",
|
||||
"vite-plugin-image-optimizer": "^1.1.7"
|
||||
"vite-plugin-image-optimizer": "^1.1.8"
|
||||
},
|
||||
"type": "module",
|
||||
"dependencies": {
|
||||
"@codemirror/commands": "^6.6.0",
|
||||
"@codemirror/lang-javascript": "^6.2.2",
|
||||
"@codemirror/language": "^6.10.1",
|
||||
"@codemirror/lint": "^6.5.0",
|
||||
"@codemirror/language": "^6.10.2",
|
||||
"@codemirror/lint": "^6.8.0",
|
||||
"@codemirror/state": "^6.4.1",
|
||||
"@codemirror/view": "^6.26.3",
|
||||
"@codemirror/view": "^6.28.1",
|
||||
"@isaacs/ttlcache": "^1.4.1",
|
||||
"@lezer/highlight": "^1.2.0",
|
||||
"@octokit/types": "^13.5.0",
|
||||
"@steeze-ui/svelte-icon": "^1.5.0",
|
||||
"@tusbar/cache-control": "^1.0.1",
|
||||
"@uiw/codemirror-theme-github": "^4.21.25",
|
||||
"@tusbar/cache-control": "^1.0.2",
|
||||
"@uiw/codemirror-theme-github": "^4.22.2",
|
||||
"Notes": "file:Notes-1.0.0.tgz",
|
||||
"acorn": "^8.11.3",
|
||||
"acorn": "^8.12.0",
|
||||
"codemirror": "^6.0.1",
|
||||
"magic-string": "^0.30.10",
|
||||
"octokit": "^3.2.0",
|
||||
"octokit": "^3.2.1",
|
||||
"slugify": "^1.6.6",
|
||||
"super-sitemap": "^0.14.14",
|
||||
"svelte-codemirror-editor": "^1.3.0",
|
||||
"terser": "^5.30.4",
|
||||
"svelte-codemirror-editor": "^1.4.0",
|
||||
"terser": "^5.31.1",
|
||||
"xmlbuilder2": "^3.1.1"
|
||||
},
|
||||
"targets": {
|
||||
|
|
|
|||
|
|
@ -1,9 +1,4 @@
|
|||
<script lang="ts" context="module">
|
||||
export enum LanguageConfig {
|
||||
None,
|
||||
JavaScript,
|
||||
}
|
||||
|
||||
type Attrs = {
|
||||
[name: string]: string;
|
||||
};
|
||||
|
|
@ -12,34 +7,156 @@
|
|||
|
||||
<script lang="ts">
|
||||
// look at https://github.com/sveltejs/learn.svelte.dev/blob/main/src/routes/tutorial/%5Bslug%5D/Editor.svelte
|
||||
import CodeMirror from "svelte-codemirror-editor";
|
||||
import { javascript } from "@codemirror/lang-javascript";
|
||||
// import { javascript } from "@codemirror/lang-javascript";
|
||||
import { onDestroy, onMount, createEventDispatcher } from "svelte";
|
||||
import { theme } from "$lib/theme";
|
||||
import { githubLight, githubDark } from "$lib/themes/github";
|
||||
import type { Extension } from "@codemirror/state";
|
||||
import { EditorView } from "@codemirror/view";
|
||||
import {
|
||||
EditorState,
|
||||
StateEffect,
|
||||
type Extension,
|
||||
} from "@codemirror/state";
|
||||
|
||||
import { type LanguageSupport } from "@codemirror/language";
|
||||
import { get_base_extensions } from "./editorExtensions";
|
||||
|
||||
export let value = "";
|
||||
export let contentAttributes: AttrSource | null = null;
|
||||
export let lang: LanguageSupport | null = null;
|
||||
|
||||
export let useTab = true;
|
||||
export let tabSize = 2;
|
||||
|
||||
export let lineWrapping = false;
|
||||
export let editable = true;
|
||||
export let readonly = false;
|
||||
export let lang: LanguageConfig = LanguageConfig.None;
|
||||
export let placeholder: string | HTMLElement | null | undefined = undefined;
|
||||
|
||||
const is_browser = typeof window !== "undefined";
|
||||
|
||||
let element: HTMLDivElement;
|
||||
let view: EditorView;
|
||||
|
||||
$: view && update(value);
|
||||
$: view && state_extensions && reconfigure();
|
||||
|
||||
$: on_change = handle_change;
|
||||
|
||||
let update_from_prop = false;
|
||||
let update_from_state = false;
|
||||
let first_config = true;
|
||||
let first_update = true;
|
||||
|
||||
let langPlugin = null;
|
||||
|
||||
switch (lang) {
|
||||
case LanguageConfig.None:
|
||||
langPlugin = null;
|
||||
break;
|
||||
case LanguageConfig.JavaScript:
|
||||
langPlugin = javascript();
|
||||
break;
|
||||
let extensions: Extension[] = [];
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
let extensions: Extension[] = [
|
||||
$: state_extensions = [
|
||||
...get_base_extensions(
|
||||
useTab,
|
||||
tabSize,
|
||||
lineWrapping,
|
||||
placeholder,
|
||||
editable,
|
||||
readonly,
|
||||
lang,
|
||||
),
|
||||
$theme == "dark" ? githubDark : githubLight,
|
||||
...extensions,
|
||||
];
|
||||
|
||||
if (langPlugin !== null) extensions.push(langPlugin);
|
||||
if (contentAttributes !== null) extensions.push(EditorView.contentAttributes.of(contentAttributes));
|
||||
if (contentAttributes !== null)
|
||||
extensions.push(EditorView.contentAttributes.of(contentAttributes));
|
||||
|
||||
onMount(() => {
|
||||
view = create_editor_view();
|
||||
dispatch("ready", view);
|
||||
});
|
||||
onDestroy(() => view?.destroy());
|
||||
|
||||
const dispatch = createEventDispatcher<{
|
||||
change: string;
|
||||
ready: EditorView;
|
||||
reconfigure: EditorView;
|
||||
}>();
|
||||
|
||||
function create_editor_view(): EditorView {
|
||||
return new EditorView({
|
||||
parent: element,
|
||||
state: create_editor_state(value),
|
||||
dispatch(transaction) {
|
||||
view.update([transaction]);
|
||||
|
||||
if (!update_from_prop && transaction.docChanged) {
|
||||
on_change();
|
||||
}
|
||||
},
|
||||
});
|
||||
}
|
||||
|
||||
function reconfigure(): void {
|
||||
if (first_config) {
|
||||
first_config = false;
|
||||
return;
|
||||
}
|
||||
|
||||
view.dispatch({
|
||||
effects: StateEffect.reconfigure.of(state_extensions),
|
||||
});
|
||||
|
||||
dispatch("reconfigure", view);
|
||||
}
|
||||
|
||||
function update(value: string | null | undefined): void {
|
||||
if (first_update) {
|
||||
first_update = false;
|
||||
return;
|
||||
}
|
||||
|
||||
if (update_from_state) {
|
||||
update_from_state = false;
|
||||
return;
|
||||
}
|
||||
|
||||
update_from_prop = true;
|
||||
|
||||
if (value === undefined) {
|
||||
return;
|
||||
}
|
||||
const currentValue = view ? view.state.doc.toString() : "";
|
||||
if (view && value !== currentValue) {
|
||||
view.dispatch({
|
||||
changes: {
|
||||
from: 0,
|
||||
to: currentValue.length,
|
||||
insert: value || "",
|
||||
},
|
||||
});
|
||||
}
|
||||
|
||||
update_from_prop = false;
|
||||
}
|
||||
|
||||
function handle_change(): void {
|
||||
const new_value = view.state.doc.toString();
|
||||
if (new_value === value) return;
|
||||
|
||||
update_from_state = true;
|
||||
|
||||
value = new_value;
|
||||
dispatch("change", value);
|
||||
}
|
||||
|
||||
function create_editor_state(
|
||||
value: string | null | undefined,
|
||||
): EditorState {
|
||||
return EditorState.create({
|
||||
doc: value ?? undefined,
|
||||
extensions: state_extensions,
|
||||
});
|
||||
}
|
||||
|
||||
// $: console.log(value)
|
||||
|
||||
|
|
@ -56,15 +173,28 @@
|
|||
<slot name="header" />
|
||||
</div>
|
||||
{/if}
|
||||
<CodeMirror
|
||||
{#if is_browser}
|
||||
<div class="codemirror-wrapper editor" bind:this={element} />
|
||||
{:else}
|
||||
<div class="scm-waiting editor">
|
||||
<div class="scm-waiting__loading scm-loading">
|
||||
<div class="scm-loading__spinner" />
|
||||
<p class="scm-loading__text">Loading editor...</p>
|
||||
</div>
|
||||
|
||||
<pre class="scm-pre cm-editor">{value}</pre>
|
||||
</div>
|
||||
{/if}
|
||||
<!-- <CodeMirror
|
||||
{value}
|
||||
class="editor"
|
||||
theme={$theme == "dark" ? githubDark : githubLight}
|
||||
{extensions}
|
||||
{readonly}
|
||||
on:change
|
||||
/>
|
||||
/> -->
|
||||
</div>
|
||||
|
||||
<!-- <CodeMirror basic={true} bind:value lang={javascript({})} class="editor" /> -->
|
||||
|
||||
<style>
|
||||
|
|
@ -74,6 +204,11 @@
|
|||
z-index: 1;
|
||||
background-color: var(--surface-secondary-color);
|
||||
}
|
||||
|
||||
.codemirror-wrapper :global(.cm-focused) {
|
||||
outline: none;
|
||||
}
|
||||
|
||||
:global(.editor-wrapper .cm-scroller, .editor-wrapper .cm-editor) {
|
||||
min-height: 200px;
|
||||
border-bottom-left-radius: var(--border-radius);
|
||||
|
|
|
|||
30
packages/website/src/lib/editorExtensions.ts
Normal file
30
packages/website/src/lib/editorExtensions.ts
Normal file
|
|
@ -0,0 +1,30 @@
|
|||
import { type LanguageSupport, indentUnit } from "@codemirror/language";
|
||||
import { type Extension, EditorState } from "@codemirror/state";
|
||||
import { EditorView, keymap } from "@codemirror/view";
|
||||
|
||||
import { indentWithTab } from "@codemirror/commands";
|
||||
import { basicSetup } from "codemirror";
|
||||
|
||||
export function get_base_extensions(
|
||||
useTab: boolean,
|
||||
tabSize: number,
|
||||
lineWrapping: boolean,
|
||||
placeholder: string | HTMLElement | null | undefined,
|
||||
editable: boolean,
|
||||
readonly: boolean,
|
||||
lang: LanguageSupport | null | undefined
|
||||
): Extension[] {
|
||||
const extensions: Extension[] = [
|
||||
indentUnit.of(" ".repeat(tabSize)),
|
||||
EditorView.editable.of(editable),
|
||||
EditorState.readOnly.of(readonly),
|
||||
basicSetup
|
||||
];
|
||||
|
||||
if (useTab) extensions.push(keymap.of([indentWithTab]));
|
||||
// if (placeholder) extensions.push(placeholderExt(placeholder));
|
||||
if (lang) extensions.push(lang);
|
||||
if (lineWrapping) extensions.push(EditorView.lineWrapping);
|
||||
|
||||
return extensions;
|
||||
}
|
||||
|
|
@ -1,5 +1,6 @@
|
|||
<script lang="ts">
|
||||
import Editor, { LanguageConfig } from "$lib/Editor.svelte";
|
||||
import Editor from "$lib/Editor.svelte";
|
||||
import { javascript } from "@codemirror/lang-javascript";
|
||||
import SvelteSeo from "svelte-seo";
|
||||
import { bookmarkify, parseMeta } from "./bookmarklets";
|
||||
import type { Config } from "./config";
|
||||
|
|
@ -39,7 +40,7 @@
|
|||
<Editor
|
||||
{value}
|
||||
on:change={(e) => (value = e.detail)}
|
||||
lang={LanguageConfig.JavaScript}
|
||||
lang={javascript()}
|
||||
{contentAttributes}
|
||||
>
|
||||
<div slot="header" class="code-header">Input</div>
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
|
||||
|
||||
import MagicString from "magic-string";
|
||||
// import MagicString from "magic-string";
|
||||
import { Parser } from "acorn";
|
||||
import { type MinifyOptions, type MinifyOutput } from "terser";
|
||||
|
||||
|
|
|
|||
1213
pnpm-lock.yaml
generated
1213
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load diff
Loading…
Add table
Reference in a new issue