Skip to content

Commit

Permalink
fixup! fix: move more computed props to composable and rename this la…
Browse files Browse the repository at this point in the history
…tter.
  • Loading branch information
DorraJaouad committed Apr 30, 2024
1 parent d1e2ef0 commit 7864cfb
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 47 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -287,7 +287,7 @@ import NcButton from '@nextcloud/vue/dist/Components/NcButton.js'
import NcEmojiPicker from '@nextcloud/vue/dist/Components/NcEmojiPicker.js'

import { useMessageInfo } from '../../../../../composables/useMessageInfo.js'
import { PARTICIPANT, CONVERSATION, ATTENDEE } from '../../../../../constants.js'
import { CONVERSATION, ATTENDEE } from '../../../../../constants.js'
import { getMessageReminder, removeMessageReminder, setMessageReminder } from '../../../../../services/remindersService.js'
import { useIntegrationsStore } from '../../../../../stores/integrations.js'
import { useReactionsStore } from '../../../../../stores/reactions.js'
Expand All @@ -297,7 +297,6 @@ import { parseMentions } from '../../../../../utils/textParse.ts'
const EmojiIndex = new EmojiIndexFactory(data)
const supportReminders = getCapabilities()?.spreed?.features?.includes('remind-me-later')
const canEditMessage = getCapabilities()?.spreed?.features?.includes('edit-messages')
const canDeleteMessageUnlimited = getCapabilities()?.spreed?.features?.includes('delete-messages-unlimited')

export default {
name: 'MessageButtonsBar',
Expand Down Expand Up @@ -468,11 +467,13 @@ export default {
const { messageActions } = useIntegrationsStore()
const {
isEditable,
isDeleteable,
isModifiable,
isMyMsg,
isFileShare,
isFileShareWithoutCaption,
} = useMessageInfo(props.token, props.id)
isConversationReadOnly,
} = useMessageInfo(props.token, props.id)

return {
messageActions,
Expand All @@ -483,6 +484,8 @@ export default {
isMyMsg,
isFileShare,
isFileShareWithoutCaption,
isConversationReadOnly,
isDeleteable,
}
},

Expand Down Expand Up @@ -512,21 +515,6 @@ export default {
return this.getMessagesListScroller()
},

isDeleteable() {
if (!this.isModifiable) {
return false
}

return (canDeleteMessageUnlimited || (moment(this.timestamp * 1000).add(6, 'h')) > moment())
&& (this.messageType === 'comment' || this.messageType === 'voice-message')
&& !this.isDeleting
&& (this.isMyMsg
|| (this.conversation.type !== CONVERSATION.TYPE.ONE_TO_ONE
&& this.conversation.type !== CONVERSATION.TYPE.ONE_TO_ONE_FORMER
&& (this.conversation.participantType === PARTICIPANT.TYPE.OWNER
|| this.conversation.participantType === PARTICIPANT.TYPE.MODERATOR)))
},

isPrivateReplyable() {
return this.isReplyable
&& (this.conversation.type === CONVERSATION.TYPE.PUBLIC
Expand All @@ -549,10 +537,6 @@ export default {
return this.$store.getters.isActorGuest()
},

isConversationReadOnly() {
return this.conversation.readOnly === CONVERSATION.STATE.READ_ONLY
},

isDeletedMessage() {
return this.messageType === 'comment_deleted'
},
Expand Down
7 changes: 6 additions & 1 deletion src/composables/useConversationInfo.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

import { computed, ref } from 'vue'

import { ATTENDEE, CONVERSATION } from '../constants.js'
import { ATTENDEE, CONVERSATION, PARTICIPANT } from '../constants.js'

/**
* Reusable properties for Conversation... items
Expand Down Expand Up @@ -122,10 +122,15 @@ export function useConversationInfo({
return item.value.readOnly === CONVERSATION.STATE.READ_ONLY
})

const isModifiable = computed(() =>
!isConversationReadOnly.value
&& item.value.participantType !== PARTICIPANT.TYPE.GUEST)

return {
counterType,
conversationInformation,
isOneToOne,
isConversationReadOnly,
isModifiable,
}
}
42 changes: 18 additions & 24 deletions src/composables/useMessageInfo.js
Original file line number Diff line number Diff line change
@@ -1,20 +1,6 @@
/*
* @copyright Copyright (c) 2024 Dorra Jaouad <[email protected]>
*
* @license AGPL-3.0-or-later
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
/**
* SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/

import { computed } from 'vue'
Expand All @@ -24,7 +10,9 @@ import moment from '@nextcloud/moment'

import { useConversationInfo } from './useConversationInfo.js'
import { useStore } from './useStore.js'
import { PARTICIPANT } from '../constants.js'

const canDeleteMessageUnlimited = getCapabilities()?.spreed?.features?.includes('delete-messages-unlimited')
const canEditMessage = getCapabilities()?.spreed?.features?.includes('edit-messages')

/**
* Check whether the user can edit the message or not
Expand All @@ -44,21 +32,16 @@ export function useMessageInfo(token = null, messageId = null) {
const {
isOneToOne,
isConversationReadOnly,
isModifiable,
} = useConversationInfo({ item: conversation })

const isModifiable = computed(() =>
!isConversationReadOnly.value
&& conversation.value.participantType !== PARTICIPANT.TYPE.GUEST)

const isObjectShare = computed(() => Object.keys(Object(message.value.messageParameters)).some(key => key.startsWith('object')))

const isMyMsg = computed(() =>
message.value.actorId === store.getters.getActorId()
&& message.value.actorType === store.getters.getActorType()
)

const canEditMessage = getCapabilities()?.spreed?.features?.includes('edit-messages')

const isEditable = computed(() => {
if (!canEditMessage || !isModifiable.value || isObjectShare.value
|| ((!store.getters.isModerator || isOneToOne.value) && !isMyMsg.value)) {
Expand All @@ -72,8 +55,19 @@ export function useMessageInfo(token = null, messageId = null) {

const isFileShareWithoutCaption = computed(() => message.value.message === '{file}' && isFileShare.value)

const isDeleteable = computed(() => {
if (!isModifiable.value) {
return false
}

return (canDeleteMessageUnlimited || (moment(message.value.timestamp * 1000).add(6, 'h')) > moment())
&& (message.value.messageType === 'comment' || message.value.messageType === 'voice-message')
&& (isMyMsg.value || (!isOneToOne.value && store.getters.isModerator))
})

return {
isEditable,
isDeleteable,
isMyMsg,
isObjectShare,
isModifiable,
Expand Down

0 comments on commit 7864cfb

Please sign in to comment.