import 'package:douyin_demo/pages/RecommendPage/FriendList.dart'; import 'package:douyin_demo/providers/AtUserProvider.dart'; import 'package:douyin_demo/providers/RecommendProvider.dart'; import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; class ReplyFullList extends StatelessWidget { ReplyFullList({Key key,this.pCtx}) : super(key: key); final BuildContext pCtx; @override Widget build(BuildContext context) { double rpx = MediaQuery.of(context).size.width / 750; RecommendProvider provider = Provider.of(pCtx); Reply reply = provider.reply; List replies = []; replies.add(reply); replies.add(reply); replies.add(reply); ScrollController controller = ScrollController(); return Scaffold( appBar: PreferredSize( preferredSize: Size.fromHeight(80*rpx), child: AppBar( leading: Container(), elevation:0, backgroundColor: Colors.grey[50], actions: [ IconButton( icon: Icon( Icons.close, color: Colors.black, ), onPressed: () { Navigator.pop(context); }, ) ], title: Text( "10条评论", style: TextStyle(color: Colors.grey[700],fontSize: 25*rpx), ), // elevation: 1, ) ), bottomNavigationBar: SafeArea( child: BottomReplyBar(pCtx: pCtx,), ), body: SingleChildScrollView( controller: controller, child: Container( child: genReplyList(replies, controller), ))); } } class ReplyList extends StatelessWidget { const ReplyList({Key key, this.reply, this.controller}) : super(key: key); final Reply reply; final ScrollController controller; @override Widget build(BuildContext context) { double rpx = MediaQuery.of(context).size.width / 750; List replies = []; replies.add(reply); replies.add(reply); replies.add(reply); return Container( child: Column( mainAxisSize: MainAxisSize.min, children: [ Row( children: [ Container( width: 100 * rpx, height: 100 * rpx, padding: EdgeInsets.all(10 * rpx), child: CircleAvatar( backgroundImage: NetworkImage("${reply.replyMakerAvatar}"), ), ), Container( width: 550 * rpx, child: ListTile( title: Text("${reply.replyMakerName}"), subtitle: Text( "${reply.replyContent}", maxLines: 2, overflow: TextOverflow.ellipsis, ), ), ), Container( width: 100 * rpx, child: IconButton( onPressed: () {}, icon: Icon( Icons.favorite, color: Colors.grey[300], ), ), ) ], ), genAfterReplyList(replies, controller) ], ), ); } } class AfterReply extends StatelessWidget { const AfterReply({Key key, this.afterReply}) : super(key: key); final Reply afterReply; @override Widget build(BuildContext context) { double rpx = MediaQuery.of(context).size.width / 750; return Container( child: Column( mainAxisSize: MainAxisSize.min, children: [ Row( children: [ Container( width: 100 * rpx, ), Container( width: 550 * rpx, child: Row( crossAxisAlignment: CrossAxisAlignment.start, children: [ Container( width: 70 * rpx, height: 70 * rpx, margin: EdgeInsets.only(top: 15 * rpx), padding: EdgeInsets.all(10 * rpx), child: CircleAvatar( backgroundImage: NetworkImage("${afterReply.replyMakerAvatar}"), ), ), Container( width: 480 * rpx, child: ListTile( title: Text("${afterReply.replyMakerName}"), subtitle: RichText( text: TextSpan( text: "${afterReply.replyContent}", style: TextStyle(color: Colors.grey[500]), children: [ TextSpan(text: " ${afterReply.whenReplied}") ]), ), ), ) ], ), ), Container( width: 100 * rpx, child: IconButton( onPressed: () {}, icon: Icon( Icons.favorite, color: Colors.grey[300], ), ), ) ], ) ], ), ); } } genReplyList(List replies, ScrollController controller) { return ListView.builder( shrinkWrap: true, controller: controller, itemCount: replies.length, itemBuilder: (context, index) { return ReplyList( reply: replies[index], controller: controller, ); }, ); } genAfterReplyList(List replies, ScrollController controller) { return ListView.builder( shrinkWrap: true, controller: controller, itemCount: replies.length <= 2 ? replies.length : 2, itemBuilder: (context, index) { return AfterReply( afterReply: replies[index], ); }, ); } class BottomReplyBar extends StatelessWidget { const BottomReplyBar({Key key,this.pCtx}) : super(key: key); final BuildContext pCtx; @override Widget build(BuildContext context) { TextEditingController _controller=TextEditingController(); double toBottom=MediaQuery.of(context).viewInsets.bottom; double rpx=MediaQuery.of(context).size.width/750; return Container( padding: EdgeInsets.only(bottom: toBottom), decoration: BoxDecoration(border: Border(top: BorderSide(color: Colors.grey[200],width: 1))), child: Row(children: [ Expanded( child: Container( padding: EdgeInsets.only(left: 30*rpx), // width: 600*rspx, child: TextField(controller: _controller,decoration: InputDecoration(hintText: "留下你的精彩评论",border: InputBorder.none),), ) ), IconButton(icon: Icon(Icons.email,color: Colors.grey[500],size: 50*rpx,),onPressed: (){showAtFriendPage(pCtx);},), IconButton(icon: Icon(Icons.face,color: Colors.grey[500],size: 50*rpx),onPressed: (){},), SizedBox(width: 20*rpx,) ],), ); } } showAtFriendPage(BuildContext context){ Navigator.of(context).push(MaterialPageRoute( builder: (BuildContext context) { return MultiProvider( providers: [ChangeNotifierProvider(builder:(context)=>AtUserProvider())], child: AtFriendPage() ); }, fullscreenDialog: true )); }