2023-08-28 20:31:49 -04:00
|
|
|
import { assign, createMachine } from 'xstate'
|
2024-03-14 15:56:45 -04:00
|
|
|
import { Themes, getSystemTheme, setThemeClass } from 'lib/theme'
|
2024-04-02 10:29:34 -04:00
|
|
|
import { createSettings, settings } from 'lib/settings/initialSettings'
|
2024-03-12 10:37:35 -04:00
|
|
|
import {
|
2024-04-02 10:29:34 -04:00
|
|
|
BaseUnit,
|
|
|
|
SetEventTypes,
|
|
|
|
SettingsLevel,
|
|
|
|
SettingsPaths,
|
|
|
|
WildcardSetEvent,
|
2024-03-14 15:56:45 -04:00
|
|
|
} from 'lib/settings/settingsTypes'
|
2024-02-20 17:55:06 -08:00
|
|
|
|
2023-08-28 20:31:49 -04:00
|
|
|
export const settingsMachine = createMachine(
|
|
|
|
{
|
2024-04-02 10:29:34 -04:00
|
|
|
/** @xstate-layout N4IgpgJg5mDOIC5QGUwBc0EsB2VYDpMIAbMAYlnXwFsB7CMYnKfAV20zVgG0AGAXUSgADrVidMtbEJAAPRABYAHAFZ8vAEwA2FVq0aNAZgCcARl0B2ADQgAnolO8LvfBYUXT+48YW+tCgF8Am1QMZgIiUgoqAENhYXw0AAswajA+QSQQUXEsKRl5BCM1DQUDMo0VQwVjJxt7BFMDJXwNWo0LFSU3c0DgkFCsXAiScgAlOHQAAkow4YyZHIl8rMKAWn18Q39q3ScVFQ1NFXqHXiVTfGNqhSdeXi1DJQ1TIJD0IbxCUbIAKgWsks8tJVopjFp8KZjEpqi9lKZDE0TnYzgZXO5PG0fH4+u85l9IuRQlMYsRiFNsGAAO4zD7hAEiMTLEGgda6fAKJoIiyIkwWYwWawoxpGFxaHkKFS1a7woL9bD0OAyQbhRZM4EFRBrUyOLY7SVafaHTSnBDGDqQiz6DRKbwqTxvAZ04bfUhq3KSFlyBxHdQIhR6HTQmoC02OUwKPW7GrPdy8QxygJAA */
|
2023-08-28 20:31:49 -04:00
|
|
|
id: 'Settings',
|
|
|
|
predictableActionArguments: true,
|
2024-04-02 10:29:34 -04:00
|
|
|
context: {} as ReturnType<typeof createSettings>,
|
2023-08-28 20:31:49 -04:00
|
|
|
initial: 'idle',
|
|
|
|
states: {
|
|
|
|
idle: {
|
2024-03-14 15:56:45 -04:00
|
|
|
entry: ['setThemeClass', 'setClientSideSceneUnits', 'persistSettings'],
|
2024-04-02 10:29:34 -04:00
|
|
|
|
2023-08-28 20:31:49 -04:00
|
|
|
on: {
|
2024-04-02 10:29:34 -04:00
|
|
|
'*': {
|
2023-08-28 20:31:49 -04:00
|
|
|
target: 'idle',
|
|
|
|
internal: true,
|
2024-04-02 10:29:34 -04:00
|
|
|
actions: ['setSettingAtLevel', 'toastSuccess', 'persistSettings'],
|
2023-08-28 20:31:49 -04:00
|
|
|
},
|
2024-04-02 10:29:34 -04:00
|
|
|
|
|
|
|
'set.app.onboardingStatus': {
|
2023-08-28 20:31:49 -04:00
|
|
|
target: 'idle',
|
|
|
|
internal: true,
|
2024-04-02 10:29:34 -04:00
|
|
|
actions: ['setSettingAtLevel', 'persistSettings'], // No toast
|
2023-08-28 20:31:49 -04:00
|
|
|
},
|
2024-04-05 00:59:02 -04:00
|
|
|
'set.app.themeColor': {
|
|
|
|
target: 'idle',
|
|
|
|
internal: true,
|
|
|
|
actions: ['setSettingAtLevel', 'persistSettings'], // No toast
|
|
|
|
},
|
2024-04-02 10:29:34 -04:00
|
|
|
|
|
|
|
'set.modeling.defaultUnit': {
|
2023-08-28 20:31:49 -04:00
|
|
|
target: 'idle',
|
|
|
|
internal: true,
|
|
|
|
actions: [
|
2024-04-02 10:29:34 -04:00
|
|
|
'setSettingAtLevel',
|
2023-08-28 20:31:49 -04:00
|
|
|
'toastSuccess',
|
2024-04-02 10:29:34 -04:00
|
|
|
'setClientSideSceneUnits',
|
|
|
|
'Execute AST',
|
2023-08-28 20:31:49 -04:00
|
|
|
'persistSettings',
|
|
|
|
],
|
|
|
|
},
|
2024-04-02 10:29:34 -04:00
|
|
|
|
|
|
|
'set.app.theme': {
|
2023-09-06 21:27:30 -04:00
|
|
|
target: 'idle',
|
|
|
|
internal: true,
|
2023-08-28 20:31:49 -04:00
|
|
|
actions: [
|
2024-04-02 10:29:34 -04:00
|
|
|
'setSettingAtLevel',
|
2023-08-28 20:31:49 -04:00
|
|
|
'toastSuccess',
|
2023-09-08 10:13:35 -04:00
|
|
|
'setThemeClass',
|
2024-03-22 09:35:07 -04:00
|
|
|
'setEngineTheme',
|
2024-04-02 10:29:34 -04:00
|
|
|
'persistSettings',
|
2023-08-28 20:31:49 -04:00
|
|
|
],
|
2024-04-02 10:29:34 -04:00
|
|
|
},
|
|
|
|
|
2024-04-19 00:58:32 -04:00
|
|
|
'set.modeling.highlightEdges': {
|
|
|
|
target: 'idle',
|
|
|
|
internal: true,
|
|
|
|
actions: [
|
|
|
|
'setSettingAtLevel',
|
|
|
|
'toastSuccess',
|
|
|
|
'setEngineEdges',
|
|
|
|
'persistSettings',
|
|
|
|
],
|
|
|
|
},
|
|
|
|
|
2024-04-02 10:29:34 -04:00
|
|
|
'Reset settings': {
|
2023-08-28 20:31:49 -04:00
|
|
|
target: 'idle',
|
|
|
|
internal: true,
|
|
|
|
actions: [
|
2024-04-02 10:29:34 -04:00
|
|
|
'resetSettings',
|
|
|
|
'setThemeClass',
|
|
|
|
'setEngineTheme',
|
|
|
|
'setClientSideSceneUnits',
|
2024-03-14 15:56:45 -04:00
|
|
|
'Execute AST',
|
2024-04-02 10:29:34 -04:00
|
|
|
'persistSettings',
|
2023-09-08 10:13:35 -04:00
|
|
|
],
|
2024-04-02 10:29:34 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
'Set all settings': {
|
2023-09-08 10:13:35 -04:00
|
|
|
target: 'idle',
|
|
|
|
internal: true,
|
|
|
|
actions: [
|
2024-04-02 10:29:34 -04:00
|
|
|
'setAllSettings',
|
|
|
|
'setThemeClass',
|
|
|
|
'setEngineTheme',
|
|
|
|
'setClientSideSceneUnits',
|
|
|
|
'Execute AST',
|
2023-08-28 20:31:49 -04:00
|
|
|
'persistSettings',
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
tsTypes: {} as import('./settingsMachine.typegen').Typegen0,
|
|
|
|
schema: {
|
|
|
|
events: {} as
|
2024-04-02 10:29:34 -04:00
|
|
|
| WildcardSetEvent<SettingsPaths>
|
|
|
|
| SetEventTypes
|
2023-09-11 16:21:23 -04:00
|
|
|
| {
|
2024-04-02 10:29:34 -04:00
|
|
|
type: 'set.app.theme'
|
|
|
|
data: { level: SettingsLevel; value: Themes }
|
2023-09-11 16:21:23 -04:00
|
|
|
}
|
2023-08-28 20:31:49 -04:00
|
|
|
| {
|
2024-04-02 10:29:34 -04:00
|
|
|
type: 'set.modeling.units'
|
|
|
|
data: { level: SettingsLevel; value: BaseUnit }
|
2023-08-28 20:31:49 -04:00
|
|
|
}
|
2024-04-02 10:29:34 -04:00
|
|
|
| { type: 'Reset settings'; defaultDirectory: string }
|
|
|
|
| { type: 'Set all settings'; settings: typeof settings },
|
2023-08-28 20:31:49 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
actions: {
|
2024-04-02 10:29:34 -04:00
|
|
|
resetSettings: assign((context, { defaultDirectory }) => {
|
|
|
|
// Reset everything except onboarding status,
|
|
|
|
// which should be preserved
|
|
|
|
const newSettings = createSettings()
|
|
|
|
if (context.app.onboardingStatus.user) {
|
|
|
|
newSettings.app.onboardingStatus.user =
|
|
|
|
context.app.onboardingStatus.user
|
2024-03-14 15:56:45 -04:00
|
|
|
}
|
2024-04-02 10:29:34 -04:00
|
|
|
// We instead pass in the default directory since it's asynchronous
|
|
|
|
// to re-initialize, and that can be done by the caller.
|
|
|
|
newSettings.app.projectDirectory.default = defaultDirectory
|
|
|
|
|
|
|
|
return newSettings
|
|
|
|
}),
|
|
|
|
setAllSettings: assign((_, event) => {
|
|
|
|
return event.settings
|
|
|
|
}),
|
|
|
|
setSettingAtLevel: assign((context, event) => {
|
|
|
|
const { level, value } = event.data
|
|
|
|
const [category, setting] = event.type
|
|
|
|
.replace(/^set./, '')
|
|
|
|
.split('.') as [keyof typeof settings, string]
|
|
|
|
|
|
|
|
// @ts-ignore
|
|
|
|
context[category][setting][level] = value
|
|
|
|
|
|
|
|
const newContext = {
|
|
|
|
...context,
|
|
|
|
[category]: {
|
|
|
|
...context[category],
|
|
|
|
// @ts-ignore
|
|
|
|
[setting]: context[category][setting],
|
|
|
|
},
|
2023-08-28 20:31:49 -04:00
|
|
|
}
|
2024-04-02 10:29:34 -04:00
|
|
|
|
|
|
|
return newContext
|
|
|
|
}),
|
|
|
|
setThemeClass: (context) => {
|
|
|
|
const currentTheme = context.app.theme.current ?? Themes.System
|
2023-08-31 09:34:13 -04:00
|
|
|
setThemeClass(
|
|
|
|
currentTheme === Themes.System ? getSystemTheme() : currentTheme
|
|
|
|
)
|
|
|
|
},
|
2023-08-28 20:31:49 -04:00
|
|
|
},
|
|
|
|
}
|
|
|
|
)
|