ProjectController.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  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. use App\Http\Requests\Coach\SetProjectRequest;
  9. use App\Http\Requests\Coach\OpenProjectRequest;
  10. /**
  11. * @group 技师端
  12. *
  13. * 项目管理相关的API接口
  14. */
  15. class ProjectController extends Controller
  16. {
  17. use ResponseTrait;
  18. protected ProjectService $service;
  19. public function __construct(ProjectService $service)
  20. {
  21. $this->service = $service;
  22. }
  23. /**
  24. * [项目]获取可开通项目列表
  25. *
  26. * @description 获取技师可以开通的项目列表,包含项目的基本信息、价格信息和服务说明,以及是否已开通状态
  27. *
  28. * @authenticated 需要技师身份认证
  29. *
  30. * @response {
  31. * "status": true,
  32. * "message": "获取成功",
  33. * "data": [
  34. * {
  35. * "id": 1, // 项目ID
  36. * "title": "精油推拿", // 项目标题
  37. * "subtitle": "专业精油推拿", // 项目副标题
  38. * "cover": "http://example.com/cover.jpg", // 项目封面图
  39. * "price": "188.00", // 项目价格
  40. * "original_price": "288.00", // 原价
  41. * "sales": 100, // 销量
  42. * "duration": 60, // 服务时长(分钟)
  43. * "project_desc": "项目描述", // 项目描述
  44. * "service_desc": "服务说明", // 服务说明
  45. * "type": 1, // 项目类型
  46. * "is_opened": false // 是否已开通
  47. * }
  48. * ]
  49. * }
  50. *
  51. * @response 404 {
  52. * "message": "技师信息不存在"
  53. * }
  54. */
  55. public function getAvailableProjects()
  56. {
  57. return $this->success(
  58. $this->service->getAvailableProjects(Auth::user()->coach)
  59. );
  60. }
  61. /**
  62. * [项目]开通/关闭项目
  63. *
  64. * @description 技师开通或关闭服务项目,包含项目状态和资格检查
  65. *
  66. * 业务流程:
  67. * 1. 验证项目ID和操作类型
  68. * 2. 调用服务层处理开关逻辑
  69. * 3. 返回操作结果
  70. *
  71. * @authenticated 需要技师身份认证
  72. *
  73. * @bodyParam project_id integer required 项目ID Example: 1
  74. * @bodyParam action string required 操作类型(open:开通 close:关闭) Example: "open"
  75. *
  76. * @response {
  77. * "status": true,
  78. * "message": "获取成功",
  79. * "data": {
  80. * "project_id": 1, // 项目ID
  81. * "project_name": "精油推拿", // 项目名称
  82. * "state": 1, // 项目状态
  83. * "state_text": "已开通" // 状态描述
  84. * }
  85. * }
  86. *
  87. * @response 404 {
  88. * "message": "项目不存在或已下架"
  89. * }
  90. * @response 422 {
  91. * "message": "技师状态异常,无法操作项目"
  92. * }
  93. */
  94. public function openProject(OpenProjectRequest $request)
  95. {
  96. // 调用服务层处理开通/关闭逻辑并返回结果
  97. return $this->success(
  98. $this->service->openProject(Auth::user()->coach, $request->validated())
  99. );
  100. }
  101. /**
  102. * [项目]项目设置
  103. *
  104. * @description 设置技师已开通项目的相关参数,包括代金券、顾客性别和交通费设置
  105. *
  106. * 业务流程:
  107. * 1. 验证项目设置参数
  108. * 2. 调用服务层处理设置更新
  109. * 3. 返回更新结果
  110. *
  111. * @authenticated 需要技师身份认证
  112. *
  113. * @bodyParam project_id integer required 项目ID Example: 1
  114. * @bodyParam voucher numeric 代金卷金额(0-10元) Example: 5.00
  115. * @bodyParam gender integer 顾客性别(0:不限 1:男 2:女) Example: 0
  116. * @bodyParam traffic_fee_type integer 交通费类型(0:免费 1:单程 2:双程) Example: 2
  117. *
  118. * @response {
  119. * "status": true,
  120. * "message": "项目设置更新成功",
  121. * "data": {
  122. * "coach_id": 1,
  123. * "settings": {
  124. * "voucher": "5.00",
  125. * "gender": 0,
  126. * "traffic_fee_type": 2
  127. * }
  128. * }
  129. * }
  130. *
  131. * @response 404 {
  132. * "message": "未开通该项目"
  133. * }
  134. * @response 422 {
  135. * "message": "代金卷金额不能超过10元"
  136. * }
  137. */
  138. public function setProject(SetProjectRequest $request)
  139. {
  140. // 调用服务层处理设置更新并返回结果
  141. return $this->success(
  142. $this->service->setProject(Auth::user()->coach, $request->validated())
  143. );
  144. }
  145. /**
  146. * [项目]获取项目设置
  147. *
  148. * @description 获取技师已开通项目的相关参数设置,包括代金券、顾客性别和交通费设置
  149. *
  150. * @authenticated 需要技师身份认证
  151. *
  152. * @queryParam project_id integer required 项目ID Example: 1
  153. *
  154. * @response {
  155. * "status": true,
  156. * "message": "获取成功",
  157. * "data": {
  158. * "project_id": 1,
  159. * "project_name": "精油推拿",
  160. * "settings": {
  161. * "voucher": "5.00", // 代金券金额
  162. * "gender": 0, // 顾客性别(0:不限 1:男 2:女)
  163. * "traffic_fee_type": 2 // 交通费类型(0:免费 1:单程 2:双程)
  164. * }
  165. * }
  166. * }
  167. *
  168. * @response 404 {
  169. * "message": "未开通该项目"
  170. * }
  171. */
  172. public function getProjectSettings(Request $request)
  173. {
  174. $validated = $request->validate([
  175. 'project_id' => 'required|integer|exists:project,id'
  176. ]);
  177. return $this->success(
  178. $this->service->getProjectSettings(Auth::user()->coach, $validated['project_id'])
  179. );
  180. }
  181. }