mirror of
https://github.com/logos-storage/ethcc-demo.git
synced 2026-05-24 09:59:28 +00:00
97 lines
1.6 KiB
Vue
97 lines
1.6 KiB
Vue
|
|
<script setup>
|
||
|
|
import { onMounted } from 'vue'
|
||
|
|
import { useEventsStore } from './stores/events'
|
||
|
|
import { RouterView } from 'vue-router'
|
||
|
|
import Balance from './components/Balance.vue'
|
||
|
|
import BlockNumber from './components/BlockNumber.vue'
|
||
|
|
import AppNav from './components/AppNav.vue'
|
||
|
|
import { initDrawers } from 'flowbite'
|
||
|
|
|
||
|
|
const eventsStore = useEventsStore()
|
||
|
|
|
||
|
|
onMounted(async () => {
|
||
|
|
initDrawers()
|
||
|
|
await eventsStore.fetchPastEvents()
|
||
|
|
|
||
|
|
function onStorageRequested(blockNumber, requestId, request, state) {
|
||
|
|
alert('storage requested')
|
||
|
|
}
|
||
|
|
await eventsStore.listenForNewEvents(onStorageRequested)
|
||
|
|
})
|
||
|
|
</script>
|
||
|
|
|
||
|
|
<template>
|
||
|
|
<header>
|
||
|
|
<AppNav />
|
||
|
|
</header>
|
||
|
|
<RouterView class="max-w-screen-xl mx-auto" />
|
||
|
|
<footer>
|
||
|
|
<Balance />
|
||
|
|
<BlockNumber />
|
||
|
|
</footer>
|
||
|
|
</template>
|
||
|
|
|
||
|
|
<!-- <style scoped>
|
||
|
|
header {
|
||
|
|
line-height: 1.5;
|
||
|
|
max-height: 100vh;
|
||
|
|
}
|
||
|
|
|
||
|
|
.logo {
|
||
|
|
display: block;
|
||
|
|
margin: 0 auto 2rem;
|
||
|
|
}
|
||
|
|
|
||
|
|
nav {
|
||
|
|
width: 100%;
|
||
|
|
font-size: 12px;
|
||
|
|
text-align: center;
|
||
|
|
margin-top: 2rem;
|
||
|
|
}
|
||
|
|
|
||
|
|
nav a.router-link-exact-active {
|
||
|
|
color: var(--color-text);
|
||
|
|
}
|
||
|
|
|
||
|
|
nav a.router-link-exact-active:hover {
|
||
|
|
background-color: transparent;
|
||
|
|
}
|
||
|
|
|
||
|
|
nav a {
|
||
|
|
display: inline-block;
|
||
|
|
padding: 0 1rem;
|
||
|
|
border-left: 1px solid var(--color-border);
|
||
|
|
}
|
||
|
|
|
||
|
|
nav a:first-of-type {
|
||
|
|
border: 0;
|
||
|
|
}
|
||
|
|
|
||
|
|
@media (min-width: 1024px) {
|
||
|
|
header {
|
||
|
|
display: flex;
|
||
|
|
place-items: center;
|
||
|
|
padding-right: calc(var(--section-gap) / 2);
|
||
|
|
}
|
||
|
|
|
||
|
|
.logo {
|
||
|
|
margin: 0 2rem 0 0;
|
||
|
|
}
|
||
|
|
|
||
|
|
header .wrapper {
|
||
|
|
display: flex;
|
||
|
|
place-items: flex-start;
|
||
|
|
flex-wrap: wrap;
|
||
|
|
}
|
||
|
|
|
||
|
|
nav {
|
||
|
|
text-align: left;
|
||
|
|
margin-left: -1rem;
|
||
|
|
font-size: 1rem;
|
||
|
|
|
||
|
|
padding: 1rem 0;
|
||
|
|
margin-top: 1rem;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
</style> -->
|