OrderItemModel.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  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(
  18. int $orderId,
  19. int $productId,
  20. int $companyId,
  21. string $kitchenNote = ''
  22. ): int|false
  23. {
  24. $orderModel = new OrderModel();
  25. $productModel = new ProductModel();
  26. $order = $orderModel->getOrderById($orderId, $companyId, false);
  27. if (!$order) {
  28. return false;
  29. }
  30. $product = $productModel->getProductById($productId, $companyId);
  31. if (!$product) {
  32. return false;
  33. }
  34. $stmt = $this->pdo->prepare("
  35. INSERT INTO order_item (
  36. order_id,
  37. product_id,
  38. company_id,
  39. order_item_flag,
  40. order_item_kitchen_note
  41. ) VALUES (
  42. :order_id,
  43. :product_id,
  44. :company_id,
  45. 'a',
  46. :order_item_kitchen_note
  47. )
  48. ");
  49. try {
  50. $executed = $stmt->execute([
  51. 'order_id' => $orderId,
  52. 'product_id' => $productId,
  53. 'company_id' => $companyId,
  54. 'order_item_kitchen_note' => $kitchenNote
  55. ]);
  56. if ($executed) {
  57. if (!empty($product['product_is_kitchen']) && $product['product_is_kitchen'] == 1) {
  58. $this->pdo->prepare("
  59. UPDATE `order`
  60. SET order_flag = 'a'
  61. WHERE order_id = :order_id
  62. AND company_id = :company_id
  63. ")->execute([
  64. 'order_id' => $orderId,
  65. 'company_id' => $companyId
  66. ]);
  67. }
  68. return (int)$this->pdo->lastInsertId();
  69. }
  70. return false;
  71. } catch (\PDOException $e) {
  72. error_log("PDO Exception during order item creation: " . $e->getMessage());
  73. return false;
  74. }
  75. }
  76. public function deleteOrderItem(int $orderItemId, int $companyId): bool
  77. {
  78. $stmt = $this->pdo->prepare("
  79. DELETE FROM order_item
  80. WHERE order_item_id = :order_item_id
  81. AND order_id IN (
  82. SELECT order_id FROM `order` WHERE company_id = :company_id AND order_flag = 'a'
  83. )
  84. ");
  85. $executed = $stmt->execute(['order_item_id' => $orderItemId, 'company_id' => $companyId]);
  86. return $executed && $stmt->rowCount() > 0;
  87. }
  88. public function getOrderItemsByOrderId(?int $orderId, int $companyId, int $page = 1, int $limit = 10): array
  89. {
  90. if ($orderId !== null) {
  91. $orderModel = new OrderModel();
  92. $order = $orderModel->getOrderById($orderId, $companyId);
  93. if (!$order) {
  94. return [];
  95. }
  96. $stmt = $this->pdo->prepare("
  97. SELECT order_item_id, order_id, product_id, company_id
  98. FROM order_item
  99. WHERE order_id = :order_id AND company_id = :company_id
  100. ");
  101. $stmt->execute([
  102. 'order_id' => $orderId,
  103. 'company_id' => $companyId,
  104. ]);
  105. } else {
  106. $offset = ($page - 1) * $limit;
  107. $stmt = $this->pdo->prepare("
  108. SELECT order_item_id, order_id, product_id, company_id
  109. FROM order_item
  110. WHERE company_id = :company_id
  111. LIMIT :limit OFFSET :offset
  112. ");
  113. $stmt->bindValue(':company_id', $companyId, \PDO::PARAM_INT);
  114. $stmt->bindValue(':limit', $limit, \PDO::PARAM_INT);
  115. $stmt->bindValue(':offset', $offset, \PDO::PARAM_INT);
  116. $stmt->execute();
  117. }
  118. return $stmt->fetchAll(\PDO::FETCH_ASSOC);
  119. }
  120. public function updateOrderItem(int $orderItemId, int $companyId): bool
  121. {
  122. $stmt = $this->pdo->prepare("
  123. SELECT order_item_flag, order_id, product_id
  124. FROM order_item
  125. WHERE order_item_id = :order_item_id
  126. AND company_id = :company_id
  127. ");
  128. $stmt->execute([
  129. 'order_item_id' => $orderItemId,
  130. 'company_id' => $companyId
  131. ]);
  132. $item = $stmt->fetch(\PDO::FETCH_ASSOC);
  133. if (!$item) {
  134. return false;
  135. }
  136. $newFlag = $item['order_item_flag'] === 'a' ? 'p' : 'a';
  137. $update = $this->pdo->prepare("
  138. UPDATE order_item
  139. SET order_item_flag = :new_flag
  140. WHERE order_item_id = :order_item_id
  141. AND company_id = :company_id
  142. ");
  143. $executed = $update->execute([
  144. 'new_flag' => $newFlag,
  145. 'order_item_id' => $orderItemId,
  146. 'company_id' => $companyId
  147. ]);
  148. if ($executed && $update->rowCount() > 0) {
  149. $stmtCheck = $this->pdo->prepare("
  150. SELECT COUNT(*)
  151. FROM order_item
  152. NATURAL JOIN product
  153. WHERE order_id = :order_id
  154. AND company_id = :company_id
  155. AND product_is_kitchen = 1
  156. AND order_item_flag != 'p'
  157. ");
  158. $stmtCheck->execute([
  159. 'order_id' => $item['order_id'],
  160. 'company_id' => $companyId
  161. ]);
  162. $pendingKitchen = (int)$stmtCheck->fetchColumn();
  163. if ($pendingKitchen === 0) {
  164. $this->pdo->prepare("
  165. UPDATE `order`
  166. SET order_flag = 'p'
  167. WHERE order_id = :order_id
  168. AND company_id = :company_id
  169. ")->execute([
  170. 'order_id' => $item['order_id'],
  171. 'company_id' => $companyId
  172. ]);
  173. } else {
  174. $stmtOrderFlag = $this->pdo->prepare("
  175. SELECT order_flag FROM `order`
  176. WHERE order_id = :order_id AND company_id = :company_id
  177. ");
  178. $stmtOrderFlag->execute([
  179. 'order_id' => $item['order_id'],
  180. 'company_id' => $companyId
  181. ]);
  182. $currentOrderFlag = $stmtOrderFlag->fetchColumn();
  183. if ($currentOrderFlag === 'p' && $newFlag === 'a') {
  184. $this->pdo->prepare("
  185. UPDATE `order`
  186. SET order_flag = 'a'
  187. WHERE order_id = :order_id AND company_id = :company_id
  188. ")->execute([
  189. 'order_id' => $item['order_id'],
  190. 'company_id' => $companyId
  191. ]);
  192. }
  193. }
  194. return true;
  195. }
  196. return false;
  197. }
  198. }