mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-01-26 00:14:49 +01:00
79 lines
2.1 KiB
Vue
79 lines
2.1 KiB
Vue
<template>
|
|
<modals-modal v-model="show" name="changelog" :width="800" :height="'unset'">
|
|
<template #outer>
|
|
<div class="absolute top-0 left-0 p-5 w-2/3 overflow-hidden">
|
|
<p class="text-3xl text-white truncate">Changelog</p>
|
|
</div>
|
|
</template>
|
|
<div class="px-8 py-6 w-full rounded-lg bg-bg shadow-lg border border-black-300 relative overflow-y-scroll" style="max-height: 80vh">
|
|
<p class="text-xl font-bold pb-4">
|
|
Changelog <a :href="currentTagUrl" target="_blank" class="hover:underline">v{{ currentVersionNumber }}</a> ({{ currentVersionPubDate }})
|
|
</p>
|
|
<div class="custom-text" v-html="compiledMarkedown" />
|
|
</div>
|
|
</modals-modal>
|
|
</template>
|
|
|
|
<script>
|
|
import { marked } from '@/static/libs/marked/index.js'
|
|
|
|
export default {
|
|
props: {
|
|
value: Boolean,
|
|
versionData: {
|
|
type: Object,
|
|
default: () => {}
|
|
}
|
|
},
|
|
computed: {
|
|
show: {
|
|
get() {
|
|
return this.value
|
|
},
|
|
set(val) {
|
|
this.$emit('input', val)
|
|
}
|
|
},
|
|
dateFormat() {
|
|
return this.$store.state.serverSettings.dateFormat
|
|
},
|
|
changelog() {
|
|
return this.versionData?.currentVersionChangelog || 'No Changelog Available'
|
|
},
|
|
compiledMarkedown() {
|
|
return marked.parse(this.changelog, { gfm: true, breaks: true })
|
|
},
|
|
currentVersionPubDate() {
|
|
if (!this.versionData?.currentVersionPubDate) return 'Unknown release date'
|
|
return `${this.$formatDate(this.versionData.currentVersionPubDate, this.dateFormat)}`
|
|
},
|
|
currentTagUrl() {
|
|
return this.versionData?.currentTagUrl
|
|
},
|
|
currentVersionNumber() {
|
|
return this.$config.version
|
|
}
|
|
},
|
|
methods: {},
|
|
mounted() {}
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
/*
|
|
1. we need to manually define styles to apply to the parsed markdown elements,
|
|
since we don't have access to the actual elements in this component
|
|
|
|
2. v-deep allows these to take effect on the content passed in to the v-html in the div above
|
|
*/
|
|
.custom-text ::v-deep > h2 {
|
|
@apply text-lg font-bold;
|
|
}
|
|
.custom-text ::v-deep > h3 {
|
|
@apply text-lg font-bold;
|
|
}
|
|
.custom-text ::v-deep > ul {
|
|
@apply list-disc list-inside pb-4;
|
|
}
|
|
</style>
|