1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-17 18:44:45 +02:00
joplin/packages/lib/services/PluginManager.js

112 lines
2.2 KiB
JavaScript
Raw Normal View History

const Logger = require('@joplin/utils/Logger').default;
class PluginManager {
constructor() {
2019-07-29 15:43:53 +02:00
this.plugins_ = {};
this.logger_ = new Logger();
}
setLogger(l) {
this.logger_ = l;
}
logger() {
return this.logger_;
}
static instance() {
if (this.instance_) return this.instance_;
this.instance_ = new PluginManager();
return this.instance_;
}
register(classes) {
if (!Array.isArray(classes)) classes = [classes];
for (let i = 0; i < classes.length; i++) {
const PluginClass = classes[i];
2019-07-29 15:43:53 +02:00
2019-09-19 23:51:18 +02:00
if (this.plugins_[PluginClass.manifest.name]) throw new Error(`Already registered: ${PluginClass.manifest.name}`);
this.plugins_[PluginClass.manifest.name] = {
Class: PluginClass,
instance: null,
};
}
}
pluginInstance_(name) {
const p = this.plugins_[name];
if (p.instance) return p.instance;
p.instance = new p.Class();
p.instance.dispatch = action => this.dispatch_(action);
return p.instance;
}
pluginClass_(name) {
return this.plugins_[name].Class;
}
onPluginMenuItemTrigger_(event) {
const p = this.pluginInstance_(event.pluginName);
p.onTrigger({
itemName: event.itemName,
userData: event.userData,
});
}
pluginDialogToShow(pluginStates) {
for (const name in pluginStates) {
const p = pluginStates[name];
if (!p.dialogOpen) continue;
const Class = this.pluginClass_(name);
if (!Class.Dialog) continue;
return {
Dialog: Class.Dialog,
props: { ...this.dialogProps_(name), userData: p.userData },
2019-07-29 15:43:53 +02:00
};
}
return null;
}
dialogProps_(name) {
return {
dispatch: action => this.dispatch_(action),
plugin: this.pluginInstance_(name),
};
}
menuItems() {
let output = [];
for (const name in this.plugins_) {
const menuItems = this.plugins_[name].Class.manifest.menuItems.slice();
if (!menuItems) continue;
for (let i = 0; i < menuItems.length; i++) {
const item = { ...menuItems[i] };
item.click = () => {
this.onPluginMenuItemTrigger_({
pluginName: name,
itemName: item.name,
userData: item.userData,
});
2019-07-29 15:43:53 +02:00
};
if (menuItems[i].accelerator) item.accelerator = menuItems[i].accelerator();
menuItems[i] = item;
}
output = output.concat(menuItems);
}
return output;
}
}
2019-07-29 15:43:53 +02:00
module.exports = PluginManager;