wupengfei 1 年之前
父節點
當前提交
662ac2279c

+ 15 - 12
.idea/workspace.xml

@@ -2,10 +2,13 @@
 <project version="4">
   <component name="ChangeListManager">
     <list default="true" id="1a36929e-c054-4875-a943-593a74e55fa4" name="Default Changelist" comment="">
+      <change afterPath="$PROJECT_DIR$/application/common/model/StoreOrderRefund.php" afterDir="false" />
       <change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
-      <change beforePath="$PROJECT_DIR$/application/api/controller/Demand.php" beforeDir="false" afterPath="$PROJECT_DIR$/application/api/controller/Demand.php" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/application/api/controller/Activity.php" beforeDir="false" afterPath="$PROJECT_DIR$/application/api/controller/Activity.php" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/application/api/controller/Alipay.php" beforeDir="false" afterPath="$PROJECT_DIR$/application/api/controller/Alipay.php" afterDir="false" />
       <change beforePath="$PROJECT_DIR$/application/common/model/Activity.php" beforeDir="false" afterPath="$PROJECT_DIR$/application/common/model/Activity.php" afterDir="false" />
       <change beforePath="$PROJECT_DIR$/application/common/service/Activity.php" beforeDir="false" afterPath="$PROJECT_DIR$/application/common/service/Activity.php" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/application/common/service/SerBase.php" beforeDir="false" afterPath="$PROJECT_DIR$/application/common/service/SerBase.php" afterDir="false" />
     </list>
     <option name="SHOW_DIALOG" value="false" />
     <option name="HIGHLIGHT_CONFLICTS" value="true" />
@@ -134,7 +137,7 @@
     <property name="ASKED_ADD_EXTERNAL_FILES" value="true" />
     <property name="RunOnceActivity.ShowReadmeOnStart" value="true" />
     <property name="WebServerToolWindowFactoryState" value="false" />
-    <property name="last_opened_file_path" value="$PROJECT_DIR$/../ddsc" />
+    <property name="last_opened_file_path" value="$PROJECT_DIR$/application/common/model" />
     <property name="node.js.detected.package.eslint" value="true" />
     <property name="node.js.detected.package.tslint" value="true" />
     <property name="node.js.path.for.package.eslint" value="project" />
@@ -145,19 +148,19 @@
     <property name="two.files.diff.last.used.folder" value="$PROJECT_DIR$" />
   </component>
   <component name="RecentsManager">
-    <key name="MoveFile.RECENT_KEYS">
-      <recent name="D:\zs\gaoyixia\public\wx_cert" />
-      <recent name="D:\zs\gaoyixia\public\a" />
-      <recent name="D:\zs\gaoyixia\public" />
-      <recent name="D:\zs\gaoyixia\application\api\controller" />
-    </key>
     <key name="CopyFile.RECENT_KEYS">
+      <recent name="D:\zs\gaoyixia\application\common\model" />
       <recent name="D:\zs\gaoyixia\application\operate\view" />
       <recent name="D:\zs\gaoyixia\application\operate\controller" />
-      <recent name="D:\zs\gaoyixia\application\common\model" />
       <recent name="D:\zs\gaoyixia\config" />
       <recent name="D:\zs\gaoyixia\application\operate\view\supplier_classify" />
     </key>
+    <key name="MoveFile.RECENT_KEYS">
+      <recent name="D:\zs\gaoyixia\public\wx_cert" />
+      <recent name="D:\zs\gaoyixia\public\a" />
+      <recent name="D:\zs\gaoyixia\public" />
+      <recent name="D:\zs\gaoyixia\application\api\controller" />
+    </key>
   </component>
   <component name="SvnConfiguration">
     <configuration />
@@ -314,7 +317,7 @@
       <workItem from="1683593806398" duration="18594000" />
       <workItem from="1683680449159" duration="24035000" />
       <workItem from="1683766597228" duration="22109000" />
-      <workItem from="1683852930702" duration="7256000" />
+      <workItem from="1683852930702" duration="19254000" />
     </task>
     <servers />
   </component>
@@ -440,10 +443,10 @@
       <screen x="0" y="0" width="2560" height="1400" />
     </state>
     <state x="1211" y="541" key="#com.intellij.fileTypes.FileTypeChooser/0.0.2560.1400@0.0.2560.1400" timestamp="1675311007920" />
-    <state x="1106" y="469" key="#com.jetbrains.php.actions.copyPaste.importReferences.PhpImportReferencesDialog" timestamp="1683703719384">
+    <state x="1106" y="469" key="#com.jetbrains.php.actions.copyPaste.importReferences.PhpImportReferencesDialog" timestamp="1683880731541">
       <screen x="0" y="0" width="2560" height="1400" />
     </state>
-    <state x="1106" y="469" key="#com.jetbrains.php.actions.copyPaste.importReferences.PhpImportReferencesDialog/0.0.2560.1400@0.0.2560.1400" timestamp="1683703719384" />
+    <state x="1106" y="469" key="#com.jetbrains.php.actions.copyPaste.importReferences.PhpImportReferencesDialog/0.0.2560.1400@0.0.2560.1400" timestamp="1683880731541" />
     <state x="420" y="147" width="1942" height="1088" key="DiffContextDialog" timestamp="1683710739557">
       <screen x="0" y="0" width="2560" height="1400" />
     </state>

+ 8 - 3
application/api/controller/Activity.php

@@ -14,6 +14,7 @@ use app\common\model\BillHeader;
 use app\common\model\DatumUrl;
 use app\common\model\DeliveryAddress;
 use app\common\model\PlatformLike;
+use app\common\model\StoreOrderRefund;
 use app\common\model\User;
 use app\common\model\UserCollect;
 use app\common\model\UserSearch;
@@ -1156,12 +1157,16 @@ class Activity extends Base
     public function hxOrder(){
         $qr_content = input('post.qr_content');
         if(!$qr_content) $this->error('没有核销内容');
-        $item_info = ActivityApplyItem::where(['i.qr_content'=>$qr_content,'is_hx'=>0])->alias('i')->field('i.is_hx,i.status,i.is_deleted,a.status,a.cancel_state,a,pay_state,a.refund_state')
+        $item_info = ActivityApplyItem::where(['i.qr_content'=>$qr_content,'is_hx'=>0])
+            ->alias('i')->field('i.is_hx,i.status,i.apply_id,i.is_deleted,a.status,a.cancel_state,a,pay_state,a.refund_state')
             ->leftJoin("ActivityApply a",'a.id = i.apply_id')->find();
         if(!$item_info) $this->error('没有找到核销记录');
         if($item_info->pay_state)$this->error('订单已取消');
-        if(!in_array($item_info->refund_state,[0,3]))$this->error('订单已申请退款');
-        ActivityApplyItem::where('id',$item_info['id'])->update(['is_hx'=>1]);
+        $refund_info = StoreOrderRefund::getRefundInfo($item_info['apply_id'],$item_info['id'],1);
+        if(!empty($refund_info && in_array($refund_info['status'],[0,1,3,5])))$this->error('已申请退款');
+        //if(!in_array($item_info->refund_state,[0,3]))$this->error('订单已申请退款');
+        if(!in_array($item_info->status,[1]))$this->error('票状态异常');
+        ActivityApplyItem::where('id',$item_info['id'])->update(['is_hx'=>1,'ticket_status'=>1]);
         $this->success('核销成功');
     }
 

+ 9 - 1
application/api/controller/Alipay.php

@@ -200,5 +200,13 @@ class Alipay extends Base
     }
 
 
-
+    /**
+     * 支付宝支付退款
+     */
+    public static function aliRefund($outTradeNo,$totalAmount,$type= 'H5'){
+        Factory::setOptions(self::getOptions('',$type));
+        $result = Factory::payment()->common()->refund($outTradeNo,$totalAmount);
+        $responseChecker = new ResponseChecker();
+        return $responseChecker->success($result);
+    }
 }

+ 0 - 11
application/common/model/Activity.php

@@ -57,15 +57,4 @@ class Activity extends Model
     }
 
 
-    /**
-     * 订单申请退款
-     * @param $order_id
-     * @param $item_id
-     */
-    public static function orderApplyRefund($order_id,$item_id,$refund)
-    {
-
-    }
-
-
 }

+ 23 - 0
application/common/model/StoreOrderRefund.php

@@ -0,0 +1,23 @@
+<?php
+namespace app\common\model;
+use think\Model;
+// 订单退款
+class StoreOrderRefund extends Model
+{
+    //获取订单退款金额
+    public static function getRefundMoney($order_id,$type = 1)
+    {
+        return static::where('order_id',$order_id)
+            ->where('status','in','0,1,3')
+            ->where('type',$type)->sum('refund_money');
+    }
+
+    // 获取退款详情
+    public static function getRefundInfo($order_id,$item_id,$type =1)
+    {
+        $info = static ::where('order_id',$order_id)->where('item_id',$item_id)->where('type',$type)->find();
+        return $info ? $info->toArray() : [];
+    }
+
+
+}

+ 88 - 10
application/common/service/Activity.php

@@ -1,24 +1,102 @@
 <?php
 namespace app\common\service;
-use app\common\model\DiscountActivity;
-use app\common\model\DiscountGoods;
-use app\common\model\GroupActivity;
-use app\common\model\GroupGoods;
-use app\common\model\ReductionActivity;
-use app\common\model\SeckillActivity;
-use app\common\model\SeckillGoods;
+use app\common\model\ActivityApply;
+use app\common\model\ActivityApplyItem;
+use app\common\model\GoodsOrderRefund;
+use app\common\model\StoreOrderRefund;
+use app\api\controller\Alipay;
+use EasyWeChat\Factory;
+use library\tools\Data;
+use think\Db;
+use think\Exception;
 
 /**
  * 活动管理
  * Class Activity
  */
-class Activity
+class Activity extends SerBase
 {
 
-    //订单退款
-    public static function orderRefund()
+    /**
+     * 订单申请退款
+     * @param $order_id 订单id
+     * @param $item_id  票id
+     * @param $is_refund  是否立即退款
+     */
+    public static function orderApplyRefund($order_id,$item_id,$is_refund = 0)
     {
+        //$ret_val = static::$ret_val;// ['code' => 200 , 'msg'=>'ok','extend'=>''];
+        $order_info = ActivityApply::where('id',$order_id)->find()->toArray();
+        $item_info  = ActivityApplyItem::where('id',$item_id)->find()->toArray();
+        if(!$order_info['pay_state']) return ['code'=>201,'msg' => '订单未支付'];
+        $refund_money = StoreOrderRefund::getRefundMoney($order_id);
+        if($refund_money >=  $order_info['money'])return ['code'=>201,'msg' => '订单已全额退款'];
+        $refund_info = StoreOrderRefund::where(['order_id'=>$order_id,'item_id'=>$item_id,'type'=>1])->find();
+        if(!$refund_info && in_array($refund_info->status,[0,1,3])) return ['code'=>201,'msg' => '订单已申请退款'];
+        if($item_info['is_hx'] || $item_info['ticket_status'])return ['code'=>201,'msg' => '票已核销无法申请'];
+        // 申请记录详情
+        Data::save('StoreOrderRefund',[
+            'user_id' => $order_info['user_id'],
+            'order_id' => $order_id,
+            'item_id' => $item_id,
+            'type' => 1,
+            'is_deleted' => 0,
+            'sell_price' => $item_info['total_money'],
+            'refund_money' => $item_info['money'],//优惠后价格
+            'refund_no' => get_order_sn(),
+        ],'order_id',['order_id'=>$order_id,'item_id'=>$item_id,'type'=>1]);
+        if($is_refund) {
+            $refund_id = StoreOrderRefund::where(['order_id'=>$order_id,'item_id'=>$item_id,'type'=>1])->value('id');
+            $refund_res = static::orderRefund($refund_id);
+        }
+        return ['code'=>200,'msg' => '申请成功'];
+    }
+
 
+    /**
+     * 确定退款
+     * @param $refund_id 退款记录id
+     */
+    public static function orderRefund($refund_id)
+    {
+        $refund_info = StoreOrderRefund::where('id',$refund_id)->find()->toArray();
+        if(in_array($refund_info['status'],[2,3,5]) || $refund_info['is_deleted'])  return ['code'=>201,'msg' => '退款记录异常'];
+        $order_info = ActivityApply::where('id',$refund_info['order_id'])->find()->toArray();
+        $item_info  = ActivityApplyItem::where('id',$refund_info['item_id'])->find()->toArray();
+        if($item_info['is_hx'] || $item_info['ticket_status'])return ['code'=>201,'msg' => '票已核销无法退款'];
+        // (1.h5微信,2.h5支付宝,3.app微信,4.app支付宝,5.h5微信内支付,9线下支付)
+        if($refund_info['refund_money'] <= 0 || $refund_info['refund_money'] > $order_info['money']) return ['code'=>201,'订单退款金额有误'];
+        Db::startTrans();
+        try {
+            $refund_no = $refund_info['refund_no'] ? $refund_info['refund_no'] : get_order_sn();
+            //微信退款
+            if(in_array($order_info['pay_type'],[1,3,5])){ // h5
+                $app = $order_info['pay_type'] == 3 ? Factory::payment(config('app.app_wx')) :  Factory::payment(config('app.wx_pay'));
+                $result = $app->refund->byOutTradeNumber($order_info['pay_no'], $refund_no, $order_info['money'] * 100, $refund_info['refund_money']*100, ['refund_desc' => '订单退款']);
+                if($result['return_code'] != 'SUCCESS')  throw new Exception('微信退款异常');
+                if($result['result_code'] != 'SUCCESS')  throw new Exception($result['err_code_des']);
+                // 修改退款记录状态
+                GoodsOrderRefund::where(['id'=>$refund_info['id']])->update(['refund_no'=>$refund_no,'status'=>3]);
+            }
+            //  支付宝退款
+            if(in_array($order_info['pay_type'],[2,4]))
+            {
+                $result =  Alipay::aliRefund($order_info['pay_no'], $refund_info['refund_money'],$order_info['pay_type'] == 2 ?'H5':'APP');
+                if(!$result)   throw new Exception('支付宝退款异常');
+                // 修改退款记录状态
+                GoodsOrderRefund::where(['id'=>$refund_info['id']])->update(['refund_no'=>$refund_no,'status'=>3]);
+            }
+            if(in_array($order_info['pay_type'],[9])) {
+                // 修改退款记录状态
+                GoodsOrderRefund::where(['id'=>$refund_info['id']])->update(['refund_no'=>$refund_no,'status'=>3]);
+            }
+            Db::commit();
+        }catch (\Exception $e){
+            Db::rollback();
+            GoodsOrderRefund::where(['id'=>$refund_info['id']])->update(['status'=>4]);
+            return ['code'=>201 ,'msg'=>$e->getMessage()];
+        }
+        return ['code'=>200,'msg'=>'退款成功'];
     }
 
 

+ 1 - 1
application/common/service/SerBase.php

@@ -8,7 +8,7 @@ use think\Exception;
  */
 class SerBase
 {
-
+    public static  $ret_val = ['code' => 200 , 'msg'=>'ok','extend'=>''];
     public static function exception($msg){
         throw new Exception($msg);
     }