Solved

Javascript function not initializing Google API

Posted on 2008-06-20
6
612 Views
Last Modified: 2013-11-19
Hello,

I have a function called initializePoint that is working properly and I am trying to have a similar function called initializeStreet run and display in a div called Pano.  initializeStreet is not displaying properly however when I click on the tab info box.  Can somebody take a peek at my javascript and tell me if I am making some sort of glaring newbie error?  I am attaching .js file below.

You can also click on a listing to the right and then select the Street View tab to see the example here:
http://progresstechlabs.com/gmaps/integrate/index.php
var map;

var centerLatitude = 26.589450;

var centerLongitude = -81.819848;

var startZoom = 13;

var deselectCurrent = function() {};

var myPano;

    

function initializeStreet(pointData) {

      var fenwayPark = new GLatLng(pointData.latitude, pointData.longitude);

      panoramaOptions = { latlng:fenwayPark };

      myPano = new GStreetviewPanorama(document.getElementById("pano"), panoramaOptions);

      GEvent.addListener(myPano, "error", handleNoFlash);

    }

    

function handleNoFlash(errorCode) {

      if (errorCode == FLASH_UNAVAILABLE) {

        alert("Error: Flash doesn't appear to be supported by your browser");

        return;

      }

    } 
 

function initializePoint(pointData) {

	var point = new GLatLng(pointData.latitude, pointData.longitude);

	var marker = new GMarker(point);

	var listItem = document.createElement('li');

	var listItemLink = listItem.appendChild(document.createElement('a'));

	var visible = false;
 

	listItemLink.href = "#";

	listItemLink.innerHTML = '<img width=90 border=1 height=68 align=right src=http://www.retsfl.com/rets_images/'+pointData.mls+'.jpg>'+'<strong>MLS #:' + pointData.mls + '</strong><BR>Price: $' + pointData.price + '<BR>Bedrooms: ' + pointData.bedrooms + '/ Baths: ' + pointData.baths + '<BR>Sq. Ft: ' + pointData.sqft ;

	

	var focusPoint = function() {

		deselectCurrent();

		listItem.className = 'current';

		deselectCurrent = function() { listItem.className = ''; }

		var infoTabs = [

		new GInfoWindowTab("Listing", '<img width=300 border=1 height=227 align=right src=http://www.retsfl.com/rets_images/'+pointData.mls+'.jpg>'+'<strong>MLS #:' + pointData.mls + '</strong><BR>Price: $' + pointData.price + '<BR>Bedrooms: ' + pointData.bedrooms + '/ Baths: ' + pointData.baths + '<BR>Sq. Ft: ' + pointData.sqft + '<BR><BR><span style="font: 10px Helvetica, sans-serif;">Address:<BR>' + pointData.streetfull ),

		new GInfoWindowTab("More Info", "Data"),

		new GInfoWindowTab("Street View", '<div name="pano" id="pano" style="width: 300px; height: 227px"></div>'),

		new GInfoWindowTab("Agent Info", '<strong>Agent/Office:</strong><BR><li>' + pointData.agentfirstname + ' ' + pointData.agentlastname + ', ' + pointData.office + '<br><strong><font color=red><h4>Are you ready to take a closer look?</h4></font>Fill out the form below to email the agent immediately:<BR><label><input name="Name" type="text" id="Name" value="Name" /></label><br /><label><input name="Phone" type="text" id="Phone" value="Phone" /></label><br /><label><input name="Email" type="text" id="Email" value="Email" /></label><br /><textarea name="textarea" id="textarea" cols="25" rows="3"></textarea><br /><label><input type="submit" name="Contact Agent" id="Contact Agent" value="Contact Agent" /></label>')		

		];

		marker.openInfoWindowTabsHtml(infoTabs,{

		selectedTab:0,

		maxWidth:420

	});

		map.panTo(point);

		return false;

	}
 

	GEvent.addListener(marker, 'click', focusPoint);	

	listItemLink.onclick = focusPoint;
 

	pointData.show = function() {

		if (!visible) {

			document.getElementById('sidebar-list').appendChild(listItem);

			map.addOverlay(marker);

			visible = true;

		}

	}

	pointData.hide = function() {

		if (visible) {

			document.getElementById('sidebar-list').removeChild(listItem);

			map.removeOverlay(marker);

			visible = false;

		}

	}
 

	pointData.show();

}
 
 
 

function initializeSortTab(type) {

	var listItem = document.createElement('li');

	var listItemLink = listItem.appendChild(document.createElement('a'));
 

	listItemLink.href = "#";

	listItemLink.innerHTML = type;

	listItemLink.onclick = function() {

		changeBodyClass('standby', 'loading');
 

		for(id in markers) {

			if (markers[id].type == type || 'All' == type)

				markers[id].show();

			else

				markers[id].hide();	

		}
 

		changeBodyClass('loading', 'standby');
 

		return false;

	}
 

	document.getElementById('filters').appendChild(listItem);

}

/* [listing 6-22 end] */
 

function windowHeight() {

	// Standard browsers (Mozilla, Safari, etc.)

	if (self.innerHeight)

		return self.innerHeight;

	// IE 6

	if (document.documentElement && document.documentElement.clientHeight)

		return document.documentElement.clientHeight;

	// IE 5

	if (document.body)

		return document.body.clientHeight;

	// Just in case.

	return 0;

}
 

function handleResize() {

	var height = windowHeight() - document.getElementById('toolbar').offsetHeight - 30;

	document.getElementById('map').style.height = height + 'px';

	document.getElementById('sidebar').style.height = height + 'px';

}
 

function changeBodyClass(from, to) {

	document.body.className = document.body.className.replace(from, to);

	return false;

}
 

function init() {

	var type;

	var allTypes = { 'All':[] };

	

	document.getElementById('button-sidebar-hide').onclick = function() { return changeBodyClass('sidebar-right', 'nosidebar'); };

	document.getElementById('button-sidebar-show').onclick = function() { return changeBodyClass('nosidebar', 'sidebar-right'); };

	handleResize();

	

	map = new GMap(document.getElementById("map"));

	map.addControl(new GSmallMapControl());

	map.addControl(new GMapTypeControl());

	map.setCenter(new GLatLng(centerLatitude, centerLongitude), startZoom);

	

	/* [listing 6-21] */

	for(id in markers) {

		initializePoint(markers[id]);

		allTypes[markers[id].type] = true;

	}
 

	for(type in allTypes) {

		initializeSortTab(type);

	}

	/* [listing 6-21 end] */
 

	changeBodyClass('loading', 'standby');

}
 

window.onresize = handleResize;

window.onload = init;

window.onunload = GUnload;

Open in new window

0
Comment
Question by:pda4me
  • 3
  • 3
6 Comments
 
LVL 3

Expert Comment

by:JayeshKitukale
ID: 21836259
From initial study I think you have never called the function initializeStreet anywhere in the code!
0
 

Author Comment

by:pda4me
ID: 21836318
Hello,

How do I call the function, can you show me where/how to do this?

Thanks!
0
 
LVL 3

Expert Comment

by:JayeshKitukale
ID: 21836326
in function initializePoint(pointData)
before this line:
map.panTo(point);
Try this and let me know if it works as I am not able to run the code here.
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 3

Accepted Solution

by:
JayeshKitukale earned 500 total points
ID: 21836335
As in:
.
.
maxWidth:420
});
initializeStreet(pointData); << Add this line
map.panTo(point);
return false;
.
.
0
 

Author Comment

by:pda4me
ID: 21836347
Awesome!  Thanks!
0
 

Author Closing Comment

by:pda4me
ID: 31469374
Many thanks!!
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction Knockoutjs (Knockout) is a JavaScript framework (Model View ViewModel or MVVM framework).   The main ideology behind Knockout is to control from JavaScript how a page looks whilst creating an engaging user experience in the least …
JavaScript has plenty of pieces of code people often just copy/paste from somewhere but never quite fully understand. Self-Executing functions are just one good example that I'll try to demystify here.
Viewers will learn about basic arrays, how to declare them, and how to use them. Introduction and definition: Declare an array and cover the syntax of declaring them: Initialize every index in the created array: Example/Features of a basic arr…
The viewer will learn the benefit of using external CSS files and the relationship between class and ID selectors. Create your external css file by saving it as style.css then set up your style tags: (CODE) Reference the nav tag and set your prop…

911 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

24 Experts available now in Live!

Get 1:1 Help Now