CommentRecordController.php 3.5 KB

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