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

76 lines
1.9 KiB
Vue
Raw Normal View History

<template>
2020-04-17 22:27:00 +00:00
<div v-if="!loading" :class="isSidebarOpen" class="form-container">
2020-06-29 23:35:08 +00:00
<el-form v-if="!loading" :model="rateLimitersData" :label-position="labelPosition" :label-width="labelWidth">
2020-01-22 11:58:12 +00:00
<setting :setting-group="rateLimiters" :data="rateLimitersData"/>
</el-form>
<div class="submit-button-container">
2021-02-23 20:42:47 +00:00
<el-button class="submit-button" type="primary" @click="onSubmit">{{ $t('settings.submit') }}</el-button>
2020-01-22 11:58:12 +00:00
</div>
</div>
</template>
<script>
import { mapGetters } from 'vuex'
import i18n from '@/lang'
import Setting from './Setting'
2020-01-21 18:16:56 +00:00
import _ from 'lodash'
export default {
name: 'RateLimiters',
components: { Setting },
computed: {
...mapGetters([
'settings'
]),
rateLimiters() {
return this.settings.description.find(setting => setting.key === ':rate_limit')
},
rateLimitersData() {
2020-01-21 18:16:56 +00:00
return _.get(this.settings.settings, [':pleroma', ':rate_limit']) || {}
},
isMobile() {
return this.$store.state.app.device === 'mobile'
},
2020-04-17 22:27:00 +00:00
isSidebarOpen() {
return this.$store.state.app.sidebar.opened ? 'sidebar-opened' : 'sidebar-closed'
},
isTablet() {
return this.$store.state.app.device === 'tablet'
},
labelPosition() {
return this.isMobile ? 'top' : 'right'
},
labelWidth() {
if (this.isMobile) {
return '120px'
} else if (this.isTablet) {
return '200px'
} else {
return '280px'
}
2019-11-06 01:01:31 +00:00
},
loading() {
return this.$store.state.settings.loading
}
},
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>