-
-
Notifications
You must be signed in to change notification settings - Fork 16
Plugin Events Reference
You can add Dynamic Actions to respond to various events from the map.
- addressFound [v1.0]
- addFeature / removeFeature [v1.1]
- batchLoaded [v1.2]
- directions [v1.0]
- geolocate [v1.0]
- loadedGeoJson [v1.1]
- mapBoundsChanged [v1.5]
- mapCenterChanged [v1.5]
- mapClick [v1.0]
- mapContextMenu [v1.5]
- mapDoubleClick [v1.5]
- mapDrag [v1.5]
- mapDragStart / mapDragEnd [v1.5]
- mapHeadingChanged [v1.5]
- mapIdle [v1.5]
- mapLoaded [v1.0]
- mapMouseMove [v1.5]
- mapMouseOver / mapMouseOut [v1.5]
- mapProjectionChanged [v1.5]
- mapRefreshed [v1.1]
- mapTilesLoaded [v1.5]
- mapTiltChanged [v1.5]
- mapTypeChanged [v1.5]
- mapZoomChanged [v1.5]
- markerAdded [v1.1]
- markerClick [v1.0]
- markerDrag [v1.0]
- mouseoverFeature / mouseoutFeature [v1.3]
- selectFeature / unselectFeature [v1.1]
- setGeometry [v1.1]
- spiderfy / unspiderfy [v1.2]
NOTE: make sure to set Fire on Initialization set to No on the Action for your dynamic actions; otherwise you will get javascript errors like "Cannot read property 'lat' of undefined TypeError: Cannot read property 'lat' of undefined".
This fires if the user enters an address, or clicks the map, and a geocode result is found. The event provides the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.lat
= the Latitude of the address location -
this.data.lng
= the Longitude of the address location -
this.data.result
= the GeocoderResult - this will be an object comprising the following attributes, among others:-
address_components
- an array of GeocoderAddressComponent, each consisting of an array of types (usually the first one is the most useful, e.g. "street_number"), ashort_name
and along_name
. See below for more details. -
formatted_address
- the formatted address string
-
this.data.result.address_components
The following javascript could be put in a dynamic action which would search for certain desired components from the address and put them in items on the page:
var ac = this.data.result.address_components;
for (i=0; i<ac.length; i++) {
switch (ac[i].types[0]) {
case "street_number" :
$s("P1_STREET_NUMBER", ac[i].short_name);
break;
case "route" :
$s("P1_STREET_NAME", ac[i].short_name);
break;
case "locality" :
$s("P1_LOCALITY", ac[i].short_name);
break;
case "administrative_area_level_1" :
$s("P1_STATE", ac[i].short_name);
$s("P1_STATE_NAME", ac[i].long_name);
break;
case "country" :
$s("P1_COUNTRY", ac[i].short_name);
$s("P1_COUNTRY_NAME", ac[i].long_name);
break;
case "postal_code" :
$s("P1_POSTCODE", ac[i].short_name);
break;
}
}
The various values that may be found in types
may be found here.
Only applicable if the Drawing Library is enabled (by setting Drawing Mode). This fires when the user adds or removes a feature. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.feature
= the feature that was added or removed (google.maps.Data.Feature object)
This fires after each intermediate batch of results has been loaded. Only occurs if the Rows Per Batch attribute is set. The event provides the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.countPins
= number of pins retrieved by the query so far -
this.data.southwest
= south-west bound {lat, lng} of the pins retrieved by the query so far -
this.data.northeast
= north-east bound {lat, lng} of the pins retrieved by the query so far
This fires if directions are shown. The event provides the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.distance
= total estimated distance, in metres -
this.data.duration
= total estimated travel time, in seconds -
this.data.legs
= number of legs (hops) in the journey -
this.data.directions
= the google.maps.DirectionsResult with all the details of the route [added in v1.2]
This fires if the geolocate option is on and the user's current location was able to be determined. The event provides the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.lat
= the approximate Latitude of the user's current location -
this.data.lng
= the approximate Longitude of the user's current location
Only applicable if the Option: Drag & Drop GeoJSON is set. This fires after a GeoJSON document (whether a file or a JSON fragment) is dropped onto the map and successfully loaded. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.geoJson
= the GeoJSON document as a parsed JSON object -
this.data.features
= array of google.maps.Data.Features -
this.data.filename
= the name of the file (if available) [added in v1.5]
Added in Release 1.5. Fires if the bounds (lat,lng points of the northwest, southeast, etc.) of the visible map are changed (e.g. in response to the user panning or zooming the map). The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.center
= the {lat, lng} of the center of the visible map -
this.data.southwest
= the {lat, lng} of the south-west bound of the visible map -
this.data.northeast
= the {lat, lng} of the north-east bound of the visible map -
this.data.zoom
= the zoom level (0..23) -
this.data.heading
= the heading (compass heading of aerial imagery, degrees clockwise from North) -
this.data.tilt
= the tilt (0 or 45) -
this.data.mapType
= the map type (roadmap, satellite, hybrid or terrain)
Added in Release 1.5. Fires if the center (lat,lng) of the visible map is changed (e.g. in response to the user panning the map). The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.center
= the {lat, lng} of the center of the visible map -
this.data.southwest
= the {lat, lng} of the south-west bound of the visible map -
this.data.northeast
= the {lat, lng} of the north-east bound of the visible map -
this.data.zoom
= the zoom level (0..23) -
this.data.heading
= the heading (compass heading of aerial imagery, degrees clockwise from North) -
this.data.tilt
= the tilt (0 or 45) -
this.data.mapType
= the map type (roadmap, satellite, hybrid or terrain)
This fires when the user clicks in the free area of the map. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.lat
= the Latitude of the point where the user clicked -
this.data.lng
= the Longitude of the point where the user clicked
Added in Release 1.5. Fires when the user invokes the context menu (e.g. using the right mouse button) in the map. Only fires if the Detailed Mouse Events option is enabled. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.lat
= the Latitude of the point where the user clicked -
this.data.lng
= the Longitude of the point where the user clicked
Added in Release 1.5. Fires when the user double-clicks in the map. Only fires if the Detailed Mouse Events option is enabled. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.lat
= the Latitude of the point where the user clicked -
this.data.lng
= the Longitude of the point where the user clicked
Added in Release 1.5. Fires repeatedly while the user drags the map. Only fires if the Detailed Mouse Events option is enabled. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.lat
= the Latitude of the point where the mouse cursor was positioned -
this.data.lng
= the Longitude of the point where the mouse cursor was positioned
Added in Release 1.5. Fires when the user starts or stops dragging the map. Only fires if the Detailed Mouse Events option is enabled. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.lat
= the Latitude of the point where the mouse cursor was positioned -
this.data.lng
= the Longitude of the point where the mouse cursor was positioned
Added in Release 1.5. Fires if the map heading is changed. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.center
= the {lat, lng} of the center of the visible map -
this.data.southwest
= the {lat, lng} of the south-west bound of the visible map -
this.data.northeast
= the {lat, lng} of the north-east bound of the visible map -
this.data.zoom
= the zoom level (0..23) -
this.data.heading
= the heading (compass heading of aerial imagery, degrees clockwise from North) -
this.data.tilt
= the tilt (0 or 45) -
this.data.mapType
= the map type (roadmap, satellite, hybrid or terrain)
Added in Release 1.5. Fires when the map becomes idle after panning or zooming. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.center
= the {lat, lng} of the center of the visible map -
this.data.southwest
= the {lat, lng} of the south-west bound of the visible map -
this.data.northeast
= the {lat, lng} of the north-east bound of the visible map -
this.data.zoom
= the zoom level (0..23) -
this.data.heading
= the heading (compass heading of aerial imagery, degrees clockwise from North) -
this.data.tilt
= the tilt (0 or 45) -
this.data.mapType
= the map type (roadmap, satellite, hybrid or terrain)
This fires after the map has been initialised and the data first loaded. It does not fire, however, if the plugin does not have a data source (i.e. a query). The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.countPins
= number of pins retrieved by the query [added in v1.1] -
this.data.southwest
= south-west bound {lat, lng} of the pins retrieved by the query [added in v1.1] -
this.data.northeast
= north-east bound {lat, lng} of the pins retrieved by the query [added in v1.1]
To have some JavaScript code run after the map is loaded but prior to the data being retrieved, use the Initialization JavaScript Code attribute.
Added in Release 1.5. This fires when the user moves the mouse over the map. Only fires if the Detailed Mouse Events option is enabled. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.lat
= the Latitude of the point where the mouse cursor was positioned -
this.data.lng
= the Longitude of the point where the mouse cursor was positioned
Added in Release 1.5. This fires when the user's mouse enters or exits the map. Only fires if the Detailed Mouse Events option is enabled. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.lat
= the Latitude of the point where the mouse cursor was positioned -
this.data.lng
= the Longitude of the point where the mouse cursor was positioned
Added in Release 1.5. Fires when the map projection is changed. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object
Tip: call
$("#map_mymap").reportmap("instance").map.getProjection()
to get the Projection object.
This event is identical to mapLoaded except that it does not fire on the initial page load, but fires whenever the region is subsequently refreshed again. It does not fire if the plugin does not have a data source (i.e. a query). The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.countPins
= number of pins retrieved by the query [added in v1.1] -
this.data.southwest
= south-west bound {lat, lng} of the pins retrieved by the query [added in v1.1] -
this.data.northeast
= north-east bound {lat, lng} of the pins retrieved by the query [added in v1.1]
Added in Release 1.5. Fires when the visible map tiles have finished loading. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.center
= the {lat, lng} of the center of the visible map -
this.data.southwest
= the {lat, lng} of the south-west bound of the visible map -
this.data.northeast
= the {lat, lng} of the north-east bound of the visible map -
this.data.zoom
= the zoom level (0..23) -
this.data.heading
= the heading (compass heading of aerial imagery, degrees clockwise from North) -
this.data.tilt
= the tilt (0 or 45) -
this.data.mapType
= the map type (roadmap, satellite, hybrid or terrain)
Added in Release 1.5. Fires when the map tilt is changed. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.center
= the {lat, lng} of the center of the visible map -
this.data.southwest
= the {lat, lng} of the south-west bound of the visible map -
this.data.northeast
= the {lat, lng} of the north-east bound of the visible map -
this.data.zoom
= the zoom level (0..23) -
this.data.heading
= the heading (compass heading of aerial imagery, degrees clockwise from North) -
this.data.tilt
= the tilt (0 or 45) -
this.data.mapType
= the map type (roadmap, satellite, hybrid or terrain)
Added in Release 1.5. Fires when the map type (e.g. roadmap, satellite, etc.) is changed. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.center
= the {lat, lng} of the center of the visible map -
this.data.southwest
= the {lat, lng} of the south-west bound of the visible map -
this.data.northeast
= the {lat, lng} of the north-east bound of the visible map -
this.data.zoom
= the zoom level (0..23) -
this.data.heading
= the heading (compass heading of aerial imagery, degrees clockwise from North) -
this.data.tilt
= the tilt (0 or 45) -
this.data.mapType
= the map type (roadmap, satellite, hybrid or terrain)
Added in Release 1.5. Fires when the map zoom is changed. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.center
= the {lat, lng} of the center of the visible map -
this.data.southwest
= the {lat, lng} of the south-west bound of the visible map -
this.data.northeast
= the {lat, lng} of the north-east bound of the visible map -
this.data.zoom
= the zoom level (0..23) -
this.data.heading
= the heading (compass heading of aerial imagery, degrees clockwise from North) -
this.data.tilt
= the tilt (0 or 45) -
this.data.mapType
= the map type (roadmap, satellite, hybrid or terrain)
This fires after the map data is loaded or refreshed, for each new pin that has been added to the map. If the pin was previously already shown on the map (based on record ID), this event does not fire for that pin. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.id
= the value of theid
column from the SQL Query -
this.data.name
= the value of thename
column from the SQL Query -
this.data.lat
= the Latitude of the marker location -
this.data.lng
= the Longitude of the marker location -
this.data.attr01
..this.data.attr10
= additional flex fields from the SQL query, if provided -
this.data.marker
= the google.maps.Marker object [added in v1.1]
This fires when the user clicks on one of the report markers that were shown on the map. Works for all the pin-type visualisations. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.id
= the value of theid
column from the SQL Query -
this.data.name
= the value of thename
column from the SQL Query -
this.data.lat
= the Latitude of the marker location -
this.data.lng
= the Longitude of the marker location -
this.data.attr01
..this.data.attr10
= additional flex fields from the SQL query, if provided -
this.data.marker
= the google.maps.Marker object [added in v1.1]
NOTE: if the Draggable option is set, the lat/lng will be the marker's current location, not necessarily its original location.
NOTE: for the Info Layer visualisation, the event will fire if the user clicks within the extent of the HTML content rendered.
Only applicable if the Draggable option is switched on. This fires after the user drags one of the report markers to another location on the amp. The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.id
= the value of theid
column from the SQL Query -
this.data.name
= the value of thename
column from the SQL Query -
this.data.lat
= the Latitude of the new marker location -
this.data.lng
= the Longitude of the new marker location -
this.data.attr01
..this.data.attr10
= additional flex fields from the SQL query, if provided -
this.data.marker
= the google.maps.Marker object [added in v1.1]
This fires when the user moves the mouse over or out from a feature (i.e. one loaded via geoJson). The event has the following attributes accessible via JavaScript:
-
this.data.map
= the google.maps.Map object -
this.data.feature
= the feature that was selected or unselected (google.maps.Data.Feature object)
You can access any properties associated with the feature via the getProperty
function, e.g. this.data.feature.getProperty('name')
. Properties can also be set using setProperty
.
This fires when the user selects or unselects a feature (i.e. one loaded via geoJson). (v1.2: only fires if the Drawing Library is enabled (by setting Drawing Mode)). The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.feature
= the feature that was selected or unselected (google.maps.Data.Feature object)
You can access any properties associated with the feature via the getProperty
function, e.g. this.data.feature.getProperty('name')
. Properties can also be set using setProperty
.
This fires when the user changes the geometry of a feature (i.e. drags it to a new location). Only applicable if the Drawing Library is enabled (by setting Drawing Mode). The event has the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.feature
= the feature that was added (google.maps.Data.Feature object) -
this.data.newGeometry
= the new geometry (google.maps.Data.Geometry) for the feature -
this.data.oldGeometry
= the old geometry (google.maps.Data.Geometry) for the feature
Applicable if the Visualisation is set to Spiderfier. These fire when the spiderfier "spiderfies" or "unspiderfies" one or more pins. For example, if a cluster of pins are very close together, and the user clicks on one of them, the spiderfier spreads the pins out in a circle or spiral, and then the "spiderfy" event fires. If the user then clicks on some other unrelated pin, or zooms in or out of the map, the spiderifier restores the original position of the pins, and the "unspiderfy" event fires. These events have the following attributes accessible via Javascript:
-
this.data.map
= the google.maps.Map object -
this.data.markers
= an array of google.maps.Marker objects that were spiderfied or unspiderfied