diff --git a/src/app/components/local-plugin.js b/src/app/components/local-plugin.js index a848f1826c..0bcc98922e 100644 --- a/src/app/components/local-plugin.js +++ b/src/app/components/local-plugin.js @@ -3,27 +3,25 @@ const modalDialog = require('../ui/modaldialog') module.exports = class LocalPlugin { - constructor() {} - /** * Open a modal to create a local plugin * @param {{profile: any, api: any}[]} plugins The list of the plugins in the store * @returns {Promise<{api: any, profile: any}>} A promise with the new plugin profile */ - open(plugins) { + open (plugins) { this.profile = JSON.parse(localStorage.getItem('plugins/local')) || { notifications: {} } - return new Promise((res, rej) => { + return new Promise((resolve, reject) => { modalDialog('Local Plugin', this.form(plugins), - { fn:() => res(this.create()) }, - { fn: () => rej() } + { fn: () => resolve(this.create()) }, + { fn: () => resolve() } ) - }) + }) } /** * Create the object to add to the plugin-list */ - create() { + create () { const profile = { ...this.profile, icon: '', @@ -42,7 +40,7 @@ module.exports = class LocalPlugin { * @param {string} pluginName The name of the plugin * @param {string} eventName The name of the event to listen on */ - toggleNotification(e, pluginName, eventName) { + toggleNotification (e, pluginName, eventName) { const {checked} = e.target if (checked) { if (!this.profile.notifications[pluginName]) this.profile.notifications[pluginName] = [] @@ -53,15 +51,15 @@ module.exports = class LocalPlugin { } } - updateName({target}) { + updateName ({target}) { this.profile.name = target.value } - updateUrl({target}) { + updateUrl ({target}) { this.profile.url = target.value } - updateDisplayName({target}) { + updateDisplayName ({target}) { this.profile.displayName = target.value } @@ -70,7 +68,7 @@ module.exports = class LocalPlugin { * @param {string} plugin The name of the plugin * @param {string} event The name of the event exposed by the plugin */ - notificationCheckbox(plugin, event) { + notificationCheckbox (plugin, event) { const notifications = this.profile.notifications || {} const checkbox = notifications[plugin] && notifications[plugin].includes(event) ? yo`` @@ -85,7 +83,7 @@ module.exports = class LocalPlugin { * The form to create a local plugin * @param {Profile[]} plugins Liste of profile of the plugins */ - form(plugins = []) { + form (plugins = []) { const name = this.profile.name || '' const url = this.profile.url || '' const displayName = this.profile.displayName || '' @@ -114,4 +112,4 @@ module.exports = class LocalPlugin { ` } -} \ No newline at end of file +} diff --git a/src/app/components/plugin-manager-component.js b/src/app/components/plugin-manager-component.js index e267437717..3c29dbabeb 100644 --- a/src/app/components/plugin-manager-component.js +++ b/src/app/components/plugin-manager-component.js @@ -103,8 +103,9 @@ class PluginManagerComponent { /** * Add a local plugin to the list of plugins */ - async openLocalPlugin() { + async openLocalPlugin () { const profile = await this.localPlugin.open(this.store.getAll()) + if (!profile) return const resolveLocaton = (iframe) => this.appManager.resolveLocation(profile, iframe) const api = new Plugin(profile, { resolveLocaton }) this.appManager.init([{profile, api}])