/** * 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 = '

' + _.terms[data].term + '

' + _.terms[data].description + '
' + tooltipCloseMarkup + '
'; $(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/"}