erp/app/Events/StockUpdateEvent.php

65 lines
1.7 KiB
PHP
Raw Permalink Normal View History

2022-08-16 21:02:31 +08:00
<?php
namespace App\Events;
2023-11-21 16:27:14 +08:00
use App\Models\DailyStockRecord;
use App\Models\GoodsSku;
use App\Utils\DateTimeUtils;
2022-08-16 21:02:31 +08:00
use Illuminate\Broadcasting\Channel;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Queue\SerializesModels;
class StockUpdateEvent
{
use Dispatchable, InteractsWithSockets, SerializesModels;
2023-11-21 16:27:14 +08:00
2022-08-16 21:02:31 +08:00
public $goodsSku;
2023-11-21 16:33:34 +08:00
public $combinationGoodsUpdate = true;
2022-08-16 21:02:31 +08:00
/**
* Create a new event instance.
*
2023-11-18 14:35:19 +08:00
* @param $goodsSku
2022-08-16 21:02:31 +08:00
*/
2023-11-18 14:35:19 +08:00
public function __construct($goodsSku)
2022-08-16 21:02:31 +08:00
{
2023-11-18 14:35:19 +08:00
$this->goodsSku = $goodsSku;
2023-11-21 16:27:14 +08:00
$this->checkStatusAndStock($goodsSku);
}
private function checkStatusAndStock($goodsSku)
{
$stock = $goodsSku->stock;
if (0 >= $goodsSku->stock) {
$status = GoodsSku::$STATUS_DOWN;
} else {
$status = GoodsSku::$STATUS_ON_SALE;
}
$arrivedTodayNum = DailyStockRecord::query()
->where('day', DateTimeUtils::getToday())
->where('sku_id', $goodsSku->id)
->value('arrived_today_num');
if (20 < $arrivedTodayNum + $goodsSku->yesterday_num && 4 > $goodsSku->stock) {
$status = GoodsSku::$STATUS_DOWN;
$stock = 0;
}
$goodsSku->status = $status;
$goodsSku->stock = $stock;
$goodsSku->save();
2022-08-16 21:02:31 +08:00
}
/**
* Get the channels the event should broadcast on.
*
* @return \Illuminate\Broadcasting\Channel|array
*/
public function broadcastOn()
{
return new PrivateChannel('channel-name');
}
}