Skip to content
Snippets Groups Projects
dashboard.html 12.4 KiB
Newer Older
<%!
  from django.core.urlresolvers import reverse
  from courseware.courses import course_image_url, get_course_about_section
  from courseware.access import has_access
Victor Shnayder's avatar
Victor Shnayder committed
  from certificates.models import CertificateStatuses
Matthew Mongeau's avatar
Matthew Mongeau committed
<%inherit file="main.html" />

<%namespace name='static' file='static_content.html'/>

<%block name="title"><title>Dashboard</title></%block>

<%block name="js_extra">
  <script type="text/javascript">
  (function() {

    $(".unenroll").click(function(event) {
      $("#unenroll_course_id").val( $(event.target).data("course-id") );
      $("#unenroll_course_number").text( $(event.target).data("course-number") );
    });

    $(document).delegate('#unenroll_form', 'ajax:success', function(data, json, xhr) {
      if(json.success) {
        location.href="${reverse('dashboard')}";
      } else {
        if($('#unenroll_error').length == 0) {
          $('#unenroll_form').prepend('<div id="unenroll_error" class="modal-form-error"></div>');
        }
        $('#unenroll_error').text(json.error).stop().css("display", "block");
      }
    });

    $('#pwd_reset_button').click(function() {
      $.post('${reverse("password_reset")}',
             {"email"  : $('#id_email').val()},
             function(data){
               $("#password_reset_complete_link").click();
             });
    });
    $("#change_email_form").submit(function(){
      var new_email = $('#new_email_field').val();
      var new_password = $('#new_email_password').val();

      $.post('${reverse("change_email")}',
               {"new_email" : new_email, "password" : new_password},
               function(data) {
                 if (data.success) {
                   $("#change_email_title").html("Please verify your new email");
                   $("#change_email_form").html("<p>You'll receive a confirmation in your " +
                                                "in-box. Please click the link in the " +
                                                "email to confirm the email change.</p>");
                 } else {
                   $("#change_email_error").html(data.error).stop().css("display", "block");
                 }
               });
      return false;
    $("#change_name_form").submit(function(){
      var new_name = $('#new_name_field').val();
      var rationale = $('#name_rationale_field').val();

      $.post('${reverse("change_name")}',
             {"new_name":new_name, "rationale":rationale},
             function(data) {
               if(data.success) {
                 location.reload();
                 // $("#change_name_body").html("<p>Name changed.</p>");
               } else {
                 $("#change_name_error").html(data.error).stop().css("display", "block");
               }
             });
       return false;
    });

<section class="container dashboard">
  %if message:
    <section class="dashboard-banner">
      ${message}
    </section>
  %endif
Matthew Mongeau's avatar
Matthew Mongeau committed

  <section class="profile-sidebar">
    <header class="profile">
      <h1 class="user-name">${ user.username }</h1>
          <span class="title"><div class="icon name-icon"></div>Full Name (<a href="#apply_name_change" rel="leanModal" class="edit-name">edit</a>)</span> <span class="data">${ user.profile.name | h }</span>
        </li>
        <li>
          <span class="title"><div class="icon email-icon"></div>Email (<a href="#change_email" rel="leanModal" class="edit-email">edit</a>)</span> <span class="data">${ user.email | h }</span>
          <span class="title"><a href="#password_reset_complete" rel="leanModal" id="pwd_reset_button">Reset Password</a></span>
          <form id="password_reset_form" method="post" data-remote="true" action="${reverse('password_reset')}">
            <input id="id_email" type="hidden" name="email" maxlength="75" value="${user.email}" />
            <!-- <input type="submit" id="pwd_reset_button" value="Reset Password" /> -->
          </form>
Matthew Mongeau's avatar
Matthew Mongeau committed

  <section class="my-courses">
    <header>
      <h2>Current Courses</h2>
Matthew Mongeau's avatar
Matthew Mongeau committed

    % if len(courses) > 0:
Victor Shnayder's avatar
Victor Shnayder committed
      % for course, cert_status in zip(courses, cert_statuses):
        <article class="my-course">
          if has_access(user, course, 'load'):
            course_target = reverse('info', args=[course.id])
          else:
            course_target = reverse('about_course', args=[course.id])
          %>

          <a href="${course_target}">
            <section class="cover" style="background-image: url('${course_image_url(course)}')">
              <div class="shade"></div>
              <div class="arrow">&#10095;</div>

            <section class="info">
              <hgroup>
                <h2 class="university">${get_course_about_section(course, 'university')}</h2>
                <h3>${course.number} ${course.title}</h3>
              </hgroup>
              <section class="course-status course-status-completed">
                <p><!-- Class Starts - <span>${course.start_date_text}</span> --> Course Completed - <span>Nov 6, 2012</span></p>
              % if course.id in show_courseware_links_for:
                <p class="enter-course">View Courseware</p>
              % endif
Victor Shnayder's avatar
Victor Shnayder committed
        % if course.has_ended:
Victor Shnayder's avatar
Victor Shnayder committed
            <%
            passing_grade = False
            cert_button = False
            survey_button = False
            if cert_status['status'] in [CertificateStatuses.generating, CertificateStatuses.regenerating]:
                status_css_class = 'course-status-certrendering'
                cert_button = True
                survey_button = True
                passing_grade = True
            elif cert_status['status'] == CertificateStatuses.downloadable:
                status_css_class = 'course-status-certavailable'
                cert_button = True
                survey_button = True
                passing_grade = True
            elif cert_status['status'] == CertificateStatuses.notpassing:
                status_css_class = 'course-status-certnotavailable'
                survey_button = True
            else:
                # This is primarily the 'unavailable' state, but also 'error', 'deleted', etc.
                status_css_class = 'course-status-processing'

            if survey_button and not course.end_of_course_survey_url:
                survey_button = False
            %>
Victor Shnayder's avatar
Victor Shnayder committed
            <div class="message message-status ${status_css_class} is-shown">

            % if cert_status == CertificateStatuses.unavailable:
              <p class="message-copy">Final course details are being wrapped up at this time.
              Your final standing will be available shortly.</p>
            % elif passing_grade:
              <p class="message-copy">You have received a grade of
                        <span class="grade-value">${cert_status['grade']}</span>
              in this course.</p>
            % elif cert_status == CertificateStatuses.notpassing:
              <p class="message-copy">You did not complete the necessary requirements for
              completion of this course. Your grade was <span class="grade-value">${cert_status['grade']}</span>
              </p>
            % endif
            % if cert_button or survey_button:
              <ul class="actions">
                % if cert_button and cert_status['status'] == CertificateStatuses.generating:
                  <li class="action"><span class="btn disabled" href="">Your Certificate is Generating</span></li>
                % elif cert_button and cert_status['status'] == CertificateStatuses.downloadable:
                  <li class="action">
                  <a class="btn" href="${cert_status['download_url']}"
                     title="This link will open/download a PDF document">
                     Download Your PDF Certificate</a></li>
                % endif
                % if survey_button:
                  <li class="action"><a class="cta" href="${course.end_of_course_survey_url}">
                         Complete our course feedback survey</a></li>
                % endif
              </ul>
            % endif
            </div>

        % endif
        <a href="#unenroll-modal" class="unenroll" rel="leanModal" data-course-id="${course.id}" data-course-number="${course.number}">Unregister</a>
      % endfor
    % else:
      <section class="empty-dashboard-message">
        <p>Looks like you haven't registered for any courses yet.</p>
        <a href="${reverse('courses')}">Find courses now!</a>
Matthew Mongeau's avatar
Matthew Mongeau committed

    % if staff_access and len(errored_courses) > 0:
      <div id="course-errors">
        <h2>Course-loading errors</h2>

      % for course_dir, errors in errored_courses.items():
         <h3>${course_dir | h}</h3>
             <ul>
           % for (msg, err) in errors:
               <li>${msg}
                 <ul><li><pre>${err}</pre></li></ul>
               </li>
           % endfor
             </ul>
      % endfor
    % endif
Matthew Mongeau's avatar
Matthew Mongeau committed
  </section>
</section>

<section id="unenroll-modal" class="modal unenroll-modal">
  <div class="inner-wrapper">
    <header>
      <h2>Are you sure you want to unregister from <span id="unenroll_course_number"></span>?</h2>
    </header>

    <form id="unenroll_form" method="post" data-remote="true" action="${reverse('change_enrollment')}">
      <input name="course_id" id="unenroll_course_id" type="hidden" />
      <input name="enrollment_action" type="hidden" value="unenroll" />
      <div class="submit">
        <input name="submit" type="submit" value="Unregister" />
      </div>
    </form>

    <div class="close-modal">
      <div class="inner">
        <p>&#10005;</p>
      </div>
    </div>
  </div>
</section>

<section id="password_reset_complete" class="modal">
  <div class="inner-wrapper">
    <header>
      <h2>Password Reset Email Sent</h2>
      <hr/>
    </header>
      <form> <!-- Here for styling reasons -->
        <section>
          <p>An email has been sent to ${user.email}. Follow the link in the email to change your password.</p>
        </section>
      </form>
    </div>
    <div class="close-modal">
      <div class="inner">
        <p>&#10005;</p>
      </div>
    </div>
  </div>
</section>
<section id="change_email" class="modal">
  <div class="inner-wrapper">
    <header>
      <h2><span id="change_email_title">Change Email</span></h2>
      <hr/>
    </header>
    <div id="change_email_body">
      <form id="change_email_form">
        <div id="change_email_error" class="modal-form-error"> </div>
          <div class="input-group">
            <label>Please enter your new email address:</label>
            <input id="new_email_field" type="email" value="" />
            <label>Please confirm your password:</label>
            <input id="new_email_password" value="" type="password" />
          </div>
            <p>We will send a confirmation to both ${user.email} and your new email as part of the process.</p>
          <div class="submit">
            <input type="submit" id="submit_email_change" value="Change Email"/>
          </div>
        </fieldset>
      </form>
    </div>
    <div class="close-modal">
      <div class="inner">
        <p>&#10005;</p>
      </div>
    </div>
  </div>
</section>

<section id="apply_name_change" class="modal">
  <div class="inner-wrapper">
    <header>
      <h2>Change your name</h2>
      <hr/>
    </header>
    <div id="change_name_body">
      <form id="change_name_form">
        <div id="change_name_error" class="modal-form-error"> </div>
        <p>To uphold the credibility of edX certificates, all name changes will be logged and recorded.</p>
        <br/>
        <fieldset>
          <div class="input-group">
            <label>Enter your desired full name, as it will appear on the edX certificates: </label>
            <input id="new_name_field" value="" type="text" />
            <label>Reason for name change:</label>
            <textarea id="name_rationale_field" value=""></textarea>
          </div>
          <div class="submit">
            <input type="submit" id="submit" value="Change My Name">
          </div>
        </fieldset>
      </form>
    </div>
    <div class="close-modal">
      <div class="inner">
        <p>&#10005;</p>
      </div>
    </div>
  </div>
</section>