mirror of https://github.com/sveltejs/svelte
259 lines
4.8 KiB
259 lines
4.8 KiB
<script>
|
|
import { onMount } from 'svelte';
|
|
import Icon from './Icon.svelte';
|
|
import { page } from '@sapper/app';
|
|
|
|
export let segment;
|
|
|
|
let open = false;
|
|
let visible = true;
|
|
|
|
// hide nav whenever we navigate
|
|
page.subscribe(() => {
|
|
open = false;
|
|
});
|
|
|
|
// TODO remove this post-https://github.com/sveltejs/svelte/issues/1914
|
|
let ul;
|
|
onMount(() => {
|
|
function handler(event) {
|
|
if (!open) {
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
open = true;
|
|
}
|
|
}
|
|
|
|
ul.addEventListener('touchstart', handler, {
|
|
capture: true
|
|
});
|
|
|
|
return () => {
|
|
ul.removeEventListener('touchstart', handler, {
|
|
capture: true
|
|
});
|
|
};
|
|
});
|
|
|
|
let last_scroll = 0;
|
|
function handle_scroll() {
|
|
const scroll = window.pageYOffset;
|
|
visible = (scroll < 50 || scroll < last_scroll);
|
|
|
|
last_scroll = scroll;
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
header {
|
|
position: fixed;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
width: 100vw;
|
|
height: var(--nav-h);
|
|
padding: 0 var(--side-nav);
|
|
margin: 0 auto;
|
|
background-color: white;
|
|
box-shadow: 0 -0.4rem 0.9rem 0.2rem rgba(0,0,0,.5);
|
|
font-family: var(--font);
|
|
z-index: 100;
|
|
user-select: none;
|
|
transform: translate(0,calc(-100% - 1rem));
|
|
transition: transform 0.2s;
|
|
}
|
|
|
|
header.visible {
|
|
transform: none;
|
|
}
|
|
|
|
nav {
|
|
position: fixed;
|
|
top: 0;
|
|
left: 0;
|
|
width: 100vw;
|
|
height: var(--nav-h);
|
|
padding: 0 var(--side-nav) 0 var(--side-nav);
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
background-color: transparent;
|
|
transform: none;
|
|
transition: none;
|
|
box-shadow: none;
|
|
}
|
|
|
|
.primary {
|
|
list-style: none;
|
|
font-family: var(--font);
|
|
margin: 0;
|
|
line-height: 1;
|
|
}
|
|
|
|
li {
|
|
display: block;
|
|
display: none;
|
|
}
|
|
|
|
li.active {
|
|
display: block;
|
|
}
|
|
|
|
ul {
|
|
position: relative;
|
|
padding: 0 3rem 0 0;
|
|
background: url(/icons/chevron.svg) calc(100% - 1em) 0.05em no-repeat;
|
|
background-size: 1em 1em;
|
|
}
|
|
|
|
ul::after {
|
|
/* prevent clicks from registering if nav is closed */
|
|
position: absolute;
|
|
content: '';
|
|
width: 100%;
|
|
height: 100%;
|
|
left: 0;
|
|
top: 0;
|
|
}
|
|
|
|
ul.open {
|
|
padding: 0 0 1em 0;
|
|
background: white;
|
|
border-left: 1px solid #eee;
|
|
border-right: 1px solid #eee;
|
|
border-bottom: 1px solid #eee;
|
|
border-radius: 0 0 var(--border-r) var(--border-r);
|
|
align-self: start;
|
|
}
|
|
|
|
ul.open li {
|
|
display: block;
|
|
text-align: right
|
|
}
|
|
|
|
ul.open::after {
|
|
display: none;
|
|
}
|
|
|
|
ul li a {
|
|
font-size: var(--h5);
|
|
padding: 0 .8rem;
|
|
}
|
|
|
|
ul.open li a {
|
|
padding: 1.5rem 3.7rem 1.5rem 4rem;
|
|
display: block;
|
|
}
|
|
|
|
ul.open li:first-child a {
|
|
padding-top: 2.3rem;
|
|
}
|
|
|
|
.primary :global(svg) {
|
|
width: 2rem;
|
|
height: 2rem;
|
|
}
|
|
|
|
.home {
|
|
position: relative;
|
|
top: -.1rem;
|
|
width: 18rem;
|
|
height: 4.2rem;
|
|
-webkit-tap-highlight-color: transparent;
|
|
-webkit-touch-callout: none;
|
|
background: url(/svelte-logo-horizontal.svg) 0 50% no-repeat;
|
|
background-size: auto 100%;
|
|
/* z-index: 11; */
|
|
}
|
|
|
|
.active {
|
|
color: var(--prime)
|
|
}
|
|
|
|
.modal-background {
|
|
position: fixed;
|
|
width: 100%;
|
|
height: 100%;
|
|
left: 0;
|
|
top: 0;
|
|
background-color: rgba(255, 255, 255, 0.9);
|
|
}
|
|
|
|
@media (min-width: 840px) {
|
|
ul {
|
|
padding: 0;
|
|
background: none;
|
|
}
|
|
|
|
ul.open {
|
|
padding: 0;
|
|
background: white;
|
|
border: none;
|
|
align-self: initial;
|
|
}
|
|
|
|
ul.open li {
|
|
display: inline;
|
|
text-align: left;
|
|
}
|
|
|
|
ul.open li a {
|
|
font-size: var(--h5);
|
|
padding: 0 .8rem;
|
|
display: inline;
|
|
}
|
|
|
|
ul::after {
|
|
display: none;
|
|
}
|
|
|
|
li {
|
|
display: inline !important;
|
|
}
|
|
|
|
.hide-if-desktop {
|
|
display: none !important;
|
|
}
|
|
}
|
|
</style>
|
|
|
|
<svelte:window on:scroll={handle_scroll}/>
|
|
|
|
<header class:visible="{visible || open}">
|
|
<nav>
|
|
<a rel="prefetch" href='.' class="home" title='Homepage'></a>
|
|
|
|
{#if open}
|
|
<div class="modal-background hide-if-desktop" on:click="{() => open = false}"></div>
|
|
{/if}
|
|
|
|
<ul
|
|
bind:this={ul}
|
|
class="primary"
|
|
class:open
|
|
on:mouseenter="{() => open = true}"
|
|
on:mouseleave="{() => open = false}"
|
|
>
|
|
<li class="hide-if-desktop" class:active="{!segment}"><a rel="prefetch" href=".">Home</a></li>
|
|
<li class:active="{segment === 'tutorial'}"><a rel="prefetch" href="tutorial">Tutorial</a></li>
|
|
<li class:active="{segment === 'docs'}"><a rel="prefetch" href="docs">API Docs</a></li>
|
|
<li class:active="{segment === 'examples'}"><a rel="prefetch" href="examples">Examples</a></li>
|
|
<li class:active="{segment === 'repl'}"><a rel="prefetch" href="repl">REPL</a></li>
|
|
<li class:active="{segment === 'blog'}"><a rel="prefetch" href="blog">Blog</a></li>
|
|
<li><a href="https://sapper.svelte.technology">Sapper</a></li>
|
|
|
|
<li>
|
|
<a href="https://discord.gg/yy75DKs" title="Discord Chat">
|
|
<Icon name="message-square" />
|
|
</a>
|
|
</li>
|
|
|
|
<li>
|
|
<a href="https://github.com/sveltejs/svelte" title="Github Repo">
|
|
<Icon name="github" />
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</nav>
|
|
</header>
|