@bcc-code/vue-bcc-chat-ui 5.2.4 → 5.2.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@bcc-code/vue-bcc-chat-ui",
3
3
  "author": "bcc-code",
4
4
  "license": "Apache-2.0",
5
- "version": "5.2.4",
5
+ "version": "5.2.7",
6
6
  "type": "module",
7
7
  "private": false,
8
8
  "files": [
@@ -1,4 +1,6 @@
1
1
  <script setup lang="ts">
2
+ import { CometChat, Group, GroupMember } from "@cometchat/chat-sdk-javascript";
3
+ import { CometChatMessageEvents, MessageStatus } from "@cometchat/uikit-resources";
2
4
  import {
3
5
  PropType,
4
6
  Ref,
@@ -12,16 +14,14 @@ import {
12
14
  } from "vue";
13
15
  import chat from "../chat";
14
16
  import { connect, disconnect } from "../chat/connection";
17
+ import { getGroupMembersInfo } from "../chat/data";
18
+ import logger from "../chat/logger";
15
19
  import { loggedIn } from "../chat/login";
16
- import { CometChat, Group, GroupMember } from "@cometchat/chat-sdk-javascript";
17
20
  import { watchAndApplyStyle } from "../chat/styleFix";
18
21
  import { ChatInstance, ParticipantInfo } from "../chat/types";
19
- import { CometChatMessageEvents, MessageStatus } from "@cometchat/uikit-resources";
22
+ import { onlineMode, onlineStatus } from "../offline/connectivity";
20
23
  import BccChatMessages from "./BccChatMessages.vue";
21
24
  import BccScheduledMessages from "./BccScheduledMessages.vue";
22
- import { getGroupMembersInfo } from "../chat/data";
23
- import logger from "../chat/logger";
24
- import { onlineMode, onlineStatus } from "../offline/connectivity";
25
25
  const props = defineProps({
26
26
  chatUid: { type: String, required: true },
27
27
  senderDisplayName: { type: String, required: false },
@@ -1,22 +1,23 @@
1
1
  <template>
2
2
  <div class="cc__imageviewer__full-screen-viewer">
3
3
  <div class="cc__imageviewer__zoom-container" ref="zoomContainer">
4
- <img class="cc__imageviewer__loading" :src="props.placeholderImage ?? placeholderIcon" v-if="!isImageLoaded"/>
5
- <img :src="proxyImage(props.URL)" @load="imageLoaded"/>
4
+ <img class="cc__imageviewer__loading" :src="placeholderImage" v-if="!isImageLoaded" />
5
+ <img :src="proxyImage(url)" @load="imageLoaded" />
6
6
  </div>
7
7
  </div>
8
- <div class="cc__imageviewer__button cc__imageviewer__close-button" @click="dispatchCloseClickEvent">
9
- <cometchat-icon :URL="Close2xIcon" :iconStyle="iconStyle"></cometchat-icon>
8
+ <div class="cc__imageviewer-option cc__imageviewer-option--close" @click="dispatchCloseClickEvent">
9
+ <CloseIcon class="w-6 h-6 text-white" />
10
10
  </div>
11
- <div class="cc__imageviewer__button cc__imageviewer__download-button" @click="openImage">
12
- <cometchat-icon :URL="dowloadIcon" :iconStyle="iconStyle"></cometchat-icon>
11
+ <div class="cc__imageviewer-option cc__imageviewer-option--download" @click="openImage">
12
+ <DownloadIcon class="w-6 h-6 text-white" />
13
13
  </div>
14
14
  </template>
15
15
 
16
16
  <script setup lang="ts">
17
- import { ref, onMounted, onBeforeUnmount } from 'vue';
18
- import { Close2xIcon, CometChatIcon } from '@cometchat/chat-uikit-vue';
17
+ import { CloseIcon, DownloadIcon } from '@bcc-code/icons-vue';
18
+ import { CometChatIcon } from '@cometchat/chat-uikit-vue';
19
19
  import createPanZoom from 'panzoom';
20
+ import { onBeforeUnmount, onMounted, ref } from 'vue';
20
21
  import { proxyImage } from '../chat/data';
21
22
 
22
23
  if (!window.customElements.get('cometchat-icon')) {
@@ -24,7 +25,7 @@ if (!window.customElements.get('cometchat-icon')) {
24
25
  }
25
26
 
26
27
  const props = defineProps({
27
- URL: {
28
+ url: {
28
29
  type: String,
29
30
  required: true
30
31
  },
@@ -42,17 +43,8 @@ const dispatchCloseClickEvent = (event: Event) => {
42
43
  emit('cc-close-clicked');
43
44
  };
44
45
 
45
- const placeholderIcon = "";
46
- const dowloadIcon = ""
47
-
48
- const iconStyle = {
49
- height: '24px',
50
- width: '24px',
51
- iconTint: "white",
52
- };
53
-
54
46
  const openImage = () => {
55
- window.open(props.URL, '_blank');
47
+ window.open(props.url, '_blank');
56
48
  };
57
49
 
58
50
  const isImageLoaded = ref(false);
@@ -105,21 +97,22 @@ img {
105
97
  max-height: 100%;
106
98
  }
107
99
 
108
- .cc__imageviewer__button {
100
+ .cc__imageviewer-option {
109
101
  position: fixed;
110
- right: 0;
111
102
  cursor: pointer;
112
103
  z-index: 10001;
113
104
  padding: 10px;
114
105
  }
115
106
 
116
- .cc__imageviewer__close-button {
107
+ .cc__imageviewer-option--close {
117
108
  top: 0;
109
+ right: 0;
118
110
  margin-top: env(safe-area-inset-top);
119
111
  }
120
112
 
121
- .cc__imageviewer__download-button {
122
- top: 49px;
113
+ .cc__imageviewer-option--download {
114
+ top: 0;
115
+ left: 0;
123
116
  margin-top: env(safe-area-inset-top);
124
117
  }
125
118
  </style>
@@ -1,7 +1,7 @@
1
1
  <script setup lang="ts">
2
+ import { MediaMessage } from '@cometchat/chat-sdk-javascript';
2
3
  import { ref } from 'vue';
3
4
  import BccCometChatFullScreenViewer from './BccCometChatFullScreenViewer.vue';
4
- import { MediaMessage } from '@cometchat/chat-sdk-javascript';
5
5
 
6
6
 
7
7
  const props = defineProps({
@@ -12,43 +12,19 @@ const props = defineProps({
12
12
  placeholderImage: {
13
13
  type: String
14
14
  },
15
- imageStyle: {
16
- type: Object
17
- },
18
15
  message: {
19
16
  type: MediaMessage
20
17
  }
21
18
  })
22
19
 
23
- const imageStyle = {
24
- height: "auto",
25
- maxHeight: "500px",
26
- maxWidth: "400px",
27
- ...props.imageStyle
28
- };
29
-
30
- const onePixelPlaceholderImage = "";
31
- const wideThinTransparentImage = "";
32
- const height300pxImage = "";
33
-
34
- const imgDimensions = (props.message?.getMetadata() as any)?.dimensions;
35
- const numericAspectRatio = imgDimensions ? imgDimensions.width / imgDimensions.height : undefined;
36
- const isLandscape = imgDimensions ? imgDimensions.height < imgDimensions.width : undefined;
37
-
38
- let aspectRatio: string | undefined;
39
- if (numericAspectRatio !== undefined && numericAspectRatio <= 0.28) { // 0.28 is the minimum aspect ratio before min-width is reached.
40
- aspectRatio = "0.28 / 1";
41
- } else if (numericAspectRatio !== undefined && numericAspectRatio >= 8) { // 8 is the maximum aspect ratio before min-height is reached.
42
- aspectRatio = "8 / 1";
43
- } else if (imgDimensions) {
44
- aspectRatio = `${imgDimensions.width}/${imgDimensions.height}`;
45
- }
20
+ const imgDimensions = (props.message?.getMetadata() as any)?.dimensions || { width: 300, height: 150 };
46
21
 
22
+ const imageLoaded = ref(false);
47
23
  const openFullscreenView = ref(false);
48
24
  const imageurlToOpen = ref("");
49
25
 
50
- async function openImageInFullScreen(thisObj: any) {
51
- imageurlToOpen.value = props.message?.getAttachments()[0]?.getUrl() ?? thisObj.detail.url;
26
+ async function openImageInFullScreen() {
27
+ imageurlToOpen.value = props.message?.getAttachments()[0]?.getUrl() || props.src;
52
28
  openFullscreenView.value = true;
53
29
  }
54
30
 
@@ -60,27 +36,24 @@ function closeImageInFullScreen() {
60
36
 
61
37
  <template>
62
38
  <div class="bcc-image_container">
63
- <div class="placeholder" v-if="imgDimensions != undefined" :class="{ 'landscape': isLandscape }" :style="{ 'aspect-ratio': aspectRatio }">
64
- <img :src="isLandscape ? wideThinTransparentImage : height300pxImage" />
65
- </div>
66
- <cometchat-image-bubble
67
- :src="props.src"
68
- :placeholderImage="imgDimensions ? onePixelPlaceholderImage : props.placeholderImage"
69
- :imageStyle="imageStyle"
70
- :onCcImageClicked="openImageInFullScreen"
71
- />
39
+ <div class="bg-gradient-to-tr from-brand-200 to-brand-50 dark:from-brand-900 dark:to-brand-700"
40
+ :class="{ 'animate-pulse': !imageLoaded }"
41
+ :style="!imageLoaded ? `width: ${imgDimensions.width}px; height: ${imgDimensions.height}px` : ''"
42
+ >
43
+ <img @load="imageLoaded = true" :src="src" @click="openImageInFullScreen" />
44
+ </div>
72
45
  </div>
73
- <BccCometChatFullScreenViewer v-if="openFullscreenView"
74
- :onCcCloseClicked="closeImageInFullScreen"
75
- :URL="imageurlToOpen"
46
+ <BccCometChatFullScreenViewer
47
+ v-if="openFullscreenView"
48
+ @CcCloseClicked="closeImageInFullScreen"
49
+ :placeholder-image="placeholderImage"
50
+ :url="imageurlToOpen"
76
51
  />
77
52
  </template>
78
53
 
79
54
  <style scoped>
80
55
  .bcc-image_container {
81
56
  max-height: 300px;
82
- display: grid;
83
- grid-template-columns: 1fr;
84
57
  justify-content: center;
85
58
  overflow: hidden;
86
59
  border-radius: 10px;
@@ -88,37 +61,15 @@ function closeImageInFullScreen() {
88
61
  min-height: 28px;
89
62
  min-width: 84px;
90
63
  }
91
-
92
- /* Placeholder styles */
93
- .bcc-image_container .placeholder {
94
- width: 100%;
95
- height: auto;
96
- display: flex;
97
- justify-content: center;
98
- align-items: center;
99
- background-color: var(--cc__accent200, #3e8e7526); /* Placeholder background color */
100
- grid-row-start: 1;
101
- grid-column-start: 1;
64
+ .bcc-image_container img {
65
+ max-height: 500px;
66
+ max-width: 400px;
67
+ object-fit: contain;
68
+ object-position: center;
102
69
  position: relative;
103
- z-index: -1;
104
70
  }
105
71
 
106
72
  .bcc-image_container .placeholder::before {
107
73
  content: "⌛";
108
- position: absolute;
109
- }
110
-
111
- .bcc-image_container .placeholder.landscape > img {
112
- width: 100%;
113
- }
114
-
115
- cometchat-image-bubble {
116
- display: block;
117
- max-width: 100%;
118
- grid-row-start: 1;
119
- grid-column-start: 1;
120
- display: flex;
121
- justify-content: center;
122
- /* align-items: center; */
123
74
  }
124
75
  </style>