diff --git a/native/account/log-in-panel.react.js b/native/account/log-in-panel.react.js --- a/native/account/log-in-panel.react.js +++ b/native/account/log-in-panel.react.js @@ -37,6 +37,7 @@ setNativeCredentials, } from './native-credentials'; import { PanelButton, Panel } from './panel-components.react'; +import { PasswordInput } from './password-input.react'; export type LogInState = { +usernameInputText: ?string, @@ -59,7 +60,7 @@ }; class LogInPanel extends React.PureComponent { usernameInput: ?TextInput; - passwordInput: ?TextInput; + passwordInput: ?PasswordInput; componentDidMount() { this.attemptToFetchCredentials(); @@ -132,14 +133,14 @@ color="#555" style={styles.icon} /> - void = passwordInput => { + passwordInputRef: (passwordInput: ?PasswordInput) => void = passwordInput => { this.passwordInput = passwordInput; }; @@ -345,6 +346,9 @@ input: { paddingLeft: 35, }, + inputPassword: { + paddingRight: 40, + }, row: { marginHorizontal: 24, }, diff --git a/native/account/password-input.react.js b/native/account/password-input.react.js new file mode 100644 --- /dev/null +++ b/native/account/password-input.react.js @@ -0,0 +1,79 @@ +// @flow + +import invariant from 'invariant'; +import * as React from 'react'; +import { TextInput as BaseTextInput, View, StyleSheet } from 'react-native'; + +import Button from '../components/button.react'; +import SWMansionIcon from '../components/swmansion-icon.react'; +import { TextInput } from './modal-components.react'; + +type Props = React.ElementConfig; + +type State = { + +secureTextEntry: boolean, +}; + +class PasswordInput extends React.PureComponent { + wrappedTextInput: ?TextInput; + constructor(props: Props) { + super(props); + this.state = { secureTextEntry: true }; + } + + buttonOnclick: () => void = () => { + this.setState(state => ({ + secureTextEntry: !state.secureTextEntry, + })); + }; + + render(): React.Node { + return ( + + + + + ); + } + + wrappedTextInputRef: ( + wrappedTextInput: ?TextInput, + ) => void = wrappedTextInput => { + this.wrappedTextInput = wrappedTextInput; + }; + + focus() { + invariant(this.wrappedTextInput, 'ref should exist'); + this.wrappedTextInput.focus(); + } +} + +const styles = StyleSheet.create({ + button: { + borderRadius: 21, + bottom: 0, + margin: 2, + padding: 8, + position: 'absolute', + right: 10, + }, +}); + +export { PasswordInput };