summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarten Hogeweg2012-06-24 10:36:44 -0700
committerMarten Hogeweg2012-06-24 10:36:44 -0700
commit4c3e57b70afc79390b7d6e7d95c2a98da7aefe26 (patch)
treee4c227f45c1a5ceccba3525b27bba2e9f18413f7
Initial commit
-rw-r--r--config/config.js51
-rw-r--r--css/960.css776
-rw-r--r--css/common.css1497
-rw-r--r--css/ie9.css3
-rw-r--r--css/reset.css102
-rw-r--r--css/themes.css260
-rw-r--r--esri_mapgallery.info9
-rw-r--r--esri_mapgallery.install44
-rw-r--r--esri_mapgallery.module161
-rw-r--r--gallery.tpl.php98
-rw-r--r--images/ui/activeLink.pngbin0 -> 183 bytes
-rw-r--r--images/ui/ajax-loader.gifbin0 -> 1737 bytes
-rw-r--r--images/ui/banner.pngbin0 -> 86072 bytes
-rw-r--r--images/ui/bluepoint-21x25.pngbin0 -> 2097 bytes
-rw-r--r--images/ui/contentBG.jpgbin0 -> 1202 bytes
-rw-r--r--images/ui/dataLayers.jpgbin0 -> 1232 bytes
-rw-r--r--images/ui/external.pngbin0 -> 1054 bytes
-rw-r--r--images/ui/footerBG.jpgbin0 -> 1153 bytes
-rw-r--r--images/ui/logoBorder.jpgbin0 -> 1123 bytes
-rw-r--r--images/ui/logoBorderRTL.jpgbin0 -> 1123 bytes
-rw-r--r--images/ui/uiSprite.gifbin0 -> 2427 bytes
-rw-r--r--images/ui/uiSprite.pngbin0 -> 3212 bytes
-rw-r--r--javascript/about/layout.js122
-rw-r--r--javascript/common.js984
-rw-r--r--javascript/djConfig.js22
-rw-r--r--javascript/home/layout.js504
-rw-r--r--javascript/map/layout.js905
-rw-r--r--nls/template.js77
28 files changed, 5615 insertions, 0 deletions
diff --git a/config/config.js b/config/config.js
new file mode 100644
index 0000000..c140849
--- /dev/null
+++ b/config/config.js
@@ -0,0 +1,51 @@
+var configOptions = {
+ "group":"92595b371efa47e49c1b6c5c216c11bc",
+ "appid":"",
+ "theme":"blueTheme",
+ "siteTitle":"My Gallery",
+ "siteBannerImage":"",
+ "mapTitle":"",
+ "mapSnippet":"",
+ "mapItemDescription":"",
+ "homeHeading":"",
+ "homeSnippet":"",
+ "homeSideHeading":"Description",
+ "homeSideContent":"",
+ "footerHeading":"",
+ "footerDescription":"",
+ "footerLogo":"",
+ "footerLogoUrl":"",
+ "addThisProfileId":"xa-4f3bf72958320e9e",
+ "defaultLayout":"grid",
+ "sortField":"modified",
+ "sortOrder":"desc",
+ "searchType":"Web Map",
+ "mapViewer":"simple",
+ "galleryItemsPerPage":9,
+ "showProfileUrl":true,
+ "showAboutPage":true,
+ "showSocialButtons":true,
+ "showFooter":true,
+ "showBasemapGallery":true,
+ "showGroupSearch":true,
+ "showMapSearch":true,
+ "showLayerToggle":true,
+ "showLayoutSwitch":true,
+ "showOverviewMap":true,
+ "showMoreInfo":true,
+ "showPagination":true,
+ "showExplorerButton":true,
+ "showArcGISOnlineButton":true,
+ "showMobileButtons":true,
+ "openGalleryItemsNewWindow":false,
+ "bingMapsKey":"",
+ "proxyUrl":"",
+ "locatorserviceurl":"http://tasks.arcgis.com/ArcGIS/rest/services/WorldLocator/GeocodeServer/",
+ "geometryserviceurl":"http://tasks.arcgisonline.com/ArcGIS/rest/services/Geometry/GeometryServer",
+ "sharingurl":"http://www.arcgis.com/sharing/rest/content/items",
+ "portalUrl":"http://www.arcgis.com/",
+ "mobilePortalUrl":"arcgis://www.arcgis.com/",
+ "iosAppUrl":"itms://itunes.apple.com/us/app/arcgis/id379687930?mt=8",
+ "androidAppUrl":"https://market.android.com/details?id=com.esri.android.client",
+ "pointGraphic":"images/ui/bluepoint-21x25.png"
+}; \ No newline at end of file
diff --git a/css/960.css b/css/960.css
new file mode 100644
index 0000000..eaafafe
--- /dev/null
+++ b/css/960.css
@@ -0,0 +1,776 @@
+body {
+ min-width:960px;
+}
+.container_12, .container_16 {
+ margin-left:auto;
+ margin-right:auto;
+ width:960px;
+}
+.grid_1, .grid_2, .grid_3, .grid_4, .grid_5, .grid_6, .grid_7, .grid_8, .grid_9, .grid_10, .grid_11, .grid_12, .grid_13, .grid_14, .grid_15, .grid_16 {
+ display:inline;
+ float:left;
+ margin-left:10px;
+ margin-right:10px;
+}
+.esriRtl .grid_1, .esriRtl .grid_2, .esriRtl .grid_3, .esriRtl .grid_4, .esriRtl .grid_5, .esriRtl .grid_6, .esriRtl .grid_7, .esriRtl .grid_8, .esriRtl .grid_9, .esriRtl .grid_10, .esriRtl .grid_11, .esriRtl .grid_12, .esriRtl .grid_13, .esriRtl .grid_14, .esriRtl .grid_15, .esriRtl .grid_16 {
+ float: right;
+}
+.push_1, .pull_1, .push_2, .pull_2, .push_3, .pull_3, .push_4, .pull_4, .push_5, .pull_5, .push_6, .pull_6, .push_7, .pull_7, .push_8, .pull_8, .push_9, .pull_9, .push_10, .pull_10, .push_11, .pull_11, .push_12, .pull_12, .push_13, .pull_13, .push_14, .pull_14, .push_15, .pull_15 {
+ position:relative;
+}
+.container_12 .grid_3, .container_16 .grid_4 {
+ width:220px;
+}
+.container_12 .grid_6, .container_16 .grid_8 {
+ width:460px;
+}
+.container_12 .grid_9, .container_16 .grid_12 {
+ width:700px;
+}
+.container_12 .grid_12, .container_16 .grid_16 {
+ width:940px;
+}
+.alpha {
+ margin-left:0;
+}
+.omega {
+ margin-right:0;
+}
+.esriRtl .alpha {
+ margin-left:10px;
+ margin-right:0;
+}
+.esriRtl .omega {
+ margin-right:10px;
+ margin-left:0;
+}
+.sigma {
+ margin-left:0;
+ margin-right:0;
+}
+.container_12 .grid_1 {
+ width:60px;
+}
+.container_12 .grid_2 {
+ width:140px;
+}
+.container_12 .grid_4 {
+ width:300px;
+}
+.container_12 .grid_5 {
+ width:380px;
+}
+.container_12 .grid_7 {
+ width:540px;
+}
+.container_12 .grid_8 {
+ width:620px;
+}
+.container_12 .grid_10 {
+ width:780px;
+}
+.container_12 .grid_11 {
+ width:860px;
+}
+.container_16 .grid_1 {
+ width:40px;
+}
+.container_16 .grid_2 {
+ width:100px;
+}
+.container_16 .grid_3 {
+ width:160px;
+}
+.container_16 .grid_5 {
+ width:280px;
+}
+.container_16 .grid_6 {
+ width:340px;
+}
+.container_16 .grid_7 {
+ width:400px;
+}
+.container_16 .grid_9 {
+ width:520px;
+}
+.container_16 .grid_10 {
+ width:580px;
+}
+.container_16 .grid_11 {
+ width:640px;
+}
+.container_16 .grid_13 {
+ width:760px;
+}
+.container_16 .grid_14 {
+ width:820px;
+}
+.container_16 .grid_15 {
+ width:880px;
+}
+.container_12 .prefix_3, .container_16 .prefix_4 {
+ padding-left:240px;
+}
+.container_12 .prefix_6, .container_16 .prefix_8 {
+ padding-left:480px;
+}
+.container_12 .prefix_9, .container_16 .prefix_12 {
+ padding-left:720px;
+}
+.container_12 .prefix_1 {
+ padding-left:80px;
+}
+.container_12 .prefix_2 {
+ padding-left:160px;
+}
+.container_12 .prefix_4 {
+ padding-left:320px;
+}
+.container_12 .prefix_5 {
+ padding-left:400px;
+}
+.container_12 .prefix_7 {
+ padding-left:560px;
+}
+.container_12 .prefix_8 {
+ padding-left:640px;
+}
+.container_12 .prefix_10 {
+ padding-left:800px;
+}
+.container_12 .prefix_11 {
+ padding-left:880px;
+}
+.container_16 .prefix_1 {
+ padding-left:60px;
+}
+.container_16 .prefix_2 {
+ padding-left:120px;
+}
+.container_16 .prefix_3 {
+ padding-left:180px;
+}
+.container_16 .prefix_5 {
+ padding-left:300px;
+}
+.container_16 .prefix_6 {
+ padding-left:360px;
+}
+.container_16 .prefix_7 {
+ padding-left:420px;
+}
+.container_16 .prefix_9 {
+ padding-left:540px;
+}
+.container_16 .prefix_10 {
+ padding-left:600px;
+}
+.container_16 .prefix_11 {
+ padding-left:660px;
+}
+.esriLtr.container_16 .prefix_13 {
+ padding-left:780px;
+}
+.container_16 .prefix_14 {
+ padding-left:840px;
+}
+.container_16 .prefix_15 {
+ padding-left:900px;
+}
+.container_12 .suffix_3, .container_16 .suffix_4 {
+ padding-right:240px;
+}
+.esriLtr.container_12 .suffix_6, .container_16 .suffix_8 {
+ padding-right:480px;
+}
+.container_12 .suffix_9, .container_16 .suffix_12 {
+ padding-right:720px;
+}
+.container_12 .suffix_1 {
+ padding-right:80px;
+}
+.container_12 .suffix_2 {
+ padding-right:160px;
+}
+.container_12 .suffix_4 {
+ padding-right:320px;
+}
+.container_12 .suffix_5 {
+ padding-right:400px;
+}
+.container_12 .suffix_7 {
+ padding-right:560px;
+}
+.container_12 .suffix_8 {
+ padding-right:640px;
+}
+.container_12 .suffix_10 {
+ padding-right:800px;
+}
+.container_12 .suffix_11 {
+ padding-right:880px;
+}
+.container_16 .suffix_1 {
+ padding-right:60px;
+}
+.container_16 .suffix_2 {
+ padding-right:120px;
+}
+.container_16 .suffix_3 {
+ padding-right:180px;
+}
+.container_16 .suffix_5 {
+ padding-right:300px;
+}
+.container_16 .suffix_6 {
+ padding-right:360px;
+}
+.container_16 .suffix_7 {
+ padding-right:420px;
+}
+.container_16 .suffix_9 {
+ padding-right:540px;
+}
+.container_16 .suffix_10 {
+ padding-right:600px;
+}
+.container_16 .suffix_11 {
+ padding-right:660px;
+}
+.container_16 .suffix_13 {
+ padding-right:780px;
+}
+.container_16 .suffix_14 {
+ padding-right:840px;
+}
+.container_16 .suffix_15 {
+ padding-right:900px;
+}
+.container_12 .push_3, .container_16 .push_4 {
+ left:240px;
+}
+.container_12 .push_6, .container_16 .push_8 {
+ left:480px;
+}
+.container_12 .push_9, .container_16 .push_12 {
+ left:720px;
+}
+.container_12 .push_1 {
+ left:80px;
+}
+.container_12 .push_2 {
+ left:160px;
+}
+.container_12 .push_4 {
+ left:320px;
+}
+.container_12 .push_5 {
+ left:400px;
+}
+.container_12 .push_7 {
+ left:560px;
+}
+.container_12 .push_8 {
+ left:640px;
+}
+.container_12 .push_10 {
+ left:800px;
+}
+.container_12 .push_11 {
+ left:880px;
+}
+.container_16 .push_1 {
+ left:60px;
+}
+.container_16 .push_2 {
+ left:120px;
+}
+.container_16 .push_3 {
+ left:180px;
+}
+.container_16 .push_5 {
+ left:300px;
+}
+.container_16 .push_6 {
+ left:360px;
+}
+.container_16 .push_7 {
+ left:420px;
+}
+.container_16 .push_9 {
+ left:540px;
+}
+.container_16 .push_10 {
+ left:600px;
+}
+.container_16 .push_11 {
+ left:660px;
+}
+.container_16 .push_13 {
+ left:780px;
+}
+.container_16 .push_14 {
+ left:840px;
+}
+.container_16 .push_15 {
+ left:900px;
+}
+.container_12 .pull_3, .container_16 .pull_4 {
+ left:-240px;
+}
+.container_12 .pull_6, .container_16 .pull_8 {
+ left:-480px;
+}
+.container_12 .pull_9, .container_16 .pull_12 {
+ left:-720px;
+}
+.container_12 .pull_1 {
+ left:-80px;
+}
+.container_12 .pull_2 {
+ left:-160px;
+}
+.container_12 .pull_4 {
+ left:-320px;
+}
+.container_12 .pull_5 {
+ left:-400px;
+}
+.container_12 .pull_7 {
+ left:-560px;
+}
+.container_12 .pull_8 {
+ left:-640px;
+}
+.container_12 .pull_10 {
+ left:-800px;
+}
+.container_12 .pull_11 {
+ left:-880px;
+}
+.container_16 .pull_1 {
+ left:-60px;
+}
+.container_16 .pull_2 {
+ left:-120px;
+}
+.container_16 .pull_3 {
+ left:-180px;
+}
+.container_16 .pull_5 {
+ left:-300px;
+}
+.container_16 .pull_6 {
+ left:-360px;
+}
+.container_16 .pull_7 {
+ left:-420px;
+}
+.container_16 .pull_9 {
+ left:-540px;
+}
+.container_16 .pull_10 {
+ left:-600px;
+}
+.container_16 .pull_11 {
+ left:-660px;
+}
+.container_16 .pull_13 {
+ left:-780px;
+}
+.container_16 .pull_14 {
+ left:-840px;
+}
+.container_16 .pull_15 {
+ left:-900px;
+}
+.esriRtl .container_12 .prefix_3, .esriRtl .container_16 .prefix_4 {
+ padding-right:240px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_6, .esriRtl .container_16 .prefix_8 {
+ padding-right:480px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_9, .esriRtl .container_16 .prefix_12 {
+ padding-right:720px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_1 {
+ padding-right:80px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_2 {
+ padding-right:160px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_4 {
+ padding-right:320px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_5 {
+ padding-right:400px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_7 {
+ padding-right:560px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_8 {
+ padding-right:640px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_10 {
+ padding-right:800px;
+ padding-left:0;
+}
+.esriRtl .container_12 .prefix_11 {
+ padding-right:880px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_1 {
+ padding-right:60px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_2 {
+ padding-right:120px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_3 {
+ padding-right:180px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_5 {
+ padding-right:300px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_6 {
+ padding-right:360px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_7 {
+ padding-right:420px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_9 {
+ padding-right:540px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_10 {
+ padding-right:600px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_11 {
+ padding-right:660px;
+ padding-left:0;
+}
+.esriRtl.container_16 .prefix_13 {
+ padding-right:780px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_14 {
+ padding-right:840px;
+ padding-left:0;
+}
+.esriRtl .container_16 .prefix_15 {
+ padding-right:900px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_3, .esriRtl .container_16 .suffix_4 {
+ padding-right:240px;
+ padding-left:0;
+}
+.esriRtl.container_12 .suffix_6, .esriRtl .container_16 .suffix_8 {
+ padding-right:480px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_9, .esriRtl .container_16 .suffix_12 {
+ padding-right:720px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_1 {
+ padding-right:80px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_2 {
+ padding-right:160px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_4 {
+ padding-right:320px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_5 {
+ padding-right:400px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_7 {
+ padding-right:560px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_8 {
+ padding-right:640px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_10 {
+ padding-right:800px;
+ padding-left:0;
+}
+.esriRtl .container_12 .suffix_11 {
+ padding-right:880px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_1 {
+ padding-right:60px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_2 {
+ padding-right:120px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_3 {
+ padding-right:180px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_5 {
+ padding-right:300px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_6 {
+ padding-right:360px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_7 {
+ padding-right:420px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_9 {
+ padding-right:540px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_10 {
+ padding-right:600px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_11 {
+ padding-right:660px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_13 {
+ padding-right:780px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_14 {
+ padding-right:840px;
+ padding-left:0;
+}
+.esriRtl .container_16 .suffix_15 {
+ padding-right:900px;
+ padding-left:0;
+}
+.esriRtl .container_12 .push_3, .esriRtl .container_16 .push_4 {
+ right:240px;
+ left:auto;
+}
+.esriRtl .container_12 .push_6, .esriRtl .container_16 .push_8 {
+ right:480px;
+ left:auto;
+}
+.esriRtl .container_12 .push_9, .esriRtl .container_16 .push_12 {
+ right:720px;
+ left:auto;
+}
+.esriRtl .container_12 .push_1 {
+ right:80px;
+ left:auto;
+}
+.esriRtl .container_12 .push_2 {
+ right:160px;
+ left:auto;
+}
+.esriRtl .container_12 .push_4 {
+ right:320px;
+ left:auto;
+}
+.esriRtl .container_12 .push_5 {
+ right:400px;
+ left:auto;
+}
+.esriRtl .container_12 .push_7 {
+ right:560px;
+ left:auto;
+}
+.esriRtl .container_12 .push_8 {
+ right:640px;
+ left:auto;
+}
+.esriRtl .container_12 .push_10 {
+ right:800px;
+ left:auto;
+}
+.esriRtl .container_12 .push_11 {
+ right:880px;
+ left:auto;
+}
+.esriRtl .container_16 .push_1 {
+ right:60px;
+ left:auto;
+}
+.esriRtl .container_16 .push_2 {
+ right:120px;
+ left:auto;
+}
+.esriRtl .container_16 .push_3 {
+ right:180px;
+ left:auto;
+}
+.esriRtl .container_16 .push_5 {
+ right:300px;
+ left:auto;
+}
+.esriRtl .container_16 .push_6 {
+ right:360px;
+ left:auto;
+}
+.esriRtl .container_16 .push_7 {
+ right:420px;
+ left:auto;
+}
+.esriRtl .container_16 .push_9 {
+ right:540px;
+ left:auto;
+}
+.esriRtl .container_16 .push_10 {
+ right:600px;
+ left:auto;
+}
+.esriRtl .container_16 .push_11 {
+ right:660px;
+ left:auto;
+}
+.esriRtl .container_16 .push_13 {
+ right:780px;
+ left:auto;
+}
+.esriRtl .container_16 .push_14 {
+ right:840px;
+ left:auto;
+}
+.esriRtl .container_16 .push_15 {
+ right:900px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_3, .esriRtl .container_16 .pull_4 {
+ right:-240px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_6, .esriRtl .container_16 .pull_8 {
+ right:-480px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_9, .esriRtl .container_16 .pull_12 {
+ right:-720px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_1 {
+ right:-80px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_2 {
+ right:-160px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_4 {
+ right:-320px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_5 {
+ right:-400px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_7 {
+ right:-560px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_8 {
+ right:-640px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_10 {
+ right:-800px;
+ left:auto;
+}
+.esriRtl .container_12 .pull_11 {
+ right:-880px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_1 {
+ right:-60px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_2 {
+ right:-120px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_3 {
+ right:-180px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_5 {
+ right:-300px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_6 {
+ right:-360px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_7 {
+ right:-420px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_9 {
+ right:-540px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_10 {
+ right:-600px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_11 {
+ right:-660px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_13 {
+ right:-780px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_14 {
+ right:-840px;
+ left:auto;
+}
+.esriRtl .container_16 .pull_15 {
+ right:-900px;
+ left:auto;
+}
+.clear {
+ clear:both;
+ display:block;
+ overflow:hidden;
+ visibility:hidden;
+ width:0;
+ height:0;
+}
+.clearfix:before, .clearfix:after {
+ content:'\0020';
+ display:block;
+ overflow:hidden;
+ visibility:hidden;
+ width:0;
+ height:0;
+}
+.clearfix:after {
+ clear:both;
+}
+.clearfix {
+ zoom:1;
+}
diff --git a/css/common.css b/css/common.css
new file mode 100644
index 0000000..c18a152
--- /dev/null
+++ b/css/common.css
@@ -0,0 +1,1497 @@
+/*-------------------------------------------------- */
+/* GENERAL */
+/*-------------------------------------------------- */
+html {
+ overflow-y: scroll;
+}
+html, body {
+ font-family: Verdana, Geneva, sans-serif;
+ font-size:13px;
+ letter-spacing:normal;
+ line-height:18px;
+ text-align: left;
+ outline:0;
+}
+body {
+ color:#000;
+ background-color:#E5E5E5;
+}
+.esriRtl, .esriRtl body {
+ text-align: right;
+}
+.dialogContent {
+ margin-bottom:20px;
+}
+h1 {
+ font-size:44px;
+ text-shadow: 1px 1px 1px #ffffff; /* Text shadow for newer browsers */
+ font-family:Arial, Helvetica, sans-serif;
+ font-weight: bold;
+ line-height:52px;
+ font-variant:normal;
+ color:#404040;
+ line-height:normal;
+ font-variant:normal;
+ margin-bottom:10px;
+ margin:0;
+}
+.mapPage h1 {
+ font-size:24px;
+ line-height: normal;
+}
+#homeSideHeading {
+ width:180px;
+ padding:52px 20px 0 20px;
+}
+#homeSideContent {
+ width:180px;
+ padding: 0 20px 20px 20px;
+}
+h2, h2 a {
+ font-size:24px;
+ text-shadow: 1px 1px 3px #ffffff; /* Text shadow for newer browsers */
+ font-family:Arial, Helvetica, sans-serif;
+ font-weight: bold;
+ line-height:normal;
+ font-variant:normal;
+ margin-bottom:4px;
+ padding:0;
+ margin:0;
+ line-height:normal;
+ font-variant:normal;
+ text-decoration:none;
+}
+h2 a:hover, h2 a:focus {
+ text-decoration:underline;
+}
+h3, h3 a {
+ font-size:21px;
+ text-shadow: 1px 1px 3px #ffffff; /* Text shadow for newer browsers */
+ font-family:Arial, Helvetica, sans-serif;
+ font-weight: bold;
+ line-height:normal;
+ font-variant:normal;
+ margin:15px 0 4px 0;
+ text-decoration:none;
+}
+h3 a:hover, h3 a:focus {
+ text-decoration:underline;
+}
+h4, h5, h6 {
+ padding:0;
+ margin:0;
+}
+#legendMenu h2, #aboutMenu h2 {
+ margin:0px 0px 10px 0px;
+}
+#mapLayerToggle {
+ margin:0;
+ padding:0;
+ border-collapse:collapse;
+}
+#mapLayerToggle td {
+ vertical-align:top;
+ text-align:left;
+ padding: 0 0 2px 0;
+}
+.esriRtl #mapLayerToggle td {
+ text-align: right;
+}
+#mapLayerToggle .checkColumn {
+ padding-right:4px;
+}
+.esriRtl #mapLayerToggle .checkColumn {
+ padding-right:0;
+ padding-left:4px;
+}
+#mapLayerToggle .checkColumn .toggleLayers {
+ cursor:pointer;
+}
+#mapLayerToggle label {
+ display:inline-block;
+ margin:2px 0;
+}
+.mapPage h2, .mapPage h2 a {
+ font-size:18px;
+ text-decoration:none;
+}
+.mapPage h2 a:hover, .mapPage h2 a:focus {
+ text-decoration:underline;
+}
+.mapPage h3, .mapPage h3 a {
+ font-size:16px;
+ text-decoration:none;
+}
+.mapPage h2 a:hover, .mapPage h2 a:focus {
+ text-decoration:underline;
+}
+ul {
+ list-style:none;
+}
+ol {
+ padding-left:20px;
+}
+a {
+ text-decoration:none;
+ outline:0;
+}
+a:hover, a:focus {
+ color:#000;
+ text-decoration:underline;
+}
+p {
+ margin-bottom:10px;
+}
+input[type=search] {
+ -webkit-appearance: none;
+}
+input[type="search"]::-webkit-search-decoration, input[type="search"]::-webkit-search-cancel-button {
+ display: none;
+}
+#mapLayers {
+ margin-bottom:10px;
+}
+#descriptionContent {
+ margin-bottom:10px;
+}
+/*-------------------------------------------------- */
+/* Alerts */
+/*-------------------------------------------------- */
+.alert {
+ padding:10px;
+ border: 1px solid;
+ -webkit-border-radius: 5px;
+ border-radius: 5px;
+ -moz-box-shadow: 1px 1px 3px #ccc;
+ -webkit-box-shadow: 1px 1px 3px #ccc;
+ box-shadow: 1px 1px 3px #ccc;
+}
+.info {
+ color: #00529B;
+ background-color: #e6f2f8;
+ border-color:#9fc7db;
+}
+.info a {
+ color: #00529B !important;
+ text-decoration: underline;
+}
+.success {
+ color: #4F8A10;
+ background-color: #eff7e2;
+ border-color:#adca7e;
+}
+.success a {
+ color: #4F8A10 !important;
+ text-decoration: underline;
+}
+.warning {
+ color: #9F6000;
+ background-color: #f9f1d5;
+ border-color:#d3bf70;
+}
+.warning a {
+ color: #9F6000 !important;
+ text-decoration: underline;
+}
+.error {
+ color: #D8000C;
+ background-color: #f8e1e1;
+ border-color:#e4a5a5;
+}
+.error a {
+ color: #D8000C !important;
+ text-decoration: underline;
+}
+/*-------------------------------------------------- */
+/* Header */
+/*-------------------------------------------------- */
+#header {
+ position:relative;
+ z-index:2;
+}
+#header {
+ height:75px;
+ overflow:hidden;
+ color:#000;
+ display: none;
+}
+#header .headerContainer {
+ background:url(../images/ui/banner.png) no-repeat top left;
+ _background:none;
+ height:75px;
+}
+#header ul {
+ list-style:none;
+ margin:0;
+ padding:0;
+}
+#header ul li {
+ display:block;
+ float:left;
+ margin:0;
+ padding:0;
+ background:none;
+}
+.esriRtl #header ul li {
+ float:right;
+}
+#header ul li a {
+ color:#fff;
+ font-size: 13px;
+ text-decoration:none;
+ text-align:left;
+ font-weight:bold;
+ font-family:Arial, Helvetica, sans-serif;
+ white-space:nowrap;
+ -moz-user-select: none;
+ -webkit-user-select:none;
+ user-select:none;
+ outline:0;
+ margin:0 10px;
+ padding:27px 20px 13px 20px;
+ display:inline-block;
+ line-height:35px;
+ max-height:75px;
+ overflow:hidden;
+}
+.esriRtl #header ul li a {
+ text-align: right;
+}
+#header ul li a:hover, #header ul li a:focus {
+ -webkit-transition:opacity 0.25s ease-in;
+ -moz-transition:opacity 0.25s ease-in;
+ -o-transition:opacity 0.25s ease-in;
+ transition:opacity 0.25s ease-in;
+ filter:alpha(opacity=75);
+ opacity:.75;
+}
+#header ul li .activeLink {
+ background:url(../images/ui/activeLink.png) left bottom repeat-x;
+ _background:none;
+}
+#header ul #homeItem {
+ margin:0;
+}
+#header ul #homeItem a {
+ display:inline-block;
+ background:none;
+ max-height:75px;
+ font-size:35px;
+ line-height:75px;
+ height:75px;
+ padding:0;
+ margin:0;
+ overflow:hidden;
+ text-shadow: 1px 1px 1px #000; /* Text shadow for newer browsers */
+ font-family:Arial, Helvetica, sans-serif;
+ font-weight: bold;
+ color:#fff;
+}
+#header ul #homeItem a img {
+ display:inline-block;
+ margin:0;
+ padding:0;
+ max-height:75px;
+}
+/*-------------------------------------------------- */
+/* CONTENT */
+/*-------------------------------------------------- */
+#galleryContent {
+ /* background:#e5e5e5 url(../images/ui/contentBG.jpg) repeat-x top left; */
+ background:#ffffff;
+ color:#404040;
+ min-height:550px;
+}
+#galleryContent .contentLeft {
+ padding:30px 0 50px 0;
+ position:relative;
+}
+.socialButtons {
+ margin-bottom:20px;
+ min-width: 138px;
+}
+.itemLeft {
+ float:left;
+}
+.itemRight {
+ float:right;
+}
+.esriRtl .itemLeft {
+ float:right;
+}
+.esriRtl .itemRight {
+ float:left;
+}
+/*-------------------------------------------------- */
+/* FEATURED MAPS */
+/*-------------------------------------------------- */
+#featuredMaps {
+ margin:20px 0;
+}
+.featuredLoading {
+ margin:20px 0;
+ padding-left:21px;
+ height:16px;
+ background:url(../images/ui/ajax-loader.gif) no-repeat left center;
+}
+/*-------------------------------------------------- */
+/* LAYOUT TOGGLE */
+/*-------------------------------------------------- */
+#layoutAndSearch {
+ margin: 20px 0 0 0;
+}
+.toggleLayout li {
+ float:right;
+}
+.esriRtl .toggleLayout li {
+ float:left;
+}
+.toggleLayout .active {
+ font-weight:bold;
+}
+.toggleLayout .gridView {
+ display:inline-block;
+ width:11px;
+ height:11px;
+ overflow:hidden;
+ background:url(../images/ui/uiSprite.png) no-repeat -96px 0;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -96px 0;
+}
+.toggleLayout .active .gridView {
+ background:url(../images/ui/uiSprite.png) no-repeat -128px 0;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -128px 0;
+}
+.toggleLayout .listView {
+ display:inline-block;
+ width:13px;
+ height:11px;
+ overflow:hidden;
+ background:url(../images/ui/uiSprite.png) no-repeat -112px 0;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -112px 0;
+}
+.toggleLayout .active .listView {
+ background:url(../images/ui/uiSprite.png) no-repeat -144px 0;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -144px 0;
+}
+.spinnerRemove {
+ margin:0 10px;
+ width:16px;
+ height: 26px;
+ display:block;
+}
+.loadingAjax {
+ display:inline-block;
+ vertical-align:middle;
+ cursor:default;
+ border:0;
+ width:16px;
+ height: 26px;
+ margin:0;
+ background:url(../images/ui/ajax-loader.gif) no-repeat center center;
+}
+#resetGroupSearch {
+ cursor:pointer;
+}
+#resetGroupSearch:hover, #resetGroupSearch:focus {
+ text-decoration:underline;
+}
+#groupSortOptions {
+ margin:20px 0 0 0;
+}
+/*-------------------------------------------------- */
+/* MAPS GRID */
+/*-------------------------------------------------- */
+.mapsGrid .item {
+ width:200px;
+ margin: 0 7px 20px 7px;
+ background:#fff;
+ padding:3px;
+ -webkit-border-radius: 5px;
+ border-radius: 5px;
+ -moz-box-shadow: 0px 0px 6px #ccc;
+ -webkit-box-shadow: 0px 0px 6px #ccc;
+ box-shadow: 0px 0px 6px #ccc;
+ display:block;
+ border:0;
+ text-decoration:none;
+ color:#404040;
+ outline:0;
+ cursor:pointer;
+}
+.mapsGrid .item:hover, .mapsGrid .item:focus {
+ -moz-box-shadow: 0px 0px 6px #999;
+ -webkit-box-shadow: 0px 0px 6px #999;
+ box-shadow: 0px 0px 6px #999;
+ -webkit-transition:-webkit-box-shadow 0.25s ease-in;
+ -moz-transition:-moz-box-shadow 0.25s ease-in;
+ -o-transition:box-shadow 0.25s ease-in;
+ transition:box-shadow 0.25s ease-in;
+}
+.mapsGrid .item .summaryHidden {
+ zoom:1;
+ position:absolute;
+ width:190px;
+ height:123px;
+ opacity:0;
+ -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(opacity=0)";
+ filter:alpha(opacity=0);
+ padding:5px;
+ background:#fff;
+ z-index:2;
+ display:block;
+ overflow:hidden;
+ font-size:11px;
+}
+.mapsGrid .item .summaryHidden strong {
+ display:block;
+}
+.mapsGrid .item:hover .summaryHidden, .mapsGrid .item:focus .summaryHidden {
+ -webkit-transition:opacity 0.25s ease-in;
+ -moz-transition:opacity 0.25s ease-in;
+ -o-transition:opacity 0.25s ease-in;
+ transition:opacity 0.25s ease-in;
+ opacity:.9;
+ -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(opacity=90)";
+ filter:alpha(opacity=90);
+}
+.mapsGrid .alpha .item {
+ margin-right:14px;
+ margin-left:0;
+}
+.mapsGrid .omega .item {
+ margin-right:0;
+ margin-left:14px;
+}
+.esriRtl .mapsGrid .alpha .item {
+ margin-right:0;
+ margin-left:14px;
+}
+.esriRtl .mapsGrid .omega .item {
+ margin-right:14px;
+ margin-left:0;
+}
+.mapsGrid .item .gridImg {
+ width:200px;
+ height:133px;
+ display:block;
+ overflow:hidden;
+ background:#fff url(../images/ui/ajax-loader.gif) no-repeat center center;
+ opacity:1;
+}
+.mapsGrid .item:hover .gridImg, .mapsGrid .item:focus .gridImg {
+ background-image:none;
+ opacity:0.75;
+ -webkit-transition:opacity 0.25s ease-in;
+ -moz-transition:opacity 0.25s ease-in;
+ -o-transition:opacity 0.25s ease-in;
+ transition:opacity 0.25s ease-in;
+}
+.mapsGrid .item .itemTitle {
+ display:block;
+ padding:5px;
+ width:190px;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ -o-text-overflow: ellipsis;
+ -ms-text-overflow: ellipsis;
+}
+.mapsGrid .externalLink {
+ position:relative;
+}
+.mapsGrid .externalLink .externalIcon {
+ display: block;
+ zoom:1;
+ position:absolute;
+ z-index:3;
+ top:0;
+ right:0;
+ background:#fff url(../images/ui/external.png) no-repeat top right;
+ padding: 0 0 3px 3px;
+ margin: 0;
+ width:13px;
+ height:12px;
+ overflow: hidden;
+ -webkit-border-radius: 0 0 0 3px;
+ border-radius: 0 0 0 3px;
+}
+.esriRtl .mapsGrid .externalLink .externalIcon {
+ right:auto;
+ left:0;
+ padding: 0 3px 3px 0;
+ background-position: top left;
+ -webkit-border-radius: 0 0 3px 0;
+ border-radius: 0 0 3px 0;
+}
+/*-------------------------------------------------- */
+/* MAPS LIST */
+/*-------------------------------------------------- */
+.mapsList .item {
+ background:#fff;
+ margin:0 0 10px 0;
+ padding:3px;
+ -webkit-border-radius: 5px;
+ border-radius: 5px;
+ -moz-box-shadow: 0px 0px 6px #ccc;
+ -webkit-box-shadow: 0px 0px 6px #ccc;
+ box-shadow: 0px 0px 6px #ccc;
+}
+.mapsList .item .block {
+ display:block;
+ float: left;
+ width:200px;
+ height:133px;
+ overflow:hidden;
+}
+.esriRtl .mapsList .item .block {
+ float:right;
+}
+.mapsList .externalLink .block {
+ position:relative;
+}
+.mapsList .externalLink .externalIcon {
+ display: block;
+ zoom:1;
+ position:absolute;
+ z-index:2;
+ top:0;
+ right:0;
+ background:#fff url(../images/ui/external.png) no-repeat top right;
+ padding: 0 0 3px 3px;
+ margin: 0;
+ width:13px;
+ height:12px;
+ overflow: hidden;
+ -webkit-border-radius: 0 0 0 3px;
+ border-radius: 0 0 0 3px;
+}
+.esriRtl .mapsList .externalLink .externalIcon {
+ right:auto;
+ left:0;
+ padding: 0 3px 3px 0;
+ background-position: top left;
+ -webkit-border-radius: 0 0 3px 0;
+ border-radius: 0 0 3px 0;
+}
+.mapsList .item .itemInfo {
+ float:left;
+ width:474px;
+ margin: 0 0 0 10px;
+}
+.esriRtl .mapsList .item .itemInfo {
+ float:right;
+ margin: 0 10px 0 0;
+}
+.mapsList .item .itemInfo a {
+ outline:0;
+ color:#404040;
+}
+.mapsList .item .itemInfo strong {
+ display:block;
+}
+.mapsList .item .itemInfo strong a {
+ text-decoration:none;
+}
+.mapsList .item .itemInfo p a {
+ text-decoration:underline;
+}
+.mapsList .item .itemInfo a:hover, .mapsList .item .itemInfo a:focus {
+ color:#999;
+ text-decoration:none;
+}
+.mapsList .item .itemInfo p {
+ margin:0 0 6px 0;
+}
+.mapsList .item .block img {
+ width:200px;
+ height:133px;
+ display:block;
+ overflow: hidden;
+ opacity:1;
+ background:#fff url(../images/ui/ajax-loader.gif) no-repeat center center;
+}
+.mapsList .block:hover img, .mapsList .block:focus img {
+ background-image:none;
+ opacity:.75;
+ -webkit-transition:opacity 0.25s ease-in;
+ -moz-transition:opacity 0.25s ease-in;
+ -o-transition:opacity 0.25s ease-in;
+ transition:opacity 0.25s ease-in;
+}
+.mapsList .item .itemInfo .ratingCon {
+ color:#656565;
+ font-size: 11px;
+ line-height:16px;
+ margin-bottom:5px;
+}
+.mapsList .item .itemInfo .dateInfo {
+ color:#656565;
+ font-size: 11px;
+ line-height:normal;
+}
+/*-------------------------------------------------- */
+/* DATA LAYERS */
+/*-------------------------------------------------- */
+.dataLayers {
+ background:#f1f1f1 url(../images/ui/dataLayers.jpg) repeat-x top left;
+ padding:30px 0 50px 0;
+ -moz-box-shadow: 0px 1px 10px #999;
+ -webkit-box-shadow: 0px 1px 10px #999;
+ box-shadow: 0px 1px 10px #999;
+ line-height:18px;
+ position:relative;
+}
+.dataLayers ul li {
+ margin-bottom:10px;
+}
+.dataLayers .moreInfoList {
+ margin:10px 0;
+}
+.dataLayers .moreInfoList li {
+ margin:0 0 5px 0;
+}
+.dataLayers ul li a {
+ text-decoration:none;
+}
+.dataLayers ul li a:hover, .dataLayers ul li a:focus {
+ text-decoration:underline;
+}
+.dataLayers .dataLayersButton {
+ margin:30px 0;
+}
+.dataLayers .blackText {
+ color:#000;
+}
+/*-------------------------------------------------- */
+/* SEARCH */
+/*-------------------------------------------------- */
+#mapSearch {
+ width:190px;
+}
+.searchList {
+ margin:0;
+ padding:0;
+ list-style:none;
+}
+.searchList li {
+ float:left;
+}
+.esriRtl .searchList li {
+ float:right;
+}
+.searchList .iconInput {
+ display:inline-block;
+ vertical-align:middle;
+ position:relative;
+ height:24px;
+ background:#fff;
+ border-top:1px solid #eee;
+ border-bottom:1px solid #eee;
+ -webkit-border-radius: 5px 0 0 5px;
+ border-radius:5px 0 0 5px;
+ -moz-box-shadow: 0px 0px 6px #ccc;
+ -webkit-box-shadow: 0px 0px 6px #ccc;
+ box-shadow: 0px 0px 6px #ccc;
+}
+.esriRtl .searchList .iconInput {
+ -webkit-border-radius: 0 5px 5px 0;
+ border-radius:0 5px 5px 0;
+}
+.autoCompleteOpen .iconInput {
+ -webkit-border-radius: 5px 0 0 0;
+ border-radius: 5px 0 0 0;
+}
+.esriRtl .autoCompleteOpen .iconInput {
+ -webkit-border-radius: 0 5px 0 0;
+ border-radius:0 5px 0 0;
+}
+.autoCompleteOpen #searchGoupButton {
+ -webkit-border-radius: 0 5px 0 0;
+ border-radius: 0 5px 0 0;
+}
+.esriRtl .autoCompleteOpen #searchGoupButton {
+ -webkit-border-radius: 5px 0 0 0;
+ border-radius: 5px 0 0 0;
+}
+.searchList .searchButton {
+ display:inline-block;
+ width:12px;
+ height:12px;
+ overflow:hidden;
+ background:url(../images/ui/uiSprite.png) no-repeat -82px -1px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -82px -1px;
+}
+.searchList .iconInput .iconReset {
+ display:none;
+}
+.searchList .iconInput .resetActive {
+ display:block;
+ position:absolute;
+ right:5px;
+ top:3px;
+ width:16px;
+ height:16px;
+ z-index:2;
+ overflow:hidden;
+ cursor:pointer;
+ background:url(../images/ui/uiSprite.png) no-repeat -64px 0;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -64px 0;
+}
+.esriRtl .searchList .iconInput .resetActive {
+ right:auto;
+ left:5px;
+}
+.searchList .iconInput .resetActive:hover, .searchList .iconInput .resetActive:focus {
+ opacity:0.75;
+ -webkit-transition:opacity 0.25s ease-in;
+ -moz-transition:opacity 0.25s ease-in;
+ -o-transition:opacity 0.25s ease-in;
+ transition:opacity 0.25s ease-in;
+}
+.searchList .iconInput input {
+ width:159px;
+ outline:0;
+ display:inline-block;
+ border:0;
+ border-collapse:collapse;
+ vertical-align:middle;
+ font-size:12px;
+ line-height:14px;
+ font-weight:normal;
+ margin:0;
+ padding:5px 0;
+ height:14px;
+ position:absolute;
+ left:5px;
+ top:0;
+ color:#000;
+ text-align: left;
+ background:none;
+}
+.esriRtl .searchList .iconInput input {
+ left:auto;
+ right:5px;
+ text-align: right;
+}
+
+
+/*-------------------------------------------------- */
+/* MAP TEMPLATE */
+/*-------------------------------------------------- */
+.addressContainer {
+ display:block;
+ margin: 20px 0;
+}
+#fullScreen {
+ display:block;
+ position:absolute;
+ top:10px;
+ right:10px;
+ z-index:30;
+}
+.fullScreenButton {
+ display:inline-block;
+ width:12px;
+ height:12px;
+ overflow:hidden;
+ background:url(../images/ui/uiSprite.png) no-repeat -2px -2px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -2px -2px;
+}
+#subtitle {
+ line-height:18px;
+ margin-bottom:10px;
+}
+#geoButton {
+ display:block;
+ position:absolute;
+ top:10px;
+ right:58px;
+ z-index:30;
+}
+.geoLocateButton {
+ display:inline-block;
+ width:12px;
+ height:12px;
+ overflow:hidden;
+ background:url(../images/ui/uiSprite.png) no-repeat -162px -2px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -162px -2px;
+}
+.basemapConRel {
+ position: relative;
+ z-index:31;
+}
+#basemapButton {
+ display: block;
+ float: right;
+}
+.esriRtl #basemapButton {
+ float:left;
+}
+#basemapButton.open {
+ -webkit-border-radius: 5px 5px 0 0;
+ border-radius: 5px 5px 0 0;
+ cursor: pointer !important;
+}
+#basemapGallery {
+ display: none;
+ position:absolute;
+ z-index:31;
+ background: #fff;
+ top:100%;
+ right:0;
+ width: 375px;
+ height: 350px;
+ overflow: auto;
+ padding: 10px;
+ -webkit-border-radius: 5px 0px 5px 5px;
+ border-radius: 5px 0px 5px 5px;
+ -moz-box-shadow: 1px 1px 3px #666;
+ -webkit-box-shadow: 1px 1px 3px #666;
+ box-shadow: 1px 1px 3px #666;
+}
+.esriRtl #basemapGallery {
+ right:auto;
+ left: 0;
+ -webkit-border-radius: 0 5px 5px 5px;
+ border-radius: 0 5px 5px 5px;
+}
+.basemapArrowButton {
+ display:inline-block;
+ vertical-align:text-bottom;
+ width:12px;
+ height:12px;
+ overflow:hidden;
+ margin-right:2px;
+ background:url(../images/ui/uiSprite.png) no-repeat -194px -2px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -194px -2px;
+}
+.buttonSelected .basemapArrowButton {
+ background:url(../images/ui/uiSprite.png) no-repeat -178px -2px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -178px -2px;
+}
+.esriRtl .basemapArrowButton {
+ margin-right:0;
+ margin-left:2px;
+}
+/*-------------------------------------------------- */
+/* MAP TAB MENU*/
+/*-------------------------------------------------- */
+#tabMenu {
+ margin:0 20px 20px 20px;
+}
+#tabMenu .toggleButton {
+ float:left;
+}
+.esriRtl #tabMenu .toggleButton {
+ float:right;
+}
+.tabMenu {
+ display:none;
+}
+.defaultMenu {
+ display:block;
+}
+#legendMenu, #aboutMenu {
+ position:relative;
+}
+#legendMenu .esriLegendLayerLabel {
+ font-weight:bold;
+ margin-bottom:2px;
+}
+#legendMenu .esriLegendLayer td {
+ line-height:normal;
+ vertical-align:middle;
+}
+#legendMenu .esriLegendLayer img {
+ margin-right:5px;
+}
+.esriRtl #legendMenu .esriLegendLayer img {
+ margin-right:0;
+ margin-left:5px;
+}
+/*-------------------------------------------------- */
+/* MAP */
+/*-------------------------------------------------- */
+.mapContainer {
+ background:#fff;
+ padding:3px;
+ -webkit-border-radius: 5px;
+ border-radius: 5px;
+ width: 694px;
+ height: 584px;
+ position:relative;
+}
+#map {
+ text-align: left;
+ direction: ltr;
+ width:694px;
+ height:584px;
+ position:relative;
+ background:#fff url(../images/ui/ajax-loader.gif) no-repeat center center;
+}
+#map.mapLoaded {
+ background-image:none !important;
+}
+.esriScalebar {
+ padding-left:15px;
+}
+.map .bingLogo-lg {
+ left:18px !important;
+}
+#accessInformation .credits {
+ margin:5px 0 0 0;
+ font-size:10px;
+ color:#656565;
+}
+#mapButtonCon {
+ margin:20px 0 0 0;
+}
+/*-------------------------------------------------- */
+/* MAP PAGE */
+/*-------------------------------------------------- */
+#description, #legendDiv {
+ width:180px;
+ padding: 0 20px 20px 20px;
+ zoom:1;
+}
+#mapButtons .mapButton {
+ margin-left:10px;
+}
+.esriRtl #mapButtons .mapButton {
+ margin-left:0;
+ margin-right:10px;
+}
+/*-------------------------------------------------- */
+/* BUTTONS */
+/*-------------------------------------------------- */
+.silverButton, .pagination .disabled:hover, .pagination .disabled:focus {
+ zoom: 1;
+ display:inline-block;
+ vertical-align:middle;
+ font-size:12px;
+ line-height:14px;
+ height:14px;
+ margin:0;
+ padding:6px 10px;
+ color:#5f5f5f;
+ background: #ffffff;
+ background: url();
+ background: -moz-linear-gradient(top, #ffffff 0%, #e3e3e3 50%, #c3c3c3 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #ffffff), color-stop(50%, #e3e3e3), color-stop(100%, #c3c3c3));
+ background: -webkit-linear-gradient(top, #ffffff 0%, #e3e3e3 50%, #c3c3c3 100%);
+ background: -o-linear-gradient(top, #ffffff 0%, #e3e3e3 50%, #c3c3c3 100%);
+ background: -ms-linear-gradient(top, #ffffff 0%, #e3e3e3 50%, #c3c3c3 100%);
+ background: linear-gradient(top, #ffffff 0%, #e3e3e3 50%, #c3c3c3 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#c3c3c3', GradientType=0 );
+ text-decoration:none;
+ cursor:pointer;
+ font-weight:normal;
+ white-space:nowrap;
+ -moz-user-select: none;
+ -webkit-user-select:none;
+ user-select:none;
+ outline:0;
+ -moz-box-shadow: 0px 0px 6px #ccc;
+ -webkit-box-shadow: 0px 0px 6px #ccc;
+ box-shadow: 0px 0px 6px #ccc;
+}
+.pagination .disabled, .pagination .disabled:hover, .pagination .disabled:focus {
+ cursor: default;
+}
+.silverButton:hover, .silverButton:focus {
+ background: #c3c3c3;
+ background: url();
+ background: -moz-linear-gradient(top, #c3c3c3 0%, #e3e3e3 50%, #ffffff 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #c3c3c3), color-stop(50%, #e3e3e3), color-stop(100%, #ffffff));
+ background: -webkit-linear-gradient(top, #c3c3c3 0%, #e3e3e3 50%, #ffffff 100%);
+ background: -o-linear-gradient(top, #c3c3c3 0%, #e3e3e3 50%, #ffffff 100%);
+ background: -ms-linear-gradient(top, #c3c3c3 0%, #e3e3e3 50%, #ffffff 100%);
+ background: linear-gradient(top, #c3c3c3 0%, #e3e3e3 50%, #ffffff 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c3c3c3', endColorstr='#ffffff', GradientType=0 );
+}
+.active .silverButton {
+ color:#fff;
+ cursor:default;
+ background: #5a5a5a;
+ background: url();
+ background: -moz-linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #5a5a5a), color-stop(50%, #696969), color-stop(100%, #7b7b7b));
+ background: -webkit-linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+ background: -o-linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+ background: -ms-linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+ background: linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#5a5a5a', endColorstr='#7b7b7b', GradientType=0 );
+}
+.mapButton {
+ zoom: 1;
+ display:inline-block;
+ vertical-align:middle;
+ font-size:12px;
+ line-height:14px;
+ height:14px;
+ margin:0;
+ padding:6px 13px;
+ border:0;
+ color:#fff;
+ text-decoration:none;
+ cursor:pointer;
+ font-weight:normal;
+ white-space:nowrap;
+ -moz-user-select: none;
+ -webkit-user-select:none;
+ user-select:none;
+ outline:0;
+ -moz-box-shadow: 0px 0px 6px #ccc;
+ -webkit-box-shadow: 0px 0px 6px #ccc;
+ box-shadow: 0px 0px 6px #ccc;
+}
+.mapButton:hover, .mapButton:focus {
+ text-decoration:none;
+ color:#fff;
+}
+.toggleButton {
+ display:inline-block;
+ vertical-align:middle;
+ font-size:12px;
+ line-height:normal;
+ margin:0;
+ padding:7px 13px;
+ border:0;
+ color:#000;
+ text-decoration:none;
+ cursor:pointer;
+ font-weight:normal;
+ white-space:nowrap;
+ -moz-user-select: none;
+ -webkit-user-select:none;
+ user-select:none;
+ outline:0;
+ background: #dbdbdb;
+ background: url();
+ background: -moz-linear-gradient(top, #dbdbdb 0%, #cbcbcb 44%, #b9b9b9 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #dbdbdb), color-stop(44%, #cbcbcb), color-stop(100%, #b9b9b9));
+ background: -webkit-linear-gradient(top, #dbdbdb 0%, #cbcbcb 44%, #b9b9b9 100%);
+ background: -o-linear-gradient(top, #dbdbdb 0%, #cbcbcb 44%, #b9b9b9 100%);
+ background: -ms-linear-gradient(top, #dbdbdb 0%, #cbcbcb 44%, #b9b9b9 100%);
+ background: linear-gradient(top, #dbdbdb 0%, #cbcbcb 44%, #b9b9b9 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#dbdbdb', endColorstr='#b9b9b9', GradientType=0 );
+ border-top:1px solid #fff;
+ border-bottom:none;
+ -moz-box-shadow: 0px 0px 6px #ccc;
+ -webkit-box-shadow: 0px 0px 6px #ccc;
+ box-shadow: 0px 0px 6px #ccc;
+}
+.toggleButton:hover, .toggleButton:focus {
+ border-top:none;
+ border-bottom:1px solid #fff;
+ background: #b9b9b9;
+ background: url();
+ background: -moz-linear-gradient(top, #b9b9b9 0%, #cbcbcb 56%, #dbdbdb 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #b9b9b9), color-stop(56%, #cbcbcb), color-stop(100%, #dbdbdb));
+ background: -webkit-linear-gradient(top, #b9b9b9 0%, #cbcbcb 56%, #dbdbdb 100%);
+ background: -o-linear-gradient(top, #b9b9b9 0%, #cbcbcb 56%, #dbdbdb 100%);
+ background: -ms-linear-gradient(top, #b9b9b9 0%, #cbcbcb 56%, #dbdbdb 100%);
+ background: linear-gradient(top, #b9b9b9 0%, #cbcbcb 56%, #dbdbdb 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#b9b9b9', endColorstr='#dbdbdb', GradientType=0 );
+}
+.buttonSelected, .buttonSelected:hover, .buttonSelected:focus {
+ cursor:default;
+ border-bottom:none;
+ color:#fff !important;
+}
+.buttonRight {
+ -webkit-border-radius: 0px 5px 5px 0px;
+ border-radius: 0px 5px 5px 0px;
+}
+.buttonLeft {
+ -webkit-border-radius: 5px 0px 0px 5px;
+ border-radius: 5px 0px 0px 5px;
+}
+.esriRtl .buttonRight {
+ -webkit-border-radius: 5px 0px 0px 5px;
+ border-radius: 5px 0px 0px 5px;
+}
+.esriRtl .buttonLeft {
+ -webkit-border-radius: 0px 5px 5px 0px;
+ border-radius: 0px 5px 5px 0px;
+}
+.buttonSingle {
+ -webkit-border-radius: 5px;
+ border-radius:5px;
+}
+/*-------------------------------------------------- */
+/* FULSCREEN */
+/*-------------------------------------------------- */
+.fullScreen, .fullScreen body {
+ width:100%;
+ height:100%;
+ min-width:100%;
+}
+.fullScreen #fullScreen {
+ right:242px;
+}
+.fullScreen .fullScreenButton {
+ background:url(../images/ui/uiSprite.png) no-repeat -50px -2px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -50px -2px;
+}
+.fullScreen #geoButton {
+ right:290px;
+}
+.fullScreen .container_12, .fullScreen #content, .fullScreen #content .contentLeft, .fullScreen .container_12 .grid_9, .fullScreen .container_12 .grid_12 {
+ width:100% !important;
+ height:100% !important;
+ padding:0 !important;
+ margin:0 !important;
+ display:block !important;
+ overflow:hidden !important;
+ background:none !important;
+ min-height:100% !important;
+}
+.fullScreen #header, .fullScreen .fullScreen .socialButtons {
+ display:none !important;
+}
+.fullScreen .dataLayers {
+ position:static;
+}
+.fullScreen #legendMenu {
+ display: block !important;
+ position:absolute;
+ z-index:38;
+ top:10px;
+ right:10px;
+ background:#F1F1F1;
+}
+.fullScreen #aboutMenu {
+ display: none !important;
+}
+.fullScreen #description, .fullScreen #legendDiv {
+ padding:20px;
+}
+.fullScreen .scrollHeight {
+ height: 400px !important;
+ max-height:400px !important;
+ zoom:1;
+ -webkit-border-radius: 5px;
+ border-radius: 5px;
+ -moz-box-shadow: 1px 1px 3px #666;
+ -webkit-box-shadow: 1px 1px 3px #666;
+ box-shadow: 1px 1px 3px #666;
+}
+.fullScreen .mapContainer {
+ padding:0 !important;
+ margin:0 !important;
+ width:100% !important;
+ height:100% !important;
+ overflow:hidden !important;
+ -webkit-border-radius: 0 !important;
+ border-radius: 0 !important;
+}
+.fullScreen .searchListCon {
+ position:absolute;
+ z-index:38;
+ top:10px;
+ margin: 0;
+ left:75px;
+}
+.fullScreen .addressContainer, .fullScreen .searchList {
+ margin:0;
+}
+.fullScreen #title {
+ display:none;
+}
+.fullScreen #map {
+ padding:0 !important;
+ margin:0 !important;
+ width:100% !important;
+ height:100% !important;
+ overflow:hidden !important;
+}
+.fullScreen #subtitle {
+ display:none;
+}
+.fullScreen .basemapConRel {
+ position: absolute;
+ top:10px;
+ right:338px;
+ z-index:38;
+}
+/*-------------------------------------------------- */
+/* Pagination */
+/*-------------------------------------------------- */
+.pagination {
+ margin:0 0 20px 0;
+}
+.pagination ul {
+ list-style:none;
+ margin:0;
+ padding:0;
+}
+.pagination ul li {
+ float:left;
+ display:block;
+ font-size:12px;
+ line-height:14px;
+ margin:0;
+}
+.esriRtl .pagination ul li {
+ float:right;
+}
+.pagination ul .default {
+ display:inline-block;
+ padding:5px;
+ cursor:pointer;
+ background:#dadada;
+ border-top:1px solid #c4c4c4;
+ border-bottom:1px solid #c4c4c4;
+ width:30px;
+ text-align:center;
+ -moz-box-shadow: 6px 0px 6px #ccc;
+ -webkit-box-shadow: 6px 0px 6px #ccc;
+ box-shadow: 6px 0px 6px #ccc;
+}
+.esriRtl .pagination ul .default {
+ -moz-box-shadow: -6px 0px 6px #ccc;
+ -webkit-box-shadow: -6px 0px 6px #ccc;
+ box-shadow: -6px 0px 6px #ccc;
+}
+.pagination ul .default:hover, .pagination ul .default:focus {
+ background-color:#ccc;
+ color:#333;
+ -webkit-transition:background-color 0.25s ease-in;
+ -moz-transition:background-color 0.25s ease-in;
+ -o-transition:background-color 0.25s ease-in;
+ transition:background-color 0.25s ease-in;
+}
+.pagination ul .selected, .pagination ul .selected:hover, .pagination ul .selected:focus {
+ cursor:default;
+ font-weight:bold;
+ color:#fff;
+ background: #5a5a5a;
+ background: url();
+ background: -moz-linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #5a5a5a), color-stop(50%, #696969), color-stop(100%, #7b7b7b));
+ background: -webkit-linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+ background: -o-linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+ background: -ms-linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+ background: linear-gradient(top, #5a5a5a 0%, #696969 50%, #7b7b7b 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#5a5a5a', endColorstr='#7b7b7b', GradientType=0 );
+ border-bottom:1px solid #6a6a6a;
+ border-top:1px solid #6a6a6a;
+}
+.pagination ul .next span {
+ display:inline-block;
+ background:url(../images/ui/uiSprite.png) no-repeat -35px -1px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -35px -1px;
+ height:12px;
+ width:12px;
+ overflow:hidden;
+}
+.pagination ul .previous span {
+ display:inline-block;
+ background:url(../images/ui/uiSprite.png) no-repeat -18px -1px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -18px -1px;
+ height:12px;
+ width:12px;
+ overflow:hidden;
+}
+.esriRtl .pagination ul .next span {
+ background:url(../images/ui/uiSprite.png) no-repeat -18px -1px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -18px -1px;
+}
+.esriRtl .pagination ul .previous span {
+ background:url(../images/ui/uiSprite.png) no-repeat -35px -1px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -35px -1px;
+}
+/*-------------------------------------------------- */
+/* AUTO COMPLETE LIST */
+/*-------------------------------------------------- */
+#acCon {
+ position:relative;
+ z-index:39;
+}
+.autoComplete {
+ width:190px;
+ position:absolute;
+ top:0;
+ left:0;
+ z-index:39;
+ background:#fff;
+ font-size:12px;
+ -webkit-box-shadow: 1px 1px 3px #999;
+ -moz-box-shadow: 1px 1px 3px #999;
+ box-shadow: 1px 1px 3px #999;
+ -webkit-border-radius: 0px 0px 8px 8px;
+ border-radius: 0px 0px 8px 8px;
+ display:none;
+}
+.esriRtl .autoComplete {
+ left:auto;
+ right:0;
+}
+.autoComplete p {
+ margin:6px 0;
+ padding:6px 10px;
+}
+.autoComplete ul {
+ margin:6px 0;
+}
+.autoComplete li {
+ padding: 6px 10px;
+ cursor:pointer;
+}
+.autoComplete li span {
+ font-weight:bold;
+}
+/*-------------------------------------------------- */
+/* Zebra stripes */
+/*-------------------------------------------------- */
+.zebraStripes .stripe {
+ background-color: #eee;
+}
+/*-------------------------------------------------- */
+/* About Page */
+/*-------------------------------------------------- */
+#thumbnailUrl {
+ text-align: center;
+}
+.ownerImage {
+ display: inline-block;
+ margin:0 0 5px 0;
+ -webkit-border-radius: 5px;
+ border-radius: 5px;
+}
+.ownerImage:hover, .ownerImage:focus {
+ -webkit-transition:-webkit-box-shadow 0.25s ease-in;
+ -moz-transition:-moz-box-shadow 0.25s ease-in;
+ -o-transition:box-shadow 0.25s ease-in;
+ transition:box-shadow 0.25s ease-in;
+}
+.ownerImage img {
+ display: block;
+ -webkit-border-radius: 5px;
+ border-radius: 5px;
+ background:url(../images/ui/ajax-loader.gif) no-repeat center center;
+ opacity:1;
+}
+.ownerImage:hover img, .ownerImage:focus img {
+ background-image:none;
+ opacity:0.75;
+ -webkit-transition:opacity 0.25s ease-in;
+ -moz-transition:opacity 0.25s ease-in;
+ -o-transition:opacity 0.25s ease-in;
+ transition:opacity 0.25s ease-in;
+}
+/*-------------------------------------------------- */
+/* RTL */
+/*-------------------------------------------------- */
+.esriRtl {
+ direction: rtl;
+}
+/*-------------------------------------------------- */
+/* Sorting */
+/*-------------------------------------------------- */
+#sortGallery li {
+ float:left;
+}
+.esriRtl #sortGallery li {
+ float:right;
+}
+#sortGallery .active .silverButton {
+ cursor:pointer !important;
+}
+#sortGallery .label {
+ margin-right:10px;
+}
+.esriRtl #sortGallery .label {
+ margin-right:0;
+ margin-left:10px;
+}
+#sortGallery .label span {
+ display:inline-block;
+ vertical-align:center;
+ font-size:12px;
+ line-height:14px;
+ padding:6px 0;
+}
+#sortGallery li .arrow {
+ display:inline-block;
+ vertical-align:text-bottom;
+ width:12px;
+ height:12px;
+ overflow:hidden;
+ margin-left:4px;
+}
+.esriRtl #sortGallery li .arrow {
+ margin-left:0;
+ margin-right:4px;
+}
+#sortGallery .desc .arrow {
+ background:url(../images/ui/uiSprite.png) no-repeat -178px -2px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -178px -2px;
+}
+#sortGallery .desc:hover .arrow, #sortGallery .desc:focus .arrow {
+ background:url(../images/ui/uiSprite.png) no-repeat -178px -2px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -178px -2px;
+}
+#sortGallery .asc .arrow {
+ background:url(../images/ui/uiSprite.png) no-repeat -242px -2px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -242px -2px;
+}
+#sortGallery .asc:hover .arrow, #sortGallery .asc:focus .arrow {
+ background:url(../images/ui/uiSprite.png) no-repeat -242px -2px;
+ _background:url(../images/ui/uiSprite.gif) no-repeat -242px -2px;
+}
+/*-------------------------------------------------- */
+/* Comments */
+/*-------------------------------------------------- */
+#comments {
+ margin:20px 0 0 0;
+}
+#comments h2 {
+ margin-bottom:10px;
+}
+#comments .comment {
+ background:#fff;
+ padding:10px;
+ margin-bottom:10px;
+ -webkit-border-radius: 5px;
+ border-radius: 5px;
+ -moz-box-shadow: 1px 1px 3px #ccc;
+ -webkit-box-shadow: 1px 1px 3px #ccc;
+ box-shadow: 1px 1px 3px #ccc;
+}
+#comments .comment .smallText {
+ color:#656565;
+ font-size: 11px;
+}
+/*-------------------------------------------------- */
+/* Scroll Div */
+/*-------------------------------------------------- */
+.scrollHeight {
+ overflow:auto;
+ zoom:1;
+ margin:0;
+ padding:0;
+ width:220px;
+}
+/*-------------------------------------------------- */
+/* Media Queries */
+/*-------------------------------------------------- */
+@media only screen and (max-width: 940px) {
+.fullScreen .basemapConRel {
+ display: none !important;
+}
+}
+@media only screen and (max-width: 620px) {
+.fullScreen .searchListCon, .fullScreen .basemapConRel, .fullScreen #fullScreen, .fullScreen #geoButton {
+ display: none !important;
+}
+}
+@media only screen and (max-width: 570px) {
+.fullScreen .searchListCon, .fullScreen .basemapConRel, .fullScreen #legendMenu, .fullScreen #fullScreen, .fullScreen #geoButton, #map .dijitSlider {
+ display: none !important;
+}
+}
+/*-------------------------------------------------- */
+/* END */
+/*-------------------------------------------------- */
diff --git a/css/ie9.css b/css/ie9.css
new file mode 100644
index 0000000..ce37ffa
--- /dev/null
+++ b/css/ie9.css
@@ -0,0 +1,3 @@
+.gradient, .disabled, .toggleButton, .silverButton, .mapButton, .buttonSelected, .buttonLeft, .buttonRight, .buttonSingle, .esriPopup .titlePane, .dj_ie7 .esriPopup .titlePane .title {
+ filter: none !important;
+}
diff --git a/css/reset.css b/css/reset.css
new file mode 100644
index 0000000..726fccc
--- /dev/null
+++ b/css/reset.css
@@ -0,0 +1,102 @@
+/*
+html5doctor.com Reset Stylesheet
+v1.6.1
+Last Updated: 2010-09-17
+Author: Richard Clark - http://richclarkdesign.com
+Twitter: @rich_clark
+*/
+
+html, body, div, span, object, iframe,
+h1, h2, h3, h4, h5, h6, p, blockquote, pre,
+abbr, address, cite, code,
+del, dfn, em, img, ins, kbd, q, samp,
+small, strong, sub, sup, var,
+b, i,
+dl, dt, dd, ol, ul, li,
+fieldset, form, label, legend,
+table, caption, tbody, tfoot, thead, tr, th, td,
+article, aside, canvas, details, figcaption, figure,
+footer, header, hgroup, menu, nav, section, summary,
+time, mark, audio, video {
+ margin:0;
+ padding:0;
+ border:0;
+ outline:0;
+ font-size:100%;
+ vertical-align:baseline;
+ background:transparent;
+}
+
+body {
+ line-height:1;
+}
+
+article,aside,details,figcaption,figure,
+footer,header,hgroup,menu,nav,section {
+ display:block;
+}
+
+nav ul {
+ list-style:none;
+}
+
+blockquote, q {
+ quotes:none;
+}
+
+blockquote:before, blockquote:after,
+q:before, q:after {
+ content:'';
+ content:none;
+}
+
+a {
+ margin:0;
+ padding:0;
+ font-size:100%;
+ vertical-align:baseline;
+ background:transparent;
+}
+
+/* change colours to suit your needs */
+ins {
+ background-color:#ff9;
+ color:#000;
+ text-decoration:none;
+}
+
+/* change colours to suit your needs */
+mark {
+ background-color:#ff9;
+ color:#000;
+ font-style:italic;
+ font-weight:bold;
+}
+
+del {
+ text-decoration: line-through;
+}
+
+abbr[title], dfn[title] {
+ border-bottom:1px dotted;
+ cursor:help;
+}
+
+table {
+ border-collapse:collapse;
+ border-spacing:0;
+}
+
+/* change border colour to suit your needs */
+hr {
+ display:block;
+ height:1px;
+ border:0;
+ border-top:1px solid #cccccc;
+ margin:1em 0;
+ padding:0;
+}
+
+input, select {
+ vertical-align:middle;
+}
diff --git a/css/themes.css b/css/themes.css
new file mode 100644
index 0000000..672c7c7
--- /dev/null
+++ b/css/themes.css
@@ -0,0 +1,260 @@
+/*-------------------------------------------------- */
+/* RED THEME */
+/*-------------------------------------------------- */
+.redTheme {
+ display:block;
+}
+.redTheme .mapHeader, .redTheme h2, .redTheme h2 a, .redTheme a, .redTheme h3, .redTheme h3 a {
+ color:#d15929;
+}
+.redTheme #header {
+ display: block;
+ background: #d86932;
+ background: url();
+ background: -moz-linear-gradient(top, #d86932 0%, #aa1f0c 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #d86932), color-stop(100%, #aa1f0c));
+ background: -webkit-linear-gradient(top, #d86932 0%, #aa1f0c 100%);
+ background: -o-linear-gradient(top, #d86932 0%, #aa1f0c 100%);
+ background: -ms-linear-gradient(top, #d86932 0%, #aa1f0c 100%);
+ background: linear-gradient(top, #d86932 0%, #aa1f0c 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d86932', endColorstr='#aa1f0c', GradientType=0 );
+}
+.redTheme .mapButton {
+ color:#fff;
+ background: #db652c;
+ background: url();
+ background: -moz-linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #db652c), color-stop(44%, #c54417), color-stop(100%, #af2302));
+ background: -webkit-linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+ background: -o-linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+ background: -ms-linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+ background: linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#db652c', endColorstr='#af2302', GradientType=0 );
+}
+.redTheme .mapButton:hover, .redTheme .buttonSelected, .redTheme .buttonSelected:hover, .redTheme .mapButton:focus, .redTheme .buttonSelected:focus {
+ background: #af2302;
+ background: url();
+ background: -moz-linear-gradient(top, #af2302 0%, #c54417 56%, #db652c 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #af2302), color-stop(56%, #c54417), color-stop(100%, #db652c));
+ background: -webkit-linear-gradient(top, #af2302 0%, #c54417 56%, #db652c 100%);
+ background: -o-linear-gradient(top, #af2302 0%, #c54417 56%, #db652c 100%);
+ background: -ms-linear-gradient(top, #af2302 0%, #c54417 56%, #db652c 100%);
+ background: linear-gradient(top, #af2302 0%, #c54417 56%, #db652c 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#af2302', endColorstr='#db652c', GradientType=0 );
+}
+.redTheme .autoComplete li:hover, .redTheme .autoComplete li:focus {
+ background-color: #db652c;
+ color:#fff;
+}
+.esriPopup.redTheme .titlePane {
+ border-color:#901b01;
+ background: #db652c;
+ background: url();
+ background: -moz-linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #db652c), color-stop(44%, #c54417), color-stop(100%, #af2302));
+ background: -webkit-linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+ background: -o-linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+ background: -ms-linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+ background: linear-gradient(top, #db652c 0%, #c54417 44%, #af2302 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#db652c', endColorstr='#af2302', GradientType=0 );
+ color: #fff;
+ font-weight: 700;
+}
+.dj_ie7 .esriPopup.redTheme .titlePane, .dj_ie7 .esriPopup.redTheme .titlePane .title {
+ background: #db652c;
+}
+.esriPopup.redTheme .titlePane {
+ border-color:#901b01;
+}
+.esriPopup.redTheme a {
+ color: #d15929;
+}
+.esriPopup.redTheme .contentPane, .esriPopup.redTheme .actionsPane {
+ color:#404040;
+}
+.esriPopup.redTheme .contentPane, .esriPopup.redTheme .actionsPane {
+ border-color:#901b01;
+}
+/*-------------------------------------------------- */
+/* blueTheme THEME */
+/*-------------------------------------------------- */
+.blueTheme {
+ display:block;
+}
+.blueTheme .mapHeader, .blueTheme h2, .blueTheme h2 a, .blueTheme a, .blueTheme h3, .blueTheme h3 a {
+ color:#2c65a7;
+}
+.blueTheme #header {
+ display: block;
+ background: #1478c3;
+ background: url();
+ background: -moz-linear-gradient(top, #1478c3 0%, #081b3e 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #1478c3), color-stop(100%, #081b3e));
+ background: -webkit-linear-gradient(top, #1478c3 0%, #081b3e 100%);
+ background: -o-linear-gradient(top, #1478c3 0%, #081b3e 100%);
+ background: -ms-linear-gradient(top, #1478c3 0%, #081b3e 100%);
+ background: linear-gradient(top, #1478c3 0%, #081b3e 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1478c3', endColorstr='#081b3e', GradientType=0 );
+}
+.blueTheme .mapButton {
+ color:#fff;
+ background: #1393ff;
+ background: url();
+ background: -moz-linear-gradient(top, #1393ff 0%, #004e9a 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #1393ff), color-stop(100%, #004e9a));
+ background: -webkit-linear-gradient(top, #1393ff 0%, #004e9a 100%);
+ background: -o-linear-gradient(top, #1393ff 0%, #004e9a 100%);
+ background: -ms-linear-gradient(top, #1393ff 0%, #004e9a 100%);
+ background: linear-gradient(top, #1393ff 0%, #004e9a 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1393ff', endColorstr='#004e9a', GradientType=0 );
+}
+.blueTheme .mapButton:hover, .blueTheme .buttonSelected, .blueTheme .buttonSelected:hover, .blueTheme .mapButton:focus, .blueTheme .buttonSelected:focus {
+ background: #004e9a;
+ background: url();
+ background: -moz-linear-gradient(top, #004e9a 0%, #1393ff 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #004e9a), color-stop(100%, #1393ff));
+ background: -webkit-linear-gradient(top, #004e9a 0%, #1393ff 100%);
+ background: -o-linear-gradient(top, #004e9a 0%, #1393ff 100%);
+ background: -ms-linear-gradient(top, #004e9a 0%, #1393ff 100%);
+ background: linear-gradient(top, #004e9a 0%, #1393ff 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#004e9a', endColorstr='#1393ff', GradientType=0 );
+}
+.blueTheme .autoComplete li:hover, .blueTheme .autoComplete li:focus {
+ background-color: #1393ff;
+ color:#fff;
+}
+.esriPopup.blueTheme .titlePane {
+ border-color:#0f8bf6;
+ background: #1393ff;
+ background: url();
+ background: -moz-linear-gradient(top, #1393ff 0%, #004e9a 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #1393ff), color-stop(100%, #004e9a));
+ background: -webkit-linear-gradient(top, #1393ff 0%, #004e9a 100%);
+ background: -o-linear-gradient(top, #1393ff 0%, #004e9a 100%);
+ background: -ms-linear-gradient(top, #1393ff 0%, #004e9a 100%);
+ background: linear-gradient(top, #1393ff 0%, #004e9a 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1393ff', endColorstr='#004e9a', GradientType=0 );
+ color: #fff;
+ font-weight: 700;
+}
+.dj_ie7 .esriPopup.blueTheme .titlePane, .dj_ie7 .esriPopup.blueTheme .titlePane .title {
+ background: #1393ff;
+}
+.esriPopup.blueTheme .titlePane {
+ border-color:#0f8bf6;
+}
+.esriPopup.blueTheme a {
+ color: #2c65a7;
+}
+.esriPopup.blueTheme .contentPane, .esriPopup.blueTheme .actionsPane {
+ color:#404040;
+}
+.esriPopup.blueTheme .contentPane, .esriPopup.blueTheme .actionsPane {
+ border-color:#0f8bf6;
+}
+/*-------------------------------------------------- */
+/* GREEN THEME */
+/*-------------------------------------------------- */
+.greenTheme {
+ display:block;
+}
+.greenTheme .mapHeader, .greenTheme h2, .greenTheme h2 a, .greenTheme a, .greenTheme h3, .greenTheme h3 a {
+ color:#2a7433;
+}
+.greenTheme #header {
+ display: block;
+ background: #339340;
+ background: url();
+ background: -moz-linear-gradient(top, #339340 0%, #07440c 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #339340), color-stop(100%, #07440c));
+ background: -webkit-linear-gradient(top, #339340 0%, #07440c 100%);
+ background: -o-linear-gradient(top, #339340 0%, #07440c 100%);
+ background: -ms-linear-gradient(top, #339340 0%, #07440c 100%);
+ background: linear-gradient(top, #339340 0%, #07440c 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#339340', endColorstr='#07440c', GradientType=0 );
+}
+.greenTheme .mapButton {
+ color:#fff;
+ background: #6fbf7d;
+ background: url();
+ background: -moz-linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #6fbf7d), color-stop(100%, #0f5314));
+ background: -webkit-linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+ background: -o-linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+ background: -ms-linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+ background: linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#6fbf7d', endColorstr='#0f5314', GradientType=0 );
+}
+.greenTheme .mapButton:hover, .greenTheme .buttonSelected, .greenTheme .buttonSelected:hover, .greenTheme .mapButton:focus, .greenTheme .buttonSelected:focus {
+ background: #0f5314;
+ background: url();
+ background: -moz-linear-gradient(top, #0f5314 0%, #6fbf7d 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #0f5314), color-stop(100%, #6fbf7d));
+ background: -webkit-linear-gradient(top, #0f5314 0%, #6fbf7d 100%);
+ background: -o-linear-gradient(top, #0f5314 0%, #6fbf7d 100%);
+ background: -ms-linear-gradient(top, #0f5314 0%, #6fbf7d 100%);
+ background: linear-gradient(top, #0f5314 0%, #6fbf7d 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0f5314', endColorstr='#6fbf7d', GradientType=0 );
+}
+.greenTheme .autoComplete li:hover, .greenTheme .autoComplete li:focus {
+ background-color: #6fbf7d;
+ color:#fff;
+}
+.esriPopup.greenTheme .titlePane {
+ border-color:#6FBF7D;
+ background: #6fbf7d;
+ background: url();
+ background: -moz-linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #6fbf7d), color-stop(100%, #0f5314));
+ background: -webkit-linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+ background: -o-linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+ background: -ms-linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+ background: linear-gradient(top, #6fbf7d 0%, #0f5314 100%);
+filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#6fbf7d', endColorstr='#0f5314', GradientType=0 );
+ color: #fff;
+ font-weight: 700;
+}
+.dj_ie7 .esriPopup.greenTheme .titlePane, .dj_ie7 .esriPopup.greenTheme .titlePane .title {
+ background: #6fbf7d;
+}
+.esriPopup.greenTheme .titlePane {
+ border-color:#6FBF7D;
+}
+.esriPopup.greenTheme a {
+ color: #2a7433;
+}
+.esriPopup.greenTheme .contentPane, .esriPopup.greenTheme .actionsPane {
+ color:#404040;
+}
+.esriPopup.greenTheme .contentPane, .esriPopup.greenTheme .actionsPane {
+ border-color:#6FBF7D;
+}
+/*-------------------------------------------------- */
+/* CUSTOM THEME */
+/*-------------------------------------------------- */
+.custom {
+ display:block;
+}
+.custom .mapHeader, .custom h2, .custom h2 a, .custom a, .custom h3, .custom h3 a {
+}
+.custom #header {
+ display: block;
+}
+.custom .mapButton {
+}
+.custom .mapButton:hover, .custom .buttonSelected, .custom .buttonSelected:hover, .custom .mapButton:focus, .custom .buttonSelected:focus {
+}
+.custom .autoComplete li:hover, .custom .autoComplete li:focus {
+}
+.esriPopup.custom .titlePane {
+}
+.dj_ie7 .esriPopup.custom .titlePane, .dj_ie7 .esriPopup.custom .titlePane .title {
+}
+.esriPopup.custom .titlePane {
+}
+.esriPopup.custom a {
+}
+.esriPopup.custom .contentPane, .esriPopup.custom .actionsPane {
+}
+.esriPopup.custom .contentPane, .esriPopup.custom .actionsPane {
+}
diff --git a/esri_mapgallery.info b/esri_mapgallery.info
new file mode 100644
index 0000000..d35b23f
--- /dev/null
+++ b/esri_mapgallery.info
@@ -0,0 +1,9 @@
+name = Esri Map Gallery
+title = Esri Map Gallery
+package = ArcGIS Modules
+description = This module provides Map Galleries of content from ArcGIS Online as well as an embeddable viewer.
+core = "7.x"
+version = "1.0 Beta"
+
+; NEW LINE
+configure = admin/config/content/esri_mapgallery \ No newline at end of file
diff --git a/esri_mapgallery.install b/esri_mapgallery.install
new file mode 100644
index 0000000..4e43ea0
--- /dev/null
+++ b/esri_mapgallery.install
@@ -0,0 +1,44 @@
+<?php
+
+function esri_mapgallery_install() {
+ drupal_install_schema('galleries');
+}
+
+function esri_mapgallery_uninstall() {
+ drupal_uninstall_schema('galleries');
+}
+
+function esri_mapgallery_schema() {
+ $schema['galleries'] = array(
+ 'description' => 'Example map gallery module',
+ 'fields' => array(
+ 'vid' => array (
+ 'type' => 'int',
+ 'unsigned' => TRUE,
+ 'not null' => TRUE,
+ 'default' => 0
+ ),
+ 'nid' => array (
+ 'type' => 'int',
+ 'unsigned' => TRUE,
+ 'not null' => TRUE,
+ 'default' => 0
+ ),
+ 'count' => array (
+ 'type' => 'int',
+ 'not null' => TRUE,
+ 'default' => '9'
+ ),
+ 'groupid' => array (
+ 'type' => 'varchar',
+ 'length' => 50,
+ 'not null' => TRUE,
+ 'default' => 'c755678be14e4a0984af36a15f5b643e'
+ ),
+ ),
+ 'primary key' => array('vid'),
+ );
+
+ return $schema;
+}
+ \ No newline at end of file
diff --git a/esri_mapgallery.module b/esri_mapgallery.module
new file mode 100644
index 0000000..5996646
--- /dev/null
+++ b/esri_mapgallery.module
@@ -0,0 +1,161 @@
+<?php
+
+/**
+ * @file
+ * Module file for esri_mapgallery_module.
+ */
+
+/**
+ * @defgroup esri_mapgallery Example: Page
+ * @ingroup ArcGIS
+ * @{
+ * This example demonstrates how a module can display a map gallery at a given URL.
+ *
+ */
+
+/**
+ * Implements hook_help().
+ */
+function esri_mapgallery_help($path, $arg) {
+ switch ($path) {
+ case 'arcgis/about':
+ // Help text for the simple page registered for this path.
+ return t('This is help text for the ArcGIS Online module for Drupal.');
+
+ case 'arcgis/map':
+ // Help text for the simple page registered for this path.
+ return t('This is help text for the Webmap Page.');
+
+ case 'arcgis/gallery':
+ // Help text for the simple page registered for this path.
+ return t('This is help text for the Gallery page.');
+
+ case 'admin/help#esri_mapgallery':
+ // Help text for the admin section, using the module name in the path.
+ return t('This is help text created in the page example\'s second case.');
+ }
+}
+
+/**
+ * Implements hook_permission().
+ */
+function esri_mapgallery_permission() {
+ return array(
+ 'access map page' => array(
+ 'title' => t('Access map page'),
+ 'description' => t('Allow users to access the Webmap Viewer page'),
+ ),
+ 'access gallery page' => array(
+ 'title' => t('Access gallery page'),
+ 'description' => t('Allow users to access the Map Gallery page'),
+ ),
+ );
+}
+
+/**
+ * Implements hook_theme().
+ */
+function esri_mapgallery_theme() {
+ return array(
+ 'gallery' => array(
+ 'template' => 'gallery',
+ 'variables' => array('title' => NULL, 'groupID' => '69b91f7b857b40a484c4aacbd1b243a7'),
+ ),
+ );
+}
+
+
+/**
+ * Implements hook_menu().
+ *
+ * @see hook_menu()
+ * @see menu_example
+ */
+function esri_mapgallery_menu() {
+
+ // This is the minimum information you can provide for a menu item. This menu
+ // item will be created in the default menu, usually Navigation.
+ $items['arcgis/about'] = array(
+ 'title' => 'Map Gallery',
+ 'page callback' => 'esri_mapgallery_description',
+ 'access callback' => TRUE,
+ 'expanded' => TRUE,
+ );
+
+ // Webmap Page with simple map template
+ $items['arcgis/map/%'] = array(
+ 'title' => 'ArcGIS Online Map',
+ 'page callback' => 'esri_mapgallery_map',
+ 'page arguments' => array(2),
+ 'access arguments' => array('access simple map page'),
+ );
+
+ // Gallery URL with groupid, page size, and start page
+ $items['arcgis/gallery/%'] = array(
+ 'page callback' => 'esri_mapgallery_gallery',
+ 'page arguments' => array(2),
+ 'access arguments' => array('access arguments page'),
+ 'type' => MENU_CALLBACK,
+ );
+
+ return $items;
+}
+
+/**
+ * Constructs a descriptive page.
+ */
+function esri_mapgallery_description() {
+ return array('#markup' => t('The esri_mapgallery provides two pages, "map" and "gallery". The <a href="@map_link">map page</a> just returns a renderable array for display. The <a href="@gallery_link">arguments page</a> takes two arguments and displays them, as in @gallery_link', array('@map_link' => url('arcgis/map/d4a907a736404636a4f6a9875a19aa8a', array('absolute' => TRUE)), '@gallery_link' => url('arcgis/gallery/5/7', array('absolute' => TRUE)))));
+}
+
+/**
+ * Constructs a simple webmap page.
+ */
+function esri_mapgallery_map($mapid) {
+
+ // TODO: replace with the nice map page from the gallery sample
+
+ $content = ''.
+ '<iframe width="500" height="400" frameborder="0" scrolling="no" marginheight="0" marginwidth="0"' .
+ ' src="http://www.arcgis.com/home/webmap/embedViewer.html?webmap=@mapid' .
+ ' &amp;zoom=true"></iframe><br />'.
+ ' <small><a href="http://www.arcgis.com/home/webmap/viewer.html?webmap=@mapid' .
+ ' " style="color:#0000FF;text-align:left" target="_blank">View Larger Map</a></small>';
+
+ return array('#markup' => t($content, array('@mapid' => $mapid) ));
+}
+
+/**
+ * Gallery page callback.
+ */
+function esri_mapgallery_gallery($groupID) {
+ // $groupID = group id for which the gallery will be created
+
+ // TODO: Make sure you don't trust the URL to be safe! Always check for exploits.
+ //if (!is_numeric($count) || !is_numeric($pageNum)) {
+ // // We will just show a standard "access denied" page in this case.
+ // drupal_access_denied();
+ // return; // We actually don't get here.
+ //}
+
+ // get paths
+ $modulePath = drupal_get_path('module', 'esri_mapgallery');
+
+ $build['esri_mapgallery_gallery'] = array(
+ '#theme' => 'gallery',
+ '#title' => '',
+ '#groupID' => $groupID
+ );
+ $build['esri_mapgallery_gallery']['#attached']['library'][] = array('system', 'ui.galleryBody');
+
+ // insert a call to a function
+ $build['esri_mapgallery_gallery']['#attached']['js'][] = array('data' => '(function($){$(function() { setConfigOptions(\'' . $groupID . '\'); })})(jQuery);', 'type' => 'inline');
+ $output = drupal_render($build);
+ return $output;
+
+
+
+}
+/**
+ * @} End of "defgroup esri_mapgallery".
+ */
diff --git a/gallery.tpl.php b/gallery.tpl.php
new file mode 100644
index 0000000..c1f6346
--- /dev/null
+++ b/gallery.tpl.php
@@ -0,0 +1,98 @@
+<?php
+
+/**
+ * @file
+ * Template file for gallery.
+ */
+
+?>
+<script type="text/javascript">
+var configOptions;
+
+function setConfigOptions(groupID) {
+ configOptions = {
+ "group":groupID,
+ "appid":"",
+ "theme":"blueTheme",
+ "siteTitle":"",
+ "siteBannerImage":"",
+ "mapTitle":"",
+ "mapSnippet":"",
+ "mapItemDescription":"",
+ "homeHeading":"",
+ "homeSnippet":"",
+ "homeSideHeading":"Description",
+ "homeSideContent":"",
+ "footerHeading":"",
+ "footerDescription":"",
+ "footerLogo":"",
+ "footerLogoUrl":"",
+ "addThisProfileId":"xa-4f3bf72958320e9e",
+ "defaultLayout":"list",
+ "sortField":"modified",
+ "sortOrder":"desc",
+ "searchType":"Web Map",
+ "mapViewer":"drupal",
+ "galleryItemsPerPage":9,
+ "showProfileUrl":true,
+ "showAboutPage":false,
+ "showSocialButtons":true,
+ "showFooter":false,
+ "showBasemapGallery":false,
+ "showGroupSearch":true,
+ "showMapSearch":true,
+ "showLayerToggle":true,
+ "showLayoutSwitch":true,
+ "showOverviewMap":true,
+ "showMoreInfo":true,
+ "showPagination":true,
+ "showExplorerButton":false,
+ "showArcGISOnlineButton":false,
+ "showMobileButtons":false,
+ "openGalleryItemsNewWindow":false,
+ "bingMapsKey":"",
+ "proxyUrl":"",
+ "locatorserviceurl":"http://tasks.arcgis.com/ArcGIS/rest/services/WorldLocator/GeocodeServer/",
+ "geometryserviceurl":"http://tasks.arcgisonline.com/ArcGIS/rest/services/Geometry/GeometryServer",
+ "sharingurl":"http://www.arcgis.com/sharing/rest/content/items",
+ "portalUrl":"http://www.arcgis.com/",
+ "mobilePortalUrl":"arcgis://www.arcgis.com/",
+ "iosAppUrl":"itms://itunes.apple.com/us/app/arcgis/id379687930?mt=8",
+ "androidAppUrl":"https://market.android.com/details?id=com.esri.android.client",
+ "pointGraphic":"images/ui/bluepoint-21x25.png"
+ }
+}
+</script>
+<!-- STYLESHEETS -->
+<link href="http://serverapi.arcgisonline.com/jsapi/arcgis/3.0/js/dojo/dijit/themes/claro/claro.css" rel="stylesheet" type="text/css" />
+<link href="<?php print $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'esri_mapgallery'); ?>/css/reset.css" rel="stylesheet" type="text/css" />
+<link href="<?php print $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'esri_mapgallery'); ?>/css/960.css" rel="stylesheet" type="text/css" />
+<link href="<?php print $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'esri_mapgallery'); ?>/css/common.css" rel="stylesheet" type="text/css" />
+<link href="<?php print $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'esri_mapgallery'); ?>/css/themes.css" rel="stylesheet" type="text/css" />
+<!--[if gte IE 9]>
+<link href="<?php print $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'esri_mapgallery'); ?>/css/ie9.css" rel="stylesheet" type="text/css" />
+<![endif]-->
+
+<!-- JAVASCRIPT -->
+<script type="text/javascript" src="<?php print $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'esri_mapgallery'); ?>/javascript/djConfig.js"></script>
+<script type="text/javascript" src="http://serverapi.arcgisonline.com/jsapi/arcgis/?v=3.0"></script>
+<script type="text/javascript" src="<?php print $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'esri_mapgallery'); ?>/javascript/common.js"></script>
+<script type="text/javascript" src="<?php print $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'esri_mapgallery'); ?>/javascript/home/layout.js"></script>
+<!-- END JAVASCRIPT -->
+
+ <div id="galleryContent">
+ <div class="container_12">
+ <div id="mainPanel" class="grid_9">
+ <h1 id="homeHeading"></h1>
+ <p id="homeSnippet"></p>
+ <div id="layoutAndSearch"></div>
+ <div id="featuredMaps">
+ <p id="featuredLoading" class="featuredLoading"></p>
+ </div>
+ <div class="clear"></div>
+ <div class="grid_6 alpha">
+ <div id="maps_pagination" class="pagination"></div>
+ </div>
+ </div>
+ </div>
+ </div>
diff --git a/images/ui/activeLink.png b/images/ui/activeLink.png
new file mode 100644
index 0000000..f4b13b6
--- /dev/null
+++ b/images/ui/activeLink.png
Binary files differ
diff --git a/images/ui/ajax-loader.gif b/images/ui/ajax-loader.gif
new file mode 100644
index 0000000..1560b64
--- /dev/null
+++ b/images/ui/ajax-loader.gif
Binary files differ
diff --git a/images/ui/banner.png b/images/ui/banner.png
new file mode 100644
index 0000000..316c499
--- /dev/null
+++ b/images/ui/banner.png
Binary files differ
diff --git a/images/ui/bluepoint-21x25.png b/images/ui/bluepoint-21x25.png
new file mode 100644
index 0000000..57c883c
--- /dev/null
+++ b/images/ui/bluepoint-21x25.png
Binary files differ
diff --git a/images/ui/contentBG.jpg b/images/ui/contentBG.jpg
new file mode 100644
index 0000000..05d5768
--- /dev/null
+++ b/images/ui/contentBG.jpg
Binary files differ
diff --git a/images/ui/dataLayers.jpg b/images/ui/dataLayers.jpg
new file mode 100644
index 0000000..3937c29
--- /dev/null
+++ b/images/ui/dataLayers.jpg
Binary files differ
diff --git a/images/ui/external.png b/images/ui/external.png
new file mode 100644
index 0000000..7c61c62
--- /dev/null
+++ b/images/ui/external.png
Binary files differ
diff --git a/images/ui/footerBG.jpg b/images/ui/footerBG.jpg
new file mode 100644
index 0000000..2717b01
--- /dev/null
+++ b/images/ui/footerBG.jpg
Binary files differ
diff --git a/images/ui/logoBorder.jpg b/images/ui/logoBorder.jpg
new file mode 100644
index 0000000..79e8b2c
--- /dev/null
+++ b/images/ui/logoBorder.jpg
Binary files differ
diff --git a/images/ui/logoBorderRTL.jpg b/images/ui/logoBorderRTL.jpg
new file mode 100644
index 0000000..eb46fcf
--- /dev/null
+++ b/images/ui/logoBorderRTL.jpg
Binary files differ
diff --git a/images/ui/uiSprite.gif b/images/ui/uiSprite.gif
new file mode 100644
index 0000000..33f34c2
--- /dev/null
+++ b/images/ui/uiSprite.gif
Binary files differ
diff --git a/images/ui/uiSprite.png b/images/ui/uiSprite.png
new file mode 100644
index 0000000..9007e18
--- /dev/null
+++ b/images/ui/uiSprite.png
Binary files differ
diff --git a/javascript/about/layout.js b/javascript/about/layout.js
new file mode 100644
index 0000000..68f8c8b
--- /dev/null
+++ b/javascript/about/layout.js
@@ -0,0 +1,122 @@
+// Dojo Requires
+dojo.require("esri.arcgis.utils");
+dojo.require("esri.IdentityManager");
+dojo.require("esri.arcgis.Portal");
+dojo.require("dojo.NodeList-manipulate");
+dojo.require("dojo.NodeList-traverse");
+dojo.require("dojox.NodeList.delegate");
+dojo.require("dijit.Dialog");
+dojo.require("dojo.io.script");
+dojo.require("dojo.number");
+/*------------------------------------*/
+// on dojo load
+/*------------------------------------*/
+dojo.addOnLoad(function(){
+ // set default configuration options
+ setDefaultConfigOptions();
+ // set app ID settings and call init after
+ setAppIdSettings(function(){
+ // create portal
+ createPortal(function(){
+ init();
+ });
+ });
+});
+/*------------------------------------*/
+// Query Owner
+/*------------------------------------*/
+function queryOwnerInfo(obj){
+ // default values
+ var settings = {
+ // Group Owner
+ owner: '',
+ // format
+ dataType : 'json',
+ // callback function with object
+ callback: null
+ };
+ // If options exist, lets merge them with our default settings
+ if(obj) {
+ dojo.mixin(settings, obj);
+ }
+ var q = 'username:' + settings.owner;
+ var params = {
+ q: q,
+ v: configOptions.arcgisRestVersion,
+ f: settings.dataType
+ };
+ portal.queryUsers(params).then(function(data){
+ if(typeof settings.callback === 'function'){
+ // call callback function with settings and data
+ settings.callback.call(this, settings, data);
+ }
+ });
+}
+/*------------------------------------*/
+// place about content into dom
+/*------------------------------------*/
+function insertAboutContent(userInfo){
+ var node, html;
+ if(userInfo){
+ // users full name
+ node = dojo.byId('fullName');
+ if(userInfo.fullName){
+ setNodeHTML(node, userInfo.fullName);
+ }
+ // users description
+ node = dojo.byId('userDescription');
+ if(userInfo.description){
+ setNodeHTML(node, userInfo.description);
+ }
+ // users thumbnail
+ node = dojo.byId('thumbnailUrl');
+ html = '';
+ if(userInfo.thumbnailUrl){
+ if(configOptions.showProfileUrl){
+ html += '<a class="ownerImage" href="' + getViewerURL('owner_page') + '" target="_blank">';
+ }
+ else{
+ html += '<span class="ownerImage">';
+ }
+ html += '<img alt="' + userInfo.fullName + '" title="' + userInfo.fullName + '" src="' + userInfo.thumbnailUrl + '" width="150" height="150" />';
+ if(configOptions.showProfileUrl){
+ html += '</a>';
+ }
+ else{
+ html += '</span>';
+ }
+ }
+ if(configOptions.showProfileUrl && userInfo.username){
+ html += '<div><a href="' + getViewerURL('owner_page') + '" target="_blank">' + userInfo.username + '</a></div>';
+ }
+ setNodeHTML(node, html);
+ }
+}
+/*------------------------------------*/
+// Init
+/*------------------------------------*/
+function init(){
+ // Query group and then query maps
+ queryGroup(function(){
+ // query group info
+ queryOwnerInfo({
+ // Group Owner
+ owner: configOptions.groupOwner,
+ // Executed after ajax returned
+ callback: function(obj,data){
+ if(data.results.length > 0){
+ // place about content into dom
+ insertAboutContent(data.results[0]);
+ }
+ else{
+ // show error dialog
+ var dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.noMatches
+ });
+ dialog.show();
+ }
+ }
+ });
+ });
+} \ No newline at end of file
diff --git a/javascript/common.js b/javascript/common.js
new file mode 100644
index 0000000..04fbfd8
--- /dev/null
+++ b/javascript/common.js
@@ -0,0 +1,984 @@
+/*------------------------------------*/
+// Add Spinner
+/*------------------------------------*/
+function addSpinner(id){
+ var html = '<div class="spinnerRemove"><div class="loadingAjax"></div></div>';
+ var node = dojo.byId(id);
+ setNodeHTML(node, html);
+}
+/*------------------------------------*/
+// Reverse sort order
+/*------------------------------------*/
+function reverseSortOrder(order){
+ if(order === 'desc'){
+ return 'asc';
+ }
+ // else
+ return 'desc';
+}
+/*------------------------------------*/
+// Remove Spinner
+/*------------------------------------*/
+function removeSpinner(){
+ dojo.query('.spinnerRemove').orphan();
+}
+/*------------------------------------*/
+// Hide all content
+/*------------------------------------*/
+function hideAllContent(){
+ var node = dojo.byId('content');
+ setNodeHTML(node, '');
+}
+/*------------------------------------*/
+// App ID Settings
+/*------------------------------------*/
+function setAppIdSettings(callback){
+ if(configOptions.appid){
+ var requestHandle = esri.request({
+ url: configOptions.sharingurl + "/" + configOptions.appid + "/data",
+ content: {
+ f: "json"
+ },
+ callbackParamName: "callback",
+ // on load
+ load: function (response) {
+ // check for false value strings
+ var appSettings = setFalseValues(response.values);
+ // set other config options from app id
+ dojo.mixin(configOptions, appSettings);
+ // callback function
+ if(typeof callback === 'function'){
+ // call callback function
+ callback.call(this);
+ }
+ },
+ // on error
+ error: function (response) {
+ var error = response.message;
+ // show error dialog
+ var dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.createMap + " : " + error
+ });
+ dialog.show();
+ // hide all content
+ hideAllContent();
+ }
+ });
+ }
+ else{
+ // callback function
+ if(typeof callback === 'function'){
+ // call callback function
+ callback.call(this);
+ }
+ }
+}
+/*------------------------------------*/
+// Clear address function
+/*------------------------------------*/
+function clearAddress(obj){
+ // empty value
+ obj.attr('value', "");
+ // get reset node
+ var iconReset = obj.next('.iconReset');
+ // remove active class
+ iconReset.removeClass('resetActive');
+ // add default class
+ obj.addClass('default');
+}
+/*------------------------------------*/
+// Checks to see if address is populated
+/*------------------------------------*/
+function checkAddressStatus(obj){
+ // get value of node
+ var cAVal = dojo.query(obj).attr('value')[0];
+ // get reset node
+ var iconReset = dojo.query(obj).next('.iconReset');
+ // if value is not empty
+ if(cAVal !== ''){
+ // add reset class
+ iconReset.addClass('resetActive');
+ }
+}
+/*------------------------------------*/
+// Set default options for the template
+/*------------------------------------*/
+function setDefaultConfigOptions(){
+ // set user agent
+ setUserAgent();
+ // set up params
+ configUrlParams();
+ // set localization
+ i18n = dojo.i18n.getLocalization("esriTemplate", "template");
+
+ // if RTL
+ if(window.dojoConfig.locale && window.dojoConfig.locale.indexOf("ar") !== -1) {
+ //right now checking for Arabic only, to generalize for all RTL languages
+ configOptions.isRightToLeft = true; // configOptions.isRightToLeft property setting to true when the locale is 'ar'
+ }
+ // Template Version. Used for development and version recognition.
+ configOptions.templateVersion = "2.05a";
+ // ArcGIS Rest Version
+ configOptions.arcgisRestVersion = 1;
+ // row items
+ configOptions.galleryPerRow = 3;
+ // Set geometry to HTTPS if protocol is used
+ if(configOptions.geometryserviceurl && location.protocol === "https:") {
+ configOptions.geometryserviceurl = configOptions.geometryserviceurl.replace('http:', 'https:');
+ }
+ // https locator url
+ if(configOptions.locatorserviceurl && location.protocol === "https:") {
+ configOptions.locatorserviceurl = configOptions.locatorserviceurl.replace('http:', 'https:');
+ }
+ // https sharing url
+ if(configOptions.sharingurl && location.protocol === "https:") {
+ configOptions.sharingurl = configOptions.sharingurl.replace('http:', 'https:');
+ }
+ // https portal url
+ if(configOptions.portalUrl && location.protocol === "https:") {
+ configOptions.portalUrl = configOptions.portalUrl.replace('http:', 'https:');
+ }
+ // set sharing URL
+ if(!configOptions.sharingurl){
+ configOptions.sharingurl = location.protocol + '//' + location.host + "/sharing/rest/content/items";
+ }
+ // set portal URL
+ if(!configOptions.portalUrl){
+ configOptions.portalUrl = location.protocol + '//' + location.host + "/";
+ }
+ // set portal URL
+ if(!configOptions.mobilePortalUrl){
+ configOptions.mobilePortalUrl = 'arcgis://' + location.host + "/";
+ }
+ // Set Proxy URL
+ if(!configOptions.proxyUrl){
+ configOptions.proxyUrl = location.protocol + '//' + location.host + "/sharing/proxy";
+ }
+ // lowercase layout
+ if(configOptions.defaultLayout){
+ configOptions.defaultLayout = configOptions.defaultLayout.toLowerCase();
+ }
+ // if no theme is set at all
+ if(!configOptions.theme){
+ configOptions.theme = "blueTheme";
+ }
+ // if no point symbol set
+ if(!configOptions.hasOwnProperty('pointGraphic')){
+ configOptions.pointGraphic = "images/ui/bluepoint-21x25.png";
+ }
+ // if no gallery per page set
+ if(!configOptions.hasOwnProperty('galleryItemsPerPage')){
+ configOptions.galleryItemsPerPage = 9;
+ }
+ // if no gallery per page set
+ if(!configOptions.hasOwnProperty('mapViewer')){
+ configOptions.mapViewer = 'simple';
+ }
+ // if no sort order set
+ if(!configOptions.hasOwnProperty('sortOrder')){
+ configOptions.sortOrder = 'desc';
+ }
+ // if no sort field set
+ if(!configOptions.hasOwnProperty('sortField')){
+ configOptions.sortField = 'modified';
+ }
+ // if no default layout
+ if(!configOptions.hasOwnProperty('defaultLayout')){
+ configOptions.defaultLayout = 'grid';
+ }
+ // set defaults
+ esri.arcgis.utils.arcgisUrl = configOptions.sharingurl;
+ esri.config.defaults.geometryService = new esri.tasks.GeometryService(configOptions.geometryserviceurl);
+ esri.config.defaults.io.proxyUrl = configOptions.proxyUrl;
+ esri.config.defaults.io.corsEnabledServers = [location.protocol + '//' + location.host];
+ esri.config.defaults.io.alwaysUseProxy = false;
+}
+/*------------------------------------*/
+// query group
+/*------------------------------------*/
+function queryGroup(callback){
+ // query group info
+ queryArcGISGroupInfo({
+ // Settings
+ id_group: configOptions.group,
+ // Executed after ajax returned
+ callback: function(obj,data){
+ if(data.results.length > 0){
+ // set group content
+ setGroupContent(data.results[0]);
+ // if callback
+ if(callback && typeof callback === 'function'){
+ // call callback function
+ callback.call(this);
+ }
+ }
+ else{
+ // show error dialog
+ var dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.noGroupResults
+ });
+ dialog.show();
+ }
+ }
+ });
+}
+/*------------------------------------*/
+// Set group information to template
+/*------------------------------------*/
+function setGroupContent(groupInfo){
+ // set group id
+ if(!configOptions.group){
+ configOptions.group = groupInfo.id;
+ }
+ // Set owner
+ if(!configOptions.groupOwner){
+ configOptions.groupOwner = groupInfo.owner;
+ }
+ // Set group title
+ if(!configOptions.groupTitle){
+ configOptions.groupTitle = groupInfo.title;
+ }
+ // Set home heading
+ if(!configOptions.homeHeading){
+ configOptions.homeHeading = groupInfo.title;
+ }
+ // Set home snippet
+ if(!configOptions.homeSnippet){
+ configOptions.homeSnippet = groupInfo.snippet;
+ }
+ // Set home side content
+ if(!configOptions.homeSideContent){
+ configOptions.homeSideContent = groupInfo.description;
+ }
+ // set footer image
+ if(!configOptions.footerLogo){
+ configOptions.footerLogo = groupInfo.thumbnailUrl;
+ }
+ // set footer image link
+ if(!configOptions.footerLogoUrl){
+ configOptions.footerLogoUrl = getViewerURL('group_page');
+ }
+ // set page title
+ document.title = configOptions.siteTitle + ' - ' + groupInfo.title;
+ // insert all the group content
+ insertContent();
+}
+/*------------------------------------*/
+// Set false url param strings to false
+/*------------------------------------*/
+function setFalseValues(obj){
+ // for each key
+ for(var key in obj){
+ // if not a prototype
+ if(obj.hasOwnProperty(key)){
+ // if is a false value string
+ if(typeof obj[key] === 'string' && (obj[key].toLowerCase() === 'false' || obj[key].toLowerCase() === 'null' || obj[key].toLowerCase() === 'undefined')){
+ // set to false bool type
+ obj[key] = false;
+ }
+ }
+ }
+ // return object
+ return obj;
+}
+/*------------------------------------*/
+// Set URL params such as group, theme, webmap and more
+/*------------------------------------*/
+function configUrlParams(){
+ // set url object
+ urlObject = esri.urlToObject(document.location.href);
+ //urlObject = esri.urlToObject(tmpURL);
+ // make sure it's an object
+ urlObject.query = urlObject.query || {};
+ // check for false value strings
+ urlObject.query = setFalseValues(urlObject.query);
+ // mix in settings
+ dojo.mixin(configOptions, urlObject.query);
+}
+/*------------------------------------*/
+// is user on supported mobile device
+/*------------------------------------*/
+function isMobileUser(){
+ // if ios or android
+ if(configOptions.agent_ios || configOptions.agent_android){
+ return true;
+ }
+ else{
+ return false;
+ }
+}
+/*------------------------------------*/
+// ZOOM TO LOCATION: ZOOMS MAP TO LOCATION POINT
+/*------------------------------------*/
+function zoomToLocation(x, y, IPAccuracy){
+ // calculate lod
+ var lod = 16;
+ // set point
+ var pt = esri.geometry.geographicToWebMercator(new esri.geometry.Point(x, y));
+ // if point graphic set
+ if(configOptions.pointGraphic){
+ // If locate layer
+ if(locateResultLayer) {
+ // clear layer
+ locateResultLayer.clear();
+ }
+ else{
+ // Create layer for result
+ locateResultLayer = new esri.layers.GraphicsLayer();
+ // Add layer to map
+ map.addLayer(locateResultLayer);
+ }
+ // Create point symbol
+ var pointSymbol = new esri.symbol.PictureMarkerSymbol(configOptions.pointGraphic, 21, 25).setOffset(0,12);
+ // Set graphic
+ var locationGraphic = new esri.Graphic(pt,pointSymbol);
+ // Add graphic to layer
+ locateResultLayer.add(locationGraphic);
+ }
+ // zoom and center
+ map.centerAndZoom(pt,lod);
+}
+/*------------------------------------*/
+// GEOLOCATE FUNCTION: SETS MAP LOCATION TO USERS LOCATION
+/*------------------------------------*/
+function geoLocateMap(position){
+ // Get lattitude
+ var latitude = position.coords.latitude;
+ // Get longitude
+ var longitude = position.coords.longitude;
+ // Get accuracy
+ var IPAccuracy = position.coords.accuracy;
+ // Zoom to location
+ zoomToLocation(longitude, latitude, IPAccuracy);
+}
+/*------------------------------------*/
+// Set user agent
+/*------------------------------------*/
+function setUserAgent(){
+ // set agent
+ configOptions.agent = navigator.userAgent.toLowerCase();
+ // if iOS
+ configOptions.agent_ios = configOptions.agent.match(/(iphone|ipod|ipad)/);
+ // if Android
+ configOptions.agent_android = configOptions.agent.match(/(android)/);
+}
+/*------------------------------------*/
+// Insert social media html
+/*------------------------------------*/
+function insertSocialHTML(){
+ var html = '';
+ if(configOptions.showSocialButtons){
+ html += '<div class="addthis_toolbox addthis_default_style">';
+ html += '<a class="addthis_button_facebook"></a>';
+ html += '<a class="addthis_button_twitter"></a>';
+ html += '<a class="addthis_button_linkedin"></a>';
+ html += '<a class="addthis_button_email"></a>';
+ html += '<a class="addthis_button_compact"></a>';
+ html += '<a class="addthis_counter addthis_bubble_style"></a>';
+ html += '</div>';
+ // addthis url
+ var addthisURL = "http://s7.addthis.com/js/250/addthis_widget.js#pubid=";
+ // https support
+ if(addthisURL && location.protocol === "https:"){
+ addthisURL = addthisURL.replace('http:', 'https:');
+ }
+ // load share script
+ dojo.io.script.get({
+ url: addthisURL + configOptions.addThisProfileId
+ });
+ }
+ else{
+ html += '&nbsp;';
+ }
+ // if social HTML
+ var node = dojo.byId('socialHTML');
+ setNodeHTML(node, html);
+}
+/*------------------------------------*/
+// Insert footer HTML
+/*------------------------------------*/
+function insertFooterHTML(){
+ var html = '';
+ html += '<div id="footerCon">';
+ html += '<div class="container_12">';
+ html += '<div class="grid_6">';
+ html += '<div class="Pad">';
+ // Set footer heading
+ if(configOptions.footerHeading){
+ html += '<h2 id="footerHeading">';
+ html += configOptions.footerHeading;
+ html += '</h2>';
+ }
+ // if footer description
+ if(configOptions.footerDescription){
+ html += '<div id="footerDescription">';
+ html += configOptions.footerDescription;
+ html += '</div>';
+ }
+ // if neither is set just put a space.
+ if(!configOptions.footerHeading && !configOptions.footerDescription){
+ html += '&nbsp;';
+ }
+ html += '</div>';
+ html += '</div>';
+ html += '<div class="prefix_3 grid_3">';
+ html += '<div id="footerLogoDiv" class="logoDiv footBorder">';
+ // Set footer logo
+ if(configOptions.footerLogo && configOptions.showFooter){
+ html += '<div>';
+ // if logo url
+ if(configOptions.footerLogoUrl){
+ html += '<a id="yourLogo" href="' + configOptions.footerLogoUrl + '" title="' + configOptions.homeHeading + '">';
+ }
+ html += '<img src="' + configOptions.footerLogo + '" alt="' + configOptions.homeHeading + '" title="' + configOptions.homeHeading + '" />';
+ // if logo url
+ if(configOptions.footerLogoUrl){
+ html += '</a>';
+ }
+ html += '</div>';
+ }
+ html += '</div>';
+ html += '</div>';
+ html += '<div class="clear"></div>';
+ html += '</div>';
+ html += '</div>';
+ // if Footer
+ var node = dojo.byId('footer');
+ setNodeHTML(node, html);
+ // set Background Color
+ dojo.query("body").style('background-color', '#4d4d4d');
+}
+/*------------------------------------*/
+// Insert Navigation/Banner
+/*------------------------------------*/
+function insertHeaderContent(){
+ var html = '';
+ var node = dojo.byId('templateNav');
+ html += '<li id="homeItem"><a tabindex="0" title="' + configOptions.siteTitle + '" href="' + getViewerURL('index_page') + '" id="siteTitle">';
+ // if banner image
+ if(configOptions.siteBannerImage){
+ html += '<img alt="' + configOptions.siteTitle + '" title="' + configOptions.siteTitle + '" src="' + configOptions.siteBannerImage + '" />';
+ }
+ else{
+ html += configOptions.siteTitle;
+ }
+ html += '</a></li>';
+ // copy if any current lists are in there that users may have set
+ if(node){
+ html += node.innerHTML;
+ }
+ // if show about page
+ if(configOptions.showAboutPage){
+ html += '<li><a tabindex="0" href="' + getViewerURL('about_page') + '">' + i18n.viewer.sidePanel.aboutButton + '</a></li>';
+ }
+ // insert HTML
+ setNodeHTML(node, html);
+ // set selected class
+ dojo.forEach(dojo.query('#templateNav li a'),function(obj){
+ // if link HREF equals page HREF
+ if(obj.href === location.href){
+ // add selected class
+ dojo.query(obj).addClass('activeLink');
+ }
+ });
+}
+/*------------------------------------*/
+// Insert HTML to node reference function
+/*------------------------------------*/
+function setNodeHTML(node, htmlString){
+ if(node){
+ // update HTML
+ node.innerHTML = htmlString;
+ // resize sidebar and scrolling div
+ resizeSidebarHeight();
+ }
+}
+/*------------------------------------*/
+// Resize Sidebar and scrolling div
+/*------------------------------------*/
+function resizeSidebarHeight(){
+ // vars
+ var scrollHeight = 0, mainHeight = 0, outerHeight = 0, outerNode = dojo.query('#sidePanel .outerHeight'), scrollNode = dojo.query('#sidePanel .scrollHeight'), sideNode = dojo.byId('sidePanel'), mainNode = dojo.byId('mainPanel');
+ // outer nodes in scroll area
+ if(outerNode){
+ // for each outer node
+ for(var i = 0; i < outerNode.length; i++){
+ // increase outer node height
+ outerHeight = outerHeight + dojo.marginBox(outerNode[i]).h;
+ }
+ }
+ // if main node and side node
+ if(mainNode && sideNode){
+ // get inner height of main node
+ mainHeight = dojo.contentBox(mainNode).h;
+ // if inner height is less than 750. make that the default.
+ if(mainHeight < 750){
+ mainHeight = 750;
+ }
+ // set scrolling height
+ scrollHeight = mainHeight - outerHeight;
+ // set height of side bar
+ dojo.style(sideNode, 'height', mainHeight + 'px');
+ }
+ // if scroll height is set and scroll nodes are there
+ if(scrollHeight && scrollNode){
+ // for each scrolling node
+ for(var j = 0; j < scrollNode.length; j++){
+ // set it's height
+ dojo.style(scrollNode[j], 'height', scrollHeight + 'px');
+ }
+ }
+}
+/*------------------------------------*/
+// Insert content
+/*------------------------------------*/
+function insertContent(){
+ // add direction tag to HTML
+ var dirNode = dojo.query("html");
+ // if RTL
+ if(configOptions.isRightToLeft) {
+ // Set direction class
+ dirNode.addClass('esriRtl');
+ // direction attribute
+ dirNode.attr('dir', 'rtl');
+ }
+ else {
+ // Set direction class
+ dirNode.addClass('esriLtr');
+ // direction attribute
+ dirNode.attr('dir', 'ltr');
+ }
+ // add sidepanel class
+ dojo.query('#sidePanel').addClass('dataLayers');
+ // add main panel class
+ dojo.query('#mainPanel').addClass('contentLeft');
+ // Set Theme
+ dirNode.addClass(configOptions.theme);
+ // Insert banner and navigation
+ insertHeaderContent();
+ // Set social media buttons
+ insertSocialHTML();
+ // Set footer
+ if(configOptions.showFooter){
+ insertFooterHTML();
+ }
+}
+/*------------------------------------*/
+// query arcgis group info
+/*------------------------------------*/
+function queryArcGISGroupInfo(obj){
+ // default values
+ var settings = {
+ // set group id for web maps
+ id_group : '',
+ // format
+ dataType : 'json',
+ // callback function with object
+ callback: null
+ };
+ // If options exist, lets merge them with our default settings
+ if(obj) {
+ dojo.mixin(settings, obj);
+ }
+ // first, request the group to see if it's public or private
+ esri.request({
+ // group rest URL
+ url: configOptions.portalUrl + '/sharing/rest/community/groups/' + settings.id_group,
+ content: {
+ 'f':settings.dataType
+ },
+ callbackParamName: 'callback',
+ load: function (response) {
+ // sign-in flag
+ var signInRequired = (response.access !== 'public') ? true : false;
+ // if sign-in is required
+ if(signInRequired){
+ portal.signIn();
+ }
+ // query
+ var q = 'id:"' + settings.id_group + '"';
+ var params = {
+ q: q,
+ v: configOptions.arcgisRestVersion,
+ f: settings.dataType
+ };
+ portal.queryGroups(params).then(function(data){
+ if(typeof settings.callback === 'function'){
+ // call callback function with settings and data
+ settings.callback.call(this, settings, data);
+ }
+ });
+ }
+ });
+}
+/*------------------------------------*/
+// Create portal and proceed
+/*------------------------------------*/
+function createPortal(callback){
+ // create portal
+ portal = new esri.arcgis.Portal(configOptions.portalUrl);
+ // portal loaded
+ dojo.connect(portal, 'onLoad', function(){
+ if(typeof callback === 'function'){
+ // call callback function
+ callback.call(this);
+ }
+ });
+}
+/*------------------------------------*/
+// Query arcgis items
+/*------------------------------------*/
+function queryArcGISGroupItems(obj){
+ // default values
+ var settings = {
+ // set group id for web maps
+ id_group: '',
+ // type of item
+ searchType: '',
+ // filter these items
+ filterType: '',
+ // access type
+ searchAccess: '',
+ // format
+ dataType: 'json',
+ // sorting column: The allowed field names are title, modified, type, owner, avgRating, numRatings, numComments and numViews.
+ sortField: 'modified',
+ // sorting order: Values: asc | desc
+ sortOrder: 'desc',
+ // if pagination
+ pagination: true,
+ // how many links to show on each side of pagination
+ paginationSize: 1,
+ // show first and last links on pagination
+ paginationShowFirstLast: true,
+ // show previous and next links
+ paginationShowPrevNext: true,
+ // search limit
+ perPage: '',
+ // maps per row
+ perRow: '',
+ // offset
+ searchStart: 1,
+ // search keywords
+ keywords: '',
+ // style of layout for the results
+ layout: 'grid',
+ // callback function with object
+ callback: null
+ };
+ // If options exist, lets merge them with our default settings
+ if(obj) {
+ dojo.mixin(settings, obj);
+ }
+ var q = '';
+ q += 'group:"' + settings.id_group + '"';
+ if(settings.keywords){
+ q += ' AND (';
+ q += ' title:"' + settings.keywords + '"';
+ q += ' OR tags:"' + settings.keywords + '"';
+ q += ' OR typeKeywords:"' + settings.keywords + '"';
+ q += ' OR snippet:"' + settings.keywords + '"';
+ q += ' ) ';
+ }
+ if(settings.searchType){
+ q += ' AND type:"' + settings.searchType + '"';
+ }
+ if(settings.searchType && settings.filterType){
+ q += ' -type:"' + settings.filterType + '"';
+ }
+ if(settings.searchAccess){
+ q += ' AND access:"' + settings.searchAccess + '"';
+ }
+ var params = {
+ q: q,
+ v: configOptions.arcgisRestVersion,
+ f: settings.dataType
+ };
+ if(settings.sortField){
+ params.sortField = settings.sortField;
+ }
+ if(settings.sortOrder){
+ params.sortOrder = settings.sortOrder;
+ }
+ if(settings.perPage){
+ params.num = settings.perPage;
+ }
+ else{
+ params.num = 0;
+ }
+ if(settings.searchStart > 1){
+ params.start = (((settings.searchStart - 1) * settings.perPage) + 1);
+ }
+ portal.queryItems(params).then(function(data){
+ if(typeof settings.callback === 'function'){
+ // call callback function with settings and data
+ settings.callback.call(this, settings, data);
+ }
+ });
+}
+/*------------------------------------*/
+// create pagination function
+/*------------------------------------*/
+function createPagination(obj, totalItems, pagObject){
+ // creates middle pagination item HTML
+ function createMiddleItem(i, current){
+ // class
+ var selectedClass = 'enabled';
+ if(i === current){
+ // if selected
+ selectedClass = 'selected';
+ }
+ // page list item
+ return '<li tabindex="0" title="' + i18n.viewer.pagination.page + ' ' + dojo.number.format(i) + '" data-offset="' + i + '" class="default ' + selectedClass + '">' + dojo.number.format(i) + '</li>';
+ }
+ // variables
+ var html = '', startHTML = '', middleHTML = '', endHTML = '', current, first, previous, next, last, middleCount = 0, lastMiddle = 0, firstMiddle = 0, remainderStart, helipText = i18n.viewer.pagination.helip, paginationCount, npCount = 0;
+ // if pagination is necessary
+ if(obj.pagination && obj.perPage && totalItems > obj.perPage){
+ // create pagination list
+ html += '<ul>';
+ // determine offset links
+ current = parseInt(obj.searchStart, 10);
+ // first link
+ first = 1;
+ // previous link
+ previous = current - 1;
+ // next link
+ next = current + 1;
+ // last link
+ last = Math.ceil(totalItems/obj.perPage);
+ // determine next and previous count
+ if(obj.paginationShowPrevNext){
+ npCount = 2;
+ }
+ // determine pagination total size
+ paginationCount = 1 + npCount + (2 * obj.paginationSize);
+ // if pages matches size of pagination
+ if(last === paginationCount){
+ helipText = '';
+ }
+ // pagination previous
+ if(obj.paginationShowPrevNext){
+ var firstClass = 'disabled', firstOffset = '';
+ if(current > 1){
+ firstClass = 'enabled';
+ firstOffset = 'data-offset="' + previous + '"';
+ }
+ startHTML += '<li tabindex="0" title="' + i18n.viewer.pagination.previous + '" class="silverButton buttonLeft previous ' + firstClass + '" ' + firstOffset + '><span>&nbsp;</span></li>';
+ }
+ // pagination first page
+ if(obj.paginationShowFirstLast && current > (obj.paginationSize + 1)){
+ startHTML += '<li tabindex="0" class="default enabled" title="' + i18n.viewer.pagination.first + '" data-offset="' + first + '">' + dojo.number.format(first) + helipText + '</li>';
+ }
+ else{
+ middleCount = middleCount - 1;
+ }
+ // pagination last page
+ if(obj.paginationShowFirstLast && current < (last - obj.paginationSize)){
+ endHTML += '<li tabindex="0" class="default enabled" title="' + i18n.viewer.pagination.last + '" data-offset="' + last + '">' + helipText + dojo.number.format(last) + '</li>';
+ }
+ else{
+ middleCount = middleCount - 1;
+ }
+ // pagination next
+ if(obj.paginationShowPrevNext){
+ var lastClass = 'disabled', lastOffset = '';
+ if(current < last){
+ lastClass = 'enabled';
+ lastOffset = 'data-offset="' + next + '"';
+ }
+ endHTML += '<li tabindex="0" title="' + i18n.viewer.pagination.next + '" class="silverButton buttonRight next ' + lastClass + '" ' + lastOffset + '><span>&nbsp;</span></li>';
+ }
+ // create each pagination item
+ for(var i = 1; i <= last; i++) {
+ if(i <= (current + obj.paginationSize) && i >= (current - obj.paginationSize)){
+ if(firstMiddle === 0){
+ firstMiddle = i;
+ }
+ middleHTML += createMiddleItem(i, current);
+ middleCount++;
+ lastMiddle = i;
+ }
+ }
+ // if last middle is last page
+ if(lastMiddle === last){
+ // get remainderStart start
+ remainderStart = firstMiddle - 1;
+ // while not enough remainders
+ while(middleCount < (obj.paginationSize * 2) + 1){
+ // if remainder start is less or equal to first page
+ if(remainderStart <= first){
+ // end while
+ break;
+ }
+ // add item to beginning of middle html
+ middleHTML = createMiddleItem(remainderStart, current) + middleHTML;
+ // increase middle count
+ middleCount++;
+ // decrease remainder start
+ remainderStart--;
+ }
+ }
+ // if first middle is first page
+ else if(firstMiddle === first){
+ // get remainderStart start
+ remainderStart = lastMiddle + 1;
+ // while not enough remainders
+ while(middleCount < (obj.paginationSize * 2) + 1){
+ // if remainder start is greater or equal to last page
+ if(remainderStart >= last){
+ // end while
+ break;
+ }
+ // add item to end of middle html
+ middleHTML += createMiddleItem(remainderStart, current);
+ // increase middle count
+ middleCount++;
+ // increase remainder start
+ remainderStart++;
+ }
+ }
+ // add up HTML
+ html += startHTML + middleHTML + endHTML;
+ // Pagination Spinner Container
+ html += '<li id="paginationSpinner" class="spinnerCon"></li>';
+ // end pagination
+ html += '</ul>';
+ }
+ else{
+ html += '&nbsp;';
+ }
+ html += '<div class="clear"></div>';
+ // insert into html
+ var node = dojo.byId(pagObject);
+ // insert pagination html
+ setNodeHTML(node, html);
+}
+/*------------------------------------*/
+// Configure viewer URL to use
+/*------------------------------------*/
+function getViewerURL(viewer, webmap, owner){
+ // if not defined
+ if(!viewer){
+ // set to default in config
+ viewer = configOptions.mapViewer;
+ }
+ // lowercase viewer string
+ viewer = viewer.toLowerCase();
+ // return url and vars
+ var retUrl = '', queryString = '', firstParamFlag;
+ // if webmap is set
+ if(webmap){
+ // set webmap in query object
+ urlObject.query.webmap = webmap;
+ }
+ else{
+ // if webmap set
+ if(urlObject.query.webmap){
+ // unset it
+ delete urlObject.query.webmap;
+ }
+ }
+ // for each query param
+ for(var key in urlObject.query){
+ // if url has property
+ if(urlObject.query.hasOwnProperty(key)){
+ // if flag not set
+ if(!firstParamFlag){
+ // prepend ?
+ queryString += '?';
+ // flag for first query param
+ firstParamFlag = 1;
+ }
+ else{
+ // prepend &
+ queryString += '&';
+ }
+ // append to query string
+ queryString += key + '=' + encodeURIComponent(urlObject.query[key]);
+ }
+ }
+ // return correct url
+ switch(viewer){
+ // home page link
+ case 'index_page':
+ retUrl = 'index.html' + queryString;
+ return retUrl;
+ // about page link
+ case 'about_page':
+ retUrl = 'about.html' + queryString;
+ return retUrl;
+ // portal viewer link
+ case 'arcgis':
+ return configOptions.portalUrl + 'home/webmap/viewer.html?webmap=' + webmap;
+ // arcgis explorer link
+ case 'explorer':
+ retUrl = "http://explorer.arcgis.com/?open=" + webmap;
+ if(retUrl && location.protocol === "https:") {
+ retUrl = retUrl.replace('http:', 'https:');
+ }
+ return retUrl;
+ // arcgis explorer presentation mode link
+ case 'explorer_present':
+ retUrl = "http://explorer.arcgis.com/?present=" + webmap;
+ if(retUrl && location.protocol === "https:") {
+ retUrl = retUrl.replace('http:', 'https:');
+ }
+ return retUrl;
+ // portal owner page link
+ case 'owner_page':
+ if(configOptions.groupOwner || owner){
+ if(owner){
+ retUrl = configOptions.portalUrl + 'home/user.html?user=' + encodeURIComponent(owner);
+ }
+ else{
+ retUrl = configOptions.portalUrl + 'home/user.html?user=' + encodeURIComponent(configOptions.groupOwner);
+ }
+ }
+ return retUrl;
+ // portal item page
+ case 'item_page':
+ if(configOptions.webmap){
+ retUrl = configOptions.portalUrl + 'home/item.html?id=' + configOptions.webmap;
+ }
+ return retUrl;
+ // portal group page
+ case 'group_page':
+ if(configOptions.groupOwner && configOptions.groupTitle){
+ retUrl = configOptions.portalUrl + 'home/group.html?owner=' + encodeURIComponent(configOptions.groupOwner) + '&title=' + encodeURIComponent(configOptions.groupTitle);
+ }
+ return retUrl;
+ // portal mobile URL data
+ case 'mobile':
+ if(configOptions.agent_ios){
+ retUrl = configOptions.mobilePortalUrl + 'sharing/rest/content/items/' + webmap + '/data';
+ }
+ else if(configOptions.agent_android){
+ retUrl = configOptions.mobilePortalUrl + '?webmap=' + webmap;
+ }
+ return retUrl;
+ case 'mobile_app':
+ // if iOS Device
+ if(configOptions.agent_ios && configOptions.iosAppUrl){
+ retUrl = configOptions.iosAppUrl;
+ }
+ // if Android Device
+ else if(configOptions.agent_android && configOptions.androidAppUrl){
+ retUrl = configOptions.androidAppUrl;
+ }
+ return retUrl;
+ // simple viewer
+ case 'simple':
+ retUrl = 'map.html' + queryString;
+ return retUrl;
+
+ case 'drupal':
+ retUrl = '/drupal78/arcgis/map/' + webmap;
+ return retUrl;
+
+ default:
+ return '';
+ }
+} \ No newline at end of file
diff --git a/javascript/djConfig.js b/javascript/djConfig.js
new file mode 100644
index 0000000..108d1c6
--- /dev/null
+++ b/javascript/djConfig.js
@@ -0,0 +1,22 @@
+// host path regular expression
+var pathRegex = new RegExp(/\/[^\/]+$/);
+var locationPath = location.pathname.replace(pathRegex, '');
+
+// Dojo Config
+var dojoConfig = {
+ parseOnLoad: true,
+ packages: [{
+ name: "esriTemplate",
+ location: 'http://martenh:82/drupal78/sites/all/modules/esri_mapgallery' // locationPath
+ //location: 'abc'
+ }, {
+ name: "myModules",
+ location: locationPath + '/javascript'
+ }, {
+ name: "apl",
+ location: locationPath + '/apl'
+ }]
+};
+
+// Global Variables
+var i18n, searchVal = '', dataOffset, prevVal = "", ACObj, ACTimeout, timer, urlObject, portal, map, locateResultLayer, aoGeocoder, aoGeoCoderAutocomplete, mapFullscreen, resizeTimer, mapCenter; \ No newline at end of file
diff --git a/javascript/home/layout.js b/javascript/home/layout.js
new file mode 100644
index 0000000..23ae7df
--- /dev/null
+++ b/javascript/home/layout.js
@@ -0,0 +1,504 @@
+// Dojo Requires
+dojo.require("esri.arcgis.utils");
+dojo.require("esri.IdentityManager");
+dojo.require("esri.arcgis.Portal");
+dojo.require("dojo.NodeList-manipulate");
+dojo.require("dojo.NodeList-traverse");
+dojo.require("dojox.NodeList.delegate");
+dojo.require("dijit.Dialog");
+dojo.require("dojo.io.script");
+dojo.require("dojo.number");
+/*------------------------------------*/
+// on dojo load
+/*------------------------------------*/
+dojo.addOnLoad(function(){
+ // set default configuration options
+ setDefaultConfigOptions();
+ // set app ID settings and call init after
+ setAppIdSettings(function(){
+ // create portal
+ createPortal(function(){
+ init();
+ });
+ });
+});
+/*------------------------------------*/
+// QUERY FEATURED MAPS
+/*------------------------------------*/
+function queryMaps(data_offset,keywords){
+ // If no offest, set to 1
+ if(!data_offset) {
+ data_offset = 1;
+ }
+ // If no keywords
+ if(!keywords) {
+ keywords = '';
+ }
+ // Call featured maps
+ queryArcGISGroupItems({
+ // Settings
+ id_group : configOptions.group,
+ searchType : configOptions.searchType,
+ sortField : configOptions.sortField,
+ sortOrder : configOptions.sortOrder,
+ pagination: configOptions.showPagination,
+ paginationShowFirstLast: true,
+ paginationShowPrevNext: true,
+ keywords: keywords,
+ perPage : parseInt(configOptions.galleryItemsPerPage, 10),
+ perRow : parseInt(configOptions.galleryPerRow, 10),
+ layout: configOptions.defaultLayout,
+ searchStart : data_offset,
+ // Executed after ajax is returned
+ callback: function(obj,data){
+ // Build featured items
+ buildMapPlaylist(obj,data);
+ }
+ });
+}
+/*------------------------------------*/
+// Insert Home Content
+/*------------------------------------*/
+function insertHomeContent(){
+ // Set home heading
+ if(configOptions.homeHeading){
+ node = dojo.byId('homeHeading');
+ setNodeHTML(node, configOptions.homeHeading);
+ }
+ // Set home intro text
+ if(configOptions.homeSnippet){
+ node = dojo.byId('homeSnippet');
+ setNodeHTML(node, configOptions.homeSnippet);
+ }
+ // Set home right heading
+ if(configOptions.homeSideHeading){
+ node = dojo.byId('homeSideHeading');
+ setNodeHTML(node, configOptions.homeSideHeading);
+ }
+ // Set home right content
+ if(configOptions.homeSideContent){
+ node = dojo.byId('homeSideContent');
+ setNodeHTML(node, configOptions.homeSideContent);
+ }
+}
+/*------------------------------------*/
+// Group auto-complete search
+/*------------------------------------*/
+function groupAutoComplete(acQuery){
+ // Called when searching (Autocomplete)
+ queryArcGISGroupItems({
+ // Settings
+ id_group : configOptions.group,
+ searchType : configOptions.searchType,
+ sortField : configOptions.sortField, // SORTING COLUMN: The allowed field names are title, modified, type, owner, avgRating, numRatings, numComments and numViews.
+ sortOrder : configOptions.sortOrder, // SORTING ORDER: Values: asc | desc
+ keywords: acQuery,
+ perPage : 10,
+ searchStart : 1,
+ // Executed after ajax is returned
+ callback: function(obj,data){
+ // Show auto-complete
+ showGroupAutoComplete(obj,data);
+ }
+ });
+}
+/*------------------------------------*/
+// Hide auto-complete
+/*------------------------------------*/
+function hideGroupAutoComplete(){
+ dojo.query("#searchListUL").removeClass('autoCompleteOpen');
+ dojo.query("#groupAutoComplete").style('display','none');
+}
+/*------------------------------------*/
+// Show auto-complete
+/*------------------------------------*/
+function showGroupAutoComplete(obj, data){
+ var aResults = '';
+ var node;
+ var partialMatch = dojo.query("#searchGroup").attr('value')[0];
+ var regex = new RegExp('(' + partialMatch + ')','gi');
+ if(data.results !== null){
+ dojo.query(".searchList").addClass('autoCompleteOpen');
+ ACObj = data.results;
+ aResults += '<ul class="zebraStripes">';
+ for(var i = 0; i < data.results.length; i++){
+ var layerClass = '';
+ if(i % 2 === 0){
+ layerClass = '';
+ }
+ else{
+ layerClass = 'stripe';
+ }
+ aResults += '<li tabindex="0" class="' + layerClass + '">' + data.results[i].title.replace(regex,'<span>' + partialMatch + '</span>') + '</li>';
+ }
+ aResults += '</ul>';
+ node = dojo.byId('groupAutoComplete');
+ if(node){
+ if(data.results.length > 0){
+ setNodeHTML(node, aResults);
+ }
+ else{
+ setNodeHTML(node, '<p>' + i18n.viewer.errors.noMatches + '</p>');
+ clearTimeout(ACTimeout);
+ ACTimeout = setTimeout(function(){
+ hideGroupAutoComplete();
+ },3000);
+ }
+ dojo.style(node, 'display', 'block');
+ }
+ }
+}
+/*------------------------------------*/
+// Build Map Playlist
+/*------------------------------------*/
+function buildMapPlaylist(obj,data){
+ // hide auto complete
+ hideGroupAutoComplete();
+ // Remove Spinner
+ removeSpinner();
+ // Clear Pagination
+ var node = dojo.byId('maps_pagination');
+ setNodeHTML(node, '');
+ // HTML Variable
+ var html = '';
+ // Get total results
+ var totalItems = data.total;
+ var totalResults = data.results.length;
+ var layout;
+ // If we have items
+ if(totalItems > 0){
+ layout = 'mapsGrid';
+ if(obj.layout === 'list'){
+ layout = 'mapsList';
+ }
+ // If perpage is more than total
+ var fortotal;
+ if(obj.pagination && obj.perPage && obj.perPage < totalResults){
+ // Use per page
+ forTotal = obj.perPage;
+ }
+ else{
+ // Use total
+ forTotal = totalResults;
+ }
+ // Create list items
+ for(var i = 0; i < forTotal; i++) {
+ // variables
+ var appClass = '';
+ var itemTitle;
+ var itemURL;
+ var snippet;
+ var linkTarget;
+ var externalLink = false;
+ // If item has URL
+ if(data.results[i].url){
+ itemURL = data.results[i].url;
+ appClass = ' externalLink';
+ externalLink = true;
+ }
+ else{
+ // url variable
+ itemURL = getViewerURL(configOptions.mapViewer, data.results[i].id);
+ }
+ if(obj.layout === 'list'){
+ itemTitle = data.results[i].title;
+ snippet = '';
+ if(data.results[i].snippet){
+ snippet = data.results[i].snippet;
+ }
+ linkTarget = '';
+ if(configOptions.openGalleryItemsNewWindow || externalLink){
+ linkTarget = 'target="_blank"';
+ }
+ // Build list item
+ html += '<div class="grid_9 sigma">';
+ html += '<div class="item' + appClass + '">';
+ html += '<a ' + linkTarget + ' class="block" id="mapItem' + i + '" title="' + itemTitle + '" href="' + itemURL + '">';
+ if(externalLink){
+ html += '<span class="externalIcon"></span>';
+ }
+ html += '<img alt="' + itemTitle + '" src="' + data.results[i].thumbnailUrl + '" width="200" height="133" />';
+ html += '</a>';
+ html += '<div class="itemInfo">';
+ html += '<strong><a ' + linkTarget + ' class="title" id="mapItemLink' + i + '" title="' + snippet + '" href="' + itemURL + '">' + itemTitle + '</a></strong>';
+ html += '<p>' + snippet + '</p>';
+ html += '</div>';
+ html += '<div class="clear"></div>';
+ html += '</div>';
+ html += '</div>';
+ html += '<div class="clear"></div>';
+ }
+ else{
+ var endRow = false, frontRow = false;
+ var itemClass = '';
+ itemTitle = data.results[i].title;
+ snippet = '';
+ if(data.results[i].snippet){
+ snippet = data.results[i].snippet;
+ }
+ linkTarget = '';
+ if(configOptions.openGalleryItemsNewWindow || externalLink){
+ linkTarget = 'target="_blank"';
+ }
+ // Last row item
+ if((i + 1) % obj.perRow === 0){
+ itemClass = ' omega';
+ endRow = true;
+ }
+ // First row item
+ if((i + 3) % obj.perRow === 0){
+ itemClass = ' alpha';
+ frontRow = true;
+ }
+ // Build grid item
+ html += '<div class="grid_3' + itemClass + '">';
+ html += '<a class="item' + appClass + '" ' + linkTarget + ' id="mapItem' + i + '" title="' + snippet + '" href="' + itemURL + '">';
+ if(externalLink){
+ html += '<span class="externalIcon"></span>';
+ }
+ html += '<img alt="' + itemTitle + '" class="gridImg" src="' + data.results[i].thumbnailUrl + '" width="200" height="133" />';
+ html += '<span class="itemTitle">' + itemTitle + '</span>';
+ html += '</a>';
+ html += '</div>';
+ if(endRow){
+ html += '<div class="clear"></div>';
+ }
+ }
+ }
+ // Close
+ html += '<div class="clear"></div>';
+ }
+ else{
+ // No results
+ html += '<div class="grid_5 suffix_4 sigma"><p class="alert error">' + i18n.viewer.errors.noMapsFound + ' <a tabindex="0" id="resetGroupSearch">' + i18n.viewer.groupPage.showAllMaps + '</a></p></div>';
+ html += '<div class="clear"></div>';
+ }
+ // Insert HTML
+ node = dojo.byId('featuredMaps');
+ if(node){
+ dojo.query(node).removeClass('mapsGrid mapsList').addClass(layout);
+ setNodeHTML(node, html);
+ }
+ // Create pagination
+ createPagination(obj,totalItems,'maps_pagination');
+}
+/*------------------------------------*/
+// Enalbe layout and search options
+/*------------------------------------*/
+function configLayoutSearch(){
+ // if show search or show layout switch
+ if(configOptions.showGroupSearch || configOptions.showLayoutSwitch){
+ // create HTML
+ var html = '', listClass, gridClass;
+ // if show search
+ html += '<div id="searchListCon" class="grid_5 alpha">';
+ if(configOptions.showGroupSearch){
+ html += '<ul id="searchListUL" class="searchList">';
+ html += '<li id="mapSearch" class="iconInput">';
+ html += '<input placeholder="' + i18n.viewer.groupPage.searchPlaceholder + '" id="searchGroup" title="' + i18n.viewer.groupPage.searchTitle + '" value="" autocomplete="off" type="text" tabindex="0" />';
+ html += '<div tabindex="0" title="' + i18n.viewer.main.clearSearch + '" class="iconReset" id="clearAddress"></div>';
+ html += '</li>';
+ html += '<li title="' + i18n.viewer.groupPage.searchTitleShort + '" class="searchButtonLi">';
+ html += '<span tabindex="0" id="searchGroupButton" class="silverButton buttonRight">';
+ html += '<span class="searchButton">&nbsp;</span></span>';
+ html += '</li>';
+ html += '<li id="groupSpinner" class="spinnerCon"></li>';
+ html += '</ul>';
+ html += '<div class="clear"></div>';
+ html += '<div id="acCon"><div id="groupAutoComplete" class="autoComplete"></div></div><div class="clear"></div>';
+ }
+ else{
+ html += '&nbsp;';
+ }
+ html += '</div>';
+ // if show switch
+ html += '<div class="grid_4 omega">';
+ if(configOptions.showLayoutSwitch){
+ if(configOptions.defaultLayout === "list"){
+ listClass = 'active';
+ gridClass = '';
+ }
+ else{
+ listClass = '';
+ gridClass = 'active';
+ }
+ html += '<div class="toggleLayout">';
+ html += '<ul>';
+ html += '<li id="layoutList" class="' + listClass + '" title="' + i18n.viewer.groupPage.listSwitch + '">';
+ html += '<span tabindex="0" class="silverButton buttonRight"><span class="listView">&nbsp;</span></span>';
+ html += '<li id="layoutGrid" class="' + gridClass + '" title="' + i18n.viewer.groupPage.gridSwitch + '">';
+ html += '<span tabindex="0" class="silverButton buttonLeft"><span class="gridView">&nbsp;</span></span>';
+ html += '</li>';
+ html += '<li id="layoutSpinner" class="spinnerCon"></li>';
+ html += '</li>';
+ html += '</ul>';
+ html += '<div class="clear"></div>';
+ html += '</div>';
+ html += '<div class="clear"></div>';
+ }
+ else{
+ html += '&nbsp;';
+ }
+ html += '</div>';
+ html += '<div class="clear"></div>';
+ // if node, insert HTML
+ var node = dojo.byId('layoutAndSearch');
+ setNodeHTML(node, html);
+ }
+}
+/*------------------------------------*/
+// Event Delegations
+/*------------------------------------*/
+function setDelegations(){
+ // Featured maps pagination onclick function
+ dojo.query('#maps_pagination').delegate("ul .enabled", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ // clicked
+ dojo.query(this).addClass('clicked');
+ var placeDom = dojo.query("#maps_pagination ul");
+ // add loading spinner
+ addSpinner("paginationSpinner");
+ // get offset number
+ var data_offset = dojo.query(this).attr('data-offset')[0];
+ dataOffset = data_offset;
+ // query maps function
+ queryMaps(data_offset,searchVal);
+ }
+ });
+ // search button
+ dojo.query(document).delegate("#searchGroupButton", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ var textVal = dojo.query("#searchGroup").attr('value')[0];
+ if(textVal !== prevVal){
+ searchVal = textVal;
+ addSpinner("groupSpinner");
+ queryMaps(1,textVal);
+ prevVal = searchVal;
+ }
+ }
+ });
+ // search reset button
+ dojo.query(document).delegate("#clearAddress, #resetGroupSearch", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ dojo.query('#clearAddress').removeClass('resetActive');
+ dojo.query("#searchGroup").attr('value', '');
+ searchVal = '';
+ addSpinner("groupSpinner");
+ queryMaps(1,'');
+ prevVal = searchVal;
+ hideGroupAutoComplete();
+ }
+ });
+ // list view
+ dojo.query(document).delegate("#layoutList", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ if(configOptions.defaultLayout !== 'list'){
+ configOptions.defaultLayout = 'list';
+ dojo.query('.toggleLayout li').removeClass('active');
+ dojo.query(this).addClass('active');
+ addSpinner("layoutSpinner");
+ queryMaps(dataOffset,searchVal);
+ }
+ }
+ });
+ // grid view
+ dojo.query(document).delegate("#layoutGrid", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ if(configOptions.defaultLayout !== 'grid'){
+ configOptions.defaultLayout = 'grid';
+ dojo.query('.toggleLayout li').removeClass('active');
+ dojo.query(this).addClass('active');
+ addSpinner("layoutSpinner");
+ queryMaps(dataOffset,searchVal);
+ }
+ }
+ });
+ // Reset X click
+ dojo.query(document).delegate(".iconInput .iconReset", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ var obj = dojo.query(this).prevAll('input');
+ clearAddress(obj);
+ }
+ });
+ // auto complete && address specific action listeners
+ dojo.query(document).delegate("#searchGroup", "onkeyup", function(e){
+ checkAddressStatus(this);
+ var aquery = dojo.query(this).attr('value')[0];
+ var alength = aquery.length;
+ if(e.keyCode === 13 && aquery !== '') {
+ clearTimeout (timer);
+ var textVal = dojo.query(this).attr('value');
+ if(textVal !== prevVal){
+ searchVal = textVal;
+ addSpinner("groupSpinner");
+ queryMaps(1,textVal);
+ prevVal = searchVal;
+ }
+ hideGroupAutoComplete();
+ }
+ else if(e.keyCode === 38) {
+ dojo.query('#groupAutoComplete li:last')[0].focus();
+ }
+ else if(e.keyCode === 40) {
+ dojo.query('#groupAutoComplete li:first')[0].focus();
+ }
+ else if(alength >= 2){
+ clearTimeout (timer);
+ timer = setTimeout(function(){
+ groupAutoComplete(aquery);
+ }, 250);
+ }
+ else{
+ hideGroupAutoComplete();
+ }
+ });
+ // Autocomplete key up and click
+ dojo.query(document).delegate("#groupAutoComplete ul li", "onclick,keyup", function(e){
+ if(event.type === 'click' || (e.type === 'keyup' && e.keyCode === 13)){
+ // hide auto complete
+ hideGroupAutoComplete();
+ // get result number
+ var locNum = dojo.indexOf(dojo.query('#groupAutoComplete ul li'), this);
+ // if map has a url
+ var mapURL;
+ if(ACObj[locNum].url){
+ mapURL = ACObj[locNum].url;
+ }
+ else{
+ // item url
+ mapURL = getViewerURL(configOptions.mapViewer, ACObj[locNum].id);
+ }
+ // load map
+ window.location = mapURL;
+ }
+ else if(e.type === 'keyup' && e.keyCode === 40) {
+ dojo.query(this).next('li')[0].focus();
+ }
+ else if(e.type === 'keyup' && e.keyCode === 38) {
+ dojo.query(this).prev('li')[0].focus();
+ }
+ });
+}
+/*------------------------------------*/
+// Init
+/*------------------------------------*/
+function init(){
+ // set default data offset
+ if(!dataOffset){
+ dataOffset = 0;
+ }
+ // set loading text
+ var node = dojo.byId('featuredLoading');
+ setNodeHTML(node, i18n.viewer.groupPage.loadingText);
+ // Query group and then query maps
+ queryGroup(function(){
+ // insert home items
+ insertHomeContent();
+ // Configure grid/list and search
+ configLayoutSearch();
+ // query for maps
+ queryMaps();
+ });
+ // set up event delegations
+ setDelegations();
+} \ No newline at end of file
diff --git a/javascript/map/layout.js b/javascript/map/layout.js
new file mode 100644
index 0000000..5352085
--- /dev/null
+++ b/javascript/map/layout.js
@@ -0,0 +1,905 @@
+// Dojo Requires
+dojo.require("esri.arcgis.utils");
+dojo.require("esri.IdentityManager");
+dojo.require("esri.arcgis.Portal");
+dojo.require("dojo.NodeList-manipulate");
+dojo.require("dojo.NodeList-traverse");
+dojo.require("dojox.NodeList.delegate");
+dojo.require("dijit.Dialog");
+dojo.require("dojo.io.script");
+dojo.require("dojo.number");
+// Map Only
+dojo.require("esri.map");
+dojo.require("esri.dijit.Legend");
+dojo.require("esri.dijit.Scalebar");
+dojo.require("esri.dijit.OverviewMap");
+dojo.require("esri.dijit.BasemapGallery");
+dojo.require("esri.tasks.locator");
+// Localization
+dojo.requireLocalization("esriTemplate","template");
+/*------------------------------------*/
+// on dojo load
+/*------------------------------------*/
+dojo.addOnLoad(function(){
+ // set default options
+ setDefaultConfigOptions();
+ // set app ID settings and call setWebmap after
+ setAppIdSettings(function(){
+ // create portal
+ createPortal(function(){
+ // query group info
+ queryGroup(function(){
+ // set webmap info
+ setWebmap();
+ });
+ });
+ });
+});
+/*------------------------------------*/
+// Sets the webmap to load
+/*------------------------------------*/
+function setWebmap(){
+ // if webmap set
+ if(configOptions.webmap) {
+ // init map page
+ initMap();
+ }
+ // get first map in group if no webmap is set
+ else{
+ // call featured maps function to get 1 webmap
+ queryArcGISGroupItems({
+ // settings
+ id_group: configOptions.group,
+ searchType: "Web Map",
+ filterType: "Web Mapping Application",
+ sortField: configOptions.sortField,
+ sortOrder: configOptions.sortOrder,
+ perPage: 1,
+ // executed after ajax is returned
+ callback: function(obj, data){
+ // if group has at least 1 webmap
+ if(data.results.length > 0){
+ // set webmap
+ configOptions.webmap = data.results[0].id;
+ // init map page
+ initMap();
+ }
+ else{
+ // show error dialog
+ var dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.noSearchResults
+ });
+ dialog.show();
+ }
+ }
+ });
+ }
+}
+/*------------------------------------*/
+// Toggle full screen map view
+/*------------------------------------*/
+function toggleFullscreenMap(value){
+ var buttonText;
+ // Record center of map
+ mapCenter = map.extent.getCenter();
+ // if true, fullscreen
+ if(value){
+ // button text
+ buttonText = i18n.viewer.mapPage.exitFullscreen;
+ // change html class
+ dojo.query("html").addClass('fullScreen');
+ // set buttton classes and text
+ dojo.query("#fullScreen").attr('title',buttonText);
+ // toggle global variable
+ mapFullscreen = true;
+ }
+ // exit fullscreen
+ else{
+ // button text
+ buttonText = i18n.viewer.mapPage.enterFullscreen;
+ // change html class
+ dojo.query("html").removeClass('fullScreen');
+ // set buttton classes and text
+ dojo.query("#fullScreen").attr('title',buttonText);
+ // toggle global variable
+ mapFullscreen = false;
+ }
+ // reset center of map
+ resizeMapAndCenter();
+}
+/*------------------------------------*/
+// Tabs
+/*------------------------------------*/
+function tabMenu(menuObj, buttonObj){
+ // hide all tabs
+ dojo.query('.tabMenu').style('display','none');
+ // remove selected button class
+ dojo.query('#tabMenu .toggleButton').removeClass('buttonSelected');
+ // show new tab
+ dojo.query(menuObj).style('display','block');
+ // set new tab button to selected
+ dojo.query(buttonObj).addClass('buttonSelected');
+}
+/*------------------------------------*/
+// Map Buttons
+/*------------------------------------*/
+function setInnerMapButtons(){
+ var html = '';
+ // fullscreen button
+ html += '<div tabindex="0" title="' + i18n.viewer.mapPage.enterFullscreen + '" class="mapButton buttonSingle" id="fullScreen"><span class="fullScreenButton">&nbsp;</span></div>';
+ // fullscreen button
+ dojo.query(document).delegate("#fullScreen", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ // if currently in full screen
+ if(!mapFullscreen){
+ // enter fullscreen
+ toggleFullscreenMap(true);
+ }
+ else{
+ // exit fullscreen
+ toggleFullscreenMap(false);
+ }
+ }
+ });
+ // if gelocation is available
+ if(navigator.geolocation){
+ html += '<div tabindex="0" id="geoButton" title="' + i18n.viewer.mapPage.geoLocateTitle + '" class="mapButton buttonSingle"><span class="geoLocateButton">&nbsp;</span></div>';
+ dojo.query(document).delegate("#geoButton", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ navigator.geolocation.getCurrentPosition(geoLocateMap);
+ }
+ });
+ }
+ // insert html
+ dojo.place(html, "map", "last");
+}
+/*------------------------------------*/
+// Hide auto-complete
+/*------------------------------------*/
+function hideAutoComplete(){
+ dojo.query(".searchList").removeClass('autoCompleteOpen');
+ dojo.query("#autoComplete").style('display','none');
+}
+/*------------------------------------*/
+// Set map content
+/*------------------------------------*/
+function setDelegations(){
+ // show about button click
+ dojo.query(document).delegate("#showAbout", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ tabMenu('#aboutMenu',this);
+ }
+ });
+ // show legend button click
+ dojo.query(document).delegate("#showLegend", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ tabMenu('#legendMenu',this);
+ }
+ });
+ // escape button when in full screen view
+ dojo.query(document).delegate("body", "onkeyup", function(e){
+ // if esc key and map is fullscreen
+ if(e.keyCode === 27 && mapFullscreen) {
+ // exit fullscreen
+ toggleFullscreenMap(false);
+ }
+ });
+ // Search Button
+ dojo.query(document).delegate("#searchAddressButton", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ locate();
+ hideAutoComplete();
+ }
+ });
+ // Clear address button
+ dojo.query(document).delegate(".iconInput .iconReset", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ var obj = dojo.query(this).prevAll('input');
+ clearAddress(obj);
+ }
+ });
+ // auto complete && address specific action listeners
+ dojo.query(document).delegate("#searchAddress", "onkeyup", function(e){
+ checkAddressStatus(this);
+ var aquery = dojo.query(this).attr('value')[0];
+ var alength = aquery.length;
+ // enter key
+ if(e.keyCode === 13 && aquery !== '') {
+ clearTimeout (timer);
+ clearLocate();
+ locate();
+ hideAutoComplete();
+ }
+ // up arrow key
+ else if(e.keyCode === 38) {
+ dojo.query('#autoComplete li:last')[0].focus();
+ }
+ // down arrow key
+ else if(e.keyCode === 40) {
+ dojo.query('#autoComplete li:first')[0].focus();
+ }
+ // more than 3 chars
+ else if(alength >= 2){
+ clearTimeout (timer);
+ timer = setTimeout(function(){
+ autoComplete(aquery);
+ }, 250);
+ }
+ else{
+ hideAutoComplete();
+ }
+ });
+ // autocomplete result key up
+ dojo.query(document).delegate("#autoComplete ul li", "onclick,keyup", function(e){
+ if(e.type === 'click' || (e.type === 'keyup' && e.keyCode === 13)){
+ var locTxt = dojo.query(this).text();
+ var locNum = dojo.indexOf(dojo.query('#autoComplete ul li'), this);
+ dojo.query('#searchAddress').attr('value', locTxt);
+ showResults(ACObj, locNum);
+ hideAutoComplete();
+ }
+ else if(e.type === 'keyup' && e.keyCode === 40) {
+ dojo.query(this).next('li')[0].focus();
+ }
+ else if(e.type === 'keyup' && e.keyCode === 38) {
+ dojo.query(this).prev('li')[0].focus();
+ }
+ });
+ // clear address
+ dojo.query(document).delegate("#clearAddress", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ clearLocate();
+ hideAutoComplete();
+ }
+ });
+ // toggle legend layers
+ dojo.query(document).delegate("#mapLayerToggle .toggleLayers", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ var dataAttr = dojo.query(this).attr('data-layers')[0].split(',');
+ for(var i = 0; i < dataAttr.length; i++){
+ toggleLayerSwitch(dataAttr[i]);
+ }
+ }
+ });
+}
+/*------------------------------------*/
+// show autocomplete
+/*------------------------------------*/
+function showAutoComplete(geocodeResults){
+ var aResults = '';
+ var partialMatch = dojo.query("#searchAddress").attr('value')[0];
+ var regex = new RegExp('(' + partialMatch + ')','gi');
+ if(geocodeResults !== null){
+ dojo.query(".searchList").addClass('autoCompleteOpen');
+ ACObj = geocodeResults;
+ aResults += '<ul class="zebraStripes">';
+ for(var i = 0; i < geocodeResults.length; i++){
+ var layerClass = '';
+ if(i % 2 === 0){
+ layerClass = '';
+ }
+ else{
+ layerClass = 'stripe';
+ }
+ aResults += '<li tabindex="0" class="' + layerClass + '">' + geocodeResults[i].address.replace(regex,'<span>' + partialMatch + '</span>') + '</li>';
+ }
+ aResults += '</ul>';
+ if(geocodeResults.length > 0){
+ var node = dojo.byId('autoComplete');
+ if(node){
+ setNodeHTML(node, aResults);
+ dojo.style(node, 'display', 'block');
+ }
+ }
+ else{
+ hideAutoComplete();
+ }
+ }
+}
+/*------------------------------------*/
+// map now loaded
+/*------------------------------------*/
+function mapNowLoaded(layers){
+ // Map Loaded Class
+ dojo.query("#map").addClass('mapLoaded');
+ // if overview map
+ if(configOptions.showOverviewMap){
+ //add the overview map
+ var overviewMapDijit = new esri.dijit.OverviewMap({
+ map: map,
+ attachTo: "bottom-left",
+ visible: false
+ });
+ overviewMapDijit.startup();
+ }
+ initUI(layers);
+ // add popup theme
+ dojo.addClass(map.infoWindow.domNode, configOptions.theme);
+}
+/*------------------------------------*/
+// clear the locate graphic
+/*------------------------------------*/
+function clearLocate() {
+ // if locate layer exists
+ if(locateResultLayer){
+ // clear it
+ locateResultLayer.clear();
+ }
+ // reset locate string
+ locateString = "";
+}
+/*------------------------------------*/
+// Locate
+/*------------------------------------*/
+function locate() {
+ var query = dojo.byId("searchAddress").value;
+ if(query){
+ // add loading spinner
+ addSpinner("locateSpinner");
+ // locate string
+ locateString = query;
+ // address object
+ var address = {
+ SingleLine: locateString
+ };
+ // get address and set callback. * includes all fields in query
+ aoGeocoder.addressToLocations(address,["*"]);
+ }
+}
+/*------------------------------------*/
+// search box functions
+/*------------------------------------*/
+function autoComplete(query) {
+ // set global locate string
+ locateString = query;
+ // address object
+ var address = {
+ SingleLine: locateString
+ };
+ // get address and set callback. * includes all fields in query
+ aoGeoCoderAutocomplete.addressToLocations(address,["*"]);
+}
+/*------------------------------------*/
+// Show search results
+/*------------------------------------*/
+function showResults(geocodeResults, resultNumber){
+ // remove spinner
+ removeSpinner();
+ // hide autocomplete
+ hideAutoComplete();
+ // if result found
+ if(geocodeResults.length > 0) {
+ // num result variable
+ var numResult = 0;
+ // if result number
+ if(resultNumber){
+ numResult = resultNumber;
+ }
+ // if point graphic set
+ if(configOptions.pointGraphic){
+ // if locate results
+ if(locateResultLayer) {
+ locateResultLayer.clear();
+ }
+ else{
+ locateResultLayer = new esri.layers.GraphicsLayer();
+ map.addLayer(locateResultLayer);
+ }
+ // create point marker
+ var pointMeters = esri.geometry.geographicToWebMercator(geocodeResults[0].location);
+ var pointSymbol = new esri.symbol.PictureMarkerSymbol(configOptions.pointGraphic, 21, 25).setOffset(0,12);
+ var locationGraphic = new esri.Graphic(pointMeters,pointSymbol);
+ locateResultLayer.add(locationGraphic);
+ }
+ // set extent variables
+ var xminNew, yminNew, xmaxNew, ymaxNew;
+ // if no attributes set
+ if(!geocodeResults[numResult].hasOwnProperty('attributes')){
+ geocodeResults[numResult].attributes = {};
+ }
+ // if one of the extent properteis isn't set
+ if(!geocodeResults[numResult].attributes.hasOwnProperty('West_Lon') || !geocodeResults[numResult].attributes.hasOwnProperty('South_Lat') || !geocodeResults[numResult].attributes.hasOwnProperty('East_Lon') || !geocodeResults[numResult].attributes.hasOwnProperty('North_Lat')){
+ xminNew = parseFloat(geocodeResults[numResult].location.x - 0.011);
+ yminNew = parseFloat(geocodeResults[numResult].location.y - 0.011);
+ xmaxNew = parseFloat(geocodeResults[numResult].location.x + 0.011);
+ ymaxNew = parseFloat(geocodeResults[numResult].location.y + 0.011);
+ }
+ else{
+ xminNew = parseFloat(geocodeResults[numResult].attributes.West_Lon);
+ yminNew = parseFloat(geocodeResults[numResult].attributes.South_Lat);
+ xmaxNew = parseFloat(geocodeResults[numResult].attributes.East_Lon);
+ ymaxNew = parseFloat(geocodeResults[numResult].attributes.North_Lat);
+ }
+ // create new extent
+ var newExtent = new esri.geometry.Extent({
+ xmin: xminNew,
+ ymin: yminNew,
+ xmax: xmaxNew,
+ ymax: ymaxNew,
+ spatialReference: map.extent.spatialReference
+ });
+ // set extent converted to web mercator
+ map.setExtent(esri.geometry.geographicToWebMercator(newExtent));
+ }
+ else{
+ // show error dialog
+ var dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.noSearchResults
+ });
+ dialog.show();
+ }
+}
+/*------------------------------------*/
+// Basemap Gallery
+/*------------------------------------*/
+function createBasemapGallery() {
+ var html = '';
+ // insert HTML for basemap
+ html += '<div tabindex="0" class="silverButton buttonSingle" id="basemapButton"><span class="basemapArrowButton">&nbsp;</span>' + i18n.viewer.mapPage.switchBasemap + '</div>';
+ html += '<div class="clear"></div>';
+ html += '<div id="basemapGallery"></div>';
+ // if node exists
+ var node = dojo.byId("basemapContainer");
+ setNodeHTML(node, html);
+ //add the basemap gallery, in this case we'll display maps from ArcGIS.com including bing maps
+ var basemapGallery = new esri.dijit.BasemapGallery({
+ showArcGISBasemaps: true,
+ bingMapsKey: configOptions.bingMapsKey,
+ map: map
+ }, dojo.create("div"));
+ dojo.byId("basemapGallery").appendChild(basemapGallery.domNode);
+ // start it up!
+ basemapGallery.startup();
+ // if something bad happened
+ dojo.connect(basemapGallery, "onError", function(msg){
+ // show error dialog
+ var dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: msg
+ });
+ dialog.show();
+ });
+ // toggle basemap button
+ dojo.query(document).delegate("#basemapButton", "onclick,keyup", function(event){
+ if(event.type === 'click' || (event.type === 'keyup' && event.keyCode === 13)){
+ // get nodes
+ var buttonNode = dojo.query(this);
+ var node = dojo.byId('basemapGallery');
+ // if they exist
+ if(node && buttonNode){
+ // remove classes
+ buttonNode.removeClass('buttonSelected open');
+ // if already shown
+ if(dojo.style(node, 'display') === 'block'){
+ // hide
+ dojo.style(node, 'display', 'none');
+ }
+ else{
+ // show and add class
+ dojo.style(node, 'display', 'block');
+ buttonNode.addClass('buttonSelected open');
+ }
+ }
+ }
+ });
+}
+/*------------------------------------*/
+// Set search address html
+/*------------------------------------*/
+function setAddressContainer(){
+ var html = '';
+ html += '<div class="grid_4 alpha searchListCon">';
+ if(configOptions.locatorserviceurl && configOptions.showMapSearch){
+ html += '<ul class="searchList">';
+ html += '<li id="mapSearch" class="iconInput">';
+ html += '<input tabindex="0" placeholder="' + i18n.viewer.mapPage.findPlaceholder + '" title="' + i18n.viewer.mapPage.findLocation + '" id="searchAddress" value="" autocomplete="off" type="text" tabindex="1">';
+ html += '<div tabindex="0" title="' + i18n.viewer.main.clearSearch + '" class="iconReset" id="clearAddress"></div>';
+ html += '</li>';
+ html += '<li class="searchButtonLi" title="' + i18n.viewer.mapPage.findLocation + '" id="searchAddressButton"><span tabindex="0" class="silverButton buttonRight"><span class="searchButton">&nbsp;</span></span></li>';
+ html += '<li id="locateSpinner" class="spinnerCon"></li>';
+ html += '</ul>';
+ html += '<div class="clear"></div>';
+ html += '<div id="acCon">';
+ html += '<div id="autoComplete" class="autoComplete"></div>';
+ html += '</div>';
+ html += '<div class="clear"></div>';
+ }
+ else{
+ html += '&nbsp;';
+ }
+ html += '</div>';
+ html += '<div class="grid_5 omega basemapConRel"><div id="basemapContainer">&nbsp;</div>';
+ html += '</div>';
+ html += '<div class="clear"></div>';
+ // Set
+ var node = dojo.byId("addressContainer");
+ setNodeHTML(node, html);
+}
+/*------------------------------------*/
+// Insert Menu Tab HTML
+/*------------------------------------*/
+function insertMenuTabs(){
+ var html = '';
+ html += '<div tabindex="0" title="' + i18n.viewer.sidePanel.legendButtonTitle + '" id="showLegend" class="toggleButton buttonLeft buttonSelected">' + i18n.viewer.sidePanel.legendButton + '</div>';
+ html += '<div tabindex="0" title="' + i18n.viewer.sidePanel.aboutButtonTitle + '" id="showAbout" class="toggleButton buttonRight">' + i18n.viewer.sidePanel.aboutButton + '</div>';
+ html += '<div class="clear"></div>';
+ // Set
+ var node = dojo.byId("tabMenu");
+ setNodeHTML(node, html);
+}
+/*------------------------------------*/
+// Add bottom map buttons
+/*------------------------------------*/
+function addBottomMapButtons(){
+ var html = '';
+ if(configOptions.showExplorerButton && !isMobileUser()){
+ // add open in explorer button
+ html += '<a tabindex="0" target="_blank" href="' + getViewerURL('explorer', configOptions.webmap) + '" class="mapButton buttonSingle">' + i18n.viewer.mapPage.openInExplorer + '</a>';
+ }
+ if(configOptions.showArcGISOnlineButton){
+ // add open in arcgis button
+ html += '<a tabindex="0" target="_blank" href="' + getViewerURL('arcgis', configOptions.webmap) + '" class="mapButton buttonSingle">' + i18n.viewer.mapPage.openInArcGIS + '</a>';
+ }
+ // If mobile user
+ if(isMobileUser() && configOptions.showMobileButtons){
+ // add button
+ html += '<a tabindex="0" href="' + getViewerURL('mobile', configOptions.webmap) + '" class="mapButton buttonSingle">' + i18n.viewer.mapPage.openInMobile + '</a>';
+ // add app button
+ html += '<a tabindex="0" href="' + getViewerURL('mobile_app') + '" class="mapButton buttonSingle">Get Mobile App</a>'; // localize
+ }
+ if(html === ''){
+ html = '&nbsp;';
+ }
+ // insert
+ var node = dojo.byId("mapButtons");
+ setNodeHTML(node, html);
+}
+/*------------------------------------*/
+// Init Map
+/*------------------------------------*/
+function initMap() {
+ // set map content
+ setDelegations();
+ // set map buttons
+ setInnerMapButtons();
+ // ITEM
+ var itemDeferred = esri.arcgis.utils.getItem(configOptions.webmap);
+ itemDeferred.addErrback(function(error) {
+ // show error dialog
+ dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.createMap + error
+ });
+ dialog.show();
+ // hide all content
+ hideAllContent();
+ });
+ itemDeferred.addCallback(function(itemInfo) {
+ var html = '';
+ // if it's a webmap
+ if(itemInfo && itemInfo.item && itemInfo.item.type === 'Web Map'){
+ // insert menu tab html
+ insertMenuTabs();
+ // insert address html
+ setAddressContainer();
+ // if no title set in config
+ if(!configOptions.mapTitle){
+ configOptions.mapTitle = itemInfo.item.title;
+ }
+ // if no subtitle set in config
+ if(!configOptions.mapSnippet){
+ configOptions.mapSnippet = itemInfo.item.snippet;
+ }
+ // if no description set in config
+ if(!configOptions.mapItemDescription){
+ configOptions.mapItemDescription = itemInfo.item.description;
+ }
+ // Set title
+ var titleNode = dojo.byId("title");
+ setNodeHTML(titleNode, configOptions.mapTitle || "");
+ // Set subtitle
+ var subTitleNode = dojo.byId("subtitle");
+ setNodeHTML(subTitleNode, configOptions.mapSnippet || "");
+ // if showMoreInfo is set
+ if(configOptions.showMoreInfo){
+ var d, dateLocale;
+ html = '';
+ html += '<h2>' + i18n.viewer.mapPage.moreInformation + '</h2>';
+ html += '<ul class="moreInfoList">';
+ // Set owner
+ if(itemInfo.item.owner){
+ html += '<li><strong>' + i18n.viewer.mapPage.ownerHeader + '</strong><br /><a href="' + getViewerURL('owner_page', false, itemInfo.item.owner) + '" target="_blank">' + itemInfo.item.owner + '</a></li>';
+ }
+ // item page link
+ html += '<li>';
+ html += '<a id="mapContentsLink" href="' + getViewerURL('item_page') + '" target="_blank">' + i18n.viewer.mapPage.arcgisLink + '</a>';
+ html += '</li>';
+ html += '</ul>';
+ // set html to node
+ var mapMoreInfo = dojo.byId("mapMoreInfo");
+ setNodeHTML(mapMoreInfo, html);
+ }
+ // Set description
+ var descriptionInfo = configOptions.mapItemDescription || "";
+ var descNode = dojo.byId("descriptionContent");
+ setNodeHTML(descNode, '<h2>' + i18n.viewer.mapPage.aboutHeader + '</h2>' + descriptionInfo + '<div class="clear"></div>');
+ // set page title
+ if(configOptions.mapTitle){
+ document.title = configOptions.siteTitle + ' | ' + configOptions.mapTitle;
+ }
+ else{
+ document.title = configOptions.siteTitle;
+ }
+ // add bottom map buttons
+ addBottomMapButtons();
+ // create map
+ var mapDeferred = esri.arcgis.utils.createMap(itemInfo, "map", {
+ mapOptions: {
+ slider: true,
+ sliderStyle: "small",
+ wrapAround180:true,
+ nav: false
+ },
+ ignorePopups:false,
+ bingMapsKey: configOptions.bingMapsKey,
+ geometryServiceURL: configOptions.geometryserviceurl
+ });
+ // map response
+ mapDeferred.addCallback(function(response) {
+ // set map
+ map = response.map;
+ var layers = response.itemInfo.itemData.operationalLayers;
+ // LAYER TOGGLE
+ if(configOptions.showLayerToggle && layers.length > 0){
+ var html = '';
+ var mapLayersNode = dojo.byId('mapLayers');
+ if(mapLayersNode){
+ html += '<h2>' + i18n.viewer.mapPage.layersHeader + '</h2>';
+ html += '<table id="mapLayerToggle">';
+ html += "<tbody>";
+ for(j=0; j < layers.length; j++){
+ var checked;
+ // if feature collection
+ if(layers[j].featureCollection){
+ html += "<tr>";
+ checked = '';
+ if(layers[j].visibility){
+ checked = 'checked="checked"';
+ }
+ // check column
+ html += '<td class="checkColumn"><input tabindex="0" class="toggleLayers" id="layerCheckbox' + j + '" ' + checked + ' type="checkbox" data-layers="';
+ // if feature collection layers
+ if(layers[j].featureCollection.layers){
+ for(k = 0; k < layers[j].featureCollection.layers.length; k++){
+ html += layers[j].featureCollection.layers[k].id;
+ // if not last
+ if(k !== (layers[j].featureCollection.layers.length - 1)){
+ html += ",";
+ }
+ }
+ }
+ // csv
+ else{
+ html += layers[j].id;
+ }
+ html += '" /></td>';
+ // label column
+ html += '<td><label for="layerCheckbox' + j + '">' + layers[j].title + '</label></td>';
+ html += "</tr>";
+ }
+ else{
+ html += "<tr>";
+ checked = '';
+ if(layers[j].visibility){
+ checked = 'checked="checked"';
+ }
+ // check column
+ html += '<td class="checkColumn"><input tabindex="0" class="toggleLayers" id="layerSingleCheckbox' + j + '" ' + checked + ' type="checkbox" data-layers="';
+ html += layers[j].id;
+ html += '" /></td>';
+ // label column
+ html += '<td><label for="layerSingleCheckbox' + j + '">' + layers[j].title + '</label></td>';
+ html += "</tr>";
+ }
+ }
+ html += "</tbody>";
+ html += '</table>';
+ html += '<div class="clear"></div>';
+ setNodeHTML(mapLayersNode, html);
+ }
+ }
+ // ENDLAYER TOGGLE
+ if(map.loaded){
+ mapNowLoaded(layers);
+ }
+ else{
+ dojo.connect(map,"onLoad",function(){
+ mapNowLoaded(layers);
+ });
+ }
+ });
+ mapDeferred.addErrback(function(error) {
+ // show error dialog
+ var dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.createMap + " : " + error
+ });
+ dialog.show();
+ // hide all content
+ hideAllContent();
+ });
+ // LOCATOR
+ aoGeocoder = new esri.tasks.Locator(configOptions.locatorserviceurl);
+ aoGeoCoderAutocomplete = new esri.tasks.Locator(configOptions.locatorserviceurl);
+ dojo.connect(aoGeocoder, "onAddressToLocationsComplete", showResults);
+ dojo.connect(aoGeoCoderAutocomplete, "onAddressToLocationsComplete", showAutoComplete);
+ itemDeferred.addErrback(function(error) {
+ var dialog;
+ // don't i18n this. I'ts returned from the server
+ if (error && error.message === "BingMapsKey must be provided.") {
+ dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.bingError
+ });
+ dialog.show();
+ }
+ else {
+ // show error dialog
+ dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.createMap + " : " + error
+ });
+ dialog.show();
+ // hide all content
+ hideAllContent();
+ }
+ });
+ }
+ else{
+ // show error dialog
+ dialog = new dijit.Dialog({
+ title: i18n.viewer.errors.general,
+ content: i18n.viewer.errors.createMap
+ });
+ dialog.show();
+ // hide all content
+ hideAllContent();
+ }
+ });
+}
+/*------------------------------------*/
+// TOGGLE LAYER
+/*------------------------------------*/
+function toggleLayerSwitch(layerid){
+ var layer = map.getLayer(layerid);
+ if(layer){
+ //if visible hide the layer
+ if(layer.visible === true) {
+ layer.hide();
+ }
+ //otherwise show
+ else {
+ layer.show();
+ }
+ }
+}
+/*------------------------------------*/
+// BUILD LAYERS LIST
+/*------------------------------------*/
+function buildLayersList(layers) {
+ //layers arg is response.itemInfo.itemData.operationalLayers;
+ var layerInfos = [];
+ dojo.forEach(layers, function (mapLayer, index) {
+ var layerInfo = {};
+ if (mapLayer.featureCollection && mapLayer.type !== "CSV") {
+ if (mapLayer.featureCollection.showLegend === true) {
+ dojo.forEach(mapLayer.featureCollection.layers, function (fcMapLayer) {
+ if (fcMapLayer.showLegend !== false) {
+ layerInfo = {
+ "layer": fcMapLayer.layerObject,
+ "title": mapLayer.title,
+ "defaultSymbol": false
+ };
+ if (mapLayer.featureCollection.layers.length > 1) {
+ layerInfo.title += " - " + fcMapLayer.layerDefinition.name;
+ }
+ layerInfos.push(layerInfo);
+ }
+ });
+ }
+ } else if (mapLayer.showLegend !== false && mapLayer.layerObject) {
+ var showDefaultSymbol = false;
+ if (mapLayer.layerObject.version < 10.1 && (mapLayer.layerObject instanceof esri.layers.ArcGISDynamicMapServiceLayer || mapLayer.layerObject instanceof esri.layers.ArcGISTiledMapServiceLayer)) {
+ showDefaultSymbol = true;
+ }
+ layerInfo = {
+ "layer": mapLayer.layerObject,
+ "title": mapLayer.title,
+ "defaultSymbol": showDefaultSymbol
+ };
+ //does it have layers too? If so check to see if showLegend is false
+ if (mapLayer.layers) {
+ var hideLayers = dojo.map(dojo.filter(mapLayer.layers, function (lyr) {
+ return (lyr.showLegend === false);
+ }), function (lyr) {
+ return lyr.id;
+ });
+ if (hideLayers.length) {
+ layerInfo.hideLayers = hideLayers;
+ }
+ }
+ layerInfos.push(layerInfo);
+ }
+ });
+ return layerInfos;
+}
+/*------------------------------------*/
+// INIT UI
+/*------------------------------------*/
+function initUI(layers) {
+ // Set legend header
+ var node = dojo.byId('legendHeader');
+ setNodeHTML(node, i18n.viewer.sidePanel.title);
+ // Set basemap gallery
+ if(configOptions.showBasemapGallery){
+ createBasemapGallery();
+ }
+ // Set map background image
+ dojo.query("#map").style('background-image','none');
+ // Setup resize map
+ dojo.connect(window, "onresize", resizeMap);
+ //add scalebar
+ var scalebar = new esri.dijit.Scalebar({
+ map: map,
+ scalebarUnit: i18n.viewer.main.scaleBarUnits
+ });
+ // Legend Information
+ var layerInfo = buildLayersList(layers);
+ // Build Legend
+ if(layerInfo.length > 0){
+ var legendDijit = new esri.dijit.Legend({
+ map:map,
+ layerInfos:layerInfo
+ },"legendContent");
+ legendDijit.startup();
+ }
+ else{
+ var legendContentNode = dojo.byId('legendContent');
+ setNodeHTML(legendContentNode, i18n.viewer.errors.noLayers);
+ }
+}
+/*------------------------------------*/
+// Resize and Reposition Map
+/*------------------------------------*/
+function mapResizeAndReposition(){
+ map.resize();
+ map.reposition();
+}
+/*------------------------------------*/
+// Resize Map And Center
+/*------------------------------------*/
+function resizeMapAndCenter(){
+ clearTimeout(resizeTimer);
+ resizeTimer = setTimeout(function() {
+ mapResizeAndReposition();
+ if(mapCenter.x && mapCenter.y){
+ setTimeout(function() {
+ map.centerAt(mapCenter);
+ mapResizeAndReposition();
+ }, 500);
+ }
+ }, 500);
+}
+/*------------------------------------*/
+// Resize Map
+/*------------------------------------*/
+function resizeMap() {
+ clearTimeout(resizeTimer);
+ if(map){
+ resizeTimer = setTimeout(function() {
+ mapResizeAndReposition();
+ }, 500);
+ }
+} \ No newline at end of file
diff --git a/nls/template.js b/nls/template.js
new file mode 100644
index 0000000..3201957
--- /dev/null
+++ b/nls/template.js
@@ -0,0 +1,77 @@
+define({
+ "root": ({
+ "viewer": {
+ "main": {
+ "scaleBarUnits": "english",
+ "clearSearch": "Clear"
+ },
+ "errors": {
+ "createMap": "Unable to create map",
+ "general": "Error",
+ "bingError": "Deploying this application requires your own Bing Maps key.",
+ "noLayers": "No operational layers",
+ "noSearchResults": "Sorry, no results were found.",
+ "noGroupResults": "The group could not be found.",
+ "noMatches": "No matches found.",
+ "noMapsFound": "No maps were found."
+ },
+ "sidePanel": {
+ "title": "Legend",
+ "legendButton": "Legend",
+ "legendButtonTitle": "Map Legend",
+ "aboutButton": "About",
+ "aboutButtonTitle": "About Map",
+ "message": "No operational layers"
+ },
+ "groupPage": {
+ "showAllMaps": "Show all maps",
+ "searchTitle": "Search this group",
+ "searchTitleShort": "Search",
+ "searchPlaceholder": "Search maps",
+ "itemTitle": "View map",
+ "gridSwitch": "Switch to Grid View",
+ "listSwitch": "Switch to List View",
+ "loadingText": "Loading Maps&hellip;"
+ },
+ "mapPage": {
+ "findLocation": "Find a location",
+ "findPlaceholder": "Locate an address",
+ "aboutHeader": "About this map",
+ "layersHeader": "Layers",
+ "enterFullscreen": "Fullscreen View",
+ "exitFullscreen": "Exit Fullscreen",
+ "arcgisLink": "Item Details",
+ "moreInformation": "More Information",
+ "geoLocateTitle": "Use Current Location",
+ "openInMobile": "Open in Mobile App",
+ "openInArcGIS": "ArcGIS Online",
+ "openInExplorer": "ArcGIS Explorer",
+ "ownerHeader": "Owner:",
+ "switchBasemap": "Switch Basemap"
+ },
+ "pagination": {
+ "previous": "Previous",
+ "next": "Next",
+ "first": "First Page",
+ "last": "Last Page",
+ "helip": "&hellip;",
+ "page": "Page"
+ }
+ }
+ }),
+ "ar": 1,
+ "de": 1,
+ "es": 1,
+ "fr": 1,
+ "it": 1,
+ "ja": 1,
+ "ko": 1,
+ "nl": 1,
+ "no": 1,
+ "pl": 1,
+ "pt-br": 1,
+ "ro": 1,
+ "ru": 1,
+ "sv": 1,
+ "zh-cn": 1
+}); \ No newline at end of file