/**
 * @file These functions handle portal highlighters
 * @module portal_highlighter
 */

// 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';

/**
 * Adds a new portal highlighter to map. The highlighter is a function that will be called for each portal.
 *
 * @function addPortalHighlighter
 * @param {string} name - The name of the highlighter.
 * @param {Function} data - The callback function for the highlighter.
 *                          This function receives data about the portal and decides how to highlight it.
 */
window.addPortalHighlighter = function (name, data) {
  if (window._highlighters === null) {
    window._highlighters = {};
  }

  // old-format highlighters just passed a callback function. this is the same as just a highlight method
  if (!data.highlight) {
    data = { highlight: data };
  }

  window._highlighters[name] = data;

  if (window.isApp && window.app.addPortalHighlighter) window.app.addPortalHighlighter(name);

  if (window._current_highlighter === undefined) {
    window._current_highlighter = name;
  }

  if (window._current_highlighter === name) {
    if (window.isApp && window.app.setActiveHighlighter) window.app.setActiveHighlighter(name);

    // call the setSelected callback
    if (window._highlighters[window._current_highlighter].setSelected) {
      window._highlighters[window._current_highlighter].setSelected(true);
    }
  }
  window.updatePortalHighlighterControl();
};

/**
 * Updates the portal highlighter dropdown list, recreating the dropdown list of available highlighters.
 *
 * @function updatePortalHighlighterControl
 */
window.updatePortalHighlighterControl = function () {
  if (window.isApp && window.app.addPortalHighlighter) {
    $('#portal_highlight_select').remove();
    return;
  }

  if (window._highlighters !== null) {
    if ($('#portal_highlight_select').length === 0) {
      $('.leaflet-top.leaflet-left').first().append("<select id='portal_highlight_select' class='leaflet-control'></select>");
      $('#portal_highlight_select').change(function () {
        window.changePortalHighlights($(this).val());
      });
    }
    $('#portal_highlight_select').html('');
    $('#portal_highlight_select').append($('<option>').attr('value', window._no_highlighter).text(window._no_highlighter));
    var h_names = Object.keys(window._highlighters).sort();

    $.each(h_names, function (i, name) {
      $('#portal_highlight_select').append($('<option>').attr('value', name).text(name));
    });

    $('#portal_highlight_select').val(window._current_highlighter);
  }
};

/**
 * Changes the current portal highlights based on the selected highlighter.
 *
 * @function changePortalHighlights
 * @param {string} name - The name of the highlighter to be applied.
 */
window.changePortalHighlights = function (name) {
  // first call any previous highlighter select callback
  if (window._current_highlighter && window._highlighters[window._current_highlighter] && window._highlighters[window._current_highlighter].setSelected) {
    window._highlighters[window._current_highlighter].setSelected(false);
  }

  window._current_highlighter = name;
  if (window.isApp && window.app.setActiveHighlighter) window.app.setActiveHighlighter(name);

  // now call the setSelected callback for the new highlighter
  if (window._current_highlighter && window._highlighters[window._current_highlighter] && window._highlighters[window._current_highlighter].setSelected) {
    window._highlighters[window._current_highlighter].setSelected(true);
  }

  window.resetHighlightedPortals();
  localStorage.portal_highlighter = name;
};

/**
 * Applies the currently active highlighter to a specific portal.
 * This function is typically called for each portal on the map.
 *
 * @function highlightPortal
 * @param {Object} p - The portal object to be highlighted.
 */
window.highlightPortal = function (p) {
  if (window._highlighters !== null && window._highlighters[window._current_highlighter] !== undefined) {
    return window._highlighters[window._current_highlighter].highlight({ portal: p });
  }
};

/**
 * Resets the highlighting of all portals, returning them to their default style.
 *
 * @function resetHighlightedPortals
 */
window.resetHighlightedPortals = function () {
  $.each(window.portals, function (guid, portal) {
    window.setMarkerStyle(portal, guid === window.selectedPortal);
  });
};