/* Toolgif | https://mburakerman.github.io/toolgif/ | @mburakerman | License: MIT */ (function () { class Toolgif { #giphyApiKey = 'MFkHa14W6F1BYFsvPVgCwnt4IEyAmiia'; #placementBottom = 'bottom'; #placementTop = 'top'; constructor(el, options = {}) { this.el = document.querySelectorAll(el); this.options = options; this.defaultOptions = { width: 120, height: 100, borderRadius: 5, placement: this.#placementTop, downsized: true, preloader: '%0D%0AL2dvby5nbC83QUp6YkwgLS0+Cjxzdmcgd2lkdGg9IjQ0IiBoZWlnaHQ9IjQ0IiB2aWV3Qm94PSIw%0D%0AIDAgNDQgNDQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjNzE2%0D%0AOERCIj4KICAgIDxnIGZpbGw9Im5vbmUiIGZpbGwtcnVsZT0iZXZlbm9kZCIgc3Ryb2tlLXdpZHRo%0D%0APSIyIj4KICAgICAgICA8Y2lyY2xlIGN4PSIyMiIgY3k9IjIyIiByPSIxIj4KICAgICAgICAgICAg%0D%0APGFuaW1hdGUgYXR0cmlidXRlTmFtZT0iciIKICAgICAgICAgICAgICAgIGJlZ2luPSIwcyIgZHVy%0D%0APSIxLjhzIgogICAgICAgICAgICAgICAgdmFsdWVzPSIxOyAyMCIKICAgICAgICAgICAgICAgIGNh%0D%0AbGNNb2RlPSJzcGxpbmUiCiAgICAgICAgICAgICAgICBrZXlUaW1lcz0iMDsgMSIKICAgICAgICAg%0D%0AICAgICAgIGtleVNwbGluZXM9IjAuMTY1LCAwLjg0LCAwLjQ0LCAxIgogICAgICAgICAgICAgICAg%0D%0AcmVwZWF0Q291bnQ9ImluZGVmaW5pdGUiIC8+CiAgICAgICAgICAgIDxhbmltYXRlIGF0dHJpYnV0%0D%0AZU5hbWU9InN0cm9rZS1vcGFjaXR5IgogICAgICAgICAgICAgICAgYmVnaW49IjBzIiBkdXI9IjEu%0D%0AOHMiCiAgICAgICAgICAgICAgICB2YWx1ZXM9IjE7IDAiCiAgICAgICAgICAgICAgICBjYWxjTW9k%0D%0AZT0ic3BsaW5lIgogICAgICAgICAgICAgICAga2V5VGltZXM9IjA7IDEiCiAgICAgICAgICAgICAg%0D%0AICBrZXlTcGxpbmVzPSIwLjMsIDAuNjEsIDAuMzU1LCAxIgogICAgICAgICAgICAgICAgcmVwZWF0%0D%0AQ291bnQ9ImluZGVmaW5pdGUiIC8+CiAgICAgICAgPC9jaXJjbGU+CiAgICAgICAgPGNpcmNsZSBj%0D%0AeD0iMjIiIGN5PSIyMiIgcj0iMSI+CiAgICAgICAgICAgIDxhbmltYXRlIGF0dHJpYnV0ZU5hbWU9%0D%0AInIiCiAgICAgICAgICAgICAgICBiZWdpbj0iLTAuOXMiIGR1cj0iMS44cyIKICAgICAgICAgICAg%0D%0AICAgIHZhbHVlcz0iMTsgMjAiCiAgICAgICAgICAgICAgICBjYWxjTW9kZT0ic3BsaW5lIgogICAg%0D%0AICAgICAgICAgICAga2V5VGltZXM9IjA7IDEiCiAgICAgICAgICAgICAgICBrZXlTcGxpbmVzPSIw%0D%0ALjE2NSwgMC44NCwgMC40NCwgMSIKICAgICAgICAgICAgICAgIHJlcGVhdENvdW50PSJpbmRlZmlu%0D%0AaXRlIiAvPgogICAgICAgICAgICA8YW5pbWF0ZSBhdHRyaWJ1dGVOYW1lPSJzdHJva2Utb3BhY2l0%0D%0AeSIKICAgICAgICAgICAgICAgIGJlZ2luPSItMC45cyIgZHVyPSIxLjhzIgogICAgICAgICAgICAg%0D%0AICAgdmFsdWVzPSIxOyAwIgogICAgICAgICAgICAgICAgY2FsY01vZGU9InNwbGluZSIKICAgICAg%0D%0AICAgICAgICAgIGtleVRpbWVzPSIwOyAxIgogICAgICAgICAgICAgICAga2V5U3BsaW5lcz0iMC4z%0D%0ALCAwLjYxLCAwLjM1NSwgMSIKICAgICAgICAgICAgICAgIHJlcGVhdENvdW50PSJpbmRlZmluaXRl%0D%0AIiAvPgogICAgICAgIDwvY2lyY2xlPgogICAgPC9nPgo8L3N2Zz4=', }; this.options = Object.assign(this.defaultOptions, this.options); } toolgif() { for (let i = 0; i < this.el.length; i++) { const currentElement = this.el[i]; currentElement.style.position = 'relative'; currentElement.style.top = 0; const img = document.createElement('img'); currentElement.appendChild(img); img.className = 'toolgif-gif' + ' ' + 'toolgif-gif-' + i; if (this.options.preloader !== null) img.src = this.options.preloader; let defaultStyles = { display: 'block', visibility: 'hidden', opacity: 0, position: 'absolute', left: '50%', marginLeft: -(this.options.width / 2) + 'px', borderRadius: this.options.borderRadius + 'px', width: this.options.width + 'px', height: this.options.height + 'px', transition: 'all .2s', transform: 'translateY(5px)', zIndex: 9999, }; Object.getOwnPropertyNames(defaultStyles).forEach((cssProperty) => { img.style[cssProperty] = defaultStyles[cssProperty]; }); if (this.options.placement == this.#placementBottom) { img.style.top = currentElement.offsetHeight + 'px'; } else { img.style.bottom = currentElement.offsetHeight + 'px'; } currentElement.addEventListener('mouseenter', (e) => { if ( this.options.preloader !== null || this.options.preloader !== '' ) { img.src = this.options.preloader; } img.style.transform = 'translateY(0px)'; img.style.visibility = 'visible'; img.style.opacity = 1; const currentText = e.target.textContent; const dataToolgifTag = currentElement.getAttribute('data-toolgif-tag'); const dataToolgifUrl = currentElement.getAttribute('data-toolgif-url'); if (this.#isDataToolgifExist(currentElement, 'url')) { img.src = dataToolgifUrl; return; } if (this.#isDataToolgifExist(currentElement, 'tag')) { this.#fetchGiphyDataAndSetImageSource(img, dataToolgifTag); } else { this.#fetchGiphyDataAndSetImageSource(img, currentText); } }); currentElement.addEventListener('mouseleave', (e) => { img.style.transform = 'translateY(5px)'; img.style.visibility = 'hidden'; img.style.opacity = 0; }); } } #isDataToolgifExist(element, name) { let dataToolgifUrl = element.getAttribute(`data-toolgif-${name}`); let isExist = false; if (dataToolgifUrl !== null && dataToolgifUrl !== '') { isExist = true; } else { isExist = false; } return isExist; } async #fetchGiphyDataAndSetImageSource(element, text) { const giphyUrl = `https://api.giphy.com/v1/gifs/random?&api_key=${this.#giphyApiKey}&q=&tag=${text}`; return await fetch(giphyUrl) .then((res) => res.json()) .then((data) => { const gifUrl = data.data.image_url; const downsizdedGifUrl = data.data.images.downsized.url; this.options.downsized ? (element.src = downsizdedGifUrl) : (element.src = gifUrl); }); } } if (typeof module !== 'undefined' && typeof module.exports !== 'undefined') { module.exports = Toolgif; } else { if (typeof define === 'function' && define.amd) { define([], function () { return Toolgif; }); } else { window.Toolgif = Toolgif; } } })();