DEV: New Plugin API method for delegating an app event

This commit is contained in:
Robin Ward 2021-08-05 13:34:11 -04:00
parent 2ec0a17bef
commit 844c05b70b
1 changed files with 24 additions and 2 deletions

View File

@ -81,7 +81,7 @@ import { addSearchResultsCallback } from "discourse/lib/search";
import { addSearchSuggestion } from "discourse/widgets/search-menu-results";
// If you add any methods to the API ensure you bump up this number
const PLUGIN_API_VERSION = "0.12.0";
const PLUGIN_API_VERSION = "0.12.1";
class PluginApi {
constructor(version, container) {
@ -1316,13 +1316,35 @@ class PluginApi {
* Add a suggestion shortcut to search menu panel.
*
* ```
* addSearchSuggestion("in:assigned");
* api.addSearchSuggestion("in:assigned");
* ```
*
*/
addSearchSuggestion(value) {
addSearchSuggestion(value);
}
/**
* Calls a method on a mounted widget whenever an app event happens.
*
* For example, if you have a widget with a `key` of `cool-widget` that lives inside the
* `site-header` component, and you wanted it to respond to `thing:happened`, you could do this:
*
* ```
* api.dispatchWidgetAppEvent('site-header', 'cool-widget', 'thing:happened');
* ```
*
* In this case, the `cool-widget` must have a method called `thingHappened`. The event name
* is converted to camelCase and used as the method name for you.
*/
dispatchWidgetAppEvent(mountedComponent, widgetKey, appEvent) {
this.modifyClass(`component:${mountedComponent}`, {
didInsertElement() {
this._super();
this.dispatch(appEvent, widgetKey);
},
});
}
}
// from http://stackoverflow.com/questions/6832596/how-to-compare-software-version-number-using-js-only-number