tabs saves to forage instead of storage

This commit is contained in:
Jan Prochazka
2023-03-05 15:43:45 +01:00
parent ff044ebec8
commit aa4406942f
3 changed files with 30 additions and 8 deletions

View File

@@ -1,8 +1,8 @@
<script lang="ts">
import localforage from 'localforage';
import _ from 'lodash';
import { TabDefinition } from '../stores';
import getElectron from './getElectron';
import { getLocalStorage, setLocalStorage } from './storageCache';
let counter = 0;
$: counterCopy = counter;
@@ -26,15 +26,15 @@
)
) {
try {
let openedTabs = getLocalStorage('openedTabs') || [];
let openedTabs = (await localforage.getItem<TabDefinition[]>('openedTabs')) || [];
if (!_.isArray(openedTabs)) openedTabs = [];
openedTabs = openedTabs
.map(tab => (tab.closedTime ? tab : { ...tab, closedTime: new Date().getTime() }))
.map(tab => ({ ...tab, selected: false }));
setLocalStorage('openedTabs', openedTabs);
setLocalStorage('selectedWidget', 'history');
await localforage.setItem('openedTabs', openedTabs);
await localStorage.setItem('selectedWidget', 'history');
} catch (err) {
localStorage.removeItem('openedTabs');
localforage.removeItem('openedTabs');
}
// try {
// await localforage.clear();

View File

@@ -2,13 +2,13 @@ import moment from 'moment';
import localforage from 'localforage';
export default async function localStorageGarbageCollector() {
const openedTabsJson = localStorage.getItem('openedTabs');
const openedTabsJson = await localforage.getItem('openedTabs');
let openedTabs = openedTabsJson ? JSON.parse(openedTabsJson) : [];
const closeLimit = moment().add(-7, 'day').valueOf();
openedTabs = openedTabs.filter(x => !x.closedTime || x.closedTime > closeLimit);
localStorage.setItem('openedTabs', JSON.stringify(openedTabs));
await localforage.setItem('openedTabs', JSON.stringify(openedTabs));
const toRemove = [];
for (const key in localStorage) {