New page: == Challenge == In order to keep track of real time response for a questionnaire As a system consultant I want to create a portal element showing 2 different answers of a question ... |
No edit summary |
||
Line 14: | Line 14: | ||
*Change answers after every 30 seconds | *Change answers after every 30 seconds | ||
== Code == | == Code == | ||
<source lang="javascript" line="1"> | <source lang="javascript" line="1"> | ||
var | this.nRecords = 1000; | ||
var CommentDisplay = | |||
{ | { | ||
onInit: function( | onInit: function(valueStr, element) | ||
{ | |||
CommentDisplay.comments = eval(valueStr); | |||
CommentDisplay.interval = 30000; | |||
CommentDisplay.PortalElement = element; | |||
if (typeof(CommentDisplay.comments) != 'string') | |||
CommentDisplay.removeShortComments(); | |||
}, | |||
removeShortComments: function() | |||
{ | |||
var i = 0; | |||
while(i<CommentDisplay.comments.length) | |||
{ | |||
if (CommentDisplay.comments[i][1].length <20) | |||
//remove from comemnts | |||
CommentDisplay.comments.splice(i, 1); | |||
else | |||
i = i + 1; | |||
} | |||
}, | |||
displayComment: function(i) | |||
{ | { | ||
var body = "<table width=\"100%\"><tbody>"; | |||
body = body + "<tr><td style=\"COLOR: #217afd; FONT-FAMILY: verdana; BACKGROUND-COLOR: #dbedff\">"; | |||
body = body + "<b>" + CommentDisplay.comments[i][0] + ": " + CommentDisplay.comments[i][2] + ":</b>"; | |||
body = body + "</td></tr><tr><td style=\"COLOR: #555555; FONT-FAMILY: verdana\">"; | |||
body = body + CommentDisplay.comments[i][1]; | |||
body = body + "</td></tr>"; | |||
// | body = body + "</tbody></table><br/>"; | ||
return body; | |||
}, | }, | ||
//display the comments in each interval | |||
executeInEachInterval: function() | |||
{ | { | ||
if (typeof(CommentDisplay.comments) == 'string') | |||
{ | |||
CommentDisplay.PortalElement.showComment(CommentDisplay.comments); | |||
return; | |||
} | |||
var n = CommentDisplay.comments.length - 1; | |||
if (n<0) | |||
{ | |||
CommentDisplay.PortalElement.showComment("There is no record satisfying the conditions."); | |||
return; | |||
} | |||
var index1 = Math.floor(Math.random()*n); | |||
var index2 = Math.floor(Math.random()*n); | |||
var body = "<p>"; | |||
body = body + CommentDisplay.displayComment(index1); | |||
body = body + CommentDisplay.displayComment(index2); | |||
body = body + "</p>"; | |||
CommentDisplay.PortalElement.showComment(body); | |||
setTimeout(CommentDisplay.executeInEachInterval, CommentDisplay.interval); | |||
} | } | ||
} | } | ||
var | this.onload = function() | ||
{ | |||
this.get_contentDiv().innerHTML = "Please wait..."; | |||
//retrieve data the first time | |||
this.getDCSData(); | |||
} | |||
this.getDCSData = function() | |||
{ | |||
var columns = new Array(); | |||
columns[0] = "StartDate"; | |||
columns[1] = "Q25"; | |||
columns[2] = "BankName"; | |||
var dcsId = 2755; | |||
var topN = this.nRecords; | |||
var orderByColumn = "StartDate"; | |||
var orderType = "desc"; | |||
var condition = ""; | |||
var xml = this.getCriteria(dcsId, topN, orderByColumn, orderType, condition, columns); | |||
CatGlobe.Web.DataModule.DataCache.WebService.DCSWebService.GetDCSData(xml.toString(), this.onSuccess, null, this); | |||
} | |||
this.showComment = function(value) | |||
function | |||
{ | { | ||
this.get_contentDiv().innerHTML = value; | |||
this.getManager().updateElementOrdination(); | |||
} | |||
//called when the web service method has been executed successfully | |||
this.onSuccess = function(result, userContext,methodName) | |||
var | { | ||
CommentDisplay.onInit(result, userContext); | |||
//show comment | |||
CommentDisplay.executeInEachInterval(); | |||
} | |||
for(var i= 0; i< | this.getCriteria = function(dcsId, topN, orderBy, orderType, condition, selectedColumns) | ||
{ | |||
var xml = new Document(); | |||
var root = xml.createElement("criteria"); | |||
root.setAttribute("dcs-id",dcsId); | |||
root.setAttribute("top-N", topN); | |||
root.setAttribute("order-by-column", orderBy); | |||
root.setAttribute("order-type", orderType); | |||
root.setAttribute("condition", condition); | |||
var c; | |||
for(var i=0; i<selectedColumns.length; i++) | |||
{ | { | ||
c = xml.createElement("column"); | |||
c.setAttribute("name", selectedColumns[i]); | |||
root.appendChild(c); | |||
} | } | ||
} | xml.appendChild(root); | ||
return xml; | |||
} | |||
this. | this.onerror = function(e) | ||
{ | { | ||
debugger; | |||
} | } | ||
</source> | </source> |
Revision as of 02:15, 2 January 2009
Challenge
In order to keep track of real time response for a questionnaire
As a system consultant
I want to create a portal element showing 2 different answers of a question in every 30 seconds
Solution
- Create a questionnaire cache containing data of the questionnaire
- Create a user-defined portal element with script
- Connect to registered DCS web service to retrieve the data
- Change answers after every 30 seconds
Code
this.nRecords = 1000;
var CommentDisplay =
{
onInit: function(valueStr, element)
{
CommentDisplay.comments = eval(valueStr);
CommentDisplay.interval = 30000;
CommentDisplay.PortalElement = element;
if (typeof(CommentDisplay.comments) != 'string')
CommentDisplay.removeShortComments();
},
removeShortComments: function()
{
var i = 0;
while(i<CommentDisplay.comments.length)
{
if (CommentDisplay.comments[i][1].length <20)
//remove from comemnts
CommentDisplay.comments.splice(i, 1);
else
i = i + 1;
}
},
displayComment: function(i)
{
var body = "<table width=\"100%\"><tbody>";
body = body + "<tr><td style=\"COLOR: #217afd; FONT-FAMILY: verdana; BACKGROUND-COLOR: #dbedff\">";
body = body + "<b>" + CommentDisplay.comments[i][0] + ": " + CommentDisplay.comments[i][2] + ":</b>";
body = body + "</td></tr><tr><td style=\"COLOR: #555555; FONT-FAMILY: verdana\">";
body = body + CommentDisplay.comments[i][1];
body = body + "</td></tr>";
body = body + "</tbody></table><br/>";
return body;
},
//display the comments in each interval
executeInEachInterval: function()
{
if (typeof(CommentDisplay.comments) == 'string')
{
CommentDisplay.PortalElement.showComment(CommentDisplay.comments);
return;
}
var n = CommentDisplay.comments.length - 1;
if (n<0)
{
CommentDisplay.PortalElement.showComment("There is no record satisfying the conditions.");
return;
}
var index1 = Math.floor(Math.random()*n);
var index2 = Math.floor(Math.random()*n);
var body = "<p>";
body = body + CommentDisplay.displayComment(index1);
body = body + CommentDisplay.displayComment(index2);
body = body + "</p>";
CommentDisplay.PortalElement.showComment(body);
setTimeout(CommentDisplay.executeInEachInterval, CommentDisplay.interval);
}
}
this.onload = function()
{
this.get_contentDiv().innerHTML = "Please wait...";
//retrieve data the first time
this.getDCSData();
}
this.getDCSData = function()
{
var columns = new Array();
columns[0] = "StartDate";
columns[1] = "Q25";
columns[2] = "BankName";
var dcsId = 2755;
var topN = this.nRecords;
var orderByColumn = "StartDate";
var orderType = "desc";
var condition = "";
var xml = this.getCriteria(dcsId, topN, orderByColumn, orderType, condition, columns);
CatGlobe.Web.DataModule.DataCache.WebService.DCSWebService.GetDCSData(xml.toString(), this.onSuccess, null, this);
}
this.showComment = function(value)
{
this.get_contentDiv().innerHTML = value;
this.getManager().updateElementOrdination();
}
//called when the web service method has been executed successfully
this.onSuccess = function(result, userContext,methodName)
{
CommentDisplay.onInit(result, userContext);
//show comment
CommentDisplay.executeInEachInterval();
}
this.getCriteria = function(dcsId, topN, orderBy, orderType, condition, selectedColumns)
{
var xml = new Document();
var root = xml.createElement("criteria");
root.setAttribute("dcs-id",dcsId);
root.setAttribute("top-N", topN);
root.setAttribute("order-by-column", orderBy);
root.setAttribute("order-type", orderType);
root.setAttribute("condition", condition);
var c;
for(var i=0; i<selectedColumns.length; i++)
{
c = xml.createElement("column");
c.setAttribute("name", selectedColumns[i]);
root.appendChild(c);
}
xml.appendChild(root);
return xml;
}
this.onerror = function(e)
{
debugger;
}