import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; import 'package:test_sa/controllers/providers/api/all_requests_provider.dart'; import 'package:test_sa/controllers/providers/api/notifications_provider.dart'; import 'package:test_sa/controllers/providers/settings/setting_provider.dart'; import 'package:test_sa/extensions/context_extension.dart'; import 'package:test_sa/extensions/int_extensions.dart'; import 'package:test_sa/extensions/text_extensions.dart'; import 'package:test_sa/extensions/widget_extensions.dart'; import 'package:test_sa/new_views/app_style/app_color.dart'; import 'package:test_sa/views/pages/user/notifications/notifications_page.dart'; import '../../controllers/providers/api/user_provider.dart'; import '../../models/user.dart'; class AppBarWidget extends StatelessWidget { final VoidCallback onDrawerPress; const AppBarWidget({Key key, this.onDrawerPress}) : super(key: key); @override Widget build(BuildContext context) { return AppBar( automaticallyImplyLeading: false, backgroundColor: Theme.of(context).scaffoldBackgroundColor, titleSpacing: 0, title: Consumer(builder: (context, snapshot, _) { return Row( // mainAxisAlignment: MainAxisAlignment.spaceBetween, crossAxisAlignment: CrossAxisAlignment.center, children: [ CircleAvatar( radius: 24, backgroundColor: context.isDark ? AppColor.neutral50 : AppColor.neutral40, child: Padding( padding: const EdgeInsets.all(1), // Border radius child: ClipOval( child: snapshot.profileImage != null ? Image.file(snapshot.profileImage) : (snapshot.user.profilePhotoName?.isNotEmpty ?? false) ? Image.network(snapshot.user.profilePhotoName) : const Icon(Icons.person, size: 24, color: Colors.white), ), ), ).onPress(onDrawerPress), 8.width, Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ Text( snapshot.user == null ? "" : (snapshot.user?.username ?? ""), style: AppTextStyles.heading6.copyWith(color: context.isDark ? AppColor.neutral30 : AppColor.neutral50, fontWeight: FontWeight.w600), ), Text( snapshot.user == null ? "" : snapshot.user?.type?.name?.toCamelCase ?? "", style: AppTextStyles.bodyText.copyWith(color: context.isDark ? AppColor.neutral10 : AppColor.neutral20), ), ], ), const Spacer(), Consumer(builder: (context, settingProvider, child) { return Container( padding: const EdgeInsets.fromLTRB(12, 6, 6, 6), decoration: BoxDecoration( borderRadius: BorderRadius.circular(8), color: AppColor.background(context), boxShadow: const [ BoxShadow( color: Color(0x07000000), blurRadius: 14, offset: Offset(0, 0), spreadRadius: 0, ) ], ), child: DropdownButton( value: settingProvider.assetGroup, //iconSize: 24, isDense: true, icon: const Icon(Icons.keyboard_arrow_down), elevation: 8, // dropdownColor: Colors.amber, borderRadius: BorderRadius.circular(8), style: TextStyle(color: Theme.of(context).primaryColor), underline: const SizedBox.shrink(), onChanged: (newValue) { if (settingProvider.assetGroup != newValue) { settingProvider.setAssetGroup(newValue); WidgetsBinding.instance.addPostFrameCallback((_) { Provider.of(context, listen: false).getRequests(); Provider.of(context, listen: false).getSystemNotifications(user: Provider.of(context, listen: false).user, resetProvider: true); }); } }, items: Provider.of(context, listen: false).user.assetGroups.map>((value) { return DropdownMenuItem( value: value, child: Text( value?.name ?? "", style: Theme.of(context).textTheme.bodyLarge, ), ); })?.toList(), ), ); }), 16.width, Stack( alignment: Alignment.topRight, children: [ Icon(Icons.notifications, color: context.isDark ? AppColor.neutral30 : AppColor.neutral20, size: 30).paddingOnly(top: 6, end: 0), // todo @sikander will add count for unread notifications // Positioned( // top: 0, // right: 0, // child: Container( // padding: const EdgeInsets.all(4), // decoration: const ShapeDecoration( // color: Color(0xFFD02127), // shape: CircleBorder(), // ), // child: Text("", style: AppTextStyles.bodyText), // ), // ) ], ).onPress(() { Navigator.of(context).pushNamed(NotificationsPage.id); }), ], ).paddingOnly(start: 16, end: 16); }), ); } }