@smart-link/rn-im 1.0.1
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/README.md +34 -0
- package/assets/avatars-busi-notify.png +0 -0
- package/assets/avatars-empty.png +0 -0
- package/assets/avatars-group.jpg +0 -0
- package/assets/avatars-man.jpg +0 -0
- package/assets/avatars-woman.jpg +0 -0
- package/assets/cloud-backup-begin.png +0 -0
- package/assets/cloud-backup.png +0 -0
- package/assets/group-mgr.png +0 -0
- package/assets/group-owner.png +0 -0
- package/assets/hook-black-double.png +0 -0
- package/assets/hook-black.png +0 -0
- package/assets/hook-blue-double.png +0 -0
- package/assets/hook-blue.png +0 -0
- package/assets/hook-green.png +0 -0
- package/assets/no_message.png +0 -0
- package/assets/share.jpeg +0 -0
- package/assets/voice-left-playing.gif +0 -0
- package/assets/voice-left.png +0 -0
- package/dist/api/addressList.d.ts +27 -0
- package/dist/api/addressList.js +18 -0
- package/dist/api/backup.d.ts +18 -0
- package/dist/api/backup.js +29 -0
- package/dist/api/file.d.ts +4 -0
- package/dist/api/file.js +49 -0
- package/dist/api/user.d.ts +8 -0
- package/dist/api/user.js +16 -0
- package/dist/components/CachedImage.d.ts +11 -0
- package/dist/components/CachedImage.js +48 -0
- package/dist/components/Camera/Camera.d.ts +10 -0
- package/dist/components/Camera/Camera.js +100 -0
- package/dist/components/Camera/CameraCapture.d.ts +32 -0
- package/dist/components/Camera/CameraCapture.js +360 -0
- package/dist/components/Camera/CameraResult.d.ts +11 -0
- package/dist/components/Camera/CameraResult.js +102 -0
- package/dist/components/ChatAvatar/ChatAvatar.d.ts +15 -0
- package/dist/components/ChatAvatar/ChatAvatar.js +134 -0
- package/dist/components/ChatAvatar/ChatAvatarId.d.ts +8 -0
- package/dist/components/ChatAvatar/ChatAvatarId.js +92 -0
- package/dist/components/ChatAvatar/ChatAvatarLocal.d.ts +9 -0
- package/dist/components/ChatAvatar/ChatAvatarLocal.js +76 -0
- package/dist/components/ChatAvatar/index.d.ts +2 -0
- package/dist/components/ChatAvatar/index.js +23 -0
- package/dist/components/Favicon.d.ts +7 -0
- package/dist/components/Favicon.js +74 -0
- package/dist/components/FormatTimeText.d.ts +8 -0
- package/dist/components/FormatTimeText.js +24 -0
- package/dist/components/Highlighter.d.ts +9 -0
- package/dist/components/Highlighter.js +42 -0
- package/dist/components/IndicatorText.d.ts +10 -0
- package/dist/components/IndicatorText.js +47 -0
- package/dist/components/LocalImage.d.ts +10 -0
- package/dist/components/LocalImage.js +37 -0
- package/dist/components/NetworkUnconnected.d.ts +3 -0
- package/dist/components/NetworkUnconnected.js +55 -0
- package/dist/components/PopoverWrapper.d.ts +13 -0
- package/dist/components/PopoverWrapper.js +78 -0
- package/dist/components/VideoPlayer.d.ts +13 -0
- package/dist/components/VideoPlayer.js +288 -0
- package/dist/components/styles.d.ts +19 -0
- package/dist/components/styles.js +23 -0
- package/dist/default-assets.d.ts +18 -0
- package/dist/default-assets.js +22 -0
- package/dist/hooks/useFormatMsgTime.d.ts +4 -0
- package/dist/hooks/useFormatMsgTime.js +53 -0
- package/dist/hooks/useImSelector.d.ts +15 -0
- package/dist/hooks/useImSelector.js +48 -0
- package/dist/hooks/useTranslation.d.ts +13 -0
- package/dist/hooks/useTranslation.js +12 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +28 -0
- package/dist/init.d.ts +17 -0
- package/dist/init.js +116 -0
- package/dist/interface.d.ts +47 -0
- package/dist/interface.js +2 -0
- package/dist/locales/en/addressList.d.ts +3 -0
- package/dist/locales/en/addressList.js +31 -0
- package/dist/locales/index.d.ts +4 -0
- package/dist/locales/index.js +27 -0
- package/dist/locales/lao/addressList.d.ts +3 -0
- package/dist/locales/lao/addressList.js +31 -0
- package/dist/locales/zh/addressList.d.ts +30 -0
- package/dist/locales/zh/addressList.js +32 -0
- package/dist/pages/address-list/AddressList.d.ts +6 -0
- package/dist/pages/address-list/AddressList.js +158 -0
- package/dist/pages/address-list/CardInfo.d.ts +15 -0
- package/dist/pages/address-list/CardInfo.js +42 -0
- package/dist/pages/address-list/ChooseContact.d.ts +6 -0
- package/dist/pages/address-list/ChooseContact.js +197 -0
- package/dist/pages/address-list/Icons.d.ts +5 -0
- package/dist/pages/address-list/Icons.js +16 -0
- package/dist/pages/address-list/Organization.d.ts +13 -0
- package/dist/pages/address-list/Organization.js +221 -0
- package/dist/pages/address-list/UserDetail.d.ts +6 -0
- package/dist/pages/address-list/UserDetail.js +131 -0
- package/dist/pages/address-list/UserJobs.d.ts +6 -0
- package/dist/pages/address-list/UserJobs.js +50 -0
- package/dist/pages/address-list/UserSearch.d.ts +6 -0
- package/dist/pages/address-list/UserSearch.js +82 -0
- package/dist/pages/address-list/addressList.routes.d.ts +50 -0
- package/dist/pages/address-list/addressList.routes.js +50 -0
- package/dist/pages/collection/Collection.d.ts +3 -0
- package/dist/pages/collection/Collection.js +136 -0
- package/dist/pages/collection/ContentFactory.d.ts +6 -0
- package/dist/pages/collection/ContentFactory.js +167 -0
- package/dist/pages/collection/collection.routes.d.ts +9 -0
- package/dist/pages/collection/collection.routes.js +17 -0
- package/dist/pages/conversation/ForwardToConversation.d.ts +6 -0
- package/dist/pages/conversation/ForwardToConversation.js +172 -0
- package/dist/pages/conversation/List.d.ts +6 -0
- package/dist/pages/conversation/List.js +204 -0
- package/dist/pages/conversation/components/ConversationCard.d.ts +12 -0
- package/dist/pages/conversation/components/ConversationCard.js +142 -0
- package/dist/pages/conversation/components/ConversationOption.d.ts +11 -0
- package/dist/pages/conversation/components/ConversationOption.js +99 -0
- package/dist/pages/conversation/conversation.routes.d.ts +2 -0
- package/dist/pages/conversation/conversation.routes.js +74 -0
- package/dist/pages/conversation/setting/GroupTransfer.d.ts +6 -0
- package/dist/pages/conversation/setting/GroupTransfer.js +88 -0
- package/dist/pages/conversation/setting/OptionAvatars.d.ts +22 -0
- package/dist/pages/conversation/setting/OptionAvatars.js +152 -0
- package/dist/pages/conversation/setting/OptionCancelGroup.d.ts +6 -0
- package/dist/pages/conversation/setting/OptionCancelGroup.js +49 -0
- package/dist/pages/conversation/setting/OptionConversation.d.ts +19 -0
- package/dist/pages/conversation/setting/OptionConversation.js +71 -0
- package/dist/pages/conversation/setting/OptionGroup.d.ts +17 -0
- package/dist/pages/conversation/setting/OptionGroup.js +76 -0
- package/dist/pages/conversation/setting/OptionGroupManage.d.ts +6 -0
- package/dist/pages/conversation/setting/OptionGroupManage.js +68 -0
- package/dist/pages/conversation/setting/OptionGroupMoreMember.d.ts +4 -0
- package/dist/pages/conversation/setting/OptionGroupMoreMember.js +124 -0
- package/dist/pages/conversation/setting/OptionGroupNameOrNoticeEdit.d.ts +6 -0
- package/dist/pages/conversation/setting/OptionGroupNameOrNoticeEdit.js +149 -0
- package/dist/pages/conversation/setting/Setting.d.ts +6 -0
- package/dist/pages/conversation/setting/Setting.js +184 -0
- package/dist/pages/conversation/setting/SettingChatBg.d.ts +6 -0
- package/dist/pages/conversation/setting/SettingChatBg.js +95 -0
- package/dist/pages/index.d.ts +8 -0
- package/dist/pages/index.js +27 -0
- package/dist/pages/message/ChooseMember.d.ts +6 -0
- package/dist/pages/message/ChooseMember.js +185 -0
- package/dist/pages/message/MessageBackup/Bar.d.ts +8 -0
- package/dist/pages/message/MessageBackup/Bar.js +77 -0
- package/dist/pages/message/MessageBackup/MessageBackup.d.ts +10 -0
- package/dist/pages/message/MessageBackup/MessageBackup.js +133 -0
- package/dist/pages/message/MessageBackup/RestoreBackupPage.d.ts +6 -0
- package/dist/pages/message/MessageBackup/RestoreBackupPage.js +135 -0
- package/dist/pages/message/MessageBackup/StartBackupPage.d.ts +6 -0
- package/dist/pages/message/MessageBackup/StartBackupPage.js +135 -0
- package/dist/pages/message/MessageBackup/index.d.ts +3 -0
- package/dist/pages/message/MessageBackup/index.js +12 -0
- package/dist/pages/message/MessageBackup/utils.d.ts +46 -0
- package/dist/pages/message/MessageBackup/utils.js +239 -0
- package/dist/pages/message/MessageList.d.ts +6 -0
- package/dist/pages/message/MessageList.js +175 -0
- package/dist/pages/message/MessageRecord.d.ts +6 -0
- package/dist/pages/message/MessageRecord.js +97 -0
- package/dist/pages/message/components/BusiNotifyCard.d.ts +6 -0
- package/dist/pages/message/components/BusiNotifyCard.js +132 -0
- package/dist/pages/message/components/ChatBg.d.ts +7 -0
- package/dist/pages/message/components/ChatBg.js +65 -0
- package/dist/pages/message/components/MessageItem.d.ts +16 -0
- package/dist/pages/message/components/MessageItem.js +205 -0
- package/dist/pages/message/components/MessageItemQuote.d.ts +7 -0
- package/dist/pages/message/components/MessageItemQuote.js +83 -0
- package/dist/pages/message/components/MessageItemTips.d.ts +9 -0
- package/dist/pages/message/components/MessageItemTips.js +67 -0
- package/dist/pages/message/components/MessageOption.d.ts +11 -0
- package/dist/pages/message/components/MessageOption.js +360 -0
- package/dist/pages/message/components/MessagePayload.d.ts +14 -0
- package/dist/pages/message/components/MessagePayload.js +96 -0
- package/dist/pages/message/components/MessagePictureAlbum.d.ts +10 -0
- package/dist/pages/message/components/MessagePictureAlbum.js +105 -0
- package/dist/pages/message/components/MessageReceiptStatus.d.ts +6 -0
- package/dist/pages/message/components/MessageReceiptStatus.js +61 -0
- package/dist/pages/message/components/MessageUndo.d.ts +10 -0
- package/dist/pages/message/components/MessageUndo.js +75 -0
- package/dist/pages/message/components/MultipleBar/index.d.ts +5 -0
- package/dist/pages/message/components/MultipleBar/index.js +116 -0
- package/dist/pages/message/components/Payload/PayloadContact.d.ts +4 -0
- package/dist/pages/message/components/Payload/PayloadContact.js +86 -0
- package/dist/pages/message/components/Payload/PayloadFile.d.ts +4 -0
- package/dist/pages/message/components/Payload/PayloadFile.js +115 -0
- package/dist/pages/message/components/Payload/PayloadMultiple.d.ts +4 -0
- package/dist/pages/message/components/Payload/PayloadMultiple.js +102 -0
- package/dist/pages/message/components/Payload/PayloadNotify.d.ts +9 -0
- package/dist/pages/message/components/Payload/PayloadNotify.js +92 -0
- package/dist/pages/message/components/Payload/PayloadPicture.d.ts +7 -0
- package/dist/pages/message/components/Payload/PayloadPicture.js +69 -0
- package/dist/pages/message/components/Payload/PayloadShare.d.ts +4 -0
- package/dist/pages/message/components/Payload/PayloadShare.js +100 -0
- package/dist/pages/message/components/Payload/PayloadText.d.ts +4 -0
- package/dist/pages/message/components/Payload/PayloadText.js +128 -0
- package/dist/pages/message/components/Payload/PayloadVideo.d.ts +4 -0
- package/dist/pages/message/components/Payload/PayloadVideo.js +78 -0
- package/dist/pages/message/components/Payload/PayloadVoice.d.ts +6 -0
- package/dist/pages/message/components/Payload/PayloadVoice.js +155 -0
- package/dist/pages/message/components/Payload/PayloadWrapper.d.ts +12 -0
- package/dist/pages/message/components/Payload/PayloadWrapper.js +73 -0
- package/dist/pages/message/components/Payload/type.d.ts +9 -0
- package/dist/pages/message/components/Payload/type.js +2 -0
- package/dist/pages/message/components/ReceiptBack.d.ts +7 -0
- package/dist/pages/message/components/ReceiptBack.js +82 -0
- package/dist/pages/message/components/TextMixMessage.d.ts +9 -0
- package/dist/pages/message/components/TextMixMessage.js +62 -0
- package/dist/pages/message/components/TextMixQuote.d.ts +61 -0
- package/dist/pages/message/components/TextMixQuote.js +276 -0
- package/dist/pages/message/components/TextMixQuoteMessage.d.ts +14 -0
- package/dist/pages/message/components/TextMixQuoteMessage.js +74 -0
- package/dist/pages/message/components/UploadProgress.d.ts +9 -0
- package/dist/pages/message/components/UploadProgress.js +51 -0
- package/dist/pages/message/components/messageBar/EmojiPanel.d.ts +11 -0
- package/dist/pages/message/components/messageBar/EmojiPanel.js +101 -0
- package/dist/pages/message/components/messageBar/Icons.d.ts +18 -0
- package/dist/pages/message/components/messageBar/Icons.js +88 -0
- package/dist/pages/message/components/messageBar/MessageBar.d.ts +12 -0
- package/dist/pages/message/components/messageBar/MessageBar.js +273 -0
- package/dist/pages/message/components/messageBar/MessageInput.d.ts +21 -0
- package/dist/pages/message/components/messageBar/MessageInput.js +203 -0
- package/dist/pages/message/components/messageBar/OptionPanel.d.ts +8 -0
- package/dist/pages/message/components/messageBar/OptionPanel.js +240 -0
- package/dist/pages/message/components/messageBar/VoiceBar.d.ts +3 -0
- package/dist/pages/message/components/messageBar/VoiceBar.js +272 -0
- package/dist/pages/message/components/messageBar/index.d.ts +2 -0
- package/dist/pages/message/components/messageBar/index.js +23 -0
- package/dist/pages/message/message.routes.d.ts +2 -0
- package/dist/pages/message/message.routes.js +79 -0
- package/dist/pages/search/Search.d.ts +6 -0
- package/dist/pages/search/Search.js +84 -0
- package/dist/pages/search/SearchChatRecords.d.ts +3 -0
- package/dist/pages/search/SearchChatRecords.js +173 -0
- package/dist/pages/search/SearchFile.d.ts +3 -0
- package/dist/pages/search/SearchFile.js +202 -0
- package/dist/pages/search/SearchManager.d.ts +6 -0
- package/dist/pages/search/SearchManager.js +111 -0
- package/dist/pages/search/SearchPicturePage.d.ts +6 -0
- package/dist/pages/search/SearchPicturePage.js +56 -0
- package/dist/pages/search/components/ChatRecords.d.ts +6 -0
- package/dist/pages/search/components/ChatRecords.js +151 -0
- package/dist/pages/search/components/MyGroupChat.d.ts +6 -0
- package/dist/pages/search/components/MyGroupChat.js +128 -0
- package/dist/pages/search/components/PictureMulipleBar.d.ts +10 -0
- package/dist/pages/search/components/PictureMulipleBar.js +105 -0
- package/dist/pages/search/components/SearchFileList.d.ts +7 -0
- package/dist/pages/search/components/SearchFileList.js +173 -0
- package/dist/pages/search/components/SearchPictures.d.ts +8 -0
- package/dist/pages/search/components/SearchPictures.js +220 -0
- package/dist/pages/search/components/SearchShareLinkList.d.ts +7 -0
- package/dist/pages/search/components/SearchShareLinkList.js +112 -0
- package/dist/pages/search/components/SearchUser.d.ts +6 -0
- package/dist/pages/search/components/SearchUser.js +83 -0
- package/dist/pages/search/components/useSearchMessage.d.ts +11 -0
- package/dist/pages/search/components/useSearchMessage.js +68 -0
- package/dist/pages/search/search.routes.d.ts +2 -0
- package/dist/pages/search/search.routes.js +48 -0
- package/dist/pages/search/utils.d.ts +12 -0
- package/dist/pages/search/utils.js +42 -0
- package/dist/pages/types.d.ts +70 -0
- package/dist/pages/types.js +2 -0
- package/dist/slice/contact/contact.action.d.ts +1 -0
- package/dist/slice/contact/contact.action.js +2 -0
- package/dist/slice/contact/contact.slice.d.ts +12 -0
- package/dist/slice/contact/contact.slice.js +60 -0
- package/dist/slice/index.d.ts +9 -0
- package/dist/slice/index.js +15 -0
- package/dist/slice/panel/panel.slice.d.ts +8 -0
- package/dist/slice/panel/panel.slice.js +19 -0
- package/dist/slice/video/video.action.d.ts +5 -0
- package/dist/slice/video/video.action.js +65 -0
- package/dist/slice/video/video.slice.d.ts +17 -0
- package/dist/slice/video/video.slice.js +40 -0
- package/dist/utils/color.d.ts +1 -0
- package/dist/utils/color.js +9 -0
- package/dist/utils/common-action-sheet.d.ts +8 -0
- package/dist/utils/common-action-sheet.js +45 -0
- package/dist/utils/cookie.d.ts +1 -0
- package/dist/utils/cookie.js +29 -0
- package/dist/utils/emoji.d.ts +9 -0
- package/dist/utils/emoji.js +627 -0
- package/dist/utils/file-icon.d.ts +7 -0
- package/dist/utils/file-icon.js +80 -0
- package/dist/utils/file-operate.d.ts +1 -0
- package/dist/utils/file-operate.js +4 -0
- package/dist/utils/file.d.ts +23 -0
- package/dist/utils/file.js +255 -0
- package/dist/utils/golden-rectangle.d.ts +4 -0
- package/dist/utils/golden-rectangle.js +34 -0
- package/dist/utils/phone.d.ts +2 -0
- package/dist/utils/phone.js +24 -0
- package/dist/utils/request.d.ts +34 -0
- package/dist/utils/request.js +67 -0
- package/dist/utils/scroll.d.ts +1 -0
- package/dist/utils/scroll.js +12 -0
- package/dist/utils/summary.d.ts +2 -0
- package/dist/utils/summary.js +42 -0
- package/dist/utils/take-camera.d.ts +2 -0
- package/dist/utils/take-camera.js +41 -0
- package/dist/utils/text-mix.d.ts +9 -0
- package/dist/utils/text-mix.js +82 -0
- package/dist/utils/upload.d.ts +5 -0
- package/dist/utils/upload.js +80 -0
- package/package.json +79 -0
@@ -0,0 +1,135 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
27
|
+
};
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
29
|
+
const rn_ui_1 = require("@smart-link/rn-ui");
|
30
|
+
const react_1 = __importStar(require("react"));
|
31
|
+
const react_native_1 = require("react-native");
|
32
|
+
const utils_1 = require("./utils");
|
33
|
+
const MessageBackup_1 = require("./MessageBackup");
|
34
|
+
const default_assets_1 = require("../../../default-assets");
|
35
|
+
const useTranslation_1 = __importDefault(require("../../../hooks/useTranslation"));
|
36
|
+
const Bar_1 = __importDefault(require("./Bar"));
|
37
|
+
const { width } = react_native_1.Dimensions.get('window');
|
38
|
+
const StartBackupPage = ({ navigation }) => {
|
39
|
+
const { t, i18n } = (0, useTranslation_1.default)();
|
40
|
+
const [progress, setProgress] = (0, react_1.useState)(0);
|
41
|
+
const [paused, setPaused] = (0, react_1.useState)(false);
|
42
|
+
const messageBack = (0, react_1.useRef)();
|
43
|
+
(0, react_1.useEffect)(() => {
|
44
|
+
navigation.setOptions({
|
45
|
+
title: t('cloudBackup_startText'),
|
46
|
+
});
|
47
|
+
}, [t, navigation]);
|
48
|
+
(0, react_1.useEffect)(() => {
|
49
|
+
messageBack.current = new utils_1.MessageBackupUtils(p => {
|
50
|
+
setProgress(p);
|
51
|
+
});
|
52
|
+
messageBack.current.start();
|
53
|
+
return () => {
|
54
|
+
var _a;
|
55
|
+
(_a = messageBack.current) === null || _a === void 0 ? void 0 : _a.destroy();
|
56
|
+
};
|
57
|
+
}, []);
|
58
|
+
const cancel = () => {
|
59
|
+
var _a;
|
60
|
+
(_a = messageBack.current) === null || _a === void 0 ? void 0 : _a.cancel();
|
61
|
+
navigation.goBack();
|
62
|
+
};
|
63
|
+
const pause = () => {
|
64
|
+
var _a;
|
65
|
+
(_a = messageBack.current) === null || _a === void 0 ? void 0 : _a.pause();
|
66
|
+
setPaused(true);
|
67
|
+
};
|
68
|
+
const resume = () => {
|
69
|
+
var _a;
|
70
|
+
(_a = messageBack.current) === null || _a === void 0 ? void 0 : _a.resume();
|
71
|
+
setPaused(false);
|
72
|
+
};
|
73
|
+
const finished = progress >= 100;
|
74
|
+
return (<rn_ui_1.NavigationPage noPadding>
|
75
|
+
<react_native_1.View style={styles.container}>
|
76
|
+
<react_native_1.Image style={styles.img} source={default_assets_1.messageBackupImg.cloud_begin}/>
|
77
|
+
<react_native_1.View style={styles.progress}>
|
78
|
+
{!finished ? (<react_native_1.Text style={styles.text}>{t('cloudBackup_inBackup')}</react_native_1.Text>) : (<react_native_1.Text style={styles.text}>{t('cloudBackup_completed')}</react_native_1.Text>)}
|
79
|
+
<react_native_1.View style={styles.progressBar}>
|
80
|
+
<Bar_1.default width={(0, rn_ui_1.dp)(width - 80)} progress={progress}/>
|
81
|
+
</react_native_1.View>
|
82
|
+
<react_native_1.Text style={styles.progressText}>{progress}%</react_native_1.Text>
|
83
|
+
</react_native_1.View>
|
84
|
+
{!finished && !paused && (<rn_ui_1.Button style={styles.button} type={'primary'} onPress={pause}>
|
85
|
+
{t('cloudBackup_pause')}
|
86
|
+
</rn_ui_1.Button>)}
|
87
|
+
{!finished && paused && (<rn_ui_1.Button style={styles.button} type={'primary'} onPress={resume}>
|
88
|
+
{t('cloudBackup_resume')}
|
89
|
+
</rn_ui_1.Button>)}
|
90
|
+
{!finished && (<rn_ui_1.Button style={styles.button} danger onPress={cancel}>
|
91
|
+
{t('cancel')}
|
92
|
+
</rn_ui_1.Button>)}
|
93
|
+
|
94
|
+
{finished && (<rn_ui_1.Button style={styles.button} type="default" onPress={() => {
|
95
|
+
navigation.goBack();
|
96
|
+
}}>
|
97
|
+
{i18n.t('back')}
|
98
|
+
</rn_ui_1.Button>)}
|
99
|
+
</react_native_1.View>
|
100
|
+
</rn_ui_1.NavigationPage>);
|
101
|
+
};
|
102
|
+
const styles = react_native_1.StyleSheet.create({
|
103
|
+
container: {
|
104
|
+
flex: 1,
|
105
|
+
alignItems: 'center',
|
106
|
+
paddingTop: (0, rn_ui_1.dp)(20),
|
107
|
+
width,
|
108
|
+
},
|
109
|
+
img: (0, MessageBackup_1.getImageStyle)(default_assets_1.messageBackupImg.cloud_begin, 0.8),
|
110
|
+
text: {
|
111
|
+
textAlign: 'center',
|
112
|
+
marginVertical: (0, rn_ui_1.dp)(8),
|
113
|
+
},
|
114
|
+
button: {
|
115
|
+
marginVertical: (0, rn_ui_1.dp)(8),
|
116
|
+
width: (0, rn_ui_1.dp)(width - 40),
|
117
|
+
},
|
118
|
+
progress: {
|
119
|
+
paddingTop: (0, rn_ui_1.dp)(30),
|
120
|
+
paddingBottom: (0, rn_ui_1.dp)(20),
|
121
|
+
},
|
122
|
+
progressBar: {
|
123
|
+
flexDirection: 'row',
|
124
|
+
alignItems: 'center',
|
125
|
+
},
|
126
|
+
percent: {
|
127
|
+
marginLeft: (0, rn_ui_1.dp)(4),
|
128
|
+
fontSize: (0, rn_ui_1.dp)(14),
|
129
|
+
},
|
130
|
+
progressText: {
|
131
|
+
fontSize: (0, rn_ui_1.dp)(14),
|
132
|
+
textAlign: 'center',
|
133
|
+
},
|
134
|
+
});
|
135
|
+
exports.default = StartBackupPage;
|
@@ -0,0 +1,12 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.RestoreBackupPage = exports.StartBackupPage = exports.default = void 0;
|
7
|
+
var MessageBackup_1 = require("./MessageBackup");
|
8
|
+
Object.defineProperty(exports, "default", { enumerable: true, get: function () { return __importDefault(MessageBackup_1).default; } });
|
9
|
+
var StartBackupPage_1 = require("./StartBackupPage");
|
10
|
+
Object.defineProperty(exports, "StartBackupPage", { enumerable: true, get: function () { return __importDefault(StartBackupPage_1).default; } });
|
11
|
+
var RestoreBackupPage_1 = require("./RestoreBackupPage");
|
12
|
+
Object.defineProperty(exports, "RestoreBackupPage", { enumerable: true, get: function () { return __importDefault(RestoreBackupPage_1).default; } });
|
@@ -0,0 +1,46 @@
|
|
1
|
+
import { CancelTokenSource } from "axios";
|
2
|
+
declare class Queue {
|
3
|
+
queue: TaskItem[];
|
4
|
+
constructor();
|
5
|
+
push(item: TaskItem): void;
|
6
|
+
pop(): TaskItem | undefined;
|
7
|
+
unshift(item: TaskItem): void;
|
8
|
+
isEmpty(): boolean;
|
9
|
+
}
|
10
|
+
declare class BaseUtils {
|
11
|
+
state: 'idle' | 'running' | 'paused' | 'canceled' | 'destroyed';
|
12
|
+
current?: TaskItem | null;
|
13
|
+
queue: Queue;
|
14
|
+
complete: number;
|
15
|
+
pageSize: number;
|
16
|
+
total: number;
|
17
|
+
batchId?: string;
|
18
|
+
progressCallback: (progress: number) => void;
|
19
|
+
constructor(callback: (progress: number) => void);
|
20
|
+
pause(): void;
|
21
|
+
start(): Promise<void>;
|
22
|
+
next(): Promise<void>;
|
23
|
+
resume(): Promise<void>;
|
24
|
+
cancel(): void;
|
25
|
+
destroy(): void;
|
26
|
+
}
|
27
|
+
declare class TaskItem {
|
28
|
+
cancelToken: CancelTokenSource;
|
29
|
+
limit: number;
|
30
|
+
offset: number;
|
31
|
+
constructor(limit: number, offset: number);
|
32
|
+
execute(callback: (progress: number, batchId?: string) => void, batchId?: string): Promise<void>;
|
33
|
+
cancel(): Promise<void>;
|
34
|
+
}
|
35
|
+
export declare class MessageBackupUtils extends BaseUtils {
|
36
|
+
constructor(callback: (progress: number) => void);
|
37
|
+
pause(): void;
|
38
|
+
start(): Promise<void>;
|
39
|
+
cancel(): Promise<void>;
|
40
|
+
}
|
41
|
+
export declare class MessageRestoreUtils extends BaseUtils {
|
42
|
+
constructor(callback: (progress: number) => void);
|
43
|
+
pause(): void;
|
44
|
+
start(): Promise<void>;
|
45
|
+
}
|
46
|
+
export {};
|
@@ -0,0 +1,239 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
+
});
|
10
|
+
};
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
13
|
+
};
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
15
|
+
exports.MessageRestoreUtils = exports.MessageBackupUtils = void 0;
|
16
|
+
const axios_1 = __importDefault(require("axios"));
|
17
|
+
const init_1 = require("../../../init");
|
18
|
+
const backup_1 = require("../../../api/backup");
|
19
|
+
class Queue {
|
20
|
+
constructor() {
|
21
|
+
this.queue = [];
|
22
|
+
}
|
23
|
+
push(item) {
|
24
|
+
this.queue.push(item);
|
25
|
+
}
|
26
|
+
pop() {
|
27
|
+
return this.queue.shift();
|
28
|
+
}
|
29
|
+
unshift(item) {
|
30
|
+
this.queue.unshift(item);
|
31
|
+
}
|
32
|
+
isEmpty() {
|
33
|
+
return this.queue.length === 0;
|
34
|
+
}
|
35
|
+
}
|
36
|
+
class BaseUtils {
|
37
|
+
constructor(callback) {
|
38
|
+
this.current = null;
|
39
|
+
this.state = 'idle';
|
40
|
+
this.current = null;
|
41
|
+
this.queue = new Queue();
|
42
|
+
this.complete = 0;
|
43
|
+
this.pageSize = 35;
|
44
|
+
this.progressCallback = callback;
|
45
|
+
this.total = 0;
|
46
|
+
this.batchId = undefined;
|
47
|
+
}
|
48
|
+
pause() {
|
49
|
+
this.state = 'paused';
|
50
|
+
if (this.current) {
|
51
|
+
this.current.cancel();
|
52
|
+
this.queue.unshift(new TaskItem(this.pageSize, this.current.offset));
|
53
|
+
}
|
54
|
+
}
|
55
|
+
start() {
|
56
|
+
return __awaiter(this, void 0, void 0, function* () {
|
57
|
+
});
|
58
|
+
}
|
59
|
+
next() {
|
60
|
+
return __awaiter(this, void 0, void 0, function* () {
|
61
|
+
if (this.state === 'running') {
|
62
|
+
this.current = this.queue.pop();
|
63
|
+
if (this.current) {
|
64
|
+
yield this.current.execute((count, batchId) => {
|
65
|
+
this.complete += count;
|
66
|
+
this.batchId = batchId;
|
67
|
+
this.progressCallback(Math.min(Number((this.complete / this.total * 100).toFixed(2)), 100));
|
68
|
+
}, this.batchId);
|
69
|
+
yield this.next();
|
70
|
+
}
|
71
|
+
else {
|
72
|
+
this.state = 'idle';
|
73
|
+
}
|
74
|
+
}
|
75
|
+
});
|
76
|
+
}
|
77
|
+
resume() {
|
78
|
+
return __awaiter(this, void 0, void 0, function* () {
|
79
|
+
this.state = 'running';
|
80
|
+
yield this.next();
|
81
|
+
});
|
82
|
+
}
|
83
|
+
cancel() {
|
84
|
+
this.state = 'canceled';
|
85
|
+
if (this.current) {
|
86
|
+
this.current.cancel();
|
87
|
+
}
|
88
|
+
}
|
89
|
+
destroy() {
|
90
|
+
this.state = 'destroyed';
|
91
|
+
if (this.current) {
|
92
|
+
this.current.cancel();
|
93
|
+
}
|
94
|
+
this.current = null;
|
95
|
+
}
|
96
|
+
}
|
97
|
+
class TaskItem {
|
98
|
+
constructor(limit, offset) {
|
99
|
+
this.cancelToken = axios_1.default.CancelToken.source();
|
100
|
+
this.limit = limit;
|
101
|
+
this.offset = offset;
|
102
|
+
}
|
103
|
+
execute(callback, batchId) {
|
104
|
+
return __awaiter(this, void 0, void 0, function* () {
|
105
|
+
});
|
106
|
+
}
|
107
|
+
cancel() {
|
108
|
+
return __awaiter(this, void 0, void 0, function* () {
|
109
|
+
this.cancelToken.cancel();
|
110
|
+
});
|
111
|
+
}
|
112
|
+
}
|
113
|
+
class BackupTaskItem extends TaskItem {
|
114
|
+
constructor(limit, offset, messageSeq) {
|
115
|
+
super(limit, offset);
|
116
|
+
this.limit = limit;
|
117
|
+
this.offset = offset;
|
118
|
+
this.messageSeq = messageSeq;
|
119
|
+
}
|
120
|
+
execute(callback, batchId) {
|
121
|
+
return __awaiter(this, void 0, void 0, function* () {
|
122
|
+
const { data, lastMessageSeq } = yield (0, init_1.getImManager)().db.selectMessageForBackup({
|
123
|
+
messageSeq: this.messageSeq,
|
124
|
+
limit: this.limit,
|
125
|
+
offset: this.offset
|
126
|
+
});
|
127
|
+
let prevCount = Math.ceil(data.length / 5);
|
128
|
+
callback(prevCount, batchId);
|
129
|
+
const { data: newBatchId } = yield (0, backup_1.uploadMessage)({ batchId: batchId, lastMessageSeq, messages: data }, { cancelToken: this.cancelToken.token });
|
130
|
+
callback(data.length - prevCount, newBatchId || batchId);
|
131
|
+
});
|
132
|
+
}
|
133
|
+
}
|
134
|
+
class MessageBackupUtils extends BaseUtils {
|
135
|
+
constructor(callback) {
|
136
|
+
super(callback);
|
137
|
+
}
|
138
|
+
pause() {
|
139
|
+
this.state = 'paused';
|
140
|
+
if (this.current) {
|
141
|
+
this.current.cancel();
|
142
|
+
this.queue.unshift(new BackupTaskItem(this.pageSize, this.current.offset));
|
143
|
+
}
|
144
|
+
}
|
145
|
+
start() {
|
146
|
+
return __awaiter(this, void 0, void 0, function* () {
|
147
|
+
this.state = 'running';
|
148
|
+
// 查询最近一次备份的消息序列
|
149
|
+
const { data: messageSeq } = yield (0, backup_1.queryMyLastBackupMessageSeq)();
|
150
|
+
console.log('LastBackup messageSeq: ', messageSeq);
|
151
|
+
const total = yield (0, init_1.getImManager)().db.countMessageAfterSeq(messageSeq);
|
152
|
+
console.log('total', total);
|
153
|
+
this.total = total;
|
154
|
+
// 没有需要备份的消息
|
155
|
+
if (this.total === 0) {
|
156
|
+
this.state = 'idle';
|
157
|
+
this.progressCallback(100);
|
158
|
+
return;
|
159
|
+
}
|
160
|
+
Array.from({ length: Math.ceil(total / this.pageSize) }, (v, i) => i).forEach(i => {
|
161
|
+
this.queue.push(new BackupTaskItem(this.pageSize, i * this.pageSize, messageSeq));
|
162
|
+
});
|
163
|
+
yield this.next();
|
164
|
+
});
|
165
|
+
}
|
166
|
+
cancel() {
|
167
|
+
const _super = Object.create(null, {
|
168
|
+
cancel: { get: () => super.cancel }
|
169
|
+
});
|
170
|
+
return __awaiter(this, void 0, void 0, function* () {
|
171
|
+
_super.cancel.call(this);
|
172
|
+
yield (0, backup_1.cancelBackupMessage)(this.batchId);
|
173
|
+
});
|
174
|
+
}
|
175
|
+
}
|
176
|
+
exports.MessageBackupUtils = MessageBackupUtils;
|
177
|
+
class RestoreTaskItem extends TaskItem {
|
178
|
+
constructor(pageNum, pageSize) {
|
179
|
+
super(pageNum, pageSize);
|
180
|
+
this.pageNum = pageNum;
|
181
|
+
this.pageSize = pageSize;
|
182
|
+
}
|
183
|
+
execute(callback) {
|
184
|
+
return __awaiter(this, void 0, void 0, function* () {
|
185
|
+
const { data: { records: [messages] } } = yield (0, backup_1.queryMyBackMessage)({ pageNum: this.pageNum, pageSize: this.pageSize }, { cancelToken: this.cancelToken.token });
|
186
|
+
const imManager = (0, init_1.getImManager)();
|
187
|
+
yield Promise.all(messages.map(item => {
|
188
|
+
return (() => __awaiter(this, void 0, void 0, function* () {
|
189
|
+
const message = JSON.parse(item);
|
190
|
+
const exist = yield imManager.db.existMessage(message.messageSeq);
|
191
|
+
if (!exist) {
|
192
|
+
console.log('insertMessage: ', message);
|
193
|
+
try {
|
194
|
+
if (message.payload.localPath) {
|
195
|
+
message.payload.localPath = undefined;
|
196
|
+
}
|
197
|
+
yield imManager.db.insertMessage(message);
|
198
|
+
}
|
199
|
+
catch (e) {
|
200
|
+
console.log('insertMessage error: ', e);
|
201
|
+
}
|
202
|
+
}
|
203
|
+
callback(1);
|
204
|
+
return message;
|
205
|
+
}))();
|
206
|
+
}));
|
207
|
+
});
|
208
|
+
}
|
209
|
+
}
|
210
|
+
class MessageRestoreUtils extends BaseUtils {
|
211
|
+
constructor(callback) {
|
212
|
+
super(callback);
|
213
|
+
// 默认每页1个批次的多条数据,按批次处理进度
|
214
|
+
this.pageSize = 1;
|
215
|
+
}
|
216
|
+
pause() {
|
217
|
+
this.state = 'paused';
|
218
|
+
if (this.current) {
|
219
|
+
this.current.cancel();
|
220
|
+
this.queue.unshift(new RestoreTaskItem(this.pageSize, this.current.offset));
|
221
|
+
}
|
222
|
+
}
|
223
|
+
start() {
|
224
|
+
return __awaiter(this, void 0, void 0, function* () {
|
225
|
+
this.state = 'running';
|
226
|
+
const { data: { total, } } = yield (0, backup_1.queryMyBackMessage)({ pageNum: 1, pageSize: 1 });
|
227
|
+
console.log('total: ', total);
|
228
|
+
this.total = total;
|
229
|
+
const length = Math.ceil(this.total / this.pageSize);
|
230
|
+
console.log('pages:', length);
|
231
|
+
Array.from({ length }, (v, i) => i).forEach(i => {
|
232
|
+
this.queue.push(new RestoreTaskItem(length - i, this.pageSize));
|
233
|
+
});
|
234
|
+
console.log('queue:', this.queue);
|
235
|
+
yield this.next();
|
236
|
+
});
|
237
|
+
}
|
238
|
+
}
|
239
|
+
exports.MessageRestoreUtils = MessageRestoreUtils;
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import { NativeStackScreenProps } from '@react-navigation/native-stack/lib/typescript/src/types';
|
2
|
+
import React from 'react';
|
3
|
+
import { IMPageParamList } from '../../pages';
|
4
|
+
type MessageListProps = NativeStackScreenProps<IMPageParamList, 'MessageList'>;
|
5
|
+
declare const MessageList: ({ navigation }: MessageListProps) => React.JSX.Element;
|
6
|
+
export default MessageList;
|
@@ -0,0 +1,175 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
27
|
+
};
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
29
|
+
const im_base_1 = require("@smart-link/im-base");
|
30
|
+
const rn_ui_1 = require("@smart-link/rn-ui");
|
31
|
+
const react_1 = __importStar(require("react"));
|
32
|
+
const react_native_1 = require("react-native");
|
33
|
+
const FontAwesome5_1 = __importDefault(require("react-native-vector-icons/FontAwesome5"));
|
34
|
+
const useImSelector_1 = require("../../hooks/useImSelector");
|
35
|
+
const useTranslation_1 = __importDefault(require("../../hooks/useTranslation"));
|
36
|
+
const init_1 = require("../../init");
|
37
|
+
const MessageBar_1 = __importDefault(require("./components/messageBar/MessageBar"));
|
38
|
+
const MessageItem_1 = __importDefault(require("./components/MessageItem"));
|
39
|
+
const MessageOption_1 = __importDefault(require("./components/MessageOption"));
|
40
|
+
const VideoPlayer_1 = __importDefault(require("../../components/VideoPlayer"));
|
41
|
+
const MessageItemQuote_1 = __importDefault(require("../../pages/message/components/MessageItemQuote"));
|
42
|
+
const MessagePictureAlbum_1 = __importDefault(require("./components/MessagePictureAlbum"));
|
43
|
+
const MultipleBar_1 = __importDefault(require("./components/MultipleBar"));
|
44
|
+
const ChatBg_1 = __importDefault(require("./components/ChatBg"));
|
45
|
+
const ahooks_1 = require("ahooks");
|
46
|
+
const MessageItemTips_1 = __importDefault(require("./components/MessageItemTips"));
|
47
|
+
const MessageList = ({ navigation }) => {
|
48
|
+
const { t } = (0, useTranslation_1.default)();
|
49
|
+
const messageListRef = (0, react_1.useRef)(null);
|
50
|
+
const { currentConversation } = (0, useImSelector_1.useConversation)();
|
51
|
+
const { messages, rangeList, quote, tips, isMultiple, multipleSelect } = (0, useImSelector_1.useMessage)();
|
52
|
+
const { user } = (0, useImSelector_1.useAuth)();
|
53
|
+
const bar = (0, react_1.useRef)(null);
|
54
|
+
const [showAlbum, setShowAlbum] = (0, react_1.useState)(false);
|
55
|
+
const [targetMessageSeq, setTargetMessageSeq] = (0, react_1.useState)('');
|
56
|
+
const [selectMessage, setSelectMessage] = (0, react_1.useState)();
|
57
|
+
const [nativeEvent, setNativeEvent] = (0, react_1.useState)();
|
58
|
+
const isB2C = (currentConversation === null || currentConversation === void 0 ? void 0 : currentConversation.type) === im_base_1.ConversationType.B2C;
|
59
|
+
(0, react_1.useEffect)(() => {
|
60
|
+
console.log('[进入会话]: ', currentConversation);
|
61
|
+
if (currentConversation) {
|
62
|
+
navigation.setOptions({
|
63
|
+
headerLeft: isMultiple
|
64
|
+
? () => (<react_native_1.TouchableOpacity onPress={() => {
|
65
|
+
(0, init_1.getImManager)().store.dispatch(im_base_1.MessagePanelActions.cancelMultipleSelect());
|
66
|
+
}}>
|
67
|
+
<react_native_1.Text style={{ color: '#fff' }}>{t('cancel')}</react_native_1.Text>
|
68
|
+
</react_native_1.TouchableOpacity>)
|
69
|
+
: rn_ui_1.HeaderBackButton,
|
70
|
+
headerTitle: ({ tintColor }) => (<react_native_1.View style={{ width: (0, rn_ui_1.dp)(220) }}>
|
71
|
+
<react_native_1.Text numberOfLines={1} style={{ color: tintColor, fontSize: (0, rn_ui_1.dp)(18), textAlign: 'center' }}>{currentConversation.name}</react_native_1.Text>
|
72
|
+
</react_native_1.View>),
|
73
|
+
headerRight: ({ tintColor }) => (<react_native_1.TouchableOpacity onPress={() => {
|
74
|
+
navigation.navigate('ConversationSetting');
|
75
|
+
}} style={{ width: (0, rn_ui_1.dp)(40), justifyContent: 'center', alignItems: 'center' }}>
|
76
|
+
<FontAwesome5_1.default name="ellipsis-h" color={tintColor} size={(0, rn_ui_1.dp)(18)}/>
|
77
|
+
</react_native_1.TouchableOpacity>),
|
78
|
+
});
|
79
|
+
}
|
80
|
+
let remover = navigation.addListener('beforeRemove', e => {
|
81
|
+
const imManager = (0, init_1.getImManager)();
|
82
|
+
if (isMultiple) {
|
83
|
+
e.preventDefault();
|
84
|
+
imManager.store.dispatch(im_base_1.MessagePanelActions.cancelMultipleSelect());
|
85
|
+
}
|
86
|
+
else {
|
87
|
+
console.log('[离开会话]: ');
|
88
|
+
imManager.store.dispatch(im_base_1.MessagePanelActions.saveDraftText(imManager));
|
89
|
+
react_native_1.InteractionManager.runAfterInteractions(() => {
|
90
|
+
imManager.leaveConversation();
|
91
|
+
});
|
92
|
+
}
|
93
|
+
});
|
94
|
+
return () => {
|
95
|
+
remover();
|
96
|
+
};
|
97
|
+
}, [isMultiple, navigation, currentConversation]);
|
98
|
+
(0, react_1.useEffect)(() => {
|
99
|
+
(0, init_1.getImManager)().setFlatListRef(messageListRef);
|
100
|
+
(0, init_1.getImManager)().setInputRef(bar);
|
101
|
+
}, []);
|
102
|
+
const onLongPressPopover = (0, react_1.useCallback)((message, nativeEvent) => {
|
103
|
+
setNativeEvent(nativeEvent);
|
104
|
+
setSelectMessage(message);
|
105
|
+
}, []);
|
106
|
+
const onLayoutItem = (0, ahooks_1.useMemoizedFn)((message, e) => {
|
107
|
+
if (rangeList.length > 0 && message.messageSeq === (tips === null || tips === void 0 ? void 0 : tips.messageSeq)) {
|
108
|
+
const imManager = (0, init_1.getImManager)();
|
109
|
+
imManager.store.dispatch(im_base_1.MessagePanelActions.onRangeLayout(imManager));
|
110
|
+
}
|
111
|
+
});
|
112
|
+
const onPressPopover = (0, react_1.useCallback)((message, nativeEvent) => {
|
113
|
+
if (message.payloadType === im_base_1.PayloadType.PICTURE) {
|
114
|
+
setNativeEvent(nativeEvent);
|
115
|
+
setShowAlbum(true);
|
116
|
+
setTargetMessageSeq(message.messageSeq);
|
117
|
+
}
|
118
|
+
}, []);
|
119
|
+
const onKeyboardAt = () => {
|
120
|
+
if ((currentConversation === null || currentConversation === void 0 ? void 0 : currentConversation.type) === im_base_1.ConversationType.C2G) {
|
121
|
+
react_native_1.Keyboard.dismiss();
|
122
|
+
navigation.navigate('ChooseMember', { atOther: true });
|
123
|
+
}
|
124
|
+
};
|
125
|
+
return (<rn_ui_1.NavigationPage noPadding>
|
126
|
+
{(currentConversation === null || currentConversation === void 0 ? void 0 : currentConversation.type) === im_base_1.ConversationType.B2C && (<react_native_1.View style={{ padding: (0, rn_ui_1.dp)(8), backgroundColor: '#f5f5f5', elevation: 1 }}>
|
127
|
+
<rn_ui_1.Input shape="normal" placeholder={t('search')} wrapStyle={{ height: (0, rn_ui_1.dp)(40) }}/>
|
128
|
+
</react_native_1.View>)}
|
129
|
+
<ChatBg_1.default fileId={currentConversation === null || currentConversation === void 0 ? void 0 : currentConversation.imageBackground}>
|
130
|
+
<>
|
131
|
+
<react_native_1.FlatList ref={messageListRef} inverted contentContainerStyle={{
|
132
|
+
paddingVertical: (0, rn_ui_1.dp)(20),
|
133
|
+
justifyContent: 'flex-end',
|
134
|
+
flexGrow: 1,
|
135
|
+
overflow: 'scroll',
|
136
|
+
}} numColumns={1} onEndReachedThreshold={0.1} keyboardShouldPersistTaps={'handled'} keyExtractor={item => item.messageSeq} renderItem={({ item, index }) => {
|
137
|
+
return (<MessageItem_1.default message={item} conversation={currentConversation} mine={item.messageFrom === user.userId} showTimeLine={(0, im_base_1.showTimeLine)(item, index, messages)} isMultiple={isMultiple} multipleSelect={multipleSelect} onLongPressPopover={onLongPressPopover} onPressPopover={onPressPopover} onLayoutItem={onLayoutItem}/>);
|
138
|
+
}} data={messages} onEndReached={() => {
|
139
|
+
(0, init_1.getImManager)()
|
140
|
+
.loadBeforeMessages(currentConversation === null || currentConversation === void 0 ? void 0 : currentConversation.id, { limit: 15 })
|
141
|
+
.then(() => {
|
142
|
+
console.log('loaded');
|
143
|
+
});
|
144
|
+
}} refreshing={false} onRefresh={() => {
|
145
|
+
(0, init_1.getImManager)()
|
146
|
+
.loadAfterMessages(currentConversation === null || currentConversation === void 0 ? void 0 : currentConversation.id, { limit: 15 })
|
147
|
+
.then(() => {
|
148
|
+
console.log('loaded last');
|
149
|
+
});
|
150
|
+
}} onTouchStart={() => {
|
151
|
+
var _a;
|
152
|
+
(_a = bar.current) === null || _a === void 0 ? void 0 : _a.reset();
|
153
|
+
}} onLayout={() => {
|
154
|
+
}}/>
|
155
|
+
{quote && (<MessageItemQuote_1.default {...quote} onDeleteQuote={() => {
|
156
|
+
(0, init_1.getImManager)().store.dispatch(im_base_1.MessageActions.setQuote(null));
|
157
|
+
}}/>)}
|
158
|
+
</>
|
159
|
+
</ChatBg_1.default>
|
160
|
+
|
161
|
+
{!isB2C && (isMultiple ? <MultipleBar_1.default /> : <MessageBar_1.default ref={bar} onKeyboardAt={onKeyboardAt}/>)}
|
162
|
+
|
163
|
+
{tips && tips.type === im_base_1.TipsType.AT && (<MessageItemTips_1.default {...tips}/>)}
|
164
|
+
<VideoPlayer_1.default />
|
165
|
+
<MessageOption_1.default visible={Boolean(selectMessage)} nativeEvent={nativeEvent} message={selectMessage} onClose={() => {
|
166
|
+
setNativeEvent(undefined);
|
167
|
+
setSelectMessage(undefined);
|
168
|
+
}}/>
|
169
|
+
|
170
|
+
<MessagePictureAlbum_1.default visible={showAlbum} messages={messages} messageSeq={targetMessageSeq} onClose={() => {
|
171
|
+
setShowAlbum(false);
|
172
|
+
}}/>
|
173
|
+
</rn_ui_1.NavigationPage>);
|
174
|
+
};
|
175
|
+
exports.default = MessageList;
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { NativeStackScreenProps } from '@react-navigation/native-stack';
|
3
|
+
import { IMPageParamList } from '../types';
|
4
|
+
type MessageRecordProps = NativeStackScreenProps<IMPageParamList, 'MessageRecord'>;
|
5
|
+
declare const MessageRecord: ({ navigation, route: { params } }: MessageRecordProps) => React.JSX.Element;
|
6
|
+
export default MessageRecord;
|