9 changed files with 215 additions and 11 deletions
@ -0,0 +1,23 @@ |
|||||
|
import axios from "axios"; |
||||
|
|
||||
|
export default { |
||||
|
name: 'AdminApi', |
||||
|
data: () => ({ |
||||
|
allowBan: false |
||||
|
}), |
||||
|
checkAllowBan() { |
||||
|
return axios.options("/api/admin/ban") |
||||
|
.then(response => { |
||||
|
return response.status === 200; |
||||
|
}) |
||||
|
.catch((err) => { |
||||
|
return err.response.status === 200 |
||||
|
}); |
||||
|
}, |
||||
|
async serverPrefetch() { |
||||
|
this.checkAllowBan().then((r) => { |
||||
|
console.log("[AdminApi] allow ban: " + r); |
||||
|
this.allowBan = true; |
||||
|
}) |
||||
|
} |
||||
|
} |
@ -0,0 +1,10 @@ |
|||||
|
<template> |
||||
|
<svg height="60%" version="1.1" viewBox="0 0 124 132" width="512px" xmlns="http://www.w3.org/2000/svg"> |
||||
|
<path fill="currentColor" d="M99.1,113.7c2.6,0,4.7-2.1,4.7-4.7V79.9h11.2v29.8c0,8.4-6.8,15.2-15.2,15.2H18.5c-8.4,0-15.2-6.8-15.2-15.2V79.9h11.2V109 c0,2.6,2.1,4.7,4.7,4.7H99.1L99.1,113.7z M37.1,17.7h43.9V57h16.8L59.1,94.8L20.4,57h16.8V17.7L37.1,17.7z"/><rect class="st2" height="132" id="_x3C_Slice_x3E__100_" width="124"/></svg> |
||||
|
</template> |
||||
|
|
||||
|
<script> |
||||
|
export default { |
||||
|
name: "DownloadSvg" |
||||
|
} |
||||
|
</script> |
@ -0,0 +1,53 @@ |
|||||
|
<template> |
||||
|
<svg version="1.1" id="Capa_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" |
||||
|
width="512px" height="60%" viewBox="0 0 512 512" style="enable-background:new 0 0 512 512;" xml:space="preserve"> |
||||
|
<g> |
||||
|
<path fill="currentColor" d="M151.961,418.005c13.572,0,26.893-6.567,34.986-18.708c12.867-19.301,7.651-45.377-11.649-58.244l-33.037-22.022 |
||||
|
c5.654-1.54,11.597-2.38,17.739-2.38c37.196,0,67.348,30.152,67.348,67.351s-30.153,67.349-67.349,67.349 |
||||
|
c-36.202,0-65.722-28.564-67.274-64.387l35.977,23.984C135.863,415.721,143.955,418.005,151.961,418.005z M426.67,0 |
||||
|
C473.607,0,512,38.406,512,85.344v341.314C512,473.626,473.607,512,426.67,512H85.344C38.406,512,0,473.625,0,426.659V325.145 |
||||
|
l60.667,40.444c-5.826,31.587,3.469,65.415,27.899,89.845c39.452,39.452,103.415,39.452,142.868,0 |
||||
|
c24.234-24.231,33.575-57.715,28.039-89.082L384,254.858v-0.001c23.123-3.319,45.408-13.872,63.197-31.661 |
||||
|
c43.736-43.738,43.736-114.653,0-158.392c-43.74-43.739-114.654-43.739-158.393,0c-17.789,17.789-28.344,40.073-31.662,63.196l0,0 |
||||
|
L154.796,283.115c-15.924,0.816-31.689,5.382-45.863,13.695L0,224.189V85.344C0,38.406,38.405,0,85.343,0H426.67z M448,144 |
||||
|
c0-44.183-35.816-80-80-80s-80,35.817-80,80s35.816,80,80,80S448,188.183,448,144z M320,144c0-26.51,21.49-48,48-48s48,21.49,48,48 |
||||
|
s-21.49,48-48,48S320,170.51,320,144z"/> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
<g> |
||||
|
</g> |
||||
|
</svg> |
||||
|
</template> |
||||
|
|
||||
|
<script> |
||||
|
export default { |
||||
|
name: "SteamSvg" |
||||
|
} |
||||
|
</script> |
@ -0,0 +1,11 @@ |
|||||
|
<template> |
||||
|
<svg xmlns="http://www.w3.org/2000/svg" width="512px" height="60%" focusable="false" viewBox="0 0 12 12"> |
||||
|
<path fill="currentColor" d="M11 1H1c-.55 0-1 .45-1 1v8c0 .55.45 1 1 1h10c.55 0 1-.45 1-1V2c0-.55-.45-1-1-1zM2.5 9.12a.62.62 0 01-.44-.18.628.628 0 010-.88L4.12 6 2.06 3.94c-.24-.24-.24-.64 0-.88s.64-.24.88 0L5.09 5.2c.44.44.44 1.15 0 1.59L2.94 8.94a.62.62 0 01-.44.18zm7-.12h-4c-.28 0-.5-.22-.5-.5s.22-.5.5-.5h4c.28 0 .5.22.5.5s-.22.5-.5.5z"/> |
||||
|
</svg> |
||||
|
</template> |
||||
|
|
||||
|
<script> |
||||
|
export default { |
||||
|
name: 'TerminalSvg' |
||||
|
} |
||||
|
</script> |
@ -0,0 +1,76 @@ |
|||||
|
<template> |
||||
|
<md-dialog :md-active.sync="showPlayerDialog"> |
||||
|
<div class="md-layout md-alignment-bottom-center" style="z-index: 1"> |
||||
|
<div class="md-layout-item md-size-5"/> |
||||
|
<div class="md-layout-item rounded-and-colored md-size-60" style="min-width: 35em"> |
||||
|
<h3 style="text-align: center; margin: 2% 0%; max-height: 30em" class="h3-player">{{player['name']}}</h3> |
||||
|
</div> |
||||
|
<div class="md-layout-item rounded-and-colored-circle md-size-5" v-on:click="closePEI()" style="min-width: 3em"> |
||||
|
<h3 style="text-align: center; margin: 25% 0%">X</h3> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="md-layout md-alignment-bottom-center" style="margin-top: -3.5%;"> |
||||
|
<div class="md-layout-item md-size-65 server-info-rounded" style="min-width: 40em"> |
||||
|
<div style="margin-top: 5%; text-align: center"> |
||||
|
<a :href="player['steam']['community_url']" target="_blank" class="a-player">Открыть профиль Steam</a> |
||||
|
</div> |
||||
|
<div style="justify-content: center; display: flex; margin-top: 0%"> |
||||
|
<div style="max-width: 45%; float: left; margin-right: 5%"> |
||||
|
<p class="p-player">Очки: {{player['score']}}</p> |
||||
|
<p class="p-player">Время игры: {{player['duration']}}</p> |
||||
|
<p class="p-player">Пинг: {{player['ping']}} мс</p> |
||||
|
<p class="p-player">Потери пакетов: {{player['loss']}}</p> |
||||
|
</div> |
||||
|
<div style="max-width: 45%; float: left;"> |
||||
|
<p class="p-player">ID на сервере: {{player['id']}}</p> |
||||
|
<p class="p-player">Steam64: {{player['steam']['steam64']}}</p> |
||||
|
<p class="p-player">Steam3: {{player['steam']['steam3']}}</p> |
||||
|
<p class="p-player">Steam2: {{player['steam']['steam2']}}</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div style="justify-content: center; display: flex; margin-top: 0%"> |
||||
|
<md-button class="md-raised" style="color: #131213; font-family: tf2build; background: #fd8846">РЕПОРТ</md-button> |
||||
|
<md-button v-if="showPlayerDialog && allowKick" class="md-raised" style="color: #131213; font-family: tf2build; background: darkcyan">кикнуть</md-button> |
||||
|
<md-button v-if="showPlayerDialog && allowBan" class="md-raised" style="color: #131213; font-family: tf2build; background: brown">забанить</md-button> |
||||
|
<md-button v-if="showPlayerDialog && allowMute" class="md-raised" style="color: #131213; font-family: tf2build; background: lightgreen">замьютить</md-button> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</md-dialog> |
||||
|
</template> |
||||
|
|
||||
|
<script> |
||||
|
import AdminApi from "@/api/AdminApi"; |
||||
|
export default { |
||||
|
name: 'PlayerExtendedInfo', |
||||
|
props: { |
||||
|
player: Object |
||||
|
}, |
||||
|
data: () => ({ |
||||
|
showPlayerDialog: false, |
||||
|
allowBan: AdminApi.data().allowBan, |
||||
|
allowMute: false, |
||||
|
allowKick: false |
||||
|
}), |
||||
|
methods: { |
||||
|
closePEI() { |
||||
|
this.showPlayerDialog = false; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
</script> |
||||
|
|
||||
|
<style> |
||||
|
.a-player { |
||||
|
text-align: center; font-size: 2em; color: #131213; |
||||
|
} |
||||
|
|
||||
|
.h3-player { |
||||
|
line-height: 1em; |
||||
|
} |
||||
|
|
||||
|
.p-player { |
||||
|
color: #131213; |
||||
|
font-size: 1.2em; |
||||
|
} |
||||
|
</style> |
Loading…
Reference in new issue