summaryrefslogtreecommitdiff
path: root/wizards/source
diff options
context:
space:
mode:
authorJean-Pierre Ledure <jp@ledure.be>2023-10-04 16:59:53 +0200
committerJean-Pierre Ledure <jp@ledure.be>2023-10-04 18:50:16 +0200
commita29841ccbdf1e71b9a7c943c5c430d1a1b96234b (patch)
tree9c178447b440a7dbc3a9aff533080009c5acec68 /wizards/source
parent7b4bf155b622e985cdc5f90d620d0a797bc48204 (diff)
ScriptForge (SFDocuments) Styles management
Introduction of new properties and methods: - StyleFamilies List of available style families All document types except Base - XStyle(family, stylename) UNO representation of given style All document types except Base - Styles(family, [namepattern, used, userdefined, parentstyle, category) A list of styles matching the given criteria All document types except Base - DeleteStyles(family, styleslist) Suppress the user-defined styles in the list All document types except Base and FormDocument - ImportStylesFromFile(filename, families, overwrite) Load styles from a closed file Calc and Writer only Example: to delete unused styles: a = doc.Styles("ParagraphStyles", used := False) doc.DeleteStyles("ParagraphStyles", a) All functionalities are available from Basic and Python scripts. Documentation has to be completed. Change-Id: I2533c14912257b58feb42bb11ff9d151c7b9531a Reviewed-on: https://gerrit.libreoffice.org/c/core/+/157563 Reviewed-by: Jean-Pierre Ledure <jp@ledure.be> Tested-by: Jenkins
Diffstat (limited to 'wizards/source')
-rw-r--r--wizards/source/scriptforge/SF_PythonHelper.xba8
-rw-r--r--wizards/source/scriptforge/python/ScriptForgeHelper.py2
-rw-r--r--wizards/source/scriptforge/python/scriptforge.py49
-rw-r--r--wizards/source/sfdocuments/SF_Calc.xba39
-rw-r--r--wizards/source/sfdocuments/SF_Document.xba457
-rw-r--r--wizards/source/sfdocuments/SF_FormDocument.xba25
-rw-r--r--wizards/source/sfdocuments/SF_Writer.xba39
7 files changed, 611 insertions, 8 deletions
diff --git a/wizards/source/scriptforge/SF_PythonHelper.xba b/wizards/source/scriptforge/SF_PythonHelper.xba
index b611dbfd0d7e..8ad0dfa7c06c 100644
--- a/wizards/source/scriptforge/SF_PythonHelper.xba
+++ b/wizards/source/scriptforge/SF_PythonHelper.xba
@@ -783,6 +783,7 @@ Try:
Case &quot;SFDocuments.Document&quot;
Select Case Script
Case &quot;Forms&quot; : vReturn = vBasicObject.Forms(vArgs(0))
+ Case &quot;Styles&quot; : vReturn = vBasicObject.Styles(vArgs(0), vArgs(1), vArgs(2), vArgs(3), vArgs(4), vArgs(5))
Case &quot;Toolbars&quot; : vReturn = vBasicObject.Toolbars(vArgs(0))
End Select
Case &quot;SFDocuments.Base&quot;
@@ -800,6 +801,7 @@ Try:
Case &quot;SetArray&quot; : vReturn = vBasicObject.SetArray(vArgs(0), vArgs(1))
Case &quot;SetFormula&quot; : vReturn = vBasicObject.SetFormula(vArgs(0), vArgs(1))
Case &quot;SetValue&quot; : vReturn = vBasicObject.SetValue(vArgs(0), vArgs(1))
+ Case &quot;Styles&quot; : vReturn = vBasicObject.Styles(vArgs(0), vArgs(1), vArgs(2), vArgs(3), vArgs(4), vArgs(5))
Case &quot;Toolbars&quot; : vReturn = vBasicObject.Toolbars(vArgs(0))
End Select
Case &quot;SFDocuments.Form&quot;
@@ -814,6 +816,12 @@ Try:
Case &quot;Forms&quot; : vReturn = vBasicObject.Forms(vArgs(0))
Case &quot;Toolbars&quot; : vReturn = vBasicObject.Toolbars(vArgs(0))
End Select
+ Case &quot;SFDocuments.Writer&quot;
+ Select Case Script
+ Case &quot;Forms&quot; : vReturn = vBasicObject.Forms(vArgs(0))
+ Case &quot;Styles&quot; : vReturn = vBasicObject.Styles(vArgs(0), vArgs(1), vArgs(2), vArgs(3), vArgs(4), vArgs(5))
+ Case &quot;Toolbars&quot; : vReturn = vBasicObject.Toolbars(vArgs(0))
+ End Select
Case &quot;SFWidgets.Toolbar&quot;
Select Case Script
Case &quot;ToolbarButtons&quot; : vReturn = vBasicObject.ToolbarButtons(vArgs(0))
diff --git a/wizards/source/scriptforge/python/ScriptForgeHelper.py b/wizards/source/scriptforge/python/ScriptForgeHelper.py
index e228095053df..c9ebf6e61c88 100644
--- a/wizards/source/scriptforge/python/ScriptForgeHelper.py
+++ b/wizards/source/scriptforge/python/ScriptForgeHelper.py
@@ -24,7 +24,7 @@
"""
Collection of Python helper functions called from the ScriptForge Basic libraries
to execute specific services that are not or not easily available from Basic directly.
-When relevant, the methods present in the ScripForge Python module might call the
+When relevant, the methods present in the ScriptForge Python module (scriptforge.py) might call the
functions below for compatibility reasons.
"""
diff --git a/wizards/source/scriptforge/python/scriptforge.py b/wizards/source/scriptforge/python/scriptforge.py
index 060c57208de7..13ceadca96fc 100644
--- a/wizards/source/scriptforge/python/scriptforge.py
+++ b/wizards/source/scriptforge/python/scriptforge.py
@@ -2165,7 +2165,8 @@ class SFDocuments:
DocumentType = False, ExportFilters = False, FileSystem = False, ImportFilters = False,
IsBase = False, IsCalc = False, IsDraw = False, IsFormDocument = False,
IsImpress = False, IsMath = False, IsWriter = False, Keywords = True, Readonly = False,
- Subject = True, Title = True, XComponent = False, XDocumentSettings = False)
+ StyleFamilies = False, Subject = True, Title = True, XComponent = False,
+ XDocumentSettings = False)
# Force for each property to get its value from Basic - due to intense interactivity with user
forceGetProperty = True
@@ -2185,6 +2186,13 @@ class SFDocuments:
def CreateMenu(self, menuheader, before = '', submenuchar = '>'):
return self.ExecMethod(self.vbMethod, 'CreateMenu', menuheader, before, submenuchar)
+ def DeleteStyles(self, family, styleslist):
+ # Exclude Base, FormDocument and Math
+ doctype = self.DocumentType
+ if doctype in ('Calc', 'Writer', 'Draw', 'Impress'):
+ return self.ExecMethod(self.vbMethod, 'DeleteStyles', family, styleslist)
+ raise RuntimeError('The \'DeleteStyles\' method is not applicable to {0} documents'.format(doctype))
+
def Echo(self, echoon = True, hourglass = False):
return self.ExecMethod(self.vbMethod, 'Echo', echoon, hourglass)
@@ -2214,9 +2222,28 @@ class SFDocuments:
def SetPrinter(self, printer = '', orientation = '', paperformat = ''):
return self.ExecMethod(self.vbMethod, 'SetPrinter', printer, orientation, paperformat)
+ def Styles(self, family, namepattern = '', used = ScriptForge.cstSymEmpty,
+ userdefined = ScriptForge.cstSymEmpty, parentstyle = '', category = ''):
+ # Exclude Base and Math
+ doctype = self.DocumentType
+ if doctype in ('Calc', 'Writer', 'FormDocument', 'Draw', 'Impress'):
+ return self.ExecMethod(self.vbMethod + self.flgArrayRet, 'Styles', family, namepattern, used,
+ userdefined, parentstyle, category)
+ raise RuntimeError('The \'Styles\' method is not applicable to {0} documents'.format(doctype))
+
def Toolbars(self, toolbarname = ''):
return self.ExecMethod(self.vbMethod + self.flgArrayRet, 'Toolbars', toolbarname)
+ def XStyle(self, family, stylename):
+ # Exclude Base and Math
+ doctype = self.DocumentType
+ if doctype in ('Calc', 'Writer', 'FormDocument', 'Draw', 'Impress'):
+ # XStyles() DOES NOT WORK through the socket bridge ?!? Works normally in direct mode.
+ if ScriptForge.port > 0:
+ return None
+ return self.ExecMethod(self.vbMethod + self.flgUno, 'XStyle', family, stylename)
+ raise RuntimeError('The \'XStyle\' method is not applicable to {0} documents'.format(doctype))
+
# #########################################################################
# SF_Base CLASS
# #########################################################################
@@ -2291,8 +2318,9 @@ class SFDocuments:
DocumentProperties = False, DocumentType = False, ExportFilters = False,
FileSystem = False, ImportFilters = False, IsBase = False, IsCalc = False,
IsDraw = False, IsFormDocument = False, IsImpress = False, IsMath = False,
- IsWriter = False, Keywords = True, Readonly = False, Sheets = False, Subject = True,
- Title = True, XComponent = False, XDocumentSettings = False)
+ IsWriter = False, Keywords = True, Readonly = False, Sheets = False,
+ StyleFamilies = False, Subject = True, Title = True, XComponent = False,
+ XDocumentSettings = False)
# Force for each property to get its value from Basic - due to intense interactivity with user
forceGetProperty = True
@@ -2440,6 +2468,9 @@ class SFDocuments:
return self.ExecMethod(self.vbMethod, 'ImportFromDatabase', filename, registrationname,
destinationcell, sqlcommand, directsql)
+ def ImportStylesFromFile(self, filename = '', families = '', overwrite = False):
+ return self.ExecMethod(self.vbMethod, 'ImportStylesFromFile', filename, families, overwrite)
+
def InsertSheet(self, sheetname, beforesheet = 32768):
return self.ExecMethod(self.vbMethod, 'InsertSheet', sheetname, beforesheet)
@@ -2561,8 +2592,7 @@ class SFDocuments:
OnApproveRowChange = True, OnApproveSubmit = True, OnConfirmDelete = True,
OnCursorMoved = True, OnErrorOccurred = True, OnLoaded = True, OnReloaded = True,
OnReloading = True, OnResetted = True, OnRowChanged = True, OnUnloaded = True,
- OnUnloading = True,
- OrderBy = True, Parent = False, RecordSource = True, XForm = False)
+ OnUnloading = True, OrderBy = True, Parent = False, RecordSource = True, XForm = False)
def Activate(self):
return self.ExecMethod(self.vbMethod, 'Activate')
@@ -2648,7 +2678,8 @@ class SFDocuments:
servicesynonyms = ('formdocument', 'sfdocuments.formdocument')
serviceproperties = dict(DocumentType = False, FileSystem = False, IsBase = False, IsCalc = False,
IsDraw = False, IsFormDocument = False, IsImpress = False, IsMath = False,
- IsWriter = False, Readonly = False, XComponent = False, XDocumentSettings = False)
+ IsWriter = False, Readonly = False, StyleFamilies = False, XComponent = False,
+ XDocumentSettings = False)
@classmethod
def ReviewServiceArgs(cls, windowname = ''):
@@ -2687,7 +2718,8 @@ class SFDocuments:
DocumentType = False, ExportFilters = False, FileSystem = False, ImportFilters = False,
IsBase = False, IsCalc = False, IsDraw = False, IsFormDocument = False,
IsImpress = False, IsMath = False, IsWriter = False, Keywords = True, Readonly = False,
- Subject = True, Title = True, XComponent = False, XDocumentSettings = False)
+ StyleFamilies = False, Subject = True, Title = True, XComponent = False,
+ XDocumentSettings = False)
# Force for each property to get its value from Basic - due to intense interactivity with user
forceGetProperty = True
@@ -2701,6 +2733,9 @@ class SFDocuments:
def Forms(self, form = ''):
return self.ExecMethod(self.vbMethod + self.flgArrayRet, 'Forms', form)
+ def ImportStylesFromFile(self, filename = '', families = '', overwrite = False):
+ return self.ExecMethod(self.vbMethod, 'ImportStylesFromFile', filename, families, overwrite)
+
def PrintOut(self, pages = '', copies = 1, printbackground = True, printblankpages = False,
printevenpages = True, printoddpages = True, printimages = True):
return self.ExecMethod(self.vbMethod, 'PrintOut', pages, copies, printbackground, printblankpages,
diff --git a/wizards/source/sfdocuments/SF_Calc.xba b/wizards/source/sfdocuments/SF_Calc.xba
index 941f23834230..a14be220ef37 100644
--- a/wizards/source/sfdocuments/SF_Calc.xba
+++ b/wizards/source/sfdocuments/SF_Calc.xba
@@ -2574,6 +2574,7 @@ Public Function Properties() As Variant
, &quot;Sheet&quot; _
, &quot;SheetName&quot; _
, &quot;Sheets&quot; _
+ , &quot;StyleFamilies&quot; _
, &quot;Subject&quot; _
, &quot;Title&quot; _
, &quot;Width&quot; _
@@ -3681,6 +3682,11 @@ Property Get Readonly() As Variant
End Property &apos; SFDocuments.SF_Calc.Readonly
REM -----------------------------------------------------------------------------
+Property Get StyleFamilies() As Variant
+ StyleFamilies = [_Super].GetProperty(&quot;StyleFamilies&quot;)
+End Property &apos; SFDocuments.SF_Calc.StyleFamilies
+
+REM -----------------------------------------------------------------------------
Property Get Subject() As Variant
Subject = [_Super].GetProperty(&quot;Subject&quot;)
End Property &apos; SFDocuments.SF_Calc.Subject
@@ -3731,6 +3737,13 @@ Public Function CreateMenu(Optional ByVal MenuHeader As Variant _
End Function &apos; SFDocuments.SF_Calc.CreateMenu
REM -----------------------------------------------------------------------------
+Public Sub DeleteStyles(Optional ByVal Family As Variant _
+ , Optional ByRef StylesList As Variant _
+ )
+ [_Super].DeleteStyles(Family, StylesList)
+End Sub &apos; SFDocuments.SF_Calc.DeleteStyles
+
+REM -----------------------------------------------------------------------------
Public Sub Echo(Optional ByVal EchoOn As Variant _
, Optional ByVal Hourglass As Variant _
)
@@ -3748,6 +3761,14 @@ Public Function ExportAsPDF(Optional ByVal FileName As Variant _
End Function &apos; SFDocuments.SF_Calc.ExportAsPDF
REM -----------------------------------------------------------------------------
+Public Sub ImportStylesFromFile(Optional FileName As Variant _
+ , Optional ByRef Families As Variant _
+ , Optional ByVal Overwrite As variant _
+ ) As Variant
+ [_Super]._ImportStylesFromFile(FileName, Families, Overwrite)
+End Sub &apos; SFDocuments.SF_Calc.ImportStylesFromFile
+
+REM -----------------------------------------------------------------------------
Public Function RemoveMenu(Optional ByVal MenuHeader As Variant) As Boolean
RemoveMenu = [_Super].RemoveMenu(MenuHeader)
End Function &apos; SFDocuments.SF_Calc.RemoveMenu
@@ -3793,10 +3814,28 @@ Public Function SetPrinter(Optional ByVal Printer As Variant _
End Function &apos; SFDocuments.SF_Calc.SetPrinter
REM -----------------------------------------------------------------------------
+Public Function Styles(Optional ByVal Family As Variant _
+ , Optional ByVal NamePattern As variant _
+ , Optional ByVal Used As variant _
+ , Optional ByVal UserDefined As Variant _
+ , Optional ByVal ParentStyle As Variant _
+ , Optional ByVal Category As Variant _
+ ) As Variant
+ Styles = [_Super].Styles(Family, NamePattern, Used, UserDefined, ParentStyle, Category)
+End Function &apos; SFDocuments.SF_Calc.Styles
+
+REM -----------------------------------------------------------------------------
Public Function Toolbars(Optional ByVal ToolbarName As Variant) As Variant
Toolbars = [_Super].Toolbars(ToolbarName)
End Function &apos; SFDocuments.SF_Calc.Toolbars
+REM -----------------------------------------------------------------------------
+Public Function XStyle(Optional ByVal Family As Variant _
+ , Optional ByVal StyleName As variant _
+ ) As Object
+ Set XStyle = [_Super].XStyle(Family, StyleName)
+End Function &apos; SFDocuments.SF_Calc.XStyle
+
REM =========================================================== PRIVATE FUNCTIONS
REM -----------------------------------------------------------------------------
diff --git a/wizards/source/sfdocuments/SF_Document.xba b/wizards/source/sfdocuments/SF_Document.xba
index 209834999c3b..917dd1ea58a9 100644
--- a/wizards/source/sfdocuments/SF_Document.xba
+++ b/wizards/source/sfdocuments/SF_Document.xba
@@ -60,6 +60,8 @@ Private Const DOCUMENTREADONLYERROR = &quot;DOCUMENTREADONLYERROR&quot;
Private Const FORMDEADERROR = &quot;FORMDEADERROR&quot;
+Private Const UNKNOWNFILEERROR = &quot;UNKNOWNFILEERROR&quot;
+
REM ============================================================= PRIVATE MEMBERS
Private [Me] As Object
@@ -84,6 +86,20 @@ Private _CustomProperties As Object &apos; Dictionary of custom properties
&apos; Cache for static toolbar descriptions
Private _Toolbars As Object &apos; SF_Dictionary instance to hold toolbars stored in application or in document
+&apos; Style descriptor
+Type StyleDescriptor
+ Family As Object
+ StyleName As String
+ DisplayName As String
+ IsUsed As Boolean
+ BuiltIn As Boolean
+ Category As String
+ ParentStyle As String
+ XStyle As Object
+End Type
+
+Private _StyleFamilies As Variant &apos; Array of available style families
+
REM ============================================================ MODULE CONSTANTS
Const ISDOCFORM = 1 &apos; Form is stored in a Writer document
@@ -107,6 +123,7 @@ Private Sub Class_Initialize()
Set _DocumentProperties = Nothing
Set _CustomProperties = Nothing
Set _Toolbars = Nothing
+ _StyleFamilies = Array()
End Sub &apos; SFDocuments.SF_Document Constructor
REM -----------------------------------------------------------------------------
@@ -345,6 +362,12 @@ Property Get Readonly() As Boolean
End Property &apos; SFDocuments.SF_Document.Readonly
REM -----------------------------------------------------------------------------
+Property Get StyleFamilies() As Variant
+&apos;&apos;&apos; Returns the list of available style families, as an array of strings
+ StyleFamilies = _PropertyGet(&quot;StyleFamilies&quot;)
+End Property &apos; SFDocuments.SF_Document.StyleFamilies
+
+REM -----------------------------------------------------------------------------
Property Get Subject() As Variant
&apos;&apos;&apos; Returns the updatable document property Subject
Subject = _PropertyGet(&quot;Subject&quot;)
@@ -565,6 +588,62 @@ Catch:
End Function &apos; SFDocuments.SF_Document.CreateMenu
REM -----------------------------------------------------------------------------
+Public Sub DeleteStyles(Optional ByVal Family As Variant _
+ , Optional ByRef StylesList As Variant _
+ )
+&apos;&apos;&apos; Delete a single style or an array of styles given by their name(s)
+&apos;&apos;&apos; within a specific styles family.
+&apos;&apos;&apos; Only user-defined styles may be deleted. Built-in styles are ignored.
+&apos;&apos;&apos; Args:
+&apos;&apos;&apos; Family: one of the style families present in the actual document, as a case-sensitive string
+&apos;&apos;&apos; StylesList: a single style name as a string or an array of style names.
+&apos;&apos;&apos; The style names may be localized or not.
+&apos;&apos;&apos; The StylesList is typically the output of the execution of a Styles() method.
+&apos;&apos;&apos; Returns:
+&apos;&apos;&apos; Examples:
+&apos;&apos;&apos; &apos; Remove all inised styles
+&apos;&apos;&apos; Const family = &quot;ParagraphStyles&quot;
+&apos;&apos;&apos; doc.DeleteStyles(family, doc.Styles(family, Used := False, UserDefined := True))
+
+Dim oFamily As Object &apos; Style names container
+Dim vStylesList As Variant &apos; Alias of StylesList
+Dim sStyle As String &apos; A single style name
+Const cstThisSub = &quot;SFDocuments.Document.DeleteStyles&quot;
+Const cstSubArgs = &quot;Family, StylesList&quot;
+
+ If ScriptForge.SF_Utils._ErrorHandling() Then On Local Error GoTo Catch
+
+Check:
+ If ScriptForge.SF_Utils._EnterFunction(cstThisSub, cstSubArgs) Then
+ If Not _IsStillAlive() Then GoTo Finally
+ If UBound(_StyleFamilies) &lt; 0 Then _StyleFamilies = _Component.getStyleFamilies().getElementNames()
+ If Not ScriptForge.SF_Utils._Validate(Family, &quot;Family&quot;, V_STRING, _StyleFamilies) Then GoTo Finally
+ If IsArray(StylesList) Then
+ If Not ScriptForge.SF_Utils._ValidateArray(StylesList, &quot;StylesList&quot;, 1, V_STRING, True) Then GoTo Finally
+ Else
+ If Not ScriptForge.SF_Utils._Validate(StylesList, &quot;StylesList&quot;, V_STRING) Then GoTo Finally
+ End If
+ End If
+
+Try:
+ Set oFamily = _GetStyleFamily(Family)
+ If Not IsNull(oFamily) Then
+ With oFamily
+ If Not IsArray(StylesList) Then vStylesList = Array(StylesList) Else vStylesList = StylesList
+ For Each sStyle In vStylesList
+ If .hasByName(sStyle) Then .removeByName(sStyle)
+ Next sStyle
+ End With
+ End If
+
+Finally:
+ ScriptForge.SF_Utils._ExitFunction(cstThisSub)
+ Exit Sub
+Catch:
+ GoTo Finally
+End Sub &apos; SFDocuments.SF_Document.DeleteStyles
+
+REM -----------------------------------------------------------------------------
Public Sub Echo(Optional ByVal EchoOn As Variant _
, Optional ByVal Hourglass As Variant _
)
@@ -778,7 +857,9 @@ Public Function Methods() As Variant
, &quot;CloseDocument&quot; _
, &quot;CreateMenu&quot; _
, &quot;Echo&quot; _
+ , &quot;DeleteStyles&quot; _
, &quot;ExportAsPDF&quot; _
+ , &quot;ImportStylesFromFile&quot; _
, &quot;PrintOut&quot; _
, &quot;RemoveMenu&quot; _
, &quot;RunCommand&quot; _
@@ -786,6 +867,9 @@ Public Function Methods() As Variant
, &quot;SaveAs&quot; _
, &quot;SaveCopyAs&quot; _
, &quot;SetPrinter&quot; _
+ , &quot;Styles&quot; _
+ , &quot;Toolbars&quot; _
+ , &quot;XStyle&quot; _
)
End Function &apos; SFDocuments.SF_Document.Methods
@@ -866,6 +950,7 @@ Public Function Properties() As Variant
, &quot;IsWriter&quot; _
, &quot;Keywords&quot; _
, &quot;Readonly&quot; _
+ , &quot;StyleFamilies&quot; _
, &quot;Subject&quot; _
, &quot;Title&quot; _
, &quot;XComponent&quot; _
@@ -1386,6 +1471,123 @@ Catch:
End Function &apos; SFDocuments.SF_Document.SetProperty
REM -----------------------------------------------------------------------------
+Public Function Styles(Optional ByVal Family As Variant _
+ , Optional ByVal NamePattern As variant _
+ , Optional ByVal Used As variant _
+ , Optional ByVal UserDefined As Variant _
+ , Optional ByVal ParentStyle As Variant _
+ , Optional ByVal Category As Variant _
+ ) As Variant
+&apos;&apos;&apos; Returns an array of style names matching the filters given in argument
+&apos;&apos;&apos; Args:
+&apos;&apos;&apos; Family: one of the style families present in the actual document, as a case-sensitive string
+&apos;&apos;&apos; NamePattern: a filter on the style names, as a case-sensitive string pattern
+&apos;&apos;&apos; Admitted wildcard are: the &quot;?&quot; represents any single character
+&apos;&apos;&apos; the &quot;*&quot; represents zero, one, or multiple characters
+&apos;&apos;&apos; The names include the internal and localized names.
+&apos;&apos;&apos; Used: when True, the style must be used in the document
+&apos;&apos;&apos; When absent, the argument is ignored.
+&apos;&apos;&apos; UserDefined: when True, the style must have been added by the user, either in the document or its template
+&apos;&apos;&apos; When absent, the argument is ignored.
+&apos;&apos;&apos; ParentStyle: when present, only the children of the given, localized or not, parent style name are retained
+&apos;&apos;&apos; Category: a case-insensitive string: TEXT, CHAPTER, LIST, INDEX, EXTRA, HTML
+&apos;&apos;&apos; For their respective meanings, read https://api.libreoffice.org/docs/idl/ref/namespacecom_1_1sun_1_1star_1_1style_1_1ParagraphStyleCategory.html
+&apos;&apos;&apos; The argument is ignored when the Family is not = &quot;ParagraphStyles&quot;.
+&apos;&apos;&apos; Returns:
+&apos;&apos;&apos; An array of style localized names
+&apos;&apos;&apos; An error is raised when the Family does not exist.
+&apos;&apos;&apos; The returned array may be empty.
+&apos;&apos;&apos; Example:
+&apos;&apos;&apos; Dim vStyles As Variant
+&apos;&apos;&apos; vStyles = doc.Styles(&quot;ParagraphStyles&quot;) &apos; All styles in the family
+&apos;&apos;&apos; vStyles = doc.Styles(&quot;ParagraphStyles&quot;, &quot;H*&quot;) &apos; Heading, Heading 1, ...
+&apos;&apos;&apos; vStyles = doc.Styles(&quot;ParagraphStyles&quot;, Used := False, UserDefined := True)
+&apos;&apos;&apos; &apos; All user-defined styles that are not used
+&apos;&apos;&apos; vStyles = doc.Styles(&quot;ParagraphStyles&quot;, ParentStyle := &quot;Standard&quot;)
+&apos;&apos;&apos; &apos; All styles dervived from the &quot;Default Paragraph Style&quot;
+
+Dim vStyles As Variant &apos; Return value
+Dim sStyle As String &apos; A single style name
+Dim oFamily As Object &apos; Style names container
+Dim oStyle As Object &apos; _StyleDescriptor
+Dim oParentStyle As Object &apos; _StyleDescriptor
+Dim bValid As Boolean &apos; When True, a given style passes the filter
+Dim i As Integer
+Const cstCategories = &quot;TEXT,CHAPTER,LIST,INDEX,EXTRA,HTML&quot;
+
+Const cstThisSub = &quot;SFDocuments.Document.Styles&quot;
+Const cstSubArgs = &quot;Family, [NamePattern=&quot;&quot;*&quot;&quot;], [Used=True|False], [UserDefined=True|False], ParentStyle = &quot;&quot;&quot;&quot;&quot; _
+ &amp; &quot;, [Category=&quot;&quot;&quot;&quot;|&quot;&quot;TEXT&quot;&quot;|&quot;&quot;CHAPTER&quot;&quot;|&quot;&quot;LIST&quot;&quot;|&quot;&quot;INDEX&quot;&quot;|&quot;&quot;EXTRA&quot;&quot;|&quot;&quot;HTML&quot;&quot;]&quot;
+
+ If ScriptForge.SF_Utils._ErrorHandling() Then On Local Error GoTo Catch
+ vStyles = Array()
+
+Check:
+ If IsMissing(NamePattern) Or IsEmpty(NamePattern) Then NamePattern = &quot;&quot;
+ If IsMissing(Used) Then Used = Empty
+ If IsMissing(UserDefined) Then UserDefined = Empty
+ If IsMissing(ParentStyle) Or IsEmpty(ParentStyle) Then ParentStyle = &quot;&quot;
+ If IsMissing(Category) Or IsEmpty(Category) Then Category = &quot;&quot;
+ If ScriptForge.SF_Utils._EnterFunction(cstThisSub, cstSubArgs) Then
+ If Not _IsStillAlive() Then GoTo Finally
+ If UBound(_StyleFamilies) &lt; 0 Then _StyleFamilies = _Component.getStyleFamilies().getElementNames()
+ If Not ScriptForge.SF_Utils._Validate(Family, &quot;Family&quot;, V_STRING, _StyleFamilies) Then GoTo Finally
+ If Not ScriptForge.SF_Utils._Validate(NamePattern, &quot;NamePattern&quot;, V_STRING) Then GoTo Finally
+ If Not IsEmpty(Used) Then
+ If Not ScriptForge.SF_Utils._Validate(Used, &quot;Used&quot;, ScriptForge.V_BOOLEAN) Then GoTo Finally
+ End If
+ If Not IsEmpty(UserDefined) Then
+ If Not ScriptForge.SF_Utils._Validate(UserDefined, &quot;UserDefined&quot;, ScriptForge.V_BOOLEAN) Then GoTo Finally
+ End If
+ If Not ScriptForge.SF_Utils._Validate(ParentStyle, &quot;ParentStyle&quot;, V_STRING) Then GoTo Finally
+ If Not ScriptForge.SF_Utils._Validate(Category, &quot;Category&quot;, V_STRING, Split(&quot;,&quot; &amp; cstCategories, &quot;,&quot;)) Then GoTo Finally
+ End If
+
+Try:
+ Set oFamily = _GetStyleFamily(Family)
+ If Not IsNull(oFamily) Then
+ &apos; Load it with the complete list of styles in the family
+ vStyles = oFamily.getElementNames()
+ &apos; Scan the list and retain those passing the filter
+ For i = 0 To UBound(vStyles)
+ With oStyle
+ sStyle = vStyles(i)
+ Set oStyle = _GetStyle(oFamily, sStyle)
+ If Not IsNull(oStyle) Then
+ &apos; Pattern ?
+ bValid = ( Len(NamePattern) = 0 )
+ If Not bValid Then bValid = ScriptForge.SF_String.IsLike(.DisplayName, NamePattern, CaseSensitive := True)
+ &apos; Used ?
+ If bValid And Not IsEmpty(Used) Then bValid = ( Used = .IsUsed )
+ &apos; User defined ?
+ If bValid And Not IsEmpty(UserDefined) Then bValid = ( UserDefined = Not .BuiltIn )
+ &apos; Parent style ?
+ If bValid And Len(ParentStyle) &gt; 0 Then
+ Set oParentStyle = _GetStyle(oFamily, .ParentStyle)
+ bValid = Not IsNull(oParentStyle) &apos; The child has a parent
+ If bValid Then bValid = ( ParentStyle = oParentStyle.DisplayName Or ParentStyle = oParentStyle.StyleName)
+ End If
+ &apos; Category ?
+ If bValid And Len(Category) &gt; 0 Then bValid = ( UCase(Category) = .Category )
+ If bValid Then vStyles(i) = .DisplayName Else vStyles(i) = &quot;&quot;
+ Else
+ vStyles(i) = &quot;&quot;
+ End If
+ End With
+ Next i
+ &apos; Reject when not valid
+ vStyles = ScriptForge.SF_Array.TrimArray(vStyles)
+ End If
+
+Finally:
+ Styles = vStyles
+ ScriptForge.SF_Utils._ExitFunction(cstThisSub)
+ Exit Function
+Catch:
+ GoTo Finally
+End Function &apos; SFDocuments.SF_Document.Styles
+
+REM -----------------------------------------------------------------------------
Public Function Toolbars(Optional ByVal ToolbarName As Variant) As Variant
&apos;&apos;&apos; Returns either a list of the available toolbar names in the actual document
&apos;&apos;&apos; or a Toolbar object instance.
@@ -1428,6 +1630,55 @@ Catch:
GoTo Finally
End Function &apos; SFDocuments.SF_Document.Toolbars
+REM -----------------------------------------------------------------------------
+Public Function XStyle(Optional ByVal Family As Variant _
+ , Optional ByVal StyleName As variant _
+ ) As Object
+&apos;&apos;&apos; Returns a com.sun.star.style.Style UNO object corresponding with the arguments
+&apos;&apos;&apos; Args:
+&apos;&apos;&apos; Family: one of the style families present in the actual document, as a not case-sensitive string
+&apos;&apos;&apos; StyleName: one of the styles present in the given family, as a case-sensitive string
+&apos;&apos;&apos; The StyleName may be localized or not.
+&apos;&apos;&apos; Returns:
+&apos;&apos;&apos; A com.sun.star.style.XStyle UNO object or one of its descendants,
+&apos;&apos;&apos; like com.sun.star.style.CellStyle or com.sun.star.style.ParagraphStyle etc.
+&apos;&apos;&apos; An error is raised when the Family does not exist.
+&apos;&apos;&apos; Nothing is returned when the StyleName does not exist in the given Family.
+&apos;&apos;&apos; Example:
+&apos;&apos;&apos; Dim oStyle As Object
+&apos;&apos;&apos; Set oStyle = doc.XStyle(&quot;ParagraphStyle&quot;, &quot;Heading 2&quot;)
+
+Dim oXStyle As Object &apos; Return value
+Dim oFamily As Object &apos; Style names container
+
+Const cstThisSub = &quot;SFDocuments.Document.XStyle&quot;
+Const cstSubArgs = &quot;Family, StyleName&quot;
+
+ If ScriptForge.SF_Utils._ErrorHandling() Then On Local Error GoTo Catch
+ Set oXStyle = Nothing
+
+Check:
+ If ScriptForge.SF_Utils._EnterFunction(cstThisSub, cstSubArgs) Then
+ If Not _IsStillAlive() Then GoTo Finally
+ If UBound(_StyleFamilies) &lt; 0 Then _StyleFamilies = _Component.getStyleFamilies().getElementNames()
+ If Not ScriptForge.SF_Utils._Validate(Family, &quot;Family&quot;, V_STRING, _StyleFamilies) Then GoTo Finally
+ If Not ScriptForge.SF_Utils._Validate(StyleName, &quot;StyleName&quot;, V_STRING) Then GoTo Finally
+ End If
+
+Try:
+ Set oFamily = _GetStyleFamily(Family)
+ If Not IsNull(oFamily) Then
+ If oFamily.hasByName(StyleName) Then Set oXStyle = oFamily.getByName(StyleName)
+ End If
+
+Finally:
+ Set XStyle = oXStyle
+ ScriptForge.SF_Utils._ExitFunction(cstThisSub)
+ Exit Function
+Catch:
+ GoTo Finally
+End Function &apos; SFDocuments.SF_Document.XStyle
+
REM =========================================================== PRIVATE FUNCTIONS
REM -----------------------------------------------------------------------------
@@ -1503,6 +1754,209 @@ Finally:
End Function &apos; SFDocuments.SF_Document._GetFilterNames
REM -----------------------------------------------------------------------------
+Private Function _GetStyle(ByRef poFamily As Object _
+ , Optional ByVal pvDisplayName As Variant _
+ , Optional ByVal pvStyleIndex As Variant _
+ ) As Object
+&apos;&apos;&apos; Returns the style descriptor of the style passed as argument in the given family
+&apos;&apos;&apos; Args:
+&apos;&apos;&apos; poFamily: a com.sun.star.container.XNameContainer/XStyleFamily object
+&apos;&apos;&apos; pvDisplayName: case-sensitive string, localized style name as visible in the user interface
+&apos;&apos;&apos; pvStyleIndex: index of the style in the family, as an integer
+&apos;&apos;&apos; Exactly 1 out of the last 2 arguments must be supplied
+&apos;&apos;&apos; Returns:
+&apos;&apos;&apos; A StyleDescriptor object or Nothing
+
+Dim oStyleDescriptor &apos; Return value
+Dim oStyle As Object &apos; com.sun.star.style.XStyle and variants
+Dim bFound As Boolean &apos; When True, the style has been found in the family
+Dim vCategories As Variant &apos; Array of category constants
+Dim iCategory As Integer &apos; Index of vCategories
+Dim oSession As Object : Set oSession = ScriptForge.SF_Services.CreateScriptService(&quot;Session&quot;)
+Dim i As Integer
+
+Const cstCAT0 = &quot;TEXT&quot; &apos; is applied to styles that are used for common text
+Const cstCAT1 = &quot;CHAPTER&quot; &apos; is applied to styles that are used as headings
+Const cstCAT2 = &quot;LIST&quot; &apos; is applied to styles that used in numberings and lists
+Const cstCAT3 = &quot;INDEX&quot; &apos; is applied to styles that are used in indexes
+Const cstCAT4 = &quot;EXTRA&quot; &apos; is applied to styles that are used in special regions like headers, footers, and footnote text
+Const cstCAT5 = &quot;HTML&quot; &apos; is applied to styles that are used to support HTML
+Const cstCAT = cstCAT0 &amp; &quot;,&quot; &amp; cstCAT1 &amp; &quot;,&quot; &amp; cstCAT2 &amp; &quot;,&quot; &amp; cstCAT3 &amp; &quot;,&quot; &amp; cstCAT4 &amp; &quot;,&quot; &amp; cstCAT5
+
+ On Local Error GoTo Catch
+ Set oStyleDescriptor = Nothing
+
+Check:
+ If IsNull(poFamily) Then HoTo Vatch
+ If IsMissing(pvDisplayName) Or IsEmpty(pvDisplayName) Then pvDisplayName = &quot;&quot;
+ If IsMissing(pvStyleIndex) Or IsEmpty(pvStyleIndex) Then pvStyleIndex = -1
+Try:
+ &apos; Find style corresponding with the given display name
+ With poFamily
+ If Len(pvDisplayName) &gt; 0 Then
+ bFound = .hasByName(pvDisplayName) &apos; hasByName searches both for Name and DisplayName attributes here
+ If bFound Then Set oStyle = .getByName(pvDisplayName) Else GoTo Catch
+ ElseIf pvStyleIndex &gt;= 0 And pvStyleIndex &lt; .Count Then
+ Set oStyle = .getByIndex(pvStyleIndex)
+ Else
+ GoTo Catch &apos; Should not happen
+ End If
+ End With
+
+ &apos; Setup the style descriptor
+ Set oStyleDescriptor = New StyleDescriptor
+ With oStyleDescriptor
+ Set .Family = poFamily
+ .StyleName = oStyle.Name
+ .DisplayName = oStyle.DisplayName
+ .IsUsed = oStyle.isInUse
+ .BuiltIn = Not oStyle.isUserDefined()
+ .Category = &quot;&quot;
+ If oSession.HasUnoProperty(oStyle, &quot;Category&quot;) Then
+ vCategories = Split(cstCAT, &quot;,&quot;)
+ iCategory = oStyle.Category
+ If iCategory &gt;= 0 And iCategory &lt;= UBound(vCategories) Then .Category = vCategories(iCategory)
+ End If
+ .ParentStyle = oStyle.ParentStyle
+ Set .XStyle = oStyle
+ End With
+
+Finally:
+ Set _GetStyle = oStyleDescriptor
+ Exit Function
+Catch:
+ Set oStyleDescriptor = Nothing
+ GoTo Finally
+End Function &apos; SFDocuments.SF_Document._GetStyle
+
+REM -----------------------------------------------------------------------------
+Private Function _GetStyleFamily(ByVal psFamilyName As String) As Object
+&apos;&apos;&apos; Returns the style names container corresponding with the argument
+&apos;&apos;&apos; Args:
+&apos;&apos;&apos; psFamilyName: CellStyles, CharacterStyles, FrameStyles, GraphicsStyles, ListStyles,
+&apos;&apos;&apos; NumberingStyles, PageStyles, ParagraphStyles, TableStyles
+&apos;&apos;&apos; Returns:
+&apos;&apos;&apos; A com.sun.star.container.XNameContainer/XStyleFamily object or Nothing
+
+Dim oFamily As Object &apos; Return value
+Dim oFamilies As Object &apos; com.sun.star.container.XNameAccess
+Dim iIndex As Integer &apos; Index in vFamilies of the given argument
+
+ On Local Error GoTo Catch
+ Set oFamily = Nothing
+
+Try:
+ Set oFamilies = _Component.getStyleFamilies()
+ If UBound(_StyleFamilies) &lt; 0 Then _StyleFamilies = oFamilies.getElementNames()
+ &apos; oFamilies.hasByName()/getByName() not used here to admit not case-sensitive family names
+ iIndex = ScriptForge.SF_Array.IndexOf(_StyleFamilies, psFamilyName, CaseSensitive := False)
+ If iIndex &gt;= 0 Then Set oFamily = oFamilies.getByName(_StyleFamilies(iIndex))
+
+Finally:
+ Set _GetStyleFamily = oFamily
+ Exit Function
+Catch:
+ Set oFamily = Nothing
+ GoTo Finally
+End Function &apos; SFDocuments.SF_Document._GetStyleFamily
+
+REM -----------------------------------------------------------------------------
+Public Sub _ImportStylesFromFile(Optional FileName As Variant _
+ , Optional ByRef Families As Variant _
+ , Optional ByVal Overwrite As variant _
+ ) As Variant
+&apos;&apos;&apos; Load all the styles belonging to one or more style families from a closed file
+&apos;&apos;&apos; into the actual document. The actual document must be a Calc or a Writer document.
+&apos;&apos;&apos; Are always imported together:
+&apos;&apos;&apos; ParagraphStyles and CharacterStyles
+&apos;&apos;&apos; NumberingStyles and ListStyles
+&apos;&apos;&apos; Args:
+&apos;&apos;&apos; FileName: the file from which to load the styles in the FileSystem notation.
+&apos;&apos;&apos; The file is presumed to be of the same document type as the actual document
+&apos;&apos;&apos; Families: one of the style families present in the actual document, as a case-sensitive string
+&apos;&apos;&apos; or an array of such strings. Default = all families
+&apos;&apos;&apos; Overwrite: when True, the actual styles may be overwritten. Defailt = False
+&apos;&apos;&apos; Returns:
+&apos;&apos;&apos; Exceptions:
+&apos;&apos;&apos; UNKNOWNFILEERROR The fiven file name does not exist
+&apos;&apos;&apos; Example:
+&apos;&apos;&apos; oDoc.ImportStylesFromFile(&quot;C:\...\abc.odt&quot;, Families := &quot;ParagraphStyles&quot;, Overwrite := True)
+
+Dim vFamilies As Variant &apos; Alias of Families
+Dim oFamilies As Object &apos; com.sun.star.container.XNameAccess
+Dim vOptions As Variant &apos; Array of property values
+Dim bAll As Boolean &apos; When True, ALL style families are considered
+Dim sName As String &apos; A single name in vOptions
+Dim FSO As Object : Set FSO = ScriptForge.SF_FileSystem
+Dim i As Integer
+Const cstThisSub = &quot;SFDocuments.Document.ImportStylesFromFile&quot;
+Const cstSubArgs = &quot;FileName, [Families], [Overwrite=False]&quot;
+
+ If ScriptForge.SF_Utils._ErrorHandling() Then On Local Error GoTo Catch
+
+Check:
+ If IsMissing(Families) Or IsEmpty(Families) Then Families = &quot;&quot;
+ If IsMissing(Overwrite) Or IsEmpty(Overwrite) Then Overwrite = False
+
+ Set oFamilies = _Component.getStyleFamilies()
+ If UBound(_StyleFamilies) &lt; 0 Then _StyleFamilies = oFamilies.getElementNames()
+
+ If ScriptForge.SF_Utils._EnterFunction(cstThisSub, cstSubArgs) Then
+ If Not _IsStillAlive() Then GoTo Finally
+ If Not ScriptForge.SF_Utils._ValidateFile(FileName, &quot;FileName&quot;, False) Then GoTo Finally
+ If IsArray(Families) Then
+ If Not ScriptForge.SF_Utils._ValidateArray(Families, &quot;Families&quot;, 1, V_STRING, True) Then GoTo Finally
+ Else
+ If Not ScriptForge.SF_Utils._Validate(Families, &quot;Families&quot;, V_STRING, ScriptForge.SF_Array.Append(_StyleFamilies, &quot;&quot;)) Then GoTo Finally
+ End If
+ If Not ScriptForge.SF_Utils._Validate(Overwrite, &quot;Overwrite&quot;, ScriptForge.V_BOOLEAN) Then GoTo Finally
+ End If
+
+ If Not FSO.FileExists(FileName) Then GoTo CatchNotExists
+ If IsArray(Families) Then
+ vFamilies = Families
+ Else
+ bAll = ( Len(Families) = 0 ) &apos; When Families is absent (= &quot;&quot;), all families should be considered
+ vFamilies = Array(Families)
+ End If
+
+Try:
+ With ScriptForge.SF_Utils
+ Set vOptions = _Component.getStyleFamilies().getStyleLoaderOptions
+ &apos; By default, all style families are imported (True)
+ If Not bAll Then
+ For i = 0 To UBound(vOptions)
+ vOptions(i).Value = False
+ Next i
+ For i = LBound(vFamilies) To UBound(vFamilies)
+ Select Case UCase(vFamilies(i))
+ Case &quot;PARAGRAPHSTYLES&quot;, &quot;CHARACTERSTYLES&quot; : sName = &quot;TextStyles&quot;
+ Case &quot;FRAMESTYLES&quot; : sName = &quot;FrameStyles&quot;
+ Case &quot;PAGESTYLES&quot; : sName = &quot;PageStyles&quot;
+ Case &quot;NUMBERINGSTYLES&quot;, &quot;LISTSTYLES&quot; : sName = &quot;NumberingStyles&quot;
+ Case &quot;CELLSTYLES&quot; : sName = &quot;PageStyles&quot;
+ Case Else : sName = &quot;&quot;
+ End Select
+ If Len(sName) &gt; 0 Then Set vOptions = ._SetPropertyValue(vOptions, &quot;Load&quot; &amp; sName, True)
+ Next i
+ End If
+ vOptions = ._SetPropertyValue(vOptions, &quot;OverwriteStyles&quot;, Overwrite)
+ End With
+
+ &apos; Finally, import
+ oFamilies.loadStylesFromURL(FSO._ConvertToUrl(FileName), vOptions)
+
+Finally:
+ ScriptForge.SF_Utils._ExitFunction(cstThisSub)
+ Exit Sub
+Catch:
+ GoTo Finally
+CatchNotExists:
+ SF_Exception.RaiseFatal(UNKNOWNFILEERROR, &quot;FileName&quot;, FileName)
+ GoTo Finally
+End Sub &apos; SFDocuments.SF_Document._ImportStylesFromFile
+
+REM -----------------------------------------------------------------------------
Private Function _IsStillAlive(Optional ByVal pbForUpdate As Boolean _
, Optional ByVal pbError As Boolean _
) As Boolean
@@ -1640,6 +2094,9 @@ Const cstSubArgs = &quot;&quot;
_PropertyGet = Join(_Component.DocumentProperties.Keywords, &quot;, &quot;)
Case &quot;Readonly&quot;
_PropertyGet = _Component.isReadonly()
+ Case &quot;StyleFamilies&quot;
+ If UBound(_StyleFamilies) &lt; 0 Then _StyleFamilies = _Component.getStyleFamilies().getElementNames()
+ _PropertyGet = _StyleFamilies
Case &quot;Subject&quot;
_PropertyGet = _Component.DocumentProperties.Subject
Case &quot;Title&quot;
diff --git a/wizards/source/sfdocuments/SF_FormDocument.xba b/wizards/source/sfdocuments/SF_FormDocument.xba
index 9411d234caaf..42f853f174f4 100644
--- a/wizards/source/sfdocuments/SF_FormDocument.xba
+++ b/wizards/source/sfdocuments/SF_FormDocument.xba
@@ -335,6 +335,7 @@ Public Function Methods() As Variant
Methods = Array( _
&quot;CloseDocument&quot; _
, &quot;Forms&quot; _
+ , &quot;GetDatabase&quot; _
, &quot;PrintOut&quot; _
)
@@ -429,6 +430,7 @@ Public Function Properties() As Variant
, &quot;IsImpress&quot; _
, &quot;IsMath&quot; _
, &quot;Readonly&quot; _
+ , &quot;StyleFamilies&quot; _
, &quot;XComponent&quot; _
, &quot;XDocumentSettings&quot; _
)
@@ -478,6 +480,11 @@ Property Get Readonly() As Variant
End Property &apos; SFDocuments.SF_FormDocument.Readonly
REM -----------------------------------------------------------------------------
+Property Get StyleFamilies() As Variant
+ StyleFamilies = [_Super].GetProperty(&quot;StyleFamilies&quot;)
+End Property &apos; SFDocuments.SF_FormDocument.StyleFamilies
+
+REM -----------------------------------------------------------------------------
Property Get XComponent() As Variant
XComponent = [_Super].GetProperty(&quot;XComponent&quot;)
End Property &apos; SFDocuments.SF_FormDocument.XComponent
@@ -550,10 +557,28 @@ Public Function SetPrinter(Optional ByVal Printer As Variant _
End Function &apos; SFDocuments.SF_FormDocument.SetPrinter
REM -----------------------------------------------------------------------------
+Public Function Styles(Optional ByVal Family As Variant _
+ , Optional ByVal NamePattern As variant _
+ , Optional ByVal Used As variant _
+ , Optional ByVal UserDefined As Variant _
+ , Optional ByVal ParentStyle As Variant _
+ , Optional ByVal Category As Variant _
+ ) As Variant
+ Styles = [_Super].Styles(Family, NamePattern, Used, UserDefined, ParentStyle, Category)
+End Function &apos; SFDocuments.SF_FormDocument.Styles
+
+REM -----------------------------------------------------------------------------
Public Function Toolbars(Optional ByVal ToolbarName As Variant) As Variant
Toolbars = [_Super].Toolbars(ToolbarName)
End Function &apos; SFDocuments.SF_FormDocument.Toolbars
+REM -----------------------------------------------------------------------------
+Public Function XStyle(Optional ByVal Family As Variant _
+ , Optional ByVal StyleName As variant _
+ ) As Object
+ Set XStyle = [_Super].XStyle(Family, StyleName)
+End Function &apos; SFDocuments.SF_FormDocument.XStyle
+
REM =========================================================== PRIVATE FUNCTIONS
REM -----------------------------------------------------------------------------
diff --git a/wizards/source/sfdocuments/SF_Writer.xba b/wizards/source/sfdocuments/SF_Writer.xba
index 6a54ca2e3d10..ebdff7f78386 100644
--- a/wizards/source/sfdocuments/SF_Writer.xba
+++ b/wizards/source/sfdocuments/SF_Writer.xba
@@ -321,6 +321,7 @@ Public Function Properties() As Variant
, &quot;IsWriter&quot; _
, &quot;Keywords&quot; _
, &quot;Readonly&quot; _
+ , &quot;StyleFamilies&quot; _
, &quot;Subject&quot; _
, &quot;Title&quot; _
, &quot;XComponent&quot; _
@@ -475,6 +476,11 @@ Property Get Readonly() As Variant
End Property &apos; SFDocuments.SF_Writer.Readonly
REM -----------------------------------------------------------------------------
+Property Get StyleFamilies() As Variant
+ StyleFamilies = [_Super].GetProperty(&quot;StyleFamilies&quot;)
+End Property &apos; SFDocuments.SF_Writer.StyleFamilies
+
+REM -----------------------------------------------------------------------------
Property Get Subject() As Variant
Subject = [_Super].GetProperty(&quot;Subject&quot;)
End Property &apos; SFDocuments.SF_Writer.Subject
@@ -525,6 +531,13 @@ Public Function CreateMenu(Optional ByVal MenuHeader As Variant _
End Function &apos; SFDocuments.SF_Writer.CreateMenu
REM -----------------------------------------------------------------------------
+Public Sub DeleteStyles(Optional ByVal Family As Variant _
+ , Optional ByRef StylesList As Variant _
+ )
+ [_Super].DeleteStyles(Family, StylesList)
+End Sub &apos; SFDocuments.SF_Writer.DeleteStyles
+
+REM -----------------------------------------------------------------------------
Public Sub Echo(Optional ByVal EchoOn As Variant _
, Optional ByVal Hourglass As Variant _
)
@@ -542,6 +555,14 @@ Public Function ExportAsPDF(Optional ByVal FileName As Variant _
End Function &apos; SFDocuments.SF_Writer.ExportAsPDF
REM -----------------------------------------------------------------------------
+Public Sub ImportStylesFromFile(Optional FileName As Variant _
+ , Optional ByRef Families As Variant _
+ , Optional ByVal Overwrite As variant _
+ ) As Variant
+ [_Super]._ImportStylesFromFile(FileName, Families, Overwrite)
+End Sub &apos; SFDocuments.SF_Writer.ImportStylesFromFile
+
+REM -----------------------------------------------------------------------------
Public Function RemoveMenu(Optional ByVal MenuHeader As Variant) As Boolean
RemoveMenu = [_Super].RemoveMenu(MenuHeader)
End Function &apos; SFDocuments.SF_Writer.RemoveMenu
@@ -587,10 +608,28 @@ Public Function SetPrinter(Optional ByVal Printer As Variant _
End Function &apos; SFDocuments.SF_Writer.SetPrinter
REM -----------------------------------------------------------------------------
+Public Function Styles(Optional ByVal Family As Variant _
+ , Optional ByVal NamePattern As variant _
+ , Optional ByVal Used As variant _
+ , Optional ByVal UserDefined As Variant _
+ , Optional ByVal ParentStyle As Variant _
+ , Optional ByVal Category As Variant _
+ ) As Variant
+ Styles = [_Super].Styles(Family, NamePattern, Used, UserDefined, ParentStyle, Category)
+End Function &apos; SFDocuments.SF_Writer.Styles
+
+REM -----------------------------------------------------------------------------
Public Function Toolbars(Optional ByVal ToolbarName As Variant) As Variant
Toolbars = [_Super].Toolbars(ToolbarName)
End Function &apos; SFDocuments.SF_Writer.Toolbars
+REM -----------------------------------------------------------------------------
+Public Function XStyle(Optional ByVal Family As Variant _
+ , Optional ByVal StyleName As variant _
+ ) As Object
+ Set XStyle = [_Super].XStyle(Family, StyleName)
+End Function &apos; SFDocuments.SF_Writer.XStyle
+
REM =========================================================== PRIVATE FUNCTIONS
REM -----------------------------------------------------------------------------