Wednesday, 7 August 2013

CRUD in Gridview (Add, Edit, Delete in Gridview)

Hi all,
     All the developer need to work with the Gridview often in the project. so here I am giving you the idea how to do CRUD operation in Gridview.

First I have bind the data from the database using linq then I am editing the row using Gridview's EditItemTemplate to edit the data into the Gridview itself.

 Second we can edit the data using popup window, so I have used fancybox to do so.


Here is the code with requried Javascript.

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <link href="Styles/Style.css" rel="stylesheet" type="text/css" />
    <script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
    <script src="Scripts/jquery.hovercard.js" type="text/javascript"></script>
    <script src="fancybox/jquery.fancybox-1.3.4.js" type="text/javascript"></script>
    <link href="fancybox/jquery.fancybox-1.3.4.css" rel="stylesheet" type="text/css" />
    <script type="text/javascript">
        function ChangeStatus(ID) {
            // To make Active User Inactive and vice a versa
            $.ajax({
                type: "POST",
                url: "Default.aspx/ChangeStatus",
                data: '{"UserID": "' + ID + '"}',
                contentType: "application/json; charset=utf-8",
                dataType: "json",
                success: function () {
                    window.location = "Default.aspx";
                }
            });
        }
    </script>
    <script type="text/javascript">
        $(document).ready(function () {
            GridOperate();
            Sys.WebForms.PageRequestManager.getInstance().add_endRequest(GridOperate);
            $(".opendialog").fancybox({
                'titlePosition': 'inside',
                'transitionIn': 'none',
                'transitionOut': 'none',
                enableEscapeButton: false,
                hideOnOverlayClick: false,
                titleShow: false
            });
        });
        function GridOperate(sender, args) {
            // To check and uncheck all checkbox of grid
            $("#<%=Gv.ClientID%> input[id*='chkSelectAll']:checkbox").click(function () {
                if ($(this).is(':checked'))
                    $("#<%=Gv.ClientID%> input[id*='CheckSelect']:checkbox").attr('checked', true);
                else
                    $("#<%=Gv.ClientID%> input[id*='CheckSelect']:checkbox").attr('checked', false);
            });
            //To Create Hover popup in the grid
            $(".customer-number,.number_hover").hover(function () {
                $(this).parent().find(".number_hover").show();
            }, function () {
                $(".number_hover").hide();
            });
            // To apply proper style to Hover popup
            $('.contentTable td').each(function () {
                $(this).find('.downarrow_customer_tooltip').css('left', ($(this).width() / 2) - 10 + 'px');
                $(this).find('.number_hover p').css('width', ($(this).width()) + 'px');
                $(this).find('.number_hover').css('width', ($(this).width()) - 14 + 'px');
            })
        }
        function OpenDialog(ID) {         
                var returnpath = window.location;              
                $(".frmPass").attr('src', 'EditUser.aspx?UserID=' + ID + '&ReturnPath=' + returnpath);
                  $(".OpenDialog").width(900);
                  $.fancybox.center();
                  $(".OpenDialog").fancybox();
        }
    </script>
    <style type="text/css">
    upload.scroll {
       height: 200px;
       width: 300px;
       overflow: auto;
    }
</style>
</head>
<body>
    <form id="form1" runat="server">
    <asp:ScriptManager ID="sm" runat="server">
    </asp:ScriptManager>
   
    <asp:UpdatePanel ID="UpdatePanel1" runat="server">
    <Triggers>
  <asp:PostBackTrigger ControlID="Gv" />
 </Triggers>
        <ContentTemplate>
            <div>
                <table class="contentTable login_table" style="margin-top: 0px; width: 100%">
                    <tbody>
                    <tr><td><asp:Button ID="btnDelete" runat="server" Text="Delete Selected" style="background-color:#990000;color:White;font-weight:bold;"
                            onclick="btnDelete_Click" OnClientClick="JavaScript:return confirm('Are you sure want to delete the selected items');" /></td></tr>
                        <tr>
                            <td>
                                <asp:GridView ID="Gv" runat="server" Width="100%" AutoGenerateColumns="False" RowStyle-HorizontalAlign="Center"
                                AllowPaging="True" onpageindexchanging="Gv_PageIndexChanging" PageSize="4"
                                    AllowSorting="True" onrowediting="Gv_RowEditing" onsorting="Gv_Sorting"
                                    onrowupdating="Gv_RowUpdating" onrowcancelingedit="Gv_RowCancelingEdit"
                                    onrowdeleting="Gv_RowDeleting" ShowFooter="True"
                                    FooterStyle-HorizontalAlign="Center" onrowcommand="Gv_RowCommand"
                                    onrowdatabound="Gv_RowDataBound" CssClass="Itemgrid" CellPadding="4"
                                    ForeColor="#333333" GridLines="None" BorderWidth="2" >
                                    <AlternatingRowStyle BackColor="White" />
                                    <Columns>
                                        <asp:TemplateField HeaderText="" Visible="true" ItemStyle-Width="25px">
                                            <HeaderStyle CssClass="leftcorner" />
                                            <HeaderTemplate>
                                                <div class="gk" style="margin-left: 0px">
                                                    <input type="checkbox" id="chkSelectAll" name="chkSelectAll" runat="server" style="-webkit-appearance: checkbox;
                                                        cursor: pointer;" class="styled headercheck" />
                                                </div>
                                            </HeaderTemplate>
                                            <ItemTemplate>
                                                <div style="margin-left: 0px">
                                                <asp:CheckBox ID="CheckSelect" runat="server" />
                                                    <asp:HiddenField ID="hdnId" runat="server" Value='<%# Eval("ID") %>' />
                                                </div>
                                            </ItemTemplate>
                                            <ItemStyle Width="25px" />
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="Sr No" Visible="true" ItemStyle-Width="50px">
                                            <ItemTemplate>
                                                <%#Container.DataItemIndex + 1 %>
                                            </ItemTemplate>
                                            <ItemStyle Width="50px" />
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="FirstName" SortExpression="FirstName">
                                            <HeaderStyle HorizontalAlign="Center" VerticalAlign="Middle" CssClass="searchStoreCol04" />
                                            <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" />
                                            <FooterTemplate>
                                                <asp:TextBox ID="txtAddFirstName" runat="server"></asp:TextBox>
                                            </FooterTemplate>                                           
                                            <EditItemTemplate>
                                            <asp:TextBox ID="txtFirstName" runat="server" Text='<%# Eval("FirstName") %>'></asp:TextBox>
                                            </EditItemTemplate>
                                            <ItemTemplate>
                                                <div class="cust_number">
                                                    <asp:Label CssClass="customer-number" ID="lblFirstName" runat="server" Text='<%# Eval("FirstName") %>'></asp:Label>
                                                    <%# Convert.ToString(Eval("FirstName")) != "" ? "<div class=\"number_hover cf matched_tool\"><em>First Name</em><p>" + Eval("FirstName") + "<br /></p><span class=\"downarrow_customer_tooltip\"></span></div>" : ""%>
                                                </div>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="LastName" SortExpression="LastName">
                                            <HeaderStyle HorizontalAlign="Center" VerticalAlign="Middle" CssClass="searchStoreCol04" />
                                            <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" />
                                            <EditItemTemplate>
                                                <asp:TextBox ID="txtLastName" runat="server" Text='<%# Eval("LastName") %>'></asp:TextBox>
                                            </EditItemTemplate>
                                            <FooterTemplate>
                                                <asp:TextBox ID="txtAddLastName" runat="server"></asp:TextBox>
                                            </FooterTemplate>
                                            <ItemTemplate>
                                                <div class="cust_number">
                                                    <asp:Label CssClass="customer-number" ID="lblLastName" runat="server" Text='<%# Eval("LastName") %>'></asp:Label>
                                                    <%# Convert.ToString(Eval("LastName")) != "" ? "<div class=\"number_hover cf matched_tool\"><em>Last Name</em><p>" + Eval("LastName") + "<br /></p><span class=\"downarrow_customer_tooltip\"></span></div>" : ""%>
                                                </div>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="Address" SortExpression="Address">
                                            <HeaderStyle HorizontalAlign="Center" VerticalAlign="Middle" CssClass="searchStoreCol04" />
                                            <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" />
                                            <EditItemTemplate>
                                                <asp:TextBox ID="txtAddress" runat="server" Text='<%# Eval("Address") %>'></asp:TextBox>
                                            </EditItemTemplate>
                                            <FooterTemplate>
                                                <asp:TextBox ID="txtAddAddress" runat="server"></asp:TextBox>
                                            </FooterTemplate>
                                            <ItemTemplate>
                                                <div class="cust_number">
                                                    <asp:Label CssClass="customer-number" ID="lblAddress" runat="server" Text='<%# Eval("Address") %>'></asp:Label>
                                                    <%# Convert.ToString(Eval("Address")) != "" ? "<div class=\"number_hover cf matched_tool\"><em>Address</em><p>" + Eval("Address") + "<br /></p><span class=\"downarrow_customer_tooltip\"></span></div>" : ""%>
                                                </div>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="ContactNo" SortExpression="ContactNo">
                                            <HeaderStyle HorizontalAlign="Center" VerticalAlign="Middle" CssClass="searchStoreCol04" />
                                            <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" />
                                            <EditItemTemplate>
                                                <asp:TextBox ID="txtContactNo" runat="server" Text='<%# Eval("ContactNo") %>'></asp:TextBox>
                                            </EditItemTemplate>
                                            <FooterTemplate>
                                                <asp:TextBox ID="txtAddContactNo" runat="server"></asp:TextBox>
                                            </FooterTemplate>
                                            <ItemTemplate>
                                                <div class="cust_number">
                                                    <asp:Label CssClass="customer-number" ID="lblContactNo" runat="server" Text='<%# Eval("ContactNo") %>'></asp:Label>
                                                    <%# Convert.ToString(Eval("ContactNo")) != "" ? "<div class=\"number_hover cf matched_tool\"><em>ContactNo</em><p>" + Eval("ContactNo") + "<br /></p><span class=\"downarrow_customer_tooltip\"></span></div>" : ""%>
                                                </div>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="Image" SortExpression="Image">
                                            <HeaderStyle HorizontalAlign="Center" VerticalAlign="Middle" Width="110px" />
                                            <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" />
                                            <EditItemTemplate>
                                                <asp:FileUpload ID="fupEditImage" runat="server" />
                                            </EditItemTemplate>
                                            <FooterTemplate>
                                                <asp:FileUpload ID="fupAddImage" runat="server" Width="100px" style="width:100px;" />
                                            </FooterTemplate>
                                            <ItemTemplate>
                                                <div class="cust_number">
                                                <asp:Image ID="imgImage" runat="server" Height="100" Width="100" ImageUrl='<%# "ImageHandler.ashx?ID="+ Eval("ID") %>' />                                                   
                                                    <%# Convert.ToString(Eval("Image")) != "" ? "<div class=\"number_hover cf matched_tool\"><em>Image</em><p>" + Eval("Image") + "<br /></p><span class=\"downarrow_customer_tooltip\"></span></div>" : ""%>
                                                </div>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="Status" SortExpression="Status">
                                            <HeaderStyle Width="11%" VerticalAlign="Middle" HorizontalAlign="Center" CssClass="searchStoreCol08" />
                                            <ItemStyle VerticalAlign="Middle" HorizontalAlign="Center" />
                                            <ItemTemplate>
                                                <div class="cust_number">
                                                    <a id="a_status" class="customer-number" title="Status" onclick="javascript: ChangeStatus('<%# Eval("ID") %>');">
                                                        <%# Convert.ToBoolean(Eval("Status")) == true ? "<span style='color:Green;'>Active</span>" : "<span style='color:red;'>Inactive</span>"%>
                                                    </a>
                                                    <%# Convert.ToString(Eval("Status")) == "1" ? "<div class=\"number_hover cf matched_tool\"><em>Status</em><p>Active<br /></p><span class=\"downarrow_customer_tooltip\"></span></div>" : ""%>
                                                    <%# Convert.ToString(Eval("Status")) == "2" ? "<div class=\"number_hover cf matched_tool\"><em>Status</em><p>InActive<br /></p><span class=\"downarrow_customer_tooltip\"></span></div>" : ""%>
                                                </div>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="Action">
                                            <HeaderStyle Width="11%" HorizontalAlign="Center" VerticalAlign="Middle" CssClass="searchStoreCol08 rightcorner" />
                                            <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" />
                                            <FooterTemplate>
                                               <center><asp:ImageButton ID="imgAdd" runat="server" ImageUrl="~/Images/add_blue.jpg" Height="20px" Width="20px" CommandName="Add" /></center>
                                            </FooterTemplate>
                                            <ItemTemplate>
                                                <div class="cust_number">
                                                    <%--<asp:ImageButton ID="imgEdit" runat="server" ImageUrl="~/Images/edit_blue.jpg" Height="20px" Width="20px" OnClientClick='javascript: OpenDialog();' />--%>
                                                  <a href="#upload" class="opendialog"> 
                                                  <input type="image" id="imgEdit" class="imgedit" src="Images/edit_blue.jpg" style ="Height:20px;Width:20px;" onclick='javascript: OpenDialog("<%# Eval("ID") %>");' /></a>
                                                    <asp:ImageButton ID="imgDelete" runat="server" ImageUrl="~/Images/delete_blue.jpg" Height="20px" Width="20px" OnClientClick="return confirm('Are you sure you want to delete?')" CommandName="DeleteButton" CommandArgument='<%#Eval("ID") %>'/>                                                   
                                                </div>
                                            </ItemTemplate>
                                        </asp:TemplateField>                                       
                                        <asp:CommandField ShowEditButton="True" />
                                        <asp:CommandField ShowDeleteButton="True" />
                                    </Columns>
                                    <FooterStyle BackColor="#990000" Font-Bold="True" ForeColor="White"
                                        HorizontalAlign="Center" />
                                    <HeaderStyle BackColor="#990000" Font-Bold="True" ForeColor="White" />
                                    <PagerStyle BackColor="#FFCC66" ForeColor="#333333" HorizontalAlign="Center" />
                                    <PagerTemplate>
                                                <div class="carrier_pagination alignright" style="padding-top:18px">
                                                    <div class="arrows alignright">
                                                    <asp:LinkButton ID="lnkFirst" CommandName="Page" CommandArgument="First" ToolTip="First Page"
                                                            runat="server" CssClass="prev">First</asp:LinkButton>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                                                        <asp:LinkButton ID="lnkPrevious" CommandName="Page" CommandArgument="Prev" ToolTip="Previous Page"
                                                            runat="server" CssClass="prev">Prev</asp:LinkButton>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                                                        <asp:LinkButton ID="lnkNext" CommandName="Page" CommandArgument="Next" ToolTip="Next Page" runat="server"
                                                            CssClass="next">Next</asp:LinkButton>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                                                        <asp:LinkButton ID="lnkLast" CommandName="Page" CommandArgument="Last" ToolTip="Last Page"
                                                            runat="server" CssClass="Last">Last</asp:LinkButton>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                                                       <asp:LinkButton ID="LnkAll" OnClick="LnkAll_Click" CssClass="viewall" ToolTip="view All"
                                                runat="server">View All</asp:LinkButton>
                                                    </div>
                                                    <span class="alignright">Page <em>
                                                        <%= Gv.PageIndex + 1%></em> of
                                                        <%= Gv.PageCount%></span>
                                                </div>
                                            </PagerTemplate>
                                    <RowStyle HorizontalAlign="Center" BackColor="#FFFBD6" ForeColor="#333333" />
                                    <SelectedRowStyle BackColor="#FFCC66" Font-Bold="True" ForeColor="Navy" />
                                    <SortedAscendingCellStyle BackColor="#FDF5AC" />
                                    <SortedAscendingHeaderStyle BackColor="#4D0000" />
                                    <SortedDescendingCellStyle BackColor="#FCF6C0" />
                                    <SortedDescendingHeaderStyle BackColor="#820000" />
                                </asp:GridView>
                                <div class="arrows alignright " style="width: auto; ">
                                            <asp:LinkButton ID="LnkViewAll" Text="View Paging" Visible="false" runat="server" OnClick="LnkViewAll_Click"
                                                CssClass="viewall" ></asp:LinkButton>
                                        </div>
                            </td>
                        </tr>
                    </tbody>
                </table>
            </div>
        </ContentTemplate>       
    </asp:UpdatePanel>
    <!-- Code for the modal popup -->
    <div style="display: none;">
        <div id="upload" class="statusmodal">
            <iframe id="frm" runat="server" class="frmPass" width="400px" height="504px" scrolling="no"
                frameborder="0" style="border: 0;"></iframe>
        </div>
    </div>
    <!-- Code for the modal popup -->
    </form>
</body>
</html>

The Code file

#region Data Members
        Entities db = new Entities();
        UserService Users = new UserService();
        #endregion
        #region Properties
        public string SortDirection
        {
            get
            {
                if (ViewState["SortDirection"] == null)
                    ViewState["SortDirection"] = " ASC";
                return (string)ViewState["SortDirection"];
            }
            set { ViewState["SortDirection"] = value; }
        }
        public string SortExpression
        {
            get
            {
                if (ViewState["SortExpression"] == null)
                    ViewState["SortExpression"] = "Name";
                return (string)ViewState["SortExpression"];
            }
            set { ViewState["SortExpression"] = value; }
        }
        #endregion
        #region Events
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!Page.IsPostBack)
            {
                BindGrid("");
            }
        }
              
        protected void LnkViewAll_Click(object sender, EventArgs e)
        {
            Gv.AllowPaging = true;
            //Gv.PageSize = 10;
            LnkViewAll.Visible = false;
            BindGrid("");
        }
       
        protected void LnkAll_Click(object sender, EventArgs e)
        {
            Gv.AllowPaging = false;
            LnkViewAll.Visible = true;
            BindGrid("");
        }
        protected void Gv_PageIndexChanging(object sender, GridViewPageEventArgs e)
        {
            if (e.NewPageIndex != -1)
            {
                Gv.PageIndex = e.NewPageIndex;
            }
            BindGrid("");
        }
        protected void Gv_RowCommand(object sender, GridViewCommandEventArgs e)
        {
            if (e.CommandName == "Add")
            {
                string FirstName, LastName, Address, ContactNo;
                GridViewRow gvr = (GridViewRow)(((ImageButton)e.CommandSource).NamingContainer);
                TextBox TbFirstName = (TextBox)(gvr.FindControl("txtAddFirstName"));
                TextBox TbLastName = (TextBox)(gvr.FindControl("txtAddLastName"));
                TextBox TbAddress = (TextBox)(gvr.FindControl("txtAddAddress"));
                TextBox TbContactNo = (TextBox)(gvr.FindControl("txtAddContactNo"));
                FileUpload FupImage = (FileUpload)(gvr.FindControl("fupAddImage"));
                //--Start Code to convert image to byte
                int Length = FupImage.PostedFile.ContentLength;
                byte[] Image = new byte[Length];
                HttpPostedFile ImageFile = FupImage.PostedFile;
                ImageFile.InputStream.Read(Image, 0, Length);
                // --End Code
                FirstName = TbFirstName.Text;
                LastName = TbLastName.Text;
                Address = TbAddress.Text;
                ContactNo = TbContactNo.Text;
                User NewUser = new User();
                NewUser.FirstName = FirstName;
                NewUser.LastName = LastName;
                NewUser.Address = Address;
                NewUser.ContactNo = ContactNo;
                NewUser.Image = Image;
                NewUser.Status = true;
                db.AddToUsers(NewUser);
                db.SaveChanges();
                BindGrid("");
            }
            else if (e.CommandName == "DeleteButton")
            {
                GridViewRow gvr = (GridViewRow)(((ImageButton)e.CommandSource).NamingContainer);
                HiddenField HdnId = (HiddenField)(gvr.FindControl("hdnId"));
                long Id = Convert.ToInt64(HdnId.Value);
                User Userdata = db.Users.Where(u => u.ID == Id).SingleOrDefault();
                db.DeleteObject(Userdata);
                db.SaveChanges();
                BindGrid("");
            }
        }
        protected void Gv_Sorting(object sender, GridViewSortEventArgs e)
        {
            if (ViewState["Sorting"] == null)
            {
                ViewState["Sorting"] = e.SortDirection;
                BindGrid(e.SortExpression + " Asc");
            }
            else if (ViewState["Sorting"].ToString() == "Ascending")
            {
                ViewState["Sorting"] = "Descending";
                BindGrid(e.SortExpression + " Desc");
            }
            else
            {
                ViewState["Sorting"] = "Ascending";
                BindGrid(e.SortExpression + " Asc");
            }
        }
        protected void Gv_RowEditing(object sender, GridViewEditEventArgs e)
        {
            Gv.EditIndex = e.NewEditIndex;
            BindGrid("");
        }
        protected void Gv_RowUpdating(object sender, GridViewUpdateEventArgs e)
        {
            string FirstName, LastName, Address, ContactNo;
            long Id;
            try
            {
                TextBox TbFirstName = (TextBox)(Gv.Rows[e.RowIndex].FindControl("txtFirstName"));
                TextBox TbLastName = (TextBox)(Gv.Rows[e.RowIndex].FindControl("txtLastName"));
                TextBox TbAddress = (TextBox)(Gv.Rows[e.RowIndex].FindControl("txtAddress"));
                TextBox TbContactNo = (TextBox)(Gv.Rows[e.RowIndex].FindControl("txtContactNo"));
                FileUpload FupImage = (FileUpload)(Gv.Rows[e.RowIndex].FindControl("fupEditImage"));
                //--Start Code to convert image to byte
                int Length = FupImage.PostedFile.ContentLength;
                byte[] Image = new byte[Length];
                HttpPostedFile ImageFile = FupImage.PostedFile;
                ImageFile.InputStream.Read(Image, 0, Length);
                // --End Code
                HiddenField HdnId = (HiddenField)(Gv.Rows[e.RowIndex].FindControl("hdnId"));
                FirstName = TbFirstName.Text;
                LastName = TbLastName.Text;
                Address = TbAddress.Text;
                ContactNo = TbContactNo.Text;
                Id = Convert.ToInt64(HdnId.Value);
                User Userdata = db.Users.Where(u => u.ID == Id).SingleOrDefault();
                Userdata.FirstName = FirstName;
                Userdata.LastName = LastName;
                Userdata.Address = Address;
                Userdata.ContactNo = ContactNo;
                Userdata.Image = Image;
                db.SaveChanges();
                Gv.EditIndex = -1;
                BindGrid("");
            }
            catch (Exception)
            {
            }
        }
        protected void Gv_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
        {
            Gv.EditIndex = -1;
            BindGrid("");
        }
        protected void Gv_RowDeleting(object sender, GridViewDeleteEventArgs e)
        {
            try
            {
                long Id;
                HiddenField HdnId = (HiddenField)(Gv.Rows[e.RowIndex].FindControl("hdnId"));
                Id = Convert.ToInt64(HdnId.Value);
                User Userdata = db.Users.Where(u => u.ID == Id).SingleOrDefault();
                db.DeleteObject(Userdata);
                db.SaveChanges();
                BindGrid("");
            }
            catch (Exception)
            {
            }
        }
        protected void Gv_RowDataBound(object sender, GridViewRowEventArgs e)
        {
            if (e.Row.RowType == DataControlRowType.DataRow)
            {
                try
                {
                    LinkButton delbutton = (LinkButton)e.Row.Cells[10].Controls[0];
                    delbutton.OnClientClick = string.Format("return confirm('Are you sure want to delete');");
                }
                catch (ArgumentOutOfRangeException) { }
            } 
        }
        protected void btnDelete_Click(object sender, EventArgs e)
        {
            foreach (GridViewRow row in Gv.Rows)
            {
               
                CheckBox chk = (CheckBox)row.FindControl("CheckSelect");
                HiddenField hdnID = (HiddenField)row.FindControl("hdnId");
                if (chk != null && chk.Checked)
                {
                    long id = Convert.ToInt64(hdnID.Value);
                    User a = db.Users.Where(u => u.ID == id).SingleOrDefault();                   
                    db.DeleteObject(a);
                    db.SaveChanges();
                }
            }
            BindGrid("");
        }
        #endregion
        #region Methods
        public void BindGrid(string SortExp)
        {
            Gv.DataSource = Users.GetUsers();
            if (SortExp != "")
            {
                DataView dv = new DataView(Helper.ListToDataTable(Users.GetUsers().ToList()));
                dv.Sort = SortExp;
                Gv.DataSource = dv;
            }
            Gv.DataBind();
        }
        [WebMethod]
        public static string ChangeStatus(long UserID)
        {
            try
            {
                Entities db = new Entities();
                UserService Users = new UserService();
                User Userdata = db.Users.Where(u => u.ID == UserID).SingleOrDefault();   // Users.GetUserById(Convert.ToInt64(UserID));
                Userdata.Status = Userdata.Status == true ? Userdata.Status = false : Userdata.Status = true;
                //Users.UpdateUser(Userdata);
                db.SaveChanges();                               
                return "Success";
            }
            catch (Exception)
            {               
                return "Error";
            }
        }
        #endregion

Now the code for Popup File

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <style type="text/css">
    div.scroll {
       height: 200px;
       width: 300px;
       overflow: auto;
    }
</style>
    <script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
    $(document).ready(function () {
        $(".FileUpload").change(function (e) {
            var img = document.getElementById('<%=imgView.ClientID %>');
            img.src = e.value;
            alert(img.src);
        });
    });
    function readURL(input) {
        if (input.files && input.files[0]) {
            var reader = new FileReader();
            reader.onload = function (e) {
                $('#imgView').attr('src', e.target.result);
            }           
            reader.readAsDataURL(input.files[0]);
        }
    }
    function RedirectParent(URL) {
        parent.window.location = URL;
    }
</script>
</head>
<body>
    <form id="form1" runat="server">
    <div style="border:2px solid black;padding-bottom:21px;">
        <h1 align="center">
            Edit User</h1>
        <table align="center" bgcolor="silver" cellspacing="5px">
            <tr>
                <td>
                    First Name
                </td>
                <td>
                    :
                    <asp:TextBox ID="txtFirstName" runat="server"></asp:TextBox>
                </td>
            </tr>
            <tr>
                <td>
                    Last Name
                </td>
                <td>
                    :
                    <asp:TextBox ID="txtLastName" runat="server"></asp:TextBox>
                </td>
            </tr>
            <tr>
                <td>
                    Address
                </td>
                <td>
                    :
                    <asp:TextBox ID="txtAddress" runat="server"></asp:TextBox>
                </td>
            </tr>
            <tr>
                <td>
                    Contact No.
                </td>
                <td>
                    :
                    <asp:TextBox ID="txtContactNo" runat="server"></asp:TextBox>
                </td>
            </tr>
            <tr>
                <td>
                    Image
                </td>
                <td>
                    :
                    <asp:FileUpload ID="fupEditImage" runat="server" CssClass="FileUpload1"  onchange="readURL(this);" /><div id="dv"></div>
                </td>
            </tr>
             <tr>
                <td>                   
                    &nbsp;
                </td>
                <td>
                    <asp:Image ID="imgView" runat="server" Height="200px" Width="200px" />
                </td>
            </tr>
             <tr>
                <td>
                   
                </td>
                <td>
                <asp:Button ID="btnSubmit" runat="server" Text="Update" onclick="btnSubmit_Click" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                    <asp:Button ID="btnReset" runat="server" Text="Reset" onclick="btnReset_Click" />
                </td>
            </tr>
        </table>
    </div>
    </form>
</body>
</html>

Code file of Popup

 Entities db = new Entities();
        string UserId, ReturnURL;
        protected void Page_Load(object sender, EventArgs e)
        {
            UserId = Request.QueryString["UserID"].ToString();
            ReturnURL = Request.QueryString["ReturnPath"].ToString();
            if (!Page.IsPostBack)
            {
                SendData(Convert.ToInt64(UserId));
            }
        }
        protected void btnSubmit_Click(object sender, EventArgs e)
        {
            string FirstName, LastName, Address, ContactNo;
            long Id;
            FirstName = txtFirstName.Text;
            LastName = txtLastName.Text;
            Address = txtAddress.Text;
            ContactNo = txtContactNo.Text;
            //--Start Code to convert image to byte
            int Length = fupEditImage.PostedFile.ContentLength;
            byte[] Image = new byte[Length];
            HttpPostedFile ImageFile = fupEditImage.PostedFile;
            ImageFile.InputStream.Read(Image, 0, Length);
            // --End Code
            Id = Convert.ToInt64(UserId);
            User Userdata = db.Users.Where(u => u.ID == Id).SingleOrDefault();
            Userdata.FirstName = FirstName;
            Userdata.LastName = LastName;
            Userdata.Address = Address;
            Userdata.ContactNo = ContactNo;
            Userdata.Image = Image;
            db.SaveChanges();           
            this.ClientScript.RegisterStartupScript(this.GetType(), Guid.NewGuid().ToString(), "javascript: RedirectParent('" + ReturnURL + "'); " , true);
        }
        public void SendData(long Id)
        {
            User EditUser = db.Users.Where(u => u.ID == Id).FirstOrDefault();
            txtFirstName.Text = EditUser.FirstName;
            txtLastName.Text = EditUser.LastName;
            txtAddress.Text = EditUser.Address;
            txtContactNo.Text = EditUser.ContactNo;
            if (EditUser.Image != null)
            {
                //imgView.ImageUrl = String.Format("ImageHandler.ashx?ID={0}", Id);
                imgView.ImageUrl = "ImageHandler.ashx?ID=" + Id;
            }
        }
        public void ResetData()
        {
            txtFirstName.Text = "";
            txtLastName.Text = "";
            txtAddress.Text = "";
            txtContactNo.Text = "";
        }
        protected void btnReset_Click(object sender, EventArgs e)
        {
            ResetData();
        }
 

No comments:

Post a Comment