Toggle menu
862
3.8K
30.2K
279.1K
Catglobe Wiki
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

Display a questionnaire's answers in real time: Difference between revisions

From Catglobe Wiki
Line 14: Line 14:
*Create a user-defined portal element with script
*Create a user-defined portal element with script
*Connect to registered DCS web service to retrieve the data:
*Connect to registered DCS web service to retrieve the data:
**<source lang="javascript">CatGlobe.Web.DataModule.DataCache.WebService.DCSWebService.GetDCSData(condition, onSuccessFunction, onFailFunction, element_context);</source>
**CatGlobe.Web.DataModule.DataCache.WebService.DCSWebService.GetDCSData(condition, onSuccessFunction, onFailFunction, element_context);
**The condition xml should follow the format of:
**The condition xml should follow the format of:
<source lang="xml" line="0">
<source lang="xml" line="0">
Line 24: Line 24:
</source>
</source>
*Change answers after every 30 seconds:
*Change answers after every 30 seconds:
**<source lang="javascript">setTimeout(function_to_execute, interval)</source>
**setTimeout(function_to_execute, interval)


== Code  ==
== Code  ==

Revision as of 02:35, 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:
    • CatGlobe.Web.DataModule.DataCache.WebService.DCSWebService.GetDCSData(condition, onSuccessFunction, onFailFunction, element_context);
    • The condition xml should follow the format of:
<criteria dcs-id="1" top-N="1000" order-by-column="StartDate" order-type="desc">
<column name="StartDate"></column>
<column name="Q25"></column>
<column name="BankName"></column>
</criteria>
  • Change answers after every 30 seconds:
    • setTimeout(function_to_execute, interval)

Code

The below code is the old version, it could be enhanced using jQuery

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;
}