67 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <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>
 |