|
@@ -79,6 +79,7 @@ export const getDefaultAppState = (): Omit<
|
|
|
zenModeEnabled: false,
|
|
|
zoom: { value: 1 as NormalizedZoomValue, translation: { x: 0, y: 0 } },
|
|
|
viewModeEnabled: false,
|
|
|
+ pendingImageElement: null,
|
|
|
};
|
|
|
};
|
|
|
|
|
@@ -92,78 +93,87 @@ const APP_STATE_STORAGE_CONF = (<
|
|
|
browser: boolean;
|
|
|
/** whether to keep when exporting to file/database */
|
|
|
export: boolean;
|
|
|
+ /** server (shareLink/collab/...) */
|
|
|
+ server: boolean;
|
|
|
},
|
|
|
T extends Record<keyof AppState, Values>
|
|
|
>(
|
|
|
config: { [K in keyof T]: K extends keyof AppState ? T[K] : never },
|
|
|
) => config)({
|
|
|
- theme: { browser: true, export: false },
|
|
|
- collaborators: { browser: false, export: false },
|
|
|
- currentChartType: { browser: true, export: false },
|
|
|
- currentItemBackgroundColor: { browser: true, export: false },
|
|
|
- currentItemEndArrowhead: { browser: true, export: false },
|
|
|
- currentItemFillStyle: { browser: true, export: false },
|
|
|
- currentItemFontFamily: { browser: true, export: false },
|
|
|
- currentItemFontSize: { browser: true, export: false },
|
|
|
- currentItemLinearStrokeSharpness: { browser: true, export: false },
|
|
|
- currentItemOpacity: { browser: true, export: false },
|
|
|
- currentItemRoughness: { browser: true, export: false },
|
|
|
- currentItemStartArrowhead: { browser: true, export: false },
|
|
|
- currentItemStrokeColor: { browser: true, export: false },
|
|
|
- currentItemStrokeSharpness: { browser: true, export: false },
|
|
|
- currentItemStrokeStyle: { browser: true, export: false },
|
|
|
- currentItemStrokeWidth: { browser: true, export: false },
|
|
|
- currentItemTextAlign: { browser: true, export: false },
|
|
|
- cursorButton: { browser: true, export: false },
|
|
|
- draggingElement: { browser: false, export: false },
|
|
|
- editingElement: { browser: false, export: false },
|
|
|
- editingGroupId: { browser: true, export: false },
|
|
|
- editingLinearElement: { browser: false, export: false },
|
|
|
- elementLocked: { browser: true, export: false },
|
|
|
- elementType: { browser: true, export: false },
|
|
|
- errorMessage: { browser: false, export: false },
|
|
|
- exportBackground: { browser: true, export: false },
|
|
|
- exportEmbedScene: { browser: true, export: false },
|
|
|
- exportScale: { browser: true, export: false },
|
|
|
- exportWithDarkMode: { browser: true, export: false },
|
|
|
- fileHandle: { browser: false, export: false },
|
|
|
- gridSize: { browser: true, export: true },
|
|
|
- height: { browser: false, export: false },
|
|
|
- isBindingEnabled: { browser: false, export: false },
|
|
|
- isLibraryOpen: { browser: false, export: false },
|
|
|
- isLoading: { browser: false, export: false },
|
|
|
- isResizing: { browser: false, export: false },
|
|
|
- isRotating: { browser: false, export: false },
|
|
|
- lastPointerDownWith: { browser: true, export: false },
|
|
|
- multiElement: { browser: false, export: false },
|
|
|
- name: { browser: true, export: false },
|
|
|
- offsetLeft: { browser: false, export: false },
|
|
|
- offsetTop: { browser: false, export: false },
|
|
|
- openMenu: { browser: true, export: false },
|
|
|
- openPopup: { browser: false, export: false },
|
|
|
- pasteDialog: { browser: false, export: false },
|
|
|
- previousSelectedElementIds: { browser: true, export: false },
|
|
|
- resizingElement: { browser: false, export: false },
|
|
|
- scrolledOutside: { browser: true, export: false },
|
|
|
- scrollX: { browser: true, export: false },
|
|
|
- scrollY: { browser: true, export: false },
|
|
|
- selectedElementIds: { browser: true, export: false },
|
|
|
- selectedGroupIds: { browser: true, export: false },
|
|
|
- selectionElement: { browser: false, export: false },
|
|
|
- shouldCacheIgnoreZoom: { browser: true, export: false },
|
|
|
- showHelpDialog: { browser: false, export: false },
|
|
|
- showStats: { browser: true, export: false },
|
|
|
- startBoundElement: { browser: false, export: false },
|
|
|
- suggestedBindings: { browser: false, export: false },
|
|
|
- toastMessage: { browser: false, export: false },
|
|
|
- viewBackgroundColor: { browser: true, export: true },
|
|
|
- width: { browser: false, export: false },
|
|
|
- zenModeEnabled: { browser: true, export: false },
|
|
|
- zoom: { browser: true, export: false },
|
|
|
- viewModeEnabled: { browser: false, export: false },
|
|
|
+ theme: { browser: true, export: false, server: false },
|
|
|
+ collaborators: { browser: false, export: false, server: false },
|
|
|
+ currentChartType: { browser: true, export: false, server: false },
|
|
|
+ currentItemBackgroundColor: { browser: true, export: false, server: false },
|
|
|
+ currentItemEndArrowhead: { browser: true, export: false, server: false },
|
|
|
+ currentItemFillStyle: { browser: true, export: false, server: false },
|
|
|
+ currentItemFontFamily: { browser: true, export: false, server: false },
|
|
|
+ currentItemFontSize: { browser: true, export: false, server: false },
|
|
|
+ currentItemLinearStrokeSharpness: {
|
|
|
+ browser: true,
|
|
|
+ export: false,
|
|
|
+ server: false,
|
|
|
+ },
|
|
|
+ currentItemOpacity: { browser: true, export: false, server: false },
|
|
|
+ currentItemRoughness: { browser: true, export: false, server: false },
|
|
|
+ currentItemStartArrowhead: { browser: true, export: false, server: false },
|
|
|
+ currentItemStrokeColor: { browser: true, export: false, server: false },
|
|
|
+ currentItemStrokeSharpness: { browser: true, export: false, server: false },
|
|
|
+ currentItemStrokeStyle: { browser: true, export: false, server: false },
|
|
|
+ currentItemStrokeWidth: { browser: true, export: false, server: false },
|
|
|
+ currentItemTextAlign: { browser: true, export: false, server: false },
|
|
|
+ cursorButton: { browser: true, export: false, server: false },
|
|
|
+ draggingElement: { browser: false, export: false, server: false },
|
|
|
+ editingElement: { browser: false, export: false, server: false },
|
|
|
+ editingGroupId: { browser: true, export: false, server: false },
|
|
|
+ editingLinearElement: { browser: false, export: false, server: false },
|
|
|
+ elementLocked: { browser: true, export: false, server: false },
|
|
|
+ elementType: { browser: true, export: false, server: false },
|
|
|
+ errorMessage: { browser: false, export: false, server: false },
|
|
|
+ exportBackground: { browser: true, export: false, server: false },
|
|
|
+ exportEmbedScene: { browser: true, export: false, server: false },
|
|
|
+ exportScale: { browser: true, export: false, server: false },
|
|
|
+ exportWithDarkMode: { browser: true, export: false, server: false },
|
|
|
+ fileHandle: { browser: false, export: false, server: false },
|
|
|
+ gridSize: { browser: true, export: true, server: true },
|
|
|
+ height: { browser: false, export: false, server: false },
|
|
|
+ isBindingEnabled: { browser: false, export: false, server: false },
|
|
|
+ isLibraryOpen: { browser: false, export: false, server: false },
|
|
|
+ isLoading: { browser: false, export: false, server: false },
|
|
|
+ isResizing: { browser: false, export: false, server: false },
|
|
|
+ isRotating: { browser: false, export: false, server: false },
|
|
|
+ lastPointerDownWith: { browser: true, export: false, server: false },
|
|
|
+ multiElement: { browser: false, export: false, server: false },
|
|
|
+ name: { browser: true, export: false, server: false },
|
|
|
+ offsetLeft: { browser: false, export: false, server: false },
|
|
|
+ offsetTop: { browser: false, export: false, server: false },
|
|
|
+ openMenu: { browser: true, export: false, server: false },
|
|
|
+ openPopup: { browser: false, export: false, server: false },
|
|
|
+ pasteDialog: { browser: false, export: false, server: false },
|
|
|
+ previousSelectedElementIds: { browser: true, export: false, server: false },
|
|
|
+ resizingElement: { browser: false, export: false, server: false },
|
|
|
+ scrolledOutside: { browser: true, export: false, server: false },
|
|
|
+ scrollX: { browser: true, export: false, server: false },
|
|
|
+ scrollY: { browser: true, export: false, server: false },
|
|
|
+ selectedElementIds: { browser: true, export: false, server: false },
|
|
|
+ selectedGroupIds: { browser: true, export: false, server: false },
|
|
|
+ selectionElement: { browser: false, export: false, server: false },
|
|
|
+ shouldCacheIgnoreZoom: { browser: true, export: false, server: false },
|
|
|
+ showHelpDialog: { browser: false, export: false, server: false },
|
|
|
+ showStats: { browser: true, export: false, server: false },
|
|
|
+ startBoundElement: { browser: false, export: false, server: false },
|
|
|
+ suggestedBindings: { browser: false, export: false, server: false },
|
|
|
+ toastMessage: { browser: false, export: false, server: false },
|
|
|
+ viewBackgroundColor: { browser: true, export: true, server: true },
|
|
|
+ width: { browser: false, export: false, server: false },
|
|
|
+ zenModeEnabled: { browser: true, export: false, server: false },
|
|
|
+ zoom: { browser: true, export: false, server: false },
|
|
|
+ viewModeEnabled: { browser: false, export: false, server: false },
|
|
|
+ pendingImageElement: { browser: false, export: false, server: false },
|
|
|
});
|
|
|
|
|
|
-const _clearAppStateForStorage = <ExportType extends "export" | "browser">(
|
|
|
+const _clearAppStateForStorage = <
|
|
|
+ ExportType extends "export" | "browser" | "server"
|
|
|
+>(
|
|
|
appState: Partial<AppState>,
|
|
|
exportType: ExportType,
|
|
|
) => {
|
|
@@ -176,8 +186,10 @@ const _clearAppStateForStorage = <ExportType extends "export" | "browser">(
|
|
|
for (const key of Object.keys(appState) as (keyof typeof appState)[]) {
|
|
|
const propConfig = APP_STATE_STORAGE_CONF[key];
|
|
|
if (propConfig?.[exportType]) {
|
|
|
- // @ts-ignore see https://github.com/microsoft/TypeScript/issues/31445
|
|
|
- stateForExport[key] = appState[key];
|
|
|
+ const nextValue = appState[key];
|
|
|
+
|
|
|
+ // https://github.com/microsoft/TypeScript/issues/31445
|
|
|
+ (stateForExport as any)[key] = nextValue;
|
|
|
}
|
|
|
}
|
|
|
return stateForExport;
|
|
@@ -190,3 +202,7 @@ export const clearAppStateForLocalStorage = (appState: Partial<AppState>) => {
|
|
|
export const cleanAppStateForExport = (appState: Partial<AppState>) => {
|
|
|
return _clearAppStateForStorage(appState, "export");
|
|
|
};
|
|
|
+
|
|
|
+export const clearAppStateForDatabase = (appState: Partial<AppState>) => {
|
|
|
+ return _clearAppStateForStorage(appState, "server");
|
|
|
+};
|