<?php
namespace app\service;
use think\facade\Db;
use app\service\WarehouseService;
use app\service\GoodsService;
* 订单拆分服务层
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2020-07-18
* @desc description
*/
class OrderSplitService
{
* 订单拆分入口
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2020-07-18
* @desc description
* @param [array] $params [输入参数]
*/
public static function Run($params = [])
{
$p = [
[
'checked_type' => 'is_array',
'key_name' => 'goods',
'error_msg' => MyLang('goods_empty_or_format_error_tips'),
],
];
$ret = ParamsChecked($params, $p);
if($ret !== true)
{
return DataReturn($ret, -1);
}
$warehouse_goods = self::GoodsWarehouseAggregate($params);
if(count($warehouse_goods) > 1 && !in_array($params['site_model'], [0,1]))
{
$params['site_model'] = 0;
$params['common_site_type'] = 0;
}
$data = self::GroupGoodsBaseHandle($warehouse_goods, $params);
$hook_name = 'plugins_service_buy_group_goods_handle';
$ret = EventReturnHandle(MyEventTrigger($hook_name, [
'hook_name' => $hook_name,
'is_backend' => true,
'params' => $params,
'data' => &$data,
]));
if(isset($ret['code']) && $ret['code'] != 0)
{
return $ret;
}
if(!empty($data))
{
foreach($data as &$v)
{
if(!empty($v['order_base']['extension_data']))
{
$ext = self::ExtensionDataPriceHandle($v['order_base']['extension_data']);
$v['order_base']['increase_price'] = PriceBeautify(PriceNumberFormat($v['order_base']['increase_price']+$ext['inc']));
$v['order_base']['preferential_price'] = PriceBeautify(PriceNumberFormat($v['order_base']['preferential_price']+$ext['dec']));
$v['order_base']['actual_price'] = PriceBeautify(PriceNumberFormat(($v['order_base']['actual_price']+$ext['inc'])-$ext['dec']));
$v['order_base']['total_price'] = PriceBeautify(PriceNumberFormat($v['order_base']['total_price']));
if($v['order_base']['actual_price'] < 0)
{
$v['order_base']['actual_price'] = 0;
}
}
}
}
return DataReturn(MyLang('operate_success'), 0, $data);
}
* 扩展数据解析金额
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2020-07-23
* @desc description
* @param [array] $data [扩展数据]
*/
public static function ExtensionDataPriceHandle($data)
{
$inc = 0;
$dec = 0;
if(!empty($data))
{
if(!is_array($data))
{
$data = json_decode($data, true);
}
foreach($data as $v)
{
if(isset($v['type']) && isset($v['price']) && $v['price'] > 0)
{
switch($v['type'])
{
case 0 :
$dec += $v['price'];
break;
case 1 :
$inc += $v['price'];
break;
}
}
}
}
return [
'inc' => $inc,
'dec' => $dec,
];
}
* 分组商品基础处理
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2020-07-23
* @desc description
* @param [array] $data [分组商品]
* @param [array] $params [输入参数]
*/
public static function GroupGoodsBaseHandle($data, $params)
{
if(!empty($data))
{
foreach($data as &$v)
{
$total_price = PriceNumberFormat(array_sum(array_column($v['goods_items'], 'total_price')));
$v['order_base'] = [
'total_price' => PriceBeautify($total_price),
'actual_price' => PriceBeautify($total_price),
'preferential_price' => 0.00,
'increase_price' => 0.00,
'goods_count' => count($v['goods_items']),
'spec_weight_total' => array_sum(array_map(function($v) {return $v['spec_weight']*$v['stock'];}, $v['goods_items'])),
'spec_volume_total' => array_sum(array_map(function($v) {return $v['spec_volume']*$v['stock'];}, $v['goods_items'])),
'buy_count' => array_sum(array_column($v['goods_items'], 'stock')),
'address' => $params['address'],
'extraction_address' => $params['extraction_address'],
'site_model' => $params['site_model'],
'common_site_type' => $params['common_site_type'],
'goods_price_show_status' => (array_sum(array_filter(array_column($v['goods_items'], 'show_field_price_status'))) > 0) ? 1 : 0,
'goods_original_price_show_status' => (array_sum(array_filter(array_column($v['goods_items'], 'show_field_original_price_status'))) > 0) ? 1 : 0,
'extension_data' => [],
];
}
}
return $data;
}
* 商品仓库集合
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2020-07-18
* @desc description
* @param [array] $params [输入参数]
*/
public static function GoodsWarehouseAggregate($params)
{
$field = 'w.*,wgs.inventory';
$order_by = 'w.level desc,w.is_default desc,wgs.inventory desc';
$lng = '';
$lat = '';
if(!empty($params['address']))
{
if(isset($params['address']['lng']) && $params['address']['lng'] != 0 && isset($params['address']['lat']) && $params['address']['lat'] != 0)
{
$lng = $params['address']['lng'];
$lat = $params['address']['lat'];
}
}
if(empty($lng) && empty($lat))
{
$request_params = empty($params['params']) ? [] : $params['params'];
$lng = empty($request_params['lng']) ? (empty($request_params['user_lng']) ? '' : $request_params['user_lng']) : $request_params['lng'];
$lat = empty($request_params['lat']) ? (empty($request_params['user_lat']) ? '' : $request_params['user_lat']) : $request_params['lat'];
}
if(!empty($lng) && !empty($lat))
{
$field .= ',ROUND(6378.138*2*ASIN(SQRT(POW(SIN(('.$lat.'*PI()/180-w.lat*PI()/180)/2),2)+COS('.$lat.'*PI()/180)*COS(w.lat*PI()/180)*POW(SIN(('.$lng.'*PI()/180-w.lng*PI()/180)/2),2)))*1000) AS distance';
$order_by = 'distance asc, '.$order_by;
}
$warehouse_default = [];
$result = [];
foreach($params['goods'] as $v)
{
$spec = empty($v['spec']) ? [['type' => GoodsService::GoodsSpecDefaultName(),'value' => 'default']] : $v['spec'];
$where = [
['wgs.goods_id', '=', $v['goods_id']],
['wgs.md5_key', '=', md5(implode('', array_column($spec, 'value')))],
['wgs.inventory', '>', 0],
['wg.goods_id', '=', $v['goods_id']],
['wg.is_enable', '=', 1],
['w.is_enable', '=', 1],
['w.is_delete_time', '=', 0],
];
$warehouse = Db::name('WarehouseGoodsSpec')->alias('wgs')->join('warehouse_goods wg', 'wgs.warehouse_id=wg.warehouse_id')->join('warehouse w', 'wg.warehouse_id=w.id')->where($where)->field($field)->order($order_by)->select()->toArray();
$hook_name = 'plugins_service_buy_group_goods_warehouse_handle';
MyEventTrigger($hook_name, [
'hook_name' => $hook_name,
'is_backend' => true,
'params' => $params,
'spec' => $spec,
'where' => $where,
'goods' => $v,
'data' => &$warehouse,
]);
if(!empty($warehouse))
{
foreach($warehouse as $w)
{
if($v['stock'] > 0)
{
$temp_v = $v;
if($temp_v['stock'] > $w['inventory'] && $w['inventory'] > 0)
{
$temp_v['stock'] = $w['inventory'];
}
$temp_v['total_price'] = PriceBeautify(PriceNumberFormat(floatval($temp_v['price'])*$temp_v['stock']));
$v['stock'] -= $w['inventory'];
if(!array_key_exists($w['id'], $result))
{
unset($w['is_enable'], $w['is_delete_time'], $w['contacts_name'], $w['contacts_tel'], $w['add_time'], $w['upd_time']);
$warehouse_handle = WarehouseService::WarehouseListHandle([$w]);
$result[$w['id']] = $warehouse_handle[0];
$result[$w['id']]['goods_items'] = [];
unset($result[$w['id']]['is_default'], $result[$w['id']]['level'], $result[$w['id']]['inventory']);
}
$result[$w['id']]['goods_items'] = array_merge($result[$w['id']]['goods_items'], [$temp_v]);
} else {
break;
}
}
} else {
if(empty($warehouse_default))
{
$warehouse_default = Db::name('Warehouse')->where(['is_default'=>1, 'is_enable'=>1, 'is_delete_time'=>0])->field('id,name,alias,lng,lat,province,city,county,address')->find();
if(empty($warehouse_default))
{
$warehouse_default = Db::name('Warehouse')->where(['is_enable'=>1, 'is_delete_time'=>0])->field('id,name,alias,lng,lat,province,city,county,address')->order('id asc')->find();
}
}
$temp_warehouse_default = $warehouse_default;
$hook_name = 'plugins_service_buy_group_goods_default_warehouse_handle';
MyEventTrigger($hook_name, [
'hook_name' => $hook_name,
'is_backend' => true,
'params' => $params,
'goods' => $v,
'data' => &$temp_warehouse_default,
]);
if(!empty($temp_warehouse_default))
{
if(!array_key_exists($temp_warehouse_default['id'], $result))
{
$warehouse_handle = WarehouseService::WarehouseListHandle([$temp_warehouse_default]);
$result[$temp_warehouse_default['id']] = $warehouse_handle[0];
$result[$temp_warehouse_default['id']]['goods_items'] = [];
}
$result[$temp_warehouse_default['id']]['goods_items'][] = $v;
}
}
}
return array_values($result);
}
}
?>