This macro set helps you work with SugarCube's Dialog API without having to touch any JavaScript.
THE CODE: Minified. Pretty.
DEMO: Available.
GUIDE: Not available.
Syntax: <<dialog [title] [classList]>> <</dialog>>
The <<dialog>>
macro creates a new dialog box, with an optional title and an optional list of classes for styling. The content between the macro tags is parsed and appended to the dialog box's body. You will generally want to pair this with some type of interaction, like a link or button. You can use the child tags <<onopen>>
and <<onclose>>
to run TwineScript code when the dialog is opened and closed (see below).
Arguments:
- title: (optional) A title to appear at the top of the dialog box. If you want to omit a title but include classes, this argument can be an empty string (
''
). - classList: (optional) A list of CSS classes to add to the dialog, for styling. The classes should be a space-separated list of quoted class names (i.e.
'class-a' 'class-b' 'class-c'
), a quoted list of space-separated class names (i.e.'class-a class-b class-c'
), or one or more string arrays (i.e.['class-a', 'class-b', 'class-c']
), or any combination of thereof.
Usage:
/% creates a link that opens a dialog box called 'Character Sheet' with the classes .char-sheet and .stats %/
<<link 'View Character Sheet'>>
<<dialog 'Character Sheet' 'char-sheet stats'>>\
|Strength|$str|
|Dexterity|$dex|
|Wisdom|$wis|\
<</dialog>>
<</link>>
/% create an about button for your credits %/
<<button 'About'>>
<<dialog 'Credits'>>\
This game was made by John P. Nottingham in Twine!\
<</dialog>>
<</button>>
/% a dialog with no title or classes %/
<<link 'Hello!'>>
<<dialog>>Greetings!<</dialog>>
<</link>>
You can use this child tag to run code when the dialog is opened.
Usage:
<<link 'View Character Sheet'>>
<<dialog 'Character Sheet' 'char-sheet stats'>>\
|Strength|$str|
|Dexterity|$dex|
|Wisdom|$wis|\
<<onopen>>
<<audio 'click' volume 1 play>>
<</dialog>>
<</link>>
You can use this child tag to run code when the dialog is closed.
Usage:
<<link 'View Character Sheet'>>
<<dialog 'Character Sheet' 'char-sheet stats'>>\
|Strength|$str|
|Dexterity|$dex|
|Wisdom|$wis|\
<<onopen>>
<<audio 'click' volume 1 play>>
<<onclose>>
<<audio 'close' volume 1 play>>
<</dialog>>
<</link>>
Syntax: <<popup passageName [title] [classList]>>
The <<popup>>
macro provides a similar result to what you might get by pairing a <<dialog>>
macro and an <<include>>
macro. The macro is generally the same as <<dialog>>
, but the first argument must be the name of a passage, and instead of rendering content from between tags, that passage's content will be rendered into the dialog box. This macr does not support the <<onopen>>
and <<onclose>>
feature; if you need it, use the <<dialog>>
macro with <<include>>
.
Arguments:
- passageName: The name of one of your passages. The indicated passage's content will be rendered into the dialog box's body.
- title: (optional) A title to appear at the top of the dialog box. If you want to omit a title but include classes, this argument can be an empty string (
''
). - classList: (optional) A list of CSS classes to add to the dialog, for styling. The classes should be a space-separated list of quoted class names (i.e.
'class-a' 'class-b' 'class-c'
), a quoted list of space-separated class names (i.e.'class-a class-b class-c'
), or one or more string arrays (i.e.['class-a', 'class-b', 'class-c']
), or any combination of thereof.
Usage:
/%
creates a link that opens a dialog box called 'Character Sheet'
with the classes .char-sheet and .stats
and renders the content of the passage 'charsheet' into it
%/
<<link 'View Character Sheet'>>
<<popup 'charsheet' 'Characer Sheet' 'char-sheet stats'>>
<</link>>
/% create an about button for your credits that uses the content of the 'credits-passage' passage %/
<<button 'About'>>
<<popup 'credits-passage' 'Credits'>>
<</button>>
Syntax: <<dialogclose>>
Closes the dialog.
Usage:
<<link 'View Character Sheet'>>
<<dialog 'Character Sheet' 'char-sheet stats'>>\
|Strength|$str|
|Dexterity|$dex|
|Wisdom|$wis|\
@@float:right;
<<button "Close">><<dialogclose>><</button>>
@@
<</dialog>>
<</link>>