+L.OSM.share = function (options) {
+ var control = L.control(options),
+ marker = L.marker([0, 0], {draggable: true}),
+ locationFilter = new L.LocationFilter({
+ enableButton: false,
+ adjustButton: false
+ });
+
+ control.onAdd = function (map) {
+ var $container = $('<div>')
+ .attr('class', 'control-share');
+
+ $('<a>')
+ .attr('class', 'control-button')
+ .attr('href', '#')
+ .attr('title', 'Share')
+ .html('<span class="icon share"></span>')
+ .on('click', toggle)
+ .appendTo($container);
+
+ var $ui = $('<div>')
+ .attr('class', 'share-ui');
+
+ $('<div>')
+ .attr('class', 'sidebar_heading')
+ .appendTo($ui)
+ .append(
+ $('<a>')
+ .text(I18n.t('javascripts.close'))
+ .attr('class', 'sidebar_close')
+ .attr('href', '#')
+ .bind('click', toggle))
+ .append(
+ $('<h4>')
+ .text(I18n.t('javascripts.share.title')));
+
+ // Link
+
+ var $linkSection = $('<div>')
+ .attr('class', 'section share-link')
+ .appendTo($ui);
+
+ $('<h4>')
+ .text(I18n.t('javascripts.share.link'))
+ .appendTo($linkSection);
+
+ var $form = $('<form>')
+ .attr('class', 'standard-form')
+ .appendTo($linkSection);
+
+ $('<div>')
+ .attr('class', 'form-row')
+ .appendTo($form)
+ .append(
+ $('<label>')
+ .attr('for', 'link_marker')
+ .append(
+ $('<input>')
+ .attr('id', 'link_marker')
+ .attr('type', 'checkbox')
+ .bind('change', toggleMarker))
+ .append(I18n.t('javascripts.share.include_marker')));
+
+ var $shortLink, $longLink;
+
+ $('<ul>')
+ .appendTo($linkSection)
+ .append($('<li>')
+ .append($longLink = $('<a>')
+ .text(I18n.t('javascripts.share.long_link'))))
+ .append($('<li>')
+ .append($shortLink = $('<a>')
+ .text(I18n.t('javascripts.share.short_link'))));
+
+ // Embeddable HTML
+
+ var $embedSection = $('<div>')
+ .attr('class', 'section share-html')
+ .appendTo($ui);
+
+ $('<h4>')
+ .text(I18n.t('javascripts.share.embed'))
+ .appendTo($embedSection);
+
+ $form = $('<form>')
+ .attr('class', 'standard-form')
+ .appendTo($embedSection);
+
+ $('<div>')
+ .attr('class', 'form-row')
+ .appendTo($form)
+ .append(
+ $('<label>')
+ .attr('for', 'embed_marker')
+ .append(
+ $('<input>')
+ .attr('id', 'embed_marker')
+ .attr('type', 'checkbox')
+ .bind('change', toggleMarker))
+ .append(I18n.t('javascripts.share.include_marker')));
+
+ $('<div>')
+ .attr('class', 'form-row')
+ .appendTo($form)
+ .append(
+ $('<textarea>')
+ .attr('id', 'embed_html')
+ .on('click', select));
+
+ $('<p>')
+ .attr('class', 'deemphasize')
+ .text(I18n.t('javascripts.share.paste_html'))
+ .appendTo($embedSection);
+
+ // Image
+
+ var $imageSection = $('<div>')
+ .attr('class', 'section share-image')
+ .appendTo($ui);
+
+ $('<h4>')
+ .text(I18n.t('javascripts.share.image'))
+ .appendTo($imageSection);
+
+ $form = $('<form>')
+ .attr('class', 'standard-form')
+ .attr('action', '/export/finish')
+ .attr('method', 'post')
+ .appendTo($imageSection);
+
+ $('<div>')
+ .attr('class', 'form-row')
+ .appendTo($form)
+ .append(
+ $('<label>')
+ .attr('for', 'image_filter')
+ .append(
+ $('<input>')
+ .attr('id', 'image_filter')
+ .attr('type', 'checkbox')
+ .bind('change', toggleFilter))
+ .append(I18n.t('javascripts.share.custom_dimensions')));
+
+ $('<div>')
+ .attr('class', 'form-row')
+ .appendTo($form)
+ .append(
+ $('<label>')
+ .attr('class', 'standard-label')
+ .attr('for', 'mapnik_format')
+ .text(I18n.t('javascripts.share.format')))
+ .append($('<select>')
+ .attr('name', 'mapnik_format')
+ .attr('id', 'mapnik_format')
+ .append($('<option>').val('png').text('PNG').prop('selected', true))
+ .append($('<option>').val('jpeg').text('JPEG'))
+ .append($('<option>').val('svg').text('SVG'))
+ .append($('<option>').val('pdf').text('PDF')));
+
+ $('<div>')
+ .attr('class', 'form-row')
+ .appendTo($form)
+ .append($('<label>')
+ .attr('class', 'standard-label')
+ .attr('for', 'mapnik_scale')
+ .text(I18n.t('javascripts.share.scale')))
+ .append('1 : ')
+ .append($('<input>')
+ .attr('name', 'mapnik_scale')
+ .attr('id', 'mapnik_scale')
+ .attr('type', 'text')
+ .on('change', update));
+
+ ['minlon', 'minlat', 'maxlon', 'maxlat'].forEach(function(name) {
+ $('<input>')
+ .attr('id', 'mapnik_' + name)
+ .attr('name', name)
+ .attr('type', 'hidden')
+ .appendTo($form);
+ });