From 591e8c002618f3bf2ab1b030fef4faaef904c833 Mon Sep 17 00:00:00 2001 From: Sam Foster Date: Wed, 19 Oct 2011 11:45:36 +0100 Subject: [PATCH] Adding tests for sort with queryOptions, and sort method. Ensure sort details included in the sortOptions are retained in the grid.sortOrder array property --- OnDemandList.js | 4 ++++ test/test_OnDemand.html | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+) diff --git a/OnDemandList.js b/OnDemandList.js index 233fe061c..d8ea446c4 100644 --- a/OnDemandList.js +++ b/OnDemandList.js @@ -40,6 +40,10 @@ return declare([List], { // and tells it to refresh. this.query = query !== undefined ? query : this.query; this.queryOptions = queryOptions || this.queryOptions; + // stash sort details if the queryOptions included them + if(queryOptions && queryOptions.sort){ + this.sortOrder = queryOptions.sort; + } this.refresh(); }, diff --git a/test/test_OnDemand.html b/test/test_OnDemand.html index 5630ec2f5..97ea28902 100644 --- a/test/test_OnDemand.html +++ b/test/test_OnDemand.html @@ -182,6 +182,36 @@ console.log("reset query to show all"); grid.setQuery({}); }); + + var sortDescending = true; + + on(document.getElementById("setQueryWithOptions"), "click", function(){ + // set sortOrder for the col1 field + sortDescending ^= 1; // toggle true/false + + // get an existing sortOrder + var sortByCol1 = dojo.filter( + grid.sortOrder || [], + function(sortBy){ + return sortBy.attribute == "col1"; + } + ).shift(); + if(sortByCol1){ + console.log("modifying existing sortOrder for col1: ", sortByCol1); + } else { + sortByCol1 = { attribute: "col1" }; + } + sortByCol1.descending = sortDescending; + grid.setQuery(grid.query, { sort: [sortByCol1] }); + }); + on(document.getElementById("sort"), "click", function(){ + console.log("sortOrder: ", grid.sortOrder); + + sortDescending ^= 1; // toggle true/false + grid.sort("col1", sortDescending); + }); + + on(document.getElementById("empty"), "click", function(){ console.log("set store to emptyStore"); grid.setStore(emptyStore, {}); @@ -252,6 +282,8 @@

Simple test to show setting a new store and query to dgrid

+ +