UrsTalentLevelStatsCard.php 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. <?php
  2. namespace App\Module\UrsPromotion\AdminControllers\Metrics;
  3. use App\Module\UrsPromotion\Models\UrsUserTalent;
  4. use App\Module\UrsPromotion\Models\UrsTalentConfig;
  5. use App\Module\UrsPromotion\Enums\UrsTalentLevel;
  6. use UCore\DcatAdmin\Metrics\Examples\NumberS2;
  7. use Illuminate\Http\Request;
  8. use Illuminate\Support\Facades\DB;
  9. /**
  10. * URS达人等级统计卡片
  11. * 使用单行多数字卡片显示各个达人等级的人数统计
  12. */
  13. class UrsTalentLevelStatsCard extends NumberS2
  14. {
  15. /**
  16. * 初始化卡片内容
  17. */
  18. protected function init()
  19. {
  20. parent::init();
  21. $this->title('URS达人等级统计');
  22. // 移除下拉选项,因为达人等级统计不需要时间范围选择
  23. $this->dropdown([]);
  24. }
  25. /**
  26. * 处理请求
  27. *
  28. * @param Request $request
  29. * @return mixed|void
  30. */
  31. public function handle(Request $request)
  32. {
  33. $stats = $this->getTalentLevelStats();
  34. // 转换为NumberS2需要的数据格式
  35. $dataList = [];
  36. foreach ($stats as $stat) {
  37. $dataList[$stat['name']] = $stat['count'];
  38. }
  39. $this->withContent($dataList);
  40. }
  41. /**
  42. * 获取达人等级统计数据
  43. *
  44. * @return array
  45. */
  46. protected function getTalentLevelStats(): array
  47. {
  48. // 统计各等级的用户数量
  49. $levelCounts = UrsUserTalent::select('talent_level', DB::raw('COUNT(*) as count'))
  50. ->groupBy('talent_level')
  51. ->get()
  52. ->keyBy('talent_level');
  53. $stats = [];
  54. // 遍历所有等级配置,包括非达人等级
  55. foreach (UrsTalentLevel::cases() as $levelEnum) {
  56. $level = $levelEnum->value;
  57. $count = $levelCounts->get($level)->count ?? 0;
  58. $stats[] = [
  59. 'level' => $level,
  60. 'name' => $levelEnum->getName(),
  61. 'count' => $count,
  62. ];
  63. }
  64. return $stats;
  65. }
  66. }