import 'package:flutter/material.dart'; import 'package:flutter_screenutil/flutter_screenutil.dart'; import 'package:huixiang/generated/l10n.dart'; import 'package:huixiang/data/activity.dart'; import 'package:huixiang/data/article.dart'; import 'package:like_button/like_button.dart'; import 'dart:io'; import 'package:emoji_picker_flutter/emoji_picker_flutter.dart'; class InputComment extends StatefulWidget { final String hintText; final Activity? activity; final Article? article; final bool isKeyBoardShow; final double keyboard; final bool emojiShowing; final FocusNode commentFocus; final Function toComment; final Function onSmileyTap; final Function onTextFieldTap; final Function(String text) queryMemberComment; final Function() queryInformationLikes; final TextEditingController commentTextController; final bool? isLike; final Function(bool emojiShow)? emojiShowFunction; InputComment( Key key, this.hintText, this.isKeyBoardShow, this.keyboard, this.emojiShowing, this.commentFocus, this.commentTextController, this.toComment, this.onSmileyTap, this.onTextFieldTap, this.queryMemberComment, this.queryInformationLikes, { this.activity, this.article, this.isLike, this.emojiShowFunction } ) : super(key: key); @override State createState() { return _InputComment(); } } class _InputComment extends State { bool emojiShowing = false; @override Widget build(BuildContext context) { return Container( padding: EdgeInsets.only(top: 16.h,), decoration: BoxDecoration( color: Colors.white, boxShadow: [ BoxShadow( color: Colors.black.withAlpha(12), offset: Offset(0, 2), blurRadius: 14, spreadRadius: 0, ), ], borderRadius: BorderRadius.vertical( top: Radius.circular(8), ), ), child: Column( children: [ Row( children: [ IconButton( onPressed: () { widget.onSmileyTap(); }, icon: Icon( Icons.emoji_emotions, color: Color(0xFF868686), ), ), Expanded( flex: 1, child: Container( decoration: BoxDecoration( color: Color(0xffF2F2F2), borderRadius: BorderRadius.circular(2.0), ), child: Container( margin: EdgeInsets.symmetric(horizontal: 4.w), alignment: Alignment.topLeft, child: TextField( textInputAction:TextInputAction.send, onTap: (){ widget.onTextFieldTap(); }, onEditingComplete: () { var commentText = widget.commentTextController.text; if (commentText.trim() == "") { return; } widget.queryMemberComment(commentText); }, maxLines: 8, minLines: 1, focusNode: widget.commentFocus, controller: widget.commentTextController, decoration: InputDecoration( border: InputBorder.none, hintText: widget.hintText, hintStyle: TextStyle( fontSize: 14.sp, color: Color(0xFF868686), ), ), ), ), ), ), if (widget.isKeyBoardShow) GestureDetector( behavior: HitTestBehavior.opaque, onTap: () { var commentText = widget.commentTextController.text; if (commentText.trim() == "") { return; } widget.queryMemberComment(commentText); }, child: Container( padding: EdgeInsets.symmetric(horizontal: 20.w,vertical:15.h), child: Text( S.of(context).fasong, style: TextStyle( fontSize: 16.sp, fontWeight: FontWeight.bold, color: Color(0XFF1A1A1A), ), ), ), ), if (!widget.isKeyBoardShow) InkWell( onTap: () { widget.toComment.call(); }, child: Tooltip( message: S.of(context).daopinglunliebiaodingbu, child: Container( padding: EdgeInsets.only(left: 20.w, right: 10.w), child: Image.asset( "assets/image/icon_comment.webp", width: 24, height: 24, ), ), ), ), if (!widget.isKeyBoardShow) Tooltip( message: S.of(context).dianzanxihuan_(widget.activity == null ? S.of(context).wenzhang : S.of(context).huodong), child: LikeButton( padding: EdgeInsets.all(10), size: 24, circleSize: 24, circleColor: CircleColor( start: Color(0xff00ddff), end: Color(0xff0099cc), ), bubblesColor: BubblesColor( dotPrimaryColor: Color(0xff33b5e5), dotSecondaryColor: Color(0xff0099cc), ), bubblesSize: 24, likeBuilder: (bool isLiked) { return isLiked ? Image.asset( "assets/image/icon_like.webp", width: 24, height: 24, ) : Image.asset( "assets/image/icon_like_h.webp", width: 24, height: 24, ); }, isLiked: (widget.activity != null ? widget.activity!.liked : widget.article != null ? widget.article!.liked : widget.isLike??false), onTap: (isLiked) async { await widget.queryInformationLikes(); return (widget.activity != null ? widget.activity!.liked : widget.article != null ? widget.article!.liked : widget.isLike ?? false); }, countBuilder: (int? count, bool isLiked, String text) { return Text( text, style: TextStyle( color: Color(0xFF1A1A1A), fontSize: 12.sp, ), ); }, ), ), ], ), SizedBox(height: 16.h,), Offstage( offstage: !widget.emojiShowing, child: SizedBox( height: widget.keyboard == -1 ? 270 : widget.keyboard, width: MediaQuery.of(context).size.width, child: EmojiPicker( textEditingController: widget.commentTextController, config: Config( emojiViewConfig: EmojiViewConfig( columns: 7, emojiSizeMax: 28 * (Platform.isIOS ? 1.10 : 1.0), verticalSpacing: 0, horizontalSpacing: 0, backgroundColor: const Color(0xFFF2F2F2), gridPadding: EdgeInsets.zero, recentsLimit: 35, replaceEmojiOnLimitExceed: false, noRecents: Text( "最近使用", style: TextStyle(fontSize: 20, color: Colors.black26), textAlign: TextAlign.center, ), loadingIndicator: const SizedBox.shrink(), buttonMode: ButtonMode.MATERIAL, ), skinToneConfig: SkinToneConfig( enabled: true, dialogBackgroundColor: Colors.white, indicatorColor: Colors.grey, ), categoryViewConfig: CategoryViewConfig( initCategory: Category.RECENT, iconColor: Colors.grey, iconColorSelected: Colors.blue, backspaceColor: Colors.blue, categoryIcons: const CategoryIcons(), tabIndicatorAnimDuration: Duration(milliseconds: 0), ), bottomActionBarConfig: BottomActionBarConfig( backgroundColor: Colors.transparent, buttonIconColor: Colors.blue, showBackspaceButton: true, showSearchViewButton: false, ), swapCategoryAndBottomBar: false, checkPlatformCompatibility: true, ), ), ), ), ], ), ); }}