vuepress-theme-reco/components/Page.vue

284 lines
6.1 KiB
Vue
Raw Normal View History

2019-04-15 10:35:40 +08:00
<template>
<main class="page" :class="recoShow?'reco-show': 'reco-hide'">
<slot name="top"/>
<div class="page-title">
2019-04-15 10:35:40 +08:00
<h1>{{$page.title}}</h1>
<hr>
2019-11-14 16:01:39 +08:00
<PageInfo :pageInfo="$page" :hideAccessNumber="hideAccessNumber"></PageInfo>
2019-04-15 10:35:40 +08:00
</div>
<Content class="theme-reco-content" />
2019-04-15 10:35:40 +08:00
<footer 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>
</footer>
<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"/>
</main>
</template>
<script>
import PageInfo from '@theme/components/PageInfo'
import { resolvePage, outboundRE, endingSlashRE } from '../util'
export default {
components: { PageInfo },
2019-04-15 10:35:40 +08:00
props: ['sidebarItems'],
data () {
return {
recoShow: false,
isHasKey: true
2019-04-15 10:35:40 +08:00
}
},
computed: {
2019-11-14 16:01:39 +08:00
hideAccessNumber () {
const valineConfig = this.$themeConfig.valineConfig
if (valineConfig) {
2019-11-14 16:01:39 +08:00
return false
} else {
return true
}
},
2019-04-15 10:35:40 +08:00
lastUpdated () {
return this.$page.lastUpdated
},
lastUpdatedText () {
if (typeof this.$themeLocaleConfig.lastUpdated === 'string') {
return this.$themeLocaleConfig.lastUpdated
}
2019-05-08 15:13:18 +08:00
if (typeof this.$themeConfig.lastUpdated === 'string') {
return this.$themeConfig.lastUpdated
2019-04-15 10:35:40 +08:00
}
return 'Last Updated'
},
prev () {
2019-07-20 19:00:36 +08:00
const prev = this.$frontmatter.prev
2019-04-15 10:35:40 +08:00
if (prev === false) {
return
} else if (prev) {
return resolvePage(this.$site.pages, prev, this.$route.path)
} else {
return resolvePrev(this.$page, this.sidebarItems)
}
},
next () {
2019-07-20 19:00:36 +08:00
const next = this.$frontmatter.next
2019-04-15 10:35:40 +08:00
if (next === false) {
return
} else if (next) {
return resolvePage(this.$site.pages, next, this.$route.path)
} else {
return resolveNext(this.$page, this.sidebarItems)
}
},
editLink () {
2019-07-20 19:00:36 +08:00
if (this.$frontmatter.editLink === false) {
2019-09-20 13:54:13 +08:00
return false
2019-04-15 10:35:40 +08:00
}
const {
repo,
editLinks,
docsDir = '',
docsBranch = 'master',
docsRepo = repo
2019-05-08 15:13:18 +08:00
} = this.$themeConfig
2019-04-15 10:35:40 +08:00
if (docsRepo && editLinks && this.$page.relativePath) {
return this.createEditLink(repo, docsRepo, docsDir, docsBranch, this.$page.relativePath)
}
2019-09-20 13:54:13 +08:00
return ''
2019-04-15 10:35:40 +08:00
},
editLinkText () {
return (
2019-09-20 13:54:13 +08:00
this.$themeLocaleConfig.editLinkText || this.$themeConfig.editLinkText || `Edit this page`
2019-04-15 10:35:40 +08:00
)
}
},
mounted () {
this.recoShow = true
},
methods: {
createEditLink (repo, docsRepo, docsDir, docsBranch, path) {
const bitbucket = /bitbucket.org/
if (bitbucket.test(repo)) {
const base = outboundRE.test(docsRepo)
? docsRepo
: repo
return (
2019-09-20 13:54:13 +08:00
base.replace(endingSlashRE, '') +
`/src` +
`/${docsBranch}/` +
(docsDir ? docsDir.replace(endingSlashRE, '') + '/' : '') +
path +
`?mode=edit&spa=0&at=${docsBranch}&fileviewer=file-view-default`
2019-04-15 10:35:40 +08:00
)
}
const base = outboundRE.test(docsRepo)
? docsRepo
: `https://github.com/${docsRepo}`
return (
2019-09-20 13:54:13 +08:00
base.replace(endingSlashRE, '') +
`/edit` +
`/${docsBranch}/` +
(docsDir ? docsDir.replace(endingSlashRE, '') + '/' : '') +
path
2019-04-15 10:35:40 +08:00
)
}
}
}
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 = []
flatten(items, res)
for (let i = 0; i < res.length; i++) {
const cur = res[i]
if (cur.type === 'page' && cur.path === decodeURIComponent(page.path)) {
return res[i + offset]
}
}
}
function flatten (items, res) {
for (let i = 0, l = items.length; i < l; i++) {
if (items[i].type === 'group') {
flatten(items[i].children || [], res)
} else {
res.push(items[i])
}
}
}
</script>
<style lang="stylus">
@require '../styles/wrapper.styl'
@require '../styles/loadMixin.styl'
.page
2019-10-16 20:21:47 +08:00
padding-top 5rem
2019-04-15 10:35:40 +08:00
padding-bottom 2rem
display block
2019-07-20 23:01:42 +08:00
#time-line {
margin-top 0
padding-top 0
2019-09-20 13:54:13 +08:00
}
2019-04-15 10:35:40 +08:00
.page-title
max-width: 740px;
margin: 0 auto;
2019-10-16 20:21:47 +08:00
padding: 1rem 2.5rem;
2019-07-20 23:01:42 +08:00
.page-edit
@extend $wrapper
padding-top 1rem
padding-bottom 1rem
overflow auto
.edit-link
display inline-block
a
color lighten($textColor, 25%)
margin-right 0.25rem
.last-updated
float right
font-size 0.9em
.prefix
font-weight 500
color lighten($textColor, 25%)
.time
font-weight 400
color #aaa
&.reco-hide.page {
load-start()
}
&.reco-show.page {
load-end(0.08s)
2019-09-20 13:54:13 +08:00
}
2019-04-15 10:35:40 +08:00
.page-nav
@extend $wrapper
padding-top 1rem
padding-bottom 0
.inner
min-height 2rem
margin-top 0
border-top 1px solid $borderColor
padding-top 1rem
overflow auto // clear float
.next
float right
@media (max-width: $MQMobile)
.page-title
2019-09-20 13:54:13 +08:00
padding: 0 1rem;
2019-04-15 10:35:40 +08:00
.page-edit
.edit-link
margin-bottom .5rem
.last-updated
font-size .8em
float none
text-align left
</style>