A beautifully simple Google Map field type for Craft CMS. Full localization support, compatible with Matrix, supports searching by location and sorting by distance.
Click here for the Craft 3 version.
Copy the simplemap
folder into craft/plugins
.
Create the field as you would any other.
The field type will return an array containing the following:
lat
- The selected locations latitudelng
- The selected locations longitudezoom
- The zoom level of the mapaddress
- The address of the selected locationparts
- See below
This means you can use {{ myMapField.lat }}
.
parts
This contains the locations address, broken down into its constituent parts. All values are optional so you'll need to have checks on any you use to make sure they exist.
A list of the available values can be found here.
To access the short version of any part, append _short
to the end of its name.
e.g. {{ myMapField.country_short }}
.
You can search for elements using the location specified in your map field. When searching by your map field you also have the option to sort the results by distance.
{% set entries = craft.entries.myMapField({
location: 'Maidstone, Kent',
country: 'GB',
radius: 100,
unit: 'mi'
}).orderBy('distance').all() %}
location
: Can either be an address string (requires a Google Maps Geocoding API key) or a Lat Lng Array ({ 'lat': 51.27219908, 'lng': 0.51545620 }
).country
: Optional. Restrict the search to a specific country (useful for non-specific searches, i.e. town name). Must be valid 2-letter ISO code (recommended), or full country name.radius
: Optional. The radius around the location to search. Defaults to50
.unit
: Optional. The unit of measurement for the search. Can be eitherkm
(kilometers) ormi
(miles). Defaults tokm
.
You can access your browser API key in templates using craft.simpleMap.apiKey
.
This plugin does not generate a front-end map; how you do that and what map library you use is up to you. However, since we have received a lot of questions asking how to do so, here are a couple of examples.
Using Google Maps:
<div id="map"></div>
<script>
var map;
function initMap() {
map = new google.maps.Map(document.getElementById("map"), {
center: {
lat: {{ entry.myMapField.lat }},
lng: {{ entry.myMapField.lng }}
},
zoom: {{ entry.myMapField.zoom }}
});
}
</script>
<script src="https://maps.googleapis.com/maps/api/js?key={{ craft.simpleMap.apiKey }}&callback=initMap" async defer></script>
And Mapbox:
<script src="https://api.mapbox.com/mapbox-gl-js/v0.21.0/mapbox-gl.js"></script>
<link href="https://api.mapbox.com/mapbox-gl-js/v0.21.0/mapbox-gl.css" rel="stylesheet" />
<div id="map" style="width: 400px; height: 300px;"></div>
<script>
mapboxgl.accessToken = "YOUR_API_KEY";
var map = new mapboxgl.Map({
container: "map",
style: "mapbox://styles/mapbox/streets-v9",
center: [
{{ entry.myMapField.lng }},
{{ entry.myMapField.lat }}
]
});
</script>
If you need to convert a string address to a Lat/Lng you can do so using the
craft.simpleMap.getLatLngFromAddress($addressString[, $country])
variable.
An example of this would be wanting to convert a customers delivery address to a
Lat/Lng, to display it on a map.
$address
- The string address you want to convert.$country
- Optional. Restrict the conversion to a specific country (useful for non-specific searches, i.e. town name). Must be valid 2-letter ISO code (recommended), or full country name.
{% set location = craft.simpleMap.getLatLngFromAddress("Ether Creative, Maidstone", "GB") %}
{{ location.lat }}
{{ location.lng }}
In addition to the plugins settings withing the Craft CP, you can use a config file. Copy config.php
from the plugins folder to craft/config/simplemap.php
and change the settings as needed.
- Added ability to define settings via config file
- Fixed error when saving #92 #94 (via @taylordaughtry)
- Fixed bug where distance was always
null
- Fixed bug where maps didn't save
- The maps
parts
now contains all available options from here (including the_small
variants). Any options without values are returned as empty strings. - Added
craft.simpleMap.getLatLngFromAddress($addressString[, $country])
.
- Added ability to restrict location search by country
- New icon!
- It is now possible to save the field using only an address (useful for saving via the front-end, requires Geocoding).
- Improved the field's validation.
- Improved the efficiency of the location search query.
- The field is now previewable in the entries table (via @joshuabaker)
- Fixed a bug where
SimpleMap_MapModel
__toString()
would't always return a string.
- Fixed bug where some browsers would consider some decimals invalid in the Lat/Lng inputs #46
- Fixed
CDbException
when trying to search by invalid location.mapField.distance
will returnNULL
in this case #48
- Added fix for slightly major bug in 1.6.0 that meant any non-translatable fields would stop displaying old data. #44
- Added alternative Server API key setting #38
- Fix maps not saving because of troubles with dots and commas #41 - @Zae
- Non-translatable fields now actually don’t translate #43
- Added error handling for failed server geocode requests #37
- You can no longer tap to move the marker on mobile (drag map instead) #33
- Fixed the Lat/Lng inputs not accepting decimals in Chrome #36
- Added FeedMe 2 support! (thanks to @engram-design, #23)
- Added support for Neo. #21
- Fixed when using the address search, locations that are non-specific (i.e. the name of a country) will no longer be forced to be specific.
- Fixed "Unnamed Roads" no longer change to a different unnamed road when the map is re-loaded. #26
- Disabled scrollwheel on map, #27
- Details about the selected location are now populated server-side, no more JavaScript shittery! #30
- Improved locale specific address details #24
- If the query limit is reached, the map will re-try after 1 second, a maximum of 5 times. #19
- The address of the map will be returned when output as a string, i.e.
{{ entry.myMapField }}
. #29
- Changed Git folder structure to exclude surplus files from plugin directory
- Lat / Lng fields are now visible and editable
- Added option to hide Lat / Lng fields
- Added option to hide the map, leaving only the address input
- Added ability to restrict auto-complete by country, address type, and boundary
- Added
_short
prefix to all parts, returning the short value. You will need to re-save your entries for this to take effect. - Fixed map JS erroring when in globals
- Merged API keys into one
- The address input automatically updates the map after paste
- Browser API key can now be accessed in templates
- Added Browser API key setting
- Fixed bug where map would not display correctly when in a secondary tab.
- Added search and sorting support.
- Added optional Google API Server Key setting
- WARNING: This update will break any map fields that are NOT standalone (global) or in a Matrix field.
- Fix #5 via @jripmeester - Fixed Lat / Lng being populated with function, not number.
- Added
parts
to the fieldtype output.
- Merged #2 & #3 from @cballenar
- #2 - Field now stores map zoom
- #3 - Improved handling of unknown locations
- Improved error message display
- Added link to docs
- Added releases json for updates
- Fixed: Hidden Lat/Lng/Address fields are now cleared when the Address Search input is empty.
- Initial Release
Copyright © 2017 Ether Creative hello@ethercreative.co.uk
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.