1cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="view_XPrintable" script:language="StarBasic">
4cdf0e10cSrcweir
5cdf0e10cSrcweir
6cdf0e10cSrcweir'*************************************************************************
7cdf0e10cSrcweir'
8*3709053cSAndrew Rist'  Licensed to the Apache Software Foundation (ASF) under one
9*3709053cSAndrew Rist'  or more contributor license agreements.  See the NOTICE file
10*3709053cSAndrew Rist'  distributed with this work for additional information
11*3709053cSAndrew Rist'  regarding copyright ownership.  The ASF licenses this file
12*3709053cSAndrew Rist'  to you under the Apache License, Version 2.0 (the
13*3709053cSAndrew Rist'  "License"); you may not use this file except in compliance
14*3709053cSAndrew Rist'  with the License.  You may obtain a copy of the License at
15*3709053cSAndrew Rist'
16*3709053cSAndrew Rist'    http://www.apache.org/licenses/LICENSE-2.0
17*3709053cSAndrew Rist'
18*3709053cSAndrew Rist'  Unless required by applicable law or agreed to in writing,
19*3709053cSAndrew Rist'  software distributed under the License is distributed on an
20*3709053cSAndrew Rist'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21*3709053cSAndrew Rist'  KIND, either express or implied.  See the License for the
22*3709053cSAndrew Rist'  specific language governing permissions and limitations
23*3709053cSAndrew Rist'  under the License.
24cdf0e10cSrcweir'
25cdf0e10cSrcweir'*************************************************************************
26cdf0e10cSrcweir
27cdf0e10cSrcweir
28cdf0e10cSrcweir
29*3709053cSAndrew Rist
30*3709053cSAndrew Rist
31cdf0e10cSrcweir' Be sure that all variables are dimensioned:
32cdf0e10cSrcweiroption explicit
33cdf0e10cSrcweir
34cdf0e10cSrcweir
35cdf0e10cSrcweir
36cdf0e10cSrcweirSub RunTest()
37cdf0e10cSrcweir
38cdf0e10cSrcweir'*************************************************************************
39cdf0e10cSrcweir' INTERFACE:
40cdf0e10cSrcweir' com.sun.star.view.XPrintable
41cdf0e10cSrcweir'*************************************************************************
42cdf0e10cSrcweirOn Error Goto ErrHndl
43cdf0e10cSrcweir    Dim bOK As Boolean
44cdf0e10cSrcweir    Dim sFileName, sFileUrl As String
45cdf0e10cSrcweir    Dim aPrintingOptions(1) As New com.sun.star.beans.PropertyValue
46cdf0e10cSrcweir    Dim aPrinterProps As Variant
47cdf0e10cSrcweir    Dim i As Integer
48cdf0e10cSrcweir
49cdf0e10cSrcweir    Test.StartMethod("getPrinter()")
50cdf0e10cSrcweir    bOK = true
51cdf0e10cSrcweir    aPrinterProps = oObj.getPrinter()
52cdf0e10cSrcweir    bOK = bOK AND (ubound(aPrinterProps) &gt; 0)
53cdf0e10cSrcweir    Test.MethodTested("getPrinter()", bOK)
54cdf0e10cSrcweir
55cdf0e10cSrcweir
56cdf0e10cSrcweir    Test.StartMethod("print()")
57cdf0e10cSrcweir    bOK = true
58cdf0e10cSrcweir
59cdf0e10cSrcweir    sFileUrl = utils.getTempFileURL("/XPrintable.prt", true)
60cdf0e10cSrcweir    sFileName = utils.URL2Path(sFileUrl)
61cdf0e10cSrcweir
62cdf0e10cSrcweir    aPrintingOptions(0).Name = "FileName"
63cdf0e10cSrcweir    aPrintingOptions(0).Value = sFileName
64cdf0e10cSrcweir    aPrintingOptions(0).State = com.sun.star.beans.PropertyState.DEFAULT_VALUE
65cdf0e10cSrcweir
66cdf0e10cSrcweir    aPrintingOptions(1).Name = "Wait"
67cdf0e10cSrcweir    aPrintingOptions(1).Value = true
68cdf0e10cSrcweir    oObj.Print(aPrintingOptions())
69cdf0e10cSrcweir
70cdf0e10cSrcweir    ' without waiting Office can hang on setPrinter() call.
71cdf0e10cSrcweir    wait(500)
72cdf0e10cSrcweir
73cdf0e10cSrcweir    bOK = bOK AND FileExists(sFileName)
74cdf0e10cSrcweir    Test.MethodTested("print()", bOK)
75cdf0e10cSrcweir
76cdf0e10cSrcweir    Test.StartMethod("setPrinter()")
77cdf0e10cSrcweir    bOK = true
78cdf0e10cSrcweir    Dim iPaperFormat As Integer
79cdf0e10cSrcweir    Dim iNewPaperFormat As Integer
80cdf0e10cSrcweir
81cdf0e10cSrcweir    for i = 0 to ubound(aPrinterProps())
82cdf0e10cSrcweir        if (aPrinterProps(i).Name = "PaperFormat") then
83cdf0e10cSrcweir            iPaperFormat = aPrinterProps(i).Value
84cdf0e10cSrcweir            exit for
85cdf0e10cSrcweir        endif
86cdf0e10cSrcweir    next i
87cdf0e10cSrcweir
88cdf0e10cSrcweir    if (iPaperFormat = com.sun.star.view.PaperFormat.A4) then
89cdf0e10cSrcweir        iNewPaperFormat = com.sun.star.view.PaperFormat.LETTER
90cdf0e10cSrcweir    else
91cdf0e10cSrcweir        iNewPaperFormat = com.sun.star.view.PaperFormat.A4
92cdf0e10cSrcweir    endif
93cdf0e10cSrcweir
94cdf0e10cSrcweir    aPrinterProps(i).Value = iNewPaperFormat
95cdf0e10cSrcweir
96cdf0e10cSrcweir    oObj.setPrinter(aPrinterProps())
97cdf0e10cSrcweir
98cdf0e10cSrcweir    aPrinterProps() = oObj.getPrinter()
99cdf0e10cSrcweir
100cdf0e10cSrcweir    for i = 0 to ubound(aPrinterProps())
101cdf0e10cSrcweir        if (aPrinterProps(i).Name = "PaperFormat") then
102cdf0e10cSrcweir            bOK = bOK AND (aPrinterProps(i).Value = iNewPaperFormat)
103cdf0e10cSrcweir            exit for
104cdf0e10cSrcweir        endif
105cdf0e10cSrcweir    next i
106cdf0e10cSrcweir    Test.MethodTested("setPrinter()", bOK)
107cdf0e10cSrcweir
108cdf0e10cSrcweirExit Sub
109cdf0e10cSrcweirErrHndl:
110cdf0e10cSrcweir    Test.Exception()
111cdf0e10cSrcweir    bOK = false
112cdf0e10cSrcweir    resume next
113cdf0e10cSrcweirEnd Sub
114cdf0e10cSrcweir</script:module>
115