Files
iD/modules/ui/source_switch.js
Quincy Morgan 32f8274929 Make t function return a span element with a lang attribute unless html: false is specified in the options (re: #7963)
Update `text` functions to `html` to support inserting the `span` elements
Specify `html: false` for various instances where a `span` is not desired, e.g. `placeholder` and `title` attributes
2020-09-15 21:56:22 -04:00

60 lines
1.5 KiB
JavaScript

import {
event as d3_event,
select as d3_select
} from 'd3-selection';
import { t } from '../core/localizer';
import { modeBrowse } from '../modes/browse';
export function uiSourceSwitch(context) {
var keys;
function click() {
d3_event.preventDefault();
var osm = context.connection();
if (!osm) return;
if (context.inIntro()) return;
if (context.history().hasChanges() &&
!window.confirm(t('source_switch.lose_changes'))) return;
var isLive = d3_select(this)
.classed('live');
isLive = !isLive;
context.enter(modeBrowse(context));
context.history().clearSaved(); // remove saved history
context.flush(); // remove stored data
d3_select(this)
.html(isLive ? t('source_switch.live') : t('source_switch.dev'))
.classed('live', isLive)
.classed('chip', isLive);
osm.switch(isLive ? keys[0] : keys[1]); // switch connection (warning: dispatches 'change' event)
}
var sourceSwitch = function(selection) {
selection
.append('a')
.attr('href', '#')
.html(t('source_switch.live'))
.attr('class', 'live chip')
.on('click', click);
};
sourceSwitch.keys = function(_) {
if (!arguments.length) return keys;
keys = _;
return sourceSwitch;
};
return sourceSwitch;
}