import 'package:dynamic_sdk/dynamic_sdk.dart';
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
class WalletsView extends StatelessWidget {
const WalletsView({super.key});
@override
Widget build(BuildContext context) {
return ChangeNotifierProvider(
create: (_) => WalletManager(),
child: Consumer<WalletManager>(
builder: (context, walletManager, _) {
if (walletManager.isCreatingWallets) {
return const Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
CircularProgressIndicator(),
SizedBox(height: 16),
Text('Creating wallets...'),
],
),
);
}
if (walletManager.creationTimedOut) {
return const Center(
child: Text('Wallet creation timed out. Please try again.'),
);
}
if (walletManager.wallets.isEmpty) {
return const Center(
child: Text('No wallets available'),
);
}
return ListView.builder(
itemCount: walletManager.wallets.length,
itemBuilder: (context, index) {
final wallet = walletManager.wallets[index];
return WalletCard(wallet: wallet);
},
);
},
),
);
}
}
class WalletCard extends StatelessWidget {
final BaseWallet wallet;
const WalletCard({super.key, required this.wallet});
@override
Widget build(BuildContext context) {
return Card(
margin: const EdgeInsets.symmetric(horizontal: 16, vertical: 8),
child: Padding(
padding: const EdgeInsets.all(16.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
wallet.walletName ?? 'Wallet',
style: Theme.of(context).textTheme.titleMedium,
),
Container(
padding: const EdgeInsets.symmetric(horizontal: 8, vertical: 4),
decoration: BoxDecoration(
color: Colors.blue.withOpacity(0.2),
borderRadius: BorderRadius.circular(4),
),
child: Text(
wallet.chain.toUpperCase(),
style: Theme.of(context).textTheme.labelSmall,
),
),
],
),
const SizedBox(height: 8),
Text(
wallet.address,
style: Theme.of(context).textTheme.bodyMedium?.copyWith(
color: Colors.grey[600],
),
overflow: TextOverflow.ellipsis,
),
],
),
),
);
}
}