jspsych 6.3.0 → 7.1.1

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 (397) 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 +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 -734
  59. package/docs/core_library/jspsych-data.md +0 -589
  60. package/docs/core_library/jspsych-pluginAPI.md +0 -610
  61. package/docs/core_library/jspsych-randomization.md +0 -397
  62. package/docs/core_library/jspsych-turk.md +0 -102
  63. package/docs/extensions/extensions.md +0 -83
  64. package/docs/extensions/jspsych-ext-webgazer.md +0 -106
  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 -184
  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 -237
  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 -60
  145. package/docs/plugins/jspsych-webgazer-init-camera.md +0 -31
  146. package/docs/plugins/jspsych-webgazer-validate.md +0 -43
  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.js +0 -88886
  216. package/examples/jspsych-RDK.html +0 -58
  217. package/examples/jspsych-animation.html +0 -39
  218. package/examples/jspsych-audio-button-response.html +0 -58
  219. package/examples/jspsych-audio-keyboard-response.html +0 -68
  220. package/examples/jspsych-audio-slider-response.html +0 -61
  221. package/examples/jspsych-call-function.html +0 -32
  222. package/examples/jspsych-canvas-button-response.html +0 -95
  223. package/examples/jspsych-canvas-keyboard-response.html +0 -78
  224. package/examples/jspsych-canvas-slider-response.html +0 -67
  225. package/examples/jspsych-categorize-animation.html +0 -49
  226. package/examples/jspsych-categorize-html.html +0 -33
  227. package/examples/jspsych-categorize-image.html +0 -44
  228. package/examples/jspsych-cloze.html +0 -37
  229. package/examples/jspsych-free-sort.html +0 -109
  230. package/examples/jspsych-fullscreen.html +0 -45
  231. package/examples/jspsych-html-button-response.html +0 -43
  232. package/examples/jspsych-html-keyboard-response.html +0 -42
  233. package/examples/jspsych-html-slider-response.html +0 -53
  234. package/examples/jspsych-iat.html +0 -520
  235. package/examples/jspsych-image-button-response.html +0 -91
  236. package/examples/jspsych-image-keyboard-response.html +0 -85
  237. package/examples/jspsych-image-slider-response.html +0 -85
  238. package/examples/jspsych-instructions.html +0 -37
  239. package/examples/jspsych-maxdiff.html +0 -33
  240. package/examples/jspsych-preload.html +0 -140
  241. package/examples/jspsych-reconstruction.html +0 -43
  242. package/examples/jspsych-resize.html +0 -34
  243. package/examples/jspsych-same-different-html.html +0 -28
  244. package/examples/jspsych-same-different-image.html +0 -39
  245. package/examples/jspsych-serial-reaction-time-mouse.html +0 -98
  246. package/examples/jspsych-serial-reaction-time.html +0 -54
  247. package/examples/jspsych-survey-html-form.html +0 -33
  248. package/examples/jspsych-survey-likert.html +0 -42
  249. package/examples/jspsych-survey-multi-choice.html +0 -40
  250. package/examples/jspsych-survey-multi-select.html +0 -42
  251. package/examples/jspsych-survey-text.html +0 -34
  252. package/examples/jspsych-video-button-response.html +0 -65
  253. package/examples/jspsych-video-keyboard-response.html +0 -61
  254. package/examples/jspsych-video-slider-response.html +0 -63
  255. package/examples/jspsych-virtual-chinrest.html +0 -69
  256. package/examples/jspsych-visual-search-circle.html +0 -64
  257. package/examples/jspsych-vsl-animate-occlusion.html +0 -35
  258. package/examples/jspsych-vsl-grid-scene.html +0 -47
  259. package/examples/lexical-decision.html +0 -134
  260. package/examples/manual-preloading.html +0 -59
  261. package/examples/pause-unpause.html +0 -33
  262. package/examples/progress-bar.html +0 -68
  263. package/examples/save-trial-parameters.html +0 -98
  264. package/examples/sound/hammer.mp3 +0 -0
  265. package/examples/sound/sound.mp3 +0 -0
  266. package/examples/sound/speech_blue.mp3 +0 -0
  267. package/examples/sound/speech_green.mp3 +0 -0
  268. package/examples/sound/speech_joke.mp3 +0 -0
  269. package/examples/sound/speech_red.mp3 +0 -0
  270. package/examples/sound/tone.mp3 +0 -0
  271. package/examples/timeline-variables-sampling.html +0 -50
  272. package/examples/timeline-variables.html +0 -64
  273. package/examples/video/sample_video.mp4 +0 -0
  274. package/examples/webgazer.html +0 -162
  275. package/examples/webgazer_image.html +0 -60
  276. package/extensions/jspsych-ext-webgazer.js +0 -185
  277. package/jspsych.js +0 -3015
  278. package/license.txt +0 -21
  279. package/mkdocs.yml +0 -118
  280. package/plugins/jspsych-animation.js +0 -189
  281. package/plugins/jspsych-audio-button-response.js +0 -269
  282. package/plugins/jspsych-audio-keyboard-response.js +0 -212
  283. package/plugins/jspsych-audio-slider-response.js +0 -278
  284. package/plugins/jspsych-call-function.js +0 -58
  285. package/plugins/jspsych-canvas-button-response.js +0 -199
  286. package/plugins/jspsych-canvas-keyboard-response.js +0 -155
  287. package/plugins/jspsych-canvas-slider-response.js +0 -207
  288. package/plugins/jspsych-categorize-animation.js +0 -266
  289. package/plugins/jspsych-categorize-html.js +0 -220
  290. package/plugins/jspsych-categorize-image.js +0 -222
  291. package/plugins/jspsych-cloze.js +0 -112
  292. package/plugins/jspsych-external-html.js +0 -112
  293. package/plugins/jspsych-free-sort.js +0 -478
  294. package/plugins/jspsych-fullscreen.js +0 -106
  295. package/plugins/jspsych-html-button-response.js +0 -188
  296. package/plugins/jspsych-html-keyboard-response.js +0 -149
  297. package/plugins/jspsych-html-slider-response.js +0 -202
  298. package/plugins/jspsych-iat-html.js +0 -284
  299. package/plugins/jspsych-iat-image.js +0 -286
  300. package/plugins/jspsych-image-button-response.js +0 -327
  301. package/plugins/jspsych-image-keyboard-response.js +0 -263
  302. package/plugins/jspsych-image-slider-response.js +0 -369
  303. package/plugins/jspsych-instructions.js +0 -237
  304. package/plugins/jspsych-maxdiff.js +0 -173
  305. package/plugins/jspsych-preload.js +0 -345
  306. package/plugins/jspsych-rdk.js +0 -1373
  307. package/plugins/jspsych-reconstruction.js +0 -134
  308. package/plugins/jspsych-resize.js +0 -166
  309. package/plugins/jspsych-same-different-html.js +0 -168
  310. package/plugins/jspsych-same-different-image.js +0 -169
  311. package/plugins/jspsych-serial-reaction-time-mouse.js +0 -212
  312. package/plugins/jspsych-serial-reaction-time.js +0 -247
  313. package/plugins/jspsych-survey-html-form.js +0 -171
  314. package/plugins/jspsych-survey-likert.js +0 -195
  315. package/plugins/jspsych-survey-multi-choice.js +0 -208
  316. package/plugins/jspsych-survey-multi-select.js +0 -232
  317. package/plugins/jspsych-survey-text.js +0 -185
  318. package/plugins/jspsych-video-button-response.js +0 -335
  319. package/plugins/jspsych-video-keyboard-response.js +0 -279
  320. package/plugins/jspsych-video-slider-response.js +0 -351
  321. package/plugins/jspsych-virtual-chinrest.js +0 -471
  322. package/plugins/jspsych-visual-search-circle.js +0 -259
  323. package/plugins/jspsych-vsl-animate-occlusion.js +0 -196
  324. package/plugins/jspsych-vsl-grid-scene.js +0 -103
  325. package/plugins/jspsych-webgazer-calibrate.js +0 -166
  326. package/plugins/jspsych-webgazer-init-camera.js +0 -95
  327. package/plugins/jspsych-webgazer-validate.js +0 -304
  328. package/plugins/template/jspsych-plugin-template.js +0 -35
  329. package/tests/README.md +0 -7
  330. package/tests/jsPsych/case-sensitive-responses.test.js +0 -53
  331. package/tests/jsPsych/css-classes-parameter.test.js +0 -107
  332. package/tests/jsPsych/default-iti.test.js +0 -51
  333. package/tests/jsPsych/default-parameters.test.js +0 -58
  334. package/tests/jsPsych/endexperiment.test.js +0 -49
  335. package/tests/jsPsych/events.test.js +0 -606
  336. package/tests/jsPsych/functions-as-parameters.test.js +0 -210
  337. package/tests/jsPsych/init.test.js +0 -48
  338. package/tests/jsPsych/loads.test.js +0 -7
  339. package/tests/jsPsych/min-rt.test.js +0 -58
  340. package/tests/jsPsych/progressbar.test.js +0 -202
  341. package/tests/jsPsych/timeline-variables.test.js +0 -531
  342. package/tests/jsPsych/timelines.test.js +0 -569
  343. package/tests/jsPsych.data/data-csv-conversion.test.js +0 -85
  344. package/tests/jsPsych.data/data-json-conversion.test.js +0 -120
  345. package/tests/jsPsych.data/datacollection.test.js +0 -117
  346. package/tests/jsPsych.data/datacolumn.test.js +0 -50
  347. package/tests/jsPsych.data/datamodule.test.js +0 -152
  348. package/tests/jsPsych.data/dataparameter.test.js +0 -251
  349. package/tests/jsPsych.data/interactions.test.js +0 -109
  350. package/tests/jsPsych.data/trialparameters.test.js +0 -175
  351. package/tests/jsPsych.extensions/extensions.test.js +0 -207
  352. package/tests/jsPsych.extensions/test-extension.js +0 -42
  353. package/tests/jsPsych.pluginAPI/pluginapi.test.js +0 -341
  354. package/tests/jsPsych.pluginAPI/preloads.test.js +0 -43
  355. package/tests/jsPsych.randomization/randomziation.test.js +0 -27
  356. package/tests/jsPsych.utils/utils.test.js +0 -58
  357. package/tests/plugins/plugin-animation.test.js +0 -34
  358. package/tests/plugins/plugin-audio-button-response.test.js +0 -15
  359. package/tests/plugins/plugin-audio-keyboard-response.test.js +0 -15
  360. package/tests/plugins/plugin-audio-slider-response.test.js +0 -15
  361. package/tests/plugins/plugin-call-function.test.js +0 -49
  362. package/tests/plugins/plugin-categorize-animation.test.js +0 -263
  363. package/tests/plugins/plugin-categorize-html.test.js +0 -17
  364. package/tests/plugins/plugin-categorize-image.test.js +0 -17
  365. package/tests/plugins/plugin-cloze.test.js +0 -157
  366. package/tests/plugins/plugin-free-sort.test.js +0 -106
  367. package/tests/plugins/plugin-fullscreen.test.js +0 -41
  368. package/tests/plugins/plugin-html-button-response.test.js +0 -161
  369. package/tests/plugins/plugin-html-keyboard-response.test.js +0 -139
  370. package/tests/plugins/plugin-html-slider-response.test.js +0 -155
  371. package/tests/plugins/plugin-iat-html.test.js +0 -299
  372. package/tests/plugins/plugin-iat-image.test.js +0 -298
  373. package/tests/plugins/plugin-image-button-response.test.js +0 -174
  374. package/tests/plugins/plugin-image-keyboard-response.test.js +0 -147
  375. package/tests/plugins/plugin-image-slider-response.test.js +0 -174
  376. package/tests/plugins/plugin-instructions.test.js +0 -85
  377. package/tests/plugins/plugin-maxdiff.test.js +0 -39
  378. package/tests/plugins/plugin-preload.test.js +0 -916
  379. package/tests/plugins/plugin-rdk.test.js +0 -61
  380. package/tests/plugins/plugin-reconstruction.test.js +0 -16
  381. package/tests/plugins/plugin-resize.test.js +0 -16
  382. package/tests/plugins/plugin-same-different-html.test.js +0 -17
  383. package/tests/plugins/plugin-same-different-image.test.js +0 -17
  384. package/tests/plugins/plugin-serial-reaction-time-mouse.test.js +0 -42
  385. package/tests/plugins/plugin-serial-reaction-time.test.js +0 -109
  386. package/tests/plugins/plugin-survey-html-form.test.js +0 -44
  387. package/tests/plugins/plugin-survey-likert.test.js +0 -48
  388. package/tests/plugins/plugin-survey-multi-choice.test.js +0 -47
  389. package/tests/plugins/plugin-survey-multi-select.test.js +0 -71
  390. package/tests/plugins/plugin-survey-text.test.js +0 -115
  391. package/tests/plugins/plugin-video-button-response.test.js +0 -32
  392. package/tests/plugins/plugin-video-keyboard-response.test.js +0 -32
  393. package/tests/plugins/plugin-video-slider-response.test.js +0 -31
  394. package/tests/plugins/plugin-visual-search-circle.test.js +0 -16
  395. package/tests/plugins/plugin-vsl-animate-occlusion.test.js +0 -16
  396. package/tests/plugins/plugin-vsl-grid-scene.test.js +0 -16
  397. package/tests/testing-utils.js +0 -13
@@ -1,369 +0,0 @@
1
- /**
2
- * jspsych-image-slider-response
3
- * a jspsych plugin for free response survey questions
4
- *
5
- * Josh de Leeuw
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- */
10
-
11
-
12
- jsPsych.plugins['image-slider-response'] = (function() {
13
-
14
- var plugin = {};
15
-
16
- jsPsych.pluginAPI.registerPreload('image-slider-response', 'stimulus', 'image');
17
-
18
- plugin.info = {
19
- name: 'image-slider-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
- min: {
47
- type: jsPsych.plugins.parameterType.INT,
48
- pretty_name: 'Min slider',
49
- default: 0,
50
- description: 'Sets the minimum value of the slider.'
51
- },
52
- max: {
53
- type: jsPsych.plugins.parameterType.INT,
54
- pretty_name: 'Max slider',
55
- default: 100,
56
- description: 'Sets the maximum value of the slider',
57
- },
58
- slider_start: {
59
- type: jsPsych.plugins.parameterType.INT,
60
- pretty_name: 'Slider starting value',
61
- default: 50,
62
- description: 'Sets the starting value of the slider',
63
- },
64
- step: {
65
- type: jsPsych.plugins.parameterType.INT,
66
- pretty_name: 'Step',
67
- default: 1,
68
- description: 'Sets the step of the slider'
69
- },
70
- labels: {
71
- type: jsPsych.plugins.parameterType.HTML_STRING,
72
- pretty_name:'Labels',
73
- default: [],
74
- array: true,
75
- description: 'Labels of the slider.',
76
- },
77
- slider_width: {
78
- type: jsPsych.plugins.parameterType.INT,
79
- pretty_name:'Slider width',
80
- default: null,
81
- description: 'Width of the slider in pixels.'
82
- },
83
- button_label: {
84
- type: jsPsych.plugins.parameterType.STRING,
85
- pretty_name: 'Button label',
86
- default: 'Continue',
87
- array: false,
88
- description: 'Label of the button to advance.'
89
- },
90
- require_movement: {
91
- type: jsPsych.plugins.parameterType.BOOL,
92
- pretty_name: 'Require movement',
93
- default: false,
94
- description: 'If true, the participant will have to move the slider before continuing.'
95
- },
96
- prompt: {
97
- type: jsPsych.plugins.parameterType.STRING,
98
- pretty_name: 'Prompt',
99
- default: null,
100
- description: 'Any content here will be displayed below the slider.'
101
- },
102
- stimulus_duration: {
103
- type: jsPsych.plugins.parameterType.INT,
104
- pretty_name: 'Stimulus duration',
105
- default: null,
106
- description: 'How long to hide the stimulus.'
107
- },
108
- trial_duration: {
109
- type: jsPsych.plugins.parameterType.INT,
110
- pretty_name: 'Trial duration',
111
- default: null,
112
- description: 'How long to show the trial.'
113
- },
114
- response_ends_trial: {
115
- type: jsPsych.plugins.parameterType.BOOL,
116
- pretty_name: 'Response ends trial',
117
- default: true,
118
- description: 'If true, trial will end when user makes a response.'
119
- },
120
- render_on_canvas: {
121
- type: jsPsych.plugins.parameterType.BOOL,
122
- pretty_name: 'Render on canvas',
123
- default: true,
124
- description: 'If true, the image will be drawn onto a canvas element (prevents blank screen between consecutive images in some browsers).'+
125
- 'If false, the image will be shown via an img element.'
126
- }
127
- }
128
- }
129
-
130
- plugin.trial = function(display_element, trial) {
131
-
132
- var height, width;
133
- var html;
134
- // half of the thumb width value from jspsych.css, used to adjust the label positions
135
- var half_thumb_width = 7.5;
136
-
137
- if (trial.render_on_canvas) {
138
- var image_drawn = false;
139
- // first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
140
- if (display_element.hasChildNodes()) {
141
- // can't loop through child list because the list will be modified by .removeChild()
142
- while (display_element.firstChild) {
143
- display_element.removeChild(display_element.firstChild);
144
- }
145
- }
146
- // create wrapper div, canvas element and image
147
- var content_wrapper = document.createElement('div');
148
- content_wrapper.id = "jspsych-image-slider-response-wrapper";
149
- content_wrapper.style.margin = "100px 0px";
150
- var canvas = document.createElement("canvas");
151
- canvas.id = "jspsych-image-slider-response-stimulus";
152
- canvas.style.margin = 0;
153
- canvas.style.padding = 0;
154
- var ctx = canvas.getContext("2d");
155
- var img = new Image();
156
- img.onload = function() {
157
- // if image wasn't preloaded, then it will need to be drawn whenever it finishes loading
158
- if (!image_drawn) {
159
- getHeightWidth(); // only possible to get width/height after image loads
160
- ctx.drawImage(img,0,0,width,height);
161
- }
162
- };
163
- img.src = trial.stimulus;
164
- // get/set image height and width - this can only be done after image loads because uses image's naturalWidth/naturalHeight properties
165
- function getHeightWidth() {
166
- if (trial.stimulus_height !== null) {
167
- height = trial.stimulus_height;
168
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
169
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
170
- }
171
- } else {
172
- height = img.naturalHeight;
173
- }
174
- if (trial.stimulus_width !== null) {
175
- width = trial.stimulus_width;
176
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
177
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
178
- }
179
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
180
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
181
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
182
- width = img.naturalWidth;
183
- }
184
- canvas.height = height;
185
- canvas.width = width;
186
- }
187
- getHeightWidth(); // call now, in case image loads immediately (is cached)
188
- // create container with slider and labels
189
- var slider_container = document.createElement('div');
190
- slider_container.classList.add("jspsych-image-slider-response-container");
191
- slider_container.style.position = "relative";
192
- slider_container.style.margin = "0 auto 3em auto";
193
- if(trial.slider_width !== null){
194
- slider_container.style.width = trial.slider_width.toString()+'px';
195
- }
196
- // create html string with slider and labels, and add to slider container
197
- html ='<input type="range" class="jspsych-slider" value="'+trial.slider_start+'" min="'+trial.min+'" max="'+trial.max+'" step="'+trial.step+'" id="jspsych-image-slider-response-response"></input>';
198
- html += '<div>'
199
- for(var j=0; j < trial.labels.length; j++){
200
- var label_width_perc = 100/(trial.labels.length-1);
201
- var percent_of_range = j * (100/(trial.labels.length - 1));
202
- var percent_dist_from_center = ((percent_of_range-50)/50)*100;
203
- var offset = (percent_dist_from_center * half_thumb_width)/100;
204
- html += '<div style="border: 1px solid transparent; display: inline-block; position: absolute; '+
205
- 'left:calc('+percent_of_range+'% - ('+label_width_perc+'% / 2) - '+offset+'px); text-align: center; width: '+label_width_perc+'%;">';
206
- html += '<span style="text-align: center; font-size: 80%;">'+trial.labels[j]+'</span>';
207
- html += '</div>'
208
- }
209
- html += '</div>';
210
- slider_container.innerHTML = html;
211
- // add canvas and slider to content wrapper div
212
- content_wrapper.insertBefore(canvas, content_wrapper.firstElementChild);
213
- content_wrapper.insertBefore(slider_container, canvas.nextElementSibling);
214
- // add content wrapper div to screen and draw image on canvas
215
- display_element.insertBefore(content_wrapper, null);
216
- if (img.complete && Number.isFinite(width) && Number.isFinite(height)) {
217
- // if image has loaded and width/height have been set, then draw it now
218
- // (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)
219
- ctx.drawImage(img,0,0,width,height);
220
- image_drawn = true;
221
- }
222
- // add prompt if there is one
223
- if (trial.prompt !== null) {
224
- display_element.insertAdjacentHTML('beforeend', trial.prompt);
225
- }
226
- // add submit button
227
- var submit_btn = document.createElement('button');
228
- submit_btn.id = "jspsych-image-slider-response-next";
229
- submit_btn.classList.add("jspsych-btn");
230
- submit_btn.disabled = (trial.require_movement) ? true : false;
231
- submit_btn.innerHTML = trial.button_label;
232
- display_element.insertBefore(submit_btn, display_element.nextElementSibling);
233
-
234
- } else {
235
-
236
- html = '<div id="jspsych-image-slider-response-wrapper" style="margin: 100px 0px;">';
237
- html += '<div id="jspsych-image-slider-response-stimulus">';
238
- html += '<img src="'+trial.stimulus+'" style="';
239
- if(trial.stimulus_height !== null){
240
- html += 'height:'+trial.stimulus_height+'px; '
241
- if(trial.stimulus_width == null && trial.maintain_aspect_ratio){
242
- html += 'width: auto; ';
243
- }
244
- }
245
- if(trial.stimulus_width !== null){
246
- html += 'width:'+trial.stimulus_width+'px; '
247
- if(trial.stimulus_height == null && trial.maintain_aspect_ratio){
248
- html += 'height: auto; ';
249
- }
250
- }
251
- html += '"></img>';
252
- html += '</div>';
253
- html += '<div class="jspsych-image-slider-response-container" style="position:relative; margin: 0 auto 3em auto; width:';
254
- if (trial.slider_width !== null) {
255
- html += trial.slider_width+'px;';
256
- } else {
257
- html += 'auto;';
258
- }
259
- html += '">';
260
- html += '<input type="range" class="jspsych-slider" value="'+trial.slider_start+'" min="'+trial.min+'" max="'+trial.max+'" step="'+trial.step+'" id="jspsych-image-slider-response-response"></input>';
261
- html += '<div>'
262
- for(var j=0; j < trial.labels.length; j++){
263
- var label_width_perc = 100/(trial.labels.length-1);
264
- var percent_of_range = j * (100/(trial.labels.length - 1));
265
- var percent_dist_from_center = ((percent_of_range-50)/50)*100;
266
- var offset = (percent_dist_from_center * half_thumb_width)/100;
267
- html += '<div style="border: 1px solid transparent; display: inline-block; position: absolute; '+
268
- 'left:calc('+percent_of_range+'% - ('+label_width_perc+'% / 2) - '+offset+'px); text-align: center; width: '+label_width_perc+'%;">';
269
- html += '<span style="text-align: center; font-size: 80%;">'+trial.labels[j]+'</span>';
270
- html += '</div>'
271
- }
272
- html += '</div>';
273
- html += '</div>';
274
- html += '</div>';
275
-
276
- if (trial.prompt !== null){
277
- html += trial.prompt;
278
- }
279
-
280
- // add submit button
281
- html += '<button id="jspsych-image-slider-response-next" class="jspsych-btn" '+ (trial.require_movement ? "disabled" : "") + '>'+trial.button_label+'</button>';
282
-
283
- display_element.innerHTML = html;
284
-
285
- // set image dimensions after image has loaded (so that we have access to naturalHeight/naturalWidth)
286
- var img = display_element.querySelector('img');
287
- if (trial.stimulus_height !== null) {
288
- height = trial.stimulus_height;
289
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
290
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
291
- }
292
- } else {
293
- height = img.naturalHeight;
294
- }
295
- if (trial.stimulus_width !== null) {
296
- width = trial.stimulus_width;
297
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
298
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
299
- }
300
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
301
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
302
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
303
- width = img.naturalWidth;
304
- }
305
- img.style.height = height.toString() + "px";
306
- img.style.width = width.toString() + "px";
307
- }
308
-
309
- var response = {
310
- rt: null,
311
- response: null
312
- };
313
-
314
- if(trial.require_movement){
315
- display_element.querySelector('#jspsych-image-slider-response-response').addEventListener('click', function(){
316
- display_element.querySelector('#jspsych-image-slider-response-next').disabled = false;
317
- });
318
- }
319
-
320
- display_element.querySelector('#jspsych-image-slider-response-next').addEventListener('click', function() {
321
- // measure response time
322
- var endTime = performance.now();
323
- response.rt = endTime - startTime;
324
- response.response = display_element.querySelector('#jspsych-image-slider-response-response').valueAsNumber;
325
-
326
- if(trial.response_ends_trial){
327
- end_trial();
328
- } else {
329
- display_element.querySelector('#jspsych-image-slider-response-next').disabled = true;
330
- }
331
-
332
- });
333
-
334
- function end_trial(){
335
-
336
- jsPsych.pluginAPI.clearAllTimeouts();
337
-
338
- // save data
339
- var trialdata = {
340
- rt: response.rt,
341
- stimulus: trial.stimulus,
342
- slider_start: trial.slider_start,
343
- response: response.response
344
- };
345
-
346
- display_element.innerHTML = '';
347
-
348
- // next trial
349
- jsPsych.finishTrial(trialdata);
350
- }
351
-
352
- if (trial.stimulus_duration !== null) {
353
- jsPsych.pluginAPI.setTimeout(function() {
354
- display_element.querySelector('#jspsych-image-slider-response-stimulus').style.visibility = 'hidden';
355
- }, trial.stimulus_duration);
356
- }
357
-
358
- // end trial if trial_duration is set
359
- if (trial.trial_duration !== null) {
360
- jsPsych.pluginAPI.setTimeout(function() {
361
- end_trial();
362
- }, trial.trial_duration);
363
- }
364
-
365
- var startTime = performance.now();
366
- };
367
-
368
- return plugin;
369
- })();
@@ -1,237 +0,0 @@
1
- /* jspsych-instructions.js
2
- * Josh de Leeuw
3
- *
4
- * This plugin displays text (including HTML formatted strings) during the experiment.
5
- * Use it to show instructions, provide performance feedback, etc...
6
- *
7
- * Page numbers can be displayed to help with navigation by setting show_page_number
8
- * to true.
9
- *
10
- * documentation: docs.jspsych.org
11
- *
12
- *
13
- */
14
-
15
- jsPsych.plugins.instructions = (function() {
16
-
17
- var plugin = {};
18
-
19
- plugin.info = {
20
- name: 'instructions',
21
- description: '',
22
- parameters: {
23
- pages: {
24
- type: jsPsych.plugins.parameterType.HTML_STRING,
25
- pretty_name: 'Pages',
26
- default: undefined,
27
- array: true,
28
- description: 'Each element of the array is the content for a single page.'
29
- },
30
- key_forward: {
31
- type: jsPsych.plugins.parameterType.KEY,
32
- pretty_name: 'Key forward',
33
- default: 'ArrowRight',
34
- description: 'The key the subject can press in order to advance to the next page.'
35
- },
36
- key_backward: {
37
- type: jsPsych.plugins.parameterType.KEY,
38
- pretty_name: 'Key backward',
39
- default: 'ArrowLeft',
40
- description: 'The key that the subject can press to return to the previous page.'
41
- },
42
- allow_backward: {
43
- type: jsPsych.plugins.parameterType.BOOL,
44
- pretty_name: 'Allow backward',
45
- default: true,
46
- description: 'If true, the subject can return to the previous page of the instructions.'
47
- },
48
- allow_keys: {
49
- type: jsPsych.plugins.parameterType.BOOL,
50
- pretty_name: 'Allow keys',
51
- default: true,
52
- description: 'If true, the subject can use keyboard keys to navigate the pages.'
53
- },
54
- show_clickable_nav: {
55
- type: jsPsych.plugins.parameterType.BOOL,
56
- pretty_name: 'Show clickable nav',
57
- default: false,
58
- description: 'If true, then a "Previous" and "Next" button will be displayed beneath the instructions.'
59
- },
60
- show_page_number: {
61
- type: jsPsych.plugins.parameterType.BOOL,
62
- pretty_name: 'Show page number',
63
- default: false,
64
- description: 'If true, and clickable navigation is enabled, then Page x/y will be shown between the nav buttons.'
65
- },
66
- page_label: {
67
- type: jsPsych.plugins.parameterType.STRING,
68
- pretty_name: 'Page label',
69
- default: 'Page',
70
- description: 'The text that appears before x/y (current/total) pages displayed with show_page_number'
71
- },
72
- button_label_previous: {
73
- type: jsPsych.plugins.parameterType.STRING,
74
- pretty_name: 'Button label previous',
75
- default: 'Previous',
76
- description: 'The text that appears on the button to go backwards.'
77
- },
78
- button_label_next: {
79
- type: jsPsych.plugins.parameterType.STRING,
80
- pretty_name: 'Button label next',
81
- default: 'Next',
82
- description: 'The text that appears on the button to go forwards.'
83
- }
84
- }
85
- }
86
-
87
- plugin.trial = function(display_element, trial) {
88
-
89
- var current_page = 0;
90
-
91
- var view_history = [];
92
-
93
- var start_time = performance.now();
94
-
95
- var last_page_update_time = start_time;
96
-
97
- function btnListener(evt){
98
- evt.target.removeEventListener('click', btnListener);
99
- if(this.id === "jspsych-instructions-back"){
100
- back();
101
- }
102
- else if(this.id === 'jspsych-instructions-next'){
103
- next();
104
- }
105
- }
106
-
107
- function show_current_page() {
108
- var html = trial.pages[current_page];
109
-
110
- var pagenum_display = "";
111
- if(trial.show_page_number) {
112
- pagenum_display = "<span style='margin: 0 1em;' class='"+
113
- "jspsych-instructions-pagenum'>"+ trial.page_label + ' ' +(current_page+1)+"/"+trial.pages.length+"</span>";
114
- }
115
-
116
- if (trial.show_clickable_nav) {
117
-
118
- var nav_html = "<div class='jspsych-instructions-nav' style='padding: 10px 0px;'>";
119
- if (trial.allow_backward) {
120
- var allowed = (current_page > 0 )? '' : "disabled='disabled'";
121
- nav_html += "<button id='jspsych-instructions-back' class='jspsych-btn' style='margin-right: 5px;' "+allowed+">&lt; "+trial.button_label_previous+"</button>";
122
- }
123
- if (trial.pages.length > 1 && trial.show_page_number) {
124
- nav_html += pagenum_display;
125
- }
126
- nav_html += "<button id='jspsych-instructions-next' class='jspsych-btn'"+
127
- "style='margin-left: 5px;'>"+trial.button_label_next+
128
- " &gt;</button></div>";
129
-
130
- html += nav_html;
131
- display_element.innerHTML = html;
132
- if (current_page != 0 && trial.allow_backward) {
133
- display_element.querySelector('#jspsych-instructions-back').addEventListener('click', btnListener);
134
- }
135
-
136
- display_element.querySelector('#jspsych-instructions-next').addEventListener('click', btnListener);
137
- } else {
138
- if (trial.show_page_number && trial.pages.length > 1) {
139
- // page numbers for non-mouse navigation
140
- html += "<div class='jspsych-instructions-pagenum'>"+pagenum_display+"</div>"
141
- }
142
- display_element.innerHTML = html;
143
- }
144
-
145
- }
146
-
147
- function next() {
148
-
149
- add_current_page_to_view_history()
150
-
151
- current_page++;
152
-
153
- // if done, finish up...
154
- if (current_page >= trial.pages.length) {
155
- endTrial();
156
- } else {
157
- show_current_page();
158
- }
159
-
160
- }
161
-
162
- function back() {
163
-
164
- add_current_page_to_view_history()
165
-
166
- current_page--;
167
-
168
- show_current_page();
169
- }
170
-
171
- function add_current_page_to_view_history() {
172
-
173
- var current_time = performance.now();
174
-
175
- var page_view_time = current_time - last_page_update_time;
176
-
177
- view_history.push({
178
- page_index: current_page,
179
- viewing_time: page_view_time
180
- });
181
-
182
- last_page_update_time = current_time;
183
- }
184
-
185
- function endTrial() {
186
-
187
- if (trial.allow_keys) {
188
- jsPsych.pluginAPI.cancelKeyboardResponse(keyboard_listener);
189
- }
190
-
191
- display_element.innerHTML = '';
192
-
193
- var trial_data = {
194
- view_history: view_history,
195
- rt: performance.now() - start_time
196
- };
197
-
198
- jsPsych.finishTrial(trial_data);
199
- }
200
-
201
- var after_response = function(info) {
202
-
203
- // have to reinitialize this instead of letting it persist to prevent accidental skips of pages by holding down keys too long
204
- keyboard_listener = jsPsych.pluginAPI.getKeyboardResponse({
205
- callback_function: after_response,
206
- valid_responses: [trial.key_forward, trial.key_backward],
207
- rt_method: 'performance',
208
- persist: false,
209
- allow_held_key: false
210
- });
211
- // check if key is forwards or backwards and update page
212
- if (jsPsych.pluginAPI.compareKeys(info.key, trial.key_backward)) {
213
- if (current_page !== 0 && trial.allow_backward) {
214
- back();
215
- }
216
- }
217
-
218
- if (jsPsych.pluginAPI.compareKeys(info.key, trial.key_forward)) {
219
- next();
220
- }
221
-
222
- };
223
-
224
- show_current_page();
225
-
226
- if (trial.allow_keys) {
227
- var keyboard_listener = jsPsych.pluginAPI.getKeyboardResponse({
228
- callback_function: after_response,
229
- valid_responses: [trial.key_forward, trial.key_backward],
230
- rt_method: 'performance',
231
- persist: false
232
- });
233
- }
234
- };
235
-
236
- return plugin;
237
- })();