diff --git a/android/.project b/android/.project new file mode 100644 index 0000000..3964dd3 --- /dev/null +++ b/android/.project @@ -0,0 +1,17 @@ + + + android + Project android created by Buildship. + + + + + org.eclipse.buildship.core.gradleprojectbuilder + + + + + + org.eclipse.buildship.core.gradleprojectnature + + diff --git a/android/.settings/org.eclipse.buildship.core.prefs b/android/.settings/org.eclipse.buildship.core.prefs new file mode 100644 index 0000000..d19d611 --- /dev/null +++ b/android/.settings/org.eclipse.buildship.core.prefs @@ -0,0 +1,13 @@ +arguments= +auto.sync=false +build.scans.enabled=false +connection.gradle.distribution=GRADLE_DISTRIBUTION(WRAPPER) +connection.project.dir= +eclipse.preferences.version=1 +gradle.user.home= +java.home=/usr/lib/jvm/java-8-openjdk-amd64 +jvm.arguments= +offline.mode=false +override.workspace.settings=true +show.console.view=true +show.executions.view=true diff --git a/android/app/.classpath b/android/app/.classpath new file mode 100644 index 0000000..eb19361 --- /dev/null +++ b/android/app/.classpath @@ -0,0 +1,6 @@ + + + + + + diff --git a/android/app/.project b/android/app/.project new file mode 100644 index 0000000..ac485d7 --- /dev/null +++ b/android/app/.project @@ -0,0 +1,23 @@ + + + app + Project app created by Buildship. + + + + + org.eclipse.jdt.core.javabuilder + + + + + org.eclipse.buildship.core.gradleprojectbuilder + + + + + + org.eclipse.jdt.core.javanature + org.eclipse.buildship.core.gradleprojectnature + + diff --git a/android/app/.settings/org.eclipse.buildship.core.prefs b/android/app/.settings/org.eclipse.buildship.core.prefs new file mode 100644 index 0000000..b1886ad --- /dev/null +++ b/android/app/.settings/org.eclipse.buildship.core.prefs @@ -0,0 +1,2 @@ +connection.project.dir=.. +eclipse.preferences.version=1 diff --git a/assets/logo.jpg b/assets/logo.jpg new file mode 100644 index 0000000..2df4aa2 Binary files /dev/null and b/assets/logo.jpg differ diff --git a/lib/main-dev.dart b/lib/main-dev.dart index 446fb23..0913770 100644 --- a/lib/main-dev.dart +++ b/lib/main-dev.dart @@ -6,7 +6,7 @@ import 'app.dart'; void main() { Config( - flavor: Flavor.DEV, + flavor: Flavor.PRODUCTION, color: Colors.blue, apiURL: "https://asia-northeast1-mokkon-wholesale-dev.cloudfunctions.net/APIOK", diff --git a/lib/pages/home_page.dart b/lib/pages/home_page.dart index 05c0c06..8e6ed1f 100644 --- a/lib/pages/home_page.dart +++ b/lib/pages/home_page.dart @@ -1,12 +1,4 @@ -import 'dart:async'; - -import 'package:firebase_messaging/firebase_messaging.dart'; -import 'package:flutter/material.dart'; -import 'package:flutter_staggered_grid_view/flutter_staggered_grid_view.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:intl/intl.dart'; -import 'package:logging/logging.dart'; -import 'package:provider/provider.dart'; +import 'dart:math' as math; import 'package:fcs/charts/bar_chart.dart'; import 'package:fcs/charts/delivery_do_line.dart'; import 'package:fcs/charts/delivery_do_summary.dart'; @@ -15,40 +7,35 @@ import 'package:fcs/charts/delivery_summary.dart'; import 'package:fcs/charts/do_line.dart'; import 'package:fcs/charts/po_balance_chart.dart'; import 'package:fcs/charts/po_line.dart'; -import 'package:fcs/charts/quota.dart'; import 'package:fcs/charts/revenue_line.dart'; import 'package:fcs/model/language_model.dart'; -import 'package:fcs/model/main_model.dart'; -import 'package:fcs/model/notification_model.dart'; import 'package:fcs/model/product_model.dart'; import 'package:fcs/pages/banks/banks.dart'; import 'package:fcs/pages/buyer_list.dart'; import 'package:fcs/pages/contact.dart'; import 'package:fcs/pages/delivery/delivery_list.dart'; import 'package:fcs/pages/manual/manual_page.dart'; -import 'package:fcs/pages/my_registeration_info.dart'; import 'package:fcs/pages/notification_list.dart'; -import 'package:fcs/pages/pin_login_dialog.dart'; import 'package:fcs/pages/settings.dart'; import 'package:fcs/pages/term.dart'; -import 'package:fcs/pages/test_list.dart'; -import 'package:fcs/pages/util.dart'; import 'package:fcs/reports/report_list.dart'; -import 'package:fcs/vo/user.dart'; -import 'package:fcs/widget/badge.dart'; import 'package:fcs/widget/banner.dart'; import 'package:fcs/widget/local_text.dart'; import 'package:fcs/widget/localization/app_translations.dart'; import 'package:fcs/widget/offline_redirect.dart'; -import 'package:fcs/vo/notification.dart' as Noti; +import 'package:flutter/cupertino.dart'; +import 'package:flutter/material.dart'; +import 'package:flutter_staggered_grid_view/flutter_staggered_grid_view.dart'; +import 'package:font_awesome_flutter/font_awesome_flutter.dart'; +import 'package:intl/intl.dart'; +import 'package:logging/logging.dart'; +import 'package:provider/provider.dart'; import '../theme/theme.dart'; import 'announcement_list.dart'; import 'do/do_list.dart'; import 'employee_list.dart'; -import 'my_registeration.dart'; import 'pd/pd_list.dart'; -import 'po/po_submission_list.dart'; import 'products_list.dart'; import 'profile_page.dart'; import 'storage/storage_list.dart'; @@ -88,7 +75,8 @@ class _HomePageState extends State { @override Widget build(BuildContext context) { - final helpBtn = _buildBtn("manual.title", + final helpBtn = _buildBtn2("manual.title", + icon: FontAwesomeIcons.readme, imgIcon: Image.asset( "assets/manual.png", width: 40, @@ -100,7 +88,7 @@ class _HomePageState extends State { // btnCallback: () => Navigator.of(context) // .push(MaterialPageRoute(builder: (_) => TestList())) ); - final announcementBtn = _buildBtn("announcement.title", + final announcementBtn = _buildBtn2("announcement.title", icon: Icons.announcement, btnCallback: () => Navigator.of(context) .push(MaterialPageRoute(builder: (_) => AnnouncementList()))); @@ -115,7 +103,8 @@ class _HomePageState extends State { btnCallback: () => Navigator.of(context) .push(MaterialPageRoute(builder: (_) => BuyerList()))); - final reportBtn = _buildBtn("report.title", + final reportBtn = _buildBtn2("report.title", + icon: FontAwesomeIcons.paperPlane, imgIcon: Image.asset( "assets/report.png", width: 50, @@ -193,7 +182,8 @@ class _HomePageState extends State { btnCallback: () => Navigator.of(context) .push(MaterialPageRoute(builder: (_) => EmployeeList()))); - final termBtn = _buildBtn("term.title", + final termBtn = _buildBtn2("term.title", + icon: FontAwesomeIcons.fileContract, imgIcon: Image.asset( "assets/term.png", width: 40, @@ -219,7 +209,7 @@ class _HomePageState extends State { ); }); - final _bankAccountsBtn = _buildBtn("banks.title", + final _bankAccountsBtn = _buildBtn2("banks.title", icon: FontAwesomeIcons.moneyCheck, btnCallback: () { Navigator.push( context, @@ -227,7 +217,6 @@ class _HomePageState extends State { ); }); - List widgets = [helpBtn]; widgets.add(announcementBtn); widgets.add(reportBtn); @@ -341,10 +330,11 @@ class _HomePageState extends State { child: FlavorBanner( child: Scaffold( appBar: AppBar( + elevation: 0, backgroundColor: primaryColor, title: ClipRRect( - child: Image.asset("assets/logo.png", height: 40), - borderRadius: new BorderRadius.circular(15.0), + child: Image.asset("assets/logo.jpg", height: 40), + borderRadius: new BorderRadius.circular(35.0), ), actions: [ IconButton( @@ -355,7 +345,7 @@ class _HomePageState extends State { ); }, iconSize: 30, - icon: Icon(Icons.phone), + icon: Icon(Icons.notifications), ), IconButton( onPressed: () { @@ -365,53 +355,99 @@ class _HomePageState extends State { ); }, iconSize: 30, - icon: Icon(Icons.account_circle), + icon: Icon(Icons.tune), ), ]), - body: StaggeredGridView.count( - crossAxisCount: 3, - crossAxisSpacing: 12.0, - mainAxisSpacing: 12.0, - padding: EdgeInsets.symmetric(horizontal: 16.0, vertical: 8.0), - children: [ - _buildTile( - Padding( - padding: const EdgeInsets.all(20.0), - child: productListBox, - ), - onTap: () => Navigator.of(context) - .push(MaterialPageRoute(builder: (_) => ProductsList())), - ), - new GridView.count( - shrinkWrap: true, - scrollDirection: Axis.horizontal, - crossAxisCount: 1, - crossAxisSpacing: 12, - mainAxisSpacing: 12, - padding: EdgeInsets.only(bottom: 5, left: 10, right: 5), - children: widgets, - ), - _buildTile( - PageView( - children: chartWidgets, + body: Container( + decoration: BoxDecoration( + gradient: + // RadialGradient( + // center: const Alignment(-0.7, 0.6), // near the top right + // radius: 0.6, + // colors: [ + // secondaryColor, + // primaryColor, // yellow sun + // ], + // stops: [0.4, 1.0], + // ) + // LinearGradient( + // begin: Alignment.topCenter, + // end: Alignment + // .bottomCenter, // 10% of the width, so there are ten blinds. + // colors: [ + // Color(0xd0272262), + // Color(0xfa272262), + // ], // whitish to gray + // ), + SweepGradient( + center: FractionalOffset.centerLeft, + startAngle: 0.0, + endAngle: math.pi * 2, + colors: const [ + secondaryColor, + primaryColor, + secondaryColor, + primaryColor, + secondaryColor, + ], + stops: const [0.0, 0.25, 0.5, 0.75, 1.0], ), ), - ], - staggeredTiles: [ - StaggeredTile.extent(5, 110.0), - StaggeredTile.extent(3, 110.0), - StaggeredTile.extent(3, 250.0), - ], - )), + child: ListView(children: [ + Wrap( + children: widgets, + ), + ]) + // child: StaggeredGridView.count( + // crossAxisCount: 3, + // crossAxisSpacing: 12.0, + // mainAxisSpacing: 12.0, + // padding: EdgeInsets.symmetric(horizontal: 16.0, vertical: 8.0), + // children: [ + // _buildTile( + // Padding( + // padding: const EdgeInsets.all(20.0), + // child: productListBox, + // ), + // onTap: () => Navigator.of(context).push( + // MaterialPageRoute(builder: (_) => ProductsList())), + // ), + // new GridView.count( + // shrinkWrap: true, + // scrollDirection: Axis.horizontal, + // crossAxisCount: 1, + // crossAxisSpacing: 12, + // mainAxisSpacing: 12, + // padding: EdgeInsets.only(bottom: 5, left: 10, right: 5), + // children: widgets, + // ), + // Container( + // color:Colors.red + // ), + + // _buildTile( + // PageView( + // children: chartWidgets, + // ), + // ), + // ], + // staggeredTiles: [ + // StaggeredTile.extent(5, 110.0), + // StaggeredTile.extent(3, 110.0), + // StaggeredTile.extent(3, 250.0), + // ], + // ), + )), ), ); } Widget _buildTile(Widget child, {Function() onTap}) { return Material( - elevation: 30.0, + elevation: 0, borderRadius: BorderRadius.circular(12.0), - shadowColor: Color(0x802196F3), + // shadowColor: Colors.transparent, + color: Colors.transparent, child: InkWell( onTap: onTap != null ? () => onTap() @@ -458,12 +494,56 @@ class _HomePageState extends State { ); } - _showNotifications() async { - if (!super.mounted) return; - await Navigator.push( - context, - MaterialPageRoute(builder: (context) => NotificationList()), + Widget _buildBtn2(String title, + {Image imgIcon, IconData icon, BtnCallback btnCallback}) { + var languageModel = Provider.of(context); + return Container( + width: 130, + height: 130, + decoration: new BoxDecoration( + color: Colors.transparent, //new Color.fromRGBO(255, 0, 0, 0.0), + borderRadius: new BorderRadius.only( + topLeft: const Radius.circular(40.0), + topRight: const Radius.circular(40.0))), + // color: Colors.transparent, + child: Padding( + padding: const EdgeInsets.all(5.0), + child: Column( + mainAxisAlignment: MainAxisAlignment.center, + crossAxisAlignment: CrossAxisAlignment.center, + children: [ + // Padding( + // padding: EdgeInsets.only(top: 10), + // child: Icon(icon, color: Colors.white, size: 35.0)), + // Padding(padding: EdgeInsets.only(bottom: 10.0)), + ClipOval( + child: Material( + color: Colors.white, // button color + child: InkWell( + splashColor: secondaryColor, // inkwell color + child: SizedBox(width: 60, height: 60, child: Icon(icon,size:35)), + onTap: btnCallback, + ), + ), + ), + + Text(AppTranslations.of(context).text(title), + style: + // languageModel.isEng + // ? + TextStyle( + color: Colors.white, + fontWeight: FontWeight.normal, + fontSize: 16.0, + fontFamily: "Roboto") + // : TextStyle( + // color: Colors.black, + // fontWeight: FontWeight.w700, + // fontSize: 12.0, + // fontFamily: "MyanmarUnicode") + ), + ]), + ), ); - // Provider.of(context, listen: false).seen(); } } diff --git a/lib/pages/profile_page.dart b/lib/pages/profile_page.dart index a0e0c83..b7ec792 100644 --- a/lib/pages/profile_page.dart +++ b/lib/pages/profile_page.dart @@ -94,6 +94,7 @@ class _ProfileState extends State { ], ), )); + final phonenumberbox = Container( height: 45.0, child: Row( @@ -319,6 +320,14 @@ class _ProfileState extends State { languageBox, logoutbutton, Divider(color: secondaryColor), + Switch( + value: false, + onChanged: (value) { + setState(() {}); + }, + // activeTrackColor: Colors.lightGreenAccent, + // activeColor: Colors.green, + ), versionbox, SizedBox( height: 20, @@ -332,7 +341,7 @@ class _ProfileState extends State { Widget getPrivilegeBox(BuildContext context) { var languageModel = Provider.of(context); var userModel = Provider.of(context); - + return ListTileTheme( contentPadding: EdgeInsets.all(0), child: ExpansionTile( diff --git a/lib/theme/theme.dart b/lib/theme/theme.dart index 373f602..2b48844 100644 --- a/lib/theme/theme.dart +++ b/lib/theme/theme.dart @@ -2,8 +2,8 @@ import 'package:flutter/material.dart'; import 'dart:ui'; import 'package:flutter/cupertino.dart'; -const primaryColor = const Color(0xfff00a21); -const secondaryColor = const Color(0xFF0815f1); +const primaryColor = const Color(0xff272262); +const secondaryColor = const Color(0xffff4400); const thirdColor = const Color(0xFF0700f1); const nextColor = const Color(0xFFfa833d); const buttonColor = const Color(0xFFFFFFFF);