<!DOCTYPE html>
<html>

  <head>
    <script type="text/javascript" data-require="google-maps@*" data-semver="1.0.0" src="http://maps.google.com/maps/api/js?sensor=false"></script>
    <script type="text/javascript" data-require="lodash-underscore@2.4.1" data-semver="2.4.1" src="https://rawgithub.com/lodash/lodash/2.4.1/dist/lodash.underscore.min.js"></script>
    <script type="text/javascript" data-require="angular.js@1.2.21" data-semver="1.2.21" src="https://code.angularjs.org/1.2.21/angular.js"></script>
    <script type="text/javascript" data-require="angular-google-maps@*" data-semver="1.1.13" src="https://rawgithub.com/nlaplante/angular-google-maps/1.1.13/dist/angular-google-maps.min.js"></script>
    <link rel="stylesheet" href="style.css" />
    <script type="text/javascript" src="script.js"></script>
  </head>

  <body ng-app="appMap">
    <div ng-controller="MapCtrl">
      <google-map center="[0, 0]"
                  draggable="true"
                  zoom="map.zoom"
                  control="map.control"
                  events="map.events">
        <markers models="places"
                 icon="'icon'"
                 doCluster="false"
                 coords="'self'"
                 events="marker.events"
                 options="marker.options"
                 control="marker.control">
        </markers>
      </google-map>
      
      <ul>
        <li ng-repeat="place in places">
          <button ng-disabled="place.id === currentPlaceId" ng-click="selectMarker(place.id)">{{ 'marker id:' + place.id }}</button>
        </li>
      </ul>
      
      
    </div>
  </body>

</html>


app = angular.module('appMap', ['google-maps']);


app.controller('MapCtrl', function($scope, $timeout) {
  
  var img_base64 = {
    small: 'http://huisx.nl/images/reddot2.png',
    //small: '',
    
    //big: ''
    big: 'http://huisx.nl/images/reddot1.png'
    
  };
  
  $scope.places = [{id:5262130,latitude:52.34985,longitude:4.88261,icon:img_base64.small},{id:2565685,latitude:52.35086,longitude:4.868575,icon:img_base64.small},{id:2204287,latitude:52.3495,longitude:4.88379,icon:img_base64.small},{id:5224846,latitude:52.34572,longitude:4.877543,icon:img_base64.small},{id:3754387,latitude:52.34975,longitude:4.879244,icon:img_base64.small},{id:5052270,latitude:52.34407,longitude:4.87429,icon:img_base64.small},{id:5052274,latitude:52.34407,longitude:4.87429,icon:img_base64.small},{id:1660247,latitude:52.34376,longitude:4.873905,icon:img_base64.small},{id:4802088,latitude:52.34186,longitude:4.874022,icon:img_base64.small},{id:4634588,latitude:52.347439,longitude:4.870012,icon:img_base64.small},{id:5251926,latitude:52.34744,longitude:4.870009,icon:img_base64.small},{id:5266390,latitude:52.3496,longitude:4.87,icon:img_base64.small},{id:4742990,latitude:52.346492,longitude:4.870712,icon:img_base64.small},{id:1299421,latitude:52.3472,longitude:4.8796,icon:img_base64.small},{id:660984,latitude:52.3471378,longitude:4.87931,icon:img_base64.small},{id:4725604,latitude:52.3471,longitude:4.87826,icon:img_base64.small},{id:4829643,latitude:52.345073,longitude:4.875631,icon:img_base64.small},{id:5094258,latitude:52.34649,longitude:4.880015,icon:img_base64.small},{id:1591397,latitude:52.34513,longitude:4.883148,icon:img_base64.small},{id:4721708,latitude:52.34619,longitude:4.883388,icon:img_base64.small},{id:1015936,latitude:52.34407,longitude:4.874383,icon:img_base64.small},{id:1530779,latitude:52.34274,longitude:4.872451,icon:img_base64.small},{id:1787219,latitude:52.3455732,longitude:4.8744046,icon:img_base64.small},{id:2274381,latitude:52.3471825,longitude:4.8850114,icon:img_base64.small},{id:2352605,latitude:52.3476341,longitude:4.8834213,icon:img_base64.small},{id:2568893,latitude:52.34713,longitude:4.878575,icon:img_base64.small},{id:2598347,latitude:52.34798,longitude:4.867927,icon:img_base64.small},{id:2964477,latitude:52.34626,longitude:4.884553,icon:img_base64.small},{id:3010781,latitude:52.3486,longitude:4.87986,icon:img_base64.small},{id:3104913,latitude:52.35112,longitude:4.876394,icon:img_base64.small},{id:3130467,latitude:52.347,longitude:4.88443,icon:img_base64.small},{id:3196281,latitude:52.34599,longitude:4.878054,icon:img_base64.small},{id:3246467,latitude:52.34376,longitude:4.875086,icon:img_base64.small},{id:3295503,latitude:52.35011,longitude:4.882539,icon:img_base64.small},{id:3437799,latitude:52.342,longitude:4.87254,icon:img_base64.small},{id:3441219,latitude:52.34222,longitude:4.87344,icon:img_base64.small},{id:3530813,latitude:52.34218,longitude:4.871509,icon:img_base64.small},{id:3530839,latitude:52.35056,longitude:4.881187,icon:img_base64.small},{id:3573675,latitude:52.34622,longitude:4.87951,icon:img_base64.small},{id:3644337,latitude:52.34536,longitude:4.875772,icon:img_base64.small},{id:3743791,latitude:52.3428,longitude:4.870342,icon:img_base64.small},{id:3819389,latitude:52.34967,longitude:4.874842,icon:img_base64.small},{id:3899167,latitude:52.34377,longitude:4.870698,icon:img_base64.small},{id:3923457,latitude:52.34398,longitude:4.87366,icon:img_base64.small},{id:3954713,latitude:52.34558,longitude:4.874845,icon:img_base64.small},{id:3965743,latitude:52.34796,longitude:4.868642,icon:img_base64.small}];
  
  $scope.map = {
      control: {},
      zoom: 4,
      events: {}
  };
  
  $scope.marker = {
  	control: {},
      options: {
        draggable: true,
      },
      events: {
        dragend: function(marker, eventName, place) {
          place.latitude = marker.getPosition().lat();
          place.longitude = marker.getPosition().lng();
        }
      }
  };
  
  $scope.centerMap = function() {
      var bounds = new google.maps.LatLngBounds();
      
      for(var i = 0; i < $scope.places.length; i++) {
        var place = $scope.places[i];
          bounds.extend(new google.maps.LatLng(place.latitude, place.longitude));
      }
      
      $scope.map.control.getGMap().fitBounds(bounds);
  };
  
  $timeout(function() {
    $scope.centerMap();
  });
  
  $scope.selectMarker = function(id) {
    _($scope.places).forEach(function(place) {
			if(place.id === id) {
			  $scope.currentPlaceId = id;
				place.icon = img_base64.big;
			}
			else {
				place.icon = img_base64.small;
			}
		});
  }
  
});
/* Styles go here */

.angular-google-map-container {
    width: 100%;
    height: 300px;
}