js/playscreen.js
author veltr
Thu, 04 Apr 2013 17:44:59 +0200
changeset 17 8ee8c9ea2a9f
parent 16 9a82fbbf6377
child 18 cd85b780f4a5
permissions -rw-r--r--
Added user tweets
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) {
14
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
     8
    var u = "http://159.217.144.101:8050/sia-solr/" + table + "/select?" + $.param(params) + "&wt=json&json.wrf=?";
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
     9
    console.log(u);
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
    10
    return u;
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    11
}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    12
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    13
function showData() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    14
    
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    15
	data.topiclabels.forEach(function(v) {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    16
		var words = _(v.words).map(function(v, k) {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    17
			return {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    18
				word: k,
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    19
				weight: v
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    20
			}
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    21
		});
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    22
		words.sort(function(a,b) {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    23
			return b.weight - a.weight;
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    24
		})
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    25
		data.topics[v.topic_id].words = words;
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    26
	});
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
    27
	
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    28
    var topicHash = document.location.hash || "#selectedtopics=5,15&visibletopics=5,10,15";
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    29
    
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    30
    var pageParams = {};
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    31
    
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    32
    var syncVideo = true,
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    33
    	syncTimer;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    34
    
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    35
    function deSync() {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    36
    	syncVideo = false;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    37
    	clearTimeout(syncTimer);
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    38
    	syncTimer = setTimeout(function() {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    39
    		syncVideo = true;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    40
    	},5000);
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    41
    }
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    42
    
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    43
    topicHash
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    44
    	.replace(/^#/,'')
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    45
    	.split('&')
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    46
    	.forEach(function(p) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    47
    		var s = p.split('=');
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    48
    		pageParams[s[0]] = s[1].split(",").map(function(t) { return decodeURIComponent(t)});
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    49
    	})
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    50
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    51
    var ordertag = 0;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    52
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    53
    function secsToString(seconds) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    54
        var hours = Math.floor(seconds/3600),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    55
            minutes = Math.floor(seconds/60) % 60,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    56
            secs = Math.floor(seconds % 60);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    57
        function pad(n) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    58
            var r = n.toString();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    59
            while (r.length < 2) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    60
                r = "0" + r;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    61
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    62
            return r;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    63
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    64
        return (hours ? (hours + ":") : "") + pad(minutes) + ":" + pad(secs);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    65
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    66
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    67
    $(".duration").text(secsToString(data.duration));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    68
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    69
    var nmmso = data.segments.length;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    70
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    71
    data.topics.forEach(function(topic) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    72
        topic.score = 0;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    73
        topic.weights = [];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    74
        for (var i = 0; i < nmmso; i++) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    75
            topic.weights.push(0);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    76
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    77
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    78
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    79
    data.segments.forEach(function(mmso, i) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    80
        mmso.topics.forEach(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    81
            data.topics[t.topic].weights[i] = t.weight;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    82
            data.topics[t.topic].score += t.weight;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    83
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    84
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    85
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    86
    var sortedTopics = data.topics.filter(function(t) {
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
    87
        return pageParams.visibletopics.indexOf(t.index.toString()) !==-1 && t.index !== topicPoubelle;
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    88
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
    89
    
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    90
    function hasTopics(mmso, topics) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    91
    	for (var j = 0; j < mmso.topics.length; j++) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    92
			if (topics.indexOf(mmso.topics[j].topic) !== -1) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    93
				return true;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    94
			}
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    95
		}
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    96
		return false;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    97
    }
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    98
    
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
    99
    function checkOrGoNext() {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   100
    	var topics = Array.prototype.slice.call(
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   101
    		$(".topic.selected").map(function() {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   102
    			return parseInt($(this).attr("data-topic-id"))
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   103
			})
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   104
		);
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   105
		var currentMmso = _(data.segments).find(function(s) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   106
			return s.start <= player.currentTime && s.end > player.currentTime;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   107
		});
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   108
		
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   109
		if (hasTopics(currentMmso, topics)) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   110
			throttledShowLocal();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   111
		} else {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   112
			goToNext();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   113
		}
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   114
		
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   115
    }
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   116
    
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   117
    function goToNext() {
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   118
    	var topics = Array.prototype.slice.call(
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   119
    		$(".topic.selected").map(function() {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   120
    			return parseInt($(this).attr("data-topic-id"));
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   121
			})
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   122
		);
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   123
    	for (var i = 0; i < data.segments.length; i++) {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   124
    		var mmso = data.segments[i];
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   125
    		if (mmso.start >= player.currentTime && hasTopics(mmso, topics)) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   126
    			player.setCurrentTime(mmso.start);
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   127
				throttledShowLocal();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   128
				return;
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   129
    		}
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   130
    	}
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   131
    }
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   132
    
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   133
    function showTopics(topiclist) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   134
        var tbhtml = topiclist.reduce(function(mem, topic) {
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   135
            var wordsToShow = topic.words.slice(0,4),
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   136
                max = wordsToShow[0].weight,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   137
                min = Math.min(wordsToShow[wordsToShow.length - 1].weight, max - .01),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   138
                scale = 8 / (max - min);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   139
            var li = '<li class="shadow-block topic" data-topic-id="'
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   140
                + topic.index
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   141
                + '" data-timestamp="999999"><ul class="topic-words">'
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   142
                + wordsToShow.reduce(function(memwords, word) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   143
                    return memwords
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   144
                        + '<li style="font-size: '
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   145
                        + ( 8 + scale * (word.weight - min) )
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   146
                        + 'px;">'
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   147
                        + word.word
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   148
                        + '</li>';
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   149
                },"")
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   150
                + '</ul></li>';
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   151
            return mem + li;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   152
        },'');
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   153
        var tb = $(".topics-block");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   154
        tb.html(tbhtml);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   155
        tb.css("top",0);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   156
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   157
        showTopicViz();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   158
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   159
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   160
    var tweetLines = [];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   161
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   162
    function showTopicViz() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   163
        var selectedBlocks = $(".topic.selected, .topic.hover"),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   164
            sbl = selectedBlocks.length,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   165
            topicBlocks = $(".topic");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   166
        if (!sbl && topicBlocks.length < sortedTopics.length) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   167
            selectedBlocks = topicBlocks;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   168
            sbl = selectedBlocks.length;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   169
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   170
        var topicsAndColors = [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   171
        	colors = {};
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   172
        selectedBlocks.each(function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   173
            var el = $(this),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   174
                topicid = parseInt(el.attr("data-topic-id"));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   175
            topicsAndColors.push({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   176
                "$": el,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   177
                timestamp: parseInt(el.attr("data-timestamp")),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   178
                hovered: el.hasClass("hover"),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   179
                id: topicid,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   180
                topic: data.topics[topicid]
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   181
            });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   182
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   183
        topicsAndColors.sort(function(a,b) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   184
           return ( a.timestamp - b.timestamp ) || ( a.id - b.id );
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   185
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   186
        topicBlocks.css("background","");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   187
        topicsAndColors.forEach(function(topic, i) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   188
            topic.color = topic.hovered ? "#ffff00" : colorset[i % colorset.length];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   189
            colors[topic.id] = topic.color;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   190
            topic.$.css("background", topic.color);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   191
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   192
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   193
        for (var i = 0; i < nmmso; i++) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   194
            var opacity = 0,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   195
                rgb = [0,0,0];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   196
            topicsAndColors.forEach(function(topic) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   197
                var c = Raphael.getRGB(topic.color),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   198
                    o = topic.topic.weights[i];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   199
                rgb[0] += c.r * o;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   200
                rgb[1] += c.g * o;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   201
                rgb[2] += c.b * o;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   202
                opacity += o;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   203
            });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   204
            if (opacity) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   205
                color = Raphael.rgb.apply(Raphael, rgb.map(function(c) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   206
                    return c/opacity;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   207
                }));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   208
                var attr = {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   209
                    fill: color,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   210
                    opacity: .5 + .5 * opacity
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   211
                };
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   212
                segmentrects[i].show();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   213
                segmentrects[i].attr(attr);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   214
                if (i >= localMmsoDelta && i < localMmsoDelta + localMmsos.length) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   215
                	localMmsos[i - localMmsoDelta].show();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   216
                	localMmsos[i - localMmsoDelta].attr(attr);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   217
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   218
            } else {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   219
                segmentrects[i].hide();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   220
                if (i >= localMmsoDelta && i < localMmsoDelta + localMmsos.length) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   221
                	localMmsos[i - localMmsoDelta].hide();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   222
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   223
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   224
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   225
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   226
        tweetLines.forEach(function(tl) { tl.remove(); });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   227
        tweetLines = [];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   228
        
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   229
        var deltaY = $(".play-bottom").offset().top;
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   230
        
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   231
        $(".play-localtweets .tweet:visible").each(function() {
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   232
        	var el = $(this),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   233
        		liY = + el.offset().top + el.outerHeight() / 2 - deltaY,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   234
        		tY = localyscale * (+el.attr("data-timestamp") - localpos + localduration / 2),
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   235
        		p = "M" + localL + "," + tY + "L" + localR + "," + tY + "L400," + liY,
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   236
        		path = paper.path(p);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   237
    		$(this).css("background",colors[el.attr("data-topic-id")] || "");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   238
    		path.attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   239
    			stroke: "#ccc"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   240
    		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   241
    		tweetLines.push(path);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   242
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   243
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   244
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   245
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   246
    var jqsvg = $(".play-svg"),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   247
        paper = new Raphael(jqsvg[0]),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   248
        totalR = jqsvg.width(),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   249
        ph = jqsvg.height(),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   250
        globW = 85,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   251
        globL = 40,
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   252
        entonnoirR = 155,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   253
        localL = 235,
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   254
        localW = 85,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   255
        localR = (localL + localW),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   256
        localTimeR = (localL + localW) + globL,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   257
        globR = (globW + globL),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   258
        yscale = ph / data.duration,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   259
        mx = Math.max.apply(Math, data.minutes.map(function(s) { return s.count})),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   260
        xscale = globW/mx;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   261
    var segmentrects = data.segments.map(function(mmso) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   262
        var rect = paper.rect(globL, yscale * mmso.start, globW, yscale * mmso.duration);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   263
        rect.attr({stroke: "none"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   264
        return rect;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   265
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   266
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   267
    var d = "M" + data.minutes.map(function(s) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   268
            var x = globL + xscale * s.count;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   269
            return x
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   270
                + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   271
                + yscale * (s.from + 20)
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   272
                + "L"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   273
                + x
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   274
                + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   275
                + yscale * (s.from + 40);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   276
        }).join("L");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   277
        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   278
    paper.path(d).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   279
        "stroke-width": 4,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   280
        "stroke": "#000000",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   281
        opacity: .5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   282
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   283
    paper.path(d).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   284
        "stroke-width": 1,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   285
        "stroke": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   286
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   287
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   288
    for (var i=0; i < data.duration; i += 1800) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   289
        var y = yscale * i;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   290
        paper.path("M0" + "," + y + "l" + globR + ",0").attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   291
        paper.text(0, y + 6, secsToString(i)).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   292
        	"text-anchor": "start",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   293
            "fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   294
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   295
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   296
    paper.text(0, ph-8, secsToString(data.duration)).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   297
        "text-anchor": "start",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   298
        "fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   299
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   300
    paper.path("M0" + globR + ",0L" + localTimeR + ",0" ).attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   301
    paper.path("M0," + (ph-1) + "l" + localTimeR + ",0" ).attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   302
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   303
    paper.path("M" + globR + ",0l0," + ph).attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   304
    paper.path("M" + localL + ",0l0," + ph).attr({stroke: "#666"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   305
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   306
    var entonnoir = paper.path("").attr("fill","#333"),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   307
    	localStartText = paper.text(localTimeR,6,"").attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   308
    		"text-anchor": "end",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   309
    		"fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   310
    	}),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   311
    	localEndText = paper.text(localTimeR,ph - 8, "").attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   312
    		"text-anchor": "end",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   313
    		"fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   314
    	}),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   315
    	localTimes = [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   316
    	localMmsos = [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   317
    	localMmsoDelta,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   318
    	mmsoAlt = [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   319
    	lowerFiveSecs,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   320
    	higherFiveSecs,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   321
    	localyscale;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   322
	
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   323
	entonnoir.toBack();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   324
    
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   325
    var cloudTemplate = _.template('<li style="font-size: <%- size %>px;"<% if (selected) {%> class="selected"<% } %>><%- word %></li>');
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   326
    
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   327
    var globalIndic = $(".global-position"),
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   328
    	localIndic = $(".local-position"),
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   329
    	playTime = $(".current-time");
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   330
    
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   331
    function showLocal() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   332
		localyscale = ph / localduration;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   333
    	var localstart = localpos - localduration/2;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   334
    		localend = localpos + localduration/2;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   335
    		globtop = yscale * localstart,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   336
    		globbottom = yscale * localend,
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   337
    		betweenx = (globR + entonnoirR) / 2,
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   338
    		betweenyt = (globtop) / 2,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   339
    		betweenyb = (globbottom + ph) / 2,
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   340
    		curve = (entonnoirR - globR) / 2,
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   341
    		entonnoird = "M0," + globtop + "l" + globR + ",0Q" + betweenx + "," + globtop + "," + betweenx + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   342
    			+ Math.max(globtop - curve, betweenyt) + "L" + betweenx + "," + Math.min(curve, betweenyt) + "Q"
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   343
    			+ betweenx + ",0," + entonnoirR + ",0"
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   344
    			+ "L" + localR + ",0L" + localR + "," + ph + "L" + entonnoirR + "," + ph + "Q" + betweenx + "," + ph + ","
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   345
    			+ betweenx + "," + Math.max(ph - curve, betweenyb) +"L" + betweenx + "," + Math.min(globbottom + curve, betweenyb)
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   346
    			+ "Q" + betweenx + "," + globbottom + "," + globR + "," + globbottom + "L0," + globbottom,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   347
			localkeywords = {};
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   348
			
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   349
		entonnoir.attr("path",entonnoird);
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   350
    	localIndic.css("top",(player.currentTime - localstart) * localyscale);
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   351
		localTimes.forEach(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   352
			t.text.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   353
			t.line.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   354
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   355
		localMmsos.forEach(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   356
			t.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   357
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   358
		mmsoAlt.forEach(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   359
			t.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   360
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   361
		var filteredSegments = data.segments.filter(function(s) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   362
			return s.start < localend && s.end > localstart;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   363
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   364
		localMmsoDelta = parseInt(filteredSegments[0].id.split("_")[1]);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   365
		localMmsos = filteredSegments.map(function(s) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   366
			var y = localyscale * (s.start - localstart),
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   367
				h = localyscale * s.duration,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   368
				rect = paper.rect( localL, y, localW, h ),
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   369
				visibled = (
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   370
					s.start < localstart
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   371
					? s.duration - localstart + s.start
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   372
					: (
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   373
						s.end > localend
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   374
						? s.duration - s.end + localend
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   375
						: s.duration
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   376
					)
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   377
				);
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   378
			_(s.keywords).each(function(v,k) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   379
				localkeywords[k] = (v * visibled) + (localkeywords[k] || 0);
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   380
			});
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   381
	        rect.attr({stroke: "none", title: s.id});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   382
	        if (parseInt(s.id.replace("MMSO_","")) % 2) {
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   383
	        	var altrect = paper.rect( localR, y, 60, h);
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   384
	        	altrect.attr({stroke: "none", fill: "#222"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   385
	        	mmsoAlt.push(altrect);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   386
	        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   387
	        return rect;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   388
		});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   389
		localStartText.attr("text", secsToString(localstart)).toFront();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   390
		localEndText.attr("text", secsToString(localend)).toFront();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   391
		for ( var i = (1 + Math.floor(localstart / 120)) * 120; i < localend; i += 120 ) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   392
			var y = localyscale*(i - localstart)
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   393
			localTimes.push({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   394
				text: paper.text(localTimeR,6+y,secsToString(i)).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   395
		    		"text-anchor": "end",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   396
		    		"fill": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   397
		    	}),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   398
		    	line: paper.path("M0" + localL + "," + y + "L" + localTimeR + "," + y).attr({stroke: "#666"})
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   399
			});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   400
		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   401
		if (lowerFiveSecs) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   402
			lowerFiveSecs.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   403
		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   404
		if (higherFiveSecs) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   405
			higherFiveSecs.remove();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   406
		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   407
		var filteredFiveSecs = data.fiveseconds.slice(Math.floor(localstart / 5), Math.ceil(localend / 5));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   408
        var counts = filteredFiveSecs.map(function(s) { return s.count}),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   409
        	lmx = Math.max.apply(Math, counts),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   410
        	lmi = Math.min.apply(Math, counts.concat([lmx - 1]))
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   411
        	lxscale = localW/(lmx-lmi);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   412
       	
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   413
	    var d = "M" + filteredFiveSecs.map(function(s) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   414
	            var x = localL + lxscale * (s.count - lmi);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   415
	            return x
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   416
	                + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   417
	                + localyscale * (s.from + 1 - localstart)
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   418
	                + "L"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   419
	                + x
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   420
	                + ","
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   421
	                + localyscale * (s.from + 4 - localstart);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   422
	        }).join("L");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   423
	        
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   424
	    lowerFiveSecs = paper.path(d).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   425
	        "stroke-width": 4,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   426
	        "stroke": "#000000",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   427
	        opacity: .5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   428
	    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   429
	    higherFiveSecs = paper.path(d).attr({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   430
	        "stroke-width": 1,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   431
	        "stroke": "#ffffff"
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   432
	    });
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   433
	    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   434
	    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
   435
	    for (var i = imgstart; i <= imgend; i+= imgrate) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   436
	    	var imgsrc = i + '.png';
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   437
	    	while (imgsrc.length < 9) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   438
	    		imgsrc = '0' + imgsrc;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   439
	    	}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   440
	    	var imgy = Math.floor( localyscale * (i - localstart) - 22.5 )
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   441
	    	imghtm += '<img src="thumbnails/' + imgsrc + '" style="top: ' + imgy +'px;" />';
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   442
	    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   443
	    $(".play-images").html(imghtm);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   444
	    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   445
	    $(".play-localtweets .tweet").each(function() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   446
	    	var el = $(this),
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   447
	    		t = parseInt(el.attr("data-timestamp"));
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   448
    		if (t > localstart && t < localend) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   449
    			el.show();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   450
    		} else {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   451
    			el.hide();
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
	    
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   455
	    localkeywords = _(localkeywords)
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   456
	    	.chain()
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   457
	    	.map(function(v,k) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   458
	    		return { word: k, score: v }
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   459
	    	})
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   460
	    	.sortBy(function(w) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   461
	    		return -w.score;
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   462
	    	})
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   463
	    	.first(40)
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   464
	    	.value();
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   465
    	
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   466
    	var values = _(localkeywords).pluck('score'),
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   467
    		max = Math.max.apply(Math, values),
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   468
    		min = Math.min.apply(Math, values),
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   469
    		scale = 10 / (max - Math.min(max - .1, min)),
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   470
    		selectedVisible = false;
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   471
		
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   472
		localkeywords.forEach(function(w) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   473
			w.size = 10 + (w.score - min) * scale;
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   474
			w.selected = (w.word === selectedWord);
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   475
			selectedVisible = selectedVisible || w.selected;
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   476
		});
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   477
    	
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   478
    	if (!selectedVisible) {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   479
    		selectedWord = false;
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   480
    	}
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   481
    	
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   482
    	$(".play-tagcloud").html(localkeywords.map(cloudTemplate).join(""));
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   483
	    
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   484
		throttledGetTweets();
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   485
		showTopicViz();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   486
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   487
    
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   488
    $(".play-tagcloud").on("click","li", function() {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   489
    	if ($(this).hasClass("selected")) {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   490
    		selectedWord = false;
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   491
    	} else {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   492
    		selectedWord = $(this).text();
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   493
    	}
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   494
    	throttledShowLocal();
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   495
    });
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   496
    
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   497
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   498
    var lastPos, lastDuration, lastTopics;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   499
    
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   500
    var tweetTemplate = _.template(
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   501
    		'<li class="tweet" data-timestamp="<%= timestamp %>" data-topic-id="<%= topic.topic %>">'
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   502
    		+ '<% if (show_link) { %><a href="#" data-user-id="<%- data.from_user_id %>"><% } %>'
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   503
    		+ '<img src="<%- data.profile_image_url %>" /><% if (show_link) { %></a><% } %>'
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   504
    		+ '<p><% if (show_link) { %><a href="#" data-user-id="<%- data.from_user_id %>"><% } %>'
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   505
    		+ '@<%- data.from_user_name %>:<% if (show_link) { %></a><% } %> <%= htext %></p></li>'),
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   506
    	callnum = 0,
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   507
    	tweetstructure = {},
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   508
    	requestedtweets = {},
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   509
    	_NTWEETS = 50,
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   510
    	selectedWord = false;
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   511
    
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   512
    function showTweets() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   513
    	var toshow = [];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   514
    	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
   515
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   516
    	for (var i = 0; i < localMmsos.length; i++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   517
    		var mmso = data.segments[localMmsoDelta + i];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   518
    		var mmsostruct = tweetstructure[mmso.id];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   519
    		if (mmsostruct) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   520
	    		for (var j = 0; j < topics.length; j++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   521
	    			var topicid = topics[j];
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   522
					if (mmsostruct.tweetids) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   523
						var tweetids = mmsostruct.tweetids[topicid];
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   524
						for (var k = 0; k < tweetids.length; k++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   525
							toshow.push(tweetids[k]);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   526
						}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   527
					}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   528
	    		}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   529
    		}
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   530
    	}
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   531
    	toshow = _(toshow).uniq();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   532
    	    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   533
    	var tweetstoshow = toshow.map(function(tid) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   534
    		return requestedtweets[tid];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   535
    	}).filter(function(tw) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   536
    		return ((tw.status == 2) && (tw.timestamp > (localpos - localduration / 2)) && (tw.timestamp < (localpos + localduration / 2)));
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   537
		});
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   538
				
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   539
		if (selectedWord) {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   540
			var rx = new RegExp(selectedWord.replace(/(\W)/gm,'\\$1'),'im');
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   541
			tweetstoshow = tweetstoshow.filter(function(tw) {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   542
				return rx.test(tw.data.text);
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   543
			});
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   544
		}
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   545
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   546
		tweetstoshow.forEach(function(tw) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   547
			tw.topic = tw.topics.filter(function(t) {
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   548
				return topics.indexOf(t.topic.toString()) !== -1;
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   549
			}).sort(function(a,b) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   550
				return b.weight - a.weight
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   551
			})[0];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   552
		});
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   553
		
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   554
		tweetstoshow = tweetstoshow.filter(function(t) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   555
			return !!t.topic;
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   556
		});
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   557
				
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   558
		tweetstoshow.sort(function(a, b) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   559
			return b.topic.weight - a.topic.weight; 
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   560
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   561
		
14
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   562
		if (tweetstoshow.length < 8) {
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   563
			var randtweets = data.randomtweets.filter(function(tw) {
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   564
				return (tw.timestamp > (localpos - localduration / 2)) && (tw.timestamp < (localpos + localduration / 2))
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   565
			});
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   566
			var mod = Math.ceil(randtweets.length / 8);
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   567
			randtweets = randtweets.filter(function(v,k) {
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   568
				return !(k % mod);
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   569
			});
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   570
			tweetstoshow = tweetstoshow.concat(randtweets);
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   571
		}
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   572
		
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   573
		tweetstoshow = tweetstoshow.slice(0,10);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   574
		
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   575
		if (selectedWord) {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   576
			var rx = new RegExp( '(' + selectedWord.replace(/(\W)/gm,'\\$1') + ')', 'gim' );
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   577
			tweetstoshow.forEach(function(tw) {
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   578
				tw.htext = _(tw.data.text).escape().replace(rx,'<span class="highlight">$1</span>');
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   579
			});
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   580
		} else {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   581
			tweetstoshow.forEach(function(tw) {
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   582
				tw.htext = _(tw.data.text).escape();
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   583
			});
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   584
		}
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   585
		
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   586
		tweetstoshow.forEach(function(tw) {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   587
			tw.show_link = true;
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   588
		});
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   589
		
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   590
		tweetstoshow.sort(function(a, b) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   591
			return a.timestamp - b.timestamp;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   592
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   593
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   594
		var html = tweetstoshow.map(tweetTemplate).join("");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   595
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   596
		$(".play-localtweets").html(html);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   597
		var h = 0;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   598
		$(".play-localtweets .tweet").each(function() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   599
			h += $(this).outerHeight();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   600
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   601
		$(".play-localtweets .tweet").css("margin-top",Math.max(0,($(".play-bottom").height() - h)/(tweetstoshow.length+1)));
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   602
		showTopicViz();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   603
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   604
    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   605
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   606
    function getMmsoTweetIds(mmstruct) {
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   607
    	TopicsBean.bestSocialInteractionsIdsMatching(mmstruct.mmsoid, 0, _NTWEETS, {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   608
			callback: function(res) {
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   609
				mmstruct.status = 2;
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   610
				mmstruct.tweetids = res;
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   611
				for (var j = 0; j < res.length; j++) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   612
					var tweetids = res[j],
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   613
						ntw = tweetids.length,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   614
						topicweight = data.topics[j].weights[mmstruct.mmsoindex];
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   615
					for (var k = 0; k < tweetids.length; k++) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   616
						var relevance = topicweight * (ntw - k) / ntw,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   617
							tweetid = tweetids[k];
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   618
						if (!requestedtweets[tweetid]) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   619
							requestedtweets[tweetid] = {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   620
								id: tweetid,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   621
								status: 0,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   622
								topics: []
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   623
							}
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   624
						}
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   625
						requestedtweets[tweetid].topics.push({
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   626
							topic: j,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   627
							weight: relevance
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   628
						});
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   629
					}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   630
				}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   631
				debouncedGetTweetData();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   632
			},
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   633
			errorHandler: function(err,info) {
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   634
				mmstruct.status = 0;
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   635
				console.error(err,info);
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   636
				debouncedGetTweetIds();
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   637
			}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   638
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   639
    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   640
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   641
    var _MAX_BATCH = 20;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   642
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   643
    function getTweetIds() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   644
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   645
    	console.log("getTweetIds");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   646
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   647
    	var toload = [];
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   648
    	
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   649
    	_(tweetstructure).each(function(w) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   650
			if (!w.status) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   651
				w.status = 1;
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   652
				toload.push(w);
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   653
			}
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   654
    	});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   655
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   656
    	if (toload.length) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   657
    		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   658
    		if (toload.length > _MAX_BATCH) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   659
    			toload = _(toload).shuffle().slice(0,_MAX_BATCH);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   660
    			window.setInterval(throttledGetTweetIds,0);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   661
    		}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   662
    		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   663
    		dwr.engine.beginBatch();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   664
    		toload.forEach(getMmsoTweetIds);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   665
    		dwr.engine.endBatch();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   666
    	}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   667
    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   668
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   669
    function getTweetData() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   670
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   671
    	console.log("getTweetData");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   672
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   673
    	var toload = [];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   674
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   675
    	_(requestedtweets).each(function(v) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   676
			if (!v.status) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   677
				toload.push(v.id);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   678
			}
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   679
		});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   680
		
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   681
		if (toload.length) {
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   682
			toload = toload.slice(0,200);
10
veltr
parents: 9
diff changeset
   683
			toload.forEach(function(twid) {
veltr
parents: 9
diff changeset
   684
				requestedtweets[twid].status = 1;
veltr
parents: 9
diff changeset
   685
			})
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   686
			$.getJSON(
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   687
			solrUrl(
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   688
				"twitter",
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   689
				{
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   690
					q:"id:(" + toload.join(" OR ") + ")",
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   691
					fl: "id_str,created_at,from_user_name,text,profile_image_url,from_user_id",
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   692
					rows: toload.length
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   693
				}
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   694
			),
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   695
			function(t) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   696
				var tweets = t.response.docs;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   697
				tweets.forEach(function(tweet) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   698
					var timestamp = new Date(tweet.created_at).valueOf() / 1000 - deltaT;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   699
					requestedtweets[tweet.id_str].data = tweet;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   700
					requestedtweets[tweet.id_str].status = 2;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   701
					requestedtweets[tweet.id_str].timestamp = timestamp;
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   702
				});
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   703
				throttledShowTweets();
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   704
				debouncedGetTweetData();
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   705
			});
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   706
		}
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   707
		
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   708
		
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   709
		
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   710
    }
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   711
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   712
    debouncedGetTweetData = _(getTweetData).debounce(125);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   713
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   714
    throttledGetTweetIds = _(getTweetIds).throttle(10000);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   715
    
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   716
    debouncedGetTweetIds = _(throttledGetTweetIds).debounce(125);
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
   717
    
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   718
    throttledShowTweets = _(showTweets).throttle(200);
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   719
    
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   720
    function getLocalTweets() {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   721
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   722
    	console.log("getLocalTweets");
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   723
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   724
    	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
   725
    	
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   726
    	for (var i = 0; i < localMmsos.length; i++) {
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   727
    		var mmso = data.segments[localMmsoDelta + i];
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   728
    		if (!tweetstructure[mmso.id]) {
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   729
    			tweetstructure[mmso.id] = {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   730
    				mmsoid: mmso.id,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   731
    				mmsoindex: localMmsoDelta + i,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   732
    				status: 0
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   733
    			}
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   734
    		}
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   735
    	}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   736
    	
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   737
    	throttledGetTweetIds();
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   738
    	throttledShowTweets();
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   739
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   740
    
6
14dd1980b0b9 MMSO Caching
veltr
parents: 5
diff changeset
   741
    var throttledGetTweets = _.throttle(getLocalTweets, 500),
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   742
    	throttledShowLocal = _.throttle(showLocal, 100);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   743
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   744
    showTopics(sortedTopics);
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   745
    
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   746
    pageParams.selectedtopics.forEach(function(id) {
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   747
    	$(".topic[data-topic-id=" + id + "]").addClass("selected").attr("data-timestamp",++ordertag);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   748
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   749
    
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   750
    var localpos = 300,
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   751
    	localduration = 600;
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   752
   	
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   753
   	var player = new Player();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   754
   	
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   755
   	player.duration = data.duration;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   756
   	
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   757
   	player.on("play", function() {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   758
   		$(".play-button").html("▐&nbsp;▌");
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   759
   	});
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   760
   	player.on("pause", function() {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   761
   		$(".play-button").text("▶");
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   762
   	});
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   763
   	player.on("timeupdate", function(t) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   764
   		playTime.text(secsToString(t));
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   765
   		globalIndic.css("top", yscale * t);
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   766
   		if (localyscale) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   767
   			var localy = (+t - localpos + localduration / 2) * localyscale;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   768
   			localIndic.css("top", localy);
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   769
   		}
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   770
    	if (syncVideo) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   771
    		localpos = Math.max(localduration / 2, Math.min(data.duration - localduration / 2, t));
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   772
    		throttledShowLocal();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   773
    	}
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   774
   	});
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   775
   	
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   776
   	$(".play-button").click(function() {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   777
   		if (player.paused) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   778
   			player.play();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   779
   		} else {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   780
   			player.pause();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   781
   		}
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   782
   	});
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   783
    
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   784
    $(".next-button").click(goToNext);
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   785
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   786
    $(".topics-block").on("mouseenter", ".topic", function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   787
        var el = $(this);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   788
        el.addClass("hover");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   789
        showTopicViz();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   790
    }).on("mouseleave", ".topic", function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   791
        $(this).removeClass("hover");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   792
        showTopicViz();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   793
    }).on("click", ".topic", function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   794
        var el = $(this);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   795
        $(this).toggleClass("selected");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   796
        el.attr("data-timestamp", el.hasClass("selected") ? ++ordertag : 999999);
16
9a82fbbf6377 tweet refresh fix
veltr
parents: 14
diff changeset
   797
		throttledGetTweets();
9a82fbbf6377 tweet refresh fix
veltr
parents: 14
diff changeset
   798
		showTopicViz();
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   799
    });
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   800
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   801
	var h = Hammer($(".play-bottom")[0]);
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   802
	
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   803
	var scrollGlobal, isDragging, startPos, startLevel, scaleStep = 1/Math.log(Math.sqrt(2));
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   804
	
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   805
	h.on("tap", function(e) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   806
		var _o = $(this).offset(),
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   807
			posX = e.gesture.center.pageX - _o.left,
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   808
			posY = e.gesture.center.pageY - _o.top;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   809
		if (posX < 140) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   810
			deSync();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   811
			localpos = Math.max(localduration / 2, Math.min(data.duration - localduration / 2, Math.floor(posY / yscale)));
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   812
			throttledShowLocal();
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   813
		}
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   814
	})
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   815
	.on("dragstart", function(e) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   816
		startPos = localpos;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   817
		var x = e.gesture.center.pageX - $(this).offset().left;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   818
		isDragging = (x < 380);
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   819
		scrollGlobal = (x < 140);
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   820
	})
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   821
	.on("drag", function(e) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   822
		if (isDragging && e.gesture) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   823
			var delta = Math.floor(e.gesture.deltaY / (scrollGlobal ? yscale : - localyscale));
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   824
			deSync();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   825
			localpos = Math.max(localduration / 2, Math.min(data.duration - localduration / 2, startPos + delta));
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   826
			throttledShowLocal();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   827
		}
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   828
	})
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   829
	.on("touch", function(e) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   830
		startLevel = currentlevel;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   831
	})
12
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   832
	.on("pinchin pinchout", function(e) {
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   833
		var x = e.gesture.center.pageX - $(this).offset().left;
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   834
		if (x > 380) {
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   835
			return;
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   836
		}
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   837
		var newlevel = Math.max(
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   838
			0,
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   839
			Math.min(
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   840
				zoomlevels.length - 1,
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   841
				startLevel + Math.round(Math.log(e.gesture.scale)*scaleStep) * (x > 140 ? 1 : -1)
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   842
			)
81a8bb1d872a ipad bugfixes
veltr
parents: 11
diff changeset
   843
		);
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   844
		if (newlevel !== currentlevel) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   845
			currentlevel = newlevel;
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   846
			localduration = zoomlevels[currentlevel];
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   847
			localpos = Math.max(localduration / 2, Math.min(data.duration - localduration / 2, localpos));
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   848
			throttledShowLocal();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   849
		}
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   850
	});
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   851
   
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   852
    var totalScroll = 0, zoomlevels = [ 1800, 900, 600, 300, 120, 60 ], currentlevel = 2;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   853
    
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   854
    $(".play-bottom")
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   855
    .mousedown(function(_e) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   856
    	_e.preventDefault();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   857
    })
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   858
    .on("touchstart", function(_e) {
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   859
    	_e.preventDefault();
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   860
    })
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   861
    .mousewheel(function(_event, _scrolldelta) {
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   862
    	totalScroll += _scrolldelta;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   863
	    if (Math.abs(totalScroll) >= 1) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   864
	    	var d = (totalScroll > 0 ? 1 : -1),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   865
	    		newlevel = Math.max(0, Math.min(zoomlevels.length - 1, currentlevel + d));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   866
    		if (newlevel !== currentlevel) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   867
    			currentlevel = newlevel;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   868
    			localduration = zoomlevels[currentlevel];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   869
    			localpos = Math.max(localduration / 2, Math.min(data.duration - localduration / 2, localpos));
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   870
    			throttledShowLocal();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   871
    		}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   872
	        totalScroll = 0;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   873
	    }
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   874
	    _event.preventDefault();
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   875
    });
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   876
    
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   877
    if (pageParams.keywords && pageParams.keywords.length) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   878
    	$(".keyword-search a").removeClass("placeholder").text(pageParams.keywords.join(", "));
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
   879
    }
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   880
    
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   881
    var moveInterval;
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   882
    
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   883
    $(".left-arrow").data("direction", -3);
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   884
    $(".right-arrow").data("direction", 3);
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   885
    
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   886
    $(".left-arrow,.right-arrow")
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   887
    	.on("mouseenter touchstart", function() {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   888
    		clearInterval(moveInterval);
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   889
    		var moveDirection = $(this).data("direction");
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   890
    		moveInterval = setInterval(function() {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   891
    			var t = $(".topics-block");
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   892
    			t.css("left", + moveDirection + parseFloat(t.css("left")));
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   893
    		}, 20);
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   894
    	})
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   895
    	.on("mouseleave touchend", function() {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   896
    		clearInterval(moveInterval);
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   897
    	});
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   898
    
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   899
    $(".play-localtweets").on("click", "li a", function() {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   900
    	var userid = $(this).attr("data-user-id");
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   901
    	$.getJSON(
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   902
			solrUrl(
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   903
				"twitter",
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   904
				{
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   905
					q: "from_user_id:" + userid,
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   906
					fl: "id_str,created_at,from_user_name,text,profile_image_url,from_user_id",
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   907
					rows: 500
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   908
				}
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   909
			),
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   910
			function(t) {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   911
				var tweets = t.response.docs;
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   912
				tweets.forEach(function(tweet) {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   913
					tweet.timestamp = new Date(tweet.created_at).valueOf() / 1000 - deltaT;
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   914
				});
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   915
				tweets.sort(function(a,b) {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   916
					return a.timestamp - b.timestamp;
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   917
				})
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   918
				var html = tweets.reduce(function(mem, tweet) {
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   919
					return mem + tweetTemplate({
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   920
						timestamp: tweet.timestamp,
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   921
						topic: {topic: -1},
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   922
						weight: 0,
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   923
						data: tweet,
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   924
						htext: _(tweet.text).escape(),
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   925
						show_link: false
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   926
					});
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   927
				},"");
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   928
				$(".user-tweets").show();
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   929
				$(".user-tweets-list").html(html);
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   930
				$(".user-name").text(tweets[0].from_user_name);
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   931
			}
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   932
		);
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   933
		return false;
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   934
    });
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
   935
    
11
9833f3e24105 Added video player
veltr
parents: 10
diff changeset
   936
    checkOrGoNext();
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   937
}
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   938
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   939
var data = { duration: 10200, topics: [] },
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   940
    colorset = ["#E41A1C", "#377EB8", "#4DAF4A", "#984EA3", "#FF7F00", "#A65628", "#F781BF"];
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   941
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   942
$(function() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   943
	
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   944
	dwr.engine.setErrorHandler(function(a, b) { console.error("DWR", b); });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   945
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   946
    $(".topics-block").draggable({axis:"x"});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   947
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   948
    var loadedSteps = 0,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   949
        stepsToFullyLoaded = 0;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   950
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   951
    function checkIfLoaded() {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   952
        loadedSteps++;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   953
        if (loadedSteps >= stepsToFullyLoaded) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   954
            setTimeout(showData,0);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   955
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   956
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   957
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   958
    function loadJson(url, propname, callback) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   959
        stepsToFullyLoaded++;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   960
        $.getJSON(url, function(d) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   961
            if (callback) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   962
                var res = callback(d);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   963
            } else {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   964
                var res = d;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   965
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   966
            if (propname) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   967
                data[propname] = res;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   968
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   969
            checkIfLoaded();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   970
        });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   971
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   972
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   973
    function loadFromTopicsBean(method, propname, args, callback) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   974
        stepsToFullyLoaded++;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   975
        var arg = args || [],
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   976
            cb = function(d) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   977
                if (callback) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   978
                    var res = callback(d);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   979
                } else {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   980
                    var res = d;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   981
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   982
                if (propname) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   983
                    data[propname] = res;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   984
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   985
                checkIfLoaded();
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   986
            }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   987
        arg.push({callback: cb});
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   988
        TopicsBean[method].apply(TopicsBean,arg);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   989
    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   990
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   991
    loadJson("data/minutes.json", "minutes");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   992
    loadJson("data/5secs.json", "fiveseconds");
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
   993
    
14
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   994
    var t = Math.floor(30*Math.random());
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   995
    
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   996
    function pad(n) {
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   997
        var r = n.toString();
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   998
        while (r.length < 2) {
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
   999
            r = "0" + r;
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1000
        }
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1001
        return r;
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1002
    }
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1003
        
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1004
    loadJson(
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1005
    	solrUrl(
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1006
    		"twitter",
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1007
    		{
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1008
    			q: "created_at:(*\\:*\\:"
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1009
    				+ pad(t)
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1010
    				+ "* OR *\\:*\\:"
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1011
    				+ (30+t)
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1012
    				+ "*)",
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1013
    			group: "true",
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1014
    			"group.field": "created_at",
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
  1015
    			"fl": "id_str,created_at,from_user_name,text,profile_image_url,from_user_id",
14
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1016
    			"rows": 800
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1017
    		}
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1018
		),
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1019
		"randomtweets",
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1020
		function(d) {
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1021
			var randtweets = d.grouped.created_at.groups.map(function(g) {
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1022
				var tweet = g.doclist.docs[0];
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1023
				return {
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1024
					topic: { topic: -1, weight: 0 },
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1025
					timestamp: (new Date(tweet.created_at).valueOf() / 1000 - deltaT),
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1026
					data: tweet
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1027
				}
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1028
			});
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1029
			randtweets.sort(function(a,b) {
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1030
				return a.timestamp - b.timestamp;
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1031
			});
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1032
			return randtweets;
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1033
		}
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1034
    )
3aa6b9963de0 Added topic labels
veltr
parents: 12
diff changeset
  1035
    
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
  1036
    loadJson("data/topiclabels.json", "topiclabels");
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
  1037
    
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1038
    loadJson(
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
  1039
        solrUrl("MMSO", {q: "*:*", fl: "topic*,MMSO_id,multimediaSegment,keywordsFromSocial", rows: 250 }),
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1040
        "segments",
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1041
        function(d) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1042
            return d.response.docs.map(function(mmso) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1043
                var tc = mmso.multimediaSegment.match(/\d+/g),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1044
                    start = parseInt(tc[0]),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1045
                    end = parseInt(tc[1]),
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1046
                    topics = [],
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1047
                    keywords = {};
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1048
                
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1049
                function getKeywords(field) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1050
                	var keywordtexts = mmso[field].replace(/[{}]/g,'').split(", ");
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1051
	                keywordtexts.forEach(function(k) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1052
	                	var t = k.split('='),
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1053
	                		s = parseFloat(t[1]),
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1054
	                		w = t[0].split(" ");
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1055
	            		w.forEach(function(m) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1056
	            			if (m.length > 2) {
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1057
	            				keywords[m] = s + (keywords[m] || 0);
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1058
	            			}
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1059
	            		});
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1060
	                });
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1061
                }
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1062
                
9
5b743d461f99 Clickable tagcloud + tweet request limiting
veltr
parents: 7
diff changeset
  1063
                //getKeywords("keywordsFromAudio");
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1064
                getKeywords("keywordsFromSocial");
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1065
                
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1066
                for (var k in mmso) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1067
                    if (k.substr(0,5) === "topic" && mmso[k] > .01) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1068
                        topics.push({
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1069
                            topic: parseInt(k.substr(5)),
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1070
                            weight: mmso[k]
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1071
                        })
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1072
                    }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1073
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1074
                topics.sort(function(a,b) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1075
                    return b.weight - a.weight;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1076
                });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1077
/*                topics = topics.filter(function(t) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1078
                    return t.topic !== topicPoubelle
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1079
                }).slice(0,1);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1080
                topics[0].weight = 1; */
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1081
                return {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1082
                    id: mmso.MMSO_id,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1083
                    start: start,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1084
                    end: end,
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1085
                    duration: end - start,
7
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1086
                    topics: topics,
a2d5b669f663 new data access method
veltr
parents: 6
diff changeset
  1087
                    keywords: keywords
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1088
                }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1089
            }).sort(function(a,b) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1090
                return a.start - b.start;
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1091
            });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1092
        })
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1093
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1094
    dwr.engine.setTimeout(60000);
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1095
    TopicsBean._path = "http://159.217.144.101:8050/sia-solr/dwr";
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1096
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1097
    loadFromTopicsBean("getTopicsNumber",false,false,function(topic_count) {
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1098
        for (var i = 0; i < topic_count; i++) {
17
8ee8c9ea2a9f Added user tweets
veltr
parents: 16
diff changeset
  1099
            data.topics.push({ index: i, words: [ { word: "(no label)", weight: 1 }] });
5
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1100
        }
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1101
    });
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1102
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1103
    
490e4d1b6fee started work on "play" screen
veltr
parents:
diff changeset
  1104
});