badguardhome/client/src/components/Dashboard/Counters.js

95 lines
3.5 KiB
JavaScript
Raw Normal View History

2018-08-30 14:25:33 +00:00
import React from 'react';
import PropTypes from 'prop-types';
import Card from '../ui/Card';
import Tooltip from '../ui/Tooltip';
2018-10-08 15:55:30 +00:00
const tooltipType = 'tooltip-custom--narrow';
2018-08-30 14:25:33 +00:00
const Counters = props => (
<Card title="General statistics" subtitle="in the last 24 hours" bodyType="card-table" refresh={props.refreshButton}>
2018-08-30 14:25:33 +00:00
<table className="table card-table">
<tbody>
<tr>
<td>
DNS Queries
2018-10-08 15:55:30 +00:00
<Tooltip text="A number of DNS quieries processed in the last 24 hours" type={tooltipType} />
2018-08-30 14:25:33 +00:00
</td>
<td className="text-right">
<span className="text-muted">
{props.dnsQueries}
</span>
</td>
</tr>
<tr>
<td>
Blocked by filters
2018-10-08 15:55:30 +00:00
<Tooltip text="A number of DNS requests blocked by filters" type={tooltipType} />
2018-08-30 14:25:33 +00:00
</td>
<td className="text-right">
<span className="text-muted">
{props.blockedFiltering}
</span>
</td>
</tr>
<tr>
<td>
Blocked malware/phishing
2018-10-08 15:55:30 +00:00
<Tooltip text="A number of DNS requests blocked" type={tooltipType} />
2018-08-30 14:25:33 +00:00
</td>
<td className="text-right">
<span className="text-muted">
{props.replacedSafebrowsing}
</span>
</td>
</tr>
<tr>
<td>
Blocked adult websites
2018-10-08 15:55:30 +00:00
<Tooltip text="A number of adult websites blocked" type={tooltipType} />
2018-08-30 14:25:33 +00:00
</td>
<td className="text-right">
<span className="text-muted">
{props.replacedParental}
</span>
</td>
</tr>
<tr>
<td>
Enforced safe search
2018-10-08 15:55:30 +00:00
<Tooltip text="A number of DNS requests to search engines for which Safe Search was enforced" type={tooltipType} />
2018-08-30 14:25:33 +00:00
</td>
<td className="text-right">
<span className="text-muted">
{props.replacedSafesearch}
</span>
</td>
</tr>
<tr>
<td>
Average processing time
2018-10-08 15:55:30 +00:00
<Tooltip text="Average time in milliseconds on processing a DNS request" type={tooltipType} />
2018-08-30 14:25:33 +00:00
</td>
<td className="text-right">
<span className="text-muted">
{props.avgProcessingTime}
</span>
</td>
</tr>
</tbody>
</table>
</Card>
);
Counters.propTypes = {
dnsQueries: PropTypes.number.isRequired,
blockedFiltering: PropTypes.number.isRequired,
replacedSafebrowsing: PropTypes.number.isRequired,
replacedParental: PropTypes.number.isRequired,
replacedSafesearch: PropTypes.number.isRequired,
avgProcessingTime: PropTypes.number.isRequired,
refreshButton: PropTypes.node,
};
export default Counters;