2020-08-25 23:36:48 +00:00
|
|
|
<template lang="html">
|
|
|
|
<b-button variant="danger" v-b-modal:account-settings>
|
|
|
|
Delete Account
|
|
|
|
|
|
|
|
<b-modal
|
|
|
|
id="account-settings"
|
|
|
|
hide-footer
|
|
|
|
title="Delete account"
|
|
|
|
>
|
2020-10-09 18:38:35 +00:00
|
|
|
<b-alert show variant="success" v-if="deleting && progress === 5">
|
|
|
|
Account deleted
|
|
|
|
</b-alert>
|
|
|
|
|
|
|
|
<template v-else-if="deleting">
|
|
|
|
{{ message }}
|
|
|
|
<b-progress :value="progress" :max="5" class="mb-3" />
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<div v-else>
|
|
|
|
The following database entries will be deleted FOREVER.
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
<li>User</li>
|
|
|
|
<li>Tags</li>
|
|
|
|
<li>Notes</li>
|
|
|
|
<li>Game Progresses</li>
|
|
|
|
<li>Settings</li>
|
|
|
|
<li>Boards</li>
|
|
|
|
<!-- <li>Wallpapers </li> -->
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<b-button
|
|
|
|
variant="danger"
|
|
|
|
@click="promptDeleteAccount"
|
|
|
|
:disabled="deleting"
|
|
|
|
>
|
2020-08-25 23:36:48 +00:00
|
|
|
Delete Account
|
|
|
|
</b-button>
|
|
|
|
</b-modal>
|
|
|
|
</b-button>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import { mapState } from 'vuex';
|
2020-10-09 18:38:35 +00:00
|
|
|
import firebase from 'firebase/app';
|
2020-08-25 23:36:48 +00:00
|
|
|
|
|
|
|
export default {
|
2020-10-09 18:38:35 +00:00
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
progress: 0,
|
|
|
|
deleting: false,
|
|
|
|
message: 'test',
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
2020-08-25 23:36:48 +00:00
|
|
|
computed: {
|
2020-10-09 18:38:35 +00:00
|
|
|
...mapState([
|
|
|
|
'user',
|
|
|
|
'tags',
|
|
|
|
'notes',
|
|
|
|
'progresses',
|
|
|
|
'settings',
|
|
|
|
'boards',
|
|
|
|
'wallpapers',
|
|
|
|
]),
|
2020-08-25 23:36:48 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
promptDeleteAccount() {
|
|
|
|
this.$bvModal.msgBoxConfirm('All your data will be removed', {
|
|
|
|
title: 'Are you sure you want to delete your account?',
|
|
|
|
okVariant: 'danger',
|
|
|
|
okTitle: 'Yes, delete account',
|
|
|
|
})
|
|
|
|
.then((value) => {
|
|
|
|
if (value) {
|
|
|
|
this.deleteAccount();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
2020-10-09 18:38:35 +00:00
|
|
|
async deleteAccount() {
|
|
|
|
this.deleting = true;
|
|
|
|
|
|
|
|
const db = firebase.firestore();
|
|
|
|
const user = firebase.auth().currentUser;
|
|
|
|
|
|
|
|
this.message = 'Deleting tags';
|
|
|
|
await db.collection('tags').doc(this.user.uid).delete();
|
|
|
|
this.progress = this.progress + 1;
|
|
|
|
|
|
|
|
this.message = 'Deleting notes';
|
|
|
|
await db.collection('notes').doc(this.user.uid).delete();
|
|
|
|
this.progress = this.progress + 1;
|
|
|
|
|
|
|
|
this.message = 'Deleting game progresses';
|
|
|
|
await db.collection('progresses').doc(this.user.uid).delete();
|
|
|
|
this.progress = this.progress + 1;
|
|
|
|
|
|
|
|
this.message = 'Deleting settings';
|
|
|
|
await db.collection('settings').doc(this.user.uid).delete();
|
|
|
|
this.progress = this.progress + 1;
|
|
|
|
|
|
|
|
this.message = 'Deleting boards';
|
|
|
|
await db.collection('boards').doc(this.user.uid).delete();
|
|
|
|
this.progress = this.progress + 1;
|
|
|
|
|
|
|
|
user.delete().then(() => {
|
|
|
|
this.$bvToast.toast('Account deleted', { title: 'Success', variant: 'success' });
|
|
|
|
|
|
|
|
const exitUrl = process.env.NODE_ENV === 'development'
|
|
|
|
? 'http://localhost:3000'
|
|
|
|
: 'https://gamebrary.com';
|
|
|
|
|
|
|
|
window.location.href = exitUrl;
|
|
|
|
|
|
|
|
this.$store.commit('CLEAR_SESSION');
|
|
|
|
})
|
|
|
|
.catch(() => {
|
|
|
|
this.$store.commit('SET_SESSION_EXPIRED', true);
|
|
|
|
});
|
2020-08-25 23:36:48 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|