mirror of
https://github.com/MadeBaruna/paimon-moe.git
synced 2025-01-08 19:33:51 +01:00
Add data sync for wish counter
This commit is contained in:
parent
8567c6b831
commit
0641747a78
3 changed files with 49 additions and 8 deletions
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
import Button from '../components/Button.svelte';
|
import Button from '../components/Button.svelte';
|
||||||
import Icon from '../components/Icon.svelte';
|
import Icon from '../components/Icon.svelte';
|
||||||
import { driveSignedIn, driveLoading, synced } from '../stores/dataSync';
|
import { driveSignedIn, driveLoading, synced, localModified, lastSyncTime } from '../stores/dataSync';
|
||||||
|
|
||||||
function signIn() {
|
function signIn() {
|
||||||
gapi.auth2.getAuthInstance().signIn();
|
gapi.auth2.getAuthInstance().signIn();
|
||||||
|
@ -12,6 +12,8 @@
|
||||||
function signOut() {
|
function signOut() {
|
||||||
gapi.auth2.getAuthInstance().signOut();
|
gapi.auth2.getAuthInstance().signOut();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$: isSynced = $synced && !$localModified;
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="lg:ml-64 pt-20 px-8 lg:pt-8">
|
<div class="lg:ml-64 pt-20 px-8 lg:pt-8">
|
||||||
|
@ -33,14 +35,17 @@
|
||||||
</Button>
|
</Button>
|
||||||
<p class="text-white mt-4">
|
<p class="text-white mt-4">
|
||||||
Sync Status:
|
Sync Status:
|
||||||
<span class={`font-bold ${$synced ? 'text-green-400' : 'text-yellow-400'}`}>
|
<span class={`font-bold ${isSynced ? 'text-green-400' : 'text-yellow-400'}`}>
|
||||||
{$synced ? 'Synced' : 'Syncing...'}
|
{isSynced ? 'Synced' : $localModified && $synced ? 'Waiting...' : 'Syncing...'}
|
||||||
{#if $synced}
|
{#if isSynced}
|
||||||
<Icon path={mdiCheckCircleOutline} className="text-green-400" />
|
<Icon path={mdiCheckCircleOutline} className="text-green-400" />
|
||||||
{:else}
|
{:else if $localModified && !$synced}
|
||||||
<Icon path={mdiLoading} className="text-yellow-400" spin />
|
<Icon path={mdiLoading} className="text-yellow-400" spin />
|
||||||
{/if}
|
{/if}
|
||||||
</span>
|
</span>
|
||||||
</p>
|
</p>
|
||||||
|
{#if $lastSyncTime !== null}
|
||||||
|
<p class="text-gray-400">Last Sync: {$lastSyncTime.format('dddd, MMMM D, YYYY h:mm:ss A')}</p>
|
||||||
|
{/if}
|
||||||
{/if}
|
{/if}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -3,5 +3,6 @@ import { writable } from 'svelte/store';
|
||||||
export const driveSignedIn = writable(false);
|
export const driveSignedIn = writable(false);
|
||||||
export const driveLoading = writable(true);
|
export const driveLoading = writable(true);
|
||||||
export const lastSyncTime = writable(null);
|
export const lastSyncTime = writable(null);
|
||||||
|
export const localModified = writable(false);
|
||||||
export const synced = writable(false);
|
export const synced = writable(false);
|
||||||
export const saveId = writable('');
|
export const saveId = writable('');
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
import dayjs from 'dayjs';
|
import dayjs from 'dayjs';
|
||||||
import { writable } from 'svelte/store';
|
import { writable } from 'svelte/store';
|
||||||
|
import debounce from 'lodash/debounce';
|
||||||
|
|
||||||
import { synced } from './dataSync';
|
import { synced, saveId, localModified, lastSyncTime } from './dataSync';
|
||||||
|
|
||||||
export const updateTime = writable(null);
|
export const updateTime = writable(null);
|
||||||
export const fromRemote = writable(false);
|
export const fromRemote = writable(false);
|
||||||
|
@ -10,13 +11,43 @@ export const UPDATE_TIME_KEY = 'update-time';
|
||||||
|
|
||||||
let pendingQueue = [];
|
let pendingQueue = [];
|
||||||
let queueSave = true;
|
let queueSave = true;
|
||||||
|
let saveFileId = '';
|
||||||
|
|
||||||
const unsubscribe = synced.subscribe((value) => {
|
saveId.subscribe((val) => {
|
||||||
|
saveFileId = val;
|
||||||
|
});
|
||||||
|
|
||||||
|
const saveToRemote = debounce(() => {
|
||||||
|
saveData(getLocalSaveJson());
|
||||||
|
}, 5000);
|
||||||
|
|
||||||
|
async function saveData(data) {
|
||||||
|
console.log('saving to remote file');
|
||||||
|
synced.set(false);
|
||||||
|
|
||||||
|
try {
|
||||||
|
await gapi.client.request({
|
||||||
|
path: `/upload/drive/v3/files/${saveFileId}`,
|
||||||
|
method: 'PATCH',
|
||||||
|
params: {
|
||||||
|
uploadType: 'media',
|
||||||
|
},
|
||||||
|
body: data,
|
||||||
|
});
|
||||||
|
synced.set(true);
|
||||||
|
localModified.set(false);
|
||||||
|
} catch (err) {
|
||||||
|
console.error(err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
synced.subscribe((value) => {
|
||||||
console.log('synced:', value);
|
console.log('synced:', value);
|
||||||
queueSave = !value;
|
queueSave = !value;
|
||||||
|
|
||||||
if (value) {
|
if (value) {
|
||||||
flushPendingQueue();
|
flushPendingQueue();
|
||||||
|
lastSyncTime.set(dayjs());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -33,6 +64,10 @@ export const getLocalSaveJson = () => {
|
||||||
};
|
};
|
||||||
|
|
||||||
export const updateSave = (key, data, isFromRemote) => {
|
export const updateSave = (key, data, isFromRemote) => {
|
||||||
|
if (!isFromRemote) {
|
||||||
|
localModified.set(true);
|
||||||
|
}
|
||||||
|
|
||||||
if (queueSave && !isFromRemote) {
|
if (queueSave && !isFromRemote) {
|
||||||
pendingQueue.push({ key, data });
|
pendingQueue.push({ key, data });
|
||||||
return;
|
return;
|
||||||
|
@ -44,6 +79,7 @@ export const updateSave = (key, data, isFromRemote) => {
|
||||||
const currentTime = dayjs().toISOString();
|
const currentTime = dayjs().toISOString();
|
||||||
updateTime.set(currentTime);
|
updateTime.set(currentTime);
|
||||||
localStorage.setItem(UPDATE_TIME_KEY, currentTime);
|
localStorage.setItem(UPDATE_TIME_KEY, currentTime);
|
||||||
|
saveToRemote();
|
||||||
} else {
|
} else {
|
||||||
fromRemote.set(true);
|
fromRemote.set(true);
|
||||||
}
|
}
|
||||||
|
@ -64,5 +100,4 @@ export const flushPendingQueue = () => {
|
||||||
|
|
||||||
pendingQueue = [];
|
pendingQueue = [];
|
||||||
queueSave = false;
|
queueSave = false;
|
||||||
unsubscribe();
|
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue