import 'dart:convert'; import 'dart:io'; import 'package:dio/dio.dart'; import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import 'package:flutter_smart_dialog/flutter_smart_dialog.dart'; import 'package:huixiang/generated/l10n.dart'; import 'package:huixiang/data/base_data.dart'; import 'package:huixiang/data/upload_result.dart'; import 'package:huixiang/data/user_info.dart'; import 'package:huixiang/retrofit/retrofit_api.dart'; import 'package:huixiang/utils/flutter_utils.dart'; import 'package:huixiang/utils/font_weight.dart'; import 'package:huixiang/utils/shared_preference.dart'; import 'package:huixiang/view_widget/cupertino_date_picker.dart'; import 'package:huixiang/view_widget/custom_image.dart'; import 'package:huixiang/view_widget/my_appbar.dart'; import 'package:image_pickers/image_pickers.dart'; import 'package:intl/intl.dart'; import 'package:permission_handler/permission_handler.dart'; import 'package:shared_preferences/shared_preferences.dart'; import 'package:flutter_screenutil/flutter_screenutil.dart'; class UserInfoPage extends StatefulWidget { @override State createState() { return _UserInfoPage(); } } class _UserInfoPage extends State { ApiService? apiService; Map modifyInfo = { "birth": "", "headimg": "", "nickname": "", "sex": "", "signature": "" }; @override void initState() { super.initState(); String userStr = SharedInstance.instance.userJson; if (userStr.isNotEmpty) { print(userStr); user = UserInfo.fromJson(jsonDecode(userStr!)); 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 ?? ""); refresh(); apiService = ApiService(Dio(), context: context, token: SharedInstance.instance.token); } } String? age; String mobile = ""; String locale = "zh"; UserInfo? user; int selectSexIndex = 0; refresh() async { setState(() {}); } @override Widget build(BuildContext context) { return Scaffold( backgroundColor: Color(0xFFFFFFFF), appBar: MyAppBar( title: S.of(context).gerenxinxi, titleColor: Colors.black, background: Color(0xFFFFFFFF), leadingColor: Colors.black, ), 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), child: Column( children: [ InkWell( onTap: () { showImagePicker(); }, child: avatarItem(0, ""), ), Container( margin: EdgeInsets.symmetric(vertical: 12.h), width: double.infinity, height: 1, color: Color(0xFFF2F2F2), ), InkWell( onTap: () { editname(); }, child: avatarItem(1, (modifyInfo["nickname"]) == "" ? "回乡" : modifyInfo["nickname"]), ), 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"]), ), Container( margin: EdgeInsets.symmetric(vertical: 12.h), width: double.infinity, height: 1, color: Color(0xFFF2F2F2), ), InkWell( onTap: (modifyInfo["birth"] == "") ? showDateSelector : () {}, child: avatarItem( 3, (modifyInfo["birth"] != null && modifyInfo["birth"] != "") ? modifyInfo["birth"] : S.of(context).wanshanshengrixinxi_yhq), ), Container( margin: EdgeInsets.symmetric(vertical: 12.h), width: double.infinity, height: 1, color: Color(0xFFF2F2F2), ), avatarItem(4, mobile), 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"]:"还未选择性别"), ), ], ), ); } editname() async { dynamic name = await Navigator.of(context).pushNamed('/router/edit_name', arguments: {"nick": modifyInfo['nickname']}); if (name != null && name != "") { 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(); } } List itemLefts = [ S.current.touxiang, S.current.yonghuming, "个性签名", S.current.wodeshengri, S.current.shoujihao, "性别", ]; ///生日时期选择 showDateSelector() async { DateTime dateTime = await showModalBottomSheet( backgroundColor: Colors.transparent, context: context, builder: (_) { return CupertinoDatePickerWidget(); }); modifyInfo["birth"] = DateFormat("yyyy-MM-dd").format(dateTime); user?.birth = modifyInfo["birth"]; age = AppUtils.getAge(dateTime); modifyInfos(); 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, ), )), ) ], ), ); }); }, ); } ///显示图片选择方式 showImagePicker() { showCupertinoModalPopup( context: context, builder: (contetx) { return CupertinoActionSheet( title: Text(S.of(context).genghuantouxiang), actions: [ CupertinoActionSheetAction( child: Text(S.of(context).paizhao), onPressed: () { openCamera(); Navigator.of(context).pop(); }, isDefaultAction: true, isDestructiveAction: false, ), CupertinoActionSheetAction( child: Text(S.of(context).xiangce), onPressed: () { openStorage(); Navigator.of(context).pop(); }, isDefaultAction: true, isDestructiveAction: false, ), ], cancelButton: CupertinoActionSheetAction( onPressed: () { Navigator.of(context).pop(); }, child: Text(S.of(context).quxiao), isDestructiveAction: true, ), ); }); } ///拍照 openCamera() async { if (await Permission.camera.isGranted) { Media? medias = await ImagePickers.openCamera( cameraMimeType: CameraMimeType.photo, cropConfig: CropConfig( enableCrop: true, width: 200, height: 200, ), compressSize: 500, ); filePath = medias?.path; fileUpload(); } else { await Permission.camera.request(); openCamera(); } } String? filePath; ///打开相册 openStorage() async { if (await Permission.storage.isGranted) { List 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.length == 0) return; filePath = medias[0].path; setState(() {}); fileUpload(); } else { await Permission.storage.request(); openStorage(); } } // Future 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; // } ///调用修改用户信息接口 modifyInfos() async { var info = await apiService?.editInfo(modifyInfo).catchError((error) { return BaseData(msg: error)..isSuccess = false; }); if (info?.isSuccess ?? false) { SharedPreferences.getInstance().then((value) { value.setString('user', jsonEncode(modifyInfo)); }); setState(() { SmartDialog.showToast("用户信息修改成功", alignment: Alignment.center); }); } else { SmartDialog.showToast("用户信息修改失败 ${info?.msg}", alignment: Alignment.center); } } ///文件上传 fileUpload() async { if ((filePath?.isNotEmpty ?? false) && await File(filePath!).exists()) { BaseData? baseData = await apiService?.upload(File(filePath!), 123123123, false) .catchError((onError) { return BaseData()..isSuccess = false; }); if (baseData?.isSuccess ?? false) { UploadResult? uploadResult = baseData!.data; modifyInfo["headimg"] = uploadResult?.url; modifyInfos(); } } } Widget avatarItem(type, value) { print("object: $value"); return Container( child: Row( children: [ Expanded( child: Text( itemLefts[type], style: TextStyle( fontWeight: FontWeight.bold, fontSize: 15.sp, color: Color(0xFF1A1A1A), ), ), flex: 1, ), buildValue(type, value), if (type != 5 && type != 4 && type != 3 && (((modifyInfo["birth"] == "")) || type != 3)) valueEnd(), ], ), ); } Widget valueEnd() { return Container( child: Icon( Icons.keyboard_arrow_right, size: 20.sp, ), ); } Widget buildValue(type, value) { if (type == 0) { return ClipRRect( borderRadius: BorderRadius.circular(4), child: (filePath?.isEmpty ?? true) ? (modifyInfo["headimg"] != null && modifyInfo["headimg"] != "" ? MImage( modifyInfo["headimg"], width: 42, height: 42, fit: BoxFit.cover, ) : Image.asset( "assets/image/default_1.webp", width: 42, height: 42, fit: BoxFit.cover, )) : Image.file( File(filePath!), width: 42, height: 42, fit: BoxFit.cover, ), ); } else if (type == 1) { return Text( value, maxLines: 1, overflow: TextOverflow.ellipsis, style: TextStyle( fontWeight: MyFontWeight.regular, fontSize: 13.sp, color: Color(0xFF4D4D4D), ), ); } else { return Expanded( child: Text( value, maxLines: 1, overflow: TextOverflow.ellipsis, textAlign: TextAlign.right, style: TextStyle( fontWeight: MyFontWeight.regular, fontSize: 13.sp, color: Color(0xFF4D4D4D), ), )); } } }