как изменить цвет 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,
    );
  }
}

если проверка не удалась, значит, мне нужно изменить цвет линии границы текстового поля на красный, иначе цвет линии будет синим. Я попытался отправить логический статус, но не могу.

0 ответов

Другие вопросы по тегам