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,311 +0,0 @@
1
- /**
2
- * jspsych-image-button-response
3
- * Josh de Leeuw
4
- *
5
- * plugin for displaying a stimulus and getting a button response
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- **/
10
-
11
- jsPsych.plugins["image-button-response"] = (function() {
12
-
13
- var plugin = {};
14
-
15
- jsPsych.pluginAPI.registerPreload('image-button-response', 'stimulus', 'image');
16
-
17
- plugin.info = {
18
- name: 'image-button-response',
19
- description: '',
20
- parameters: {
21
- stimulus: {
22
- type: jsPsych.plugins.parameterType.IMAGE,
23
- pretty_name: 'Stimulus',
24
- default: undefined,
25
- description: 'The image to be displayed'
26
- },
27
- stimulus_height: {
28
- type: jsPsych.plugins.parameterType.INT,
29
- pretty_name: 'Image height',
30
- default: null,
31
- description: 'Set the image height in pixels'
32
- },
33
- stimulus_width: {
34
- type: jsPsych.plugins.parameterType.INT,
35
- pretty_name: 'Image width',
36
- default: null,
37
- description: 'Set the image width in pixels'
38
- },
39
- maintain_aspect_ratio: {
40
- type: jsPsych.plugins.parameterType.BOOL,
41
- pretty_name: 'Maintain aspect ratio',
42
- default: true,
43
- description: 'Maintain the aspect ratio after setting width or height'
44
- },
45
- choices: {
46
- type: jsPsych.plugins.parameterType.STRING,
47
- pretty_name: 'Choices',
48
- default: undefined,
49
- array: true,
50
- description: 'The labels for the buttons.'
51
- },
52
- button_html: {
53
- type: jsPsych.plugins.parameterType.STRING,
54
- pretty_name: 'Button HTML',
55
- default: '<button class="jspsych-btn">%choice%</button>',
56
- array: true,
57
- description: 'The html of the button. Can create own style.'
58
- },
59
- prompt: {
60
- type: jsPsych.plugins.parameterType.STRING,
61
- pretty_name: 'Prompt',
62
- default: null,
63
- description: 'Any content here will be displayed under the button.'
64
- },
65
- stimulus_duration: {
66
- type: jsPsych.plugins.parameterType.INT,
67
- pretty_name: 'Stimulus duration',
68
- default: null,
69
- description: 'How long to hide the stimulus.'
70
- },
71
- trial_duration: {
72
- type: jsPsych.plugins.parameterType.INT,
73
- pretty_name: 'Trial duration',
74
- default: null,
75
- description: 'How long to show the trial.'
76
- },
77
- margin_vertical: {
78
- type: jsPsych.plugins.parameterType.STRING,
79
- pretty_name: 'Margin vertical',
80
- default: '0px',
81
- description: 'The vertical margin of the button.'
82
- },
83
- margin_horizontal: {
84
- type: jsPsych.plugins.parameterType.STRING,
85
- pretty_name: 'Margin horizontal',
86
- default: '8px',
87
- description: 'The horizontal margin of the button.'
88
- },
89
- response_ends_trial: {
90
- type: jsPsych.plugins.parameterType.BOOL,
91
- pretty_name: 'Response ends trial',
92
- default: true,
93
- description: 'If true, then trial will end when user responds.'
94
- },
95
- render_on_canvas: {
96
- type: jsPsych.plugins.parameterType.BOOL,
97
- pretty_name: 'Render on canvas',
98
- default: true,
99
- description: 'If true, the image will be drawn onto a canvas element (prevents blank screen between consecutive images in some browsers).'+
100
- 'If false, the image will be shown via an img element.'
101
- }
102
- }
103
- }
104
-
105
- plugin.trial = function(display_element, trial) {
106
-
107
- var height, width;
108
- var html;
109
- if (trial.render_on_canvas) {
110
- // first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
111
- if (display_element.hasChildNodes()) {
112
- // can't loop through child list because the list will be modified by .removeChild()
113
- while (display_element.firstChild) {
114
- display_element.removeChild(display_element.firstChild);
115
- }
116
- }
117
- // create canvas element and image
118
- var canvas = document.createElement("canvas");
119
- canvas.id = "jspsych-image-button-response-stimulus";
120
- canvas.style.margin = 0;
121
- canvas.style.padding = 0;
122
- var img = new Image();
123
- img.src = trial.stimulus;
124
- // determine image height and width
125
- if (trial.stimulus_height !== null) {
126
- height = trial.stimulus_height;
127
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
128
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
129
- }
130
- } else {
131
- height = img.naturalHeight;
132
- }
133
- if (trial.stimulus_width !== null) {
134
- width = trial.stimulus_width;
135
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
136
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
137
- }
138
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
139
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
140
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
141
- width = img.naturalWidth;
142
- }
143
- canvas.height = height;
144
- canvas.width = width;
145
- // create buttons
146
- var buttons = [];
147
- if (Array.isArray(trial.button_html)) {
148
- if (trial.button_html.length == trial.choices.length) {
149
- buttons = trial.button_html;
150
- } else {
151
- console.error('Error in image-button-response plugin. The length of the button_html array does not equal the length of the choices array');
152
- }
153
- } else {
154
- for (var i = 0; i < trial.choices.length; i++) {
155
- buttons.push(trial.button_html);
156
- }
157
- }
158
- var btngroup_div = document.createElement('div');
159
- btngroup_div.id = "jspsych-image-button-response-btngroup";
160
- html = '';
161
- for (var i = 0; i < trial.choices.length; i++) {
162
- var str = buttons[i].replace(/%choice%/g, trial.choices[i]);
163
- html += '<div class="jspsych-image-button-response-button" style="display: inline-block; margin:'+trial.margin_vertical+' '+trial.margin_horizontal+'" id="jspsych-image-button-response-button-' + i +'" data-choice="'+i+'">'+str+'</div>';
164
- }
165
- btngroup_div.innerHTML = html;
166
- // add canvas to screen and draw image
167
- display_element.insertBefore(canvas, null);
168
- var ctx = canvas.getContext("2d");
169
- ctx.drawImage(img,0,0,width,height);
170
- // add buttons to screen
171
- display_element.insertBefore(btngroup_div, canvas.nextElementSibling);
172
- // add prompt if there is one
173
- if (trial.prompt !== null) {
174
- display_element.insertAdjacentHTML('beforeend', trial.prompt);
175
- }
176
-
177
- } else {
178
-
179
- // display stimulus as an image element
180
- html = '<img src="'+trial.stimulus+'" id="jspsych-image-button-response-stimulus">';
181
- //display buttons
182
- var buttons = [];
183
- if (Array.isArray(trial.button_html)) {
184
- if (trial.button_html.length == trial.choices.length) {
185
- buttons = trial.button_html;
186
- } else {
187
- console.error('Error in image-button-response plugin. The length of the button_html array does not equal the length of the choices array');
188
- }
189
- } else {
190
- for (var i = 0; i < trial.choices.length; i++) {
191
- buttons.push(trial.button_html);
192
- }
193
- }
194
- html += '<div id="jspsych-image-button-response-btngroup">';
195
-
196
- for (var i = 0; i < trial.choices.length; i++) {
197
- var str = buttons[i].replace(/%choice%/g, trial.choices[i]);
198
- html += '<div class="jspsych-image-button-response-button" style="display: inline-block; margin:'+trial.margin_vertical+' '+trial.margin_horizontal+'" id="jspsych-image-button-response-button-' + i +'" data-choice="'+i+'">'+str+'</div>';
199
- }
200
- html += '</div>';
201
- // add prompt
202
- if (trial.prompt !== null){
203
- html += trial.prompt;
204
- }
205
- // update the page content
206
- display_element.innerHTML = html;
207
-
208
- // set image dimensions after image has loaded (so that we have access to naturalHeight/naturalWidth)
209
- var img = display_element.querySelector('#jspsych-image-button-response-stimulus');
210
- if (trial.stimulus_height !== null) {
211
- height = trial.stimulus_height;
212
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
213
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
214
- }
215
- } else {
216
- height = img.naturalHeight;
217
- }
218
- if (trial.stimulus_width !== null) {
219
- width = trial.stimulus_width;
220
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
221
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
222
- }
223
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
224
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
225
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
226
- width = img.naturalWidth;
227
- }
228
- img.style.height = height.toString() + "px";
229
- img.style.width = width.toString() + "px";
230
- }
231
-
232
- // start timing
233
- var start_time = performance.now();
234
-
235
- for (var i = 0; i < trial.choices.length; i++) {
236
- display_element.querySelector('#jspsych-image-button-response-button-' + i).addEventListener('click', function(e){
237
- var choice = e.currentTarget.getAttribute('data-choice'); // don't use dataset for jsdom compatibility
238
- after_response(choice);
239
- });
240
- }
241
-
242
- // store response
243
- var response = {
244
- rt: null,
245
- button: null
246
- };
247
-
248
- // function to handle responses by the subject
249
- function after_response(choice) {
250
-
251
- // measure rt
252
- var end_time = performance.now();
253
- var rt = end_time - start_time;
254
- response.button = parseInt(choice);
255
- response.rt = rt;
256
-
257
- // after a valid response, the stimulus will have the CSS class 'responded'
258
- // which can be used to provide visual feedback that a response was recorded
259
- display_element.querySelector('#jspsych-image-button-response-stimulus').className += ' responded';
260
-
261
- // disable all the buttons after a response
262
- var btns = document.querySelectorAll('.jspsych-image-button-response-button button');
263
- for(var i=0; i<btns.length; i++){
264
- //btns[i].removeEventListener('click');
265
- btns[i].setAttribute('disabled', 'disabled');
266
- }
267
-
268
- if (trial.response_ends_trial) {
269
- end_trial();
270
- }
271
- };
272
-
273
- // function to end trial when it is time
274
- function end_trial() {
275
-
276
- // kill any remaining setTimeout handlers
277
- jsPsych.pluginAPI.clearAllTimeouts();
278
-
279
- // gather the data to store for the trial
280
- var trial_data = {
281
- "rt": response.rt,
282
- "stimulus": trial.stimulus,
283
- "button_pressed": response.button
284
- };
285
-
286
- // clear the display
287
- display_element.innerHTML = '';
288
-
289
- // move on to the next trial
290
- jsPsych.finishTrial(trial_data);
291
- };
292
-
293
- // hide image if timing is set
294
- if (trial.stimulus_duration !== null) {
295
- jsPsych.pluginAPI.setTimeout(function() {
296
- display_element.querySelector('#jspsych-image-button-response-stimulus').style.visibility = 'hidden';
297
- }, trial.stimulus_duration);
298
- }
299
-
300
- // end trial if time limit is set
301
- if (trial.trial_duration !== null) {
302
- jsPsych.pluginAPI.setTimeout(function() {
303
- end_trial();
304
- }, trial.trial_duration);
305
- } else if (trial.response_ends_trial === false) {
306
- console.warn("The experiment may be deadlocked. Try setting a trial duration or set response_ends_trial to true.");
307
- }
308
- };
309
-
310
- return plugin;
311
- })();
@@ -1,247 +0,0 @@
1
- /**
2
- * jspsych-image-keyboard-response
3
- * Josh de Leeuw
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["image-keyboard-response"] = (function() {
13
-
14
- var plugin = {};
15
-
16
- jsPsych.pluginAPI.registerPreload('image-keyboard-response', 'stimulus', 'image');
17
-
18
- plugin.info = {
19
- name: 'image-keyboard-response',
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
- stimulus_height: {
29
- type: jsPsych.plugins.parameterType.INT,
30
- pretty_name: 'Image height',
31
- default: null,
32
- description: 'Set the image height in pixels'
33
- },
34
- stimulus_width: {
35
- type: jsPsych.plugins.parameterType.INT,
36
- pretty_name: 'Image width',
37
- default: null,
38
- description: 'Set the image width in pixels'
39
- },
40
- maintain_aspect_ratio: {
41
- type: jsPsych.plugins.parameterType.BOOL,
42
- pretty_name: 'Maintain aspect ratio',
43
- default: true,
44
- description: 'Maintain the aspect ratio after setting width or height'
45
- },
46
- choices: {
47
- type: jsPsych.plugins.parameterType.KEYCODE,
48
- array: true,
49
- pretty_name: 'Choices',
50
- default: jsPsych.ALL_KEYS,
51
- description: 'The keys the subject is allowed to press to respond to the stimulus.'
52
- },
53
- prompt: {
54
- type: jsPsych.plugins.parameterType.STRING,
55
- pretty_name: 'Prompt',
56
- default: null,
57
- description: 'Any content here will be displayed below the stimulus.'
58
- },
59
- stimulus_duration: {
60
- type: jsPsych.plugins.parameterType.INT,
61
- pretty_name: 'Stimulus duration',
62
- default: null,
63
- description: 'How long to hide the stimulus.'
64
- },
65
- trial_duration: {
66
- type: jsPsych.plugins.parameterType.INT,
67
- pretty_name: 'Trial duration',
68
- default: null,
69
- description: 'How long to show trial before it ends.'
70
- },
71
- response_ends_trial: {
72
- type: jsPsych.plugins.parameterType.BOOL,
73
- pretty_name: 'Response ends trial',
74
- default: true,
75
- description: 'If true, trial will end when subject makes a response.'
76
- },
77
- render_on_canvas: {
78
- type: jsPsych.plugins.parameterType.BOOL,
79
- pretty_name: 'Render on canvas',
80
- default: true,
81
- description: 'If true, the image will be drawn onto a canvas element (prevents blank screen between consecutive images in some browsers).'+
82
- 'If false, the image will be shown via an img element.'
83
- }
84
- }
85
- }
86
-
87
- plugin.trial = function(display_element, trial) {
88
-
89
- var height, width;
90
- if (trial.render_on_canvas) {
91
- // first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
92
- if (display_element.hasChildNodes()) {
93
- // can't loop through child list because the list will be modified by .removeChild()
94
- while (display_element.firstChild) {
95
- display_element.removeChild(display_element.firstChild);
96
- }
97
- }
98
- // create canvas element and image
99
- var canvas = document.createElement("canvas");
100
- canvas.id = "jspsych-image-keyboard-response-stimulus";
101
- canvas.style.margin = 0;
102
- canvas.style.padding = 0;
103
- var img = new Image();
104
- img.src = trial.stimulus;
105
- // determine image height and width
106
- if (trial.stimulus_height !== null) {
107
- height = trial.stimulus_height;
108
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
109
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
110
- }
111
- } else {
112
- height = img.naturalHeight;
113
- }
114
- if (trial.stimulus_width !== null) {
115
- width = trial.stimulus_width;
116
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
117
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
118
- }
119
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
120
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
121
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
122
- width = img.naturalWidth;
123
- }
124
- canvas.height = height;
125
- canvas.width = width;
126
- // add canvas and draw image
127
- display_element.insertBefore(canvas, null);
128
- var ctx = canvas.getContext("2d");
129
- ctx.drawImage(img,0,0,width,height);
130
- // add prompt if there is one
131
- if (trial.prompt !== null) {
132
- display_element.insertAdjacentHTML('beforeend', trial.prompt);
133
- }
134
-
135
- } else {
136
-
137
- // display stimulus as an image element
138
- var html = '<img src="'+trial.stimulus+'" id="jspsych-image-keyboard-response-stimulus">';
139
- // add prompt
140
- if (trial.prompt !== null){
141
- html += trial.prompt;
142
- }
143
- // update the page content
144
- display_element.innerHTML = html;
145
-
146
- // set image dimensions after image has loaded (so that we have access to naturalHeight/naturalWidth)
147
- var img = display_element.querySelector('#jspsych-image-keyboard-response-stimulus');
148
- if (trial.stimulus_height !== null) {
149
- height = trial.stimulus_height;
150
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
151
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
152
- }
153
- } else {
154
- height = img.naturalHeight;
155
- }
156
- if (trial.stimulus_width !== null) {
157
- width = trial.stimulus_width;
158
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
159
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
160
- }
161
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
162
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
163
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
164
- width = img.naturalWidth;
165
- }
166
- img.style.height = height.toString() + "px";
167
- img.style.width = width.toString() + "px";
168
- }
169
-
170
- // store response
171
- var response = {
172
- rt: null,
173
- key: null
174
- };
175
-
176
- // function to end trial when it is time
177
- var end_trial = function() {
178
-
179
- // kill any remaining setTimeout handlers
180
- jsPsych.pluginAPI.clearAllTimeouts();
181
-
182
- // kill keyboard listeners
183
- if (typeof keyboardListener !== 'undefined') {
184
- jsPsych.pluginAPI.cancelKeyboardResponse(keyboardListener);
185
- }
186
-
187
- // gather the data to store for the trial
188
- var trial_data = {
189
- "rt": response.rt,
190
- "stimulus": trial.stimulus,
191
- "key_press": response.key
192
- };
193
-
194
- // clear the display
195
- display_element.innerHTML = '';
196
-
197
- // move on to the next trial
198
- jsPsych.finishTrial(trial_data);
199
- };
200
-
201
- // function to handle responses by the subject
202
- var after_response = function(info) {
203
-
204
- // after a valid response, the stimulus will have the CSS class 'responded'
205
- // which can be used to provide visual feedback that a response was recorded
206
- display_element.querySelector('#jspsych-image-keyboard-response-stimulus').className += ' responded';
207
-
208
- // only record the first response
209
- if (response.key == null) {
210
- response = info;
211
- }
212
-
213
- if (trial.response_ends_trial) {
214
- end_trial();
215
- }
216
- };
217
-
218
- // start the response listener
219
- if (trial.choices != jsPsych.NO_KEYS) {
220
- var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
221
- callback_function: after_response,
222
- valid_responses: trial.choices,
223
- rt_method: 'performance',
224
- persist: false,
225
- allow_held_key: false
226
- });
227
- }
228
-
229
- // hide stimulus if stimulus_duration is set
230
- if (trial.stimulus_duration !== null) {
231
- jsPsych.pluginAPI.setTimeout(function() {
232
- display_element.querySelector('#jspsych-image-keyboard-response-stimulus').style.visibility = 'hidden';
233
- }, trial.stimulus_duration);
234
- }
235
-
236
- // end trial if trial_duration is set
237
- if (trial.trial_duration !== null) {
238
- jsPsych.pluginAPI.setTimeout(function() {
239
- end_trial();
240
- }, trial.trial_duration);
241
- } else if (trial.response_ends_trial === false) {
242
- console.warn("The experiment may be deadlocked. Try setting a trial duration or set response_ends_trial to true.");
243
- }
244
- };
245
-
246
- return plugin;
247
- })();