Files
moadiran/TaxPayerFull/CUSComponent/OrderItemNew.razor

300 lines
12 KiB
Plaintext
Raw Normal View History

2024-07-27 23:20:15 +03:30
@using Front.Services
@using Shared.DTOs
@inject Fixedvalues fv;
@inject HttpClientController hc;
<Preload LoadingText="در حال بارگذاری..." />
2024-07-28 17:42:40 +03:30
@* alert *@
<div class="row">
<Alert hidden="@Hidealert" Color="@alertColor" Dismissable="false">
<Icon Name="@alertIconName" class="me-2"></Icon>
@alertMessage
</Alert>
2024-07-27 23:20:15 +03:30
2024-07-28 17:42:40 +03:30
</div>
2024-07-28 15:34:46 +03:30
<div class="row">
<div class="col-md-6">
2024-07-27 23:20:15 +03:30
<Dropdown Color="DropdownColor.Secondary">
2024-07-28 15:34:46 +03:30
<DropdownToggleButton>@orderSelectName</DropdownToggleButton>
2024-07-27 23:20:15 +03:30
<DropdownMenu>
@foreach (var i in orderstype)
{
<DropdownItem @onclick="()=>OnChange(i.ID,i.Title)">@i.Title</DropdownItem>
}
</DropdownMenu>
</Dropdown>
</div>
</div>
2024-07-28 15:34:46 +03:30
<hr class="hr" />
<table class="table table-sm">
<thead>
<tr>
<th style="width:40%" scope="col">سیستم</th>
<th style="width:30%" scope="col">قیمت پایه</th>
<th scope="col">تعداد</th>
</tr>
</thead>
<tbody>
@if (Selected!=null)
{
if (Selected.promotionDetails.Any(w => w.PermissionID == 3))
{
<tr>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 3).Select(s => s.PermissionTitle).FirstOrDefault()</td>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 3).Select(s => s.APrice).FirstOrDefault().ToString("N0") ريال</td>
<td>
@if (Selected.ID < 0)
{
<InputNumber @bind-Value="values[0]" @bind-Value:after="OnInput" type="text" class="form-control" id="inputfa" style="text-align:center;" placeholder="تعداد" />
}
else
{
<input value="@Selected.promotionDetails.Where(w => w.PermissionID == 3).Select(s => s.CreditAmount).FirstOrDefault()" style="text-align:center;" class="form-control" type="text" readonly>
}
</td>
</tr>
}
if (Selected.promotionDetails.Any(w => w.PermissionID == 4))
{
<tr>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 4).Select(s => s.PermissionTitle).FirstOrDefault()</td>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 4).Select(s => s.APrice).FirstOrDefault().ToString("N0") ريال</td>
<td>
@if (Selected.ID < 0)
{
<InputNumber @bind-Value="values[1]" @bind-Value:after="OnInput" type="text" class="form-control" id="inputcod" style="text-align:center;" placeholder="تعداد" />
}
else
{
<input value="@Selected.promotionDetails.Where(w => w.PermissionID == 4).Select(s => s.CreditAmount).FirstOrDefault()" style="text-align:center;" class="form-control" type="text" readonly>
}
</td>
</tr>
}
if (Selected.promotionDetails.Any(w => w.PermissionID == 5))
{
<tr>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 5).Select(s => s.PermissionTitle).FirstOrDefault()</td>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 5).Select(s => s.APrice).FirstOrDefault().ToString("N0") ريال</td>
<td>
@if (Selected.ID < 0)
{
<InputNumber @bind-Value="values[2]" @bind-Value:after="OnInput" type="text" class="form-control" id="inputcus" style="text-align:center;" placeholder="تعداد" />
}
else
{
<input value="@Selected.promotionDetails.Where(w => w.PermissionID == 5).Select(s => s.CreditAmount).FirstOrDefault()" style="text-align:center;" class="form-control" type="text" readonly>
}
</td>
</tr>
}
if (Selected.promotionDetails.Any(w => w.PermissionID == 16))
{
<tr>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 16).Select(s => s.PermissionTitle).FirstOrDefault()</td>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 16).Select(s => s.APrice).FirstOrDefault().ToString("N0") ريال</td>
<td>
@if (Selected.ID < 0)
{
<InputNumber @bind-Value="values[3]" @bind-Value:after="OnInput" type="text" class="form-control" id="inputax" style="text-align:center;" placeholder="تعداد" />
}
else
{
<input value="@Selected.promotionDetails.Where(w => w.PermissionID == 16).Select(s => s.CreditAmount).FirstOrDefault()" style="text-align:center;" class="form-control" type="text" readonly>
}
</td>
</tr>
}
2025-01-25 23:46:57 +03:30
if (Selected.promotionDetails.Any(w => w.PermissionID == 18))
{
<tr>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 18).Select(s => s.PermissionTitle).FirstOrDefault()</td>
<td>@Selected.promotionDetails.Where(w => w.PermissionID == 18).Select(s => s.APrice).FirstOrDefault().ToString("N0") ريال</td>
<td>
@if (Selected.ID < 0)
{
<InputNumber @bind-Value="values[4]" @bind-Value:after="OnInput" type="text" class="form-control" id="inputax" style="text-align:center;" placeholder="تعداد" />
}
else
{
<input value="@Selected.promotionDetails.Where(w => w.PermissionID == 18).Select(s => s.CreditAmount).FirstOrDefault()" style="text-align:center;" class="form-control" type="text" readonly>
}
</td>
</tr>
}
2024-07-28 15:34:46 +03:30
}
</tbody>
</table>
<div class="row">
2024-10-15 14:19:54 +03:30
<div class="col-md-6">
2024-07-28 15:34:46 +03:30
<span class="text-muted fw-light">قیمت نهایی :</span> @TotalPrice.ToString("N0") ريال
</div>
2024-07-27 23:20:15 +03:30
<div class="col-md-4">
2024-10-15 14:19:54 +03:30
<Button Disabled="SpinnerVisible" Color="ButtonColor.Primary" @onclick="NewOrder">ثبت</Button>
</div>
<div class="col-md-2">
<Spinner Visible="SpinnerVisible" Color="SpinnerColor.Primary" />
2024-07-27 23:20:15 +03:30
</div>
</div>
@code {
2024-10-15 14:19:54 +03:30
public bool SpinnerVisible { get; set; } = false;
2024-07-28 17:42:40 +03:30
#region Alert
// alert
AlertColor alertColor = AlertColor.Primary;
IconName alertIconName = IconName.CheckCircleFill;
bool Hidealert = true;
string alertMessage = "";
#endregion
2024-07-28 15:34:46 +03:30
string orderSelectName = "نوع سفارش";
2024-07-27 23:20:15 +03:30
int orderSelectID = 0;
[Inject] protected PreloadService PreloadService { get; set; } = default!;
[Parameter] public EventCallback<OrderDto> OnMultipleOfThree { get; set; }
2024-07-28 15:34:46 +03:30
List<IdName<int>> orderstype = new List<IdName<int>>();
public List<PromotionDto> Promotions { get; set; } = new();
public PromotionDto? Selected { get; set; } = null;
// invoice cod cus tax
2025-01-25 23:46:57 +03:30
int[] values = { 0,0,0,0,0};
2024-07-28 15:34:46 +03:30
decimal TotalPrice = 0;
2024-07-27 23:20:15 +03:30
}
@functions {
2024-07-28 17:42:40 +03:30
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;
}
2024-07-27 23:20:15 +03:30
protected override async Task OnParametersSetAsync()
{
2024-07-28 22:58:39 +03:30
orderSelectName = "نوع سفارش";
Selected = null;
2025-01-25 23:46:57 +03:30
values =new int[] { 0,0,0,0,0};
2024-07-28 22:58:39 +03:30
TotalPrice = 0;
2024-08-01 18:04:05 +03:30
Promotions = await fv.GetPromotion();
2024-07-28 22:58:39 +03:30
orderstype = new List<IdName<int>>();
2024-07-27 23:20:15 +03:30
orderstype.AddRange(Promotions.Select(s => new IdName<int>
2024-07-28 15:34:46 +03:30
{ ID = s.ID, Title = s.Name }).ToList());
2024-07-27 23:20:15 +03:30
await base.OnParametersSetAsync();
}
2024-07-28 15:34:46 +03:30
public async Task OnChange(int ID, string Title)
2024-07-27 23:20:15 +03:30
{
orderSelectID = ID;
orderSelectName = Title;
2024-07-28 15:34:46 +03:30
2024-07-28 22:58:39 +03:30
2024-07-28 15:34:46 +03:30
Selected = Promotions.Where(w => w.ID == ID).First();
2024-07-28 22:58:39 +03:30
if (ID > 0)
TotalPrice = Selected.TotalPrice;
2024-07-28 15:34:46 +03:30
}
private async Task OnInput()
{
if (Selected != null)
{
var itemFac= Selected.promotionDetails.Where(w => w.PermissionID == 3).FirstOrDefault();
if (itemFac!=null)
2024-07-28 17:31:40 +03:30
itemFac.CreditAmount = values[0];
2024-07-28 15:34:46 +03:30
var itemcod = Selected.promotionDetails.Where(w => w.PermissionID == 4).FirstOrDefault();
if (itemcod != null)
itemcod.CreditAmount = values[1];
var itemcus = Selected.promotionDetails.Where(w => w.PermissionID == 5).FirstOrDefault();
if (itemcus != null)
itemcus.CreditAmount = values[2];
var itemtax = Selected.promotionDetails.Where(w => w.PermissionID == 16).FirstOrDefault();
if (itemtax != null)
itemtax.CreditAmount = values[3];
2025-01-25 23:46:57 +03:30
var itemwarehouse = Selected.promotionDetails.Where(w => w.PermissionID == 18).FirstOrDefault();
if (itemwarehouse != null)
itemwarehouse.CreditAmount = values[4];
2024-07-28 15:34:46 +03:30
TotalPrice = Selected.TotalPrice;
}
2024-07-28 17:31:40 +03:30
2024-07-28 15:34:46 +03:30
}
public async Task NewOrder()
{
2024-10-15 14:19:54 +03:30
SpinnerVisible = true;
2024-07-28 22:58:39 +03:30
if (Selected != null)
{
2025-01-25 23:46:57 +03:30
if (Selected.ID < 0 && (values[0] < 0 || values[1] < 0 || values[2] < 0 || values[3] < 0 || values[4] < 0)) return;
if (Selected.ID < 0 && values[0] == 0 && values[1] == 0 && values[2] == 0 && values[3] == 0 && values[4] == 0) return;
2024-07-28 22:58:39 +03:30
2024-07-28 17:31:40 +03:30
//---------
2024-07-28 22:58:39 +03:30
var itemFac = Selected.promotionDetails.Where(w => w.PermissionID == 3).FirstOrDefault();
if (itemFac != null)
itemFac.CreditAmount = values[0];
var itemcod = Selected.promotionDetails.Where(w => w.PermissionID == 4).FirstOrDefault();
if (itemcod != null)
itemcod.CreditAmount = values[1];
var itemcus = Selected.promotionDetails.Where(w => w.PermissionID == 5).FirstOrDefault();
if (itemcus != null)
itemcus.CreditAmount = values[2];
var itemtax = Selected.promotionDetails.Where(w => w.PermissionID == 16).FirstOrDefault();
if (itemtax != null)
itemtax.CreditAmount = values[3];
2025-01-25 23:46:57 +03:30
var itemwarehouse = Selected.promotionDetails.Where(w => w.PermissionID == 18).FirstOrDefault();
if (itemwarehouse != null)
itemwarehouse.CreditAmount = values[4];
2024-07-28 22:58:39 +03:30
//---------
var rsp = await hc.Post<PromotionDto>($"Orders/AddOrder", Selected);
if (rsp.IsSuccessStatusCode)
{
var newidorder = await rsp.Content.ReadFromJsonAsync<OrderDto>();
await OnMultipleOfThree.InvokeAsync(newidorder);
}
else if (rsp.StatusCode == System.Net.HttpStatusCode.NotFound)
{
ShowDangerAlert("مرجع یافت نشد یافت نشد");
}
else
{
var request = await rsp.Content.ReadFromJsonAsync<List<string>>();
ShowDangerAlert(request[0]);
}
2024-07-28 17:31:40 +03:30
}
2024-10-15 14:19:54 +03:30
SpinnerVisible = false;
2024-07-28 17:31:40 +03:30
2024-07-27 23:20:15 +03:30
}
}