scgateway_flutter_plugin 2.0.0 scgateway_flutter_plugin: ^2.0.0 copied to clipboard
Scgateway Flutter plugin.
import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutter/services.dart';
import 'package:scgateway_flutter_plugin/scgateway_flutter_plugin.dart';
import 'package:scgateway_flutter_plugin_example/screens/connect_screen.dart';
import 'package:scgateway_flutter_plugin_example/screens/holdings_screen.dart';
import 'package:scgateway_flutter_plugin_example/screens/leadgen_screen.dart';
import 'package:scgateway_flutter_plugin_example/screens/smt_screen.dart';
import 'package:scgateway_flutter_plugin_example/screens/sst_screen.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false,
title: 'Smartinvesting Flutter Demo',
home: BottomNavigationBarController(),
// home: MyHomePage(),
);
}
}
class MyHomePage extends StatefulWidget {
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
int _currentIndex = 0;
@override
void initState() {
super.initState();
}
@override
Widget build(BuildContext context) {
PageController _pageController = PageController();
List<Widget> _screens = [ConnectScreen(), SstScreen(), SmtScreen(), HoldingsScreen(), LeadGenScreen()];
void _onPageChanged(int index) {
setState(() => _currentIndex = index);
}
void _onItemTapped(int selectedIndex) {
_pageController.jumpToPage(selectedIndex);
}
final colorScheme = Theme.of(context).colorScheme;
final textTheme = Theme.of(context).textTheme;
return Scaffold(
body: PageView(
controller: _pageController,
children: _screens,
onPageChanged: _onPageChanged,
physics: NeverScrollableScrollPhysics(),
),
bottomNavigationBar: BottomNavigationBar(
type: BottomNavigationBarType.shifting,
currentIndex: _currentIndex,
backgroundColor: colorScheme.surface,
selectedItemColor: colorScheme.onSurface,
unselectedItemColor: colorScheme.onSurface.withOpacity(.60),
selectedLabelStyle: textTheme.caption,
unselectedLabelStyle: textTheme.caption,
onTap: _onItemTapped,
items: [
BottomNavigationBarItem(
label: 'Connect',
icon: Icon(Icons.favorite),
),
BottomNavigationBarItem(
label: 'SST',
icon: Icon(Icons.music_note),
),
BottomNavigationBarItem(
label: 'SMT',
icon: Icon(Icons.library_books),
),
BottomNavigationBarItem(
label: 'Holdings',
icon: Icon(Icons.location_on),
),
BottomNavigationBarItem(
label: 'Lead Gen',
icon: Icon(Icons.library_books),
),
],
),
);
}
}
class BottomNavigationBarController extends StatefulWidget {
@override
_BottomNavigationBarControllerState createState() =>
_BottomNavigationBarControllerState();
}
class _BottomNavigationBarControllerState
extends State<BottomNavigationBarController> {
final List<Widget> pages = [
ConnectScreen(
key: PageStorageKey('Page1'),
),
SstScreen(
key: PageStorageKey('Page2'),
),
SmtScreen(
key: PageStorageKey('Page3'),
),
HoldingsScreen(
key: PageStorageKey('Page4'),
),
LeadGenScreen(
key: PageStorageKey('Page5'),
)
];
final PageStorageBucket bucket = PageStorageBucket();
int _selectedIndex = 0;
Widget _bottomNavigationBar(int selectedIndex) => BottomNavigationBar(
backgroundColor: Colors.black,
selectedItemColor: Colors.black,
unselectedItemColor: Colors.grey,
// selectedLabelStyle: textTheme.caption,
// unselectedLabelStyle: textTheme.caption,
onTap: (int index) => setState(() => _selectedIndex = index),
currentIndex: selectedIndex,
items: const <BottomNavigationBarItem>[
BottomNavigationBarItem(
label: 'Connect',
icon: Icon(Icons.favorite),
),
BottomNavigationBarItem(
label: 'SST',
icon: Icon(Icons.music_note),
),
BottomNavigationBarItem(
label: 'SMT',
icon: Icon(Icons.library_books),
),
BottomNavigationBarItem(
label: 'Holdings',
icon: Icon(Icons.location_on),
),
BottomNavigationBarItem(
label: 'Lead Gen',
icon: Icon(Icons.library_books),
),
],
);
@override
Widget build(BuildContext context) {
final colorScheme = Theme.of(context).colorScheme;
final textTheme = Theme.of(context).textTheme;
return Scaffold(
bottomNavigationBar: _bottomNavigationBar(_selectedIndex),
body: PageStorage(
child: pages[_selectedIndex],
bucket: bucket,
),
);
}
}