jellyfin-web/dashboard-ui/bower_components/emby-webcomponents/emby-button/paper-icon-button-light.js
Luke Pulverenti 0e0fa54547 update events
2016-08-07 15:43:52 -04:00

71 lines
1.7 KiB
JavaScript

define(['browser', 'dom', 'css!./emby-button', 'registerElement'], function (browser, dom) {
var EmbyButtonPrototype = Object.create(HTMLButtonElement.prototype);
function enableAnimation() {
if (browser.tv) {
// too slow
return false;
}
return true;
}
function animateButtonInternal(e, btn) {
var div = document.createElement('div');
div.classList.add('ripple-effect');
var offsetX = e.offsetX || 0;
var offsetY = e.offsetY || 0;
if (offsetX > 0 && offsetY > 0) {
div.style.left = offsetX + 'px';
div.style.top = offsetY + 'px';
}
btn.appendChild(div);
div.addEventListener("animationend", function () {
div.parentNode.removeChild(div);
}, false);
}
function animateButton(e) {
var btn = this;
requestAnimationFrame(function () {
animateButtonInternal(e, btn);
});
}
function onKeyDown(e) {
if (e.keyCode == 13) {
animateButton.call(this, e);
}
}
EmbyButtonPrototype.attachedCallback = function () {
if (this.classList.contains('paper-icon-button-light')) {
return;
}
this.classList.add('paper-icon-button-light');
if (enableAnimation()) {
dom.addEventListener(this, 'keydown', onKeyDown, {
passive: true
});
dom.addEventListener(this, 'click', animateButton, {
passive: true
});
}
};
document.registerElement('paper-icon-button-light', {
prototype: EmbyButtonPrototype,
extends: 'button'
});
});