As part of our ongoing quest to standardise the rendering systems across Discourse’s codebase, we’re replacing the implementation of the topic-list.
Previously, this used a ‘raw handlebars’ (.hbr) approach, and could be customized via template overrides and raw-plugin-outlets. The new implementation of the topic-list uses modern Glimmer components, and has been built from the ground-up to to be customizable in sustainable ways.
The new implementation is now available behind the glimmer_topic_list_mode setting.
- disabled: use the legacy “raw handlebars” topic-list
- auto: will detect the compatibility of your current plugins and themes. If any are incompatible, it will use the legacy system; otherwise it will use the new implementation.
- enabled: will use the new topic-list implementation. If you have any incompatible plugins or themes, your site may be broken.
We’ve already updated most of our official themes and plugins to be compatible with the new menu. But, if you run any third-party plugins, themes, or theme components which customize the topic list, upgrading them will be required.
Warnings will be printed in the browser console identifying the source of the incompatibility.
 Roll-out Timeline
 Roll-out Timeline
These are rough estimates subject to change
Q4 2024:
 core implementation finished core implementation finished
 updating official themes/plugins (in progress) updating official themes/plugins (in progress)
 enabled on Meta enabled on Meta
 published upgrade advice published upgrade advice
Q1 2025:
- 
 updating official themes/plugins updating official themes/plugins
- 
  glimmer_topic_list_modedefault toauto; console deprecation messages enabled
- 
 deprecations will trigger an admin warning banner for any remaining issues deprecations will trigger an admin warning banner for any remaining issues
- 
third-party plugins and themes should be updated 
- 
 1st March - enable the new topic-list for all sites. The default for the site setting will be switched to 1st March - enable the new topic-list for all sites. The default for the site setting will be switched toenabled, but it will still be possible to switch back to ‘disabled’
Q2 2025
 after 1st April - final removal of the legacy mode & associated code after 1st April - final removal of the legacy mode & associated code
 What does it mean for me?
 What does it mean for me?
If your plugin or theme has any ‘raw handlebars’ files (named .hbr or .raw.hbs) then those will need to be updated for compatibility with the new version. Regular .hbs files for Ember components/routes are unaffected by this change.
Upgrades will also be required if you use modifyClass on component:topic-list or component:topic-list-item.
If your site has any of these incompatible customizations, warning messages will be printed to the browser developer console, including information about which theme/plugin is the cause.
What are the replacements?
Some of the old raw-plugin-outlets have been converted to regular Plugin Outlets. Those can be updated in a 1:1 fashion.
More advanced customizations will need to be assessed on a case-by-case basis. The new topic-list has a number of new APIs for easy and robust customization. Find out more here:
Here are some examples:
- 
discourse-assignintroduces a new column to a specific topic-list
- 
discourse-calendaruses one of the new plugin outlets to display the event date badge
- 
discourse-solveduses a new valueTransformer to replace the previous modifyClass
 What about other customizations?
 What about other customizations?
If your customization cannot be achieved using the new APIs we’ve introduced, please let us know by creating a new Dev topic to discuss.
 I am a plugin/theme author. How do I update a theme/plugin to support both old and new topic list during the transition?
 I am a plugin/theme author. How do I update a theme/plugin to support both old and new topic list during the transition?
The new plugin outlets are rendered in both the old and new implementations of the topic list. So: when you’ve implemented the new one, simply delete the old raw-plugin-outlet connector.
For DAG-based customizations which replace template-overrides or non-modernized outlets, you will need to maintain both implementations during the transition period.
Once your theme/plugin supports both old and new implementations, you can add this magic comment at the top of all your .hbr files:
{{!-- has-modern-replacement --}}
This will silence the deprecation messages, and allow the new implementation to be used when in “auto” mode.

 It will not seems to be an easy run…
 It will not seems to be an easy run…  But value transformer probably will make it easier.
 But value transformer probably will make it easier.






