81 lines
2.0 KiB
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> |