Testing
Public Sub CreateDocument()
Dim oDocument As Word.Document
Dim oCellRange As Word.Range
On Error GoTo ErrorHandler
' ActiveDocument.Sections(1).PageSetup.DifferentFirstPageHeaderFooter = False
' Set oDocument = Application.Documents.Add
'
' oDocument.PageSetup.TopMargin = CentimetersToPoints(3.81)
' oDocument.PageSetup.BottomMargin = CentimetersToPoints(1.27)
'
' oDocument.ActiveWindow.View.Type = wdPrintView
Call Page_HeaderFooterInsert_Page1
'add/modify the page content
Set oCellRange = ActiveDocument.Sections(1).Range.Paragraphs(1).Range
oCellRange.InsertBreak (WdBreakType.wdSectionBreakNextPage)
Call Page_HeaderFooterInsert_Page2
'add/modify the page content
Set oCellRange = ActiveDocument.Content
oCellRange.Collapse Direction:=WdCollapseDirection.wdCollapseEnd
oCellRange.InsertBreak (WdBreakType.wdSectionBreakNextPage)
Call Page_HeaderFooterInsert_Page3
'add/modify the page content
Set oCellRange = ActiveDocument.Content
oCellRange.Collapse Direction:=WdCollapseDirection.wdCollapseEnd
oCellRange.Delete
Set oCellRange = ActiveDocument.Content
oCellRange.Collapse Direction:=WdCollapseDirection.wdCollapseEnd
oCellRange.InsertBreak (WdBreakType.wdSectionBreakNextPage)
'add/modify the page content
Call Page_HeaderFooterInsert_Page4
'add/modify the page content
Set oCellRange = ActiveDocument.Content
oCellRange.Collapse Direction:=WdCollapseDirection.wdCollapseEnd
oCellRange.Text = "Introduction"
ActiveDocument.ActiveWindow.View.Type = wdPrintView
' oRange.Style = "Header"
' oRange.InsertAfter "Boyd Consultants" & vbTab
' oRange.Collapse WdCollapseDirection.wdCollapseEnd
' ActiveDocument.Fields.Add Range:=oRange, _
' Type:=wdFieldEmpty, _
' Text:="FILENAME", _
' PreserveFormatting:=True
Exit Sub
ErrorHandler:
Call MsgBox(Err.Number & " - " & Err.Description)
End Sub
'****************************************************************************************
Public Sub Page_HeaderFooterInsert_Page1()
Const sPROCNAME As String = "Page_HeaderFooterInsert_Page1"
Dim oHeader As Word.HeaderFooter
Dim oHeaderRange As Word.Range
Dim oTable As Word.Table
Dim oCellRange As Word.Range
Dim oLogoShape As Word.Shape
On Error GoTo ErrorHandler
Set oHeader = ActiveDocument.Sections(1).Headers(WdHeaderFooterIndex.wdHeaderFooterPrimary)
Set oHeaderRange = oHeader.Range
oHeaderRange.Paragraphs.Alignment = Word.WdParagraphAlignment.wdAlignParagraphRight
Set oTable = ActiveDocument.Tables.Add(Range:=oHeaderRange, _
NumRows:=1, _
NumColumns:=2, _
DefaultTableBehavior:=WdDefaultTableBehavior.wdWord8TableBehavior, _
AutoFitBehavior:=WdAutoFitBehavior.wdAutoFitWindow)
oTable.LeftPadding = CentimetersToPoints(0)
oTable.RightPadding = CentimetersToPoints(0)
oTable.Cell(1, 1).Range.Paragraphs.Alignment = wdAlignParagraphLeft
oTable.Cell(1, 1).Width = Application.CentimetersToPoints(3)
oTable.Cell(1, 2).Range.Paragraphs.Alignment = wdAlignParagraphLeft
oTable.Cell(1, 2).Width = Application.CentimetersToPoints(13.51)
oTable.Rows(1).SetHeight RowHeight:=Application.CentimetersToPoints(2.4), HeightRule:=wdRowHeightExactly
'add the orange bottom border
' oTable.Borders(wdBorderBottom).LineStyle = Word.WdLineStyle.wdLineStyleSingle
' oTable.Borders(wdBorderBottom).Color = RGB(240, 139, 29)
' oTable.Borders(wdBorderBottom).LineWidth = Word.WdLineWidth.wdLineWidth100pt
'add the logo to first cell
Set oCellRange = oTable.Cell(1, 1).Range
oCellRange.Collapse Direction:=WdCollapseDirection.wdCollapseStart
Set oCellRange = Template_InsertCustomAutoText("AT_Logo", oCellRange)
'make the shape inline
Set oLogoShape = oCellRange.ShapeRange(1)
oLogoShape.WrapFormat.Type = wdWrapInline
'insert the embedded table
Set oCellRange = oTable.Cell(1, 2).Range
oCellRange.Collapse Direction:=WdCollapseDirection.wdCollapseStart
Set oTable = ActiveDocument.Tables.Add(Range:=oCellRange, _
NumRows:=2, _
NumColumns:=1, _
DefaultTableBehavior:=WdDefaultTableBehavior.wdWord8TableBehavior, _
AutoFitBehavior:=WdAutoFitBehavior.wdAutoFitWindow)
Exit Sub
ErrorHandler:
Call MsgBox(Err.Number & " - " & Err.Description)
End Sub
'****************************************************************************************
Public Sub Page_HeaderFooterInsert_Page2()
Const sPROCNAME As String = "Page_HeaderFooterInsert_Page2"
Dim oHeader As Word.HeaderFooter
Dim oHeaderRange As Word.Range
Dim oCellRange As Word.Range
Dim oLogoShape As Word.Shape
Dim oTable As Word.Table
On Error GoTo ErrorHandler
Set oHeader = ActiveDocument.Sections(2).Headers(WdHeaderFooterIndex.wdHeaderFooterPrimary)
oHeader.LinkToPrevious = False
Set oHeaderRange = oHeader.Range
'inside the header, insert another table underneath
oHeaderRange.Collapse wdCollapseEnd
' oHeaderRange.Paragraphs.Alignment = Word.WdParagraphAlignment.wdAlignParagraphLeft
oHeaderRange.InsertParagraphAfter
oHeaderRange.Collapse wdCollapseEnd
Set oTable = oHeaderRange.Tables.Add(Range:=oHeaderRange, _
NumRows:=4, _
NumColumns:=1, _
DefaultTableBehavior:=WdDefaultTableBehavior.wdWord8TableBehavior, _
AutoFitBehavior:=WdAutoFitBehavior.wdAutoFitWindow)
oTable.Cell(1, 1).Range.Text = "three"
oTable.Cell(1, 1).Range.Style = "Heading 4" '"~ProjectName"
oTable.Cell(2, 1).Range.Text = "four"
oTable.Cell(2, 1).Range.Style = "Heading 5" '"~ReportTitle"
oTable.Cell(3, 1).Range.Text = "five"
oTable.Cell(3, 1).Range.Style = "Heading 6" '"~PropertyAddress"
Exit Sub
ErrorHandler:
Call MsgBox(Err.Number & " - " & Err.Description)
' Call Error_Handle(msMODULENAME, sPROCNAME, Err.Number, Err.Description)
End Sub
'****************************************************************************************
Public Sub Page_HeaderFooterInsert_Page3()
Const sPROCNAME As String = "Page_HeaderFooterInsert_Page3"
Dim oHeader As Word.HeaderFooter
Dim oHeaderRange As Word.Range
Dim oTable As Word.Table
On Error GoTo ErrorHandler
Set oHeader = ActiveDocument.Sections(3).Headers(WdHeaderFooterIndex.wdHeaderFooterPrimary)
oHeader.LinkToPrevious = False
Set oHeaderRange = oHeader.Range
'modify the embedded table
Set oTable = oHeaderRange.Tables(1).Tables(1)
oTable.Cell(1, 1).Range.Text = "one"
oTable.Cell(1, 1).Range.Style = "Heading 3"
oTable.Cell(1, 1).Range.Paragraphs.Alignment = wdAlignParagraphRight
oTable.Cell(2, 1).Range.Text = "two"
oTable.Cell(2, 1).Range.Style = "Heading 4"
oTable.Cell(2, 1).Range.Paragraphs.Alignment = wdAlignParagraphRight
'inside the header, remove the second table
Set oTable = oHeaderRange.Tables(2)
oTable.Delete
oHeaderRange.Collapse wdCollapseEnd
oHeaderRange.Delete
Exit Sub
ErrorHandler:
Call MsgBox(Err.Number & " - " & Err.Description)
End Sub
'****************************************************************************************
Public Sub Page_HeaderFooterInsert_Page4()
Const sPROCNAME As String = "Page_HeaderFooterInsert_Page4"
Dim oFooter As Word.HeaderFooter
Dim oFooterRange As Word.Range
Dim oTable As Word.Table
On Error GoTo ErrorHandler
Set oFooter = ActiveDocument.Sections(4).Footers(WdHeaderFooterIndex.wdHeaderFooterPrimary)
oFooter.LinkToPrevious = False
Set oFooterRange = oFooter.Range
'inside the footer, add the page number
oFooterRange.Text = "footer"
Exit Sub
ErrorHandler:
Call MsgBox(Err.Number & " - " & Err.Description)
End Sub
'****************************************************************************************
Attribute VB_Name = "modAppendixDivider"
Option Explicit
Public Sub InsertAppendixDivider()
Dim oRange As Word.Range
Dim oRange2 As Word.Range
Dim oBMRange As Word.Range
Dim oFormField As Word.FormField
Set oRange = Selection.Range
oRange.Paragraphs.Format.Style = "Heading 1"
Set oFormField = Selection.FormFields.Add(Range:=oRange, _
Type:=WdFieldType.wdFieldFormTextInput)
oFormField.Result = "<Insert Appendix Heading>"
Set oBMRange = oFormField.Range
'oBMRange.Select
ActiveDocument.Bookmarks.Add name:="BM_FirstAppHeading", Range:=oBMRange
Set oRange = oBMRange.Duplicate
oRange.Collapse wdCollapseEnd
oRange.Select
oRange.InsertParagraph
oRange.Move Unit:=WdUnits.wdParagraph, Count:=1
'oRange.Select
'add the bookmark including the paragraph mark
'oBMRange.Select
oBMRange.End = oBMRange.End + 1
oBMRange.Select
ActiveDocument.Bookmarks.Add name:="BM_AppHeading", Range:=oBMRange
oRange.Paragraphs.Format.Style = "Heading 2"
Set oFormField = Selection.FormFields.Add(Range:=oRange, _
Type:=WdFieldType.wdFieldFormTextInput)
oFormField.Result = "<Insert description text if required>"
Set oRange = oFormField.Range
oRange.Collapse wdCollapseEnd
oRange.InsertParagraph
oRange.Move Unit:=WdUnits.wdParagraph, Count:=1
oRange.InsertBreak (WdBreakType.wdPageBreak)
oRange.Move Unit:=WdUnits.wdParagraph, Count:=1
End Sub
'WITH TABLE
'Public Sub InsertAppendixDivider()
'Dim oRange As Word.Range
'Dim oBMRange As Word.Range
'Dim oFormField As Word.FormField
'
' Set oRange = Selection.Range
'
' Set oTable = ActiveDocument.Tables.Add(Range:=oRange, _
' NumRows:=1, _
' NumColumns:=1, _
' DefaultTableBehavior:=WdDefaultTableBehavior.wdWord8TableBehavior, _
' AutoFitBehavior:=WdAutoFitBehavior.wdAutoFitWindow)
'
' Set oRange = oTable.Cell(1, 1).Range
' 'oRange.Select
'
' 'modify the range to the contents of the cell, not the whole cell
' oRange.End = oRange.End - 1
'
' oRange.Paragraphs.Format.Style = "~AppHead1"
' Set oFormField = Selection.FormFields.Add(Range:=oRange, _
' Type:=WdFieldType.wdFieldFormTextInput)
' oFormField.Result = "<Insert Appendix Heading>"
'
' Set oBMRange = oFormField.Range
' ActiveDocument.Bookmarks.Add name:="BM_FirstAppHeading", Range:=oBMRange
'
' Set oRange = oTable.Cell(1, 1).Range
'
' oRange.End = oRange.End - 1
' oRange.Collapse wdCollapseEnd
' oRange.InsertParagraph
' oRange.Move Unit:=WdUnits.wdParagraph, Count:=1
'
' 'add the bookmark including the paragraph mark
' oBMRange.End = oBMRange.End + 1
' ActiveDocument.Bookmarks.Add name:="BM_AppHeading", Range:=oBMRange
'
'
' oRange.Paragraphs.Format.Style = "~TableTextLeft"
' Set oFormField = Selection.FormFields.Add(Range:=oRange, _
' Type:=WdFieldType.wdFieldFormTextInput)
' oFormField.Result = "<Insert description text if required>"
'
' Set oRange = oTable.Range
' oRange.Collapse wdCollapseEnd
'
' oRange.InsertParagraph
' oRange.Move Unit:=WdUnits.wdParagraph, Count:=1
'
' oRange.InsertBreak (WdBreakType.wdPageBreak)
' oRange.Move Unit:=WdUnits.wdParagraph, Count:=1
'
'End Sub
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrev