CategoryModel.php 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. <?php
  2. namespace Models;
  3. class CategoryModel
  4. {
  5. private \PDO $pdo;
  6. public function __construct()
  7. {
  8. $dbFile = $_ENV['DB_FILE'];
  9. $dbPath = __DIR__ . '/../' . $dbFile;
  10. $this->pdo = new \PDO("sqlite:" . $dbPath);
  11. $this->pdo->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
  12. }
  13. public function getCategories(int $companyId): array
  14. {
  15. $stmt = $this->pdo->prepare("SELECT * FROM category WHERE company_id = :company_id AND category_flag = 'a'");
  16. $stmt->execute(['company_id' => $companyId]);
  17. return $stmt->fetchAll(\PDO::FETCH_ASSOC);
  18. }
  19. public function createCategory(string $name, int $companyId, bool $isKitchen): bool
  20. {
  21. $stmt = $this->pdo->prepare("INSERT INTO category (category_name, category_is_kitchen, category_flag, company_id)
  22. VALUES (:name, :is_kitchen, 'a', :company_id)");
  23. return $stmt->execute(['name' => $name, 'is_kitchen' => $isKitchen ? 1 : 0, 'company_id' => $companyId]);
  24. }
  25. public function deleteByName(string $name, int $companyId): bool
  26. {
  27. $stmt = $this->pdo->prepare("UPDATE category SET category_flag = 'd'
  28. WHERE category_name = :name AND company_id = :company_id AND category_flag = 'a'");
  29. return $stmt->execute(['name' => $name, 'company_id' => $companyId]);
  30. }
  31. public function addProductToCategory(string $productName, float $price, string $categoryName, int $companyId): bool
  32. {
  33. $stmt = $this->pdo->prepare("SELECT category_id FROM category WHERE category_name = :name AND company_id = :company_id AND category_flag = 'a'");
  34. $stmt->execute(['name' => $categoryName, 'company_id' => $companyId]);
  35. $category = $stmt->fetch(\PDO::FETCH_ASSOC);
  36. if (!$category) {
  37. return false;
  38. }
  39. $stmt = $this->pdo->prepare("INSERT INTO product (product_name, product_price, category_id, company_id, product_flag)
  40. VALUES (:name, :price, :category_id, :company_id, 'a')");
  41. return $stmt->execute(['name' => $productName, 'price' => $price, 'category_id' => $category['category_id'], 'company_id' => $companyId]);
  42. }
  43. }