This commit is contained in:
mmrbnjd
2025-01-22 13:02:53 +03:30
parent 83d7514581
commit 88d4b63394
5 changed files with 382 additions and 54 deletions

View File

@@ -23,51 +23,55 @@ namespace Back.Services.Warehouse
_RemittanceRepo = remittanceRepo;
_ReceiptRepo = receiptRepo;
}
public async Task<PagingDto<CirculationDto>> Circulation(int CompanyID,string date="",int CODID=0,int PageIndex=1,int PageSize=5)
public async Task<PagingDto<CirculationDto>> Circulation(int CompanyID, string date = "", int CODID = 0, int PageIndex = 1, int PageSize = 5)
{
var RequestRemittance = _RemittanceRepo.Get(w => w.cODItem.CompanyID == CompanyID && !w.Deleted)
.Select(s=>new CirculationDto
.Select(s => new CirculationDto
{
CODID=s.CODID,
CODTitle=s.cODItem.Title,
Date=s.Date,
Count=s.Count,
info=s.info,
Type=TypeCirculation.Remittance,
ID= s.ID,
CODID = s.CODID,
CODTitle = s.cODItem.Title,
Date = s.Date.ShamciToFormatShamci(),
Count = s.Count,
info = s.info,
Type = TypeCirculation.Remittance,
ModelTypeID = (int)s.Type,
ModelTypeTitle= s.Type.GetDisplayName()
ModelTypeTitle = s.Type.GetDisplayName(),
invoiceID = s.InvoiceID,
});
if (!string.IsNullOrEmpty(date))
RequestRemittance = RequestRemittance.Where(w => w.Date == date);
if (CODID!=0)
if (CODID != 0)
RequestRemittance = RequestRemittance.Where(w => w.CODID == CODID);
//-----------
var RequestReceipt = _ReceiptRepo.Get(w => w.cODItem.CompanyID == CompanyID && !w.Deleted)
.Select(s => new CirculationDto
{
ID = s.ID,
CODID = s.CODID,
CODTitle = s.cODItem.Title,
Date = s.Date,
Date = s.Date.ShamciToFormatShamci(),
Count = s.Count,
info = s.info,
Type = TypeCirculation.Receipt,
ModelTypeID = (int)s.Type,
ModelTypeTitle = s.Type.GetDisplayName()
ModelTypeTitle = s.Type.GetDisplayName(),
invoiceID = s.InvoiceID,
});
if (!string.IsNullOrEmpty(date))
RequestReceipt = RequestReceipt.Where(w => w.Date == date);
if (CODID != 0)
RequestReceipt = RequestReceipt.Where(w => w.CODID == CODID);
return await RequestReceipt.Union(RequestRemittance).OrderByDescending(o => o.Date).Paging(PageIndex, PageSize);
return await RequestReceipt.Union(RequestRemittance).OrderByDescending(o => o.Date).Paging(PageIndex, PageSize);
//var list = await RequestReceipt.ToListAsync();
//list.AddRange(await RequestRemittance.ToListAsync());
//return await list.OrderByDescending(o=>o.Date).AsQueryable().Paging(PageIndex, PageSize);
}
public async Task<decimal> Inventory(int CompanyID,int CODID)
public async Task<decimal> Inventory(int CompanyID, int CODID)
{
var CReceipt=await _ReceiptRepo.Get(w => w.cODItem.CompanyID == CompanyID && w.CODID == CODID && w.ForSale && !w.Deleted).SumAsync(s => s.Count);
var CRemittance=await _RemittanceRepo.Get(w => w.cODItem.CompanyID == CompanyID && w.CODID == CODID && !w.Deleted).SumAsync(s => s.Count);
var CReceipt = await _ReceiptRepo.Get(w => w.cODItem.CompanyID == CompanyID && w.CODID == CODID && w.ForSale && !w.Deleted).SumAsync(s => s.Count);
var CRemittance = await _RemittanceRepo.Get(w => w.cODItem.CompanyID == CompanyID && w.CODID == CODID && !w.Deleted).SumAsync(s => s.Count);
return CReceipt - CRemittance;
}
}

View File

@@ -11,13 +11,14 @@ namespace Shared.DTOs.Warehouse
public enum TypeCirculation
{
[Display(Name = "رسید")]
Receipt,
Receipt=10,
[Display(Name = "حواله")]
Remittance
Remittance=20
}
public class CirculationDto
{
public int ID { get; set; }
public int CODID { get; set; }
[Display(Name = "کالا")]
public string? CODTitle { get; set; }
@@ -35,5 +36,6 @@ namespace Shared.DTOs.Warehouse
public TypeCirculation Type { get; set; }
[Display(Name = "نوع سند")]
public string msgType { get { return Type.GetEnumDisplayName(); } }
public int? invoiceID { get; set; }
}
}

View File

@@ -13,11 +13,6 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "View", "View", "{25C58D68-C
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "moadiran", "moadiran\moadiran.csproj", "{E209C152-76D5-469F-A969-B5BE5970CA7A}"
EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{8B482DB5-6DE6-4983-A3B2-36458EAEAD5F}"
ProjectSection(SolutionItems) = preProject
next.txt = next.txt
EndProjectSection
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU

View File

@@ -0,0 +1,321 @@
@using Front.Services
@using Shared
@using Shared.DTOs
@using Shared.DTOs.Warehouse
@using Shared.Enums
@inject HttpClientController hc;
<ConfirmDialog @ref="dialog" />
<form>
@* alert *@
<div class="row">
<Alert hidden="@Hidealert" Color="@alertColor" Dismissable="false">
<Icon Name="@alertIconName" class="me-2"></Icon>
@alertMessage
</Alert>
</div>
<ul>
@if (_UsedFromInvoice)
{
<li> style="color:indianred"این سند از فاکتور صادر شده، ویرایش مستقیم آن ممکن نیست</li>
<br />
}
</ul>
<div class="col-md-2">
<AutoComplete @bind-Value="model.CODTitle"
TItem="CODIdName<int>"
DataProvider="CODDataProvider"
PropertyName="Title"
Placeholder="جستجو در کالا..."
OnChanged="(CODIdName<int> cod) => OnAutoCompleteChanged(cod)" />
</div>
@* <div class="col-md-2">
<select style="text-align:center" @bind="Doctype" class="form-control" aria-label="Default select example">
<option value="0" style="color: #b5b5b5" selected>نوع ...</option>
<option value="10">رسید</option>
<option value="20">حواله</option>
</select>
</div> *@
<div class="form-group col-md-2">
<label class="col-sm-4 col-form-label" style="color:red" for="inputFullName">تعداد</label>
<InputNumber @bind-Value="model.Count" type="text" class="form-control" id="inputam" placeholder="تعداد" />
</div>
<div class="form-group col-md-2">
<label class="col-sm-5 col-form-label" for="inputInvoicIssueDate">تاریخ</label>
<InputText style=" text-align: center;" @bind-Value="model.Date" type="text" class="form-control" id="inputInvoicIssueDate" placeholder="تاریخ" />
</div>
<div class="col-md-2">
<select style="text-align:center" @bind="model.ModelTypeID" class="form-control" aria-label="Default select example">
<option value="0" style="color: #b5b5b5" selected>نوع سند ...</option>
@if (model.Type == TypeCirculation.Receipt)
{
<option value="1">خرید</option>
<option value="2">امانت</option>
}
@if (model.Type == TypeCirculation.Remittance)
{
<option value="3">فروش</option>
<option value="4">امانت</option>
}
</select>
</div>
@if (model.Type == TypeCirculation.Receipt)
{
<div class="col-md-2">
<Switch @bind-Value="forsale" Label="اجازه فروش" />
</div>
}
<div class="form-group col-md-4">
<label class="col-form-label" for="inputdes">توضیحات</label>
<InputText @bind-Value="model.info" type="text" class="form-control" id="inputdes" placeholder="توضیحات" />
</div>
</form>
<div class="row g-3">
<div class="col-md-10">
@if (model.CODID == 0)
{
<Button class="mt-3" Color="ButtonColor.Success" @onclick="OnClickAddOrUpdate" Type="ButtonType.Button">
جدید
</Button>
}
else
{
@if (!_UsedFromInvoice)
{
<Button Disabled="SpinnerVisible" class="mt-3" Color="ButtonColor.Success" @onclick="OnClickAddOrUpdate" Type="ButtonType.Button">
ثبت تغییرات
</Button>
<Button Disabled="SpinnerVisible" class=" mt-3" Color="ButtonColor.Danger" @onclick="ShowConfirmationDeleteAsync" Type="ButtonType.Button">
حذف
</Button>
}
}
</div>
<div class="col-md-2">
<Spinner Visible="SpinnerVisible" Color="SpinnerColor.Primary" />
</div>
</div>
@code {
[Parameter] public CirculationDto model { get; set; }
[Parameter] public EventCallback<ActionInResultComponent> OnMultipleOfThree { get; set; }
[Parameter] public bool NewItem { get; set; }
[Parameter] public List<CODIdName<int>> CODrequest { get; set; }
private ConfirmDialog dialog = default!;
AlertColor alertColor = AlertColor.Primary;
IconName alertIconName = IconName.CheckCircleFill;
bool Hidealert = true;
string alertMessage = "";
bool _UsedFromInvoice = false;
public bool SpinnerVisible { get; set; } = false;
private bool forsale { get; set; } = false;
}
@functions {
protected override async Task OnParametersSetAsync()
{
_UsedFromInvoice = model.invoiceID.HasValue;
if (NewItem)
model.Date = DateTime.Now.ConvertMiladiToShamsiinFront().ShamciToFormatShamciinFront();
await base.OnParametersSetAsync();
}
private void ShowSuccessAlert(string msg)
{
Hidealert = false;
alertColor = AlertColor.Success;
alertIconName = IconName.CheckCircleFill;
alertMessage = msg;
}
private void ShowDangerAlert(string msg)
{
Hidealert = false;
alertColor = AlertColor.Danger;
alertIconName = IconName.ExclamationTriangleFill;
alertMessage = msg;
}
public async Task OnClickDelete()
{
if (NewItem)
return;
SpinnerVisible = true;
await Delete();
SpinnerVisible = false;
}
private async Task Delete()
{
string route = model.Type == TypeCirculation.Receipt ? "Receipt" : "Remittance";
var rsp = await hc.Delete($"{route}/{model.ID}");
if (rsp.IsSuccessStatusCode)
{
var request = await rsp.Content.ReadFromJsonAsync<bool>();
if (request)
{
ActionInResultComponent result = new ActionInResultComponent();
result.Status = ComponentStatus.success;
result.Action = ComponentAction.delete;
await OnMultipleOfThree.InvokeAsync(result);
}
else ShowDangerAlert("خطایی در اجرای عملیات رخ داده");
}
else if (rsp.StatusCode == System.Net.HttpStatusCode.NotFound)
{
ShowDangerAlert("سندی یافت نشد");
}
else ShowDangerAlert("خطایی در اجرای عملیات رخ داده");
}
private async Task Addorupdate()
{
string controller = model.Type == TypeCirculation.Receipt ? "Receipt" : "Remittance";
string route = NewItem ? "ADD" : "Update";
ActionInResultComponent result = new ActionInResultComponent();
HttpResponseMessage rsp = new HttpResponseMessage();
if (NewItem)
{
if (model.Type == TypeCirculation.Receipt)
rsp = await hc.Post($"{controller}/{NewItem}/{model.ID}", new ReceiptDto()
{
CODID = model.CODID,
Count = model.Count,
Date = model.Date,
ForSale = model.ForSale.Value,
info = model.info,
Type = (TypeReceipt)model.ModelTypeID,
});
if (model.Type == TypeCirculation.Remittance)
rsp = await hc.Post($"{route}/Update/{model.ID}", new RemittanceDto()
{
CODID = model.CODID,
Count = model.Count,
Date = model.Date,
info = model.info,
Type = (TypeRemittance)model.ModelTypeID,
});
result.Action = ComponentAction.add;
}
else
{
if (model.Type == TypeCirculation.Receipt)
rsp = await hc.Put($"{controller}/{NewItem}/{model.ID}", new ReceiptDto()
{
CODID = model.CODID,
Count = model.Count,
Date = model.Date,
ForSale = model.ForSale.Value,
info = model.info,
Type = (TypeReceipt)model.ModelTypeID,
});
if (model.Type == TypeCirculation.Remittance)
rsp = await hc.Put($"{route}/Update/{model.ID}", new RemittanceDto()
{
CODID = model.CODID,
Count = model.Count,
Date = model.Date,
info = model.info,
Type = (TypeRemittance)model.ModelTypeID,
});
result.Action = ComponentAction.update;
}
if (rsp.IsSuccessStatusCode)
{
result.Status = ComponentStatus.success;
await OnMultipleOfThree.InvokeAsync(result);
}
else
{
var request = await rsp.Content.ReadFromJsonAsync<List<string>>();
ShowDangerAlert(request[0]);
}
}
public async Task OnClickAddOrUpdate()
{
SpinnerVisible = true;
await Addorupdate();
SpinnerVisible = false;
}
private async Task ShowConfirmationDeleteAsync()
{
if (!NewItem)
{
var confirmation = await dialog.ShowAsync(
title: "عملیات حذف سند انبار",
message1: $"{model.info}",
message2: "اطمینان دارید?");
if (confirmation)
await OnClickDelete();
}
}
private async Task<bool> ValidateRemittance()
{
if (model.Type == TypeCirculation.Remittance)
{
if (model.ModelTypeID != 3 && model.ModelTypeID != 4)
ShowDangerAlert("نوع سند صحیح نمی باشد");
else return await Validate();
}
return false;
}
private async Task<bool> ValidateReceipt()
{
if (model.Type == TypeCirculation.Receipt)
{
model.ForSale = forsale;
if (model.ModelTypeID != 1 && model.ModelTypeID != 2)
ShowDangerAlert("نوع سند صحیح نمی باشد");
else return await Validate();
}
return false;
}
private async Task<bool> Validate()
{
if (model.CODID == null || model.CODID == 0)
ShowDangerAlert("کالایی انتخاب کنید");
if (model.Count <= 0)
ShowDangerAlert("تعدادی وارد کنید");
if (string.IsNullOrEmpty(model.Date))
ShowDangerAlert("تاریخ را مشخص کنید");
if (model.Date.Replace("/", "").Length != 10)
ShowDangerAlert("تاریخ صحیح نمی باشد");
if (string.IsNullOrEmpty(model.info))
ShowDangerAlert("توضیحی مشخص کنید");
else return true;
return false;
}
private async Task<AutoCompleteDataProviderResult<CODIdName<int>>> CODDataProvider(AutoCompleteDataProviderRequest<CODIdName<int>> request)
{
return await Task.FromResult(request.ApplyTo(CODrequest.OrderBy(cod => cod.ID)));
}
private void OnAutoCompleteChanged(CODIdName<int> cOD)
{
model.CODID = cOD.ID;
}
}

View File

@@ -1,5 +1,6 @@
<PageTitle>انبارداری</PageTitle>
@page "/Warehouse"
@using Front.CUSComponent
@using Front.Services
@using Shared.DTOs
@using Shared.DTOs.Warehouse
@@ -20,7 +21,7 @@
<ul class="list-group fa-padding" style="border: 2px solid #0d6efd">
<li class="list-group-item" data-toggle="modal" data-target="#issue">
<div class="row g-3">
=
=
<div class="col-md-2">
<input @bind-value="date" placeholder="تاریخ" style="text-align:center" dir="ltr" class="form-control" type="number">
</div>
@@ -157,7 +158,15 @@
string query = "";
if (!string.IsNullOrEmpty(date))
query = $"date={date}&";
{
if (date.Replace("/","").Length==10)
query = $"date={date}&";
else
{
ShowDangerAlert("تاریخ صحیح نمی باشد");
return;
}
}
if (CODID != null && CODID != 0)
query += $"CODID={CODID}&";
@@ -183,44 +192,41 @@
}
public async Task CallBackItem(ActionInResultComponent result)
{
if (result.Status == ComponentStatus.success && result.Action==ComponentAction.delete)
ShowSuccessAlert("حذف با موفقیت انجام شد");
if (result.Status == ComponentStatus.success && result.Action == ComponentAction.update)
ShowSuccessAlert("ویرایش با موفقیت انجام شد");
if (result.Status == ComponentStatus.success && result.Action == ComponentAction.add)
ShowSuccessAlert("سند جدید اضافه شد");
if (result.Status==ComponentStatus.success)
{
await Load(1);
}
}
public async Task Item(CirculationDto circulationDto)
{
//رسید
string title = "";
//رسید
if (circulationDto.Type == TypeCirculation.Receipt)
{
//جدید
if (circulationDto.CODID==0)
{
}
else
{
}
}
//حواله
title = "رسید";
//حواله
if (circulationDto.Type == TypeCirculation.Remittance)
{
//جدید
if (circulationDto.CODID == 0)
{
title = "حواله";
}
else
{
}
}
// var parameters = new Dictionary<string, object>();
if (circulationDto.CODID == 0)
title += " جدید";
else title = "اطلاعات " + title;
var parameters = new Dictionary<string, object>();
// if (ID == 0) parameters.Add("Cus", new RCustomer() { ID = 0 });
// else parameters.Add("Cus", request.list.Where(w => w.ID == ID).First().Clone());
// parameters.Add("OnMultipleOfThree", EventCallback.Factory.Create<ActionInResultComponent>(this, CallBackCustomerItem));
// await modal.ShowAsync<CustomerItem>(title: ID == 0 ? "مشتری جدید" : "ویرایش اطلاعات", parameters: parameters);
parameters.Add("OnMultipleOfThree", EventCallback.Factory.Create<ActionInResultComponent>(this, CallBackItem));
parameters.Add("model", circulationDto);
parameters.Add("NewItem", circulationDto.CODID == 0);
parameters.Add("CODrequest", CODrequest);
await modal.ShowAsync<WarehouseItem>(title: title, parameters: parameters);
}