109 lines
4.7 KiB
Vue
109 lines
4.7 KiB
Vue
<template>
|
|
<div id="container">
|
|
<div id="wrap">
|
|
<div id="top">
|
|
<div id="logo">
|
|
<!--<img class="logo"-->
|
|
<!-- src="img/logo.png"-->
|
|
<!--/>-->
|
|
<!--如果需要自定义logo图片,使用上面这段代码,并删除下面这段代码,图片位置应放在img下的logo.png-->
|
|
<router-link to="/overview">
|
|
<img
|
|
class="logo"
|
|
src=""
|
|
/>
|
|
</router-link>
|
|
<p></p>
|
|
<div class="headline">
|
|
<h1>Welcome</h1>
|
|
</div>
|
|
<div class="" id="kg-btn">
|
|
<input class="tgl tgl-flip" id="qieh" type="checkbox" />
|
|
<label
|
|
class="tgl-btn"
|
|
data-tg-off="PROXY"
|
|
data-tg-on="DIRECT"
|
|
for="qieh"
|
|
@click="toggleProxy"
|
|
></label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div id="main">
|
|
<div class="app animated fadeInLeft" id="app">
|
|
<ul>
|
|
<li v-for="p in proxies">
|
|
<a :href="isProxy ? p.proxyUrl : p.directUrl" target="_blank">
|
|
<img class="shake" width="128" height="128" :src="p.image" />
|
|
<strong>{{ p.name }}</strong></a
|
|
>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div id="footer">
|
|
<div class="footer-contents">
|
|
<div class="links">
|
|
<div class="line">
|
|
<a href="/">FRP Home</a>
|
|
<span class="footer-link-separator"></span>
|
|
<span class="copyright">@</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { ref } from 'vue'
|
|
class Item {
|
|
name: string
|
|
image: string
|
|
directUrl: string
|
|
proxyUrl: string
|
|
|
|
/**
|
|
*
|
|
*/
|
|
constructor(proxy: any, host: string) {
|
|
this.name = proxy.name
|
|
this.image = proxy.conf.group
|
|
this.directUrl = proxy.conf.group_key
|
|
this.proxyUrl = `${host}:${proxy.conf.remote_port}`
|
|
}
|
|
}
|
|
|
|
let proxies = ref<Item[]>([])
|
|
let isProxy = ref<Boolean>(true)
|
|
const protocal = window.location.protocol
|
|
const host = window.location.hostname
|
|
|
|
const fetchData = () => {
|
|
fetch('../api/proxy/tcp', { credentials: 'include' })
|
|
.then((res) => {
|
|
return res.json()
|
|
})
|
|
.then((json) => {
|
|
const result = json.proxies.sort(
|
|
(a: any, b: any) =>
|
|
parseInt(a.conf.remote_port) - parseInt(b.conf.remote_port)
|
|
)
|
|
for (let proxy of result) {
|
|
if (proxy != null && proxy.conf.group != '')
|
|
proxies.value.push(new Item(proxy, `${protocal}//${host}`))
|
|
}
|
|
})
|
|
}
|
|
fetchData()
|
|
|
|
const toggleProxy = () => {
|
|
isProxy.value = !isProxy.value
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
@import url('assets/style.css');
|
|
</style>
|