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

149 lines
5.3 KiB
Dart
Raw Normal View History

2022-10-09 01:13:55 +02:00
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:adguard_home_manager/screens/settings/access_settings/clients_list.dart';
2022-10-09 01:13:55 +02:00
2023-04-06 18:50:06 +02:00
import 'package:adguard_home_manager/constants/enums.dart';
2022-10-09 01:13:55 +02:00
import 'package:adguard_home_manager/services/http_requests.dart';
import 'package:adguard_home_manager/providers/app_config_provider.dart';
import 'package:adguard_home_manager/providers/servers_provider.dart';
class AccessSettings extends StatelessWidget {
const AccessSettings({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
final serversProvider = Provider.of<ServersProvider>(context);
final appConfigProvider = Provider.of<AppConfigProvider>(context);
return AccessSettingsWidget(
serversProvider: serversProvider,
appConfigProvider: appConfigProvider,
);
}
}
class AccessSettingsWidget extends StatefulWidget {
final ServersProvider serversProvider;
final AppConfigProvider appConfigProvider;
const AccessSettingsWidget({
Key? key,
required this.serversProvider,
required this.appConfigProvider,
}) : super(key: key);
@override
State<AccessSettingsWidget> createState() => _AccessSettingsWidgetState();
}
class _AccessSettingsWidgetState extends State<AccessSettingsWidget> with TickerProviderStateMixin {
final ScrollController scrollController = ScrollController();
late TabController tabController;
Future fetchClients() async {
2023-04-06 18:10:23 +02:00
widget.serversProvider.setClientsLoadStatus(LoadStatus.loading, false);
2022-10-09 01:13:55 +02:00
final result = await getClients(widget.serversProvider.selectedServer!);
if (mounted) {
if (result['result'] == 'success') {
widget.serversProvider.setClientsData(result['data']);
2023-04-06 18:10:23 +02:00
widget.serversProvider.setClientsLoadStatus(LoadStatus.loaded, true);
2022-10-09 01:13:55 +02:00
}
else {
widget.appConfigProvider.addLog(result['log']);
2023-04-06 18:10:23 +02:00
widget.serversProvider.setClientsLoadStatus(LoadStatus.error, true);
2022-10-09 01:13:55 +02:00
}
}
}
@override
void initState() {
2023-04-30 22:54:39 +02:00
if (mounted) fetchClients();
2022-10-09 01:13:55 +02:00
super.initState();
tabController = TabController(
initialIndex: 0,
length: 3,
vsync: this,
);
}
@override
Widget build(BuildContext context) {
final serversProvider = Provider.of<ServersProvider>(context);
return Scaffold(
body: DefaultTabController(
length: 3,
child: NestedScrollView(
controller: scrollController,
headerSliverBuilder: ((context, innerBoxIsScrolled) {
return [
2022-10-09 16:44:58 +02:00
SliverOverlapAbsorber(
handle: NestedScrollView.sliverOverlapAbsorberHandleFor(context),
sliver: SliverSafeArea(
top: false,
sliver: SliverAppBar(
title: Text(AppLocalizations.of(context)!.accessSettings),
pinned: true,
floating: true,
2023-03-16 23:29:18 +01:00
centerTitle: false,
2022-10-09 16:44:58 +02:00
forceElevated: innerBoxIsScrolled,
bottom: TabBar(
controller: tabController,
2022-10-28 01:53:42 +02:00
isScrollable: true,
2022-11-05 01:09:09 +01:00
unselectedLabelColor: Theme.of(context).colorScheme.onSurfaceVariant,
2022-10-09 16:44:58 +02:00
tabs: [
Tab(
2022-11-05 01:09:09 +01:00
icon: const Icon(Icons.check),
text: AppLocalizations.of(context)!.allowedClients,
2022-10-09 16:44:58 +02:00
),
Tab(
2022-11-05 01:09:09 +01:00
icon: const Icon(Icons.block),
text: AppLocalizations.of(context)!.disallowedClients,
2022-10-09 16:44:58 +02:00
),
Tab(
2022-11-05 01:09:09 +01:00
icon: const Icon(Icons.link_rounded),
text: AppLocalizations.of(context)!.disallowedDomains,
2022-10-09 16:44:58 +02:00
),
]
)
),
),
2022-10-09 01:13:55 +02:00
)
];
}),
2023-03-16 23:29:18 +01:00
body: TabBarView(
controller: tabController,
children: [
ClientsList(
type: 'allowed',
scrollController: scrollController,
loadStatus: serversProvider.clients.loadStatus,
2023-04-06 18:10:23 +02:00
data: serversProvider.clients.loadStatus == LoadStatus.loaded
2023-03-16 23:29:18 +01:00
? serversProvider.clients.data!.clientsAllowedBlocked!.allowedClients : [],
fetchClients: fetchClients
),
ClientsList(
type: 'disallowed',
scrollController: scrollController,
loadStatus: serversProvider.clients.loadStatus,
2023-04-06 18:10:23 +02:00
data: serversProvider.clients.loadStatus == LoadStatus.loaded
2023-03-16 23:29:18 +01:00
? serversProvider.clients.data!.clientsAllowedBlocked!.disallowedClients : [],
fetchClients: fetchClients
),
ClientsList(
type: 'domains',
scrollController: scrollController,
loadStatus: serversProvider.clients.loadStatus,
2023-04-06 18:10:23 +02:00
data: serversProvider.clients.loadStatus == LoadStatus.loaded
2023-03-16 23:29:18 +01:00
? serversProvider.clients.data!.clientsAllowedBlocked!.blockedHosts : [],
fetchClients: fetchClients
),
]
)
2022-10-09 01:13:55 +02:00
)
),
);
}
}