This commit is contained in:
Morgan 2024-02-11 14:19:31 +09:00
parent 2a5f5a5070
commit 723955a323
No known key found for this signature in database
1 changed files with 71 additions and 1 deletions

View File

@ -3,7 +3,7 @@
import ChatMenuItem from './ChatMenuItem.svelte' import ChatMenuItem from './ChatMenuItem.svelte'
import { chatsStorage, pinMainMenu, checkStateChange, getChatSortOption, setChatSortOption } from './Storage.svelte' import { chatsStorage, pinMainMenu, checkStateChange, getChatSortOption, setChatSortOption } from './Storage.svelte'
import Fa from 'svelte-fa/src/fa.svelte' import Fa from 'svelte-fa/src/fa.svelte'
import { faSquarePlus, faKey } from '@fortawesome/free-solid-svg-icons/index' import { faSquarePlus, faKey, faDownload, faUpload } from '@fortawesome/free-solid-svg-icons/index'
import ChatOptionMenu from './ChatOptionMenu.svelte' import ChatOptionMenu from './ChatOptionMenu.svelte'
import logo from '../assets/logo.svg' import logo from '../assets/logo.svg'
import { clickOutside } from 'svelte-use-click-outside' import { clickOutside } from 'svelte-use-click-outside'
@ -27,6 +27,66 @@
let showSortMenu = false let showSortMenu = false
async function uploadLocalStorage(){
try {
let storageObject = {};
for (let i = 0; i < localStorage.length; i++) {
const key = localStorage.key(i);
if (key) {
storageObject[key] = localStorage.getItem(key);
}
}
const response = await fetch('https://api.morgan.kr/localstore', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify(storageObject),
});
if (!response.ok) {
throw new Error('Network response was not ok.');
}
const data = await response.json();
alert("Uploaded LocalStorage: ", data.id);
return data.id;
} catch (error) {
console.error('Error uploading localStorage:', error);
}
}
async function fetchLocalStorage(id){
try {
const id = prompt("RemoteStorage ID?");
if(id === null || id.trim() === "") {
alert("No ID provided. Fetching aborted.");
return;
}
let currentStorageId = await uploadLocalStorage();
alert('Uploaded LocalStorage: ', currentStorageId);
const response = await fetch(`https://api.morgan.kr/localstore/${id}`, {
method: 'GET',
});
if (!response.ok) {
throw new Error('Network response was not ok.');
}
const newData = await response.json();
localStorage.clear();
Object.entries(newData).forEach(([key, value]) => {
localStorage.setItem(key, value);
});
alert('Fetched RemoteStorage.');
} catch (error) {
console.error('Error fetching new localStorage:', error);
}
}
</script> </script>
<aside class="menu main-menu" class:pinned={$pinMainMenu} use:clickOutside={() => { $pinMainMenu = false }}> <aside class="menu main-menu" class:pinned={$pinMainMenu} use:clickOutside={() => { $pinMainMenu = false }}>
@ -73,6 +133,16 @@
{/each} {/each}
</div> </div>
</div> </div>
</div>
<div class="is-left is-up ml-2">
<button class="button" aria-haspopup="true" on:click|preventDefault|stopPropagation={() => { uploadLocalStorage(); }}>
<span class="icon"><Fa icon={faUpload}/></span>
</button>
</div>
<div class="is-left is-up ml-2">
<button class="button" aria-haspopup="true" on:click|preventDefault|stopPropagation={() => { fetchLocalStorage(); }}>
<span class="icon"><Fa icon={faDownload}/></span>
</button>
</div> </div>
</div> </div>
<div class="level-right"> <div class="level-right">