diff --git a/integration_test/e2e_test.dart b/integration_test/e2e_test.dart index 37f6838..311b9a5 100644 --- a/integration_test/e2e_test.dart +++ b/integration_test/e2e_test.dart @@ -109,17 +109,17 @@ void testE2E(String description) { ); /// Add ND to shoot another scene - await tester.openPickerAndSelect('2'); - await _expectMeteringStateAndMeasure( - tester, - equipmentProfile: mockEquipmentProfiles[0], - film: mockFilms[0], - fastest: 'f/1.8 - 1/200', - slowest: 'f/16 - 1/2.5', - iso: '400', - nd: '2', - ev: mockPhotoEv100 + 2 - 1, - ); + // await tester.openPickerAndSelect('2'); + // await _expectMeteringStateAndMeasure( + // tester, + // equipmentProfile: mockEquipmentProfiles[0], + // film: mockFilms[0], + // fastest: 'f/1.8 - 1/200', + // slowest: 'f/16 - 1/2.5', + // iso: '400', + // nd: '2', + // ev: mockPhotoEv100 + 2 - 1, + // ); /// Select another lens without ND await tester.openPickerAndSelect(mockEquipmentProfiles[1].name); diff --git a/lib/screens/equipment_profile_edit/screen_equipment_profile_edit.dart b/lib/screens/equipment_profile_edit/screen_equipment_profile_edit.dart index 332bee6..ecc441d 100644 --- a/lib/screens/equipment_profile_edit/screen_equipment_profile_edit.dart +++ b/lib/screens/equipment_profile_edit/screen_equipment_profile_edit.dart @@ -137,6 +137,7 @@ class _NameFieldBuilder extends StatelessWidget { bottom: Dimens.paddingS / 2, ), child: LightmeterTextField( + autofocus: true, initialValue: state.name, maxLength: 48, hintText: S.of(context).name, diff --git a/lib/screens/shared/text_field/widget_text_field.dart b/lib/screens/shared/text_field/widget_text_field.dart index 5ffae94..40eeaa0 100644 --- a/lib/screens/shared/text_field/widget_text_field.dart +++ b/lib/screens/shared/text_field/widget_text_field.dart @@ -1,33 +1,74 @@ import 'package:flutter/material.dart'; +import 'package:flutter/services.dart'; -class LightmeterTextField extends TextFormField { - LightmeterTextField({ - super.controller, - super.autofocus, - super.initialValue, - super.inputFormatters, - super.maxLength, - super.onChanged, - super.style, - super.textAlign, - Widget? leading, - String? hintText, - }) : super( - autovalidateMode: AutovalidateMode.onUserInteraction, - maxLines: 1, - decoration: InputDecoration( - counter: const SizedBox(), - contentPadding: EdgeInsets.zero, - errorStyle: const TextStyle(fontSize: 0), - icon: leading, - hintText: hintText, - ), - validator: (value) { - if (value == null || value.isEmpty) { - return ''; - } else { - return null; - } - }, - ); +class LightmeterTextField extends StatefulWidget { + const LightmeterTextField({ + this.autofocus = false, + this.controller, + this.hintText, + this.initialValue, + this.inputFormatters, + this.leading, + this.maxLength, + this.onChanged, + this.style, + this.textAlign = TextAlign.start, + }); + + final bool autofocus; + final TextEditingController? controller; + final String? hintText; + final String? initialValue; + final List? inputFormatters; + final Widget? leading; + final int? maxLength; + final void Function(String)? onChanged; + final TextStyle? style; + final TextAlign textAlign; + + @override + State createState() => _LightmeterTextFieldState(); +} + +class _LightmeterTextFieldState extends State { + late final focusNode = FocusNode(debugLabel: widget.hintText); + + @override + Widget build(BuildContext context) { + return TextFormField( + autofocus: widget.autofocus, + autovalidateMode: AutovalidateMode.onUserInteraction, + controller: widget.controller, + focusNode: focusNode, + initialValue: widget.initialValue, + inputFormatters: widget.inputFormatters, + maxLength: widget.maxLength, + onChanged: widget.onChanged, + style: widget.style, + textAlign: widget.textAlign, + decoration: InputDecoration( + counter: const SizedBox(), + contentPadding: EdgeInsets.zero, + errorStyle: const TextStyle(fontSize: 0), + icon: widget.leading, + hintText: widget.hintText, + ), + onTapOutside: (event) { + focusNode.unfocus(); + }, + validator: (value) { + if (value == null || value.isEmpty) { + return ''; + } else { + return null; + } + }, + ); + } + + @override + void dispose() { + focusNode.dispose(); + super.dispose(); + } }