This commit is contained in:
Hamza-Ayed
2023-08-15 23:55:41 +03:00
parent 65ade9c874
commit 9b3716aabd
19 changed files with 466 additions and 189 deletions

View File

@@ -3,6 +3,7 @@
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.FOREGROUND_SERVICE" /> <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
<application android:label="ride" android:name="${applicationName}" android:icon="@mipmap/ic_launcher"> <application android:label="ride" android:name="${applicationName}" android:icon="@mipmap/ic_launcher">
<activity android:name=".MainActivity" android:exported="true" android:launchMode="singleTop" android:theme="@style/LaunchTheme" android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode" android:hardwareAccelerated="true" android:windowSoftInputMode="adjustResize"> <activity android:name=".MainActivity" android:exported="true" android:launchMode="singleTop" android:theme="@style/LaunchTheme" android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode" android:hardwareAccelerated="true" android:windowSoftInputMode="adjustResize">
<!-- Specifies an Android theme to apply to this Activity as soon as <!-- Specifies an Android theme to apply to this Activity as soon as

View File

@@ -4,4 +4,5 @@ class AppColor {
static const Color primaryColor = Colors.black; static const Color primaryColor = Colors.black;
static const Color secondaryColor = Colors.white; static const Color secondaryColor = Colors.white;
static const Color accentColor = Colors.grey; static const Color accentColor = Colors.grey;
static const Color redColor = Color.fromARGB(255, 199, 56, 46);
} }

View File

@@ -0,0 +1,4 @@
class TableName {
static const String placesFavorite = "placesFavorite";
static const String carLocations = "carLocations";
}

View File

@@ -1,4 +1,5 @@
import 'dart:convert'; import 'dart:convert';
import 'dart:math';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_secure_storage/flutter_secure_storage.dart'; import 'package:flutter_secure_storage/flutter_secure_storage.dart';
@@ -7,8 +8,11 @@ import 'package:ride/constant/box_name.dart';
import 'package:ride/constant/links.dart'; import 'package:ride/constant/links.dart';
import 'package:ride/controller/functions/crud.dart'; import 'package:ride/controller/functions/crud.dart';
import 'package:ride/main.dart'; import 'package:ride/main.dart';
import 'package:ride/views/auth/verify_email_page.dart';
import 'package:ride/views/home/map_page.dart'; import 'package:ride/views/home/map_page.dart';
import '../firebase/firbase_messge.dart';
class LoginController extends GetxController { class LoginController extends GetxController {
final formKey = GlobalKey<FormState>(); final formKey = GlobalKey<FormState>();
TextEditingController emailController = TextEditingController(); TextEditingController emailController = TextEditingController();
@@ -46,12 +50,17 @@ class LoginController extends GetxController {
'phone': phoneController.text, 'phone': phoneController.text,
'password': passwordController.text 'password': passwordController.text
}); });
if (res == 'Failure') {
isloading = false;
update();
Get.snackbar('Failure', '', backgroundColor: Colors.red);
} else {
var jsonDecoeded = jsonDecode(res); var jsonDecoeded = jsonDecode(res);
// print(jsonDecoeded); // print(jsonDecoeded);
if (jsonDecoeded.isNotEmpty) { if (jsonDecoeded.isNotEmpty) {
if (jsonDecoeded['status'] == 'success') { if (jsonDecoeded['status'] == 'success') {
if (jsonDecoeded['data'][0]['verified'] == '1') { print(jsonDecoeded['data'][0]['verified']);
if (jsonDecoeded['data'][0]['verified'] == 1) {
box.write(BoxName.pasengerID, jsonDecoeded['data'][0]['id']); box.write(BoxName.pasengerID, jsonDecoeded['data'][0]['id']);
box.write(BoxName.email, jsonDecoeded['data'][0]['email']); box.write(BoxName.email, jsonDecoeded['data'][0]['email']);
box.write(BoxName.phone, jsonDecoeded['data'][0]['phone']); box.write(BoxName.phone, jsonDecoeded['data'][0]['phone']);
@@ -59,13 +68,27 @@ class LoginController extends GetxController {
isloading = false; isloading = false;
update(); update();
print(box.read(BoxName.pasengerID).toString()); print(box.read(BoxName.pasengerID).toString());
print(box.read(BoxName.tokenFCM));
await CRUD().post(link: AppLink.addTokens, payload: { await CRUD().post(link: AppLink.addTokens, payload: {
'token': box.read(BoxName.tokenFCM.toString()), 'token': box.read(BoxName.tokenFCM),
'passengerID': box.read(BoxName.pasengerID).toString() 'passengerID': box.read(BoxName.pasengerID).toString()
}).then((value) => print('cccc')); }).then((value) => print('cccc'));
} else { } else {
Get.snackbar('You must Verify email !.'.tr, '', isloading = false;
backgroundColor: Colors.yellow[300]); update();
Get.defaultDialog(
title: 'You must Verify email !.'.tr,
middleText: '',
backgroundColor: Colors.yellow[300],
onConfirm: () async {
int randomNumber = Random().nextInt(100000) + 1;
await CRUD().post(link: AppLink.sendVerifyEmail, payload: {
'email': emailController.text,
'token': randomNumber.toString(),
}).then((value) => print(value));
Get.to(() => const VerifyEmailPage());
},
);
} }
} else if (jsonDecoeded['status'] == 'Failure') { } else if (jsonDecoeded['status'] == 'Failure') {
Get.snackbar(jsonDecoeded['status'], jsonDecoeded['data'], Get.snackbar(jsonDecoeded['status'], jsonDecoeded['data'],
@@ -75,6 +98,9 @@ class LoginController extends GetxController {
} }
} else { } else {
print('res is null'); print('res is null');
isloading = false;
update();
}
} }
} }
@@ -87,6 +113,7 @@ class LoginController extends GetxController {
@override @override
void onInit() { void onInit() {
super.onInit(); super.onInit();
FirebasMessagesController().requestPermission();
// goToMapPage(); // goToMapPage();
} }
} }

View File

@@ -61,11 +61,10 @@ class RegisterController extends GetxController {
'email': emailController.text, 'email': emailController.text,
'token': verfyCode.text, 'token': verfyCode.text,
}); });
var jsondecod = jsonDecode(res);
if (jsondecod['status'] == 'success') { // if (jsondecod['status'] == 'success') {
Get.offAll(() => const MapPage()); Get.offAll(() => const MapPage());
} // }
} }
void register() async { void register() async {

View File

@@ -1,8 +1,10 @@
import 'dart:convert'; import 'dart:convert';
import 'dart:io'; import 'dart:io';
import 'package:firebase_messaging/firebase_messaging.dart'; import 'package:firebase_messaging/firebase_messaging.dart';
import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:http/http.dart' as http; import 'package:http/http.dart' as http;
import 'package:ride/constant/colors.dart';
import '../../constant/box_name.dart'; import '../../constant/box_name.dart';
import '../../constant/credential.dart'; import '../../constant/credential.dart';
@@ -29,17 +31,39 @@ class FirebasMessagesController extends GetxController {
await FirebaseMessaging.instance.getNotificationSettings(); await FirebaseMessaging.instance.getNotificationSettings();
print('------noti======'); print('------noti======');
print(notificationSettings!.authorizationStatus.toString()); print(notificationSettings!.authorizationStatus.toString());
// if (notificationSettings?.authorizationStatus.toString() ==
// 'AuthorizationStatus.denied') {
// await Get.defaultDialog(
// title: 'AuthorizationStatus',
// content: TextButton(
// onPressed: () {
// requestPermission();
// },
// child: Text(
// "Text Button",
// ),
// ),
// );
// }
update(); update();
} }
void requestPermission() async { Future checkAndRequestPermission() async {
if (notificationSettings!.authorizationStatus ==
AuthorizationStatus.denied) {
await requestPermission();
}
}
Future requestPermission() async {
// Check if the platform is Android // Check if the platform is Android
if (Platform.isAndroid) { if (Platform.isAndroid) {
// Request permission for Android // Request permission for Android
fcmToken.requestPermission().then((value) { fcmToken.requestPermission().then((value) {
if (value!.authorizationStatus == AuthorizationStatus.denied) { if (value.authorizationStatus == AuthorizationStatus.denied) {
print('dddddddddddddddddddddd'); print('dddddddddddddddddddddd');
} }
print(value.authorizationStatus);
}); });
} else { } else {
// Request permission for iOS // Request permission for iOS
@@ -86,8 +110,8 @@ class FirebasMessagesController extends GetxController {
// final SharedPreferences prefs = await SharedPreferences.getInstance(); // final SharedPreferences prefs = await SharedPreferences.getInstance();
await fcmToken.getToken().then( await fcmToken.getToken().then(
(token) { (token) {
// print(token);/
box.write(BoxName.tokenFCM, token); box.write(BoxName.tokenFCM, token);
print(box.read(BoxName.tokenFCM).toString());
}, },
); );
FirebaseMessaging.onMessage.listen((event) { FirebaseMessaging.onMessage.listen((event) {
@@ -95,8 +119,8 @@ class FirebasMessagesController extends GetxController {
'onMessage: ${event.notification!.title} ${event.notification!.body}'); 'onMessage: ${event.notification!.title} ${event.notification!.body}');
if (Get.currentRoute == '/') { if (Get.currentRoute == '/') {
// If the app is in the foreground, show a dialog to the user // If the app is in the foreground, show a dialog to the user
if (event.notification!.title.toString().contains('reef')) { if (event.notification!.title.toString().contains('ride')) {
// Get.snackbar('reeffff', 'message'); Get.snackbar('ride', 'message', backgroundColor: AppColor.redColor);
} else if (event.notification!.title.toString().contains('انذار')) { } else if (event.notification!.title.toString().contains('انذار')) {
// Get.to(() => const ProfilePage()); // Get.to(() => const ProfilePage());
} else if (event.notification!.title } else if (event.notification!.title
@@ -112,8 +136,8 @@ class FirebasMessagesController extends GetxController {
if (notification != null && android != null) { if (notification != null && android != null) {
print( print(
'onMessageOpenedApp: ${notification.title} ${notification.body}'); 'onMessageOpenedApp: ${notification.title} ${notification.body}');
if (event.notification!.title.toString().contains('reef')) { if (event.notification!.title.toString().contains('ride')) {
// Get.snackbar('reef', ''); Get.snackbar('ride', 'message', backgroundColor: AppColor.redColor);
// SendGpsNow().getSiteNotification(); // SendGpsNow().getSiteNotification();
} else if (event.notification!.title.toString().contains('انذار')) { } else if (event.notification!.title.toString().contains('انذار')) {
// Get.to(() => const ProfilePage()); // Get.to(() => const ProfilePage());
@@ -134,8 +158,8 @@ class FirebasMessagesController extends GetxController {
if (notification != null) { if (notification != null) {
print('onMessageOpenedApp: ${notification.title} ${notification.body}'); print('onMessageOpenedApp: ${notification.title} ${notification.body}');
if (event.notification!.title.toString().contains('reef')) { if (event.notification!.title.toString().contains('ride')) {
// Get.snackbar('reef', ''); Get.snackbar('ride', 'message', backgroundColor: AppColor.redColor);
// SendGpsNow().getSiteNotification(); // SendGpsNow().getSiteNotification();
} else if (event.notification!.title.toString().contains('انذار')) { } else if (event.notification!.title.toString().contains('انذار')) {
// Get.to(() => const ProfilePage()); // Get.to(() => const ProfilePage());

View File

@@ -21,7 +21,7 @@ class CRUD {
'Basic ${base64Encode(utf8.encode(AppCredintials.basicAuthCredentials))}', 'Basic ${base64Encode(utf8.encode(AppCredintials.basicAuthCredentials))}',
}, },
); );
// print("--------------" + response.request.toString()); // print("--------------" + response.body.toString());
if (response.statusCode == 200) { if (response.statusCode == 200) {
var jsonData = jsonDecode(response.body); var jsonData = jsonDecode(response.body);
if (jsonData['status'] == 'success') { if (jsonData['status'] == 'success') {
@@ -49,8 +49,8 @@ class CRUD {
}, },
); );
print(response.request); print(response.request);
if (response.statusCode == 200) {
var jsonData = jsonDecode(response.body); var jsonData = jsonDecode(response.body);
if (response.statusCode == 200) {
if (jsonData['status'] == 'success') { if (jsonData['status'] == 'success') {
Get.snackbar( Get.snackbar(
jsonData['status'], jsonData['status'],
@@ -60,7 +60,7 @@ class CRUD {
return response.body; return response.body;
} }
} }
// return (response.body); return (jsonData['status']);
} }
Future<dynamic> getGoogleApi({ Future<dynamic> getGoogleApi({

View File

@@ -0,0 +1,47 @@
import 'package:flutter/material.dart';
import 'package:flutter/src/widgets/basic.dart';
import 'package:get/get.dart';
import 'package:ride/constant/box_name.dart';
import 'package:ride/constant/colors.dart';
import 'package:ride/main.dart';
import 'package:ride/views/lang/languages.dart';
import 'package:ride/views/widgets/elevated_btn.dart';
import '../../constant/style.dart';
class LogOut {
Future logOut() async {
Get.defaultDialog(
title: 'Are you Sure to LogOut?'.tr,
content: Row(
mainAxisAlignment: MainAxisAlignment.spaceAround,
children: [
MyElevatedButton(
title: 'Cancel'.tr,
onPressed: () => Get.back(),
),
ElevatedButton(
style: ButtonStyle(
backgroundColor: MaterialStateProperty.all(AppColor.redColor),
),
onPressed: () {
// box.remove(BoxName.agreeTerms);
box.remove(BoxName.driverID);
box.remove(BoxName.email);
box.remove(BoxName.lang);
box.remove(BoxName.name);
box.remove(BoxName.pasengerID);
box.remove(BoxName.phone);
box.remove(BoxName.tokenFCM);
box.remove(BoxName.tokens);
Get.offAll(const Language());
},
child: Text(
'Sign Out'.tr,
style:
AppStyle.title.copyWith(color: AppColor.secondaryColor),
))
],
));
}
}

View File

@@ -11,6 +11,7 @@ import 'package:ride/controller/functions/crud.dart';
import 'package:ride/views/home/map_widget.dart/buttom_sheet_map_show.dart'; import 'package:ride/views/home/map_widget.dart/buttom_sheet_map_show.dart';
import '../../models/model/locations.dart'; import '../../models/model/locations.dart';
import '../firebase/firbase_messge.dart';
class MapController extends GetxController { class MapController extends GetxController {
bool isloading = true; bool isloading = true;
@@ -429,6 +430,7 @@ class MapController extends GetxController {
void onInit() async { void onInit() async {
// getPolyLine(); // getPolyLine();
// getMap(); // getMap();
FirebasMessagesController().requestPermission();
await getLocation(); await getLocation();
await getCarsLocationByPassenger(); await getCarsLocationByPassenger();
addCustomPicker(); addCustomPicker();

View File

@@ -3,6 +3,7 @@ import 'package:get/get.dart';
import '../../constant/box_name.dart'; import '../../constant/box_name.dart';
import '../../main.dart'; import '../../main.dart';
import '../firebase/firbase_messge.dart';
import '../themes/themes.dart'; import '../themes/themes.dart';
class LocaleController extends GetxController { class LocaleController extends GetxController {
@@ -21,6 +22,7 @@ class LocaleController extends GetxController {
@override @override
void onInit() { void onInit() {
FirebasMessagesController().requestPermission();
if (box.read(BoxName.lang) == "ar") { if (box.read(BoxName.lang) == "ar") {
language = const Locale("ar"); language = const Locale("ar");
appTheme = themeArabic; appTheme = themeArabic;

View File

@@ -14,9 +14,11 @@ import 'controller/functions/location_permission.dart';
import 'controller/local/local_controller.dart'; import 'controller/local/local_controller.dart';
import 'controller/local/translations.dart'; import 'controller/local/translations.dart';
import 'firebase_options.dart'; import 'firebase_options.dart';
import 'models/db_sql.dart';
import 'views/home/map_page.dart'; import 'views/home/map_page.dart';
final box = GetStorage(); final box = GetStorage();
DbSql sql = DbSql.instance;
@pragma('vm:entry-point') @pragma('vm:entry-point')
Future<void> backgroundMessageHandler(RemoteMessage message) async { Future<void> backgroundMessageHandler(RemoteMessage message) async {
await Firebase.initializeApp(); await Firebase.initializeApp();

View File

@@ -1,3 +1,4 @@
import 'package:ride/constant/table_names.dart';
import 'package:sqflite/sqflite.dart'; import 'package:sqflite/sqflite.dart';
import 'package:path/path.dart'; import 'package:path/path.dart';
@@ -21,7 +22,7 @@ class DbSql {
version: 1, version: 1,
onCreate: (db, version) async { onCreate: (db, version) async {
await db.execute(''' await db.execute('''
CREATE TABLE IF NOT EXISTS car_locations( CREATE TABLE IF NOT EXISTS ${TableName.carLocations}(
id INTEGER PRIMARY KEY AUTOINCREMENT, id INTEGER PRIMARY KEY AUTOINCREMENT,
driver_id INTEGER, driver_id INTEGER,
latitude REAL, latitude REAL,
@@ -30,6 +31,15 @@ class DbSql {
updated_at TEXT updated_at TEXT
) )
'''); ''');
await db.execute('''
CREATE TABLE IF NOT EXISTS ${TableName.placesFavorite}(
id INTEGER PRIMARY KEY AUTOINCREMENT,
latitude REAL,
longitude REAL,
name TEXT UNIQUE,
rate TEXT
)
''');
}, },
); );
} }

View File

@@ -3,7 +3,6 @@ import 'package:get/get.dart';
import 'package:ride/constant/colors.dart'; import 'package:ride/constant/colors.dart';
import 'package:ride/constant/style.dart'; import 'package:ride/constant/style.dart';
import 'package:ride/controller/auth/register_controller.dart'; import 'package:ride/controller/auth/register_controller.dart';
import 'package:ride/controller/auth/verify_email_controller.dart';
import 'package:ride/views/widgets/elevated_btn.dart'; import 'package:ride/views/widgets/elevated_btn.dart';
import 'package:ride/views/widgets/my_scafold.dart'; import 'package:ride/views/widgets/my_scafold.dart';

View File

@@ -3,6 +3,7 @@ import 'package:get/get.dart';
import 'package:google_maps_flutter/google_maps_flutter.dart'; import 'package:google_maps_flutter/google_maps_flutter.dart';
import 'package:ride/constant/colors.dart'; import 'package:ride/constant/colors.dart';
import 'package:ride/controller/home/map_page_controller.dart'; import 'package:ride/controller/home/map_page_controller.dart';
import 'package:ride/views/widgets/mycircular.dart';
import '../../controller/home/menu_controller.dart'; import '../../controller/home/menu_controller.dart';
import 'map_widget.dart/buttom_sheet_map_show.dart'; import 'map_widget.dart/buttom_sheet_map_show.dart';
@@ -22,9 +23,7 @@ class MapPage extends StatelessWidget {
children: [ children: [
GetBuilder<MapController>( GetBuilder<MapController>(
builder: (controller) => controller.isloading builder: (controller) => controller.isloading
? const Center( ? const MyCircularProgressIndicator()
child: CircularProgressIndicator.adaptive(),
)
: GoogleMap( : GoogleMap(
onMapCreated: controller.onMapCreated, onMapCreated: controller.onMapCreated,
cameraTargetBounds: cameraTargetBounds:
@@ -140,7 +139,7 @@ class MapPage extends StatelessWidget {
), ),
), ),
const PickerIconOnMap(), const PickerIconOnMap(),
PickerAnimtionContainer(), PickerAnimtionContainerFormPlaces(),
const MapMenuWidget(), const MapMenuWidget(),
const MenuIconMapPageWidget(), const MenuIconMapPageWidget(),
buttomSheetMapPage() buttomSheetMapPage()

View File

@@ -1,11 +1,15 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:ride/constant/table_names.dart';
import '../../../constant/colors.dart'; import '../../../constant/colors.dart';
import '../../../constant/style.dart'; import '../../../constant/style.dart';
import '../../../controller/home/map_page_controller.dart'; import '../../../controller/home/map_page_controller.dart';
import '../../../main.dart';
import '../../../models/db_sql.dart';
GetBuilder<MapController> formSearchPlaces() { GetBuilder<MapController> formSearchPlaces() {
// DbSql sql = DbSql.instance;
return GetBuilder<MapController>( return GetBuilder<MapController>(
builder: (controller) => Positioned( builder: (controller) => Positioned(
top: 5, top: 5,
@@ -33,6 +37,7 @@ GetBuilder<MapController> formSearchPlaces() {
'${controller.mylocation.latitude.toString()},${controller.mylocation.longitude.toString()}', '${controller.mylocation.latitude.toString()},${controller.mylocation.longitude.toString()}',
"${res['geometry']['location']['lat']},${res['geometry']['location']['lng']}"); "${res['geometry']['location']['lat']},${res['geometry']['location']['lng']}");
controller.places = []; controller.places = [];
controller.placeController.clear();
Get.back(); Get.back();
controller.bottomSheet(); controller.bottomSheet();
// Get.back(); // Get.back();
@@ -46,10 +51,27 @@ GetBuilder<MapController> formSearchPlaces() {
Row( Row(
mainAxisAlignment: mainAxisAlignment:
MainAxisAlignment.spaceBetween, MainAxisAlignment.spaceBetween,
children: [
Column(
children: [ children: [
Image.network( Image.network(
res['icon'], res['icon'],
width: 30, width: 20,
),
IconButton(
onPressed: () async {
await sql.insertData({
'latitude': res['geometry']
['location']['lat'],
'longitude': res['geometry']
['location']['lng'],
'name': res['name'].toString(),
'rate': res['rating'].toString(),
}, TableName.placesFavorite);
},
icon: const Icon(Icons.favorite_border),
),
],
), ),
Column( Column(
children: [ children: [

View File

@@ -1,24 +1,28 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:ride/constant/table_names.dart';
import 'package:ride/models/db_sql.dart';
import '../../../constant/colors.dart'; import '../../../constant/colors.dart';
import '../../../constant/style.dart'; import '../../../constant/style.dart';
import '../../../controller/home/map_page_controller.dart'; import '../../../controller/home/map_page_controller.dart';
import '../../../main.dart';
import '../../widgets/elevated_btn.dart'; import '../../widgets/elevated_btn.dart';
import 'form_search_places.dart'; import 'form_search_places.dart';
class PickerAnimtionContainer extends StatelessWidget { class PickerAnimtionContainerFormPlaces extends StatelessWidget {
PickerAnimtionContainer({ PickerAnimtionContainerFormPlaces({
super.key, super.key,
}); });
final controller = MapController(); final controller = MapController();
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
// DbSql sql = DbSql.instance;
return GetBuilder<MapController>( return GetBuilder<MapController>(
builder: (controller) => Positioned( builder: (controller) => Positioned(
bottom: 0, bottom: 0,
left: 0, left: 0,
right: 60, right: 5,
child: AnimatedContainer( child: AnimatedContainer(
duration: const Duration(milliseconds: 300), duration: const Duration(milliseconds: 300),
height: controller.places.isNotEmpty height: controller.places.isNotEmpty
@@ -52,8 +56,10 @@ class PickerAnimtionContainer extends StatelessWidget {
), ),
controller.isPickerShown controller.isPickerShown
? InkWell( ? InkWell(
onTapDown: (details) => onTapDown: (details) {
controller.changePickerShown(), controller.changePickerShown();
controller.changeHeight();
},
child: Container( child: Container(
height: 4, height: 4,
width: Get.width * .3, width: Get.width * .3,
@@ -71,7 +77,11 @@ class PickerAnimtionContainer extends StatelessWidget {
onTap: () {}, onTap: () {},
child: formSearchPlaces(), child: formSearchPlaces(),
) )
: TextButton( : Row(
mainAxisAlignment:
MainAxisAlignment.spaceEvenly,
children: [
TextButton(
onPressed: () { onPressed: () {
controller.changePickerShown(); controller.changePickerShown();
}, },
@@ -81,6 +91,106 @@ class PickerAnimtionContainer extends StatelessWidget {
style: AppStyle.subtitle, style: AppStyle.subtitle,
); );
}), }),
),
TextButton(
onPressed: () async {
List favoritePlaces = await sql
.getAllData(TableName.placesFavorite);
print(favoritePlaces);
Get.defaultDialog(
title: 'Favorite Places'.tr,
content: SizedBox(
width: Get.width * .8,
height: 300,
child: favoritePlaces.isEmpty
? Center(
child: Column(
mainAxisAlignment:
MainAxisAlignment
.center,
children: [
const Icon(
Icons
.hourglass_empty_rounded,
size: 99,
color: AppColor
.primaryColor,
),
Text(
'You Dont Have Any places yet !'
.tr,
style: AppStyle.title,
),
],
),
)
: ListView.builder(
itemCount:
favoritePlaces.length,
itemBuilder:
(BuildContext context,
int index) {
return Row(
mainAxisAlignment:
MainAxisAlignment
.spaceBetween,
children: [
TextButton(
onPressed: () async {
await controller
.getMap(
'${controller.mylocation.latitude},${controller.mylocation.longitude}',
'${favoritePlaces[index]['latitude']},${favoritePlaces[index]['longitude']}',
);
controller
.changePickerShown();
controller
.changeButtomSheetShown();
controller
.bottomSheet();
Get.back();
},
child: Text(
favoritePlaces[
index]['name'],
style:
AppStyle.title,
),
),
IconButton(
onPressed: () async {
await sql.deleteData(
TableName
.placesFavorite,
favoritePlaces[
index]
['id']);
Get.back();
Get.snackbar(
'Deleted ',
'You are Delete ${favoritePlaces[index]['name']} from your list',
backgroundColor:
AppColor
.accentColor);
},
icon: const Icon(Icons
.favorite_outlined),
),
],
);
},
),
),
);
},
child: Builder(builder: (context) {
return Text(
"Go To Favorite Places".tr,
style: AppStyle.subtitle,
);
}),
),
],
) )
], ],
), ),
@@ -95,6 +205,9 @@ class PickerAnimtionContainer extends StatelessWidget {
controller.changePickerShown(); controller.changePickerShown();
controller.changeButtomSheetShown(); controller.changeButtomSheetShown();
controller.bottomSheet(); controller.bottomSheet();
// await sql
// .getAllData(TableName.placesFavorite)
// .then((value) => print(value));
}, },
), ),
if (controller.isPickerShown && controller.places.isEmpty) if (controller.isPickerShown && controller.places.isEmpty)

View File

@@ -8,6 +8,8 @@ import 'package:ride/views/widgets/elevated_btn.dart';
import 'package:ride/views/widgets/my_scafold.dart'; import 'package:ride/views/widgets/my_scafold.dart';
import 'package:ride/views/widgets/mycircular.dart'; import 'package:ride/views/widgets/mycircular.dart';
import '../../../controller/functions/log_out.dart';
class PassengerProfilePage extends StatelessWidget { class PassengerProfilePage extends StatelessWidget {
const PassengerProfilePage({super.key}); const PassengerProfilePage({super.key});
@@ -23,6 +25,8 @@ class PassengerProfilePage extends StatelessWidget {
? const MyCircularProgressIndicator() ? const MyCircularProgressIndicator()
: Padding( : Padding(
padding: const EdgeInsets.symmetric(horizontal: 15), padding: const EdgeInsets.symmetric(horizontal: 15),
child: SizedBox(
height: Get.height,
child: SingleChildScrollView( child: SingleChildScrollView(
child: Column( child: Column(
mainAxisAlignment: MainAxisAlignment.start, mainAxisAlignment: MainAxisAlignment.start,
@@ -92,8 +96,8 @@ class PassengerProfilePage extends StatelessWidget {
width: 35, width: 35,
), ),
trailing: const Icon(Icons.arrow_forward_ios), trailing: const Icon(Icons.arrow_forward_ios),
subtitle: Text( subtitle: Text(controller.prfoileData['education']
controller.prfoileData['education'].toString()), .toString()),
onTap: () { onTap: () {
Get.defaultDialog( Get.defaultDialog(
title: 'Update Education'.tr, title: 'Update Education'.tr,
@@ -153,7 +157,18 @@ class PassengerProfilePage extends StatelessWidget {
], ],
), ),
), ),
)) ),
)),
Positioned(
left: 70,
bottom: 5,
right: 70,
child: MyElevatedButton(
title: 'Sign Out'.tr,
onPressed: () {
LogOut().logOut();
}),
)
], ],
); );
} }

View File

@@ -29,7 +29,7 @@ class Language extends GetView<LocaleController> {
onPressed: () { onPressed: () {
controller.changeLang("ar"); controller.changeLang("ar");
// main(); // main();
box.read(BoxName.email).toString() != '' box.read(BoxName.email) != null
? Get.offAll(() => const MapPage()) ? Get.offAll(() => const MapPage())
: Get.offAll(() => LoginPage()); : Get.offAll(() => LoginPage());
}, },
@@ -38,7 +38,7 @@ class Language extends GetView<LocaleController> {
title: "En", title: "En",
onPressed: () { onPressed: () {
controller.changeLang("en"); controller.changeLang("en");
box.read(BoxName.email).toString() != '' box.read(BoxName.email) != null
? Get.offAll(() => const MapPage()) ? Get.offAll(() => const MapPage())
: Get.offAll(() => LoginPage()); : Get.offAll(() => LoginPage());
}, },

View File

@@ -2,6 +2,10 @@ import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:ride/constant/colors.dart'; import 'package:ride/constant/colors.dart';
import '../../constant/box_name.dart';
import '../../constant/links.dart';
import '../../controller/functions/crud.dart';
import '../../main.dart';
import '../widgets/my_scafold.dart'; import '../widgets/my_scafold.dart';
class NotificationPage extends StatelessWidget { class NotificationPage extends StatelessWidget {
@@ -13,7 +17,13 @@ class NotificationPage extends StatelessWidget {
isleading: true, isleading: true,
title: 'Notifications', title: 'Notifications',
action: IconButton( action: IconButton(
onPressed: () {}, onPressed: () async {
print(box.read(BoxName.tokenFCM).toString());
// await CRUD().post(link: AppLink.addTokens, payload: {
// 'token': box.read(BoxName.tokenFCM).toString(),
// 'passengerID': box.read(BoxName.pasengerID).toString()
// }).then((value) => print('cccc'));
},
icon: const Icon( icon: const Icon(
Icons.add, Icons.add,
color: AppColor.primaryColor, color: AppColor.primaryColor,