2018-01-28 18:40:49 +02:00
< ? php
ob_start ( " ob_gzhandler " );
2018-03-03 13:50:13 +02:00
session_start ();
2020-08-30 02:21:22 +03:00
if ( empty ( $_SESSION [ 'uid' ])) {
header ( " Location: index.php " );
2020-09-30 17:19:55 +03:00
exit ;
2020-08-30 02:21:22 +03:00
}
2018-03-03 13:50:13 +02:00
include_once 'functions.php' ;
2020-08-30 02:21:22 +03:00
if ( ! $user -> clan ) {
2020-09-30 15:01:33 +03:00
exit ( err ( 'Вы не состоите в клане!' ));
2018-03-03 13:50:13 +02:00
}
2020-08-30 02:21:22 +03:00
try {
2020-08-30 03:55:53 +03:00
$clanRow = db :: c () -> query ( 'SELECT * FROM `clans` WHERE `id` = ?i' , $user -> clan ) -> fetch_assoc ();
2020-08-30 02:21:22 +03:00
$polno = unserialize ( $clanRow [ 'vozm' ]) ? ? [];
} catch ( Exception $e ) {
echo " MYSQL_ERROR: Таблицы clans не существует! Вся панель — одна сплошная ошибка! " ;
}
define ( 'COST_ADD_MEMBER' , 100 );
define ( 'COST_REMOVE_MEMBER' , 30 );
define ( 'CASTLE_REPUTATION_NEEDED' , 1000000 );
define ( 'CASTLE_COST' , 25000 );
$status = null ;
$action = $_POST [ 'action' ] ? ? 0 ;
$login = $_POST [ 'login' ] ? ? 0 ;
$zamok = $_POST [ 'zamok' ] ? ? null ;
$kr = $_POST [ 'kr' ] ? ? null ;
$kolv = $_POST [ 'kolv' ] ? ? null ;
$newClanStatus = $_POST [ 'new_status' ] ? ? null ;
$vin = $_POST [ 'vin' ] ? ? null ;
$tus = $_POST [ 'tus' ] ? ? null ;
2019-06-21 00:48:46 +03:00
2020-08-30 02:21:22 +03:00
if ( $zamok ) {
2019-06-21 00:48:46 +03:00
db :: c () -> query ( 'UPDATE `clans` SET `zamok` = 1 WHERE `glava` = ?i' , $_SESSION [ 'uid' ]);
$status = " Начат сбор средств на строительство Кланового Замка. " ;
2019-06-21 17:35:09 +03:00
header ( " Location: clan.php " );
2019-06-21 00:48:46 +03:00
}
2020-08-30 02:21:22 +03:00
if ( $kr && $kolv > 0 ) {
if ( $user -> money >= $kolv ) {
db :: c () -> query ( 'UPDATE `clans` SET `zbor` = `zbor` + ?i WHERE `id` = ?i' , $kolv , $user -> clan );
db :: c () -> query ( 'UPDATE `users` SET `money` = `money` - ?i WHERE `id` = ?i' , $kolv , $user -> id );
2019-06-21 17:35:09 +03:00
header ( " Location: clan.php " );
2020-08-30 02:21:22 +03:00
} else {
$status = 'Не хватает денег!' ;
}
2019-06-21 00:48:46 +03:00
}
2020-08-30 03:55:53 +03:00
if ( $login && $action == 'add_member' && $polno [ $user -> id ][ 0 ] == 1 ) {
2020-08-30 02:21:22 +03:00
$sok = db :: c () -> query ( 'SELECT id, level, clan FROM users WHERE align = 0 AND login = "?s"' , $login ) -> fetch_assoc ();
$proverka = db :: c () -> query ( 'SELECT 1 FROM users_effects WHERE type = 20 AND owner_id = ?i' , $sok [ 'id' ]) -> getNumRows ();
if ( ! $proverka ) {
echo " Нет проверки! " ;
} elseif ( $sok [ 'clan' ]) {
echo 'Персонаж уже состоит в клане!' ;
} elseif ( $sok [ 'level' ] > 0 && $user -> money >= COST_ADD_MEMBER ) {
db :: c () -> query ( 'UPDATE users SET money = money - ?i WHERE `id` = ?i' , COST_ADD_MEMBER , $_SESSION [ 'uid' ]);
db :: c () -> query ( 'UPDATE users SET clan = "?s", align = ?i WHERE id = ?i' , $clanRow [ 'id' ], $clanRow [ 'align' ], $sok [ 'id' ]);
2019-06-22 17:10:37 +03:00
$status = 'Персонаж «' . $login . '» успешно принят в клан.' ;
2020-08-30 02:21:22 +03:00
} else {
$status = 'Не хватает денег, или персонажа не существует.' ;
}
2019-06-21 02:37:39 +03:00
}
2020-08-30 03:55:53 +03:00
if ( $login && $action == 'remove_member' && $polno [ $user -> id ][ 0 ] == 1 ) {
2020-08-30 02:21:22 +03:00
$sok = db :: c () -> query ( 'SELECT id FROM users WHERE clan = "?s" AND login = "?s"' , $clanRow [ 'id' ], $login ) -> fetch_assoc ();
if ( $sok [ 'id' ] != $clanRow [ 'glava' ] && $user -> money >= COST_REMOVE_MEMBER ) {
db :: c () -> query ( 'UPDATE users SET money = money - ?i WHERE id = ?i' , COST_REMOVE_MEMBER , $_SESSION [ 'uid' ]);
db :: c () -> query ( 'UPDATE users SET clan = "?s", align = 0 WHERE id = ?i' , '' , $sok [ 'id' ]);
2019-06-22 17:10:37 +03:00
$status = 'Персонаж «' . $login . '» покинул клан.' ;
2019-06-21 02:37:39 +03:00
}
}
2020-08-30 02:21:22 +03:00
if ( $login && $action == 'change_owner' && $clanRow [ 'glava' ] == $_SESSION [ 'uid' ]) {
$sok = db :: c () -> query ( 'SELECT id FROM users WHERE clan = "?s" AND login = "?s"' , $clanRow [ 'id' ], $login ) -> fetch_assoc ();
db :: c () -> query ( 'UPDATE clans SET glava = ?i WHERE id = ?i' , $sok [ 'id' ], $clanRow [ 'id' ]);
db :: c () -> query ( 'UPDATE users SET status = "?s" WHERE id = ?i' , '' , $sok [ 'id' ]);
db :: c () -> query ( 'UPDATE users SET status = "?s" WHERE id = ?i' , 'Боец' , $_SESSION [ 'uid' ]);
$clanRow [ 'glava' ] = $sok [ 'id' ];
2019-06-21 02:37:39 +03:00
}
2020-08-30 02:21:22 +03:00
if ( $login && $action == 'edit_status' ) {
$sok = db :: c () -> query ( 'SELECT id, status FROM users WHERE clan = "?s" AND login = "?s"' , $clanRow [ 'id' ], $login ) -> fetch_assoc ();
if ( $sok [ 'id' ] != $clanRow [ 'glava' ]) {
if ( $newClanStatus ) {
$st = strip_tags ( str_replace ( " < " , " < " , str_replace ( " > " , " > " , $newClanStatus )), " <B><I><U> " );
db :: c () -> query ( 'UPDATE users SET status = "?s" WHERE id = ?i' , $st , $sok [ 'id' ]);
2019-06-22 17:13:47 +03:00
$sok [ 'status' ] = $st ;
2019-06-22 17:05:14 +03:00
}
2020-08-30 02:21:22 +03:00
if ( $clanRow [ 'glava' ] == $_SESSION [ 'uid' ]) {
if ( $vin ) {
$polno [ $sok [ 'id' ]][ 0 ] = 1 ;
} else {
$polno [ $sok [ 'id' ]][ 0 ] = 0 ;
}
if ( $tus ) {
$polno [ $sok [ 'id' ]][ 1 ] = 1 ;
} else {
$polno [ $sok [ 'id' ]][ 1 ] = 0 ;
}
db :: c () -> query ( 'UPDATE clans SET vozm = "?s" WHERE id = ?i' , serialize ( $polno ), $clanRow [ 'id' ]);
2019-06-22 17:05:14 +03:00
}
2020-08-30 02:21:22 +03:00
} else {
$status = 'Главу клана редактировать запрещено!' ;
}
2019-06-22 17:05:14 +03:00
}
2020-08-30 02:21:22 +03:00
$clan_memberlist = db :: c () -> query ( 'SELECT `id`, `login`, `status`, `level`, `room`, `align`, (select `id` from `online` WHERE `date` >= ?i AND `id` = users.`id`) AS `online` FROM `users` WHERE `klan` = ?i ORDER BY `online` DESC , `login` ASC' , ( time () - 60 ), $clanRow [ 'id' ]);
2020-10-28 22:21:08 +02:00
\Battles\Template :: header ( 'clan' );
2018-01-28 18:40:49 +02:00
?>
2019-06-22 15:49:35 +03:00
<div>
2020-08-30 02:21:22 +03:00
<button onclick="location.href='main.php'">Вернуться</button>
<?php if (!empty($status)) {err($status);} ?>
</div>
2019-06-21 00:48:46 +03:00
<table style="width: 100%">
2018-03-03 13:50:13 +02:00
<tr>
2019-06-22 15:27:35 +03:00
<td>
<p style="width: 50%; vertical-align: top;" rowspan=2>
2020-10-01 01:12:53 +03:00
<h3><img src="./i/clan/<?= $clanRow['short'] ?>.png"><?= $clanRow['name'] ?></h3>
2019-06-22 15:27:35 +03:00
Количество рейтинговых очков клана: <span
2020-08-30 02:21:22 +03:00
style="color: #428f21; font-size: larger;"><?= $clanRow['rating'] ?></span><br>
2019-06-22 13:56:52 +03:00
2020-08-30 03:55:53 +03:00
<?php if ($polno[$user->id][0] == 1): ?>
2019-06-22 13:56:52 +03:00
<div>
<span id="add_member">
<input type="submit" onclick="use('add_member')" value="Принять в клан">
</span>
2020-08-30 02:21:22 +03:00
(стоимость услуги: <B><?= COST_ADD_MEMBER ?></B> кр.)
2019-06-22 13:56:52 +03:00
</div>
<div>
<span id="remove_member">
<input type="submit" onclick="use('remove_member')" value="Выгнать из клана">
</span>
2020-08-30 02:21:22 +03:00
(стоимость услуги: <B><?= COST_REMOVE_MEMBER ?></B> кр.)
2019-06-22 13:56:52 +03:00
</div>
<?php endif; ?>
2020-08-30 03:55:53 +03:00
<?php if ($polno[$user->id][1] == 1 || $clanRow['glava'] == $user->id): ?>
2020-08-30 02:21:22 +03:00
<?php if ($login && $action == 'edit_status' && $sok['id'] != $clanRow['glava']): ?>
2019-06-22 17:05:14 +03:00
<form method='post'>
<input placeholder='Статус' name='new_status'>
2019-06-22 17:10:37 +03:00
<input type="hidden" name="login" value="<?= $login ?>">
2020-08-30 03:55:53 +03:00
<?php if ($clanRow['glava'] == $user->id): ?>
2019-06-22 17:05:14 +03:00
<?php if ($polno[$sok['id']][0] == 1): ?>
<br><input type=checkbox name=vin checked> Может принимать/выгонять членов клана
<?php else: ?>
<br><input type=checkbox name=vin> Может принимать/выгонять членов клана
<?php endif; ?>
<?php if ($polno[$sok['id']][1] == 1): ?>
<br><input type=checkbox name=tus checked> Может менять статус членов клана
<?php else: ?>
<br><input type=checkbox name=tus> Может менять статус членов клана
<?php endif; ?>
<?php endif; ?>
<button name='action' value='edit_status' type='submit'>Ок</button>
<button>× </button>
</form>
<?php else: ?>
<div>
<span id="edit_status">
<input type="submit" onclick="use('edit_status')" value="Редактировать статус">
</span>
</div>
<?php endif; ?>
2019-06-22 13:56:52 +03:00
<?php endif; ?>
2020-08-30 03:55:53 +03:00
<?php if ($clanRow['glava'] == $user->id): ?>
2019-06-22 13:56:52 +03:00
<div>
<span id="change_owner">
<input type="submit" onclick="use('change_owner')" value="Сменить главу клана">
</span>
(сложить с себя полномочия, назначив <b style="color: teal;">Главой Клана</b> другого персонажа)
</div>
2020-08-30 02:21:22 +03:00
<?php if (empty($clanRow['zamok'])): ?>
<?php if ($clanRow['rating'] < CASTLE_REPUTATION_NEEDED): ?>
Недостаточно рейтинга для постройки замка. <?= showProgressBar($clanRow['rating'], CASTLE_REPUTATION_NEEDED) ?>
2019-06-22 15:00:26 +03:00
<?php else: ?>
<form method="post">
<button type="submit" name="zamok" value="zamok">Построить Замок</button>
2020-08-30 02:21:22 +03:00
(собрать силами всего клана <?= CASTLE_COST ?> кр.)<BR>
2019-06-22 15:00:26 +03:00
</form>
<?php endif; ?>
<?php endif; ?>
2019-06-22 13:56:52 +03:00
<?php endif; ?>
2018-03-03 17:52:28 +02:00
2020-08-30 02:21:22 +03:00
<?php if ($clanRow['zamok'] == 1): ?>
2019-06-22 15:26:14 +03:00
<p>
2020-08-30 02:21:22 +03:00
<?php if ($clanRow['zbor'] < CASTLE_COST): ?>
2019-06-22 15:00:26 +03:00
Сбор средств на постройку кланового замка:
2020-08-30 02:21:22 +03:00
<?= showProgressBar($clanRow['zbor'], CASTLE_COST) ?>
2019-06-22 15:20:02 +03:00
<form method="post">
<input name="kolv" size="10">
<button type="submit" name="kr" value="kr">Пожертвовать</button>
</form>
2019-06-22 15:00:26 +03:00
<?php else: ?>
Средства на постройку кланового замка собраны!
2020-08-30 02:21:22 +03:00
<?= showProgressBar(CASTLE_COST, CASTLE_COST) ?>
2019-06-22 15:00:26 +03:00
<?php endif; ?>
<?php endif; ?>
2018-03-03 13:50:13 +02:00
</td>
2019-06-21 18:54:48 +03:00
<td style="vertical-align: top;">
2019-06-21 02:02:30 +03:00
<h3>Соклановцы</h3>
2019-06-22 15:52:55 +03:00
<table class="zebra" style="width: 100%;">
2019-06-22 15:49:35 +03:00
<tr>
<th>Имя</th>
<th>Статус</th>
<th>Местонахождение</th>
</tr>
2019-06-22 15:51:07 +03:00
<?php
while ($row = $clan_memberlist->fetch_assoc()):
2020-08-30 02:21:22 +03:00
if ($row['id'] == $clanRow['glava']) {
$row['status'] = '<b style="color: #008080;">Глава клана</b>';
}
if (empty($row['status'])) {
$row['status'] = 'Боец';
}
if (empty($row['online'])) {
$rrm = 'Персонаж не в игре';
} elseif ($row['room'] > 500 && $row['room'] < 561) {
$rrm = 'Башня смерти';
} else {
$rrm = $rooms[$row['room']];
}
2019-06-22 15:51:07 +03:00
?>
<tr>
2020-08-27 15:17:02 +03:00
<td><?= Nick::id($row['id'])->full() ?></td>
2019-06-22 15:49:35 +03:00
<td><?= $row['status'] ?></td>
<td><i style="font-size: smaller;"><?= $rrm ?></i></td>
2019-06-22 15:51:07 +03:00
</tr>
<?php endwhile; ?>
2019-06-22 15:49:35 +03:00
</table>
2018-03-03 13:50:13 +02:00
</td>
</tr>
2018-01-28 18:40:49 +02:00
</table>
2019-06-21 00:48:46 +03:00
<script type="text/javascript">
function use(option) {
2019-06-21 02:57:48 +03:00
document.getElementById(option).innerHTML = "<form method='post'><input placeholder='Имя персонажа' name='login'><button name='action' value='" + option + "' type='submit'>Ок</button><button>× </button></form>";
2019-06-21 00:48:46 +03:00
}
2020-09-30 17:19:55 +03:00
</script>