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,104 +0,0 @@
1
- /* jspsych-fullscreen.js
2
- * Josh de Leeuw
3
- *
4
- * toggle fullscreen mode in the browser
5
- *
6
- */
7
-
8
- jsPsych.plugins.fullscreen = (function() {
9
-
10
- var plugin = {};
11
-
12
- plugin.info = {
13
- name: 'fullscreen',
14
- description: '',
15
- parameters: {
16
- fullscreen_mode: {
17
- type: jsPsych.plugins.parameterType.BOOL,
18
- pretty_name: 'Fullscreen mode',
19
- default: true,
20
- array: false,
21
- description: 'If true, experiment will enter fullscreen mode. If false, the browser will exit fullscreen mode.'
22
- },
23
- message: {
24
- type: jsPsych.plugins.parameterType.STRING,
25
- pretty_name: 'Message',
26
- default: '<p>The experiment will switch to full screen mode when you press the button below</p>',
27
- array: false,
28
- description: 'HTML content to display above the button to enter fullscreen mode.'
29
- },
30
- button_label: {
31
- type: jsPsych.plugins.parameterType.STRING,
32
- pretty_name: 'Button label',
33
- default: 'Continue',
34
- array: false,
35
- description: 'The text that appears on the button to enter fullscreen.'
36
- },
37
- delay_after: {
38
- type: jsPsych.plugins.parameterType.INT,
39
- pretty_name: 'Delay after',
40
- default: 1000,
41
- array: false,
42
- description: 'The length of time to delay after entering fullscreen mode before ending the trial.'
43
- },
44
- }
45
- }
46
-
47
- plugin.trial = function(display_element, trial) {
48
-
49
- // check if keys are allowed in fullscreen mode
50
- var keyboardNotAllowed = typeof Element !== 'undefined' && 'ALLOW_KEYBOARD_INPUT' in Element;
51
- if (keyboardNotAllowed) {
52
- // This is Safari, and keyboard events will be disabled. Don't allow fullscreen here.
53
- // do something else?
54
- endTrial();
55
- } else {
56
- if(trial.fullscreen_mode){
57
- display_element.innerHTML = trial.message + '<button id="jspsych-fullscreen-btn" class="jspsych-btn">'+trial.button_label+'</button>';
58
- var listener = display_element.querySelector('#jspsych-fullscreen-btn').addEventListener('click', function() {
59
- var element = document.documentElement;
60
- if (element.requestFullscreen) {
61
- element.requestFullscreen();
62
- } else if (element.mozRequestFullScreen) {
63
- element.mozRequestFullScreen();
64
- } else if (element.webkitRequestFullscreen) {
65
- element.webkitRequestFullscreen();
66
- } else if (element.msRequestFullscreen) {
67
- element.msRequestFullscreen();
68
- }
69
- endTrial();
70
- });
71
- } else {
72
- if (document.exitFullscreen) {
73
- document.exitFullscreen();
74
- } else if (document.msExitFullscreen) {
75
- document.msExitFullscreen();
76
- } else if (document.mozCancelFullScreen) {
77
- document.mozCancelFullScreen();
78
- } else if (document.webkitExitFullscreen) {
79
- document.webkitExitFullscreen();
80
- }
81
- endTrial();
82
- }
83
- }
84
-
85
- function endTrial() {
86
-
87
- display_element.innerHTML = '';
88
-
89
- jsPsych.pluginAPI.setTimeout(function(){
90
-
91
- var trial_data = {
92
- success: !keyboardNotAllowed
93
- };
94
-
95
- jsPsych.finishTrial(trial_data);
96
-
97
- }, trial.delay_after);
98
-
99
- }
100
-
101
- };
102
-
103
- return plugin;
104
- })();
@@ -1,188 +0,0 @@
1
- /**
2
- * jspsych-html-button-response
3
- * Josh de Leeuw
4
- *
5
- * plugin for displaying a stimulus and getting a keyboard response
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- **/
10
-
11
- jsPsych.plugins["html-button-response"] = (function() {
12
-
13
- var plugin = {};
14
-
15
- plugin.info = {
16
- name: 'html-button-response',
17
- description: '',
18
- parameters: {
19
- stimulus: {
20
- type: jsPsych.plugins.parameterType.HTML_STRING,
21
- pretty_name: 'Stimulus',
22
- default: undefined,
23
- description: 'The HTML string to be displayed'
24
- },
25
- choices: {
26
- type: jsPsych.plugins.parameterType.STRING,
27
- pretty_name: 'Choices',
28
- default: undefined,
29
- array: true,
30
- description: 'The labels for the buttons.'
31
- },
32
- button_html: {
33
- type: jsPsych.plugins.parameterType.STRING,
34
- pretty_name: 'Button HTML',
35
- default: '<button class="jspsych-btn">%choice%</button>',
36
- array: true,
37
- description: 'The html of the button. Can create own style.'
38
- },
39
- prompt: {
40
- type: jsPsych.plugins.parameterType.STRING,
41
- pretty_name: 'Prompt',
42
- default: null,
43
- description: 'Any content here will be displayed under the button.'
44
- },
45
- stimulus_duration: {
46
- type: jsPsych.plugins.parameterType.INT,
47
- pretty_name: 'Stimulus duration',
48
- default: null,
49
- description: 'How long to hide the stimulus.'
50
- },
51
- trial_duration: {
52
- type: jsPsych.plugins.parameterType.INT,
53
- pretty_name: 'Trial duration',
54
- default: null,
55
- description: 'How long to show the trial.'
56
- },
57
- margin_vertical: {
58
- type: jsPsych.plugins.parameterType.STRING,
59
- pretty_name: 'Margin vertical',
60
- default: '0px',
61
- description: 'The vertical margin of the button.'
62
- },
63
- margin_horizontal: {
64
- type: jsPsych.plugins.parameterType.STRING,
65
- pretty_name: 'Margin horizontal',
66
- default: '8px',
67
- description: 'The horizontal margin of the button.'
68
- },
69
- response_ends_trial: {
70
- type: jsPsych.plugins.parameterType.BOOL,
71
- pretty_name: 'Response ends trial',
72
- default: true,
73
- description: 'If true, then trial will end when user responds.'
74
- },
75
- }
76
- }
77
-
78
- plugin.trial = function(display_element, trial) {
79
-
80
- // display stimulus
81
- var html = '<div id="jspsych-html-button-response-stimulus">'+trial.stimulus+'</div>';
82
-
83
- //display buttons
84
- var buttons = [];
85
- if (Array.isArray(trial.button_html)) {
86
- if (trial.button_html.length == trial.choices.length) {
87
- buttons = trial.button_html;
88
- } else {
89
- console.error('Error in html-button-response plugin. The length of the button_html array does not equal the length of the choices array');
90
- }
91
- } else {
92
- for (var i = 0; i < trial.choices.length; i++) {
93
- buttons.push(trial.button_html);
94
- }
95
- }
96
- html += '<div id="jspsych-html-button-response-btngroup">';
97
- for (var i = 0; i < trial.choices.length; i++) {
98
- var str = buttons[i].replace(/%choice%/g, trial.choices[i]);
99
- html += '<div class="jspsych-html-button-response-button" style="display: inline-block; margin:'+trial.margin_vertical+' '+trial.margin_horizontal+'" id="jspsych-html-button-response-button-' + i +'" data-choice="'+i+'">'+str+'</div>';
100
- }
101
- html += '</div>';
102
-
103
- //show prompt if there is one
104
- if (trial.prompt !== null) {
105
- html += trial.prompt;
106
- }
107
- display_element.innerHTML = html;
108
-
109
- // start time
110
- var start_time = performance.now();
111
-
112
- // add event listeners to buttons
113
- for (var i = 0; i < trial.choices.length; i++) {
114
- display_element.querySelector('#jspsych-html-button-response-button-' + i).addEventListener('click', function(e){
115
- var choice = e.currentTarget.getAttribute('data-choice'); // don't use dataset for jsdom compatibility
116
- after_response(choice);
117
- });
118
- }
119
-
120
- // store response
121
- var response = {
122
- rt: null,
123
- button: null
124
- };
125
-
126
- // function to handle responses by the subject
127
- function after_response(choice) {
128
-
129
- // measure rt
130
- var end_time = performance.now();
131
- var rt = end_time - start_time;
132
- response.button = parseInt(choice);
133
- response.rt = rt;
134
-
135
- // after a valid response, the stimulus will have the CSS class 'responded'
136
- // which can be used to provide visual feedback that a response was recorded
137
- display_element.querySelector('#jspsych-html-button-response-stimulus').className += ' responded';
138
-
139
- // disable all the buttons after a response
140
- var btns = document.querySelectorAll('.jspsych-html-button-response-button button');
141
- for(var i=0; i<btns.length; i++){
142
- //btns[i].removeEventListener('click');
143
- btns[i].setAttribute('disabled', 'disabled');
144
- }
145
-
146
- if (trial.response_ends_trial) {
147
- end_trial();
148
- }
149
- };
150
-
151
- // function to end trial when it is time
152
- function end_trial() {
153
-
154
- // kill any remaining setTimeout handlers
155
- jsPsych.pluginAPI.clearAllTimeouts();
156
-
157
- // gather the data to store for the trial
158
- var trial_data = {
159
- "rt": response.rt,
160
- "stimulus": trial.stimulus,
161
- "button_pressed": response.button
162
- };
163
-
164
- // clear the display
165
- display_element.innerHTML = '';
166
-
167
- // move on to the next trial
168
- jsPsych.finishTrial(trial_data);
169
- };
170
-
171
- // hide image if timing is set
172
- if (trial.stimulus_duration !== null) {
173
- jsPsych.pluginAPI.setTimeout(function() {
174
- display_element.querySelector('#jspsych-html-button-response-stimulus').style.visibility = 'hidden';
175
- }, trial.stimulus_duration);
176
- }
177
-
178
- // end trial if time limit is set
179
- if (trial.trial_duration !== null) {
180
- jsPsych.pluginAPI.setTimeout(function() {
181
- end_trial();
182
- }, trial.trial_duration);
183
- }
184
-
185
- };
186
-
187
- return plugin;
188
- })();
@@ -1,149 +0,0 @@
1
- /**
2
- * jspsych-html-keyboard-response
3
- * Josh de Leeuw
4
- *
5
- * plugin for displaying a stimulus and getting a keyboard response
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- **/
10
-
11
-
12
- jsPsych.plugins["html-keyboard-response"] = (function() {
13
-
14
- var plugin = {};
15
-
16
- plugin.info = {
17
- name: 'html-keyboard-response',
18
- description: '',
19
- parameters: {
20
- stimulus: {
21
- type: jsPsych.plugins.parameterType.HTML_STRING,
22
- pretty_name: 'Stimulus',
23
- default: undefined,
24
- description: 'The HTML string to be displayed'
25
- },
26
- choices: {
27
- type: jsPsych.plugins.parameterType.KEYCODE,
28
- array: true,
29
- pretty_name: 'Choices',
30
- default: jsPsych.ALL_KEYS,
31
- description: 'The keys the subject is allowed to press to respond to the stimulus.'
32
- },
33
- prompt: {
34
- type: jsPsych.plugins.parameterType.STRING,
35
- pretty_name: 'Prompt',
36
- default: null,
37
- description: 'Any content here will be displayed below the stimulus.'
38
- },
39
- stimulus_duration: {
40
- type: jsPsych.plugins.parameterType.INT,
41
- pretty_name: 'Stimulus duration',
42
- default: null,
43
- description: 'How long to hide the stimulus.'
44
- },
45
- trial_duration: {
46
- type: jsPsych.plugins.parameterType.INT,
47
- pretty_name: 'Trial duration',
48
- default: null,
49
- description: 'How long to show trial before it ends.'
50
- },
51
- response_ends_trial: {
52
- type: jsPsych.plugins.parameterType.BOOL,
53
- pretty_name: 'Response ends trial',
54
- default: true,
55
- description: 'If true, trial will end when subject makes a response.'
56
- },
57
-
58
- }
59
- }
60
-
61
- plugin.trial = function(display_element, trial) {
62
-
63
- var new_html = '<div id="jspsych-html-keyboard-response-stimulus">'+trial.stimulus+'</div>';
64
-
65
- // add prompt
66
- if(trial.prompt !== null){
67
- new_html += trial.prompt;
68
- }
69
-
70
- // draw
71
- display_element.innerHTML = new_html;
72
-
73
- // store response
74
- var response = {
75
- rt: null,
76
- key: null
77
- };
78
-
79
- // function to end trial when it is time
80
- var end_trial = function() {
81
-
82
- // kill any remaining setTimeout handlers
83
- jsPsych.pluginAPI.clearAllTimeouts();
84
-
85
- // kill keyboard listeners
86
- if (typeof keyboardListener !== 'undefined') {
87
- jsPsych.pluginAPI.cancelKeyboardResponse(keyboardListener);
88
- }
89
-
90
- // gather the data to store for the trial
91
- var trial_data = {
92
- "rt": response.rt,
93
- "stimulus": trial.stimulus,
94
- "key_press": response.key
95
- };
96
-
97
- // clear the display
98
- display_element.innerHTML = '';
99
-
100
- // move on to the next trial
101
- jsPsych.finishTrial(trial_data);
102
- };
103
-
104
- // function to handle responses by the subject
105
- var after_response = function(info) {
106
-
107
- // after a valid response, the stimulus will have the CSS class 'responded'
108
- // which can be used to provide visual feedback that a response was recorded
109
- display_element.querySelector('#jspsych-html-keyboard-response-stimulus').className += ' responded';
110
-
111
- // only record the first response
112
- if (response.key == null) {
113
- response = info;
114
- }
115
-
116
- if (trial.response_ends_trial) {
117
- end_trial();
118
- }
119
- };
120
-
121
- // start the response listener
122
- if (trial.choices != jsPsych.NO_KEYS) {
123
- var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
124
- callback_function: after_response,
125
- valid_responses: trial.choices,
126
- rt_method: 'performance',
127
- persist: false,
128
- allow_held_key: false
129
- });
130
- }
131
-
132
- // hide stimulus if stimulus_duration is set
133
- if (trial.stimulus_duration !== null) {
134
- jsPsych.pluginAPI.setTimeout(function() {
135
- display_element.querySelector('#jspsych-html-keyboard-response-stimulus').style.visibility = 'hidden';
136
- }, trial.stimulus_duration);
137
- }
138
-
139
- // end trial if trial_duration is set
140
- if (trial.trial_duration !== null) {
141
- jsPsych.pluginAPI.setTimeout(function() {
142
- end_trial();
143
- }, trial.trial_duration);
144
- }
145
-
146
- };
147
-
148
- return plugin;
149
- })();
@@ -1,202 +0,0 @@
1
- /**
2
- * jspsych-html-slider-response
3
- * a jspsych plugin for free response survey questions
4
- *
5
- * Josh de Leeuw
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- */
10
-
11
-
12
- jsPsych.plugins['html-slider-response'] = (function() {
13
-
14
- var plugin = {};
15
-
16
- plugin.info = {
17
- name: 'html-slider-response',
18
- description: '',
19
- parameters: {
20
- stimulus: {
21
- type: jsPsych.plugins.parameterType.HTML_STRING,
22
- pretty_name: 'Stimulus',
23
- default: undefined,
24
- description: 'The HTML string to be displayed'
25
- },
26
- min: {
27
- type: jsPsych.plugins.parameterType.INT,
28
- pretty_name: 'Min slider',
29
- default: 0,
30
- description: 'Sets the minimum value of the slider.'
31
- },
32
- max: {
33
- type: jsPsych.plugins.parameterType.INT,
34
- pretty_name: 'Max slider',
35
- default: 100,
36
- description: 'Sets the maximum value of the slider',
37
- },
38
- slider_start: {
39
- type: jsPsych.plugins.parameterType.INT,
40
- pretty_name: 'Slider starting value',
41
- default: 50,
42
- description: 'Sets the starting value of the slider',
43
- },
44
- step: {
45
- type: jsPsych.plugins.parameterType.INT,
46
- pretty_name: 'Step',
47
- default: 1,
48
- description: 'Sets the step of the slider'
49
- },
50
- labels: {
51
- type: jsPsych.plugins.parameterType.HTML_STRING,
52
- pretty_name:'Labels',
53
- default: [],
54
- array: true,
55
- description: 'Labels of the slider.',
56
- },
57
- slider_width: {
58
- type: jsPsych.plugins.parameterType.INT,
59
- pretty_name:'Slider width',
60
- default: null,
61
- description: 'Width of the slider in pixels.'
62
- },
63
- button_label: {
64
- type: jsPsych.plugins.parameterType.STRING,
65
- pretty_name: 'Button label',
66
- default: 'Continue',
67
- array: false,
68
- description: 'Label of the button to advance.'
69
- },
70
- require_movement: {
71
- type: jsPsych.plugins.parameterType.BOOL,
72
- pretty_name: 'Require movement',
73
- default: false,
74
- description: 'If true, the participant will have to move the slider before continuing.'
75
- },
76
- prompt: {
77
- type: jsPsych.plugins.parameterType.STRING,
78
- pretty_name: 'Prompt',
79
- default: null,
80
- description: 'Any content here will be displayed below the slider.'
81
- },
82
- stimulus_duration: {
83
- type: jsPsych.plugins.parameterType.INT,
84
- pretty_name: 'Stimulus duration',
85
- default: null,
86
- description: 'How long to hide the stimulus.'
87
- },
88
- trial_duration: {
89
- type: jsPsych.plugins.parameterType.INT,
90
- pretty_name: 'Trial duration',
91
- default: null,
92
- description: 'How long to show the trial.'
93
- },
94
- response_ends_trial: {
95
- type: jsPsych.plugins.parameterType.BOOL,
96
- pretty_name: 'Response ends trial',
97
- default: true,
98
- description: 'If true, trial will end when user makes a response.'
99
- },
100
- }
101
- }
102
-
103
- plugin.trial = function(display_element, trial) {
104
-
105
- // half of the thumb width value from jspsych.css, used to adjust the label positions
106
- var half_thumb_width = 7.5;
107
-
108
- var html = '<div id="jspsych-html-slider-response-wrapper" style="margin: 100px 0px;">';
109
- html += '<div id="jspsych-html-slider-response-stimulus">' + trial.stimulus + '</div>';
110
- html += '<div class="jspsych-html-slider-response-container" style="position:relative; margin: 0 auto 3em auto; ';
111
- if(trial.slider_width !== null){
112
- html += 'width:'+trial.slider_width+'px;';
113
- } else {
114
- html += 'width:auto;';
115
- }
116
- html += '">';
117
- html += '<input type="range" class="jspsych-slider" value="'+trial.slider_start+'" min="'+trial.min+'" max="'+trial.max+'" step="'+trial.step+'" id="jspsych-html-slider-response-response"></input>';
118
- html += '<div>'
119
- for(var j=0; j < trial.labels.length; j++){
120
- var label_width_perc = 100/(trial.labels.length-1);
121
- var percent_of_range = j * (100/(trial.labels.length - 1));
122
- var percent_dist_from_center = ((percent_of_range-50)/50)*100;
123
- var offset = (percent_dist_from_center * half_thumb_width)/100;
124
- html += '<div style="border: 1px solid transparent; display: inline-block; position: absolute; '+
125
- 'left:calc('+percent_of_range+'% - ('+label_width_perc+'% / 2) - '+offset+'px); text-align: center; width: '+label_width_perc+'%;">';
126
- html += '<span style="text-align: center; font-size: 80%;">'+trial.labels[j]+'</span>';
127
- html += '</div>'
128
- }
129
- html += '</div>';
130
- html += '</div>';
131
- html += '</div>';
132
-
133
- if (trial.prompt !== null){
134
- html += trial.prompt;
135
- }
136
-
137
- // add submit button
138
- html += '<button id="jspsych-html-slider-response-next" class="jspsych-btn" '+ (trial.require_movement ? "disabled" : "") + '>'+trial.button_label+'</button>';
139
-
140
- display_element.innerHTML = html;
141
-
142
- var response = {
143
- rt: null,
144
- response: null
145
- };
146
-
147
- if(trial.require_movement){
148
- display_element.querySelector('#jspsych-html-slider-response-response').addEventListener('click', function(){
149
- display_element.querySelector('#jspsych-html-slider-response-next').disabled = false;
150
- });
151
- }
152
-
153
- display_element.querySelector('#jspsych-html-slider-response-next').addEventListener('click', function() {
154
- // measure response time
155
- var endTime = performance.now();
156
- response.rt = endTime - startTime;
157
- response.response = display_element.querySelector('#jspsych-html-slider-response-response').valueAsNumber;
158
-
159
- if(trial.response_ends_trial){
160
- end_trial();
161
- } else {
162
- display_element.querySelector('#jspsych-html-slider-response-next').disabled = true;
163
- }
164
-
165
- });
166
-
167
- function end_trial(){
168
-
169
- jsPsych.pluginAPI.clearAllTimeouts();
170
-
171
- // save data
172
- var trialdata = {
173
- "rt": response.rt,
174
- "stimulus": trial.stimulus,
175
- "slider_start": trial.slider_start,
176
- "response": response.response
177
- };
178
-
179
- display_element.innerHTML = '';
180
-
181
- // next trial
182
- jsPsych.finishTrial(trialdata);
183
- }
184
-
185
- if (trial.stimulus_duration !== null) {
186
- jsPsych.pluginAPI.setTimeout(function() {
187
- display_element.querySelector('#jspsych-html-slider-response-stimulus').style.visibility = 'hidden';
188
- }, trial.stimulus_duration);
189
- }
190
-
191
- // end trial if trial_duration is set
192
- if (trial.trial_duration !== null) {
193
- jsPsych.pluginAPI.setTimeout(function() {
194
- end_trial();
195
- }, trial.trial_duration);
196
- }
197
-
198
- var startTime = performance.now();
199
- };
200
-
201
- return plugin;
202
- })();