You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
169 lines
7.1 KiB
Dart
169 lines
7.1 KiB
Dart
import 'package:diplomaticquarterapp/core/viewModels/project_view_model.dart';
|
|
import 'package:diplomaticquarterapp/theme/colors.dart';
|
|
import 'package:diplomaticquarterapp/uitl/app_shared_preferences.dart';
|
|
import 'package:diplomaticquarterapp/uitl/translations_delegate_base.dart';
|
|
import 'package:diplomaticquarterapp/uitl/utils_new.dart';
|
|
import 'package:diplomaticquarterapp/widgets/avatar/large_avatar.dart';
|
|
import 'package:diplomaticquarterapp/widgets/my_rich_text.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_rating_bar/flutter_rating_bar.dart';
|
|
import 'package:flutter_svg/flutter_svg.dart';
|
|
import 'package:provider/provider.dart';
|
|
|
|
class TodoListCard extends StatefulWidget {
|
|
TodoListCard();
|
|
|
|
@override
|
|
_TodoListCardState createState() => _TodoListCardState();
|
|
}
|
|
|
|
class _TodoListCardState extends State<TodoListCard> {
|
|
AppSharedPreferences sharedPref = AppSharedPreferences();
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
ProjectViewModel projectViewModel = Provider.of(context);
|
|
return Container(
|
|
width: double.infinity,
|
|
margin: EdgeInsets.all(10.0),
|
|
decoration: cardRadius(12),
|
|
padding: EdgeInsets.all(16),
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
Row(
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
children: [
|
|
Row(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
Padding(
|
|
padding: const EdgeInsets.only(top: 4.0),
|
|
child: SvgPicture.asset("assets/images/new/virtual.svg"),
|
|
),
|
|
Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
Padding(
|
|
padding: const EdgeInsets.only(left: 8.0, right: 8.0),
|
|
child: Text(TranslationBase.of(context).videoAppo, style: TextStyle(fontSize: 12, fontWeight: FontWeight.w600, color: Color(0xff2B353E), letterSpacing: -0.48)),
|
|
),
|
|
Padding(
|
|
padding: const EdgeInsets.only(left: 8.0, right: 8.0),
|
|
child: Text("01:23:22 " + TranslationBase.of(context).upcomingTimeLeft, style: TextStyle(fontSize: 12, fontWeight: FontWeight.w600, color: CustomColors.primaryColor, letterSpacing: -0.48)),
|
|
),
|
|
],
|
|
),
|
|
],
|
|
),
|
|
Container(
|
|
child: InkWell(
|
|
onTap: () {
|
|
// showConfirmMessage(model, order);
|
|
},
|
|
child: Container(
|
|
padding: EdgeInsets.symmetric(vertical: 8, horizontal: 14),
|
|
decoration: BoxDecoration(
|
|
color: CustomColors.green,
|
|
border: Border.all(color: Colors.white, width: 1),
|
|
borderRadius: BorderRadius.circular(6),
|
|
),
|
|
child: Text(
|
|
TranslationBase.of(context).confirm,
|
|
style: TextStyle(fontSize: 12, fontWeight: FontWeight.w600, color: Colors.white, letterSpacing: -0.4),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
Padding(
|
|
padding: const EdgeInsets.only(top: 8.0),
|
|
child: Text(
|
|
"Raed Mubarak Bin Ghanem",
|
|
style: TextStyle(fontSize: 16, fontWeight: FontWeight.w600, color: Color(0xff2E303A), letterSpacing: -0.64, height: 25 / 16),
|
|
),
|
|
),
|
|
Row(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: <Widget>[
|
|
LargeAvatar(
|
|
name: "Raed Mubarak Bin Ghanem",
|
|
url: "https://hmgwebservices.com/Images/MobileImages/TAKHSUSI/158210.png",
|
|
width: 52,
|
|
height: 52,
|
|
),
|
|
SizedBox(width: 11),
|
|
Expanded(
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: <Widget>[
|
|
MyRichText(TranslationBase.of(context).clinic + ": ", "Cardiology", projectViewModel.isArabic),
|
|
MyRichText(TranslationBase.of(context).appointmentDate + ": ", "11/04/2021 15:30", projectViewModel.isArabic),
|
|
MyRichText(TranslationBase.of(context).branch, "Olaya Hospital", projectViewModel.isArabic),
|
|
Row(
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
mainAxisSize: MainAxisSize.max,
|
|
children: <Widget>[
|
|
RatingBar(
|
|
initialRating: 4.6,
|
|
direction: Axis.horizontal,
|
|
allowHalfRating: true,
|
|
itemCount: 5,
|
|
itemSize: 20,
|
|
ignoreGestures: true,
|
|
ratingWidget: RatingWidget(
|
|
full: Icon(Icons.star, color: CustomColors.primaryColor,),
|
|
half: Icon(Icons.star_half, color: CustomColors.primaryColor,),
|
|
empty: Icon(Icons.star, color: CustomColors.primaryColor,),
|
|
),
|
|
tapOnlyMode: true,
|
|
unratedColor: Colors.grey[500],
|
|
itemPadding: EdgeInsets.symmetric(horizontal: 4.0),
|
|
onRatingUpdate: (rating) {
|
|
print(rating);
|
|
},
|
|
)
|
|
// RatingBar.readOnly(
|
|
// initialRating: 4.5,
|
|
// size: 16.0,
|
|
// filledColor: Color(0XFFD02127),
|
|
// emptyColor: Color(0XFFD02127),
|
|
// isHalfAllowed: true,
|
|
// halfFilledIcon: Icons.star_half,
|
|
// filledIcon: Icons.star,
|
|
// emptyIcon: Icons.star_border,
|
|
// ),
|
|
],
|
|
),
|
|
],
|
|
),
|
|
),
|
|
],
|
|
),
|
|
Padding(
|
|
padding: const EdgeInsets.only(top: 12.0),
|
|
child: Text(
|
|
"Please confirm the appointment to avoid cancellation",
|
|
style: TextStyle(fontSize: 10, fontWeight: FontWeight.w600, color: Color(0xff2E303A), letterSpacing: -0.48, height: 25 / 16),
|
|
),
|
|
),
|
|
Padding(
|
|
padding: const EdgeInsets.only(top: 0.0),
|
|
child: Text(
|
|
"More Details",
|
|
style: TextStyle(fontSize: 10, fontWeight: FontWeight.w600, color: CustomColors.primaryColor, letterSpacing: -0.48, height: 25 / 16, decoration: TextDecoration.underline),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|