All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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