ethcc-demo/src/App.vue

97 lines
1.6 KiB
Vue
Raw Normal View History

2024-05-30 17:56:10 +10:00
<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> -->