dashboard.html 9.89 KB
Newer Older
1 2
<%inherit file="main.html" />
<%namespace name='static' file='static_content.html'/>
3
<%!
4 5 6 7 8 9
from django.utils.translation import ugettext as _
from django.template import RequestContext
import third_party_auth
from third_party_auth import pipeline
from microsite_configuration import microsite
from django.core.urlresolvers import reverse
10
import json
11
%>
12 13 14 15 16 17

<%
  cert_name_short = settings.CERT_NAME_SHORT
  cert_name_long = settings.CERT_NAME_LONG
%>

Matthew Mongeau committed
18

19
<%block name="pagetitle">${_("Dashboard")}</%block>
20
<%block name="bodyclass">view-dashboard is-authenticated</%block>
21
<%block name="nav_skip">#my-courses</%block>
22

Will Daly committed
23 24 25 26 27 28
<%block name="header_extras">
% for template_name in ["donation"]:
<script type="text/template" id="${template_name}-tpl">
  <%static:include path="dashboard/${template_name}.underscore" />
</script>
% endfor
29 30 31 32 33 34

% for template_name in ["dashboard_search_item", "dashboard_search_results", "search_loading", "search_error"]:
<script type="text/template" id="${template_name}-tpl">
    <%static:include path="search/${template_name}.underscore" />
</script>
% endfor
Will Daly committed
35 36
</%block>

37
<%block name="js_extra">
38
  <script src="${static.url('js/commerce/credit.js')}"></script>
Will Daly committed
39
  <%static:js group='dashboard'/>
40
  <script type="text/javascript">
41 42 43 44
    $(document).ready(function() {
      edx.dashboard.legacy.init({
        dashboard: "${reverse('dashboard')}",
        signInUser: "${reverse('signin_user')}",
45
        changeEmailSettings: "${reverse('change_email_settings')}"
46
      });
47
    });
48
  </script>
49
  % if settings.FEATURES.get('ENABLE_DASHBOARD_SEARCH'):
cahrens committed
50 51 52
    <%static:require_module module_name="js/search/dashboard/dashboard_search_factory" class_name="DashboardSearchFactory">
        DashboardSearchFactory();
    </%static:require_module>
53
  % endif
54 55 56 57 58 59 60
  % if redirect_message:
    <%static:require_module module_name="js/views/message_banner" class_name="MessageBannerView">
        var banner = new MessageBannerView({urgency: 'low', type: 'warning'});
        $('#content').prepend(banner.$el);
        banner.showMessage(${json.dumps(redirect_message)})
    </%static:require_module>
  % endif
61 62
</%block>

63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
<div class="dashboard-notifications" tabindex="-1">
    %if message:
        <section class="dashboard-banner">
            ${message}
        </section>
    %endif

    %if enrollment_message:
        <section class="dashboard-banner">
            ${enrollment_message}
        </section>
    %endif
</div>

<section class="container dashboard" id="dashboard-main">
78
  <section class="my-courses" id="my-courses" role="main" aria-label="Content">
79
    <header class="wrapper-header-courses">
80
      <h2 class="header-courses">${_("My Courses")}</h2>
81
    </header>
82 83


84
    % if len(course_enrollments) > 0:
85
      <ul class="listing-courses">
86
      <% share_settings = getattr(settings, 'SOCIAL_SHARING_SETTINGS', {}) %>
87 88 89
      % for dashboard_index, enrollment in enumerate(course_enrollments):
        <% show_courseware_link = (enrollment.course_id in show_courseware_links_for) %>
        <% cert_status = cert_statuses.get(enrollment.course_id) %>
90
        <% can_unenroll = (not cert_status) or cert_status.get('can_unenroll') %>
91 92 93 94 95 96 97 98
        <% credit_status = credit_statuses.get(enrollment.course_id) %>
        <% show_email_settings = (enrollment.course_id in show_email_settings_for) %>
        <% course_mode_info = all_course_modes.get(enrollment.course_id) %>
        <% show_refund_option = (enrollment.course_id in show_refund_option_for) %>
        <% is_paid_course = (enrollment.course_id in enrolled_courses_either_paid) %>
        <% is_course_blocked = (enrollment.course_id in block_courses) %>
        <% course_verification_status = verification_status_by_course.get(enrollment.course_id, {}) %>
        <% course_requirements = courses_requirements_not_met.get(enrollment.course_id) %>
99
        <% course_program_info = course_programs.get(unicode(enrollment.course_id)) %>
100
        <%include file = 'dashboard/_dashboard_course_listing.html' args="course_overview=enrollment.course_overview, enrollment=enrollment, show_courseware_link=show_courseware_link, cert_status=cert_status, can_unenroll=can_unenroll, credit_status=credit_status, show_email_settings=show_email_settings, course_mode_info=course_mode_info, show_refund_option=show_refund_option, is_paid_course=is_paid_course, is_course_blocked=is_course_blocked, verification_status=course_verification_status, course_requirements=course_requirements, dashboard_index=dashboard_index, share_settings=share_settings, user=user, course_program_info=course_program_info" />
101
      % endfor
102

103 104 105
      </ul>
    % else:
      <section class="empty-dashboard-message">
106 107
        <p>${_("Looks like you haven't enrolled in any courses yet.")}</p>

108 109 110 111 112 113 114 115 116 117 118
        % if settings.FEATURES.get('COURSES_ARE_BROWSABLE'):
          <a href="${marketing_link('COURSES')}">
            ${_("Find courses now!")}
          </a>
        %endif
      </section>
    % endif

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

120 121 122 123 124 125 126 127 128 129
      % 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
130
      </div>
131 132
    % endif
  </section>
133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154

  % if settings.FEATURES.get('ENABLE_DASHBOARD_SEARCH'):
    <div id="dashboard-search-bar" class="search-bar dashboard-search-bar" role="search" aria-label="Dashboard">
      <form>
        <label for="dashboard-search-input">${_('Search Your Courses')}</label>
        <div class="search-field-wrapper">
          <input id="dashboard-search-input" type="text" class="search-field"/>
          <button type="submit" class="search-button" aria-label="${_('Search')}">
            <i class="icon fa fa-search" aria-hidden="true"></i>
          </button>
          <button type="button" class="cancel-button" aria-label="${_('Clear search')}">
            <i class="icon fa fa-remove" aria-hidden="true"></i>
          </button>
        </div>
      </form>
    </div>
  % endif

  % if settings.FEATURES.get('ENABLE_DASHBOARD_SEARCH'):
    <section id="dashboard-search-results" class="search-results dashboard-search-results"></section>
  % endif

155
  % if settings.FEATURES.get('IS_EDX_DOMAIN') and settings.FEATURES.get('COURSES_ARE_BROWSABLE'):
156
    <div class="wrapper-find-courses">
157
      <p class="copy">${_("Check out our recently launched courses and what's new in your favorite subjects")}</p>
158 159 160 161 162
      <p><a class="btn-find-courses" href="${marketing_link('COURSES')}">${_("Find New Courses")}</a></p>
    </div>
  % endif

  <section class="profile-sidebar" id="profile-sidebar" role="region" aria-label="Account Status Info">
163
    <header class="profile">
164
      <h2 class="account-status-title sr">${_("Account Status Info")}: </h2>
165
    </header>
166 167
    <section class="user-info">
      <ul>
168

169 170 171 172 173 174 175 176 177
        % if len(order_history_list):
        <li class="order-history">
          <span class="title">${_("Order History")}</span>
          % for order_history_item in order_history_list:
            <span><a href="${order_history_item['receipt_url']}" target="_blank" class="edit-name">${order_history_item['order_date']}</a></span>
          % endfor
        </li>
        % endif

178
        <%include file='dashboard/_dashboard_status_verification.html' />
179

180 181
      </ul>
    </section>
Matthew Mongeau committed
182 183
  </section>
</section>
184

185
<section id="email-settings-modal" class="modal" aria-hidden="true">
186
  <div class="inner-wrapper" role="dialog" aria-labelledby="email-settings-title">
187
    <button class="close-modal">
188
      <i class="icon fa fa-remove"></i>
189 190
      <span class="sr">
        ## Translators: this is a control to allow users to exit out of this modal interface (a menu or piece of UI that takes the full focus of the screen)
191
        ${_("Close")}
192 193
      </span>
    </button>
194

195
    <header>
196
      <h2 id="email-settings-title">
197
        ${_("Email Settings for {course_number}").format(course_number='<span id="email_settings_course_number"></span>')}
198 199
        <span class="sr">,
          ## Translators: this text gives status on if the modal interface (a menu or piece of UI that takes the full focus of the screen) is open or not
200
          ${_("window open")}
201 202
        </span>
      </h2>
203 204 205 206 207
      <hr/>
    </header>

    <form id="email_settings_form" method="post">
      <input name="course_id" id="email_settings_course_id" type="hidden" />
208
      <label>${_("Receive course emails")} <input type="checkbox" id="receive_emails" name="receive_emails" /></label>
209
      <div class="submit">
210
        <input type="submit" id="submit" value="${_("Save Settings")}" />
211 212 213 214 215
      </div>
    </form>
  </div>
</section>

216
<section id="unenroll-modal" class="modal unenroll-modal" aria-hidden="true">
David Baumgold committed
217
  <div class="inner-wrapper" role="dialog" aria-labelledby="unenrollment-modal-title">
218
    <button class="close-modal">
219
      <i class="icon fa fa-remove"></i>
220 221
      <span class="sr">
        ## Translators: this is a control to allow users to exit out of this modal interface (a menu or piece of UI that takes the full focus of the screen)
222
        ${_("Close")}
223 224 225
      </span>
    </button>

226
    <header>
227
      <h2 id="unenrollment-modal-title">
228 229
        <span id='track-info'></span>
        <span id='refund-info'></span>
230 231
        <span class="sr">,
          ## Translators: this text gives status on if the modal interface (a menu or piece of UI that takes the full focus of the screen) is open or not
232
          ${_("window open")}
233 234
        </span>
      </h2>
235 236 237 238 239 240 241
      <hr/>
    </header>
    <div id="unenroll_error" class="modal-form-error"></div>
    <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">
242
        <input name="submit" type="submit" value="${_("Unenroll")}" />
243 244 245
      </div>
    </form>
  </div>
246
</section>