mirror of
https://github.com/eugene-serb/wavelovers.git
synced 2023-09-09 23:41:16 +03:00
![Eugene Serb](/assets/img/avatar_default.png)
- added condition for link tags. - improve stability. - linted code. - up version. - build.
144 lines
3.0 KiB
Vue
144 lines
3.0 KiB
Vue
<template>
|
|
<header class="header">
|
|
<div class="header-wrapper container">
|
|
<div class="logo-wrapper">
|
|
<span class="logo-wrapper__logo" translate="no">Wavelovers</span>
|
|
</div>
|
|
<nav class="menu-wrapper">
|
|
<ul class="navigation">
|
|
<li class="navigation__item">
|
|
<router-link to="/">Home</router-link>
|
|
</li>
|
|
<li class="navigation__item">
|
|
<router-link to="/faq">FAQ</router-link>
|
|
</li>
|
|
<li class="navigation__item">
|
|
<router-link to="/about">About</router-link>
|
|
</li>
|
|
<li class="navigation__item">
|
|
<router-link to="/donate">Donate</router-link>
|
|
</li>
|
|
</ul>
|
|
</nav>
|
|
</div>
|
|
</header>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { defineComponent } from 'vue';
|
|
|
|
export default defineComponent({
|
|
name: 'HeaderItem',
|
|
});
|
|
</script>
|
|
|
|
<style lang="scss">
|
|
.header {
|
|
border-bottom: 8px solid var(--color-header-borderline);
|
|
background: var(--color-header-background);
|
|
}
|
|
|
|
.header ::selection {
|
|
background: var(--color-header-selection);
|
|
}
|
|
|
|
.header :focus {
|
|
border-bottom: 2px solid var(--color-header-navigation-link-hover);
|
|
}
|
|
|
|
.header :focus-visible {
|
|
outline: 2px solid var(--color-header-navigation-link-hover);
|
|
border-color: transparent;
|
|
}
|
|
|
|
.header-wrapper {
|
|
padding-top: 32px;
|
|
padding-bottom: 16px;
|
|
}
|
|
|
|
.logo-wrapper {
|
|
text-align: center;
|
|
}
|
|
|
|
.logo-wrapper__logo {
|
|
font-size: 48px;
|
|
font-weight: 500;
|
|
color: var(--color-header-logo);
|
|
cursor: default;
|
|
}
|
|
|
|
.menu-wrapper {
|
|
margin-top: 16px;
|
|
align-self: center;
|
|
}
|
|
|
|
.navigation {
|
|
padding: 0;
|
|
list-style-type: none;
|
|
display: flex;
|
|
flex-direction: row;
|
|
flex-wrap: wrap;
|
|
justify-content: space-between;
|
|
gap: 8px;
|
|
}
|
|
|
|
.navigation__item {
|
|
font-size: 16px;
|
|
text-transform: uppercase;
|
|
}
|
|
|
|
.navigation__item a {
|
|
border-color: transparent;
|
|
color: var(--color-header-navigation-link);
|
|
}
|
|
|
|
.navigation__item a:hover {
|
|
border-color: var(--color-header-navigation-link-hover);
|
|
color: var(--color-header-navigation-link-hover);
|
|
}
|
|
|
|
@media only screen and (min-width: 540px) {
|
|
.header {
|
|
border-bottom: 32px solid var(--color-header-borderline);
|
|
background: var(--color-header-background);
|
|
}
|
|
|
|
.header-wrapper {
|
|
padding-top: 64px;
|
|
padding-bottom: 16px;
|
|
}
|
|
|
|
.menu-wrapper {
|
|
margin-top: 32px;
|
|
align-self: center;
|
|
}
|
|
}
|
|
|
|
@media only screen and (min-width: 720px) {
|
|
.header-wrapper {
|
|
display: flex;
|
|
flex-direction: row;
|
|
flex-wrap: nowrap;
|
|
justify-content: space-between;
|
|
gap: 64px;
|
|
}
|
|
|
|
.logo-wrapper {
|
|
width: 50%;
|
|
text-align: left;
|
|
}
|
|
|
|
.menu-wrapper {
|
|
width: 50%;
|
|
margin-top: 0px;
|
|
align-self: flex-end;
|
|
}
|
|
}
|
|
|
|
@media only screen and (min-width: 1024px) {
|
|
.logo-wrapper__logo {
|
|
font-size: 64px;
|
|
}
|
|
}
|
|
</style>
|