modal-delete-page.vue 1.81 KB
Newer Older
NGPixel's avatar
NGPixel committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
<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-red
              span {{ $t('modal.deletepagetitle') }}
              p.modal-notify(v-bind:class='{ "is-active": isLoading }'): i
            section
              span {{ $t('modal.deletepagewarning') }}
            footer
              a.button.is-grey.is-outlined(v-on:click='discard') {{ $t('modal.discard') }}
              a.button.is-red(v-on:click='deletePage') {{ $t('modal.delete') }}

</template>

<script>
  export default {
    name: 'modal-delete-page',
    props: ['currentPath'],
    data () {
      return {
        isLoading: false
      }
    },
    computed: {
      isShown () {
        return this.$store.state.modalDeletePage.shown
      }
    },
    methods: {
      discard () {
        this.isLoading = false
        this.$store.dispatch('modalDeletePage/close')
      },
      deletePage () {
        let self = this
        this.isLoading = true
        this.$http.delete(window.location.href).then(resp => {
          return resp.json()
        }).then(resp => {
          if (resp.ok) {
            window.location.assign('/')
          } else {
            self.isLoading = false
            self.$store.dispatch('alert', {
              style: 'red',
              icon: 'ui-2_square-remove-09',
              msg: resp.msg
            })
          }
        }).catch(err => {
          self.isLoading = false
          self.$store.dispatch('alert', {
            style: 'red',
            icon: 'ui-2_square-remove-09',
            msg: 'Error: ' + err.body.msg
          })
        })
      }
    }
  }
</script>