- client: Don't hide version string when built-in auto-update is disabled: Merge pull request #628 in DNS/adguard-home from fix/1726 to master

Close #1726

Squashed commit of the following:

commit 3eac793c7c05fbb599f510fd8cae560011b7f5ca
Merge: aebfaf61 16a6aada
Author: ArtemBaskal <a.baskal@adguard.com>
Date:   Wed May 27 14:14:58 2020 +0300

    Merge branch 'master' into fix/1726

commit aebfaf610113f83027feb959ed87adef1b2db255
Author: ArtemBaskal <a.baskal@adguard.com>
Date:   Wed May 27 12:54:30 2020 +0300

    Always show version but hide update button when program is launched with "--no-check-update" flag

commit 1d4ee05959379420fee9730b3bf8ba737852e96e
Author: ArtemBaskal <a.baskal@adguard.com>
Date:   Wed May 27 11:59:10 2020 +0300

    Use classnames lib

commit 7003a7064c9625fab513dc02222faff4a340393f
Author: ArtemBaskal <a.baskal@adguard.com>
Date:   Tue May 26 19:40:22 2020 +0300

    - client: Don't hide version string when built-in auto-update is disabled
This commit is contained in:
Artem Baskal 2020-05-27 14:25:27 +03:00
parent 16a6aada6f
commit 355e634f64
4 changed files with 65 additions and 60 deletions

View File

@ -126,6 +126,7 @@ class App extends Component {
dnsPort={dashboard.dnsPort} dnsPort={dashboard.dnsPort}
processingVersion={dashboard.processingVersion} processingVersion={dashboard.processingVersion}
getVersion={getVersion} getVersion={getVersion}
checkUpdateFlag={dashboard.checkUpdateFlag}
/> />
<Toasts /> <Toasts />
<Icons /> <Icons />

View File

@ -1,6 +1,7 @@
import React, { Component, Fragment } from 'react'; import React, { Component, Fragment } from 'react';
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
import { Trans, withTranslation } from 'react-i18next'; import { Trans, withTranslation } from 'react-i18next';
import classNames from 'classnames';
import { REPOSITORY, PRIVACY_POLICY_LINK } from '../../helpers/constants'; import { REPOSITORY, PRIVACY_POLICY_LINK } from '../../helpers/constants';
import { LANGUAGES } from '../../helpers/twosky'; import { LANGUAGES } from '../../helpers/twosky';
@ -10,6 +11,22 @@ import Version from './Version';
import './Footer.css'; import './Footer.css';
import './Select.css'; import './Select.css';
const linksData = [
{
href: REPOSITORY.URL,
name: 'homepage',
},
{
href: PRIVACY_POLICY_LINK,
name: 'privacy_policy',
},
{
href: REPOSITORY.ISSUES,
className: 'btn btn-outline-primary btn-sm footer__link--report',
name: 'report_an_issue',
},
];
class Footer extends Component { class Footer extends Component {
getYear = () => { getYear = () => {
const today = new Date(); const today = new Date();
@ -20,9 +37,27 @@ class Footer extends Component {
i18n.changeLanguage(event.target.value); i18n.changeLanguage(event.target.value);
}; };
renderCopyright = () => <div className="footer__column">
<div className="footer__copyright">
<Trans>copyright</Trans> &copy; {this.getYear()}{' '}
<a target="_blank" rel="noopener noreferrer" href="https://adguard.com/">AdGuard</a>
</div>
</div>;
renderLinks = (linksData) => linksData.map(({ name, href, className = '' }) => <a
key={name}
href={href}
className={classNames('footer__link', className)}
target="_blank"
rel="noopener noreferrer"
>
<Trans>{name}</Trans>
</a>);
render() { render() {
const { const {
dnsVersion, processingVersion, getVersion, dnsVersion, processingVersion, getVersion, checkUpdateFlag,
} = this.props; } = this.props;
return ( return (
@ -30,39 +65,8 @@ class Footer extends Component {
<footer className="footer"> <footer className="footer">
<div className="container"> <div className="container">
<div className="footer__row"> <div className="footer__row">
{!dnsVersion && (
<div className="footer__column">
<div className="footer__copyright">
<Trans>copyright</Trans> &copy; {this.getYear()}{' '}
<a target="_blank" rel="noopener noreferrer" href="https://adguard.com/">AdGuard</a>
</div>
</div>
)}
<div className="footer__column footer__column--links"> <div className="footer__column footer__column--links">
<a {this.renderLinks(linksData)}
href={REPOSITORY.URL}
className="footer__link"
target="_blank"
rel="noopener noreferrer"
>
<Trans>homepage</Trans>
</a>
<a
href={PRIVACY_POLICY_LINK}
className="footer__link"
target="_blank"
rel="noopener noreferrer"
>
<Trans>privacy_policy</Trans>
</a>
<a
href={REPOSITORY.ISSUES}
className="btn btn-outline-primary btn-sm footer__link footer__link--report"
target="_blank"
rel="noopener noreferrer"
>
<Trans>report_an_issue</Trans>
</a>
</div> </div>
<div className="footer__column footer__column--language"> <div className="footer__column footer__column--language">
<select <select
@ -70,37 +74,32 @@ class Footer extends Component {
value={i18n.language} value={i18n.language}
onChange={this.changeLanguage} onChange={this.changeLanguage}
> >
{Object.keys(LANGUAGES).map((lang) => ( {Object.keys(LANGUAGES)
<option key={lang} value={lang}> .map((lang) => (
{LANGUAGES[lang]} <option key={lang} value={lang}>
</option> {LANGUAGES[lang]}
))} </option>
))}
</select> </select>
</div> </div>
</div> </div>
</div> </div>
</footer> </footer>
{dnsVersion && ( <div className="footer">
<div className="footer"> <div className="container">
<div className="container"> <div className="footer__row">
<div className="footer__row"> {this.renderCopyright()}
<div className="footer__column"> <div className="footer__column footer__column--language">
<div className="footer__copyright"> <Version
<Trans>copyright</Trans> &copy; {this.getYear()}{' '} dnsVersion={dnsVersion}
<a target="_blank" rel="noopener noreferrer" href="https://adguard.com/">AdGuard</a> processingVersion={processingVersion}
</div> getVersion={getVersion}
</div> checkUpdateFlag={checkUpdateFlag}
<div className="footer__column footer__column--language"> />
<Version
dnsVersion={dnsVersion}
processingVersion={processingVersion}
getVersion={getVersion}
/>
</div>
</div> </div>
</div> </div>
</div> </div>
)} </div>
</Fragment> </Fragment>
); );
} }
@ -110,6 +109,7 @@ Footer.propTypes = {
dnsVersion: PropTypes.string, dnsVersion: PropTypes.string,
processingVersion: PropTypes.bool, processingVersion: PropTypes.bool,
getVersion: PropTypes.func, getVersion: PropTypes.func,
checkUpdateFlag: PropTypes.bool,
}; };
export default withTranslation()(Footer); export default withTranslation()(Footer);

View File

@ -6,14 +6,15 @@ import './Version.css';
const Version = (props) => { const Version = (props) => {
const { const {
dnsVersion, processingVersion, t, dnsVersion = 'undefined', processingVersion, t, checkUpdateFlag,
} = props; } = props;
return ( return (
<div className="version"> <div className="version">
<div className="version__text"> <div className="version__text">
<Trans>version</Trans>:&nbsp;<span className="version__value" title={dnsVersion}>{dnsVersion}</span> <Trans>version</Trans>:&nbsp;
<button <span className="version__value" title={dnsVersion}>{dnsVersion}</span>
{checkUpdateFlag && <button
type="button" type="button"
className="btn btn-icon btn-icon-sm btn-outline-primary btn-sm ml-2" className="btn btn-icon btn-icon-sm btn-outline-primary btn-sm ml-2"
onClick={() => props.getVersion(true)} onClick={() => props.getVersion(true)}
@ -23,7 +24,7 @@ const Version = (props) => {
<svg className="icons"> <svg className="icons">
<use xlinkHref="#refresh" /> <use xlinkHref="#refresh" />
</svg> </svg>
</button> </button>}
</div> </div>
</div> </div>
); );
@ -33,6 +34,7 @@ Version.propTypes = {
dnsVersion: PropTypes.string.isRequired, dnsVersion: PropTypes.string.isRequired,
getVersion: PropTypes.func.isRequired, getVersion: PropTypes.func.isRequired,
processingVersion: PropTypes.bool.isRequired, processingVersion: PropTypes.bool.isRequired,
checkUpdateFlag: PropTypes.bool.isRequired,
t: PropTypes.func.isRequired, t: PropTypes.func.isRequired,
}; };

View File

@ -96,6 +96,7 @@ const dashboard = handleActions(
canAutoUpdate, canAutoUpdate,
isUpdateAvailable: true, isUpdateAvailable: true,
processingVersion: false, processingVersion: false,
checkUpdateFlag: !!payload,
}; };
return newState; return newState;
} }
@ -165,6 +166,7 @@ const dashboard = handleActions(
autoClients: [], autoClients: [],
supportedTags: [], supportedTags: [],
name: '', name: '',
checkUpdateFlag: false,
}, },
); );