adguard-home-manager/lib/screens/settings/dns_rewrites/dns_rewrites.dart

316 lines
11 KiB
Dart
Raw Normal View History

2022-10-15 20:20:35 +02:00
// ignore_for_file: use_build_context_synchronously
import 'dart:io';
2022-10-15 14:47:32 +02:00
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
2022-10-15 20:52:31 +02:00
import 'package:adguard_home_manager/screens/settings/dns_rewrites/add_dns_rewrite_modal.dart';
2022-10-15 20:20:35 +02:00
import 'package:adguard_home_manager/screens/settings/dns_rewrites/delete_dns_rewrite.dart';
2022-10-15 14:47:32 +02:00
import 'package:adguard_home_manager/services/http_requests.dart';
import 'package:adguard_home_manager/providers/app_config_provider.dart';
2022-10-15 20:20:35 +02:00
import 'package:adguard_home_manager/functions/snackbar.dart';
import 'package:adguard_home_manager/models/rewrite_rules.dart';
2022-10-15 14:47:32 +02:00
import 'package:adguard_home_manager/providers/servers_provider.dart';
2022-10-15 20:20:35 +02:00
import 'package:adguard_home_manager/classes/process_modal.dart';
2022-10-15 14:47:32 +02:00
class DnsRewrites extends StatelessWidget {
const DnsRewrites({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
final serversProvider = Provider.of<ServersProvider>(context);
final appConfigProvider = Provider.of<AppConfigProvider>(context);
return DnsRewritesWidget(
serversProvider: serversProvider,
appConfigProvider: appConfigProvider,
);
}
}
class DnsRewritesWidget extends StatefulWidget {
final ServersProvider serversProvider;
final AppConfigProvider appConfigProvider;
const DnsRewritesWidget({
Key? key,
required this.serversProvider,
required this.appConfigProvider
}) : super(key: key);
@override
State<DnsRewritesWidget> createState() => _DnsRewritesWidgetState();
}
class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
2022-10-15 20:20:35 +02:00
Future fetchData() async {
2022-10-15 14:47:32 +02:00
widget.serversProvider.setRewriteRulesLoadStatus(0, false);
final result = await getDnsRewriteRules(server: widget.serversProvider.selectedServer!);
if (result['result'] == 'success') {
widget.serversProvider.setRewriteRulesData(result['data']);
widget.serversProvider.setRewriteRulesLoadStatus(1, true);
}
else {
widget.appConfigProvider.addLog(result['log']);
widget.serversProvider.setRewriteRulesLoadStatus(2, true);
}
}
@override
void initState() {
fetchData();
super.initState();
}
@override
Widget build(BuildContext context) {
final serversProvider = Provider.of<ServersProvider>(context);
2022-10-15 20:20:35 +02:00
final appConfigProvider = Provider.of<AppConfigProvider>(context);
final width = MediaQuery.of(context).size.width;
2022-10-15 20:20:35 +02:00
void deleteDnsRewrite(RewriteRulesData rule) async {
ProcessModal processModal = ProcessModal(context: context);
processModal.open(AppLocalizations.of(context)!.deleting);
final result = await deleteDnsRewriteRule(server: serversProvider.selectedServer!, data: {
"domain": rule.domain,
"answer": rule.answer
});
processModal.close();
if (result['result'] == 'success') {
List<RewriteRulesData> data = serversProvider.rewriteRules.data!;
data = data.where((item) => item.domain != rule.domain).toList();
serversProvider.setRewriteRulesData(data);
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleDeleted,
color: Colors.green
);
}
else {
appConfigProvider.addLog(result['log']);
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleNotDeleted,
color: Colors.red
);
}
}
2022-10-15 14:47:32 +02:00
2022-10-15 20:52:31 +02:00
void addDnsRewrite(RewriteRulesData rule) async {
ProcessModal processModal = ProcessModal(context: context);
processModal.open(AppLocalizations.of(context)!.addingRewrite);
final result = await addDnsRewriteRule(server: serversProvider.selectedServer!, data: {
"domain": rule.domain,
"answer": rule.answer
});
processModal.close();
if (result['result'] == 'success') {
List<RewriteRulesData> data = serversProvider.rewriteRules.data!;
data.add(rule);
serversProvider.setRewriteRulesData(data);
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleAdded,
color: Colors.green
);
}
else {
appConfigProvider.addLog(result['log']);
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleNotAdded,
color: Colors.red
);
}
}
2022-10-15 14:47:32 +02:00
Widget generateBody() {
switch (serversProvider.rewriteRules.loadStatus) {
case 0:
return SizedBox(
width: double.maxFinite,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
const CircularProgressIndicator(),
const SizedBox(height: 30),
Text(
AppLocalizations.of(context)!.loadingRewriteRules,
2023-01-29 21:52:37 +01:00
style: TextStyle(
2022-10-15 14:47:32 +02:00
fontSize: 22,
2023-01-29 21:52:37 +01:00
color: Theme.of(context).colorScheme.onSurfaceVariant,
2022-10-15 14:47:32 +02:00
),
)
],
),
);
case 1:
if (serversProvider.rewriteRules.data!.isNotEmpty) {
2022-10-15 20:20:35 +02:00
return RefreshIndicator(
onRefresh: () async {
await fetchData();
},
child: ListView.builder(
padding: const EdgeInsets.only(top: 0),
itemCount: serversProvider.rewriteRules.data!.length,
itemBuilder: (context, index) => Container(
2022-11-05 01:09:09 +01:00
padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 10),
2022-10-15 20:20:35 +02:00
decoration: BoxDecoration(
border: Border(
bottom: BorderSide(
2022-11-05 01:09:09 +01:00
width: 1,
2022-11-05 04:10:49 +01:00
color: Theme.of(context).colorScheme.outline.withOpacity(0.2)
2022-10-15 20:20:35 +02:00
)
2022-10-15 14:47:32 +02:00
)
2022-10-15 20:20:35 +02:00
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Row(
children: [
Text(
"${AppLocalizations.of(context)!.domain}: ",
2022-11-05 01:09:09 +01:00
style: TextStyle(
fontWeight: FontWeight.w500,
color: Theme.of(context).colorScheme.onSurface
2022-10-15 20:20:35 +02:00
),
2022-10-15 14:47:32 +02:00
),
2022-10-15 20:20:35 +02:00
Text(
serversProvider.rewriteRules.data![index].domain,
2022-11-05 01:09:09 +01:00
style: TextStyle(
color: Theme.of(context).colorScheme.onSurface
),
2022-10-15 14:47:32 +02:00
),
2022-10-15 20:20:35 +02:00
],
),
const SizedBox(height: 3),
Row(
children: [
Text(
"${AppLocalizations.of(context)!.answer}: ",
2022-11-05 01:09:09 +01:00
style: TextStyle(
fontWeight: FontWeight.w500,
color: Theme.of(context).colorScheme.onSurface
2022-10-15 20:20:35 +02:00
),
),
Text(
serversProvider.rewriteRules.data![index].answer,
2022-11-05 01:09:09 +01:00
style: TextStyle(
color: Theme.of(context).colorScheme.onSurface
),
2022-10-15 20:20:35 +02:00
),
],
),
],
),
IconButton(
onPressed: () => {
showDialog(
context: context,
builder: (context) => DeleteDnsRewrite(
onConfirm: () => deleteDnsRewrite(serversProvider.rewriteRules.data![index])
)
)
},
icon: const Icon(Icons.delete)
)
],
),
)
),
2022-10-15 14:47:32 +02:00
);
}
else {
return Center(
child: Text(
AppLocalizations.of(context)!.noRewriteRules,
2023-01-29 21:52:37 +01:00
style: TextStyle(
2022-10-15 14:47:32 +02:00
fontSize: 22,
2023-01-29 21:52:37 +01:00
color: Theme.of(context).colorScheme.onSurfaceVariant,
2022-10-15 14:47:32 +02:00
),
),
);
}
case 2:
return SizedBox(
width: double.maxFinite,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
const Icon(
Icons.error,
color: Colors.red,
size: 50,
),
const SizedBox(height: 30),
Text(
AppLocalizations.of(context)!.rewriteRulesNotLoaded,
2023-01-29 21:52:37 +01:00
style: TextStyle(
2022-10-15 14:47:32 +02:00
fontSize: 22,
2023-01-29 21:52:37 +01:00
color: Theme.of(context).colorScheme.onSurfaceVariant,
2022-10-15 14:47:32 +02:00
),
)
],
),
);
default:
return const SizedBox();
}
}
return Scaffold(
appBar: AppBar(
title: Text(AppLocalizations.of(context)!.dnsRewrites),
2023-03-16 23:29:18 +01:00
centerTitle: false,
2022-10-15 14:47:32 +02:00
),
body: generateBody(),
2022-10-15 20:52:31 +02:00
floatingActionButton: FloatingActionButton(
onPressed: () => {
if (width > 900 || !(Platform.isAndroid || Platform.isIOS)) {
showDialog(
context: context,
builder: (context) => AddDnsRewriteModal(
onConfirm: addDnsRewrite,
dialog: true,
),
)
}
else {
showModalBottomSheet(
context: context,
builder: (context) => AddDnsRewriteModal(
onConfirm: addDnsRewrite,
dialog: false,
),
backgroundColor: Colors.transparent,
isScrollControlled: true
)
}
2022-10-15 20:52:31 +02:00
},
2023-01-25 19:55:34 +01:00
child: const Icon(Icons.add),
2022-10-15 20:52:31 +02:00
),
2022-10-15 14:47:32 +02:00
);
}
}