2018-03-29 20:43:47 -04:00
|
|
|
// @flow
|
2019-08-27 10:43:42 -04:00
|
|
|
import React, { useState } from 'react';
|
2019-07-08 12:51:53 -04:00
|
|
|
import { FormField, Form } from 'component/common/form';
|
|
|
|
import Button from 'component/button';
|
2019-08-14 12:28:13 -04:00
|
|
|
import analytics from 'analytics';
|
2019-09-26 12:28:08 -04:00
|
|
|
import { EMAIL_REGEX } from 'constants/email';
|
2020-02-24 15:54:40 -05:00
|
|
|
import I18nMessage from 'component/i18nMessage';
|
2017-06-01 20:51:52 -04:00
|
|
|
|
2018-03-29 20:43:47 -04:00
|
|
|
type Props = {
|
|
|
|
errorMessage: ?string,
|
|
|
|
isPending: boolean,
|
|
|
|
addUserEmail: string => void,
|
2019-09-26 12:28:08 -04:00
|
|
|
syncEnabled: boolean,
|
|
|
|
setSync: boolean => void,
|
|
|
|
balance: number,
|
2020-02-24 15:43:07 -05:00
|
|
|
daemonSettings: { share_usage_data: boolean },
|
|
|
|
setShareDiagnosticData: boolean => void,
|
2018-03-29 20:43:47 -04:00
|
|
|
};
|
|
|
|
|
2019-08-27 10:43:42 -04:00
|
|
|
function UserEmailNew(props: Props) {
|
2020-02-24 15:43:07 -05:00
|
|
|
const { errorMessage, isPending, addUserEmail, setSync, daemonSettings, setShareDiagnosticData } = props;
|
|
|
|
const { share_usage_data: shareUsageData } = daemonSettings;
|
2019-08-27 10:43:42 -04:00
|
|
|
const [newEmail, setEmail] = useState('');
|
2020-02-24 15:43:07 -05:00
|
|
|
const [localShareUsageData, setLocalShareUsageData] = React.useState(false);
|
2019-10-15 17:23:51 -04:00
|
|
|
const [formSyncEnabled, setFormSyncEnabled] = useState(true);
|
2019-09-26 12:07:11 -04:00
|
|
|
const valid = newEmail.match(EMAIL_REGEX);
|
2017-06-01 20:51:52 -04:00
|
|
|
|
2020-02-24 15:43:07 -05:00
|
|
|
function handleUsageDataChange() {
|
2020-02-25 10:16:33 -05:00
|
|
|
setLocalShareUsageData(!localShareUsageData);
|
2020-02-24 15:43:07 -05:00
|
|
|
}
|
|
|
|
|
2019-08-27 10:43:42 -04:00
|
|
|
function handleSubmit() {
|
2019-10-15 17:23:51 -04:00
|
|
|
setSync(formSyncEnabled);
|
2019-08-27 10:43:42 -04:00
|
|
|
addUserEmail(newEmail);
|
2020-02-24 15:47:27 -05:00
|
|
|
// @if TARGET='app'
|
2020-02-24 15:43:07 -05:00
|
|
|
setShareDiagnosticData(true);
|
2020-02-24 15:47:27 -05:00
|
|
|
// @endif
|
2019-08-14 12:28:13 -04:00
|
|
|
analytics.emailProvidedEvent();
|
2017-06-01 20:51:52 -04:00
|
|
|
}
|
|
|
|
|
2019-08-27 10:43:42 -04:00
|
|
|
return (
|
2019-10-15 17:23:51 -04:00
|
|
|
<React.Fragment>
|
2019-11-13 13:14:19 -05:00
|
|
|
<h1 className="section__title--large">{__('Sign In to lbry.tv')}</h1>
|
|
|
|
<p className="section__subtitle">
|
|
|
|
{/* @if TARGET='web' */}
|
|
|
|
{__('Create a new account or sign in.')}
|
|
|
|
{/* @endif */}
|
|
|
|
{/* @if TARGET='app' */}
|
|
|
|
{__('An account with lbry.tv allows you to earn rewards and backup your data.')}
|
|
|
|
{/* @endif */}
|
|
|
|
</p>
|
2019-09-26 12:07:11 -04:00
|
|
|
<Form onSubmit={handleSubmit} className="section__body">
|
|
|
|
<FormField
|
|
|
|
autoFocus
|
|
|
|
placeholder={__('hotstuff_96@hotmail.com')}
|
|
|
|
type="email"
|
2019-09-26 12:28:08 -04:00
|
|
|
name="sign_up_email"
|
2019-09-26 12:07:11 -04:00
|
|
|
label={__('Email')}
|
|
|
|
value={newEmail}
|
|
|
|
error={errorMessage}
|
|
|
|
onChange={e => setEmail(e.target.value)}
|
|
|
|
/>
|
2019-10-15 17:23:51 -04:00
|
|
|
|
|
|
|
{!IS_WEB && (
|
2019-09-30 15:52:53 -04:00
|
|
|
<FormField
|
|
|
|
type="checkbox"
|
2019-10-15 17:23:51 -04:00
|
|
|
name="sync_checkbox"
|
2019-10-03 17:40:54 -04:00
|
|
|
label={
|
2019-10-15 17:23:51 -04:00
|
|
|
<React.Fragment>
|
2019-11-13 13:14:19 -05:00
|
|
|
{__('Backup your account and wallet data.')}{' '}
|
2019-10-15 17:23:51 -04:00
|
|
|
<Button button="link" href="https://lbry.com/faq/account-sync" label={__('Learn More')} />
|
|
|
|
</React.Fragment>
|
|
|
|
}
|
|
|
|
checked={formSyncEnabled}
|
|
|
|
onChange={() => setFormSyncEnabled(!formSyncEnabled)}
|
2019-09-30 15:52:53 -04:00
|
|
|
/>
|
2019-10-15 17:23:51 -04:00
|
|
|
)}
|
2020-02-24 15:43:07 -05:00
|
|
|
|
2020-02-24 15:47:27 -05:00
|
|
|
{!shareUsageData && !IS_WEB && (
|
2020-02-24 15:43:07 -05:00
|
|
|
<FormField
|
|
|
|
type="checkbox"
|
|
|
|
name="share_data_checkbox"
|
|
|
|
checked={localShareUsageData}
|
|
|
|
onChange={handleUsageDataChange}
|
|
|
|
label={
|
|
|
|
<React.Fragment>
|
|
|
|
{__('Share usage data with LBRY inc.')}{' '}
|
2020-02-24 16:28:38 -05:00
|
|
|
<Button button="link" href="https://lbry.com/faq/privacy-and-data" label={__('Learn More')} />
|
2020-02-24 15:43:07 -05:00
|
|
|
{!localShareUsageData && <span className="error-text"> ({__('Required')})</span>}
|
|
|
|
</React.Fragment>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
)}
|
2019-10-15 17:23:51 -04:00
|
|
|
<div className="card__actions">
|
2020-02-24 15:43:07 -05:00
|
|
|
<Button
|
|
|
|
button="primary"
|
|
|
|
type="submit"
|
|
|
|
label={__('Continue')}
|
2020-02-25 20:16:34 -05:00
|
|
|
disabled={!newEmail || !valid || (!IS_WEB && (!localShareUsageData && !shareUsageData)) || isPending}
|
2020-02-24 15:43:07 -05:00
|
|
|
/>
|
2019-09-26 12:07:11 -04:00
|
|
|
</div>
|
|
|
|
</Form>
|
2020-02-24 15:54:40 -05:00
|
|
|
{/* @if TARGET='web' */}
|
|
|
|
<p className="help">
|
|
|
|
<React.Fragment>
|
|
|
|
<I18nMessage
|
|
|
|
tokens={{
|
|
|
|
terms: (
|
|
|
|
<Button
|
|
|
|
tabIndex="2"
|
|
|
|
button="link"
|
|
|
|
href="https://www.lbry.com/termsofservice"
|
|
|
|
label={__('Terms of Service')}
|
|
|
|
/>
|
|
|
|
),
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
By continuing, I agree to the %terms% and confirm I am over the age of 13.
|
|
|
|
</I18nMessage>
|
|
|
|
</React.Fragment>
|
|
|
|
</p>
|
|
|
|
{/* @endif */}
|
2019-10-15 17:23:51 -04:00
|
|
|
</React.Fragment>
|
2019-08-27 10:43:42 -04:00
|
|
|
);
|
2017-06-01 20:51:52 -04:00
|
|
|
}
|
|
|
|
|
2017-06-08 17:15:34 -04:00
|
|
|
export default UserEmailNew;
|