import React from "react"; import { trackEvent } from "../analytics"; import { load, questionCircle, save, saveAs } from "../components/icons"; import { ProjectName } from "../components/ProjectName"; import { ToolButton } from "../components/ToolButton"; import "../components/ToolIcon.scss"; import { Tooltip } from "../components/Tooltip"; import { DarkModeToggle, Appearence } from "../components/DarkModeToggle"; import { loadFromJSON, saveAsJSON } from "../data"; import { t } from "../i18n"; import useIsMobile from "../is-mobile"; import { KEYS } from "../keys"; import { register } from "./register"; export const actionChangeProjectName = register({ name: "changeProjectName", perform: (_elements, appState, value) => { trackEvent("change", "title"); return { appState: { ...appState, name: value }, commitToHistory: false }; }, PanelComponent: ({ appState, updateData, appProps }) => ( updateData(name)} isNameEditable={ typeof appProps.name === "undefined" && !appState.viewModeEnabled } /> ), }); export const actionChangeExportBackground = register({ name: "changeExportBackground", perform: (_elements, appState, value) => { return { appState: { ...appState, exportBackground: value }, commitToHistory: false, }; }, PanelComponent: ({ appState, updateData }) => ( ), }); export const actionChangeExportEmbedScene = register({ name: "changeExportEmbedScene", perform: (_elements, appState, value) => { return { appState: { ...appState, exportEmbedScene: value }, commitToHistory: false, }; }, PanelComponent: ({ appState, updateData }) => ( ), }); export const actionChangeShouldAddWatermark = register({ name: "changeShouldAddWatermark", perform: (_elements, appState, value) => { return { appState: { ...appState, shouldAddWatermark: value }, commitToHistory: false, }; }, PanelComponent: ({ appState, updateData }) => ( ), }); export const actionSaveScene = register({ name: "saveScene", perform: async (elements, appState, value) => { const fileHandleExists = !!appState.fileHandle; try { const { fileHandle } = await saveAsJSON(elements, appState); return { commitToHistory: false, appState: { ...appState, fileHandle, toastMessage: fileHandleExists ? fileHandle.name ? t("toast.fileSavedToFilename").replace( "{filename}", `"${fileHandle.name}"`, ) : t("toast.fileSaved") : null, }, }; } catch (error) { if (error?.name !== "AbortError") { console.error(error); } return { commitToHistory: false }; } }, keyTest: (event) => event.key === KEYS.S && event[KEYS.CTRL_OR_CMD] && !event.shiftKey, PanelComponent: ({ updateData }) => ( updateData(null)} /> ), }); export const actionSaveAsScene = register({ name: "saveAsScene", perform: async (elements, appState, value) => { try { const { fileHandle } = await saveAsJSON(elements, { ...appState, fileHandle: null, }); return { commitToHistory: false, appState: { ...appState, fileHandle } }; } catch (error) { if (error?.name !== "AbortError") { console.error(error); } return { commitToHistory: false }; } }, keyTest: (event) => event.key === KEYS.S && event.shiftKey && event[KEYS.CTRL_OR_CMD], PanelComponent: ({ updateData }) => (