You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

792 lines
25 KiB

4 years ago
import 'dart:convert';
4 years ago
import 'dart:io';
import 'package:dio/dio.dart';
4 years ago
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
4 years ago
import 'package:huixiang/generated/l10n.dart';
4 years ago
import 'package:huixiang/retrofit/data/base_data.dart';
import 'package:huixiang/retrofit/data/upload_result.dart';
import 'package:huixiang/retrofit/data/user_info.dart';
import 'package:huixiang/retrofit/retrofit_api.dart';
4 years ago
import 'package:huixiang/utils/flutter_utils.dart';
import 'package:huixiang/utils/font_weight.dart';
4 years ago
import 'package:huixiang/view_widget/cupertino_date_picker.dart';
3 years ago
import 'package:huixiang/view_widget/custom_image.dart';
4 years ago
import 'package:huixiang/view_widget/my_appbar.dart';
3 years ago
import 'package:image_pickers/image_pickers.dart';
4 years ago
import 'package:intl/intl.dart';
4 years ago
import 'package:permission_handler/permission_handler.dart';
4 years ago
import 'package:shared_preferences/shared_preferences.dart';
4 years ago
import 'package:flutter_screenutil/flutter_screenutil.dart';
4 years ago
import '../view_widget/request_permission.dart';
4 years ago
class UserInfoPage extends StatefulWidget {
@override
State<StatefulWidget> createState() {
return _UserInfoPage();
}
}
class _UserInfoPage extends State<UserInfoPage> {
4 years ago
ApiService apiService;
Map<String, dynamic> modifyInfo = {
"birth": "",
"headimg": "",
"nickname": "",
"sex": "",
"signature": ""
4 years ago
};
4 years ago
@override
void initState() {
super.initState();
SharedPreferences.getInstance().then((value) => {
4 years ago
print(value.getString('user')),
4 years ago
user = UserInfo.fromJson(jsonDecode(value.getString('user'))),
mobile = user?.phone ?? "",
modifyInfo["nickname"] = user?.nickname ??"",
modifyInfo["signature"] = user?.signature ?? "",
modifyInfo["birth"] = user?.birth ?? "",
modifyInfo["headimg"] = user?.headimg ?? "",
modifyInfo["sex"] = user?.sex ?? "",
age = AppUtils.getAgeByString(user ?.birth ?? ""),
4 years ago
refresh(),
apiService = ApiService(Dio(),
context: context, token: value.getString('token')),
4 years ago
});
}
String age;
String mobile = "";
String locale = "zh";
4 years ago
UserInfo user;
int selectSexIndex = 0;
4 years ago
refresh() async {
setState(() {});
}
4 years ago
@override
Widget build(BuildContext context) {
return Scaffold(
3 years ago
backgroundColor: Color(0xFFFFFFFF),
4 years ago
appBar: MyAppBar(
3 years ago
title: S.of(context).gerenxinxi,
4 years ago
titleColor: Colors.black,
3 years ago
background: Color(0xFFFFFFFF),
4 years ago
leadingColor: Colors.black,
4 years ago
),
body: Container(
child: Column(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
userInfo(),
],
),
),
);
}
Widget userInfo() {
return Container(
margin: EdgeInsets.only(left: 14.w, right: 14.w),
4 years ago
child: Column(
children: [
4 years ago
InkWell(
onTap: () {
showImagePicker();
},
child: avatarItem(0, ""),
),
Container(
3 years ago
margin: EdgeInsets.symmetric(vertical: 12.h),
width: double.infinity,
height: 1,
color: Color(0xFFF2F2F2),
4 years ago
),
4 years ago
InkWell(
4 years ago
onTap: () {
4 years ago
editname();
},
4 years ago
child: avatarItem(1,
(modifyInfo["nickname"]) == "" ? "回乡" : modifyInfo["nickname"]),
4 years ago
),
3 years ago
Container(
margin: EdgeInsets.symmetric(vertical: 12.h),
width: double.infinity,
height: 1,
color: Color(0xFFF2F2F2),
),
InkWell(
onTap: () {
editSignature();
},
child: avatarItem(
2,
(modifyInfo["signature"]) == ""
? "还未编辑个性签名~"
: modifyInfo["signature"]),
),
3 years ago
Container(
margin: EdgeInsets.symmetric(vertical: 12.h),
width: double.infinity,
height: 1,
color: Color(0xFFF2F2F2),
),
4 years ago
InkWell(
onTap: (modifyInfo["birth"] == "") ? showDateSelector : () {},
4 years ago
child: avatarItem(
3,
4 years ago
(modifyInfo["birth"] != null && modifyInfo["birth"] != "")
? modifyInfo["birth"]
4 years ago
: S.of(context).wanshanshengrixinxi_yhq),
4 years ago
),
3 years ago
Container(
margin: EdgeInsets.symmetric(vertical: 12.h),
width: double.infinity,
height: 1,
color: Color(0xFFF2F2F2),
),
avatarItem(4, mobile),
3 years ago
Container(
margin: EdgeInsets.symmetric(vertical: 12.h),
width: double.infinity,
height: 1,
color: Color(0xFFF2F2F2),
),
InkWell(
onTap: () {
showSexSelect(selectSexIndex);
},
child: avatarItem(
5, (modifyInfo["sex"] != null && modifyInfo["sex"] != "") ? modifyInfo["sex"]:"还未选择性别"),
),
4 years ago
],
),
);
}
4 years ago
editname() async {
4 years ago
dynamic name = await Navigator.of(context).pushNamed('/router/edit_name',
arguments: {"nick": modifyInfo['nickname']});
if (name != null && name != "") {
4 years ago
modifyInfo["nickname"] = name;
setState(() {});
modifyInfos();
}
}
editSignature() async {
dynamic signature = await Navigator.of(context).pushNamed(
'/router/edit_signature',
arguments: {"signature": modifyInfo['signature']});
if (signature != null && signature != "") {
modifyInfo["signature"] = signature;
setState(() {});
modifyInfos();
}
}
4 years ago
List<String> itemLefts = [
S.current.touxiang,
S.current.yonghuming,
"个性签名",
4 years ago
S.current.wodeshengri,
S.current.shoujihao,
"性别",
4 years ago
];
///生日时期选择
4 years ago
showDateSelector() async {
4 years ago
DateTime dateTime = await showModalBottomSheet(
4 years ago
backgroundColor: Colors.transparent,
context: context,
4 years ago
builder: (_) {
4 years ago
return CupertinoDatePickerWidget();
});
if (dateTime != null) {
4 years ago
modifyInfo["birth"] = DateFormat("yyyy-MM-dd").format(dateTime);
user.birth = modifyInfo["birth"];
4 years ago
age = AppUtils.getAge(dateTime);
4 years ago
modifyInfos();
4 years ago
setState(() {});
}
}
///性别选择
showSexSelect(index) {
showModalBottomSheet(
context: context,
builder: (context) {
return StatefulBuilder(builder: (
context,
state,
) {
return Container(
width: double.infinity,
height: 200.h,
padding: EdgeInsets.only(top: 12.h),
decoration: BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.only(
topRight: Radius.circular(6),
topLeft: Radius.circular(6),
)),
child: Column(
children: [
Padding(
padding: EdgeInsets.symmetric(horizontal: 14.w),
child: Row(
children: [
Expanded(
child:GestureDetector(
behavior:HitTestBehavior.opaque,
onTap: (){
Navigator.of(context).pop();
},
child: Text(
S.of(context).quxiao,
style: TextStyle(
color: Colors.black,
fontSize: 16.sp,
fontWeight: MyFontWeight.black,
),
),
)),
GestureDetector(
behavior:HitTestBehavior.opaque,
onTap: (){
state((){
modifyInfo["sex"] = (selectSexIndex == 0)?"":"";
modifyInfos();
Navigator.of(context).pop();
});},
child: Text(
S.of(context).queding,
style: TextStyle(
color: Color(0xFF32A060),
fontSize: 16.sp,
fontWeight: MyFontWeight.black,
),
),
)
],
),
),
Container(
margin: EdgeInsets.only(top: 12.h, bottom: 13.h),
height: 1.h,
color: Color(0xFFF2F2F2)),
GestureDetector(
behavior:HitTestBehavior.opaque,
onTap: () {
state((){
selectSexIndex = 0;
});
},
child: Container(
width: double.infinity,
alignment: Alignment.center,
padding:
EdgeInsets.only(top:12.h, bottom:12.h, left: 12.w),
margin: EdgeInsets.symmetric(horizontal: 14.w),
decoration: BoxDecoration(
borderRadius:BorderRadius.circular(6),
border: Border.all(
color: selectSexIndex == 0 ? Color(0xFF32A060):Color(0xFFF7F7F7),
width: selectSexIndex == 0 ? 1 :0,
),
color: selectSexIndex == 0 ? Color(0xFFF0FAF4) :Color(0xFFF7F7F7),
),
child: Text(
"",
style: TextStyle(
color: selectSexIndex == 0? Color(0xFF32A060):Color(0xFF4D4D4D),
fontSize: 18.sp,
fontWeight: MyFontWeight.regular,
),
),
),
),
SizedBox(
height: 13.h,
),
GestureDetector(
behavior:HitTestBehavior.opaque,
onTap: () {
state((){
selectSexIndex = 1;
});
},
child: Container(
width: double.infinity,
alignment: Alignment.center,
padding:
EdgeInsets.only(top: 12.h, bottom: 12.h, left: 12.w),
margin: EdgeInsets.symmetric(horizontal: 14.w),
decoration: BoxDecoration(
borderRadius:BorderRadius.circular(6),
border: Border.all(
color: selectSexIndex == 1 ? Color(0xFF32A060):Color(0xFFF7F7F7),
width: selectSexIndex == 1 ? 1 :0,
),
color: selectSexIndex == 1 ? Color(0xFFF0FAF4) :Color(0xFFF7F7F7),
),
child: Text(
"",
style: TextStyle(
color: selectSexIndex == 1 ?Color(0xFF32A060):Color(0xFF4D4D4D),
fontSize: 18.sp,
fontWeight: MyFontWeight.regular,
),
)),
)
],
),
);
});
},
);
}
4 years ago
///显示图片选择方式
showImagePicker() {
showCupertinoModalPopup(
context: context,
builder: (contetx) {
return CupertinoActionSheet(
4 years ago
title: Text(S.of(context).genghuantouxiang),
4 years ago
actions: [
CupertinoActionSheetAction(
4 years ago
child: Text(S.of(context).paizhao),
4 years ago
onPressed: () {
openCamera();
Navigator.of(context).pop();
},
isDefaultAction: true,
isDestructiveAction: false,
),
CupertinoActionSheetAction(
4 years ago
child: Text(S.of(context).xiangce),
4 years ago
onPressed: () {
openStorage();
Navigator.of(context).pop();
},
isDefaultAction: true,
isDestructiveAction: false,
),
],
cancelButton: CupertinoActionSheetAction(
onPressed: () {
Navigator.of(context).pop();
},
4 years ago
child: Text(S.of(context).quxiao),
4 years ago
isDestructiveAction: true,
),
);
});
}
///拍照
openCamera() async {
if (await Permission.camera.isPermanentlyDenied) {
showCupertinoDialog(
context: context,
builder: (context) {
return RequestPermission(
"assets/image/icon_camera_permission_tips.webp",
S.of(context).ninxiangjiquanxianweikaiqi,
S.of(context).weilekaipaizhaoxuanzhetouxiang,
S.of(context).kaiqiquanxian,
(result) async {
if (result) {
await openAppSettings();
}
},
heightRatioWithWidth: 0.82,
);
});
}else if (await Permission.camera.isGranted) {
if (await Permission.storage.isPermanentlyDenied) {
showCupertinoDialog(
context: context,
builder: (context) {
return RequestPermission(
"assets/image/icon_storage_permission_tips.webp",
"您未开启存储权限,请点击开启",
"为了您可以在使用过程中访问您设备上的照片、媒体内容和文件,请您开启存储使用权限",
S.of(context).kaiqiquanxian,
(result) async {
if (result) {
await openAppSettings();
}
},
heightRatioWithWidth: 0.82,
);
});}else if(await Permission.storage.isGranted){
Media medias = await ImagePickers.openCamera(
cameraMimeType: CameraMimeType.photo,
cropConfig: CropConfig(
enableCrop: true,
width: 200,
height: 200,
),
compressSize: 500,
);
if (medias == null) return;
filePath = medias.path;
fileUpload();
}else{
showStorageTipsAlertDialog(context,1);
return false;
}
4 years ago
} else {
showCameraTipsAlertDialog(context);
return false;
// await Permission.camera.request();
// openCamera();
4 years ago
}
}
String filePath;
///打开相册
openStorage() async {
if (await Permission.storage.isPermanentlyDenied) {
showCupertinoDialog(
context: context,
builder: (context) {
return RequestPermission(
"assets/image/icon_storage_permission_tips.webp",
"您未开启存储权限,请点击开启",
"为了您可以在使用过程中访问您设备上的照片、媒体内容和文件,请您开启存储使用权限",
S.of(context).kaiqiquanxian,
(result) async {
if (result) {
await openAppSettings();
}
},
heightRatioWithWidth: 0.82,
);
});
}else if (await Permission.storage.isGranted) {
3 years ago
List<Media> medias = await ImagePickers.pickerPaths(
galleryMode: GalleryMode.image,
selectCount: 1,
showGif: true,
showCamera: false,
compressSize: 500,
uiConfig: UIConfig(
uiThemeColor: Color(0xFFFFFFFF),
),
cropConfig: CropConfig(
enableCrop: true,
width: 200,
height: 200,
),
);
if (medias == null || medias.length == 0) return;
filePath = medias[0].path;
4 years ago
setState(() {});
4 years ago
fileUpload();
} else {
showStorageTipsAlertDialog(context,0);
return false;
// await Permission.storage.request();
// openStorage();
}
}
///相册权限说明
showStorageTipsAlertDialog(context,type) async {
//显示对话框
showDialog(
context: context,
barrierDismissible: false,
barrierColor: null,
builder: (BuildContext context) {
return Column(
children: [
Container(
width: double.infinity,
padding: EdgeInsets.all(15),
margin: EdgeInsets.all(15),
decoration: new BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.circular(10),
),
child: Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(padding:EdgeInsets.only(right: 10.w,),
child: Icon(
Icons.add_photo_alternate_outlined,
color: Colors.black,
size: 22,
)),
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min,
children: [
Text(
"存储权限使用说明",
style: TextStyle(
fontSize: 18.sp,
fontWeight: MyFontWeight.regular,
color: Colors.black,
),
),
SizedBox(
height: 3.h,
),
Text(
"为了帮您实现分享照片、保存照片等功能。",
style: TextStyle(
fontSize: 13.sp,
height: 1.2,
fontWeight: MyFontWeight.regular,
color: Colors.black,
),
),
],
),
),
],
),
)
],
mainAxisSize: MainAxisSize.min,
);
},
);
await Permission.storage.request();
Navigator.of(context).pop();
if(await Permission.storage.isGranted){
if(type == 1){
openCamera();
}else{
openStorage();
}
}
}
///拍照权限说明
showCameraTipsAlertDialog(context) async {
//显示对话框
showDialog(
context: context,
barrierDismissible: false,
barrierColor: null,
builder: (BuildContext context) {
return Column(
children: [
Container(
width: double.infinity,
padding: EdgeInsets.all(15),
margin: EdgeInsets.all(15),
decoration: new BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.circular(10),
),
child: Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(padding:EdgeInsets.only(right: 10.w,),
child: Icon(
Icons.add_photo_alternate_outlined,
color: Colors.black,
size: 22,
)),
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min,
children: [
Text(
"相机权限使用说明",
style: TextStyle(
fontSize: 18.sp,
fontWeight: MyFontWeight.regular,
color: Colors.black,
),
),
SizedBox(
height: 3.h,
),
Text(
"实现您扫码、拍摄等功能。",
style: TextStyle(
fontSize: 13.sp,
height: 1.2,
fontWeight: MyFontWeight.regular,
color: Colors.black,
),
),
],
),
),
],
),
)
],
mainAxisSize: MainAxisSize.min,
);
},
);
await Permission.camera.request();
Navigator.of(context).pop();
if(await Permission.camera.isGranted){
openCamera();
4 years ago
}
}
3 years ago
// Future<File> cropImage(imagePath) async {
// File croppedFile = await ImageCropper.cropImage(
// sourcePath: imagePath,
// aspectRatioPresets: [
// CropAspectRatioPreset.square,
// // CropAspectRatioPreset.ratio3x2,
// // CropAspectRatioPreset.original,
// // CropAspectRatioPreset.ratio4x3,
// // CropAspectRatioPreset.ratio16x9
// ],
// aspectRatio: CropAspectRatio(ratioX: 1, ratioY: 1),
// androidUiSettings: AndroidUiSettings(
// toolbarTitle: 'Cropper',
// toolbarColor: Colors.black,
// toolbarWidgetColor: Colors.white,
// initAspectRatio: CropAspectRatioPreset.square,
// hideBottomControls: true,
// lockAspectRatio: false),
// iosUiSettings: IOSUiSettings(
// minimumAspectRatio: 1.0,
// resetAspectRatioEnabled: false,
// aspectRatioPickerButtonHidden: true,
// rectWidth: 500.w,
// rectHeight: 500.h,
// ));
// return croppedFile;
3 years ago
// }
4 years ago
4 years ago
///调用修改用户信息接口
modifyInfos() async {
3 years ago
var info = await apiService.editInfo(modifyInfo).catchError((onError) {});
4 years ago
if (info.isSuccess) {
SharedPreferences.getInstance().then((value) {
value.setString('user', jsonEncode(modifyInfo));
});
4 years ago
setState(() {
4 years ago
SmartDialog.showToast("用户信息修改成功", alignment: Alignment.center);
4 years ago
});
}else{
SmartDialog.showToast("用户信息修改失败 " + info.msg, alignment: Alignment.center);
4 years ago
}
}
///文件上传
fileUpload() async {
if (filePath != null && filePath != "" && await File(filePath).exists()) {
BaseData<UploadResult> baseData = await apiService
.upload(File(filePath), 123123123, false)
.catchError((onError) {});
4 years ago
if (baseData != null && baseData.isSuccess) {
3 years ago
UploadResult uploadResult = baseData.data;
4 years ago
modifyInfo["headimg"] = uploadResult.url;
modifyInfos();
}
}
}
4 years ago
Widget avatarItem(type, value) {
3 years ago
print("object: $value");
4 years ago
return Container(
child: Row(
children: [
Expanded(
child: Text(
itemLefts[type],
style: TextStyle(
fontWeight: FontWeight.bold,
3 years ago
fontSize: 15.sp,
color: Color(0xFF1A1A1A),
4 years ago
),
),
flex: 1,
),
buildValue(type, value),
if (type != 5 &&
type != 4 &&
type != 3 &&
(((modifyInfo["birth"] == "")) || type != 3))
valueEnd(),
4 years ago
],
),
);
}
Widget valueEnd() {
return Container(
child: Icon(
Icons.keyboard_arrow_right,
size: 20.sp,
));
4 years ago
}
Widget buildValue(type, value) {
if (type == 0) {
return ClipRRect(
borderRadius: BorderRadius.circular(4),
4 years ago
child: filePath == null || filePath == ""
? (modifyInfo["headimg"] != null && modifyInfo["headimg"] != ""
3 years ago
? MImage(
4 years ago
modifyInfo["headimg"],
3 years ago
width: 42,
height: 42,
4 years ago
fit: BoxFit.cover,
)
: Image.asset(
"assets/image/default_1.webp",
3 years ago
width: 42,
height: 42,
4 years ago
fit: BoxFit.cover,
))
: Image.file(
File(filePath),
3 years ago
width: 42,
height: 42,
4 years ago
fit: BoxFit.cover,
),
4 years ago
);
} else if (type == 1) {
return Text(
value,
maxLines: 1,
overflow: TextOverflow.ellipsis,
4 years ago
style: TextStyle(
3 years ago
fontWeight: MyFontWeight.regular,
fontSize: 13.sp,
color: Color(0xFF4D4D4D),
4 years ago
),
4 years ago
);
} else {
return Expanded(
child: Text(
4 years ago
value,
maxLines: 1,
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.right,
4 years ago
style: TextStyle(
3 years ago
fontWeight: MyFontWeight.regular,
fontSize: 13.sp,
color: Color(0xFF4D4D4D),
4 years ago
),
));
4 years ago
}
}
}