查询数据
This commit is contained in:
@@ -2,14 +2,17 @@ import 'package:flutter/material.dart';
|
||||
import 'package:get/get.dart';
|
||||
import 'package:getx_scaffold/common/common.dart';
|
||||
import 'package:getx_scaffold/common/services/http.dart';
|
||||
import 'package:getx_scaffold/getx_scaffold.dart';
|
||||
import 'package:intl/intl.dart';
|
||||
import 'package:ln_jq_app/common/model/base_model.dart';
|
||||
import 'package:ln_jq_app/common/styles/theme.dart';
|
||||
import 'package:ln_jq_app/pages/b_page/site/controller.dart';
|
||||
import 'package:ln_jq_app/storage_service.dart'; // 用于日期格式化
|
||||
import 'package:ln_jq_app/storage_service.dart';
|
||||
|
||||
class ReservationController extends GetxController {
|
||||
/// --- 状态变量 ---
|
||||
import '../../../common/styles/theme.dart'; // 用于日期格式化
|
||||
|
||||
class ReservationController extends GetxController with BaseControllerMixin {
|
||||
@override
|
||||
String get builderId => 'reservation';
|
||||
|
||||
// 【修改】使用 Rx 变量,让 GetX 的 Obx/GetX 能够自动监听变化,UI更新更简单
|
||||
// 日期,默认为今天
|
||||
@@ -27,7 +30,7 @@ class ReservationController extends GetxController {
|
||||
final TextEditingController amountController = TextEditingController();
|
||||
|
||||
// 车牌号
|
||||
final TextEditingController plateNumberController = TextEditingController();
|
||||
final TextEditingController plateNumberController = TextEditingController(text: "浙F");
|
||||
|
||||
// 加氢站
|
||||
final List<String> stationOptions = [
|
||||
@@ -152,7 +155,6 @@ class ReservationController extends GetxController {
|
||||
},
|
||||
);
|
||||
|
||||
// 安全校验
|
||||
if (response == null || response.data == null) {
|
||||
showToast('暂时无法获取预约数据');
|
||||
hasReservationData = false;
|
||||
@@ -163,12 +165,8 @@ class ReservationController extends GetxController {
|
||||
final baseModel = BaseModel<dynamic>.fromJson(response.data);
|
||||
|
||||
if (baseModel.code == 0 && baseModel.data != null) {
|
||||
// 【核心修改】处理接口返回的列表数据
|
||||
final dataMap = baseModel.data as Map<String, dynamic>;
|
||||
|
||||
final List<dynamic> listFromServer = dataMap['list'] ?? [];
|
||||
|
||||
// 使用 .map() 遍历列表,将每个 item 转换为一个 ReservationModel 对象
|
||||
reservationList = listFromServer.map((item) {
|
||||
return ReservationModel.fromJson(item as Map<String, dynamic>);
|
||||
}).toList();
|
||||
@@ -176,18 +174,15 @@ class ReservationController extends GetxController {
|
||||
// 根据列表是否为空来更新 hasReservationData 状态
|
||||
hasReservationData = reservationList.isNotEmpty;
|
||||
} else {
|
||||
// 接口返回业务错误
|
||||
showToast(baseModel.message);
|
||||
hasReservationData = false;
|
||||
reservationList = []; // 清空列表
|
||||
}
|
||||
} catch (e) {
|
||||
// 捕获网络或解析异常
|
||||
showToast('获取预约数据失败');
|
||||
hasReservationData = false;
|
||||
reservationList = []; // 清空列表
|
||||
} finally {
|
||||
// 无论成功失败,最后都要关闭加载动画并更新UI
|
||||
dismissLoading();
|
||||
}
|
||||
|
||||
@@ -344,6 +339,103 @@ class ReservationController extends GetxController {
|
||||
);
|
||||
}
|
||||
|
||||
String phone = "";
|
||||
String name = "";
|
||||
String leftHydrogen = "";
|
||||
String workEfficiency = "";
|
||||
//累计数据
|
||||
String fillingWeight = "";
|
||||
String fillingTimes = "";
|
||||
String plateNumber = "沪AGZ8967";
|
||||
|
||||
@override
|
||||
void onInit() {
|
||||
phone = StorageService.to.phone ?? "";
|
||||
name = StorageService.to.name ?? "";
|
||||
|
||||
getCatinfo();
|
||||
getJqinfo();
|
||||
// getSiteList();
|
||||
super.onInit();
|
||||
}
|
||||
|
||||
void getJqinfo() async {
|
||||
try {
|
||||
HttpService.to.setBaseUrl(AppTheme.test_service_url);
|
||||
var responseData = await HttpService.to.get(
|
||||
'appointment/truck/history-filling-summary?vin=LSFGL23Z2ND214377'
|
||||
);
|
||||
if (responseData == null || responseData.data == null) {
|
||||
showToast('服务暂不可用,请稍后');
|
||||
return;
|
||||
}
|
||||
|
||||
var result = BaseModel.fromJson(responseData.data);
|
||||
|
||||
fillingWeight = "${result.data["fillingWeight"]}${result.data["fillingWeightUnit"]}";
|
||||
fillingTimes = "${result.data["fillingTimes"]}${result.data["fillingTimesUnit"]}";
|
||||
|
||||
updateUi();
|
||||
} catch (e) {
|
||||
} finally {
|
||||
HttpService.to.setBaseUrl(AppTheme.test_service_url);
|
||||
}
|
||||
}
|
||||
|
||||
void getCatinfo() async {
|
||||
try {
|
||||
HttpService.to.setBaseUrl(AppTheme.car_service_url);
|
||||
var responseData = await HttpService.to.post(
|
||||
'VehicleData/getHydrogenInfoByPlateNumber',
|
||||
data: {
|
||||
'userName': "xll@lingniu",
|
||||
'password': "4q%3!l6s0p",
|
||||
'plateNumber': plateNumber,
|
||||
},
|
||||
);
|
||||
if (responseData == null || responseData.data == null) {
|
||||
showToast('服务暂不可用,请稍后');
|
||||
return;
|
||||
}
|
||||
|
||||
var result = BaseModel.fromJson(responseData.data);
|
||||
|
||||
leftHydrogen = result.data["leftHydrogen"].toString();
|
||||
workEfficiency = result.data["workEfficiency"].toString();
|
||||
|
||||
updateUi();
|
||||
} catch (e) {
|
||||
} finally {
|
||||
HttpService.to.setBaseUrl(AppTheme.test_service_url);
|
||||
}
|
||||
}
|
||||
|
||||
void getSiteList() async {
|
||||
final originalHeaders = Map<String, dynamic>.from(HttpService.to.dio.options.headers);
|
||||
try {
|
||||
HttpService.to.setBaseUrl(AppTheme.jiaqing_service_url);
|
||||
HttpService.to.dio.options.headers['appId'] = '97ad10eeb6b346f79e0d6ffd81e4d3c3';
|
||||
|
||||
var responseData = await HttpService.to.get("hydrogen/queryHydrogenSiteInfo");
|
||||
|
||||
if (responseData == null && responseData!.data == null) {
|
||||
showToast('暂时无法获取站点信息');
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
var result = BaseModel.fromJson(responseData.data);
|
||||
// showToast(result.data["data"].toString());
|
||||
} catch (e) {
|
||||
showToast('数据异常');
|
||||
}
|
||||
} catch (e) {
|
||||
} finally {
|
||||
HttpService.to.setBaseUrl(AppTheme.test_service_url);
|
||||
HttpService.to.dio.options.headers = originalHeaders;
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
void onClose() {
|
||||
amountController.dispose();
|
||||
|
||||
Reference in New Issue
Block a user