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.
		
		
		
		
		
			
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
| import React from 'react';
 | |
| import { QRCode } from 'react-qr-svg';
 | |
| 
 | |
| import { SessionModal } from './SessionModal';
 | |
| import { SessionButton } from './SessionButton';
 | |
| import { SessionHtmlRenderer } from './SessionHTMLRenderer';
 | |
| 
 | |
| interface Props {
 | |
|   value: string;
 | |
|   onClose: any;
 | |
| }
 | |
| 
 | |
| export class SessionQRModal extends React.Component<Props> {
 | |
|   constructor(props: any) {
 | |
|     super(props);
 | |
|   }
 | |
|   public render() {
 | |
|     const { value, onClose } = this.props;
 | |
| 
 | |
|     const theme = window.Events.getThemeSetting();
 | |
| 
 | |
|     // Foreground equivalent to .session-modal background color
 | |
|     const bgColor = 'rgba(0, 0, 0, 0)';
 | |
|     const fgColor = theme === 'dark' ? '#FFFFFF' : '#1B1B1B';
 | |
| 
 | |
|     return (
 | |
|       <SessionModal
 | |
|         title={window.i18n('QRCodeTitle')}
 | |
|         onOk={() => null}
 | |
|         onClose={onClose}
 | |
|       >
 | |
|         <div className="spacer-sm" />
 | |
| 
 | |
|         <div className="qr-dialog__description text-subtle">
 | |
|           <SessionHtmlRenderer html={window.i18n('QRCodeDescription')} />
 | |
|         </div>
 | |
|         <div className="spacer-lg" />
 | |
| 
 | |
|         <div id="qr">
 | |
|           <QRCode value={value} bgColor={bgColor} fgColor={fgColor} level="L" />
 | |
|         </div>
 | |
| 
 | |
|         <div className="spacer-lg" />
 | |
|         <div className="session-modal__button-group">
 | |
|           <SessionButton text={window.i18n('close')} onClick={onClose} />
 | |
|         </div>
 | |
|       </SessionModal>
 | |
|     );
 | |
|   }
 | |
| }
 |