1<?xml version="1.0" encoding="UTF-8"?>
2<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3<script:module xmlns:script="http://openoffice.org/2000/script" script:name="xmloff_Impress_XMLStylesExporter" script:language="StarBasic">
4
5
6'*************************************************************************
7'
8' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9'
10' Copyright 2000, 2010 Oracle and/or its affiliates.
11'
12' OpenOffice.org - a multi-platform office productivity suite
13'
14' This file is part of OpenOffice.org.
15'
16' OpenOffice.org is free software: you can redistribute it and/or modify
17' it under the terms of the GNU Lesser General Public License version 3
18' only, as published by the Free Software Foundation.
19'
20' OpenOffice.org is distributed in the hope that it will be useful,
21' but WITHOUT ANY WARRANTY; without even the implied warranty of
22' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23' GNU Lesser General Public License version 3 for more details
24' (a copy is included in the LICENSE file that accompanied this code).
25'
26' You should have received a copy of the GNU Lesser General Public License
27' version 3 along with OpenOffice.org.  If not, see
28' <http://www.openoffice.org/license.html>
29' for a copy of the LGPLv3 License.
30'
31'*************************************************************************
32'*************************************************************************
33
34
35
36' Be sure that all variables are dimensioned:
37option explicit
38
39
40' REQUIRED VARIABLES for interface/service tests:
41
42'Required for com.sun.star.document.XFilter
43Global oFilterDescriptor As Variant
44
45'Required for com.sun.star.lang.XInitialization
46Global aInitArgs() As Variant
47
48'Required for com.sun.star.document.XExporter
49Global oSrcDocument As Object
50
51
52Sub CreateObj()
53
54'*************************************************************************
55' COMPONENT:
56' xmloff.Impress.XMLStylesExporter
57'*************************************************************************
58On error goto ErrHndl
59    Dim initArgs(0), oMSF, oStyleFamilies, oFamily, oStyle As Object
60    Dim oSFNames As Variant
61    Dim oFamilyName As String
62    Dim printXML As Boolean
63    Dim filter As Variant
64    Dim expString As String
65    Dim Tag1, Tag2, Tag3 As Variant
66
67    printXML = true
68    expString = "NewStyle"
69    oMSF = getProcessServiceManager()
70    oDoc = utils.createImpressDocument(cObjectName)
71    oDocHandler = oMSF.createInstanceWithArguments("basichelper.DocumentHandler", Array(printXML))
72
73    Tag1 = Array("office:document-styles")
74    Tag2 = Array("office:styles")
75    Tag3 = Array("style:style", "style:name", expString)
76    filter = Array( _
77                Array("TagEnclosed", Tag2, Tag1), _
78                Array("TagEnclosed", Tag3, Tag2) _
79             )
80
81    oDocHandler.initialize(filter)
82
83    initArgs(0) = oDocHandler
84    aInitArgs = initArgs()
85    oObj = oMSF.createInstanceWithArguments("com.sun.star.comp.Impress.XMLStylesExporter", initArgs())
86
87    oStyleFamilies = oDoc.getStyleFamilies()
88    oSFNames = oStyleFamilies.getElementNames()
89    oFamilyName = oSFNames(0)
90    oFamily = oStyleFamilies.getByName(oFamilyName)
91    oStyle = oDoc.createInstance("com.sun.star.style.Style")
92    oFamily.insertByName(expString, oStyle)
93
94    oObj.setSourceDocument(oDoc)
95
96    Dim aFilterDescr(0) As New com.sun.star.beans.PropertyValue
97    aFilterDescr(0).Name = "FilterName"
98    aFilterDescr(0).Value = "simpress: StarOffice XML (Impress)"
99    oFilterDescriptor = aFilterDescr()
100
101    oSrcDocument = oDoc
102Exit Sub
103ErrHndl:
104    Test.Exception()
105End Sub
106
107Global oDocHandler As Object
108
109Function checkFilter() As Boolean
110    checkFilter = oDocHandler.getByName("XMLIsCorrect")
111    Out.Log(oDocHandler.getByName("XMLCode"))
112End Function
113</script:module>
114