VB.NET handling data between different forms

Posted by niuchu on Stack Overflow See other posts from Stack Overflow or by niuchu
Published on 2010-04-29T16:17:13Z Indexed on 2010/04/29 18:17 UTC
Read the original article Hit count: 380

Filed under:
|

Hi,

I'm writing a simple application - address book. User enters new addresses and they are added as an entry to a list visible on the main form (frmStart). I use one form to add and edit (AddContForm). Add button on the frmStart works fine, however I experience some problems with the edit button as when I press it and enter new data they are added as new entry however the previous entry is still there. Logic is handled by Contact.vb class. Please let me know how to fix this problem. Here is the code:

Contact.vb

Public Class Contact
    Public Contact As String
    Public Title As String
    Public Fname As String
    Public Surname As String
    Public Address As String
    Private myCont As String
    Public Property Cont()
        Get
            Return myCont
        End Get
        Set(ByVal value)
            myCont = Value
        End Set
    End Property
    Public Overrides Function ToString() As String
        Return Me.Cont
    End Function

    Public Sub Display()
        Dim C As New Contact
        C.Cont = frmAddCont.txtTitle.Text
        C.Fname = frmAddCont.txtFName.Text
        C.Surname = frmAddCont.txtSName.Text
        C.Address = frmAddCont.txtAddress.Text
        frmStart.lstContact.Items.Add(C)
    End Sub
End Class

Here is frmStart.vb

Public Class frmStart
    Public Button As String

    Private Sub btnAdd_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnAdd.Click
        Button = ""
        Button = "Add"
        frmAddCont.ShowDialog()

    End Sub

    Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnDel.Click

        Button = ""
        Button = "Del"
        Dim DelCont As Contact
        DelCont = Me.lstContact.SelectedItem()


        lstContact.Items.Remove(DelCont)

    End Sub

    Private Sub lstContact_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles lstContact.SelectedIndexChanged

    End Sub

    Private Sub btnEdit_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnEdit.Click
        Button = ""
        Button = "Edit"
        Dim C As Contact

        If lstContact.SelectedItem IsNot Nothing Then

            C = DirectCast(lstContact.SelectedItem, Contact)
            frmAddCont.ShowDialog()

        End If
    End Sub
End Class

Here is AddContFrm.vb

Public Class frmAddCont
    Public Class ControlObject
        Dim Title As String
        Dim FName As String
        Dim SName As String
        Dim Address As String
        Dim TelephoneNumber As Integer
        Dim emailAddress As String
        Dim Website As String
        Dim Photograph As String

    End Class

    Private Sub btnConfirmAdd_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnConfirmAdd.Click

        Dim B As String
        B = frmStart.Button

        Dim C As New Contact

        C.Display()
        Me.Hide()
        If B = "Edit" Then
            C = DirectCast(frmStart.lstContact.SelectedItem, Contact)
            frmStart.lstContact.SelectedItems.Remove(C)
        End If     

     End Sub

    Private Sub frmAddCont_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

    End Sub

End Class

© Stack Overflow or respective owner

Related posts about vb.net

Related posts about data