@droppii-org/chat-sdk 0.0.30 → 0.0.31
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/assets/conversationBg.png +0 -0
- package/dist/assets/images/conversationBg.png +0 -0
- package/dist/assets/images/imageFailed.png +0 -0
- package/dist/assets/sdk/sql-wasm.wasm +0 -0
- package/dist/assets/sdk/version +1 -0
- package/dist/assets/sdk/wasm_exec.js +575 -0
- package/dist/assets/svg/document.d.ts +2 -0
- package/dist/assets/svg/document.d.ts.map +1 -0
- package/dist/assets/svg/document.js +2 -0
- package/dist/assets/svg/document.tsx +37 -0
- package/dist/assets/svg/index.d.ts +2 -0
- package/dist/assets/svg/index.d.ts.map +1 -0
- package/dist/assets/svg/index.js +1 -0
- package/dist/assets/svg/index.ts +1 -0
- package/dist/components/chatBubble/ChatBubble.d.ts.map +1 -1
- package/dist/components/chatBubble/ChatBubble.js +6 -11
- package/dist/components/conversation/ConversationItemList.d.ts +7 -0
- package/dist/components/conversation/ConversationItemList.d.ts.map +1 -0
- package/dist/components/conversation/ConversationItemList.js +20 -0
- package/dist/components/conversation/DeskConversationList.d.ts +1 -5
- package/dist/components/conversation/DeskConversationList.d.ts.map +1 -1
- package/dist/components/conversation/DeskConversationList.js +40 -24
- package/dist/components/mediaCollection/FileCollection.d.ts +3 -0
- package/dist/components/mediaCollection/FileCollection.d.ts.map +1 -0
- package/dist/components/mediaCollection/FileCollection.js +54 -0
- package/dist/components/mediaCollection/ImageCollection.d.ts +3 -0
- package/dist/components/mediaCollection/ImageCollection.d.ts.map +1 -0
- package/dist/components/mediaCollection/ImageCollection.js +37 -0
- package/dist/components/mediaCollection/LinkCollection.d.ts +3 -0
- package/dist/components/mediaCollection/LinkCollection.d.ts.map +1 -0
- package/dist/components/mediaCollection/LinkCollection.js +8 -0
- package/dist/components/mediaCollection/VideoCollection.d.ts +3 -0
- package/dist/components/mediaCollection/VideoCollection.d.ts.map +1 -0
- package/dist/components/mediaCollection/VideoCollection.js +53 -0
- package/dist/components/mediaCollection/index.d.ts +9 -0
- package/dist/components/mediaCollection/index.d.ts.map +1 -0
- package/dist/components/mediaCollection/index.js +54 -0
- package/dist/components/message/MessageHeader.d.ts.map +1 -1
- package/dist/components/message/MessageHeader.js +2 -1
- package/dist/components/message/MessageList.d.ts.map +1 -1
- package/dist/components/message/MessageList.js +14 -2
- package/dist/components/message/footer/FilePreview.d.ts +0 -1
- package/dist/components/message/footer/FilePreview.d.ts.map +1 -1
- package/dist/components/message/footer/FilePreview.js +4 -4
- package/dist/components/message/footer/ToolbarPlugin.js +1 -1
- package/dist/components/message/footer/index.js +1 -1
- package/dist/components/message/item/FileMessage.d.ts.map +1 -1
- package/dist/components/message/item/FileMessage.js +2 -1
- package/dist/components/message/item/ImageMessage.js +3 -3
- package/dist/components/message/item/TextMessage.js +2 -2
- package/dist/components/message/item/index.js +1 -1
- package/dist/components/session/AssignedSessionFilter.js +9 -10
- package/dist/constants/images.d.ts +5 -0
- package/dist/constants/images.d.ts.map +1 -0
- package/dist/constants/images.js +7 -0
- package/dist/context/ChatContext.d.ts +2 -1
- package/dist/context/ChatContext.d.ts.map +1 -1
- package/dist/context/ChatContext.js +17 -24
- package/dist/hooks/collection/useMediaCollection.d.ts +229 -0
- package/dist/hooks/collection/useMediaCollection.d.ts.map +1 -0
- package/dist/hooks/collection/useMediaCollection.js +66 -0
- package/dist/hooks/common/useIsMobile.d.ts +2 -0
- package/dist/hooks/common/useIsMobile.d.ts.map +1 -0
- package/dist/hooks/common/useIsMobile.js +15 -0
- package/dist/hooks/conversation/useConversationStore.d.ts +3 -2
- package/dist/hooks/conversation/useConversationStore.d.ts.map +1 -1
- package/dist/hooks/global/useGlobalEvent.d.ts.map +1 -1
- package/dist/hooks/global/useGlobalEvent.js +55 -6
- package/dist/hooks/init/useChatToken.d.ts +2 -0
- package/dist/hooks/init/useChatToken.d.ts.map +1 -0
- package/dist/hooks/init/useChatToken.js +11 -0
- package/dist/hooks/message/useSendMessage.d.ts.map +1 -1
- package/dist/hooks/message/useSendMessage.js +31 -12
- package/dist/index.d.ts +5 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -2
- package/dist/layout/index.d.ts.map +1 -1
- package/dist/layout/index.js +2 -5
- package/dist/locales/i18n.d.ts +3 -0
- package/dist/locales/i18n.d.ts.map +1 -0
- package/dist/locales/i18n.js +16 -0
- package/dist/locales/i18n.ts +18 -0
- package/dist/locales/vi/common.json +9 -0
- package/dist/screens/chatBubble/index.d.ts.map +1 -1
- package/dist/screens/chatBubble/index.js +4 -3
- package/dist/screens/deskMessage/index.d.ts.map +1 -1
- package/dist/screens/deskMessage/index.js +3 -3
- package/dist/services/api.d.ts +2 -0
- package/dist/services/api.d.ts.map +1 -0
- package/dist/services/api.js +16 -0
- package/dist/services/query.d.ts +5 -0
- package/dist/services/query.d.ts.map +1 -0
- package/dist/services/query.js +4 -0
- package/dist/services/routes.d.ts +15 -0
- package/dist/services/routes.d.ts.map +1 -0
- package/dist/services/routes.js +14 -0
- package/dist/store/auth.d.ts +4 -0
- package/dist/store/auth.d.ts.map +1 -0
- package/dist/store/auth.js +16 -0
- package/dist/styles/global.css +1 -1
- package/dist/types/chat.d.ts +10 -4
- package/dist/types/chat.d.ts.map +1 -1
- package/dist/types/dto.d.ts +35 -0
- package/dist/types/dto.d.ts.map +1 -0
- package/dist/types/dto.js +1 -0
- package/dist/utils/common.d.ts +2 -0
- package/dist/utils/common.d.ts.map +1 -0
- package/dist/utils/common.js +12 -0
- package/dist/utils/imCommon.d.ts +0 -1
- package/dist/utils/imCommon.d.ts.map +1 -1
- package/dist/utils/imCommon.js +0 -5
- package/package.json +15 -3
- package/dist/assets/openIM.wasm +0 -0
- package/dist/components/ChatBubble.d.ts +0 -10
- package/dist/components/ChatBubble.d.ts.map +0 -1
- package/dist/components/ChatBubble.js +0 -28
- package/dist/components/message/MessageItem.d.ts +0 -7
- package/dist/components/message/MessageItem.d.ts.map +0 -1
- package/dist/components/message/MessageItem.js +0 -21
- package/dist/components/message/footer/BottomSection.d.ts +0 -3
- package/dist/components/message/footer/BottomSection.d.ts.map +0 -1
- package/dist/components/message/footer/BottomSection.js +0 -6
- package/dist/screens/desk-message/index.d.ts +0 -3
- package/dist/screens/desk-message/index.d.ts.map +0 -1
- package/dist/screens/desk-message/index.js +0 -15
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/dist/types/index.d.ts +0 -1
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js +0 -1
- package/dist/types/sdk.d.ts +0 -1
- package/dist/types/sdk.d.ts.map +0 -1
- package/dist/types/sdk.js +0 -1
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { MessageType, SessionType } from "@openim/wasm-client-sdk";
|
|
2
|
+
export interface Pageable {
|
|
3
|
+
pageNumber: number;
|
|
4
|
+
pageSize: number;
|
|
5
|
+
totalElements: number;
|
|
6
|
+
totalPages: number;
|
|
7
|
+
}
|
|
8
|
+
export interface MediaCollectionRequest {
|
|
9
|
+
recvID: string;
|
|
10
|
+
contentType: MessageType;
|
|
11
|
+
page: number;
|
|
12
|
+
pageSize: number;
|
|
13
|
+
}
|
|
14
|
+
export interface MediaCollectionItem {
|
|
15
|
+
chatLog: {
|
|
16
|
+
sendID: string;
|
|
17
|
+
recvID: string;
|
|
18
|
+
msgFrom: string;
|
|
19
|
+
contentType: MessageType;
|
|
20
|
+
content: string;
|
|
21
|
+
sendTime: number;
|
|
22
|
+
createTime: number;
|
|
23
|
+
sessionType: SessionType;
|
|
24
|
+
isRead: boolean;
|
|
25
|
+
isRevoked: boolean;
|
|
26
|
+
clientMsgID: string;
|
|
27
|
+
serverMsgID: string;
|
|
28
|
+
};
|
|
29
|
+
isRevoked: boolean;
|
|
30
|
+
}
|
|
31
|
+
export interface MediaCollectionResponse {
|
|
32
|
+
data: MediaCollectionItem[];
|
|
33
|
+
pageable: Pageable;
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=dto.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dto.d.ts","sourceRoot":"","sources":["../../src/types/dto.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAEnE,MAAM,WAAW,QAAQ;IACvB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,WAAW,CAAC;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE;QACP,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;QACf,OAAO,EAAE,MAAM,CAAC;QAChB,WAAW,EAAE,WAAW,CAAC;QACzB,OAAO,EAAE,MAAM,CAAC;QAChB,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;QACnB,WAAW,EAAE,WAAW,CAAC;QACzB,MAAM,EAAE,OAAO,CAAC;QAChB,SAAS,EAAE,OAAO,CAAC;QACnB,WAAW,EAAE,MAAM,CAAC;QACpB,WAAW,EAAE,MAAM,CAAC;KACrB,CAAC;IACF,SAAS,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,uBAAuB;IACtC,IAAI,EAAE,mBAAmB,EAAE,CAAC;IAC5B,QAAQ,EAAE,QAAQ,CAAC;CACpB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../src/utils/common.ts"],"names":[],"mappings":"AAAA,wBAAgB,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAapD"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export function renderFileSize(bytes) {
|
|
2
|
+
if (!bytes || bytes <= 0)
|
|
3
|
+
return "0 B";
|
|
4
|
+
const units = ["B", "KB", "MB", "GB", "TB"];
|
|
5
|
+
let index = 0;
|
|
6
|
+
let size = bytes;
|
|
7
|
+
while (size >= 1024 && index < units.length - 1) {
|
|
8
|
+
size /= 1024;
|
|
9
|
+
index++;
|
|
10
|
+
}
|
|
11
|
+
return `${size.toFixed(1)} ${units[index]}`;
|
|
12
|
+
}
|
package/dist/utils/imCommon.d.ts
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { ConversationItem, SessionType } from "@openim/wasm-client-sdk";
|
|
2
2
|
export declare const isGroupSession: (sessionType?: SessionType) => boolean;
|
|
3
|
-
export declare const initStore: () => void;
|
|
4
3
|
export declare const conversationSort: (conversationList: ConversationItem[], originalList?: ConversationItem[]) => {
|
|
5
4
|
conversationID: string;
|
|
6
5
|
conversationType: SessionType;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"imCommon.d.ts","sourceRoot":"","sources":["../../src/utils/imCommon.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;
|
|
1
|
+
{"version":3,"file":"imCommon.d.ts","sourceRoot":"","sources":["../../src/utils/imCommon.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAGxE,eAAO,MAAM,cAAc,GAAI,cAAc,WAAW,YACO,CAAC;AAEhE,eAAO,MAAM,gBAAgB,GAC3B,kBAAkB,gBAAgB,EAAE,EACpC,eAAe,gBAAgB,EAAE;;;;;;;;;;;;;;;;;;;;;;GA8ClC,CAAC"}
|
package/dist/utils/imCommon.js
CHANGED
|
@@ -10,12 +10,7 @@ var __rest = (this && this.__rest) || function (s, e) {
|
|
|
10
10
|
return t;
|
|
11
11
|
};
|
|
12
12
|
import { GroupSessionTypes } from "../constants/im";
|
|
13
|
-
import useConversationStore from "../store/conversation";
|
|
14
13
|
export const isGroupSession = (sessionType) => sessionType ? GroupSessionTypes.includes(sessionType) : false;
|
|
15
|
-
export const initStore = () => {
|
|
16
|
-
const { getConversationListByReq } = useConversationStore.getState();
|
|
17
|
-
getConversationListByReq();
|
|
18
|
-
};
|
|
19
14
|
export const conversationSort = (conversationList, originalList) => {
|
|
20
15
|
const listWithIndex = conversationList.map((item, index) => {
|
|
21
16
|
var _a;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@droppii-org/chat-sdk",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.31",
|
|
4
4
|
"description": "Droppii React Chat SDK",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"types": "./dist/index.d.ts",
|
|
@@ -45,18 +45,24 @@
|
|
|
45
45
|
"import": "./dist/utils/*.js",
|
|
46
46
|
"types": "./dist/utils/*.d.ts"
|
|
47
47
|
},
|
|
48
|
+
"./services/*": {
|
|
49
|
+
"import": "./dist/services/*.js",
|
|
50
|
+
"types": "./dist/services/*.d.ts"
|
|
51
|
+
},
|
|
52
|
+
"./locales/*": "./dist/locales/*",
|
|
48
53
|
"./styles/global.css": "./dist/styles/global.css"
|
|
49
54
|
},
|
|
50
55
|
"files": [
|
|
51
56
|
"dist"
|
|
52
57
|
],
|
|
53
58
|
"scripts": {
|
|
54
|
-
"build": "pnpm build:css && tsc -p tsconfig.build.json &&
|
|
59
|
+
"build": "pnpm build:css && tsc -p tsconfig.build.json && pnpm copy-assets",
|
|
55
60
|
"build:css": "tailwindcss -i ./src/styles/global.css -o ./dist/styles/global.css --minify",
|
|
56
61
|
"dev": "tsc --noEmit --watch",
|
|
57
62
|
"lint": "eslint src/",
|
|
58
63
|
"type-check": "tsc --noEmit",
|
|
59
|
-
"prepublishOnly": "pnpm build"
|
|
64
|
+
"prepublishOnly": "pnpm build",
|
|
65
|
+
"copy-assets": "cp -R src/assets dist && cp -R src/locales dist"
|
|
60
66
|
},
|
|
61
67
|
"keywords": [
|
|
62
68
|
"chat",
|
|
@@ -79,16 +85,22 @@
|
|
|
79
85
|
"@lexical/rich-text": "^0.34.0",
|
|
80
86
|
"@openim/wasm-client-sdk": "3.8.3-patch.10",
|
|
81
87
|
"@tailwindcss/postcss": "^4.1.12",
|
|
88
|
+
"@tanstack/react-query": "^5.85.5",
|
|
82
89
|
"ahooks": "^3.9.4",
|
|
83
90
|
"antd": "^5.27.0",
|
|
91
|
+
"axios": "^1.11.0",
|
|
84
92
|
"clsx": "^2.0.0",
|
|
85
93
|
"dayjs": "^1.11.13",
|
|
94
|
+
"i18next": "^25.5.2",
|
|
86
95
|
"lexical": "^0.34.0",
|
|
96
|
+
"lodash": "^4.17.21",
|
|
87
97
|
"lucide-react": "^0.263.1",
|
|
88
98
|
"mitt": "^3.0.1",
|
|
89
99
|
"postcss": "^8.5.6",
|
|
100
|
+
"react-i18next": "^15.7.3",
|
|
90
101
|
"react-icomoon": "^2.6.1",
|
|
91
102
|
"react-infinite-scroll-component": "^6.1.0",
|
|
103
|
+
"react-sticky-box": "^2.0.5",
|
|
92
104
|
"tailwind-merge": "^2.0.0",
|
|
93
105
|
"tailwindcss": "^3.3.0",
|
|
94
106
|
"uuid": "^11.1.0",
|
package/dist/assets/openIM.wasm
DELETED
|
Binary file
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { SessionType } from "@openim/wasm-client-sdk";
|
|
2
|
-
interface ChatBubbleProps {
|
|
3
|
-
conversationId: string;
|
|
4
|
-
sourceID: string;
|
|
5
|
-
sessionType: SessionType;
|
|
6
|
-
className?: string;
|
|
7
|
-
}
|
|
8
|
-
declare const ChatBubble: ({ conversationId, sourceID, sessionType, className, }: ChatBubbleProps) => import("react/jsx-runtime").JSX.Element;
|
|
9
|
-
export default ChatBubble;
|
|
10
|
-
//# sourceMappingURL=ChatBubble.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ChatBubble.d.ts","sourceRoot":"","sources":["../../src/components/ChatBubble.tsx"],"names":[],"mappings":"AAKA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAGtD,UAAU,eAAe;IACvB,cAAc,EAAE,MAAM,CAAC;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,WAAW,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,QAAA,MAAM,UAAU,GAAI,uDAKjB,eAAe,4CAmDjB,CAAC;AAEF,eAAe,UAAU,CAAC"}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
-
import { useState } from "react";
|
|
4
|
-
import { FloatButton, Drawer } from "antd";
|
|
5
|
-
import { MessageOutlined, CloseOutlined } from "@ant-design/icons";
|
|
6
|
-
import MessageList from "./message/MessageList";
|
|
7
|
-
import { useConversationDetail } from "../hooks/conversation/useConversation";
|
|
8
|
-
const ChatBubble = ({ conversationId, sourceID, sessionType, className, }) => {
|
|
9
|
-
const { conversationDetail } = useConversationDetail({
|
|
10
|
-
sourceID,
|
|
11
|
-
sessionType,
|
|
12
|
-
});
|
|
13
|
-
const [isOpen, setIsOpen] = useState(false);
|
|
14
|
-
const toggleChat = () => {
|
|
15
|
-
setIsOpen(!isOpen);
|
|
16
|
-
};
|
|
17
|
-
return (_jsxs(_Fragment, { children: [_jsx(FloatButton, { icon: isOpen ? _jsx(CloseOutlined, {}) : _jsx(MessageOutlined, {}), type: "primary", style: {
|
|
18
|
-
right: 24,
|
|
19
|
-
bottom: 24,
|
|
20
|
-
width: 60,
|
|
21
|
-
height: 60,
|
|
22
|
-
}, onClick: toggleChat, className: className }), _jsx(Drawer, { placement: "right", onClose: () => setIsOpen(false), open: isOpen, mask: true, closable: false, styles: {
|
|
23
|
-
body: { padding: 0 },
|
|
24
|
-
}, classNames: {
|
|
25
|
-
wrapper: "!z-[9999]",
|
|
26
|
-
}, children: _jsx(MessageList, { conversationId: conversationId, conversationData: conversationDetail, className: "flex-1", onClose: () => setIsOpen(false) }) })] }));
|
|
27
|
-
};
|
|
28
|
-
export default ChatBubble;
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { GroupMessageItem } from "../../types/chat";
|
|
2
|
-
interface MessageItemProps {
|
|
3
|
-
groupMessage: GroupMessageItem;
|
|
4
|
-
}
|
|
5
|
-
declare const MessageItem: ({ groupMessage }: MessageItemProps) => import("react/jsx-runtime").JSX.Element;
|
|
6
|
-
export default MessageItem;
|
|
7
|
-
//# sourceMappingURL=MessageItem.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MessageItem.d.ts","sourceRoot":"","sources":["../../../src/components/message/MessageItem.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAUpD,UAAU,gBAAgB;IACxB,YAAY,EAAE,gBAAgB,CAAC;CAChC;AACD,QAAA,MAAM,WAAW,GAAI,kBAAkB,gBAAgB,4CAwEtD,CAAC;AAEF,eAAe,WAAW,CAAC"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import dayjs from "dayjs";
|
|
3
|
-
import clsx from "clsx";
|
|
4
|
-
import { Avatar } from "antd";
|
|
5
|
-
import isToday from "dayjs/plugin/isToday";
|
|
6
|
-
import { useChatContext } from "../../context/ChatContext";
|
|
7
|
-
import { SessionType } from "@openim/wasm-client-sdk";
|
|
8
|
-
dayjs.extend(isToday);
|
|
9
|
-
const MessageItem = ({ groupMessage }) => {
|
|
10
|
-
const { user } = useChatContext();
|
|
11
|
-
const messagesInGroup = (groupMessage === null || groupMessage === void 0 ? void 0 : groupMessage.messages) || [];
|
|
12
|
-
const isToday = dayjs(groupMessage === null || groupMessage === void 0 ? void 0 : groupMessage.sendTime).isToday();
|
|
13
|
-
return (_jsxs("div", { className: "flex flex-col gap-2 my-4 mx-3 sm:mx-4", children: [_jsx("div", { className: "flex justify-center", children: _jsx("span", { className: "text-xs text-gray-600 text-center bg-neutral-100 px-2 py-1 rounded-full", children: dayjs(groupMessage === null || groupMessage === void 0 ? void 0 : groupMessage.sendTime).format(isToday ? "HH:mm" : "HH:mm, DD MMMM") }) }), messagesInGroup === null || messagesInGroup === void 0 ? void 0 : messagesInGroup.map((message, messageIndex) => {
|
|
14
|
-
var _a, _b, _c;
|
|
15
|
-
const isMine = (message === null || message === void 0 ? void 0 : message.sendID) === (user === null || user === void 0 ? void 0 : user.userID);
|
|
16
|
-
const showAvatar = messageIndex === messagesInGroup.length - 1;
|
|
17
|
-
const showSenderName = messageIndex === 0 && (message === null || message === void 0 ? void 0 : message.sessionType) === SessionType.Group;
|
|
18
|
-
return (_jsx("div", { className: clsx("flex", isMine ? "justify-end" : "justify-start"), children: _jsxs("div", { className: clsx("flex items-end gap-2", isMine ? "justify-end" : "justify-start"), children: [!isMine && (_jsx("div", { className: "flex items-center justify-center w-[32px] h-[32px]", children: showAvatar && (_jsx(Avatar, { children: ((_b = (_a = message === null || message === void 0 ? void 0 : message.senderNickname) === null || _a === void 0 ? void 0 : _a.charAt) === null || _b === void 0 ? void 0 : _b.call(_a, 0)) || "A" })) })), _jsxs("div", { className: "flex flex-col items-start flex-[0.8]", children: [!isMine && showSenderName && (_jsx("span", { className: "text-xs text-gray-500 mb-1 px-3", children: message === null || message === void 0 ? void 0 : message.senderNickname })), _jsxs("div", { className: clsx("px-3 py-2 rounded-2xl max-w-full break-words flex flex-col text-gray-900", isMine ? "bg-blue-100" : "bg-gray-100"), children: [_jsx("p", { className: "text-sm sm:text-base whitespace-pre-wrap", children: ((_c = message === null || message === void 0 ? void 0 : message.textElem) === null || _c === void 0 ? void 0 : _c.content) || "Tin nhắn không khả dụng" }), _jsx("span", { className: clsx("text-xs text-gray-500 text-right text-gray-500"), children: dayjs(message === null || message === void 0 ? void 0 : message.sendTime).format("HH:mm") })] })] })] }) }, message === null || message === void 0 ? void 0 : message.clientMsgID));
|
|
19
|
-
})] }, groupMessage === null || groupMessage === void 0 ? void 0 : groupMessage.groupMessageID));
|
|
20
|
-
};
|
|
21
|
-
export default MessageItem;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"BottomSection.d.ts","sourceRoot":"","sources":["../../../../src/components/message/footer/BottomSection.tsx"],"names":[],"mappings":"AAEA,QAAA,MAAM,mBAAmB,+CAMxB,CAAC;AAEF,eAAe,mBAAmB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/screens/desk-message/index.tsx"],"names":[],"mappings":"AAQA,QAAA,MAAM,gBAAgB,+CAerB,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
-
import { SessionType } from "@openim/wasm-client-sdk";
|
|
4
|
-
import MessageList from "../../components/message/MessageList";
|
|
5
|
-
import DeskConversationList from "../../components/conversation/DeskConversationList";
|
|
6
|
-
import { useConversationDetail } from "../../hooks/conversation/useConversation";
|
|
7
|
-
import AssignedSessionFilter from "../../components/session/AssignedSessionFilter";
|
|
8
|
-
const DChatDeskMessage = () => {
|
|
9
|
-
const { conversationDetail } = useConversationDetail({
|
|
10
|
-
sourceID: "123-123",
|
|
11
|
-
sessionType: SessionType.Group,
|
|
12
|
-
});
|
|
13
|
-
return (_jsxs("div", { className: "flex flex-1 flex-row h-screen bg-gray-50", children: [_jsx(AssignedSessionFilter, {}), _jsx(DeskConversationList, {}), _jsx(MessageList, { conversationId: "sg_123-123", conversationData: conversationDetail })] }));
|
|
14
|
-
};
|
|
15
|
-
export default DChatDeskMessage;
|