mirror of
https://github.com/grocy/grocy.git
synced 2025-04-29 09:39:57 +00:00
94 lines
3.0 KiB
PHP
94 lines
3.0 KiB
PHP
<?php
|
|
|
|
namespace Grocy\Services;
|
|
|
|
use \Grocy\Services\StockService;
|
|
|
|
class RecipesService extends BaseService
|
|
{
|
|
const RECIPE_TYPE_NORMAL = 'normal';
|
|
const RECIPE_TYPE_MEALPLAN_DAY = 'mealplan-day';
|
|
const RECIPE_TYPE_MEALPLAN_WEEK = 'mealplan-week';
|
|
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
$this->StockService = new StockService();
|
|
}
|
|
|
|
protected $StockService;
|
|
|
|
public function GetRecipesPosResolved()
|
|
{
|
|
$sql = 'SELECT * FROM recipes_pos_resolved';
|
|
return $this->DatabaseService->ExecuteDbQuery($sql)->fetchAll(\PDO::FETCH_OBJ);
|
|
}
|
|
|
|
public function GetRecipesResolved()
|
|
{
|
|
$sql = 'SELECT * FROM recipes_resolved';
|
|
return $this->DatabaseService->ExecuteDbQuery($sql)->fetchAll(\PDO::FETCH_OBJ);
|
|
}
|
|
|
|
public function AddNotFulfilledProductsToShoppingList($recipeId, $excludedProductIds = null)
|
|
{
|
|
$recipe = $this->Database->recipes($recipeId);
|
|
|
|
$recipePositions = $this->GetRecipesPosResolved();
|
|
foreach ($recipePositions as $recipePosition)
|
|
{
|
|
if($recipePosition->recipe_id == $recipeId && !in_array($recipePosition->product_id, $excludedProductIds))
|
|
{
|
|
$product = $this->Database->products($recipePosition->product_id);
|
|
|
|
$toOrderAmount = ceil(($recipePosition->missing_amount - $recipePosition->amount_on_shopping_list) / $product->qu_factor_purchase_to_stock);
|
|
if ($recipe->not_check_shoppinglist == 1)
|
|
{
|
|
$toOrderAmount = ceil($recipePosition->missing_amount / $product->qu_factor_purchase_to_stock);
|
|
}
|
|
|
|
if($toOrderAmount > 0)
|
|
{
|
|
$shoppinglistRow = $this->Database->shopping_list()->createRow(array(
|
|
'product_id' => $recipePosition->product_id,
|
|
'amount' => $toOrderAmount,
|
|
'note' => $this->LocalizationService->__t('Added for recipe %s', $recipe->name)
|
|
));
|
|
$shoppinglistRow->save();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public function ConsumeRecipe($recipeId)
|
|
{
|
|
if (!$this->RecipeExists($recipeId))
|
|
{
|
|
throw new \Exception('Recipe does not exist');
|
|
}
|
|
|
|
$transactionId = uniqid();
|
|
$recipePositions = $this->Database->recipes_pos_resolved()->where('recipe_id', $recipeId)->fetchAll();
|
|
foreach ($recipePositions as $recipePosition)
|
|
{
|
|
if ($recipePosition->only_check_single_unit_in_stock == 0)
|
|
{
|
|
$this->StockService->ConsumeProduct($recipePosition->product_id, $recipePosition->recipe_amount, false, StockService::TRANSACTION_TYPE_CONSUME, 'default', $recipeId, null, $transactionId, true);
|
|
}
|
|
}
|
|
|
|
$recipeRow = $this->Database->recipes()->where('id = :1', $recipeId)->fetch();
|
|
if (!empty($recipeRow->product_id))
|
|
{
|
|
$recipeResolvedRow = $this->Database->recipes_resolved()->where('recipe_id = :1', $recipeId)->fetch();
|
|
$this->StockService->AddProduct($recipeRow->product_id, floatval($recipeRow->desired_servings), null, StockService::TRANSACTION_TYPE_SELF_PRODUCTION, date('Y-m-d'), floatval($recipeResolvedRow->costs));
|
|
}
|
|
}
|
|
|
|
private function RecipeExists($recipeId)
|
|
{
|
|
$recipeRow = $this->Database->recipes()->where('id = :1', $recipeId)->fetch();
|
|
return $recipeRow !== null;
|
|
}
|
|
}
|