Hi and thanks ahead of time:
I'm new to vb.net - not sure if I'm doing this right.
I need an editable gridview with an Access database as it's source.
The findcontrol is not finding control in gridview (dropdownlist).
I have the following gridview:
<asp:GridView ID="gvRescue"
runat="server"
AutoGenerateColumns="False"
onrowcancelingedit="gvRescue_RowCancelingEdit"
onrowediting="gvRescue_RowEditing"
onrowupdating="gvRescue_RowUpdating"
onrowdatabound="gvRescue_RowDataBound">
<Columns>
<asp:TemplateField HeaderText="ID">
<ItemTemplate >
<asp:Label ID="lblID" runat="server" Text='<%# Eval("PersonPlaceID") %>' > </asp:Label>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="FirstName">
<ItemTemplate >
<asp:Label ID="lblFirstName" runat="server" Text='<%# Eval("FirstName") %>' > </asp:Label>
</ItemTemplate>
<EditItemTemplate >
<asp:TextBox ID="txtFirstName" runat="server" Width="50px" Text='<%# Eval("FirstName")%>' ></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Last<br>Name" SortExpression="LastName">
<ItemTemplate>
<asp:Label ID="lblLastName" runat="server" Text='<%# Eval("LastName") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtLastName" runat="server" Width="50px" Text='<%# Eval("LastName") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Role ID" >
<ItemTemplate>
<asp:Label ID="lblRoleID" runat="server" Text='<%# Eval("RoleID") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtRoleID" runat="server" Width="50px" Text='<%# Eval("RoleID") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Role<br>(Rescue<br>Foster<br>Adopter">
<ItemTemplate >
<asp:Label ID="lblRescueRole" runat="server" Text='<%# Eval("RescueRole") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate >
<asp:DropDownList ID="ddRoles" runat="server" > </asp:DropDownList>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Address" >
<ItemTemplate>
<asp:Label ID="lblAddress" runat="server" Text='<%# Eval("Address") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtAddress" runat="server" Width="150px" Text='<%# Eval("Address") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="City" SortExpression="City">
<ItemTemplate>
<asp:Label ID="lblCity" runat="server" Text='<%# Eval("City") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtCity" runat="server" Width="150px" Text='<%# Eval("City") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="State ID" >
<EditItemTemplate>
<asp:TextBox ID="txtStateID" runat="server" Width="20px" Text='<%# Eval("StateID") %>'></asp:TextBox>
</EditItemTemplate>
<ItemTemplate>
<asp:Label ID="lblStateID" runat="server" Text='<%# Eval("StateID") %>'></asp:Label>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="State">
<ItemTemplate >
<asp:Label ID="lblState" runat="server" Text='<%# Eval("RescueState") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate >
<asp:DropDownList ID="ddStates" runat="server" DataTextField="State" DataValueField="StateID"> </asp:DropDownList>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Zip" SortExpression="Zip">
<ItemTemplate>
<asp:Label ID="lblZip" runat="server" Text='<%# Eval("Zip") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtZip" runat="server" Width="50px" Text='<%# Eval("Zip") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="1st Phone" >
<ItemTemplate>
<asp:Label ID="lblPhone1" runat="server" Text='<%# Eval("Phone1") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtPhone1" runat="server" Width="60px" Text='<%# Eval("Phone1") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="2nd Phone" >
<ItemTemplate>
<asp:Label ID="lblPhone2" runat="server" Text='<%# Eval("Phone2") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtPhone2" runat="server" Width="60px" Text='<%# Eval("Phone2") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="3rd Phone" >
<ItemTemplate>
<asp:Label ID="lblPhone3" runat="server" Text='<%# Eval("Phone3") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="Phone3" runat="server" Width="60px" Text='<%# Eval("Phone3") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Email" >
<ItemTemplate>
<asp:Label ID="lblEmail" runat="server" Text='<%# Eval("Email") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtEmail" runat="server" Width="150px" Text='<%# Eval("Email") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Website" >
<ItemTemplate>
<asp:Label ID="lblWebsite" runat="server" Text='<%# Eval("Website") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtWebsite" runat="server" Width="150px" Text='<%# Eval("Website") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="UserName" >
<ItemTemplate>
<asp:Label ID="lblUserName" runat="server" Text='<%# Eval("UserName") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtUserName" runat="server" Width="50px" Text='<%# Eval("UserName") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="PassWord" >
<ItemTemplate>
<asp:Label ID="lblPassWord" runat="server" Text='<%# Eval("UserPassWord") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtPassWord" runat="server" Width="50px" Text='<%# Eval("UserPassWord") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Rescue<br>Contact" >
<ItemTemplate>
<asp:Label ID="lblContact" runat="server" Text='<%# Eval("RescueContactName") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtContact" runat="server" Width="75px" Text='<%# Eval("RescueContactName") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Rescue<br>Criteria" >
<ItemTemplate>
<asp:Label ID="lblCriteria" runat="server" Text='<%# Eval("RescueCriteria") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtCriteria" runat="server" Width="200px" Text='<%# Eval("RescueCriteria") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Comment" >
<ItemTemplate>
<asp:Label ID="lblComment" runat="server" Text='<%# Eval("PersonPlaceComment") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtComment" runat="server" TextMode="MultiLine" Width="200px" Text='<%# Eval("PersonPlaceComment") %>'></asp:TextBox>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Approved<br>For<br>Website">
<ItemTemplate >
<asp:Label ID="lblApproved" runat="server" Text='<%# Eval("Approved") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate >
<asp:CheckBoxList ID="CheckBoxApproved" runat="server" >
<asp:ListItem>Approved</asp:ListItem>
</asp:CheckBoxList>
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Edit" ShowHeader="false">
<ItemTemplate>
<asp:Button ID="btnedit" runat="server" CommandName="Edit" Text="Edit" ></asp:Button>
</ItemTemplate>
<EditItemTemplate>
<asp:Button ID="btnupdate" runat="server" CommandName="Update" Text="Update" ></asp:Button>
<asp:Button ID="btncancel" runat="server" CommandName="Cancel" Text="Cancel"></asp:Button>
</EditItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
' Here is where I'm trying to load the dropdownlist:
Protected Sub gvRescue_RowDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewRowEventArgs) Handles gvRescue.RowDataBound
Dim drv As DataRowView = e.Row.DataItem
'if its a row in the datagrid
If e.Row.RowType = DataControlRowType.DataRow Then
If (e.Row.RowState & DataControlRowState.Edit) > 0 Then
Dim dp As DropDownList = CType(e.Row.Cells(4).FindControl("ddRoles"), DropDownList)
Dim dt As DataTable = LoadRoles()
Dim i As Integer = 0
For z As Integer = 0 To dt.Rows.Count - 1
Dim lt As New ListItem
lt.Text = dt.Rows(i)(0).ToString
dp.Items.Add(lt)
Next
dp.SelectedValue = drv(3).ToString
End If
End If
End Sub
The code is bombing out on the following line:
dp.Items.Add(lt)
Error is: object not set to an instance of an object
When I step through the code the following line has value of "nothing":
Dim dp As DropDownList = CType(e.Row.Cells(4).FindControl("ddRoles"), DropDownList)
So I think error is because dp (dropdownlist) isn't found in the gridview.
This is the code where the dropdownlist is getting it's source:
Public Function LoadRoles()
Dim dt As New DataTable
Dim DBConnection As OleDbConnection = Dogs.MyConnection
Dim DBAdapter As New OleDbDataAdapter
Try
DBConnection.Open()
Dim sSelect As String = "SELECT Role, RoleID from Roles ORDER BY Role;"
Dim cmd As New OleDbCommand(sSelect)
cmd.CommandType = CommandType.Text
cmd.Connection = DBConnection
DBAdapter.SelectCommand = cmd
DBAdapter.Fill(dt)
Catch ex As Exception
lblMessage.Visible = True
lblMessage.Text = ex.Message
' lblMessage.Text = "<font color=red>Problem accessing Role records." _
' & " Please contact Programmer or CaliDogs.org.</font>"
Me.SetFocus(lblMessage)
Finally
DBConnection.Close()
DBConnection.Dispose()
End Try
This is the code for datasource of gridview - called in page_load event:
Protected Sub ShowGrid(ByVal vRescueID As Integer)
Dim dtRescue As New DataTable
Dim DBConnection As OleDbConnection = Dogs.MyConnection
Dim DBAdapter As New OleDbDataAdapter
Try
DBConnection.Open()
Dim sSelect As String = "SELECT PersonPlace.PersonPlaceID, State.StateID, PersonPlace_Roles.FKRoleID AS RoleID, PersonPlace.FirstName, PersonPlace.LastName, Roles.Role AS RescueRole, PersonPlace.Address, PersonPlace.City, State.StateAbbv AS RescueState, PersonPlace.Zip, PersonPlace.Phone1, PersonPlace.Phone2, PersonPlace.Phone3, PersonPlace.Email, PersonPlace.Website, PersonPlace.UserName, PersonPlace.UserPassWord, PersonPlace.RescueContactName, PersonPlace.RescueCriteria, PersonPlace.PersonPlaceComment, PersonPlace.Approved, PersonPlace_Roles.FKRoleID FROM ((PersonPlace INNER JOIN PersonPlace_Roles ON PersonPlace.PersonPlaceID=PersonPlace_Roles.FKPersonPlaceID) INNER JOIN State ON PersonPlace.StateID=State.StateID) LEFT JOIN Roles ON PersonPlace_Roles.FKRoleID=Roles.RoleID WHERE (PersonPlace_Roles.FKRoleID=3 Or PersonPlace_Roles.FKRoleID=4 Or PersonPlace_Roles.FKRoleID=5) And (PersonPlace.PersonPlaceID = 11) ORDER BY PersonPlace.LastName;"
Dim cmd As New OleDbCommand(sSelect)
cmd.CommandType = CommandType.Text
cmd.Connection = DBConnection
DBAdapter.SelectCommand = cmd
DBAdapter.Fill(dtRescue)
gvRescue.DataSource = dtRescue
gvRescue.DataBind()
Catch ex As Exception
lblMessage.Visible = True
lblMessage.Text = ex.Message
' lblMessage.Text = "<font color=red>Problem accessing Rescue/Foster/Adopter records." _
' & " Please contact Programmer or CaliDogs.org.</font>"
Me.SetFocus(lblMessage)
Finally
DBConnection.Close()
DBConnection.Dispose()
End Try
End Sub