grid->column($idField, $label)->display(function ($userId) use ($usernameField) {
$username = $this->{$usernameField} ?? '';
return <<
ID: {$userId}
用户名: {$username}
HTML;
});
}
/**
* 添加用户活动时间组合列
*
* 复用价值:高 - 将最后登录时间和最后活动时间组合显示,提高信息密度
*
* @param string $label 标签名
* @return Column
*/
public function columnUserActivityTimes(string $label = '活动时间'): Column
{
return $this->grid->column('info.last_login_time', $label)->display(function ($lastLoginTime) {
$lastActivityTime = $this->info->last_activity_time ?? '';
$loginTimeHtml = $lastLoginTime ? "最后登录: {$lastLoginTime}
" : "最后登录: 未登录
";
$activityTimeHtml = $lastActivityTime ? "最后活动: {$lastActivityTime}
" : "最后活动: 无活动
";
return $loginTimeHtml . $activityTimeHtml;
})->sortable();
}
/**
* 添加最后登录时间列
*
* 复用价值:中 - 单独显示最后登录时间
*
* @param string $label 标签名
* @return Column
*/
public function columnLastLoginTime(string $label = '最后登录时间'): Column
{
return $this->grid->column('info.last_login_time', $label)->display(function ($value) {
return $value ?: '未登录';
})->sortable();
}
/**
* 添加最后活动时间列
*
* 复用价值:中 - 单独显示最后活动时间
*
* @param string $label 标签名
* @return Column
*/
public function columnLastActivityTime(string $label = '最后活动时间'): Column
{
return $this->grid->column('info.last_activity_time', $label)->display(function ($value) {
return $value ?: '无活动';
})->sortable();
}
/**
* 添加用户联系信息组合列
*
* 复用价值:高 - 将用户手机号、邮箱和微信号组合显示,提高信息密度
*
* @param string $label 标签名
* @return Column
*/
public function columnUserContact(string $label = '联系方式'): Column
{
return $this->grid->column('id', $label)->display(function ($userId) {
return '联系方式';
});
}
/**
* 添加时间信息组合列 - 使用统一的时间格式化
*
* 复用价值:高 - 将创建时间和更新时间组合显示,提高信息密度
*
* @param string $createdAtField 创建时间字段名
* @param string $updatedAtField 更新时间字段名
* @param string $label 标签名
* @return Column
*/
public function columnTimes($createdAtField = 'created_at', $updatedAtField = 'updated_at', $label = '时间信息'): Column
{
return $this->grid->column($createdAtField, $label)->display(function ($createdAt) use ($updatedAtField) {
$updatedAt = $this->{$updatedAtField} ?? '';
// 使用静态方法进行时间格式化
$createdAtFormatted = self::formatDateTimeStatic($createdAt);
$createdAtHtml = "创建: {$createdAtFormatted}
";
$updatedAtHtml = '';
if ($updatedAt) {
$updatedAtFormatted = self::formatDateTimeStatic($updatedAt);
$updatedAtHtml = "更新: {$updatedAtFormatted}
";
}
return $createdAtHtml . $updatedAtHtml;
})->sortable();
}
/**
* 格式化时间的静态方法
*
* @param mixed $value 时间值
* @return string 格式化后的时间字符串
*/
private static function formatDateTimeStatic($value)
{
// 检查空值(但不包括0,因为0是有效的时间戳)
if (is_null($value) || $value === '') {
return '-';
}
// 如果是时间戳,转换为日期时间字符串
if (is_numeric($value)) {
return date('Y-m-d H:i:s', $value);
}
// 如果是Carbon实例或DateTime对象
if ($value instanceof \Carbon\Carbon || $value instanceof \DateTime) {
return $value->format('Y-m-d H:i:s');
}
// 如果是字符串,尝试转换为标准格式
if (is_string($value)) {
try {
$date = new \DateTime($value);
return $date->format('Y-m-d H:i:s');
} catch (\Exception $e) {
return $value; // 如果转换失败,返回原值
}
}
return $value;
}
/**
* 添加用户资金账户信息列
*
* 复用价值:高 - 显示用户的资金账户信息
*
* @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) {
return '资金账户';
});
}
/**
* 添加用户物品信息列
*
* 复用价值:高 - 显示用户的物品信息
*
* @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) {
return '物品背包';
});
}
/**
* 添加用户土地信息列
*
* 复用价值:高 - 显示用户的土地信息
*
* @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) {
return '土地信息';
});
}
/**
* 添加用户神像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) {
return '神像加持';
});
}
/**
* 添加用户种植作物信息列
*
* 复用价值:高 - 显示用户的种植作物信息
*
* @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 '无种植作物';
}
// 获取作物生长阶段统计
$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::FRUIT->value => '果实期',
\App\Module\Farm\Enums\GROWTH_STAGE::MATURE->value => '成熟期',
\App\Module\Farm\Enums\GROWTH_STAGE::WITHERED->value => '枯萎期'
];
$html = '';
$html .= "
总数: {$crops->count()} 株
";
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::FRUIT->value => 'warning',
\App\Module\Farm\Enums\GROWTH_STAGE::MATURE->value => 'success',
\App\Module\Farm\Enums\GROWTH_STAGE::WITHERED->value => 'danger',
default => 'dark'
};
$html .= "
{$stageName}: {$count} 株
";
}
$html .= '
';
$html .= "";
return $html;
});
}
/**
* 添加奖励类型列
*
* @param string $field 字段名
* @param string $label 标签名
* @return Column
*/
public function columnRewardType(string $field = 'reward_type', string $label = '奖励类型'): Column
{
return $this->grid->column($field, $label)->display(function ($value) {
return REWARD_TYPE::getName($value);
})->label([
REWARD_TYPE::ITEM->value => 'primary',
REWARD_TYPE::CURRENCY->value => 'success',
REWARD_TYPE::PET_EXP->value => 'info',
REWARD_TYPE::PET_ENERGY->value => 'warning',
REWARD_TYPE::OTHER->value => 'default',
]);
}
/**
* 添加奖励来源类型列
*
* @param string $field 字段名
* @param string $label 标签名
* @return Column
*/
public function columnRewardSourceType(string $field = 'source_type', string $label = '奖励来源'): Column
{
return $this->grid->column($field, $label)->display(function ($value) {
return REWARD_SOURCE_TYPE::getName($value);
})->label([
REWARD_SOURCE_TYPE::TASK->value => 'primary',
REWARD_SOURCE_TYPE::ACTIVITY->value => 'success',
REWARD_SOURCE_TYPE::SIGN_IN->value => 'info',
REWARD_SOURCE_TYPE::ACHIEVEMENT->value => 'warning',
REWARD_SOURCE_TYPE::LEVEL->value => 'danger',
REWARD_SOURCE_TYPE::CHEST->value => 'dark',
REWARD_SOURCE_TYPE::SYSTEM->value => 'default',
]);
}
/**
* 添加奖励组列
*
* @param string $field 字段名
* @param string $label 标签名
* @return Column
*/
public function columnRewardGroup(string $field = 'group_id', string $label = '奖励组'): Column
{
return $this->grid->column($field, $label)->display(function ($value) {
$group = GameRewardGroup::find($value);
return $group ? "{$group->name} ({$group->code})" : "未知 ({$value})";
});
}
/**
* 添加奖励项列
*
* @param string $field 字段名
* @param string $label 标签名
* @return Column
*/
public function columnRewardItems(string $field = 'reward_items', string $label = '奖励项'): Column
{
return $this->grid->column($field, $label)->display(function ($value) {
$items = json_decode($value, true);
if (empty($items)) {
return '无奖励项';
}
$count = count($items);
return "{$count}个奖励项";
});
}
/**
* 添加是否随机发放列
*
* @param string $field 字段名
* @param string $label 标签名
* @return Column
*/
public function columnIsRandom(string $field = 'is_random', string $label = '随机发放'): Column
{
return $this->grid->column($field, $label)->switch();
}
/**
* 添加是否必中列
*
* @param string $field 字段名
* @param string $label 标签名
* @return Column
*/
public function columnIsGuaranteed(string $field = 'is_guaranteed', string $label = '必中'): Column
{
return $this->grid->column($field, $label)->switch();
}
/**
* 添加权重列
*
* @param string $field 字段名
* @param string $label 标签名
* @return Column
*/
public function columnWeight(string $field = 'weight', string $label = '权重'): Column
{
return $this->grid->column($field, $label)->sortable();
}
}