/**
* koglossarylinks - KOglossaryLinks is a jQuery plugin that shows glossary-style tooltips when hovered (or tapped on touchscreen devices)
* @version v0.4.0
* @link https://github.com/mrmartineau/KOglossaryLinks
* @license MIT
*/
;(function ($, f) {
var KOglossaryLinks = function () {
var _ = this;
_.tooltipClass = 'KOglossaryLinkTooltip';
_.element = '[data-koglossarylink]';
// Set some default options
_.options = {
sourceURL: '',
tooltipwidth: 260,
debug: false
};
_.init = function (el, options) {
_.options = $.extend(_.options, options);
_.el = el;
_.overEvent = _.supportsTouch() ? "click" : "mouseover";
_.terms = {};
if (_.options.debug) { console.log('_.options', _.options); }
$.getJSON(_.options.sourceURL).then(function (data) {
var jsonData = data;
for (var i = 0; i < jsonData.length; i++) {
_.terms[jsonData[i].term.toLowerCase()] = jsonData[i];
}
if (_.options.debug) { console.log('All the terms:', _.terms); }
});
_.el.on(_.overEvent, _.element, function (event) {
event.preventDefault();
event.stopPropagation();
// Close all other tooltips before opening this one
_.el.find(_.element).children('.' + _.tooltipClass).removeClass('is-visible');
var tooltipState = $(this).parent('.tooltipWrapper').length ? true : false; // Check if the toolip has been created already
var data = $(this).data('koglossarylink') !== undefined ? $(this).data('koglossarylink').toLowerCase() : '';
var tooltipCloseMarkup = _.supportsTouch() ? '
' : '';
var toolTipTitleClass = _.supportsTouch() ? _.tooltipClass + '-title ' + _.tooltipClass + '-title--touch' : _.tooltipClass + '-title';
if ( $(this).parent('.' + _.tooltipClass).hasClass('is-visible') ) {
$(this).parent('.' + _.tooltipClass).removeClass('is-visible');
} else {
// Only create markup if the tooltip hasn't been created
if (tooltipState) {
$(this).find('.' + _.tooltipClass).addClass('is-visible');
_.positionTooltip($(this));
return;
} else {
if (_.terms[data] !== undefined) {
var tooltip = '';
$(this).wrap("").append(tooltip);
$(this).find('.' + _.tooltipClass).addClass('is-visible');
_.positionTooltip($(this));
} else {
if (_.options.debug) { console.log('No term found'); }
}
}
}
});
_.el.on('mouseout', _.element, function () {
$(this).find('.' + _.tooltipClass).removeClass('is-visible');
});
_.el.on('click', _.element + ' .' + _.tooltipClass + '-close', function (event) {
event.preventDefault();
event.stopPropagation();
$(this).parent('.' + _.tooltipClass).removeClass('is-visible');
});
$(window).resize(_.positionTooltip(_.el.find(_.element)));
return _;
};
_.positionTooltip = function ($el) {
if ($el.offset() === undefined) { return; }
var $pos = parseInt($el.offset().left, 10);
var $elWidth = $el.width();
var $elCenterPoint = parseInt($pos + ($elWidth / 2), 10);
var $windowWidth = $(window).width();
var halfTooltipWidth = _.options.tooltipwidth / 2;
var $tooltip = $el.find('.' + _.tooltipClass);
var $tooltipTriangle = $el.find('.' + _.tooltipClass + '-triangle');
var difference;
var newTooltipCentre;
var newArrowCentre;
if ($elCenterPoint + halfTooltipWidth > $windowWidth) {
// El is floating off right side
difference = parseInt( (($elCenterPoint + halfTooltipWidth) - $windowWidth) + 20 , 10);
newTooltipCentre = parseInt(halfTooltipWidth + (difference / 2) + 20, 10);
newArrowCentre = parseInt(10 + (difference / 2), 10);
if (_.options.debug) {
console.log('El is floating off right side:', '\nwindow width', $windowWidth, '\nelcentrepoint', $elCenterPoint, '\ndifference', difference, '\nnewtooltipcentre', newTooltipCentre, '\nnewarrowcentre', newArrowCentre);
}
$tooltip.css({
marginLeft: '-' + newTooltipCentre + 'px'
});
$tooltipTriangle.css({
marginLeft: newArrowCentre + 'px'
});
} else if ($elCenterPoint - halfTooltipWidth < 0) {
// El is floating off left side
difference = parseInt($elCenterPoint, 10);
newTooltipCentre = difference - 20;
newArrowCentre = (halfTooltipWidth - 10) - (difference - 40);
if (_.options.debug) {
console.log('El is floating off left side:', '\nwindow width', $windowWidth, '\nelcentrepoint', $elCenterPoint, '\ndifference', difference, '\nnewtooltipcentre', newTooltipCentre, '\nnewarrowcentre', newArrowCentre);
}
$tooltip.css({
marginLeft: '-' + newTooltipCentre + 'px'
});
$tooltipTriangle.css({
marginLeft: '-' + newArrowCentre + 'px'
});
} else {
// Reset position back to normal
$tooltip.css({
marginLeft: '-' + halfTooltipWidth + 'px'
});
$tooltipTriangle.css({
marginLeft: '-10px'
});
}
};
_.supportsTouch = function() {
return ('ontouchstart' in document.documentElement) || (window.DocumentTouch && document instanceof DocumentTouch || navigator.msMaxTouchPoints ? true : false);
};
};
// Create a jQuery plugin
$.fn.KOglossaryLinks = function (options) {
var len = this.length;
return this.each(function (index) {
var me = $(this),
key = 'KOglossaryLinks' + (len > 1 ? '-' + ++index : ''),
instance = (new KOglossaryLinks).init(me, options)
;
// Invoke an KOglossaryLinks instance
me.data(key, instance).data('key', key);
});
};
KOglossaryLinks.version = "0.4.0";
})(jQuery, false);
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["jquery-KOglossaryLinks.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"jquery-KOglossaryLinks.js","sourcesContent":[";(function ($, f) {\n\tvar KOglossaryLinks = function () {\n\n\t\tvar _ = this;\n\t\t_.tooltipClass = 'KOglossaryLinkTooltip';\n\t\t_.element      = '[data-koglossarylink]';\n\n\t\t// Set some default options\n\t\t_.options = {\n\t\t\tsourceURL: '',\n\t\t\ttooltipwidth: 260,\n\t\t\tdebug: false\n\t\t};\n\n\t\t_.init = function (el, options) {\n\t\t\t_.options = $.extend(_.options, options);\n\t\t\t_.el = el;\n\t\t\t_.overEvent = _.supportsTouch() ? \"click\" : \"mouseover\";\n\t\t\t_.terms = {};\n\n\t\t\tif (_.options.debug) { console.log('_.options', _.options); }\n\n\t\t\t$.getJSON(_.options.sourceURL).then(function (data) {\n\t\t\t\tvar jsonData = data;\n\n\t\t\t\tfor (var i = 0; i < jsonData.length; i++) {\n\t\t\t\t\t_.terms[jsonData[i].term.toLowerCase()] = jsonData[i];\n\t\t\t\t}\n\t\t\t\tif (_.options.debug) { console.log('All the terms:', _.terms); }\n\t\t\t});\n\n\t\t\t_.el.on(_.overEvent, _.element, function (event) {\n\t\t\t\tevent.preventDefault();\n\t\t\t\tevent.stopPropagation();\n\n\t\t\t\t// Close all other tooltips before opening this one\n\t\t\t\t_.el.find(_.element).children('.' + _.tooltipClass).removeClass('is-visible');\n\n\t\t\t\tvar tooltipState       = $(this).parent('.tooltipWrapper').length ? true : false; // Check if the toolip has been created already\n\t\t\t\tvar data               = $(this).data('koglossarylink') !== undefined ? $(this).data('koglossarylink').toLowerCase() : '';\n\t\t\t\tvar tooltipCloseMarkup = _.supportsTouch() ? '<div class=\"' + _.tooltipClass + '-close icon-close\"></div>' : '';\n\t\t\t\tvar toolTipTitleClass  = _.supportsTouch() ? _.tooltipClass + '-title ' + _.tooltipClass + '-title--touch' : _.tooltipClass + '-title';\n\n\t\t\t\tif ( $(this).parent('.' + _.tooltipClass).hasClass('is-visible') ) {\n\t\t\t\t\t$(this).parent('.' + _.tooltipClass).removeClass('is-visible');\n\t\t\t\t} else {\n\t\t\t\t\t// Only create markup if the tooltip hasn't been created\n\t\t\t\t\tif (tooltipState) {\n\t\t\t\t\t\t$(this).find('.' + _.tooltipClass).addClass('is-visible');\n\t\t\t\t\t\t_.positionTooltip($(this));\n\t\t\t\t\t\treturn;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (_.terms[data] !== undefined) {\n\t\t\t\t\t\t\tvar tooltip = '<div class=\"' + _.tooltipClass + '\"><h3 class=\"' + toolTipTitleClass + '\">' + _.terms[data].term + '</h3><div class=\"' + _.tooltipClass + '-description\">' + _.terms[data].description + '</div>' + tooltipCloseMarkup + '<span class=\"' + _.tooltipClass + '-triangle\"></span></div>';\n\t\t\t\t\t\t\t$(this).wrap(\"<span class='tooltipWrapper'></span>\").append(tooltip);\n\t\t\t\t\t\t\t$(this).find('.' + _.tooltipClass).addClass('is-visible');\n\t\t\t\t\t\t\t_.positionTooltip($(this));\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tif (_.options.debug) { console.log('No term found'); }\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t_.el.on('mouseout', _.element, function () {\n\t\t\t\t$(this).find('.' + _.tooltipClass).removeClass('is-visible');\n\t\t\t});\n\n\t\t\t_.el.on('click', _.element + ' .' + _.tooltipClass + '-close', function (event) {\n\t\t\t\tevent.preventDefault();\n\t\t\t\tevent.stopPropagation();\n\t\t\t\t$(this).parent('.' + _.tooltipClass).removeClass('is-visible');\n\t\t\t});\n\n\t\t\t$(window).resize(_.positionTooltip(_.el.find(_.element)));\n\n\t\t\treturn _;\n\t\t};\n\n\t\t_.positionTooltip = function ($el) {\n\t\t\tif ($el.offset() === undefined) { return; }\n\n\t\t\tvar $pos = parseInt($el.offset().left, 10);\n\t\t\tvar $elWidth = $el.width();\n\t\t\tvar $elCenterPoint = parseInt($pos + ($elWidth / 2), 10);\n\t\t\tvar $windowWidth = $(window).width();\n\t\t\tvar halfTooltipWidth = _.options.tooltipwidth / 2;\n\t\t\tvar $tooltip = $el.find('.' + _.tooltipClass);\n\t\t\tvar $tooltipTriangle = $el.find('.' + _.tooltipClass + '-triangle');\n\t\t\tvar difference;\n\t\t\tvar newTooltipCentre;\n\t\t\tvar newArrowCentre;\n\n\t\t\tif ($elCenterPoint + halfTooltipWidth > $windowWidth) {\n\t\t\t\t// El is floating off right side\n\t\t\t\tdifference       = parseInt( (($elCenterPoint + halfTooltipWidth) - $windowWidth) + 20 , 10);\n\t\t\t\tnewTooltipCentre = parseInt(halfTooltipWidth + (difference / 2) + 20, 10);\n\t\t\t\tnewArrowCentre   = parseInt(10 + (difference / 2), 10);\n\n\t\t\t\tif (_.options.debug) {\n\t\t\t\t\tconsole.log('El is floating off right side:', '\\nwindow width', $windowWidth, '\\nelcentrepoint', $elCenterPoint, '\\ndifference', difference, '\\nnewtooltipcentre', newTooltipCentre, '\\nnewarrowcentre', newArrowCentre);\n\t\t\t\t}\n\n\t\t\t\t$tooltip.css({\n\t\t\t\t\tmarginLeft: '-' + newTooltipCentre + 'px'\n\t\t\t\t});\n\t\t\t\t$tooltipTriangle.css({\n\t\t\t\t\tmarginLeft: newArrowCentre + 'px'\n\t\t\t\t});\n\n\t\t\t} else if ($elCenterPoint - halfTooltipWidth < 0) {\n\t\t\t\t// El is floating off left side\n\t\t\t\tdifference       = parseInt($elCenterPoint, 10);\n\t\t\t\tnewTooltipCentre = difference - 20;\n\t\t\t\tnewArrowCentre   = (halfTooltipWidth - 10) - (difference - 40);\n\n\t\t\t\tif (_.options.debug) {\n\t\t\t\t\tconsole.log('El is floating off left side:', '\\nwindow width', $windowWidth, '\\nelcentrepoint', $elCenterPoint, '\\ndifference', difference, '\\nnewtooltipcentre', newTooltipCentre, '\\nnewarrowcentre', newArrowCentre);\n\t\t\t\t}\n\n\t\t\t\t$tooltip.css({\n\t\t\t\t\tmarginLeft: '-' + newTooltipCentre + 'px'\n\t\t\t\t});\n\t\t\t\t$tooltipTriangle.css({\n\t\t\t\t\tmarginLeft: '-' + newArrowCentre + 'px'\n\t\t\t\t});\n\n\t\t\t} else {\n\t\t\t\t// Reset position back to normal\n\t\t\t\t$tooltip.css({\n\t\t\t\t\tmarginLeft: '-' + halfTooltipWidth + 'px'\n\t\t\t\t});\n\t\t\t\t$tooltipTriangle.css({\n\t\t\t\t\tmarginLeft: '-10px'\n\t\t\t\t});\n\t\t\t}\n\t\t};\n\n\t\t_.supportsTouch = function() {\n\t\t\treturn ('ontouchstart' in document.documentElement) || (window.DocumentTouch && document instanceof DocumentTouch || navigator.msMaxTouchPoints ? true : false);\n\t\t};\n\n\t};\n\n\n\t//  Create a jQuery plugin\n\t$.fn.KOglossaryLinks = function (options) {\n\t\tvar len = this.length;\n\n\t\treturn this.each(function (index) {\n\t\t\tvar me = $(this),\n\t\t\t\tkey = 'KOglossaryLinks' + (len > 1 ? '-' + ++index : ''),\n\t\t\t\tinstance = (new KOglossaryLinks).init(me, options)\n\t\t\t;\n\n\t\t\t//  Invoke an KOglossaryLinks instance\n\t\t\tme.data(key, instance).data('key', key);\n\t\t});\n\t};\n\n\tKOglossaryLinks.version = \"0.4.0\";\n})(jQuery, false);\n"],"sourceRoot":"/source/"}