This commit is contained in:
mmrbnjd
2024-09-08 17:23:33 +03:30
parent 745412ee56
commit b81c950c39
9 changed files with 468 additions and 126 deletions

View File

@@ -1,81 +1,331 @@
@using Shared.DTOs
@using Front.Services
@using Shared.DTOs
@inject Fixedvalues fv;
@inject HttpClientController hc;
<Grid @ref="grid"
TItem="InvoicePaymentDTO"
Class="table table-hover table-bordered table-striped mt-3"
Data="payments">
Data="invoice.payments"
OnRowClick="OnRowClick">
<GridColumns>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="شناسه" PropertyName="ID">
@context.ID
</GridColumn>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="شماره سوییچ پرداخت" PropertyName="iinn">
<GridColumn TItem="InvoicePaymentDTO" TextAlignment="Alignment.Center" HeaderTextAlignment="Alignment.Center" HeaderText="شماره سوییچ پرداخت" PropertyName="iinn">
@context.iinn
</GridColumn>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="شماره پذیرنده فروشگاهی" PropertyName="acn">
<GridColumn TItem="InvoicePaymentDTO" TextAlignment="Alignment.Center" HeaderTextAlignment="Alignment.Center" HeaderText="شماره پذیرنده فروشگاهی" PropertyName="acn">
@context.acn
</GridColumn>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="شماره پایانه" PropertyName="trmn">
<GridColumn TItem="InvoicePaymentDTO" TextAlignment="Alignment.Center" HeaderTextAlignment="Alignment.Center" HeaderText="شماره پایانه" PropertyName="trmn">
@context.trmn
</GridColumn>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="روش پرداخت" PropertyName="pmt">
@context.pmt
<GridColumn TItem="InvoicePaymentDTO" TextAlignment="Alignment.Center" HeaderTextAlignment="Alignment.Center" HeaderText="روش پرداخت" PropertyName="paymentMethod">
@context.paymentMethod
</GridColumn>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="شماره پیگیری/شماره مرجع" PropertyName="trn">
<GridColumn TItem="InvoicePaymentDTO" TextAlignment="Alignment.Center" HeaderTextAlignment="Alignment.Center" HeaderText="شماره پیگیری/شماره مرجع" PropertyName="trn">
@context.trn
</GridColumn>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="شماره کارت پرداخت کننده" PropertyName="pcn">
<GridColumn TItem="InvoicePaymentDTO" TextAlignment="Alignment.Center" HeaderTextAlignment="Alignment.Center" HeaderText="شماره کارت" PropertyName="pcn">
@context.pcn
</GridColumn>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="شماره/شناسه ملی/کد فراگیر اتباع غیر ایرانی پرداخت کننده" PropertyName="pid">
<GridColumn TItem="InvoicePaymentDTO" TextAlignment="Alignment.Center" HeaderTextAlignment="Alignment.Center" HeaderText="شماره/شناسه ملی/کد فراگیر اتباع غیر ایرانی" PropertyName="pid">
@context.pid
</GridColumn>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="تاریخ" PropertyName="PaymentDateTime">
<GridColumn TItem="InvoicePaymentDTO" TextAlignment="Alignment.Center" HeaderTextAlignment="Alignment.Center" HeaderText="تاریخ" PropertyName="PaymentDateTime">
@context.PaymentDateTime
</GridColumn>
<GridColumn TItem="InvoicePaymentDTO" HeaderText="مبلغ" PropertyName="pv">
<GridColumn TItem="InvoicePaymentDTO" TextAlignment="Alignment.Center" HeaderTextAlignment="Alignment.Center" HeaderText="مبلغ" PropertyName="pv">
@context.pv??.ToString("N0")
</GridColumn>
</GridColumns>
</Grid>
<div class="row g-3">
<div class="form-group col-md-1">
@if (add)
{
<label class="col-sm-6 col-form-label">جدید</label>
}
else
{
<label class="col-sm-6 col-form-label">اطلاعات پرداخت</label>
}
@code {
[Parameter] public ICollection<InvoicePaymentDTO> payments { get; set; }
Grid<InvoicePaymentDTO> grid = default!;
</div>
<div class="form-group col-md-11">
<hr class="hr" />
</div>
</div>
<div class="row g-3">
<div class="form-group col-md-4">
<label class="col-sm-6 col-form-label">شماره سوییچ پرداخت</label>
<InputText onkeypress="return event.charCode &gt;= 48 &amp;&amp; event.charCode &lt;= 57" style="text-align: center" maxlength="9" class="form-control" @bind-Value="item.iinn" Placeholder="شماره سوییچ پرداخت" />
</div>
<div class="form-group col-md-4">
<label class="col-sm-6 col-form-label">شماره پذیرنده فروشگاهی</label>
<InputText onkeypress="return event.charCode &gt;= 48 &amp;&amp; event.charCode &lt;= 57" style="text-align: center" maxlength="14" type="text" class="form-control" @bind-Value="item.acn" Placeholder="شماره پذیرنده فروشگاهی" />
</div>
<div class="form-group col-md-4">
<label class="col-sm-6 col-form-label">شماره پایانه</label>
<InputText onkeypress="return event.charCode &gt;= 48 &amp;&amp; event.charCode &lt;= 57" style="text-align: center" maxlength="8" type="text" class="form-control" @bind-Value="item.trmn" Placeholder="شماره پایانه" />
</div>
</div>
<div class="row g-3">
<div class="form-group col-md-4">
<label class="col-sm-4 col-form-label" for="inputinvoicepmt">روش پرداخت</label>
<select @bind="item.pmt" class="form-control" aria-label="Default select example" id="inputinvoicepmt">
@if (!item.pmt.HasValue)
{
<option value="0" style="color: #b5b5b5" selected>انتخاب کنید...</option>
}
else
{
<option value="0" style="color: #b5b5b5">انتخاب کنید...</option>
}
protected override void OnInitialized()
@if (pmts != null)
{
foreach (var _item in pmts)
{
if (item.pmt == Convert.ToInt32(_item.ID))
{
<option value="@_item.ID" selected>@_item.Title</option>
}
else
{
<option value="@_item.ID">@_item.Title</option>
}
}
}
</select>
</div>
<div class="form-group col-md-4">
<label class="col-sm-6 col-form-label">شماره پیگیری/شماره مرجع</label>
<InputText onkeypress="return event.charCode &gt;= 48 &amp;&amp; event.charCode &lt;= 57" style="text-align: center" maxlength="14" type="text" class="form-control" @bind-Value="item.trn" Placeholder="شماره پیگیری/شماره مرجع" />
</div>
<div class="form-group col-md-4">
<label class="col-sm-6 col-form-label">شماره کارت</label>
<InputText onkeypress="return event.charCode &gt;= 48 &amp;&amp; event.charCode &lt;= 57" style="text-align: center" maxlength="16" type="text" class="form-control" @bind-Value="item.pcn" Placeholder="شماره کارت" />
</div>
</div>
<div class="row g-3">
<div class="form-group col-md-4">
<label class="col-sm-10 col-form-label">شماره/شناسه ملی/کد فراگیر اتباع غیر ایرانی</label>
<InputText onkeypress="return event.charCode &gt;= 48 &amp;&amp; event.charCode &lt;= 57" style="text-align: center" maxlength="12" type="text" class="form-control" @bind-Value="item.pid" Placeholder="شماره/شناسه ملی/کد فراگیر اتباع غیر ایرانی" />
</div>
<div class="form-group col-md-4">
<label class="col-sm-6 col-form-label">تاریخ</label>
<InputText type="text" style="text-align: center" class="form-control" @bind-Value="item.PaymentDateTime" Placeholder="تاریخ" />
</div>
<div class="form-group col-md-4">
<label class="col-sm-6 col-form-label">مبلغ</label>
<CurrencyInput TValue="long?" @bind-Value="item.pv" Locale="fa-Ir" Placeholder="مبلغ" style="text-align: center" />
</div>
</div>
<div class="row g-3">
@if (add)
{
// payments = new List<InvoicePaymentDTO>();
<div class="form-group col-md-2">
<Button class="mt-3" Color="ButtonColor.Success" @onclick="AddPay" Type="ButtonType.Button">
جدید
</Button>
</div>
}
else
{
<div class="form-group col-md-2">
<Button class="mt-3" Color="ButtonColor.Info" @onclick="AddPay" Type="ButtonType.Button">
ویرایش
</Button>
</div>
<div class="form-group col-md-2">
<Button class="mt-3" Color="ButtonColor.Danger" @onclick="AddPay" Type="ButtonType.Button">
حذف
</Button>
</div>
<div class="form-group col-md-2">
<Button class="mt-3" Color="ButtonColor.Primary" @onclick="cancell" Type="ButtonType.Button">
انصزاف
</Button>
</div>
}
}
// private async Task AddEmployee()
// {
// // for the same employees collection, we are adding an object
// // explicit grid refresh required
// employees!.Add(CreateEmployee());
// await grid.RefreshDataAsync();
// }
</div>
// private void AddEmployee2()
// {
// // creates a shallow copy
// var emps = employees!.GetRange(0, employees.Count);
// emps.Add(CreateEmployee());
// // now employees variable has a new reference. So no need to refresh the grid explicitly
// // explicit grid refresh is not required
// employees = emps;
// }
@* alert *@
<div class="row">
<Alert hidden="@Hidealert" Color="@alertColor" Dismissable="false">
<Icon Name="@alertIconName" class="me-2"></Icon>
@alertMessage
</Alert>
// private Employee1 CreateEmployee()
// {
// var emp = new Employee1();
// emp.Id = employees!.Max(x => x.Id) + 1;
// emp.Name = $"Employee {emp.Id}";
// emp.Designation = $"QA Engineer {emp.Id}";
// emp.DOJ = new DateOnly(new Random().Next(1970, 2000), new Random().Next(1, 12), new Random().Next(1, 25));
// emp.IsActive = true;
// return emp;
// }
</div>
@code {
bool add = true;
[Parameter] public InvoiceDTO invoice { get; set; }
Grid<InvoicePaymentDTO> grid = default!;
InvoicePaymentDTO item;
List<IdName<string>> pmts;
// alert
AlertColor alertColor = AlertColor.Primary;
IconName alertIconName = IconName.CheckCircleFill;
bool Hidealert = true;
string alertMessage = "";
protected override async Task OnParametersSetAsync()
{
item = new InvoicePaymentDTO();
pmts = await fv.GetPaymentMethods();
await base.OnParametersSetAsync();
}
}
@functions {
private async Task OnRowClick(GridRowEventArgs<InvoicePaymentDTO> args)
{
item = args.Item;
add = false;
}
async Task cancell()
{
add = true;
item = new InvoicePaymentDTO();
}
async Task AddPay()
{
if (await Validation())
{
var rsp = await hc.Post<InvoicePaymentDTO>("InvoicePayment/AddPay", item);
if (rsp.IsSuccessStatusCode)
{
var request = await rsp.Content.ReadFromJsonAsync<InvoicePaymentDTO>();
if (request != null && request.ID.HasValue)
{
invoice.payments.Add(request);
await grid.RefreshDataAsync();
item = new InvoicePaymentDTO();
}
else ShowDangerAlert("خطایی در اجرای عملیات رخ داده");
}
else
{
var request = await rsp.Content.ReadFromJsonAsync<List<string>>();
ShowDangerAlert(request[0]);
}
}
}
async Task UpdatePay()
{
if (await Validation())
{
var rsp = await hc.Put<InvoicePaymentDTO>("InvoicePayment/UpdatePay", item);
if (rsp.IsSuccessStatusCode)
{
var request = await rsp.Content.ReadFromJsonAsync<InvoicePaymentDTO>();
if (request != null && request.ID.HasValue)
{
invoice.payments.Add(request);
await grid.RefreshDataAsync();
item = new InvoicePaymentDTO();
}
else ShowDangerAlert("خطایی در اجرای عملیات رخ داده");
}
else
{
var request = await rsp.Content.ReadFromJsonAsync<List<string>>();
ShowDangerAlert(request[0]);
}
}
}
async Task DeletePay()
{
if (item.ID.HasValue)
{
var rsp = await hc.Delete($"InvoicePayment/DeletePay/{item.ID.Value}");
if (rsp.IsSuccessStatusCode)
{
var request = await rsp.Content.ReadFromJsonAsync<bool>();
if (request)
{
invoice.payments.Add(item);
await grid.RefreshDataAsync();
item = new InvoicePaymentDTO();
}
else ShowDangerAlert("خطایی در اجرای عملیات رخ داده");
}
else
{
var request = await rsp.Content.ReadFromJsonAsync<List<string>>();
ShowDangerAlert(request[0]);
}
}
}
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;
}
async Task<bool> Validation()
{
if (invoice.tbill < invoice.payments.Sum(s => s.pv) + item.pv)
{
ShowDangerAlert("مجموع مبلغ پرداختی نمی تواند از مجموع صورتحساب بیشتر باشد.");
return false;
}
if (item.pmt.HasValue && item.pmt.Value > 0 && item.pmt.Value < 9)
{
if (string.IsNullOrEmpty(item.PaymentDateTime))
{
ShowDangerAlert("تاریخ نمیتواند خالی باشد");
return false;
}
else
{
string paydate = item.PaymentDateTime.Replace("/", "");
if (paydate.Length == 8 && int.TryParse(paydate, out int _paydate))
{
if (Convert.ToInt32(invoice.InvoiceDate.Replace("/", "")) > _paydate)
{
ShowDangerAlert("تاریخ پرداخت نمیتواند از تاریخ صورتحساب عقبتر باشد");
return false;
}
}
else { ShowDangerAlert("تاریخ صحیح نمی باشد"); return false; }
}
}
else { ShowDangerAlert("روش پرداخت مشخص نشده"); return false; }
return true;
}
}