@livelike/react-native
Version:
LiveLike React Native package
148 lines (147 loc) • 5.59 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.LLChatMessageList = LLChatMessageList;
var _react = _interopRequireWildcard(require("react"));
var _reactNative = require("react-native");
var _hooks = require("../../hooks");
var _LLChatMessageItem = require("../LLChatMessageItem");
var _LLMessageListEmptyComponent = require("./LLMessageListEmptyComponent");
var _LLLoadActionButton = require("../LLLoadActionButton");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
const listItemKeyExtractor = message => message.id;
function LLChatMessageList(_ref) {
let {
roomId,
styles: stylesProp,
MessageListComponent = _reactNative.FlatList,
MessageItemComponent = _LLChatMessageItem.LLChatMessageItem,
MessageListEmptyComponent = _LLMessageListEmptyComponent.LLMessageListEmptyComponent,
LoadPrevButtonComponent = _LLLoadActionButton.LLLoadActionButtonComponent,
MessageItemComponentStyles,
MessageListLoadingComponent,
MessageListEmptyComponentStyles
} = _ref;
const listRef = (0, _react.useRef)(null);
const userReactionsLoadedRef = (0, _react.useRef)(false);
const {
chatMessages,
chatMessagesLoaded,
messageListIterator
} = (0, _hooks.useChatRoomState)({
roomId
});
const {
onContentSizeChangeHandler,
onScrollEndDrag
} = (0, _hooks.useAutoScroll)({
ref: listRef
});
const messageListStyles = (0, _hooks.useStyles)({
componentStylesFn: getMessageListStyles,
stylesProp
});
const {
theme
} = (0, _hooks.useTheme)();
const {
reactionSpace
} = (0, _hooks.useReactionSpace)({
targetGroupId: roomId
});
(0, _hooks.useChatMessagesEffect)({
roomId
});
(0, _hooks.useLoadReactionPacksEffect)({
reactionSpaceId: reactionSpace === null || reactionSpace === void 0 ? void 0 : reactionSpace.id
});
(0, _hooks.useUserReactionsEffect)({
reactionSpaceId: reactionSpace === null || reactionSpace === void 0 ? void 0 : reactionSpace.id
});
const {
loadPrevMessages
} = (0, _hooks.useChatRoomActions)({
roomId
});
const targetIds = (0, _react.useMemo)(() => chatMessages === null || chatMessages === void 0 ? void 0 : chatMessages.map(_ref2 => {
let {
id
} = _ref2;
return id;
}), [chatMessages]);
const {
loadUserReactions
} = (0, _hooks.useLoadUserReactions)({
reactionSpaceId: reactionSpace === null || reactionSpace === void 0 ? void 0 : reactionSpace.id
});
(0, _react.useEffect)(() => {
if (!(targetIds !== null && targetIds !== void 0 && targetIds.length) || userReactionsLoadedRef.current) {
return;
}
loadUserReactions({
targetIds
});
userReactionsLoadedRef.current = true;
}, [targetIds]);
const renderLoadPrevMessagesButton = (0, _react.useCallback)(() => {
if (!messageListIterator) {
return null;
}
return /*#__PURE__*/_react.default.createElement(LoadPrevButtonComponent, {
label: "Load previous messages",
actionInProgressLabel: "Loading previous messages",
onPress: loadPrevMessages
});
}, [messageListIterator, loadPrevMessages]);
const renderListItem = (0, _react.useCallback)(_ref3 => {
let {
item
} = _ref3;
return /*#__PURE__*/_react.default.createElement(MessageItemComponent, {
message: item,
styles: MessageItemComponentStyles
});
}, [MessageItemComponentStyles]);
const renderListLoadingComponent = MessageListLoadingComponent ? /*#__PURE__*/_react.default.createElement(MessageListLoadingComponent, null) : /*#__PURE__*/_react.default.createElement(_reactNative.ActivityIndicator, {
size: 'large',
color: theme.text,
style: messageListStyles.listLoadingIndicator
});
return /*#__PURE__*/_react.default.createElement(_reactNative.View, {
style: messageListStyles.rootContainer
}, !chatMessagesLoaded ? renderListLoadingComponent : /*#__PURE__*/_react.default.createElement(MessageListComponent, {
ref: listRef,
contentContainerStyle: {
flexGrow: 1
},
ListEmptyComponent: /*#__PURE__*/_react.default.createElement(MessageListEmptyComponent, {
styles: MessageListEmptyComponentStyles
}),
data: chatMessages,
renderItem: renderListItem,
keyExtractor: listItemKeyExtractor,
onContentSizeChange: onContentSizeChangeHandler,
onScrollEndDrag: onScrollEndDrag,
ListHeaderComponent: renderLoadPrevMessagesButton,
maintainVisibleContentPosition: {
minIndexForVisible: 0
}
}));
}
const getMessageListStyles = _ref4 => {
let {
theme
} = _ref4;
return _reactNative.StyleSheet.create({
rootContainer: {
display: 'flex',
flex: 1,
justifyContent: 'center',
marginBottom: 10
},
listLoadingIndicator: {}
});
};
//# sourceMappingURL=LLChatMessageList.js.map