Compare commits

..

No commits in common. "4d84f375b8112f6b2a6ca01a9c5cc191806f8546" and "ccefd5c2e4ab9a8f56506d39156e429705515817" have entirely different histories.

30 changed files with 289 additions and 308 deletions

View file

@ -26,16 +26,20 @@ apply plugin: 'kotlin-android'
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle" apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"
android { android {
compileSdkVersion 31 compileSdkVersion 29
sourceSets { sourceSets {
main.java.srcDirs += 'src/main/kotlin' main.java.srcDirs += 'src/main/kotlin'
} }
lintOptions {
disable 'InvalidPackage'
}
defaultConfig { defaultConfig {
// TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
applicationId "com.example.robo_advisory" applicationId "com.example.robo_advisory"
minSdkVersion 20 minSdkVersion 16
targetSdkVersion 29 targetSdkVersion 29
versionCode flutterVersionCode.toInteger() versionCode flutterVersionCode.toInteger()
versionName flutterVersionName versionName flutterVersionName

View file

@ -6,12 +6,11 @@
additional functionality it is fine to subclass or reimplement additional functionality it is fine to subclass or reimplement
FlutterApplication and put your custom class here. --> FlutterApplication and put your custom class here. -->
<application <application
android:name="${applicationName}" android:name="io.flutter.app.FlutterApplication"
android:label="robo_advisory" android:label="robo_advisory"
android:icon="@mipmap/ic_launcher"> android:icon="@mipmap/ic_launcher">
<activity <activity
android:name=".MainActivity" android:name=".MainActivity"
android:exported="true"
android:launchMode="singleTop" android:launchMode="singleTop"
android:theme="@style/LaunchTheme" android:theme="@style/LaunchTheme"
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode" android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"

View file

@ -1,12 +1,12 @@
buildscript { buildscript {
ext.kotlin_version = '1.7.10' ext.kotlin_version = '1.3.50'
repositories { repositories {
google() google()
mavenCentral() jcenter()
} }
dependencies { dependencies {
classpath 'com.android.tools.build:gradle:4.1.0' classpath 'com.android.tools.build:gradle:3.5.0'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
} }
} }
@ -14,7 +14,7 @@ buildscript {
allprojects { allprojects {
repositories { repositories {
google() google()
mavenCentral() jcenter()
} }
} }

View file

@ -3,4 +3,4 @@ distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-6.9-all.zip distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.2-all.zip

View file

@ -1,7 +1,7 @@
enum Flavor { MOCK, PRO } enum Flavor { MOCK, PRO }
class Injector { class Injector {
static late Flavor _flavor; static Flavor _flavor;
static void configure(Flavor flavor) { static void configure(Flavor flavor) {
_flavor = flavor; _flavor = flavor;

View file

@ -3,8 +3,8 @@ class Expenses {
String amount; String amount;
String percentage; String percentage;
Expenses({ Expenses({
required this.type, this.type,
required this.amount, this.amount,
required this.percentage, this.percentage,
}); });
} }

View file

@ -6,11 +6,11 @@ class HealthSteam {
String oneGramGoldPriceInLira; String oneGramGoldPriceInLira;
HealthSteam({ HealthSteam({
required this.type, this.type,
required this.valueInPercentage, this.valueInPercentage,
required this.goldInGram, this.goldInGram,
required this.goldPriceInTurkishLira, this.goldPriceInTurkishLira,
required this.oneGramGoldPriceInLira, this.oneGramGoldPriceInLira,
}); });
HealthSteam.fromJson(Map<dynamic, dynamic> map) HealthSteam.fromJson(Map<dynamic, dynamic> map)

View file

@ -1,8 +1,7 @@
class Category { class Category {
String name; String name;
String color; String color;
Category({this.name, this.color});
Category({required this.name, required this.color});
Category.formJson(Map<String, dynamic> map) Category.formJson(Map<String, dynamic> map)
: name = map["name"], : name = map["name"],
@ -17,11 +16,7 @@ class Transaction {
Category category; Category category;
Transaction( Transaction(
{required this.amount, {this.amount, this.description, this.date, this.name, this.category});
required this.description,
required this.date,
required this.name,
required this.category});
Transaction.fromJson(Map<String, dynamic> map) Transaction.fromJson(Map<String, dynamic> map)
: category = Category.formJson(map["category"]), : category = Category.formJson(map["category"]),

View file

@ -4,11 +4,5 @@ class User {
String email; String email;
String token; String token;
static final User noUser = User(userId: 0, name: '', email: '', token: ''); User({this.userId, this.name, this.email, this.token});
User(
{required this.userId,
required this.name,
required this.email,
required this.token});
} }

View file

@ -11,16 +11,14 @@ class Wallet {
List<HealthSteam> healthStreams; List<HealthSteam> healthStreams;
List<Expenses> expensesChart; List<Expenses> expensesChart;
static final Wallet emptyWallet = Wallet._empty();
Wallet({ Wallet({
required this.totalAssets, this.totalAssets,
required this.totalTurkishLiraPool, this.totalTurkishLiraPool,
required this.totalGoldInGram, this.totalGoldInGram,
required this.totalGoldInTurkishLira, this.totalGoldInTurkishLira,
required this.healthSteamDay, this.healthSteamDay,
required this.healthStreams, this.healthStreams,
required this.expensesChart, this.expensesChart,
}); });
Wallet.fromMap(Map<String, dynamic> map) Wallet.fromMap(Map<String, dynamic> map)
@ -31,15 +29,5 @@ class Wallet {
healthSteamDay = map["health_stream_day"], healthSteamDay = map["health_stream_day"],
healthStreams = (map["health_stream"] as List) healthStreams = (map["health_stream"] as List)
.map((i) => HealthSteam.fromJson(i)) .map((i) => HealthSteam.fromJson(i))
.toList(), .toList();
expensesChart = [];
Wallet._empty():
totalAssets = '',
totalTurkishLiraPool = '',
totalGoldInGram = '',
totalGoldInTurkishLira = '',
healthSteamDay = '',
healthStreams = [],
expensesChart = [];
} }

View file

@ -18,7 +18,7 @@ class AuthProvider with ChangeNotifier {
Status get loggedInStatus => _loggedInStatus; Status get loggedInStatus => _loggedInStatus;
Status get registeredInStatus => _registeredInStatus; Status get registeredInStatus => _registeredInStatus;
Future login(String email, int pinCode) async { Future<Map<String, dynamic>> login(String email, int pinCode) async {
var result; var result;
final Map<String, dynamic> loginData = { final Map<String, dynamic> loginData = {

View file

@ -3,28 +3,32 @@ import 'package:robo_advisory/models/transaction.dart';
import 'package:robo_advisory/repository/transaction.repository.dart'; import 'package:robo_advisory/repository/transaction.repository.dart';
class TransactionProvider with ChangeNotifier { class TransactionProvider with ChangeNotifier {
String? _selectedCategory; String _selectedCategory = "All";
List<Transaction> _transactionsData = []; List<Transaction> _transactionsData;
List<Transaction> _transactionsList;
List<Transaction> get transactionList { List<Transaction> get transactionList {
if (_selectedCategory == null) { if (_selectedCategory != 'All') {
return _transactionsData; return _transactionsList = _transactionsData
.where((transaction) =>
transaction.category.name == _selectedCategory.toLowerCase())
.toList();
} else {
return _transactionsList = _transactionsData;
} }
return _transactionsData
.where((transaction) =>
transaction.category.name == _selectedCategory?.toLowerCase())
.toList();
} }
void setTransactionsList(List<Transaction> transactions) { void setTransactionsList(List<Transaction> transactions) {
_transactionsData = transactions; _transactionsData = transactions;
_transactionsList = transactions;
notifyListeners(); notifyListeners();
} }
String? get selectedCategory => _selectedCategory; String get selectedCategory => _selectedCategory;
void setSelectedCategory(String? category) { void setSelectedCategory(String category) {
_selectedCategory = category; _selectedCategory = category;
print(_selectedCategory);
notifyListeners(); notifyListeners();
} }

View file

@ -2,10 +2,10 @@ import 'package:flutter/foundation.dart';
import 'package:robo_advisory/models/user.dart'; import 'package:robo_advisory/models/user.dart';
class UserProvider with ChangeNotifier { class UserProvider with ChangeNotifier {
User _user = User.noUser; User _user = new User();
int _selectedTabIndex = 0; int _selectedTabIndex = 0;
List<String> _categories = ["Workplace", "Equipment", "Home", "Other"]; List<String> _categories = ["All", "Workplace", "Equipment", "Home", "Other"];
List<String> get categories => _categories; List<String> get categories => _categories;

View file

@ -3,7 +3,7 @@ import 'package:robo_advisory/models/wallet.dart';
import 'package:robo_advisory/repository/wallet.repository.dart'; import 'package:robo_advisory/repository/wallet.repository.dart';
class WalletProvider with ChangeNotifier { class WalletProvider with ChangeNotifier {
Wallet _wallet = Wallet.emptyWallet; Wallet _wallet = new Wallet();
Wallet get wallet => _wallet; Wallet get wallet => _wallet;

View file

@ -17,7 +17,7 @@ class _DashboardScreenState extends State<DashboardScreen> {
final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>(); final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
void _openEndDrawer() { void _openEndDrawer() {
_scaffoldKey.currentState?.openEndDrawer(); _scaffoldKey.currentState.openEndDrawer();
} }
@override @override

View file

@ -3,7 +3,7 @@ import 'package:robo_advisory/theme/icons.dart';
import 'package:flutter_svg/flutter_svg.dart'; import 'package:flutter_svg/flutter_svg.dart';
class BottomNavigation extends StatelessWidget { class BottomNavigation extends StatelessWidget {
BottomNavigation({required this.selectedIndex, required this.onItemTapped}); BottomNavigation({@required this.selectedIndex, @required this.onItemTapped});
final int selectedIndex; final int selectedIndex;
final Function onItemTapped; final Function onItemTapped;
@override @override
@ -48,7 +48,7 @@ class BottomNavigation extends StatelessWidget {
showSelectedLabels: false, showSelectedLabels: false,
showUnselectedLabels: false, showUnselectedLabels: false,
currentIndex: selectedIndex, currentIndex: selectedIndex,
onTap: (v) => onItemTapped(v), onTap: onItemTapped,
); );
} }
} }

View file

@ -17,20 +17,24 @@ class HistoryScreen extends StatefulWidget {
class _HistoryScreenState extends State<HistoryScreen> { class _HistoryScreenState extends State<HistoryScreen> {
bool loadingData = true; bool loadingData = true;
List<Transaction> transactionData = []; List<Transaction> transactionData;
void initState() { void initState() {
TransactionProvider transactionProvider = TransactionProvider transactionProvider =
Provider.of<TransactionProvider>(context, listen: false); Provider.of<TransactionProvider>(context, listen: false);
transactionProvider.loadTransactions().then((value) { transactionProvider.loadTransactions().then((value) {
Timer(Duration(seconds: 3), () { if (value != null) {
setState(() { Timer(Duration(seconds: 3), () {
loadingData = false; setState(() {
transactionData = value; loadingData = false;
Provider.of<TransactionProvider>(context, listen: false) transactionData = value;
.setTransactionsList(transactionData); Provider.of<TransactionProvider>(context, listen: false)
.setTransactionsList(transactionData);
});
}); });
}); }
print(value);
}); });
super.initState(); super.initState();
} }
@ -57,25 +61,19 @@ class _HistoryScreenState extends State<HistoryScreen> {
children: [ children: [
DropdownButton<String>( DropdownButton<String>(
isExpanded: true, isExpanded: true,
items: [ items: Provider.of<UserProvider>(context, listen: true)
DropdownMenuItem<String>( .categories
value: null, .map((String value) {
child: Text('All'), return DropdownMenuItem<String>(
), value: value,
...Provider.of<UserProvider>(context, listen: true) child: Text(value),
.categories );
.map((String value) { }).toList(),
return DropdownMenuItem<String>(
value: value,
child: Text(value),
);
})
],
hint: new Text("Select Category"), hint: new Text("Select Category"),
value: Provider.of<TransactionProvider>(context, value: Provider.of<TransactionProvider>(context,
listen: true) listen: true)
.selectedCategory, .selectedCategory,
onChanged: (String? newValue) { onChanged: (String newValue) {
Provider.of<TransactionProvider>(context, Provider.of<TransactionProvider>(context,
listen: false) listen: false)
.setSelectedCategory(newValue); .setSelectedCategory(newValue);

View file

@ -4,9 +4,7 @@ import 'package:robo_advisory/utils/helpers.dart';
class TransactionListTile extends StatelessWidget { class TransactionListTile extends StatelessWidget {
final Transaction transactionObject; final Transaction transactionObject;
TransactionListTile({this.transactionObject});
TransactionListTile({required this.transactionObject});
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Column( return Column(

View file

@ -12,7 +12,7 @@ import 'package:robo_advisory/screens/home/local_widgets/expenses_chart.dart';
import 'dart:async'; import 'dart:async';
class HomeScreen extends StatefulWidget { class HomeScreen extends StatefulWidget {
HomeScreen({required this.toggleDrawer}); HomeScreen({@required this.toggleDrawer});
final Function toggleDrawer; final Function toggleDrawer;
@override @override
_HomeScreenState createState() => _HomeScreenState(); _HomeScreenState createState() => _HomeScreenState();
@ -20,13 +20,13 @@ class HomeScreen extends StatefulWidget {
class _HomeScreenState extends State<HomeScreen> { class _HomeScreenState extends State<HomeScreen> {
bool loadingData = true; bool loadingData = true;
Wallet walletData = Wallet.emptyWallet; Wallet walletData;
void initState() { void initState() {
WalletProvider walletProvider = WalletProvider walletProvider =
Provider.of<WalletProvider>(context, listen: false); Provider.of<WalletProvider>(context, listen: false);
walletProvider.loadWallet().then((value) { walletProvider.loadWallet().then((value) {
if (value.totalAssets.isNotEmpty) { if (value.totalAssets != null) {
Timer(Duration(seconds: 3), () { Timer(Duration(seconds: 3), () {
setState(() { setState(() {
loadingData = false; loadingData = false;
@ -70,7 +70,7 @@ class _HomeScreenState extends State<HomeScreen> {
), ),
), ),
GestureDetector( GestureDetector(
onTap: () => widget.toggleDrawer(), onTap: widget.toggleDrawer,
child: Icon(Icons.more_vert), child: Icon(Icons.more_vert),
), ),
], ],
@ -247,7 +247,7 @@ class _HomeScreenState extends State<HomeScreen> {
SizedBox( SizedBox(
height: 20.0, height: 20.0,
), ),
Container(height: 200, width: 200, child: ExpensesChart()) ExpensesChart()
], ],
) )
], ],

View file

@ -10,15 +10,7 @@ class ExpensesChart extends StatefulWidget {
} }
class ExpensesChartState extends State { class ExpensesChartState extends State {
int? touchedIndex; int touchedIndex;
bool disposed = false;
@override
void dispose() {
disposed = true;
super.dispose();
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
@ -29,23 +21,18 @@ class ExpensesChartState extends State {
Expanded( Expanded(
child: PieChart( child: PieChart(
PieChartData( PieChartData(
pieTouchData: pieTouchData: PieTouchData(touchCallback: (pieTouchResponse) {
PieTouchData(touchCallback: (event, pieTouchResponse) {
if (pieTouchResponse == null) return;
if (disposed) return;
setState(() { setState(() {
if (event is FlLongPressEnd || event is FlPanEndEvent) { if (pieTouchResponse.touchInput is FlLongPressEnd ||
pieTouchResponse.touchInput is FlPanEnd) {
touchedIndex = -1; touchedIndex = -1;
} else { } else {
touchedIndex = touchedIndex = pieTouchResponse.touchedSectionIndex;
pieTouchResponse.touchedSection?.touchedSectionIndex;
if (touchedIndex != null) { if (touchedIndex != null) {
Provider.of<UserProvider>(context, listen: false) Provider.of<UserProvider>(context, listen: false)
.setSelectedTabIndex(3); .setSelectedTabIndex(3);
Provider.of<TransactionProvider>(context, listen: false) Provider.of<TransactionProvider>(context, listen: false)
.setSelectedCategory(categories[touchedIndex! + 1]); .setSelectedCategory(categories[touchedIndex + 1]);
} }
} }
}); });
@ -63,31 +50,58 @@ class ExpensesChartState extends State {
} }
List<PieChartSectionData> showingSections() { List<PieChartSectionData> showingSections() {
final colorsDict = [0xff0293ee, 0xfff8b250, 0xff13d38e, 0xff845bef]; return List.generate(4, (i) {
final values = [50.0, 12.0, 13.0, 25.0]; final isTouched = i == touchedIndex;
final double fontSize = isTouched ? 25 : 16;
return values final double radius = isTouched ? 60 : 50;
.asMap() switch (i) {
.entries case 0:
.map((entry) => _pieChartSectionData( return PieChartSectionData(
colorsDict[entry.key], entry.value, touchedIndex == entry.key)) color: const Color(0xff0293ee),
.toList(); value: 50,
} title: '50%',
radius: radius,
PieChartSectionData _pieChartSectionData( titleStyle: TextStyle(
int color, double value, bool isTouched) { fontSize: fontSize,
final double fontSize = isTouched ? 25 : 16; fontWeight: FontWeight.bold,
final double radius = isTouched ? 60 : 50; color: const Color(0xffffffff)),
);
return PieChartSectionData( case 1:
color: Color(color), return PieChartSectionData(
value: value, color: const Color(0xfff8b250),
title: value.toString() + '%', value: 12,
radius: radius, title: '12%',
titleStyle: TextStyle( radius: radius,
fontSize: fontSize, titleStyle: TextStyle(
fontWeight: FontWeight.bold, fontSize: fontSize,
color: const Color(0xffffffff)), fontWeight: FontWeight.bold,
); color: const Color(0xffffffff)),
);
case 2:
return PieChartSectionData(
color: const Color(0xff13d38e),
value: 13,
title: '13%',
radius: radius,
titleStyle: TextStyle(
fontSize: fontSize,
fontWeight: FontWeight.bold,
color: const Color(0xffffffff)),
);
case 3:
return PieChartSectionData(
color: const Color(0xff845bef),
value: 25,
title: '25%',
radius: radius,
titleStyle: TextStyle(
fontSize: fontSize,
fontWeight: FontWeight.bold,
color: const Color(0xffffffff)),
);
default:
return null;
}
});
} }
} }

View file

@ -4,7 +4,7 @@ import 'package:google_fonts/google_fonts.dart';
import 'package:flutter_custom_dialog/flutter_custom_dialog.dart'; import 'package:flutter_custom_dialog/flutter_custom_dialog.dart';
class FinancialHealthStream extends StatelessWidget { class FinancialHealthStream extends StatelessWidget {
FinancialHealthStream({required this.healthSteams}); FinancialHealthStream({@required this.healthSteams});
final List<HealthSteam> healthSteams; final List<HealthSteam> healthSteams;
double calculatePercentage(double fullWidth, int percentValue) { double calculatePercentage(double fullWidth, int percentValue) {

View file

@ -2,7 +2,6 @@ import 'package:flutter/material.dart';
import 'package:pin_code_fields/pin_code_fields.dart'; import 'package:pin_code_fields/pin_code_fields.dart';
import 'package:robo_advisory/utils/constants.dart'; import 'package:robo_advisory/utils/constants.dart';
import 'package:robo_advisory/config/Routes.dart'; import 'package:robo_advisory/config/Routes.dart';
import 'package:robo_advisory/widgets/buttons.dart';
class LoginScreen extends StatelessWidget { class LoginScreen extends StatelessWidget {
bool rememberSwitch = false; bool rememberSwitch = false;
@ -22,7 +21,9 @@ class LoginScreen extends StatelessWidget {
Expanded( Expanded(
child: Container( child: Container(
child: Center( child: Center(
child: ElevatedButton( child: FlatButton(
splashColor: Colors.transparent,
highlightColor: Colors.transparent,
onPressed: () { onPressed: () {
Navigator.pushNamed(context, Routes.register); Navigator.pushNamed(context, Routes.register);
}, },
@ -75,7 +76,6 @@ class LoginScreen extends StatelessWidget {
Padding( Padding(
padding: EdgeInsets.only(left: 10.0, right: 10.0), padding: EdgeInsets.only(left: 10.0, right: 10.0),
child: PinCodeTextField( child: PinCodeTextField(
appContext: context,
length: 5, length: 5,
cursorColor: Colors.black, cursorColor: Colors.black,
animationType: AnimationType.fade, animationType: AnimationType.fade,
@ -109,7 +109,9 @@ class LoginScreen extends StatelessWidget {
// activeTrackColor: Colors.white, // activeTrackColor: Colors.white,
// activeColor: Colors.white, // activeColor: Colors.white,
), ),
TextButton( FlatButton(
splashColor: Colors.transparent,
highlightColor: Colors.transparent,
onPressed: () { onPressed: () {
Navigator.pushNamed( Navigator.pushNamed(
context, Routes.splashScreen); context, Routes.splashScreen);
@ -123,12 +125,17 @@ class LoginScreen extends StatelessWidget {
), ),
SizedBox( SizedBox(
width: double.infinity, width: double.infinity,
child: ElevatedButton( child: RaisedButton(
style: mainButtonStyle(), color: Color(0xFF495057),
textColor: Colors.white,
onPressed: () { onPressed: () {
Navigator.pushNamed(context, Routes.dashboard); Navigator.pushNamed(context, Routes.dashboard);
}, },
child: Text('Log In'), child: Text('Log In'),
padding: EdgeInsets.all(18.0),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(18.0),
),
), ),
) )
], ],

View file

@ -2,7 +2,6 @@ import 'package:flutter/material.dart';
import 'package:pin_code_fields/pin_code_fields.dart'; import 'package:pin_code_fields/pin_code_fields.dart';
import 'package:robo_advisory/utils/constants.dart'; import 'package:robo_advisory/utils/constants.dart';
import 'package:robo_advisory/screens/register/register_step_2.dart'; import 'package:robo_advisory/screens/register/register_step_2.dart';
import 'package:robo_advisory/widgets/buttons.dart';
class RegisterFirstScreen extends StatelessWidget { class RegisterFirstScreen extends StatelessWidget {
@override @override
@ -45,7 +44,6 @@ class RegisterFirstScreen extends StatelessWidget {
Padding( Padding(
padding: EdgeInsets.only(left: 10.0, right: 10.0), padding: EdgeInsets.only(left: 10.0, right: 10.0),
child: PinCodeTextField( child: PinCodeTextField(
appContext: context,
length: 5, length: 5,
cursorColor: Colors.black, cursorColor: Colors.black,
backgroundColor: Colors.white, backgroundColor: Colors.white,
@ -77,7 +75,6 @@ class RegisterFirstScreen extends StatelessWidget {
scale: 0.8, scale: 0.8,
child: Switch( child: Switch(
value: false, value: false,
onChanged: (_) {},
), ),
), ),
Text('Remember me') Text('Remember me')
@ -90,8 +87,9 @@ class RegisterFirstScreen extends StatelessWidget {
), ),
SizedBox( SizedBox(
width: double.infinity, width: double.infinity,
child: ElevatedButton( child: RaisedButton(
style: mainButtonStyle(), color: Color(0xFF495057),
textColor: Colors.white,
onPressed: () { onPressed: () {
Navigator.push( Navigator.push(
context, context,
@ -103,6 +101,10 @@ class RegisterFirstScreen extends StatelessWidget {
); );
}, },
child: Text('Continue'), child: Text('Continue'),
padding: EdgeInsets.all(18.0),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(18.0),
),
), ),
) )
], ],

View file

@ -1,7 +1,6 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:robo_advisory/utils/constants.dart'; import 'package:robo_advisory/utils/constants.dart';
import 'package:robo_advisory/config/Routes.dart'; import 'package:robo_advisory/config/Routes.dart';
import 'package:robo_advisory/widgets/buttons.dart';
class RegisterSecondScreen extends StatelessWidget { class RegisterSecondScreen extends StatelessWidget {
@override @override
@ -57,13 +56,18 @@ class RegisterSecondScreen extends StatelessWidget {
), ),
SizedBox( SizedBox(
width: double.infinity, width: double.infinity,
child: ElevatedButton( child: RaisedButton(
style: mainButtonStyle(), color: Color(0xFF495057),
textColor: Colors.white,
onPressed: () { onPressed: () {
Navigator.pushNamed(context, Routes.dashboard); Navigator.pushNamed(context, Routes.dashboard);
print('Next Step'); print('Next Step');
}, },
child: Text('Register'), child: Text('Register'),
padding: EdgeInsets.all(18.0),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(18.0),
),
), ),
) )
], ],

View file

@ -14,7 +14,7 @@ final otpPinTheme = PinTheme(
fieldWidth: 50, fieldWidth: 50,
); );
InputDecoration roboInputDecoration({String? placeholderHint}) { InputDecoration roboInputDecoration({String placeholderHint}) {
return InputDecoration( return InputDecoration(
filled: true, filled: true,
fillColor: Colors.white, fillColor: Colors.white,

View file

@ -1,30 +1,30 @@
// import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
//
// class SizeConfig { class SizeConfig {
// static MediaQueryData _mediaQueryData; static MediaQueryData _mediaQueryData;
// static double screenWidth; static double screenWidth;
// static double screenHeight; static double screenHeight;
// static double defaultSize; static double defaultSize;
// static Orientation orientation; static Orientation orientation;
//
// void init(BuildContext context) { void init(BuildContext context) {
// _mediaQueryData = MediaQuery.of(context); _mediaQueryData = MediaQuery.of(context);
// screenWidth = _mediaQueryData.size.width; screenWidth = _mediaQueryData.size.width;
// screenHeight = _mediaQueryData.size.height; screenHeight = _mediaQueryData.size.height;
// orientation = _mediaQueryData.orientation; orientation = _mediaQueryData.orientation;
// } }
// } }
//
// // Get the proportionate height as per screen size // Get the proportionate height as per screen size
// double getProportionateScreenHeight(double inputHeight) { double getProportionateScreenHeight(double inputHeight) {
// double screenHeight = SizeConfig.screenHeight; double screenHeight = SizeConfig.screenHeight;
// // 812 is the layout height that designer use // 812 is the layout height that designer use
// return (inputHeight / 812.0) * screenHeight; return (inputHeight / 812.0) * screenHeight;
// } }
//
// // Get the proportionate height as per screen size // Get the proportionate height as per screen size
// double getProportionateScreenWidth(double inputWidth) { double getProportionateScreenWidth(double inputWidth) {
// double screenWidth = SizeConfig.screenWidth; double screenWidth = SizeConfig.screenWidth;
// // 375 is the layout width that designer use // 375 is the layout width that designer use
// return (inputWidth / 375.0) * screenWidth; return (inputWidth / 375.0) * screenWidth;
// } }

View file

@ -1,11 +0,0 @@
import 'package:flutter/material.dart';
mainButtonStyle() {
return ElevatedButton.styleFrom(
backgroundColor: Color(0xFF495057),
foregroundColor: Colors.white,
padding: EdgeInsets.all(18.0),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(18.0),
));
}

View file

@ -46,7 +46,6 @@ class AppDrawer extends StatelessWidget {
_createDrawerItem( _createDrawerItem(
icon: accountIcon, icon: accountIcon,
text: 'Account', text: 'Account',
onTap: () {},
), ),
_createDrawerItem( _createDrawerItem(
icon: logoutIcon, icon: logoutIcon,
@ -126,7 +125,7 @@ class AppDrawer extends StatelessWidget {
} }
Widget _createDrawerItem( Widget _createDrawerItem(
{required String icon, required String text, required GestureTapCallback onTap}) { {String icon, String text, GestureTapCallback onTap}) {
return ListTile( return ListTile(
title: Row( title: Row(
children: <Widget>[ children: <Widget>[

View file

@ -7,84 +7,98 @@ packages:
name: async name: async
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.9.0" version: "2.5.0-nullsafety.1"
boolean_selector: boolean_selector:
dependency: transitive dependency: transitive
description: description:
name: boolean_selector name: boolean_selector
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.0" version: "2.1.0-nullsafety.1"
characters: characters:
dependency: transitive dependency: transitive
description: description:
name: characters name: characters
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.2.1" version: "1.1.0-nullsafety.3"
charcode:
dependency: transitive
description:
name: charcode
url: "https://pub.dartlang.org"
source: hosted
version: "1.2.0-nullsafety.1"
clock: clock:
dependency: transitive dependency: transitive
description: description:
name: clock name: clock
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.1.1" version: "1.1.0-nullsafety.1"
collection: collection:
dependency: transitive dependency: transitive
description: description:
name: collection name: collection
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.16.0" version: "1.15.0-nullsafety.3"
convert:
dependency: transitive
description:
name: convert
url: "https://pub.dartlang.org"
source: hosted
version: "2.1.1"
crypto: crypto:
dependency: transitive dependency: transitive
description: description:
name: crypto name: crypto
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "3.0.2" version: "2.1.5"
cupertino_icons: cupertino_icons:
dependency: "direct main" dependency: "direct main"
description: description:
name: cupertino_icons name: cupertino_icons
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.0.5" version: "1.0.0"
equatable: equatable:
dependency: transitive dependency: transitive
description: description:
name: equatable name: equatable
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.0.5" version: "1.2.5"
fake_async: fake_async:
dependency: transitive dependency: transitive
description: description:
name: fake_async name: fake_async
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.3.1" version: "1.2.0-nullsafety.1"
ffi: ffi:
dependency: transitive dependency: transitive
description: description:
name: ffi name: ffi
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.2.1" version: "0.1.3"
file: file:
dependency: transitive dependency: transitive
description: description:
name: file name: file
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "6.1.4" version: "5.2.1"
fl_chart: fl_chart:
dependency: "direct main" dependency: "direct main"
description: description:
name: fl_chart name: fl_chart
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "0.55.1" version: "0.12.0"
flutter: flutter:
dependency: "direct main" dependency: "direct main"
description: flutter description: flutter
@ -96,21 +110,21 @@ packages:
name: flutter_custom_dialog name: flutter_custom_dialog
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.3.0" version: "1.0.20"
flutter_spinkit: flutter_spinkit:
dependency: "direct main" dependency: "direct main"
description: description:
name: flutter_spinkit name: flutter_spinkit
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "5.1.0" version: "4.1.2+1"
flutter_svg: flutter_svg:
dependency: "direct main" dependency: "direct main"
description: description:
name: flutter_svg name: flutter_svg
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.1.5" version: "0.19.1"
flutter_test: flutter_test:
dependency: "direct dev" dependency: "direct dev"
description: flutter description: flutter
@ -127,224 +141,196 @@ packages:
name: google_fonts name: google_fonts
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "3.0.1" version: "1.1.1"
http: http:
dependency: "direct main" dependency: "direct main"
description: description:
name: http name: http
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "0.13.5" version: "0.12.2"
http_parser: http_parser:
dependency: transitive dependency: transitive
description: description:
name: http_parser name: http_parser
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "4.0.1" version: "3.1.4"
js: intl:
dependency: transitive dependency: transitive
description: description:
name: js name: intl
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "0.6.4" version: "0.16.1"
matcher: matcher:
dependency: transitive dependency: transitive
description: description:
name: matcher name: matcher
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "0.12.12" version: "0.12.10-nullsafety.1"
material_color_utilities:
dependency: transitive
description:
name: material_color_utilities
url: "https://pub.dartlang.org"
source: hosted
version: "0.1.5"
meta: meta:
dependency: transitive dependency: transitive
description: description:
name: meta name: meta
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.8.0" version: "1.3.0-nullsafety.3"
nested: nested:
dependency: transitive dependency: transitive
description: description:
name: nested name: nested
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.0.0" version: "0.0.4"
path: path:
dependency: transitive dependency: transitive
description: description:
name: path name: path
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.8.2" version: "1.8.0-nullsafety.1"
path_drawing: path_drawing:
dependency: transitive dependency: transitive
description: description:
name: path_drawing name: path_drawing
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.0.1" version: "0.4.1+1"
path_parsing: path_parsing:
dependency: transitive dependency: transitive
description: description:
name: path_parsing name: path_parsing
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.0.1" version: "0.1.4"
path_provider: path_provider:
dependency: transitive dependency: transitive
description: description:
name: path_provider name: path_provider
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.0.11" version: "1.6.24"
path_provider_android:
dependency: transitive
description:
name: path_provider_android
url: "https://pub.dartlang.org"
source: hosted
version: "2.0.20"
path_provider_ios:
dependency: transitive
description:
name: path_provider_ios
url: "https://pub.dartlang.org"
source: hosted
version: "2.0.11"
path_provider_linux: path_provider_linux:
dependency: transitive dependency: transitive
description: description:
name: path_provider_linux name: path_provider_linux
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.7" version: "0.0.1+2"
path_provider_macos: path_provider_macos:
dependency: transitive dependency: transitive
description: description:
name: path_provider_macos name: path_provider_macos
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.0.6" version: "0.0.4+6"
path_provider_platform_interface: path_provider_platform_interface:
dependency: transitive dependency: transitive
description: description:
name: path_provider_platform_interface name: path_provider_platform_interface
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.0.4" version: "1.0.4"
path_provider_windows: path_provider_windows:
dependency: transitive dependency: transitive
description: description:
name: path_provider_windows name: path_provider_windows
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.0.7" version: "0.0.4+3"
pedantic:
dependency: transitive
description:
name: pedantic
url: "https://pub.dartlang.org"
source: hosted
version: "1.9.2"
petitparser: petitparser:
dependency: transitive dependency: transitive
description: description:
name: petitparser name: petitparser
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "5.0.0" version: "3.1.0"
pin_code_fields: pin_code_fields:
dependency: "direct main" dependency: "direct main"
description: description:
name: pin_code_fields name: pin_code_fields
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "7.4.0" version: "6.0.1"
platform: platform:
dependency: transitive dependency: transitive
description: description:
name: platform name: platform
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "3.1.0" version: "2.2.1"
plugin_platform_interface: plugin_platform_interface:
dependency: transitive dependency: transitive
description: description:
name: plugin_platform_interface name: plugin_platform_interface
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.2" version: "1.0.3"
process: process:
dependency: transitive dependency: transitive
description: description:
name: process name: process
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "4.2.4" version: "3.0.13"
provider: provider:
dependency: "direct main" dependency: "direct main"
description: description:
name: provider name: provider
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "6.0.3" version: "4.3.2+2"
shared_preferences: shared_preferences:
dependency: "direct main" dependency: "direct main"
description: description:
name: shared_preferences name: shared_preferences
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.0.15" version: "0.5.12+4"
shared_preferences_android:
dependency: transitive
description:
name: shared_preferences_android
url: "https://pub.dartlang.org"
source: hosted
version: "2.0.13"
shared_preferences_ios:
dependency: transitive
description:
name: shared_preferences_ios
url: "https://pub.dartlang.org"
source: hosted
version: "2.1.1"
shared_preferences_linux: shared_preferences_linux:
dependency: transitive dependency: transitive
description: description:
name: shared_preferences_linux name: shared_preferences_linux
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.1" version: "0.0.2+4"
shared_preferences_macos: shared_preferences_macos:
dependency: transitive dependency: transitive
description: description:
name: shared_preferences_macos name: shared_preferences_macos
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.0.4" version: "0.0.1+11"
shared_preferences_platform_interface: shared_preferences_platform_interface:
dependency: transitive dependency: transitive
description: description:
name: shared_preferences_platform_interface name: shared_preferences_platform_interface
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.0" version: "1.0.4"
shared_preferences_web: shared_preferences_web:
dependency: transitive dependency: transitive
description: description:
name: shared_preferences_web name: shared_preferences_web
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.0.4" version: "0.1.2+7"
shared_preferences_windows: shared_preferences_windows:
dependency: transitive dependency: transitive
description: description:
name: shared_preferences_windows name: shared_preferences_windows
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.1" version: "0.0.1+3"
sky_engine: sky_engine:
dependency: transitive dependency: transitive
description: flutter description: flutter
@ -356,77 +342,77 @@ packages:
name: source_span name: source_span
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.9.0" version: "1.8.0-nullsafety.2"
stack_trace: stack_trace:
dependency: transitive dependency: transitive
description: description:
name: stack_trace name: stack_trace
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.10.0" version: "1.10.0-nullsafety.1"
stream_channel: stream_channel:
dependency: transitive dependency: transitive
description: description:
name: stream_channel name: stream_channel
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.0" version: "2.1.0-nullsafety.1"
string_scanner: string_scanner:
dependency: transitive dependency: transitive
description: description:
name: string_scanner name: string_scanner
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.1.1" version: "1.1.0-nullsafety.1"
term_glyph: term_glyph:
dependency: transitive dependency: transitive
description: description:
name: term_glyph name: term_glyph
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.2.1" version: "1.2.0-nullsafety.1"
test_api: test_api:
dependency: transitive dependency: transitive
description: description:
name: test_api name: test_api
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "0.4.12" version: "0.2.19-nullsafety.2"
typed_data: typed_data:
dependency: transitive dependency: transitive
description: description:
name: typed_data name: typed_data
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.3.0" version: "1.3.0-nullsafety.3"
vector_math: vector_math:
dependency: transitive dependency: transitive
description: description:
name: vector_math name: vector_math
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.2" version: "2.1.0-nullsafety.3"
win32: win32:
dependency: transitive dependency: transitive
description: description:
name: win32 name: win32
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.5.2" version: "1.7.4"
xdg_directories: xdg_directories:
dependency: transitive dependency: transitive
description: description:
name: xdg_directories name: xdg_directories
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "0.2.0+2" version: "0.1.2"
xml: xml:
dependency: transitive dependency: transitive
description: description:
name: xml name: xml
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "6.1.0" version: "4.5.1"
sdks: sdks:
dart: ">=2.17.0 <3.0.0" dart: ">=2.10.0-110 <2.11.0"
flutter: ">=2.11.0-0.1.pre" flutter: ">=1.22.0 <2.0.0"

View file

@ -18,7 +18,7 @@ publish_to: 'none' # Remove this line if you wish to publish to pub.dev
version: 1.0.0+1 version: 1.0.0+1
environment: environment:
sdk: ">=2.16.2 <3.0.0" sdk: ">=2.7.0 <3.0.0"
dependencies: dependencies:
flutter: flutter:
@ -28,15 +28,15 @@ dependencies:
# The following adds the Cupertino Icons font to your application. # The following adds the Cupertino Icons font to your application.
# Use with the CupertinoIcons class for iOS style icons. # Use with the CupertinoIcons class for iOS style icons.
cupertino_icons: ^1.0.0 cupertino_icons: ^1.0.0
provider: ^6.0.3 provider: ^4.3.2+2
http: ^0.13.5 http: ^0.12.2
shared_preferences: ^2.0.15 shared_preferences: ^0.5.12+4
flutter_spinkit: ^5.1.0 flutter_spinkit: ^4.1.2+1
pin_code_fields: ^7.4.0 pin_code_fields: ^6.0.1
flutter_svg: ^1.1.5 flutter_svg: ^0.19.1
google_fonts: ^3.0.1 google_fonts: ^1.1.1
fl_chart: ^0.55.1 fl_chart: ^0.12.0
flutter_custom_dialog: ^1.3.0 flutter_custom_dialog: ^1.0.20
dev_dependencies: dev_dependencies:
flutter_test: flutter_test:
sdk: flutter sdk: flutter