openlayers
Version:
Build tools and sources for developing OpenLayers based mapping applications
82 lines (72 loc) • 2.34 kB
JavaScript
(function() {
var copyButton = document.getElementById('copy-button');
if (copyButton) {
var data = document.getElementById('example-source').textContent;
new ZeroClipboard(copyButton).on('copy', function(event) {
event.clipboardData.setData({
'text/plain': data,
'text/html': data
});
});
}
var fiddleButton = document.getElementById('jsfiddle-button');
if (fiddleButton) {
fiddleButton.onclick = function(event) {
event.preventDefault();
document.getElementById('jsfiddle-form').submit();
};
}
if (window.location.host === 'localhost:3000') {
return;
}
var container = document.getElementById('navbar-logo-container');
if (!container) {
return;
}
var form = document.createElement('form');
var select = document.createElement('select');
var possibleModes = {
'raw' : 'Development',
'advanced': 'Production'
};
var urlMode = window.location.href.match(/mode=([a-z0-9\-]+)\&?/i);
var curMode = urlMode ? urlMode[1] : 'advanced';
for (var mode in possibleModes) {
if (possibleModes.hasOwnProperty(mode)) {
var option = document.createElement('option');
var modeTxt = possibleModes[mode];
option.value = mode;
option.innerHTML = modeTxt;
option.selected = curMode === mode;
select.appendChild(option);
}
}
select.onchange = function(event) {
var newMode = event.target.value;
var search = window.location.search.substring(1);
var baseUrl = window.location.href.split('?')[0];
var chunks = search ? search.split('&') : [];
var pairs = [];
var modeFound = false;
for (var i = chunks.length - 1; i >= 0; --i) {
var pair = chunks[i].split('=');
if (pair[0].toLowerCase() === 'mode') {
pair[1] = newMode;
modeFound = true;
}
var adjusted = encodeURIComponent(pair[0]);
if (typeof pair[1] !== undefined) {
adjusted += '=' + encodeURIComponent(pair[1] || '');
}
pairs.push(adjusted);
}
if (!modeFound) {
pairs.push('mode=' + encodeURIComponent(newMode));
}
location.href = baseUrl + '?' + pairs.join('&');
};
select.className = 'input-medium';
form.className = 'navbar-form version-form';
form.appendChild(select);
container.appendChild(form);
})();