From 86c653a090d9a26bca5ca7bd1bc2e761dd99e15d Mon Sep 17 00:00:00 2001 From: Hillel Coren Date: Sun, 13 Aug 2023 16:36:24 +0300 Subject: [PATCH] Documents --- lib/ui/document/edit/document_edit.dart | 51 ++++++++++++++----------- 1 file changed, 28 insertions(+), 23 deletions(-) diff --git a/lib/ui/document/edit/document_edit.dart b/lib/ui/document/edit/document_edit.dart index 59238716d..3f8aaaf82 100644 --- a/lib/ui/document/edit/document_edit.dart +++ b/lib/ui/document/edit/document_edit.dart @@ -4,6 +4,7 @@ import 'package:flutter/material.dart'; // Project imports: import 'package:invoiceninja_flutter/ui/app/edit_scaffold.dart'; import 'package:invoiceninja_flutter/ui/app/form_card.dart'; +import 'package:invoiceninja_flutter/ui/app/forms/decorated_form_field.dart'; import 'package:invoiceninja_flutter/ui/app/scrollable_listview.dart'; import 'package:invoiceninja_flutter/ui/document/edit/document_edit_vm.dart'; import 'package:invoiceninja_flutter/utils/completers.dart'; @@ -26,20 +27,20 @@ class _DocumentEditState extends State { GlobalKey(debugLabel: '_documentEdit'); final _debouncer = Debouncer(); - // STARTER: controllers - do not remove comment + final _nameController = TextEditingController(); List _controllers = []; @override void didChangeDependencies() { _controllers = [ - // STARTER: array - do not remove comment + _nameController, ]; _controllers.forEach((controller) => controller.removeListener(_onChanged)); - //final document = widget.viewModel.document; - // STARTER: read value - do not remove comment + final document = widget.viewModel.document; + _nameController.text = document.name; _controllers.forEach((controller) => controller.addListener(_onChanged)); @@ -57,9 +58,8 @@ class _DocumentEditState extends State { } void _onChanged() { - final document = widget.viewModel.document.rebuild((b) => b - // STARTER: set value - do not remove comment - ); + final document = widget.viewModel.document + .rebuild((b) => b..name = _nameController.text.trim()); if (document != widget.viewModel.document) { _debouncer.run(() { widget.viewModel.onChanged(document); @@ -67,6 +67,16 @@ class _DocumentEditState extends State { } } + void _onSavePressed() { + final bool isValid = _formKey.currentState.validate(); + + if (!isValid) { + return; + } + + widget.viewModel.onSavePressed(context); + } + @override Widget build(BuildContext context) { final viewModel = widget.viewModel; @@ -77,21 +87,7 @@ class _DocumentEditState extends State { entity: document, title: document.isNew ? localization.newDocument : localization.editDocument, - onSavePressed: (context) { - final bool isValid = _formKey.currentState.validate(); - - /* - setState(() { - autoValidate = !isValid ?? false; - }); - */ - - if (!isValid) { - return; - } - - viewModel.onSavePressed(context); - }, + onSavePressed: (_) => _onSavePressed(), body: Form( key: _formKey, child: Builder(builder: (BuildContext context) { @@ -99,7 +95,16 @@ class _DocumentEditState extends State { children: [ FormCard( children: [ - // STARTER: widgets - do not remove comment + DecoratedFormField( + autofocus: true, + label: localization.name, + keyboardType: TextInputType.text, + controller: _nameController, + onSavePressed: (_) => _onSavePressed(), + validator: (value) => value.trim().isEmpty + ? localization.pleaseEnterAName + : null, + ), ], ), ],