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,112 +0,0 @@
1
- const root = '../../';
2
-
3
- jest.useFakeTimers();
4
-
5
- describe('free-sort plugin', function(){
6
-
7
- beforeEach(function(){
8
- require(root + 'jspsych.js');
9
- require(root + 'plugins/jspsych-free-sort.js');
10
- });
11
-
12
- test('loads correctly', function(){
13
- expect(typeof window.jsPsych.plugins['free-sort']).not.toBe('undefined');
14
- });
15
-
16
- test('should display stimuli', function(){
17
- var trial = {
18
- type: 'free-sort',
19
- stimuli: ['img/happy_face_1.jpg','img/happy_face_2.jpg','img/happy_face_3.jpg','img/happy_face_4.jpg']
20
- }
21
-
22
- jsPsych.init({
23
- timeline: [trial],
24
- auto_preload: false
25
- });
26
-
27
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('src=\"img/happy_face_1.jpg\" data-src=\"img/happy_face_1.jpg\"'));
28
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('src=\"img/happy_face_2.jpg\" data-src=\"img/happy_face_2.jpg\"'));
29
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('src=\"img/happy_face_3.jpg\" data-src=\"img/happy_face_3.jpg\"'));
30
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('src=\"img/happy_face_4.jpg\" data-src=\"img/happy_face_4.jpg\"'));
31
- });
32
-
33
- test('should be able to adjust the height and width of free-sort area', function(){
34
- var trial = {
35
- type: 'free-sort',
36
- stimuli: ['img/happy_face_1.jpg','img/happy_face_2.jpg','img/happy_face_3.jpg','img/happy_face_4.jpg'],
37
- sort_area_height: 500,
38
- sort_area_width: 700,
39
- }
40
-
41
- jsPsych.init({
42
- timeline: [trial],
43
- auto_preload: false
44
- });
45
-
46
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('class=\"jspsych-free-sort-arena\" style=\"position: relative; width:700px; height:500px;'));
47
- });
48
-
49
- test('should be able to adjust the height and width of stimuli', function(){
50
- var trial = {
51
- type: 'free-sort',
52
- stimuli: ['img/happy_face_1.jpg','img/happy_face_2.jpg','img/happy_face_3.jpg','img/happy_face_4.jpg'],
53
- stim_height: 200,
54
- stim_width: 200,
55
- }
56
-
57
- jsPsych.init({
58
- timeline: [trial],
59
- auto_preload: false
60
- });
61
-
62
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<img src=\"img/happy_face_1.jpg\".+width:200px; height:200px'));
63
- });
64
-
65
- test('should display prompt', function(){
66
- var trial = {
67
- type: 'free-sort',
68
- stimuli: ['img/happy_face_1.jpg','img/happy_face_2.jpg','img/happy_face_3.jpg','img/happy_face_4.jpg'],
69
- prompt: '<p>This is a prompt</p>'
70
- }
71
-
72
- jsPsych.init({
73
- timeline: [trial],
74
- auto_preload: false
75
- });
76
-
77
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<p>This is a prompt</p>'));
78
- });
79
-
80
- test('should display prompt at bottom if prompt_location is "below"',function(){
81
- var trial = {
82
- type: 'free-sort',
83
- stimuli: ['img/happy_face_1.jpg','img/happy_face_2.jpg','img/happy_face_3.jpg','img/happy_face_4.jpg'],
84
- prompt: '<p>This is a prompt</p>',
85
- prompt_location: 'below',
86
- }
87
-
88
- jsPsych.init({
89
- timeline: [trial],
90
- auto_preload: false
91
- });
92
-
93
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<p>This is a prompt</p>.+<button id=\"jspsych-free-sort-done-btn\"'));
94
- });
95
-
96
- test('should be able to change label of button', function(){
97
- var trial = {
98
- type: 'free-sort',
99
- stimuli: ['img/happy_face_1.jpg','img/happy_face_2.jpg','img/happy_face_3.jpg','img/happy_face_4.jpg'],
100
- button_label: 'Finito'
101
-
102
- }
103
-
104
- jsPsych.init({
105
- timeline: [trial],
106
- auto_preload: false
107
- });
108
-
109
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<button id=\"jspsych-free-sort-done-btn\" class=\"jspsych-btn\".+>Finito</button>'));
110
- });
111
-
112
- });
@@ -1,41 +0,0 @@
1
- const root = '../../';
2
-
3
- jest.useFakeTimers();
4
-
5
- describe('fullscreen plugin', function(){
6
-
7
- beforeEach(function(){
8
- require(root + 'jspsych.js');
9
- require(root + 'plugins/jspsych-fullscreen.js');
10
- // require(root + 'plugins/jspsych-text.js');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['fullscreen']).not.toBe('undefined');
15
- });
16
-
17
- // can't test this right now because jsdom doesn't support fullscreen API.
18
-
19
- /*test('launches fullscreen mode by default', function(){
20
- var trial = {
21
- type: 'fullscreen',
22
- delay_after: 0
23
- }
24
-
25
- var text = {
26
- type: 'html-keyboard-response',
27
- stimulus: 'fullscreen'
28
- }
29
-
30
- jsPsych.init({
31
- timeline: [trial, text]
32
- });
33
-
34
- expect(document.fullscreenElement).toBeUndefined();
35
- console.log(jsPsych.getDisplayElement().requestFullscreen);
36
- document.querySelector('#jspsych-fullscreen-btn').dispatchEvent(new MouseEvent('click', {}));
37
-
38
- expect(document.fullscreenElement).not.toBeUndefined();
39
- });*/
40
-
41
- });
@@ -1,161 +0,0 @@
1
- const utils = require('../testing-utils.js');
2
- const root = '../../';
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('html-button-response', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-html-button-response');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['html-button-response']).not.toBe('undefined');
15
- });
16
-
17
- test('displays html stimulus', function(){
18
- var trial = {
19
- type: 'html-button-response',
20
- stimulus: 'this is html',
21
- choices: ['button-choice']
22
- }
23
-
24
- jsPsych.init({
25
- timeline: [trial]
26
- });
27
-
28
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-html-button-response-stimulus">this is html</div>');
29
- });
30
-
31
- test('display button labels', function(){
32
- var trial = {
33
- type: 'html-button-response',
34
- stimulus: 'this is html',
35
- choices: ['button-choice1', 'button-choice2']
36
- }
37
-
38
- jsPsych.init({
39
- timeline: [trial]
40
- });
41
-
42
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<button class=\"jspsych-btn\">button-choice1</button>'));
43
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<button class=\"jspsych-btn\">button-choice2</button>'));
44
- });
45
-
46
- test('display button html', function(){
47
- var trial = {
48
- type: 'html-button-response',
49
- stimulus: 'this is html',
50
- choices: ['buttonChoice'],
51
- button_html: '<button class="jspsych-custom-button">%choice%</button>',
52
- }
53
-
54
- jsPsych.init({
55
- timeline: [trial]
56
- });
57
-
58
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<button class="jspsych-custom-button">buttonChoice</button>'));
59
- });
60
-
61
- test('display should clear after button click', function(){
62
- var trial = {
63
- type: 'html-button-response',
64
- stimulus: 'this is html',
65
- choices: ['button-choice']
66
- }
67
-
68
- jsPsych.init({
69
- timeline: [trial]
70
- });
71
-
72
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<div id="jspsych-html-button-response-stimulus">this is html</div>'));
73
-
74
- utils.clickTarget(document.querySelector('#jspsych-html-button-response-button-0'));
75
-
76
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
77
- });
78
-
79
- test('prompt should append below button', function(){
80
- var trial = {
81
- type: 'html-button-response',
82
- stimulus: 'this is html',
83
- choices: ['button-choice'],
84
- prompt: '<p>this is a prompt</p>'
85
- }
86
-
87
- jsPsych.init({
88
- timeline: [trial]
89
- });
90
-
91
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<button class=\"jspsych-btn\">button-choice</button></div></div><p>this is a prompt</p>')
92
- });
93
-
94
- test('should hide stimulus if stimulus-duration is set', function(){
95
- var trial = {
96
- type: 'html-button-response',
97
- stimulus: 'this is html',
98
- choices: ['button-choice'],
99
- stimulus_duration: 500
100
- }
101
-
102
- jsPsych.init({
103
- timeline: [trial]
104
- });
105
-
106
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-html-button-response-stimulus').style.visibility).toMatch("");
107
- jest.runTimersToTime(500);
108
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-html-button-response-stimulus').style.visibility).toMatch('hidden');
109
- });
110
-
111
- test('should end trial when trial duration is reached', function(){
112
- var trial = {
113
- type: 'html-button-response',
114
- stimulus: 'this is html',
115
- choices: ['button-choice'],
116
- trial_duration: 500,
117
- }
118
-
119
- jsPsych.init({
120
- timeline: [trial]
121
- });
122
-
123
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-html-button-response-stimulus">this is html</div>');
124
- jest.runTimersToTime(500);
125
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
126
- });
127
-
128
- test('should end trial when button is clicked', function(){
129
- var trial = {
130
- type: 'html-button-response',
131
- stimulus: 'this is html',
132
- choices: ['button-choice'],
133
- response_ends_trial: true,
134
- }
135
-
136
- jsPsych.init({
137
- timeline: [trial]
138
- });
139
-
140
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-html-button-response-stimulus">this is html</div>');
141
- utils.clickTarget(document.querySelector('#jspsych-html-button-response-button-0'));
142
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
143
- });
144
-
145
- test('class should have responded when button is clicked', function(){
146
- var trial = {
147
- type: 'html-button-response',
148
- stimulus: 'this is html',
149
- choices: ['button-choice'],
150
- response_ends_trial: false,
151
- }
152
-
153
- jsPsych.init({
154
- timeline: [trial]
155
- });
156
-
157
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-html-button-response-stimulus">this is html</div>');
158
- utils.clickTarget(document.querySelector('#jspsych-html-button-response-button-0'));
159
- expect(document.querySelector('#jspsych-html-button-response-stimulus').className).toBe(' responded');
160
- });
161
- });
@@ -1,139 +0,0 @@
1
- const root = '../../';
2
- const utils = require('../testing-utils.js');
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('html-keyboard-response', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-html-keyboard-response');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['html-keyboard-response']).not.toBe('undefined');
15
- });
16
-
17
- test('displays html stimulus', function(){
18
- var trial = {
19
- type: 'html-keyboard-response',
20
- stimulus: 'this is html'
21
- }
22
-
23
- jsPsych.init({
24
- timeline: [trial]
25
- });
26
-
27
- expect(jsPsych.getDisplayElement().innerHTML).toBe('<div id="jspsych-html-keyboard-response-stimulus">this is html</div>');
28
-
29
- utils.pressKey(70);
30
- });
31
-
32
- test('display clears after key press', function(){
33
- var trial = {
34
- type: 'html-keyboard-response',
35
- stimulus: 'this is html',
36
- choices: ['f', 'j']
37
- }
38
-
39
- jsPsych.init({
40
- timeline: [trial]
41
- });
42
-
43
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<div id="jspsych-html-keyboard-response-stimulus">this is html</div>'));
44
-
45
- utils.pressKey(70);
46
-
47
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
48
- });
49
-
50
- test('prompt should append html below stimulus', function(){
51
- var trial = {
52
- type: 'html-keyboard-response',
53
- stimulus: 'this is html',
54
- choices: ['f', 'j'],
55
- prompt: '<div id="foo">this is a prompt</div>'
56
- }
57
-
58
- jsPsych.init({
59
- timeline: [trial]
60
- });
61
-
62
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<div id="jspsych-html-keyboard-response-stimulus">this is html</div><div id="foo">this is a prompt</div>'));
63
-
64
- utils.pressKey(70);
65
- });
66
-
67
- test('should hide stimulus if stimulus-duration is set', function(){
68
- var trial = {
69
- type: 'html-keyboard-response',
70
- stimulus: 'this is html',
71
- choices: ['f','j'],
72
- stimulus_duration: 500,
73
- }
74
-
75
- jsPsych.init({
76
- timeline: [trial]
77
- });
78
-
79
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-html-keyboard-response-stimulus').style.visibility).toMatch("");
80
- jest.runTimersToTime(500);
81
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-html-keyboard-response-stimulus').style.visibility).toMatch("hidden");
82
- utils.pressKey(70);
83
- });
84
-
85
- test('should end trial when trial duration is reached', function(){
86
- var trial ={
87
- type: 'html-keyboard-response',
88
- stimulus: 'this is html',
89
- choices: ['f', 'j'],
90
- trial_duration: 500,
91
- }
92
-
93
- jsPsych.init({
94
- timeline: [trial]
95
- });
96
-
97
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-html-keyboard-response-stimulus">this is html</div>');
98
- jest.runTimersToTime(500);
99
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
100
- });
101
-
102
- test('should end trial when key press', function(){
103
- var trial = {
104
- type: 'html-keyboard-response',
105
- stimulus: 'this is html',
106
- choices: ['f', 'j'],
107
- response_ends_trial: true,
108
- }
109
-
110
- jsPsych.init({
111
- timeline: [trial]
112
- });
113
-
114
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<div id="jspsych-html-keyboard-response-stimulus">this is html</div>'));
115
-
116
- utils.pressKey(70);
117
-
118
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
119
- });
120
-
121
- test('class should say responded when key is pressed', function(){
122
- var trial = {
123
- type: 'html-keyboard-response',
124
- stimulus: 'this is html',
125
- choices: ['f','j'],
126
- response_ends_trial: false,
127
- }
128
-
129
- jsPsych.init({
130
- timeline: [trial]
131
- });
132
-
133
- expect(jsPsych.getDisplayElement().innerHTML).toMatch(new RegExp('<div id="jspsych-html-keyboard-response-stimulus">this is html</div>'));
134
-
135
- utils.pressKey(70);
136
-
137
- expect(document.querySelector('#jspsych-html-keyboard-response-stimulus').className).toBe(' responded');
138
- });
139
- });
@@ -1,155 +0,0 @@
1
- const utils = require('../testing-utils.js');
2
- const root = '../../';
3
-
4
- jest.useFakeTimers();
5
-
6
- describe('html-slider-response', function(){
7
-
8
- beforeEach(function(){
9
- require(root + 'jspsych.js');
10
- require(root + 'plugins/jspsych-html-slider-response.js');
11
- });
12
-
13
- test('loads correctly', function(){
14
- expect(typeof window.jsPsych.plugins['html-slider-response']).not.toBe('undefined');
15
- });
16
-
17
- test('displays html stimulus', function(){
18
- var trial = {
19
- type: 'html-slider-response',
20
- stimulus: 'this is html',
21
- labels: ['left', 'right'],
22
- button_label: 'button'
23
- }
24
-
25
- jsPsych.init({
26
- timeline: [trial]
27
- });
28
-
29
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-html-slider-response-stimulus">this is html</div>');
30
- });
31
-
32
- test('displays labels', function(){
33
- var trial = {
34
- type: 'html-slider-response',
35
- stimulus: 'this is html',
36
- labels: ['left', 'right'],
37
- button_label: 'button'
38
- }
39
-
40
- jsPsych.init({
41
- timeline: [trial]
42
- });
43
-
44
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<span style=\"text-align: center; font-size: 80%;\">left</span>');
45
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<span style=\"text-align: center; font-size: 80%;\">right</span>');
46
- });
47
-
48
- test('displays button label', function(){
49
- var trial = {
50
- type: 'html-slider-response',
51
- stimulus: 'this is html',
52
- labels: ['left', 'right'],
53
- button_label: 'button'
54
- }
55
-
56
- jsPsych.init({
57
- timeline: [trial]
58
- });
59
-
60
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<button id=\"jspsych-html-slider-response-next\" class=\"jspsych-btn\">button</button>');
61
- });
62
-
63
- test('should set min, max and step', function(){
64
- var trial = {
65
- type: 'html-slider-response',
66
- stimulus: 'this is html',
67
- labels: ['left', 'right'],
68
- min: 2,
69
- max: 10,
70
- step: 2,
71
- button_label: 'button'
72
- }
73
-
74
- jsPsych.init({
75
- timeline: [trial]
76
- });
77
-
78
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-html-slider-response-response').min).toBe('2');
79
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-html-slider-response-response').max).toBe('10');
80
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-html-slider-response-response').step).toBe('2');
81
- });
82
-
83
- test('should append to bottom on stimulus', function(){
84
- var trial = {
85
- type: 'html-slider-response',
86
- stimulus: 'this is html',
87
- labels: ['left', 'right'],
88
- button_label: 'button',
89
- prompt: '<p>This is a prompt</p>'
90
- }
91
-
92
- jsPsych.init({
93
- timeline: [trial]
94
- });
95
-
96
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<p>This is a prompt</p>');
97
- });
98
-
99
- test('should hide stimulus if stimulus_duration is set', function(){
100
- var trial = {
101
- type: 'html-slider-response',
102
- stimulus: 'this is html',
103
- labels: ['left', 'right'],
104
- button_label: 'button',
105
- stimulus_duration: 500
106
- }
107
-
108
- jsPsych.init({
109
- timeline: [trial]
110
- });
111
-
112
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-html-slider-response-stimulus').style.visibility).toMatch("");
113
- jest.runTimersToTime(500);
114
- expect(jsPsych.getDisplayElement().querySelector('#jspsych-html-slider-response-stimulus').style.visibility).toMatch("hidden");
115
- });
116
-
117
- test('should end trial when trial duration is reached', function(){
118
- var trial = {
119
- type: 'html-slider-response',
120
- stimulus: 'this is html',
121
- labels: ['left', 'right'],
122
- button_label: 'button',
123
- trial_duration: 500
124
-
125
- }
126
-
127
- jsPsych.init({
128
- timeline: [trial]
129
- });
130
-
131
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-html-slider-response-stimulus">this is html</div>');
132
- jest.runTimersToTime(500);
133
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
134
- });
135
-
136
- test('should end trial when button is clicked', function(){
137
- var trial = {
138
- type: 'html-slider-response',
139
- stimulus: 'this is html',
140
- labels: ['left', 'right'],
141
- button_label: 'button',
142
- response_ends_trial: true
143
- }
144
-
145
- jsPsych.init({
146
- timeline: [trial]
147
- });
148
-
149
- expect(jsPsych.getDisplayElement().innerHTML).toMatch('<div id="jspsych-html-slider-response-stimulus">this is html</div>');
150
-
151
- utils.clickTarget(document.querySelector('#jspsych-html-slider-response-next'));
152
-
153
- expect(jsPsych.getDisplayElement().innerHTML).toBe('');
154
- });
155
- });