|
|
|
@ -1,5 +1,5 @@
|
|
|
|
|
import classNames from 'classnames';
|
|
|
|
|
import { isEmpty, noop } from 'lodash';
|
|
|
|
|
import { isEmpty } from 'lodash';
|
|
|
|
|
import moment from 'moment';
|
|
|
|
|
import React, { createContext, useCallback, useContext, useLayoutEffect, useState } from 'react';
|
|
|
|
|
import { InView } from 'react-intersection-observer';
|
|
|
|
@ -17,7 +17,6 @@ import {
|
|
|
|
|
getQuotedMessageToAnimate,
|
|
|
|
|
getShouldHighlightMessage,
|
|
|
|
|
} from '../../../../state/selectors/conversations';
|
|
|
|
|
import { getIsAppFocused } from '../../../../state/selectors/section';
|
|
|
|
|
import { useSelectedIsPrivate } from '../../../../state/selectors/selectedConversation';
|
|
|
|
|
import { canDisplayImage } from '../../../../types/Attachment';
|
|
|
|
|
import { ScrollToLoadedMessageContext } from '../../SessionMessagesListContainer';
|
|
|
|
@ -84,8 +83,6 @@ const StyledAvatarContainer = styled.div`
|
|
|
|
|
`;
|
|
|
|
|
|
|
|
|
|
export const MessageContent = (props: Props) => {
|
|
|
|
|
const isAppFocused = useSelector(getIsAppFocused);
|
|
|
|
|
|
|
|
|
|
const [highlight, setHighlight] = useState(false);
|
|
|
|
|
const [didScroll, setDidScroll] = useState(false);
|
|
|
|
|
const contentProps = useSelector((state: StateType) =>
|
|
|
|
@ -101,7 +98,7 @@ export const MessageContent = (props: Props) => {
|
|
|
|
|
const [imageBroken, setImageBroken] = useState(false);
|
|
|
|
|
|
|
|
|
|
const onVisible = (inView: boolean, _: IntersectionObserverEntry) => {
|
|
|
|
|
if (isAppFocused && inView) {
|
|
|
|
|
if (inView) {
|
|
|
|
|
if (isMessageVisible !== true) {
|
|
|
|
|
setMessageIsVisible(true);
|
|
|
|
|
}
|
|
|
|
@ -185,7 +182,7 @@ export const MessageContent = (props: Props) => {
|
|
|
|
|
<InView
|
|
|
|
|
id={`inview-content-${props.messageId}`}
|
|
|
|
|
as={'div'}
|
|
|
|
|
onChange={isAppFocused ? onVisible : noop}
|
|
|
|
|
onChange={onVisible}
|
|
|
|
|
threshold={0}
|
|
|
|
|
rootMargin="500px 0px 500px 0px"
|
|
|
|
|
triggerOnce={false}
|
|
|
|
|