Skip to content

Commit

Permalink
fixup! feat(OpenConversationsList): expose description
Browse files Browse the repository at this point in the history
  • Loading branch information
DorraJaouad committed May 3, 2024
1 parent f25ae56 commit d52b580
Show file tree
Hide file tree
Showing 4 changed files with 17 additions and 19 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -182,12 +182,7 @@ export default {

setup(props) {
const { item, isSearchResult } = toRefs(props)
const { counterType, conversationInformation } = useConversationInfo({
item,
isSearchResult,
exposeMessages: !isSearchResult.value,
exposeDescription: isSearchResult.value
})
const { counterType, conversationInformation } = useConversationInfo({ item, isSearchResult })

return {
counterType,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
</template>

<script>
import { inject, toRefs } from 'vue'
import { inject, toRefs, ref } from 'vue'

import NcListItem from '@nextcloud/vue/dist/Components/NcListItem.js'

Expand Down Expand Up @@ -64,8 +64,8 @@ export default {
setup(props) {
const { item } = toRefs(props)
const selectedRoom = inject('selectedRoom', null)
const exposeDescription = inject('exposeDescription', false)
const { counterType, conversationInformation } = useConversationInfo({ item, exposeDescription })
const exposeDescriptionRef = inject('exposeDescription', ref(false))
const { counterType, conversationInformation } = useConversationInfo({ item, exposeDescriptionRef })

return {
selectedRoom,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
</template>

<script>
import { provide } from 'vue'
import { provide, ref } from 'vue'

import RoomSelector from '../../RoomSelector.vue'

Expand All @@ -27,7 +27,7 @@ export default {
},

setup() {
provide('exposeDescription', true)
provide('exposeDescription', ref(true))
},

data() {
Expand Down
19 changes: 11 additions & 8 deletions src/composables/useConversationInfo.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,17 +12,20 @@ import { ATTENDEE, CONVERSATION } from '../constants.js'
* @param {object} payload function payload
* @param {import('vue').Ref} payload.item conversation item
* @param {import('vue').Ref} [payload.isSearchResult] whether conversation item appears as search result
* @param {boolean} [payload.exposeMessages] whether to show messages in conversation item
* @param {boolean} [payload.exposeDescription] whether to show description in conversation item
* @param {import('vue').Ref} [payload.exposeMessagesRef] whether to show messages in conversation item
* @param {import('vue').Ref} [payload.exposeDescriptionRef] whether to show description in conversation item
*/
export function useConversationInfo({
item,
isSearchResult = ref(null),
exposeMessages = false,
exposeDescription = false,
exposeMessagesRef = ref(null),
exposeDescriptionRef = ref(null),
}) {
const exposeMessages = isSearchResult.value !== null ? !isSearchResult.value : exposeMessagesRef.value
const exposeDescription = isSearchResult.value !== null ? isSearchResult.value : exposeDescriptionRef.value

const counterType = computed(() => {
if (exposeMessages === false) {
if (!exposeMessages) {
return ''
} else if (item.value.unreadMentionDirect || (item.value.unreadMessages !== 0
&& [CONVERSATION.TYPE.ONE_TO_ONE, CONVERSATION.TYPE.ONE_TO_ONE_FORMER].includes(item.value.type)
Expand All @@ -45,7 +48,7 @@ export function useConversationInfo({
* e.g. no avatars on mentions.
*/
const simpleLastChatMessage = computed(() => {
if (exposeMessages === false || !hasLastMessage.value) {
if (!exposeMessages || !hasLastMessage.value) {
return ''
}

Expand All @@ -64,7 +67,7 @@ export function useConversationInfo({
* @return {string} Part of the name until the first space
*/
const shortLastChatMessageAuthor = computed(() => {
if (exposeMessages === false || !hasLastMessage.value || item.value.lastMessage.systemMessage.length) {
if (!exposeMessages || !hasLastMessage.value || item.value.lastMessage.systemMessage.length) {
return ''
}

Expand All @@ -83,7 +86,7 @@ export function useConversationInfo({
return t('spreed', 'Joining conversation …')
}

if (exposeMessages === false) {
if (!exposeMessages) {
return exposeDescription ? item.value?.description : ''
} else if (!hasLastMessage.value) {
return t('spreed', 'No messages')
Expand Down

0 comments on commit d52b580

Please sign in to comment.