private void BuildDataList() { if (SessionState.Questionnaire != null) { PollQuestionCollection pollQuestions = PollQuestionCollection.GetByQuestionnaire(SessionState.Questionnaire.QuestionnaireID); QuestionRankMax = pollQuestions.MaxRank(); DataListQuestion.DataSource = pollQuestions; DataListQuestion.DataBind(); // Trouver les reponses foreach (DataListItem dli in DataListQuestion.Items) { DataList dl = new DataList(); dl = ( DataList )dli.FindControl("DataListReponse"); HiddenField hf = new HiddenField(); hf = ( HiddenField )dli.FindControl("PollQuestionId"); Guid pollQuestionId = new Guid(hf.Value); PollAnswerCollection answers = PollAnswerCollection.GetByPollQuestionID(pollQuestionId); dl.DataSource = answers; dl.DataBind(); } } Trace.Warn("BuildDataList"); }
private void BuildDataList() { Trace.Warn("BuildDataList"); if (SessionState.Questionnaire != null) { PollQuestionCollection pollQuestions = PollQuestionCollection.GetByQuestionnaire(SessionState.Questionnaire.QuestionnaireID); QuestionRankMax = pollQuestions.MaxRank(); DropDownListCopierAPartirDe.Items.Clear(); DropDownListCopierAPartirDe.Items.Add(""); foreach (PollQuestion pq in pollQuestions) { DropDownListCopierAPartirDe.Items.Add(pq.Rank.ToString()); } DataListQuestion.DataSource = pollQuestions; DataListQuestion.DataBind(); // Trouver les reponses foreach (DataListItem dli in DataListQuestion.Items) { DataList dl = new DataList(); dl = ( DataList )dli.FindControl("DataListReponse"); HiddenField hf = new HiddenField(); hf = ( HiddenField )dli.FindControl("PollQuestionId"); Guid pollQuestionId = new Guid(hf.Value); PollAnswerCollection answers = PollAnswerCollection.GetByPollQuestionID(pollQuestionId); dl.DataSource = answers; dl.DataBind(); } } }
protected void Page_Load(object sender, System.EventArgs e) { if (IsPostBack == false) { if (Request.QueryString["QuestionnaireID"] != null) { Cache["QuestionnaireID"] = int.Parse(Request.QueryString["QuestionnaireID"]); Questionnaire questionnaire = Questionnaire.GetQuestionnaire((int)Cache["QuestionnaireID"]); Reporter.Trace("Questionnaire lecture"); ValidationMessage.Text += "Suppression du Questionnaire : " + questionnaire.Description + ":" + questionnaire.CodeAcces + " questions : "; Cache["Questions"] = PollQuestionCollection.GetByQuestionnaire(( int )Cache["QuestionnaireID"]); ValidationMessage.Text += ((PollQuestionCollection)Cache["Questions"]).Count + "<br />"; foreach (PollQuestion question in ( PollQuestionCollection )Cache["Questions"]) { ValidationMessage.Text += "-- Question : " + question.Question + "<br />"; PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer reponse in reponses) { ValidationMessage.Text += "---- Réponse : " + reponse.Answer + "<br />"; int nbVotes = PollVoteCollection.NumberOfVotesByAnswer(reponse.PollAnswerId); ValidationMessage.Text += "----- Votes : " + nbVotes.ToString() + "<br />"; } } Cache["Personnes"] = PersonneCollection.GetQuestionnaire(( int )Cache["QuestionnaireID"]); ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des contacts : " + (( PersonneCollection )Cache["Personnes"]).Count + "<br />"; foreach (Personne p in ( PersonneCollection )Cache["Personnes"]) { ValidationMessage.Text += p.Nom + " " + p.Prenom + " " + p.EmailBureau + " " + p.Societe + "<br />"; } MemberInfo membre = MemberInfo.GetMemberInfo(questionnaire.MembreGUID); Cache["WebContents"] = WebContentCollection.GetWebContents(membre.NomUtilisateur, questionnaire.CodeAcces.ToString()); ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des contenus web : " + (( WebContentCollection )Cache["WebContents"]).Count + "<br />"; foreach (WebContent wc in ( WebContentCollection )Cache["WebContents"]) { ValidationMessage.Text += wc.Section + " " + wc.Utilisateur + " " + wc.Visualisateur + "<br />"; } Cache["Scores"] = ScoreCollection.GetScoreQuestionnaire(( int )Cache["QuestionnaireID"]); ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des scores : " + (( ScoreCollection )Cache["Scores"]).Count + "<br />"; ValidationMessage.Visible = true; } } }
protected void QuestionSuivante_Click(object sender, EventArgs e) { if (SessionState.CurrentQuestionIndex == SessionState.Questions.Count - 1) { SessionState.Questionnaire = null; Page.Response.Redirect("~/Poll/Termine.aspx", true); } // Passer a la question suivante SessionState.CurrentQuestionIndex += 1; SessionState.Question = SessionState.Questions[SessionState.CurrentQuestionIndex]; SessionState.Reponses = PollAnswerCollection.GetByPollQuestionID(SessionState.Question.PollQuestionId); this.Controls.Clear(); CreateControls(); }
protected override void OnLoad(EventArgs e) { if (!Page.IsPostBack) { if (Page.Request["QuestionnaireID"] != null) { int questionnaireID = int.Parse(Page.Request["QuestionnaireID"].ToString()); SessionState.Questionnaire = Questionnaire.GetQuestionnaire(questionnaireID); SessionState.Questions = PollQuestionCollection.GetByQuestionnaire(questionnaireID); SessionState.Question = SessionState.Questions[0]; // permiere question SessionState.Reponses = PollAnswerCollection.GetByPollQuestionID(SessionState.Question.PollQuestionId); SessionState.CurrentQuestionIndex = 0; } } if (!Page.IsCallback) { int tete = 123214; } }
protected void TextBoxQuestion_TextChanged(object sender, EventArgs e) { Reporter.Trace("TextBoxQuestion_TextChanged"); BloquerQuestionnaire(SessionState.Questionnaire.Bloque); try { TextBox textBox = ( TextBox )sender; HiddenField hf = new HiddenField(); hf = ( HiddenField )textBox.Parent.FindControl("PollQuestionId"); Guid pollQuestionId = new Guid(hf.Value); PollQuestion question = SessionState.Questions.FindByPollQuestionID(pollQuestionId); // Mise a jour de la Question if (textBox.Text.Trim() != string.Empty) { question.Question = textBox.Text.Trim(); PollQuestion.Update(question); } else // Suppression de la Question des Reponses et des Votes associes { int status = 0; PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer reponse in reponses) { PollVoteCollection votes = PollVoteCollection.GetVotes(reponse.PollAnswerId); foreach (PollVote vote in votes) { status += PollVote.Delete(vote.VoteId); } status += PollAnswer.Delete(reponse.PollAnswerId); } status += PollQuestion.Delete(question.PollQuestionId); SessionState.Limitations.SupprimerQuestion(); RebuildDataList(); } } catch { } }
protected void SubmitButton_Click(object sender, EventArgs e) { if (HasUserAlreadyVoted()) { this.Controls.Add(new LiteralControl("<br/>Vous avez déjà répondu à cette question.")); } else if (!Strings.IsNullOrEmpty(((( RadioButtonList )this.Controls[5]).SelectedValue))) { Limitation limitation = new Limitation(SessionState.Questionnaire.MembreGUID); if (limitation.LimitesReponses) { Context.Response.Redirect(Tools.PageErreurPath + "Désolé mais le nombre de réponses pour ce questionnaire est atteinte.", true); } PollVote pv = new PollVote(); pv.PollQuestionID = SessionState.Question.PollQuestionId; pv.PollAnswerId = new Guid((( RadioButtonList )this.Controls[5]).SelectedValue); pv.UserGUID = SessionState.Personne.PersonneGUID; pv.QuestionnaireID = SessionState.Question.QuestionnaireID; pv.CreationDate = DateTime.Now; PollVote.Create(pv); // Le questionnaire est termine if (SessionState.CurrentQuestionIndex == SessionState.Questions.Count - 1) { SessionState.Questionnaire = null; Page.Response.Redirect("~/Poll/Termine.aspx", true); } // Passer a la question suivante SessionState.CurrentQuestionIndex += 1; SessionState.Question = SessionState.Questions[SessionState.CurrentQuestionIndex]; SessionState.Reponses = PollAnswerCollection.GetByPollQuestionID(SessionState.Question.PollQuestionId); this.Controls.Clear(); CreateControls(); } else { this.Controls.Add(new LiteralControl("<br/>Merci de répondre à la question.")); } }
protected void ButtonValiderQuestionnaire_Click(object sender, EventArgs e) { if (Request.QueryString["valider"] != null) { if (Request.QueryString["valider"].ToString() == "2") { Page.Response.Redirect("~/Poll/Termine.Aspx", true); } } if (SessionState.QuestionsEnCours.Count <= 0) { ValidationMessage.Text += "Pas de questions en cours."; ValidationMessage.Visible = true; return; } if (SessionState.VotesEnCours.Count <= 0) { // L'interviewe a deja clique sur le bouton if (ValidationMessage.Text == "Pas de réponses en cours.") { Page.Response.Redirect("~/Poll/Termine.Aspx", true); } ValidationMessage.Text += "Pas de réponses en cours."; ValidationMessage.Visible = true; return; } int statusGlobal = 0; Session["_VotesEnCoursCount"] = SessionState.VotesEnCours.Count; foreach (PollQuestion question in SessionState.QuestionsEnCours) { PollAnswerCollection answers = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer answer in answers) { PollVoteCollection pvc = SessionState.VotesEnCours.FindByAnswerID(answer.PollAnswerId); if (pvc.Count > 0) { foreach (PollVote vote in pvc) { if (HttpContext.Current.User.Identity.IsAuthenticated == false) { Limitation limitation = new Limitation(SessionState.Questionnaire.MembreGUID); if (limitation.LimitesReponses) { Context.Response.Redirect(Tools.PageErreurPath + "Désolé mais le nombre de réponses pour ce questionnaire est atteinte.", true); } int status = PollVote.Create(vote); if (status != 1) { statusGlobal += 1; } } SessionState.Votes.Add(vote); SessionState.VotesEnCours.Remove(vote); } } } } if (statusGlobal != 0) { ValidationMessage.Text += "Erreur à la création des votes : " + statusGlobal.ToString(); ValidationMessage.Visible = true; return; } if (Request.QueryString["fin"] != null) { Page.Response.Redirect("~/Poll/QuestionnaireEnCours.aspx?valider=2", true); } Page.Response.Redirect("~/Poll/QuestionnaireEnCours.aspx?valider=1", true); }
// BUG10092009 static Guid MembreGUID = Guid.Empty; protected void Page_Load(object sender, EventArgs e) { if (IsPostBack == false) { if (Request.QueryString["MembreGUID"] == null) { Response.Redirect("~/Member/Manage.aspx"); } else { Cache["MembreGUID"] = new Guid(Request.QueryString["MembreGUID"]); MembershipUser user = Membership.GetUser(( Guid )Cache["MembreGUID"]); MemberInfo member = MemberInfo.Get(( Guid )Cache["MembreGUID"]); ValidationMessage.Text += "Suppression du Membre : " + member.Nom + " " + member.Prenom + " " + user.Email + "<br />"; ValidationMessage.Text += "-- Nom d'utilisateur : " + user.UserName + "<br /><br />"; Cache["Questionnaires"] = QuestionnaireCollection.GetQuestionnaireMembre(( Guid )Cache["MembreGUID"]); foreach (Questionnaire questionnaire in ( QuestionnaireCollection )Cache["Questionnaires"]) { int QuestionnaireID = questionnaire.QuestionnaireID; ValidationMessage.Text += "Suppression du Questionnaire : " + questionnaire.Description + ":" + questionnaire.CodeAcces + " questions : "; PollQuestionCollection questions = PollQuestionCollection.GetByQuestionnaire(QuestionnaireID); ValidationMessage.Text += questions.Count + "<br />"; foreach (PollQuestion question in questions) { ValidationMessage.Text += "-- Question : " + question.Question + "<br />"; PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer reponse in reponses) { ValidationMessage.Text += "---- Réponse : " + reponse.Answer + "<br />"; int nbVotes = PollVoteCollection.NumberOfVotesByAnswer(reponse.PollAnswerId); ValidationMessage.Text += "------ Votes : " + nbVotes.ToString() + "<br />"; } } PersonneCollection personnes = PersonneCollection.GetQuestionnaire(QuestionnaireID); ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des contacts : " + personnes.Count + "<br />"; foreach (Personne p in personnes) { ValidationMessage.Text += p.Nom + " " + p.Prenom + " " + p.EmailBureau + " " + p.Societe + "<br />"; } ValidationMessage.Text += "</br>"; WebContentCollection webContents = WebContentCollection.GetWebContents(member.NomUtilisateur, questionnaire.CodeAcces.ToString()); ValidationMessage.Text += "Suppression des contenus web pour le Questionnaire : " + webContents.Count + "<br />"; foreach (WebContent wc in webContents) { ValidationMessage.Text += wc.Section + " " + wc.Utilisateur + " " + wc.Visualisateur + "<br />"; } ValidationMessage.Text += "</br>"; Cache["Scores"] = ScoreCollection.GetScoreQuestionnaire(QuestionnaireID); ValidationMessage.Text += "Suppression des scores : " + (( ScoreCollection )Cache["Scores"]).Count + "<br />"; ValidationMessage.Text += "</br>"; } ValidationMessage.Text += "</br>"; Cache["WebContentsToutLeMonde"] = WebContentCollection.GetWebContents(member.NomUtilisateur, WebContent.ToutLeMonde); ValidationMessage.Text += "Suppression des contenus web pour Tout le Monde : " + (( WebContentCollection )Cache["WebContentsToutLeMonde"]).Count + "<br />"; foreach (WebContent wc in ( WebContentCollection )Cache["WebContentsToutLeMonde"]) { ValidationMessage.Text += "-- " + wc.Section + " " + wc.Utilisateur + " " + wc.Visualisateur + "<br />"; } ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des styles web :<br />"; string dirStyleWeb = Server.MapPath("~/App_Data/StyleWeb/" + user.UserName); if (Directory.Exists(dirStyleWeb)) { List <Fichier> fichiers = Tools.GetAllFichiers(dirStyleWeb); if (fichiers.Count <= 0) { ValidationMessage.Text += "-- Pas de style web<br />"; } else { foreach (Fichier f in fichiers) { string nomFichier = Tools.GetFileNameWithoutExtension(f.Nom); ValidationMessage.Text += "-- " + nomFichier + "<br />"; } } } else { ValidationMessage.Text += "-- Pas de style web<br />"; } ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression du fichier de paramètres : <br />"; string fileName = Server.MapPath("~/App_Data/MemberSettings/" + user.UserName + ".xml"); if (File.Exists(fileName)) { string nomFichier = Tools.GetFileNameWithoutExtension(fileName); ValidationMessage.Text += "-- " + nomFichier + "<br />"; } else { ValidationMessage.Text += "-- Pas de paramètres<br />"; } ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression du Serveur SMTP :<br />"; SmtpServer stmpServeur = SmtpServer.Get(member.MembreGUID); if (stmpServeur != null) { ValidationMessage.Text += "-- Email : " + stmpServeur.Email + "<br />"; ValidationMessage.Text += "-- UserName : "******"<br />"; ValidationMessage.Text += "-- PassWord : "******"<br />"; ValidationMessage.Text += "-- ServerName : " + stmpServeur.ServerName + "<br />"; } else { ValidationMessage.Text += "-- Pas de serveur SMTP<br />"; } ValidationMessage.Visible = true; } } }
protected void ButtonSupprimer_Click(object sender, EventArgs e) { if (Cache["MembreGUID"] == null || ( Guid )Cache["MembreGUID"] == Guid.Empty) { ValidationMessage.Text += "<br/>Choisir un membre à supprimer.<br/>"; ValidationMessage.CssClass = "LabelValidationMessageErrorStyle"; ValidationMessage.Visible = true; } else { int status = 0; int statusGlobal = 0; ValidationMessage.Text += "<br />-----------------------------------------------------<br />"; ValidationMessage.Text += " Début de la Suppression du Membre <br />"; ValidationMessage.Text += "-----------------------------------------------------<br />"; Reporter.Trace("ButtonSupprimer_Click début"); MemberInfo member = MemberInfo.Get(( Guid )Cache["MembreGUID"]); foreach (Questionnaire questionnaire in (QuestionnaireCollection)Cache["Questionnaires"]) { int QuestionnaireID = questionnaire.QuestionnaireID; ValidationMessage.Text += "--- Suppression du Questionnaire : " + questionnaire.Description + ":" + questionnaire.CodeAcces + " questions : "; PollQuestionCollection questions = PollQuestionCollection.GetByQuestionnaire(QuestionnaireID); ValidationMessage.Text += questions.Count + "<br />"; foreach (PollQuestion question in questions) { PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer reponse in reponses) { PollVoteCollection votes = PollVoteCollection.GetVotes(reponse.PollAnswerId); int nbVotes = PollVoteCollection.NumberOfVotesByAnswer(reponse.PollAnswerId); ValidationMessage.Text += "----- Suppression des votes : " + nbVotes.ToString() + "<br />"; foreach (PollVote vote in votes) { status = PollVote.Delete(vote.VoteId); statusGlobal = statusGlobal + status; ValidationMessage.Text += " status : " + status.ToString() + "<br />"; } ValidationMessage.Text += "---- Suppression de la Réponse : " + reponse.Answer + "<br />"; status = PollAnswer.Delete(reponse.PollAnswerId); statusGlobal = statusGlobal + status; ValidationMessage.Text += " status : " + status.ToString() + "<br />"; } ValidationMessage.Text += "--- Suppression de la Question : " + question.Question + "<br />"; status = PollQuestion.Delete(question.PollQuestionId); SessionState.Limitations.SupprimerQuestion(); statusGlobal = statusGlobal + status; ValidationMessage.Text += " status : " + status.ToString() + "<br />"; } PersonneCollection personnes = PersonneCollection.GetQuestionnaire(QuestionnaireID); ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des contacts : " + personnes.Count + "<br />"; foreach (Personne p in personnes) { ValidationMessage.Text += p.Nom + " " + p.Prenom + " " + p.EmailBureau + " " + p.Societe + "<br />"; status = Personne.Delete(p.ID_Personne); statusGlobal = statusGlobal + status; ValidationMessage.Text += "status : " + status.ToString() + "<br />"; } SessionState.Limitations.SupprimerInterviewes(personnes.Count); WebContentCollection webContents = WebContentCollection.GetWebContents(member.NomUtilisateur, questionnaire.CodeAcces.ToString()); ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des contenus web pour le Questionnaire : " + webContents.Count + "<br />"; foreach (WebContent wc in webContents) { ValidationMessage.Text += wc.Section + " " + wc.Utilisateur + " " + wc.Visualisateur + "<br />"; status = WebContent.Delete(wc.WebContentID); statusGlobal = statusGlobal + status; ValidationMessage.Text += "status : " + status.ToString() + "<br />"; } ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des scores : " + (( ScoreCollection )Cache["Scores"]).Count + "<br />"; foreach (Score s in ( ScoreCollection )Cache["Scores"]) { status = Score.Delete(s.ScoreID); statusGlobal = statusGlobal + status; } ValidationMessage.Text += "Suppression du Questionnaire : " + questionnaire.Description + "<br />"; status = Questionnaire.Delete(questionnaire.QuestionnaireID); statusGlobal = statusGlobal + status; SessionState.Limitations.SupprimerQuestionnaire(); ValidationMessage.Text += "status : " + status.ToString() + "<br />"; }// Fin de foreach ( Questionnaire questionnaire in Questionnaires ) Reporter.Trace("foreach ( Questionnaire questionnaire in Questionnaires ) fin"); ValidationMessage.Text += "Suppression des contenus web pour Tout Le Monde : " + (( WebContentCollection )Cache["WebContentsToutLeMonde"]).Count + "<br />"; foreach (WebContent wc in ( WebContentCollection )Cache["WebContentsToutLeMonde"]) { ValidationMessage.Text += wc.Section + " " + wc.Utilisateur + " " + wc.Visualisateur + "<br />"; status = WebContent.Delete(wc.WebContentID); statusGlobal = statusGlobal + status; ValidationMessage.Text += "status : " + status.ToString() + "<br />"; } MembershipUser user = Membership.GetUser(( Guid )Cache["MembreGUID"]); Reporter.Trace("Directory.Exists( dirStyleWeb ) début"); ValidationMessage.Text += "Suppression des styles web :<br />"; string dirStyleWeb = Server.MapPath("~/App_Data/StyleWeb/" + user.UserName); if (Directory.Exists(dirStyleWeb)) { List <Fichier> fichiers = Tools.GetAllFichiers(dirStyleWeb); if (fichiers.Count <= 0) { ValidationMessage.Text += "-- Pas de style web<br />"; } else { foreach (Fichier f in fichiers) { try { File.Delete(f.Nom); string nomFichier = Tools.GetFileNameWithoutExtension(f.Nom); ValidationMessage.Text += "-- fichier supprimé : " + nomFichier + "<br />"; } catch { string nomFichier = Tools.GetFileNameWithoutExtension(f.Nom); ValidationMessage.Text += "-- ERREUR à la suppression du fichier : " + nomFichier + "<br />"; } } } ValidationMessage.Text += "Suppression du répertoire : " + user.UserName; try { Directory.Delete(dirStyleWeb); } catch (Exception ex) { ValidationMessage.Text += " Erreur : " + ex.Message + "</br>"; } ValidationMessage.Text += "</br>"; } else { ValidationMessage.Text += "-- Pas de style web<br />"; } ValidationMessage.Text += "</br>"; Reporter.Trace("Directory.Exists( dirStyleWeb ) fin"); ValidationMessage.Text += "Suppression du fichier de paramètres :<br />"; string fileName = Server.MapPath("~/App_Data/MemberSettings/" + user.UserName + ".xml"); if (File.Exists(fileName)) { File.Delete(fileName); string nomFichier = Tools.GetFileNameWithoutExtension(fileName); ValidationMessage.Text += "-- fichier supprimé : " + nomFichier + "<br />"; } else { string nomFichier = Tools.GetFileNameWithoutExtension(fileName); ValidationMessage.Text += "-- ERREUR à la suppression du fichier : " + nomFichier + "<br />"; } ValidationMessage.Text += "</br>"; Reporter.Trace("SmtpServer.Get( member.MembreGUID ) début"); SmtpServer stmpServeur = SmtpServer.Get(member.MembreGUID); if (stmpServeur != null) { ValidationMessage.Text += "Suppression du Serveur SMTP :" + stmpServeur.ServerName + "<br />"; status = SmtpServer.Delete(stmpServeur.SmtpServerID); statusGlobal = statusGlobal + status; ValidationMessage.Text += "status : " + status.ToString() + "<br />"; } Reporter.Trace("SmtpServer.Get( member.MembreGUID ) fin"); ValidationMessage.Text += "Suppression du Membre : " + member.Nom + " " + member.Prenom + " " + user.Email + " " + user.UserName + "<br />"; status = MemberInfo.Delete(( Guid )Cache["MembreGUID"]); statusGlobal = statusGlobal + status; ValidationMessage.Text += "status : " + status.ToString() + "<br />"; ValidationMessage.Text += "Suppression de l'Utilisateur : " + user.UserName + "<br />"; bool ok = Membership.DeleteUser(user.UserName, true); if (ok) { status = 0; } else { status = 1; } ValidationMessage.Text += "status : " + status.ToString() + "<br />"; ValidationMessage.Text += "<br />status global : " + statusGlobal.ToString() + "<br />"; ValidationMessage.Visible = true; // Forcer les Questionnaires a se recharger depuis la Base de Donnees SessionState.Questionnaires = null; SessionState.Questionnaire = null; Cache["MembreGUID"] = Guid.Empty; // Si c'est un membre qui supprime sont compte if (User.IsInRole("Administrateur") == false) { // Message de suppression d'un membre a l'admin string sujetEmail2 = "Suppression d'un Membre sur le site : " + Global.SettingsXml.SiteNom; string bodyEmail2 = ""; bodyEmail2 += "Nom d'utilisateur : " + SessionState.MemberInfo.NomUtilisateur + "<br/>"; bodyEmail2 += "Nom : " + SessionState.MemberInfo.Nom + "<br/>"; bodyEmail2 += "Prénom : " + SessionState.MemberInfo.Prenom + "<br/>"; bodyEmail2 += "Société : " + SessionState.MemberInfo.Societe + "<br/>"; bodyEmail2 += "Téléphone : " + SessionState.MemberInfo.Telephone + "<br/>"; bodyEmail2 += "Adresse : " + SessionState.MemberInfo.Adresse + "<br/>"; bodyEmail2 += "Email : " + user.Email + "<br/>"; bodyEmail2 += "<br/>Accès à l'application :<br/>" + string.Format("<a href=\"{0}\" >{1}</a>", Utils.WebSiteUri, Utils.WebSiteUri) + "<br/>"; MemberInfo admin = MemberInfo.GetMemberInfo("admin"); MembershipUser userAdmin = Membership.GetUser(admin.MembreGUID); Courriel.EnvoyerEmailToAssynchrone(admin.MembreGUID, userAdmin.Email, sujetEmail2, bodyEmail2); // Deconnecter l'utilisateur FormsAuthentication.SignOut(); HttpContext.Current.Session.Abandon(); Response.Redirect("~/Member/Login.aspx"); } } }
// Ajouter des Reponses a la Question protected void TextBoxReponse_TextChanged(object sender, EventArgs e) { Reporter.Trace("TextBoxReponse_TextChanged"); BloquerQuestionnaire(SessionState.Questionnaire.Bloque); try { TextBox textBox = ( TextBox )sender; DropDownList ddlTypeReponse = ( DropDownList )textBox.Parent.FindControl("DropDownListTypeReponse"); if (textBox.Text.Trim() != "" && ddlTypeReponse.SelectedValue != "-1") { HiddenField hf = new HiddenField(); hf = ( HiddenField )textBox.Parent.FindControl("PollQuestionId"); Guid pollQuestionId = new Guid(hf.Value); PollQuestion question = SessionState.Questions.FindByPollQuestionID(pollQuestionId); PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(pollQuestionId); CheckBox cbxObligatoire = ( CheckBox )textBox.Parent.FindControl("CheckBoxObligatoire"); if (textBox.Text.Trim().Contains(";")) { int rank = reponses.MaxRank() + 1; // ajouter les reponses a la suite des reponses existantes string[] reponsesSplit = textBox.Text.Trim().Split(';'); foreach (string rep in reponsesSplit) { PollAnswer reponse = new PollAnswer(rep.Trim()); reponse.PollQuestionId = question.PollQuestionId; reponse.TypeReponse = ddlTypeReponse.SelectedValue; reponse.Obligatoire = cbxObligatoire.Checked; reponse.Rank = rank; int status = PollAnswer.Create(reponse); rank += 1; } } else { PollAnswer reponse = new PollAnswer(); reponse.PollQuestionId = question.PollQuestionId; reponse.Answer = textBox.Text.Trim(); reponse.TypeReponse = ddlTypeReponse.SelectedValue; // reponse.Width = reponse.Width; // reponse.Rows = reponse.Rows; // reponse.AlignLeft = reponse.AlignLeft; // reponse.Horizontal = reponse.Horizontal; reponse.Obligatoire = cbxObligatoire.Checked; reponse.Rank = reponses.MaxRank() + 1; // ajouter la reponse a la suite des reponses existantes int status = PollAnswer.Create(reponse); } RebuildDataList(); } if (ddlTypeReponse.SelectedValue == "-1") { textBox.CssClass = "TextBoxListUserQuestionInstructionRedStyle"; textBox.Text = "Choisir un Type de réponse"; } } catch { } }
private void BuildDataList() { Reporter.Trace("BuildDataList"); // AME19102010 Mode Pagination - Il y a t-il plusieurs pages ? if (modePage()) { // AME19102010 - Mettre ou remettre les boutons des pager en fonction de CurrentPage if (CurrentPage == 0) // premiere page { ButtonPagePrecedenteHaut.Visible = false; ButtonPagePrecedenteBas.Visible = false; ButtonPageSuivanteHaut.Visible = true; ButtonPageSuivanteBas.Visible = true; } if (CurrentPage > 0) { ButtonPagePrecedenteHaut.Visible = true; ButtonPagePrecedenteBas.Visible = true; ButtonPageSuivanteHaut.Visible = true; ButtonPageSuivanteBas.Visible = true; } if (nombrePage() > 0 && CurrentPage + 1 >= nombrePage()) // derniere page { CurrentPage = nombrePage() - 1; // si on a change la pagination CurrentPage ne peut pas depasser nombrePage() - 1 ButtonPagePrecedenteHaut.Visible = true; ButtonPagePrecedenteBas.Visible = true; ButtonPageSuivanteHaut.Visible = false; ButtonPageSuivanteBas.Visible = false; } PagedDataSource pagedDataSource = new PagedDataSource(); pagedDataSource.AllowPaging = true; pagedDataSource.DataSource = SessionState.Questions; pagedDataSource.PageSize = int.Parse(SessionState.MemberSettings.TaillePageQuestions); pagedDataSource.CurrentPageIndex = CurrentPage; LabelPageCouranteHaut.Text = (CurrentPage + 1).ToString() + "/" + nombrePage().ToString(); LabelPageCouranteBas.Text = LabelPageCouranteHaut.Text; LabelPageCouranteHaut.ToolTip = "Page courante/Nombre de pages - taille d'une page : " + SessionState.MemberSettings.TaillePageQuestions; LabelPageCouranteBas.ToolTip = LabelPageCouranteHaut.ToolTip; PanelPagerHaut.Visible = true; PanelPagerBas.Visible = true; DataListQuestion.DataSource = pagedDataSource; } else { PanelPagerHaut.Visible = false; PanelPagerBas.Visible = false; DataListQuestion.DataSource = SessionState.Questions; } DataListQuestion.DataBind(); // Trouver toutes les reponses foreach (DataListItem dli in DataListQuestion.Items) { DataList dl = new DataList(); dl = ( DataList )dli.FindControl("DataListReponse"); HiddenField hf = new HiddenField(); hf = ( HiddenField )dli.FindControl("PollQuestionId"); Guid pollQuestionId = new Guid(hf.Value); PollAnswerCollection answers = PollAnswerCollection.GetByPollQuestionID(pollQuestionId); dl.DataSource = answers; dl.DataBind(); DropDownList ddlTypReponse = ( DropDownList )dli.FindControl("DropDownListTypeReponse"); ddlTypReponse.DataSource = TypeReponse.List(); ddlTypReponse.DataBind(); ddlTypReponse.Items.Insert(0, new ListItem("Type de Réponse", "-1")); // Par defaut on propose toujours le type de reponse "Choix" ddlTypReponse.SelectedValue = TypeReponse.Choix; } }
protected void DetailsView1_ItemInserted(object sender, DetailsViewInsertedEventArgs e) { Trace.Warn("DetailsView1_ItemInserted"); // Copier les reponses de la question de rang choisie par l'utilisateur // dans la nouvelle question if (DropDownListCopierAPartirDe.SelectedValue != "") { // Le GUID de la nouvelle question cree Guid pollQuestionId = new Guid(e.Values["PollQuestionID"].ToString()); int questionRank = 0; try { questionRank = int.Parse(DropDownListCopierAPartirDe.SelectedValue); } catch { LabelValidationMessage.Text = "Erreur : le rang n'est pas un entier"; LabelValidationMessage.CssClass = "LabelValidationMessageErrorStyle"; return; } PollQuestionCollection questions = PollQuestionCollection.GetByQuestionnaire(SessionState.Questionnaire.QuestionnaireID); PollQuestion laQuestion = null; foreach (PollQuestion question in questions) { if (question.Rank == questionRank) { laQuestion = new PollQuestion(); laQuestion = question; break; } } if (laQuestion == null) { LabelValidationMessage.Text = "Pas de Question de ce rang"; LabelValidationMessage.CssClass = "LabelValidationMessageErrorStyle"; return; } PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(laQuestion.PollQuestionId); foreach (PollAnswer reponse in reponses) { PollAnswer a = new PollAnswer(); a.PollQuestionId = pollQuestionId; a.Answer = reponse.Answer; a.TypeReponse = reponse.TypeReponse; a.Width = reponse.Width; a.Rows = reponse.Rows; a.Rank = reponse.Rank; a.Score = reponse.Score; int status = PollAnswer.Create(a); if (status == 0) { LabelValidationMessage.Text = "Réponses copiées correctement"; } else { LabelValidationMessage.Text = "Erreur à la création des réponses"; LabelValidationMessage.CssClass = "LabelValidationMessageErrorStyle"; } } } Trace.Warn("DetailsView1_ItemInserted"); BuildDataList(); }
protected void ButtonCopier_Click(object sender, EventArgs e) { Reporter.Trace("ButtonCopier_Click"); if (( int )Cache["QuestionnaireID "] == 0) { ValidationMessage.Text += "Choisir un questionnaire à copier.<br/>"; ValidationMessage.CssClass = "LabelValidationMessageErrorStyle"; ValidationMessage.Visible = true; } else { int status = 0; MemberInfo membre = MemberInfo.GetMemberInfo(( Guid )Cache["MembreGUID"]); Questionnaire questionnaire = Questionnaire.GetQuestionnaire(( int )Cache["QuestionnaireID "]); Questionnaire newquestionnaire = new Questionnaire(); Reporter.Trace("GetMemberInfo() GetQuestionnaire()"); // Creation d'un nouveau Questionnaire if (( int )Cache["QuestionnaireExistantID"] == 0) { newquestionnaire.Description = questionnaire.Description; newquestionnaire.Style = questionnaire.Style; newquestionnaire.Valider = questionnaire.Valider; newquestionnaire.Fin = questionnaire.Fin; newquestionnaire.Anonyme = questionnaire.Anonyme; newquestionnaire.Compteur = questionnaire.Compteur; newquestionnaire.DateCreation = DateTime.Now; newquestionnaire.MembreGUID = ( Guid )Cache["MembreGUID"]; newquestionnaire.CodeAcces = ( int )Cache["CodeAcces"]; ValidationMessage.Text += "<br />Création du Questionnaire : " + newquestionnaire.Description + ":" + newquestionnaire.CodeAcces + "<br />"; if (User.IsInRole("Administrateur")) { ValidationMessage.Text += "Pour le membre : " + membre.NomUtilisateur + "/" + membre.Nom + "/" + membre.Prenom + "<br />"; } // Tester les limitations avant d'ajouter le questionnaire if (SessionState.Limitations.LimiteQuestionnaires) { // BUG05062010 12072010 SessionState.Questionnaire = null; Tools.PageValidation("La limite du nombre de Questionnaires : " + SessionState.Limitations.NombreQuestionnaires + " est atteinte.<br/>Contactez l'administrateur."); } status = Questionnaire.Create(newquestionnaire); if (status == 1) { ValidationMessage.Text += "Questionnaire créé correctement.<br/>"; // BUG05062010 // Prendre en compte le nouveau Questionnaire //SessionState.Questionnaires.Add( questionnaire ); //SessionState.Questionnaire = questionnaire; //SessionState.Limitations.AjouterQuestionnaire(); SessionState.Questionnaires.Add(newquestionnaire); SessionState.Questionnaire = newquestionnaire; SessionState.Limitations.AjouterQuestionnaire(); } else if (status == 2) { ValidationMessage.Text += "Le Questionnaire existe déjà.<br>"; ValidationMessage.CssClass = "LabelValidationMessageErrorStyle"; } else { ValidationMessage.Text += "Erreur sur la création du Questionnaire<br/>"; ValidationMessage.CssClass = "LabelValidationMessageErrorStyle"; } } else // Questionnaire existant { newquestionnaire = Questionnaire.GetQuestionnaire(( int )Cache["QuestionnaireExistantID"]); // BUG05062010 // Arrive ici la DropDownListQuestionnaire a modifie // SessionState.Questionnaire avec le questionnaire de l'Intervieweur // il faut donc remmettre SessionState.Questionnaire a la valeur de l'utilisateur SessionState.Questionnaire = newquestionnaire; ValidationMessage.Text += "<br />Copie du Questionnaire : " + newquestionnaire.Description + ":" + newquestionnaire.CodeAcces + "<br />"; ValidationMessage.Text += "Pour le membre : " + membre.NomUtilisateur + "/" + membre.Nom + "/" + membre.Prenom + "<br />"; } int rank = 0; // Conserver le rang des Questions avec un biais MaxRank if (( int )Cache["QuestionnaireExistantID"] != 0) { PollQuestionCollection questionsExistantes = PollQuestionCollection.GetByQuestionnaire(( int )Cache["QuestionnaireExistantID"]); rank = questionsExistantes.MaxRank() + 1; } Reporter.Trace("Questionnaire copier début"); foreach (PollQuestion question in ( PollQuestionCollection )Cache["Questions"]) { ValidationMessage.Text += "----Création de la Question : " + question.Question + "<br />"; PollQuestion q = new PollQuestion(); q.Question = question.Question; q.Rank = question.Rank + rank; // Ajouter le Biais q.Societe = question.Societe; q.Obligatoire = question.Obligatoire; q.Fin = question.Fin; q.ChoixMultiple = question.ChoixMultiple; q.ChoixMultipleMin = question.ChoixMultipleMin; //BUG20100330 q.ChoixMultipleMax = question.ChoixMultipleMax; q.CreationDate = DateTime.Now; q.Instruction = question.Instruction; q.Message = question.Message; q.MessageHaut = question.MessageHaut; q.SautPage = question.SautPage; q.Tableau = question.Tableau; q.AlignementQuestion = question.AlignementQuestion; q.AlignementReponse = question.AlignementReponse; q.QuestionnaireID = newquestionnaire.QuestionnaireID; q.MembreGUID = membre.MembreGUID; // Tester les limitations avant d'ajouter la question if (SessionState.Limitations.LimiteQuestions) { Tools.PageValidation("La limite du nombre de Questions : " + SessionState.Limitations.NombreQuestions + " est atteinte.<br/>Contactez l'administrateur."); } status = PollQuestion.Create(q); ValidationMessage.Text += " status : " + status + "<br/>"; SessionState.Limitations.AjouterQuestion(); PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer reponse in reponses) { Reporter.Trace("PollAnswer.Create()"); ValidationMessage.Text += "----Création de la Réponse : " + reponse.Answer + "<br />"; PollAnswer a = new PollAnswer(); a.PollQuestionId = q.PollQuestionId; a.Answer = reponse.Answer; a.TypeReponse = reponse.TypeReponse; a.Width = reponse.Width; a.Rows = reponse.Rows; a.AlignLeft = reponse.AlignLeft; a.Horizontal = reponse.Horizontal; a.Obligatoire = reponse.Obligatoire; a.Rank = reponse.Rank; a.Score = reponse.Score; status = PollAnswer.Create(a); ValidationMessage.Text += " status : " + status.ToString() + "<br />"; } } //foreach ( PollQuestion question in questions ) // Ne laisser faire qu'une copie ButtonCopier.Visible = false; // BUG05062010 // NE PAS FAIRE ICI //// Creation d'un nouveau Questionnaire //// Prendre en compte le nouveau Questionnaire //if ( ( int )Cache[ "QuestionnaireExistantID" ] == 0 ) //{ // SessionState.Questionnaires.Add( newquestionnaire ); // SessionState.Questionnaire = newquestionnaire; //} Cache["QuestionnaireID "] = 0; // fermer le formulaire Cache["QuestionnaireExistantID"] = 0; // Attention c'est faux Questionnaire.Create() retourn 1 si OK if (status != 0) { ValidationMessage.Text += "Erreur à la copie du Questionnaire status : " + status.ToString() + "<br />"; } Reporter.Trace("Questionnaire copier fin"); ButtonAjouterQuestion.Visible = true; } }
private void BuildDataList() { DataListQuestion.DataSource = SessionState.QuestionsEnCours; DataListQuestion.DataBind(); // Trouver les Reponses et les Votes foreach (DataListItem dli in DataListQuestion.Items) { DataList dl = new DataList(); dl = ( DataList )dli.FindControl("DataListReponse"); HiddenField hf = new HiddenField(); hf = ( HiddenField )dli.FindControl("PollQuestionId"); Guid pollQuestionId = new Guid(hf.Value); PollAnswerCollection answers = PollAnswerCollection.GetByPollQuestionID(pollQuestionId); dl.DataSource = answers; dl.DataBind(); // Rechercher dans les Votes deja effectues if (answers.Count > 0 && SessionState.Votes != null) { int indexReponse = 0; // Trouver le bon LabelVote dans DataListReponse foreach (PollAnswer answer in answers) { PollVoteCollection pvc = SessionState.Votes.FindByAnswerID(answer.PollAnswerId); if (pvc.Count >= 1) // surement un seul mais bon ... { Label lbl = ( Label )dl.Controls[indexReponse].FindControl("LabelVote"); lbl.Text = "X"; lbl.CssClass = "LabelQuestionEnCoursVoteDejaFaitStyle"; if (TypeReponse.EstTextuelle(answer.TypeReponse)) { Label lblVoteTexte = ( Label )dl.Controls[indexReponse].FindControl("LabelVoteTexte"); lblVoteTexte.Text = pvc[0].Vote; } } indexReponse += 1; } } // Rechercher dans les Votes en Cours if (answers.Count > 0 && SessionState.VotesEnCours != null) { int indexReponse = 0; // Trouver le bon LabelVote dans DataListReponse foreach (PollAnswer answer in answers) { PollVoteCollection pvc = SessionState.VotesEnCours.FindByAnswerID(answer.PollAnswerId); if (pvc.Count >= 1) // surement un seul mais ... { Label lbl = ( Label )dl.Controls[indexReponse].FindControl("LabelVote"); lbl.Text = "X"; if (TypeReponse.EstTextuelle(answer.TypeReponse)) { Label lblVoteTexte = ( Label )dl.Controls[indexReponse].FindControl("LabelVoteTexte"); lblVoteTexte.Text = pvc[0].Vote; } } indexReponse += 1; } } } }
protected void ButtonSupprimer_Click(object sender, EventArgs e) { if ((int)Cache["QuestionnaireID"] == 0) { ValidationMessage.Text += "<br/>Choisir un questionnaire à supprimer.<br/>"; ValidationMessage.CssClass = "LabelValidationMessageErrorStyle"; ValidationMessage.Visible = true; } else { int status = 0; int statusGlobal = 0; Questionnaire questionnaire = Questionnaire.GetQuestionnaire(( int )Cache["QuestionnaireID"]); Reporter.Trace("Questionnaire delete"); ValidationMessage.Text += "<br />-----------------------------------------------------<br />"; ValidationMessage.Text += " Début de la Suppression du Questionnaire <br />"; ValidationMessage.Text += "-----------------------------------------------------<br />"; foreach (PollQuestion question in ( PollQuestionCollection )Cache["Questions"]) { PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer reponse in reponses) { PollVoteCollection votes = PollVoteCollection.GetVotes(reponse.PollAnswerId); int nbVotes = PollVoteCollection.NumberOfVotesByAnswer(reponse.PollAnswerId); ValidationMessage.Text += "----- Suppression des votes : " + nbVotes.ToString() + "<br />"; foreach (PollVote vote in votes) { status = PollVote.Delete(vote.VoteId); statusGlobal = statusGlobal + status; ValidationMessage.Text += " status : " + status.ToString() + "<br />"; } ValidationMessage.Text += "---- Suppression de la Réponse : " + reponse.Answer + "<br />"; status = PollAnswer.Delete(reponse.PollAnswerId); statusGlobal = statusGlobal + status; ValidationMessage.Text += " status : " + status.ToString() + "<br />"; } ValidationMessage.Text += "--- Suppression de la Question : " + question.Question + "<br />"; status = PollQuestion.Delete(question.PollQuestionId); statusGlobal = statusGlobal + status; SessionState.Limitations.SupprimerQuestion(); ValidationMessage.Text += " status : " + status.ToString() + "<br />"; } Reporter.Trace("Questionnaire delete fin"); //PersonneCollection personnes = PersonneCollection.GetQuestionnaire( ( int )Cache[ "QuestionnaireID" ] ); ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des contacts : " + (( PersonneCollection )Cache["Personnes"]).Count + "<br />"; foreach (Personne p in ( PersonneCollection )Cache["Personnes"]) { ValidationMessage.Text += p.Nom + " " + p.Prenom + " " + p.EmailBureau + " " + p.Societe + "<br />"; status = Personne.Delete(p.ID_Personne); statusGlobal = statusGlobal + status; ValidationMessage.Text += "status : " + status.ToString() + "<br />"; } SessionState.Limitations.SupprimerInterviewes((( PersonneCollection )Cache["Personnes"]).Count); MemberInfo membre = MemberInfo.GetMemberInfo(questionnaire.MembreGUID); //WebContentCollection webContents = WebContentCollection.GetWebContents( membre.NomUtilisateur, questionnaire.CodeAcces.ToString() ); ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des contenus web : " + (( WebContentCollection )Cache["WebContents"]).Count + "<br />"; foreach (WebContent wc in ( WebContentCollection )Cache["WebContents"]) { ValidationMessage.Text += wc.Section + " " + wc.Utilisateur + " " + wc.Visualisateur + "<br />"; status = WebContent.Delete(wc.WebContentID); statusGlobal = statusGlobal + status; ValidationMessage.Text += "status : " + status.ToString() + "<br />"; } ValidationMessage.Text += "</br>"; ValidationMessage.Text += "Suppression des scores : " + (( ScoreCollection )Cache["Scores"]).Count + "<br />"; foreach (Score s in ( ScoreCollection )Cache["Scores"]) { status = Score.Delete(s.ScoreID); statusGlobal = statusGlobal + status; } ValidationMessage.Text += "Suppression du Questionnaire : " + questionnaire.Description + "<br />"; status = Questionnaire.Delete(questionnaire.QuestionnaireID); statusGlobal = statusGlobal + status; SessionState.Limitations.SupprimerQuestionnaire(); ValidationMessage.Text += "status : " + status.ToString() + "<br />"; ValidationMessage.Text += "<br />status global : " + statusGlobal.ToString() + "<br />"; ValidationMessage.Visible = true; // Forcer les Questionnaires a se recharger depuis la Base de Donnees SessionState.Questionnaires = null; SessionState.Questionnaire = null; Cache["QuestionnaireID"] = 0; // fermer le formulaire // On ne supprime qu'une fois ! ButtonSupprimer.Visible = false; } }
protected void Page_Load(object sender, System.EventArgs e) { ValidationMessage.Text = ""; if (!User.IsInRole("Administrateur") && !User.IsInRole("Client")) { GridView1.Columns[0].Visible = false; // Edit delete column DetailsView1.Visible = false; } if (Request["PollId"] == null) { if (SessionState.Questionnaire != null) { SessionState.Questions = PollQuestionCollection.GetByQuestionnaire(SessionState.Questionnaire.QuestionnaireID); if (SessionState.Questions.Count > 0) { PollQuestionGUID = SessionState.Questions[0].PollQuestionId; // Il faut prevenir le SqlDataSource que le parametre n'est pas dans la Query ... // <asp:QueryStringParameter Name="pollId" QueryStringField="PollId" /> //SqlDataSource1.SelectParameters.Add( "pollId", PollQuestionGUID.ToString() ); //SqlDataSource1.DataBind() // Cela ne fonctionne pas donc on fait : Response.Redirect("~/Poll/Answers.aspx?PollId=" + PollQuestionGUID.ToString()); } } } else { try { PollQuestionGUID = new Guid(Request["PollId"]); } catch { Response.Redirect("~/Poll/Manage.aspx", true); } } if (PollQuestionGUID == Guid.Empty) { Response.Redirect("~/Poll/Manage.aspx", true); } if (SessionState.Questionnaire != null) { HyperLinkQuestionnaire.Text = SessionState.Questionnaire.Description; } PollQuestion question = PollQuestion.GetQuestion(PollQuestionGUID); HyperLinkRank.Text = question.Rank.ToString(); HyperLinkRank.NavigateUrl = "~/Poll/Questionnaire.aspx?PollQuestionId=" + question.PollQuestionId.ToString() + "&t=1"; HyperLinkModifierQuestion.NavigateUrl = "~/Wizard/Question.aspx?PollQuestionId=" + question.PollQuestionId.ToString(); LabelQuestion.Text = " - " + question.Question; LabelObligatoire.Visible = question.Obligatoire; LabelChoixMultiple.Visible = question.ChoixMultiple; LabelChoixMultipleMinMax.Visible = question.ChoixMultiple && (question.ChoixMultipleMin > 0) && (question.ChoixMultipleMax > 0); LabelChoixMultipleMinMax.Text = "(" + question.ChoixMultipleMin + "/" + question.ChoixMultipleMax + ")"; LabelChoixSimple.Visible = (question.ChoixMultiple == false); LabelFin.Visible = question.Fin; LabelInstruction.Text = question.Instruction; LabelMessage.Text = question.Message; Reponses = PollAnswerCollection.GetByPollQuestionID(PollQuestionGUID); ReponseRankMax = Reponses.MaxRank(); if (Reponses.Count > 0) { Reponse0 = Reponses[0]; } if (Page.IsPostBack == false) { DropDownListTextAlign.DataSource = TextAlign(); DropDownListTextAlign.DataBind(); if (Reponses.Count > 0) { DropDownListTextAlign.SelectedValue = Reponses[0].AlignLeft == true ? ( string )TextAlign()[1] : ( string )TextAlign()[0]; } DropDownListVerticalHorizontal.DataSource = VerticalHorizontal(); DropDownListVerticalHorizontal.DataBind(); if (Reponses.Count > 0) { DropDownListVerticalHorizontal.SelectedValue = Reponses[0].Horizontal == true ? ( string )VerticalHorizontal()[1] : ( string )VerticalHorizontal()[0]; } } }
protected override void OnLoadComplete(EventArgs e) { Trace.Warn("OnLoadComplete"); Reponses = PollAnswerCollection.GetByPollQuestionID(PollQuestionGUID); }
/// <summary> /// !!!!!!!!!!!!! /// Attention !!! /// !!!!!!!!!!!!! /// Je ne peux pas utiliser cette fonction pour copier un questionnaire pour un utilisateur non authentifie /// On ne peut pas utiliser SessionState pour un utilisateur non authentifie /// lorsque l'utilisateur s'enregsitre mais qu'il n'est pas encore totalement authentifié /// SessionSate crée des Erreurs d'un autre monde !!! /// Si je voulais réintrégrer ce code dans Questionnaire/Copier.aspx il faudrait prendre cette précaution /// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! /// Ce jour là il y a 5 nouveaux utilisateurs qui ce sont enregistrés ! /// </summary> /// <param name="QuestionnaireID"></param> /// <param name="MembreGUID"></param> /// <param name="QuestionnaireExistantID"></param> /// <returns></returns> public static string CopierQuestionnaire(int QuestionnaireID, Guid MembreGUID, int QuestionnaireExistantID) { string message = ""; string msg = ""; if (QuestionnaireID == 0) { message += "Choisir un questionnaire à copier.<br/>"; } else { int status = 0; MemberInfo membre = MemberInfo.GetMemberInfo(MembreGUID); Questionnaire questionnaire = Questionnaire.GetQuestionnaire(QuestionnaireID); Questionnaire newquestionnaire = new Questionnaire(); // Calculer un nouveau CodeAcces avant de pouvoir Copier le Questionnaire ArrayList codes = QuestionnaireDAL.GetCodeAccessAll(); string codeAcces = Tools.CalculCodeAcces(membre.MembreID, codes).ToString(); // Creation d'un nouveau Questionnaire if (QuestionnaireExistantID == 0) { newquestionnaire.Description = questionnaire.Description; newquestionnaire.Style = questionnaire.Style; newquestionnaire.Valider = questionnaire.Valider; newquestionnaire.Fin = questionnaire.Fin; newquestionnaire.Anonyme = questionnaire.Anonyme; newquestionnaire.Compteur = questionnaire.Compteur; newquestionnaire.DateCreation = DateTime.Now; newquestionnaire.MembreGUID = MembreGUID; newquestionnaire.CodeAcces = int.Parse(codeAcces); message += "<br />Création du Questionnaire : " + newquestionnaire.Description + ":" + newquestionnaire.CodeAcces + "<br />"; if (HttpContext.Current.User.IsInRole("Administrateur")) { message += "Pour le membre : " + membre.NomUtilisateur + "/" + membre.Nom + "/" + membre.Prenom + "<br />"; } //BUG00020100215 //if ( SessionState.Limitations.LimiteQuestionnaires ) //{ // Tools.PageValidation( "La limite du nombre de Questionnaires : " + SessionState.Limitations.NombreQuestionnaires + " est atteinte.<br/>Contactez l'administrateur." ); //} status = Questionnaire.Create(newquestionnaire); if (status == 1) { msg += "Copie du questionnaire d'exemple.<br/>"; message += "Questionnaire créé correctement.<br/>"; //BUG00020100215 //SessionState.Limitations.AjouterQuestionnaire(); } else if (status == 2) { msg += "Erreur à la copie du questionnaire exemple.<br/>"; message += "Le Questionnaire existe déjà.<br/>"; } else { msg += "Erreur à la copie du questionnaire exemple.<br/>"; message += "Erreur sur la création du Questionnaire<br/>"; } } else // Questionnaire existant { newquestionnaire = Questionnaire.GetQuestionnaire(QuestionnaireExistantID); message += "<br />Copie du Questionnaire : " + newquestionnaire.Description + ":" + newquestionnaire.CodeAcces + "<br />"; message += "Pour le membre : " + membre.NomUtilisateur + "/" + membre.Nom + "/" + membre.Prenom + "<br />"; } int rank = 0; // Conserver le rang des Questions avec un biais MaxRank if (QuestionnaireExistantID != 0) { PollQuestionCollection questionsExistantes = PollQuestionCollection.GetByQuestionnaire(QuestionnaireExistantID); rank = questionsExistantes.MaxRank() + 1; } PollQuestionCollection questions = PollQuestionCollection.GetByQuestionnaire(QuestionnaireID); foreach (PollQuestion question in questions) { message += "----Création de la Question : " + question.Question + "<br />"; PollQuestion q = new PollQuestion(); q.Question = question.Question; q.Rank = question.Rank + rank; // Ajouter le Biais q.Societe = question.Societe; q.Obligatoire = question.Obligatoire; q.Fin = question.Fin; q.ChoixMultiple = question.ChoixMultiple; q.ChoixMultipleMin = question.ChoixMultipleMin; //BUG20100330 q.ChoixMultipleMax = question.ChoixMultipleMax; q.CreationDate = DateTime.Now; q.Instruction = question.Instruction; q.Message = question.Message; q.MessageHaut = question.MessageHaut; q.SautPage = question.SautPage; q.Tableau = question.Tableau; q.AlignementQuestion = question.AlignementQuestion; q.AlignementReponse = question.AlignementReponse; q.QuestionnaireID = newquestionnaire.QuestionnaireID; q.MembreGUID = membre.MembreGUID; //BUG00020100215 //// Tester les limitations avant d'ajouter la question //if ( SessionState.Limitations.LimiteQuestions ) //{ // Tools.PageValidation( "La limite du nombre de Questions : " + SessionState.Limitations.NombreQuestions + " est atteinte.<br/>Contactez l'administrateur." ); //} status = PollQuestion.Create(q); message += " status : " + status + "<br/>"; //BUG00020100215 //SessionState.Limitations.AjouterQuestion(); PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer reponse in reponses) { message += "----Création de la Réponse : " + reponse.Answer + "<br />"; PollAnswer a = new PollAnswer(); a.PollQuestionId = q.PollQuestionId; a.Answer = reponse.Answer; a.TypeReponse = reponse.TypeReponse; a.Width = reponse.Width; a.Rows = reponse.Rows; a.AlignLeft = reponse.AlignLeft; a.Horizontal = reponse.Horizontal; a.Obligatoire = reponse.Obligatoire; a.Rank = reponse.Rank; a.Score = reponse.Score; status = PollAnswer.Create(a); message += " status : " + status.ToString() + "<br />"; } } //foreach ( PollQuestion question in questions ) // Ne laisser faire qu'une copie //ButtonCopier.Visible = false; // // Attention BUG l'acces a SessionState cree un BUG d'un autre monde // // peut pas evaluer l'exepression car trop en haut de la pile //SessionState.Questionnaire = newquestionnaire; // Creation d'un nouveau Questionnaire //if ( QuestionnaireExistantID == 0 ) //{ // SessionState.Questionnaires.Add( newquestionnaire ); //} QuestionnaireID = 0; // fermer le formulaire QuestionnaireExistantID = 0; // Attention c'est faux Questionnaire.Create() retourn 1 si OK if (status != 0) { message += "Erreur à la copie du Questionnaire status : " + status.ToString() + "<br />"; } //ButtonAjouterQuestion.Visible = true; } //return message; return(msg); }
protected void Page_Load(object sender, EventArgs e) { if (IsPostBack == false) { ScoreCollection scores = ScoreCollection.GetScoreQuestionnaire(SessionState.Questionnaire.QuestionnaireID); if (scores.Count > 0) { PanelScore.Visible = true; int scoreTotal = 0; int scoreInterviewe = 0; foreach (PollQuestion question in SessionState.Questions) { PollAnswerCollection answers = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer answer in answers) { PollVoteCollection pvc = SessionState.Votes.FindByAnswerID(answer.PollAnswerId); if (pvc.Count > 0) { foreach (PollVote vote in pvc) { scoreInterviewe += answer.Score; } } scoreTotal += answer.Score; } } LabelResultat.Text = "Vous avez un score de " + scoreInterviewe.ToString() + " sur un total de " + scoreTotal.ToString(); foreach (Score score in scores) { if (scoreInterviewe >= score.ScoreMin && scoreInterviewe <= score.ScoreMax) { LabelScoreTexte.Text += score.ScoreTexte; } } } // Ne pas envoyer d'email quand c'est un intervieweur ou l'admin if (User.Identity.IsAuthenticated == false) { MemberInfo membre = MemberInfo.Get(SessionState.Questionnaire.MembreGUID); MemberSettings memberSettings = MemberSettings.GetMemberSettings(membre.NomUtilisateur); if (memberSettings.PrevenirNouvelleReponse) { string sujetEmail = "Nouvelle réponse au questionnaire " + SessionState.Questionnaire.Description; string bodyEmail = ""; if (SessionState.Questionnaire.Anonymat == false) { bodyEmail += "Nom : " + SessionState.Personne.Nom + "<br/>"; bodyEmail += "Prénom : " + SessionState.Personne.Prenom + "<br/>"; bodyEmail += "Email : " + SessionState.Personne.EmailBureau + "<br/>"; bodyEmail += "Téléphone : " + SessionState.Personne.TelephonePerso + "<br/>"; } Limitation limitations = new Limitation(membre.MembreGUID); bodyEmail += "<br/>Abonnement crédits réponses : " + (limitations.NombreReponses - limitations.Reponses).ToString() + "<br/>"; bodyEmail += "<br/>Accès à l'application :<br/>" + string.Format("<a href=\"{0}\" >{1}</a>", Utils.WebSiteUri, Utils.WebSiteUri) + "<br/>"; //Courriel.EnvoyerEmailNouvelleReponse( sujetEmail, bodyEmail ); Guid smtpMembreGUID = SessionState.Questionnaire.MembreGUID; Courriel.EnvoyerEmailNouvelleReponseAssynchrone(smtpMembreGUID, sujetEmail, bodyEmail); } } } }
// BUG10092009 remplace par l'utilisation du cache //private int QuestionnaireID //{ // get // { // if ( ViewState[ "QuestionnaireID" ] == null ) // { // ViewState[ "QuestionnaireID" ] = 0; // } // return ( int )ViewState[ "QuestionnaireID" ]; // } // set { ViewState[ "QuestionnaireID" ] = value; } //} //private int QuestionnaireExistantID //{ // get // { // if ( ViewState[ "QuestionnaireExistantID" ] == null ) // { // ViewState[ "QuestionnaireExistantID" ] = 0; // } // return ( int )ViewState[ "QuestionnaireExistantID" ]; // } // set { ViewState[ "QuestionnaireExistantID" ] = value; } //} //private Guid MembreGUID //{ // get // { // if ( ViewState[ "MembreGUID" ] == null ) // { // ViewState[ "MembreGUID" ] = Guid.Empty; // } // return ( Guid )ViewState[ "MembreGUID" ]; // } // set { ViewState[ "MembreGUID" ] = value; } //} //private int CodeAcces //{ // get // { // if ( ViewState[ "CodeAcces" ] == null ) // { // ViewState[ "CodeAcces" ] = 0; // } // return ( int )ViewState[ "CodeAcces" ]; // } // set { ViewState[ "CodeAcces" ] = value; } //} protected void Page_Load(object sender, System.EventArgs e) { if (IsPostBack == false) { if (Request.QueryString["MembreGUID"] != null) { Cache["MembreGUID"] = new Guid(Request.QueryString["MembreGUID"].ToString()); } else { ValidationMessage.Text += "Erreur pas de Questionnaire à copier !<br/>"; ValidationMessage.Visible = true; } Cache["CodeAcces"] = 0; if (Request.QueryString["CodeAcces"] != null) { Cache["CodeAcces"] = int.Parse(Request.QueryString["CodeAcces"].ToString()); } Cache["QuestionnaireExistantID"] = 0; if (Request.QueryString["QuestionnaireExistantID"] != null) { Cache["QuestionnaireExistantID"] = int.Parse(Request.QueryString["QuestionnaireExistantID"].ToString()); } if (( int )Cache["CodeAcces"] == 0 && (( int )Cache["QuestionnaireExistantID"]) == 0) { ValidationMessage.Text += "Erreur pas de code d'accès !<br/>"; ValidationMessage.Text += "Pas de Questionnaire à copier !<br/>"; ValidationMessage.Visible = true; } if (Request.QueryString["QuestionnaireID"] != null) { Cache["QuestionnaireID "] = int.Parse(Request.QueryString["QuestionnaireID"]); Questionnaire questionnaire = Questionnaire.GetQuestionnaire(( int )Cache["QuestionnaireID "]); ValidationMessage.Text += "Copie du Questionnaire : " + questionnaire.Description + ":" + questionnaire.CodeAcces + "<br />"; MemberInfo membre = MemberInfo.GetMemberInfo(( Guid )Cache["MembreGUID"]); if (User.IsInRole("Administrateur")) { ValidationMessage.Text += "Pour le membre : " + membre.NomUtilisateur + "/" + membre.Nom + "/" + membre.Prenom + "<br />"; } if (( int )Cache["CodeAcces"] != 0 && ( int )Cache["CodeAcces"] != questionnaire.CodeAcces && ( int )Cache["QuestionnaireExistantID"] == 0) { ValidationMessage.Text += "Nouveau code d'accès : " + ( int )Cache["CodeAcces"] + "<br />"; } ValidationMessage.Text += "<br />"; Cache["Questions"] = PollQuestionCollection.GetByQuestionnaire(( int )Cache["QuestionnaireID "]); foreach (PollQuestion question in (PollQuestionCollection)Cache["Questions"]) { ValidationMessage.Text += "- Question : " + question.Question + "<br />"; PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); foreach (PollAnswer reponse in reponses) { ValidationMessage.Text += "-- Réponse : " + reponse.Answer + "<br />"; } } if (( int )Cache["QuestionnaireExistantID"] != 0) { questionnaire = Questionnaire.GetQuestionnaire(( int )Cache["QuestionnaireExistantID"]); ValidationMessage.Text += "<br />"; ValidationMessage.Text += "Pour le Questionnaire : " + questionnaire.Description + ":" + questionnaire.CodeAcces + "<br />"; } ValidationMessage.Visible = true; } } }
void AfficherToutLesVotesEnBas(Guid pollQuestionID) { PanelReponsesEnBas.Controls.Clear(); bool afficherDateVote = SessionState.CheckBox["CheckBoxAfficherDateVote"]; PollQuestionCollection pollQuestionCollection = PollQuestionCollection.GetByQuestionnaire(SessionState.Questionnaire.QuestionnaireID); // On cumul les Questions cliquees par l'utilisateur if (pollQuestionID != Guid.Empty) { // La Collection se reduit a une seule Question PollQuestion pollQuestion = pollQuestionCollection.FindByPollQuestionID(pollQuestionID); // Cumuler les questions cliquees par l'utilisateur // Sauf si elle est deja dans QuestionsVotesEnBas // cela permet d'eviter de cumuler encore quand on passe aux formulaires print ou excel bool trouve = false; foreach (PollQuestion q in QuestionsVotesEnBas) { if (q.PollQuestionId == pollQuestionID) { trouve = true; break; } } if (trouve == false) { QuestionsVotesEnBas.Add(pollQuestion); } } else { // On prend toutes les questions du questionnaire QuestionsVotesEnBas = pollQuestionCollection; } // Si une sous-population est a l'etude on affiche que cette sous-population AME13072010 PersonneCollection personnesAffichees = new PersonneCollection(); PollVoteCollection[] tableauPollVotespersonnesAffichees; if (PersonnesOntReponduATout.Count > 0) { personnesAffichees = PersonnesOntReponduATout; // Il faut reafficher PanelReponse sinon il disparait // Attention ici on est appellé par ListBoxQui_SelectedIndexChange donc on doit faire un Clear PanelReponses.Controls.Clear(); AfficherEnHautReponsesDeSousPopulation(); tableauPollVotespersonnesAffichees = TableauVotesPersonnesOntReponduATout; } else { personnesAffichees = Personnes; tableauPollVotespersonnesAffichees = TableauVotesPersonnes; } foreach (PollQuestion question in QuestionsVotesEnBas) { PollAnswerCollection reponses = PollAnswerCollection.GetByPollQuestionID(question.PollQuestionId); Label labelQ = new Label(); labelQ.CssClass = "LabelQuestionStyle"; labelQ.Text = question.Rank.ToString() + " - " + question.Question; Table tableQ = new Table(); TableCell cellQ = new TableCell(); TableRow rowQ = new TableRow(); cellQ.Controls.Add(labelQ); rowQ.Controls.Add(cellQ); tableQ.Controls.Add(rowQ); PanelReponsesEnBas.Controls.Add(tableQ); foreach (PollAnswer reponse in reponses) { Table tableR = new Table(); TableCell cellR = new TableCell(); TableRow rowR = new TableRow(); Label labelR = new Label(); labelR.CssClass = "HyperLinkQuestionEnCoursStyle"; if (FormulaireEnModeExcel) { labelR.Text = "r : "; // ajouter un petit " r : " pour que ce con d'excel ne prenne pas ca pour une date } labelR.Text += reponse.Rank.ToString() + " - " + reponse.Answer; cellR.Controls.Add(labelR); rowR.Controls.Add(cellR); tableR.Controls.Add(rowR); PanelReponsesEnBas.Controls.Add(tableR); Table tableP = new Table(); int indexPollVotes = 0; foreach (Personne p in personnesAffichees) { PollVoteCollection pvc = tableauPollVotespersonnesAffichees[indexPollVotes].FindByAnswerID(reponse.PollAnswerId); string personne = FormatPersonne(p); foreach (PollVote pv in pvc) { // Table de Reponses des Interviewes TableCell cellP = new TableCell(); TableRow rowP = new TableRow(); if (afficherDateVote) { TableCell cellD = new TableCell(); cellD.Text = pv.CreationDate.ToString(); rowP.Cells.Add(cellD); } cellP.Text = personne; // OPT17072010 Strings.TexteToHTML( personne ); cellP.CssClass = "TableReponsePersonneStyle"; rowP.Cells.Add(cellP); tableP.Rows.Add(rowP); // Pour les reponses textuelles if (pv.Vote != "") { TableCell cellV = new TableCell(); cellV.Text = Strings.TexteToHTML(pv.Vote); rowP.Cells.Add(cellV); tableP.Rows.Add(rowP); } } if (pvc.Count > 0 /* votant */) { PanelReponsesEnBas.Controls.Add(tableP); } indexPollVotes += 1; } } } }