RecordOrganizer/app/DD-Record-Organiser/ClassOfficeTemplate.vb
2015-07-27 15:56:59 +02:00

117 lines
6.7 KiB
VB.net

Imports Microsoft.Office.Interop.Word
Public Class ClassOfficeTemplate
Public Shared Function Open_Word_Template(Template_ID As Integer, Record_ID As Integer)
Try
Dim sql_Template As String = "SELECT * FROM VWPMO_TEMPLATE_ENTITY WHERE TEMPLATE_ID = " & Template_ID
Dim DT_TEMPLATE As System.Data.DataTable = ClassDatabase.Return_Datatable(sql_Template)
Dim sql_patterns As String = "select * from TBPMO_TEMPLATE_ENTITY_PATTERN where TEMPL_ENT_ID = (SELECT GUID FROM TBPMO_TEMPLATE_ENTITY WHERE ENTITY_ID = " & CURRENT_FORM_ID & " AND TEMPLATE_ID = " & Template_ID & ")"
Dim DT_PATTERNS As System.Data.DataTable = ClassDatabase.Return_Datatable(sql_patterns)
If IsNothing(DT_PATTERNS) Then
MsgBox("Keine Patterns für diese Vorlage definiert. Bitte prüfen Sie die Konfiguration!", MsgBoxStyle.Critical)
Return False
End If
Dim Original_Vorlage As String = DT_TEMPLATE.Rows(0).Item("TEMPLATE_PATH")
Dim DOCTYPE_ID As Integer = ClassDatabase.Execute_Scalar("SELECT DOCTYPE_ID FROM TBPMO_TEMPLATE_ENTITY WHERE ENTITY_ID = " & CURRENT_FORM_ID & " AND TEMPLATE_ID = " & Template_ID)
If System.IO.File.Exists(Original_Vorlage) = False Then
MsgBox("Achtung: die Vorlage " & vbNewLine & Original_Vorlage & vbNewLine & "existiert nicht!", MsgBoxStyle.Critical)
Return False
End If
Dim tempdoc = ClassHelper.Get_TempFilename & ".docx"
System.IO.File.Copy(Original_Vorlage, tempdoc)
Dim word As New Microsoft.Office.Interop.Word.Application
Dim doc As Microsoft.Office.Interop.Word.Document
doc = word.Documents.Open(tempdoc)
doc.Activate()
Dim _BuiltInProperties As Object = doc.BuiltInDocumentProperties
If Not _BuiltInProperties Is Nothing Then
'_BuiltInProperties("Title").Value = txtTitle.Text.Trim()
'_BuiltInProperties("Subject").Value = txtSubject.Text.Trim()
' _BuiltInProperties("Author").Value = txtAuthor.Text.Trim()
'_BuiltInProperties("Manager").Value = txtManager.Text.Trim()
'_BuiltInProperties("Company").Value = txtCompany.Text.Trim()
_BuiltInProperties("Category").Value = DT_TEMPLATE.Rows(0).Item("TEMPLATE_NAME")
'_BuiltInProperties("Keywords").Value = txtKeyWords.Text.Trim()
_BuiltInProperties("Comments").Value = "RECORD_ID:" & CURRENT_RECORD_ID.ToString
End If
' word.Visible = (True) 'Word sichtbar
For Each cc In doc.ContentControls
If LogErrorsOnly = False Then ClassLogger.Add(">> Office-Pattern: " & cc.Tag, False)
For Each patternrow As System.Data.DataRow In DT_PATTERNS.Rows
If patternrow.Item("NAME_PATTERN").ToString.ToUpper = cc.tag.ToString.ToUpper Then
If Not IsDBNull(patternrow.Item("FIXED_VALUE")) Then
'Fixed Value ist gefüllt
Dim fvalue As String = patternrow.Item("FIXED_VALUE").ToString.ToUpper
If fvalue <> "" Then
If fvalue.Contains("@") Then
If fvalue.Contains("CONTROLID") Then
Dim Control_ID = fvalue.Replace("@CONTROLID:", "")
Try
If CInt(Control_ID) Then
If LogErrorsOnly = False Then ClassLogger.Add(">> Get Value for Control-ID: " & Control_ID.ToString, False)
Dim value_akt = ClassDatabase.Execute_Scalar("SELECT VALUE FROM TBPMO_CONTROL_VALUE WHERE CONTROL_ID = " & Control_ID & " AND RECORD_ID = " & Record_ID)
If Not IsNothing(value_akt) Then
cc.Range.Text = value_akt.ToString
Else
ClassLogger.Add("Für Control-ID '" & Control_ID & "' konnte kein Wert gelesen werden!", True)
End If
End If
Catch ex As Exception
ClassLogger.Add("Unerwarteter Fehler beim Auslesen eines Control-Wertes in Pattern-For: " & ex.Message, True)
End Try
End If
Else
If LogErrorsOnly = False Then ClassLogger.Add(">> Pattern wird mit festem Wert '" & patternrow.Item("FIXED_VALUE") & "' gefüllt!", False)
cc.Range.Text = patternrow.Item("FIXED_VALUE").ToString
End If
End If
Else 'Kein Fixed Value, also wohl eher sql-result
If Not IsDBNull(patternrow.Item("CONNECTION_ID")) Then
If Not IsDBNull(patternrow.Item("SQL_COMMAND")) Then
End If
End If
End If
End If
Next
Next cc
' doc.ContentControls().Item("Name").Range.Text = "Schreiber"
'Textmarken füllen
' doc.().Item("Name").Range.Text = "Schreiber"
'doc.Bookmarks().Item("Vorname").Range.Text = "Marlon"
'doc.Bookmarks().Item("Produktion").Range.Text = "Testproduktion"
doc.SaveAs(tempdoc)
'doc.Close()
'speichern / drucken
'doc.SaveAs("c:\Proforma.doc")
'doc.PrintOut()
doc.Close()
doc = Nothing
word.Quit()
If ClassImport_Windream.Import_File(tempdoc, DOCTYPE_ID) = True Then
System.IO.File.Delete(tempdoc)
Process.Start(CURRENT_FILEIN_WD)
Return True
Else
MsgBox("Die Vorlage konnte nicht nach windream importiert werden. Die Datei wird dennoch geöffnet!", MsgBoxStyle.Exclamation)
Process.Start(tempdoc)
Return False
End If
Catch ex As Exception
ClassLogger.Add("Error in Open_Word_Template: " & ex.Message, True)
MsgBox("Unexpected Error in Open_Word_Template:" & vbNewLine & ex.Message, MsgBoxStyle.Critical)
Return False
End Try
End Function
Private Func
End Class