Moved the AccountName widgets to pull providers from context

This commit is contained in:
Arseni
2025-12-22 21:38:26 +03:00
parent 4073c8819c
commit d26ba84094
3 changed files with 32 additions and 36 deletions

View File

@@ -1,18 +1,16 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:pweb/providers/account_name.dart'; import 'package:pweb/providers/account_name.dart';
class AccountNameActions extends StatelessWidget { class AccountNameActions extends StatelessWidget {
const AccountNameActions({ const AccountNameActions({super.key});
super.key,
required this.state,
});
final AccountNameState state;
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
final state = context.watch<AccountNameState>();
final theme = Theme.of(context); final theme = Theme.of(context);
if (state.isEditing) { if (state.isEditing) {

View File

@@ -54,10 +54,10 @@ class _AccountNameBody extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
final state = context.watch<AccountNameState>();
final provider = context.watch<AccountProvider>();
final theme = Theme.of(context); final theme = Theme.of(context);
return Consumer2<AccountNameState, AccountProvider>(
builder: (context, state, provider, _) {
final currentName = provider.account?.name ?? state.initialName; final currentName = provider.account?.name ?? state.initialName;
state.syncName(currentName); state.syncName(currentName);
@@ -68,13 +68,12 @@ class _AccountNameBody extends StatelessWidget {
mainAxisAlignment: MainAxisAlignment.center, mainAxisAlignment: MainAxisAlignment.center,
children: [ children: [
AccountNameText( AccountNameText(
state: state,
hintText: hintText, hintText: hintText,
inputWidth: _AccountNameConstants.inputWidth, inputWidth: _AccountNameConstants.inputWidth,
borderWidth: _AccountNameConstants.borderWidth, borderWidth: _AccountNameConstants.borderWidth,
), ),
const SizedBox(width: _AccountNameConstants.spacing), const SizedBox(width: _AccountNameConstants.spacing),
AccountNameActions(state: state), const AccountNameActions(),
], ],
), ),
const SizedBox(height: _AccountNameConstants.errorSpacing), const SizedBox(height: _AccountNameConstants.errorSpacing),
@@ -87,7 +86,5 @@ class _AccountNameBody extends StatelessWidget {
), ),
], ],
); );
},
);
} }
} }

View File

@@ -1,24 +1,25 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:pweb/providers/account_name.dart'; import 'package:pweb/providers/account_name.dart';
class AccountNameText extends StatelessWidget { class AccountNameText extends StatelessWidget {
const AccountNameText({ const AccountNameText({
super.key, super.key,
required this.state,
required this.hintText, required this.hintText,
required this.inputWidth, required this.inputWidth,
required this.borderWidth, required this.borderWidth,
}); });
final AccountNameState state;
final String hintText; final String hintText;
final double inputWidth; final double inputWidth;
final double borderWidth; final double borderWidth;
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
final state = context.watch<AccountNameState>();
final theme = Theme.of(context); final theme = Theme.of(context);
if (state.isEditing) { if (state.isEditing) {