- add an alternative API that includes a setSelected callback, so highlighters know when they're turned on/off - fix bug where highlighters were selected multiple times - a few other cleanups
103 lines
3.4 KiB
JavaScript
103 lines
3.4 KiB
JavaScript
// Portal Highlighter //////////////////////////////////////////////////////////
|
|
// these functions handle portal highlighters
|
|
|
|
// an object mapping highlighter names to the object containing callback functions
|
|
window._highlighters = null;
|
|
|
|
// the name of the current highlighter
|
|
window._current_highlighter = localStorage.portal_highlighter;
|
|
|
|
window._no_highlighter = 'No Highlights';
|
|
|
|
|
|
window.addPortalHighlighter = function(name, data) {
|
|
if(_highlighters === null) {
|
|
_highlighters = {};
|
|
}
|
|
|
|
// old-format highlighters just passed a callback function. this is the same as just a highlight method
|
|
if (!data.highlight) {
|
|
data = {highlight: data}
|
|
}
|
|
|
|
_highlighters[name] = data;
|
|
|
|
if (typeof android !== 'undefined' && android && android.addPortalHighlighter)
|
|
android.addPortalHighlighter(name);
|
|
|
|
if(window._current_highlighter === undefined) {
|
|
_current_highlighter = name;
|
|
}
|
|
|
|
if (_current_highlighter == name) {
|
|
if (typeof android !== 'undefined' && android && android.setActiveHighlighter)
|
|
android.setActiveHighlighter(name);
|
|
|
|
// call the setSelected callback
|
|
if (_highlighters[_current_highlighter].setSelected) {
|
|
_highlighters[_current_highlighter].setSelected(true);
|
|
}
|
|
|
|
}
|
|
updatePortalHighlighterControl();
|
|
}
|
|
|
|
// (re)creates the highlighter dropdown list
|
|
window.updatePortalHighlighterControl = function() {
|
|
if (typeof android !== 'undefined' && android && android.addPortalHighlighter) {
|
|
$('#portal_highlight_select').remove();
|
|
return;
|
|
}
|
|
|
|
if(_highlighters !== null) {
|
|
if($('#portal_highlight_select').length === 0) {
|
|
$("body").append("<select id='portal_highlight_select'></select>");
|
|
$("#portal_highlight_select").change(function(){ changePortalHighlights($(this).val());});
|
|
$(".leaflet-top.leaflet-left").css('padding-top', '20px');
|
|
$(".leaflet-control-scale-line").css('margin-top','25px');
|
|
}
|
|
$("#portal_highlight_select").html('');
|
|
$("#portal_highlight_select").append($("<option>").attr('value',_no_highlighter).text(_no_highlighter));
|
|
var h_names = Object.keys(_highlighters).sort();
|
|
|
|
$.each(h_names, function(i, name) {
|
|
$("#portal_highlight_select").append($("<option>").attr('value',name).text(name));
|
|
});
|
|
|
|
$("#portal_highlight_select").val(_current_highlighter);
|
|
}
|
|
}
|
|
|
|
window.changePortalHighlights = function(name) {
|
|
|
|
// first call any previous highlighter select callback
|
|
if (_current_highlighter && _highlighters[_current_highlighter] && _highlighters[_current_highlighter].setSelected) {
|
|
_highlighters[_current_highlighter].setSelected(false);
|
|
}
|
|
|
|
_current_highlighter = name;
|
|
if (typeof android !== 'undefined' && android && android.setActiveHighlighter)
|
|
android.setActiveHighlighter(name);
|
|
|
|
// now call the setSelected callback for the new highlighter
|
|
if (_current_highlighter && _highlighters[_current_highlighter] && _highlighters[_current_highlighter].setSelected) {
|
|
_highlighters[_current_highlighter].setSelected(true);
|
|
}
|
|
|
|
resetHighlightedPortals();
|
|
localStorage.portal_highlighter = name;
|
|
}
|
|
|
|
window.highlightPortal = function(p) {
|
|
|
|
if(_highlighters !== null && _highlighters[_current_highlighter] !== undefined) {
|
|
_highlighters[_current_highlighter].highlight({portal: p});
|
|
}
|
|
}
|
|
|
|
window.resetHighlightedPortals = function() {
|
|
$.each(portals, function(guid, portal) {
|
|
setMarkerStyle(portal, guid === selectedPortal);
|
|
});
|
|
}
|