koel/resources/assets/js/components/modals/add-user-form.vue

66 lines
1.5 KiB
Vue
Raw Normal View History

2016-11-30 09:23:11 +00:00
<template>
<div class="overlay" v-if="newUser">
<sound-bar v-if="loading"/>
<form class="user-add" @submit.prevent="submit" v-else>
<header>
<h1>Add New User</h1>
</header>
<div>
<div class="form-row">
<label>Name</label>
<input type="text" name="name" v-model="newUser.name" required v-koel-focus>
</div>
<div class="form-row">
<label>Email</label>
<input type="email" name="email" v-model="newUser.email" required>
</div>
<div class="form-row">
<label>Password</label>
<input type="password" name="password" v-model="newUser.password">
</div>
</div>
<footer>
<button class="btn btn-green btn-add">Save</button>
<button class="btn btn-white btn-cancel" @click.prevent="cancel">Cancel</button>
</footer>
</form>
2017-03-25 07:18:06 +00:00
</div>
2016-11-30 09:23:11 +00:00
</template>
<script>
import { clone } from 'lodash'
import soundBar from '../shared/sound-bar.vue'
import { userStore } from '../../stores'
export default {
name: 'modals--add-user-form',
components: { soundBar },
data () {
return {
loading: false,
newUser: null
}
},
methods: {
open () {
this.newUser = clone(userStore.stub)
},
2017-05-02 05:46:06 +00:00
async submit () {
2016-11-30 09:23:11 +00:00
this.loading = true
2017-05-02 05:46:06 +00:00
await userStore.store(this.newUser.name, this.newUser.email, this.newUser.password)
this.loading = false
this.newUser = null
2016-11-30 09:23:11 +00:00
},
cancel () {
this.newUser = null
}
}
}
</script>