Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
79 changes: 0 additions & 79 deletions EstateReportingAPI.BusinessLogic/ReportingManager.cs
Original file line number Diff line number Diff line change
Expand Up @@ -571,85 +571,6 @@ private Decimal SafeDivide(Decimal number, Int32 divisor)

return number / divisor;
}

public async Task<TodaysSales> GetProductPerformance(Guid estateId, DateTime comparisonDate, List<Int32> productReportingIds, CancellationToken cancellationToken)
{
using ResolvedDbContext<EstateManagementContext>? resolvedContext = this.Resolver.Resolve(EstateManagementDatabaseName, estateId.ToString());
await using EstateManagementContext context = resolvedContext.Context;

// First we need to get a value of todays sales
var todaysSalesQuery = (from t in context.TodayTransactions
where t.IsAuthorised && t.TransactionType == "Sale"
&& t.TransactionDate == DateTime.Now.Date
&& t.TransactionTime <= DateTime.Now.TimeOfDay
select t);

var comparisonSalesQuery = (from t in context.TransactionHistory
where t.IsAuthorised && t.TransactionType == "Sale"
&& t.TransactionDate == comparisonDate
&& t.TransactionTime <= DateTime.Now.TimeOfDay
select t);


if (productReportingIds.Any())
{
todaysSalesQuery = todaysSalesQuery.Where(t => productReportingIds.Contains(t.ContractProductReportingId));
comparisonSalesQuery = comparisonSalesQuery.Where(t => productReportingIds.Contains(t.ContractProductReportingId));
}

TodaysSales response = new TodaysSales
{
ComparisonSalesCount = comparisonSalesQuery.Count(),
ComparisonSalesValue = comparisonSalesQuery.Sum(t => t.TransactionAmount),
TodaysSalesCount = todaysSalesQuery.Count(),
TodaysSalesValue = todaysSalesQuery.Sum(t => t.TransactionAmount),
};
response.ComparisonAverageSalesValue =
SafeDivide(response.ComparisonSalesValue, response.ComparisonSalesCount);
response.TodaysAverageSalesValue =
SafeDivide(response.TodaysSalesValue, response.TodaysSalesCount);

return response;
}

public async Task<TodaysSales> GetOperatorPerformance(Guid estateId, DateTime comparisonDate, List<Int32> operatorReportingIds, CancellationToken cancellationToken){
using ResolvedDbContext<EstateManagementContext>? resolvedContext = this.Resolver.Resolve(EstateManagementDatabaseName, estateId.ToString());
await using EstateManagementContext context = resolvedContext.Context;

// First we need to get a value of todays sales
var todaysSalesQuery = (from t in context.TodayTransactions
where t.IsAuthorised && t.TransactionType == "Sale"
&& t.TransactionDate == DateTime.Now.Date
&& t.TransactionTime <= DateTime.Now.TimeOfDay
select t);

var comparisonSalesQuery = (from t in context.TransactionHistory
where t.IsAuthorised && t.TransactionType == "Sale"
&& t.TransactionDate == comparisonDate
&& t.TransactionTime <= DateTime.Now.TimeOfDay
select t);


if (operatorReportingIds.Any())
{
todaysSalesQuery = todaysSalesQuery.Where(t => operatorReportingIds.Contains(t.OperatorReportingId));
comparisonSalesQuery = comparisonSalesQuery.Where(t => operatorReportingIds.Contains(t.OperatorReportingId));
}

TodaysSales response = new TodaysSales
{
ComparisonSalesCount = comparisonSalesQuery.Count(),
ComparisonSalesValue = comparisonSalesQuery.Sum(t => t.TransactionAmount),
TodaysSalesCount = todaysSalesQuery.Count(),
TodaysSalesValue = todaysSalesQuery.Sum(t => t.TransactionAmount),
};
response.ComparisonAverageSalesValue =
SafeDivide(response.ComparisonSalesValue, response.ComparisonSalesCount);
response.TodaysAverageSalesValue =
SafeDivide(response.TodaysSalesValue, response.TodaysSalesCount);

return response;
}

public async Task<List<Merchant>> GetMerchants(Guid estateId,
CancellationToken cancellationToken) {
Expand Down
31 changes: 31 additions & 0 deletions EstateReportingAPI.BusinessLogic/ReportingManagerExtensions.cs
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,37 @@ public static IQueryable<TransactionHistory> ApplyMerchantFilter(this IQueryable
return query.Where(t => merchantReportingIds.Contains(t.MerchantReportingId)).AsQueryable();
}

public static IQueryable<TodayTransaction> ApplyProductFilter(this IQueryable<TodayTransaction> query, List<int> productReportingIds)
{
if (productReportingIds == null || productReportingIds.Count == 0)
return query;

return query.Where(t => productReportingIds.Contains(t.ContractProductReportingId)).AsQueryable();
}

public static IQueryable<TransactionHistory> ApplyProductFilter(this IQueryable<TransactionHistory> query, List<int> productReportingIds)
{
if (productReportingIds == null || productReportingIds.Count == 0)
return query;

return query.Where(t => productReportingIds.Contains(t.ContractProductReportingId)).AsQueryable();
}

public static IQueryable<TodayTransaction> ApplyOperatorFilter(this IQueryable<TodayTransaction> query, List<int> operatorReportingIds)
{
if (operatorReportingIds == null || operatorReportingIds.Count == 0)
return query;

return query.Where(t => operatorReportingIds.Contains(t.OperatorReportingId)).AsQueryable();
}

public static IQueryable<TransactionHistory> ApplyOperatorFilter(this IQueryable<TransactionHistory> query, List<int> operatorReportingIds)
{
if (operatorReportingIds == null || operatorReportingIds.Count == 0)
return query;

return query.Where(t => operatorReportingIds.Contains(t.OperatorReportingId)).AsQueryable();
}

public static IQueryable<DatabaseProjections.FeeTransactionProjection> ApplyMerchantFilter(this IQueryable<DatabaseProjections.FeeTransactionProjection> query,
EstateManagementContext context,
Expand Down
54 changes: 54 additions & 0 deletions EstateReportingAPI.BusinessLogic/ReportingManagerRefactored.cs
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,60 @@ public async Task<TodaysSales> GetMerchantPerformance(Guid estateId, DateTime co
return response;
}

public async Task<TodaysSales> GetProductPerformance(Guid estateId, DateTime comparisonDate, List<Int32> productReportingIds, CancellationToken cancellationToken)
{
using ResolvedDbContext<EstateManagementContext>? resolvedContext = this.Resolver.Resolve(EstateManagementDatabaseName, estateId.ToString());
await using EstateManagementContext context = resolvedContext.Context;

// First we need to get a value of todays sales
IQueryable<TodayTransaction> todaysSalesQuery = BuildTodaySalesQuery(context);
IQueryable<TransactionHistory> comparisonSalesQuery = BuildComparisonSalesQuery(context, comparisonDate);

todaysSalesQuery = todaysSalesQuery.ApplyProductFilter(productReportingIds);
comparisonSalesQuery = comparisonSalesQuery.ApplyProductFilter(productReportingIds);

TodaysSales response = new TodaysSales
{
ComparisonSalesCount = await comparisonSalesQuery.CountAsync(cancellationToken),
ComparisonSalesValue = await comparisonSalesQuery.SumAsync(t => t.TransactionAmount, cancellationToken),
TodaysSalesCount = await todaysSalesQuery.CountAsync(cancellationToken),
TodaysSalesValue = await todaysSalesQuery.SumAsync(t => t.TransactionAmount, cancellationToken),
};
response.ComparisonAverageSalesValue =
SafeDivide(response.ComparisonSalesValue, response.ComparisonSalesCount);
response.TodaysAverageSalesValue =
SafeDivide(response.TodaysSalesValue, response.TodaysSalesCount);

return response;
}

public async Task<TodaysSales> GetOperatorPerformance(Guid estateId, DateTime comparisonDate, List<Int32> operatorReportingIds, CancellationToken cancellationToken)
{
using ResolvedDbContext<EstateManagementContext>? resolvedContext = this.Resolver.Resolve(EstateManagementDatabaseName, estateId.ToString());
await using EstateManagementContext context = resolvedContext.Context;

// First we need to get a value of todays sales
IQueryable<TodayTransaction> todaysSalesQuery = BuildTodaySalesQuery(context);
IQueryable<TransactionHistory> comparisonSalesQuery = BuildComparisonSalesQuery(context, comparisonDate);

todaysSalesQuery = todaysSalesQuery.ApplyOperatorFilter(operatorReportingIds);
comparisonSalesQuery = comparisonSalesQuery.ApplyOperatorFilter(operatorReportingIds);

TodaysSales response = new TodaysSales
{
ComparisonSalesCount = await comparisonSalesQuery.CountAsync(cancellationToken),
ComparisonSalesValue = await comparisonSalesQuery.SumAsync(t => t.TransactionAmount, cancellationToken),
TodaysSalesCount = await todaysSalesQuery.CountAsync(cancellationToken),
TodaysSalesValue = await todaysSalesQuery.SumAsync(t => t.TransactionAmount, cancellationToken),
};
response.ComparisonAverageSalesValue =
SafeDivide(response.ComparisonSalesValue, response.ComparisonSalesCount);
response.TodaysAverageSalesValue =
SafeDivide(response.TodaysSalesValue, response.TodaysSalesCount);

return response;
}

}

public class DatabaseProjections {
Expand Down
Loading