jspsych 6.2.0 → 7.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (360) hide show
  1. package/README.md +43 -29
  2. package/css/jspsych.css +39 -39
  3. package/dist/JsPsych.d.ts +112 -0
  4. package/dist/TimelineNode.d.ts +34 -0
  5. package/dist/index.browser.js +3164 -0
  6. package/dist/index.browser.js.map +1 -0
  7. package/dist/index.browser.min.js +2 -0
  8. package/dist/index.browser.min.js.map +1 -0
  9. package/dist/index.cjs +3158 -0
  10. package/dist/index.cjs.map +1 -0
  11. package/dist/index.d.ts +11 -0
  12. package/dist/index.js +3152 -0
  13. package/dist/index.js.map +1 -0
  14. package/dist/migration.d.ts +3 -0
  15. package/dist/modules/data/DataCollection.d.ts +45 -0
  16. package/dist/modules/data/DataColumn.d.ts +15 -0
  17. package/dist/modules/data/index.d.ts +25 -0
  18. package/dist/modules/data/utils.d.ts +3 -0
  19. package/dist/modules/extensions.d.ts +22 -0
  20. package/dist/modules/plugin-api/HardwareAPI.d.ts +15 -0
  21. package/dist/modules/plugin-api/KeyboardListenerAPI.d.ts +34 -0
  22. package/dist/modules/plugin-api/MediaAPI.d.ts +27 -0
  23. package/dist/modules/plugin-api/SimulationAPI.d.ts +41 -0
  24. package/dist/modules/plugin-api/TimeoutAPI.d.ts +5 -0
  25. package/dist/modules/plugin-api/index.d.ts +8 -0
  26. package/dist/modules/plugins.d.ts +129 -0
  27. package/dist/modules/randomization.d.ts +35 -0
  28. package/dist/modules/turk.d.ts +40 -0
  29. package/dist/modules/utils.d.ts +7 -0
  30. package/package.json +32 -15
  31. package/src/JsPsych.ts +884 -0
  32. package/src/TimelineNode.ts +536 -0
  33. package/src/index.ts +71 -0
  34. package/src/migration.ts +37 -0
  35. package/src/modules/data/DataCollection.ts +198 -0
  36. package/src/modules/data/DataColumn.ts +86 -0
  37. package/src/modules/data/index.ts +174 -0
  38. package/src/modules/data/utils.ts +75 -0
  39. package/src/modules/extensions.ts +23 -0
  40. package/src/modules/plugin-api/HardwareAPI.ts +32 -0
  41. package/src/modules/plugin-api/KeyboardListenerAPI.ts +165 -0
  42. package/src/modules/plugin-api/MediaAPI.ts +337 -0
  43. package/src/modules/plugin-api/SimulationAPI.ts +181 -0
  44. package/src/modules/plugin-api/TimeoutAPI.ts +16 -0
  45. package/src/modules/plugin-api/index.ts +28 -0
  46. package/src/modules/plugins.ts +158 -0
  47. package/src/modules/randomization.ts +327 -0
  48. package/src/modules/turk.ts +99 -0
  49. package/src/modules/utils.ts +30 -0
  50. package/.github/workflows/jest.yml +0 -20
  51. package/code-of-conduct.md +0 -56
  52. package/contributors.md +0 -61
  53. package/docs/CNAME +0 -1
  54. package/docs/about/about.md +0 -18
  55. package/docs/about/contributing.md +0 -43
  56. package/docs/about/license.md +0 -25
  57. package/docs/about/support.md +0 -7
  58. package/docs/core_library/jspsych-core.md +0 -661
  59. package/docs/core_library/jspsych-data.md +0 -589
  60. package/docs/core_library/jspsych-pluginAPI.md +0 -510
  61. package/docs/core_library/jspsych-randomization.md +0 -397
  62. package/docs/core_library/jspsych-turk.md +0 -102
  63. package/docs/img/blue.png +0 -0
  64. package/docs/img/folder-setup.png +0 -0
  65. package/docs/img/folder-with-html.png +0 -0
  66. package/docs/img/githubreleases.jpg +0 -0
  67. package/docs/img/jspsych-favicon.png +0 -0
  68. package/docs/img/jspsych-logo-no-text-mono.svg +0 -493
  69. package/docs/img/jspsych-logo.jpg +0 -0
  70. package/docs/img/orange.png +0 -0
  71. package/docs/img/palmer_stim.png +0 -0
  72. package/docs/img/progress_bar.png +0 -0
  73. package/docs/img/visual_search_example.jpg +0 -0
  74. package/docs/index.md +0 -9
  75. package/docs/overview/browser-device-support.md +0 -35
  76. package/docs/overview/callbacks.md +0 -140
  77. package/docs/overview/data.md +0 -281
  78. package/docs/overview/exclude-browser.md +0 -32
  79. package/docs/overview/experiment-options.md +0 -121
  80. package/docs/overview/fullscreen.md +0 -36
  81. package/docs/overview/media-preloading.md +0 -91
  82. package/docs/overview/mturk.md +0 -77
  83. package/docs/overview/progress-bar.md +0 -110
  84. package/docs/overview/record-browser-interactions.md +0 -23
  85. package/docs/overview/running-experiments.md +0 -95
  86. package/docs/overview/timeline.md +0 -387
  87. package/docs/overview/trial.md +0 -142
  88. package/docs/plugins/creating-a-plugin.md +0 -79
  89. package/docs/plugins/jspsych-animation.md +0 -40
  90. package/docs/plugins/jspsych-audio-button-response.md +0 -60
  91. package/docs/plugins/jspsych-audio-keyboard-response.md +0 -58
  92. package/docs/plugins/jspsych-audio-slider-response.md +0 -53
  93. package/docs/plugins/jspsych-call-function.md +0 -81
  94. package/docs/plugins/jspsych-canvas-button-response.md +0 -66
  95. package/docs/plugins/jspsych-canvas-keyboard-response.md +0 -68
  96. package/docs/plugins/jspsych-canvas-slider-response.md +0 -89
  97. package/docs/plugins/jspsych-categorize-animation.md +0 -60
  98. package/docs/plugins/jspsych-categorize-html.md +0 -52
  99. package/docs/plugins/jspsych-categorize-image.md +0 -53
  100. package/docs/plugins/jspsych-cloze.md +0 -45
  101. package/docs/plugins/jspsych-external-html.md +0 -70
  102. package/docs/plugins/jspsych-free-sort.md +0 -55
  103. package/docs/plugins/jspsych-fullscreen.md +0 -57
  104. package/docs/plugins/jspsych-html-button-response.md +0 -42
  105. package/docs/plugins/jspsych-html-keyboard-response.md +0 -51
  106. package/docs/plugins/jspsych-html-slider-response.md +0 -45
  107. package/docs/plugins/jspsych-iat-html.md +0 -64
  108. package/docs/plugins/jspsych-iat-image.md +0 -64
  109. package/docs/plugins/jspsych-image-button-response.md +0 -46
  110. package/docs/plugins/jspsych-image-keyboard-response.md +0 -57
  111. package/docs/plugins/jspsych-image-slider-response.md +0 -52
  112. package/docs/plugins/jspsych-instructions.md +0 -58
  113. package/docs/plugins/jspsych-maxdiff.md +0 -42
  114. package/docs/plugins/jspsych-rdk.md +0 -119
  115. package/docs/plugins/jspsych-reconstruction.md +0 -48
  116. package/docs/plugins/jspsych-resize.md +0 -39
  117. package/docs/plugins/jspsych-same-different-html.md +0 -53
  118. package/docs/plugins/jspsych-same-different-image.md +0 -66
  119. package/docs/plugins/jspsych-serial-reaction-time-mouse.md +0 -50
  120. package/docs/plugins/jspsych-serial-reaction-time.md +0 -57
  121. package/docs/plugins/jspsych-survey-html-form.md +0 -50
  122. package/docs/plugins/jspsych-survey-likert.md +0 -70
  123. package/docs/plugins/jspsych-survey-multi-choice.md +0 -48
  124. package/docs/plugins/jspsych-survey-multi-select.md +0 -53
  125. package/docs/plugins/jspsych-survey-text.md +0 -63
  126. package/docs/plugins/jspsych-video-button-response.md +0 -52
  127. package/docs/plugins/jspsych-video-keyboard-response.md +0 -48
  128. package/docs/plugins/jspsych-video-slider-response.md +0 -58
  129. package/docs/plugins/jspsych-visual-search-circle.md +0 -52
  130. package/docs/plugins/jspsych-vsl-animate-occlusion.md +0 -55
  131. package/docs/plugins/jspsych-vsl-grid-scene.md +0 -62
  132. package/docs/plugins/overview.md +0 -111
  133. package/docs/tutorials/hello-world.md +0 -144
  134. package/docs/tutorials/rt-task.md +0 -1107
  135. package/examples/add-to-end-of-timeline.html +0 -32
  136. package/examples/conditional-and-loop-functions.html +0 -63
  137. package/examples/css/jquery-ui.css +0 -1225
  138. package/examples/data-add-properties.html +0 -40
  139. package/examples/data-as-function.html +0 -36
  140. package/examples/data-from-timeline.html +0 -45
  141. package/examples/data-from-url.html +0 -21
  142. package/examples/demo-flanker.html +0 -108
  143. package/examples/demo-simple-rt-task.html +0 -104
  144. package/examples/demos/demo_1.html +0 -29
  145. package/examples/demos/demo_2.html +0 -43
  146. package/examples/demos/demo_3.html +0 -58
  147. package/examples/display-element-to-embed-experiment.html +0 -73
  148. package/examples/end-active-node.html +0 -52
  149. package/examples/end-experiment.html +0 -43
  150. package/examples/exclusions.html +0 -32
  151. package/examples/external_html/simple_consent.html +0 -4
  152. package/examples/img/1.gif +0 -0
  153. package/examples/img/10.gif +0 -0
  154. package/examples/img/11.gif +0 -0
  155. package/examples/img/12.gif +0 -0
  156. package/examples/img/2.gif +0 -0
  157. package/examples/img/3.gif +0 -0
  158. package/examples/img/4.gif +0 -0
  159. package/examples/img/5.gif +0 -0
  160. package/examples/img/6.gif +0 -0
  161. package/examples/img/7.gif +0 -0
  162. package/examples/img/8.gif +0 -0
  163. package/examples/img/9.gif +0 -0
  164. package/examples/img/age/of1.jpg +0 -0
  165. package/examples/img/age/of2.jpg +0 -0
  166. package/examples/img/age/of3.jpg +0 -0
  167. package/examples/img/age/om1.jpg +0 -0
  168. package/examples/img/age/om2.jpg +0 -0
  169. package/examples/img/age/om3.jpg +0 -0
  170. package/examples/img/age/yf1.jpg +0 -0
  171. package/examples/img/age/yf4.jpg +0 -0
  172. package/examples/img/age/yf5.jpg +0 -0
  173. package/examples/img/age/ym2.jpg +0 -0
  174. package/examples/img/age/ym3.jpg +0 -0
  175. package/examples/img/age/ym5.jpg +0 -0
  176. package/examples/img/backwardN.gif +0 -0
  177. package/examples/img/blue.png +0 -0
  178. package/examples/img/con1.png +0 -0
  179. package/examples/img/con2.png +0 -0
  180. package/examples/img/fixation.gif +0 -0
  181. package/examples/img/happy_face_1.jpg +0 -0
  182. package/examples/img/happy_face_2.jpg +0 -0
  183. package/examples/img/happy_face_3.jpg +0 -0
  184. package/examples/img/happy_face_4.jpg +0 -0
  185. package/examples/img/inc1.png +0 -0
  186. package/examples/img/inc2.png +0 -0
  187. package/examples/img/normalN.gif +0 -0
  188. package/examples/img/orange.png +0 -0
  189. package/examples/img/redX.png +0 -0
  190. package/examples/img/ribbon.jpg +0 -0
  191. package/examples/img/sad_face_1.jpg +0 -0
  192. package/examples/img/sad_face_2.jpg +0 -0
  193. package/examples/img/sad_face_3.jpg +0 -0
  194. package/examples/img/sad_face_4.jpg +0 -0
  195. package/examples/js/snap.svg-min.js +0 -21
  196. package/examples/jspsych-RDK.html +0 -58
  197. package/examples/jspsych-animation.html +0 -33
  198. package/examples/jspsych-audio-button-response.html +0 -52
  199. package/examples/jspsych-audio-keyboard-response.html +0 -62
  200. package/examples/jspsych-audio-slider-response.html +0 -55
  201. package/examples/jspsych-call-function.html +0 -32
  202. package/examples/jspsych-canvas-button-response.html +0 -95
  203. package/examples/jspsych-canvas-keyboard-response.html +0 -78
  204. package/examples/jspsych-canvas-slider-response.html +0 -67
  205. package/examples/jspsych-categorize-animation.html +0 -46
  206. package/examples/jspsych-categorize-html.html +0 -38
  207. package/examples/jspsych-categorize-image.html +0 -38
  208. package/examples/jspsych-cloze.html +0 -42
  209. package/examples/jspsych-free-sort.html +0 -97
  210. package/examples/jspsych-fullscreen.html +0 -44
  211. package/examples/jspsych-html-button-response.html +0 -46
  212. package/examples/jspsych-html-keyboard-response.html +0 -42
  213. package/examples/jspsych-html-slider-response.html +0 -53
  214. package/examples/jspsych-iat.html +0 -510
  215. package/examples/jspsych-image-button-response.html +0 -84
  216. package/examples/jspsych-image-keyboard-response.html +0 -78
  217. package/examples/jspsych-image-slider-response.html +0 -76
  218. package/examples/jspsych-instructions.html +0 -37
  219. package/examples/jspsych-maxdiff.html +0 -33
  220. package/examples/jspsych-reconstruction.html +0 -43
  221. package/examples/jspsych-resize.html +0 -34
  222. package/examples/jspsych-same-different-html.html +0 -28
  223. package/examples/jspsych-same-different-image.html +0 -33
  224. package/examples/jspsych-serial-reaction-time-mouse.html +0 -98
  225. package/examples/jspsych-serial-reaction-time.html +0 -54
  226. package/examples/jspsych-survey-html-form.html +0 -33
  227. package/examples/jspsych-survey-likert.html +0 -42
  228. package/examples/jspsych-survey-multi-choice.html +0 -40
  229. package/examples/jspsych-survey-multi-select.html +0 -42
  230. package/examples/jspsych-survey-text.html +0 -34
  231. package/examples/jspsych-video-button-response.html +0 -57
  232. package/examples/jspsych-video-keyboard-response.html +0 -53
  233. package/examples/jspsych-video-slider-response.html +0 -55
  234. package/examples/jspsych-visual-search-circle.html +0 -58
  235. package/examples/jspsych-vsl-animate-occlusion.html +0 -29
  236. package/examples/jspsych-vsl-grid-scene.html +0 -41
  237. package/examples/lexical-decision.html +0 -132
  238. package/examples/manual-preloading.html +0 -53
  239. package/examples/pause-unpause.html +0 -33
  240. package/examples/progress-bar.html +0 -62
  241. package/examples/sound/hammer.mp3 +0 -0
  242. package/examples/sound/sound.mp3 +0 -0
  243. package/examples/sound/speech_blue.mp3 +0 -0
  244. package/examples/sound/speech_green.mp3 +0 -0
  245. package/examples/sound/speech_joke.mp3 +0 -0
  246. package/examples/sound/speech_red.mp3 +0 -0
  247. package/examples/sound/tone.mp3 +0 -0
  248. package/examples/timeline-variables-sampling.html +0 -50
  249. package/examples/timeline-variables.html +0 -55
  250. package/examples/video/sample_video.mp4 +0 -0
  251. package/jspsych.js +0 -2796
  252. package/license.txt +0 -21
  253. package/mkdocs.yml +0 -104
  254. package/plugins/jspsych-animation.js +0 -189
  255. package/plugins/jspsych-audio-button-response.js +0 -247
  256. package/plugins/jspsych-audio-keyboard-response.js +0 -204
  257. package/plugins/jspsych-audio-slider-response.js +0 -262
  258. package/plugins/jspsych-call-function.js +0 -58
  259. package/plugins/jspsych-canvas-button-response.js +0 -199
  260. package/plugins/jspsych-canvas-keyboard-response.js +0 -155
  261. package/plugins/jspsych-canvas-slider-response.js +0 -207
  262. package/plugins/jspsych-categorize-animation.js +0 -266
  263. package/plugins/jspsych-categorize-html.js +0 -220
  264. package/plugins/jspsych-categorize-image.js +0 -222
  265. package/plugins/jspsych-cloze.js +0 -112
  266. package/plugins/jspsych-external-html.js +0 -112
  267. package/plugins/jspsych-free-sort.js +0 -444
  268. package/plugins/jspsych-fullscreen.js +0 -104
  269. package/plugins/jspsych-html-button-response.js +0 -188
  270. package/plugins/jspsych-html-keyboard-response.js +0 -149
  271. package/plugins/jspsych-html-slider-response.js +0 -202
  272. package/plugins/jspsych-iat-html.js +0 -284
  273. package/plugins/jspsych-iat-image.js +0 -286
  274. package/plugins/jspsych-image-button-response.js +0 -311
  275. package/plugins/jspsych-image-keyboard-response.js +0 -247
  276. package/plugins/jspsych-image-slider-response.js +0 -353
  277. package/plugins/jspsych-instructions.js +0 -237
  278. package/plugins/jspsych-maxdiff.js +0 -174
  279. package/plugins/jspsych-rdk.js +0 -1373
  280. package/plugins/jspsych-reconstruction.js +0 -134
  281. package/plugins/jspsych-resize.js +0 -166
  282. package/plugins/jspsych-same-different-html.js +0 -168
  283. package/plugins/jspsych-same-different-image.js +0 -169
  284. package/plugins/jspsych-serial-reaction-time-mouse.js +0 -213
  285. package/plugins/jspsych-serial-reaction-time.js +0 -247
  286. package/plugins/jspsych-survey-html-form.js +0 -171
  287. package/plugins/jspsych-survey-likert.js +0 -195
  288. package/plugins/jspsych-survey-multi-choice.js +0 -208
  289. package/plugins/jspsych-survey-multi-select.js +0 -232
  290. package/plugins/jspsych-survey-text.js +0 -185
  291. package/plugins/jspsych-video-button-response.js +0 -320
  292. package/plugins/jspsych-video-keyboard-response.js +0 -279
  293. package/plugins/jspsych-video-slider-response.js +0 -351
  294. package/plugins/jspsych-visual-search-circle.js +0 -259
  295. package/plugins/jspsych-vsl-animate-occlusion.js +0 -196
  296. package/plugins/jspsych-vsl-grid-scene.js +0 -103
  297. package/plugins/template/jspsych-plugin-template.js +0 -35
  298. package/tests/README.md +0 -7
  299. package/tests/jsPsych/default-iti.test.js +0 -51
  300. package/tests/jsPsych/default-parameters.test.js +0 -58
  301. package/tests/jsPsych/endexperiment.test.js +0 -49
  302. package/tests/jsPsych/events.test.js +0 -369
  303. package/tests/jsPsych/init.test.js +0 -48
  304. package/tests/jsPsych/loads.test.js +0 -7
  305. package/tests/jsPsych/min-rt.test.js +0 -58
  306. package/tests/jsPsych/progressbar.test.js +0 -202
  307. package/tests/jsPsych/timeline-variables.test.js +0 -254
  308. package/tests/jsPsych/timelines.test.js +0 -498
  309. package/tests/jsPsych.data/datacollection.test.js +0 -116
  310. package/tests/jsPsych.data/datacolumn.test.js +0 -50
  311. package/tests/jsPsych.data/datamodule.test.js +0 -152
  312. package/tests/jsPsych.data/dataparameter.test.js +0 -251
  313. package/tests/jsPsych.data/interactions.test.js +0 -109
  314. package/tests/jsPsych.pluginAPI/pluginapi.test.js +0 -144
  315. package/tests/jsPsych.randomization/randomziation.test.js +0 -27
  316. package/tests/jsPsych.utils/utils.test.js +0 -58
  317. package/tests/media/blue.png +0 -0
  318. package/tests/media/orange.png +0 -0
  319. package/tests/media/sample_video.mp4 +0 -0
  320. package/tests/media/sound.mp3 +0 -0
  321. package/tests/plugins/plugin-animation.test.js +0 -35
  322. package/tests/plugins/plugin-audio-button-response.test.js +0 -15
  323. package/tests/plugins/plugin-audio-keyboard-response.test.js +0 -15
  324. package/tests/plugins/plugin-audio-slider-response.test.js +0 -15
  325. package/tests/plugins/plugin-call-function.test.js +0 -49
  326. package/tests/plugins/plugin-categorize-animation.test.js +0 -274
  327. package/tests/plugins/plugin-categorize-html.test.js +0 -17
  328. package/tests/plugins/plugin-categorize-image.test.js +0 -17
  329. package/tests/plugins/plugin-cloze.test.js +0 -140
  330. package/tests/plugins/plugin-free-sort.test.js +0 -112
  331. package/tests/plugins/plugin-fullscreen.test.js +0 -41
  332. package/tests/plugins/plugin-html-button-response.test.js +0 -161
  333. package/tests/plugins/plugin-html-keyboard-response.test.js +0 -139
  334. package/tests/plugins/plugin-html-slider-response.test.js +0 -155
  335. package/tests/plugins/plugin-iat-html.test.js +0 -328
  336. package/tests/plugins/plugin-iat-image.test.js +0 -308
  337. package/tests/plugins/plugin-image-button-response.test.js +0 -183
  338. package/tests/plugins/plugin-image-keyboard-response.test.js +0 -154
  339. package/tests/plugins/plugin-image-slider-response.test.js +0 -183
  340. package/tests/plugins/plugin-instructions.test.js +0 -66
  341. package/tests/plugins/plugin-maxdiff.test.js +0 -39
  342. package/tests/plugins/plugin-rdk.test.js +0 -17
  343. package/tests/plugins/plugin-reconstruction.test.js +0 -16
  344. package/tests/plugins/plugin-resize.test.js +0 -16
  345. package/tests/plugins/plugin-same-different-html.test.js +0 -17
  346. package/tests/plugins/plugin-same-different-image.test.js +0 -17
  347. package/tests/plugins/plugin-serial-reaction-time-mouse.test.js +0 -42
  348. package/tests/plugins/plugin-serial-reaction-time.test.js +0 -69
  349. package/tests/plugins/plugin-survey-html-form.test.js +0 -44
  350. package/tests/plugins/plugin-survey-likert.test.js +0 -48
  351. package/tests/plugins/plugin-survey-multi-choice.test.js +0 -48
  352. package/tests/plugins/plugin-survey-multi-select.test.js +0 -72
  353. package/tests/plugins/plugin-survey-text.test.js +0 -115
  354. package/tests/plugins/plugin-video-button-response.test.js +0 -35
  355. package/tests/plugins/plugin-video-keyboard-response.test.js +0 -35
  356. package/tests/plugins/plugin-video-slider-response.test.js +0 -34
  357. package/tests/plugins/plugin-visual-search-circle.test.js +0 -16
  358. package/tests/plugins/plugin-vsl-animate-occlusion.test.js +0 -16
  359. package/tests/plugins/plugin-vsl-grid-scene.test.js +0 -16
  360. package/tests/testing-utils.js +0 -13
@@ -1,284 +0,0 @@
1
- /**
2
- * jspsych-iat
3
- * Kristin Diep
4
- *
5
- * plugin for displaying a stimulus and getting a keyboard response
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- **/
10
-
11
-
12
- jsPsych.plugins['iat-html'] = (function() {
13
-
14
- var plugin = {};
15
-
16
- plugin.info = {
17
- name: 'iat-html',
18
- description: '',
19
- parameters: {
20
- stimulus: {
21
- type: jsPsych.plugins.parameterType.HTML_STRING,
22
- pretty_name: 'Stimulus',
23
- default: undefined,
24
- description: 'The HTML string to be displayed.'
25
- },
26
- left_category_key: {
27
- type: jsPsych.plugins.parameterType.HTML_STRING,
28
- pretty_name: 'Left category key',
29
- default: 'E',
30
- description: 'Key press that is associated with the left category label.'
31
- },
32
- right_category_key: {
33
- type: jsPsych.plugins.parameterType.STRING,
34
- pretty_name: 'Right category key',
35
- default: 'I',
36
- description: 'Key press that is associated with the right category label.'
37
- },
38
- left_category_label: {
39
- type: jsPsych.plugins.parameterType.STRING,
40
- pretty_name: 'Left category label',
41
- array: true,
42
- default: ['left'],
43
- description: 'The label that is associated with the stimulus. Aligned to the left side of page.'
44
- },
45
- right_category_label: {
46
- type: jsPsych.plugins.parameterType.STRING,
47
- pretty_name: 'Right category label',
48
- array: true,
49
- default: ['right'],
50
- description: 'The label that is associated with the stimulus. Aligned to the right side of the page.'
51
- },
52
- key_to_move_forward: {
53
- type: jsPsych.plugins.parameterType.KEYCODE,
54
- pretty_name: 'Key to move forward',
55
- array: true,
56
- default: jsPsych.ALL_KEYS,
57
- description: 'The keys that allow the user to advance to the next trial if their key press was incorrect.'
58
- },
59
- display_feedback: {
60
- type: jsPsych.plugins.parameterType.BOOL,
61
- pretty_name: 'Display feedback',
62
- default: false,
63
- description: 'If true, then html when wrong will be displayed when user makes an incorrect key press.'
64
- },
65
- html_when_wrong: {
66
- type: jsPsych.plugins.parameterType.HTML_STRING,
67
- pretty_name: 'HTML when wrong',
68
- default: '<span style="color: red; font-size: 80px">X</span>',
69
- description: 'The image to display when a user presses the wrong key.'
70
- },
71
- bottom_instructions: {
72
- type: jsPsych.plugins.parameterType.HTML_STRING,
73
- pretty_name: 'Bottom instructions',
74
- default: '<p>If you press the wrong key, a red X will appear. Press any key to continue.</p>',
75
- description: 'Instructions shown at the bottom of the page.'
76
- },
77
- force_correct_key_press: {
78
- type: jsPsych.plugins.parameterType.BOOL,
79
- pretty_name: 'Force correct key press',
80
- default: false,
81
- description: 'If true, in order to advance to the next trial after a wrong key press the user will be forced to press the correct key.'
82
- },
83
- stim_key_association: {
84
- type: jsPsych.plugins.parameterType.HTML_STRING,
85
- pretty_name: 'Stimulus key association',
86
- options: ['left', 'right'],
87
- default: 'undefined',
88
- description: 'Stimulus will be associated with eight "left" or "right".'
89
- },
90
- response_ends_trial: {
91
- type: jsPsych.plugins.parameterType.BOOL,
92
- pretty_name: 'Response ends trial',
93
- default: true,
94
- description: 'If true, trial will end when user makes a response.'
95
- },
96
- trial_duration: {
97
- type: jsPsych.plugins.parameterType.INT,
98
- pretty_name: 'Trial duration',
99
- default: null,
100
- description: 'How long to show the trial.'
101
- },
102
- }
103
- }
104
-
105
-
106
- plugin.trial = function(display_element, trial) {
107
-
108
- var html_str = "";
109
-
110
- html_str += "<div style='position: absolute; height: 20%; width: 100%; margin-left: auto; margin-right: auto; top: 42%; left: 0; right: 0'><p id='jspsych-iat-stim'>" + trial.stimulus + "</p></div>";
111
-
112
- html_str += "<div id='trial_left_align' style='position: absolute; top: 18%; left: 20%'>";
113
-
114
- if(trial.left_category_label.length == 1) {
115
- html_str += "<p>Press " + trial.left_category_key + " for:<br> " +
116
- trial.left_category_label[0].bold() + "</p></div>";
117
- } else {
118
- html_str += "<p>Press " + trial.left_category_key + " for:<br> " +
119
- trial.left_category_label[0].bold() + "<br>" + "or<br>" +
120
- trial.left_category_label[1].bold() + "</p></div>";
121
- }
122
-
123
- html_str += "<div id='trial_right_align' style='position: absolute; top: 18%; right: 20%'>";
124
-
125
- if(trial.right_category_label.length == 1) {
126
- html_str += "<p>Press " + trial.right_category_key + " for:<br> " +
127
- trial.right_category_label[0].bold() + '</p></div>';
128
- } else {
129
- html_str += "<p>Press " + trial.right_category_key + " for:<br> " +
130
- trial.right_category_label[0].bold() + "<br>" + "or<br>" +
131
- trial.right_category_label[1].bold() + "</p></div>";
132
- }
133
-
134
- html_str += "<div id='wrongImgID' style='position:relative; top: 300px; margin-left: auto; margin-right: auto; left: 0; right: 0'>";
135
-
136
- if(trial.display_feedback === true) {
137
- html_str += "<div id='wrongImgContainer' style='visibility: hidden; position: absolute; top: -75px; margin-left: auto; margin-right: auto; left: 0; right: 0'><p>"+trial.html_when_wrong+"</p></div>";
138
- html_str += "<div>"+trial.bottom_instructions+"</div>";
139
- } else {
140
- html_str += "<div>"+trial.bottom_instructions+"</div>";
141
- }
142
-
143
- html_str += "</div>";
144
-
145
- display_element.innerHTML = html_str;
146
-
147
-
148
- // store response
149
- var response = {
150
- rt: null,
151
- key: null,
152
- correct: false
153
- };
154
-
155
- // function to end trial when it is time
156
- var end_trial = function() {
157
-
158
- // kill any remaining setTimeout handlers
159
- jsPsych.pluginAPI.clearAllTimeouts();
160
-
161
- // kill keyboard listeners
162
- if (typeof keyboardListener !== 'undefined') {
163
- jsPsych.pluginAPI.cancelKeyboardResponse(keyboardListener);
164
- }
165
-
166
- // gather the data to store for the trial
167
- var trial_data = {
168
- "rt": response.rt,
169
- "stimulus": trial.stimulus,
170
- "key_press": response.key,
171
- "correct": response.correct
172
- };
173
-
174
- // clears the display
175
- display_element.innerHTML = '';
176
-
177
- // move on to the next trial
178
- jsPsych.finishTrial(trial_data);
179
- };
180
-
181
- var leftKeyCode = jsPsych.pluginAPI.convertKeyCharacterToKeyCode(trial.left_category_key);
182
- var rightKeyCode = jsPsych.pluginAPI.convertKeyCharacterToKeyCode(trial.right_category_key);
183
-
184
- // function to handle responses by the subject
185
- var after_response = function(info) {
186
- var wImg = document.getElementById("wrongImgContainer");
187
- // after a valid response, the stimulus will have the CSS class 'responded'
188
- // which can be used to provide visual feedback that a response was recorded
189
- display_element.querySelector('#jspsych-iat-stim').className += ' responded';
190
-
191
- // only record the first response
192
- if (response.key == null ) {
193
- response = info;
194
- }
195
-
196
- if(trial.stim_key_association == "right") {
197
- if(response.rt !== null && response.key == rightKeyCode) {
198
- response.correct = true;
199
- if (trial.response_ends_trial) {
200
- end_trial();
201
- }
202
- } else {
203
- response.correct = false;
204
- if(!trial.response_ends_trial && trial.display_feedback == true) {
205
- wImg.style.visibility = "visible";
206
- }
207
- if (trial.response_ends_trial && trial.display_feedback == true) {
208
- wImg.style.visibility = "visible";
209
- if(trial.force_correct_key_press) {
210
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
211
- callback_function: end_trial,
212
- valid_responses: [trial.right_category_key]
213
- });
214
- } else {
215
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
216
- callback_function: end_trial,
217
- valid_responses: trial.key_to_move_forward
218
- });}
219
- } else if(trial.response_ends_trial && trial.display_feedback != true) {
220
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
221
- callback_function: end_trial,
222
- valid_responses: [jsPsych.ALL_KEYS]
223
- });
224
- } else if(!trial.response_ends_trial && trial.display_feedback != true) {
225
-
226
- }
227
- }
228
- } else if(trial.stim_key_association == "left") {
229
- if(response.rt !== null && response.key == leftKeyCode) {
230
- response.correct = true;
231
- if (trial.response_ends_trial) {
232
- end_trial();
233
- }
234
- } else {
235
- response.correct = false;
236
- if(!trial.response_ends_trial && trial.display_feedback == true) {
237
- wImg.style.visibility = "visible";
238
- }
239
- if (trial.response_ends_trial && trial.display_feedback == true) {
240
- wImg.style.visibility = "visible";
241
- if(trial.force_correct_key_press) {
242
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
243
- callback_function: end_trial,
244
- valid_responses: [trial.left_category_key]
245
- });
246
- } else {
247
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
248
- callback_function: end_trial,
249
- valid_responses: trial.key_to_move_forward
250
- });}
251
- } else if(trial.response_ends_trial && trial.display_feedback != true) {
252
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
253
- callback_function: end_trial,
254
- valid_responses: [jsPsych.ALL_KEYS]
255
- });
256
- } else if(!trial.response_ends_trial && trial.display_feedback != true) {
257
-
258
- }
259
- }
260
- }
261
- };
262
-
263
- // start the response listener
264
- if (trial.left_category_key != jsPsych.NO_KEYS && trial.right_category_key != jsPsych.NO_KEYS) {
265
- var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
266
- callback_function: after_response,
267
- valid_responses: [trial.left_category_key, trial.right_category_key],
268
- rt_method: 'performance',
269
- persist: false,
270
- allow_held_key: false
271
- });
272
- }
273
-
274
- // end trial if time limit is set
275
- if (trial.trial_duration !== null && trial.response_ends_trial != true) {
276
- jsPsych.pluginAPI.setTimeout(function() {
277
- end_trial();
278
- }, trial.trial_duration);
279
- }
280
-
281
- };
282
-
283
- return plugin;
284
- })();
@@ -1,286 +0,0 @@
1
- /**
2
- * jspsych-iat
3
- * Kristin Diep
4
- *
5
- * plugin for displaying a stimulus and getting a keyboard response
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- **/
10
-
11
-
12
- jsPsych.plugins['iat-image'] = (function() {
13
-
14
- var plugin = {};
15
-
16
- jsPsych.pluginAPI.registerPreload('iat-image', 'stimulus', 'image');
17
-
18
- plugin.info = {
19
- name: 'iat-image',
20
- description: '',
21
- parameters: {
22
- stimulus: {
23
- type: jsPsych.plugins.parameterType.IMAGE,
24
- pretty_name: 'Stimulus',
25
- default: undefined,
26
- description: 'The image to be displayed'
27
- },
28
- left_category_key: {
29
- type: jsPsych.plugins.parameterType.HTML_STRING,
30
- pretty_name: 'Left category key',
31
- default: 'E',
32
- description: 'Key press that is associated with the left category label.'
33
- },
34
- right_category_key: {
35
- type: jsPsych.plugins.parameterType.STRING,
36
- pretty_name: 'Right category key',
37
- default: 'I',
38
- description: 'Key press that is associated with the right category label.'
39
- },
40
- left_category_label: {
41
- type: jsPsych.plugins.parameterType.STRING,
42
- pretty_name: 'Left category label',
43
- array: true,
44
- default: ['left'],
45
- description: 'The label that is associated with the stimulus. Aligned to the left side of page.'
46
- },
47
- right_category_label: {
48
- type: jsPsych.plugins.parameterType.STRING,
49
- pretty_name: 'Right category label',
50
- array: true,
51
- default: ['right'],
52
- description: 'The label that is associated with the stimulus. Aligned to the right side of the page.'
53
- },
54
- key_to_move_forward: {
55
- type: jsPsych.plugins.parameterType.KEYCODE,
56
- pretty_name: 'Key to move forward',
57
- array: true,
58
- default: jsPsych.ALL_KEYS,
59
- description: 'The keys that allow the user to advance to the next trial if their key press was incorrect.'
60
- },
61
- display_feedback: {
62
- type: jsPsych.plugins.parameterType.BOOL,
63
- pretty_name: 'Display feedback',
64
- default: false,
65
- description: 'If true, then html when wrong will be displayed when user makes an incorrect key press.'
66
- },
67
- html_when_wrong: {
68
- type: jsPsych.plugins.parameterType.HTML_STRING,
69
- pretty_name: 'HTML when wrong',
70
- default: '<span style="color: red; font-size: 80px">X</span>',
71
- description: 'The image to display when a user presses the wrong key.'
72
- },
73
- bottom_instructions: {
74
- type: jsPsych.plugins.parameterType.HTML_STRING,
75
- pretty_name: 'Bottom instructions',
76
- default: '<p>If you press the wrong key, a red X will appear. Press any key to continue.</p>',
77
- description: 'Instructions shown at the bottom of the page.'
78
- },
79
- force_correct_key_press: {
80
- type: jsPsych.plugins.parameterType.BOOL,
81
- pretty_name: 'Force correct key press',
82
- default: false,
83
- description: 'If true, in order to advance to the next trial after a wrong key press the user will be forced to press the correct key.'
84
- },
85
- stim_key_association: {
86
- type: jsPsych.plugins.parameterType.HTML_STRING,
87
- pretty_name: 'Stimulus key association',
88
- options: ['left', 'right'],
89
- default: 'undefined',
90
- description: 'Stimulus will be associated with eight "left" or "right".'
91
- },
92
- response_ends_trial: {
93
- type: jsPsych.plugins.parameterType.BOOL,
94
- pretty_name: 'Response ends trial',
95
- default: true,
96
- description: 'If true, trial will end when user makes a response.'
97
- },
98
- trial_duration: {
99
- type: jsPsych.plugins.parameterType.INT,
100
- pretty_name: 'Trial duration',
101
- default: null,
102
- description: 'How long to show the trial.'
103
- },
104
- }
105
- }
106
-
107
-
108
- plugin.trial = function(display_element, trial) {
109
-
110
- var html_str = "";
111
-
112
- html_str += "<div style='position: absolute; height: 20%; width: 100%; margin-left: auto; margin-right: auto; top: 42%; left: 0; right: 0'><img src='"+trial.stimulus+"' id='jspsych-iat-stim'></img></div>";
113
-
114
- html_str += "<div id='trial_left_align' style='position: absolute; top: 18%; left: 20%'>";
115
-
116
- if(trial.left_category_label.length == 1) {
117
- html_str += "<p>Press " + trial.left_category_key + " for:<br> " +
118
- trial.left_category_label[0].bold() + "</p></div>";
119
- } else {
120
- html_str += "<p>Press " + trial.left_category_key + " for:<br> " +
121
- trial.left_category_label[0].bold() + "<br>" + "or<br>" +
122
- trial.left_category_label[1].bold() + "</p></div>";
123
- }
124
-
125
- html_str += "<div id='trial_right_align' style='position: absolute; top: 18%; right: 20%'>";
126
-
127
- if(trial.right_category_label.length == 1) {
128
- html_str += "<p>Press " + trial.right_category_key + " for:<br> " +
129
- trial.right_category_label[0].bold() + '</p></div>';
130
- } else {
131
- html_str += "<p>Press " + trial.right_category_key + " for:<br> " +
132
- trial.right_category_label[0].bold() + "<br>" + "or<br>" +
133
- trial.right_category_label[1].bold() + "</p></div>";
134
- }
135
-
136
- html_str += "<div id='wrongImgID' style='position:relative; top: 300px; margin-left: auto; margin-right: auto; left: 0; right: 0'>";
137
-
138
- if(trial.display_feedback === true) {
139
- html_str += "<div id='wrongImgContainer' style='visibility: hidden; position: absolute; top: -75px; margin-left: auto; margin-right: auto; left: 0; right: 0'><p>"+trial.html_when_wrong+"</p></div>";
140
- html_str += "<div>"+trial.bottom_instructions+"</div>";
141
- } else {
142
- html_str += "<div>"+trial.bottom_instructions+"</div>";
143
- }
144
-
145
- html_str += "</div>";
146
-
147
- display_element.innerHTML = html_str;
148
-
149
-
150
- // store response
151
- var response = {
152
- rt: null,
153
- key: null,
154
- correct: false
155
- };
156
-
157
- // function to end trial when it is time
158
- var end_trial = function() {
159
-
160
- // kill any remaining setTimeout handlers
161
- jsPsych.pluginAPI.clearAllTimeouts();
162
-
163
- // kill keyboard listeners
164
- if (typeof keyboardListener !== 'undefined') {
165
- jsPsych.pluginAPI.cancelKeyboardResponse(keyboardListener);
166
- }
167
-
168
- // gather the data to store for the trial
169
- var trial_data = {
170
- "rt": response.rt,
171
- "stimulus": trial.stimulus,
172
- "key_press": response.key,
173
- "correct": response.correct
174
- };
175
-
176
- // clears the display
177
- display_element.innerHTML = '';
178
-
179
- // move on to the next trial
180
- jsPsych.finishTrial(trial_data);
181
- };
182
-
183
- var leftKeyCode = jsPsych.pluginAPI.convertKeyCharacterToKeyCode(trial.left_category_key);
184
- var rightKeyCode = jsPsych.pluginAPI.convertKeyCharacterToKeyCode(trial.right_category_key);
185
-
186
- // function to handle responses by the subject
187
- var after_response = function(info) {
188
- var wImg = document.getElementById("wrongImgContainer");
189
- // after a valid response, the stimulus will have the CSS class 'responded'
190
- // which can be used to provide visual feedback that a response was recorded
191
- display_element.querySelector('#jspsych-iat-stim').className += ' responded';
192
-
193
- // only record the first response
194
- if (response.key == null ) {
195
- response = info;
196
- }
197
-
198
- if(trial.stim_key_association == "right") {
199
- if(response.rt !== null && response.key == rightKeyCode) {
200
- response.correct = true;
201
- if (trial.response_ends_trial) {
202
- end_trial();
203
- }
204
- } else {
205
- response.correct = false;
206
- if(!trial.response_ends_trial && trial.display_feedback == true) {
207
- wImg.style.visibility = "visible";
208
- }
209
- if (trial.response_ends_trial && trial.display_feedback == true) {
210
- wImg.style.visibility = "visible";
211
- if(trial.force_correct_key_press) {
212
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
213
- callback_function: end_trial,
214
- valid_responses: [trial.right_category_key]
215
- });
216
- } else {
217
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
218
- callback_function: end_trial,
219
- valid_responses: trial.key_to_move_forward
220
- });}
221
- } else if(trial.response_ends_trial && trial.display_feedback != true) {
222
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
223
- callback_function: end_trial,
224
- valid_responses: [jsPsych.ALL_KEYS]
225
- });
226
- } else if(!trial.response_ends_trial && trial.display_feedback != true) {
227
-
228
- }
229
- }
230
- } else if(trial.stim_key_association == "left") {
231
- if(response.rt !== null && response.key == leftKeyCode) {
232
- response.correct = true;
233
- if (trial.response_ends_trial) {
234
- end_trial();
235
- }
236
- } else {
237
- response.correct = false;
238
- if(!trial.response_ends_trial && trial.display_feedback == true) {
239
- wImg.style.visibility = "visible";
240
- }
241
- if (trial.response_ends_trial && trial.display_feedback == true) {
242
- wImg.style.visibility = "visible";
243
- if(trial.force_correct_key_press) {
244
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
245
- callback_function: end_trial,
246
- valid_responses: [trial.left_category_key]
247
- });
248
- } else {
249
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
250
- callback_function: end_trial,
251
- valid_responses: trial.key_to_move_forward
252
- });}
253
- } else if(trial.response_ends_trial && trial.display_feedback != true) {
254
- var keyListener = jsPsych.pluginAPI.getKeyboardResponse({
255
- callback_function: end_trial,
256
- valid_responses: [jsPsych.ALL_KEYS]
257
- });
258
- } else if(!trial.response_ends_trial && trial.display_feedback != true) {
259
-
260
- }
261
- }
262
- }
263
- };
264
-
265
- // start the response listener
266
- if (trial.left_category_key != jsPsych.NO_KEYS && trial.right_category_key != jsPsych.NO_KEYS) {
267
- var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
268
- callback_function: after_response,
269
- valid_responses: [trial.left_category_key, trial.right_category_key],
270
- rt_method: 'performance',
271
- persist: false,
272
- allow_held_key: false
273
- });
274
- }
275
-
276
- // end trial if time limit is set
277
- if (trial.trial_duration !== null && trial.response_ends_trial != true) {
278
- jsPsych.pluginAPI.setTimeout(function() {
279
- end_trial();
280
- }, trial.trial_duration);
281
- }
282
-
283
- };
284
-
285
- return plugin;
286
- })();