Compare commits

..

No commits in common. "fbedb63e3adec0f722ad8e627b11224af0033f1b" and "dfaa4de44b89fc1f3ebef7da51a06130ef71320b" have entirely different histories.

32 changed files with 614 additions and 638 deletions

View File

@ -49,6 +49,7 @@ import 'package:yimaru_app/services/vimeo_service.dart';
import 'package:yimaru_app/services/url_launcher_service.dart'; import 'package:yimaru_app/services/url_launcher_service.dart';
import 'package:yimaru_app/services/phone_caller_service.dart'; import 'package:yimaru_app/services/phone_caller_service.dart';
import 'package:yimaru_app/ui/views/learn_subscription/learn_subscription_view.dart'; import 'package:yimaru_app/ui/views/learn_subscription/learn_subscription_view.dart';
import 'package:yimaru_app/ui/views/arif_pay/arif_pay_view.dart';
import 'package:yimaru_app/services/learn_service.dart'; import 'package:yimaru_app/services/learn_service.dart';
import 'package:yimaru_app/ui/views/course_catalog/course_catalog_view.dart'; import 'package:yimaru_app/ui/views/course_catalog/course_catalog_view.dart';
import 'package:yimaru_app/ui/views/course_unit/course_unit_view.dart'; import 'package:yimaru_app/ui/views/course_unit/course_unit_view.dart';
@ -57,7 +58,6 @@ import 'package:yimaru_app/ui/views/landing/landing_view.dart';
import 'package:yimaru_app/ui/views/course_module/course_module_view.dart'; import 'package:yimaru_app/ui/views/course_module/course_module_view.dart';
import 'package:yimaru_app/services/onboarding_service.dart'; import 'package:yimaru_app/services/onboarding_service.dart';
import 'package:yimaru_app/ui/views/learn_course/learn_course_view.dart'; import 'package:yimaru_app/ui/views/learn_course/learn_course_view.dart';
import 'package:yimaru_app/ui/views/payment/payment_view.dart';
// @stacked-import // @stacked-import
@StackedApp( @StackedApp(
@ -91,12 +91,12 @@ import 'package:yimaru_app/ui/views/payment/payment_view.dart';
MaterialRoute(page: LearnProgramView), MaterialRoute(page: LearnProgramView),
MaterialRoute(page: AssessmentView), MaterialRoute(page: AssessmentView),
MaterialRoute(page: LearnSubscriptionView), MaterialRoute(page: LearnSubscriptionView),
MaterialRoute(page: ArifPayView),
MaterialRoute(page: CourseCatalogView), MaterialRoute(page: CourseCatalogView),
MaterialRoute(page: CourseUnitView), MaterialRoute(page: CourseUnitView),
MaterialRoute(page: LandingView), MaterialRoute(page: LandingView),
MaterialRoute(page: CourseModuleView), MaterialRoute(page: CourseModuleView),
MaterialRoute(page: LearnCourseView), MaterialRoute(page: LearnCourseView),
MaterialRoute(page: PaymentView),
// @stacked-route // @stacked-route
], ],
dependencies: [ dependencies: [

View File

@ -9,7 +9,7 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/material.dart' as _i37; import 'package:flutter/material.dart' as _i37;
import 'package:stacked/stacked.dart' as _i1; import 'package:stacked/stacked.dart' as _i1;
import 'package:stacked_services/stacked_services.dart' as _i47; import 'package:stacked_services/stacked_services.dart' as _i46;
import 'package:yimaru_app/models/course.dart' as _i42; import 'package:yimaru_app/models/course.dart' as _i42;
import 'package:yimaru_app/models/course_catalog.dart' as _i44; import 'package:yimaru_app/models/course_catalog.dart' as _i44;
import 'package:yimaru_app/models/course_lesson.dart' as _i43; import 'package:yimaru_app/models/course_lesson.dart' as _i43;
@ -17,33 +17,33 @@ import 'package:yimaru_app/models/course_module.dart' as _i45;
import 'package:yimaru_app/models/learn_course.dart' as _i38; import 'package:yimaru_app/models/learn_course.dart' as _i38;
import 'package:yimaru_app/models/learn_lesson.dart' as _i40; import 'package:yimaru_app/models/learn_lesson.dart' as _i40;
import 'package:yimaru_app/models/learn_module.dart' as _i39; import 'package:yimaru_app/models/learn_module.dart' as _i39;
import 'package:yimaru_app/models/learn_subscription.dart' as _i46;
import 'package:yimaru_app/ui/common/enmus.dart' as _i41; import 'package:yimaru_app/ui/common/enmus.dart' as _i41;
import 'package:yimaru_app/ui/views/account_privacy/account_privacy_view.dart' import 'package:yimaru_app/ui/views/account_privacy/account_privacy_view.dart'
as _i9; as _i9;
import 'package:yimaru_app/ui/views/arif_pay/arif_pay_view.dart' as _i31;
import 'package:yimaru_app/ui/views/assessment/assessment_view.dart' as _i29; import 'package:yimaru_app/ui/views/assessment/assessment_view.dart' as _i29;
import 'package:yimaru_app/ui/views/call_support/call_support_view.dart' import 'package:yimaru_app/ui/views/call_support/call_support_view.dart'
as _i12; as _i12;
import 'package:yimaru_app/ui/views/course/course_view.dart' as _i27; import 'package:yimaru_app/ui/views/course/course_view.dart' as _i27;
import 'package:yimaru_app/ui/views/course_catalog/course_catalog_view.dart' import 'package:yimaru_app/ui/views/course_catalog/course_catalog_view.dart'
as _i31; as _i32;
import 'package:yimaru_app/ui/views/course_lesson_detail/course_lesson_detail_view.dart' import 'package:yimaru_app/ui/views/course_lesson_detail/course_lesson_detail_view.dart'
as _i25; as _i25;
import 'package:yimaru_app/ui/views/course_module/course_module_view.dart' import 'package:yimaru_app/ui/views/course_module/course_module_view.dart'
as _i34; as _i35;
import 'package:yimaru_app/ui/views/course_payment/course_payment_view.dart' import 'package:yimaru_app/ui/views/course_payment/course_payment_view.dart'
as _i23; as _i23;
import 'package:yimaru_app/ui/views/course_unit/course_unit_view.dart' as _i32; import 'package:yimaru_app/ui/views/course_unit/course_unit_view.dart' as _i33;
import 'package:yimaru_app/ui/views/downloads/downloads_view.dart' as _i7; import 'package:yimaru_app/ui/views/downloads/downloads_view.dart' as _i7;
import 'package:yimaru_app/ui/views/duolingo/duolingo_view.dart' as _i26; import 'package:yimaru_app/ui/views/duolingo/duolingo_view.dart' as _i26;
import 'package:yimaru_app/ui/views/failure/failure_view.dart' as _i24; import 'package:yimaru_app/ui/views/failure/failure_view.dart' as _i24;
import 'package:yimaru_app/ui/views/forget_password/forget_password_view.dart' import 'package:yimaru_app/ui/views/forget_password/forget_password_view.dart'
as _i20; as _i20;
import 'package:yimaru_app/ui/views/home/home_view.dart' as _i2; import 'package:yimaru_app/ui/views/home/home_view.dart' as _i2;
import 'package:yimaru_app/ui/views/landing/landing_view.dart' as _i33; import 'package:yimaru_app/ui/views/landing/landing_view.dart' as _i34;
import 'package:yimaru_app/ui/views/language/language_view.dart' as _i13; import 'package:yimaru_app/ui/views/language/language_view.dart' as _i13;
import 'package:yimaru_app/ui/views/learn_course/learn_course_view.dart' import 'package:yimaru_app/ui/views/learn_course/learn_course_view.dart'
as _i35; as _i36;
import 'package:yimaru_app/ui/views/learn_lesson/learn_lesson_view.dart' import 'package:yimaru_app/ui/views/learn_lesson/learn_lesson_view.dart'
as _i19; as _i19;
import 'package:yimaru_app/ui/views/learn_lesson_detail/learn_lesson_detail_view.dart' import 'package:yimaru_app/ui/views/learn_lesson_detail/learn_lesson_detail_view.dart'
@ -58,7 +58,6 @@ import 'package:yimaru_app/ui/views/learn_subscription/learn_subscription_view.d
as _i30; as _i30;
import 'package:yimaru_app/ui/views/login/login_view.dart' as _i17; import 'package:yimaru_app/ui/views/login/login_view.dart' as _i17;
import 'package:yimaru_app/ui/views/onboarding/onboarding_view.dart' as _i3; import 'package:yimaru_app/ui/views/onboarding/onboarding_view.dart' as _i3;
import 'package:yimaru_app/ui/views/payment/payment_view.dart' as _i36;
import 'package:yimaru_app/ui/views/privacy_policy/privacy_policy_view.dart' import 'package:yimaru_app/ui/views/privacy_policy/privacy_policy_view.dart'
as _i14; as _i14;
import 'package:yimaru_app/ui/views/profile/profile_view.dart' as _i5; import 'package:yimaru_app/ui/views/profile/profile_view.dart' as _i5;
@ -132,6 +131,8 @@ class Routes {
static const learnSubscriptionView = '/learn-subscription-view'; static const learnSubscriptionView = '/learn-subscription-view';
static const arifPayView = '/arif-pay-view';
static const courseCatalogView = '/course-catalog-view'; static const courseCatalogView = '/course-catalog-view';
static const courseUnitView = '/course-unit-view'; static const courseUnitView = '/course-unit-view';
@ -142,8 +143,6 @@ class Routes {
static const learnCourseView = '/learn-course-view'; static const learnCourseView = '/learn-course-view';
static const paymentView = '/payment-view';
static const all = <String>{ static const all = <String>{
homeView, homeView,
onboardingView, onboardingView,
@ -174,12 +173,12 @@ class Routes {
learnProgramView, learnProgramView,
assessmentView, assessmentView,
learnSubscriptionView, learnSubscriptionView,
arifPayView,
courseCatalogView, courseCatalogView,
courseUnitView, courseUnitView,
landingView, landingView,
courseModuleView, courseModuleView,
learnCourseView, learnCourseView,
paymentView,
}; };
} }
@ -301,29 +300,29 @@ class StackedRouter extends _i1.RouterBase {
Routes.learnSubscriptionView, Routes.learnSubscriptionView,
page: _i30.LearnSubscriptionView, page: _i30.LearnSubscriptionView,
), ),
_i1.RouteDef(
Routes.arifPayView,
page: _i31.ArifPayView,
),
_i1.RouteDef( _i1.RouteDef(
Routes.courseCatalogView, Routes.courseCatalogView,
page: _i31.CourseCatalogView, page: _i32.CourseCatalogView,
), ),
_i1.RouteDef( _i1.RouteDef(
Routes.courseUnitView, Routes.courseUnitView,
page: _i32.CourseUnitView, page: _i33.CourseUnitView,
), ),
_i1.RouteDef( _i1.RouteDef(
Routes.landingView, Routes.landingView,
page: _i33.LandingView, page: _i34.LandingView,
), ),
_i1.RouteDef( _i1.RouteDef(
Routes.courseModuleView, Routes.courseModuleView,
page: _i34.CourseModuleView, page: _i35.CourseModuleView,
), ),
_i1.RouteDef( _i1.RouteDef(
Routes.learnCourseView, Routes.learnCourseView,
page: _i35.LearnCourseView, page: _i36.LearnCourseView,
),
_i1.RouteDef(
Routes.paymentView,
page: _i36.PaymentView,
), ),
]; ];
@ -591,52 +590,52 @@ class StackedRouter extends _i1.RouterBase {
settings: data, settings: data,
); );
}, },
_i31.CourseCatalogView: (data) { _i31.ArifPayView: (data) {
final args = data.getArgs<ArifPayViewArguments>(nullOk: false);
return _i37.MaterialPageRoute<dynamic>(
builder: (context) =>
_i31.ArifPayView(key: args.key, phone: args.phone),
settings: data,
);
},
_i32.CourseCatalogView: (data) {
final args = data.getArgs<CourseCatalogViewArguments>( final args = data.getArgs<CourseCatalogViewArguments>(
orElse: () => const CourseCatalogViewArguments(), orElse: () => const CourseCatalogViewArguments(),
); );
return _i37.MaterialPageRoute<dynamic>( return _i37.MaterialPageRoute<dynamic>(
builder: (context) => _i31.CourseCatalogView(key: args.key), builder: (context) => _i32.CourseCatalogView(key: args.key),
settings: data, settings: data,
); );
}, },
_i32.CourseUnitView: (data) { _i33.CourseUnitView: (data) {
final args = data.getArgs<CourseUnitViewArguments>(nullOk: false); final args = data.getArgs<CourseUnitViewArguments>(nullOk: false);
return _i37.MaterialPageRoute<dynamic>( return _i37.MaterialPageRoute<dynamic>(
builder: (context) => builder: (context) =>
_i32.CourseUnitView(key: args.key, catalog: args.catalog), _i33.CourseUnitView(key: args.key, catalog: args.catalog),
settings: data, settings: data,
); );
}, },
_i33.LandingView: (data) { _i34.LandingView: (data) {
final args = data.getArgs<LandingViewArguments>( final args = data.getArgs<LandingViewArguments>(
orElse: () => const LandingViewArguments(), orElse: () => const LandingViewArguments(),
); );
return _i37.MaterialPageRoute<dynamic>( return _i37.MaterialPageRoute<dynamic>(
builder: (context) => _i33.LandingView(key: args.key), builder: (context) => _i34.LandingView(key: args.key),
settings: data, settings: data,
); );
}, },
_i34.CourseModuleView: (data) { _i35.CourseModuleView: (data) {
final args = data.getArgs<CourseModuleViewArguments>(nullOk: false); final args = data.getArgs<CourseModuleViewArguments>(nullOk: false);
return _i37.MaterialPageRoute<dynamic>( return _i37.MaterialPageRoute<dynamic>(
builder: (context) => _i34.CourseModuleView( builder: (context) => _i35.CourseModuleView(
key: args.key, module: args.module, catalog: args.catalog), key: args.key, module: args.module, catalog: args.catalog),
settings: data, settings: data,
); );
}, },
_i35.LearnCourseView: (data) { _i36.LearnCourseView: (data) {
final args = data.getArgs<LearnCourseViewArguments>(nullOk: false); final args = data.getArgs<LearnCourseViewArguments>(nullOk: false);
return _i37.MaterialPageRoute<dynamic>( return _i37.MaterialPageRoute<dynamic>(
builder: (context) => _i35.LearnCourseView(key: args.key, id: args.id), builder: (context) => _i36.LearnCourseView(key: args.key, id: args.id),
settings: data,
);
},
_i36.PaymentView: (data) {
final args = data.getArgs<PaymentViewArguments>(nullOk: false);
return _i37.MaterialPageRoute<dynamic>(
builder: (context) => _i36.PaymentView(
key: args.key, phone: args.phone, subscription: args.subscription),
settings: data, settings: data,
); );
}, },
@ -1379,6 +1378,33 @@ class LearnSubscriptionViewArguments {
} }
} }
class ArifPayViewArguments {
const ArifPayViewArguments({
this.key,
required this.phone,
});
final _i37.Key? key;
final String phone;
@override
String toString() {
return '{"key": "$key", "phone": "$phone"}';
}
@override
bool operator ==(covariant ArifPayViewArguments other) {
if (identical(this, other)) return true;
return other.key == key && other.phone == phone;
}
@override
int get hashCode {
return key.hashCode ^ phone.hashCode;
}
}
class CourseCatalogViewArguments { class CourseCatalogViewArguments {
const CourseCatalogViewArguments({this.key}); const CourseCatalogViewArguments({this.key});
@ -1509,39 +1535,7 @@ class LearnCourseViewArguments {
} }
} }
class PaymentViewArguments { extension NavigatorStateExtension on _i46.NavigationService {
const PaymentViewArguments({
this.key,
required this.phone,
required this.subscription,
});
final _i37.Key? key;
final String phone;
final _i46.LearnSubscription subscription;
@override
String toString() {
return '{"key": "$key", "phone": "$phone", "subscription": "$subscription"}';
}
@override
bool operator ==(covariant PaymentViewArguments other) {
if (identical(this, other)) return true;
return other.key == key &&
other.phone == phone &&
other.subscription == subscription;
}
@override
int get hashCode {
return key.hashCode ^ phone.hashCode ^ subscription.hashCode;
}
}
extension NavigatorStateExtension on _i47.NavigationService {
Future<dynamic> navigateToHomeView({ Future<dynamic> navigateToHomeView({
_i37.Key? key, _i37.Key? key,
int? routerId, int? routerId,
@ -2036,6 +2030,23 @@ extension NavigatorStateExtension on _i47.NavigationService {
transition: transition); transition: transition);
} }
Future<dynamic> navigateToArifPayView({
_i37.Key? key,
required String phone,
int? routerId,
bool preventDuplicates = true,
Map<String, String>? parameters,
Widget Function(BuildContext, Animation<double>, Animation<double>, Widget)?
transition,
}) async {
return navigateTo<dynamic>(Routes.arifPayView,
arguments: ArifPayViewArguments(key: key, phone: phone),
id: routerId,
preventDuplicates: preventDuplicates,
parameters: parameters,
transition: transition);
}
Future<dynamic> navigateToCourseCatalogView({ Future<dynamic> navigateToCourseCatalogView({
_i37.Key? key, _i37.Key? key,
int? routerId, int? routerId,
@ -2121,25 +2132,6 @@ extension NavigatorStateExtension on _i47.NavigationService {
transition: transition); transition: transition);
} }
Future<dynamic> navigateToPaymentView({
_i37.Key? key,
required String phone,
required _i46.LearnSubscription subscription,
int? routerId,
bool preventDuplicates = true,
Map<String, String>? parameters,
Widget Function(BuildContext, Animation<double>, Animation<double>, Widget)?
transition,
}) async {
return navigateTo<dynamic>(Routes.paymentView,
arguments: PaymentViewArguments(
key: key, phone: phone, subscription: subscription),
id: routerId,
preventDuplicates: preventDuplicates,
parameters: parameters,
transition: transition);
}
Future<dynamic> replaceWithHomeView({ Future<dynamic> replaceWithHomeView({
_i37.Key? key, _i37.Key? key,
int? routerId, int? routerId,
@ -2634,6 +2626,23 @@ extension NavigatorStateExtension on _i47.NavigationService {
transition: transition); transition: transition);
} }
Future<dynamic> replaceWithArifPayView({
_i37.Key? key,
required String phone,
int? routerId,
bool preventDuplicates = true,
Map<String, String>? parameters,
Widget Function(BuildContext, Animation<double>, Animation<double>, Widget)?
transition,
}) async {
return replaceWith<dynamic>(Routes.arifPayView,
arguments: ArifPayViewArguments(key: key, phone: phone),
id: routerId,
preventDuplicates: preventDuplicates,
parameters: parameters,
transition: transition);
}
Future<dynamic> replaceWithCourseCatalogView({ Future<dynamic> replaceWithCourseCatalogView({
_i37.Key? key, _i37.Key? key,
int? routerId, int? routerId,
@ -2718,23 +2727,4 @@ extension NavigatorStateExtension on _i47.NavigationService {
parameters: parameters, parameters: parameters,
transition: transition); transition: transition);
} }
Future<dynamic> replaceWithPaymentView({
_i37.Key? key,
required String phone,
required _i46.LearnSubscription subscription,
int? routerId,
bool preventDuplicates = true,
Map<String, String>? parameters,
Widget Function(BuildContext, Animation<double>, Animation<double>, Widget)?
transition,
}) async {
return replaceWith<dynamic>(Routes.paymentView,
arguments: PaymentViewArguments(
key: key, phone: phone, subscription: subscription),
id: routerId,
preventDuplicates: preventDuplicates,
parameters: parameters,
transition: transition);
}
} }

View File

@ -122,7 +122,7 @@ String kTelegramSupport = '@yimaruacademy2026';
String kTelegramSupportLink = 'https://t.me/yimaruacademy2026'; String kTelegramSupportLink = 'https://t.me/yimaruacademy2026';
String kErrorUrl = 'https://yimaru.net/api/v1/payments/chapa/error'; String kErrorUrl = 'https://yimaru.net/api/v1/payments/arifpay/error';
String kSuccessUrl = String kSuccessUrl =
'https://api.yimaruacademy.com/api/v1/payments/chapa/success'; 'https://api.yimaruacademy.com/api/v1/payments/arifpay/success';

View File

@ -25,9 +25,11 @@ enum ProgressStatuses { pending, started, completed }
// Duolingo types // Duolingo types
enum DuolingoAssessments { speaking, reading, writing, listening } enum DuolingoAssessments { speaking, reading, writing, listening }
// Practice reason // Practice reason
enum PracticeReason { course, module, lesson, previousModule, previousCourse } enum PracticeReason { course, module, lesson, previousModule, previousCourse }
// State object // State object
enum StateObjects { enum StateObjects {
none, none,

View File

@ -38,8 +38,7 @@ class CodegenLoader extends AssetLoader {
"confirm_password": "የይለፍ ቃል ያረጋግጡ", "confirm_password": "የይለፍ ቃል ያረጋግጡ",
"eight_character_minimum": "ቢያንስ 8 ፊደላት", "eight_character_minimum": "ቢያንስ 8 ፊደላት",
"password_match": "የይለፍ ቃሉ ተመሳስሏል", "password_match": "የይለፍ ቃሉ ተመሳስሏል",
"sign_up_agreement": "sign_up_agreement": "‘ይመዝገቡ’ የሚለውን ሲጫኑ በ‘አገልግሎት ውሎች’ እና ‘በግላዊነት ፖሊሲ’ ይስማማሉ።",
"‘ይመዝገቡ’ የሚለውን ሲጫኑ በ‘አገልግሎት ውሎች’ እና ‘በግላዊነት ፖሊሲ’ ይስማማሉ።",
"terms_of_services": "የአገልግሎት ውሎች", "terms_of_services": "የአገልግሎት ውሎች",
"and": "እና", "and": "እና",
"privacy_policy": "የግላዊነት ፖሊሲ", "privacy_policy": "የግላዊነት ፖሊሲ",
@ -138,8 +137,7 @@ class CodegenLoader extends AssetLoader {
"call_our_support": "ከ3 ጠዋት እስከ 12 ማታ ድረስ የድጋፍ ቡድናችንን ይደውሉ", "call_our_support": "ከ3 ጠዋት እስከ 12 ማታ ድረስ የድጋፍ ቡድናችንን ይደውሉ",
"tap_to_call": "ለመደወል ይንኩ", "tap_to_call": "ለመደወል ይንኩ",
"join_telegram": "በቴሌግራም የይማሩ አካዳሚን ይቀላቀሉ", "join_telegram": "በቴሌግራም የይማሩ አካዳሚን ይቀላቀሉ",
"connect_with_support_team": "connect_with_support_team": "ለፈጣን እርዳታ እና የማህበረሰብ ዝማኔዎች፣ በቴሌግራም ከድጋፍ ቡድናችን ጋር ወዲያውኑ ይገናኙ።",
"ለፈጣን እርዳታ እና የማህበረሰብ ዝማኔዎች፣ በቴሌግራም ከድጋፍ ቡድናችን ጋር ወዲያውኑ ይገናኙ።",
"open_in_telegram": "በቴሌግራም ይክፈቱ", "open_in_telegram": "በቴሌግራም ይክፈቱ",
"search_for": "ፈልጉት", "search_for": "ፈልጉት",
"current_level": "የአሁኑ ደረጃ", "current_level": "የአሁኑ ደረጃ",
@ -189,8 +187,7 @@ class CodegenLoader extends AssetLoader {
"evey_one_has_strugle": "ሁሉም ሰው ችግሮች አሉት፣ የአንተን እንጀምር እንፍታ", "evey_one_has_strugle": "ሁሉም ሰው ችግሮች አሉት፣ የአንተን እንጀምር እንፍታ",
"write_your_challenge": "ችግርህን ጻፍ…", "write_your_challenge": "ችግርህን ጻፍ…",
"topic_interest": "በጣም የሚስቡህ ርዕሶች የትኞቹ ናቸው?", "topic_interest": "በጣም የሚስቡህ ርዕሶች የትኞቹ ናቸው?",
"favourite_topic": "favourite_topic": "የምትወዳቸው ርዕሶች አስደሳች እና ከሕይወትህ ጋር የተዛመዱ ትምህርቶችን ለመፍጠር ይረዱናል።",
"የምትወዳቸው ርዕሶች አስደሳች እና ከሕይወትህ ጋር የተዛመዱ ትምህርቶችን ለመፍጠር ይረዱናል።",
"your_interest": "ፍላጎትህን ጻፍ…", "your_interest": "ፍላጎትህን ጻፍ…",
"want_quick_assessment": "የእንግሊዝኛ ደረጃህን ለማወቅ ፈጣን ግምገማ ትፈልጋለህ?", "want_quick_assessment": "የእንግሊዝኛ ደረጃህን ለማወቅ ፈጣን ግምገማ ትፈልጋለህ?",
"answer_quick_questions": "የእንግሊዝኛ ችሎታህን ለመረዳት ጥቂት ፈጣን ጥያቄዎችን መልስ።", "answer_quick_questions": "የእንግሊዝኛ ችሎታህን ለመረዳት ጥቂት ፈጣን ጥያቄዎችን መልስ።",
@ -205,8 +202,7 @@ class CodegenLoader extends AssetLoader {
"finish_all_practice_lesson": "ይህን ልምምድ ለመውሰድ የቀድሞውን የትምህርት ልምምድ ያጠናቅቁ", "finish_all_practice_lesson": "ይህን ልምምድ ለመውሰድ የቀድሞውን የትምህርት ልምምድ ያጠናቅቁ",
"finish_all_practice_module": "የሞጁሉን ልምምድ ለመውሰድ የትምህርት ልምምዶችን ያጠናቅቁ", "finish_all_practice_module": "የሞጁሉን ልምምድ ለመውሰድ የትምህርት ልምምዶችን ያጠናቅቁ",
"finish_all_practice_course": "የኮርሱን ልምምድ ለመውሰድ የሞጁል ልምምዶችን ያጠናቅቁ", "finish_all_practice_course": "የኮርሱን ልምምድ ለመውሰድ የሞጁል ልምምዶችን ያጠናቅቁ",
"finish_all_practice_previouse_module": "finish_all_practice_previouse_module": "ይህን ልምምድ ለመውሰድ የቀድሞውን የሞጁል ልምምድ ያጠናቅቁ",
"ይህን ልምምድ ለመውሰድ የቀድሞውን የሞጁል ልምምድ ያጠናቅቁ",
"finish_all_practice_previouse_course": "ይህን ለመውሰድ የቀድሞውን የኮርስ ልምምድ ያጠናቅቁ" "finish_all_practice_previouse_course": "ይህን ለመውሰድ የቀድሞውን የኮርስ ልምምድ ያጠናቅቁ"
}; };
static const Map<String,dynamic> _en = { static const Map<String,dynamic> _en = {
@ -227,15 +223,13 @@ class CodegenLoader extends AssetLoader {
"login": "Login", "login": "Login",
"register_with_google": "Register with Google", "register_with_google": "Register with Google",
"register_with_phone": "Register with phone number", "register_with_phone": "Register with phone number",
"enter_phone_number": "enter_phone_number": "Enter your phone number. We will send you a confirmation code there.",
"Enter your phone number. We will send you a confirmation code there.",
"login_with_email": "Login with email", "login_with_email": "Login with email",
"create_password": "Create password", "create_password": "Create password",
"confirm_password": "Confirm password", "confirm_password": "Confirm password",
"eight_character_minimum": "8 characters minimum", "eight_character_minimum": "8 characters minimum",
"password_match": "password match", "password_match": "password match",
"sign_up_agreement": "sign_up_agreement": "By clicking Sign Up, you agree to our Terms of Service and Privacy Policy",
"By clicking Sign Up, you agree to our Terms of Service and Privacy Policy",
"terms_of_services": "Terms of Service", "terms_of_services": "Terms of Service",
"and": "and", "and": "and",
"privacy_policy": "Privacy Policy", "privacy_policy": "Privacy Policy",
@ -246,8 +240,7 @@ class CodegenLoader extends AssetLoader {
"code_sent_to_email": "Code sent to your email", "code_sent_to_email": "Code sent to your email",
"resend_code_in": "Resend code in", "resend_code_in": "Resend code in",
"reset_password": "Reset Password", "reset_password": "Reset Password",
"enter_email_reset_code": "enter_email_reset_code": "Enter your email. We will send you a reset code.",
"Enter your email. We will send you a reset code.",
"please_wait": "Please wait", "please_wait": "Please wait",
"reset_code_sent": "Reset code sent successfully", "reset_code_sent": "Reset code sent successfully",
"reset_code": "Reset code", "reset_code": "Reset code",
@ -288,8 +281,7 @@ class CodegenLoader extends AssetLoader {
"cancel": "Cancel", "cancel": "Cancel",
"you_are_speaking": "You're speaking", "you_are_speaking": "You're speaking",
"practice_completed": "Practice completed!", "practice_completed": "Practice completed!",
"great_improvement": "great_improvement": "You sound more confident this time, great improvement",
"You sound more confident this time, great improvement",
"practice_again": "Practice again", "practice_again": "Practice again",
"conversation_review": "Conversation review", "conversation_review": "Conversation review",
"result": "Result", "result": "Result",
@ -336,8 +328,7 @@ class CodegenLoader extends AssetLoader {
"call_our_support": "Call our support team between 9 AM - 6 PM", "call_our_support": "Call our support team between 9 AM - 6 PM",
"tap_to_call": "Tap to call", "tap_to_call": "Tap to call",
"join_telegram": "Join Yimaru Academy on Telegram", "join_telegram": "Join Yimaru Academy on Telegram",
"connect_with_support_team": "connect_with_support_team": "Connect with our support team instantly on Telegram for quick assistance and community updates",
"Connect with our support team instantly on Telegram for quick assistance and community updates",
"open_in_telegram": "Open in Telegram", "open_in_telegram": "Open in Telegram",
"search_for": "Search for", "search_for": "Search for",
"current_level": "Current Level", "current_level": "Current Level",
@ -345,22 +336,18 @@ class CodegenLoader extends AssetLoader {
"no_practice_available": "No practice available!", "no_practice_available": "No practice available!",
"begin_module_practice": "Begin Module Practice", "begin_module_practice": "Begin Module Practice",
"lets_practice_lesson": "Lets Practice", "lets_practice_lesson": "Lets Practice",
"lets_quickly_review": "lets_quickly_review": "Lets quickly review what youve learned in this module!",
"Lets quickly review what youve learned in this module!",
"lets_practice_module": "Let's practice what you just learnt!", "lets_practice_module": "Let's practice what you just learnt!",
"ask_you_few_actions": "ask_you_few_actions": "Ill ask you a few questions, and you can respond naturally.",
"Ill ask you a few questions, and you can respond naturally.",
"begin_level_practice": "Begin Level Practice", "begin_level_practice": "Begin Level Practice",
"lets_practice_course": "Lets Practice Course", "lets_practice_course": "Lets Practice Course",
"lets_quick_review": "lets_quick_review": "Lets quickly review what youve learned in this level!",
"Lets quickly review what youve learned in this level!",
"speaking": "is speaking...", "speaking": "is speaking...",
"you_have_finished_practice": "You have finished your practice", "you_have_finished_practice": "You have finished your practice",
"view_results": "View My Results", "view_results": "View My Results",
"sample_answer": "Sample Answer", "sample_answer": "Sample Answer",
"your_answer": "Your Answer", "your_answer": "Your Answer",
"sound_confident": "sound_confident": "You sound more confident this time - great improvement!",
"You sound more confident this time - great improvement!",
"you_have_completed": "Yay, youve completed", "you_have_completed": "Yay, youve completed",
"yes": "Yes", "yes": "Yes",
"no": "No", "no": "No",
@ -371,20 +358,15 @@ class CodegenLoader extends AssetLoader {
"phone_must_start_with": "Phone number must start with 251", "phone_must_start_with": "Phone number must start with 251",
"phone_must_be": "Phone number must be 12 digits", "phone_must_be": "Phone number must be 12 digits",
"what_should_we_call_you": "What should we call you?", "what_should_we_call_you": "What should we call you?",
"name_for_personalization": "name_for_personalization": "Well use your name to personalize your learning journey.",
"Well use your name to personalize your learning journey.",
"choose_your_gender": "Choose your gender?", "choose_your_gender": "Choose your gender?",
"gender_for_personalization": "gender_for_personalization": "Well personalize your learning experience based on your gender.",
"Well personalize your learning experience based on your gender.",
"age_range": "Which age range are you in?", "age_range": "Which age range are you in?",
"age_for_personalization": "age_for_personalization": "Well personalize your learning experience based on your age.",
"Well personalize your learning experience based on your age.",
"educational_background": "Whats your current educational level?", "educational_background": "Whats your current educational level?",
"education_for_personalization": "education_for_personalization": "This helps us tailor your lessons to your experience.",
"This helps us tailor your lessons to your experience.",
"your_occupation": "Whats your occupation?", "your_occupation": "Whats your occupation?",
"occupation_for_personalization": "occupation_for_personalization": "Well personalize your learning experience based on your occupation.",
"Well personalize your learning experience based on your occupation.",
"location": "Where are you from?", "location": "Where are you from?",
"select_country_region": "Select your country and region from the dropdown", "select_country_region": "Select your country and region from the dropdown",
"select_country": "Select country", "select_country": "Select country",
@ -396,13 +378,10 @@ class CodegenLoader extends AssetLoader {
"evey_one_has_strugle": "Everyone has struggles, lets start fixing yours", "evey_one_has_strugle": "Everyone has struggles, lets start fixing yours",
"write_your_challenge": "Write your challenge…", "write_your_challenge": "Write your challenge…",
"topic_interest": "Which topics interest you most?", "topic_interest": "Which topics interest you most?",
"favourite_topic": "favourite_topic": "Your favorite topics help us create fun, relatable lessons.",
"Your favorite topics help us create fun, relatable lessons.",
"your_interest": "Write your interest…", "your_interest": "Write your interest…",
"want_quick_assessment": "want_quick_assessment": "Want a quick assessment to know your English level?",
"Want a quick assessment to know your English level?", "answer_quick_questions": "Answer a few quick questions to help us understand your English proficiency.",
"answer_quick_questions":
"Answer a few quick questions to help us understand your English proficiency.",
"skip": "Skip", "skip": "Skip",
"finish_level": "Finish Level", "finish_level": "Finish Level",
"likely_speaker": "Youre likely speaker of", "likely_speaker": "Youre likely speaker of",
@ -411,19 +390,11 @@ class CodegenLoader extends AssetLoader {
"welcome_abroad": "Welcome aboard", "welcome_abroad": "Welcome aboard",
"ready_to_explore": "Youre ready to explore your personalized lessons.", "ready_to_explore": "Youre ready to explore your personalized lessons.",
"finish": "Finish", "finish": "Finish",
"finish_all_practice_lesson": "finish_all_practice_lesson": "Finish the previous lesson practice to take this practice",
"Finish the previous lesson practice to take this practice", "finish_all_practice_module": "Finish the lesson practices to take the Module Practice",
"finish_all_practice_module": "finish_all_practice_course": "Finish the Module practices to take the Course practice",
"Finish the lesson practices to take the Module Practice", "finish_all_practice_previouse_module": "Finish the previous Module practice to take this practice",
"finish_all_practice_course": "finish_all_practice_previouse_course": "Finish the previous course practice to take this"
"Finish the Module practices to take the Course practice",
"finish_all_practice_previouse_module":
"Finish the previous Module practice to take this practice",
"finish_all_practice_previouse_course":
"Finish the previous course practice to take this"
};
static const Map<String, Map<String, dynamic>> mapLocales = {
"am": _am,
"en": _en
}; };
static const Map<String, Map<String,dynamic>> mapLocales = {"am": _am, "en": _en};
} }

View File

@ -161,8 +161,7 @@ abstract class LocaleKeys {
static const educational_background = 'educational_background'; static const educational_background = 'educational_background';
static const education_for_personalization = 'education_for_personalization'; static const education_for_personalization = 'education_for_personalization';
static const your_occupation = 'your_occupation'; static const your_occupation = 'your_occupation';
static const occupation_for_personalization = static const occupation_for_personalization = 'occupation_for_personalization';
'occupation_for_personalization';
static const location = 'location'; static const location = 'location';
static const select_country_region = 'select_country_region'; static const select_country_region = 'select_country_region';
static const select_country = 'select_country'; static const select_country = 'select_country';
@ -189,8 +188,7 @@ abstract class LocaleKeys {
static const finish_all_practice_lesson = 'finish_all_practice_lesson'; static const finish_all_practice_lesson = 'finish_all_practice_lesson';
static const finish_all_practice_module = 'finish_all_practice_module'; static const finish_all_practice_module = 'finish_all_practice_module';
static const finish_all_practice_course = 'finish_all_practice_course'; static const finish_all_practice_course = 'finish_all_practice_course';
static const finish_all_practice_previouse_module = static const finish_all_practice_previouse_module = 'finish_all_practice_previouse_module';
'finish_all_practice_previouse_module'; static const finish_all_practice_previouse_course = 'finish_all_practice_previouse_course';
static const finish_all_practice_previouse_course =
'finish_all_practice_previouse_course';
} }

View File

@ -1,61 +1,55 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_inappwebview/flutter_inappwebview.dart'; import 'package:flutter_inappwebview/flutter_inappwebview.dart';
import 'package:stacked/stacked.dart'; import 'package:stacked/stacked.dart';
import 'package:yimaru_app/ui/common/app_constants.dart';
import 'package:yimaru_app/ui/common/enmus.dart';
import 'package:yimaru_app/ui/common/ui_helpers.dart';
import 'package:yimaru_app/ui/widgets/page_loading_indicator.dart';
import '../../../models/learn_subscription.dart'; import 'arif_pay_viewmodel.dart';
import '../../common/app_constants.dart';
import '../../common/enmus.dart';
import '../../common/ui_helpers.dart';
import '../../widgets/page_loading_indicator.dart';
import 'payment_viewmodel.dart';
class PaymentView extends StackedView<PaymentViewModel> { class ArifPayView extends StackedView<ArifPayViewModel> {
final String phone; final String phone;
final LearnSubscription subscription;
const PaymentView({Key? key, required this.phone, required this.subscription}) const ArifPayView({Key? key, required this.phone}) : super(key: key);
: super(key: key);
void _error(PaymentViewModel viewModel) => viewModel.pop(); void _error(ArifPayViewModel viewModel) => viewModel.pop();
Future<void> _success(PaymentViewModel viewModel) async { Future<void> _success(ArifPayViewModel viewModel) async {
await viewModel.updatePaymentStatus(); await viewModel.updatePaymentStatus();
await viewModel.replaceWithHome(); await viewModel.replaceWithHome();
} }
@override @override
void onViewModelReady(PaymentViewModel viewModel) async { void onViewModelReady(ArifPayViewModel viewModel) async {
await viewModel.createLearnSubscriptionRequest(phone: phone,subscription: subscription); await viewModel.createLearnSubscriptionRequest(phone);
super.onViewModelReady(viewModel); super.onViewModelReady(viewModel);
} }
@override @override
PaymentViewModel viewModelBuilder( ArifPayViewModel viewModelBuilder(BuildContext context) => ArifPayViewModel();
BuildContext context,
) =>
PaymentViewModel();
@override @override
Widget builder( Widget builder(
BuildContext context, BuildContext context,
PaymentViewModel viewModel, ArifPayViewModel viewModel,
Widget? child, Widget? child,
) => ) =>
_buildScaffoldWrapper(viewModel); _buildScaffoldWrapper(viewModel);
Widget _buildScaffoldWrapper(PaymentViewModel viewModel) => Widget _buildScaffoldWrapper(ArifPayViewModel viewModel) =>
Scaffold(body: _buildScaffoldState(viewModel)); Scaffold(body: _buildScaffoldState(viewModel));
Widget _buildScaffoldState(PaymentViewModel viewModel) => Widget _buildScaffoldState(ArifPayViewModel viewModel) =>
viewModel.busy(StateObjects.learnSubscription) viewModel.busy(StateObjects.learnSubscription)
? const PageLoadingIndicator() ? const PageLoadingIndicator()
: _buildScaffold(viewModel); : _buildScaffold(viewModel);
Widget _buildScaffold(PaymentViewModel viewModel) => Widget _buildScaffold(ArifPayViewModel viewModel) =>
SafeArea(child: _buildBody(viewModel)); SafeArea(child: _buildBody(viewModel));
Widget _buildBody(PaymentViewModel viewModel) => InAppWebView( Widget _buildBody(ArifPayViewModel viewModel) => InAppWebView(
initialUrlRequest: initialUrlRequest:
URLRequest(url: WebUri(viewModel.request?.paymentUrl ?? '')), URLRequest(url: WebUri(viewModel.request?.paymentUrl ?? '')),
onUpdateVisitedHistory: (controller, url, androidIsReload) async { onUpdateVisitedHistory: (controller, url, androidIsReload) async {

View File

@ -1,17 +1,17 @@
import 'package:stacked/stacked.dart'; import 'package:stacked/stacked.dart';
import 'package:stacked_services/stacked_services.dart'; import 'package:stacked_services/stacked_services.dart';
import 'package:yimaru_app/ui/common/enmus.dart';
import '../../../app/app.locator.dart'; import '../../../app/app.locator.dart';
import '../../../app/app.router.dart'; import '../../../app/app.router.dart';
import '../../../models/learn_subscription.dart';
import '../../../models/learn_subscription_request.dart'; import '../../../models/learn_subscription_request.dart';
import '../../../models/user.dart'; import '../../../models/user.dart';
import '../../../services/api_service.dart'; import '../../../services/api_service.dart';
import '../../../services/authentication_service.dart'; import '../../../services/authentication_service.dart';
import '../../../services/status_checker_service.dart'; import '../../../services/status_checker_service.dart';
import '../../common/enmus.dart'; import '../../common/ui_helpers.dart';
class PaymentViewModel extends ReactiveViewModel { class ArifPayViewModel extends ReactiveViewModel {
// Dependency injection // Dependency injection
final _apiService = locator<ApiService>(); final _apiService = locator<ApiService>();
@ -30,7 +30,6 @@ class PaymentViewModel extends ReactiveViewModel {
User? get _user => _authenticationService.user; User? get _user => _authenticationService.user;
User? get user => _user; User? get user => _user;
// Learn subscription request // Learn subscription request
LearnSubscriptionRequest? _request; LearnSubscriptionRequest? _request;
@ -45,18 +44,18 @@ class PaymentViewModel extends ReactiveViewModel {
// Remote api call // Remote api call
// Learn subscription // Learn subscription
Future<void> createLearnSubscriptionRequest({required String phone,required LearnSubscription subscription}) async => Future<void> createLearnSubscriptionRequest(String phone) async =>
await runBusyFuture(_createLearnSubscriptionRequest(phone: phone,subscription: subscription), await runBusyFuture(_createLearnSubscriptionRequest(phone),
busyObject: StateObjects.learnSubscription); busyObject: StateObjects.learnSubscription);
Future<void> _createLearnSubscriptionRequest({required String phone,required LearnSubscription subscription}) async { Future<void> _createLearnSubscriptionRequest(String phone) async {
print('MY SUMMARIES : PAYMENT');
if (await _statusChecker.checkConnection()) { if (await _statusChecker.checkConnection()) {
Map<String, dynamic> data = { Map<String, dynamic> data = {
'plan_id': 1,
'provider': 'CHAPA', 'provider': 'CHAPA',
'phone': '251$phone', 'phone': '251$phone',
'email': 'test@gmail.com', 'email': 'test@gmail.com',
'plan_id': subscription.id,
}; };
Map<String, dynamic> response = Map<String, dynamic> response =

View File

@ -27,8 +27,10 @@ class AssessmentResultScreen extends ViewModelWidget<AssessmentViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(AssessmentViewModel viewModel) => List<Widget> _buildScaffoldChildren(AssessmentViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildAppBar(AssessmentViewModel viewModel) => LargeAppBar( Widget _buildAppBar(AssessmentViewModel viewModel) => LargeAppBar(
showBackButton: true, showBackButton: true,

View File

@ -44,8 +44,10 @@ class StartLessonScreen extends ViewModelWidget<AssessmentViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(AssessmentViewModel viewModel) => List<Widget> _buildScaffoldChildren(AssessmentViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildAppBar(AssessmentViewModel viewModel) => LargeAppBar( Widget _buildAppBar(AssessmentViewModel viewModel) => LargeAppBar(
showBackButton: true, showBackButton: true,

View File

@ -86,8 +86,10 @@ class ResetPasswordScreen extends ViewModelWidget<ForgetPasswordViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(ForgetPasswordViewModel viewModel) => List<Widget> _buildScaffoldChildren(ForgetPasswordViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildAppBar(ForgetPasswordViewModel viewModel) => LargeAppBar( Widget _buildAppBar(ForgetPasswordViewModel viewModel) => LargeAppBar(
showBackButton: true, showBackButton: true,

View File

@ -31,7 +31,8 @@ class LearnLessonView extends StackedView<LearnLessonViewModel> {
} else { } else {
await _showSheet(context: context, viewModel: viewModel); await _showSheet(context: context, viewModel: viewModel);
} }
/* if (index > 1) { /*
if (index > 1) {
if (viewModel.user?.subscriptionStatus?.toLowerCase() == 'subscribed') { if (viewModel.user?.subscriptionStatus?.toLowerCase() == 'subscribed') {
if (lesson.access?.isAccessible ?? false) { if (lesson.access?.isAccessible ?? false) {
await viewModel.navigateToLearnPractice(lesson.id ?? 0); await viewModel.navigateToLearnPractice(lesson.id ?? 0);
@ -251,6 +252,7 @@ class LearnLessonView extends StackedView<LearnLessonViewModel> {
LearnLessonTile( LearnLessonTile(
last: last, last: last,
index: index, index: index,
lesson: lesson, lesson: lesson,
onLessonTap: onLessonTap, onLessonTap: onLessonTap,
onPracticeTap: onPracticeTap, onPracticeTap: onPracticeTap,

View File

@ -59,15 +59,14 @@ class LearnLessonViewModel extends ReactiveViewModel {
await _navigationService.navigateToLearnSubscriptionView(); await _navigationService.navigateToLearnSubscriptionView();
Future<void> navigateToLearnLessonDetail( Future<void> navigateToLearnLessonDetail(
{required int index, {
required int index,
required bool hasPractice, required bool hasPractice,
required LearnLesson lesson, required LearnLesson lesson,
required LearnModule module}) async => required LearnModule module}) async =>
await _navigationService.navigateToLearnLessonDetailView( await _navigationService.navigateToLearnLessonDetailView(
index: index, index: index,
lesson: lesson, lesson: lesson, module: module, hasPractice: hasPractice);
module: module,
hasPractice: hasPractice);
// Remote api call // Remote api call

View File

@ -34,6 +34,7 @@ class LearnLessonDetailView extends StackedView<LearnLessonDetailViewModel> {
await viewModel.pause(); await viewModel.pause();
await viewModel.navigateToLearnPractice(lesson.id ?? 0); await viewModel.navigateToLearnPractice(lesson.id ?? 0);
/* if (index > 1) { /* if (index > 1) {
if (viewModel.user?.subscriptionStatus?.toLowerCase() == 'subscribed') { if (viewModel.user?.subscriptionStatus?.toLowerCase() == 'subscribed') {
await viewModel.pause(); await viewModel.pause();

View File

@ -31,10 +31,6 @@ class LearnSubscriptionViewModel extends FormViewModel {
int get selectedIndex => _selectedIndex; int get selectedIndex => _selectedIndex;
LearnSubscription? _selectedSubscription;
LearnSubscription? get selectedSubscription => _selectedSubscription;
List<LearnSubscription> _subscriptions = []; List<LearnSubscription> _subscriptions = [];
List<LearnSubscription> get subscriptions => _subscriptions; List<LearnSubscription> get subscriptions => _subscriptions;
@ -44,13 +40,6 @@ class LearnSubscriptionViewModel extends FormViewModel {
_focusPhoneNumber = true; _focusPhoneNumber = true;
rebuildUi(); rebuildUi();
} }
//Learn subscriptions
void setSelectedPricing(int index) {
_selectedIndex = index;
_selectedSubscription = _subscriptions[index];
rebuildUi();
}
// In-app navigation // In-app navigation
@ -71,11 +60,16 @@ class LearnSubscriptionViewModel extends FormViewModel {
// Navigation // Navigation
void pop() => _navigationService.back(); void pop() => _navigationService.back();
Future<void> navigateToArifPay( Future<void> navigateToArifPay(String phone) async {
{required String phone, required LearnSubscription? subscription}) async {
pop(); pop();
await _navigationService.navigateToPaymentView( await _navigationService.navigateToArifPayView(phone: phone);
phone: phone, subscription: subscription ?? _subscriptions[0]); }
//Learn subscriptions
void setSelectedPricing(int index) {
_selectedIndex = index;
rebuildUi();
} }
// Remote api call // Remote api call

View File

@ -178,9 +178,8 @@ class LearnSubscriptionFormScreen
? kcPrimaryColor ? kcPrimaryColor
: kcPrimaryColor.withOpacity(0.1), : kcPrimaryColor.withOpacity(0.1),
onTap: phoneNumberController.text.isNotEmpty onTap: phoneNumberController.text.isNotEmpty
? () async => await viewModel.navigateToArifPay( ? () async =>
phone: phoneNumberController.text, await viewModel.navigateToArifPay(phoneNumberController.text)
subscription: viewModel.selectedSubscription)
: null, : null,
); );

View File

@ -41,8 +41,10 @@ class AgeGroupFormScreen extends ViewModelWidget<OnboardingViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildExpandedBody(OnboardingViewModel viewModel) => Widget _buildExpandedBody(OnboardingViewModel viewModel) =>
Expanded(child: _buildColumnScroller(viewModel)); Expanded(child: _buildColumnScroller(viewModel));

View File

@ -42,8 +42,10 @@ class ChallengeFormScreen extends ViewModelWidget<OnboardingViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildExpandedBody(OnboardingViewModel viewModel) => Widget _buildExpandedBody(OnboardingViewModel viewModel) =>
Expanded(child: _buildBodyScroller(viewModel)); Expanded(child: _buildBodyScroller(viewModel));

View File

@ -58,8 +58,10 @@ class CountryRegionFormScreen extends ViewModelWidget<OnboardingViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildExpandedBody(OnboardingViewModel viewModel) => Widget _buildExpandedBody(OnboardingViewModel viewModel) =>
Expanded(child: _buildBodyWrapper(viewModel)); Expanded(child: _buildBodyWrapper(viewModel));

View File

@ -43,8 +43,10 @@ class EducationalBackgroundFormScreen
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildExpandedBody(OnboardingViewModel viewModel) => Widget _buildExpandedBody(OnboardingViewModel viewModel) =>
Expanded(child: _buildColumnScroller(viewModel)); Expanded(child: _buildColumnScroller(viewModel));

View File

@ -40,8 +40,10 @@ class FullNameFormScreen extends ViewModelWidget<OnboardingViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildExpandedBody(OnboardingViewModel viewModel) => Widget _buildExpandedBody(OnboardingViewModel viewModel) =>
Expanded(child: _buildBodyWrapper(viewModel)); Expanded(child: _buildBodyWrapper(viewModel));

View File

@ -40,8 +40,10 @@ class GenderFormScreen extends ViewModelWidget<OnboardingViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildExpandedBody(OnboardingViewModel viewModel) => Widget _buildExpandedBody(OnboardingViewModel viewModel) =>
Expanded(child: _buildBodyWrapper(viewModel)); Expanded(child: _buildBodyWrapper(viewModel));

View File

@ -25,6 +25,8 @@ class LanguageGoalFormScreens extends ViewModelWidget<OnboardingViewModel> {
return Icons.book; return Icons.book;
} }
String getSubtitle(int index) { String getSubtitle(int index) {
switch (index) { switch (index) {
case 0: case 0:
@ -47,6 +49,7 @@ class LanguageGoalFormScreens extends ViewModelWidget<OnboardingViewModel> {
Map<String, dynamic> data = { Map<String, dynamic> data = {
'language_goal': viewModel.selectedLanguageGoal?.code, 'language_goal': viewModel.selectedLanguageGoal?.code,
}; };
viewModel.addUserData(data); viewModel.addUserData(data);
@ -67,8 +70,10 @@ class LanguageGoalFormScreens extends ViewModelWidget<OnboardingViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildExpandedBody(OnboardingViewModel viewModel) => Widget _buildExpandedBody(OnboardingViewModel viewModel) =>
Expanded(child: _buildBodyScroller(viewModel)); Expanded(child: _buildBodyScroller(viewModel));

View File

@ -42,8 +42,10 @@ class LearningGoalFormScreen extends ViewModelWidget<OnboardingViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildExpandedBody(OnboardingViewModel viewModel) => Widget _buildExpandedBody(OnboardingViewModel viewModel) =>
Expanded(child: _buildBodyScroller(viewModel)); Expanded(child: _buildBodyScroller(viewModel));

View File

@ -43,8 +43,10 @@ class OccupationFormScreen extends ViewModelWidget<OnboardingViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildExpandedBody(OnboardingViewModel viewModel) => Widget _buildExpandedBody(OnboardingViewModel viewModel) =>
Expanded(child: _buildBodyWrapper(viewModel)); Expanded(child: _buildBodyWrapper(viewModel));

View File

@ -45,8 +45,10 @@ class TopicFormScreen extends ViewModelWidget<OnboardingViewModel> {
children: _buildScaffoldChildren(viewModel), children: _buildScaffoldChildren(viewModel),
); );
List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => List<Widget> _buildScaffoldChildren(OnboardingViewModel viewModel) => [
[_buildAppBar(viewModel), _buildExpandedBody(viewModel)]; _buildAppBar(viewModel),
_buildExpandedBody(viewModel)
];
Widget _buildAppBar(OnboardingViewModel viewModel) => LargeAppBar( Widget _buildAppBar(OnboardingViewModel viewModel) => LargeAppBar(
showBackButton: true, showBackButton: true,

View File

@ -26,8 +26,8 @@ class LearnCourseTile extends ViewModelWidget<LearnCourseViewModel> {
Widget build(BuildContext context, LearnCourseViewModel viewModel) => Widget build(BuildContext context, LearnCourseViewModel viewModel) =>
_buildExpansionTileCardWrapper(viewModel); _buildExpansionTileCardWrapper(viewModel);
Widget _buildExpansionTileCardWrapper(LearnCourseViewModel viewModel) =>
GestureDetector( Widget _buildExpansionTileCardWrapper(LearnCourseViewModel viewModel)=> GestureDetector(
onTap: !(course.access?.isAccessible ?? false) ? onPracticeTap:null, onTap: !(course.access?.isAccessible ?? false) ? onPracticeTap:null,
child: _buildExpansionTileCard(viewModel), child: _buildExpansionTileCard(viewModel),
); );

View File

@ -25,10 +25,8 @@ class LearnModuleTile extends ViewModelWidget<LearnModuleViewModel> {
Widget build(BuildContext context, LearnModuleViewModel viewModel) => Widget build(BuildContext context, LearnModuleViewModel viewModel) =>
_buildExpansionTileCardWrapper(context: context, viewModel: viewModel); _buildExpansionTileCardWrapper(context: context, viewModel: viewModel);
Widget _buildExpansionTileCardWrapper( Widget _buildExpansionTileCardWrapper( {required BuildContext context,
{required BuildContext context, required LearnModuleViewModel viewModel})=> GestureDetector(
required LearnModuleViewModel viewModel}) =>
GestureDetector(
onTap: !(module.access?.isAccessible ?? false) ? onPracticeTap:null, onTap: !(module.access?.isAccessible ?? false) ? onPracticeTap:null,
child: _buildExpansionTileCard(context: context,viewModel: viewModel), child: _buildExpansionTileCard(context: context,viewModel: viewModel),
); );

View File

@ -1,5 +1,5 @@
name: yimaru_app name: yimaru_app
version: 0.1.30+32 version: 0.1.29+31
publish_to: 'none' publish_to: 'none'
description: A new Flutter project. description: A new Flutter project.

View File

@ -4,7 +4,7 @@ import 'package:yimaru_app/app/app.locator.dart';
import '../helpers/test_helpers.dart'; import '../helpers/test_helpers.dart';
void main() { void main() {
group('PaymentViewModel Tests -', () { group('ArifPayViewModel Tests -', () {
setUp(() => registerServices()); setUp(() => registerServices());
tearDown(() => locator.reset()); tearDown(() => locator.reset());
}); });