mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 20:22:45 +08:00
FEATURE: add an "init" method for extra nav items
This allows us to trigger special initialization code prior to adding an extra nav item to the navigation menu.
This commit is contained in:
parent
72bc0f82b9
commit
f66e5d38d3
|
@ -46,7 +46,7 @@ import { queryRegistry } from "discourse/widgets/widget";
|
|||
import Composer from "discourse/models/composer";
|
||||
|
||||
// If you add any methods to the API ensure you bump up this number
|
||||
const PLUGIN_API_VERSION = "0.8.35";
|
||||
const PLUGIN_API_VERSION = "0.8.36";
|
||||
|
||||
class PluginApi {
|
||||
constructor(version, container) {
|
||||
|
@ -716,7 +716,7 @@ class PluginApi {
|
|||
|
||||
/**
|
||||
*
|
||||
* Adds a new item in the navigation bar.
|
||||
* Adds a new item in the navigation bar. Returns the NavItem object created.
|
||||
*
|
||||
* Example:
|
||||
*
|
||||
|
@ -729,12 +729,16 @@ class PluginApi {
|
|||
* An optional `customFilter` callback can be included to not display the
|
||||
* nav item on certain routes
|
||||
*
|
||||
* An optional `init` callback can be included to run custom code on menu
|
||||
* init
|
||||
*
|
||||
* Example:
|
||||
*
|
||||
* addNavigationBarItem({
|
||||
* name: "link-to-bugs-category",
|
||||
* displayName: "bugs"
|
||||
* href: "/c/bugs",
|
||||
* init: (navItem, category) => { if (category) { navItem.set("category", category) } }
|
||||
* customFilter: (category, args, router) => { category && category.name !== 'bug' }
|
||||
* customHref: (category, args, router) => { if (category && category.name) === 'not-a-bug') "/a-feature"; },
|
||||
* before: "top",
|
||||
|
@ -773,7 +777,15 @@ class PluginApi {
|
|||
};
|
||||
}
|
||||
|
||||
addNavItem(item);
|
||||
const init = item.init;
|
||||
if (init) {
|
||||
const router = this.container.lookup("service:router");
|
||||
item.init = function(navItem, category, args) {
|
||||
init(navItem, category, args, router);
|
||||
};
|
||||
}
|
||||
|
||||
return addNavItem(item);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -118,6 +118,8 @@ const ExtraNavItem = NavItem.extend({
|
|||
}
|
||||
}),
|
||||
|
||||
count: 0,
|
||||
|
||||
customFilter: null
|
||||
});
|
||||
|
||||
|
@ -196,6 +198,10 @@ NavItem.reopenClass({
|
|||
let forceActive = false;
|
||||
|
||||
extraItems.forEach(item => {
|
||||
if (item.init) {
|
||||
item.init.call(this, item, category, args);
|
||||
}
|
||||
|
||||
const before = item.before;
|
||||
if (before) {
|
||||
let i = 0;
|
||||
|
@ -243,5 +249,7 @@ export function customNavItemHref(cb) {
|
|||
}
|
||||
|
||||
export function addNavItem(item) {
|
||||
NavItem.extraNavItems.push(ExtraNavItem.create(item));
|
||||
const navItem = ExtraNavItem.create(item);
|
||||
NavItem.extraNavItems.push(navItem);
|
||||
return navItem;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user