forked from zenon-network/syrius
/
input_field.dart
119 lines (115 loc) · 3.72 KB
/
input_field.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:zenon_syrius_wallet_flutter/utils/app_colors.dart';
import 'package:zenon_syrius_wallet_flutter/utils/constants.dart';
class InputField extends StatefulWidget {
final TextEditingController controller;
final FocusNode? thisNode;
final FocusNode? nextNode;
final String? hintText;
final bool enabled;
final List<TextInputFormatter>? inputFormatters;
final String? Function(String?)? validator;
final Widget? suffixIcon;
final BoxConstraints? suffixIconConstraints;
final double contentLeftPadding;
final Function(String)? onChanged;
final bool obscureText;
final String? errorText;
final int maxLines;
final Function(String)? onSubmitted;
final TextStyle inputtedTextStyle;
final InputBorder? enabledBorder;
final InputBorder? focusedBorder;
final InputBorder? disabledBorder;
final InputBorder? errorBorder;
final InputBorder? focusedErrorBorder;
const InputField({
required this.controller,
this.maxLines = 1,
this.thisNode,
this.hintText,
this.nextNode,
this.enabled = true,
this.inputFormatters,
this.validator,
this.suffixIcon,
this.suffixIconConstraints,
this.contentLeftPadding = kContentPadding,
this.onChanged,
this.obscureText = false,
this.errorText,
this.onSubmitted,
this.inputtedTextStyle = const TextStyle(
fontSize: 14.0,
color: AppColors.znnColor,
),
this.disabledBorder,
this.enabledBorder,
this.errorBorder,
this.focusedBorder,
this.focusedErrorBorder,
Key? key,
}) : super(key: key);
@override
State createState() {
return _InputFieldState();
}
}
class _InputFieldState extends State<InputField> {
@override
Widget build(BuildContext context) {
return TextFormField(
contextMenuBuilder: (context, editableTextState) {
return AdaptiveTextSelectionToolbar(
anchors: editableTextState.contextMenuAnchors,
children: editableTextState.contextMenuButtonItems
.map((ContextMenuButtonItem buttonItem) {
return Row(children: [
Expanded(
child: TextButton(
onPressed: buttonItem.onPressed,
style: TextButton.styleFrom(
shape: const RoundedRectangleBorder(),
),
child: Text(
AdaptiveTextSelectionToolbar.getButtonLabel(
context, buttonItem),
style: Theme.of(context).textTheme.bodyMedium),
))
]);
}).toList());
},
maxLines: widget.maxLines,
obscureText: widget.obscureText,
onChanged: widget.onChanged,
validator: widget.validator,
inputFormatters: widget.inputFormatters ?? [],
enabled: widget.enabled,
controller: widget.controller,
autofocus: false,
focusNode: widget.thisNode,
onFieldSubmitted: widget.onSubmitted,
style: widget.inputtedTextStyle,
decoration: InputDecoration(
enabledBorder: widget.enabledBorder,
disabledBorder: widget.disabledBorder,
focusedBorder: widget.focusedBorder,
errorBorder: widget.errorBorder,
focusedErrorBorder: widget.focusedBorder,
errorText: widget.errorText,
errorMaxLines: 2,
contentPadding: EdgeInsets.only(
left: widget.contentLeftPadding,
right: kContentPadding,
top: kContentPadding,
bottom: kContentPadding,
),
suffixIcon: widget.suffixIcon,
suffixIconConstraints: widget.suffixIconConstraints,
filled: true,
hintText: widget.hintText,
),
);
}
}