Geofield Map is an advanced, complete and easy-to-use Geo Mapping solution for Drupal 8+, based on and fully compatible with the Geofield module, that lets you manage the Geofield with an interactive Map both in back-end and in the front-end.
It represents the perfect solution to:
- geolocate (with one or more Locations / Geofields) any fieldable Drupal entity throughout an Interactive Geofield Map widget;
- render each Content's Locations throughout a fully customizable Interactive Geofield Map Formatter;
- expose and query Contents throughout fully customizable Map Views Integration;
- implement advanced front-end Google Maps with Marker Icon & Infowindow advanced customizations, custom Google Map Styles and Marker Clustering capabilities;
- customize Map Geometries properties (Lines & Polylines, Polygons,
Multipolygons, etc.), based on Google Maps Polygons APIs;
Technical Functionalities and specifications
The actual module release implements the following components:
Geofield Map widget
An highly customizable Map widget,
providing an interactive and very intuitive map on which to perform localization and input of geographic coordinates throughout:
- MULTIPOINTS Geofield mapping support;
- Search Address Geocoding throughout Google Maps Geocoder service and
Google Maps Places Autocomplete Service or throughout other Geocoder providers provided by the Geocoder module integration;
- Google Map or Leaflet Map JS libraries and interfaces;
- Map click and marker dragging, with instant reverse geocoding;
- HTML5 Geolocation of the user position;
- the possibility to permanently store the Geocoded address into the Entity Title
or in a "string type" field (among the content's ones);
- etc.
Geofield Map Formatter
An higly customizable Google Map formatter, by which render and expose the Geo contents throughout:
A "Geofield Google Map (static)" formatter is also available, that renders a
Google Map, accordingly to the Google Maps Static API (only Points supported, and not Geometries such as Polylines, Polygons, etc.).
Views Integration
A dedicated Geofield Map View style plugin able to render a Views result on a higly customizable Google Map,
with Marker and Infowindow specifications and Markers Clustering capabilities.
Advanced Google Map and Markeclustering Features for the front-end maps
Both in Geofield Map Formatter and in the Geofield Map View style it is possible:
Basic Installation and Use
Geofield Map module needs to be installed using Composer to manage Drupal site dependencies, which will also download the required Geofield Module dependency and PHP libraries).
It means simply running the following command from your project root (where the main composer.json file is sited):
$ composer require 'drupal/geofield_map'
Once done, you can setup the following:
- Geofield Widget: In a Content Type including a Geofield Field, go to "Manage form display" and select "Geofield Map" as Geofield Widget. Specify the Widget further settings for both Google or Leaflet Map types;
- Geofield Google Map Formatter: In a Content Type including a Geofield Field, go to "Manage display" and select "Geofield Google Map" as Geofield field Formatter. Specify the Formatter further settings for specific personalization;
- Geofield Map Views: In a View Display select the Geofield Google Map Format, and be sure to add a Geofield type field in the fields list. Specify the View Format settings for specific personalization;
Hints for Advanced Use
- For each GeofieldMapWidget it is possible the enable (and custom configure) addresses Geocoding via the Google Maps Places Autocomplete Service.
- GeofieldMapWidget uses Leaflet MapTypes/Tiles pre-defined as LeafletTileLayers D8 plugins, but any third party module is able to define and add its new LeafletTileLayer Plugins;
- As default (configurable) option, eventual overlapping markers will be Spiderfied, with the support of the Overlapping Marker Spiderfier Library (for Google Maps);
- Add, enable and configure the Geoocoder module for D8 to enable Geocoder Control (with Autocomplete) for quick Address search and Geofield Map Pan & Zoom functionalities;
- The Geofield Map View style plugin will pass to the client js (as drupalSettings.geofield_google_map[mapid] & Drupal.geoFieldMap[mapid] variables) the un-hidden fields values of the View, as markers/features' properties data;
Geofield Map Dynamic Markers Theming & Legends Specifications
The Geofield Map (since 2.x version) allows the Geofield Map View definition of Custom Markers & Icons Images based on dynamic values of the Map features.
Moreover a custom Geofield Map Legend Block is defined by the module and is able to expose each Map Theming logics in the form of fully configurable and impressive Legends.
Geofield Map introduces the MapThemer Plugin system that allows the definition of MapThemer Plugins able to dinamically differentiate Map Features/Markers based on Contents Types, Taxonomy Terms, Values, etc.
Each Plugin Type provides the automatic definition of a related Legend Build, that is able to fill the definition of a Custom GeofieldMapLegend block.
At the moment the following two Geofield Map Themers plugin types have been defined:
- Custom Icon Image File, allows the definition of a unique custom Marker Icon, valid for all the Map Markers;
- Entity Type, allows the definition of different Marker Icons based on the View filtered Entity Types/Bundles;
- Taxonomy Term, allows the definition of different Marker Icons based on Taxonomy Terms reference field in View;
- List Type Field, allows the definition of different Marker Icons based on List (Options) Type fields in View;
As Drupal 8+ Plugin system based, the Geofield MapThemers Plugin and Legend block system is fully extendable and overridable.
You, as Drupal 8+ developer, are free to override and extend the existing ones, or create your custom MapThemer based on your specific needs and logics.
New: SVG Image files are now supported for Marker Icons, via the Svg Image module
How to use.
In a Geofield Map View Display, just go into its settings and choose the wanted MapThemer in the new Map Theming Options section/fieldset.
It is possible to associate a Drupal Managed File for each MapThemer plugin value and even the Icon Image style the Icon should be rendered on the Map. The Value labels and Icons might have an alias, might be reordered and might be hidden from the correspondent Legend Block.
Once defined and configured the Legend you are free to place it, once or several times, as a normal Drupal 8+ block on the pages, with your logics and contextual rules.
Notes & Warnings