Add ability to remove instance panel doc

This commit is contained in:
Angelina Filippova 2020-09-18 01:11:50 +03:00
parent b1c22da958
commit d414750cd5
4 changed files with 20 additions and 5 deletions

View file

@ -438,7 +438,8 @@ export default {
removeSettingConfirmation: 'Are you sure you want to remove this setting\'s value from the database?', removeSettingConfirmation: 'Are you sure you want to remove this setting\'s value from the database?',
changeImage: 'Change image', changeImage: 'Change image',
uploadImage: 'Upload image', uploadImage: 'Upload image',
remove: 'Remove' remove: 'Remove',
instancePanel: 'Instance Panel Document'
}, },
invites: { invites: {
inviteTokens: 'Invite tokens', inviteTokens: 'Invite tokens',

View file

@ -85,7 +85,7 @@ const settings = {
actions: { actions: {
async FetchInstanceDocument({ commit, getters }, name) { async FetchInstanceDocument({ commit, getters }, name) {
const { data } = await getInstanceDocument(name, getters.authHost, getters.token) const { data } = await getInstanceDocument(name, getters.authHost, getters.token)
commit('SET_INSTANCE_PANEL', data.url) commit('SET_INSTANCE_PANEL', data)
}, },
async FetchSettings({ commit, getters }) { async FetchSettings({ commit, getters }) {
commit('SET_LOADING', true) commit('SET_LOADING', true)
@ -105,8 +105,9 @@ const settings = {
commit('TOGGLE_TABS', false) commit('TOGGLE_TABS', false)
commit('SET_LOADING', false) commit('SET_LOADING', false)
}, },
async RemoveInstanceDocument({ getters }, name) { async RemoveInstanceDocument({ dispatch, getters }, name) {
await deleteInstanceDocument(name, getters.authHost, getters.token) await deleteInstanceDocument(name, getters.authHost, getters.token)
await dispatch('FetchInstanceDocument', 'instance-panel')
}, },
async RemoveSetting({ commit, getters }, configs) { async RemoveSetting({ commit, getters }, configs) {
await removeSettings(configs, getters.authHost, getters.token) await removeSettings(configs, getters.authHost, getters.token)
@ -130,7 +131,8 @@ const settings = {
commit('TOGGLE_REBOOT', response.data.need_reboot) commit('TOGGLE_REBOOT', response.data.need_reboot)
commit('CLEAR_UPDATED_SETTINGS') commit('CLEAR_UPDATED_SETTINGS')
}, },
async UpdateInstanceDocs({ getters }, { name, content }) { async UpdateInstanceDocs({ commit, getters }, { name, content }) {
commit('SET_INSTANCE_PANEL', content)
const formData = new FormData() const formData = new FormData()
const blob = new Blob([content], { type: 'text/html' }) const blob = new Blob([content], { type: 'text/html' })
formData.append('file', blob) formData.append('file', blob)

View file

@ -1,9 +1,9 @@
<template> <template>
<div v-if="!loading" :class="isSidebarOpen" class="form-container"> <div v-if="!loading" :class="isSidebarOpen" class="form-container">
<editor-input :content="instancePanelContent" @input="handleEditorUpdate"/>
<el-form :model="instanceData" :label-position="labelPosition" :label-width="labelWidth"> <el-form :model="instanceData" :label-position="labelPosition" :label-width="labelWidth">
<setting :setting-group="instance" :data="instanceData"/> <setting :setting-group="instance" :data="instanceData"/>
</el-form> </el-form>
<editor-input :content="instancePanelContent" @input="handleEditorUpdate"/>
<el-divider v-if="instance" class="divider thick-line"/> <el-divider v-if="instance" class="divider thick-line"/>
<el-form :model="restrictUnauthenticatedData" :label-position="labelPosition" :label-width="labelWidth"> <el-form :model="restrictUnauthenticatedData" :label-position="labelPosition" :label-width="labelWidth">
<setting :setting-group="restrictUnauthenticated" :data="restrictUnauthenticatedData"/> <setting :setting-group="restrictUnauthenticated" :data="restrictUnauthenticatedData"/>

View file

@ -1,6 +1,12 @@
<template> <template>
<el-form :label-position="labelPosition" :label-width="labelWidth"> <el-form :label-position="labelPosition" :label-width="labelWidth">
<el-form-item label="Instance panel doc" class="editor-form-item"> <el-form-item label="Instance panel doc" class="editor-form-item">
<span slot="label">
{{ $t('settings.instancePanel') }}
<el-tooltip :content="$t('settings.removeFromDB')" placement="bottom-end">
<el-button icon="el-icon-delete" circle size="mini" class="delete-setting-button" @click="removeInstanceDoc"/>
</el-tooltip>
</span>
<div class="editor"> <div class="editor">
<editor-menu-bar v-slot="{ commands, isActive }" :editor="editor"> <editor-menu-bar v-slot="{ commands, isActive }" :editor="editor">
<div class="menubar"> <div class="menubar">
@ -165,6 +171,12 @@ export default {
}, },
beforeDestroy() { beforeDestroy() {
this.editor.destroy() this.editor.destroy()
},
methods: {
async removeInstanceDoc(name) {
await this.$store.dispatch('RemoveInstanceDocument', 'instance-panel')
this.editor.setContent(this.content)
}
} }
} }
</script> </script>