getOrdergoodsList(['order_id' => $order_id]); $data = []; $pintuan_list = [];//需要后续处理的促销活动 $ppintuanorder_model = model('ppintuanorder'); foreach ($goods_list as $goods) { $data[$goods['goods_id']] = $goods['goods_num']; //如果是拼团 if ($goods['goods_type'] == 6) { $pintuan_list[] = $goods; } $condition = []; $condition[] = ['order_id', '=', $order_info['order_id']]; $condition[] = ['pintuanorder_type', '=', 0]; $condition[] = ['pintuanorder_state', '=', 1]; $ppintuanorder_model->editPpintuanorder($condition, ['pintuanorder_state' => 0]); } if ($if_quque) { \mall\queue\QueueClient::push('cancelOrderUpdateStorage', $data); } else { \model('queue', 'logic')->cancelOrderUpdateStorage($data); } if ($if_update_account) { $predeposit_model = model('predeposit'); //注意:当用户全额使用预存款进行支付,并不会冻结, 当用户使用部分预存款进行支付,支付的预存款则会冻结.也就是支付成功之后不会有冻结资金,当未支付成功,使用的预付款变为冻结资金。 if ($order_info['order_state'] == ORDER_STATE_NEW || $order_info['order_state'] == ORDER_STATE_DEPOSIT || $order_info['order_state'] == ORDER_STATE_REST) { //解冻充值卡 $rcb_amount = floatval($order_info['rcb_amount']); if ($order_info['order_state'] == ORDER_STATE_REST && $role != 'admin' && $role != 'seller') {//非管理员和卖家取消订单不退定金 $rcb_amount -= $order_info['presell_deposit_amount']; $data_pd = []; $data_pd['member_id'] = $order_info['buyer_id']; $data_pd['member_name'] = $order_info['buyer_name']; $data_pd['amount'] = $rcb_amount > 0 ? $order_info['presell_deposit_amount'] : $order_info['rcb_amount']; $data_pd['order_sn'] = $order_info['order_sn']; if ($data_pd['amount'] > 0) { $predeposit_model->changeRcb('order_comb_pay', $data_pd); } } if ($rcb_amount > 0) { $data_pd = []; $data_pd['member_id'] = $order_info['buyer_id']; $data_pd['member_name'] = $order_info['buyer_name']; $data_pd['amount'] = $rcb_amount; $data_pd['order_sn'] = $order_info['order_sn']; $predeposit_model->changeRcb('order_cancel', $data_pd); } //当是已下单,未支付(可能包含部分款项使用预存款,预存款在冻结资金),则退还预存款,取消订单 $pd_amount = floatval($order_info['pd_amount']); if ($order_info['order_state'] == ORDER_STATE_REST && $role != 'admin' && $role != 'seller' && $rcb_amount < 0) {//非管理员取消订单不退定金 $pd_amount += $rcb_amount; $data_pd = []; $data_pd['member_id'] = $order_info['buyer_id']; $data_pd['member_name'] = $order_info['buyer_name']; $data_pd['amount'] = -$rcb_amount; $data_pd['order_sn'] = $order_info['order_sn']; $predeposit_model->changePd('order_comb_pay', $data_pd); } if ($pd_amount > 0) { $data_pd = []; $data_pd['member_id'] = $order_info['buyer_id']; $data_pd['member_name'] = $order_info['buyer_name']; $data_pd['amount'] = $pd_amount; $data_pd['order_sn'] = $order_info['order_sn']; $predeposit_model->changePd('order_cancel', $data_pd); } } if ($order_info['order_state'] == ORDER_STATE_PAY && $order_info['payment_code'] != 'offline') {//offline为货到付款的订单,取消时不需要返回预存款 //拼团退团 if (!empty($pintuan_list)) { foreach ($pintuan_list as $goods) { $ppintuangroup_info = Db::name('ppintuangroup')->where('pintuangroup_id', $goods['promotions_id'])->lock(true)->find(); if ($ppintuangroup_info && $ppintuangroup_info['pintuangroup_state'] == 1) { if ($ppintuangroup_info['pintuangroup_joined'] > 0) { Db::name('ppintuangroup')->where('pintuangroup_id', $goods['promotions_id'])->dec('pintuangroup_joined')->update(); if ($ppintuangroup_info['pintuangroup_joined'] == 1) { //拼团统计开团数量 $condition = []; $condition[] = ['pintuan_id', '=', $ppintuangroup_info['pintuan_id']]; $condition[] = ['pintuan_count', '>', 0]; Db::name('ppintuan')->where($condition)->dec('pintuan_count')->update(); } } } } } $refundreturn_model = model('refundreturn'); $refundreturn_model->refundAmount($order_info, $order_info['order_amount']); } } //更新订单信息 $update_order = ['order_state' => ORDER_STATE_CANCEL, 'pd_amount' => 0]; $update = $order_model->editOrder($update_order, ['order_id' => $order_id]); if (!$update) { throw new \think\Exception('保存失败', 10006); } //自提点订单取消 $chain_order_model = model('chain_order'); $chain_order_model->editChainOrderCancel($order_id, 0, 1); //添加订单日志 $data = []; $data['order_id'] = $order_id; $data['log_role'] = $role; $data['log_msg'] = '取消了订单'; $data['log_user'] = $user; if ($msg) { $data['log_msg'] .= ' ( ' . $msg . ' )'; } $data['log_orderstate'] = ORDER_STATE_CANCEL; $order_model->addOrderlog($data); } } /** * 返还金额 */ public function orderCancelBack($order_info, $member_info) { //返还卡券 if (!empty($order_info['deduction_amount']) && $order_info['card_id'] != 0) { //这两个都满足的情况下,走退款 删除支付记录里的订单关联数据 //1.回滚卡片余额 $cardWhere = []; $cardWhere[] = ['id', '=', $order_info['card_id']]; $cardWhere[] = ['member_id', '=', $member_info['member_id']]; $cardInfo = Db::name('sub_card')->where($cardWhere)->find(); if (($cardInfo['balance'] + $order_info['deduction_amount']) == $cardInfo['worth']) { $cardStatus = 1; } else { $cardStatus = 2; } $cardUpdate = [ 'card_status' => $cardStatus, 'balance' => $cardInfo['balance'] + $order_info['deduction_amount'], 'freeze' => $cardInfo['freeze'] - $order_info['deduction_amount'], 'update_time' => time(), 'used_count' => $cardInfo['used_count'] - 1, ]; $cardRes = Db::name('sub_card')->where($cardWhere)->update($cardUpdate); if ($cardRes) { //如果卡的数据恢复成功了 删除卡的消费记录 Db::name('sub_card_expense')->where([ ['card_id', '=', $cardInfo['id']], ['order_id', '=', $order_info['order_id']], ])->update(['expense_status' => 2]); } } //返还积分 if ($order_info['point_amount'] > 0) { $userModel = new User(); $point_ratio = config('app.point_ratio'); $userModel->changeScore( $order_info['point_amount'] * $point_ratio, '取消订单', '', $member_info['union_id']); } } /** * 收货 * @param array $order_info * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统 * @param string $user 操作人 * @param string $msg 操作备注 * @return array */ public function changeOrderStateReceive($order_info, $role, $user = '', $msg = '') { try { $member_id = $order_info['buyer_id']; $order_id = $order_info['order_id']; $order_model = model('order'); //更新订单状态 $update_order = []; if (!$order_info['delay_time']) { $update_order['delay_time'] = TIMESTAMP; } $update_order['finnshed_time'] = TIMESTAMP; $update_order['order_state'] = ORDER_STATE_SUCCESS; $update = $order_model->editOrder($update_order, ['order_id' => $order_id]); if (!$update) { throw new \think\Exception('保存失败', 10006); } //如果是门店订单,则修改订单状态 $chain_order_model = model('chain_order'); $chain_order_info = $chain_order_model->getChainOrderInfo(['order_id' => $order_id, 'chain_order_type' => 1]); if ($chain_order_info) { $chain_order_model->editChainOrderPickup([], ['order_id' => $order_id, 'chain_order_type' => 1]); } //添加订单日志 $data = []; $data['order_id'] = $order_id; $data['log_role'] = 'buyer'; $data['log_msg'] = '签收了货物'; $data['log_user'] = $user; if ($msg) { $data['log_msg'] .= ' ( ' . $msg . ' )'; } $data['log_orderstate'] = ORDER_STATE_SUCCESS; $order_model->addOrderlog($data); //添加会员积分 if (config('ds_config.points_isuse') == 1) { model('points')->savePointslog('order', [ 'pl_memberid' => $order_info['buyer_id'], 'pl_membername' => $order_info['buyer_name'], 'orderprice' => $order_info['order_amount'], 'order_sn' => $order_info['order_sn'], 'order_id' => $order_info['order_id'], ], true); } //添加会员经验值 model('exppoints')->saveExppointslog('order', [ 'explog_memberid' => $order_info['buyer_id'], 'explog_membername' => $order_info['buyer_name'], 'orderprice' => $order_info['order_amount'], 'order_sn' => $order_info['order_sn'], 'order_id' => $order_info['order_id'], ], true); //邀请人获得返利积分 $inviter_id = ds_getvalue_byname('member', 'member_id', $member_id, 'inviter_id'); if (!empty($inviter_id)) { $inviter_name = ds_getvalue_byname('member', 'member_id', $inviter_id, 'member_name'); $rebate_amount = ceil(0.01 * $order_info['order_amount'] * config('ds_config.points_rebate')); model('points')->savePointslog('rebate', [ 'pl_memberid' => $inviter_id, 'pl_membername' => $inviter_name, 'pl_points' => $rebate_amount, ], true); } return ds_callback(true, '操作成功'); } catch (Exception $e) { return ds_callback(false, '操作失败'); } } /** * 更改运费 * @param array $order_info * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统 * @param string $user 操作人 * @param float $price 运费 * @return array */ public function changeOrderShipPrice($order_info, $role, $user = '', $price) { try { $order_id = $order_info['order_id']; $order_model = model('order'); $data = []; $data['shipping_fee'] = abs(floatval($price)); $data['order_amount'] = Db::raw('goods_amount+' . $data['shipping_fee']); if (($order_info['rcb_amount'] + $order_info['pd_amount']) > ($data['shipping_fee'] + $order_info['goods_amount'])) { throw new \think\Exception('订单金额必须大于用户已支付金额', 10006); } $update = $order_model->editOrder($data, ['order_id' => $order_id]); if (!$update) { throw new \think\Exception('保存失败', 10006); } //记录订单日志 $data = []; $data['order_id'] = $order_id; $data['log_role'] = $role; $data['log_user'] = $user; $data['log_msg'] = '修改了运费' . '( ' . $price . ' )';; $data['log_orderstate'] = $order_info['payment_code'] == 'offline' ? ORDER_STATE_PAY : ORDER_STATE_NEW; $order_model->addOrderlog($data); return ds_callback(true, '操作成功'); } catch (Exception $e) { return ds_callback(false, $e->getMessage()); } } /** * 更改商品费用 * @param array $order_info * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统 * @param string $user 操作人 * @param float $price 运费 * @return array */ public function changeOrderSpayPrice($order_info, $role, $user = '', $price) { $order_model = model('order'); Db::startTrans(); try { $order_id = $order_info['order_id']; $data = []; $data['goods_amount'] = abs(floatval($price)); $data['order_amount'] = Db::raw('shipping_fee+' . $data['goods_amount']); if (($order_info['rcb_amount'] + $order_info['pd_amount']) > ($order_info['shipping_fee'] + $data['goods_amount'])) { throw new \think\Exception('订单金额必须大于用户已支付金额', 10006); } $update = $order_model->editOrder($data, ['order_id' => $order_id]); if (!$update) { throw new \think\Exception('保存失败', 10006); } //修改商品费用 if ($data['goods_amount'] > 0) { $ordergoods_list = $order_model->getOrdergoodsList(['order_id' => $order_id]); $diff_amount = $data['goods_amount'] - $order_info['goods_amount']; $i = 0; foreach ($ordergoods_list as $ordergoods) { if ($i != (count($ordergoods_list) - 1)) { if ($order_info['goods_amount'] > 0) { $temp = $ordergoods['goods_pay_price'] / $order_info['goods_amount'] * $diff_amount; $price = round($ordergoods['goods_pay_price'] + $temp, 2); } else { $price = round(1 / count($ordergoods_list) * $diff_amount, 2); $temp = $price; } $diff_amount -= $temp; } else { $price = $ordergoods['goods_pay_price'] + $diff_amount; } $order_model->editOrdergoods(['goods_pay_price' => $price], ['rec_id' => $ordergoods['rec_id']]); $i++; } } else { $order_model->editOrdergoods(['goods_pay_price' => 0], ['order_id' => $order_id]); } //记录订单日志 $data = []; $data['order_id'] = $order_id; $data['log_role'] = $role; $data['log_user'] = $user; $data['log_msg'] = '修改了商品费用' . '( ' . $price . ' )';; $data['log_orderstate'] = $order_info['payment_code'] == 'offline' ? ORDER_STATE_PAY : ORDER_STATE_NEW; $order_model->addOrderlog($data); } catch (\Exception $e) { Db::rollback(); return ds_callback(false, $e->getMessage()); } Db::commit(); return ds_callback(true, '操作成功'); } /** * 回收站操作(放入回收站、还原、永久删除) * @param array $order_info * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统 * @param string $state_type 操作类型 * @return array */ public function changeOrderStateRecycle($order_info, $role, $state_type) { $order_id = $order_info['order_id']; $order_model = model('order'); //更新订单删除状态 $state = str_replace(['delete', 'drop', 'restore'], [ ORDER_DEL_STATE_DELETE, ORDER_DEL_STATE_DROP, ORDER_DEL_STATE_DEFAULT, ], $state_type); $update = $order_model->editOrder(['delete_state' => $state], ['order_id' => $order_id]); if (!$update) { return ds_callback(false, '操作失败'); } else { return ds_callback(true, '操作成功'); } } /** * 发货 * @param array $order_info * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统 * @param string $user 操作人 * @return array */ public function changeOrderSend($order_info, $role, $user = '', $post = []) { $order_id = $order_info['order_id']; $order_model = model('order'); //查看是否为拼团订单 $condition = []; $condition[] = ['order_id', '=', $order_id]; $condition[] = ['pintuanorder_type', '=', 0]; $pintuanorder = model('ppintuanorder')->getOnePpintuanorder($condition); if (!empty($pintuanorder) && $pintuanorder['pintuanorder_state'] != 2) { return ds_callback(FALSE, '拼团订单暂时不允许发货'); } if (!isset($post['daddress_id'])) { return ds_callback(FALSE, '请先设置发货地址'); } try { Db::startTrans(); $data = []; $data['reciver_name'] = $post['reciver_name']; $data['reciver_info'] = $post['reciver_info']; $data['deliver_explain'] = $post['deliver_explain']; $data['daddress_id'] = intval($post['daddress_id']); $data['shipping_express_id'] = intval($post['shipping_express_id']); $data['shipping_time'] = TIMESTAMP; $condition = []; $condition[] = ['order_id', '=', $order_id]; $condition[] = ['store_id', '=', $order_info['store_id']]; $update = $order_model->editOrdercommon($data, $condition); if (!$update) { throw new \think\Exception('操作失败', 10006); } $data = []; $data['shipping_code'] = isset($post['shipping_code']) ? $post['shipping_code'] : ''; $data['order_state'] = ORDER_STATE_SEND; $data['delay_time'] = TIMESTAMP; $update = $order_model->editOrder($data, $condition); if (!$update) { throw new \think\Exception('操作失败', 10006); } Db::commit(); } catch (Exception $e) { Db::rollback(); return ds_callback(false, $e->getMessage()); } //更新表发货信息 if ($post['shipping_express_id'] && isset($post['shipping_code'])) { $data = []; $data['shipping_code'] = $post['shipping_code']; $data['order_sn'] = $order_info['order_sn']; $express_info = model('express')->getExpressInfo(intval($post['shipping_express_id'])); $data['express_code'] = $express_info['express_code']; $data['express_name'] = $express_info['express_name']; //如果是门店订单,则修改订单状态 $chain_order_model = model('chain_order'); $chain_order_info = $chain_order_model->getChainOrderInfo(['order_id' => $order_id, 'chain_order_type' => 1]); if ($chain_order_info) { $chain_order_model->editChainOrder([ 'express_code' => $data['express_code'], 'express_name' => $data['express_name'], 'shipping_code' => $data['shipping_code'], 'chain_order_state' => ORDER_STATE_SEND, ], ['order_id' => $order_id, 'chain_order_type' => 1]); } } //添加订单日志 $data = []; $data['order_id'] = intval($order_id); $data['log_role'] = 'seller'; $data['log_user'] = $user; $data['log_msg'] = '发出了货物 ( 编辑了发货信息 )'; $data['log_orderstate'] = ORDER_STATE_SEND; $order_model->addOrderlog($data); // 发送买家消息 $param = []; $param['code'] = 'order_deliver_success'; $param['member_id'] = $order_info['buyer_id']; //阿里短信参数 $param['ali_param'] = [ 'order_sn' => $order_info['order_sn'], ]; $param['ten_param'] = [ $order_info['order_sn'], ]; $param['param'] = array_merge($param['ali_param'], [ 'order_url' => HOME_SITE_URL . '/Memberorder/show_order?order_id=' . $order_id, ]); //微信模板消息 $param['weixin_param'] = [ 'url' => config('ds_config.h5_site_url') . '/member/order_detail?order_id=' . $order_id, 'data' => [ "keyword1" => [ "value" => isset($post['shipping_code']) ? $post['shipping_code'] : '无', "color" => "#333", ], "keyword2" => [ "value" => isset($express_info['express_name']) ? $express_info['express_name'] : '无', "color" => "#333", ], "keyword3" => [ "value" => date('Y-m-d H:i'), "color" => "#333", ], "keyword4" => [ "value" => isset($order_info['extend_order_common']['reciver_name']) ? $order_info['extend_order_common']['reciver_name'] : '无', "color" => "#333", ], "keyword5" => [ "value" => isset($order_info['extend_order_common']['address']) ? $order_info['extend_order_common']['reciver_info']['address'] : '无', "color" => "#333", ], ], ]; \mall\queue\QueueClient::push('sendMemberMsg', $param); return ds_callback(true, '操作成功'); } /** * 收到货款 * @param array $order_info * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统 * @param string $user 操作人 * @return array */ public function changeOrderReceivePay($order_list, $role, $user = '', $post = []) { $order_model = model('order'); $predeposit_model = model('predeposit'); foreach ($order_list as $order_info) { $order_id = $order_info['order_id']; if ($order_info['order_state'] != ORDER_STATE_NEW && $order_info['order_state'] != ORDER_STATE_REST) continue; //下单,支付被冻结的充值卡 $rcb_amount = floatval($order_info['rcb_amount']); if ($rcb_amount > 0) { $data_pd = []; $data_pd['member_id'] = $order_info['buyer_id']; $data_pd['member_name'] = $order_info['buyer_name']; $data_pd['amount'] = $rcb_amount; $data_pd['order_sn'] = $order_info['order_sn']; $predeposit_model->changeRcb('order_comb_pay', $data_pd); } //下单,支付被冻结的预存款 $pd_amount = floatval($order_info['pd_amount']); if ($pd_amount > 0) { $data_pd = []; $data_pd['member_id'] = $order_info['buyer_id']; $data_pd['member_name'] = $order_info['buyer_name']; $data_pd['amount'] = $pd_amount; $data_pd['order_sn'] = $order_info['order_sn']; $predeposit_model->changePd('order_comb_pay', $data_pd); } } if ($order_info['order_state'] == ORDER_STATE_NEW || $order_info['order_state'] == ORDER_STATE_REST) { $order_state = ORDER_STATE_PAY; $data = []; $data['api_paystate'] = 1; $update = $order_model->editOrderpay($data, ['pay_sn' => $order_list[0]['pay_sn']]); if (!$update) { throw new \think\Exception('更新支付单状态失败', 10006); } } else if ($order_info['order_state'] == ORDER_STATE_DEPOSIT) { $order_state = ORDER_STATE_REST; } //更新订单状态 $update_order = []; $update_order['order_state'] = $order_state; $update_order['payment_time'] = isset($post['payment_time']) ? strtotime($post['payment_time']) : TIMESTAMP; $update_order['payment_code'] = isset($post['payment_code']) ? $post['payment_code'] : ''; $update_order['trade_no'] = isset($post['trade_no']) ? $post['trade_no'] : ''; $update = $order_model->editOrder($update_order, [ 'pay_sn' => $order_info['pay_sn'], 'order_state' => $order_info['order_state'], ]); if ($order_state == ORDER_STATE_PAY) { //更改自提点的订单状态 $chain_order_model = model('chain_order'); $chain_order_model->editChainOrderPay($order_info['order_id']); } if (!$update) { throw new \think\Exception('操作失败', 10006); } $ppintuangroup_model = model('ppintuangroup'); foreach ($order_list as $order_info) { //防止重复发送消息 if ($order_info['order_state'] != ORDER_STATE_NEW && $order_info['order_state'] != ORDER_STATE_DEPOSIT && $order_info['order_state'] != ORDER_STATE_REST) continue; $order_id = $order_info['order_id']; $order_goods = $order_model->getOrdergoodsList(['order_id' => $order_info['order_id']]); foreach ($order_goods as $goods) { //如果是拼团 if ($goods['goods_type'] == 6) { $ppintuangroup_info = Db::name('ppintuangroup')->where('pintuangroup_id', $goods['promotions_id'])->lock(true)->find(); if ($ppintuangroup_info && $ppintuangroup_info['pintuangroup_state'] == 1) { if ($ppintuangroup_info['pintuangroup_joined'] == 0) { //拼团统计开团数量 $condition = []; $condition[] = ['pintuan_id', '=', $ppintuangroup_info['pintuan_id']]; Db::name('ppintuan')->where($condition)->inc('pintuan_count')->update(); } //开团统计新增人数 Db::name('ppintuangroup')->where('pintuangroup_id', $goods['promotions_id'])->inc('pintuangroup_joined')->update(); if (($ppintuangroup_info['pintuangroup_joined'] + 1) >= $ppintuangroup_info['pintuangroup_limit_number']) { $condition = []; $condition[] = ['pintuangroup_is_virtual', '=', 0]; $condition[] = ['pintuangroup_id', '=', $goods['promotions_id']]; $condition2 = []; $condition2[] = ['pintuangroup_id', '=', $goods['promotions_id']]; $ppintuangroup_model->successPpintuangroup($condition, $condition2); $condition = []; $condition[] = ['pintuan_id', '=', $ppintuangroup_info['pintuan_id']]; Db::name('ppintuan')->where($condition)->inc('pintuan_ok_count')->update(); } } } } // 支付成功发送买家消息 $param = []; $param['code'] = 'order_payment_success'; $param['member_id'] = $order_info['buyer_id']; //阿里短信参数 $param['ali_param'] = [ 'order_sn' => $order_info['order_sn'], ]; $param['ten_param'] = [ $order_info['order_sn'], ]; $param['param'] = array_merge($param['ali_param'], [ 'order_url' => HOME_SITE_URL . '/Memberorder/show_order?order_id=' . $order_info['order_id'], ]); //微信模板消息 $param['weixin_param'] = [ 'url' => config('ds_config.h5_site_url') . '/member/order_detail?order_id=' . $order_info['order_id'], 'data' => [ "keyword1" => [ "value" => $order_info['order_sn'], "color" => "#333", ], "keyword2" => [ "value" => $order_goods[0]['goods_name'] . (count($order_goods) > 1 ? sprintf(lang('order_goods_more_than_one'), count($order_goods)) : ''), "color" => "#333", ], "keyword3" => [ "value" => $order_info['order_amount'], "color" => "#333", ], "keyword4" => [ "value" => date('Y-m-d H:i', $order_info['add_time']), "color" => "#333", ], ], ]; \mall\queue\QueueClient::push('sendMemberMsg', $param); if ($order_info['order_state'] == ORDER_STATE_NEW || $order_info['order_state'] == ORDER_STATE_DEPOSIT) { // 支付成功发送店铺消息 $param = []; $param['code'] = 'new_order'; $param['store_id'] = $order_info['store_id']; $param['ali_param'] = [ 'order_sn' => $order_info['order_sn'], ]; $param['ten_param'] = [ $order_info['order_sn'], ]; $param['param'] = $param['ali_param']; $param['weixin_param'] = [ 'url' => config('ds_config.h5_site_url') . '/seller/order_detail?order_id=' . $order_info['order_id'], 'data' => [ "keyword1" => [ "value" => $order_info['order_sn'], "color" => "#333", ], "keyword2" => [ "value" => $order_goods[0]['goods_name'] . (count($order_goods) > 1 ? sprintf(lang('order_goods_more_than_one'), count($order_goods)) : ''), "color" => "#333", ], "keyword3" => [ "value" => $order_info['order_amount'], "color" => "#333", ], "keyword4" => [ "value" => date('Y-m-d H:i', $order_info['add_time']), "color" => "#333", ], ], ]; \mall\queue\QueueClient::push('sendStoremsg', $param); } if ($order_info['order_state'] == ORDER_STATE_NEW || $order_info['order_state'] == ORDER_STATE_REST) { $order_state = ORDER_STATE_PAY; } else if ($order_info['order_state'] == ORDER_STATE_DEPOSIT) { $order_state = ORDER_STATE_REST; } //添加订单日志 $data = []; $data['order_id'] = $order_id; $data['log_role'] = $role; $data['log_user'] = $user; $data['log_msg'] = '收到了货款 ' . (isset($post['trade_no']) ? ('( 支付平台交易号 : ' . $post['trade_no'] . ' )') : ''); $data['log_orderstate'] = $order_state; $order_model->addOrderlog($data); } } }