refacto: contact screen

This commit is contained in:
poka 2023-03-15 18:31:55 +01:00
parent 00b81d530e
commit 6ec550e7ec
2 changed files with 8 additions and 14 deletions

View File

@ -2,24 +2,19 @@ import 'package:easy_localization/easy_localization.dart';
import 'package:gecko/globals.dart'; import 'package:gecko/globals.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:gecko/providers/duniter_indexer.dart';
import 'package:gecko/providers/wallets_profiles.dart';
import 'package:gecko/widgets/bottom_app_bar.dart'; import 'package:gecko/widgets/bottom_app_bar.dart';
import 'package:gecko/widgets/commons/offline_info.dart'; import 'package:gecko/widgets/commons/offline_info.dart';
import 'package:gecko/widgets/contacts_list.dart'; import 'package:gecko/widgets/contacts_list.dart';
import 'package:provider/provider.dart';
class ContactsScreen extends StatelessWidget { class ContactsScreen extends StatelessWidget {
const ContactsScreen({Key? key}) : super(key: key); const ContactsScreen({Key? key}) : super(key: key);
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
WalletsProfilesProvider walletsProfilesClass =
Provider.of<WalletsProfilesProvider>(context, listen: true);
final duniterIndexer = Provider.of<DuniterIndexer>(context, listen: false);
double avatarSize = 55; double avatarSize = 55;
final myContacts = contactsBox.toMap().values.toList(); final myContacts = contactsBox.toMap().values.toList();
// Order contacts by username
myContacts.sort((p1, p2) { myContacts.sort((p1, p2) {
return Comparable.compare(p1.username?.toLowerCase() ?? 'zz', return Comparable.compare(p1.username?.toLowerCase() ?? 'zz',
p2.username?.toLowerCase() ?? 'zz'); p2.username?.toLowerCase() ?? 'zz');
@ -41,9 +36,7 @@ class ContactsScreen extends StatelessWidget {
child: Stack(children: [ child: Stack(children: [
ContactsList( ContactsList(
myContacts: myContacts, myContacts: myContacts,
avatarSize: avatarSize, avatarSize: avatarSize),
walletsProfilesClass: walletsProfilesClass,
duniterIndexer: duniterIndexer),
const OfflineInfo(), const OfflineInfo(),
]), ]),
), ),

View File

@ -11,29 +11,30 @@ import 'package:gecko/providers/wallets_profiles.dart';
import 'package:gecko/screens/wallet_view.dart'; import 'package:gecko/screens/wallet_view.dart';
import 'package:gecko/widgets/balance.dart'; import 'package:gecko/widgets/balance.dart';
import 'package:gecko/widgets/name_by_address.dart'; import 'package:gecko/widgets/name_by_address.dart';
import 'package:provider/provider.dart';
class ContactsList extends StatelessWidget { class ContactsList extends StatelessWidget {
const ContactsList({ const ContactsList({
Key? key, Key? key,
required this.myContacts, required this.myContacts,
required this.avatarSize, required this.avatarSize,
required this.walletsProfilesClass,
required this.duniterIndexer,
}) : super(key: key); }) : super(key: key);
final List<G1WalletsList> myContacts; final List<G1WalletsList> myContacts;
final double avatarSize; final double avatarSize;
final WalletsProfilesProvider walletsProfilesClass;
final DuniterIndexer duniterIndexer;
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
final walletsProfilesClass =
Provider.of<WalletsProfilesProvider>(context, listen: true);
final duniterIndexer = Provider.of<DuniterIndexer>(context, listen: false);
return Padding( return Padding(
padding: const EdgeInsets.symmetric(horizontal: 20), padding: const EdgeInsets.symmetric(horizontal: 20),
child: Column( child: Column(
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[ children: <Widget>[
const SizedBox(height: 20), const SizedBox(height: 20, width: double.infinity),
if (myContacts.isEmpty) if (myContacts.isEmpty)
Text('noContacts'.tr()) Text('noContacts'.tr())
else else