lbry.com/web/js/global.js
ポール ウェッブ cc91d0ac57 Initial commit
2019-03-28 17:52:41 -05:00

142 lines
3.8 KiB
JavaScript

window.lbry = {};
jQuery.fn.extend({
jFor: function() {
var self = $(this),
target = self.data('for') || self.attr('for');
if (!target)
return $();
if (target instanceof jQuery)
return target;
return $(target.toString());
}
});
$(document).ready(function() {
var body = $('body');
body.on('click', 'a', onAnchorClick);
if (window.twttr) {
twttr.events.bind('follow', onTwitterFollow);
}
window.fbAsyncInit = function() {
window.FB.Event.subscribe('edge.create', onFacebookLike);
}
function onAnchorClick() {
var anchor = $(this),
action = anchor.data('action');
if (action == 'toggle') {
anchor.jFor().toggle();
anchor.data('toggle-count', 1 + (anchor.data('toggle-count') ? anchor.data('toggle-count') : 0));
anchor.find('.toggle-even, .toggle-odd').hide();
anchor.find(anchor.data('toggle-count') % 2 == 1 ? '.toggle-odd' : '.toggle-even').show();
}
if (action == 'toggle-class') {
anchor.jFor().toggleClass(anchor.data('class'));
}
if (anchor.data('facebook-track') && window.fbq) {
fbq('track', "Lead");
}
if (anchor.data('twitter-track-id') && window.twttr) {
twttr.conversion.trackPid(anchor.data('twitter-track-id'));
}
if (anchor.data('analytics-category') && anchor.data('analytics-action') && anchor.data('analytics-label') && window.ga) {
ga('send', 'event', anchor.data('analytics-category'), anchor.data('analytics-action'), anchor.data('analytics-label'));
}
}
function resizeVideo(iframe) {
var maxWidth = Math.min(iframe.offsetParent().width(), iframe.data('maxWidth')),
maxHeight = iframe.data('maxHeight'),
ratio = iframe.data('aspectRatio');
if (ratio && maxWidth && maxHeight) {
var height = maxWidth * ratio,
width = maxWidth;
if (height > maxHeight) {
height = maxHeight;
width = maxHeight * 1 / ratio;
}
iframe
.width(width)
.height(width * ratio);
}
}
function onTwitterFollow(intentEvent) {
if (!intentEvent || !ga)
return;
ga('send', 'social', 'Twitter', 'follow', window.location.href);
}
function onFacebookLike() {
if (!ga)
return;
ga('send', 'social', 'Facebook', 'like', window.location.href);
}
});
// Automatically open external links in new tabs
document.querySelectorAll("a[href]").forEach(link => {
if (link.href.indexOf(location.hostname) === -1) {
link.rel = "noopener noreferrer";
link.target = "_blank";
}
});
// Greet visitors from .tech
document.addEventListener("DOMContentLoaded", () => {
switch(true) {
case document.referrer.includes("http://localhost:8080"):
case document.referrer.includes("https://lbry.tech"):
const html = `
<section class="alert" id="tech-greeting">
<div class="inner-wrap">
<p><strong>Welcome to the consumer side of LBRY!</strong> You've had fun delving into the tech, we hope.</p>
<br><br>
<p>Here by accident? Come back to <a href="${document.referrer}">the techno scene</a>.</p>
<button id="close-alert">&times;</button>
</div>
</section>
`;
document.querySelector("body").insertAdjacentHTML("afterend", html);
document.getElementById("close-alert").onclick = () => {
document.getElementById("tech-greeting").style.display = "none";
};
break;
default:
break;
}
});
// Fix for touchscreen devices
const navigationLinks = document.querySelectorAll("drawer-title");
navigationLinks.forEach(navigationLink => {
navigationLink.ontouchstart = () => {
// $("drawer-navigation-helper").hide(); // rewrite this in vanilla JS
navigationLink.onhover.call(navigationLink);
};
});