Suggested Avatar: Fix opening avatar for second time not working (#3082)
This commit is contained in:
parent
f13d0218d8
commit
01bd8f8b5b
@ -1,6 +1,6 @@
|
||||
import type { FC } from '../../lib/teact/teact';
|
||||
import React, {
|
||||
memo, useEffect, useMemo, useRef,
|
||||
memo, useCallback, useEffect, useMemo, useRef,
|
||||
} from '../../lib/teact/teact';
|
||||
import { getActions, getGlobal, withGlobal } from '../../global';
|
||||
|
||||
@ -149,19 +149,26 @@ const ActionMessage: FC<OwnProps & StateProps> = ({
|
||||
: undefined;
|
||||
}, [targetUserIds, usersById]);
|
||||
|
||||
const content = renderActionMessageText(
|
||||
lang,
|
||||
message,
|
||||
senderUser,
|
||||
senderChat,
|
||||
targetUsers,
|
||||
targetMessage,
|
||||
targetChatId,
|
||||
topic,
|
||||
{ isEmbedded },
|
||||
observeIntersectionForLoading,
|
||||
observeIntersectionForPlaying,
|
||||
);
|
||||
const renderContent = useCallback(() => {
|
||||
return renderActionMessageText(
|
||||
lang,
|
||||
message,
|
||||
senderUser,
|
||||
senderChat,
|
||||
targetUsers,
|
||||
targetMessage,
|
||||
targetChatId,
|
||||
topic,
|
||||
{ isEmbedded },
|
||||
observeIntersectionForLoading,
|
||||
observeIntersectionForPlaying,
|
||||
);
|
||||
},
|
||||
[
|
||||
isEmbedded, lang, message, observeIntersectionForLoading, observeIntersectionForPlaying, senderChat,
|
||||
senderUser, targetChatId, targetMessage, targetUsers, topic,
|
||||
]);
|
||||
|
||||
const {
|
||||
isContextMenuOpen, contextMenuPosition,
|
||||
handleBeforeContextMenu, handleContextMenu,
|
||||
@ -190,7 +197,7 @@ const ActionMessage: FC<OwnProps & StateProps> = ({
|
||||
}
|
||||
|
||||
if (isEmbedded) {
|
||||
return <span ref={ref} className="embedded-action-message">{content}</span>;
|
||||
return <span ref={ref} className="embedded-action-message">{renderContent()}</span>;
|
||||
}
|
||||
|
||||
function renderGift() {
|
||||
@ -231,12 +238,12 @@ const ActionMessage: FC<OwnProps & StateProps> = ({
|
||||
onMouseDown={handleMouseDown}
|
||||
onContextMenu={handleContextMenu}
|
||||
>
|
||||
{!isSuggestedAvatar && <span className="action-message-content">{content}</span>}
|
||||
{!isSuggestedAvatar && <span className="action-message-content">{renderContent()}</span>}
|
||||
{isGift && renderGift()}
|
||||
{isSuggestedAvatar && (
|
||||
<ActionMessageSuggestedAvatar
|
||||
message={message}
|
||||
content={content}
|
||||
renderContent={renderContent}
|
||||
/>
|
||||
)}
|
||||
{contextMenuPosition && (
|
||||
|
||||
@ -19,12 +19,12 @@ import ConfirmDialog from '../ui/ConfirmDialog';
|
||||
|
||||
type OwnProps = {
|
||||
message: ApiMessage;
|
||||
content?: TextPart;
|
||||
renderContent: () => TextPart | undefined;
|
||||
};
|
||||
|
||||
const ActionMessageSuggestedAvatar: FC<OwnProps> = ({
|
||||
message,
|
||||
content,
|
||||
renderContent,
|
||||
}) => {
|
||||
const {
|
||||
openMediaViewer, uploadProfilePhoto, showNotification,
|
||||
@ -102,7 +102,7 @@ const ActionMessageSuggestedAvatar: FC<OwnProps> = ({
|
||||
withVideo={isVideo}
|
||||
size="jumbo"
|
||||
/>
|
||||
<span>{content}</span>
|
||||
<span>{renderContent()}</span>
|
||||
|
||||
<span className="action-message-button">{lang(isVideo ? 'ViewVideoAction' : 'ViewPhotoAction')}</span>
|
||||
<CropModal
|
||||
@ -115,7 +115,7 @@ const ActionMessageSuggestedAvatar: FC<OwnProps> = ({
|
||||
title={lang('SuggestedVideo')}
|
||||
confirmHandler={handleSetVideo}
|
||||
onClose={closeVideoModal}
|
||||
textParts={content}
|
||||
textParts={renderContent()}
|
||||
/>
|
||||
</span>
|
||||
);
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user