OpenContacts/lib/widgets/friends/friends_list_app_bar.dart

145 lines
5.2 KiB
Dart
Raw Normal View History

import 'package:collection/collection.dart';
2024-07-15 00:23:04 -04:00
import 'package:OpenContacts/client_holder.dart';
import 'package:OpenContacts/clients/messaging_client.dart';
import 'package:OpenContacts/models/users/online_status.dart';
import 'package:OpenContacts/widgets/friends/user_search.dart';
import 'package:OpenContacts/widgets/my_profile_dialog.dart';
2023-06-03 11:17:54 -04:00
import 'package:flutter/material.dart';
import 'package:intl/intl.dart';
import 'package:provider/provider.dart';
class FriendsListAppBar extends StatefulWidget {
const FriendsListAppBar({super.key});
@override
State<StatefulWidget> createState() => _FriendsListAppBarState();
}
class _FriendsListAppBarState extends State<FriendsListAppBar> with AutomaticKeepAliveClientMixin {
@override
Widget build(BuildContext context) {
super.build(context);
return AppBar(
2024-07-25 17:02:29 -04:00
title: const Text("Contacts"),
actions: [
2023-09-30 09:22:37 -04:00
Consumer<MessagingClient>(builder: (context, client, _) {
return PopupMenuButton<OnlineStatus>(
child: Row(
children: [
Padding(
padding: const EdgeInsets.only(right: 8.0),
child: Icon(
Icons.circle,
size: 16,
color: client.userStatus.onlineStatus.color(context),
),
),
Text(toBeginningOfSentenceCase(client.userStatus.onlineStatus.name) ?? "Unknown"),
],
),
onSelected: (OnlineStatus onlineStatus) async {
final settingsClient = ClientHolder.of(context).settingsClient;
try {
2023-10-10 03:53:34 -04:00
await client.setOnlineStatus(onlineStatus);
2023-09-30 09:22:37 -04:00
await settingsClient
.changeSettings(settingsClient.currentSettings.copyWith(lastOnlineStatus: onlineStatus.index));
} catch (e, s) {
FlutterError.reportError(FlutterErrorDetails(exception: e, stack: s));
if (context.mounted) {
ScaffoldMessenger.of(context)
.showSnackBar(const SnackBar(content: Text("Failed to set online-status.")));
}
}
},
itemBuilder: (BuildContext context) => OnlineStatus.values
2024-07-15 11:13:40 -04:00
.where((element) => element == OnlineStatus.sociable || element == OnlineStatus.online ||element == OnlineStatus.busy || element == OnlineStatus.offline).sorted((a, b) => b.index.compareTo(a.index),)
2023-09-30 09:22:37 -04:00
.map(
(item) => PopupMenuItem<OnlineStatus>(
value: item,
child: Row(
mainAxisAlignment: MainAxisAlignment.start,
children: [
Icon(
Icons.circle,
size: 16,
2023-09-30 09:22:37 -04:00
color: item.color(context),
),
2023-09-30 09:22:37 -04:00
const SizedBox(
width: 8,
),
Text(toBeginningOfSentenceCase(item.name)!),
],
2023-06-03 11:17:54 -04:00
),
),
2023-09-30 09:22:37 -04:00
)
.toList(),
);
}),
Padding(
padding: const EdgeInsets.only(left: 4, right: 4),
child: PopupMenuButton<MenuItemDefinition>(
icon: const Icon(Icons.more_vert),
onSelected: (MenuItemDefinition itemDef) async {
await itemDef.onTap();
2023-06-03 11:17:54 -04:00
},
itemBuilder: (BuildContext context) => [
MenuItemDefinition(
2024-07-15 02:08:17 -04:00
name: "Add Users",
icon: Icons.person_add,
onTap: () async {
final mClient = Provider.of<MessagingClient>(context, listen: false);
await Navigator.of(context).push(
MaterialPageRoute(
builder: (context) => ChangeNotifierProvider<MessagingClient>.value(
value: mClient,
child: const UserSearch(),
2023-06-03 11:17:54 -04:00
),
),
);
},
),
MenuItemDefinition(
name: "My Profile",
icon: Icons.person,
onTap: () async {
await showDialog(
context: context,
builder: (context) {
return const MyProfileDialog();
},
);
},
),
]
.map(
(item) => PopupMenuItem<MenuItemDefinition>(
2023-09-30 09:22:37 -04:00
value: item,
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(item.name),
Icon(item.icon),
],
),
),
)
.toList(),
),
)
],
2023-06-03 11:17:54 -04:00
);
}
@override
bool get wantKeepAlive => true;
}
class MenuItemDefinition {
final String name;
final IconData icon;
final Function() onTap;
const MenuItemDefinition({required this.name, required this.icon, required this.onTap});
}