Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
E
Education
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
黄奎
Education
Commits
3eeb0325
Commit
3eeb0325
authored
Aug 09, 2021
by
罗超
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of
http://gitlab.oytour.com/Kui2/education
parents
56141d04
b7847834
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
100 additions
and
20 deletions
+100
-20
RB_Class_ViewModel.cs
Edu.Model/ViewModel/Grade/RB_Class_ViewModel.cs
+5
-0
ClassModule.cs
Edu.Module.Course/ClassModule.cs
+53
-14
RB_Student_MakeupRepository.cs
Edu.Repository/BackClass/RB_Student_MakeupRepository.cs
+1
-1
ClassController.cs
Edu.WebApi/Controllers/Course/ClassController.cs
+39
-5
TeacherClassController.cs
Edu.WebApi/Controllers/Course/TeacherClassController.cs
+2
-0
No files found.
Edu.Model/ViewModel/Grade/RB_Class_ViewModel.cs
View file @
3eeb0325
...
...
@@ -242,6 +242,11 @@ namespace Edu.Model.ViewModel.Grade
/// 查询状态
/// </summary>
public
string
QClassStatus
{
get
;
set
;
}
/// <summary>
/// 开班时间
/// </summary>
public
List
<
string
>
ClassDateList
{
get
;
set
;
}
}
/// <summary>
...
...
Edu.Module.Course/ClassModule.cs
View file @
3eeb0325
...
...
@@ -592,16 +592,19 @@ namespace Edu.Module.Course
}
#
endregion
//班级上课计划列表
List
<
RB_Class_Plan_ViewModel
>
classPlanList
=
CreateClassPlanList
(
model
,
defaultPlanTimeList
,
BasicMinutes
);
model
.
ClassPlanList
=
classPlanList
;
if
(
model
.
Teacher_Id
>
0
&&
model
.
ClassRoomId
>
0
)
{
//班级上课计划列表
List
<
RB_Class_Plan_ViewModel
>
classPlanList
=
CreateClassPlanList
(
model
,
defaultPlanTimeList
,
BasicMinutes
);
model
.
ClassPlanList
=
classPlanList
;
}
else
{
model
.
ClassPlanList
=
new
List
<
RB_Class_Plan_ViewModel
>();
}
#
region
同步班级到甲鹤小程序
Add
by
:
W
2021
-
08
-
02
09
:
49
SetGoodsSpecificationValue
(
model
);
#
endregion
return
flag
;
}
...
...
@@ -947,25 +950,53 @@ namespace Edu.Module.Course
/// <param name="message"></param>
/// <returns></returns>
[
TransactionCallHandler
]
public
virtual
bool
SetClassStatusModule
(
RB_Class_ViewModel
model
,
out
string
message
,
out
bool
result
)
public
virtual
bool
SetClassStatusModule
(
RB_Class_ViewModel
model
,
UserInfo
user
,
out
string
message
,
out
bool
result
)
{
var
oldModel
=
GetClassModule
(
model
.
ClassId
);
result
=
false
;
bool
flag
=
false
;
message
=
""
;
var
newTeacherId
=
oldModel
.
Teacher_Id
>
0
?
oldModel
.
Teacher_Id
:
model
.
Teacher_Id
;
var
newClassRoomId
=
oldModel
.
ClassRoomId
>
0
?
oldModel
.
ClassRoomId
:
model
.
ClassRoomId
;
Dictionary
<
string
,
object
>
fileds
=
new
Dictionary
<
string
,
object
>()
{
{
nameof
(
RB_Class_ViewModel
.
ClassStatus
),(
int
)
model
.
ClassStatus
},
};
//上课计划
Dictionary
<
string
,
object
>
planFileds
=
new
Dictionary
<
string
,
object
>();
if
(
model
.
ClassRoomId
>
0
)
{
fileds
.
Add
(
nameof
(
RB_Class_ViewModel
.
ClassRoomId
),
model
.
ClassRoomId
);
planFileds
.
Add
(
nameof
(
RB_Class_Plan
.
ClassRoomId
),
model
.
ClassRoomId
);
}
if
(
model
.
Teacher_Id
>
0
)
{
fileds
.
Add
(
nameof
(
RB_Class_ViewModel
.
Teacher_Id
),
model
.
Teacher_Id
);
Dictionary
<
string
,
object
>
planFileds
=
new
Dictionary
<
string
,
object
>()
{
{
nameof
(
RB_Class_Plan
.
TeacherId
),
model
.
Teacher_Id
},
};
planFileds
.
Add
(
nameof
(
RB_Class_Plan
.
TeacherId
),
model
.
Teacher_Id
);
}
if
(
planFileds
!=
null
&&
planFileds
.
Count
>
0
)
{
class_PlanRepository
.
Update
(
planFileds
,
new
WhereHelper
(
nameof
(
RB_Class_Plan
.
ClassId
),
model
.
ClassId
));
class_PlanRepository
.
CheckClassPlanRepeatRepository
(
model
.
ClassId
,
out
result
);
}
if
(
model
.
ClassStatus
==
ClassStatusEnum
.
StudyIng
)
{
if
(
oldModel
.
Teacher_Id
>
0
&&
oldModel
.
ClassRoomId
>
0
)
{
class_PlanRepository
.
CheckClassPlanRepeatRepository
(
model
.
ClassId
,
out
result
);
}
else
{
oldModel
.
Teacher_Id
=
newTeacherId
;
oldModel
.
ClassRoomId
=
newClassRoomId
;
var
BasicMinutes
=
GetBasicMinutesModule
(
oldModel
.
Group_Id
);
if
(!
string
.
IsNullOrEmpty
(
oldModel
.
DefaultTimeJson
))
{
oldModel
.
DefaultTimeList
=
Common
.
Plugin
.
JsonHelper
.
DeserializeObject
<
List
<
ClassTimeItem
>>(
oldModel
.
DefaultTimeJson
);
}
List
<
RB_Class_Plan_ViewModel
>
classPlanList
=
CreateClassPlanList
(
oldModel
,
oldModel
.
DefaultTimeList
,
BasicMinutes
);
model
.
ClassPlanList
=
classPlanList
;
AddClassPlanModule
(
model
.
ClassId
,
classPlanList
,
user
,
out
result
);
}
}
//结课验证课时
if
(
model
.
ClassStatus
==
ClassStatusEnum
.
EndClass
)
...
...
@@ -1301,6 +1332,7 @@ namespace Edu.Module.Course
var
extModel
=
classRepository
.
GetEntity
<
RB_Class_ViewModel
>(
ClassId
);
if
(
extModel
!=
null
&&
extModel
.
ClassId
>
0
)
{
extModel
.
ClassDateList
=
new
List
<
string
>();
if
(
extModel
.
CouseId
>
0
)
{
extModel
.
CourseName
=
courseRepository
.
GetEntity
(
extModel
.
CouseId
)?.
CourseName
??
""
;
...
...
@@ -1330,6 +1362,10 @@ namespace Edu.Module.Course
{
extModel
.
WeekDayList
=
Common
.
Plugin
.
JsonHelper
.
DeserializeObject
<
List
<
string
>>(
extModel
.
DateJson
);
}
if
(!
string
.
IsNullOrEmpty
(
Common
.
ConvertHelper
.
FormatDate
(
extModel
.
OpenTime
)))
{
extModel
.
ClassDateList
.
Add
(
Common
.
ConvertHelper
.
FormatDate
(
extModel
.
OpenTime
));
}
}
return
extModel
;
}
...
...
@@ -2586,6 +2622,7 @@ namespace Edu.Module.Course
TotalNum
+=
tempTotalNum
;
var
checkList
=
checkLogList
.
Where
(
x
=>
x
.
CheckStatus
==
0
&&
x
.
ClassTimeId
==
subItem
.
ClassTimeId
).
ToList
();
var
noCheckList
=
checkLogList
.
Where
(
x
=>
x
.
CheckStatus
==
1
&&
x
.
ClassTimeId
==
subItem
.
ClassTimeId
).
ToList
();
var
askforleaveList
=
checkLogList
.
Where
(
x
=>
x
.
CheckStatus
==
2
&&
x
.
ClassTimeId
==
subItem
.
ClassTimeId
).
ToList
();
NoCheckNum
+=
noCheckList
.
Count
();
var
obj
=
new
{
...
...
@@ -2595,6 +2632,8 @@ namespace Edu.Module.Course
CheckList
=
checkList
.
Select
(
qitem
=>
new
{
qitem
.
GuestName
}),
NoCheckNum
=
noCheckList
.
Count
(),
NoCheckList
=
noCheckList
.
Select
(
qitem
=>
new
{
qitem
.
GuestName
}),
AskforleaveNum
=
askforleaveList
.
Count
(),
AskforleaveList
=
askforleaveList
.
Select
(
qitem
=>
new
{
qitem
.
GuestName
}),
};
time
.
Add
(
obj
);
}
...
...
Edu.Repository/BackClass/RB_Student_MakeupRepository.cs
View file @
3eeb0325
...
...
@@ -37,7 +37,7 @@ FROM RB_Student_Makeup AS A LEFT JOIN rb_class_check AS B ON A.ClassCheckId=B.Cl
LEFT JOIN rb_teacher AS F ON B.TeacherId=F.TId
LEFT JOIN rb_class_room AS G ON B.ClassRoomId=G.RoomId
LEFT JOIN rb_class_time AS H ON B.ClassTimeId=H.ClassTimeId
WHERE 1=1 and B.CheckStatus
=1
WHERE 1=1 and B.CheckStatus
IN(1,2)
"
);
if
(
query
!=
null
)
{
...
...
Edu.WebApi/Controllers/Course/ClassController.cs
View file @
3eeb0325
...
...
@@ -78,6 +78,8 @@ namespace Edu.WebApi.Controllers.Course
item
.
CouseId
,
item
.
CourseName
,
item
.
Teacher_Id
,
item
.
ClassRoomId
,
item
.
RoomName
,
item
.
TeacherName
,
item
.
ClassPersion
,
item
.
OrderStudentCount
,
...
...
@@ -196,6 +198,7 @@ namespace Edu.WebApi.Controllers.Course
[
HttpPost
]
public
ApiResult
SetClass
()
{
var
oldClassId
=
base
.
ParmJObj
.
GetInt
(
"ClassId"
);
var
extModel
=
new
RB_Class_ViewModel
()
{
ClassId
=
base
.
ParmJObj
.
GetInt
(
"ClassId"
),
...
...
@@ -232,6 +235,7 @@ namespace Edu.WebApi.Controllers.Course
StudentNumType
=
(
StudentNumTypeEnum
)
base
.
ParmJObj
.
GetInt
(
"StudentNumType"
),
ClassHourMinute
=
base
.
ParmJObj
.
GetInt
(
"ClassHourMinute"
),
};
extModel
.
ClassDateList
=
Common
.
Plugin
.
JsonHelper
.
DeserializeObject
<
List
<
string
>>(
base
.
ParmJObj
.
GetStringValue
(
"ClassDateList"
));
try
{
string
ClassStepPriceListStr
=
base
.
ParmJObj
.
GetStringValue
(
"ClassStepPriceList"
);
...
...
@@ -308,6 +312,10 @@ namespace Edu.WebApi.Controllers.Course
{
Common
.
Plugin
.
LogHelper
.
Write
(
ex
,
"SetClass_DefaultPlanTimeList"
);
}
if
(
oldClassId
==
0
&&
(
extModel
.
ClassDateList
==
null
||
(
extModel
.
ClassDateList
!=
null
&&
extModel
.
ClassDateList
.
Count
==
0
)))
{
return
ApiResult
.
Failed
(
message
:
"请选择开班日期!"
);
}
List
<
string
>
dayList
=
new
List
<
string
>();
if
(
extModel
.
DefaultTimeList
!=
null
&&
extModel
.
DefaultTimeList
.
Count
>
0
)
{
...
...
@@ -324,6 +332,10 @@ namespace Edu.WebApi.Controllers.Course
foreach
(
var
item
in
rootItem
.
TimeList
)
{
string
message
=
""
;
if
(
string
.
IsNullOrEmpty
(
item
.
StartTime
)
||
string
.
IsNullOrEmpty
(
item
.
EndTime
))
{
return
ApiResult
.
Failed
(
message
:
"请选择【学习时段】的开始时间和结束时间!"
);
}
if
(!
Common
.
ConvertHelper
.
IsTime
(
item
.
StartTime
+
":00"
))
{
message
=
"【"
+
item
.
StartTime
+
"】格式不正确!(参考格式为 00:00)"
;
...
...
@@ -378,7 +390,23 @@ namespace Edu.WebApi.Controllers.Course
{
extModel
.
DefaultTimeJson
=
""
;
}
bool
flag
=
classModule
.
SetClassModule
(
extModel
);
bool
flag
=
false
;
if
(
oldClassId
==
0
)
{
foreach
(
var
item
in
extModel
.
ClassDateList
)
{
extModel
.
OpenTime
=
Convert
.
ToDateTime
(
item
);
if
(
oldClassId
==
0
)
{
extModel
.
ClassId
=
0
;
}
flag
=
classModule
.
SetClassModule
(
extModel
);
}
}
else
{
flag
=
classModule
.
SetClassModule
(
extModel
);
}
return
flag
?
ApiResult
.
Success
(
data
:
extModel
)
:
ApiResult
.
Failed
();
}
...
...
@@ -557,7 +585,8 @@ namespace Edu.WebApi.Controllers.Course
{
ClassId
=
base
.
ParmJObj
.
GetInt
(
"ClassId"
),
ClassStatus
=
(
ClassStatusEnum
)
base
.
ParmJObj
.
GetInt
(
"ClassStatus"
),
Teacher_Id
=
base
.
ParmJObj
.
GetInt
(
"Teacher_Id"
)
Teacher_Id
=
base
.
ParmJObj
.
GetInt
(
"Teacher_Id"
),
ClassRoomId
=
base
.
ParmJObj
.
GetInt
(
"ClassRoomId"
),
};
if
(
extModel
.
ClassId
<=
0
)
{
...
...
@@ -570,10 +599,14 @@ namespace Edu.WebApi.Controllers.Course
}
if
(
model
.
ClassStatus
==
ClassStatusEnum
.
NonOpenClass
&&
extModel
.
ClassStatus
==
ClassStatusEnum
.
StudyIng
&&
model
.
Teacher_Id
<=
0
&&
extModel
.
Teacher_Id
<=
0
)
{
return
ApiResult
.
ParamIsNull
(
message
:
"未找到此班级,请刷新页面重试!"
);
return
ApiResult
.
ParamIsNull
(
message
:
"请选择班级上课老师!"
);
}
if
(
model
.
ClassStatus
==
ClassStatusEnum
.
NonOpenClass
&&
extModel
.
ClassStatus
==
ClassStatusEnum
.
StudyIng
&&
model
.
ClassRoomId
<=
0
&&
extModel
.
ClassRoomId
<=
0
)
{
return
ApiResult
.
ParamIsNull
(
message
:
"请选择班级上课教室!"
);
}
extModel
.
CouseId
=
model
.
CouseId
;
bool
flag
=
classModule
.
SetClassStatusModule
(
extModel
,
out
string
message
,
out
bool
result
);
bool
flag
=
classModule
.
SetClassStatusModule
(
extModel
,
base
.
UserInfo
,
out
string
message
,
out
bool
result
);
return
flag
?
ApiResult
.
Success
(
message
:
message
,
data
:
result
)
:
ApiResult
.
Failed
(
message
:
message
,
data
:
result
);
}
...
...
@@ -627,6 +660,7 @@ namespace Edu.WebApi.Controllers.Course
CompleteProgress
=
extModel
?.
CompleteProgress
??
0
,
ClassStatusStr
=
extModel
?.
ClassStatusStr
??
""
,
ClassHourMinute
=
extModel
?.
ClassHourMinute
??
45
,
ClassDateList
=
extModel
?.
ClassDateList
??
new
List
<
string
>(),
};
return
ApiResult
.
Success
(
data
:
obj
);
}
...
...
@@ -1446,7 +1480,7 @@ namespace Edu.WebApi.Controllers.Course
Name
=
"不限"
});
}
return
ApiResult
.
Success
(
data
:
list
);
return
ApiResult
.
Success
(
data
:
list
.
OrderBy
(
qitem
=>
qitem
.
Id
)
);
}
#
endregion
...
...
Edu.WebApi/Controllers/Course/TeacherClassController.cs
View file @
3eeb0325
...
...
@@ -75,6 +75,8 @@ namespace Edu.WebApi.Controllers.Course
item
.
CourseName
,
item
.
Teacher_Id
,
item
.
TeacherName
,
item
.
ClassRoomId
,
item
.
RoomName
,
item
.
ClassPersion
,
item
.
TotalPlanNum
,
item
.
UsePlanNum
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment