Add embedded sharing to Google Play Music from Chrome ext.

This commit is contained in:
Jonathan Cremin 2015-12-01 10:57:56 +00:00
parent 93ae893400
commit dbc7f4806d
9 changed files with 170 additions and 37 deletions

View file

@ -0,0 +1,77 @@
var events = {},
selectors = {},
styles = document.createElement('style'),
keyframes = document.createElement('style'),
head = document.getElementsByTagName('head')[0],
startNames = ['animationstart', 'oAnimationStart', 'MSAnimationStart', 'webkitAnimationStart'],
startEvent = function(event){
event.selector = (events[event.animationName] || {}).selector;
((this.selectorListeners || {})[event.animationName] || []).forEach(function(fn){
fn.call(this, event);
}, this);
},
prefix = (function() {
var duration = 'animation-duration: 0.001s;',
name = 'animation-name: SelectorListener !important;',
computed = window.getComputedStyle(document.documentElement, ''),
pre = (Array.prototype.slice.call(computed).join('').match(/moz|webkit|ms/)||(computed.OLink===''&&['o']))[0];
return {
css: '-' + pre + '-',
properties: '{' + duration + name + '-' + pre + '-' + duration + '-' + pre + '-' + name + '}',
keyframes: !!(window.CSSKeyframesRule || window[('WebKit|Moz|MS|O').match(new RegExp('(' + pre + ')', 'i'))[1] + 'CSSKeyframesRule'])
};
})();
styles.type = keyframes.type = 'text/css';
head.appendChild(styles);
head.appendChild(keyframes);
HTMLDocument.prototype.addSelectorListener = HTMLElement.prototype.addSelectorListener = function(selector, fn){
var key = selectors[selector],
listeners = this.selectorListeners = this.selectorListeners || {};
if (key) events[key].count++;
else {
key = selectors[selector] = 'SelectorListener-' + new Date().getTime();
var node = document.createTextNode('@' + (prefix.keyframes ? prefix.css : '') + 'keyframes ' + key + ' {'
+'from { outline-color: #fff; } to { outline-color: #000; }'
+ '}');
keyframes.appendChild(node);
styles.sheet.insertRule(selector + prefix.properties.replace(/SelectorListener/g, key), 0);
events[key] = { count: 1, selector: selector, keyframe: node, rule: styles.sheet.cssRules[0] };
}
if (listeners.count) listeners.count++;
else {
listeners.count = 1;
startNames.forEach(function(name){
this.addEventListener(name, startEvent, false);
}, this);
}
(listeners[key] = listeners[key] || []).push(fn);
};
HTMLDocument.prototype.removeSelectorListener = HTMLElement.prototype.removeSelectorListener = function(selector, fn){
var listeners = this.selectorListeners || {},
key = selectors[selector],
listener = listeners[key] || [],
index = listener.indexOf(fn);
if (index > -1){
var event = events[selectors[selector]];
event.count--;
if (!event.count){
styles.sheet.deleteRule(styles.sheet.cssRules.item(event.rule));
keyframes.removeChild(event.keyframe);
delete events[key];
delete selectors[selector];
}
listeners.count--;
listener.splice(index, 1);
if (!listeners.count) startNames.forEach(function(name){
this.removeEventListener(name, startEvent, false);
}, this);
}
};