use html input instead of comma separated

pull/1/head
yann300 6 years ago
parent 3ec823f006
commit d42c6fe21a
  1. 29
      src/app/components/local-plugin.js
  2. 1
      src/app/components/plugin-manager-component.js

@ -37,10 +37,10 @@ module.exports = class LocalPlugin {
...this.profile,
icon: '',
methods: [],
events: [],
hash: `local-${this.profile.name}`,
location: 'swapPanel'
}
profile.events = profile.events.filter((item) => { return item !== '' })
if (!profile.name) throw new Error('Plugin should have a name')
if (!profile.url) throw new Error('Plugin should have an URL')
localStorage.setItem('plugins/local', JSON.stringify(profile))
@ -76,9 +76,9 @@ module.exports = class LocalPlugin {
this.profile.displayName = target.value
}
updateEvents ({target}) {
if (target.value && target.value.indexOf(',') !== -1) {
this.profile.events = target.value.split(',')
updateEvents ({target}, index) {
if (this.profile.events[index] !== undefined) {
this.profile.events[index] = target.value
}
}
@ -106,12 +106,25 @@ module.exports = class LocalPlugin {
const name = this.profile.name || ''
const url = this.profile.url || ''
const displayName = this.profile.displayName || ''
const events = (this.profile.events || []).join(',')
const profiles = plugins
.filter(({profile}) => profile.events && profile.events.length > 0)
.map(({profile}) => profile)
const eventsForm = (events) => {
return yo`<div>${events.map((event, i) => {
return yo`<input class="form-control" onchange="${e => this.updateEvents(e, i)}" value="${event}" />`
})}</div>`
}
const eventsEl = eventsForm(this.profile.events || [])
const pushEvent = () => {
if (!this.profile.events) this.profile.events = []
this.profile.events.push('')
yo.update(eventsEl, eventsForm(this.profile.events))
}
const addEvent = yo`<button type="button" class="btn btn-sm btn-light" onclick="${() => pushEvent()}">Add an event</button>`
return yo`
<form id="local-plugin-form" onsubmit="${e => this.validate(e)}">
<form id="local-plugin-form">
<div class="form-group">
<label for="plugin-name">Plugin Name <small>(required)</small></label>
<input class="form-control" onchange="${e => this.updateName(e)}" value="${name}" id="plugin-name" placeholder="Should be camelCase">
@ -125,8 +138,8 @@ module.exports = class LocalPlugin {
<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>Events <small>(comma separated)</small></label>
<input class="form-control" onchange="${e => this.updateEvents(e)}" value="${events}" id="plugin-events" placeholder="ex: compilationFinished,configurationChanged">
<label>Events</label>
${eventsEl}${addEvent}
</div>
<div class="form-group">
<label>Notifications</label>

@ -18,7 +18,6 @@ const css = csjs`
}
.localPluginBtn {
margin-top: 15px;
margin-bottom: -25px;
}
.displayName {
text-transform: capitalize;

Loading…
Cancel
Save