mirror of
https://github.com/xfgryujk/blivechat.git
synced 2025-02-25 19:30:53 +08:00
144 lines
5.1 KiB
Vue
144 lines
5.1 KiB
Vue
<template>
|
|
<el-form :model="form" ref="form" label-width="150px" :rules="{
|
|
roomId: [
|
|
{required: true, message: $t('home.roomIdEmpty'), trigger: 'blur'},
|
|
{type: 'integer', min: 1, message: $t('home.roomIdInteger'), trigger: 'blur'}
|
|
]
|
|
}">
|
|
<el-tabs>
|
|
<el-tab-pane :label="$t('home.general')">
|
|
<el-form-item :label="$t('home.roomId')" required prop="roomId">
|
|
<el-input v-model.number="form.roomId" type="number" min="1"></el-input>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.showDanmaku')">
|
|
<el-switch v-model="form.showDanmaku"></el-switch>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.showGift')">
|
|
<el-switch v-model="form.showGift"></el-switch>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.mergeSimilarDanmaku')">
|
|
<el-switch v-model="form.mergeSimilarDanmaku"></el-switch>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.minGiftPrice')">
|
|
<el-input v-model.number="form.minGiftPrice" type="number" min="0"></el-input>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.maxNumber')">
|
|
<el-input v-model.number="form.maxNumber" type="number" min="1"></el-input>
|
|
</el-form-item>
|
|
</el-tab-pane>
|
|
|
|
<el-tab-pane :label="$t('home.block')">
|
|
<el-form-item :label="$t('home.giftDanmaku')">
|
|
<el-switch v-model="form.blockGiftDanmaku"></el-switch>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.blockLevel')">
|
|
<el-slider v-model="form.blockLevel" show-input :min="0" :max="60"></el-slider>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.informalUser')">
|
|
<el-switch v-model="form.blockNewbie"></el-switch>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.unverifiedUser')">
|
|
<el-switch v-model="form.blockNotMobileVerified"></el-switch>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.blockKeywords')">
|
|
<el-input v-model="form.blockKeywords" type="textarea" :rows="5" :placeholder="$t('home.onePerLine')"></el-input>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.blockUsers')">
|
|
<el-input v-model="form.blockUsers" type="textarea" :rows="5" :placeholder="$t('home.onePerLine')"></el-input>
|
|
</el-form-item>
|
|
<el-form-item :label="$t('home.blockMedalLevel')">
|
|
<el-slider v-model="form.blockMedalLevel" show-input :min="0" :max="20"></el-slider>
|
|
</el-form-item>
|
|
</el-tab-pane>
|
|
</el-tabs>
|
|
|
|
<el-divider></el-divider>
|
|
<el-form-item :label="$t('home.roomUrl')">
|
|
<el-input ref="roomUrlInput" readonly :value="roomUrl" style="width: calc(100% - 8em); margin-right: 1em;"></el-input>
|
|
<el-button type="primary" @click="copyUrl">{{$t('home.copy')}}</el-button>
|
|
</el-form-item>
|
|
<el-form-item>
|
|
<el-button type="primary" :disabled="!roomUrl" @click="enterRoom">{{$t('home.enterRoom')}}</el-button>
|
|
<el-button type="primary" @click="exportConfig">{{$t('home.exportConfig')}}</el-button>
|
|
<el-button type="primary" @click="importConfig">{{$t('home.importConfig')}}</el-button>
|
|
</el-form-item>
|
|
</el-form>
|
|
</template>
|
|
|
|
<script>
|
|
import _ from 'lodash'
|
|
import download from 'downloadjs'
|
|
|
|
import {mergeConfig} from '@/utils'
|
|
import * as config from '@/api/config'
|
|
|
|
export default {
|
|
name: 'Home',
|
|
data() {
|
|
return {
|
|
form: {
|
|
roomId: parseInt(window.localStorage.roomId || '1'),
|
|
...config.getLocalConfig()
|
|
}
|
|
}
|
|
},
|
|
computed: {
|
|
roomUrl() {
|
|
if (this.form.roomId === '') {
|
|
return ''
|
|
}
|
|
let query = {...this.form}
|
|
delete query.roomId
|
|
let resolved = this.$router.resolve({name: 'room', params: {roomId: this.form.roomId}, query})
|
|
return `${window.location.protocol}//${window.location.host}${resolved.href}`
|
|
}
|
|
},
|
|
watch: {
|
|
roomUrl: _.debounce(function() {
|
|
window.localStorage.roomId = this.form.roomId
|
|
config.setLocalConfig(this.form)
|
|
}, 500)
|
|
},
|
|
methods: {
|
|
enterRoom() {
|
|
window.open(this.roomUrl, `room ${this.form.roomId}`, 'menubar=0,location=0,scrollbars=0,toolbar=0,width=600,height=600')
|
|
},
|
|
copyUrl() {
|
|
this.$refs.roomUrlInput.select()
|
|
document.execCommand('Copy')
|
|
},
|
|
exportConfig() {
|
|
let cfg = mergeConfig(this.form, config.DEFAULT_CONFIG)
|
|
download(JSON.stringify(cfg, null, 2), 'blivechat.json', 'application/json')
|
|
},
|
|
importConfig() {
|
|
let input = document.createElement('input')
|
|
input.type = 'file'
|
|
input.accept = 'application/json'
|
|
input.onchange = () => {
|
|
let reader = new window.FileReader()
|
|
reader.onload = () => {
|
|
let cfg
|
|
try {
|
|
cfg = JSON.parse(reader.result)
|
|
} catch (e) {
|
|
this.$message.error(this.$t('home.failedToParseConfig') + e)
|
|
return
|
|
}
|
|
cfg = mergeConfig(cfg, config.DEFAULT_CONFIG)
|
|
this.form = {roomId: this.form.roomId, ...cfg}
|
|
}
|
|
reader.readAsText(input.files[0])
|
|
}
|
|
input.click()
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
.el-form {
|
|
max-width: 800px;
|
|
}
|
|
</style>
|