|
|
@@ -5,16 +5,325 @@ namespace App\Module\Game\AdminControllers\Helper;
|
|
|
use App\Module\Game\Enums\REWARD_SOURCE_TYPE;
|
|
|
use App\Module\Game\Enums\REWARD_TYPE;
|
|
|
use App\Module\Game\Models\GameRewardGroup;
|
|
|
+use App\Module\User\Enums\STATUS2;
|
|
|
use Dcat\Admin\Grid;
|
|
|
use Dcat\Admin\Grid\Column;
|
|
|
|
|
|
/**
|
|
|
- * 列表页辅助特性
|
|
|
+ * 游戏用户列表页辅助特性
|
|
|
*
|
|
|
- * 提供游戏模块后台控制器的列表页构建功能的具体实现
|
|
|
+ * 提供游戏用户模块后台控制器的列表页构建功能的具体实现
|
|
|
+ * 包含用户基础信息和游戏相关信息的显示方法
|
|
|
*/
|
|
|
trait GridHelperTrait
|
|
|
{
|
|
|
+ /**
|
|
|
+ * 添加用户信息组合列
|
|
|
+ *
|
|
|
+ * 复用价值:高 - 将用户ID、用户名和头像组合显示,提高信息密度
|
|
|
+ *
|
|
|
+ * @param string $idField 用户ID字段名
|
|
|
+ * @param string $usernameField 用户名字段名
|
|
|
+ * @param string $avatarField 头像字段名
|
|
|
+ * @param string $label 标签名
|
|
|
+ * @return Column
|
|
|
+ */
|
|
|
+ public function columnUserInfo(string $idField = 'id', string $usernameField = 'username', string $avatarField = 'avatar', string $label = '用户信息'): Column
|
|
|
+ {
|
|
|
+ return $this->grid->column($idField, $label)->display(function ($userId) use ($usernameField, $avatarField) {
|
|
|
+ $username = $this->{$usernameField} ?? '';
|
|
|
+ $avatar = $this->{$avatarField} ?? '';
|
|
|
+
|
|
|
+ $avatarHtml = $avatar ? "<img src='{$avatar}' width='30' height='30' style='border-radius: 50%; margin-right: 5px;'>" : '';
|
|
|
+
|
|
|
+ return <<<HTML
|
|
|
+ <div style="display: flex; align-items: center;">
|
|
|
+ {$avatarHtml}
|
|
|
+ <div>
|
|
|
+ <div>ID: {$userId}</div>
|
|
|
+ <div>{$username}</div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ HTML;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 添加用户联系信息组合列
|
|
|
+ *
|
|
|
+ * 复用价值:高 - 将用户手机号、邮箱和微信号组合显示,提高信息密度
|
|
|
+ *
|
|
|
+ * @param string $phoneField 手机号字段名
|
|
|
+ * @param string $emailField 邮箱字段名
|
|
|
+ * @param string $wxIdField 微信号字段名
|
|
|
+ * @param string $label 标签名
|
|
|
+ * @return Column
|
|
|
+ */
|
|
|
+ public function columnUserContact(string $phoneField = 'phone', string $emailField = 'email', string $wxIdField = 'wx_id', string $label = '联系方式'): Column
|
|
|
+ {
|
|
|
+ return $this->grid->column($phoneField, $label)->display(function ($phone) use ($emailField, $wxIdField) {
|
|
|
+ $email = $this->{$emailField} ?? '';
|
|
|
+ $wxId = $this->{$wxIdField} ?? '';
|
|
|
+
|
|
|
+ $phoneHtml = $phone ? "<div>手机: {$phone}</div>" : '';
|
|
|
+ $emailHtml = $email ? "<div>邮箱: {$email}</div>" : '';
|
|
|
+ $wxIdHtml = $wxId ? "<div>微信: {$wxId}</div>" : '';
|
|
|
+
|
|
|
+ return $phoneHtml . $emailHtml . $wxIdHtml;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 添加时间信息组合列
|
|
|
+ *
|
|
|
+ * 复用价值:高 - 将创建时间和更新时间组合显示,提高信息密度
|
|
|
+ *
|
|
|
+ * @param string $createdAtField 创建时间字段名
|
|
|
+ * @param string $updatedAtField 更新时间字段名
|
|
|
+ * @param string $label 标签名
|
|
|
+ * @return Column
|
|
|
+ */
|
|
|
+ public function columnTimes(string $createdAtField = 'created_at', string $updatedAtField = 'updated_at', string $label = '时间信息'): Column
|
|
|
+ {
|
|
|
+ return $this->grid->column($createdAtField, $label)->display(function ($createdAt) use ($updatedAtField) {
|
|
|
+ $updatedAt = $this->{$updatedAtField} ?? '';
|
|
|
+
|
|
|
+ $createdAtHtml = "<div>创建: {$createdAt}</div>";
|
|
|
+ $updatedAtHtml = $updatedAt ? "<div>更新: {$updatedAt}</div>" : '';
|
|
|
+
|
|
|
+ return $createdAtHtml . $updatedAtHtml;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 添加用户资金账户信息列
|
|
|
+ *
|
|
|
+ * 复用价值:高 - 显示用户的资金账户信息
|
|
|
+ *
|
|
|
+ * @param string $idField 用户ID字段名
|
|
|
+ * @param string $label 标签名
|
|
|
+ * @return Column
|
|
|
+ */
|
|
|
+ public function columnUserFunds(string $idField = 'id', string $label = '资金账户'): Column
|
|
|
+ {
|
|
|
+ return $this->grid->column($idField, $label)->display(function ($userId) {
|
|
|
+ // 获取用户的资金账户
|
|
|
+ $funds = \App\Module\Fund\Models\FundModel::where('user_id', $userId)->get();
|
|
|
+
|
|
|
+ if ($funds->isEmpty()) {
|
|
|
+ return '<span class="text-muted">无资金账户</span>';
|
|
|
+ }
|
|
|
+
|
|
|
+ $fundNames = \App\Module\Fund\Services\AccountService::getFundsDesc();
|
|
|
+ $html = '<div style="max-height: 150px; overflow-y: auto;">';
|
|
|
+
|
|
|
+ foreach ($funds as $fund) {
|
|
|
+ $fundName = $fundNames[$fund->fund_id] ?? "未知类型({$fund->fund_id})";
|
|
|
+ $balance = number_format($fund->balance / 100, 2);
|
|
|
+ $html .= "<div><span class='badge badge-info'>{$fundName}</span>: {$balance}</div>";
|
|
|
+ }
|
|
|
+
|
|
|
+ $html .= '</div>';
|
|
|
+ $html .= "<div><a href='" . admin_url("fund-accounts?user_id={$userId}") . "' class='text-primary'>查看详情</a></div>";
|
|
|
+
|
|
|
+ return $html;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 添加用户物品信息列
|
|
|
+ *
|
|
|
+ * 复用价值:高 - 显示用户的物品信息
|
|
|
+ *
|
|
|
+ * @param string $idField 用户ID字段名
|
|
|
+ * @param string $label 标签名
|
|
|
+ * @return Column
|
|
|
+ */
|
|
|
+ public function columnUserItems(string $idField = 'id', string $label = '物品背包'): Column
|
|
|
+ {
|
|
|
+ return $this->grid->column($idField, $label)->display(function ($userId) {
|
|
|
+ // 获取用户的物品(限制最多显示5个)
|
|
|
+ $items = \App\Module\GameItems\Models\ItemUser::with('item')
|
|
|
+ ->where('user_id', $userId)
|
|
|
+ ->orderBy('quantity', 'desc')
|
|
|
+ ->limit(5)
|
|
|
+ ->get();
|
|
|
+
|
|
|
+ if ($items->isEmpty()) {
|
|
|
+ return '<span class="text-muted">无物品</span>';
|
|
|
+ }
|
|
|
+
|
|
|
+ $html = '<div style="max-height: 150px; overflow-y: auto;">';
|
|
|
+
|
|
|
+ foreach ($items as $userItem) {
|
|
|
+ $itemName = $userItem->item->name ?? "物品 {$userItem->item_id}";
|
|
|
+ $quantity = $userItem->quantity;
|
|
|
+ $html .= "<div><span class='badge badge-success'>{$itemName}</span> x {$quantity}</div>";
|
|
|
+ }
|
|
|
+
|
|
|
+ // 获取用户物品总数
|
|
|
+ $totalCount = \App\Module\GameItems\Models\ItemUser::where('user_id', $userId)->count();
|
|
|
+ if ($totalCount > 5) {
|
|
|
+ $html .= "<div>... 共 {$totalCount} 种物品</div>";
|
|
|
+ }
|
|
|
+
|
|
|
+ $html .= '</div>';
|
|
|
+ $html .= "<div><a href='" . admin_url("game-items-users?user_id={$userId}") . "' class='text-primary'>查看详情</a></div>";
|
|
|
+
|
|
|
+ return $html;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 添加用户土地信息列
|
|
|
+ *
|
|
|
+ * 复用价值:高 - 显示用户的土地信息
|
|
|
+ *
|
|
|
+ * @param string $idField 用户ID字段名
|
|
|
+ * @param string $label 标签名
|
|
|
+ * @return Column
|
|
|
+ */
|
|
|
+ public function columnUserLands(string $idField = 'id', string $label = '土地信息'): Column
|
|
|
+ {
|
|
|
+ return $this->grid->column($idField, $label)->display(function ($userId) {
|
|
|
+ // 获取用户的土地
|
|
|
+ $lands = \App\Module\Farm\Models\FarmLand::where('user_id', $userId)->get();
|
|
|
+
|
|
|
+ if ($lands->isEmpty()) {
|
|
|
+ return '<span class="text-muted">无土地</span>';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 获取土地状态统计
|
|
|
+ $statusCounts = $lands->groupBy('status')->map->count();
|
|
|
+
|
|
|
+ $statusMap = [
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::IDLE->value => '空闲',
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::PLANTING->value => '种植中',
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::DISASTER->value => '灾害',
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::HARVESTABLE->value => '可收获',
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::WITHERED->value => '枯萎'
|
|
|
+ ];
|
|
|
+
|
|
|
+ $html = '<div style="max-height: 150px; overflow-y: auto;">';
|
|
|
+ $html .= "<div>总数: {$lands->count()} 块</div>";
|
|
|
+
|
|
|
+ foreach ($statusCounts as $status => $count) {
|
|
|
+ $statusName = $statusMap[$status] ?? "未知状态({$status})";
|
|
|
+ $badgeClass = match($status) {
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::IDLE->value => 'secondary',
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::PLANTING->value => 'primary',
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::DISASTER->value => 'warning',
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::HARVESTABLE->value => 'success',
|
|
|
+ \App\Module\Farm\Enums\LAND_STATUS::WITHERED->value => 'danger',
|
|
|
+ default => 'info'
|
|
|
+ };
|
|
|
+ $html .= "<div><span class='badge badge-{$badgeClass}'>{$statusName}</span>: {$count} 块</div>";
|
|
|
+ }
|
|
|
+
|
|
|
+ $html .= '</div>';
|
|
|
+ $html .= "<div><a href='" . admin_url("farm-lands?user_id={$userId}") . "' class='text-primary'>查看详情</a></div>";
|
|
|
+
|
|
|
+ return $html;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 添加用户神像buff信息列
|
|
|
+ *
|
|
|
+ * 复用价值:高 - 显示用户的神像buff信息
|
|
|
+ *
|
|
|
+ * @param string $idField 用户ID字段名
|
|
|
+ * @param string $label 标签名
|
|
|
+ * @return Column
|
|
|
+ */
|
|
|
+ public function columnUserBuffs(string $idField = 'id', string $label = '神像加持'): Column
|
|
|
+ {
|
|
|
+ return $this->grid->column($idField, $label)->display(function ($userId) {
|
|
|
+ // 获取用户的神像buff
|
|
|
+ $buffs = \App\Module\Farm\Models\FarmGodBuff::where('user_id', $userId)
|
|
|
+ ->where('expire_time', '>', now())
|
|
|
+ ->get();
|
|
|
+
|
|
|
+ if ($buffs->isEmpty()) {
|
|
|
+ return '<span class="text-muted">无有效神像加持</span>';
|
|
|
+ }
|
|
|
+
|
|
|
+ $buffTypes = [
|
|
|
+ \App\Module\Farm\Enums\BUFF_TYPE::HARVEST_GOD->value => '丰收之神',
|
|
|
+ \App\Module\Farm\Enums\BUFF_TYPE::RAIN_GOD->value => '雨露之神',
|
|
|
+ \App\Module\Farm\Enums\BUFF_TYPE::WEED_KILLER_GOD->value => '屠草之神',
|
|
|
+ \App\Module\Farm\Enums\BUFF_TYPE::PEST_CLEANER_GOD->value => '拭虫之神'
|
|
|
+ ];
|
|
|
+
|
|
|
+ $html = '<div style="max-height: 150px; overflow-y: auto;">';
|
|
|
+
|
|
|
+ foreach ($buffs as $buff) {
|
|
|
+ $buffName = $buffTypes[$buff->buff_type] ?? "未知神像({$buff->buff_type})";
|
|
|
+ $expireTime = $buff->expire_time->format('Y-m-d H:i:s');
|
|
|
+ $html .= "<div><span class='badge badge-warning'>{$buffName}</span> 到期: {$expireTime}</div>";
|
|
|
+ }
|
|
|
+
|
|
|
+ $html .= '</div>';
|
|
|
+ $html .= "<div><a href='" . admin_url("farm-god-buffs?user_id={$userId}") . "' class='text-primary'>查看详情</a></div>";
|
|
|
+
|
|
|
+ return $html;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 添加用户种植作物信息列
|
|
|
+ *
|
|
|
+ * 复用价值:高 - 显示用户的种植作物信息
|
|
|
+ *
|
|
|
+ * @param string $idField 用户ID字段名
|
|
|
+ * @param string $label 标签名
|
|
|
+ * @return Column
|
|
|
+ */
|
|
|
+ public function columnUserCrops(string $idField = 'id', string $label = '种植作物'): Column
|
|
|
+ {
|
|
|
+ return $this->grid->column($idField, $label)->display(function ($userId) {
|
|
|
+ // 获取用户的作物
|
|
|
+ $crops = \App\Module\Farm\Models\FarmCrop::with(['seed', 'land'])
|
|
|
+ ->where('user_id', $userId)
|
|
|
+ ->get();
|
|
|
+
|
|
|
+ if ($crops->isEmpty()) {
|
|
|
+ return '<span class="text-muted">无种植作物</span>';
|
|
|
+ }
|
|
|
+
|
|
|
+ // 获取作物生长阶段统计
|
|
|
+ $stageCounts = $crops->groupBy('growth_stage')->map->count();
|
|
|
+
|
|
|
+ $stageMap = [
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::SEED->value => '种子期',
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::SPROUT->value => '发芽期',
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::GROWTH->value => '生长期',
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::MATURE->value => '成熟期',
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::WITHERED->value => '枯萎期'
|
|
|
+ ];
|
|
|
+
|
|
|
+ $html = '<div style="max-height: 150px; overflow-y: auto;">';
|
|
|
+ $html .= "<div>总数: {$crops->count()} 株</div>";
|
|
|
+
|
|
|
+ foreach ($stageCounts as $stage => $count) {
|
|
|
+ $stageName = $stageMap[$stage] ?? "未知阶段({$stage})";
|
|
|
+ $badgeClass = match($stage) {
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::SEED->value => 'secondary',
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::SPROUT->value => 'info',
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::GROWTH->value => 'primary',
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::MATURE->value => 'success',
|
|
|
+ \App\Module\Farm\Enums\GROWTH_STAGE::WITHERED->value => 'danger',
|
|
|
+ default => 'dark'
|
|
|
+ };
|
|
|
+ $html .= "<div><span class='badge badge-{$badgeClass}'>{$stageName}</span>: {$count} 株</div>";
|
|
|
+ }
|
|
|
+
|
|
|
+ $html .= '</div>';
|
|
|
+ $html .= "<div><a href='" . admin_url("farm-crops?user_id={$userId}") . "' class='text-primary'>查看详情</a></div>";
|
|
|
+
|
|
|
+ return $html;
|
|
|
+ });
|
|
|
+ }
|
|
|
/**
|
|
|
* 添加奖励类型列
|
|
|
*
|