com.l2fprod.common.propertysheet.PropertyEditorRegistry Maven / Gradle / Ivy
The newest version!
/**
* @PROJECT.FULLNAME@ @VERSION@ License.
*
* Copyright @YEAR@ L2FProd.com
*
* Licensed 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.
*/
package com.l2fprod.common.propertysheet;
import com.l2fprod.common.beans.editor.*;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.Insets;
import java.awt.Rectangle;
import java.beans.PropertyDescriptor;
import java.beans.PropertyEditor;
import java.beans.PropertyEditorManager;
import java.io.File;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
/**
* Mapping between Properties, Property Types and Property Editors.
*/
public class PropertyEditorRegistry implements PropertyEditorFactory {
private Map typeToEditor;
private Map propertyToEditor;
public PropertyEditorRegistry() {
typeToEditor = new HashMap();
propertyToEditor = new HashMap();
registerDefaults();
}
public PropertyEditor createPropertyEditor(Property property) {
return getEditor(property);
}
/**
* Gets an editor for the given property. The lookup is as follow:
*
* - if propertyDescriptor.getPropertyEditorClass() returns a valid value,
* it is returned, else,
*
- if an editor was registered with
* {@link #registerEditor(Property, PropertyEditor)}, it is
* returned, else
* - if an editor class was registered with
* {@link #registerEditor(Property, Class)}, it is returned, else
*
-
*
- look for editor for the property type using
* {@link #getEditor(Class)}.it is returned, else
*
* - look for editor using PropertyEditorManager.findEditor(Class);
*
*
*
* @param property
* @return an editor suitable for the Property.
*/
public synchronized PropertyEditor getEditor(Property property) {
PropertyEditor editor = null;
if (property instanceof PropertyDescriptorAdapter) {
PropertyDescriptor descriptor = ((PropertyDescriptorAdapter) property).getDescriptor();
if (descriptor != null) {
Class clz = descriptor.getPropertyEditorClass();
if (clz != null) {
editor = loadPropertyEditor(clz);
}
}
}
if (editor == null) {
Object value = propertyToEditor.get(property);
if (value instanceof PropertyEditor) {
editor = (PropertyEditor) value;
} else if (value instanceof Class) {
editor = loadPropertyEditor((Class) value);
} else {
editor = getEditor(property.getType());
}
}
if ((editor == null) && (property instanceof PropertyDescriptorAdapter)) {
PropertyDescriptor descriptor = ((PropertyDescriptorAdapter) property).getDescriptor();
Class clz = descriptor.getPropertyType();
editor = PropertyEditorManager.findEditor(clz);
}
return editor;
}
/**
* Load PropertyEditor from clz through reflection.
* @param clz Class to load from.
* @return Loaded propertyEditor
*/
private PropertyEditor loadPropertyEditor(Class clz) {
PropertyEditor editor = null;
try {
editor = (PropertyEditor) clz.newInstance();
} catch (Exception e) {
e.printStackTrace();
}
return editor;
}
/**
* Gets an editor for the given property type. The lookup is as
* follow:
*
* - if an editor was registered with
* {@link #registerEditor(Class, PropertyEditor)}, it is returned,
* else
* - if an editor class was registered with
* {@link #registerEditor(Class, Class)}, it is returned, else
*
-
*
- it returns null.
*
*
* @param type
* @return an editor suitable for the Property type or null if none
* found
*/
public synchronized PropertyEditor getEditor(Class type) {
PropertyEditor editor = null;
Object value = typeToEditor.get(type);
if (value instanceof PropertyEditor) {
editor = (PropertyEditor)value;
} else if (value instanceof Class) {
try {
editor = (PropertyEditor)((Class)value).newInstance();
} catch (Exception e) {
e.printStackTrace();
}
}
return editor;
}
public synchronized void registerEditor(Class type, Class editorClass) {
typeToEditor.put(type, editorClass);
}
public synchronized void registerEditor(Class type, PropertyEditor editor) {
typeToEditor.put(type, editor);
}
public synchronized void unregisterEditor(Class type) {
typeToEditor.remove(type);
}
public synchronized void registerEditor(Property property, Class editorClass) {
propertyToEditor.put(property, editorClass);
}
public synchronized void registerEditor(Property property,
PropertyEditor editor) {
propertyToEditor.put(property, editor);
}
public synchronized void unregisterEditor(Property property) {
propertyToEditor.remove(property);
}
/**
* Adds default editors. This method is called by the constructor
* but may be called later to reset any customizations made through
* the registerEditor
methods. Note: if overriden,
* super.registerDefaults()
must be called before
* plugging custom defaults.
*/
public void registerDefaults() {
typeToEditor.clear();
propertyToEditor.clear();
// our editors
registerEditor(String.class, StringPropertyEditor.class);
registerEditor(double.class, DoublePropertyEditor.class);
registerEditor(Double.class, DoublePropertyEditor.class);
registerEditor(float.class, FloatPropertyEditor.class);
registerEditor(Float.class, FloatPropertyEditor.class);
registerEditor(int.class, IntegerPropertyEditor.class);
registerEditor(Integer.class, IntegerPropertyEditor.class);
registerEditor(long.class, LongPropertyEditor.class);
registerEditor(Long.class, LongPropertyEditor.class);
registerEditor(short.class, ShortPropertyEditor.class);
registerEditor(Short.class, ShortPropertyEditor.class);
registerEditor(boolean.class, BooleanAsCheckBoxPropertyEditor.class);
registerEditor(Boolean.class, BooleanAsCheckBoxPropertyEditor.class);
registerEditor(File.class, FilePropertyEditor.class);
// awt object editors
registerEditor(Color.class, ColorPropertyEditor.class);
registerEditor(Dimension.class, DimensionPropertyEditor.class);
registerEditor(Insets.class, InsetsPropertyEditor.class);
try {
Class fontEditor =
Class.forName("com.l2fprod.common.beans.editor.FontPropertyEditor");
registerEditor(Font.class, fontEditor);
} catch (Exception e) {
// FontPropertyEditor might not be there when using the split jars
}
registerEditor(Rectangle.class, RectanglePropertyEditor.class);
//
// Date Editors based on what we have in the classpath
//
boolean foundDateEditor = false;
// if JCalendar jar is available, use it as the default date
// editor
try {
Class.forName("com.toedter.calendar.JDateChooser");
registerEditor(Date.class, Class
.forName("com.l2fprod.common.beans.editor.JCalendarDatePropertyEditor"));
foundDateEditor = true;
} catch (ClassNotFoundException e) {
// No JCalendar found
}
if (!foundDateEditor) {
// try NachoCalendar
try {
Class.forName("net.sf.nachocalendar.components.DateField");
registerEditor(
Date.class,
Class
.forName("com.l2fprod.common.beans.editor.NachoCalendarDatePropertyEditor"));
foundDateEditor = true;
} catch (ClassNotFoundException e) {
// No NachoCalendar found
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy