|
|
|
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<StatefulWidget> createState() {
|
|
|
|
return _InputComment();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class _InputComment extends State<InputComment> {
|
|
|
|
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,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}}
|