stream-chat-react 11.23.8 → 11.23.9

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.
@@ -37030,18 +37030,29 @@ var ACTIONS_NOT_WORKING_IN_THREAD = [
37030
37030
  MESSAGE_ACTIONS.reply,
37031
37031
  MESSAGE_ACTIONS.markUnread,
37032
37032
  ];
37033
- var showMessageActionsBox = function (actions, inThread) {
37034
- if (actions.length === 0) {
37033
+ /**
37034
+ * @deprecated use `shouldRenderMessageActions` instead
37035
+ */
37036
+ var showMessageActionsBox = function (actions, inThread) { return shouldRenderMessageActions({ inThread: inThread, messageActions: actions }); };
37037
+ var shouldRenderMessageActions = function (_a) {
37038
+ var customMessageActions = _a.customMessageActions, CustomMessageActionsList = _a.CustomMessageActionsList, inThread = _a.inThread, messageActions = _a.messageActions;
37039
+ if (typeof CustomMessageActionsList !== 'undefined' ||
37040
+ typeof customMessageActions !== 'undefined')
37041
+ return true;
37042
+ if (!messageActions.length)
37035
37043
  return false;
37036
- }
37037
37044
  if (inThread &&
37038
- actions.filter(function (action) { return !ACTIONS_NOT_WORKING_IN_THREAD.includes(action); }).length === 0) {
37045
+ messageActions.filter(function (action) { return !ACTIONS_NOT_WORKING_IN_THREAD.includes(action); }).length === 0) {
37039
37046
  return false;
37040
37047
  }
37041
- if (actions.length === 1 && (actions.includes('react') || actions.includes('reply'))) {
37048
+ if (messageActions.length === 1 &&
37049
+ (messageActions.includes(MESSAGE_ACTIONS.react) ||
37050
+ messageActions.includes(MESSAGE_ACTIONS.reply))) {
37042
37051
  return false;
37043
37052
  }
37044
- if (actions.length === 2 && actions.includes('react') && actions.includes('reply')) {
37053
+ if (messageActions.length === 2 &&
37054
+ messageActions.includes(MESSAGE_ACTIONS.react) &&
37055
+ messageActions.includes(MESSAGE_ACTIONS.reply)) {
37045
37056
  return false;
37046
37057
  }
37047
37058
  return true;
@@ -39181,7 +39192,8 @@ function useMessageActionsBoxPopper(_a) {
39181
39192
  var MessageActions = function (props) {
39182
39193
  var _a = props.ActionsIcon, ActionsIcon$1 = _a === void 0 ? ActionsIcon : _a, _b = props.customWrapperClass, customWrapperClass = _b === void 0 ? '' : _b, propGetMessageActions = props.getMessageActions, propHandleDelete = props.handleDelete, propHandleFlag = props.handleFlag, propHandleMarkUnread = props.handleMarkUnread, propHandleMute = props.handleMute, propHandlePin = props.handlePin, inline = props.inline, propMessage = props.message, messageWrapperRef = props.messageWrapperRef, mine = props.mine;
39183
39194
  var mutes = useChatContext('MessageActions').mutes;
39184
- var _c = useMessageContext('MessageActions'), customMessageActions = _c.customMessageActions, contextGetMessageActions = _c.getMessageActions, contextHandleDelete = _c.handleDelete, contextHandleFlag = _c.handleFlag, contextHandleMarkUnread = _c.handleMarkUnread, contextHandleMute = _c.handleMute, contextHandlePin = _c.handlePin, isMyMessage = _c.isMyMessage, contextMessage = _c.message, setEditingState = _c.setEditingState;
39195
+ var _c = useMessageContext('MessageActions'), customMessageActions = _c.customMessageActions, contextGetMessageActions = _c.getMessageActions, contextHandleDelete = _c.handleDelete, contextHandleFlag = _c.handleFlag, contextHandleMarkUnread = _c.handleMarkUnread, contextHandleMute = _c.handleMute, contextHandlePin = _c.handlePin, isMyMessage = _c.isMyMessage, contextMessage = _c.message, setEditingState = _c.setEditingState, threadList = _c.threadList;
39196
+ var CustomMessageActionsList = useComponentContext('MessageActions').CustomMessageActionsList;
39185
39197
  var t = useTranslationContext('MessageActions').t;
39186
39198
  var getMessageActions = propGetMessageActions || contextGetMessageActions;
39187
39199
  var handleDelete = propHandleDelete || contextHandleDelete;
@@ -39193,13 +39205,19 @@ var MessageActions = function (props) {
39193
39205
  var isMine = mine ? mine() : isMyMessage();
39194
39206
  var _d = React.useState(false), actionsBoxOpen = _d[0], setActionsBoxOpen = _d[1];
39195
39207
  var isMuted = React.useCallback(function () { return isUserMuted(message, mutes); }, [message, mutes]);
39208
+ var messageActions = getMessageActions();
39209
+ var renderMessageActions = shouldRenderMessageActions({
39210
+ customMessageActions: customMessageActions,
39211
+ CustomMessageActionsList: CustomMessageActionsList,
39212
+ inThread: threadList,
39213
+ messageActions: messageActions,
39214
+ });
39196
39215
  var hideOptions = React.useCallback(function (event) {
39197
39216
  if (event instanceof KeyboardEvent && event.key !== 'Escape') {
39198
39217
  return;
39199
39218
  }
39200
39219
  setActionsBoxOpen(false);
39201
39220
  }, []);
39202
- var messageActions = getMessageActions();
39203
39221
  var messageDeletedAt = !!(message === null || message === void 0 ? void 0 : message.deleted_at);
39204
39222
  React.useEffect(function () {
39205
39223
  if (messageWrapperRef === null || messageWrapperRef === void 0 ? void 0 : messageWrapperRef.current) {
@@ -39227,7 +39245,7 @@ var MessageActions = function (props) {
39227
39245
  placement: isMine ? 'top-end' : 'top-start',
39228
39246
  referenceElement: actionsBoxButtonRef.current,
39229
39247
  }), attributes = _e.attributes, popperElementRef = _e.popperElementRef, styles = _e.styles;
39230
- if (!messageActions.length && !customMessageActions)
39248
+ if (!renderMessageActions)
39231
39249
  return null;
39232
39250
  return (React__default["default"].createElement(MessageActionsWrapper, { customWrapperClass: customWrapperClass, inline: inline, setActionsBoxOpen: setActionsBoxOpen },
39233
39251
  React__default["default"].createElement(MessageActionsBox, exports.__assign({}, attributes.popper, { getMessageActions: getMessageActions, handleDelete: handleDelete, handleEdit: setEditingState, handleFlag: handleFlag, handleMarkUnread: handleMarkUnread, handleMute: handleMute, handlePin: handlePin, isUserMuted: isMuted, mine: isMine, open: actionsBoxOpen, ref: popperElementRef, style: styles.popper })),
@@ -39236,7 +39254,7 @@ var MessageActions = function (props) {
39236
39254
  };
39237
39255
  var MessageActionsWrapper = function (props) {
39238
39256
  var children = props.children, customWrapperClass = props.customWrapperClass, inline = props.inline, setActionsBoxOpen = props.setActionsBoxOpen;
39239
- var defaultWrapperClass = "\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--options\n str-chat__message-actions-container";
39257
+ var defaultWrapperClass = clsx('str-chat__message-simple__actions__action', 'str-chat__message-simple__actions__action--options', 'str-chat__message-actions-container');
39240
39258
  var wrapperClass = customWrapperClass || defaultWrapperClass;
39241
39259
  var onClickOptionsAction = function (event) {
39242
39260
  event.stopPropagation();
@@ -39254,11 +39272,10 @@ var MessageActionsWrapper = function (props) {
39254
39272
 
39255
39273
  var UnMemoizedMessageOptions = function (props) {
39256
39274
  var _a = props.ActionsIcon, ActionsIcon$1 = _a === void 0 ? ActionsIcon : _a, _b = props.displayReplies, displayReplies = _b === void 0 ? true : _b, propHandleOpenThread = props.handleOpenThread, messageWrapperRef = props.messageWrapperRef, _c = props.ReactionIcon, ReactionIcon$1 = _c === void 0 ? ReactionIcon : _c, _d = props.theme, theme = _d === void 0 ? 'simple' : _d, _e = props.ThreadIcon, ThreadIcon$1 = _e === void 0 ? ThreadIcon : _e;
39257
- var _f = useMessageContext('MessageOptions'), customMessageActions = _f.customMessageActions, getMessageActions = _f.getMessageActions, contextHandleOpenThread = _f.handleOpenThread, initialMessage = _f.initialMessage, message = _f.message, onReactionListClick = _f.onReactionListClick, showDetailedReactions = _f.showDetailedReactions, threadList = _f.threadList;
39275
+ var _f = useMessageContext('MessageOptions'), getMessageActions = _f.getMessageActions, contextHandleOpenThread = _f.handleOpenThread, initialMessage = _f.initialMessage, message = _f.message, onReactionListClick = _f.onReactionListClick, showDetailedReactions = _f.showDetailedReactions, threadList = _f.threadList;
39258
39276
  var t = useTranslationContext('MessageOptions').t;
39259
39277
  var handleOpenThread = propHandleOpenThread || contextHandleOpenThread;
39260
39278
  var messageActions = getMessageActions();
39261
- var showActionsBox = showMessageActionsBox(messageActions, threadList) || !!customMessageActions;
39262
39279
  var shouldShowReactions = messageActions.indexOf(MESSAGE_ACTIONS.react) > -1;
39263
39280
  var shouldShowReplies = messageActions.indexOf(MESSAGE_ACTIONS.reply) > -1 && displayReplies && !threadList;
39264
39281
  if (!message.type ||
@@ -39272,7 +39289,7 @@ var UnMemoizedMessageOptions = function (props) {
39272
39289
  }
39273
39290
  var rootClassName = "str-chat__message-".concat(theme, "__actions str-chat__message-options");
39274
39291
  return (React__default["default"].createElement("div", { className: rootClassName, "data-testid": 'message-options' },
39275
- showActionsBox && (React__default["default"].createElement(MessageActions, { ActionsIcon: ActionsIcon$1, messageWrapperRef: messageWrapperRef })),
39292
+ React__default["default"].createElement(MessageActions, { ActionsIcon: ActionsIcon$1, messageWrapperRef: messageWrapperRef }),
39276
39293
  shouldShowReplies && (React__default["default"].createElement("button", { "aria-label": t('aria/Open Thread'), className: "str-chat__message-".concat(theme, "__actions__action str-chat__message-").concat(theme, "__actions__action--thread str-chat__message-reply-in-thread-button"), "data-testid": 'thread-action', onClick: handleOpenThread },
39277
39294
  React__default["default"].createElement(ThreadIcon$1, { className: 'str-chat__message-action-icon' }))),
39278
39295
  shouldShowReactions && (React__default["default"].createElement("button", { "aria-expanded": showDetailedReactions, "aria-label": t('aria/Open Reaction Selector'), className: "str-chat__message-".concat(theme, "__actions__action str-chat__message-").concat(theme, "__actions__action--reactions str-chat__message-reactions-button"), "data-testid": 'message-reaction-action', onClick: onReactionListClick },
@@ -49680,6 +49697,7 @@ exports.renderPreviewText = renderPreviewText;
49680
49697
  exports.renderText = renderText;
49681
49698
  exports.resampleWaveformData = resampleWaveformData;
49682
49699
  exports.ruTranslations = ruTranslations;
49700
+ exports.shouldRenderMessageActions = shouldRenderMessageActions;
49683
49701
  exports.showMessageActionsBox = showMessageActionsBox;
49684
49702
  exports.trTranslations = trTranslations;
49685
49703
  exports.upSample = upSample;
@@ -48182,18 +48182,29 @@ var StreamChatReact = (function (exports, React$2, ReactDOM, streamChat, Picker)
48182
48182
  MESSAGE_ACTIONS.reply,
48183
48183
  MESSAGE_ACTIONS.markUnread,
48184
48184
  ];
48185
- var showMessageActionsBox = function (actions, inThread) {
48186
- if (actions.length === 0) {
48185
+ /**
48186
+ * @deprecated use `shouldRenderMessageActions` instead
48187
+ */
48188
+ var showMessageActionsBox = function (actions, inThread) { return shouldRenderMessageActions({ inThread: inThread, messageActions: actions }); };
48189
+ var shouldRenderMessageActions = function (_a) {
48190
+ var customMessageActions = _a.customMessageActions, CustomMessageActionsList = _a.CustomMessageActionsList, inThread = _a.inThread, messageActions = _a.messageActions;
48191
+ if (typeof CustomMessageActionsList !== 'undefined' ||
48192
+ typeof customMessageActions !== 'undefined')
48193
+ return true;
48194
+ if (!messageActions.length)
48187
48195
  return false;
48188
- }
48189
48196
  if (inThread &&
48190
- actions.filter(function (action) { return !ACTIONS_NOT_WORKING_IN_THREAD.includes(action); }).length === 0) {
48197
+ messageActions.filter(function (action) { return !ACTIONS_NOT_WORKING_IN_THREAD.includes(action); }).length === 0) {
48191
48198
  return false;
48192
48199
  }
48193
- if (actions.length === 1 && (actions.includes('react') || actions.includes('reply'))) {
48200
+ if (messageActions.length === 1 &&
48201
+ (messageActions.includes(MESSAGE_ACTIONS.react) ||
48202
+ messageActions.includes(MESSAGE_ACTIONS.reply))) {
48194
48203
  return false;
48195
48204
  }
48196
- if (actions.length === 2 && actions.includes('react') && actions.includes('reply')) {
48205
+ if (messageActions.length === 2 &&
48206
+ messageActions.includes(MESSAGE_ACTIONS.react) &&
48207
+ messageActions.includes(MESSAGE_ACTIONS.reply)) {
48197
48208
  return false;
48198
48209
  }
48199
48210
  return true;
@@ -50363,7 +50374,8 @@ var StreamChatReact = (function (exports, React$2, ReactDOM, streamChat, Picker)
50363
50374
  window.StreamChat.StreamChat=StreamChat;window.StreamChat.logChatPromiseExecution=logChatPromiseExecution;window.StreamChat.Channel=Channel;window.ICAL=window.ICAL||{};var MessageActions = function (props) {
50364
50375
  var _a = props.ActionsIcon, ActionsIcon$1 = _a === void 0 ? ActionsIcon : _a, _b = props.customWrapperClass, customWrapperClass = _b === void 0 ? '' : _b, propGetMessageActions = props.getMessageActions, propHandleDelete = props.handleDelete, propHandleFlag = props.handleFlag, propHandleMarkUnread = props.handleMarkUnread, propHandleMute = props.handleMute, propHandlePin = props.handlePin, inline = props.inline, propMessage = props.message, messageWrapperRef = props.messageWrapperRef, mine = props.mine;
50365
50376
  var mutes = useChatContext('MessageActions').mutes;
50366
- var _c = useMessageContext('MessageActions'), customMessageActions = _c.customMessageActions, contextGetMessageActions = _c.getMessageActions, contextHandleDelete = _c.handleDelete, contextHandleFlag = _c.handleFlag, contextHandleMarkUnread = _c.handleMarkUnread, contextHandleMute = _c.handleMute, contextHandlePin = _c.handlePin, isMyMessage = _c.isMyMessage, contextMessage = _c.message, setEditingState = _c.setEditingState;
50377
+ var _c = useMessageContext('MessageActions'), customMessageActions = _c.customMessageActions, contextGetMessageActions = _c.getMessageActions, contextHandleDelete = _c.handleDelete, contextHandleFlag = _c.handleFlag, contextHandleMarkUnread = _c.handleMarkUnread, contextHandleMute = _c.handleMute, contextHandlePin = _c.handlePin, isMyMessage = _c.isMyMessage, contextMessage = _c.message, setEditingState = _c.setEditingState, threadList = _c.threadList;
50378
+ var CustomMessageActionsList = useComponentContext('MessageActions').CustomMessageActionsList;
50367
50379
  var t = useTranslationContext('MessageActions').t;
50368
50380
  var getMessageActions = propGetMessageActions || contextGetMessageActions;
50369
50381
  var handleDelete = propHandleDelete || contextHandleDelete;
@@ -50375,13 +50387,19 @@ var StreamChatReact = (function (exports, React$2, ReactDOM, streamChat, Picker)
50375
50387
  var isMine = mine ? mine() : isMyMessage();
50376
50388
  var _d = React$2.useState(false), actionsBoxOpen = _d[0], setActionsBoxOpen = _d[1];
50377
50389
  var isMuted = React$2.useCallback(function () { return isUserMuted(message, mutes); }, [message, mutes]);
50390
+ var messageActions = getMessageActions();
50391
+ var renderMessageActions = shouldRenderMessageActions({
50392
+ customMessageActions: customMessageActions,
50393
+ CustomMessageActionsList: CustomMessageActionsList,
50394
+ inThread: threadList,
50395
+ messageActions: messageActions,
50396
+ });
50378
50397
  var hideOptions = React$2.useCallback(function (event) {
50379
50398
  if (event instanceof KeyboardEvent && event.key !== 'Escape') {
50380
50399
  return;
50381
50400
  }
50382
50401
  setActionsBoxOpen(false);
50383
50402
  }, []);
50384
- var messageActions = getMessageActions();
50385
50403
  var messageDeletedAt = !!(message === null || message === void 0 ? void 0 : message.deleted_at);
50386
50404
  React$2.useEffect(function () {
50387
50405
  if (messageWrapperRef === null || messageWrapperRef === void 0 ? void 0 : messageWrapperRef.current) {
@@ -50409,7 +50427,7 @@ var StreamChatReact = (function (exports, React$2, ReactDOM, streamChat, Picker)
50409
50427
  placement: isMine ? 'top-end' : 'top-start',
50410
50428
  referenceElement: actionsBoxButtonRef.current,
50411
50429
  }), attributes = _e.attributes, popperElementRef = _e.popperElementRef, styles = _e.styles;
50412
- if (!messageActions.length && !customMessageActions)
50430
+ if (!renderMessageActions)
50413
50431
  return null;
50414
50432
  return (React__default["default"].createElement(MessageActionsWrapper, { customWrapperClass: customWrapperClass, inline: inline, setActionsBoxOpen: setActionsBoxOpen },
50415
50433
  React__default["default"].createElement(MessageActionsBox, __assign({}, attributes.popper, { getMessageActions: getMessageActions, handleDelete: handleDelete, handleEdit: setEditingState, handleFlag: handleFlag, handleMarkUnread: handleMarkUnread, handleMute: handleMute, handlePin: handlePin, isUserMuted: isMuted, mine: isMine, open: actionsBoxOpen, ref: popperElementRef, style: styles.popper })),
@@ -50418,7 +50436,7 @@ var StreamChatReact = (function (exports, React$2, ReactDOM, streamChat, Picker)
50418
50436
  };
50419
50437
  var MessageActionsWrapper = function (props) {
50420
50438
  var children = props.children, customWrapperClass = props.customWrapperClass, inline = props.inline, setActionsBoxOpen = props.setActionsBoxOpen;
50421
- var defaultWrapperClass = "\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--options\n str-chat__message-actions-container";
50439
+ var defaultWrapperClass = clsx('str-chat__message-simple__actions__action', 'str-chat__message-simple__actions__action--options', 'str-chat__message-actions-container');
50422
50440
  var wrapperClass = customWrapperClass || defaultWrapperClass;
50423
50441
  var onClickOptionsAction = function (event) {
50424
50442
  event.stopPropagation();
@@ -50438,11 +50456,10 @@ var StreamChatReact = (function (exports, React$2, ReactDOM, streamChat, Picker)
50438
50456
 
50439
50457
  window.StreamChat.StreamChat=StreamChat;window.StreamChat.logChatPromiseExecution=logChatPromiseExecution;window.StreamChat.Channel=Channel;window.ICAL=window.ICAL||{};var UnMemoizedMessageOptions = function (props) {
50440
50458
  var _a = props.ActionsIcon, ActionsIcon$1 = _a === void 0 ? ActionsIcon : _a, _b = props.displayReplies, displayReplies = _b === void 0 ? true : _b, propHandleOpenThread = props.handleOpenThread, messageWrapperRef = props.messageWrapperRef, _c = props.ReactionIcon, ReactionIcon$1 = _c === void 0 ? ReactionIcon : _c, _d = props.theme, theme = _d === void 0 ? 'simple' : _d, _e = props.ThreadIcon, ThreadIcon$1 = _e === void 0 ? ThreadIcon : _e;
50441
- var _f = useMessageContext('MessageOptions'), customMessageActions = _f.customMessageActions, getMessageActions = _f.getMessageActions, contextHandleOpenThread = _f.handleOpenThread, initialMessage = _f.initialMessage, message = _f.message, onReactionListClick = _f.onReactionListClick, showDetailedReactions = _f.showDetailedReactions, threadList = _f.threadList;
50459
+ var _f = useMessageContext('MessageOptions'), getMessageActions = _f.getMessageActions, contextHandleOpenThread = _f.handleOpenThread, initialMessage = _f.initialMessage, message = _f.message, onReactionListClick = _f.onReactionListClick, showDetailedReactions = _f.showDetailedReactions, threadList = _f.threadList;
50442
50460
  var t = useTranslationContext('MessageOptions').t;
50443
50461
  var handleOpenThread = propHandleOpenThread || contextHandleOpenThread;
50444
50462
  var messageActions = getMessageActions();
50445
- var showActionsBox = showMessageActionsBox(messageActions, threadList) || !!customMessageActions;
50446
50463
  var shouldShowReactions = messageActions.indexOf(MESSAGE_ACTIONS.react) > -1;
50447
50464
  var shouldShowReplies = messageActions.indexOf(MESSAGE_ACTIONS.reply) > -1 && displayReplies && !threadList;
50448
50465
  if (!message.type ||
@@ -50456,7 +50473,7 @@ var StreamChatReact = (function (exports, React$2, ReactDOM, streamChat, Picker)
50456
50473
  }
50457
50474
  var rootClassName = "str-chat__message-".concat(theme, "__actions str-chat__message-options");
50458
50475
  return (React__default["default"].createElement("div", { className: rootClassName, "data-testid": 'message-options' },
50459
- showActionsBox && (React__default["default"].createElement(MessageActions, { ActionsIcon: ActionsIcon$1, messageWrapperRef: messageWrapperRef })),
50476
+ React__default["default"].createElement(MessageActions, { ActionsIcon: ActionsIcon$1, messageWrapperRef: messageWrapperRef }),
50460
50477
  shouldShowReplies && (React__default["default"].createElement("button", { "aria-label": t('aria/Open Thread'), className: "str-chat__message-".concat(theme, "__actions__action str-chat__message-").concat(theme, "__actions__action--thread str-chat__message-reply-in-thread-button"), "data-testid": 'thread-action', onClick: handleOpenThread },
50461
50478
  React__default["default"].createElement(ThreadIcon$1, { className: 'str-chat__message-action-icon' }))),
50462
50479
  shouldShowReactions && (React__default["default"].createElement("button", { "aria-expanded": showDetailedReactions, "aria-label": t('aria/Open Reaction Selector'), className: "str-chat__message-".concat(theme, "__actions__action str-chat__message-").concat(theme, "__actions__action--reactions str-chat__message-reactions-button"), "data-testid": 'message-reaction-action', onClick: onReactionListClick },
@@ -63163,7 +63180,7 @@ var StreamChatReact = (function (exports, React$2, ReactDOM, streamChat, Picker)
63163
63180
 
63164
63181
  window.StreamChat.StreamChat=StreamChat;window.StreamChat.logChatPromiseExecution=logChatPromiseExecution;window.StreamChat.Channel=Channel;window.ICAL=window.ICAL||{};
63165
63182
 
63166
- window.StreamChat.StreamChat=StreamChat;window.StreamChat.logChatPromiseExecution=logChatPromiseExecution;window.StreamChat.Channel=Channel;window.ICAL=window.ICAL||{};var version$1 = '11.23.8';
63183
+ window.StreamChat.StreamChat=StreamChat;window.StreamChat.logChatPromiseExecution=logChatPromiseExecution;window.StreamChat.Channel=Channel;window.ICAL=window.ICAL||{};var version$1 = '11.23.9';
63167
63184
 
63168
63185
  window.StreamChat.StreamChat=StreamChat;window.StreamChat.logChatPromiseExecution=logChatPromiseExecution;window.StreamChat.Channel=Channel;window.ICAL=window.ICAL||{};var useChat = function (_a) {
63169
63186
  var _b, _c;
@@ -97543,6 +97560,7 @@ bitsperframe: %d
97543
97560
  exports.renderText = renderText;
97544
97561
  exports.resampleWaveformData = resampleWaveformData;
97545
97562
  exports.ruTranslations = ruTranslations;
97563
+ exports.shouldRenderMessageActions = shouldRenderMessageActions;
97546
97564
  exports.showMessageActionsBox = showMessageActionsBox;
97547
97565
  exports.trTranslations = trTranslations;
97548
97566
  exports.upSample = upSample;