VBA - Saving an email only after 'Send' is pushed?

mv2005

Board Regular
Joined
May 23, 2004
Messages
73
I have a spreadsheet that automatically creates an email (based on code from rondebruin.com and some manipulation from a consultant) and initially would just save a copy of the message on our network (for records purposes) as well as sending it.

However it occured to me after that there will be times when attachments are required and as such for archiving purposes it really needs any attachments to also be saved as part of the email. What I believe to be the relevant code is shown below:

With OutMail
.To = TextBox6.Value
.CC = ""
.BCC = ""
.subject = "MRWA response to your inquiry on " & ComboBox9.Value
.body = strbody
.Display 'or use .Send
.SaveAs "\\Dacsrv02\rtddata\Advice\Tech Queries\TRIM Emails\" & emailname
End With
On Error GoTo 0

The thing is it is storing the email at the same time it opens it for display. As such any attachments would be made post save. How would I go about getting it to wait until after attachments have been made (presumably once it detects the 'Send' button has been pushed on the email)?

Thanks
Mike
 
Hey Mike,

I don't often use Class Modules, and what I know about Outlook could fit on the back of a ****tail napkin. That said, I cleaned-up my previous suggestion a bit, and got rid of .Logon and a couple of things.

You may well get better suggestions, but in the mean time, try this one first. In short, rather than later worrying about handling a bad logon attempt, we just insist the user is already in Outlook, which as you stated, is the expected case. If this works, we can worry about if the user cancels the email (instead of hitting the Send button).

Mark

In your created Class Module named "clsOutlook":

Rich (BB code):
Option Explicit
Public WithEvents obj_OL As Outlook.Application
'
Private Sub obj_OL_ItemSend(ByVal Item As Object, Cancel As Boolean)
 
    '// For example, change pathway to suit, such as:                           //
    '// "\\Dacsrv02\rtddata\Advice\TechQueries\TRIM Emails" & emailname
    OutMail.SaveAs ThisWorkbook.Path & _
                           Application.PathSeparator & _
                           emailname
 
    '// AFTER the event has been called, explicitly release Outlook.        //
    Set obj_OL = Nothing
    Set OutMail = Nothing
End Sub


In the standard module that your already had:

Rich (BB code):
Option Explicit
'// Connect the declared object w/the class module                          //
Dim cls_OL As New clsOutlook
'// Declare the email msg (mail item) and emailname string as Public, so    //
'// that they can be "seen" from any procedures in the class mod.           //
Public OutMail As Outlook.MailItem
Public emailname As String
Sub Email_Response()
Dim strbody As String
Dim emaildate As String
Dim newdate As String
'// You no doubt are using some/all of these for other code not included.   //
'// I simply rem'd them to make the example easier to read.                 //
'Dim copymail As NewFile
'Dim Staff As String
'Dim Who As String
'Dim What As String
'Dim How_Long As String
'Dim Fortnight As Date
'Dim Name As Integer
'Dim Criteria1 As Integer
'Dim Criteria2 As Integer
'Dim Criteria3 As Integer
'Dim Criteria5 As Integer
'Dim Criteria6 As Integer
'Dim Criteria7 As Integer
    '// Switch error handling to in-line for a moment.  This way when we    //
    '// try and GetObject, if Outlook is not already running, an error will //
    '// occur, which we can use to tell us what to do next.                 //
    On Error Resume Next
    '// Rather than Create the object, we'll just GetObject.  While this    //
    '// means the user must be logged on to Outlook, this means we no longer//
    '// have to worry about .Logon or what happens if the user goobers up   //
    '// their password.                                                     //
    Set cls_OL.obj_OL = GetObject(Class:="Outlook.Application")
 
    '// If Outlook was running, we skip by this.                            //
    If Err.Number > 0 Then
        '// If we made it here, Outlook was not running, so we want to make //
        '// a graceful exit...                                              //
        On Error GoTo 0
        Err.Clear
        Set cls_OL.obj_OL = Nothing
        MsgBox "Sorry - Outlook must be running before this program can run." _
               & vbCrLf & _
               "Please logon to Outlook, then (push whatever button " & _
               "starts this).", _
               vbCritical, ""
        Exit Sub
    End If
 
    '// Since we made it past the previous test, Outlook is running, and we //
    '// should reset error handling, as elsewise we may have problems       //
    '// in our code 'masked'.                                               //
    On Error GoTo 0
 
    '// "timestamp" the sheet.                                              //
    ThisWorkbook.Worksheets("Technical Inquiry Form").Range("C30").Value = Now()
 
    '// I don't see why we're disabling events, but killing .ScreenUpdating //
    '// will speed up processing if there's data being written or other     //
    '// visible changes that would normally be painted upon execution.      //
    With Application
        .EnableEvents = False
        .ScreenUpdating = False
    End With
 
    '// Create our new mail item                                            //
    Set OutMail = cls_OL.obj_OL.CreateItem(0)
'    If OptionButton1.Value = True Then
'        '... strBody built here...
'    End If
    '// Example substitute                                                      //
    strbody = "This is just example text, to substitute for the string built " & _
              "from all the text boxes etc..."
 
    On Error Resume Next
 
    emaildate = Sheets("Technical Inquiry Form").Range("c30")
 
    newdate = Day(Sheets("Technical Inquiry Form").Range("c30")) & "-" & _
              Month(Sheets("Technical Inquiry Form").Range("c30")) & "-" & _
              Year(Sheets("Technical Inquiry Form").Range("c30"))
 
    emailname = "MRWA response to inquiry on " & "ComboBox9.Value" & _
                " (Trim file " & _
                Sheets("Technical Inquiry Form").Range("H22") & ") " & _
                newdate & ".msg"
    With OutMail
        .To = TextBox6.Value
        .CC = ""
        .BCC = ""
        .Subject = "MRWA response to your inquiry on " & "ComboBox9.Value"
        .body = strbody
        .Display
    End With
 
    On Error GoTo 0
 
    With Application
        .EnableEvents = True
        .ScreenUpdating = True
    End With
End Sub


Error Correction:
This post was so helpful to me except there is an error that plagued me for 2 days!! 'OutMail' in this class module should be
Item.

'// For example, change pathway to suit, such as: //
'// "\\Dacsrv02\rtddata\Advice\TechQueries\TRIM Emails" & emailname
OutMail.SaveAs ThisWorkbook.Path & _
Application.PathSeparator & _
emailname
 
Upvote 0

Excel Facts

Can Excel fill bagel flavors?
You can teach Excel a new custom list. Type the list in cells, File, Options, Advanced, Edit Custom Lists, Import, OK
Anyone has solution for this problem?
I have tried the solution however it still saved the "draft email" instead of "sent email".

I have a spreadsheet that automatically creates an email (based on code from rondebruin.com and some manipulation from a consultant) and initially would just save a copy of the message on our network (for records purposes) as well as sending it.

However it occured to me after that there will be times when attachments are required and as such for archiving purposes it really needs any attachments to also be saved as part of the email. What I believe to be the relevant code is shown below:

With OutMail
.To = TextBox6.Value
.CC = ""
.BCC = ""
.subject = "MRWA response to your inquiry on " & ComboBox9.Value
.body = strbody
.Display 'or use .Send
.SaveAs "\\Dacsrv02\rtddata\Advice\Tech Queries\TRIM Emails" & emailname
End With
On Error GoTo 0

The thing is it is storing the email at the same time it opens it for display. As such any attachments would be made post save. How would I go about getting it to wait until after attachments have been made (presumably once it detects the 'Send' button has been pushed on the email)?

Thanks
Mike
 
Upvote 0

Forum statistics

Threads
1,223,911
Messages
6,175,325
Members
452,635
Latest member
laura12345

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