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,353 +0,0 @@
1
- /**
2
- * jspsych-image-slider-response
3
- * a jspsych plugin for free response survey questions
4
- *
5
- * Josh de Leeuw
6
- *
7
- * documentation: docs.jspsych.org
8
- *
9
- */
10
-
11
-
12
- jsPsych.plugins['image-slider-response'] = (function() {
13
-
14
- var plugin = {};
15
-
16
- jsPsych.pluginAPI.registerPreload('image-slider-response', 'stimulus', 'image');
17
-
18
- plugin.info = {
19
- name: 'image-slider-response',
20
- description: '',
21
- parameters: {
22
- stimulus: {
23
- type: jsPsych.plugins.parameterType.IMAGE,
24
- pretty_name: 'Stimulus',
25
- default: undefined,
26
- description: 'The image to be displayed'
27
- },
28
- stimulus_height: {
29
- type: jsPsych.plugins.parameterType.INT,
30
- pretty_name: 'Image height',
31
- default: null,
32
- description: 'Set the image height in pixels'
33
- },
34
- stimulus_width: {
35
- type: jsPsych.plugins.parameterType.INT,
36
- pretty_name: 'Image width',
37
- default: null,
38
- description: 'Set the image width in pixels'
39
- },
40
- maintain_aspect_ratio: {
41
- type: jsPsych.plugins.parameterType.BOOL,
42
- pretty_name: 'Maintain aspect ratio',
43
- default: true,
44
- description: 'Maintain the aspect ratio after setting width or height'
45
- },
46
- min: {
47
- type: jsPsych.plugins.parameterType.INT,
48
- pretty_name: 'Min slider',
49
- default: 0,
50
- description: 'Sets the minimum value of the slider.'
51
- },
52
- max: {
53
- type: jsPsych.plugins.parameterType.INT,
54
- pretty_name: 'Max slider',
55
- default: 100,
56
- description: 'Sets the maximum value of the slider',
57
- },
58
- slider_start: {
59
- type: jsPsych.plugins.parameterType.INT,
60
- pretty_name: 'Slider starting value',
61
- default: 50,
62
- description: 'Sets the starting value of the slider',
63
- },
64
- step: {
65
- type: jsPsych.plugins.parameterType.INT,
66
- pretty_name: 'Step',
67
- default: 1,
68
- description: 'Sets the step of the slider'
69
- },
70
- labels: {
71
- type: jsPsych.plugins.parameterType.HTML_STRING,
72
- pretty_name:'Labels',
73
- default: [],
74
- array: true,
75
- description: 'Labels of the slider.',
76
- },
77
- slider_width: {
78
- type: jsPsych.plugins.parameterType.INT,
79
- pretty_name:'Slider width',
80
- default: null,
81
- description: 'Width of the slider in pixels.'
82
- },
83
- button_label: {
84
- type: jsPsych.plugins.parameterType.STRING,
85
- pretty_name: 'Button label',
86
- default: 'Continue',
87
- array: false,
88
- description: 'Label of the button to advance.'
89
- },
90
- require_movement: {
91
- type: jsPsych.plugins.parameterType.BOOL,
92
- pretty_name: 'Require movement',
93
- default: false,
94
- description: 'If true, the participant will have to move the slider before continuing.'
95
- },
96
- prompt: {
97
- type: jsPsych.plugins.parameterType.STRING,
98
- pretty_name: 'Prompt',
99
- default: null,
100
- description: 'Any content here will be displayed below the slider.'
101
- },
102
- stimulus_duration: {
103
- type: jsPsych.plugins.parameterType.INT,
104
- pretty_name: 'Stimulus duration',
105
- default: null,
106
- description: 'How long to hide the stimulus.'
107
- },
108
- trial_duration: {
109
- type: jsPsych.plugins.parameterType.INT,
110
- pretty_name: 'Trial duration',
111
- default: null,
112
- description: 'How long to show the trial.'
113
- },
114
- response_ends_trial: {
115
- type: jsPsych.plugins.parameterType.BOOL,
116
- pretty_name: 'Response ends trial',
117
- default: true,
118
- description: 'If true, trial will end when user makes a response.'
119
- },
120
- render_on_canvas: {
121
- type: jsPsych.plugins.parameterType.BOOL,
122
- pretty_name: 'Render on canvas',
123
- default: true,
124
- description: 'If true, the image will be drawn onto a canvas element (prevents blank screen between consecutive images in some browsers).'+
125
- 'If false, the image will be shown via an img element.'
126
- }
127
- }
128
- }
129
-
130
- plugin.trial = function(display_element, trial) {
131
-
132
- var height, width;
133
- var html;
134
- // half of the thumb width value from jspsych.css, used to adjust the label positions
135
- var half_thumb_width = 7.5;
136
-
137
- if (trial.render_on_canvas) {
138
- // first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
139
- if (display_element.hasChildNodes()) {
140
- // can't loop through child list because the list will be modified by .removeChild()
141
- while (display_element.firstChild) {
142
- display_element.removeChild(display_element.firstChild);
143
- }
144
- }
145
- // create wrapper div, canvas element and image
146
- var content_wrapper = document.createElement('div');
147
- content_wrapper.id = "jspsych-image-slider-response-wrapper";
148
- content_wrapper.style.margin = "100px 0px";
149
- var canvas = document.createElement("canvas");
150
- canvas.id = "jspsych-image-slider-response-stimulus";
151
- canvas.style.margin = 0;
152
- canvas.style.padding = 0;
153
- var img = new Image();
154
- img.src = trial.stimulus;
155
- // determine image height and width
156
- if (trial.stimulus_height !== null) {
157
- height = trial.stimulus_height;
158
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
159
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
160
- }
161
- } else {
162
- height = img.naturalHeight;
163
- }
164
- if (trial.stimulus_width !== null) {
165
- width = trial.stimulus_width;
166
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
167
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
168
- }
169
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
170
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
171
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
172
- width = img.naturalWidth;
173
- }
174
- canvas.height = height;
175
- canvas.width = width;
176
- // create container with slider and labels
177
- var slider_container = document.createElement('div');
178
- slider_container.classList.add("jspsych-image-slider-response-container");
179
- slider_container.style.position = "relative";
180
- slider_container.style.margin = "0 auto 3em auto";
181
- if(trial.slider_width !== null){
182
- slider_container.style.width = trial.slider_width.toString()+'px';
183
- }
184
- // create html string with slider and labels, and add to slider container
185
- html ='<input type="range" class="jspsych-slider" value="'+trial.slider_start+'" min="'+trial.min+'" max="'+trial.max+'" step="'+trial.step+'" id="jspsych-image-slider-response-response"></input>';
186
- html += '<div>'
187
- for(var j=0; j < trial.labels.length; j++){
188
- var label_width_perc = 100/(trial.labels.length-1);
189
- var percent_of_range = j * (100/(trial.labels.length - 1));
190
- var percent_dist_from_center = ((percent_of_range-50)/50)*100;
191
- var offset = (percent_dist_from_center * half_thumb_width)/100;
192
- html += '<div style="border: 1px solid transparent; display: inline-block; position: absolute; '+
193
- 'left:calc('+percent_of_range+'% - ('+label_width_perc+'% / 2) - '+offset+'px); text-align: center; width: '+label_width_perc+'%;">';
194
- html += '<span style="text-align: center; font-size: 80%;">'+trial.labels[j]+'</span>';
195
- html += '</div>'
196
- }
197
- html += '</div>';
198
- slider_container.innerHTML = html;
199
- // add canvas and slider to content wrapper div
200
- content_wrapper.insertBefore(canvas, content_wrapper.firstElementChild);
201
- content_wrapper.insertBefore(slider_container, canvas.nextElementSibling);
202
- // add content wrapper div to screen and draw image on canvas
203
- display_element.insertBefore(content_wrapper, null);
204
- var ctx = canvas.getContext("2d");
205
- ctx.drawImage(img,0,0,width,height);
206
- // add prompt if there is one
207
- if (trial.prompt !== null) {
208
- display_element.insertAdjacentHTML('beforeend', trial.prompt);
209
- }
210
- // add submit button
211
- var submit_btn = document.createElement('button');
212
- submit_btn.id = "jspsych-image-slider-response-next";
213
- submit_btn.classList.add("jspsych-btn");
214
- submit_btn.disabled = (trial.require_movement) ? true : false;
215
- submit_btn.innerHTML = trial.button_label;
216
- display_element.insertBefore(submit_btn, display_element.nextElementSibling);
217
-
218
- } else {
219
-
220
- html = '<div id="jspsych-image-slider-response-wrapper" style="margin: 100px 0px;">';
221
- html += '<div id="jspsych-image-slider-response-stimulus">';
222
- html += '<img src="'+trial.stimulus+'" style="';
223
- if(trial.stimulus_height !== null){
224
- html += 'height:'+trial.stimulus_height+'px; '
225
- if(trial.stimulus_width == null && trial.maintain_aspect_ratio){
226
- html += 'width: auto; ';
227
- }
228
- }
229
- if(trial.stimulus_width !== null){
230
- html += 'width:'+trial.stimulus_width+'px; '
231
- if(trial.stimulus_height == null && trial.maintain_aspect_ratio){
232
- html += 'height: auto; ';
233
- }
234
- }
235
- html += '"></img>';
236
- html += '</div>';
237
- html += '<div class="jspsych-image-slider-response-container" style="position:relative; margin: 0 auto 3em auto; width:';
238
- if (trial.slider_width !== null) {
239
- html += trial.slider_width+'px;';
240
- } else {
241
- html += 'auto;';
242
- }
243
- html += '">';
244
- html += '<input type="range" class="jspsych-slider" value="'+trial.slider_start+'" min="'+trial.min+'" max="'+trial.max+'" step="'+trial.step+'" id="jspsych-image-slider-response-response"></input>';
245
- html += '<div>'
246
- for(var j=0; j < trial.labels.length; j++){
247
- var label_width_perc = 100/(trial.labels.length-1);
248
- var percent_of_range = j * (100/(trial.labels.length - 1));
249
- var percent_dist_from_center = ((percent_of_range-50)/50)*100;
250
- var offset = (percent_dist_from_center * half_thumb_width)/100;
251
- html += '<div style="border: 1px solid transparent; display: inline-block; position: absolute; '+
252
- 'left:calc('+percent_of_range+'% - ('+label_width_perc+'% / 2) - '+offset+'px); text-align: center; width: '+label_width_perc+'%;">';
253
- html += '<span style="text-align: center; font-size: 80%;">'+trial.labels[j]+'</span>';
254
- html += '</div>'
255
- }
256
- html += '</div>';
257
- html += '</div>';
258
- html += '</div>';
259
-
260
- if (trial.prompt !== null){
261
- html += trial.prompt;
262
- }
263
-
264
- // add submit button
265
- html += '<button id="jspsych-image-slider-response-next" class="jspsych-btn" '+ (trial.require_movement ? "disabled" : "") + '>'+trial.button_label+'</button>';
266
-
267
- display_element.innerHTML = html;
268
-
269
- // set image dimensions after image has loaded (so that we have access to naturalHeight/naturalWidth)
270
- var img = display_element.querySelector('img');
271
- if (trial.stimulus_height !== null) {
272
- height = trial.stimulus_height;
273
- if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
274
- width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
275
- }
276
- } else {
277
- height = img.naturalHeight;
278
- }
279
- if (trial.stimulus_width !== null) {
280
- width = trial.stimulus_width;
281
- if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
282
- height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
283
- }
284
- } else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
285
- // if stimulus width is null, only use the image's natural width if the width value wasn't set
286
- // in the if statement above, based on a specified height and maintain_aspect_ratio = true
287
- width = img.naturalWidth;
288
- }
289
- img.style.height = height.toString() + "px";
290
- img.style.width = width.toString() + "px";
291
- }
292
-
293
- var response = {
294
- rt: null,
295
- response: null
296
- };
297
-
298
- if(trial.require_movement){
299
- display_element.querySelector('#jspsych-image-slider-response-response').addEventListener('click', function(){
300
- display_element.querySelector('#jspsych-image-slider-response-next').disabled = false;
301
- });
302
- }
303
-
304
- display_element.querySelector('#jspsych-image-slider-response-next').addEventListener('click', function() {
305
- // measure response time
306
- var endTime = performance.now();
307
- response.rt = endTime - startTime;
308
- response.response = display_element.querySelector('#jspsych-image-slider-response-response').valueAsNumber;
309
-
310
- if(trial.response_ends_trial){
311
- end_trial();
312
- } else {
313
- display_element.querySelector('#jspsych-image-slider-response-next').disabled = true;
314
- }
315
-
316
- });
317
-
318
- function end_trial(){
319
-
320
- jsPsych.pluginAPI.clearAllTimeouts();
321
-
322
- // save data
323
- var trialdata = {
324
- "rt": response.rt,
325
- "stimulus": trial.stimulus,
326
- "slider_start": trial.slider_start,
327
- "response": response.response
328
- };
329
-
330
- display_element.innerHTML = '';
331
-
332
- // next trial
333
- jsPsych.finishTrial(trialdata);
334
- }
335
-
336
- if (trial.stimulus_duration !== null) {
337
- jsPsych.pluginAPI.setTimeout(function() {
338
- display_element.querySelector('#jspsych-image-slider-response-stimulus').style.visibility = 'hidden';
339
- }, trial.stimulus_duration);
340
- }
341
-
342
- // end trial if trial_duration is set
343
- if (trial.trial_duration !== null) {
344
- jsPsych.pluginAPI.setTimeout(function() {
345
- end_trial();
346
- }, trial.trial_duration);
347
- }
348
-
349
- var startTime = performance.now();
350
- };
351
-
352
- return plugin;
353
- })();
@@ -1,237 +0,0 @@
1
- /* jspsych-instructions.js
2
- * Josh de Leeuw
3
- *
4
- * This plugin displays text (including HTML formatted strings) during the experiment.
5
- * Use it to show instructions, provide performance feedback, etc...
6
- *
7
- * Page numbers can be displayed to help with navigation by setting show_page_number
8
- * to true.
9
- *
10
- * documentation: docs.jspsych.org
11
- *
12
- *
13
- */
14
-
15
- jsPsych.plugins.instructions = (function() {
16
-
17
- var plugin = {};
18
-
19
- plugin.info = {
20
- name: 'instructions',
21
- description: '',
22
- parameters: {
23
- pages: {
24
- type: jsPsych.plugins.parameterType.HTML_STRING,
25
- pretty_name: 'Pages',
26
- default: undefined,
27
- array: true,
28
- description: 'Each element of the array is the content for a single page.'
29
- },
30
- key_forward: {
31
- type: jsPsych.plugins.parameterType.KEYCODE,
32
- pretty_name: 'Key forward',
33
- default: 'rightarrow',
34
- description: 'The key the subject can press in order to advance to the next page.'
35
- },
36
- key_backward: {
37
- type: jsPsych.plugins.parameterType.KEYCODE,
38
- pretty_name: 'Key backward',
39
- default: 'leftarrow',
40
- description: 'The key that the subject can press to return to the previous page.'
41
- },
42
- allow_backward: {
43
- type: jsPsych.plugins.parameterType.BOOL,
44
- pretty_name: 'Allow backward',
45
- default: true,
46
- description: 'If true, the subject can return to the previous page of the instructions.'
47
- },
48
- allow_keys: {
49
- type: jsPsych.plugins.parameterType.BOOL,
50
- pretty_name: 'Allow keys',
51
- default: true,
52
- description: 'If true, the subject can use keyboard keys to navigate the pages.'
53
- },
54
- show_clickable_nav: {
55
- type: jsPsych.plugins.parameterType.BOOL,
56
- pretty_name: 'Show clickable nav',
57
- default: false,
58
- description: 'If true, then a "Previous" and "Next" button will be displayed beneath the instructions.'
59
- },
60
- show_page_number: {
61
- type: jsPsych.plugins.parameterType.BOOL,
62
- pretty_name: 'Show page number',
63
- default: false,
64
- description: 'If true, and clickable navigation is enabled, then Page x/y will be shown between the nav buttons.'
65
- },
66
- page_label: {
67
- type: jsPsych.plugins.parameterType.STRING,
68
- pretty_name: 'Page label',
69
- default: 'Page',
70
- description: 'The text that appears before x/y (current/total) pages displayed with show_page_number'
71
- },
72
- button_label_previous: {
73
- type: jsPsych.plugins.parameterType.STRING,
74
- pretty_name: 'Button label previous',
75
- default: 'Previous',
76
- description: 'The text that appears on the button to go backwards.'
77
- },
78
- button_label_next: {
79
- type: jsPsych.plugins.parameterType.STRING,
80
- pretty_name: 'Button label next',
81
- default: 'Next',
82
- description: 'The text that appears on the button to go forwards.'
83
- }
84
- }
85
- }
86
-
87
- plugin.trial = function(display_element, trial) {
88
-
89
- var current_page = 0;
90
-
91
- var view_history = [];
92
-
93
- var start_time = performance.now();
94
-
95
- var last_page_update_time = start_time;
96
-
97
- function btnListener(evt){
98
- evt.target.removeEventListener('click', btnListener);
99
- if(this.id === "jspsych-instructions-back"){
100
- back();
101
- }
102
- else if(this.id === 'jspsych-instructions-next'){
103
- next();
104
- }
105
- }
106
-
107
- function show_current_page() {
108
- var html = trial.pages[current_page];
109
-
110
- var pagenum_display = "";
111
- if(trial.show_page_number) {
112
- pagenum_display = "<span style='margin: 0 1em;' class='"+
113
- "jspsych-instructions-pagenum'>"+ trial.page_label + ' ' +(current_page+1)+"/"+trial.pages.length+"</span>";
114
- }
115
-
116
- if (trial.show_clickable_nav) {
117
-
118
- var nav_html = "<div class='jspsych-instructions-nav' style='padding: 10px 0px;'>";
119
- if (trial.allow_backward) {
120
- var allowed = (current_page > 0 )? '' : "disabled='disabled'";
121
- nav_html += "<button id='jspsych-instructions-back' class='jspsych-btn' style='margin-right: 5px;' "+allowed+">&lt; "+trial.button_label_previous+"</button>";
122
- }
123
- if (trial.pages.length > 1 && trial.show_page_number) {
124
- nav_html += pagenum_display;
125
- }
126
- nav_html += "<button id='jspsych-instructions-next' class='jspsych-btn'"+
127
- "style='margin-left: 5px;'>"+trial.button_label_next+
128
- " &gt;</button></div>";
129
-
130
- html += nav_html;
131
- display_element.innerHTML = html;
132
- if (current_page != 0 && trial.allow_backward) {
133
- display_element.querySelector('#jspsych-instructions-back').addEventListener('click', btnListener);
134
- }
135
-
136
- display_element.querySelector('#jspsych-instructions-next').addEventListener('click', btnListener);
137
- } else {
138
- if (trial.show_page_number && trial.pages.length > 1) {
139
- // page numbers for non-mouse navigation
140
- html += "<div class='jspsych-instructions-pagenum'>"+pagenum_display+"</div>"
141
- }
142
- display_element.innerHTML = html;
143
- }
144
-
145
- }
146
-
147
- function next() {
148
-
149
- add_current_page_to_view_history()
150
-
151
- current_page++;
152
-
153
- // if done, finish up...
154
- if (current_page >= trial.pages.length) {
155
- endTrial();
156
- } else {
157
- show_current_page();
158
- }
159
-
160
- }
161
-
162
- function back() {
163
-
164
- add_current_page_to_view_history()
165
-
166
- current_page--;
167
-
168
- show_current_page();
169
- }
170
-
171
- function add_current_page_to_view_history() {
172
-
173
- var current_time = performance.now();
174
-
175
- var page_view_time = current_time - last_page_update_time;
176
-
177
- view_history.push({
178
- page_index: current_page,
179
- viewing_time: page_view_time
180
- });
181
-
182
- last_page_update_time = current_time;
183
- }
184
-
185
- function endTrial() {
186
-
187
- if (trial.allow_keys) {
188
- jsPsych.pluginAPI.cancelKeyboardResponse(keyboard_listener);
189
- }
190
-
191
- display_element.innerHTML = '';
192
-
193
- var trial_data = {
194
- "view_history": JSON.stringify(view_history),
195
- "rt": performance.now() - start_time
196
- };
197
-
198
- jsPsych.finishTrial(trial_data);
199
- }
200
-
201
- var after_response = function(info) {
202
-
203
- // have to reinitialize this instead of letting it persist to prevent accidental skips of pages by holding down keys too long
204
- keyboard_listener = jsPsych.pluginAPI.getKeyboardResponse({
205
- callback_function: after_response,
206
- valid_responses: [trial.key_forward, trial.key_backward],
207
- rt_method: 'performance',
208
- persist: false,
209
- allow_held_key: false
210
- });
211
- // check if key is forwards or backwards and update page
212
- if (jsPsych.pluginAPI.compareKeys(info.key, trial.key_backward)) {
213
- if (current_page !== 0 && trial.allow_backward) {
214
- back();
215
- }
216
- }
217
-
218
- if (jsPsych.pluginAPI.compareKeys(info.key, trial.key_forward)) {
219
- next();
220
- }
221
-
222
- };
223
-
224
- show_current_page();
225
-
226
- if (trial.allow_keys) {
227
- var keyboard_listener = jsPsych.pluginAPI.getKeyboardResponse({
228
- callback_function: after_response,
229
- valid_responses: [trial.key_forward, trial.key_backward],
230
- rt_method: 'performance',
231
- persist: false
232
- });
233
- }
234
- };
235
-
236
- return plugin;
237
- })();