[fusion-commits] r2766 - in trunk: layers/MapGuide lib

svn_fusion at osgeo.org svn_fusion at osgeo.org
Tue Aug 13 07:45:25 PDT 2013


Author: jng
Date: 2013-08-13 07:45:25 -0700 (Tue, 13 Aug 2013)
New Revision: 2766

Modified:
   trunk/layers/MapGuide/MapGuide.js
   trunk/lib/MGBroker.js
Log:
Use DESCRIBERUNTIMEMAP for rebuilding the legend if supported. Like CREATERUNTIMEMAP, DESCRIBERUNTIMEMAP bypasses the LoadMap.php/LoadScaleRanges.php chain for reloading a map's layer/group structure

Modified: trunk/layers/MapGuide/MapGuide.js
===================================================================
--- trunk/layers/MapGuide/MapGuide.js	2013-08-09 06:49:50 UTC (rev 2765)
+++ trunk/layers/MapGuide/MapGuide.js	2013-08-13 14:45:25 UTC (rev 2766)
@@ -670,17 +670,27 @@
         var oldLayers = $A(this.aLayers);
         this.aLayers = [];
 
-        var sl = Fusion.getScriptLanguage();
-        var loadmapScript = 'layers/' + this.arch + '/' + sl  + '/LoadMap.' + sl;
+        if (this.bUseNativeServices) {
+            var features = (1 | 2 | 4); //We want the whole lot
+            var r = new Fusion.Lib.MGRequest.MGDescribeRuntimeMap(this._sMapname, features, 25);
+            r.setParams({
+                iconFormat: "GIF",
+                session: this.getSessionID()
+            });
+            Fusion.oBroker.dispatchRequest(r, OpenLayers.Function.bind(this.onRuntimeMapReloaded, this, oldLayers));
+        } else {
+            var sl = Fusion.getScriptLanguage();
+            var loadmapScript = 'layers/' + this.arch + '/' + sl  + '/LoadMap.' + sl;
 
-        var sessionid = this.getSessionID();
+            var sessionid = this.getSessionID();
 
-        var params = {'mapname': this._sMapname, 'session': sessionid};
-        var options = {
-              onSuccess: OpenLayers.Function.bind(this.mapReloaded,this,oldLayers),
-              onException: OpenLayers.Function.bind(this.reloadFailed, this),
-              parameters: params};
-        Fusion.ajaxRequest(loadmapScript, options);
+            var params = {'mapname': this._sMapname, 'session': sessionid};
+            var options = {
+                  onSuccess: OpenLayers.Function.bind(this.mapReloaded,this,oldLayers),
+                  onException: OpenLayers.Function.bind(this.reloadFailed, this),
+                  parameters: params};
+            Fusion.ajaxRequest(loadmapScript, options);
+        }
     },
 
     reloadFailed: function(r) {
@@ -747,6 +757,31 @@
         }
     },
     
+    onRuntimeMapReloaded: function(oldLayers, r) {
+        if (r.status == 200) {
+            var json = Fusion.parseJSON(r.responseText);
+            var co = this.convertResponse(json);
+            var o = co.LoadMap;
+            this.parseMapLayersAndGroups(o);
+            //Need to wait for the right event to trigger loadScaleRanges, so stash our
+            //prepared result for when it comes
+            this._initScaleRanges = co.LoadScaleRanges;
+            for (var i=0; i<this.aLayers.length; ++i) {
+              var newLayer = this.aLayers[i];
+              for (var j=0; j<oldLayers.length; ++j){
+                if (oldLayers[j].uniqueId == newLayer.uniqueId) {
+                  newLayer.selectedFeatureCount = oldLayers[j].selectedFeatureCount;
+                  newLayer.noCache = oldLayers[j].noCache;
+                  break;
+                }
+              }
+            }
+            this.mapWidget.triggerEvent(Fusion.Event.MAP_RELOADED);
+            this.drawMap();
+        }
+        this.mapWidget._removeWorker();
+    },
+    
 //TBD: this function not yet converted for OL
     mapReloaded: function(oldLayers,r) {
         if (r.status == 200) {

Modified: trunk/lib/MGBroker.js
===================================================================
--- trunk/lib/MGBroker.js	2013-08-09 06:49:50 UTC (rev 2765)
+++ trunk/lib/MGBroker.js	2013-08-13 14:45:25 UTC (rev 2766)
@@ -344,6 +344,35 @@
 });
 
 /****************************************************************************
+ * Class: Fusion.Lib.MGRequest.MGDescribeRuntimeMap
+ *
+ * encapsulate a request to the server to create a new runtime map (and session if required)
+ * on the server
+ *
+ * Inherits from:
+ *  - <Fusion.Lib.MGRequest>
+ */
+Fusion.Lib.MGRequest.MGDescribeRuntimeMap = OpenLayers.Class(Fusion.Lib.MGRequest, {
+    /**
+     * Constructor: Fusion.Lib.MGRequest.MGCreateRuntimeMap
+     * 
+     * initialize a new instance of Fusion.Lib.MGRequest.MGCreateRuntimeMap
+     */
+    initialize: function(mapName, features, iconsPerScaleRange) {
+        this.initializeRequest();
+        this.setParams({
+            operation: "DESCRIBERUNTIMEMAP",
+            mapname: mapName,
+            requestedfeatures: features,
+            iconsperscalerange: iconsPerScaleRange,
+            format: "application/json",
+            version: "2.6.0"
+        });
+    }
+});
+
+
+/****************************************************************************
  * Class: Fusion.Lib.MGRequest.MGCopyResource
  *
  * encapsulate a request to the server to copy a resource.



More information about the fusion-commits mailing list