aboutsummaryrefslogtreecommitdiffstats
path: root/Resources/friendship
diff options
context:
space:
mode:
Diffstat (limited to 'Resources/friendship')
-rw-r--r--Resources/friendship/core/FacebookFQL.js23
-rw-r--r--Resources/friendship/ui/ApplicationWindow.js8
-rw-r--r--Resources/friendship/ui/FriendSelector.js11
-rw-r--r--Resources/friendship/ui/LikeList.js28
-rw-r--r--Resources/friendship/ui/LoginWindow.js2
5 files changed, 46 insertions, 26 deletions
diff --git a/Resources/friendship/core/FacebookFQL.js b/Resources/friendship/core/FacebookFQL.js
index 1c6f217..823e86f 100644
--- a/Resources/friendship/core/FacebookFQL.js
+++ b/Resources/friendship/core/FacebookFQL.js
@@ -1,41 +1,54 @@
(function() {
fs.core.queryFQL = function(fqlQuery, fqlCallback) {
var fqlURL = "fql?q=" + fqlQuery.replace(/ /g, "+");
- Ti.API.info("https://graph.facebook.com/" + fqlURL);
+ //Ti.API.info("https://graph.facebook.com/" + fqlURL);
Ti.Facebook.requestWithGraphPath(fqlURL, {}, 'GET', fqlCallback);
};
fs.core.handleFQLResponse = function(response, eventName) {
if (response.success) {
+ //Ti.API.info(eventName + ": FQL response: got " + response.result.length + " Bytes");
+ if (response.result.length < 100) {
+ //Ti.API.info("> " + response.result);
+ }
var data = JSON.parse(response.result);
- Ti.API.fireEvent(eventName, {data: data});
+ //Ti.API.info(eventName + ": FQL response: parsed " + data.length + " entries");
+ Ti.App.fireEvent(eventName, {data: data});
} else if (response.error) {
- Ti.API.fireEvent("processFQLError", {what: response.error});
+ //Ti.API.info(eventName + ": FQL response error: " + response.error);
+ Ti.App.fireEvent("processFQLError", {what: response.error});
} else {
- Ti.API.fireEvent("processFQLError", {what: "unrecognized query response"});
+ //Ti.API.info(eventName + ": FQL response error: UNKNOWN");
+ Ti.App.fireEvent("processFQLError", {what: "unrecognized query response"});
}
}; // LATER: find some way to handle timeout (via Ti.Facebook....)
fs.core.handleFriendIDsFQLResponse = function (result) { fs.core.handleFQLResponse(result, "processFriendIDs"); };
fs.core.queryFriendIDsFQL = function() {
+ ////Ti.API.info("calling queryFriendIDsFQL");
var query = "SELECT uid, name, pic_square FROM user WHERE uid IN (SELECT uid2 FROM friend WHERE uid1 = " + Ti.Facebook.uid + ")"
Ti.Facebook.request('fql.query', {query: query}, fs.core.handleFriendIDsFQLResponse);
};
fs.core.handleLikeIDsFQLResponse = function (result) { fs.core.handleFQLResponse(result, "processLikeIDs"); };
fs.core.queryLikeIDsFQL = function(friend_ids) {
+ //Ti.API.info("calling queryLikeIDsFQL:");
var query = "SELECT page_id, created_time, uid FROM page_fan WHERE uid IN (" + friend_ids.join() + ")";
+ //Ti.API.info(query);
Ti.Facebook.request('fql.query', {query: query}, fs.core.handleLikeIDsFQLResponse);
};
fs.core.handleAllFriendLikeIDsFQLResponse = function (result) { fs.core.handleFQLResponse(result, "processLikeIDs"); };
fs.core.queryAllFriendLikeIDsFQL = function() {
+ //Ti.API.info("calling queryAllFriendLikeIDsFQL");
var query = "SELECT page_id, created_time, uid FROM page_fan WHERE uid IN (SELECT uid2 FROM friend WHERE uid1 = " + Ti.Facebook.uid + ")";
Ti.Facebook.request('fql.query', {query: query}, fs.core.handleAllFriendLikeIDsFQLResponse);
};
fs.core.handleLikesFQLResponse = function (result) { fs.core.handleFQLResponse(result, "processLikes"); };
fs.core.queryLikesFQL = function(page_ids) {
+ //Ti.API.info("calling queryLikesFQL");
+
//var query = "SELECT page_id, name, description, page_url, pic_square, fan_count, type, website, general_info ";
//query += "FROM page WHERE page_id ";
//query += "IN (SELECT page_id FROM page_fan WHERE uid ";
@@ -48,10 +61,12 @@
fs.core.fetchMoreLikes = function(numLikesMore) {
numLikesMore = Math.min((fs.data.reverseChronoLikedIDs.length - fs.data.numLikesFetched), numLikesMore);
+ //Ti.API.info("calling fetchMoreLikes: fetching more = " + numLikesMore + ", currently have: " + fs.data.numLikesFetched + ", total: " + fs.data.reverseChronoLikedIDs.length);
page_ids = Array();
for (var i = fs.data.numLikesFetched; i < fs.data.numLikesFetched + numLikesMore; i++) {
page_ids.push(fs.data.reverseChronoLikedIDs[i].pid);
}
fs.core.queryLikesFQL(page_ids);
};
+
})();
diff --git a/Resources/friendship/ui/ApplicationWindow.js b/Resources/friendship/ui/ApplicationWindow.js
index 067969a..85809a0 100644
--- a/Resources/friendship/ui/ApplicationWindow.js
+++ b/Resources/friendship/ui/ApplicationWindow.js
@@ -8,7 +8,7 @@
image: 'images/refresh.png',
height: 5
});
- refresh_button.addEventListener('click', fs.ui.refreshAllFriendsLikeList);
+ refresh_button.addEventListener('click', fs.ui.refreshFilteredLikeList);
var friend_selector_button = fs.ui.friendSelectorButton();
@@ -30,17 +30,17 @@
win.add(fs.ui.createLikeList());
- Ti.API.addEventListener("processFQLError", function(e) {
+ Ti.App.addEventListener("processFQLError", function(e) {
alert(e.what);
});
- Ti.API.addEventListener("refreshAllData", function(e) {
+ Ti.App.addEventListener("refreshAllData", function(e) {
if (Ti.Facebook.loggedIn) {
Ti.App.fireEvent('app:show.loader');
fs.core.queryFriendIDsFQL();
}
})
- Ti.API.fireEvent("refreshAllData");
+ Ti.App.fireEvent("refreshAllData");
tab_group.addTab(tab);
diff --git a/Resources/friendship/ui/FriendSelector.js b/Resources/friendship/ui/FriendSelector.js
index 62ba42d..47114db 100644
--- a/Resources/friendship/ui/FriendSelector.js
+++ b/Resources/friendship/ui/FriendSelector.js
@@ -25,16 +25,7 @@
});
done_button.addEventListener('click', function() {
- var friend_ids = Array();
- for (key in fs.data.friends) {
- if (fs.data.friends[key].selected) {
- friend_ids.push(fs.data.friends[key].uid);
- }
- }
- if (friend_ids.length > 0) {
- fs.ui.refreshLikeList(friend_ids);
- }
-
+ fs.ui.refreshFilteredLikeList();
win.close();
});
diff --git a/Resources/friendship/ui/LikeList.js b/Resources/friendship/ui/LikeList.js
index 9e7f872..227972d 100644
--- a/Resources/friendship/ui/LikeList.js
+++ b/Resources/friendship/ui/LikeList.js
@@ -68,7 +68,7 @@
url: key.page_url
}));
});
-
+
var profile_icon = Ti.UI.createImageView({
image:key.pic_square,
width:50,
@@ -206,7 +206,8 @@
//Ti.App.fireEvent('app:show.loader');
- Ti.API.addEventListener("processFriendIDs", function(e) {
+ Ti.App.addEventListener("processFriendIDs", function(e) {
+ //Ti.API.info("processFriendIDs callback");
fs.data.friends = Array();
for (var i = 0; i < e.data.length; i++) {
fs.data.friends[e.data[i].uid.toString()] = {uid: e.data[i].uid, pic: e.data[i].pic_square, name: e.data[i].name, selected: true};
@@ -215,7 +216,8 @@
fs.core.queryAllFriendLikeIDsFQL();
});
- Ti.API.addEventListener("processLikeIDs", function(e) {
+ Ti.App.addEventListener("processLikeIDs", function(e) {
+ //Ti.API.info("processLikeIDs callback");
fs.data.likeIDs = Array();
fs.data.reverseChronoLikedIDs = Array();
@@ -260,14 +262,14 @@
fs.core.fetchMoreLikes(fs.data.NUM_LIKES_PER_FETCH);
} else {
fs.data.isQueryingMore = false;
- ll_view.footerTitle = "0 / 0 loaded";
+ ll_view.footerTitle = "loading failed";
Ti.App.fireEvent('app:hide.loader');
}
});
- Ti.API.addEventListener("processLikes", function(e) {
+ Ti.App.addEventListener("processLikes", function(e) {
+ //Ti.API.info("processLikes callback");
for ( key in e.data ) {
-
e.data[key].more = fs.data.reverseChronoLikedIDs[fs.data.numLikesFetched];
e.data[key].friend_name = friend_name_from_uid(e.data[key].more.uid);
fs.data.numLikesFetched++;
@@ -304,10 +306,22 @@
}
};
- fs.ui.refreshLikeList = function(friend_ids) {
+ fs.ui.refreshLikeList = function(friend_ids) { // called by fs.ui.refreshFilteredLikeList; do not call directly unless you know friend_ids
if (Ti.Facebook.loggedIn) {
Ti.App.fireEvent('app:show.loader');
fs.core.queryLikeIDsFQL(friend_ids);
}
};
+
+ fs.ui.refreshFilteredLikeList = function() {
+ var friend_ids = Array();
+ for (key in fs.data.friends) {
+ if (fs.data.friends[key].selected) {
+ friend_ids.push(fs.data.friends[key].uid);
+ }
+ }
+ if (friend_ids.length > 0) {
+ fs.ui.refreshLikeList(friend_ids);
+ }
+ };
})();
diff --git a/Resources/friendship/ui/LoginWindow.js b/Resources/friendship/ui/LoginWindow.js
index 4a48c64..569aaac 100644
--- a/Resources/friendship/ui/LoginWindow.js
+++ b/Resources/friendship/ui/LoginWindow.js
@@ -6,7 +6,7 @@
Ti.Facebook.addEventListener('login', function(e) {
if (e.success) {
fs.app.mainTabGroup.open();
- Ti.API.fireEvent("refreshAllData");
+ Ti.App.fireEvent("refreshAllData");
} else {
alert('Could not log into Facebook');
}