修改选择器样式
This commit is contained in:
15
assets/mhlangs/en_US.json
Normal file
15
assets/mhlangs/en_US.json
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"语言名称": "English",
|
||||||
|
"菜单": {
|
||||||
|
"首页": "Home",
|
||||||
|
"报告": "Reports",
|
||||||
|
"控制": "Control",
|
||||||
|
"我的": "Mine"
|
||||||
|
},
|
||||||
|
"标题": {
|
||||||
|
"智能床名称": "Smart Bed Name",
|
||||||
|
"设置": "Settings",
|
||||||
|
"详情": "Details",
|
||||||
|
"人员资料": "User Info"
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -8,6 +8,7 @@ import 'package:url_launcher/url_launcher.dart';
|
|||||||
import 'package:vbvs_app/common/color/app_uri_status.dart';
|
import 'package:vbvs_app/common/color/app_uri_status.dart';
|
||||||
import 'package:vbvs_app/common/util/FitTool.dart';
|
import 'package:vbvs_app/common/util/FitTool.dart';
|
||||||
import 'package:vbvs_app/component/tool/ClickableContainer.dart';
|
import 'package:vbvs_app/component/tool/ClickableContainer.dart';
|
||||||
|
import 'package:vbvs_app/controller/mh_controller/mh_language_controller.dart';
|
||||||
import 'package:vbvs_app/controller/setting/language/language_controller.dart';
|
import 'package:vbvs_app/controller/setting/language/language_controller.dart';
|
||||||
import 'package:vbvs_app/controller/theme_controller/ThemeController.dart';
|
import 'package:vbvs_app/controller/theme_controller/ThemeController.dart';
|
||||||
import 'package:vbvs_app/language/AppLanguage.dart';
|
import 'package:vbvs_app/language/AppLanguage.dart';
|
||||||
@@ -15,6 +16,7 @@ import 'package:vbvs_app/model/api_response.dart';
|
|||||||
|
|
||||||
ThemeController themeController = Get.find();
|
ThemeController themeController = Get.find();
|
||||||
LanguageController languageController = Get.find();
|
LanguageController languageController = Get.find();
|
||||||
|
MHLanguageController mhLanguageController = Get.find();
|
||||||
|
|
||||||
class MyUtils {
|
class MyUtils {
|
||||||
static String formatDate(DateTime dateTime) {
|
static String formatDate(DateTime dateTime) {
|
||||||
@@ -393,7 +395,6 @@ var returnIconButtomNew = ClickableContainer(
|
|||||||
// ),
|
// ),
|
||||||
// );
|
// );
|
||||||
|
|
||||||
|
|
||||||
var returnIconButtomAddCallback = (
|
var returnIconButtomAddCallback = (
|
||||||
VoidCallback? returnCallBack, {
|
VoidCallback? returnCallBack, {
|
||||||
bool enableBack = true,
|
bool enableBack = true,
|
||||||
|
|||||||
92
lib/controller/mh_controller/mh_language_controller.dart
Normal file
92
lib/controller/mh_controller/mh_language_controller.dart
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
|
import 'package:ef/ef.dart';
|
||||||
|
import 'package:flutter/services.dart';
|
||||||
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
import 'package:path/path.dart' as path;
|
||||||
|
import 'package:vbvs_app/language/AppLanguage.dart';
|
||||||
|
|
||||||
|
part 'mh_language_controller.g.dart'; // 由json_serializable自动生成的部分
|
||||||
|
|
||||||
|
@JsonSerializable()
|
||||||
|
class MHLanguageModel {
|
||||||
|
String? filename; // 语言文件名称
|
||||||
|
String? language_name; // 语言名称
|
||||||
|
bool? selected; // 是否选中
|
||||||
|
String? language_code; //语言简称
|
||||||
|
|
||||||
|
MHLanguageModel();
|
||||||
|
|
||||||
|
factory MHLanguageModel.fromJson(Map<String, dynamic> json) {
|
||||||
|
try {
|
||||||
|
return _$LanguageModelFromJson(json);
|
||||||
|
} catch (e) {
|
||||||
|
return MHLanguageModel(); // 或者返回一个带有错误信息的特定实例
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() => _$LanguageModelToJson(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
class MHLanguageController extends GetControllerEx<MHLanguageModel> {
|
||||||
|
LanguageController() {
|
||||||
|
attr = GetModel(MHLanguageModel()).obs;
|
||||||
|
}
|
||||||
|
|
||||||
|
RxList languageList = [].obs;
|
||||||
|
var selectLanguage = Rx<MHLanguageModel?>(null);
|
||||||
|
Future<void> initLanuageList() async {
|
||||||
|
try {
|
||||||
|
String currentLanguageCode = AppLanguage().getCurrentLanguageCode();
|
||||||
|
languageList.clear(); // 清空现有列表
|
||||||
|
|
||||||
|
// 1. 获取 assets/langs/ 目录下所有 .json 文件
|
||||||
|
final manifestContent = await rootBundle.loadString('AssetManifest.json');
|
||||||
|
final Map<String, dynamic> manifestMap = json.decode(manifestContent);
|
||||||
|
|
||||||
|
// 筛选出 langs 目录下的 .json 文件
|
||||||
|
final langFiles = manifestMap.keys
|
||||||
|
.where((String key) =>
|
||||||
|
key.startsWith('assets/mhlangs/') && key.endsWith('.json'))
|
||||||
|
.toList();
|
||||||
|
|
||||||
|
// 2. 遍历所有语言文件
|
||||||
|
for (final filePath in langFiles) {
|
||||||
|
try {
|
||||||
|
// 加载 JSON 文件内容
|
||||||
|
final jsonString = await rootBundle.loadString(filePath);
|
||||||
|
final jsonMap = json.decode(jsonString);
|
||||||
|
|
||||||
|
// 提取语言名称(假设 JSON 文件中有 "语言名称" 字段)
|
||||||
|
final languageName = jsonMap['语言名称'] as String? ??
|
||||||
|
path.basenameWithoutExtension(filePath);
|
||||||
|
|
||||||
|
// 3. 构造 LanguageModel 并添加到列表
|
||||||
|
final languageModel = MHLanguageModel()
|
||||||
|
..filename = path.basename(filePath) // 如 "zh-CN.json"
|
||||||
|
..language_name = languageName // 如 "简体中文"
|
||||||
|
..selected =
|
||||||
|
(path.basename(filePath) == '$currentLanguageCode.json')
|
||||||
|
..language_code =
|
||||||
|
path.basenameWithoutExtension(filePath); // 如 "zh-CN"
|
||||||
|
if (languageModel.selected == true) {
|
||||||
|
selectLanguage.value = languageModel;
|
||||||
|
}
|
||||||
|
languageList.add(languageModel);
|
||||||
|
} catch (e) {
|
||||||
|
print('加载语言文件失败: $filePath, 错误: $e');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
print("object");
|
||||||
|
} catch (e) {
|
||||||
|
print('初始化语言列表失败: $e');
|
||||||
|
// 可选:添加默认语言(如英文)作为后备
|
||||||
|
languageList.add(
|
||||||
|
MHLanguageModel()
|
||||||
|
..filename = 'en-US.json'
|
||||||
|
..language_name = 'English'
|
||||||
|
..selected = true, // 默认语言为选中状态
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
22
lib/controller/mh_controller/mh_language_controller.g.dart
Normal file
22
lib/controller/mh_controller/mh_language_controller.g.dart
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
// GENERATED CODE - DO NOT MODIFY BY HAND
|
||||||
|
|
||||||
|
part of 'mh_language_controller.dart';
|
||||||
|
|
||||||
|
// **************************************************************************
|
||||||
|
// JsonSerializableGenerator
|
||||||
|
// **************************************************************************
|
||||||
|
|
||||||
|
MHLanguageModel _$LanguageModelFromJson(Map<String, dynamic> json) =>
|
||||||
|
MHLanguageModel()
|
||||||
|
..filename = json['filename'] as String?
|
||||||
|
..language_name = json['language_name'] as String?
|
||||||
|
..selected = json['selected'] as bool?
|
||||||
|
..language_code = json['language_code'] as String?;
|
||||||
|
|
||||||
|
Map<String, dynamic> _$LanguageModelToJson(MHLanguageModel instance) =>
|
||||||
|
<String, dynamic>{
|
||||||
|
'filename': instance.filename,
|
||||||
|
'language_name': instance.language_name,
|
||||||
|
'selected': instance.selected,
|
||||||
|
'language_code': instance.language_code,
|
||||||
|
};
|
||||||
@@ -1,12 +1,17 @@
|
|||||||
import 'dart:io';
|
import 'dart:convert';
|
||||||
|
import 'package:EasyDartModule/EasyDartModule.dart';
|
||||||
import 'package:ef/ef.dart';
|
import 'package:ef/ef.dart';
|
||||||
import 'package:fluwx/fluwx.dart';
|
import 'package:fluwx/fluwx.dart';
|
||||||
|
import 'package:get_storage/get_storage.dart';
|
||||||
|
import 'package:img_picker/img_picker.dart';
|
||||||
import 'package:json_annotation/json_annotation.dart';
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
import 'package:dio/dio.dart' as dio;
|
||||||
import 'package:path/path.dart' as p;
|
import 'package:vbvs_app/common/color/ServiceConstant.dart';
|
||||||
|
import 'package:vbvs_app/common/color/app_uri_status.dart';
|
||||||
|
import 'package:vbvs_app/common/util/DailyLogUtils.dart';
|
||||||
|
import 'package:vbvs_app/common/util/MyUtils.dart';
|
||||||
import 'package:vbvs_app/controller/mh_controller/user_data.dart';
|
import 'package:vbvs_app/controller/mh_controller/user_data.dart';
|
||||||
|
import 'package:vbvs_app/model/api_response.dart';
|
||||||
part 'muser_info_controller.g.dart';
|
part 'muser_info_controller.g.dart';
|
||||||
|
|
||||||
@JsonSerializable()
|
@JsonSerializable()
|
||||||
@@ -43,135 +48,187 @@ class MUserInfoController extends GetControllerEx<MUserInfoModel> {
|
|||||||
attr = GetModel(MUserInfoModel()).obs;
|
attr = GetModel(MUserInfoModel()).obs;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Future<void> uploadImg() async {
|
List device_bind_status = [];
|
||||||
// final ImagePicker picker = ImagePicker();
|
int device_bind_flag = 0; //0。未初始化 1.已初始化
|
||||||
// final XFile? image = await picker.pickImage(source: ImageSource.gallery);
|
|
||||||
// final user = Supabase.instance.client.auth.currentUser;
|
|
||||||
// try {
|
|
||||||
// if (image != null) {
|
|
||||||
// int fileSize = await image.length(); // 获取图片大小,单位为字节
|
|
||||||
// if (fileSize > 1048576) {
|
|
||||||
// // 1 MB = 1024 * 1024 bytes
|
|
||||||
// showToast("头像图片不能超过1MB");
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
// final filePath = image.path; // 获取文件路径
|
|
||||||
// final fileExtension = p.extension(filePath); // 获取文件扩展名,包括点(.)
|
|
||||||
// // 获取当前日期并格式化为 yyyy-MM-dd
|
|
||||||
// final String folderName =
|
|
||||||
// DateFormat('yyyy-MM-dd').format(DateTime.now());
|
|
||||||
// final file = File(image.path);
|
|
||||||
// // 构造文件路径,文件会被上传到 record_img 文件夹下的当天日期文件夹
|
|
||||||
// var response = await ef.client.storage
|
|
||||||
// .from(model.img_bucket!)
|
|
||||||
// .upload('$folderName/${Uuid().v4()}$fileExtension', file);
|
|
||||||
// if (response != null) {
|
|
||||||
// String publicUrl =
|
|
||||||
// ef.client.storage.from(model.img_bucket!).getPublicUrl(response);
|
|
||||||
|
|
||||||
// print('文件上传成功: $response');
|
Future<ApiResponse> uploadImg() async {
|
||||||
// print('文件上传成功: $publicUrl');
|
EasyDartModule.logger.info("请求上传图片");
|
||||||
// String prefixToRemove = 'user/';
|
DailyLogUtils.writeLog("请求上传图片");
|
||||||
// // model.user!.tmpHead = model.user!.head;
|
final ImagePicker picker = ImagePicker();
|
||||||
// model.user!.tmpHead = publicUrl.startsWith(prefixToRemove)
|
final XFile? image = await picker.pickImage(source: ImageSource.gallery);
|
||||||
// ? response.substring(prefixToRemove.length)
|
try {
|
||||||
// : response;
|
ApiResponse apiResponse = ApiResponse(code: -1, msg: "我的.头像上传失败".tr);
|
||||||
// updateAll();
|
if (image != null) {
|
||||||
// }
|
int fileSize = await image.length(); // 获取图片大小,单位为字节
|
||||||
// print('/$model.img_bucket');
|
if (fileSize > 1048576 * 5) {
|
||||||
// } else {
|
apiResponse.msg = "我的.头像限制".tr;
|
||||||
// print('未选择图片');
|
return apiResponse;
|
||||||
// return;
|
}
|
||||||
// }
|
String serviceAddress = ServiceConstant.service_address;
|
||||||
// } catch (e) {
|
String serviceName = ServiceConstant.server_service;
|
||||||
// print('上传失败: $e');
|
String serviceApi = ServiceConstant.upload_file;
|
||||||
// }
|
String queryUrl = "${serviceAddress}${serviceName}${serviceApi}";
|
||||||
// }
|
String? language = "";
|
||||||
|
if (languageController.selectLanguage != null) {
|
||||||
|
language = languageController.selectLanguage.value!.language_code;
|
||||||
|
}
|
||||||
|
if (language != null && language.isNotEmpty) {
|
||||||
|
if (queryUrl.contains("?")) {
|
||||||
|
queryUrl += "&lang=$language";
|
||||||
|
} else {
|
||||||
|
queryUrl += "?lang=$language";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var formData = dio.FormData.fromMap({
|
||||||
|
"type": 1,
|
||||||
|
"file": await dio.MultipartFile.fromFile(
|
||||||
|
image.path, // 确保 image 是 File 类型
|
||||||
|
filename: image.path.split('/').last,
|
||||||
|
),
|
||||||
|
});
|
||||||
|
var response = await EasyDartModule.dio.post(queryUrl, data: formData);
|
||||||
|
if (response != null) {
|
||||||
|
var responseData = response.data is String
|
||||||
|
? jsonDecode(response.data)
|
||||||
|
: response.data;
|
||||||
|
ApiResponse res =
|
||||||
|
ApiResponse.fromJson(responseData, (object) => object);
|
||||||
|
MyUtils.formatResponse(apiResponse, "我的.上传成功".tr, "我的.头像上传失败".tr);
|
||||||
|
model.user!.tmpHead = res.data['path'];
|
||||||
|
updateAll();
|
||||||
|
return res;
|
||||||
|
} else {
|
||||||
|
return ApiResponse(code: -1, msg: "服务器.失败".tr);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
apiResponse.msg = "我的.未选择图片".tr;
|
||||||
|
return apiResponse;
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
EasyDartModule.logger.error("上传图片失败->$e");
|
||||||
|
DailyLogUtils.writeError("上传图片失败->$e");
|
||||||
|
return ApiResponse(code: -1, msg: "服务器.失败".tr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// updateData() {
|
//更新用户信息
|
||||||
// UserInfoController controller = Get.find();
|
Future<ApiResponse> updateData() async {
|
||||||
// UserRepository userRepository = UserRepository();
|
EasyDartModule.logger.info("更新用户资料");
|
||||||
// return userRepository.updateInfo(controller.model.user!);
|
DailyLogUtils.writeLog("更新用户资料");
|
||||||
// }
|
try {
|
||||||
|
ApiResponse apiResponse = ApiResponse(code: -1, msg: "我的.保存失败".tr);
|
||||||
|
UserModel user = model.user!;
|
||||||
|
if (user.tmpNickName == null || user.tmpNickName!.isEmpty) {
|
||||||
|
apiResponse.msg = "我的.昵称为空".tr;
|
||||||
|
return apiResponse;
|
||||||
|
}
|
||||||
|
String serviceAddress = ServiceConstant.service_address;
|
||||||
|
String serviceName = ServiceConstant.server_service;
|
||||||
|
String serviceApi = ServiceConstant.user_info;
|
||||||
|
String queryUrl = "${serviceAddress}${serviceName}${serviceApi}";
|
||||||
|
String? language = "";
|
||||||
|
if (languageController.selectLanguage != null) {
|
||||||
|
language = languageController.selectLanguage.value!.language_code;
|
||||||
|
}
|
||||||
|
if (language != null && language.isNotEmpty) {
|
||||||
|
if (queryUrl.contains("?")) {
|
||||||
|
queryUrl += "&lang=$language";
|
||||||
|
} else {
|
||||||
|
queryUrl += "?lang=$language";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
final data = {
|
||||||
|
"nickName": user.tmpNickName,
|
||||||
|
if (user.tmpHead != null && user.tmpHead!.isNotEmpty)
|
||||||
|
"avatar": user.tmpHead,
|
||||||
|
};
|
||||||
|
|
||||||
// autoLogin(String token) async {
|
var response =
|
||||||
// final UserInfoController userInfoController = Get.find();
|
await EasyDartModule.dio.put(queryUrl, data: jsonEncode(data));
|
||||||
// try {
|
if (apiResponse != null) {
|
||||||
// final Map<String, dynamic> requestBody = {
|
var responseData =
|
||||||
// 'token': token,
|
response.data is String ? jsonDecode(response.data) : response.data;
|
||||||
// };
|
ApiResponse res =
|
||||||
|
ApiResponse.fromJson(responseData, (object) => object);
|
||||||
|
MyUtils.formatResponse(res, "我的.保存成功".tr, "我的.保存失败".tr);
|
||||||
|
return res;
|
||||||
|
} else {
|
||||||
|
return ApiResponse(code: -1, msg: "服务器.失败".tr);
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
EasyDartModule.logger.info("更新用户资料失败->$e");
|
||||||
|
DailyLogUtils.writeLog("更新用户资料失败->$e");
|
||||||
|
return ApiResponse(code: -1, msg: "服务器.失败".tr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// var response = await ApiService.request
|
//查询用户信息
|
||||||
// .post("/api/auth/account/info/autoLogin", data: requestBody);
|
Future<ApiResponse> getUserInfo() async {
|
||||||
// if (response.statusCode == 200) {
|
EasyDartModule.logger.info("查询用户资料");
|
||||||
// if (response.data != null) {
|
DailyLogUtils.writeLog("查询用户资料");
|
||||||
// ApiResponse<UserModel> apiResponse = ApiResponse.fromJson(
|
try {
|
||||||
// response.data,
|
ApiResponse apiResponse = ApiResponse(code: -1, msg: "我的.查询失败".tr);
|
||||||
// (json) => UserModel.fromJson(json as Map<String, dynamic>));
|
String serviceAddress = ServiceConstant.service_address;
|
||||||
// if (apiResponse.code == HttpStatusCodes.ok) {
|
String serviceName = ServiceConstant.server_service;
|
||||||
// userInfoController.model.user = apiResponse.data;
|
String serviceApi = ServiceConstant.user_info;
|
||||||
// userInfoController.model.token = response.headers['token']!.first;
|
String queryUrl = "${serviceAddress}${serviceName}${serviceApi}";
|
||||||
// userInfoController.model.login = 1;
|
String? language = "";
|
||||||
|
if (languageController.selectLanguage != null) {
|
||||||
|
language = languageController.selectLanguage.value!.language_code;
|
||||||
|
}
|
||||||
|
if (language != null && language.isNotEmpty) {
|
||||||
|
if (queryUrl.contains("?")) {
|
||||||
|
queryUrl += "&lang=$language";
|
||||||
|
} else {
|
||||||
|
queryUrl += "?lang=$language";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var response = await EasyDartModule.dio.get(queryUrl);
|
||||||
|
if (response != null) {
|
||||||
|
var responseData =
|
||||||
|
response.data is String ? jsonDecode(response.data) : response.data;
|
||||||
|
ApiResponse res =
|
||||||
|
ApiResponse.fromJson(responseData, (object) => object);
|
||||||
|
MyUtils.formatResponse(apiResponse, "我的.保存成功".tr, "我的.保存失败".tr);
|
||||||
|
if (res.code == HttpStatusCodes.ok) {
|
||||||
|
MUserInfoController userInfoController = Get.find();
|
||||||
|
userInfoController.model.user = UserModel.fromJson(res.data);
|
||||||
|
final box = GetStorage();
|
||||||
|
box.write('user', userInfoController.model.user!.toJson()); // 存储用户信息
|
||||||
|
userInfoController.updateAll();
|
||||||
|
}
|
||||||
|
return apiResponse;
|
||||||
|
} else {
|
||||||
|
return ApiResponse(code: -1, msg: "服务器.失败".tr);
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
EasyDartModule.logger.info("更新用户资料失败->$e");
|
||||||
|
DailyLogUtils.writeLog("更新用户资料失败->$e");
|
||||||
|
return ApiResponse(code: -1, msg: "服务器.失败".tr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ApiResponse logOut() {
|
||||||
|
// ApiResponse apiResponse = ApiResponse(code: 1, msg: "设置页.退出成功".tr);
|
||||||
|
// EasyDartModule.logger.info("退出登录");
|
||||||
|
// DailyLogUtils.writeLog("退出登录");
|
||||||
|
// model.login = 0;
|
||||||
|
// EasyDartModule.dio.token = null;
|
||||||
// final box = GetStorage();
|
// final box = GetStorage();
|
||||||
// box.write(
|
// box.remove("user");
|
||||||
// 'user', userInfoController.model.user!.toJson()); // 存储用户信息
|
// box.remove("token");
|
||||||
// box.write('token', userInfoController.model.token); // 存储 token
|
// BodyDeviceController bodyDeviceController = Get.find();
|
||||||
// String efPd = await getValueBySysConfigKey(CommonVariables.efKey);
|
// bodyDeviceController.bindDeviceNum.value = 0;
|
||||||
// if (efPd != null && efPd.isNotEmpty) {
|
// HomeController homeController = Get.find();
|
||||||
// await initDataEf(key: efPd);
|
// homeController.sleepNum.value = 0;
|
||||||
// } else {
|
// LoginController loginController = Get.find();
|
||||||
// print("efPD为空,无法初始化");
|
// loginController.model.register_agree = null;
|
||||||
// // 清除本地缓存
|
// bodyDeviceController.sleepReportData.value = {};
|
||||||
// final box = GetStorage();
|
// MessageController messageController = Get.find();
|
||||||
// box.remove('user');
|
// messageController.model.body_message_read = 0;
|
||||||
// box.remove('token');
|
// messageController.model.system_message_read = 0;
|
||||||
// userInfoController.model.token = null;
|
// CountdownController countdownController = Get.find();
|
||||||
// userInfoController.model.user = null;
|
// countdownController.countdown.value = 0;
|
||||||
// // 设置成未登录
|
// return apiResponse;
|
||||||
// userInfoController.model.login = 0;
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// final AuthResponse res = await ef.client.auth.signInWithPassword(
|
|
||||||
// phone: userInfoController.model.user!.tel,
|
|
||||||
// password: userInfoController.model.user!.exp1!,
|
|
||||||
// );
|
|
||||||
// userInfoController.model.superbase_session = res.session;
|
|
||||||
// userInfoController.model.superbase_user = res.user;
|
|
||||||
// userInfoController.updateAll();
|
|
||||||
// // 登录成功移出网络检查监听
|
|
||||||
// Checknetwork.subscription?.cancel();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// } else {
|
|
||||||
// // 处理非 200 响应
|
|
||||||
// print('Failed to sign in. Status code: ${response.statusCode}');
|
|
||||||
// print('Response data: ${response.data}');
|
|
||||||
// }
|
|
||||||
// } catch (e) {
|
|
||||||
// e.printError();
|
|
||||||
// // 清除本地缓存
|
|
||||||
// final box = GetStorage();
|
|
||||||
// box.remove('user');
|
|
||||||
// box.remove('token');
|
|
||||||
// userInfoController.model.token = null;
|
|
||||||
// userInfoController.model.user = null;
|
|
||||||
// // 设置成未登录
|
|
||||||
// userInfoController.model.login = 0;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // 拉起微信企业客服
|
|
||||||
// Future<void> openWeChatCustomerService() async {
|
|
||||||
// bool isWeChatInstalled = await fluwx.isWeChatInstalled;
|
|
||||||
// if (!isWeChatInstalled) {
|
|
||||||
// showToast("请先安装微信APP,再联系客服", color: color_error);
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
// showToast('正在打开微信客服...', color: color_success);
|
|
||||||
// await fluwx.open(
|
|
||||||
// target: CustomerServiceChat(
|
|
||||||
// corpId: CommonVariables.wxCorpId, url: CommonVariables.wxKfUrl));
|
|
||||||
// }
|
// }
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -91,4 +91,5 @@ class LanguageController extends GetControllerEx<LanguageModel> {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ import 'package:vbvs_app/common/color/ServiceConstant.dart';
|
|||||||
import 'package:vbvs_app/common/util/CheckNetwork.dart';
|
import 'package:vbvs_app/common/util/CheckNetwork.dart';
|
||||||
import 'package:vbvs_app/common/util/CommonVariables.dart';
|
import 'package:vbvs_app/common/util/CommonVariables.dart';
|
||||||
import 'package:vbvs_app/common/util/FitTool.dart';
|
import 'package:vbvs_app/common/util/FitTool.dart';
|
||||||
|
import 'package:vbvs_app/common/util/requestWithLog.dart';
|
||||||
import 'package:vbvs_app/controller/date/CalendarController.dart';
|
import 'package:vbvs_app/controller/date/CalendarController.dart';
|
||||||
import 'package:vbvs_app/controller/device/blueteeth_bind_controller.dart';
|
import 'package:vbvs_app/controller/device/blueteeth_bind_controller.dart';
|
||||||
import 'package:vbvs_app/controller/device/body_device_controller.dart';
|
import 'package:vbvs_app/controller/device/body_device_controller.dart';
|
||||||
@@ -39,6 +40,7 @@ import 'package:vbvs_app/controller/mh_controller/find_password_controller.dart'
|
|||||||
import 'package:vbvs_app/controller/mh_controller/issue_controller.dart';
|
import 'package:vbvs_app/controller/mh_controller/issue_controller.dart';
|
||||||
import 'package:vbvs_app/controller/mh_controller/issue_preview_controller.dart';
|
import 'package:vbvs_app/controller/mh_controller/issue_preview_controller.dart';
|
||||||
import 'package:vbvs_app/controller/mh_controller/message_controller.dart';
|
import 'package:vbvs_app/controller/mh_controller/message_controller.dart';
|
||||||
|
import 'package:vbvs_app/controller/mh_controller/mh_language_controller.dart';
|
||||||
import 'package:vbvs_app/controller/mh_controller/muser_info_controller.dart';
|
import 'package:vbvs_app/controller/mh_controller/muser_info_controller.dart';
|
||||||
import 'package:vbvs_app/controller/mh_controller/my_experience_list_controller.dart';
|
import 'package:vbvs_app/controller/mh_controller/my_experience_list_controller.dart';
|
||||||
import 'package:vbvs_app/controller/mh_controller/people_info_controller.dart';
|
import 'package:vbvs_app/controller/mh_controller/people_info_controller.dart';
|
||||||
@@ -214,6 +216,59 @@ Future<void> initLogin() async {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//处理绑定未完成的数据
|
||||||
|
Future<void> dealBindProcess() async {
|
||||||
|
UserInfoController userInfoController = Get.find();
|
||||||
|
String serviceAddress = ServiceConstant.service_address;
|
||||||
|
String serviceName = ServiceConstant.server_service;
|
||||||
|
String serviceApi = ServiceConstant.device_list;
|
||||||
|
String queryUrl = "${serviceAddress}${serviceName}${serviceApi}?bindType=1";
|
||||||
|
userInfoController.device_bind_status = [];
|
||||||
|
|
||||||
|
try {
|
||||||
|
final res = await requestWithLog(
|
||||||
|
logTitle: "查询设备绑定列表",
|
||||||
|
method: MyHttpMethod.get,
|
||||||
|
queryUrl: queryUrl,
|
||||||
|
);
|
||||||
|
|
||||||
|
List data = res.data ?? [];
|
||||||
|
if (data.isNotEmpty) {
|
||||||
|
// 使用 Future.wait 等待所有设备的查询完成
|
||||||
|
await Future.wait(
|
||||||
|
data.map((element) async {
|
||||||
|
String mac = element['mac'];
|
||||||
|
String type = "device_bind_status_$mac";
|
||||||
|
String queryUrl =
|
||||||
|
"${serviceAddress}${serviceName}${ServiceConstant.user_setting}?type=${type}";
|
||||||
|
|
||||||
|
try {
|
||||||
|
final res = await requestWithLog(
|
||||||
|
logTitle: "查询绑定流程",
|
||||||
|
method: MyHttpMethod.get,
|
||||||
|
queryUrl: queryUrl,
|
||||||
|
);
|
||||||
|
|
||||||
|
if (res.data != null && res.data.isNotEmpty) {
|
||||||
|
bool celibration = res.data['celibration'];
|
||||||
|
bool person_info = res.data['person_info'];
|
||||||
|
bool wifi = res.data['wifi'];
|
||||||
|
if (!celibration || !person_info || !wifi) {
|
||||||
|
res.data['device_info'] = element;
|
||||||
|
userInfoController.device_bind_status.add(res.data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
print("查询绑定流程失败: $e");
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
print("查询设备绑定列表失败: $e");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
class MyApp extends StatelessWidget {
|
class MyApp extends StatelessWidget {
|
||||||
MyApp({super.key});
|
MyApp({super.key});
|
||||||
final ThemeController themeController = Get.put(ThemeController());
|
final ThemeController themeController = Get.put(ThemeController());
|
||||||
@@ -245,8 +300,10 @@ class MyApp extends StatelessWidget {
|
|||||||
Get.lazyPut(() => SleepingHabitController()),
|
Get.lazyPut(() => SleepingHabitController()),
|
||||||
Get.lazyPut(() => PeopleInfoController()),
|
Get.lazyPut(() => PeopleInfoController()),
|
||||||
Get.lazyPut(() => MainPageController()),
|
Get.lazyPut(() => MainPageController()),
|
||||||
|
Get.lazyPut(() => MHLanguageController()),
|
||||||
Get.lazyPut(() => AddressListController()),
|
Get.lazyPut(() => AddressListController()),
|
||||||
Get.lazyPut(() => AddressController()),
|
Get.lazyPut(() => AddressController()),
|
||||||
|
Get.lazyPut(() => MHLanguageController()),
|
||||||
Get.lazyPut(() => BlueteethBindController()),
|
Get.lazyPut(() => BlueteethBindController()),
|
||||||
Get.lazyPut(() => BookInfoController()),
|
Get.lazyPut(() => BookInfoController()),
|
||||||
Get.lazyPut(() => PersonController()),
|
Get.lazyPut(() => PersonController()),
|
||||||
|
|||||||
@@ -224,11 +224,11 @@ Future showDateSelectionDialog(BuildContext context,
|
|||||||
),
|
),
|
||||||
SizedBox(
|
SizedBox(
|
||||||
height: 240.rpx,
|
height: 240.rpx,
|
||||||
|
child: Padding(
|
||||||
|
padding: EdgeInsets.symmetric(horizontal: 95.rpx),
|
||||||
child: Row(
|
child: Row(
|
||||||
children: [
|
children: [
|
||||||
Expanded(
|
Expanded(
|
||||||
child: Padding(
|
|
||||||
padding: EdgeInsets.only(right: 30.rpx),
|
|
||||||
child: getOnePickers(
|
child: getOnePickers(
|
||||||
context,
|
context,
|
||||||
years,
|
years,
|
||||||
@@ -237,11 +237,7 @@ Future showDateSelectionDialog(BuildContext context,
|
|||||||
onChanged: (_) => updateDays(),
|
onChanged: (_) => updateDays(),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
|
||||||
Expanded(
|
Expanded(
|
||||||
child: Padding(
|
|
||||||
padding: EdgeInsets.symmetric(
|
|
||||||
horizontal: 30.rpx),
|
|
||||||
child: getOnePickers(
|
child: getOnePickers(
|
||||||
context,
|
context,
|
||||||
months,
|
months,
|
||||||
@@ -250,10 +246,7 @@ Future showDateSelectionDialog(BuildContext context,
|
|||||||
onChanged: (_) => updateDays(),
|
onChanged: (_) => updateDays(),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
|
||||||
Expanded(
|
Expanded(
|
||||||
child: Padding(
|
|
||||||
padding: EdgeInsets.only(left: 30.rpx),
|
|
||||||
child: getOnePickers(
|
child: getOnePickers(
|
||||||
context,
|
context,
|
||||||
daysSelect,
|
daysSelect,
|
||||||
@@ -261,10 +254,10 @@ Future showDateSelectionDialog(BuildContext context,
|
|||||||
unit: "日",
|
unit: "日",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
|
|||||||
@@ -3,25 +3,28 @@ import 'package:ef/ef.dart';
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:vbvs_app/common/util/FitTool.dart';
|
import 'package:vbvs_app/common/util/FitTool.dart';
|
||||||
import 'package:vbvs_app/common/util/MyUtils.dart';
|
import 'package:vbvs_app/common/util/MyUtils.dart';
|
||||||
|
import 'package:vbvs_app/controller/mh_controller/message_controller.dart';
|
||||||
|
|
||||||
class LanguagePage extends StatefulWidget {
|
import 'package:vbvs_app/controller/mh_controller/mh_language_controller.dart';
|
||||||
@override
|
|
||||||
_LanguagePageState createState() => _LanguagePageState();
|
|
||||||
}
|
|
||||||
|
|
||||||
BoxConstraints? bodysize;
|
class LanguagePage extends GetView<MHLanguageController> {
|
||||||
List<String> languageList = [
|
// @override
|
||||||
|
// _LanguagePageState createState() => _LanguagePageState();
|
||||||
|
// }
|
||||||
|
MHLanguageController controller = Get.find();
|
||||||
|
BoxConstraints? bodysize;
|
||||||
|
List<String> languageList = [
|
||||||
'简体中文',
|
'简体中文',
|
||||||
'繁體中文',
|
'繁體中文',
|
||||||
'English',
|
'English',
|
||||||
];
|
];
|
||||||
final Map<String, String> languageMap = {
|
final Map<String, String> languageMap = {
|
||||||
'简体中文': 'zh_CN',
|
'简体中文': 'zh_CN',
|
||||||
'繁體中文': 'zh_TW',
|
'繁體中文': 'zh_TW',
|
||||||
'English': 'en_US',
|
'English': 'en_US',
|
||||||
};
|
};
|
||||||
|
|
||||||
class _LanguagePageState extends State<LanguagePage> {
|
// class _LanguagePageState extends State<LanguagePage> {
|
||||||
RxBool checkboxValue = false.obs;
|
RxBool checkboxValue = false.obs;
|
||||||
RxString? selectLanguage = ''.obs;
|
RxString? selectLanguage = ''.obs;
|
||||||
@override
|
@override
|
||||||
@@ -93,14 +96,13 @@ class _LanguagePageState extends State<LanguagePage> {
|
|||||||
padding: EdgeInsets.zero,
|
padding: EdgeInsets.zero,
|
||||||
shrinkWrap: true,
|
shrinkWrap: true,
|
||||||
scrollDirection: Axis.vertical,
|
scrollDirection: Axis.vertical,
|
||||||
itemCount: languageList.length,
|
itemCount: controller.languageList.length,
|
||||||
itemBuilder:
|
itemBuilder:
|
||||||
(BuildContext context, int index) {
|
(BuildContext context, int index) {
|
||||||
return _buildItem(
|
return _buildItem(context, index,
|
||||||
context, index, languageList[index]);
|
controller.languageList[index]);
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
Container(height: bodysize!.maxHeight * 0.12)
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
))))),
|
))))),
|
||||||
@@ -108,7 +110,7 @@ class _LanguagePageState extends State<LanguagePage> {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget _buildItem(BuildContext context, int index, String text) {
|
Widget _buildItem(BuildContext context, int index, MHLanguageModel model) {
|
||||||
return Container(
|
return Container(
|
||||||
// width: bodysize!.maxWidth * 1,
|
// width: bodysize!.maxWidth * 1,
|
||||||
height: bodysize!.maxHeight * 0.055,
|
height: bodysize!.maxHeight * 0.055,
|
||||||
@@ -116,7 +118,7 @@ class _LanguagePageState extends State<LanguagePage> {
|
|||||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
children: [
|
children: [
|
||||||
Text(
|
Text(
|
||||||
text,
|
model.language_name ?? "",
|
||||||
style: TextStyle(color: Colors.white, fontSize: 30.rpx),
|
style: TextStyle(color: Colors.white, fontSize: 30.rpx),
|
||||||
),
|
),
|
||||||
Theme(
|
Theme(
|
||||||
@@ -132,15 +134,17 @@ class _LanguagePageState extends State<LanguagePage> {
|
|||||||
),
|
),
|
||||||
child: Obx(() {
|
child: Obx(() {
|
||||||
return Checkbox(
|
return Checkbox(
|
||||||
value: selectLanguage!.value == languageMap[text],
|
value: controller.selectLanguage.value?.language_code ==
|
||||||
|
model.language_code,
|
||||||
onChanged: (newValue) async {
|
onChanged: (newValue) async {
|
||||||
if (newValue!) {
|
controller.selectLanguage.value = model;
|
||||||
selectLanguage!.value = languageMap[
|
// if (newValue!) {
|
||||||
text]!; // Set selectLanguage to the current text value
|
// selectLanguage!.value = languageMap[
|
||||||
} else {
|
// text]!; // Set selectLanguage to the current text value
|
||||||
selectLanguage!.value =
|
// } else {
|
||||||
''; // Clear selection if unchecked
|
// selectLanguage!.value =
|
||||||
}
|
// ''; // Clear selection if unchecked
|
||||||
|
// }
|
||||||
},
|
},
|
||||||
shape: CircleBorder(),
|
shape: CircleBorder(),
|
||||||
side: BorderSide(
|
side: BorderSide(
|
||||||
|
|||||||
@@ -132,7 +132,7 @@ class _BluetoothState extends State<BluetoothPage> {
|
|||||||
_buildMenuButton(
|
_buildMenuButton(
|
||||||
context, '详情', "/devicePeopleInfo"),
|
context, '详情', "/devicePeopleInfo"),
|
||||||
_buildMenuButton(
|
_buildMenuButton(
|
||||||
context, '人员资料', "/devicePeopleInfo"),
|
context, '人员资料', "/peopleInfoPage"),
|
||||||
_buildMenuButton(
|
_buildMenuButton(
|
||||||
context, '房间选择', "/roomPickerPage"),
|
context, '房间选择', "/roomPickerPage"),
|
||||||
_buildMenuButton(
|
_buildMenuButton(
|
||||||
|
|||||||
@@ -709,7 +709,8 @@ class EditAddressPage extends GetView<AddressController>
|
|||||||
children: [
|
children: [
|
||||||
InkWell(
|
InkWell(
|
||||||
// onTap: () {
|
// onTap: () {
|
||||||
// CityPicker.show(
|
// CityPicker
|
||||||
|
// .show(
|
||||||
// context:
|
// context:
|
||||||
// context,
|
// context,
|
||||||
// cityPickerListener:
|
// cityPickerListener:
|
||||||
|
|||||||
@@ -1,26 +1,26 @@
|
|||||||
import 'package:ef/base/widget/flutterflow/FlutterFlowTheme.dart';
|
import 'package:ef/base/widget/flutterflow/FlutterFlowTheme.dart';
|
||||||
import 'package:ef/ef.dart';
|
import 'package:ef/ef.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:EasyDartModule/EasyDartModule.dart' as edm;
|
||||||
import 'package:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
|
import 'package:vbvs_app/common/color/app_uri_status.dart';
|
||||||
|
import 'package:vbvs_app/common/util/DailyLogUtils.dart';
|
||||||
import 'package:vbvs_app/common/util/FitTool.dart';
|
import 'package:vbvs_app/common/util/FitTool.dart';
|
||||||
import 'package:vbvs_app/common/util/MyUtils.dart';
|
import 'package:vbvs_app/common/util/MyUtils.dart';
|
||||||
|
import 'package:vbvs_app/component/tool/ClickableContainer.dart';
|
||||||
import 'package:vbvs_app/component/tool/CustomCard.dart';
|
import 'package:vbvs_app/component/tool/CustomCard.dart';
|
||||||
|
import 'package:vbvs_app/component/tool/TopSlideNotification.dart';
|
||||||
|
import 'package:vbvs_app/model/api_response.dart';
|
||||||
|
|
||||||
import '../../controller/mh_controller/muser_info_controller.dart';
|
import '../../controller/mh_controller/muser_info_controller.dart';
|
||||||
|
|
||||||
class EditUserInfoPage extends GetView<MUserInfoController> {
|
class EditUserInfoPage extends GetView<MUserInfoController> {
|
||||||
final scaffoldKey = GlobalKey<ScaffoldState>();
|
final scaffoldKey = GlobalKey<ScaffoldState>();
|
||||||
|
|
||||||
// EditUserInfoPage() {
|
|
||||||
// UserInfoController controller = Get.find();
|
|
||||||
// controller.model.user!.tmpHead = controller.model.user!.head;
|
|
||||||
// }
|
|
||||||
MUserInfoController controller = Get.find();
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
// UserInfoController controller = Get.find();
|
// UserInfoController controller = Get.find();
|
||||||
|
MUserInfoController userInfoController = Get.find();
|
||||||
return GestureDetector(
|
return GestureDetector(
|
||||||
onTap: () => FocusScope.of(context).unfocus(),
|
onTap: () => FocusScope.of(context).unfocus(),
|
||||||
child: Container(
|
child: Container(
|
||||||
@@ -118,8 +118,25 @@ class EditUserInfoPage extends GetView<MUserInfoController> {
|
|||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Padding(
|
ClickableContainer(
|
||||||
padding: EdgeInsets.only(top: 44.rpx),
|
backgroundColor: Colors.transparent,
|
||||||
|
highlightColor: Colors.transparent,
|
||||||
|
padding: EdgeInsets.only(top: 44.rpx, bottom: 44.rpx),
|
||||||
|
onTap: () async {
|
||||||
|
edm.EasyDartModule.logger
|
||||||
|
.info("${userInfoController.model.user!}点击上传头像");
|
||||||
|
DailyLogUtils.writeLog(
|
||||||
|
"${userInfoController.model.user!}点击上传头像");
|
||||||
|
ApiResponse apiResponse =
|
||||||
|
await userInfoController.uploadImg();
|
||||||
|
TopSlideNotification.show(
|
||||||
|
context,
|
||||||
|
text: apiResponse.msg!,
|
||||||
|
textColor: apiResponse.code == HttpStatusCodes.ok
|
||||||
|
? themeController.currentColor.sc2
|
||||||
|
: themeController.currentColor.sc9,
|
||||||
|
);
|
||||||
|
},
|
||||||
child: Text(
|
child: Text(
|
||||||
'点击更换头像',
|
'点击更换头像',
|
||||||
style:
|
style:
|
||||||
@@ -127,8 +144,7 @@ class EditUserInfoPage extends GetView<MUserInfoController> {
|
|||||||
),
|
),
|
||||||
),
|
),
|
||||||
Padding(
|
Padding(
|
||||||
padding:
|
padding: EdgeInsets.fromLTRB(60.rpx, 78.rpx, 60.rpx, 0.rpx),
|
||||||
EdgeInsets.fromLTRB(60.rpx, 122.rpx, 60.rpx, 0.rpx),
|
|
||||||
child: Container(
|
child: Container(
|
||||||
width: double.infinity,
|
width: double.infinity,
|
||||||
height: 88.rpx,
|
height: 88.rpx,
|
||||||
@@ -143,7 +159,7 @@ class EditUserInfoPage extends GetView<MUserInfoController> {
|
|||||||
alignment: Alignment(0, 0),
|
alignment: Alignment(0, 0),
|
||||||
child: TextField(
|
child: TextField(
|
||||||
obscureText: false,
|
obscureText: false,
|
||||||
keyboardType: TextInputType.number,
|
keyboardType: TextInputType.text,
|
||||||
textInputAction: TextInputAction.done,
|
textInputAction: TextInputAction.done,
|
||||||
textAlign: TextAlign.center,
|
textAlign: TextAlign.center,
|
||||||
style: TextStyle(fontSize: 30.rpx, color: Colors.white),
|
style: TextStyle(fontSize: 30.rpx, color: Colors.white),
|
||||||
@@ -153,7 +169,7 @@ class EditUserInfoPage extends GetView<MUserInfoController> {
|
|||||||
hintText: "请输入昵称",
|
hintText: "请输入昵称",
|
||||||
hintStyle: TextStyle(color: Colors.white),
|
hintStyle: TextStyle(color: Colors.white),
|
||||||
border: InputBorder.none,
|
border: InputBorder.none,
|
||||||
contentPadding: EdgeInsets.all(0)),
|
contentPadding: EdgeInsets.only(bottom: 10.rpx)),
|
||||||
onChanged: (value) {
|
onChanged: (value) {
|
||||||
controller.model.user?.nickName = value;
|
controller.model.user?.nickName = value;
|
||||||
controller.updateAll();
|
controller.updateAll();
|
||||||
@@ -180,53 +196,32 @@ class EditUserInfoPage extends GetView<MUserInfoController> {
|
|||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Widget getImageWidget(BuildContext context) {
|
Widget getImageWidget(BuildContext context) {
|
||||||
// try {
|
try {
|
||||||
// UserInfoController controller = Get.find();
|
MUserInfoController controller = Get.find();
|
||||||
|
var head = controller.model.user!.tmpHead;
|
||||||
// var head = controller.model.user!.tmpHead;
|
return Container(
|
||||||
// return InkWell(
|
width: 200.rpx,
|
||||||
// onTap: () {
|
height: 200.rpx,
|
||||||
// controller.uploadImg();
|
child: Container(
|
||||||
// },
|
clipBehavior: Clip.antiAlias,
|
||||||
// child: Row(
|
decoration: BoxDecoration(
|
||||||
// children: [
|
shape: BoxShape.circle,
|
||||||
// Container(
|
),
|
||||||
// width: 50,
|
child: head == null || head.isEmpty
|
||||||
// height: 50,
|
? Image.asset(
|
||||||
// decoration: BoxDecoration(
|
'assets/img/avatar.png',
|
||||||
// color: FlutterFlowTheme.of(context).secondaryBackground,
|
fit: BoxFit.cover,
|
||||||
// ),
|
)
|
||||||
// child: Container(
|
: Image.network(
|
||||||
// width: 120,
|
head,
|
||||||
// height: 120,
|
fit: BoxFit.cover,
|
||||||
// clipBehavior: Clip.antiAlias,
|
),
|
||||||
// decoration: BoxDecoration(
|
),
|
||||||
// shape: BoxShape.circle,
|
);
|
||||||
// ),
|
} catch (e) {
|
||||||
// child: head == null || head.isEmpty
|
print(e);
|
||||||
// ? Image.asset(
|
}
|
||||||
// 'assets/images/avatar.png',
|
return Container();
|
||||||
// fit: BoxFit.cover,
|
}
|
||||||
// )
|
|
||||||
// : Image.network(
|
|
||||||
// "${getStorageResourceUrl(head)}",
|
|
||||||
// fit: BoxFit.cover,
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// SizedBox(width: 10),
|
|
||||||
// Icon(
|
|
||||||
// Icons.arrow_forward_ios,
|
|
||||||
// color: Color(0xFF373737),
|
|
||||||
// size: 12,
|
|
||||||
// ),
|
|
||||||
// ],
|
|
||||||
// ),
|
|
||||||
// );
|
|
||||||
// } catch (e) {
|
|
||||||
// print(e);
|
|
||||||
// }
|
|
||||||
// return Container();
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -107,7 +107,7 @@ class _MinePageState extends State<NewMinePage> {
|
|||||||
highlightColor: Colors.transparent,
|
highlightColor: Colors.transparent,
|
||||||
padding: EdgeInsets.only(right: 11.rpx),
|
padding: EdgeInsets.only(right: 11.rpx),
|
||||||
onTap: () {
|
onTap: () {
|
||||||
Get.toNamed("/peopleInfoPage");
|
|
||||||
},
|
},
|
||||||
child: Container(
|
child: Container(
|
||||||
height: 42.rpx,
|
height: 42.rpx,
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import 'package:vbvs_app/common/util/MyUtils.dart';
|
|||||||
import 'package:vbvs_app/component/tool/ClickableContainer.dart';
|
import 'package:vbvs_app/component/tool/ClickableContainer.dart';
|
||||||
import 'package:vbvs_app/component/tool/CustomCard.dart';
|
import 'package:vbvs_app/component/tool/CustomCard.dart';
|
||||||
import 'package:vbvs_app/component/tool/TopSlideNotification.dart';
|
import 'package:vbvs_app/component/tool/TopSlideNotification.dart';
|
||||||
|
import 'package:vbvs_app/controller/mh_controller/mh_language_controller.dart';
|
||||||
|
|
||||||
class SettingPage extends StatefulWidget {
|
class SettingPage extends StatefulWidget {
|
||||||
@override
|
@override
|
||||||
@@ -15,6 +16,13 @@ class SettingPage extends StatefulWidget {
|
|||||||
}
|
}
|
||||||
|
|
||||||
class _SettingPageState extends State<SettingPage> {
|
class _SettingPageState extends State<SettingPage> {
|
||||||
|
MHLanguageController languageController = Get.find();
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
languageController.initLanuageList();
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return LayoutBuilder(builder: (context, bodySize) {
|
return LayoutBuilder(builder: (context, bodySize) {
|
||||||
@@ -248,8 +256,9 @@ class _SettingPageState extends State<SettingPage> {
|
|||||||
return Text(
|
return Text(
|
||||||
languageController
|
languageController
|
||||||
.selectLanguage
|
.selectLanguage
|
||||||
.value!
|
.value
|
||||||
.language_name!,
|
?.language_name ??
|
||||||
|
'简体中文',
|
||||||
style: FlutterFlowTheme.of(
|
style: FlutterFlowTheme.of(
|
||||||
context)
|
context)
|
||||||
.bodyMedium
|
.bodyMedium
|
||||||
@@ -263,16 +272,15 @@ class _SettingPageState extends State<SettingPage> {
|
|||||||
),
|
),
|
||||||
);
|
);
|
||||||
}),
|
}),
|
||||||
|
SvgPicture.asset(
|
||||||
// SvgPicture.asset(
|
'assets/img/icon/arrow_right.svg',
|
||||||
// 'assets/img/icon/arrow_right.svg',
|
width: 8.rpx,
|
||||||
// width: 8.rpx,
|
height: 15
|
||||||
// height: 15
|
.rpx, // 如果 SVG 中没有固定颜色,可以这样设置
|
||||||
// .rpx, // 如果 SVG 中没有固定颜色,可以这样设置
|
color: themeController
|
||||||
// color: themeController
|
.currentColor.sc3,
|
||||||
// .currentColor.sc3,
|
),
|
||||||
// ),
|
].divide(SizedBox(width: 22.rpx)),
|
||||||
].divide(SizedBox(width: 28.rpx)),
|
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
@@ -286,10 +294,7 @@ class _SettingPageState extends State<SettingPage> {
|
|||||||
.currentColor.sc21, // 点击时的背景色
|
.currentColor.sc21, // 点击时的背景色
|
||||||
padding: EdgeInsetsDirectional.fromSTEB(
|
padding: EdgeInsetsDirectional.fromSTEB(
|
||||||
0.rpx, 0.rpx, 0.rpx, 0.rpx),
|
0.rpx, 0.rpx, 0.rpx, 0.rpx),
|
||||||
onTap: () {
|
onTap: () {},
|
||||||
print('点击了容器');
|
|
||||||
Get.toNamed("/aboutUsPage");
|
|
||||||
},
|
|
||||||
child: Container(
|
child: Container(
|
||||||
child: Padding(
|
child: Padding(
|
||||||
padding: EdgeInsetsDirectional.fromSTEB(
|
padding: EdgeInsetsDirectional.fromSTEB(
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ import 'package:vbvs_app/common/util/MyUtils.dart';
|
|||||||
import 'package:vbvs_app/component/tool/CustomCard.dart';
|
import 'package:vbvs_app/component/tool/CustomCard.dart';
|
||||||
import 'package:vbvs_app/controller/main_bottom/global_controller.dart';
|
import 'package:vbvs_app/controller/main_bottom/global_controller.dart';
|
||||||
import 'package:vbvs_app/controller/mh_controller/people_info_controller.dart';
|
import 'package:vbvs_app/controller/mh_controller/people_info_controller.dart';
|
||||||
|
|
||||||
import 'package:vbvs_app/pages/common/selectDialog.dart';
|
import 'package:vbvs_app/pages/common/selectDialog.dart';
|
||||||
|
|
||||||
class PeopleInfoPage extends StatefulWidget {
|
class PeopleInfoPage extends StatefulWidget {
|
||||||
@@ -269,7 +270,6 @@ class _PeopleInfoState extends State<PeopleInfoPage> {
|
|||||||
),
|
),
|
||||||
),
|
),
|
||||||
getLine(),
|
getLine(),
|
||||||
|
|
||||||
Container(
|
Container(
|
||||||
width: double.infinity,
|
width: double.infinity,
|
||||||
height: MediaQuery.sizeOf(context).height *
|
height: MediaQuery.sizeOf(context).height *
|
||||||
|
|||||||
Reference in New Issue
Block a user