@bcc-code/vue-bcc-chat-ui 5.2.5 → 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/dist/components/BccCometChatFullScreenViewer.vue.d.ts +2 -2
- package/dist/components/BccImageBubble.vue.d.ts +0 -6
- package/dist/vue-bcc-chat-ui.css +1 -1
- package/dist/vue-bcc-chat-ui.js +13306 -13326
- package/dist/vue-bcc-chat-ui.js.map +1 -1
- package/package.json +1 -1
- package/src/components/BccChatMessageList.vue +5 -5
- package/src/components/BccCometChatFullScreenViewer.vue +17 -24
- package/src/components/BccImageBubble.vue +20 -70
package/package.json
CHANGED
|
@@ -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 {
|
|
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="
|
|
5
|
-
<img :src="proxyImage(
|
|
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="
|
|
9
|
-
<
|
|
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="
|
|
12
|
-
<
|
|
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 {
|
|
18
|
-
import {
|
|
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
|
-
|
|
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.
|
|
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
|
-
.
|
|
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
|
-
.
|
|
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
|
-
.
|
|
122
|
-
top:
|
|
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,6 +1,5 @@
|
|
|
1
1
|
<script setup lang="ts">
|
|
2
2
|
import { MediaMessage } from '@cometchat/chat-sdk-javascript';
|
|
3
|
-
import { CometChatImageBubble } from '@cometchat/chat-uikit-vue';
|
|
4
3
|
import { ref } from 'vue';
|
|
5
4
|
import BccCometChatFullScreenViewer from './BccCometChatFullScreenViewer.vue';
|
|
6
5
|
|
|
@@ -13,43 +12,19 @@ const props = defineProps({
|
|
|
13
12
|
placeholderImage: {
|
|
14
13
|
type: String
|
|
15
14
|
},
|
|
16
|
-
imageStyle: {
|
|
17
|
-
type: Object
|
|
18
|
-
},
|
|
19
15
|
message: {
|
|
20
16
|
type: MediaMessage
|
|
21
17
|
}
|
|
22
18
|
})
|
|
23
19
|
|
|
24
|
-
const
|
|
25
|
-
height: "auto",
|
|
26
|
-
maxHeight: "500px",
|
|
27
|
-
maxWidth: "400px",
|
|
28
|
-
...props.imageStyle
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
const onePixelPlaceholderImage = "";
|
|
32
|
-
const wideThinTransparentImage = "";
|
|
33
|
-
const height300pxImage = "";
|
|
34
|
-
|
|
35
|
-
const imgDimensions = (props.message?.getMetadata() as any)?.dimensions;
|
|
36
|
-
const numericAspectRatio = imgDimensions ? imgDimensions.width / imgDimensions.height : undefined;
|
|
37
|
-
const isLandscape = imgDimensions ? imgDimensions.height < imgDimensions.width : undefined;
|
|
38
|
-
|
|
39
|
-
let aspectRatio: string | undefined;
|
|
40
|
-
if (numericAspectRatio !== undefined && numericAspectRatio <= 0.28) { // 0.28 is the minimum aspect ratio before min-width is reached.
|
|
41
|
-
aspectRatio = "0.28 / 1";
|
|
42
|
-
} else if (numericAspectRatio !== undefined && numericAspectRatio >= 8) { // 8 is the maximum aspect ratio before min-height is reached.
|
|
43
|
-
aspectRatio = "8 / 1";
|
|
44
|
-
} else if (imgDimensions) {
|
|
45
|
-
aspectRatio = `${imgDimensions.width}/${imgDimensions.height}`;
|
|
46
|
-
}
|
|
20
|
+
const imgDimensions = (props.message?.getMetadata() as any)?.dimensions || { width: 300, height: 150 };
|
|
47
21
|
|
|
22
|
+
const imageLoaded = ref(false);
|
|
48
23
|
const openFullscreenView = ref(false);
|
|
49
24
|
const imageurlToOpen = ref("");
|
|
50
25
|
|
|
51
|
-
async function openImageInFullScreen(
|
|
52
|
-
imageurlToOpen.value = props.message?.getAttachments()[0]?.getUrl()
|
|
26
|
+
async function openImageInFullScreen() {
|
|
27
|
+
imageurlToOpen.value = props.message?.getAttachments()[0]?.getUrl() || props.src;
|
|
53
28
|
openFullscreenView.value = true;
|
|
54
29
|
}
|
|
55
30
|
|
|
@@ -61,27 +36,24 @@ function closeImageInFullScreen() {
|
|
|
61
36
|
|
|
62
37
|
<template>
|
|
63
38
|
<div class="bcc-image_container">
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
:imageStyle="imageStyle"
|
|
71
|
-
:onCcImageClicked="openImageInFullScreen"
|
|
72
|
-
/>
|
|
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>
|
|
73
45
|
</div>
|
|
74
|
-
<BccCometChatFullScreenViewer
|
|
75
|
-
|
|
76
|
-
|
|
46
|
+
<BccCometChatFullScreenViewer
|
|
47
|
+
v-if="openFullscreenView"
|
|
48
|
+
@CcCloseClicked="closeImageInFullScreen"
|
|
49
|
+
:placeholder-image="placeholderImage"
|
|
50
|
+
:url="imageurlToOpen"
|
|
77
51
|
/>
|
|
78
52
|
</template>
|
|
79
53
|
|
|
80
54
|
<style scoped>
|
|
81
55
|
.bcc-image_container {
|
|
82
56
|
max-height: 300px;
|
|
83
|
-
display: grid;
|
|
84
|
-
grid-template-columns: 1fr;
|
|
85
57
|
justify-content: center;
|
|
86
58
|
overflow: hidden;
|
|
87
59
|
border-radius: 10px;
|
|
@@ -89,37 +61,15 @@ function closeImageInFullScreen() {
|
|
|
89
61
|
min-height: 28px;
|
|
90
62
|
min-width: 84px;
|
|
91
63
|
}
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
display: flex;
|
|
98
|
-
justify-content: center;
|
|
99
|
-
align-items: center;
|
|
100
|
-
background-color: var(--cc__accent200, #3e8e7526); /* Placeholder background color */
|
|
101
|
-
grid-row-start: 1;
|
|
102
|
-
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;
|
|
103
69
|
position: relative;
|
|
104
|
-
z-index: -1;
|
|
105
70
|
}
|
|
106
71
|
|
|
107
72
|
.bcc-image_container .placeholder::before {
|
|
108
73
|
content: "⌛";
|
|
109
|
-
position: absolute;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
.bcc-image_container .placeholder.landscape > img {
|
|
113
|
-
width: 100%;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
cometchat-image-bubble {
|
|
117
|
-
display: block;
|
|
118
|
-
max-width: 100%;
|
|
119
|
-
grid-row-start: 1;
|
|
120
|
-
grid-column-start: 1;
|
|
121
|
-
display: flex;
|
|
122
|
-
justify-content: center;
|
|
123
|
-
/* align-items: center; */
|
|
124
74
|
}
|
|
125
75
|
</style>
|