mirror of
https://github.com/eliasstepanik/strudel-docker.git
synced 2026-01-27 21:48:27 +00:00
working
This commit is contained in:
parent
8d143f4bf1
commit
1e2c26123b
@ -85,7 +85,7 @@ export function Header({ context }) {
|
|||||||
)}
|
)}
|
||||||
</button>
|
</button>
|
||||||
<button
|
<button
|
||||||
onClick={() => handleUpdate()}
|
onClick={() => handleUpdate({})}
|
||||||
title="update"
|
title="update"
|
||||||
className={cx(
|
className={cx(
|
||||||
'flex items-center space-x-1',
|
'flex items-center space-x-1',
|
||||||
|
|||||||
@ -139,17 +139,19 @@ export function Repl({ embedded = false }) {
|
|||||||
//
|
//
|
||||||
|
|
||||||
const handleTogglePlay = async () => editorRef.current?.toggle();
|
const handleTogglePlay = async () => editorRef.current?.toggle();
|
||||||
const handleUpdate = async (newCode, reset = false) => {
|
|
||||||
|
// payload = {reset: boolean, code: string, evaluate: boolean}
|
||||||
|
const handleUpdate = async ({ reset = false, code = null, evaluate = true }) => {
|
||||||
if (reset) {
|
if (reset) {
|
||||||
clearCanvas();
|
clearCanvas();
|
||||||
resetLoadedSounds();
|
resetLoadedSounds();
|
||||||
editorRef.current.repl.setCps(1);
|
editorRef.current.repl.setCps(1);
|
||||||
await prebake(); // declare default samples
|
await prebake(); // declare default samples
|
||||||
}
|
}
|
||||||
if (newCode) {
|
if (code != null) {
|
||||||
editorRef.current.setCode(newCode);
|
editorRef.current.setCode(code);
|
||||||
editorRef.current.repl.evaluate(newCode);
|
}
|
||||||
} else if (isDirty) {
|
if (evaluate && isDirty) {
|
||||||
editorRef.current.evaluate();
|
editorRef.current.evaluate();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
@ -19,10 +19,40 @@ function classNames(...classes) {
|
|||||||
return classes.filter(Boolean).join(' ');
|
return classes.filter(Boolean).join(' ');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function PatternButton({ isActive, onClick, label }) {
|
||||||
|
return (
|
||||||
|
<a
|
||||||
|
className={classNames('mr-4 hover:opacity-50 cursor-pointer inline-block', isActive ? 'outline outline-1' : '')}
|
||||||
|
onClick={onClick}
|
||||||
|
>
|
||||||
|
{label}
|
||||||
|
</a>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function PatternButtons({ patterns, activePattern, onClick }) {
|
||||||
|
return (
|
||||||
|
<div className="font-mono text-sm">
|
||||||
|
{Object.entries(patterns).map(([key, data]) => (
|
||||||
|
<PatternButton key={key} label={key} isActive={key === activePattern} onClick={() => onClick(key, data)} />
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
export function PatternsTab({ context }) {
|
export function PatternsTab({ context }) {
|
||||||
const { userPatterns } = useSettings();
|
const { userPatterns } = useSettings();
|
||||||
const activePattern = useActivePattern();
|
const activePattern = useActivePattern();
|
||||||
const isExample = useMemo(() => activePattern && !!tunes[activePattern], [activePattern]);
|
const isExample = useMemo(() => activePattern && !!tunes[activePattern], [activePattern]);
|
||||||
|
const onPatternClick = (key, data) => {
|
||||||
|
const { code } = data;
|
||||||
|
setActivePattern(key);
|
||||||
|
context.handleUpdate({ code, evaluate: false });
|
||||||
|
};
|
||||||
|
|
||||||
|
const examplePatterns = {};
|
||||||
|
Object.entries(tunes).forEach(([key, code]) => (examplePatterns[key] = { code }));
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="px-4 w-full dark:text-white text-stone-900 space-y-4 pb-4">
|
<div className="px-4 w-full dark:text-white text-stone-900 space-y-4 pb-4">
|
||||||
<section>
|
<section>
|
||||||
@ -47,31 +77,14 @@ export function PatternsTab({ context }) {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
<div className="font-mono text-sm">
|
<PatternButtons onClick={onPatternClick} patterns={userPatterns} activePattern={activePattern} />
|
||||||
{Object.entries(userPatterns).map(([key, up]) => (
|
|
||||||
<a
|
|
||||||
key={key}
|
|
||||||
className={classNames(
|
|
||||||
'mr-4 hover:opacity-50 cursor-pointer inline-block',
|
|
||||||
key === activePattern ? 'outline outline-1' : '',
|
|
||||||
)}
|
|
||||||
onClick={() => {
|
|
||||||
const { code } = up;
|
|
||||||
setActivePattern(key);
|
|
||||||
context.handleUpdate(code, true);
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
{key}
|
|
||||||
</a>
|
|
||||||
))}
|
|
||||||
</div>
|
|
||||||
<div className="pr-4 space-x-4 border-b border-foreground mb-2 h-8 flex overflow-auto max-w-full items-center">
|
<div className="pr-4 space-x-4 border-b border-foreground mb-2 h-8 flex overflow-auto max-w-full items-center">
|
||||||
<button
|
<button
|
||||||
className="hover:opacity-50"
|
className="hover:opacity-50"
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
const name = newUserPattern();
|
const name = newUserPattern();
|
||||||
const { code } = getUserPattern(name);
|
const { code } = getUserPattern(name);
|
||||||
context.handleUpdate(code, true);
|
context.handleUpdate({ code, evaluate: false });
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
new
|
new
|
||||||
@ -96,23 +109,7 @@ export function PatternsTab({ context }) {
|
|||||||
</section>
|
</section>
|
||||||
<section>
|
<section>
|
||||||
<h2 className="text-xl mb-2">Examples</h2>
|
<h2 className="text-xl mb-2">Examples</h2>
|
||||||
<div className="font-mono text-sm">
|
<PatternButtons onClick={onPatternClick} patterns={examplePatterns} activePattern={activePattern} />
|
||||||
{Object.entries(tunes).map(([key, tune]) => (
|
|
||||||
<a
|
|
||||||
key={key}
|
|
||||||
className={classNames(
|
|
||||||
'mr-4 hover:opacity-50 cursor-pointer inline-block',
|
|
||||||
key === activePattern ? 'outline outline-1' : '',
|
|
||||||
)}
|
|
||||||
onClick={() => {
|
|
||||||
setActivePattern(key);
|
|
||||||
context.handleUpdate(tune, true);
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
{key}
|
|
||||||
</a>
|
|
||||||
))}
|
|
||||||
</div>
|
|
||||||
</section>
|
</section>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user