ProjectController.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. <?php
  2. namespace App\Http\Controllers\Coach;
  3. use Illuminate\Http\Request;
  4. use App\Traits\ResponseTrait;
  5. use App\Http\Controllers\Controller;
  6. use Illuminate\Support\Facades\Auth;
  7. use App\Services\Coach\ProjectService;
  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. * "status": true,
  30. * "message": "获取成功",
  31. * "data": [
  32. * {
  33. * "id": 1, // 项目ID
  34. * "title": "精油推拿", // 项目标题
  35. * "subtitle": "专业精油推拿", // 项目副标题
  36. * "cover": "http://example.com/cover.jpg", // 项目封面图
  37. * "price": "188.00", // 项目价格
  38. * "original_price": "288.00", // 原价
  39. * "sales": 100, // 销量
  40. * "duration": 60, // 服务时长(分钟)
  41. * "project_desc": "项目描述", // 项目描述
  42. * "service_desc": "服务说明", // 服务说明
  43. * "type": 1, // 项目类型
  44. * "is_opened": false // 是否已开通
  45. * }
  46. * ]
  47. * }
  48. *
  49. * @response 404 {
  50. * "message": "技师信息不存在"
  51. * }
  52. */
  53. public function getAvailableProjects()
  54. {
  55. return $this->success(
  56. $this->service->getAvailableProjects(Auth::user()->coach)
  57. );
  58. }
  59. /**
  60. * [项目]开通项目
  61. *
  62. * @description 技师开通新的服务项目
  63. *
  64. * @authenticated
  65. *
  66. * @bodyParam project_id integer required 项目ID Example: 1
  67. *
  68. * @response {
  69. * "message": "项目开通成功",
  70. * "project_id": 1,
  71. * "project_name": "精油推拿"
  72. * }
  73. */
  74. public function openProject(Request $request)
  75. {
  76. $data = $request->validate([
  77. 'project_id' => 'required|integer|exists:project,id',
  78. ]);
  79. return $this->success($this->service->openProject(Auth::user()->id, $data));
  80. }
  81. /**
  82. * [项目]项目设置
  83. *
  84. * @description 设置技师已开通项目的相关参数
  85. *
  86. * @authenticated
  87. *
  88. * @bodyParam project_id integer required 项目ID Example: 1
  89. * @bodyParam voucher numeric 代金卷金额(0-10元) Example: 5.00
  90. * @bodyParam gender integer 顾客性别(0:不限 1:男 2:女) Example: 0
  91. * @bodyParam traffic_fee integer 路费类型(0:免费 1:单程 2:双程) Example: 2
  92. *
  93. * @response {
  94. * "message": "项目设置更新成功",
  95. * "project_id": 1,
  96. * "settings": {
  97. * "voucher": "5.00",
  98. * "gender": 0,
  99. * "traffic_fee": 2,
  100. * }
  101. * }
  102. */
  103. public function setProject(Request $request)
  104. {
  105. $data = $request->validate([
  106. 'project_id' => 'required|integer|exists:project,id',
  107. 'voucher' => 'nullable|numeric|min:0|max:10',
  108. 'gender' => 'nullable|integer|in:0,1,2',
  109. 'traffic_fee' => 'nullable|integer|in:0,1,2',
  110. ]);
  111. return $this->success($this->service->setProject(Auth::user()->id, $data));
  112. }
  113. }