Files
Traders_Circuit/lib/view/MainScreen/HomeScreen.dart

816 lines
35 KiB
Dart
Raw Normal View History

2024-03-21 00:32:12 -07:00
// import 'package:flutter/material.dart';
2024-05-15 17:55:05 +05:30
import 'dart:developer';
import 'package:flutter/cupertino.dart';
2024-03-19 22:57:32 -07:00
import 'package:flutter/material.dart';
2024-04-16 16:43:11 +05:30
import 'package:flutter/services.dart';
2024-03-19 22:57:32 -07:00
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:flutter_svg/svg.dart';
2024-05-14 18:47:05 +05:30
import 'package:gap/gap.dart';
2024-03-19 22:57:32 -07:00
import 'package:get/get.dart';
import 'package:traderscircuit/Utils/Common/CommonBottomNavigation.dart';
import 'package:traderscircuit/Utils/Common/comonGlassmorphicContainer.dart';
import 'package:traderscircuit/Utils/Common/sized_box.dart';
2024-03-19 23:09:10 -07:00
import 'package:traderscircuit/Utils/text.dart';
2024-05-15 17:55:05 +05:30
import 'package:traderscircuit/controller/contact_us_controller.dart';
2024-05-08 16:06:35 +05:30
2024-05-08 15:58:31 +05:30
import 'package:traderscircuit/model/HomeModel/home_model.dart';
2024-05-08 16:06:35 +05:30
import 'package:traderscircuit/controller/products_controller.dart';
2024-05-08 16:06:35 +05:30
2024-03-19 22:57:32 -07:00
import 'package:traderscircuit/resources/routes/route_name.dart';
2024-05-15 17:55:05 +05:30
import 'package:traderscircuit/view/MainScreen/ExploreUnseen.dart';
2024-03-19 22:57:32 -07:00
import 'package:traderscircuit/view/MainScreen/MainScreen.dart';
2024-04-04 11:45:15 +05:30
import 'package:traderscircuit/view/Sidemenu/ContentByte/PlayerWidget.dart';
2024-03-19 22:57:32 -07:00
import 'package:traderscircuit/view/Sidemenu/Sidemenu.dart';
import 'package:traderscircuit/view/onBoarding/splashScreen1.dart';
2024-05-08 15:58:31 +05:30
import 'package:traderscircuit/view_model/HomeApi/home_api.dart';
2024-03-19 22:57:32 -07:00
2024-05-14 18:47:05 +05:30
import '../../Utils/Common/CustomTextFormField.dart';
import '../../view_model/ProfileAPI/GetProfileApi.dart';
2024-03-19 22:57:32 -07:00
class HomeScreen extends StatefulWidget {
const HomeScreen({super.key});
@override
State<HomeScreen> createState() => _HomeScreenState();
}
class _HomeScreenState extends State<HomeScreen> {
GlobalKey<ScaffoldState> _scaffoldKey1 = GlobalKey<ScaffoldState>();
RxString userName = "User".obs;
2024-05-08 16:06:35 +05:30
2024-05-08 15:58:31 +05:30
HomeModel homeModel = HomeModel();
RxBool isApiCalling = true.obs;
ProductsController productsController = Get.put(ProductsController());
2024-05-15 17:55:05 +05:30
ContactUsController contactUsController = Get.put(ContactUsController());
@override
void initState() {
GetProfile().GetProfileAPI().then((value) {
userName.value = ProfileObj!.data!.userName ?? "User";
});
2024-05-08 15:58:31 +05:30
HomeApi().getHomeData().then((value) {
homeModel = HomeModel.fromJson(value.data);
2024-05-24 18:48:09 +05:30
productsController.isUpstoxTokenNotExpired.value =
homeModel.data!.isUpstoxTokenRefreshed!;
2024-05-08 18:48:45 +05:30
isApiCalling.value = false;
2024-05-08 15:58:31 +05:30
});
super.initState();
}
2024-05-24 18:48:09 +05:30
String calculatePercentageChange(double openPrice, double currentPrice) {
final percentageChange = ((currentPrice - openPrice) / openPrice) * 100;
log(percentageChange.toStringAsFixed(2));
return percentageChange.toStringAsFixed(2);
}
2024-03-19 22:57:32 -07:00
@override
Widget build(BuildContext context) {
2024-04-16 16:43:11 +05:30
return WillPopScope(
onWillPop: () async {
_onBackButtonPressed(context);
return true; // Return true to allow the pop action
},
child: Scaffold(
drawerEnableOpenDragGesture: false,
key: _scaffoldKey1,
2024-03-19 22:57:32 -07:00
backgroundColor: Colors.black,
drawer: Container(child: const SideMenu()),
2024-04-16 16:43:11 +05:30
extendBody: true,
appBar: AppBar(
scrolledUnderElevation: 0.0,
backgroundColor: Colors.black,
elevation: 0,
automaticallyImplyLeading: false,
titleSpacing: 0,
leading: InkWell(
onTap: () {
2024-04-16 16:43:11 +05:30
_scaffoldKey1.currentState?.openDrawer();
},
2024-04-16 16:43:11 +05:30
child: Center(
child: Image.asset(
'assets/images/png/menu.png',
height: 15.h,
width: 20.w,
),
),
2024-03-19 22:57:32 -07:00
),
2024-04-16 16:43:11 +05:30
actions: [
InkWell(
onTap: () {
Get.toNamed(RouteName.notification);
},
child: Padding(
padding: EdgeInsets.only(right: 14.w),
child: SvgPicture.asset('assets/images/svg/Group 1897.svg')),
),
],
),
2024-05-08 18:48:45 +05:30
body: Obx(
() => Stack(
children: [
const CommonBlurLeft(),
const CommonBlurRight(),
Stack(children: [
Padding(
padding:
const EdgeInsets.symmetric(horizontal: 16, vertical: 16),
child: isApiCalling.value
2024-05-14 18:47:05 +05:30
? const Center(
child: CircularProgressIndicator(
color: Color(0xFF0093FF),
),
2024-05-08 18:48:45 +05:30
)
: ListView(
physics: const BouncingScrollPhysics(),
children: [
2024-05-14 18:47:05 +05:30
sizedBoxHeight(15.h),
CustomTextFormField1(
hintText: 'Search',
leadingIcon: SizedBox(
height: 20,
width: 20,
child: Center(
child: SvgPicture.asset(
'assets/images/svg/search-svgrepo-com.svg',
),
),
),
),
2024-05-08 18:48:45 +05:30
sizedBoxHeight(20.h),
Text(
2024-05-08 15:58:31 +05:30
"Welcome $userName",
style: TextStyle(
color: Colors.white,
fontSize: 24.sp,
fontFamily: 'hiragino',
fontWeight: FontWeight.w500),
),
2024-05-24 18:48:09 +05:30
!homeModel.data!.isUpstoxTokenRefreshed!
? const SizedBox()
: sizedBoxHeight(25.h),
!homeModel.data!.isUpstoxTokenRefreshed!
? const SizedBox()
: SingleChildScrollView(
scrollDirection: Axis.horizontal,
child: Row(
children: [
commoncontainer(
width: 250.w,
text: homeModel
.data!
.indexLiveData!
.data!
.nSEINDEXNifty50!
.instrumentToken!
.split("NSE_INDEX|")[1],
amount: homeModel.data!.indexLiveData!
.data!.nSEINDEXNifty50!.lastPrice!
.toString(),
rate: homeModel.data!.indexLiveData!
.data!.nSEINDEXNifty50!.netChange
.toString(),
percentageChange:
calculatePercentageChange(
homeModel.data!.indexLiveData!.data!
.nSEINDEXNifty50!.ohlc!.open!,
homeModel.data!.indexLiveData!.data!
.nSEINDEXNifty50!.lastPrice!,
),
),
sizedBoxWidth(10.w),
commoncontainer(
width: 250.w,
text: homeModel
.data!
.indexLiveData!
.data!
.nSEINDEXNiftyBank!
.instrumentToken!
.split("NSE_INDEX|")[1],
amount: homeModel
.data!
.indexLiveData!
.data!
.nSEINDEXNiftyBank!
.lastPrice!
.toString(),
rate: homeModel
.data!
.indexLiveData!
.data!
.nSEINDEXNiftyBank!
.netChange
.toString(),
percentageChange:
calculatePercentageChange(
homeModel.data!.indexLiveData!.data!
.nSEINDEXNiftyBank!.ohlc!.open!,
homeModel.data!.indexLiveData!.data!
.nSEINDEXNiftyBank!.lastPrice!,
),
),
],
),
),
!homeModel.data!.isUpstoxTokenRefreshed!
? const SizedBox()
: sizedBoxHeight(30.h),
!homeModel.data!.isUpstoxTokenRefreshed!
? const SizedBox()
: Container(
width: double.infinity,
height: 1.h,
color: const Color(0xFF3A3A3A),
),
2024-05-08 18:48:45 +05:30
sizedBoxHeight(30.h),
text22W500('View our products'),
sizedBoxHeight(30.h),
SizedBox(
2024-05-14 18:47:05 +05:30
height: 280,
child: ListView.builder(
2024-05-08 18:48:45 +05:30
physics: const NeverScrollableScrollPhysics(),
itemCount: homeModel.data!.products!.length,
itemBuilder: (context, index) {
2024-05-14 18:47:05 +05:30
return Container(
margin: const EdgeInsets.only(bottom: 12),
child: ProductWidget(
2024-05-08 18:48:45 +05:30
text: homeModel.data!.products!
.elementAt(index)
.title!,
2024-05-14 18:47:05 +05:30
),
);
2024-05-08 18:48:45 +05:30
},
),
),
sizedBoxHeight(25.h),
Row(
mainAxisAlignment: MainAxisAlignment.center,
2024-05-08 15:58:31 +05:30
children: [
2024-05-08 18:48:45 +05:30
SvgPicture.asset(
'assets/images/svg/Vector (2).svg'),
2024-05-08 15:58:31 +05:30
sizedBoxWidth(10.w),
2024-05-27 11:10:11 +05:30
InkWell(
child: text18W500('UNLOCK NOW!'),
onTap: () {
throw Exception();
},
),
2024-05-08 15:58:31 +05:30
],
),
2024-05-08 18:48:45 +05:30
sizedBoxHeight(25.h),
Container(
width: double.infinity,
height: 1.h,
color: const Color(0xFF3A3A3A),
2024-05-08 15:58:31 +05:30
),
2024-05-08 18:48:45 +05:30
sizedBoxHeight(25.h),
2024-05-14 18:47:05 +05:30
text25W800('Explore The Unseen'),
sizedBoxHeight(10.h),
Container(
padding: const EdgeInsets.all(8),
width: 398,
height: 55,
decoration: ShapeDecoration(
gradient: LinearGradient(
begin: const Alignment(1.00, 0.02),
end: const Alignment(-1, -0.02),
colors: [
Colors.white
.withOpacity(0.09000000357627869),
Colors.white
.withOpacity(0.0925697460770607),
Colors.white
.withOpacity(0.10999999940395355)
],
2024-05-08 15:58:31 +05:30
),
2024-05-14 18:47:05 +05:30
shape: RoundedRectangleBorder(
side: const BorderSide(
width: 1, color: Color(0x994A73FB)),
borderRadius: BorderRadius.circular(8),
),
),
child: Container(
width: 382,
height: 40,
decoration: ShapeDecoration(
color: const Color(0xFF00C236),
shape: RoundedRectangleBorder(
side: const BorderSide(width: 0.80),
borderRadius: BorderRadius.circular(5),
2024-05-08 15:58:31 +05:30
),
2024-05-14 18:47:05 +05:30
),
child: Center(
child: text18W500("Long Term"),
),
2024-05-08 15:58:31 +05:30
),
2024-05-08 18:48:45 +05:30
),
2024-05-14 18:47:05 +05:30
sizedBoxHeight(25.h),
// DefaultTabController(
// length: 2,
// child: Column(
// children: [
// MyTabBar(),
// SizedBox(
// height: 250.h,
// child: TabBarView(
// children: [
// ActiveCallsTab(),
// ExitedCallsTab(),
// ],
// ),
// ),
// ],
// ),
// ),
cardcallWidget(
action: homeModel
.data!
.exploreTheUnseenActiveCalls!
.first
.recommendationActionsXid ==
1
? "Buy"
: homeModel
.data!
.exploreTheUnseenActiveCalls!
.first
.recommendationActionsXid ==
2
? "Sell"
: homeModel
.data!
.exploreTheUnseenActiveCalls!
.first
.recommendationActionsXid ==
3
? "Hold"
: homeModel
.data!
.exploreTheUnseenActiveCalls!
.first
.recommendationActionsXid ==
4
? "Exit"
: "",
text: homeModel
.data!
.exploreTheUnseenActiveCalls!
.first
.stockName!,
amount:
"${homeModel.data!.exploreTheUnseenActiveCalls!.first.buyPrice!}",
pdfname: 'Download Pdf'),
sizedBoxHeight(25.h),
2024-05-08 18:48:45 +05:30
Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
2024-05-14 18:47:05 +05:30
text20W600('Content Bytes'),
2024-05-08 18:48:45 +05:30
sizedBoxHeight(8.w),
Row(
mainAxisAlignment: MainAxisAlignment.end,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
SizedBox(
2024-05-15 17:55:05 +05:30
width: 220.w,
2024-05-08 18:48:45 +05:30
child: text16W400_DADADA(
'The Beauty and Power of Video')),
// sizedBoxWidth(10.w),
const Spacer(),
2024-05-15 17:55:05 +05:30
InkWell(
onTap: () {
Get.toNamed(RouteName.contentbytes);
},
child: Container(
width: 105,
height: 35,
decoration: ShapeDecoration(
2024-05-24 18:48:09 +05:30
color: const Color(0xFF0093FF),
2024-05-15 17:55:05 +05:30
shape: RoundedRectangleBorder(
borderRadius:
BorderRadius.circular(5)),
2024-05-08 15:58:31 +05:30
),
2024-05-15 17:55:05 +05:30
child: Center(
child: text14W500('View More')),
2024-05-08 18:48:45 +05:30
),
),
],
),
sizedBoxHeight(20.h),
commonGlassContainer(
borderradius: 8,
width: double.infinity,
height: 330.h,
customWidget: Padding(
padding: EdgeInsets.symmetric(
vertical: 10.h, horizontal: 10.w),
child: Column(
children: [
InkWell(
onTap: () {
Get.to(() => const PlayerWidget(),
arguments: {
"video_url": homeModel
.data!
.contentByteVideo!
.link ??
"",
});
},
child: Container(
height: 200.h,
width: double.infinity,
decoration: BoxDecoration(
borderRadius:
BorderRadius.circular(8.r),
image: DecorationImage(
image: NetworkImage(homeModel
2024-05-08 15:58:31 +05:30
.data!
.contentByteVideo!
2024-05-08 18:48:45 +05:30
.image ??
2024-05-08 15:58:31 +05:30
""),
2024-05-08 18:48:45 +05:30
),
),
child: Center(
child: SvgPicture.asset(
'assets/images/svg/gridicons_play.svg',
height: 56.h,
width: 56.w,
),
),
2024-05-08 15:58:31 +05:30
),
2024-05-08 18:48:45 +05:30
),
sizedBoxHeight(20.h),
Row(
crossAxisAlignment:
CrossAxisAlignment.center,
children: [
sizedBoxWidth(10.w),
Expanded(
child: Column(
crossAxisAlignment:
CrossAxisAlignment.start,
children: [
text18W500(homeModel
.data!
.contentByteVideo!
.title ??
""),
// sizedBoxHeight(10.h),
text12W400_979797(
2024-05-15 17:55:05 +05:30
contactUsController
.timeAgoConverter(
homeModel
.data!
.contentByteVideo!
.createdAt!)),
2024-05-08 18:48:45 +05:30
],
),
)
],
)
],
),
))
],
),
],
),
)
])
],
),
2024-04-16 16:43:11 +05:30
),
bottomNavigationBar: bottomnavigationbar(mainController),
2024-03-19 22:57:32 -07:00
),
);
}
2024-04-16 16:43:11 +05:30
Future<bool> _onBackButtonPressed(BuildContext context) async {
bool? exitApp = await showDialog(
context: context,
builder: (context) {
return AlertDialog(
backgroundColor: const Color(0xFFFFF3E4),
title: const Text('Exit App'),
content: const Text('Do you really want to close the app?'),
actions: [
TextButton(
onPressed: () {
Navigator.of(context).pop(false);
},
child: const Text(
'No',
style: TextStyle(
color: Color(0xff1B243D),
),
),
),
TextButton(
onPressed: () {
SystemNavigator.pop();
Navigator.pop(context);
},
child: const Text(
'Yes',
style: TextStyle(
color: Color(0xff1B243D),
),
),
)
],
);
});
return exitApp ?? false;
}
2024-03-19 22:57:32 -07:00
2024-05-08 15:58:31 +05:30
Widget ActiveCallsTab() {
return Column(
children: [
sizedBoxHeight(30.h),
cardcallWidget(
action: homeModel.data!.exploreTheUnseenActiveCalls!.first
.recommendationActionsXid ==
1
? "Buy"
: homeModel.data!.exploreTheUnseenActiveCalls!.first
.recommendationActionsXid ==
2
? "Sell"
: homeModel.data!.exploreTheUnseenActiveCalls!.first
.recommendationActionsXid ==
3
? "Hold"
: homeModel.data!.exploreTheUnseenActiveCalls!.first
.recommendationActionsXid ==
4
? "Exit"
: "",
text: homeModel.data!.exploreTheUnseenActiveCalls!.first.stockName!,
amount:
"${homeModel.data!.exploreTheUnseenActiveCalls!.first.buyPrice!}",
pdfname: 'Download Pdf'),
sizedBoxHeight(30.h),
],
);
}
2024-05-08 15:58:31 +05:30
Widget ExitedCallsTab() {
return Column(
children: [
sizedBoxHeight(30.h),
2024-05-08 15:58:31 +05:30
homeModel.data!.exploreTheUnseenExitedCalls!.isEmpty ||
homeModel.data!.exploreTheUnseenExitedCalls == null
? text14W300("No Data")
: Column(
children: List.generate(
homeModel.data!.exploreTheUnseenExitedCalls!.length,
(index) {
return Column(
children: [
cardcallWidget(
action: "Hold",
text: homeModel.data!.exploreTheUnseenExitedCalls!
.elementAt(index)
.stockName ??
"",
amount: homeModel.data!.exploreTheUnseenExitedCalls!
.elementAt(index)
.buyPrice ??
"",
pdfname: "Download Pdf"),
sizedBoxHeight(20.h)
],
);
}),
)
],
2024-05-08 15:58:31 +05:30
);
}
2024-03-19 22:57:32 -07:00
}
Widget cardcallWidget(
2024-05-08 15:58:31 +05:30
{required String text,
required String amount,
required String pdfname,
required String action}) {
2024-05-14 18:47:05 +05:30
return Container(
width: 398,
height: 251,
decoration: ShapeDecoration(
color: const Color(0x232C79ED),
shape: RoundedRectangleBorder(
side: const BorderSide(width: 1, color: Color(0x994A73FB)),
borderRadius: BorderRadius.circular(8),
),
),
child: Stack(
2024-03-19 22:57:32 -07:00
children: [
2024-05-15 17:55:05 +05:30
Positioned(
right: 0,
child: SvgPicture.asset("assets/images/svg/card_decoration.svg")),
2024-05-14 18:47:05 +05:30
Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
padding: EdgeInsets.symmetric(vertical: 16.h, horizontal: 16.w),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
2024-03-19 22:57:32 -07:00
children: [
2024-05-14 18:47:05 +05:30
text16W700(text),
Container(
width: 75.w,
height: 30.h,
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(15.r),
color: action == "Buy"
? Colors.green
: action == "Sell"
? Colors.red
: action == "Hold"
? const Color(0xFFFFAD31)
: Colors.white,
),
child: Center(child: text14W500(action, clr: Colors.black)),
)
2024-03-19 22:57:32 -07:00
],
),
2024-05-14 18:47:05 +05:30
),
Padding(
padding: const EdgeInsets.all(20),
child: Column(
2024-03-19 22:57:32 -07:00
crossAxisAlignment: CrossAxisAlignment.start,
2024-05-14 18:47:05 +05:30
mainAxisAlignment: MainAxisAlignment.start,
2024-03-19 22:57:32 -07:00
children: [
2024-05-14 18:47:05 +05:30
text14W400_979797('Initial Entry Price'),
2024-03-19 22:57:32 -07:00
sizedBoxHeight(5.h),
2024-05-14 18:47:05 +05:30
text15W600(amount),
sizedBoxHeight(30.w),
2024-03-19 22:57:32 -07:00
Row(
2024-05-14 18:47:05 +05:30
mainAxisAlignment: MainAxisAlignment.spaceBetween,
2024-03-19 22:57:32 -07:00
children: [
2024-05-14 18:47:05 +05:30
Container(
width: 150,
height: 52,
decoration: ShapeDecoration(
color: const Color(0x332C79ED),
shape: RoundedRectangleBorder(
side: const BorderSide(
width: 1, color: Color(0x994A73FB)),
borderRadius: BorderRadius.circular(8),
),
),
child: Row(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
// SvgPicture.asset('assets/images/svg/pdfsvg.svg'),
Image.asset(
'assets/images/png/pdf.png',
height: 20.h,
width: 20.w,
),
const Gap(5),
text15W600(pdfname),
],
),
),
2024-05-15 17:55:05 +05:30
GestureDetector(
onTap: () {
log("RUNNING");
2024-05-24 18:48:09 +05:30
Get.to(const ExploreUnseen());
2024-05-15 17:55:05 +05:30
},
child: Container(
height: 52,
width: 150,
decoration: ShapeDecoration(
color: const Color(0xFF0093FF),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(8)),
),
child: Center(child: text15W600("View More")),
2024-05-14 18:47:05 +05:30
),
)
2024-03-19 22:57:32 -07:00
],
2024-05-14 18:47:05 +05:30
),
2024-03-19 22:57:32 -07:00
],
2024-05-14 18:47:05 +05:30
),
)
],
),
2024-03-19 22:57:32 -07:00
],
),
);
}
2024-05-14 18:47:05 +05:30
Widget ProductWidget({
required String text,
}) {
2024-05-15 18:48:17 +05:30
ProductsController productsController = Get.put(ProductsController());
return InkWell(
onTap: () {
2024-05-15 19:03:16 +05:30
mainController.updateTab(1);
2024-05-15 18:48:17 +05:30
if (text == "Swing Trade") {
productsController.selectedIndex.value = 0;
} else if (text == "Options") {
productsController.selectedIndex.value = 2;
} else {
productsController.selectedIndex.value = 1;
}
},
child: Container(
padding: const EdgeInsets.only(left: 20),
width: 398,
height: 83,
decoration: ShapeDecoration(
gradient: const LinearGradient(
begin: Alignment(0.99, -0.14),
end: Alignment(-0.99, 0.14),
colors: [Color(0xFF1538C5), Color(0xFF0B2074), Color(0xFF000D41)],
),
shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(8)),
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
text18W600(text),
// Image.asset(
// "assets/images/png/swingImage.png",
// height: 83,
// )
SvgPicture.asset(text == "Swing Trade"
? "assets/images/svg/swing_image.svg"
: text == "Options"
? "assets/images/svg/options_image.svg"
: "assets/images/svg/multibagger_image.svg")
],
2024-03-19 22:57:32 -07:00
),
),
);
}
2024-05-24 18:48:09 +05:30
Widget commoncontainer({
required String text,
required String amount,
required String rate,
required double width,
required String percentageChange,
}) {
2024-05-14 18:47:05 +05:30
return Container(
height: 83,
decoration: ShapeDecoration(
color: const Color(0xFF0F2C53),
shape: RoundedRectangleBorder(
side: const BorderSide(width: 1, color: Color(0x7F4A73FB)),
borderRadius: BorderRadius.circular(8),
),
2024-03-19 22:57:32 -07:00
),
child: Padding(
padding: EdgeInsets.symmetric(vertical: 10.h, horizontal: 10.w),
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
text14W400_979797(text),
sizedBoxWidth(8.w),
text16W600(amount),
sizedBoxWidth(8.w),
2024-05-24 18:48:09 +05:30
rate.contains("-")
? SvgPicture.asset(
'assets/images/svg/Line 587.svg',
height: 15.h,
width: 15.w,
)
: rate == "0.0"
? const SizedBox()
: SvgPicture.asset(
'assets/images/svg/up_arrow.svg',
height: 15.h,
width: 15.w,
),
2024-03-19 22:57:32 -07:00
],
),
sizedBoxHeight(8.w),
2024-05-24 18:48:09 +05:30
text14W400(
rate.contains("-")
? "$rate ($percentageChange%)"
: "+$rate ($percentageChange%)",
clr: rate.contains("-")
? const Color(0xFFFF0000)
: rate == "0.0"
? Colors.grey
: const Color(0xFF00FF19),
),
2024-03-19 22:57:32 -07:00
],
),
),
);
}