mirror of
https://github.com/eliasstepanik/strudel-docker.git
synced 2026-01-11 13:48:34 +00:00
move widget registry to codemirror package
+ add transpiler as dependency to codemirror
This commit is contained in:
parent
8742d50bad
commit
4a95bf67da
@ -46,6 +46,7 @@
|
|||||||
"@replit/codemirror-vscode-keymap": "^6.0.2",
|
"@replit/codemirror-vscode-keymap": "^6.0.2",
|
||||||
"@strudel/core": "workspace:*",
|
"@strudel/core": "workspace:*",
|
||||||
"@strudel/draw": "workspace:*",
|
"@strudel/draw": "workspace:*",
|
||||||
|
"@strudel/transpiler": "workspace:*",
|
||||||
"@uiw/codemirror-themes": "^4.21.21",
|
"@uiw/codemirror-themes": "^4.21.21",
|
||||||
"@uiw/codemirror-themes-all": "^4.21.21",
|
"@uiw/codemirror-themes-all": "^4.21.21",
|
||||||
"nanostores": "^0.9.5"
|
"nanostores": "^0.9.5"
|
||||||
|
|||||||
@ -1,5 +1,7 @@
|
|||||||
import { StateEffect, StateField } from '@codemirror/state';
|
import { StateEffect, StateField } from '@codemirror/state';
|
||||||
import { Decoration, EditorView, WidgetType } from '@codemirror/view';
|
import { Decoration, EditorView, WidgetType } from '@codemirror/view';
|
||||||
|
import { registerWidgetType } from '@strudel/transpiler';
|
||||||
|
import { Pattern } from '@strudel/core';
|
||||||
|
|
||||||
const getWidgetID = (from) => `widget_${from}`;
|
const getWidgetID = (from) => `widget_${from}`;
|
||||||
|
|
||||||
@ -79,3 +81,15 @@ export class BlockWidget extends WidgetType {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export const widgetPlugin = [widgetField];
|
export const widgetPlugin = [widgetField];
|
||||||
|
|
||||||
|
// widget implementer API to create a new widget type
|
||||||
|
export function registerWidget(type, fn) {
|
||||||
|
registerWidgetType(type);
|
||||||
|
if (fn) {
|
||||||
|
Pattern.prototype[type] = function (id, options = { fold: 1 }) {
|
||||||
|
// fn is expected to create a dom element and call setWidget(id, el);
|
||||||
|
// fn should also return the pattern
|
||||||
|
return fn(id, options, this);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@ -2,7 +2,7 @@ import { For } from 'solid-js';
|
|||||||
import { customElement } from 'solid-element';
|
import { customElement } from 'solid-element';
|
||||||
import { getClaviature } from 'claviature';
|
import { getClaviature } from 'claviature';
|
||||||
import { Dynamic } from 'solid-js/web';
|
import { Dynamic } from 'solid-js/web';
|
||||||
import { registerWidget } from './registry.mjs';
|
import { registerWidget } from '@strudel/codemirror';
|
||||||
|
|
||||||
let defaultOptions = {
|
let defaultOptions = {
|
||||||
range: ['A1', 'C6'],
|
range: ['A1', 'C6'],
|
||||||
|
|||||||
@ -1,7 +1,6 @@
|
|||||||
import { registerWidget } from './registry.mjs';
|
import { registerWidget, setWidget } from '@strudel/codemirror';
|
||||||
import { setWidget } from '@strudel/codemirror';
|
|
||||||
|
|
||||||
function createCanvasWidget(id, options) {
|
function getCanvasWidget(id, options) {
|
||||||
const { width = 300, height = 100, pixelRatio = window.devicePixelRatio } = options || {};
|
const { width = 300, height = 100, pixelRatio = window.devicePixelRatio } = options || {};
|
||||||
let canvas = document.getElementById(id) || document.createElement('canvas');
|
let canvas = document.getElementById(id) || document.createElement('canvas');
|
||||||
canvas.width = width * pixelRatio;
|
canvas.width = width * pixelRatio;
|
||||||
@ -13,11 +12,11 @@ function createCanvasWidget(id, options) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
registerWidget('roll', (id, options = { fold: 1 }, pat) => {
|
registerWidget('roll', (id, options = { fold: 1 }, pat) => {
|
||||||
const ctx = createCanvasWidget(id, options).getContext('2d');
|
const ctx = getCanvasWidget(id, options).getContext('2d');
|
||||||
return pat.pianoroll({ ...options, ctx, id });
|
return pat.pianoroll({ ...options, ctx, id });
|
||||||
});
|
});
|
||||||
|
|
||||||
registerWidget('twist', (id, options = {}, pat) => {
|
registerWidget('twist', (id, options = {}, pat) => {
|
||||||
const ctx = createCanvasWidget(id, options).getContext('2d');
|
const ctx = getCanvasWidget(id, options).getContext('2d');
|
||||||
return pat.spiral({ ...options, ctx, size: 50, id });
|
return pat.spiral({ ...options, ctx, size: 50, id });
|
||||||
});
|
});
|
||||||
|
|||||||
@ -1,3 +1,2 @@
|
|||||||
export * from './Claviature.jsx';
|
export * from './Claviature.jsx';
|
||||||
export * from './canvas.mjs';
|
export * from './canvas.mjs';
|
||||||
export * from './registry.mjs';
|
|
||||||
|
|||||||
@ -1,11 +0,0 @@
|
|||||||
import { registerWidgetType } from '@strudel/transpiler';
|
|
||||||
import { Pattern } from '@strudel/core';
|
|
||||||
|
|
||||||
export function registerWidget(type, fn) {
|
|
||||||
registerWidgetType(type);
|
|
||||||
if (fn) {
|
|
||||||
Pattern.prototype[type] = function (id, options = { fold: 1 }) {
|
|
||||||
return fn(id, options, this);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
3
pnpm-lock.yaml
generated
3
pnpm-lock.yaml
generated
@ -184,6 +184,9 @@ importers:
|
|||||||
'@strudel/draw':
|
'@strudel/draw':
|
||||||
specifier: workspace:*
|
specifier: workspace:*
|
||||||
version: link:../draw
|
version: link:../draw
|
||||||
|
'@strudel/transpiler':
|
||||||
|
specifier: workspace:*
|
||||||
|
version: link:../transpiler
|
||||||
'@uiw/codemirror-themes':
|
'@uiw/codemirror-themes':
|
||||||
specifier: ^4.21.21
|
specifier: ^4.21.21
|
||||||
version: 4.21.21(@codemirror/language@6.10.0)(@codemirror/state@6.4.0)(@codemirror/view@6.23.0)
|
version: 4.21.21(@codemirror/language@6.10.0)(@codemirror/state@6.4.0)(@codemirror/view@6.23.0)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user