|
@@ -2,13 +2,27 @@
|
|
|
|
|
|
namespace app\admin\controller\order;
|
|
|
|
|
|
+use app\admin\service\member\MemberService;
|
|
|
+use app\admin\service\order\OrderService;
|
|
|
use app\admin\validate\order\OrderValidate;
|
|
|
use app\controller\Curd;
|
|
|
+use app\model\Appointment;
|
|
|
use app\model\Goods;
|
|
|
+use app\model\GoodsComponent;
|
|
|
+use app\model\GoodsRunning;
|
|
|
+use app\model\GoodsSku;
|
|
|
+use app\model\Member;
|
|
|
+use app\model\MemberAccount;
|
|
|
use app\model\Order;
|
|
|
use app\model\OrderSheet;
|
|
|
+use app\model\PayDetail;
|
|
|
+use app\model\SysDept;
|
|
|
+use support\Db;
|
|
|
+use support\exception\BusinessException;
|
|
|
+use support\Redis;
|
|
|
use support\Request;
|
|
|
use support\Response;
|
|
|
+use Webman\Event\Event;
|
|
|
|
|
|
class KangyangCityController extends Curd{
|
|
|
public function __construct()
|
|
@@ -168,4 +182,617 @@ class KangyangCityController extends Curd{
|
|
|
|
|
|
return $items;
|
|
|
}
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @Desc 下单+支付
|
|
|
+ * @Author Gorden
|
|
|
+ * @Date 2024/9/5 13:13
|
|
|
+ *
|
|
|
+ * @param Request $request
|
|
|
+ * @return Response
|
|
|
+ */
|
|
|
+ public function insert(Request $request): Response
|
|
|
+ {
|
|
|
+ $params = $request->post();
|
|
|
+ // 判断餐品是否连带着服务或实体
|
|
|
+ $goodsClassifys = array_unique(array_column($params['goodsContentList'], 'goods_classify'));
|
|
|
+ if (in_array('MEALS', $goodsClassifys) && count($goodsClassifys) > 1) {
|
|
|
+ return json_fail('餐饮餐品不支持和其他类型的产品一起下单');
|
|
|
+ }
|
|
|
+ if (in_array('MEALS', $goodsClassifys)) {
|
|
|
+ $params['submit_goods_classify'] = 'MEALS';
|
|
|
+ }
|
|
|
+ if (in_array('PACKAGE', $goodsClassifys)) {
|
|
|
+ $params['submit_goods_classify'] = 'PACKAGE';
|
|
|
+ }
|
|
|
+ if (!empty($params['dept_premises_id'])) {
|
|
|
+ $premises = SysDept::where('dept_name', $params['dept_premises_id'])->first();
|
|
|
+ }
|
|
|
+
|
|
|
+ $params['goods_classify'] = $goodsClassifys[0];
|
|
|
+ Db::beginTransaction();
|
|
|
+ try {
|
|
|
+ // 验证线下付款密码
|
|
|
+ if ($params['settlement_now'] == 'Y' && $params['pay_constitute'] == 'N' && in_array($params['pay_category'], ['OFFLINE', 'MONEY'])) {
|
|
|
+ $password = $params['offline_password'];
|
|
|
+ if ($password != '666888') {
|
|
|
+ throw new BusinessException('密码错误,请重新输入');
|
|
|
+ }
|
|
|
+ }
|
|
|
+ // 下单账户
|
|
|
+ if (empty($params['join_order_member_id']) && !empty($params['mobile'])) {
|
|
|
+ if (Member::where('member_mobile', $params['mobile'])->exists()) {
|
|
|
+ throw new BusinessException('会员已存在');
|
|
|
+ }
|
|
|
+ $params['join_order_member_id'] = $params['member_id'] = 'MR' . date('YmdHis') . random_string(6, 'up');
|
|
|
+ // 创建会员
|
|
|
+ MemberService::createMember($params);
|
|
|
+ } else if (empty($params['join_order_member_id']) && empty($params['mobile'])) {
|
|
|
+ $params['join_order_member_id'] = Member::where('member_mobile', '0000')->value('member_id');
|
|
|
+ }
|
|
|
+ if (empty($params['join_order_member_id'])) {
|
|
|
+ throw new BusinessException('检查下单账户');
|
|
|
+ }
|
|
|
+
|
|
|
+ $qrcodePayAmount = 0;
|
|
|
+ $params['orderId'] = 'OD' . date('YmdHis') . random_string(6, 'up');
|
|
|
+ $params['orderGroupId'] = 'OD' . date('YmdHis') . random_string(6, 'up');
|
|
|
+
|
|
|
+ $systemStatus = 'SENDING'; // 待发货
|
|
|
+ // 立即结算
|
|
|
+ if ($params['settlement_now'] == 'Y') {
|
|
|
+ if (in_array($params['goods_classify'], ['SERVICE', 'CHNMED', 'CHNNCD', 'MEALS', 'VIP'])) {
|
|
|
+ $params['order_is_complete'] = 'Y';
|
|
|
+ $systemStatus = 'DONE';
|
|
|
+ }
|
|
|
+ if ($params['goods_classify'] == 'PACKAGE' && $params['delivery'] == 'ARRIVAL') {
|
|
|
+ $systemStatus = "WAITING";
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if ($params['settlement_now'] == 'Y' && ($params['pay_category'] == 'OFFLINE' || $params['pay_category'] == 'MONEY')) {
|
|
|
+ if ($params['pay_category'] == 'OFFLINE' && !empty($params['pay_category_sub'])) {
|
|
|
+ $params['pay_category'] = $params['pay_category_sub'];
|
|
|
+ }
|
|
|
+ $params['order_status_system'] = $systemStatus;
|
|
|
+ $params['order_status_payment'] = 'SUCCESS';
|
|
|
+ }
|
|
|
+ if (($params['pay_constitute'] == 'Y' || $params['pay_category'] == 'QRCODE') && $params['settlement_now'] == 'Y' && !empty($params['qrcode_nbr'])) { // 付款码
|
|
|
+ // 提交过来的支付分类
|
|
|
+ $submitPayCategory = $params['pay_category'];
|
|
|
+ // 账户支付的金额
|
|
|
+ $accountAmount = $params['order_amount_pay'];
|
|
|
+ if ($params['pay_constitute'] == 'Y' && $qrcodePayAmount > 0) {
|
|
|
+ // 组合支付,支付金额改成需要付款码需要支付的金额
|
|
|
+ $params['order_amount_pay'] = $qrcodePayAmount;
|
|
|
+ }
|
|
|
+ if ($params['pay_constitute'] == 'Y' && $qrcodePayAmount <= 0) {
|
|
|
+ $params['order_status_system'] = $systemStatus;
|
|
|
+ $params['order_status_payment'] = 'SUCCESS';
|
|
|
+ }
|
|
|
+ // 不组合或者组合后需要付款码的金额>0
|
|
|
+ if ($params['pay_constitute'] == 'N' || ($params['pay_constitute'] == 'Y' && $qrcodePayAmount > 0)) {
|
|
|
+ $result = OrderService::qrcodePay($params);
|
|
|
+ $result = json_encode($result);
|
|
|
+ $params['pay_json_response'] = $result;
|
|
|
+ $result = json_decode($result, true);
|
|
|
+
|
|
|
+ $prefix = substr($params['qrcode_nbr'], 0, 2);
|
|
|
+ if (in_array($prefix, [10, 11, 12, 13, 14, 15])) {
|
|
|
+ $params['pay_category'] = 'WXPAY';
|
|
|
+ if ((!isset($result['return_code']) || $result['return_code'] != 'SUCCESS') || (!isset($result['result_code']) || $result['result_code'] != 'SUCCESS') || (empty($result['trade_state']) || $result['trade_state'] != 'SUCCESS')) {
|
|
|
+ $params['order_status_system'] = 'PAYING';
|
|
|
+ $params['order_status_payment'] = 'PENDING';
|
|
|
+ $params['order_is_complete'] = 'N';
|
|
|
+// Db::rollBack();
|
|
|
+// return json_fail('支付失败');
|
|
|
+ } else {
|
|
|
+ $params['order_status_system'] = $systemStatus;
|
|
|
+ $params['order_status_payment'] = 'SUCCESS';
|
|
|
+ }
|
|
|
+ } else if (in_array($prefix, [25, 26, 27, 28, 29, 30])) {
|
|
|
+ $params['pay_category'] = 'ALIPAY';
|
|
|
+ if ((!isset($result['code']) || $result['code'] != '10000') || (empty($result['trade_status']) || $result['trade_status'] != 'TRADE_SUCCESS')) {
|
|
|
+ $params['order_status_system'] = 'PAYING';
|
|
|
+ $params['order_status_payment'] = 'PENDING';
|
|
|
+ $params['order_is_complete'] = 'N';
|
|
|
+// Db::rollBack();
|
|
|
+// return json_fail('支付失败');
|
|
|
+ } else {
|
|
|
+ $params['order_status_system'] = $systemStatus;
|
|
|
+ $params['order_status_payment'] = 'SUCCESS';
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ throw new BusinessException('付款码无效');
|
|
|
+ }
|
|
|
+
|
|
|
+ // 组合支付,追加加一条支付记录 pay_detail
|
|
|
+ if ($params['pay_constitute'] == 'Y' && $qrcodePayAmount > 0 && $params['order_status_payment'] == 'SUCCESS') {
|
|
|
+ $insertPayDetailData = [
|
|
|
+ 'join_pay_member_id' => $params['join_order_member_id'],
|
|
|
+ 'join_pay_order_id' => $params['orderGroupId'],
|
|
|
+ 'pay_status' => 'SUCCESS',
|
|
|
+ 'pay_category' => $params['goods_classify'],
|
|
|
+ 'pay_amount' => $params['order_amount_pay'],
|
|
|
+ 'pay_paytimes' => date('Y-m-d H:i:s'),
|
|
|
+ 'pay_prepayid' => $params['pay_category'],
|
|
|
+ 'pay_json_request' => json_encode($params),
|
|
|
+ 'pay_json_response' => $params['pay_json_response'],
|
|
|
+ 'pay_addtimes' => time()
|
|
|
+ ];
|
|
|
+
|
|
|
+ PayDetail::insert($insertPayDetailData);
|
|
|
+
|
|
|
+ // 组合支付,还原提交的支付分类
|
|
|
+ $params['pay_category'] = $submitPayCategory;
|
|
|
+ }
|
|
|
+
|
|
|
+ // 账户支付的金额
|
|
|
+ $params['order_amount_pay'] = $accountAmount;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ $orderConfigJson = [];
|
|
|
+ // 配送方式
|
|
|
+ if (isset($params['delivery']) && ($params['delivery'] == 'PICKUP' || $params['delivery'] == 'ARRIVAL')) { // 自提/ 到店
|
|
|
+ $orderConfigJson['premises'] = $params['dept_premises_id'];
|
|
|
+ } else if (isset($params['delivery']) && $params['delivery'] == 'LOGISTICS') {
|
|
|
+ // $params['order_express_json'] = json_encode([
|
|
|
+ // 'express' => 'Y',
|
|
|
+ // ]);
|
|
|
+ }
|
|
|
+ $params['order_amount_pay'] = $params['order_amount_pay'] + $qrcodePayAmount;
|
|
|
+ $params['order_config_json'] = json_encode($orderConfigJson);
|
|
|
+ // 写入主订单
|
|
|
+ $this->insertMain($params);
|
|
|
+ // 订单详情
|
|
|
+ $sheetId = $this->insertSheet($params);
|
|
|
+ // 支付记录
|
|
|
+ $params['order_amount_pay'] = $params['order_amount_pay'] - $qrcodePayAmount;
|
|
|
+ $this->insertPayDetail($params);
|
|
|
+
|
|
|
+ $params['order_express_goods'] = json_encode(['sheet' => [$sheetId]]);
|
|
|
+
|
|
|
+ // 2.4W 康养城
|
|
|
+ if ($params['goods_classify'] == 'VIP' && $params['order_status_payment'] == 'SUCCESS') {
|
|
|
+ $params['member_id'] = $params['join_order_member_id'];
|
|
|
+ Event::dispatch('order.kangyangCityVIP.grant', $params);
|
|
|
+ }
|
|
|
+
|
|
|
+ Db::commit();
|
|
|
+
|
|
|
+ // 会员升级
|
|
|
+ if (!empty($params['order_is_complete']) && $params['order_is_complete'] == 'Y' && $params['order_status_payment'] == 'SUCCESS') {
|
|
|
+ Event::dispatch('order.complete', $params);
|
|
|
+ }
|
|
|
+
|
|
|
+ if ($params['settlement_now'] == 'Y' && $params['order_status_payment'] != 'SUCCESS') {
|
|
|
+ _syslog("订单", "支付异常,检查是否有轮询");
|
|
|
+ return json_throw(2001, '支付异常', ['order_id' => $params['orderId']]);
|
|
|
+ }
|
|
|
+ _syslog("订单", "创建订单成功");
|
|
|
+ return json_success('创建订单成功');
|
|
|
+ } catch (BusinessException $e) {
|
|
|
+ Db::rollBack();
|
|
|
+ dump($e->getMessage());
|
|
|
+ dump($e->getTrace());
|
|
|
+ _syslog("订单", $e->getMessage());
|
|
|
+ return json_fail($e->getMessage());
|
|
|
+ } catch (\Exception $e) {
|
|
|
+ Db::rollBack();
|
|
|
+ dump($e->getMessage());
|
|
|
+ dump($e->getTrace());
|
|
|
+ _syslog("订单", "创建订单失败");
|
|
|
+ return json_fail('创建订单失败');
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @Desc 支付
|
|
|
+ * @Author Gorden
|
|
|
+ * @Date 2024/9/5 13:12
|
|
|
+ *
|
|
|
+ * @param Request $request
|
|
|
+ * @return Response
|
|
|
+ */
|
|
|
+ public function pay(Request $request)
|
|
|
+ {
|
|
|
+ $params = $request->post();
|
|
|
+ // 验证线下付款密码
|
|
|
+ if ($params['pay_constitute'] == 'N' && in_array($params['pay_category'], ['OFFLINE', 'MONEY'])) {
|
|
|
+ $password = $params['offline_password'];
|
|
|
+ if ($password != '666888') {
|
|
|
+ return json_fail("密码错误,请重新输入");
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ $order = Order::where('order_id', $params['order_id'])->first();
|
|
|
+ if (!$order) {
|
|
|
+ return json_fail('订单异常');
|
|
|
+ }
|
|
|
+ if ($order->order_status_system != 'PAYING') {
|
|
|
+ return json_fail('订单不是可支付状态');
|
|
|
+ }
|
|
|
+
|
|
|
+ $params['orderId'] = $params['order_id'];
|
|
|
+ $params['orderGroupId'] = $order->order_groupby;
|
|
|
+
|
|
|
+ $goods = Goods::where('goods_id', $params['join_sheet_goods_id'])
|
|
|
+ ->select('goods_id', 'goods_name', 'goods_classify')
|
|
|
+ ->first();
|
|
|
+ if (!$goods) {
|
|
|
+ return json_fail('产品数据异常');
|
|
|
+ }
|
|
|
+ $goods = $goods->toArray();
|
|
|
+ $params['goods_classify'] = $goods['goods_classify'] ?? '';
|
|
|
+
|
|
|
+ $systemStatus = 'SENDING'; // 待发货
|
|
|
+ // 立即结算
|
|
|
+ if (in_array($params['goods_classify'], ['SERVICE', 'CHNMED', 'CHNNCD', 'MEALS', 'VIP'])) {
|
|
|
+ $order->order_is_complete = 'Y';
|
|
|
+ $systemStatus = 'DONE';
|
|
|
+ }
|
|
|
+ if ($params['goods_classify'] == 'PACKAGE' && $params['delivery'] == 'ARRIVAL') {
|
|
|
+ $systemStatus = "WAITING";
|
|
|
+ }
|
|
|
+ Db::beginTransaction();
|
|
|
+ try {
|
|
|
+ // 组合支付时,付款码应收金额
|
|
|
+ $qrcodePayAmount = 0;
|
|
|
+ if ($params['pay_category'] == 'OFFLINE' || $params['pay_category'] == 'MONEY') {
|
|
|
+ $order->order_status_system = $systemStatus;
|
|
|
+ $order->order_status_payment = 'SUCCESS';
|
|
|
+ if ($params['pay_category'] == 'OFFLINE' && !empty($params['pay_category_sub'])) {
|
|
|
+ $params['pay_category'] = $params['pay_category_sub'];
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (($params['pay_constitute'] == 'Y' || $params['pay_category'] == 'QRCODE') && !empty($params['qrcode_nbr'])) { // 付款码
|
|
|
+ // 提交过来的支付分类
|
|
|
+ $submitPayCategory = $params['pay_category'];
|
|
|
+ // 账户支付的金额
|
|
|
+ $accountAmount = $params['order_amount_pay'];
|
|
|
+ if ($params['pay_constitute'] == 'Y' && $qrcodePayAmount > 0) {
|
|
|
+ // 组合支付,改成需要付款码需要支付的金额
|
|
|
+ $params['order_amount_pay'] = $qrcodePayAmount;
|
|
|
+ }
|
|
|
+ // 去支付
|
|
|
+ $result = OrderService::qrcodePay($params);
|
|
|
+ $result = json_encode($result);
|
|
|
+ $params['pay_json_response'] = $result;
|
|
|
+ $result = json_decode($result, true);
|
|
|
+
|
|
|
+ $prefix = substr($params['qrcode_nbr'], 0, 2);
|
|
|
+ if (in_array($prefix, [10, 11, 12, 13, 14, 15])) {
|
|
|
+ $params['pay_category'] = 'WXPAY';
|
|
|
+ if ((!isset($result['return_code']) || $result['return_code'] != 'SUCCESS') || (!isset($result['result_code']) || $result['result_code'] != 'SUCCESS') || (empty($result['trade_state']) || $result['trade_state'] != 'SUCCESS')) {
|
|
|
+ $order->order_status_system = 'PAYING';
|
|
|
+ $order->order_status_payment = 'PENDING';
|
|
|
+ $order->order_is_complete = 'N';
|
|
|
+// Db::rollBack();
|
|
|
+// return json_fail('支付失败');
|
|
|
+ } else {
|
|
|
+ $order->order_status_system = $systemStatus;
|
|
|
+ $order->order_status_payment = 'SUCCESS';
|
|
|
+ }
|
|
|
+ } else if (in_array($prefix, [25, 26, 27, 28, 29, 30])) {
|
|
|
+ $params['pay_category'] = 'ALIPAY';
|
|
|
+ if ((!isset($result['code']) || $result['code'] != '10000') || (empty($result['trade_status']) || $result['trade_status'] != 'TRADE_SUCCESS')) {
|
|
|
+ $order->order_status_system = 'PAYING';
|
|
|
+ $order->order_status_payment = 'PENDING';
|
|
|
+ $order->order_is_complete = 'N';
|
|
|
+// Db::rollBack();
|
|
|
+// return json_fail('支付失败');
|
|
|
+ } else {
|
|
|
+ $order->order_status_system = $systemStatus;
|
|
|
+ $order->order_status_payment = 'SUCCESS';
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ throw new BusinessException('付款码无效');
|
|
|
+ }
|
|
|
+
|
|
|
+ // 组合支付,追加加一条支付记录 pay_detail
|
|
|
+ if ($params['pay_constitute'] == 'Y' && $qrcodePayAmount > 0) {
|
|
|
+ $insertPayDetailData = [
|
|
|
+ 'join_pay_member_id' => $params['join_order_member_id'],
|
|
|
+ 'join_pay_order_id' => $params['orderGroupId'],
|
|
|
+ 'pay_status' => 'SUCCESS',
|
|
|
+ 'pay_category' => $params['goods_classify'],
|
|
|
+ 'pay_amount' => $params['order_amount_pay'],
|
|
|
+ 'pay_paytimes' => date('Y-m-d H:i:s'),
|
|
|
+ 'pay_prepayid' => $params['pay_category'],
|
|
|
+ 'pay_json_request' => json_encode($params),
|
|
|
+ 'pay_json_response' => $params['pay_json_response'],
|
|
|
+ 'join_pay_object_json' => !empty($params['orderId']) ? json_encode(['order_id' => $params['orderId']]) : '[]',
|
|
|
+ 'pay_addtimes' => time()
|
|
|
+ ];
|
|
|
+
|
|
|
+ PayDetail::insert($insertPayDetailData);
|
|
|
+
|
|
|
+ // 组合支付,还原提交的支付分类
|
|
|
+ $params['pay_category'] = $submitPayCategory;
|
|
|
+ }
|
|
|
+
|
|
|
+ // 账户支付的金额
|
|
|
+ $params['order_amount_pay'] = $accountAmount;
|
|
|
+ }
|
|
|
+ $orderConfigJson = [];
|
|
|
+ if (!empty($order->order_config_json)) {
|
|
|
+ $orderConfigJson = json_decode($order->order_config_json, true);
|
|
|
+ }
|
|
|
+ $orderConfigJson['preferential'] = $params['preferential'] ?? '';
|
|
|
+ if (isset($orderConfigJson['tableid']) && !empty($orderConfigJson['tableid'])) {
|
|
|
+ SysDept::where('dept_id', $orderConfigJson['tableid'])->where('dept_category', '桌台')->update(['dept_status' => 'ACTIVED']);
|
|
|
+ }
|
|
|
+ $order->order_config_json = json_encode($orderConfigJson);
|
|
|
+ $order->order_amount_pay = $params['order_amount_pay'] + $qrcodePayAmount;
|
|
|
+ // 康养城订单,支付完就结束了
|
|
|
+ if ($order->order_status_payment == 'SUCCESS' && $params['goods_classify'] == 'VIP') {
|
|
|
+ $order->order_is_complete = 'Y';
|
|
|
+ }
|
|
|
+ // 主订单
|
|
|
+ $order->save();
|
|
|
+
|
|
|
+ // sheet
|
|
|
+ if ($order->order_status_payment == 'SUCCESS') {
|
|
|
+ OrderSheet::where('join_sheet_order_id', $params['order_id'])->update([
|
|
|
+ 'order_sheet_status' => $systemStatus,
|
|
|
+ ]);
|
|
|
+ }
|
|
|
+ // payDetail
|
|
|
+ $payData = [
|
|
|
+ 'pay_amount' => $params['order_amount_pay']
|
|
|
+ ];
|
|
|
+ if ($order->order_status_payment == 'SUCCESS') {
|
|
|
+ $payData['pay_paytimes'] = date('Y-m-d H:i:s');
|
|
|
+ $payData['pay_status'] = 'SUCCESS';
|
|
|
+ }
|
|
|
+ if ($params['pay_constitute'] == 'N' && in_array($params['pay_category'], ['WXPAY', 'ALIPAY'])) {
|
|
|
+ $payData['pay_prepayid'] = $params['pay_category'];
|
|
|
+ $payData['pay_json_response'] = $params['pay_json_response'];
|
|
|
+ } else if ($params['pay_category'] == 'CASH') {
|
|
|
+ $payData['pay_prepayid'] = $params['join_order_member_id'] . '-CASH';
|
|
|
+ } else if ($params['pay_category'] == 'WELFARE') {
|
|
|
+ $payData['pay_prepayid'] = $params['join_order_member_id'] . '-WELFARE';
|
|
|
+ } else if ($params['pay_category'] == 'CARD') {
|
|
|
+ $payData['pay_prepayid'] = $params['card_nbr'];
|
|
|
+ } else if ($params['pay_category'] == 'OFFLINE') {
|
|
|
+ $payData['pay_prepayid'] = 'OFFLINE';
|
|
|
+ } else if ($params['pay_category'] == 'OFFLINE_ALIPAY') {
|
|
|
+ $payData['pay_prepayid'] = 'OFFLINE_ALIPAY';
|
|
|
+ } else if ($params['pay_category'] == 'OFFLINE_WXPAY') {
|
|
|
+ $payData['pay_prepayid'] = 'OFFLINE_WXPAY';
|
|
|
+ } else if ($params['pay_category'] == 'MONEY') {
|
|
|
+ $payData['pay_prepayid'] = 'MONEY';
|
|
|
+ }
|
|
|
+ // 如果 是APP 过来的菜订单,可能没有paydetail
|
|
|
+ if (!PayDetail::where('join_pay_order_id', $order->order_groupby)->where('pay_category', '<>', 'WXPAY')->where('pay_category', '<>', 'ALIPAY')->exists()) {
|
|
|
+ $payData['join_pay_member_id'] = $params['join_order_member_id'];
|
|
|
+ $payData['join_pay_order_id'] = $order->order_groupby;
|
|
|
+ $payData['pay_status'] = $payData['pay_status'] == 'SUCCESS' ? $payData['pay_status'] : 'WAITING';
|
|
|
+ $payData['pay_category'] = $params['goods_classify'] ?? '';
|
|
|
+ $payData['pay_json_request'] = json_encode($params); // {"pay-result": "支付成功", "result-datetime": "2024-07-29 18:38:21"}
|
|
|
+ $payData['pay_json_response'] = $payData['pay_status'] == 'SUCCESS' ? json_encode([
|
|
|
+ 'pay-result' => '支付成功', 'result-datetime' => date('Y-m-d H:i:s')
|
|
|
+ ]) : '[]';
|
|
|
+ $payData['join_pay_object_json'] = !empty($params['orderId']) ? json_encode(['order_id' => $params['orderId']]) : '[]';
|
|
|
+ $payData['pay_addtimes'] = time();
|
|
|
+
|
|
|
+ PayDetail::insert($payData);
|
|
|
+ } else {
|
|
|
+ // 更新非微信支付宝的支付记录
|
|
|
+ PayDetail::where('join_pay_order_id', $order->order_groupby)->where('pay_category', '<>', 'WXPAY')->where('pay_category', '<>', 'ALIPAY')->update($payData);
|
|
|
+ }
|
|
|
+
|
|
|
+ // 2.4W 康养城
|
|
|
+ if ($params['goods_classify'] == 'VIP' && $order->order_status_payment == 'SUCCESS') {
|
|
|
+ $params['member_id'] = $params['join_order_member_id'];
|
|
|
+ Event::dispatch('order.kangyangCityVIP.grant', $params);
|
|
|
+ }
|
|
|
+
|
|
|
+ Db::commit();
|
|
|
+
|
|
|
+ if ($order->order_is_complete == 'Y' && $order->order_status_payment == 'SUCCESS') {
|
|
|
+ Event::dispatch('order.complete', $params);
|
|
|
+ }
|
|
|
+
|
|
|
+ if ($order->order_status_payment != 'SUCCESS') {
|
|
|
+ _syslog("订单", "支付异常,检查是否有轮询");
|
|
|
+ return json_throw(2001, '支付异常', ['order_id' => $params['orderId']]);
|
|
|
+ }
|
|
|
+ _syslog("订单", "订单支付成功");
|
|
|
+ return json_success('支付成功');
|
|
|
+ } catch (BusinessException $e) {
|
|
|
+ dump($e->getMessage());
|
|
|
+ Db::rollBack();
|
|
|
+ _syslog("订单", "订单支付失败:" . $e->getMessage());
|
|
|
+ return json_fail("支付失败:" . $e->getMessage());
|
|
|
+ } catch (\Exception $e) {
|
|
|
+ dump($e->getMessage());
|
|
|
+ Db::rollBack();
|
|
|
+ _syslog("订单", "订单支付失败");
|
|
|
+ return json_fail('支付失败');
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @Desc
|
|
|
+ * @Author Gorden
|
|
|
+ * @Date 2024/6/7 10:30
|
|
|
+ *
|
|
|
+ * @param $params
|
|
|
+ * @return void
|
|
|
+ * @throws BusinessException
|
|
|
+ */
|
|
|
+ public function insertMain($params)
|
|
|
+ {
|
|
|
+ try {
|
|
|
+ $orderCategory = 'NORMAL';
|
|
|
+ if (!empty($params['order_category'])) {
|
|
|
+ $orderCategory = $params['order_category'];
|
|
|
+ } else if (isset($params['submit_goods_classify']) && $params['submit_goods_classify'] == 'MEALS') {
|
|
|
+ $orderCategory = 'DISHES';
|
|
|
+ } else if (isset($params['goods_classify'])) {
|
|
|
+ $orderCategory = $params['goods_classify'];
|
|
|
+ }
|
|
|
+ if (empty($params['order_extend_json'])) {
|
|
|
+ $params['order_extend_json'] = [];
|
|
|
+ } else {
|
|
|
+ if (is_json($params['order_extend_json'])) {
|
|
|
+ $params['order_extend_json'] = json_decode($params['order_extend_json'], true);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ // 推荐人
|
|
|
+ $params['order_extend_json']['referee'] = $params['referee'] ?? '';
|
|
|
+
|
|
|
+ $data = [
|
|
|
+ 'order_id' => $params['orderId'],
|
|
|
+ 'order_groupby' => $params['orderGroupId'],
|
|
|
+ 'join_order_member_id' => $params['join_order_member_id'],
|
|
|
+ 'order_name' => date('Y-m-d H:i:s') . '-订单',
|
|
|
+ 'order_amount_total' => $params['order_amount_total'],
|
|
|
+ 'order_amount_pay' => $params['order_amount_pay'],
|
|
|
+ 'order_category' => $orderCategory,
|
|
|
+ 'order_is_complete' => $params['order_is_complete'] ?? 'N',
|
|
|
+ 'order_status_system' => $params['order_status_system'],
|
|
|
+ 'order_status_payment' => $params['order_status_payment'],
|
|
|
+ 'order_status_storage' => $params['order_status_storage'],
|
|
|
+ 'order_platform' => $params['order_platform'],
|
|
|
+ 'order_remark' => $params['order_remark'] ?? '',
|
|
|
+ 'order_discount_json' => $params['order_discount_json'] ?? '[]',
|
|
|
+ 'order_config_json' => $params['order_config_json'] ?? '[]',
|
|
|
+ 'order_express_json' => $params['order_express_json'] ?? '[]',
|
|
|
+ 'order_extend_json' => $params['order_extend_json'] ? json_encode($params['order_extend_json']) : '[]',
|
|
|
+ 'order_addtimes' => time()
|
|
|
+ ];
|
|
|
+
|
|
|
+ Order::insert($data);
|
|
|
+ } catch (\Exception $e) {
|
|
|
+ dump($e->getMessage());
|
|
|
+ throw new BusinessException('订单创建信息失败');
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @Desc
|
|
|
+ * @Author Gorden
|
|
|
+ * @Date 2024/6/7 10:25
|
|
|
+ *
|
|
|
+ * @param $params
|
|
|
+ * @return void
|
|
|
+ * @throws BusinessException
|
|
|
+ */
|
|
|
+ public function insertSheet($params)
|
|
|
+ {
|
|
|
+ try {
|
|
|
+ $orderSheetIds = [];
|
|
|
+ foreach ($params['goodsContentList'] as $goods) {
|
|
|
+ //{"unit": "份", "table": null, "premises": "15"}
|
|
|
+ $price = floatval($goods['goods_sales_price']);
|
|
|
+ $extendJson['unit'] = $goods['sku_name'];
|
|
|
+ if (isset($params['submit_premises_id'])) {
|
|
|
+ $extendJson['premises'] = $params['submit_premises_id'];
|
|
|
+ }
|
|
|
+ if (isset($params['submit_goods_classify']) && $params['submit_goods_classify'] == 'MEALS') {
|
|
|
+ $extendJson['table'] = null;
|
|
|
+ }
|
|
|
+ $data = [
|
|
|
+ 'join_sheet_member_id' => $params['join_order_member_id'],
|
|
|
+ 'join_sheet_order_id' => $params['orderId'],
|
|
|
+ 'join_sheet_goods_id' => $goods['goods_id'],
|
|
|
+ 'join_sheet_goods_sku_id' => $goods['sku_id'],
|
|
|
+ 'order_sheet_status' => $params['settlement_now'] == 'Y' && $params['order_status_payment'] == 'SUCCESS' ? 'DONE' : 'PAYING',
|
|
|
+ 'order_sheet_category' => (isset($params['submit_goods_classify']) && $params['submit_goods_classify'] == 'MEALS') ? 'DISHES' : 'NORMAL',
|
|
|
+ 'order_sheet_num' => $goods['nbr'],
|
|
|
+ 'order_sheet_price' => $goods['goods_sales_price'],
|
|
|
+ 'order_sheet_amount' => $price * $goods['nbr'],
|
|
|
+ 'order_sheet_pay' => $price * $goods['nbr'],
|
|
|
+ 'order_sheet_task_status' => 'NONE',
|
|
|
+ 'order_sheet_remark' => $params['order_remark'] ?? '',
|
|
|
+ 'order_sheet_addtimes' => time(),
|
|
|
+ 'order_sheet_extend_json' => json_encode($extendJson)
|
|
|
+ ];
|
|
|
+
|
|
|
+ $orderSheetId = OrderSheet::insertGetId($data);
|
|
|
+ $orderSheetIds[] = $orderSheetId;
|
|
|
+
|
|
|
+ // 减库存,规格和总库存
|
|
|
+ if (!isset($params['submit_goods_classify']) || !in_array($params['submit_goods_classify'], ['MEALS', 'PACKAGE'])) {
|
|
|
+ $goodsSku = GoodsSku::where('goods_sku_id', $goods['sku_id'])->first();
|
|
|
+ $skuStorageJson = json_decode($goodsSku->goods_sku_storage_json, true);
|
|
|
+ if (isset($skuStorageJson['storage']) && !empty($skuStorageJson['storage'])) {
|
|
|
+ $skuStorageJson['storage'] = $skuStorageJson['storage'] - $goods['nbr'];
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!isset($skuStorageJson['storage']) || (!empty($skuStorageJson['storage']) && $skuStorageJson['storage'] < 0)) {
|
|
|
+ throw new BusinessException('库存不足');
|
|
|
+ }
|
|
|
+ $goodsSku->goods_sku_storage_json = json_encode($skuStorageJson);
|
|
|
+ $goodsSku->save();
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ $goodsRunning = GoodsRunning::where('join_running_goods_id', $goods['goods_id'])->first();
|
|
|
+ $goodsRunning->goods_running_storage = $goodsRunning->goods_running_storage - $goods['nbr'];
|
|
|
+ if ($goodsRunning->goods_running_storage < 0) {
|
|
|
+ throw new BusinessException('库存不足');
|
|
|
+ }
|
|
|
+ $goodsRunning->goods_running_sale = $goodsRunning->goods_running_sale + $goods['nbr'];
|
|
|
+ $goodsRunning->save();
|
|
|
+ }
|
|
|
+ return $orderSheetIds;
|
|
|
+ } catch (\support\exception\BusinessException $e) {
|
|
|
+ dump($e->getMessage() . '||' . $e->getLine());
|
|
|
+ throw new BusinessException($e->getMessage());
|
|
|
+ } catch (\Exception $e) {
|
|
|
+ dump($e->getMessage() . '||' . $e->getLine());
|
|
|
+ throw new BusinessException('订单创建失败');
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @Desc
|
|
|
+ * @Author Gorden
|
|
|
+ * @Date 2024/6/7 10:35
|
|
|
+ *
|
|
|
+ * @param $params
|
|
|
+ * @return void
|
|
|
+ * @throws BusinessException
|
|
|
+ */
|
|
|
+ public function insertPayDetail($params)
|
|
|
+ {
|
|
|
+ try {
|
|
|
+ if (in_array($params['pay_category'], ['WXPAY', 'ALIPAY'])) {
|
|
|
+ $payPrepayid = $params['pay_category'];
|
|
|
+ } else if ($params['pay_category'] == 'OFFLINE') {
|
|
|
+ $payPrepayid = 'OFFLINE';
|
|
|
+ } else if ($params['pay_category'] == 'OFFLINE_ALIPAY') {
|
|
|
+ $payPrepayid = 'OFFLINE_ALIPAY';
|
|
|
+ } else if ($params['pay_category'] == 'OFFLINE_WXPAY') {
|
|
|
+ $payPrepayid = 'OFFLINE_WXPAY';
|
|
|
+ } else if ($params['pay_category'] == 'MONEY') {
|
|
|
+ $payPrepayid = 'MONEY';
|
|
|
+ } else {
|
|
|
+ $payPrepayid = $params['join_order_member_id'] . '-' . $params['pay_category'];
|
|
|
+ }
|
|
|
+ $data = [
|
|
|
+ 'join_pay_member_id' => $params['join_order_member_id'],
|
|
|
+ 'join_pay_order_id' => $params['orderGroupId'],
|
|
|
+ 'pay_status' => $params['settlement_now'] == 'Y' && $params['order_status_payment'] == 'SUCCESS' ? 'SUCCESS' : 'WAITING',
|
|
|
+ 'pay_category' => $params['goods_classify'],
|
|
|
+ 'pay_amount' => $params['order_amount_pay'],
|
|
|
+ 'pay_prepayid' => $payPrepayid,
|
|
|
+ 'pay_paytimes' => date('Y-m-d H:i:s'),
|
|
|
+ 'join_pay_object_json' => !empty($params['orderId']) ? json_encode(['order_id' => $params['orderId']]) : '[]',
|
|
|
+ 'pay_json_request' => json_encode($params),
|
|
|
+ 'pay_json_response' => $params['pay_json_response'] ?? '[]',
|
|
|
+ 'pay_remark' => $params['order_remark'] ?? '',
|
|
|
+ 'pay_addtimes' => time(),
|
|
|
+ ];
|
|
|
+
|
|
|
+ PayDetail::insert($data);
|
|
|
+ } catch (\Exception $e) {
|
|
|
+ dump($e->getMessage());
|
|
|
+ throw new BusinessException('创建支付记录失败');
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|