vue3-yuanma/packages/sfc-playground/src/Header.vue

107 lines
2.6 KiB
Vue
Raw Normal View History

2021-03-28 13:35:45 +08:00
<template>
<nav>
<h1>
<img alt="logo" src="/icon.png">
<span>Vue SFC Playground</span>
</h1>
<div class="links">
<a class="commit-link" href="https://app.netlify.com/sites/vue-sfc-playground/deploys" target="_blank">
@{{ commit }}
</a>
<button class="share" @click="copyLink">
<svg width="1.4em" height="1.4em" viewBox="0 0 24 24">
<g fill="none" stroke="#626262" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
<circle cx="18" cy="5" r="3"/>
<circle cx="6" cy="12" r="3"/>
<circle cx="18" cy="19" r="3"/>
<path d="M8.59 13.51l6.83 3.98"/>
<path d="M15.41 6.51l-6.82 3.98"/>
</g>
</svg>
</button>
<button class="download" @click="downloadProject">
<svg width="1.7em" height="1.7em" viewBox="0 0 24 24">
<g fill="#626262">
<rect x="4" y="18" width="16" height="2" rx="1" ry="1"/>
<rect x="3" y="17" width="4" height="2" rx="1" ry="1" transform="rotate(-90 5 18)"/>
<rect x="17" y="17" width="4" height="2" rx="1" ry="1" transform="rotate(-90 19 18)"/>
<path d="M12 15a1 1 0 0 1-.58-.18l-4-2.82a1 1 0 0 1-.24-1.39a1 1 0 0 1 1.4-.24L12 12.76l3.4-2.56a1 1 0 0 1 1.2 1.6l-4 3a1 1 0 0 1-.6.2z"/>
<path d="M12 13a1 1 0 0 1-1-1V4a1 1 0 0 1 2 0v8a1 1 0 0 1-1 1z"/>
</g>
</svg>
</button>
</div>
2021-03-28 13:35:45 +08:00
</nav>
</template>
<script setup lang="ts">
2021-03-29 11:48:01 +08:00
import { downloadProject } from './download/download'
const commit = __COMMIT__
function copyLink() {
navigator.clipboard.writeText(location.href)
alert('Sharable URL has been copied to clipboard.')
}
</script>
2021-03-28 13:35:45 +08:00
<style>
nav {
height: var(--nav-height);
box-sizing: border-box;
padding: 0 1em;
background-color: #fff;
box-shadow: 0 0 4px rgba(0, 0, 0, 0.33);
position: relative;
z-index: 999;
display: flex;
justify-content: space-between;
2021-03-28 13:35:45 +08:00
}
h1 {
margin: 0;
line-height: var(--nav-height);
font-weight: 500;
display: inline-block;
vertical-align: middle;
}
h1 img {
height: 24px;
vertical-align: middle;
margin-right: 10px;
position: relative;
top: -2px;
}
@media (max-width:400px) {
h1 span {
display: none;
}
}
.commit-link {
color: var(--color-branding);
text-decoration: none;
margin-left: 6px;
vertical-align: middle;
line-height: var(--nav-height);
2021-03-28 13:35:45 +08:00
}
.share {
position: relative;
top: 6px;
margin: 0 2px;
}
.download {
position: relative;
top: 8px;
margin: 0 2px;
}
.commit-link {
margin: 0 5px;
}
2021-03-28 13:35:45 +08:00
</style>