import 'dart:math'; import 'package:flutter/material.dart'; import 'package:loading_indicator/loading_indicator.dart'; import 'package:zhiying_comm/zhiying_comm.dart'; import 'turn_chain_style_model.dart'; class TurnChainLoading { static OverlayEntry _overlayEntry; static Future show( BuildContext context, TurnChainStyleModel model, ) async { dismiss(); _overlayEntry = new OverlayEntry(builder: (context) { return GestureDetector( onTap: dismiss, child: Container( color: Colors.black.withOpacity(0.3), child: TurnChainDialogWidget(model), ), ); }); try { //插入到 Overlay中显示 OverlayEntry Overlay.of(context).insert(_overlayEntry); } catch (e, s) { Logger.error(e, s); } } static dismiss() { try { _overlayEntry?.remove(); _overlayEntry = null; } catch (e, s) { Logger.error(e, s); } } } class TurnChainDialogWidget extends StatelessWidget { TurnChainStyleModel model; TurnChainDialogWidget(this.model); @override Widget build(BuildContext context) { return WillPopScope( onWillPop: () { return Future.value(false); }, child: Scaffold( backgroundColor: HexColor.fromHex('#54555555'), body: Center( child: Container( height: 250, width: 260, // margin: const EdgeInsets.symmetric(horizontal: 70), padding: const EdgeInsets.all(20), decoration: BoxDecoration( color: HexColor.fromHex('#FEFFFE'), borderRadius: BorderRadius.circular(13), ), child: Column( mainAxisAlignment: MainAxisAlignment.center, crossAxisAlignment: CrossAxisAlignment.center, children: [ /// 跳转图标 _buildTransitionIconWidget(), /// 正在跳转提示文字 Padding(padding: const EdgeInsets.only(top: 12), child: _buildJumpTipWidget()), /// 返利和券 Padding(padding: const EdgeInsets.only(top: 13), child: _buildCouponAndRebateWidget()), // /// 共省提示 Padding(padding: const EdgeInsets.only(top: 14), child: _buildSaveMoneyTipWidget()), /// 注意提示文字 Padding(padding: const EdgeInsets.only(top: 8, left: 9.5, right: 9.5), child: _buildNoticeWidget()), ], )), ), ), ); } /// 过渡图标 Widget _buildTransitionIconWidget() { return Container( height: 50, child: Row( crossAxisAlignment: CrossAxisAlignment.center, mainAxisAlignment: MainAxisAlignment.center, children: [ Container( margin: const EdgeInsets.only(right: 8), width: 50, height: 50, child: CachedNetworkImage( imageUrl: model?.appLogo ?? '', ), ), Container( height: 10, width: 34, child: LoadingIndicator( indicatorType: Indicator.ballPulse, color: HexColor.fromHex('#FE7978'), colors: [ HexColor.fromHex('#FF2020'), HexColor.fromHex('#FE7978'), HexColor.fromHex('#FEBCBB'), ], ), ), Container( margin: const EdgeInsets.only(left: 8), width: 50, height: 50, // color: Colors.red, child: CachedNetworkImage( imageUrl: _getProviderIcon(), ), ), ], ), ); } String _getProviderIcon() { int length = model?.style?.providerIcons?.length ?? 0; String result = ''; if (length > 0) { model.style.providerIcons.forEach((element) { if (element.type == model.provider) { result = element?.img ?? ''; } }); } return result; } /// 跳转文字提示 Widget _buildJumpTipWidget() { return Text( '${model?.style?.text}${model.providerName}', style: TextStyle(color: HexColor.fromHex('#333333'), fontSize: 15, fontWeight: FontWeight.bold), ); } /// 返利与优惠券 Widget _buildCouponAndRebateWidget() { return Container( height: 30, child: Row( mainAxisAlignment: MainAxisAlignment.center, children: [ _buildCustomButtonWidget( text: model?.style?.leftBtnText ?? '返利', textColor: model?.style?.leftBtnTextColor ?? '#FEFFFE', number: !EmptyUtil.isEmpty(model?.commission) ? model?.commission : '0.00', numberColor: model?.style?.leftBtnTextColor ?? '#FEFFFE', bgColor: model?.style?.leftBtnColor ?? '#FF2020', bgImg: model?.style?.leftBtnImg ?? ''), const SizedBox(width: 8), _buildCustomButtonWidget( text: model?.style?.rightBtnText ?? '券', textColor: model?.style?.rightBtnTextColor ?? '#FEFFFE', number: !EmptyUtil.isEmpty(model?.coupon) ? model?.coupon : '0.00', numberColor: model?.style?.rightBtnTextColor ?? '#FEFFFE', bgColor: model?.style?.rightBtnColor ?? '#FF2020', bgImg: model?.style?.rightBtnImg ?? ''), ], ), ); } Widget _buildCustomButtonWidget({String text, String textColor, String number, String numberColor, String bgColor, String bgImg}) { return Container( height: 30, width: 95, alignment: Alignment.center, decoration: BoxDecoration( borderRadius: BorderRadius.circular(8), color: !EmptyUtil.isEmpty(bgImg) ? null : HexColor.fromHex(bgColor), image: EmptyUtil.isEmpty(bgImg) ? null : DecorationImage( image: CachedNetworkImageProvider(bgImg ?? ''), )), child: RichText( text: TextSpan(children: [ TextSpan( text: text ?? '', style: TextStyle(color: HexColor.fromHex(textColor), fontSize: 13), ), TextSpan( text: number ?? '', style: TextStyle(color: HexColor.fromHex(numberColor), fontFamily: 'Din', package: 'zhiying_base_widget', fontSize: 13), ), ]), )); } /// 总共省下多少钱的提示 Widget _buildSaveMoneyTipWidget() { return RichText( text: TextSpan(children: [ TextSpan(text: model?.style?.saveMomenyText ?? '共省 ¥', style: TextStyle(color: HexColor.fromHex(model?.style?.saveMomenyColor ?? '#FF2020'), fontSize: 13)), TextSpan( text: model?.totalSave ?? '0.00', style: TextStyle(color: HexColor.fromHex(model?.style?.saveMomenyColor ?? '#FF2020'), fontSize: 18, fontFamily: 'Din', package: 'zhiying_base_widget')), // TextSpan(text: '.99', style: TextStyle(color: HexColor.fromHex(model?.style?.saveMomenyColor ?? '#FF2020'), fontSize: 13, fontFamily: 'Din', package: 'zhiying_base_widget')), ]), ); } /// 注意提示文字提示 Widget _buildNoticeWidget() { return Text( model?.style?.tipText ?? '注意:使用红包下单,会导致收益变少,或没有收益!', textAlign: TextAlign.center, maxLines: 2, overflow: TextOverflow.ellipsis, style: TextStyle(color: HexColor.fromHex(model?.style?.tipColor ?? '#999999'), fontSize: 11), ); } }