// ==UserScript== // @name Steam DRM Highlighter Revenant // @namespace bf83963f-fffc-4c93-98ee-bc11e23e2176 // @author Rebecca Menessec (fr. Denilson Sá) // @version 1.8.0 // @description Highlight DRM-related words in Steam Store pages. // @icon  // @encoding utf-8 // @include http://store.steampowered.com/app/* // @include http://store.steampowered.com/sub/* // @include https://store.steampowered.com/app/* // @include https://store.steampowered.com/sub/* // @downloadURL https://update.greasyfork.icu/scripts/16785/Steam%20DRM%20Highlighter%20Revenant.user.js // @updateURL https://update.greasyfork.icu/scripts/16785/Steam%20DRM%20Highlighter%20Revenant.meta.js // ==/UserScript== ! function() { // Adds a new match to the found_in_this_page array. // Returns the added element. function add_match_to_page_list(text, element) { var new_match = { text: text.trim(), element: element, index: found_in_this_page.length, id: "bad_word_" + this.index }; return found_in_this_page.push(new_match), new_match } // Creates and returns a new element like this: // text function createBadWordElement(text) { var elem = document.createElement("span"), found = add_match_to_page_list(text, elem); return elem.setAttribute("class", "bad_word"), elem.setAttribute("id", found.id), elem.appendChild(document.createTextNode(text)), elem } // This function receives a list of text elements, and makes the highlight // in-place, directly in those elements. However, while doing so, some // elements are created and others are deleted. Thus, this function also // returns a new list of text elements (that can be passed again for // highlighting other words). // // This function was loosely based on: // http://userscripts.org/scripts/show/64232 function find_highlight_in_elements(bad_word_regexp, text_elements) { for (var new_text_elements = [], i = 0; i < text_elements.length; i++) for (var current = text_elements[i];;) { // current is a TextNode always attached to the document tree var match = bad_word_regexp.exec(current.nodeValue); if (!match) // no match { new_text_elements.push(current); break } var current_text = current.nodeValue, before_text = current_text.substring(0, match.index), middle_text = match[0], after_text = current_text.substring(bad_word_regexp.lastIndex), before = document.createTextNode(before_text), hl_node = createBadWordElement(middle_text), after = document.createTextNode(after_text), par = current.parentNode; par.insertBefore(before, current), par.insertBefore(hl_node, current), par.insertBefore(after, current), par.removeChild(current), new_text_elements.push(before), current = after, // Making it restart from the beginning. bad_word_regexp.lastIndex = 0 } return new_text_elements } // This is basically the main function of this script. // It finds all text nodes in the document and, for each one, tries // to find and highlight the bad_words. function highlight_words_in_document() { for (var result = document.evaluate("//body//text()", // XPath expression document, // contextNode null, // namespaceResolver XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null), result_len = result.snapshotLength, text_i = 0; result_len > text_i; text_i++) { var text = result.snapshotItem(text_i); // Ignoring hidden text inside some elements: if (!(1 == text.parentNode.nodeType && text.parentNode.nodeName.toLowerCase() in ignored_tags)) for (var text_elements = [text], i = 0; i < bad_words.length; i++) text_elements = find_highlight_in_elements(bad_words[i], text_elements) } } // Adds a