add tabletools
This commit is contained in:
		
							parent
							
								
									17e9016981
								
							
						
					
					
						commit
						53923c5a7a
					
				
					 1 changed files with 13 additions and 102 deletions
				
			
		|  | @ -107,111 +107,22 @@ | |||
| 
 | ||||
| {% block extra_script %} | ||||
|     <script src="{{ STATIC_URL }}datatables/js/jquery.dataTables.min.js" type="text/javascript"></script> | ||||
|     <script src="{{ STATIC_URL }}tabletools/js/TableTools.min.js" type="text/javascript"></script> | ||||
|     <script src="{{ STATIC_URL }}datatables/js/dataTables.bootstrap.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'); | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } ); | ||||
|              | ||||
|         $(function() {             | ||||
|             $("table.table-reviews").dataTable({ | ||||
|                 "sDom": "<'row'<'span5'l><'span5'f>r>t<'row'<'span5'i><'span5'p>>", | ||||
|                 "sDom": "<'row'<'span3'l><'span3'T><'span4'f>r>t<'row'<'span3'i><'span5'p>>", | ||||
|                 "sPaginationType": "bootstrap", | ||||
|                 "bStateSave": true | ||||
|             }); | ||||
|             $.extend($.fn.dataTableExt.oStdClasses, { | ||||
|                 "sWrapper": "dataTables_wrapper form-inline" | ||||
|                 "bStateSave": true, | ||||
|                 "oTableTools": { | ||||
|                     "aButtons": [ | ||||
|                         "copy", | ||||
|                         "csv", | ||||
|                         "print" | ||||
|                     ], | ||||
|                     "sSwfPath": "{{ STATIC_URL }}tabletools/swf/copy_csv_xls.swf" | ||||
|                 } | ||||
|             }); | ||||
|         }); | ||||
|     </script> | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Luke Hatcher
						Luke Hatcher