vr-shopxo-source/application/plugins/freightfee/Hook.php

316 lines
10 KiB
PHP
Raw Normal View History

2019-03-18 08:21:25 +00:00
<?php
2019-03-21 09:34:40 +00:00
// +----------------------------------------------------------------------
// | ShopXO 国内领先企业级B2C免费开源电商系统
// +----------------------------------------------------------------------
// | Copyright (c) 2011~2019 http://shopxo.net All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: Devil
// +----------------------------------------------------------------------
2019-03-18 08:21:25 +00:00
namespace app\plugins\freightfee;
2019-03-21 09:34:40 +00:00
use app\service\PluginsService;
2019-03-18 08:21:25 +00:00
/**
* 运费设置 - 钩子入口
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2016-12-01T21:51:08+0800
*/
2019-03-21 09:34:40 +00:00
class Hook
2019-03-18 08:21:25 +00:00
{
2019-03-21 09:34:40 +00:00
/**
* 应用响应入口
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @datetime 2019-02-09T14:25:44+0800
* @param [array] $params [输入参数]
*/
2019-03-18 08:21:25 +00:00
public function run($params = [])
{
2019-03-21 09:34:40 +00:00
if(!empty($params['hook_name']))
2019-03-18 08:21:25 +00:00
{
2019-03-21 09:34:40 +00:00
switch($params['hook_name'])
{
2019-04-26 07:22:08 +00:00
// css
case 'plugins_css' :
2019-04-30 08:27:01 +00:00
$ret = __MY_ROOT_PUBLIC__.'static/plugins/css/freightfee/index/style.css';
2019-04-26 07:22:08 +00:00
break;
2019-03-21 09:34:40 +00:00
// 运费计算
case 'plugins_service_buy_handle' :
$ret = $this->FreightFeeCalculate($params);
break;
2019-03-18 08:21:25 +00:00
2019-04-26 07:22:08 +00:00
// 商品免运费icon
case 'plugins_view_goods_detail_title' :
$ret = $this->FreeShippingGoodsIcon($params);
break;
2019-03-21 09:34:40 +00:00
default :
$ret = '';
}
return $ret;
}
}
2019-04-26 07:22:08 +00:00
/**
* 商品免运费icon
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2019-04-26
* @desc description
* @param [array] $params [输入参数]
*/
private function FreeShippingGoodsIcon($params = [])
{
$ret = PluginsService::PluginsData('freightfee');
if($ret['code'] == 0 && !empty($ret['data']['goods_ids']) && !empty($params['goods_id']))
{
$goods_all = explode(',', $ret['data']['goods_ids']);
if(in_array($params['goods_id'], $goods_all))
{
return '<span class="am-badge am-radius plugins-freightfee-goods-icon">免运费</span>';
}
}
return '';
}
2019-03-21 09:34:40 +00:00
/**
* 运费计算
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2019-03-21
* @desc description
* @param [array] $params [输入参数]
*/
public function FreightFeeCalculate($params = [])
{
$ret = PluginsService::PluginsData('freightfee');
if($ret['code'] == 0)
{
// 默认运费
$price = 0;
// 支付方式免运费
$is_payment = true;
if(!empty($ret['data']['payment']) && !empty($params['params']['payment_id']))
{
$payment = array_map(function($v){return explode('-', $v);}, explode(',', $ret['data']['payment']));
if(!empty($payment) && is_array($payment))
{
foreach($payment as $v)
{
if(isset($v[0]) && $v[0] == $params['params']['payment_id'])
{
$is_payment = false;
break;
}
}
}
}
2019-04-26 07:22:08 +00:00
// 免运费商品
2019-04-26 17:53:29 +00:00
$free_goods = $this->FreeShippingGoods(empty($ret['data']['goods_ids']) ? '' : $ret['data']['goods_ids'], $params);
2019-04-26 07:22:08 +00:00
$params['data']['base']['buy_count'] -= $free_goods['buy_count'];
$params['data']['base']['spec_weight_total'] -= $free_goods['spec_weight'];
2019-03-21 09:34:40 +00:00
// 是否设置运费数据
if($is_payment === true && !empty($ret['data']['data'][0]))
2019-03-21 09:34:40 +00:00
{
// 规则
$rules = $this->RulesHandle($ret['data']['data'], $params['data']['base']['address']);
// 计费方式
if(!empty($rules))
{
2019-04-26 07:22:08 +00:00
// 订单金额满免运费
if(empty($rules['free_shipping_price']) || $params['data']['base']['total_price'] < $rules['free_shipping_price'])
2019-03-21 09:34:40 +00:00
{
2019-04-26 07:22:08 +00:00
// 根据规则计算运费
switch($ret['data']['valuation'])
{
// 按件
case 0 :
$price = $this->PieceCalculate($rules, $params['data']);
break;
2019-03-21 09:34:40 +00:00
2019-04-26 07:22:08 +00:00
// 按量
case 1 :
$price = $this->QuantityCalculate($rules, $params['data']);
break;
}
2019-03-21 09:34:40 +00:00
}
}
}
// 扩展展示数据
$show_name = empty($ret['data']['show_name']) ? '运费' : $ret['data']['show_name'];
$params['data']['extension_data'][] = [
'name' => $show_name,
'price' => $price,
2019-03-26 09:48:53 +00:00
'type' => 1,
'tips' => '+¥'.$price.'元',
];
// 金额
$params['data']['base']['increase_price'] += $price;
$params['data']['base']['actual_price'] += $price;
2019-03-21 09:34:40 +00:00
return DataReturn('无需处理', 0);
2019-03-18 08:21:25 +00:00
} else {
2019-03-21 09:34:40 +00:00
return $ret['msg'];
}
}
2019-04-26 07:22:08 +00:00
/**
* 免运费商品
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2019-04-26
* @desc description
* @param [string] $goods_ids [商品ids]
* @param [array] $params [钩子参数]
*/
private function FreeShippingGoods($goods_ids, $params)
{
$result = [
'buy_count' => 0,
'spec_weight' => 0,
];
if(!empty($goods_ids))
{
$goods_all = explode(',', $goods_ids);
foreach($params['data']['goods'] as $goods)
{
if(in_array($goods['goods_id'], $goods_all))
{
$result['buy_count'] += $goods['stock'];
$result['spec_weight'] += $goods['spec_weight'];
}
}
}
return $result;
}
2019-03-21 09:34:40 +00:00
/**
* 按重计费
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2019-03-21
* @desc description
* @param [array] $rules [规则]
* @param [array] $buy [生成订单数据]
*/
public function QuantityCalculate($rules, $buy)
{
$price = 0;
if($rules['first_price'] > 0 && $buy['base']['spec_weight_total'] >= $rules['first'])
{
$price = $rules['first_price'];
}
if($rules['continue_price'] > 0 && $buy['base']['spec_weight_total'] >= $rules['continue']+$rules['first'])
{
$number = ($buy['base']['spec_weight_total']-$rules['first'])/$rules['continue'];
if($number > 0)
{
$price += round($rules['continue_price']*$number);
}
}
return $price;
}
/**
* 按件计费
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2019-03-21
* @desc description
* @param [array] $rules [规则]
* @param [array] $buy [生成订单数据]
*/
public function PieceCalculate($rules, $buy)
{
$price = 0;
if($rules['first_price'] > 0 && $buy['base']['buy_count'] >= $rules['first'])
{
$price = $rules['first_price'];
}
if($rules['continue_price'] > 0 && $buy['base']['buy_count'] >= $rules['continue']+$rules['first'])
{
$number = round(($buy['base']['buy_count']-$rules['first'])/$rules['continue']);
if($number > 0)
{
$price += round($rules['continue_price']*$number);
}
}
return $price;
}
/**
* 运费规则匹配
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2019-03-21
* @desc description
* @param [array] $rules [运费规则列表]
* @param [array] $address [用户地址]
*/
public function RulesHandle($rules, $address)
{
if(count($rules) > 1 && !empty($address))
{
$data = [
'province' => ['rules' => [], 'number' => 0],
'city' => ['rules' => [], 'number' => 0],
];
foreach($rules as $k=>$v)
{
if($k != 0)
{
$region = explode('-', $v['region']);
if(!empty($region))
{
if(in_array($address['province'], $region))
{
$data['province']['rules'] = $v;
$data['province']['number']++;
}
if(in_array($address['city'], $region))
{
$data['city']['rules'] = $v;
$data['city']['number']++;
}
}
}
}
if($data['city']['number'] > 0)
{
if($data['province']['number'] > $data['city']['number'])
{
return $data['province']['rules'];
}
return $data['city']['rules'];
} else {
if($data['province']['number'] > 0)
{
return $data['province']['rules'];
}
}
2019-03-18 08:21:25 +00:00
}
2019-03-21 09:34:40 +00:00
return $rules[0];
2019-03-18 08:21:25 +00:00
}
}
?>