koel/resources/assets/js/components/modals/edit-user-form.vue
2017-05-02 12:46:06 +07:00

69 lines
1.7 KiB
Vue

<template>
<div class="overlay" v-if="copiedUser">
<sound-bar v-if="loading"/>
<form class="user-edit" @submit.prevent="submit" v-else>
<header>
<h1>Edit User</h1>
</header>
<div>
<div class="form-row">
<label>Name</label>
<input type="text" name="name" v-model="copiedUser.name" required v-koel-focus>
</div>
<div class="form-row">
<label>Email</label>
<input type="email" name="email" v-model="copiedUser.email" required>
</div>
<div class="form-row">
<label>Password</label>
<input type="password" name="password" v-model="copiedUser.password" placeholder="Leave blank for no changes">
</div>
</div>
<footer>
<button class="btn btn-green btn-update">Update</button>
<button class="btn btn-white btn-cancel" @click.prevent="cancel">Cancel</button>
</footer>
</form>
</div>
</template>
<script>
import { clone } from 'lodash'
import soundBar from '../shared/sound-bar.vue'
import { userStore } from '../../stores'
export default {
name: 'modals--edit-user-form',
components: { soundBar },
data () {
return {
user: null,
loading: false,
// We work on a cloned version of the user
copiedUser: null
}
},
methods: {
open (user) {
this.copiedUser = clone(user)
// Keep a reference
this.user = user
},
async submit () {
this.loading = true
await userStore.update(this.user, this.copiedUser.name, this.copiedUser.email, this.copiedUser.password)
this.loading = false
this.copiedUser = null
},
cancel () {
this.copiedUser = null
}
}
}
</script>