jspsych 6.2.0 → 7.1.0

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 (360) hide show
  1. package/README.md +43 -29
  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 -661
  59. package/docs/core_library/jspsych-data.md +0 -589
  60. package/docs/core_library/jspsych-pluginAPI.md +0 -510
  61. package/docs/core_library/jspsych-randomization.md +0 -397
  62. package/docs/core_library/jspsych-turk.md +0 -102
  63. package/docs/img/blue.png +0 -0
  64. package/docs/img/folder-setup.png +0 -0
  65. package/docs/img/folder-with-html.png +0 -0
  66. package/docs/img/githubreleases.jpg +0 -0
  67. package/docs/img/jspsych-favicon.png +0 -0
  68. package/docs/img/jspsych-logo-no-text-mono.svg +0 -493
  69. package/docs/img/jspsych-logo.jpg +0 -0
  70. package/docs/img/orange.png +0 -0
  71. package/docs/img/palmer_stim.png +0 -0
  72. package/docs/img/progress_bar.png +0 -0
  73. package/docs/img/visual_search_example.jpg +0 -0
  74. package/docs/index.md +0 -9
  75. package/docs/overview/browser-device-support.md +0 -35
  76. package/docs/overview/callbacks.md +0 -140
  77. package/docs/overview/data.md +0 -281
  78. package/docs/overview/exclude-browser.md +0 -32
  79. package/docs/overview/experiment-options.md +0 -121
  80. package/docs/overview/fullscreen.md +0 -36
  81. package/docs/overview/media-preloading.md +0 -91
  82. package/docs/overview/mturk.md +0 -77
  83. package/docs/overview/progress-bar.md +0 -110
  84. package/docs/overview/record-browser-interactions.md +0 -23
  85. package/docs/overview/running-experiments.md +0 -95
  86. package/docs/overview/timeline.md +0 -387
  87. package/docs/overview/trial.md +0 -142
  88. package/docs/plugins/creating-a-plugin.md +0 -79
  89. package/docs/plugins/jspsych-animation.md +0 -40
  90. package/docs/plugins/jspsych-audio-button-response.md +0 -60
  91. package/docs/plugins/jspsych-audio-keyboard-response.md +0 -58
  92. package/docs/plugins/jspsych-audio-slider-response.md +0 -53
  93. package/docs/plugins/jspsych-call-function.md +0 -81
  94. package/docs/plugins/jspsych-canvas-button-response.md +0 -66
  95. package/docs/plugins/jspsych-canvas-keyboard-response.md +0 -68
  96. package/docs/plugins/jspsych-canvas-slider-response.md +0 -89
  97. package/docs/plugins/jspsych-categorize-animation.md +0 -60
  98. package/docs/plugins/jspsych-categorize-html.md +0 -52
  99. package/docs/plugins/jspsych-categorize-image.md +0 -53
  100. package/docs/plugins/jspsych-cloze.md +0 -45
  101. package/docs/plugins/jspsych-external-html.md +0 -70
  102. package/docs/plugins/jspsych-free-sort.md +0 -55
  103. package/docs/plugins/jspsych-fullscreen.md +0 -57
  104. package/docs/plugins/jspsych-html-button-response.md +0 -42
  105. package/docs/plugins/jspsych-html-keyboard-response.md +0 -51
  106. package/docs/plugins/jspsych-html-slider-response.md +0 -45
  107. package/docs/plugins/jspsych-iat-html.md +0 -64
  108. package/docs/plugins/jspsych-iat-image.md +0 -64
  109. package/docs/plugins/jspsych-image-button-response.md +0 -46
  110. package/docs/plugins/jspsych-image-keyboard-response.md +0 -57
  111. package/docs/plugins/jspsych-image-slider-response.md +0 -52
  112. package/docs/plugins/jspsych-instructions.md +0 -58
  113. package/docs/plugins/jspsych-maxdiff.md +0 -42
  114. package/docs/plugins/jspsych-rdk.md +0 -119
  115. package/docs/plugins/jspsych-reconstruction.md +0 -48
  116. package/docs/plugins/jspsych-resize.md +0 -39
  117. package/docs/plugins/jspsych-same-different-html.md +0 -53
  118. package/docs/plugins/jspsych-same-different-image.md +0 -66
  119. package/docs/plugins/jspsych-serial-reaction-time-mouse.md +0 -50
  120. package/docs/plugins/jspsych-serial-reaction-time.md +0 -57
  121. package/docs/plugins/jspsych-survey-html-form.md +0 -50
  122. package/docs/plugins/jspsych-survey-likert.md +0 -70
  123. package/docs/plugins/jspsych-survey-multi-choice.md +0 -48
  124. package/docs/plugins/jspsych-survey-multi-select.md +0 -53
  125. package/docs/plugins/jspsych-survey-text.md +0 -63
  126. package/docs/plugins/jspsych-video-button-response.md +0 -52
  127. package/docs/plugins/jspsych-video-keyboard-response.md +0 -48
  128. package/docs/plugins/jspsych-video-slider-response.md +0 -58
  129. package/docs/plugins/jspsych-visual-search-circle.md +0 -52
  130. package/docs/plugins/jspsych-vsl-animate-occlusion.md +0 -55
  131. package/docs/plugins/jspsych-vsl-grid-scene.md +0 -62
  132. package/docs/plugins/overview.md +0 -111
  133. package/docs/tutorials/hello-world.md +0 -144
  134. package/docs/tutorials/rt-task.md +0 -1107
  135. package/examples/add-to-end-of-timeline.html +0 -32
  136. package/examples/conditional-and-loop-functions.html +0 -63
  137. package/examples/css/jquery-ui.css +0 -1225
  138. package/examples/data-add-properties.html +0 -40
  139. package/examples/data-as-function.html +0 -36
  140. package/examples/data-from-timeline.html +0 -45
  141. package/examples/data-from-url.html +0 -21
  142. package/examples/demo-flanker.html +0 -108
  143. package/examples/demo-simple-rt-task.html +0 -104
  144. package/examples/demos/demo_1.html +0 -29
  145. package/examples/demos/demo_2.html +0 -43
  146. package/examples/demos/demo_3.html +0 -58
  147. package/examples/display-element-to-embed-experiment.html +0 -73
  148. package/examples/end-active-node.html +0 -52
  149. package/examples/end-experiment.html +0 -43
  150. package/examples/exclusions.html +0 -32
  151. package/examples/external_html/simple_consent.html +0 -4
  152. package/examples/img/1.gif +0 -0
  153. package/examples/img/10.gif +0 -0
  154. package/examples/img/11.gif +0 -0
  155. package/examples/img/12.gif +0 -0
  156. package/examples/img/2.gif +0 -0
  157. package/examples/img/3.gif +0 -0
  158. package/examples/img/4.gif +0 -0
  159. package/examples/img/5.gif +0 -0
  160. package/examples/img/6.gif +0 -0
  161. package/examples/img/7.gif +0 -0
  162. package/examples/img/8.gif +0 -0
  163. package/examples/img/9.gif +0 -0
  164. package/examples/img/age/of1.jpg +0 -0
  165. package/examples/img/age/of2.jpg +0 -0
  166. package/examples/img/age/of3.jpg +0 -0
  167. package/examples/img/age/om1.jpg +0 -0
  168. package/examples/img/age/om2.jpg +0 -0
  169. package/examples/img/age/om3.jpg +0 -0
  170. package/examples/img/age/yf1.jpg +0 -0
  171. package/examples/img/age/yf4.jpg +0 -0
  172. package/examples/img/age/yf5.jpg +0 -0
  173. package/examples/img/age/ym2.jpg +0 -0
  174. package/examples/img/age/ym3.jpg +0 -0
  175. package/examples/img/age/ym5.jpg +0 -0
  176. package/examples/img/backwardN.gif +0 -0
  177. package/examples/img/blue.png +0 -0
  178. package/examples/img/con1.png +0 -0
  179. package/examples/img/con2.png +0 -0
  180. package/examples/img/fixation.gif +0 -0
  181. package/examples/img/happy_face_1.jpg +0 -0
  182. package/examples/img/happy_face_2.jpg +0 -0
  183. package/examples/img/happy_face_3.jpg +0 -0
  184. package/examples/img/happy_face_4.jpg +0 -0
  185. package/examples/img/inc1.png +0 -0
  186. package/examples/img/inc2.png +0 -0
  187. package/examples/img/normalN.gif +0 -0
  188. package/examples/img/orange.png +0 -0
  189. package/examples/img/redX.png +0 -0
  190. package/examples/img/ribbon.jpg +0 -0
  191. package/examples/img/sad_face_1.jpg +0 -0
  192. package/examples/img/sad_face_2.jpg +0 -0
  193. package/examples/img/sad_face_3.jpg +0 -0
  194. package/examples/img/sad_face_4.jpg +0 -0
  195. package/examples/js/snap.svg-min.js +0 -21
  196. package/examples/jspsych-RDK.html +0 -58
  197. package/examples/jspsych-animation.html +0 -33
  198. package/examples/jspsych-audio-button-response.html +0 -52
  199. package/examples/jspsych-audio-keyboard-response.html +0 -62
  200. package/examples/jspsych-audio-slider-response.html +0 -55
  201. package/examples/jspsych-call-function.html +0 -32
  202. package/examples/jspsych-canvas-button-response.html +0 -95
  203. package/examples/jspsych-canvas-keyboard-response.html +0 -78
  204. package/examples/jspsych-canvas-slider-response.html +0 -67
  205. package/examples/jspsych-categorize-animation.html +0 -46
  206. package/examples/jspsych-categorize-html.html +0 -38
  207. package/examples/jspsych-categorize-image.html +0 -38
  208. package/examples/jspsych-cloze.html +0 -42
  209. package/examples/jspsych-free-sort.html +0 -97
  210. package/examples/jspsych-fullscreen.html +0 -44
  211. package/examples/jspsych-html-button-response.html +0 -46
  212. package/examples/jspsych-html-keyboard-response.html +0 -42
  213. package/examples/jspsych-html-slider-response.html +0 -53
  214. package/examples/jspsych-iat.html +0 -510
  215. package/examples/jspsych-image-button-response.html +0 -84
  216. package/examples/jspsych-image-keyboard-response.html +0 -78
  217. package/examples/jspsych-image-slider-response.html +0 -76
  218. package/examples/jspsych-instructions.html +0 -37
  219. package/examples/jspsych-maxdiff.html +0 -33
  220. package/examples/jspsych-reconstruction.html +0 -43
  221. package/examples/jspsych-resize.html +0 -34
  222. package/examples/jspsych-same-different-html.html +0 -28
  223. package/examples/jspsych-same-different-image.html +0 -33
  224. package/examples/jspsych-serial-reaction-time-mouse.html +0 -98
  225. package/examples/jspsych-serial-reaction-time.html +0 -54
  226. package/examples/jspsych-survey-html-form.html +0 -33
  227. package/examples/jspsych-survey-likert.html +0 -42
  228. package/examples/jspsych-survey-multi-choice.html +0 -40
  229. package/examples/jspsych-survey-multi-select.html +0 -42
  230. package/examples/jspsych-survey-text.html +0 -34
  231. package/examples/jspsych-video-button-response.html +0 -57
  232. package/examples/jspsych-video-keyboard-response.html +0 -53
  233. package/examples/jspsych-video-slider-response.html +0 -55
  234. package/examples/jspsych-visual-search-circle.html +0 -58
  235. package/examples/jspsych-vsl-animate-occlusion.html +0 -29
  236. package/examples/jspsych-vsl-grid-scene.html +0 -41
  237. package/examples/lexical-decision.html +0 -132
  238. package/examples/manual-preloading.html +0 -53
  239. package/examples/pause-unpause.html +0 -33
  240. package/examples/progress-bar.html +0 -62
  241. package/examples/sound/hammer.mp3 +0 -0
  242. package/examples/sound/sound.mp3 +0 -0
  243. package/examples/sound/speech_blue.mp3 +0 -0
  244. package/examples/sound/speech_green.mp3 +0 -0
  245. package/examples/sound/speech_joke.mp3 +0 -0
  246. package/examples/sound/speech_red.mp3 +0 -0
  247. package/examples/sound/tone.mp3 +0 -0
  248. package/examples/timeline-variables-sampling.html +0 -50
  249. package/examples/timeline-variables.html +0 -55
  250. package/examples/video/sample_video.mp4 +0 -0
  251. package/jspsych.js +0 -2796
  252. package/license.txt +0 -21
  253. package/mkdocs.yml +0 -104
  254. package/plugins/jspsych-animation.js +0 -189
  255. package/plugins/jspsych-audio-button-response.js +0 -247
  256. package/plugins/jspsych-audio-keyboard-response.js +0 -204
  257. package/plugins/jspsych-audio-slider-response.js +0 -262
  258. package/plugins/jspsych-call-function.js +0 -58
  259. package/plugins/jspsych-canvas-button-response.js +0 -199
  260. package/plugins/jspsych-canvas-keyboard-response.js +0 -155
  261. package/plugins/jspsych-canvas-slider-response.js +0 -207
  262. package/plugins/jspsych-categorize-animation.js +0 -266
  263. package/plugins/jspsych-categorize-html.js +0 -220
  264. package/plugins/jspsych-categorize-image.js +0 -222
  265. package/plugins/jspsych-cloze.js +0 -112
  266. package/plugins/jspsych-external-html.js +0 -112
  267. package/plugins/jspsych-free-sort.js +0 -444
  268. package/plugins/jspsych-fullscreen.js +0 -104
  269. package/plugins/jspsych-html-button-response.js +0 -188
  270. package/plugins/jspsych-html-keyboard-response.js +0 -149
  271. package/plugins/jspsych-html-slider-response.js +0 -202
  272. package/plugins/jspsych-iat-html.js +0 -284
  273. package/plugins/jspsych-iat-image.js +0 -286
  274. package/plugins/jspsych-image-button-response.js +0 -311
  275. package/plugins/jspsych-image-keyboard-response.js +0 -247
  276. package/plugins/jspsych-image-slider-response.js +0 -353
  277. package/plugins/jspsych-instructions.js +0 -237
  278. package/plugins/jspsych-maxdiff.js +0 -174
  279. package/plugins/jspsych-rdk.js +0 -1373
  280. package/plugins/jspsych-reconstruction.js +0 -134
  281. package/plugins/jspsych-resize.js +0 -166
  282. package/plugins/jspsych-same-different-html.js +0 -168
  283. package/plugins/jspsych-same-different-image.js +0 -169
  284. package/plugins/jspsych-serial-reaction-time-mouse.js +0 -213
  285. package/plugins/jspsych-serial-reaction-time.js +0 -247
  286. package/plugins/jspsych-survey-html-form.js +0 -171
  287. package/plugins/jspsych-survey-likert.js +0 -195
  288. package/plugins/jspsych-survey-multi-choice.js +0 -208
  289. package/plugins/jspsych-survey-multi-select.js +0 -232
  290. package/plugins/jspsych-survey-text.js +0 -185
  291. package/plugins/jspsych-video-button-response.js +0 -320
  292. package/plugins/jspsych-video-keyboard-response.js +0 -279
  293. package/plugins/jspsych-video-slider-response.js +0 -351
  294. package/plugins/jspsych-visual-search-circle.js +0 -259
  295. package/plugins/jspsych-vsl-animate-occlusion.js +0 -196
  296. package/plugins/jspsych-vsl-grid-scene.js +0 -103
  297. package/plugins/template/jspsych-plugin-template.js +0 -35
  298. package/tests/README.md +0 -7
  299. package/tests/jsPsych/default-iti.test.js +0 -51
  300. package/tests/jsPsych/default-parameters.test.js +0 -58
  301. package/tests/jsPsych/endexperiment.test.js +0 -49
  302. package/tests/jsPsych/events.test.js +0 -369
  303. package/tests/jsPsych/init.test.js +0 -48
  304. package/tests/jsPsych/loads.test.js +0 -7
  305. package/tests/jsPsych/min-rt.test.js +0 -58
  306. package/tests/jsPsych/progressbar.test.js +0 -202
  307. package/tests/jsPsych/timeline-variables.test.js +0 -254
  308. package/tests/jsPsych/timelines.test.js +0 -498
  309. package/tests/jsPsych.data/datacollection.test.js +0 -116
  310. package/tests/jsPsych.data/datacolumn.test.js +0 -50
  311. package/tests/jsPsych.data/datamodule.test.js +0 -152
  312. package/tests/jsPsych.data/dataparameter.test.js +0 -251
  313. package/tests/jsPsych.data/interactions.test.js +0 -109
  314. package/tests/jsPsych.pluginAPI/pluginapi.test.js +0 -144
  315. package/tests/jsPsych.randomization/randomziation.test.js +0 -27
  316. package/tests/jsPsych.utils/utils.test.js +0 -58
  317. package/tests/media/blue.png +0 -0
  318. package/tests/media/orange.png +0 -0
  319. package/tests/media/sample_video.mp4 +0 -0
  320. package/tests/media/sound.mp3 +0 -0
  321. package/tests/plugins/plugin-animation.test.js +0 -35
  322. package/tests/plugins/plugin-audio-button-response.test.js +0 -15
  323. package/tests/plugins/plugin-audio-keyboard-response.test.js +0 -15
  324. package/tests/plugins/plugin-audio-slider-response.test.js +0 -15
  325. package/tests/plugins/plugin-call-function.test.js +0 -49
  326. package/tests/plugins/plugin-categorize-animation.test.js +0 -274
  327. package/tests/plugins/plugin-categorize-html.test.js +0 -17
  328. package/tests/plugins/plugin-categorize-image.test.js +0 -17
  329. package/tests/plugins/plugin-cloze.test.js +0 -140
  330. package/tests/plugins/plugin-free-sort.test.js +0 -112
  331. package/tests/plugins/plugin-fullscreen.test.js +0 -41
  332. package/tests/plugins/plugin-html-button-response.test.js +0 -161
  333. package/tests/plugins/plugin-html-keyboard-response.test.js +0 -139
  334. package/tests/plugins/plugin-html-slider-response.test.js +0 -155
  335. package/tests/plugins/plugin-iat-html.test.js +0 -328
  336. package/tests/plugins/plugin-iat-image.test.js +0 -308
  337. package/tests/plugins/plugin-image-button-response.test.js +0 -183
  338. package/tests/plugins/plugin-image-keyboard-response.test.js +0 -154
  339. package/tests/plugins/plugin-image-slider-response.test.js +0 -183
  340. package/tests/plugins/plugin-instructions.test.js +0 -66
  341. package/tests/plugins/plugin-maxdiff.test.js +0 -39
  342. package/tests/plugins/plugin-rdk.test.js +0 -17
  343. package/tests/plugins/plugin-reconstruction.test.js +0 -16
  344. package/tests/plugins/plugin-resize.test.js +0 -16
  345. package/tests/plugins/plugin-same-different-html.test.js +0 -17
  346. package/tests/plugins/plugin-same-different-image.test.js +0 -17
  347. package/tests/plugins/plugin-serial-reaction-time-mouse.test.js +0 -42
  348. package/tests/plugins/plugin-serial-reaction-time.test.js +0 -69
  349. package/tests/plugins/plugin-survey-html-form.test.js +0 -44
  350. package/tests/plugins/plugin-survey-likert.test.js +0 -48
  351. package/tests/plugins/plugin-survey-multi-choice.test.js +0 -48
  352. package/tests/plugins/plugin-survey-multi-select.test.js +0 -72
  353. package/tests/plugins/plugin-survey-text.test.js +0 -115
  354. package/tests/plugins/plugin-video-button-response.test.js +0 -35
  355. package/tests/plugins/plugin-video-keyboard-response.test.js +0 -35
  356. package/tests/plugins/plugin-video-slider-response.test.js +0 -34
  357. package/tests/plugins/plugin-visual-search-circle.test.js +0 -16
  358. package/tests/plugins/plugin-vsl-animate-occlusion.test.js +0 -16
  359. package/tests/plugins/plugin-vsl-grid-scene.test.js +0 -16
  360. package/tests/testing-utils.js +0 -13
@@ -1,279 +0,0 @@
1
- /**
2
- * jspsych-video-keyboard-response
3
- * Josh de Leeuw
4
- *
5
- * plugin for playing a video file and getting a keyboard response
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- **/
10
-
11
- jsPsych.plugins["video-keyboard-response"] = (function() {
12
-
13
- var plugin = {};
14
-
15
- jsPsych.pluginAPI.registerPreload('video-keyboard-response', 'stimulus', 'video');
16
-
17
- plugin.info = {
18
- name: 'video-keyboard-response',
19
- description: '',
20
- parameters: {
21
- stimulus: {
22
- type: jsPsych.plugins.parameterType.VIDEO,
23
- pretty_name: 'Video',
24
- default: undefined,
25
- description: 'The video file to play.'
26
- },
27
- choices: {
28
- type: jsPsych.plugins.parameterType.KEYCODE,
29
- pretty_name: 'Choices',
30
- array: true,
31
- default: jsPsych.ALL_KEYS,
32
- description: 'The keys the subject is allowed to press to respond to the stimulus.'
33
- },
34
- prompt: {
35
- type: jsPsych.plugins.parameterType.STRING,
36
- pretty_name: 'Prompt',
37
- default: null,
38
- description: 'Any content here will be displayed below the stimulus.'
39
- },
40
- width: {
41
- type: jsPsych.plugins.parameterType.INT,
42
- pretty_name: 'Width',
43
- default: '',
44
- description: 'The width of the video in pixels.'
45
- },
46
- height: {
47
- type: jsPsych.plugins.parameterType.INT,
48
- pretty_name: 'Height',
49
- default: '',
50
- description: 'The height of the video display in pixels.'
51
- },
52
- autoplay: {
53
- type: jsPsych.plugins.parameterType.BOOL,
54
- pretty_name: 'Autoplay',
55
- default: true,
56
- description: 'If true, the video will begin playing as soon as it has loaded.'
57
- },
58
- controls: {
59
- type: jsPsych.plugins.parameterType.BOOL,
60
- pretty_name: 'Controls',
61
- default: false,
62
- description: 'If true, the subject will be able to pause the video or move the playback to any point in the video.'
63
- },
64
- start: {
65
- type: jsPsych.plugins.parameterType.FLOAT,
66
- pretty_name: 'Start',
67
- default: null,
68
- description: 'Time to start the clip.'
69
- },
70
- stop: {
71
- type: jsPsych.plugins.parameterType.FLOAT,
72
- pretty_name: 'Stop',
73
- default: null,
74
- description: 'Time to stop the clip.'
75
- },
76
- rate: {
77
- type: jsPsych.plugins.parameterType.FLOAT,
78
- pretty_name: 'Rate',
79
- default: 1,
80
- description: 'The playback rate of the video. 1 is normal, <1 is slower, >1 is faster.'
81
- },
82
- trial_ends_after_video: {
83
- type: jsPsych.plugins.parameterType.BOOL,
84
- pretty_name: 'End trial after video finishes',
85
- default: false,
86
- description: 'If true, the trial will end immediately after the video finishes playing.'
87
- },
88
- trial_duration: {
89
- type: jsPsych.plugins.parameterType.INT,
90
- pretty_name: 'Trial duration',
91
- default: null,
92
- description: 'How long to show trial before it ends.'
93
- },
94
- response_ends_trial: {
95
- type: jsPsych.plugins.parameterType.BOOL,
96
- pretty_name: 'Response ends trial',
97
- default: true,
98
- description: 'If true, the trial will end when subject makes a response.'
99
- },
100
- response_allowed_while_playing: {
101
- type: jsPsych.plugins.parameterType.BOOL,
102
- pretty_name: 'Response allowed while playing',
103
- default: true,
104
- description: 'If true, then responses are allowed while the video is playing. '+
105
- 'If false, then the video must finish playing before a response is accepted.'
106
- }
107
- }
108
- }
109
-
110
- plugin.trial = function(display_element, trial) {
111
-
112
- // setup stimulus
113
- var video_html = '<div>'
114
- video_html += '<video id="jspsych-video-keyboard-response-stimulus"';
115
-
116
- if(trial.width) {
117
- video_html += ' width="'+trial.width+'"';
118
- }
119
- if(trial.height) {
120
- video_html += ' height="'+trial.height+'"';
121
- }
122
- if(trial.autoplay & (trial.start == null)){
123
- // if autoplay is true and the start time is specified, then the video will start automatically
124
- // via the play() method, rather than the autoplay attribute, to prevent showing the first frame
125
- video_html += " autoplay ";
126
- }
127
- if(trial.controls){
128
- video_html +=" controls ";
129
- }
130
- if (trial.start !== null) {
131
- // hide video element when page loads if the start time is specified,
132
- // to prevent the video element from showing the first frame
133
- video_html += ' style="visibility: hidden;"';
134
- }
135
- video_html +=">";
136
-
137
- var video_preload_blob = jsPsych.pluginAPI.getVideoBuffer(trial.stimulus[0]);
138
- if(!video_preload_blob) {
139
- for(var i=0; i<trial.stimulus.length; i++){
140
- var file_name = trial.stimulus[i];
141
- if(file_name.indexOf('?') > -1){
142
- file_name = file_name.substring(0, file_name.indexOf('?'));
143
- }
144
- var type = file_name.substr(file_name.lastIndexOf('.') + 1);
145
- type = type.toLowerCase();
146
- if (type == "mov") {
147
- console.warn('Warning: video-keyboard-response plugin does not reliably support .mov files.')
148
- }
149
- video_html+='<source src="' + file_name + '" type="video/'+type+'">';
150
- }
151
- }
152
- video_html += "</video>";
153
- video_html += "</div>";
154
-
155
- // add prompt if there is one
156
- if (trial.prompt !== null) {
157
- video_html += trial.prompt;
158
- }
159
-
160
- display_element.innerHTML = video_html;
161
-
162
- var video_element = display_element.querySelector('#jspsych-video-keyboard-response-stimulus');
163
-
164
- if(video_preload_blob){
165
- video_element.src = video_preload_blob;
166
- }
167
-
168
- video_element.onended = function(){
169
- if(trial.trial_ends_after_video){
170
- end_trial();
171
- }
172
- if ((trial.response_allowed_while_playing == false) & (!trial.trial_ends_after_video)) {
173
- // start keyboard listener
174
- var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
175
- callback_function: after_response,
176
- valid_responses: trial.choices,
177
- rt_method: 'performance',
178
- persist: false,
179
- allow_held_key: false,
180
- });
181
- }
182
- }
183
-
184
- video_element.playbackRate = trial.rate;
185
-
186
- // if video start time is specified, hide the video and set the starting time
187
- // before showing and playing, so that the video doesn't automatically show the first frame
188
- if(trial.start !== null){
189
- video_element.pause();
190
- video_element.currentTime = trial.start;
191
- video_element.onseeked = function() {
192
- video_element.style.visibility = "visible";
193
- if (trial.autoplay) {
194
- video_element.play();
195
- }
196
- }
197
- }
198
-
199
- if(trial.stop !== null){
200
- video_element.addEventListener('timeupdate', function(e){
201
- var currenttime = video_element.currentTime;
202
- if(currenttime >= trial.stop){
203
- video_element.pause();
204
- }
205
- })
206
- }
207
-
208
- // store response
209
- var response = {
210
- rt: null,
211
- key: null
212
- };
213
-
214
- // function to end trial when it is time
215
- function end_trial() {
216
-
217
- // kill any remaining setTimeout handlers
218
- jsPsych.pluginAPI.clearAllTimeouts();
219
-
220
- // kill keyboard listeners
221
- jsPsych.pluginAPI.cancelAllKeyboardResponses();
222
-
223
- // stop the video file if it is playing
224
- // remove end event listeners if they exist
225
- display_element.querySelector('#jspsych-video-keyboard-response-stimulus').pause();
226
- display_element.querySelector('#jspsych-video-keyboard-response-stimulus').onended = function(){ };
227
-
228
- // gather the data to store for the trial
229
- var trial_data = {
230
- "rt": response.rt,
231
- "stimulus": JSON.stringify(trial.stimulus),
232
- "key_press": response.key
233
- };
234
-
235
- // clear the display
236
- display_element.innerHTML = '';
237
-
238
- // move on to the next trial
239
- jsPsych.finishTrial(trial_data);
240
- }
241
-
242
- // function to handle responses by the subject
243
- var after_response = function(info) {
244
-
245
- // after a valid response, the stimulus will have the CSS class 'responded'
246
- // which can be used to provide visual feedback that a response was recorded
247
- display_element.querySelector('#jspsych-video-keyboard-response-stimulus').className += ' responded';
248
-
249
- // only record the first response
250
- if (response.key == null) {
251
- response = info;
252
- }
253
-
254
- if (trial.response_ends_trial) {
255
- end_trial();
256
- }
257
- };
258
-
259
- // start the response listener
260
- if ((trial.choices != jsPsych.NO_KEYS) & (trial.response_allowed_while_playing)) {
261
- var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
262
- callback_function: after_response,
263
- valid_responses: trial.choices,
264
- rt_method: 'performance',
265
- persist: false,
266
- allow_held_key: false,
267
- });
268
- }
269
-
270
- // end trial if time limit is set
271
- if (trial.trial_duration !== null) {
272
- jsPsych.pluginAPI.setTimeout(function() {
273
- end_trial();
274
- }, trial.trial_duration);
275
- }
276
- };
277
-
278
- return plugin;
279
- })();
@@ -1,351 +0,0 @@
1
- /**
2
- * jspsych-video-slider-response
3
- * Josh de Leeuw
4
- *
5
- * plugin for playing a video file and getting a slider response
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- **/
10
-
11
- jsPsych.plugins["video-slider-response"] = (function() {
12
-
13
- var plugin = {};
14
-
15
- jsPsych.pluginAPI.registerPreload('video-slider-response', 'stimulus', 'video');
16
-
17
- plugin.info = {
18
- name: 'video-slider-response',
19
- description: '',
20
- parameters: {
21
- stimulus: {
22
- type: jsPsych.plugins.parameterType.VIDEO,
23
- pretty_name: 'Video',
24
- default: undefined,
25
- description: 'The video file to play.'
26
- },
27
- prompt: {
28
- type: jsPsych.plugins.parameterType.STRING,
29
- pretty_name: 'Prompt',
30
- default: null,
31
- description: 'Any content here will be displayed below the stimulus.'
32
- },
33
- width: {
34
- type: jsPsych.plugins.parameterType.INT,
35
- pretty_name: 'Width',
36
- default: '',
37
- description: 'The width of the video in pixels.'
38
- },
39
- height: {
40
- type: jsPsych.plugins.parameterType.INT,
41
- pretty_name: 'Height',
42
- default: '',
43
- description: 'The height of the video display in pixels.'
44
- },
45
- autoplay: {
46
- type: jsPsych.plugins.parameterType.BOOL,
47
- pretty_name: 'Autoplay',
48
- default: true,
49
- description: 'If true, the video will begin playing as soon as it has loaded.'
50
- },
51
- controls: {
52
- type: jsPsych.plugins.parameterType.BOOL,
53
- pretty_name: 'Controls',
54
- default: false,
55
- description: 'If true, the subject will be able to pause the video or move the playback to any point in the video.'
56
- },
57
- start: {
58
- type: jsPsych.plugins.parameterType.FLOAT,
59
- pretty_name: 'Start',
60
- default: null,
61
- description: 'Time to start the clip.'
62
- },
63
- stop: {
64
- type: jsPsych.plugins.parameterType.FLOAT,
65
- pretty_name: 'Stop',
66
- default: null,
67
- description: 'Time to stop the clip.'
68
- },
69
- rate: {
70
- type: jsPsych.plugins.parameterType.FLOAT,
71
- pretty_name: 'Rate',
72
- default: 1,
73
- description: 'The playback rate of the video. 1 is normal, <1 is slower, >1 is faster.'
74
- },
75
- min: {
76
- type: jsPsych.plugins.parameterType.INT,
77
- pretty_name: 'Min slider',
78
- default: 0,
79
- description: 'Sets the minimum value of the slider.'
80
- },
81
- max: {
82
- type: jsPsych.plugins.parameterType.INT,
83
- pretty_name: 'Max slider',
84
- default: 100,
85
- description: 'Sets the maximum value of the slider',
86
- },
87
- slider_start: {
88
- type: jsPsych.plugins.parameterType.INT,
89
- pretty_name: 'Slider starting value',
90
- default: 50,
91
- description: 'Sets the starting value of the slider',
92
- },
93
- step: {
94
- type: jsPsych.plugins.parameterType.INT,
95
- pretty_name: 'Step',
96
- default: 1,
97
- description: 'Sets the step of the slider'
98
- },
99
- labels: {
100
- type: jsPsych.plugins.parameterType.HTML_STRING,
101
- pretty_name:'Labels',
102
- default: [],
103
- array: true,
104
- description: 'Labels of the slider.',
105
- },
106
- slider_width: {
107
- type: jsPsych.plugins.parameterType.INT,
108
- pretty_name:'Slider width',
109
- default: null,
110
- description: 'Width of the slider in pixels.'
111
- },
112
- button_label: {
113
- type: jsPsych.plugins.parameterType.STRING,
114
- pretty_name: 'Button label',
115
- default: 'Continue',
116
- array: false,
117
- description: 'Label of the button to advance.'
118
- },
119
- require_movement: {
120
- type: jsPsych.plugins.parameterType.BOOL,
121
- pretty_name: 'Require movement',
122
- default: false,
123
- description: 'If true, the participant will have to move the slider before continuing.'
124
- },
125
- trial_ends_after_video: {
126
- type: jsPsych.plugins.parameterType.BOOL,
127
- pretty_name: 'End trial after video finishes',
128
- default: false,
129
- description: 'If true, the trial will end immediately after the video finishes playing.'
130
- },
131
- trial_duration: {
132
- type: jsPsych.plugins.parameterType.INT,
133
- pretty_name: 'Trial duration',
134
- default: null,
135
- description: 'How long to show trial before it ends.'
136
- },
137
- response_ends_trial: {
138
- type: jsPsych.plugins.parameterType.BOOL,
139
- pretty_name: 'Response ends trial',
140
- default: true,
141
- description: 'If true, the trial will end when subject makes a response.'
142
- },
143
- response_allowed_while_playing: {
144
- type: jsPsych.plugins.parameterType.BOOL,
145
- pretty_name: 'Response allowed while playing',
146
- default: true,
147
- description: 'If true, then responses are allowed while the video is playing. '+
148
- 'If false, then the video must finish playing before a response is accepted.'
149
- }
150
- }
151
- }
152
-
153
- plugin.trial = function(display_element, trial) {
154
-
155
- // half of the thumb width value from jspsych.css, used to adjust the label positions
156
- var half_thumb_width = 7.5;
157
-
158
- // setup stimulus
159
- var video_html = '<video id="jspsych-video-slider-response-stimulus-video"';
160
-
161
- if(trial.width) {
162
- video_html += ' width="'+trial.width+'"';
163
- }
164
- if(trial.height) {
165
- video_html += ' height="'+trial.height+'"';
166
- }
167
- if(trial.autoplay & (trial.start == null)){
168
- // if autoplay is true and the start time is specified, then the video will start automatically
169
- // via the play() method, rather than the autoplay attribute, to prevent showing the first frame
170
- video_html += " autoplay ";
171
- }
172
- if(trial.controls){
173
- video_html +=" controls ";
174
- }
175
- if (trial.start !== null) {
176
- // hide video element when page loads if the start time is specified,
177
- // to prevent the video element from showing the first frame
178
- video_html += ' style="visibility: hidden;"';
179
- }
180
- video_html +=">";
181
-
182
- var video_preload_blob = jsPsych.pluginAPI.getVideoBuffer(trial.stimulus[0]);
183
- if(!video_preload_blob) {
184
- for(var i=0; i<trial.stimulus.length; i++){
185
- var file_name = trial.stimulus[i];
186
- if(file_name.indexOf('?') > -1){
187
- file_name = file_name.substring(0, file_name.indexOf('?'));
188
- }
189
- var type = file_name.substr(file_name.lastIndexOf('.') + 1);
190
- type = type.toLowerCase();
191
- if (type == "mov") {
192
- console.warn('Warning: video-slider-response plugin does not reliably support .mov files.')
193
- }
194
- video_html+='<source src="' + file_name + '" type="video/'+type+'">';
195
- }
196
- }
197
- video_html += "</video>";
198
-
199
- var html = '<div id="jspsych-video-slider-response-wrapper" style="margin: 100px 0px;">';
200
- html += '<div id="jspsych-video-slider-response-stimulus">' + video_html + '</div>';
201
- html += '<div class="jspsych-video-slider-response-container" style="position:relative; margin: 0 auto 3em auto; width:';
202
- if (trial.slider_width !== null) {
203
- html += trial.slider_width+'px;'
204
- } else {
205
- html += 'auto;'
206
- }
207
- html += '">';
208
- html += '<input type="range" class="jspsych-slider" value="'+trial.slider_start+'" min="'+trial.min+'" max="'+trial.max+'" step="'+trial.step+'" id="jspsych-video-slider-response-response"';
209
- if (!trial.response_allowed_while_playing) {
210
- html += ' disabled';
211
- }
212
- html += '></input><div>'
213
- for(var j=0; j < trial.labels.length; j++){
214
- var label_width_perc = 100/(trial.labels.length-1);
215
- var percent_of_range = j * (100/(trial.labels.length - 1));
216
- var percent_dist_from_center = ((percent_of_range-50)/50)*100;
217
- var offset = (percent_dist_from_center * half_thumb_width)/100;
218
- html += '<div style="border: 1px solid transparent; display: inline-block; position: absolute; '+
219
- 'left:calc('+percent_of_range+'% - ('+label_width_perc+'% / 2) - '+offset+'px); text-align: center; width: '+label_width_perc+'%;">';
220
- html += '<span style="text-align: center; font-size: 80%;">'+trial.labels[j]+'</span>';
221
- html += '</div>'
222
- }
223
- html += '</div>';
224
- html += '</div>';
225
- html += '</div>';
226
-
227
- // add prompt if there is one
228
- if (trial.prompt !== null) {
229
- html += '<div>'+trial.prompt+'</div>';
230
- }
231
-
232
- // add submit button
233
- var next_disabled_attribute = "";
234
- if (trial.require_movement | !trial.response_allowed_while_playing) {
235
- next_disabled_attribute = "disabled";
236
- }
237
- html += '<button id="jspsych-video-slider-response-next" class="jspsych-btn" '+ next_disabled_attribute + '>'+trial.button_label+'</button>';
238
-
239
- display_element.innerHTML = html;
240
-
241
- var video_element = display_element.querySelector('#jspsych-video-slider-response-stimulus-video');
242
-
243
- if(video_preload_blob){
244
- video_element.src = video_preload_blob;
245
- }
246
-
247
- video_element.onended = function(){
248
- if(trial.trial_ends_after_video){
249
- end_trial();
250
- } else if (!trial.response_allowed_while_playing) {
251
- enable_slider();
252
- }
253
- }
254
-
255
- video_element.playbackRate = trial.rate;
256
-
257
- // if video start time is specified, hide the video and set the starting time
258
- // before showing and playing, so that the video doesn't automatically show the first frame
259
- if(trial.start !== null){
260
- video_element.pause();
261
- video_element.currentTime = trial.start;
262
- video_element.onseeked = function() {
263
- video_element.style.visibility = "visible";
264
- if (trial.autoplay) {
265
- video_element.play();
266
- }
267
- }
268
- }
269
-
270
- if(trial.stop !== null){
271
- video_element.addEventListener('timeupdate', function(e){
272
- var currenttime = video_element.currentTime;
273
- if(currenttime >= trial.stop){
274
- video_element.pause();
275
- }
276
- })
277
- }
278
-
279
- if(trial.require_movement){
280
- display_element.querySelector('#jspsych-video-slider-response-response').addEventListener('click', function(){
281
- display_element.querySelector('#jspsych-video-slider-response-next').disabled = false;
282
- });
283
- }
284
-
285
- var startTime = performance.now();
286
-
287
- // store response
288
- var response = {
289
- rt: null,
290
- response: null
291
- };
292
-
293
- display_element.querySelector('#jspsych-video-slider-response-next').addEventListener('click', function() {
294
- // measure response time
295
- var endTime = performance.now();
296
- response.rt = endTime - startTime;
297
- response.response = display_element.querySelector('#jspsych-video-slider-response-response').valueAsNumber;
298
-
299
- if(trial.response_ends_trial){
300
- end_trial();
301
- } else {
302
- display_element.querySelector('#jspsych-video-slider-response-next').disabled = true;
303
- }
304
-
305
- });
306
-
307
- // function to end trial when it is time
308
- function end_trial() {
309
-
310
- // kill any remaining setTimeout handlers
311
- jsPsych.pluginAPI.clearAllTimeouts();
312
-
313
- // stop the video file if it is playing
314
- // remove any remaining end event handlers
315
- display_element.querySelector('#jspsych-video-slider-response-stimulus-video').pause();
316
- display_element.querySelector('#jspsych-video-slider-response-stimulus-video').onended = function() {};
317
-
318
- // gather the data to store for the trial
319
- var trial_data = {
320
- "rt": response.rt,
321
- "stimulus": JSON.stringify(trial.stimulus),
322
- "start": trial.start,
323
- "slider_start": trial.slider_start,
324
- "response": response.response
325
- };
326
-
327
- // clear the display
328
- display_element.innerHTML = '';
329
-
330
- // move on to the next trial
331
- jsPsych.finishTrial(trial_data);
332
- };
333
-
334
- // function to enable slider after video ends
335
- function enable_slider() {
336
- document.querySelector('#jspsych-video-slider-response-response').disabled = false;
337
- if (!trial.require_movement) {
338
- document.querySelector('#jspsych-video-slider-response-next').disabled = false;
339
- }
340
- }
341
-
342
- // end trial if time limit is set
343
- if (trial.trial_duration !== null) {
344
- jsPsych.pluginAPI.setTimeout(function() {
345
- end_trial();
346
- }, trial.trial_duration);
347
- }
348
- };
349
-
350
- return plugin;
351
- })();