OrderItemModel.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <?php
  2. namespace Models;
  3. use Models\OrderModel;
  4. use Models\ProductModel;
  5. class OrderItemModel
  6. {
  7. private \PDO $pdo;
  8. public function __construct()
  9. {
  10. $dbFile = $_ENV['DB_FILE'];
  11. $dbPath = __DIR__ . '/../' . $dbFile;
  12. $this->pdo = new \PDO("sqlite:" . $dbPath);
  13. $this->pdo->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
  14. $this->pdo->exec('PRAGMA journal_mode = WAL;');
  15. $this->pdo->exec('PRAGMA busy_timeout = 5000;');
  16. }
  17. public function createOrderItem(int $orderId, int $productId, int $companyId, string $kitchenNote = ''): int|false
  18. {
  19. $orderModel = new OrderModel();
  20. $productModel = new ProductModel();
  21. $order = $orderModel->getOrderById($orderId, $companyId);
  22. if (!$order) {
  23. return false;
  24. }
  25. $product = $productModel->getProductById($productId, $companyId);
  26. if (!$product) {
  27. return false;
  28. }
  29. $stmt = $this->pdo->prepare("
  30. INSERT INTO order_item (order_id, product_id, company_id, order_item_kitchen_note)
  31. VALUES (:order_id, :product_id, :company_id, :order_item_kitchen_note)
  32. ");
  33. try {
  34. $executed = $stmt->execute([
  35. 'order_id' => $orderId,
  36. 'product_id' => $productId,
  37. 'company_id' => $companyId,
  38. 'order_item_kitchen_note' => $kitchenNote
  39. ]);
  40. return $executed ? (int)$this->pdo->lastInsertId() : false;
  41. } catch (\PDOException $e) {
  42. error_log("PDO Exception during order item creation: " . $e->getMessage());
  43. return false;
  44. }
  45. }
  46. public function deleteOrderItem(int $orderItemId, int $companyId): bool
  47. {
  48. $stmt = $this->pdo->prepare("
  49. DELETE FROM order_item
  50. WHERE order_item_id = :order_item_id
  51. AND order_id IN (
  52. SELECT order_id FROM `order` WHERE company_id = :company_id AND order_flag = 'a'
  53. )
  54. ");
  55. $executed = $stmt->execute(['order_item_id' => $orderItemId, 'company_id' => $companyId]);
  56. return $executed && $stmt->rowCount() > 0;
  57. }
  58. public function getOrderItemsByOrderId(?int $orderId, int $companyId, int $page = 1, int $limit = 10): array
  59. {
  60. if ($orderId !== null) {
  61. $orderModel = new OrderModel();
  62. $order = $orderModel->getOrderById($orderId, $companyId);
  63. if (!$order) {
  64. return [];
  65. }
  66. $stmt = $this->pdo->prepare("
  67. SELECT order_item_id, order_id, product_id, company_id
  68. FROM order_item
  69. WHERE order_id = :order_id AND company_id = :company_id
  70. ");
  71. $stmt->execute([
  72. 'order_id' => $orderId,
  73. 'company_id' => $companyId,
  74. ]);
  75. } else {
  76. $offset = ($page - 1) * $limit;
  77. $stmt = $this->pdo->prepare("
  78. SELECT order_item_id, order_id, product_id, company_id
  79. FROM order_item
  80. WHERE company_id = :company_id
  81. LIMIT :limit OFFSET :offset
  82. ");
  83. $stmt->bindValue(':company_id', $companyId, \PDO::PARAM_INT);
  84. $stmt->bindValue(':limit', $limit, \PDO::PARAM_INT);
  85. $stmt->bindValue(':offset', $offset, \PDO::PARAM_INT);
  86. $stmt->execute();
  87. }
  88. return $stmt->fetchAll(\PDO::FETCH_ASSOC);
  89. }
  90. }