import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; import 'package:flutter_screenutil/flutter_screenutil.dart'; import 'package:huixiang/utils/font_weight.dart'; class ItemInputWidget extends StatelessWidget { final String hintText; final String title; final TextStyle style; final int inputState; final TextEditingController? controller; final Function(String value)? onChanged; final Function()? onTap; final double? discount; final int inputLimit; final bool isShowBtn; final int btnState; final String? btnText; final String errorText; final Color errorTextColor; final Color titleColor; final double radius; final EdgeInsets padding; final TextInputType textInputType; final TextInputFormatter? textInputFormatter; ItemInputWidget( this.title, { this.hintText = "", this.inputState = 0, this.btnState = 0, this.inputLimit = 16, this.controller, this.onChanged, this.style = const TextStyle(), this.radius = 4, this.onTap, this.discount, required this.textInputType, this.errorText = "", this.errorTextColor = const Color(0xFFFF441A), this.titleColor = Colors.black, this.padding = const EdgeInsets.only(left: 20, right: 21, top: 16, bottom: 4), this.btnText, this.textInputFormatter, this.isShowBtn = false, }); @override Widget build(BuildContext context) { var color = Color(0xFFF7F7F7); if (inputState == 0) { color = Color(0xFFF7F7F7); } else if (inputState == 1) { color = Color(0xFF37A546); } else { color = Color(0xFFFF441A); } var inputBorder = UnderlineInputBorder( borderSide: BorderSide(width: 1, color: color, style: BorderStyle.solid), ); return Container( // margin: EdgeInsets.only(left: 20.w, right: 20.w, top: 12.h, bottom: 4.h), padding: padding, color: Colors.white, // decoration: BoxDecoration( // boxShadow: [ // BoxShadow( // color: Color(0x000000).withAlpha(25), // offset: Offset(0, 1), // blurRadius: 12.0, // ), // ], // color: Colors.white, // borderRadius: BorderRadius.circular(radius), // ), child: Column( mainAxisAlignment: MainAxisAlignment.spaceAround, crossAxisAlignment: CrossAxisAlignment.start, children: [ Row( mainAxisAlignment: MainAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.center, children: [ Text( title, style: TextStyle( fontSize: 14.sp, fontWeight: FontWeight.bold, color: titleColor, ), ), Container( margin: EdgeInsets.only(left: 5), height: 20.h, alignment: Alignment.center, padding: EdgeInsets.only(left:3,right:4), decoration: BoxDecoration( borderRadius: BorderRadius.only( topLeft: Radius.circular(9), topRight: Radius.circular(9), bottomLeft: Radius.circular(0), bottomRight: Radius.circular(9), ), color: Color(0xFF32A060), ), child: Text( "当前折扣:${discount.toString()}折", style: TextStyle( fontSize: 12.sp, fontWeight: MyFontWeight.medium, color: Colors.white, ), ), ), ], ), SizedBox( height: 5.h, ), Container( alignment: Alignment.centerLeft, child: Stack( alignment: Alignment.centerLeft, children: [ Container( width: 20.w, alignment: Alignment.centerLeft, child: Text( "¥", style: TextStyle( fontWeight: MyFontWeight.medium, color: style.color, fontSize: 26.sp, ), ), margin: EdgeInsets.only(left: 5, bottom: 12.h), ), Container( // height: 0.035.sh, margin: EdgeInsets.only(bottom:10.h), child: TextField( controller: controller, style: style, onChanged: onChanged, keyboardType: textInputType, decoration: InputDecoration( errorBorder: inputBorder, focusedBorder: inputBorder, enabledBorder: inputBorder, hintText: hintText, contentPadding: EdgeInsets.only( top: 12.h, bottom: 12.h, left: 24.w, ), hintStyle: TextStyle( fontSize: 10.sp, color: Color(0xFFA29E9E), ), ), textInputAction: TextInputAction.next, inputFormatters: textInputFormatter != null ? [ LengthLimitingTextInputFormatter(inputLimit), textInputFormatter!, ] : [ LengthLimitingTextInputFormatter(inputLimit), ], cursorColor: Colors.grey, maxLines: 1, minLines: 1, ), ), ], ), ), Offstage( offstage: errorText == "", child: Text( errorText ?? "", style: TextStyle( color: errorTextColor, fontSize: 12.sp, ), ), ) ], ), ); } }