Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/MHSanaei/3x-ui.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTara Rostami <132676256+TaraRostami@users.noreply.github.com>2024-04-20 21:45:36 +0300
committerGitHub <noreply@github.com>2024-04-20 21:45:36 +0300
commitdb24d216210e0038f92e634de1ab8a46fbce4632 (patch)
tree3648326a1e359543febd865747822bc6f8f72781 /web/html/xui/form/protocol
parent3d5c06bf08f0ede7206e0ef39966d6be2106a225 (diff)
UI Improvements (#2228)
* UI Improvements Better Table Update QR Code Modal Better Info Modal Compression HTML files Better Dropdown Menu Better Calendar and more .. Remove files Minor Fixes
Diffstat (limited to 'web/html/xui/form/protocol')
-rw-r--r--web/html/xui/form/protocol/http.html36
-rw-r--r--web/html/xui/form/protocol/socks.html59
-rw-r--r--web/html/xui/form/protocol/trojan.html88
-rw-r--r--web/html/xui/form/protocol/vless.html92
-rw-r--r--web/html/xui/form/protocol/wireguard.html136
5 files changed, 201 insertions, 210 deletions
diff --git a/web/html/xui/form/protocol/http.html b/web/html/xui/form/protocol/http.html
index a14418a2..3206139e 100644
--- a/web/html/xui/form/protocol/http.html
+++ b/web/html/xui/form/protocol/http.html
@@ -1,21 +1,23 @@
{{define "form/http"}}
<a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
- <table style="width: 100%; text-align: center; margin: 1rem 0;">
- <tr>
- <td width="45%">{{ i18n "username" }}</td>
- <td width="45%">{{ i18n "password" }}</td>
- <td><a-button size="small" @click="inbound.settings.addAccount(new Inbound.HttpSettings.HttpAccount())">+</a-button></td>
- </tr>
- </table>
- <a-input-group compact v-for="(account, index) in inbound.settings.accounts" style="margin-bottom: 10px;">
- <a-input style="width: 50%" v-model.trim="account.user" placeholder='{{ i18n "username" }}'>
- <template slot="addonBefore" style="margin: 0;">[[ index+1 ]]</template>
- </a-input>
- <a-input style="width: 50%" v-model.trim="account.pass" placeholder='{{ i18n "password" }}'>
- <template slot="addonAfter">
- <a-button size="small" @click="inbound.settings.delAccount(index)">-</a-button>
- </template>
- </a-input>
- </a-input-group>
+ <table style="width: 100%; text-align: center; margin: 1rem 0;">
+ <tr>
+ <td width="45%">{{ i18n "username" }}</td>
+ <td width="45%">{{ i18n "password" }}</td>
+ <td>
+ <a-button icon="plus" size="small" @click="inbound.settings.addAccount(new Inbound.HttpSettings.HttpAccount())"></a-button>
+ </td>
+ </tr>
+ </table>
+ <a-input-group compact v-for="(account, index) in inbound.settings.accounts" style="margin-bottom: 10px;">
+ <a-input style="width: 50%" v-model.trim="account.user" placeholder='{{ i18n "username" }}'>
+ <template slot="addonBefore" style="margin: 0;">[[ index+1 ]]</template>
+ </a-input>
+ <a-input style="width: 50%" v-model.trim="account.pass" placeholder='{{ i18n "password" }}'>
+ <template slot="addonAfter">
+ <a-button icon="minus" size="small" @click="inbound.settings.delAccount(index)"></a-button>
+ </template>
+ </a-input>
+ </a-input-group>
</a-form>
{{end}}
diff --git a/web/html/xui/form/protocol/socks.html b/web/html/xui/form/protocol/socks.html
index 105603e5..849ec210 100644
--- a/web/html/xui/form/protocol/socks.html
+++ b/web/html/xui/form/protocol/socks.html
@@ -1,33 +1,34 @@
{{define "form/socks"}}
<a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
- <a-form-item label='{{ i18n "pages.inbounds.enable" }} UDP'>
- <a-switch v-model="inbound.settings.udp"></a-switch>
- </a-form-item>
- <a-form-item label="IP" v-if="inbound.settings.udp">
- <a-input v-model.trim="inbound.settings.ip"></a-input>
- </a-form-item>
- <a-form-item label='{{ i18n "password" }}'>
- <a-switch :checked="inbound.settings.auth === 'password'"
- @change="checked => inbound.settings.auth = checked ? 'password' : 'noauth'"></a-switch>
- </a-form-item>
- <template v-if="inbound.settings.auth === 'password'">
- <table style="width: 100%; text-align: center; margin: 1rem 0;">
- <tr>
- <td width="45%">{{ i18n "username" }}</td>
- <td width="45%">{{ i18n "password" }}</td>
- <td><a-button size="small" @click="inbound.settings.addAccount(new Inbound.SocksSettings.SocksAccount())">+</a-button></td>
- </tr>
- </table>
- <a-input-group compact v-for="(account, index) in inbound.settings.accounts" style="margin-bottom: 10px;">
- <a-input style="width: 50%" v-model.trim="account.user" placeholder='{{ i18n "username" }}'>
- <template slot="addonBefore" style="margin: 0;">[[ index+1 ]]</template>
- </a-input>
- <a-input style="width: 50%" v-model.trim="account.pass" placeholder='{{ i18n "password" }}'>
- <template slot="addonAfter">
- <a-button size="small" @click="inbound.settings.delAccount(index)">-</a-button>
- </template>
- </a-input>
- </a-input-group>
- </template>
+ <a-form-item label='{{ i18n "pages.inbounds.enable" }} UDP'>
+ <a-switch v-model="inbound.settings.udp"></a-switch>
+ </a-form-item>
+ <a-form-item label="IP" v-if="inbound.settings.udp">
+ <a-input v-model.trim="inbound.settings.ip"></a-input>
+ </a-form-item>
+ <a-form-item label='{{ i18n "password" }}'>
+ <a-switch :checked="inbound.settings.auth === 'password'" @change="checked => inbound.settings.auth = checked ? 'password' : 'noauth'"></a-switch>
+ </a-form-item>
+ <template v-if="inbound.settings.auth === 'password'">
+ <table style="width: 100%; text-align: center; margin: 1rem 0;">
+ <tr>
+ <td width="45%">{{ i18n "username" }}</td>
+ <td width="45%">{{ i18n "password" }}</td>
+ <td>
+ <a-button icon="plus" size="small" @click="inbound.settings.addAccount(new Inbound.SocksSettings.SocksAccount())"></a-button>
+ </td>
+ </tr>
+ </table>
+ <a-input-group compact v-for="(account, index) in inbound.settings.accounts" style="margin-bottom: 10px;">
+ <a-input style="width: 50%" v-model.trim="account.user" placeholder='{{ i18n "username" }}'>
+ <template slot="addonBefore" style="margin: 0;">[[ index+1 ]]</template>
+ </a-input>
+ <a-input style="width: 50%" v-model.trim="account.pass" placeholder='{{ i18n "password" }}'>
+ <template slot="addonAfter">
+ <a-button icon="minus" size="small" @click="inbound.settings.delAccount(index)"></a-button>
+ </template>
+ </a-input>
+ </a-input-group>
+ </template>
</a-form>
{{end}}
diff --git a/web/html/xui/form/protocol/trojan.html b/web/html/xui/form/protocol/trojan.html
index fe1db139..8c99a67a 100644
--- a/web/html/xui/form/protocol/trojan.html
+++ b/web/html/xui/form/protocol/trojan.html
@@ -1,54 +1,50 @@
{{define "form/trojan"}}
-<a-collapse activeKey="0" v-for="(client, index) in inbound.settings.trojans.slice(0,1)" v-if="!isEdit">
- <a-collapse-panel header='{{ i18n "pages.inbounds.client" }}'>
- {{template "form/client"}}
- </a-collapse-panel>
+<a-collapse activeKey="0" v-for="(client, index) in inbound.settings.trojans.slice(0,1)" v-if="!isEdit">
+ <a-collapse-panel header='{{ i18n "pages.inbounds.client" }}'>
+ {{template "form/client"}}
+ </a-collapse-panel>
</a-collapse>
<a-collapse v-else>
- <a-collapse-panel :header="'{{ i18n "pages.client.clientCount"}} : ' + inbound.settings.trojans.length">
- <table width="100%">
- <tr class="client-table-header">
- <th>{{ i18n "pages.inbounds.email" }}</th>
- <th>Password</th>
- </tr>
- <tr v-for="(client, index) in inbound.settings.trojans" :class="index % 2 == 1 ? 'client-table-odd-row' : ''">
- <td>[[ client.email ]]</td>
- <td>[[ client.password ]]</td>
- </tr>
- </table>
- </a-collapse-panel>
+ <a-collapse-panel :header="'{{ i18n "pages.client.clientCount"}} : ' + inbound.settings.trojans.length">
+ <table width="100%">
+ <tr class="client-table-header">
+ <th>{{ i18n "pages.inbounds.email" }}</th>
+ <th>Password</th>
+ </tr>
+ <tr v-for="(client, index) in inbound.settings.trojans" :class="index % 2 == 1 ? 'client-table-odd-row' : ''">
+ <td>[[ client.email ]]</td>
+ <td>[[ client.password ]]</td>
+ </tr>
+ </table>
+ </a-collapse-panel>
</a-collapse>
<template v-if="inbound.isTcp && !inbound.stream.isReality">
- <a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
- <a-form-item label="Fallbacks">
- <a-button type="primary" size="small" @click="inbound.settings.addFallback()">+</a-button>
- </a-form-item>
- </a-form>
+ <a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
+ <a-form-item label="Fallbacks">
+ <a-button icon="plus" type="primary" size="small" @click="inbound.settings.addFallback()"></a-button>
+ </a-form-item>
+ </a-form>
- <!-- trojan fallbacks -->
- <a-form v-for="(fallback, index) in inbound.settings.fallbacks" :colon="false" :label-col="{ md: {span:8} }"
- :wrapper-col="{ md: {span:14} }">
- <a-divider style="margin:0;">
- Fallback [[ index + 1 ]]
- <a-icon type="delete" @click="() => inbound.settings.delFallback(index)"
- style="color: rgb(255, 77, 79);cursor: pointer;" />
- </a-divider>
- <a-form-item label='SNI'>
- <a-input v-model="fallback.name"></a-input>
- </a-form-item>
- <a-form-item label='ALPN'>
- <a-input v-model="fallback.alpn"></a-input>
- </a-form-item>
- <a-form-item label='Path'>
- <a-input v-model="fallback.path"></a-input>
- </a-form-item>
- <a-form-item label='Dest'>
- <a-input v-model="fallback.dest"></a-input>
- </a-form-item>
- <a-form-item label='xVer'>
- <a-input-number v-model="fallback.xver" :min="0" :max="2"></a-input-number>
- </a-form-item>
- </a-form>
- <a-divider style="margin:5px 0;"></a-divider>
+ <!-- trojan fallbacks -->
+ <a-form v-for="(fallback, index) in inbound.settings.fallbacks" :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
+ <a-divider style="margin:0;"> Fallback [[ index + 1 ]] <a-icon type="delete" @click="() => inbound.settings.delFallback(index)" style="color: rgb(255, 77, 79);cursor: pointer;"></a-icon>
+ </a-divider>
+ <a-form-item label='SNI'>
+ <a-input v-model="fallback.name"></a-input>
+ </a-form-item>
+ <a-form-item label='ALPN'>
+ <a-input v-model="fallback.alpn"></a-input>
+ </a-form-item>
+ <a-form-item label='Path'>
+ <a-input v-model="fallback.path"></a-input>
+ </a-form-item>
+ <a-form-item label='Dest'>
+ <a-input v-model="fallback.dest"></a-input>
+ </a-form-item>
+ <a-form-item label='xVer'>
+ <a-input-number v-model="fallback.xver" :min="0" :max="2"></a-input-number>
+ </a-form-item>
+ </a-form>
+ <a-divider style="margin:5px 0;"></a-divider>
</template>
{{end}}
diff --git a/web/html/xui/form/protocol/vless.html b/web/html/xui/form/protocol/vless.html
index 5ccec3fe..82d5424e 100644
--- a/web/html/xui/form/protocol/vless.html
+++ b/web/html/xui/form/protocol/vless.html
@@ -1,56 +1,52 @@
{{define "form/vless"}}
-<a-collapse activeKey="0" v-for="(client, index) in inbound.settings.vlesses.slice(0,1)" v-if="!isEdit">
- <a-collapse-panel header='{{ i18n "pages.inbounds.client" }}'>
- {{template "form/client"}}
- </a-collapse-panel>
+<a-collapse activeKey="0" v-for="(client, index) in inbound.settings.vlesses.slice(0,1)" v-if="!isEdit">
+ <a-collapse-panel header='{{ i18n "pages.inbounds.client" }}'>
+ {{template "form/client"}}
+ </a-collapse-panel>
</a-collapse>
<a-collapse v-else>
- <a-collapse-panel :header="'{{ i18n "pages.client.clientCount"}} : ' + inbound.settings.vlesses.length">
- <table width="100%">
- <tr class="client-table-header">
- <th>{{ i18n "pages.inbounds.email" }}</th>
- <th>Flow</th>
- <th>ID</th>
- </tr>
- <tr v-for="(client, index) in inbound.settings.vlesses" :class="index % 2 == 1 ? 'client-table-odd-row' : ''">
- <td>[[ client.email ]]</td>
- <td>[[ client.flow ]]</td>
- <td>[[ client.id ]]</td>
- </tr>
- </table>
- </a-collapse-panel>
+ <a-collapse-panel :header="'{{ i18n "pages.client.clientCount"}} : ' + inbound.settings.vlesses.length">
+ <table width="100%">
+ <tr class="client-table-header">
+ <th>{{ i18n "pages.inbounds.email" }}</th>
+ <th>Flow</th>
+ <th>ID</th>
+ </tr>
+ <tr v-for="(client, index) in inbound.settings.vlesses" :class="index % 2 == 1 ? 'client-table-odd-row' : ''">
+ <td>[[ client.email ]]</td>
+ <td>[[ client.flow ]]</td>
+ <td>[[ client.id ]]</td>
+ </tr>
+ </table>
+ </a-collapse-panel>
</a-collapse>
<template v-if="inbound.isTcp && !inbound.stream.isReality">
- <a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
- <a-form-item label="Fallbacks">
- <a-button type="primary" size="small" @click="inbound.settings.addFallback()">+</a-button>
- </a-form-item>
- </a-form>
+ <a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
+ <a-form-item label="Fallbacks">
+ <a-button icon="plus" type="primary" size="small" @click="inbound.settings.addFallback()"></a-button>
+ </a-form-item>
+ </a-form>
- <!-- vless fallbacks -->
- <a-form v-for="(fallback, index) in inbound.settings.fallbacks" :colon="false" :label-col="{ md: {span:8} }"
- :wrapper-col="{ md: {span:14} }">
- <a-divider style="margin:0;">
- Fallback [[ index + 1 ]]
- <a-icon type="delete" @click="() => inbound.settings.delFallback(index)"
- style="color: rgb(255, 77, 79);cursor: pointer;" />
- </a-divider>
- <a-form-item label='SNI'>
- <a-input v-model="fallback.name"></a-input>
- </a-form-item>
- <a-form-item label='ALPN'>
- <a-input v-model="fallback.alpn"></a-input>
- </a-form-item>
- <a-form-item label='Path'>
- <a-input v-model="fallback.path"></a-input>
- </a-form-item>
- <a-form-item label='Dest'>
- <a-input v-model="fallback.dest"></a-input>
- </a-form-item>
- <a-form-item label='xVer'>
- <a-input-number v-model="fallback.xver" :min="0" :max="2"></a-input-number>
- </a-form-item>
- </a-form>
- <a-divider style="margin:5px 0;"></a-divider>
+ <!-- vless fallbacks -->
+ <a-form v-for="(fallback, index) in inbound.settings.fallbacks" :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
+ <a-divider style="margin:0;"> Fallback [[ index + 1 ]] <a-icon type="delete" @click="() => inbound.settings.delFallback(index)" style="color: rgb(255, 77, 79);cursor: pointer;"></a-icon>
+ </a-divider>
+ <a-form-item label='SNI'>
+ <a-input v-model="fallback.name"></a-input>
+ </a-form-item>
+ <a-form-item label='ALPN'>
+ <a-input v-model="fallback.alpn"></a-input>
+ </a-form-item>
+ <a-form-item label='Path'>
+ <a-input v-model="fallback.path"></a-input>
+ </a-form-item>
+ <a-form-item label='Dest'>
+ <a-input v-model="fallback.dest"></a-input>
+ </a-form-item>
+ <a-form-item label='xVer'>
+ <a-input-number v-model="fallback.xver" :min="0" :max="2"></a-input-number>
+ </a-form-item>
+ </a-form>
+ <a-divider style="margin:5px 0;"></a-divider>
</template>
{{end}}
diff --git a/web/html/xui/form/protocol/wireguard.html b/web/html/xui/form/protocol/wireguard.html
index a1ac5628..738aaf5f 100644
--- a/web/html/xui/form/protocol/wireguard.html
+++ b/web/html/xui/form/protocol/wireguard.html
@@ -1,80 +1,76 @@
{{define "form/wireguard"}}
<a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
- <a-form-item>
- <template slot="label">
- <a-tooltip>
- <template slot="title">
- <span>{{ i18n "reset" }}</span>
- </template>
- {{ i18n "pages.xray.wireguard.secretKey" }}
- <a-icon type="sync"
- @click="[inbound.settings.pubKey, inbound.settings.secretKey] = Object.values(Wireguard.generateKeypair())">
- </a-icon>
- </a-tooltip>
+ <a-form-item>
+ <template slot="label">
+ <a-tooltip>
+ <template slot="title">
+ <span>{{ i18n "reset" }}</span>
</template>
- <a-input v-model.trim="inbound.settings.secretKey"></a-input>
+ {{ i18n "pages.xray.wireguard.secretKey" }}
+ <a-icon type="sync" @click="[inbound.settings.pubKey, inbound.settings.secretKey] = Object.values(Wireguard.generateKeypair())"></a-icon>
+ </a-tooltip>
+ </template>
+ <a-input v-model.trim="inbound.settings.secretKey"></a-input>
+ </a-form-item>
+ <a-form-item label='{{ i18n "pages.xray.wireguard.publicKey" }}'>
+ <a-input disabled v-model="inbound.settings.pubKey"></a-input>
+ </a-form-item>
+ <a-form-item label='MTU'>
+ <a-input-number v-model.number="inbound.settings.mtu"></a-input-number>
+ </a-form-item>
+ <a-form-item label='Kernel Mode'>
+ <a-switch v-model="inbound.settings.kernelMode"></a-switch>
+ </a-form-item>
+ <a-form-item label="Peers">
+ <a-button icon="plus" type="primary" size="small" @click="inbound.settings.addPeer()"></a-button>
+ </a-form-item>
+ <a-form v-for="(peer, index) in inbound.settings.peers" :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
+ <a-divider style="margin:0;"> Peer [[ index + 1 ]] <a-icon v-if="inbound.settings.peers.length>1" type="delete" @click="() => inbound.settings.delPeer(index)" style="color: rgb(255, 77, 79);cursor: pointer;"></a-icon>
+ </a-divider>
+ <a-form-item>
+ <template slot="label">
+ <a-tooltip>
+ <template slot="title">
+ <span>{{ i18n "reset" }}</span>
+ </template>
+ {{ i18n "pages.xray.wireguard.secretKey" }}
+ <a-icon @click="[peer.publicKey, peer.privateKey] = Object.values(Wireguard.generateKeypair())" type="sync"></a-icon>
+ </a-tooltip>
+ </template>
+ <a-input v-model.trim="peer.privateKey"></a-input>
</a-form-item>
- <a-form-item label='{{ i18n "pages.xray.wireguard.publicKey" }}'>
- <a-input disabled v-model="inbound.settings.pubKey"></a-input>
+ <a-form-item>
+ <template slot="label">
+ {{ i18n "pages.xray.wireguard.publicKey" }}
+ </template>
+ <a-input v-model.trim="peer.publicKey"></a-input>
</a-form-item>
- <a-form-item label='MTU'>
- <a-input-number v-model.number="inbound.settings.mtu"></a-input-number>
+ <a-form-item>
+ <template slot="label">
+ <a-tooltip>
+ <template slot="title">
+ <span>{{ i18n "reset" }}</span>
+ </template>
+ {{ i18n "pages.xray.wireguard.psk" }}
+ <a-icon @click="peer.psk = Wireguard.keyToBase64(Wireguard.generatePresharedKey())" type="sync"></a-icon>
+ </a-tooltip>
+ </template>
+ <a-input v-model.trim="peer.psk"></a-input>
</a-form-item>
- <a-form-item label='Kernel Mode'>
- <a-switch v-model="inbound.settings.kernelMode"></a-switch>
+ <a-form-item>
+ <template slot="label">
+ {{ i18n "pages.xray.wireguard.allowedIPs" }}
+ <a-button icon="plus" type="primary" size="small" @click="peer.allowedIPs.push('')"></a-button>
+ </template>
+ <template v-for="(aip, index) in peer.allowedIPs" style="margin-bottom: 10px;">
+ <a-input v-model.trim="peer.allowedIPs[index]">
+ <a-button icon="minus" v-if="peer.allowedIPs.length>1" slot="addonAfter" size="small" @click="peer.allowedIPs.splice(index, 1)"></a-button>
+ </a-input>
+ </template>
</a-form-item>
- <a-form-item label="Peers">
- <a-button type="primary" size="small" @click="inbound.settings.addPeer()">+</a-button>
+ <a-form-item label='Keep Alive'>
+ <a-input-number v-model.number="peer.keepAlive" :min="0"></a-input-number>
</a-form-item>
- <a-form v-for="(peer, index) in inbound.settings.peers" :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
- <a-divider style="margin:0;">
- Peer [[ index + 1 ]]
- <a-icon v-if="inbound.settings.peers.length>1" type="delete" @click="() => inbound.settings.delPeer(index)"
- style="color: rgb(255, 77, 79);cursor: pointer;"/>
- </a-divider>
- <a-form-item>
- <template slot="label">
- <a-tooltip>
- <template slot="title">
- <span>{{ i18n "reset" }}</span>
- </template>
- {{ i18n "pages.xray.wireguard.secretKey" }}
- <a-icon @click="[peer.publicKey, peer.privateKey] = Object.values(Wireguard.generateKeypair())"type="sync"> </a-icon>
- </a-tooltip>
- </template>
- <a-input v-model.trim="peer.privateKey"></a-input>
- </a-form-item>
- <a-form-item>
- <template slot="label">
- {{ i18n "pages.xray.wireguard.publicKey" }}
- </template>
- <a-input v-model.trim="peer.publicKey"></a-input>
- </a-form-item>
- <a-form-item>
- <template slot="label">
- <a-tooltip>
- <template slot="title">
- <span>{{ i18n "reset" }}</span>
- </template>
- {{ i18n "pages.xray.wireguard.psk" }}
- <a-icon @click="peer.psk = Wireguard.keyToBase64(Wireguard.generatePresharedKey())"type="sync"> </a-icon>
- </a-tooltip>
- </template>
- <a-input v-model.trim="peer.psk"></a-input>
- </a-form-item>
- <a-form-item>
- <template slot="label">
- {{ i18n "pages.xray.wireguard.allowedIPs" }} <a-button type="primary" size="small" @click="peer.allowedIPs.push('')">+</a-button>
- </template>
- <template v-for="(aip, index) in peer.allowedIPs" style="margin-bottom: 10px;">
- <a-input v-model.trim="peer.allowedIPs[index]">
- <a-button v-if="peer.allowedIPs.length>1" slot="addonAfter" size="small" @click="peer.allowedIPs.splice(index, 1)">-</a-button>
- </a-input>
- </template>
- </a-form-item>
- <a-form-item label='Keep Alive'>
- <a-input-number v-model.number="peer.keepAlive" :min="0"></a-input>
- </a-form-item>
- </a-form>
+ </a-form>
</a-form>
{{end}} \ No newline at end of file