| author | Raphael Velt <raph.velt@gmail.com> |
| Thu, 27 Oct 2011 17:57:53 +0200 | |
| changeset 339 | 6a073c4a8578 |
| parent 336 | d60efd677b50 |
| child 340 | a99a04556e3b |
| permissions | -rw-r--r-- |
| 333 | 1 |
var socket, |
2 |
tlPaper, |
|
3 |
twPaper, |
|
4 |
tweetData = { |
|
5 |
"tweetcount" : 0, |
|
6 |
"position" : 0, |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
7 |
"feedMode" : true, |
| 333 | 8 |
"followLast" : true, |
9 |
"zoomLevel" : 3, |
|
10 |
"timeLevel" : 2, |
|
11 |
"tweets" : [], |
|
12 |
"posIndex" : [], |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
13 |
"tlChanged" : true, |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
14 |
"tlLevelChanged" : true, |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
15 |
"blockUpdate" : false, |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
16 |
"waitUpdate" : true, |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
17 |
"htmlBuffer" : '', |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
18 |
"wheelDelta" : 0 |
| 333 | 19 |
}, |
20 |
displaySplitting = [ |
|
21 |
{ |
|
22 |
positions : [ 10, 20, 22, 24, 25, 26, 27, 28, 29, 31, 33, 43, 53 ], |
|
23 |
classNames : [ 'icons fade', 'icons', 'quarter fade', 'quarter', 'half fade', 'half', 'full', 'half', 'half fade', 'quarter', 'quarter fade', 'icons', 'icons fade' ] |
|
24 |
}, |
|
25 |
{ |
|
26 |
positions : [ 1, 3, 5, 7, 13, 33, 53 ], |
|
27 |
classNames : [ 'full', 'half', 'half fade', 'quarter', 'quarter fade', 'icons', 'icons fade' ] |
|
28 |
} |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
29 |
]; |
| 333 | 30 |
|
31 |
function placeHolder(className) { |
|
32 |
return '<li class="placeholder ' + className + '"></li>'; |
|
33 |
} |
|
34 |
||
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
35 |
function clicTweet(tweetPos) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
36 |
if (tweetPos != tweetData.position) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
37 |
tweetData.position = tweetPos; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
38 |
tweetData.followLast = (tweetData.position == tweetData.tweetcount); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
39 |
return false; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
40 |
} else { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
41 |
console.log("getting linkedTweets"); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
42 |
socket.emit('linkedTweets',{"tweetpos":tweetPos}); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
43 |
} |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
44 |
} |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
45 |
|
| 333 | 46 |
function tweetToHtml(tweet, className) { |
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
47 |
if (!tweet) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
48 |
return placeHolder(className); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
49 |
} |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
50 |
html = '<li class="tweet ' + className + '" id="tweet_' + tweet.pos + '" onclick="return clicTweet(' + tweet.pos + ')"'; |
| 333 | 51 |
if (tweetData.followLast && tweet.pos == tweetData.position) { |
52 |
html += ' style="display: none"'; |
|
53 |
} |
|
54 |
html += '>'; |
|
55 |
if (tweet.annotations.length) { |
|
56 |
html += '<div class="annotations">'; |
|
57 |
for (var i in tweet.annotations) { |
|
|
335
5f83c21dee69
Created conf.js file, shared between server & client
Raphael Velt <raph.velt@gmail.com>
parents:
334
diff
changeset
|
58 |
html += '<div class="annotation" style="width:' + (100/tweet.annotations.length) + '%; background:' + annotations[tweet.annotations[i]].colors.tweet + '"></div>'; |
| 333 | 59 |
} |
60 |
html += '</div>'; |
|
61 |
} |
|
62 |
html += '<div class="twmain">'; |
|
63 |
a_user = '<a href="http://twitter.com/' + tweet.user.screen_name + '" target="_blank" title="' + tweet.user.name + '">'; |
|
64 |
if (tweet.user.profile_image_url) { |
|
65 |
html += a_user + '<img class="profile_image" src="' + tweet.user.profile_image_url + '" /></a>'; |
|
66 |
} |
|
67 |
html += '<h4>' + a_user + '@' + tweet.user.screen_name + '</a></h4><p class="created_at">' + new Date(tweet.created_at).toLocaleTimeString() + '</p><p class="tweet_text">'; |
|
68 |
lastend = 0; |
|
69 |
txt = ''; |
|
70 |
entities = []; |
|
71 |
for (var i in tweet.entities.hashtags) { |
|
72 |
entities.push({ |
|
73 |
"start" : tweet.entities.hashtags[i].indices[0], |
|
74 |
"end" : tweet.entities.hashtags[i].indices[1], |
|
75 |
"html" : '<a href="http://twitter.com/search?q=%23' + tweet.entities.hashtags[i].text + '" target="_blank">#' + tweet.entities.hashtags[i].text + '</a>' |
|
76 |
}); |
|
77 |
} |
|
78 |
for (var i in tweet.entities.urls) { |
|
79 |
entities.push({ |
|
80 |
"start" : tweet.entities.urls[i].indices[0], |
|
81 |
"end" : tweet.entities.urls[i].indices[1], |
|
82 |
"html" : '<a href="' + tweet.entities.urls[i].expanded_url + '" target="_blank">' + tweet.entities.urls[i].display_url + '</a>' |
|
83 |
}); |
|
84 |
} |
|
85 |
for (var i in tweet.entities.user_mentions) { |
|
86 |
entities.push({ |
|
87 |
"start" : tweet.entities.user_mentions[i].indices[0], |
|
88 |
"end" : tweet.entities.user_mentions[i].indices[1], |
|
89 |
"html" : '<a href="http://twitter.com/' + tweet.entities.user_mentions[i].screen_name + '" target="_blank" title="' + tweet.entities.user_mentions[i].name + '">@' + tweet.entities.user_mentions[i].screen_name + '</a>' |
|
90 |
}); |
|
91 |
} |
|
92 |
entities.sort(function(a, b) { return a.start - b.start }); |
|
93 |
for (var i in entities) { |
|
94 |
txt += tweet.text.substring(lastend, entities[i].start) + entities[i].html; |
|
95 |
lastend = entities[i].end; |
|
96 |
} |
|
97 |
txt += tweet.text.substring(lastend); |
|
98 |
html += txt + '</p></li></div>'; |
|
99 |
return html; |
|
100 |
} |
|
101 |
||
102 |
||
103 |
function getUpdate() { |
|
104 |
tweetData.posToDisplay = []; |
|
105 |
if (tweetData.followLast) { |
|
106 |
for (var i = tweetData.tweetcount; i >= tweetData.tweetcount - 52; i--) { |
|
107 |
tweetData.posToDisplay.push( i > 0 ? i : -1 ); |
|
108 |
} |
|
109 |
tweetData.end = tweetData.tweetcount; |
|
110 |
tweetData.start = Math.max(1, tweetData.end - 52); |
|
111 |
} else { |
|
112 |
for (var i = tweetData.position + 26; i >= tweetData.position - 26; i--) { |
|
113 |
tweetData.posToDisplay.push( i > 0 && i <= tweetData.tweetcount ? i : -1 ); |
|
114 |
} |
|
115 |
tweetData.end = Math.min(tweetData.tweetcount, tweetData.position + 26 ); |
|
116 |
tweetData.start = Math.max(1, tweetData.position - 26); |
|
117 |
} |
|
118 |
var tweetsToGet = []; |
|
119 |
for (var i = tweetData.start; i <= tweetData.end; i++) { |
|
120 |
if (!tweetByPos(i)) { |
|
121 |
tweetsToGet.push(i); |
|
122 |
} |
|
123 |
} |
|
124 |
if (tweetsToGet.length) { |
|
125 |
socket.emit('updateTweets', { |
|
126 |
"tweets" : tweetsToGet |
|
127 |
}); |
|
128 |
} else { |
|
129 |
drawTweetList(); |
|
130 |
//drawDisplay(); |
|
131 |
} |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
132 |
if (tweetData.tlChanged || tweetData.tlLevelChanged) { |
| 333 | 133 |
socket.emit('updateTimeline', { |
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
134 |
"level" : tweetData.timeLevel, |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
135 |
"full" : tweetData.tlLevelChanged |
| 333 | 136 |
}); |
137 |
} else { |
|
138 |
drawTimeLine(); |
|
139 |
} |
|
140 |
} |
|
141 |
||
142 |
function tweetByPos(pos) { |
|
143 |
var index = tweetData.posIndex.indexOf(pos); |
|
144 |
return (index == -1 ? false : tweetData.tweets[index]); |
|
145 |
} |
|
146 |
||
147 |
function delayedUpdate() { |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
148 |
tweetData.blockUpdate = false; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
149 |
if (tweetData.waitUpdate) { |
| 333 | 150 |
updateDisplay(); |
151 |
} |
|
152 |
} |
|
153 |
||
154 |
function updateDisplay() { |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
155 |
if (tweetData.blockUpdate) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
156 |
tweetData.waitUpdate = true; |
| 333 | 157 |
} else { |
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
158 |
tweetData.waitUpdate = false; |
| 333 | 159 |
getUpdate(); |
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
160 |
tweetData.blockUpdate = true; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
161 |
setTimeout(delayedUpdate, 300); |
| 333 | 162 |
} |
163 |
} |
|
164 |
||
165 |
function setTimeZoom(level) { |
|
166 |
if (level >= 0 && level <= 4) { |
|
167 |
tweetData.timeLevel = level; |
|
168 |
tweetData.tlChanged = true; |
|
169 |
updateDisplay(); |
|
170 |
} |
|
171 |
} |
|
172 |
||
173 |
function drawTweetList() { |
|
174 |
html = ''; |
|
175 |
var i = 0; |
|
176 |
while (i < tweetData.posIndex.length) { |
|
177 |
if (tweetData.posToDisplay.indexOf(tweetData.posIndex[i]) == -1) { |
|
178 |
tweetData.posIndex.splice(i,1); |
|
179 |
tweetData.tweets.splice(i,1); |
|
180 |
} else { |
|
181 |
i++; |
|
182 |
} |
|
183 |
} |
|
184 |
for (var i in tweetData.posToDisplay) { |
|
185 |
var ds = displaySplitting[tweetData.followLast ? 1 : 0]; |
|
186 |
for (var j in ds.positions) { |
|
187 |
if (ds.positions[j] > i) { |
|
188 |
var className = ds.classNames[j]; |
|
189 |
break; |
|
190 |
} |
|
191 |
} |
|
192 |
html += ( tweetData.posToDisplay[i] != -1 ? tweetToHtml(tweetByPos(tweetData.posToDisplay[i]), className) : placeHolder(className) ); |
|
193 |
} |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
194 |
if (tweetData.htmlBuffer != html) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
195 |
$("#tweetlist").html(html); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
196 |
tweetData.htmlBuffer = html; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
197 |
} |
| 333 | 198 |
if (tweetData.followLast) { |
199 |
$("#tweet_" + tweetData.position).fadeIn(500); |
|
200 |
} |
|
201 |
drawTimeWindow(); |
|
202 |
} |
|
203 |
||
204 |
function drawTimeWindow() { |
|
205 |
twPaper.clear(); |
|
206 |
if (!tweetData.timeline || !tweetData.timeline.length) return; |
|
207 |
|
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
208 |
var dtfintl = tweetData.timeline[ tweetData.timeline.length - 1 ].end, |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
209 |
dtdebtl = tweetData.timeline[0].start, |
| 333 | 210 |
dtfintw = new Date( tweetByPos( tweetData.end ).created_at ), |
211 |
dtdebtw = new Date( tweetByPos( tweetData.start ).created_at ), |
|
212 |
scY = 600 / ( dtfintl - dtdebtl ); |
|
213 |
twPaper.rect( 0, scY * ( dtfintl - dtfintw ), 300, scY * ( dtfintw - dtdebtw )).attr({"stroke":"none","fill":"#8080ff","fill-opacity":.2}); |
|
214 |
var dtcour = new Date( tweetByPos( tweetData.position ).created_at ), |
|
215 |
posY = scY * ( dtfintl - dtcour ); |
|
216 |
twPaper.path("M0 "+posY+"L300 "+posY).attr({"stroke":"#ff0"}); |
|
217 |
} |
|
218 |
||
219 |
function drawTimeLine() { |
|
220 |
tlPaper.clear(); |
|
221 |
if (!tweetData.timeline || !tweetData.timeline.length) return; |
|
222 |
tweetData.tlTweetRects = []; |
|
223 |
var scaleY = 600 / tweetData.timeline.length, |
|
224 |
max = 0; |
|
225 |
for (var i = 0; i < tweetData.timeline.length; i++) { |
|
226 |
max = Math.max(max, tweetData.timeline[i].tweets); |
|
227 |
} |
|
228 |
var scaleX = 160 / max; |
|
229 |
|
|
230 |
// dessin de l'axe vertical |
|
231 |
|
|
232 |
tlPaper.path("M160 0L160 600").attr({"stroke":"#ccc"}); |
|
233 |
|
|
234 |
// dessin de la date de début |
|
235 |
|
|
236 |
tlPaper.text(165, 592, new Date(tweetData.timeline[0].start).toLocaleTimeString()).attr({ "text-anchor" : "start", "font-size": "12px" }); |
|
237 |
|
|
238 |
// dessin de la date de fin |
|
239 |
|
|
240 |
tlPaper.text(165, 7, new Date(tweetData.timeline[tweetData.timeline.length - 1].end).toLocaleTimeString()).attr({ "text-anchor" : "start", "font-size": "12px" }); |
|
241 |
for (var i = 0; i < tweetData.timeline.length; i++) { |
|
242 |
var posY = 600 - (i * scaleY); |
|
243 |
|
|
244 |
// Si on est à une demi-heure, on trace un axe secondaire + heure |
|
245 |
|
|
246 |
if (i && !(new Date(tweetData.timeline[i].start).valueOf() % 1800000)) { |
|
247 |
tlPaper.path("M0 "+posY+"L165 "+posY).attr({"stroke":"#ccc"}); |
|
248 |
tlPaper.text(165, posY, new Date(tweetData.timeline[i].start).toLocaleTimeString()).attr({ "text-anchor" : "start", "font-size": "12px" }); |
|
249 |
} |
|
250 |
var anz = { |
|
|
335
5f83c21dee69
Created conf.js file, shared between server & client
Raphael Velt <raph.velt@gmail.com>
parents:
334
diff
changeset
|
251 |
"default" :tweetData.timeline[i].tweets |
| 333 | 252 |
}; |
253 |
for (var j in tweetData.timeline[i].annotations) { |
|
|
335
5f83c21dee69
Created conf.js file, shared between server & client
Raphael Velt <raph.velt@gmail.com>
parents:
334
diff
changeset
|
254 |
anz.default -= tweetData.timeline[i].annotations[j]; |
| 333 | 255 |
anz[j] = tweetData.timeline[i].annotations[j]; |
256 |
} |
|
257 |
var posX = 0; |
|
258 |
for (var j in anz) { |
|
259 |
var largX = scaleX * anz[j]; |
|
|
335
5f83c21dee69
Created conf.js file, shared between server & client
Raphael Velt <raph.velt@gmail.com>
parents:
334
diff
changeset
|
260 |
tlPaper.rect(posX, 600 - scaleY * (i+1), largX, scaleY).attr({"stroke": "none", "fill": annotations[j].colors.timeline}); |
| 333 | 261 |
posX += largX; |
262 |
} |
|
263 |
} |
|
264 |
|
|
265 |
drawTimeWindow(); |
|
266 |
/* for (var i = 0; i < tweetData.arcs.length; i++) { |
|
267 |
var x1 = scaleX * (tmptw[tweetData.arcs[i].from].x + .5), |
|
268 |
x2 = scaleX * (tmptw[tweetData.arcs[i].to].x + .5), |
|
269 |
y1 = 600 - scaleY * (tmptw[tweetData.arcs[i].from].y + .5), |
|
270 |
y2 = 600 - scaleY * (tmptw[tweetData.arcs[i].to].y + .5), |
|
271 |
d = "M"+x1+" "+y1+"C"; |
|
272 |
if (y1 == y2) { |
|
273 |
d += x1+" "+(y1 - 30)+" "+x2+" "+(y2 - 30); |
|
274 |
} else { |
|
275 |
d += (x1 + 60)+" "+y1+" "+(x2 + 60)+" "+y2; |
|
276 |
} |
|
277 |
paper.path(d+" "+x2+" "+y2); |
|
278 |
} */ |
|
279 |
} |
|
280 |
||
281 |
$(document).ready(function() { |
|
282 |
tlPaper = Raphael("timeline", 220, 600); |
|
283 |
twPaper = Raphael("timewindow", 220, 600); |
|
| 334 | 284 |
socket = io.connect('http://' + document.location.hostname ); |
| 333 | 285 |
socket.on('tweetSummary', function (data) { |
286 |
if (tweetData.tweetcount != data.tweetcount) { |
|
287 |
tweetData.tweetcount = data.tweetcount; |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
288 |
tweetData.tlLevelChanged = true; |
| 333 | 289 |
if (tweetData.followLast) { |
290 |
tweetData.position = data.tweetcount; |
|
291 |
} |
|
292 |
updateDisplay(); |
|
293 |
} |
|
294 |
}); |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
295 |
socket.on('tweetPosByDate', function (data) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
296 |
tweetData.position = data.tweetpos; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
297 |
tweetData.followLast = (tweetData.position == tweetData.tweetcount); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
298 |
updateDisplay(); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
299 |
}); |
| 333 | 300 |
socket.on('tweets', function (data) { |
301 |
for (var i in data) { |
|
302 |
if (tweetData.posIndex.indexOf(data[i].pos) == -1) { |
|
303 |
tweetData.tweets.push(data[i]); |
|
304 |
tweetData.posIndex.push(data[i].pos); |
|
305 |
} |
|
306 |
} |
|
307 |
drawTweetList(); |
|
308 |
}); |
|
309 |
socket.on('timeline', function (data) { |
|
310 |
tweetData.tlChanged = false; |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
311 |
if (data.full) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
312 |
tweetData.timeline = data.data; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
313 |
} else { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
314 |
if (tweetData.timeline[tweetData.timeline.length - 1].start == data.data[0].start) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
315 |
tweetData.timeline[tweetData.timeline.length - 1] = data.data[0]; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
316 |
} else { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
317 |
tweetData.timeline.push(data.data[0]); |
| 333 | 318 |
} |
319 |
} |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
320 |
while (tweetData.length > 50) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
321 |
tweetData.splice(0,1); |
| 333 | 322 |
} |
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
323 |
drawTimeLine(); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
324 |
}); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
325 |
socket.on('linkedTweets', function(data) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
326 |
console.log(data); |
| 333 | 327 |
}); |
328 |
$("#tweetlist").mousewheel(function(e, d) { |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
329 |
tweetData.wheelDelta += d; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
330 |
if (Math.abs(tweetData.wheelDelta) >= 1) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
331 |
tweetData.position = Math.min( tweetData.tweetcount, Math.max(1, parseInt(tweetData.wheelDelta) + tweetData.position ) ); |
| 333 | 332 |
tweetData.followLast = (tweetData.position == tweetData.tweetcount); |
333 |
updateDisplay(); |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
334 |
tweetData.wheelDelta = 0; |
| 333 | 335 |
} |
336 |
return false; |
|
337 |
}); |
|
338 |
$("#timewindow").mousewheel(function(e, d) { |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
339 |
tweetData.wheelDelta += d; |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
340 |
if (Math.abs(tweetData.wheelDelta) >= 1) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
341 |
if (tweetData.wheelDelta > 0) { |
| 333 | 342 |
setTimeZoom(tweetData.timeLevel + 1); |
343 |
} else { |
|
344 |
setTimeZoom(tweetData.timeLevel - 1); |
|
345 |
} |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
346 |
tweetData.wheelDelta = 0; |
| 333 | 347 |
} |
348 |
return false; |
|
349 |
}); |
|
|
339
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
350 |
$("#timewindow").click(function(evt) { |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
351 |
var offsetY = evt.pageY - $(this).offset().top, |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
352 |
dtfintl = tweetData.timeline[ tweetData.timeline.length - 1 ].end, |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
353 |
dtdebtl = tweetData.timeline[0].start, |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
354 |
clicTime = dtdebtl + (1 - ( offsetY / 600 ) ) * ( dtfintl - dtdebtl ); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
355 |
socket.emit('tweetPosByDate',{ date: clicTime }); |
|
6a073c4a8578
Minor changes and bug fixes
Raphael Velt <raph.velt@gmail.com>
parents:
336
diff
changeset
|
356 |
}); |
| 333 | 357 |
}); |