More Matrix bugfixes

This commit is contained in:
Yung Han Khoe 2008-12-07 13:10:08 +00:00
parent 931b502666
commit 8ba4f6ef70
6 changed files with 54 additions and 22 deletions

View file

@ -361,7 +361,8 @@ sub getCompareForm {
$maxComparisons = $self->get('maxComparisonsPrivileged'); $maxComparisons = $self->get('maxComparisonsPrivileged');
} }
$form .= "\n<script type='text/javascript'>\n". $form .= "\n<script type='text/javascript'>\n".
'var maxComparisons = '.$maxComparisons.';'. 'var maxComparisons = '.$maxComparisons.";\n".
"var matrixUrl = '".$self->getUrl."';\n".
"\n</script>\n"; "\n</script>\n";
return $form; return $form;
} }
@ -674,6 +675,7 @@ sub www_compare {
'var listingIds = new Array('.join(", ",map {'"'.$_.'"'} @listingIds).");\n". 'var listingIds = new Array('.join(", ",map {'"'.$_.'"'} @listingIds).");\n".
'var responseFields = new Array("attributeId", "name", "fieldType", "checked", '.join(", ",map {'"'.$_.'"'} @responseFields).");\n". 'var responseFields = new Array("attributeId", "name", "fieldType", "checked", '.join(", ",map {'"'.$_.'"'} @responseFields).");\n".
"var maxComparisons = ".$maxComparisons.";\n". "var maxComparisons = ".$maxComparisons.";\n".
"var matrixUrl = '".$self->getUrl."';\n".
"</script>"; "</script>";
return $self->processStyle($self->processTemplate($var,$self->get("compareTemplateId"))); return $self->processStyle($self->processTemplate($var,$self->get("compareTemplateId")));
@ -903,12 +905,12 @@ sub www_getCompareFormData {
my $session = $self->session; my $session = $self->session;
my $form = $session->form; my $form = $session->form;
my $sort = shift || $session->scratch->get('matrixSort') || $self->get('defaultSort'); my $sort = shift || $session->scratch->get('matrixSort') || $self->get('defaultSort');
my $sortDirection = ' asc'; my $sortDirection = ' desc';
=cut
if ( WebGUI::Utility::isIn($sort, qw(revisionDate score)) ) { if ( WebGUI::Utility::isIn($sort, qw(revisionDate score)) ) {
$sortDirection = " desc"; $sortDirection = " desc";
} }
=cut
my @results; my @results;
my @listingIds = $self->session->form->checkList("listingId"); my @listingIds = $self->session->form->checkList("listingId");
@ -983,7 +985,7 @@ assetData.revisionDate
} }
} }
$result->{assetId} =~ s/-/_____/g; $result->{assetId} =~ s/-/_____/g;
$result->{url} = "/".$result->{url}; $result->{url} = $session->url->gateway($result->{url});
} }
my $jsonOutput; my $jsonOutput;

View file

@ -22,13 +22,13 @@ YAHOO.util.Event.addListener(window, "load", function() {
]; ];
var uri = "func=getCompareFormData"; var uri = "func=getCompareFormData";
if(typeof(listingIds) != 'undefined'){ if(typeof(listingIds) != 'undefined'){
for (var i = 0; i < listingIds.length; i++) { for (var i = 0; i < listingIds.length; i++) {
uri = uri+';listingId='+listingIds[i]; uri = uri+';listingId='+listingIds[i];
} }
} }
this.myDataSource = new YAHOO.util.DataSource("?"); this.myDataSource = new YAHOO.util.DataSource(matrixUrl + "?");
this.myDataSource.responseType = YAHOO.util.DataSource.TYPE_JSON; this.myDataSource.responseType = YAHOO.util.DataSource.TYPE_JSON;
this.myDataSource.connXhrMode = "queueRequests"; this.myDataSource.connXhrMode = "queueRequests";
this.myDataSource.responseSchema = { this.myDataSource.responseSchema = {
@ -47,25 +47,25 @@ YAHOO.util.Event.addListener(window, "load", function() {
var btnSortByViews = new YAHOO.widget.Button("sortByViews"); var btnSortByViews = new YAHOO.widget.Button("sortByViews");
btnSortByViews.on("click", function(e) { btnSortByViews.on("click", function(e) {
this.myDataTable.sortColumn(this.myDataTable.getColumn(2)); this.myDataTable.sortColumn(this.myDataTable.getColumn(2));
var request = YAHOO.util.Connect.asyncRequest('POST', "?func=setSort;sort=views"); var request = YAHOO.util.Connect.asyncRequest('POST', matrixUrl + "?func=setSort;sort=views");
},this,true); },this,true);
var btnSortByClicks = new YAHOO.widget.Button("sortByClicks"); var btnSortByClicks = new YAHOO.widget.Button("sortByClicks");
btnSortByClicks.on("click", function(e) { btnSortByClicks.on("click", function(e) {
this.myDataTable.sortColumn(this.myDataTable.getColumn(3)); this.myDataTable.sortColumn(this.myDataTable.getColumn(3));
var request = YAHOO.util.Connect.asyncRequest('POST', "?func=setSort;sort=clicks"); var request = YAHOO.util.Connect.asyncRequest('POST', matrixUrl + "?func=setSort;sort=clicks");
},this,true); },this,true);
var btnSortByCompares = new YAHOO.widget.Button("sortByCompares"); var btnSortByCompares = new YAHOO.widget.Button("sortByCompares");
btnSortByCompares.on("click", function(e) { btnSortByCompares.on("click", function(e) {
this.myDataTable.sortColumn(this.myDataTable.getColumn(4)); this.myDataTable.sortColumn(this.myDataTable.getColumn(4));
var request = YAHOO.util.Connect.asyncRequest('POST', "?func=setSort;sort=compares"); var request = YAHOO.util.Connect.asyncRequest('POST', matrixUrl + "?func=setSort;sort=compares");
},this,true); },this,true);
var btnSortByUpdated = new YAHOO.widget.Button("sortByUpdated"); var btnSortByUpdated = new YAHOO.widget.Button("sortByUpdated");
btnSortByUpdated.on("click", function(e) { btnSortByUpdated.on("click", function(e) {
this.myDataTable.sortColumn(this.myDataTable.getColumn(5)); this.myDataTable.sortColumn(this.myDataTable.getColumn(5));
var request = YAHOO.util.Connect.asyncRequest('POST', "?func=setSort;sort=lastUpdated"); var request = YAHOO.util.Connect.asyncRequest('POST', matrixUrl + "?func=setSort;sort=lastUpdated");
},this,true); },this,true);
var myCallback = function() { var myCallback = function() {
@ -77,6 +77,15 @@ YAHOO.util.Event.addListener(window, "load", function() {
btnCompare.on("click", function(e) { btnCompare.on("click", function(e) {
window.document.forms['doCompare'].submit(); window.document.forms['doCompare'].submit();
},this,true); },this,true);
var btnCompare2 = new YAHOO.widget.Button("compare2",{disabled:true,id:"compareButton2"});
btnCompare2.on("click", function(e) {
window.document.forms['doCompare'].submit();
},this,true);
var btnSearch = new YAHOO.widget.Button("search");
btnSearch.on("click", function(e) {
window.location.href = matrixUrl + '?func=search';
},this,true);
window.compareDataTable = this.myDataTable; window.compareDataTable = this.myDataTable;
@ -92,8 +101,10 @@ YAHOO.util.Event.addListener(window, "load", function() {
} }
if (checked > 1 && checked < maxComparisons){ if (checked > 1 && checked < maxComparisons){
btnCompare.set("disabled",false); btnCompare.set("disabled",false);
btnCompare2.set("disabled",false);
}else{ }else{
btnCompare.set("disabled",true); btnCompare.set("disabled",true);
btnCompare2.set("disabled",true);
} }
var elements = window.compareDataTable.getRecordSet().getRecords(); var elements = window.compareDataTable.getRecordSet().getRecords();
for(j=0; j<elements.length; j++){ for(j=0; j<elements.length; j++){

View file

@ -89,10 +89,13 @@ YAHOO.util.Event.addListener(window, "load", function() {
scope : myDataTable scope : myDataTable
}; };
var btnCompare = new YAHOO.widget.Button("compare",{disabled:true,id:"compareButton"}); var btnCompare = new YAHOO.widget.Button("compare",{disabled:true,id:"compareButton"});
btnCompare.on("click", function(e) { btnCompare.on("click", function(e) {
var uri = "func=getCompareListData";
var compareCheckBoxes = YAHOO.util.Dom.getElementsByClassName('compareCheckBox','input'); var compareCheckBoxes = YAHOO.util.Dom.getElementsByClassName('compareCheckBox','input');
var uri = "func=getCompareListData";
for (var i = compareCheckBoxes.length; i--; ) { for (var i = compareCheckBoxes.length; i--; ) {
if(compareCheckBoxes[i].checked == true){ if(compareCheckBoxes[i].checked == true){
uri = uri+';listingId='+compareCheckBoxes[i].value; uri = uri+';listingId='+compareCheckBoxes[i].value;
@ -101,6 +104,23 @@ YAHOO.util.Event.addListener(window, "load", function() {
this.myDataSource.sendRequest(uri,callback2); this.myDataSource.sendRequest(uri,callback2);
},this,true); },this,true);
var btnCompare2 = new YAHOO.widget.Button("compare2",{disabled:true,id:"compareButton2"});
btnCompare2.on("click", function(e) {
var compareCheckBoxes = YAHOO.util.Dom.getElementsByClassName('compareCheckBox','input');
var uri = "func=getCompareListData";
for (var i = compareCheckBoxes.length; i--; ) {
if(compareCheckBoxes[i].checked == true){
uri = uri+';listingId='+compareCheckBoxes[i].value;
}
}
this.myDataSource.sendRequest(uri,callback2);
},this,true);
var btnSearch = new YAHOO.widget.Button("search");
btnSearch.on("click", function(e) {
window.location.href = matrixUrl + '?func=search';
},this,true);
window.compareFormButton = function() { window.compareFormButton = function() {
var compareCheckBoxes = YAHOO.util.Dom.getElementsByClassName('compareCheckBox','input'); var compareCheckBoxes = YAHOO.util.Dom.getElementsByClassName('compareCheckBox','input');
var checked = 0; var checked = 0;
@ -111,8 +131,10 @@ YAHOO.util.Event.addListener(window, "load", function() {
} }
if (checked > 1 && checked < maxComparisons){ if (checked > 1 && checked < maxComparisons){
btnCompare.set("disabled",false); btnCompare.set("disabled",false);
btnCompare2.set("disabled",false);
}else{ }else{
btnCompare.set("disabled",true); btnCompare.set("disabled",true);
btnCompare2.set("disabled",true);
} }
} }

View file

@ -16,10 +16,7 @@ YAHOO.util.Event.addListener(window, "load", function() {
var myColumnDefs = [ var myColumnDefs = [
{key:"assetId",label:"",sortable:false, formatter:this.formatCheckBox}, {key:"assetId",label:"",sortable:false, formatter:this.formatCheckBox},
{key:"title", label:"Name", sortable:true, formatter:this.formatUrl}, {key:"title", label:"Name", sortable:true, formatter:this.formatUrl}
{key:"views", sortable:true},
{key:"clicks", sortable:true},
{key:"compares", sortable:true}
]; ];
var uri = "func=getCompareFormData"; var uri = "func=getCompareFormData";
@ -34,7 +31,7 @@ YAHOO.util.Event.addListener(window, "load", function() {
this.myDataSource.connXhrMode = "queueRequests"; this.myDataSource.connXhrMode = "queueRequests";
this.myDataSource.responseSchema = { this.myDataSource.responseSchema = {
resultsList: "ResultSet.Result", resultsList: "ResultSet.Result",
fields: ["title","views","clicks","compares","checked","url","assetId"] fields: ["title","checked","url","assetId"]
}; };
var myDataTable = new YAHOO.widget.DataTable("compareForm", myColumnDefs, var myDataTable = new YAHOO.widget.DataTable("compareForm", myColumnDefs,