Hallo Karl-Heinz
Sobald alle Pflichtfelder ausgefüllt sind, kann man das folgende Script erst auslösen (Mail wird verschickt). Sobald das der Fall ist, dass man den Button drücken kann, um das Mail zu schicken, soll dann das Blatt " Tabelle2" sichtbar sein. Denn darin befindet sich eine Bestätigung des auftrags.
Wie du siehst, habe ich die Aufzählung in G4 so eingebaut. Bei deiner Variannte musste ich jeweils Debuggen. Eventuell liegt es daran, dass die Seite jeweils geschützt werden muss.
Option Private Module
Sub Absenden()
[G4] = [G4] + 1
ActiveSheet.Unprotect Password:=""
Dim Source As Range
Dim Dest As Workbook
Dim wb As Workbook
Dim TempFilePath As String
Dim TempFileName As String
Dim FileExtStr As String
Dim FileFormatNum As Long
Dim OutApp As Object
Dim OutMail As Object
Set Source = Nothing
On Error Resume Next
Set Source = Range("A1:I27").SpecialCells(xlCellTypeVisible)
On Error GoTo 0
If Tabelle1.Range("E20").Value = "" Then
MsgBox "Zelle Baubeginn ist leer. Tragen Sie den Baubeginn ein!", vbCritical
Exit Sub
End If
ActiveSheet.Protect Password:=""
If Tabelle1.Range("E22").Value = "" Then
MsgBox "Zelle Bauende ist leer. Tragen Sie das voraussichtliche Bau-Ende ein!", vbCritical
Exit Sub
End If
ActiveSheet.Protect Password:=""
If Tabelle1.Range("E24").Value = "" Then
MsgBox "Zelle Budgetierte Bausumme (EUR) ist leer. Tragen Sie einen Wert ein!", vbCritical
Exit Sub
End If
ActiveSheet.Protect Password:=""
If Tabelle1.Range("E26").Value = "" Then
MsgBox "Zelle Tochtergesellschaft ist leer. Tragen Sie einen Wert ein!", vbCritical
Exit Sub
End If
ActiveSheet.Protect Password:=""
With Application
.ScreenUpdating = False
.EnableEvents = False
End With
Set wb = ActiveWorkbook
Set Dest = Workbooks.Add(xlWBATWorksheet)
Source.Copy
With Dest.Sheets(1)
.Cells(1).PasteSpecial Paste:=8
.Cells(1).PasteSpecial Paste:=xlPasteValues
.Cells(1).PasteSpecial Paste:=xlPasteFormats
.Cells(1).Select
Application.CutCopyMode = False
End With
TempFilePath = Environ$("temp") & "\"
TempFileName = "Selection of " & wb.Name & " " _
& Format(Now, "dd-mmm-yy h-mm-ss")
If Val(Application.Version) < 12 Then
'You use Excel 2000-2003
FileExtStr = ".xlsx": FileFormatNum = -4143
Else
'You use Excel 2007-2010
FileExtStr = ".xlsx": FileFormatNum = 51
End If
Set OutApp = CreateObject("Outlook.Application")
Set OutMail = OutApp.CreateItem(0)
With Dest
.SaveAs TempFilePath & TempFileName & FileExtStr, _
FileFormat:=FileFormatNum
On Error Resume Next
With OutMail
.GetInspector
.To = "irgendeinmail@weisnicht.de"
.CC = ""
.BCC = ""
.Subject = "Projekt"
.Body = "Bauprojekt" & vbCrLf & .Body
.Attachments.Add Dest.FullName
.Display
End With
On Error GoTo 0
.Close SaveChanges:=False
End With
Kill TempFilePath & TempFileName & FileExtStr
Set OutMail = Nothing
Set OutApp = Nothing
With Application
.ScreenUpdating = True
.EnableEvents = True
End With
ActiveSheet.Protect Password:=""
End Sub
|