From 3f681b8e91ac36d22764c0f5a619e2efe77dd15e Mon Sep 17 00:00:00 2001 From: Peter Grassberger Date: Tue, 29 Dec 2015 13:56:55 +0100 Subject: musicgrid: show grid diff --git a/www/index.html b/www/index.html index c082c43..c3ccc68 100644 --- a/www/index.html +++ b/www/index.html @@ -167,6 +167,7 @@ +

Musikpools

@@ -179,9 +180,76 @@

Musikgrid

-

- coming soon! -

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
00:0001:0002:0003:0004:0005:0006:0007:0008:0009:0010:0011:0016:0017:0018:0019:0020:0021:0022:0023:00
Montag
Dienstag
Mittwoch
Donnerstag
Freitag
Samstag
Sonntag
diff --git a/www/js/musicgrid.js b/www/js/musicgrid.js index c17b79e..695bca4 100644 --- a/www/js/musicgrid.js +++ b/www/js/musicgrid.js @@ -23,13 +23,61 @@ 'use strict'; var rivendell = null; +var musicgrid = null; function musicgrid_init() { rivendell = new Rivendell.Rivendell(auth_username, auth_token, '/rd-bin/rdxport.cgi'); rivendell.setMusicgridEndpoint('/rh-bin/musicgrid.cgi'); - rivendell.getMusicgrid(); + + musicgrid = new Musicgrid(); } function musicgrid_cleanup() { rivendell = null; } + +var Musicgrid = function() { + this.clocks = []; + + this.fetch(); +}; + +Musicgrid.prototype.fetch = function() { + var self = this; + rivendell.getMusicgrid(function(gridXml, status, req) { + var dbs = $(gridXml).find("grid").children(); + dbs.each(function(index, clockXml) { + var clock = new MusicgridClock( + $('name', clockXml).text(), + $('color', clockXml).text(), + $('title', clockXml).text(), + $(clockXml).attr('dow'), + $(clockXml).attr('hour') + ); + + self.clocks.push(clock); + }); + self.updateTable(); + }); +}; + +Musicgrid.prototype.updateTable = function() { + var $table = $('#app-musicgrid table'); + $(this.clocks).each(function(index, clock) { + var $td = $('tr[data-dow="' + clock.dow + '"] td[data-hour="' + clock.hour +'"]', $table); + var $div = $('
' + clock.name + '
' + clock.title + '
'); + $div.css('background-color', clock.color); + // todo: move this css to stylesheet + $div.css('text-align', 'center'); + $td.html($div); + }); +}; + +var MusicgridClock = function(name, color, title, dow, hour) { + this.name = name; + this.color = color; + this.title = title; + this.dow = dow; + this.hour = hour; +}; + -- cgit v0.10.2