[Webinar] Streamline your web hosting managementRegister Today

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 176
  • Last Modified:

How do I avoid copying functions into different objects

I am developing a system that displays data in several different ways for different groups of users. However many of the fields and associated functions are the same. E.g. when a CompletedDate is updated for a field I need to do several other functions depending on the value of data in related fields. To accomplish this I have created an AfterUpdate event and associated function in the form's VBA library. Both the AfterUpdate event and Function refer to other fields on the form (e.g. me.AssignedTo).

When I implement the same functionality on another form I can copy the AfterUpdate event and function into the new form's VBA but every time I change the code I have to remember to change it in multiple places.

I know I could put the Function in a standard module but then I would need to feed to the function multiple field values; I can't just reference them by me.AssignedTo nor can I specifically reference them by using the form name because the same function could be called by multiple forms.

Is there any way to easily feed, or reference, all the fields to a function or what is the generally accepted approach to use in this case to keep the code as tidy as possible?
0
Rob4077
Asked:
Rob4077
  • 2
1 Solution
 
Scott McDaniel (Microsoft Access MVP - EE MVE )Infotrakker SoftwareCommented:
A function can accept input values:

Function MyFunction(StartDate As DAte, EndDate As Date) as Double
  MyFunction= DateDiff(StartDate, EndDate)
End Function

So if your function is identical, just create it in the module, and then in each AfterUpdate event call that function. For Example:

Msgbox MyFunction(Me.txtJobStart, Me.txtJobEnd)

If those fields are name differently on another form:

Msgbox MyFunction(Me.txtHireDate, Now)

You can also include optional arguments:

MyFunction(StartDate As Date, EndDate As Date, Optional AddDays As integer) As Double

In the example above, you can call it like this:

Msgbox MyFunction(Me.txtStartDate, Me.txtEndDate)

Or

Msgbox MyFunction(Me.txtStartDate, Me.txtEndDate, 7)
0
 
Rob4077Author Commented:
Thanks for that but my functions need multiple parameters and they also change values of other fields. I can list all the parameters but how do I change all the associated fields on the calling form?
0
 
Jim Dettman (Microsoft MVP/ EE MVE)PresidentCommented:
You can pass references to objects as well as discrete values:

Sub ProcessDates(frm As Form)

  frm.NumberofDays = DateDiff("d",frm.StartDate, frm.EndDate)

End Sub

 and the call in the AfterUpdate property sheet would be:

ProcessDates([Form])

  You can pass references to any object; controls, reports, recordsets, etc.

Jim.
0
 
Rob4077Author Commented:
That's awesome! That would have saved me sooo much duplicated code over the years. Thank you sooo much!!!
0

Featured Post

Learn to develop an Android App

Want to increase your earning potential in 2018? Pad your resume with app building experience. Learn how with this hands-on course.

  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now