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,183 +0,0 @@
1
- const utils = require('../testing-utils.js');
2
- const root = '../../';
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('image-button-response', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-image-button-response');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['image-button-response']).not.toBe('undefined');
15
- });
16
-
17
- test('displays image stimulus', function(){
18
- var trial = {
19
- type: 'image-button-response',
20
- stimulus: '../media/blue.png',
21
- choices: ['button-choice'],
22
- render_on_canvas: false
23
- }
24
-
25
- jsPsych.init({
26
- timeline: [trial],
27
- auto_preload: false
28
- });
29
-
30
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<img src="../media/blue.png"');
31
- });
32
-
33
- test('display button labels', function(){
34
- var trial = {
35
- type: 'image-button-response',
36
- stimulus: '../media/blue.png',
37
- choices: ['button-choice1', 'button-choice2'],
38
- render_on_canvas: false
39
- }
40
-
41
- jsPsych.init({
42
- timeline: [trial],
43
- auto_preload: false
44
- });
45
-
46
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<button class=\"jspsych-btn\">button-choice1</button>'));
47
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<button class=\"jspsych-btn\">button-choice2</button>'));
48
- });
49
-
50
- test('display button html', function(){
51
- var trial = {
52
- type: 'image-button-response',
53
- stimulus: '../media/blue.png',
54
- choices: ['buttonChoice'],
55
- button_html: '<button class="jspsych-custom-button">%choice%</button>',
56
- render_on_canvas: false
57
- }
58
-
59
- jsPsych.init({
60
- timeline: [trial],
61
- auto_preload: false
62
- });
63
-
64
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<button class="jspsych-custom-button">buttonChoice</button>'));
65
- });
66
-
67
- test('display should clear after button click', function(){
68
- var trial = {
69
- type: 'image-button-response',
70
- stimulus: '../media/blue.png',
71
- choices: ['button-choice'],
72
- render_on_canvas: false
73
- }
74
-
75
- jsPsych.init({
76
- timeline: [trial],
77
- auto_preload: false
78
- });
79
-
80
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<img src="../media/blue.png" id="jspsych-image-button-response-stimulus"');
81
-
82
- utils.clickTarget(document.querySelector('#jspsych-image-button-response-button-0'));
83
-
84
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
85
- });
86
-
87
- test('prompt should append below button', function(){
88
- var trial = {
89
- type: 'image-button-response',
90
- stimulus: '../media/blue.png',
91
- choices: ['button-choice'],
92
- prompt: '<p>This is a prompt</p>',
93
- render_on_canvas: false
94
- }
95
-
96
- jsPsych.init({
97
- timeline: [trial],
98
- auto_preload: false
99
- });
100
-
101
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<button class=\"jspsych-btn\">button-choice</button></div></div><p>This is a prompt</p>');
102
- });
103
-
104
- test('should hide stimulus if stimulus-duration is set', function(){
105
- var trial = {
106
- type: 'image-button-response',
107
- stimulus: '../media/blue.png',
108
- choices: ['button-choice'],
109
- stimulus_duration: 500,
110
- render_on_canvas: false
111
- }
112
-
113
- jsPsych.init({
114
- timeline: [trial],
115
- auto_preload: false
116
- });
117
-
118
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-image-button-response-stimulus').style.visibility).toMatch("");
119
- jest.runTimersToTime(500);
120
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-image-button-response-stimulus').style.visibility).toMatch('hidden');
121
- });
122
-
123
- test('should end trial when trial duration is reached', function(){
124
- var trial = {
125
- type: 'image-button-response',
126
- stimulus: '../media/blue.png',
127
- choices: ['f','j'],
128
- trial_duration: 500,
129
- render_on_canvas: false
130
- }
131
-
132
- jsPsych.init({
133
- timeline: [trial],
134
- auto_preload: false
135
- });
136
-
137
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<img src="../media/blue.png" id="jspsych-image-button-response-stimulus"');
138
- jest.runTimersToTime(500);
139
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
140
- });
141
-
142
- test('should end trial when button is clicked', function(){
143
- var trial = {
144
- type: 'image-button-response',
145
- stimulus: '../media/blue.png',
146
- choices: ['button-choice'],
147
- response_ends_trial: true,
148
- render_on_canvas: false
149
- }
150
-
151
- jsPsych.init({
152
- timeline: [trial],
153
- auto_preload: false
154
- });
155
-
156
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<img src="../media/blue.png" id="jspsych-image-button-response-stimulus"');
157
-
158
- utils.clickTarget(document.querySelector('#jspsych-image-button-response-button-0'));
159
-
160
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
161
- });
162
-
163
- test('should show console warning when trial duration is null and response ends trial is false', function() {
164
- const spy = jest.spyOn(console, 'warn').mockImplementation();
165
-
166
- var trial = {
167
- type: 'image-button-response',
168
- stimulus: '../media/blue.png',
169
- choices: ['button-choice'],
170
- response_ends_trial: false,
171
- trial_duration: null,
172
- render_on_canvas: false
173
- };
174
-
175
- jsPsych.init({
176
- timeline: [trial],
177
- auto_preload: false
178
- });
179
-
180
- expect(spy).toHaveBeenCalled();
181
- spy.mockRestore();
182
- });
183
- });
@@ -1,154 +0,0 @@
1
- const root = '../../';
2
- const utils = require('../testing-utils.js');
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('image-keyboard-response', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-image-keyboard-response');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['image-keyboard-response']).not.toBe('undefined');
15
- });
16
-
17
- test('displays image stimulus', function(){
18
- var trial = {
19
- type: 'image-keyboard-response',
20
- stimulus: '../media/blue.png',
21
- render_on_canvas: false
22
- }
23
-
24
- jsPsych.init({
25
- timeline: [trial],
26
- auto_preload: false
27
- });
28
-
29
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<img src=\"../media/blue.png\" id=\"jspsych-image-keyboard-response-stimulus\"');
30
-
31
- utils.pressKey(70);
32
- });
33
-
34
- test('display clears after key press', function(){
35
- var trial = {
36
- type: 'image-keyboard-response',
37
- stimulus: '../media/blue.png',
38
- choices: ['f','j'],
39
- render_on_canvas: false
40
- }
41
-
42
- jsPsych.init({
43
- timeline: [trial],
44
- auto_preload: false
45
- });
46
-
47
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<img src="../media/blue.png" id="jspsych-image-keyboard-response-stimulus"');
48
-
49
- utils.pressKey(70);
50
-
51
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
52
- });
53
-
54
- test('prompt should append html', function(){
55
- var trial = {
56
- type: 'image-keyboard-response',
57
- stimulus: '../media/blue.png',
58
- choices: ['f','j'],
59
- prompt: '<div id="foo">this is a prompt</div>',
60
- render_on_canvas: false
61
- }
62
-
63
- jsPsych.init({
64
- timeline: [trial],
65
- auto_preload: false
66
- });
67
-
68
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="foo">this is a prompt</div>');
69
- utils.pressKey(70);
70
- });
71
-
72
- test('should hide stimulus if stimulus-duration is set', function(){
73
- var trial = {
74
- type: 'image-keyboard-response',
75
- stimulus: '../media/blue.png',
76
- choices:['f','j'],
77
- stimulus_duration: 500,
78
- render_on_canvas: false
79
- }
80
-
81
- jsPsych.init({
82
- timeline: [trial],
83
- auto_preload: false
84
- });
85
-
86
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-image-keyboard-response-stimulus').style.visibility).toMatch("");
87
- jest.runTimersToTime(500);
88
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-image-keyboard-response-stimulus').style.visibility).toMatch("hidden");
89
- utils.pressKey(70);
90
-
91
- });
92
-
93
- test('should end trial when trial duration is reached', function(){
94
- var trial = {
95
- type: 'image-keyboard-response',
96
- stimulus: '../media/blue.png',
97
- choices: ['f','j'],
98
- trial_duration: 500,
99
- render_on_canvas: false
100
- }
101
-
102
- jsPsych.init({
103
- timeline: [trial],
104
- auto_preload: false
105
- });
106
-
107
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<img src="../media/blue.png" id="jspsych-image-keyboard-response-stimulus"');
108
- jest.runTimersToTime(500);
109
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
110
- });
111
-
112
- test('should end trial when key is pressed', function(){
113
- var trial = {
114
- type:'image-keyboard-response',
115
- stimulus: '../media/blue.png',
116
- choices: ['f','j'],
117
- response_ends_trial: true,
118
- render_on_canvas: false
119
- }
120
-
121
- jsPsych.init({
122
- timeline: [trial],
123
- auto_preload: false
124
- });
125
-
126
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<img src="../media/blue.png" id="jspsych-image-keyboard-response-stimulus"');
127
-
128
- utils.pressKey(70);
129
-
130
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
131
- });
132
-
133
-
134
- test('should show console warning when trial duration is null and response ends trial is false', function() {
135
- const spy = jest.spyOn(console, 'warn').mockImplementation();
136
-
137
- var trial = {
138
- type: 'image-keyboard-response',
139
- stimulus: '../media/blue.png',
140
- choices: ['f','j'],
141
- response_ends_trial: false,
142
- trial_duration: null,
143
- render_on_canvas: false
144
- };
145
-
146
- jsPsych.init({
147
- timeline: [trial],
148
- auto_preload: false
149
- });
150
-
151
- expect(spy).toHaveBeenCalled();
152
- spy.mockRestore();
153
- });
154
- });
@@ -1,183 +0,0 @@
1
- const utils = require('../testing-utils.js');
2
- const root = '../../';
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('image-slider-response', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-image-slider-response.js');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['image-slider-response']).not.toBe('undefined');
15
- });
16
-
17
- test('displays image stimulus', function(done){
18
- var trial = {
19
- type: 'image-slider-response',
20
- stimulus: '../media/blue.png',
21
- labels: ['left', 'right'],
22
- button_label: 'button',
23
- render_on_canvas: false,
24
- on_load: function(){
25
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-image-slider-response-stimulus"><img src="../media/blue.png"');
26
- utils.clickTarget(document.querySelector('#jspsych-image-slider-response-next'));
27
- done();
28
- }
29
- }
30
-
31
- jsPsych.init({
32
- timeline: [trial],
33
- auto_preload: false
34
- });
35
- });
36
-
37
- test('displays labels', function(){
38
- var trial = {
39
- type: 'image-slider-response',
40
- stimulus: '../media/blue.png',
41
- labels: ['left', 'right'],
42
- button_label: 'button',
43
- render_on_canvas: false
44
- }
45
-
46
- jsPsych.init({
47
- timeline: [trial],
48
- auto_preload: false
49
- });
50
-
51
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<span style=\"text-align: center; font-size: 80%;\">left</span>');
52
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<span style=\"text-align: center; font-size: 80%;\">right</span>');
53
-
54
- utils.clickTarget(document.querySelector('#jspsych-image-slider-response-next'));
55
- })
56
-
57
- test('displays button label', function(){
58
- var trial = {
59
- type: 'image-slider-response',
60
- stimulus: '../media/blue.png',
61
- labels: ['left', 'right'],
62
- button_label: 'button',
63
- render_on_canvas: false
64
- }
65
-
66
- jsPsych.init({
67
- timeline: [trial],
68
- auto_preload: false
69
- });
70
-
71
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<button id=\"jspsych-image-slider-response-next\" class=\"jspsych-btn\">button</button>');
72
-
73
- utils.clickTarget(document.querySelector('#jspsych-image-slider-response-next'));
74
- });
75
-
76
- test('should set min, max and step', function(){
77
- var trial = {
78
- type: 'image-slider-response',
79
- stimulus: '../media/blue.png',
80
- labels: ['left', 'right'],
81
- button_label: 'button',
82
- min: 2,
83
- max: 10,
84
- step: 2,
85
- render_on_canvas: false
86
- }
87
-
88
- jsPsych.init({
89
- timeline: [trial],
90
- auto_preload: false
91
- });
92
-
93
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-image-slider-response-response').min).toBe('2');
94
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-image-slider-response-response').max).toBe('10');
95
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-image-slider-response-response').step).toBe('2');
96
-
97
- utils.clickTarget(document.querySelector('#jspsych-image-slider-response-next'));
98
- });
99
-
100
- test('prompt should append to bottom of stimulus', function(){
101
- var trial = {
102
- type: 'image-slider-response',
103
- stimulus: '../media/blue.png',
104
- labels: ['left', 'right'],
105
- button_label: 'button',
106
- prompt: '<p>This is a prompt</p>',
107
- render_on_canvas: false
108
- }
109
-
110
- jsPsych.init({
111
- timeline: [trial],
112
- auto_preload: false
113
- });
114
-
115
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<p>This is a prompt</p>');
116
-
117
- utils.clickTarget(document.querySelector('#jspsych-image-slider-response-next'));
118
- });
119
-
120
- test('should hide stimulus if stimulus_duration is set', function(){
121
- var trial = {
122
- type: 'image-slider-response',
123
- stimulus: '../media/blue.png',
124
- labels: ['left', 'right'],
125
- button_label: 'button',
126
- stimulus_duration: 500,
127
- render_on_canvas: false
128
- }
129
-
130
- jsPsych.init({
131
- timeline: [trial],
132
- auto_preload: false
133
- });
134
-
135
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-image-slider-response-stimulus').style.visibility).toMatch("");
136
- jest.runTimersToTime(500);
137
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-image-slider-response-stimulus').style.visibility).toMatch("hidden");
138
- utils.clickTarget(document.querySelector('#jspsych-image-slider-response-next'));
139
- });
140
-
141
- test('should end trial when trial duration is reached', function(){
142
- var trial = {
143
- type: 'image-slider-response',
144
- stimulus: '../media/blue.png',
145
- labels: ['left', 'right'],
146
- button_label: 'button',
147
- trial_duration: 500,
148
- render_on_canvas: false
149
-
150
- }
151
-
152
- jsPsych.init({
153
- timeline: [trial],
154
- auto_preload: false
155
- });
156
-
157
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-image-slider-response-stimulus"><img src="../media/blue.png"');
158
- jest.runTimersToTime(500);
159
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
160
- });
161
-
162
- test('should end trial when button is clicked', function(){
163
- var trial = {
164
- type: 'image-slider-response',
165
- stimulus: '../media/blue.png',
166
- labels: ['left', 'right'],
167
- button_label: 'button',
168
- response_ends_trial: true,
169
- render_on_canvas: false
170
- }
171
-
172
- jsPsych.init({
173
- timeline: [trial],
174
- auto_preload: false
175
- });
176
-
177
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-image-slider-response-stimulus"><img src="../media/blue.png"');
178
-
179
- utils.clickTarget(document.querySelector('#jspsych-image-slider-response-next'));
180
-
181
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
182
- });
183
- });
@@ -1,66 +0,0 @@
1
- const root = '../../';
2
- const utils = require('../testing-utils.js');
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('instructions plugin', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-instructions.js');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['instructions']).not.toBe('undefined');
15
- });
16
-
17
- test('keys can be specified as numeric codes', function(){
18
- var trial = {
19
- type: 'instructions',
20
- pages: ['page 1', 'page 2'],
21
- key_forward: 32
22
- }
23
-
24
- jsPsych.init({
25
- timeline: [trial]
26
- });
27
-
28
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('page 1');
29
-
30
- utils.pressKey(32);
31
-
32
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('page 2');
33
-
34
- utils.pressKey(32);
35
-
36
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
37
- });
38
-
39
- test('bug issue #544 reproduce', function(){
40
- var trial = {
41
- type: 'instructions',
42
- pages: ['page 1', 'page 2'],
43
- key_forward: 32,
44
- allow_backward: false
45
- }
46
-
47
- jsPsych.init({
48
- timeline: [trial]
49
- });
50
-
51
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('page 1');
52
-
53
- utils.pressKey(32);
54
-
55
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('page 2');
56
-
57
- utils.pressKey(37); // left arrow
58
-
59
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('page 2');
60
-
61
- utils.pressKey(32);
62
-
63
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
64
- })
65
-
66
- });
@@ -1,39 +0,0 @@
1
- const root = '../../';
2
- const utils = require('../testing-utils.js');
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('maxdiff plugin', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-maxdiff.js');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['maxdiff']).not.toBe('undefined');
15
- });
16
-
17
- test('returns appropriate response with randomization', function(){
18
- var trial = {
19
- type: 'maxdiff',
20
- alternatives: ['a', 'b', 'c', 'd'],
21
- labels: ['Most', 'Least'],
22
- randomize_alternative_order: true
23
- }
24
-
25
- jsPsych.init({
26
- timeline: [trial]
27
- });
28
-
29
- document.querySelector('input[data-name="0"][name="left"]').checked = true;
30
- document.querySelector('input[data-name="1"][name="right"]').checked = true;
31
-
32
- utils.clickTarget(document.querySelector('#jspsych-maxdiff-next'));
33
-
34
- var maxdiff_data = jsPsych.data.get().values()[0];
35
- expect(maxdiff_data.left).toBe("a");
36
- expect(maxdiff_data.right).toBe("b");
37
- });
38
-
39
- });
@@ -1,17 +0,0 @@
1
- const root = '../../';
2
- const utils = require('../testing-utils.js');
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('rdk plugin', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-rdk.js');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['rdk']).not.toBe('undefined');
15
- });
16
-
17
- });
@@ -1,16 +0,0 @@
1
- const root = '../../';
2
-
3
- jest.useFakeTimers();
4
-
5
- describe('reconstruction plugin', function(){
6
-
7
- beforeEach(function(){
8
- require(root + 'jspsych.js');
9
- require(root + 'plugins/jspsych-reconstruction.js');
10
- });
11
-
12
- test('loads correctly', function(){
13
- expect(typeof window.jsPsych.plugins['reconstruction']).not.toBe('undefined');
14
- });
15
-
16
- });
@@ -1,16 +0,0 @@
1
- const root = '../../';
2
-
3
- jest.useFakeTimers();
4
-
5
- describe('resize plugin', function(){
6
-
7
- beforeEach(function(){
8
- require(root + 'jspsych.js');
9
- require(root + 'plugins/jspsych-resize.js');
10
- });
11
-
12
- test('loads correctly', function(){
13
- expect(typeof window.jsPsych.plugins['resize']).not.toBe('undefined');
14
- });
15
-
16
- });
@@ -1,17 +0,0 @@
1
- const root = '../../';
2
- const utils = require('../testing-utils.js');
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('same-different-html plugin', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-same-different-html.js');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['same-different-html']).not.toBe('undefined');
15
- });
16
-
17
- });