74 lines
2.0 KiB
Vue
74 lines
2.0 KiB
Vue
<template>
|
|
<div class="p-8 relative">
|
|
<div class="key-art absolute top-8 left-0 right-0" />
|
|
<div
|
|
class="absolute top-0 bottom-0 left-0 right-0 flex flex-col items-center justify-center"
|
|
:class="`text-${$store.getters.activeTab.darkColor}`"
|
|
@click="click"
|
|
>
|
|
<span
|
|
class="spare-time flex flex-row items-center font-bold rounded-2xl select-none"
|
|
>
|
|
<span
|
|
class="spare-time-value text-3xl md:text-5xl"
|
|
v-text="currencyText"
|
|
/>
|
|
<span class="fas fa-hourglass-half text-xl pl-2 md:text-3xl md:pt-1" />
|
|
</span>
|
|
<span class="spare-time-explanation text-sm md:text-lg select-none">
|
|
Tap to gain
|
|
<b><span class="fas fa-hourglass-half" /> Spare Time</b>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
export default {
|
|
computed: {
|
|
currencyText() {
|
|
if (this.$store.state.currency.greaterThan(1e7)) {
|
|
return this.$store.state.currency.toString()
|
|
}
|
|
return Math.floor(this.$store.state.currency)
|
|
},
|
|
},
|
|
methods: {
|
|
click() {
|
|
if (this.$store.state.gameStopped) return
|
|
|
|
this.$store.commit('addCurrency', 1)
|
|
if (
|
|
this.$store.getters.isTabUnlocked('Time Magic') &&
|
|
this.$store.state.manaMax > this.$store.state.mana
|
|
) {
|
|
this.$store.commit('tickMana')
|
|
}
|
|
},
|
|
},
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
.key-art {
|
|
background: url('https://freesvg.org/img/johnny_automatic_hourglass.png');
|
|
background-size: contain;
|
|
background-repeat: no-repeat;
|
|
background-position: center;
|
|
opacity: 0.4;
|
|
height: calc(100% - 4rem); /* 4rem = top padding + bottom padding */
|
|
}
|
|
.spare-time {
|
|
--color: rgba(2555, 255, 255, 0.5);
|
|
box-shadow: 0px 0px 20px 20px var(--color);
|
|
background: var(--color);
|
|
transition: color 2000ms;
|
|
}
|
|
.spare-time-explanation {
|
|
--color: rgba(2555, 255, 255, 0.2);
|
|
box-shadow: 0px 0px 10px 10px var(--color);
|
|
background: var(--color);
|
|
transition: color 2000ms;
|
|
}
|
|
</style>
|