Update:Show version number in bottom of siderail #660 and save previous version data to continue showing if update is available

This commit is contained in:
advplyr 2022-06-01 17:15:13 -05:00
parent c88bbf1ce4
commit 4621c78573
4 changed files with 83 additions and 30 deletions

View File

@ -73,6 +73,12 @@
<p class="text-xs font-mono pb-0.5">{{ numIssues }}</p> <p class="text-xs font-mono pb-0.5">{{ numIssues }}</p>
</div> </div>
</nuxt-link> </nuxt-link>
<div class="w-full h-12 px-1 py-2 border-t border-black border-opacity-20 absolute left-0" :style="{ bottom: streamLibraryItem ? '240px' : '65px' }">
<p class="font-mono text-xs text-center text-gray-300 leading-3 mb-1">v{{ $config.version }}</p>
<a v-if="hasUpdate" :href="githubTagUrl" target="_blank" class="text-warning text-xxs text-center block leading-3">Update</a>
<p v-else class="text-xxs text-gray-400 leading-3 text-center italic">{{ Source }}</p>
</div>
</div> </div>
</template> </template>
@ -82,6 +88,12 @@ export default {
return {} return {}
}, },
computed: { computed: {
Source() {
return this.$store.state.Source
},
isMobileLandscape() {
return this.$store.state.globals.isMobileLandscape
},
isShowingBookshelfToolbar() { isShowingBookshelfToolbar() {
if (!this.$route.name) return false if (!this.$route.name) return false
return this.$route.name.startsWith('library') return this.$route.name.startsWith('library')
@ -131,6 +143,21 @@ export default {
}, },
numIssues() { numIssues() {
return this.$store.state.libraries.issues || 0 return this.$store.state.libraries.issues || 0
},
versionData() {
return this.$store.state.versionData || {}
},
hasUpdate() {
return !!this.versionData.hasUpdate
},
latestVersion() {
return this.versionData.latestVersion
},
githubTagUrl() {
return this.versionData.githubTagUrl
},
streamLibraryItem() {
return this.$store.state.streamLibraryItem
} }
}, },
methods: {}, methods: {},

View File

@ -515,23 +515,12 @@ export default {
this.$store.commit('globals/updateWindowSize', { width: window.innerWidth, height: window.innerHeight }) this.$store.commit('globals/updateWindowSize', { width: window.innerWidth, height: window.innerHeight })
}, },
checkVersionUpdate() { checkVersionUpdate() {
// Version check is only run if time since last check was 5 minutes
const VERSION_CHECK_BUFF = 1000 * 60 * 5 // 5 minutes
var lastVerCheck = localStorage.getItem('lastVerCheck') || 0
if (Date.now() - Number(lastVerCheck) > VERSION_CHECK_BUFF) {
this.$store this.$store
.dispatch('checkForUpdate') .dispatch('checkForUpdate')
.then((res) => { .then((res) => {
localStorage.setItem('lastVerCheck', Date.now())
if (res && res.hasUpdate) this.showUpdateToast(res) if (res && res.hasUpdate) this.showUpdateToast(res)
}) })
.catch((err) => console.error(err)) .catch((err) => console.error(err))
if (this.$route.query.error) {
this.$toast.error(this.$route.query.error)
this.$router.replace(this.$route.path)
}
}
} }
}, },
beforeMount() { beforeMount() {
@ -551,6 +540,11 @@ export default {
} }
this.checkVersionUpdate() this.checkVersionUpdate()
if (this.$route.query.error) {
this.$toast.error(this.$route.query.error)
this.$router.replace(this.$route.path)
}
}, },
beforeDestroy() { beforeDestroy() {
window.removeEventListener('resize', this.resize) window.removeEventListener('resize', this.resize)

View File

@ -23,14 +23,17 @@ function parseSemver(ver) {
} }
return null return null
} }
export const currentVersion = packagejson.version
export async function checkForUpdate() { export async function checkForUpdate() {
if (!packagejson.version) { if (!packagejson.version) {
return return null
} }
var currVerObj = parseSemver('v' + packagejson.version) var currVerObj = parseSemver('v' + packagejson.version)
if (!currVerObj) { if (!currVerObj) {
console.error('Invalid version', packagejson.version) console.error('Invalid version', packagejson.version)
return return null
} }
var largestVer = null var largestVer = null
await axios.get(`https://api.github.com/repos/advplyr/audiobookshelf/releases`).then((res) => { await axios.get(`https://api.github.com/repos/advplyr/audiobookshelf/releases`).then((res) => {
@ -49,7 +52,7 @@ export async function checkForUpdate() {
}) })
if (!largestVer) { if (!largestVer) {
console.error('No valid version tags to compare with') console.error('No valid version tags to compare with')
return return null
} }
return { return {

View File

@ -1,4 +1,4 @@
import { checkForUpdate } from '@/plugins/version' import { checkForUpdate, currentVersion } from '@/plugins/version'
import Vue from 'vue' import Vue from 'vue'
export const state = () => ({ export const state = () => ({
@ -65,15 +65,44 @@ export const actions = {
}) })
}, },
checkForUpdate({ commit }) { checkForUpdate({ commit }) {
const VERSION_CHECK_BUFF = 1000 * 60 * 5 // 5 minutes
var lastVerCheck = localStorage.getItem('lastVerCheck') || 0
var savedVersionData = localStorage.getItem('versionData')
if (savedVersionData) {
try {
savedVersionData = JSON.parse(localStorage.getItem('versionData'))
} catch (error) {
console.error('Failed to parse version data', error)
savedVersionData = null
localStorage.removeItem('versionData')
}
}
var shouldCheckForUpdate = Date.now() - Number(lastVerCheck) > VERSION_CHECK_BUFF
if (!shouldCheckForUpdate && savedVersionData && savedVersionData.version !== currentVersion) {
// Version mismatch between saved data so check for update anyway
shouldCheckForUpdate = true
}
if (shouldCheckForUpdate) {
return checkForUpdate() return checkForUpdate()
.then((res) => { .then((res) => {
if (res) {
localStorage.setItem('lastVerCheck', Date.now())
localStorage.setItem('versionData', JSON.stringify(res))
commit('setVersionData', res) commit('setVersionData', res)
return res }
return res && res.hasUpdate
}) })
.catch((error) => { .catch((error) => {
console.error('Update check failed', error) console.error('Update check failed', error)
return false return false
}) })
} else if (savedVersionData) {
commit('setVersionData', savedVersionData)
}
return null
} }
} }