Skip to content
Snippets Groups Projects
Commit 6ec550e7 authored by poka's avatar poka
Browse files

refacto: contact screen

parent 00b81d53
Branches
Tags
No related merge requests found
Pipeline #18996 waiting for manual action
...@@ -2,24 +2,19 @@ import 'package:easy_localization/easy_localization.dart'; ...@@ -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 { ...@@ -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(),
]), ]),
), ),
......
...@@ -11,29 +11,30 @@ import 'package:gecko/providers/wallets_profiles.dart'; ...@@ -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
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment