mirror of
https://github.com/FoggedLens/iD.git
synced 2026-02-13 17:23:02 +00:00
97 lines
2.4 KiB
JavaScript
97 lines
2.4 KiB
JavaScript
import { t } from '../util/locale';
|
|
import { modeBrowse } from '../modes';
|
|
import { svgIcon } from '../svg';
|
|
|
|
import {
|
|
uiDataHeader,
|
|
uiQuickLinks,
|
|
uiRawTagEditor,
|
|
uiTooltipHtml
|
|
} from './index';
|
|
|
|
|
|
export function uiDataEditor(context) {
|
|
var dataHeader = uiDataHeader();
|
|
var quickLinks = uiQuickLinks();
|
|
var rawTagEditor = uiRawTagEditor(context);
|
|
var _datum;
|
|
|
|
|
|
function dataEditor(selection) {
|
|
// quick links
|
|
var choices = [{
|
|
id: 'zoom_to',
|
|
label: 'inspector.zoom_to.title',
|
|
tooltip: function() {
|
|
return uiTooltipHtml(t('inspector.zoom_to.tooltip_data'), t('inspector.zoom_to.key'));
|
|
},
|
|
click: function zoomTo() {
|
|
context.mode().zoomToSelected();
|
|
}
|
|
}];
|
|
|
|
|
|
var header = selection.selectAll('.header')
|
|
.data([0]);
|
|
|
|
var headerEnter = header.enter()
|
|
.append('div')
|
|
.attr('class', 'header fillL');
|
|
|
|
headerEnter
|
|
.append('button')
|
|
.attr('class', 'fr data-editor-close')
|
|
.on('click', function() {
|
|
context.enter(modeBrowse(context));
|
|
})
|
|
.call(svgIcon('#iD-icon-close'));
|
|
|
|
headerEnter
|
|
.append('h3')
|
|
.text(t('map_data.title'));
|
|
|
|
|
|
var body = selection.selectAll('.body')
|
|
.data([0]);
|
|
|
|
body = body.enter()
|
|
.append('div')
|
|
.attr('class', 'body')
|
|
.merge(body);
|
|
|
|
var editor = body.selectAll('.data-editor')
|
|
.data([0]);
|
|
|
|
editor.enter()
|
|
.append('div')
|
|
.attr('class', 'modal-section data-editor')
|
|
.merge(editor)
|
|
.call(dataHeader.datum(_datum))
|
|
.call(quickLinks.choices(choices));
|
|
|
|
var rte = body.selectAll('.raw-tag-editor')
|
|
.data([0]);
|
|
|
|
rte.enter()
|
|
.append('div')
|
|
.attr('class', 'raw-tag-editor inspector-inner data-editor')
|
|
.merge(rte)
|
|
.call(rawTagEditor
|
|
.expanded(true)
|
|
.readOnlyTags([/./])
|
|
.tags((_datum && _datum.properties) || {})
|
|
.state('hover')
|
|
);
|
|
}
|
|
|
|
|
|
dataEditor.datum = function(val) {
|
|
if (!arguments.length) return _datum;
|
|
_datum = val;
|
|
return this;
|
|
};
|
|
|
|
|
|
return dataEditor;
|
|
}
|