Fixed a number of Matrix datatable problems.

This commit is contained in:
Yung Han Khoe 2008-11-21 02:53:53 +00:00
parent 19b8a90139
commit 36d4013dff
5 changed files with 174 additions and 27 deletions

View file

@ -28,7 +28,7 @@ YAHOO.util.Event.addListener(window, "load", function() {
this.myDataSource.connXhrMode = "queueRequests";
this.myDataSource.responseSchema = {
resultsList: "ResultSet.Result",
fields: columnKeys
fields: responseFields
};
var uri = "func=getCompareListData";
@ -42,6 +42,7 @@ YAHOO.util.Event.addListener(window, "load", function() {
this.myDataSource.doBeforeParseData = function (oRequest, oFullResponse) {
myDataTable.getRecordSet().reset();
myDataTable.refreshView();
var existingColumns = myDataTable.getColumnSet().keys;
for (var i = 0; i < existingColumns.length; i++) {
if(i > 1){
@ -66,12 +67,6 @@ YAHOO.util.Event.addListener(window, "load", function() {
this.onDataReturnAppendRows.apply(this,arguments);
};
var myCallback2 = function() {
this.set("sortedBy", null);
this.onDataReturnAppendRows.apply(this,arguments);
};
var callback2 = {
success : myCallback,
failure : myCallback,
@ -81,12 +76,10 @@ YAHOO.util.Event.addListener(window, "load", function() {
var btnCompare = new YAHOO.widget.Button("compare",{disabled:true,id:"compareButton"});
btnCompare.on("click", function(e) {
var uri = "func=getCompareListData";
for (var i = 0; i < columnKeys.length; i++) {
if(columnKeys[i] != 'name'){
var checkBox = new Dom.get(columnKeys[i] + '_checkBox');
if(checkBox.checked == true){
uri = uri+';listingId='+columnKeys[i];
}
var compareCheckBoxes = YAHOO.util.Dom.getElementsByClassName('compareCheckBox','input');
for (var i = compareCheckBoxes.length; i--; ) {
if(compareCheckBoxes[i].checked == true){
uri = uri+';listingId='+compareCheckBoxes[i].value;
}
}
this.myDataSource.sendRequest(uri,callback2);

View file

@ -0,0 +1,89 @@
YAHOO.util.Event.addListener(window, "load", function() {
YAHOO.example.XHR_JSON = new function() {
var Dom = YAHOO.util.Dom;
var hideStickies = 0;
this.formatStickied = function(elCell, oRecord, oColumn, sData) {
elCell.innerHTML = "<input type='checkBox' class='stickieCheckbox' id='" + oRecord.getData("attributeId") + "_stickied'>";
};
var myColumnDefs = [
{key:"stickied",formatter:this.formatStickied},
{key:"label"},
{key:"value"}
];
this.myDataSource = new YAHOO.util.DataSource("?");
this.myDataSource.responseType = YAHOO.util.DataSource.TYPE_JSON;
this.myDataSource.connXhrMode = "queueRequests";
this.myDataSource.responseSchema = {
resultsList: "ResultSet.Result",
fields: ["label","value","attributeId"]
};
var uri = "func=getAttributes";
// for (var i = 0; i < listingIds.length; i++) {
// uri = uri+';listingId='+listingIds[i];
// }
var myDataTable = new YAHOO.widget.DataTable("attributes", myColumnDefs,
this.myDataSource, {initialRequest:uri});
this.myDataSource.doBeforeParseData = function (oRequest, oFullResponse) {
myDataTable.getRecordSet().reset();
return oFullResponse;
}
var myCallback = function() {
this.set("sortedBy", null);
this.onDataReturnAppendRows.apply(this,arguments);
};
var myCallback2 = function() {
this.set("sortedBy", null);
this.onDataReturnAppendRows.apply(this,arguments);
};
var callback2 = {
success : myCallback,
failure : myCallback,
scope : myDataTable
};
var btnStickied = new YAHOO.widget.Button("stickied");
btnStickied.on("click", function(e) {
var elements = myDataTable.getRecordSet().getRecords();
if(hideStickies == 0){
// hide non-selected attributes
for(i=0; i<elements.length; i++){
var attributeId = elements[i].getData('attributeId');
var checkBox = Dom.get(attributeId+"_stickied");
if (checkBox.checked == false){
elRow = myDataTable.getTrEl(elements[i]);
Dom.setStyle(elRow, "display", "none");
}
}
hideStickies = 1;
}else{
// show all attributes
for(i=0; i<elements.length; i++){
var attributeId = elements[i].getData('attributeId');
var checkBox = Dom.get(attributeId+"_stickied");
if (checkBox.checked == false){
elRow = myDataTable.getTrEl(elements[i]);
Dom.setStyle(elRow, "display", "table-row");
}
}
hideStickies = 0;
}
},this,true);
};
});

View file

@ -57,16 +57,9 @@ YAHOO.util.Event.addListener(window, "load", function() {
for (var i = attributeSelects.length; i--; ) {
newUri = newUri + ';search_' + attributeSelects[i].id + '=' + attributeSelects[i].value;
}
var elements = myDataTable.getRecordSet().getRecords();
for(i=0; i<elements.length; i++){
elRow = myDataTable.getTrEl(elements[i]);
Dom.setStyle(elRow, "display", "none");
}
var compareCheckBoxes = YAHOO.util.Dom.getElementsByClassName('compareCheckBox','input');
for (var i = compareCheckBoxes.length; i--; ) {
compareCheckBoxes[i].checked = false;
}
myDataTable.getRecordSet().deleteRecord(0,elements.length);
myDataTable.getRecordSet().reset();
myDataTable.refreshView();
myDataSource.sendRequest(newUri,callback2);
}