From 8567c6b8314cd0a971be3c59a480cec1b1470913 Mon Sep 17 00:00:00 2001 From: I Made Setia Baruna Date: Fri, 6 Nov 2020 15:24:41 +0700 Subject: [PATCH] WIP: data conflict resolve --- src/components/DataSync.svelte | 44 ++++++++++++++++++++++--- src/components/SyncConflictModal.svelte | 24 +++++++++++--- src/routes/_layout.svelte | 9 ++--- src/routes/wish/_counter.svelte | 1 + src/stores/dataSync.js | 3 +- src/stores/saveManager.js | 32 ++++++++++++++++++ 6 files changed, 99 insertions(+), 14 deletions(-) diff --git a/src/components/DataSync.svelte b/src/components/DataSync.svelte index 92ef240f..b85771b5 100644 --- a/src/components/DataSync.svelte +++ b/src/components/DataSync.svelte @@ -2,13 +2,13 @@ // doc: /static/images.save_sync_flow.png import dayjs from 'dayjs'; - import { onMount, getContext } from 'svelte'; - import { driveSignedIn, driveLoading, saveId } from '../stores/dataSync'; + import { onMount, getContext, setContext } from 'svelte'; + import { driveSignedIn, driveLoading, saveId, synced } from '../stores/dataSync'; import { getLocalSaveJson, updateSave, updateTime, UPDATE_TIME_KEY } from '../stores/saveManager'; import SyncConflictModal from '../components/SyncConflictModal.svelte'; - const { open: openModal } = getContext('simple-modal'); + const { open: openModal, close: closeModal } = getContext('simple-modal'); const CLIENT_ID = __paimon.env.GOOGLE_DRIVE_CLIENT_ID; const API_KEY = __paimon.env.GOOGLE_DRIVE_API_KEY; @@ -19,12 +19,21 @@ $: localSaveExists = $updateTime !== null; + setContext('sync', { + startSync, + }); + onMount(() => { + startSync(); + }); + + function startSync() { + synced.set(false); const script = document.createElement('script'); script.onload = handleClientLoad; script.src = 'https://apis.google.com/js/api.js'; document.body.appendChild(script); - }); + } function handleClientLoad() { gapi.load('client:auth2', initClient); @@ -37,6 +46,8 @@ if (status) { getFiles(); + } else { + synced.set(true); } } @@ -51,6 +62,22 @@ } } + async function useRemoteData() { + for (const k in remoteSave) { + updateSave(k, remoteSave[k], true); + } + + synced.set(true); + closeModal(); + } + + async function useLocalData() { + await saveData(getLocalSaveJson()); + + synced.set(true); + closeModal(); + } + async function compareLocalSave() { try { const data = await getData(); @@ -65,6 +92,8 @@ remoteTime: remoteTime, localTime: $updateTime, downloadBackup: exportData, + useRemote: useRemoteData, + useLocal: useLocalData, }, { closeButton: false, @@ -73,6 +102,8 @@ styleWindow: { background: '#25294A' }, }, ); + } else { + synced.set(true); } } catch (err) { console.error(err); @@ -100,6 +131,7 @@ await compareLocalSave(); } else { await copyRemoteToLocal(); + synced.set(true); } } } catch (err) { @@ -125,6 +157,7 @@ await saveData(getLocalSaveJson()); } + synced.set(true); console.log(result); } catch (err) { console.error(err); @@ -140,6 +173,7 @@ alt: 'media', }); + console.log(result); return result; } catch (err) { console.error(err); @@ -199,3 +233,5 @@ fileLink.click(); } + + diff --git a/src/components/SyncConflictModal.svelte b/src/components/SyncConflictModal.svelte index efe63ef0..97449ded 100644 --- a/src/components/SyncConflictModal.svelte +++ b/src/components/SyncConflictModal.svelte @@ -1,5 +1,5 @@