EsgController.php 1.7KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. <?php
  2. namespace App\Http\Controllers\Api;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\EsgHistory;
  5. use App\Models\UploadFile;
  6. use App\Supports\Response;
  7. use Carbon\Carbon;
  8. use Illuminate\Http\Request;
  9. use Illuminate\Support\Facades\DB;
  10. use Illuminate\Support\Facades\Log;
  11. /**
  12. * @group Lottery Prize
  13. */
  14. class EsgController extends Controller
  15. {
  16. public function __construct(
  17. )
  18. {
  19. }
  20. public function histories($locale = 'tw')
  21. {
  22. $locale = $locale == "tw" ? "zh_TW" : $locale;
  23. $data = EsgHistory::where("visible", 1)->orderByDesc("selected_year", "desc")->orderByDesc("selected_month")->get();
  24. $yearList = EsgHistory::select("selected_year", \DB::raw("concat(selected_year, '年') as lable"))->distinct()->orderBy("selected_year", "desc")->pluck('lable', 'selected_year');
  25. $result = [];
  26. $result["yearList"] = $yearList;
  27. foreach($data as $item){
  28. $result["list"][$item->selected_year][] = [
  29. "operateMonth " => $item->selected_year . "." . str_pad($item->selected_month, 2, "0", STR_PAD_LEFT),
  30. "title" => $item->getTranslation("title", $locale),
  31. "description" => $item->getTranslation("description", $locale)
  32. ];
  33. }
  34. return Response::ok($result);
  35. }
  36. public function uploadFiles($locale = "tw")
  37. {
  38. $locale = $locale == "tw" ? "zh_TW" : $locale;
  39. $fileList = UploadFile::where("type", 1)->select("upload_link", "award_date")->get()->map(function ($record) {
  40. return [
  41. "uploadLink" => $record->upload_link,
  42. "awardDate" => "獲頒日期 : " . date("Y/m/d", strtotime($record->award_date))
  43. ];
  44. });
  45. return Response::ok($fileList);
  46. }
  47. }