hi-client/lib/app/modules/hi_menu/views/hi_menu_view.dart

141 lines
5.1 KiB
Dart
Executable File

import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:easy_refresh/easy_refresh.dart';
import 'package:flutter_html/flutter_html.dart';
import 'package:flutter_markdown/flutter_markdown.dart';
import 'package:kaer_with_panels/app/widgets/hi_base_scaffold.dart';
import '../../../routes/app_pages.dart';
import 'package:kaer_with_panels/app/widgets/swipe/has_swipe_config.dart';
import 'package:kaer_with_panels/app/widgets/swipe/swipe_config.dart';
import '../controllers/hi_menu_controller.dart';
import 'package:kaer_with_panels/app/widgets/kr_app_text_style.dart';
import 'package:kaer_with_panels/app/localization/app_translations.dart';
import 'package:flutter/services.dart';
import 'package:kaer_with_panels/app/widgets/kr_local_image.dart';
import 'package:kaer_with_panels/app/modules/kr_home/views/hi_subscription_corner_button.dart';
import 'package:kaer_with_panels/app/common/app_run_data.dart';
import 'package:kaer_with_panels/app/modules/hi_menu/widgets/hi_menu_list_item.dart';
import 'package:kaer_with_panels/app/modules/hi_menu/widgets/user_info_card.dart';
import '../../../utils/kr_common_util.dart';
class HIMenuView extends GetView<HIMenuController> implements HasSwipeConfig {
const HIMenuView({super.key});
@override
SwipeConfig get swipeConfig => SwipeConfig(
enableRight: true,
onRight: () => Get.offNamed(Routes.KR_HOME),
);
@override
Widget build(BuildContext context) {
final List<MenuItem> menuItems = [
const MenuItem(
iconName: 'icon-1',
title: '节点列表',
route: Routes.HI_NODE_LIST,
),
const MenuItem(
iconName: 'icon-2',
title: '消息中心',
route: Routes.KR_MESSAGE,
),
const MenuItem(
iconName: 'icon-3',
title: '常见问题',
route: Routes.HI_HELP,
),
const MenuItem(
iconName: 'icon-4',
title: '邀请好友',
route: Routes.KR_INVITE,
),
const MenuItem(
iconName: 'icon-6',
title: '软件防丢',
route: Routes.HI_ANTI_LOST,
),
MenuItem(
iconName: 'icon-5',
title: '在线客服',
route: Routes.KR_CHATWOOT,
),
];
return HIBaseScaffold(
child: Stack(
fit: StackFit.expand,
children: [
Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min,
children: [
SizedBox(height: 60.h),
Padding(
// 5. 为整个区块设置左右 41.w 的内边距
padding: EdgeInsets.symmetric(horizontal: 41.w),
child: Column(
mainAxisSize: MainAxisSize.min, // 让 Column 包裹内容
children: [
Obx(() {
final account =
KRAppRunData.getInstance().kr_account.value;
final isDeviceLogin =
account != null && account.startsWith('9000');
final accountText = (account == null || isDeviceLogin)
? '待绑定'
: '${KRAppRunData.getInstance().kr_account.value.toString()}';
return UserInfoCard(
controller: controller,
userId: accountText,
);
}),
SizedBox(height: 10.h), // 卡片 and 菜单列表的间距
// ListView.separated 现在也会继承 Padding 的约束
ListView.separated(
shrinkWrap: true, // 让 ListView 高度自适应内容
physics:
const NeverScrollableScrollPhysics(), // 在 Stack 中,禁用其自身的滚动
itemCount: menuItems.length,
// 渲染每一项
itemBuilder: (context, index) {
return MenuListItem(item: menuItems[index]);
},
// 设置每一项之间的间距
separatorBuilder: (context, index) {
return SizedBox(height: 10.h);
},
),
],
),
),
],
),
// 版本号信息
Obx(() {
return Positioned(
bottom: 40.0,
left: 0,
right: 0,
child: GestureDetector(
onDoubleTap: () => controller.toggleVersionDisplay(),
child: Text(
'当前版本:${controller.kr_showBuild.value ? '${controller.kr_version.value}.${controller.kr_buildNumber.value}' : controller.kr_version.value}',
textAlign: TextAlign.center,
style: TextStyle(
color: Theme.of(context).primaryColor,
fontSize: 10.w,
),
),
),
);
}),
],
),
);
}
}