mirror of
https://github.com/nextcloud/server.git
synced 2026-02-14 08:14:47 -05:00
115 lines
3.1 KiB
JavaScript
115 lines
3.1 KiB
JavaScript
/**
|
|
* SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
|
|
import { showError, showUndo, TOAST_UNDO_TIMEOUT } from '@nextcloud/dialogs'
|
|
import { mapStores } from 'pinia'
|
|
import logger from '../logger.js'
|
|
import DeleteComment from '../services/DeleteComment.js'
|
|
import EditComment from '../services/EditComment.js'
|
|
import NewComment from '../services/NewComment.js'
|
|
import { useDeletedCommentLimbo } from '../store/deletedCommentLimbo.js'
|
|
|
|
export default {
|
|
props: {
|
|
id: {
|
|
type: Number,
|
|
default: null,
|
|
},
|
|
message: {
|
|
type: String,
|
|
default: '',
|
|
},
|
|
resourceId: {
|
|
type: [String, Number],
|
|
required: true,
|
|
},
|
|
resourceType: {
|
|
type: String,
|
|
default: 'files',
|
|
},
|
|
},
|
|
|
|
data() {
|
|
return {
|
|
deleted: false,
|
|
editing: false,
|
|
loading: false,
|
|
}
|
|
},
|
|
|
|
computed: {
|
|
...mapStores(useDeletedCommentLimbo),
|
|
},
|
|
|
|
methods: {
|
|
// EDITION
|
|
onEdit() {
|
|
this.editing = true
|
|
},
|
|
onEditCancel() {
|
|
this.editing = false
|
|
// Restore original value
|
|
this.updateLocalMessage(this.message)
|
|
},
|
|
async onEditComment(message) {
|
|
this.loading = true
|
|
try {
|
|
await EditComment(this.resourceType, this.resourceId, this.id, message)
|
|
logger.debug('Comment edited', { resourceType: this.resourceType, resourceId: this.resourceId, id: this.id, message })
|
|
this.$emit('update:message', message)
|
|
this.editing = false
|
|
} catch (error) {
|
|
showError(t('comments', 'An error occurred while trying to edit the comment'))
|
|
logger.error('An error occurred while trying to edit the comment', { error })
|
|
} finally {
|
|
this.loading = false
|
|
}
|
|
},
|
|
|
|
// DELETION
|
|
onDeleteWithUndo() {
|
|
this.$emit('delete')
|
|
this.deleted = true
|
|
this.deletedCommentLimboStore.addId(this.id)
|
|
const timeOutDelete = setTimeout(this.onDelete, TOAST_UNDO_TIMEOUT)
|
|
showUndo(t('comments', 'Comment deleted'), () => {
|
|
clearTimeout(timeOutDelete)
|
|
this.deleted = false
|
|
this.deletedCommentLimboStore.removeId(this.id)
|
|
})
|
|
},
|
|
async onDelete() {
|
|
try {
|
|
await DeleteComment(this.resourceType, this.resourceId, this.id)
|
|
logger.debug('Comment deleted', { resourceType: this.resourceType, resourceId: this.resourceId, id: this.id })
|
|
this.$emit('delete', this.id)
|
|
} catch (error) {
|
|
showError(t('comments', 'An error occurred while trying to delete the comment'))
|
|
logger.error('An error occurred while trying to delete the comment', { error })
|
|
this.deleted = false
|
|
this.deletedCommentLimboStore.removeId(this.id)
|
|
}
|
|
},
|
|
|
|
// CREATION
|
|
async onNewComment(message) {
|
|
this.loading = true
|
|
try {
|
|
const newComment = await NewComment(this.resourceType, this.resourceId, message)
|
|
logger.debug('New comment posted', { resourceType: this.resourceType, resourceId: this.resourceId, newComment })
|
|
this.$emit('new', newComment)
|
|
|
|
// Clear old content
|
|
this.$emit('update:message', '')
|
|
this.localMessage = ''
|
|
} catch (error) {
|
|
showError(t('comments', 'An error occurred while trying to create the comment'))
|
|
logger.error('An error occurred while trying to create the comment', { error })
|
|
} finally {
|
|
this.loading = false
|
|
}
|
|
},
|
|
},
|
|
}
|