Moved the AccountName widgets to pull providers from context
This commit is contained in:
@@ -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) {
|
||||||
|
|||||||
@@ -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 {
|
|||||||
),
|
),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
},
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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) {
|
||||||
|
|||||||
Reference in New Issue
Block a user