jspsych 6.3.0 → 7.1.1
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.
- package/README.md +36 -37
- package/css/jspsych.css +39 -39
- package/dist/JsPsych.d.ts +112 -0
- package/dist/TimelineNode.d.ts +34 -0
- package/dist/index.browser.js +3164 -0
- package/dist/index.browser.js.map +1 -0
- package/dist/index.browser.min.js +2 -0
- package/dist/index.browser.min.js.map +1 -0
- package/dist/index.cjs +3158 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.js +3152 -0
- package/dist/index.js.map +1 -0
- package/dist/migration.d.ts +3 -0
- package/dist/modules/data/DataCollection.d.ts +45 -0
- package/dist/modules/data/DataColumn.d.ts +15 -0
- package/dist/modules/data/index.d.ts +25 -0
- package/dist/modules/data/utils.d.ts +3 -0
- package/dist/modules/extensions.d.ts +22 -0
- package/dist/modules/plugin-api/HardwareAPI.d.ts +15 -0
- package/dist/modules/plugin-api/KeyboardListenerAPI.d.ts +34 -0
- package/dist/modules/plugin-api/MediaAPI.d.ts +27 -0
- package/dist/modules/plugin-api/SimulationAPI.d.ts +41 -0
- package/dist/modules/plugin-api/TimeoutAPI.d.ts +5 -0
- package/dist/modules/plugin-api/index.d.ts +8 -0
- package/dist/modules/plugins.d.ts +129 -0
- package/dist/modules/randomization.d.ts +35 -0
- package/dist/modules/turk.d.ts +40 -0
- package/dist/modules/utils.d.ts +7 -0
- package/package.json +32 -15
- package/src/JsPsych.ts +884 -0
- package/src/TimelineNode.ts +536 -0
- package/src/index.ts +71 -0
- package/src/migration.ts +37 -0
- package/src/modules/data/DataCollection.ts +198 -0
- package/src/modules/data/DataColumn.ts +86 -0
- package/src/modules/data/index.ts +174 -0
- package/src/modules/data/utils.ts +75 -0
- package/src/modules/extensions.ts +23 -0
- package/src/modules/plugin-api/HardwareAPI.ts +32 -0
- package/src/modules/plugin-api/KeyboardListenerAPI.ts +165 -0
- package/src/modules/plugin-api/MediaAPI.ts +337 -0
- package/src/modules/plugin-api/SimulationAPI.ts +181 -0
- package/src/modules/plugin-api/TimeoutAPI.ts +16 -0
- package/src/modules/plugin-api/index.ts +28 -0
- package/src/modules/plugins.ts +158 -0
- package/src/modules/randomization.ts +327 -0
- package/src/modules/turk.ts +99 -0
- package/src/modules/utils.ts +30 -0
- package/.github/workflows/jest.yml +0 -20
- package/code-of-conduct.md +0 -56
- package/contributors.md +0 -61
- package/docs/CNAME +0 -1
- package/docs/about/about.md +0 -18
- package/docs/about/contributing.md +0 -43
- package/docs/about/license.md +0 -25
- package/docs/about/support.md +0 -7
- package/docs/core_library/jspsych-core.md +0 -734
- package/docs/core_library/jspsych-data.md +0 -589
- package/docs/core_library/jspsych-pluginAPI.md +0 -610
- package/docs/core_library/jspsych-randomization.md +0 -397
- package/docs/core_library/jspsych-turk.md +0 -102
- package/docs/extensions/extensions.md +0 -83
- package/docs/extensions/jspsych-ext-webgazer.md +0 -106
- package/docs/img/blue.png +0 -0
- package/docs/img/devtools-change-css.png +0 -0
- package/docs/img/devtools-css-errors.png +0 -0
- package/docs/img/devtools-inspect-element.png +0 -0
- package/docs/img/folder-setup.png +0 -0
- package/docs/img/folder-with-html.png +0 -0
- package/docs/img/githubreleases.jpg +0 -0
- package/docs/img/jspsych-favicon.png +0 -0
- package/docs/img/jspsych-logo-no-text-mono.svg +0 -493
- package/docs/img/jspsych-logo.jpg +0 -0
- package/docs/img/orange.png +0 -0
- package/docs/img/palmer_stim.png +0 -0
- package/docs/img/progress_bar.png +0 -0
- package/docs/img/prolific-study-completion.png +0 -0
- package/docs/img/prolific-study-link.png +0 -0
- package/docs/img/visual_search_example.jpg +0 -0
- package/docs/index.md +0 -9
- package/docs/overview/browser-device-support.md +0 -35
- package/docs/overview/callbacks.md +0 -184
- package/docs/overview/data.md +0 -281
- package/docs/overview/dynamic-parameters.md +0 -147
- package/docs/overview/exclude-browser.md +0 -32
- package/docs/overview/experiment-options.md +0 -149
- package/docs/overview/eye-tracking.md +0 -237
- package/docs/overview/fullscreen.md +0 -36
- package/docs/overview/media-preloading.md +0 -369
- package/docs/overview/mturk.md +0 -77
- package/docs/overview/plugins.md +0 -320
- package/docs/overview/progress-bar.md +0 -110
- package/docs/overview/prolific.md +0 -78
- package/docs/overview/record-browser-interactions.md +0 -23
- package/docs/overview/running-experiments.md +0 -95
- package/docs/overview/style.md +0 -293
- package/docs/overview/timeline.md +0 -457
- package/docs/plugins/jspsych-animation.md +0 -40
- package/docs/plugins/jspsych-audio-button-response.md +0 -60
- package/docs/plugins/jspsych-audio-keyboard-response.md +0 -58
- package/docs/plugins/jspsych-audio-slider-response.md +0 -53
- package/docs/plugins/jspsych-call-function.md +0 -81
- package/docs/plugins/jspsych-canvas-button-response.md +0 -66
- package/docs/plugins/jspsych-canvas-keyboard-response.md +0 -68
- package/docs/plugins/jspsych-canvas-slider-response.md +0 -89
- package/docs/plugins/jspsych-categorize-animation.md +0 -60
- package/docs/plugins/jspsych-categorize-html.md +0 -53
- package/docs/plugins/jspsych-categorize-image.md +0 -53
- package/docs/plugins/jspsych-cloze.md +0 -45
- package/docs/plugins/jspsych-external-html.md +0 -70
- package/docs/plugins/jspsych-free-sort.md +0 -56
- package/docs/plugins/jspsych-fullscreen.md +0 -57
- package/docs/plugins/jspsych-html-button-response.md +0 -42
- package/docs/plugins/jspsych-html-keyboard-response.md +0 -51
- package/docs/plugins/jspsych-html-slider-response.md +0 -45
- package/docs/plugins/jspsych-iat-html.md +0 -64
- package/docs/plugins/jspsych-iat-image.md +0 -64
- package/docs/plugins/jspsych-image-button-response.md +0 -48
- package/docs/plugins/jspsych-image-keyboard-response.md +0 -58
- package/docs/plugins/jspsych-image-slider-response.md +0 -54
- package/docs/plugins/jspsych-instructions.md +0 -58
- package/docs/plugins/jspsych-maxdiff.md +0 -41
- package/docs/plugins/jspsych-preload.md +0 -128
- package/docs/plugins/jspsych-rdk.md +0 -119
- package/docs/plugins/jspsych-reconstruction.md +0 -48
- package/docs/plugins/jspsych-resize.md +0 -39
- package/docs/plugins/jspsych-same-different-html.md +0 -53
- package/docs/plugins/jspsych-same-different-image.md +0 -66
- package/docs/plugins/jspsych-serial-reaction-time-mouse.md +0 -52
- package/docs/plugins/jspsych-serial-reaction-time.md +0 -57
- package/docs/plugins/jspsych-survey-html-form.md +0 -50
- package/docs/plugins/jspsych-survey-likert.md +0 -70
- package/docs/plugins/jspsych-survey-multi-choice.md +0 -48
- package/docs/plugins/jspsych-survey-multi-select.md +0 -53
- package/docs/plugins/jspsych-survey-text.md +0 -63
- package/docs/plugins/jspsych-video-button-response.md +0 -54
- package/docs/plugins/jspsych-video-keyboard-response.md +0 -50
- package/docs/plugins/jspsych-video-slider-response.md +0 -60
- package/docs/plugins/jspsych-virtual-chinrest.md +0 -105
- package/docs/plugins/jspsych-visual-search-circle.md +0 -52
- package/docs/plugins/jspsych-vsl-animate-occlusion.md +0 -55
- package/docs/plugins/jspsych-vsl-grid-scene.md +0 -62
- package/docs/plugins/jspsych-webgazer-calibrate.md +0 -60
- package/docs/plugins/jspsych-webgazer-init-camera.md +0 -31
- package/docs/plugins/jspsych-webgazer-validate.md +0 -43
- package/docs/plugins/list-of-plugins.md +0 -54
- package/docs/tutorials/hello-world.md +0 -162
- package/docs/tutorials/rt-task.md +0 -1334
- package/docs/tutorials/video-tutorials.md +0 -11
- package/examples/add-to-end-of-timeline.html +0 -38
- package/examples/case-sensitive-responses.html +0 -45
- package/examples/conditional-and-loop-functions.html +0 -64
- package/examples/css/jquery-ui.css +0 -1225
- package/examples/css-classes-parameter.html +0 -145
- package/examples/data-add-properties.html +0 -44
- package/examples/data-as-function.html +0 -39
- package/examples/data-from-timeline.html +0 -52
- package/examples/data-from-url.html +0 -21
- package/examples/demo-flanker.html +0 -117
- package/examples/demo-simple-rt-task.html +0 -120
- package/examples/demos/demo_1.html +0 -35
- package/examples/demos/demo_2.html +0 -50
- package/examples/demos/demo_3.html +0 -63
- package/examples/display-element-to-embed-experiment.html +0 -79
- package/examples/end-active-node.html +0 -52
- package/examples/end-experiment.html +0 -45
- package/examples/exclusions.html +0 -32
- package/examples/external_html/simple_consent.html +0 -4
- package/examples/img/1.gif +0 -0
- package/examples/img/10.gif +0 -0
- package/examples/img/11.gif +0 -0
- package/examples/img/12.gif +0 -0
- package/examples/img/2.gif +0 -0
- package/examples/img/3.gif +0 -0
- package/examples/img/4.gif +0 -0
- package/examples/img/5.gif +0 -0
- package/examples/img/6.gif +0 -0
- package/examples/img/7.gif +0 -0
- package/examples/img/8.gif +0 -0
- package/examples/img/9.gif +0 -0
- package/examples/img/age/of1.jpg +0 -0
- package/examples/img/age/of2.jpg +0 -0
- package/examples/img/age/of3.jpg +0 -0
- package/examples/img/age/om1.jpg +0 -0
- package/examples/img/age/om2.jpg +0 -0
- package/examples/img/age/om3.jpg +0 -0
- package/examples/img/age/yf1.jpg +0 -0
- package/examples/img/age/yf4.jpg +0 -0
- package/examples/img/age/yf5.jpg +0 -0
- package/examples/img/age/ym2.jpg +0 -0
- package/examples/img/age/ym3.jpg +0 -0
- package/examples/img/age/ym5.jpg +0 -0
- package/examples/img/backwardN.gif +0 -0
- package/examples/img/blue.png +0 -0
- package/examples/img/card.png +0 -0
- package/examples/img/con1.png +0 -0
- package/examples/img/con2.png +0 -0
- package/examples/img/fixation.gif +0 -0
- package/examples/img/happy_face_1.jpg +0 -0
- package/examples/img/happy_face_2.jpg +0 -0
- package/examples/img/happy_face_3.jpg +0 -0
- package/examples/img/happy_face_4.jpg +0 -0
- package/examples/img/inc1.png +0 -0
- package/examples/img/inc2.png +0 -0
- package/examples/img/normalN.gif +0 -0
- package/examples/img/orange.png +0 -0
- package/examples/img/redX.png +0 -0
- package/examples/img/ribbon.jpg +0 -0
- package/examples/img/sad_face_1.jpg +0 -0
- package/examples/img/sad_face_2.jpg +0 -0
- package/examples/img/sad_face_3.jpg +0 -0
- package/examples/img/sad_face_4.jpg +0 -0
- package/examples/js/snap.svg-min.js +0 -21
- package/examples/js/webgazer.js +0 -88886
- package/examples/jspsych-RDK.html +0 -58
- package/examples/jspsych-animation.html +0 -39
- package/examples/jspsych-audio-button-response.html +0 -58
- package/examples/jspsych-audio-keyboard-response.html +0 -68
- package/examples/jspsych-audio-slider-response.html +0 -61
- package/examples/jspsych-call-function.html +0 -32
- package/examples/jspsych-canvas-button-response.html +0 -95
- package/examples/jspsych-canvas-keyboard-response.html +0 -78
- package/examples/jspsych-canvas-slider-response.html +0 -67
- package/examples/jspsych-categorize-animation.html +0 -49
- package/examples/jspsych-categorize-html.html +0 -33
- package/examples/jspsych-categorize-image.html +0 -44
- package/examples/jspsych-cloze.html +0 -37
- package/examples/jspsych-free-sort.html +0 -109
- package/examples/jspsych-fullscreen.html +0 -45
- package/examples/jspsych-html-button-response.html +0 -43
- package/examples/jspsych-html-keyboard-response.html +0 -42
- package/examples/jspsych-html-slider-response.html +0 -53
- package/examples/jspsych-iat.html +0 -520
- package/examples/jspsych-image-button-response.html +0 -91
- package/examples/jspsych-image-keyboard-response.html +0 -85
- package/examples/jspsych-image-slider-response.html +0 -85
- package/examples/jspsych-instructions.html +0 -37
- package/examples/jspsych-maxdiff.html +0 -33
- package/examples/jspsych-preload.html +0 -140
- package/examples/jspsych-reconstruction.html +0 -43
- package/examples/jspsych-resize.html +0 -34
- package/examples/jspsych-same-different-html.html +0 -28
- package/examples/jspsych-same-different-image.html +0 -39
- package/examples/jspsych-serial-reaction-time-mouse.html +0 -98
- package/examples/jspsych-serial-reaction-time.html +0 -54
- package/examples/jspsych-survey-html-form.html +0 -33
- package/examples/jspsych-survey-likert.html +0 -42
- package/examples/jspsych-survey-multi-choice.html +0 -40
- package/examples/jspsych-survey-multi-select.html +0 -42
- package/examples/jspsych-survey-text.html +0 -34
- package/examples/jspsych-video-button-response.html +0 -65
- package/examples/jspsych-video-keyboard-response.html +0 -61
- package/examples/jspsych-video-slider-response.html +0 -63
- package/examples/jspsych-virtual-chinrest.html +0 -69
- package/examples/jspsych-visual-search-circle.html +0 -64
- package/examples/jspsych-vsl-animate-occlusion.html +0 -35
- package/examples/jspsych-vsl-grid-scene.html +0 -47
- package/examples/lexical-decision.html +0 -134
- package/examples/manual-preloading.html +0 -59
- package/examples/pause-unpause.html +0 -33
- package/examples/progress-bar.html +0 -68
- package/examples/save-trial-parameters.html +0 -98
- package/examples/sound/hammer.mp3 +0 -0
- package/examples/sound/sound.mp3 +0 -0
- package/examples/sound/speech_blue.mp3 +0 -0
- package/examples/sound/speech_green.mp3 +0 -0
- package/examples/sound/speech_joke.mp3 +0 -0
- package/examples/sound/speech_red.mp3 +0 -0
- package/examples/sound/tone.mp3 +0 -0
- package/examples/timeline-variables-sampling.html +0 -50
- package/examples/timeline-variables.html +0 -64
- package/examples/video/sample_video.mp4 +0 -0
- package/examples/webgazer.html +0 -162
- package/examples/webgazer_image.html +0 -60
- package/extensions/jspsych-ext-webgazer.js +0 -185
- package/jspsych.js +0 -3015
- package/license.txt +0 -21
- package/mkdocs.yml +0 -118
- package/plugins/jspsych-animation.js +0 -189
- package/plugins/jspsych-audio-button-response.js +0 -269
- package/plugins/jspsych-audio-keyboard-response.js +0 -212
- package/plugins/jspsych-audio-slider-response.js +0 -278
- package/plugins/jspsych-call-function.js +0 -58
- package/plugins/jspsych-canvas-button-response.js +0 -199
- package/plugins/jspsych-canvas-keyboard-response.js +0 -155
- package/plugins/jspsych-canvas-slider-response.js +0 -207
- package/plugins/jspsych-categorize-animation.js +0 -266
- package/plugins/jspsych-categorize-html.js +0 -220
- package/plugins/jspsych-categorize-image.js +0 -222
- package/plugins/jspsych-cloze.js +0 -112
- package/plugins/jspsych-external-html.js +0 -112
- package/plugins/jspsych-free-sort.js +0 -478
- package/plugins/jspsych-fullscreen.js +0 -106
- package/plugins/jspsych-html-button-response.js +0 -188
- package/plugins/jspsych-html-keyboard-response.js +0 -149
- package/plugins/jspsych-html-slider-response.js +0 -202
- package/plugins/jspsych-iat-html.js +0 -284
- package/plugins/jspsych-iat-image.js +0 -286
- package/plugins/jspsych-image-button-response.js +0 -327
- package/plugins/jspsych-image-keyboard-response.js +0 -263
- package/plugins/jspsych-image-slider-response.js +0 -369
- package/plugins/jspsych-instructions.js +0 -237
- package/plugins/jspsych-maxdiff.js +0 -173
- package/plugins/jspsych-preload.js +0 -345
- package/plugins/jspsych-rdk.js +0 -1373
- package/plugins/jspsych-reconstruction.js +0 -134
- package/plugins/jspsych-resize.js +0 -166
- package/plugins/jspsych-same-different-html.js +0 -168
- package/plugins/jspsych-same-different-image.js +0 -169
- package/plugins/jspsych-serial-reaction-time-mouse.js +0 -212
- package/plugins/jspsych-serial-reaction-time.js +0 -247
- package/plugins/jspsych-survey-html-form.js +0 -171
- package/plugins/jspsych-survey-likert.js +0 -195
- package/plugins/jspsych-survey-multi-choice.js +0 -208
- package/plugins/jspsych-survey-multi-select.js +0 -232
- package/plugins/jspsych-survey-text.js +0 -185
- package/plugins/jspsych-video-button-response.js +0 -335
- package/plugins/jspsych-video-keyboard-response.js +0 -279
- package/plugins/jspsych-video-slider-response.js +0 -351
- package/plugins/jspsych-virtual-chinrest.js +0 -471
- package/plugins/jspsych-visual-search-circle.js +0 -259
- package/plugins/jspsych-vsl-animate-occlusion.js +0 -196
- package/plugins/jspsych-vsl-grid-scene.js +0 -103
- package/plugins/jspsych-webgazer-calibrate.js +0 -166
- package/plugins/jspsych-webgazer-init-camera.js +0 -95
- package/plugins/jspsych-webgazer-validate.js +0 -304
- package/plugins/template/jspsych-plugin-template.js +0 -35
- package/tests/README.md +0 -7
- package/tests/jsPsych/case-sensitive-responses.test.js +0 -53
- package/tests/jsPsych/css-classes-parameter.test.js +0 -107
- package/tests/jsPsych/default-iti.test.js +0 -51
- package/tests/jsPsych/default-parameters.test.js +0 -58
- package/tests/jsPsych/endexperiment.test.js +0 -49
- package/tests/jsPsych/events.test.js +0 -606
- package/tests/jsPsych/functions-as-parameters.test.js +0 -210
- package/tests/jsPsych/init.test.js +0 -48
- package/tests/jsPsych/loads.test.js +0 -7
- package/tests/jsPsych/min-rt.test.js +0 -58
- package/tests/jsPsych/progressbar.test.js +0 -202
- package/tests/jsPsych/timeline-variables.test.js +0 -531
- package/tests/jsPsych/timelines.test.js +0 -569
- package/tests/jsPsych.data/data-csv-conversion.test.js +0 -85
- package/tests/jsPsych.data/data-json-conversion.test.js +0 -120
- package/tests/jsPsych.data/datacollection.test.js +0 -117
- package/tests/jsPsych.data/datacolumn.test.js +0 -50
- package/tests/jsPsych.data/datamodule.test.js +0 -152
- package/tests/jsPsych.data/dataparameter.test.js +0 -251
- package/tests/jsPsych.data/interactions.test.js +0 -109
- package/tests/jsPsych.data/trialparameters.test.js +0 -175
- package/tests/jsPsych.extensions/extensions.test.js +0 -207
- package/tests/jsPsych.extensions/test-extension.js +0 -42
- package/tests/jsPsych.pluginAPI/pluginapi.test.js +0 -341
- package/tests/jsPsych.pluginAPI/preloads.test.js +0 -43
- package/tests/jsPsych.randomization/randomziation.test.js +0 -27
- package/tests/jsPsych.utils/utils.test.js +0 -58
- package/tests/plugins/plugin-animation.test.js +0 -34
- package/tests/plugins/plugin-audio-button-response.test.js +0 -15
- package/tests/plugins/plugin-audio-keyboard-response.test.js +0 -15
- package/tests/plugins/plugin-audio-slider-response.test.js +0 -15
- package/tests/plugins/plugin-call-function.test.js +0 -49
- package/tests/plugins/plugin-categorize-animation.test.js +0 -263
- package/tests/plugins/plugin-categorize-html.test.js +0 -17
- package/tests/plugins/plugin-categorize-image.test.js +0 -17
- package/tests/plugins/plugin-cloze.test.js +0 -157
- package/tests/plugins/plugin-free-sort.test.js +0 -106
- package/tests/plugins/plugin-fullscreen.test.js +0 -41
- package/tests/plugins/plugin-html-button-response.test.js +0 -161
- package/tests/plugins/plugin-html-keyboard-response.test.js +0 -139
- package/tests/plugins/plugin-html-slider-response.test.js +0 -155
- package/tests/plugins/plugin-iat-html.test.js +0 -299
- package/tests/plugins/plugin-iat-image.test.js +0 -298
- package/tests/plugins/plugin-image-button-response.test.js +0 -174
- package/tests/plugins/plugin-image-keyboard-response.test.js +0 -147
- package/tests/plugins/plugin-image-slider-response.test.js +0 -174
- package/tests/plugins/plugin-instructions.test.js +0 -85
- package/tests/plugins/plugin-maxdiff.test.js +0 -39
- package/tests/plugins/plugin-preload.test.js +0 -916
- package/tests/plugins/plugin-rdk.test.js +0 -61
- package/tests/plugins/plugin-reconstruction.test.js +0 -16
- package/tests/plugins/plugin-resize.test.js +0 -16
- package/tests/plugins/plugin-same-different-html.test.js +0 -17
- package/tests/plugins/plugin-same-different-image.test.js +0 -17
- package/tests/plugins/plugin-serial-reaction-time-mouse.test.js +0 -42
- package/tests/plugins/plugin-serial-reaction-time.test.js +0 -109
- package/tests/plugins/plugin-survey-html-form.test.js +0 -44
- package/tests/plugins/plugin-survey-likert.test.js +0 -48
- package/tests/plugins/plugin-survey-multi-choice.test.js +0 -47
- package/tests/plugins/plugin-survey-multi-select.test.js +0 -71
- package/tests/plugins/plugin-survey-text.test.js +0 -115
- package/tests/plugins/plugin-video-button-response.test.js +0 -32
- package/tests/plugins/plugin-video-keyboard-response.test.js +0 -32
- package/tests/plugins/plugin-video-slider-response.test.js +0 -31
- package/tests/plugins/plugin-visual-search-circle.test.js +0 -16
- package/tests/plugins/plugin-vsl-animate-occlusion.test.js +0 -16
- package/tests/plugins/plugin-vsl-grid-scene.test.js +0 -16
- package/tests/testing-utils.js +0 -13
package/license.txt
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
The MIT License (MIT)
|
|
2
|
-
|
|
3
|
-
Copyright (c) 2014-2018 Joshua R. de Leeuw
|
|
4
|
-
|
|
5
|
-
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
in the Software without restriction, including without limitation the rights
|
|
8
|
-
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
furnished to do so, subject to the following conditions:
|
|
11
|
-
|
|
12
|
-
The above copyright notice and this permission notice shall be included in all
|
|
13
|
-
copies or substantial portions of the Software.
|
|
14
|
-
|
|
15
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
-
SOFTWARE.
|
package/mkdocs.yml
DELETED
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
site_name: jsPsych
|
|
2
|
-
theme:
|
|
3
|
-
name: 'material'
|
|
4
|
-
language: 'en'
|
|
5
|
-
palette:
|
|
6
|
-
primary: 'green'
|
|
7
|
-
accent: 'orange'
|
|
8
|
-
logo: 'img/jspsych-logo-no-text-mono.svg'
|
|
9
|
-
favicon: 'img/jspsych-favicon.png'
|
|
10
|
-
extra:
|
|
11
|
-
social:
|
|
12
|
-
- icon: 'fontawesome/brands/github'
|
|
13
|
-
link: 'https://github.com/jspsych'
|
|
14
|
-
- icon: 'fontawesome/brands/twitter'
|
|
15
|
-
link: 'https://twitter.com/joshdeleeuw'
|
|
16
|
-
copyright: 'Copyright © 2012-2021 Josh de Leeuw'
|
|
17
|
-
google_analytics:
|
|
18
|
-
- 'UA-50563838-1'
|
|
19
|
-
- 'auto'
|
|
20
|
-
markdown_extensions:
|
|
21
|
-
- admonition
|
|
22
|
-
- codehilite:
|
|
23
|
-
guess_lang: false
|
|
24
|
-
- toc:
|
|
25
|
-
permalink: true
|
|
26
|
-
- pymdownx.superfences
|
|
27
|
-
- pymdownx.details
|
|
28
|
-
repo_url: 'https://github.com/jspsych/jsPsych'
|
|
29
|
-
repo_name: 'jspsych/jspsych'
|
|
30
|
-
docs_dir: docs
|
|
31
|
-
nav:
|
|
32
|
-
- Introduction: 'index.md'
|
|
33
|
-
- Tutorials:
|
|
34
|
-
- 'The Basics: Hello World': 'tutorials/hello-world.md'
|
|
35
|
-
- 'Demo Experiment: Simple Reaction Time Task': 'tutorials/rt-task.md'
|
|
36
|
-
- 'Video Tutorials': 'tutorials/video-tutorials.md'
|
|
37
|
-
- Overview:
|
|
38
|
-
- 'Creating an Experiment: The Timeline': 'overview/timeline.md'
|
|
39
|
-
- 'Plugins': 'overview/plugins.md'
|
|
40
|
-
- 'Dynamic Parameters': 'overview/dynamic-parameters.md'
|
|
41
|
-
- 'Controlling Visual Appearance': 'overview/style.md'
|
|
42
|
-
- 'Data Storage, Aggregation, and Manipulation': 'overview/data.md'
|
|
43
|
-
- 'Running Experiments': 'overview/running-experiments.md'
|
|
44
|
-
- 'Experiment Settings': 'overview/experiment-options.md'
|
|
45
|
-
- 'Event-related Callback Functions': 'overview/callbacks.md'
|
|
46
|
-
- 'Record Browser Interactions': 'overview/record-browser-interactions.md'
|
|
47
|
-
- 'Media Preloading': 'overview/media-preloading.md'
|
|
48
|
-
- 'Fullscreen Experiments': 'overview/fullscreen.md'
|
|
49
|
-
- 'Eye Tracking': 'overview/eye-tracking.md'
|
|
50
|
-
- 'Exclude Participants Based on Browser Features': 'overview/exclude-browser.md'
|
|
51
|
-
- 'Automatic Progress Bar': 'overview/progress-bar.md'
|
|
52
|
-
- 'Integrating with Prolific': 'overview/prolific.md'
|
|
53
|
-
- 'Integrating with Mechanical Turk': 'overview/mturk.md'
|
|
54
|
-
- 'Browser and Device Support': 'overview/browser-device-support.md'
|
|
55
|
-
- Reference:
|
|
56
|
-
- 'jsPsych': 'core_library/jspsych-core.md'
|
|
57
|
-
- 'jsPsych.data': 'core_library/jspsych-data.md'
|
|
58
|
-
- 'jsPsych.randomization': 'core_library/jspsych-randomization.md'
|
|
59
|
-
- 'jsPsych.turk': 'core_library/jspsych-turk.md'
|
|
60
|
-
- 'jsPsych.pluginAPI': 'core_library/jspsych-pluginAPI.md'
|
|
61
|
-
- Plugins:
|
|
62
|
-
- 'List of Plugins': 'plugins/list-of-plugins.md'
|
|
63
|
-
- 'jspsych-animation': 'plugins/jspsych-animation.md'
|
|
64
|
-
- 'jspsych-audio-button-response': 'plugins/jspsych-audio-button-response.md'
|
|
65
|
-
- 'jspsych-audio-keyboard-response': 'plugins/jspsych-audio-keyboard-response.md'
|
|
66
|
-
- 'jspsych-audio-slider-response': 'plugins/jspsych-audio-slider-response.md'
|
|
67
|
-
- 'jspsych-canvas-button-response': 'plugins/jspsych-canvas-button-response.md'
|
|
68
|
-
- 'jspsych-canvas-keyboard-response': 'plugins/jspsych-canvas-keyboard-response.md'
|
|
69
|
-
- 'jspsych-canvas-slider-response': 'plugins/jspsych-canvas-slider-response.md'
|
|
70
|
-
- 'jspsych-call-function': 'plugins/jspsych-call-function.md'
|
|
71
|
-
- 'jspsych-categorize-animation': 'plugins/jspsych-categorize-animation.md'
|
|
72
|
-
- 'jspsych-categorize-html': 'plugins/jspsych-categorize-html.md'
|
|
73
|
-
- 'jspsych-categorize-image': 'plugins/jspsych-categorize-image.md'
|
|
74
|
-
- 'jspsych-cloze' : 'plugins/jspsych-cloze.md'
|
|
75
|
-
- 'jspsych-external-html': 'plugins/jspsych-external-html.md'
|
|
76
|
-
- 'jspsych-free-sort': 'plugins/jspsych-free-sort.md'
|
|
77
|
-
- 'jspsych-fullscreen': 'plugins/jspsych-fullscreen.md'
|
|
78
|
-
- 'jspsych-html-button-response': 'plugins/jspsych-html-button-response.md'
|
|
79
|
-
- 'jspsych-html-keyboard-response': 'plugins/jspsych-html-keyboard-response.md'
|
|
80
|
-
- 'jspsych-html-slider-response': 'plugins/jspsych-html-slider-response.md'
|
|
81
|
-
- 'jspsych-iat-html': 'plugins/jspsych-iat-html.md'
|
|
82
|
-
- 'jspsych-iat-image': 'plugins/jspsych-iat-image.md'
|
|
83
|
-
- 'jspsych-image-button-response': 'plugins/jspsych-image-button-response.md'
|
|
84
|
-
- 'jspsych-image-keyboard-response': 'plugins/jspsych-image-keyboard-response.md'
|
|
85
|
-
- 'jspsych-image-slider-response': 'plugins/jspsych-image-slider-response.md'
|
|
86
|
-
- 'jspsych-instructions': 'plugins/jspsych-instructions.md'
|
|
87
|
-
- 'jspsych-maxdiff': 'plugins/jspsych-maxdiff.md'
|
|
88
|
-
- 'jspsych-preload': 'plugins/jspsych-preload.md'
|
|
89
|
-
- 'jspsych-rdk': 'plugins/jspsych-rdk.md'
|
|
90
|
-
- 'jspsych-reconstruction': 'plugins/jspsych-reconstruction.md'
|
|
91
|
-
- 'jspsych-resize': 'plugins/jspsych-resize.md'
|
|
92
|
-
- 'jspsych-same-different-html': 'plugins/jspsych-same-different-html.md'
|
|
93
|
-
- 'jspsych-same-different-image': 'plugins/jspsych-same-different-image.md'
|
|
94
|
-
- 'jspsych-serial-reaction-time': 'plugins/jspsych-serial-reaction-time.md'
|
|
95
|
-
- 'jspsych-serial-reaction-time-mouse': 'plugins/jspsych-serial-reaction-time-mouse.md'
|
|
96
|
-
- 'jspsych-survey-html-form' : 'plugins/jspsych-survey-html-form.md'
|
|
97
|
-
- 'jspsych-survey-likert': 'plugins/jspsych-survey-likert.md'
|
|
98
|
-
- 'jspsych-survey-multi-choice': 'plugins/jspsych-survey-multi-choice.md'
|
|
99
|
-
- 'jspsych-survey-multi-select': 'plugins/jspsych-survey-multi-select.md'
|
|
100
|
-
- 'jspsych-survey-text': 'plugins/jspsych-survey-text.md'
|
|
101
|
-
- 'jspsych-video-button-response': 'plugins/jspsych-video-button-response.md'
|
|
102
|
-
- 'jspsych-video-keyboard-response': 'plugins/jspsych-video-keyboard-response.md'
|
|
103
|
-
- 'jspsych-video-slider-response': 'plugins/jspsych-video-slider-response.md'
|
|
104
|
-
- 'jspsych-virtual-chinrest' : 'plugins/jspsych-virtual-chinrest.md'
|
|
105
|
-
- 'jspsych-visual-search-circle': 'plugins/jspsych-visual-search-circle.md'
|
|
106
|
-
- 'jspsych-vsl-animate-occlusion': 'plugins/jspsych-vsl-animate-occlusion.md'
|
|
107
|
-
- 'jspsych-vsl-grid-scene': 'plugins/jspsych-vsl-grid-scene.md'
|
|
108
|
-
- 'jspsych-webgazer-calibrate': 'plugins/jspsych-webgazer-calibrate.md'
|
|
109
|
-
- 'jspsych-webgazer-init-camera': 'plugins/jspsych-webgazer-init-camera.md'
|
|
110
|
-
- 'jspsych-webgazer-validate': 'plugins/jspsych-webgazer-validate.md'
|
|
111
|
-
- Extensions:
|
|
112
|
-
- 'Extensions': 'extensions/extensions.md'
|
|
113
|
-
- 'jspsych-ext-webgazer.js': 'extensions/jspsych-ext-webgazer.md'
|
|
114
|
-
- About:
|
|
115
|
-
- 'About jsPsych': 'about/about.md'
|
|
116
|
-
- 'Getting Help': 'about/support.md'
|
|
117
|
-
- 'Contributing to jsPsych': 'about/contributing.md'
|
|
118
|
-
- 'License': 'about/license.md'
|
|
@@ -1,189 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* jsPsych plugin for showing animations and recording keyboard responses
|
|
3
|
-
* Josh de Leeuw
|
|
4
|
-
*
|
|
5
|
-
* documentation: docs.jspsych.org
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
jsPsych.plugins.animation = (function() {
|
|
9
|
-
|
|
10
|
-
var plugin = {};
|
|
11
|
-
|
|
12
|
-
jsPsych.pluginAPI.registerPreload('animation', 'stimuli', 'image');
|
|
13
|
-
|
|
14
|
-
plugin.info = {
|
|
15
|
-
name: 'animation',
|
|
16
|
-
description: '',
|
|
17
|
-
parameters: {
|
|
18
|
-
stimuli: {
|
|
19
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
20
|
-
pretty_name: 'Stimuli',
|
|
21
|
-
default: undefined,
|
|
22
|
-
array: true,
|
|
23
|
-
description: 'The images to be displayed.'
|
|
24
|
-
},
|
|
25
|
-
frame_time: {
|
|
26
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
27
|
-
pretty_name: 'Frame time',
|
|
28
|
-
default: 250,
|
|
29
|
-
description: 'Duration to display each image.'
|
|
30
|
-
},
|
|
31
|
-
frame_isi: {
|
|
32
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
33
|
-
pretty_name: 'Frame gap',
|
|
34
|
-
default: 0,
|
|
35
|
-
description: 'Length of gap to be shown between each image.'
|
|
36
|
-
},
|
|
37
|
-
sequence_reps: {
|
|
38
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
39
|
-
pretty_name: 'Sequence repetitions',
|
|
40
|
-
default: 1,
|
|
41
|
-
description: 'Number of times to show entire sequence.'
|
|
42
|
-
},
|
|
43
|
-
choices: {
|
|
44
|
-
type: jsPsych.plugins.parameterType.KEY,
|
|
45
|
-
pretty_name: 'Choices',
|
|
46
|
-
default: jsPsych.ALL_KEYS,
|
|
47
|
-
array: true,
|
|
48
|
-
description: 'Keys subject uses to respond to stimuli.'
|
|
49
|
-
},
|
|
50
|
-
prompt: {
|
|
51
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
52
|
-
pretty_name: 'Prompt',
|
|
53
|
-
default: null,
|
|
54
|
-
description: 'Any content here will be displayed below stimulus.'
|
|
55
|
-
},
|
|
56
|
-
render_on_canvas: {
|
|
57
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
58
|
-
pretty_name: 'Render on canvas',
|
|
59
|
-
default: true,
|
|
60
|
-
description: 'If true, the images will be drawn onto a canvas element (prevents blank screen between consecutive images in some browsers).'+
|
|
61
|
-
'If false, the image will be shown via an img element.'
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
plugin.trial = function(display_element, trial) {
|
|
67
|
-
|
|
68
|
-
var interval_time = trial.frame_time + trial.frame_isi;
|
|
69
|
-
var animate_frame = -1;
|
|
70
|
-
var reps = 0;
|
|
71
|
-
var startTime = performance.now();
|
|
72
|
-
var animation_sequence = [];
|
|
73
|
-
var responses = [];
|
|
74
|
-
var current_stim = "";
|
|
75
|
-
|
|
76
|
-
if (trial.render_on_canvas) {
|
|
77
|
-
// first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
|
|
78
|
-
if (display_element.hasChildNodes()) {
|
|
79
|
-
// can't loop through child list because the list will be modified by .removeChild()
|
|
80
|
-
while (display_element.firstChild) {
|
|
81
|
-
display_element.removeChild(display_element.firstChild);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
var canvas = document.createElement("canvas");
|
|
85
|
-
canvas.id = "jspsych-animation-image";
|
|
86
|
-
canvas.style.margin = 0;
|
|
87
|
-
canvas.style.padding = 0;
|
|
88
|
-
display_element.insertBefore(canvas, null);
|
|
89
|
-
var ctx = canvas.getContext("2d");
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
var animate_interval = setInterval(function() {
|
|
93
|
-
var showImage = true;
|
|
94
|
-
if (!trial.render_on_canvas) {
|
|
95
|
-
display_element.innerHTML = ''; // clear everything
|
|
96
|
-
}
|
|
97
|
-
animate_frame++;
|
|
98
|
-
if (animate_frame == trial.stimuli.length) {
|
|
99
|
-
animate_frame = 0;
|
|
100
|
-
reps++;
|
|
101
|
-
if (reps >= trial.sequence_reps) {
|
|
102
|
-
endTrial();
|
|
103
|
-
clearInterval(animate_interval);
|
|
104
|
-
showImage = false;
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
if (showImage) {
|
|
108
|
-
show_next_frame();
|
|
109
|
-
}
|
|
110
|
-
}, interval_time);
|
|
111
|
-
|
|
112
|
-
function show_next_frame() {
|
|
113
|
-
if (trial.render_on_canvas) {
|
|
114
|
-
display_element.querySelector('#jspsych-animation-image').style.visibility = 'visible';
|
|
115
|
-
var img = new Image();
|
|
116
|
-
img.src = trial.stimuli[animate_frame];
|
|
117
|
-
canvas.height = img.naturalHeight;
|
|
118
|
-
canvas.width = img.naturalWidth;
|
|
119
|
-
ctx.drawImage(img,0,0);
|
|
120
|
-
if (trial.prompt !== null & animate_frame == 0 & reps == 0) {
|
|
121
|
-
display_element.insertAdjacentHTML('beforeend', trial.prompt);
|
|
122
|
-
}
|
|
123
|
-
} else {
|
|
124
|
-
// show image
|
|
125
|
-
display_element.innerHTML = '<img src="'+trial.stimuli[animate_frame]+'" id="jspsych-animation-image"></img>';
|
|
126
|
-
if (trial.prompt !== null) {
|
|
127
|
-
display_element.innerHTML += trial.prompt;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
current_stim = trial.stimuli[animate_frame];
|
|
131
|
-
|
|
132
|
-
// record when image was shown
|
|
133
|
-
animation_sequence.push({
|
|
134
|
-
"stimulus": trial.stimuli[animate_frame],
|
|
135
|
-
"time": performance.now() - startTime
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
if (trial.frame_isi > 0) {
|
|
139
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
140
|
-
display_element.querySelector('#jspsych-animation-image').style.visibility = 'hidden';
|
|
141
|
-
current_stim = 'blank';
|
|
142
|
-
// record when blank image was shown
|
|
143
|
-
animation_sequence.push({
|
|
144
|
-
"stimulus": 'blank',
|
|
145
|
-
"time": performance.now() - startTime
|
|
146
|
-
});
|
|
147
|
-
}, trial.frame_time);
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
var after_response = function(info) {
|
|
152
|
-
|
|
153
|
-
responses.push({
|
|
154
|
-
key_press: info.key,
|
|
155
|
-
rt: info.rt,
|
|
156
|
-
stimulus: current_stim
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
// after a valid response, the stimulus will have the CSS class 'responded'
|
|
160
|
-
// which can be used to provide visual feedback that a response was recorded
|
|
161
|
-
display_element.querySelector('#jspsych-animation-image').className += ' responded';
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
// hold the jspsych response listener object in memory
|
|
165
|
-
// so that we can turn off the response collection when
|
|
166
|
-
// the trial ends
|
|
167
|
-
var response_listener = jsPsych.pluginAPI.getKeyboardResponse({
|
|
168
|
-
callback_function: after_response,
|
|
169
|
-
valid_responses: trial.choices,
|
|
170
|
-
rt_method: 'performance',
|
|
171
|
-
persist: true,
|
|
172
|
-
allow_held_key: false
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
function endTrial() {
|
|
176
|
-
|
|
177
|
-
jsPsych.pluginAPI.cancelKeyboardResponse(response_listener);
|
|
178
|
-
|
|
179
|
-
var trial_data = {
|
|
180
|
-
animation_sequence: animation_sequence,
|
|
181
|
-
response: responses
|
|
182
|
-
};
|
|
183
|
-
|
|
184
|
-
jsPsych.finishTrial(trial_data);
|
|
185
|
-
}
|
|
186
|
-
};
|
|
187
|
-
|
|
188
|
-
return plugin;
|
|
189
|
-
})();
|
|
@@ -1,269 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* jspsych-audio-button-response
|
|
3
|
-
* Kristin Diep
|
|
4
|
-
*
|
|
5
|
-
* plugin for playing an audio file and getting a keyboard response
|
|
6
|
-
*
|
|
7
|
-
* documentation: docs.jspsych.org
|
|
8
|
-
*
|
|
9
|
-
**/
|
|
10
|
-
|
|
11
|
-
jsPsych.plugins["audio-button-response"] = (function () {
|
|
12
|
-
var plugin = {};
|
|
13
|
-
|
|
14
|
-
jsPsych.pluginAPI.registerPreload('audio-button-response', 'stimulus', 'audio');
|
|
15
|
-
|
|
16
|
-
plugin.info = {
|
|
17
|
-
name: 'audio-button-response',
|
|
18
|
-
description: '',
|
|
19
|
-
parameters: {
|
|
20
|
-
stimulus: {
|
|
21
|
-
type: jsPsych.plugins.parameterType.AUDIO,
|
|
22
|
-
pretty_name: 'Stimulus',
|
|
23
|
-
default: undefined,
|
|
24
|
-
description: 'The audio to be played.'
|
|
25
|
-
},
|
|
26
|
-
choices: {
|
|
27
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
28
|
-
pretty_name: 'Choices',
|
|
29
|
-
default: undefined,
|
|
30
|
-
array: true,
|
|
31
|
-
description: 'The button labels.'
|
|
32
|
-
},
|
|
33
|
-
button_html: {
|
|
34
|
-
type: jsPsych.plugins.parameterType.HTML_STRING,
|
|
35
|
-
pretty_name: 'Button HTML',
|
|
36
|
-
default: '<button class="jspsych-btn">%choice%</button>',
|
|
37
|
-
array: true,
|
|
38
|
-
description: 'Custom button. Can make your own style.'
|
|
39
|
-
},
|
|
40
|
-
prompt: {
|
|
41
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
42
|
-
pretty_name: 'Prompt',
|
|
43
|
-
default: null,
|
|
44
|
-
description: 'Any content here will be displayed below the stimulus.'
|
|
45
|
-
},
|
|
46
|
-
trial_duration: {
|
|
47
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
48
|
-
pretty_name: 'Trial duration',
|
|
49
|
-
default: null,
|
|
50
|
-
description: 'The maximum duration to wait for a response.'
|
|
51
|
-
},
|
|
52
|
-
margin_vertical: {
|
|
53
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
54
|
-
pretty_name: 'Margin vertical',
|
|
55
|
-
default: '0px',
|
|
56
|
-
description: 'Vertical margin of button.'
|
|
57
|
-
},
|
|
58
|
-
margin_horizontal: {
|
|
59
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
60
|
-
pretty_name: 'Margin horizontal',
|
|
61
|
-
default: '8px',
|
|
62
|
-
description: 'Horizontal margin of button.'
|
|
63
|
-
},
|
|
64
|
-
response_ends_trial: {
|
|
65
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
66
|
-
pretty_name: 'Response ends trial',
|
|
67
|
-
default: true,
|
|
68
|
-
description: 'If true, the trial will end when user makes a response.'
|
|
69
|
-
},
|
|
70
|
-
trial_ends_after_audio: {
|
|
71
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
72
|
-
pretty_name: 'Trial ends after audio',
|
|
73
|
-
default: false,
|
|
74
|
-
description: 'If true, then the trial will end as soon as the audio file finishes playing.'
|
|
75
|
-
},
|
|
76
|
-
response_allowed_while_playing: {
|
|
77
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
78
|
-
pretty_name: 'Response allowed while playing',
|
|
79
|
-
default: true,
|
|
80
|
-
description: 'If true, then responses are allowed while the audio is playing. ' +
|
|
81
|
-
'If false, then the audio must finish playing before a response is accepted.'
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
plugin.trial = function (display_element, trial) {
|
|
87
|
-
|
|
88
|
-
// setup stimulus
|
|
89
|
-
var context = jsPsych.pluginAPI.audioContext();
|
|
90
|
-
var audio;
|
|
91
|
-
|
|
92
|
-
// store response
|
|
93
|
-
var response = {
|
|
94
|
-
rt: null,
|
|
95
|
-
button: null
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
// record webaudio context start time
|
|
99
|
-
var startTime;
|
|
100
|
-
|
|
101
|
-
// load audio file
|
|
102
|
-
jsPsych.pluginAPI.getAudioBuffer(trial.stimulus)
|
|
103
|
-
.then(function (buffer) {
|
|
104
|
-
if (context !== null) {
|
|
105
|
-
audio = context.createBufferSource();
|
|
106
|
-
audio.buffer = buffer;
|
|
107
|
-
audio.connect(context.destination);
|
|
108
|
-
} else {
|
|
109
|
-
audio = buffer;
|
|
110
|
-
audio.currentTime = 0;
|
|
111
|
-
}
|
|
112
|
-
setupTrial();
|
|
113
|
-
})
|
|
114
|
-
.catch(function (err) {
|
|
115
|
-
console.error(`Failed to load audio file "${trial.stimulus}". Try checking the file path. We recommend using the preload plugin to load audio files.`)
|
|
116
|
-
console.error(err)
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
function setupTrial() {
|
|
120
|
-
// set up end event if trial needs it
|
|
121
|
-
if (trial.trial_ends_after_audio) {
|
|
122
|
-
audio.addEventListener('ended', end_trial);
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
// enable buttons after audio ends if necessary
|
|
126
|
-
if ((!trial.response_allowed_while_playing) & (!trial.trial_ends_after_audio)) {
|
|
127
|
-
audio.addEventListener('ended', enable_buttons);
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
//display buttons
|
|
131
|
-
var buttons = [];
|
|
132
|
-
if (Array.isArray(trial.button_html)) {
|
|
133
|
-
if (trial.button_html.length == trial.choices.length) {
|
|
134
|
-
buttons = trial.button_html;
|
|
135
|
-
} else {
|
|
136
|
-
console.error('Error in audio-button-response plugin. The length of the button_html array does not equal the length of the choices array');
|
|
137
|
-
}
|
|
138
|
-
} else {
|
|
139
|
-
for (var i = 0; i < trial.choices.length; i++) {
|
|
140
|
-
buttons.push(trial.button_html);
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
var html = '<div id="jspsych-audio-button-response-btngroup">';
|
|
145
|
-
for (var i = 0; i < trial.choices.length; i++) {
|
|
146
|
-
var str = buttons[i].replace(/%choice%/g, trial.choices[i]);
|
|
147
|
-
html += '<div class="jspsych-audio-button-response-button" style="cursor: pointer; display: inline-block; margin:' + trial.margin_vertical + ' ' + trial.margin_horizontal + '" id="jspsych-audio-button-response-button-' + i + '" data-choice="' + i + '">' + str + '</div>';
|
|
148
|
-
}
|
|
149
|
-
html += '</div>';
|
|
150
|
-
|
|
151
|
-
//show prompt if there is one
|
|
152
|
-
if (trial.prompt !== null) {
|
|
153
|
-
html += trial.prompt;
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
display_element.innerHTML = html;
|
|
157
|
-
|
|
158
|
-
if (trial.response_allowed_while_playing) {
|
|
159
|
-
enable_buttons();
|
|
160
|
-
} else {
|
|
161
|
-
disable_buttons();
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
// start time
|
|
165
|
-
startTime = performance.now();
|
|
166
|
-
|
|
167
|
-
// start audio
|
|
168
|
-
if (context !== null) {
|
|
169
|
-
startTime = context.currentTime;
|
|
170
|
-
audio.start(startTime);
|
|
171
|
-
} else {
|
|
172
|
-
audio.play();
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
// end trial if time limit is set
|
|
176
|
-
if (trial.trial_duration !== null) {
|
|
177
|
-
jsPsych.pluginAPI.setTimeout(function () {
|
|
178
|
-
end_trial();
|
|
179
|
-
}, trial.trial_duration);
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
// function to handle responses by the subject
|
|
186
|
-
function after_response(choice) {
|
|
187
|
-
|
|
188
|
-
// measure rt
|
|
189
|
-
var endTime = performance.now();
|
|
190
|
-
var rt = endTime - startTime;
|
|
191
|
-
if (context !== null) {
|
|
192
|
-
endTime = context.currentTime;
|
|
193
|
-
rt = Math.round((endTime - startTime) * 1000);
|
|
194
|
-
}
|
|
195
|
-
response.button = parseInt(choice);
|
|
196
|
-
response.rt = rt;
|
|
197
|
-
|
|
198
|
-
// disable all the buttons after a response
|
|
199
|
-
disable_buttons();
|
|
200
|
-
|
|
201
|
-
if (trial.response_ends_trial) {
|
|
202
|
-
end_trial();
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
// function to end trial when it is time
|
|
207
|
-
function end_trial() {
|
|
208
|
-
|
|
209
|
-
// kill any remaining setTimeout handlers
|
|
210
|
-
jsPsych.pluginAPI.clearAllTimeouts();
|
|
211
|
-
|
|
212
|
-
// stop the audio file if it is playing
|
|
213
|
-
// remove end event listeners if they exist
|
|
214
|
-
if (context !== null) {
|
|
215
|
-
audio.stop();
|
|
216
|
-
} else {
|
|
217
|
-
audio.pause();
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
audio.removeEventListener('ended', end_trial);
|
|
221
|
-
audio.removeEventListener('ended', enable_buttons);
|
|
222
|
-
|
|
223
|
-
// gather the data to store for the trial
|
|
224
|
-
var trial_data = {
|
|
225
|
-
rt: response.rt,
|
|
226
|
-
stimulus: trial.stimulus,
|
|
227
|
-
response: response.button
|
|
228
|
-
};
|
|
229
|
-
|
|
230
|
-
// clear the display
|
|
231
|
-
display_element.innerHTML = '';
|
|
232
|
-
|
|
233
|
-
// move on to the next trial
|
|
234
|
-
jsPsych.finishTrial(trial_data);
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
function button_response(e) {
|
|
238
|
-
var choice = e.currentTarget.getAttribute('data-choice'); // don't use dataset for jsdom compatibility
|
|
239
|
-
after_response(choice);
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
function disable_buttons() {
|
|
243
|
-
var btns = document.querySelectorAll('.jspsych-audio-button-response-button');
|
|
244
|
-
for (var i = 0; i < btns.length; i++) {
|
|
245
|
-
var btn_el = btns[i].querySelector('button');
|
|
246
|
-
if (btn_el) {
|
|
247
|
-
btn_el.disabled = true;
|
|
248
|
-
}
|
|
249
|
-
btns[i].removeEventListener('click', button_response);
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
function enable_buttons() {
|
|
254
|
-
var btns = document.querySelectorAll('.jspsych-audio-button-response-button');
|
|
255
|
-
for (var i = 0; i < btns.length; i++) {
|
|
256
|
-
var btn_el = btns[i].querySelector('button');
|
|
257
|
-
if (btn_el) {
|
|
258
|
-
btn_el.disabled = false;
|
|
259
|
-
}
|
|
260
|
-
btns[i].addEventListener('click', button_response);
|
|
261
|
-
}
|
|
262
|
-
}
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
};
|
|
267
|
-
|
|
268
|
-
return plugin;
|
|
269
|
-
})();
|