LaborReportsCountingRecordService.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. <?php
  2. namespace App\Services;
  3. use App\LaborReport;
  4. use Carbon\Carbon;
  5. use DateTime;
  6. use Illuminate\Support\Facades\Auth;
  7. use Illuminate\Support\Facades\Cache;
  8. use Illuminate\Support\Str;
  9. use Ramsey\Uuid\Type\Integer;
  10. use App\Traits\ServiceAppAop;
  11. class LaborReportsCountingRecordService
  12. {
  13. use ServiceAppAop;
  14. protected $modelClass=LaborReportsCountingRecord::class;
  15. public function __construct(LaborReport $laborReport)
  16. {
  17. $laborReport::$withoutAppends = false;
  18. }
  19. public function userGroupsCount($start, $end)
  20. {
  21. $resultByCache = Cache::remember('userGroupsCount_' . $start . '_' . $end, 600, function () use ($start, $end) {
  22. return LaborReport::query()->selectRaw('user_workgroup_id,count(user_workgroup_id) amount')
  23. ->with('userWorkgroup', 'laborReportStatus')
  24. ->whereDate('created_at', '>=', $start)
  25. ->whereDate('created_at', '<', $end)
  26. ->groupBy('user_workgroup_id')->get();
  27. });
  28. $resultByCache = $resultByCache->filter(function ($item) {
  29. return $item->amount != 0;
  30. });
  31. $result = collect();
  32. $resultByCache->each(function ($item) use (&$result) {
  33. $result->push(
  34. [
  35. 'value' => $item->amount,
  36. 'name' => $item->userWorkgroup->name,
  37. 'id' => $item->userWorkgroup->id,
  38. ]
  39. );
  40. });
  41. return $result->sortBy('id');
  42. }
  43. public function get($start, $end, $unit = '日')
  44. {
  45. $resultByCache = $this->getByCache($start, $end, $unit);
  46. if ($resultByCache['dateList'] == []) {
  47. return $resultByCache['dataList'];
  48. } else {
  49. $this->syncDBToCache($resultByCache['dateList'], $unit);
  50. return $this->getByCache($start, $end, $unit)['dataList'];
  51. }
  52. }
  53. public function getByCache($start, $end, $unit)
  54. {
  55. $dataList = collect();
  56. $dateList = collect($this->periodDateToArray($start, $end, $unit));
  57. $result = [];
  58. foreach ($dateList as $date) {
  59. $key = 'laborReportsCountingRecords_' . $date . '_' . $unit;
  60. $item = Cache::get($key);
  61. if ($item) {
  62. $dataList->push($item);
  63. $dateList = $dateList->reject(function ($value) use ($date) {
  64. return $value == $date;
  65. });
  66. }
  67. }
  68. $result['dataList'] = $dataList;
  69. $result['dateList'] = $dateList->toArray();
  70. return $result;
  71. }
  72. /**
  73. * @param $start
  74. * @param $end
  75. * @param string $unit
  76. * @return array
  77. */
  78. private function periodDateToArray($start, $end, $unit = '日')
  79. {
  80. $dataArray = [];
  81. switch ($unit) {
  82. case '日';
  83. foreach (Carbon::parse($start)->daysUntil($end, 1)->toArray() as $item) {
  84. $dataArray[] = $item->toDateString();
  85. }
  86. break;
  87. case '月';
  88. foreach (Carbon::parse($start)->monthsUntil($end, 1)->toArray() as $item) {
  89. $dataArray[] = $item->year . '-' . $item->format('m') . '';
  90. }
  91. break;
  92. case '年';
  93. foreach (Carbon::parse($start)->yearsUntil($end, 1)->toArray() as $item) {
  94. $dataArray[] = $item->year.'';
  95. }
  96. break;
  97. default:
  98. break;
  99. }
  100. return $dataArray;
  101. }
  102. private function syncDBToCache($dateList, $unit)
  103. {
  104. switch ($unit) {
  105. case '日':
  106. $query = LaborReport::query()
  107. ->selectRaw("DATE_FORMAT(created_at,'%Y-%m-%d') as date_target, count(DISTINCT enter_number ) as counter");
  108. foreach ($dateList as $startOfWeek) {
  109. $query->orWhere(function ($query) use ($startOfWeek) {
  110. $query->whereDate('created_at', $startOfWeek);
  111. });
  112. }
  113. $dataList = $query->groupBy('date_target')->get();
  114. $dataList->each(function ($item) use ($unit) {
  115. $date = $item->date_target;
  116. $key = 'laborReportsCountingRecords_' . $date . '_' . $unit;
  117. Cache::put($key, $item);
  118. });
  119. break;
  120. case '月':
  121. $query = LaborReport::query()->selectRaw("DATE_FORMAT(created_at,'%Y-%m') as date_target, count(DISTINCT enter_number ) as counter");
  122. foreach ($dateList as $date) {
  123. $query->orWhere(function ($query) use ($date) {
  124. $year = Str::of($date)->explode('-')[0];
  125. $month = Str::of($date)->explode('-')[1];
  126. $query->whereYear('created_at', $year)->whereMonth('created_at', $month);
  127. });
  128. }
  129. $dataList = $query->groupBy('date_target')->get();
  130. $dataList->each(function ($item) use ($unit) {
  131. $date = $item->date_target;
  132. $key = 'laborReportsCountingRecords_' . $date . '_' . $unit;
  133. Cache::put($key, $item);
  134. });
  135. break;
  136. case '年':
  137. $query = LaborReport::query()->selectRaw("DATE_FORMAT(created_at,'%Y') as date_target, count(DISTINCT enter_number ) as counter");
  138. foreach ($dateList as $date) {
  139. $query->orWhere(function ($query) use ($date) {
  140. $year = Str::of($date)->explode('-')[0];
  141. $query->whereYear('created_at', $year)->whereYear('created_at', $year);
  142. });
  143. }
  144. $dataList = $query->groupBy('date_target')->get();
  145. $dataList->each(function ($item) use ($unit) {
  146. $date = $item->date_target;
  147. $key = 'laborReportsCountingRecords_' . $date . '_' . $unit;
  148. Cache::put($key, $item);
  149. });
  150. break;
  151. default:
  152. break;
  153. }
  154. }
  155. }