Index.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <?php
  2. namespace app\api\controller\inspection;
  3. use app\api\controller\inspection\Base;
  4. use app\common\Service\InspectService;
  5. use app\common\Enum\StatusEnum;
  6. /**
  7. * 示例接口
  8. */
  9. class Index extends Base
  10. {
  11. /**
  12. * 获取验货选项列表
  13. */
  14. public function getOptions()
  15. {
  16. $params = [
  17. 'status' => StatusEnum::ENABLED,
  18. ];
  19. $options = InspectService::getInspectionItems($params);
  20. $this->success('获取成功', $options);
  21. }
  22. /**
  23. * 提交验货任务
  24. *
  25. * @ApiTitle (提交验货任务)
  26. * @ApiSummary (提交验货任务,包含验货结果和照片信息)
  27. * @ApiMethod (POST)
  28. * @ApiRoute (/api/inspection/index/submitTask)
  29. * @ApiParams (name="order_id", type="integer", required=true, description="订单ID")
  30. * @ApiParams (name="order_goods_id", type="integer", required=true, description="订单商品ID")
  31. * @ApiParams (name="inspector_id", type="integer", required=true, description="验货员ID")
  32. * @ApiParams (name="remark", type="string", required=false, description="备注信息")
  33. * @ApiParams (name="images", type="string", required=false, description="任务图片,多张用逗号分隔")
  34. * @ApiParams (name="start_time", type="integer", required=false, description="任务开始时间戳")
  35. * @ApiParams (name="end_time", type="integer", required=false, description="任务结束时间戳")
  36. * @ApiParams (name="task_id", type="integer", required=false, description="任务ID,更新时传入")
  37. * @ApiParams (name="results", type="array", required=true, description="验货结果数组")
  38. * @ApiParams (name="results.item_id", type="integer", required=true, description="检查项ID")
  39. * @ApiParams (name="results.name", type="string", required=false, description="检查项名称")
  40. * @ApiParams (name="results.is_qualified", type="integer", required=true, description="是否合格 0:否 1:是")
  41. * @ApiParams (name="results.remark", type="string", required=false, description="不合格原因")
  42. * @ApiParams (name="results.photos", type="array", required=false, description="照片数组")
  43. * @ApiParams (name="results.photos.photo_url", type="string", required=true, description="照片URL")
  44. * @ApiReturnParams (name="code", type="integer", required=true, sample="1")
  45. * @ApiReturnParams (name="msg", type="string", required=true, sample="验货任务提交成功")
  46. * @ApiReturnParams (name="data", type="object", description="返回数据")
  47. * @ApiReturn ({
  48. 'code':'1',
  49. 'msg':'验货任务提交成功',
  50. 'data': {
  51. 'task_id': 123
  52. }
  53. })
  54. */
  55. public function submitTask()
  56. {
  57. $params = $this->request->post();
  58. // 验证必要参数
  59. if (empty($params['order_id'])) {
  60. $this->error('订单ID不能为空');
  61. }
  62. if (empty($params['order_goods_id'])) {
  63. $this->error('订单商品ID不能为空');
  64. }
  65. $params['inspector_id'] = $this->auth->id;
  66. if (empty($params['results']) || !is_array($params['results'])) {
  67. $this->error('验货结果不能为空');
  68. }
  69. // 组装任务数据
  70. $taskData = [
  71. 'order_id' => $params['order_id'],
  72. 'order_goods_id' => $params['order_goods_id'],
  73. 'inspector_id' => $params['inspector_id'],
  74. 'remark' => $params['remark'] ?? '',
  75. 'images' => $params['images'] ?? '',
  76. 'start_time' => $params['start_time'] ?? time(),
  77. 'end_time' => $params['end_time'] ?? time(),
  78. 'task_status' => 1, // 进行中
  79. 'status' => 1 // 开启
  80. ];
  81. // 如果是更新任务,传入task_id
  82. if (!empty($params['task_id'])) {
  83. $taskData['task_id'] = $params['task_id'];
  84. }
  85. // 组装结果数据
  86. $resultData = [];
  87. foreach ($params['results'] as $result) {
  88. if (empty($result['item_id'])) {
  89. $this->error('检查项ID不能为空');
  90. }
  91. $resultItem = [
  92. 'item_id' => $result['item_id'],
  93. 'name' => $result['name'] ?? '',
  94. 'is_qualified' => $result['is_qualified'] ?? 1,
  95. 'remark' => $result['remark'] ?? '',
  96. 'photos' => $result['photos'] ?? []
  97. ];
  98. $resultData[] = $resultItem;
  99. }
  100. // 调用服务提交验货任务
  101. list($code, $msg, $data) = InspectService::submitInspectionTask($taskData, $resultData);
  102. if ($code == 1) {
  103. $this->success($msg, $data);
  104. } else {
  105. $this->error($msg);
  106. }
  107. }
  108. //
  109. }