2018-03-26 23:32:43 +02:00
// @flow
2018-11-26 02:21:25 +01:00
import * as ICONS from 'constants/icons' ;
import * as SETTINGS from 'constants/settings' ;
2018-03-26 23:32:43 +02:00
import * as React from 'react' ;
2019-02-13 17:27:20 +01:00
import { FormField , FormFieldPrice , Form } from 'component/common/form' ;
2018-03-26 23:32:43 +02:00
import Button from 'component/button' ;
import Page from 'component/page' ;
import FileSelector from 'component/common/file-selector' ;
export type Price = {
currency : string ,
amount : number ,
} ;
2019-02-12 18:26:50 +01:00
type SetDaemonSettingArg = boolean | string | number | Price ;
2018-03-26 23:32:43 +02:00
type DaemonSettings = {
2019-02-12 18:26:50 +01:00
download _dir : string ,
2018-03-26 23:32:43 +02:00
share _usage _data : boolean ,
2018-10-13 17:49:47 +02:00
max _key _fee ? : Price ,
2018-03-26 23:32:43 +02:00
} ;
type Props = {
2019-02-12 18:26:50 +01:00
setDaemonSetting : ( string , ? SetDaemonSettingArg ) => void ,
setClientSetting : ( string , SetDaemonSettingArg ) => void ,
2018-03-26 23:32:43 +02:00
clearCache : ( ) => Promise < any > ,
getThemes : ( ) => void ,
daemonSettings : DaemonSettings ,
showNsfw : boolean ,
instantPurchaseEnabled : boolean ,
instantPurchaseMax : Price ,
currentTheme : string ,
themes : Array < string > ,
automaticDarkModeEnabled : boolean ,
2018-05-30 05:18:41 +02:00
autoplay : boolean ,
2018-08-10 16:51:51 +02:00
autoDownload : boolean ,
2018-07-18 21:48:30 +02:00
encryptWallet : ( ) => void ,
decryptWallet : ( ) => void ,
2018-10-13 17:49:47 +02:00
updateWalletStatus : ( ) => void ,
2018-07-18 21:48:30 +02:00
walletEncrypted : boolean ,
2018-08-01 20:49:57 +02:00
osNotificationsEnabled : boolean ,
2018-03-26 23:32:43 +02:00
} ;
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 ) . onKeyFeeChange = this . onKeyFeeChange . bind ( this ) ;
2019-02-12 18:26:50 +01:00
( this : any ) . onKeyFeeDisableChange = this . onKeyFeeDisableChange . bind ( this ) ;
2018-03-26 23:32:43 +02:00
( this : any ) . onInstantPurchaseMaxChange = this . onInstantPurchaseMaxChange . bind ( this ) ;
( this : any ) . onThemeChange = this . onThemeChange . bind ( this ) ;
( this : any ) . onAutomaticDarkModeChange = this . onAutomaticDarkModeChange . bind ( this ) ;
( this : any ) . clearCache = this . clearCache . bind ( this ) ;
2017-06-16 07:43:43 +02:00
}
2018-03-26 23:32:43 +02:00
componentDidMount ( ) {
2018-10-13 17:49:47 +02:00
this . props . getThemes ( ) ;
this . props . updateWalletStatus ( ) ;
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 ) {
2019-02-12 18:26:50 +01:00
if ( isDisabled ) this . setDaemonSetting ( 'max_key_fee' ) ;
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 ) ;
}
2018-11-26 02:21:25 +01: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-11-26 02:21:25 +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 ) {
2018-11-26 02:21:25 +01:00
this . props . setClientSetting ( SETTINGS . INSTANT _PURCHASE _ENABLED , enabled ) ;
2017-09-08 07:03:37 +02:00
}
2018-03-26 23:32:43 +02:00
onInstantPurchaseMaxChange ( newValue : Price ) {
2018-11-26 02:21:25 +01:00
this . props . setClientSetting ( SETTINGS . INSTANT _PURCHASE _MAX , newValue ) ;
2017-09-08 07:03:37 +02:00
}
2018-07-18 21:48:30 +02:00
onChangeEncryptWallet ( ) {
2018-10-13 17:49:47 +02:00
const { decryptWallet , walletEncrypted , encryptWallet } = this . props ;
if ( walletEncrypted ) {
decryptWallet ( ) ;
} else {
encryptWallet ( ) ;
}
2017-08-24 18:29:54 +02:00
}
2019-02-12 18:26:50 +01:00
setDaemonSetting ( name : string , value : ? SetDaemonSettingArg ) : void {
2018-10-13 17:49:47 +02:00
this . props . setDaemonSetting ( name , value ) ;
}
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 ,
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 ,
2018-05-30 05:18:41 +02:00
autoplay ,
2018-07-18 21:48:30 +02:00
walletEncrypted ,
2018-08-01 20:49:57 +02:00
osNotificationsEnabled ,
2018-08-10 16:51:51 +02:00
autoDownload ,
2019-02-13 17:27:20 +01:00
setDaemonSetting ,
setClientSetting ,
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-05-06 22:40:30 +02:00
const isDarkModeEnabled = currentTheme === 'dark' ;
2018-02-08 20:28:46 +01:00
2019-02-12 18:26:50 +01:00
const defaultMaxKeyFee = { currency : 'USD' , amount : 50 } ;
const disableMaxKeyFee = ! ( daemonSettings && daemonSettings . max _key _fee ) ;
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" >
2018-12-19 06:44:53 +01:00
< header className = "card__header" >
< h2 className = "card__title" > { _ _ ( 'Download Directory' ) } < / h2 >
< p className = "card__subtitle" > { _ _ ( 'LBRY downloads will be saved here.' ) } < / p >
< / header >
2018-10-19 22:38:07 +02:00
< div className = "card__content" >
2019-02-13 17:27:20 +01:00
< Form >
< FileSelector
type = "openDirectory"
currentPath = { daemonSettings . download _dir }
2019-02-20 06:20:29 +01:00
onFileChosen = { ( newDirectory : string ) => {
setDaemonSetting ( 'download_dir' , newDirectory ) ;
} }
2019-02-13 17:27:20 +01:00
/ >
< / Form >
2018-10-19 22:38:07 +02:00
< / div >
2018-03-26 23:32:43 +02:00
< / section >
2018-12-19 06:44:53 +01:00
2018-03-26 23:32:43 +02:00
< section className = "card card--section" >
2018-12-19 06:44:53 +01:00
< header className = "card__header" >
< h2 className = "card__title" > { _ _ ( 'Max Purchase Price' ) } < / h2 >
< p className = "card__subtitle" >
{ _ _ (
'This will prevent you from purchasing any content over a certain cost, as a safety measure.'
) }
< / p >
< / header >
2019-02-13 17:27:20 +01:00
< Form className = "card__content" >
2019-02-20 06:20:29 +01:00
< FormField
type = "radio"
name = "no_max_purchase_no_limit"
checked = { disableMaxKeyFee }
label = { _ _ ( 'No Limit' ) }
onChange = { ( ) => {
this . onKeyFeeDisableChange ( true ) ;
} }
/ >
< FormField
type = "radio"
name = "max_purchase_limit"
checked = { ! disableMaxKeyFee }
onChange = { ( ) => {
this . onKeyFeeDisableChange ( false ) ;
this . onKeyFeeChange ( defaultMaxKeyFee ) ;
} }
label = { _ _ ( 'Choose limit' ) }
/ >
2019-02-13 17:27:20 +01:00
2019-02-12 18:26:50 +01:00
{ ! disableMaxKeyFee && (
2018-04-11 00:05:30 +02:00
< FormFieldPrice
name = "max_key_fee"
min = { 0 }
onChange = { this . onKeyFeeChange }
price = {
2019-02-12 18:26:50 +01:00
daemonSettings . max _key _fee ? daemonSettings . max _key _fee : defaultMaxKeyFee
2018-04-11 00:05:30 +02:00
}
/ >
) }
2019-02-13 17:27:20 +01:00
< / Form >
2018-03-26 23:32:43 +02:00
< / section >
2018-12-19 06:44:53 +01:00
2018-03-26 23:32:43 +02:00
< section className = "card card--section" >
2018-12-19 06:44:53 +01:00
< header className = "card__header" >
< h2 className = "card__title" > { _ _ ( 'Purchase Confirmations' ) } < / h2 >
< p className = "card__subtitle" >
{ _ _ (
"When this option is chosen, LBRY won't ask you to confirm downloads below your chosen price."
) }
< / p >
< / header >
2019-02-13 17:27:20 +01:00
< Form className = "card__content" >
2019-02-20 06:20:29 +01:00
< FormField
type = "radio"
name = "confirm_all_purchases"
checked = { ! instantPurchaseEnabled }
label = { _ _ ( 'Always confirm before purchasing content' ) }
onChange = { ( ) => {
this . onInstantPurchaseEnabledChange ( false ) ;
} }
/ >
< FormField
type = "radio"
name = "instant_purchases"
checked = { instantPurchaseEnabled }
label = { _ _ ( 'Only confirm purchases over a certain price' ) }
onChange = { ( ) => {
this . onInstantPurchaseEnabledChange ( true ) ;
} }
/ >
2018-04-11 00:05:30 +02:00
{ instantPurchaseEnabled && (
< FormFieldPrice
2019-02-13 17:27:20 +01:00
name = "confirmation_price"
2018-04-11 00:05:30 +02:00
min = { 0.1 }
onChange = { this . onInstantPurchaseMaxChange }
price = { instantPurchaseMax }
/ >
) }
2019-02-13 17:27:20 +01:00
< / Form >
2018-03-26 23:32:43 +02:00
< / section >
2018-12-19 06:44:53 +01:00
2018-03-26 23:32:43 +02:00
< section className = "card card--section" >
2018-12-19 06:44:53 +01:00
< header className = "card__header" >
< h2 className = "card__title" > { _ _ ( 'Content Settings' ) } < / h2 >
< / header >
2019-02-13 17:27:20 +01:00
< Form className = "card__content" >
< FormField
type = "setting"
name = "show_nsfw"
onChange = { ( ) => setClientSetting ( SETTINGS . SHOW _NSFW , ! showNsfw ) }
checked = { showNsfw }
label = { _ _ ( '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. '
) }
/ >
< / Form >
2018-03-26 23:32:43 +02:00
< / section >
2018-08-01 00:42:54 +02:00
< section className = "card card--section" >
2018-12-19 06:44:53 +01:00
< header className = "card__header" >
< h2 className = "card__title" > { _ _ ( 'Notifications' ) } < / h2 >
< / header >
2019-02-13 17:27:20 +01:00
< Form className = "card__content" >
2018-12-19 06:44:53 +01:00
< FormField
2019-02-13 17:27:20 +01:00
type = "setting"
2018-12-19 06:44:53 +01:00
name = "desktopNotification"
2019-02-13 17:27:20 +01:00
onChange = { ( ) =>
setClientSetting ( SETTINGS . OS _NOTIFICATIONS _ENABLED , ! osNotificationsEnabled )
}
2018-12-19 06:44:53 +01:00
checked = { osNotificationsEnabled }
2019-02-13 17:27:20 +01:00
label = { _ _ ( 'Show Desktop Notifications' ) }
helper = { _ _ (
'Get notified when a publish is confirmed, or when new content is available to watch.'
) }
2018-12-19 06:44:53 +01:00
/ >
2019-02-13 17:27:20 +01:00
< / Form >
2018-08-01 00:42:54 +02:00
< / section >
2018-03-26 23:32:43 +02:00
< section className = "card card--section" >
2018-12-19 06:44:53 +01:00
< header className = "card__header" >
< h2 className = "card__title" > { _ _ ( 'Share Diagnostic Data' ) } < / h2 >
< / header >
2019-02-13 17:27:20 +01:00
< Form className = "card__content" >
2018-12-19 06:44:53 +01:00
< FormField
2019-02-13 17:27:20 +01:00
type = "setting"
2018-12-19 06:44:53 +01:00
name = "share_usage_data"
2019-02-13 17:27:20 +01:00
onChange = { ( ) =>
setDaemonSetting ( 'share_usage_data' , ! daemonSettings . share _usage _data )
}
2018-12-19 06:44:53 +01:00
checked = { daemonSettings . share _usage _data }
2019-02-13 17:27:20 +01:00
label = { _ _ (
2018-12-19 06:44:53 +01:00
'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.'
) }
/ >
2019-02-13 17:27:20 +01:00
< / Form >
2018-03-26 23:32:43 +02:00
< / section >
2018-12-19 06:44:53 +01:00
2018-07-18 21:48:30 +02:00
< section className = "card card--section" >
2018-12-19 06:44:53 +01:00
< header className = "card__header" >
2019-02-13 17:27:20 +01:00
< h2 className = "card__title" > { _ _ ( 'Appearance' ) } < / h2 >
2018-12-19 06:44:53 +01:00
< / header >
2019-02-13 17:27:20 +01:00
< Form className = "card__content" >
< fieldset - section >
2019-01-09 05:29:06 +01:00
< FormField
name = "theme_select"
type = "select"
2019-02-13 17:27:20 +01:00
label = { _ _ ( 'Theme' ) }
2019-01-09 05:29:06 +01:00
onChange = { this . onThemeChange }
value = { currentTheme }
disabled = { automaticDarkModeEnabled }
>
{ themes . map ( theme => (
< option key = { theme } value = { theme } >
{ theme }
< / option >
) ) }
< / FormField >
2019-02-13 17:27:20 +01:00
< / f i e l d s e t - s e c t i o n >
< fieldset - section >
< FormField
type = "setting"
name = "automatic_dark_mode"
onChange = { ( ) => this . onAutomaticDarkModeChange ( ! automaticDarkModeEnabled ) }
checked = { automaticDarkModeEnabled }
disabled = { isDarkModeEnabled }
label = { _ _ ( 'Automatic dark mode (9pm to 8am)' ) }
/ >
< / f i e l d s e t - s e c t i o n >
< / Form >
2018-07-18 21:48:30 +02:00
< / section >
2018-12-19 06:44:53 +01:00
2018-07-18 21:48:30 +02:00
< section className = "card card--section" >
2018-12-19 06:44:53 +01:00
< header className = "card__header" >
< h2 className = "card__title" > { _ _ ( 'Wallet Security' ) } < / h2 >
< / header >
2019-02-13 17:27:20 +01:00
< Form className = "card__content" >
2018-12-19 06:44:53 +01:00
< FormField
2019-02-13 17:27:20 +01:00
type = "setting"
2018-12-19 06:44:53 +01:00
name = "encrypt_wallet"
onChange = { ( ) => this . onChangeEncryptWallet ( ) }
checked = { walletEncrypted }
2019-02-13 17:27:20 +01:00
label = { _ _ ( 'Encrypt my wallet with a custom password.' ) }
2018-12-19 06:44:53 +01:00
helper = {
< React.Fragment >
{ _ _ ( 'Secure your local wallet data with a custom password.' ) } { ' ' }
< strong > { _ _ ( 'Lost passwords cannot be recovered.' ) } < / strong >
< Button
button = "link"
label = { _ _ ( 'Learn more' ) }
href = "https://lbry.io/faq/wallet-encryption"
/ >
.
< / React.Fragment >
}
/ >
2019-02-13 17:27:20 +01:00
< / Form >
2018-08-29 02:05:14 +02:00
< / section >
2018-12-19 06:44:53 +01:00
2019-01-28 21:05:28 +01:00
< section className = "card card--section" >
< header className = "card__header" >
< h2 className = "card__title" > { _ _ ( 'Experimental Settings' ) } < / h2 >
< / header >
2019-02-13 17:27:20 +01:00
< Form className = "card__content" >
< FormField
type = "setting"
name = "auto_download"
onChange = { ( ) => setClientSetting ( SETTINGS . AUTO _DOWNLOAD , ! autoDownload ) }
checked = { autoDownload }
label = { _ _ ( 'Automatically download new content from my subscriptions' ) }
helper = { _ _ (
"The latest file from each of your subscriptions will be downloaded for quick access as soon as it's published."
) }
/ >
< FormField
type = "setting"
name = "autoplay"
onChange = { ( ) => 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.'
) }
/ >
< / Form >
2019-01-28 21:05:28 +01:00
< / section >
2018-03-26 23:32:43 +02:00
< section className = "card card--section" >
2018-12-19 06:44:53 +01:00
< header className = "card__header" >
< h2 className = "card__title" > { _ _ ( 'Application Cache' ) } < / h2 >
< p className = "card__subtitle" >
{ _ _ ( 'This will clear the application cache. Your wallet will not be affected.' ) }
< / p >
< / header >
2018-03-26 23:32:43 +02:00
< div className = "card__content" >
< Button
button = "primary"
2019-01-09 18:53:05 +01:00
label = { this . state . clearingCache ? _ _ ( 'Clearing' ) : _ _ ( 'Clear Cache' ) }
2018-11-26 02:21:25 +01:00
icon = { ICONS . ALERT }
2019-02-20 06:20:29 +01:00
onClick = { this . clearCache }
2018-03-26 23:32:43 +02:00
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 ;