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,162 +0,0 @@
1
- <!DOCTYPE html>
2
- <html>
3
-
4
- <head>
5
- <script src="../jspsych.js"></script>
6
- <script src="../plugins/jspsych-html-keyboard-response.js"></script>
7
- <script src="../plugins/jspsych-html-button-response.js"></script>
8
- <script src="../plugins/jspsych-webgazer-init-camera.js"></script>
9
- <script src="../plugins/jspsych-webgazer-calibrate.js"></script>
10
- <script src="../plugins/jspsych-webgazer-validate.js"></script>
11
- <script src="js/webgazer.js"></script>
12
- <script src="../extensions/jspsych-ext-webgazer.js"></script>
13
- <link rel="stylesheet" href="../css/jspsych.css">
14
- <style>
15
- .jspsych-content { max-width: 100%;}
16
- </style>
17
- </head>
18
-
19
- <body></body>
20
-
21
- <script>
22
-
23
- var init_camera = {
24
- type: 'webgazer-init-camera'
25
- }
26
-
27
- var calibration_instructions = {
28
- type: 'html-button-response',
29
- stimulus: `
30
- <p>Great! Now the eye tracker will be calibrated to translate the image of your eyes from the webcam to a location on your screen.</p>
31
- <p>To do this, you need to click a series of dots.</p>
32
- <p>Keep your head still, and click on each dot as it appears. Look at the dot as you click it.</p>
33
- `,
34
- choices: ['Click to begin'],
35
- post_trial_gap: 1000
36
- }
37
-
38
- var calibration = {
39
- type: 'webgazer-calibrate',
40
- calibration_points: [[50,50], [25,25], [25,75], [75,25], [75,75]],
41
- //calibration_points: [[10,10],[10,30],[10,50],[10,70],[10,90],[30,10],[30,30],[30,50],[30,70],[30,90],[50,10],[50,30],[50,50],[50,70],[50,90],[70,10],[70,30],[70,50],[70,70],[70,90],[90,10],[90,30],[90,50],[90,70],[90,90]],
42
- // calibration_points: [
43
- // [10,10],[10,50],[10,90],
44
- // [30,10],[30,50],[30,90],
45
- // [40,10],[40,30],[40,40],[40,45],[40,50],[40,55],[40,60],[40,70],[40,90],
46
- // [50,10],[50,30],[50,40],[50,45],[50,50],[50,55],[50,60],[50,70],[50,90],
47
- // [60,10],[60,30],[60,40],[60,45],[60,50],[60,55],[60,60],[60,70],[60,90],
48
- // [70,10],[70,50],[70,90],
49
- // [90,10],[90,50],[90,90]],
50
- repetitions_per_point: 1,
51
- randomize_calibration_order: true,
52
- }
53
-
54
- var validation_instructions = {
55
- type: 'html-button-response',
56
- stimulus: `
57
- <p>Let's see how accurate the eye tracking is. </p>
58
- <p>Keep your head still, and move your eyes to focus on each dot as it appears.</p>
59
- <p>You do not need to click on the dots. Just move your eyes to look at the dots.</p>
60
- `,
61
- choices: ['Click to begin'],
62
- post_trial_gap: 1000
63
- }
64
-
65
- var validation = {
66
- type: 'webgazer-validate',
67
- validation_points: [[-200,-200], [-200,200], [200,-200], [200,200]],
68
- validation_point_coordinates: 'center-offset-pixels',
69
- show_validation_data: true
70
- }
71
-
72
- var task_instructions = {
73
- type: 'html-button-response',
74
- stimulus: `
75
- <p>We're ready for the task now.</p>
76
- <p>You'll see an arrow symbol (⬅ or ➡) appear on the screen.</p>
77
- <p>Your job is to press A if ⬅ appears, and L if ➡ appears.</p>
78
- <p>This will repeat 8 times.</p>
79
- `,
80
- choices: ['I am ready!'],
81
- post_trial_gap: 1000
82
- }
83
-
84
- var fixation = {
85
- type: 'html-keyboard-response',
86
- stimulus: '<p style="font-size:40px;">+</p>',
87
- choices: jsPsych.NO_KEYS,
88
- trial_duration: 500
89
- }
90
-
91
- var trial = {
92
- type: 'html-keyboard-response',
93
- stimulus: function () {
94
- return(
95
- `<div style="position: relative; width: 400px; height: 400px;">
96
- <div style="position: absolute; top:${jsPsych.timelineVariable('top', true)}%; left: ${jsPsych.timelineVariable('left', true)}%">
97
- <span id="arrow-target" style="font-size: 40px; transform: translate(-50%, -50%);">${jsPsych.timelineVariable('direction', true) == 'left' ? '⬅' : '➡'}</span>
98
- </div>
99
- </div>`
100
- )
101
- },
102
- choices: ['a', 'l'],
103
- post_trial_gap: 750,
104
- data: {
105
- top: jsPsych.timelineVariable('top'),
106
- left: jsPsych.timelineVariable('left')
107
- },
108
- extensions: [
109
- {type: 'webgazer', params: {targets: ['#arrow-target']}}
110
- ]
111
- }
112
-
113
- var params = [
114
- { left: 0, top: 0, direction: 'left' },
115
- { left: 100, top: 0, direction: 'left' },
116
- { left: 0, top: 100, direction: 'left' },
117
- { left: 100, top: 100, direction: 'left' },
118
- { left: 0, top: 0, direction: 'right' },
119
- { left: 100, top: 0, direction: 'right' },
120
- { left: 0, top: 100, direction: 'right' },
121
- { left: 100, top: 100, direction: 'right' },
122
- ]
123
-
124
- var trial_proc = {
125
- timeline: [fixation, trial],
126
- timeline_variables: params,
127
- randomize_order: true
128
- }
129
-
130
- var done = {
131
- type: 'html-button-response',
132
- choices: ['CSV', 'JSON'],
133
- stimulus: `<p>Done!</p><p>If you'd like to download a copy of the data to explore, click the format you'd like below</p>`,
134
- on_finish: function(data){
135
- if(data.response == 0){
136
- jsPsych.data.get().localSave('csv','webgazer-sample-data.csv');
137
- }
138
- if(data.response == 1){
139
- jsPsych.data.get().localSave('json', 'webgazer-sample-data.json');
140
- }
141
- }
142
- }
143
-
144
- var timeline = [];
145
- timeline.push(init_camera);
146
- timeline.push(calibration_instructions);
147
- timeline.push(calibration);
148
- timeline.push(validation_instructions);
149
- timeline.push(validation);
150
- timeline.push(task_instructions);
151
- timeline.push(trial_proc);
152
- timeline.push(done);
153
-
154
- jsPsych.init({
155
- timeline: timeline,
156
- extensions: [
157
- {type: 'webgazer'}
158
- ]
159
- })
160
- </script>
161
-
162
- </html>
@@ -1,60 +0,0 @@
1
- <!DOCTYPE html>
2
- <html>
3
- <head>
4
- <script src="../jspsych.js"></script>
5
- <script src="../plugins/jspsych-preload.js"></script>
6
- <script src="../plugins/jspsych-image-keyboard-response.js"></script>
7
- <script src="../plugins/jspsych-html-keyboard-response.js"></script>
8
- <script src="../plugins/jspsych-webgazer-init-camera.js"></script>
9
- <script src="../plugins/jspsych-webgazer-calibrate.js"></script>
10
- <script src="js/webgazer.js"></script>
11
- <script src="../extensions/jspsych-ext-webgazer.js"></script>
12
- <link rel="stylesheet" href="../css/jspsych.css">
13
- </head>
14
- <body></body>
15
- <script>
16
-
17
- var preload = {
18
- type: 'preload',
19
- images: ['img/blue.png']
20
- }
21
-
22
- var init_camera = {
23
- type: 'webgazer-init-camera'
24
- }
25
-
26
- var validation = {
27
- type: 'webgazer-calibrate',
28
- }
29
-
30
- var start = {
31
- type: 'html-keyboard-response',
32
- stimulus: 'Press any key to start.'
33
- }
34
-
35
- var trial = {
36
- type: 'image-keyboard-response',
37
- stimulus: 'img/blue.png',
38
- render_on_canvas: false,
39
- choices: jsPsych.NO_KEYS,
40
- trial_duration: 1000,
41
- extensions: [
42
- {
43
- type: 'webgazer',
44
- params: {targets: ['#jspsych-image-keyboard-response-stimulus']}
45
- }
46
- ]
47
- }
48
-
49
- jsPsych.init({
50
- timeline: [preload, init_camera, validation, start, trial],
51
- extensions: [
52
- {type: 'webgazer'}
53
- ],
54
- on_finish: function() {
55
- jsPsych.data.displayData();
56
- }
57
- })
58
-
59
- </script>
60
- </html>
@@ -1,185 +0,0 @@
1
- jsPsych.extensions['webgazer'] = (function () {
2
-
3
- var extension = {};
4
-
5
- // private state for the extension
6
- // extension authors can define public functions to interact
7
- // with the state. recommend not exposing state directly
8
- // so that state manipulations are checked.
9
- var state = {};
10
-
11
- // required, will be called at jsPsych.init
12
- // should return a Promise
13
- extension.initialize = function (params) {
14
- return new Promise(function(resolve, reject){
15
- if (typeof params.webgazer === 'undefined') {
16
- if (window.webgazer) {
17
- state.webgazer = window.webgazer;
18
- } else {
19
- reject(new Error('webgazer extension failed to initialize. webgazer.js not loaded. Load webgazer.js before calling jsPsych.init()'));
20
- }
21
- } else {
22
- state.webgazer = params.webgazer;
23
- }
24
-
25
- if (typeof params.round_predictions === 'undefined'){
26
- state.round_predictions = true;
27
- } else {
28
- state.round_predictions = params.round_predictions;
29
- }
30
-
31
- // sets up event handler for webgazer data
32
- state.webgazer.setGazeListener(handleGazeDataUpdate);
33
-
34
- // starts webgazer, and once it initializes we stop mouseCalibration and
35
- // pause webgazer data.
36
- state.webgazer.begin().then(function () {
37
- extension.stopMouseCalibration();
38
- extension.pause();
39
- resolve();
40
- })
41
-
42
- // hide video by default
43
- extension.hideVideo();
44
-
45
- // hide predictions by default
46
- extension.hidePredictions();
47
- })
48
- }
49
-
50
- // required, will be called when the trial starts (before trial loads)
51
- extension.on_start = function (params) {
52
- state.currentTrialData = [];
53
- state.currentTrialTargets = [];
54
- }
55
-
56
- // required will be called when the trial loads
57
- extension.on_load = function (params) {
58
-
59
- // set current trial start time
60
- state.currentTrialStart = performance.now();
61
-
62
- // resume data collection
63
- state.webgazer.resume();
64
-
65
- // set internal flag
66
- state.activeTrial = true;
67
-
68
- // record bounding box of any elements in params.targets
69
- if(typeof params !== 'undefined'){
70
- if(typeof params.targets !== 'undefined'){
71
- for(var i=0; i<params.targets.length; i++){
72
- var target = document.querySelector(params.targets[i]);
73
- if(target !== null){
74
- var bounding_rect = target.getBoundingClientRect();
75
- state.currentTrialTargets.push({
76
- selector: params.targets[i],
77
- top: bounding_rect.top,
78
- bottom: bounding_rect.bottom,
79
- left: bounding_rect.left,
80
- right: bounding_rect.right
81
- })
82
- }
83
- }
84
- }
85
- }
86
- }
87
-
88
- // required, will be called when jsPsych.finishTrial() is called
89
- // must return data object to be merged into data.
90
- extension.on_finish = function (params) {
91
- // pause the eye tracker
92
- state.webgazer.pause();
93
-
94
- // set internal flag
95
- state.activeTrial = false;
96
-
97
- // send back the gazeData
98
- return {
99
- webgazer_data: state.currentTrialData,
100
- webgazer_targets: state.currentTrialTargets
101
- }
102
- }
103
-
104
- extension.faceDetected = function () {
105
- return state.webgazer.getTracker().predictionReady;
106
- }
107
-
108
- extension.showPredictions = function () {
109
- state.webgazer.showPredictionPoints(true);
110
- }
111
-
112
- extension.hidePredictions = function () {
113
- state.webgazer.showPredictionPoints(false);
114
- }
115
-
116
- extension.showVideo = function () {
117
- state.webgazer.showVideo(true);
118
- state.webgazer.showFaceOverlay(true);
119
- state.webgazer.showFaceFeedbackBox(true);
120
- }
121
-
122
- extension.hideVideo = function () {
123
- state.webgazer.showVideo(false);
124
- state.webgazer.showFaceOverlay(false);
125
- state.webgazer.showFaceFeedbackBox(false);
126
- }
127
-
128
- extension.resume = function () {
129
- state.webgazer.resume();
130
- }
131
-
132
- extension.pause = function () {
133
- state.webgazer.pause();
134
- }
135
-
136
- extension.stopMouseCalibration = function () {
137
- state.webgazer.removeMouseEventListeners()
138
- }
139
-
140
- extension.startMouseCalibration = function () {
141
- state.webgazer.addMouseEventListeners()
142
- }
143
-
144
- extension.calibratePoint = function (x, y) {
145
- state.webgazer.recordScreenPosition(x, y, 'click');
146
- }
147
-
148
- extension.setRegressionType = function (regression_type) {
149
- var valid_regression_models = ['ridge', 'weigthedRidge', 'threadedRidge'];
150
- if (valid_regression_models.includes(regression_type)) {
151
- state.webgazer.setRegression(regression_type)
152
- } else {
153
- console.warn('Invalid regression_type parameter for webgazer.setRegressionType. Valid options are ridge, weightedRidge, and threadedRidge.')
154
- }
155
- }
156
-
157
- extension.getCurrentPrediction = async function () {
158
- var prediction = await state.webgazer.getCurrentPrediction();
159
- if(state.round_predictions){
160
- prediction.x = Math.round(prediction.x);
161
- prediction.y = Math.round(prediction.y);
162
- }
163
- return prediction;
164
- }
165
-
166
- // extension.addGazeDataUpdateListener(listener){
167
- // state.webgazer.setGazeListener(listener);
168
- // }
169
-
170
- function handleGazeDataUpdate(gazeData, elapsedTime) {
171
- if (gazeData !== null && state.activeTrial) {
172
- var d = {
173
- x: state.round_predictions ? Math.round(gazeData.x) : gazeData.x,
174
- y: state.round_predictions ? Math.round(gazeData.y) : gazeData.y,
175
- t: Math.round(performance.now() - state.currentTrialStart)
176
- }
177
- state.currentTrialData.push(d); // add data to current trial's data
178
- }
179
-
180
- }
181
-
182
- return extension;
183
-
184
- })();
185
-