|
|
@@ -13,6 +13,7 @@ use App\Order;
|
|
|
use App\OrderIssue;
|
|
|
use App\Owner;
|
|
|
use App\OwnerFeeDetail;
|
|
|
+use App\OwnerFeeDetailLogistic;
|
|
|
use App\Province;
|
|
|
use App\RejectedBill;
|
|
|
use App\Services\common\BatchUpdateService;
|
|
|
@@ -1008,7 +1009,7 @@ class OrderService
|
|
|
if (Cache::has($key))Cache::increment($key);
|
|
|
else Cache::put($key,1,2678400);
|
|
|
|
|
|
- $order->loadMissing(["logistic","shop","packages.commodities.commodity"]);
|
|
|
+ $order->loadMissing(["logistic","shop","packages.commodities.commodity","batch"]);
|
|
|
|
|
|
/** @var OwnerPriceExpressService $service */
|
|
|
$service = app("OwnerPriceExpressService");
|
|
|
@@ -1021,27 +1022,37 @@ class OrderService
|
|
|
|
|
|
if (!$order->logistic || $order->logistic->type != "快递")$logistic_fee = null;
|
|
|
|
|
|
+ $items = [];
|
|
|
foreach ($order->packages as &$package){
|
|
|
$logistic_bill .= $package->logistic_number.",";
|
|
|
$volume += $package->bulk;
|
|
|
$weight += $package->weight;
|
|
|
|
|
|
// 四维转二维
|
|
|
+ $partAmount = 0;
|
|
|
foreach($package->commodities as &$commodity){
|
|
|
$commodity["commodity_name"] = $commodity->commodity ? $commodity->commodity->name : '';
|
|
|
$commodity["sku"] = $commodity->commodity ? $commodity->commodity->sku : '';
|
|
|
- $amount += $commodity->amount;
|
|
|
+ $partAmount += $commodity->amount;
|
|
|
}
|
|
|
+ $amount += $partAmount;
|
|
|
$commodities = array_merge($commodities,$package->commodities->toArray());
|
|
|
|
|
|
+ $provinceName = mb_substr($order->province,0,2);
|
|
|
+ $province = app(CacheService::class)->getOrExecute("province_".$provinceName,function ()use($provinceName){
|
|
|
+ return Province::query()->where("name","like",$provinceName."%")->first();
|
|
|
+ },86400);
|
|
|
+ if (!$province)$logistic_fee = null;
|
|
|
+
|
|
|
+ $fee = $service->matching($package->weight, $order->owner_id, $order->logistic_id, $province->id);
|
|
|
+ $items[] = [
|
|
|
+ "amount" => $partAmount,
|
|
|
+ "logistic_bill" => $package->logistic_number,
|
|
|
+ "volume"=>$package->bulk,
|
|
|
+ "weight"=>$package->weight,
|
|
|
+ "logistic_fee" => $fee>0 ? $fee : null,
|
|
|
+ ];
|
|
|
if ($logistic_fee!==null){
|
|
|
- $provinceName = mb_substr($order->province,0,2);
|
|
|
- $province = app(CacheService::class)->getOrExecute("province_".$provinceName,function ()use($provinceName){
|
|
|
- return Province::query()->where("name","like",$provinceName."%")->first();
|
|
|
- },86400);
|
|
|
- if (!$province)$logistic_fee = null;
|
|
|
-
|
|
|
- $fee = $service->matching($package->weight, $order->owner_id, $order->logistic_id, $province->id);
|
|
|
if ($fee<0)$logistic_fee = null;
|
|
|
else $logistic_fee += $fee;
|
|
|
}
|
|
|
@@ -1052,14 +1063,17 @@ class OrderService
|
|
|
"logistic_name"=>($order->logistic ? $order->logistic->name : ''),
|
|
|
"shop_name"=>($order->shop ? $order->shop->name : ''),
|
|
|
"order_type"=>$order->order_type,
|
|
|
+ "batch_type" => $order->batch ? $order->batch->wms_type : '',
|
|
|
"owner_id"=>$order->owner_id];
|
|
|
- $mapping = ["packages"=>"commodities","商品名称"=>"commodity_name","承运商"=>"logistic_name","店铺类型"=>"shop_name","订单类型"=>"order_type","订单数"=>"amount"];
|
|
|
+ $mapping = ["packages"=>"commodities","商品名称"=>"commodity_name",
|
|
|
+ "承运商"=>"logistic_name","店铺类型"=>"shop_name","订单类型"=>"order_type",
|
|
|
+ "波次类型"=>"batch_type"];
|
|
|
|
|
|
/** @var OwnerPriceOperationService $service */
|
|
|
$service = app("OwnerPriceOperationService");
|
|
|
$result = $service->matching($object,$mapping,$order->owner_id,"出库");
|
|
|
|
|
|
- if (app("OwnerFeeDetailService")->create([
|
|
|
+ $detail = app("OwnerFeeDetailService")->create([
|
|
|
"owner_id" => $order->owner_id,
|
|
|
"worked_at" => $order->wms_edittime ?? $order->updated_at,
|
|
|
"type" => "发货",
|
|
|
@@ -1078,7 +1092,12 @@ class OrderService
|
|
|
"created_at" => date('Y-m-d H:i:s'),
|
|
|
"outer_id" => $order->id,
|
|
|
"outer_table_name" => "orders",
|
|
|
- ]))return true;
|
|
|
+ ]);
|
|
|
+ if ($detail){
|
|
|
+ foreach ($items as &$item)$item["owner_fee_detail_id"] = $detail->id;
|
|
|
+ if (count($items)>1)OwnerFeeDetailLogistic::query()->insert($items);
|
|
|
+ return true;
|
|
|
+ }
|
|
|
return false;
|
|
|
}
|
|
|
|