132 lines
3.8 KiB
Dart
Raw Normal View History

2023-07-10 17:50:31 +08:00
import 'package:flutter/material.dart';
import 'package:flutter_easyloading/flutter_easyloading.dart';
2023-07-10 17:50:31 +08:00
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get.dart';
import 'package:star_lock/main/lockDetail/lockSet/lockTime/lockTime_state.dart';
2023-07-10 17:50:31 +08:00
import '../../../../app_settings/app_colors.dart';
import '../../../../tools/appRouteObserver.dart';
2023-07-10 17:50:31 +08:00
import '../../../../tools/submitBtn.dart';
import '../../../../tools/titleAppBar.dart';
2023-09-04 15:00:42 +08:00
import 'lockTime_logic.dart';
2023-07-10 17:50:31 +08:00
class LockTimePage extends StatefulWidget {
2023-07-15 15:11:28 +08:00
const LockTimePage({Key? key}) : super(key: key);
2023-07-10 17:50:31 +08:00
@override
State<LockTimePage> createState() => _LockTimePageState();
}
class _LockTimePageState extends State<LockTimePage> with RouteAware{
final LockTimeLogic logic = Get.put(LockTimeLogic());
final LockTimeState state = Get.find<LockTimeLogic>().state;
2023-09-04 15:00:42 +08:00
2023-07-10 17:50:31 +08:00
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: Colors.white,
appBar: TitleAppBar(
2024-07-31 17:24:30 +08:00
barTitle: '锁时间'.tr,
haveBack: true,
backgroundColor: AppColors.mainColor),
body: Container(
2023-07-10 17:50:31 +08:00
padding: EdgeInsets.all(30.w),
child: Column(
children: <Widget>[
SizedBox(
height: 50.h,
),
2023-09-04 15:00:42 +08:00
Obx(() => Row(
2023-07-10 17:50:31 +08:00
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
2023-09-04 15:00:42 +08:00
Text(state.dateTime.value,
style: TextStyle(
fontSize: 26.sp, color: AppColors.blackColor)),
2023-07-10 17:50:31 +08:00
],
2023-09-04 15:00:42 +08:00
),),
SizedBox(
height: 60.h,
),
SubmitBtn(
2024-07-31 17:24:30 +08:00
btnName: '校准时间'.tr,
2023-07-10 17:50:31 +08:00
borderRadius: 20.w,
fontSize: 32.sp,
// margin: EdgeInsets.only(left: 03.w, right: 30.w, top: 20.w),
padding: EdgeInsets.only(top: 20.w, bottom: 20.w),
2023-09-04 15:00:42 +08:00
onClick: () {
2024-01-02 18:03:50 +08:00
// logic.sendTiming();
logic.getServerDatetime(true);
// logic.sendTiming();
2023-09-04 15:00:42 +08:00
}),
SizedBox(
height: 40.h,
2023-07-10 17:50:31 +08:00
),
// GestureDetector(
// onTap: () {},
// child: Container(
// child: Text(TranslationLoader.lanKeys!.setTheDSTMode!.tr,
// style: TextStyle(
// fontSize: 24.sp, color: AppColors.mainColor))),
// ),
2023-07-10 17:50:31 +08:00
],
),
)
);
2023-07-10 17:50:31 +08:00
}
@override
void didChangeDependencies() {
super.didChangeDependencies();
/// 路由订阅
AppRouteObserver().routeObserver.subscribe(this, ModalRoute.of(context)!);
}
@override
void dispose() {
/// 取消路由订阅
AppRouteObserver().routeObserver.unsubscribe(this);
super.dispose();
}
/// 从上级界面进入 当前界面即将出现
@override
void didPush() {
super.didPush();
state.ifCurrentScreen.value = true;
}
/// 返回上一个界面 当前界面即将消失
@override
void didPop() {
super.didPop();
logic.cancelBlueConnetctToastTimer();
if (EasyLoading.isShow) {
EasyLoading.dismiss(animation: true);
}
state.ifCurrentScreen.value = false;
state.sureBtnState.value = 0;
}
/// 从下级返回 当前界面即将出现
@override
void didPopNext() {
super.didPopNext();
state.ifCurrentScreen.value = true;
}
/// 进入下级界面 当前界面即将消失
@override
void didPushNext() {
super.didPushNext();
logic.cancelBlueConnetctToastTimer();
if (EasyLoading.isShow) {
EasyLoading.dismiss(animation: true);
}
state.ifCurrentScreen.value = false;
state.sureBtnState.value = 0;
}
2023-07-10 17:50:31 +08:00
}