Strapi plugin logo for Leaflet Geoman

Leaflet Geoman
Plugin verified by Strapi

The Strapi Leaflet Geoman plugin seamlessly integrates with Leaflet, allowing users to draw and customize various geometry figures, creating a GeoJSON collection for effortless spatial data representation.

Strapi-Leaflet-Geoman

Meilisearch-Strapi

A Strapi plugin allowing you to implement a Leaflet-Geoman custom field into your content-types, which can be used to pick and retrieve locations.

✨ Usage

The API response of a Strapi content-type implementing this leaflet-geoman custom field could look as follows:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
{
  "type": "FeatureCollection",
  "features": [
    {
      "type": "Feature",
      "geometry": {
        "type": "Point | Polygon | MultiLineString | LineString",
          "coordinates": [-104.99404, 39.75621]
      },
      "properties": {
      	"style": {
          "color": "#059669",
          "weight": 8
        },
      }
    }
  ]
}

You can configure globally this plugin inside your Strapi dashboard's settings tab (e.g. to enter leaflet tile url, attribution etc.).

Preview

Also plugin can be configured per collection entity.

Preview

Now you can use Strapi Leaflet Geoman as a custom field.

Preview

❗ Requirements

🔧 Installation

You just need to install the strapi-leaflet-geoman package via npm, at the root of your strapi project.

npm:

npm i strapi-leaflet-geoman

yarn:

yarn add strapi-leaflet-geoman

To make Strapi Leaflet Geoman work, you should take a look at the next section.

After restarting your Strapi app, Strapi Leaflet Geoman should be listed as one of your plugins.

🚀 Strapi Configuration (required)

Allow all Google Maps assets to be loaded correctly by customizing the strapi::security middleware inside ./config/middlewares.js.

Instead of:

1
2
3
4
5
export default [
  // ...
  'strapi::security',
  // ...
];

Write:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
export default [
  // ...
  {
    name: 'strapi::security',
    config: {
      contentSecurityPolicy: {
        useDefaults: true,
        directives: {
          "connect-src": ["'self'", "https:"],
          "script-src": [
            "'self'",
            "unsafe-inline",
            "https://*.basemaps.cartocdn.com",
          ],
          "media-src": [
            "'self'",
            "blob:",
            "data:",
            "https://*.basemaps.cartocdn.com",
            "https://tile.openstreetmap.org",
          ],
          "img-src": [
            "'self'",
            "blob:",
            "data:",
            "https://*.basemaps.cartocdn.com",
            "market-assets.strapi.io",
            "https://tile.openstreetmap.org",
          ],
        },
      },
    },
  },
  // ...
];

Install now

npm install strapi-leaflet-geoman

STATS

11 GitHub stars75 weekly downloads

Last updated

203 days ago

Strapi Version

4.0.0 and above

Author

github profile image for Hadjiu Sorin
Hadjiu Sorin

Useful links

Create your own plugin

Check out the available plugin resources that will help you to develop your plugin or provider and get it listed on the marketplace.