2022-09-29 23:12:24 +02:00
|
|
|
// ignore_for_file: use_build_context_synchronously
|
|
|
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:provider/provider.dart';
|
2022-10-09 17:45:18 +02:00
|
|
|
import 'package:bottom_sheet/bottom_sheet.dart';
|
2022-09-29 23:12:24 +02:00
|
|
|
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
|
|
|
|
2022-10-07 17:08:23 +02:00
|
|
|
import 'package:adguard_home_manager/screens/clients/client_modal.dart';
|
2022-09-29 23:12:24 +02:00
|
|
|
|
2022-10-07 16:10:27 +02:00
|
|
|
import 'package:adguard_home_manager/models/clients.dart';
|
2022-09-29 23:12:24 +02:00
|
|
|
import 'package:adguard_home_manager/services/http_requests.dart';
|
|
|
|
import 'package:adguard_home_manager/models/clients_allowed_blocked.dart';
|
|
|
|
import 'package:adguard_home_manager/classes/process_modal.dart';
|
|
|
|
import 'package:adguard_home_manager/providers/servers_provider.dart';
|
|
|
|
import 'package:adguard_home_manager/providers/app_config_provider.dart';
|
|
|
|
|
|
|
|
class ClientsFab extends StatelessWidget {
|
2022-10-07 20:19:02 +02:00
|
|
|
final int tab;
|
|
|
|
|
|
|
|
const ClientsFab({
|
|
|
|
Key? key,
|
|
|
|
required this.tab,
|
|
|
|
}) : super(key: key);
|
2022-09-29 23:12:24 +02:00
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
final serversProvider = Provider.of<ServersProvider>(context);
|
|
|
|
final appConfigProvider = Provider.of<AppConfigProvider>(context);
|
|
|
|
|
2022-10-06 00:47:35 +02:00
|
|
|
void confirmRemoveDomain(String ip) async {
|
2022-09-29 23:12:24 +02:00
|
|
|
Map<String, List<String>> body = {};
|
|
|
|
|
2022-10-06 00:47:35 +02:00
|
|
|
final List<String> clients = [...serversProvider.clients.data!.clientsAllowedBlocked?.disallowedClients ?? [], ip];
|
|
|
|
body = {
|
|
|
|
"allowed_clients": serversProvider.clients.data!.clientsAllowedBlocked?.allowedClients ?? [],
|
|
|
|
"disallowed_clients": clients,
|
|
|
|
"blocked_hosts": serversProvider.clients.data!.clientsAllowedBlocked?.blockedHosts ?? [],
|
|
|
|
};
|
2022-09-29 23:12:24 +02:00
|
|
|
|
|
|
|
ProcessModal processModal = ProcessModal(context: context);
|
2022-09-29 23:21:42 +02:00
|
|
|
processModal.open(AppLocalizations.of(context)!.addingClient);
|
2022-09-29 23:12:24 +02:00
|
|
|
|
|
|
|
final result = await requestAllowedBlockedClientsHosts(serversProvider.selectedServer!, body);
|
|
|
|
|
|
|
|
processModal.close();
|
|
|
|
|
|
|
|
if (result['result'] == 'success') {
|
|
|
|
serversProvider.setAllowedDisallowedClientsBlockedDomains(
|
|
|
|
ClientsAllowedBlocked(
|
|
|
|
allowedClients: body['allowed_clients'] ?? [],
|
|
|
|
disallowedClients: body['disallowed_clients'] ?? [],
|
|
|
|
blockedHosts: body['blocked_hosts'] ?? [],
|
|
|
|
)
|
|
|
|
);
|
2022-10-08 22:16:35 +02:00
|
|
|
appConfigProvider.setShowingSnackbar();
|
2022-09-29 23:12:24 +02:00
|
|
|
ScaffoldMessenger.of(context).showSnackBar(
|
|
|
|
SnackBar(
|
|
|
|
content: Text(AppLocalizations.of(context)!.clientAddedSuccessfully),
|
|
|
|
backgroundColor: Colors.green,
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2022-09-29 23:27:29 +02:00
|
|
|
else if (result['result'] == 'error' && result['message'] == 'client_another_list') {
|
2022-10-08 22:16:35 +02:00
|
|
|
appConfigProvider.setShowingSnackbar();
|
2022-09-29 23:27:29 +02:00
|
|
|
ScaffoldMessenger.of(context).showSnackBar(
|
|
|
|
SnackBar(
|
|
|
|
content: Text(AppLocalizations.of(context)!.clientAnotherList),
|
|
|
|
backgroundColor: Colors.red,
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2022-09-29 23:12:24 +02:00
|
|
|
else {
|
2022-10-03 22:41:19 +02:00
|
|
|
appConfigProvider.addLog(result['log']);
|
2022-10-08 22:16:35 +02:00
|
|
|
appConfigProvider.setShowingSnackbar();
|
2022-09-29 23:12:24 +02:00
|
|
|
ScaffoldMessenger.of(context).showSnackBar(
|
|
|
|
SnackBar(
|
2022-09-29 23:27:29 +02:00
|
|
|
content: Text(AppLocalizations.of(context)!.clientNotAdded),
|
2022-09-29 23:12:24 +02:00
|
|
|
backgroundColor: Colors.red,
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-07 16:10:27 +02:00
|
|
|
void confirmAddClient(Client client) async {
|
2022-10-07 00:35:41 +02:00
|
|
|
ProcessModal processModal = ProcessModal(context: context);
|
|
|
|
processModal.open(AppLocalizations.of(context)!.addingClient);
|
|
|
|
|
|
|
|
final result = await postAddClient(server: serversProvider.selectedServer!, data: client.toJson());
|
|
|
|
|
|
|
|
processModal.close();
|
2022-10-06 02:09:14 +02:00
|
|
|
|
2022-10-07 00:35:41 +02:00
|
|
|
if (result['result'] == 'success') {
|
2022-10-07 16:10:27 +02:00
|
|
|
ClientsData clientsData = serversProvider.clients.data!;
|
|
|
|
clientsData.clients.add(client);
|
|
|
|
serversProvider.setClientsData(clientsData);
|
2022-10-08 22:16:35 +02:00
|
|
|
appConfigProvider.setShowingSnackbar();
|
2022-10-07 00:35:41 +02:00
|
|
|
ScaffoldMessenger.of(context).showSnackBar(
|
|
|
|
SnackBar(
|
|
|
|
content: Text(AppLocalizations.of(context)!.clientAddedSuccessfully),
|
|
|
|
backgroundColor: Colors.green,
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
appConfigProvider.addLog(result['log']);
|
2022-10-08 22:16:35 +02:00
|
|
|
appConfigProvider.setShowingSnackbar();
|
2022-10-07 00:35:41 +02:00
|
|
|
ScaffoldMessenger.of(context).showSnackBar(
|
|
|
|
SnackBar(
|
|
|
|
content: Text(AppLocalizations.of(context)!.clientNotAdded),
|
|
|
|
backgroundColor: Colors.red,
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2022-10-06 02:09:14 +02:00
|
|
|
}
|
|
|
|
|
2022-10-06 00:47:35 +02:00
|
|
|
void openAddClient() {
|
2022-10-09 17:45:18 +02:00
|
|
|
showFlexibleBottomSheet(
|
|
|
|
minHeight: 0.6,
|
|
|
|
initHeight: 0.6,
|
|
|
|
maxHeight: 0.95,
|
|
|
|
isCollapsible: true,
|
|
|
|
duration: const Duration(milliseconds: 250),
|
|
|
|
anchors: [0.95],
|
2022-10-06 02:09:14 +02:00
|
|
|
context: context,
|
2022-10-09 17:45:18 +02:00
|
|
|
builder: (ctx, controller, offset) => ClientModal(
|
|
|
|
scrollController: controller,
|
2022-10-06 02:09:14 +02:00
|
|
|
onConfirm: confirmAddClient
|
|
|
|
),
|
2022-10-09 17:45:18 +02:00
|
|
|
bottomSheetColor: Colors.transparent
|
2022-10-06 02:09:14 +02:00
|
|
|
);
|
2022-10-06 00:47:35 +02:00
|
|
|
}
|
|
|
|
|
2022-10-09 01:13:55 +02:00
|
|
|
return FloatingActionButton(
|
|
|
|
onPressed: () => openAddClient(),
|
|
|
|
child: const Icon(Icons.add),
|
|
|
|
);
|
2022-09-29 23:12:24 +02:00
|
|
|
}
|
|
|
|
}
|