-
Notifications
You must be signed in to change notification settings - Fork 196
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
The banner will show on top of an empty online mod list, explaining that the list is empty because splash screen failed to load it. A one-click option for trying to update the mod list is offered. This change is adjustment to the fact that the splash screen no longer stops on errors and user is more likely to reach the manager view with no mod list loaded into Vuex.
- Loading branch information
Showing
2 changed files
with
76 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
<script lang="ts"> | ||
import { mixins } from 'vue-class-component'; | ||
import { Component, Watch } from 'vue-property-decorator'; | ||
import UtilityMixin from './mixins/UtilityMixin.vue'; | ||
@Component({}) | ||
export default class ModListUpdateBanner extends mixins(UtilityMixin) { | ||
updateError = ''; | ||
get isModListLoaded(): boolean { | ||
return this.$store.state.tsMods.modsLastUpdated !== undefined; | ||
} | ||
get isUpdateInProgress(): boolean { | ||
return this.$store.state.tsMods.isBackgroundUpdateInProgress; | ||
} | ||
@Watch('isUpdateInProgress') | ||
onLoadingProgressChange(newVal: boolean, oldVal: boolean) { | ||
// React to background update as well as the manual update from the banner. | ||
if (!oldVal && newVal) { | ||
this.updateError = ''; | ||
} | ||
} | ||
async updateModList() { | ||
if (this.isUpdateInProgress) { | ||
return; | ||
} | ||
this.$store.commit('tsMods/startBackgroundUpdate'); | ||
this.updateError = ''; | ||
try { | ||
// Invalidate hash to force a refresh. Otherwise a scenario where | ||
// the latest index hash is already present in IndexedDB but loading | ||
// the package list into Vuex store has failed would cause the banner | ||
// to just disappear when refreshThunderstoreModList skips the actual | ||
// update but updates the timestamp of the hash. | ||
await this.$store.dispatch('tsMods/updateIndexHash', 'invalidated'); | ||
await this.refreshThunderstoreModList(); | ||
} catch (e) { | ||
this.updateError = `${e}`; | ||
} finally { | ||
this.$store.commit('tsMods/finishBackgroundUpdate'); | ||
} | ||
} | ||
} | ||
</script> | ||
|
||
<template> | ||
<div v-if="!isModListLoaded" id="mod-list-update-banner" class="margin-bottom"> | ||
<div class="notification is-warning margin-right"> | ||
<span v-if="isUpdateInProgress"> | ||
Updating mod list from Thunderstore... | ||
</span> | ||
<span v-else-if="updateError"> | ||
Error updating the mod list: {{ updateError }}<br /> | ||
The manager will keep trying to update the mod list in the background. | ||
</span> | ||
<span v-else> | ||
An error occurred when updating the mod list from Thunderstore. | ||
Would you like to | ||
<a @click="updateModList">try again now</a>? | ||
</span> | ||
</div> | ||
</div> | ||
</template> | ||
|
||
<style scoped lang="scss"> | ||
</style> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters