import React, { useState } from 'react'; import PropTypes from 'prop-types'; import { Trans, withTranslation } from 'react-i18next'; import Tabs from './Tabs'; import Icons from './Icons'; const dnsPrivacyList = [{ title: 'Android', list: [ { label: 'setup_dns_privacy_android_1', }, { label: 'setup_dns_privacy_android_2', components: [ { key: 0, href: 'https://adguard.com/adguard-android/overview.html', }, text, ], }, { label: 'setup_dns_privacy_android_3', components: [ { key: 0, href: 'https://getintra.org/', }, text, ], }, ], }, { title: 'iOS', list: [ { label: 'setup_dns_privacy_ios_1', components: [ { key: 0, href: 'https://itunes.apple.com/app/id1452162351', }, text, { key: 2, href: 'https://dnscrypt.info/stamps', }, ], }, { label: 'setup_dns_privacy_ios_2', components: [ { key: 0, href: 'https://adguard.com/adguard-ios/overview.html', }, text, ], }, ], }, { title: 'setup_dns_privacy_other_title', list: [ { label: 'setup_dns_privacy_other_1', }, { label: 'setup_dns_privacy_other_2', components: [ { key: 0, href: 'https://github.com/AdguardTeam/dnsproxy', }, ], }, { href: 'https://github.com/jedisct1/dnscrypt-proxy', label: 'setup_dns_privacy_other_3', components: [ { key: 0, href: 'https://github.com/jedisct1/dnscrypt-proxy', }, text, ], }, { label: 'setup_dns_privacy_other_4', components: [ { key: 0, href: 'https://github.com/jedisct1/dnscrypt-proxy', }, text, ], }, { label: 'setup_dns_privacy_other_5', components: [ { key: 0, href: 'https://dnscrypt.info/implementations', }, { key: 1, href: 'https://dnsprivacy.org/wiki/display/DP/DNS+Privacy+Clients', }, ], }, ], }, ]; const renderDnsPrivacyList = ({ title, list }) =>
{title}
; const getTabs = ({ tlsAddress, httpsAddress, showDnsPrivacyNotice, t, }) => ({ Router: { // eslint-disable-next-line react/display-name getTitle: () =>

install_devices_router_desc

, title: 'Router', list: ['install_devices_router_list_1', 'install_devices_router_list_2', 'install_devices_router_list_3', // eslint-disable-next-line react/jsx-key link , ]}>install_devices_router_list_4, ], }, Windows: { title: 'Windows', list: ['install_devices_windows_list_1', 'install_devices_windows_list_2', 'install_devices_windows_list_3', 'install_devices_windows_list_4', 'install_devices_windows_list_5', 'install_devices_windows_list_6'], }, macOS: { title: 'macOS', list: ['install_devices_macos_list_1', 'install_devices_macos_list_2', 'install_devices_macos_list_3', 'install_devices_macos_list_4'], }, Android: { title: 'Android', list: ['install_devices_android_list_1', 'install_devices_android_list_2', 'install_devices_android_list_3', 'install_devices_android_list_4', 'install_devices_android_list_5'], }, iOS: { title: 'iOS', list: ['install_devices_ios_list_1', 'install_devices_ios_list_2', 'install_devices_ios_list_3', 'install_devices_ios_list_4'], }, dns_privacy: { title: 'dns_privacy', // eslint-disable-next-line react/display-name getTitle: () =>
{tlsAddress && tlsAddress.length > 0 && (
text, text, ]} > setup_dns_privacy_1
)} {httpsAddress && httpsAddress.length > 0 && (
text, text, ]} > setup_dns_privacy_2
)} {showDnsPrivacyNotice ?
link , text, ]} > setup_dns_notice
: <>
text

]}> setup_dns_privacy_3
{dnsPrivacyList.map(renderDnsPrivacyList)} }
, }, }); const renderContent = ({ title, list, getTitle }, t) =>
{t(title)}
{typeof getTitle === 'function' && getTitle()} {list &&
    {list.map((item) =>
  1. {item}
  2. )}
}
; const Guide = ({ dnsAddresses, t }) => { const tlsAddress = (dnsAddresses && dnsAddresses.filter((item) => item.includes('tls://'))) || ''; const httpsAddress = (dnsAddresses && dnsAddresses.filter((item) => item.includes('https://'))) || ''; const showDnsPrivacyNotice = httpsAddress.length < 1 && tlsAddress.length < 1; const [activeTabLabel, setActiveTabLabel] = useState('Router'); const tabs = getTabs({ tlsAddress, httpsAddress, showDnsPrivacyNotice, t, }); const activeTab = renderContent(tabs[activeTabLabel], t); return (
{activeTab}
); }; Guide.defaultProps = { dnsAddresses: [], }; Guide.propTypes = { dnsAddresses: PropTypes.array, t: PropTypes.func.isRequired, }; renderDnsPrivacyList.propTypes = { title: PropTypes.string.isRequired, list: PropTypes.array.isRequired, }; renderContent.propTypes = { title: PropTypes.string.isRequired, list: PropTypes.array.isRequired, getTitle: PropTypes.func, }; export default withTranslation()(Guide);