erp/app/Listeners/CombinationGoodsStockUpdateListener.php
2023-04-26 10:51:15 +08:00

91 lines
2.9 KiB
PHP

<?php
namespace App\Listeners;
use App\Models\CombinationGood;
use App\Models\GoodsSku;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Queue\InteractsWithQueue;
use App\Events\StockUpdateEvent;
class CombinationGoodsStockUpdateListener
{
/**
* Create the event listener.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Handle the event.
*
* @param $event
* @return void
*/
public function handle($event)
{
if ($event->combinationGoodsUpdate) {
return false;
}
$updateIds = $combinationGoodsIds = $combinationGoodsItemIds = [];
if ($event->goodsSku) {
if ($event->goodsSku->is_combination) {
$combinationGoodsIds[] = $event->goodsSku->id;
} else {
$combinationGoodsItemIds[$event->goodsSku->id] = $event->goodsSku->stock;
}
}
if ($event->goodsSkus) {
foreach ($event->goodsSkus as $sku) {
if ($sku->is_combination) {
$combinationGoodsIds[] = $sku->id;
} else {
$combinationGoodsItemIds[$sku->id] = $sku->stock;
}
}
}
// 减子商品库存
if ($combinationGoodsIds) {
$combinationGoods = CombinationGood::query()
->with('goodsSku:id,stock')
->whereIn('goods_sku_id', $combinationGoodsIds)
->get();
foreach ($combinationGoods as $item) {
$sku = GoodsSku::query()->find($item['item_id']);
$sku->stock -= $item['item_num'];
$sku->save();
$updateIds[] = $sku->id;
}
}
// 计算主商品库存
if ($combinationGoodsItemIds) {
$combinationGoodsItems = CombinationGood::query()
->whereIn('item_id', array_keys($combinationGoodsItemIds))
->get();
if ($combinationGoodsItems->isEmpty()){
return false;
}
$goodsSkuIds = array_column($combinationGoodsItems->toArray(), 'goods_sku_id');
$goodsSkus = GoodsSku::query()
->whereIn('id', $goodsSkuIds)
->pluck('stock', 'id')
->toArray();
foreach ($combinationGoodsItems as $item){
$stock = $combinationGoodsItemIds[$item['item_id']] / $item['item_num'];
if ($stock < $goodsSkus[$item['goods_sku_id']]) {
GoodsSku::query()->where('id', $item['goods_sku_id'])->update(['stock' => $stock]);
$updateIds[] = $item['goods_sku_id'];
}
}
}
if ($updateIds) {
$updateIds = array_unique($updateIds);
event(new StockUpdateEvent($updateIds, 1, true));
}
}
}