1 // Wikilens Javascript functions.
5 var rating = new Array; var prediction = new Array;
6 var avg = new Array; var numusers = new Array;
7 var canRate = new Array;
8 var msg_rating_votes = "Rating: %.1f (%d votes)";
9 var msg_curr_rating = "Your current rating: ";
10 var msg_curr_prediction = "Your current prediction: ";
11 //var msg_chg_rating = "Change your rating from ";
13 var msg_add_rating = "Add your rating: ";
14 var msg_thanks = "Thanks!";
15 var msg_rating_deleted = "Rating deleted!";
17 var rateit_imgsrc = '/wiki/themes/fusionforge/images/RateIt';
18 var rateit_action = 'RateIt';
22 function displayRating(imgId, imgPrefix, ratingvalue, pred, init) {
23 var ratings = new Array('Not Rated','Awful','Very Poor','Poor','Below Average',
24 'Average','Above Average','Good','Very Good','Excellent','Outstanding');
25 var cancel = imgId + imgPrefix + 'Cancel';
26 var curr_rating = rating[imgId];
27 var curr_pred = prediction[imgId];
29 var imgSrc = rateit_imgsrc;
30 if (init) { // re-initialize titles
31 title = msg_curr_rating+curr_rating+' '+ratings[curr_rating*2];
32 var linebreak = '. '; //
 or 
 within IE only;
34 title = title+' '+msg_curr_prediction+ curr_pred+' '+ratings[curr_pred*2];
38 document.getElementById(cancel).style.display = 'inline';
41 document.getElementById(cancel).style.display = 'none';
45 for (var i=1; i<=10; i++) {
46 var imgName = imgId + i;
48 //document[imgName].title = title;
50 if (ratingvalue > 0) {
52 document.getElementById(imgName).onmouseout = function() { displayRating(imgId,imgPrefix,avg[imgId],0,0) };
53 } else if (curr_pred) {
54 document.getElementById(imgName).onmouseout = function() { displayRating(imgId,imgPrefix,curr_pred,1,0) };
56 if (curr_rating != ratingvalue && typeof(msg_chg_rating) != "undefined") {
57 document.getElementById(imgName).title = msg_chg_rating+curr_rating+' '+ratings[curr_rating*2]+msg_to+j+' '+ratings[i];
60 document.getElementById(imgName).onmouseout = function() { displayRating(imgId,imgPrefix,avg[imgId],0,0) };
61 document.getElementById(imgName).title = msg_add_rating+j+' '+ratings[i];
67 document.getElementById(imgName).title = title+linebreak+msg_add_rating+ratings[i];
69 } else if (i<=(ratingvalue*2)) {
72 document.getElementById(imgName).src = imgSrc + imgPrefix + imgType + ((i%2) ? 'k1' : 'k0') + '.png';
76 function displayRating2(imgId, imgPrefix, ratingvalue, pred, init) {
77 var ratings = new Array('Not Rated','Awful','Very Poor','Poor','Below Average',
78 'Average','Above Average','Good','Very Good','Excellent','Outstanding');
79 var cancel = imgId + imgPrefix + 'Cancel';
80 var curr_rating = rating[imgId];
81 var curr_pred = prediction[imgId];
83 var imgSrc = rateit_imgsrc;
84 if (init) { // re-initialize titles
85 title = msg_curr_rating+curr_rating+' '+ratings[curr_rating*2];
86 var linebreak = '. '; //
 or 
 within IE only;
88 title = title+' '+msg_curr_prediction+ curr_pred+' '+ratings[curr_pred*2];
91 document.getElementById(cancel).style.display = 'inline';
94 document.getElementById(cancel).style.display = 'none';
97 for (var i=1; i<=10; i++) {
98 var imgName = imgId + i;
100 //document[imgName].title = title;
102 if (ratingvalue > 0) {
104 document.getElementById(imgName).onmouseout = function() { displayRating(imgId,imgPrefix,avg[imgId],0,0) };
105 } else if (curr_pred) {
106 document.getElementById(imgName).onmouseout = function() { displayRating(imgId,imgPrefix,curr_pred,1,0) };
108 if (curr_rating != ratingvalue && typeof(msg_chg_rating) != "undefined") {
109 document.getElementById(imgName).title = msg_chg_rating+curr_rating+' '+ratings[curr_rating*2]+msg_to+j+' '+ratings[i];
112 document.getElementById(imgName).onmouseout = function() { displayRating(imgId,imgPrefix,avg[imgId],0,0) };
113 document.getElementById(imgName).title = msg_add_rating+j+' '+ratings[i];
119 document.getElementById(imgName).title = title+linebreak+msg_add_rating+ratings[i];
122 if (ratingvalue <= curr_rating) {
123 if (i <= (ratingvalue * 2))
126 if (i <= (curr_rating * 2))
130 if (i <= (curr_rating * 2))
133 if (i <= (ratingvalue * 2))
137 document.getElementById(imgName).src = imgSrc + imgPrefix + imgType + ((i%2) ? 'k1' : 'k0') + '.png';
141 function sprintfRating(s, num, count) {
142 var num1 = Math.round(num * 10) / 10;
143 if (count < 2) s = s.replace(/votes/, 'vote');
144 return s.replace(/\%.1f/, num1).replace(/\%d/, count);
146 function clickRating(imgPrefix,pagename,version,imgId,dimension,newrating) {
147 var actionImg = imgId+'Action';
148 var top = document.getElementById('rateit-widget-top');
149 var nusers = numusers[imgId];
150 var old_rating = rating[imgId];
151 var sum1 = avg[imgId] * nusers;
153 if (newrating == 'X') {
154 deleteRating(actionImg,pagename,dimension);
156 if (old_rating && old_rating > 0) {
158 new_avg = (sum1 - old_rating) / (nusers - 1);
166 if (new_avg.toString() != "NaN" && idTop == imgId) {
167 avg[imgId] = new_avg;
168 top.childNodes[0].innerHTML = sprintfRating(msg_rating_votes, new_avg, nusers-1);
172 displayRating2(imgId,imgPrefix,0,0,1);
174 submitRating(actionImg,pagename,version,dimension,newrating);
176 if (old_rating && (old_rating > 0)) {
177 new_avg = (sum1 + newrating - old_rating) / nusers;
179 new_avg = (sum1 + newrating) / (nusers + 1);
182 if (new_avg.toString() != "NaN" && idTop == imgId) {
183 avg[imgId] = new_avg;
184 if (newrating != rating[imgId]) {
185 top.childNodes[0].innerHTML = sprintfRating(msg_rating_votes, new_avg, numusers[imgId]);
188 } else if (top && idTop == imgId) {
189 top.childNodes[0].innerHTML = sprintfRating(msg_rating_votes, newrating, 1);
190 avg[imgId] = newrating;
193 rating[imgId] = newrating;
194 displayRating2(imgId,imgPrefix,newrating,0,1);
197 function submitRating(actionImg,page,version,dimension,newrating) {
198 //TODO: GET => PUT request
199 // currently ratings are changed with side-effect, but GET should be side-effect free.
200 var myRand = Math.round(Math.random()*(1000000));
201 var imgSrc = WikiURL(page) + 'version=' + version + '&action=' + rateit_action + '&mode=add&rating=' + newrating + '&dimension=' + dimension + '&nocache=1&nopurge=1&rand=' + myRand;
202 document.getElementById(actionImg).title = msg_thanks;
203 document.getElementById(actionImg).src = imgSrc;
205 function deleteRating(actionImg, page, dimension) {
206 //TODO: GET => DELETE request
207 // currently ratings are changed with side-effect, but GET should be side-effect free.
208 var myRand = Math.round(Math.random()*(1000000));
209 var imgSrc = WikiURL(page) + 'action=' + rateit_action + '&mode=delete&dimension=' + dimension + '&nocache=1&nopurge=1&rand=' + myRand;
210 document.getElementById(actionImg).title = msg_rating_deleted;
211 document.getElementById(actionImg).src = imgSrc;