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

42 lines
1.3 KiB
React
Raw Normal View History

2019-10-15 23:23:51 +02:00
// @flow
import * as MODALS from 'constants/modal_types';
2019-10-15 23:23:51 +02:00
import React from 'react';
import SettingsRow from 'component/settingsRow';
import { withRouter } from 'react-router';
import { FormField } from 'component/common/form';
2019-10-15 23:23:51 +02:00
type Props = {
setSyncEnabled: (boolean) => void,
2019-10-15 23:23:51 +02:00
syncEnabled: boolean,
history: { push: (string) => void },
location: UrlLocation,
getSyncError: ?string,
disabled: boolean,
openModal: (string, any) => void,
2019-10-15 23:23:51 +02:00
};
function SyncToggle(props: Props) {
// Redesign for new sync system
const { openModal, syncEnabled, disabled } = props;
2019-10-15 23:23:51 +02:00
return (
<SettingsRow title={__('Sync')} subtitle={disabled ? '' : __('Sync your balance and preferences across devices.')}>
<FormField
type="checkbox"
name="sync_toggle"
label={disabled ? __('Sync your balance and preferences across devices.') : undefined}
checked={syncEnabled}
onChange={() => openModal(MODALS.SYNC_ENABLE, { mode: syncEnabled ? 'disable' : 'enable' })}
disabled={disabled}
helper={
disabled
? __("To enable Sync, close LBRY completely and check 'Remember Password' during wallet unlock.")
: null
}
/>
</SettingsRow>
2019-10-15 23:23:51 +02:00
);
}
export default withRouter(SyncToggle);