Custom Top Navigation Links

:discourse2: Summary Custom Top Navigation Links allows you to add links to Discourse top navigation.
:eyeglasses: Preview Preview on Discourse Theme Creator
:hammer_and_wrench: Repository Link https://github.com/discourse/Discourse-nav-links-component
:open_book: New to Discourse Themes? Beginner’s guide to using Discourse Themes

Install this theme component

Features

Desktop

Mobile

Settings:

Name Descriptions
Nav links Semicolon delimited in this order: display name;description;URL
Hide dropdowns Hide category and tag dropdowns
Hide default links Hide the default links on both mobile and desktop.
  • Nav links — these need 3 parts:

    • Name
    • Description
    • Path or URL

    Name is the text for the link that shows up on the menu. Description shows up when you hover the name like this:

    Path/URL is where you want the link to go.

    You can add links as semicolon delimited values in theme settings following this order

    name;description;URL

    URL can also be relative like

    /c/staff, /t/232, /groups/plugin_authors, /about, /tags/official

  • Hide dropdowns

    Hides the default category and tag dropdowns

    Screenshot 2023-05-11 at 3.10.55 PM

  • Hide default links

    Hides the default links in this section

    Screenshot 2023-05-11 at 3.11.29 PM


:discourse2: Hosted by us? Theme components are available to use on our Standard, Business, and Enterprise plans.

Last edited by @JammyDodger 2024-06-11T23:40:05Z

Check documentPerform check on document:
64 лайка
Categories in "top menu"?
Add /groups to top nav
How to make some categories like Bugs and Features here visible in top menu?
What about adding tags in the top menu?
How to add breadcrumb?
Adding link to blog on main page
Create a Tag filter like 'Make & Model' on community.cartalk.com
What is the proper way to extend categories route and filter topics?
Simple Unread List
Displaying all non-solved topics
Link to find all deleted posts by all users in a particular period
A playful approach to category moderation
How can I add a menu item
Reply reminder - Remind users to reply to new users topics with zero replies
How to add a topic in top nav in a specific category?
Following tags and top feed for followed tags
Show latest list sorted by creation date
Following tags and top feed for followed tags
Change Topic List home router - from Latest to Following
Missing category and tags breadcrumbs
A "Votes" option for the top menu in main page
Adding a chat link in the top navigation links?
Add a specific class for wikis (when first post) at the topic list level
How to add an icon in a navigation link?
Customizing your site with existing theme components
Show Latest topics, not by comment on home page
Custom Button For Discourse
Add Follow feed to top navigation
Improvements i want for my discourse for making it less overwhelming/noisy for newcomers
Sidebar link / top button to PM admin
Adding 'Upcoming Events' to top navigation
Strange repetition in menu items
Disclaimer section on the "about" page
Alternative component (plugin?) to categories navbar
Alternative component (plugin?) to categories navbar
FKB Pro - Social theme
2023: The Year in Review
Is it possible to have the Board view as the only view?
How to add Button in Section
Brave default Theme
Air Theme
Provide a way to access tracked/watched topics (outside search)
Discourse Solved
The first Custom Top Nav link inappropriately appears selected
Add another tab to menu bar
How can I remove the Category and tag filter?
How to Disable ALL User-to-User DMs/Chat without breaking Other Features?
Can we add "Groups" to top menu?
Ability to create Custom Navigation Filters in top menu
Add category in Top Menu?
Disable personal message between members
How can I add a link to the top menu area?
Why we can't add groups to top menu
How to add links on home page menu to other site?
Traditional multi level hierarchy vs flat discourse hierarchy
Ordering topics - how do the links work?
Knowledge Base
Automatically fill category with topics? "Best of" category?
How to add new button in different color
Adding "Category" as a topic list option within categories
Docs: Add link to top menu
New Theme: Tag-Pages Navigation
Custom nav bar options
Where can I see posts created by me?
Showing categories statically above most recent posts
Custom nav items no longer showing after recent update
Add /groups to top nav
Add topics-sorted-by-create-time to `top menu`
Categories Customization
Volunteer Activities - a simple setup for non-hierarchical collaboration
How to make the recommanded topics collection

Привет

Я использую этот компонент темы. Один из пунктов меню ведёт к категории, и я хотел бы отображать количество непрочитанных тем для этой категории.

Вместо «Agora» я хотел бы видеть «Agora (3)» для пользователя, у которого три непрочитанные темы в этой категории (такое же поведение, как у стандартной ссылки «Непрочитанные»).

Есть какие-то идеи?

Заранее спасибо.

Подскажите, пожалуйста, как добавить ссылку на тег, которая будет относительной текущему маршруту? Я хочу использовать тег О нас и разместить его как верхнюю ссылку, ведущую на тему О нас, относительную категории, в которой находится пользователь.

Например: пользователь находится в категории /c/feedback/7. При выборе О нас он должен перейти по адресу /tags/c/feedback/7/about.

2 лайка

Я хотел бы использовать компонент на экземпляре, но различные функции не работают:

  • При использовании параметра «Скрыть ссылки по умолчанию» скрываются первые два дочерних элемента («Последние» и «Категории»). Однако при переходе в категорию стандартная ссылка «Категории» уже не отображается в меню. В этом случае настройка скрывает дополнительный элемент навигации — тот, который в ином случае был бы третьим по порядку.

Screenshot from 2022-05-10 18-29-05

  • Я добавил элемент меню для прямой ссылки на категорию (/c/game-talk). При переходе по ней ему не присваивается активный класс, и он не подсвечивается. Вместо этого подсвечивается ссылка «Последние», и ей присвоен активный класс. Причём это не стандартная ссылка «Последние», а та, которую я добавил через компонент (ссылающаяся только на /latest).

Screenshot from 2022-05-10 18-25-39

  • На самом деле, ссылка «Последние» также не получает активный класс, если она названа не «Последние». Таким образом, активный класс на текущем маршруте, по-видимому, вообще не работает из-за компонента. Вот как это выглядит на странице /latest, но с другим названием для ссылки «Последние»:

Screenshot from 2022-05-10 18-39-15

2 лайка

Вопрос на скорую руку —
Пытаюсь создать это и сделать URL ?order=created, чтобы пользователи могли просматривать недавние темы.

На компьютере всё работает отлично, но на мобильном не получается — навигационная панель просто перезагружается и не показывает выпадающее меню.

У меня тот же вопрос… Это решение? :face_with_monocle:

Думаю, я понял, почему это произошло…
в компоненте есть строка ниже:

if (window.location.pathname.match(sec2)) {
          $(navHeader).html(filter + markd);
        }

Из-за регулярного выражения… символ ? сам по себе используется как специальный знак в регулярных выражениях, а параметр должен сравниваться с window.location.search.
Я форкнул компонент, изменил его на следующий код, и теперь всё работает.

if (sec[2].indexOf("?") === -1) {
        if (window.location.pathname.match(sec[2])) {
          $(navHeader).html(filter + markd);
        }
      } else {
        // регулярное выражение ? -> /?
        sec[2] = sec[2].replace(/\?/g, "/?");
        const pathWithSearch = window.location.pathname + window.location.search;
        if (pathWithSearch.match(sec[2])) {
          $(navHeader).html(filter + markd);
        }
      }
1 лайк

Ого, отлично сделано :clap:

Где вы разместили этот фрагмент кода?

Discourse-nav-links-component/mobile/head_tag.html, замените соответствующий код. :face_with_peeking_eye:

1 лайк

Почему бы не оформить это в виде PR, чтобы все могли этим воспользоваться?

4 лайка

Могу ли я это сделать? Я всегда думаю, что мой уровень программирования слишком низкий… и чувствую немного неловко. Спасибо за совет!!! Я исправлю это и сделаю PR!

1 лайк

Я тоже так думаю о своих попытках внести вклад!!

Однако команда @team (и их автоматизированные инструменты) кажется довольно хорошо справляется с приведением кода в порядок.

Как только вы создадите PR, вы можете опубликовать ссылку на него здесь в Meta, и он отобразит потрясающее встроенное живое обновление статуса PR.

5 лайков

Вам когда-нибудь удавалось решить эту проблему? У меня возникла похожая ситуация.

Я не могу сказать, что нашел идеальное решение, но понял, в чём была проблема для меня.

Проблема находится здесь:
https://github.com/discourse/Discourse-nav-links-component/blob/main/desktop/head_tag.html

А именно в этой части:

    api.modifyClass("component:navigation-item", {
      pluginId: 'discourse-nav-links-component',
      active: Ember.computed("contentFilterMode", "filterMode", function() {
        let contentFilterMode = this.get("content").get("filterMode");

        if (window.location.pathname === location) {
          return contentFilterMode === filter;
        } else {
          return this._super(contentFilterMode, this.get("filterMode"));
        }
      })
    });

Похоже, что этот код устанавливает свойство “active” для каждой ссылки навигации. Честно говоря, логика того, как он принимает решения и что означают все эти переменные, для меня довольно запутанна. Но проблема здесь:

        if (window.location.pathname === location) {
          return contentFilterMode === filter;
        } else {
          return this._super(contentFilterMode, this.get("filterMode"));
        }

На мой взгляд, здесь проверяется, совпадает ли URL страницы с location (адресом) ссылки в навигационной панели, и если да, то возвращается результат выражения contentFilterMode === filter, при этом обе переменные для меня немного неясны. Если условие не выполняется, похоже, что просто запускается обычная логика определения того, должно ли что-то быть помечено как активное (поэтому мои нестандартные ссылки, кажется, работают нормально). Проблема в том, что, хотя этот код корректно выполняется один раз для каждой ссылки навигации, переменная location всегда, кажется, равна “categories”, поэтому условие if всегда ложно для пользовательских ссылок. Кроме того, даже если я исправлю переменную “location”, заменив её на this.get("content").href, возвращаемое значение также всегда будет ложным, потому что переменная filter также всегда установлена в значение “categories”.

Обычно я бы просто создал PR с исправлением, но истинная корневая проблема всё ещё ускользает от меня. Я придумал обходное решение, которое работает для меня, но немного меняет задокументированную функциональность этого компонента, поэтому я бы не хотел отправлять его в виде PR. Мне кажется, что будут пограничные случаи, когда оно не сработает, например, если ваша домашняя страница установлена как /latest.

    api.modifyClass("component:navigation-item", {
      pluginId: 'discourse-nav-links-component',
      active: Ember.computed("contentFilterMode", "filterMode", function() {
        return window.location.pathname.includes(this.get("content").href);
      })
    });

По сути, здесь просто проверяется, содержит ли текущий URL адрес ссылки в навигационной панели как подстроку. Если да, то она подсвечивается.

4 лайка

4 сообщения были перенесены в новую тему: Фильтр относительных тегов в навигационной панели

Здравствуйте. Я редактирую этот пост. Подскажите, пожалуйста, есть ли способ отмечать непрочитанные темы? Спасибо.

Здравствуйте,
Как настроить открытие ссылки в новой вкладке?
Спасибо!

Это потенциально очень полезный компонент, но, похоже, несколько базовых (но, к сожалению, не поддающихся исправлению с моей стороны) ошибок препятствуют его более широкому использованию. Будет ли исправлена какая-либо из них?

Можете ли вы уточнить, какие именно ошибки мешают вам использовать компонент?

Да, извините, основная проблема, с которой я столкнулся, — это следующая:

Полагаю, это просто требует более точной настройки CSS, но я могу ошибаться!

1 лайк