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.
		
		
		
		
		
			
		
			
				
	
	
		
			124 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			TypeScript
		
	
			
		
		
	
	
			124 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			TypeScript
		
	
| import { useSelector } from 'react-redux';
 | |
| import styled from 'styled-components';
 | |
| import { getLeftPaneConversationIdsCount } from '../state/selectors/conversations';
 | |
| import { useIsDarkTheme } from '../state/selectors/theme';
 | |
| import { isSignWithRecoveryPhrase } from '../util/storage';
 | |
| import { Flex } from './basic/Flex';
 | |
| import { Spacer2XL, SpacerXS } from './basic/Text';
 | |
| import { Localizer } from './basic/Localizer';
 | |
| 
 | |
| const StyledPlaceholder = styled(Flex)`
 | |
|   background-color: var(--background-secondary-color);
 | |
|   height: 100%;
 | |
| `;
 | |
| 
 | |
| const StyledSessionFullLogo = styled(Flex)`
 | |
|   img:first-child {
 | |
|     height: 180px;
 | |
|     filter: brightness(0) saturate(100%) invert(75%) sepia(84%) saturate(3272%) hue-rotate(103deg)
 | |
|       brightness(106%) contrast(103%);
 | |
|     -webkit-user-drag: none;
 | |
|   }
 | |
| 
 | |
|   img:nth-child(2) {
 | |
|     margin-top: 10px;
 | |
|     width: 250px;
 | |
|     transition: var(--duration-session-logo-text);
 | |
|     filter: var(--session-logo-text-current-filter);
 | |
|     -webkit-user-drag: none;
 | |
|   }
 | |
| `;
 | |
| 
 | |
| const StyledPartyPopper = styled.img`
 | |
|   height: 180px;
 | |
|   margin: 0 auto;
 | |
|   -webkit-user-drag: none;
 | |
| `;
 | |
| 
 | |
| const StyledP = styled.p`
 | |
|   margin: 0;
 | |
|   padding: 0;
 | |
|   text-align: center;
 | |
| `;
 | |
| 
 | |
| const StyledHeading = styled(StyledP)`
 | |
|   margin: 0 0 var(--margins-md);
 | |
|   line-height: 1;
 | |
|   font-size: 48px;
 | |
|   font-weight: 700;
 | |
| `;
 | |
| 
 | |
| const StyledSessionWelcome = styled(StyledP)<{ color: string }>`
 | |
|   line-height: 1;
 | |
|   color: ${props => props.color};
 | |
|   font-size: 32px;
 | |
| `;
 | |
| 
 | |
| const StyledHR = styled.hr`
 | |
|   color: var(--text-secondary-color);
 | |
|   opacity: 0.5;
 | |
|   width: 300px;
 | |
|   border-width: 1px;
 | |
|   margin: 40px 0 var(--margins-lg);
 | |
| `;
 | |
| 
 | |
| const StyledNoConversations = styled(StyledP)`
 | |
|   font-size: 24px;
 | |
|   font-weight: 700;
 | |
| `;
 | |
| 
 | |
| export const EmptyMessageView = () => {
 | |
|   const isDarkTheme = useIsDarkTheme();
 | |
|   const conversationCount = useSelector(getLeftPaneConversationIdsCount);
 | |
|   const isSignInWithRecoveryPhrase = isSignWithRecoveryPhrase();
 | |
| 
 | |
|   const launchCount = window.getSettingValue('launch-count');
 | |
|   const newAccountCreated = !isSignInWithRecoveryPhrase && (!launchCount || launchCount < 1);
 | |
| 
 | |
|   return (
 | |
|     <StyledPlaceholder
 | |
|       container={true}
 | |
|       width={'100%'}
 | |
|       className="content"
 | |
|       flexDirection="column"
 | |
|       justifyContent="center"
 | |
|       alignItems="center"
 | |
|     >
 | |
|       {newAccountCreated ? (
 | |
|         <>
 | |
|           <StyledPartyPopper src="images/party-popper.svg" alt="party popper emoji" />
 | |
|           <Spacer2XL />
 | |
|           <StyledHeading>{window.i18n('onboardingAccountCreated')}</StyledHeading>
 | |
|           <StyledSessionWelcome
 | |
|             color={isDarkTheme ? 'var(--primary-color)' : 'var(--text-primary-color)'}
 | |
|           >
 | |
|             <Localizer token="onboardingBubbleWelcomeToSession" args={{ emoji: '👋' }} />
 | |
|           </StyledSessionWelcome>
 | |
|         </>
 | |
|       ) : (
 | |
|         <StyledSessionFullLogo
 | |
|           container={true}
 | |
|           className="content"
 | |
|           flexDirection="column"
 | |
|           justifyContent="center"
 | |
|           alignItems="center"
 | |
|           margin="0 auto"
 | |
|         >
 | |
|           <img src="images/session/brand.svg" alt="full-brand-logo" />
 | |
|           <img src="images/session/session-text.svg" alt="full-brand-text" />
 | |
|         </StyledSessionFullLogo>
 | |
|       )}
 | |
|       {!conversationCount ? (
 | |
|         <>
 | |
|           <StyledHR />
 | |
|           <StyledNoConversations data-testid="empty-conversation">
 | |
|             {window.i18n('conversationsNone')}
 | |
|           </StyledNoConversations>
 | |
|           <SpacerXS />
 | |
|           <StyledP style={{ width: '360px' }}>{window.i18n('onboardingHitThePlusButton')}</StyledP>
 | |
|         </>
 | |
|       ) : null}
 | |
|     </StyledPlaceholder>
 | |
|   );
 | |
| };
 |