New
0.17.0
New:
TerminalandLocalTerminalare now renamed toTerminalStateandLocalTerminalState, respectively, along with some new capabilities:- Add
focusedboolean which defaults to true. If the terminal supports sending focus changes, this will be updated in real time. - Add
themeproperty which defaults to 'unknown'. If the terminal supports querying theme state, this will be 'light' or 'dark' and be updated in real time. Note: this is not the OS theme, but instead reflects the theme of the terminal color scheme. - Size property now features the size in pixels in addition to cells. These values will be 0 if unsupported by the terminal.
- Add
- Bind
TerminalState.focusedto aLifecycleand expose into the composition asLocalLifecycleOwner. This allows using Compose lifecycle helpers such asLifecycleResumeEffectand others. - Fancy underline styles (single, double, dashed, dotted, curved) and colors can now be specified for text and annotated string spans.
LocalStaticLoggercomposition local provides access toStaticLoggerwhich allows logging plain strings at arbitrary points for inclusion in the next frame. This can be used from effects, callback, state classes, etc. Support for loggingAnnotatedStrings will come in a future release.runMosaicMainfunction replaces the existingrunMosaicBlockingfor use specifically infun main()or main-like scenarios.
Changed:
- Switched to our own terminal integration and parsing library. Report any issues with keyboard input, incorrect size reporting, or garbled output. This unlocks many of the features listed above, as well as many more planned in the future.
- Only disable the cursor and emit synchronized rendering markers if the terminal reports support for those features.
Staticfunction is now calledStaticEffectto better indicate that it only renders its content once.runMosaicandrunMosaicBlockingnow accept aNonInteractivePolicyargument which dictates the behavior when Mosaic cannot connect directly to the TTY.
Fixed:
- Prevent final character from being erased when a row writes into the last column of the terminal.
- Do not emit ANSI style reset escape sequence when colors are disabled (such as in testing).
- Do not draw blank spaces at the end of every line.
Removed:
renderMosaicwas removed without replacement. As the capabilities of the library grow, supporting a string as a render target was increasingly difficult.