This repository has been archived by the owner on May 4, 2021. It is now read-only.
forked from Bonnevoy/wiener
-
Notifications
You must be signed in to change notification settings - Fork 1
/
wiener.coffee
107 lines (97 loc) · 6.44 KB
/
wiener.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
class event_gender
@app_id: "292295494139725"
@male: 0
@female: 0
@pathname: ''
# Acquire an access token with OAuth and save it to @access_token for future use.
@getAccessToken: ->
if (window.location.hash.length is 0)
path = 'https://www.facebook.com/dialog/oauth?'
query_params =
['client_id=' + @app_id
'redirect_uri=' + window.location
'response_type=token']
query = query_params.join('&')
url = path + query
window.location = url
else
@access_token or= window.location.hash.substring(1);
# Acquire the id of the event. The path name will be of the form /events/event_id/.
@getEventId: ->
window.location.pathname.split('/')[2]
# Acquire the attending list of the event. The list is limited to 2500 attendees for speed issues.
# The function will return a jQurey Deferred Object.
@getEvent: ->
path_event = "https://graph.facebook.com/" + @getEventId() + "/attending?"
query_params = [@access_token, 'limit=2500']
query = query_params.join('&')
url_event = path_event + query
$.getJSON(url_event)
# The information about the users is required in batches of 100, once again for speed issues.
@getUsers: (event_users) ->
ids = []
defs = []
ids.push user.id for user in event_users
for i in [0..ids.length] by 100
url_user = "https://graph.facebook.com/?ids=" + ids[i..(i+100)].join(',')
defs.push $.getJSON(url_user).done (data) =>
@[data[user_id].gender]++ for user_id of data
@updateStats()
$.when.apply($, defs).done ->
$('.gender_icon').removeClass('spin')
# The stats are updated after every batch that is finished.
@updateStats: ->
$('#stats_male').html(@male)
$('#stats_female').html(@female)
@render: ->
html = '<li class="prs uiListItem">
<div class="clearfix pvm">
<div class="fbInfoIcon lfloat">
<i class="img gender_icon spin" title="Females" style="display:inline-block;height:10px;width:10px;background:url();">
<u>Females</u>
</i>
</div>
<div class="lfloat" id="stats_female">...</div>
</div>
</li>
<li class="pls uiListItem">
<div class="clearfix pvm">
<div class="fbInfoIcon lfloat">
<i class="img gender_icon spin" title="Males" style="display:inline-block;height:10px;width:10px;background:url();">
<u>Males</u>
</i>
</div>
<div class="lfloat" id="stats_male">...</div>
</div>
</li>'
old_location = $('#contentArea .fbEventInfo .uiList li li:first-child')
if (old_location.length)
old_location.after(html)
else
$('#contentArea .fbEventInfo ul.uiList.-cx-PRIVATE-uiList__horiz li.pls').removeClass('pls').addClass('prs')
$('#contentArea .fbEventInfo ul.uiList.-cx-PRIVATE-uiList__horiz').append(html)
html = '<style>
@-webkit-keyframes spin {
0% { -webkit-transform: rotateY(0deg); }
50% { -webkit-transform: rotateY(180deg); }
100% { -webkit-transform: rotateY(0deg); }
}
.spin {
-webkit-animation: spin 4s infinite;
}
</style>'
$('head').append(html)
# Require an access token, render the UI, get the attendees and subsequently their gender.
@init: ->
if @pathname isnt window.location.pathname
@pathname = window.location.pathname
@getAccessToken()
@render()
@getEvent().done (res) =>
@getUsers(res.data)
# FB uses pushstate for navigation and as far as we know there is no event fired when history.pushstate is used.
# Therefore, an interval is set to check if the current page is an event.
# Anyone with a better solution for this?
$( ->
setInterval ( -> event_gender.init() if window.location.pathname.search(/events\/[0-9]*\//i) isnt -1), 200
)