256 lines
9.2 KiB
Dart
256 lines
9.2 KiB
Dart
import 'package:SEFER/constant/api_key.dart';
|
|
import 'package:SEFER/constant/links.dart';
|
|
import 'package:SEFER/controller/home/captin/home_captain_controller.dart';
|
|
import 'package:SEFER/views/auth/captin/contact_us_page.dart';
|
|
import 'package:SEFER/views/auth/captin/invite_driver_screen.dart';
|
|
import 'package:SEFER/views/notification/available_rides_page.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_rating_bar/flutter_rating_bar.dart';
|
|
import 'package:get/get.dart';
|
|
import 'package:SEFER/constant/box_name.dart';
|
|
import 'package:SEFER/main.dart';
|
|
import 'package:SEFER/views/auth/captin/logout_captain.dart';
|
|
import 'package:SEFER/views/home/Captin/history/history_captain.dart';
|
|
import 'package:SEFER/views/home/Captin/home_captain/help_captain.dart';
|
|
import 'package:SEFER/views/home/Captin/About%20Us/settings_captain.dart';
|
|
import 'package:SEFER/views/home/my_wallet/walet_captain.dart';
|
|
import 'package:SEFER/views/home/profile/profile_captain.dart';
|
|
import 'package:SEFER/views/notification/notification_captain.dart';
|
|
|
|
import '../../../../constant/colors.dart';
|
|
import '../../../../controller/functions/upload_image.dart';
|
|
import '../assurance_health_page.dart';
|
|
import '../maintain_center_page.dart';
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
class CupertinoDrawerCaptain extends StatelessWidget {
|
|
final ImageController imageController = Get.put(ImageController());
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return CupertinoPageScaffold(
|
|
navigationBar: CupertinoNavigationBar(
|
|
middle: Text('Menu'.tr),
|
|
),
|
|
child: SafeArea(
|
|
child: CustomScrollView(
|
|
slivers: [
|
|
const SliverToBoxAdapter(child: const UserAccountHeader()),
|
|
SliverList(
|
|
delegate: SliverChildListDelegate([
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.money_dollar,
|
|
text: 'Wallet'.tr,
|
|
onTap: () => Get.to(() => WalletCaptain()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.person,
|
|
text: 'Profile'.tr,
|
|
onTap: () => Get.to(() => ProfileCaptain()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.clock,
|
|
text: 'History of Trip'.tr,
|
|
onTap: () => Get.to(() => const HistoryCaptain()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.car_detailed,
|
|
text: 'Available for rides'.tr,
|
|
onTap: () => Get.to(() => const AvailableRidesPage()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.bell,
|
|
text: 'Notifications'.tr,
|
|
onTap: () => Get.to(() => const NotificationCaptain()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.question_circle,
|
|
text: 'Helping Center'.tr,
|
|
onTap: () => Get.to(() => HelpCaptain()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.share,
|
|
text: 'Share App'.tr,
|
|
onTap: () => Get.to(() => InviteDriverScreen()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.wrench,
|
|
text: "Maintenance Center".tr,
|
|
onTap: () => Get.to(() => MaintainCenterPage()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon:
|
|
CupertinoIcons.heart, // Updated icon to represent health
|
|
text: "Health Insurance".tr, // Updated English text
|
|
onTap: () => Get.to(() => AssuranceHealthPage()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.mail,
|
|
text: "Contact Us".tr,
|
|
onTap: () => Get.to(() => ContactUsPage()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.settings,
|
|
text: 'Settings'.tr,
|
|
onTap: () => Get.to(() => const SettingsCaptain()),
|
|
),
|
|
_buildDivider(),
|
|
_buildDrawerItem(
|
|
icon: CupertinoIcons.square_arrow_right,
|
|
text: 'Sign Out'.tr,
|
|
onTap: () => Get.to(() => const LogoutCaptain()),
|
|
),
|
|
_buildDivider(),
|
|
]),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
Widget _buildDivider() {
|
|
return const Divider(
|
|
thickness: 1,
|
|
height: 1,
|
|
color: CupertinoColors.systemGrey4,
|
|
);
|
|
}
|
|
|
|
Widget _buildDrawerItem({
|
|
required IconData icon,
|
|
required String text,
|
|
required VoidCallback onTap,
|
|
}) {
|
|
return CupertinoButton(
|
|
onPressed: onTap,
|
|
child: Row(
|
|
children: [
|
|
Icon(icon, color: CupertinoColors.activeBlue),
|
|
const SizedBox(width: 10),
|
|
Text(text, style: const TextStyle(color: CupertinoColors.label)),
|
|
const Spacer(),
|
|
const Icon(CupertinoIcons.right_chevron,
|
|
color: CupertinoColors.systemGrey),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|
|
|
|
class UserAccountHeader extends StatelessWidget {
|
|
const UserAccountHeader({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Container(
|
|
padding: const EdgeInsets.all(16),
|
|
decoration: const BoxDecoration(
|
|
gradient: LinearGradient(
|
|
colors: [AppColor.blueColor, AppColor.twitterColor],
|
|
begin: Alignment.topLeft,
|
|
end: Alignment.bottomRight,
|
|
),
|
|
),
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
GetBuilder<ImageController>(
|
|
builder: (imageController) {
|
|
return Stack(
|
|
children: [
|
|
imageController.isloading
|
|
? const CupertinoActivityIndicator()
|
|
: Container(
|
|
width: 100,
|
|
height: 100,
|
|
decoration: BoxDecoration(
|
|
shape: BoxShape.circle,
|
|
image: DecorationImage(
|
|
fit: BoxFit.cover,
|
|
image: NetworkImage(
|
|
'${AppLink.seferCairoServer}/portrate_captain_image/${box.read(BoxName.driverID)}.jpg',
|
|
),
|
|
),
|
|
),
|
|
),
|
|
Positioned(
|
|
right: 0,
|
|
top: 0,
|
|
child: CupertinoButton(
|
|
onPressed: () {
|
|
imageController.choosImagePicture(
|
|
AppLink.uploadImage1, 'portrait');
|
|
},
|
|
child: const Icon(CupertinoIcons.pencil_circle_fill,
|
|
color: CupertinoColors.white),
|
|
),
|
|
),
|
|
],
|
|
);
|
|
},
|
|
),
|
|
const SizedBox(height: 10),
|
|
Text(
|
|
box.read(BoxName.nameDriver).toString(),
|
|
style: const TextStyle(
|
|
color: CupertinoColors.white,
|
|
fontSize: 18,
|
|
fontWeight: FontWeight.bold),
|
|
),
|
|
const SizedBox(height: 5),
|
|
Text(
|
|
box.read(BoxName.emailDriver),
|
|
style: const TextStyle(color: CupertinoColors.white, fontSize: 14),
|
|
),
|
|
const SizedBox(height: 10),
|
|
Row(
|
|
children: [
|
|
Text(
|
|
Get.find<HomeCaptainController>().rating.toString(),
|
|
style: const TextStyle(
|
|
color: CupertinoColors.systemYellow, fontSize: 16),
|
|
),
|
|
const SizedBox(width: 5),
|
|
// You might want to replace this with a Cupertino-style rating widget
|
|
// For now, we'll use text to represent stars
|
|
// const Text('★★★★★',
|
|
// style: TextStyle(color: CupertinoColors.systemYellow)),
|
|
|
|
Container(
|
|
padding: const EdgeInsets.symmetric(horizontal: 4, vertical: 1),
|
|
color: AppColor.greenColor,
|
|
child: RatingBar.builder(
|
|
initialRating: double.parse(
|
|
Get.find<HomeCaptainController>().rating.toString()),
|
|
minRating: 1,
|
|
direction: Axis.horizontal,
|
|
itemCount: 5,
|
|
itemSize: 20,
|
|
itemPadding: const EdgeInsets.symmetric(horizontal: 2),
|
|
itemBuilder: (context, _) => const Icon(
|
|
Icons.star,
|
|
color: Colors.amber,
|
|
),
|
|
onRatingUpdate: (rating) {},
|
|
),
|
|
),
|
|
],
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|