# Displaying text screens on Trezor T ## Requirements For this feature, you will need a debug-enabled firmware for Trezor T. Usually that will be the emulator. You will also need `trezorctl` 0.12 or later. Best bet is to run the version from github master. ## Trezor T text capabilities The Trezor T screen has a _header_, with an icon and text. Below it is _body_, which can fit up to 5 lines of text. Text can be in one of several colors, and in one of four styles: NORMAL, BOLD, MONO and MONO_BOLD. It is possible to have multiple styles on the same line, but different styles must be separated by a space. I.e., this works fine: > This word is **bold** and this is `monospaced`. This will not work: > Em**bold**ened middle, mono`space`d middle. A line that is too long to fit on screen will automatically break, using a hyphen (`-`) character. This is usually undesirable. Instead, a manual line-break should be inserted in the appropriate place. ## Command line syntax The most basic way to put words on screen is this: ```sh trezorctl debug show-text "My hovercraft is full of eels, call the porter, there is a frog in my bidet." ``` The above command will show: data:image/s3,"s3://crabby-images/d8b68/d8b684beb6f9133f0ac978e5503cb2e769814f30" alt="Screenshot01" Notice the "quotes" around the text. The whole body text must be enquoted. To use quotes inside the text, prefix them with backslashes `\`: ```sh trezorctl debug show-text "My \"hovercraft\" is full of eels." ``` data:image/s3,"s3://crabby-images/b102a/b102a192ae4f086dfb378fc3bd608c3e13f5b7fe" alt="Screenshot02" ### Line breaks Let's insert some line breaks. Do that by placing `@@BR` in the appropriate place in the text: ```sh trezorctl debug show-text "My hovercraft is full of @@BR eels, call the porter, @@BR there is a frog in my @@BR bidet." ``` data:image/s3,"s3://crabby-images/8aed2/8aed2ab5dc3712476326a384c51853cf0fb116a7" alt="Screenshot03" Better! ### Text styles Now let's add some style. Use `@@BOLD` to start printing in bold. Use `@@NORMAL` to go back to normal text. `@@MONO` and `@@MONO_BOLD` works similarly. ```sh trezorctl debug show-text "My hovercraft is @@BOLD full of @@BR eels. @@NORMAL Call the porter, @@BR there is a @@MONO frog @@NORMAL in my @@BR bidet." ``` data:image/s3,"s3://crabby-images/72a80/72a80951de470cdf191bf86a1d0098d35c31fc0c" alt="Screenshot04" ### Line spacing Adding another `@@BR` after a `@@BR` will leave one line empty -- just like pressing \<Enter\> twice. If you don't want a full empty line, you can make a half-break with `@@BR_HALF`. ```sh trezorctl debug show-text "Line one. @@BR @@BR Line two. @@BR @@BR_HALF Line three." ``` data:image/s3,"s3://crabby-images/bd0f3/bd0f36307bcbdf0d865cf7b1226899daaa7fc32d" alt="Screenshot05" ### Text colors To switch to one of the [available colors](../../core/src/trezor/ui/style.py#L14-L47), use the color name prefixed with `%%`: e.g., `%%RED`, `%%LIGHT_BLUE`... To switch back to the default color, you can use `%%FG`: ```sh trezorctl debug show-text "My %%RED hovercraft is @@BOLD full %%GREEN of @@BR eels. @@NORMAL Call %%ORANGE the %%FG porter." ``` data:image/s3,"s3://crabby-images/a381e/a381e524a9b2d1c2efa9312926392e556b459d00" alt="Screenshot06" ### Headers The default header says "Showing text" with an orange gear icon. It is possible to change all of that. To change the text, use `-h` option: ```sh trezorctl debug show-text -h "Hello world" "My hovercraft is full." ``` To change the icon, you can pick [an icon name from here](../../core/src/trezor/ui/style.py#L50-L70) and specify it with the `-i` option: ```sh trezorctl debug show-text -i RECEIVE "My hovercraft is full." ``` The icons are defined as shapes, and you can specify a custom color [from the list](../../core/src/trezor/ui/style.py#L14-L47) with the `-c` option: ```sh trezorctl debug show-text -c RED "My hovercraft is full." ``` ### Putting it all together Here is how to reproduce the confirmation screen after the wallet is created: ```sh trezorctl debug show-text -h "Success" -i CONFIRM -c GREEN "@@BOLD New wallet created @@BR successfully! @@BR @@BR_HALF @@NORMAL You should back up your @@BR new wallet right now." ``` data:image/s3,"s3://crabby-images/5cc3e/5cc3e08bcd70e2331d16b85f4af61f41e86f65e1" alt="Screenshot07"