<template lang="pug">
  transition(:duration="400")
    .modal(v-show='isShown', v-cloak)
      transition(name='modal-background')
        .modal-background(v-show='isShown')
      .modal-container
        transition(name='modal-content')
          .modal-content(v-show='isShown')
            header.is-blue
              span Create / Authorize User
              p.modal-notify(v-bind:class='{ "is-active": loading }'): i
            section
              label.label Email address:
              p.control.is-fullwidth
                input.input(type='text', placeholder='e.g. john.doe@company.com', v-model='email', autofocus)
            section
              label.label Provider:
              p.control.is-fullwidth
                select(v-model='provider')
                  option(value='local') Local Database
                  option(value='windowslive') Microsoft Account
                  option(value='google') Google ID
                  option(value='facebook') Facebook
                  option(value='github') GitHub
                  option(value='slack') Slack
            section(v-if='provider=="local"')
              label.label Password:
              p.control.is-fullwidth
                input.input(type='password', placeholder='', v-model='password')
            section(v-if='provider=="local"')
              label.label Full Name:
              p.control.is-fullwidth
                input.input(type='text', placeholder='e.g. John Doe', v-model='name')
            footer
              a.button.is-grey.is-outlined(v-on:click='cancel') Discard
              a.button(v-on:click='create', v-if='provider=="local"', v-bind:disabled='loading', v-bind:class='{ "is-disabled": loading, "is-blue": !loading }') Create User
              a.button(v-on:click='create', v-if='provider!="local"', v-bind:disabled='loading', v-bind:class='{ "is-disabled": loading, "is-blue": !loading }') Authorize User
</template>

<script>
  export default {
    name: 'modal-create-user',
    data () {
      return {
        email: '',
        provider: 'local',
        password: '',
        name: '',
        loading: false
      }
    },
    computed: {
      isShown () {
        return this.$store.state.modalCreateUser.shown
      }
    },
    methods: {
      cancel () {
        this.$store.dispatch('modalCreateUser/close')
        this.email = ''
        this.provider = 'local'
      },
      create () {
        let self = this
        this.loading = true
        this.$http.post('/admin/users/create', {
          email: this.email,
          provider: this.provider,
          password: this.password,
          name: this.name
        }).then(resp => {
          return resp.json()
        }).then(resp => {
          this.loading = false
          if (resp.ok) {
            this.cancel()
            window.location.reload(true)
          } else {
            self.$store.dispatch('alert', {
              style: 'red',
              icon: 'square-cross',
              msg: resp.msg
            })
          }
        }).catch(err => {
          this.loading = false
          self.$store.dispatch('alert', {
            style: 'red',
            icon: 'square-cross',
            msg: 'Error: ' + err.body.msg
          })
        })
      }
    }
  }
</script>