Skip to content

Flow

A flow is an overlay that is displayed before the user attempts an exercise level. This flow should typically contain an overview description of the level with some images, quizzes, and/or interactive canvas.

Tags

Levels

Flows need to be separated for different levels, so that each level has it's own flow. To write a flow specific to a level the [level?] tag is used - where ? is the level number starting at 1.

Example

1
2
3
4
5
6
[level1]
This is shown during the flow for Level 1.
[/level1]
[level2]
This is shown during the flow for Level 2.
[/level2]
The above text will depending on which level the user is at render as the following in the flow:

This is shown during the flow for Level 1.

This is shown during the flow for Level 2.

Warning

The [level?] tags cannot share a row with anything else, not even other [level?] tags or their own content.

Continue and Coding Buttons

There are two predefined buttons that can be included for the user to press to continue inside the flow or exit it.

The [continue] button is a self closing tag that does not take any content. It defined the end of a segment within the flow so that everything below it is hidden until the user presses the button.

The [coding] button is used as a final button in the flow for the user to exit the flow and go back to the coding editor. It takes a body which is the button's text.

Coding tag for a button with the text "Start coding"

1
[coding]Start coding[/coding]

Warning

It is not possible to have any continue/coding buttons inside language tags (ex. [english][/english]).

Warning

[continue] and [coding] tags cannot share a row with anything else.

Quiz

A quiz is a question/answer section that the user can interact with and get either right or wrong.

Name Description
quiz The main wrapping tag
question The question that is prompted to the user
hint A hint to the user that can help it if needed
explanation A more detailed explanation of the question's context
option-correct The correct answer to the quiz
option An incorrect answer to the quiz
feedback-correct The text that is shown to the user if it answers correctly
feedback-incorrect The text that is shown to the user if it answers incorrectly

Tags

Warning

All tags are required, but if for example [hint] or [explanation] are left empty they will not render in the flow.

Quiz
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
[quiz]
  [question]What is the main operation performed by Bubble Sort?[/question]
  [hint]Consider what happens after a comparison shows two elements not in order[/hint]
  [explanation]Swap is the action of switching the position of two elements which are not sorted.[/explanation]

  [option-correct]Swapping[/option-correct]
  [option]Merging[/option]
  [option]Insertion[/option]
  [option]Splitting[/option]

  [feedback-correct]Good job![/feedback-correct]
  [feedback-incorrect]Almost there[/feedback-incorrect]
[/quiz]

A [continue] or [coding] tag is often needed after the quiz.

Interact

You can add a canvas from one of the levels in a flow. This can be done using the [interact-?] tag - where ? is the level number starting at 1.

Interact tag
1
[interact-1]

Warning

A [continue] tag is needed before and after the interact tag.

Other tags

Several other tags which work in the Description are also supported in the flow, such as:

  • Language tags, e.g. [swedish] and [english]

  • Programming language tags, e.g. [python] and [c|cpp]

  • Switches with default, for example:

Switch with default

1
2
3
4
5
[switch]
  [python]"is" or "==" depending on what you are comparing[/python]
  [javascript|typescript]===[/javascript|typescript]
  [default]==[/default]
[/switch]
Depending on which language the user is using it will be rendered as:

"is" or "==" depending on what you are comparing

===

===

==

  • Translation tables, e.g.
Translation table, hello

1
2
3
4
5
6
[translate]
  [from]hello[/from]
  [python]HELLO!!!![/python]
  [c|cpp]_h_e_l_l_o_[/c|cpp]
  [default]h e l l o . . .[/default]
[/translate]
If we have the translation table above and write *hello in our flow, it will be rendered as something different depending on which language you are using.

HELLO!!!!

_h_e_l_l_o_

_h_e_l_l_o_

h e l l o . . .

Translation table, programming language

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
[translate]
  [from]language[/from]
  [c]C[/c]
  [c_sharp]C#[/c_sharp]
  [cpp]C++[/cpp]
  [go]Go[/go]
  [java]Java[/java]
  [kotlin]Kotlin[/kotlin]
  [javascript]JavaScript[/javascript]
  [typescript]TypeScript[/typescript]
  [php]PHP[/php]
  [python]Python[/python]
  [ruby]Ruby[/ruby]
  [rust]Rust[/rust]
  [scala]Scala[/scala]
  [default]the programming language at hand[/default]
[/translate]
If you have the translation table below and type *language in the flow it will show as the language the user is using:

C

C#

C++

Go

Java

Kotlin

JavaScript

TypeScript

PHP

Python

Ruby

Rust

Scala

the programming language at hand