list orders
This commit is contained in:
@@ -6,6 +6,7 @@ library;
|
||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
||||
import 'package:worker/core/network/dio_client.dart';
|
||||
import 'package:worker/features/orders/data/datasources/order_remote_datasource.dart';
|
||||
import 'package:worker/features/orders/data/datasources/order_status_local_datasource.dart';
|
||||
import 'package:worker/features/orders/data/repositories/order_repository_impl.dart';
|
||||
import 'package:worker/features/orders/domain/repositories/order_repository.dart';
|
||||
|
||||
@@ -22,5 +23,6 @@ Future<OrderRemoteDataSource> orderRemoteDataSource(Ref ref) async {
|
||||
@riverpod
|
||||
Future<OrderRepository> orderRepository(Ref ref) async {
|
||||
final remoteDataSource = await ref.watch(orderRemoteDataSourceProvider.future);
|
||||
return OrderRepositoryImpl(remoteDataSource);
|
||||
final statusLocalDataSource = OrderStatusLocalDataSource();
|
||||
return OrderRepositoryImpl(remoteDataSource, statusLocalDataSource);
|
||||
}
|
||||
|
||||
@@ -6,6 +6,7 @@ library;
|
||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
||||
import 'package:worker/core/network/dio_client.dart';
|
||||
import 'package:worker/features/orders/data/datasources/order_remote_datasource.dart';
|
||||
import 'package:worker/features/orders/data/datasources/order_status_local_datasource.dart';
|
||||
import 'package:worker/features/orders/data/repositories/order_repository_impl.dart';
|
||||
import 'package:worker/features/orders/domain/repositories/order_repository.dart';
|
||||
|
||||
@@ -16,7 +17,8 @@ part 'order_repository_provider.g.dart';
|
||||
Future<OrderRepository> orderRepository(Ref ref) async {
|
||||
final dioClient = await ref.watch(dioClientProvider.future);
|
||||
final remoteDataSource = OrderRemoteDataSource(dioClient);
|
||||
return OrderRepositoryImpl(remoteDataSource);
|
||||
final statusLocalDataSource = OrderStatusLocalDataSource();
|
||||
return OrderRepositoryImpl(remoteDataSource, statusLocalDataSource);
|
||||
}
|
||||
|
||||
/// Create Order Provider
|
||||
|
||||
@@ -50,7 +50,7 @@ final class OrderRepositoryProvider
|
||||
}
|
||||
}
|
||||
|
||||
String _$orderRepositoryHash() => r'15efafcf3b545ea52fdc8d0acbd8192ba8f41546';
|
||||
String _$orderRepositoryHash() => r'f9808aac43686973737a55410e4121ae8332b908';
|
||||
|
||||
/// Create Order Provider
|
||||
///
|
||||
|
||||
@@ -4,33 +4,41 @@
|
||||
library;
|
||||
|
||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
||||
import 'package:worker/core/database/models/enums.dart';
|
||||
import 'package:worker/features/orders/data/datasources/orders_local_datasource.dart';
|
||||
import 'package:worker/features/orders/data/models/order_model.dart';
|
||||
import 'package:worker/features/orders/domain/entities/order.dart';
|
||||
import 'package:worker/features/orders/domain/entities/order_status.dart';
|
||||
import 'package:worker/features/orders/presentation/providers/order_repository_provider.dart';
|
||||
|
||||
part 'orders_provider.g.dart';
|
||||
|
||||
/// Orders Local Data Source Provider
|
||||
@riverpod
|
||||
OrdersLocalDataSource ordersLocalDataSource(Ref ref) {
|
||||
return OrdersLocalDataSource();
|
||||
}
|
||||
|
||||
/// Orders Provider
|
||||
///
|
||||
/// Provides list of all orders from local data source.
|
||||
/// Provides list of all orders from repository (Clean Architecture).
|
||||
@riverpod
|
||||
class Orders extends _$Orders {
|
||||
@override
|
||||
Future<List<OrderModel>> build() async {
|
||||
return await ref.read(ordersLocalDataSourceProvider).getAllOrders();
|
||||
Future<List<Order>> build() async {
|
||||
// Fetch orders from repository
|
||||
try {
|
||||
final repository = await ref.read(orderRepositoryProvider.future);
|
||||
return await repository.getOrdersList(
|
||||
limitStart: 0,
|
||||
limitPageLength: 0, // 0 = get all
|
||||
);
|
||||
} catch (e) {
|
||||
// Return empty list on error
|
||||
return [];
|
||||
}
|
||||
}
|
||||
|
||||
/// Refresh orders
|
||||
Future<void> refresh() async {
|
||||
state = const AsyncValue.loading();
|
||||
state = await AsyncValue.guard(() async {
|
||||
return await ref.read(ordersLocalDataSourceProvider).getAllOrders();
|
||||
final repository = await ref.read(orderRepositoryProvider.future);
|
||||
return await repository.getOrdersList(
|
||||
limitStart: 0,
|
||||
limitPageLength: 0,
|
||||
);
|
||||
});
|
||||
}
|
||||
}
|
||||
@@ -42,12 +50,12 @@ class Orders extends _$Orders {
|
||||
@riverpod
|
||||
class SelectedOrderStatus extends _$SelectedOrderStatus {
|
||||
@override
|
||||
OrderStatus? build() {
|
||||
String? build() {
|
||||
return null; // Default: show all orders
|
||||
}
|
||||
|
||||
/// Select a status filter
|
||||
void selectStatus(OrderStatus? status) {
|
||||
void selectStatus(String? status) {
|
||||
state = status;
|
||||
}
|
||||
|
||||
@@ -82,7 +90,7 @@ class OrderSearchQuery extends _$OrderSearchQuery {
|
||||
///
|
||||
/// Filters orders by selected status and search query.
|
||||
@riverpod
|
||||
Future<List<OrderModel>> filteredOrders(Ref ref) async {
|
||||
Future<List<Order>> filteredOrders(Ref ref) async {
|
||||
final ordersAsync = ref.watch(ordersProvider);
|
||||
final selectedStatus = ref.watch(selectedOrderStatusProvider);
|
||||
final searchQuery = ref.watch(orderSearchQueryProvider);
|
||||
@@ -102,15 +110,23 @@ Future<List<OrderModel>> filteredOrders(Ref ref) async {
|
||||
if (searchQuery.isNotEmpty) {
|
||||
filtered = filtered
|
||||
.where(
|
||||
(order) => order.orderNumber.toLowerCase().contains(
|
||||
(order) => order.name.toLowerCase().contains(
|
||||
searchQuery.toLowerCase(),
|
||||
),
|
||||
)
|
||||
.toList();
|
||||
}
|
||||
|
||||
// Sort by creation date (newest first)
|
||||
filtered.sort((a, b) => b.createdAt.compareTo(a.createdAt));
|
||||
// Sort by transaction date (newest first)
|
||||
filtered.sort((a, b) {
|
||||
try {
|
||||
final aDate = DateTime.parse(a.transactionDate);
|
||||
final bDate = DateTime.parse(b.transactionDate);
|
||||
return bDate.compareTo(aDate);
|
||||
} catch (e) {
|
||||
return 0; // Keep original order if parsing fails
|
||||
}
|
||||
});
|
||||
|
||||
return filtered;
|
||||
},
|
||||
@@ -123,15 +139,16 @@ Future<List<OrderModel>> filteredOrders(Ref ref) async {
|
||||
///
|
||||
/// Returns count of orders for each status.
|
||||
@riverpod
|
||||
Future<Map<OrderStatus, int>> ordersCountByStatus(Ref ref) async {
|
||||
Future<Map<String, int>> ordersCountByStatus(Ref ref) async {
|
||||
final ordersAsync = ref.watch(ordersProvider);
|
||||
|
||||
return ordersAsync.when(
|
||||
data: (orders) {
|
||||
final counts = <OrderStatus, int>{};
|
||||
final counts = <String, int>{};
|
||||
|
||||
for (final status in OrderStatus.values) {
|
||||
counts[status] = orders.where((order) => order.status == status).length;
|
||||
// Count orders by their status string
|
||||
for (final order in orders) {
|
||||
counts[order.status] = (counts[order.status] ?? 0) + 1;
|
||||
}
|
||||
|
||||
return counts;
|
||||
@@ -152,3 +169,13 @@ Future<int> totalOrdersCount(Ref ref) async {
|
||||
error: (error, stack) => 0,
|
||||
);
|
||||
}
|
||||
|
||||
/// Order Status List Provider
|
||||
///
|
||||
/// Provides cached order status list with automatic refresh.
|
||||
/// Uses cache-first strategy with API fallback.
|
||||
@riverpod
|
||||
Future<List<OrderStatus>> orderStatusList(Ref ref) async {
|
||||
final repository = await ref.watch(orderRepositoryProvider.future);
|
||||
return await repository.getOrderStatusList();
|
||||
}
|
||||
|
||||
@@ -8,74 +8,20 @@ part of 'orders_provider.dart';
|
||||
|
||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
||||
// ignore_for_file: type=lint, type=warning
|
||||
/// Orders Local Data Source Provider
|
||||
|
||||
@ProviderFor(ordersLocalDataSource)
|
||||
const ordersLocalDataSourceProvider = OrdersLocalDataSourceProvider._();
|
||||
|
||||
/// Orders Local Data Source Provider
|
||||
|
||||
final class OrdersLocalDataSourceProvider
|
||||
extends
|
||||
$FunctionalProvider<
|
||||
OrdersLocalDataSource,
|
||||
OrdersLocalDataSource,
|
||||
OrdersLocalDataSource
|
||||
>
|
||||
with $Provider<OrdersLocalDataSource> {
|
||||
/// Orders Local Data Source Provider
|
||||
const OrdersLocalDataSourceProvider._()
|
||||
: super(
|
||||
from: null,
|
||||
argument: null,
|
||||
retry: null,
|
||||
name: r'ordersLocalDataSourceProvider',
|
||||
isAutoDispose: true,
|
||||
dependencies: null,
|
||||
$allTransitiveDependencies: null,
|
||||
);
|
||||
|
||||
@override
|
||||
String debugGetCreateSourceHash() => _$ordersLocalDataSourceHash();
|
||||
|
||||
@$internal
|
||||
@override
|
||||
$ProviderElement<OrdersLocalDataSource> $createElement(
|
||||
$ProviderPointer pointer,
|
||||
) => $ProviderElement(pointer);
|
||||
|
||||
@override
|
||||
OrdersLocalDataSource create(Ref ref) {
|
||||
return ordersLocalDataSource(ref);
|
||||
}
|
||||
|
||||
/// {@macro riverpod.override_with_value}
|
||||
Override overrideWithValue(OrdersLocalDataSource value) {
|
||||
return $ProviderOverride(
|
||||
origin: this,
|
||||
providerOverride: $SyncValueProvider<OrdersLocalDataSource>(value),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
String _$ordersLocalDataSourceHash() =>
|
||||
r'753fcc2a4000c4c9843fba022d1bf398daba6c7a';
|
||||
|
||||
/// Orders Provider
|
||||
///
|
||||
/// Provides list of all orders from local data source.
|
||||
/// Provides list of all orders from repository (Clean Architecture).
|
||||
|
||||
@ProviderFor(Orders)
|
||||
const ordersProvider = OrdersProvider._();
|
||||
|
||||
/// Orders Provider
|
||||
///
|
||||
/// Provides list of all orders from local data source.
|
||||
final class OrdersProvider
|
||||
extends $AsyncNotifierProvider<Orders, List<OrderModel>> {
|
||||
/// Provides list of all orders from repository (Clean Architecture).
|
||||
final class OrdersProvider extends $AsyncNotifierProvider<Orders, List<Order>> {
|
||||
/// Orders Provider
|
||||
///
|
||||
/// Provides list of all orders from local data source.
|
||||
/// Provides list of all orders from repository (Clean Architecture).
|
||||
const OrdersProvider._()
|
||||
: super(
|
||||
from: null,
|
||||
@@ -95,25 +41,24 @@ final class OrdersProvider
|
||||
Orders create() => Orders();
|
||||
}
|
||||
|
||||
String _$ordersHash() => r'7d2ae33e528260172495e8360f6879cb6e089766';
|
||||
String _$ordersHash() => r'1a4712005f0d2fdd2d15e01b6dd9ea2adc428343';
|
||||
|
||||
/// Orders Provider
|
||||
///
|
||||
/// Provides list of all orders from local data source.
|
||||
/// Provides list of all orders from repository (Clean Architecture).
|
||||
|
||||
abstract class _$Orders extends $AsyncNotifier<List<OrderModel>> {
|
||||
FutureOr<List<OrderModel>> build();
|
||||
abstract class _$Orders extends $AsyncNotifier<List<Order>> {
|
||||
FutureOr<List<Order>> build();
|
||||
@$mustCallSuper
|
||||
@override
|
||||
void runBuild() {
|
||||
final created = build();
|
||||
final ref =
|
||||
this.ref as $Ref<AsyncValue<List<OrderModel>>, List<OrderModel>>;
|
||||
final ref = this.ref as $Ref<AsyncValue<List<Order>>, List<Order>>;
|
||||
final element =
|
||||
ref.element
|
||||
as $ClassProviderElement<
|
||||
AnyNotifier<AsyncValue<List<OrderModel>>, List<OrderModel>>,
|
||||
AsyncValue<List<OrderModel>>,
|
||||
AnyNotifier<AsyncValue<List<Order>>, List<Order>>,
|
||||
AsyncValue<List<Order>>,
|
||||
Object?,
|
||||
Object?
|
||||
>;
|
||||
@@ -134,7 +79,7 @@ const selectedOrderStatusProvider = SelectedOrderStatusProvider._();
|
||||
/// Tracks the currently selected order status filter.
|
||||
/// null means "All" orders.
|
||||
final class SelectedOrderStatusProvider
|
||||
extends $NotifierProvider<SelectedOrderStatus, OrderStatus?> {
|
||||
extends $NotifierProvider<SelectedOrderStatus, String?> {
|
||||
/// Selected Order Status Provider
|
||||
///
|
||||
/// Tracks the currently selected order status filter.
|
||||
@@ -158,34 +103,34 @@ final class SelectedOrderStatusProvider
|
||||
SelectedOrderStatus create() => SelectedOrderStatus();
|
||||
|
||||
/// {@macro riverpod.override_with_value}
|
||||
Override overrideWithValue(OrderStatus? value) {
|
||||
Override overrideWithValue(String? value) {
|
||||
return $ProviderOverride(
|
||||
origin: this,
|
||||
providerOverride: $SyncValueProvider<OrderStatus?>(value),
|
||||
providerOverride: $SyncValueProvider<String?>(value),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
String _$selectedOrderStatusHash() =>
|
||||
r'51834a8660a7f792e4075f76354e8a23a4fe9d7c';
|
||||
r'24d7f26c87da85b04a6f7ad0691663ef50f9523f';
|
||||
|
||||
/// Selected Order Status Provider
|
||||
///
|
||||
/// Tracks the currently selected order status filter.
|
||||
/// null means "All" orders.
|
||||
|
||||
abstract class _$SelectedOrderStatus extends $Notifier<OrderStatus?> {
|
||||
OrderStatus? build();
|
||||
abstract class _$SelectedOrderStatus extends $Notifier<String?> {
|
||||
String? build();
|
||||
@$mustCallSuper
|
||||
@override
|
||||
void runBuild() {
|
||||
final created = build();
|
||||
final ref = this.ref as $Ref<OrderStatus?, OrderStatus?>;
|
||||
final ref = this.ref as $Ref<String?, String?>;
|
||||
final element =
|
||||
ref.element
|
||||
as $ClassProviderElement<
|
||||
AnyNotifier<OrderStatus?, OrderStatus?>,
|
||||
OrderStatus?,
|
||||
AnyNotifier<String?, String?>,
|
||||
String?,
|
||||
Object?,
|
||||
Object?
|
||||
>;
|
||||
@@ -274,11 +219,11 @@ const filteredOrdersProvider = FilteredOrdersProvider._();
|
||||
final class FilteredOrdersProvider
|
||||
extends
|
||||
$FunctionalProvider<
|
||||
AsyncValue<List<OrderModel>>,
|
||||
List<OrderModel>,
|
||||
FutureOr<List<OrderModel>>
|
||||
AsyncValue<List<Order>>,
|
||||
List<Order>,
|
||||
FutureOr<List<Order>>
|
||||
>
|
||||
with $FutureModifier<List<OrderModel>>, $FutureProvider<List<OrderModel>> {
|
||||
with $FutureModifier<List<Order>>, $FutureProvider<List<Order>> {
|
||||
/// Filtered Orders Provider
|
||||
///
|
||||
/// Filters orders by selected status and search query.
|
||||
@@ -298,17 +243,17 @@ final class FilteredOrdersProvider
|
||||
|
||||
@$internal
|
||||
@override
|
||||
$FutureProviderElement<List<OrderModel>> $createElement(
|
||||
$FutureProviderElement<List<Order>> $createElement(
|
||||
$ProviderPointer pointer,
|
||||
) => $FutureProviderElement(pointer);
|
||||
|
||||
@override
|
||||
FutureOr<List<OrderModel>> create(Ref ref) {
|
||||
FutureOr<List<Order>> create(Ref ref) {
|
||||
return filteredOrders(ref);
|
||||
}
|
||||
}
|
||||
|
||||
String _$filteredOrdersHash() => r'4cc009352d3b09159c0fe107645634c3a4a81a7c';
|
||||
String _$filteredOrdersHash() => r'04c5c87d7138b66987c8b45f878d445026ec8e19';
|
||||
|
||||
/// Orders Count by Status Provider
|
||||
///
|
||||
@@ -324,13 +269,11 @@ const ordersCountByStatusProvider = OrdersCountByStatusProvider._();
|
||||
final class OrdersCountByStatusProvider
|
||||
extends
|
||||
$FunctionalProvider<
|
||||
AsyncValue<Map<OrderStatus, int>>,
|
||||
Map<OrderStatus, int>,
|
||||
FutureOr<Map<OrderStatus, int>>
|
||||
AsyncValue<Map<String, int>>,
|
||||
Map<String, int>,
|
||||
FutureOr<Map<String, int>>
|
||||
>
|
||||
with
|
||||
$FutureModifier<Map<OrderStatus, int>>,
|
||||
$FutureProvider<Map<OrderStatus, int>> {
|
||||
with $FutureModifier<Map<String, int>>, $FutureProvider<Map<String, int>> {
|
||||
/// Orders Count by Status Provider
|
||||
///
|
||||
/// Returns count of orders for each status.
|
||||
@@ -350,18 +293,18 @@ final class OrdersCountByStatusProvider
|
||||
|
||||
@$internal
|
||||
@override
|
||||
$FutureProviderElement<Map<OrderStatus, int>> $createElement(
|
||||
$FutureProviderElement<Map<String, int>> $createElement(
|
||||
$ProviderPointer pointer,
|
||||
) => $FutureProviderElement(pointer);
|
||||
|
||||
@override
|
||||
FutureOr<Map<OrderStatus, int>> create(Ref ref) {
|
||||
FutureOr<Map<String, int>> create(Ref ref) {
|
||||
return ordersCountByStatus(ref);
|
||||
}
|
||||
}
|
||||
|
||||
String _$ordersCountByStatusHash() =>
|
||||
r'85fe4fb85410855bb434b19fdc05c933c6e76235';
|
||||
r'f6cd7f4eb47123d8e3bcfc04a82990301f3c2690';
|
||||
|
||||
/// Total Orders Count Provider
|
||||
|
||||
@@ -400,3 +343,58 @@ final class TotalOrdersCountProvider
|
||||
}
|
||||
|
||||
String _$totalOrdersCountHash() => r'ec1ab3a8d432033aa1f02d28e841e78eba06d63e';
|
||||
|
||||
/// Order Status List Provider
|
||||
///
|
||||
/// Provides cached order status list with automatic refresh.
|
||||
/// Uses cache-first strategy with API fallback.
|
||||
|
||||
@ProviderFor(orderStatusList)
|
||||
const orderStatusListProvider = OrderStatusListProvider._();
|
||||
|
||||
/// Order Status List Provider
|
||||
///
|
||||
/// Provides cached order status list with automatic refresh.
|
||||
/// Uses cache-first strategy with API fallback.
|
||||
|
||||
final class OrderStatusListProvider
|
||||
extends
|
||||
$FunctionalProvider<
|
||||
AsyncValue<List<OrderStatus>>,
|
||||
List<OrderStatus>,
|
||||
FutureOr<List<OrderStatus>>
|
||||
>
|
||||
with
|
||||
$FutureModifier<List<OrderStatus>>,
|
||||
$FutureProvider<List<OrderStatus>> {
|
||||
/// Order Status List Provider
|
||||
///
|
||||
/// Provides cached order status list with automatic refresh.
|
||||
/// Uses cache-first strategy with API fallback.
|
||||
const OrderStatusListProvider._()
|
||||
: super(
|
||||
from: null,
|
||||
argument: null,
|
||||
retry: null,
|
||||
name: r'orderStatusListProvider',
|
||||
isAutoDispose: true,
|
||||
dependencies: null,
|
||||
$allTransitiveDependencies: null,
|
||||
);
|
||||
|
||||
@override
|
||||
String debugGetCreateSourceHash() => _$orderStatusListHash();
|
||||
|
||||
@$internal
|
||||
@override
|
||||
$FutureProviderElement<List<OrderStatus>> $createElement(
|
||||
$ProviderPointer pointer,
|
||||
) => $FutureProviderElement(pointer);
|
||||
|
||||
@override
|
||||
FutureOr<List<OrderStatus>> create(Ref ref) {
|
||||
return orderStatusList(ref);
|
||||
}
|
||||
}
|
||||
|
||||
String _$orderStatusListHash() => r'f005726ad238164f7e0dece62476b39fd762e933';
|
||||
|
||||
Reference in New Issue
Block a user