ProjectController.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php
  2. namespace App\Http\Controllers\Coach;
  3. use App\Http\Controllers\Controller;
  4. use App\Services\Coach\ProjectService;
  5. use App\Traits\ResponseTrait;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\Auth;
  8. /**
  9. * @group 技师端
  10. *
  11. * 项目管理相关的API接口
  12. */
  13. class ProjectController extends Controller
  14. {
  15. use ResponseTrait;
  16. protected ProjectService $service;
  17. public function __construct(ProjectService $service)
  18. {
  19. $this->service = $service;
  20. }
  21. /**
  22. * [项目]获取可开通项目列表
  23. *
  24. * @description 获取技师可以开通的项目列表
  25. *
  26. * @authenticated
  27. *
  28. * @response {
  29. * "data": {
  30. * "items": [
  31. * {
  32. * "id": 1,
  33. * "name": "精油推拿",
  34. * "cover": "http://example.com/cover.jpg",
  35. * "price": "188.00",
  36. * "duration": 60,
  37. * "description": "项目描述",
  38. * "qualification_requirements": "资质要求"
  39. * }
  40. * ],
  41. * "total": 10
  42. * }
  43. * }
  44. */
  45. public function getAvailableProjects()
  46. {
  47. return $this->success($this->service->getAvailableProjects(Auth::user()->id));
  48. }
  49. /**
  50. * [项目]开通项目
  51. *
  52. * @description 技师开通新的服务项目
  53. *
  54. * @authenticated
  55. *
  56. * @bodyParam project_id integer required 项目ID Example: 1
  57. *
  58. * @response {
  59. * "message": "项目开通成功",
  60. * "project_id": 1,
  61. * "project_name": "精油推拿"
  62. * }
  63. */
  64. public function openProject(Request $request)
  65. {
  66. $data = $request->validate([
  67. 'project_id' => 'required|integer|exists:project,id',
  68. ]);
  69. return $this->success($this->service->openProject(Auth::user()->id, $data));
  70. }
  71. /**
  72. * [项目]设置项目参数
  73. *
  74. * @description 设置技师已开通项目的相关参数
  75. *
  76. * @authenticated
  77. *
  78. * @bodyParam project_id integer required 项目ID Example: 1
  79. * @bodyParam discount_amount numeric 优惠金额(0-10元) Example: 5.00
  80. * @bodyParam service_gender integer 服务性别(0:不限 1:男 2:女) Example: 0
  81. * @bodyParam service_distance integer 服务距离(公里,0表示不限) Example: 5
  82. * @bodyParam traffic_fee_type integer 交通费类型(0:免费 1:单程 2:双程) Example: 2
  83. * @bodyParam traffic_fee numeric 交通费金额 Example: 10.00
  84. *
  85. * @response {
  86. * "message": "项目设置更新成功",
  87. * "project_id": 1,
  88. * "settings": {
  89. * "discount_amount": "5.00",
  90. * "service_gender": 0,
  91. * "service_distance": 5,
  92. * "traffic_fee_type": 2,
  93. * "traffic_fee": "10.00"
  94. * }
  95. * }
  96. */
  97. public function setProject(Request $request)
  98. {
  99. $data = $request->validate([
  100. 'project_id' => 'required|integer|exists:project,id',
  101. 'discount_amount' => 'nullable|numeric|min:0|max:10',
  102. 'service_gender' => 'nullable|integer|in:0,1,2',
  103. 'service_distance' => 'nullable|integer|min:0',
  104. 'traffic_fee_type' => 'nullable|integer|in:0,1,2',
  105. 'traffic_fee' => 'nullable|numeric|min:0',
  106. ]);
  107. return $this->success($this->service->setProject(Auth::user()->id, $data));
  108. }
  109. }