Exemplo n.º 1
0
        protected void Page_Load(object sender, EventArgs e)
        {
            if (Session["UserName"] == null || Session["SystemRole"] == null)
            {
                Response.Redirect("login.aspx");
            }

            if (!IsPostBack)
            {
                int deptId = Convert.ToInt32(Session["DeptId"]);
                if (Request.QueryString["id"] == "redirectSave")
                {
                    Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.success('تم حفظ بيانات اللجنة بنجاح', 'تم')", true);
                }
                if (Request.QueryString["id"] == "redirectUpdate")
                {
                    Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.success('تم تعديل بيانات اللجنة بنجاح', 'تم')", true);
                }
                if (Session["SystemRole"].ToString() == "5")
                {
                    btnaddNewCommittee.Visible = false;
                    LinkButton1.Visible        = false;
                }
                else
                {
                    btnaddNewCommittee.Visible = true;
                    LinkButton1.Visible        = true;
                }
                LoadCommittees();
                gvCommittee.DataSource = WebApiConsume.ShowCommittees(txtCommitteeName.Text.Trim().ToLower(), deptId);
                gvCommittee.DataBind();
            }
        }
Exemplo n.º 2
0
        protected void gvMembersOfCommittee_RowDeleting(object sender, GridViewDeleteEventArgs e)
        {
            int    memberId = Convert.ToInt32(gvMembersOfCommittee.Rows[e.RowIndex].Cells[1].Text.ToString());
            string apiUrl3  = Utilities.BASE_URL + "/api/CommitteeMembers";

            WebClient client = new WebClient();

            client.Headers["Content-type"] = "application/json";
            client.Encoding = Encoding.UTF8;
            int    committeeId = Convert.ToInt32(ViewState["CommitteeId"]);
            object input       = new
            {
                memberId    = memberId,
                committeeId = committeeId
            };

            string inputJson3 = (new JavaScriptSerializer()).Serialize(input);

            client.UploadString(apiUrl3 + "/DeleteCommitteeMembers?memberId=" + memberId + "&committeeId=" + committeeId, inputJson3);
            Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.success('تم مسح العضو من اللجنة بنجاح', 'تم')", true);


            gvMembersOfCommittee.DataSource = WebApiConsume.ShowCommitteeMembers(Convert.ToInt32(ViewState["CommitteeId"]));

            gvMembersOfCommittee.DataBind();
        }
Exemplo n.º 3
0
        protected void btnSearch_Click(object sender, EventArgs e)
        {
            int deptId = Convert.ToInt32(Session["DeptId"]);

            gvCommittee.DataSource = WebApiConsume.ShowCommittees(txtCommitteeName.Text.Trim().ToLower(), deptId);
            gvCommittee.DataBind();
        }
Exemplo n.º 4
0
        protected void btnLogin_Click(object sender, EventArgs e)
        {
            try
            {
                bool validate = WebApiConsume.login(Utilities.BASE_URL + "/api/Users", txtuserName.Text, txtPass.Text, out string UserName, out string LoginName, out int?SystemRole, out string DepartmentId);

                if (validate)
                {
                    Session["SystemRole"] = SystemRole;
                    Session["UserName"]   = UserName;
                    Session["Name"]       = LoginName;

                    Session["DeptId"] = DepartmentId;
                    Response.Redirect("Dashboard.aspx");
                }
                else
                {
                    ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('دخول خطأ. تأكد من اسم المستخدم والرقم السرى')", true);
                }
            }
            catch (Exception ex)
            {
                Response.Write(ex.Message);
            }
        }
Exemplo n.º 5
0
        protected void gvCommittee_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
        {
            int deptId = Convert.ToInt32(Session["DeptId"]);

            gvCommittee.EditIndex  = -1;
            gvCommittee.DataSource = WebApiConsume.ShowCommittees(txtCommitteeName.Text.Trim().ToLower(), deptId);
            gvCommittee.DataBind();
        }
Exemplo n.º 6
0
        protected void gvCommittee_PageIndexChanging(object sender, GridViewPageEventArgs e)
        {
            int deptId = Convert.ToInt32(Session["DeptId"]);

            gvCommittee.PageIndex  = e.NewPageIndex;
            gvCommittee.DataSource = WebApiConsume.ShowCommittees(txtCommitteeName.Text.Trim().ToLower(), deptId);
            gvCommittee.DataBind();
        }
Exemplo n.º 7
0
        private void LoadCommittees()
        {
            int deptId = Convert.ToInt32(Session["DeptId"]);

            this.gvCommittee.DataSource = WebApiConsume.ShowCommittees(txtCommitteeName.Text.Trim().ToLower(), deptId);
            this.gvCommittee.DataBind();
            ViewState["dt"]   = WebApiConsume.ShowCommittees(txtCommitteeName.Text.Trim().ToLower(), deptId);
            ViewState["sort"] = "Asc";
        }
Exemplo n.º 8
0
        public static int SendChatAlert(int CommiteeId)
        {
            List <User> users = WebApiConsume.ShowCommitteeMembersForChat(CommiteeId);

            foreach (var user in users)
            {
                try
                {
                    string    apiUrlFcm = BASE_URL + "/api/Fcm";
                    WebClient clienfcm  = new WebClient();
                    clienfcm.Headers["Content-type"] = "application/json";
                    clienfcm.Encoding = Encoding.UTF8;
                    object UserFcmo = new
                    {
                        Action_Id1  = CommiteeId,
                        Action_Id2  = "",
                        CreatedAt   = DateTime.Now.ToString("yyyy-MM-dd"),
                        Body        = "رسالة جديدة",
                        Title       = "غرفة النقاش",
                        Action_Type = "type_chat_notification"
                    };
                    string inputFcm = (new JavaScriptSerializer()).Serialize(UserFcmo);
                    clienfcm.UploadString(apiUrlFcm + "/SendMessage?_to=" + user.FCMToken, inputFcm);
                    string    apiUrlAlert = Utilities.BASE_URL + "/api/Committees";
                    WebClient client4     = new WebClient();

                    client4.Headers["Content-type"] = "application/json";
                    client4.Encoding = Encoding.UTF8;

                    Alert alert = new Alert()
                    {
                        Action_Id1  = CommiteeId,
                        Action_Id2  = null,
                        CreatedAt   = DateTime.Now.ToString("yyyy-MM-dd"),
                        Action_Type = 7,
                        Message     = "رسالة جديدة",
                        Title       = "غرفة النقاش",
                    };
                    string inputAlert = (new JavaScriptSerializer()).Serialize(alert);
                    client4.UploadString(apiUrlAlert + "/PostAlert", inputAlert);
                }
                catch (Exception ex)
                {
                    return(0);
                }
            }
            return(1);
        }
Exemplo n.º 9
0
        protected void gvCommittee_RowDeleting(object sender, GridViewDeleteEventArgs e)
        {
            int    committeeId = Convert.ToInt32(gvCommittee.Rows[e.RowIndex].Cells[1].Text);
            string committee   = WebApiConsume.DeleteCommittee(Utilities.BASE_URL + "/api/Committees", committeeId);

            if (committee == "")
            {
            }
            else
            {
                ScriptManager.RegisterClientScriptBlock(this.Page, this.Page.GetType(), "تم", "alert('تم مسح بيانات اللجنة بنجاح');", true);

                gvCommittee.DataSource = ShowDeptCommittees(Convert.ToInt32(Request.QueryString["dId"]));
                gvCommittee.DataBind();
            }
        }
Exemplo n.º 10
0
        protected void btnSave_Click(object sender, EventArgs e)
        {
            WebClient client = new WebClient();

            client.Headers["Content-type"] = "application/json";
            client.Encoding = Encoding.UTF8;
            if (Request.QueryString["status"] == "update")
            {
                ViewState["UserID"] = Request.QueryString["mId"];

                string apiUrlUser = Utilities.BASE_URL + "/api/Users";
                if (Session["SystemRole"].ToString() == "1")
                {
                    Committee.Models.User memberManger = new Models.User()
                    {
                        ID                  = Convert.ToInt32(Request.QueryString["mId"]),
                        Name                = txtMemberName.Text,
                        UserEmailId         = txtMemberEmail.Text,
                        Phone               = txtPhoneNumber.Text,
                        Title               = txtMemberJob.Text,
                        SecrtaryOfDept      = ddlmangerForDept?.SelectedItem?.Value,
                        WorkSide            = txtWorkSide.Text,
                        SystemRole          = Convert.ToInt32(ddlMemberType?.SelectedItem?.Value),
                        UserName            = txtuserNameOfManager.Text,
                        UserPassword        = Encryptor.MD5Hash(txtPasswordOfManager.Text),
                        Address             = txtAddress.Text,
                        UserImage           = "/" + ImgUpload?.PostedFile?.FileName,
                        ManagerOfDepartment = ddlmangerForDept?.SelectedItem?.Value
                    };

                    if (string.IsNullOrEmpty(txtuserNameOfManager.Text))
                    {
                        memberManger.UserName = memberManger.Name;
                    }
                    else
                    {
                        memberManger.UserName = txtuserNameOfManager.Text;
                    }
                    if (ViewState["Phone"].ToString() == txtPhoneNumber.Text.Trim().ToLower())
                    {
                        memberManger.Phone = txtPhoneNumber.Text.Trim().ToLower();
                        if (ImgUpload.PostedFile != null && ImgUpload.PostedFile.ContentLength > 0)
                        {
                            string fname = Path.GetFileName(ImgUpload.PostedFile.FileName);
                            ImgUpload.SaveAs(Server.MapPath(Path.Combine("~/MasterPage/Uploads/", fname)));
                            ImgUser.ImageUrl = "~/MasterPage/Uploads/" + fname;

                            memberManger.UserImage = "/" + fname;
                        }
                        else
                        {
                            memberManger.UserImage = ImgUser.ImageUrl.Replace("~/MasterPage/Uploads/", "");
                        }


                        string inputJson = (new JavaScriptSerializer()).Serialize(memberManger);
                        client.UploadString(apiUrlUser + "/PutUser?id=" + Convert.ToInt32(ViewState["UserID"]), inputJson);
                        Response.Redirect("MemberMangement.aspx?id=redirectUpdate");
                    }
                    else
                    {
                        bool phoneExist = WebApiConsume.ValidateUserPhone(txtPhoneNumber.Text.Trim().ToLower());
                        if (!phoneExist)
                        {
                            memberManger.Phone = txtPhoneNumber.Text.Trim().ToLower();
                            if (ImgUpload.PostedFile != null && ImgUpload.PostedFile.ContentLength > 0)
                            {
                                string fname = Path.GetFileName(ImgUpload.PostedFile.FileName);
                                ImgUpload.SaveAs(Server.MapPath(Path.Combine("~/MasterPage/Uploads/", fname)));
                                ImgUser.ImageUrl = "~/MasterPage/Uploads/" + fname;

                                memberManger.UserImage = "/" + fname;
                            }
                            else
                            {
                                memberManger.UserImage = ImgUser.ImageUrl;
                            }
                            string inputJson = (new JavaScriptSerializer()).Serialize(memberManger);

                            client.UploadString(apiUrlUser + "/PutUser?id=" + Convert.ToInt32(ViewState["UserID"]), inputJson);
                            Response.Redirect("MemberMangement.aspx?id=redirectUpdate");
                        }
                        else
                        {
                            Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.success('هذا الرقم موجود من قبل .من فضلك قك بتسجيل رقم اخر')", true);
                        }
                    }
                }
                else
                {
                    Committee.Models.User memberUpdate = new Models.User()
                    {
                        ID          = Convert.ToInt32(Request.QueryString["mId"]),
                        Name        = txtMemberName.Text,
                        UserEmailId = txtMemberEmail.Text,

                        Title               = txtMemberJob.Text,
                        SecrtaryOfDept      = Session["DeptId"].ToString(),
                        WorkSide            = txtWorkSide.Text,
                        SystemRole          = Convert.ToInt32(ddlMemberRole.SelectedItem.Value),
                        UserName            = txtUserName.Text,
                        UserPassword        = Encryptor.MD5Hash(txtPass.Text),
                        Address             = txtAddress.Text,
                        ManagerOfDepartment = Session["DeptId"].ToString(),

                        // UserImage = "/" + ImgUpload?.PostedFile?.FileName
                    };
                    if (string.IsNullOrEmpty(txtUserName.Text))
                    {
                        memberUpdate.UserName = memberUpdate.Name;
                    }
                    if (ViewState["Phone"].ToString() == txtPhoneNumber.Text.Trim().ToLower())
                    {
                        memberUpdate.Phone = txtPhoneNumber.Text.Trim().ToLower();
                        if (ImgUpload.PostedFile != null && ImgUpload.PostedFile.ContentLength > 0)
                        {
                            string fname = Path.GetFileName(ImgUpload.PostedFile.FileName);
                            ImgUpload.SaveAs(Server.MapPath(Path.Combine("~/MasterPage/Uploads/", fname)));
                            ImgUser.ImageUrl = "~/MasterPage/Uploads/" + fname;

                            memberUpdate.UserImage = "/" + fname;
                        }
                        else
                        {
                            memberUpdate.UserImage = ImgUser.ImageUrl.Replace("~/MasterPage/Uploads/", "");
                        }


                        string inputJson = (new JavaScriptSerializer()).Serialize(memberUpdate);
                        client.UploadString(apiUrlUser + "/PutUser?id=" + Convert.ToInt32(ViewState["UserID"]), inputJson);
                        Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.success('تم تعديل بيانات العضو بنجاح', 'تم')", true);
                    }
                    else
                    {
                        bool phoneExist = WebApiConsume.ValidateUserPhone(txtPhoneNumber.Text.Trim().ToLower());
                        if (!phoneExist)
                        {
                            memberUpdate.Phone = txtPhoneNumber.Text.Trim().ToLower();
                            if (ImgUpload.PostedFile != null && ImgUpload.PostedFile.ContentLength > 0)
                            {
                                string fname = Path.GetFileName(ImgUpload.PostedFile.FileName);
                                ImgUpload.SaveAs(Server.MapPath(Path.Combine("~/MasterPage/Uploads/", fname)));
                                ImgUser.ImageUrl = "~/MasterPage/Uploads/" + fname;

                                memberUpdate.UserImage = "/" + fname;
                            }
                            else
                            {
                                memberUpdate.UserImage = ImgUser.ImageUrl;
                            }
                            string inputJson = (new JavaScriptSerializer()).Serialize(memberUpdate);

                            client.UploadString(apiUrlUser + "/PutUser?id=" + Convert.ToInt32(ViewState["UserID"]), inputJson);
                            Response.Redirect("MemberMangement.aspx?id=redirectUpdate");
                        }
                        else
                        {
                            Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.success('هذا الرقم موجود من قبل .من فضلك قك بتسجيل رقم اخر')", true);
                        }
                    }
                }
            }

            else if (Request.QueryString["status"] == "new")
            {
                bool phoneExist = WebApiConsume.ValidateUserPhone(txtPhoneNumber.Text.Trim().ToLower());
                if (!phoneExist)
                {
                    if (ImgUpload.PostedFile != null && ImgUpload.PostedFile.ContentLength > 0)
                    {
                        string fname = Path.GetFileName(ImgUpload.PostedFile.FileName);
                        ImgUpload.SaveAs(Server.MapPath(Path.Combine("~/MasterPage/Uploads/", fname)));
                    }


                    string apiUrlMember = Utilities.BASE_URL + "/api/Users";

                    if (Session["SystemRole"].ToString() == "1")
                    {
                        int    systemRole = 0;
                        string secRole    = null;
                        if (ddlMemberType.SelectedItem.Value == "4")
                        {
                            systemRole = 4;
                            secRole    = ddlmangerForDept?.SelectedItem?.Value;
                        }
                        if (ddlMemberType.SelectedItem.Value == "5")
                        {
                            systemRole = 5;
                            secRole    = null;
                        }
                        Committee.Models.User memberManger = new Models.User()
                        {
                            Name                = txtMemberName.Text,
                            UserEmailId         = txtMemberEmail.Text,
                            Phone               = txtPhoneNumber.Text,
                            Title               = txtMemberJob.Text,
                            SecrtaryOfDept      = secRole,
                            WorkSide            = txtWorkSide.Text,
                            SystemRole          = systemRole,
                            UserName            = txtUserName.Text,
                            UserPassword        = Encryptor.MD5Hash(txtPasswordOfManager.Text),
                            Address             = txtAddress.Text,
                            UserImage           = "/" + ImgUpload?.PostedFile?.FileName,
                            ManagerOfDepartment = ddlmangerForDept?.SelectedItem?.Value,
                        };

                        if (string.IsNullOrEmpty(txtuserNameOfManager.Text))
                        {
                            memberManger.UserName = memberManger.Name;
                        }
                        else
                        {
                            memberManger.UserName = txtuserNameOfManager.Text;
                        }
                        string inputJsonMember = (new JavaScriptSerializer()).Serialize(memberManger);


                        client.UploadString(apiUrlMember + "/PostUser", inputJsonMember);
                    }
                    else
                    {
                        Committee.Models.User member = new Models.User()
                        {
                            Name                = txtMemberName.Text,
                            UserEmailId         = txtMemberEmail.Text,
                            Phone               = txtPhoneNumber.Text,
                            Title               = txtMemberJob.Text,
                            SecrtaryOfDept      = ddlmangerForDept?.SelectedItem?.Value,
                            WorkSide            = txtWorkSide.Text,
                            SystemRole          = 6,
                            UserName            = txtUserName.Text,
                            UserPassword        = Encryptor.MD5Hash(txtPass.Text),
                            Address             = txtAddress.Text,
                            UserImage           = "/" + ImgUpload?.PostedFile?.FileName,
                            ManagerOfDepartment = Session["DeptId"].ToString(),
                        };
                        if (string.IsNullOrEmpty(txtUserName.Text))
                        {
                            member.UserName = member.Name;
                        }
                        string inputJson = (new JavaScriptSerializer()).Serialize(member);


                        client.UploadString(apiUrlMember + "/PostUser", inputJson);
                    }



                    ResetControld();
                    Response.Redirect("MemberMangement.aspx?id=redirectSave");
                }
                else
                {
                    // Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.success('هذا الرقم موجود من قبل .من فضلك قك بتسجيل رقم اخر', 'تم')", true);
                    ScriptManager.RegisterClientScriptBlock(this.Page, this.Page.GetType(), "تم", "alert('هذا الرقم موجود من قبل .من فضلك قك بتسجيل رقم اخر');", true);
                }
            }
        }
Exemplo n.º 11
0
 protected void gvMembersOfCommittee_PageIndexChanging(object sender, GridViewPageEventArgs e)
 {
     gvMembersOfCommittee.PageIndex  = e.NewPageIndex;
     gvMembersOfCommittee.DataSource = WebApiConsume.ShowCommitteeMembers(Convert.ToInt32(ViewState["CommitteeId"]));
     gvMembersOfCommittee.DataBind();
 }
Exemplo n.º 12
0
        protected void btnAddChange_Click(object sender, EventArgs e)
        {
            List <int> membersList = new List <int>();

            foreach (GridViewRow row in gvMembersOfCommittee.Rows)
            {
                int member = Convert.ToInt32(row.Cells[1].Text);
                membersList.Add(member);
            }
            string apiUrl2  = Utilities.BASE_URL + "/api/CommitteesMembers";
            int    memberId = WebApiConsume.GetUserId(Utilities.BASE_URL + "/api/Users", ddlMemberChange.SelectedItem.Text);

            if (!membersList.Contains(memberId))
            {
                int?meetingId = WebApiConsume.GetMeetingId(Utilities.BASE_URL + "/api/Committees", Convert.ToInt32(ViewState["CommitteeId"]), ViewState["CreatedAt"].ToString());

                CommitteesMember input = new CommitteesMember
                {
                    CommitteeId   = Convert.ToInt32(ViewState["CommitteeId"]),
                    MemberId      = memberId,
                    CommitteeRole = 6,
                    UpdatedAt     = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
                    CreatedAt     = ViewState["CreatedAt"].ToString(),
                    MeetingId     = meetingId
                };
                try
                {
                    string apiUrlUser = Utilities.BASE_URL + "/api/Users";

                    string inputJson3 = (new JavaScriptSerializer()).Serialize(input);
                    WebApiConsume.PostCommitteeMembersUpdate(Utilities.BASE_URL + "/api/CommitteesMembers", inputJson3);


                    gvMembersOfCommittee.DataSource = WebApiConsume.ShowCommitteeMembers(Convert.ToInt32(ViewState["CommitteeId"]));

                    gvMembersOfCommittee.DataBind();
                    User   userFcm   = WebApiConsume.GetUserById(Utilities.BASE_URL + "/api/Users", memberId);
                    string apiUrlFcm = Utilities.BASE_URL + "/api/Fcm";
                    WebApiConsume.SendUserNotification(apiUrlFcm, Convert.ToInt32(ViewState["CommitteeId"]), txtCommitteeName.Text, userFcm.FCMToken);
                    SMS.SendSms("انت عضو فى لجنة " + "\n" + txtCommitteeName.Text + " المشكلة بتاريخ   " + "\n" + txtCommitteeDate.Text, userFcm.Phone);

                    foreach (GridViewRow row in gvMembersOfCommittee.Rows)
                    {
                        string mobile = row.Cells[3].Text;
                        SMS.SendSms("تم اضافة عضو للجنة " + "\n" + txtCommitteeName.Text + " المشكلة بتاريخ   " + "\n" + txtCommitteeDate.Text, mobile);
                    }
                    //  Utilities.SendMailToOnePerson(userFcm.UserEmailId, "انضمام للجنة", "تم اضافتك للجنة بنجاح");
                    ScriptManager.RegisterClientScriptBlock(this.Page, this.Page.GetType(), "تم", "alert('تم اضافة العضو لللجنة بنجاح');", true);
                }
                catch (Exception ex)
                {
                    string filePath = @Utilities.LogError_Path + "Error.txt";


                    using (StreamWriter writer = new StreamWriter(filePath, true))
                    {
                        writer.WriteLine("-----------------------------------------------------------------------------");
                        writer.WriteLine("Date : " + DateTime.Now.ToString());
                        writer.WriteLine();

                        while (ex != null)
                        {
                            writer.WriteLine(ex.GetType().FullName);
                            writer.WriteLine("Message : " + ex.Message);
                            writer.WriteLine("StackTrace : " + ex.StackTrace);

                            ex = ex.InnerException;
                        }
                    }
                }

                //Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.success('تم ارسال الاشعارات بنجاح', 'تم')", true);
            }
            else
            {
                Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.error('هذا العضو موجود بالفعل داخل اللجنه', 'تحذير')", true);
                //ScriptManager.RegisterClientScriptBlock(this.Page, this.Page.GetType(), "تحذير", "alert('هذا العضو موجود بالفعل داخل اللجنه');", true);
            }
        }
Exemplo n.º 13
0
        protected void btnAdd_Click(object sender, EventArgs e)
        {
            if ((ddlCommitteepresident.SelectedValue != "NULL" && ddlCommitteeSecrtary.SelectedValue != "NULL"))
            {
                selectedUsers.Add(Convert.ToInt32(ddlCommitteeSecrtary.SelectedItem.Value));
                selectedUsers.Add(Convert.ToInt32(ddlCommitteepresident.SelectedItem.Value));
            }
            else
            {
                // ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('من فضلك قم باختيار رئيس لجنه وسكرتير لجنه ')", true);
            }

            if (selectedUsers.Count != 0)
            {
                if (ddlMemberSelect?.SelectedItem?.Value != "NULL")
                {
                    if (selectedUsers.Contains(Convert.ToInt32(ddlMemberSelect?.SelectedItem?.Value)))
                    {
                        ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('هذا العضو موجود بالفعل ')", true);
                        //Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.error('هذا العضو موجود بالفعل ', 'تحذير')", true);
                    }
                    else
                    {
                        List <int> membersList = new List <int>();
                        string     apiUrl2     = Utilities.BASE_URL + "/api/CommitteesMembers";
                        int        memberId    = WebApiConsume.GetUserId(Utilities.BASE_URL + "/api/Users", ddlMemberSelect.SelectedItem.Text);
                        membersList.Add(memberId);
                        if (gvAddMember.Rows.Count != 0)
                        {
                            foreach (GridViewRow row in gvAddMember.Rows)
                            {
                                //membersList.Add(memberId);
                                if (!userGrids.Any(x => x.رقم_العضو == memberId))
                                {
                                    userGrids.Add(WebApiConsume.ShowCommitteeMembersForNew(memberId)[0]);

                                    gvAddMember.Visible = true;

                                    gvAddMember.DataSource = userGrids.Distinct().ToList();

                                    gvAddMember.DataBind();
                                    selectedUsers.Add(Convert.ToInt32(ddlMemberSelect.SelectedItem.Value));
                                    ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('تم ادخال العضو للجنة بنجاح')", true);
                                }
                            }
                        }
                        else
                        {
                            userGrids.Add(WebApiConsume.ShowCommitteeMembersForNew(memberId)[0]);

                            gvAddMember.Visible = true;

                            gvAddMember.DataSource = userGrids;

                            gvAddMember.DataBind();
                            selectedUsers.Add(Convert.ToInt32(ddlMemberSelect.SelectedItem.Value));
                            ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('تم ادخال العضو للجنة بنجاح')", true);
                        }
                        if (!membersList.Contains(memberId))
                        {
                            //CommitteesMember input = new CommitteesMember
                            //{
                            //    CommitteeId = Convert.ToInt32(ViewState["CommitteeId"]),
                            //    MemberId = memberId
                            //};
                            //string apiUrlUser = Utilities.BASE_URL + "/api/Users";

                            //string inputJson3 = (new JavaScriptSerializer()).Serialize(input);
                            //WebApiConsume.PostCommitteeMembersUpdate(Utilities.BASE_URL + "/api/CommitteesMembers", inputJson3);

                            //Page.ClientScript.RegisterStartupScript(this.GetType(), "toastr_message", "toastr.success('تم ادخال هذا العضو بنجاح', 'تم')", true);
                        }
                    }
                }
            }
        }
Exemplo n.º 14
0
        protected void btnSave_Click(object sender, EventArgs e)
        {
            if (Request.QueryString["status"] == "update" || Request.QueryString["status"] == "selected")
            {
                int committeeId = Convert.ToInt32(Request.QueryString["cId"]);

                List <UserGrid> data = WebApiConsume.ShowCommitteeMembers(committeeId);
                gvMembersOfCommittee.DataSource = data.Where(x => x != null).ToList();

                gvMembersOfCommittee.DataBind();
                ViewState["CommitteeId"] = committeeId;
                List <User> Members = WebApiConsume.GetUsers(Utilities.BASE_URL + "/api/Users/GetUsers");
                ddlMemberChange.DataSource     = Members;
                ddlMemberChange.DataTextField  = "Name";
                ddlMemberChange.DataValueField = "ID";
                ddlMemberChange.DataBind();
                divAddMember.Visible = true;
                List <UserGrid> data2 = WebApiConsume.ShowCommitteeMembers(committeeId);
                gvMembersOfCommittee.DataSource = data2.Where(x => x != null).ToList();

                gvMembersOfCommittee.DataBind();
                if (Session["SystemRole"].ToString() == "2")

                {
                    divAddMember.Visible = true;
                }

                Committee.Models.Committee committeeUpdate = new Models.Committee()
                {
                    CommitteeName             = txtCommitteeName.Text,
                    CommitteeDate             = txtCommitteeDateHidden.Value,
                    TypeId                    = Convert.ToInt32(ddlCommitteeClassification.SelectedItem.Value),
                    ActivityId                = Convert.ToInt32(ddlcommitteeStatus.SelectedItem.Value),
                    ImportanceId              = Convert.ToInt32(ddlCommitteeImportancy.SelectedItem.Value),
                    CommitteeTopic            = txtCommitteeTopic.Text,
                    CommitteeBasedOn          = txtCommitteeBasedON.Text,
                    CommitteeEnrollmentNumber = txtEnrollmentNumber.Text,
                    CommitteeEnrollmentDate   = txtEnrollmentDate.Text,
                    CommitteeManager          = ddlCommitteepresident.SelectedItem.Value == "NULL" ? null : ddlCommitteepresident.SelectedItem.Value,
                    CommitteeSecretary        = ddlCommitteeSecrtary.SelectedItem.Value == "NULL" ? null : ddlCommitteeSecrtary.SelectedItem.Value,
                    CommitteeInbox1           = txtInboxSide.Text,
                    DeptId                    = ddlCommitteeDept.SelectedItem.Value == "NULL" ? null : ddlCommitteeDept.SelectedItem.Value,
                    CommitteeId               = Convert.ToInt32(ViewState["CommitteeId"]),
                    UpdatedAt                 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
                    CreatedAt                 = ViewState["CreatedAt"].ToString()
                };

                string inputJson = (new JavaScriptSerializer()).Serialize(committeeUpdate);
                WebApiConsume.UpdateCommittee(Utilities.BASE_URL + "/api/Committees", Convert.ToInt32(ViewState["CommitteeId"]), inputJson);
                btnSave.Text = "حفظ";

                Response.Redirect("CommitteeMangement.aspx?id=redirectUpdate");

                //gvCommittee.EditIndex = -1;
            }
            else if (Request.QueryString["status"] == "new")
            {
                string isCommitteeExist = "";

                bool CommitteeExist = WebApiConsume.IsCommitteeExist(Utilities.BASE_URL + "/api/Committees", txtCommitteeName.Text.Trim().ToLower());
                if (CommitteeExist)
                {
                    ScriptManager.RegisterClientScriptBlock(this.Page, this.Page.GetType(), "تم", "alert('هذا الاسم موجود بالفعل من فضلك قم بادخال اسم اخر لللجنه');", true);
                }
                else
                {
                    if (ddlCommitteepresident.SelectedItem.Value != "NULL" || ddlCommitteeSecrtary.SelectedItem.Value != "NULL")
                    {
                        if (selectedUsers.Count == 0 && ddlCommitteeSecrtary.Visible == true && ddlCommitteepresident.Visible == true)
                        {
                            selectedUsers.Add(Convert.ToInt32(ddlCommitteeSecrtary.SelectedItem.Value));
                            selectedUsers.Add(Convert.ToInt32(ddlCommitteepresident.SelectedItem.Value));
                        }
                    }

                    Committee.Models.Committee committee = new Models.Committee()
                    {
                        CommitteeName             = txtCommitteeName.Text,
                        CommitteeDate             = txtCommitteeDateHidden.Value,
                        TypeId                    = Convert.ToInt32(ddlCommitteeClassification.SelectedItem.Value),
                        ActivityId                = Convert.ToInt32(ddlcommitteeStatus.SelectedItem.Value),
                        ImportanceId              = Convert.ToInt32(ddlCommitteeImportancy.SelectedItem.Value),
                        CommitteeTopic            = txtCommitteeTopic.Text,
                        CommitteeBasedOn          = txtCommitteeBasedON.Text,
                        CommitteeEnrollmentNumber = txtEnrollmentNumber.Text,
                        CommitteeEnrollmentDate   = txtEnrollmentDate.Text,
                        CommitteeManager          = ddlCommitteepresident.SelectedItem.Value == "NULL" ? null : ddlCommitteepresident.SelectedItem.Value,
                        CommitteeSecretary        = ddlCommitteeSecrtary.SelectedItem.Value == "NULL" ? null : ddlCommitteeSecrtary.SelectedItem.Value,
                        CommitteeInbox1           = txtInboxSide.Text,
                        DeptId                    = ddlCommitteeDept.SelectedItem.Value == "NULL" ? null : ddlCommitteeDept.SelectedItem.Value,
                        CreatedAt                 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
                        UpdatedAt                 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
                    };

                    string inputJson = (new JavaScriptSerializer()).Serialize(committee);
                    WebApiConsume.PostCommittee(Utilities.BASE_URL + "/api/Committees", inputJson);


                    List <CommitteesMember> committeesMembers = new List <CommitteesMember>();
                    int Committee     = WebApiConsume.GetCommitteeId(Utilities.BASE_URL + "/api/Committees", txtCommitteeName.Text.Trim().ToLower());
                    int committeeRole = 0;

                    for (int i = 0; i < selectedUsers.Count; i++)
                    {
                        // client.DownloadString(apiUrl3 + "/GetCommitteeId?committeeName=" + txtCommitteeName.Text);

                        if (i == 0)
                        {
                            committeeRole = 4;
                        }
                        if (i == 1)
                        {
                            committeeRole = 5;
                        }
                        if (i > 1)
                        {
                            committeeRole = 6;
                        }
                        committeesMembers.Add(new CommitteesMember()
                        {
                            MemberId      = selectedUsers[i],
                            CommitteeId   = Committee,
                            CommitteeRole = committeeRole,
                            CreatedAt     = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
                            UpdatedAt     = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
                        });
                    }

                    string inputJson2 = (new JavaScriptSerializer()).Serialize(committeesMembers);
                    //WebClient client = new WebClient();

                    WebApiConsume.PostCommitteeMembers(Utilities.BASE_URL + "/api/CommitteesMembers", inputJson2);

                    foreach (var member in committeesMembers)
                    {
                        object memb = new
                        {
                            id = member.MemberId,
                        };

                        try
                        {
                            User userFcm = WebApiConsume.GetUserById(Utilities.BASE_URL + "/api/Users", member.MemberId);
                            WebApiConsume.SendUserNotification(Utilities.BASE_URL + "/api/Fcm", member.CommitteeId, txtCommitteeName.Text, userFcm.FCMToken);
                            //  SMS.SendSms("تم إنشاء لجنة جديده : " + "\n" + txtCommitteeName.Text, userFcm.Phone);
                            if (userFcm.Phone != "" || userFcm.Phone != null)
                            {
                                SMS.SendSms("تم إنشاء لجنه " + "\n" + txtCommitteeName.Text + " المشكلة بتاريخ   " + "\n" + txtCommitteeDate.Text, userFcm.Phone);
                                //  Utilities.SendMailToOnePerson(userFcm.UserEmailId, "انضمام للجنة", "تم اضافتك للجنة بنجاح");
                            }
                        }
                        catch (Exception ex)
                        {
                            string filePath = @Utilities.LogError_Path + "Error.txt";


                            using (StreamWriter writer = new StreamWriter(filePath, true))
                            {
                                writer.WriteLine("-----------------------------------------------------------------------------");
                                writer.WriteLine("Date : " + DateTime.Now.ToString());
                                writer.WriteLine();

                                while (ex != null)
                                {
                                    writer.WriteLine(ex.GetType().FullName);
                                    writer.WriteLine("Message : " + ex.Message);
                                    writer.WriteLine("StackTrace : " + ex.StackTrace);

                                    ex = ex.InnerException;
                                }
                            }
                        }
                        string apiUrlAlert = "";
                        WebApiConsume.PostAlert(Utilities.BASE_URL + "/api/Committees", member.CommitteeId, member.MemberId);
                    }
                    ViewState["update"] = 0;
                    selectedUsers       = new List <int>();
                    userGrids           = new List <UserGrid>();
                    Response.Redirect("CommitteeMangement.aspx?id=redirectSave");
                }
            }
        }
Exemplo n.º 15
0
        protected void Page_Load(object sender, EventArgs e)
        {
            if (Session["UserName"] == null || Session["SystemRole"] == null)
            {
                Response.Redirect("login.aspx");
            }
            txtCommitteeDate.Text = txtCommitteeDateHidden.Value;
            if (!IsPostBack)
            {
                txtCommitteeDate.Text = "";
                divAddMember.Visible  = false;
                selectedUsers         = new List <int>();
                userGrids             = new List <UserGrid>();
                List <User> Members = WebApiConsume.GetUsers(Utilities.BASE_URL + "/api/Users/GetUsers");


                ddlMemberSelect.DataSource     = Members;
                ddlMemberSelect.DataTextField  = "Name";
                ddlMemberSelect.DataValueField = "ID";
                ddlMemberSelect.DataBind();
                ddlMemberSelect.Items.Insert(0, new ListItem("أختر من القائمه", "NULL"));
                ddlCommitteeSecrtary.DataSource     = Members;
                ddlCommitteeSecrtary.DataTextField  = "Name";
                ddlCommitteeSecrtary.DataValueField = "ID";
                ddlCommitteeSecrtary.DataBind();
                ddlCommitteeSecrtary.Items.Insert(0, new ListItem("أختر من القائمه", "NULL"));

                ddlCommitteepresident.DataSource     = Members;
                ddlCommitteepresident.DataTextField  = "Name";
                ddlCommitteepresident.DataValueField = "ID";
                ddlCommitteepresident.DataBind();
                ddlCommitteepresident.Items.Insert(0, new ListItem("أختر من القائمه", "NULL"));


                List <Committee.Models.Department> departments = WebApiConsume.GetDepartments(Utilities.BASE_URL + "/api/Deapartments/GetDepartments");


                ddlCommitteeDept.DataSource     = departments;
                ddlCommitteeDept.DataTextField  = "DeptName";
                ddlCommitteeDept.DataValueField = "DeptId";
                ddlCommitteeDept.DataBind();
                ddlCommitteeDept.SelectedValue = Session["DeptId"].ToString();
                ddlCommitteeDept.Enabled       = false;
                ddlCommitteeDept.Items.Insert(0, new ListItem("أختر من القائمه", "NULL"));
                int committeeId = Convert.ToInt32(Request.QueryString["cId"]);

                List <UserGrid> data = WebApiConsume.ShowCommitteeMembers(committeeId);
                if (Request.QueryString["status"] == "selected")
                {
                    gvMeeting.DataSource = ShowMeetings(Convert.ToInt32(Request.QueryString["cId"]));
                    gvMeeting.DataBind();



                    if (data.Count != 0)
                    {
                        lblmembersOfCommittee.Visible = true;
                        lblmembersOfCommittee.Text    = "الاعضاء المشتركون فى اللجنة";
                    }
                    else
                    {
                        lblmembersOfCommittee.Visible = true;
                        lblmembersOfCommittee.Text    = "لا يوجد اعضاء مشتركون فى  هذه اللجنة";
                    }
                    gvMembersOfCommittee.DataSource = data.Where(x => x != null).ToList();

                    gvMembersOfCommittee.DataBind();
                    ddlMemberChange.Visible        = true;
                    ddlMemberChange.DataSource     = Members;
                    ddlMemberChange.DataTextField  = "Name";
                    ddlMemberChange.DataValueField = "ID";
                    ddlMemberChange.DataBind();
                    ddlMemberChange.Items.Insert(0, new ListItem("أختر من القائمه", "NULL"));
                    gvMembersOfCommittee.Visible = true;
                    divAddMember.Visible         = true;
                }

                gvMembersOfCommittee.DataSource = data.Where(x => x != null).ToList();

                gvMembersOfCommittee.DataBind();
                LabelddlCommitteepresident.Visible = true;
                LabeddlCommitteeSecrtary.Visible   = true;
                ddlCommitteeSecrtary.Visible       = true;
                ddlCommitteepresident.Visible      = true;
                divAddMembers.Visible          = true;
                ddlMemberSelect.Visible        = true;
                ddlMemberSelect.DataSource     = Members;
                ddlMemberSelect.DataTextField  = "Name";
                ddlMemberSelect.DataValueField = "ID";
                ddlMemberSelect.DataBind();
                ddlMemberSelect.Items.Insert(0, new ListItem("أختر من القائمه", "NULL"));

                if (Request.QueryString["status"] == "selected")
                {
                    gvMeeting.DataSource = ShowMeetings(Convert.ToInt32(Request.QueryString["cId"]));
                    gvMeeting.DataBind();


                    committeeId = Convert.ToInt32(Request.QueryString["cId"]);

                    data = WebApiConsume.ShowCommitteeMembers(committeeId);
                    if (data.Count != 0)
                    {
                        lblmembersOfCommittee.Visible   = true;
                        lblmembersOfCommittee.Text      = "الاعضاء المشتركون فى اللجنة";
                        gvMembersOfCommittee.DataSource = data.Where(x => x != null).ToList();
                        gvMembersOfCommittee.DataBind();
                    }
                    else
                    {
                        lblmembersOfCommittee.Visible = true;
                        lblmembersOfCommittee.Text    = "لا يوجد اعضاء مشتركون فى  هذه اللجنة";
                    }
                }

                if (Request.QueryString["status"] == "update" || Request.QueryString["status"] == "selected")

                {
                    gvMeeting.Visible = true;
                    List <MeetingSearch> ms = ShowMeetings(Convert.ToInt32(Request.QueryString["cId"]));
                    if (ms.Count != 0)
                    {
                        lblgvMeeting.Visible = true;
                        lblgvMeeting.Text    = "اجتماعات اللجنة";
                        gvMeeting.DataSource = ms;
                        gvMeeting.DataBind();
                    }
                    else
                    {
                        lblgvMeeting.Visible = true;
                        lblgvMeeting.Text    = " لا يوجد اجتماعات لهذه اللجنة";
                    }

                    data = WebApiConsume.ShowCommitteeMembers(Convert.ToInt32(Request.QueryString["cId"]));
                    if (data.Count != 0)
                    {
                        lblmembersOfCommittee.Visible   = true;
                        lblmembersOfCommittee.Text      = "الاعضاء المشتركون فى اللجنة";
                        gvMembersOfCommittee.DataSource = data.Where(x => x != null).ToList();
                        gvMembersOfCommittee.DataBind();
                        lblmembersOfCommittee.Visible = true;
                    }
                    else
                    {
                        lblmembersOfCommittee.Visible = true;
                        lblmembersOfCommittee.Text    = "لا يوجد اعضاء مشتركون فى  هذه اللجنة";
                    }


                    lblAddCommitteetitle.Text = "تعديل اللجنة";
                    lblAddCommitteeh2.Text    = "تعديل اللجنة";
                    List <CommitteeSearchUpdate> committeesUpdate = new List <CommitteeSearchUpdate>();
                    string apiUrl3 = Utilities.BASE_URL + "/api/Committees";

                    WebClient client = new WebClient();
                    client.Headers["Content-type"] = "application/json";
                    client.Encoding = Encoding.UTF8;
                    int cId = Convert.ToInt32(Request.QueryString["cId"]);
                    ViewState["CommitteeId"] = cId;
                    Committee.Models.CommitteeRetrieveUpdate Committee = (new JavaScriptSerializer()).Deserialize <Committee.Models.CommitteeRetrieveUpdate>(client.DownloadString(apiUrl3 + "/GetCommitteeByIdForWeb?committeeId=" + cId.ToString()));
                    txtCommitteeDate.Text = Committee.CommitteeDate;
                    ddlCommitteeClassification.SelectedValue = Committee.Type.Id.ToString();
                    ddlCommitteeImportancy.SelectedValue     = Committee.Importance.Id.ToString();
                    ddlcommitteeStatus.SelectedValue         = Committee.Activity.Id.ToString();
                    txtCommitteeTopic.Text              = Committee.CommitteeTopic;
                    txtCommitteeBasedON.Text            = Committee.CommitteeBasedOn;
                    txtEnrollmentNumber.Text            = Committee.CommitteeEnrollmentNumber;
                    txtEnrollmentDate.Text              = Committee.CommitteeEnrollmentDate;
                    txtInboxSide.Text                   = Committee.CommitteeInbox1;
                    ddlCommitteeDept.SelectedValue      = Committee?.Department?.DeptId.ToString();
                    txtCommitteeName.Text               = Committee.CommitteeName;
                    ddlCommitteepresident.SelectedValue = Committee.CommitteeManager;
                    ddlCommitteeSecrtary.SelectedValue  = Committee.CommitteeSecretary;
                    ViewState["CreatedAt"]              = Committee.CreatedAt;
                    //gvCommittee.DataSource = ShowCommittees();
                    //gvCommittee.DataBind();
                }
                else
                {
                    lblAddCommitteetitle.Text = "اضافة لجنة جديدة";
                    lblAddCommitteeh2.Text    = "اضافة لجنة جديدة";
                }
                if (Request.QueryString["status"] == "selected")
                {
                    lblAddCommitteetitle.Text = "عرض اللجنة";
                    lblAddCommitteeh2.Text    = "عرض اللجنة";
                    List <CommitteeSearchUpdate> committeesUpdate = new List <CommitteeSearchUpdate>();
                    string apiUrl3 = Utilities.BASE_URL + "/api/Committees";

                    WebClient client = new WebClient();
                    client.Headers["Content-type"] = "application/json";
                    client.Encoding = Encoding.UTF8;
                    int cId = Convert.ToInt32(Request.QueryString["cId"]);
                    ViewState["CommitteeId"] = cId;
                    Committee.Models.CommitteeRetrieveUpdate Committee = (new JavaScriptSerializer()).Deserialize <Committee.Models.CommitteeRetrieveUpdate>(client.DownloadString(apiUrl3 + "/GetCommitteeByIdForWeb?committeeId=" + cId.ToString()));
                    txtCommitteeDate.Text    = Committee.CommitteeDate;
                    txtCommitteeDate.Enabled = false;
                    ddlCommitteeClassification.SelectedValue = Committee.Type.Id.ToString();
                    ddlCommitteeClassification.Enabled       = false;
                    ddlCommitteeImportancy.SelectedValue     = Committee.Importance.Id.ToString();
                    ddlCommitteeImportancy.Enabled           = false;
                    ddlcommitteeStatus.SelectedValue         = Committee.Activity.Id.ToString();
                    ddlcommitteeStatus.Enabled          = false;
                    txtCommitteeTopic.Text              = Committee.CommitteeTopic;
                    txtCommitteeTopic.Enabled           = false;
                    txtCommitteeBasedON.Text            = Committee.CommitteeBasedOn;
                    txtCommitteeBasedON.Enabled         = false;
                    txtEnrollmentNumber.Text            = Committee.CommitteeEnrollmentNumber;
                    txtEnrollmentNumber.Enabled         = false;
                    txtEnrollmentDate.Text              = Committee.CommitteeEnrollmentDate;
                    txtEnrollmentDate.Enabled           = false;
                    txtInboxSide.Text                   = Committee.CommitteeInbox1;
                    txtInboxSide.Enabled                = false;
                    ddlCommitteeDept.SelectedValue      = Committee?.Department?.DeptId.ToString();
                    ddlCommitteeDept.Enabled            = false;
                    txtCommitteeName.Text               = Committee.CommitteeName;
                    txtCommitteeName.Enabled            = false;
                    ddlCommitteepresident.SelectedValue = Committee.CommitteeManager;
                    ddlCommitteepresident.Enabled       = false;
                    ddlCommitteeSecrtary.SelectedValue  = Committee.CommitteeSecretary;
                    ddlCommitteeSecrtary.Enabled        = false;
                    btnSave.Visible      = false;
                    divAddMember.Visible = false;
                }
                if (Request.QueryString["status"] == "update")
                {
                    divAddMember.Visible           = true;
                    divAddMembers.Visible          = false;
                    ddlMemberChange.Visible        = true;
                    ddlMemberChange.DataSource     = Members;
                    ddlMemberChange.DataTextField  = "Name";
                    ddlMemberChange.DataValueField = "ID";
                    ddlMemberChange.DataBind();
                    ddlMemberChange.Items.Insert(0, new ListItem("أختر من القائمه", "NULL"));
                }
                if (Session["SystemRole"].ToString() == "1" && Request.QueryString["status"] == "update")
                {
                    divAddMember.Visible  = false;
                    divAddMembers.Visible = false;
                }
            }
        }