|  |  |  | @ -6,65 +6,73 @@ import 'package:mohem_flutter_app/extensions/int_extensions.dart'; | 
		
	
		
			
				|  |  |  |  | import 'package:mohem_flutter_app/extensions/string_extensions.dart'; | 
		
	
		
			
				|  |  |  |  | import 'package:mohem_flutter_app/extensions/widget_extensions.dart'; | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | AppBar AppBarWidget(BuildContext context, | 
		
	
		
			
				|  |  |  |  | PreferredSize AppBarWidget(BuildContext context, | 
		
	
		
			
				|  |  |  |  |     {required String title, | 
		
	
		
			
				|  |  |  |  |     bool showHomeButton = true, | 
		
	
		
			
				|  |  |  |  |     bool showNotificationButton = false, | 
		
	
		
			
				|  |  |  |  |     bool showMemberButton = false, | 
		
	
		
			
				|  |  |  |  |     String? image}) { | 
		
	
		
			
				|  |  |  |  |   return AppBar( | 
		
	
		
			
				|  |  |  |  |     leadingWidth: 0, | 
		
	
		
			
				|  |  |  |  |     // leading: GestureDetector( | 
		
	
		
			
				|  |  |  |  |     //   behavior: HitTestBehavior.opaque, | 
		
	
		
			
				|  |  |  |  |     //   onTap: Feedback.wrapForTap(() => Navigator.maybePop(context), context), | 
		
	
		
			
				|  |  |  |  |     //   child: const Icon(Icons.arrow_back_ios, color: MyColors.darkIconColor), | 
		
	
		
			
				|  |  |  |  |     // ), | 
		
	
		
			
				|  |  |  |  |     //titleSpacing: -1.44, | 
		
	
		
			
				|  |  |  |  |     title: Row( | 
		
	
		
			
				|  |  |  |  |   return PreferredSize( | 
		
	
		
			
				|  |  |  |  |     preferredSize: const Size.fromHeight(57.0), | 
		
	
		
			
				|  |  |  |  |     child: Column( | 
		
	
		
			
				|  |  |  |  |       children: [ | 
		
	
		
			
				|  |  |  |  |         GestureDetector( | 
		
	
		
			
				|  |  |  |  |           behavior: HitTestBehavior.opaque, | 
		
	
		
			
				|  |  |  |  |           onTap: | 
		
	
		
			
				|  |  |  |  |               Feedback.wrapForTap(() => Navigator.maybePop(context), context), | 
		
	
		
			
				|  |  |  |  |           child: | 
		
	
		
			
				|  |  |  |  |               const Icon(Icons.arrow_back_ios, color: MyColors.darkIconColor), | 
		
	
		
			
				|  |  |  |  |         AppBar( | 
		
	
		
			
				|  |  |  |  |           leadingWidth: 0, | 
		
	
		
			
				|  |  |  |  |           // leading: GestureDetector( | 
		
	
		
			
				|  |  |  |  |           //   behavior: HitTestBehavior.opaque, | 
		
	
		
			
				|  |  |  |  |           //   onTap: Feedback.wrapForTap(() => Navigator.maybePop(context), context), | 
		
	
		
			
				|  |  |  |  |           //   child: const Icon(Icons.arrow_back_ios, color: MyColors.darkIconColor), | 
		
	
		
			
				|  |  |  |  |           // ), | 
		
	
		
			
				|  |  |  |  |           //titleSpacing: -1.44, | 
		
	
		
			
				|  |  |  |  |           title: Row( | 
		
	
		
			
				|  |  |  |  |             children: [ | 
		
	
		
			
				|  |  |  |  |               GestureDetector( | 
		
	
		
			
				|  |  |  |  |                 behavior: HitTestBehavior.opaque, | 
		
	
		
			
				|  |  |  |  |                 onTap: | 
		
	
		
			
				|  |  |  |  |                     Feedback.wrapForTap(() => Navigator.maybePop(context), context), | 
		
	
		
			
				|  |  |  |  |                 child: | 
		
	
		
			
				|  |  |  |  |                     const Icon(Icons.arrow_back_ios, color: MyColors.darkIconColor), | 
		
	
		
			
				|  |  |  |  |               ), | 
		
	
		
			
				|  |  |  |  |               4.width, | 
		
	
		
			
				|  |  |  |  |               if (image != null) SvgPicture.asset( | 
		
	
		
			
				|  |  |  |  |                 image, | 
		
	
		
			
				|  |  |  |  |                 height: 40, | 
		
	
		
			
				|  |  |  |  |                 width: 40, | 
		
	
		
			
				|  |  |  |  |               ), | 
		
	
		
			
				|  |  |  |  |               if (image != null) 14.width, | 
		
	
		
			
				|  |  |  |  |               title.toText24(color: MyColors.darkTextColor, isBold: true).expanded, | 
		
	
		
			
				|  |  |  |  |             ], | 
		
	
		
			
				|  |  |  |  |           ), | 
		
	
		
			
				|  |  |  |  |           centerTitle: false, | 
		
	
		
			
				|  |  |  |  |           elevation: 0, | 
		
	
		
			
				|  |  |  |  |           backgroundColor: Colors.white, | 
		
	
		
			
				|  |  |  |  |           actions: [ | 
		
	
		
			
				|  |  |  |  |             if (showHomeButton) | 
		
	
		
			
				|  |  |  |  |               IconButton( | 
		
	
		
			
				|  |  |  |  |                 onPressed: () { | 
		
	
		
			
				|  |  |  |  |                   Navigator.popUntil( | 
		
	
		
			
				|  |  |  |  |                       context, ModalRoute.withName(AppRoutes.dashboard)); | 
		
	
		
			
				|  |  |  |  |                 }, | 
		
	
		
			
				|  |  |  |  |                 icon: const Icon(Icons.home, color: MyColors.darkIconColor), | 
		
	
		
			
				|  |  |  |  |               ), | 
		
	
		
			
				|  |  |  |  |             if (showNotificationButton) | 
		
	
		
			
				|  |  |  |  |               IconButton( | 
		
	
		
			
				|  |  |  |  |                 onPressed: () { | 
		
	
		
			
				|  |  |  |  |                   Navigator.pushNamed(context, AppRoutes.worklistSettings); | 
		
	
		
			
				|  |  |  |  |                 }, | 
		
	
		
			
				|  |  |  |  |                 icon: const Icon(Icons.notifications, color: MyColors.textMixColor), | 
		
	
		
			
				|  |  |  |  |               ), | 
		
	
		
			
				|  |  |  |  |             if (showMemberButton) | 
		
	
		
			
				|  |  |  |  |               IconButton( | 
		
	
		
			
				|  |  |  |  |                 onPressed: () { | 
		
	
		
			
				|  |  |  |  |                   Navigator.pushNamed(context, AppRoutes.subordinateLeave); | 
		
	
		
			
				|  |  |  |  |                 }, | 
		
	
		
			
				|  |  |  |  |                 icon: const Icon(Icons.people, color: MyColors.textMixColor), | 
		
	
		
			
				|  |  |  |  |               ), | 
		
	
		
			
				|  |  |  |  |           ], | 
		
	
		
			
				|  |  |  |  |         ), | 
		
	
		
			
				|  |  |  |  |         4.width, | 
		
	
		
			
				|  |  |  |  |         if (image != null) SvgPicture.asset( | 
		
	
		
			
				|  |  |  |  |           image, | 
		
	
		
			
				|  |  |  |  |           height: 40, | 
		
	
		
			
				|  |  |  |  |           width: 40, | 
		
	
		
			
				|  |  |  |  |         ), | 
		
	
		
			
				|  |  |  |  |         if (image != null) 14.width, | 
		
	
		
			
				|  |  |  |  |         title.toText24(color: MyColors.darkTextColor, isBold: true).expanded, | 
		
	
		
			
				|  |  |  |  |         Container(width: double.infinity, height: 1, color: MyColors.lightGreyEFColor), | 
		
	
		
			
				|  |  |  |  |       ], | 
		
	
		
			
				|  |  |  |  |     ), | 
		
	
		
			
				|  |  |  |  |     centerTitle: false, | 
		
	
		
			
				|  |  |  |  |     elevation: 0, | 
		
	
		
			
				|  |  |  |  |     backgroundColor: Colors.white, | 
		
	
		
			
				|  |  |  |  |     actions: [ | 
		
	
		
			
				|  |  |  |  |       if (showHomeButton) | 
		
	
		
			
				|  |  |  |  |         IconButton( | 
		
	
		
			
				|  |  |  |  |           onPressed: () { | 
		
	
		
			
				|  |  |  |  |             Navigator.popUntil( | 
		
	
		
			
				|  |  |  |  |                 context, ModalRoute.withName(AppRoutes.dashboard)); | 
		
	
		
			
				|  |  |  |  |           }, | 
		
	
		
			
				|  |  |  |  |           icon: const Icon(Icons.home, color: MyColors.darkIconColor), | 
		
	
		
			
				|  |  |  |  |         ), | 
		
	
		
			
				|  |  |  |  |       if (showNotificationButton) | 
		
	
		
			
				|  |  |  |  |         IconButton( | 
		
	
		
			
				|  |  |  |  |           onPressed: () { | 
		
	
		
			
				|  |  |  |  |             Navigator.pushNamed(context, AppRoutes.worklistSettings); | 
		
	
		
			
				|  |  |  |  |           }, | 
		
	
		
			
				|  |  |  |  |           icon: const Icon(Icons.notifications, color: MyColors.textMixColor), | 
		
	
		
			
				|  |  |  |  |         ), | 
		
	
		
			
				|  |  |  |  |       if (showMemberButton) | 
		
	
		
			
				|  |  |  |  |         IconButton( | 
		
	
		
			
				|  |  |  |  |           onPressed: () { | 
		
	
		
			
				|  |  |  |  |             Navigator.pushNamed(context, AppRoutes.subordinateLeave); | 
		
	
		
			
				|  |  |  |  |           }, | 
		
	
		
			
				|  |  |  |  |           icon: const Icon(Icons.people, color: MyColors.textMixColor), | 
		
	
		
			
				|  |  |  |  |         ), | 
		
	
		
			
				|  |  |  |  |     ], | 
		
	
		
			
				|  |  |  |  |   ); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
	
		
			
				
					|  |  |  | 
 |