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

134 lines
4.7 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';
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) {
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), // 卡片和菜单列表的间距
// 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(() {
// 1. 从 Obx 的回调函数中 return 一个 Widget
return Positioned(
bottom: 40.0,
left: 0,
right: 0,
child: Text(
'当前版本:${controller.kr_version.value}',
textAlign: TextAlign.center,
style: TextStyle(
// 2. 建议使用更稳定的颜色,避免主题切换时出现问题
color: Theme.of(context).primaryColor,
fontSize: 10.w,
),
),
);
}),
],
),
);
}
}
const List<MenuItem> _menuItems = [
MenuItem(
iconName: 'icon-1',
title: '节点列表',
route: Routes.HI_NODE_LIST,
),
MenuItem(
iconName: 'icon-2',
title: '消息中心',
route: Routes.KR_MESSAGE,
),
MenuItem(
iconName: 'icon-3',
title: '常见问题',
route: Routes.HI_HELP,
),
MenuItem(
iconName: 'icon-4',
title: '邀请好友',
route: Routes.KR_INVITE,
),
MenuItem(
iconName: 'icon-5',
title: '在线客服',
route: Routes.KR_CRISP,
),
];