- browseObjectList.appendChild(list);
-
- var link = document.createElement("a");
- link.href = this.protocol.url;
- link.appendChild(document.createTextNode(I18n.t('browse.start_rjs.object_list.api')));
- browseObjectList.appendChild(link);
-
- $("#browse_content").html(browseObjectList);
- }
- }
-
- function viewFeatureLink() {
- var layer = this.feature.layer;
-
- for (var i = 0; i < layer.selectedFeatures.length; i++) {
- var f = layer.selectedFeatures[i];
- layer.drawFeature(f, layer.styleMap.createSymbolizer(f, "default"));
- }
-
- onFeatureSelect(this.feature);
-
- if (browseMode != "auto") {
- map.setCenter(this.feature.geometry.getBounds().getCenterLonLat());
- }
-
- return false;
- }
-
- function loadObjectList() {
- $("#browse_content").empty();
- $("#browse_content").append(browseObjectList);
-
- return false;
- }
-
- function onFeatureSelect(feature) {
- // Unselect previously selected feature
- if (browseActiveFeature) {
- browseActiveFeature.layer.drawFeature(
- browseActiveFeature,
- browseActiveFeature.layer.styleMap.createSymbolizer(browseActiveFeature, "default")
- );
- }
-
- // Redraw in selected style
- feature.layer.drawFeature(
- feature, feature.layer.styleMap.createSymbolizer(feature, "select")
- );
-
- // If the current object is the list, don't innerHTML="", since that could clear it.
- if ($("#browse_content").firstChild == browseObjectList) {
- $("#browse_content").removeChild(browseObjectList);
- } else {
- $("#browse_content").empty();
- }
-
- // Create a link back to the object list
- var div = document.createElement("div");
- div.style.textAlign = "center";
- div.style.marginBottom = "20px";
- $("#browse_content").append(div);
- var link = document.createElement("a");
- link.href = "#";
- link.onclick = loadObjectList;
- link.appendChild(document.createTextNode(I18n.t('browse.start_rjs.object_list.back')));
- div.appendChild(link);
-
- var table = document.createElement("table");
- table.width = "100%";
- table.className = "browse_heading";
- $("#browse_content").append(table);
-
- var tr = document.createElement("tr");
- table.appendChild(tr);
-
- var heading = document.createElement("td");
- heading.appendChild(document.createTextNode(featureNameSelect(feature)));
- tr.appendChild(heading);
-
- var td = document.createElement("td");
- td.align = "right";
- tr.appendChild(td);
-
- var type = featureType(feature);
- var link = document.createElement("a");
- link.href = "/browse/" + type + "/" + feature.osm_id;
- link.appendChild(document.createTextNode(I18n.t('browse.start_rjs.object_list.details')));
- td.appendChild(link);
-
- var div = document.createElement("div");
- div.className = "browse_details";
-
- $("#browse_content").append(div);
-
- // Now the list of attributes
- var ul = document.createElement("ul");
- for (var key in feature.attributes) {
- var li = document.createElement("li");
- var b = document.createElement("b");
- b.appendChild(document.createTextNode(key));
- li.appendChild(b);
- li.appendChild(document.createTextNode(": " + feature.attributes[key]));
- ul.appendChild(li);
- }
-
- div.appendChild(ul);
-
- var link = document.createElement("a");
- link.href = "/browse/" + type + "/" + feature.osm_id + "/history";
- link.appendChild(document.createTextNode(I18n.t('browse.start_rjs.show_history')));
- link.onclick = OpenLayers.Function.bind(loadHistory, {
- type: type, feature: feature, link: link
- });
-
- div.appendChild(link);
-
- // Stash the currently drawn feature
- browseActiveFeature = feature;
- }
-
- function loadHistory() {
- this.link.href = "";
- this.link.innerHTML = I18n.t('browse.start_rjs.wait');
-
- $.ajax("/api/" + OSM.API_VERSION + "/" + this.type + "/" + this.feature.osm_id + "/history", {
- complete: OpenLayers.Function.bind(displayHistory, this)
- });
-
- return false;
- }
-
- function displayHistory(request) {
- if (browseActiveFeature.osm_id != this.feature.osm_id || $("#browse_content").firstChild == browseObjectList) {
- return false;
- }
-
- this.link.parentNode.removeChild(this.link);
-
- var doc = request.responseXML;
-
- var table = document.createElement("table");
- table.width = "100%";
- table.className = "browse_heading";
- $("#browse_content").append(table);
-
- var tr = document.createElement("tr");
- table.appendChild(tr);
-
- var heading = document.createElement("td");
- heading.appendChild(document.createTextNode(I18n.t("browse.start_rjs.history_for_feature", { feature: featureNameHistory(this.feature) })));
- tr.appendChild(heading);
-
- var td = document.createElement("td");
- td.align = "right";
- tr.appendChild(td);
-
- var link = document.createElement("a");
- link.href = "/browse/" + this.type + "/" + this.feature.osm_id + "/history";
- link.appendChild(document.createTextNode(I18n.t('browse.start_rjs.details')));
- td.appendChild(link);
-
- var div = document.createElement("div");
- div.className = "browse_details";
-
- var nodes = doc.getElementsByTagName(this.type);
- var history = document.createElement("ul");
- for (var i = nodes.length - 1; i >= 0; i--) {
- var user = nodes[i].getAttribute("user") || I18n.t('browse.start_rjs.private_user');
- var timestamp = nodes[i].getAttribute("timestamp");
- var item = document.createElement("li");
- item.appendChild(document.createTextNode(I18n.t("browse.start_rjs.edited_by_user_at_timestamp", { user: user, timestamp: timestamp })));
- history.appendChild(item);
- }
- div.appendChild(history);
-
- $("#browse_content").append(div);
- }
-
- function featureType(feature) {
- if (feature.geometry.CLASS_NAME == "OpenLayers.Geometry.Point") {
- return "node";
- } else {
- return "way";
- }
- }
-
- function featureTypeName(feature) {
- if (featureType(feature) == "node") {
- return I18n.t('browse.start_rjs.object_list.type.node');
- } else if (featureType(feature) == "way") {
- return I18n.t('browse.start_rjs.object_list.type.way');
- }
- }
-
- function featureName(feature) {
- var lang = $('html').attr('lang');
- if (feature.attributes['name:' + lang]) {
- return feature.attributes['name:' + lang];
- } else if (feature.attributes.name) {
- return feature.attributes.name;
- } else {
- return feature.osm_id;
- }
- }
-
- function featureNameSelect(feature) {
- var lang = $('html').attr('lang');
- if (feature.attributes['name:' + lang]) {
- return feature.attributes['name:' + lang];
- } else if (feature.attributes.name) {
- return feature.attributes.name;
- } else if (featureType(feature) == "node") {
- return I18n.t("browse.start_rjs.object_list.selected.type.node", { id: feature.osm_id });
- } else if (featureType(feature) == "way") {
- return I18n.t("browse.start_rjs.object_list.selected.type.way", { id: feature.osm_id });