NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript==
// @name POE Trade Fixes
// @namespace poetradefixes
// @version 2.0.1
// @description Fixes for official POE Trade
// @author iamroose
// @license MIT
// @match https://www.pathofexile.com/trade*
// @grant none
// @require https://raw.githubusercontent.com/tommoor/tinycon/master/tinycon.min.js
// @run-at document-start
// ==/UserScript==
(function(){
install();
var is_focused = true;
// Change the favicon
function updateFavicon() {
//document.querySelector("link[rel='icon']")?.remove();
document.querySelector("link[rel*='icon']")?.remove();
document.querySelector("link[rel='shortcut icon']")?.remove();
document.querySelector("link[rel='mask-icon']")?.remove();
var link = document.querySelector("link[rel='icon']") || document.createElement('link');
link.type = 'image/x-icon';
link.rel = 'icon';
link.sizes = '16x16';
link.href = '';
document.getElementsByTagName('head')[0].appendChild(link);
}
// Check live trade count and update favicon if necessary.
function updateCount(title) {
if(!is_focused){
var count = title.match(/\d+/)[0];
Tinycon.setBubble(count);
}
}
// Add some styles
function addStyles() {
var css = "#trade {max-width:920px;} .search-advanced-items {display:flex; flex-direction:column; margin-bottom: 20px;} .search-advanced-pane {width:100% !important; margin-bottom:20px;}.results .resultset{margin-bottom:0;}";
var style = document.createElement("style");
style.type = "text/css";
if (style.styleSheet){
style.styleSheet.cssText = css;
} else {
style.appendChild(document.createTextNode(css));
}
document.documentElement.appendChild(style);
}
// Observe any change in the <title> content, checking for the unread notification character.
function install() {
updateFavicon();
document.addEventListener('DOMContentLoaded', function(){
addStyles();
}, false);
var titleNode = document.querySelector('head > title');
this.observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
var newTitle = mutation.target.textContent;
updateCount(newTitle);
});
});
observer.observe(titleNode, { subtree: true, characterData: true, childList: true });
}
window.addEventListener("focus", function(event)
{
is_focused = true;
Tinycon.setBubble(0);
}, false);
window.addEventListener("blur", function(event)
{
is_focused = false;
}, false);
})();