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; } }