RegisteredRecordController.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. <?php
  2. namespace App\Http\Controllers\Behavior;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\RegisteredRecord;
  5. use App\Repositories\Behavior\RegisteredRecordRepository;
  6. use App\Transformers\Behavior\RegisteredRecordTransformer;
  7. use League\Fractal\Manager;
  8. use League\Fractal\Pagination\IlluminatePaginatorAdapter;
  9. use League\Fractal\Resource\Collection;
  10. use Illuminate\Http\Request;
  11. /**
  12. * Created by PhpStorm.
  13. * User: durong
  14. * Date: 2019/6/14
  15. * Time: 上午11:30
  16. */
  17. class RegisteredRecordController extends Controller
  18. {
  19. public function __construct(RegisteredRecordRepository $registeredRecordRepository)
  20. {
  21. $this->registeredRecordRepository = $registeredRecordRepository;
  22. }
  23. /**
  24. * 新用户注册账本列表
  25. */
  26. public function index(Request $request)
  27. {
  28. $registeredList = $this->registeredRecordRepository->lists($request->all());
  29. if (count($registeredList)>0) {
  30. $behavior_absolute_progression = RegisteredRecord::select('absolute_progression')->orderBy('id', 'DESC')->first();//行为绝对级数
  31. $behavior_trigger_times = RegisteredRecord::select('trigger_type')->where('trigger_type', '!=', null)->count();//总触发数
  32. $behavior_effective_trigger = RegisteredRecord::select('trigger_type')->where('trigger_type', 1)->count();//有效触发数
  33. $physical_exertion = RegisteredRecord::select('physical_exertion')->sum('physical_exertion');//总消耗体力值
  34. $generation_quantity = RegisteredRecord::select('generation_quantity')->sum('generation_quantity');//总生成彩虹豆
  35. $quantity_issued = RegisteredRecord::select('quantity_issued')->sum('quantity_issued');//总发放彩虹豆
  36. foreach ($registeredList as $k => $v) {
  37. $v['all_absolute_progression'] = $behavior_absolute_progression->absolute_progression;
  38. $v['all_trigger_times'] = $behavior_trigger_times;
  39. $v['all_effective_trigger'] = $behavior_effective_trigger;
  40. $v['physical_exertion'] = intval($physical_exertion);
  41. $v['generation_quantity'] = intval($generation_quantity);
  42. $v['quantity_issued'] = intval($quantity_issued);
  43. }
  44. }
  45. $fractal = new Manager();
  46. $resource = new Collection($registeredList, new RegisteredRecordTransformer());
  47. $resource->setPaginator(new IlluminatePaginatorAdapter($registeredList));
  48. $data = $fractal->createData($resource)->toArray();
  49. $data['extra'] = [
  50. 'filters' => [
  51. 'id',
  52. 'uid',
  53. 'created_at',
  54. 'absolute_progression',
  55. 'trigger_type',
  56. 'virus_behavior_id'
  57. ],
  58. 'columns' => [
  59. 'id',
  60. 'created_at',
  61. 'virus_behavior_id',
  62. 'uid',
  63. 'trigger_time',
  64. 'physical_exertion',
  65. 'trigger_type',
  66. 'generation_type',
  67. 'absolute_progression',
  68. 'superior_uid',
  69. 'release_status',
  70. 'generation_quantity',
  71. 'quantity_issued',
  72. 'behavior_cycle_type',
  73. 'name',
  74. 'relative_series',
  75. 'is_open',
  76. 'bahavior_created_at',
  77. 'all_absolute_progression',
  78. 'all_trigger_times',
  79. 'all_effective_trigger',
  80. 'all_physical_exertion',
  81. 'all_generation_quantity',
  82. 'all_quantity_issued'
  83. ]
  84. ];
  85. return $data;
  86. }
  87. }