ProcessStatisticController.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Process;
  4. use App\Services\ProcessStatisticService;
  5. use Exception;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\Gate;
  8. use Illuminate\Support\Facades\Http;
  9. class ProcessStatisticController extends Controller
  10. {
  11. public function index(Request $request){
  12. /** @var ProcessStatisticService $processStatistics */
  13. $processStatistics=app("processStatisticService")->paginate($request->input());
  14. $owners=app("ownerService")->getSelection();
  15. $processMethods=app("processMethodService")->getSelection();
  16. return view('process.statistic',['processStatistics'=>$processStatistics,'owners'=>$owners,'processMethods'=>$processMethods]);
  17. }
  18. public function export(Request $request){
  19. if(!Gate::allows('二次加工管理-查询')){ return '没有权限'; }
  20. if ($request->checkAllSign){
  21. $params = $request->input();
  22. unset($params['checkAllSign']);
  23. $sql = app('processStatisticService')->getSql($params);
  24. }else $sql = app('processStatisticService')->getSql(["process_id"=>$request->data]);
  25. $row = ["任务号", "货主", "开始日期", "完成日期","创建日期", "单价", "预期数量", "完成数量", "收入合计",
  26. "完成时间(天)'", "总工时", "加工类型", "最高日产能", "最低日产能", "日均产能", "合计成本", "毛利润",
  27. "毛利率", "状态","加工备注","结算备注"];
  28. $column = ["process_code", "owner_name", "started_at", "ended_at","process_created_at", "process_unit_price", "process_amount", "process_completed_amount", "revenue",
  29. "duration_days", "duration_man_hours", "process_method_name", "top_capacity", "bottom_capacity",
  30. "average_capacity", "total_cost", "gross_profit", "gross_profit_rate", "process_status", "process_remark", "process_balance_remark"];
  31. $rule = ["gross_profit_rate"=> "percent", "started_at"=>"mysqlDate", "ended_at"=>"mysqlDate", "process_created_at"=>"mysqlDate"];
  32. $post = Http::post(config('go.export.url'),['type'=>'unify','sql'=>$sql, 'connection'=>'mysql',
  33. 'row'=>json_encode($row,JSON_UNESCAPED_UNICODE), 'column'=>json_encode($column), 'rule'=>json_encode($rule)]);
  34. if ($post->status() == 500){
  35. throw new Exception($post->header("Msg"));
  36. }
  37. return response($post,200, [
  38. "Content-type"=>"application/octet-stream",
  39. "Content-Disposition"=>"attachment; filename=二次加工统计记录-".date('ymdHis').'.xlsx',
  40. ]);
  41. }
  42. }