var jekyllMaps = (function () { 'use strict'; return { data: [], maps: [], initializeMap: initializeMap, initializeCluster: initializeCluster, register: register, render: render, processCluster: processCluster }; /** * Setup Google Maps options and call renderer. */ function initializeMap() { this.options = { mapTypeId: google.maps.MapTypeId.ROADMAP, center: new google.maps.LatLng(0, 0), zoom: 12 } this.mapReady = true; this.render(); } /** * Register map data to be rendered once Google Maps API is loaded. * * @param String id * @param Array locations * @param Object settings */ function register(id, locations, settings) { this.data.push({id: id, locations: locations, settings: settings}); this.render(); } /** * Render maps data if Google Maps API is loaded. */ function render() { if (!this.mapReady) return; while (this.data.length > 0) { var data = this.data.pop(), bounds = new google.maps.LatLngBounds(), options = Object.assign({}, this.options, data.settings), map = new google.maps.Map(document.getElementById(data.id), options), infoWindow = new google.maps.InfoWindow(), markers = data.locations.map(function (location) { return createMarker(location, options.showMarkerPopup); }); map.fitBounds(bounds); google.maps.event.addListenerOnce(map, 'bounds_changed', onBoundsChanged); if (options.useCluster) { this.maps.push({map: map, markers: markers}); this.processCluster(); } } function createMarker(location, showMarkerPopup) { var position = new google.maps.LatLng(location.latitude, location.longitude), marker = new google.maps.Marker({ position: position, title: location.title, image: location.image, url: location.url, map: map }); bounds.extend(position); if (showMarkerPopup) marker.addListener('click', markerPopup); return marker; } function markerPopup() { var contentString = '