mirror of
https://github.com/JGeek00/adguard-home-manager.git
synced 2025-05-04 20:30:35 +00:00
Extracted dns rewrites
This commit is contained in:
parent
9460da6dcb
commit
5afe912e7e
8 changed files with 80 additions and 99 deletions
|
@ -12,52 +12,36 @@ import 'package:adguard_home_manager/screens/settings/dns_rewrites/delete_dns_re
|
|||
import 'package:adguard_home_manager/services/http_requests.dart';
|
||||
import 'package:adguard_home_manager/providers/app_config_provider.dart';
|
||||
import 'package:adguard_home_manager/functions/snackbar.dart';
|
||||
import 'package:adguard_home_manager/constants/enums.dart';
|
||||
import 'package:adguard_home_manager/providers/rewrute_rules_provider.dart';
|
||||
import 'package:adguard_home_manager/models/rewrite_rules.dart';
|
||||
import 'package:adguard_home_manager/providers/servers_provider.dart';
|
||||
import 'package:adguard_home_manager/classes/process_modal.dart';
|
||||
|
||||
class DnsRewrites extends StatelessWidget {
|
||||
const DnsRewrites({Key? key}) : super(key: key);
|
||||
class DnsRewritesScreen extends StatefulWidget {
|
||||
const DnsRewritesScreen({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,
|
||||
);
|
||||
}
|
||||
State<DnsRewritesScreen> createState() => _DnsRewritesScreenState();
|
||||
}
|
||||
|
||||
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> {
|
||||
class _DnsRewritesScreenState extends State<DnsRewritesScreen> {
|
||||
Future fetchData() async {
|
||||
widget.serversProvider.setRewriteRulesLoadStatus(0, false);
|
||||
final rewriteRulesProvider = Provider.of<RewriteRulesProvider>(context, listen: false);
|
||||
final serversProvider = Provider.of<ServersProvider>(context, listen: false);
|
||||
final appConfigProvider = Provider.of<AppConfigProvider>(context, listen: false);
|
||||
|
||||
final result = await getDnsRewriteRules(server: widget.serversProvider.selectedServer!);
|
||||
rewriteRulesProvider.setRewriteRulesLoadStatus(LoadStatus.loading, false);
|
||||
|
||||
final result = await getDnsRewriteRules(server: serversProvider.selectedServer!);
|
||||
|
||||
if (result['result'] == 'success') {
|
||||
widget.serversProvider.setRewriteRulesData(result['data']);
|
||||
widget.serversProvider.setRewriteRulesLoadStatus(1, true);
|
||||
rewriteRulesProvider.setRewriteRulesData(result['data']);
|
||||
rewriteRulesProvider.setRewriteRulesLoadStatus(LoadStatus.loaded, true);
|
||||
}
|
||||
else {
|
||||
widget.appConfigProvider.addLog(result['log']);
|
||||
widget.serversProvider.setRewriteRulesLoadStatus(2, true);
|
||||
appConfigProvider.addLog(result['log']);
|
||||
rewriteRulesProvider.setRewriteRulesLoadStatus(LoadStatus.error, true);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -70,11 +54,12 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
@override
|
||||
Widget build(BuildContext context) {
|
||||
final serversProvider = Provider.of<ServersProvider>(context);
|
||||
final rewriteRulesProvider = Provider.of<RewriteRulesProvider>(context);
|
||||
final appConfigProvider = Provider.of<AppConfigProvider>(context);
|
||||
|
||||
final width = MediaQuery.of(context).size.width;
|
||||
|
||||
void deleteDnsRewrite(RewriteRulesData rule) async {
|
||||
void deleteDnsRewrite(RewriteRules rule) async {
|
||||
ProcessModal processModal = ProcessModal(context: context);
|
||||
processModal.open(AppLocalizations.of(context)!.deleting);
|
||||
|
||||
|
@ -86,9 +71,9 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
processModal.close();
|
||||
|
||||
if (result['result'] == 'success') {
|
||||
List<RewriteRulesData> data = serversProvider.rewriteRules.data!;
|
||||
List<RewriteRules> data = rewriteRulesProvider.rewriteRules!;
|
||||
data = data.where((item) => item.domain != rule.domain).toList();
|
||||
serversProvider.setRewriteRulesData(data);
|
||||
rewriteRulesProvider.setRewriteRulesData(data);
|
||||
|
||||
showSnacbkar(
|
||||
appConfigProvider: appConfigProvider,
|
||||
|
@ -106,7 +91,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
}
|
||||
}
|
||||
|
||||
void addDnsRewrite(RewriteRulesData rule) async {
|
||||
void addDnsRewrite(RewriteRules rule) async {
|
||||
ProcessModal processModal = ProcessModal(context: context);
|
||||
processModal.open(AppLocalizations.of(context)!.addingRewrite);
|
||||
|
||||
|
@ -118,9 +103,9 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
processModal.close();
|
||||
|
||||
if (result['result'] == 'success') {
|
||||
List<RewriteRulesData> data = serversProvider.rewriteRules.data!;
|
||||
List<RewriteRules> data = rewriteRulesProvider.rewriteRules!;
|
||||
data.add(rule);
|
||||
serversProvider.setRewriteRulesData(data);
|
||||
rewriteRulesProvider.setRewriteRulesData(data);
|
||||
|
||||
showSnacbkar(
|
||||
appConfigProvider: appConfigProvider,
|
||||
|
@ -139,8 +124,8 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
}
|
||||
|
||||
Widget generateBody() {
|
||||
switch (serversProvider.rewriteRules.loadStatus) {
|
||||
case 0:
|
||||
switch (rewriteRulesProvider.loadStatus) {
|
||||
case LoadStatus.loading:
|
||||
return SizedBox(
|
||||
width: double.maxFinite,
|
||||
child: Column(
|
||||
|
@ -160,15 +145,15 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
),
|
||||
);
|
||||
|
||||
case 1:
|
||||
if (serversProvider.rewriteRules.data!.isNotEmpty) {
|
||||
case LoadStatus.loaded:
|
||||
if (rewriteRulesProvider.rewriteRules!.isNotEmpty) {
|
||||
return RefreshIndicator(
|
||||
onRefresh: () async {
|
||||
await fetchData();
|
||||
},
|
||||
child: ListView.builder(
|
||||
padding: const EdgeInsets.only(top: 0),
|
||||
itemCount: serversProvider.rewriteRules.data!.length,
|
||||
itemCount: rewriteRulesProvider.rewriteRules!.length,
|
||||
itemBuilder: (context, index) => Container(
|
||||
padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 10),
|
||||
decoration: BoxDecoration(
|
||||
|
@ -195,7 +180,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
),
|
||||
),
|
||||
Text(
|
||||
serversProvider.rewriteRules.data![index].domain,
|
||||
rewriteRulesProvider.rewriteRules![index].domain,
|
||||
style: TextStyle(
|
||||
color: Theme.of(context).colorScheme.onSurface
|
||||
),
|
||||
|
@ -213,7 +198,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
),
|
||||
),
|
||||
Text(
|
||||
serversProvider.rewriteRules.data![index].answer,
|
||||
rewriteRulesProvider.rewriteRules![index].answer,
|
||||
style: TextStyle(
|
||||
color: Theme.of(context).colorScheme.onSurface
|
||||
),
|
||||
|
@ -227,7 +212,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
showDialog(
|
||||
context: context,
|
||||
builder: (context) => DeleteDnsRewrite(
|
||||
onConfirm: () => deleteDnsRewrite(serversProvider.rewriteRules.data![index])
|
||||
onConfirm: () => deleteDnsRewrite(rewriteRulesProvider.rewriteRules![index])
|
||||
)
|
||||
)
|
||||
},
|
||||
|
@ -251,7 +236,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|||
);
|
||||
}
|
||||
|
||||
case 2:
|
||||
case LoadStatus.error:
|
||||
return SizedBox(
|
||||
width: double.maxFinite,
|
||||
child: Column(
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue