Browse Source

хочеться сдохнуть

master
gsd 1 year ago
parent
commit
84bac6bedc
  1. 2
      src/App.vue
  2. 11
      src/api/GlobalApi.js
  3. 4
      src/api/Stages.js
  4. 130
      src/components/ActionDialogs/AdminDialog.vue
  5. 0
      src/components/ActionDialogs/ReportView.vue
  6. 1
      src/components/Others/Loader/LoaderPage.vue
  7. 12
      src/components/Others/Loader/ProfileViewer.vue
  8. 5
      src/components/TabsMenuElements/ServersView/Components/PlayerExtendedInfo.vue
  9. 2
      src/components/TabsMenuElements/ServersView/Components/ServerCard.vue

2
src/App.vue

@ -27,6 +27,7 @@ import MdSteppers from "vue-material/dist/components/MdSteppers";
import MdTable from "vue-material/dist/components/MdTable"; import MdTable from "vue-material/dist/components/MdTable";
import MdContent from "vue-material/dist/components/MdContent"; import MdContent from "vue-material/dist/components/MdContent";
import MdRipple from "vue-material/dist/components/MdRipple"; import MdRipple from "vue-material/dist/components/MdRipple";
import MdSwitch from "vue-material/dist/components/MdSwitch";
Vue.use(MdTabs); Vue.use(MdTabs);
Vue.use(MdIcon); Vue.use(MdIcon);
@ -43,6 +44,7 @@ Vue.use(MdSteppers);
Vue.use(MdTable); Vue.use(MdTable);
Vue.use(MdContent); Vue.use(MdContent);
Vue.use(MdRipple); Vue.use(MdRipple);
Vue.use(MdSwitch);
import TabsMenu from "@/components/TabsMenu.vue"; import TabsMenu from "@/components/TabsMenu.vue";
import LoaderPage from "@/components/Others/Loader/LoaderPage.vue"; import LoaderPage from "@/components/Others/Loader/LoaderPage.vue";

11
src/api/GlobalApi.js

@ -119,17 +119,18 @@ export default class GlobalApi {
async load() { async load() {
this.loading = true; this.loading = true;
document.title = `Загрузка - Факты 13`; document.title = `Загрузка - Факты 13`;
await Promise.all( let need2load = [
[this.fillThis('statistic'), this.fillThis('statistic'),
this.fillThis('uniq'), this.fillThis('uniq'),
this.fillThis('donate'), this.fillThis('donate'),
this.fillServers(), this.fillServers(),
this.admin.load(this.load_stages),
this.player.load(this.load_stages),
this.vip.getVipPrices(this.load_stages), this.vip.getVipPrices(this.load_stages),
this.vip.getVipStatistic(this.load_stages), this.vip.getVipStatistic(this.load_stages),
this.admin.load(this.load_stages),
this.player.load(this.load_stages),
this.fillOther()] this.fillOther()]
).then(() => { this.load_stages.count_stages = need2load.length;
await Promise.all(need2load).then(() => {
console.log("[Loader] success end"); console.log("[Loader] success end");
this.loading = false; this.loading = false;
document.title = `Факты 13`; document.title = `Факты 13`;

4
src/api/Stages.js

@ -1,5 +1,6 @@
export default class Stages { export default class Stages {
stages = []; stages = [];
count_stages = 0;
add(s) { add(s) {
this.stages.push(s) this.stages.push(s)
@ -18,11 +19,12 @@ export default class Stages {
case 'vip prices': return 'курс рубля к лаймовой краске...'; case 'vip prices': return 'курс рубля к лаймовой краске...';
case 'vip statistic': return 'переводим деньги на СВО...'; case 'vip statistic': return 'переводим деньги на СВО...';
case 'profile': return 'виталик ищет тебя...'; case 'profile': return 'виталик ищет тебя...';
case 'donate': return 'отправляем деньги на СВО...';
default: return s; default: return s;
} }
} }
percent() { percent() {
return 100 - this.stages.length * 100 / 5; return this.stages.length * 100 / this.count_stages;
} }
} }

130
src/components/ActionDialogs/AdminDialog.vue

@ -0,0 +1,130 @@
<template>
<md-dialog :md-active.sync="active" @close="active=false" v-if="steam64!==null">
<div class="md-layout md-alignment-bottom-center rounded-only">
<md-card class="md-layout-item md-small-size-100" v-if="current_mode===1">
<md-card-header>
<div class="md-title" style="display: inline;">Забанить игрока</div>
</md-card-header>
<md-card-content>
<div class="md-layout md-gutter">
<div class="md-layout-item md-small-size-100">
<md-field>
<label for="ban_reason">Причина</label>
<md-input name="ban_reason" v-model="payload.ban_reason" :disabled="sending" />
<span class="md-error" v-if="payload.ban_reason<3">Нужна объективная причина</span>
</md-field>
</div>
</div>
<div class="md-layout md-gutter">
<div class="md-layout-item md-small-size-100">
<md-field>
<label for="ban_reason">Длина бана в минутах</label>
<md-input type="number" name="ban_reason" v-model="payload.ban_length" :disabled="sending" />
<span class="md-error" v-if="payload.ban_length<0">Ты не можешь забанить в отрицалово</span>
</md-field>
</div>
</div>
<p v-if="response.length>0" style="font-family: tf2secondary; color: black">Ответ: {{response}}</p>
<md-button v-on:click="toBan()" style="float: left;background-color: #bd2200; color: black; font-family: tf2build">Забанить</md-button>
<md-button v-on:click="payload.ban_length = 0" style="float: left;background-color: #fd8846; color: black; font-family: tf2build">Навсегда</md-button>
<md-button v-on:click="showMe(false)" style="float: right;background-color: #46fd4f; color: black; font-family: tf2build">Закрыть</md-button>
</md-card-content>
</md-card>
<!---->
<md-card class="md-layout-item md-small-size-100" v-if="current_mode===2">
<md-card-header>
<div class="md-title" style="display: inline;">Разбанить игрока</div>
</md-card-header>
<md-card-content>
<p v-if="response.length>0" style="font-family: tf2secondary; color: black">Ответ: {{response}}</p>
<md-button v-on:click="toUnBan()" style="float: left;background-color: #bd2200; color: black; font-family: tf2build">Разбанить</md-button>
<md-button v-on:click="showMe(false)" style="float: right;background-color: #46fd4f; color: black; font-family: tf2build">Закрыть</md-button>
</md-card-content>
</md-card>
<!---->
<md-card class="md-layout-item md-small-size-100" v-if="current_mode===3">
<md-card-header>
<div class="md-title" style="display: inline;">Кикнуть игрока</div>
</md-card-header>
<md-card-content>
<div class="md-layout md-gutter">
<div class="md-layout-item md-small-size-100">
<md-field>
<label for="ban_reason">Причина</label>
<md-input name="ban_reason" v-model="payload.ban_reason" :disabled="sending" />
<span class="md-error" v-if="payload.ban_reason<3">Нужна объективная причина</span>
</md-field>
</div>
</div>
<p v-if="response.length>0" style="font-family: tf2secondary; color: black">Ответ: {{response}}</p>
<md-button v-on:click="toKick()" style="float: left;background-color: #579af1; color: black; font-family: tf2build">Кикнуть</md-button>
<md-button v-on:click="showMe(false)" style="float: right;background-color: #46fd4f; color: black; font-family: tf2build">Закрыть</md-button>
</md-card-content>
</md-card>
</div>
</md-dialog>
</template>
<script>
import axios from "axios";
export default {
name: "AdminDialog",
props: {
steam64: String,
},
data: () => ({
active: false,
payload: {
ban_length:0,
ban_reason:"без причины"
},
sending: false,
response: "",
current_mode: 0
}),
methods: {
showMe(b, m) {this.response="";this.active = b;this.current_mode =m},
toBan() {
this.sending = true;
this.response = "Отправляем...";
axios.post(`/api/admin/ban?steam64=${this.steam64}&ban_length=${this.payload.ban_length}&ban_reason=${this.payload.ban_reason}`)
.then((response) => {
switch (response.status) {
case 201: {this.response=`Успешно забанен, ид #${response.data}`;break;}
case 202: {this.response=`Уже в бане, ид #${response.data}`;break;}
case 406: {this.response="Тот кого ты пытаешься забанить, круче тебя";break;}
default: {this.response="Куда ты лезишь мудоеб, не для тебя это";break;}
}
}).catch(()=>{})
.finally(()=>{this.sending = false;})
},
toUnBan(){
this.sending = true;
this.response = "Отправляем...";
axios.post(`/api/admin/unban?steam64=${this.steam64}`)
.then((response) => {
switch (response.status) {
case 200: {this.response=`Игрок разбанен!`;break;}
case 404: {this.response=`Этот игрок не в бане!!!`;break;}
case 406: {this.response="Этого игрока забанил админ который круче тебя!";break;}
default: {this.response="Куда ты лезишь мудоеб, не для тебя это";break;}
}
}).catch(()=>{})
.finally(()=>{this.sending = false;})
},
toKick(){
this.sending = true;
this.response = "Отправляем...";
axios.post(`/api/admin/kick?steam64=${this.steam64}&reason=${this.payload.ban_reason}`)
.then((response) => {
switch (response.status) {
case 200: {this.response=`Игрок был кикнут!`;break;}
case 404: {this.response=`Такого игрока нет на серверах!`;break;}
default: {this.response="Куда ты лезишь мудоеб, не для тебя это";break;}
}
}).catch(()=>{})
.finally(()=>{this.sending = false;})
}
},
}
</script>

0
src/components/Others/ReportView.vue → src/components/ActionDialogs/ReportView.vue

1
src/components/Others/Loader/LoaderPage.vue

@ -2,6 +2,7 @@
<md-dialog :md-active.sync="this.l" class="bbb"> <md-dialog :md-active.sync="this.l" class="bbb">
<md-progress-spinner :md-diameter="200" :md-stroke="10" md-mode="indeterminate"/> <md-progress-spinner :md-diameter="200" :md-stroke="10" md-mode="indeterminate"/>
<h1 style="color: #fd8846; text-align: center">Загрузка</h1> <h1 style="color: #fd8846; text-align: center">Загрузка</h1>
<h3 style="color: #fd8846; text-align: center">{{100 - (this.$API.load_stages.stages.length * 100 / this.$API.load_stages.count_stages).toFixed(0)}}%</h3>
<p v-for="stage in this.$API.load_stages.stages" :key="stage" style="text-align: center; margin: 0%">{{$API.load_stages.human(stage)}}</p> <p v-for="stage in this.$API.load_stages.stages" :key="stage" style="text-align: center; margin: 0%">{{$API.load_stages.human(stage)}}</p>
</md-dialog> </md-dialog>
</template> </template>

12
src/components/Others/Loader/ProfileViewer.vue

@ -5,12 +5,14 @@
<h1 v-if="loading">Загрузка</h1> <h1 v-if="loading">Загрузка</h1>
<ProfileContainer v-else :player="player"/> <ProfileContainer v-else :player="player"/>
<hr width="100%"> <hr width="100%">
<md-button v-if="!loading && this.$API.admin.permition.kick" class="md-raised" style="color: #131213; font-family: tf2build; background: darkcyan">кикнуть</md-button> <md-button v-if="!loading && this.$API.admin.permition.kick && player!==null && 'play_on' in player && player['play_on'] !== null" class="md-raised" style="color: #131213; font-family: tf2build; background: darkcyan" v-on:click="$refs.ad.showMe(true, 3)">кикнуть</md-button>
<md-button v-if="!loading && this.$API.admin.permition.ban" class="md-raised" style="color: #131213; font-family: tf2build; background: brown">забанить</md-button> <md-button v-if="!loading && this.$API.admin.permition.ban && player!==null && 'ban' in player && player['ban'] === null" class="md-raised" style="color: #131213; font-family: tf2build; background: brown" v-on:click="$refs.ad.showMe(true, 1)">забанить</md-button>
<md-button v-if="!loading && this.$API.admin.permition.mute" style="color: #131213; font-family: tf2build; background: lightgreen">замьютить</md-button> <md-button v-if="!loading && this.$API.admin.permition.ban && player!==null && 'ban' in player && player['ban'] !== null" class="md-raised" style="color: #131213; font-family: tf2build; background: #21ff00" v-on:click="$refs.ad.showMe(true, 2)">разбанить</md-button>
<!--<md-button v-if="!loading && this.$API.admin.permition.mute" style="color: #131213; font-family: tf2build; background: lightgreen">замьютить</md-button>-->
<md-button v-if="!loading" v-on:click="showProfileDialog=false" style="background-color: #fd8846; font-family: tf2build;color: black; float: right">Закрыть</md-button> <md-button v-if="!loading" v-on:click="showProfileDialog=false" style="background-color: #fd8846; font-family: tf2build;color: black; float: right">Закрыть</md-button>
</div> </div>
</div> </div>
<AdminDialog :steam64 = "steam64" ref="ad"/>
</md-dialog> </md-dialog>
</template> </template>
@ -18,10 +20,11 @@
import ProfileContainer from "@/components/TabsMenuElements/ProfileView/Components/ProfileContainer.vue"; import ProfileContainer from "@/components/TabsMenuElements/ProfileView/Components/ProfileContainer.vue";
import axios from "axios"; import axios from "axios";
import {PLAYER_REQUESTS} from "@/api/PlayerApi"; import {PLAYER_REQUESTS} from "@/api/PlayerApi";
import AdminDialog from "@/components/ActionDialogs/AdminDialog.vue";
export default { export default {
name: "ProfileViewer", name: "ProfileViewer",
components: {ProfileContainer}, components: {AdminDialog, ProfileContainer},
props: { props: {
steam64: String steam64: String
}, },
@ -32,7 +35,6 @@ export default {
}), }),
methods: { methods: {
getPlayer() { getPlayer() {
console.log(this.steam64.length);
if (this.steam64.length === 0) return; if (this.steam64.length === 0) return;
this.showProfileDialog = true; this.showProfileDialog = true;
this.loading = true; this.loading = true;

5
src/components/TabsMenuElements/ServersView/Components/PlayerExtendedInfo.vue

@ -30,9 +30,6 @@
</div> </div>
<div style="justify-content: center; display: flex; margin-top: 0%"> <div style="justify-content: center; display: flex; margin-top: 0%">
<md-button class="md-raised" v-if="showPlayerDialog && this.$API.player.success_auth" style="color: #131213; font-family: tf2build; background: #fd8846" v-on:click="$refs.rv.showRV(true)">Репорт</md-button> <md-button class="md-raised" v-if="showPlayerDialog && this.$API.player.success_auth" style="color: #131213; font-family: tf2build; background: #fd8846" v-on:click="$refs.rv.showRV(true)">Репорт</md-button>
<md-button v-if="showPlayerDialog && this.$API.admin.permition.kick" class="md-raised" style="color: #131213; font-family: tf2build; background: darkcyan">кикнуть</md-button>
<md-button v-if="showPlayerDialog && this.$API.admin.permition.ban" class="md-raised" style="color: #131213; font-family: tf2build; background: brown">забанить</md-button>
<md-button v-if="showPlayerDialog && this.$API.admin.permition.mute" style="color: #131213; font-family: tf2build; background: lightgreen">замьютить</md-button>
<md-button v-if="showPlayerDialog && this.$API.player.success_auth" style="color: #131213; font-family: tf2build; background: #fdecc1" v-on:click="showProfile()">информация</md-button> <md-button v-if="showPlayerDialog && this.$API.player.success_auth" style="color: #131213; font-family: tf2build; background: #fdecc1" v-on:click="showProfile()">информация</md-button>
</div> </div>
</div> </div>
@ -44,7 +41,7 @@
<script> <script>
import ProfileViewer from "@/components/Others/Loader/ProfileViewer.vue"; import ProfileViewer from "@/components/Others/Loader/ProfileViewer.vue";
import ReportView from "@/components/Others/ReportView.vue"; import ReportView from "@/components/ActionDialogs/ReportView.vue";
export default { export default {
name: 'PlayerExtendedInfo', name: 'PlayerExtendedInfo',

2
src/components/TabsMenuElements/ServersView/Components/ServerCard.vue

@ -44,7 +44,7 @@ export default {
}), }),
methods: { methods: {
openServerFullInfo() { openServerFullInfo() {
console.log("Open server full info"); console.log("[ServerCard] Open server full info");
if (this.serverData['status'] === true) this.$refs.ssd.openFIF(); if (this.serverData['status'] === true) this.$refs.ssd.openFIF();
else alert("сервер мертв, нелезь на него"); else alert("сервер мертв, нелезь на него");
}, },

Loading…
Cancel
Save