Exp-lookit-exit-survey Class
These docs have moved here.Standard exit survey for Lookit studies: confirm participant birthdate, ask user for video sharing permission level & Databrary sharing, option to withdraw, freeform comments, debriefing/thank you text. Leaves fullscreen mode.
"frames": {
    "my-exit-survey": {
        "kind": "exp-lookit-exit-survey",
        "debriefing": {
            "title": "Thank you!",
            "text": "Learning how children react to ducks will help scientists design better rubber ducks.",
            "image": {
                "src": "https://s3.amazonaws.com/lookitcontents/ducks/duck.png",
                "alt": "Very cute duck"
            }
        }
    }
}
Item Index
Methods
Properties
Data collected
Methods
destroySessionRecorder
        ()
    
    exitFullscreen
        ()
    
    makeTimeEvent
        - 
                        eventName
- 
                        [extra]
Create the time event payload for a particular frame / event. This can be overridden to add fields to every event sent by a particular frame
Parameters:
Returns:
Event type, time, and any additional metadata provided
onSessionRecordingStarted
        ()
    
    serializeContent
        - 
                        eventTimings
Each frame that extends ExpFrameBase will send at least an array eventTimings,
a frame type, and any generateProperties back to the server upon completion.
Individual frames may define additional properties that are sent.
Parameters:
- 
                        eventTimingsArray
Returns:
setupRecorder
        - 
                        element
Parameters:
- 
                        elementNodeA DOM node representing where to mount the recorder 
Returns:
A promise representing the result of installing the recorder
showFullscreen
        ()
    
    startSessionRecorder
        ()
        
            
        
    
    Returns:
stopSessionRecorder
        ()
        
            
        
    
    Returns:
whenPossibleToRecordSessionObserver
        ()
    
    Properties
debriefing
    Object
    
    Object specifying information to show on second page of exit survey, before returning to main Lookit site.
Sub-properties:
- 
                    titleStringTitle of debriefing page 
- 
                    textStringParagraph to show as debriefing 
- 
                    imageObjectObject specifying source URL [src] & alt-text [alt] for any image to show during debriefing (optional). Example: { "src": "https://s3.amazonaws.com/lookitcontents/ducks/duck.png", "alt": "Very cute duck" }
displayFullscreenOverride
    String
    
    true to display this frame in fullscreen mode, even if the frame type
is not always displayed fullscreen. (For instance, you might use this to keep
a survey between test trials in fullscreen mode.)
    Default: false
endSessionRecording
    Number
    
    Default: false
fullScreenElementId
    String
        private
    
    generateProperties
    String
    
    Function to generate additional properties for this frame (like {"kind": "exp-lookit-text"}) at the time the frame is initialized. Allows behavior of study to depend on what has happened so far (e.g., answers on a form or to previous test trials). Must be a valid Javascript function, returning an object, provided as a string.
Arguments that will be provided are: expData, sequence, child, pastSessions, conditions.
expData, sequence, and conditions are the same data as would be found in the session data shown
on the Lookit experimenter interface under 'Individual Responses', except that
they will only contain information up to this point in the study.
expData is an object consisting of frameId: frameData pairs; the data associated
with a particular frame depends on the frame kind.
sequence is an ordered list of frameIds, corresponding to the keys in expData.
conditions is an object representing the data stored by any randomizer frames;
keys are frameIds for randomizer frames and data stored depends on the randomizer
used.
child is an object that has the following properties - use child.get(propertyName)
to access:
- additionalInformation: String; additional information field from child form
- ageAtBirth: String; child's gestational age at birth in weeks. Possible values are "24" through "39", "na" (not sure or prefer not to answer), "<24" (under 24 weeks), and "40>" (40 or more weeks).
- birthday: Date object
- gender: "f" (female), "m" (male), "o" (other), or "na" (prefer not to answer)
- givenName: String, child's given name/nickname
- id: String, child UUID
- languageList: String, space-separated list of languages child is exposed to (2-letter codes)
- conditionList: String, space-separated list of conditions/characteristics
- of child from registration form, as used in criteria expression, e.g. "autism_spectrum_disorder deaf multiple_birth"
pastSessions is a list of previous response objects for this child and this study,
ordered starting from most recent (at index 0 is this session!). Each has properties
(access as pastSessions[i].get(propertyName)):
- completed: Boolean, whether they submitted an exit survey
- completedConsentFrame: Boolean, whether they got through at least a consent frame
- conditions: Object representing any conditions assigned by randomizer frames
- createdOn: Date object
- expData: Object consisting of frameId: frameData pairs
- globalEventTimings: list of any events stored outside of individual frames - currently just used for attempts to leave the study early
- sequence: ordered list of frameIds, corresponding to keys in expData
- isPreview: Boolean, whether this is from a preview session (possible in the event this is an experimenter's account)
Example:
function(expData, sequence, child, pastSessions, conditions) {
    return {
       'blocks':
            [
                {
                    'text': 'Name: ' + child.get('givenName')
                },
                {
                    'text': 'Frame number: ' + sequence.length
                },
                {
                    'text': 'N past sessions: ' + pastSessions.length
                }
            ]
      };
  }
(This example is split across lines for readability; when added to JSON it would need to be on one line.)
Default: null
parameters
    Object[]
    
    An object containing values for any parameters (variables) to use in this frame.
Any property VALUES in this frame that match any of the property NAMES in parameters
will be replaced by the corresponding parameter value. For example, suppose your frame
is:
{
   'kind': 'FRAME_KIND',
   'parameters': {
       'FRAME_KIND': 'exp-lookit-text'
   }
}
Then the frame kind will be exp-lookit-text. This may be useful if you need
to repeat values for different frame properties, especially if your frame is actually
a randomizer or group. You may use parameters nested within objects (at any depth) or
within lists.
You can also use selectors to randomly sample from or permute
a list defined in parameters. Suppose STIMLIST is defined in
parameters, e.g. a list of potential stimuli. Rather than just using STIMLIST
as a value in your frames, you can also:
- Select the Nth element (0-indexed) of the value of STIMLIST: (Will cause error ifN >= THELIST.length)
   'parameterName': 'STIMLIST#N'
- Select (uniformly) a random element of the value of STIMLIST:
   'parameterName': 'STIMLIST#RAND'
- Set parameterNameto a random permutation of the value ofSTIMLIST:
   'parameterName': 'STIMLIST#PERM'
- Select the next element in a random permutation of the value of STIMLIST, which is used across all substitutions in this randomizer. This allows you, for instance, to provide a list of possible images in yourparameterSet, and use a different one each frame with the subset/order randomized per participant. If moreSTIMLIST#UNIQparameters than elements ofSTIMLISTare used, we loop back around to the start of the permutation generated for this randomizer.
   'parameterName': 'STIMLIST#UNIQ'
Default: {}
selectNextFrame
    String
    
    Function to select which frame index to go to when using the 'next' action on this frame. Allows flexible looping / short-circuiting based on what has happened so far in the study (e.g., once the child answers N questions correctly, move on to next segment). Must be a valid Javascript function, returning a number from 0 through frames.length - 1, provided as a string.
Arguments that will be provided are:
frames, frameIndex, expData, sequence, child, pastSessions
frames is an ordered list of frame configurations for this study; each element
is an object corresponding directly to a frame you defined in the
JSON document for this study (but with any randomizer frames resolved into the
particular frames that will be used this time).
frameIndex is the index in frames of the current frame
expData is an object consisting of frameId: frameData pairs; the data associated
with a particular frame depends on the frame kind.
sequence is an ordered list of frameIds, corresponding to the keys in expData.
child is an object that has the following properties - use child.get(propertyName)
to access:
- additionalInformation: String; additional information field from child form
- ageAtBirth: String; child's gestational age at birth in weeks. Possible values are "24" through "39", "na" (not sure or prefer not to answer), "<24" (under 24 weeks), and "40>" (40 or more weeks).
- birthday: timestamp in format "Mon Apr 10 2017 20:00:00 GMT-0400 (Eastern Daylight Time)"
- gender: "f" (female), "m" (male), "o" (other), or "na" (prefer not to answer)
- givenName: String, child's given name/nickname
- id: String, child UUID
pastSessions is a list of previous response objects for this child and this study,
ordered starting from most recent (at index 0 is this session!). Each has properties
(access as pastSessions[i].get(propertyName)):
- completed: Boolean, whether they submitted an exit survey
- completedConsentFrame: Boolean, whether they got through at least a consent frame
- conditions: Object representing any conditions assigned by randomizer frames
- createdOn: timestamp in format "Thu Apr 18 2019 12:33:26 GMT-0400 (Eastern Daylight Time)"
- expData: Object consisting of frameId: frameData pairs
- globalEventTimings: list of any events stored outside of individual frames - currently just used for attempts to leave the study early
- sequence: ordered list of frameIds, corresponding to keys in expData
Example that just sends us to the last frame of the study no matter what:
`"function(frames, frameIndex, frameData, expData, sequence, child, pastSessions) {return frames.length - 1;}"``
Default: null
sessionAudioOnly
    Number
    
    Default: 0
sessionMaxUploadSeconds
    Number
    
    Default: 10
startSessionRecording
    Number
    
    Default: false
Data keys collected
These are the fields that will be captured by this frame and sent back to the Lookit server. Each of these fields will correspond to one row of the CSV frame data for a given response - the row will havekey set to the data key name, and value set to the value for this response.
                Equivalently, this data will be available in the exp_data field of the response JSON data.
                    
                    
                    eventTimings
                        
                    
                    
                    
                    
                    
                    
                    
                    
                        
                    
                        Ordered list of events captured during this frame (oldest to newest). Each event is
                    represented as an object with at least the properties
                    {'eventType': EVENTNAME, 'timestamp': TIMESTAMP}.
                    See Events tab for details of events that might be captured.
frameType
                        
                    
                    
                    
                    
                    
                    
                    
                    
                        
                    
                        Type of frame: EXIT (exit survey), CONSENT (consent or assent frame), or DEFAULT (anything else)
Events
enteredFullscreen
                        
                    
                    
                    
                    
                    
                        
                    
                        leftFullscreen
                        
                    
                    
                    
                    
                    
                        
                    
                        nextFrame
                        
                    
                    
                    
                    
                    
                        
                    
                        Move to next frame
previousFrame
                        
                    
                    
                    
                    
                    
                        
                    
                        Move to previous frame
sessionRecorderReady
                        
                    
                    
                    
                    
                    
                        
                    
                        startSessionRecording
                        
                    
                    
                    
                    
                    
                        
                    
                        stoppingCapture
                        
                    
                    
                    
                    
                    
                        
                    
                        stopSessionRecording
                        
                    
                    
                    
                    
                    
                        
                    
                        videoStreamConnection
                        
                    
                    
                    
                    
                    
                        
                    
                        Event Payload:
- 
                                            statusStringstatus of video stream connection, e.g. 'NetConnection.Connect.Success' if successful 
 
                