From c78789848cf25b9935fe8aa22175652a2fb8ed21 Mon Sep 17 00:00:00 2001 From: Hans Then Date: Sat, 5 Oct 2024 15:30:49 +0200 Subject: [PATCH 1/2] Add event handlers to the draw plugin This makes the draw plugin more dynamic. It allows the user to add `JsCode` event handlers to the generated layers. --- folium/plugins/draw.py | 29 ++++++++++++++++++++++++----- requirements.txt | 2 +- 2 files changed, 25 insertions(+), 6 deletions(-) diff --git a/folium/plugins/draw.py b/folium/plugins/draw.py index 95155f8e1..06bef61ba 100644 --- a/folium/plugins/draw.py +++ b/folium/plugins/draw.py @@ -5,7 +5,7 @@ class Draw(JSCSSMixin, MacroElement): - """ + ''' Vector drawing and editing plugin for Leaflet. Parameters @@ -25,6 +25,9 @@ class Draw(JSCSSMixin, MacroElement): edit_options : dict, optional The options used to configure the edit toolbar. See https://leaflet.github.io/Leaflet.draw/docs/leaflet-draw-latest.html#editpolyoptions + on : dict, optional + Event handlers to attach to the created layer. Pass a mapping from the + names of the events to their `JsCode` handlers. Examples -------- @@ -32,15 +35,25 @@ class Draw(JSCSSMixin, MacroElement): >>> Draw( ... export=True, ... filename="my_data.geojson", + ... show_geometry_on_click=False, ... position="topleft", ... draw_options={"polyline": {"allowIntersection": False}}, ... edit_options={"poly": {"allowIntersection": False}}, + ... on={ + ... "click": JsCode( + ... """ + ... function(event) { + ... alert(JSON.stringify(this.toGeoJSON())); + ... } + ... """ + ... ) + ... }, ... ).add_to(m) For more info please check https://leaflet.github.io/Leaflet.draw/docs/leaflet-draw-latest.html - """ + ''' _template = Template( """ @@ -68,11 +81,15 @@ class Draw(JSCSSMixin, MacroElement): console.log(coords); }); {%- endif %} + + {%- for event, handler in this.on.items() %} + layer.on( + "{{event}}", + {{handler}} + ); + {%- endfor %} drawnItems_{{ this.get_name() }}.addLayer(layer); }); - {{ this._parent.get_name() }}.on('draw:created', function(e) { - drawnItems_{{ this.get_name() }}.addLayer(e.layer); - }); {% if this.export %} document.getElementById('export').onclick = function(e) { var data = drawnItems_{{ this.get_name() }}.toGeoJSON(); @@ -111,6 +128,7 @@ def __init__( show_geometry_on_click=True, draw_options=None, edit_options=None, + on=None, ): super().__init__() self._name = "DrawControl" @@ -120,6 +138,7 @@ def __init__( self.show_geometry_on_click = show_geometry_on_click self.draw_options = draw_options or {} self.edit_options = edit_options or {} + self.on = on or {} def render(self, **kwargs): super().render(**kwargs) diff --git a/requirements.txt b/requirements.txt index dff8e41f4..ec930fa40 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,5 +1,5 @@ branca>=0.6.0 jinja2>=2.9 -numpy +numpy==1.* requests xyzservices From 0c7f152194ecabd21ccd16bdbbf7223e96333346 Mon Sep 17 00:00:00 2001 From: Hans Then Date: Thu, 17 Oct 2024 20:11:20 +0200 Subject: [PATCH 2/2] Removed numpy version fix --- requirements.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements.txt b/requirements.txt index ec930fa40..dff8e41f4 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,5 +1,5 @@ branca>=0.6.0 jinja2>=2.9 -numpy==1.* +numpy requests xyzservices