GeneralRecordController.php 3.5 KB

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