Skip to content

Releases: Textualize/textual

The Streamed Layout

01 Aug 18:50
d4740a1
Compare
Choose a tag to compare

This release adds a new "stream" layout. It's a little experimental at the moment, and undocumented. For the brave only!

[5.2.0] - 2025-08-01

Added

  • Added a 'stream' layout, which is a lot like vertical but with fewer supported rules (which is why it is faster), will remain undocumented for now. #6013

The skinny release

31 Jul 19:10
7c2b65f
Compare
Choose a tag to compare

For some reason I still don't understand, poetry included pycache files in the last PyPi release. After updating Poetry, the build is a more sensible size. There are no code changes in this release.

The empty inside release

31 Jul 09:00
c1c94cc
Compare
Choose a tag to compare

This release adds an :empty pseudo-class which matches widgets with no children. You could use this to hide a container that doesn't have any children, for example:

.container:empty {
    display: none;
}

Also in this release, support for scrolling left and right via the trackpad or a mouse that supports it. This was a contribution from @fancidev

Full changes below:

[5.1.0] - 2025-07-31

Added

  • Added empty pseudo class, which applies when a widget has no displayed children #5999
  • Added Screen.action_focus #5999
  • Added support for left and right mouse scroll for terminals and input devices which support it #5995

Changed

  • last-child, last-of-type, first-child, and first-of-type apply to displayed children only #5999
  • textual.compose is now public #5999

The appended release

25 Jul 19:51
e3bae00
Compare
Choose a tag to compare

A hotfix. See below for details.

[5.0.1] - 2025-07-25

Fixed

  • Fixed appending to Markdown widgets that were constructed with an existing document #5990

The Tabled release.

25 Jul 07:50
9a1cda5
Compare
Choose a tag to compare

This is quite a large release! Fueled in part by my work on Toad

Markdown rendering has been improved, with full text selection, prettier code blocks and tables. Plus streaming support.

Screenshot 2025-07-25 at 08 37 30

Plenty of other fixes and additions. Thats to everyone who contributed code and issues!

There are two breaking changes (see below). These are unlikely to affect anyone, but Semver requires bumping the major version number.

[5.0.0] - 2025-07-25

Added

  • Added get_minimal_width to Visual protocol #5962
  • Added expand and shrink attributes to GridLayout #5962
  • Added Markdown.get_stream #5966
  • Added textual.highlight module for syntax highlighting #5966
  • Added MessagePump.wait_for_refresh method #5966
  • Added Widget.container_scroll_offset e84600c
  • Added Markdown.source attribute to MarkdownBlocks e84600c
  • Added extension mechanism to Markdown e84600c
  • Added index to ListView.Selected event #5973
  • Added layout switch to Static.update #5973

Fixed

  • Fixed TextArea issue with the css theme, where the background color was stuck from the previous theme #5964

Changed

  • Improved rendering of Markdown tables (replace Rich table with grid) which allows text selection #5962
  • Change look of command palette, to drop accented borders #5966
  • Some style tweaks to Markdown e84600c
  • Content markup can now accept component classes when preceded by a dot, e.g. "Hello [.my_custo_style]World[/]!" #5981
  • Breaking change: Visual.render_strips has a new signature. If you aren't explicitly building Visuals then this won't effect you. #5981
  • Breaking change: The component classes on Markdown have been moved to MarkdownBlock. This won't affect you unless you have customize the Markdown CSS #5981
  • The textual-speedups library will now be imported automatically if it is installed. Set TEXTUAL_SPEEDUPS=0 to disable.

The Streaming Release

12 Jul 09:51
e22a213
Compare
Choose a tag to compare

The highlight of this release is the new Markdown.append method which can be used to efficiently stream markdown content (like you might get from an LLM).

Screen.Recording.2025-07-12.at.10.46.30.mov

The Widget.anchor method has changed semantics (and also works much better), which is the reason for the major version bump. This will only impact you if you are actually using that method.

And there are a few fixes and additions. Thanks to the community for these contributions.

[4.0.0] - 2025-07-12

Fixed

  • Fixed query_one and query_exactly_one not raising documented WrongType exception. #5945
  • Fixed logging to a file on Windows #5941
  • Fixed eight bit colors crashing when applying dim style #5957

Changed

  • Breaking change: Widget.anchor now has different semantics. It should be applied to a container and anchors to the bottom of the scroll position. #5950

Added

  • Added Markdown.append #5950
  • Added Widget.release_anchor #5950
  • Added compact parameter to MaskedInput #5952

The Selective Release

09 Jul 09:06
3339d67
Compare
Choose a tag to compare

A hotfix for text selection with soft wrapping in the TextArea widget

[3.7.1] - 2025-07-09

Fixed

  • Fixed broken text selection with soft_wrap=False #5940

The Lucky number Sevens release

07 Jul 20:59
73e9a99
Compare
Choose a tag to compare

A few enhancements, including a handy getters module for creating properties to get widgets.

Also a potentially breaking change, see below for the details...

[3.7.0] - 2025-07-07

Added

  • Added textual.getters #5930
  • Added a show_cursor boolean to TextArea #5934

Changed

  • Potential breaking change: Changed default query_one and query_exactly_one search to breadth first #5930
  • Cursor is now visible by default when in read only mode (restoring pre 3.6.0 behavior) #5934

Fixed

  • Fixed issue with Keylines not scrolling #5936

The belated birthday release

06 Jul 07:59
93709e9
Compare
Choose a tag to compare

Some substantial optimizations and tweaks for the TextArea widget, and the usual fixes.

[3.6.0] - 2025-07-06

Fixed

  • Fixed issue with the "transparent" CSS value not being transparent when set using python #5890
  • Fixed issue with pushing screens when Input has mouse captured #5900
  • Implemented workaround for Ghostty bug which produces negative mouse coordinates #5926

Changed

  • Widget.release_mouse will now only release the mouse, if it was captured by self #5900
  • Some optimizations to TextArea, which may be noticeable during scrolling (note: may break snapshots with a TextArea) #5925
  • Selecting in the TextArea now hides the cursor until you release the mouse #5925
  • Read only TextAreas will no longer display a cursor #5925

Added

  • Added TextArea.highlight_cursor_line toggle #5924

The faster startup release

20 Jun 14:50
1051db1
Compare
Choose a tag to compare

This release contains some optimizations to startup time, which may be significant if you create a lot of widgets. There are also some visual updates to Markdown.

This release will break your snapshots, although I don't expect any visual changes. If you are using the snapshot plugin, you will need to regenerate those snapshots. Even if you give them a quick scan, this should only take a few minutes.

[3.5.0] - 2025-06-20

Changed

  • Optimized startup #5869
  • New blank visual which makes background faster to render (note this will break snapshots tests this version) #5869
  • Exposed code_indent_guides boolean on Markdown widget #5874
  • Changed code fence background to use CSS background rather than its code theme #5874