Scripts:Animepage:Sourcecode1: Difference between revisions
Jump to navigation
Jump to search
m (Futurpruf) |
m (Firefox Script:Sourcecode1 moved to Scripts:Animepage:Sourcecode1) |
(No difference)
|
Revision as of 16:14, 23 July 2006
// AniDB-Site-Enhancements: Full // - Select all files of a group // - Replace vote-dropdowns with textfields (enter integers from 100 to 1000) // // Version 20051210.01 // works with FF1.5 and greasemonkey 0.6.4 // Copyright (c) 2005, Lupin III. // Released under the GPL license // http://www.gnu.org/copyleft/gpl.html // // Thanks to // TechNiko for the webspace // visnu for some advice on speedups for long animelists // // ==UserScript== // @name AniDB-Site-Enhancer: Full // @namespace lupin_sanseis_scripts // @description selects all files of a release group, replaces vote dropdowns with textfields // @include http://anidb.info/perl-bin/animedb.pl?show=anime&* // ==/UserScript== (function() { // 2D-array containing all the checkbox names corresponding to a group checkbox_names = new Object(); function initialize() { // use '//' to disable unwanted functions group_selects(); decimal_vote(); } function group_selects () { // look up the grouplist table (using the bold "Group Info:" as an anchor, as it's fast to find) var group_table = document.evaluate("//b/text()[starts-with(.,'Group') and contains(., 'Info:')]/../../../..", document, null, XPathResult.ANY_UNORDERED_NODE_TYPE, null).singleNodeValue; // when css convert of page happens // var group_table = document.evaluate("//div[class="anime_group"]/table", document, null, XPathResult.ANY_UNORDERED_NODE_TYPE, null).singleNodeValue; // will want checking though... // if (group_table == null){ return; } // search for trs of the group-list-table var trs = document.evaluate(".//tr", group_table, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null); var regexp = /gid=(\d+)"/; // walk through all rows of the table for (var i=0; i < trs.snapshotLength; i++) { var tr = trs.snapshotItem(i); // create an adittional column to add to the end of the row var td = document.createElement("td"); if (match = regexp.exec(tr.innerHTML)) { // found a group-id, so create the subarray for the checkboxnames and the checkbox var gid = match[1]; checkbox_names[gid] = new Array(); var input = document.createElement('input'); input.setAttribute('type', 'checkbox'); input.setAttribute('id', 'toggle_gid_'+gid); input.setAttribute('value', gid); input.addEventListener('click', toggle, false); td.appendChild(input); } else if (tr.innerHTML.match(/Group Info:/i)) { td.setAttribute('bgcolor', '#b0b0b0'); td.appendChild(document.createTextNode('toggle all')); } tr.appendChild(td); } // if checkbox_names still contains no elements, it's no animelisting --> exit function var found = false; for (var gid in checkbox_names) { found = true; break; } if (!found) { return; } // walk through all checkboxes in the page // if the checkboxname is like madd.f.xyz, try to find the gid in the same table-row // and add the checkboxname to the corresponding array var checkboxes = document.evaluate("//input[@type='checkbox' and starts-with(@name, 'madd.f.')]", document, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null); var regexp = /gid=(\d+)/; for (var i=0; i < checkboxes.snapshotLength; i++) { var tr = checkboxes.snapshotItem(i).parentNode.parentNode; if (match = regexp.exec(tr.innerHTML)) { var gid = match[1]; if (checkbox_names[gid]) { checkbox_names[gid].push(checkboxes.snapshotItem(i).name); } } } // add a title attribute to the created checkboxes for (var gid in checkbox_names) { document.getElementById('toggle_gid_'+gid).setAttribute('title', 'Toggle all files of this anime-group ('+checkbox_names[gid].length+' files)'); document.getElementById('toggle_gid_'+gid).parentNode.appendChild(document.createTextNode('('+checkbox_names[gid].length+')')); } // expand the grouplist too when expanding all file-entries (change href of plus icon) var as = document.evaluate("//a[contains(@href, 'expandall') and .//*[contains(@title, 'all entries')]]", document, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null); for (var i=0; i < as.snapshotLength; i++) { as.snapshotItem(i).href += '&showallag=1'; } // finally add the function for the checkbox onclick-handler to the document function toggle(_gid) { var _gid = this.getAttribute('value'); for (var i=0; i < checkbox_names[_gid].length; i++) { document.getElementsByName(checkbox_names[_gid][i])[0].checked = document.getElementById('toggle_gid_'+_gid).checked; } if (document.getElementById('toggle_gid_'+_gid).checked) { alert('Selected ' + checkbox_names[_gid].length + ' files. Please check for correctness!'); } else { alert('Removed all checkmarks for this group!'); } } } function decimal_vote() { // replace vote-dropdowns with textfields var selects = document.evaluate("//select[../input[@name = 'votea.tmpratenow' or @name = 'votea.ratenow']]", document, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null); for (var i = 0; i < selects.snapshotLength; i++) { var textfield = document.createElement('input'); textfield.setAttribute('type', 'text'); textfield.setAttribute('size', '25'); textfield.setAttribute('name', 'votea.rate'); textfield.setAttribute('value', 'vote from 100 to 1000'); selects.snapshotItem(i).parentNode.replaceChild(textfield, selects.snapshotItem(i)); } } window.addEventListener("load", initialize(), false); })();