2018-03-26 23:32:43 +02:00
// @flow
import * as React from 'react' ;
import { FormField , FormFieldPrice } from 'component/common/form' ;
2017-12-21 22:08:54 +01:00
import * as settings from 'constants/settings' ;
2018-03-26 23:32:43 +02:00
import * as icons from 'constants/icons' ;
import Button from 'component/button' ;
import Page from 'component/page' ;
import FileSelector from 'component/common/file-selector' ;
export type Price = {
currency : string ,
amount : number ,
} ;
type DaemonSettings = {
download _directory : string ,
disable _max _key _fee : boolean ,
share _usage _data : boolean ,
} ;
type Props = {
setDaemonSetting : ( string , boolean | string | Price ) => void ,
setClientSetting : ( string , boolean | string | Price ) => void ,
clearCache : ( ) => Promise < any > ,
getThemes : ( ) => void ,
daemonSettings : DaemonSettings ,
showNsfw : boolean ,
instantPurchaseEnabled : boolean ,
instantPurchaseMax : Price ,
showUnavailable : boolean ,
currentTheme : string ,
themes : Array < string > ,
automaticDarkModeEnabled : boolean ,
} ;
type State = {
clearingCache : boolean ,
} ;
class SettingsPage extends React . PureComponent < Props , State > {
constructor ( props : Props ) {
2017-05-17 10:10:25 +02:00
super ( props ) ;
2017-06-02 18:40:26 +02:00
2017-05-18 03:37:39 +02:00
this . state = {
2017-06-16 07:43:43 +02:00
clearingCache : false ,
2017-06-06 23:19:12 +02:00
} ;
2018-02-08 20:28:46 +01:00
2018-03-26 23:32:43 +02:00
( this : any ) . onDownloadDirChange = this . onDownloadDirChange . bind ( this ) ;
( this : any ) . onKeyFeeChange = this . onKeyFeeChange . bind ( this ) ;
( this : any ) . onInstantPurchaseMaxChange = this . onInstantPurchaseMaxChange . bind ( this ) ;
( this : any ) . onShowNsfwChange = this . onShowNsfwChange . bind ( this ) ;
( this : any ) . onShowUnavailableChange = this . onShowUnavailableChange . bind ( this ) ;
( this : any ) . onShareDataChange = this . onShareDataChange . bind ( this ) ;
( this : any ) . onThemeChange = this . onThemeChange . bind ( this ) ;
( this : any ) . onAutomaticDarkModeChange = this . onAutomaticDarkModeChange . bind ( this ) ;
( this : any ) . clearCache = this . clearCache . bind ( this ) ;
// (this: any).onLanguageChange = this.onLanguageChange.bind(this)
2017-06-16 07:43:43 +02:00
}
2018-03-26 23:32:43 +02:00
componentDidMount ( ) {
this . props . getThemes ( ) ;
2017-05-17 10:10:25 +02:00
}
2018-03-26 23:32:43 +02:00
onRunOnStartChange ( event : SyntheticInputEvent < * > ) {
2017-12-21 22:08:54 +01:00
this . setDaemonSetting ( 'run_on_startup' , event . target . checked ) ;
2017-05-17 10:10:25 +02:00
}
2018-03-26 23:32:43 +02:00
onShareDataChange ( event : SyntheticInputEvent < * > ) {
2017-12-21 22:08:54 +01:00
this . setDaemonSetting ( 'share_usage_data' , event . target . checked ) ;
2017-05-17 10:10:25 +02:00
}
2018-03-26 23:32:43 +02:00
onDownloadDirChange ( newDirectory : string ) {
this . setDaemonSetting ( 'download_directory' , newDirectory ) ;
2017-05-17 10:10:25 +02:00
}
2018-03-26 23:32:43 +02:00
onKeyFeeChange ( newValue : Price ) {
this . setDaemonSetting ( 'max_key_fee' , newValue ) ;
2017-05-17 10:10:25 +02:00
}
2018-03-26 23:32:43 +02:00
onKeyFeeDisableChange ( isDisabled : boolean ) {
2017-12-21 22:08:54 +01:00
this . setDaemonSetting ( 'disable_max_key_fee' , isDisabled ) ;
2017-05-17 10:10:25 +02:00
}
2018-03-26 23:32:43 +02:00
onThemeChange ( event : SyntheticInputEvent < * > ) {
2017-08-12 20:46:10 +02:00
const { value } = event . target ;
2018-02-08 20:28:46 +01:00
if ( value === 'dark' ) {
this . onAutomaticDarkModeChange ( false ) ;
}
2017-09-07 02:52:34 +02:00
this . props . setClientSetting ( settings . THEME , value ) ;
2017-08-05 03:36:36 +02:00
}
2018-03-26 23:32:43 +02:00
onAutomaticDarkModeChange ( value : boolean ) {
2018-02-08 20:28:46 +01:00
this . props . setClientSetting ( settings . AUTOMATIC _DARK _MODE _ENABLED , value ) ;
2018-01-14 10:14:15 +01:00
}
2018-03-26 23:32:43 +02:00
onInstantPurchaseEnabledChange ( enabled : boolean ) {
2017-09-08 07:03:37 +02:00
this . props . setClientSetting ( settings . INSTANT _PURCHASE _ENABLED , enabled ) ;
}
2018-03-26 23:32:43 +02:00
onInstantPurchaseMaxChange ( newValue : Price ) {
2017-09-08 07:03:37 +02:00
this . props . setClientSetting ( settings . INSTANT _PURCHASE _MAX , newValue ) ;
}
2018-03-26 23:32:43 +02:00
onShowNsfwChange ( event : SyntheticInputEvent < * > ) {
2017-08-18 19:09:40 +02:00
this . props . setClientSetting ( settings . SHOW _NSFW , event . target . checked ) ;
2017-05-17 10:10:25 +02:00
}
2018-03-26 23:32:43 +02:00
onShowUnavailableChange ( event : SyntheticInputEvent < * > ) {
2017-12-21 22:08:54 +01:00
this . props . setClientSetting ( settings . SHOW _UNAVAILABLE , event . target . checked ) ;
2017-09-07 03:53:42 +02:00
}
2017-04-12 16:55:19 +02:00
2018-03-26 23:32:43 +02:00
setDaemonSetting ( name : string , value : boolean | string | Price ) {
this . props . setDaemonSetting ( name , value ) ;
2017-08-24 18:29:54 +02:00
}
2018-03-26 23:32:43 +02:00
clearCache ( ) {
this . setState ( {
clearingCache : true ,
} ) ;
const success = ( ) => {
this . setState ( { clearingCache : false } ) ;
window . location . href = 'index.html' ;
} ;
const clear = ( ) => this . props . clearCache ( ) . then ( success ) ;
setTimeout ( clear , 1000 , { once : true } ) ;
}
2017-08-07 05:01:10 +02:00
2017-05-17 10:10:25 +02:00
render ( ) {
2017-09-07 03:53:42 +02:00
const {
daemonSettings ,
showNsfw ,
2017-09-08 07:03:37 +02:00
instantPurchaseEnabled ,
instantPurchaseMax ,
2017-09-07 03:53:42 +02:00
showUnavailable ,
2018-03-26 23:32:43 +02:00
currentTheme ,
2017-09-07 03:53:42 +02:00
themes ,
2018-01-14 10:14:15 +01:00
automaticDarkModeEnabled ,
2017-09-07 03:53:42 +02:00
} = this . props ;
2017-05-17 23:52:45 +02:00
2018-03-26 23:32:43 +02:00
const noDaemonSettings = ! daemonSettings || Object . keys ( daemonSettings ) . length === 0 ;
2018-02-08 20:28:46 +01:00
2016-04-10 02:00:56 +02:00
return (
2018-03-26 23:32:43 +02:00
< Page >
{ noDaemonSettings ? (
< section className = "card card--section" >
< div className = "card__title" > { _ _ ( 'Failed to load settings.' ) } < / div >
< / section >
) : (
< React.Fragment >
< section className = "card card--section" >
< div className = "card__title" > { _ _ ( 'Download Directory' ) } < / div >
< span className = "card__subtitle" > { _ _ ( 'LBRY downloads will be saved here.' ) } < / span >
< FileSelector
type = "openDirectory"
currentPath = { daemonSettings . download _directory }
onFileChosen = { this . onDownloadDirChange }
2017-06-06 23:19:12 +02:00
/ >
2018-03-26 23:32:43 +02:00
< / section >
< section className = "card card--section" >
< div className = "card__title" > { _ _ ( 'Max Purchase Price' ) } < / div >
< span className = "card__subtitle" >
{ _ _ (
'This will prevent you from purchasing any content over a certain cost, as a safety measure.'
) }
< / span >
< div className = "card__content" >
< FormField
type = "radio"
name = "no_max_purchase_limit"
checked = { daemonSettings . disable _max _key _fee }
postfix = { _ _ ( 'No Limit' ) }
onChange = { ( ) => {
this . onKeyFeeDisableChange ( true ) ;
} }
/ >
< FormField
type = "radio"
name = "max_purchase_limit"
onChange = { ( ) => {
this . onKeyFeeDisableChange ( false ) ;
} }
checked = { ! daemonSettings . disable _max _key _fee }
postfix = { _ _ ( 'Choose limit' ) }
/ >
2017-08-07 00:24:55 +02:00
< FormFieldPrice
2018-03-26 23:32:43 +02:00
name = "max_key_fee"
label = "Max purchase price"
min = { 0 }
onChange = { this . onKeyFeeChange }
disabled = { daemonSettings . disable _max _key _fee }
price = {
2017-08-07 00:24:55 +02:00
daemonSettings . max _key _fee
? daemonSettings . max _key _fee
2017-12-21 22:08:54 +01:00
: { currency : 'USD' , amount : 50 }
2017-08-07 00:24:55 +02:00
}
2017-11-24 15:31:05 +01:00
/ >
2018-03-26 23:32:43 +02:00
< / div >
< / section >
< section className = "card card--section" >
< div className = "card__title" > { _ _ ( 'Purchase Confirmations' ) } < / div >
< div className = "card__subtitle" >
{ _ _ (
"When this option is chosen, LBRY won't ask you to confirm downloads below your chosen price."
) }
< / div >
< div className = "card__content" >
< FormField
type = "radio"
name = "confirm_all_purchases"
checked = { ! instantPurchaseEnabled }
postfix = { _ _ ( 'Always confirm before purchasing content' ) }
onChange = { ( ) => {
this . onInstantPurchaseEnabledChange ( false ) ;
} }
/ >
< FormField
type = "radio"
name = "instant_purchases"
checked = { instantPurchaseEnabled }
postfix = { _ _ ( 'Only confirm purchases over a certain price' ) }
onChange = { ( ) => {
this . onInstantPurchaseEnabledChange ( true ) ;
} }
/ >
2017-09-08 07:03:37 +02:00
< FormFieldPrice
2018-03-26 23:32:43 +02:00
label = { _ _ ( 'Confirmation price' ) }
disabled = { ! instantPurchaseEnabled }
min = { 0.1 }
onChange = { this . onInstantPurchaseMaxChange }
price = { instantPurchaseMax }
2017-11-24 15:31:05 +01:00
/ >
2018-03-26 23:32:43 +02:00
< / div >
< / section >
< section className = "card card--section" >
< div className = "card__title" > { _ _ ( 'Content Settings' ) } < / div >
< FormField
type = "checkbox"
name = "show_unavailable"
onChange = { this . onShowUnavailableChange }
checked = { showUnavailable }
postfix = { _ _ ( 'Show unavailable content in search results' ) }
/ >
< FormField
type = "checkbox"
name = "show_nsfw"
onChange = { this . onShowNsfwChange }
checked = { showNsfw }
postfix = { _ _ ( 'Show NSFW content' ) }
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-06-16 07:43:43 +02:00
/ >
2018-03-26 23:32:43 +02:00
< / section >
< section className = "card card--section" >
< div className = "card__title" > { _ _ ( 'Share Diagnostic Data' ) } < / div >
< div className = "card__content" >
< FormField
type = "checkbox"
name = "share_usage_data"
onChange = { this . onShareDataChange }
checked = { daemonSettings . share _usage _data }
postfix = { _ _ (
'Help make LBRY better by contributing analytics and diagnostic data about my usage.'
) }
helper = { _ _ (
'You will be ineligible to earn rewards while diagnostics are not being shared.'
) }
/ >
< / div >
< / section >
{
// Hiding this for now until we update the dark mode styles
// <section className="card card--section">
// <div className="card__title">{__('Theme')}</div>
// <FormField
// name="theme_select"
// type="select"
// onChange={this.onThemeChange}
// value={currentTheme}
// disabled={automaticDarkModeEnabled}
// >
// {themes.map(theme => (
// <option key={theme} value={theme}>
// {theme}
// </option>
// ))}
// </FormField>
//
// <FormField
// type="checkbox"
// name="automatic_dark_mode"
// onChange={e => this.onAutomaticDarkModeChange(e.target.checked)}
// checked={automaticDarkModeEnabled}
// postfix={__('Automatic dark mode (9pm to 8am)')}
// />
// </section>
}
< section className = "card card--section" >
< div className = "card__title" > { _ _ ( 'Application Cache' ) } < / div >
< span className = "card__subtitle" >
{ _ _ ( "This will delete your subscriptions, and clar the app's cache" ) }
< / span >
< div className = "card__content" >
< Button
button = "primary"
label = { this . state . clearingCache ? _ _ ( 'Clearing' ) : _ _ ( 'Clear the cache' ) }
icon = { icons . ALERT }
onClick = { this . clearCache }
disabled = { this . state . clearingCache }
/ >
< / div >
< / section >
< / React.Fragment >
) }
< / Page >
2016-04-10 02:00:56 +02:00
) ;
}
2017-05-17 10:10:25 +02:00
}
2016-11-22 21:19:08 +01:00
export default SettingsPage ;