mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-05 05:42:44 +08:00
372 lines
11 KiB
Vue
372 lines
11 KiB
Vue
<template>
|
|
<div
|
|
:class="['van-doc-content', `van-doc-content--${currentPage}`]"
|
|
@click="onClick"
|
|
>
|
|
<slot />
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import { copyToClipboard } from '../../common';
|
|
|
|
export default {
|
|
name: 'VanDocContent',
|
|
|
|
computed: {
|
|
currentPage() {
|
|
const { path } = this.$route;
|
|
if (path) {
|
|
return path.split('/').slice(-1)[0];
|
|
}
|
|
return this.$route.name;
|
|
},
|
|
},
|
|
|
|
watch: {
|
|
$route(to, from) {
|
|
if (from.path !== to.path) {
|
|
setTimeout(() => {
|
|
this.copyAction();
|
|
});
|
|
}
|
|
},
|
|
},
|
|
|
|
mounted() {
|
|
this.copyAction();
|
|
},
|
|
|
|
methods: {
|
|
onClick({ target }) {
|
|
if (['H2', 'H3', 'H4', 'H5'].includes(target.tagName)) {
|
|
this.scrollToAnchor(target);
|
|
}
|
|
},
|
|
|
|
scrollToAnchor(target) {
|
|
if (target.id) {
|
|
this.$router.push({
|
|
name: this.$route.name,
|
|
hash: '#' + target.id,
|
|
});
|
|
}
|
|
},
|
|
|
|
copyAction() {
|
|
const codeBoxes = document.querySelectorAll('.van-doc-card pre code');
|
|
|
|
if (!codeBoxes || !codeBoxes.length) {
|
|
return;
|
|
}
|
|
|
|
for (let i = 0; i < codeBoxes.length; i++) {
|
|
const item = codeBoxes[i];
|
|
let timer = null;
|
|
|
|
item.addEventListener('click', () => {
|
|
if (timer) return;
|
|
const content = item.innerText;
|
|
copyToClipboard(content);
|
|
item.classList.add('code-copy-success');
|
|
|
|
timer = setTimeout(() => {
|
|
item.classList.remove('code-copy-success');
|
|
timer = null;
|
|
}, 1400);
|
|
});
|
|
}
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<style lang="less">
|
|
.van-doc-card {
|
|
margin-bottom: 24px;
|
|
padding: 24px;
|
|
background-color: var(--van-doc-background-2);
|
|
border-radius: var(--van-doc-border-radius);
|
|
overflow: auto;
|
|
|
|
> pre code {
|
|
position: relative;
|
|
padding-right: 30px;
|
|
pointer-events: none;
|
|
overflow: initial;
|
|
}
|
|
|
|
> pre:hover {
|
|
code::before {
|
|
position: absolute;
|
|
z-index: 9;
|
|
right: 14px;
|
|
top: 11px;
|
|
width: 20px;
|
|
height: 20px;
|
|
background-position: center;
|
|
background-size: contain;
|
|
background-image: url(data:image/png;base64,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);
|
|
cursor: pointer;
|
|
content: '';
|
|
display: block;
|
|
pointer-events: auto;
|
|
}
|
|
}
|
|
|
|
> pre .code-copy-success::after {
|
|
content: 'Copied!';
|
|
display: block;
|
|
position: absolute;
|
|
z-index: 9;
|
|
right: -4px;
|
|
top: 0;
|
|
animation: ease-out code-copy-animation 0.2s;
|
|
animation-fill-mode: forwards;
|
|
}
|
|
|
|
@keyframes code-copy-animation {
|
|
0% {
|
|
top: 0;
|
|
opacity: 0;
|
|
}
|
|
|
|
100% {
|
|
top: -20px;
|
|
opacity: 1;
|
|
}
|
|
}
|
|
|
|
> p a,
|
|
> ul a,
|
|
> table a,
|
|
> blockquote a {
|
|
margin: 0 1px;
|
|
color: var(--van-doc-link-color);
|
|
-webkit-font-smoothing: auto;
|
|
|
|
&:hover {
|
|
opacity: 0.8;
|
|
}
|
|
|
|
&:active {
|
|
opacity: 0.6;
|
|
}
|
|
}
|
|
|
|
> h3,
|
|
> h4,
|
|
> h5,
|
|
> h6 {
|
|
font-weight: normal;
|
|
line-height: 1.6;
|
|
|
|
&[id] {
|
|
cursor: pointer;
|
|
}
|
|
}
|
|
|
|
> h3 {
|
|
margin-bottom: 16px;
|
|
font-weight: 600;
|
|
font-size: 20px;
|
|
}
|
|
|
|
> h4 {
|
|
margin: 24px 0 12px;
|
|
font-weight: 600;
|
|
font-size: 18px;
|
|
}
|
|
|
|
> h5 {
|
|
margin: 24px 0 12px;
|
|
font-weight: 600;
|
|
font-size: 16px;
|
|
}
|
|
|
|
> p {
|
|
margin-top: 8px;
|
|
color: var(--van-doc-text-color-3);
|
|
font-size: 15px;
|
|
line-height: 26px;
|
|
|
|
strong {
|
|
color: var(--van-doc-text-color-1);
|
|
}
|
|
}
|
|
|
|
> table {
|
|
width: 100%;
|
|
margin-top: 12px;
|
|
color: var(--van-doc-text-color-3);
|
|
font-size: 14px;
|
|
line-height: 1.5;
|
|
border-collapse: collapse;
|
|
|
|
th {
|
|
padding: 8px 10px;
|
|
font-weight: 600;
|
|
text-align: left;
|
|
|
|
&:first-child {
|
|
padding-left: 0;
|
|
}
|
|
|
|
&:last-child {
|
|
padding-right: 0;
|
|
}
|
|
}
|
|
|
|
td {
|
|
padding: 8px;
|
|
border-top: 1px solid var(--van-doc-border-color);
|
|
|
|
&:first-child {
|
|
padding-left: 0;
|
|
|
|
// version tag
|
|
code {
|
|
margin: 0;
|
|
padding: 2px 6px;
|
|
color: var(--van-doc-blue);
|
|
font-weight: 600;
|
|
font-size: 11px;
|
|
background-color: rgba(25, 137, 250, 0.15);
|
|
border-radius: 20px;
|
|
}
|
|
}
|
|
|
|
&:last-child {
|
|
padding-right: 0;
|
|
}
|
|
}
|
|
|
|
em {
|
|
display: inline-block;
|
|
color: var(--van-doc-green);
|
|
font-size: 14px;
|
|
font-family: 'Source Code Pro', 'Monaco', 'Inconsolata', monospace;
|
|
font-style: normal;
|
|
max-width: 300px;
|
|
-webkit-font-smoothing: auto;
|
|
}
|
|
}
|
|
|
|
> ul {
|
|
margin: 12px 0;
|
|
}
|
|
|
|
> ul li,
|
|
> ol li {
|
|
position: relative;
|
|
margin: 5px 0 5px 10px;
|
|
padding-left: 15px;
|
|
color: var(--van-doc-text-color-3);
|
|
font-size: 15px;
|
|
line-height: 26px;
|
|
|
|
&::before {
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
box-sizing: border-box;
|
|
width: 6px;
|
|
height: 6px;
|
|
margin-top: 10px;
|
|
border: 1px solid currentColor;
|
|
border-radius: 50%;
|
|
content: '';
|
|
}
|
|
}
|
|
|
|
> hr {
|
|
margin: 30px 0;
|
|
border: 0 none;
|
|
border-top: 1px solid #eee;
|
|
}
|
|
|
|
> p code,
|
|
> ul code,
|
|
> ol code,
|
|
> table code {
|
|
display: inline;
|
|
margin: 0 2px;
|
|
padding: 2px 5px;
|
|
font-size: 14px;
|
|
font-family: inherit;
|
|
font-weight: 600;
|
|
word-break: keep-all;
|
|
border-radius: 4px;
|
|
-webkit-font-smoothing: antialiased;
|
|
}
|
|
|
|
> blockquote {
|
|
margin: 16px 0 0;
|
|
padding: 16px;
|
|
font-size: 14px;
|
|
color: var(--van-doc-blockquote-color);
|
|
background-color: var(--van-doc-blockquote-background);
|
|
border-radius: var(--van-doc-border-radius);
|
|
}
|
|
|
|
> img,
|
|
> p img {
|
|
width: 100%;
|
|
margin: 16px 0;
|
|
border-radius: var(--van-doc-border-radius);
|
|
}
|
|
}
|
|
|
|
.van-doc-content {
|
|
position: relative;
|
|
flex: 1;
|
|
padding: 0 0 75px;
|
|
|
|
.van-doc-markdown-body {
|
|
padding: 24px;
|
|
overflow: hidden;
|
|
|
|
h1,
|
|
h2 {
|
|
font-weight: normal;
|
|
line-height: 1.5;
|
|
|
|
&[id] {
|
|
cursor: pointer;
|
|
}
|
|
}
|
|
|
|
h1 {
|
|
margin: 0 0 30px;
|
|
font-size: 34px;
|
|
cursor: default;
|
|
}
|
|
|
|
h2 {
|
|
margin: 45px 0 20px;
|
|
font-size: 26px;
|
|
}
|
|
}
|
|
|
|
&--changelog {
|
|
strong {
|
|
display: block;
|
|
margin: 24px 0 12px;
|
|
font-weight: 600;
|
|
font-size: 15px;
|
|
}
|
|
|
|
h3 {
|
|
+ p code {
|
|
margin: 0;
|
|
}
|
|
|
|
a {
|
|
color: inherit;
|
|
font-size: 20px;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</style>
|