Wrap localStorage API Access in try-catch (#1241)
This commit is contained in:
parent
2cc1105ff5
commit
22160f50d3
@ -81,8 +81,12 @@ export class TopErrorBoundary extends React.Component<
|
|||||||
{t("errorSplash.clearCanvasMessage")}
|
{t("errorSplash.clearCanvasMessage")}
|
||||||
<button
|
<button
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
localStorage.clear();
|
try {
|
||||||
window.location.reload();
|
localStorage.clear();
|
||||||
|
window.location.reload();
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error);
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
{t("errorSplash.clearCanvasMessage_button")}
|
{t("errorSplash.clearCanvasMessage_button")}
|
||||||
|
@ -10,19 +10,32 @@ export function saveToLocalStorage(
|
|||||||
elements: readonly ExcalidrawElement[],
|
elements: readonly ExcalidrawElement[],
|
||||||
appState: AppState,
|
appState: AppState,
|
||||||
) {
|
) {
|
||||||
localStorage.setItem(
|
try {
|
||||||
LOCAL_STORAGE_KEY,
|
localStorage.setItem(
|
||||||
JSON.stringify(elements.filter((element) => !element.isDeleted)),
|
LOCAL_STORAGE_KEY,
|
||||||
);
|
JSON.stringify(elements.filter((element) => !element.isDeleted)),
|
||||||
localStorage.setItem(
|
);
|
||||||
LOCAL_STORAGE_KEY_STATE,
|
localStorage.setItem(
|
||||||
JSON.stringify(clearAppStateForLocalStorage(appState)),
|
LOCAL_STORAGE_KEY_STATE,
|
||||||
);
|
JSON.stringify(clearAppStateForLocalStorage(appState)),
|
||||||
|
);
|
||||||
|
} catch (error) {
|
||||||
|
// Unable to access window.localStorage
|
||||||
|
console.error(error);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export function restoreFromLocalStorage() {
|
export function restoreFromLocalStorage() {
|
||||||
const savedElements = localStorage.getItem(LOCAL_STORAGE_KEY);
|
let savedElements = null;
|
||||||
const savedState = localStorage.getItem(LOCAL_STORAGE_KEY_STATE);
|
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 = [];
|
let elements = [];
|
||||||
if (savedElements) {
|
if (savedElements) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user