218 lines
		
	
	
	
		
			8.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			218 lines
		
	
	
	
		
			8.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
{% extends "site_base.html" %}
 | 
						|
 | 
						|
{% load i18n %}
 | 
						|
{% load sitetree %}
 | 
						|
 | 
						|
{% block extra_style %}
 | 
						|
    <style type="text/css">
 | 
						|
        div.dataTables_length label {
 | 
						|
            float: left;
 | 
						|
            text-align: left;
 | 
						|
        }
 | 
						|
 | 
						|
        div.dataTables_length select {
 | 
						|
            width: 75px;
 | 
						|
        }
 | 
						|
 | 
						|
        div.dataTables_filter label {
 | 
						|
            float: right;
 | 
						|
        }
 | 
						|
 | 
						|
        div.dataTables_info {
 | 
						|
            padding-top: 8px;
 | 
						|
        }
 | 
						|
 | 
						|
        div.dataTables_paginate {
 | 
						|
            float: right;
 | 
						|
            margin: 0;
 | 
						|
        }
 | 
						|
 | 
						|
        table.table {
 | 
						|
            clear: both;
 | 
						|
            margin-bottom: 6px !important;
 | 
						|
            background-color: white;
 | 
						|
        }
 | 
						|
 | 
						|
        table.table thead .sorting,
 | 
						|
        table.table thead .sorting_asc,
 | 
						|
        table.table thead .sorting_desc,
 | 
						|
        table.table thead .sorting_asc_disabled,
 | 
						|
        table.table thead .sorting_desc_disabled {
 | 
						|
            cursor: pointer;
 | 
						|
            *cursor: hand;
 | 
						|
        }
 | 
						|
 | 
						|
        {% comment %}
 | 
						|
        table.table thead .sorting { background: url('{{ STATIC_URL }}datatables/images/sort_both.png') no-repeat center right; }
 | 
						|
        table.table thead .sorting_asc { background: url('{{ STATIC_URL }}datatables/images/sort_asc.png') no-repeat center right; }
 | 
						|
        table.table thead .sorting_desc { background: url('{{ STATIC_URL }}datatables/images/sort_desc.png') no-repeat center right; }
 | 
						|
 | 
						|
        table.table thead .sorting_asc_disabled { background: url('{{ STATIC_URL }}datatables/images/sort_asc_disabled.png') no-repeat center right; }
 | 
						|
        table.table thead .sorting_desc_disabled { background: url('{{ STATIC_URL }}datatables/images/sort_desc_disabled.png') no-repeat center right; }
 | 
						|
        {% endcomment %}
 | 
						|
 | 
						|
        table.dataTable th:active {
 | 
						|
            outline: none;
 | 
						|
        }
 | 
						|
    </style>
 | 
						|
{% endblock %}
 | 
						|
 | 
						|
{% block body_class %}reviews{% endblock %}
 | 
						|
 | 
						|
{% block body_base %}
 | 
						|
    <div class="container">
 | 
						|
        
 | 
						|
        {% include "_messages.html" %}
 | 
						|
        
 | 
						|
        {% block breadcrumbs %}
 | 
						|
            {% sitetree_breadcrumbs from "main" %}
 | 
						|
        {% endblock %}
 | 
						|
        
 | 
						|
        <div class="row">
 | 
						|
            <div class="span2">
 | 
						|
                {% block sidebar %}
 | 
						|
                    <ul class="nav nav-list well">
 | 
						|
                        {% for section in review_sections %}
 | 
						|
                            <li class="nav-header">
 | 
						|
                                {{ section }}
 | 
						|
                            </li>
 | 
						|
                            <li>
 | 
						|
                                <a href="{% url review_section section.section.slug %}">
 | 
						|
                                    {% trans "All Reviews" %}
 | 
						|
                                </a>
 | 
						|
                            </li>
 | 
						|
                            {% comment %}
 | 
						|
                            <li>
 | 
						|
                                <a href="{% url review_section_assignments section.section.slug %}">
 | 
						|
                                    {% trans "Your Assignments" %}
 | 
						|
                                </a>
 | 
						|
                            </li>
 | 
						|
                            {% endcomment %}
 | 
						|
                            <li>
 | 
						|
                                <a href="{% url review_status section.section.slug %}">
 | 
						|
                                    {% trans "Voting Status" %}
 | 
						|
                                </a>
 | 
						|
                            </li>
 | 
						|
                        {% endfor %}
 | 
						|
                    </ul>
 | 
						|
                {% endblock %}
 | 
						|
            </div>
 | 
						|
            <div class="span10">
 | 
						|
                {% block body %}
 | 
						|
                {% endblock %}
 | 
						|
            </div>
 | 
						|
        </div>
 | 
						|
    </div>
 | 
						|
{% endblock %}
 | 
						|
 | 
						|
{% block extra_script %}
 | 
						|
    <script src="{{ STATIC_URL }}datatables/js/jquery.dataTables.min.js" type="text/javascript"></script>
 | 
						|
    <script type="text/javascript">
 | 
						|
        $(function() {
 | 
						|
            /* Default class modification */
 | 
						|
            $.extend( $.fn.dataTableExt.oStdClasses, {
 | 
						|
                "sWrapper": "dataTables_wrapper form-inline"
 | 
						|
            } );
 | 
						|
 | 
						|
            /* API method to get paging information */
 | 
						|
            $.fn.dataTableExt.oApi.fnPagingInfo = function ( oSettings )
 | 
						|
            {
 | 
						|
                return {
 | 
						|
                    "iStart":         oSettings._iDisplayStart,
 | 
						|
                    "iEnd":           oSettings.fnDisplayEnd(),
 | 
						|
                    "iLength":        oSettings._iDisplayLength,
 | 
						|
                    "iTotal":         oSettings.fnRecordsTotal(),
 | 
						|
                    "iFilteredTotal": oSettings.fnRecordsDisplay(),
 | 
						|
                    "iPage":          Math.ceil( oSettings._iDisplayStart / oSettings._iDisplayLength ),
 | 
						|
                    "iTotalPages":    Math.ceil( oSettings.fnRecordsDisplay() / oSettings._iDisplayLength )
 | 
						|
                };
 | 
						|
            }
 | 
						|
 | 
						|
            /* Bootstrap style pagination control */
 | 
						|
            $.extend( $.fn.dataTableExt.oPagination, {
 | 
						|
                "bootstrap": {
 | 
						|
                    "fnInit": function( oSettings, nPaging, fnDraw ) {
 | 
						|
                        var oLang = oSettings.oLanguage.oPaginate;
 | 
						|
                        var fnClickHandler = function ( e ) {
 | 
						|
                            e.preventDefault();
 | 
						|
                            if ( oSettings.oApi._fnPageChange(oSettings, e.data.action) ) {
 | 
						|
                                fnDraw( oSettings );
 | 
						|
                            }
 | 
						|
                        };
 | 
						|
 | 
						|
                        $(nPaging).addClass('pagination').append(
 | 
						|
                            '<ul>'+
 | 
						|
                                '<li class="prev disabled"><a href="#">← '+oLang.sPrevious+'</a></li>'+
 | 
						|
                                '<li class="next disabled"><a href="#">'+oLang.sNext+' → </a></li>'+
 | 
						|
                            '</ul>'
 | 
						|
                        );
 | 
						|
                        var els = $('a', nPaging);
 | 
						|
                        $(els[0]).bind( 'click.DT', { action: "previous" }, fnClickHandler );
 | 
						|
                        $(els[1]).bind( 'click.DT', { action: "next" }, fnClickHandler );
 | 
						|
                    },
 | 
						|
 | 
						|
                    "fnUpdate": function ( oSettings, fnDraw ) {
 | 
						|
                        var iListLength = 5;
 | 
						|
                        var oPaging = oSettings.oInstance.fnPagingInfo();
 | 
						|
                        var an = oSettings.aanFeatures.p;
 | 
						|
                        var i, j, sClass, iStart, iEnd, iHalf=Math.floor(iListLength/2);
 | 
						|
 | 
						|
                        if ( oPaging.iTotalPages < iListLength) {
 | 
						|
                            iStart = 1;
 | 
						|
                            iEnd = oPaging.iTotalPages;
 | 
						|
                        }
 | 
						|
                        else if ( oPaging.iPage <= iHalf ) {
 | 
						|
                            iStart = 1;
 | 
						|
                            iEnd = iListLength;
 | 
						|
                        } else if ( oPaging.iPage >= (oPaging.iTotalPages-iHalf) ) {
 | 
						|
                            iStart = oPaging.iTotalPages - iListLength + 1;
 | 
						|
                            iEnd = oPaging.iTotalPages;
 | 
						|
                        } else {
 | 
						|
                            iStart = oPaging.iPage - iHalf + 1;
 | 
						|
                            iEnd = iStart + iListLength - 1;
 | 
						|
                        }
 | 
						|
 | 
						|
                        for ( i=0, iLen=an.length ; i<iLen ; i++ ) {
 | 
						|
                            // Remove the middle elements
 | 
						|
                            $('li:gt(0)', an[i]).filter(':not(:last)').remove();
 | 
						|
 | 
						|
                            // Add the new list items and their event handlers
 | 
						|
                            for ( j=iStart ; j<=iEnd ; j++ ) {
 | 
						|
                                sClass = (j==oPaging.iPage+1) ? 'class="active"' : '';
 | 
						|
                                $('<li '+sClass+'><a href="#">'+j+'</a></li>')
 | 
						|
                                    .insertBefore( $('li:last', an[i])[0] )
 | 
						|
                                    .bind('click', function (e) {
 | 
						|
                                        e.preventDefault();
 | 
						|
                                        oSettings._iDisplayStart = (parseInt($('a', this).text(),10)-1) * oPaging.iLength;
 | 
						|
                                        fnDraw( oSettings );
 | 
						|
                                    } );
 | 
						|
                            }
 | 
						|
 | 
						|
                            // Add / remove disabled classes from the static elements
 | 
						|
                            if ( oPaging.iPage === 0 ) {
 | 
						|
                                $('li:first', an[i]).addClass('disabled');
 | 
						|
                            } else {
 | 
						|
                                $('li:first', an[i]).removeClass('disabled');
 | 
						|
                            }
 | 
						|
 | 
						|
                            if ( oPaging.iPage === oPaging.iTotalPages-1 || oPaging.iTotalPages === 0 ) {
 | 
						|
                                $('li:last', an[i]).addClass('disabled');
 | 
						|
                            } else {
 | 
						|
                                $('li:last', an[i]).removeClass('disabled');
 | 
						|
                            }
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            } );
 | 
						|
            
 | 
						|
            $("table.table-reviews").dataTable({
 | 
						|
                "sDom": "<'row'<'span5'l><'span5'f>r>t<'row'<'span5'i><'span5'p>>",
 | 
						|
                "sPaginationType": "bootstrap",
 | 
						|
                "bStateSave": true
 | 
						|
            });
 | 
						|
            $.extend($.fn.dataTableExt.oStdClasses, {
 | 
						|
                "sWrapper": "dataTables_wrapper form-inline"
 | 
						|
            });
 | 
						|
        });
 | 
						|
    </script>
 | 
						|
{% endblock %}
 |