feat(course-visibility): rework visibility check for ZA courses
This commit is contained in:
parent
7ce60a36f4
commit
a16eb1ab91
@ -12,6 +12,7 @@ import Handler.Allocation.Register
|
||||
import Handler.Allocation.Application
|
||||
|
||||
import qualified Database.Esqueleto as E
|
||||
import qualified Database.Esqueleto.Utils as E
|
||||
|
||||
|
||||
getAShowR :: TermId -> SchoolId -> AllocationShorthand -> Handler Html
|
||||
@ -31,7 +32,7 @@ getAShowR tid ssh ash = do
|
||||
resultIsRegistered = _4 . _Value
|
||||
|
||||
(Entity aId Allocation{..}, School{..}, isAnyLecturer, courses, registration) <- runDB $ do
|
||||
alloc@(Entity aId Allocation{allocationSchool}) <- getBy404 $ TermSchoolAllocationShort tid ssh ash
|
||||
alloc@(Entity aId Allocation{allocationSchool,allocationRegisterFrom,allocationRegisterTo}) <- getBy404 $ TermSchoolAllocationShort tid ssh ash
|
||||
school <- getJust allocationSchool
|
||||
|
||||
courses <- E.select . E.from $ \((allocationCourse `E.InnerJoin` course) `E.LeftOuterJoin` courseApplication `E.LeftOuterJoin` registration) -> do
|
||||
@ -43,7 +44,15 @@ getAShowR tid ssh ash = do
|
||||
E.&&. courseApplication E.?. CourseApplicationAllocation E.==. E.just (E.just $ E.val aId)
|
||||
E.on $ allocationCourse E.^. AllocationCourseCourse E.==. course E.^. CourseId
|
||||
E.where_ $ allocationCourse E.^. AllocationCourseAllocation E.==. E.val aId
|
||||
E.&&. mayViewCourse' muid ata now course
|
||||
E.&&. (mayViewCourse' muid ata now course
|
||||
E.||. E.isJust (courseApplication E.?. CourseApplicationId)
|
||||
E.||. (E.isJust (E.val allocationRegisterFrom)
|
||||
E.&&. E.val allocationRegisterFrom E.<=. E.val (Just now)
|
||||
E.&&. (E.isNothing (E.val allocationRegisterTo)
|
||||
E.||. E.val (Just now) E.<=. E.val allocationRegisterTo
|
||||
)
|
||||
)
|
||||
)
|
||||
E.orderBy [E.asc $ course E.^. CourseName]
|
||||
let hasTemplate = E.exists . E.from $ \courseAppInstructionFile ->
|
||||
E.where_ $ courseAppInstructionFile E.^. CourseAppInstructionFileCourse E.==. course E.^. CourseId
|
||||
|
||||
Loading…
Reference in New Issue
Block a user