Update: 2026-06-14 04:27:17

This commit is contained in:
Hamza-Ayed
2026-06-14 04:27:17 +03:00
parent 55970712cc
commit 2645ed0cf1
9 changed files with 1394 additions and 48 deletions

View File

@@ -490,8 +490,8 @@ https://siromove.com/invite.php?code=$couponCode&app=rider
"inviterDriverPhone": formattedPhoneNumber,
});
if (response != 'failure') {
var d = (response);
if (response != 'failure' && response is Map) {
var d = response;
mySnackbarSuccess('Invite sent successfully'.tr);
String inviteCode = d['message']['inviteCode'].toString();
String message = '${'*Siro DRIVER CODE*'.tr}\n\n'
@@ -499,9 +499,10 @@ https://siromove.com/invite.php?code=$couponCode&app=rider
'${"To get a gift for both".tr}\n\n'
'${"The period of this code is 24 hours".tr}\n\n'
'${'before'.tr} *${d['message']['expirationTime'].toString()}*\n\n'
'_*${inviteCode}*_\n\n'
'${"Code:".tr} *${inviteCode}*\n\n'
'${"Quick Invite Link:".tr}\n'
'${AppLink.inviteRedirectUrl}?code=$inviteCode&app=driver';
'${AppLink.inviteRedirectUrl}?code=$inviteCode&app=driver\n\n'
'${"💡 Note: If the link above is not clickable, please save this contact or reply to this message to activate all links.".tr}';
launchCommunication('whatsapp', formattedPhoneNumber, message);
invitePhoneController.clear();
@@ -533,7 +534,7 @@ https://siromove.com/invite.php?code=$couponCode&app=rider
},
);
if (response != 'failure') {
if (response != 'failure' && response is Map) {
var d = response;
mySnackbarSuccess('Invite sent successfully'.tr);
String inviteCode = d['message']['inviteCode'].toString();
@@ -543,9 +544,10 @@ https://siromove.com/invite.php?code=$couponCode&app=rider
'${"To get a gift for both".tr}\n\n'
'${"The period of this code is 24 hours".tr}\n\n'
'${'before'.tr} *${d['message']['expirationTime'].toString()}*\n\n'
'_*${inviteCode}*_\n\n'
'${"Code:".tr} *${inviteCode}*\n\n'
'${"Quick Invite Link:".tr}\n'
'${AppLink.inviteRedirectUrl}?code=$inviteCode&app=rider';
'${AppLink.inviteRedirectUrl}?code=$inviteCode&app=rider\n\n'
'${"💡 Note: If the link above is not clickable, please save this contact or reply to this message to activate all links.".tr}';
launchCommunication('whatsapp', formattedPhoneNumber, message);
invitePhoneController.clear();

View File

@@ -5,6 +5,8 @@ import 'package:siro_driver/constant/links.dart';
import 'package:siro_driver/controller/functions/crud.dart';
import 'package:siro_driver/views/widgets/error_snakbar.dart';
import '../../views/widgets/mycircular.dart';
class InvitesRewardsController extends GetxController {
bool isLoading = false;
String? referralCode;
@@ -23,7 +25,7 @@ class InvitesRewardsController extends GetxController {
update();
var res = await CRUD().get(link: AppLink.getDriverReferrals);
if (res != 'failure' && res != 'token_expired' && res != 'no_internet') {
try {
var jsonData = jsonDecode(res);
@@ -44,8 +46,9 @@ class InvitesRewardsController extends GetxController {
}
Future<void> claimReward(int referralId, String claimType) async {
Get.dialog(const Center(child: CircularProgressIndicator()), barrierDismissible: false);
Get.dialog(const Center(child: CircularProgressIndicator()),
barrierDismissible: false);
var res = await CRUD().post(
link: AppLink.claimDriverReward,
payload: {
@@ -76,28 +79,58 @@ class InvitesRewardsController extends GetxController {
Future<void> claimUnifiedReward(int referralId) async {
// Show dialog to choose wallet or cash
Get.defaultDialog(
title: "Choose Claim Method".tr,
content: Text("How would you like to receive your reward?".tr),
actions: [
ElevatedButton(
onPressed: () {
Get.back();
claimReward(referralId, 'wallet');
},
child: Text("Wallet".tr),
),
ElevatedButton(
onPressed: () {
Get.back();
claimReward(referralId, 'cash');
},
child: Text("Cash".tr),
),
TextButton(
onPressed: () => Get.back(),
child: Text("Cancel".tr, style: TextStyle(color: Colors.red)),
)
]
);
title: "Choose Claim Method".tr,
content: Text("How would you like to receive your reward?".tr),
actions: [
ElevatedButton(
onPressed: () {
Get.back();
claimReward(referralId, 'wallet');
},
child: Text("Wallet".tr),
),
ElevatedButton(
onPressed: () {
Get.back();
claimReward(referralId, 'cash');
},
child: Text("Cash".tr),
),
TextButton(
onPressed: () => Get.back(),
child: Text("Cancel".tr, style: TextStyle(color: Colors.red)),
)
]);
}
Future<void> linkInviteCode(String inviteCode) async {
Get.dialog(const Center(child: MyCircularProgressIndicator()),
barrierDismissible: false);
try {
var response =
await CRUD().post(link: AppLink.addUnifiedInvite, payload: {
"inviter_code": inviteCode,
});
Get.back(); // close loading
if (response != 'failure') {
var data = response is String ? jsonDecode(response) : response;
if (data['status'] == 'success') {
Get.snackbar("Success".tr, "You have been successfully referred!".tr,
backgroundColor: Colors.green, colorText: Colors.white);
await getReferralStats(); // Refresh stats
} else {
Get.snackbar(
"Notice".tr, data['message'] ?? "Could not add invite".tr);
}
} else {
Get.snackbar("Error".tr, "Network error occurred".tr);
}
} catch (e) {
Get.back(); // close loading
Get.snackbar("Error".tr, "Network error occurred".tr);
}
}
}