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 29f96b0..4be8a25 100644
--- a/lib/pages/home_page.dart
+++ b/lib/pages/home_page.dart
@@ -1,15 +1,4 @@
-import 'dart:async';
-
-import 'package:fcs/pages/fcs_profile_page.dart';
-import 'package:fcs/pages/pickup_list.dart';
-import 'package:fcs/pages/shipment_rates.dart';
-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';
@@ -18,42 +7,40 @@ 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 'fcs_profile_page.dart';
import 'pd/pd_list.dart';
-import 'po/po_submission_list.dart';
+import 'pickup_list.dart';
import 'products_list.dart';
import 'profile_page.dart';
+import 'shipment_rates.dart';
import 'storage/storage_list.dart';
import 'user_list.dart';
@@ -91,7 +78,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,
@@ -103,7 +91,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())));
@@ -118,7 +106,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,
@@ -211,7 +200,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,
@@ -237,7 +227,7 @@ class _HomePageState extends State {
);
});
- final _bankAccountsBtn = _buildBtn("banks.title",
+ final _bankAccountsBtn = _buildBtn2("banks.title",
icon: FontAwesomeIcons.moneyCheck, btnCallback: () {
Navigator.push(
context,
@@ -361,10 +351,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(
@@ -375,7 +366,7 @@ class _HomePageState extends State {
);
},
iconSize: 30,
- icon: Icon(Icons.phone),
+ icon: Icon(Icons.notifications),
),
IconButton(
onPressed: () {
@@ -385,53 +376,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()
@@ -478,12 +515,57 @@ 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);