renamed and relocated delete popup

This commit is contained in:
Chad Derya 2019-09-09 21:55:20 +01:00
parent 619ae1b940
commit ea34bf3e80
2 changed files with 115 additions and 4 deletions

View File

@ -0,0 +1,112 @@
<template>
<div>
<el-button icon="el-icon-delete" size="mini" type="danger" @click="openDeletePopup">
Delete
</el-button>
<el-dialog :visible.sync="dialogVisible">
<div v-if="viewState==='initialState'">
<div>
<h3>
Are you sure you want to delete this {{ type }} ?
</h3>
<p>To delete this {{ type }}, type in <b>{{ item.name }}</b> and click delete</p>
</div>
<el-row :gutter="20">
<el-col :span="12" :offset="6">
<div class="inputBox">
<el-input v-model="input" placeholder="Please input" />
</div>
</el-col>
</el-row>
<el-button @click="dialogVisible = false">
Cancel
</el-button>
<el-button type="danger" :disabled="isNameCorrect" @click="handleSubmit">
Confirm
</el-button>
</div>
<div v-else-if="viewState==='Success'">
<h1>SUCCESS you can now close this popup</h1>
<h1>{{ item._id }}</h1>
<el-button @click="dialogVisible = false">
Close
</el-button>
</div>
<div v-else-if="viewState==='Error'">
<h1>ERROR please try again, if the error persist contact Chadmin!</h1>
<el-button @click="dialogVisible = false">
Close
</el-button>
</div>
</el-dialog>
</div>
</template>
<script>
// const deleteProduct = require('@/api/product').deleteProduct
import { deleteProduct } from '@/api/product'
export default {
name: 'DeletePopUp',
props: {
item: {
type: Object,
default: function() {
return {
name: 'BROKEN!-KEROSENOS-BROKEN!',
_id: 'THIS-ID-IS-BROKEN!'
}
}
},
type: {
type: String,
default: 'chad'
}
},
data() {
return {
dialogVisible: false,
viewState: 'initialState',
isNameCorrect: true,
input: ''
}
},
watch: {
input: function() {
if (this.input === this.item.name) {
this.isNameCorrect = false
} else {
this.isNameCorrect = true
}
}
},
methods: {
openDeletePopup() {
this.dialogVisible = true
this.viewState = 'initialState'
this.input = ''
},
checkAllSuccess() {
return Object.keys(this.listObj).every(item => this.listObj[item].hasSuccess)
},
handleSubmit() {
console.log(this.item._id)
console.log(deleteProduct(this.item._id))
// .then((r) => {
// console.log(r)
// })
if (this.input) {
this.viewState = 'Success'
} else if (!this.input) {
this.viewState = 'Error'
}
}
}
}
</script>
<style lang="scss" scoped>
.inputBox {
margin-bottom: 20px;
}
</style>

View File

@ -40,8 +40,7 @@
Edit
</el-button>
</router-link>
<editorImage
<deletePopUp
:item="scope.row"
:type="'Product'"
/>
@ -56,11 +55,11 @@
<script>
import { fetchList } from '@/api/product'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import editorImage from './components/EditorImage'
import DeletePopUp from '@/components/PopUps/Delete'
export default {
name: 'ProductList',
components: { Pagination, editorImage },
components: { Pagination, DeletePopUp },
filters: {
statusFilter(status) {
const statusMap = {