diff --git a/messages/uniworx/de.msg b/messages/uniworx/de.msg index 5cf794630..b28e5d649 100644 --- a/messages/uniworx/de.msg +++ b/messages/uniworx/de.msg @@ -30,6 +30,7 @@ Aborted: Abgebrochen Remarks: Hinweise Registered: Angemeldet RegisteredSince: Angemeldet seit +Registration: Anmeldung RegisterFrom: Anmeldungen von RegisterTo: Anmeldungen bis DeRegUntil: Abmeldungen bis @@ -1023,6 +1024,7 @@ MenuExamEdit: Bearbeiten MenuExamUsers: Teilnehmer MenuExamAddMembers: Prüfungsteilnehmer hinzufügen MenuLecturerInvite: Dozenten hinzufügen +MenuAllocationInfo: Hinweise zum Ablauf einer Zentralanmeldung AuthPredsInfo: Um eigene Veranstaltungen aus Sicht der Teilnehmer anzusehen, können Veranstalter und Korrektoren hier die Prüfung ihrer erweiterten Berechtigungen temporär deaktivieren. Abgewählte Prädikate schlagen immer fehl. Abgewählte Prädikate werden also nicht geprüft um Zugriffe zu gewähren, welche andernfalls nicht erlaubt wären. Diese Einstellungen gelten nur temporär bis Ihre Sitzung abgelaufen ist, d.h. bis ihr Browser-Cookie abgelaufen ist. Durch Abwahl von Prädikaten kann man sich höchstens temporär aussperren. AuthPredsActive: Aktive Authorisierungsprädikate @@ -1481,8 +1483,11 @@ AllocationStaffRegisterFrom: Eintragung der Kurse ab AllocationStaffRegister: Eintragung der Kurse AllocationRegisterFrom: Bewerbung ab AllocationRegister: Bewerbung +AllocationRegisterClosed: Die Zentralanmeldung ist aktuell geschlossen. +AllocationRegisterOpensIn opens@Text: Die Zentralanmeldung öffnet voraussichtlich in #{opens} AllocationStaffAllocationFrom: Bewertung der Bewerbungen ab -AllocationStaffAllocation: Bewertung der Bewerbungen +AllocationStaffAllocation: Bewerbungsbewertung +AllocationProcess: Platzvergabe AllocationNoApplication: Keine Bewerbung AllocationPriority: Priorität AllocationPriorityTip: Kurse, denen Sie eine höhere Priorität zuteilen, werden bei der Platzvergabe präferiert. @@ -1496,7 +1501,7 @@ BtnAllocationRegister: Teilnahme registrieren BtnAllocationRegistrationEdit: Teilnahme anpassen AllocationParticipation: Teilnahme an der Zentralanmeldung AllocationParticipationLoginFirst: Um an der Zentralanmeldung teilzunehmen, loggen Sie sich bitte zunächst ein. -AllocationCourses: Kurse +AllocationCourses: Kurse dieser Zentralanmeldung AllocationData: Organisatorisches AllocationCoursePriority i@Natural: #{i}. Wahl AllocationCourseNoApplication: Keine Bewerbung diff --git a/routes b/routes index d1da938d1..88099df1a 100644 --- a/routes +++ b/routes @@ -61,6 +61,7 @@ /info InfoR GET !free /info/lecturer InfoLecturerR GET !lecturer /info/data DataProtR GET !free +/info/allocation InfoAllocationR GET !free /impressum ImpressumR GET !free /version VersionR GET !free diff --git a/src/Foundation.hs b/src/Foundation.hs index 247a9bb91..e22691223 100644 --- a/src/Foundation.hs +++ b/src/Foundation.hs @@ -1728,6 +1728,7 @@ instance YesodBreadcrumbs UniWorX where breadcrumb InfoR = return ("Information" , Nothing) breadcrumb InfoLecturerR = return ("Veranstalter" , Just InfoR) breadcrumb DataProtR = return ("Datenschutz" , Just InfoR) + breadcrumb InfoAllocationR = return ("Zentralanmeldungen", Just InfoR) breadcrumb ImpressumR = return ("Impressum" , Just InfoR) breadcrumb VersionR = return ("Versionsgeschichte", Just InfoR) @@ -2156,7 +2157,7 @@ pageActions (TermCourseListR tid) = ] pageActions (TermSchoolCourseListR _tid _ssh) = [ MenuItem - { menuItemType = PageActionPrime + { menuItemType = PageActionPrime , menuItemLabel = MsgMenuCourseNew , menuItemIcon = Just "book" , menuItemRoute = SomeRoute CourseNewR @@ -2164,6 +2165,16 @@ pageActions (TermSchoolCourseListR _tid _ssh) = , menuItemAccessCallback' = return True } ] +pageActions (AllocationR _tid _ssh _ash AShowR) = + [ MenuItem + { menuItemType = PageActionPrime + , menuItemLabel = MsgMenuAllocationInfo + , menuItemIcon = Nothing + , menuItemRoute = SomeRoute InfoAllocationR + , menuItemModal = True + , menuItemAccessCallback' = return True + } + ] pageActions (CourseListR) = [ MenuItem { menuItemType = PageActionPrime diff --git a/src/Handler/Allocation.hs b/src/Handler/Allocation.hs index 991ef61bb..3cb35e7cc 100644 --- a/src/Handler/Allocation.hs +++ b/src/Handler/Allocation.hs @@ -2,6 +2,7 @@ module Handler.Allocation ( module Handler.Allocation ) where +import Handler.Allocation.Info as Handler.Allocation import Handler.Allocation.Show as Handler.Allocation import Handler.Allocation.Application as Handler.Allocation import Handler.Allocation.Register as Handler.Allocation diff --git a/src/Handler/Allocation/Info.hs b/src/Handler/Allocation/Info.hs new file mode 100644 index 000000000..d3140d75a --- /dev/null +++ b/src/Handler/Allocation/Info.hs @@ -0,0 +1,13 @@ +module Handler.Allocation.Info + ( getInfoAllocationR + ) where + +import Import +import Handler.Utils + + +getInfoAllocationR :: Handler Html +getInfoAllocationR = do + siteLayoutMsg MsgMenuAllocationInfo $ do + setTitleI MsgMenuAllocationInfo + $(i18nWidgetFile "allocation-info") diff --git a/src/Handler/Allocation/Show.hs b/src/Handler/Allocation/Show.hs index 57264cf1c..0cc4d455b 100644 --- a/src/Handler/Allocation/Show.hs +++ b/src/Handler/Allocation/Show.hs @@ -9,18 +9,19 @@ import Handler.Allocation.Register import Handler.Allocation.Application import qualified Database.Esqueleto as E - + getAShowR :: TermId -> SchoolId -> AllocationShorthand -> Handler Html getAShowR tid ssh ash = do muid <- maybeAuthId + now <- liftIO getCurrentTime let resultCourse :: Simple Field1 a (Entity Course) => Lens' a (Entity Course) resultCourse = _1 resultCourseApplication :: Simple Field2 a (Maybe (Entity CourseApplication)) => Traversal' a (Entity CourseApplication) resultCourseApplication = _2 . _Just - resultHasTemplate :: Simple Field3 a (E.Value Bool) => Lens' a Bool + resultHasTemplate :: Simple Field3 a (E.Value Bool) => Lens' a Bool resultHasTemplate = _3 . _Value (Entity aId Allocation{..}, courses, registration) <- runDB $ do @@ -91,5 +92,6 @@ getAShowR tid ssh ash = do
- _{MsgAllocationParticipationLoginFirst} + _{MsgAllocationParticipationLoginFirst} + $elseif mayRegister + $# existing registrations may also be edited in this case + ^{registerForm'} + $elseif is _Just registration + $# show existing registration even if it cannot be changed now + $maybe Entity _ AllocationUser{allocationUserTotalCourses} <- registration +
+ _{MsgAllocationRegisterOpensIn (formatDiffDays daysToOpen)} + $nothing +
+ _{MsgAllocationRegisterClosed} +
+ $# This redundant links prevents useless help requests from frantic users
+ ^{allocationInfoModal}
$if not (null courseWidgets)
+ Jede Zentralanmeldung durchläuft
+ der Reihe nach folgende Phasen:
+
+ Veranstalter können nur in diesem Zeitraum ihre Veranstaltungen
+ zur Zentralanmeldung hinzufügen oder entfernen.
+
+ Pro Veranstaltung wird einzeln festgelegt,
+ ob Studierende einen Bewerbungstext und/oder Bewerbungsdateien
+ einreichen sollen.
+ Veranstalter stellen auch Anweisungen zur Bewerbung ein,
+ z.B. welchen Inhalt abzugebende Bewerbungsdateien enthalten sollen.
+
+ Zur Zentralanmeldung eingetragene Kurse
+ erlauben während dem gesamten Ablauf
+ der Zentralanmeldung keine anderweitigen Kursanmeldung mehr,
+ auch nicht durch den Veranstalter selbst.
+
+
+ Studierende können sich nur in diesem Zeitraum
+ auf Plätze in Kursen einer Zentralanmeldung bewerben.
+
+ Bewerber können jedem Kurs der Zentralanmeldung eine Priorität
+ zuweisen, zwischen "dieser Kurs wäre meine erste Wahl"
+ und "diesen Kurs besuche ich auf keinen Fall".
+ Es kann auch mehreren Kursen die gleiche Priorität eingeräumt werden.
+
+ Studierende können auch mehr als einen Platz
+ in verschiedenen Kursen einer Zentralanmeldung anfordern,
+ falls die Kurskapazitäten und/oder Dringlichkeit ausreichend sind.
+
+ Bewerbungstexte und/oder Bewerbungsdateien
+ sind pro Kurs anzugeben, falls vom Veranstalter gefordert.
+
+
+ Veranstalter können nur in diesem Zeitraum die
+ Bewerbungen einsehen und bewerten.
+ $#
+ $# Nur in manchen Zentralanmeldungen dürfen Veranstalter
+ $# Bewerber jetzt direkt ablehnen und/oder übernehmen.
+ $#
+ $# Veranstalter haben noch eine letzte Möglichkeit,
+ $# die Kurskapazität anzupassen.
+
+
+ Die Plätze werden gemäß Studienfortschritt, Dringlichkeit
+ und der Bewertung durch den Veranstalter auf die Bewerber verteilt.
+
+ Die Bewerber werden diekt in den jeweiligen Kursen angemeldet.
+ Eine Abmeldung durch Studierende ist nicht erlaubt.
+ Übernommene Bewerber, welche einen zugeteilten Platz
+ ohne Angabe eines triftigen Grundes nicht antreten,
+ werden in zukünftigen Zentralanmeldungen
+ unter Umständen benachteiligt.
+
+ Veranstalter können frühestens nach der erfolgten Zuteilung
+ Teilnehmer selbst an-/abmelden
+ und ggf. Nachrücker für freigewordene Plätze anfordern.
+
+
+ Der Ablauf einer Zentralanmeldung kann unter Umständen noch variieren.
+
+ Insbesondere: #
+ Fehlt in der Übersichtsseite einer Zentralanmeldung
+ die Angabe einer dieser Phasen, dann wurde der entsprechende Zeitraum
+ leider noch nicht festgelegt!
+
+ Mehrere Zentralanmeldungen werden völlig unabhängig voneinander
+ abgewickelt.
+
diff --git a/templates/table/course/course-teaser.hamlet b/templates/table/course/course-teaser.hamlet
index b4f50fe97..f9a3f2a71 100644
--- a/templates/table/course/course-teaser.hamlet
+++ b/templates/table/course/course-teaser.hamlet
@@ -17,9 +17,16 @@
$forall lecturer <- courseLecturers
+