FullInvoiceItem

This commit is contained in:
mmrbnjd
2024-07-20 17:34:28 +03:30
parent cb8c69d81b
commit bd99459bc2
5 changed files with 158 additions and 125 deletions

View File

@@ -80,24 +80,24 @@ namespace Back.Controllers
if (result == null) if (result == null)
return BadRequest(new List<string> { "صورتحساب یافت نشد" }); return BadRequest(new List<string> { "صورتحساب یافت نشد" });
else //else
{ //{
if (result.invoiceType == InvoiceType.Bidding) // if (result.invoiceType == InvoiceType.Bidding)
return BadRequest(new List<string> { "صورتحساب در وضعیت پیش نویس نمیتواند آماده ارسال شود" }); // return BadRequest(new List<string> { "صورتحساب در وضعیت پیش نویس نمیتواند آماده ارسال شود" });
if (await _servTaxPayer.ExistSuccessfulorSendorpendingInvoice(result)) // if (await _servTaxPayer.ExistSuccessfulorSendorpendingInvoice(result))
return BadRequest(new List<string> { "این صورتحساب قبلا به سازمان ارسال شده" }); // return BadRequest(new List<string> { "این صورتحساب قبلا به سازمان ارسال شده" });
if ((result.invoiceType == InvoiceType.BackFrmSale || result.invoiceType == InvoiceType.Repair) // if ((result.invoiceType == InvoiceType.BackFrmSale || result.invoiceType == InvoiceType.Repair)
&& !result.BillReference.HasValue) // && !result.BillReference.HasValue)
return BadRequest(new List<string> { "در وضعیت برگشت از فروش و اصلاحی باید صورتحساب مرجع وجود داشته باشد" }); // return BadRequest(new List<string> { "در وضعیت برگشت از فروش و اصلاحی باید صورتحساب مرجع وجود داشته باشد" });
if ((result.invoiceType == InvoiceType.BackFrmSale || result.invoiceType == InvoiceType.Repair) // if ((result.invoiceType == InvoiceType.BackFrmSale || result.invoiceType == InvoiceType.Repair)
&& !await _servTaxPayer.ExistSuccessfulorSendorpendingInvoice(result.invoice)) // && !await _servTaxPayer.ExistSuccessfulorSendorpendingInvoice(result.invoice))
return BadRequest(new List<string> { "در وضعیت برگشت از فروش و اصلاحی باید صورتحساب مرجع به سامانه مودیان ارسال شده باشد" }); // return BadRequest(new List<string> { "در وضعیت برگشت از فروش و اصلاحی باید صورتحساب مرجع به سامانه مودیان ارسال شده باشد" });
} //}
return Ok(await _servTaxPayer.PreparationInvoiceBeforeSending(item, result)); return Ok(await _servTaxPayer.PreparationInvoiceBeforeSending(item, result));

View File

@@ -25,12 +25,12 @@ namespace Back.Data.Models
public string? mu { get { return cODItem != null ? cODItem.CODUnit.UnitTaxID : null; } } public string? mu { get { return cODItem != null ? cODItem.CODUnit.UnitTaxID : null; } }
//میزان ارز //میزان ارز
[MaxLength(18)] [MaxLength(18)]
public decimal? cfee { get { return fee / exr; } } public decimal? cfee { get { return exr==null || exr==0 ? null : fee / exr; } }
//مبلغ مالیات بر ارزش افزوده //مبلغ مالیات بر ارزش افزوده
[MaxLength(18)] [MaxLength(18)]
public decimal? vam { get public decimal? vam { get
{ {
return invoice?.pattern?.inp == 9 ? fee*vra/100 : return vra==0 ? 0 : invoice?.pattern?.inp == 9 ? fee*vra/100 :
invoice?.pattern?.inp == 13 ? ((tcpbs+9)/100)+((prdis*vra)/100) invoice?.pattern?.inp == 13 ? ((tcpbs+9)/100)+((prdis*vra)/100)
: vra * adis / 100; : vra * adis / 100;
} } } }

View File

@@ -33,39 +33,38 @@ namespace Back.Services
} }
#endregion #endregion
//----------------------- //-----------------------
var item= await invok
return await invok
.Include(inc => inc.invoiceDetails) .Include(inc => inc.invoiceDetails)
.ThenInclude(inc => inc.cODItem) .ThenInclude(inc => inc.cODItem)
.ThenInclude(inc => inc.CODUnit) .ThenInclude(inc => inc.CODUnit)
.Include(inc => inc.Customer)
.Include(inc => inc.sentTax) .Include(inc => inc.sentTax)
//.Include(inc => inc.payments) //.Include(inc => inc.payments)
.Include(inc => inc.pattern) .Include(inc => inc.pattern)
.ThenInclude(inc => inc.BillType) .ThenInclude(inc => inc.BillType).FirstOrDefaultAsync();
.Select(s => new InvoiceDTO() return new InvoiceDTO()
{ {
IsDeleted = s.IsDeleted, IsDeleted = item.IsDeleted,
PatternID = s.PatternID, PatternID = item.PatternID,
PatternTitle = s.pattern.Title, PatternTitle = item.pattern.Title,
CustomerID = s.CustomerID, CustomerID = item.CustomerID,
CustomerName = s.Customer.FullName, CustomerName = item.Customer.FullName,
ID = s.ID, ID = item.ID,
InvoiceDate = s.InvoiceDate.ShamciToFormatShamci(), InvoiceDate = item.InvoiceDate.ShamciToFormatShamci(),
invoiceTypeTitle = s.invoiceType.GetEnumDisplayName(), invoiceTypeTitle = item.invoiceType.GetEnumDisplayName(),
invoiceType = s.invoiceType, invoiceType = item.invoiceType,
Title = s.Title, Title = item.Title,
InvoicIssueDate = s.InvoicIssueDate.ShamciToFormatShamci(), InvoicIssueDate = item.InvoicIssueDate.ShamciToFormatShamci(),
BillReference = s.BillReference, BillReference = item.BillReference,
tbill = s.tbill, tbill = item.tbill,
Des = s.Des, Des = item.Des,
PreparedtoSendtoTax = s.PreparedtoSendtoTax, PreparedtoSendtoTax = item.PreparedtoSendtoTax,
tdis = s.tdis, tdis = item.tdis,
// tvam = item.tvam,
tvam = s.tvam, Udate = item.Udate.ShamciToFormatShamci(),
Udate = s.Udate.ShamciToFormatShamci(),
InvoiceSendTaxs = s.sentTax.OrderBy(o => o.ID).Select(s => new SentTaxDto() InvoiceSendTaxs = item.sentTax.OrderBy(o => o.ID).Select(s => new SentTaxDto()
{ {
Date = s.Date.ShamciToFormatShamci(), Date = s.Date.ShamciToFormatShamci(),
Time = s.Time, Time = s.Time,
@@ -76,21 +75,21 @@ namespace Back.Services
msgInvoiceType = s.InvoiceType.GetEnumDisplayName(), msgInvoiceType = s.InvoiceType.GetEnumDisplayName(),
msgSentStatus = s.SentStatus.GetEnumDisplayName() msgSentStatus = s.SentStatus.GetEnumDisplayName()
}).ToList(), }).ToList(),
//items = s.invoiceDetails.OrderBy(o => o.ID).Select(x => new InvoiceItemDTO() items = item.invoiceDetails.OrderBy(o => o.ID).Select(x => new InvoiceItemDTO()
//{ {
// ID = x.ID, ID = x.ID,
// CODID = x.CODID, CODID = x.CODID,
// adis = x.adis, adis = x.adis,
// am = x.am.Value, am = x.am.Value,
// dis = x.dis, dis = x.dis,
// fee = x.fee.Value, fee = x.fee.Value,
// mu = x.unitTitle, mu = x.unitTitle,
// sstt = x.sstt, sstt = x.sstt,
// tsstam = x.tsstam, tsstam = x.tsstam,
// vam = x.vam, vam = x.vam,
// vra = x.vra, vra = x.vra,
// prdis = x.prdis prdis = x.prdis
//}).ToList(), }).ToList(),
payments = new List<InvoicePaymentDTO>() payments = new List<InvoicePaymentDTO>()
//s.payments.OrderBy(o => o.ID).Select(x => new InvoicePaymentDTO() //s.payments.OrderBy(o => o.ID).Select(x => new InvoicePaymentDTO()
//{ //{
@@ -106,8 +105,7 @@ namespace Back.Services
// trmn = x.trmn, // trmn = x.trmn,
// trn = x.acn // trn = x.acn
//}).ToList() //}).ToList()
}) };
.FirstOrDefaultAsync();
} }

View File

@@ -334,16 +334,17 @@
} }
else else
{ {
<div class="d-flex gap-2">
<Dropdown Color="DropdownColor.Info" Direction="DropdownDirection.Dropend">
<DropdownToggleButton>Dropend</DropdownToggleButton> <Button class="mt-3" Color="ButtonColor.Success" @onclick="OnClickUpdate" Type="ButtonType.Button">
<DropdownMenu> ثبت تغییرات
<DropdownItem Type="ButtonType.Link" @onclick="OnClickUpdate"> ثبت تغییرات</DropdownItem> </Button>
<DropdownItem Type="ButtonType.Link" @onclick="ShowConfirmationDeleteAsync">حذف</DropdownItem> <Button class="mt-3" Color="ButtonColor.Danger" @onclick="ShowConfirmationDeleteAsync" Type="ButtonType.Button">
<DropdownItem Type="ButtonType.Link" @onclick="showFullInvoiceItem">اطلاعات تکمیلی صورتحساب</DropdownItem> حذف
</DropdownMenu> </Button>
</Dropdown> <Button class="mt-3" Color="ButtonColor.Primary" @onclick="showFullInvoiceItem" Type="ButtonType.Button">
</div> اطلاعات تکمیلی
</Button>
@* <Button class="mt-3" Color="ButtonColor.Primary" @onclick="ShowReport" Type="ButtonType.Button"> @* <Button class="mt-3" Color="ButtonColor.Primary" @onclick="ShowReport" Type="ButtonType.Button">
pdf pdf
</Button> </Button>
@@ -354,7 +355,7 @@
} }
</div> </div>
@if (invoice.invoiceType != InvoiceType.Bidding && SendInvoice) @if (!invoice.IsDeleted && invoice.invoiceType != InvoiceType.Bidding && SendInvoice)
{ {
<div class="form-group col-md-2"> <div class="form-group col-md-2">
<br /> <br />

View File

@@ -17,10 +17,22 @@
</Alert> </Alert>
</div> </div>
<h4 class="fw-bold py-3 mb-4"> @if (FullInvoice)
{
<h4 class="fw-bold py-3 mb-4">
<span class="text-muted fw-light">سرویس ها / صورتحساب /</span> اطلاعات تکمیلی صورتحساب
</h4>
}
else
{
<h4 class="fw-bold py-3 mb-4">
<span class="text-muted fw-light">سرویس ها / صورتحساب /</span> آماده سازی قبل از ارسال به سامانه مودیان <span class="text-muted fw-light">سرویس ها / صورتحساب /</span> آماده سازی قبل از ارسال به سامانه مودیان
</h4> </h4>
<div class="row"> }
@if(!FullInvoice)
{
<div class="row">
<div class="col-md-12"> <div class="col-md-12">
<div class="card mb-4"> <div class="card mb-4">
<h4 style="color:red;" class="card-header">توجه</h4> <h4 style="color:red;" class="card-header">توجه</h4>
@@ -32,7 +44,9 @@
</div> </div>
</div> </div>
</div> </div>
</div> </div>
}
<div class="row"> <div class="row">
<div class="col-md-12"> <div class="col-md-12">
<div class="card mb-4"> <div class="card mb-4">
@@ -188,7 +202,15 @@
<div class="row"> <div class="row">
<div class="col-md-12"> <div class="col-md-12">
<div class="col-auto"> <div class="col-auto">
@if (FullInvoice)
{
<button type="submit" @onclick="Send" class="btn btn-primary">ثبت تغییرات</button>
}
else
{
<button type="submit" @onclick="Send" class="btn btn-primary">آماده سازی و ارسال</button> <button type="submit" @onclick="Send" class="btn btn-primary">آماده سازی و ارسال</button>
}
</div> </div>
</div> </div>
</div> </div>
@@ -204,6 +226,7 @@
List<ToastMessage> messages = new List<ToastMessage>(); List<ToastMessage> messages = new List<ToastMessage>();
[Inject] protected PreloadService PreloadService { get; set; } = default!; [Inject] protected PreloadService PreloadService { get; set; } = default!;
public _TaxPayer.Atemplatefield? invoice { get; set; } public _TaxPayer.Atemplatefield? invoice { get; set; }
public bool FullInvoice { get; set; } = true;
// alert // alert
AlertColor alertColor = AlertColor.Primary; AlertColor alertColor = AlertColor.Primary;
IconName alertIconName = IconName.CheckCircleFill; IconName alertIconName = IconName.CheckCircleFill;
@@ -216,7 +239,9 @@
await LoadData(); await LoadData();
PreloadService.Hide(); PreloadService.Hide();
var res= hc._nav.Uri.ToString(); if (hc._nav.Uri.ToString().Contains("FullInvoiceItem"))
FullInvoice = true;
else FullInvoice = false;
await base.OnParametersSetAsync(); await base.OnParametersSetAsync();
} }
@@ -232,7 +257,7 @@
}; };
public async Task Send() public async Task Send()
{ {
if (!await CheckAuth()) if (!FullInvoice && !await CheckAuth())
{ {
ShowMessage(ToastType.Danger, "خطا در احراز هویت سازمان مالیاتی"); ShowMessage(ToastType.Danger, "خطا در احراز هویت سازمان مالیاتی");
} }
@@ -244,7 +269,11 @@
var response = await rsp.Content.ReadFromJsonAsync<bool>(); var response = await rsp.Content.ReadFromJsonAsync<bool>();
if (response) if (response)
{ {
ShowMessage(ToastType.Success, "آماده سازی با موفقیت انجام شد"); if(FullInvoice)
ShowMessage(ToastType.Success, "تغییرات با موفقیت انجام شد");
if (!FullInvoice)
{
ShowMessage(ToastType.Light, "در حال ارسال صورتحساب"); ShowMessage(ToastType.Light, "در حال ارسال صورتحساب");
rsp = await hc.Get($"TaxPayer/SendInvoice/{InvoiceID}"); rsp = await hc.Get($"TaxPayer/SendInvoice/{InvoiceID}");
if (rsp.IsSuccessStatusCode) if (rsp.IsSuccessStatusCode)
@@ -266,8 +295,13 @@
ShowMessage(ToastType.Danger, request[0]); ShowMessage(ToastType.Danger, request[0]);
} }
} }
}
else else
{ {
if (FullInvoice)
ShowMessage(ToastType.Danger, "خطای در ذخیره سازی اطلاعات رخ داده");
else
ShowMessage(ToastType.Danger, "خطای در آماده سازی اطلاعات رخ داده"); ShowMessage(ToastType.Danger, "خطای در آماده سازی اطلاعات رخ داده");
} }
} }