85 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
| <?php
 | ||
| // +----------------------------------------------------------------------
 | ||
| // | 宏驰云科技开发团队 版权所有 拥有最终解释权
 | ||
| // +----------------------------------------------------------------------
 | ||
| 
 | ||
| // | Author: HcyShop-kiki
 | ||
| // +----------------------------------------------------------------------
 | ||
| namespace app\common\logic;
 | ||
| use think\Db;
 | ||
| 
 | ||
| class CouponLogic {
 | ||
|     public static function couponClose($user_id = ''){
 | ||
|         $coupon_list = Db::name('coupon')
 | ||
|             ->where(['del'=>0])
 | ||
|             ->column('id,use_time_type,use_time_start,use_time_end,use_time','id');
 | ||
| 
 | ||
|         $coupon_ids = array_keys($coupon_list);
 | ||
|         $where[] = ['coupon_id','in',$coupon_ids];
 | ||
|         $where[] = ['status','in',0];
 | ||
|         if($user_id){
 | ||
|             $where[] = ['user_id','=',$user_id];
 | ||
|         }
 | ||
|         $user_coupon_list = Db::name('coupon_list')
 | ||
|             ->where(['coupon_id'=>$coupon_ids,'status'=>0])
 | ||
|             ->field('id,coupon_id,create_time')
 | ||
|             ->order('id asc')
 | ||
|             ->select();
 | ||
| 
 | ||
|         $now = time();
 | ||
|         $update_data = [];
 | ||
|         foreach ($user_coupon_list as $coupon_item){
 | ||
|             $coupon = $coupon_list[$coupon_item['coupon_id']] ?? [];
 | ||
|             if($coupon){
 | ||
|                 //用券时间类型:1-固定时间;2-领券当天起;3-领券次日起
 | ||
|                 switch ($coupon['use_time_type']){
 | ||
|                     case 1:
 | ||
|                         if($now > $coupon['use_time_end']){
 | ||
|                             $update_data[] = $coupon_item['id'];
 | ||
|                         }
 | ||
|                         break;
 | ||
|                     case 2:
 | ||
|                         $daytime = strtotime(date("Y-m-d",$coupon_item['create_time'])) + 86400 * $coupon['use_time'];
 | ||
|                         if($now > $daytime){
 | ||
|                             $update_data[] = $coupon_item['id'];
 | ||
|                         }
 | ||
|                         break;
 | ||
|                     case 3:
 | ||
|                         $day = $coupon['use_time'] + 2;
 | ||
|                         $daytime = strtotime(date("Y-m-d",$coupon_item['create_time'])) + 86400 * $day;
 | ||
|                         if($now > $daytime){
 | ||
|                             $update_data[] = $coupon_item['id'];
 | ||
|                         }
 | ||
|                 }
 | ||
|             }
 | ||
|         }
 | ||
| 
 | ||
|         if($update_data){
 | ||
|             Db::name('coupon_list')->where(['id'=>$update_data])->update(['status'=>2,'update_time'=>$now]);
 | ||
| 
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
|     /**
 | ||
|      * Desc: 使用优惠券
 | ||
|      * @param $coupon_list_id
 | ||
|      * @param $order_id
 | ||
|      * @throws \think\Exception
 | ||
|      * @throws \think\exception\PDOException
 | ||
|      */
 | ||
|     public static function handleCouponByOrder($coupon_list_id, $order_id)
 | ||
|     {
 | ||
|         $update_coupon = [
 | ||
|             'status' => 1,
 | ||
|             'use_time' => time(),
 | ||
|             'order_id' => $order_id,
 | ||
|             'update_time' => time(),
 | ||
|         ];
 | ||
| 
 | ||
|         Db::name('coupon_list')
 | ||
|             ->where('id', $coupon_list_id)
 | ||
|             ->update($update_coupon);
 | ||
|     }
 | ||
| } |