Archive.html is feature-complete

It just needs some love in table style and alignments
This commit is contained in:
boyska 2014-04-23 12:41:12 +02:00
parent 1d5355c771
commit cfa08ddb72
4 changed files with 49 additions and 7 deletions

View file

@ -15,14 +15,49 @@
<script src="/static/js/jquery.ui.datepicker-it.min.js"></script> <script src="/static/js/jquery.ui.datepicker-it.min.js"></script>
<script src="/static/js/rec.js"></script> <script src="/static/js/rec.js"></script>
<script> <script>
function delta(end, start) {
//end, start are unix timestamps
diff = parseInt(end, 10) - parseInt(start, 10); //diff is in seconds
msec = diff*1000;
var hh = Math.floor(msec / 1000 / 60 / 60);
msec -= hh * 1000 * 60 * 60;
var mm = Math.floor(msec / 1000 / 60);
msec -= mm * 1000 * 60;
var ss = Math.floor(msec / 1000);
msec -= ss * 1000;
if(hh === 0) {
if(mm === 0) {
return ss + 's';
}
return mm + 'min ' + ss + 's';
}
return hh + 'h ' + mm + 'm ' + ss + 's';
}
$(function() { $(function() {
"use strict"; "use strict";
RecAPI.get_archive().success(function(archive) { RecAPI.get_archive().success(function(archive) {
$.each(archive, function(idx, rec) { /* To get sorted traversal, we need to do an array containing keys */
$('#ongoing-recs-table tbody') var keys = [];
.append($('<tr/>').append($('<td/>') for(var prop in archive) {
.append($('<a/>').prop('href', '/output/' + rec.filename).text(rec.filename)))); keys.push(prop);
}); }
keys.sort(function(a,b) { return b - a; }); //descending
/* ok, now we can traverse the objects */
for(var i =0; i < keys.length; i++) {
var rec = archive[keys[i]];
console.log(rec);
var name = $('<td/>').text(rec.name);
var start = $('<td/>').text(config.date_read(
parseInt(rec.starttime, 10)).toLocaleString()
);
var duration = $('<td/>').text(delta(rec.endtime, rec.starttime));
var fn = $('<td/>').append($('<a/>').prop('href', '/output/' +
rec.filename).text(rec.filename));
var row = $('<tr/>').append(name).append(start).append(duration).append(fn);
$('#ongoing-recs-table tbody').append(row);
}
}); });
}); });
</script> </script>
@ -47,6 +82,9 @@ $(function() {
id="ongoing-recs-table" style="margin-top: 3em;"> id="ongoing-recs-table" style="margin-top: 3em;">
<tbody> <tbody>
<tr> <tr>
<th>Nome</th>
<th>Inizio</th>
<th>Durata</th>
<th>Filename</th> <th>Filename</th>
</tr> </tr>
</tbody> </tbody>

View file

@ -102,10 +102,10 @@ $.widget("ror.ongoingrec", {
var rec = this.options.rec; var rec = this.options.rec;
this.element.find('input').val(rec.name); this.element.find('input').val(rec.name);
this.element.find(':ror-countclock').countclock("option", "since", this.element.find(':ror-countclock').countclock("option", "since",
rec.starttime !== null ? new Date(rec.starttime*1000) : null); rec.starttime !== null ? config.date_read(rec.starttime) : null);
if(this.options.state > 0) { if(this.options.state > 0) {
this.element.find(':ror-countclock').countclock("option", "to", this.element.find(':ror-countclock').countclock("option", "to",
rec.endtime !== null ? new Date(rec.endtime*1000) : null rec.endtime !== null ? config.date_read(rec.endtime) : null
); );
} else { } else {
this.element.find(':ror-countclock').countclock("option", "to", null); this.element.find(':ror-countclock').countclock("option", "to", null);

View file

@ -4,6 +4,9 @@ var config = {
date_write: function(d) { date_write: function(d) {
return Math.floor(d.getTime() / 1000); return Math.floor(d.getTime() / 1000);
}, },
date_read: function(unix_timestamp) {
return new Date(unix_timestamp * 1000);
},
datetimeformat: function(d) { datetimeformat: function(d) {
if(Math.abs(new Date() - d) > (3*60*60*1000)) { if(Math.abs(new Date() - d) > (3*60*60*1000)) {
return d.toLocaleString(); return d.toLocaleString();

View file

@ -145,6 +145,7 @@ class RecDB:
def get_archive_recent(self): def get_archive_recent(self):
query = self._query_saved() query = self._query_saved()
query = self._query_newer(timedelta(days=15), query) query = self._query_newer(timedelta(days=15), query)
query = query.order_by(Rec.starttime.desc())
return query.all() return query.all()
def _query_ongoing(self, query=None): def _query_ongoing(self, query=None):