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.
		
		
		
		
		
			
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			TypeScript
		
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			TypeScript
		
	
| import React from 'react';
 | |
| 
 | |
| import { missingCaseError } from '../../util/missingCaseError';
 | |
| import { PropsForExpirationTimer } from '../../state/ducks/conversations';
 | |
| 
 | |
| import { ExpirableReadableMessage } from './message/message-item/ExpirableReadableMessage';
 | |
| import { SessionIcon } from '../icon';
 | |
| import { SpacerSM, Text } from '../basic/Text';
 | |
| import { Flex } from '../basic/Flex';
 | |
| 
 | |
| export const TimerNotification = (props: PropsForExpirationTimer) => {
 | |
|   const {
 | |
|     messageId,
 | |
|     receivedAt,
 | |
|     isUnread,
 | |
|     pubkey,
 | |
|     profileName,
 | |
|     expirationType,
 | |
|     timespan,
 | |
|     type,
 | |
|     disabled,
 | |
|   } = props;
 | |
| 
 | |
|   const contact = profileName || pubkey;
 | |
|   const mode =
 | |
|     expirationType === 'deleteAfterRead'
 | |
|       ? window.i18n('timerModeRead')
 | |
|       : window.i18n('timerModeSent');
 | |
| 
 | |
|   let textToRender: string | undefined;
 | |
|   switch (type) {
 | |
|     case 'fromOther':
 | |
|       textToRender = disabled
 | |
|         ? window.i18n('disabledDisappearingMessages', [contact, timespan])
 | |
|         : window.i18n('theyChangedTheTimer', [contact, timespan, mode]);
 | |
|       break;
 | |
|     case 'fromMe':
 | |
|     case 'fromSync':
 | |
|       textToRender = disabled
 | |
|         ? window.i18n('youDisabledDisappearingMessages')
 | |
|         : window.i18n('youChangedTheTimer', [timespan, mode]);
 | |
|       break;
 | |
|     default:
 | |
|       throw missingCaseError(type);
 | |
|   }
 | |
| 
 | |
|   if (!textToRender || textToRender.length === 0) {
 | |
|     throw new Error('textToRender invalid key used TimerNotification');
 | |
|   }
 | |
| 
 | |
|   return (
 | |
|     <ExpirableReadableMessage
 | |
|       convoId={props.convoId}
 | |
|       messageId={messageId}
 | |
|       direction={props.direction}
 | |
|       receivedAt={receivedAt}
 | |
|       isUnread={isUnread}
 | |
|       expirationLength={props.expirationLength}
 | |
|       expirationTimestamp={props.expirationTimestamp}
 | |
|       isExpired={props.isExpired}
 | |
|       key={`readable-message-${messageId}`}
 | |
|     >
 | |
|       <Flex
 | |
|         container={true}
 | |
|         flexDirection="column"
 | |
|         alignItems="center"
 | |
|         justifyContent="center"
 | |
|         width="90%"
 | |
|         maxWidth="700px"
 | |
|         margin="10px auto"
 | |
|         padding="5px 10px"
 | |
|       >
 | |
|         <SessionIcon iconType="stopwatch" iconColor="inherit" iconSize="medium" />
 | |
|         <SpacerSM />
 | |
|         <Text text={textToRender} />
 | |
|       </Flex>
 | |
|     </ExpirableReadableMessage>
 | |
|   );
 | |
| };
 |