sphinx_nervproject_theme/ui/src/Page.vue

265 lines
6.0 KiB
Vue

<template>
<div class="page">
<slot/>
<!-- <Content :custom="false"/> -->
<!-- <div class="page-edit"> -->
<!-- <div -->
<!-- class="edit-link" -->
<!-- v-if="editLink" -->
<!-- > -->
<!-- <a -->
<!-- :href="editLink" -->
<!-- target="_blank" -->
<!-- rel="noopener noreferrer" -->
<!-- >{{ editLinkText }}</a> -->
<!-- <OutboundLink/> -->
<!-- </div> -->
<!-- <div -->
<!-- class="last-updated" -->
<!-- v-if="lastUpdated" -->
<!-- > -->
<!-- <span class="prefix">{{ lastUpdatedText }}: </span> -->
<!-- <span class="time">{{ lastUpdated }}</span> -->
<!-- </div> -->
<!-- </div> -->
<!-- <div class="page-nav" v-if="prev || next"> -->
<!-- <p class="inner"> -->
<!-- <span -->
<!-- v-if="prev" -->
<!-- class="prev" -->
<!-- > -->
<!-- ← -->
<!-- <router-link -->
<!-- v-if="prev" -->
<!-- class="prev" -->
<!-- :to="prev.path" -->
<!-- > -->
<!-- {{ prev.title || prev.path }} -->
<!-- </router-link> -->
<!-- </span> -->
<!-- <span -->
<!-- v-if="next" -->
<!-- class="next" -->
<!-- > -->
<!-- <router-link -->
<!-- v-if="next" -->
<!-- :to="next.path" -->
<!-- > -->
<!-- {{ next.title || next.path }} -->
<!-- </router-link> -->
<!-- → -->
<!-- </span> -->
<!-- </p> -->
<!-- </div> -->
<slot name="bottom"/>
</div>
</template>
<script>
//import { resolvePage, normalize, outboundRE, endingSlashRE } from './util'
export default {
/*
props: ['sidebarItems'],
computed: {
lastUpdated () {
if (this.$page.lastUpdated) {
return new Date(this.$page.lastUpdated).toLocaleString(this.$lang)
}
},
lastUpdatedText () {
if (typeof this.$themeLocaleConfig.lastUpdated === 'string') {
return this.$themeLocaleConfig.lastUpdated
}
if (typeof this.$site.themeConfig.lastUpdated === 'string') {
return this.$site.themeConfig.lastUpdated
}
return 'Last Updated'
},
prev () {
const prev = this.$page.frontmatter.prev
if (prev === false) {
return
} else if (prev) {
return resolvePage(this.$site.pages, prev, this.$route.path)
} else {
return resolvePrev(this.$page, this.sidebarItems)
}
},
next () {
const next = this.$page.frontmatter.next
if (next === false) {
return
} else if (next) {
return resolvePage(this.$site.pages, next, this.$route.path)
} else {
return resolveNext(this.$page, this.sidebarItems)
}
},
editLink () {
if (this.$page.frontmatter.editLink === false) {
return
}
const {
repo,
editLinks,
docsDir = '',
docsBranch = 'master',
docsRepo = repo
} = this.$site.themeConfig
let path = normalize(this.$page.path)
if (endingSlashRE.test(path)) {
path += 'README.md'
} else {
path += '.md'
}
if (docsRepo && editLinks) {
return this.createEditLink(repo, docsRepo, docsDir, docsBranch, path)
}
},
editLinkText () {
return (
this.$themeLocaleConfig.editLinkText ||
this.$site.themeConfig.editLinkText ||
`Edit this page`
)
}
},
methods: {
createEditLink (repo, docsRepo, docsDir, docsBranch, path) {
const bitbucket = /bitbucket.org/
if (bitbucket.test(repo)) {
const base = outboundRE.test(docsRepo)
? docsRepo
: repo
return (
base.replace(endingSlashRE, '') +
`/${docsBranch}` +
(docsDir ? '/' + docsDir.replace(endingSlashRE, '') : '') +
path +
`?mode=edit&spa=0&at=${docsBranch}&fileviewer=file-view-default`
)
}
const base = outboundRE.test(docsRepo)
? docsRepo
: `https://github.com/${docsRepo}`
return (
base.replace(endingSlashRE, '') +
`/edit/${docsBranch}` +
(docsDir ? '/' + docsDir.replace(endingSlashRE, '') : '') +
path
)
}
}
*/
}
/*
function resolvePrev (page, items) {
return find(page, items, -1)
}
function resolveNext (page, items) {
return find(page, items, 1)
}
function find (page, items, offset) {
const res = []
items.forEach(item => {
if (item.type === 'group') {
res.push(...item.children || [])
} else {
res.push(item)
}
})
for (let i = 0; i < res.length; i++) {
const cur = res[i]
if (cur.type === 'page' && cur.path === page.path) {
return res[i + offset]
}
}
}
*/
</script>
<style lang="less">
@import './vuepress/styles/config.less';
@import './vuepress/styles/wrapper.less';
.page {
padding-top: var(--navbarHeight);
padding-bottom: 2rem;
}
.page-edit {
.wrapper();
padding-top: 1rem;
padding-bottom: 1rem;
overflow: auto;
.edit-link {
display: inline-block;
a, a:visited {
color: hsla(var(--TClr-h), var(--TClr-s), calc(var(--TClr-l)*1.25), var(--TClr-a));
margin-right: 0.25rem;
}
}
.last-updated {
float: right;
font-size: 0.9em;
.prefix {
font-weight: 500;
color: hsla(var(--TClr-h), var(--TClr-s), calc(var(--TClr-l)*1.25), var(--TClr-a));
}
.time {
font-weight: 400;
color: hsla(var(--TClr-h), var(--TClr-s), calc(var(--TClr-l)*1.25), var(--TClr-a));
}
}
}
.page-nav {
.wrapper();
padding-top: 1rem;
padding-bottom: 0;
.inner {
min-height: 2rem;
margin-top: 0;
border-top: 1px solid var(--BClr);
padding-top: 1rem;
overflow: auto; // clear float;
}
.next {
float: right;
}
}
@media (max-width: @MQMobile) {
.page-edit {
.edit-link {
margin-bottom: .5rem;
}
.last-updated {
font-size: .8em;
float: none;
text-align: left;
}
}
}
</style>