adguard-home-manager/lib/widgets/servers_list/delete_modal.dart

114 lines
3.4 KiB
Dart
Raw Normal View History

2022-09-26 22:43:30 +02:00
// ignore_for_file: use_build_context_synchronously
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:adguard_home_manager/models/server.dart';
2022-11-01 19:41:41 +01:00
import 'package:adguard_home_manager/functions/snackbar.dart';
import 'package:adguard_home_manager/providers/app_config_provider.dart';
2022-09-26 22:43:30 +02:00
import 'package:adguard_home_manager/providers/servers_provider.dart';
class DeleteModal extends StatelessWidget {
final Server serverToDelete;
const DeleteModal({
Key? key,
required this.serverToDelete,
}) : super(key: key);
@override
Widget build(BuildContext context) {
final serversProvider = Provider.of<ServersProvider>(context);
2022-11-01 19:41:41 +01:00
final appConfigProvider = Provider.of<AppConfigProvider>(context);
2022-09-26 22:43:30 +02:00
void removeServer() async {
2023-04-30 22:54:39 +02:00
final previouslySelectedServer = serversProvider.selectedServer;
2022-09-26 22:43:30 +02:00
final deleted = await serversProvider.removeServer(serverToDelete);
2023-04-30 22:54:39 +02:00
2022-09-26 22:43:30 +02:00
Navigator.pop(context);
2023-04-30 22:54:39 +02:00
2022-09-26 22:43:30 +02:00
if (deleted == true) {
2023-04-30 22:54:39 +02:00
if (previouslySelectedServer != null && previouslySelectedServer.id == serverToDelete.id) {
appConfigProvider.setSelectedScreen(0);
}
2022-11-01 19:41:41 +01:00
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.connectionRemoved,
color: Colors.green
2022-09-26 22:43:30 +02:00
);
}
else {
2022-11-01 19:41:41 +01:00
showSnacbkar(
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.connectionCannotBeRemoved,
color: Colors.red
2022-09-26 22:43:30 +02:00
);
}
}
return AlertDialog(
title: Column(
children: [
2022-11-04 17:04:25 +01:00
Icon(
2022-09-26 22:43:30 +02:00
Icons.delete,
2022-11-04 17:04:25 +01:00
size: 24,
2022-11-05 02:35:35 +01:00
color: Theme.of(context).listTileTheme.iconColor
2022-09-26 22:43:30 +02:00
),
Padding(
2022-11-04 17:04:25 +01:00
padding: const EdgeInsets.only(top: 16),
2022-09-26 22:43:30 +02:00
child: Text(
AppLocalizations.of(context)!.remove,
2022-11-04 17:04:25 +01:00
style: TextStyle(
fontSize: 24,
fontWeight: FontWeight.w400,
color: Theme.of(context).colorScheme.onSurface
2022-09-26 22:43:30 +02:00
),
),
),
],
),
content: Column(
mainAxisSize: MainAxisSize.min,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Column(
children: [
Text(
AppLocalizations.of(context)!.removeWarning,
textAlign: TextAlign.center,
2022-11-04 17:04:25 +01:00
style: TextStyle(
2022-11-04 22:56:00 +01:00
color: Theme.of(context).colorScheme.onSurfaceVariant
2022-11-04 17:04:25 +01:00
),
2022-09-26 22:43:30 +02:00
),
const SizedBox(height: 10),
Center(
child: Text(
"${serverToDelete.connectionMethod}://${serverToDelete.domain}${serverToDelete.path ?? ""}${serverToDelete.port != null ? ':${serverToDelete.port}' : ""}",
2022-11-04 17:04:25 +01:00
style: TextStyle(
fontStyle: FontStyle.italic,
2022-11-04 22:56:00 +01:00
color: Theme.of(context).colorScheme.onSurfaceVariant
2022-09-26 22:43:30 +02:00
),
),
),
],
),
],
),
actions: [
TextButton(
onPressed: () => {
Navigator.pop(context)
},
child: Text(AppLocalizations.of(context)!.cancel)
),
TextButton(
onPressed: removeServer,
child: Text(AppLocalizations.of(context)!.remove),
),
],
);
}
}