当前位置:首页 > CMS教程 > ecshop > 列表

ecshop自动分成二次开发实例

发布:smiling 来源: PHP粉丝网  添加日期:2015-12-10 13:52:15 浏览: 评论:0 

自动分成功能在ecshop系统自带是没有的,如果我们需要对一单添加分成功能我们是需要进入二次开发的,下面小编来为各位介绍一个例子.

大概逻辑:

后台操作一个订单发货的时候进行自动分成,后台取消发货,退货,改为未发货的时候去掉自动分成部分.

核心代码:lib_common.php

  1. //分成积分计算 
  2.  
  3. function fenchenjifen($usertype=3,$point){
  4.  
  5.  $affiliate = unserialize($GLOBALS['_CFG']['affiliate']); 
  6.  
  7. if($usertype==3){   //采购                          
  8.  
  9.                 if ($affiliate['config']['level_register_up']) 
  10.  
  11.         { 
  12.  
  13.             $affiliate['config']['level_register_up'] /= 100; 
  14.  
  15.         } 
  16.  
  17.             $point_cg = round($affiliate['config']['level_register_up'] * intval($point), 0); 
  18.  
  19.             return $point_cg
  20.  
  21.         }    
  22.  
  23. if($usertype==1){//经销商 
  24.  
  25.         if ($affiliate['config']['level_money_all']) 
  26.  
  27.         { 
  28.  
  29.             $affiliate['config']['level_money_all'] /= 100; 
  30.  
  31.         } 
  32.  
  33.             $point_cg = round($affiliate['config']['level_money_all'] * intval($point), 0); 
  34.  
  35.             return $point_cg
  36.  
  37.         }    
  38.  
  39. if($usertype==2){//财务 
  40.  
  41.     if ($affiliate['config']['level_register_all']) 
  42.  
  43.         { 
  44.  
  45.             $affiliate['config']['level_register_all'] /= 100; 
  46.  
  47.         } 
  48.  
  49.             $point_cg = round($affiliate['config']['level_register_all'] * intval($point), 0); 
  50.  
  51.             return $point_cg
  52.  
  53.         }  
  54.  
  55.  
  56.    
  57. /** 
  58.  
  59.  
  60.  
  61. * @param <a href="/tags.php/undefined/" target="_blank">undefined</a> $order  订单信息 
  62.  
  63. * @param undefined $buyuser 购买者信息 
  64.  
  65. * @param undefined $integral 计算积分 
  66.  
  67. * $type = 1 增加  $type=-1 撤销 
  68.  
  69. * 分成log状态99 
  70.  
  71. */ 
  72.  
  73. function fun_fencheng_change($order,$buyuser,$integral=array(),$type=1){//店铺分成计算 
  74.  
  75.     if(intval($order['parent_shopid'])==0) return false; 
  76.  
  77.     if(!is_array($buyuser)) return false; 
  78.  
  79.        
  80.  
  81.     $order_id=$order['order_id']; 
  82.  
  83.     $separate_by=99; 
  84.  
  85.     switch($buyuser['usertype']){ 
  86.  
  87.         case '0'://购买者类型 
  88.  
  89.          $row = $GLOBALS['db']->getRow("SELECT * from " . $GLOBALS['ecs']->table('users') . " u "
  90.  
  91.                     " WHERE u.shopid  =".$order['parent_shopid']." and u.usertype=1" 
  92.  
  93.                 );//获取pid 
  94.  
  95.            
  96.  
  97.             $up_uid = $row['user_id'];           
  98.  
  99.             if(!emptyempty($up_uid) && $up_uid > 0) 
  100.  
  101.             { 
  102.  
  103.                 $money=$point=0;     
  104.  
  105.                 $point= fenchenjifen(1,$integral['custom_points']);  
  106.  
  107.                            
  108.  
  109.                // $info = sprintf($GLOBALS['_LANG']['separate_info'], $order['order_sn'], $money, $point); 
  110.  
  111.                 $info="订单".$order['order_sn']."分成获得积分:".$point
  112.  
  113.                 log_account_change($up_uid$money, 0, ($type)*$point, ($type)*$point$info); 
  114.  
  115.                 //var_dump($info);   
  116.  
  117.                 if($type==1){            
  118.  
  119.                    
  120.  
  121.                 write_affiliate_log1($order_id$up_uid$row['user_name'], $money$point$separate_by); 
  122.  
  123.                 }else
  124.  
  125.                     rollback_affiliate_log($order_id); 
  126.  
  127.                 } 
  128.  
  129.                 $orderupdate['is_separate']=$type==1?$separate_by:0; 
  130.  
  131.                  $GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_info'), 
  132.  
  133.         $orderupdate'UPDATE'"order_id = '$order_id'"); 
  134.  
  135.             } 
  136.  
  137.         break
  138.  
  139.         case '3'
  140.  
  141.         $row = $GLOBALS['db']->getAll("SELECT u.shopid,u.user_id,u.usertype, u.user_name FROM " . $GLOBALS['ecs']->table('users') . " u "
  142.  
  143.                     " WHERE u.shopid= ".$order['parent_shopid']." and u.usertype in (1,2)"); 
  144.  
  145.                     <a href="/tags.php/foreach/" target="_blank">foreach</a>($row as $val){ // 经销商和财务获得分成 
  146.  
  147.                         if($val['usertype']==1){ 
  148.  
  149.                             $pointf = fenchenjifen(1,$integral['custom_points']);    
  150.  
  151.                             } 
  152.  
  153.                         if($val['usertype']==2){ 
  154.  
  155.                             $pointf = fenchenjifen(2,$integral['custom_points']);    
  156.  
  157.                             }    
  158.  
  159.                             $up_uid = $val['user_id']; 
  160.  
  161.                             //$info = sprintf($GLOBALS['_LANG']['separate_info'], $order['order_sn'], $money, $pointf); 
  162.  
  163.                             $info="订单".$order['order_sn']."分成获得积分:".$pointf
  164.  
  165.                 log_account_change($up_uid$money, 0, ($type)*$pointf, ($type)*$pointf$info); 
  166.  
  167.                    
  168.  
  169.                 if($type==1){            
  170.  
  171.                       write_affiliate_log1($order_id$up_uid$val['user_name'], $money$pointf$separate_by); 
  172.  
  173.                 }else
  174.  
  175.                     rollback_affiliate_log($order_id); 
  176.  
  177.                 } 
  178.  
  179.                  $orderupdate['is_separate']=$type==1?$separate_by:0; 
  180.  
  181.                  $GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_info'), 
  182.  
  183.         $orderupdate'UPDATE'"order_id = '$order_id'");       
  184.  
  185.                     } 
  186.  
  187.            
  188.  
  189.         break
  190.  
  191.     } 
  192.  
  193.     return true; 
  194.  
  195.  
  196.    
  197.  
  198. /** 
  199.  
  200.  
  201.  
  202. * @param undefined $oid 
  203.  
  204. * @param undefined $uid 
  205.  
  206. * @param undefined $username 
  207.  
  208. * @param undefined $money 
  209.  
  210. * @param undefined $point 
  211.  
  212. * @param undefined $separate_by 
  213.  
  214. * 写入订单分成 log 
  215.  
  216. */ 
  217.  
  218. function write_affiliate_log1($oid$uid$username$money$point$separate_by
  219.  
  220.  
  221.     $time = gmtime(); 
  222.  
  223.     $sql = "INSERT INTO " . $GLOBALS['ecs']->table('affiliate_log') . "( order_id, user_id, user_name, time, money, point, separate_type)"
  224.  
  225.                                                               " VALUES ( '$oid', '$uid', '$username', '$time', '$money', '$point', $separate_by)"
  226.  
  227.     if ($oid
  228.  
  229.     { 
  230.  
  231.         $GLOBALS['db']->query($sql); 
  232.  
  233.     } 
  234.  
  235. }  
  236.  
  237. //撤销订单分成 
  238.  
  239. function rollback_affiliate_log($order_id,$falg=-2){ 
  240. //phpfensi.com 
  241.       $sql = "UPDATE " . $GLOBALS['ecs']->table('affiliate_log') . 
  242.  
  243.                " SET separate_type = '$falg'" . 
  244.  
  245.                " WHERE order_id = '$order_id'"
  246.  
  247.          $GLOBALS['db']->query($sql); 
  248.  

需要注意的点:

后台发货程序在admin/order.php 需要修改的地方有:发货 866行,取消发货 1035行 改为未发货 3961行 退货4132行.

本代码只计算分成部分,自己下单部分另外.

这个代码是按照店铺ID分成,多商户的,为ecshop二次开发版,无法用于原版.

调用分成:fun_fencheng_change($order,$user,$integral,1);

取消分成:fun_fencheng_change($order,$user,$integral,-1);

Tags: ecshop二次开发 ecshop开发实例

分享到: