public async Task <IActionResult> UpdateMaritalStatusAsync([FromBody] UpdateMaritalStatusManagementAc updateMaritalStatusManagement)
        {
            if (string.IsNullOrEmpty(updateMaritalStatusManagement.Name.Trim()))
            {
                return(Ok(new SharedLookUpResponse {
                    ErrorType = SharedLookUpResponseType.Name, HasError = true, Message = "Marital status name can't be empty"
                }));
            }
            else if (string.IsNullOrEmpty(updateMaritalStatusManagement.Code.Trim()))
            {
                return(Ok(new SharedLookUpResponse {
                    ErrorType = SharedLookUpResponseType.Code, HasError = true, Message = "Marital status name can't be empty"
                }));
            }
            else
            {
                var loggedInUserInstituteId = await GetUserCurrentSelectedInstituteIdAsync();

                if (await _iMSDbContext.MaritalStatuses.AnyAsync(x => x.Id == updateMaritalStatusManagement.MaritalStatusId && x.InstituteId == loggedInUserInstituteId))
                {
                    return(Ok(await _maritalStatusManagementRepository.UpdateMaritalStatusAsync(updateMaritalStatusManagement, loggedInUserInstituteId)));
                }
                else
                {
                    return(Ok(new SharedLookUpResponse {
                        HasError = true, ErrorType = SharedLookUpResponseType.Code, Message = "Marital status not found"
                    }));
                }
            }
        }
Exemple #2
0
        /// <summary>
        /// Method to update MaritalStatus - SS
        /// </summary>
        /// <param name="updateMaritalStatusManagement">MaritalStatus detail</param>
        /// <param name="instituteId">institute id</param>
        /// <returns>message</returns>
        public async Task <SharedLookUpResponse> UpdateMaritalStatusAsync(UpdateMaritalStatusManagementAc updateMaritalStatusManagement, int instituteId)
        {
            var maritalStatuss = await _iMSDbContext.MaritalStatuses.Where(x => x.InstituteId == instituteId && x.Id != updateMaritalStatusManagement.MaritalStatusId).ToListAsync();

            var isDuplicate = maritalStatuss.Any(x => x.Code.ToLowerInvariant() == updateMaritalStatusManagement.Code.ToLowerInvariant());

            if (isDuplicate)
            {
                return new SharedLookUpResponse()
                       {
                           HasError = true, ErrorType = SharedLookUpResponseType.Code, Message = "Duplicate code of marital status. Please use unique code"
                       }
            }
            ;
            else
            {
                var maritalStatus = await _iMSDbContext.MaritalStatuses.FirstAsync(x => x.Id == updateMaritalStatusManagement.MaritalStatusId);

                maritalStatus.Name        = updateMaritalStatusManagement.Name;
                maritalStatus.Code        = updateMaritalStatusManagement.Code;
                maritalStatus.Description = updateMaritalStatusManagement.Description;
                maritalStatus.Status      = updateMaritalStatusManagement.Status;
                _iMSDbContext.MaritalStatuses.Update(maritalStatus);
                await _iMSDbContext.SaveChangesAsync();

                return(new SharedLookUpResponse()
                {
                    HasError = false, Message = "Marital status updated successfully"
                });
            }
        }