adguard-home-manager/lib/screens/top_items/top_items.dart

80 lines
2.3 KiB
Dart
Raw Normal View History

2022-09-28 13:59:09 +02:00
// ignore_for_file: use_build_context_synchronously
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:adguard_home_manager/functions/number_format.dart';
import 'package:adguard_home_manager/providers/servers_provider.dart';
import 'package:adguard_home_manager/services/http_requests.dart';
class TopItemsScreen extends StatelessWidget {
final String type;
final String title;
const TopItemsScreen({
Key? key,
required this.type,
required this.title,
}) : super(key: key);
@override
Widget build(BuildContext context) {
final serversProvider = Provider.of<ServersProvider>(context);
List<Map<String, dynamic>> data = [];
switch (type) {
case 'topQueriedDomains':
data = serversProvider.serverStatus.data!.stats.topQueriedDomains;
break;
case 'topBlockedDomains':
data = serversProvider.serverStatus.data!.stats.topBlockedDomains;
break;
case 'topClients':
data = serversProvider.serverStatus.data!.stats.topClients;
break;
default:
break;
}
int total = 0;
for (var element in data) {
total = total + int.parse(element.values.toList()[0].toString());
}
return Scaffold(
appBar: AppBar(
title: Text(title),
),
body: RefreshIndicator(
onRefresh: () async {
final result = await getServerStatus(serversProvider.selectedServer!);
if (result['result'] == 'success') {
serversProvider.setServerStatusData(result['data']);
}
else {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text(AppLocalizations.of(context)!.serverStatusNotRefreshed),
backgroundColor: Colors.red,
)
);
}
},
child: ListView.builder(
itemCount: data.length,
itemBuilder: (context, index) => ListTile(
title: Text(data[index].keys.toList()[0]),
trailing: Text(data[index].values.toList()[0].toString()),
subtitle: Text("${doubleFormat((data[index].values.toList()[0]/total*100), Platform.localeName)}%")
)
),
),
);
}
}