diff --git a/android/build/reports/problems/problems-report.html b/android/build/reports/problems/problems-report.html
index 4111900..243e3a1 100644
--- a/android/build/reports/problems/problems-report.html
+++ b/android/build/reports/problems/problems-report.html
@@ -650,7 +650,7 @@ code + .copy-button {
diff --git a/lib/binding/initial_binding.dart b/lib/binding/initial_binding.dart
new file mode 100644
index 0000000..551c451
--- /dev/null
+++ b/lib/binding/initial_binding.dart
@@ -0,0 +1,9 @@
+import 'package:get/get.dart';
+import '../controller/admin/dashboard_controller.dart';
+
+class InitialBinding extends Bindings {
+ @override
+ void dependencies() {
+ Get.put(DashboardController(), permanent: true);
+ }
+}
diff --git a/lib/constant/colors.dart b/lib/constant/colors.dart
index efde492..156772a 100644
--- a/lib/constant/colors.dart
+++ b/lib/constant/colors.dart
@@ -1,7 +1,5 @@
import 'package:flutter/material.dart';
-import 'package:flutter/material.dart';
-
class AppColor {
// --- Core Design Tokens ---
@@ -42,5 +40,5 @@ class AppColor {
static const Color greenColor = success;
static const Color blueColor = info;
static const Color yellowColor = warning;
+ static const Color deepPurpleAccent = accent; // Map to accent
}
-
diff --git a/lib/constant/links.dart b/lib/constant/links.dart
index ba7469f..93a4c2c 100644
--- a/lib/constant/links.dart
+++ b/lib/constant/links.dart
@@ -119,6 +119,7 @@ class AppLink {
/////////---getKazanPercent===////////////
static String getKazanPercent = "$ride/kazan/get.php";
static String addKazanPercent = "$ride/kazan/add.php";
+ static String updateKazanPercent = "$ride/kazan/update.php";
////-----------------DriverPayment------------------
static String addDriverpayment = "$tripzPaymentServer/payment/add.php";
diff --git a/lib/controller/admin/complaint_controller.dart b/lib/controller/admin/complaint_controller.dart
new file mode 100644
index 0000000..52634fe
--- /dev/null
+++ b/lib/controller/admin/complaint_controller.dart
@@ -0,0 +1,56 @@
+import 'dart:convert';
+import 'package:get/get.dart';
+import '../../constant/links.dart';
+import '../functions/crud.dart';
+
+class ComplaintController extends GetxController {
+ var complaintList = [].obs;
+ var isLoading = false.obs;
+ final CRUD _crud = CRUD();
+
+ @override
+ void onInit() {
+ super.onInit();
+ getComplaints();
+ }
+
+ Future getComplaints() async {
+ isLoading.value = true;
+ try {
+ var response = await _crud.get(link: AppLink.getComplaintAllData);
+ if (response != null && response != 'failure' && response != 'token_expired') {
+ var decoded = response is String ? jsonDecode(response) : response;
+ if (decoded['status'] == "success") {
+ complaintList.assignAll(decoded['message']);
+ }
+ } else {
+ complaintList.clear();
+ }
+ } catch (e) {
+ Get.snackbar("خطأ", "فشل جلب الشكاوى: $e");
+ } finally {
+ isLoading.value = false;
+ }
+ }
+
+ Future updateComplaintStatus(String id, String status, String resolution) async {
+ isLoading.value = true;
+ try {
+ var response = await _crud.post(link: "${AppLink.server}/serviceapp/update_complaint.php", payload: {
+ "id": id,
+ "statusComplaint": status,
+ "resolution": resolution,
+ });
+ if (response != null && response is Map && response['status'] == "success") {
+ await getComplaints();
+ return true;
+ }
+ return false;
+ } catch (e) {
+ Get.snackbar("خطأ", "فشل تحديث الشكوى: $e");
+ return false;
+ } finally {
+ isLoading.value = false;
+ }
+ }
+}
diff --git a/lib/controller/admin/dashboard_controller.dart b/lib/controller/admin/dashboard_controller.dart
index c18375d..3f9e642 100644
--- a/lib/controller/admin/dashboard_controller.dart
+++ b/lib/controller/admin/dashboard_controller.dart
@@ -4,6 +4,7 @@ import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:sefer_admin1/constant/links.dart';
import 'package:sefer_admin1/controller/functions/crud.dart';
+import 'package:sefer_admin1/controller/auth/otp_helper.dart';
import '../../constant/api_key.dart';
import '../../constant/box_name.dart';
@@ -25,6 +26,19 @@ class DashboardController extends GetxController {
var res = await CRUD().get(link: AppLink.getdashbord, payload: {});
print('📡 Main dashboard response: $res');
+ if (res == 'token_expired') {
+ print('❌ Admin token expired. Attempting seamless auto-login.');
+ box.remove(BoxName.jwt);
+ try {
+ final otpHelper = Get.put(OtpHelper());
+ await otpHelper.checkAdminLogin();
+ } catch (e) {
+ Get.offAllNamed('/login');
+ }
+ return;
+ }
+
+
if (res != 'failure' && res != null) {
try {
var d = res is String ? jsonDecode(res) : res;
diff --git a/lib/controller/admin/driver_docs_controller.dart b/lib/controller/admin/driver_docs_controller.dart
new file mode 100644
index 0000000..ef88f70
--- /dev/null
+++ b/lib/controller/admin/driver_docs_controller.dart
@@ -0,0 +1,97 @@
+import 'dart:convert';
+import 'package:get/get.dart';
+import '../../constant/links.dart';
+import '../functions/crud.dart';
+
+class DriverDocsController extends GetxController {
+ var pendingDrivers = [].obs;
+ var isLoading = false.obs;
+ var isMoreLoading = false.obs;
+ var hasMore = true.obs;
+ int _offset = 0;
+ final int _limit = 10;
+ final CRUD _crud = CRUD();
+
+ @override
+ void onInit() {
+ super.onInit();
+ getPendingDrivers();
+ }
+
+ Future getPendingDrivers({bool refresh = true}) async {
+ if (refresh) {
+ isLoading.value = true;
+ _offset = 0;
+ hasMore.value = true;
+ } else {
+ if (isMoreLoading.value || !hasMore.value) return;
+ isMoreLoading.value = true;
+ }
+
+ try {
+ var response = await _crud.post(
+ link: AppLink.getDriversPending,
+ payload: {"limit": _limit.toString(), "offset": _offset.toString()},
+ );
+ if (response != null && response != 'failure' && response != 'token_expired') {
+ var decoded = response is String ? jsonDecode(response) : response;
+ if (decoded['status'] == "success") {
+ List newItems = decoded['message'] ?? [];
+ if (refresh) {
+ pendingDrivers.assignAll(newItems);
+ } else {
+ pendingDrivers.addAll(newItems);
+ }
+ _offset += newItems.length;
+ if (newItems.length < _limit) {
+ hasMore.value = false;
+ }
+ }
+ }
+ } catch (e) {
+ Get.snackbar("خطأ", "فشل جلب السائقين: $e");
+ } finally {
+ isLoading.value = false;
+ isMoreLoading.value = false;
+ }
+ }
+
+ Future loadMore() async {
+ await getPendingDrivers(refresh: false);
+ }
+
+ Future