2019-01-11 21:57:15 +00:00
|
|
|
|
<?php
|
2022-08-09 19:57:43 +00:00
|
|
|
|
|
2020-10-28 20:21:08 +00:00
|
|
|
|
namespace Battles;
|
2021-03-14 17:54:13 +00:00
|
|
|
|
|
2022-08-09 19:57:43 +00:00
|
|
|
|
use Battles\Models\Inventory;
|
2021-03-14 17:54:13 +00:00
|
|
|
|
|
2019-01-11 21:57:15 +00:00
|
|
|
|
class InventoryItem extends Item
|
|
|
|
|
{
|
2022-08-09 19:57:43 +00:00
|
|
|
|
private ?string $present;
|
|
|
|
|
private int $owner_id;
|
2021-03-14 17:54:13 +00:00
|
|
|
|
private const TOO_MANY_ITEMS_IN_SLOTS = 'Критическая ошибка: Переполнение слота!';
|
|
|
|
|
private const UNKNOWN_ITEM_TYPE = 'Неизвестный тип предмета!';
|
|
|
|
|
private const REQUIREMENTS_NOT_MET = 'Персонаж не соответствует требованиям!';
|
2019-01-12 09:47:23 +00:00
|
|
|
|
|
2021-03-14 17:54:13 +00:00
|
|
|
|
/**
|
|
|
|
|
* InventoryItem constructor.
|
|
|
|
|
*
|
|
|
|
|
* @param $row
|
|
|
|
|
*/
|
2019-01-12 09:47:23 +00:00
|
|
|
|
public function __construct($row)
|
|
|
|
|
{
|
|
|
|
|
parent::__construct($row);
|
2021-03-14 17:54:13 +00:00
|
|
|
|
$this->owner_id = $row->owner_id;
|
2021-08-20 17:40:06 +00:00
|
|
|
|
$this->present = $row->present;
|
2019-01-12 09:47:23 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-01-11 21:57:15 +00:00
|
|
|
|
public function printInfo()
|
|
|
|
|
{
|
2021-08-29 22:34:50 +00:00
|
|
|
|
echo $this->getAllInfo();
|
2020-07-21 15:03:46 +00:00
|
|
|
|
if ($this->present) {
|
2021-08-20 17:40:06 +00:00
|
|
|
|
echo "<p style='color: maroon; font-style: italic'>Это подарок от $this->present. Вы не можете передать его кому-либо ещё.</p>";
|
2020-07-21 15:03:46 +00:00
|
|
|
|
}
|
2019-01-11 21:57:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-01-11 22:18:18 +00:00
|
|
|
|
public function printImage()
|
|
|
|
|
{
|
2021-03-10 21:43:48 +00:00
|
|
|
|
if (in_array($this->item_type, range(1, 12))) {
|
|
|
|
|
echo <<<HTML
|
2022-01-26 23:15:33 +00:00
|
|
|
|
<a href=/main.php?edit=1&dress=$this->item_id title='Надеть'>
|
|
|
|
|
<img src="/i/sh/$this->image" class="item-wrap-normal" alt="">
|
2021-03-10 21:43:48 +00:00
|
|
|
|
</a>
|
|
|
|
|
HTML;
|
2020-07-21 15:03:46 +00:00
|
|
|
|
} else {
|
2021-03-10 21:43:48 +00:00
|
|
|
|
echo <<<IMG
|
2022-01-26 23:15:33 +00:00
|
|
|
|
<img src="/i/sh/$this->image" class="item-wrap-normal" alt="">
|
2021-03-10 21:43:48 +00:00
|
|
|
|
IMG;
|
2019-01-11 22:30:12 +00:00
|
|
|
|
}
|
2019-01-11 22:18:18 +00:00
|
|
|
|
}
|
2021-01-28 23:58:07 +00:00
|
|
|
|
|
2022-08-09 19:57:43 +00:00
|
|
|
|
public function printControls()
|
|
|
|
|
{
|
2021-08-29 22:34:50 +00:00
|
|
|
|
// Для кнопок управления под картинкой.
|
2021-03-14 17:54:13 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-08-09 19:57:43 +00:00
|
|
|
|
private function dressStatsChecks(): bool
|
2021-03-14 17:54:13 +00:00
|
|
|
|
{
|
|
|
|
|
$checkStats = new UserStats($this->owner_id);
|
2022-01-25 16:16:09 +00:00
|
|
|
|
$stat = $checkStats->getFullStats();
|
2022-08-09 19:57:43 +00:00
|
|
|
|
return $this->need_strength > $stat->strength
|
|
|
|
|
|| $this->need_dexterity > $stat->dexterity
|
|
|
|
|
|| $this->need_intuition > $stat->intuition
|
|
|
|
|
|| $this->need_endurance > $stat->endurance
|
|
|
|
|
|| $this->need_intelligence > $stat->intelligence
|
|
|
|
|
|| $this->need_wisdom > $stat->wisdom;
|
2021-03-14 17:54:13 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Одевание предмета из инвентаря в слот.
|
|
|
|
|
* @return bool|string
|
|
|
|
|
*/
|
|
|
|
|
public function dressItem()
|
|
|
|
|
{
|
|
|
|
|
$itemInSlot = [];
|
|
|
|
|
if ($this->dressStatsChecks()) {
|
|
|
|
|
return self::REQUIREMENTS_NOT_MET;
|
|
|
|
|
}
|
|
|
|
|
// считаем сколько ОДЕТЫХ предметов в слоте в который мы хотим одеть предмет. 1=просто вещь 1-3=шашни с кольцами
|
|
|
|
|
// Count добавленный в первый запрос возвращает одну строку в любом случае.
|
|
|
|
|
// fetch возвращает одну строку в любом случае.
|
2022-08-09 19:57:43 +00:00
|
|
|
|
$weared = Inventory::getDressed($this->item_type, $this->owner_id);
|
|
|
|
|
$wearedCount = Inventory::countDressed($this->item_type, $this->owner_id);
|
2021-03-14 17:54:13 +00:00
|
|
|
|
// Если в слоте есть предмет(ы), забиваем их массив одетых в слот предметов.
|
|
|
|
|
if ($wearedCount) {
|
|
|
|
|
foreach ($weared as $item) {
|
|
|
|
|
$itemInSlot[] = $item->dressed_slot;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (in_array($this->item_type, [
|
|
|
|
|
self::ITEM_TYPE_HELMET, self::ITEM_TYPE_ARMOR, self::ITEM_TYPE_LEGS, self::ITEM_TYPE_BOOTS,
|
|
|
|
|
self::ITEM_TYPE_GLOVES, self::ITEM_TYPE_WEAPON, self::ITEM_TYPE_SHIELD, self::ITEM_TYPE_BELT,
|
|
|
|
|
self::ITEM_TYPE_AMULET,
|
|
|
|
|
])) {
|
|
|
|
|
//работаем с нормальными слотами
|
|
|
|
|
if ($wearedCount->c == 1) {
|
|
|
|
|
//если слот занят, снимаем старый предмет и одеваем новый предмет
|
2022-08-09 19:57:43 +00:00
|
|
|
|
Inventory::undressOne($itemInSlot[0], $this->owner_id);
|
|
|
|
|
Inventory::dressOne($this->item_id, $this->owner_id);
|
2021-03-14 17:54:13 +00:00
|
|
|
|
} elseif (!$wearedCount->c) {
|
|
|
|
|
//если слот пуст, одеваем новый предмет
|
2022-08-09 19:57:43 +00:00
|
|
|
|
Inventory::dressOne($this->item_id, $this->owner_id);
|
2021-03-14 17:54:13 +00:00
|
|
|
|
} else {
|
|
|
|
|
/* проверка на переполнение слотов */
|
|
|
|
|
$error = self::TOO_MANY_ITEMS_IN_SLOTS;
|
|
|
|
|
DressedItems::undressAllItems($this->owner_id);
|
|
|
|
|
}
|
|
|
|
|
} elseif ($this->item_type == self::ITEM_TYPE_RING) {
|
|
|
|
|
// работаем с кольцами
|
|
|
|
|
if ($wearedCount->c < 3) {
|
|
|
|
|
// Сравниваем массив колец и массив слотов для колец.
|
|
|
|
|
$emptyRingSlots = array_diff([9, 10, 11], $itemInSlot);
|
|
|
|
|
// Сортируем массив свободных слотов по возрастанию.
|
|
|
|
|
sort($emptyRingSlots);
|
|
|
|
|
// Одеваем предмет в первый свободный слот.
|
2022-08-09 19:57:43 +00:00
|
|
|
|
Inventory::dressOneToSlot($this->item_id, $emptyRingSlots[0]);
|
2021-03-14 17:54:13 +00:00
|
|
|
|
} elseif ($wearedCount->c == 3) {
|
|
|
|
|
// Cнимаем предмет из последнего слота 11 и одеваем новый предмет
|
2022-08-09 19:57:43 +00:00
|
|
|
|
Inventory::changeRings($this->item_id);
|
2021-03-14 17:54:13 +00:00
|
|
|
|
} else {
|
|
|
|
|
/* проверка на переполнение слотов */
|
|
|
|
|
$error = self::TOO_MANY_ITEMS_IN_SLOTS;
|
|
|
|
|
DressedItems::undressAllItems($this->owner_id);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
$error = self::UNKNOWN_ITEM_TYPE;
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-20 17:40:06 +00:00
|
|
|
|
return $error ?? true;
|
2021-03-14 17:54:13 +00:00
|
|
|
|
}
|
2021-05-12 19:02:05 +00:00
|
|
|
|
|
2022-08-09 19:57:43 +00:00
|
|
|
|
// Выбрасываем вещь.
|
|
|
|
|
public function drop(): string
|
2021-05-12 19:02:05 +00:00
|
|
|
|
{
|
2022-08-09 19:57:43 +00:00
|
|
|
|
if (empty($this->item_id)) {
|
|
|
|
|
return 'Ошибка: предмет не найден!';
|
|
|
|
|
}
|
|
|
|
|
if (Inventory::isWeared($this->item_id)) {
|
|
|
|
|
return 'Ошибка: нельзя выбросить одетый предмет!';
|
|
|
|
|
}
|
|
|
|
|
Inventory::destroyItem($this->item_id, $this->owner_id);
|
|
|
|
|
GameLogs::addUserLog(User::getInstance()->getId(), User::getInstance()->getLogin() . ' выбросил предмет ' . $this->name . ' id:(cap' . $this->item_id . ')');
|
|
|
|
|
return 'Предмет ' . $this->name . ' выброшен.';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/** Снятие всех предметов, которые не подходят по статам. */
|
|
|
|
|
public static function autoDrop()
|
|
|
|
|
{
|
|
|
|
|
$DI = new DressedItems(User::getInstance()->getId());
|
|
|
|
|
foreach ($DI->getItemsInSlots() as $dressedItem)
|
|
|
|
|
{
|
|
|
|
|
$ITM = new self($dressedItem);
|
|
|
|
|
if (!$ITM->dressStatsChecks()) {
|
|
|
|
|
$DI->undressItem($dressedItem->dressed_slot);
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-05-12 19:02:05 +00:00
|
|
|
|
}
|
2021-08-27 15:55:18 +00:00
|
|
|
|
|
|
|
|
|
/** Надеюсь, временная заглушка, которая объединяет get_meshok() и другую выдачу одной строкой.
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
public static function getWeightData(): string
|
|
|
|
|
{
|
2022-08-09 19:57:43 +00:00
|
|
|
|
$all = Inventory::getWeight(User::getInstance()->getId());
|
|
|
|
|
$max = User::getInstance()->stats()->getMaxWeight();
|
|
|
|
|
$css = $all > $max ? ' style="color:maroon;"' : '';
|
|
|
|
|
return "<span$css>$all / $max</span>";
|
2021-08-27 15:55:18 +00:00
|
|
|
|
}
|
2019-01-11 21:57:15 +00:00
|
|
|
|
}
|