import React from "react"; import { ProjectName } from "../components/ProjectName"; import { saveAsJSON, loadFromJSON } from "../data"; import { load, save } from "../components/icons"; import { ToolButton } from "../components/ToolButton"; import { t } from "../i18n"; import useIsMobile from "../is-mobile"; import { register } from "./register"; export const actionChangeProjectName = register({ name: "changeProjectName", perform: (_elements, appState, value) => { return { appState: { ...appState, name: value }, commitToHistory: false }; }, PanelComponent: ({ appState, updateData }) => ( updateData(name)} /> ), }); export const actionChangeExportBackground = register({ name: "changeExportBackground", perform: (_elements, appState, value) => { return { appState: { ...appState, exportBackground: value }, commitToHistory: false, }; }, PanelComponent: ({ appState, updateData }) => ( ), }); export const actionSaveScene = register({ name: "saveScene", perform: (elements, appState, value) => { saveAsJSON(elements, appState).catch(error => console.error(error)); return { commitToHistory: false }; }, PanelComponent: ({ updateData }) => ( updateData(null)} /> ), }); export const actionLoadScene = register({ name: "loadScene", perform: ( elements, appState, { elements: loadedElements, appState: loadedAppState }, ) => { return { elements: loadedElements, appState: loadedAppState, commitToHistory: false, }; }, PanelComponent: ({ updateData }) => ( { loadFromJSON() .then(({ elements, appState }) => { updateData({ elements: elements, appState: appState }); }) .catch(error => console.error(error)); }} /> ), });