LaborReportsCountingRecordService.php 6.1 KB

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