MergeMessageRender.vue 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <template>
  2. <view @click="toPreview" class="merge_message_container">
  3. <view class="merge_title">
  4. <text>{{ title }}</text>
  5. </view>
  6. <view class="merge_desc">
  7. <text
  8. v-for="(item, idx) in message.mergeElem.abstractList"
  9. v-if="idx < 4"
  10. :key="idx"
  11. class="merge_item"
  12. >
  13. {{ item }}
  14. </text>
  15. </view>
  16. </view>
  17. </template>
  18. <script>
  19. export default {
  20. name: "CardMessageRender",
  21. components: {},
  22. props: {
  23. message: Object,
  24. },
  25. data() {
  26. return {};
  27. },
  28. computed: {
  29. title() {
  30. // const sessionType = this.message.mergeElem.multiMessage[0].sessionType;
  31. // if (sessionType === 1) {
  32. // return this.message.mergeElem.title;
  33. // }
  34. return this.message.mergeElem.title;
  35. },
  36. },
  37. methods: {
  38. toPreview() {
  39. uni.$u.route("/pages_im/pages/conversation/previewMerge/index", {
  40. mergeData: encodeURIComponent(JSON.stringify(this.message.mergeElem)),
  41. });
  42. },
  43. },
  44. };
  45. </script>
  46. <style lang="scss" scoped>
  47. .merge_message_container {
  48. padding: 0 !important;
  49. width: 444rpx;
  50. box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.1);
  51. border-radius: 12rpx;
  52. border: 1px solid #ececec;
  53. background: #fff;
  54. .merge_title {
  55. padding: 12rpx 24rpx;
  56. border-bottom: 1px solid #ececec;
  57. text {
  58. @include ellipsisWithLine(1);
  59. }
  60. }
  61. .merge_desc {
  62. @include colBox(false);
  63. padding: 12rpx 24rpx;
  64. font-size: 24rpx;
  65. color: #666;
  66. .merge_item {
  67. @include ellipsisWithLine(3);
  68. padding: 4rpx 0;
  69. }
  70. }
  71. }
  72. </style>