// IIFE to ensure safe use of $
(function( $ ) {

  // Create plugin
  $.fn.tooltips = function(el) {

    var $tooltip,
      $body = $('body'),
      $el;

    // Ensure chaining works
    return this.each(function(i, el) {

      $el = $(el).attr("data-tooltip", i);

      // Make DIV and append to page
      var $tooltip = $('<div class="tooltip" data-tooltip="' + i + '"><div class="arrow"></div>' + $el.attr('title') + '</div>').appendTo("#image-map");

      // Position right away, so first appearance is smooth
      var linkPosition = $el.position();
      var linkHeight = $el.height();
      var linkWidth = $el.width();

      $tooltip.css({
        top: linkPosition.top + linkHeight + 5,
        left: linkPosition.left + (linkWidth/2) - ($tooltip.outerWidth()/2)
      });

      $el
      // Get rid of yellow box popup
      .removeAttr("title")

      // Mouseenter
      .hover(function() {

        $el = $(this);

        $tooltip = $('div[data-tooltip=' + $el.data('tooltip') + ']');

        // Reposition tooltip, in case of page movement e.g. screen resize
        var linkPosition = $el.position();
        var linkHeight = $el.height();

        $tooltip.css({
          top: linkPosition.top + linkHeight + 5,
          left: linkPosition.left + (linkWidth/2) - ($tooltip.outerWidth()/2)
        });

        // Adding class handles animation through CSS
        $tooltip.addClass("active");

        // Mouseleave
      }, function() {

        $el = $(this);

        // Temporary class for same-direction fadeout
        $tooltip = $('div[data-tooltip=' + $el.data('tooltip') + ']').addClass("out");

        // Remove all classes
        setTimeout(function() {
          $tooltip.removeClass("active").removeClass("out");
          }, 300);

        });

      });

    }

})(jQuery);
