1 changed files with 117 additions and 0 deletions
			
			
		@ -0,0 +1,117 @@ | 
			
		|||||
 | 
				<?php | 
			
		||||
 | 
				
 | 
			
		||||
 | 
				namespace App\Http\Controllers\Api; | 
			
		||||
 | 
				
 | 
			
		||||
 | 
				use App\Http\Controllers\Controller; | 
			
		||||
 | 
				use App\Models\AgentProduct; | 
			
		||||
 | 
				use App\Models\Order; | 
			
		||||
 | 
				use Illuminate\Http\Request; | 
			
		||||
 | 
				
 | 
			
		||||
 | 
				/** | 
			
		||||
 | 
				 * 订单 | 
			
		||||
 | 
				 * Class OrderController | 
			
		||||
 | 
				 * @package App\Http\Controllers\Api | 
			
		||||
 | 
				 */ | 
			
		||||
 | 
				class OrderController extends Controller | 
			
		||||
 | 
				{ | 
			
		||||
 | 
					//订单列表
 | 
			
		||||
 | 
				    public function index(Request $request) | 
			
		||||
 | 
					{ | 
			
		||||
 | 
						$formData = $request->only(['page', 'status']); | 
			
		||||
 | 
						$request->validate([ | 
			
		||||
 | 
							'page' => 'regex:/^\d+$/', | 
			
		||||
 | 
							'status' => 'integer' | 
			
		||||
 | 
						], [ | 
			
		||||
 | 
							'page.regex' => '页码错误', | 
			
		||||
 | 
							'status.integer' => '未指定订单状态' | 
			
		||||
 | 
						]); | 
			
		||||
 | 
				
 | 
			
		||||
 | 
						if (array_key_exists('status', $formData) && $formData['status'] !== null) { | 
			
		||||
 | 
							$where['status'] = $formData['status']; | 
			
		||||
 | 
						} | 
			
		||||
 | 
						$where['user_id'] = $this->user_id; | 
			
		||||
 | 
				
 | 
			
		||||
 | 
						$list = Order::where($where) | 
			
		||||
 | 
							->with(['product' => fn($query) => $query->select('id', 'title', 'pictures')]) | 
			
		||||
 | 
							->select('id', 'product_id', 'price', 'num', 'created_at') | 
			
		||||
 | 
							->orderBy('id', 'DESC') | 
			
		||||
 | 
							->simplePaginate(15); | 
			
		||||
 | 
						return $this->success($list); | 
			
		||||
 | 
					} | 
			
		||||
 | 
				
 | 
			
		||||
 | 
					public function create(Request $request) | 
			
		||||
 | 
					{ | 
			
		||||
 | 
						$formData = $request->only(['id', 'name', 'mobile', 'pay_type', 'num']); | 
			
		||||
 | 
						$formData = array_map(fn($v) => trim($v), $formData); //过滤,删除首尾空
 | 
			
		||||
 | 
				
 | 
			
		||||
 | 
						//表单验证
 | 
			
		||||
 | 
						$request->validate([ | 
			
		||||
 | 
							'id' => ['required', 'regex:/^\d+$/'], | 
			
		||||
 | 
							'name' => ['required', 'between:2,20'], | 
			
		||||
 | 
							'mobile' => ['required', 'regex:/^1[3-9]\d{9}$/'], | 
			
		||||
 | 
							'pay_type' => ['required', 'in:0,1,2'], | 
			
		||||
 | 
							'num' => ['required', 'min:1'], | 
			
		||||
 | 
						], [ | 
			
		||||
 | 
							'id.required' => '未指定产品ID', | 
			
		||||
 | 
							'name.required' => '请输入联系人姓名', | 
			
		||||
 | 
							'mobile.required' => '请输入联系手机号', | 
			
		||||
 | 
							'id.regex' => '产品ID错误', | 
			
		||||
 | 
							'name.between' => '联系人姓名在2~20字符之间', | 
			
		||||
 | 
							'mobile.regex' => '请输入11位手机号', | 
			
		||||
 | 
							'pay_type.required' => '请选择支付方式', | 
			
		||||
 | 
							'pay_type.in' => '不存在此支付方式', | 
			
		||||
 | 
							'num.required' => '请输入购买数量', | 
			
		||||
 | 
							'num.min' => '购买数量输入错误', | 
			
		||||
 | 
						]); | 
			
		||||
 | 
				
 | 
			
		||||
 | 
						$product = AgentProduct::where('id', $formData['id'])->with('product')->first(); | 
			
		||||
 | 
						if (!$product) { | 
			
		||||
 | 
							$this->error('产品不存在'); | 
			
		||||
 | 
						} | 
			
		||||
 | 
				
 | 
			
		||||
 | 
						$price = $product->price; //TODO 1、成交价格还要扣除优惠券;2、产品表加库存;3、生成资金流水;4、开启事务;
 | 
			
		||||
 | 
						Order::create([ | 
			
		||||
 | 
							'user_id' => $this->user_id, | 
			
		||||
 | 
							'order_no' => $this->getOrderNo(), | 
			
		||||
 | 
							'num' => $formData['num'], | 
			
		||||
 | 
							'price' => $price, | 
			
		||||
 | 
							'name' => $formData['name'], | 
			
		||||
 | 
							'mobile' => $formData['mobile'], | 
			
		||||
 | 
							'title' => $product->product->title, | 
			
		||||
 | 
							'agent_product_id' => $product->id, | 
			
		||||
 | 
							'product_id' => $product->product_id, | 
			
		||||
 | 
							'status' => 0, | 
			
		||||
 | 
							'pay_type' => $formData['pay_type'], | 
			
		||||
 | 
						]); | 
			
		||||
 | 
						return $this->success(); | 
			
		||||
 | 
					} | 
			
		||||
 | 
				
 | 
			
		||||
 | 
					//获取应付金额
 | 
			
		||||
 | 
					public function getPrice(Request $request) | 
			
		||||
 | 
					{ | 
			
		||||
 | 
						$id = $request->input('id'); | 
			
		||||
 | 
						if (!$id || !ctype_digit($id)) { | 
			
		||||
 | 
							return $this->error('未指定ID'); | 
			
		||||
 | 
						} | 
			
		||||
 | 
				
 | 
			
		||||
 | 
						$num = (float)$request->input('num'); | 
			
		||||
 | 
						if (!$num || $num < 1) { | 
			
		||||
 | 
							return $this->error('未指定产品数量'); | 
			
		||||
 | 
						} | 
			
		||||
 | 
				
 | 
			
		||||
 | 
						return $this->success(['price' => $this->calc($id, $num)]); | 
			
		||||
 | 
					} | 
			
		||||
 | 
				
 | 
			
		||||
 | 
					//计算价格
 | 
			
		||||
 | 
					private function calc($agent_id, $num) | 
			
		||||
 | 
					{ | 
			
		||||
 | 
						return 2888.99; // TODO 此处需要详细计算,并扣除优惠价等之后的价格
 | 
			
		||||
 | 
					} | 
			
		||||
 | 
				
 | 
			
		||||
 | 
					// 生成订单号
 | 
			
		||||
 | 
					private function getOrderNo() | 
			
		||||
 | 
					{ | 
			
		||||
 | 
						list($micro, $sec) = explode(' ', microtime()); | 
			
		||||
 | 
						return date('YmdHis', $sec) . str_pad(floor($micro * 1000000), 6, 0, STR_PAD_LEFT) . mt_rand(100, 999); | 
			
		||||
 | 
					} | 
			
		||||
 | 
				} | 
			
		||||
						Write
						Preview
					
					
					Loading…
					
					Cancel
						Save
					
		Reference in new issue