feat:depotPurchase
This commit is contained in:
@@ -8,6 +8,9 @@ use App\Constants\Admin\DepotCode;
|
||||
use App\Exception\ErrException;
|
||||
use App\Model\Depot;
|
||||
use App\Model\DepotPurchase;
|
||||
use App\Model\Material;
|
||||
use App\Model\MaterialStock;
|
||||
use App\Model\Supplier;
|
||||
use App\Service\Admin\BaseService;
|
||||
use Hyperf\Di\Annotation\Inject;
|
||||
|
||||
@@ -20,7 +23,13 @@ class DepotService extends BaseService{
|
||||
protected Depot $DepotModel;
|
||||
|
||||
#[Inject]
|
||||
protected DepotPurchase $DepotPurchaseModel;
|
||||
protected Material $MaterialModel;
|
||||
|
||||
#[Inject]
|
||||
protected Supplier $SupplierModel;
|
||||
|
||||
#[Inject]
|
||||
protected MaterialStock $MaterialStockModel;
|
||||
|
||||
public function handle()
|
||||
{
|
||||
@@ -112,5 +121,72 @@ class DepotService extends BaseService{
|
||||
return $this->return->success();
|
||||
}
|
||||
|
||||
public function purchase():array
|
||||
{
|
||||
$depotId = (int)$this->request->input('depot_id');
|
||||
$depotInfo = $this->DepotModel->getInfoById($depotId);
|
||||
if (empty($depotInfo)) throw new ErrException('仓库不存在');
|
||||
|
||||
$materialId = (int)$this->request->input('material_id');
|
||||
$materialInfo = $this->MaterialModel->getInfoById($materialId);
|
||||
if (empty($materialInfo)) throw new ErrException("材料不存在");
|
||||
|
||||
$supplierId = (int)$this->request->input('supplier_id');
|
||||
$supplierInfo = $this->SupplierModel->getInfoById($supplierId);
|
||||
if (empty($supplierInfo)) throw new ErrException('供应商不存在');
|
||||
|
||||
$type = (int)$this->request->input('type');
|
||||
$purchase_price = (double)$this->request->input('purchase_price');
|
||||
$number = (double)$this->request->input('number');
|
||||
|
||||
if (!empty($purchase_price) && !empty($number)){
|
||||
$sum_price = $purchase_price * $number;
|
||||
}
|
||||
|
||||
$cityId = (int)$this->request->input('city_id');
|
||||
$kitchenId = (int)$this->request->input('kitchen_id');
|
||||
|
||||
$depotPurchase = new DepotPurchase();
|
||||
$depotPurchase->depot_id = $depotId;
|
||||
$depotPurchase->material_id = $materialId;
|
||||
$depotPurchase->supplier_id = $supplierId;
|
||||
$depotPurchase->type = $type;
|
||||
$depotPurchase->purchase_price = $purchase_price;
|
||||
$depotPurchase->number = $number;
|
||||
$depotPurchase->sum_price = $sum_price;
|
||||
$depotPurchase->city_id = $cityId;
|
||||
$depotPurchase->kitchen_id = $kitchenId;
|
||||
$depotPurchase->operator_id = $this->adminId;
|
||||
|
||||
|
||||
$materialStock = $this->MaterialStockModel
|
||||
->where('depot_id',$depotId)
|
||||
->where('material_id',$materialId)
|
||||
->where('supplier_id',$supplierId)
|
||||
->first();
|
||||
if (empty($materialStock)){
|
||||
$materialStock = new MaterialStock();
|
||||
$materialStock->depot_id = $depotId;
|
||||
$materialStock->material_id = $materialId;
|
||||
$materialStock->supplier_id = $supplierId;
|
||||
$materialStock->current_stock = $number;
|
||||
$materialStock->unit_price = $purchase_price;
|
||||
}
|
||||
else{
|
||||
//采购入库
|
||||
if ($depotPurchase->type == 1){
|
||||
$materialStock->current_stock = $materialStock->current_stock + $number;
|
||||
}
|
||||
//采购退货
|
||||
else
|
||||
$materialStock->current_stock = $materialStock->current_stock - $number;
|
||||
|
||||
}
|
||||
|
||||
if (!$depotPurchase->save() || !$materialStock->save()) throw new ErrException('采购添加失败');
|
||||
|
||||
return $this->return->success();
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user