mirror of
https://github.com/earthjasonlin/zzz-signal-search-export.git
synced 2025-04-19 15:10:17 +08:00
167 lines
6.3 KiB
Vue
167 lines
6.3 KiB
Vue
<template>
|
|
<div class="bg-white py-4 px-6 w-screen h-screen fixed inset-0 overflow-y-auto">
|
|
<div class="flex content-center items-center mb-4 justify-between">
|
|
<h3 class="text-lg">{{text.title}}</h3>
|
|
<el-button icon="close" @click="closeSetting" plain circle type="default" class="w-8 h-8 shadow-md focus:shadow-none focus:outline-none fixed top-4 right-6"></el-button>
|
|
</div>
|
|
<el-form :model="settingForm" label-width="120px">
|
|
<el-form-item :label="text.language">
|
|
<el-select @change="saveLang" v-model="settingForm.lang">
|
|
<el-option v-for="item of data.langMap" :key="item[0]" :label="item[1]" :value="item[0]"></el-option>
|
|
</el-select>
|
|
<p class="text-gray-400 text-xs m-1.5">{{text.languageHint}}</p>
|
|
</el-form-item>
|
|
<el-form-item :label="text.logType">
|
|
<el-radio-group @change="saveSetting" v-model.number="settingForm.logType">
|
|
<el-radio-button :label="0">{{text.auto}}</el-radio-button>
|
|
<el-radio-button :label="1">{{text.cnServer}}</el-radio-button>
|
|
<el-radio-button :label="2">{{text.seaServer}}</el-radio-button>
|
|
</el-radio-group>
|
|
<p class="text-gray-400 text-xs m-1.5">{{text.logTypeHint}}</p>
|
|
</el-form-item>
|
|
<el-form-item :label="common.data">
|
|
<el-button type="primary" plain @click="state.showDataDialog = true">{{common.dataManage}}</el-button>
|
|
<p class="text-gray-400 text-xs m-1.5">{{text.dataManagerHint}}</p>
|
|
</el-form-item>
|
|
<el-form-item :label="text.autoUpdate">
|
|
<el-switch
|
|
@change="saveSetting"
|
|
v-model="settingForm.autoUpdate">
|
|
</el-switch>
|
|
</el-form-item>
|
|
<el-form-item :label="text.fetchFullHistory">
|
|
<el-switch
|
|
@change="saveSetting"
|
|
v-model="settingForm.fetchFullHistory">
|
|
</el-switch>
|
|
<p class="text-gray-400 text-xs m-1.5">{{text.fetchFullHistoryHint}}</p>
|
|
</el-form-item>
|
|
<el-form-item :label="text.proxyMode">
|
|
<el-switch
|
|
@change="saveSetting"
|
|
v-model="settingForm.proxyMode">
|
|
</el-switch>
|
|
<p class="text-gray-400 text-xs m-1.5">{{text.proxyModeHint}}</p>
|
|
<el-button class="focus:outline-none" @click="disableProxy">{{text.closeProxy}}</el-button>
|
|
<p class="text-gray-400 text-xs m-1.5">{{text.closeProxyHint}}</p>
|
|
</el-form-item>
|
|
</el-form>
|
|
<h3 class="text-lg my-4">{{about.title}}</h3>
|
|
<p class="text-gray-600 text-xs mt-1">{{text.idVersion}} {{idJson.version}}</p>
|
|
<p class="text-gray-600 text-xs mt-1">{{about.license}}</p>
|
|
<p class="text-gray-600 text-xs mt-1">GitHub: <a @click="openGithub" class="cursor-pointer text-blue-400">https://github.com/earthjasonlin/zzz-signal-search-export</a></p>
|
|
<p class="text-gray-600 text-xs mt-1 pb-6">UIGF: <a @click="openUIGF" class="cursor-pointer text-blue-400">https://uigf.org/</a></p>
|
|
<el-dialog v-model="state.showDataDialog" :title="common.dataManage" width="90%">
|
|
<div class="">
|
|
<el-table :data="gachaDataInfo" border stripe>
|
|
<el-table-column property="uid" label="UID" width="128" />
|
|
<el-table-column property="time" :label="common.updateTime">
|
|
<template #default="scope">
|
|
{{ new Date(scope.row.time).toLocaleString() }}
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column property="deleted" :label="common.status" width="128">
|
|
<template #default="scope">
|
|
<el-tag type="info" size="small" v-if="scope.row.deleted">{{common.deleted}}</el-tag>
|
|
<el-tag type="success" size="small" v-else>{{common.normal}}</el-tag>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column property="deleted" :label="common.action" width="128">
|
|
<template #default="scope">
|
|
<el-tooltip :content="scope.row.deleted ? common.restore : common.delete" placement="top">
|
|
<el-button :loading="state.dataActionLoading" size="small" icon="refresh" plain type="success" @click="deleteData(scope.row.uid, false)" v-if="scope.row.deleted"></el-button>
|
|
<el-button :loading="state.dataActionLoading" size="small" icon="delete" plain type="danger" @click="deleteData(scope.row.uid, true)" v-else></el-button>
|
|
</el-tooltip>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
</div>
|
|
</el-dialog>
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<script setup>
|
|
const { ipcRenderer, shell } = require('electron')
|
|
import idJson from '../../idJson.json'
|
|
import { reactive, onMounted, computed } from 'vue'
|
|
|
|
const emit = defineEmits(['close', 'changeLang', 'refreshData'])
|
|
|
|
const props = defineProps({
|
|
i18n: Object,
|
|
gachaDataInfo: Array
|
|
})
|
|
|
|
const data = reactive({
|
|
langMap: new Map(),
|
|
})
|
|
|
|
const settingForm = reactive({
|
|
lang: 'zh-cn',
|
|
logType: 1,
|
|
proxyMode: true,
|
|
autoUpdate: true,
|
|
fetchFullHistory: false,
|
|
})
|
|
|
|
const state = reactive({
|
|
showDataDialog: false,
|
|
dataActionLoading: false
|
|
})
|
|
|
|
const common = computed(() => props.i18n.ui.common)
|
|
const text = computed(() => props.i18n.ui.setting)
|
|
const about = computed(() => props.i18n.ui.about)
|
|
|
|
const saveSetting = async () => {
|
|
const keys = ['lang', 'logType', 'proxyMode', 'autoUpdate', 'fetchFullHistory']
|
|
for (let key of keys) {
|
|
await ipcRenderer.invoke('SAVE_CONFIG', [key, settingForm[key]])
|
|
}
|
|
}
|
|
|
|
const saveLang = async () => {
|
|
await saveSetting()
|
|
emit('changeLang')
|
|
}
|
|
|
|
const closeSetting = () => emit('close')
|
|
|
|
const disableProxy = async () => {
|
|
await ipcRenderer.invoke('DISABLE_PROXY')
|
|
}
|
|
|
|
const openGithub = () => shell.openExternal('https://github.com/earthjasonlin/zzz-signal-search-export')
|
|
const openUIGF = () => shell.openExternal('https://uigf.org/')
|
|
const openLink = (link) => shell.openExternal(link)
|
|
|
|
const deleteData = async (uid, action) => {
|
|
state.dataActionLoading = true
|
|
await ipcRenderer.invoke('DELETE_DATA', uid, action)
|
|
state.dataActionLoading = false
|
|
emit('refreshData')
|
|
}
|
|
|
|
onMounted(async () => {
|
|
data.langMap = await ipcRenderer.invoke('LANG_MAP')
|
|
const config = await ipcRenderer.invoke('GET_CONFIG')
|
|
Object.assign(settingForm, config)
|
|
})
|
|
|
|
</script>
|
|
|
|
<style>
|
|
.el-form-item__label {
|
|
line-height: normal !important;
|
|
position: relative;
|
|
top: 6px;
|
|
}
|
|
.el-form-item__content {
|
|
flex-direction: column;
|
|
align-items: start !important;
|
|
}
|
|
.el-form-item--default {
|
|
margin-bottom: 14px !important;
|
|
}
|
|
</style> |