public async Task <ActionResult> PatientQuestionnaireResults(int id, string email) { var userAnswers = await _userAnswerRepo.GetUserAnswersByUserEmail(email); var answersToSelectedQuestionnaire = userAnswers.Where(answer => _questionRepo.GetById(answer.QuestionId).Result.QuestionnaireId == id).ToList(); var user = await _userManager.FindByEmailAsync(email); var model = new ResultViewModel { NumberOfSolvedQuestionnaires = 0, PatientEmail = email, FirstName = user.FirstName, LastName = user.LastName, PESEL = user.PESEL }; if (answersToSelectedQuestionnaire.Count == 0) { return(View(model)); } var questionnaireAnswered = await _userQuestionnaireAnswerRepo.GetByUserEmailAndQuestionnaireId(email, id); var questionnaireAnswerDetails = new List <QuestionnaireAnswerDetails>(); foreach (var questionnaireAnswer in questionnaireAnswered) { var questionnaireDetails = new QuestionnaireAnswerDetails { AnswerDate = questionnaireAnswer.AnswerDate, AnswerCount = 0, AnswerSum = 0 }; foreach (var answer in answersToSelectedQuestionnaire.Where(answer => answer.UserQuestionnaireAnswerId == questionnaireAnswer.Id)) { questionnaireDetails.AnswerCount++; questionnaireDetails.AnswerSum += answer.Value; } questionnaireAnswerDetails.Add(questionnaireDetails); } questionnaireAnswerDetails = questionnaireAnswerDetails.Where(q => q.AnswerDate.HasValue).OrderBy(q => q.AnswerDate.Value).ToList(); var averageScorePerQuestionnaire = questionnaireAnswerDetails.Select(answerDetail => answerDetail.GetAverageScore()).ToList(); model.AverageQuestionnaireScore = averageScorePerQuestionnaire.ToArray(); model.LastQuestionnaireDate = questionnaireAnswerDetails.LastOrDefault().AnswerDate; model.NumberOfSolvedQuestionnaires = questionnaireAnswerDetails.Count; model.QuestionnaireName = (await _questionnaireRepo.GetById(id)).Name; model.StudyStart = questionnaireAnswerDetails.FirstOrDefault().AnswerDate; return(View(model)); }
public async Task <ActionResult> RemoveQuestionnaireFromPatient(int id, string email) { var patientQuestionnaire = await _patientQuestionnaireRepo.GetByIdAndUserEmail(id, email); await _patientQuestionnaireRepo.Delete(patientQuestionnaire); var userAnswers = await _userAnswerRepo.GetUserAnswersByUserEmail(email); var answersToSelectedQuestionnaire = userAnswers.Where(answer => _questionRepo.GetById(answer.QuestionId).Result.QuestionnaireId == id).ToList(); var questionnaireAnswered = _userQuestionnaireAnswerRepo.GetByUserEmailAndQuestionnaireId(email, id).Result; foreach (var userAnswer in answersToSelectedQuestionnaire) { await _userAnswerRepo.Delete(userAnswer); } foreach (var questionnaire in questionnaireAnswered) { await _userQuestionnaireAnswerRepo.Delete(questionnaire); } return(RedirectToAction("ManagePatientQuestionnaires", new { id = email })); }