staticbook.html 3.6 KB
Newer Older
1 2
<%! from django.utils.translation import ugettext as _ %>

Piotr Mitros committed
3
<%inherit file="main.html" />
4
<%namespace name='static' file='static_content.html'/>
Chris Dodge committed
5
<%block name="title"><title>${_("{course_number} Textbook").format(course_number=course.display_number_with_default) | h}</title></%block>
6

7 8
<%block name="headextra">
<%static:css group='course'/>
Matthew Mongeau committed
9
<%static:js group='courseware'/>
10 11
</%block>

12
<%block name="js_extra">
Kyle Fiedler committed
13
  <script type="text/javascript" src="${static.url('js/jquery.treeview.js')}"></script>
Piotr Mitros committed
14 15 16 17
<script>
var page=${ page };

$(document).ready(function(){
18 19 20 21 22 23
   if(!page) {
     cookie_page = $.cookie("book_page");
     if(cookie_page) {
       goto_page(cookie_page);
     }
   }
Piotr Mitros committed
24 25 26 27
   $("#booknav").treeview({collapsed:true, unique:true/*, cookieId: "treeview-book-nav", persist: "cookie"*/});
});

function goto_page(n) {
28
  Logger.log("book", {"type":"gotopage","old":page,"new":n});
Piotr Mitros committed
29
  page=n;
Piotr Mitros committed
30 31 32 33 34 35 36
  var prefix = "";
  if(n<100) {
    prefix="0";
  }
  if(n<10) {
    prefix="00";
  }
37
  $("#bookpage").attr("src","${ book_url }p"+prefix+n+".png");
38
  $.cookie("book_page", n, {'expires':3650, 'path':'/'});
Piotr Mitros committed
39 40 41
};

function prev_page() {
Piotr Mitros committed
42
  var newpage=page-1;
43
  if(newpage< ${start_page}) newpage=${start_page};
Piotr Mitros committed
44
  goto_page(newpage);
45
  Logger.log("book", {"type":"prevpage","new":page});
Piotr Mitros committed
46 47 48
}

function next_page() {
Piotr Mitros committed
49
  var newpage=page+1;
50
  if(newpage> ${end_page}) newpage=${end_page};
Piotr Mitros committed
51
  goto_page(newpage);
52
  Logger.log("book", {"type":"nextpage","new":page});
Piotr Mitros committed
53
}
54 55 56 57 58 59 60 61 62

$("#open_close_accordion a").click(function(){
  if ($(".book-wrapper").hasClass("closed")){
    $(".book-wrapper").removeClass("closed");
  } else {
    $(".book-wrapper").addClass("closed");
  }
});

Piotr Mitros committed
63
</script>
64
</%block>
65

Victor Shnayder committed
66
<%include file="/courseware/course_navigation.html" args="active_page='textbook/{0}'.format(book_index)" />
67

68
<section class="container">
69 70
  <div class="book-wrapper">

71
    <section aria-label="${_('Textbook Navigation')}" class="book-sidebar">
72 73 74 75 76
      <header id="open_close_accordion">
        <a href="#">close</a>
      </header>

      <ul id="booknav" class="treeview-booknav">
77 78 79
          <%def name="print_entry(entry)">
              <li>
                  <a href="javascript:goto_page(${entry.get('page')})">
80 81 82 83 84 85 86 87
                      <span class="chapter">
                        %if entry.get('chapter'):
                          <span class="chapter-number">${entry.get('chapter')}.</span> ${entry.get('name')}
                        %else:
                          ${entry.get('name')}
                        %endif
                      </span>
                      <span class="page-number">${entry.get('page_label')}</span>
88 89 90 91 92 93 94 95 96 97 98 99 100 101
                  </a>
                  % if len(entry) > 0:
                      <ul>
                          % for child in entry:
                              ${print_entry(child)}
                          % endfor
                      </ul>
                  % endif
              </li>
          </%def>

          % for entry in table_of_contents:
            ${print_entry(entry)}
          % endfor
102

103 104
        ## Don't delete this empty list item. Without it, Jquery.TreeView won't
        ## render the last list item as expandable.
105
        <li></li>
106 107
      </ul>
    </section>
108

109
    <section class="book">
110 111 112 113
      <section class="page">
        <nav>
          <ul>
            <li class="last">
114
              <a href="javascript:prev_page()">${_('Previous page')}</a>
115 116
            </li>
            <li class="next">
117
              <a href="javascript:next_page()">${_('Next page')}</a>
118 119 120 121
            </li>
          </ul>
        </nav>

122
        <img id="bookpage" src="${ book_url }p${ "%03i"%(page) }.png">
123
      </section>
124
    </section>
125
  </div>
126
</section>