2022-08-26 08:11:35 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
|
|
|
import 'package:stackwallet/pages/add_wallet_views/add_wallet_view/add_wallet_view.dart';
|
|
|
|
import 'package:stackwallet/pages/wallets_view/sub_widgets/wallet_list_item.dart';
|
|
|
|
import 'package:stackwallet/providers/providers.dart';
|
|
|
|
import 'package:stackwallet/utilities/text_styles.dart';
|
2022-09-22 23:48:50 +00:00
|
|
|
import 'package:stackwallet/utilities/theme/stack_colors.dart';
|
2022-08-26 08:11:35 +00:00
|
|
|
import 'package:stackwallet/widgets/custom_buttons/blue_text_button.dart';
|
|
|
|
|
|
|
|
class AllWallets extends StatelessWidget {
|
|
|
|
const AllWallets({Key? key}) : super(key: key);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
debugPrint("BUILD: $runtimeType");
|
|
|
|
return Column(
|
|
|
|
children: [
|
|
|
|
Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
|
|
children: [
|
|
|
|
Text(
|
|
|
|
"All wallets",
|
2022-09-22 22:17:21 +00:00
|
|
|
style: STextStyles.itemSubtitle(context).copyWith(
|
2022-09-22 23:48:50 +00:00
|
|
|
color: Theme.of(context).extension<StackColors>()!.textDark,
|
2022-09-21 22:49:48 +00:00
|
|
|
),
|
2022-08-26 08:11:35 +00:00
|
|
|
),
|
|
|
|
BlueTextButton(
|
|
|
|
text: "Add new",
|
|
|
|
onTap: () {
|
|
|
|
Navigator.of(context).pushNamed(AddWalletView.routeName);
|
|
|
|
},
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
const SizedBox(
|
|
|
|
height: 10,
|
|
|
|
),
|
|
|
|
Expanded(
|
|
|
|
child: Consumer(
|
|
|
|
builder: (_, ref, __) {
|
|
|
|
final providersByCoin = ref.watch(walletsChangeNotifierProvider
|
|
|
|
.select((value) => value.getManagerProvidersByCoin()));
|
|
|
|
|
|
|
|
return ListView.builder(
|
|
|
|
itemCount: providersByCoin.length,
|
|
|
|
itemBuilder: (builderContext, index) {
|
|
|
|
final coin =
|
|
|
|
providersByCoin.keys.toList(growable: false)[index];
|
|
|
|
final int walletCount = providersByCoin[coin]!.length;
|
|
|
|
return Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: 4),
|
|
|
|
child: WalletListItem(
|
|
|
|
coin: coin,
|
|
|
|
walletCount: walletCount,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|