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,266 +0,0 @@
1
- /**
2
- * jspsych plugin for categorization trials with feedback and animated stimuli
3
- * Josh de Leeuw
4
- *
5
- * documentation: docs.jspsych.org
6
- **/
7
-
8
-
9
- jsPsych.plugins["categorize-animation"] = (function() {
10
-
11
- var plugin = {};
12
-
13
- jsPsych.pluginAPI.registerPreload('categorize-animation', 'stimuli', 'image');
14
-
15
- plugin.info = {
16
- name: 'categorize-animation',
17
- description: '',
18
- parameters: {
19
- stimuli: {
20
- type: jsPsych.plugins.parameterType.IMAGE,
21
- pretty_name: 'Stimuli',
22
- default: undefined,
23
- description: 'Array of paths to image files.'
24
- },
25
- key_answer: {
26
- type: jsPsych.plugins.parameterType.KEYCODE,
27
- pretty_name: 'Key answer',
28
- default: undefined,
29
- description: 'The key to indicate correct response'
30
- },
31
- choices: {
32
- type: jsPsych.plugins.parameterType.KEYCODE,
33
- pretty_name: 'Choices',
34
- default: jsPsych.ALL_KEYS,
35
- array: true,
36
- description: 'The keys subject is allowed to press to respond to stimuli.'
37
- },
38
- text_answer: {
39
- type: jsPsych.plugins.parameterType.STRING,
40
- pretty_name: 'Text answer',
41
- default: null,
42
- description: 'Text to describe correct answer.'
43
- },
44
- correct_text: {
45
- type: jsPsych.plugins.parameterType.STRING,
46
- pretty_name: 'Correct text',
47
- default: 'Correct.',
48
- description: 'String to show when subject gives correct answer'
49
- },
50
- incorrect_text: {
51
- type: jsPsych.plugins.parameterType.STRING,
52
- pretty_name: 'Incorrect text',
53
- default: 'Wrong.',
54
- description: 'String to show when subject gives incorrect answer.'
55
- },
56
- frame_time: {
57
- type: jsPsych.plugins.parameterType.INT,
58
- pretty_name: 'Frame time',
59
- default: 500,
60
- description: 'Duration to display each image.'
61
- },
62
- sequence_reps: {
63
- type: jsPsych.plugins.parameterType.INT,
64
- pretty_name: 'Sequence repetitions',
65
- default: 1,
66
- description: 'How many times to display entire sequence.'
67
- },
68
- allow_response_before_complete: {
69
- type: jsPsych.plugins.parameterType.BOOL,
70
- pretty_name: 'Allow response before complete',
71
- default: false,
72
- description: 'If true, subject can response before the animation sequence finishes'
73
- },
74
- feedback_duration: {
75
- type: jsPsych.plugins.parameterType.INT,
76
- pretty_name: 'Feedback duration',
77
- default: 2000,
78
- description: 'How long to show feedback'
79
- },
80
- prompt: {
81
- type: jsPsych.plugins.parameterType.STRING,
82
- pretty_name: 'Prompt',
83
- default: null,
84
- description: 'Any content here will be displayed below the stimulus.'
85
- },
86
- render_on_canvas: {
87
- type: jsPsych.plugins.parameterType.BOOL,
88
- pretty_name: 'Render on canvas',
89
- default: true,
90
- description: 'If true, the images will be drawn onto a canvas element (prevents blank screen between consecutive images in some browsers).'+
91
- 'If false, the image will be shown via an img element.'
92
- }
93
- }
94
- }
95
-
96
- plugin.trial = function(display_element, trial) {
97
-
98
- var animate_frame = -1;
99
- var reps = 0;
100
-
101
- var showAnimation = true;
102
-
103
- var responded = false;
104
- var timeoutSet = false;
105
- var correct;
106
-
107
- if (trial.render_on_canvas) {
108
- // first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
109
- if (display_element.hasChildNodes()) {
110
- // can't loop through child list because the list will be modified by .removeChild()
111
- while (display_element.firstChild) {
112
- display_element.removeChild(display_element.firstChild);
113
- }
114
- }
115
- var canvas = document.createElement("canvas");
116
- canvas.id = "jspsych-categorize-animation-stimulus";
117
- canvas.style.margin = 0;
118
- canvas.style.padding = 0;
119
- display_element.insertBefore(canvas, null);
120
- var ctx = canvas.getContext("2d");
121
- if (trial.prompt !== null) {
122
- var prompt_div = document.createElement("div");
123
- prompt_div.id = "jspsych-categorize-animation-prompt";
124
- prompt_div.style.visibility = "hidden";
125
- prompt_div.innerHTML = trial.prompt;
126
- display_element.insertBefore(prompt_div, canvas.nextElementSibling);
127
- }
128
- var feedback_div = document.createElement("div");
129
- display_element.insertBefore(feedback_div, display_element.nextElementSibling);
130
- }
131
-
132
- // show animation
133
- var animate_interval = setInterval(function() {
134
- if (!trial.render_on_canvas) {
135
- display_element.innerHTML = ''; // clear everything
136
- }
137
- animate_frame++;
138
- if (animate_frame == trial.stimuli.length) {
139
- animate_frame = 0;
140
- reps++;
141
- // check if reps complete //
142
- if (trial.sequence_reps != -1 && reps >= trial.sequence_reps) {
143
- // done with animation
144
- showAnimation = false;
145
- }
146
- }
147
-
148
- if (showAnimation) {
149
- if (trial.render_on_canvas) {
150
- display_element.querySelector('#jspsych-categorize-animation-stimulus').style.visibility = 'visible';
151
- var img = new Image();
152
- img.src = trial.stimuli[animate_frame];
153
- canvas.height = img.naturalHeight;
154
- canvas.width = img.naturalWidth;
155
- ctx.drawImage(img,0,0);
156
- } else {
157
- display_element.innerHTML += '<img src="'+trial.stimuli[animate_frame]+'" class="jspsych-categorize-animation-stimulus"></img>';
158
- }
159
- }
160
-
161
- if (!responded && trial.allow_response_before_complete) {
162
- // in here if the user can respond before the animation is done
163
- if (trial.prompt !== null) {
164
- if (trial.render_on_canvas) {
165
- prompt_div.style.visibility = "visible";
166
- } else {
167
- display_element.innerHTML += trial.prompt;
168
- }
169
- }
170
- if (trial.render_on_canvas) {
171
- if (!showAnimation) {
172
- canvas.remove();
173
- }
174
- }
175
- } else if (!responded) {
176
- // in here if the user has to wait to respond until animation is done.
177
- // if this is the case, don't show the prompt until the animation is over.
178
- if (!showAnimation) {
179
- if (trial.prompt !== null) {
180
- if (trial.render_on_canvas) {
181
- prompt_div.style.visibility = "visible";
182
- } else {
183
- display_element.innerHTML += trial.prompt;
184
- }
185
- }
186
- if (trial.render_on_canvas) {
187
- canvas.remove();
188
- }
189
- }
190
- } else {
191
- // user has responded if we get here.
192
-
193
- // show feedback
194
- var feedback_text = "";
195
- if (correct) {
196
- feedback_text = trial.correct_text.replace("%ANS%", trial.text_answer);
197
- } else {
198
- feedback_text = trial.incorrect_text.replace("%ANS%", trial.text_answer);
199
- }
200
- if (trial.render_on_canvas) {
201
- if (trial.prompt !== null) {
202
- prompt_div.remove();
203
- }
204
- feedback_div.innerHTML = feedback_text;
205
- } else {
206
- display_element.innerHTML += feedback_text;
207
- }
208
-
209
- // set timeout to clear feedback
210
- if (!timeoutSet) {
211
- timeoutSet = true;
212
- jsPsych.pluginAPI.setTimeout(function() {
213
- endTrial();
214
- }, trial.feedback_duration);
215
- }
216
- }
217
-
218
-
219
- }, trial.frame_time);
220
-
221
-
222
- var keyboard_listener;
223
- var trial_data = {};
224
-
225
- var after_response = function(info) {
226
- // ignore the response if animation is playing and subject
227
- // not allowed to respond before it is complete
228
- if (!trial.allow_response_before_complete && showAnimation) {
229
- return false;
230
- }
231
-
232
- correct = false;
233
- if (trial.key_answer == info.key) {
234
- correct = true;
235
- }
236
-
237
- responded = true;
238
-
239
- trial_data = {
240
- "stimulus": JSON.stringify(trial.stimuli),
241
- "rt": info.rt,
242
- "correct": correct,
243
- "key_press": info.key
244
- };
245
-
246
- jsPsych.pluginAPI.cancelKeyboardResponse(keyboard_listener);
247
-
248
- }
249
-
250
- keyboard_listener = jsPsych.pluginAPI.getKeyboardResponse({
251
- callback_function: after_response,
252
- valid_responses: trial.choices,
253
- rt_method: 'performance',
254
- persist: true,
255
- allow_held_key: false
256
- });
257
-
258
- function endTrial() {
259
- clearInterval(animate_interval); // stop animation!
260
- display_element.innerHTML = ''; // clear everything
261
- jsPsych.finishTrial(trial_data);
262
- }
263
- };
264
-
265
- return plugin;
266
- })();
@@ -1,220 +0,0 @@
1
- /**
2
- * jspsych plugin for categorization trials with feedback
3
- * Josh de Leeuw
4
- *
5
- * documentation: docs.jspsych.org
6
- **/
7
-
8
-
9
- jsPsych.plugins['categorize-html'] = (function() {
10
-
11
- var plugin = {};
12
-
13
- plugin.info = {
14
- name: 'categorize-html',
15
- description: '',
16
- parameters: {
17
- stimulus: {
18
- type: jsPsych.plugins.parameterType.HTML_STRING,
19
- pretty_name: 'Stimulus',
20
- default: undefined,
21
- description: 'The HTML content to be displayed.'
22
- },
23
- key_answer: {
24
- type: jsPsych.plugins.parameterType.KEYCODE,
25
- pretty_name: 'Key answer',
26
- default: undefined,
27
- description: 'The key to indicate the correct response.'
28
- },
29
- choices: {
30
- type: jsPsych.plugins.parameterType.KEYCODE,
31
- pretty_name: 'Choices',
32
- default: jsPsych.ALL_KEYS,
33
- array: true,
34
- description: 'The keys the subject is allowed to press to respond to the stimulus.'
35
- },
36
- text_answer: {
37
- type: jsPsych.plugins.parameterType.STRING,
38
- pretty_name: 'Text answer',
39
- default: null,
40
- description: 'Label that is associated with the correct answer.'
41
- },
42
- correct_text: {
43
- type: jsPsych.plugins.parameterType.STRING,
44
- pretty_name: 'Correct text',
45
- default: "<p class='feedback'>Correct</p>",
46
- description: 'String to show when correct answer is given.'
47
- },
48
- incorrect_text: {
49
- type: jsPsych.plugins.parameterType.STRING,
50
- pretty_name: 'Incorrect text',
51
- default: "<p class='feedback'>Incorrect</p>",
52
- description: 'String to show when incorrect answer is given.'
53
- },
54
- prompt: {
55
- type: jsPsych.plugins.parameterType.STRING,
56
- pretty_name: 'Prompt',
57
- default: null,
58
- description: 'Any content here will be displayed below the stimulus.'
59
- },
60
- force_correct_button_press: {
61
- type: jsPsych.plugins.parameterType.BOOL,
62
- pretty_name: 'Force correct button press',
63
- default: false,
64
- description: 'If set to true, then the subject must press the correct response key after feedback in order to advance to next trial.'
65
- },
66
- show_stim_with_feedback: {
67
- type: jsPsych.plugins.parameterType.BOOL,
68
- default: true,
69
- no_function: false,
70
- description: ''
71
- },
72
- show_feedback_on_timeout: {
73
- type: jsPsych.plugins.parameterType.BOOL,
74
- pretty_name: 'Show feedback on timeout',
75
- default: false,
76
- description: 'If true, stimulus will be shown during feedback. If false, only the text feedback will be displayed during feedback.'
77
- },
78
- timeout_message: {
79
- type: jsPsych.plugins.parameterType.STRING,
80
- pretty_name: 'Timeout message',
81
- default: "<p>Please respond faster.</p>",
82
- description: 'The message displayed on a timeout non-response.'
83
- },
84
- stimulus_duration: {
85
- type: jsPsych.plugins.parameterType.INT,
86
- pretty_name: 'Stimulus duration',
87
- default: null,
88
- description: 'How long to hide stimulus.'
89
- },
90
- trial_duration: {
91
- type: jsPsych.plugins.parameterType.INT,
92
- pretty_name: 'Trial duration',
93
- default: null,
94
- description: 'How long to show trial'
95
- },
96
- feedback_duration: {
97
- type: jsPsych.plugins.parameterType.INT,
98
- pretty_name: 'Feedback duration',
99
- default: 2000,
100
- description: 'How long to show feedback.'
101
- }
102
- }
103
- }
104
-
105
- plugin.trial = function(display_element, trial) {
106
-
107
- display_element.innerHTML = '<div id="jspsych-categorize-html-stimulus" class="jspsych-categorize-html-stimulus">'+trial.stimulus+'</div>';
108
-
109
- // hide image after time if the timing parameter is set
110
- if (trial.stimulus_duration !== null) {
111
- jsPsych.pluginAPI.setTimeout(function() {
112
- display_element.querySelector('#jspsych-categorize-html-stimulus').style.visibility = 'hidden';
113
- }, trial.stimulus_duration);
114
- }
115
-
116
- // if prompt is set, show prompt
117
- if (trial.prompt !== null) {
118
- display_element.innerHTML += trial.prompt;
119
- }
120
-
121
- var trial_data = {};
122
-
123
- // create response function
124
- var after_response = function(info) {
125
-
126
- // kill any remaining setTimeout handlers
127
- jsPsych.pluginAPI.clearAllTimeouts();
128
-
129
- // clear keyboard listener
130
- jsPsych.pluginAPI.cancelAllKeyboardResponses();
131
-
132
- var correct = false;
133
- if (trial.key_answer == info.key) {
134
- correct = true;
135
- }
136
-
137
- // save data
138
- trial_data = {
139
- "rt": info.rt,
140
- "correct": correct,
141
- "stimulus": trial.stimulus,
142
- "key_press": info.key
143
- };
144
-
145
- display_element.innerHTML = '';
146
-
147
- var timeout = info.rt == null;
148
- doFeedback(correct, timeout);
149
- }
150
-
151
- jsPsych.pluginAPI.getKeyboardResponse({
152
- callback_function: after_response,
153
- valid_responses: trial.choices,
154
- rt_method: 'performance',
155
- persist: false,
156
- allow_held_key: false
157
- });
158
-
159
- if (trial.trial_duration !== null) {
160
- jsPsych.pluginAPI.setTimeout(function() {
161
- after_response({
162
- key: null,
163
- rt: null
164
- });
165
- }, trial.trial_duration);
166
- }
167
-
168
- function doFeedback(correct, timeout) {
169
-
170
- if (timeout && !trial.show_feedback_on_timeout) {
171
- display_element.innerHTML += trial.timeout_message;
172
- } else {
173
- // show image during feedback if flag is set
174
- if (trial.show_stim_with_feedback) {
175
- display_element.innerHTML = '<div id="jspsych-categorize-html-stimulus" class="jspsych-categorize-html-stimulus">'+trial.stimulus+'</div>';
176
- }
177
-
178
- // substitute answer in feedback string.
179
- var atext = "";
180
- if (correct) {
181
- atext = trial.correct_text.replace("%ANS%", trial.text_answer);
182
- } else {
183
- atext = trial.incorrect_text.replace("%ANS%", trial.text_answer);
184
- }
185
-
186
- // show the feedback
187
- display_element.innerHTML += atext;
188
- }
189
- // check if force correct button press is set
190
- if (trial.force_correct_button_press && correct === false && ((timeout && trial.show_feedback_on_timeout) || !timeout)) {
191
-
192
- var after_forced_response = function(info) {
193
- endTrial();
194
- }
195
-
196
- jsPsych.pluginAPI.getKeyboardResponse({
197
- callback_function: after_forced_response,
198
- valid_responses: [trial.key_answer],
199
- rt_method: 'performance',
200
- persist: false,
201
- allow_held_key: false
202
- });
203
-
204
- } else {
205
- jsPsych.pluginAPI.setTimeout(function() {
206
- endTrial();
207
- }, trial.feedback_duration);
208
- }
209
-
210
- }
211
-
212
- function endTrial() {
213
- display_element.innerHTML = '';
214
- jsPsych.finishTrial(trial_data);
215
- }
216
-
217
- };
218
-
219
- return plugin;
220
- })();
@@ -1,222 +0,0 @@
1
- /**
2
- * jspsych plugin for categorization trials with feedback
3
- * Josh de Leeuw
4
- *
5
- * documentation: docs.jspsych.org
6
- **/
7
-
8
-
9
- jsPsych.plugins['categorize-image'] = (function() {
10
-
11
- var plugin = {};
12
-
13
- jsPsych.pluginAPI.registerPreload('categorize-image', 'stimulus', 'image');
14
-
15
- plugin.info = {
16
- name: 'categorize-image',
17
- description: '',
18
- parameters: {
19
- stimulus: {
20
- type: jsPsych.plugins.parameterType.IMAGE,
21
- pretty_name: 'Stimulus',
22
- default: undefined,
23
- description: 'The image content to be displayed.'
24
- },
25
- key_answer: {
26
- type: jsPsych.plugins.parameterType.KEYCODE,
27
- pretty_name: 'Key answer',
28
- default: undefined,
29
- description: 'The key to indicate the correct response.'
30
- },
31
- choices: {
32
- type: jsPsych.plugins.parameterType.KEYCODE,
33
- pretty_name: 'Choices',
34
- default: jsPsych.ALL_KEYS,
35
- array: true,
36
- description: 'The keys the subject is allowed to press to respond to the stimulus.'
37
- },
38
- text_answer: {
39
- type: jsPsych.plugins.parameterType.STRING,
40
- pretty_name: 'Text answer',
41
- default: null,
42
- description: 'Label that is associated with the correct answer.'
43
- },
44
- correct_text: {
45
- type: jsPsych.plugins.parameterType.STRING,
46
- pretty_name: 'Correct text',
47
- default: "<p class='feedback'>Correct</p>",
48
- description: 'String to show when correct answer is given.'
49
- },
50
- incorrect_text: {
51
- type: jsPsych.plugins.parameterType.STRING,
52
- pretty_name: 'Incorrect text',
53
- default: "<p class='feedback'>Incorrect</p>",
54
- description: 'String to show when incorrect answer is given.'
55
- },
56
- prompt: {
57
- type: jsPsych.plugins.parameterType.STRING,
58
- pretty_name: 'Prompt',
59
- default: null,
60
- description: 'Any content here will be displayed below the stimulus.'
61
- },
62
- force_correct_button_press: {
63
- type: jsPsych.plugins.parameterType.BOOL,
64
- pretty_name: 'Force correct button press',
65
- default: false,
66
- description: 'If set to true, then the subject must press the correct response key after feedback in order to advance to next trial.'
67
- },
68
- show_stim_with_feedback: {
69
- type: jsPsych.plugins.parameterType.BOOL,
70
- default: true,
71
- no_function: false,
72
- description: ''
73
- },
74
- show_feedback_on_timeout: {
75
- type: jsPsych.plugins.parameterType.BOOL,
76
- pretty_name: 'Show feedback on timeout',
77
- default: false,
78
- description: 'If true, stimulus will be shown during feedback. If false, only the text feedback will be displayed during feedback.'
79
- },
80
- timeout_message: {
81
- type: jsPsych.plugins.parameterType.STRING,
82
- pretty_name: 'Timeout message',
83
- default: "<p>Please respond faster.</p>",
84
- description: 'The message displayed on a timeout non-response.'
85
- },
86
- stimulus_duration: {
87
- type: jsPsych.plugins.parameterType.INT,
88
- pretty_name: 'Stimulus duration',
89
- default: null,
90
- description: 'How long to hide stimulus.'
91
- },
92
- trial_duration: {
93
- type: jsPsych.plugins.parameterType.INT,
94
- pretty_name: 'Trial duration',
95
- default: null,
96
- description: 'How long to show trial'
97
- },
98
- feedback_duration: {
99
- type: jsPsych.plugins.parameterType.INT,
100
- pretty_name: 'Feedback duration',
101
- default: 2000,
102
- description: 'How long to show feedback.'
103
- }
104
- }
105
- }
106
-
107
- plugin.trial = function(display_element, trial) {
108
-
109
- display_element.innerHTML = '<img id="jspsych-categorize-image-stimulus" class="jspsych-categorize-image-stimulus" src="'+trial.stimulus+'"></img>';
110
-
111
- // hide image after time if the timing parameter is set
112
- if (trial.stimulus_duration !== null) {
113
- jsPsych.pluginAPI.setTimeout(function() {
114
- display_element.querySelector('#jspsych-categorize-image-stimulus').style.visibility = 'hidden';
115
- }, trial.stimulus_duration);
116
- }
117
-
118
- // if prompt is set, show prompt
119
- if (trial.prompt !== null) {
120
- display_element.innerHTML += trial.prompt;
121
- }
122
-
123
- var trial_data = {};
124
-
125
- // create response function
126
- var after_response = function(info) {
127
-
128
- // kill any remaining setTimeout handlers
129
- jsPsych.pluginAPI.clearAllTimeouts();
130
-
131
- // clear keyboard listener
132
- jsPsych.pluginAPI.cancelAllKeyboardResponses();
133
-
134
- var correct = false;
135
- if (trial.key_answer == info.key) {
136
- correct = true;
137
- }
138
-
139
- // save data
140
- trial_data = {
141
- "rt": info.rt,
142
- "correct": correct,
143
- "stimulus": trial.stimulus,
144
- "key_press": info.key
145
- };
146
-
147
- display_element.innerHTML = '';
148
-
149
- var timeout = info.rt == null;
150
- doFeedback(correct, timeout);
151
- }
152
-
153
- jsPsych.pluginAPI.getKeyboardResponse({
154
- callback_function: after_response,
155
- valid_responses: trial.choices,
156
- rt_method: 'performance',
157
- persist: false,
158
- allow_held_key: false
159
- });
160
-
161
- if (trial.trial_duration !== null) {
162
- jsPsych.pluginAPI.setTimeout(function() {
163
- after_response({
164
- key: null,
165
- rt: null
166
- });
167
- }, trial.trial_duration);
168
- }
169
-
170
- function doFeedback(correct, timeout) {
171
-
172
- if (timeout && !trial.show_feedback_on_timeout) {
173
- display_element.innerHTML += trial.timeout_message;
174
- } else {
175
- // show image during feedback if flag is set
176
- if (trial.show_stim_with_feedback) {
177
- display_element.innerHTML = '<img id="jspsych-categorize-image-stimulus" class="jspsych-categorize-image-stimulus" src="'+trial.stimulus+'"></img>';
178
- }
179
-
180
- // substitute answer in feedback string.
181
- var atext = "";
182
- if (correct) {
183
- atext = trial.correct_text.replace("%ANS%", trial.text_answer);
184
- } else {
185
- atext = trial.incorrect_text.replace("%ANS%", trial.text_answer);
186
- }
187
-
188
- // show the feedback
189
- display_element.innerHTML += atext;
190
- }
191
- // check if force correct button press is set
192
- if (trial.force_correct_button_press && correct === false && ((timeout && trial.show_feedback_on_timeout) || !timeout)) {
193
-
194
- var after_forced_response = function(info) {
195
- endTrial();
196
- }
197
-
198
- jsPsych.pluginAPI.getKeyboardResponse({
199
- callback_function: after_forced_response,
200
- valid_responses: [trial.key_answer],
201
- rt_method: 'performance',
202
- persist: false,
203
- allow_held_key: false
204
- });
205
-
206
- } else {
207
- jsPsych.pluginAPI.setTimeout(function() {
208
- endTrial();
209
- }, trial.feedback_duration);
210
- }
211
-
212
- }
213
-
214
- function endTrial() {
215
- display_element.innerHTML = '';
216
- jsPsych.finishTrial(trial_data);
217
- }
218
-
219
- };
220
-
221
- return plugin;
222
- })();