mirror of
https://github.com/eliasstepanik/strudel-docker.git
synced 2026-01-11 21:58:31 +00:00
109 lines
4.0 KiB
JavaScript
109 lines
4.0 KiB
JavaScript
import { persistentMap } from '@nanostores/persistent';
|
|
import { useStore } from '@nanostores/react';
|
|
import { register } from '@strudel/core';
|
|
import { isUdels } from './repl/util.mjs';
|
|
|
|
export const audioEngineTargets = {
|
|
webaudio: 'webaudio',
|
|
osc: 'osc',
|
|
};
|
|
|
|
export const defaultSettings = {
|
|
activeFooter: 'intro',
|
|
keybindings: 'codemirror',
|
|
isBracketMatchingEnabled: true,
|
|
isBracketClosingEnabled: true,
|
|
isLineNumbersDisplayed: true,
|
|
isActiveLineHighlighted: true,
|
|
isAutoCompletionEnabled: false,
|
|
isTooltipEnabled: false,
|
|
isFlashEnabled: true,
|
|
isSyncEnabled: false,
|
|
isLineWrappingEnabled: false,
|
|
isPatternHighlightingEnabled: true,
|
|
theme: 'strudelTheme',
|
|
fontFamily: 'monospace',
|
|
fontSize: 18,
|
|
latestCode: '',
|
|
isZen: false,
|
|
soundsFilter: 'all',
|
|
patternFilter: 'community',
|
|
// panelPosition: window.innerWidth > 1000 ? 'right' : 'bottom', //FIX: does not work on astro
|
|
panelPosition: 'right',
|
|
isPanelPinned: false,
|
|
isPanelOpen: true,
|
|
togglePanelTrigger: 'click', //click | hover
|
|
userPatterns: '{}',
|
|
audioEngineTarget: audioEngineTargets.webaudio,
|
|
isButtonRowHidden: false,
|
|
isCSSAnimationDisabled: false,
|
|
maxPolyphony: 128,
|
|
};
|
|
|
|
let search = null;
|
|
if (typeof window !== 'undefined') {
|
|
search = new URLSearchParams(window.location.search);
|
|
}
|
|
// if running multiple instance in one window, it will use the settings for that instance. else default to normal
|
|
const instance = parseInt(search?.get('instance') ?? '0');
|
|
const settings_key = `strudel-settings${instance > 0 ? instance : ''}`;
|
|
|
|
export const settingsMap = persistentMap(settings_key, defaultSettings);
|
|
|
|
const parseBoolean = (booleanlike) => ([true, 'true'].includes(booleanlike) ? true : false);
|
|
|
|
export function useSettings() {
|
|
const state = useStore(settingsMap);
|
|
|
|
const userPatterns = JSON.parse(state.userPatterns);
|
|
Object.keys(userPatterns).forEach((key) => {
|
|
const data = userPatterns[key];
|
|
data.id = data.id ?? key;
|
|
userPatterns[key] = data;
|
|
});
|
|
return {
|
|
...state,
|
|
isZen: parseBoolean(state.isZen),
|
|
isBracketMatchingEnabled: parseBoolean(state.isBracketMatchingEnabled),
|
|
isBracketClosingEnabled: parseBoolean(state.isBracketClosingEnabled),
|
|
isLineNumbersDisplayed: parseBoolean(state.isLineNumbersDisplayed),
|
|
isActiveLineHighlighted: parseBoolean(state.isActiveLineHighlighted),
|
|
isAutoCompletionEnabled: parseBoolean(state.isAutoCompletionEnabled),
|
|
isPatternHighlightingEnabled: parseBoolean(state.isPatternHighlightingEnabled),
|
|
isButtonRowHidden: parseBoolean(state.isButtonRowHidden),
|
|
isCSSAnimationDisabled: parseBoolean(state.isCSSAnimationDisabled),
|
|
isTooltipEnabled: parseBoolean(state.isTooltipEnabled),
|
|
isLineWrappingEnabled: parseBoolean(state.isLineWrappingEnabled),
|
|
isFlashEnabled: parseBoolean(state.isFlashEnabled),
|
|
isSyncEnabled: isUdels() ? true : parseBoolean(state.isSyncEnabled),
|
|
fontSize: Number(state.fontSize),
|
|
panelPosition: state.activeFooter !== '' && !isUdels() ? state.panelPosition : 'bottom', // <-- keep this 'bottom' where it is!
|
|
isPanelPinned: parseBoolean(state.isPanelPinned),
|
|
isPanelOpen: parseBoolean(state.isPanelOpen),
|
|
userPatterns: userPatterns,
|
|
};
|
|
}
|
|
|
|
export const setActiveFooter = (tab) => settingsMap.setKey('activeFooter', tab);
|
|
export const setPanelPinned = (bool) => settingsMap.setKey('isPanelPinned', bool);
|
|
export const setIsPanelOpened = (bool) => settingsMap.setKey('isPanelOpen', bool);
|
|
|
|
export const setIsZen = (active) => settingsMap.setKey('isZen', !!active);
|
|
|
|
const patternSetting = (key) =>
|
|
register(key, (value, pat) =>
|
|
pat.onTrigger(() => {
|
|
value = Array.isArray(value) ? value.join(' ') : value;
|
|
if (value !== settingsMap.get()[key]) {
|
|
settingsMap.setKey(key, value);
|
|
}
|
|
return pat;
|
|
}, false),
|
|
);
|
|
|
|
export const theme = patternSetting('theme');
|
|
export const fontFamily = patternSetting('fontFamily');
|
|
export const fontSize = patternSetting('fontSize');
|
|
|
|
export const settingPatterns = { theme, fontFamily, fontSize };
|