'************************************************************************* ' ' Licensed to the Apache Software Foundation (ASF) under one ' or more contributor license agreements. See the NOTICE file ' distributed with this work for additional information ' regarding copyright ownership. The ASF licenses this file ' to you under the Apache License, Version 2.0 (the ' "License"); you may not use this file except in compliance ' with the License. You may obtain a copy of the License at ' ' http://www.apache.org/licenses/LICENSE-2.0 ' ' Unless required by applicable law or agreed to in writing, ' software distributed under the License is distributed on an ' "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY ' KIND, either express or implied. See the License for the ' specific language governing permissions and limitations ' under the License. ' '************************************************************************* ' Be sure that all variables are dimensioned: option explicit ' REQUIRED VARIABLES for interface/service tests: ' for XComponent Global oComponentInstance As Object ' for XPersistObject Global oPersistInstance As Object ' for XUpdateBroadcaster Global bCustomUpdate As Boolean Global oForm As Object Global aList(1) As Variant Sub CreateObj() '************************************************************************* ' COMPONENT: ' forms.OListBoxModel '************************************************************************* On Error Goto ErrHndl Dim bOK As Boolean Dim aSelection(0 to 0) As Variant Dim oShape As Object, oDrawPage As Object bOK = true oDoc = utils.createDocument("swriter", cObjectName) oShape = toolkittools.addControlToDefaultForm("ListBox", 1000, 1000, 2000, 1000) oObj = oShape.getControl() oShape = toolkittools.addControlToDefaultForm("ListBox", 1000, 3000, 2000, 1000) oComponentInstance = oShape.getControl() oShape = toolkittools.addControlToDefaultForm("ListBox", 1000, 5000, 2000, 1000) oPersistInstance = oShape.getControl() 'for UnoControlListBoxModel::SelectedItems aList(0) = "Hello" aList(1) = "World" aSelection(0) = 1 oObj.DefaultSelection = aSelection() oObj.ListSource = aList() 'get control from document oDrawPage = oDoc.DrawPage oForm = oDrawPage.Forms.getByName("Standard") oForm.DataSourceName = "Bibliography" oForm.Command = "biblio" oForm.CommandType = com.sun.star.sdb.CommandType.TABLE oObj.DataField = "Author" oForm.load() ' for XUpdateBroadcaster bCustomUpdate = true Exit Sub ErrHndl: Test.Exception() End Sub Global sChangedText As String ' for XBoundComponent Sub prepareCommit() On Error Goto ErrHndl Dim items As Variant Dim item As Variant Out.Log("prepareCommit() called.") items = oObj.SelectedItems if ubound(items()) < 0 then item = 0 else if items(0) = 0 then item = 1 else item = 0 endif sChangedText = aList(item) oObj.SelectedItems = Array(item) exit sub ErrHndl: Test.Exception() End Sub ' for XBoundComponent Function checkCommit() As Boolean On Error Goto ErrHndl Out.Log("checkCommit() called.") Dim rowText As Variant rowText = oForm.getString(oForm.findColumn("Author")) checkCommit() = (rowText = sChangedText) exit function ErrHndl: Test.Exception() End Function ' for XUpdateBroadcaster Sub UpdateComponent() Out.Log("UpdateComponent() called.") Dim items As Variant Dim item As Variant items = oObj.SelectedItems if ubound(items()) < 0 then item = 0 else if items(0) = 0 then item = 1 else item = 0 endif oObj.SelectedItems = Array(item) oObj.commit() End Sub