Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

leaflet-editable-textbox

Package Overview
Dependencies
Maintainers
1
Versions
22
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

leaflet-editable-textbox - npm Package Compare versions

Comparing version 1.0.5 to 1.0.6

163

dist/L.Editable.Textbox-src.js

@@ -12,6 +12,7 @@ (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g=(g.L||(g.L = {}));g=(g.Editable||(g.Editable = {}));g.Textbox = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){

require('./src/Editable.Textbox');
require('./src/SVG');
module.exports = L.Editable.TextBoxEditor;
},{"./src/Editable.Textbox":3,"./src/Textbox":4,"./src/Util":5,"leaflet":undefined,"leaflet-editable":undefined,"leaflet-path-transform/src/Matrix":2}],2:[function(require,module,exports){
},{"./src/Editable.Textbox":3,"./src/SVG":4,"./src/Textbox":5,"./src/Util":6,"leaflet":undefined,"leaflet-editable":undefined,"leaflet-path-transform/src/Matrix":2}],2:[function(require,module,exports){
/**

@@ -290,2 +291,3 @@ * @class L.Matrix

this._text = this.feature._text;
if (this._text) {

@@ -298,2 +300,7 @@ this._textArea.innerHTML = this._text;

if (this.feature._textNode) {
this.feature._textNode.parentNode.removeChild(this.feature._textNode);
this.feature._textNode = null;
}
return this;

@@ -330,2 +337,4 @@ },

}
this.feature._text = this._text;
this.feature._renderText();
}

@@ -410,13 +419,3 @@

}
var ret = L.Rectangle.prototype.enableEdit.call(this, map);
if (this._textNode) {
this._textNode.parentNode.removeChild(this._textNode);
this._textNode = null;
}
ret = L.Rectangle.prototype.enableEdit.call(this, map);
this.editor.setText(this._text);
return ret;
return L.Rectangle.prototype.enableEdit.call(this, map);
},

@@ -431,3 +430,2 @@

L.Rectangle.prototype.disableEdit.call(this);
this._renderText();

@@ -457,3 +455,138 @@ return this;

},{}],4:[function(require,module,exports){
/**
* SVG tools
*
* @author rumax
* @license MIT
* @preserve
*/
var DEFAULT_SIZE = 12;
var LINE_FACTOR = 1.12;
/**
* @param {SVGElement} svg
* @return {Object}
*/
L.SVG.calcFontSize = L.SVG.calcFontSize || function(svg) {
var size = DEFAULT_SIZE;
var sizeMin = Number.MAX_VALUE;
var sizeMax = Number.MIN_VALUE;
var texts = svg.querySelectorAll('text');
var textSize;
if (0 < texts.length) {
size = 0;
for (var ind = texts.length - 1; 0 <= ind; --ind) {
textSize = parseFloat(texts[ind].getAttribute('font-size'));
size += textSize;
if (sizeMin > textSize) {
sizeMin = textSize;
}
if (sizeMax < textSize) {
sizeMax = textSize;
}
}
return {
size: Math.round(size / texts.length + 0.5),
min: Math.round(sizeMin + 0.5),
max: Number.MIN_VALUE === sizeMax ? size : Math.round(sizeMax + 0.5)
};
}
return {
size: size,
min: size,
max: size
};
};
L.SVG.include({
renderText: function(layer) {
var textElement = layer._textNode;
var text = layer._text;
if (textElement) {
textElement.parentNode.removeChild(textElement);
}
textElement = layer._textNode = L.SVG.create('text');
layer.updateStyle();
this._rootGroup.appendChild(textElement);
if (text) {
var scale = layer._getScale(this._map.getZoom());
var pos = layer._rings[0][1];
var size = layer._rings[0][3].subtract(pos).divideBy(scale);
var chars = text.split('');
var line = chars.shift();
var char = chars.shift();
var lineInd = 1;
var maxWidth = size.x - layer.options.padding;
var tspan = this._textMakeNextLine(textElement, line, {
x: layer.options.padding
});
var lineHeight = textElement.getBBox().height;
tspan.setAttribute('dy', lineHeight);
while (char) {
if (' ' === char) {
line += char;
} else if ('\n' === char) {
line = '';
tspan = this._textMakeNextLine(textElement, line, {
x: layer.options.padding,
dy: LINE_FACTOR * lineHeight
});
} else if ('\t' !== char) { //skip tabs
var prevLine = line;
line += char;
tspan.firstChild.nodeValue = line;
var lineLength = layer.options.padding +
tspan.getComputedTextLength();
if (lineLength > maxWidth && 1 <= line.length) {
++lineInd;
tspan.firstChild.nodeValue = prevLine.replace(/\s*$/gm, '');
prevLine = '';
line = char;
tspan = this._textMakeNextLine(textElement, line, {
x: layer.options.padding,
dy: LINE_FACTOR * lineHeight
});
}
}
char = chars.shift();
}
} else if (null !== textElement) {
textElement.parentNode.removeChild(textElement);
textElement = null;
}
return textElement;
},
_textMakeNextLine: function(container, text, attrs) {
var tspan = L.SVG.create('tspan');
var key;
for (key in attrs || {}) {
if (attrs.hasOwnProperty(key)) {
tspan.setAttribute(key, attrs[key]);
}
}
tspan.appendChild(document.createTextNode(text || ''));
container.appendChild(tspan);
return tspan;
}
});
},{}],5:[function(require,module,exports){
L.TextBox = L.Rectangle.extend({

@@ -543,3 +676,3 @@

},{}],5:[function(require,module,exports){
},{}],6:[function(require,module,exports){
/**

@@ -558,2 +691,2 @@ * @param {Element} element

});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","index.js","node_modules/leaflet-path-transform/src/Matrix.js","src/Editable.Textbox.js","src/Textbox.js","src/Util.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/*eslint no-undef: \"error\"*/\n/*eslint-env node*/\n\nvar L = require('leaflet');\n\nrequire('leaflet-editable');\nrequire('leaflet-path-transform/src/Matrix');\nrequire('./src/Textbox');\nrequire('./src/Util');\nrequire('./src/Editable.Textbox');\n\nmodule.exports = L.Editable.TextBoxEditor;\n","/**\n * @class  L.Matrix\n *\n * @param {Number} a\n * @param {Number} b\n * @param {Number} c\n * @param {Number} d\n * @param {Number} e\n * @param {Number} f\n */\nL.Matrix = function(a, b, c, d, e, f) {\n\n  /**\n   * @type {Array.<Number>}\n   */\n  this._matrix = [a, b, c, d, e, f];\n};\n\n\nL.Matrix.prototype = {\n\n\n  /**\n   * @param  {L.Point} point\n   * @return {L.Point}\n   */\n  transform: function(point) {\n    return this._transform(point.clone());\n  },\n\n\n  /**\n   * Destructive\n   *\n   * [ x ] = [ a  b  tx ] [ x ] = [ a * x + b * y + tx ]\n   * [ y ] = [ c  d  ty ] [ y ] = [ c * x + d * y + ty ]\n   *\n   * @param  {L.Point} point\n   * @return {L.Point}\n   */\n  _transform: function(point) {\n    var matrix = this._matrix;\n    var x = point.x, y = point.y;\n    point.x = matrix[0] * x + matrix[1] * y + matrix[4];\n    point.y = matrix[2] * x + matrix[3] * y + matrix[5];\n    return point;\n  },\n\n\n  /**\n   * @param  {L.Point} point\n   * @return {L.Point}\n   */\n  untransform: function (point) {\n    var matrix = this._matrix;\n    return new L.Point(\n      (point.x / matrix[0] - matrix[4]) / matrix[0],\n      (point.y / matrix[2] - matrix[5]) / matrix[2]\n    );\n  },\n\n\n  /**\n   * @return {L.Matrix}\n   */\n  clone: function() {\n    var matrix = this._matrix;\n    return new L.Matrix(\n      matrix[0], matrix[1], matrix[2],\n      matrix[3], matrix[4], matrix[5]\n    );\n  },\n\n\n  /**\n   * @param {L.Point=|Number=} translate\n   * @return {L.Matrix|L.Point}\n   */\n  translate: function(translate) {\n    if (translate === undefined) {\n      return new L.Point(this._matrix[4], this._matrix[5]);\n    }\n\n    var translateX, translateY;\n    if (typeof translate === 'number') {\n      translateX = translateY = translate;\n    } else {\n      translateX = translate.x;\n      translateY = translate.y;\n    }\n\n    return this._add(1, 0, 0, 1, translateX, translateY);\n  },\n\n\n  /**\n   * @param {L.Point=|Number=} scale\n   * @return {L.Matrix|L.Point}\n   */\n  scale: function(scale, origin) {\n    if (scale === undefined) {\n      return new L.Point(this._matrix[0], this._matrix[3]);\n    }\n\n    var scaleX, scaleY;\n    origin = origin || L.point(0, 0);\n    if (typeof scale === 'number') {\n      scaleX = scaleY = scale;\n    } else {\n      scaleX = scale.x;\n      scaleY = scale.y;\n    }\n\n    return this\n      ._add(scaleX, 0, 0, scaleY, origin.x, origin.y)\n      ._add(1, 0, 0, 1, -origin.x, -origin.y);\n  },\n\n\n  /**\n   * m00  m01  x - m00 * x - m01 * y\n   * m10  m11  y - m10 * x - m11 * y\n   * @param {Number}   angle\n   * @param {L.Point=} origin\n   * @return {L.Matrix}\n   */\n  rotate: function(angle, origin) {\n    var cos = Math.cos(angle);\n    var sin = Math.sin(angle);\n\n    origin = origin || new L.Point(0, 0);\n\n    return this\n      ._add(cos, sin, -sin, cos, origin.x, origin.y)\n      ._add(1, 0, 0, 1, -origin.x, -origin.y);\n  },\n\n\n  /**\n   * Invert rotation\n   * @return {L.Matrix}\n   */\n  flip: function() {\n    this._matrix[1] *= -1;\n    this._matrix[2] *= -1;\n    return this;\n  },\n\n\n  /**\n   * @param {Number|L.Matrix} a\n   * @param {Number} b\n   * @param {Number} c\n   * @param {Number} d\n   * @param {Number} e\n   * @param {Number} f\n   */\n  _add: function(a, b, c, d, e, f) {\n    var result = [[], [], []];\n    var src = this._matrix;\n    var m = [\n      [src[0], src[2], src[4]],\n      [src[1], src[3], src[5]],\n      [     0,      0,     1]\n    ];\n    var other = [\n      [a, c, e],\n      [b, d, f],\n      [0, 0, 1]\n    ], val;\n\n\n    if (a && a instanceof L.Matrix) {\n      src = a._matrix;\n      other = [\n        [src[0], src[2], src[4]],\n        [src[1], src[3], src[5]],\n        [     0,      0,     1]];\n    }\n\n    for (var i = 0; i < 3; i++) {\n      for (var j = 0; j < 3; j++) {\n        val = 0;\n        for (var k = 0; k < 3; k++) {\n          val += m[i][k] * other[k][j];\n        }\n        result[i][j] = val;\n      }\n    }\n\n    this._matrix = [\n      result[0][0], result[1][0], result[0][1],\n      result[1][1], result[0][2], result[1][2]\n    ];\n    return this;\n  }\n\n\n};\n\n\nL.matrix = function(a, b, c, d, e, f) {\n  return new L.Matrix(a, b, c, d, e, f);\n};\n","/**\n * TextBox\n *\n * @author rumax\n * @license MIT\n */\n\n/* eslint-disable no-console */\n\nL.Editable.TextBoxEditor = L.Editable.RectangleEditor.extend({\n\n  options: {\n    textareaPadding: 1\n  },\n\n  /**\n   * @param  {L.Map}     map\n   * @param  {L.Textbox} feature\n   * @param  {Object=}   options\n   */\n  initialize: function(map, feature, options) {\n\n    /**\n     * @type {HTMLTextAreaElement}\n     */\n    this._textArea = null;\n\n    /**\n     * @type {String}\n     */\n    this._text     = null;\n\n    L.Editable.RectangleEditor.prototype.initialize.call(this, map, feature, options);\n  },\n\n\n  updateStyle: function() {\n    if (null !== this._textArea) {\n      var style   = this._textArea.style;\n      var options = this.feature.options;\n\n      style.fontSize   = options.fontSize + 'px';\n      style.color      = options.fontColor;\n      style.fontFamily = options.fontFamily;\n    }\n  },\n\n\n  enable: function() {\n    L.Editable.RectangleEditor.prototype.enable.call(this);\n    this.map\n        .on('dragend', this._focus, this)\n        .on('zoomanim', this._animateZoom, this)\n        .on('zoomend', this._updateTextAreaBounds, this);\n\n    if (null === this._textArea) {\n      this._textArea = L.DomUtil.create('textarea',\n        'leaflet-zoom-animated leaflet-textbox');\n      var style = this._textArea.style;\n      style.resize          = 'none';\n      style.border          = 'none';\n      style.padding         = this.options.textareaPadding + 'px';\n      style.backgroundColor = 'transparent';\n\n      this.updateStyle();\n      this.map.getPane('markerPane').appendChild(this._textArea);\n\n      if (this._text) {\n        this._textArea.innerHTML = this._text;\n      }\n\n      this._updateTextAreaBounds();\n    }\n\n    return this;\n  },\n\n\n  setText: function(text) {\n    this._text = text;\n\n    if (null !== this._textArea) {\n      this._textArea.value = text;\n    }\n  },\n\n\n  getText: function() {\n    this._text = this._textArea.value;\n    return this._text;\n  },\n\n\n  disable: function() {\n    if (this._enabled) {\n      this.map\n        .off('dragend',  this._focus, this)\n        .off('zoomanim', this._animateZoom, this)\n        .off('zoomend',  this._updateTextAreaBounds, this);\n\n      if (null !== this.textArea) {\n        this.getText();\n        this._textArea.parentNode.removeChild(this._textArea);\n        this._textArea = null;\n      }\n    }\n\n    L.Editable.RectangleEditor.prototype.disable.call(this);\n\n    return this;\n  },\n\n\n  updateBounds: function (bounds) {\n    L.Editable.RectangleEditor.prototype.updateBounds.call(this, bounds);\n    return this._updateTextAreaBounds();\n  },\n\n\n  _focus: function() {\n    if (null !== this._textArea) {\n      L.Util.requestAnimFrame(function() {\n        this._textArea.focus();\n      }, this);\n    }\n  },\n\n\n  /**\n   * Animated resize\n   * @param  {Event} evt\n   */\n  _animateZoom: function(evt) {\n    var bounds = this.feature._bounds;\n    var scale  = this.feature._getScale(evt.zoom);\n    var offset = this.map._latLngToNewLayerPoint(\n      bounds.getNorthWest(), evt.zoom, evt.center);\n\n    L.DomUtil.setTransform(this._textArea, offset, scale.toFixed(3));\n  },\n\n\n  /**\n   * Resize, reposition on zoom end or resize\n   */\n  _updateTextAreaBounds: function() {\n    var scale, latlngs, pos, size;\n    var feature  = this.feature;\n    var bounds   = feature._bounds;\n    var textArea = this._textArea;\n    var map      = this.map;\n\n    if (null !== textArea) {\n      if (null !== bounds) {\n        scale = feature._getScale(map.getZoom());\n        latlngs = feature._boundsToLatLngs(bounds);\n        pos = map.latLngToLayerPoint(latlngs[1]);\n        size = map.latLngToLayerPoint(latlngs[3]).subtract(pos);\n        L.DomUtil\n           .setSize(textArea, size.divideBy(scale).round())\n           .setTransform(textArea, pos, scale.toFixed(3));\n\n        textArea.style.display  = '';\n        textArea.style.position = 'absolute';\n        textArea.setAttribute('spellcheck', false);\n\n        this._focus();\n      } else {\n        textArea.style.display = 'none';\n      }\n    }\n\n    return this;\n  }\n\n});\n\n\nL.TextBox.include({\n\n  enableEdit: function(map) {\n    if (!this.editor) {\n      this.createEditor(map);\n    }\n    var ret = L.Rectangle.prototype.enableEdit.call(this, map);\n\n    if (this._textNode) {\n      this._textNode.parentNode.removeChild(this._textNode);\n      this._textNode = null;\n    }\n\n    ret = L.Rectangle.prototype.enableEdit.call(this, map);\n    this.editor.setText(this._text);\n\n    return ret;\n  },\n\n\n  disableEdit: function() {\n    if (this.editor) {\n      this._text = this.editor.getText();\n    }\n\n    L.Rectangle.prototype.disableEdit.call(this);\n    this._renderText();\n\n    return this;\n  },\n\n\n  getEditorClass: function() {\n    return L.Editable.TextBoxEditor;\n  }\n\n});\n\n\n/**\n * @param  {Array.<LatLng>=} latlng\n * @param  {Object=} options\n * @return {L.TextBox}\n */\nL.Editable.prototype.startTextBox = function(latlng, options) {\n  return this.startRectangle(null, L.extend({\n    rectangleClass: L.TextBox\n  }, options));\n};\n","\nL.TextBox = L.Rectangle.extend({\n\n  options: {\n    padding: 2,\n    fontSize: 12,\n    fillOpacity: 0.5,\n    fillColor: '#ffffff',\n    weight: 1,\n    fontColor: '',\n    fontFamily: '',\n    ratio: 1,\n    text: 'Please, add text'\n\n    //TODO: wrapBy: 'letter', 'char', 'nowrap', etc.\n  },\n\n\n  initialize: function(bounds, options) {\n    L.Rectangle.prototype.initialize.call(this, bounds, options);\n\n    this._text = this.options.text;\n    this._textNode = null;\n  },\n\n\n  /**\n   * @param {Object} style\n   */\n  setStyle: function(style) {\n    L.setOptions(this, style);\n\n    if (this.editor && this.editor._enabled) {\n      this.editor.updateStyle();\n    } else {\n      this._renderText();\n    }\n  },\n\n\n  updateStyle: function() {\n    var textNode = this._textNode;\n    var options = this.options;\n    if (null !== textNode) {\n      textNode.setAttribute('font-family', options.fontFamily);\n      textNode.setAttribute('font-size', options.fontSize + 'px');\n      textNode.setAttribute('fill', options.fontColor);\n    }\n  },\n\n\n  _renderText: function() {\n    this._textNode = this._renderer.renderText(this);\n    this._path.parentNode\n        .insertBefore(this._textNode, this._path.nextSibling);\n    this.updateStyle();\n    this._updatePosition();\n  },\n\n\n  _updatePosition: function() {\n    if (null !== this._textNode && 0 !== this._rings.length) {\n      var pos = this._rings[0][1];\n      var textMatrix = new L.Matrix(1, 0, 0, 1, 0, 0)\n        .translate(pos)\n        .scale(this._getScale(this._map.getZoom()));\n      this._textNode.setAttribute('transform',\n        'matrix(' + textMatrix._matrix.join(' ') + ')');\n    }\n  },\n\n\n  _getScale: function(zoom) {\n    return (this._map ?\n      Math.pow(2, zoom) * this.options.ratio : 1);\n  },\n\n\n  _updatePath: function() {\n    L.Rectangle.prototype._updatePath.call(this);\n    this._updatePosition();\n  }\n\n});\n","/**\n * @param  {Element} element\n * @param  {L.Point} size\n * @return {Object} self\n */\nL.DomUtil.setSize =  L.DomUtil.setSize || function(element, size) {\n  element.style.width = size.x  + 'px';\n  element.style.height = size.y + 'px';\n  return this;\n};\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","index.js","node_modules/leaflet-path-transform/src/Matrix.js","src/Editable.Textbox.js","src/SVG.js","src/Textbox.js","src/Util.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/*eslint no-undef: \"error\"*/\n/*eslint-env node*/\n\nvar L = require('leaflet');\n\nrequire('leaflet-editable');\nrequire('leaflet-path-transform/src/Matrix');\nrequire('./src/Textbox');\nrequire('./src/Util');\nrequire('./src/Editable.Textbox');\nrequire('./src/SVG');\n\nmodule.exports = L.Editable.TextBoxEditor;\n","/**\n * @class  L.Matrix\n *\n * @param {Number} a\n * @param {Number} b\n * @param {Number} c\n * @param {Number} d\n * @param {Number} e\n * @param {Number} f\n */\nL.Matrix = function(a, b, c, d, e, f) {\n\n  /**\n   * @type {Array.<Number>}\n   */\n  this._matrix = [a, b, c, d, e, f];\n};\n\n\nL.Matrix.prototype = {\n\n\n  /**\n   * @param  {L.Point} point\n   * @return {L.Point}\n   */\n  transform: function(point) {\n    return this._transform(point.clone());\n  },\n\n\n  /**\n   * Destructive\n   *\n   * [ x ] = [ a  b  tx ] [ x ] = [ a * x + b * y + tx ]\n   * [ y ] = [ c  d  ty ] [ y ] = [ c * x + d * y + ty ]\n   *\n   * @param  {L.Point} point\n   * @return {L.Point}\n   */\n  _transform: function(point) {\n    var matrix = this._matrix;\n    var x = point.x, y = point.y;\n    point.x = matrix[0] * x + matrix[1] * y + matrix[4];\n    point.y = matrix[2] * x + matrix[3] * y + matrix[5];\n    return point;\n  },\n\n\n  /**\n   * @param  {L.Point} point\n   * @return {L.Point}\n   */\n  untransform: function (point) {\n    var matrix = this._matrix;\n    return new L.Point(\n      (point.x / matrix[0] - matrix[4]) / matrix[0],\n      (point.y / matrix[2] - matrix[5]) / matrix[2]\n    );\n  },\n\n\n  /**\n   * @return {L.Matrix}\n   */\n  clone: function() {\n    var matrix = this._matrix;\n    return new L.Matrix(\n      matrix[0], matrix[1], matrix[2],\n      matrix[3], matrix[4], matrix[5]\n    );\n  },\n\n\n  /**\n   * @param {L.Point=|Number=} translate\n   * @return {L.Matrix|L.Point}\n   */\n  translate: function(translate) {\n    if (translate === undefined) {\n      return new L.Point(this._matrix[4], this._matrix[5]);\n    }\n\n    var translateX, translateY;\n    if (typeof translate === 'number') {\n      translateX = translateY = translate;\n    } else {\n      translateX = translate.x;\n      translateY = translate.y;\n    }\n\n    return this._add(1, 0, 0, 1, translateX, translateY);\n  },\n\n\n  /**\n   * @param {L.Point=|Number=} scale\n   * @return {L.Matrix|L.Point}\n   */\n  scale: function(scale, origin) {\n    if (scale === undefined) {\n      return new L.Point(this._matrix[0], this._matrix[3]);\n    }\n\n    var scaleX, scaleY;\n    origin = origin || L.point(0, 0);\n    if (typeof scale === 'number') {\n      scaleX = scaleY = scale;\n    } else {\n      scaleX = scale.x;\n      scaleY = scale.y;\n    }\n\n    return this\n      ._add(scaleX, 0, 0, scaleY, origin.x, origin.y)\n      ._add(1, 0, 0, 1, -origin.x, -origin.y);\n  },\n\n\n  /**\n   * m00  m01  x - m00 * x - m01 * y\n   * m10  m11  y - m10 * x - m11 * y\n   * @param {Number}   angle\n   * @param {L.Point=} origin\n   * @return {L.Matrix}\n   */\n  rotate: function(angle, origin) {\n    var cos = Math.cos(angle);\n    var sin = Math.sin(angle);\n\n    origin = origin || new L.Point(0, 0);\n\n    return this\n      ._add(cos, sin, -sin, cos, origin.x, origin.y)\n      ._add(1, 0, 0, 1, -origin.x, -origin.y);\n  },\n\n\n  /**\n   * Invert rotation\n   * @return {L.Matrix}\n   */\n  flip: function() {\n    this._matrix[1] *= -1;\n    this._matrix[2] *= -1;\n    return this;\n  },\n\n\n  /**\n   * @param {Number|L.Matrix} a\n   * @param {Number} b\n   * @param {Number} c\n   * @param {Number} d\n   * @param {Number} e\n   * @param {Number} f\n   */\n  _add: function(a, b, c, d, e, f) {\n    var result = [[], [], []];\n    var src = this._matrix;\n    var m = [\n      [src[0], src[2], src[4]],\n      [src[1], src[3], src[5]],\n      [     0,      0,     1]\n    ];\n    var other = [\n      [a, c, e],\n      [b, d, f],\n      [0, 0, 1]\n    ], val;\n\n\n    if (a && a instanceof L.Matrix) {\n      src = a._matrix;\n      other = [\n        [src[0], src[2], src[4]],\n        [src[1], src[3], src[5]],\n        [     0,      0,     1]];\n    }\n\n    for (var i = 0; i < 3; i++) {\n      for (var j = 0; j < 3; j++) {\n        val = 0;\n        for (var k = 0; k < 3; k++) {\n          val += m[i][k] * other[k][j];\n        }\n        result[i][j] = val;\n      }\n    }\n\n    this._matrix = [\n      result[0][0], result[1][0], result[0][1],\n      result[1][1], result[0][2], result[1][2]\n    ];\n    return this;\n  }\n\n\n};\n\n\nL.matrix = function(a, b, c, d, e, f) {\n  return new L.Matrix(a, b, c, d, e, f);\n};\n","/**\n * TextBox\n *\n * @author rumax\n * @license MIT\n */\n\n/* eslint-disable no-console */\n\nL.Editable.TextBoxEditor = L.Editable.RectangleEditor.extend({\n\n  options: {\n    textareaPadding: 1\n  },\n\n  /**\n   * @param  {L.Map}     map\n   * @param  {L.Textbox} feature\n   * @param  {Object=}   options\n   */\n  initialize: function(map, feature, options) {\n\n    /**\n     * @type {HTMLTextAreaElement}\n     */\n    this._textArea = null;\n\n    /**\n     * @type {String}\n     */\n    this._text     = null;\n\n    L.Editable.RectangleEditor.prototype.initialize.call(this, map, feature, options);\n  },\n\n\n  updateStyle: function() {\n    if (null !== this._textArea) {\n      var style   = this._textArea.style;\n      var options = this.feature.options;\n\n      style.fontSize   = options.fontSize + 'px';\n      style.color      = options.fontColor;\n      style.fontFamily = options.fontFamily;\n    }\n  },\n\n\n  enable: function() {\n    L.Editable.RectangleEditor.prototype.enable.call(this);\n    this.map\n        .on('dragend', this._focus, this)\n        .on('zoomanim', this._animateZoom, this)\n        .on('zoomend', this._updateTextAreaBounds, this);\n\n    if (null === this._textArea) {\n      this._textArea = L.DomUtil.create('textarea',\n        'leaflet-zoom-animated leaflet-textbox');\n      var style = this._textArea.style;\n      style.resize          = 'none';\n      style.border          = 'none';\n      style.padding         = this.options.textareaPadding + 'px';\n      style.backgroundColor = 'transparent';\n\n      this.updateStyle();\n      this.map.getPane('markerPane').appendChild(this._textArea);\n\n      this._text = this.feature._text;\n      if (this._text) {\n        this._textArea.innerHTML = this._text;\n      }\n\n      this._updateTextAreaBounds();\n    }\n\n    if (this.feature._textNode) {\n      this.feature._textNode.parentNode.removeChild(this.feature._textNode);\n      this.feature._textNode = null;\n    }\n\n    return this;\n  },\n\n\n  setText: function(text) {\n    this._text = text;\n\n    if (null !== this._textArea) {\n      this._textArea.value = text;\n    }\n  },\n\n\n  getText: function() {\n    this._text = this._textArea.value;\n    return this._text;\n  },\n\n\n  disable: function() {\n    if (this._enabled) {\n      this.map\n        .off('dragend',  this._focus, this)\n        .off('zoomanim', this._animateZoom, this)\n        .off('zoomend',  this._updateTextAreaBounds, this);\n\n      if (null !== this.textArea) {\n        this.getText();\n        this._textArea.parentNode.removeChild(this._textArea);\n        this._textArea = null;\n      }\n      this.feature._text = this._text;\n      this.feature._renderText();\n    }\n\n    L.Editable.RectangleEditor.prototype.disable.call(this);\n\n    return this;\n  },\n\n\n  updateBounds: function (bounds) {\n    L.Editable.RectangleEditor.prototype.updateBounds.call(this, bounds);\n    return this._updateTextAreaBounds();\n  },\n\n\n  _focus: function() {\n    if (null !== this._textArea) {\n      L.Util.requestAnimFrame(function() {\n        this._textArea.focus();\n      }, this);\n    }\n  },\n\n\n  /**\n   * Animated resize\n   * @param  {Event} evt\n   */\n  _animateZoom: function(evt) {\n    var bounds = this.feature._bounds;\n    var scale  = this.feature._getScale(evt.zoom);\n    var offset = this.map._latLngToNewLayerPoint(\n      bounds.getNorthWest(), evt.zoom, evt.center);\n\n    L.DomUtil.setTransform(this._textArea, offset, scale.toFixed(3));\n  },\n\n\n  /**\n   * Resize, reposition on zoom end or resize\n   */\n  _updateTextAreaBounds: function() {\n    var scale, latlngs, pos, size;\n    var feature  = this.feature;\n    var bounds   = feature._bounds;\n    var textArea = this._textArea;\n    var map      = this.map;\n\n    if (null !== textArea) {\n      if (null !== bounds) {\n        scale = feature._getScale(map.getZoom());\n        latlngs = feature._boundsToLatLngs(bounds);\n        pos = map.latLngToLayerPoint(latlngs[1]);\n        size = map.latLngToLayerPoint(latlngs[3]).subtract(pos);\n        L.DomUtil\n           .setSize(textArea, size.divideBy(scale).round())\n           .setTransform(textArea, pos, scale.toFixed(3));\n\n        textArea.style.display  = '';\n        textArea.style.position = 'absolute';\n        textArea.setAttribute('spellcheck', false);\n\n        this._focus();\n      } else {\n        textArea.style.display = 'none';\n      }\n    }\n\n    return this;\n  }\n\n});\n\n\nL.TextBox.include({\n\n  enableEdit: function(map) {\n    if (!this.editor) {\n      this.createEditor(map);\n    }\n    return L.Rectangle.prototype.enableEdit.call(this, map);\n  },\n\n\n  disableEdit: function() {\n    if (this.editor) {\n      this._text = this.editor.getText();\n    }\n\n    L.Rectangle.prototype.disableEdit.call(this);\n\n    return this;\n  },\n\n\n  getEditorClass: function() {\n    return L.Editable.TextBoxEditor;\n  }\n\n});\n\n\n/**\n * @param  {Array.<LatLng>=} latlng\n * @param  {Object=} options\n * @return {L.TextBox}\n */\nL.Editable.prototype.startTextBox = function(latlng, options) {\n  return this.startRectangle(null, L.extend({\n    rectangleClass: L.TextBox\n  }, options));\n};\n","/**\n * SVG tools\n *\n * @author rumax\n * @license MIT\n * @preserve\n */\n\nvar DEFAULT_SIZE = 12;\nvar LINE_FACTOR  = 1.12;\n\n/**\n * @param  {SVGElement} svg\n * @return {Object}\n */\nL.SVG.calcFontSize = L.SVG.calcFontSize || function(svg) {\n  var size    = DEFAULT_SIZE;\n  var sizeMin = Number.MAX_VALUE;\n  var sizeMax = Number.MIN_VALUE;\n  var texts   = svg.querySelectorAll('text');\n  var textSize;\n\n  if (0 < texts.length) {\n    size = 0;\n    for (var ind = texts.length - 1; 0 <= ind; --ind) {\n      textSize = parseFloat(texts[ind].getAttribute('font-size'));\n      size += textSize;\n      if (sizeMin > textSize) {\n        sizeMin = textSize;\n      }\n\n      if (sizeMax < textSize) {\n        sizeMax = textSize;\n      }\n    }\n\n    return {\n      size: Math.round(size / texts.length + 0.5),\n      min: Math.round(sizeMin + 0.5),\n      max: Number.MIN_VALUE === sizeMax ? size : Math.round(sizeMax + 0.5)\n    };\n  }\n\n  return {\n    size: size,\n    min: size,\n    max: size\n  };\n};\n\n\nL.SVG.include({\n\n  renderText: function(layer) {\n    var textElement = layer._textNode;\n    var text  = layer._text;\n\n    if (textElement) {\n      textElement.parentNode.removeChild(textElement);\n    }\n    textElement = layer._textNode = L.SVG.create('text');\n    layer.updateStyle();\n    this._rootGroup.appendChild(textElement);\n\n    if (text) {\n      var scale = layer._getScale(this._map.getZoom());\n      var pos   = layer._rings[0][1];\n      var size  = layer._rings[0][3].subtract(pos).divideBy(scale);\n\n      var chars = text.split('');\n      var line = chars.shift();\n      var char = chars.shift();\n      var lineInd = 1;\n      var maxWidth = size.x - layer.options.padding;\n      var tspan = this._textMakeNextLine(textElement, line, {\n        x: layer.options.padding\n      });\n      var lineHeight = textElement.getBBox().height;\n      tspan.setAttribute('dy', lineHeight);\n\n      while (char) {\n        if (' ' === char) {\n          line += char;\n        } else if ('\\n' === char) {\n          line = '';\n          tspan = this._textMakeNextLine(textElement, line, {\n            x: layer.options.padding,\n            dy: LINE_FACTOR * lineHeight\n          });\n        } else if ('\\t' !== char) { //skip tabs\n          var prevLine = line;\n          line += char;\n          tspan.firstChild.nodeValue = line;\n          var lineLength = layer.options.padding +\n            tspan.getComputedTextLength();\n\n          if (lineLength > maxWidth && 1 <= line.length) {\n            ++lineInd;\n            tspan.firstChild.nodeValue = prevLine.replace(/\\s*$/gm, '');\n            prevLine = '';\n            line = char;\n            tspan = this._textMakeNextLine(textElement, line, {\n              x: layer.options.padding,\n              dy: LINE_FACTOR * lineHeight\n            });\n          }\n        }\n        char = chars.shift();\n      }\n    } else if (null !== textElement) {\n      textElement.parentNode.removeChild(textElement);\n      textElement = null;\n    }\n\n    return textElement;\n  },\n\n\n  _textMakeNextLine: function(container, text, attrs) {\n    var tspan = L.SVG.create('tspan');\n    var key;\n\n    for (key in attrs || {}) {\n      if (attrs.hasOwnProperty(key)) {\n        tspan.setAttribute(key, attrs[key]);\n      }\n    }\n    tspan.appendChild(document.createTextNode(text || ''));\n    container.appendChild(tspan);\n\n    return tspan;\n  }\n});\n","\nL.TextBox = L.Rectangle.extend({\n\n  options: {\n    padding: 2,\n    fontSize: 12,\n    fillOpacity: 0.5,\n    fillColor: '#ffffff',\n    weight: 1,\n    fontColor: '',\n    fontFamily: '',\n    ratio: 1,\n    text: 'Please, add text'\n\n    //TODO: wrapBy: 'letter', 'char', 'nowrap', etc.\n  },\n\n\n  initialize: function(bounds, options) {\n    L.Rectangle.prototype.initialize.call(this, bounds, options);\n\n    this._text = this.options.text;\n    this._textNode = null;\n  },\n\n\n  /**\n   * @param {Object} style\n   */\n  setStyle: function(style) {\n    L.setOptions(this, style);\n\n    if (this.editor && this.editor._enabled) {\n      this.editor.updateStyle();\n    } else {\n      this._renderText();\n    }\n  },\n\n\n  updateStyle: function() {\n    var textNode = this._textNode;\n    var options = this.options;\n    if (null !== textNode) {\n      textNode.setAttribute('font-family', options.fontFamily);\n      textNode.setAttribute('font-size', options.fontSize + 'px');\n      textNode.setAttribute('fill', options.fontColor);\n    }\n  },\n\n\n  _renderText: function() {\n    this._textNode = this._renderer.renderText(this);\n    this._path.parentNode\n        .insertBefore(this._textNode, this._path.nextSibling);\n    this.updateStyle();\n    this._updatePosition();\n  },\n\n\n  _updatePosition: function() {\n    if (null !== this._textNode && 0 !== this._rings.length) {\n      var pos = this._rings[0][1];\n      var textMatrix = new L.Matrix(1, 0, 0, 1, 0, 0)\n        .translate(pos)\n        .scale(this._getScale(this._map.getZoom()));\n      this._textNode.setAttribute('transform',\n        'matrix(' + textMatrix._matrix.join(' ') + ')');\n    }\n  },\n\n\n  _getScale: function(zoom) {\n    return (this._map ?\n      Math.pow(2, zoom) * this.options.ratio : 1);\n  },\n\n\n  _updatePath: function() {\n    L.Rectangle.prototype._updatePath.call(this);\n    this._updatePosition();\n  }\n\n});\n","/**\n * @param  {Element} element\n * @param  {L.Point} size\n * @return {Object} self\n */\nL.DomUtil.setSize =  L.DomUtil.setSize || function(element, size) {\n  element.style.width = size.x  + 'px';\n  element.style.height = size.y + 'px';\n  return this;\n};\n"]}

@@ -1,2 +0,2 @@

(function(t){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=t()}else if(typeof define==="function"&&define.amd){define([],t)}else{var e;if(typeof window!=="undefined"){e=window}else if(typeof global!=="undefined"){e=global}else if(typeof self!=="undefined"){e=self}else{e=this}e=e.L||(e.L={});e=e.Editable||(e.Editable={});e.Textbox=t()}})(function(){var t,e,i;return function n(t,e,i){function r(a,s){if(!e[a]){if(!t[a]){var l=typeof require=="function"&&require;if(!s&&l)return l(a,!0);if(o)return o(a,!0);var f=new Error("Cannot find module '"+a+"'");throw f.code="MODULE_NOT_FOUND",f}var d=e[a]={exports:{}};t[a][0].call(d.exports,function(e){var i=t[a][1][e];return r(i?i:e)},d,d.exports,n,t,e,i)}return e[a].exports}var o=typeof require=="function"&&require;for(var a=0;a<i.length;a++)r(i[a]);return r}({1:[function(t,e,i){var n=t("leaflet");t("leaflet-editable");t("leaflet-path-transform/src/Matrix");t("./src/Textbox");t("./src/Util");t("./src/Editable.Textbox");e.exports=n.Editable.TextBoxEditor},{"./src/Editable.Textbox":3,"./src/Textbox":4,"./src/Util":5,leaflet:undefined,"leaflet-editable":undefined,"leaflet-path-transform/src/Matrix":2}],2:[function(t,e,i){L.Matrix=function(t,e,i,n,r,o){this._matrix=[t,e,i,n,r,o]};L.Matrix.prototype={transform:function(t){return this._transform(t.clone())},_transform:function(t){var e=this._matrix;var i=t.x,n=t.y;t.x=e[0]*i+e[1]*n+e[4];t.y=e[2]*i+e[3]*n+e[5];return t},untransform:function(t){var e=this._matrix;return new L.Point((t.x/e[0]-e[4])/e[0],(t.y/e[2]-e[5])/e[2])},clone:function(){var t=this._matrix;return new L.Matrix(t[0],t[1],t[2],t[3],t[4],t[5])},translate:function(t){if(t===undefined){return new L.Point(this._matrix[4],this._matrix[5])}var e,i;if(typeof t==="number"){e=i=t}else{e=t.x;i=t.y}return this._add(1,0,0,1,e,i)},scale:function(t,e){if(t===undefined){return new L.Point(this._matrix[0],this._matrix[3])}var i,n;e=e||L.point(0,0);if(typeof t==="number"){i=n=t}else{i=t.x;n=t.y}return this._add(i,0,0,n,e.x,e.y)._add(1,0,0,1,-e.x,-e.y)},rotate:function(t,e){var i=Math.cos(t);var n=Math.sin(t);e=e||new L.Point(0,0);return this._add(i,n,-n,i,e.x,e.y)._add(1,0,0,1,-e.x,-e.y)},flip:function(){this._matrix[1]*=-1;this._matrix[2]*=-1;return this},_add:function(t,e,i,n,r,o){var a=[[],[],[]];var s=this._matrix;var l=[[s[0],s[2],s[4]],[s[1],s[3],s[5]],[0,0,1]];var f=[[t,i,r],[e,n,o],[0,0,1]],d;if(t&&t instanceof L.Matrix){s=t._matrix;f=[[s[0],s[2],s[4]],[s[1],s[3],s[5]],[0,0,1]]}for(var u=0;u<3;u++){for(var h=0;h<3;h++){d=0;for(var x=0;x<3;x++){d+=l[u][x]*f[x][h]}a[u][h]=d}}this._matrix=[a[0][0],a[1][0],a[0][1],a[1][1],a[0][2],a[1][2]];return this}};L.matrix=function(t,e,i,n,r,o){return new L.Matrix(t,e,i,n,r,o)}},{}],3:[function(t,e,i){/**
(function(t){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=t()}else if(typeof define==="function"&&define.amd){define([],t)}else{var e;if(typeof window!=="undefined"){e=window}else if(typeof global!=="undefined"){e=global}else if(typeof self!=="undefined"){e=self}else{e=this}e=e.L||(e.L={});e=e.Editable||(e.Editable={});e.Textbox=t()}})(function(){var t,e,i;return function n(t,e,i){function r(o,s){if(!e[o]){if(!t[o]){var l=typeof require=="function"&&require;if(!s&&l)return l(o,!0);if(a)return a(o,!0);var d=new Error("Cannot find module '"+o+"'");throw d.code="MODULE_NOT_FOUND",d}var f=e[o]={exports:{}};t[o][0].call(f.exports,function(e){var i=t[o][1][e];return r(i?i:e)},f,f.exports,n,t,e,i)}return e[o].exports}var a=typeof require=="function"&&require;for(var o=0;o<i.length;o++)r(i[o]);return r}({1:[function(t,e,i){var n=t("leaflet");t("leaflet-editable");t("leaflet-path-transform/src/Matrix");t("./src/Textbox");t("./src/Util");t("./src/Editable.Textbox");t("./src/SVG");e.exports=n.Editable.TextBoxEditor},{"./src/Editable.Textbox":3,"./src/SVG":4,"./src/Textbox":5,"./src/Util":6,leaflet:undefined,"leaflet-editable":undefined,"leaflet-path-transform/src/Matrix":2}],2:[function(t,e,i){L.Matrix=function(t,e,i,n,r,a){this._matrix=[t,e,i,n,r,a]};L.Matrix.prototype={transform:function(t){return this._transform(t.clone())},_transform:function(t){var e=this._matrix;var i=t.x,n=t.y;t.x=e[0]*i+e[1]*n+e[4];t.y=e[2]*i+e[3]*n+e[5];return t},untransform:function(t){var e=this._matrix;return new L.Point((t.x/e[0]-e[4])/e[0],(t.y/e[2]-e[5])/e[2])},clone:function(){var t=this._matrix;return new L.Matrix(t[0],t[1],t[2],t[3],t[4],t[5])},translate:function(t){if(t===undefined){return new L.Point(this._matrix[4],this._matrix[5])}var e,i;if(typeof t==="number"){e=i=t}else{e=t.x;i=t.y}return this._add(1,0,0,1,e,i)},scale:function(t,e){if(t===undefined){return new L.Point(this._matrix[0],this._matrix[3])}var i,n;e=e||L.point(0,0);if(typeof t==="number"){i=n=t}else{i=t.x;n=t.y}return this._add(i,0,0,n,e.x,e.y)._add(1,0,0,1,-e.x,-e.y)},rotate:function(t,e){var i=Math.cos(t);var n=Math.sin(t);e=e||new L.Point(0,0);return this._add(i,n,-n,i,e.x,e.y)._add(1,0,0,1,-e.x,-e.y)},flip:function(){this._matrix[1]*=-1;this._matrix[2]*=-1;return this},_add:function(t,e,i,n,r,a){var o=[[],[],[]];var s=this._matrix;var l=[[s[0],s[2],s[4]],[s[1],s[3],s[5]],[0,0,1]];var d=[[t,i,r],[e,n,a],[0,0,1]],f;if(t&&t instanceof L.Matrix){s=t._matrix;d=[[s[0],s[2],s[4]],[s[1],s[3],s[5]],[0,0,1]]}for(var u=0;u<3;u++){for(var h=0;h<3;h++){f=0;for(var x=0;x<3;x++){f+=l[u][x]*d[x][h]}o[u][h]=f}}this._matrix=[o[0][0],o[1][0],o[0][1],o[1][1],o[0][2],o[1][2]];return this}};L.matrix=function(t,e,i,n,r,a){return new L.Matrix(t,e,i,n,r,a)}},{}],3:[function(t,e,i){/**
* TextBox

@@ -7,2 +7,9 @@ *

*/
L.Editable.TextBoxEditor=L.Editable.RectangleEditor.extend({options:{textareaPadding:1},initialize:function(t,e,i){this._textArea=null;this._text=null;L.Editable.RectangleEditor.prototype.initialize.call(this,t,e,i)},updateStyle:function(){if(null!==this._textArea){var t=this._textArea.style;var e=this.feature.options;t.fontSize=e.fontSize+"px";t.color=e.fontColor;t.fontFamily=e.fontFamily}},enable:function(){L.Editable.RectangleEditor.prototype.enable.call(this);this.map.on("dragend",this._focus,this).on("zoomanim",this._animateZoom,this).on("zoomend",this._updateTextAreaBounds,this);if(null===this._textArea){this._textArea=L.DomUtil.create("textarea","leaflet-zoom-animated leaflet-textbox");var t=this._textArea.style;t.resize="none";t.border="none";t.padding=this.options.textareaPadding+"px";t.backgroundColor="transparent";this.updateStyle();this.map.getPane("markerPane").appendChild(this._textArea);if(this._text){this._textArea.innerHTML=this._text}this._updateTextAreaBounds()}return this},setText:function(t){this._text=t;if(null!==this._textArea){this._textArea.value=t}},getText:function(){this._text=this._textArea.value;return this._text},disable:function(){if(this._enabled){this.map.off("dragend",this._focus,this).off("zoomanim",this._animateZoom,this).off("zoomend",this._updateTextAreaBounds,this);if(null!==this.textArea){this.getText();this._textArea.parentNode.removeChild(this._textArea);this._textArea=null}}L.Editable.RectangleEditor.prototype.disable.call(this);return this},updateBounds:function(t){L.Editable.RectangleEditor.prototype.updateBounds.call(this,t);return this._updateTextAreaBounds()},_focus:function(){if(null!==this._textArea){L.Util.requestAnimFrame(function(){this._textArea.focus()},this)}},_animateZoom:function(t){var e=this.feature._bounds;var i=this.feature._getScale(t.zoom);var n=this.map._latLngToNewLayerPoint(e.getNorthWest(),t.zoom,t.center);L.DomUtil.setTransform(this._textArea,n,i.toFixed(3))},_updateTextAreaBounds:function(){var t,e,i,n;var r=this.feature;var o=r._bounds;var a=this._textArea;var s=this.map;if(null!==a){if(null!==o){t=r._getScale(s.getZoom());e=r._boundsToLatLngs(o);i=s.latLngToLayerPoint(e[1]);n=s.latLngToLayerPoint(e[3]).subtract(i);L.DomUtil.setSize(a,n.divideBy(t).round()).setTransform(a,i,t.toFixed(3));a.style.display="";a.style.position="absolute";a.setAttribute("spellcheck",false);this._focus()}else{a.style.display="none"}}return this}});L.TextBox.include({enableEdit:function(t){if(!this.editor){this.createEditor(t)}var e=L.Rectangle.prototype.enableEdit.call(this,t);if(this._textNode){this._textNode.parentNode.removeChild(this._textNode);this._textNode=null}e=L.Rectangle.prototype.enableEdit.call(this,t);this.editor.setText(this._text);return e},disableEdit:function(){if(this.editor){this._text=this.editor.getText()}L.Rectangle.prototype.disableEdit.call(this);this._renderText();return this},getEditorClass:function(){return L.Editable.TextBoxEditor}});L.Editable.prototype.startTextBox=function(t,e){return this.startRectangle(null,L.extend({rectangleClass:L.TextBox},e))}},{}],4:[function(t,e,i){L.TextBox=L.Rectangle.extend({options:{padding:2,fontSize:12,fillOpacity:.5,fillColor:"#ffffff",weight:1,fontColor:"",fontFamily:"",ratio:1,text:"Please, add text"},initialize:function(t,e){L.Rectangle.prototype.initialize.call(this,t,e);this._text=this.options.text;this._textNode=null},setStyle:function(t){L.setOptions(this,t);if(this.editor&&this.editor._enabled){this.editor.updateStyle()}else{this._renderText()}},updateStyle:function(){var t=this._textNode;var e=this.options;if(null!==t){t.setAttribute("font-family",e.fontFamily);t.setAttribute("font-size",e.fontSize+"px");t.setAttribute("fill",e.fontColor)}},_renderText:function(){this._textNode=this._renderer.renderText(this);this._path.parentNode.insertBefore(this._textNode,this._path.nextSibling);this.updateStyle();this._updatePosition()},_updatePosition:function(){if(null!==this._textNode&&0!==this._rings.length){var t=this._rings[0][1];var e=new L.Matrix(1,0,0,1,0,0).translate(t).scale(this._getScale(this._map.getZoom()));this._textNode.setAttribute("transform","matrix("+e._matrix.join(" ")+")")}},_getScale:function(t){return this._map?Math.pow(2,t)*this.options.ratio:1},_updatePath:function(){L.Rectangle.prototype._updatePath.call(this);this._updatePosition()}})},{}],5:[function(t,e,i){L.DomUtil.setSize=L.DomUtil.setSize||function(t,e){t.style.width=e.x+"px";t.style.height=e.y+"px";return this}},{}]},{},[1])(1)});
L.Editable.TextBoxEditor=L.Editable.RectangleEditor.extend({options:{textareaPadding:1},initialize:function(t,e,i){this._textArea=null;this._text=null;L.Editable.RectangleEditor.prototype.initialize.call(this,t,e,i)},updateStyle:function(){if(null!==this._textArea){var t=this._textArea.style;var e=this.feature.options;t.fontSize=e.fontSize+"px";t.color=e.fontColor;t.fontFamily=e.fontFamily}},enable:function(){L.Editable.RectangleEditor.prototype.enable.call(this);this.map.on("dragend",this._focus,this).on("zoomanim",this._animateZoom,this).on("zoomend",this._updateTextAreaBounds,this);if(null===this._textArea){this._textArea=L.DomUtil.create("textarea","leaflet-zoom-animated leaflet-textbox");var t=this._textArea.style;t.resize="none";t.border="none";t.padding=this.options.textareaPadding+"px";t.backgroundColor="transparent";this.updateStyle();this.map.getPane("markerPane").appendChild(this._textArea);this._text=this.feature._text;if(this._text){this._textArea.innerHTML=this._text}this._updateTextAreaBounds()}if(this.feature._textNode){this.feature._textNode.parentNode.removeChild(this.feature._textNode);this.feature._textNode=null}return this},setText:function(t){this._text=t;if(null!==this._textArea){this._textArea.value=t}},getText:function(){this._text=this._textArea.value;return this._text},disable:function(){if(this._enabled){this.map.off("dragend",this._focus,this).off("zoomanim",this._animateZoom,this).off("zoomend",this._updateTextAreaBounds,this);if(null!==this.textArea){this.getText();this._textArea.parentNode.removeChild(this._textArea);this._textArea=null}this.feature._text=this._text;this.feature._renderText()}L.Editable.RectangleEditor.prototype.disable.call(this);return this},updateBounds:function(t){L.Editable.RectangleEditor.prototype.updateBounds.call(this,t);return this._updateTextAreaBounds()},_focus:function(){if(null!==this._textArea){L.Util.requestAnimFrame(function(){this._textArea.focus()},this)}},_animateZoom:function(t){var e=this.feature._bounds;var i=this.feature._getScale(t.zoom);var n=this.map._latLngToNewLayerPoint(e.getNorthWest(),t.zoom,t.center);L.DomUtil.setTransform(this._textArea,n,i.toFixed(3))},_updateTextAreaBounds:function(){var t,e,i,n;var r=this.feature;var a=r._bounds;var o=this._textArea;var s=this.map;if(null!==o){if(null!==a){t=r._getScale(s.getZoom());e=r._boundsToLatLngs(a);i=s.latLngToLayerPoint(e[1]);n=s.latLngToLayerPoint(e[3]).subtract(i);L.DomUtil.setSize(o,n.divideBy(t).round()).setTransform(o,i,t.toFixed(3));o.style.display="";o.style.position="absolute";o.setAttribute("spellcheck",false);this._focus()}else{o.style.display="none"}}return this}});L.TextBox.include({enableEdit:function(t){if(!this.editor){this.createEditor(t)}return L.Rectangle.prototype.enableEdit.call(this,t)},disableEdit:function(){if(this.editor){this._text=this.editor.getText()}L.Rectangle.prototype.disableEdit.call(this);return this},getEditorClass:function(){return L.Editable.TextBoxEditor}});L.Editable.prototype.startTextBox=function(t,e){return this.startRectangle(null,L.extend({rectangleClass:L.TextBox},e))}},{}],4:[function(t,e,i){/**
* SVG tools
*
* @author rumax
* @license MIT
* @preserve
*/
var n=12;var r=1.12;L.SVG.calcFontSize=L.SVG.calcFontSize||function(t){var e=n;var i=Number.MAX_VALUE;var r=Number.MIN_VALUE;var a=t.querySelectorAll("text");var o;if(0<a.length){e=0;for(var s=a.length-1;0<=s;--s){o=parseFloat(a[s].getAttribute("font-size"));e+=o;if(i>o){i=o}if(r<o){r=o}}return{size:Math.round(e/a.length+.5),min:Math.round(i+.5),max:Number.MIN_VALUE===r?e:Math.round(r+.5)}}return{size:e,min:e,max:e}};L.SVG.include({renderText:function(t){var e=t._textNode;var i=t._text;if(e){e.parentNode.removeChild(e)}e=t._textNode=L.SVG.create("text");t.updateStyle();this._rootGroup.appendChild(e);if(i){var n=t._getScale(this._map.getZoom());var a=t._rings[0][1];var o=t._rings[0][3].subtract(a).divideBy(n);var s=i.split("");var l=s.shift();var d=s.shift();var f=1;var u=o.x-t.options.padding;var h=this._textMakeNextLine(e,l,{x:t.options.padding});var x=e.getBBox().height;h.setAttribute("dy",x);while(d){if(" "===d){l+=d}else if("\n"===d){l="";h=this._textMakeNextLine(e,l,{x:t.options.padding,dy:r*x})}else if(" "!==d){var c=l;l+=d;h.firstChild.nodeValue=l;var p=t.options.padding+h.getComputedTextLength();if(p>u&&1<=l.length){++f;h.firstChild.nodeValue=c.replace(/\s*$/gm,"");c="";l=d;h=this._textMakeNextLine(e,l,{x:t.options.padding,dy:r*x})}}d=s.shift()}}else if(null!==e){e.parentNode.removeChild(e);e=null}return e},_textMakeNextLine:function(t,e,i){var n=L.SVG.create("tspan");var r;for(r in i||{}){if(i.hasOwnProperty(r)){n.setAttribute(r,i[r])}}n.appendChild(document.createTextNode(e||""));t.appendChild(n);return n}})},{}],5:[function(t,e,i){L.TextBox=L.Rectangle.extend({options:{padding:2,fontSize:12,fillOpacity:.5,fillColor:"#ffffff",weight:1,fontColor:"",fontFamily:"",ratio:1,text:"Please, add text"},initialize:function(t,e){L.Rectangle.prototype.initialize.call(this,t,e);this._text=this.options.text;this._textNode=null},setStyle:function(t){L.setOptions(this,t);if(this.editor&&this.editor._enabled){this.editor.updateStyle()}else{this._renderText()}},updateStyle:function(){var t=this._textNode;var e=this.options;if(null!==t){t.setAttribute("font-family",e.fontFamily);t.setAttribute("font-size",e.fontSize+"px");t.setAttribute("fill",e.fontColor)}},_renderText:function(){this._textNode=this._renderer.renderText(this);this._path.parentNode.insertBefore(this._textNode,this._path.nextSibling);this.updateStyle();this._updatePosition()},_updatePosition:function(){if(null!==this._textNode&&0!==this._rings.length){var t=this._rings[0][1];var e=new L.Matrix(1,0,0,1,0,0).translate(t).scale(this._getScale(this._map.getZoom()));this._textNode.setAttribute("transform","matrix("+e._matrix.join(" ")+")")}},_getScale:function(t){return this._map?Math.pow(2,t)*this.options.ratio:1},_updatePath:function(){L.Rectangle.prototype._updatePath.call(this);this._updatePosition()}})},{}],6:[function(t,e,i){L.DomUtil.setSize=L.DomUtil.setSize||function(t,e){t.style.width=e.x+"px";t.style.height=e.y+"px";return this}},{}]},{},[1])(1)});

@@ -11,3 +11,4 @@ /*eslint no-undef: "error"*/

require('./src/Editable.Textbox');
require('./src/SVG');
module.exports = L.Editable.TextBoxEditor;

2

package.json
{
"name": "leaflet-editable-textbox",
"version": "1.0.5",
"version": "1.0.6",
"description": "TextBox for Leaflet.Editable",

@@ -5,0 +5,0 @@ "main": "index.js",

@@ -68,2 +68,3 @@ /**

this._text = this.feature._text;
if (this._text) {

@@ -76,2 +77,7 @@ this._textArea.innerHTML = this._text;

if (this.feature._textNode) {
this.feature._textNode.parentNode.removeChild(this.feature._textNode);
this.feature._textNode = null;
}
return this;

@@ -108,2 +114,4 @@ },

}
this.feature._text = this._text;
this.feature._renderText();
}

@@ -188,13 +196,3 @@

}
var ret = L.Rectangle.prototype.enableEdit.call(this, map);
if (this._textNode) {
this._textNode.parentNode.removeChild(this._textNode);
this._textNode = null;
}
ret = L.Rectangle.prototype.enableEdit.call(this, map);
this.editor.setText(this._text);
return ret;
return L.Rectangle.prototype.enableEdit.call(this, map);
},

@@ -209,3 +207,2 @@

L.Rectangle.prototype.disableEdit.call(this);
this._renderText();

@@ -212,0 +209,0 @@ return this;

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