VBA Passing in Textbox into a function Help

  • Thread starter Thread starter Jerry8989
  • Start date Start date
J

Jerry8989

I have many date fields that I want to validate a range for. I created this
function to pass in the text so that it will verify the date and then display
a message if it is out of range then cancel the change so it isn't committed.

Private Sub txtInDate_BeforeUpdate(Cancel As Integer)
ValidationRFQDates (txtInDate)
End Sub

Private Sub ValidationRFQDates(txtField As TextBox)
If (DateValidation(txtField) = 0) Then
MsgBox "Date Must be Greater Than 1/1/1999 and Less Than " & DateAdd("yyyy",
10, Date)
Cancel = True
txtField.Undo
End If
End Sub

I keeps telling me "Object Required" on ValidationRFQDates (txtInDate)

Thank You
 
What is DateValidation?
You have it coded as if it is a function.
If so, where is the function. If it is in a standard module, it shoud be a
Public Function.

Also your Cancel = True is in the wrong place. It has to be in the Before
Update event code.
 
Klatuu thank you for your reply.
DateValidation is a function I have in a module. All it does is take a take
and make sure it's within a range. What i'm trying to do it make 1 function
that I can pass the text box too and have the date checked and if it errors
out to undo the changes and cancel the action. I have 30 different date
fields so I thought passing in the actual text box would allow me to check
the date and do all the other stuff in one place. I didn't want to copy the
"Cancel = True" and the textbox.undo for every BeforeUpdate for ever text
box.

Thanks again for any help
Jerry
 
Marsh Thank you for your tips. That makes sense. My only question is that
if Cancel is set to true will it know which text box i'm cancelling or will
it just cancel whatever the current change was?

Thank You again
 
No, the Cancel argument can't be seen outside of the procedure it is in.
What you can do is modify your code so it return the correct cancel value.

Cancel = DateValidation(Me.txtSomeDateControl)

Or you could use:
Cancel = DateValidation()

Then in the DateValidation code, you can reference which text box it is
being called from with:

Screen.ActiveControl
 
Marshall & Klatuu,
Thank you both for your replies I followed what you said and I figured it
out. I used the function and the cancel is within each beforeupdate event.

Thanks again
Jerry

Marshall Barton said:
Cancel applies to the BeforeUpdate event and if the event is
cancelled, then the event's control (txtInDate) can not be
updated.
--
Marsh
MVP [MS Access]

Marsh Thank you for your tips. That makes sense. My only question is that
if Cancel is set to true will it know which text box i'm cancelling or will
it just cancel whatever the current change was?

Thank You again
 
Back
Top