jspsych 6.3.1 → 7.1.2

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 (401) hide show
  1. package/README.md +36 -37
  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 +3171 -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 +3165 -0
  10. package/dist/index.cjs.map +1 -0
  11. package/dist/index.d.ts +11 -0
  12. package/dist/index.js +3159 -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 +136 -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 +165 -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 -719
  59. package/docs/core_library/jspsych-data.md +0 -587
  60. package/docs/core_library/jspsych-pluginAPI.md +0 -624
  61. package/docs/core_library/jspsych-randomization.md +0 -389
  62. package/docs/core_library/jspsych-turk.md +0 -98
  63. package/docs/extensions/extensions.md +0 -83
  64. package/docs/extensions/jspsych-ext-webgazer.md +0 -137
  65. package/docs/img/blue.png +0 -0
  66. package/docs/img/devtools-change-css.png +0 -0
  67. package/docs/img/devtools-css-errors.png +0 -0
  68. package/docs/img/devtools-inspect-element.png +0 -0
  69. package/docs/img/folder-setup.png +0 -0
  70. package/docs/img/folder-with-html.png +0 -0
  71. package/docs/img/githubreleases.jpg +0 -0
  72. package/docs/img/jspsych-favicon.png +0 -0
  73. package/docs/img/jspsych-logo-no-text-mono.svg +0 -493
  74. package/docs/img/jspsych-logo.jpg +0 -0
  75. package/docs/img/orange.png +0 -0
  76. package/docs/img/palmer_stim.png +0 -0
  77. package/docs/img/progress_bar.png +0 -0
  78. package/docs/img/prolific-study-completion.png +0 -0
  79. package/docs/img/prolific-study-link.png +0 -0
  80. package/docs/img/visual_search_example.jpg +0 -0
  81. package/docs/index.md +0 -9
  82. package/docs/overview/browser-device-support.md +0 -35
  83. package/docs/overview/callbacks.md +0 -180
  84. package/docs/overview/data.md +0 -281
  85. package/docs/overview/dynamic-parameters.md +0 -147
  86. package/docs/overview/exclude-browser.md +0 -32
  87. package/docs/overview/experiment-options.md +0 -149
  88. package/docs/overview/eye-tracking.md +0 -271
  89. package/docs/overview/fullscreen.md +0 -36
  90. package/docs/overview/media-preloading.md +0 -369
  91. package/docs/overview/mturk.md +0 -77
  92. package/docs/overview/plugins.md +0 -320
  93. package/docs/overview/progress-bar.md +0 -110
  94. package/docs/overview/prolific.md +0 -78
  95. package/docs/overview/record-browser-interactions.md +0 -23
  96. package/docs/overview/running-experiments.md +0 -95
  97. package/docs/overview/style.md +0 -293
  98. package/docs/overview/timeline.md +0 -457
  99. package/docs/plugins/jspsych-animation.md +0 -40
  100. package/docs/plugins/jspsych-audio-button-response.md +0 -60
  101. package/docs/plugins/jspsych-audio-keyboard-response.md +0 -58
  102. package/docs/plugins/jspsych-audio-slider-response.md +0 -53
  103. package/docs/plugins/jspsych-call-function.md +0 -81
  104. package/docs/plugins/jspsych-canvas-button-response.md +0 -66
  105. package/docs/plugins/jspsych-canvas-keyboard-response.md +0 -68
  106. package/docs/plugins/jspsych-canvas-slider-response.md +0 -89
  107. package/docs/plugins/jspsych-categorize-animation.md +0 -60
  108. package/docs/plugins/jspsych-categorize-html.md +0 -53
  109. package/docs/plugins/jspsych-categorize-image.md +0 -53
  110. package/docs/plugins/jspsych-cloze.md +0 -45
  111. package/docs/plugins/jspsych-external-html.md +0 -70
  112. package/docs/plugins/jspsych-free-sort.md +0 -56
  113. package/docs/plugins/jspsych-fullscreen.md +0 -57
  114. package/docs/plugins/jspsych-html-button-response.md +0 -42
  115. package/docs/plugins/jspsych-html-keyboard-response.md +0 -51
  116. package/docs/plugins/jspsych-html-slider-response.md +0 -45
  117. package/docs/plugins/jspsych-iat-html.md +0 -64
  118. package/docs/plugins/jspsych-iat-image.md +0 -64
  119. package/docs/plugins/jspsych-image-button-response.md +0 -48
  120. package/docs/plugins/jspsych-image-keyboard-response.md +0 -58
  121. package/docs/plugins/jspsych-image-slider-response.md +0 -54
  122. package/docs/plugins/jspsych-instructions.md +0 -58
  123. package/docs/plugins/jspsych-maxdiff.md +0 -41
  124. package/docs/plugins/jspsych-preload.md +0 -128
  125. package/docs/plugins/jspsych-rdk.md +0 -119
  126. package/docs/plugins/jspsych-reconstruction.md +0 -48
  127. package/docs/plugins/jspsych-resize.md +0 -39
  128. package/docs/plugins/jspsych-same-different-html.md +0 -53
  129. package/docs/plugins/jspsych-same-different-image.md +0 -66
  130. package/docs/plugins/jspsych-serial-reaction-time-mouse.md +0 -52
  131. package/docs/plugins/jspsych-serial-reaction-time.md +0 -57
  132. package/docs/plugins/jspsych-survey-html-form.md +0 -50
  133. package/docs/plugins/jspsych-survey-likert.md +0 -70
  134. package/docs/plugins/jspsych-survey-multi-choice.md +0 -48
  135. package/docs/plugins/jspsych-survey-multi-select.md +0 -53
  136. package/docs/plugins/jspsych-survey-text.md +0 -63
  137. package/docs/plugins/jspsych-video-button-response.md +0 -54
  138. package/docs/plugins/jspsych-video-keyboard-response.md +0 -50
  139. package/docs/plugins/jspsych-video-slider-response.md +0 -60
  140. package/docs/plugins/jspsych-virtual-chinrest.md +0 -105
  141. package/docs/plugins/jspsych-visual-search-circle.md +0 -52
  142. package/docs/plugins/jspsych-vsl-animate-occlusion.md +0 -55
  143. package/docs/plugins/jspsych-vsl-grid-scene.md +0 -62
  144. package/docs/plugins/jspsych-webgazer-calibrate.md +0 -61
  145. package/docs/plugins/jspsych-webgazer-init-camera.md +0 -30
  146. package/docs/plugins/jspsych-webgazer-validate.md +0 -44
  147. package/docs/plugins/list-of-plugins.md +0 -54
  148. package/docs/tutorials/hello-world.md +0 -162
  149. package/docs/tutorials/rt-task.md +0 -1334
  150. package/docs/tutorials/video-tutorials.md +0 -11
  151. package/examples/add-to-end-of-timeline.html +0 -38
  152. package/examples/case-sensitive-responses.html +0 -45
  153. package/examples/conditional-and-loop-functions.html +0 -64
  154. package/examples/css/jquery-ui.css +0 -1225
  155. package/examples/css-classes-parameter.html +0 -145
  156. package/examples/data-add-properties.html +0 -44
  157. package/examples/data-as-function.html +0 -39
  158. package/examples/data-from-timeline.html +0 -52
  159. package/examples/data-from-url.html +0 -21
  160. package/examples/demo-flanker.html +0 -117
  161. package/examples/demo-simple-rt-task.html +0 -120
  162. package/examples/demos/demo_1.html +0 -35
  163. package/examples/demos/demo_2.html +0 -50
  164. package/examples/demos/demo_3.html +0 -63
  165. package/examples/display-element-to-embed-experiment.html +0 -79
  166. package/examples/end-active-node.html +0 -52
  167. package/examples/end-experiment.html +0 -45
  168. package/examples/exclusions.html +0 -32
  169. package/examples/external_html/simple_consent.html +0 -4
  170. package/examples/img/1.gif +0 -0
  171. package/examples/img/10.gif +0 -0
  172. package/examples/img/11.gif +0 -0
  173. package/examples/img/12.gif +0 -0
  174. package/examples/img/2.gif +0 -0
  175. package/examples/img/3.gif +0 -0
  176. package/examples/img/4.gif +0 -0
  177. package/examples/img/5.gif +0 -0
  178. package/examples/img/6.gif +0 -0
  179. package/examples/img/7.gif +0 -0
  180. package/examples/img/8.gif +0 -0
  181. package/examples/img/9.gif +0 -0
  182. package/examples/img/age/of1.jpg +0 -0
  183. package/examples/img/age/of2.jpg +0 -0
  184. package/examples/img/age/of3.jpg +0 -0
  185. package/examples/img/age/om1.jpg +0 -0
  186. package/examples/img/age/om2.jpg +0 -0
  187. package/examples/img/age/om3.jpg +0 -0
  188. package/examples/img/age/yf1.jpg +0 -0
  189. package/examples/img/age/yf4.jpg +0 -0
  190. package/examples/img/age/yf5.jpg +0 -0
  191. package/examples/img/age/ym2.jpg +0 -0
  192. package/examples/img/age/ym3.jpg +0 -0
  193. package/examples/img/age/ym5.jpg +0 -0
  194. package/examples/img/backwardN.gif +0 -0
  195. package/examples/img/blue.png +0 -0
  196. package/examples/img/card.png +0 -0
  197. package/examples/img/con1.png +0 -0
  198. package/examples/img/con2.png +0 -0
  199. package/examples/img/fixation.gif +0 -0
  200. package/examples/img/happy_face_1.jpg +0 -0
  201. package/examples/img/happy_face_2.jpg +0 -0
  202. package/examples/img/happy_face_3.jpg +0 -0
  203. package/examples/img/happy_face_4.jpg +0 -0
  204. package/examples/img/inc1.png +0 -0
  205. package/examples/img/inc2.png +0 -0
  206. package/examples/img/normalN.gif +0 -0
  207. package/examples/img/orange.png +0 -0
  208. package/examples/img/redX.png +0 -0
  209. package/examples/img/ribbon.jpg +0 -0
  210. package/examples/img/sad_face_1.jpg +0 -0
  211. package/examples/img/sad_face_2.jpg +0 -0
  212. package/examples/img/sad_face_3.jpg +0 -0
  213. package/examples/img/sad_face_4.jpg +0 -0
  214. package/examples/js/snap.svg-min.js +0 -21
  215. package/examples/js/webgazer/ridgeWorker.mjs +0 -135
  216. package/examples/js/webgazer/webgazer.js +0 -88909
  217. package/examples/js/webgazer/worker_scripts/mat.js +0 -306
  218. package/examples/js/webgazer/worker_scripts/util.js +0 -398
  219. package/examples/jspsych-RDK.html +0 -58
  220. package/examples/jspsych-animation.html +0 -39
  221. package/examples/jspsych-audio-button-response.html +0 -58
  222. package/examples/jspsych-audio-keyboard-response.html +0 -68
  223. package/examples/jspsych-audio-slider-response.html +0 -61
  224. package/examples/jspsych-call-function.html +0 -32
  225. package/examples/jspsych-canvas-button-response.html +0 -95
  226. package/examples/jspsych-canvas-keyboard-response.html +0 -78
  227. package/examples/jspsych-canvas-slider-response.html +0 -67
  228. package/examples/jspsych-categorize-animation.html +0 -49
  229. package/examples/jspsych-categorize-html.html +0 -33
  230. package/examples/jspsych-categorize-image.html +0 -44
  231. package/examples/jspsych-cloze.html +0 -37
  232. package/examples/jspsych-free-sort.html +0 -109
  233. package/examples/jspsych-fullscreen.html +0 -45
  234. package/examples/jspsych-html-button-response.html +0 -43
  235. package/examples/jspsych-html-keyboard-response.html +0 -42
  236. package/examples/jspsych-html-slider-response.html +0 -53
  237. package/examples/jspsych-iat.html +0 -520
  238. package/examples/jspsych-image-button-response.html +0 -91
  239. package/examples/jspsych-image-keyboard-response.html +0 -85
  240. package/examples/jspsych-image-slider-response.html +0 -85
  241. package/examples/jspsych-instructions.html +0 -37
  242. package/examples/jspsych-maxdiff.html +0 -33
  243. package/examples/jspsych-preload.html +0 -140
  244. package/examples/jspsych-reconstruction.html +0 -43
  245. package/examples/jspsych-resize.html +0 -34
  246. package/examples/jspsych-same-different-html.html +0 -28
  247. package/examples/jspsych-same-different-image.html +0 -39
  248. package/examples/jspsych-serial-reaction-time-mouse.html +0 -98
  249. package/examples/jspsych-serial-reaction-time.html +0 -54
  250. package/examples/jspsych-survey-html-form.html +0 -33
  251. package/examples/jspsych-survey-likert.html +0 -42
  252. package/examples/jspsych-survey-multi-choice.html +0 -40
  253. package/examples/jspsych-survey-multi-select.html +0 -42
  254. package/examples/jspsych-survey-text.html +0 -34
  255. package/examples/jspsych-video-button-response.html +0 -65
  256. package/examples/jspsych-video-keyboard-response.html +0 -61
  257. package/examples/jspsych-video-slider-response.html +0 -63
  258. package/examples/jspsych-virtual-chinrest.html +0 -69
  259. package/examples/jspsych-visual-search-circle.html +0 -64
  260. package/examples/jspsych-vsl-animate-occlusion.html +0 -35
  261. package/examples/jspsych-vsl-grid-scene.html +0 -47
  262. package/examples/lexical-decision.html +0 -134
  263. package/examples/manual-preloading.html +0 -59
  264. package/examples/pause-unpause.html +0 -33
  265. package/examples/progress-bar.html +0 -68
  266. package/examples/save-trial-parameters.html +0 -98
  267. package/examples/sound/hammer.mp3 +0 -0
  268. package/examples/sound/sound.mp3 +0 -0
  269. package/examples/sound/speech_blue.mp3 +0 -0
  270. package/examples/sound/speech_green.mp3 +0 -0
  271. package/examples/sound/speech_joke.mp3 +0 -0
  272. package/examples/sound/speech_red.mp3 +0 -0
  273. package/examples/sound/tone.mp3 +0 -0
  274. package/examples/timeline-variables-sampling.html +0 -50
  275. package/examples/timeline-variables.html +0 -64
  276. package/examples/video/sample_video.mp4 +0 -0
  277. package/examples/webgazer.html +0 -174
  278. package/examples/webgazer_audio.html +0 -90
  279. package/examples/webgazer_image.html +0 -60
  280. package/extensions/jspsych-ext-webgazer.js +0 -265
  281. package/jspsych.js +0 -3023
  282. package/license.txt +0 -21
  283. package/mkdocs.yml +0 -118
  284. package/plugins/jspsych-animation.js +0 -189
  285. package/plugins/jspsych-audio-button-response.js +0 -269
  286. package/plugins/jspsych-audio-keyboard-response.js +0 -209
  287. package/plugins/jspsych-audio-slider-response.js +0 -278
  288. package/plugins/jspsych-call-function.js +0 -58
  289. package/plugins/jspsych-canvas-button-response.js +0 -199
  290. package/plugins/jspsych-canvas-keyboard-response.js +0 -155
  291. package/plugins/jspsych-canvas-slider-response.js +0 -207
  292. package/plugins/jspsych-categorize-animation.js +0 -266
  293. package/plugins/jspsych-categorize-html.js +0 -220
  294. package/plugins/jspsych-categorize-image.js +0 -222
  295. package/plugins/jspsych-cloze.js +0 -112
  296. package/plugins/jspsych-external-html.js +0 -112
  297. package/plugins/jspsych-free-sort.js +0 -478
  298. package/plugins/jspsych-fullscreen.js +0 -106
  299. package/plugins/jspsych-html-button-response.js +0 -188
  300. package/plugins/jspsych-html-keyboard-response.js +0 -149
  301. package/plugins/jspsych-html-slider-response.js +0 -202
  302. package/plugins/jspsych-iat-html.js +0 -284
  303. package/plugins/jspsych-iat-image.js +0 -286
  304. package/plugins/jspsych-image-button-response.js +0 -327
  305. package/plugins/jspsych-image-keyboard-response.js +0 -263
  306. package/plugins/jspsych-image-slider-response.js +0 -369
  307. package/plugins/jspsych-instructions.js +0 -237
  308. package/plugins/jspsych-maxdiff.js +0 -173
  309. package/plugins/jspsych-preload.js +0 -345
  310. package/plugins/jspsych-rdk.js +0 -1373
  311. package/plugins/jspsych-reconstruction.js +0 -134
  312. package/plugins/jspsych-resize.js +0 -166
  313. package/plugins/jspsych-same-different-html.js +0 -168
  314. package/plugins/jspsych-same-different-image.js +0 -169
  315. package/plugins/jspsych-serial-reaction-time-mouse.js +0 -212
  316. package/plugins/jspsych-serial-reaction-time.js +0 -247
  317. package/plugins/jspsych-survey-html-form.js +0 -171
  318. package/plugins/jspsych-survey-likert.js +0 -195
  319. package/plugins/jspsych-survey-multi-choice.js +0 -208
  320. package/plugins/jspsych-survey-multi-select.js +0 -232
  321. package/plugins/jspsych-survey-text.js +0 -185
  322. package/plugins/jspsych-video-button-response.js +0 -335
  323. package/plugins/jspsych-video-keyboard-response.js +0 -279
  324. package/plugins/jspsych-video-slider-response.js +0 -351
  325. package/plugins/jspsych-virtual-chinrest.js +0 -471
  326. package/plugins/jspsych-visual-search-circle.js +0 -259
  327. package/plugins/jspsych-vsl-animate-occlusion.js +0 -196
  328. package/plugins/jspsych-vsl-grid-scene.js +0 -103
  329. package/plugins/jspsych-webgazer-calibrate.js +0 -161
  330. package/plugins/jspsych-webgazer-init-camera.js +0 -139
  331. package/plugins/jspsych-webgazer-validate.js +0 -314
  332. package/plugins/template/jspsych-plugin-template.js +0 -35
  333. package/tests/README.md +0 -7
  334. package/tests/jsPsych/case-sensitive-responses.test.js +0 -53
  335. package/tests/jsPsych/css-classes-parameter.test.js +0 -107
  336. package/tests/jsPsych/default-iti.test.js +0 -51
  337. package/tests/jsPsych/default-parameters.test.js +0 -58
  338. package/tests/jsPsych/endexperiment.test.js +0 -49
  339. package/tests/jsPsych/events.test.js +0 -606
  340. package/tests/jsPsych/functions-as-parameters.test.js +0 -210
  341. package/tests/jsPsych/init.test.js +0 -48
  342. package/tests/jsPsych/loads.test.js +0 -7
  343. package/tests/jsPsych/min-rt.test.js +0 -58
  344. package/tests/jsPsych/progressbar.test.js +0 -202
  345. package/tests/jsPsych/timeline-variables.test.js +0 -531
  346. package/tests/jsPsych/timelines.test.js +0 -569
  347. package/tests/jsPsych.data/data-csv-conversion.test.js +0 -85
  348. package/tests/jsPsych.data/data-json-conversion.test.js +0 -120
  349. package/tests/jsPsych.data/datacollection.test.js +0 -117
  350. package/tests/jsPsych.data/datacolumn.test.js +0 -50
  351. package/tests/jsPsych.data/datamodule.test.js +0 -152
  352. package/tests/jsPsych.data/dataparameter.test.js +0 -251
  353. package/tests/jsPsych.data/interactions.test.js +0 -109
  354. package/tests/jsPsych.data/trialparameters.test.js +0 -175
  355. package/tests/jsPsych.extensions/extensions.test.js +0 -207
  356. package/tests/jsPsych.extensions/test-extension.js +0 -42
  357. package/tests/jsPsych.pluginAPI/pluginapi.test.js +0 -365
  358. package/tests/jsPsych.pluginAPI/preloads.test.js +0 -43
  359. package/tests/jsPsych.randomization/randomziation.test.js +0 -27
  360. package/tests/jsPsych.utils/utils.test.js +0 -58
  361. package/tests/plugins/plugin-animation.test.js +0 -34
  362. package/tests/plugins/plugin-audio-button-response.test.js +0 -15
  363. package/tests/plugins/plugin-audio-keyboard-response.test.js +0 -15
  364. package/tests/plugins/plugin-audio-slider-response.test.js +0 -15
  365. package/tests/plugins/plugin-call-function.test.js +0 -49
  366. package/tests/plugins/plugin-categorize-animation.test.js +0 -263
  367. package/tests/plugins/plugin-categorize-html.test.js +0 -17
  368. package/tests/plugins/plugin-categorize-image.test.js +0 -17
  369. package/tests/plugins/plugin-cloze.test.js +0 -157
  370. package/tests/plugins/plugin-free-sort.test.js +0 -106
  371. package/tests/plugins/plugin-fullscreen.test.js +0 -41
  372. package/tests/plugins/plugin-html-button-response.test.js +0 -161
  373. package/tests/plugins/plugin-html-keyboard-response.test.js +0 -139
  374. package/tests/plugins/plugin-html-slider-response.test.js +0 -155
  375. package/tests/plugins/plugin-iat-html.test.js +0 -299
  376. package/tests/plugins/plugin-iat-image.test.js +0 -298
  377. package/tests/plugins/plugin-image-button-response.test.js +0 -174
  378. package/tests/plugins/plugin-image-keyboard-response.test.js +0 -147
  379. package/tests/plugins/plugin-image-slider-response.test.js +0 -174
  380. package/tests/plugins/plugin-instructions.test.js +0 -85
  381. package/tests/plugins/plugin-maxdiff.test.js +0 -39
  382. package/tests/plugins/plugin-preload.test.js +0 -916
  383. package/tests/plugins/plugin-rdk.test.js +0 -61
  384. package/tests/plugins/plugin-reconstruction.test.js +0 -16
  385. package/tests/plugins/plugin-resize.test.js +0 -16
  386. package/tests/plugins/plugin-same-different-html.test.js +0 -17
  387. package/tests/plugins/plugin-same-different-image.test.js +0 -17
  388. package/tests/plugins/plugin-serial-reaction-time-mouse.test.js +0 -42
  389. package/tests/plugins/plugin-serial-reaction-time.test.js +0 -109
  390. package/tests/plugins/plugin-survey-html-form.test.js +0 -44
  391. package/tests/plugins/plugin-survey-likert.test.js +0 -48
  392. package/tests/plugins/plugin-survey-multi-choice.test.js +0 -47
  393. package/tests/plugins/plugin-survey-multi-select.test.js +0 -71
  394. package/tests/plugins/plugin-survey-text.test.js +0 -115
  395. package/tests/plugins/plugin-video-button-response.test.js +0 -32
  396. package/tests/plugins/plugin-video-keyboard-response.test.js +0 -32
  397. package/tests/plugins/plugin-video-slider-response.test.js +0 -31
  398. package/tests/plugins/plugin-visual-search-circle.test.js +0 -16
  399. package/tests/plugins/plugin-vsl-animate-occlusion.test.js +0 -16
  400. package/tests/plugins/plugin-vsl-grid-scene.test.js +0 -16
  401. package/tests/testing-utils.js +0 -13
@@ -1,327 +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
- var image_drawn = false;
111
- // first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
112
- if (display_element.hasChildNodes()) {
113
- // can't loop through child list because the list will be modified by .removeChild()
114
- while (display_element.firstChild) {
115
- display_element.removeChild(display_element.firstChild);
116
- }
117
- }
118
- // create canvas element and image
119
- var canvas = document.createElement("canvas");
120
- canvas.id = "jspsych-image-button-response-stimulus";
121
- canvas.style.margin = 0;
122
- canvas.style.padding = 0;
123
- var ctx = canvas.getContext("2d");
124
- var img = new Image();
125
- img.onload = function() {
126
- // if image wasn't preloaded, then it will need to be drawn whenever it finishes loading
127
- if (!image_drawn) {
128
- getHeightWidth(); // only possible to get width/height after image loads
129
- ctx.drawImage(img,0,0,width,height);
130
- }
131
- };
132
- img.src = trial.stimulus;
133
- // get/set image height and width - this can only be done after image loads because uses image's naturalWidth/naturalHeight properties
134
- function getHeightWidth() {
135
- if (trial.stimulus_height !== null) {
136
- height = trial.stimulus_height;
137
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
138
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
139
- }
140
- } else {
141
- height = img.naturalHeight;
142
- }
143
- if (trial.stimulus_width !== null) {
144
- width = trial.stimulus_width;
145
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
146
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
147
- }
148
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
149
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
150
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
151
- width = img.naturalWidth;
152
- }
153
- canvas.height = height;
154
- canvas.width = width;
155
- }
156
- getHeightWidth(); // call now, in case image loads immediately (is cached)
157
- // create buttons
158
- var buttons = [];
159
- if (Array.isArray(trial.button_html)) {
160
- if (trial.button_html.length == trial.choices.length) {
161
- buttons = trial.button_html;
162
- } else {
163
- console.error('Error in image-button-response plugin. The length of the button_html array does not equal the length of the choices array');
164
- }
165
- } else {
166
- for (var i = 0; i < trial.choices.length; i++) {
167
- buttons.push(trial.button_html);
168
- }
169
- }
170
- var btngroup_div = document.createElement('div');
171
- btngroup_div.id = "jspsych-image-button-response-btngroup";
172
- html = '';
173
- for (var i = 0; i < trial.choices.length; i++) {
174
- var str = buttons[i].replace(/%choice%/g, trial.choices[i]);
175
- 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>';
176
- }
177
- btngroup_div.innerHTML = html;
178
- // add canvas to screen and draw image
179
- display_element.insertBefore(canvas, null);
180
- if (img.complete && Number.isFinite(width) && Number.isFinite(height)) {
181
- // if image has loaded and width/height have been set, then draw it now
182
- // (don't rely on img onload function to draw image when image is in the cache, because that causes a delay in the image presentation)
183
- ctx.drawImage(img,0,0,width,height);
184
- image_drawn = true;
185
- }
186
- // add buttons to screen
187
- display_element.insertBefore(btngroup_div, canvas.nextElementSibling);
188
- // add prompt if there is one
189
- if (trial.prompt !== null) {
190
- display_element.insertAdjacentHTML('beforeend', trial.prompt);
191
- }
192
-
193
- } else {
194
-
195
- // display stimulus as an image element
196
- html = '<img src="'+trial.stimulus+'" id="jspsych-image-button-response-stimulus">';
197
- //display buttons
198
- var buttons = [];
199
- if (Array.isArray(trial.button_html)) {
200
- if (trial.button_html.length == trial.choices.length) {
201
- buttons = trial.button_html;
202
- } else {
203
- console.error('Error in image-button-response plugin. The length of the button_html array does not equal the length of the choices array');
204
- }
205
- } else {
206
- for (var i = 0; i < trial.choices.length; i++) {
207
- buttons.push(trial.button_html);
208
- }
209
- }
210
- html += '<div id="jspsych-image-button-response-btngroup">';
211
-
212
- for (var i = 0; i < trial.choices.length; i++) {
213
- var str = buttons[i].replace(/%choice%/g, trial.choices[i]);
214
- 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>';
215
- }
216
- html += '</div>';
217
- // add prompt
218
- if (trial.prompt !== null){
219
- html += trial.prompt;
220
- }
221
- // update the page content
222
- display_element.innerHTML = html;
223
-
224
- // set image dimensions after image has loaded (so that we have access to naturalHeight/naturalWidth)
225
- var img = display_element.querySelector('#jspsych-image-button-response-stimulus');
226
- if (trial.stimulus_height !== null) {
227
- height = trial.stimulus_height;
228
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
229
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
230
- }
231
- } else {
232
- height = img.naturalHeight;
233
- }
234
- if (trial.stimulus_width !== null) {
235
- width = trial.stimulus_width;
236
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
237
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
238
- }
239
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
240
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
241
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
242
- width = img.naturalWidth;
243
- }
244
- img.style.height = height.toString() + "px";
245
- img.style.width = width.toString() + "px";
246
- }
247
-
248
- // start timing
249
- var start_time = performance.now();
250
-
251
- for (var i = 0; i < trial.choices.length; i++) {
252
- display_element.querySelector('#jspsych-image-button-response-button-' + i).addEventListener('click', function(e){
253
- var choice = e.currentTarget.getAttribute('data-choice'); // don't use dataset for jsdom compatibility
254
- after_response(choice);
255
- });
256
- }
257
-
258
- // store response
259
- var response = {
260
- rt: null,
261
- button: null
262
- };
263
-
264
- // function to handle responses by the subject
265
- function after_response(choice) {
266
-
267
- // measure rt
268
- var end_time = performance.now();
269
- var rt = end_time - start_time;
270
- response.button = parseInt(choice);
271
- response.rt = rt;
272
-
273
- // after a valid response, the stimulus will have the CSS class 'responded'
274
- // which can be used to provide visual feedback that a response was recorded
275
- display_element.querySelector('#jspsych-image-button-response-stimulus').className += ' responded';
276
-
277
- // disable all the buttons after a response
278
- var btns = document.querySelectorAll('.jspsych-image-button-response-button button');
279
- for(var i=0; i<btns.length; i++){
280
- //btns[i].removeEventListener('click');
281
- btns[i].setAttribute('disabled', 'disabled');
282
- }
283
-
284
- if (trial.response_ends_trial) {
285
- end_trial();
286
- }
287
- };
288
-
289
- // function to end trial when it is time
290
- function end_trial() {
291
-
292
- // kill any remaining setTimeout handlers
293
- jsPsych.pluginAPI.clearAllTimeouts();
294
-
295
- // gather the data to store for the trial
296
- var trial_data = {
297
- rt: response.rt,
298
- stimulus: trial.stimulus,
299
- response: response.button
300
- };
301
-
302
- // clear the display
303
- display_element.innerHTML = '';
304
-
305
- // move on to the next trial
306
- jsPsych.finishTrial(trial_data);
307
- };
308
-
309
- // hide image if timing is set
310
- if (trial.stimulus_duration !== null) {
311
- jsPsych.pluginAPI.setTimeout(function() {
312
- display_element.querySelector('#jspsych-image-button-response-stimulus').style.visibility = 'hidden';
313
- }, trial.stimulus_duration);
314
- }
315
-
316
- // end trial if time limit is set
317
- if (trial.trial_duration !== null) {
318
- jsPsych.pluginAPI.setTimeout(function() {
319
- end_trial();
320
- }, trial.trial_duration);
321
- } else if (trial.response_ends_trial === false) {
322
- console.warn("The experiment may be deadlocked. Try setting a trial duration or set response_ends_trial to true.");
323
- }
324
- };
325
-
326
- return plugin;
327
- })();
@@ -1,263 +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.KEY,
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
- var image_drawn = false;
92
- // first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
93
- if (display_element.hasChildNodes()) {
94
- // can't loop through child list because the list will be modified by .removeChild()
95
- while (display_element.firstChild) {
96
- display_element.removeChild(display_element.firstChild);
97
- }
98
- }
99
- // create canvas element and image
100
- var canvas = document.createElement("canvas");
101
- canvas.id = "jspsych-image-keyboard-response-stimulus";
102
- canvas.style.margin = 0;
103
- canvas.style.padding = 0;
104
- var ctx = canvas.getContext("2d");
105
- var img = new Image();
106
- img.onload = function() {
107
- // if image wasn't preloaded, then it will need to be drawn whenever it finishes loading
108
- if (!image_drawn) {
109
- getHeightWidth(); // only possible to get width/height after image loads
110
- ctx.drawImage(img,0,0,width,height);
111
- }
112
- };
113
- img.src = trial.stimulus;
114
- // get/set image height and width - this can only be done after image loads because uses image's naturalWidth/naturalHeight properties
115
- function getHeightWidth() {
116
- if (trial.stimulus_height !== null) {
117
- height = trial.stimulus_height;
118
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
119
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
120
- }
121
- } else {
122
- height = img.naturalHeight;
123
- }
124
- if (trial.stimulus_width !== null) {
125
- width = trial.stimulus_width;
126
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
127
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
128
- }
129
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
130
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
131
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
132
- width = img.naturalWidth;
133
- }
134
- canvas.height = height;
135
- canvas.width = width;
136
- }
137
- getHeightWidth(); // call now, in case image loads immediately (is cached)
138
- // add canvas and draw image
139
- display_element.insertBefore(canvas, null);
140
- if (img.complete && Number.isFinite(width) && Number.isFinite(height)) {
141
- // if image has loaded and width/height have been set, then draw it now
142
- // (don't rely on img onload function to draw image when image is in the cache, because that causes a delay in the image presentation)
143
- ctx.drawImage(img,0,0,width,height);
144
- image_drawn = true;
145
- }
146
- // add prompt if there is one
147
- if (trial.prompt !== null) {
148
- display_element.insertAdjacentHTML('beforeend', trial.prompt);
149
- }
150
-
151
- } else {
152
-
153
- // display stimulus as an image element
154
- var html = '<img src="'+trial.stimulus+'" id="jspsych-image-keyboard-response-stimulus">';
155
- // add prompt
156
- if (trial.prompt !== null){
157
- html += trial.prompt;
158
- }
159
- // update the page content
160
- display_element.innerHTML = html;
161
-
162
- // set image dimensions after image has loaded (so that we have access to naturalHeight/naturalWidth)
163
- var img = display_element.querySelector('#jspsych-image-keyboard-response-stimulus');
164
- if (trial.stimulus_height !== null) {
165
- height = trial.stimulus_height;
166
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
167
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
168
- }
169
- } else {
170
- height = img.naturalHeight;
171
- }
172
- if (trial.stimulus_width !== null) {
173
- width = trial.stimulus_width;
174
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
175
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
176
- }
177
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
178
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
179
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
180
- width = img.naturalWidth;
181
- }
182
- img.style.height = height.toString() + "px";
183
- img.style.width = width.toString() + "px";
184
- }
185
-
186
- // store response
187
- var response = {
188
- rt: null,
189
- key: null
190
- };
191
-
192
- // function to end trial when it is time
193
- var end_trial = function() {
194
-
195
- // kill any remaining setTimeout handlers
196
- jsPsych.pluginAPI.clearAllTimeouts();
197
-
198
- // kill keyboard listeners
199
- if (typeof keyboardListener !== 'undefined') {
200
- jsPsych.pluginAPI.cancelKeyboardResponse(keyboardListener);
201
- }
202
-
203
- // gather the data to store for the trial
204
- var trial_data = {
205
- rt: response.rt,
206
- stimulus: trial.stimulus,
207
- response: response.key
208
- };
209
-
210
- // clear the display
211
- display_element.innerHTML = '';
212
-
213
- // move on to the next trial
214
- jsPsych.finishTrial(trial_data);
215
- };
216
-
217
- // function to handle responses by the subject
218
- var after_response = function(info) {
219
-
220
- // after a valid response, the stimulus will have the CSS class 'responded'
221
- // which can be used to provide visual feedback that a response was recorded
222
- display_element.querySelector('#jspsych-image-keyboard-response-stimulus').className += ' responded';
223
-
224
- // only record the first response
225
- if (response.key == null) {
226
- response = info;
227
- }
228
-
229
- if (trial.response_ends_trial) {
230
- end_trial();
231
- }
232
- };
233
-
234
- // start the response listener
235
- if (trial.choices != jsPsych.NO_KEYS) {
236
- var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
237
- callback_function: after_response,
238
- valid_responses: trial.choices,
239
- rt_method: 'performance',
240
- persist: false,
241
- allow_held_key: false
242
- });
243
- }
244
-
245
- // hide stimulus if stimulus_duration is set
246
- if (trial.stimulus_duration !== null) {
247
- jsPsych.pluginAPI.setTimeout(function() {
248
- display_element.querySelector('#jspsych-image-keyboard-response-stimulus').style.visibility = 'hidden';
249
- }, trial.stimulus_duration);
250
- }
251
-
252
- // end trial if trial_duration is set
253
- if (trial.trial_duration !== null) {
254
- jsPsych.pluginAPI.setTimeout(function() {
255
- end_trial();
256
- }, trial.trial_duration);
257
- } else if (trial.response_ends_trial === false) {
258
- console.warn("The experiment may be deadlocked. Try setting a trial duration or set response_ends_trial to true.");
259
- }
260
- };
261
-
262
- return plugin;
263
- })();