OrderItemModel.php 7.4 KB

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