mirror of
https://github.com/koel/koel
synced 2025-01-23 09:45:07 +00:00
90 lines
1.9 KiB
Vue
90 lines
1.9 KiB
Vue
<template>
|
||
<article class="user-item" :class="{ me: isCurrentUser }">
|
||
<div class="info">
|
||
<img :src="user.avatar" width="128" height="128">
|
||
|
||
<div class="right">
|
||
<div>
|
||
<h1>{{ user.name }}
|
||
<i v-if="isCurrentUser" class="you fa fa-check-circle"/>
|
||
</h1>
|
||
<p>{{ user.email }}</p>
|
||
</div>
|
||
|
||
<div class="buttons">
|
||
<button class="btn btn-blue btn-edit" @click="edit">
|
||
{{ isCurrentUser ? 'Update Profile' : 'Edit' }}
|
||
</button>
|
||
<button class="btn btn-red btn-delete" @click="del">Delete</button>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</article>
|
||
</template>
|
||
|
||
<script>
|
||
import swal from 'sweetalert'
|
||
|
||
import { userStore } from '../../stores'
|
||
import router from '../../router'
|
||
|
||
export default {
|
||
props: ['user'],
|
||
|
||
data () {
|
||
return {
|
||
confirmingDelete: false
|
||
}
|
||
},
|
||
|
||
computed: {
|
||
/**
|
||
* Determine if the current logged in user is the user bound to this component.
|
||
*
|
||
* @return {Boolean}
|
||
*/
|
||
isCurrentUser () {
|
||
return this.user.id === userStore.current.id
|
||
}
|
||
},
|
||
|
||
methods: {
|
||
/**
|
||
* Trigger editing a user.
|
||
* If the user is the current logged-in user, redirect to the profile screen instead.
|
||
*/
|
||
edit () {
|
||
if (this.isCurrentUser) {
|
||
router.go('profile')
|
||
|
||
return
|
||
}
|
||
|
||
this.$emit('editUser', this.user)
|
||
},
|
||
|
||
/**
|
||
* Kill off the freaking user.
|
||
*/
|
||
del () {
|
||
swal({
|
||
title: 'Hey…',
|
||
text: `You’re about to unperson ${this.user.name}. Are you sure?`,
|
||
type: 'warning',
|
||
showCancelButton: true,
|
||
confirmButtonText: 'Certainly',
|
||
cancelButtonText: 'Oops'
|
||
}, () => {
|
||
userStore.destroy(this.user).then(() => {
|
||
this.$destroy(true)
|
||
})
|
||
})
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
<style lang="sass">
|
||
@import "../../../sass/partials/_vars.scss";
|
||
@import "../../../sass/partials/_mixins.scss";
|
||
</style>
|