initial
This commit is contained in:
72
lib/utils/custom_text_form_field.dart
Normal file
72
lib/utils/custom_text_form_field.dart
Normal file
@@ -0,0 +1,72 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_hooks/flutter_hooks.dart';
|
||||
import 'package:hiddify/utils/text_utils.dart';
|
||||
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
||||
|
||||
class CustomTextFormField extends HookConsumerWidget {
|
||||
const CustomTextFormField({
|
||||
super.key,
|
||||
required this.onChanged,
|
||||
this.validator,
|
||||
this.controller,
|
||||
this.initialValue = '',
|
||||
this.suffixIcon,
|
||||
this.label,
|
||||
this.hint,
|
||||
this.maxLines = 1,
|
||||
this.isDense = false,
|
||||
this.autoValidate = false,
|
||||
this.autoCorrect = false,
|
||||
});
|
||||
|
||||
final ValueChanged<String> onChanged;
|
||||
final String? Function(String? value)? validator;
|
||||
final TextEditingController? controller;
|
||||
final String initialValue;
|
||||
final Widget? suffixIcon;
|
||||
final String? label;
|
||||
final String? hint;
|
||||
final int maxLines;
|
||||
final bool isDense;
|
||||
final bool autoValidate;
|
||||
final bool autoCorrect;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context, WidgetRef ref) {
|
||||
final textController =
|
||||
controller ?? useTextEditingController(text: initialValue);
|
||||
final effectiveConstraints =
|
||||
isDense ? const BoxConstraints(maxHeight: 56) : null;
|
||||
final effectiveBorder = isDense
|
||||
? OutlineInputBorder(
|
||||
borderRadius: BorderRadius.circular(36),
|
||||
borderSide: BorderSide.none,
|
||||
)
|
||||
: null;
|
||||
|
||||
return TextFormField(
|
||||
controller: textController,
|
||||
textCapitalization: TextCapitalization.sentences,
|
||||
maxLines: maxLines,
|
||||
onChanged: onChanged,
|
||||
textDirection: textController.textDirection,
|
||||
validator: validator,
|
||||
autovalidateMode:
|
||||
autoValidate ? AutovalidateMode.always : AutovalidateMode.disabled,
|
||||
autocorrect: autoCorrect,
|
||||
decoration: InputDecoration(
|
||||
isDense: true,
|
||||
label: label != null ? Text(label!) : null,
|
||||
hintText: hint,
|
||||
hintStyle: Theme.of(context).textTheme.bodySmall,
|
||||
constraints: effectiveConstraints,
|
||||
suffixIcon: suffixIcon,
|
||||
border: effectiveBorder,
|
||||
enabledBorder: effectiveBorder,
|
||||
errorBorder: effectiveBorder,
|
||||
focusedBorder: effectiveBorder,
|
||||
focusedErrorBorder: effectiveBorder,
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user