Вы должны добавить свойства для Location
и Instagram
в IndexModel
.
Обновить InputModel в Areas/Identity/Pages/Account/Manage/Index.cshtml.cs
:
public class InputModel
{
[Phone]
[Display(Name = "Phone number")]
public string PhoneNumber { get; set; }
public string Instagram { get; set; }
public string Location { get; set; }
}
Обновить LoadAsync
метод загрузки / показывает свойства:
private async Task LoadAsync(ApplicationUser user)
{
var userName = await _userManager.GetUserNameAsync(user);
var phoneNumber = await _userManager.GetPhoneNumberAsync(user);
Username = userName;
Input = new InputModel
{
PhoneNumber = phoneNumber,
Instagram=user.Instagram,
Location = user.Location
};
}
Обновить OnPostAsync
метод для обновления Location
и Instagram
свойства:
public async Task<IActionResult> OnPostAsync()
{
var user = await _userManager.GetUserAsync(User);
if (user == null)
{
return NotFound($"Unable to load user with ID '{_userManager.GetUserId(User)}'.");
}
if (!ModelState.IsValid)
{
await LoadAsync(user);
return Page();
}
var phoneNumber = await _userManager.GetPhoneNumberAsync(user);
if (Input.PhoneNumber != phoneNumber)
{
var setPhoneResult = await _userManager.SetPhoneNumberAsync(user, Input.PhoneNumber);
if (!setPhoneResult.Succeeded)
{
var userId = await _userManager.GetUserIdAsync(user);
throw new InvalidOperationException($"Unexpected error occurred setting phone number for user with ID '{userId}'.");
}
}
if (Input.Instagram != user.Instagram)
{
user.Instagram = Input.Instagram;
}
if (Input.Location != user.Location)
{
user.Location = Input.Location;
}
await _userManager.UpdateAsync(user);
await _signInManager.RefreshSignInAsync(user);
StatusMessage = "Your profile has been updated";
return RedirectToPage();
}
Наконец, измените Index.cs html чтобы включить два свойства:
<div class="form-group">
<label asp-for="Input.Location"></label>
<input asp-for="Input.Location" class="form-control" />
</div>
<div class="form-group">
<label asp-for="Input.Instagram"></label>
<input asp-for="Input.Instagram" class="form-control" />
</div>
Вы также можете нажать здесь для получения более подробной информации.