-//= require templates/map/layers
-
-L.OSM.Layers = L.Control.extend({
- onAdd: function (map) {
- this._map = map;
- this._initLayout(map);
- return this._container;
- },
+L.OSM.layers = function(options) {
+ var control = L.control(options);
+
+ control.onAdd = function (map) {
+ var layers = options.layers;
+
+ var $container = $('<div>')
+ .attr('class', 'control-layers');
+
+ var button = $('<a>')
+ .attr('class', 'control-button')
+ .attr('href', '#')
+ .attr('title', I18n.t('javascripts.map.layers.title'))
+ .html('<span class="icon layers"></span>')
+ .on('click', toggle)
+ .appendTo($container);
+
+ var $ui = $('<div>')
+ .attr('class', 'layers-ui');
+
+ $('<div>')
+ .attr('class', 'sidebar_heading')
+ .appendTo($ui)
+ .append(
+ $('<span>')
+ .text(I18n.t('javascripts.close'))
+ .attr('class', 'icon close')
+ .bind('click', toggle))
+ .append(
+ $('<h4>')
+ .text(I18n.t('javascripts.map.layers.header')));
+
+ var baseSection = $('<div>')
+ .attr('class', 'section base-layers')
+ .appendTo($ui);
+
+ list = $('<ul>')
+ .appendTo(baseSection);
+
+ layers.forEach(function(layer) {
+ var item = $('<li>')
+ .appendTo(list);