pedido_view_model.dart 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. import 'package:flutter/material.dart';
  2. import 'package:intl/intl.dart';
  3. import 'package:sqflite/sqflite.dart';
  4. import '../models/models.dart';
  5. import '../services/services.dart';
  6. class PedidoViewModel extends ChangeNotifier {
  7. String _busqueda = "";
  8. String get busqueda => _busqueda;
  9. List<Pedido> _pedidos = [];
  10. Pedido? _selectedPedido;
  11. bool _isLoading = false;
  12. int _currentPage = 1;
  13. int _totalPedidos = 0;
  14. int _limit = 10;
  15. int get currentPage => _currentPage;
  16. int get totalPedidos => _totalPedidos;
  17. int get totalPages => (_totalPedidos / _limit).ceil();
  18. List<Pedido> get pedidos => _pedidos;
  19. Pedido? get selectedPedido => _selectedPedido;
  20. bool get isLoading => _isLoading;
  21. void setIsLoading(bool loading) {
  22. _isLoading = loading;
  23. notifyListeners();
  24. }
  25. Future<bool> guardarPedidoLocal({required Pedido pedido}) async {
  26. RepoService<Pedido> repoPedido = RepoService<Pedido>();
  27. int nextFolio = await repoPedido.obtenerProximoFolio();
  28. pedido.folio = nextFolio;
  29. int idPedido = await repoPedido.guardarLocal(pedido);
  30. if (idPedido > 0) {
  31. pedido.id = idPedido;
  32. RepoService<PedidoProducto> repoPedidoProducto =
  33. RepoService<PedidoProducto>();
  34. RepoService<PedidoProductoTopping> repoPedidoProductoTopping =
  35. RepoService<PedidoProductoTopping>();
  36. for (var producto in pedido.productos) {
  37. PedidoProducto pedidoProducto = PedidoProducto(
  38. idPedido: idPedido,
  39. idProducto: producto.idProducto,
  40. cantidad: producto.cantidad,
  41. costoUnitario: producto.costoUnitario,
  42. comentario: producto.comentario,
  43. );
  44. int idPedidoProducto =
  45. await repoPedidoProducto.guardarLocal(pedidoProducto);
  46. for (var topping in producto.toppings) {
  47. PedidoProductoTopping pedidoProductoTopping = PedidoProductoTopping(
  48. idPedidoProducto: idPedidoProducto,
  49. idTopping: topping.idTopping,
  50. );
  51. await repoPedidoProductoTopping.guardarLocal(pedidoProductoTopping);
  52. // Recuperar detalles completos del topping
  53. Producto? toppingInfo = await RepoService<Producto>()
  54. .obtenerProductoPorId(topping.idTopping!);
  55. if (toppingInfo != null) {
  56. topping.topping = toppingInfo;
  57. }
  58. }
  59. }
  60. notifyListeners();
  61. return true;
  62. } else {
  63. return false;
  64. }
  65. }
  66. Future<void> fetchLocalPedidos({int page = 1}) async {
  67. _isLoading = true;
  68. _currentPage = page;
  69. notifyListeners();
  70. RepoService<Pedido> repoPedido = RepoService<Pedido>();
  71. _totalPedidos = await repoPedido.contarPedidos();
  72. int offset = (_limit * (page - 1));
  73. List<Pedido> paginatedPedidos =
  74. await repoPedido.obtenerPedidosPaginados(_limit, offset);
  75. _pedidos = paginatedPedidos;
  76. _isLoading = false;
  77. notifyListeners();
  78. }
  79. void nextPage() {
  80. if (_currentPage < totalPages) {
  81. fetchLocalPedidosForScreen(page: _currentPage + 1);
  82. }
  83. }
  84. void previousPage() {
  85. if (_currentPage > 1) {
  86. fetchLocalPedidosForScreen(page: _currentPage - 1);
  87. }
  88. }
  89. Future<void> fetchLocalPedidosForScreen({int page = 1}) async {
  90. setIsLoading(true);
  91. RepoService<Pedido> repoPedido = RepoService<Pedido>();
  92. _currentPage = page;
  93. var db = await RepoService().db;
  94. int? count = Sqflite.firstIntValue(
  95. await db!.rawQuery('SELECT COUNT(*) FROM Pedido'));
  96. _totalPedidos = count ?? 0;
  97. int offset = (_limit * (page - 1));
  98. List<Pedido> localPedidos =
  99. await repoPedido.obtenerPedidosPaginados(_limit, offset);
  100. _pedidos = localPedidos;
  101. setIsLoading(false);
  102. notifyListeners();
  103. }
  104. Future<List<Pedido>> fetchAllLocalPedidos() async {
  105. setIsLoading(true);
  106. RepoService<Pedido> repoPedido = RepoService<Pedido>();
  107. List<Pedido> allPedidos = await repoPedido.obtenerTodos();
  108. setIsLoading(false);
  109. return allPedidos;
  110. }
  111. Future<List<Pedido>> fetchPedidosPorFechaSinLimit(
  112. DateTime startDate, DateTime endDate) async {
  113. setIsLoading(true);
  114. RepoService<Pedido> repoPedido = RepoService<Pedido>();
  115. List<Pedido> pedidos = await repoPedido.buscarPorFecha(startDate, endDate);
  116. setIsLoading(false);
  117. return pedidos;
  118. }
  119. Future<Pedido?> fetchPedidoConProductos(int idPedido) async {
  120. RepoService<Pedido> repoPedido = RepoService<Pedido>();
  121. Pedido? pedido = await repoPedido.obtenerPorId(idPedido);
  122. if (pedido != null) {
  123. RepoService<PedidoProducto> repoProducto = RepoService<PedidoProducto>();
  124. RepoService<Producto> repoProductoInfo = RepoService<Producto>();
  125. List<PedidoProducto> productos =
  126. await repoProducto.obtenerPorIdPedido(idPedido);
  127. for (var producto in productos) {
  128. Producto? prodInfo =
  129. await repoProductoInfo.obtenerProductoPorId(producto.idProducto!);
  130. if (prodInfo != null) {
  131. producto.producto = prodInfo;
  132. }
  133. RepoService<PedidoProductoTopping> repoTopping =
  134. RepoService<PedidoProductoTopping>();
  135. List<PedidoProductoTopping> toppings =
  136. await repoTopping.obtenerToppingsPorPedidoProducto(producto.id!);
  137. for (var topping in toppings) {
  138. Producto? toppingInfo =
  139. await repoProductoInfo.obtenerProductoPorId(topping.idTopping!);
  140. if (toppingInfo != null) {
  141. topping.topping = toppingInfo;
  142. }
  143. }
  144. producto.toppings = toppings;
  145. }
  146. pedido.productos = productos;
  147. }
  148. return pedido;
  149. }
  150. Future<void> buscarPedidosPorFolio(String folio) async {
  151. setIsLoading(true);
  152. RepoService<Pedido> repoPedido = RepoService<Pedido>();
  153. List<Pedido> localPedidos = await repoPedido.buscarPorFolio(folio);
  154. _pedidos = localPedidos;
  155. setIsLoading(false);
  156. notifyListeners();
  157. }
  158. Future<void> buscarPedidosPorFecha(
  159. DateTime startDate, DateTime endDate) async {
  160. setIsLoading(true);
  161. RepoService<Pedido> repoPedido = RepoService<Pedido>();
  162. List<Pedido> localPedidos =
  163. await repoPedido.buscarPorFecha(startDate, endDate);
  164. _pedidos = localPedidos;
  165. setIsLoading(false);
  166. notifyListeners();
  167. }
  168. Future<List<Pedido>> buscarPorFecha(
  169. DateTime startDate, DateTime endDate) async {
  170. setIsLoading(true);
  171. RepoService<Pedido> repoPedido = RepoService<Pedido>();
  172. List<Pedido> pedidos = await repoPedido.buscarPorFecha(startDate, endDate);
  173. setIsLoading(false);
  174. notifyListeners();
  175. return pedidos;
  176. }
  177. Future<void> cancelarPedido(int idPedido) async {
  178. var db = await RepoService().db;
  179. await db?.update('Pedido', {'estatus': 'CANCELADO'},
  180. where: 'id = ?', whereArgs: [idPedido]);
  181. fetchLocalPedidosForScreen();
  182. }
  183. }