Add confirmation fot note deletion

This commit is contained in:
Angelina Filippova 2020-06-06 22:17:15 +03:00
parent 789fa36e1a
commit 727f72f058
2 changed files with 35 additions and 23 deletions

View file

@ -2,22 +2,14 @@
<el-card class="note-card"> <el-card class="note-card">
<div slot="header"> <div slot="header">
<div class="note-header"> <div class="note-header">
<div class="note-actor-container"> <div class="note-actor">
<div class="note-actor"> <img v-if="propertyExists(note.user, 'avatar')" :src="note.user.avatar" class="note-avatar-img">
<img v-if="isValid(note.user)" :src="note.user.avatar" class="note-avatar-img"> <span v-if="propertyExists(note.user, 'nickname')" class="note-actor-name">{{ note.user.nickname }}</span>
<h3 v-if="isValid(note.user)" class="note-actor-name">{{ note.user.nickname }}</h3>
</div>
</div> </div>
<div> <div>
<el-popconfirm <el-button size="mini" @click.native="handleNoteDeletion(note.id, report.id)">
title="Are you sure to delete this?" {{ $t('reports.deleteNote') }}
confirm-button-text="Yes" </el-button>
cancel-button-text="No"
@onConfirm="handleNoteDeletion(note.id, report.id)">
<el-button slot="reference" size="mini">
{{ $t('reports.deleteNote') }}
</el-button>
</el-popconfirm>
</div> </div>
</div> </div>
</div> </div>
@ -44,14 +36,29 @@ export default {
} }
}, },
methods: { methods: {
isValid(account) { handleNoteDeletion(noteID, reportID) {
return account.nickname && account.id this.$confirm('Are you sure you want to delete this note?', 'Warning', {
confirmButtonText: 'OK',
cancelButtonText: 'Cancel',
type: 'warning'
}).then(() => {
this.$store.dispatch('DeleteReportNote', { noteID, reportID })
this.$message({
type: 'success',
message: 'Delete completed'
})
}).catch(() => {
this.$message({
type: 'info',
message: 'Delete canceled'
})
})
}, },
parseTimestamp(timestamp) { parseTimestamp(timestamp) {
return moment(timestamp).format('YYYY-MM-DD HH:mm') return moment(timestamp).format('YYYY-MM-DD HH:mm')
}, },
handleNoteDeletion(noteID, reportID) { propertyExists(account, property) {
this.$store.dispatch('DeleteReportNote', { noteID, reportID }) return account[property]
} }
} }
} }
@ -76,7 +83,7 @@ export default {
} }
.note-actor-name { .note-actor-name {
margin: 0; margin: 0;
height: 22px; height: 28px;
} }
.note-avatar-img { .note-avatar-img {
width: 15px; width: 15px;
@ -96,6 +103,10 @@ export default {
.note-header { .note-header {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center;
height: 28px;
font-size: 15px;
font-weight: 500;
} }
@media only screen and (max-width:480px) { @media only screen and (max-width:480px) {
@ -105,14 +116,15 @@ export default {
.note-header { .note-header {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
height: 80px; height: 65px;
} }
.note-actor-container { .note-actor {
margin-bottom: 5px; margin-bottom: 5px;
} }
.note-header { .note-header {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: flex-start;
} }
} }
</style> </style>

View file

@ -1,10 +1,10 @@
<template> <template>
<el-dropdown :hide-on-click="false" size="small" trigger="click" @click.native.stop> <el-dropdown :hide-on-click="false" size="small" trigger="click" @click.native.stop>
<div> <div>
<span v-if="page === 'users'" class="el-dropdown-link"> <el-button v-if="page === 'users'" type="text" class="el-dropdown-link">
{{ $t('users.moderation') }} {{ $t('users.moderation') }}
<i v-if="isDesktop" class="el-icon-arrow-down el-icon--right"/> <i v-if="isDesktop" class="el-icon-arrow-down el-icon--right"/>
</span> </el-button>
<el-button v-if="page === 'userPage'" class="moderate-user-button"> <el-button v-if="page === 'userPage'" class="moderate-user-button">
<span class="moderate-user-button-container"> <span class="moderate-user-button-container">
<span> <span>