SuperX-Kernmodul
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

159 lines
5.0 KiB

/*
Copyright (c) 2004-2006, The Dojo Foundation
All Rights Reserved.
Licensed under the Academic Free License version 2.1 or above OR the
modified BSD license. For more information on Dojo licensing, see:
http://dojotoolkit.org/community/licensing.shtml
*/
dojo.require("dojo.widget.Chart");
dojo.require("dojo.widget.SortableTable");
function ChartBindingHack(div, resultSet, attributeMapping) {
this._div = div;
this._resultSet = resultSet;
this._attributeMapping = attributeMapping;
resultSet.addObserver(this);
this.redisplayWidget();
};
ChartBindingHack.prototype.redisplayWidget = function() {
this._div.innerHTML = this.getHtmlString();
var parser = new dojo.xml.Parse();
var frag = parser.parseElement(this._div, null, true);
dojo.widget.getParser().createComponents(frag);
};
ChartBindingHack.prototype.observedObjectHasChanged = function() {
this.redisplayWidget();
};
ChartBindingHack.prototype.getHtmlString = function() {
var arrayOfItems = this._resultSet.toArray();
var map = this._attributeMapping;
var arrayOfStrings = [];
arrayOfStrings.push('<div dojoType="chart" style="border:1px solid black;width:420px;background-color:#ededde;">');
arrayOfStrings.push(' <table ');
arrayOfStrings.push(' width="420" ');
arrayOfStrings.push(' height="200" ');
arrayOfStrings.push(' padding="24" ');
arrayOfStrings.push(' plotType="line" ');
arrayOfStrings.push(' axisAt="0 0" ');
arrayOfStrings.push(' rangeX="-50 50" ');
arrayOfStrings.push(' rangeY="-50 50" >');
arrayOfStrings.push(' <thead>');
arrayOfStrings.push(' <tr>');
arrayOfStrings.push(' <th>' + map.x + '</th>');
for (var i in map.plots) {
var plot = map.plots[i];
var plotType = plot["plotType"];
var y = plot["y"];
var size = plot["size"];
var plotTypeString = '';
if (plotType) {
plotTypeString = ' plotType="' + plotType + '"';
}
arrayOfStrings.push(' <th' + plotTypeString + '>' + y + '</th>');
}
arrayOfStrings.push(' </tr>');
arrayOfStrings.push(' </thead>');
arrayOfStrings.push(' <tbody>');
for (var i in arrayOfItems) {
var item = arrayOfItems[i];
var rowString = ' <tr>';
rowString += '<td>' + item.get(map.x) + '</td>';
for (var j in map.plots) {
var plot = map.plots[j];
var plotType = plot["plotType"];
var y = plot["y"];
var size = plot["size"];
if (plotType == "bubble") {
rowString += '<td size="' + item.get(size) + '">' + item.get(y) + '</td>';
} else {
rowString += '<td>' + item.get(y) + '</td>';
}
}
rowString += '</tr>';
arrayOfStrings.push(rowString);
}
arrayOfStrings.push(' </tbody>');
arrayOfStrings.push(' </table>');
arrayOfStrings.push('</div>');
var returnString = arrayOfStrings.join('\n');
return returnString;
};
// =======================================================================
function TableBindingHack(div, resultSet, attributeMapping) {
this._div = div;
this._resultSet = resultSet;
this._attributeMapping = attributeMapping;
resultSet.addObserver(this);
this.redisplayWidget();
};
TableBindingHack.prototype.redisplayWidget = function() {
this._div.innerHTML = this.getHtmlString();
var parser = new dojo.xml.Parse();
var frag = parser.parseElement(this._div, null, true);
dojo.widget.getParser().createComponents(frag);
};
TableBindingHack.prototype.observedObjectHasChanged = function() {
this.redisplayWidget();
};
TableBindingHack.prototype.getHtmlString = function() {
var dataProvider = this._resultSet.getDataProvider();
var arrayOfItems = this._resultSet.toArray();
var arrayOfStrings = [];
arrayOfStrings.push('<table dojoType="SortableTable" enableAlternateRows="true" cellpadding="0" cellspacing="0">');
arrayOfStrings.push(' <thead>');
arrayOfStrings.push(' <tr>');
var map = this._attributeMapping;
for (var i in map) {
var attributeId = map[i];
var attribute = dataProvider.getAttribute(attributeId);
var dataTypeString = "Number"; // default is "Number" -- SortableTable also supports "String" and "Date"
var type = attribute.get('type');
if (type) {
dataTypeString = type;
}
var nameString = attributeId;
var name = attribute.getName();
if (name) {
nameString = name;
}
arrayOfStrings.push(' <td field="' + attributeId + '" dataType="' + dataTypeString + '">' + nameString + '</td>');
}
// <td field="Id" dataType="Number">Id</td>');
// <td field="Name" dataType="String">Name</td>
// <td field="DateAdded" dataType="Date">Date Added</td>
// <td field="DateModified" dataType="Date" format="#MMM #d, #yyyy">Date Modified</td>
// <td>Label</td>
arrayOfStrings.push(' </tr>');
arrayOfStrings.push(' </thead>');
arrayOfStrings.push(' <tbody>');
for (var i in arrayOfItems) {
var item = arrayOfItems[i];
var rowString = ' <tr>';
for (var j in map) {
var attributeId = map[j];
rowString += '<td>' + item.get(attributeId) + '</td>';
}
rowString += '</tr>';
arrayOfStrings.push(rowString);
}
arrayOfStrings.push(' </tbody>');
arrayOfStrings.push('</table>');
var returnString = arrayOfStrings.join('\n');
return returnString;
};