3 @author: Sudheer K. <scifi1947 at gmail.com>
4 @license: GNU General Public License
9 function reloadQuotes(){
10 var query = getQuery();
12 quoteRefreshStarted();
13 logUtility.logMessage("Reloading Data..");
15 //var queryURL = 'http://query.yahooapis.com/v1/public/yql?q=select * from yahoo.finance.quotes where symbol in ("INDU","^IXIC","^GSPC","CLJ11.NYM","YHOO","AAPL","GOOG","MSFT")&env=store://datatables.org/alltableswithkeys';
16 var queryURL = 'http://query.yahooapis.com/v1/public/yql?q=select Symbol,Name,LastTradePriceOnly,Change,ChangeinPercent,Volume,MarketCapitalization from yahoo.finance.quotes where symbol in ('+query+')&env=store://datatables.org/alltableswithkeys';
17 logUtility.logMessage(queryURL);
19 var response = new XMLHttpRequest();
20 response.onreadystatechange = function() {
21 if (response.readyState == XMLHttpRequest.DONE) {
22 var success = refreshDataModel(response);
23 if (success === true){
24 logUtility.logMessage("Data Reload Completed..");
27 logUtility.logMessage("Data Reload Failed..");
29 quoteRefreshCompleted(success,strErrorMessage);
33 response.open("GET", queryURL);
37 logUtility.logMessage("No stock symbols found in configuration.");
39 strErrorMessage = "Tap the title bar to add stock tickers and update settings."
41 strErrorMessage = "Use the widget settings screen to add stock tickers and update configuration."
42 stockQuoteDataModel.clear();
43 quoteRefreshCompleted(false,strErrorMessage);
49 var symbolsArray = DBUtility.getAllSymbols();
50 if (symbolsArray && symbolsArray.length > 0){
52 for (i = 0; i< symbolsArray.length; i++) {
53 logUtility.logMessage("Appending "+symbolsArray[i]+ " to Query");
56 query = '"'+symbolsArray[i]+'"';
59 query = query + ',"' + symbolsArray[i]+'"';
67 function reloadNews(){
68 if (!rssURL || rssURL == "Unknown") {
69 logUtility.logMessage("Invalid RSS URL: "+rssURL);
72 logUtility.logMessage("Reloading news from "+rssURL);
73 //var queryURL = "http://finance.yahoo.com/rss/topfinstories";
74 logUtility.logMessage(rssURL);
75 var response = new XMLHttpRequest();
76 response.onreadystatechange = function() {
77 if (response.readyState == XMLHttpRequest.DONE) {
78 var success = refreshNewsModel(response);
79 if (success === true){
80 logUtility.logMessage("News Reload Completed..");
83 logUtility.logMessage("News Reload Failed..");
85 newsReloadCompleted(success,strErrorMessage);
89 response.open("GET", rssURL);
94 function refreshDataModel(response){
96 if (!response.responseXML) {
97 //This shouldn't happen
98 strErrorMessage = "Error occurred while loading stock quotes."
99 if (response.responseText)
100 logUtility.logMessage(response.responseText);
102 logUtility.logMessage("No responseXML for quotes");
106 var xmlDoc = response.responseXML.documentElement;
107 var results = xmlDoc.firstChild;
109 //Not the best code I ever wrote, but got no choice
110 //Refer to Memory leak issue with XMLListModel --> http://bugreports.qt.nokia.com/browse/QTBUG-15191
113 var quoteNodes = results.childNodes;
114 if (quoteNodes && quoteNodes.length > 0){
115 logUtility.logMessage("Clearing Data Model");
116 stockQuoteDataModel.clear();
119 for (i = 0; i < quoteNodes.length; i++) {
121 var quoteElements = quoteNodes[i].childNodes;
123 var symbol,stockName,lastTradedPrice,change,changePercentage,volume,marketCap
125 for (j = 0; j < quoteElements.length; j++){
127 switch (quoteElements[j].nodeName){
129 symbol = quoteElements[j].childNodes[0].nodeValue;
132 stockName = quoteElements[j].childNodes[0].nodeValue;
134 case 'LastTradePriceOnly':
135 lastTradedPrice = quoteElements[j].childNodes[0].nodeValue;
138 change = (quoteElements[j].childNodes[0])? quoteElements[j].childNodes[0].nodeValue:"";
140 case 'ChangeinPercent':
141 changePercentage = (quoteElements[j].childNodes[0])? quoteElements[j].childNodes[0].nodeValue:"";
144 volume = (quoteElements[j].childNodes[0])? quoteElements[j].childNodes[0].nodeValue:"";
146 case 'MarketCapitalization':
147 marketCap = (quoteElements[j].childNodes[0])? quoteElements[j].childNodes[0].nodeValue:"";
152 stockQuoteDataModel.append({"symbol":symbol,"stockName":stockName,"lastTradedPrice":lastTradedPrice,"change":change,"changePercentage":changePercentage,"volume":volume,"marketCap":marketCap});
153 //logUtility.logMessage("Symbol: "+stockQuoteDataModel.get(i).symbol+", Name: "+ stockQuoteDataModel.get(i).stockName+", LastTraded: "+stockQuoteDataModel.get(i).lastTradedPrice+", Change: "+stockQuoteDataModel.get(i).change+", ChangePercent: "+stockQuoteDataModel.get(i).changePercentage+", Volume: "+stockQuoteDataModel.get(i).volume+", MarketCap: "+stockQuoteDataModel.get(i).marketCap);
154 logUtility.logMessage(stockQuoteDataModel.get(i).symbol+", "+stockQuoteDataModel.get(i).lastTradedPrice+", "+stockQuoteDataModel.get(i).change+", "+stockQuoteDataModel.get(i).changePercentage+", "+stockQuoteDataModel.get(i).volume+", "+stockQuoteDataModel.get(i).marketCap);
161 strErrorMessage = "Quotes could not be fetched from Yahoo! Finance. Please verify the tickers and try again later."
162 logUtility.logMessage(response.responseText);
167 strErrorMessage = "Stock quote data from Yahoo! Finance is currently not available. Please try again later."
168 logUtility.logMessage(response.responseText);
173 var queryNode = xmlDoc;
176 var queryAttributes = queryNode.attributes;
177 for (i = 0; i < queryAttributes.length; i++) {
178 if (queryAttributes[i].name == 'created') {
179 lastUpdatedTimeStamp = "Updated: "+DateLib.ISODate.format(queryAttributes[i].value);
180 logUtility.logMessage(lastUpdatedTimeStamp);
189 function refreshNewsModel(response){
191 if (!response.responseXML) {
192 //This shouldn't happen
193 strErrorMessage = "Error occurred while loading news."
194 if (response.responseText)
195 logUtility.logMessage(response.responseText);
197 logUtility.logMessage("No responseXML for news");
201 //Not the best code I ever wrote, but got no choice
202 //Refer to Memory leak issue with XMLListModel --> http://bugreports.qt.nokia.com/browse/QTBUG-15191
205 var xmlDoc = response.responseXML.documentElement;
206 //var channel = xmlDoc.firstChild; Doesn't work with some RSS providers. THANK YOU, YAHOO
211 for (i = 0; i < xmlDoc.childNodes.length; i++){
212 if (xmlDoc.childNodes[i].nodeName === 'channel') {
213 channel = xmlDoc.childNodes[i];
219 var itemNodes = channel.childNodes;
222 logUtility.logMessage("Clearing News Model");
223 newsDataModel.clear();
224 logUtility.logMessage("No. of news stories = "+itemNodes.length);
226 for (i = 0; i < itemNodes.length; i++) {
227 if (itemNodes[i].nodeName === 'item'){
228 var newsElements = itemNodes[i].childNodes;
230 var newsTitle,newsLink
231 for (j = 0; j < newsElements.length; j++){
233 switch (newsElements[j].nodeName){
235 newsTitle = newsElements[j].childNodes[0].nodeValue;
238 newsLink = newsElements[j].childNodes[0].nodeValue;
243 newsDataModel.append({"title":newsTitle,"link":newsLink});
244 //logUtility.logMessage("Title: "+newsDataModel.get(i).title+", Link: "+ newsDataModel.get(i).link);
245 //logUtility.logMessage("Title: "+newsTitle+", Link: "+ newsLink);
251 strErrorMessage = "The RSS feed did not contain any news stories. Please try again later."
252 logUtility.logMessage(response.responseText);
257 strErrorMessage = "The RSS feed did not return valid data. Please check the URL and try again later."
258 logUtility.logMessage(response.responseText);
265 function loadSettings(){
267 value = DBUtility.getSetting("UpdateFreqency");
268 if (!value || value == "0.0" || value === "" || isNaN(value)){
269 autoUpdateInterval = 0;
272 autoUpdateInterval = parseInt(value)*60*1000; //Convert minutes to milliseconds
274 value = DBUtility.getSetting("UpdateWeekdaysOnly");
275 if (!value || value == "0.0" || value === ""){
276 updateWeekDaysOnly = false;
279 updateWeekDaysOnly = true;
283 value = DBUtility.getSetting("UpdateOnSavedNetworksOnly");
284 if (!value || value == "0.0" || value === ""){
285 updateOnSavedNetworksOnly = false;
288 updateOnSavedNetworksOnly = true;
292 value = DBUtility.getSetting("RSSURL");
293 if (!value || value == "Unknown" || value === ""){
296 else if (value === 'http://finance.yahoo.com/rss/topstories'){
298 Yahoo changed their Top New rss feed from http://finance.yahoo.com/rss/topstories to http://finance.yahoo.com/rss/topfinstories.
299 Since the application has a hardcoded default rss feed, it is better to update it here. Not sure if this is the best way to deal with such changes.
302 rssURL = "http://finance.yahoo.com/rss/topfinstories";
303 DBUtility.setSetting("RSSURL",rssURL);
311 function initialize(){
312 if (autoUpdateTimer.running) autoUpdateTimer.stop();
317 if (autoUpdateInterval !== 0) {
318 logUtility.logMessage("Starting Timer..");
319 autoUpdateTimer.start();