updae login and get pro file/ edit profile

parent 4438b883
...@@ -25,9 +25,9 @@ class MyApp extends StatelessWidget { ...@@ -25,9 +25,9 @@ class MyApp extends StatelessWidget {
primarySwatch: Colors.blue, primarySwatch: Colors.blue,
), ),
// home: SplashScreenPage(), home: SplashScreenPage(),
home: EditProfile(), //home: EditProfile(),
); );
} }
......
...@@ -24,16 +24,16 @@ class LoginModel { ...@@ -24,16 +24,16 @@ class LoginModel {
class User { class User {
int id; int id;
Null roleId; dynamic roleId;
String name; String name;
String email; String email;
String avatar; String avatar;
Null emailVerifiedAt; dynamic emailVerifiedAt;
int status; int status;
int fvRoleId; int fvRoleId;
Null settings; dynamic settings;
Null createdAt; dynamic createdAt;
Null updatedAt; dynamic updatedAt;
CustomerInfo customerInfo; CustomerInfo customerInfo;
User( User(
......
...@@ -26,7 +26,7 @@ class Api<T> { ...@@ -26,7 +26,7 @@ class Api<T> {
var _model; var _model;
var _fail; var _fail;
var result; var result;
print("this is body "+body.toString());
// (body as Map)['lang'] = allTranslations.currentLanguage; // (body as Map)['lang'] = allTranslations.currentLanguage;
await _httpConnection( await _httpConnection(
"${this._baseApi}/customer/info", this._headerApi, body) "${this._baseApi}/customer/info", this._headerApi, body)
......
...@@ -9,6 +9,8 @@ import 'package:flutter/material.dart'; ...@@ -9,6 +9,8 @@ import 'package:flutter/material.dart';
import '../../util/SizeConfig.dart'; import '../../util/SizeConfig.dart';
class EditProfile extends StatefulWidget { class EditProfile extends StatefulWidget {
String id;
EditProfile({Key key,this.id,}) : super(key: key);
@override @override
_EditProfileState createState() => _EditProfileState(); _EditProfileState createState() => _EditProfileState();
} }
...@@ -21,7 +23,8 @@ class _EditProfileState extends State<EditProfile> { ...@@ -21,7 +23,8 @@ class _EditProfileState extends State<EditProfile> {
super.initState(); super.initState();
presenter = EditprofilePresenter(this); presenter = EditprofilePresenter(this);
presenter.getprofile(); print("wwww id ="+widget.id);
presenter.getprofile(widget.id);
} }
_getImage() { _getImage() {
......
...@@ -154,10 +154,14 @@ class EditprofilePresenter extends BasePresenter<EditProfile> { ...@@ -154,10 +154,14 @@ class EditprofilePresenter extends BasePresenter<EditProfile> {
return base64.encode(imageFile.readAsBytesSync()); return base64.encode(imageFile.readAsBytesSync());
} }
getprofile() async { getprofile(String id) async {
_api = Api<GetprofileModel>(); _api = Api<GetprofileModel>();
var res = await _api.getprofile({"id": "16"}); var res = await _api.getprofile({
"id": id
});
if (res.fail == null) { if (res.fail == null) {
setState(() { setState(() {
......
...@@ -10,6 +10,9 @@ import 'package:flutter/cupertino.dart'; ...@@ -10,6 +10,9 @@ import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
class HomePage extends StatefulWidget { class HomePage extends StatefulWidget {
String id;
String image;
HomePage({Key key, this.id,this.image}) : super(key: key);
@override @override
_HomePageState createState() => _HomePageState(); _HomePageState createState() => _HomePageState();
} }
...@@ -24,8 +27,7 @@ class _HomePageState extends State<HomePage> with TickerProviderStateMixin { ...@@ -24,8 +27,7 @@ class _HomePageState extends State<HomePage> with TickerProviderStateMixin {
void initState() { void initState() {
presenter = HomePresenter(this); presenter = HomePresenter(this);
presenter.Listitem(); presenter.Listitem();
presenter.getprofile(widget.id.toString());
} }
...@@ -193,7 +195,8 @@ class _HomePageState extends State<HomePage> with TickerProviderStateMixin { ...@@ -193,7 +195,8 @@ class _HomePageState extends State<HomePage> with TickerProviderStateMixin {
showDialog( showDialog(
context: context, context: context,
builder: (BuildContext context) { builder: (BuildContext context) {
return NavDrawer();
return presenter.getmodel==null?Container():NavDrawer(name: presenter.getmodel.result[0].user.name,id:presenter.getmodel.result[0].id.toString(),image:presenter.getmodel.result[0].image ,);
}); });
}, },
child: Image.asset( child: Image.asset(
...@@ -227,12 +230,17 @@ class _HomePageState extends State<HomePage> with TickerProviderStateMixin { ...@@ -227,12 +230,17 @@ class _HomePageState extends State<HomePage> with TickerProviderStateMixin {
MaterialPageRoute(builder: (context) => LoginPage()), MaterialPageRoute(builder: (context) => LoginPage()),
); );
}, },
child: Container( child: Container(
child: Image.asset( child: ClipRRect(
'assets/images/ic_userimg.png', borderRadius: BorderRadius.all(
height: SizeConfig.getWidth(30), Radius.circular(SizeConfig.getWidth(56))),
child: Image.network(
widget.image,
fit: BoxFit.contain,
width: SizeConfig.getWidth(30), width: SizeConfig.getWidth(30),
fit: BoxFit.cover, height: SizeConfig.getWidth(30),
),
), ),
), ),
), ),
......
import 'package:feelverapp/model/Login/login_model.dart';
import 'package:feelverapp/model/category/category_model.dart'; import 'package:feelverapp/model/category/category_model.dart';
import 'package:feelverapp/model/editprofile/getprofilemodel.dart';
import 'package:feelverapp/model/home/home_model.dart'; import 'package:feelverapp/model/home/home_model.dart';
import 'package:feelverapp/service/Loading.dart';
import 'package:feelverapp/service/api.dart'; import 'package:feelverapp/service/api.dart';
import 'package:feelverapp/service/base_presenter.dart'; import 'package:feelverapp/service/base_presenter.dart';
import 'package:feelverapp/ui/home/home.dart'; import 'package:feelverapp/ui/home/home.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:rflutter_alert/rflutter_alert.dart';
class HomePresenter extends BasePresenter<HomePage> { class HomePresenter extends BasePresenter<HomePage> {
Api _api; Api _api;
final formkey = GlobalKey<FormState>(); final formkey = GlobalKey<FormState>();
GetprofileModel getmodel;
LoginModel logmodel;
HomePresenter(State<HomePage> state) : super(state); HomePresenter(State<HomePage> state) : super(state);
Listitem() async { Listitem() async {
...@@ -22,4 +28,46 @@ class HomePresenter extends BasePresenter<HomePage> { ...@@ -22,4 +28,46 @@ class HomePresenter extends BasePresenter<HomePage> {
print('res Fail'); print('res Fail');
} }
} }
getprofile(String id) async {
_api = Api<GetprofileModel>();
var res = await _api.getprofile({
"id":id.toString()
});
if (res.fail == null) {
setState(() {
getmodel = res.success;});
print("Hii"+getmodel.result[0].name);
} else {
Alert(
style: AlertStyle(
animationType: AnimationType.fromTop,
isCloseButton: false,
),
context: state.context,
title: "ไม่สามารถติดต่อ\nเซิร์ฟเวอร์ได้",
content: Icon(
Icons.warning,
color: Colors.orange,
size: 80,
),
buttons: [
DialogButton(
color: Color.fromRGBO(106, 179, 170, 1),
onPressed: () => Navigator.pop(state.context),
child: Text(
"ลองอีกครั้ง",
style: TextStyle(color: Colors.white, fontSize: 20),
),
)
]).show();
}
}
} }
...@@ -10,6 +10,8 @@ import 'package:flutter/cupertino.dart'; ...@@ -10,6 +10,8 @@ import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
class LoginPage extends StatefulWidget { class LoginPage extends StatefulWidget {
@override @override
_LoginPageState createState() => _LoginPageState(); _LoginPageState createState() => _LoginPageState();
} }
...@@ -17,6 +19,7 @@ class LoginPage extends StatefulWidget { ...@@ -17,6 +19,7 @@ class LoginPage extends StatefulWidget {
class _LoginPageState extends State<LoginPage> with TickerProviderStateMixin { class _LoginPageState extends State<LoginPage> with TickerProviderStateMixin {
TabController _tabController; TabController _tabController;
LoginPresenter presenter; LoginPresenter presenter;
@override @override
void initState() { void initState() {
// TODO: implement initState // TODO: implement initState
......
...@@ -94,7 +94,7 @@ else { ...@@ -94,7 +94,7 @@ else {
if (res.fail == null) { if (res.fail == null) {
LoginModel model = res.success;
Alert( Alert(
style: AlertStyle( style: AlertStyle(
animationType: AnimationType.fromTop, animationType: AnimationType.fromTop,
...@@ -107,15 +107,15 @@ else { ...@@ -107,15 +107,15 @@ else {
buttons: [ buttons: [
DialogButton( DialogButton(
color: Color.fromRGBO(106, 179, 170, 1), color: Color.fromRGBO(106, 179, 170, 1),
onPressed: () => onPressed: () { Navigator.pop(state.context);
Navigator.pushReplacement(state.context, CupertinoPageRoute(builder: (_) => HomePage())), Navigator.pushReplacement(state.context, CupertinoPageRoute(builder: (_) => HomePage(id:model.user.customerInfo.id.toString(),image: model.user.customerInfo.image,)));} ,
child: Text( child: Text(
"ตกลง", "ตกลง",
style: TextStyle(color: Colors.white, fontSize: 20), style: TextStyle(color: Colors.white, fontSize: 20),
), ),
) )
]).show(); ]).show();
LoginModel model = res.success;
await AccountUtil.saveToken(model.token); await AccountUtil.saveToken(model.token);
print( await AccountUtil.getToken()); print( await AccountUtil.getToken());
// print(AccountUtil.getToken().toString()); // print(AccountUtil.getToken().toString());
...@@ -192,8 +192,9 @@ Navigator.pushReplacement(state.context, CupertinoPageRoute(builder: (_) => Home ...@@ -192,8 +192,9 @@ Navigator.pushReplacement(state.context, CupertinoPageRoute(builder: (_) => Home
buttons: [ buttons: [
DialogButton( DialogButton(
color: Color.fromRGBO(106, 179, 170, 1), color: Color.fromRGBO(106, 179, 170, 1),
onPressed: () => onPressed: () { Navigator.pop(state.context);
Navigator.pushReplacement(state.context, CupertinoPageRoute(builder: (_) => HomePage())), Navigator.pushReplacement(state.context, CupertinoPageRoute(builder: (_) => HomePage()));} ,
child: Text( child: Text(
"ตกลง", "ตกลง",
style: TextStyle(color: Colors.white, fontSize: 20), style: TextStyle(color: Colors.white, fontSize: 20),
......
import 'package:feelverapp/ui/ForgetPassword/forgetpassword.dart';
import 'package:feelverapp/ui/edit_profile/edit_profile.dart'; import 'package:feelverapp/ui/edit_profile/edit_profile.dart';
import 'package:feelverapp/ui/home/home.dart';
import 'package:feelverapp/ui/login/login.dart'; import 'package:feelverapp/ui/login/login.dart';
import 'package:feelverapp/ui/login/login_presenter.dart';
import 'package:feelverapp/ui/register/register_email.dart';
//import 'package:feelverapp/ui/login/login_presenter.dart';
import 'package:feelverapp/util/SizeConfig.dart'; import 'package:feelverapp/util/SizeConfig.dart';
import 'package:flutter/cupertino.dart'; import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
class NavDrawer extends StatelessWidget { class NavDrawer extends StatefulWidget {
String id;
String name;
String image;
String lastname;
NavDrawer({Key key, this.name,this.lastname,this.image,this.id,}) : super(key: key);
@override
_NavDrawerState createState() => _NavDrawerState();
}
class _NavDrawerState extends State<NavDrawer> with TickerProviderStateMixin {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Padding( return Padding(
...@@ -14,37 +34,58 @@ class NavDrawer extends StatelessWidget { ...@@ -14,37 +34,58 @@ class NavDrawer extends StatelessWidget {
child: SingleChildScrollView( child: SingleChildScrollView(
child: Column( child: Column(
children: <Widget>[ children: <Widget>[
Stack( widget.image==null? Stack(
children: <Widget>[ children: <Widget>[
Container( Container(
height: SizeConfig.getWidth(80),
color: Color.fromRGBO(106, 179, 170, 1),
),
Container(
alignment: Alignment.topCenter,
padding: EdgeInsets.only( padding: EdgeInsets.only(
left: SizeConfig.getPadding(10), left: SizeConfig.getPadding(10),
top: SizeConfig.getPadding(24)), top: SizeConfig.getPadding(30)),
child: Image.asset( child: Container(
'assets/images/ic_userimg.png', decoration: BoxDecoration(
color: Color.fromRGBO(238, 175, 183, 1),
shape: BoxShape.circle,
border: Border.all(
color: Colors.white, width: 1.4)),
width: SizeConfig.getWidth(100), width: SizeConfig.getWidth(100),
height: SizeConfig.getWidth(100), height: SizeConfig.getWidth(100),
), ),
), ),
Container( Container(
alignment: Alignment.topCenter,
padding: EdgeInsets.only( padding: EdgeInsets.only(
left: SizeConfig.getPadding(90), left: SizeConfig.getPadding(10),
top: SizeConfig.getPadding(100)), top: SizeConfig.getPadding(65)),
child: Image.asset( child: Image.asset(
'assets/images/ic_camera.png', 'assets/images/ic_camera_profile.png',
width: SizeConfig.getWidth(30), width: SizeConfig.getWidth(34),
height: SizeConfig.getWidth(30), height: SizeConfig.getWidth(34),
),
), ),
)
], ],
):
ClipRRect(
borderRadius: BorderRadius.all(
Radius.circular(SizeConfig.getWidth(56))),
child: Image.network(
widget.image,
fit: BoxFit.contain,
width: SizeConfig.getWidth(100),
height: SizeConfig.getWidth(100),
), ),
),
Container( Container(
padding: EdgeInsets.only( padding: EdgeInsets.only(
top: SizeConfig.getPadding(20), top: SizeConfig.getPadding(20),
), ),
alignment: Alignment.center, alignment: Alignment.center,
child: Text( child: Text(
'John wick', '${widget.name}',
style: TextStyle( style: TextStyle(
color: Colors.black, color: Colors.black,
fontSize: SizeConfig.getFontSize(24), fontSize: SizeConfig.getFontSize(24),
...@@ -64,7 +105,7 @@ class NavDrawer extends StatelessWidget { ...@@ -64,7 +105,7 @@ class NavDrawer extends StatelessWidget {
onTap: () { onTap: () {
Navigator.push( Navigator.push(
context, context,
CupertinoPageRoute(builder: (context) => EditProfile(),), CupertinoPageRoute(builder: (context) => EditProfile(id:widget.id),),
); );
}, },
child: Container( child: Container(
...@@ -321,3 +362,6 @@ class NavDrawer extends StatelessWidget { ...@@ -321,3 +362,6 @@ class NavDrawer extends StatelessWidget {
); );
} }
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment