| 1 | using System.Collections.Generic;
|
|---|
| 2 | using System.Linq;
|
|---|
| 3 | using System.Threading.Tasks;
|
|---|
| 4 | using StockMaster.Data;
|
|---|
| 5 | using StockMaster.Models;
|
|---|
| 6 | using Microsoft.EntityFrameworkCore;
|
|---|
| 7 |
|
|---|
| 8 | namespace StockMaster.Services
|
|---|
| 9 | {
|
|---|
| 10 | public class WarehouseService : IWarehouseService
|
|---|
| 11 | {
|
|---|
| 12 | private readonly StockDbContext _context;
|
|---|
| 13 |
|
|---|
| 14 | public WarehouseService(StockDbContext context)
|
|---|
| 15 | {
|
|---|
| 16 | _context = context;
|
|---|
| 17 | }
|
|---|
| 18 |
|
|---|
| 19 | public async Task<List<WarehouseStock>> GetWarehouseStockAsync(int warehouseId)
|
|---|
| 20 | {
|
|---|
| 21 | return await _context.WarehouseStocks
|
|---|
| 22 | .Include(ws => ws.Warehouse)
|
|---|
| 23 | .Include(ws => ws.Product)
|
|---|
| 24 | .ThenInclude(p => p.Category)
|
|---|
| 25 |
|
|---|
| 26 | .Where(ws => ws.WarehouseId == warehouseId)
|
|---|
| 27 | .ToListAsync();
|
|---|
| 28 | }
|
|---|
| 29 |
|
|---|
| 30 | public async Task<Dictionary<string, int>> GetStockSummaryAsync()
|
|---|
| 31 | {
|
|---|
| 32 | var totalProducts = await _context.Products.CountAsync(p => p.IsActive);
|
|---|
| 33 | var totalStock = await _context.WarehouseStocks.SumAsync(ws => ws.QuantityOnHand);
|
|---|
| 34 | var warehouses = await _context.Warehouses.CountAsync();
|
|---|
| 35 |
|
|---|
| 36 | return new Dictionary<string, int>
|
|---|
| 37 | {
|
|---|
| 38 | { "TotalProducts", totalProducts },
|
|---|
| 39 | { "TotalStock", totalStock },
|
|---|
| 40 | { "Warehouses", warehouses }
|
|---|
| 41 | };
|
|---|
| 42 | }
|
|---|
| 43 | }
|
|---|
| 44 | } |
|---|