1*cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2*cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3*cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="forms_OListBoxModel" script:language="StarBasic">
4*cdf0e10cSrcweir
5*cdf0e10cSrcweir
6*cdf0e10cSrcweir'*************************************************************************
7*cdf0e10cSrcweir'
8*cdf0e10cSrcweir' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9*cdf0e10cSrcweir'
10*cdf0e10cSrcweir' Copyright 2000, 2010 Oracle and/or its affiliates.
11*cdf0e10cSrcweir'
12*cdf0e10cSrcweir' OpenOffice.org - a multi-platform office productivity suite
13*cdf0e10cSrcweir'
14*cdf0e10cSrcweir' This file is part of OpenOffice.org.
15*cdf0e10cSrcweir'
16*cdf0e10cSrcweir' OpenOffice.org is free software: you can redistribute it and/or modify
17*cdf0e10cSrcweir' it under the terms of the GNU Lesser General Public License version 3
18*cdf0e10cSrcweir' only, as published by the Free Software Foundation.
19*cdf0e10cSrcweir'
20*cdf0e10cSrcweir' OpenOffice.org is distributed in the hope that it will be useful,
21*cdf0e10cSrcweir' but WITHOUT ANY WARRANTY; without even the implied warranty of
22*cdf0e10cSrcweir' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23*cdf0e10cSrcweir' GNU Lesser General Public License version 3 for more details
24*cdf0e10cSrcweir' (a copy is included in the LICENSE file that accompanied this code).
25*cdf0e10cSrcweir'
26*cdf0e10cSrcweir' You should have received a copy of the GNU Lesser General Public License
27*cdf0e10cSrcweir' version 3 along with OpenOffice.org.  If not, see
28*cdf0e10cSrcweir' <http://www.openoffice.org/license.html>
29*cdf0e10cSrcweir' for a copy of the LGPLv3 License.
30*cdf0e10cSrcweir'
31*cdf0e10cSrcweir'*************************************************************************
32*cdf0e10cSrcweir'*************************************************************************
33*cdf0e10cSrcweir
34*cdf0e10cSrcweir
35*cdf0e10cSrcweir
36*cdf0e10cSrcweir' Be sure that all variables are dimensioned:
37*cdf0e10cSrcweiroption explicit
38*cdf0e10cSrcweir
39*cdf0e10cSrcweir
40*cdf0e10cSrcweir' REQUIRED VARIABLES for interface/service tests:
41*cdf0e10cSrcweir
42*cdf0e10cSrcweir' for XComponent
43*cdf0e10cSrcweirGlobal oComponentInstance As Object
44*cdf0e10cSrcweir
45*cdf0e10cSrcweir' for XPersistObject
46*cdf0e10cSrcweirGlobal oPersistInstance As Object
47*cdf0e10cSrcweir
48*cdf0e10cSrcweir' for XUpdateBroadcaster
49*cdf0e10cSrcweirGlobal bCustomUpdate As Boolean
50*cdf0e10cSrcweir
51*cdf0e10cSrcweirGlobal oForm As Object
52*cdf0e10cSrcweirGlobal aList(1) As Variant
53*cdf0e10cSrcweir
54*cdf0e10cSrcweir
55*cdf0e10cSrcweirSub CreateObj()
56*cdf0e10cSrcweir
57*cdf0e10cSrcweir'*************************************************************************
58*cdf0e10cSrcweir' COMPONENT:
59*cdf0e10cSrcweir' forms.OListBoxModel
60*cdf0e10cSrcweir'*************************************************************************
61*cdf0e10cSrcweirOn Error Goto ErrHndl
62*cdf0e10cSrcweir    Dim bOK As Boolean
63*cdf0e10cSrcweir    Dim aSelection(0 to 0) As Variant
64*cdf0e10cSrcweir    Dim oShape As Object, oDrawPage As Object
65*cdf0e10cSrcweir
66*cdf0e10cSrcweir    bOK = true
67*cdf0e10cSrcweir
68*cdf0e10cSrcweir    oDoc = utils.createDocument("swriter", cObjectName)
69*cdf0e10cSrcweir
70*cdf0e10cSrcweir    oShape = toolkittools.addControlToDefaultForm("ListBox", 1000, 1000, 2000, 1000)
71*cdf0e10cSrcweir    oObj = oShape.getControl()
72*cdf0e10cSrcweir    oShape = toolkittools.addControlToDefaultForm("ListBox", 1000, 3000, 2000, 1000)
73*cdf0e10cSrcweir    oComponentInstance = oShape.getControl()
74*cdf0e10cSrcweir    oShape = toolkittools.addControlToDefaultForm("ListBox", 1000, 5000, 2000, 1000)
75*cdf0e10cSrcweir    oPersistInstance = oShape.getControl()
76*cdf0e10cSrcweir
77*cdf0e10cSrcweir    'for UnoControlListBoxModel::SelectedItems
78*cdf0e10cSrcweir    aList(0) = "Hello"
79*cdf0e10cSrcweir    aList(1) = "World"
80*cdf0e10cSrcweir    aSelection(0) = 1
81*cdf0e10cSrcweir    oObj.DefaultSelection = aSelection()
82*cdf0e10cSrcweir    oObj.ListSource = aList()
83*cdf0e10cSrcweir
84*cdf0e10cSrcweir    'get control from document
85*cdf0e10cSrcweir    oDrawPage = oDoc.DrawPage
86*cdf0e10cSrcweir    oForm = oDrawPage.Forms.getByName("Standard")
87*cdf0e10cSrcweir
88*cdf0e10cSrcweir	oForm.DataSourceName = "Bibliography"
89*cdf0e10cSrcweir	oForm.Command = "biblio"
90*cdf0e10cSrcweir	oForm.CommandType = com.sun.star.sdb.CommandType.TABLE
91*cdf0e10cSrcweir
92*cdf0e10cSrcweir    oObj.DataField = "Author"
93*cdf0e10cSrcweir
94*cdf0e10cSrcweir    oForm.load()
95*cdf0e10cSrcweir
96*cdf0e10cSrcweir    ' for XUpdateBroadcaster
97*cdf0e10cSrcweir    bCustomUpdate = true
98*cdf0e10cSrcweir
99*cdf0e10cSrcweirExit Sub
100*cdf0e10cSrcweirErrHndl:
101*cdf0e10cSrcweir    Test.Exception()
102*cdf0e10cSrcweirEnd Sub
103*cdf0e10cSrcweir
104*cdf0e10cSrcweirGlobal sChangedText As String
105*cdf0e10cSrcweir
106*cdf0e10cSrcweir' for XBoundComponent
107*cdf0e10cSrcweirSub prepareCommit()
108*cdf0e10cSrcweirOn Error Goto ErrHndl
109*cdf0e10cSrcweir    Dim items As Variant
110*cdf0e10cSrcweir    Dim item As Variant
111*cdf0e10cSrcweir
112*cdf0e10cSrcweir    Out.Log("prepareCommit() called.")
113*cdf0e10cSrcweir    items = oObj.SelectedItems
114*cdf0e10cSrcweir    if ubound(items()) &lt; 0 then
115*cdf0e10cSrcweir        item = 0
116*cdf0e10cSrcweir    else
117*cdf0e10cSrcweir        if items(0) = 0 then item = 1 else item = 0
118*cdf0e10cSrcweir    endif
119*cdf0e10cSrcweir
120*cdf0e10cSrcweir    sChangedText = aList(item)
121*cdf0e10cSrcweir    oObj.SelectedItems = Array(item)
122*cdf0e10cSrcweir
123*cdf0e10cSrcweir    exit sub
124*cdf0e10cSrcweirErrHndl:
125*cdf0e10cSrcweir    Test.Exception()
126*cdf0e10cSrcweirEnd Sub
127*cdf0e10cSrcweir
128*cdf0e10cSrcweir' for XBoundComponent
129*cdf0e10cSrcweirFunction checkCommit() As Boolean
130*cdf0e10cSrcweirOn Error Goto ErrHndl
131*cdf0e10cSrcweir    Out.Log("checkCommit() called.")
132*cdf0e10cSrcweir    Dim rowText As Variant
133*cdf0e10cSrcweir
134*cdf0e10cSrcweir    rowText = oForm.getString(oForm.findColumn("Author"))
135*cdf0e10cSrcweir    checkCommit() = (rowText = sChangedText)
136*cdf0e10cSrcweir
137*cdf0e10cSrcweir    exit function
138*cdf0e10cSrcweirErrHndl:
139*cdf0e10cSrcweir    Test.Exception()
140*cdf0e10cSrcweirEnd Function
141*cdf0e10cSrcweir
142*cdf0e10cSrcweir' for XUpdateBroadcaster
143*cdf0e10cSrcweirSub UpdateComponent()
144*cdf0e10cSrcweir    Out.Log("UpdateComponent() called.")
145*cdf0e10cSrcweir
146*cdf0e10cSrcweir    Dim items As Variant
147*cdf0e10cSrcweir    Dim item As Variant
148*cdf0e10cSrcweir    items = oObj.SelectedItems
149*cdf0e10cSrcweir    if ubound(items()) &lt; 0 then
150*cdf0e10cSrcweir        item = 0
151*cdf0e10cSrcweir    else
152*cdf0e10cSrcweir        if items(0) = 0 then item = 1 else item = 0
153*cdf0e10cSrcweir    endif
154*cdf0e10cSrcweir    oObj.SelectedItems = Array(item)
155*cdf0e10cSrcweir
156*cdf0e10cSrcweir    oObj.commit()
157*cdf0e10cSrcweirEnd Sub
158*cdf0e10cSrcweir</script:module>
159