GridHelperTrait.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <?php
  2. namespace App\Module\User\AdminControllers\Helper;
  3. use App\Module\User\Enums\STATUS2;
  4. use Dcat\Admin\Grid;
  5. use Dcat\Admin\Grid\Column;
  6. /**
  7. * 列表页辅助特性
  8. *
  9. * 提供用户模块后台控制器的列表页构建功能的具体实现
  10. * 只保留具有复用价值的方法
  11. */
  12. trait GridHelperTrait
  13. {
  14. /**
  15. * 添加用户名列
  16. *
  17. * 复用价值:高 - 在多个控制器中使用,提供统一的用户名显示
  18. *
  19. * @param string $field 字段名
  20. * @param string $label 标签名
  21. * @return Column
  22. */
  23. public function columnUsername(string $field = 'username', string $label = '用户名'): Column
  24. {
  25. return $this->grid->column($field, $label);
  26. }
  27. /**
  28. * 添加用户安全信息组合列
  29. *
  30. * 复用价值:高 - 将用户安全相关信息组合显示,提高信息密度
  31. *
  32. * @param string $secretPasswordField 安全密码字段名
  33. * @param string $lastCheckAtField 最后验证时间字段名
  34. * @param string $label 标签名
  35. * @return Column
  36. */
  37. public function columnUserSecurity(string $secretPasswordField = 'secret_password', string $lastCheckAtField = 'last_check_at', string $label = '安全信息'): Column
  38. {
  39. return $this->grid->column($secretPasswordField, $label)->display(function ($secretPassword) use ($lastCheckAtField) {
  40. $lastCheckAt = $this->{$lastCheckAtField} ?? '';
  41. $secretPasswordHtml = "<div>安全密码: " . ($secretPassword ? '已设置' : '未设置') . "</div>";
  42. $lastCheckAtHtml = $lastCheckAt ? "<div>最后验证: {$lastCheckAt}</div>" : '';
  43. return $secretPasswordHtml . $lastCheckAtHtml;
  44. });
  45. }
  46. /**
  47. * 添加时间信息组合列 - 使用统一的时间格式化
  48. *
  49. * 复用价值:高 - 将创建时间和更新时间组合显示,提高信息密度
  50. *
  51. * @param string $createdAtField 创建时间字段名
  52. * @param string $updatedAtField 更新时间字段名
  53. * @param string $label 标签名
  54. * @return Column
  55. */
  56. public function columnTimes($createdAtField = 'created_at', $updatedAtField = 'updated_at', $label = '时间信息'): Column
  57. {
  58. return $this->grid->column($createdAtField, $label)->display(function ($createdAt) use ($updatedAtField) {
  59. $updatedAt = $this->{$updatedAtField} ?? '';
  60. // 使用静态方法进行时间格式化
  61. $createdAtFormatted = self::formatDateTimeStatic($createdAt);
  62. $createdAtHtml = "<div><small class='text-muted'>创建:</small> {$createdAtFormatted}</div>";
  63. $updatedAtHtml = '';
  64. if ($updatedAt) {
  65. $updatedAtFormatted = self::formatDateTimeStatic($updatedAt);
  66. $updatedAtHtml = "<div><small class='text-muted'>更新:</small> {$updatedAtFormatted}</div>";
  67. }
  68. return $createdAtHtml . $updatedAtHtml;
  69. })->sortable();
  70. }
  71. /**
  72. * 格式化时间的静态方法
  73. *
  74. * @param mixed $value 时间值
  75. * @return string 格式化后的时间字符串
  76. */
  77. private static function formatDateTimeStatic($value)
  78. {
  79. // 检查空值(但不包括0,因为0是有效的时间戳)
  80. if (is_null($value) || $value === '') {
  81. return '-';
  82. }
  83. // 如果是时间戳,转换为日期时间字符串
  84. if (is_numeric($value)) {
  85. return date('Y-m-d H:i:s', $value);
  86. }
  87. // 如果是Carbon实例或DateTime对象
  88. if ($value instanceof \Carbon\Carbon || $value instanceof \DateTime) {
  89. return $value->format('Y-m-d H:i:s');
  90. }
  91. // 如果是字符串,尝试转换为标准格式
  92. if (is_string($value)) {
  93. try {
  94. $date = new \DateTime($value);
  95. return $date->format('Y-m-d H:i:s');
  96. } catch (\Exception $e) {
  97. return $value; // 如果转换失败,返回原值
  98. }
  99. }
  100. return $value;
  101. }
  102. /**
  103. * 添加用户活动时间组合列
  104. *
  105. * 复用价值:高 - 将最后登录时间和最后活动时间组合显示,提高信息密度
  106. *
  107. * @param string $label 标签名
  108. * @return Column
  109. */
  110. public function columnUserActivityTimes(string $label = '活动时间'): Column
  111. {
  112. return $this->grid->column('info.last_login_time', $label)->display(function ($lastLoginTime) {
  113. $lastActivityTime = $this->info->last_activity_time ?? '';
  114. $loginTimeHtml = $lastLoginTime ? "<div>最后登录: {$lastLoginTime}</div>" : "<div>最后登录: 未登录</div>";
  115. $activityTimeHtml = $lastActivityTime ? "<div>最后活动: {$lastActivityTime}</div>" : "<div>最后活动: 无活动</div>";
  116. return $loginTimeHtml . $activityTimeHtml;
  117. })->sortable();
  118. }
  119. /**
  120. * 添加最后登录时间列
  121. *
  122. * 复用价值:中 - 单独显示最后登录时间
  123. *
  124. * @param string $label 标签名
  125. * @return Column
  126. */
  127. public function columnLastLoginTime(string $label = '最后登录时间'): Column
  128. {
  129. return $this->grid->column('info.last_login_time', $label)->display(function ($value) {
  130. return $value ?: '未登录';
  131. })->sortable();
  132. }
  133. /**
  134. * 添加最后活动时间列
  135. *
  136. * 复用价值:中 - 单独显示最后活动时间
  137. *
  138. * @param string $label 标签名
  139. * @return Column
  140. */
  141. public function columnLastActivityTime(string $label = '最后活动时间'): Column
  142. {
  143. return $this->grid->column('info.last_activity_time', $label)->display(function ($value) {
  144. return $value ?: '无活动';
  145. })->sortable();
  146. }
  147. }