как изменить цвет focusBorder в нестандартном компоненте Reusable Text Field
Я новичок в разработке Flutter. Я создал настраиваемый компонент текстового поля, который собираюсь использовать в своем приложении. Я делюсь кодом и могу ли мне помочь, как изменить цвет линии границы текстового поля на основе проверки текстового поля. Я буду использовать это текстовое поле для адреса электронной почты, пароля, суммы и т. Д.
код:
class MyInputWidget extends StatefulWidget {
final FocusNode focusNode;
final String hint;
final TextEditingController controller;
final VoidCallback onEditCompleted;
final show;
const MyInputWidget(
{@required this.focusNode,
@required this.hint,
@required this.controller,
@required this.show,
this.onEditCompleted})
: assert(focusNode != null),
assert(hint != null),
assert(controller != null),
assert(show != null);
@override
_MyInputWidgetState createState() => _MyInputWidgetState();
}
class _MyInputWidgetState extends State<MyInputWidget> {
TextEditingController _controller;
FocusNode _focusNode;
Color focusBorderColor;
_MyInputWidgetState();
@override
void initState() {
super.initState();
focusBorderColor = Colors.blue;
if (widget.controller != null)
_controller = widget.controller;
else
_controller = TextEditingController();
if (widget.focusNode != null)
_focusNode = widget.focusNode;
else
_focusNode = FocusNode();
_focusNode.addListener(() {});
}
void listener() {
if (_focusNode.hasFocus) {
print("focus");
} else {
print("nofocus");
}
}
@override
Widget build(BuildContext context) {
return Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Row(
children: <Widget>[
const SizedBox(
width: 1.0,
),
Expanded(
child: Stack(
alignment: const Alignment(1.0, 1.0),
children: <Widget>[
textField(),
if (widget.controller.text.isNotEmpty)
IconButton(
padding: const EdgeInsets.only(right: 3),
icon: const Icon(Icons.clear),
onPressed: () {
setState(() {
widget.controller.clear();
});
})
else
Container(
height: 0.0,
)
]),
),
],
),
],
);
}
@override
void dispose() {
super.dispose();
_controller?.dispose();
_focusNode?.dispose();
}
Widget textField() {
return TextField(
focusNode: _focusNode,
controller: _controller,
decoration: InputDecoration(
hintText: widget.hint,
focusedBorder: UnderlineInputBorder(
borderSide: BorderSide(color: focusBorderColor, width: 3),
),
enabledBorder: UnderlineInputBorder(
borderSide: BorderSide(color: focusBorderColor, width: 3),
),
),
onSubmitted: (item) {
FocusScope.of(context).requestFocus(FocusNode());
},
onEditingComplete: () {
//print(widget.show);
},
);
}
}
main.dart:
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
FocusNode emailFocusNode = FocusNode();
bool show = false;
final TextEditingController emailController = TextEditingController();
@override
void initState() {
// TODO: implement initState
super.initState();
emailNotifier();
}
emailNotifier() {
emailFocusNode.addListener(() {
if (!emailFocusNode.hasFocus) {
if (emailController.text.isNotEmpty) {
ValidationHelper().validateEmail(emailController.text).then((result) {
if (!result) {
show = true;
//print("Notifier false");
} else {
show = false;
// print("Notifier true");
}
setState(() {});
});
}
} else {
//print("Test field is empty");
}
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Padding(
padding: const EdgeInsets.symmetric(vertical: 8, horizontal: 35),
child: MyInputWidget(
focusNode: emailFocusNode,
hint: "Enter Email",
controller: emailController,
show: show,
onEditCompleted: () {
},
),
),
Visibility(child: AlertWidget(), visible: show)
],
),
),
);
}
}
class AlertWidget extends StatelessWidget {
const AlertWidget({
Key key,
}) : super(key: key);
@override
Widget build(BuildContext context) {
return Container(
child: Text("Alert"),
color: Colors.redAccent,
);
}
}
если проверка не удалась, значит, мне нужно изменить цвет линии границы текстового поля на красный, иначе цвет линии будет синим. Я попытался отправить логический статус, но не могу.