2 * This file is part of the LibreOffice project.
4 * This Source Code Form is subject to the terms of the Mozilla Public
5 * License, v. 2.0. If a copy of the MPL was not distributed with this
6 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 * This file incorporates work covered by the following license notice:
10 * Licensed to the Apache Software Foundation (ASF) under one or more
11 * contributor license agreements. See the NOTICE file distributed
12 * with this work for additional information regarding copyright
13 * ownership. The ASF licenses this file to you under the Apache
14 * License, Version 2.0 (the "License"); you may not use this file
15 * except in compliance with the License. You may obtain a copy of
16 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 import com
.sun
.star
.inspection
.LineDescriptor
;
21 import com
.sun
.star
.inspection
.XPropertyHandler
;
24 * This implementation of <CODE>PropertyHandler</CODE> does currently nothing.
25 * All methods are implemented, but not filled with content.
26 * @see com.sun.star.inspection.XPropertyHandler
28 public class PropertyHandlerImpl
implements XPropertyHandler
{
31 * This method currently does nothing
32 * @param ActuatingPropertyName the id of the actuating property.
33 * @param NewValue the new value of the property
34 * @param OldValue the old value of the property
35 * @param InspectorUI a callback for updating the object inspector UI
36 * @param FirstTimeInit If true , the method is called for the first-time update of the respective property, that is, when the property browser is just initializing with the properties of the introspected object.
37 * If false , there was a real ::com::sun::star::beans::XPropertyChangeListener::propertyChange event which triggered the call.
39 * In some cases it may be necessary to differentiate between both situations. For instance, if you want to set the value of another property when an actuating property's value changed, you should definitely not do this when FirstTimeInit is true .
40 * @throws com.sun.star.lang.NullPointerException ::com::sun::star::lang::NullPointerException if InspectorUI is NULL
42 public void actuatingPropertyChanged(
43 String ActuatingPropertyName
,
46 com
.sun
.star
.inspection
.XObjectInspectorUI InspectorUI
,
47 boolean FirstTimeInit
)
48 throws com
.sun
.star
.lang
.NullPointerException
{
52 * This method currently does nothing
53 * @param xEventListener the listener to notify about changes
55 public void addEventListener(com
.sun
.star
.lang
.XEventListener xEventListener
) {
59 * This method currently does nothing
60 * @param xPropertyChangeListener the listener to notify about property changes
61 * @throws com.sun.star.lang.NullPointerException com::sun::star::lang::NullPointerException if the listener is NULL
63 public void addPropertyChangeListener(com
.sun
.star
.beans
.XPropertyChangeListener xPropertyChangeListener
) throws com
.sun
.star
.lang
.NullPointerException
{
67 * This method currently does nothing
68 * @param PropertyName The name of the property whose value is to be converted.
69 * @param PropertyValue The to-be-converted property value.
70 * @param ControlValueType The target type of the conversion. This type is determined by the control which is used to display the property, which in turn is determined by the handler itself in describePropertyLine .
71 * Speaking strictly, this is passed for convenience only, since every XPropertyHandler implementation should know exactly which type to expect, since it implicitly determined this type in describePropertyLine by creating an appropriate XPropertyControl .
73 * @throws com.sun.star.beans.UnknownPropertyException ::com::sun::star::beans::UnknownPropertyException if the given property is not supported by the property handler
76 public Object
convertToControlValue(
79 com
.sun
.star
.uno
.Type ControlValueType
)
80 throws com
.sun
.star
.beans
.UnknownPropertyException
{
85 * This method currently does nothing
86 * @param PropertyName The name of the conversion's target property.
87 * @param ControlValue The to-be-converted control value. This value has been obtained from an XPropertyControl , using its Value attribute.
88 * @throws com.sun.star.beans.UnknownPropertyException ::com::sun::star::beans::UnknownPropertyException if the given property is not supported by the property handler
91 public Object
convertToPropertyValue(String PropertyName
, Object ControlValue
) throws com
.sun
.star
.beans
.UnknownPropertyException
{
96 * This method currently does nothing
97 * @param PropertyName the name of the property whose user interface is to be described
98 * @param ControlFactory a factory for creating XPropertyControl instances. Must not be NULL .
99 * @throws com.sun.star.beans.UnknownPropertyException ::com::sun::star::beans::UnknownPropertyException if the given property is not supported by this handler
100 * @throws com.sun.star.lang.NullPointerException ::com::sun::star::lang::NullPointerException if ControlFactory is NULL .
102 public LineDescriptor
describePropertyLine(
104 com
.sun
.star
.inspection
.XPropertyControlFactory ControlFactory
)
105 throws com
.sun
.star
.beans
.UnknownPropertyException
,
106 com
.sun
.star
.lang
.NullPointerException
{
111 * This method currently does nothing
113 public void dispose() {
117 * This method currently does nothing
120 public String
[] getActuatingProperties() {
125 * This method currently does nothing
126 * @param PropertyName the name of the property whose state is to be retrieved
127 * @throws com.sun.star.beans.UnknownPropertyException ::com::sun::star::beans::UnknownPropertyException if the given property is not supported by the property handler
130 public com
.sun
.star
.beans
.PropertyState
getPropertyState(String PropertyName
)
131 throws com
.sun
.star
.beans
.UnknownPropertyException
{
136 * This method currently does nothing
137 * @param PropertyName the name of the property whose value is to be retrieved
138 * @throws com.sun.star.beans.UnknownPropertyException ::com::sun::star::beans::UnknownPropertyException if the given property is not supported by the property handler
141 public Object
getPropertyValue(String PropertyName
) throws com
.sun
.star
.beans
.UnknownPropertyException
{
146 * This method currently does nothing
149 public String
[] getSupersededProperties() {
154 * This method currently does nothing
157 public com
.sun
.star
.beans
.Property
[] getSupportedProperties() {
162 * This method currently does nothing
163 * @param Component the component to inspect. Must not be NULL
164 * @throws com.sun.star.lang.NullPointerException com::sun::star::lang::NullPointerException if the component is NULL
166 public void inspect(Object Component
) throws com
.sun
.star
.lang
.NullPointerException
{
170 * This method currently does nothing
171 * @param PropertyName the name of the property whose composability is to be determined
172 * @throws com.sun.star.beans.UnknownPropertyException ::com::sun::star::beans::UnknownPropertyException if the given property is not supported by the property handler
177 public boolean isComposable(String PropertyName
) throws com
.sun
.star
.beans
.UnknownPropertyException
{
182 * This method currently does nothing
183 * @param PropertyName The name of the property whose browse button has been clicked
184 * @param Primary true if and only if the primary button has been clicked, false otherwise
185 * @param out_Data If the method returns InteractiveSelectionResult::ObtainedValue , then _rData contains the value which has been interactively obtained from the user, and which still needs to be set at the inspected component.
186 * @param InspectorUI provides access to the object inspector UI. Implementations should use this if the property selection requires non-modal user input. In those cases, onInteractivePropertySelection should return InteractiveSelectionResult::Pending , and the UI for (at least) the property whose input is still pending should be disabled.
188 * @throws com.sun.star.beans.UnknownPropertyException ::com::sun::star::beans::UnknownPropertyException if the given property is not supported by the property handler
189 * @throws com.sun.star.lang.NullPointerException ::com::sun::star::lang::NullPointerException if InspectorUI is NULL
192 public com
.sun
.star
.inspection
.InteractiveSelectionResult
onInteractivePropertySelection(
196 com
.sun
.star
.inspection
.XObjectInspectorUI InspectorUI
)
197 throws com
.sun
.star
.beans
.UnknownPropertyException
,
198 com
.sun
.star
.lang
.NullPointerException
{
203 * This method currently does nothing
204 * @param xEventListener the listener to be revoked
206 public void removeEventListener(com
.sun
.star
.lang
.XEventListener xEventListener
) {
210 * This method currently does nothing
211 * @param xPropertyChangeListener the listener to be revoke
213 public void removePropertyChangeListener(com
.sun
.star
.beans
.XPropertyChangeListener xPropertyChangeListener
) {
217 * This method currently does nothing
218 * @param PropertyName the name of the property whose value is to be set
219 * @param Value the property value to set
220 * @throws com.sun.star.beans.UnknownPropertyException ::com::sun::star::beans::UnknownPropertyException if the given property is not supported by the property handler
222 public void setPropertyValue(String PropertyName
, Object Value
) throws com
.sun
.star
.beans
.UnknownPropertyException
{
226 * This method currently does nothing
227 * @param Suspend Whether the handler is to be suspended true or reactivated ( false ). The latter happens if a handler was successfully suspended, but an external instance vetoed the whole suspension process.
230 public boolean suspend(boolean Suspend
) {