ProductRnR

Makes all of the ProductRnR HITs easier/faster.

目前为 2015-12-11 提交的版本。查看 最新版本

// ==UserScript==
// @name         ProductRnR
// @namespace    https://greasyfork.org/users/11580
// @version      1.9
// @description  Makes all of the ProductRnR HITs easier/faster.
// @author       Kadauchi
// @icon         http://www.mturkgrind.com/data/avatars/l/1/1084.jpg?1432698290
// @include      https://www.mturkcontent.com/dynamic/*
// @grant        GM_log
// @require      http://code.jquery.com/jquery-2.1.4.min.js
// ==/UserScript==

// Marks radio buttons.
$("input[value='notadult']").click(); // Marks Non-Adult.

// Checks to see if we are on the HIT: 
// If you were to select a caption for this image, which one would you prefer?
if ($("h1:contains(If you were to select a caption for this image, which one would you prefer?)").length){
	var Index = 0;

	$("div.documentbox").eq(Index).css({backgroundColor:"lightblue"});
	$("html, body").animate({
		scrollTop: $("div.documentbox").eq(Index).offset().top
	}, 0);

	$(window).keydown(function(e){
		if (e.keyCode == 49 || e.keyCode == 97){ //1 or Numpad 1   
			$(":radio:even").eq(Index).click();
			$("div.documentbox").css({backgroundColor:""});
			Index ++;
			$("div.documentbox").eq(Index).css({backgroundColor:"lightblue"});
			$("html, body").animate({
				scrollTop: $("div.documentbox").eq(Index).offset().top - $("div.documentbox").outerHeight()
			}, 0);
		}
		if (e.keyCode == 50 || e.keyCode == 98 ){ //2 or Numpad 2   
			$(":radio:odd").eq(Index).click();
			$("div.documentbox").css({backgroundColor:""});
			Index ++;
			$("div.documentbox").eq(Index).css({backgroundColor:"lightblue"});
			$("html, body").animate({
				scrollTop: $("div.documentbox").eq(Index).offset().top - $("div.documentbox").outerHeight()
			}, 0);
		}
		if (e.keyCode == 51 || e.keyCode == 99){ //3 or Numpad 3
			$("div.documentbox").css({backgroundColor:""});
			Index --;
			$("div.documentbox").eq(Index).css({backgroundColor:"lightblue"});
			$("html, body").animate({
				scrollTop: $("div.documentbox").eq(Index).offset().top - $("div.documentbox").outerHeight()
			}, 0);

		}
		if (e.keyCode === 13){
			$("button[name='SubmitButton']").click();
		}
	});
}

// Checks to see if we are on the HIT: 
// Identify pages where you can purchase a product (updated HIT & guidelines)
if ($("th:contains(Identify pages where you can purchase a product)").length){
	$("input[value='ShoppingPage_ProductAvailable']").click();
}

// Checks to see if we are on the HIT: 
// Determine whether the provided value of product attribute matches the corresponding value on the page
if ($("th:contains(Determine whether the provided value of product attribute matches the corresponding value on the page.)").length){
	$("input[value='Correct']").click();
}

// Checks to see if we are on the HIT: 
// Identify these images as School appropriate. (WARNING: This HIT may contain adult content. Worker discretion is advised.)
if ($("label:contains(OK to show)").length){
	$("input[value='AdultImageV2_OkToShow']").click();
}

// Checks to see if we are on the HIT: 
// Determine whether or not the given image is an image of the product being sold on the provided page				
if ($("h1:contains(Determine whether or not the given image is an image of the product being sold on the provided page.)").length){
	//alert("hi");
	$("input[value='ShoppingImage_MatchesProduct']").prop("checked", true);
}

// Checks to see if we are on the HIT: 
// If you looked at and liked the image above, which of the images below would you be more interested to see?		
if ($("div:contains(You are browsing the web for Images. If you looked at and liked the image above, which of the images below would you be more interested to see?)").length){
	$(":radio:even").click();
}

// Checks to see if we are on the HIT: 
// Choose between two pictures of a given person		
if ($("div:contains(Which of the 2 images would you prefer to represent the given person? You can use the name to search for more context on the person if necessary.)").length){
	$(":radio:even").click();
}

// Checks to see if we are on the HIT: 
// Checks to see if we are on Label images based on their relevance for the query.
if ($("b:contains(Unrelated/Only Indirectly Related)").length){
	ProductRnR_Relevance_Query();
}

function ProductRnR_Relevance_Query(){
	$(":radio").on('change',function(){
		$(this).next(":contains(Related)").parent().parent().css("opacity", "1").css({ backgroundColor: "lightgreen", opacity: "1"});
		$(this).next(":contains(Unrelated/Indirectly Related)").parent().parent().css("opacity", "1").css({ backgroundColor: "red", opacity: "1"});
		$(this).next(":contains(Image didn't load)").parent().parent().css({ backgroundColor: "", opacity: "0.1"});
	});
	$("input[value='QueryImage_Unrelated']").prop("checked", true).change();
	$(".documentbox").click(function(e){e.preventDefault();});
	$('.documentbox').contextmenu( function() {
		return false;
	});
	$(".documentbox").mousedown(function(e){
		switch (e.which) {
			case 1:
				if($(this).find("input:radio:checked").next(":contains(Related):not(:contains('Unrelated'))").length > 0){
					$(this).find("input[value='QueryImage_Unrelated']").prop("checked", true).change();return false;
				}
				if($(this).find("input:radio:checked").next(":contains(Image didn't load)").length > 0){
					$(this).find("input[value='QueryImage_Related']").prop("checked", true).change();return false;
				}
				if($(this).find("input:radio:checked").next(":contains(Unrelated/Indirectly Related)").length > 0){
					$(this).find("input[value='QueryImage_Related']").prop("checked", true).change();return false;
				}
				break;
			case 3:
				$(this).find("input[value='NoLoad']").prop("checked", true).change();return false;
				break;
		}
	});
	$("img").error(function(){
		$(this).parents(".documentbox").find("input[value='NoLoad']").prop("checked", true).change();
	});
}

// Checks to see if we are on the HIT: 
// Checks to see if we are on mark excellent HITs.
if ($("b:contains(excellent)").length){
	ProductRnR_Excellent();
}

function ProductRnR_Excellent(){
	$(":radio").on('change',function(){
		$(this).next(":contains(Excellent)").parent().parent().css("opacity", "1").css({ backgroundColor: "lightgreen", opacity: "1"});
		$(this).next(":contains(Not Excellent)").parent().parent().css("opacity", "1").css({ backgroundColor: "red", opacity: "1"});
		$(this).next(":contains(Image didn't load)").parent().parent().css({ backgroundColor: "", opacity: "0.1"});
	});
	$("input[value='Excellent']").prop("checked", true).change();
	$(".documentbox").click(function(e){e.preventDefault();});
	$('.documentbox').contextmenu( function() {
		return false;
	});
	$(".documentbox").mousedown(function(e){
		switch (e.which) {
			case 1:
				if($(this).find("input:radio:checked").next(":contains(Excellent):not(:contains('Not'))").length > 0){
					$(this).find("input[value='Bad']").prop("checked", true).change();return false;
				}
				if($(this).find("input:radio:checked").next(":contains(Image didn't load)").length > 0){
					$(this).find("input[value='Excellent']").prop("checked", true).change();return false;
				}
				if($(this).find("input:radio:checked").next(":contains(Not Excellent)").length > 0){
					$(this).find("input[value='Excellent']").prop("checked", true).change();return false;
				}
				break;
			case 3:
				$(this).find("input[value='NoLoad']").prop("checked", true).change();return false;
				break;
		}
	});
	$("img").error(function(){
		$(this).parents(".documentbox").find("input[value='NoLoad']").prop("checked", true).change();
	});
}

// Enter will sunmit the HIT.
window.onkeydown = function(event) {
	if (event.keyCode === 13) {
		$("button[name='SubmitButton']").click();
	}
};