gamebrary/src/components/Lists/ListPreferences.vue

170 lines
3.9 KiB
Vue
Raw Normal View History

2020-08-11 23:39:11 +00:00
<template lang="html">
<b-dropdown-item-button v-b-modal="modalId">
2020-09-23 03:09:48 +00:00
<b-icon-toggles class="mr-1" />
List tweaks
2020-08-11 23:39:11 +00:00
<b-modal
:id="modalId"
title="List tweaks"
2020-08-24 17:22:01 +00:00
@show="getSettings"
2020-08-11 23:39:11 +00:00
>
<form ref="renameListForm" @submit.stop.prevent="save">
2020-08-26 21:23:05 +00:00
<b-form-checkbox
v-model="showReleaseDates"
name="check-button"
class="mb-2"
switch
>
2020-08-11 23:39:11 +00:00
Show release date for unreleased games
</b-form-checkbox>
2020-08-26 21:23:05 +00:00
<b-form-checkbox
v-model="showGameRatings"
name="check-button"
class="mb-2"
switch
>
2020-08-11 23:39:11 +00:00
Show game ratings
</b-form-checkbox>
2020-08-26 21:23:05 +00:00
<b-form-checkbox
v-model="showGameProgress"
name="check-button"
class="mb-2"
switch
>
2020-08-11 23:39:11 +00:00
Show game progress
</b-form-checkbox>
2020-08-26 21:23:05 +00:00
<b-form-checkbox
v-model="showGameNotes"
name="check-button"
class="mb-2"
switch
>
2020-08-11 23:39:11 +00:00
Show game notes
</b-form-checkbox>
2020-08-26 21:23:05 +00:00
<b-form-checkbox
v-model="showGameTags"
name="check-button"
class="mb-2"
switch
>
2020-08-11 23:39:11 +00:00
Show game tags
</b-form-checkbox>
2020-08-15 00:02:17 +00:00
2020-08-26 21:23:05 +00:00
<b-form-checkbox
v-model="showGameCount"
name="check-button"
class="mb-2"
switch
>
2020-08-15 00:02:17 +00:00
Show game count
</b-form-checkbox>
2020-08-11 23:39:11 +00:00
</form>
<template v-slot:modal-footer="{ cancel }">
<b-button @click="cancel">
Cancel
</b-button>
<b-button
variant="primary"
:disabled="saving"
@click="save"
>
<b-spinner small v-if="saving" />
<span v-else>Save</span>
</b-button>
</template>
</b-modal>
</b-dropdown-item-button>
</template>
<script>
export default {
props: {
2020-08-21 14:38:03 +00:00
listIndex: Number,
list: Object,
2020-08-11 23:39:11 +00:00
},
data() {
return {
showReleaseDates: false,
showGameRatings: false,
showGameProgress: false,
showGameNotes: false,
showGameTags: false,
2020-08-15 00:02:17 +00:00
showGameCount: false,
2020-08-11 23:39:11 +00:00
saving: false,
};
},
computed: {
modalId() {
return `list-tweaks-${this.listIndex}`;
},
isDuplicate() {
return this.listName && this.existingListNames.includes(this.listName.toLowerCase());
},
},
methods: {
getSettings() {
const {
showReleaseDates,
showGameRatings,
showGameProgress,
showGameNotes,
showGameTags,
2020-08-15 00:02:17 +00:00
showGameCount,
2020-08-21 14:38:03 +00:00
} = this.list.settings;
2020-08-11 23:39:11 +00:00
this.showReleaseDates = showReleaseDates || false;
this.showGameRatings = showGameRatings || false;
this.showGameProgress = showGameProgress || false;
this.showGameNotes = showGameNotes || false;
this.showGameTags = showGameTags || false;
2020-08-15 00:02:17 +00:00
this.showGameCount = showGameCount || false;
2020-08-11 23:39:11 +00:00
},
async save() {
2020-08-21 14:38:03 +00:00
const { listIndex, list: { settings } } = this;
2020-08-11 23:39:11 +00:00
this.saving = true;
2020-08-21 14:38:03 +00:00
settings.showReleaseDates = this.showReleaseDates;
settings.showGameRatings = this.showGameRatings;
settings.showGameProgress = this.showGameProgress;
settings.showGameNotes = this.showGameNotes;
settings.showGameTags = this.showGameTags;
settings.showGameCount = this.showGameCount;
2020-08-11 23:39:11 +00:00
2020-08-21 14:38:03 +00:00
this.$store.commit('SET_LIST_SETTINGS', { listIndex, settings });
2020-08-11 23:39:11 +00:00
2020-08-21 14:38:03 +00:00
await this.$store.dispatch('SAVE_BOARD')
2020-08-11 23:39:11 +00:00
.catch(() => {
this.saving = false;
this.$bvToast.toast('There was an error renaming list', {
title: 'Error',
variant: 'danger',
});
});
this.saving = false;
this.$bvToast.toast('Settings saved', {
title: 'Success',
variant: 'success',
});
await this.$store.dispatch('LOAD_BOARD', this.$route.params.id);
2020-08-11 23:39:11 +00:00
this.$bvModal.hide(this.modalId);
},
},
};
</script>