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

270 lines
9.4 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/providers/app_config_provider.dart';
2022-10-15 20:20:35 +02:00
import 'package:adguard_home_manager/functions/snackbar.dart';
2023-05-24 19:12:11 +02:00
import 'package:adguard_home_manager/constants/enums.dart';
2023-05-24 20:40:45 +02:00
import 'package:adguard_home_manager/providers/rewrite_rules_provider.dart';
2022-10-15 20:20:35 +02:00
import 'package:adguard_home_manager/models/rewrite_rules.dart';
import 'package:adguard_home_manager/classes/process_modal.dart';
2022-10-15 14:47:32 +02:00
2023-05-24 19:12:11 +02:00
class DnsRewritesScreen extends StatefulWidget {
const DnsRewritesScreen({Key? key}) : super(key: key);
2022-10-15 14:47:32 +02:00
@override
2023-05-24 19:12:11 +02:00
State<DnsRewritesScreen> createState() => _DnsRewritesScreenState();
2022-10-15 14:47:32 +02:00
}
2023-05-24 19:12:11 +02:00
class _DnsRewritesScreenState extends State<DnsRewritesScreen> {
2022-10-15 14:47:32 +02:00
@override
void initState() {
Provider.of<RewriteRulesProvider>(context, listen: false).fetchRules();
2022-10-15 14:47:32 +02:00
super.initState();
}
@override
Widget build(BuildContext context) {
2023-05-24 19:12:11 +02:00
final rewriteRulesProvider = Provider.of<RewriteRulesProvider>(context);
2022-10-15 20:20:35 +02:00
final appConfigProvider = Provider.of<AppConfigProvider>(context);
final width = MediaQuery.of(context).size.width;
2023-05-24 19:12:11 +02:00
void deleteDnsRewrite(RewriteRules rule) async {
2022-10-15 20:20:35 +02:00
ProcessModal processModal = ProcessModal(context: context);
processModal.open(AppLocalizations.of(context)!.deleting);
final result = await rewriteRulesProvider.deleteDnsRewrite(rule);
2022-10-15 20:20:35 +02:00
processModal.close();
if (result == true) {
2022-10-15 20:20:35 +02:00
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleDeleted,
color: Colors.green
);
}
else {
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleNotDeleted,
color: Colors.red
);
}
}
2022-10-15 14:47:32 +02:00
2023-05-24 19:12:11 +02:00
void addDnsRewrite(RewriteRules rule) async {
2022-10-15 20:52:31 +02:00
ProcessModal processModal = ProcessModal(context: context);
processModal.open(AppLocalizations.of(context)!.addingRewrite);
final result = await rewriteRulesProvider.addDnsRewrite(rule);
2022-10-15 20:52:31 +02:00
processModal.close();
if (result == true) {
2022-10-15 20:52:31 +02:00
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleAdded,
color: Colors.green
);
}
else {
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleNotAdded,
color: Colors.red
);
}
}
2022-10-15 14:47:32 +02:00
Widget generateBody() {
2023-05-24 19:12:11 +02:00
switch (rewriteRulesProvider.loadStatus) {
case LoadStatus.loading:
2022-10-15 14:47:32 +02:00
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
),
)
],
),
);
2023-05-24 19:12:11 +02:00
case LoadStatus.loaded:
if (rewriteRulesProvider.rewriteRules!.isNotEmpty) {
2022-10-15 20:20:35 +02:00
return RefreshIndicator(
onRefresh: () async {
final result = await rewriteRulesProvider.fetchRules();
if (result == false) {
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.rewriteRulesNotLoaded,
color: Colors.red
);
}
2022-10-15 20:20:35 +02:00
},
child: ListView.builder(
padding: const EdgeInsets.only(top: 0),
2023-05-24 19:12:11 +02:00
itemCount: rewriteRulesProvider.rewriteRules!.length,
2022-10-15 20:20:35 +02:00
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(
2023-05-24 19:12:11 +02:00
rewriteRulesProvider.rewriteRules![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(
2023-05-24 19:12:11 +02:00
rewriteRulesProvider.rewriteRules![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(
2023-05-24 19:12:11 +02:00
onConfirm: () => deleteDnsRewrite(rewriteRulesProvider.rewriteRules![index])
2022-10-15 20:20:35 +02:00
)
)
},
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
),
),
);
}
2023-05-24 19:12:11 +02:00
case LoadStatus.error:
2022-10-15 14:47:32 +02:00
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
);
}
}