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.
- package/README.md +43 -29
- 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 -661
- package/docs/core_library/jspsych-data.md +0 -589
- package/docs/core_library/jspsych-pluginAPI.md +0 -510
- package/docs/core_library/jspsych-randomization.md +0 -397
- package/docs/core_library/jspsych-turk.md +0 -102
- package/docs/img/blue.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/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 -140
- package/docs/overview/data.md +0 -281
- package/docs/overview/exclude-browser.md +0 -32
- package/docs/overview/experiment-options.md +0 -121
- package/docs/overview/fullscreen.md +0 -36
- package/docs/overview/media-preloading.md +0 -91
- package/docs/overview/mturk.md +0 -77
- package/docs/overview/progress-bar.md +0 -110
- package/docs/overview/record-browser-interactions.md +0 -23
- package/docs/overview/running-experiments.md +0 -95
- package/docs/overview/timeline.md +0 -387
- package/docs/overview/trial.md +0 -142
- package/docs/plugins/creating-a-plugin.md +0 -79
- 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 -52
- 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 -55
- 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 -46
- package/docs/plugins/jspsych-image-keyboard-response.md +0 -57
- package/docs/plugins/jspsych-image-slider-response.md +0 -52
- package/docs/plugins/jspsych-instructions.md +0 -58
- package/docs/plugins/jspsych-maxdiff.md +0 -42
- 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 -50
- 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 -52
- package/docs/plugins/jspsych-video-keyboard-response.md +0 -48
- package/docs/plugins/jspsych-video-slider-response.md +0 -58
- 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/overview.md +0 -111
- package/docs/tutorials/hello-world.md +0 -144
- package/docs/tutorials/rt-task.md +0 -1107
- package/examples/add-to-end-of-timeline.html +0 -32
- package/examples/conditional-and-loop-functions.html +0 -63
- package/examples/css/jquery-ui.css +0 -1225
- package/examples/data-add-properties.html +0 -40
- package/examples/data-as-function.html +0 -36
- package/examples/data-from-timeline.html +0 -45
- package/examples/data-from-url.html +0 -21
- package/examples/demo-flanker.html +0 -108
- package/examples/demo-simple-rt-task.html +0 -104
- package/examples/demos/demo_1.html +0 -29
- package/examples/demos/demo_2.html +0 -43
- package/examples/demos/demo_3.html +0 -58
- package/examples/display-element-to-embed-experiment.html +0 -73
- package/examples/end-active-node.html +0 -52
- package/examples/end-experiment.html +0 -43
- 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/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/jspsych-RDK.html +0 -58
- package/examples/jspsych-animation.html +0 -33
- package/examples/jspsych-audio-button-response.html +0 -52
- package/examples/jspsych-audio-keyboard-response.html +0 -62
- package/examples/jspsych-audio-slider-response.html +0 -55
- 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 -46
- package/examples/jspsych-categorize-html.html +0 -38
- package/examples/jspsych-categorize-image.html +0 -38
- package/examples/jspsych-cloze.html +0 -42
- package/examples/jspsych-free-sort.html +0 -97
- package/examples/jspsych-fullscreen.html +0 -44
- package/examples/jspsych-html-button-response.html +0 -46
- package/examples/jspsych-html-keyboard-response.html +0 -42
- package/examples/jspsych-html-slider-response.html +0 -53
- package/examples/jspsych-iat.html +0 -510
- package/examples/jspsych-image-button-response.html +0 -84
- package/examples/jspsych-image-keyboard-response.html +0 -78
- package/examples/jspsych-image-slider-response.html +0 -76
- package/examples/jspsych-instructions.html +0 -37
- package/examples/jspsych-maxdiff.html +0 -33
- 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 -33
- 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 -57
- package/examples/jspsych-video-keyboard-response.html +0 -53
- package/examples/jspsych-video-slider-response.html +0 -55
- package/examples/jspsych-visual-search-circle.html +0 -58
- package/examples/jspsych-vsl-animate-occlusion.html +0 -29
- package/examples/jspsych-vsl-grid-scene.html +0 -41
- package/examples/lexical-decision.html +0 -132
- package/examples/manual-preloading.html +0 -53
- package/examples/pause-unpause.html +0 -33
- package/examples/progress-bar.html +0 -62
- 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 -55
- package/examples/video/sample_video.mp4 +0 -0
- package/jspsych.js +0 -2796
- package/license.txt +0 -21
- package/mkdocs.yml +0 -104
- package/plugins/jspsych-animation.js +0 -189
- package/plugins/jspsych-audio-button-response.js +0 -247
- package/plugins/jspsych-audio-keyboard-response.js +0 -204
- package/plugins/jspsych-audio-slider-response.js +0 -262
- 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 -444
- package/plugins/jspsych-fullscreen.js +0 -104
- 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 -311
- package/plugins/jspsych-image-keyboard-response.js +0 -247
- package/plugins/jspsych-image-slider-response.js +0 -353
- package/plugins/jspsych-instructions.js +0 -237
- package/plugins/jspsych-maxdiff.js +0 -174
- 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 -213
- 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 -320
- package/plugins/jspsych-video-keyboard-response.js +0 -279
- package/plugins/jspsych-video-slider-response.js +0 -351
- 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/template/jspsych-plugin-template.js +0 -35
- package/tests/README.md +0 -7
- 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 -369
- 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 -254
- package/tests/jsPsych/timelines.test.js +0 -498
- package/tests/jsPsych.data/datacollection.test.js +0 -116
- 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.pluginAPI/pluginapi.test.js +0 -144
- package/tests/jsPsych.randomization/randomziation.test.js +0 -27
- package/tests/jsPsych.utils/utils.test.js +0 -58
- package/tests/media/blue.png +0 -0
- package/tests/media/orange.png +0 -0
- package/tests/media/sample_video.mp4 +0 -0
- package/tests/media/sound.mp3 +0 -0
- package/tests/plugins/plugin-animation.test.js +0 -35
- 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 -274
- 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 -140
- package/tests/plugins/plugin-free-sort.test.js +0 -112
- 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 -328
- package/tests/plugins/plugin-iat-image.test.js +0 -308
- package/tests/plugins/plugin-image-button-response.test.js +0 -183
- package/tests/plugins/plugin-image-keyboard-response.test.js +0 -154
- package/tests/plugins/plugin-image-slider-response.test.js +0 -183
- package/tests/plugins/plugin-instructions.test.js +0 -66
- package/tests/plugins/plugin-maxdiff.test.js +0 -39
- package/tests/plugins/plugin-rdk.test.js +0 -17
- 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 -69
- 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 -48
- package/tests/plugins/plugin-survey-multi-select.test.js +0 -72
- package/tests/plugins/plugin-survey-text.test.js +0 -115
- package/tests/plugins/plugin-video-button-response.test.js +0 -35
- package/tests/plugins/plugin-video-keyboard-response.test.js +0 -35
- package/tests/plugins/plugin-video-slider-response.test.js +0 -34
- 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,266 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* jspsych plugin for categorization trials with feedback and animated stimuli
|
|
3
|
-
* Josh de Leeuw
|
|
4
|
-
*
|
|
5
|
-
* documentation: docs.jspsych.org
|
|
6
|
-
**/
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
jsPsych.plugins["categorize-animation"] = (function() {
|
|
10
|
-
|
|
11
|
-
var plugin = {};
|
|
12
|
-
|
|
13
|
-
jsPsych.pluginAPI.registerPreload('categorize-animation', 'stimuli', 'image');
|
|
14
|
-
|
|
15
|
-
plugin.info = {
|
|
16
|
-
name: 'categorize-animation',
|
|
17
|
-
description: '',
|
|
18
|
-
parameters: {
|
|
19
|
-
stimuli: {
|
|
20
|
-
type: jsPsych.plugins.parameterType.IMAGE,
|
|
21
|
-
pretty_name: 'Stimuli',
|
|
22
|
-
default: undefined,
|
|
23
|
-
description: 'Array of paths to image files.'
|
|
24
|
-
},
|
|
25
|
-
key_answer: {
|
|
26
|
-
type: jsPsych.plugins.parameterType.KEYCODE,
|
|
27
|
-
pretty_name: 'Key answer',
|
|
28
|
-
default: undefined,
|
|
29
|
-
description: 'The key to indicate correct response'
|
|
30
|
-
},
|
|
31
|
-
choices: {
|
|
32
|
-
type: jsPsych.plugins.parameterType.KEYCODE,
|
|
33
|
-
pretty_name: 'Choices',
|
|
34
|
-
default: jsPsych.ALL_KEYS,
|
|
35
|
-
array: true,
|
|
36
|
-
description: 'The keys subject is allowed to press to respond to stimuli.'
|
|
37
|
-
},
|
|
38
|
-
text_answer: {
|
|
39
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
40
|
-
pretty_name: 'Text answer',
|
|
41
|
-
default: null,
|
|
42
|
-
description: 'Text to describe correct answer.'
|
|
43
|
-
},
|
|
44
|
-
correct_text: {
|
|
45
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
46
|
-
pretty_name: 'Correct text',
|
|
47
|
-
default: 'Correct.',
|
|
48
|
-
description: 'String to show when subject gives correct answer'
|
|
49
|
-
},
|
|
50
|
-
incorrect_text: {
|
|
51
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
52
|
-
pretty_name: 'Incorrect text',
|
|
53
|
-
default: 'Wrong.',
|
|
54
|
-
description: 'String to show when subject gives incorrect answer.'
|
|
55
|
-
},
|
|
56
|
-
frame_time: {
|
|
57
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
58
|
-
pretty_name: 'Frame time',
|
|
59
|
-
default: 500,
|
|
60
|
-
description: 'Duration to display each image.'
|
|
61
|
-
},
|
|
62
|
-
sequence_reps: {
|
|
63
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
64
|
-
pretty_name: 'Sequence repetitions',
|
|
65
|
-
default: 1,
|
|
66
|
-
description: 'How many times to display entire sequence.'
|
|
67
|
-
},
|
|
68
|
-
allow_response_before_complete: {
|
|
69
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
70
|
-
pretty_name: 'Allow response before complete',
|
|
71
|
-
default: false,
|
|
72
|
-
description: 'If true, subject can response before the animation sequence finishes'
|
|
73
|
-
},
|
|
74
|
-
feedback_duration: {
|
|
75
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
76
|
-
pretty_name: 'Feedback duration',
|
|
77
|
-
default: 2000,
|
|
78
|
-
description: 'How long to show feedback'
|
|
79
|
-
},
|
|
80
|
-
prompt: {
|
|
81
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
82
|
-
pretty_name: 'Prompt',
|
|
83
|
-
default: null,
|
|
84
|
-
description: 'Any content here will be displayed below the stimulus.'
|
|
85
|
-
},
|
|
86
|
-
render_on_canvas: {
|
|
87
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
88
|
-
pretty_name: 'Render on canvas',
|
|
89
|
-
default: true,
|
|
90
|
-
description: 'If true, the images will be drawn onto a canvas element (prevents blank screen between consecutive images in some browsers).'+
|
|
91
|
-
'If false, the image will be shown via an img element.'
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
plugin.trial = function(display_element, trial) {
|
|
97
|
-
|
|
98
|
-
var animate_frame = -1;
|
|
99
|
-
var reps = 0;
|
|
100
|
-
|
|
101
|
-
var showAnimation = true;
|
|
102
|
-
|
|
103
|
-
var responded = false;
|
|
104
|
-
var timeoutSet = false;
|
|
105
|
-
var correct;
|
|
106
|
-
|
|
107
|
-
if (trial.render_on_canvas) {
|
|
108
|
-
// first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
|
|
109
|
-
if (display_element.hasChildNodes()) {
|
|
110
|
-
// can't loop through child list because the list will be modified by .removeChild()
|
|
111
|
-
while (display_element.firstChild) {
|
|
112
|
-
display_element.removeChild(display_element.firstChild);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
var canvas = document.createElement("canvas");
|
|
116
|
-
canvas.id = "jspsych-categorize-animation-stimulus";
|
|
117
|
-
canvas.style.margin = 0;
|
|
118
|
-
canvas.style.padding = 0;
|
|
119
|
-
display_element.insertBefore(canvas, null);
|
|
120
|
-
var ctx = canvas.getContext("2d");
|
|
121
|
-
if (trial.prompt !== null) {
|
|
122
|
-
var prompt_div = document.createElement("div");
|
|
123
|
-
prompt_div.id = "jspsych-categorize-animation-prompt";
|
|
124
|
-
prompt_div.style.visibility = "hidden";
|
|
125
|
-
prompt_div.innerHTML = trial.prompt;
|
|
126
|
-
display_element.insertBefore(prompt_div, canvas.nextElementSibling);
|
|
127
|
-
}
|
|
128
|
-
var feedback_div = document.createElement("div");
|
|
129
|
-
display_element.insertBefore(feedback_div, display_element.nextElementSibling);
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
// show animation
|
|
133
|
-
var animate_interval = setInterval(function() {
|
|
134
|
-
if (!trial.render_on_canvas) {
|
|
135
|
-
display_element.innerHTML = ''; // clear everything
|
|
136
|
-
}
|
|
137
|
-
animate_frame++;
|
|
138
|
-
if (animate_frame == trial.stimuli.length) {
|
|
139
|
-
animate_frame = 0;
|
|
140
|
-
reps++;
|
|
141
|
-
// check if reps complete //
|
|
142
|
-
if (trial.sequence_reps != -1 && reps >= trial.sequence_reps) {
|
|
143
|
-
// done with animation
|
|
144
|
-
showAnimation = false;
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
if (showAnimation) {
|
|
149
|
-
if (trial.render_on_canvas) {
|
|
150
|
-
display_element.querySelector('#jspsych-categorize-animation-stimulus').style.visibility = 'visible';
|
|
151
|
-
var img = new Image();
|
|
152
|
-
img.src = trial.stimuli[animate_frame];
|
|
153
|
-
canvas.height = img.naturalHeight;
|
|
154
|
-
canvas.width = img.naturalWidth;
|
|
155
|
-
ctx.drawImage(img,0,0);
|
|
156
|
-
} else {
|
|
157
|
-
display_element.innerHTML += '<img src="'+trial.stimuli[animate_frame]+'" class="jspsych-categorize-animation-stimulus"></img>';
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
if (!responded && trial.allow_response_before_complete) {
|
|
162
|
-
// in here if the user can respond before the animation is done
|
|
163
|
-
if (trial.prompt !== null) {
|
|
164
|
-
if (trial.render_on_canvas) {
|
|
165
|
-
prompt_div.style.visibility = "visible";
|
|
166
|
-
} else {
|
|
167
|
-
display_element.innerHTML += trial.prompt;
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
if (trial.render_on_canvas) {
|
|
171
|
-
if (!showAnimation) {
|
|
172
|
-
canvas.remove();
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
} else if (!responded) {
|
|
176
|
-
// in here if the user has to wait to respond until animation is done.
|
|
177
|
-
// if this is the case, don't show the prompt until the animation is over.
|
|
178
|
-
if (!showAnimation) {
|
|
179
|
-
if (trial.prompt !== null) {
|
|
180
|
-
if (trial.render_on_canvas) {
|
|
181
|
-
prompt_div.style.visibility = "visible";
|
|
182
|
-
} else {
|
|
183
|
-
display_element.innerHTML += trial.prompt;
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
if (trial.render_on_canvas) {
|
|
187
|
-
canvas.remove();
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
} else {
|
|
191
|
-
// user has responded if we get here.
|
|
192
|
-
|
|
193
|
-
// show feedback
|
|
194
|
-
var feedback_text = "";
|
|
195
|
-
if (correct) {
|
|
196
|
-
feedback_text = trial.correct_text.replace("%ANS%", trial.text_answer);
|
|
197
|
-
} else {
|
|
198
|
-
feedback_text = trial.incorrect_text.replace("%ANS%", trial.text_answer);
|
|
199
|
-
}
|
|
200
|
-
if (trial.render_on_canvas) {
|
|
201
|
-
if (trial.prompt !== null) {
|
|
202
|
-
prompt_div.remove();
|
|
203
|
-
}
|
|
204
|
-
feedback_div.innerHTML = feedback_text;
|
|
205
|
-
} else {
|
|
206
|
-
display_element.innerHTML += feedback_text;
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
// set timeout to clear feedback
|
|
210
|
-
if (!timeoutSet) {
|
|
211
|
-
timeoutSet = true;
|
|
212
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
213
|
-
endTrial();
|
|
214
|
-
}, trial.feedback_duration);
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
}, trial.frame_time);
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
var keyboard_listener;
|
|
223
|
-
var trial_data = {};
|
|
224
|
-
|
|
225
|
-
var after_response = function(info) {
|
|
226
|
-
// ignore the response if animation is playing and subject
|
|
227
|
-
// not allowed to respond before it is complete
|
|
228
|
-
if (!trial.allow_response_before_complete && showAnimation) {
|
|
229
|
-
return false;
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
correct = false;
|
|
233
|
-
if (trial.key_answer == info.key) {
|
|
234
|
-
correct = true;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
responded = true;
|
|
238
|
-
|
|
239
|
-
trial_data = {
|
|
240
|
-
"stimulus": JSON.stringify(trial.stimuli),
|
|
241
|
-
"rt": info.rt,
|
|
242
|
-
"correct": correct,
|
|
243
|
-
"key_press": info.key
|
|
244
|
-
};
|
|
245
|
-
|
|
246
|
-
jsPsych.pluginAPI.cancelKeyboardResponse(keyboard_listener);
|
|
247
|
-
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
keyboard_listener = jsPsych.pluginAPI.getKeyboardResponse({
|
|
251
|
-
callback_function: after_response,
|
|
252
|
-
valid_responses: trial.choices,
|
|
253
|
-
rt_method: 'performance',
|
|
254
|
-
persist: true,
|
|
255
|
-
allow_held_key: false
|
|
256
|
-
});
|
|
257
|
-
|
|
258
|
-
function endTrial() {
|
|
259
|
-
clearInterval(animate_interval); // stop animation!
|
|
260
|
-
display_element.innerHTML = ''; // clear everything
|
|
261
|
-
jsPsych.finishTrial(trial_data);
|
|
262
|
-
}
|
|
263
|
-
};
|
|
264
|
-
|
|
265
|
-
return plugin;
|
|
266
|
-
})();
|
|
@@ -1,220 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* jspsych plugin for categorization trials with feedback
|
|
3
|
-
* Josh de Leeuw
|
|
4
|
-
*
|
|
5
|
-
* documentation: docs.jspsych.org
|
|
6
|
-
**/
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
jsPsych.plugins['categorize-html'] = (function() {
|
|
10
|
-
|
|
11
|
-
var plugin = {};
|
|
12
|
-
|
|
13
|
-
plugin.info = {
|
|
14
|
-
name: 'categorize-html',
|
|
15
|
-
description: '',
|
|
16
|
-
parameters: {
|
|
17
|
-
stimulus: {
|
|
18
|
-
type: jsPsych.plugins.parameterType.HTML_STRING,
|
|
19
|
-
pretty_name: 'Stimulus',
|
|
20
|
-
default: undefined,
|
|
21
|
-
description: 'The HTML content to be displayed.'
|
|
22
|
-
},
|
|
23
|
-
key_answer: {
|
|
24
|
-
type: jsPsych.plugins.parameterType.KEYCODE,
|
|
25
|
-
pretty_name: 'Key answer',
|
|
26
|
-
default: undefined,
|
|
27
|
-
description: 'The key to indicate the correct response.'
|
|
28
|
-
},
|
|
29
|
-
choices: {
|
|
30
|
-
type: jsPsych.plugins.parameterType.KEYCODE,
|
|
31
|
-
pretty_name: 'Choices',
|
|
32
|
-
default: jsPsych.ALL_KEYS,
|
|
33
|
-
array: true,
|
|
34
|
-
description: 'The keys the subject is allowed to press to respond to the stimulus.'
|
|
35
|
-
},
|
|
36
|
-
text_answer: {
|
|
37
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
38
|
-
pretty_name: 'Text answer',
|
|
39
|
-
default: null,
|
|
40
|
-
description: 'Label that is associated with the correct answer.'
|
|
41
|
-
},
|
|
42
|
-
correct_text: {
|
|
43
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
44
|
-
pretty_name: 'Correct text',
|
|
45
|
-
default: "<p class='feedback'>Correct</p>",
|
|
46
|
-
description: 'String to show when correct answer is given.'
|
|
47
|
-
},
|
|
48
|
-
incorrect_text: {
|
|
49
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
50
|
-
pretty_name: 'Incorrect text',
|
|
51
|
-
default: "<p class='feedback'>Incorrect</p>",
|
|
52
|
-
description: 'String to show when incorrect answer is given.'
|
|
53
|
-
},
|
|
54
|
-
prompt: {
|
|
55
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
56
|
-
pretty_name: 'Prompt',
|
|
57
|
-
default: null,
|
|
58
|
-
description: 'Any content here will be displayed below the stimulus.'
|
|
59
|
-
},
|
|
60
|
-
force_correct_button_press: {
|
|
61
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
62
|
-
pretty_name: 'Force correct button press',
|
|
63
|
-
default: false,
|
|
64
|
-
description: 'If set to true, then the subject must press the correct response key after feedback in order to advance to next trial.'
|
|
65
|
-
},
|
|
66
|
-
show_stim_with_feedback: {
|
|
67
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
68
|
-
default: true,
|
|
69
|
-
no_function: false,
|
|
70
|
-
description: ''
|
|
71
|
-
},
|
|
72
|
-
show_feedback_on_timeout: {
|
|
73
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
74
|
-
pretty_name: 'Show feedback on timeout',
|
|
75
|
-
default: false,
|
|
76
|
-
description: 'If true, stimulus will be shown during feedback. If false, only the text feedback will be displayed during feedback.'
|
|
77
|
-
},
|
|
78
|
-
timeout_message: {
|
|
79
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
80
|
-
pretty_name: 'Timeout message',
|
|
81
|
-
default: "<p>Please respond faster.</p>",
|
|
82
|
-
description: 'The message displayed on a timeout non-response.'
|
|
83
|
-
},
|
|
84
|
-
stimulus_duration: {
|
|
85
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
86
|
-
pretty_name: 'Stimulus duration',
|
|
87
|
-
default: null,
|
|
88
|
-
description: 'How long to hide stimulus.'
|
|
89
|
-
},
|
|
90
|
-
trial_duration: {
|
|
91
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
92
|
-
pretty_name: 'Trial duration',
|
|
93
|
-
default: null,
|
|
94
|
-
description: 'How long to show trial'
|
|
95
|
-
},
|
|
96
|
-
feedback_duration: {
|
|
97
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
98
|
-
pretty_name: 'Feedback duration',
|
|
99
|
-
default: 2000,
|
|
100
|
-
description: 'How long to show feedback.'
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
plugin.trial = function(display_element, trial) {
|
|
106
|
-
|
|
107
|
-
display_element.innerHTML = '<div id="jspsych-categorize-html-stimulus" class="jspsych-categorize-html-stimulus">'+trial.stimulus+'</div>';
|
|
108
|
-
|
|
109
|
-
// hide image after time if the timing parameter is set
|
|
110
|
-
if (trial.stimulus_duration !== null) {
|
|
111
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
112
|
-
display_element.querySelector('#jspsych-categorize-html-stimulus').style.visibility = 'hidden';
|
|
113
|
-
}, trial.stimulus_duration);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
// if prompt is set, show prompt
|
|
117
|
-
if (trial.prompt !== null) {
|
|
118
|
-
display_element.innerHTML += trial.prompt;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
var trial_data = {};
|
|
122
|
-
|
|
123
|
-
// create response function
|
|
124
|
-
var after_response = function(info) {
|
|
125
|
-
|
|
126
|
-
// kill any remaining setTimeout handlers
|
|
127
|
-
jsPsych.pluginAPI.clearAllTimeouts();
|
|
128
|
-
|
|
129
|
-
// clear keyboard listener
|
|
130
|
-
jsPsych.pluginAPI.cancelAllKeyboardResponses();
|
|
131
|
-
|
|
132
|
-
var correct = false;
|
|
133
|
-
if (trial.key_answer == info.key) {
|
|
134
|
-
correct = true;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
// save data
|
|
138
|
-
trial_data = {
|
|
139
|
-
"rt": info.rt,
|
|
140
|
-
"correct": correct,
|
|
141
|
-
"stimulus": trial.stimulus,
|
|
142
|
-
"key_press": info.key
|
|
143
|
-
};
|
|
144
|
-
|
|
145
|
-
display_element.innerHTML = '';
|
|
146
|
-
|
|
147
|
-
var timeout = info.rt == null;
|
|
148
|
-
doFeedback(correct, timeout);
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
jsPsych.pluginAPI.getKeyboardResponse({
|
|
152
|
-
callback_function: after_response,
|
|
153
|
-
valid_responses: trial.choices,
|
|
154
|
-
rt_method: 'performance',
|
|
155
|
-
persist: false,
|
|
156
|
-
allow_held_key: false
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
if (trial.trial_duration !== null) {
|
|
160
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
161
|
-
after_response({
|
|
162
|
-
key: null,
|
|
163
|
-
rt: null
|
|
164
|
-
});
|
|
165
|
-
}, trial.trial_duration);
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
function doFeedback(correct, timeout) {
|
|
169
|
-
|
|
170
|
-
if (timeout && !trial.show_feedback_on_timeout) {
|
|
171
|
-
display_element.innerHTML += trial.timeout_message;
|
|
172
|
-
} else {
|
|
173
|
-
// show image during feedback if flag is set
|
|
174
|
-
if (trial.show_stim_with_feedback) {
|
|
175
|
-
display_element.innerHTML = '<div id="jspsych-categorize-html-stimulus" class="jspsych-categorize-html-stimulus">'+trial.stimulus+'</div>';
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
// substitute answer in feedback string.
|
|
179
|
-
var atext = "";
|
|
180
|
-
if (correct) {
|
|
181
|
-
atext = trial.correct_text.replace("%ANS%", trial.text_answer);
|
|
182
|
-
} else {
|
|
183
|
-
atext = trial.incorrect_text.replace("%ANS%", trial.text_answer);
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
// show the feedback
|
|
187
|
-
display_element.innerHTML += atext;
|
|
188
|
-
}
|
|
189
|
-
// check if force correct button press is set
|
|
190
|
-
if (trial.force_correct_button_press && correct === false && ((timeout && trial.show_feedback_on_timeout) || !timeout)) {
|
|
191
|
-
|
|
192
|
-
var after_forced_response = function(info) {
|
|
193
|
-
endTrial();
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
jsPsych.pluginAPI.getKeyboardResponse({
|
|
197
|
-
callback_function: after_forced_response,
|
|
198
|
-
valid_responses: [trial.key_answer],
|
|
199
|
-
rt_method: 'performance',
|
|
200
|
-
persist: false,
|
|
201
|
-
allow_held_key: false
|
|
202
|
-
});
|
|
203
|
-
|
|
204
|
-
} else {
|
|
205
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
206
|
-
endTrial();
|
|
207
|
-
}, trial.feedback_duration);
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
function endTrial() {
|
|
213
|
-
display_element.innerHTML = '';
|
|
214
|
-
jsPsych.finishTrial(trial_data);
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
};
|
|
218
|
-
|
|
219
|
-
return plugin;
|
|
220
|
-
})();
|
|
@@ -1,222 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* jspsych plugin for categorization trials with feedback
|
|
3
|
-
* Josh de Leeuw
|
|
4
|
-
*
|
|
5
|
-
* documentation: docs.jspsych.org
|
|
6
|
-
**/
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
jsPsych.plugins['categorize-image'] = (function() {
|
|
10
|
-
|
|
11
|
-
var plugin = {};
|
|
12
|
-
|
|
13
|
-
jsPsych.pluginAPI.registerPreload('categorize-image', 'stimulus', 'image');
|
|
14
|
-
|
|
15
|
-
plugin.info = {
|
|
16
|
-
name: 'categorize-image',
|
|
17
|
-
description: '',
|
|
18
|
-
parameters: {
|
|
19
|
-
stimulus: {
|
|
20
|
-
type: jsPsych.plugins.parameterType.IMAGE,
|
|
21
|
-
pretty_name: 'Stimulus',
|
|
22
|
-
default: undefined,
|
|
23
|
-
description: 'The image content to be displayed.'
|
|
24
|
-
},
|
|
25
|
-
key_answer: {
|
|
26
|
-
type: jsPsych.plugins.parameterType.KEYCODE,
|
|
27
|
-
pretty_name: 'Key answer',
|
|
28
|
-
default: undefined,
|
|
29
|
-
description: 'The key to indicate the correct response.'
|
|
30
|
-
},
|
|
31
|
-
choices: {
|
|
32
|
-
type: jsPsych.plugins.parameterType.KEYCODE,
|
|
33
|
-
pretty_name: 'Choices',
|
|
34
|
-
default: jsPsych.ALL_KEYS,
|
|
35
|
-
array: true,
|
|
36
|
-
description: 'The keys the subject is allowed to press to respond to the stimulus.'
|
|
37
|
-
},
|
|
38
|
-
text_answer: {
|
|
39
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
40
|
-
pretty_name: 'Text answer',
|
|
41
|
-
default: null,
|
|
42
|
-
description: 'Label that is associated with the correct answer.'
|
|
43
|
-
},
|
|
44
|
-
correct_text: {
|
|
45
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
46
|
-
pretty_name: 'Correct text',
|
|
47
|
-
default: "<p class='feedback'>Correct</p>",
|
|
48
|
-
description: 'String to show when correct answer is given.'
|
|
49
|
-
},
|
|
50
|
-
incorrect_text: {
|
|
51
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
52
|
-
pretty_name: 'Incorrect text',
|
|
53
|
-
default: "<p class='feedback'>Incorrect</p>",
|
|
54
|
-
description: 'String to show when incorrect answer is given.'
|
|
55
|
-
},
|
|
56
|
-
prompt: {
|
|
57
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
58
|
-
pretty_name: 'Prompt',
|
|
59
|
-
default: null,
|
|
60
|
-
description: 'Any content here will be displayed below the stimulus.'
|
|
61
|
-
},
|
|
62
|
-
force_correct_button_press: {
|
|
63
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
64
|
-
pretty_name: 'Force correct button press',
|
|
65
|
-
default: false,
|
|
66
|
-
description: 'If set to true, then the subject must press the correct response key after feedback in order to advance to next trial.'
|
|
67
|
-
},
|
|
68
|
-
show_stim_with_feedback: {
|
|
69
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
70
|
-
default: true,
|
|
71
|
-
no_function: false,
|
|
72
|
-
description: ''
|
|
73
|
-
},
|
|
74
|
-
show_feedback_on_timeout: {
|
|
75
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
76
|
-
pretty_name: 'Show feedback on timeout',
|
|
77
|
-
default: false,
|
|
78
|
-
description: 'If true, stimulus will be shown during feedback. If false, only the text feedback will be displayed during feedback.'
|
|
79
|
-
},
|
|
80
|
-
timeout_message: {
|
|
81
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
82
|
-
pretty_name: 'Timeout message',
|
|
83
|
-
default: "<p>Please respond faster.</p>",
|
|
84
|
-
description: 'The message displayed on a timeout non-response.'
|
|
85
|
-
},
|
|
86
|
-
stimulus_duration: {
|
|
87
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
88
|
-
pretty_name: 'Stimulus duration',
|
|
89
|
-
default: null,
|
|
90
|
-
description: 'How long to hide stimulus.'
|
|
91
|
-
},
|
|
92
|
-
trial_duration: {
|
|
93
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
94
|
-
pretty_name: 'Trial duration',
|
|
95
|
-
default: null,
|
|
96
|
-
description: 'How long to show trial'
|
|
97
|
-
},
|
|
98
|
-
feedback_duration: {
|
|
99
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
100
|
-
pretty_name: 'Feedback duration',
|
|
101
|
-
default: 2000,
|
|
102
|
-
description: 'How long to show feedback.'
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
plugin.trial = function(display_element, trial) {
|
|
108
|
-
|
|
109
|
-
display_element.innerHTML = '<img id="jspsych-categorize-image-stimulus" class="jspsych-categorize-image-stimulus" src="'+trial.stimulus+'"></img>';
|
|
110
|
-
|
|
111
|
-
// hide image after time if the timing parameter is set
|
|
112
|
-
if (trial.stimulus_duration !== null) {
|
|
113
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
114
|
-
display_element.querySelector('#jspsych-categorize-image-stimulus').style.visibility = 'hidden';
|
|
115
|
-
}, trial.stimulus_duration);
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
// if prompt is set, show prompt
|
|
119
|
-
if (trial.prompt !== null) {
|
|
120
|
-
display_element.innerHTML += trial.prompt;
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
var trial_data = {};
|
|
124
|
-
|
|
125
|
-
// create response function
|
|
126
|
-
var after_response = function(info) {
|
|
127
|
-
|
|
128
|
-
// kill any remaining setTimeout handlers
|
|
129
|
-
jsPsych.pluginAPI.clearAllTimeouts();
|
|
130
|
-
|
|
131
|
-
// clear keyboard listener
|
|
132
|
-
jsPsych.pluginAPI.cancelAllKeyboardResponses();
|
|
133
|
-
|
|
134
|
-
var correct = false;
|
|
135
|
-
if (trial.key_answer == info.key) {
|
|
136
|
-
correct = true;
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
// save data
|
|
140
|
-
trial_data = {
|
|
141
|
-
"rt": info.rt,
|
|
142
|
-
"correct": correct,
|
|
143
|
-
"stimulus": trial.stimulus,
|
|
144
|
-
"key_press": info.key
|
|
145
|
-
};
|
|
146
|
-
|
|
147
|
-
display_element.innerHTML = '';
|
|
148
|
-
|
|
149
|
-
var timeout = info.rt == null;
|
|
150
|
-
doFeedback(correct, timeout);
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
jsPsych.pluginAPI.getKeyboardResponse({
|
|
154
|
-
callback_function: after_response,
|
|
155
|
-
valid_responses: trial.choices,
|
|
156
|
-
rt_method: 'performance',
|
|
157
|
-
persist: false,
|
|
158
|
-
allow_held_key: false
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
if (trial.trial_duration !== null) {
|
|
162
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
163
|
-
after_response({
|
|
164
|
-
key: null,
|
|
165
|
-
rt: null
|
|
166
|
-
});
|
|
167
|
-
}, trial.trial_duration);
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
function doFeedback(correct, timeout) {
|
|
171
|
-
|
|
172
|
-
if (timeout && !trial.show_feedback_on_timeout) {
|
|
173
|
-
display_element.innerHTML += trial.timeout_message;
|
|
174
|
-
} else {
|
|
175
|
-
// show image during feedback if flag is set
|
|
176
|
-
if (trial.show_stim_with_feedback) {
|
|
177
|
-
display_element.innerHTML = '<img id="jspsych-categorize-image-stimulus" class="jspsych-categorize-image-stimulus" src="'+trial.stimulus+'"></img>';
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
// substitute answer in feedback string.
|
|
181
|
-
var atext = "";
|
|
182
|
-
if (correct) {
|
|
183
|
-
atext = trial.correct_text.replace("%ANS%", trial.text_answer);
|
|
184
|
-
} else {
|
|
185
|
-
atext = trial.incorrect_text.replace("%ANS%", trial.text_answer);
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
// show the feedback
|
|
189
|
-
display_element.innerHTML += atext;
|
|
190
|
-
}
|
|
191
|
-
// check if force correct button press is set
|
|
192
|
-
if (trial.force_correct_button_press && correct === false && ((timeout && trial.show_feedback_on_timeout) || !timeout)) {
|
|
193
|
-
|
|
194
|
-
var after_forced_response = function(info) {
|
|
195
|
-
endTrial();
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
jsPsych.pluginAPI.getKeyboardResponse({
|
|
199
|
-
callback_function: after_forced_response,
|
|
200
|
-
valid_responses: [trial.key_answer],
|
|
201
|
-
rt_method: 'performance',
|
|
202
|
-
persist: false,
|
|
203
|
-
allow_held_key: false
|
|
204
|
-
});
|
|
205
|
-
|
|
206
|
-
} else {
|
|
207
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
208
|
-
endTrial();
|
|
209
|
-
}, trial.feedback_duration);
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
function endTrial() {
|
|
215
|
-
display_element.innerHTML = '';
|
|
216
|
-
jsPsych.finishTrial(trial_data);
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
};
|
|
220
|
-
|
|
221
|
-
return plugin;
|
|
222
|
-
})();
|