OrderController.php 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. <?php
  2. namespace App\Http\Controllers\Client;
  3. use App\Http\Controllers\Controller;
  4. use App\Services\Client\OrderService;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\Auth;
  7. /**
  8. * @group 用户端
  9. *
  10. * 订单相关的API接口
  11. */
  12. class OrderController extends Controller
  13. {
  14. protected OrderService $service;
  15. public function __construct(OrderService $service)
  16. {
  17. $this->service = $service;
  18. }
  19. /**
  20. * 订单初始化
  21. *
  22. * 初始化订单
  23. *
  24. * @authenticated
  25. *
  26. * @bodyParam coach_id int required 技师ID. Example: 1
  27. * @bodyParam area_code string required 区划代码. Example: 370602
  28. * @bodyParam project_id int required 项目ID. Example: 1
  29. *
  30. * @response {
  31. * "status": "success",
  32. * "data": {}
  33. * }
  34. */
  35. public function initialize(Request $request)
  36. {
  37. $data = $request->only(['coach_id', 'area_code', 'project_id']);
  38. return $this->service->initialize(Auth::user()->id, $data);
  39. }
  40. /**
  41. * 创建订单
  42. *
  43. * 创建订单
  44. *
  45. * @authenticated
  46. *
  47. * @bodyParam project_id int required 项目ID. Example: 1
  48. * @bodyParam address_id int required 地址ID. Example: 1
  49. * @bodyParam coach_id int required 技师ID. Example: 6
  50. * @bodyParam use_balance boolean 使用余额. Example: false
  51. * @bodyParam service_time datetime required 服务时间. Example: 2024-01-01 10:00:00
  52. * @bodyParam order_id int 订单ID. Example: null
  53. *
  54. * @response {
  55. * "status": "success",
  56. * "data": {}
  57. * }
  58. */
  59. public function create(Request $request)
  60. {
  61. $data = $request->only(['project_id', 'address_id', 'coach_id', 'use_balance', 'order_id', 'service_time']);
  62. return $this->service->createOrder(Auth::user()->id, $data);
  63. }
  64. /**
  65. * 结束订单
  66. *
  67. * 结束订单
  68. *
  69. * @authenticated
  70. *
  71. * @bodyParam order_id int required 订单ID. Example: 1
  72. *
  73. * @response {
  74. * "status": "success",
  75. * "data": {}
  76. * }
  77. */
  78. public function finish(Request $request)
  79. {
  80. $userId = Auth::user()->id;
  81. $orderId = $request->input('order_id');
  82. return $this->service->finishOrder($userId, $orderId);
  83. }
  84. /**
  85. * 确认技师离开
  86. *
  87. * 确认技师离开
  88. *
  89. * @authenticated
  90. *
  91. * @bodyParam order_id int required 订单ID. Example: 123
  92. *
  93. * @response {
  94. * "status": "success",
  95. * "data": {}
  96. * }
  97. */
  98. public function confirmLeave(Request $request)
  99. {
  100. $userId = Auth::user()->id;
  101. $orderId = $request->input('order_id');
  102. return $this->service->confirmLeave($userId, $orderId);
  103. }
  104. /**
  105. * 取消订单
  106. *
  107. * 取消订单
  108. *
  109. * @authenticated
  110. *
  111. * @bodyParam order_id int required 订单ID. Example: 123
  112. *
  113. * @response {
  114. * "status": "success",
  115. * "data": {}
  116. * }
  117. */
  118. public function cancel(Request $request)
  119. {
  120. $userId = Auth::user()->id;
  121. $orderId = $request->input('order_id');
  122. return $this->service->cancelOrder($userId, $orderId);
  123. }
  124. /**
  125. * 获取订单列表
  126. *
  127. * 获取订单列表
  128. *
  129. * @authenticated
  130. *
  131. * @response {
  132. * "status": "success",
  133. * "data": []
  134. * }
  135. */
  136. public function list()
  137. {
  138. return $this->service->getOrderList(Auth::user()->id);
  139. }
  140. /**
  141. * 获取订单详情
  142. *
  143. * 获取订单详情
  144. *
  145. * @authenticated
  146. *
  147. * @urlParam id required 订单ID. Example: 1
  148. *
  149. * @response {
  150. * "status": "success",
  151. * "data": {}
  152. * }
  153. */
  154. public function detail($id)
  155. {
  156. return $this->service->getOrderDetail(Auth::user()->id, $id);
  157. }
  158. /**
  159. * 订单退款
  160. *
  161. * 订单退款
  162. *
  163. * @authenticated
  164. *
  165. * @urlParam id required 订单ID. Example: 1
  166. *
  167. * @response {
  168. * "status": "success",
  169. * "data": {}
  170. * }
  171. */
  172. public function refund($id)
  173. {
  174. return $this->service->refundOrder($id);
  175. }
  176. /**
  177. * 获取代理商配置
  178. *
  179. * 获取代理商配置
  180. *
  181. * @authenticated
  182. *
  183. * @bodyParam agent_id int required 代理商ID. Example: 1
  184. *
  185. * @response {
  186. * "min_distance": 0,
  187. * "min_fee": 0,
  188. * "per_km_fee": 0
  189. * }
  190. */
  191. public function getAgentConfig(Request $request)
  192. {
  193. $agentId = $request->input('agent_id');
  194. return $this->service->getAgentConfig($agentId);
  195. }
  196. /**
  197. * 获取技师配置
  198. *
  199. * 获取技师配置
  200. *
  201. * @authenticated
  202. *
  203. * @bodyParam coach_id int required 技师ID. Example: 1
  204. *
  205. * @response {
  206. * "delivery_fee_type": "round_trip",
  207. * "charge_delivery_fee": true
  208. * }
  209. */
  210. public function getCoachConfig(Request $request)
  211. {
  212. $coachId = $request->input('coach_id');
  213. return $this->service->getCoachConfig($coachId);
  214. }
  215. /**
  216. * 计算订单金额
  217. *
  218. * 计算订单金额
  219. *
  220. * @authenticated
  221. *
  222. * @bodyParam address_id int required 地址ID. Example: 1
  223. * @bodyParam coach_id int required 技师ID. Example: 1
  224. * @bodyParam project_id int required 项目ID. Example: 1
  225. * @bodyParam agent_id int 代理商ID. Example: 1
  226. * @bodyParam use_balance boolean 使用余额. Example: 0
  227. *
  228. * @response {
  229. * "total_amount": 0,
  230. * "balance_amount": 0,
  231. * "pay_amount": 0,
  232. * "coupon_amount": 0,
  233. * "tip_amount": 0,
  234. * "project_amount": 0,
  235. * "delivery_fee": 0
  236. * }
  237. */
  238. public function calculateOrderAmount(Request $request)
  239. {
  240. $userId = Auth::user()->id;
  241. $addressId = $request->input('address_id');
  242. $coachId = $request->input('coach_id');
  243. $projectId = $request->input('project_id');
  244. $agentId = $request->input('agent_id');
  245. $useBalance = $request->input('use_balance', 0);
  246. return $this->service->calculateOrderAmount($userId, $addressId, $coachId, $projectId, $agentId, $useBalance);
  247. }
  248. /**
  249. * 加钟
  250. *
  251. * 加钟
  252. *
  253. * @authenticated
  254. *
  255. * @bodyParam project_id int required 项目ID. Example: 1
  256. * @bodyParam use_balance boolean 使用余额. Example: false
  257. * @bodyParam order_id int 订单ID. Example: 1
  258. *
  259. * @response {
  260. * "status": "success",
  261. * "data": {}
  262. * }
  263. */
  264. public function addTime(Request $request)
  265. {
  266. $data = $request->only(['project_id', 'use_balance', 'order_id']);
  267. return $this->service->createOrder(Auth::user()->id, $data);
  268. }
  269. /**
  270. * 指定技师
  271. *
  272. * 指定技师
  273. *
  274. * @authenticated
  275. *
  276. * @urlParam order_id required 订单ID. Example: 123
  277. *
  278. * @bodyParam coach_id int required 技师ID. Example: 1
  279. *
  280. * @response {
  281. * "status": "success",
  282. * "data": {}
  283. * }
  284. */
  285. public function assignCoach(Request $request, $orderId)
  286. {
  287. $userId = Auth::user()->id;
  288. $coachId = $request->input('coach_id');
  289. return $this->service->assignCoach($userId, $orderId, $coachId);
  290. }
  291. }