mirror of
				https://github.com/grocy/grocy.git
				synced 2025-10-31 10:46:36 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.5 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');
 | |
| 		}
 | |
| 
 | |
| 		$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);
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	private function RecipeExists($recipeId)
 | |
| 	{
 | |
| 		$recipeRow = $this->Database->recipes()->where('id = :1', $recipeId)->fetch();
 | |
| 		return $recipeRow !== null;
 | |
| 	}
 | |
| }
 |