import React from "react"; import { Action } from "./types"; import { EditableText } from "../components/EditableText"; import { saveAsJSON, loadFromJSON } from "../scene"; import { load, save } from "../components/icons"; import { ToolIcon } from "../components/ToolIcon"; export const actionChangeProjectName: Action = { name: "changeProjectName", perform: (elements, appState, value) => { return { appState: { ...appState, name: value } }; }, PanelComponent: ({ appState, updateData }) => ( updateData(name)} /> ) }; export const actionChangeExportBackground: Action = { name: "changeExportBackground", perform: (elements, appState, value) => { return { appState: { ...appState, exportBackground: value } }; }, PanelComponent: ({ appState, updateData }) => ( ) }; export const actionSaveScene: Action = { name: "saveScene", perform: (elements, appState, value) => { saveAsJSON(elements, appState).catch(err => console.error(err)); return {}; }, PanelComponent: ({ updateData }) => ( updateData(null)} /> ) }; export const actionLoadScene: Action = { name: "loadScene", perform: ( elements, appState, { elements: loadedElements, appState: loadedAppState } ) => { return { elements: loadedElements, appState: loadedAppState }; }, PanelComponent: ({ updateData }) => ( { loadFromJSON() .then(({ elements, appState }) => { updateData({ elements: elements, appState: appState }); }) .catch(err => console.error(err)); }} /> ) };