2019-08-04 22:42:37 +00:00
|
|
|
<template>
|
2024-01-30 14:46:01 +00:00
|
|
|
<div class="container">
|
|
|
|
<div class="row">
|
|
|
|
<div
|
2019-08-04 22:42:37 +00:00
|
|
|
ref="content"
|
2024-01-30 14:46:01 +00:00
|
|
|
class="col relAnchor"
|
2019-08-04 22:42:37 +00:00
|
|
|
>
|
2024-01-30 14:46:01 +00:00
|
|
|
<router-link
|
|
|
|
v-if="$route.params.page"
|
|
|
|
class="btn btn-secondary btn-sm editBtn"
|
2019-08-04 22:42:37 +00:00
|
|
|
:to="{ name: 'edit', params: { page: $route.params.page } }"
|
|
|
|
>
|
|
|
|
<i class="fas fa-edit" />
|
2024-01-30 14:46:01 +00:00
|
|
|
</router-link>
|
|
|
|
|
|
|
|
<md-render
|
|
|
|
:content="content"
|
2019-08-04 22:42:37 +00:00
|
|
|
:prerender="prerender"
|
|
|
|
@rendered="rendered"
|
|
|
|
/>
|
2024-01-30 14:46:01 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2019-08-04 22:42:37 +00:00
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2024-01-30 14:46:01 +00:00
|
|
|
/* global Prism */
|
|
|
|
|
|
|
|
import mdRender from './markdown.vue'
|
2019-08-04 22:42:37 +00:00
|
|
|
|
|
|
|
export default {
|
|
|
|
|
|
|
|
components: {
|
2024-01-30 14:46:01 +00:00
|
|
|
mdRender,
|
2019-08-04 22:42:37 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
content: '',
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
intLinkClick(evt) {
|
|
|
|
const link = evt.target
|
|
|
|
this.$router.push({ name: 'view', params: { page: link.dataset.page } })
|
|
|
|
return false
|
|
|
|
},
|
|
|
|
|
|
|
|
loadPage(pageName) {
|
|
|
|
console.debug(`Loading ${pageName}...`)
|
2024-01-30 14:46:01 +00:00
|
|
|
return fetch(`/_content/${pageName}`)
|
2019-08-04 22:42:37 +00:00
|
|
|
.then(resp => {
|
2024-01-30 14:46:01 +00:00
|
|
|
if (resp.status === 404) {
|
2019-08-04 22:42:37 +00:00
|
|
|
this.$router.push({ name: 'edit', params: { page: pageName } })
|
|
|
|
return
|
|
|
|
}
|
2024-01-30 14:46:01 +00:00
|
|
|
|
|
|
|
return resp.json()
|
|
|
|
})
|
|
|
|
.then(data => {
|
|
|
|
if (!data) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
this.content = data.content
|
|
|
|
})
|
|
|
|
.catch(err => {
|
2019-08-04 22:42:37 +00:00
|
|
|
console.error(err)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
prerender(mdtext) {
|
|
|
|
// replace [[Internal]] links
|
2024-01-30 14:46:01 +00:00
|
|
|
mdtext = mdtext.replace(
|
|
|
|
new RegExp(/\[\[([^\]]+)\]\]/, 'g'),
|
|
|
|
'<a class="intLink" data-page="$1" href="$1">$1</a>',
|
|
|
|
)
|
2019-08-04 22:42:37 +00:00
|
|
|
|
|
|
|
return mdtext
|
|
|
|
},
|
|
|
|
|
|
|
|
rendered() {
|
|
|
|
// Give the DOM a moment to update before manipulating further
|
|
|
|
window.setTimeout(() => {
|
|
|
|
// Add listeners to internal links
|
|
|
|
const links = this.$refs.content.getElementsByClassName('intLink')
|
|
|
|
for (const link of links) {
|
|
|
|
link.onclick = this.intLinkClick
|
|
|
|
}
|
|
|
|
|
|
|
|
// Highlight code blocks
|
|
|
|
Prism.highlightAll()
|
|
|
|
}, 100)
|
|
|
|
},
|
|
|
|
},
|
2024-01-30 14:46:01 +00:00
|
|
|
|
|
|
|
mounted() {
|
|
|
|
this.loadPage(this.$route.params.page)
|
|
|
|
},
|
|
|
|
|
|
|
|
name: 'WikiView',
|
|
|
|
|
|
|
|
watch: {
|
|
|
|
'$route'(to, from) {
|
|
|
|
if (to.params.page === from.params.page) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
this.loadPage(to.params.page)
|
|
|
|
},
|
|
|
|
},
|
2019-08-04 22:42:37 +00:00
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style>
|
|
|
|
.editBtn {
|
|
|
|
position: absolute;
|
|
|
|
right: 5px;
|
|
|
|
top: 5px;
|
|
|
|
}
|
|
|
|
.relAnchor {
|
|
|
|
position: relative;
|
|
|
|
}
|
|
|
|
</style>
|