2018-08-30 14:25:33 +00:00
import React , { Component , Fragment } from 'react' ;
import PropTypes from 'prop-types' ;
2018-10-25 10:33:44 +00:00
import { withNamespaces , Trans } from 'react-i18next' ;
2018-08-30 14:25:33 +00:00
import Upstream from './Upstream' ;
import Checkbox from '../ui/Checkbox' ;
import Loading from '../ui/Loading' ;
import PageTitle from '../ui/PageTitle' ;
import Card from '../ui/Card' ;
import './Settings.css' ;
2018-10-25 10:33:44 +00:00
class Settings extends Component {
2018-08-30 14:25:33 +00:00
settings = {
filtering : {
enabled : false ,
2018-10-25 10:33:44 +00:00
title : this . props . t ( 'Block domains using filters and hosts files' ) ,
subtitle : this . props . t ( 'You can setup blocking rules in the <a href="#filters">Filters</a> settings.' ) ,
2018-08-30 14:25:33 +00:00
} ,
safebrowsing : {
enabled : false ,
2018-10-25 10:33:44 +00:00
title : this . props . t ( 'Use AdGuard browsing security web service' ) ,
subtitle : this . props . t ( 'AdGuard Home will check if domain is blacklisted by the browsing security web service. It will use privacy-friendly lookup API to perform the check: only a short prefix of the domain name SHA256 hash is sent to the server.' ) ,
2018-08-30 14:25:33 +00:00
} ,
parental : {
enabled : false ,
2018-10-25 10:33:44 +00:00
title : this . props . t ( 'Use AdGuard parental control web service' ) ,
subtitle : this . props . t ( 'AdGuard Home will check if domain contains adult materials. It uses the same privacy-friendly API as the browsing security web service.' ) ,
2018-08-30 14:25:33 +00:00
} ,
safesearch : {
enabled : false ,
2018-10-25 10:33:44 +00:00
title : this . props . t ( 'Enforce safe search' ) ,
subtitle : this . props . t ( 'AdGuard Home can enforce safe search in the following search engines: Google, Bing, Yandex.' ) ,
2018-08-30 14:25:33 +00:00
} ,
} ;
componentDidMount ( ) {
this . props . initSettings ( this . settings ) ;
}
handleUpstreamChange = ( value ) => {
2018-09-26 15:38:06 +00:00
this . props . handleUpstreamChange ( { upstreamDns : value } ) ;
2018-08-30 14:25:33 +00:00
} ;
handleUpstreamSubmit = ( ) => {
2018-09-26 15:38:06 +00:00
this . props . setUpstream ( this . props . dashboard . upstreamDns ) ;
2018-08-30 14:25:33 +00:00
} ;
2018-09-21 15:08:39 +00:00
handleUpstreamTest = ( ) => {
2018-09-26 15:38:06 +00:00
if ( this . props . dashboard . upstreamDns . length > 0 ) {
this . props . testUpstream ( this . props . dashboard . upstreamDns ) ;
2018-09-21 15:50:06 +00:00
} else {
2018-10-25 10:33:44 +00:00
this . props . addErrorToast ( { error : this . props . t ( 'No servers specified' ) } ) ;
2018-09-21 15:50:06 +00:00
}
2018-09-21 15:08:39 +00:00
} ;
2018-08-30 14:25:33 +00:00
renderSettings = ( settings ) => {
if ( Object . keys ( settings ) . length > 0 ) {
return Object . keys ( settings ) . map ( ( key ) => {
const setting = settings [ key ] ;
const { enabled } = setting ;
return ( < Checkbox
key = { key }
{ ... settings [ key ] }
handleChange = { ( ) => this . props . toggleSetting ( key , enabled ) }
/ > ) ;
} ) ;
}
return (
2018-10-25 10:33:44 +00:00
< div > < Trans > No settings < / T r a n s > < / d i v >
2018-08-30 14:25:33 +00:00
) ;
}
render ( ) {
2018-10-25 10:33:44 +00:00
const { settings , t } = this . props ;
2018-09-26 15:38:06 +00:00
const { upstreamDns } = this . props . dashboard ;
2018-08-30 14:25:33 +00:00
return (
< Fragment >
2018-10-25 10:33:44 +00:00
< PageTitle title = { t ( 'Settings' ) } / >
2018-08-30 14:25:33 +00:00
{ settings . processing && < Loading / > }
{ ! settings . processing &&
< div className = "content" >
< div className = "row" >
< div className = "col-md-12" >
2018-10-25 10:33:44 +00:00
< Card title = { t ( 'General settings' ) } bodyType = "card-body box-body--settings" >
2018-08-30 14:25:33 +00:00
< div className = "form" >
{ this . renderSettings ( settings . settingsList ) }
< / d i v >
< / C a r d >
< Upstream
2018-09-26 15:38:06 +00:00
upstreamDns = { upstreamDns }
2018-09-21 15:08:39 +00:00
processingTestUpstream = { settings . processingTestUpstream }
2018-08-30 14:25:33 +00:00
handleUpstreamChange = { this . handleUpstreamChange }
handleUpstreamSubmit = { this . handleUpstreamSubmit }
2018-09-21 15:08:39 +00:00
handleUpstreamTest = { this . handleUpstreamTest }
2018-08-30 14:25:33 +00:00
/ >
< / d i v >
< / d i v >
< / d i v >
}
< / F r a g m e n t >
) ;
}
}
Settings . propTypes = {
initSettings : PropTypes . func ,
settings : PropTypes . object ,
settingsList : PropTypes . object ,
toggleSetting : PropTypes . func ,
handleUpstreamChange : PropTypes . func ,
setUpstream : PropTypes . func ,
upstream : PropTypes . string ,
2018-10-25 10:33:44 +00:00
t : PropTypes . func ,
2018-08-30 14:25:33 +00:00
} ;
2018-10-25 10:33:44 +00:00
export default withNamespaces ( ) ( Settings ) ;