admin-fe/src/views/settings/components/Instance.vue

133 lines
4.3 KiB
Vue
Raw Normal View History

<template>
2019-11-06 01:01:31 +00:00
<div v-if="!loading">
2019-11-03 17:39:07 +00:00
<el-form ref="instanceData" :model="instanceData" :label-width="labelWidth">
<setting :setting-group="instance" :data="instanceData"/>
</el-form>
<div class="line"/>
<el-form ref="uriSchemes" :model="uriSchemesData" :label-width="labelWidth">
<setting :setting-group="uriSchemes" :data="uriSchemesData"/>
</el-form>
<div class="line"/>
<el-form ref="adminToken" :model="adminTokenData" :label-width="labelWidth">
<setting :setting-group="adminToken" :data="adminTokenData"/>
</el-form>
<div class="line"/>
<el-form ref="scheduledActivity" :model="scheduledActivityData" :label-width="labelWidth">
<setting :setting-group="scheduledActivity" :data="scheduledActivityData"/>
</el-form>
<div class="line"/>
<el-form ref="fetchInitialPosts" :model="fetchInitialPostsData" :label-width="labelWidth">
<setting :setting-group="fetchInitialPosts" :data="fetchInitialPostsData"/>
</el-form>
<div class="line"/>
<el-form ref="manifest" :model="manifestData" :label-width="labelWidth">
<setting :setting-group="manifest" :data="manifestData"/>
</el-form>
<div class="line"/>
<el-form ref="suggestions" :model="suggestionsData" :label-width="labelWidth">
<el-form-item label="Suggestions:"/>
<setting :setting-group="suggestions" :data="suggestionsData"/>
</el-form>
<div class="line"/>
<el-form ref="pleromaUser" :model="pleromaUserData" :label-width="labelWidth">
<setting :setting-group="pleromaUser" :data="pleromaUserData"/>
<el-form-item>
<el-button type="primary" @click="onSubmit">Submit</el-button>
</el-form-item>
</el-form>
</div>
</template>
<script>
import i18n from '@/lang'
import { mapGetters } from 'vuex'
2019-11-03 17:39:07 +00:00
import Setting from './Setting'
export default {
name: 'Instance',
2019-11-03 17:39:07 +00:00
components: {
Setting
},
computed: {
...mapGetters([
'settings'
]),
2019-11-03 17:39:07 +00:00
adminToken() {
return this.settings.description.find(setting => setting.description === `Allows to set a token that can be used to authenticate with the admin api without using an actual user by giving it as the 'admin_token' parameter`)
},
adminTokenData() {
2019-11-29 16:31:53 +00:00
return this.settings.settings[':pleroma'][':admin_token']
2019-11-03 17:39:07 +00:00
},
fetchInitialPosts() {
return this.settings.description.find(setting => setting.key === ':fetch_initial_posts')
},
fetchInitialPostsData() {
2019-11-29 16:31:53 +00:00
return this.settings.settings[':pleroma'][':fetch_initial_posts']
},
2019-11-03 17:39:07 +00:00
instance() {
return this.settings.description.find(setting => setting.key === ':instance')
},
instanceData() {
2019-11-29 16:31:53 +00:00
return this.settings.settings[':pleroma'][':instance']
},
isMobile() {
return this.$store.state.app.device === 'mobile'
},
labelWidth() {
2019-11-08 12:24:16 +00:00
return this.isMobile ? '100px' : '240px'
},
2019-11-06 01:01:31 +00:00
loading() {
return this.settings.loading
2019-11-06 01:01:31 +00:00
},
manifest() {
return this.settings.description.find(setting => setting.key === ':manifest')
},
manifestData() {
2019-11-29 16:31:53 +00:00
return this.settings.settings[':pleroma'][':manifest']
},
2019-11-03 17:39:07 +00:00
pleromaUser() {
return this.settings.description.find(setting => setting.key === 'Pleroma.User')
},
pleromaUserData() {
2019-11-29 16:31:53 +00:00
return this.settings.settings[':pleroma']['Pleroma.User']
},
2019-11-03 17:39:07 +00:00
scheduledActivity() {
return this.$store.state.settings.description.find(setting => setting.key === 'Pleroma.ScheduledActivity')
2019-08-15 12:13:14 +00:00
},
scheduledActivityData() {
2019-11-29 16:31:53 +00:00
return this.settings.settings[':pleroma']['Pleroma.ScheduledActivity']
},
2019-11-03 17:39:07 +00:00
suggestions() {
return this.$store.state.settings.description.find(setting => setting.key === ':suggestions')
},
suggestionsData() {
2019-11-29 16:31:53 +00:00
return this.settings.settings[':pleroma'][':suggestions']
},
2019-11-03 17:39:07 +00:00
uriSchemes() {
return this.$store.state.settings.description.find(setting => setting.key === ':uri_schemes')
},
uriSchemesData() {
2019-11-29 16:31:53 +00:00
return this.settings.settings[':pleroma'][':uri_schemes']
}
},
methods: {
2019-09-23 19:00:28 +00:00
async onSubmit() {
try {
await this.$store.dispatch('SubmitChanges')
} catch (e) {
return
}
this.$message({
type: 'success',
message: i18n.t('settings.success')
})
}
}
}
</script>
<style rel='stylesheet/scss' lang='scss'>
@import '../styles/main';
@include settings
</style>