hedera-web/forms/cms/location/location.js

117 lines
2.5 KiB
JavaScript
Raw Normal View History

var gmapsIsLoaded = false;
2016-09-26 09:28:47 +00:00
Hedera.Location = new Class
({
2016-09-26 09:28:47 +00:00
Extends: Hedera.Form
2015-01-31 01:05:12 +00:00
,locations: null
,activate: function ()
{
this.gui.loaderPush ();
2015-01-31 01:05:12 +00:00
var sql = 'SELECT lat, lng, title, address, postcode, city, province, phone, language FROM location';
this.conn.execQuery (sql, this.onLocationsDone.bind (this));
if (!gmapsIsLoaded)
{
gmapsLoadedCallback = this.gmapsLoaded.bind (this);
Vn.includeJs ('https://maps.google.com/maps/api/js'+
'?sensor=false&callback=gmapsLoadedCallback', null, true);
}
else
this.gmapsLoaded ();
}
2015-01-31 01:05:12 +00:00
,onLocationsDone: function (resultSet)
{
this.locations = resultSet.fetchResult ();
this.allLoaded ();
}
,gmapsLoaded: function ()
{
this.gui.loaderPop ();
gmapsIsLoaded = true;
2015-01-31 01:05:12 +00:00
this.allLoaded ();
}
,allLoaded: function ()
{
if (!this.locations || !gmapsIsLoaded)
return;
var options = {
2015-03-06 23:33:54 +00:00
zoom: 4
,mapTypeId: google.maps.MapTypeId.ROADMAP
,center: new google.maps.LatLng (46.0, 4.0)
};
2015-03-06 23:33:54 +00:00
var div = this.$('form');
var gmap = new google.maps.Map (div, options);
2017-04-08 11:42:27 +00:00
var row;
2017-04-08 11:42:27 +00:00
while (row = this.locations.fetchObject ())
this.createMarker (row, gmap);
}
2017-04-08 11:42:27 +00:00
,createMarker: function (row, gmap)
{
var div = document.createElement ('div');
2015-01-31 01:05:12 +00:00
div.className = 'marker';
var h = document.createElement ('h3');
2017-04-08 11:42:27 +00:00
h.appendChild (document.createTextNode (row.title));
div.appendChild (h);
2015-01-31 01:05:12 +00:00
var p = document.createElement ('p');
2017-04-08 11:42:27 +00:00
p.appendChild (document.createTextNode (row.address));
2015-01-31 01:05:12 +00:00
div.appendChild (p);
var p = document.createElement ('p');
2017-04-08 11:42:27 +00:00
p.appendChild (document.createTextNode (row.postcode +' '+ row.city));
2015-01-31 01:05:12 +00:00
div.appendChild (p);
var p = document.createElement ('p');
2017-04-08 11:42:27 +00:00
p.appendChild (document.createTextNode (row.province));
2015-01-31 01:05:12 +00:00
div.appendChild (p);
var p = document.createElement ('p');
2017-04-08 11:42:27 +00:00
p.appendChild (document.createTextNode (row.phone));
2015-01-31 01:05:12 +00:00
div.appendChild (p);
var lat = new google.maps.LatLng (
2017-04-08 11:42:27 +00:00
row.lat,
row.lng
2015-01-31 01:05:12 +00:00
);
var marker = new google.maps.Marker ({
position: lat
,tilte: location.title
,map: gmap
});
var infoWindow = new google.maps.InfoWindow ({
content: div
});
google.maps.event.addListener (marker, 'click',
this.openInfoWindow.bind (this, infoWindow, gmap, marker));
2015-01-31 01:05:12 +00:00
if (Vn.Locale.language
2017-04-08 11:42:27 +00:00
&& Vn.Locale.language == row.language)
this.openInfoWindow (infoWindow, gmap, marker);
}
,openInfoWindow: function (infoWindow, gmap, marker)
{
if (this.openedWindow)
this.openedWindow.close ();
infoWindow.open (gmap, marker);
this.openedWindow = infoWindow;
}
});