2016-11-22 14:19:08 -06:00
import React from 'react' ;
2017-04-10 08:32:40 -04:00
import { FormField , FormRow } from '../component/form.js' ;
2017-04-23 16:56:50 +07:00
import { SubHeader } from '../component/sub-header.js' ;
2016-11-22 14:19:08 -06:00
import lbry from '../lbry.js' ;
2017-04-27 09:17:18 -04:00
export let SettingsNav = React . createClass ( {
render : function ( ) {
return < SubHeader modifier = "constrained" viewingPage = { this . props . viewingPage } links = { {
'?settings' : 'Settings' ,
'?help' : 'Help'
} } / > ;
}
} ) ;
2016-04-09 20:00:56 -04:00
var SettingsPage = React . createClass ( {
2017-04-12 10:55:19 -04:00
_onSettingSaveSuccess : function ( ) {
// This is bad.
// document.dispatchEvent(new CustomEvent('globalNotice', {
// detail: {
// message: "Settings saved",
// },
// }))
} ,
setDaemonSetting : function ( name , value ) {
lbry . setDaemonSetting ( name , value , this . _onSettingSaveSuccess )
} ,
setClientSetting : function ( name , value ) {
lbry . setClientSetting ( name , value )
this . _onSettingSaveSuccess ( )
2017-04-26 23:54:53 -04:00
} ,
2016-04-09 20:00:56 -04:00
onRunOnStartChange : function ( event ) {
2017-04-12 10:55:19 -04:00
this . setDaemonSetting ( 'run_on_startup' , event . target . checked ) ;
2016-04-09 20:00:56 -04:00
} ,
onShareDataChange : function ( event ) {
2017-04-27 08:40:29 -04:00
this . setDaemonSetting ( 'share_usage_stats' , event . target . checked ) ;
2016-04-09 20:00:56 -04:00
} ,
onDownloadDirChange : function ( event ) {
2017-04-12 10:55:19 -04:00
this . setDaemonSetting ( 'download_directory' , event . target . value ) ;
2016-04-09 20:00:56 -04:00
} ,
onMaxUploadPrefChange : function ( isLimited ) {
if ( ! isLimited ) {
2017-04-12 10:55:19 -04:00
this . setDaemonSetting ( 'max_upload' , 0.0 ) ;
2016-04-09 20:00:56 -04:00
}
this . setState ( {
isMaxUpload : isLimited
} ) ;
} ,
onMaxUploadFieldChange : function ( event ) {
2017-04-12 10:55:19 -04:00
this . setDaemonSetting ( 'max_upload' , Number ( event . target . value ) ) ;
2016-04-09 20:00:56 -04:00
} ,
onMaxDownloadPrefChange : function ( isLimited ) {
if ( ! isLimited ) {
2017-04-12 10:55:19 -04:00
this . setDaemonSetting ( 'max_download' , 0.0 ) ;
2016-04-09 20:00:56 -04:00
}
this . setState ( {
isMaxDownload : isLimited
} ) ;
} ,
onMaxDownloadFieldChange : function ( event ) {
2017-04-12 10:55:19 -04:00
this . setDaemonSetting ( 'max_download' , Number ( event . target . value ) ) ;
2016-04-09 20:00:56 -04:00
} ,
getInitialState : function ( ) {
return {
2016-08-22 16:14:58 -04:00
settings : null ,
2017-01-19 04:58:11 -05:00
showNsfw : lbry . getClientSetting ( 'showNsfw' ) ,
showUnavailable : lbry . getClientSetting ( 'showUnavailable' ) ,
2016-04-09 20:00:56 -04:00
}
} ,
componentWillMount : function ( ) {
2017-04-29 21:56:55 -04:00
lbry . getDaemonSettings ( ( settings ) => {
2016-04-09 20:00:56 -04:00
this . setState ( {
2016-08-22 16:14:58 -04:00
daemonSettings : settings ,
2016-04-09 20:00:56 -04:00
isMaxUpload : settings . max _upload != 0 ,
isMaxDownload : settings . max _download != 0
} ) ;
2017-04-29 21:56:55 -04:00
} ) ;
2016-04-09 20:00:56 -04:00
} ,
2016-08-22 15:19:04 -04:00
onShowNsfwChange : function ( event ) {
lbry . setClientSetting ( 'showNsfw' , event . target . checked ) ;
} ,
2017-01-19 04:58:11 -05:00
onShowUnavailableChange : function ( event ) {
2017-04-12 10:55:19 -04:00
2017-01-19 04:58:11 -05:00
} ,
2016-04-09 20:00:56 -04:00
render : function ( ) {
2016-08-22 16:14:58 -04:00
if ( ! this . state . daemonSettings ) {
2016-04-09 20:00:56 -04:00
return null ;
}
2017-04-12 16:23:20 -04:00
/ *
< section className = "card" >
< div className = "card__content" >
< h3 > Run on Startup < / h 3 >
< / d i v >
< div className = "card__content" >
< FormRow type = "checkbox"
onChange = { this . onRunOnStartChange }
defaultChecked = { this . state . daemonSettings . run _on _startup }
label = "Run LBRY automatically when I start my computer" / >
< / d i v >
< / s e c t i o n >
* /
2016-04-09 20:00:56 -04:00
return (
2017-04-30 20:15:21 -04:00
< main className = "main--single-column" >
2017-04-27 09:17:18 -04:00
< SettingsNav viewingPage = "settings" / >
2016-08-07 18:45:26 -04:00
< section className = "card" >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
< h3 > Download Directory < / h 3 >
< / d i v >
< div className = "card__content" >
< FormRow type = "text"
name = "download_directory"
defaultValue = { this . state . daemonSettings . download _directory }
helper = "LBRY downloads will be saved here."
onChange = { this . onDownloadDirChange } / >
< / d i v >
2016-04-09 20:00:56 -04:00
< / s e c t i o n >
2016-08-07 18:45:26 -04:00
< section className = "card" >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
< h3 > Bandwidth Limits < / h 3 >
< / d i v >
< div className = "card__content" >
2017-04-12 10:55:19 -04:00
< div className = "form-row__label-row" > < div className = "form-field__label" > Max Upload < / d i v > < / d i v >
2017-04-10 14:12:07 -04:00
< FormRow type = "radio"
2017-04-10 08:32:40 -04:00
name = "max_upload_pref"
2017-04-29 21:56:55 -04:00
onChange = { ( ) => { this . onMaxUploadPrefChange ( false ) } }
2017-04-10 08:32:40 -04:00
defaultChecked = { ! this . state . isMaxUpload }
label = "Unlimited" / >
2017-04-12 10:55:19 -04:00
< div className = "form-row" >
< FormField type = "radio"
name = "max_upload_pref"
2017-04-29 21:56:55 -04:00
onChange = { ( ) => { this . onMaxUploadPrefChange ( true ) } }
2017-04-12 10:55:19 -04:00
defaultChecked = { this . state . isMaxUpload }
label = { this . state . isMaxUpload ? 'Up to' : 'Choose limit...' } / >
{ this . state . isMaxUpload ?
< FormField type = "number"
min = "0"
step = ".5"
defaultValue = { this . state . daemonSettings . max _upload }
placeholder = "10"
className = "form-field__input--inline"
onChange = { this . onMaxUploadFieldChange }
/ >
: ''
}
{ this . state . isMaxUpload ? < span className = "form-field__label" > MB / s < / s p a n > : ' ' }
< / d i v >
2016-08-07 23:31:21 -04:00
< / d i v >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
2017-04-12 10:55:19 -04:00
< div className = "form-row__label-row" > < div className = "form-field__label" > Max Download < / d i v > < / d i v >
< FormRow label = "Unlimited"
2017-04-10 14:12:07 -04:00
type = "radio"
name = "max_download_pref"
2017-04-29 21:56:55 -04:00
onChange = { ( ) => { this . onMaxDownloadPrefChange ( false ) } }
2017-04-10 14:12:07 -04:00
defaultChecked = { ! this . state . isMaxDownload } / >
2017-04-12 10:55:19 -04:00
< div className = "form-row" >
< FormField type = "radio"
name = "max_download_pref"
2017-04-29 21:56:55 -04:00
onChange = { ( ) => { this . onMaxDownloadPrefChange ( true ) } }
2017-04-12 10:55:19 -04:00
defaultChecked = { this . state . isMaxDownload }
label = { this . state . isMaxDownload ? 'Up to' : 'Choose limit...' } / >
{ this . state . isMaxDownload ?
< FormField type = "number"
min = "0"
step = ".5"
defaultValue = { this . state . daemonSettings . max _download }
placeholder = "10"
className = "form-field__input--inline"
onChange = { this . onMaxDownloadFieldChange }
/ >
: ''
}
{ this . state . isMaxDownload ? < span className = "form-field__label" > MB / s < / s p a n > : ' ' }
< / d i v >
2016-08-07 23:31:21 -04:00
< / d i v >
2016-04-09 20:00:56 -04:00
< / s e c t i o n >
2016-08-22 15:19:04 -04:00
< section className = "card" >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
< h3 > Content < / h 3 >
2016-08-22 16:56:52 -04:00
< / d i v >
2017-04-10 14:12:07 -04:00
< div className = "card__content" >
2017-04-10 08:32:40 -04:00
< FormRow type = "checkbox"
onChange = { this . onShowUnavailableChange }
defaultChecked = { this . state . showUnavailable }
label = "Show unavailable content in search results" / >
2017-01-19 04:58:11 -05:00
< / d i v >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
< FormRow label = "Show NSFW content" type = "checkbox"
onChange = { this . onShowNsfwChange } defaultChecked = { this . state . showNsfw }
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
< / d i v >
< / s e c t i o n >
2016-08-07 18:45:26 -04:00
< section className = "card" >
2017-04-10 08:32:40 -04:00
< div className = "card__content" >
< h3 > Share Diagnostic Data < / h 3 >
< / d i v >
2017-04-10 14:12:07 -04:00
< div className = "card__content" >
2017-04-10 08:32:40 -04:00
< FormRow type = "checkbox"
onChange = { this . onShareDataChange }
2017-04-27 08:40:29 -04:00
defaultChecked = { this . state . daemonSettings . share _usage _stats }
2017-04-10 08:32:40 -04:00
label = "Help make LBRY better by contributing diagnostic data about my usage" / >
< / d i v >
2016-04-09 20:00:56 -04:00
< / s e c t i o n >
< / m a i n >
) ;
}
2016-08-21 15:59:32 -05:00
} ) ;
2016-11-22 14:19:08 -06:00
export default SettingsPage ;