HandleQuoteMessage.vue 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <template>
  2. <view v-if="message && user" class="message-box">
  3. <view v-if="message.messageType === MessageType.text" class="message">
  4. {{ user.name }}:{{ message.content }}
  5. </view>
  6. <view v-if="message.messageType === MessageType.image" class="message-img">
  7. <text>{{ user.name }}:</text>
  8. <image alt="图片" :src="message.extend?.url" style="height: 60rpx;width: 60rpx" />
  9. </view>
  10. <view v-if="message.messageType === MessageType.file" class="message">
  11. {{ user.name }}:{{ getFileName(message.extend?.fileName) }}
  12. </view>
  13. <view v-if="message.messageType === MessageType.video" class="message">
  14. {{ user.name }}:<text class="cuIcon cuIcon-video"></text>{{getFileName(message.extend?.url)}}
  15. </view>
  16. <view v-if="message.messageType === MessageType.voice" class="message">
  17. {{ user.name }}:<text class="cuIcon-sound"></text>{{getFileName(message.extend?.time)}}
  18. </view>
  19. <text class="cuIcon cuIcon-close" @tap="closeQuote"></text>
  20. </view>
  21. </template>
  22. <script setup lang="ts">
  23. import { computed } from 'vue'
  24. import MessageType from '../utils/MessageType'
  25. import { storeToRefs } from 'pinia'
  26. import { useUserStore } from '@/store/userStore'
  27. import {getFileName} from '@/utils/FileUtils'
  28. import type Message from "@/mode/Message";
  29. import {useChatStore} from "@/store/chatStore";
  30. const { userMap } = storeToRefs(useUserStore())
  31. interface IProps{
  32. message:Message
  33. }
  34. const props = defineProps<IProps>();
  35. const user = computed(() => {
  36. if(props.message){
  37. return userMap.value.get(props.message.fromId)
  38. }
  39. return null;
  40. })
  41. const closeQuote = () => {
  42. useChatStore().setQuoteMessage(undefined)
  43. }
  44. </script>
  45. <style scoped lang="scss">
  46. .message-box {
  47. cursor: pointer;
  48. flex: 1;
  49. overflow: hidden;
  50. background-color: #e9e9e9;
  51. margin-top: 10px;
  52. padding: 5px 11px;
  53. color: #999999;
  54. font-size: 24rpx;
  55. width: 60vw;
  56. display: flex;
  57. align-items: center;
  58. .message {
  59. overflow: hidden;
  60. text-overflow: ellipsis;
  61. white-space: nowrap;
  62. display: inline-block;
  63. max-width: 100%;
  64. flex: 1;
  65. }
  66. .message-img {
  67. line-height: 2;
  68. white-space: nowrap;
  69. display: inline-flex;
  70. padding: 0 11px;
  71. max-width: 620px;
  72. }
  73. }
  74. </style>