Create file local-plugin

pull/1/head
Grandschtroumpf 6 years ago committed by yann300
parent f67ec0d0cf
commit 040876c03c
  1. 117
      src/app/components/local-plugin.js

@ -0,0 +1,117 @@
const yo = require('yo-yo')
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) {
this.profile = JSON.parse(localStorage.getItem('plugins/local')) || { notifications: {} }
return new Promise((res, rej) => {
modalDialog('Local Plugin', this.form(plugins),
{ fn:() => res(this.create()) },
{ fn: () => rej() }
)
})
}
/**
* Create the object to add to the plugin-list
*/
create() {
const profile = {
...this.profile,
icon: '',
methods: [],
events: []
}
if (!this.profile.name) throw new Error('Plugin should have a name')
if (!this.profile.url) throw new Error('Plugin should have an URL')
localStorage.setItem('plugins/local', JSON.stringify(profile))
return this.profile
}
/**
* Add or remove a notification to/from the profile
* @param {Event} e The event when checkbox changes
* @param {string} pluginName The name of the plugin
* @param {string} eventName The name of the event to listen on
*/
toggleNotification(e, pluginName, eventName) {
const {checked} = e.target
if (checked) {
if (!this.profile.notifications[pluginName]) this.profile.notifications[pluginName] = []
this.profile.notifications[pluginName].push(eventName)
} else {
this.profile.notifications[pluginName].splice(this.profile.notifications[pluginName].indexOf(eventName), 1)
if (this.profile.notifications[pluginName].length === 0) delete this.profile.notifications[pluginName]
}
}
updateName({target}) {
this.profile.name = target.value
}
updateUrl({target}) {
this.profile.url = target.value
}
updateDisplayName({target}) {
this.profile.displayName = target.value
}
/**
* The checkbox for a couple module / event
* @param {string} plugin The name of the plugin
* @param {string} event The name of the event exposed by the plugin
*/
notificationCheckbox(plugin, event) {
const notifications = this.profile.notifications || {}
const checkbox = notifications[plugin] && notifications[plugin].includes(event)
? yo`<input type="checkbox" checked onchange="${e => this.toggleNotification(e, plugin, event)}">`
: yo`<input type="checkbox" onchange="${e => this.toggleNotification(e, plugin, event)}">`
return yo`<div>
${checkbox}
<label>${plugin} - ${event}</label>
</div>`
}
/**
* The form to create a local plugin
* @param {Profile[]} plugins Liste of profile of the plugins
*/
form(plugins = []) {
const name = this.profile.name || ''
const url = this.profile.url || ''
const displayName = this.profile.displayName || ''
const profiles = plugins
.filter(({profile}) => profile.events && profile.events.length > 0)
.map(({profile}) => profile)
return yo`
<form id="local-plugin-form" onsubmit="${e => this.validate(e)}">
<div class="form-group">
<label for="plugin-name">Plugin Name</label>
<input class="form-control" onchange="${e => this.updateName(e)}" value="${name}" id="plugin-name" placeholder="Should be camelCase">
</div>
<div class="form-group">
<label for="plugin-displayname">Display Name</label>
<input class="form-control" onchange="${e => this.updateDisplayName(e)}" value="${displayName}" id="plugin-displayname" placeholder="Name in the header">
</div>
<div class="form-group">
<label for="plugin-url">Url</label>
<input class="form-control" onchange="${e => this.updateUrl(e)}" value="${url}" id="plugin-url" placeholder="ex: https://localhost:8000">
</div>
<div class="form-group">
<label>Notifications</label>
${profiles.map(({name, events}) => {
return events.map(event => this.notificationCheckbox(name, event))
})}
</div>
</form>`
}
}
Loading…
Cancel
Save