import 'package:flutter/material.dart'; import 'package:flutter/widgets.dart'; import 'package:flutter_screenutil/flutter_screenutil.dart'; import 'package:huixiang/generated/l10n.dart'; import 'package:huixiang/retrofit/data/article.dart'; import 'package:huixiang/view_widget/custom_image.dart'; import 'package:huixiang/view_widget/icon_text.dart'; class HotArticleItem extends StatelessWidget { final Article article; HotArticleItem({this.article}); @override Widget build(BuildContext context) { return GestureDetector( onTap: () { Navigator.of(context).pushNamed('/router/store_detail_page', arguments: {"articleId": article.id}); }, child: hotItem(context), ); } Widget hotItem(BuildContext context) { return Container( padding: EdgeInsets.all(16), decoration: BoxDecoration( color: Colors.white, boxShadow: [ BoxShadow( color: Colors.black.withAlpha(12), offset: Offset(0, 3), blurRadius: 14, spreadRadius: 0, ) ], borderRadius: BorderRadius.circular(4), ), child: Row( children: [ Visibility( visible: article != null && article.coverImg != null && article.coverImg != "", child: Row( children: [ Stack( alignment: Alignment.center, children: [ MImage( article != null ? article.coverImg : "", fit: BoxFit.cover, radius: BorderRadius.circular(2), aspectRatio: 1, errorSrc: "assets/image/default_1.png", fadeSrc: "assets/image/default_1.png", ), Visibility( visible: (article != null && article.coverImg != "" && article.coverImg.endsWith(".mp4")), child: Icon( Icons.play_circle_outline, size: 24, color: Colors.white, ), ), ], ), SizedBox( width: 12, ), ], ), ), Expanded( child: Column( mainAxisAlignment: MainAxisAlignment.spaceAround, crossAxisAlignment: CrossAxisAlignment.start, children: [ Text( article != null ? article.mainTitle : "", maxLines: 1, overflow: TextOverflow.ellipsis, style: TextStyle( fontWeight: FontWeight.w600, fontSize: 14.sp, color: Colors.black, ), ), Text( article != null ? (article.viceTitle ?? "") : "", maxLines: 2, overflow: TextOverflow.ellipsis, style: TextStyle( fontSize: 12.sp, fontWeight: FontWeight.w400, color: Color(0xFF353535), ), ), Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, crossAxisAlignment: CrossAxisAlignment.center, children: [ Expanded( child: Row( children: [ IconText( article != null ? (article.createTime.split(" ")[0]) : "", textStyle: TextStyle( fontSize: 10.sp, fontWeight: FontWeight.w400, color: Color(0xFFB2B2B2), ), leftIcon: Icons.access_time_rounded, iconSize: 10, iconColor: Color(0xFFB2B2B2), ), ], ), flex: 1, ), Text( S.of(context).zuozhe( (article != null && article.author != null) ? article.author.name : ""), style: TextStyle( fontSize: 10.sp, fontWeight: FontWeight.w400, color: Color(0xFFB2B2B2), ), ), ], ), ], ), ), ], ), ); } }