js/playscreen.js
author veltr
Fri, 08 Mar 2013 19:05:17 +0100
changeset 6 14dd1980b0b9
parent 5 490e4d1b6fee
child 7 a2d5b669f663
permissions -rw-r--r--
MMSO Caching
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
     1
var topicPoubelle = 13;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
     2
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
     3
var adjust = 54;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
     4
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
     5
var deltaT = new Date("Wed, 02 May 2012 19:00:00 +0000") / 1000 + adjust;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
     6
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
     7
function solrUrl(table, params) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
     8
    return "http://159.217.144.101:8050/sia-solr/" + table + "/select?" + $.param(params) + "&wt=json&json.wrf=?";
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
     9
}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    10
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    11
function showData() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    12
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    13
    var topicHash = document.location.hash || "#topics=5,15";
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    14
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    15
    var ordertag = 0;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    16
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    17
    function secsToString(seconds) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    18
        var hours = Math.floor(seconds/3600),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    19
            minutes = Math.floor(seconds/60) % 60,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    20
            secs = Math.floor(seconds % 60);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    21
        function pad(n) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    22
            var r = n.toString();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    23
            while (r.length < 2) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    24
                r = "0" + r;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    25
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    26
            return r;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    27
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    28
        return (hours ? (hours + ":") : "") + pad(minutes) + ":" + pad(secs);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    29
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    30
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    31
    $(".duration").text(secsToString(data.duration));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    32
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    33
    var nmmso = data.segments.length;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    34
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    35
    data.topics.forEach(function(topic) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    36
        topic.score = 0;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    37
        topic.weights = [];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    38
        for (var i = 0; i < nmmso; i++) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    39
            topic.weights.push(0);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    40
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    41
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    42
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    43
    data.segments.forEach(function(mmso, i) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    44
        mmso.topics.forEach(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    45
            data.topics[t.topic].weights[i] = t.weight;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    46
            data.topics[t.topic].score += t.weight;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    47
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    48
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    49
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    50
    var sortedTopics = data.topics.filter(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    51
        return t.index !== topicPoubelle;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    52
    }).sort(function(a,b) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    53
        return b.score - a.score;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    54
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    55
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    56
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    57
    function showTopics(topiclist) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    58
        var tbhtml = topiclist.reduce(function(mem, topic) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    59
            var wordsToShow = topic.words.slice(0,3),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    60
                max = wordsToShow[0].weight,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    61
                min = Math.min(wordsToShow[wordsToShow.length - 1].weight, max - .01),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    62
                scale = 8 / (max - min);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    63
            var li = '<li class="shadow-block topic" data-topic-id="'
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    64
                + topic.index
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    65
                + '" data-timestamp="999999"><ul class="topic-words">'
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    66
                + wordsToShow.reduce(function(memwords, word) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    67
                    return memwords
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    68
                        + '<li style="font-size: '
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    69
                        + ( 8 + scale * (word.weight - min) )
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    70
                        + 'px;">'
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    71
                        + word.word
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    72
                        + '</li>';
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    73
                },"")
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    74
                + '</ul></li>';
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    75
            return mem + li;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    76
        },'');
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    77
        var tb = $(".topics-block");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    78
        tb.html(tbhtml);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    79
        tb.css("top",0);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    80
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    81
        showTopicViz();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    82
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    83
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    84
    var tweetLines = [];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    85
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    86
    function showTopicViz() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    87
        var selectedBlocks = $(".topic.selected, .topic.hover"),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    88
            sbl = selectedBlocks.length,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    89
            topicBlocks = $(".topic");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    90
        if (!sbl && topicBlocks.length < sortedTopics.length) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    91
            selectedBlocks = topicBlocks;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    92
            sbl = selectedBlocks.length;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    93
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    94
        var topicsAndColors = [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    95
        	colors = {};
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    96
        selectedBlocks.each(function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    97
            var el = $(this),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    98
                topicid = parseInt(el.attr("data-topic-id"));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    99
            topicsAndColors.push({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   100
                "$": el,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   101
                timestamp: parseInt(el.attr("data-timestamp")),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   102
                hovered: el.hasClass("hover"),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   103
                id: topicid,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   104
                topic: data.topics[topicid]
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   105
            });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   106
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   107
        topicsAndColors.sort(function(a,b) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   108
           return ( a.timestamp - b.timestamp ) || ( a.id - b.id );
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   109
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   110
        topicBlocks.css("background","");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   111
        topicsAndColors.forEach(function(topic, i) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   112
            topic.color = topic.hovered ? "#ffff00" : colorset[i % colorset.length];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   113
            colors[topic.id] = topic.color;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   114
            topic.$.css("background", topic.color);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   115
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   116
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   117
        for (var i = 0; i < nmmso; i++) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   118
            var opacity = 0,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   119
                rgb = [0,0,0];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   120
            topicsAndColors.forEach(function(topic) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   121
                var c = Raphael.getRGB(topic.color),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   122
                    o = topic.topic.weights[i];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   123
                rgb[0] += c.r * o;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   124
                rgb[1] += c.g * o;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   125
                rgb[2] += c.b * o;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   126
                opacity += o;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   127
            });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   128
            if (opacity) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   129
                color = Raphael.rgb.apply(Raphael, rgb.map(function(c) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   130
                    return c/opacity;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   131
                }));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   132
                var attr = {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   133
                    fill: color,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   134
                    opacity: .5 + .5 * opacity
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   135
                };
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   136
                segmentrects[i].show();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   137
                segmentrects[i].attr(attr);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   138
                if (i >= localMmsoDelta && i < localMmsoDelta + localMmsos.length) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   139
                	localMmsos[i - localMmsoDelta].show();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   140
                	localMmsos[i - localMmsoDelta].attr(attr);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   141
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   142
            } else {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   143
                segmentrects[i].hide();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   144
                if (i >= localMmsoDelta && i < localMmsoDelta + localMmsos.length) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   145
                	localMmsos[i - localMmsoDelta].hide();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   146
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   147
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   148
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   149
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   150
        tweetLines.forEach(function(tl) { tl.remove(); });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   151
        tweetLines = [];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   152
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   153
        var deltaY = $(".play-dataviz").offset().top;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   154
        
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   155
        $(".play-localtweets .tweet:visible").each(function() {
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   156
        	var el = $(this),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   157
        		liY = + el.offset().top + el.outerHeight() / 2 - deltaY,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   158
        		tY = localyscale * (+el.attr("data-timestamp") - localpos + localduration / 2),
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   159
        		p = "M" + localL + "," + tY + "L" + localR + "," + tY + "L400," + liY,
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   160
        		path = paper.path(p);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   161
    		$(this).css("background",colors[el.attr("data-topic-id")] || "");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   162
    		path.attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   163
    			stroke: "#ccc"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   164
    		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   165
    		tweetLines.push(path);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   166
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   167
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   168
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   169
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   170
    var jqsvg = $(".play-svg"),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   171
        paper = new Raphael(jqsvg[0]),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   172
        totalR = jqsvg.width(),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   173
        ph = jqsvg.height(),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   174
        globW = 85,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   175
        globL = 40,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   176
        localL = 155,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   177
        localW = 85,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   178
        localR = (localL + localW),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   179
        localTimeR = (localL + localW) + globL,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   180
        globR = (globW + globL),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   181
        yscale = ph / data.duration,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   182
        mx = Math.max.apply(Math, data.minutes.map(function(s) { return s.count})),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   183
        xscale = globW/mx;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   184
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   185
    var segmentrects = data.segments.map(function(mmso) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   186
        var rect = paper.rect(globL, yscale * mmso.start, globW, yscale * mmso.duration);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   187
        rect.attr({stroke: "none"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   188
        return rect;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   189
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   190
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   191
    var d = "M" + data.minutes.map(function(s) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   192
            var x = globL + xscale * s.count;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   193
            return x
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   194
                + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   195
                + yscale * (s.from + 20)
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   196
                + "L"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   197
                + x
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   198
                + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   199
                + yscale * (s.from + 40);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   200
        }).join("L");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   201
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   202
    paper.path(d).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   203
        "stroke-width": 4,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   204
        "stroke": "#000000",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   205
        opacity: .5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   206
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   207
    paper.path(d).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   208
        "stroke-width": 1,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   209
        "stroke": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   210
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   211
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   212
    for (var i=0; i < data.duration; i += 1800) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   213
        var y = yscale * i;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   214
        paper.path("M0" + "," + y + "l" + globR + ",0").attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   215
        paper.text(0, y + 6, secsToString(i)).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   216
        	"text-anchor": "start",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   217
            "fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   218
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   219
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   220
    paper.text(0, ph-8, secsToString(data.duration)).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   221
        "text-anchor": "start",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   222
        "fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   223
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   224
    paper.path("M0" + globR + ",0L" + localTimeR + ",0" ).attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   225
    paper.path("M0," + (ph-1) + "l" + localTimeR + ",0" ).attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   226
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   227
    paper.path("M" + globR + ",0l0," + ph).attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   228
    paper.path("M" + localL + ",0l0," + ph).attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   229
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   230
    var entonnoir = paper.path("").attr("fill","#333"),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   231
    	localStartText = paper.text(localTimeR,6,"").attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   232
    		"text-anchor": "end",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   233
    		"fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   234
    	}),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   235
    	localEndText = paper.text(localTimeR,ph - 8, "").attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   236
    		"text-anchor": "end",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   237
    		"fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   238
    	}),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   239
    	localTimes = [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   240
    	localMmsos = [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   241
    	localMmsoDelta,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   242
    	mmsoAlt = [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   243
    	lowerFiveSecs,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   244
    	higherFiveSecs,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   245
    	localyscale;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   246
	
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   247
	entonnoir.toBack();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   248
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   249
    function showLocal() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   250
		localyscale = ph / localduration;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   251
    	var localstart = localpos - localduration/2;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   252
    		localend = localpos + localduration/2;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   253
    		globtop = yscale * localstart,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   254
    		globbottom = yscale * localend,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   255
    		betweenx = (globR + localL) / 2,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   256
    		betweenyt = (globtop) / 2,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   257
    		betweenyb = (globbottom + ph) / 2,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   258
    		curve = (localL - globR) / 2,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   259
    		entonnoird = "M0," + globtop + "l" + globR + ",0Q" + betweenx + "," + globtop + "," + betweenx + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   260
    			+ Math.max(globtop - curve, betweenyt) + "L" + betweenx + "," + Math.min(curve, betweenyt) + "Q"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   261
    			+ betweenx + ",0," + localL + ",0"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   262
    			+ "L" + localR + ",0L" + localR + "," + ph + "L" + localL + "," + ph + "Q" + betweenx + "," + ph + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   263
    			+ betweenx + "," + Math.max(ph - curve, betweenyb) +"L" + betweenx + "," + Math.min(globbottom + curve, betweenyb)
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   264
    			+ "Q" + betweenx + "," + globbottom + "," + globR + "," + globbottom + "L0," + globbottom;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   265
			
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   266
		entonnoir.attr("path",entonnoird);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   267
		localTimes.forEach(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   268
			t.text.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   269
			t.line.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   270
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   271
		localMmsos.forEach(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   272
			t.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   273
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   274
		mmsoAlt.forEach(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   275
			t.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   276
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   277
		var filteredSegments = data.segments.filter(function(s) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   278
			return s.start < localend && s.end > localstart;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   279
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   280
		localMmsoDelta = parseInt(filteredSegments[0].id.split("_")[1]);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   281
		localMmsos = filteredSegments.map(function(s) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   282
			var y = localyscale * (s.start - localstart),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   283
				h = localyscale * s.duration;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   284
	        var rect = paper.rect( localL, y, localW, h );
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   285
	        rect.attr({stroke: "none", title: s.id});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   286
	        if (parseInt(s.id.replace("MMSO_","")) % 2) {
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   287
	        	var altrect = paper.rect( localR, y, 60, h);
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   288
	        	altrect.attr({stroke: "none", fill: "#222"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   289
	        	mmsoAlt.push(altrect);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   290
	        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   291
	        return rect;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   292
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   293
		localStartText.attr("text", secsToString(localstart)).toFront();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   294
		localEndText.attr("text", secsToString(localend)).toFront();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   295
		for ( var i = (1 + Math.floor(localstart / 120)) * 120; i < localend; i += 120 ) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   296
			var y = localyscale*(i - localstart)
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   297
			localTimes.push({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   298
				text: paper.text(localTimeR,6+y,secsToString(i)).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   299
		    		"text-anchor": "end",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   300
		    		"fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   301
		    	}),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   302
		    	line: paper.path("M0" + localL + "," + y + "L" + localTimeR + "," + y).attr({stroke: "#666"})
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   303
			});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   304
		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   305
		if (lowerFiveSecs) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   306
			lowerFiveSecs.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   307
		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   308
		if (higherFiveSecs) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   309
			higherFiveSecs.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   310
		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   311
		var filteredFiveSecs = data.fiveseconds.slice(Math.floor(localstart / 5), Math.ceil(localend / 5));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   312
        var counts = filteredFiveSecs.map(function(s) { return s.count}),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   313
        	lmx = Math.max.apply(Math, counts),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   314
        	lmi = Math.min.apply(Math, counts.concat([lmx - 1]))
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   315
        	lxscale = localW/(lmx-lmi);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   316
       	
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   317
	    var d = "M" + filteredFiveSecs.map(function(s) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   318
	            var x = localL + lxscale * (s.count - lmi);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   319
	            return x
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   320
	                + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   321
	                + localyscale * (s.from + 1 - localstart)
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   322
	                + "L"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   323
	                + x
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   324
	                + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   325
	                + localyscale * (s.from + 4 - localstart);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   326
	        }).join("L");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   327
	        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   328
	    lowerFiveSecs = paper.path(d).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   329
	        "stroke-width": 4,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   330
	        "stroke": "#000000",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   331
	        opacity: .5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   332
	    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   333
	    higherFiveSecs = paper.path(d).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   334
	        "stroke-width": 1,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   335
	        "stroke": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   336
	    });
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   337
	    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   338
	    var imghtm = '', imgrate = localduration / 12, imgstart = imgrate * Math.floor(localstart / imgrate), imgend = imgrate * Math.ceil(localend / imgrate);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   339
	    for (var i = imgstart; i <= imgend; i+= imgrate) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   340
	    	var imgsrc = i + '.png';
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   341
	    	while (imgsrc.length < 9) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   342
	    		imgsrc = '0' + imgsrc;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   343
	    	}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   344
	    	var imgy = Math.floor( localyscale * (i - localstart) - 22.5 )
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   345
	    	imghtm += '<img src="thumbnails/' + imgsrc + '" style="top: ' + imgy +'px;" />';
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   346
	    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   347
	    $(".play-images").html(imghtm);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   348
	    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   349
	    $(".play-localtweets .tweet").each(function() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   350
	    	var el = $(this),
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   351
	    		t = parseInt(el.attr("data-timestamp"));
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   352
    		if (t > localstart && t < localend) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   353
    			el.show();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   354
    		} else {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   355
    			el.hide();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   356
    		}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   357
	    });
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   358
	    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   359
		throttledGetTweets();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   360
	    
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   361
		showTopicViz();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   362
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   363
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   364
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   365
    var lastPos, lastDuration, lastTopics;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   366
    
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   367
    var tweetTemplate = _.template('<li class="tweet" data-timestamp="<%= timestamp %>" data-topic-id="<%= topic.topic %>"><img src="<%- data.profile_image_url %>" /><p>@<%- data.from_user_name %>: <%- data.text %></p></li>'),
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   368
    	callnum = 0,
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   369
    	tweetstructure = {},
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   370
    	requestedtweets = {},
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   371
    	_NTWEETS = 10;
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   372
    
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   373
    function showTweets() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   374
    	    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   375
    	var toshow = [];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   376
    	var topics = Array.prototype.join.call($(".topic.selected").map(function(){return $(this).attr("data-topic-id")})).split(",");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   377
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   378
    	for (var i = 0; i < localMmsos.length; i++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   379
    		var mmso = data.segments[localMmsoDelta + i];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   380
    		var mmsostruct = tweetstructure[mmso.id];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   381
    		if (mmsostruct) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   382
	    		for (var j = 0; j < topics.length; j++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   383
	    			var topicid = topics[j];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   384
					if (mmsostruct[topicid]) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   385
						var tweetids = mmsostruct[topicid].tweetids;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   386
						for (var k = 0; k < tweetids.length; k++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   387
							toshow.push(tweetids[k]);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   388
						}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   389
					}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   390
	    		}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   391
    		}
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   392
    	}
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   393
    	toshow = _(toshow).uniq();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   394
    	    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   395
    	var tweetstoshow = toshow.map(function(tid) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   396
    		return requestedtweets[tid];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   397
    	}).filter(function(tw) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   398
    		return ((tw.status == 2) && (tw.timestamp > (localpos - localduration / 2)) && (tw.timestamp < (localpos + localduration / 2)));
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   399
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   400
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   401
		tweetstoshow.forEach(function(tw) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   402
			tw.topic = tw.topics.filter(function(t) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   403
				return topics.indexOf(t.topic) !== -1;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   404
			}).sort(function(a,b) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   405
				return b.weight - a.weight
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   406
			})[0];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   407
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   408
				
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   409
		tweetstoshow.sort(function(a, b) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   410
			return b.topic.weight - a.topic.weight; 
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   411
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   412
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   413
		tweetstoshow = tweetstoshow.slice(0,10);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   414
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   415
		tweetstoshow.sort(function(a, b) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   416
			return a.timestamp - b.timestamp;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   417
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   418
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   419
		console.log(tweetstoshow);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   420
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   421
		var html = tweetstoshow.map(tweetTemplate).join("");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   422
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   423
		$(".play-localtweets").html(html);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   424
		var h = 0;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   425
		$(".play-localtweets .tweet").each(function() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   426
			h += $(this).outerHeight();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   427
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   428
		$(".play-localtweets .tweet").css("margin-top",Math.max(0,($(".play-bottom").height() - h)/(tweetstoshow.length+1)));
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   429
		showTopicViz();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   430
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   431
    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   432
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   433
    function getMmsoTweetIds(mmstruct) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   434
    	    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   435
    	TopicsBean.bestSocialInteractionsIdsMatching(mmstruct.mmso, mmstruct.topic, 0, _NTWEETS, {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   436
			callback: function(tw) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   437
				mmstruct.status = 2;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   438
				mmstruct.tweetids = tw;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   439
				for (var k = 0; k < tw.length; k++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   440
					var tweetid = tw[k],
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   441
						relevance = mmstruct.weight * (_NTWEETS - k) / _NTWEETS;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   442
					if (!requestedtweets[tweetid]) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   443
						requestedtweets[tweetid] = {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   444
							id: tweetid,
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   445
							status: 0,
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   446
							topics: []
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   447
						}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   448
					}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   449
					requestedtweets[tweetid].topics.push({
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   450
						topic: mmstruct.topic,
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   451
						weight: relevance
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   452
					});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   453
				}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   454
				debouncedGetTweetData();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   455
			},
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   456
			errorHandler: function(err) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   457
				mmstruct.status = 0;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   458
				console.log(err);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   459
				throttledGetTweetIds();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   460
			}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   461
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   462
    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   463
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   464
    var _MAX_BATCH = 20;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   465
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   466
    function getTweetIds() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   467
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   468
    	console.log("getTweetIds");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   469
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   470
    	var toload = [];
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   471
    	
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   472
    	_(tweetstructure).each(function(v) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   473
    		_(v).each(function(w) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   474
    			if (!w.status) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   475
    				w.status = 1;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   476
    				toload.push(w);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   477
    			}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   478
    		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   479
    	});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   480
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   481
    	console.log("Loading tweet ids");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   482
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   483
    	if (toload.length) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   484
    		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   485
    		if (toload.length > _MAX_BATCH) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   486
    			toload = _(toload).shuffle().slice(0,_MAX_BATCH);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   487
    			window.setInterval(throttledGetTweetIds,0);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   488
    		}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   489
    		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   490
    		dwr.engine.beginBatch();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   491
    		toload.forEach(getMmsoTweetIds);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   492
    		dwr.engine.endBatch();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   493
    	}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   494
    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   495
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   496
    function getTweetData() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   497
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   498
    	console.log("getTweetData");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   499
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   500
    	var toload = [];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   501
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   502
    	_(requestedtweets).each(function(v) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   503
			if (!v.status) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   504
				toload.push(v.id);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   505
			}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   506
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   507
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   508
    	console.log("Loading tweet data");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   509
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   510
		$.getJSON(
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   511
			solrUrl(
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   512
				"twitter",
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   513
				{
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   514
					q:"id:(" + toload.join(" OR ") + ")",
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   515
					fl: "id_str,created_at,from_user_name,text,profile_image_url",
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   516
					rows: toload.length
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   517
				}
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   518
			),
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   519
			function(t) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   520
				var tweets = t.response.docs;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   521
				tweets.forEach(function(tweet) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   522
					var timestamp = new Date(tweet.created_at).valueOf() / 1000 - deltaT;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   523
					requestedtweets[tweet.id_str].data = tweet;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   524
					requestedtweets[tweet.id_str].status = 2;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   525
					requestedtweets[tweet.id_str].timestamp = timestamp;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   526
				});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   527
				throttledShowTweets();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   528
			}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   529
		);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   530
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   531
    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   532
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   533
    debouncedGetTweetData = _(getTweetData).debounce(125);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   534
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   535
    throttledGetTweetIds = _(getTweetIds).throttle(10000);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   536
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   537
    throttledShowTweets = _(showTweets).throttle(200);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   538
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   539
    function getLocalTweets() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   540
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   541
    	console.log("getLocalTweets");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   542
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   543
    	var topics = Array.prototype.join.call($(".topic.selected").map(function(){return $(this).attr("data-topic-id")})).split(",");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   544
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   545
    	for (var i = 0; i < localMmsos.length; i++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   546
    		var mmso = data.segments[localMmsoDelta + i];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   547
    		if (!tweetstructure[mmso.id]) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   548
    			tweetstructure[mmso.id] = {}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   549
    		}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   550
    		var mmsostruct = tweetstructure[mmso.id];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   551
    		for (var j = 0; j < topics.length; j++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   552
				var topicid = topics[j],
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   553
					weight = data.topics[topics[j]].weights[localMmsoDelta + i];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   554
				if (weight > .1 && !mmsostruct[topicid]) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   555
					mmsostruct[topicid] = {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   556
						topic: topicid,
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   557
						mmso: mmso.id,
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   558
						status: 0,
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   559
						weight: weight,
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   560
						tweetids: []
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   561
					};
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   562
				}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   563
    		}
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   564
    	}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   565
    	
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   566
    	throttledGetTweetIds();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   567
    	throttledShowTweets();
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   568
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   569
    
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   570
    var throttledGetTweets = _.throttle(getLocalTweets, 500),
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   571
    	throttledShowLocal = _.throttle(showLocal, 100);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   572
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   573
    showTopics(sortedTopics);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   574
    (topicHash.match(/\d+/g) || []).forEach(function(id) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   575
    	$(".topic[data-topic-id=" + id + "]").addClass("selected").attr("data-timestamp",++ordertag);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   576
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   577
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   578
    var localpos = 7100,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   579
    	localduration = 600;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   580
    	
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   581
    showLocal();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   582
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   583
    $(".topics-block").on("mouseenter", ".topic", function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   584
        var el = $(this);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   585
        el.addClass("hover");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   586
        showTopicViz();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   587
    }).on("mouseleave", ".topic", function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   588
        $(this).removeClass("hover");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   589
        showTopicViz();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   590
    }).on("click", ".topic", function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   591
        var el = $(this);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   592
        $(this).toggleClass("selected");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   593
        el.attr("data-timestamp", el.hasClass("selected") ? ++ordertag : 999999);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   594
        showTopicViz();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   595
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   596
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   597
    var mouseIsDown, isDragging, startY, startT, startPos, scrollGlobal, speedscale, slowiterations;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   598
    
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   599
    $(document).mouseup(function() { mouseIsDown = false; isDragging = false; });
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   600
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   601
    $(".play-dataviz").mousedown(function(e) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   602
    	var l = $(this).offset().left,
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   603
    		scrollLimit = l + 380;
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   604
		if (e.pageX < scrollLimit) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   605
			mouseIsDown = true;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   606
	    	startY = e.pageY;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   607
	    	startT = new Date();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   608
	    	startPos = localpos;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   609
	    	scrollGlobal = e.pageX < (l + 140);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   610
	    	e.preventDefault();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   611
		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   612
    }).mousemove(function(e) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   613
    	if (mouseIsDown) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   614
    		if (isDragging) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   615
    			var limit = $(this).offset().left + 140,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   616
    				deltaY = e.pageY - startY,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   617
    				delta = Math.floor(deltaY / (scrollGlobal ? yscale : - localyscale));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   618
				localpos = Math.max(localduration / 2, Math.min(data.duration - localduration / 2, startPos + delta));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   619
				throttledShowLocal();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   620
    		} else {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   621
    			isDragging = true;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   622
    		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   623
    	}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   624
    }).mouseup(function(e) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   625
    	if (scrollGlobal && !isDragging) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   626
    		
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   627
    		var posY = e.pageY - $(this).offset().top;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   628
    		localpos = Math.max(localduration / 2, Math.min(data.duration - localduration / 2, Math.floor(posY / yscale)));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   629
			throttledShowLocal();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   630
    	}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   631
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   632
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   633
    var totalScroll = 0, zoomlevels = [ 1800, 900, 600, 300, 120, 60 ], currentlevel = 2;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   634
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   635
    $(".play-dataviz").mousewheel(function(_event, _scrolldelta) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   636
    	totalScroll += _scrolldelta;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   637
	    if (Math.abs(totalScroll) >= 1) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   638
	    	var d = (totalScroll > 0 ? 1 : -1),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   639
	    		newlevel = Math.max(0, Math.min(zoomlevels.length - 1, currentlevel + d));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   640
    		if (newlevel !== currentlevel) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   641
    			currentlevel = newlevel;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   642
    			localduration = zoomlevels[currentlevel];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   643
    			localpos = Math.max(localduration / 2, Math.min(data.duration - localduration / 2, localpos));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   644
    			throttledShowLocal();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   645
    		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   646
	        totalScroll = 0;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   647
	    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   648
    })
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   649
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   650
}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   651
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   652
var data = { duration: 10200, topics: [] },
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   653
    colorset = ["#E41A1C", "#377EB8", "#4DAF4A", "#984EA3", "#FF7F00", "#A65628", "#F781BF"];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   654
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   655
$(function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   656
	
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   657
	dwr.engine.setErrorHandler(function(a, b) { console.error("DWR", b); });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   658
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   659
    $(".topics-block").draggable({axis:"x"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   660
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   661
    var loadedSteps = 0,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   662
        stepsToFullyLoaded = 0;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   663
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   664
    function checkIfLoaded() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   665
        loadedSteps++;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   666
        if (loadedSteps >= stepsToFullyLoaded) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   667
            setTimeout(showData,0);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   668
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   669
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   670
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   671
    function loadJson(url, propname, callback) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   672
        stepsToFullyLoaded++;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   673
        $.getJSON(url, function(d) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   674
            if (callback) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   675
                var res = callback(d);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   676
            } else {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   677
                var res = d;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   678
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   679
            if (propname) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   680
                data[propname] = res;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   681
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   682
            checkIfLoaded();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   683
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   684
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   685
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   686
    function loadFromTopicsBean(method, propname, args, callback) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   687
        stepsToFullyLoaded++;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   688
        var arg = args || [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   689
            cb = function(d) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   690
                if (callback) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   691
                    var res = callback(d);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   692
                } else {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   693
                    var res = d;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   694
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   695
                if (propname) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   696
                    data[propname] = res;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   697
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   698
                checkIfLoaded();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   699
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   700
        arg.push({callback: cb});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   701
        TopicsBean[method].apply(TopicsBean,arg);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   702
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   703
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   704
    loadJson("data/minutes.json", "minutes");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   705
    loadJson("data/5secs.json", "fiveseconds");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   706
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   707
    loadJson(
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   708
        solrUrl("MMSO", {q: "*:*", fl: "topic*,MMSO_id,multimediaSegment", rows: 250 }),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   709
        "segments",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   710
        function(d) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   711
            return d.response.docs.map(function(mmso) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   712
                var tc = mmso.multimediaSegment.match(/\d+/g),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   713
                    start = parseInt(tc[0]),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   714
                    end = parseInt(tc[1]),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   715
                    topics = [];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   716
                for (var k in mmso) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   717
                    if (k.substr(0,5) === "topic" && mmso[k] > .01) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   718
                        topics.push({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   719
                            topic: parseInt(k.substr(5)),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   720
                            weight: mmso[k]
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   721
                        })
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   722
                    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   723
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   724
                topics.sort(function(a,b) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   725
                    return b.weight - a.weight;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   726
                });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   727
/*                topics = topics.filter(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   728
                    return t.topic !== topicPoubelle
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   729
                }).slice(0,1);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   730
                topics[0].weight = 1; */
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   731
                return {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   732
                    id: mmso.MMSO_id,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   733
                    start: start,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   734
                    end: end,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   735
                    duration: end - start,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   736
                    topics: topics
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   737
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   738
            }).sort(function(a,b) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   739
                return a.start - b.start;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   740
            });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   741
        })
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   742
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   743
    dwr.engine.setTimeout(60000);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   744
    TopicsBean._path = "http://159.217.144.101:8050/sia-solr/dwr";
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   745
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   746
    loadFromTopicsBean("getTopicsNumber",false,false,function(topic_count) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   747
        for (var i = 0; i < topic_count; i++) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   748
            data.topics.push(null);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   749
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   750
        dwr.engine.beginBatch();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   751
        data.topics.forEach(function(v, k) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   752
            loadFromTopicsBean("getTopicDistribution",false,[k, 50, false],function(topic) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   753
                var words = topic.match(/[^=,{]+=0.\d{0,8}/g);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   754
                data.topics[k] = {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   755
                    index: k,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   756
                    words: words.map(function(w) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   757
                        var parts = w.split("=");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   758
                        return {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   759
                            word: parts[0].trim(),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   760
                            weight: parseFloat(parts[1])
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   761
                        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   762
                    })
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   763
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   764
            });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   765
            
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   766
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   767
        dwr.engine.endBatch();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   768
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   769
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   770
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   771
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   772
});