lbry-desktop/ui/component/userEmailNew/view.jsx

128 lines
4 KiB
React
Raw Normal View History

2018-03-29 20:43:47 -04:00
// @flow
2019-08-27 10:43:42 -04:00
import React, { useState } from 'react';
import { FormField, Form } from 'component/common/form';
import Button from 'component/button';
import analytics from 'analytics';
import { EMAIL_REGEX } from 'constants/email';
2020-02-24 15:54:40 -05:00
import I18nMessage from 'component/i18nMessage';
2018-03-29 20:43:47 -04:00
type Props = {
errorMessage: ?string,
isPending: boolean,
addUserEmail: string => void,
syncEnabled: boolean,
setSync: boolean => void,
balance: number,
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) {
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('');
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);
function handleUsageDataChange() {
2020-02-25 10:16:33 -05:00
setLocalShareUsageData(!localShareUsageData);
}
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'
setShareDiagnosticData(true);
2020-02-24 15:47:27 -05:00
// @endif
analytics.emailProvidedEvent();
}
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"
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:47:27 -05:00
{!shareUsageData && !IS_WEB && (
<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')} />
{!localShareUsageData && <span className="error-text"> ({__('Required')})</span>}
</React.Fragment>
}
/>
)}
2019-10-15 17:23:51 -04:00
<div className="card__actions">
<Button
button="primary"
type="submit"
label={__('Continue')}
2020-02-25 20:16:34 -05:00
disabled={!newEmail || !valid || (!IS_WEB && (!localShareUsageData && !shareUsageData)) || isPending}
/>
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-08 17:15:34 -04:00
export default UserEmailNew;