mirror of
https://github.com/AdguardTeam/AdGuardHome.git
synced 2024-12-15 11:22:49 +03:00
Add switch language button on footer
This commit is contained in:
parent
234e29697f
commit
4b821f0bd7
3
client/package.json
vendored
3
client/package.json
vendored
@ -6,8 +6,7 @@
|
|||||||
"build-dev": "NODE_ENV=development ./node_modules/.bin/webpack --config webpack.dev.js",
|
"build-dev": "NODE_ENV=development ./node_modules/.bin/webpack --config webpack.dev.js",
|
||||||
"watch": "NODE_ENV=development ./node_modules/.bin/webpack --config webpack.dev.js --watch",
|
"watch": "NODE_ENV=development ./node_modules/.bin/webpack --config webpack.dev.js --watch",
|
||||||
"build-prod": "NODE_ENV=production ./node_modules/.bin/webpack --config webpack.prod.js",
|
"build-prod": "NODE_ENV=production ./node_modules/.bin/webpack --config webpack.prod.js",
|
||||||
"lint": "eslint frontend/",
|
"lint": "eslint frontend/"
|
||||||
"start": "react-scripts start"
|
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@nivo/line": "^0.49.1",
|
"@nivo/line": "^0.49.1",
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import { Trans } from 'react-i18next';
|
import { Trans, withNamespaces } from 'react-i18next';
|
||||||
|
|
||||||
import Card from '../ui/Card';
|
import Card from '../ui/Card';
|
||||||
import Line from '../ui/Line';
|
import Line from '../ui/Line';
|
||||||
@ -107,4 +107,4 @@ Statistics.propTypes = {
|
|||||||
refreshButton: PropTypes.node.isRequired,
|
refreshButton: PropTypes.node.isRequired,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default Statistics;
|
export default withNamespaces()(Statistics);
|
||||||
|
@ -3,7 +3,7 @@ import { NavLink } from 'react-router-dom';
|
|||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import enhanceWithClickOutside from 'react-click-outside';
|
import enhanceWithClickOutside from 'react-click-outside';
|
||||||
import classnames from 'classnames';
|
import classnames from 'classnames';
|
||||||
import { Trans } from 'react-i18next';
|
import { Trans, withNamespaces } from 'react-i18next';
|
||||||
import { REPOSITORY } from '../../helpers/constants';
|
import { REPOSITORY } from '../../helpers/constants';
|
||||||
|
|
||||||
class Menu extends Component {
|
class Menu extends Component {
|
||||||
@ -74,4 +74,4 @@ Menu.propTypes = {
|
|||||||
toggleMenuOpen: PropTypes.func,
|
toggleMenuOpen: PropTypes.func,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default enhanceWithClickOutside(Menu);
|
export default withNamespaces()(enhanceWithClickOutside(Menu));
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import { Trans } from 'react-i18next';
|
import { Trans, withNamespaces } from 'react-i18next';
|
||||||
|
|
||||||
export default function Version(props) {
|
function Version(props) {
|
||||||
const { dnsVersion, dnsAddress, dnsPort } = props;
|
const { dnsVersion, dnsAddress, dnsPort } = props;
|
||||||
return (
|
return (
|
||||||
<div className="nav-version">
|
<div className="nav-version">
|
||||||
@ -21,3 +21,5 @@ Version.propTypes = {
|
|||||||
dnsAddress: PropTypes.string,
|
dnsAddress: PropTypes.string,
|
||||||
dnsPort: PropTypes.number,
|
dnsPort: PropTypes.number,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export default withNamespaces()(Version);
|
||||||
|
@ -2,7 +2,7 @@ import React, { Component } from 'react';
|
|||||||
import { Link } from 'react-router-dom';
|
import { Link } from 'react-router-dom';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import classnames from 'classnames';
|
import classnames from 'classnames';
|
||||||
import { Trans } from 'react-i18next';
|
import { Trans, withNamespaces } from 'react-i18next';
|
||||||
|
|
||||||
import Menu from './Menu';
|
import Menu from './Menu';
|
||||||
import Version from './Version';
|
import Version from './Version';
|
||||||
@ -73,4 +73,4 @@ Header.propTypes = {
|
|||||||
location: PropTypes.object,
|
location: PropTypes.object,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default Header;
|
export default withNamespaces()(Header);
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import { Trans } from 'react-i18next';
|
import { Trans, withNamespaces } from 'react-i18next';
|
||||||
|
|
||||||
class Toast extends Component {
|
class Toast extends Component {
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
@ -36,4 +36,4 @@ Toast.propTypes = {
|
|||||||
removeToast: PropTypes.func.isRequired,
|
removeToast: PropTypes.func.isRequired,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default Toast;
|
export default withNamespaces()(Toast);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import { Trans } from 'react-i18next';
|
import { Trans, withNamespaces } from 'react-i18next';
|
||||||
import { REPOSITORY } from '../../helpers/constants';
|
import { REPOSITORY } from '../../helpers/constants';
|
||||||
|
import i18n from '../../i18n';
|
||||||
|
|
||||||
class Footer extends Component {
|
class Footer extends Component {
|
||||||
getYear = () => {
|
getYear = () => {
|
||||||
@ -8,6 +9,10 @@ class Footer extends Component {
|
|||||||
return today.getFullYear();
|
return today.getFullYear();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
changeLanguage = () => {
|
||||||
|
i18n.changeLanguage(i18n.language === 'en' ? 'vi' : 'en');
|
||||||
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<footer className="footer">
|
<footer className="footer">
|
||||||
@ -25,6 +30,12 @@ class Footer extends Component {
|
|||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
<div className="col-auto">
|
||||||
|
<button className="btn btn-outline-info btn-sm" onClick={this.changeLanguage}
|
||||||
|
title={i18n.language === 'en' ? 'Chuyển sang Tiếng Việt' : 'Change to English'}>
|
||||||
|
{i18n.language === 'en' ? 'English' : 'Tiếng Việt'}
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
<div className="col-auto">
|
<div className="col-auto">
|
||||||
<a href={`${REPOSITORY.URL}/issues/new`} className="btn btn-outline-primary btn-sm" target="_blank" rel="noopener noreferrer">
|
<a href={`${REPOSITORY.URL}/issues/new`} className="btn btn-outline-primary btn-sm" target="_blank" rel="noopener noreferrer">
|
||||||
<Trans>Report an issue</Trans>
|
<Trans>Report an issue</Trans>
|
||||||
@ -39,4 +50,4 @@ class Footer extends Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export default Footer;
|
export default withNamespaces()(Footer);
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import { Trans } from 'react-i18next';
|
import { Trans, withNamespaces } from 'react-i18next';
|
||||||
import { getSourceData } from '../../helpers/trackers/trackers';
|
import { getSourceData } from '../../helpers/trackers/trackers';
|
||||||
import { captitalizeWords } from '../../helpers/helpers';
|
import { captitalizeWords } from '../../helpers/helpers';
|
||||||
|
|
||||||
@ -52,4 +52,4 @@ Popover.propTypes = {
|
|||||||
data: PropTypes.object.isRequired,
|
data: PropTypes.object.isRequired,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default Popover;
|
export default withNamespaces()(Popover);
|
||||||
|
Loading…
Reference in New Issue
Block a user