87 lines
3.1 KiB
Dart
Raw Normal View History

2023-07-10 17:50:31 +08:00
import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get.dart';
import 'package:star_lock/main/lockDetail/electronicKey/massSendElectronicKey/massSendLockGroupList/massSendLockGroupListEntity.dart';
2023-07-10 17:50:31 +08:00
import '../../../../../app_settings/app_colors.dart';
import '../../../../../tools/commonItem.dart';
2023-11-01 17:28:59 +08:00
import '../../../../../tools/noData.dart';
import '../../../../../tools/showTipView.dart';
2023-07-10 17:50:31 +08:00
import '../../../../../tools/submitBtn.dart';
import '../../../../../tools/titleAppBar.dart';
import '../../../../../translations/trans_lib.dart';
2024-01-23 17:29:18 +08:00
import 'lockSelectGrouping_logic.dart';
2023-07-10 17:50:31 +08:00
2024-01-23 17:29:18 +08:00
class LockSelectGroupingPage extends StatefulWidget {
const LockSelectGroupingPage({Key? key}) : super(key: key);
2023-07-10 17:50:31 +08:00
@override
2024-01-23 17:29:18 +08:00
State<LockSelectGroupingPage> createState() => _LockSelectGroupingPageState();
2023-07-10 17:50:31 +08:00
}
2024-01-23 17:29:18 +08:00
class _LockSelectGroupingPageState extends State<LockSelectGroupingPage> {
final logic = Get.put(LockSelectGroupingLogic());
final state = Get.find<LockSelectGroupingLogic>().state;
2023-07-10 17:50:31 +08:00
@override
Widget build(BuildContext context) {
2023-07-10 17:50:31 +08:00
return Scaffold(
backgroundColor: AppColors.mainBackgroundColor,
appBar: TitleAppBar(
barTitle: TranslationLoader.lanKeys!.selectGroup!.tr,
haveBack: true,
backgroundColor: AppColors.mainColor),
2023-11-01 17:28:59 +08:00
body: Column(
children: [
Expanded(child: _buildMainUI()),
SubmitBtn(
btnName: TranslationLoader.lanKeys!.createNewGroup!.tr,
borderRadius: 20.w,
margin: EdgeInsets.only(
left: 30.w, right: 30.w, top: 30.w, bottom: 30.w),
padding: EdgeInsets.only(top: 25.w, bottom: 25.w),
onClick: () {
// showCupertinoAlertDialog(context);
ShowTipView().showTFViewAlertDialog(state.changeNameController, TranslationLoader.lanKeys!.createNewGroup!.tr, "请输入分组名称".tr, (){
logic.addLockGroupRequest();
Get.back();
});
2023-11-01 17:28:59 +08:00
}),
SizedBox(
height: 40.h,
)
],
),
2023-07-10 17:50:31 +08:00
);
}
2023-11-01 17:28:59 +08:00
Widget _buildMainUI() {
return Obx(() => state.groupList.value.isNotEmpty ? ListView.builder(
itemCount: state.groupList.value.length,
itemBuilder: (c, index) {
2023-11-01 17:28:59 +08:00
GroupListItem itemData = state.groupList.value[index];
return CommonItem(
leftTitel: itemData.keyGroupName,
rightTitle: "",
allHeight: 70.h,
isHaveLine: true,
isHaveDirection: false,
isHaveRightWidget: true,
2023-11-01 17:28:59 +08:00
rightWidget: state.lockBasicInfo.value.groupId == itemData.keyGroupId
? Image(
image: const AssetImage("images/icon_item_checked.png"),
width: 30.w,
height: 30.w,
fit: BoxFit.contain,
)
: Container(),
action: () {
2023-11-01 17:28:59 +08:00
logic.setLockGroupRequest(itemData);
});
}) : NoData());
}
2023-07-10 17:50:31 +08:00
}