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,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
- })();