mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2024-11-28 18:15:52 -05:00
3d705e5d70
Fix link to /teachers/classes (fixes bugquest#20) Fix edit button color/icon (bugquest#23) Fix bugquest#34 Fix password input width (bugquest#33) Center new pasword text Fix teacher password reset endpoint (bugquest#4) Refactor+use NewHomeView logic for user page button (Fixes bugquest#2) Refactor teacher-password-reset endpoint This makes it much easier to prevent collisions with other logic when PUTing new User attributes. Add regression test for converting to teacher account Fix email verified links, require login (fix bugquest#16) Fix me having stale emailVerified value (Fixes bugquest#40) Don't show JoinClassModal to students Add paragraph to JoinClassModal (fixes bugquest#14) Update change-password label text (fixes bugquest#30) Fix prompting for login on Account Settings page (bugquest #10) Show validation errors for teacher password reset (bugquest#36) Show yellow progress dot in My Classes if anyone has started (bugquest#55) Remove confusing text (bugquest#100)
130 lines
4.7 KiB
Text
130 lines
4.7 KiB
Text
extends /templates/base-flat
|
|
|
|
block page_nav
|
|
include ./teacher-dashboard-nav.jade
|
|
|
|
block content
|
|
if !me.isTeacher() && !view.classrooms.size()
|
|
.access-restricted.container.text-center.m-y-3
|
|
h5(data-i18n='teacher.access_restricted')
|
|
p(data-i18n='teacher.teacher_account_required')
|
|
if me.isAnonymous()
|
|
.login-button.btn.btn-lg.btn-primary(data-i18n='login.log_in')
|
|
a.btn.btn-lg.btn-primary-alt(href="/teachers/signup" data-i18n='teacher.create_teacher_account')
|
|
else
|
|
a.btn.btn-lg.btn-primary(href="/teachers/update-account" data-i18n="teachers_quote.convert_account_title")
|
|
button#logout-button.btn.btn-lg.btn-primary-alt(data-i18n="login.log_out")
|
|
|
|
.teacher-account-blurb.text-center.col-xs-6.col-xs-offset-3.m-y-3
|
|
h5(data-i18n='teacher.what_is_a_teacher_account')
|
|
p(data-i18n='teacher.teacher_account_explanation')
|
|
|
|
else
|
|
if !me.isTeacher()
|
|
.alert.alert-danger.text-center
|
|
.container
|
|
// DNT: Temporary
|
|
h3 ATTENTION: Please upgrade your account to a Teacher Account.
|
|
p
|
|
| We are transitioning to a new improved classroom management system for instructors.
|
|
| Please convert your account to ensure you retain access to your classrooms.
|
|
a.btn.btn-primary.btn-lg(href="/teachers/update-account") Upgrade to teacher account
|
|
|
|
.container
|
|
h3(data-i18n='teacher.current_classes')
|
|
|
|
.classes.container
|
|
// Loop each class
|
|
each classroom in view.classrooms.models
|
|
unless classroom.get('archived')
|
|
+classRow(classroom)
|
|
|
|
+createClassButton
|
|
|
|
- var archivedClassrooms = view.classrooms.where({archived: true});
|
|
if _.size(archivedClassrooms)
|
|
.container
|
|
h3(data-i18n='teacher.archived_classes')
|
|
p(data-i18n='teacher.archived_classes_blurb')
|
|
|
|
.classes.container
|
|
each classroom in archivedClassrooms
|
|
+archivedClassRow(classroom)
|
|
|
|
mixin classRow(classroom)
|
|
.class.row
|
|
.col-xs-6
|
|
.text-h4.semibold
|
|
= classroom.get('name')
|
|
.language.small
|
|
span(data-i18n='teacher.language')
|
|
| :
|
|
span.language-name
|
|
= classroom.capitalLanguage
|
|
.student-count.small
|
|
span(data-i18n='teacher.students')
|
|
| :
|
|
span
|
|
= classroom.get('members').length
|
|
.class-links
|
|
a.text-h6(data-i18n='teacher.view_class' href=('/teachers/classes/' + classroom.id))
|
|
a.edit-classroom.text-h6(data-i18n='teacher.edit_class_settings' data-classroom-id=classroom.id)
|
|
a.archive-classroom.text-h6(data-i18n='teacher.archive_class' data-classroom-id=classroom.id)
|
|
|
|
.progress-col.col-xs-5
|
|
if classroom.get('members').length == 0
|
|
+addStudentsButton(classroom)
|
|
else
|
|
each trimCourse, index in classroom.get('courses') || []
|
|
- var course = view.courses.get(trimCourse._id);
|
|
+progressDot(classroom, course, index)
|
|
.view-class-arrow.col-xs-1
|
|
a.view-class-arrow-inner.glyphicon.glyphicon-chevron-right(data-classroom-id=classroom.id, href=('/teachers/classes/' + classroom.id))
|
|
|
|
|
|
mixin addStudentsButton(classroom)
|
|
.add-students
|
|
.text-center
|
|
div.small-details(data-i18n='teacher.no_students_yet')
|
|
| This class has no students yet.
|
|
a.add-students-btn.btn.btn-lg.btn-primary(data-classroom-id=classroom.id )
|
|
span(data-i18n='teacher.add_students')
|
|
| Add Students
|
|
|
|
mixin createClassButton
|
|
.create-class
|
|
.text-center
|
|
a.create-classroom-btn.btn.btn-lg.btn-primary(data-i18n='teacher.create_new_class')
|
|
| Create a New Class
|
|
|
|
mixin progressDot(classroom, course, index)
|
|
//- TODO: Give classes abbreviations instead of using index?
|
|
//- TODO: inefficient. Cache this in the view?
|
|
- courseInstance = view.courseInstances.findWhere({ courseID: course.id, classroomID: classroom.id })
|
|
- var total = classroom.get('members').length
|
|
- var complete = 0;
|
|
- var dotClass = '';
|
|
- var started = 0;
|
|
if courseInstance
|
|
- complete = courseInstance.numCompleted
|
|
- started = courseInstance.started
|
|
- dotClass = complete === total ? 'forest' : started ? 'gold' : '';
|
|
- var progressDotContext = {total: total, complete: complete};
|
|
.progress-dot(class=dotClass, data-title=view.progressDotTemplate(progressDotContext))
|
|
+progressDotLabel(index)
|
|
|
|
mixin progressDotLabel(index)
|
|
.dot-label
|
|
.text-h6
|
|
| CS
|
|
span
|
|
= index + 1
|
|
|
|
mixin archivedClassRow(classroom)
|
|
.class.row
|
|
.col-xs-10
|
|
span
|
|
= classroom.get('name')
|
|
.col-xs-2
|
|
.class-links.pull-right
|
|
a.unarchive-classroom.text-h6(data-i18n='teacher.unarchive_class' data-classroom-id=classroom.id)
|