mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-25 07:48:56 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			75 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			2.2 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">
 | |
|         <h1 class="text-3xl text-white truncate">Changelog</h1>
 | |
|       </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">
 | |
|       <template v-for="release in releasesToShow">
 | |
|         <div :key="release.name">
 | |
|           <p class="text-xl font-bold pb-4">
 | |
|             Changelog <a :href="`https://github.com/advplyr/audiobookshelf/releases/tag/${release.name}`" target="_blank" class="hover:underline">{{ release.name }}</a> ({{ $formatDate(release.pubdate, dateFormat) }})
 | |
|           </p>
 | |
|           <div class="custom-text" v-html="getChangelog(release)" />
 | |
|         </div>
 | |
|         <div v-if="release !== releasesToShow[releasesToShow.length - 1]" :key="`${release.name}-divider`" class="border-b border-black-300 my-8" />
 | |
|       </template>
 | |
|     </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
 | |
|     },
 | |
|     releasesToShow() {
 | |
|       return this.versionData?.releasesToShow || []
 | |
|     }
 | |
|   },
 | |
|   methods: {
 | |
|     getChangelog(release) {
 | |
|       return marked.parse(release.changelog || 'No Changelog Available', { gfm: true, breaks: true })
 | |
|     }
 | |
|   },
 | |
|   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>
 |