|
|
|
@ -10,19 +10,32 @@ export function saveToLocalStorage(
|
|
|
|
|
elements: readonly ExcalidrawElement[],
|
|
|
|
|
appState: AppState,
|
|
|
|
|
) {
|
|
|
|
|
localStorage.setItem(
|
|
|
|
|
LOCAL_STORAGE_KEY,
|
|
|
|
|
JSON.stringify(elements.filter((element) => !element.isDeleted)),
|
|
|
|
|
);
|
|
|
|
|
localStorage.setItem(
|
|
|
|
|
LOCAL_STORAGE_KEY_STATE,
|
|
|
|
|
JSON.stringify(clearAppStateForLocalStorage(appState)),
|
|
|
|
|
);
|
|
|
|
|
try {
|
|
|
|
|
localStorage.setItem(
|
|
|
|
|
LOCAL_STORAGE_KEY,
|
|
|
|
|
JSON.stringify(elements.filter((element) => !element.isDeleted)),
|
|
|
|
|
);
|
|
|
|
|
localStorage.setItem(
|
|
|
|
|
LOCAL_STORAGE_KEY_STATE,
|
|
|
|
|
JSON.stringify(clearAppStateForLocalStorage(appState)),
|
|
|
|
|
);
|
|
|
|
|
} catch (error) {
|
|
|
|
|
// Unable to access window.localStorage
|
|
|
|
|
console.error(error);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function restoreFromLocalStorage() {
|
|
|
|
|
const savedElements = localStorage.getItem(LOCAL_STORAGE_KEY);
|
|
|
|
|
const savedState = localStorage.getItem(LOCAL_STORAGE_KEY_STATE);
|
|
|
|
|
let savedElements = null;
|
|
|
|
|
let savedState = null;
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
savedElements = localStorage.getItem(LOCAL_STORAGE_KEY);
|
|
|
|
|
savedState = localStorage.getItem(LOCAL_STORAGE_KEY_STATE);
|
|
|
|
|
} catch (error) {
|
|
|
|
|
// Unable to access localStorage
|
|
|
|
|
console.error(error);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let elements = [];
|
|
|
|
|
if (savedElements) {
|
|
|
|
|