forked from AkkomaGang/admin-fe
Render nested settings as a tree
This commit is contained in:
parent
2a82ad691c
commit
73818195b3
3 changed files with 46 additions and 3 deletions
|
@ -1,12 +1,34 @@
|
||||||
<template>
|
<template>
|
||||||
<div class="input-container">
|
<div class="input-container">
|
||||||
<el-form-item :label-width="customLabelWidth" :class="labelClass" class="settings-input">
|
<div v-if="setting.type === 'keyword'" style="width:100%">
|
||||||
|
<el-form-item :label-width="customLabelWidth" :class="labelClass" :style="`margin-left:${margin}px;margin-bottom:0`" class="settings-input">
|
||||||
<span slot="label">
|
<span slot="label">
|
||||||
{{ setting.label }}
|
{{ setting.label }}
|
||||||
<el-tooltip v-if="canBeDeleted && isDesktop" :content="$t('settings.removeFromDB')" placement="bottom-end">
|
<el-tooltip v-if="canBeDeleted && isDesktop" :content="$t('settings.removeFromDB')" placement="bottom-end">
|
||||||
<el-button icon="el-icon-delete" circle size="mini" style="margin-left:5px" @click="removeSetting"/>
|
<el-button icon="el-icon-delete" circle size="mini" style="margin-left:5px" @click="removeSetting"/>
|
||||||
</el-tooltip>
|
</el-tooltip>
|
||||||
</span>
|
</span>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item v-for="subSetting in setting.children" :key="subSetting.key" class="settings-input has-nested">
|
||||||
|
<inputs
|
||||||
|
:setting-group="settingGroup"
|
||||||
|
:setting-parent="[...settingParent, subSetting]"
|
||||||
|
:setting="subSetting"
|
||||||
|
:data="data[setting.key]"
|
||||||
|
:custom-label-width="isDesktop ? 'auto' : '100px'"
|
||||||
|
:label-class="'center-label'"
|
||||||
|
:input-class="'keyword-inner-input'"
|
||||||
|
:margin="margin + 20"
|
||||||
|
:nested="true"/>
|
||||||
|
</el-form-item>
|
||||||
|
</div>
|
||||||
|
<el-form-item v-if="setting.type !== 'keyword'" :label-width="customLabelWidth" :class="labelClass" class="settings-input">
|
||||||
|
<span slot="label" :style="`margin-left:${margin}px`">
|
||||||
|
{{ setting.label }}
|
||||||
|
<el-tooltip v-if="canBeDeleted && isDesktop" :content="$t('settings.removeFromDB')" placement="bottom-end">
|
||||||
|
<el-button icon="el-icon-delete" circle size="mini" style="margin-left:5px" @click="removeSetting"/>
|
||||||
|
</el-tooltip>
|
||||||
|
</span>
|
||||||
<el-input
|
<el-input
|
||||||
v-if="setting.type === 'string' || (setting.type.includes('string') && setting.type.includes('atom'))"
|
v-if="setting.type === 'string' || (setting.type.includes('string') && setting.type.includes('atom'))"
|
||||||
:value="inputValue"
|
:value="inputValue"
|
||||||
|
@ -56,6 +78,7 @@
|
||||||
</el-input>
|
</el-input>
|
||||||
<div v-if="setting.type === 'keyword'">
|
<div v-if="setting.type === 'keyword'">
|
||||||
<div v-for="subSetting in setting.children" :key="subSetting.key">
|
<div v-for="subSetting in setting.children" :key="subSetting.key">
|
||||||
|
<!-- {{ [...settingParent, subSetting].map(s => s.label) }} -->
|
||||||
<inputs
|
<inputs
|
||||||
:setting-group="settingGroup"
|
:setting-group="settingGroup"
|
||||||
:setting-parent="[...settingParent, subSetting]"
|
:setting-parent="[...settingParent, subSetting]"
|
||||||
|
@ -80,6 +103,7 @@
|
||||||
<div
|
<div
|
||||||
v-if="setting.description && setting.type !== 'keyword'"
|
v-if="setting.description && setting.type !== 'keyword'"
|
||||||
:class="inputClass"
|
:class="inputClass"
|
||||||
|
:style="`margin-left:${margin}px`"
|
||||||
class="expl"
|
class="expl"
|
||||||
v-html="getFormattedDescription(setting.description)"/>
|
v-html="getFormattedDescription(setting.description)"/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
@ -136,6 +160,13 @@ export default {
|
||||||
},
|
},
|
||||||
required: false
|
required: false
|
||||||
},
|
},
|
||||||
|
margin: {
|
||||||
|
type: Number,
|
||||||
|
default: function() {
|
||||||
|
return 0
|
||||||
|
},
|
||||||
|
required: false
|
||||||
|
},
|
||||||
nested: {
|
nested: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
default: function() {
|
default: function() {
|
||||||
|
@ -162,6 +193,11 @@ export default {
|
||||||
required: false
|
required: false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
currentMargin: 0
|
||||||
|
}
|
||||||
|
},
|
||||||
computed: {
|
computed: {
|
||||||
canBeDeleted() {
|
canBeDeleted() {
|
||||||
const { group, key } = this.settingGroup
|
const { group, key } = this.settingGroup
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<el-input
|
<el-input
|
||||||
:value="proxyUrlData.host"
|
:value="proxyUrlData.host"
|
||||||
placeholder="host (e.g. localhost or 127.0.0.1)"
|
placeholder="host (e.g. localhost or 127.0.0.1)"
|
||||||
class="proxy-url-value-input"
|
class="proxy-url-host-input"
|
||||||
@input="updateProxyUrl($event, 'host')"/> :
|
@input="updateProxyUrl($event, 'host')"/> :
|
||||||
<el-input
|
<el-input
|
||||||
:value="proxyUrlData.port"
|
:value="proxyUrlData.port"
|
||||||
|
|
|
@ -4,6 +4,9 @@
|
||||||
}
|
}
|
||||||
.center-label label {
|
.center-label label {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
span {
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
.code {
|
.code {
|
||||||
background-color: #adbed67a;
|
background-color: #adbed67a;
|
||||||
|
@ -151,6 +154,10 @@
|
||||||
width: 20%;
|
width: 20%;
|
||||||
margin-right: 8px
|
margin-right: 8px
|
||||||
}
|
}
|
||||||
|
.proxy-url-host-input {
|
||||||
|
width: 35%;
|
||||||
|
margin-right: 10px
|
||||||
|
}
|
||||||
.proxy-url-value-input {
|
.proxy-url-value-input {
|
||||||
width: 35%;
|
width: 35%;
|
||||||
margin-left: 8px;
|
margin-left: 8px;
|
||||||
|
|
Loading…
Reference in a new issue