Support for remote conf
This commit is contained in:
parent
2a6ac58c6d
commit
e11e3127f0
3 changed files with 60 additions and 18 deletions
|
@ -4,11 +4,11 @@
|
||||||
|
|
||||||
<div class="body">
|
<div class="body">
|
||||||
<NewHost @add="addHost" v-if="selectedTab === 'add'" />
|
<NewHost @add="addHost" v-if="selectedTab === 'add'" />
|
||||||
<Config v-else-if="selectedTab === 'config'" />
|
<Config v-else-if="selectedTab === 'config'" @reload="reload" />
|
||||||
<LocalCommands v-else-if="selectedTab === 'host' && selectedHostOption === 'localProc'" />
|
<LocalCommands v-else-if="selectedHost && selectedHostOption === 'localProc'" />
|
||||||
<RemoteCommands v-else-if="selectedTab === 'host' && selectedHostOption === 'remoteProc'" />
|
<RemoteCommands v-else-if="selectedHost && selectedHostOption === 'remoteProc'" />
|
||||||
<Run :host="hosts[selectedHost]" v-else-if="selectedTab === 'host' && selectedHostOption === 'run'" />
|
<Run :host="hosts[selectedHost]" v-else-if="selectedHost && selectedHostOption === 'run'" />
|
||||||
<EditHost :host="hosts[selectedHost]" @save="editHost" @remove="removeHost" v-else-if="selectedTab === 'host'" />
|
<EditHost :host="hosts[selectedHost]" @save="editHost" @remove="removeHost" v-else-if="selectedHost" />
|
||||||
<div class="none" v-else>Select an option from the menu</div>
|
<div class="none" v-else>Select an option from the menu</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -53,6 +53,10 @@ export default {
|
||||||
this.selectedHostOption = hostOption;
|
this.selectedHostOption = hostOption;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
async reload() {
|
||||||
|
this.hosts = await this.getHosts();
|
||||||
|
},
|
||||||
|
|
||||||
async addHost(form) {
|
async addHost(form) {
|
||||||
if (!this.isHostFormValid(form)) {
|
if (!this.isHostFormValid(form)) {
|
||||||
this.notify('Invalid device parameter values', 'Device configuration error');
|
this.notify('Invalid device parameter values', 'Device configuration error');
|
||||||
|
@ -71,8 +75,8 @@ export default {
|
||||||
|
|
||||||
this.hosts[host.name] = host;
|
this.hosts[host.name] = host;
|
||||||
await this.saveHosts(this.hosts);
|
await this.saveHosts(this.hosts);
|
||||||
this.selectedHost = Object.keys(this.hosts)[Object.keys(this.hosts).length - 1];
|
await this.reload();
|
||||||
this.isAddHost = false;
|
this.select('host', Object.keys(this.hosts)[Object.keys(this.hosts).length - 1]);
|
||||||
} finally {
|
} finally {
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
}
|
}
|
||||||
|
@ -104,14 +108,16 @@ export default {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const i = this.selectedHost;
|
const i = this.selectedHost;
|
||||||
if (Object.keys(this.hosts).length <= 1) {
|
delete this.hosts[i];
|
||||||
|
await this.saveHosts(this.hosts);
|
||||||
|
|
||||||
|
if (!Object.keys(this.hosts).length) {
|
||||||
this.selectedHost = null;
|
this.selectedHost = null;
|
||||||
} else {
|
} else {
|
||||||
this.selectedHost = Object.keys(this.hosts)[0];
|
this.selectedHost = Object.keys(this.hosts)[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
delete this.hosts[i];
|
await this.reload();
|
||||||
await this.saveHosts(this.hosts);
|
|
||||||
} finally {
|
} finally {
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
}
|
}
|
||||||
|
@ -119,10 +125,7 @@ export default {
|
||||||
},
|
},
|
||||||
|
|
||||||
created() {
|
created() {
|
||||||
const self = this;
|
this.reload();
|
||||||
this.getHosts().then(hosts => {
|
|
||||||
self.hosts = hosts;
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
|
|
||||||
<form class="content" ref="content" @submit.prevent="save">
|
<form class="content" ref="content" @submit.prevent="save">
|
||||||
<div class="textarea">
|
<div class="textarea">
|
||||||
<textarea ref="text" v-model="config" v-text="loading ? 'Loading...' : config" @focus="onFocus" :disabled="loading" />
|
<textarea name="text" ref="text" v-model="config" v-text="loading ? 'Loading...' : config" @focus="onFocus" :disabled="loading" />
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="buttons">
|
<div class="buttons">
|
||||||
|
@ -34,11 +34,13 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
import axios from 'axios';
|
||||||
import mixins from '../utils';
|
import mixins from '../utils';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'Backup',
|
name: 'Backup',
|
||||||
mixins: [mixins],
|
mixins: [mixins],
|
||||||
|
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
config: null,
|
config: null,
|
||||||
|
@ -62,7 +64,21 @@ export default {
|
||||||
this.savedConfig = this.config;
|
this.savedConfig = this.config;
|
||||||
},
|
},
|
||||||
|
|
||||||
save(event) {},
|
async save(event) {
|
||||||
|
this.loading = true;
|
||||||
|
|
||||||
|
try {
|
||||||
|
const config = JSON.parse(event.target.text.value);
|
||||||
|
await this.saveConfig(config);
|
||||||
|
await this.reload();
|
||||||
|
this.$emit('reload');
|
||||||
|
} catch (e) {
|
||||||
|
console.warn(e);
|
||||||
|
this.notify(e.message, 'Could not save the configuration');
|
||||||
|
} finally {
|
||||||
|
this.loading = false;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
uploadFile(event) {
|
uploadFile(event) {
|
||||||
if (!(event.target.files && event.target.files.length)) {
|
if (!(event.target.files && event.target.files.length)) {
|
||||||
|
@ -86,8 +102,19 @@ export default {
|
||||||
reader.readAsText(event.target.files[0]);
|
reader.readAsText(event.target.files[0]);
|
||||||
},
|
},
|
||||||
|
|
||||||
loadURL(event) {
|
async loadURL(event) {
|
||||||
console.log(event);
|
const url = event.target.url.value.trim();
|
||||||
|
this.loading = true;
|
||||||
|
|
||||||
|
try {
|
||||||
|
const response = await axios.get(url);
|
||||||
|
this.config = JSON.stringify(response.data, null, ' ');
|
||||||
|
} catch (e) {
|
||||||
|
console.warn(e);
|
||||||
|
this.notify(e.message, 'Unable to parse the URL');
|
||||||
|
} finally {
|
||||||
|
this.loading = false;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
12
src/utils.js
12
src/utils.js
|
@ -141,6 +141,18 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
async saveConfig(config) {
|
||||||
|
this.loading = true;
|
||||||
|
const hosts = config.hosts || {};
|
||||||
|
const actions = config.actions || {};
|
||||||
|
|
||||||
|
try {
|
||||||
|
await Promise.all([this.saveHosts(hosts), this.saveActions(actions)]);
|
||||||
|
} finally {
|
||||||
|
this.loading = false;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
formToHost(form) {
|
formToHost(form) {
|
||||||
return {
|
return {
|
||||||
name: form.name.value,
|
name: form.name.value,
|
||||||
|
|
Loading…
Reference in a new issue