1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 package helper; 25 26 import com.sun.star.inspection.PropertyCategoryDescriptor; 27 import com.sun.star.inspection.XObjectInspectorModel; 28 29 /** 30 * This is an implementation of <CODE>ObjectInspectorModel</CODE>. 31 * @see com.sun.star.inspection.XObjectInspectorModel 32 */ 33 public class ObjectInspectorModelImpl implements XObjectInspectorModel{ 34 35 /** 36 * class variable which contains the implementations of 37 * <CODE>PropertyCategoryDescriptor</CODE> 38 * @see com.sun.star.inspection.PropertyCategoryDescriptor 39 */ 40 PropertyCategoryDescriptor[] m_Categories; 41 42 /** 43 * class variable which contains the count of implementations of 44 * <CODE>PropertyCategoryDescriptor</CODE> 45 */ 46 int m_count; 47 48 /** 49 * Creates a new instance of ObjectInspectorModelImpl 50 * For every count given in parameter <CODE>count</CODE> an 51 * <CODE>PropertyCategoryDescriptor</CODE> was created an filled with valuable content. 52 * @param count count of <CODE>PropertyCategoryDescriptor</CODE> to create 53 */ 54 public ObjectInspectorModelImpl(int count) { 55 m_count = count; 56 m_Categories = new PropertyCategoryDescriptor[m_count]; 57 int CategoryMem = 0; 58 int inCat = 0; 59 for (int n=0; n < m_count; n++ ){ 60 61 m_Categories[n] = new PropertyCategoryDescriptor(); 62 63 int category = n / 2; 64 inCat =(CategoryMem == category)? ++inCat: 1; 65 CategoryMem = category; 66 67 //System.out.println("Category" + category + "Number" + inCat); 68 m_Categories[n].ProgrammaticName = "Category" + category; 69 m_Categories[n].UIName = "Category" + category + "Number" + inCat; 70 m_Categories[n].HelpURL = "h:" + n; 71 } 72 } 73 74 /** 75 * returns the catrgories 76 * @return returns the catrgories 77 */ 78 public PropertyCategoryDescriptor[] describeCategories() { 79 return m_Categories; 80 } 81 82 /** 83 * returns currently nothing 84 * @return nothing 85 */ 86 public Object[] getHandlerFactories() { 87 return null; 88 } 89 90 /** determines whether the object inspector should have a help section 91 @return false 92 */ 93 public boolean getHasHelpSection() { 94 return false; 95 } 96 97 /** returns minimum number of lines in the help text section. 98 @return 3 99 */ 100 public int getMinHelpTextLines() { 101 return 3; 102 }; 103 104 /** returns maximum number of lines in the help text section. 105 @return 8 106 */ 107 public int getMaxHelpTextLines() { 108 return 8; 109 }; 110 111 /** returns whether or not the inspector's UI should be read-only 112 */ 113 public boolean getIsReadOnly() { 114 return false; 115 } 116 117 /** sets the inspector's read-only state 118 */ 119 public void setIsReadOnly( boolean _IsReadOnly ) { 120 // not supported, and not used so far in our test cases 121 } 122 123 /** 124 * retrieves an index in a global property ordering, for a given property name 125 * @param UIName the property whose global order index should be retrieved 126 * @throws com.sun.star.beans.UnknownPropertyException if the given property is unknown 127 * @return the global order index of PropertyName 128 */ 129 public int getPropertyOrderIndex(String UIName) { 130 int index = 0; 131 for (int n=0; n < m_Categories.length; n++){ 132 if (m_Categories[n].UIName.equals(UIName)){ 133 index = n; 134 break; 135 } 136 } 137 return index; 138 } 139 140 } 141