// @flow
import React from 'react';
import { Form, FormField } from 'component/common/form';
import { Modal } from 'modal/modal';
import Button from 'component/button';
import { getSavedPassword, setSavedPassword } from 'util/saved-passwords';

type Props = {
  quit: () => void,
  closeModal: () => void,
  unlockWallet: (?string) => void,
  walletUnlockSucceded: boolean,
  shouldTryWithBlankPassword: boolean,
};

type State = {
  password: string,
  rememberPassword: boolean,
};

class ModalWalletUnlock extends React.PureComponent<Props, State> {
  state = {
    password: '',
    rememberPassword: false,
  };

  componentDidMount() {
    const { unlockWallet, shouldTryWithBlankPassword } = this.props;

    getSavedPassword().then(p => {
      if (p !== null) {
        this.setState({ password: p, rememberPassword: true });
        unlockWallet(p);
      } else if (shouldTryWithBlankPassword) {
        unlockWallet('');
      }
    });
  }
  componentDidUpdate() {
    const { props } = this;

    if (props.walletUnlockSucceded === true) {
      setSavedPassword(this.state.password, this.state.rememberPassword);
      props.closeModal();
    }
  }

  onChangePassword(event: SyntheticInputEvent<*>) {
    this.setState({ password: event.target.value });
  }

  onChangeRememberPassword(event: SyntheticInputEvent<>) {
    this.setState({ rememberPassword: event.target.checked });
  }

  render() {
    const { quit, unlockWallet, walletUnlockSucceded } = this.props;

    const { password, rememberPassword } = this.state;
    return (
      <Modal
        isOpen
        title={__('Unlock Wallet')}
        contentLabel={__('Unlock Wallet')}
        type="confirm"
        shouldCloseOnOverlayClick={false}
        confirmButtonLabel={__('Unlock')}
        abortButtonLabel={__('Exit')}
        onConfirmed={() => unlockWallet(password)}
        onAborted={quit}
      >
        <p>
          {__('Your wallet has been encrypted with a local password. Please enter your wallet password to proceed.')}{' '}
          <Button button="link" label={__('Learn more')} href="https://lbry.com/faq/wallet-encryption" />.
        </p>
        <Form className="section" onSubmit={() => unlockWallet(password)}>
          <FormField
            autoFocus
            error={walletUnlockSucceded === false ? 'Incorrect Password' : false}
            label={__('Wallet Password')}
            type="password"
            name="wallet-password"
            onChange={event => this.onChangePassword(event)}
            value={password || ''}
          />
          <fieldset-section>
            <FormField
              label={__('Remember Password')}
              type="checkbox"
              name="wallet-remember-password"
              onChange={event => this.onChangeRememberPassword(event)}
              checked={rememberPassword}
            />
          </fieldset-section>
        </Form>
      </Modal>
    );
  }
}

export default ModalWalletUnlock;