New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

leaflet-editable

Package Overview
Dependencies
Maintainers
1
Versions
15
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

leaflet-editable

Make geometries editable in Leaflet

  • 0.2.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
13K
increased by2.88%
Maintainers
1
Weekly downloads
 
Created
Source

# Leaflet.Editable

Make geometries editable in Leaflet.

This is not a plug and play UI, and will not. This is a minimal, lightweight, and fully extendable API to control editing of geometries. So you can easily build your own UI with your own needs and choices.

See the demo UI.

Design keys:

  • only the core needs
  • no UI, instead hooks everywhere needed
  • everything programatically controlable
  • MultiPolygon/MultiPolyline support
  • Polygons' holes support
  • touch support
  • tests

Note: only geojson features are supported for now: Marker, Polyline, Polygon, and MultiPolygon/MultiPolylines (no Rectangle, Circle…)

## Quick start

Allow Leaflet.Editable in the map options:

var map = L.map('map', {editable: true});

Then, to start editing an existing feature, call the enableEdit method on it:

var polyline = L.polyline([[43.1, 1.2], [43.2, 1.3],[43.3, 1.2]]).addTo(map);
polyline.enableEdit();

If you want to draw a new line:

map.editTools.startPolyline();  // map.editTools has been created
                                // by passing editable: true option to the map

If you want to continue an existing line:

polyline.continueForward();
// or
polyline.continueBackward();

## API

Leaflet.Editable is made to be extendable, and you have three ways to customize the behaviour: using options, listening to events, or extending.

### L.Map

Leaflet.Editable add options and events to the L.Map object.

#### Options

option namedefaultusage
editablefalseWhether to create a L.Editable instance at map init or not.
editOptions{}Options to pass to L.Editable when instanciating.
Events
event namepropertiesusage
editable:createdlayerFired when a new feature (Marker, Polyline…) has been created.
editable:enablelayerFired when an existing feature is ready to be edited
editable:disablelayerFired when an existing feature is not ready anymore to be edited
editable:editinglayerFired as soon as any change is made to the feature geometry
editable:drawing:startlayerFired when a feature is to be drawn
editable:drawing:endlayerFired when a feature is not drawn anymore
editable:drawing:cancellayerFired when user cancel drawing while a feature is being drawn
editable:drawing:finishlayerFired when user finish drawing a feature
editable:vertex:ctrlclickoriginalEvent, latlng, vertex, layerFired when a click having ctrlKey is issued on a vertex
editable:vertex:shiftclickoriginalEvent, latlng, vertex, layerFired when a click having shiftKey is issued on a vertex
editable:vertex:altclickoriginalEvent, latlng, vertex, layerFired when a click having altKey is issued on a vertex
editable:vertex:contextmenuoriginalEvent, latlng, vertex, layerFired when a contextmenu is issued on a vertex
editable:vertex:deletedoriginalEvent, latlng, vertex, layerFired after a vertex has been deleted by user

L.Editable

You will usually have only one instance of L.Editable, and generally the one created automatically at map init: map.editTools. It's the toolbox you will use to create new feature, and also the object you will configure with options. Let's see them. Note: you can pass them when creating a map using the editOptions key.

option namedefaultusage
polylineClassL.PolylineClass to be used when creating a new Polyline
polygonClassL.PolygonClass to be used when creating a new Polygon
markerClassL.MarkerClass to be used when creating a new Marker
drawingCSSClassleaflet-editable-drawingCSS class to be added to the map container while drawing
editLayernew L.LayerGroup()Layer used to store edit tools (vertex, line guide…)
vertexMarkerClassL.Editable.VertexMarkerClass to be used as vertex, for path editing
middleMarkerClassL.Editable.MiddleMarkerClass to be used as middle vertex, pulled by the user to create a new point in the middle of a path
polylineEditorClassL.Editable.PolylineEditorClass to be used as Polyline editor
polygonEditorClassL.Editable.PolygonEditorClass to be used as Polygon editor
markerEditorClassL.Editable.MarkerEditorClass to be used as Marker editor

TO BE CONTINUED…

Keywords

FAQs

Package last updated on 03 Aug 2014

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc