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,471 +0,0 @@
1
- /*
2
- * virtual chinrest plugin for jsPsych, based on Qisheng Li 11/2019. /// https://github.com/QishengLi/virtual_chinrest
3
-
4
- Modified by Gustavo Juantorena 08/2020 // https://github.com/GEJ1
5
-
6
- Contributions from Peter J. Kohler: https://github.com/pjkohler
7
- */
8
-
9
- jsPsych.plugins["virtual-chinrest"] = (function () {
10
- var plugin = {};
11
-
12
- plugin.info = {
13
- name: "virtual-chinrest",
14
- parameters: {
15
- resize_units: {
16
- type: jsPsych.plugins.parameterType.STRING,
17
- pretty_name: "Resize units",
18
- default: "none",
19
- description:
20
- 'What units to resize to? ["none"/"cm"/"inch"/"deg"]. If "none", no resizing will be done to the jsPsych content after this trial.',
21
- },
22
- pixels_per_unit: {
23
- type: jsPsych.plugins.parameterType.INT,
24
- pretty_name: "Pixels per unit",
25
- default: 100,
26
- description:
27
- "After the scaling factor is applied, this many pixels will equal one unit of measurement.",
28
- },
29
- // mouse_adjustment: {
30
- // type: jsPsych.plugins.parameterType.BOOL,
31
- // pretty_name: "Adjust Using Mouse?",
32
- // default: true,
33
- // },
34
- adjustment_prompt: {
35
- type: jsPsych.plugins.parameterType.HTML_STRING,
36
- pretty_name: "Adjustment prompt",
37
- default: `
38
- <div style="text-align: left;">
39
- <p>Click and drag the lower right corner of the image until it is the same size as a credit card held up to the screen.</p>
40
- <p>You can use any card that is the same size as a credit card, like a membership card or driver's license.</p>
41
- <p>If you do not have access to a real card you can use a ruler to measure the image width to 3.37 inches or 85.6 mm.</p>
42
- </div>`,
43
- description:
44
- "Any content here will be displayed above the card stimulus.",
45
- },
46
- adjustment_button_prompt: {
47
- type: jsPsych.plugins.parameterType.HTML_STRING,
48
- pretty_name: "Adjustment button prompt",
49
- default: "Click here when the image is the correct size",
50
- description:
51
- " Content of the button displayed below the card stimulus.",
52
- },
53
- item_path: {
54
- type: jsPsych.plugins.parameterType.STRING,
55
- pretty_name: "Item path",
56
- default: "img/card.png",
57
- description: "Path to an image to be shown in the resizable item div."
58
- },
59
- item_height_mm: {
60
- type: jsPsych.plugins.parameterType.FLOAT,
61
- pretty_name: "Item height (mm)",
62
- default: 53.98,
63
- description: "The height of the item to be measured, in mm.",
64
- },
65
- item_width_mm: {
66
- type: jsPsych.plugins.parameterType.FLOAT,
67
- pretty_name: "Item width (mm)",
68
- default: 85.6,
69
- description: "The width of the item to be measured, in mm.",
70
- },
71
- item_init_size: {
72
- type: jsPsych.plugins.parameterType.INT,
73
- pretty_name: "Initial Size",
74
- default: 250,
75
- description:
76
- "The initial size of the card, in pixels, along the largest dimension.",
77
- },
78
- blindspot_reps: {
79
- type: jsPsych.plugins.parameterType.INT,
80
- pretty_name: "Blindspot measurement repetitions",
81
- default: 5,
82
- description:
83
- "How many times to measure the blindspot location? If 0, blindspot will not be detected, and viewing distance and degree data not computed.",
84
- },
85
- blindspot_prompt: {
86
- type: jsPsych.plugins.parameterType.HTML_STRING,
87
- pretty_name: "Blindspot prompt",
88
- default: `
89
- <p>Now we will quickly measure how far away you are sitting.</p>
90
- <div style="text-align: left">
91
- <ol>
92
- <li>Put your left hand on the <b>space bar</b>.</li>
93
- <li>Cover your right eye with your right hand.</li>
94
- <li>Using your left eye, focus on the black square. Keep your focus on the black square.</li>
95
- <li>The <span style="color: red; font-weight: bold;">red ball</span> will disappear as it moves from right to left. Press the space bar as soon as the ball disappears.</li>
96
- </ol>
97
- </div>
98
- <p>Press the space bar when you are ready to begin.</p>
99
- `,
100
- description: "HTML-formatted prompt to be shown on the screen during blindspot estimates."
101
- },
102
- // blindspot_start_prompt: {
103
- // type: jsPsych.plugins.parameterType.HTML_STRING,
104
- // pretty_name: "Blindspot start prompt",
105
- // default: "Start",
106
- // description: "Content of the start button for the blindspot tasks.",
107
- // },
108
- blindspot_measurements_prompt: {
109
- type: jsPsych.plugins.parameterType.HTML_STRING,
110
- pretty_name: "Blindspot measurements prompt",
111
- default: "Remaining measurements: ",
112
- description: "Text accompanying the remaining measures counter",
113
- },
114
- viewing_distance_report: {
115
- type: jsPsych.plugins.parameterType.HTML_STRING,
116
- pretty_name: "Viewing distance report",
117
- default: "<p>Based on your responses, you are sitting about <span id='distance-estimate' style='font-weight: bold;'></span> from the screen.</p><p>Does that seem about right?</p>",
118
- description:
119
- 'If "none" is given, viewing distance will not be reported to the participant',
120
- },
121
- redo_measurement_button_label: {
122
- type: jsPsych.plugins.parameterType.HTML_STRING,
123
- pretty_name: "Re-do measurement button label",
124
- default: 'No, that is not close. Try again.',
125
- description: "Label for the button that can be clicked on the viewing distance report screen to re-do the blindspot estimate(s)."
126
- },
127
- blindspot_done_prompt: {
128
- type: jsPsych.plugins.parameterType.HTML_STRING,
129
- pretty_name: "Blindspot done prompt",
130
- default: "Yes",
131
- description: "Label for the button that can be clicked on the viewing distance report screen to accept the viewing distance estimate.",
132
- },
133
- },
134
- };
135
-
136
- plugin.trial = function (display_element, trial) {
137
- /* check parameter compatibility */
138
- if (!(trial.blindspot_reps > 0) && (trial.resize_units == "deg" || trial.resize_units == "degrees")) {
139
- console.error("Blindspot repetitions set to 0, so resizing to degrees of visual angle is not possible!");
140
- return;
141
- }
142
-
143
- /* some additional parameter configuration */
144
- let trial_data = {
145
- item_width_mm: trial.item_width_mm,
146
- item_height_mm: trial.item_height_mm, //card dimension: 85.60 × 53.98 mm (3.370 × 2.125 in)
147
- };
148
-
149
- let blindspot_config_data = {
150
- ball_pos: [],
151
- slider_clck: false,
152
- };
153
-
154
- let aspect_ratio = trial.item_width_mm / trial.item_height_mm;
155
-
156
- const start_div_height =
157
- aspect_ratio < 1
158
- ? trial.item_init_size
159
- : Math.round(trial.item_init_size / aspect_ratio);
160
- const start_div_width =
161
- aspect_ratio < 1
162
- ? Math.round(trial.item_init_size * aspect_ratio)
163
- : trial.item_init_size;
164
- const adjust_size = Math.round(start_div_width * 0.1);
165
-
166
- /* create content for first screen, resizing card */
167
- let pagesize_content = `
168
- <div id="page-size">
169
- <div id="item" style="border: none; height: ${start_div_height}px; width: ${start_div_width}px; margin: 5px auto; background-color: none; position: relative; background-image: url(${trial.item_path}); background-size: 100% auto; background-repeat: no-repeat;">
170
- <div id="jspsych-resize-handle" style="cursor: nwse-resize; background-color: none; width: ${adjust_size}px; height: ${adjust_size}px; border: 5px solid red; border-left: 0; border-top: 0; position: absolute; bottom: 0; right: 0;">
171
- </div>
172
- </div>
173
- ${trial.adjustment_prompt}
174
- <button id="end_resize_phase" class="jspsych-btn">
175
- ${trial.adjustment_button_prompt}
176
- </button>
177
- </div>
178
- `
179
-
180
- /* create content for second screen, blind spot */
181
- let blindspot_content = `
182
- <div id="blind-spot">
183
- ${trial.blindspot_prompt}
184
- <div id="svgDiv" style="width:1000px;height:200px;"></div>
185
- <button class="btn btn-primary" id="proceed" style="display:none;"> +
186
- ${trial.blindspot_done_prompt} +
187
- </button>
188
- ${trial.blindspot_measurements_prompt}
189
- <div id="click" style="display:inline; color: red"> ${trial.blindspot_reps} </div>
190
- </div>`
191
-
192
- /* create content for final report screen */
193
- let report_content = `
194
- <div id="distance-report">
195
- <div id="info-h">
196
- ${trial.viewing_distance_report}
197
- </div>
198
- <button id="redo_blindspot" class="jspsych-btn">${trial.redo_measurement_button_label}</button>
199
- <button id="proceed" class="jspsych-btn">${trial.blindspot_done_prompt}</button>
200
- </div>
201
- `
202
-
203
- display_element.innerHTML = `<div id="content" style="width: 900px; margin: 0 auto;"></div>`
204
-
205
- const start_time = performance.now();
206
- startResizePhase();
207
-
208
- function startResizePhase() {
209
- display_element.querySelector('#content').innerHTML = pagesize_content;
210
-
211
- // Event listeners for mouse-based resize
212
- let dragging = false;
213
- let origin_x, origin_y;
214
- let cx, cy;
215
- const scale_div = display_element.querySelector("#item");
216
-
217
- function mouseupevent() {
218
- dragging = false;
219
- };
220
- document.addEventListener("mouseup", mouseupevent);
221
-
222
- function mousedownevent(e) {
223
- e.preventDefault();
224
- dragging = true;
225
- origin_x = e.pageX;
226
- origin_y = e.pageY;
227
- cx = parseInt(scale_div.style.width);
228
- cy = parseInt(scale_div.style.height);
229
- };
230
- display_element.querySelector("#jspsych-resize-handle").addEventListener("mousedown", mousedownevent);
231
-
232
- function resizeevent(e) {
233
- if (dragging) {
234
- let dx = e.pageX - origin_x;
235
- let dy = e.pageY - origin_y;
236
-
237
- if (Math.abs(dx) >= Math.abs(dy)) {
238
- scale_div.style.width =
239
- Math.round(Math.max(20, cx + dx * 2)) + "px";
240
- scale_div.style.height =
241
- Math.round(Math.max(20, cx + dx * 2) / aspect_ratio) + "px";
242
- } else {
243
- scale_div.style.height =
244
- Math.round(Math.max(20, cy + dy * 2)) + "px";
245
- scale_div.style.width =
246
- Math.round(aspect_ratio * Math.max(20, cy + dy * 2)) + "px";
247
- }
248
- }
249
- }
250
- display_element.addEventListener("mousemove", resizeevent);
251
-
252
- display_element.querySelector("#end_resize_phase").addEventListener("click", finishResizePhase);
253
-
254
- }
255
-
256
- function finishResizePhase() {
257
- // add item width info to data
258
- const item_width_px = getScaledItemWidth();
259
- trial_data["item_width_px"] = Math.round(item_width_px);
260
- const px2mm = convertPixelsToMM(item_width_px);
261
- trial_data["px2mm"] = accurateRound(px2mm, 2);
262
- // check what to do next
263
- if (trial.blindspot_reps > 0) {
264
- startBlindSpotPhase();
265
- } else {
266
- endTrial();
267
- }
268
- }
269
-
270
- function startBlindSpotPhase() {
271
- // reset the config data in case we are redoing the measurement
272
- blindspot_config_data = {
273
- ball_pos: [],
274
- slider_clck: false,
275
- };
276
- // add the content to the page
277
- document.querySelector("#content").innerHTML = blindspot_content;
278
- // draw the ball and fixation square
279
- drawBall();
280
- // wait for a spacebar to begin the animations
281
- jsPsych.pluginAPI.getKeyboardResponse({
282
- callback_function: startBall,
283
- valid_responses: [' '],
284
- rt_method: 'performance',
285
- allow_held_keys: false,
286
- persist: false
287
- })
288
- }
289
-
290
- function startBall() {
291
- ball_position_listener = jsPsych.pluginAPI.getKeyboardResponse({
292
- callback_function: recordPosition,
293
- valid_responses: [' '],
294
- rt_method: 'performance',
295
- allow_held_keys: false,
296
- persist: true
297
- });
298
- animateBall();
299
- }
300
-
301
- function finishBlindSpotPhase() {
302
- ball.stop();
303
-
304
- jsPsych.pluginAPI.cancelAllKeyboardResponses();
305
-
306
- if(trial.viewing_distance_report == 'none'){
307
- endTrial();
308
- } else {
309
- showReport();
310
- }
311
- }
312
-
313
- function showReport() {
314
- // Display data
315
- display_element.querySelector("#content").innerHTML = report_content;
316
- display_element.querySelector('#distance-estimate').innerHTML = `
317
- ${Math.round(trial_data["view_dist_mm"] / 10)} cm (${Math.round(trial_data["view_dist_mm"]*0.0393701)} inches)
318
- `
319
-
320
- display_element.querySelector("#redo_blindspot").addEventListener('click', startBlindSpotPhase)
321
- display_element.querySelector("#proceed").addEventListener('click', endTrial);
322
- }
323
-
324
- function computeTransformation() {
325
- trial_data.item_width_deg =
326
- (2 *
327
- Math.atan(
328
- trial_data["item_width_mm"] / 2 / trial_data["view_dist_mm"]
329
- ) *
330
- 180) /
331
- Math.PI;
332
- trial_data.px2deg =
333
- trial_data["item_width_px"] / trial_data.item_width_deg; // size of item in pixels divided by size of item in degrees of visual angle
334
-
335
- let px2unit_scr = 0;
336
- switch (trial.resize_units) {
337
- case "cm":
338
- case "centimeters":
339
- px2unit_scr = trial_data["px2mm"] * 10; // pixels per centimeter
340
- break;
341
- case "inch":
342
- case "inches":
343
- px2unit_scr = trial_data["px2mm"] * 25.4; // pixels per inch
344
- break;
345
- case "deg":
346
- case "degrees":
347
- px2unit_scr = trial_data["px2deg"]; // pixels per degree of visual angle
348
- break;
349
- }
350
- if (px2unit_scr > 0) {
351
- // scale the window
352
- scale_factor = px2unit_scr / trial.pixels_per_unit;
353
- document.getElementById("jspsych-content").style.transform =
354
- "scale(" + scale_factor + ")";
355
- // pixels have been scaled, so pixels per degree, pixels per mm and pixels per item_width needs to be updated
356
- trial_data.px2deg = trial_data.px2deg / scale_factor;
357
- trial_data.px2mm = trial_data.px2mm / scale_factor;
358
- trial_data.item_width_px =
359
- trial_data.item_width_px / scale_factor;
360
- trial_data.scale_factor = scale_factor;
361
- }
362
-
363
- if (trial.blindspot_reps > 0) {
364
- trial_data.win_width_deg = window.innerWidth / trial_data.px2deg;
365
- trial_data.win_height_deg =
366
- window.innerHeight / trial_data.px2deg;
367
- } else {
368
- // delete degree related properties
369
- delete trial_data.px2deg;
370
- delete trial_data.item_width_deg;
371
- }
372
- }
373
-
374
- function endTrial() {
375
-
376
- // finish trial
377
- trial_data.rt = performance.now() - start_time;
378
-
379
- // remove lingering event listeners, just in case
380
- jsPsych.pluginAPI.cancelAllKeyboardResponses();
381
-
382
- // compute final data
383
- computeTransformation();
384
-
385
- // clear the display
386
- display_element.innerHTML = "";
387
-
388
- // finish the trial
389
- jsPsych.finishTrial(trial_data);
390
-
391
- }
392
-
393
- function getScaledItemWidth() {
394
- return document.querySelector('#item').getBoundingClientRect().width;
395
- }
396
-
397
- function drawBall(pos = 180) {
398
- // pos: define where the fixation square should be.
399
- var mySVG = SVG("svgDiv");
400
- const rectX = trial_data["px2mm"] * pos;
401
- const ballX = rectX * 0.6; // define where the ball is
402
- var ball = mySVG.circle(30).move(ballX, 50).fill("#f00");
403
- window.ball = ball;
404
- var square = mySVG.rect(30, 30).move(Math.min(rectX - 50, 950), 50); //square position
405
- blindspot_config_data["square_pos"] = accurateRound(square.cx(), 2);
406
- blindspot_config_data["rectX"] = rectX;
407
- blindspot_config_data["ballX"] = ballX;
408
- }
409
-
410
- function animateBall() {
411
- ball
412
- .animate(7000)
413
- .during(function (pos) {
414
- moveX = -pos * blindspot_config_data["ballX"];
415
- window.moveX = moveX;
416
- moveY = 0;
417
- ball.attr({ transform: "translate(" + moveX + "," + moveY + ")" }); //jqueryToVanilla: el.getAttribute('');
418
- })
419
- .loop(true, false)
420
- .after(function () {
421
- animateBall();
422
- });
423
- }
424
-
425
- function recordPosition() {
426
- // angle: define horizontal blind spot entry point position in degrees.
427
- const angle = 13.5;
428
-
429
- blindspot_config_data["ball_pos"].push(accurateRound(ball.cx() + moveX, 2));
430
- var sum = blindspot_config_data["ball_pos"].reduce((a, b) => a + b, 0);
431
- var ballPosLen = blindspot_config_data["ball_pos"].length;
432
- blindspot_config_data["avg_ball_pos"] = accurateRound(sum / ballPosLen, 2);
433
- var ball_sqr_distance =
434
- (blindspot_config_data["square_pos"] - blindspot_config_data["avg_ball_pos"]) /
435
- trial_data["px2mm"];
436
- var viewDistance = ball_sqr_distance / Math.tan(Math.radians(angle));
437
- trial_data["view_dist_mm"] = accurateRound(viewDistance, 2);
438
-
439
- //counter and stop
440
- var counter = Number(document.querySelector("#click").textContent);
441
- counter = counter - 1;
442
- document.querySelector("#click").textContent = Math.max(counter, 0);
443
- if (counter <= 0) {
444
- finishBlindSpotPhase();
445
- return;
446
- } else {
447
- ball.stop();
448
- animateBall();
449
- }
450
-
451
- }
452
-
453
- function convertPixelsToMM(item_width_px){
454
- const px2mm = item_width_px / trial_data["item_width_mm"];
455
- return px2mm;
456
- }
457
-
458
- function accurateRound(value, decimals){
459
- return Number(Math.round(value+'e'+decimals)+'e-'+decimals);
460
- }
461
-
462
- };
463
-
464
- //helper function for radians
465
- // Converts from degrees to radians.
466
- Math.radians = function (degrees) {
467
- return (degrees * Math.PI) / 180;
468
- };
469
-
470
- return plugin;
471
- })();