mirror of
https://github.com/eliasstepanik/strudel.git
synced 2026-01-12 06:08:37 +00:00
58 lines
2.0 KiB
JavaScript
58 lines
2.0 KiB
JavaScript
import { persistentMap } from '@nanostores/persistent';
|
|
import { useStore } from '@nanostores/react';
|
|
import { register } from '@strudel.cycles/core';
|
|
|
|
export const defaultSettings = {
|
|
activeFooter: 'intro',
|
|
keybindings: 'codemirror',
|
|
isLineNumbersDisplayed: true,
|
|
isAutoCompletionEnabled: false,
|
|
isTooltipEnabled: false,
|
|
isLineWrappingEnabled: false,
|
|
theme: 'strudelTheme',
|
|
fontFamily: 'monospace',
|
|
fontSize: 18,
|
|
latestCode: '',
|
|
isZen: false,
|
|
soundsFilter: 'all',
|
|
panelPosition: 'bottom',
|
|
};
|
|
|
|
export const settingsMap = persistentMap('strudel-settings', defaultSettings);
|
|
|
|
export function useSettings() {
|
|
const state = useStore(settingsMap);
|
|
return {
|
|
...state,
|
|
isZen: [true, 'true'].includes(state.isZen) ? true : false,
|
|
isLineNumbersDisplayed: [true, 'true'].includes(state.isLineNumbersDisplayed) ? true : false,
|
|
isAutoCompletionEnabled: [true, 'true'].includes(state.isAutoCompletionEnabled) ? true : false,
|
|
isTooltipEnabled: [true, 'true'].includes(state.isTooltipEnabled) ? true : false,
|
|
isLineWrappingEnabled: [true, 'true'].includes(state.isLineWrappingEnabled) ? true : false,
|
|
fontSize: Number(state.fontSize),
|
|
panelPosition: state.activeFooter !== '' ? state.panelPosition : 'bottom',
|
|
};
|
|
}
|
|
|
|
export const setActiveFooter = (tab) => settingsMap.setKey('activeFooter', tab);
|
|
|
|
export const setLatestCode = (code) => settingsMap.setKey('latestCode', code);
|
|
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 };
|