mirror of
https://github.com/YunoHost/yunohost-admin.git
synced 2024-09-03 20:06:15 +02:00
ToolSettings view
This commit is contained in:
parent
895bab5e26
commit
94da3526d7
3 changed files with 74 additions and 0 deletions
|
@ -374,6 +374,15 @@ const routes = [
|
||||||
breadcrumb: ['tool-list', 'tool-webadmin']
|
breadcrumb: ['tool-list', 'tool-webadmin']
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: 'tool-settings',
|
||||||
|
path: '/tools/settings',
|
||||||
|
component: () => import(/* webpackChunkName: "views/tools/settings" */ '@/views/tool/ToolSettings'),
|
||||||
|
meta: {
|
||||||
|
args: { trad: 'tools_yunohost_settings' },
|
||||||
|
breadcrumb: ['tool-list', 'tool-settings']
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
name: 'tool-power',
|
name: 'tool-power',
|
||||||
path: '/tools/power',
|
path: '/tools/power',
|
||||||
|
|
|
@ -24,6 +24,7 @@ export default {
|
||||||
{ routeName: 'tool-migrations', icon: 'share', translation: 'migrations' },
|
{ routeName: 'tool-migrations', icon: 'share', translation: 'migrations' },
|
||||||
{ routeName: 'tool-firewall', icon: 'shield', translation: 'firewall' },
|
{ routeName: 'tool-firewall', icon: 'shield', translation: 'firewall' },
|
||||||
{ routeName: 'tool-adminpw', icon: 'key-modern', translation: 'tools_adminpw' },
|
{ routeName: 'tool-adminpw', icon: 'key-modern', translation: 'tools_adminpw' },
|
||||||
|
{ routeName: 'tool-settings', icon: 'cog', translation: 'tools_yunohost_settings' },
|
||||||
{ routeName: 'tool-webadmin', icon: 'cog', translation: 'tools_webadmin_settings' },
|
{ routeName: 'tool-webadmin', icon: 'cog', translation: 'tools_webadmin_settings' },
|
||||||
{ routeName: 'tool-power', icon: 'power-off', translation: 'tools_shutdown_reboot' }
|
{ routeName: 'tool-power', icon: 'power-off', translation: 'tools_shutdown_reboot' }
|
||||||
]
|
]
|
||||||
|
|
64
app/src/views/tool/ToolSettings.vue
Normal file
64
app/src/views/tool/ToolSettings.vue
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
<template>
|
||||||
|
<view-base
|
||||||
|
:queries="queries" @queries-response="onQueriesResponse"
|
||||||
|
ref="view" skeleton="card-form-skeleton"
|
||||||
|
>
|
||||||
|
<config-panels v-if="config.panels" v-bind="config" @submit="applyConfig" />
|
||||||
|
</view-base>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import api, { objectToParams } from '@/api'
|
||||||
|
import {
|
||||||
|
formatFormData,
|
||||||
|
formatYunoHostConfigPanels
|
||||||
|
} from '@/helpers/yunohostArguments'
|
||||||
|
import ConfigPanels from '@/components/ConfigPanels'
|
||||||
|
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: 'ToolSettingsConfig',
|
||||||
|
|
||||||
|
components: {
|
||||||
|
ConfigPanels
|
||||||
|
},
|
||||||
|
|
||||||
|
props: {},
|
||||||
|
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
queries: [
|
||||||
|
['GET', 'settings?full']
|
||||||
|
],
|
||||||
|
config: {}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {
|
||||||
|
onQueriesResponse (config) {
|
||||||
|
this.config = formatYunoHostConfigPanels(config)
|
||||||
|
},
|
||||||
|
|
||||||
|
async applyConfig (id_) {
|
||||||
|
const formatedData = await formatFormData(
|
||||||
|
this.config.forms[id_],
|
||||||
|
{ removeEmpty: false, removeNull: true, multipart: false }
|
||||||
|
)
|
||||||
|
|
||||||
|
api.put(
|
||||||
|
'settings',
|
||||||
|
{ key: id_, args: objectToParams(formatedData) },
|
||||||
|
{ key: 'tools.update_settings', name: this.name }
|
||||||
|
).then(() => {
|
||||||
|
this.$refs.view.fetchQueries({ triggerLoading: true })
|
||||||
|
}).catch(err => {
|
||||||
|
if (err.name !== 'APIBadRequestError') throw err
|
||||||
|
const panel = this.config.panels.find(({ id }) => id_ === id)
|
||||||
|
if (err.data.name) {
|
||||||
|
this.config.errors[id_][err.data.name].message = err.message
|
||||||
|
} else this.$set(panel, 'serverError', err.message)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
Loading…
Add table
Reference in a new issue