Solved

Closing Form from After Update Event

Posted on 2008-06-17
3
223 Views
Last Modified: 2013-11-28
I have a form that is to close after collecting data in a single field.  I put a DoCmd.Close command in the after update event which works well if the field is updated and the enter button is pressed, however if the field is updated and the form close button is selected I get the error message 'Error 2501: The Close action was canceled'.  There is code running in the close event to update the parent form.  How do I correct this error message?  Attached is the code related to this form.
Private Sub FMS_Oblig_AfterUpdate()
'Close Form
DoCmd.Close acForm, "Change Obligation"
End Sub
 
Private Sub Form_Close()
Dim rst, rst2 As Recordset
Dim strBookmark As Variant
Dim strFCPParameter As String
 
'Move active record back to same location with updated data
If Me.OpenArgs Then
    Forms("Multi Year End").List_of_Year_End_Multi_Year_Obligations.Requery
    Set rst = Forms("Multi Year End").List_of_Year_End_Multi_Year_Obligations.Form.RecordsetClone
    Set rst2 = Me.RecordsetClone
    strFCPParameter = IIf(IsNull(rst2.Fields("FCP")), " AND (FCP) Is Null", " AND (FCP='" & rst2.Fields("FCP").Value & "')")
    rst.FindFirst "(ACC='" & rst2.Fields("ACC").Value & "') AND (Appropriation='" & rst2.Fields("Appropriation").Value & "') AND ([As Of]=#" & rst2.Fields("As Of").Value & "#)" & strFCPParameter
    Forms("Multi Year End").List_of_Year_End_Multi_Year_Obligations.Form.Bookmark = rst.Bookmark
Else
    Forms("Last Year End").Last_Year_End_Obligations.Requery
    Set rst = Forms("Last Year End").Last_Year_End_Obligations.Form.RecordsetClone
    Set rst2 = Me.RecordsetClone
    strFCPParameter = IIf(IsNull(rst2.Fields("FCP")), " AND (FCP) Is Null", " AND (FCP='" & rst2.Fields("FCP").Value & "')")
    rst.FindFirst "(ACC='" & rst2.Fields("ACC").Value & "') AND (Appropriation='" & rst2.Fields("Appropriation").Value & "') AND ([As Of]=#" & rst2.Fields("As Of").Value & "#)" & strFCPParameter
    Forms("Last Year End").Last_Year_End_Obligations.Form.Bookmark = rst.Bookmark
End If
Set rst = Nothing
End Sub

Open in new window

0
Comment
Question by:vincem1099
  • 2
3 Comments
 
LVL 77

Expert Comment

by:peter57r
ID: 21804637
Why is there an Enter button if you always want to close the form after the entry is made?
0
 
LVL 7

Author Comment

by:vincem1099
ID: 21804835
I was referring to the enter button on the keyboard.  Pressing the enter button on the keyboard lets access know that the field has been updated so the after update event will trigger.
0
 
LVL 77

Accepted Solution

by:
peter57r earned 250 total points
ID: 21805407
OK I see.  That makes the events processing tricky.

Change the process as follows.

Remove the X close form button.
Add your own form close button using the button wizard.
Modify the code for this button as follows..
if me.dirty = false then
Docmd.close acform, me.name
else
me.dirty=false ' saves record and executes form Afterupdate event - do not close the form here
end if

Modify your existing afterupdate procedure to save the record.
Private Sub FMS_Oblig_AfterUpdate()
me.dirty = false . saves and forces Form-afterupdate event to fire.
End Sub

In the form_afterupdate event..
Docmd.Close acform, me.name

This means that if the record is changed only one form close event will fire.
0

Featured Post

Ransomware: The New Cyber Threat & How to Stop It

This infographic explains ransomware, type of malware that blocks access to your files or your systems and holds them hostage until a ransom is paid. It also examines the different types of ransomware and explains what you can do to thwart this sinister online threat.  

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

The first two articles in this short series — Using a Criteria Form to Filter Records (http://www.experts-exchange.com/A_6069.html) and Building a Custom Filter (http://www.experts-exchange.com/A_6070.html) — discuss in some detail how a form can be…
It’s been over a month into 2017, and there is already a sophisticated Gmail phishing email making it rounds. New techniques and tactics, have given hackers a way to authentically impersonate your contacts.How it Works The attack works by targeti…
In Microsoft Access, learn the trick to repeating sub-report headings at the top of each page. The problem with sub-reports and headings: Add a dummy group to the sub report using the expression =1: Set the “Repeat Section” property of the dummy…
In Microsoft Access, when working with VBA, learn some techniques for writing readable and easily maintained code.

840 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question