| 
									
										
										
										
											2018-07-14 18:23:41 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Grocy\Services; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-11 11:48:25 +02:00
										 |  |  | use \Grocy\Services\StockService; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-14 18:23:41 +02:00
										 |  |  | class RecipesService extends BaseService | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-08-11 11:48:25 +02:00
										 |  |  | 	public function __construct() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		parent::__construct(); | 
					
						
							|  |  |  | 		$this->StockService = new StockService(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected $StockService; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-14 18:23:41 +02:00
										 |  |  | 	public function GetRecipesFulfillment() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		$sql = 'SELECT * from recipes_fulfillment'; | 
					
						
							|  |  |  | 		return $this->DatabaseService->ExecuteDbQuery($sql)->fetchAll(\PDO::FETCH_OBJ); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	public function GetRecipesSumFulfillment() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		$sql = 'SELECT * from recipes_fulfillment_sum'; | 
					
						
							|  |  |  | 		return $this->DatabaseService->ExecuteDbQuery($sql)->fetchAll(\PDO::FETCH_OBJ); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-07-14 22:49:42 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	public function AddNotFulfilledProductsToShoppingList($recipeId) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		$recipe = $this->Database->recipes($recipeId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		$recipePositions = $this->GetRecipesFulfillment(); | 
					
						
							|  |  |  | 		foreach ($recipePositions as $recipePosition) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if($recipePosition->recipe_id == $recipeId) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				$toOrderAmount = $recipePosition->missing_amount - $recipePosition->amount_on_shopping_list; | 
					
						
							|  |  |  | 				if($toOrderAmount > 0) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					$shoppinglistRow = $this->Database->shopping_list()->createRow(array( | 
					
						
							|  |  |  | 						'product_id' => $recipePosition->product_id, | 
					
						
							|  |  |  | 						'amount' => $toOrderAmount, | 
					
						
							|  |  |  | 						'note' => $this->LocalizationService->Localize('Added for recipe #1', $recipe->name) | 
					
						
							|  |  |  | 					)); | 
					
						
							|  |  |  | 					$shoppinglistRow->save(); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-08-11 11:48:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	public function ConsumeRecipe($recipeId) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (!$this->RecipeExists($recipeId)) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			throw new \Exception('Recipe does not exist'); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		$recipePositions = $this->Database->recipes_pos()->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->amount, false, StockService::TRANSACTION_TYPE_CONSUME); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	private function RecipeExists($recipeId) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		$recipeRow = $this->Database->recipes()->where('id = :1', $recipeId)->fetch(); | 
					
						
							|  |  |  | 		return $recipeRow !== null; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-07-14 18:23:41 +02:00
										 |  |  | } |