112 lines
5.4 KiB
Plaintext
112 lines
5.4 KiB
Plaintext
@model CustomerAddressListModel
|
|
@{
|
|
Layout = "_ColumnsTwo";
|
|
|
|
//title
|
|
NopHtml.AddTitleParts(T("PageTitle.Account").Text);
|
|
//page class
|
|
NopHtml.AppendPageCssClassParts("html-account-page");
|
|
NopHtml.AppendPageCssClassParts("html-address-list-page");
|
|
}
|
|
@section left
|
|
{
|
|
@await Component.InvokeAsync(typeof(CustomerNavigationViewComponent), new { selectedTabId = CustomerNavigationEnum.Addresses })
|
|
}
|
|
<div class="page account-page address-list-page">
|
|
<div class="page-title">
|
|
<h1>@T("Account.MyAccount") - @T("Account.CustomerAddresses")</h1>
|
|
</div>
|
|
<div class="page-body">
|
|
@await Component.InvokeAsync(typeof(WidgetViewComponent), new { widgetZone = PublicWidgetZones.CustomerAddressesTop, additionalData = Model })
|
|
@if (Model.Addresses.Count > 0)
|
|
{
|
|
<div class="address-list">
|
|
@for (var i = 0; i < Model.Addresses.Count; i++)
|
|
{
|
|
var address = Model.Addresses[i];
|
|
<div class="section address-item">
|
|
<div class="title">
|
|
<strong>@address.FirstName @address.LastName</strong>
|
|
</div>
|
|
<ul class="info">
|
|
<li class="name">
|
|
@address.FirstName @address.LastName
|
|
</li>
|
|
<li class="email">
|
|
<label>@T("Address.Fields.Email"):</label>
|
|
@address.Email
|
|
</li>
|
|
@if (address.PhoneEnabled)
|
|
{
|
|
<li class="phone">
|
|
<label>@T("Address.Fields.PhoneNumber"):</label>
|
|
@address.PhoneNumber
|
|
</li>
|
|
}
|
|
@if (address.FaxEnabled)
|
|
{
|
|
<li class="fax">
|
|
<label>@T("Address.Fields.FaxNumber"):</label>
|
|
@address.FaxNumber
|
|
</li>
|
|
}
|
|
@if (address.CompanyEnabled && !string.IsNullOrEmpty(address.Company))
|
|
{
|
|
<li class="company">@address.Company</li>
|
|
}
|
|
@foreach(var item in address.AddressFields)
|
|
{
|
|
<li class=@item.Key.ToString().ToLower()>@item.Value</li>
|
|
}
|
|
@if (!string.IsNullOrEmpty(address.FormattedCustomAddressAttributes))
|
|
{
|
|
<li class="custom-attributes-view">
|
|
@Html.Raw(address.FormattedCustomAddressAttributes)
|
|
</li>
|
|
}
|
|
</ul>
|
|
<div class="buttons">
|
|
<button type="button" class="button-2 edit-address-button" onclick="location.href = '@(Url.RouteUrl("CustomerAddressEdit", new {addressId = address.Id}))'">@T("Common.Edit")</button>
|
|
|
|
<button type="button" class="button-2 delete-address-button" onclick="deletecustomeraddress(@(address.Id))">@T("Common.Delete")</button>
|
|
</div>
|
|
</div>
|
|
}
|
|
</div>
|
|
<script asp-location="Footer">
|
|
function deletecustomeraddress(addressId) {
|
|
if (confirm('@T("Common.AreYouSure")')) {
|
|
var postData = {
|
|
addressId: addressId
|
|
};
|
|
addAntiForgeryToken(postData);
|
|
|
|
$.ajax({
|
|
cache: false,
|
|
type: "POST",
|
|
url: "@Url.RouteUrl("CustomerAddressDelete")",
|
|
data: postData,
|
|
dataType: "json",
|
|
success: function (data, textStatus, jqXHR) {
|
|
location.href = data.redirect;
|
|
},
|
|
error: function (jqXHR, textStatus, errorThrown) {
|
|
alert('Failed to delete');
|
|
}
|
|
});
|
|
}
|
|
}
|
|
</script>
|
|
}
|
|
else
|
|
{
|
|
<div class="no-data">
|
|
@T("Account.CustomerAddresses.NoAddresses")
|
|
</div>
|
|
}
|
|
<div class="add-button">
|
|
<button type="button" class="button-1 add-address-button" onclick="location.href='@Url.RouteUrl("CustomerAddressAdd")'">@T("Common.AddNew")</button>
|
|
</div>
|
|
@await Component.InvokeAsync(typeof(WidgetViewComponent), new { widgetZone = PublicWidgetZones.CustomerAddressesBottom, additionalData = Model })
|
|
</div>
|
|
</div> |