commit
0d660ac523
|
@ -153,7 +153,7 @@ export default class {
|
||||||
mainPath
|
mainPath
|
||||||
}
|
}
|
||||||
|
|
||||||
const content = await this.loadContent(paths, configs, readConfig.info, readConfig.main);
|
const content = await this.loadContent(paths, configs, readConfig.info, readConfig.main, readConfig.type);
|
||||||
if (reload) this.localContent[index] = content;
|
if (reload) this.localContent[index] = content;
|
||||||
else this.localContent.push(content);
|
else this.localContent.push(content);
|
||||||
return content;
|
return content;
|
||||||
|
|
|
@ -20,6 +20,7 @@ export default class {
|
||||||
this.stop = this.stop.bind(this);
|
this.stop = this.stop.bind(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get type() { return 'plugin' }
|
||||||
get configs() { return this.__pluginInternals.configs }
|
get configs() { return this.__pluginInternals.configs }
|
||||||
get info() { return this.__pluginInternals.info }
|
get info() { return this.__pluginInternals.info }
|
||||||
get icon() { return this.info.icon }
|
get icon() { return this.info.icon }
|
||||||
|
|
|
@ -99,4 +99,10 @@ export default class PluginApi {
|
||||||
return plugin.exports;
|
return plugin.exports;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
import(m) {
|
||||||
|
const module = PluginManager.findPlugin(m);
|
||||||
|
if (module && module.__require) return module.__require;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,32 @@ import Vendor from './vendor';
|
||||||
import { ClientLogger as Logger } from 'common';
|
import { ClientLogger as Logger } from 'common';
|
||||||
import { Events } from 'modules';
|
import { Events } from 'modules';
|
||||||
|
|
||||||
|
class Module {
|
||||||
|
|
||||||
|
constructor(pluginInternals) {
|
||||||
|
this.__pluginInternals = pluginInternals;
|
||||||
|
this.__require = window.require(this.paths.mainPath);
|
||||||
|
this.hasSettings = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
get type() { return 'module' }
|
||||||
|
get configs() { return this.__pluginInternals.configs }
|
||||||
|
get info() { return this.__pluginInternals.info }
|
||||||
|
get icon() { return this.info.icon }
|
||||||
|
get paths() { return this.__pluginInternals.paths }
|
||||||
|
get main() { return this.__pluginInternals.main }
|
||||||
|
get defaultConfig() { return this.configs.defaultConfig }
|
||||||
|
get userConfig() { return this.configs.userConfig }
|
||||||
|
get id() { return this.info.id || this.info.name.replace(/[^a-zA-Z0-9-]/g, '-').replace(/--/g, '-') }
|
||||||
|
get name() { return this.info.name }
|
||||||
|
get authors() { return this.info.authors }
|
||||||
|
get version() { return this.info.version }
|
||||||
|
get pluginPath() { return this.paths.contentPath }
|
||||||
|
get dirName() { return this.paths.dirName }
|
||||||
|
get enabled() { return true }
|
||||||
|
get pluginConfig() { return this.userConfig.config || [] }
|
||||||
|
}
|
||||||
|
|
||||||
export default class extends ContentManager {
|
export default class extends ContentManager {
|
||||||
|
|
||||||
static get localPlugins() {
|
static get localPlugins() {
|
||||||
|
@ -33,15 +59,24 @@ export default class extends ContentManager {
|
||||||
return 'plugins';
|
return 'plugins';
|
||||||
}
|
}
|
||||||
|
|
||||||
static get loadAllPlugins() { return this.loadAllContent }
|
static async loadAllPlugins() {
|
||||||
|
const loadAll = await this.loadAllContent();
|
||||||
|
this.localPlugins.forEach(plugin => {
|
||||||
|
if (plugin.type === 'module') return;
|
||||||
|
if (plugin.enabled) plugin.start();
|
||||||
|
});
|
||||||
|
|
||||||
|
return loadAll;
|
||||||
|
}
|
||||||
static get refreshPlugins() { return this.refreshContent }
|
static get refreshPlugins() { return this.refreshContent }
|
||||||
|
|
||||||
static get loadContent() { return this.loadPlugin }
|
static get loadContent() { return this.loadPlugin }
|
||||||
static async loadPlugin(paths, configs, info, main) {
|
static async loadPlugin(paths, configs, info, main, type) {
|
||||||
const plugin = window.require(paths.mainPath)(Plugin, new PluginApi(info), Vendor);
|
|
||||||
const instance = new plugin({ configs, info, main, paths: { contentPath: paths.contentPath, dirName: paths.dirName } });
|
|
||||||
|
|
||||||
if (instance.enabled) instance.start();
|
if (type === 'module') return new Module({ configs, info, main, paths: { contentPath: paths.contentPath, dirName: paths.dirName, mainPath: paths.mainPath } });
|
||||||
|
|
||||||
|
const plugin = window.require(paths.mainPath)(Plugin, new PluginApi(info), Vendor);
|
||||||
|
const instance = new plugin({ configs, info, main, paths: { contentPath: paths.contentPath, dirName: paths.dirName, mainPath: paths.mainPath } });
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<Card :item="plugin">
|
<Card :item="plugin">
|
||||||
<SettingSwitch slot="toggle" :checked="plugin.enabled" :change="() => plugin.enabled ? plugin.stop() : plugin.start()" />
|
<SettingSwitch v-if="plugin.type === 'plugin'" slot="toggle" :checked="plugin.enabled" :change="() => plugin.enabled ? plugin.stop() : plugin.start()" />
|
||||||
<ButtonGroup slot="controls">
|
<ButtonGroup slot="controls">
|
||||||
<Button v-tooltip="'Settings'" v-if="plugin.hasSettings" :onClick="() => showSettings(plugin)">
|
<Button v-tooltip="'Settings'" v-if="plugin.hasSettings" :onClick="() => showSettings(plugin)">
|
||||||
<MiSettings size="18" />
|
<MiSettings size="18" />
|
||||||
|
|
|
@ -6,5 +6,6 @@
|
||||||
"description": "Example Plugin 2 Description"
|
"description": "Example Plugin 2 Description"
|
||||||
},
|
},
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
|
"type": "plugin",
|
||||||
"defaultConfig": []
|
"defaultConfig": []
|
||||||
}
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
{
|
||||||
|
"info": {
|
||||||
|
"name": "Example Module",
|
||||||
|
"authors": [ "Jiiks" ],
|
||||||
|
"version": 1.0,
|
||||||
|
"description": "Module Example"
|
||||||
|
},
|
||||||
|
"main": "index.js",
|
||||||
|
"type": "module"
|
||||||
|
}
|
|
@ -0,0 +1,14 @@
|
||||||
|
module.exports = class {
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
}
|
||||||
|
|
||||||
|
get foo() {
|
||||||
|
return 'Bar';
|
||||||
|
}
|
||||||
|
|
||||||
|
add(i1, i2) {
|
||||||
|
return i1 + i2;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -8,6 +8,7 @@
|
||||||
"icon": ""
|
"icon": ""
|
||||||
},
|
},
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
|
"type": "plugin",
|
||||||
"defaultConfig": [
|
"defaultConfig": [
|
||||||
{
|
{
|
||||||
"category_default_comment": "default category has no header and is always displayed first",
|
"category_default_comment": "default category has no header and is always displayed first",
|
||||||
|
|
|
@ -8,6 +8,9 @@ module.exports = (Plugin, Api, Vendor) => {
|
||||||
Events.subscribe('TEST_EVENT', this.eventTest);
|
Events.subscribe('TEST_EVENT', this.eventTest);
|
||||||
Logger.log('onStart');
|
Logger.log('onStart');
|
||||||
Logger.log(`Setting "default-0" value: ${this.getSetting('default-0')}`);
|
Logger.log(`Setting "default-0" value: ${this.getSetting('default-0')}`);
|
||||||
|
|
||||||
|
const exampleModule = new (Api.import('Example Module'));
|
||||||
|
Logger.log(`2+4=${exampleModule.add(2, 4)}`);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue