Pinafore-Web-Client-Frontend/routes/_components/Nav.html

81 lines
2.0 KiB
HTML

<nav class="main-nav">
<ul>
<li>
<NavItem :page name="home" href="/" svg="#pinafore-logo" label="Home" />
</li>
<li>
<NavItem :page name="notifications" href="/notifications" svg="#fa-bell" label="Notifications" />
</li>
{{#if $pinnedPage === '/local'}}
<li>
<NavItem :page name="local" href="/local" svg="#fa-users" label="Local" />
</li>
{{elseif $pinnedPage === '/federated'}}
<li>
<NavItem :page name="federated" href="/federated" svg="#fa-globe" label="Federated" />
</li>
{{elseif $pinnedPage === '/favorites'}}
<li>
<NavItem :page name="favorites" href="/favorites" svg="#fa-star" label="Favorites" />
</li>
{{elseif $pinnedPage.startsWith('/lists/')}}
<li>
<NavItem :page name="lists" href="{{$pinnedPage}}" svg="#fa-bars" label="{{$pinnedListTitle}}" />
</li>
{{/if}}
<li>
<NavItem :page name="community" href="/community" svg="#fa-comments" label="Community" />
</li>
<li>
<NavItem :page name="search" href="/search" svg="#fa-search" label="Search" />
</li>
<li>
<NavItem :page name="settings" href="/settings" svg="#fa-gear" label="Settings" />
</li>
</ul>
</nav>
<style>
.main-nav {
border-bottom: 1px solid var(--nav-border);
background: var(--nav-bg);
position: fixed;
left: 0;
right: 0;
top: 0;
z-index: 10;
}
.main-nav ul {
margin: 0;
padding: 0;
list-style: none;
display: flex;
align-items: center;
}
@media (max-width: 767px) {
.main-nav li {
flex: 1;
}
}
</style>
<script>
import NavItem from './NavItem'
import { store } from '../_store/store'
import { fetchLists } from '../community/_actions/community'
export default {
async oncreate() {
let pinnedPage = this.store.get('pinnedPage')
if (pinnedPage.startsWith('/lists')) {
await fetchLists()
}
},
store: () => store,
components: {
NavItem
}
}
</script>