Added empty email address for root users. everything should be functional from here on out.
This commit is contained in:
@@ -151,6 +151,32 @@ namespace CarCareTracker.Controllers
|
|||||||
return Json(false);
|
return Json(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
[HttpPost]
|
||||||
|
public IActionResult UpdateUserAccount(LoginModel userAccount)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var userId = GetUserID();
|
||||||
|
if (userId > 0)
|
||||||
|
{
|
||||||
|
var result = _loginLogic.UpdateUserDetails(userId, userAccount);
|
||||||
|
return Json(result);
|
||||||
|
}
|
||||||
|
return Json(new OperationResponse { Success = false, Message = StaticHelper.GenericErrorMessage});
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_logger.LogError(ex.Message);
|
||||||
|
return Json(new OperationResponse { Success = false, Message = StaticHelper.GenericErrorMessage });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
[HttpGet]
|
||||||
|
public IActionResult GetUserAccountInformationModal()
|
||||||
|
{
|
||||||
|
var emailAddress = User.FindFirstValue(ClaimTypes.Email);
|
||||||
|
var userName = User.Identity.Name;
|
||||||
|
return PartialView("_AccountModal", new UserData() { EmailAddress = emailAddress, UserName = userName });
|
||||||
|
}
|
||||||
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
|
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
|
||||||
public IActionResult Error()
|
public IActionResult Error()
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -246,7 +246,8 @@ namespace CarCareTracker.Logic
|
|||||||
Id = -1,
|
Id = -1,
|
||||||
UserName = credentials.UserName,
|
UserName = credentials.UserName,
|
||||||
IsAdmin = true,
|
IsAdmin = true,
|
||||||
IsRootUser = true
|
IsRootUser = true,
|
||||||
|
EmailAddress = string.Empty
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -84,6 +84,12 @@
|
|||||||
<a class="dropdown-item" href="/Admin"><i class="bi bi-people me-2"></i>@translator.Translate(userLanguage,"Admin Panel")</a>
|
<a class="dropdown-item" href="/Admin"><i class="bi bi-people me-2"></i>@translator.Translate(userLanguage,"Admin Panel")</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
|
@if (!User.IsInRole(nameof(UserData.IsRootUser)))
|
||||||
|
{
|
||||||
|
<li>
|
||||||
|
<button class="dropdown-item" onclick="showAccountInformationModal()"><i class="bi bi-person-gear me-2"></i>@translator.Translate(userLanguage, "Profile")</button>
|
||||||
|
</li>
|
||||||
|
}
|
||||||
<li>
|
<li>
|
||||||
<button class="dropdown-item" onclick="performLogOut()"><i class="bi bi-box-arrow-right me-2"></i>@translator.Translate(userLanguage,"Logout")</button>
|
<button class="dropdown-item" onclick="performLogOut()"><i class="bi bi-box-arrow-right me-2"></i>@translator.Translate(userLanguage,"Logout")</button>
|
||||||
</li>
|
</li>
|
||||||
@@ -118,6 +124,12 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="modal fade" id="accountInformationModal" tabindex="-1" role="dialog">
|
||||||
|
<div class="modal-dialog" role="document">
|
||||||
|
<div class="modal-content" id="accountInformationModalContent">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<script>
|
<script>
|
||||||
loadGarage();
|
loadGarage();
|
||||||
bindWindowResize();
|
bindWindowResize();
|
||||||
|
|||||||
35
Views/Home/_AccountModal.cshtml
Normal file
35
Views/Home/_AccountModal.cshtml
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
@using CarCareTracker.Helper
|
||||||
|
@inject IConfigHelper config
|
||||||
|
@inject ITranslationHelper translator
|
||||||
|
@model UserData
|
||||||
|
@{
|
||||||
|
var userConfig = config.GetUserConfig(User);
|
||||||
|
var userLanguage = userConfig.UserLanguage;
|
||||||
|
}
|
||||||
|
<div class="modal-header">
|
||||||
|
<h5 class="modal-title" id="addVehicleModalLabel">@translator.Translate(userLanguage, "Update Profile")</h5>
|
||||||
|
<button type="button" class="btn-close" onclick="hideAccountInformationModal()" aria-label="Close"></button>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<form class="form-inline">
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="inputUsername">@translator.Translate(userLanguage, "Username")</label>
|
||||||
|
<input type="text" id="inputUsername" class="form-control" placeholder="@translator.Translate(userLanguage, "Account Username")" value="@Model.UserName">
|
||||||
|
<label for="inputEmail">@translator.Translate(userLanguage, "Email Address")</label>
|
||||||
|
<input type="text" id="inputEmail" class="form-control" placeholder="@translator.Translate(userLanguage, "Email Address")" value="@Model.EmailAddress">
|
||||||
|
<label for="inputPassword">@translator.Translate(userLanguage, "New Password")</label>
|
||||||
|
<input type="password" id="inputPassword" class="form-control" placeholder="@translator.Translate(userLanguage, "New Password")" value="">
|
||||||
|
<label for="inputToken">@translator.Translate(userLanguage, "Token")</label>
|
||||||
|
<input type="text" id="inputToken" class="form-control" placeholder="@translator.Translate(userLanguage, "Token")" value="">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-12">
|
||||||
|
<a onclick="generateTokenForUser()" class="btn btn-link">@translator.Translate(userLanguage, "Send Token")</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button type="button" class="btn btn-secondary" onclick="hideAccountInformationModal()">@translator.Translate(userLanguage, "Cancel")</button>
|
||||||
|
<button type="button" onclick="validateAndSaveUserAccount()" class="btn btn-primary">@translator.Translate(userLanguage, "Update")</button>
|
||||||
|
</div>
|
||||||
@@ -351,3 +351,62 @@ function copyContributors(sourceVehicleId, destVehicleId) {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function showAccountInformationModal() {
|
||||||
|
$.get('/Home/GetUserAccountInformationModal', function (data) {
|
||||||
|
$('#accountInformationModalContent').html(data);
|
||||||
|
$('#accountInformationModal').modal('show');
|
||||||
|
})
|
||||||
|
}
|
||||||
|
function hideAccountInformationModal() {
|
||||||
|
$('#accountInformationModal').modal('hide');
|
||||||
|
}
|
||||||
|
function validateAndSaveUserAccount() {
|
||||||
|
var hasError = false;
|
||||||
|
if ($('#inputUsername').val().trim() == '') {
|
||||||
|
$('#inputUsername').addClass("is-invalid");
|
||||||
|
hasError = true;
|
||||||
|
} else {
|
||||||
|
$('#inputUsername').removeClass("is-invalid");
|
||||||
|
}
|
||||||
|
if ($('#inputEmail').val().trim() == '') {
|
||||||
|
$('#inputEmail').addClass("is-invalid");
|
||||||
|
hasError = true;
|
||||||
|
} else {
|
||||||
|
$('#inputEmail').removeClass("is-invalid");
|
||||||
|
}
|
||||||
|
if ($('#inputToken').val().trim() == '') {
|
||||||
|
$('#inputToken').addClass("is-invalid");
|
||||||
|
hasError = true;
|
||||||
|
} else {
|
||||||
|
$('#inputToken').removeClass("is-invalid");
|
||||||
|
}
|
||||||
|
if (hasError) {
|
||||||
|
errorToast("Please check the form data");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var userAccountInfo = {
|
||||||
|
userName: $('#inputUsername').val(),
|
||||||
|
password: $('#inputPassword').val(),
|
||||||
|
emailAddress: $('#inputEmail').val(),
|
||||||
|
token: $('#inputToken').val()
|
||||||
|
}
|
||||||
|
$.post('/Home/UpdateUserAccount', { userAccount: userAccountInfo }, function (data) {
|
||||||
|
if (data.success) {
|
||||||
|
//hide modal
|
||||||
|
hideAccountInformationModal();
|
||||||
|
successToast('Profile Updated')
|
||||||
|
} else {
|
||||||
|
errorToast(data.message);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function generateTokenForUser() {
|
||||||
|
$.post('/Home/GenerateTokenForUser', function (data) {
|
||||||
|
if (data) {
|
||||||
|
successToast('Token sent');
|
||||||
|
} else {
|
||||||
|
errorToast(genericErrorMessage())
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user