// +---------------------------------------------------------------------- namespace app\controller\merchant\store\order; use app\common\repositories\store\ExcelRepository; use app\common\repositories\store\order\MerchantReconciliationRepository; use app\common\repositories\store\order\StoreOrderProductRepository; use app\common\repositories\store\order\StoreOrderRepository; use app\common\repositories\store\order\StoreOrderStatusRepository; use app\common\repositories\store\order\StoreRefundStatusRepository; use crmeb\services\ExcelService; use think\App; use crmeb\basic\BaseController; use app\common\repositories\store\order\StoreRefundOrderRepository as repository; use think\exception\ValidateException; class RefundOrder extends BaseController { /** * @var repository */ protected $repository; /** * Order constructor. * @param App $app * @param repository $repository */ public function __construct(App $app, repository $repository) { parent::__construct($app); $this->repository = $repository; } /** * 获取可退款的商品信息 * @param $id * @param StoreOrderRepository $storeOrderRepository * @param StoreOrderProductRepository $orderProductRepository * @return \think\response\Json * @author Qinii * @day 2023/7/13 */ public function check($id, StoreOrderRepository $storeOrderRepository, StoreOrderProductRepository $orderProductRepository) { $order = $storeOrderRepository->getSearch(['mer_id' => $this->request->merId()])->where('order_id',$id)->find(); if (!$order) return app('json')->fail('订单状态有误'); // if (!$order->refund_status) return app('json')->fail('订单已过退款/退货期限'); if ($order->status < 0) return app('json')->fail('订单已退款'); if ($order->status == 10) return app('json')->fail('订单不支持退款'); $product = $orderProductRepository->userRefundProducts([],0,$id,0); $total_refund_price = $this->repository->getRefundsTotalPrice($order,$product,0); $activity_type = $order->activity_type; $status = (!$order->status || $order->status == 9) ? 0 : $order->status; $postage_price = 0; return app('json')->success(compact('activity_type', 'total_refund_price','postage_price', 'product', 'status')); } /** * 计算退款金额 * * @param StoreOrderRepository $storeOrderRepository 订单仓库 * @return \think\response\Json */ public function compute(StoreOrderRepository $storeOrderRepository) { $refund = $this->request->param('refund', []); $orderId = $this->request->param('order_id', 0); $order = $storeOrderRepository->getSearch(['mer_id' => $this->request->merId()])->where('order_id', $orderId)->find(); // 判断订单是否存在 if (!$order) return app('json')->fail('订单状态有误'); // if (!$order->refund_status) return app('json')->fail('订单已过退款/退货期限'); // 判断订单是否可退款 if ($order->status < 0) return app('json')->fail('订单已退款'); if ($order->status == 10) return app('json')->fail('订单不支持退款'); $totalRefundPrice = $this->repository->compute($order, $refund); // 返回结果 return app('json')->success(compact('totalRefundPrice')); } /** * 创建退款单,并执行退款操作 * @param StoreOrderRepository $storeOrderRepository * @return \think\response\Json * @author Qinii * @day 2023/7/13 */ public function create(StoreOrderRepository $storeOrderRepository) { $data = $this->request->params(['refund_message','refund_price','mer_mark']); $refund = $this->request->param('refund',[]); $orderId = $this->request->param('order_id',02); $order = $storeOrderRepository->getSearch(['mer_id' => $this->request->merId()])->where('order_id',$orderId)->find(); if (!$order) return app('json')->fail('订单状态有误'); // if (!$order->refund_status) return app('json')->fail('订单已过退款/退货期限'); if ($order->status < 0) return app('json')->fail('订单已退款'); if ($order->status == 10) return app('json')->fail('订单不支持退款'); $data['refund_type'] = 1; $data['admin_id'] = $this->request->adminId(); $data['user_type'] = $this->request->userType(); $refund = $this->repository->merRefund($order,$refund,$data); return app('json')->success('退款成功',['refund_order_id' => $refund->refund_order_id]); } /** * 获取列表 * * @return \think\response\Json * @author Qinii * @day 2020-06-12 */ public function lst() { // 获取分页参数 list($page, $limit) = $this->getPage(); // 获取查询条件 $where = $this->request->params(['refund_order_sn', 'status', 'refund_type', 'date', 'order_sn', 'id', 'delivery_id', 'user_type', 'username','uid','nickname','real_name','phone']); // 添加商家ID条件 $where['mer_id'] = $this->request->merId(); // 调用仓库获取列表并返回JSON格式数据 return app('json')->success($this->repository->getList($where, $page, $limit)); } /** * 获取详情 * * @param int $id 订单ID * @return \think\response\Json * @author Qinii * @day 2020-06-12 */ public function detail($id) { // 判断订单是否存在 if (!$this->repository->getExistsById($this->request->merId(), $id)) return app('json')->fail('数据不存在'); // 调用仓库获取订单详情并返回JSON格式数据 return app('json')->success($this->repository->getOne($id)); } /** * 切换审核状态 * * @param int $id 审核ID * @return \think\response\Json */ public function switchStatus($id) { if (!$this->repository->getStatusExists($this->request->merId(), $id)) return app('json')->fail('信息或状态错误'); // 获取审核状态 $status = ($this->request->param('status') == 1) ? 1 : -1; event('refund.status', compact('id', 'status')); if ($status == 1) { $data = $this->request->params(['mer_delivery_user', 'mer_delivery_address', 'phone']); if ($data['phone'] && isPhone($data['phone'])) return app('json')->fail('请输入正确的手机号'); // 设置审核状态和拒绝原因并保存数据 $data['status'] = $status; $this->repository->agree($id, $data); } else { $fail_message = $this->request->param('fail_message', ''); if ($status == -1 && empty($fail_message)) return app('json')->fail('未通过必须填写'); // 设置审核状态和拒绝原因并保存数据 $data['status'] = $status; $data['fail_message'] = $fail_message; $this->repository->refuse($id, $data); } // 返回成功信息 return app('json')->success('审核成功'); } /** * 收货后确定退款 * @param $id * @return mixed * @author Qinii * @day 2020-06-12 */ public function refundPrice($id) { if(!$this->repository->getRefundPriceExists($this->request->merId(),$id)) { return app('json')->fail('信息或状态错误'); } $params = $this->request->params(['status','fail_message']); if (!$params['status']) { return app('json')->fail('请选择状态'); } if ($params['status'] == -1 && empty($params['fail_message'])) { return app('json')->fail('拒绝原因必须填写'); } $this->repository->adminRefund($id, $params); return app('json')->success('审核成功'); } /** * 切换状态表单 * @param int $id 订单ID * @return \think\response\Json */ public function switchStatusForm($id) { if (!$this->repository->getStatusExists($this->request->merId(), $id)) return app('json')->fail('信息或状态错误'); // 返回订单状态表单数据 return app('json')->success(formToData($this->repository->statusForm($id))); } /** * 删除订单 * @param int $id 订单ID * @return \think\response\Json */ public function delete($id) { if (!$this->repository->getUserDelExists($this->request->merId(), $id)) return app('json')->fail('信息或状态错误'); $this->repository->update($id, ['is_system_del' => 1]); // 返回删除成功信息 return app('json')->success('删除成功'); } /** * 标记表单 * @param int $id 订单ID * @return \think\response\Json */ public function markForm($id) { if (!$this->repository->getExistsById($this->request->merId(), $id)) return app('json')->fail('数据不存在'); // 返回订单标记表单数据 return app('json')->success(formToData($this->repository->markForm($id))); } /** * 标记订单 * @param int $id 订单ID * @return \think\response\Json */ public function mark($id) { if (!$this->repository->getExistsById($this->request->merId(), $id)) return app('json')->fail('数据不存在'); $this->repository->update($id, ['mer_mark' => $this->request->param('mer_mark', '')]); // 返回标记成功信息 return app('json')->success('备注成功'); } /** * 查看订单日志 * @param int $id 订单ID * @return \think\response\Json */ public function log($id) { list($page, $limit) = $this->getPage(); $where = $this->request->params(['date', 'user_type']); $where['id'] = $id; $where['type'] = StoreOrderStatusRepository::TYPE_REFUND; $data = app()->make(StoreOrderStatusRepository::class)->search($where, $page, $limit); return app('json')->success($data); } /** * 重新获取对账单列表 * * @param int $id 对账单ID * @return \think\response\Json */ public function reList($id) { // 获取分页参数 [$page, $limit] = $this->getPage(); // 实例化商家对账单仓库 $make = app()->make(MerchantReconciliationRepository::class); // 判断对账单是否存在 if (!$make->getWhereCount(['mer_id' => $this->request->merId(), 'reconciliation_id' => $id])) return app('json')->fail('数据不存在'); // 构造查询条件 $where = ['reconciliation_id' => $id, 'type' => 1]; // 调用仓库方法获取对账单列表并返回结果 return app('json')->success($this->repository->reconList($where, $page, $limit)); } /** * 快递查询 * @param $id * @return mixed * @author Qinii * @day 2020-06-25 */ public function express($id) { return app('json')->success($this->repository->express($id)); } /** * 创建 Excel 文件 * * @return \think\response\Json */ public function createExcel() { $where = $this->request->params(['refund_order_sn', 'status', 'refund_type', 'date', 'order_sn', 'id']); // 添加商家 ID 条件 $where['mer_id'] = $this->request->merId(); // 获取分页参数 [$page, $limit] = $this->getPage(); // 调用 ExcelService 类的 refundOrder 方法获取数据 $data = app()->make(ExcelService::class)->refundOrder($where, $page, $limit); // 返回 JSON 格式的数据 return app('json')->success($data); } }