<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Maps in Container Dijits in ArcGIS JavaScript Maps SDK Questions</title>
    <link>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/maps-in-container-dijits/m-p/436141#M40159</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;Kind of a follow up to this old post:&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;A href="http://forums.esri.com/Thread.asp?c=158&amp;amp;f=2396&amp;amp;t=277953" rel="nofollow noopener noreferrer" target="_blank"&gt;http://forums.esri.com/Thread.asp?c=158&amp;amp;f=2396&amp;amp;t=277953&lt;/A&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Instead of a hard coded map size, I have a full map.&amp;nbsp; My problem has to do with the browser resize.&amp;nbsp; The active tab is based on a passed argument and the active tab's map is initialized with the dojo connect resize that you see in the samples.&amp;nbsp; The initial map's resizing works fine.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;function initMap(map) {
 switch (map) {
&amp;nbsp; case "daily":
&amp;nbsp;&amp;nbsp; dailyMap = new esri.Map("dailyMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; dailyMap.addLayer(streets);
&amp;nbsp;&amp;nbsp; var dailyResizeTimer;
&amp;nbsp;&amp;nbsp; dojo.connect(dailyMap, 'onLoad', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp; dojo.connect(dijit.byId('dailyMapDiv'), 'resize', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; clearTimeout(dailyResizeTimer);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dailyResizeTimer = setTimeout(function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dailyMap.resize();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dailyMap.reposition();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }, 500);
&amp;nbsp;&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; break;

&amp;nbsp; case "monthly":
&amp;nbsp;&amp;nbsp; monthlyMap = new esri.Map("monthlyMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; monthlyMap.addLayer(satellite);
&amp;nbsp;&amp;nbsp; var monthlyResizeTimer;
&amp;nbsp;&amp;nbsp; dojo.connect(monthlyMap, 'onLoad', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp; dojo.connect(dijit.byId('monthlyMapDiv'), 'resize', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; clearTimeout(monthlyResizeTimer);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; monthlyResizeTimer = setTimeout(function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; monthlyMap.resize();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; monthlyMap.reposition();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }, 500);
&amp;nbsp;&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; break;

&amp;nbsp; default:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; resisMap = new esri.Map("resisMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; resisMap.addLayer(topo);
&amp;nbsp;&amp;nbsp; var resisResizeTimer;
&amp;nbsp;&amp;nbsp; dojo.connect(resisMap, 'onLoad', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp; dojo.connect(dijit.byId('resisMapDiv'), 'resize', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; clearTimeout(resisResizeTimer);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; resisResizeTimer = setTimeout(function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; resisMap.resize();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; resisMap.reposition();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }, 500);
&amp;nbsp;&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; });
 }
}&lt;/PRE&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;When another tab is selected, the new map is initialized, but the dojo.connect doesn't get fired and thus map resizing doesn't work.&amp;nbsp; Do I need to remove the old 'onload' from the first map even though it is a separate object?&amp;nbsp; Am even I able to do this?&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Thanks,&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Glen&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Sat, 11 Dec 2021 19:32:35 GMT</pubDate>
    <dc:creator>GlenReid</dc:creator>
    <dc:date>2021-12-11T19:32:35Z</dc:date>
    <item>
      <title>Maps in Container Dijits</title>
      <link>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/maps-in-container-dijits/m-p/436141#M40159</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;Kind of a follow up to this old post:&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;A href="http://forums.esri.com/Thread.asp?c=158&amp;amp;f=2396&amp;amp;t=277953" rel="nofollow noopener noreferrer" target="_blank"&gt;http://forums.esri.com/Thread.asp?c=158&amp;amp;f=2396&amp;amp;t=277953&lt;/A&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Instead of a hard coded map size, I have a full map.&amp;nbsp; My problem has to do with the browser resize.&amp;nbsp; The active tab is based on a passed argument and the active tab's map is initialized with the dojo connect resize that you see in the samples.&amp;nbsp; The initial map's resizing works fine.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;function initMap(map) {
 switch (map) {
&amp;nbsp; case "daily":
&amp;nbsp;&amp;nbsp; dailyMap = new esri.Map("dailyMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; dailyMap.addLayer(streets);
&amp;nbsp;&amp;nbsp; var dailyResizeTimer;
&amp;nbsp;&amp;nbsp; dojo.connect(dailyMap, 'onLoad', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp; dojo.connect(dijit.byId('dailyMapDiv'), 'resize', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; clearTimeout(dailyResizeTimer);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dailyResizeTimer = setTimeout(function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dailyMap.resize();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dailyMap.reposition();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }, 500);
&amp;nbsp;&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; break;

&amp;nbsp; case "monthly":
&amp;nbsp;&amp;nbsp; monthlyMap = new esri.Map("monthlyMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; monthlyMap.addLayer(satellite);
&amp;nbsp;&amp;nbsp; var monthlyResizeTimer;
&amp;nbsp;&amp;nbsp; dojo.connect(monthlyMap, 'onLoad', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp; dojo.connect(dijit.byId('monthlyMapDiv'), 'resize', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; clearTimeout(monthlyResizeTimer);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; monthlyResizeTimer = setTimeout(function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; monthlyMap.resize();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; monthlyMap.reposition();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }, 500);
&amp;nbsp;&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; break;

&amp;nbsp; default:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; resisMap = new esri.Map("resisMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; resisMap.addLayer(topo);
&amp;nbsp;&amp;nbsp; var resisResizeTimer;
&amp;nbsp;&amp;nbsp; dojo.connect(resisMap, 'onLoad', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp; dojo.connect(dijit.byId('resisMapDiv'), 'resize', function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; clearTimeout(resisResizeTimer);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; resisResizeTimer = setTimeout(function() {
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; resisMap.resize();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; resisMap.reposition();
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }, 500);
&amp;nbsp;&amp;nbsp;&amp;nbsp; });
&amp;nbsp;&amp;nbsp; });
 }
}&lt;/PRE&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;When another tab is selected, the new map is initialized, but the dojo.connect doesn't get fired and thus map resizing doesn't work.&amp;nbsp; Do I need to remove the old 'onload' from the first map even though it is a separate object?&amp;nbsp; Am even I able to do this?&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Thanks,&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;Glen&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 11 Dec 2021 19:32:35 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/maps-in-container-dijits/m-p/436141#M40159</guid>
      <dc:creator>GlenReid</dc:creator>
      <dc:date>2021-12-11T19:32:35Z</dc:date>
    </item>
    <item>
      <title>Re: Maps in Container Dijits</title>
      <link>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/maps-in-container-dijits/m-p/436142#M40160</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;you might try the disconnect, see if that helps. i think you maybe able to consolidate your functions some...&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;this is rough, and untested... but hopefully it will give you an idea....&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;
function initMap(map){
 var rTimer;
 var dijitID;

 if(mapLoad){
&amp;nbsp; dojo.disconnect(mapLoad);
&amp;nbsp; dojo.disconnect(con);
 }

 switch(map){
&amp;nbsp; case 'daily':
&amp;nbsp;&amp;nbsp; dijitID = 'dailyMapDiv';
&amp;nbsp;&amp;nbsp; newMap = new esri.Map("dailyMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; newMap.addLayer(streets);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; break;

&amp;nbsp; case 'monthly':
&amp;nbsp;&amp;nbsp; dijitID='monthlyMapDiv';
&amp;nbsp;&amp;nbsp; newMap = new esri.Map("monthlyMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; newMap.addLayer(satellite);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; break;

&amp;nbsp; default:
&amp;nbsp;&amp;nbsp; dijitID='rsisMapDiv';
&amp;nbsp;&amp;nbsp; newMap = new esri.Map("resisMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; newMap.addLayer(topo);
 }

 var mapLoad = dojo.connect(newMap,'onLoad',function(){
&amp;nbsp; var con = dijit.byId(dijitID),'resize',function(){
&amp;nbsp;&amp;nbsp; clearTimeout(rTimer);
&amp;nbsp;&amp;nbsp; rTimer = setTimeout(function(){
&amp;nbsp;&amp;nbsp;&amp;nbsp; newMap.resize();
&amp;nbsp;&amp;nbsp;&amp;nbsp; newMap.reposition();
&amp;nbsp;&amp;nbsp; },500);
&amp;nbsp; });
 });
}
&lt;/PRE&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;so if the connection exsists (mapLoad) it dojo disconnects it and the resize connection.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;heh.. hrm.. gotta go see if i have the correct syntax for the disconnect. but i think it is right.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;yeah. its correct. &lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;also, if you want to keep all seperate functions for the different maps, you could add the disconnect as the last line of code to execute in each connection.&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 11 Dec 2021 19:32:37 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/maps-in-container-dijits/m-p/436142#M40160</guid>
      <dc:creator>timgogl</dc:creator>
      <dc:date>2021-12-11T19:32:37Z</dc:date>
    </item>
    <item>
      <title>Re: Maps in Container Dijits</title>
      <link>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/maps-in-container-dijits/m-p/436143#M40161</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;Thanks for the suggestion.&amp;nbsp; I took your code and tweaked it a little to get it working.&amp;nbsp; Like mine first example, the resize works on the initial map, but any subsequent map doesn't get into the dojo.connect for mapLoad: &lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;
var mapLoad, newMap, con;

function initMap(map){
 var rTimer;
 var dijitID;

 if (mapLoad){
&amp;nbsp; dojo.disconnect(mapLoad);
&amp;nbsp; dojo.disconnect(con);
 }

 switch(map){
&amp;nbsp; case 'daily':
&amp;nbsp;&amp;nbsp; console.log("daily");
&amp;nbsp;&amp;nbsp; dijitID = 'dailyMapDiv';
&amp;nbsp;&amp;nbsp; newMap = new esri.Map("dailyMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; newMap.addLayer(streets);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; break;

&amp;nbsp; case 'monthly':
&amp;nbsp;&amp;nbsp; console.log("monthly");
&amp;nbsp;&amp;nbsp; dijitID='monthlyMapDiv';
&amp;nbsp;&amp;nbsp; newMap = new esri.Map("monthlyMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; newMap.addLayer(satellite);
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; break;

&amp;nbsp; default:
&amp;nbsp;&amp;nbsp; console.log("resis");
&amp;nbsp;&amp;nbsp; dijitID='resisMapDiv';
&amp;nbsp;&amp;nbsp; newMap = new esri.Map("resisMapDiv", {extent:initExtent, logo:false});
&amp;nbsp;&amp;nbsp; newMap.addLayer(topo);
 }

 mapLoad = dojo.connect(newMap, 'onLoad', function(){
&amp;nbsp;&amp;nbsp; con = dojo.connect(dijit.byId(dijitID), 'resize', function() {
&amp;nbsp;&amp;nbsp; clearTimeout(rTimer);
&amp;nbsp;&amp;nbsp; rTimer = setTimeout(function(){
&amp;nbsp;&amp;nbsp;&amp;nbsp; newMap.resize();
&amp;nbsp;&amp;nbsp;&amp;nbsp; newMap.reposition();
&amp;nbsp;&amp;nbsp; },500);
&amp;nbsp; });
 });
}&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 11 Dec 2021 19:32:40 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/maps-in-container-dijits/m-p/436143#M40161</guid>
      <dc:creator>GlenReid</dc:creator>
      <dc:date>2021-12-11T19:32:40Z</dc:date>
    </item>
  </channel>
</rss>

