@viewberapp/chat 0.1.14 → 0.1.17
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/LICENSE +20 -20
- package/dist/API.d.ts +93 -91
- package/dist/API.js +243 -241
- package/dist/API.js.map +1 -1
- package/dist/CachedChat.d.ts +67 -64
- package/dist/CachedChat.js +248 -241
- package/dist/CachedChat.js.map +1 -1
- package/dist/Chat.d.ts +66 -66
- package/dist/Chat.js +273 -270
- package/dist/Chat.js.map +1 -1
- package/dist/ChatError.d.ts +4 -4
- package/dist/ChatError.js +2 -2
- package/dist/ChatSubscription.d.ts +84 -82
- package/dist/ChatSubscription.js +134 -128
- package/dist/ChatSubscription.js.map +1 -1
- package/dist/Message.d.ts +25 -25
- package/dist/Message.js +35 -35
- package/dist/OnlineUser.d.ts +8 -8
- package/dist/OnlineUser.js +9 -9
- package/dist/PendingMessage.d.ts +23 -23
- package/dist/PendingMessage.js +23 -23
- package/dist/index.d.ts +8 -8
- package/dist/index.js +27 -27
- package/dist/logger/ConsoleLogger.d.ts +8 -8
- package/dist/logger/ConsoleLogger.js +20 -20
- package/dist/logger/ConsoleLogger.js.map +1 -1
- package/dist/logger/NullLogger.d.ts +8 -8
- package/dist/logger/NullLogger.js +10 -10
- package/dist/logger/NullLogger.js.map +1 -1
- package/dist/logger/RollbarLogger.d.ts +11 -11
- package/dist/logger/RollbarLogger.js +23 -23
- package/dist/logger/RollbarLogger.js.map +1 -1
- package/dist/logger/index.d.ts +12 -12
- package/dist/logger/index.js +12 -12
- package/dist/logger/index.js.map +1 -1
- package/dist/react/components/AdminMessage.d.ts +6 -6
- package/dist/react/components/AdminMessage.js +59 -59
- package/dist/react/components/ConnectionAndChannelStatusLabel.d.ts +7 -7
- package/dist/react/components/ConnectionAndChannelStatusLabel.js +59 -59
- package/dist/react/components/Message.d.ts +23 -23
- package/dist/react/components/Message.js +87 -87
- package/dist/react/components/MessageDateTime.d.ts +8 -8
- package/dist/react/components/MessageDateTime.js +31 -31
- package/dist/react/components/MessageList.d.ts +46 -46
- package/dist/react/components/MessageList.js +107 -107
- package/dist/react/components/MessageRow.d.ts +5 -5
- package/dist/react/components/MessageRow.js +34 -34
- package/dist/react/components/index.d.ts +6 -6
- package/dist/react/components/index.js +13 -13
- package/dist/react/index.d.ts +3 -3
- package/dist/react/index.js +16 -16
- package/dist/react/useAppointmentChat.d.ts +3 -3
- package/dist/react/useAppointmentChat.js +10 -10
- package/dist/react/useChat.d.ts +40 -38
- package/dist/react/useChat.js +127 -125
- package/dist/react/useChat.js.map +1 -1
- package/dist/react/useRealtimeTotalUserUnreadChatMessages.d.ts +13 -12
- package/dist/react/useRealtimeTotalUserUnreadChatMessages.js +138 -137
- package/dist/react/useRealtimeTotalUserUnreadChatMessages.js.map +1 -1
- package/dist/util/getLatestMessage.d.ts +3 -3
- package/dist/util/getLatestMessage.js +17 -17
- package/dist/util/groupMessages.d.ts +8 -8
- package/dist/util/groupMessages.js +30 -30
- package/dist/util/index.d.ts +4 -4
- package/dist/util/index.js +9 -9
- package/dist/util/isNil.d.ts +1 -1
- package/dist/util/isNil.js +7 -7
- package/dist/util/jwtTokenChanged.d.ts +1 -1
- package/dist/util/jwtTokenChanged.js +10 -10
- package/dist/util/useIsMounted.d.ts +1 -1
- package/dist/util/useIsMounted.js +13 -13
- package/package.json +2 -2
- package/dist/util/getLatestMessageId.d.ts +0 -3
- package/dist/util/getLatestMessageId.js +0 -18
- package/dist/util/getLatestMessageId.js.map +0 -1
|
@@ -1,60 +1,60 @@
|
|
|
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
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.ConnectionAndChannelStatusLabel = void 0;
|
|
27
|
-
const React = __importStar(require("react"));
|
|
28
|
-
const ConnectionAndChannelStatusLabel = ({ connectionStatus, channelStatus }) => {
|
|
29
|
-
const derivedConnectionStatus = deriveConnectionStatus(connectionStatus, channelStatus);
|
|
30
|
-
const derivedConnectionStatusColors = {
|
|
31
|
-
connected: 'rgb(5, 150, 105)',
|
|
32
|
-
connecting: 'rgb(251, 146, 60)',
|
|
33
|
-
not_connected: 'rgb(239, 68, 68)'
|
|
34
|
-
};
|
|
35
|
-
const connectionDotStyles = {
|
|
36
|
-
display: 'inline-block',
|
|
37
|
-
width: '10px',
|
|
38
|
-
height: '10px',
|
|
39
|
-
borderRadius: '9999px',
|
|
40
|
-
marginLeft: '5px',
|
|
41
|
-
backgroundColor: derivedConnectionStatusColors[derivedConnectionStatus]
|
|
42
|
-
};
|
|
43
|
-
return (React.createElement("span", { title: `Connection: ${connectionStatus}, Channel: ${channelStatus}` },
|
|
44
|
-
"Connection",
|
|
45
|
-
React.createElement("span", { style: connectionDotStyles })));
|
|
46
|
-
};
|
|
47
|
-
exports.ConnectionAndChannelStatusLabel = ConnectionAndChannelStatusLabel;
|
|
48
|
-
const deriveConnectionStatus = (connectionStatus, channelStatus) => {
|
|
49
|
-
if (connectionStatus === 'connected' && channelStatus === 'attached') {
|
|
50
|
-
return 'connected';
|
|
51
|
-
}
|
|
52
|
-
else if (connectionStatus
|
|
53
|
-
&& channelStatus
|
|
54
|
-
&& ['connecting', 'suspended', 'closing'].includes(connectionStatus)
|
|
55
|
-
&& ['attaching', 'detaching'].includes(channelStatus)) {
|
|
56
|
-
return 'connecting';
|
|
57
|
-
}
|
|
58
|
-
return 'not_connected';
|
|
59
|
-
};
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.ConnectionAndChannelStatusLabel = void 0;
|
|
27
|
+
const React = __importStar(require("react"));
|
|
28
|
+
const ConnectionAndChannelStatusLabel = ({ connectionStatus, channelStatus }) => {
|
|
29
|
+
const derivedConnectionStatus = deriveConnectionStatus(connectionStatus, channelStatus);
|
|
30
|
+
const derivedConnectionStatusColors = {
|
|
31
|
+
connected: 'rgb(5, 150, 105)',
|
|
32
|
+
connecting: 'rgb(251, 146, 60)',
|
|
33
|
+
not_connected: 'rgb(239, 68, 68)'
|
|
34
|
+
};
|
|
35
|
+
const connectionDotStyles = {
|
|
36
|
+
display: 'inline-block',
|
|
37
|
+
width: '10px',
|
|
38
|
+
height: '10px',
|
|
39
|
+
borderRadius: '9999px',
|
|
40
|
+
marginLeft: '5px',
|
|
41
|
+
backgroundColor: derivedConnectionStatusColors[derivedConnectionStatus]
|
|
42
|
+
};
|
|
43
|
+
return (React.createElement("span", { title: `Connection: ${connectionStatus}, Channel: ${channelStatus}` },
|
|
44
|
+
"Connection",
|
|
45
|
+
React.createElement("span", { style: connectionDotStyles })));
|
|
46
|
+
};
|
|
47
|
+
exports.ConnectionAndChannelStatusLabel = ConnectionAndChannelStatusLabel;
|
|
48
|
+
const deriveConnectionStatus = (connectionStatus, channelStatus) => {
|
|
49
|
+
if (connectionStatus === 'connected' && channelStatus === 'attached') {
|
|
50
|
+
return 'connected';
|
|
51
|
+
}
|
|
52
|
+
else if (connectionStatus
|
|
53
|
+
&& channelStatus
|
|
54
|
+
&& ['connecting', 'suspended', 'closing'].includes(connectionStatus)
|
|
55
|
+
&& ['attaching', 'detaching'].includes(channelStatus)) {
|
|
56
|
+
return 'connecting';
|
|
57
|
+
}
|
|
58
|
+
return 'not_connected';
|
|
59
|
+
};
|
|
60
60
|
//# sourceMappingURL=ConnectionAndChannelStatusLabel.js.map
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import PropTypes from 'prop-types';
|
|
3
|
-
import MessageModel from "../../Message";
|
|
4
|
-
import PendingMessage from '../../PendingMessage';
|
|
5
|
-
export interface MessageProps {
|
|
6
|
-
message: MessageModel | PendingMessage;
|
|
7
|
-
isCurrentUser: boolean;
|
|
8
|
-
failedPendingMessageIconClassName?: string;
|
|
9
|
-
failedPendingMessageDescriptionStyles?: React.CSSProperties;
|
|
10
|
-
failedPendingMessageDescriptionClassName?: string;
|
|
11
|
-
onFailedPendingMessageClick?: (pendingMessage: PendingMessage) => void;
|
|
12
|
-
}
|
|
13
|
-
export declare const Message: {
|
|
14
|
-
({ message, isCurrentUser, failedPendingMessageIconClassName, failedPendingMessageDescriptionStyles, failedPendingMessageDescriptionClassName, onFailedPendingMessageClick }: MessageProps): JSX.Element;
|
|
15
|
-
propTypes: {
|
|
16
|
-
message: PropTypes.Requireable<object>;
|
|
17
|
-
isCurrentUser: PropTypes.Requireable<boolean>;
|
|
18
|
-
failedPendingMessageIconClassName: PropTypes.Requireable<string>;
|
|
19
|
-
failedPendingMessageDescriptionStyles: PropTypes.Requireable<object>;
|
|
20
|
-
failedPendingMessageDescriptionClassName: PropTypes.Requireable<string>;
|
|
21
|
-
onFailedPendingMessageClick: PropTypes.Requireable<(...args: any[]) => any>;
|
|
22
|
-
};
|
|
23
|
-
};
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import PropTypes from 'prop-types';
|
|
3
|
+
import MessageModel from "../../Message";
|
|
4
|
+
import PendingMessage from '../../PendingMessage';
|
|
5
|
+
export interface MessageProps {
|
|
6
|
+
message: MessageModel | PendingMessage;
|
|
7
|
+
isCurrentUser: boolean;
|
|
8
|
+
failedPendingMessageIconClassName?: string;
|
|
9
|
+
failedPendingMessageDescriptionStyles?: React.CSSProperties;
|
|
10
|
+
failedPendingMessageDescriptionClassName?: string;
|
|
11
|
+
onFailedPendingMessageClick?: (pendingMessage: PendingMessage) => void;
|
|
12
|
+
}
|
|
13
|
+
export declare const Message: {
|
|
14
|
+
({ message, isCurrentUser, failedPendingMessageIconClassName, failedPendingMessageDescriptionStyles, failedPendingMessageDescriptionClassName, onFailedPendingMessageClick }: MessageProps): JSX.Element;
|
|
15
|
+
propTypes: {
|
|
16
|
+
message: PropTypes.Requireable<object>;
|
|
17
|
+
isCurrentUser: PropTypes.Requireable<boolean>;
|
|
18
|
+
failedPendingMessageIconClassName: PropTypes.Requireable<string>;
|
|
19
|
+
failedPendingMessageDescriptionStyles: PropTypes.Requireable<object>;
|
|
20
|
+
failedPendingMessageDescriptionClassName: PropTypes.Requireable<string>;
|
|
21
|
+
onFailedPendingMessageClick: PropTypes.Requireable<(...args: any[]) => any>;
|
|
22
|
+
};
|
|
23
|
+
};
|
|
@@ -1,88 +1,88 @@
|
|
|
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
|
-
exports.Message = void 0;
|
|
30
|
-
const React = __importStar(require("react"));
|
|
31
|
-
const prop_types_1 = __importDefault(require("prop-types"));
|
|
32
|
-
const PendingMessage_1 = require("../../PendingMessage");
|
|
33
|
-
const MessageDateTime_1 = require("./MessageDateTime");
|
|
34
|
-
const util_1 = require("../../util");
|
|
35
|
-
const Message = ({ message, isCurrentUser, failedPendingMessageIconClassName, failedPendingMessageDescriptionStyles, failedPendingMessageDescriptionClassName, onFailedPendingMessageClick }) => {
|
|
36
|
-
const [dateTimeIsShowing, setDateTimeIsShowing] = React.useState(false);
|
|
37
|
-
const isFailedPendingMessage = ((0, PendingMessage_1.isPendingMessage)(message)
|
|
38
|
-
&& message.status === 'failed');
|
|
39
|
-
const handleMessageClick = () => {
|
|
40
|
-
if (!isFailedPendingMessage) {
|
|
41
|
-
setDateTimeIsShowing(!dateTimeIsShowing);
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
if (onFailedPendingMessageClick) {
|
|
45
|
-
onFailedPendingMessageClick(message);
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
const containerStyles = {
|
|
49
|
-
display: 'inline-block',
|
|
50
|
-
maxWidth: '300px',
|
|
51
|
-
margin: '0.125rem 0.5rem'
|
|
52
|
-
};
|
|
53
|
-
const messageStyles = {
|
|
54
|
-
display: 'inline-block',
|
|
55
|
-
borderRadius: '0.675rem',
|
|
56
|
-
backgroundColor: isCurrentUser
|
|
57
|
-
? '#218aff'
|
|
58
|
-
: '#d8d8d8',
|
|
59
|
-
color: isCurrentUser
|
|
60
|
-
? '#fff'
|
|
61
|
-
: undefined,
|
|
62
|
-
padding: '0.25rem 1rem',
|
|
63
|
-
};
|
|
64
|
-
return (React.createElement("div", { style: containerStyles },
|
|
65
|
-
React.createElement("div", null,
|
|
66
|
-
React.createElement("div", { style: messageStyles, onClick: handleMessageClick },
|
|
67
|
-
React.createElement("span", null, message.message)),
|
|
68
|
-
isFailedPendingMessage && !(0, util_1.isNil)(failedPendingMessageIconClassName) &&
|
|
69
|
-
React.createElement("div", { style: { display: 'inline-block' } },
|
|
70
|
-
React.createElement("i", { className: failedPendingMessageIconClassName })),
|
|
71
|
-
isFailedPendingMessage &&
|
|
72
|
-
React.createElement("div", { className: failedPendingMessageDescriptionClassName, style: failedPendingMessageDescriptionStyles }, (0, util_1.isNil)(onFailedPendingMessageClick)
|
|
73
|
-
? 'This message failed to send'
|
|
74
|
-
: 'This message failed to send. Click to retry'),
|
|
75
|
-
dateTimeIsShowing &&
|
|
76
|
-
React.createElement("div", null,
|
|
77
|
-
React.createElement(MessageDateTime_1.MessageDateTime, { date: message.createdAt, style: { display: 'block' } })))));
|
|
78
|
-
};
|
|
79
|
-
exports.Message = Message;
|
|
80
|
-
exports.Message.propTypes = {
|
|
81
|
-
message: prop_types_1.default.object,
|
|
82
|
-
isCurrentUser: prop_types_1.default.bool,
|
|
83
|
-
failedPendingMessageIconClassName: prop_types_1.default.string,
|
|
84
|
-
failedPendingMessageDescriptionStyles: prop_types_1.default.object,
|
|
85
|
-
failedPendingMessageDescriptionClassName: prop_types_1.default.string,
|
|
86
|
-
onFailedPendingMessageClick: prop_types_1.default.func
|
|
87
|
-
};
|
|
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
|
+
exports.Message = void 0;
|
|
30
|
+
const React = __importStar(require("react"));
|
|
31
|
+
const prop_types_1 = __importDefault(require("prop-types"));
|
|
32
|
+
const PendingMessage_1 = require("../../PendingMessage");
|
|
33
|
+
const MessageDateTime_1 = require("./MessageDateTime");
|
|
34
|
+
const util_1 = require("../../util");
|
|
35
|
+
const Message = ({ message, isCurrentUser, failedPendingMessageIconClassName, failedPendingMessageDescriptionStyles, failedPendingMessageDescriptionClassName, onFailedPendingMessageClick }) => {
|
|
36
|
+
const [dateTimeIsShowing, setDateTimeIsShowing] = React.useState(false);
|
|
37
|
+
const isFailedPendingMessage = ((0, PendingMessage_1.isPendingMessage)(message)
|
|
38
|
+
&& message.status === 'failed');
|
|
39
|
+
const handleMessageClick = () => {
|
|
40
|
+
if (!isFailedPendingMessage) {
|
|
41
|
+
setDateTimeIsShowing(!dateTimeIsShowing);
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
if (onFailedPendingMessageClick) {
|
|
45
|
+
onFailedPendingMessageClick(message);
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
const containerStyles = {
|
|
49
|
+
display: 'inline-block',
|
|
50
|
+
maxWidth: '300px',
|
|
51
|
+
margin: '0.125rem 0.5rem'
|
|
52
|
+
};
|
|
53
|
+
const messageStyles = {
|
|
54
|
+
display: 'inline-block',
|
|
55
|
+
borderRadius: '0.675rem',
|
|
56
|
+
backgroundColor: isCurrentUser
|
|
57
|
+
? '#218aff'
|
|
58
|
+
: '#d8d8d8',
|
|
59
|
+
color: isCurrentUser
|
|
60
|
+
? '#fff'
|
|
61
|
+
: undefined,
|
|
62
|
+
padding: '0.25rem 1rem',
|
|
63
|
+
};
|
|
64
|
+
return (React.createElement("div", { style: containerStyles },
|
|
65
|
+
React.createElement("div", null,
|
|
66
|
+
React.createElement("div", { style: messageStyles, onClick: handleMessageClick },
|
|
67
|
+
React.createElement("span", null, message.message)),
|
|
68
|
+
isFailedPendingMessage && !(0, util_1.isNil)(failedPendingMessageIconClassName) &&
|
|
69
|
+
React.createElement("div", { style: { display: 'inline-block' } },
|
|
70
|
+
React.createElement("i", { className: failedPendingMessageIconClassName })),
|
|
71
|
+
isFailedPendingMessage &&
|
|
72
|
+
React.createElement("div", { className: failedPendingMessageDescriptionClassName, style: failedPendingMessageDescriptionStyles }, (0, util_1.isNil)(onFailedPendingMessageClick)
|
|
73
|
+
? 'This message failed to send'
|
|
74
|
+
: 'This message failed to send. Click to retry'),
|
|
75
|
+
dateTimeIsShowing &&
|
|
76
|
+
React.createElement("div", null,
|
|
77
|
+
React.createElement(MessageDateTime_1.MessageDateTime, { date: message.createdAt, style: { display: 'block' } })))));
|
|
78
|
+
};
|
|
79
|
+
exports.Message = Message;
|
|
80
|
+
exports.Message.propTypes = {
|
|
81
|
+
message: prop_types_1.default.object,
|
|
82
|
+
isCurrentUser: prop_types_1.default.bool,
|
|
83
|
+
failedPendingMessageIconClassName: prop_types_1.default.string,
|
|
84
|
+
failedPendingMessageDescriptionStyles: prop_types_1.default.object,
|
|
85
|
+
failedPendingMessageDescriptionClassName: prop_types_1.default.string,
|
|
86
|
+
onFailedPendingMessageClick: prop_types_1.default.func
|
|
87
|
+
};
|
|
88
88
|
//# sourceMappingURL=Message.js.map
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
interface MessageDateTimeProps {
|
|
3
|
-
date?: Date | null;
|
|
4
|
-
style?: React.CSSProperties;
|
|
5
|
-
className?: string;
|
|
6
|
-
}
|
|
7
|
-
export declare const MessageDateTime: ({ date, style, className }: MessageDateTimeProps) => JSX.Element;
|
|
8
|
-
export {};
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
interface MessageDateTimeProps {
|
|
3
|
+
date?: Date | null;
|
|
4
|
+
style?: React.CSSProperties;
|
|
5
|
+
className?: string;
|
|
6
|
+
}
|
|
7
|
+
export declare const MessageDateTime: ({ date, style, className }: MessageDateTimeProps) => JSX.Element;
|
|
8
|
+
export {};
|
|
@@ -1,32 +1,32 @@
|
|
|
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
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.MessageDateTime = void 0;
|
|
27
|
-
const React = __importStar(require("react"));
|
|
28
|
-
const MessageDateTime = ({ date, style, className }) => {
|
|
29
|
-
return (React.createElement("small", { style: style, className: className }, date === null || date === void 0 ? void 0 : date.toLocaleString()));
|
|
30
|
-
};
|
|
31
|
-
exports.MessageDateTime = MessageDateTime;
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.MessageDateTime = void 0;
|
|
27
|
+
const React = __importStar(require("react"));
|
|
28
|
+
const MessageDateTime = ({ date, style, className }) => {
|
|
29
|
+
return (React.createElement("small", { style: style, className: className }, date === null || date === void 0 ? void 0 : date.toLocaleString()));
|
|
30
|
+
};
|
|
31
|
+
exports.MessageDateTime = MessageDateTime;
|
|
32
32
|
//# sourceMappingURL=MessageDateTime.js.map
|
|
@@ -1,46 +1,46 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import PropTypes from 'prop-types';
|
|
3
|
-
import ChatError from '../../ChatError';
|
|
4
|
-
import MessageModel from '../../Message';
|
|
5
|
-
import { GetLatestMessagesStatus, Messages } from '../../CachedChat';
|
|
6
|
-
import PendingMessage from '../../PendingMessage';
|
|
7
|
-
export interface MessageListProps {
|
|
8
|
-
messages: Messages;
|
|
9
|
-
currentUserId: number;
|
|
10
|
-
messagesScrollContainerId: string;
|
|
11
|
-
messagesContainerClassName?: string;
|
|
12
|
-
failedPendingMessageIconClassName?: string;
|
|
13
|
-
failedPendingMessageDescriptionStyles?: React.CSSProperties;
|
|
14
|
-
failedPendingMessageDescriptionClassName?: string;
|
|
15
|
-
onFailedPendingMessageClick?: (pendingMessage: PendingMessage) => void;
|
|
16
|
-
getLatestMessagesStatus: GetLatestMessagesStatus;
|
|
17
|
-
markMessagesReadUpTo(message: MessageModel): Promise<{
|
|
18
|
-
error: ChatError | undefined;
|
|
19
|
-
}>;
|
|
20
|
-
shouldMarkMessagesAsRead: boolean;
|
|
21
|
-
loadingContent: React.ReactNode;
|
|
22
|
-
retryContent: React.ReactNode;
|
|
23
|
-
noMessagesContent: React.ReactNode;
|
|
24
|
-
onMessagesMarkedAsRead?: () => void;
|
|
25
|
-
onRequestScrollToBottomOfMessagesScrollContainer: () => void;
|
|
26
|
-
}
|
|
27
|
-
export declare const MessageList: {
|
|
28
|
-
({ messages, currentUserId, messagesScrollContainerId, messagesContainerClassName, failedPendingMessageIconClassName, failedPendingMessageDescriptionStyles, failedPendingMessageDescriptionClassName, onFailedPendingMessageClick, getLatestMessagesStatus, markMessagesReadUpTo, shouldMarkMessagesAsRead, loadingContent, retryContent, noMessagesContent, onMessagesMarkedAsRead, onRequestScrollToBottomOfMessagesScrollContainer }: MessageListProps): React.ReactNode;
|
|
29
|
-
propTypes: {
|
|
30
|
-
messages: PropTypes.Validator<(object | null | undefined)[]>;
|
|
31
|
-
currentUserId: PropTypes.Validator<number>;
|
|
32
|
-
messagesScrollContainerId: PropTypes.Validator<string>;
|
|
33
|
-
messagesContainerClassName: PropTypes.Requireable<string>;
|
|
34
|
-
failedPendingMessageIconClassName: PropTypes.Requireable<string>;
|
|
35
|
-
failedPendingMessageDescriptionStyles: PropTypes.Requireable<object>;
|
|
36
|
-
failedPendingMessageDescriptionClassName: PropTypes.Requireable<string>;
|
|
37
|
-
onFailedPendingMessageClick: PropTypes.Requireable<(...args: any[]) => any>;
|
|
38
|
-
getLatestMessagesStatus: PropTypes.Requireable<string>;
|
|
39
|
-
markMessagesReadUpTo: PropTypes.Validator<(...args: any[]) => any>;
|
|
40
|
-
shouldMarkMessagesAsRead: PropTypes.Validator<boolean>;
|
|
41
|
-
loadingContent: PropTypes.Validator<string | number | boolean | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
|
|
42
|
-
retryContent: PropTypes.Validator<string | number | boolean | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
|
|
43
|
-
noMessagesContent: PropTypes.Validator<string | number | boolean | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
|
|
44
|
-
onRequestScrollToBottomOfMessagesScrollContainer: PropTypes.Validator<(...args: any[]) => any>;
|
|
45
|
-
};
|
|
46
|
-
};
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import PropTypes from 'prop-types';
|
|
3
|
+
import ChatError from '../../ChatError';
|
|
4
|
+
import MessageModel from '../../Message';
|
|
5
|
+
import { GetLatestMessagesStatus, Messages } from '../../CachedChat';
|
|
6
|
+
import PendingMessage from '../../PendingMessage';
|
|
7
|
+
export interface MessageListProps {
|
|
8
|
+
messages: Messages;
|
|
9
|
+
currentUserId: number;
|
|
10
|
+
messagesScrollContainerId: string;
|
|
11
|
+
messagesContainerClassName?: string;
|
|
12
|
+
failedPendingMessageIconClassName?: string;
|
|
13
|
+
failedPendingMessageDescriptionStyles?: React.CSSProperties;
|
|
14
|
+
failedPendingMessageDescriptionClassName?: string;
|
|
15
|
+
onFailedPendingMessageClick?: (pendingMessage: PendingMessage) => void;
|
|
16
|
+
getLatestMessagesStatus: GetLatestMessagesStatus;
|
|
17
|
+
markMessagesReadUpTo(message: MessageModel): Promise<{
|
|
18
|
+
error: ChatError | undefined;
|
|
19
|
+
}>;
|
|
20
|
+
shouldMarkMessagesAsRead: boolean;
|
|
21
|
+
loadingContent: React.ReactNode;
|
|
22
|
+
retryContent: React.ReactNode;
|
|
23
|
+
noMessagesContent: React.ReactNode;
|
|
24
|
+
onMessagesMarkedAsRead?: () => void;
|
|
25
|
+
onRequestScrollToBottomOfMessagesScrollContainer: () => void;
|
|
26
|
+
}
|
|
27
|
+
export declare const MessageList: {
|
|
28
|
+
({ messages, currentUserId, messagesScrollContainerId, messagesContainerClassName, failedPendingMessageIconClassName, failedPendingMessageDescriptionStyles, failedPendingMessageDescriptionClassName, onFailedPendingMessageClick, getLatestMessagesStatus, markMessagesReadUpTo, shouldMarkMessagesAsRead, loadingContent, retryContent, noMessagesContent, onMessagesMarkedAsRead, onRequestScrollToBottomOfMessagesScrollContainer }: MessageListProps): React.ReactNode;
|
|
29
|
+
propTypes: {
|
|
30
|
+
messages: PropTypes.Validator<(object | null | undefined)[]>;
|
|
31
|
+
currentUserId: PropTypes.Validator<number>;
|
|
32
|
+
messagesScrollContainerId: PropTypes.Validator<string>;
|
|
33
|
+
messagesContainerClassName: PropTypes.Requireable<string>;
|
|
34
|
+
failedPendingMessageIconClassName: PropTypes.Requireable<string>;
|
|
35
|
+
failedPendingMessageDescriptionStyles: PropTypes.Requireable<object>;
|
|
36
|
+
failedPendingMessageDescriptionClassName: PropTypes.Requireable<string>;
|
|
37
|
+
onFailedPendingMessageClick: PropTypes.Requireable<(...args: any[]) => any>;
|
|
38
|
+
getLatestMessagesStatus: PropTypes.Requireable<string>;
|
|
39
|
+
markMessagesReadUpTo: PropTypes.Validator<(...args: any[]) => any>;
|
|
40
|
+
shouldMarkMessagesAsRead: PropTypes.Validator<boolean>;
|
|
41
|
+
loadingContent: PropTypes.Validator<string | number | boolean | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
|
|
42
|
+
retryContent: PropTypes.Validator<string | number | boolean | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
|
|
43
|
+
noMessagesContent: PropTypes.Validator<string | number | boolean | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
|
|
44
|
+
onRequestScrollToBottomOfMessagesScrollContainer: PropTypes.Validator<(...args: any[]) => any>;
|
|
45
|
+
};
|
|
46
|
+
};
|