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.
		
		
		
		
		
			
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
| import classNames from 'classnames';
 | |
| import React from 'react';
 | |
| import { MAX_USERNAME_BYTES } from '../../session/constants';
 | |
| import { SessionInput } from '../basic/SessionInput';
 | |
| 
 | |
| const DisplayNameInput = (props: {
 | |
|   stealAutoFocus?: boolean;
 | |
|   displayName: string;
 | |
|   onDisplayNameChanged: (val: string) => any;
 | |
|   handlePressEnter: () => any;
 | |
| }) => {
 | |
|   return (
 | |
|     <SessionInput
 | |
|       autoFocus={props.stealAutoFocus || false}
 | |
|       label={window.i18n('displayName')}
 | |
|       type="text"
 | |
|       placeholder={window.i18n('enterDisplayName')}
 | |
|       value={props.displayName}
 | |
|       maxLength={MAX_USERNAME_BYTES}
 | |
|       onValueChanged={props.onDisplayNameChanged}
 | |
|       onEnterPressed={props.handlePressEnter}
 | |
|       inputDataTestId="display-name-input"
 | |
|     />
 | |
|   );
 | |
| };
 | |
| 
 | |
| const RecoveryPhraseInput = (props: {
 | |
|   recoveryPhrase: string;
 | |
|   onSeedChanged: (val: string) => any;
 | |
|   handlePressEnter: () => any;
 | |
|   stealAutoFocus?: boolean;
 | |
| }) => {
 | |
|   return (
 | |
|     <SessionInput
 | |
|       label={window.i18n('recoveryPhrase')}
 | |
|       type="password"
 | |
|       value={props.recoveryPhrase}
 | |
|       autoFocus={props.stealAutoFocus || false}
 | |
|       placeholder={window.i18n('enterRecoveryPhrase')}
 | |
|       enableShowHide={true}
 | |
|       onValueChanged={props.onSeedChanged}
 | |
|       onEnterPressed={props.handlePressEnter}
 | |
|       inputDataTestId="recovery-phrase-input"
 | |
|     />
 | |
|   );
 | |
| };
 | |
| 
 | |
| export interface Props {
 | |
|   showDisplayNameField: boolean;
 | |
|   showSeedField: boolean;
 | |
|   stealAutoFocus?: boolean;
 | |
|   recoveryPhrase?: string;
 | |
|   displayName: string;
 | |
|   handlePressEnter: () => any;
 | |
|   onSeedChanged?: (val: string) => any;
 | |
|   onDisplayNameChanged: (val: string) => any;
 | |
| }
 | |
| 
 | |
| export const RegistrationUserDetails = (props: Props) => {
 | |
|   if (props.showSeedField && (props.recoveryPhrase === undefined || !props.onSeedChanged)) {
 | |
|     throw new Error('if show seed is true, we need callback + value');
 | |
|   }
 | |
|   return (
 | |
|     <div className={classNames('session-registration__entry-fields')}>
 | |
|       {props.showSeedField && (
 | |
|         <RecoveryPhraseInput
 | |
|           recoveryPhrase={props.recoveryPhrase as string}
 | |
|           handlePressEnter={props.handlePressEnter}
 | |
|           onSeedChanged={props.onSeedChanged as any}
 | |
|           stealAutoFocus={props.stealAutoFocus}
 | |
|         />
 | |
|       )}
 | |
|       <div className="inputfields">
 | |
|         {props.showDisplayNameField && (
 | |
|           <DisplayNameInput
 | |
|             stealAutoFocus={!props.showSeedField && props.stealAutoFocus}
 | |
|             displayName={props.displayName}
 | |
|             handlePressEnter={props.handlePressEnter}
 | |
|             onDisplayNameChanged={props.onDisplayNameChanged}
 | |
|           />
 | |
|         )}
 | |
|       </div>
 | |
|     </div>
 | |
|   );
 | |
| };
 |