Add wish counter manual edit

This commit is contained in:
I Made Setia Baruna 2021-01-13 15:33:09 +08:00
parent 9cf7b53edb
commit 8d3fd97d6b
3 changed files with 76 additions and 25 deletions

View file

@ -32,5 +32,5 @@
{max} {max}
on:change on:change
on:input={handleInput} on:input={handleInput}
class={`w-full ${icon ? 'pl-12' : 'pl-4'} pr-4 text-white placeholder-gray-500 leading-none bg-transparent border-none focus:outline-none`} /> class={`w-full ${icon ? 'pl-12' : 'pl-4'} min-h-full pr-4 text-white placeholder-gray-500 leading-none bg-transparent border-none focus:outline-none`} />
</div> </div>

View file

@ -1,5 +1,5 @@
<script> <script>
import { mdiStar } from '@mdi/js'; import { mdiPencil, mdiStar } from '@mdi/js';
import Icon from './Icon.svelte'; import Icon from './Icon.svelte';
</script> </script>
@ -60,4 +60,11 @@
occur (maybe you got it on the 1st or even the 10th). To make the counter still accurate, you need to check it on occur (maybe you got it on the 1st or even the 10th). To make the counter still accurate, you need to check it on
the history table and add it 1 by 1 like you do 1 pull Wish.</span> the history table and add it 1 by 1 like you do 1 pull Wish.</span>
</div> </div>
<div class="text-white p-2 bg-background rounded-xl mt-4">
You can also press
<b class="rounded-lg px-2 py-1 border-white border inline-flex items-center"><Icon
path={mdiPencil}
size={0.7} /></b>
button to edit the values manually!
</div>
</div> </div>

View file

@ -1,18 +1,26 @@
<script> <script>
import { onMount } from 'svelte'; import { onMount } from 'svelte';
import { mdiStar } from '@mdi/js'; import { mdiPencil, mdiStar } from '@mdi/js';
import debounce from 'lodash/debounce'; import debounce from 'lodash/debounce';
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 Input from '../../components/Input.svelte';
import { readSave, updateSave, fromRemote } from '../../stores/saveManager'; import { readSave, updateSave, fromRemote } from '../../stores/saveManager';
export let id = ''; export let id = '';
export let name = ''; export let name = '';
let isEdit = false;
let total = 0; let total = 0;
let legendary = 0; let legendary = 0;
let rare = 0; let rare = 0;
let totalEdit = 0;
let legendaryEdit = 0;
let rareEdit = 0;
$: path = `wish-counter-${id}`; $: path = `wish-counter-${id}`;
$: if ($fromRemote) { $: if ($fromRemote) {
readLocalData(); readLocalData();
@ -22,6 +30,24 @@
readLocalData(); readLocalData();
}); });
function toggleEdit() {
isEdit = !isEdit;
if (isEdit) {
totalEdit = total;
legendaryEdit = legendary;
rareEdit = rare;
}
}
function saveEdit() {
total = totalEdit;
legendary = legendaryEdit;
rare = rareEdit;
saveData();
isEdit = false;
}
function readLocalData() { function readLocalData() {
console.log('wish read local'); console.log('wish read local');
const data = readSave(path); const data = readSave(path);
@ -82,30 +108,47 @@
</script> </script>
<div class="bg-item rounded-xl p-4 inline-flex flex-col w-full"> <div class="bg-item rounded-xl p-4 inline-flex flex-col w-full">
<h2 class="font-display font-bold text-2xl text-white mb-2">{name}</h2> <div class="flex justify-between mb-2">
<div class="flex flex-col w-full"> <h2 class="font-display font-bold text-2xl text-white">{name}</h2>
<div class="bg-background rounded-xl p-4 flex flex-row items-center justify-center mb-2"> <Button size="sm" on:click={toggleEdit}>
<span class="text-gray-200 whitespace-no-wrap flex-1">Lifetime Pulls</span> <Icon path={mdiPencil} color="white" />
<span class="font-black text-3xl text-white ml-4">{total}</span> </Button>
</div> </div>
<div class="bg-background rounded-xl p-4 flex flex-row items-center justify-center mb-2"> <div class="flex flex-col w-full">
<div
class={`${isEdit ? 'bg-item flex-col py-2' : 'bg-background flex-row items-center justify-center mb-2 p-4'} rounded-xl flex`}>
<span class="text-gray-200 whitespace-no-wrap flex-1">Lifetime Pulls</span>
{#if isEdit}
<Input type="number" min={1} bind:value={totalEdit} />
{:else}<span class="font-black text-3xl text-white ml-4">{total}</span>{/if}
</div>
<div
class={`${isEdit ? 'bg-item flex-col py-2' : 'bg-background flex-row items-center justify-center mb-2 p-4'} rounded-xl flex`}>
<span class="text-gray-200 whitespace-no-wrap flex-1"> <span class="text-gray-200 whitespace-no-wrap flex-1">
5 5
<Icon path={mdiStar} size={0.75} className="mb-1" /> <Icon path={mdiStar} size={0.75} className="mb-1" />
Pity Pity
<br /><span class="text-gray-600">Guaranteed at 90</span> <br /><span class="text-gray-600">Guaranteed at 90</span>
</span> </span>
<span class="font-black text-3xl text-legendary-from ml-4">{legendary}</span> {#if isEdit}
<Input type="number" min={1} bind:value={legendaryEdit} />
{:else}<span class="font-black text-3xl text-legendary-from ml-4">{legendary}</span>{/if}
</div> </div>
<div class="bg-background rounded-xl p-4 flex flex-row items-center justify-center"> <div
class={`${isEdit ? 'bg-item flex-col py-2' : 'bg-background flex-row items-center justify-center mb-2 p-4'} rounded-xl flex`}>
<span class="text-gray-200 whitespace-no-wrap flex-1"> <span class="text-gray-200 whitespace-no-wrap flex-1">
4 4
<Icon path={mdiStar} size={0.75} className="mb-1" /> <Icon path={mdiStar} size={0.75} className="mb-1" />
Pity Pity
<br /><span class="text-gray-600">Guaranteed at 10</span> <br /><span class="text-gray-600">Guaranteed at 10</span>
</span> </span>
<span class="font-black text-3xl text-rare-from ml-4">{rare}</span> {#if isEdit}
<Input type="number" min={1} bind:value={rareEdit} />
{:else}<span class="font-black text-3xl text-rare-from ml-4">{rare}</span>{/if}
</div> </div>
{#if isEdit}
<Button on:click={saveEdit} className="mt-4">Save</Button>
{:else}
<div class="flex gap-2 mt-2"> <div class="flex gap-2 mt-2">
<Button on:click={getLegendary} className="flex-1"> <Button on:click={getLegendary} className="flex-1">
Get 5 Get 5
@ -121,5 +164,6 @@
<Button on:click={() => add(10)} className="flex-1">+10</Button> <Button on:click={() => add(10)} className="flex-1">+10</Button>
<Button on:click={() => add(-1)} className="flex-1">-1</Button> <Button on:click={() => add(-1)} className="flex-1">-1</Button>
</div> </div>
{/if}
</div> </div>
</div> </div>