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

75 lines
2.3 KiB
Dart
Raw Normal View History

2022-09-30 00:24:56 +02:00
// ignore_for_file: use_build_context_synchronously
import 'dart:convert';
2022-09-30 01:23:28 +02:00
import 'package:adguard_home_manager/screens/app_logs/app_log_details_modal.dart';
2022-09-30 00:24:56 +02:00
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:provider/provider.dart';
import 'package:adguard_home_manager/providers/app_config_provider.dart';
2022-09-30 01:23:28 +02:00
class AppLogs extends StatelessWidget {
const AppLogs({Key? key}) : super(key: key);
2022-09-30 00:24:56 +02:00
@override
Widget build(BuildContext context) {
final appConfigProvider = Provider.of<AppConfigProvider>(context);
void copyLogsClipboard() async {
2022-09-30 01:23:28 +02:00
List<Map<String, String>> logsString = appConfigProvider.logs.map((log) => log.toMap()).toList();
2022-09-30 00:24:56 +02:00
await Clipboard.setData(
2022-09-30 01:23:28 +02:00
ClipboardData(text: jsonEncode(logsString))
2022-09-30 00:24:56 +02:00
);
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(
content: Text("Logs copied to the clipboard"),
backgroundColor: Colors.black,
)
);
}
return Scaffold(
appBar: AppBar(
title: const Text("Logs"),
actions: [
IconButton(
onPressed: appConfigProvider.logs.isNotEmpty
? copyLogsClipboard
: null,
icon: const Icon(Icons.share),
tooltip: "Copy logs to clipboard",
),
const SizedBox(width: 10),
],
),
body: appConfigProvider.logs.isNotEmpty
? ListView.builder(
padding: const EdgeInsets.only(top: 0),
itemCount: appConfigProvider.logs.length,
itemBuilder: (context, index) => ListTile(
2022-09-30 01:23:28 +02:00
title: Text(appConfigProvider.logs[index].message),
subtitle: Text(appConfigProvider.logs[index].dateTime.toString()),
trailing: Text(appConfigProvider.logs[index].type),
onTap: () => {
showDialog(
context: context,
builder: (context) => AppLogDetailsModal(
log: appConfigProvider.logs[index]
)
)
},
2022-09-30 00:24:56 +02:00
)
)
: const Center(
child: Text(
"No saved logs",
style: TextStyle(
fontSize: 24,
color: Colors.grey,
),
),
)
);
}
}