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';
|
|
|
|
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
|
|
|
|
2022-11-04 01:15:45 +01:00
|
|
|
import 'package:adguard_home_manager/screens/clients/client_screen.dart';
|
2022-09-29 23:12:24 +02:00
|
|
|
|
2022-10-09 20:03:17 +02:00
|
|
|
import 'package:adguard_home_manager/functions/snackbar.dart';
|
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/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-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-09 20:03:17 +02:00
|
|
|
|
|
|
|
showSnacbkar(
|
|
|
|
context: context,
|
|
|
|
appConfigProvider: appConfigProvider,
|
|
|
|
label: AppLocalizations.of(context)!.clientAddedSuccessfully,
|
|
|
|
color: Colors.green
|
2022-10-07 00:35:41 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
appConfigProvider.addLog(result['log']);
|
2022-10-09 20:03:17 +02:00
|
|
|
|
|
|
|
showSnacbkar(
|
|
|
|
context: context,
|
|
|
|
appConfigProvider: appConfigProvider,
|
|
|
|
label: AppLocalizations.of(context)!.clientNotAdded,
|
|
|
|
color: Colors.red
|
2022-10-07 00:35:41 +02:00
|
|
|
);
|
|
|
|
}
|
2022-10-06 02:09:14 +02:00
|
|
|
}
|
|
|
|
|
2022-10-06 00:47:35 +02:00
|
|
|
void openAddClient() {
|
2022-11-04 01:15:45 +01:00
|
|
|
Navigator.push(context, MaterialPageRoute(
|
|
|
|
fullscreenDialog: true,
|
|
|
|
builder: (BuildContext context) => ClientScreen(
|
|
|
|
onConfirm: confirmAddClient,
|
|
|
|
)
|
|
|
|
));
|
2022-10-06 00:47:35 +02:00
|
|
|
}
|
|
|
|
|
2022-10-09 01:13:55 +02:00
|
|
|
return FloatingActionButton(
|
|
|
|
onPressed: () => openAddClient(),
|
2023-01-25 19:55:34 +01:00
|
|
|
child: const Icon(Icons.add),
|
2022-10-09 01:13:55 +02:00
|
|
|
);
|
2022-09-29 23:12:24 +02:00
|
|
|
}
|
|
|
|
}
|