import React from "react"; import FormField from "component/formField"; import { FormRow } from "component/form.js"; import SubHeader from "component/subHeader"; import * as settings from "constants/settings"; import lbry from "lbry.js"; import Link from "component/link"; import FormFieldPrice from "component/formFieldPrice"; import { remote } from "electron"; class SettingsPage extends React.PureComponent { constructor(props) { super(props); const { daemonSettings } = this.props || {}; this.state = { // isMaxUpload: daemonSettings && daemonSettings.max_upload != 0, // isMaxDownload: daemonSettings && daemonSettings.max_download != 0, showUnavailable: lbry.getClientSetting(settings.SHOW_UNAVAILABLE), language: lbry.getClientSetting(settings.LANGUAGE), clearingCache: false, theme: lbry.getClientSetting(settings.THEME), themes: lbry.getClientSetting(settings.THEMES), }; } clearCache() { this.setState({ clearingCache: true, }); const success = () => { this.setState({ clearingCache: false }); window.location.href = `${remote.app.getAppPath()}/dist/index.html`; }; const clear = () => this.props.clearCache().then(success.bind(this)); setTimeout(clear, 1000, { once: true }); } getThemes() { this.props.getThemes(); } setDaemonSetting(name, value) { this.props.setDaemonSetting(name, value); } setClientSetting(name, value) { lbry.setClientSetting(name, value); this._onSettingSaveSuccess(); } setTheme(value) { this.props.setTheme(value); } onRunOnStartChange(event) { this.setDaemonSetting("run_on_startup", event.target.checked); } onShareDataChange(event) { this.setDaemonSetting("share_usage_data", event.target.checked); } onDownloadDirChange(event) { this.setDaemonSetting("download_directory", event.target.value); } onKeyFeeChange(newValue) { this.setDaemonSetting("max_key_fee", newValue); } onKeyFeeDisableChange(isDisabled) { this.setDaemonSetting("disable_max_key_fee", isDisabled); } onThemeChange(event) { const { value } = event.target; this.setTheme(value); } // onMaxUploadPrefChange(isLimited) { // if (!isLimited) { // this.setDaemonSetting("max_upload", 0.0); // } // this.setState({ // isMaxUpload: isLimited, // }); // } // // onMaxUploadFieldChange(event) { // this.setDaemonSetting("max_upload", Number(event.target.value)); // } // // onMaxDownloadPrefChange(isLimited) { // if (!isLimited) { // this.setDaemonSetting("max_download", 0.0); // } // this.setState({ // isMaxDownload: isLimited, // }); // } // // onMaxDownloadFieldChange(event) { // this.setDaemonSetting("max_download", Number(event.target.value)); // } onShowNsfwChange(event) { this.props.setClientSetting(settings.SHOW_NSFW, event.target.checked); } // onLanguageChange(language) { // lbry.setClientSetting('language', language); // i18n.setLocale(language); // this.setState({language: language}) // } onShowUnavailableChange(event) {} componentDidMount() { this.getThemes(); } render() { const { daemonSettings } = this.props; if (!daemonSettings || Object.keys(daemonSettings).length === 0) { return (
{__("Failed to load settings.")}
); } return (

{__("Download Directory")}

{__("Max Purchase Price")}

{ this.onKeyFeeDisableChange(true); }} defaultChecked={daemonSettings.disable_max_key_fee} label={__("No Limit")} />
{ this.onKeyFeeDisableChange(false); }} defaultChecked={!daemonSettings.disable_max_key_fee} label={ daemonSettings.disable_max_key_fee ? __("Choose limit") : __("Limit to") } /> {!daemonSettings.disable_max_key_fee && }
{__( "This will prevent you from purchasing any content over this cost, as a safety measure." )}

{__("Content")}

{__("Share Diagnostic Data")}

{__("Theme")}

{this.state.themes.map((theme, index) => )}

{__("Application Cache")}

); } } export default SettingsPage;