mmmturkeybacon Embiggen Radio Buttons and Checkboxes

Adds a colored label around radio buttons and checkboxes that increases the area that registers a click. If the button/box is clicked the label turns green. This script lets you more effectively click while requiring less precision and makes it easier to see which items are selected. I can't guarantee this script won't foul up a page's layout. If it does disable it. mmmturkeybacon Unclick Radio Button is a helpful companion to this script.

当前为 2015-03-22 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name mmmturkeybacon Embiggen Radio Buttons and Checkboxes
  3. // @author mmmturkeybacon
  4. // @description Adds a colored label around radio buttons and checkboxes that increases the area that registers a click. If the button/box is clicked the label turns green. This script lets you more effectively click while requiring less precision and makes it easier to see which items are selected. I can't guarantee this script won't foul up a page's layout. If it does disable it. mmmturkeybacon Unclick Radio Button is a helpful companion to this script.
  5. // @namespace http://userscripts.org/users/523367
  6. // @match http://*/*
  7. // @match https://*/*
  8. // //@match https://*.mturk.com/mturk/preview*
  9. // //@match https://*.mturk.com/mturk/accept*
  10. // //@match https://*.mturk.com/mturk/continue*
  11. // //@match https://*.mturk.com/mturk/submit*
  12. // //@match https://*.mturk.com/mturk/return*
  13. // //@match https://*.mturkcontent.com/dynamic/hit?*
  14. // //@match https://*.amazonaws.com/mturk_bulk/hits*
  15. // //@match https://*.crowdcomputingsystems.com/mturk-web/*
  16. // //@match https://*.qualtrics.com/*
  17. // //@match https://*.surveygizmo.com/*
  18. // //@match https://*.surveymonkey.com/*
  19. // @require https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js
  20. // @version 1.00
  21. // @grant GM_addStyle
  22. // ==/UserScript==
  23.  
  24. /*
  25. Examples:
  26. http://i.imgur.com/6AK6fqq.png
  27. http://i.imgur.com/ZmKaA1o.png
  28.  
  29. For testing and debugging:
  30. https://www.surveymonkey.com/s/ProfessionalProcesses
  31. https://www.surveygizmo.com/s3/2046887/73e44deab261
  32. https://msuccas.co1.qualtrics.com/SE/?SID=SV_0ilMmQXcdpZQ04d
  33. https://princetonsurvey.az1.qualtrics.com/SE/?SID=SV_8jDoy6P7ibFZN0p
  34. https://www.mturkcontent.com/dynamic/hit?assignmentId=ASSIGNMENT_ID_NOT_AVAILABLE&hitId=3DIIW4IV8PEUCG2TZJS01EOATJII4F
  35. https://s3.amazonaws.com/mturk_bulk/hits/138816851/qUqSeewj13pzxUGTsERnXg.html?assignmentId=ASSIGNMENT_ID_NOT_AVAILABLE&hitId=39KMGHJ4RY9B0N33T566YLUDOYX006
  36. https://s3.amazonaws.com/mturk_bulk/hits/138909729/mndG5I_WE1o9e66s6lB8ZA.html?assignmentId=ASSIGNMENT_ID_NOT_AVAILABLE&hitId=3DGDV62G7OEP3AI3W6SRGMH1P9TP2S
  37. */
  38.  
  39. var SIZE = 54; // pixels
  40.  
  41. var TOP_SPACING = (1/2)*SIZE + 1;
  42. var RIGHT_SPACING = (2/10)*SIZE;
  43. var BOTTOM_SPACING = (1/2)*SIZE + 1;
  44. var LEFT_SPACING = (4/10)*SIZE;
  45.  
  46. var UNCHECKED_COLOR = '#00f';
  47. var CHECKED_COLOR = '#0f0';
  48. var DISABLED_COLOR = '#999';
  49. var OPACITY = 0.25;
  50.  
  51. var $radio_buttons;
  52. var $checkboxes;
  53.  
  54. function place_radio_button(i)
  55. {
  56. if (i < $radio_buttons.length)
  57. {
  58. var $radio_button = $radio_buttons.eq(i);
  59. var offset = {};
  60. var center_offset = {};
  61.  
  62. var id = $radio_button.attr('id');
  63. if (id == null)
  64. {
  65. id = 'mtb_big_radio_button_id' + i;
  66. $radio_button.attr('id', id);
  67. }
  68.  
  69. $radio_button.css('display', 'visible');
  70.  
  71. var container_height = $radio_button.outerHeight(true);
  72. var container_width = $radio_button.outerWidth(true);
  73. var TOP_MARGIN = TOP_SPACING - container_height/2;
  74. var RIGHT_MARGIN = RIGHT_SPACING - container_width/2;
  75. var BOTTOM_MARGIN = BOTTOM_SPACING - container_height/2;
  76. var LEFT_MARGIN = LEFT_SPACING - container_width/2;
  77. //var MARGIN = TOP_MARGIN+'px '+RIGHT_MARGIN+' px'+BOTTOM_MARGIN+' px'+LEFT_MARGIN+' px';
  78.  
  79. $radio_button.wrap('<div style="display: inline-block; height: '+container_height+'px; width: '+container_width+'px; margin: '+TOP_MARGIN+'px '+RIGHT_MARGIN+'px '+BOTTOM_MARGIN+'px '+LEFT_MARGIN+'px ">');
  80. var $this_container = $radio_button.parent();
  81. $this_container.append('<div id="mtb_div_for_'+id+'"><label for="'+id+'" id="mtb_label_for_'+id+'"></label></div>');
  82.  
  83. var $this_div = $('div[id="mtb_div_for_'+id+'"]');
  84. var $this_label = $('label[id="mtb_label_for_'+id+'"]');
  85.  
  86. var label_abs_top = -SIZE/2+'px';
  87. var label_abs_left = -SIZE/2+'px';
  88.  
  89. $this_label.css({"position": "absolute", "top": label_abs_top, "left": label_abs_left});
  90.  
  91. if (document.domain.indexOf('surveymonkey') > -1)
  92. {
  93. var $next_label = $radio_button.parent().parent('.qOption').children('label');
  94. if ($next_label.length > 0)
  95. {
  96. $next_label.css('display', 'inline');
  97. $next_label.find('img').css('visibility', 'hidden');
  98. }
  99. }
  100. else if (document.domain.indexOf('surveygizmo') > -1)
  101. {
  102. $radio_button.css('position', 'static');
  103. }
  104.  
  105. offset = $radio_button.offset();
  106. center_offset.top = offset.top + $radio_button.height()/2;
  107. center_offset.left = offset.left + $radio_button.width()/2;
  108. $this_div.offset(center_offset);
  109.  
  110. // Don't hide the radio buttons so that the Tab key can still be used to navigate to between them.
  111. //$radio_button.css('visibility', 'hidden');
  112.  
  113. (function(j){setTimeout(function(){place_radio_button(j)}, 10) })(i+1);
  114. }
  115. }
  116.  
  117. function place_checkbox(i)
  118. {
  119. if (i < $checkboxes.length)
  120. {
  121. var $checkbox = $checkboxes.eq(i);
  122. var offset = {};
  123. var center_offset = {};
  124.  
  125. var id = $checkbox.attr('id');
  126. if (id == null)
  127. {
  128. id = 'mtb_big_checkbox_id' + i;
  129. $checkbox.attr('id', id);
  130. }
  131.  
  132. $checkbox.css('display', 'visible');
  133.  
  134. var container_height = $checkbox.outerHeight(true);
  135. var container_width = $checkbox.outerWidth(true);
  136. var TOP_MARGIN = TOP_SPACING - container_height/2;
  137. var RIGHT_MARGIN = RIGHT_SPACING - container_width/2;
  138. var BOTTOM_MARGIN = BOTTOM_SPACING - container_height/2;
  139. var LEFT_MARGIN = LEFT_SPACING - container_width/2;
  140. //var MARGIN = TOP_MARGIN+'px '+RIGHT_MARGIN+' px'+BOTTOM_MARGIN+' px'+LEFT_MARGIN+' px';
  141.  
  142. $checkbox.wrap('<div style="display: inline-block; height: '+container_height+'px; width: '+container_width+'px; margin: '+TOP_MARGIN+'px '+RIGHT_MARGIN+'px '+BOTTOM_MARGIN+'px '+LEFT_MARGIN+'px ">');
  143. var $this_container = $checkbox.parent();
  144. $this_container.append('<div id="mtb_div_for_'+id+'"><label for="'+id+'" id="mtb_label_for_'+id+'"></label></div>');
  145.  
  146. var $this_div = $('div[id="mtb_div_for_'+id+'"]');
  147. var $this_label = $('label[id="mtb_label_for_'+id+'"]');
  148.  
  149. var label_abs_top = -SIZE/2+'px';
  150. var label_abs_left = -SIZE/2+'px';
  151.  
  152. $this_label.css({"position": "absolute", "top": label_abs_top, "left": label_abs_left});
  153.  
  154. if (document.domain.indexOf('surveymonkey') > -1)
  155. {
  156. var $next_label = $checkbox.parent().parent('.qOption').children('label');
  157. if ($next_label.length > 0)
  158. {
  159. $next_label.css('display', 'inline');
  160. $next_label.find('img').css('visibility', 'hidden');
  161. }
  162. }
  163. else if (document.domain.indexOf('surveygizmo') > -1)
  164. {
  165. $checkbox.css('position', 'static');
  166. }
  167.  
  168. offset = $checkbox.offset();
  169. center_offset.top = offset.top + $checkbox.height()/2;
  170. center_offset.left = offset.left + $checkbox.width()/2;
  171. $this_div.offset(center_offset);
  172.  
  173. // Don't hide the checkboxes so that the Tab key can still be used to navigate to between them.
  174. //$checkbox.css('visibility', 'hidden');
  175.  
  176. (function(j){setTimeout(function(){place_checkbox(j)}, 10) })(i+1);
  177. }
  178. }
  179.  
  180. function embiggen()
  181. {
  182. var selector_prefix = ($('div[id="hit-wrapper"]').length > 0) ? 'div[id="hit-wrapper"] ' : '';
  183. if (selector_prefix || document.domain != 'www.mturk.com')
  184. { // if selector_prefix is non-empty then it is an internal HIT
  185.  
  186. $radio_buttons = $(selector_prefix+'input[type="radio"]');
  187. $checkboxes = $(selector_prefix+'input[type="checkbox"]');
  188. if ($radio_buttons.length > 0 || $checkboxes.length > 0)
  189. {
  190. GM_addStyle(' \
  191. @font-face { \
  192. font-family: "icomoon"; \
  193. src: url(data:application/x-font-ttf;charset=utf-8;base64,AAEAAAALAIAAAwAwT1MvMg8SB4AAAAC8AAAAYGNtYXDqkerYAAABHAAAAFRnYXNwAAAAEAAAAXAAAAAIZ2x5ZkY5wa4AAAF4AAAB9GhlYWQFf52VAAADbAAAADZoaGVhB8IDyQAAA6QAAAAkaG10eBIAAAAAAAPIAAAAIGxvY2EBkgEcAAAD6AAAABJtYXhwAAwAOQAAA/wAAAAgbmFtZVcZpu4AAAQcAAABRXBvc3QAAwAAAAAFZAAAACAAAwQAAZAABQAAApkCzAAAAI8CmQLMAAAB6wAzAQkAAAAAAAAAAAAAAAAAAAABEAAAAAAAAAAAAAAAAAAAAABAAADqVgPA/8AAQAPAAEAAAAABAAAAAAAAAAAAAAAgAAAAAAACAAAAAwAAABQAAwABAAAAFAAEAEAAAAAMAAgAAgAEAAEAIOpU6lb//f//AAAAAAAg6lLqVv/9//8AAf/jFbIVsQADAAEAAAAAAAAAAAAAAAAAAQAB//8ADwABAAAAAAAAAAAAAgAANzkBAAAAAAEAAAAAAAAAAAACAAA3OQEAAAAAAQAAAAAAAAAAAAIAADc5AQAAAAACAAD/wAQAA8AAEAAXAAABISIGFREUFjMhMjY1ETQmIwEnNxcBFwEDgP0ANUtLNQMANUtLNf5A7VqTATNa/nMDwEs1/QA1S0s1AwA1S/zl7lqSATJa/nIAAgAA/8AEAAPAABAAFQAAASEiBhURFBYzITI2NRE0JiMRIREhEQOA/QA1S0s1AwA1S0s1/QADAAPASzX9ADVLSzUDADVL/IADAP0AAAMAAP/ABAADwAAUACkANgAAASIOAhUUHgIzMj4CNTQuAiMRIi4CNTQ+AjMyHgIVFA4CIwM0NjMyFhUUBiMiJjUCAGq7i1BQi7tqaruLUFCLu2pQi2k8PGmLUFCLaTw8aYtQwHBQUHBwUFBwA8BQi7tqaruLUFCLu2pqu4tQ/IA8aYtQUItpPDxpi1BQi2k8AYBQcHBQUHBwUAAAAAIAAP/ABAADwAAUACkAAAEiDgIVFB4CMzI+AjU0LgIjESIuAjU0PgIzMh4CFRQOAiMCAGq7i1BQi7tqaruLUFCLu2pQi2k8PGmLUFCLaTw8aYtQA8BQi7tqaruLUFCLu2pqu4tQ/IA8aYtQUItpPDxpi1BQi2k8AAEAAAABAADOghiAXw889QALBAAAAAAA0TAsjAAAAADRMCyMAAD/wAQAA8AAAAAIAAIAAAAAAAAAAQAAA8D/wAAABAAAAAAABAAAAQAAAAAAAAAAAAAAAAAAAAgAAAAAAAAAAAAAAAACAAAABAAAAAQAAAAEAAAABAAAAAAAAAAACgAUAB4ASgBwAL4A+gAAAAEAAAAIADcAAwAAAAAAAgAAAAAAAAAAAAAAAAAAAAAAAAAOAK4AAQAAAAAAAQAOAAAAAQAAAAAAAgAOAEcAAQAAAAAAAwAOACQAAQAAAAAABAAOAFUAAQAAAAAABQAWAA4AAQAAAAAABgAHADIAAQAAAAAACgA0AGMAAwABBAkAAQAOAAAAAwABBAkAAgAOAEcAAwABBAkAAwAOACQAAwABBAkABAAOAFUAAwABBAkABQAWAA4AAwABBAkABgAOADkAAwABBAkACgA0AGMAaQBjAG8AbQBvAG8AbgBWAGUAcgBzAGkAbwBuACAAMQAuADAAaQBjAG8AbQBvAG8Abmljb21vb24AaQBjAG8AbQBvAG8AbgBSAGUAZwB1AGwAYQByAGkAYwBvAG0AbwBvAG4ARgBvAG4AdAAgAGcAZQBuAGUAcgBhAHQAZQBkACAAYgB5ACAASQBjAG8ATQBvAG8AbgAuAAAAAAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=) format("truetype"), \
  194. url(data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAAAXQAAsAAAAABYQAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABPUy8yAAABCAAAAGAAAABgDxIHgGNtYXAAAAFoAAAAVAAAAFTqkerYZ2FzcAAAAbwAAAAIAAAACAAAABBnbHlmAAABxAAAAfQAAAH0RjnBrmhlYWQAAAO4AAAANgAAADYFf52VaGhlYQAAA/AAAAAkAAAAJAfCA8lobXR4AAAEFAAAACAAAAAgEgAAAGxvY2EAAAQ0AAAAEgAAABIBkgEcbWF4cAAABEgAAAAgAAAAIAAMADluYW1lAAAEaAAAAUUAAAFFVxmm7nBvc3QAAAWwAAAAIAAAACAAAwAAAAMEAAGQAAUAAAKZAswAAACPApkCzAAAAesAMwEJAAAAAAAAAAAAAAAAAAAAARAAAAAAAAAAAAAAAAAAAAAAQAAA6lYDwP/AAEADwABAAAAAAQAAAAAAAAAAAAAAIAAAAAAAAgAAAAMAAAAUAAMAAQAAABQABABAAAAADAAIAAIABAABACDqVOpW//3//wAAAAAAIOpS6lb//f//AAH/4xWyFbEAAwABAAAAAAAAAAAAAAAAAAEAAf//AA8AAQAAAAAAAAAAAAIAADc5AQAAAAABAAAAAAAAAAAAAgAANzkBAAAAAAEAAAAAAAAAAAACAAA3OQEAAAAAAgAA/8AEAAPAABAAFwAAASEiBhURFBYzITI2NRE0JiMBJzcXARcBA4D9ADVLSzUDADVLSzX+QO1akwEzWv5zA8BLNf0ANUtLNQMANUv85e5akgEyWv5yAAIAAP/ABAADwAAQABUAAAEhIgYVERQWMyEyNjURNCYjESERIREDgP0ANUtLNQMANUtLNf0AAwADwEs1/QA1S0s1AwA1S/yAAwD9AAADAAD/wAQAA8AAFAApADYAAAEiDgIVFB4CMzI+AjU0LgIjESIuAjU0PgIzMh4CFRQOAiMDNDYzMhYVFAYjIiY1AgBqu4tQUIu7amq7i1BQi7tqUItpPDxpi1BQi2k8PGmLUMBwUFBwcFBQcAPAUIu7amq7i1BQi7tqaruLUPyAPGmLUFCLaTw8aYtQUItpPAGAUHBwUFBwcFAAAAACAAD/wAQAA8AAFAApAAABIg4CFRQeAjMyPgI1NC4CIxEiLgI1ND4CMzIeAhUUDgIjAgBqu4tQUIu7amq7i1BQi7tqUItpPDxpi1BQi2k8PGmLUAPAUIu7amq7i1BQi7tqaruLUPyAPGmLUFCLaTw8aYtQUItpPAABAAAAAQAAzoIYgF8PPPUACwQAAAAAANEwLIwAAAAA0TAsjAAA/8AEAAPAAAAACAACAAAAAAAAAAEAAAPA/8AAAAQAAAAAAAQAAAEAAAAAAAAAAAAAAAAAAAAIAAAAAAAAAAAAAAAAAgAAAAQAAAAEAAAABAAAAAQAAAAAAAAAAAoAFAAeAEoAcAC+APoAAAABAAAACAA3AAMAAAAAAAIAAAAAAAAAAAAAAAAAAAAAAAAADgCuAAEAAAAAAAEADgAAAAEAAAAAAAIADgBHAAEAAAAAAAMADgAkAAEAAAAAAAQADgBVAAEAAAAAAAUAFgAOAAEAAAAAAAYABwAyAAEAAAAAAAoANABjAAMAAQQJAAEADgAAAAMAAQQJAAIADgBHAAMAAQQJAAMADgAkAAMAAQQJAAQADgBVAAMAAQQJAAUAFgAOAAMAAQQJAAYADgA5AAMAAQQJAAoANABjAGkAYwBvAG0AbwBvAG4AVgBlAHIAcwBpAG8AbgAgADEALgAwAGkAYwBvAG0AbwBvAG5pY29tb29uAGkAYwBvAG0AbwBvAG4AUgBlAGcAdQBsAGEAcgBpAGMAbwBtAG8AbwBuAEYAbwBuAHQAIABnAGUAbgBlAHIAYQB0AGUAZAAgAGIAeQAgAEkAYwBvAE0AbwBvAG4ALgAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA) format("woff"); \
  195. font-weight: normal; \
  196. font-style: normal; \
  197. } \
  198. input[type=radio], \
  199. input[type=checkbox] { \
  200. display: visible; \
  201. } \
  202. input[type=radio] + div[id^="mtb_div_for_"], \
  203. input[type=checkbox] + div[id^="mtb_div_for_"] { \
  204. /*float: left; !important;*/ \
  205. display: inline-block !important; \
  206. width: 0px !important; \
  207. height: 0px !important; \
  208. z-index: 100 !important; \
  209. } \
  210. input[type=radio] + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"], \
  211. input[type=checkbox] + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"] { \
  212. margin: 0px !important; \
  213. padding: 0px !important; \
  214. z-index: 100 !important; \
  215. } \
  216. input[type=radio] + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before, \
  217. input[type=checkbox] + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before { \
  218. font-family: "icomoon" !important; \
  219. speak: none !important; \
  220. font-style: normal !important; \
  221. font-weight: normal !important; \
  222. font-variant: normal !important; \
  223. font-size: '+SIZE+'px !important; \
  224. text-transform: none !important; \
  225. line-height: 1 !important; \
  226. opacity: '+OPACITY+' !important; \
  227. /* Better Font Rendering =========== */ \
  228. -webkit-font-smoothing: antialiased !important; \
  229. -moz-osx-font-smoothing: grayscale !important; \
  230. } \
  231. input[type=radio]:disabled + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before, \
  232. input[type=checkbox]:disabled + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before { \
  233. color: '+DISABLED_COLOR+'; \
  234. } \
  235. input[type=radio]:focus + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before, \
  236. input[type=checkbox]:focus + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before { \
  237. outline: 1px dotted !important; \
  238. } \
  239. input[type=radio] + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before { \
  240. content: "\\ea56" !important; \
  241. color: '+UNCHECKED_COLOR+'; \
  242. } \
  243. input[type=radio]:checked + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before { \
  244. content: "\\ea54" !important; \
  245. color: '+CHECKED_COLOR+'; \
  246. } \
  247. input[type=checkbox] + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before { \
  248. content: "\\ea53" !important; \
  249. color: '+UNCHECKED_COLOR+'; \
  250. } \
  251. input[type=checkbox]:checked + div[id^="mtb_div_for_"] > label[id^="mtb_label_for_"]::before { \
  252. content: "\\ea52" !important; \
  253. color: '+CHECKED_COLOR+'; \
  254. } \
  255. ');
  256.  
  257. place_radio_button(0);
  258. place_checkbox(0);
  259. }
  260. }
  261. }
  262.  
  263. //$(document).ready(function()
  264. $(window).load(function()
  265. {
  266. if (document.domain.indexOf('qualtrics.com') == -1)
  267. {
  268. embiggen();
  269. }
  270. else
  271. {
  272. var already_ran = false;
  273. if ($('div:contains("Survey Powered By") a[href="http://www.qualtrics.com"]:contains("Qualtrics")').length > 0 && already_ran == false)
  274. {
  275. already_ran = true;
  276. embiggen();
  277. }
  278. else
  279. {
  280. $(document).bind('DOMNodeInserted',function()
  281. {
  282. if ($('div:contains("Survey Powered By") a[href="http://www.qualtrics.com"]:contains("Qualtrics")').length > 0 && already_ran == false)
  283. {
  284. already_ran = true;
  285. embiggen();
  286. }
  287. })
  288. }
  289. }
  290. });
  291.