forked from MDCPS/DamageAssessment_Backend
		
	Added new endpoint for creating multiple questions
This commit is contained in:
		| @ -239,16 +239,7 @@ namespace DamageAssesment.Api.Questions.Providers | ||||
|             try | ||||
|             { | ||||
|                 logger?.LogInformation("Query Question"); | ||||
|                 var dbquestion = mapper.Map<Models.Question, Db.Question>(Question); | ||||
|                 var dbquestiontranslation = mapper.Map<List<Models.QuestionsTranslation>, List<Db.QuestionsTranslation>>(Question.Questions); | ||||
|                 dbquestion.QuestionTypeId = questionDbContext.QuestionTypes.Where(a => a.TypeText == Question.TypeText).Select(a => a.Id).FirstOrDefault(); | ||||
|                 questionDbContext.Questions.Add(dbquestion); | ||||
|                 dbquestiontranslation.ForEach(i => i.QuestionId = dbquestion.Id); | ||||
|                 questionDbContext.QuestionsTranslations.AddRange(dbquestiontranslation); | ||||
|                 questionDbContext.SaveChanges(); | ||||
|                 Question.Id = dbquestion.Id; | ||||
|                 var result = mapper.Map<Db.Question, Models.MultiLanguage>(dbquestion); | ||||
|                 result.Text = CreateMultiLanguageObject(GetQuestionsTranslations(result.Id,"")); | ||||
|                 var result = InsertQuestion(Question); | ||||
|                 return (true, result, null); | ||||
|             } | ||||
|             catch (Exception ex) | ||||
| @ -257,6 +248,38 @@ namespace DamageAssesment.Api.Questions.Providers | ||||
|                 return (false, null, ex.Message); | ||||
|             } | ||||
|         } | ||||
|         private Models.MultiLanguage InsertQuestion(Models.Question Question) | ||||
|         { | ||||
|             var dbquestion = mapper.Map<Models.Question, Db.Question>(Question); | ||||
|             var dbquestiontranslation = mapper.Map<List<Models.QuestionsTranslation>, List<Db.QuestionsTranslation>>(Question.Questions); | ||||
|             dbquestion.QuestionTypeId = questionDbContext.QuestionTypes.Where(a => a.TypeText == Question.TypeText).Select(a => a.Id).FirstOrDefault(); | ||||
|             questionDbContext.Questions.Add(dbquestion); | ||||
|             dbquestiontranslation.ForEach(i => i.QuestionId = dbquestion.Id); | ||||
|             questionDbContext.QuestionsTranslations.AddRange(dbquestiontranslation); | ||||
|             questionDbContext.SaveChanges(); | ||||
|             Question.Id = dbquestion.Id; | ||||
|             var result = mapper.Map<Db.Question, Models.MultiLanguage>(dbquestion); | ||||
|             result.Text = CreateMultiLanguageObject(GetQuestionsTranslations(result.Id, "")); | ||||
|             return result; | ||||
|         } | ||||
|         public async Task<(bool IsSuccess, IEnumerable<Models.MultiLanguage> Question, string ErrorMessage)> PostQuestionsAsync(List<Models.Question> Questions) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|                 List<Models.MultiLanguage> results = new List<MultiLanguage>(); | ||||
|                logger?.LogInformation("Query Question"); | ||||
|                 foreach (Models.Question Question in Questions) | ||||
|                 { | ||||
|                     results.Add(InsertQuestion(Question)); | ||||
|                 } | ||||
|                 return (true, results, null); | ||||
|             } | ||||
|             catch (Exception ex) | ||||
|             { | ||||
|                 logger?.LogError(ex.ToString()); | ||||
|                 return (false, null, ex.Message); | ||||
|             } | ||||
|         } | ||||
|         public async Task<(bool IsSuccess, Models.MultiLanguage Question, string ErrorMessage)> UpdateQuestionAsync(Models.Question Question) | ||||
|         { | ||||
|             try | ||||
|  | ||||
		Reference in New Issue
	
	Block a user