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