October 30, 2018 at 6:24 pm #1597
The most simple way of having a continue button anywhere in your trial is to create a Button element using
newButtonand then use the commands
newButton("continue", "Click here to continue") .print() .wait()
However if you use many continue buttons this can rapidly become a hassle. And if you use more than one such continue button within one trial, you either have to give each of them different names, or create one Button element atop of your trial’s script and refer back to it each time using
getButton. Finally, you may prefer continue to appear as some text link rather than as a button.
Here is a method that will save you some time (explanations below):
var continueLinks = 0; var clickContinue = text => [ continueLinks++ , newText("continue_text_"+continueLinks, text||"Click here to continue") .settings.color("blue") .print() , newSelector("continue_selector_"+continueLinks) .settings.add( getText("continue_text_"+continueLinks) ) .wait() , getText("continue_text_"+continueLinks) .remove( ) ]; PennController( newText("hello", "Hello") .print() , clickContinue() , newText("world", "World") .print() , clickContinue("Click to finish") );
PennController( newText("hello", "Hello") .print() , [ newText("continue_text_0", "Click here to continue") .settings.color("blue") .print() , newSelector("continue_selector_0") .settings.add( getText("continue_text_0") ) .wait() , getText("continue_text_0") .remove() ] , newText("world", "World") .print() , [ newText("continue_text_1", "Click to finish") .settings.color("blue") .print() , newSelector("continue_selector_1") .settings.add( getText("continue_text_1") ) .wait() , getText("continue_text_1") .remove() ] );
Which is equivalent to the exact same script without the
]‘s.July 22, 2019 at 12:39 pm #4043
First of all, thank you and Florian so much for providing this amazing and user-friendly library!
I have a question with respect to the buttons. I want two buttons to be on the same page simultaneously. And I want the participants to be able to click either of them. For me, only the second one is clickable. And If I add .wait() to the entry of the first button, the second button does not appear unless I click on the first button. I will be grateful if you let me know what the issue is! Here is my code:
newText(“question”, “<p>Is the above item a word?</p>“)
newButton(“Word”, “<h1>Word ✓</h1>”)
newButton(“Not a Word”, “<h1>Not a Word x</h1>”)
];July 22, 2019 at 1:57 pm #4044
Since commands are executed in order, inserting a .wait command at the end of the first block of commands will pause the execution of the script until your first button is clicked, and only after that will the commands coming next, relating to your second button, be executed, which is why the second button wouldn’t appear until you click the first one.
With the script you posted, however, you have a .wait command relating to the second button, so the execution of the script is paused until the second button is clicked.
What you want is tell the script to pause until one of the two buttons is clicked. Put otherwise, you want people to make a selection out of a group of two buttons. Whenever you want to do that, you should consider using a Selector which you can use to group elements together and wait for your participants to make a choice. So your script should look like this:
newText("question", "Is the above item a word?") .print() , newButton("Word", "
Word ✓") .settings.color("green") .settings.size(150, 70) .print() , newButton("Not a Word", "
Not a Word x") .settings.color("red") .settings.size(150, 70) .print() , newSelector("WordOrNotaWord") .settings.log() .settings.add( getButton("Word") , getButton("Not a Word") ) .wait()
I removed the commands .settings.log from the buttons themselves, and used it on the Selector element instead since you are interested in which one is selected.
Let me know if you have any questions
July 22, 2019 at 7:34 pm #4046
- This reply was modified 7 months ago by Jeremy.
Thank you so much, Jeremy! My script is fixed now. I really appreciate it!
You must be logged in to reply to this topic.