You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
1.7 KiB
TypeScript
59 lines
1.7 KiB
TypeScript
import React, { useContext, useLayoutEffect, useState } from 'react';
|
|
import { useSelector } from 'react-redux';
|
|
import styled from 'styled-components';
|
|
import { getQuotedMessageToAnimate } from '../../state/selectors/conversations';
|
|
import { ScrollToLoadedMessageContext } from './SessionMessagesListContainer';
|
|
|
|
const LastSeenBarContainer = styled.div`
|
|
padding-bottom: 35px;
|
|
margin-inline-start: 10rem;
|
|
margin-inline-end: 10rem;
|
|
padding-top: 28px;
|
|
overflow: hidden;
|
|
`;
|
|
|
|
const LastSeenBar = styled.div`
|
|
width: 100%;
|
|
height: 2px;
|
|
background-color: var(--color-last-seen-indicator);
|
|
`;
|
|
|
|
const LastSeenText = styled.div`
|
|
margin-top: 3px;
|
|
font-size: 11px;
|
|
line-height: 26px;
|
|
letter-spacing: 0.3px;
|
|
text-transform: uppercase;
|
|
text-align: center;
|
|
|
|
color: var(--color-last-seen-indicator-text);
|
|
`;
|
|
|
|
export const SessionLastSeenIndicator = (props: { messageId: string }) => {
|
|
// if this unread-indicator is not unique it's going to cause issues
|
|
const [didScroll, setDidScroll] = useState(false);
|
|
const quotedMessageToAnimate = useSelector(getQuotedMessageToAnimate);
|
|
|
|
const scrollToLoadedMessage = useContext(ScrollToLoadedMessageContext);
|
|
|
|
// if this unread-indicator is rendered,
|
|
// we want to scroll here only if the conversation was not opened to a specific message
|
|
|
|
useLayoutEffect(() => {
|
|
if (!quotedMessageToAnimate && !didScroll) {
|
|
scrollToLoadedMessage(props.messageId, 'unread-indicator');
|
|
setDidScroll(true);
|
|
} else if (quotedMessageToAnimate) {
|
|
setDidScroll(true);
|
|
}
|
|
});
|
|
|
|
return (
|
|
<LastSeenBarContainer id="unread-indicator">
|
|
<LastSeenBar>
|
|
<LastSeenText>{window.i18n('unreadMessages')}</LastSeenText>
|
|
</LastSeenBar>
|
|
</LastSeenBarContainer>
|
|
);
|
|
};
|