You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			120 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Dart
		
	
			
		
		
	
	
			120 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Dart
		
	
| import 'package:flutter/material.dart';
 | |
| 
 | |
| import 'package:flutter_gen/gen_l10n/l10n.dart';
 | |
| import 'package:future_loading_dialog/future_loading_dialog.dart';
 | |
| import 'package:matrix/matrix.dart';
 | |
| 
 | |
| import 'package:fluffychat/widgets/layouts/max_width_body.dart';
 | |
| import '../../utils/localized_exception_extension.dart';
 | |
| import '../../widgets/matrix.dart';
 | |
| import 'settings_notifications.dart';
 | |
| 
 | |
| class SettingsNotificationsView extends StatelessWidget {
 | |
|   final SettingsNotificationsController controller;
 | |
| 
 | |
|   const SettingsNotificationsView(this.controller, {Key? key})
 | |
|       : super(key: key);
 | |
| 
 | |
|   @override
 | |
|   Widget build(BuildContext context) {
 | |
|     return Scaffold(
 | |
|       appBar: AppBar(
 | |
|         leading: const BackButton(),
 | |
|         title: Text(L10n.of(context)!.notifications),
 | |
|       ),
 | |
|       body: MaxWidthBody(
 | |
|         withScrolling: true,
 | |
|         child: StreamBuilder(
 | |
|           stream: Matrix.of(context)
 | |
|               .client
 | |
|               .onAccountData
 | |
|               .stream
 | |
|               .where((event) => event.type == 'm.push_rules'),
 | |
|           builder: (BuildContext context, _) {
 | |
|             return Column(
 | |
|               children: [
 | |
|                 SwitchListTile.adaptive(
 | |
|                   value: !Matrix.of(context).client.allPushNotificationsMuted,
 | |
|                   title: Text(
 | |
|                     L10n.of(context)!.notificationsEnabledForThisAccount,
 | |
|                   ),
 | |
|                   onChanged: (_) => showFutureLoadingDialog(
 | |
|                     context: context,
 | |
|                     future: () => Matrix.of(context)
 | |
|                         .client
 | |
|                         .setMuteAllPushNotifications(
 | |
|                           !Matrix.of(context).client.allPushNotificationsMuted,
 | |
|                         ),
 | |
|                   ),
 | |
|                 ),
 | |
|                 if (!Matrix.of(context).client.allPushNotificationsMuted) ...{
 | |
|                   const Divider(thickness: 1),
 | |
|                   ListTile(
 | |
|                     title: Text(
 | |
|                       L10n.of(context)!.pushRules,
 | |
|                       style: TextStyle(
 | |
|                         color: Theme.of(context).colorScheme.secondary,
 | |
|                         fontWeight: FontWeight.bold,
 | |
|                       ),
 | |
|                     ),
 | |
|                   ),
 | |
|                   for (var item in NotificationSettingsItem.items)
 | |
|                     SwitchListTile.adaptive(
 | |
|                       value: controller.getNotificationSetting(item) ?? true,
 | |
|                       title: Text(item.title(context)),
 | |
|                       onChanged: (bool enabled) =>
 | |
|                           controller.setNotificationSetting(item, enabled),
 | |
|                     ),
 | |
|                 },
 | |
|                 const Divider(thickness: 1),
 | |
|                 ListTile(
 | |
|                   title: Text(
 | |
|                     L10n.of(context)!.devices,
 | |
|                     style: TextStyle(
 | |
|                       color: Theme.of(context).colorScheme.secondary,
 | |
|                       fontWeight: FontWeight.bold,
 | |
|                     ),
 | |
|                   ),
 | |
|                 ),
 | |
|                 FutureBuilder<List<Pusher>?>(
 | |
|                   future: controller.pusherFuture ??=
 | |
|                       Matrix.of(context).client.getPushers(),
 | |
|                   builder: (context, snapshot) {
 | |
|                     if (snapshot.hasError) {
 | |
|                       Center(
 | |
|                         child: Text(
 | |
|                           snapshot.error!.toLocalizedString(context),
 | |
|                         ),
 | |
|                       );
 | |
|                     }
 | |
|                     if (snapshot.connectionState != ConnectionState.done) {
 | |
|                       const Center(
 | |
|                         child: CircularProgressIndicator.adaptive(
 | |
|                           strokeWidth: 2,
 | |
|                         ),
 | |
|                       );
 | |
|                     }
 | |
|                     final pushers = snapshot.data ?? [];
 | |
|                     return ListView.builder(
 | |
|                       physics: const NeverScrollableScrollPhysics(),
 | |
|                       shrinkWrap: true,
 | |
|                       itemCount: pushers.length,
 | |
|                       itemBuilder: (_, i) => ListTile(
 | |
|                         title: Text(
 | |
|                           '${pushers[i].appDisplayName} - ${pushers[i].appId}',
 | |
|                         ),
 | |
|                         subtitle: Text(pushers[i].data.url.toString()),
 | |
|                         onTap: () => controller.onPusherTap(pushers[i]),
 | |
|                       ),
 | |
|                     );
 | |
|                   },
 | |
|                 ),
 | |
|               ],
 | |
|             );
 | |
|           },
 | |
|         ),
 | |
|       ),
 | |
|     );
 | |
|   }
 | |
| }
 |