// @flow import * as PAGES from 'constants/pages'; import * as MODALS from 'constants/modal_types'; import * as ICONS from 'constants/icons'; import * as React from 'react'; import { SETTINGS } from 'lbry-redux'; import { FormField } from 'component/common/form'; import Button from 'component/button'; import Page from 'component/page'; import SettingLanguage from 'component/settingLanguage'; import FileSelector from 'component/common/file-selector'; import SyncToggle from 'component/syncToggle'; import HomepageSelector from 'component/homepageSelector'; import Card from 'component/common/card'; import SettingAccountPassword from 'component/settingAccountPassword'; import classnames from 'classnames'; import { getPasswordFromCookie } from 'util/saved-passwords'; // $FlowFixMe import homepages from 'homepages'; import { Lbryio } from 'lbryinc'; import Yrbl from 'component/yrbl'; type Price = { currency: string, amount: number, }; type SetDaemonSettingArg = boolean | string | number; type DarkModeTimes = { from: { hour: string, min: string, formattedTime: string }, to: { hour: string, min: string, formattedTime: string }, }; type OptionTimes = { fromTo: string, time: string, }; type DaemonSettings = { download_dir: string, share_usage_data: boolean, }; type Props = { setDaemonSetting: (string, ?SetDaemonSettingArg) => void, clearDaemonSetting: (string) => void, setClientSetting: (string, SetDaemonSettingArg) => void, toggle3PAnalytics: (boolean) => void, clearCache: () => Promise, daemonSettings: DaemonSettings, allowAnalytics: boolean, showNsfw: boolean, isAuthenticated: boolean, instantPurchaseEnabled: boolean, instantPurchaseMax: Price, currentTheme: string, themes: Array, automaticDarkModeEnabled: boolean, autoplay: boolean, updateWalletStatus: () => void, walletEncrypted: boolean, confirmForgetPassword: ({}) => void, floatingPlayer: boolean, hideReposts: ?boolean, clearPlayingUri: () => void, darkModeTimes: DarkModeTimes, setDarkTime: (string, {}) => void, openModal: (string) => void, language?: string, enterSettings: () => void, exitSettings: () => void, }; type State = { clearingCache: boolean, storedPassword: boolean, }; class SettingsPage extends React.PureComponent { constructor(props: Props) { super(props); this.state = { clearingCache: false, storedPassword: false, }; (this: any).onThemeChange = this.onThemeChange.bind(this); (this: any).onAutomaticDarkModeChange = this.onAutomaticDarkModeChange.bind(this); (this: any).onChangeTime = this.onChangeTime.bind(this); (this: any).onConfirmForgetPassword = this.onConfirmForgetPassword.bind(this); } componentDidMount() { const { isAuthenticated, enterSettings } = this.props; if (isAuthenticated || !IS_WEB) { this.props.updateWalletStatus(); getPasswordFromCookie().then((p) => { if (typeof p === 'string') { this.setState({ storedPassword: true }); } }); } enterSettings(); } componentWillUnmount() { const { exitSettings } = this.props; exitSettings(); } onThemeChange(event: SyntheticInputEvent<*>) { const { value } = event.target; if (value === 'dark') { this.onAutomaticDarkModeChange(false); } this.props.setClientSetting(SETTINGS.THEME, value); } onAutomaticDarkModeChange(value: boolean) { this.props.setClientSetting(SETTINGS.AUTOMATIC_DARK_MODE_ENABLED, value); } onConfirmForgetPassword() { const { confirmForgetPassword } = this.props; confirmForgetPassword({ callback: () => { this.setState({ storedPassword: false }); }, }); } onChangeTime(event: SyntheticInputEvent<*>, options: OptionTimes) { const { value } = event.target; this.props.setDarkTime(value, options); } to12Hour(time: string) { const now = new Date(0, 0, 0, Number(time)); const hour = now.toLocaleTimeString('en-US', { hour12: true, hour: '2-digit' }); return hour; } setDaemonSetting(name: string, value: ?SetDaemonSettingArg): void { this.props.setDaemonSetting(name, value); } clearDaemonSetting(name: string): void { this.props.clearDaemonSetting(name); } render() { const { daemonSettings, allowAnalytics, showNsfw, isAuthenticated, currentTheme, themes, automaticDarkModeEnabled, autoplay, walletEncrypted, // autoDownload, setDaemonSetting, setClientSetting, toggle3PAnalytics, floatingPlayer, hideReposts, clearPlayingUri, darkModeTimes, clearCache, openModal, } = this.props; const { storedPassword } = this.state; const noDaemonSettings = !daemonSettings || Object.keys(daemonSettings).length === 0; const startHours = ['18', '19', '20', '21']; const endHours = ['5', '6', '7', '8']; return ( } /> {homepages && Object.keys(homepages).length > 1 && ( } /> )} {!isAuthenticated && IS_WEB && (
} /> )} {!IS_WEB && noDaemonSettings ? (
{__('Failed to load settings.')}
) : (
{isAuthenticated && } {/* @if TARGET='app' */} { setDaemonSetting('download_dir', newDirectory.path); }} />

{__('LBRY downloads will be saved here.')}

} /> } /> {/* @endif */} {themes.map((theme) => ( ))} this.onAutomaticDarkModeChange(!automaticDarkModeEnabled)} checked={automaticDarkModeEnabled} label={__('Automatic dark mode')} /> {automaticDarkModeEnabled && ( this.onChangeTime(value, { fromTo: 'from', time: 'hour' })} value={darkModeTimes.from.hour} label={__('From --[initial time]--')} > {startHours.map((time) => ( ))} this.onChangeTime(value, { fromTo: 'to', time: 'hour' })} value={darkModeTimes.to.hour} > {endHours.map((time) => ( ))} )} } /> { setClientSetting(SETTINGS.FLOATING_PLAYER, !floatingPlayer); clearPlayingUri(); }} checked={floatingPlayer} label={__('Floating video player')} helper={__('Keep content playing in the corner when navigating to a different page.')} /> setClientSetting(SETTINGS.AUTOPLAY, !autoplay)} checked={autoplay} label={__('Autoplay media files')} helper={__( 'Autoplay video and audio files when navigating to a file, as well as the next related item when a file finishes playing.' )} /> { if (isAuthenticated) { let param = e.target.checked ? { add: 'noreposts' } : { remove: 'noreposts' }; Lbryio.call('user_tag', 'edit', param); } setClientSetting(SETTINGS.HIDE_REPOSTS, !hideReposts); }} checked={hideReposts} label={__('Hide reposts')} helper={__('You will not see reposts by people you follow or receive email notifying about them.')} /> {/* setClientSetting(SETTINGS.SHOW_ANONYMOUS, !showAnonymous)} checked={showAnonymous} label={__('Show anonymous content')} helper={__('Anonymous content is published without a channel.')} /> */} !IS_WEB || showNsfw ? setClientSetting(SETTINGS.SHOW_MATURE, !showNsfw) : openModal(MODALS.CONFIRM_AGE) } checked={showNsfw} label={__('Show mature content')} helper={__( 'Mature content may include nudity, intense sexuality, profanity, or other adult content. By displaying mature content, you are affirming you are of legal age to view mature content in your country or jurisdiction. ' )} /> } /> {/* @if TARGET='app' */} {__( `This is information like error logging, performance tracking, and usage statistics. It includes your IP address and basic system details, but no other identifying information (unless you sign in to lbry.tv)` )}{' '}
} />