2025-08-17 10:10:31 +07:00
|
|
|
import 'dart:developer';
|
|
|
|
|
|
|
|
|
|
import 'package:data_channel/data_channel.dart';
|
|
|
|
|
import 'package:injectable/injectable.dart';
|
|
|
|
|
|
|
|
|
|
import '../../../common/api/api_client.dart';
|
|
|
|
|
import '../../../common/api/api_failure.dart';
|
|
|
|
|
import '../../../common/extension/extension.dart';
|
2025-08-17 14:34:52 +07:00
|
|
|
import '../../../common/function/app_function.dart';
|
2025-08-17 10:10:31 +07:00
|
|
|
import '../../../common/url/api_path.dart';
|
|
|
|
|
import '../../../domain/analytic/analytic.dart';
|
|
|
|
|
import '../analytic_dtos.dart';
|
|
|
|
|
|
|
|
|
|
@injectable
|
|
|
|
|
class AnalyticRemoteDataProvider {
|
|
|
|
|
final ApiClient _apiClient;
|
|
|
|
|
final String _logName = "AnalyticRemoteDataProvider";
|
|
|
|
|
|
|
|
|
|
AnalyticRemoteDataProvider(this._apiClient);
|
|
|
|
|
|
|
|
|
|
Future<DC<AnalyticFailure, SalesAnalyticDto>> fetchSales({
|
|
|
|
|
required DateTime dateFrom,
|
|
|
|
|
required DateTime dateTo,
|
|
|
|
|
}) async {
|
|
|
|
|
try {
|
|
|
|
|
final response = await _apiClient.get(
|
|
|
|
|
ApiPath.salesAnalytic,
|
|
|
|
|
params: {
|
|
|
|
|
'date_from': dateFrom.toServerDate,
|
|
|
|
|
'date_to': dateTo.toServerDate,
|
|
|
|
|
},
|
2025-08-17 14:34:52 +07:00
|
|
|
headers: getAuthorizationHeader(),
|
2025-08-17 10:10:31 +07:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if (response.data['data'] == null) {
|
|
|
|
|
return DC.error(AnalyticFailure.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
final dto = SalesAnalyticDto.fromJson(response.data['data']);
|
|
|
|
|
|
|
|
|
|
return DC.data(dto);
|
|
|
|
|
} on ApiFailure catch (e, s) {
|
|
|
|
|
log('fetchSalesError', name: _logName, error: e, stackTrace: s);
|
|
|
|
|
return DC.error(AnalyticFailure.serverError(e));
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-08-17 22:36:46 +07:00
|
|
|
|
|
|
|
|
Future<DC<AnalyticFailure, ProfitLossAnalyticDto>> fetchProfitLoss({
|
|
|
|
|
required DateTime dateFrom,
|
|
|
|
|
required DateTime dateTo,
|
|
|
|
|
}) async {
|
|
|
|
|
try {
|
|
|
|
|
final response = await _apiClient.get(
|
|
|
|
|
ApiPath.profitLossAnalytic,
|
|
|
|
|
params: {
|
|
|
|
|
'date_from': dateFrom.toServerDate,
|
|
|
|
|
'date_to': dateTo.toServerDate,
|
|
|
|
|
},
|
|
|
|
|
headers: getAuthorizationHeader(),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if (response.data['data'] == null) {
|
|
|
|
|
return DC.error(AnalyticFailure.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
final dto = ProfitLossAnalyticDto.fromJson(response.data['data']);
|
|
|
|
|
|
|
|
|
|
return DC.data(dto);
|
|
|
|
|
} on ApiFailure catch (e, s) {
|
|
|
|
|
log('fetchProfitLossError', name: _logName, error: e, stackTrace: s);
|
|
|
|
|
return DC.error(AnalyticFailure.serverError(e));
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-08-17 22:46:25 +07:00
|
|
|
|
|
|
|
|
Future<DC<AnalyticFailure, CategoryAnalyticDto>> fetchCategory({
|
|
|
|
|
required DateTime dateFrom,
|
|
|
|
|
required DateTime dateTo,
|
|
|
|
|
}) async {
|
|
|
|
|
try {
|
|
|
|
|
final response = await _apiClient.get(
|
2025-08-17 23:11:31 +07:00
|
|
|
ApiPath.categoryAnalytic,
|
2025-08-17 22:46:25 +07:00
|
|
|
params: {
|
|
|
|
|
'date_from': dateFrom.toServerDate,
|
|
|
|
|
'date_to': dateTo.toServerDate,
|
|
|
|
|
},
|
|
|
|
|
headers: getAuthorizationHeader(),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if (response.data['data'] == null) {
|
|
|
|
|
return DC.error(AnalyticFailure.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
final dto = CategoryAnalyticDto.fromJson(response.data['data']);
|
|
|
|
|
|
|
|
|
|
return DC.data(dto);
|
|
|
|
|
} on ApiFailure catch (e, s) {
|
|
|
|
|
log('fetchCategoryError', name: _logName, error: e, stackTrace: s);
|
|
|
|
|
return DC.error(AnalyticFailure.serverError(e));
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-08-17 23:54:28 +07:00
|
|
|
|
|
|
|
|
Future<DC<AnalyticFailure, InventoryAnalyticDto>> fetchInventory({
|
|
|
|
|
required String outletId,
|
|
|
|
|
required DateTime dateFrom,
|
|
|
|
|
required DateTime dateTo,
|
|
|
|
|
}) async {
|
|
|
|
|
try {
|
|
|
|
|
final response = await _apiClient.get(
|
|
|
|
|
'${ApiPath.inventoryReportDetail}/$outletId',
|
|
|
|
|
params: {
|
|
|
|
|
'date_from': dateFrom.toServerDate,
|
|
|
|
|
'date_to': dateTo.toServerDate,
|
|
|
|
|
},
|
|
|
|
|
headers: getAuthorizationHeader(),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if (response.data['data'] == null) {
|
|
|
|
|
return DC.error(AnalyticFailure.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
final dto = InventoryAnalyticDto.fromJson(response.data['data']);
|
|
|
|
|
|
|
|
|
|
return DC.data(dto);
|
|
|
|
|
} on ApiFailure catch (e, s) {
|
|
|
|
|
log('fetchInventoryError', name: _logName, error: e, stackTrace: s);
|
|
|
|
|
return DC.error(AnalyticFailure.serverError(e));
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-08-18 01:50:50 +07:00
|
|
|
|
|
|
|
|
Future<DC<AnalyticFailure, DashboardAnalyticDto>> fetchDashboard({
|
|
|
|
|
required String outletId,
|
|
|
|
|
required DateTime dateFrom,
|
|
|
|
|
required DateTime dateTo,
|
|
|
|
|
}) async {
|
|
|
|
|
try {
|
|
|
|
|
final response = await _apiClient.get(
|
|
|
|
|
ApiPath.dashboardAnalytic,
|
|
|
|
|
params: {
|
|
|
|
|
'date_from': dateFrom.toServerDate,
|
|
|
|
|
'date_to': dateTo.toServerDate,
|
|
|
|
|
},
|
|
|
|
|
headers: getAuthorizationHeader(),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if (response.data['data'] == null) {
|
|
|
|
|
return DC.error(AnalyticFailure.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
final dto = DashboardAnalyticDto.fromJson(response.data['data']);
|
|
|
|
|
|
|
|
|
|
return DC.data(dto);
|
|
|
|
|
} on ApiFailure catch (e, s) {
|
|
|
|
|
log('fetchDashboardError', name: _logName, error: e, stackTrace: s);
|
|
|
|
|
return DC.error(AnalyticFailure.serverError(e));
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-08-18 02:13:11 +07:00
|
|
|
|
|
|
|
|
Future<DC<AnalyticFailure, ProductAnalyticDto>> fetchProduct({
|
|
|
|
|
required String outletId,
|
|
|
|
|
required DateTime dateFrom,
|
|
|
|
|
required DateTime dateTo,
|
|
|
|
|
}) async {
|
|
|
|
|
try {
|
|
|
|
|
final response = await _apiClient.get(
|
|
|
|
|
ApiPath.productAnalytic,
|
|
|
|
|
params: {
|
|
|
|
|
'date_from': dateFrom.toServerDate,
|
|
|
|
|
'date_to': dateTo.toServerDate,
|
|
|
|
|
},
|
|
|
|
|
headers: getAuthorizationHeader(),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if (response.data['data'] == null) {
|
|
|
|
|
return DC.error(AnalyticFailure.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
final dto = ProductAnalyticDto.fromJson(response.data['data']);
|
|
|
|
|
|
|
|
|
|
return DC.data(dto);
|
|
|
|
|
} on ApiFailure catch (e, s) {
|
|
|
|
|
log('fetchProductError', name: _logName, error: e, stackTrace: s);
|
|
|
|
|
return DC.error(AnalyticFailure.serverError(e));
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-08-18 02:23:25 +07:00
|
|
|
|
|
|
|
|
Future<DC<AnalyticFailure, PaymentMethodAnalyticDto>> fetchPaymentMethod({
|
|
|
|
|
required String outletId,
|
|
|
|
|
required DateTime dateFrom,
|
|
|
|
|
required DateTime dateTo,
|
|
|
|
|
}) async {
|
|
|
|
|
try {
|
|
|
|
|
final response = await _apiClient.get(
|
|
|
|
|
ApiPath.paymentMethodAnalytic,
|
|
|
|
|
params: {
|
|
|
|
|
'date_from': dateFrom.toServerDate,
|
|
|
|
|
'date_to': dateTo.toServerDate,
|
|
|
|
|
},
|
|
|
|
|
headers: getAuthorizationHeader(),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if (response.data['data'] == null) {
|
|
|
|
|
return DC.error(AnalyticFailure.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
final dto = PaymentMethodAnalyticDto.fromJson(response.data['data']);
|
|
|
|
|
|
|
|
|
|
return DC.data(dto);
|
|
|
|
|
} on ApiFailure catch (e, s) {
|
|
|
|
|
log('fetchPaymentMethodError', name: _logName, error: e, stackTrace: s);
|
|
|
|
|
return DC.error(AnalyticFailure.serverError(e));
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-08-17 10:10:31 +07:00
|
|
|
}
|