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'  Licensed to the Apache Software Foundation (ASF) under one
9'  or more contributor license agreements.  See the NOTICE file
10'  distributed with this work for additional information
11'  regarding copyright ownership.  The ASF licenses this file
12'  to you under the Apache License, Version 2.0 (the
13'  "License"); you may not use this file except in compliance
14'  with the License.  You may obtain a copy of the License at
15'
16'    http://www.apache.org/licenses/LICENSE-2.0
17'
18'  Unless required by applicable law or agreed to in writing,
19'  software distributed under the License is distributed on an
20'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21'  KIND, either express or implied.  See the License for the
22'  specific language governing permissions and limitations
23'  under the License.
24'
25'*************************************************************************
26
27
28
29
30
31' Be sure that all variables are dimensioned:
32option explicit
33
34
35' REQUIRED VARIABLES for interface/service tests:
36
37'Required for com.sun.star.document.XFilter
38Global oFilterDescriptor As Variant
39
40'Required for com.sun.star.lang.XInitialization
41Global aInitArgs() As Variant
42
43'Required for com.sun.star.document.XExporter
44Global oSrcDocument As Object
45
46
47Sub CreateObj()
48
49'*************************************************************************
50' COMPONENT:
51' xmloff.Impress.XMLStylesExporter
52'*************************************************************************
53On error goto ErrHndl
54    Dim initArgs(0), oMSF, oStyleFamilies, oFamily, oStyle As Object
55    Dim oSFNames As Variant
56    Dim oFamilyName As String
57    Dim printXML As Boolean
58    Dim filter As Variant
59    Dim expString As String
60    Dim Tag1, Tag2, Tag3 As Variant
61
62    printXML = true
63    expString = "NewStyle"
64    oMSF = getProcessServiceManager()
65    oDoc = utils.createImpressDocument(cObjectName)
66    oDocHandler = oMSF.createInstanceWithArguments("basichelper.DocumentHandler", Array(printXML))
67
68    Tag1 = Array("office:document-styles")
69    Tag2 = Array("office:styles")
70    Tag3 = Array("style:style", "style:name", expString)
71    filter = Array( _
72                Array("TagEnclosed", Tag2, Tag1), _
73                Array("TagEnclosed", Tag3, Tag2) _
74             )
75
76    oDocHandler.initialize(filter)
77
78    initArgs(0) = oDocHandler
79    aInitArgs = initArgs()
80    oObj = oMSF.createInstanceWithArguments("com.sun.star.comp.Impress.XMLStylesExporter", initArgs())
81
82    oStyleFamilies = oDoc.getStyleFamilies()
83    oSFNames = oStyleFamilies.getElementNames()
84    oFamilyName = oSFNames(0)
85    oFamily = oStyleFamilies.getByName(oFamilyName)
86    oStyle = oDoc.createInstance("com.sun.star.style.Style")
87    oFamily.insertByName(expString, oStyle)
88
89    oObj.setSourceDocument(oDoc)
90
91    Dim aFilterDescr(0) As New com.sun.star.beans.PropertyValue
92    aFilterDescr(0).Name = "FilterName"
93    aFilterDescr(0).Value = "simpress: StarOffice XML (Impress)"
94    oFilterDescriptor = aFilterDescr()
95
96    oSrcDocument = oDoc
97Exit Sub
98ErrHndl:
99    Test.Exception()
100End Sub
101
102Global oDocHandler As Object
103
104Function checkFilter() As Boolean
105    checkFilter = oDocHandler.getByName("XMLIsCorrect")
106    Out.Log(oDocHandler.getByName("XMLCode"))
107End Function
108</script:module>
109