Encountering Runtime Error When Entering Date in Textbox

pmgibs

New Member
Joined
Apr 5, 2017
Messages
16
I have the following code that upon exit from Textbox87 first checks to make sure the user input a date in the correct format and that it is a valid date. Then it checks to see if it is a past date or a future date. I receive a Runtime Error 13 Type Mismatch error only if a nonsensical date (i.e. 888888) is input in textbox87 and the msgbox "enter a valid date" appears. The error occurs after clicking Ok on the message box. When I click on Debug. The If CDate(TextBox87.Value) < Date Then is highlighted towards the end of the code. If a valid date is entered the error is not generated.


VBA Code:
Private Sub TextBox87_Exit(ByVal Cancel As MSForms.ReturnBoolean)
    If TextBox87.Value = "" Then
    ElseIf Len(TextBox87) <> 6 Then
        MsgBox "Enter expiration date as mmddyy(eg. 021522)"
        Cancel = True
        If Cancel = True Then
        TextBox87.Value = ""
        Else
        End If
    End If
    Dim DateStr As String
        With Me.TextBox87
            Select Case Len(.Value)
            Case 6    ' e.g., 090298 = 2-Sep-1998
                DateStr = Left(.Value, 2) & "/" & _
                          Mid(.Value, 3, 2) & "/" & Right(.Value, 2)
            Case Else
                Exit Sub
            End Select
            .Value = DateStr
        If IsDate(TextBox87.Value) Then
        Else: MsgBox "Enter a valid date!"
        Cancel = True
        If Cancel = True Then
        TextBox87.Value = ""
        Else
        End If
        End If
        End With
    
    If IsDate(TextBox87.Value) And ComboBox35.Text <> "*Bottle" Or ComboBox35.Text <> "*Saline" Then
            If CDate(TextBox87.Value) < Date Then
            MsgBox "Saline " & ComboBox35.Text & " at Workstation " & ComboBox39.Text & " Expired!", vbCritical
            If CDate(TextBox87.Value) < Date Then
            TextBox87.BackColor = &H8080FF
            End If
            If CDate(TextBox87.Value) >= Date Then
            TextBox87.BackColor = &HFFFFFF
            End If
    End If
    End If
    End Sub


I have a very similar code that does not generate this error when a nonsensical date is entered into a different textbox. Here is that code:


VBA Code:
Private Sub TextBox86_Exit(ByVal Cancel As MSForms.ReturnBoolean)

    If TextBox86.Value = "" Then
    ElseIf Len(TextBox86) <> 6 Then
        MsgBox "Enter expiration date as mmddyy(eg. 021522)"
        Cancel = True
        If Cancel = True Then
        TextBox86.Value = ""
        Else
        End If
    End If
    Dim DateStr As String
        With Me.TextBox86
            Select Case Len(.Value)
            Case 6    ' e.g., 090298 = 2-Sep-1998
                DateStr = Left(.Value, 2) & "/" & _
                          Mid(.Value, 3, 2) & "/" & Right(.Value, 2)
            Case Else
                Exit Sub
            End Select
            .Value = DateStr
        If IsDate(TextBox86.Value) Then
        Else: MsgBox "Enter a valid date!"
        Cancel = True
        If Cancel = True Then
        TextBox86.Value = ""
        Else
        End If
        End If
        End With
    If IsDate(TextBox86.Value) Then
            If CDate(TextBox86.Value) < Date Then
            MsgBox "Saline Cube at Workstation 4 is Expired!", vbCritical
            If CDate(TextBox86.Value) < Date Then
            TextBox86.BackColor = &H8080FF
            End If
            If CDate(TextBox86.Value) >= Date Then
            TextBox86.BackColor = &HFFFFFF
            End If
    End If
    End If
    End Sub

I cannot figure out why I am encountering this error when these two codes are so similar.

Thanks for any help
 

Excel Facts

Which came first: VisiCalc or Lotus 1-2-3?
Dan Bricklin and Bob Frankston debuted VisiCalc in 1979 as a Visible Calculator. Lotus 1-2-3 debuted in the early 1980's, from Mitch Kapor.
In this part change the value of the textbox to empty but you do not finish the process ...

If IsDate(TextBox86.Value) Then
Else: MsgBox "Enter a valid date!"
Cancel = True
If Cancel = True Then
TextBox86.Value = ""

So later, if the textbox87 is empty it generates the error.
If CDate(TextBox87.Value) < Date Then


I would structure the code like this:
VBA Code:
Private Sub TextBox87_Exit(ByVal Cancel As MSForms.ReturnBoolean)
  Dim DateStr As String
 
  With TextBox87
    If .Value = "" Then
      .BackColor = &HFFFFFF
      Exit Sub
    End If
  
    If Len(.Value) <> 6 Then
      MsgBox "Enter expiration date as mmddyy(eg. 021522)"
      Cancel = True
      .Value = ""
      Exit Sub
    End If
  
    DateStr = Left(.Value, 2) & "/" & Mid(.Value, 3, 2) & "/" & Right(.Value, 2)
    If Not IsDate(DateStr) Then
      MsgBox "Enter a valid date!"
      Cancel = True
      .Value = ""
      Exit Sub
    End If
  
    .Value = DateStr
  
    If IsDate(.Value) And ComboBox35.Text <> "*Bottle" Or ComboBox35.Text <> "*Saline" Then
      If CDate(.Value) < Date Then
        MsgBox "Saline " & ComboBox35.Text & " at Workstation " & ComboBox39.Text & " Expired!", vbCritical
        .BackColor = &H8080FF
      Else
        .BackColor = &HFFFFFF
      End If
    End If
  End With
End Sub
 
Last edited:
Upvote 0
Solution

Forum statistics

Threads
1,225,739
Messages
6,186,746
Members
453,370
Latest member
juliewar

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top