2017-06-06 17:19:12 -04:00
import React from "react" ;
2017-08-06 18:24:55 -04:00
import FormField from "component/formField" ;
import { FormRow } from "component/form.js" ;
2017-06-06 17:19:12 -04:00
import SubHeader from "component/subHeader" ;
2017-08-18 13:09:40 -04:00
import * as settings from "constants/settings" ;
2017-06-06 17:19:12 -04:00
import lbry from "lbry.js" ;
2017-06-16 12:43:43 +07:00
import Link from "component/link" ;
2017-08-06 18:24:55 -04:00
import FormFieldPrice from "component/formFieldPrice" ;
2017-08-06 18:55:31 -06:00
import { remote } from "electron" ;
2017-05-28 16:09:56 +02:00
2017-06-07 21:42:19 -07:00
class SettingsPage extends React . PureComponent {
2017-05-17 04:10:25 -04:00
constructor ( props ) {
super ( props ) ;
2017-06-02 12:40:26 -04:00
2017-05-17 21:37:39 -04:00
this . state = {
2017-09-08 01:03:37 -04:00
instantPurchaseEnabled : props . instantPurchaseEnabled ,
instantPurchaseMax : props . instantPurchaseMax ,
2017-06-16 12:43:43 +07:00
clearingCache : false ,
2017-06-06 17:19:12 -04:00
} ;
2017-05-17 04:10:25 -04:00
}
2017-06-16 12:43:43 +07:00
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 } ) ;
}
2017-05-17 04:10:25 -04:00
setDaemonSetting ( name , value ) {
2017-06-06 17:19:12 -04:00
this . props . setDaemonSetting ( name , value ) ;
2017-05-17 04:10:25 -04:00
}
onRunOnStartChange ( event ) {
2017-06-06 17:19:12 -04:00
this . setDaemonSetting ( "run_on_startup" , event . target . checked ) ;
2017-05-17 04:10:25 -04:00
}
onShareDataChange ( event ) {
2017-06-06 17:19:12 -04:00
this . setDaemonSetting ( "share_usage_data" , event . target . checked ) ;
2017-05-17 04:10:25 -04:00
}
onDownloadDirChange ( event ) {
2017-06-06 17:19:12 -04:00
this . setDaemonSetting ( "download_directory" , event . target . value ) ;
2017-05-17 04:10:25 -04:00
}
2017-08-06 18:24:55 -04:00
onKeyFeeChange ( newValue ) {
this . setDaemonSetting ( "max_key_fee" , newValue ) ;
2017-05-17 04:10:25 -04:00
}
2017-07-03 00:07:20 +05:30
onKeyFeeDisableChange ( isDisabled ) {
this . setDaemonSetting ( "disable_max_key_fee" , isDisabled ) ;
2017-05-17 04:10:25 -04:00
}
2017-08-04 19:36:36 -06:00
onThemeChange ( event ) {
2017-08-12 12:46:10 -06:00
const { value } = event . target ;
2017-09-06 20:52:34 -04:00
this . props . setClientSetting ( settings . THEME , value ) ;
2017-08-04 19:36:36 -06:00
}
2017-09-08 01:03:37 -04:00
oninstantPurchaseEnabledChange ( enabled ) {
this . props . setClientSetting ( settings . INSTANT _PURCHASE _ENABLED , enabled ) ;
this . setState ( {
instantPurchaseEnabled : enabled ,
} ) ;
}
onInstantPurchaseMaxChange ( newValue ) {
this . props . setClientSetting ( settings . INSTANT _PURCHASE _MAX , newValue ) ;
this . setState ( {
instantPurchaseMax : newValue ,
} ) ;
}
2017-07-24 18:15:51 -04:00
// 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));
// }
2017-05-17 17:52:45 -04:00
2017-05-17 04:10:25 -04:00
onShowNsfwChange ( event ) {
2017-08-18 13:09:40 -04:00
this . props . setClientSetting ( settings . SHOW _NSFW , event . target . checked ) ;
2017-05-17 04:10:25 -04:00
}
2017-07-07 15:15:45 +02:00
onLanguageChange ( e ) {
2017-07-07 15:26:03 +02:00
this . props . changeLanguage ( e . target . value ) ;
2017-08-23 00:50:59 +01:00
this . forceUpdate ( ) ;
2017-07-02 21:13:37 +02:00
}
2017-09-06 21:53:42 -04:00
onShowUnavailableChange ( event ) {
this . props . setClientSetting (
settings . SHOW _UNAVAILABLE ,
event . target . checked
) ;
}
2017-04-12 10:55:19 -04:00
2017-08-24 10:29:54 -06:00
componentWillMount ( ) {
2017-09-06 20:52:34 -04:00
this . props . getThemes ( ) ;
2017-08-24 10:29:54 -06:00
}
2017-08-19 17:59:48 -06:00
componentDidMount ( ) { }
2017-08-06 21:01:10 -06:00
2017-05-17 04:10:25 -04:00
render ( ) {
2017-09-06 21:53:42 -04:00
const {
daemonSettings ,
language ,
languages ,
showNsfw ,
2017-09-08 01:03:37 -04:00
instantPurchaseEnabled ,
instantPurchaseMax ,
2017-09-06 21:53:42 -04:00
showUnavailable ,
theme ,
themes ,
} = this . props ;
2017-05-17 17:52:45 -04:00
2017-07-26 15:20:18 +07:00
if ( ! daemonSettings || Object . keys ( daemonSettings ) . length === 0 ) {
2017-06-06 17:19:12 -04:00
return (
< main className = "main--single-column" >
< span className = "empty" > { _ _ ( "Failed to load settings." ) } < / span >
< / main >
) ;
2016-04-09 20:00:56 -04:00
}
return (
2017-04-30 20:15:21 -04:00
< main className = "main--single-column" >
2017-05-05 12:48:15 +07:00
< SubHeader / >
2017-08-30 12:43:35 -04:00
{ / *
2017-07-02 21:13:37 +02:00
< section className = "card" >
< div className = "card__content" >
< h3 > { _ _ ( "Language" ) } < / h3 >
< / div >
< div className = "card__content" >
< div className = "form-row" >
< FormField
2017-08-19 14:03:51 -04:00
type = "select"
2017-07-02 21:13:37 +02:00
name = "language"
2017-08-24 13:33:41 -04:00
defaultValue = { language }
2017-07-07 15:37:24 +02:00
onChange = { this . onLanguageChange . bind ( this ) }
2017-08-19 14:03:51 -04:00
>
< option value = "en" > { _ _ ( "English" ) } < / option >
{ Object . keys ( languages ) . map ( dLang =>
2017-08-24 13:33:41 -04:00
< option key = { dLang } value = { dLang } >
2017-08-19 14:03:51 -04:00
{ languages [ dLang ] }
< / option >
) }
< / FormField >
2017-07-02 21:13:37 +02:00
< / div >
< / div >
2017-08-30 12:43:35 -04:00
< / section > * / }
2016-08-07 18:45:26 -04:00
< section className = "card" >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
2017-05-26 08:40:35 +02:00
< h3 > { _ _ ( "Download Directory" ) } < / h3 >
2017-04-10 08:32:40 -04:00
< / div >
< div className = "card__content" >
2017-06-06 17:19:12 -04:00
< FormRow
type = "directory"
name = "download_directory"
defaultValue = { daemonSettings . download _directory }
helper = { _ _ ( "LBRY downloads will be saved here." ) }
onChange = { this . onDownloadDirChange . bind ( this ) }
/ >
2017-04-10 08:32:40 -04:00
< / div >
2016-04-09 20:00:56 -04:00
< / section >
2016-08-07 18:45:26 -04:00
< section className = "card" >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
2017-09-08 01:03:37 -04:00
< h3 > { _ _ ( "Purchase Settings" ) } < / h3 >
2017-04-10 08:32:40 -04:00
< / div >
< div className = "card__content" >
2017-09-22 18:31:23 -04:00
< div className = "form-row__label-row" >
< label className = "form-row__label" >
{ _ _ ( "Max Purchase Price" ) }
< / label >
< / div >
2017-06-06 17:19:12 -04:00
< FormRow
type = "radio"
2017-07-03 00:07:20 +05:30
name = "max_key_fee"
onClick = { ( ) => {
this . onKeyFeeDisableChange ( true ) ;
2017-06-06 17:19:12 -04:00
} }
2017-07-03 00:07:20 +05:30
defaultChecked = { daemonSettings . disable _max _key _fee }
label = { _ _ ( "No Limit" ) }
2017-06-06 17:19:12 -04:00
/ >
2017-04-12 10:55:19 -04:00
< div className = "form-row" >
2017-06-06 17:19:12 -04:00
< FormField
type = "radio"
2017-07-03 00:07:20 +05:30
name = "max_key_fee"
onClick = { ( ) => {
this . onKeyFeeDisableChange ( false ) ;
2017-06-06 17:19:12 -04:00
} }
2017-07-03 00:07:20 +05:30
defaultChecked = { ! daemonSettings . disable _max _key _fee }
2017-06-06 17:19:12 -04:00
label = {
2017-07-03 00:07:20 +05:30
daemonSettings . disable _max _key _fee
? _ _ ( "Choose limit" )
: _ _ ( "Limit to" )
2017-06-06 17:19:12 -04:00
}
/ >
2017-08-06 18:24:55 -04:00
{ ! daemonSettings . disable _max _key _fee &&
< FormFieldPrice
min = "0"
step = "1"
onChange = { this . onKeyFeeChange . bind ( this ) }
defaultValue = {
daemonSettings . max _key _fee
? daemonSettings . max _key _fee
: { currency : "USD" , amount : 50 }
}
/ > }
2017-04-12 10:55:19 -04:00
< / div >
2017-07-03 00:07:20 +05:30
< div className = "form-field__helper" >
{ _ _ (
2017-07-25 10:07:17 -04:00
"This will prevent you from purchasing any content over this cost, as a safety measure."
2017-07-03 00:07:20 +05:30
) }
2017-04-12 10:55:19 -04:00
< / div >
2016-08-07 23:31:21 -04:00
< / div >
2017-09-08 01:03:37 -04:00
< div className = "card__content" >
2017-09-22 18:31:23 -04:00
< div className = "form-row__label-row" >
< label className = "form-row__label" >
{ _ _ ( "Purchase Confirmations" ) }
< / label >
< / div >
< FormRow
2017-09-08 01:03:37 -04:00
type = "radio"
name = "instant_purchase_max"
checked = { ! this . state . instantPurchaseEnabled }
label = { _ _ ( "Ask for confirmation of all purchases" ) }
onClick = { e => {
this . oninstantPurchaseEnabledChange ( false ) ;
} }
/ >
< div className = "form-row" >
< FormField
type = "radio"
name = "instant_purchase_max"
checked = { this . state . instantPurchaseEnabled }
label = {
"Single-click purchasing of content less than" +
( this . state . instantPurchaseEnabled ? "" : "..." )
}
onClick = { e => {
this . oninstantPurchaseEnabledChange ( true ) ;
} }
/ >
{ this . state . instantPurchaseEnabled &&
< FormFieldPrice
min = "0.1"
step = "0.1"
onChange = { val => this . onInstantPurchaseMaxChange ( val ) }
defaultValue = { this . state . instantPurchaseMax }
/ > }
< / div >
< div className = "form-field__helper" >
When this option is chosen , LBRY won ' t ask you to confirm
downloads below the given price .
< / div >
< / div >
2016-04-09 20:00:56 -04:00
< / section >
2017-07-03 00:07:20 +05:30
2016-08-22 15:19:04 -04:00
< section className = "card" >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
2017-05-26 08:40:35 +02:00
< h3 > { _ _ ( "Content" ) } < / h3 >
2016-08-22 16:56:52 -04:00
< / div >
2017-04-10 14:12:07 -04:00
< div className = "card__content" >
2017-06-06 17:19:12 -04:00
< FormRow
type = "checkbox"
onChange = { this . onShowUnavailableChange . bind ( this ) }
2017-09-06 21:53:42 -04:00
defaultChecked = { showUnavailable }
2017-06-06 17:19:12 -04:00
label = { _ _ ( "Show unavailable content in search results" ) }
/ >
2017-01-19 04:58:11 -05:00
< / div >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
2017-06-06 17:19:12 -04:00
< FormRow
label = { _ _ ( "Show NSFW content" ) }
type = "checkbox"
onChange = { this . onShowNsfwChange . bind ( this ) }
2017-09-06 21:53:42 -04:00
defaultChecked = { showNsfw }
2017-06-06 17:19:12 -04:00
helper = { _ _ (
"NSFW content may include nudity, intense sexuality, profanity, or other adult content. By displaying NSFW content, you are affirming you are of legal age to view mature content in your country or jurisdiction. "
) }
/ >
2017-01-19 04:58:11 -05:00
< / div >
< / section >
2017-06-05 21:21:55 -07:00
2016-08-07 18:45:26 -04:00
< section className = "card" >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
2017-05-26 08:40:35 +02:00
< h3 > { _ _ ( "Share Diagnostic Data" ) } < / h3 >
2017-04-10 08:32:40 -04:00
< / div >
2017-04-10 14:12:07 -04:00
< div className = "card__content" >
2017-06-06 17:19:12 -04:00
< FormRow
type = "checkbox"
onChange = { this . onShareDataChange . bind ( this ) }
defaultChecked = { daemonSettings . share _usage _data }
label = { _ _ (
"Help make LBRY better by contributing diagnostic data about my usage"
) }
/ >
2017-04-10 08:32:40 -04:00
< / div >
2016-04-09 20:00:56 -04:00
< / section >
2017-06-16 12:43:43 +07:00
2017-08-04 19:36:36 -06:00
< section className = "card" >
< div className = "card__content" >
< h3 > { _ _ ( "Theme" ) } < / h3 >
< / div >
< div className = "card__content" >
< FormField
type = "select"
onChange = { this . onThemeChange . bind ( this ) }
2017-09-06 21:53:42 -04:00
defaultValue = { theme }
2017-08-04 19:36:36 -06:00
className = "form-field__input--inline"
>
2017-09-06 21:53:42 -04:00
{ themes . map ( ( theme , index ) =>
2017-09-06 20:52:34 -04:00
< option key = { theme } value = { theme } >
{ theme }
2017-08-19 15:34:45 -06:00
< / option >
2017-08-04 19:36:36 -06:00
) }
< / FormField >
< / div >
< / section >
2017-06-16 12:43:43 +07:00
< section className = "card" >
< div className = "card__content" >
< h3 > { _ _ ( "Application Cache" ) } < / h3 >
< / div >
< div className = "card__content" >
< p >
< Link
label = {
this . state . clearingCache
? _ _ ( "Clearing" )
: _ _ ( "Clear the cache" )
}
icon = "icon-trash"
button = "alt"
onClick = { this . clearCache . bind ( this ) }
disabled = { this . state . clearingCache }
/ >
< / p >
< / div >
< / section >
2017-06-06 17:19:12 -04:00
< / main >
2016-04-09 20:00:56 -04:00
) ;
}
2017-05-17 04:10:25 -04:00
}
2016-11-22 14:19:08 -06:00
export default SettingsPage ;