Merge branch 'mcy_revision' into job_report_revision

# Conflicts:
#	marking_app/lib/routes/RouterManager.dart
This commit is contained in:
machuanyu 2024-03-11 10:30:00 +08:00
commit b8eceb80bb
5 changed files with 212 additions and 38 deletions

View File

@ -260,7 +260,9 @@ class _HomeworkCorrectionState extends ConsumerState<HomeworkCorrection>
Expanded( Expanded(
flex: 1, flex: 1,
child: InkWell( child: InkWell(
onTap: () {}, onTap: () {
RouterManager.router.navigateTo(context, RouterManager.jobPriorityReviewSetPath,transition: getTransition());
},
child: Icon(Icons.settings_outlined, color: Color.fromRGBO(44, 48, 63, 1), size: 24.sp), child: Icon(Icons.settings_outlined, color: Color.fromRGBO(44, 48, 63, 1), size: 24.sp),
), ),
), ),

View File

@ -0,0 +1,125 @@
import 'package:flutter/material.dart';
import 'package:flutter_easyrefresh/easy_refresh.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
class JobPriorityReviewSet extends StatefulWidget {
const JobPriorityReviewSet({Key? key}) : super(key: key);
@override
State<JobPriorityReviewSet> createState() => _JobPriorityReviewSetState();
}
class _JobPriorityReviewSetState extends State<JobPriorityReviewSet>
with SingleTickerProviderStateMixin {
late final EasyRefreshController refreshController;
late TabController tabController;
int tabIndex = 0;
@override
void initState() {
super.initState();
refreshController = EasyRefreshController();
tabController =
TabController(initialIndex: tabIndex, length: 2, vsync: this);
}
@override
void dispose() {
super.dispose();
refreshController.dispose();
tabController.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: Color.fromRGBO(245, 245, 245, 1),
appBar: AppBar(
backgroundColor: Colors.white,
title: Text(
'优先批阅人配置',
style: TextStyle(fontSize: 16.sp, color: Color(0xFF333333)),
),
centerTitle: true,
leading: IconButton(
icon: Icon(Icons.arrow_back_ios, color: Colors.black),
onPressed: () => Navigator.of(context).pop(),
),
),
body: EasyRefresh(
firstRefresh: true,
taskIndependence: true,
enableControlFinishLoad: true,
enableControlFinishRefresh: true,
// emptyWidget: data.isEmpty ? const MyEmptyWidget() : null,
controller: refreshController,
header: MaterialHeader(),
footer: TaurusFooter(),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
padding: EdgeInsets.symmetric(horizontal: 14.r),
child: TabBar(
onTap: (int val) {
setState(() {
tabIndex = val;
});
},
tabs: [
SizedBox(
width: (MediaQuery.of(context).size.width - 28.r) /2,
child: Tab(
text: '优先批阅',
),
),
SizedBox(
width: (MediaQuery.of(context).size.width - 28.r) /2,
child: Tab(
text: '默认批阅',
),
)
],
controller: tabController,
unselectedLabelStyle: TextStyle(
fontSize: 14.sp, color:Color(0xFF666666)),
labelStyle: TextStyle(
fontSize: 14.sp,
color: Color(0xFF6888FD),
),
isScrollable: true,
labelColor: Color(0xFF6888FD),
unselectedLabelColor: Color(0xFF666666),
indicatorSize: TabBarIndicatorSize.label,
labelPadding: const EdgeInsets.all(0),
),
),
Container(
padding: EdgeInsets.symmetric(horizontal: 15.r),
decoration: BoxDecoration(
borderRadius: BorderRadius.all(Radius.circular(10.r)),
color: Colors.white,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text('张小凡',style: TextStyle(fontSize: 12.sp,color: Color(0xFF6888FD)),),
Container(
padding: EdgeInsets.symmetric(vertical: 2.r,horizontal: 10.r),
decoration: BoxDecoration(
borderRadius: BorderRadius.all(Radius.circular(20.r)),
color: Color(0xFF6888FD),
),
child: Center(
child: Text('取消优先',style: TextStyle(fontSize: 10.sp,color: Colors.white),),
),
)
],
),
)
],
),
),
);
}
}

View File

@ -23,9 +23,10 @@ part 'job_report.g.dart';
/// ///
class JobReport extends StatefulWidget { class JobReport extends StatefulWidget {
final int id; final int id;
final String uniqueId;
final String title; final String title;
const JobReport({required this.id, required this.title, super.key}); const JobReport({required this.id, required this.title,required this.uniqueId, super.key});
@override @override
State<JobReport> createState() => _JobReportState(); State<JobReport> createState() => _JobReportState();

View File

@ -35,21 +35,25 @@ class _QuickStudentDataTableState extends State<QuickStudentDataTable> {
StudentDetails item = widget.bodyList[index]; StudentDetails item = widget.bodyList[index];
int num = 0; int num = 0;
item.kgDetails.forEach((element) { item.kgDetails.forEach((element) {
if(element.state == 0){ if (element.state == 0) {
num = num + 1; num = num + 1;
} }
}); });
item.zgDetails.forEach((element) { item.zgDetails.forEach((element) {
if(element.state == 0){ if (element.state == 0) {
num = num + 1; num = num + 1;
} }
}); });
return DataRow2.byIndex( return DataRow2.byIndex(
index: index, index: index,
color: color != null ? num == 0?MaterialStateProperty.all(color):MaterialStateProperty.all(Color(0xFFFFD79C)): null, color: color != null
? num == 0
? MaterialStateProperty.all(color)
: MaterialStateProperty.all(Color(0xFFFFD79C))
: null,
cells: [ cells: [
DataCell(InkWell( DataCell(InkWell(
onTap: (){ onTap: () {
RouterManager.router.navigateTo( RouterManager.router.navigateTo(
context, context,
RouterManager.quickCheckPersonalPath + RouterManager.quickCheckPersonalPath +
@ -65,9 +69,16 @@ class _QuickStudentDataTableState extends State<QuickStudentDataTable> {
crossAxisAlignment: CrossAxisAlignment.center, crossAxisAlignment: CrossAxisAlignment.center,
children: [ children: [
Text(item.studentName, Text(item.studentName,
style: TextStyle(fontSize: 12.sp, color: Color(0xFF6888FD))), style:
SizedBox(width: 5.r,), TextStyle(fontSize: 12.sp, color: Color(0xFF6888FD))),
Image.asset('assets/images/job_data_right_icon.png',width: 10.r,height: 10.r,) SizedBox(
width: 5.r,
),
Image.asset(
'assets/images/job_data_right_icon.png',
width: 10.r,
height: 10.r,
)
], ],
), ),
), ),
@ -91,50 +102,74 @@ class _QuickStudentDataTableState extends State<QuickStudentDataTable> {
)), )),
DataCell( DataCell(
Padding( Padding(
padding: EdgeInsets.symmetric(vertical:2.r,horizontal: 5.r), padding: EdgeInsets.symmetric(vertical: 2.r, horizontal: 5.r),
child: SingleChildScrollView( child: SingleChildScrollView(
child: Wrap( child: Wrap(
direction: Axis.horizontal, direction: Axis.horizontal,
alignment: WrapAlignment.center, alignment: WrapAlignment.center,
spacing: 2, spacing: 2,
runSpacing: 2, runSpacing: 2,
children: List.generate(item.kgDetails.length, (index) { children: List.generate(item.kgDetails.length, (index) {
KgDetails kgInfo = item.kgDetails[index]; KgDetails kgInfo = item.kgDetails[index];
return Container( return Container(
width: 14.r, width: 14.r,
height: 14.r, height: 14.r,
decoration: BoxDecoration( decoration: BoxDecoration(
color: kgInfo.state == 0?Color(0xFFD9D9D9):kgInfo.state == 1?Color(0xFFFF7474):Color(0xFF4CC793), color: kgInfo.state == 0
borderRadius: BorderRadius.all(Radius.circular(7.r)) ? Color(0xFFD9D9D9)
), : kgInfo.state == 1
child: Center(child: Text(kgInfo.questionNo,style: TextStyle(fontSize:10.sp,color: kgInfo.state == 0?Color(0xFF525252):Colors.white),)), ? Color(0xFFFF7474)
: Color(0xFF4CC793),
borderRadius: BorderRadius.all(Radius.circular(7.r))),
child: Center(
child: Text(
kgInfo.questionNo,
style: TextStyle(
fontSize: 10.sp,
color: kgInfo.state == 0
? Color(0xFF525252)
: Colors.white),
)),
); );
})), })),
), ),
), ),
), ),
DataCell( Padding( DataCell(
padding: EdgeInsets.symmetric(vertical:2.r,horizontal: 5.r), Padding(
child: SingleChildScrollView( padding: EdgeInsets.symmetric(vertical: 2.r, horizontal: 5.r),
child: Wrap( child: SingleChildScrollView(
direction: Axis.horizontal, child: Wrap(
alignment: WrapAlignment.center, direction: Axis.horizontal,
spacing: 2, alignment: WrapAlignment.center,
runSpacing: 2, spacing: 2,
children: List.generate(item.zgDetails.length, (index) { runSpacing: 2,
KgDetails kgInfo = item.zgDetails[index]; children: List.generate(item.zgDetails.length, (index) {
return Container( KgDetails kgInfo = item.zgDetails[index];
width: 14.r, return Container(
height: 14.r, width: 14.r,
decoration: BoxDecoration( height: 14.r,
color: kgInfo.state == 0?Color(0xFFD9D9D9):kgInfo.state == 1?Color(0xFFFF7474):Color(0xFF4CC793), decoration: BoxDecoration(
borderRadius: BorderRadius.all(Radius.circular(7.r)) color: kgInfo.state == 0
), ? Color(0xFFD9D9D9)
child: Center(child: Text(kgInfo.questionNo,style: TextStyle(fontSize:10.sp,color: kgInfo.state == 0?Color(0xFF525252):Colors.white),)), : kgInfo.state == 1
); ? Color(0xFFFF7474)
})), : Color(0xFF4CC793),
borderRadius: BorderRadius.all(Radius.circular(7.r))),
child: Center(
child: Text(
kgInfo.questionNo,
style: TextStyle(
fontSize: 10.sp,
color: kgInfo.state == 0
? Color(0xFF525252)
: Colors.white),
)),
);
})),
),
), ),
),), ),
], ],
); );
} }
@ -184,7 +219,7 @@ class _QuickStudentDataTableState extends State<QuickStudentDataTable> {
style: TextStyle(fontSize: 12.sp, color: Color(0xFF505767))), style: TextStyle(fontSize: 12.sp, color: Color(0xFF505767))),
), ),
// size: ColumnSize.S, // size: ColumnSize.S,
fixedWidth: (MediaQuery.of(context).size.width - 20.r - 28.r)/5, fixedWidth: (MediaQuery.of(context).size.width - 20.r - 28.r) / 5,
); );
}), }),
rows: List<DataRow>.generate(widget.bodyList.length, rows: List<DataRow>.generate(widget.bodyList.length,

View File

@ -14,6 +14,7 @@ import 'package:flutter/material.dart';
import 'package:marking_app/common/model/enum/marking_list_type.dart'; import 'package:marking_app/common/model/enum/marking_list_type.dart';
import 'package:marking_app/pages/common/startUpPage.dart'; import 'package:marking_app/pages/common/startUpPage.dart';
import 'package:marking_app/pages/homework_correction/do_papers_job_exam.dart'; import 'package:marking_app/pages/homework_correction/do_papers_job_exam.dart';
import 'package:marking_app/pages/homework_correction/job_priority_review_set.dart';
import 'package:marking_app/pages/homework_correction/job_report.dart'; import 'package:marking_app/pages/homework_correction/job_report.dart';
import 'package:marking_app/pages/homework_correction/pages/job_list_participate_in_class.dart'; import 'package:marking_app/pages/homework_correction/pages/job_list_participate_in_class.dart';
import 'package:marking_app/pages/homework_correction/review_job.dart'; import 'package:marking_app/pages/homework_correction/review_job.dart';
@ -180,7 +181,8 @@ class RouterManager {
static final _jobReportPageHandler = Handler(handlerFunc: (BuildContext? context, Map<String, List<String>> params) { static final _jobReportPageHandler = Handler(handlerFunc: (BuildContext? context, Map<String, List<String>> params) {
int id = int.parse(params['id']![0]); int id = int.parse(params['id']![0]);
String title = params['title']![0]; String title = params['title']![0];
return JobReport(id: id, title: title); String uniqueId = params['uniqueId']![0];
return JobReport(id: id, title: title,uniqueId:uniqueId);
}); });
// //
@ -274,6 +276,14 @@ class RouterManager {
return QuickCheckPersonal(jobId: jobId, studentId: studentId); return QuickCheckPersonal(jobId: jobId, studentId: studentId);
}, },
); );
//
static final _jobPriorityReviewSetPageHandler = Handler(
handlerFunc: (BuildContext? context, Map<String, List<String>> params){
return JobPriorityReviewSet();
},
);
// //
// static final _doMarkingPapers = Handler(handlerFunc: (BuildContext? context, Map<String, List<String>> params) => MarkingPapers()); // static final _doMarkingPapers = Handler(handlerFunc: (BuildContext? context, Map<String, List<String>> params) => MarkingPapers());
@ -313,6 +323,7 @@ class RouterManager {
router.define(quickDataCheckPath, handler: _quickDataCheckPageHandler, transitionType: TransitionType.material); router.define(quickDataCheckPath, handler: _quickDataCheckPageHandler, transitionType: TransitionType.material);
router.define(quickCheckPersonalPath, router.define(quickCheckPersonalPath,
handler: _quickCheckPersonalPageHandler, transitionType: TransitionType.material); handler: _quickCheckPersonalPageHandler, transitionType: TransitionType.material);
router.define(jobPriorityReviewSetPath, handler: _jobPriorityReviewSetPageHandler, transitionType: TransitionType.material);
// getTransition() // getTransition()