SDK Reference
flutter
getPortfolio

getPortfolio Method

This method is used to get all the token assets in the user's portfolio.

Parameters

None

Example

import 'package:my_app/okto.dart';
import 'package:flutter/material.dart';
import 'package:okto_flutter_sdk/okto_flutter_sdk.dart';
 
class UserPortfolioPage extends StatefulWidget {
  const UserPortfolioPage({super.key});
 
  @override
  State<UserPortfolioPage> createState() => _UserPortfolioPageState();
}
 
class _UserPortfolioPageState extends State<UserPortfolioPage> {
  Future<UserPortfolioResponse>? _userPortfolio;
 
  Future<UserPortfolioResponse> getuserPortfolio() async {
    try {
      final userPortfolio = await okto!.userPortfolio();
      return userPortfolio;
    } catch (e) {
      throw Exception(e);
    }
  }
 
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      backgroundColor: const Color(0xff5166EE),
      body: SafeArea(
        child: Column(
          children: [
            Container(
              alignment: Alignment.center,
              margin: const EdgeInsets.all(40),
              child: const Text(
                'User Portfolio',
                style: TextStyle(color: Colors.white, fontWeight: FontWeight.w800, fontSize: 30),
              ),
            ),
            ElevatedButton(
              onPressed: () {
                setState(() {
                  _userPortfolio = getuserPortfolio();
                });
              },
              child: const Text('User Portfolio'),
            ),
            Expanded(
              child: _userPortfolio == null
                  ? Container()
                  : FutureBuilder<UserPortfolioResponse>(
                      future: _userPortfolio,
                      builder: (context, snapshot) {
                        if (snapshot.connectionState == ConnectionState.waiting) {
                          return const Center(child: CircularProgressIndicator(color: Colors.white));
                        } else if (snapshot.hasError) {
                          return Center(child: Text('Error: ${snapshot.error}'));
                        } else if (snapshot.hasData) {
                          final userPortfolio = snapshot.data!;
                          return Padding(
                            padding: const EdgeInsets.all(20.0),
                            child: Column(
                              crossAxisAlignment: CrossAxisAlignment.start,
                              children: [
                                SizedBox(
                                  height: MediaQuery.sizeOf(context).height * 0.6,
                                  child: ListView.builder(
                                      itemCount: userPortfolio.data.tokens.length,
                                      itemBuilder: (context, index) {
                                        return Container(
                                          color: Colors.blue,
                                          margin: const EdgeInsets.all(5),
                                          child: Column(
                                            crossAxisAlignment: CrossAxisAlignment.start,
                                            children: [
                                              SelectableText(
                                                'Token Name: ${userPortfolio.data.tokens[index].tokenName}',
                                                style: const TextStyle(color: Colors.white, fontSize: 20),
                                              ),
                                              SelectableText(
                                                'Quantity : ${userPortfolio.data.tokens[index].quantity}',
                                                style: const TextStyle(color: Colors.white, fontSize: 20),
                                              ),
                                              SelectableText(
                                                'Amount In INR : ${userPortfolio.data.tokens[index].amountInInr}',
                                                style: const TextStyle(color: Colors.white, fontSize: 20),
                                              ),
                                              SelectableText(
                                                'Network Name: ${userPortfolio.data.tokens[index].networkName}',
                                                style: const TextStyle(color: Colors.white, fontSize: 20),
                                              ),
                                              SelectableText(
                                                'Token Address: ${userPortfolio.data.tokens[index].tokenAddress}',
                                                style: const TextStyle(color: Colors.white, fontSize: 20),
                                              ),
                                              SelectableText(
                                                'Token Image url: ${userPortfolio.data.tokens[index].tokenImage}',
                                                style: const TextStyle(color: Colors.white, fontSize: 20),
                                              ),
                                            ],
                                          ),
                                        );
                                      }),
                                )
 
                                // Add more fields here as needed
                              ],
                            ),
                          );
                        }
                        return Container();
                      },
                    ),
                  ),
                ],
              ),
            ),
          );
        }
      }
      

View in code (opens in a new tab)