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="sc_ScTableSheetObj" script:language="StarBasic">
4cdf0e10cSrcweir
5cdf0e10cSrcweir
6cdf0e10cSrcweir'*************************************************************************
7cdf0e10cSrcweir'
8*5846f787SAndrew Rist'  Licensed to the Apache Software Foundation (ASF) under one
9*5846f787SAndrew Rist'  or more contributor license agreements.  See the NOTICE file
10*5846f787SAndrew Rist'  distributed with this work for additional information
11*5846f787SAndrew Rist'  regarding copyright ownership.  The ASF licenses this file
12*5846f787SAndrew Rist'  to you under the Apache License, Version 2.0 (the
13*5846f787SAndrew Rist'  "License"); you may not use this file except in compliance
14*5846f787SAndrew Rist'  with the License.  You may obtain a copy of the License at
15*5846f787SAndrew Rist'
16*5846f787SAndrew Rist'    http://www.apache.org/licenses/LICENSE-2.0
17*5846f787SAndrew Rist'
18*5846f787SAndrew Rist'  Unless required by applicable law or agreed to in writing,
19*5846f787SAndrew Rist'  software distributed under the License is distributed on an
20*5846f787SAndrew Rist'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21*5846f787SAndrew Rist'  KIND, either express or implied.  See the License for the
22*5846f787SAndrew Rist'  specific language governing permissions and limitations
23*5846f787SAndrew Rist'  under the License.
24cdf0e10cSrcweir'
25cdf0e10cSrcweir'*************************************************************************
26cdf0e10cSrcweir
27cdf0e10cSrcweir
28cdf0e10cSrcweir
29*5846f787SAndrew Rist
30*5846f787SAndrew Rist
31cdf0e10cSrcweir' Be sure that all variables are dimensioned:
32cdf0e10cSrcweiroption explicit
33cdf0e10cSrcweir
34cdf0e10cSrcweir
35cdf0e10cSrcweir' REQUIRED VARIABLES for interface/service tests:
36cdf0e10cSrcweir
37cdf0e10cSrcweir' Required for com.sun.star.sheet.Spreadsheet
38cdf0e10cSrcweirGlobal sStyleName As String
39cdf0e10cSrcweir
40cdf0e10cSrcweir' Required for com.sun.star.chart.XChartData
41cdf0e10cSrcweirGlobal oCellToChange As Object
42cdf0e10cSrcweir
43cdf0e10cSrcweir
44cdf0e10cSrcweirSub CreateObj()
45cdf0e10cSrcweir
46cdf0e10cSrcweir'*************************************************************************
47cdf0e10cSrcweir' COMPONENT:
48cdf0e10cSrcweir' sc.ScTableSheetObj
49cdf0e10cSrcweir'*************************************************************************
50cdf0e10cSrcweirOn Error Goto ErrHndl
51cdf0e10cSrcweir    Dim oStyleFamilies As Variant
52cdf0e10cSrcweir    Dim oNewPageStyle As Object
53cdf0e10cSrcweir    Dim oStyleFamily As Object
54cdf0e10cSrcweir
55cdf0e10cSrcweir    oDoc = utils.createDocument("scalc", cObjectName)
56cdf0e10cSrcweir    oObj = oDoc.sheets(0)
57cdf0e10cSrcweir
58cdf0e10cSrcweir    sStyleName = "MyStyle"
59cdf0e10cSrcweir    ' Adding new page style for Spreadsheet service testing
60cdf0e10cSrcweir    oStyleFamilies = oDoc.StyleFamilies
61cdf0e10cSrcweir    oStyleFamily = oStyleFamilies.getByName("PageStyles")
62cdf0e10cSrcweir    oNewPageStyle = oDoc.createInstance("com.sun.star.style.PageStyle")
63cdf0e10cSrcweir    oStyleFamily.insertByName(sStyleName, oNewPageStyle)
64cdf0e10cSrcweir
65cdf0e10cSrcweir    oCellToChange = oObj.getCellByPosition(2, 2)
66cdf0e10cSrcweir
67cdf0e10cSrcweirExit Sub
68cdf0e10cSrcweirErrHndl:
69cdf0e10cSrcweir    Test.Exception()
70cdf0e10cSrcweirEnd Sub
71cdf0e10cSrcweirFunction modifyDescriptor(descr As Variant) As Variant
72cdf0e10cSrcweirOn Error Goto ErrHndl
73cdf0e10cSrcweir    Dim i As Integer, n as Integer
74cdf0e10cSrcweir    Dim oCell As Object
75cdf0e10cSrcweir    Dim vFields(0) as new com.sun.star.table.TableSortField
76cdf0e10cSrcweir
77cdf0e10cSrcweir    for i = 0 to 10 - 1
78cdf0e10cSrcweir        oCell = oObj.getCellByPosition(0, i)
79cdf0e10cSrcweir        oCell.String = "" + (10 - i)
80cdf0e10cSrcweir        oCell.setFormula(10 - i)
81cdf0e10cSrcweir    next i
82cdf0e10cSrcweir    'ShowNameValuePair(descr)
83cdf0e10cSrcweir    vFields(0).IsCaseSensitive = false
84cdf0e10cSrcweir    vFields(0).IsAscending = true
85cdf0e10cSrcweir    vFields(0).FieldType = com.sun.star.table.TableSortFieldType.ALPHANUMERIC
86cdf0e10cSrcweir    for i = 0 to ubound(descr)
87cdf0e10cSrcweir        if descr(i).Name = "IsSortColumns" then descr(i).Value = false
88cdf0e10cSrcweir        if descr(i).Name = "SortFields" then descr(i).Value = vFields()
89cdf0e10cSrcweir    next i
90cdf0e10cSrcweir
91cdf0e10cSrcweir    modifyDescriptor() = descr
92cdf0e10cSrcweirExit Function
93cdf0e10cSrcweirErrHndl:
94cdf0e10cSrcweir    Out.Log("Exception in ScTableSheetObj.modifyDescriptor() :")
95cdf0e10cSrcweir    Test.Exception()
96cdf0e10cSrcweirend Function
97cdf0e10cSrcweir
98cdf0e10cSrcweirFunction checkSort() As Boolean
99cdf0e10cSrcweirOn Error Goto ErrHndl
100cdf0e10cSrcweir    Dim i As Integer, oCell As Object
101cdf0e10cSrcweir    Dim bOK As Boolean
102cdf0e10cSrcweir
103cdf0e10cSrcweir    bOK = true
104cdf0e10cSrcweir    for i = 0 to 10 - 1
105cdf0e10cSrcweir        oCell = oObj.getCellByPosition(0,i)
106cdf0e10cSrcweir        bOK = bOK AND oCell.String = "" + (i + 1)
107cdf0e10cSrcweir        out.dbg(oCell.String + ":" + (i+1))
108cdf0e10cSrcweir    next i
109cdf0e10cSrcweir
110cdf0e10cSrcweir    checkSort() = bOK
111cdf0e10cSrcweirExit Function
112cdf0e10cSrcweirErrHndl:
113cdf0e10cSrcweir    Out.Log("Exception in ScTableSheetObj.checkSort() :")
114cdf0e10cSrcweir    Test.Exception()
115cdf0e10cSrcweirend Function
116cdf0e10cSrcweir
117cdf0e10cSrcweir
118cdf0e10cSrcweir</script:module>
119