112 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| {% extends 'layout.html' %}
 | |
| {% block body %}
 | |
| 
 | |
|   <h2>History for <strong>{{ name }}</strong></h2>
 | |
|   <p>
 | |
|     <a class="btn btn-default btn-sm compare-revisions">Compare Revisions</a>
 | |
|   </p>
 | |
| 
 | |
|   <table class="table table-bordered revision-tbl dataTable DTTT_selectable">
 | |
|     <thead>
 | |
|     <tr>
 | |
|       <th>Name</th>
 | |
|       <th>Revision Message</th>
 | |
|       <th>Date</th>
 | |
|     </tr>
 | |
|     </thead>
 | |
|   </table>
 | |
|   <p>
 | |
|     <a class="btn btn-default btn-sm compare-revisions">Compare Revisions</a>
 | |
|   </p>
 | |
| 
 | |
| {% endblock %}
 | |
| 
 | |
| {% block css %}
 | |
|   <style type="text/css">
 | |
|     table.dataTable td {
 | |
|       transition: background-color 0.5s linear, color 0.5s linear;
 | |
|       transition-delay: 0.1s;
 | |
|     }
 | |
|     table.dataTable tr.active td {
 | |
|       transition: background-color 0.1s linear, color 0.1s linear;
 | |
|       transition-delay: 0s
 | |
|     }
 | |
|     table.dataTable tbody tr:hover {
 | |
|       background-color: #d8d8d8 !important;
 | |
|     }
 | |
|   </style>
 | |
| {% endblock %}
 | |
| 
 | |
| {% block js %}
 | |
|   <script>
 | |
|     $(document).ready(function() {
 | |
|       var selected = [];
 | |
|       var selected_pos = [];
 | |
| 
 | |
|       $('.dataTable').dataTable({
 | |
|         serverSide: true,
 | |
|         ajax: {
 | |
|           url: '{{ url_for('.history_data', name=name) }}',
 | |
|           dataSrc: function (data) {
 | |
|             $('.dataTable').data('fully_loaded', data.fully_loaded);
 | |
|             return data.data
 | |
|           }
 | |
|         },
 | |
|         ordering: false,
 | |
|         bFilter: false,
 | |
|         columns: [
 | |
|           { "data": "author" },
 | |
|           { "data": "message" },
 | |
|           { "data": "time",
 | |
|             "render": function (data) {
 | |
|               var date = new Date(data * 1000);
 | |
|               return date.toDateString();
 | |
|             }
 | |
|           }
 | |
|         ],
 | |
|         rowCallback: function( row, data, index ) {
 | |
|             index += $('.dataTable').DataTable().page.info().start;
 | |
|             $(row).data('index', index);
 | |
|             if ( $.inArray(data.DT_RowId, selected) !== -1 ) {
 | |
|                 $(row).addClass('active');
 | |
|             }
 | |
|         },
 | |
|         infoCallback: function( settings, start, end, max, total, pre ) {
 | |
|           if (!$('.dataTable').data('fully_loaded')) {
 | |
|             total += "+"
 | |
|           }
 | |
|           return "Showing " + start +" to "+ end + " of " + total + " revisions.";
 | |
|         }
 | |
|       });
 | |
| 
 | |
|       $('.dataTable tbody').on('click', 'tr', function () {
 | |
|         var id = this.id;
 | |
|         var selected_index = $.inArray(id, selected);
 | |
| 
 | |
|         if ( selected_index === -1 ) {
 | |
|             selected.push( id );
 | |
|             selected_pos.push( $(this).data('index') );
 | |
|             if ( selected.length > 2) {
 | |
|                 // Only 2 selected at once
 | |
|                 var shifted = selected.shift();
 | |
|                 selected_pos.shift();
 | |
|                 $('#' + shifted).removeClass('active');
 | |
|             }
 | |
|         } else {
 | |
|             selected.splice( selected_index, 1 );
 | |
|             selected_pos.splice( selected_index, 1);
 | |
|         }
 | |
| 
 | |
|         $(this).toggleClass('active');
 | |
|       });
 | |
|       $(".compare-revisions").click(function(){
 | |
|         if (selected.length != 2) return;
 | |
|         if (selected_pos[1] > selected_pos[0]) {
 | |
|           selected.reverse()
 | |
|         }
 | |
|         revs = selected.join("..");
 | |
|         location.href = "{{ config.RELATIVE_PATH }}/_compare/{{ name }}/" + revs;
 | |
|       });
 | |
|     });
 | |
|   </script>
 | |
| {% endblock %}
 |