Greasy Fork

Plex now playing badge

Display a badge on favicon with a number of users streaming from the server

目前为 2017-09-01 提交的版本。查看 最新版本

// ==UserScript==
// @name        Plex now playing badge
// @namespace   V@no
// @description Display a badge on favicon with a number of users streaming from the server
// @author      V@no
// @include     http://localhost:32400/web/*
// @include     http://127.0.0.1:32400/web/*
// @include     https://app.plex.tv/desktop
// @include     https://app.plex.tv/desktop/*
// @icon        
// @version     1.1
// @grant       none
// ==/UserScript==

var links = document.getElementsByTagName("link"),
		link = null,
		head = document.getElementsByTagName('head')[0],
		prev = null;

for(let i = 0; i < links.length; i++)
{
	if (links[i].getAttribute("rel") == "shortcut icon")
	{
		link = links[i];
		break;
	}
}
if (!link)
{
	link = document.createElement('link');
	link.type = 'image/x-icon';
	link.rel = 'shortcut icon';
	link.href = "/web/favicon.ico";
	head.appendChild(link);

/*
	link = document.createElement('img');
	document.body.appendChild(link);
	let span = document.createElement("span");
	span.className = "activity-badge badge badge-transparent";
	span.innerText = "0";
	document.body.appendChild(span);
*/
}
var src = link.href,
		_coords = [
			{// badge < 10
				roundRect: [14, 11, 18, 21, 4],
				lineWidth: 3,
				text: [17, 30],
				size: 23,
				color: ["#F00", "#FFF", "#000"]
			},
			{// badge > 9
				roundRect: [4, 11, 28, 21, 4],
				lineWidth: 3,
				text: [5, 30],
				size: 23,
				color: ["#F00", "#FFF", "#000"]
			}
		];

(function loop()
{
	let badge = document.getElementsByClassName("activity-badge badge badge-transparent");
	badge = badge.length ? badge[0].innerText : "";
	
	let text = parseInt(badge);

	if (isNaN(text))
		text = 0;

	if (badge && prev != text)
	{
		let canvas = document.createElement('canvas'),
				ctx = canvas.getContext('2d'),
				img = new Image();

		canvas.width = 32;
		canvas.height = 32;
		img.setAttribute('crossOrigin','anonymous');
		img.src = src;
		img.onload = function()
		{
			ctx.drawImage(img, 0, 0);
			if (text)
			{
				let coords = _coords[text < 10 ? 0 : 1];
				ctx.fillStyle = coords.color[0];
				ctx.roundRect.apply(ctx, coords.roundRect).fill();
				ctx.font = 'bold ' + coords.size + 'px sans-serif';
				ctx.strokeStyle = coords.color[2];
				ctx.lineWidth = coords.lineWidth;
				ctx.strokeText(text, coords.text[0], coords.text[1]);
				ctx.fillStyle = coords.color[1];
				ctx.fillText(text, coords.text[0], coords.text[1]);
			}
			link.href = canvas.toDataURL("image/x-icon");
			prev = text;
/*
			link.src = canvas.toDataURL("image/x-icon");
			badge[0].innerText++;
*/
		};
	}
	setTimeout(loop, 3000);
})();

//https://stackoverflow.com/a/7838871/2930038
CanvasRenderingContext2D.prototype.roundRect = function (x, y, w, h, r)
{
  if (w < 2 * r) r = w / 2;
  if (h < 2 * r) r = h / 2;
  this.beginPath();
  this.moveTo(x+r, y);
  this.arcTo(x+w, y,   x+w, y+h, r);
  this.arcTo(x+w, y+h, x,   y+h, r);
  this.arcTo(x,   y+h, x,   y,   r);
  this.arcTo(x,   y,   x+w, y,   r);
  this.closePath();
  return this;
};