Discourse hamburger tags

This is a theme component that will allow you to add tags to the hamburger menu easily.

The component comes with three display options.

Samples:

Nested tag groups

Nested allowed category tags

Flat top tags (across the site)

Settings:

The component comes with seven settings.

The hamburger_menu_tags_mode allows you to set the view mode you prefer.

top tags:
shows a flat list of the top tags used on the site

tag groups:
shows a nested list of tag groups and their child tags

allowed category tags:
shows a list of allowed tags nested under each category. I recommend keeping those to sane values.

From there, there are mode-specific settings that allow you to control how many sections/tags to show for the different modes.

There’s also a setting that lets you hide the default hamburger categories section (default off)

Notes:
The theme will respect the styles for categories/tags set in your site settings.

If you select nested allowed category tags, the links for these tags will take to topics in that category that are tagged with that tag.

All the sections add a full-width link to the /tags page before the subsections.

allowed_category_tags and top_tags have no API overhead - so no additional requests. Nested_tag_groups does require one request to a .json file. The request only fires once per user per session (on the homepage or whatever page they land on)

No preview on theme creator because it doesn’t have that many tags.

12 Likes

Is it possible to turn this into a “dynamic” #plugin? @Justin_Vega might be interested in such a thing. :slight_smile:

2 Likes

The top tags option is based on the top tags used on the site. They’re based on the overall quantity and that’s about it, there’s no time-frame involved.

Can this component - or any other component - take a .json payload and render it in a widget? Yes.

Can it generate the .json? No. That would need a plugin.

3 Likes

Yes, that’s why I suggested a #plugin that could rely on a number of different metrics.

1 Like