2020-12-05 20:00:53 +05:30
|
|
|
import { ExcalidrawElement } from "../../element/types";
|
|
|
|
import { AppState } from "../../types";
|
|
|
|
import {
|
|
|
|
clearAppStateForLocalStorage,
|
|
|
|
getDefaultAppState,
|
|
|
|
} from "../../appState";
|
|
|
|
import { clearElementsForLocalStorage } from "../../element";
|
|
|
|
import { STORAGE_KEYS as APP_STORAGE_KEYS } from "../../constants";
|
|
|
|
|
|
|
|
export const STORAGE_KEYS = {
|
|
|
|
LOCAL_STORAGE_ELEMENTS: "excalidraw",
|
|
|
|
LOCAL_STORAGE_APP_STATE: "excalidraw-state",
|
|
|
|
LOCAL_STORAGE_COLLAB: "excalidraw-collab",
|
|
|
|
LOCAL_STORAGE_KEY_COLLAB_FORCE_FLAG: "collabLinkForceLoadFlag",
|
|
|
|
};
|
2020-04-11 17:13:10 +01:00
|
|
|
|
2020-05-20 16:21:37 +03:00
|
|
|
export const saveUsernameToLocalStorage = (username: string) => {
|
2020-04-11 17:13:10 +01:00
|
|
|
try {
|
|
|
|
localStorage.setItem(
|
2020-10-30 21:01:41 +01:00
|
|
|
STORAGE_KEYS.LOCAL_STORAGE_COLLAB,
|
2020-04-11 17:13:10 +01:00
|
|
|
JSON.stringify({ username }),
|
|
|
|
);
|
2021-11-02 14:24:16 +02:00
|
|
|
} catch (error: any) {
|
2020-04-11 17:13:10 +01:00
|
|
|
// Unable to access window.localStorage
|
|
|
|
console.error(error);
|
|
|
|
}
|
2020-05-20 16:21:37 +03:00
|
|
|
};
|
2020-04-11 17:13:10 +01:00
|
|
|
|
2020-08-26 16:15:54 +05:30
|
|
|
export const importUsernameFromLocalStorage = (): string | null => {
|
2020-04-11 17:13:10 +01:00
|
|
|
try {
|
2020-10-30 21:01:41 +01:00
|
|
|
const data = localStorage.getItem(STORAGE_KEYS.LOCAL_STORAGE_COLLAB);
|
2020-04-11 17:13:10 +01:00
|
|
|
if (data) {
|
|
|
|
return JSON.parse(data).username;
|
|
|
|
}
|
2021-11-02 14:24:16 +02:00
|
|
|
} catch (error: any) {
|
2020-04-11 17:13:10 +01:00
|
|
|
// Unable to access localStorage
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
2020-05-20 16:21:37 +03:00
|
|
|
};
|
2020-03-07 10:20:38 -05:00
|
|
|
|
2020-05-20 16:21:37 +03:00
|
|
|
export const saveToLocalStorage = (
|
2020-03-07 10:20:38 -05:00
|
|
|
elements: readonly ExcalidrawElement[],
|
|
|
|
appState: AppState,
|
2020-05-20 16:21:37 +03:00
|
|
|
) => {
|
2020-04-07 15:39:37 +05:30
|
|
|
try {
|
|
|
|
localStorage.setItem(
|
2020-10-30 21:01:41 +01:00
|
|
|
STORAGE_KEYS.LOCAL_STORAGE_ELEMENTS,
|
2020-11-11 15:55:22 +01:00
|
|
|
JSON.stringify(clearElementsForLocalStorage(elements)),
|
2020-04-07 15:39:37 +05:30
|
|
|
);
|
|
|
|
localStorage.setItem(
|
2020-10-30 21:01:41 +01:00
|
|
|
STORAGE_KEYS.LOCAL_STORAGE_APP_STATE,
|
2020-04-07 15:39:37 +05:30
|
|
|
JSON.stringify(clearAppStateForLocalStorage(appState)),
|
|
|
|
);
|
2021-11-02 14:24:16 +02:00
|
|
|
} catch (error: any) {
|
2020-04-07 15:39:37 +05:30
|
|
|
// Unable to access window.localStorage
|
|
|
|
console.error(error);
|
|
|
|
}
|
2020-05-20 16:21:37 +03:00
|
|
|
};
|
2020-03-07 10:20:38 -05:00
|
|
|
|
2020-08-26 16:15:54 +05:30
|
|
|
export const importFromLocalStorage = () => {
|
2020-04-07 15:39:37 +05:30
|
|
|
let savedElements = null;
|
|
|
|
let savedState = null;
|
|
|
|
|
|
|
|
try {
|
2020-10-30 21:01:41 +01:00
|
|
|
savedElements = localStorage.getItem(STORAGE_KEYS.LOCAL_STORAGE_ELEMENTS);
|
|
|
|
savedState = localStorage.getItem(STORAGE_KEYS.LOCAL_STORAGE_APP_STATE);
|
2021-11-02 14:24:16 +02:00
|
|
|
} catch (error: any) {
|
2020-04-07 15:39:37 +05:30
|
|
|
// Unable to access localStorage
|
|
|
|
console.error(error);
|
|
|
|
}
|
2020-03-07 10:20:38 -05:00
|
|
|
|
2020-11-11 15:55:22 +01:00
|
|
|
let elements: ExcalidrawElement[] = [];
|
2020-03-07 10:20:38 -05:00
|
|
|
if (savedElements) {
|
|
|
|
try {
|
2020-11-11 15:55:22 +01:00
|
|
|
elements = clearElementsForLocalStorage(JSON.parse(savedElements));
|
2021-11-02 14:24:16 +02:00
|
|
|
} catch (error: any) {
|
2020-07-11 13:09:40 +02:00
|
|
|
console.error(error);
|
2020-03-07 10:20:38 -05:00
|
|
|
// Do nothing because elements array is already empty
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
let appState = null;
|
|
|
|
if (savedState) {
|
|
|
|
try {
|
2020-07-11 13:09:40 +02:00
|
|
|
appState = {
|
|
|
|
...getDefaultAppState(),
|
|
|
|
...clearAppStateForLocalStorage(
|
|
|
|
JSON.parse(savedState) as Partial<AppState>,
|
|
|
|
),
|
|
|
|
};
|
2021-11-02 14:24:16 +02:00
|
|
|
} catch (error: any) {
|
2020-07-11 13:09:40 +02:00
|
|
|
console.error(error);
|
2020-03-07 10:20:38 -05:00
|
|
|
// Do nothing because appState is already null
|
|
|
|
}
|
|
|
|
}
|
2020-08-26 16:15:54 +05:30
|
|
|
return { elements, appState };
|
2020-05-20 16:21:37 +03:00
|
|
|
};
|
2020-12-05 01:18:21 +02:00
|
|
|
|
2020-12-07 18:35:16 +02:00
|
|
|
export const getElementsStorageSize = () => {
|
2020-12-11 18:13:13 +02:00
|
|
|
try {
|
|
|
|
const elements = localStorage.getItem(STORAGE_KEYS.LOCAL_STORAGE_ELEMENTS);
|
2021-04-01 14:49:31 +05:30
|
|
|
const elementsSize = elements?.length || 0;
|
2020-12-11 18:13:13 +02:00
|
|
|
return elementsSize;
|
2021-11-02 14:24:16 +02:00
|
|
|
} catch (error: any) {
|
2020-12-11 18:13:13 +02:00
|
|
|
console.error(error);
|
|
|
|
return 0;
|
|
|
|
}
|
2020-12-07 18:35:16 +02:00
|
|
|
};
|
|
|
|
|
2020-12-05 01:18:21 +02:00
|
|
|
export const getTotalStorageSize = () => {
|
2020-12-11 18:13:13 +02:00
|
|
|
try {
|
|
|
|
const appState = localStorage.getItem(STORAGE_KEYS.LOCAL_STORAGE_APP_STATE);
|
|
|
|
const collab = localStorage.getItem(STORAGE_KEYS.LOCAL_STORAGE_COLLAB);
|
|
|
|
const library = localStorage.getItem(
|
|
|
|
APP_STORAGE_KEYS.LOCAL_STORAGE_LIBRARY,
|
|
|
|
);
|
2020-12-05 01:18:21 +02:00
|
|
|
|
2021-04-01 14:49:31 +05:30
|
|
|
const appStateSize = appState?.length || 0;
|
|
|
|
const collabSize = collab?.length || 0;
|
|
|
|
const librarySize = library?.length || 0;
|
2020-12-05 01:18:21 +02:00
|
|
|
|
2020-12-11 18:13:13 +02:00
|
|
|
return appStateSize + collabSize + librarySize + getElementsStorageSize();
|
2021-11-02 14:24:16 +02:00
|
|
|
} catch (error: any) {
|
2020-12-11 18:13:13 +02:00
|
|
|
console.error(error);
|
|
|
|
return 0;
|
|
|
|
}
|
2020-12-05 01:18:21 +02:00
|
|
|
};
|