|
|
|
@ -1,5 +1,6 @@
|
|
|
|
|
import 'dart:async';
|
|
|
|
|
import 'package:mc_common_app/models/provider_branches_models/branch_detail_model.dart';
|
|
|
|
|
import 'package:mc_common_app/utils/date_helper.dart';
|
|
|
|
|
import 'package:mc_common_app/utils/enums.dart';
|
|
|
|
|
import 'package:mc_common_app/view_models/appointments_view_model.dart';
|
|
|
|
|
import 'package:easy_localization/easy_localization.dart';
|
|
|
|
@ -36,15 +37,13 @@ class _ProviderProfileViewState extends State<ProviderProfileView> {
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
return Consumer(
|
|
|
|
|
builder: (BuildContext context, AppointmentsVM appointmentsVM, Widget? child) {
|
|
|
|
|
if (appointmentsVM.state == ViewState.busy) {
|
|
|
|
|
if (appointmentsVM.state == ViewState.busy || appointmentsVM.providerProfileModel == null) {
|
|
|
|
|
return Scaffold(
|
|
|
|
|
backgroundColor: MyColors.white,
|
|
|
|
|
appBar: CustomAppBar(
|
|
|
|
|
title: LocaleKeys.providerDetails.tr(),
|
|
|
|
|
),
|
|
|
|
|
body: Center(
|
|
|
|
|
child: CircularProgressIndicator(),
|
|
|
|
|
),
|
|
|
|
|
body: Center(child: CircularProgressIndicator()),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
return Scaffold(
|
|
|
|
@ -87,16 +86,19 @@ class _ProviderProfileViewState extends State<ProviderProfileView> {
|
|
|
|
|
Image.asset(MyAssets.bnCar),
|
|
|
|
|
12.height,
|
|
|
|
|
(appointmentsVM.providerProfileModel!.name ?? appointmentsVM.providerProfileModel!.companyName).toString().toText(
|
|
|
|
|
fontSize: 16,
|
|
|
|
|
isBold: true,
|
|
|
|
|
),
|
|
|
|
|
fontSize: 16,
|
|
|
|
|
isBold: true,
|
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
if (appointmentsVM.providerProfileModel!.memberSince!.isNotEmpty ) ...[
|
|
|
|
|
if (appointmentsVM.providerProfileModel!.memberSince!.isNotEmpty) ...[
|
|
|
|
|
Row(
|
|
|
|
|
children: [
|
|
|
|
|
("Member Since:").toText(color: MyColors.lightTextColor, fontSize: 12),
|
|
|
|
|
4.width,
|
|
|
|
|
"${appointmentsVM.providerProfileModel!.memberSince ?? ""}".toText(fontSize: 12, isBold: true),
|
|
|
|
|
"${DateHelper.formatAsMonthYear(DateHelper.parseStringToDate(DateHelper.formatDateT(appointmentsVM.providerProfileModel!.memberSince ?? "")))}".toText(
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
isBold: true,
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
@ -107,35 +109,35 @@ class _ProviderProfileViewState extends State<ProviderProfileView> {
|
|
|
|
|
12.height,
|
|
|
|
|
appointmentsVM.providerProfileModel!.serviceProviderBranch == null
|
|
|
|
|
? Center(
|
|
|
|
|
child: (LocaleKeys.noBranchFound.tr()).toText(
|
|
|
|
|
fontSize: 16,
|
|
|
|
|
color: MyColors.lightTextColor,
|
|
|
|
|
),
|
|
|
|
|
)
|
|
|
|
|
child: (LocaleKeys.noBranchFound.tr()).toText(
|
|
|
|
|
fontSize: 16,
|
|
|
|
|
color: MyColors.lightTextColor,
|
|
|
|
|
),
|
|
|
|
|
)
|
|
|
|
|
: appointmentsVM.providerProfileModel!.serviceProviderBranch!.isEmpty
|
|
|
|
|
? Center(child: Text(LocaleKeys.no_branch.tr()))
|
|
|
|
|
: ListView.separated(
|
|
|
|
|
itemBuilder: (context, index) {
|
|
|
|
|
BranchDetailModel branchModel = appointmentsVM.providerProfileModel!.serviceProviderBranch![index];
|
|
|
|
|
return BranchDetailCard(
|
|
|
|
|
onCardTapped: () {
|
|
|
|
|
navigateWithName(context, AppRoutes.branchDetailView, arguments: branchModel);
|
|
|
|
|
},
|
|
|
|
|
providerImageUrl: MyAssets.bnCar,
|
|
|
|
|
title: branchModel.branchName ?? "",
|
|
|
|
|
providerLocation: branchModel.distanceKm.toString() + " KM",
|
|
|
|
|
providerName: branchModel.serviceProviderName ?? "",
|
|
|
|
|
providerRatings: (branchModel.branchRateAvg ?? 0.0),
|
|
|
|
|
services: branchModel.branchServices,
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (context, index) {
|
|
|
|
|
return 12.height;
|
|
|
|
|
},
|
|
|
|
|
itemCount: appointmentsVM.providerProfileModel!.serviceProviderBranch!.length,
|
|
|
|
|
physics: NeverScrollableScrollPhysics(),
|
|
|
|
|
shrinkWrap: true,
|
|
|
|
|
)
|
|
|
|
|
? Center(child: Text(LocaleKeys.no_branch.tr()))
|
|
|
|
|
: ListView.separated(
|
|
|
|
|
itemBuilder: (context, index) {
|
|
|
|
|
BranchDetailModel branchModel = appointmentsVM.providerProfileModel!.serviceProviderBranch![index];
|
|
|
|
|
return BranchDetailCard(
|
|
|
|
|
onCardTapped: () {
|
|
|
|
|
navigateWithName(context, AppRoutes.branchDetailView, arguments: branchModel);
|
|
|
|
|
},
|
|
|
|
|
providerImageUrl: MyAssets.bnCar,
|
|
|
|
|
title: branchModel.branchName ?? "",
|
|
|
|
|
providerLocation: branchModel.distanceKm.toString() + " KM",
|
|
|
|
|
providerName: branchModel.serviceProviderName ?? "",
|
|
|
|
|
providerRatings: (branchModel.branchRateAvg ?? 0.0),
|
|
|
|
|
services: branchModel.branchServices,
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (context, index) {
|
|
|
|
|
return 12.height;
|
|
|
|
|
},
|
|
|
|
|
itemCount: appointmentsVM.providerProfileModel!.serviceProviderBranch!.length,
|
|
|
|
|
physics: NeverScrollableScrollPhysics(),
|
|
|
|
|
shrinkWrap: true,
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|