修改电子钥匙、授权管理员添加类型不对的问题

This commit is contained in:
魏少阳 2024-04-25 17:45:00 +08:00
parent 84b3042579
commit 3ee09ff746
27 changed files with 349 additions and 478 deletions

View File

@ -512,7 +512,7 @@
"未打卡":"No card punched", "未打卡":"No card punched",
"钥匙将在":"The key will be in", "钥匙将在":"The key will be in",
"天后失效":"Days later invalid", "天后失效":"Days later invalid",
"锁更新时间:":"Lock update time:", "锁电量更新时间:":"Lock power update time:",
"新增配件":"Add accessories", "新增配件":"Add accessories",
"请在锁旁边完成第一次开锁":"Please complete the first unlock next to the lock", "请在锁旁边完成第一次开锁":"Please complete the first unlock next to the lock",
"正在开锁中...":"Unlocking...", "正在开锁中...":"Unlocking...",

View File

@ -512,7 +512,7 @@
"未打卡":"未打卡", "未打卡":"未打卡",
"钥匙将在":"钥匙将在", "钥匙将在":"钥匙将在",
"天后失效":"天后失效", "天后失效":"天后失效",
"锁更新时间:":"锁更新时间:", "锁电量更新时间:":"锁电量更新时间:",
"新增配件":"新增配件", "新增配件":"新增配件",
"请在锁旁边完成第一次开锁":"请在锁旁边完成第一次开锁", "请在锁旁边完成第一次开锁":"请在锁旁边完成第一次开锁",
"正在开锁中...":"正在开锁中...", "正在开锁中...":"正在开锁中...",

View File

@ -514,7 +514,7 @@
"早退":"早退", "早退":"早退",
"钥匙将在":"钥匙将在", "钥匙将在":"钥匙将在",
"天后失效":"天后失效", "天后失效":"天后失效",
"锁更新时间:":"锁更新时间:", "锁电量更新时间:":"锁电量更新时间:",
"新增配件":"新增配件", "新增配件":"新增配件",
"请在锁旁边完成第一次开锁":"请在锁旁边完成第一次开锁", "请在锁旁边完成第一次开锁":"请在锁旁边完成第一次开锁",
"正在开锁中...":"正在开锁中...", "正在开锁中...":"正在开锁中...",

View File

@ -56,6 +56,7 @@ import 'login/forgetPassword/starLock_forgetPassword_page.dart';
import 'login/login/starLock_login_page.dart'; import 'login/login/starLock_login_page.dart';
import 'login/register/starLock_register_page.dart'; import 'login/register/starLock_register_page.dart';
import 'login/selectCountryRegion/selectCountryRegion_page.dart'; import 'login/selectCountryRegion/selectCountryRegion_page.dart';
import 'main/lockDetail/authorizedAdmin/authorizedAdmin/authorizedAdmin_page.dart';
import 'main/lockDetail/card/addCardType/addCardType_page.dart'; import 'main/lockDetail/card/addCardType/addCardType_page.dart';
import 'main/lockDetail/card/addICCard/addICCard_page.dart'; import 'main/lockDetail/card/addICCard/addICCard_page.dart';
import 'main/lockDetail/card/cardDetail/cardDetail_page.dart'; import 'main/lockDetail/card/cardDetail/cardDetail_page.dart';
@ -75,6 +76,7 @@ import 'main/lockDetail/checkingIn/checkingInStaff/checkingInSetStaffList/checki
import 'main/lockDetail/checkingIn/checkingInStaff/checkingInStaffDetail/checkingInStaffDetail_page.dart'; import 'main/lockDetail/checkingIn/checkingInStaff/checkingInStaffDetail/checkingInStaffDetail_page.dart';
import 'main/lockDetail/electronicKey/electronicKeyDetail/electronicKeyPeriodValidity/electronicKeyPeriodValidity_page.dart'; import 'main/lockDetail/electronicKey/electronicKeyDetail/electronicKeyPeriodValidity/electronicKeyPeriodValidity_page.dart';
import 'main/lockDetail/electronicKey/massSendElectronicKey/massSendElectronicKey/massSendElectronicManageKey/massSendElectronicKeyManage_page.dart'; import 'main/lockDetail/electronicKey/massSendElectronicKey/massSendElectronicKey/massSendElectronicManageKey/massSendElectronicKeyManage_page.dart';
import 'main/lockDetail/electronicKey/sendElectronicKey/sendElectronicKey/sendElectronicKey_page.dart';
import 'main/lockDetail/face/addFace/addFace_page.dart'; import 'main/lockDetail/face/addFace/addFace_page.dart';
import 'main/lockDetail/face/addFaceType/addFaceType_page.dart'; import 'main/lockDetail/face/addFaceType/addFaceType_page.dart';
import 'main/lockDetail/face/faceList/faceList_page.dart'; import 'main/lockDetail/face/faceList/faceList_page.dart';
@ -127,13 +129,11 @@ import 'main/lockMian/demoMode/demoModeLockDetail/demoModeLockDetail_page.dart';
import 'main/lockMian/demoMode/demoModeLockSet/demoModeLockSet_page.dart'; import 'main/lockMian/demoMode/demoModeLockSet/demoModeLockSet_page.dart';
import 'mine/about/about_page.dart'; import 'mine/about/about_page.dart';
import 'mine/addLock/addLock/addLock_page.dart'; import 'mine/addLock/addLock/addLock_page.dart';
import 'main/lockDetail/authorizedAdmin/authorizedAdmin/authorizedAdminManage/authorizedAdminManage_page.dart';
import 'main/lockDetail/authorizedAdmin/authorizedAdminList/authorizedAdminList_page.dart'; import 'main/lockDetail/authorizedAdmin/authorizedAdminList/authorizedAdminList_page.dart';
import 'main/lockDetail/authorizedAdmin/volumeAuthorizationLock/volumeAuthorizationLockManage/volumeAuthorizationLockManage_page.dart'; import 'main/lockDetail/authorizedAdmin/volumeAuthorizationLock/volumeAuthorizationLockManage/volumeAuthorizationLockManage_page.dart';
import 'main/lockDetail/electronicKey/electronicKeyDetail/electronicKeyDetail/electronicKeyDetail_page.dart'; import 'main/lockDetail/electronicKey/electronicKeyDetail/electronicKeyDetail/electronicKeyDetail_page.dart';
import 'main/lockDetail/electronicKey/electronicKeyDetail/electronicKeyDetailChangeDate/electronicKeyDetailChangeDate_page.dart'; import 'main/lockDetail/electronicKey/electronicKeyDetail/electronicKeyDetailChangeDate/electronicKeyDetailChangeDate_page.dart';
import 'main/lockDetail/electronicKey/electronicKeyList/electronicKeyList_page.dart'; import 'main/lockDetail/electronicKey/electronicKeyList/electronicKeyList_page.dart';
import 'main/lockDetail/electronicKey/sendElectronicKey/sendElectronicManageKey/sendElectronicKeyManage_page.dart';
import 'main/lockDetail/electronicKey/sendEmailNotification/sendEmailNotification_page.dart'; import 'main/lockDetail/electronicKey/sendEmailNotification/sendEmailNotification_page.dart';
import 'main/lockDetail/lockOperatingRecord/lockOperatingRecord_page.dart'; import 'main/lockDetail/lockOperatingRecord/lockOperatingRecord_page.dart';
import 'main/lockDetail/passwordKey/passwordKeyDetail/passwordKeyDetail_page.dart'; import 'main/lockDetail/passwordKey/passwordKeyDetail/passwordKeyDetail_page.dart';
@ -206,8 +206,8 @@ abstract class Routers {
static const electronicKeyDetailPage = '/ElectronicKeyDetailPage'; // static const electronicKeyDetailPage = '/ElectronicKeyDetailPage'; //
static const electronicKeyDetailChangeDate = static const electronicKeyDetailChangeDate =
'/ElectronicKeyDetailChangeDate'; // '/ElectronicKeyDetailChangeDate'; //
static const sendElectronicKeyManagePage = static const sendElectronicKeyPage =
'/SendElectronicKeyManagePage'; // '/SendElectronicKeyPage'; //
static const massSendElectronicKeyManagePage = static const massSendElectronicKeyManagePage =
'/MassSendElectronicKeyManagePage'; // '/MassSendElectronicKeyManagePage'; //
static const electronicKeyPeriodValidityPage = static const electronicKeyPeriodValidityPage =
@ -231,8 +231,8 @@ abstract class Routers {
static const authorizedAdminListPage = '/AuthorizedAdminListPage'; // static const authorizedAdminListPage = '/AuthorizedAdminListPage'; //
static const authorizedAdminDetailPage = static const authorizedAdminDetailPage =
'/AuthorizedAdminDetailPage'; // '/AuthorizedAdminDetailPage'; //
static const authorizedAdminManagePage = static const authorizedAdminPage =
'/AuthorizedAdminManagePage'; // '/AuthorizedAdminPage'; //
static const volumeAuthorizationLockManagePage = static const volumeAuthorizationLockManagePage =
'/VolumeAuthorizationLockManagePage'; // '/VolumeAuthorizationLockManagePage'; //
static const lockOperatingRecordPage = '/LockOperatingRecordPage'; // static const lockOperatingRecordPage = '/LockOperatingRecordPage'; //
@ -499,8 +499,8 @@ abstract class AppRouters {
page: () => const ElectronicKeyDetailChangeDate(), page: () => const ElectronicKeyDetailChangeDate(),
), ),
GetPage( GetPage(
name: Routers.sendElectronicKeyManagePage, name: Routers.sendElectronicKeyPage,
page: () => const SendElectronicKeyManagePage(), page: () => const SendElectronicKeyPage(),
), ),
GetPage( GetPage(
name: Routers.massSendElectronicKeyManagePage, name: Routers.massSendElectronicKeyManagePage,
@ -543,8 +543,8 @@ abstract class AppRouters {
page: () => const AuthorizedAdminListPage(), page: () => const AuthorizedAdminListPage(),
), ),
GetPage( GetPage(
name: Routers.authorizedAdminManagePage, name: Routers.authorizedAdminPage,
page: () => const AuthorizedAdminManagePage(), page: () => const AuthorizedAdminPage(),
), ),
GetPage( GetPage(
name: Routers.lockOperatingRecordPage, name: Routers.lockOperatingRecordPage,

View File

@ -1,37 +0,0 @@
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import '../../../../../app_settings/app_colors.dart';
import '../../../../../tools/titleAppBar.dart';
import '../../../../../translations/trans_lib.dart';
import 'authorizedAdminManage_tabbar.dart';
class AuthorizedAdminManagePage extends StatefulWidget {
const AuthorizedAdminManagePage({Key? key}) : super(key: key);
@override
State<AuthorizedAdminManagePage> createState() =>
_AuthorizedAdminManagePageState();
}
class _AuthorizedAdminManagePageState extends State<AuthorizedAdminManagePage> {
var index = 0;
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: AppColors.mainBackgroundColor,
appBar: TitleAppBar(
barTitle: TranslationLoader.lanKeys!.authorizedAdmin!.tr,
haveBack: true,
backgroundColor: AppColors.mainColor),
body: Column(
children: [
AuthorizedAdminManageTabbar(
initialIndex: index,
),
],
),
);
}
}

View File

@ -1,118 +0,0 @@
import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get.dart';
import '../../../../../app_settings/app_colors.dart';
import '../../../../../tools/CustomUnderlineTabIndicator.dart';
import '../../../../../translations/trans_lib.dart';
import '../../../electronicKey/sendElectronicKey/sendElectronicKey/sendElectronicKey_page.dart';
import '../authorizedAdmin_page.dart';
class AuthorizedAdminManageTabbar extends StatefulWidget {
var initialIndex = 1;
AuthorizedAdminManageTabbar({Key? key, required this.initialIndex}) : super(key: key);
@override
State<AuthorizedAdminManageTabbar> createState() =>
_AuthorizedAdminManageTabbarState();
}
class _AuthorizedAdminManageTabbarState extends State<AuthorizedAdminManageTabbar> with SingleTickerProviderStateMixin {
late TabController _tabController;
final List<ItemView> _itemTabs = <ItemView>[
ItemView(title: TranslationLoader.lanKeys!.timeLimit!.tr, type: "0"),
ItemView(title: TranslationLoader.lanKeys!.permanent!.tr, type: "1"),
];
@override
void initState() {
// TODO: implement initState
super.initState();
_tabController = TabController(
vsync: this,
length: _itemTabs.length,
initialIndex: widget.initialIndex);
_tabController.addListener(() {
// print("_tabController.animation!.value:${_tabController.animation!.value} _tabController.index:${_tabController.index}");
if (_tabController.animation!.value==_tabController.index){
FocusScope.of(context).requestFocus(FocusNode());
}
});
}
@override
Widget build(BuildContext context) {
return Expanded(
child: Column(
children: [
_tabBar(),
_pageWidget(),
],
));
}
TabBar _tabBar() {
return TabBar(
controller: _tabController,
tabs: _itemTabs.map((ItemView item) => _tab(item)).toList(),
onTap: (index){
FocusScope.of(context).requestFocus(FocusNode());
},
isScrollable: true,
indicatorColor: Colors.red,
unselectedLabelColor: Colors.black,
unselectedLabelStyle: TextStyle(
color: AppColors.mainColor,
fontSize: 24.sp,
),
automaticIndicatorColorAdjustment: true,
labelColor: AppColors.mainColor,
labelStyle: TextStyle(
color: AppColors.mainColor,
fontSize: 24.sp,
fontWeight: FontWeight.w600),
indicator: CustomUnderlineTabIndicator(
borderSide: BorderSide(color: AppColors.mainColor, width: 4.w),
strokeCap: StrokeCap.round,
width: 30.w),
);
}
Tab _tab(ItemView item) {
return Tab(
// text: item.title,
child: Container(
width: 1.sw / 4,
margin: EdgeInsets.all(10.w),
// color: Colors.red,
child: Text(
item.title,
textAlign: TextAlign.center,
),
),
);
}
Widget _pageWidget() {
return Expanded(
child: TabBarView(
controller: _tabController,
children: _itemTabs
.map((ItemView item) => AuthorizedAdminPage(
type: item.type,
))
.toList(),
),
);
}
}
class ItemView {
const ItemView({required this.title, required this.type});
final String title;
final String type;
}

View File

@ -1,3 +1,4 @@
import 'dart:async'; import 'dart:async';
import 'package:flutter_blue_plus/flutter_blue_plus.dart'; import 'package:flutter_blue_plus/flutter_blue_plus.dart';
@ -13,6 +14,7 @@ import '../../../../blue/io_tool/manager_event_bus.dart';
import '../../../../blue/sender_manage.dart'; import '../../../../blue/sender_manage.dart';
import '../../../../network/api_repository.dart'; import '../../../../network/api_repository.dart';
import '../../../../tools/baseGetXController.dart'; import '../../../../tools/baseGetXController.dart';
import '../../../../tools/commonDataManage.dart';
import '../../../../tools/eventBusEventManage.dart'; import '../../../../tools/eventBusEventManage.dart';
import '../../../../tools/showTipView.dart'; import '../../../../tools/showTipView.dart';
import '../../../../tools/storage.dart'; import '../../../../tools/storage.dart';
@ -220,10 +222,9 @@ class AuthorizedAdminLogic extends BaseGetXController {
var endDate = "0"; var endDate = "0";
var startTime = "0"; var startTime = "0";
var endTime = "0"; var endTime = "0";
String lockID = state.keyInfo.value.lockId.toString(); Get.log("state.type.value:${state.seletType.value}");
Get.log("state.type.value:${state.type.value}");
String getKeyType = "1"; String getKeyType = "1";
if (state.type.value == '0') { if (state.seletType.value == 0) {
getKeyType = "2"; getKeyType = "2";
startDate = DateTool().dateToTimestamp(state.beginDate.value, 1).toString(); startDate = DateTool().dateToTimestamp(state.beginDate.value, 1).toString();
@ -257,7 +258,7 @@ class AuthorizedAdminLogic extends BaseGetXController {
keyNameForAdmin: state.keyNameController.text, keyNameForAdmin: state.keyNameController.text,
keyRight: '1', keyRight: '1',
keyType: getKeyType, keyType: getKeyType,
lockId: lockID, lockId: CommonDataManage().currentKeyInfo.lockId!.toString(),
operatorUid: '', operatorUid: '',
receiverUsername: state.emailOrPhoneController.text, receiverUsername: state.emailOrPhoneController.text,
remarks: '', remarks: '',
@ -289,7 +290,7 @@ class AuthorizedAdminLogic extends BaseGetXController {
// isOn:: 1 2 // isOn:: 1 2
Future<void> updateRoomCheckIn() async { Future<void> updateRoomCheckIn() async {
var entity = await ApiRepository.to.setRoomStatusData( var entity = await ApiRepository.to.setRoomStatusData(
lockId: state.keyInfo.value.lockId!, lockId: CommonDataManage().currentKeyInfo.lockId!,
roomStatus: 1, roomStatus: 1,
); );
if (entity.errorCode!.codeIsSuccessful) { if (entity.errorCode!.codeIsSuccessful) {

View File

@ -6,7 +6,6 @@ import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:star_lock/tools/dateTool.dart'; import 'package:star_lock/tools/dateTool.dart';
import 'package:star_lock/tools/dateUtils.dart';
import 'package:star_lock/tools/pickers/pickers.dart'; import 'package:star_lock/tools/pickers/pickers.dart';
import 'package:star_lock/tools/pickers/time_picker/model/date_mode.dart'; import 'package:star_lock/tools/pickers/time_picker/model/date_mode.dart';
import 'package:star_lock/tools/showTipView.dart'; import 'package:star_lock/tools/showTipView.dart';
@ -14,36 +13,59 @@ import 'package:star_lock/tools/storage.dart';
import '../../../../appRouters.dart'; import '../../../../appRouters.dart';
import '../../../../app_settings/app_colors.dart'; import '../../../../app_settings/app_colors.dart';
import '../../../../tools/CustomUnderlineTabIndicator.dart';
import '../../../../tools/NativeInteractionTool.dart'; import '../../../../tools/NativeInteractionTool.dart';
import '../../../../tools/commonItem.dart'; import '../../../../tools/commonItem.dart';
import '../../../../tools/submitBtn.dart'; import '../../../../tools/submitBtn.dart';
import '../../../../tools/titleAppBar.dart';
import '../../../../translations/trans_lib.dart'; import '../../../../translations/trans_lib.dart';
import 'authorizedAdmin_logic.dart'; import 'authorizedAdmin_logic.dart';
class AuthorizedAdminPage extends StatefulWidget { class AuthorizedAdminPage extends StatefulWidget {
final String type; const AuthorizedAdminPage({Key? key}) : super(key: key);
const AuthorizedAdminPage({Key? key, required this.type}) : super(key: key);
@override @override
State<AuthorizedAdminPage> createState() => _AuthorizedAdminPageState(); State<AuthorizedAdminPage> createState() => _AuthorizedAdminPageState();
} }
class _AuthorizedAdminPageState extends State<AuthorizedAdminPage> { class _AuthorizedAdminPageState extends State<AuthorizedAdminPage> with SingleTickerProviderStateMixin {
final logic = Get.put(AuthorizedAdminLogic()); final logic = Get.put(AuthorizedAdminLogic());
final state = Get.find<AuthorizedAdminLogic>().state; final state = Get.find<AuthorizedAdminLogic>().state;
@override @override
void initState() { void initState() {
// TODO: implement initState
super.initState(); super.initState();
state.tabController = TabController(
vsync: this,
length: _itemTabs.length,
initialIndex: 0);
state.tabController.addListener(() {
WidgetsBinding.instance.addPostFrameCallback((_) {
state.seletType.value = state.tabController.index;
});
if (state.tabController.animation!.value == state.tabController.index) {
FocusScope.of(context).requestFocus(FocusNode());
}
});
} }
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
state.type.value = widget.type; return Scaffold(
Get.log("widget.type:${widget.type}"); backgroundColor: AppColors.mainBackgroundColor,
appBar: TitleAppBar(
return SingleChildScrollView( barTitle: TranslationLoader.lanKeys!.authorizedAdmin!.tr,
child: Obx(() => indexChangeWidget()), haveBack: true,
backgroundColor: AppColors.mainColor),
body: Column(
children: [
_tabBar(),
_pageWidget(),
],
),
); );
} }
@ -51,28 +73,32 @@ class _AuthorizedAdminPageState extends State<AuthorizedAdminPage> {
if (state.isSendSuccess.value) { if (state.isSendSuccess.value) {
return sendElectronicKeySucceed(); return sendElectronicKeySucceed();
} else { } else {
switch (int.parse(widget.type)) { switch (state.seletType.value) {
case 0: case 0:
{ {
// //
return Column( return SingleChildScrollView(
children: [ child: Column(
keyInfoWidget(), children: [
keyTimeWidget(), keyInfoWidget(),
keyRealNameWidget(), keyTimeWidget(),
keyBottomWidget( keyRealNameWidget(),
TranslationLoader.lanKeys!.authorizedAdminTip!.tr) keyBottomWidget(
], TranslationLoader.lanKeys!.authorizedAdminTip!.tr)
],
),
); );
} }
default: default:
// //
return Column( return SingleChildScrollView(
children: [ child: Column(
keyInfoWidget(), children: [
keyRealNameWidget(), keyInfoWidget(),
keyBottomWidget(TranslationLoader.lanKeys!.authorizedAdminTip!.tr) keyRealNameWidget(),
], keyBottomWidget(TranslationLoader.lanKeys!.authorizedAdminTip!.tr)
],
),
); );
} }
} }
@ -345,6 +371,8 @@ class _AuthorizedAdminPageState extends State<AuthorizedAdminPage> {
FilteringTextInputFormatter.deny('\n'), FilteringTextInputFormatter.deny('\n'),
LengthLimitingTextInputFormatter(30), LengthLimitingTextInputFormatter(30),
], ],
style: TextStyle(
fontSize: 22.sp, color: AppColors.darkGrayTextColor),
controller: lineIndex == 1 controller: lineIndex == 1
? state.emailOrPhoneController ? state.emailOrPhoneController
: state.keyNameController, : state.keyNameController,
@ -561,4 +589,67 @@ class _AuthorizedAdminPageState extends State<AuthorizedAdminPage> {
default: default:
} }
} }
TabBar _tabBar() {
return TabBar(
controller: state.tabController,
tabs: _itemTabs.map((ItemView item) => _tab(item)).toList(),
onTap: (index){
FocusScope.of(context).requestFocus(FocusNode());
},
isScrollable: true,
indicatorColor: Colors.red,
unselectedLabelColor: Colors.black,
unselectedLabelStyle: TextStyle(
color: AppColors.mainColor,
fontSize: 24.sp,
),
automaticIndicatorColorAdjustment: true,
labelColor: AppColors.mainColor,
labelStyle: TextStyle(
color: AppColors.mainColor,
fontSize: 24.sp,
fontWeight: FontWeight.w600),
indicator: CustomUnderlineTabIndicator(
borderSide: BorderSide(color: AppColors.mainColor, width: 4.w),
strokeCap: StrokeCap.round,
width: 30.w),
);
}
Tab _tab(ItemView item) {
return Tab(
// text: item.title,
child: Container(
width: 1.sw / 4,
margin: EdgeInsets.all(10.w),
// color: Colors.red,
child: Text(
item.title,
textAlign: TextAlign.center,
),
),
);
}
Widget _pageWidget() {
return Expanded(
child: TabBarView(
controller: state.tabController,
children: _itemTabs.map((ItemView item) => Obx(() => indexChangeWidget())).toList()
),
);
}
final List<ItemView> _itemTabs = <ItemView>[
ItemView(title: TranslationLoader.lanKeys!.timeLimit!.tr, type: "0"),
ItemView(title: TranslationLoader.lanKeys!.permanent!.tr, type: "1"),
];
}
class ItemView {
const ItemView({required this.title, required this.type});
final String title;
final String type;
} }

View File

@ -6,16 +6,14 @@ import 'package:star_lock/tools/dateTool.dart';
import '../../../lockMian/entity/lockListInfo_entity.dart'; import '../../../lockMian/entity/lockListInfo_entity.dart';
class AuthorizedAdminState { class AuthorizedAdminState {
final TextEditingController emailOrPhoneController = final TextEditingController emailOrPhoneController = TextEditingController(); ///
TextEditingController(); /// final TextEditingController keyNameController = TextEditingController(); //
final TextEditingController keyNameController = late TabController tabController;
TextEditingController(); //
final FlutterContactPicker contactPicker = FlutterContactPicker(); final FlutterContactPicker contactPicker = FlutterContactPicker();
late Contact contact; late Contact contact;
var type = ''.obs; // final keyInfo = LockListInfoItemEntity().obs;
final keyInfo = LockListInfoItemEntity().obs;
// final lockMainEntity = LockMainEntity().obs; // final lockMainEntity = LockMainEntity().obs;
final isAuthentication = false.obs; // final isAuthentication = false.obs; //
final onlyManageYouCreatesUser = false.obs; // final onlyManageYouCreatesUser = false.obs; //
@ -29,13 +27,13 @@ class AuthorizedAdminState {
var weekdaysList = [].obs; var weekdaysList = [].obs;
var isCreateUser = false.obs; //1 0 var isCreateUser = false.obs; //1 0
final widgetType = 0.obs; var seletType = 0.obs;
String pwdShareStr = '您好,您的授权管理员生成成功'; String pwdShareStr = '您好,您的授权管理员生成成功';
var addUserId = ''.obs; var addUserId = ''.obs;
AuthorizedAdminState() { // AuthorizedAdminState() {
Map map = Get.arguments; // Map map = Get.arguments;
// lockMainEntity.value = map["lockMainEntity"]; // // lockMainEntity.value = map["lockMainEntity"];
keyInfo.value = map["keyInfo"]; // keyInfo.value = map["keyInfo"];
} // }
} }

View File

@ -4,6 +4,7 @@ import 'package:star_lock/main/lockDetail/authorizedAdmin/authorizedAdminList/au
import 'package:star_lock/main/lockDetail/electronicKey/electronicKeyList/entity/ElectronicKeyListEntity.dart'; import 'package:star_lock/main/lockDetail/electronicKey/electronicKeyList/entity/ElectronicKeyListEntity.dart';
import 'package:star_lock/network/api_repository.dart'; import 'package:star_lock/network/api_repository.dart';
import 'package:star_lock/tools/baseGetXController.dart'; import 'package:star_lock/tools/baseGetXController.dart';
import 'package:star_lock/tools/commonDataManage.dart';
import '../../../../tools/eventBusEventManage.dart'; import '../../../../tools/eventBusEventManage.dart';
@ -14,10 +15,10 @@ class AuthorizedAdminListLogic extends BaseGetXController {
Future<ElectronicKeyListEntity> mockNetworkDataRequest() async { Future<ElectronicKeyListEntity> mockNetworkDataRequest() async {
ElectronicKeyListEntity entity = await ApiRepository.to.electronicKeyList( ElectronicKeyListEntity entity = await ApiRepository.to.electronicKeyList(
endDate: '0', endDate: '0',
keyId: state.keyInfo.value.keyId.toString(), keyId: CommonDataManage().currentKeyInfo.keyId.toString(),
keyStatus: '', keyStatus: '',
keyRight: '1', keyRight: '1',
lockId: state.keyInfo.value.lockId.toString(), lockId: CommonDataManage().currentKeyInfo.lockId.toString(),
pageNo: pageNo.toString(), pageNo: pageNo.toString(),
pageSize: pageSize.toString(), pageSize: pageSize.toString(),
startDate: '0', startDate: '0',

View File

@ -73,11 +73,7 @@ class _AuthorizedAdminListPageState extends State<AuthorizedAdminListPage> {
AddBottomWhiteBtn( AddBottomWhiteBtn(
btnName: TranslationLoader.lanKeys!.addAuthorizedAdmin!.tr, btnName: TranslationLoader.lanKeys!.addAuthorizedAdmin!.tr,
onClick: () { onClick: () {
Navigator.pushNamed(context, Routers.authorizedAdminManagePage, Navigator.pushNamed(context, Routers.authorizedAdminPage).then((val) {
arguments: {
// "lockMainEntity": state.lockMainEntity.value,
"keyInfo": state.keyInfo.value
}).then((val) {
if (val != null) { if (val != null) {
logic.pageNo = 1; logic.pageNo = 1;
mockRequest(); mockRequest();
@ -140,7 +136,6 @@ class _AuthorizedAdminListPageState extends State<AuthorizedAdminListPage> {
child: _electronicKeyItem('images/controls_user.png', indexEntity.keyName!, useDateStr, keyStatus, isAdminKey, () { child: _electronicKeyItem('images/controls_user.png', indexEntity.keyName!, useDateStr, keyStatus, isAdminKey, () {
Navigator.pushNamed(context, Routers.electronicKeyDetailPage, arguments: { Navigator.pushNamed(context, Routers.electronicKeyDetailPage, arguments: {
"itemData": indexEntity, "itemData": indexEntity,
"keyInfo": state.keyInfo.value
}).then((val) { }).then((val) {
if (val != null) { if (val != null) {
logic.mockNetworkDataRequest(); logic.mockNetworkDataRequest();

View File

@ -4,15 +4,15 @@ import 'package:star_lock/main/lockDetail/electronicKey/electronicKeyList/entity
import '../../../lockMian/entity/lockListInfo_entity.dart'; import '../../../lockMian/entity/lockListInfo_entity.dart';
class AuthorizedAdminListState { class AuthorizedAdminListState {
final keyInfo = LockListInfoItemEntity().obs; // final keyInfo = LockListInfoItemEntity().obs;
// final lockMainEntity = LockMainEntity().obs; // final lockMainEntity = LockMainEntity().obs;
final itemDataList = <ElectronicKeyListItem>[].obs; final itemDataList = <ElectronicKeyListItem>[].obs;
final searchStr = ''.obs; final searchStr = ''.obs;
AuthorizedAdminListState() { // AuthorizedAdminListState() {
Map map = Get.arguments; // Map map = Get.arguments;
// lockMainEntity.value = map["lockMainEntity"]; // // lockMainEntity.value = map["lockMainEntity"];
keyInfo.value = map["keyInfo"]; // keyInfo.value = map["keyInfo"];
} // }
} }

View File

@ -8,6 +8,7 @@ import 'package:star_lock/main/lockDetail/electronicKey/electronicKeyDetail/elec
import '../../../../../appRouters.dart'; import '../../../../../appRouters.dart';
import '../../../../../app_settings/app_colors.dart'; import '../../../../../app_settings/app_colors.dart';
import '../../../../../common/XSConstantMacro/XSConstantMacro.dart'; import '../../../../../common/XSConstantMacro/XSConstantMacro.dart';
import '../../../../../tools/commonDataManage.dart';
import '../../../../../tools/commonItem.dart'; import '../../../../../tools/commonItem.dart';
import '../../../../../tools/dateTool.dart'; import '../../../../../tools/dateTool.dart';
import '../../../../../tools/showTFView.dart'; import '../../../../../tools/showTFView.dart';
@ -164,7 +165,7 @@ class _ElectronicKeyDetailPageState extends State<ElectronicKeyDetailPage> {
child: _onlyManageYouCreatesUserSwitch())), child: _onlyManageYouCreatesUserSwitch())),
), ),
Visibility(// (state.keyInfo.value.lockSetting!.remoteUnlock == 1 ? true : false Visibility(// (state.keyInfo.value.lockSetting!.remoteUnlock == 1 ? true : false
visible: state.keyInfo.value.lockSetting!.remoteUnlock == 1 && state.itemData.value.keyRight != 1 ? true:false, visible: CommonDataManage().currentKeyInfo.lockSetting!.remoteUnlock == 1 && state.itemData.value.keyRight != 1 ? true:false,
child: CommonItem( child: CommonItem(
leftTitel: "远程开锁".tr, leftTitel: "远程开锁".tr,
rightTitle: "", rightTitle: "",

View File

@ -6,7 +6,7 @@ import '../../../../lockMian/entity/lockListInfo_entity.dart';
class ElectronicKeyDetailState { class ElectronicKeyDetailState {
final itemData = ElectronicKeyListItem().obs; final itemData = ElectronicKeyListItem().obs;
final keyInfo = LockListInfoItemEntity().obs; // final keyInfo = LockListInfoItemEntity().obs;
final keyName = "".obs; final keyName = "".obs;
final TextEditingController changeNameController = TextEditingController(); final TextEditingController changeNameController = TextEditingController();
@ -24,9 +24,9 @@ class ElectronicKeyDetailState {
ElectronicKeyDetailState() { ElectronicKeyDetailState() {
Map map = Get.arguments; Map map = Get.arguments;
itemData.value = map["itemData"]; itemData.value = map["itemData"];
if(map["keyInfo"]!=null){ // if(map["keyInfo"]!=null){
keyInfo.value = map["keyInfo"]; // keyInfo.value = map["keyInfo"];
} // }
changeNameController.text = itemData.value.keyName!; changeNameController.text = itemData.value.keyName!;
keyName.value = itemData.value.keyName!; keyName.value = itemData.value.keyName!;

View File

@ -5,6 +5,7 @@ import 'package:star_lock/main/lockDetail/electronicKey/electronicKeyList/electr
import 'package:star_lock/main/lockDetail/electronicKey/electronicKeyList/entity/ElectronicKeyListEntity.dart'; import 'package:star_lock/main/lockDetail/electronicKey/electronicKeyList/entity/ElectronicKeyListEntity.dart';
import 'package:star_lock/network/api_repository.dart'; import 'package:star_lock/network/api_repository.dart';
import 'package:star_lock/tools/baseGetXController.dart'; import 'package:star_lock/tools/baseGetXController.dart';
import 'package:star_lock/tools/commonDataManage.dart';
import 'package:star_lock/tools/showTipView.dart'; import 'package:star_lock/tools/showTipView.dart';
import '../../../../tools/eventBusEventManage.dart'; import '../../../../tools/eventBusEventManage.dart';
@ -16,10 +17,10 @@ class ElectronicKeyListLogic extends BaseGetXController {
Future<ElectronicKeyListEntity> mockNetworkDataRequest() async { Future<ElectronicKeyListEntity> mockNetworkDataRequest() async {
ElectronicKeyListEntity entity = await ApiRepository.to.electronicKeyList( ElectronicKeyListEntity entity = await ApiRepository.to.electronicKeyList(
endDate: '0', endDate: '0',
keyId: state.keyInfo.value.keyId.toString(), keyId: CommonDataManage().currentKeyInfo.keyId.toString(),
keyStatus: '', keyStatus: '',
keyRight: '0', keyRight: '0',
lockId: state.keyInfo.value.lockId.toString(), lockId: CommonDataManage().currentKeyInfo.lockId.toString(),
pageNo: pageNo.toString(), pageNo: pageNo.toString(),
pageSize: pageSize.toString(), pageSize: pageSize.toString(),
startDate: '0', startDate: '0',
@ -41,7 +42,7 @@ class ElectronicKeyListLogic extends BaseGetXController {
// //
Future<void> resetElectronicKeyListRequest() async { Future<void> resetElectronicKeyListRequest() async {
ElectronicKeyListEntity entity = await ApiRepository.to ElectronicKeyListEntity entity = await ApiRepository.to
.resetElectronicKey(state.keyInfo.value.lockId.toString(), '0'); .resetElectronicKey(CommonDataManage().currentKeyInfo.lockId.toString(), '0');
if (entity.errorCode!.codeIsSuccessful) { if (entity.errorCode!.codeIsSuccessful) {
showToast("重置成功".tr, something: (){ showToast("重置成功".tr, something: (){
pageNo = 1; pageNo = 1;

View File

@ -102,12 +102,7 @@ class _ElectronicKeyListPageState extends State<ElectronicKeyListPage> {
AddBottomWhiteBtn( AddBottomWhiteBtn(
btnName: TranslationLoader.lanKeys!.sendKey!.tr, btnName: TranslationLoader.lanKeys!.sendKey!.tr,
onClick: () { onClick: () {
Navigator.pushNamed( Navigator.pushNamed(context, Routers.sendElectronicKeyPage).then((val) {
context, Routers.sendElectronicKeyManagePage,
arguments: {
// "lockMainEntity": state.lockMainEntity.value,
"keyInfo": state.keyInfo.value
}).then((val) {
if (val != null) { if (val != null) {
logic.pageNo = 1; logic.pageNo = 1;
mockRequest(); mockRequest();
@ -182,7 +177,6 @@ class _ElectronicKeyListPageState extends State<ElectronicKeyListPage> {
context, Routers.electronicKeyDetailPage, context, Routers.electronicKeyDetailPage,
arguments: { arguments: {
"itemData": indexEntity, "itemData": indexEntity,
"keyInfo": state.keyInfo.value
}).then((val) { }).then((val) {
if (val != null) { if (val != null) {
logic.mockNetworkDataRequest(); logic.mockNetworkDataRequest();

View File

@ -6,15 +6,15 @@ import '../../../lockMian/entity/lockListInfo_entity.dart';
class ElectronicKeyListState { class ElectronicKeyListState {
TextEditingController searchController = TextEditingController(); /// TextEditingController searchController = TextEditingController(); ///
final keyInfo = LockListInfoItemEntity().obs; // final keyInfo = LockListInfoItemEntity().obs;
// final lockMainEntity = LockMainEntity().obs; // final lockMainEntity = LockMainEntity().obs;
var pageNum = 1.obs; // var pageNum = 1.obs; //
final pageSize = 20.obs; // final pageSize = 20.obs; //
final itemDataList = <ElectronicKeyListItem>[].obs; final itemDataList = <ElectronicKeyListItem>[].obs;
ElectronicKeyListState() { // ElectronicKeyListState() {
Map map = Get.arguments; // Map map = Get.arguments;
// lockMainEntity.value = map["lockMainEntity"]; // // lockMainEntity.value = map["lockMainEntity"];
keyInfo.value = map["keyInfo"]; // keyInfo.value = map["keyInfo"];
} // }
} }

View File

@ -1,15 +1,12 @@
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:star_lock/appRouters.dart';
import 'package:star_lock/app_settings/app_colors.dart';
import 'package:star_lock/common/XSConstantMacro/XSConstantMacro.dart'; import 'package:star_lock/common/XSConstantMacro/XSConstantMacro.dart';
import 'package:star_lock/main/lockDetail/electronicKey/sendElectronicKey/sendElectronicKey/sendElectronicKey_state.dart'; import 'package:star_lock/main/lockDetail/electronicKey/sendElectronicKey/sendElectronicKey/sendElectronicKey_state.dart';
import 'package:star_lock/network/api_repository.dart'; import 'package:star_lock/network/api_repository.dart';
import 'package:star_lock/tools/baseGetXController.dart'; import 'package:star_lock/tools/baseGetXController.dart';
import 'package:star_lock/tools/commonDataManage.dart';
import 'package:star_lock/tools/dateTool.dart'; import 'package:star_lock/tools/dateTool.dart';
import 'package:star_lock/tools/eventBusEventManage.dart'; import 'package:star_lock/tools/eventBusEventManage.dart';
import 'package:star_lock/translations/trans_lib.dart';
import '../../../../../tools/showTipView.dart'; import '../../../../../tools/showTipView.dart';
@ -33,26 +30,25 @@ class SendElectronicKeyLogic extends BaseGetXController {
var endDate = "0"; var endDate = "0";
var startTime = "0"; var startTime = "0";
var endTime = "0"; var endTime = "0";
String lockID = state.keyInfo.value.lockId.toString(); int typeValue = state.seletType.value;
int typeValue = int.parse(state.type.value);
switch (typeValue) { switch (typeValue) {
case 0: case 0:
{ {
if (state.beginTime.value.isEmpty) {
showToast("请选择开始时间".tr);
return;
}
if (state.beginTime.value.isEmpty) {
showToast("请选择结束时间".tr);
return;
}
typeValue = XSConstantMacro.keyTypeTime; typeValue = XSConstantMacro.keyTypeTime;
startDate = DateTool().dateToTimestamp(state.beginTime.value, 1).toString(); startDate = DateTool().dateToTimestamp(state.beginTime.value, 1).toString();
endDate = DateTool().dateToTimestamp(state.endTime.value, 1).toString(); endDate = DateTool().dateToTimestamp(state.endTime.value, 1).toString();
startTime = "0"; startTime = "0";
endTime = "0"; endTime = "0";
if (startDate.isEmpty) {
showToast("请选择开始时间".tr);
return;
}
if (endDate.isEmpty) {
showToast("请选择结束时间".tr);
return;
}
// if(DateTime.now().millisecondsSinceEpoch > int.parse(state.beginTimeTimestamp.value)){ // if(DateTime.now().millisecondsSinceEpoch > int.parse(state.beginTimeTimestamp.value)){
// Toast.show(msg: "生效时间要大于当前时间"); // Toast.show(msg: "生效时间要大于当前时间");
// return; // return;
@ -100,7 +96,7 @@ class SendElectronicKeyLogic extends BaseGetXController {
keyNameForAdmin: state.keyNameController.text, keyNameForAdmin: state.keyNameController.text,
keyRight: '0', keyRight: '0',
keyType: getKeyType, keyType: getKeyType,
lockId: lockID, lockId: CommonDataManage().currentKeyInfo.lockId.toString(),
operatorUid: '', operatorUid: '',
receiverUsername: state.emailOrPhoneController.text, receiverUsername: state.emailOrPhoneController.text,
remarks: '', remarks: '',
@ -111,7 +107,7 @@ class SendElectronicKeyLogic extends BaseGetXController {
isOnlyManageSelf: 0); isOnlyManageSelf: 0);
if (entity.errorCode!.codeIsSuccessful) { if (entity.errorCode!.codeIsSuccessful) {
state.isSendSuccess.value = true; state.isSendSuccess.value = true;
state.sendSucceedType.value = int.parse(state.type.value); state.sendSucceedType.value = state.seletType.value;
resetData(); resetData();
eventBus.fire(ElectronicKeyListRefreshUI()); eventBus.fire(ElectronicKeyListRefreshUI());
} else { } else {
@ -221,7 +217,7 @@ class SendElectronicKeyLogic extends BaseGetXController {
void resetData() { void resetData() {
state.emailOrPhoneController.text = ""; state.emailOrPhoneController.text = "";
state.keyNameController.text = ""; state.keyNameController.text = "";
if(state.type.value == "0"){ if(state.seletType.value == 0){
state.beginTime.value = DateTool().dateToYMDHNString(DateTime.now().millisecondsSinceEpoch.toString()); // state.beginTime.value = DateTool().dateToYMDHNString(DateTime.now().millisecondsSinceEpoch.toString()); //
state.endTime.value = DateTool().dateToYMDHNString(DateTime.now().millisecondsSinceEpoch.toString());// state.endTime.value = DateTool().dateToYMDHNString(DateTime.now().millisecondsSinceEpoch.toString());//
}else{ }else{

View File

@ -15,102 +15,131 @@ import 'package:star_lock/tools/showTipView.dart';
import 'package:star_lock/tools/storage.dart'; import 'package:star_lock/tools/storage.dart';
import '../../../../../appRouters.dart'; import '../../../../../appRouters.dart';
import '../../../../../tools/CustomUnderlineTabIndicator.dart';
import '../../../../../tools/NativeInteractionTool.dart'; import '../../../../../tools/NativeInteractionTool.dart';
import '../../../../../tools/commonDataManage.dart';
import '../../../../../tools/commonItem.dart'; import '../../../../../tools/commonItem.dart';
import '../../../../../tools/dateTool.dart'; import '../../../../../tools/dateTool.dart';
import '../../../../../tools/submitBtn.dart'; import '../../../../../tools/submitBtn.dart';
import '../../../../../tools/titleAppBar.dart';
import '../../../../../translations/trans_lib.dart'; import '../../../../../translations/trans_lib.dart';
class SendElectronicKeyPage extends StatefulWidget { class SendElectronicKeyPage extends StatefulWidget {
final String type; const SendElectronicKeyPage({Key? key}) : super(key: key);
const SendElectronicKeyPage({Key? key, required this.type}) : super(key: key);
@override @override
State<SendElectronicKeyPage> createState() => _SendElectronicKeyPageState(); State<SendElectronicKeyPage> createState() => _SendElectronicKeyPageState();
} }
class _SendElectronicKeyPageState extends State<SendElectronicKeyPage> { class _SendElectronicKeyPageState extends State<SendElectronicKeyPage> with SingleTickerProviderStateMixin {
final logic = Get.put(SendElectronicKeyLogic()); final logic = Get.put(SendElectronicKeyLogic());
final state = Get.find<SendElectronicKeyLogic>().state; final state = Get.find<SendElectronicKeyLogic>().state;
@override
initState() {
super.initState();
getDemoMode();
WidgetsBinding.instance.addPostFrameCallback((_) {
logic.resetData();
});
}
Future<void> getDemoMode() async { Future<void> getDemoMode() async {
state.isDemoMode = (await Storage.getBool(ifIsDemoModeOrNot))!; state.isDemoMode = (await Storage.getBool(ifIsDemoModeOrNot))!;
} }
@override @override
Widget build(BuildContext context) { void initState() {
state.type.value = widget.type; // TODO: implement initState
Get.log('state.type.value:${state.type.value}'); super.initState();
return SingleChildScrollView( getDemoMode();
child: state.isDemoMode ? indexChangeWidget() : Obx(() => indexChangeWidget()),
state.tabController = TabController(
vsync: this,
length: _itemTabs.length,
initialIndex: 0);
state.tabController.addListener(() {
WidgetsBinding.instance.addPostFrameCallback((_) {
state.seletType.value = state.tabController.index;
});
if (state.tabController.animation!.value == state.tabController.index) {
FocusScope.of(context).requestFocus(FocusNode());
}
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: AppColors.mainBackgroundColor,
appBar: TitleAppBar(
barTitle: TranslationLoader.lanKeys!.sendKey!.tr,
haveBack: true,
backgroundColor: AppColors.mainColor),
body: Column(
children: [
_tabBar(),
_pageWidget(),
],
),
); );
} }
Widget indexChangeWidget() { Widget indexChangeWidget() {
if (state.isSendSuccess.value == true && if (state.isSendSuccess.value == true &&
state.sendSucceedType.value.toString() == widget.type) { state.sendSucceedType.value == state.seletType.value) {
return sendElectronicKeySucceed(); return sendElectronicKeySucceed();
} else { } else {
switch (int.parse(widget.type)) { switch (state.seletType.value) {
case 0: case 0:
{ {
// //
return Column( return SingleChildScrollView(
children: [ child: Column(
keyInfoWidget(), children: [
keyTimeWidget(), keyInfoWidget(),
remoteUnlockingWidget(), keyTimeWidget(),
keyRealNameWidget(), remoteUnlockingWidget(),
keyBottomWidget(state.timeLimitTips) keyRealNameWidget(),
], keyBottomWidget(state.timeLimitTips)
],
),
); );
} }
case 1: case 1:
{ {
// //
return Column( return SingleChildScrollView(
children: [ child: Column(
keyInfoWidget(), children: [
remoteUnlockingWidget(), keyInfoWidget(),
keyRealNameWidget(), remoteUnlockingWidget(),
keyBottomWidget(state.permanentTips) keyRealNameWidget(),
], keyBottomWidget(state.permanentTips)
],
),
); );
} }
case 2: case 2:
{ {
// //
return Column( return SingleChildScrollView(
children: [ child: Column(
keyInfoWidget(), children: [
remoteUnlockingWidget(), keyInfoWidget(),
keyRealNameWidget(), remoteUnlockingWidget(),
keyBottomWidget(state.onceLimitTips) keyRealNameWidget(),
], keyBottomWidget(state.onceLimitTips)
],
),
); );
} }
case 3: case 3:
{ {
// //
return Column( return SingleChildScrollView(
children: [ child: Column(
keyInfoWidget(), children: [
keyPeriodValidityWidget(), keyInfoWidget(),
remoteUnlockingWidget(), keyPeriodValidityWidget(),
keyRealNameWidget(), remoteUnlockingWidget(),
keyBottomWidget(state.cycleLimitTips) keyRealNameWidget(),
], keyBottomWidget(state.cycleLimitTips)
],
),
); );
} }
default: default:
@ -441,7 +470,7 @@ class _SendElectronicKeyPageState extends State<SendElectronicKeyPage> {
// } // }
var entity = await ApiRepository.to.setRoomStatusData( var entity = await ApiRepository.to.setRoomStatusData(
lockId: state.keyInfo.value.lockId!, lockId: CommonDataManage().currentKeyInfo.lockId!,
roomStatus: 1, roomStatus: 1,
); );
if (entity.errorCode!.codeIsSuccessful) { if (entity.errorCode!.codeIsSuccessful) {
@ -542,7 +571,7 @@ class _SendElectronicKeyPageState extends State<SendElectronicKeyPage> {
return Visibility( return Visibility(
visible: state.isDemoMode visible: state.isDemoMode
? false ? false
: (state.keyInfo.value.lockSetting!.remoteUnlock == 1 ? true : false), : (CommonDataManage().currentKeyInfo.lockSetting!.remoteUnlock == 1 ? true : false),
child: Column( child: Column(
children: [ children: [
CommonItem( CommonItem(
@ -618,6 +647,65 @@ class _SendElectronicKeyPageState extends State<SendElectronicKeyPage> {
}); });
} }
TabBar _tabBar() {
return TabBar(
controller: state.tabController,
onTap: (index){
FocusScope.of(context).requestFocus(FocusNode());
},
tabs: _itemTabs.map((ItemView item) => _tab(item)).toList(),
isScrollable: true,
indicatorColor: Colors.red,
unselectedLabelColor: Colors.black,
unselectedLabelStyle: TextStyle(
color: AppColors.mainColor,
fontSize: 24.sp,
),
automaticIndicatorColorAdjustment: true,
labelColor: AppColors.mainColor,
labelStyle: TextStyle(
color: AppColors.mainColor,
fontSize: 24.sp,
fontWeight: FontWeight.w600),
indicator: CustomUnderlineTabIndicator(
borderSide: BorderSide(color: AppColors.mainColor, width: 4.w),
strokeCap: StrokeCap.round,
width: 30.w),
);
}
Tab _tab(ItemView item) {
return Tab(
// text: item.title,
child: Container(
// width: 1.sw / 8,
margin: EdgeInsets.all(10.w),
// color: Colors.red,
child: Text(
item.title,
textAlign: TextAlign.center,
),
),
);
}
Widget _pageWidget() {
return Expanded(
child: TabBarView(
controller: state.tabController,
children: _itemTabs
.map((ItemView item) => Obx(() => indexChangeWidget())).toList()
),
);
}
final List<ItemView> _itemTabs = <ItemView>[
ItemView(title: TranslationLoader.lanKeys!.timeLimit!.tr, type: "0"),
ItemView(title: TranslationLoader.lanKeys!.permanent!.tr, type: "1"),
ItemView(title: TranslationLoader.lanKeys!.once!.tr, type: "2"),
ItemView(title: TranslationLoader.lanKeys!.circulation!.tr, type: "3"),
];
List<Widget> initBottomSheetList() { List<Widget> initBottomSheetList() {
List<Widget> widgetList = []; List<Widget> widgetList = [];
@ -694,3 +782,10 @@ class _SendElectronicKeyPageState extends State<SendElectronicKeyPage> {
} }
} }
} }
class ItemView {
const ItemView({required this.title, required this.type});
final String title;
final String type;
}

View File

@ -9,9 +9,11 @@ class SendElectronicKeyState {
TextEditingController emailOrPhoneController = TextEditingController(); /// TextEditingController emailOrPhoneController = TextEditingController(); ///
TextEditingController keyNameController = TextEditingController(); // TextEditingController keyNameController = TextEditingController(); //
late TabController tabController;
final FlutterContactPicker contactPicker = FlutterContactPicker(); final FlutterContactPicker contactPicker = FlutterContactPicker();
late Contact contact; late Contact contact;
final keyInfo = LockListInfoItemEntity().obs; // final keyInfo = LockListInfoItemEntity().obs;
final isRemoteUnlock = false.obs; // final isRemoteUnlock = false.obs; //
final isAuthentication = false.obs; // final isAuthentication = false.obs; //
@ -22,7 +24,7 @@ class SendElectronicKeyState {
var failureDateTime = "".obs;// var failureDateTime = "".obs;//
var weekdaysList = [].obs; var weekdaysList = [].obs;
var type = ''.obs;// var seletType = 0.obs;//
var isSendSuccess = false.obs; var isSendSuccess = false.obs;
var countryName = '中国'.tr.obs; var countryName = '中国'.tr.obs;
var countryCode = '86'.obs; var countryCode = '86'.obs;
@ -37,9 +39,9 @@ class SendElectronicKeyState {
final cycleLimitTips = '接收者可以在有效期内的固定时间段里,不限次数使用'; // final cycleLimitTips = '接收者可以在有效期内的固定时间段里,不限次数使用'; //
SendElectronicKeyState() { SendElectronicKeyState() {
Map map = Get.arguments; // Map map = Get.arguments;
if ((map["keyInfo"] != null)) { // if ((map["keyInfo"] != null)) {
keyInfo.value = map["keyInfo"]; // keyInfo.value = map["keyInfo"];
} // }
} }
} }

View File

@ -1,31 +0,0 @@
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import '../../../../../app_settings/app_colors.dart';
import '../../../../../tools/titleAppBar.dart';
import '../../../../../translations/trans_lib.dart';
import 'sendElectronicKeyManage_tabbar.dart';
class SendElectronicKeyManagePage extends StatefulWidget {
const SendElectronicKeyManagePage({Key? key}) : super(key: key);
@override
State<SendElectronicKeyManagePage> createState() => _SendElectronicKeyManagePageState();
}
class _SendElectronicKeyManagePageState extends State<SendElectronicKeyManagePage> {
var index=0;
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: AppColors.mainBackgroundColor,
appBar: TitleAppBar(barTitle: TranslationLoader.lanKeys!.sendKey!.tr, haveBack:true, backgroundColor: AppColors.mainColor),
body: Column(
children: [
SendElectronicKeyManageTabbar(initialIndex: index,),
],
),
);
}
}

View File

@ -1,122 +0,0 @@
import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get.dart';
import '../../../../../app_settings/app_colors.dart';
import '../../../../../tools/CustomUnderlineTabIndicator.dart';
import '../../../../../translations/trans_lib.dart';
import '../sendElectronicKey/sendElectronicKey_page.dart';
class SendElectronicKeyManageTabbar extends StatefulWidget {
var initialIndex = 1;
SendElectronicKeyManageTabbar({Key? key, required this.initialIndex})
: super(key: key);
@override
State<SendElectronicKeyManageTabbar> createState() =>
_SendElectronicKeyManageTabbarState();
}
class _SendElectronicKeyManageTabbarState
extends State<SendElectronicKeyManageTabbar>
with SingleTickerProviderStateMixin {
late TabController _tabController;
final List<ItemView> _itemTabs = <ItemView>[
ItemView(title: TranslationLoader.lanKeys!.timeLimit!.tr, type: "0"),
ItemView(title: TranslationLoader.lanKeys!.permanent!.tr, type: "1"),
ItemView(title: TranslationLoader.lanKeys!.once!.tr, type: "2"),
ItemView(title: TranslationLoader.lanKeys!.circulation!.tr, type: "3"),
];
@override
void initState() {
// TODO: implement initState
super.initState();
_tabController = TabController(
vsync: this,
length: _itemTabs.length,
initialIndex: widget.initialIndex);
_tabController.addListener(() {
// print("_tabController.animation!.value:${_tabController.animation!.value} _tabController.index:${_tabController.index}");
if (_tabController.animation!.value==_tabController.index){
FocusScope.of(context).requestFocus(FocusNode());
}
});
}
@override
Widget build(BuildContext context) {
return Expanded(
child: Column(
children: [
_tabBar(),
_pageWidget(),
],
));
}
TabBar _tabBar() {
return TabBar(
controller: _tabController,
onTap: (index){
FocusScope.of(context).requestFocus(FocusNode());
},
tabs: _itemTabs.map((ItemView item) => _tab(item)).toList(),
isScrollable: true,
indicatorColor: Colors.red,
unselectedLabelColor: Colors.black,
unselectedLabelStyle: TextStyle(
color: AppColors.mainColor,
fontSize: 24.sp,
),
automaticIndicatorColorAdjustment: true,
labelColor: AppColors.mainColor,
labelStyle: TextStyle(
color: AppColors.mainColor,
fontSize: 24.sp,
fontWeight: FontWeight.w600),
indicator: CustomUnderlineTabIndicator(
borderSide: BorderSide(color: AppColors.mainColor, width: 4.w),
strokeCap: StrokeCap.round,
width: 30.w),
);
}
Tab _tab(ItemView item) {
return Tab(
// text: item.title,
child: Container(
// width: 1.sw / 8,
margin: EdgeInsets.all(10.w),
// color: Colors.red,
child: Text(
item.title,
textAlign: TextAlign.center,
),
),
);
}
Widget _pageWidget() {
return Expanded(
child: TabBarView(
controller: _tabController,
children: _itemTabs
.map((ItemView item) => SendElectronicKeyPage(
type: item.type,
))
.toList(),
),
);
}
}
class ItemView {
const ItemView({required this.title, required this.type});
final String title;
final String type;
}

View File

@ -21,6 +21,7 @@ import '../../../blue/sender_manage.dart';
import '../../../network/api_repository.dart'; import '../../../network/api_repository.dart';
import '../../../permission/permission_dialog.dart'; import '../../../permission/permission_dialog.dart';
import '../../../tools/baseGetXController.dart'; import '../../../tools/baseGetXController.dart';
import '../../../tools/commonDataManage.dart';
import '../../../tools/eventBusEventManage.dart'; import '../../../tools/eventBusEventManage.dart';
import '../../../tools/storage.dart'; import '../../../tools/storage.dart';
import '../../../translations/trans_lib.dart'; import '../../../translations/trans_lib.dart';
@ -600,6 +601,7 @@ class LockDetailLogic extends BaseGetXController {
state.keyInfos.value.lockSetting!.remoteUnlock = state.keyInfos.value.lockSetting!.remoteUnlock =
int.parse(event.setResult); int.parse(event.setResult);
} }
CommonDataManage().currentKeyInfo = state.keyInfos.value;
eventBus.fire(RefreshLockDetailInfoDataEvent()); eventBus.fire(RefreshLockDetailInfoDataEvent());
}); });
} }

View File

@ -522,7 +522,7 @@ class _LockDetailPageState extends State<LockDetailPage>
onTap: () { onTap: () {
// logic.getStarLockStatus(); // logic.getStarLockStatus();
ShowTipView().showSureAlertDialog( ShowTipView().showSureAlertDialog(
"${"更新时间:".tr}${DateTool().dateToYMDHNString(state.keyInfos.value.electricQuantityDate!.toString())}"); "${"电量更新时间:".tr}${DateTool().dateToYMDHNString(state.keyInfos.value.electricQuantityDate!.toString())}");
}, },
child: Row( child: Row(
mainAxisAlignment: MainAxisAlignment.end, mainAxisAlignment: MainAxisAlignment.end,
@ -923,8 +923,7 @@ class _LockDetailPageState extends State<LockDetailPage>
TranslationLoader.lanKeys!.electronicKey!.tr, TranslationLoader.lanKeys!.electronicKey!.tr,
state.openDoorBtnisUneable.value, state.openDoorBtnisUneable.value,
state.bottomBtnisEable.value, () { state.bottomBtnisEable.value, () {
Get.toNamed(Routers.electronicKeyListPage, Get.toNamed(Routers.electronicKeyListPage);
arguments: {"keyInfo": state.keyInfos.value});
})); }));
// //

View File

@ -57,6 +57,7 @@ class UploadElectricQuantityLogic extends BaseGetXController {
IoSenderManage.senderGetStarLockStatuInfo( IoSenderManage.senderGetStarLockStatuInfo(
lockID: BlueManage().connectDeviceName, lockID: BlueManage().connectDeviceName,
userID: await Storage.getUid(), userID: await Storage.getUid(),
isBeforeAddUser: false,
privateKey: getPrivateKeyList, privateKey: getPrivateKeyList,
); );
} else if (deviceConnectionState == BluetoothConnectionState.disconnected) { } else if (deviceConnectionState == BluetoothConnectionState.disconnected) {
@ -112,6 +113,7 @@ class UploadElectricQuantityLogic extends BaseGetXController {
IoSenderManage.senderGetStarLockStatuInfo( IoSenderManage.senderGetStarLockStatuInfo(
lockID: BlueManage().connectDeviceName, lockID: BlueManage().connectDeviceName,
userID: await Storage.getUid(), userID: await Storage.getUid(),
isBeforeAddUser: false,
privateKey: getPrivateKeyList, privateKey: getPrivateKeyList,
); );
break; break;

View File

@ -66,6 +66,7 @@ class LockTimeLogic extends BaseGetXController{
IoSenderManage.senderGetStarLockStatuInfo( IoSenderManage.senderGetStarLockStatuInfo(
lockID: BlueManage().connectDeviceName, lockID: BlueManage().connectDeviceName,
userID: await Storage.getUid(), userID: await Storage.getUid(),
isBeforeAddUser: false,
privateKey: getPrivateKeyList, privateKey: getPrivateKeyList,
); );
break; break;
@ -157,6 +158,7 @@ class LockTimeLogic extends BaseGetXController{
IoSenderManage.senderGetStarLockStatuInfo( IoSenderManage.senderGetStarLockStatuInfo(
lockID: BlueManage().connectDeviceName, lockID: BlueManage().connectDeviceName,
userID: await Storage.getUid(), userID: await Storage.getUid(),
isBeforeAddUser: false,
privateKey: getPrivateKeyList, privateKey: getPrivateKeyList,
); );
} else if (deviceConnectionState == BluetoothConnectionState.disconnected) { } else if (deviceConnectionState == BluetoothConnectionState.disconnected) {

View File

@ -14,7 +14,6 @@ import 'package:star_lock/tools/pickers/time_picker/model/date_mode.dart';
import 'package:star_lock/tools/storage.dart'; import 'package:star_lock/tools/storage.dart';
import '../../../../appRouters.dart'; import '../../../../appRouters.dart';
import '../../../../blue/blue_manage.dart';
import '../../../../blue/io_modelVendor.dart'; import '../../../../blue/io_modelVendor.dart';
import '../../../../tools/CustomUnderlineTabIndicator.dart'; import '../../../../tools/CustomUnderlineTabIndicator.dart';
import '../../../../tools/NativeInteractionTool.dart'; import '../../../../tools/NativeInteractionTool.dart';