@messenger-box/platform-mobile 10.0.2-alpha.5 → 10.0.3-alpha.5
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/CHANGELOG.md +8 -0
- package/lib/compute.js +14 -14
- package/lib/compute.js.map +1 -1
- package/lib/index.js.map +1 -1
- package/lib/module.js +1 -2
- package/lib/module.js.map +1 -1
- package/lib/screens/inbox/DialogMessages.js +44 -20
- package/lib/screens/inbox/DialogMessages.js.map +1 -1
- package/lib/screens/inbox/DialogThreadMessages.js +13 -48
- package/lib/screens/inbox/DialogThreadMessages.js.map +1 -1
- package/lib/screens/inbox/DialogThreads.js +13 -70
- package/lib/screens/inbox/DialogThreads.js.map +1 -1
- package/lib/screens/inbox/Inbox.js +18 -9
- package/lib/screens/inbox/Inbox.js.map +1 -1
- package/lib/screens/inbox/components/CachedImage/consts.js.map +1 -1
- package/lib/screens/inbox/components/CachedImage/index.js +41 -27
- package/lib/screens/inbox/components/CachedImage/index.js.map +1 -1
- package/lib/screens/inbox/components/DialogsListItem.js +96 -146
- package/lib/screens/inbox/components/DialogsListItem.js.map +1 -1
- package/lib/screens/inbox/components/ServiceDialogsListItem.js +95 -148
- package/lib/screens/inbox/components/ServiceDialogsListItem.js.map +1 -1
- package/lib/screens/inbox/components/SlackMessageContainer/ImageViewerModal.js +37 -51
- package/lib/screens/inbox/components/SlackMessageContainer/ImageViewerModal.js.map +1 -1
- package/lib/screens/inbox/components/SlackMessageContainer/SlackBubble.js +113 -97
- package/lib/screens/inbox/components/SlackMessageContainer/SlackBubble.js.map +1 -1
- package/lib/screens/inbox/components/SlackMessageContainer/SlackMessage.js +50 -42
- package/lib/screens/inbox/components/SlackMessageContainer/SlackMessage.js.map +1 -1
- package/lib/screens/inbox/components/ThreadsViewItem.js +41 -149
- package/lib/screens/inbox/components/ThreadsViewItem.js.map +1 -1
- package/lib/screens/inbox/config/config.js +8 -10
- package/lib/screens/inbox/config/config.js.map +1 -1
- package/lib/screens/inbox/containers/ConversationView.js +357 -501
- package/lib/screens/inbox/containers/ConversationView.js.map +1 -1
- package/lib/screens/inbox/containers/Dialogs.js +49 -140
- package/lib/screens/inbox/containers/Dialogs.js.map +1 -1
- package/lib/screens/inbox/containers/ThreadConversationView.js +297 -400
- package/lib/screens/inbox/containers/ThreadConversationView.js.map +1 -1
- package/lib/screens/inbox/containers/ThreadsView.js +83 -190
- package/lib/screens/inbox/containers/ThreadsView.js.map +1 -1
- package/package.json +4 -4
- package/rollup.config.mjs +5 -1
- package/lib/compute.d.ts +0 -5
- package/lib/index.d.ts +0 -4
- package/lib/module.d.ts +0 -3
- package/lib/navigation/InboxNavigation.d.ts +0 -2
- package/lib/navigation/index.d.ts +0 -1
- package/lib/screens/inbox/DialogMessages.d.ts +0 -8
- package/lib/screens/inbox/DialogThreadMessages.d.ts +0 -8
- package/lib/screens/inbox/DialogThreads.d.ts +0 -7
- package/lib/screens/inbox/Inbox.d.ts +0 -2
- package/lib/screens/inbox/components/CachedImage/consts.d.ts +0 -2
- package/lib/screens/inbox/components/CachedImage/index.d.ts +0 -8
- package/lib/screens/inbox/components/DialogsHeader.d.ts +0 -8
- package/lib/screens/inbox/components/DialogsListItem.d.ts +0 -19
- package/lib/screens/inbox/components/ServiceDialogsListItem.d.ts +0 -21
- package/lib/screens/inbox/components/SlackMessageContainer/ImageViewerModal.d.ts +0 -3
- package/lib/screens/inbox/components/SlackMessageContainer/SlackBubble.d.ts +0 -34
- package/lib/screens/inbox/components/SlackMessageContainer/SlackMessage.d.ts +0 -25
- package/lib/screens/inbox/components/SlackMessageContainer/index.d.ts +0 -3
- package/lib/screens/inbox/components/SupportServiceDialogsListItem.d.ts +0 -21
- package/lib/screens/inbox/components/ThreadsViewItem.d.ts +0 -20
- package/lib/screens/inbox/config/config.d.ts +0 -11
- package/lib/screens/inbox/config/index.d.ts +0 -1
- package/lib/screens/inbox/containers/ConversationView.d.ts +0 -11
- package/lib/screens/inbox/containers/Dialogs.d.ts +0 -7
- package/lib/screens/inbox/containers/SupportServiceDialogs.d.ts +0 -6
- package/lib/screens/inbox/containers/ThreadConversationView.d.ts +0 -11
- package/lib/screens/inbox/containers/ThreadsView.d.ts +0 -13
- package/lib/screens/index.d.ts +0 -4
|
@@ -1,72 +1,100 @@
|
|
|
1
|
-
import
|
|
1
|
+
import React__default from'react';import {StyleSheet,TouchableHighlight,View,Text,Platform,Dimensions}from'react-native';import {MessageText,Time,utils}from'react-native-gifted-chat';import CachedImage from'../CachedImage/index.js';var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
var __objRest = (source, exclude) => {
|
|
21
|
+
var target = {};
|
|
22
|
+
for (var prop in source)
|
|
23
|
+
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
24
|
+
target[prop] = source[prop];
|
|
25
|
+
if (source != null && __getOwnPropSymbols)
|
|
26
|
+
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
+
target[prop] = source[prop];
|
|
29
|
+
}
|
|
30
|
+
return target;
|
|
31
|
+
};
|
|
32
|
+
const {
|
|
2
33
|
isSameUser,
|
|
3
34
|
isSameDay
|
|
4
35
|
} = utils;
|
|
5
|
-
const windowWidth = Dimensions.get(
|
|
6
|
-
const windowHeight = Dimensions.get(
|
|
36
|
+
const windowWidth = Dimensions.get("window").width;
|
|
37
|
+
const windowHeight = Dimensions.get("window").height;
|
|
7
38
|
class Bubble extends React__default.Component {
|
|
8
39
|
constructor(props) {
|
|
9
40
|
super(props);
|
|
10
41
|
}
|
|
11
42
|
renderMessageText() {
|
|
12
43
|
if (this.props.currentMessage.text) {
|
|
13
|
-
const _a = this.props,
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
44
|
+
const _a = this.props, {
|
|
45
|
+
containerStyle,
|
|
46
|
+
wrapperStyle,
|
|
47
|
+
messageTextStyle
|
|
48
|
+
} = _a, messageTextProps = __objRest(_a, [
|
|
49
|
+
"containerStyle",
|
|
50
|
+
"wrapperStyle",
|
|
51
|
+
"messageTextStyle"
|
|
52
|
+
]);
|
|
20
53
|
if (this.props.renderMessageText) {
|
|
21
54
|
return this.props.renderMessageText(messageTextProps);
|
|
22
55
|
}
|
|
23
|
-
return React__default.createElement(MessageText,
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
27
|
-
}));
|
|
56
|
+
return /* @__PURE__ */ React__default.createElement(MessageText, __spreadProps(__spreadValues({}, messageTextProps), { textStyle: {
|
|
57
|
+
left: [styles.standardFont, styles.slackMessageText, messageTextProps.textStyle, messageTextStyle]
|
|
58
|
+
} }));
|
|
28
59
|
}
|
|
29
60
|
return null;
|
|
30
61
|
}
|
|
31
62
|
renderMessageImage() {
|
|
32
63
|
if (this.props.currentMessage.image) {
|
|
33
|
-
const _a = this.props,
|
|
34
|
-
|
|
64
|
+
const _a = this.props, {
|
|
65
|
+
containerStyle,
|
|
66
|
+
wrapperStyle
|
|
67
|
+
} = _a, messageImageProps = __objRest(_a, [
|
|
68
|
+
"containerStyle",
|
|
69
|
+
"wrapperStyle"
|
|
70
|
+
]);
|
|
35
71
|
if (this.props.renderMessageImage) {
|
|
36
72
|
return this.props.renderMessageImage(messageImageProps);
|
|
37
73
|
}
|
|
38
74
|
const {
|
|
39
75
|
image,
|
|
40
76
|
_id
|
|
41
|
-
} = messageImageProps
|
|
42
|
-
return React__default.createElement(
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
77
|
+
} = messageImageProps == null ? void 0 : messageImageProps.currentMessage;
|
|
78
|
+
return /* @__PURE__ */ React__default.createElement(
|
|
79
|
+
TouchableHighlight,
|
|
80
|
+
{
|
|
81
|
+
underlayColor: "transparent",
|
|
82
|
+
style: {
|
|
83
|
+
width: "100%"
|
|
84
|
+
},
|
|
85
|
+
onPress: () => this.props.setImageViewer(messageImageProps == null ? void 0 : messageImageProps.currentMessage, true)
|
|
49
86
|
},
|
|
50
|
-
|
|
51
|
-
}, React__default.createElement(View, {
|
|
52
|
-
style: {
|
|
87
|
+
/* @__PURE__ */ React__default.createElement(View, { style: {
|
|
53
88
|
width: windowWidth - (windowWidth - 150),
|
|
54
89
|
height: windowHeight - (windowHeight - 100)
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
height: '100%'
|
|
60
|
-
}],
|
|
61
|
-
cacheKey: `${_id}-slack-bubble-imageKey`,
|
|
62
|
-
source: {
|
|
90
|
+
} }, /* @__PURE__ */ React__default.createElement(CachedImage, { style: [styles.slackImage, {
|
|
91
|
+
width: "100%",
|
|
92
|
+
height: "100%"
|
|
93
|
+
}], cacheKey: `${_id}-slack-bubble-imageKey`, source: {
|
|
63
94
|
uri: image,
|
|
64
|
-
//headers: `Authorization: Bearer ${token}`,
|
|
65
95
|
expiresIn: 86400
|
|
66
|
-
},
|
|
67
|
-
|
|
68
|
-
alt: 'image'
|
|
69
|
-
})));
|
|
96
|
+
}, resizeMode: "cover", alt: "image" }))
|
|
97
|
+
);
|
|
70
98
|
}
|
|
71
99
|
return null;
|
|
72
100
|
}
|
|
@@ -81,45 +109,44 @@ class Bubble extends React__default.Component {
|
|
|
81
109
|
return null;
|
|
82
110
|
}
|
|
83
111
|
if (currentMessage.sent || currentMessage.received) {
|
|
84
|
-
return React__default.createElement(View, {
|
|
85
|
-
style: [styles.headerItem, styles.tickView]
|
|
86
|
-
}, currentMessage.sent && React__default.createElement(Text, {
|
|
87
|
-
style: [styles.standardFont, styles.tick, this.props.tickStyle]
|
|
88
|
-
}, "\u2713"), currentMessage.received && React__default.createElement(Text, {
|
|
89
|
-
style: [styles.standardFont, styles.tick, this.props.tickStyle]
|
|
90
|
-
}, "\u2713"));
|
|
112
|
+
return /* @__PURE__ */ React__default.createElement(View, { style: [styles.headerItem, styles.tickView] }, currentMessage.sent && /* @__PURE__ */ React__default.createElement(Text, { style: [styles.standardFont, styles.tick, this.props.tickStyle] }, "\u2713"), currentMessage.received && /* @__PURE__ */ React__default.createElement(Text, { style: [styles.standardFont, styles.tick, this.props.tickStyle] }, "\u2713"));
|
|
91
113
|
}
|
|
92
114
|
return null;
|
|
93
115
|
}
|
|
94
116
|
renderUsername() {
|
|
95
117
|
const username = this.props.currentMessage.user.name;
|
|
96
118
|
if (username) {
|
|
97
|
-
const _a = this.props,
|
|
98
|
-
|
|
119
|
+
const _a = this.props, {
|
|
120
|
+
containerStyle,
|
|
121
|
+
wrapperStyle
|
|
122
|
+
} = _a, usernameProps = __objRest(_a, [
|
|
123
|
+
"containerStyle",
|
|
124
|
+
"wrapperStyle"
|
|
125
|
+
]);
|
|
99
126
|
if (this.props.renderUsername) {
|
|
100
127
|
return this.props.renderUsername(usernameProps);
|
|
101
128
|
}
|
|
102
|
-
return React__default.createElement(Text, {
|
|
103
|
-
style: [styles.standardFont, styles.headerItem, styles.username, this.props.usernameStyle]
|
|
104
|
-
}, username);
|
|
129
|
+
return /* @__PURE__ */ React__default.createElement(Text, { style: [styles.standardFont, styles.headerItem, styles.username, this.props.usernameStyle] }, username);
|
|
105
130
|
}
|
|
106
131
|
return null;
|
|
107
132
|
}
|
|
108
133
|
renderTime() {
|
|
109
134
|
if (this.props.currentMessage.createdAt) {
|
|
110
|
-
const _a = this.props,
|
|
111
|
-
|
|
135
|
+
const _a = this.props, {
|
|
136
|
+
containerStyle,
|
|
137
|
+
wrapperStyle
|
|
138
|
+
} = _a, timeProps = __objRest(_a, [
|
|
139
|
+
"containerStyle",
|
|
140
|
+
"wrapperStyle"
|
|
141
|
+
]);
|
|
112
142
|
if (this.props.renderTime) {
|
|
113
143
|
return this.props.renderTime(timeProps);
|
|
114
144
|
}
|
|
115
|
-
return React__default.createElement(Time,
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
left: [styles.standardFont, styles.headerItem, styles.time, timeProps.textStyle]
|
|
121
|
-
}
|
|
122
|
-
}));
|
|
145
|
+
return /* @__PURE__ */ React__default.createElement(Time, __spreadProps(__spreadValues({}, timeProps), { containerStyle: {
|
|
146
|
+
left: [styles.timeContainer]
|
|
147
|
+
}, textStyle: {
|
|
148
|
+
left: [styles.standardFont, styles.headerItem, styles.time, timeProps.textStyle]
|
|
149
|
+
} }));
|
|
123
150
|
}
|
|
124
151
|
return null;
|
|
125
152
|
}
|
|
@@ -131,26 +158,21 @@ class Bubble extends React__default.Component {
|
|
|
131
158
|
}
|
|
132
159
|
render() {
|
|
133
160
|
const isSameThread = isSameUser(this.props.currentMessage, this.props.previousMessage) && isSameDay(this.props.currentMessage, this.props.previousMessage);
|
|
134
|
-
const messageHeader = isSameThread ? null : React__default.createElement(View, {
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
}, this.props.touchableProps), React__default.createElement(View, {
|
|
148
|
-
style: [styles.wrapper, this.props.wrapperStyle]
|
|
149
|
-
}, React__default.createElement(View, null, this.renderCustomView(), messageHeader, this.renderMessageImage(), this.renderMessageText()))));
|
|
161
|
+
const messageHeader = isSameThread ? null : /* @__PURE__ */ React__default.createElement(View, { style: styles.headerView }, this.renderUsername(), this.renderTime(), this.renderTicks());
|
|
162
|
+
return /* @__PURE__ */ React__default.createElement(View, { style: [styles.container, this.props.containerStyle] }, /* @__PURE__ */ React__default.createElement(
|
|
163
|
+
TouchableHighlight,
|
|
164
|
+
__spreadValues({
|
|
165
|
+
style: {
|
|
166
|
+
width: "100%"
|
|
167
|
+
},
|
|
168
|
+
underlayColor: "transparent",
|
|
169
|
+
disabled: true,
|
|
170
|
+
accessibilityTraits: "text"
|
|
171
|
+
}, this.props.touchableProps),
|
|
172
|
+
/* @__PURE__ */ React__default.createElement(View, { style: [styles.wrapper, this.props.wrapperStyle] }, /* @__PURE__ */ React__default.createElement(View, null, this.renderCustomView(), messageHeader, this.renderMessageImage(), this.renderMessageText()))
|
|
173
|
+
));
|
|
150
174
|
}
|
|
151
175
|
}
|
|
152
|
-
// Note: Everything is forced to be "left" positioned with this component.
|
|
153
|
-
// The "right" position is only used in the default Bubble.
|
|
154
176
|
const styles = StyleSheet.create({
|
|
155
177
|
standardFont: {
|
|
156
178
|
fontSize: 15
|
|
@@ -161,21 +183,21 @@ const styles = StyleSheet.create({
|
|
|
161
183
|
},
|
|
162
184
|
container: {
|
|
163
185
|
flex: 1,
|
|
164
|
-
alignItems:
|
|
186
|
+
alignItems: "flex-start"
|
|
165
187
|
},
|
|
166
188
|
wrapper: {
|
|
167
189
|
marginRight: 60,
|
|
168
190
|
minHeight: 20,
|
|
169
|
-
justifyContent:
|
|
191
|
+
justifyContent: "flex-start"
|
|
170
192
|
},
|
|
171
193
|
username: {
|
|
172
|
-
fontWeight:
|
|
194
|
+
fontWeight: "bold",
|
|
173
195
|
top: 0,
|
|
174
196
|
paddingTop: 0,
|
|
175
197
|
marginTop: 0
|
|
176
198
|
},
|
|
177
199
|
time: {
|
|
178
|
-
textAlign:
|
|
200
|
+
textAlign: "left",
|
|
179
201
|
fontSize: 12
|
|
180
202
|
},
|
|
181
203
|
timeContainer: {
|
|
@@ -187,19 +209,16 @@ const styles = StyleSheet.create({
|
|
|
187
209
|
marginRight: 10
|
|
188
210
|
},
|
|
189
211
|
headerView: {
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
alignItems: 'baseline'
|
|
212
|
+
marginTop: Platform.OS === "android" ? -2 : 0,
|
|
213
|
+
flexDirection: "row",
|
|
214
|
+
alignItems: "baseline"
|
|
194
215
|
},
|
|
195
|
-
/* eslint-disable react-native/no-color-literals */
|
|
196
216
|
tick: {
|
|
197
|
-
backgroundColor:
|
|
198
|
-
color:
|
|
217
|
+
backgroundColor: "transparent",
|
|
218
|
+
color: "white"
|
|
199
219
|
},
|
|
200
|
-
/* eslint-enable react-native/no-color-literals */
|
|
201
220
|
tickView: {
|
|
202
|
-
flexDirection:
|
|
221
|
+
flexDirection: "row"
|
|
203
222
|
},
|
|
204
223
|
slackImage: {
|
|
205
224
|
borderRadius: 3,
|
|
@@ -207,9 +226,6 @@ const styles = StyleSheet.create({
|
|
|
207
226
|
marginRight: 0
|
|
208
227
|
}
|
|
209
228
|
});
|
|
210
|
-
// Bubble.contextTypes = {
|
|
211
|
-
// actionSheet: PropTypes.func,
|
|
212
|
-
// };
|
|
213
229
|
Bubble.defaultProps = {
|
|
214
230
|
touchableProps: {},
|
|
215
231
|
onLongPress: null,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SlackBubble.js","sources":["../../../../../src/screens/inbox/components/SlackMessageContainer/SlackBubble.tsx"],"sourcesContent":[null],"names":["React"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"SlackBubble.js","sources":["../../../../../src/screens/inbox/components/SlackMessageContainer/SlackBubble.tsx"],"sourcesContent":["/* eslint-disable no-underscore-dangle, no-use-before-define */\nimport React from 'react';\nimport { Text, StyleSheet, TouchableOpacity, TouchableHighlight, View, Platform, Dimensions } from 'react-native';\n\nimport { MessageText, MessageImage, Time, utils } from 'react-native-gifted-chat';\nimport CachedImage from '../CachedImage';\nconst { isSameUser, isSameDay } = utils;\nconst windowWidth = Dimensions.get('window').width;\nconst windowHeight = Dimensions.get('window').height;\n\nexport default class Bubble extends React.Component<any> {\n static defaultProps: {\n touchableProps: {};\n onLongPress: null;\n renderMessageImage: null;\n renderMessageText: null;\n renderCustomView: null;\n renderTime: null;\n currentMessage: { text: null; createdAt: null; image: null };\n nextMessage: {};\n previousMessage: {};\n containerStyle: {};\n wrapperStyle: {};\n tickStyle: {};\n containerToNextStyle: {};\n containerToPreviousStyle: {};\n isShowImageViewer: false;\n setImageViewer: (obj: any, v: boolean) => void;\n };\n static propTypes: any;\n constructor(props: any) {\n super(props);\n }\n\n renderMessageText() {\n if (this.props.currentMessage.text) {\n const { containerStyle, wrapperStyle, messageTextStyle, ...messageTextProps } = this.props;\n if (this.props.renderMessageText) {\n return this.props.renderMessageText(messageTextProps);\n }\n return (\n <MessageText\n {...messageTextProps}\n textStyle={{\n left: [\n styles.standardFont,\n styles.slackMessageText,\n messageTextProps.textStyle,\n messageTextStyle,\n ],\n }}\n />\n );\n }\n return null;\n }\n\n renderMessageImage() {\n if (this.props.currentMessage.image) {\n const { containerStyle, wrapperStyle, ...messageImageProps } = this.props;\n if (this.props.renderMessageImage) {\n return this.props.renderMessageImage(messageImageProps);\n }\n const { image, _id } = messageImageProps?.currentMessage;\n\n return (\n <TouchableHighlight\n // underlayColor={'#c0c0c0'}\n underlayColor={'transparent'}\n style={{ width: '100%' }}\n onPress={() => this.props.setImageViewer(messageImageProps?.currentMessage, true)}\n >\n <View\n style={{\n width: windowWidth - (windowWidth - 150),\n height: windowHeight - (windowHeight - 100),\n }}\n >\n {/* <MessageImage\n {...messageImageProps}\n imageStyle={[styles.slackImage, messageImageProps.imageStyle]}\n /> */}\n <CachedImage\n style={[styles.slackImage, { width: '100%', height: '100%' }]}\n cacheKey={`${_id}-slack-bubble-imageKey`}\n source={{\n uri: image,\n //headers: `Authorization: Bearer ${token}`,\n expiresIn: 86400,\n }}\n resizeMode={'cover'}\n alt={'image'}\n />\n </View>\n </TouchableHighlight>\n );\n }\n return null;\n }\n\n renderTicks() {\n const { currentMessage } = this.props;\n if (this.props.renderTicks) {\n return this.props.renderTicks(currentMessage);\n }\n if (currentMessage.user._id !== this.props.user._id) {\n return null;\n }\n if (currentMessage.sent || currentMessage.received) {\n return (\n <View style={[styles.headerItem, styles.tickView]}>\n {currentMessage.sent && (\n <Text style={[styles.standardFont, styles.tick, this.props.tickStyle]}>✓</Text>\n )}\n {currentMessage.received && (\n <Text style={[styles.standardFont, styles.tick, this.props.tickStyle]}>✓</Text>\n )}\n </View>\n );\n }\n return null;\n }\n\n renderUsername() {\n const username = this.props.currentMessage.user.name;\n if (username) {\n const { containerStyle, wrapperStyle, ...usernameProps } = this.props;\n if (this.props.renderUsername) {\n return this.props.renderUsername(usernameProps);\n }\n return (\n <Text style={[styles.standardFont, styles.headerItem, styles.username, this.props.usernameStyle]}>\n {username}\n </Text>\n );\n }\n return null;\n }\n\n renderTime() {\n if (this.props.currentMessage.createdAt) {\n const { containerStyle, wrapperStyle, ...timeProps }: any = this.props;\n if (this.props.renderTime) {\n return this.props.renderTime(timeProps);\n }\n return (\n <Time\n {...timeProps}\n containerStyle={{ left: [styles.timeContainer] }}\n textStyle={{\n left: [styles.standardFont, styles.headerItem, styles.time, timeProps.textStyle],\n }}\n />\n );\n }\n return null;\n }\n\n renderCustomView() {\n if (this.props.renderCustomView) {\n return this.props.renderCustomView(this.props);\n }\n return null;\n }\n\n render() {\n const isSameThread =\n isSameUser(this.props.currentMessage, this.props.previousMessage) &&\n isSameDay(this.props.currentMessage, this.props.previousMessage);\n\n const messageHeader = isSameThread ? null : (\n <View style={styles.headerView}>\n {this.renderUsername()}\n {this.renderTime()}\n {this.renderTicks()}\n </View>\n );\n\n return (\n <View style={[styles.container, this.props.containerStyle]}>\n <TouchableHighlight\n style={{ width: '100%' }}\n // underlayColor={'#c0c0c0'}\n underlayColor={'transparent'}\n disabled={true}\n accessibilityTraits=\"text\"\n {...this.props.touchableProps}\n >\n <View style={[styles.wrapper, this.props.wrapperStyle]}>\n <View>\n {this.renderCustomView()}\n {messageHeader}\n {this.renderMessageImage()}\n {this.renderMessageText()}\n </View>\n </View>\n </TouchableHighlight>\n </View>\n );\n }\n}\n\n// Note: Everything is forced to be \"left\" positioned with this component.\n// The \"right\" position is only used in the default Bubble.\nconst styles = StyleSheet.create({\n standardFont: {\n fontSize: 15,\n },\n slackMessageText: {\n marginLeft: 0,\n marginRight: 0,\n },\n container: {\n flex: 1,\n alignItems: 'flex-start',\n },\n wrapper: {\n marginRight: 60,\n minHeight: 20,\n justifyContent: 'flex-start',\n },\n username: {\n fontWeight: 'bold',\n top: 0,\n paddingTop: 0,\n marginTop: 0,\n },\n time: {\n textAlign: 'left',\n fontSize: 12,\n },\n timeContainer: {\n marginLeft: 0,\n marginRight: 0,\n marginBottom: 0,\n },\n headerItem: {\n marginRight: 10,\n },\n headerView: {\n // Try to align it better with the avatar on Android.\n marginTop: Platform.OS === 'android' ? -2 : 0,\n flexDirection: 'row',\n alignItems: 'baseline',\n },\n /* eslint-disable react-native/no-color-literals */\n tick: {\n backgroundColor: 'transparent',\n color: 'white',\n },\n /* eslint-enable react-native/no-color-literals */\n tickView: {\n flexDirection: 'row',\n },\n slackImage: {\n borderRadius: 3,\n marginLeft: 8,\n marginRight: 0,\n },\n});\n\n// Bubble.contextTypes = {\n// actionSheet: PropTypes.func,\n// };\n\nBubble.defaultProps = {\n touchableProps: {},\n onLongPress: null,\n renderMessageImage: null,\n renderMessageText: null,\n renderCustomView: null,\n renderTime: null,\n currentMessage: {\n text: null,\n createdAt: null,\n image: null,\n },\n nextMessage: {},\n previousMessage: {},\n containerStyle: {},\n wrapperStyle: {},\n tickStyle: {},\n containerToNextStyle: {},\n containerToPreviousStyle: {},\n isShowImageViewer: false,\n setImageViewer: (obj: any, v: boolean) => null,\n};\n"],"names":["React"],"mappings":"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"}
|
|
@@ -1,14 +1,47 @@
|
|
|
1
|
-
import
|
|
1
|
+
import React__default from'react';import {StyleSheet,View}from'react-native';import {Day,utils}from'react-native-gifted-chat';import {Avatar,AvatarFallbackText,AvatarImage}from'@admin-layout/gluestack-ui-mobile';import Bubble from'./SlackBubble.js';var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
var __objRest = (source, exclude) => {
|
|
21
|
+
var target = {};
|
|
22
|
+
for (var prop in source)
|
|
23
|
+
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
24
|
+
target[prop] = source[prop];
|
|
25
|
+
if (source != null && __getOwnPropSymbols)
|
|
26
|
+
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
+
target[prop] = source[prop];
|
|
29
|
+
}
|
|
30
|
+
return target;
|
|
31
|
+
};
|
|
2
32
|
const {
|
|
3
33
|
isSameUser,
|
|
4
34
|
isSameDay
|
|
5
35
|
} = utils;
|
|
6
36
|
class Message extends React__default.Component {
|
|
7
37
|
getInnerComponentProps() {
|
|
8
|
-
const _a = this.props,
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
38
|
+
const _a = this.props, {
|
|
39
|
+
containerStyle
|
|
40
|
+
} = _a, props = __objRest(_a, [
|
|
41
|
+
"containerStyle"
|
|
42
|
+
]);
|
|
43
|
+
return __spreadProps(__spreadValues({}, props), {
|
|
44
|
+
position: "left",
|
|
12
45
|
isSameUser,
|
|
13
46
|
isSameDay
|
|
14
47
|
});
|
|
@@ -19,7 +52,7 @@ class Message extends React__default.Component {
|
|
|
19
52
|
if (this.props.renderDay) {
|
|
20
53
|
return this.props.renderDay(dayProps);
|
|
21
54
|
}
|
|
22
|
-
return React__default.createElement(Day,
|
|
55
|
+
return /* @__PURE__ */ React__default.createElement(Day, __spreadValues({}, dayProps));
|
|
23
56
|
}
|
|
24
57
|
return null;
|
|
25
58
|
}
|
|
@@ -28,68 +61,43 @@ class Message extends React__default.Component {
|
|
|
28
61
|
if (this.props.renderBubble) {
|
|
29
62
|
return this.props.renderBubble(bubbleProps);
|
|
30
63
|
}
|
|
31
|
-
return React__default.createElement(Bubble,
|
|
32
|
-
isShowImageViewer: this.props.isShowImageViewer,
|
|
33
|
-
setImageViewer: this.props.setImageViewer
|
|
34
|
-
}));
|
|
64
|
+
return /* @__PURE__ */ React__default.createElement(Bubble, __spreadProps(__spreadValues({}, bubbleProps), { isShowImageViewer: this.props.isShowImageViewer, setImageViewer: this.props.setImageViewer }));
|
|
35
65
|
}
|
|
36
66
|
renderAvatar() {
|
|
37
67
|
var _a, _b, _c, _d, _e, _f;
|
|
38
|
-
//new param added
|
|
39
68
|
let isSameUserAndSameDay = false;
|
|
40
69
|
if (isSameUser(this.props.currentMessage, this.props.previousMessage) && isSameDay(this.props.currentMessage, this.props.previousMessage)) {
|
|
41
70
|
isSameUserAndSameDay = true;
|
|
42
71
|
}
|
|
43
72
|
const avatarProps = this.getInnerComponentProps();
|
|
44
|
-
return React__default.createElement(Avatar, {
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
borderRadius: '$none',
|
|
48
|
-
marginRight: '$2'
|
|
49
|
-
}, React__default.createElement(AvatarFallbackText, null, isSameUserAndSameDay ? '' : (_b = (_a = avatarProps === null || avatarProps === void 0 ? void 0 : avatarProps.currentMessage) === null || _a === void 0 ? void 0 : _a.user) === null || _b === void 0 ? void 0 : _b.name[0]), !isSameUserAndSameDay && ((_d = (_c = avatarProps === null || avatarProps === void 0 ? void 0 : avatarProps.currentMessage) === null || _c === void 0 ? void 0 : _c.user) === null || _d === void 0 ? void 0 : _d.avatar) && React__default.createElement(AvatarImage, {
|
|
50
|
-
alt: "image",
|
|
51
|
-
style: Object.assign(Object.assign({}, styles.slackAvatar), avatarProps.imageStyle),
|
|
52
|
-
source: {
|
|
53
|
-
uri: (_f = (_e = avatarProps === null || avatarProps === void 0 ? void 0 : avatarProps.currentMessage) === null || _e === void 0 ? void 0 : _e.user) === null || _f === void 0 ? void 0 : _f.avatar
|
|
54
|
-
}
|
|
55
|
-
}))
|
|
56
|
-
// <Avatar
|
|
57
|
-
// {...avatarProps}
|
|
58
|
-
// showAvatarForEveryMessage={true}
|
|
59
|
-
// imageStyle={{
|
|
60
|
-
// left: [styles.slackAvatar, avatarProps.imageStyle, extraStyle],
|
|
61
|
-
// }}
|
|
62
|
-
// />
|
|
63
|
-
;
|
|
73
|
+
return /* @__PURE__ */ React__default.createElement(Avatar, { size: "sm", bg: "transparent", borderRadius: "$none", marginRight: "$2" }, /* @__PURE__ */ React__default.createElement(AvatarFallbackText, null, isSameUserAndSameDay ? "" : (_b = (_a = avatarProps == null ? void 0 : avatarProps.currentMessage) == null ? void 0 : _a.user) == null ? void 0 : _b.name[0]), !isSameUserAndSameDay && ((_d = (_c = avatarProps == null ? void 0 : avatarProps.currentMessage) == null ? void 0 : _c.user) == null ? void 0 : _d.avatar) && /* @__PURE__ */ React__default.createElement(AvatarImage, { alt: "image", style: __spreadValues(__spreadValues({}, styles.slackAvatar), avatarProps.imageStyle), source: {
|
|
74
|
+
uri: (_f = (_e = avatarProps == null ? void 0 : avatarProps.currentMessage) == null ? void 0 : _e.user) == null ? void 0 : _f.avatar
|
|
75
|
+
} }));
|
|
64
76
|
}
|
|
65
77
|
render() {
|
|
66
78
|
const marginBottom = isSameUser(this.props.currentMessage, this.props.nextMessage) ? 2 : 10;
|
|
67
|
-
return React__default.createElement(View, null, this.renderDay(), React__default.createElement(View, {
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
}, this.props.containerStyle]
|
|
71
|
-
}, this.renderAvatar(), this.renderBubble()));
|
|
79
|
+
return /* @__PURE__ */ React__default.createElement(View, null, this.renderDay(), /* @__PURE__ */ React__default.createElement(View, { style: [styles.container, {
|
|
80
|
+
marginBottom
|
|
81
|
+
}, this.props.containerStyle] }, this.renderAvatar(), this.renderBubble()));
|
|
72
82
|
}
|
|
73
83
|
}
|
|
74
84
|
const styles = StyleSheet.create({
|
|
75
85
|
container: {
|
|
76
|
-
flexDirection:
|
|
77
|
-
alignItems:
|
|
78
|
-
justifyContent:
|
|
86
|
+
flexDirection: "row",
|
|
87
|
+
alignItems: "flex-start",
|
|
88
|
+
justifyContent: "flex-start",
|
|
79
89
|
marginLeft: 8,
|
|
80
90
|
marginRight: 0
|
|
81
91
|
},
|
|
82
92
|
slackAvatar: {
|
|
83
|
-
// The bottom should roughly line up with the first line of message text.
|
|
84
93
|
height: 40,
|
|
85
94
|
width: 40,
|
|
86
95
|
borderRadius: 3,
|
|
87
|
-
// marginTop: 0,
|
|
88
96
|
marginTop: 1
|
|
89
97
|
}
|
|
90
98
|
});
|
|
91
99
|
Message.defaultProps = {
|
|
92
|
-
renderAvatar:
|
|
100
|
+
renderAvatar: void 0,
|
|
93
101
|
renderBubble: null,
|
|
94
102
|
renderDay: null,
|
|
95
103
|
currentMessage: {},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SlackMessage.js","sources":["../../../../../src/screens/inbox/components/SlackMessageContainer/SlackMessage.tsx"],"sourcesContent":[null],"names":["React"],"mappings":"
|
|
1
|
+
{"version":3,"file":"SlackMessage.js","sources":["../../../../../src/screens/inbox/components/SlackMessageContainer/SlackMessage.tsx"],"sourcesContent":["/* eslint-disable no-underscore-dangle, no-use-before-define */\n\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { View, StyleSheet } from 'react-native';\n\nimport { Day, utils } from 'react-native-gifted-chat';\nimport { Avatar, AvatarFallbackText, AvatarImage } from '@admin-layout/gluestack-ui-mobile';\nimport Bubble from './SlackBubble';\n\nconst { isSameUser, isSameDay } = utils;\n\nexport default class Message extends React.Component<any> {\n static defaultProps: {\n renderAvatar: undefined;\n renderBubble: null;\n renderDay: null;\n currentMessage: {};\n nextMessage: {};\n previousMessage: {};\n user: {};\n containerStyle: {};\n isShowImageViewer: false;\n setImageViewer: (obj: any, v: boolean) => void;\n };\n getInnerComponentProps() {\n const { containerStyle, ...props } = this.props;\n return {\n ...props,\n position: 'left',\n isSameUser,\n isSameDay,\n };\n }\n\n renderDay() {\n if (this.props.currentMessage.createdAt) {\n const dayProps = this.getInnerComponentProps();\n if (this.props.renderDay) {\n return this.props.renderDay(dayProps);\n }\n return <Day {...dayProps} />;\n }\n return null;\n }\n\n renderBubble() {\n const bubbleProps = this.getInnerComponentProps();\n if (this.props.renderBubble) {\n return this.props.renderBubble(bubbleProps);\n }\n return (\n <Bubble\n {...bubbleProps}\n isShowImageViewer={this.props.isShowImageViewer}\n setImageViewer={this.props.setImageViewer}\n />\n );\n }\n\n renderAvatar() {\n let extraStyle: any;\n //new param added\n let isSameUserAndSameDay: boolean = false;\n if (\n isSameUser(this.props.currentMessage, this.props.previousMessage) &&\n isSameDay(this.props.currentMessage, this.props.previousMessage)\n ) {\n // Set the invisible avatar height to 0, but keep the width, padding, etc.\n extraStyle = { height: 0 };\n isSameUserAndSameDay = true;\n }\n\n const avatarProps: any = this.getInnerComponentProps();\n\n return (\n <Avatar size={'sm'} bg={'transparent'} borderRadius={'$none'} marginRight={'$2'}>\n <AvatarFallbackText>\n {isSameUserAndSameDay ? '' : avatarProps?.currentMessage?.user?.name[0]}\n </AvatarFallbackText>\n {!isSameUserAndSameDay && avatarProps?.currentMessage?.user?.avatar && (\n <AvatarImage\n alt=\"image\"\n style={{ ...styles.slackAvatar, ...avatarProps.imageStyle }}\n source={{\n uri: avatarProps?.currentMessage?.user?.avatar,\n }}\n />\n )}\n </Avatar>\n // <Avatar\n // {...avatarProps}\n // showAvatarForEveryMessage={true}\n // imageStyle={{\n // left: [styles.slackAvatar, avatarProps.imageStyle, extraStyle],\n // }}\n // />\n );\n }\n\n render() {\n const marginBottom = isSameUser(this.props.currentMessage, this.props.nextMessage) ? 2 : 10;\n\n return (\n <View>\n {this.renderDay()}\n <View style={[styles.container, { marginBottom }, this.props.containerStyle]}>\n {this.renderAvatar()}\n {this.renderBubble()}\n </View>\n </View>\n );\n }\n}\n\nconst styles = StyleSheet.create({\n container: {\n flexDirection: 'row',\n alignItems: 'flex-start',\n justifyContent: 'flex-start',\n marginLeft: 8,\n marginRight: 0,\n },\n slackAvatar: {\n // The bottom should roughly line up with the first line of message text.\n height: 40,\n width: 40,\n borderRadius: 3,\n // marginTop: 0,\n marginTop: 1,\n },\n});\n\nMessage.defaultProps = {\n renderAvatar: undefined,\n renderBubble: null,\n renderDay: null,\n currentMessage: {},\n nextMessage: {},\n previousMessage: {},\n user: {},\n containerStyle: {},\n isShowImageViewer: false,\n setImageViewer: (obj: any, v: boolean) => null,\n};\n"],"names":["React"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAQA,MAAM;AAAA,EACJ,UAAA;AAAA,EACA;AACF,CAAI,GAAA,KAAA;AACiB,MAAA,OAAA,SAAgBA,eAAM,SAAe,CAAA;AAAA,EAaxD,sBAAyB,GAAA;AACvB,IAAA,MAGI,UAAK,KAFP,EAAA;AAAA,MAAA;AAAA,KA3BN,GA6BQ,EADC,EAAA,KAAA,GAAA,SAAA,CACD,EADC,EAAA;AAAA,MADH;AAAA,KAAA,CAAA;AAGF,IAAA,OAAO,iCACF,KADE,CAAA,EAAA;AAAA,MAEL,QAAU,EAAA,MAAA;AAAA,MACV,UAAA;AAAA,MACA;AAAA,KACF,CAAA;AAAA;AACF,EACA,SAAY,GAAA;AACV,IAAI,IAAA,IAAA,CAAK,KAAM,CAAA,cAAA,CAAe,SAAW,EAAA;AACvC,MAAM,MAAA,QAAA,GAAW,KAAK,sBAAuB,EAAA;AAC7C,MAAI,IAAA,IAAA,CAAK,MAAM,SAAW,EAAA;AACxB,QAAO,OAAA,IAAA,CAAK,KAAM,CAAA,SAAA,CAAU,QAAQ,CAAA;AAAA;AAEtC,MAAO,uBAAAA,cAAA,CAAA,aAAA,CAAC,wBAAQ,QAAU,CAAA,CAAA;AAAA;AAE5B,IAAO,OAAA,IAAA;AAAA;AACT,EACA,YAAe,GAAA;AACb,IAAM,MAAA,WAAA,GAAc,KAAK,sBAAuB,EAAA;AAChD,IAAI,IAAA,IAAA,CAAK,MAAM,YAAc,EAAA;AAC3B,MAAO,OAAA,IAAA,CAAK,KAAM,CAAA,YAAA,CAAa,WAAW,CAAA;AAAA;AAE5C,IAAO,uBAAAA,cAAA,CAAA,aAAA,CAAC,MAAW,EAAA,aAAA,CAAA,cAAA,CAAA,EAAA,EAAA,WAAA,CAAA,EAAX,EAAwB,iBAAA,EAAmB,IAAK,CAAA,KAAA,CAAM,iBAAmB,EAAA,cAAA,EAAgB,IAAK,CAAA,KAAA,CAAM,cAAgB,EAAA,CAAA,CAAA;AAAA;AAC9H,EACA,YAAe,GAAA;AAtDjB,IAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AAyDI,IAAA,IAAI,oBAAgC,GAAA,KAAA;AACpC,IAAA,IAAI,UAAW,CAAA,IAAA,CAAK,KAAM,CAAA,cAAA,EAAgB,KAAK,KAAM,CAAA,eAAe,CAAK,IAAA,SAAA,CAAU,KAAK,KAAM,CAAA,cAAA,EAAgB,IAAK,CAAA,KAAA,CAAM,eAAe,CAAG,EAAA;AAKzI,MAAuB,oBAAA,GAAA,IAAA;AAAA;AAEzB,IAAM,MAAA,WAAA,GAAmB,KAAK,sBAAuB,EAAA;AACrD,IAAA,oDAAQ,MAAO,EAAA,EAAA,IAAA,EAAM,MAAM,EAAI,EAAA,aAAA,EAAe,cAAc,OAAS,EAAA,WAAA,EAAa,IACtE,EAAA,kBAAAA,cAAA,CAAA,aAAA,CAAC,0BACI,oBAAuB,GAAA,EAAA,GAAA,CAAK,sDAAa,cAAb,KAAA,IAAA,GAAA,MAAA,GAAA,EAAA,CAA6B,SAA7B,IAAmC,GAAA,MAAA,GAAA,EAAA,CAAA,IAAA,CAAK,CACzE,CAAA,CAAA,EACC,CAAC,oBAAwB,KAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,WAAA,IAAA,IAAA,GAAA,MAAA,GAAA,WAAA,CAAa,mBAAb,IAA6B,GAAA,MAAA,GAAA,EAAA,CAAA,IAAA,KAA7B,mBAAmC,MAAU,CAAA,oBAAAA,cAAA,CAAA,aAAA,CAAC,WAAY,EAAA,EAAA,GAAA,EAAI,SAAQ,KAAO,EAAA,cAAA,CAAA,cAAA,CAAA,EAAA,EAC5G,OAAO,WACP,CAAA,EAAA,WAAA,CAAY,aACd,MAAQ,EAAA;AAAA,MACT,GAAK,EAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,WAAA,IAAA,IAAA,GAAA,MAAA,GAAA,WAAA,CAAa,cAAb,KAAA,IAAA,GAAA,MAAA,GAAA,EAAA,CAA6B,SAA7B,IAAmC,GAAA,MAAA,GAAA,EAAA,CAAA;AAAA,OACvC,CACG,CAAA;AAAA;AASV,EACA,MAAS,GAAA;AACP,IAAM,MAAA,YAAA,GAAe,WAAW,IAAK,CAAA,KAAA,CAAM,gBAAgB,IAAK,CAAA,KAAA,CAAM,WAAW,CAAA,GAAI,CAAI,GAAA,EAAA;AACzF,IAAO,uBAAAA,cAAA,CAAA,aAAA,CAAC,IACK,EAAA,IAAA,EAAA,IAAA,CAAK,SAAU,EAAA,+CACf,IAAK,EAAA,EAAA,KAAA,EAAO,CAAC,MAAA,CAAO,SAAW,EAAA;AAAA,MACxC;AAAA,KACF,EAAG,IAAK,CAAA,KAAA,CAAM,cAAc,CAAA,EAAA,EACb,IAAK,CAAA,YAAA,EACL,EAAA,IAAA,CAAK,YAAa,EACvB,CACJ,CAAA;AAAA;AAEZ;AACA,MAAM,MAAA,GAAS,WAAW,MAAO,CAAA;AAAA,EAC/B,SAAW,EAAA;AAAA,IACT,aAAe,EAAA,KAAA;AAAA,IACf,UAAY,EAAA,YAAA;AAAA,IACZ,cAAgB,EAAA,YAAA;AAAA,IAChB,UAAY,EAAA,CAAA;AAAA,IACZ,WAAa,EAAA;AAAA,GACf;AAAA,EACA,WAAa,EAAA;AAAA,IAEX,MAAQ,EAAA,EAAA;AAAA,IACR,KAAO,EAAA,EAAA;AAAA,IACP,YAAc,EAAA,CAAA;AAAA,IAEd,SAAW,EAAA;AAAA;AAEf,CAAC,CAAA;AACD,OAAA,CAAQ,YAAe,GAAA;AAAA,EACrB,YAAc,EAAA,MAAA;AAAA,EACd,YAAc,EAAA,IAAA;AAAA,EACd,SAAW,EAAA,IAAA;AAAA,EACX,gBAAgB,EAAC;AAAA,EACjB,aAAa,EAAC;AAAA,EACd,iBAAiB,EAAC;AAAA,EAClB,MAAM,EAAC;AAAA,EACP,gBAAgB,EAAC;AAAA,EACjB,iBAAmB,EAAA,KAAA;AAAA,EACnB,cAAA,EAAgB,CAAC,GAAA,EAAU,CAAe,KAAA;AAC5C,CAAA"}
|