qhd-prevention-flutter/lib/pages/app/application_page.dart

251 lines
9.3 KiB
Dart

import 'package:flutter/material.dart';
import 'package:qhd_prevention/pages/app/Danger_paicha/check_record_page.dart';
import 'package:qhd_prevention/pages/app/Danger_paicha/quick_report_page.dart';
import 'package:qhd_prevention/pages/home/work/danger_wait_list_page.dart';
import 'package:qhd_prevention/pages/home/work/risk_list_page.dart';
import '../../tools/tools.dart';
import '../home/userInfo_page.dart';
import '../home/work/danger_page.dart';
import '../home/work/danger_repair_page.dart';
enum AppItem {
riskInspection, // 隐患排查
quickReport, // 隐患快报
checkRecord, // 检查记录
riskRecord, // 隐患记录
pendingRectification, // 待整改隐患
overdueRectification, // 超期未整改
riskAcceptance, // 隐患验收
acceptedRisk, // 已验收隐患
specialRectification, // 专项检查中的隐患整改
specialRecord, // 专项检查中的隐患记录
supervisionRectification, // 监管帮扶中的隐患整改
supervisionRecord, // 监管帮扶中的隐患记录
}
class ApplicationPage extends StatelessWidget {
const ApplicationPage({Key? key}) : super(key: key);
// 处理项目点击事件
void _handleItemClick(BuildContext context, AppItem item) {
switch (item) {
case AppItem.riskInspection:
// 跳转到隐患排查页面
pushPage(DangerPage(), context);
break;
case AppItem.quickReport:
// 跳转到隐患快报页面
pushPage(QuickReportPage(), context);
break;
case AppItem.checkRecord:
// 跳转到检查记录页面
pushPage(CheckRecordPage(), context);
break;
case AppItem.riskRecord:
// 跳转到隐患记录页面
pushPage(DangerWaitListPage(DangerType.ristRecord), context);
break;
case AppItem.pendingRectification:
// 跳转到待整改隐患页面
pushPage(DangerWaitListPage(DangerType.wait), context);
break;
case AppItem.overdueRectification:
// 跳转到超期未整改页面
pushPage(DangerWaitListPage(DangerType.expired), context);
break;
case AppItem.riskAcceptance:
// 跳转到隐患验收页面
pushPage(DangerWaitListPage(DangerType.waitAcceptance), context);
break;
case AppItem.acceptedRisk:
// 跳转到已验收隐患页面
pushPage(DangerWaitListPage(DangerType.acceptanced), context);
break;
case AppItem.specialRectification:
// 跳转到专项检查隐患整改页面
//Navigator.push(context, MaterialPageRoute(builder: (_) => SpecialRectificationPage()));
break;
case AppItem.specialRecord:
// 跳转到专项检查隐患记录页面
// Navigator.push(context, MaterialPageRoute(builder: (_) => SpecialRecordPage()));
break;
case AppItem.supervisionRectification:
// 跳转到监管帮扶隐患整改页面
//Navigator.push(context, MaterialPageRoute(builder: (_) => SupervisionRectificationPage()));
break;
case AppItem.supervisionRecord:
// 跳转到监管帮扶隐患记录页面
//Navigator.push(context, MaterialPageRoute(builder: (_) => SupervisionRecordPage()));
break;
}
}
@override
Widget build(BuildContext context) {
// 使用枚举定义项目
final List<Map<String, dynamic>> buttonInfos = [
{
'title': '隐患排查',
'list': [
{'item': AppItem.riskInspection, 'icon': 'assets/icon-apps/icon-zl-6.png', 'title': '隐患排查', 'num': 0},
{'item': AppItem.quickReport, 'icon': 'assets/icon-apps/icon-pc-1.png', 'title': '隐患快报', 'num': 2},
{'item': AppItem.checkRecord, 'icon': 'assets/icon-apps/icon-zl-2.png', 'title': '检查记录', 'num': 0},
],
},
{
'title': '隐患治理',
'list': [
{'item': AppItem.riskRecord, 'icon': 'assets/icon-apps/icon-zl-2.png', 'title': '隐患记录', 'num': 1},
{'item': AppItem.pendingRectification, 'icon': 'assets/icon-apps/icon-zl-3.png', 'title': '待整改隐患', 'num': 3},
{'item': AppItem.overdueRectification, 'icon': 'assets/icon-apps/icon-zl-4.png', 'title': '超期未整改', 'num': 0},
{'item': AppItem.riskAcceptance, 'icon': 'assets/icon-apps/icon-yh-1.png', 'title': '隐患验收', 'num': 2},
{'item': AppItem.acceptedRisk, 'icon': 'assets/icon-apps/icon-zl-1.png', 'title': '已验收隐患', 'num': 0},
],
},
{
'title': '专项检查',
'list': [
{'item': AppItem.specialRectification, 'icon': 'assets/icon-apps/icon-pc-1.png', 'title': '隐患整改', 'num': 5},
{'item': AppItem.specialRecord, 'icon': 'assets/icon-apps/icon-zl-2.png', 'title': '隐患记录', 'num': 0},
],
},
{
'title': '监管帮扶',
'list': [
{'item': AppItem.supervisionRectification, 'icon': 'assets/icon-apps/icon-pc-1.png', 'title': '隐患整改', 'num': 2},
{'item': AppItem.supervisionRecord, 'icon': 'assets/icon-apps/icon-zl-2.png', 'title': '隐患记录', 'num': 0},
],
},
];
return Scaffold(
body: ListView.builder(
physics: const AlwaysScrollableScrollPhysics(),
padding: const EdgeInsets.all(0),
itemCount: buttonInfos.length + 1,
itemBuilder: (context, index) {
if (index == 0) {
return ClipRRect(
child: Image.asset(
'assets/images/apps-banner.jpg',
fit: BoxFit.cover,
),
);
}
final section = buttonInfos[index - 1];
final items = section['list'] as List<dynamic>;
return Padding(
padding: const EdgeInsets.only(top: 10),
child: Container(
decoration: BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.circular(8),
),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
padding: const EdgeInsets.fromLTRB(10, 10, 10, 5),
child: Row(
children: [
Container(width: 2, height: 10, color: Colors.blue),
const SizedBox(width: 5),
Text(
section['title'] as String,
style: const TextStyle(
fontSize: 14,
fontWeight: FontWeight.bold,
),
),
],
),
),
Padding(
padding: const EdgeInsets.all(10),
child: LayoutBuilder(
builder: (context, constraints) {
const spacing = 10.0;
final totalWidth = constraints.maxWidth;
final itemWidth = (totalWidth - spacing * 3) / 4;
return Wrap(
spacing: spacing,
runSpacing: spacing,
children: items.map<Widget>((item) {
return SizedBox(
width: itemWidth,
child: _buildItem(
item,
onTap: () => _handleItemClick(context, item['item'] as AppItem),
),
);
}).toList(),
);
},
),
),
],
),
),
);
},
),
);
}
// 添加 onTap 回调参数
Widget _buildItem(Map<String, dynamic> item, {VoidCallback? onTap}) {
const double size = 60;
final int badgeNum = item['num'] as int;
return InkWell(
onTap: onTap, // 添加点击事件
borderRadius: BorderRadius.circular(8),
child: SizedBox(
width: size,
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
Stack(
clipBehavior: Clip.none,
children: [
SizedBox(
width: 30,
height: 30,
child: Image.asset(item['icon'] as String, fit: BoxFit.contain),
),
if (badgeNum > 0)
Positioned(
top: -5,
right: -10,
child: Container(
width: 16,
height: 16,
decoration: const BoxDecoration(
color: Colors.red,
shape: BoxShape.circle,
),
alignment: Alignment.center,
child: Text(
badgeNum.toString(),
style: const TextStyle(color: Colors.white, fontSize: 10),
),
),
),
],
),
const SizedBox(height: 4),
Text(
item['title'] as String,
style: const TextStyle(fontSize: 12),
textAlign: TextAlign.center,
),
],
),
),
);
}
}