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

org.apache.myfaces.trinidad.component.UIXEditableValue Maven / Gradle / Ivy

The newest version!
// WARNING: This file was automatically generated. Do not edit it directly,
//          or you will lose your changes.

/*
 * 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.
*/
package org.apache.myfaces.trinidad.component;

import java.util.Iterator;
import javax.el.ValueExpression;
import javax.faces.FacesException;
import javax.faces.application.Application;
import javax.faces.application.FacesMessage;
import javax.faces.component.EditableValueHolder;
import javax.faces.component.UIComponent;
import javax.faces.component.UIInput;
import javax.faces.context.ExternalContext;
import javax.faces.context.FacesContext;
import javax.faces.convert.Converter;
import javax.faces.convert.ConverterException;
import javax.faces.el.EvaluationException;
import javax.faces.el.MethodBinding;
import javax.faces.event.AbortProcessingException;
import javax.faces.event.FacesEvent;
import javax.faces.event.FacesListener;
import javax.faces.event.PostValidateEvent;
import javax.faces.event.PreValidateEvent;
import javax.faces.event.ValueChangeEvent;
import javax.faces.event.ValueChangeListener;
import javax.faces.render.Renderer;
import javax.faces.validator.Validator;
import javax.faces.validator.ValidatorException;
import javax.validation.Validation;
import org.apache.myfaces.trinidad.bean.FacesBean;
import org.apache.myfaces.trinidad.bean.PropertyKey;
import org.apache.myfaces.trinidad.context.RequestContext;
import org.apache.myfaces.trinidad.event.ValueUpdatedEvent;
import org.apache.myfaces.trinidad.event.ValueUpdatedListener;
import org.apache.myfaces.trinidad.logging.TrinidadLogger;
import org.apache.myfaces.trinidad.util.ClassLoaderUtils;
import org.apache.myfaces.trinidad.util.ComponentUtils;
import org.apache.myfaces.trinidad.util.LabeledFacesMessage;
import org.apache.myfaces.trinidad.util.MessageFactory;
import org.apache.myfaces.trinidad.util.Reportable;

/**
 *
 * 

Events:

* * * * * * * * * * * * * * * * *
TypePhasesDescription
javax.faces.event.ValueChangeEventProcess
Validations
Apply
Request
Values
The valueChange event is delivered when the value attribute is changed.
org.apache.myfaces.trinidad.event.AttributeChangeEventInvoke
Application
Apply
Request
Values
Event delivered to describe an attribute change. Attribute change events are not delivered for any programmatic change to a property. They are only delivered when a renderer changes a property without the application's specific request. An example of an attribute change event might include the width of a column that supported client-side resizing.
*/ abstract public class UIXEditableValue extends UIXValue implements EditableValueHolder { static public final FacesBean.Type TYPE = new FacesBean.Type( UIXValue.TYPE); static public final PropertyKey IMMEDIATE_KEY = TYPE.registerKey("immediate", Boolean.class, Boolean.FALSE); static public final PropertyKey VALID_KEY = TYPE.registerKey("valid", Boolean.class, Boolean.TRUE); static public final PropertyKey REQUIRED_KEY = TYPE.registerKey("required", Boolean.class, Boolean.FALSE); static public final PropertyKey LOCAL_VALUE_SET_KEY = TYPE.registerKey("localValueSet", Boolean.class, PropertyKey.CAP_NOT_BOUND); static public final PropertyKey SUBMITTED_VALUE_KEY = TYPE.registerKey("submittedValue", PropertyKey.CAP_NOT_BOUND); static public final PropertyKey VALIDATOR_KEY = TYPE.registerKey("validator", MethodBinding.class, PropertyKey.CAP_NOT_BOUND | PropertyKey.CAP_STATE_HOLDER); static public final PropertyKey VALUE_CHANGE_LISTENER_KEY = TYPE.registerKey("valueChangeListener", MethodBinding.class, PropertyKey.CAP_NOT_BOUND | PropertyKey.CAP_STATE_HOLDER); static public final PropertyKey REQUIRED_MESSAGE_DETAIL_KEY = TYPE.registerKey("requiredMessageDetail", String.class); static public final String COMPONENT_FAMILY = "org.apache.myfaces.trinidad.EditableValue"; static public final String COMPONENT_TYPE = "org.apache.myfaces.trinidad.EditableValue"; static public final PropertyKey VALIDATORS_KEY = TYPE.registerKey("validators", Validator[].class, PropertyKey.CAP_LIST); static public final String REQUIRED_MESSAGE_ID = "org.apache.myfaces.trinidad.UIXEditableValue.REQUIRED"; static public final String CONVERSION_MESSAGE_ID = "org.apache.myfaces.trinidad.UIXEditableValue.CONVERSION"; static public final String TRINIDAD_BEAN_VALIDATION_AVAILABLE = "org.apache.myfaces.trinidad.UIXEditableValue.BEAN_VALIDATION_AVAILABLE"; static public final String VALIDATE_EMPTY_FIELDS_PARAM_NAME = "org.apache.myfaces.trinidad.UIXEditableValue.VALIDATE_EMPTY_FIELDS"; /** -=matzew=- According to http://wiki.java.net/bin/view/Projects/Jsf2MR1ChangeLog * this constant will be made public on UIInput with JSF 2.1. For now we have to have * it here as a private one... **/ static private final String JSF_SPEC_EMPTY_VALUES_AS_NULL_PARAM_NAME = "javax.faces.INTERPRET_EMPTY_STRING_SUBMITTED_VALUES_AS_NULL"; // our own cache key... static public final String TRINIDAD_EMPTY_VALUES_AS_NULL_PARAM_NAME = "org.apache.myfaces.trinidad.UIXEditableValue.INTERPRET_EMPTY_STRING_SUBMITTED_VALUES_AS_NULL"; /** * Convenience method to reset this component's value to an * uninitialized state, by resetting the local value and * submitted values to null (ensuring that {@link #isLocalValueSet} * is false), and setting "valid" to true. */ public void resetValue() { setValue(null); setSubmittedValue(null); setLocalValueSet(false); setValid(true); } // ----------------------------------------------------- Validators Methods public void addValidator(Validator validator) { if (validator == null) throw new NullPointerException(); getFacesBean().addEntry(VALIDATORS_KEY, validator); } public Validator[] getValidators() { return (Validator[]) getFacesBean().getEntries(VALIDATORS_KEY, Validator.class); } public void removeValidator(Validator validator) { getFacesBean().removeEntry(VALIDATORS_KEY, validator); } /** */ public void validate(FacesContext context) { if (context == null) throw new NullPointerException(); // Submitted value == null means "the component was not submitted // at all"; validation should not continue Object submittedValue = getSubmittedValue(); if (submittedValue == null) return; // From the SPEC: // If the javax.faces.INTERPRET_EMPTY_STRING_SUBMITTED_VALUES_AS_NULL context parameter value is // true (ignoring case), and getSubmittedValue() returns a zero-length String call // setSubmittedValue(null) and continue processing using null as the current submitted value // // TODO: -> SPEC ISSUE (matzew) setSubmittedValue(null) is wrong, so we do not follow the spec here... if (shouldInterpretEmptyStringSubmittedValuesAsNull(context) && _isEmptyString(submittedValue)) { submittedValue = null; } Object newValue = null; try { newValue = getConvertedValue(context, submittedValue); } catch (ConverterException ce) { _addConversionErrorMessage(context, ce, submittedValue); setValid(false); } validateValue(context, newValue); // If our value is valid, store the new value, erase the // "submitted" value, and emit a ValueChangeEvent if appropriate if (isValid()) { Object previous = getValue(); setSubmittedValue(null); if (compareValues(previous, newValue)) { setValue(newValue); queueEvent(new ValueChangeEvent(this, previous, newValue)); } } } /** * In addition to to the default * {@link javax.faces.component.UIComponent#broadcast} * processing, pass the {@link ValueChangeEvent} being broadcast to the * method referenced by valueChangeListener (if any). * * @param event {@link FacesEvent} to be broadcast * * @exception AbortProcessingException Signal the JavaServer Faces * implementation that no further processing on the current event * should be performed * @exception IllegalArgumentException if the implementation class * of this {@link FacesEvent} is not supported by this component * @exception NullPointerException if event is * null */ @Override public void broadcast(FacesEvent event) throws AbortProcessingException { // Perform standard superclass processing super.broadcast(event); if (event instanceof ValueChangeEvent) { broadcastToMethodBinding(event, getValueChangeListener()); } } /** * In addition to the standard processDecodes behavior * inherited from {@link UIXComponentBase}, calls * validate() if the the immediate * property is true. Iif the component is invalid afterwards or * a RuntimeException is thrown, calls * {@link FacesContext#renderResponse}. */ @Override public void processDecodes(FacesContext context) { if (!isValid()) { // An exception could occur during normal bean attribute level // validation in update_model phase. When it happens, the component // will have an invalid local value, and LOCAL_VALUE_SET remains // true since we want the invalid value to be shown to end user // to make corrections. But we don't want the invalid state affects // the next request, so we clear the local value and LOCAL_VALUE_SET // property here. While on the other hand, we should not clear the // state when the component is valid, to avoid accidentally clearing // data that other components might depend on. setValue(null); setLocalValueSet(false); } setValid(true); RequestContext requestContext = RequestContext.getCurrentInstance(); requestContext.pushCurrentComponent(context, this); pushComponentToEL(context, this); try { // Skip processing if our rendered flag is false if (!isRendered()) return; super.processDecodes(context); if (isImmediate()) _executeValidate(context); } finally { popComponentFromEL(context); requestContext.popCurrentComponent(context, this); } } @Override public void processUpdates(FacesContext context) { RequestContext requestContext = RequestContext.getCurrentInstance(); requestContext.pushCurrentComponent(context, this); pushComponentToEL(context, this); try { // Skip processing if our rendered flag is false if (!isRendered()) return; super.processUpdates(context); // Process this component itself updateModel(context); } finally { popComponentFromEL(context); requestContext.popCurrentComponent(context, this); } if (!isValid()) { context.renderResponse(); } } @Override public void processValidators(FacesContext context) { RequestContext requestContext = RequestContext.getCurrentInstance(); requestContext.pushCurrentComponent(context, this); pushComponentToEL(context, this); try { // Skip processing if our rendered flag is false if (!isRendered()) return; super.processValidators(context); if (!isImmediate()) _executeValidate(context); } finally { popComponentFromEL(context); requestContext.popCurrentComponent(context, this); } } /** * Adds a ValueUpdatedListener to the component to handle ValueUpdatedEvent which is queued * within updateModel method. */ public void addValueUpdatedListener(ValueUpdatedListener listener) { super.addFacesListener(listener); } /** * Removes a ValueUpdatedListener from the component. */ public void removeValueUpdatedListener(ValueUpdatedListener listener) { super.removeFacesListener(listener); } // TODO Better error messages when update model fails. public void updateModel(FacesContext context) { if (context == null) throw new NullPointerException(); if (!isValid() || !isLocalValueSet()) return; ValueExpression expression = getFacesBean().getValueExpression(VALUE_KEY); if (expression == null) return; try { Object localValue = getLocalValue(); expression.setValue(context.getELContext(), localValue); setValue(null); setLocalValueSet(false); (new ValueUpdatedEvent(this)).queue(); if (_LOG.isFiner()) { _LOG.finer("Wrote value {0} to model {1} in component {2}", new Object[]{localValue, expression.getExpressionString(), this}); } } catch (RuntimeException e) { // exceptions at this point can occur during normal // bean attribute level validation: if (_LOG.isFine()) { _LOG.fine("Error updating expression ({0})", expression.getExpressionString()); _LOG.fine(e); } setValid(false); // don't report the exception if the exception is a Reportable instance and tells so boolean shouldReportMessage = (e instanceof Reportable) ? ((Reportable) e).shouldReportMessage() : true; if (shouldReportMessage) { FacesMessage message = MessageFactory.getMessage(e); message = _wrapMessage(message); context.addMessage(getClientId(context), message); } } } /** */ @SuppressWarnings("unchecked") protected void validateValue(FacesContext context, Object newValue) { if (!isValid()) return; // If our value is empty, check the required property boolean isEmpty = isEmpty(newValue); if (isEmpty && isRequired()) { FacesMessage message = _getRequiredFacesMessage(context); context.addMessage(getClientId(context), message); setValid(false); } // If our value is not empty, OR we should do empty field validation, call all validators if (!isEmpty || shouldValidateEmptyFields(context)) { Iterator validators = (Iterator)getFacesBean().entries(VALIDATORS_KEY); while (validators.hasNext()) { Validator validator = validators.next(); try { validator.validate(context, this, newValue); } catch (ValidatorException ve) { // If the validator throws an exception, we're // invalid, and we need to add a message setValid(false); FacesMessage message = ve.getFacesMessage(); if (message != null) { message.setSeverity(FacesMessage.SEVERITY_ERROR); message = _wrapMessage(message); context.addMessage(getClientId(context), message); } } } MethodBinding validatorBinding = getValidator(); if (validatorBinding != null) { try { validatorBinding.invoke(context, new Object[] { context, this, newValue}); } catch (EvaluationException ee) { Throwable cause = ee.getCause(); if (cause instanceof ValidatorException) { ValidatorException ve = (ValidatorException) cause; // If the validator throws an exception, we're // invalid, and we need to add a message setValid(false); FacesMessage message = ve.getFacesMessage(); if (message != null) { message.setSeverity(FacesMessage.SEVERITY_ERROR); message = _wrapMessage(message); context.addMessage(getClientId(context), message); } } else { // Otherwise, rethrow the EvaluationException throw ee; } } } } } protected String getRequiredMessageKey() { return REQUIRED_MESSAGE_ID; } /** * */ protected Object getConvertedValue( FacesContext context, Object submittedValue) throws ConverterException { Renderer renderer = getRenderer(context); Object newValue = null; if (_LOG.isFine()) { _LOG.fine("Converting from " + submittedValue + "(" + submittedValue.getClass() + ")"); } if (renderer != null) { newValue = renderer.getConvertedValue(context, this, submittedValue); if (_LOG.isFine()) { _LOG.fine("Renderer " + renderer + " returned value " + newValue + "(" + ((newValue != null) ? newValue.getClass().getName() : "null") + ")"); } } else if (submittedValue instanceof String) { // If there's no Renderer, and we've got a String, // run it through the Converter (if any) Converter converter = _getConverterWithType(context); if (converter != null) { newValue = converter.getAsObject(context, this, (String) submittedValue); } else { newValue = submittedValue; } } else { newValue = submittedValue; } return newValue; } /** *

Return true if the new value is different from the * previous value.

* * @param previous old value of this component (if any) * @param value new value of this component (if any) */ protected boolean compareValues(Object previous, Object value) { // handle cases where previous value was empty if (previous == null || "".equals(previous)) // bug 4268807 return !(value == null || "".equals(value)); boolean isNotEqual = !previous.equals(value); // Handle objects whose comparable() implementation is inconsistent with equals(). // if not equal we will also check compareTo if the data implements Comparable. // An example of why we need this is for a case where the data is bigdecimal, // because bigdecimal remembers formatting information like scale. So 2.0 is not equal to 2.00 // in bigdecimal, but when you use compareTo 2.0 and 2.00 are equal. // See Issue TRINIDAD-1489 for test case if (isNotEqual && value instanceof Comparable && previous.getClass().equals(value.getClass())) { int compareTo = ((Comparable)previous).compareTo(value); isNotEqual = (compareTo != 0); } return isNotEqual; } /** *

Return true if the value is empty.

*/ protected boolean isEmpty(Object value) { if (value == null) return true; return ((value instanceof String) && (((String) value).trim().length() == 0)); } /** *

Return true if the value is an empty String.

*/ private boolean _isEmptyString(Object value) { return ((value instanceof String) && (((String) value).length() == 0)); } /** * Checks if the validate() should interpret an empty * submitted value should be handle as NULL * * @return a (cached) boolean to identify the interpretation as null */ public static boolean shouldInterpretEmptyStringSubmittedValuesAsNull(FacesContext context) { ExternalContext ec = context.getExternalContext(); Boolean interpretEmptyStringAsNull = (Boolean)ec.getApplicationMap().get(TRINIDAD_EMPTY_VALUES_AS_NULL_PARAM_NAME); // not yet cached... if (interpretEmptyStringAsNull == null) { // parses the web.xml to get the "javax.faces.INTERPRET_EMPTY_STRING_SUBMITTED_VALUES_AS_NULL" value String param = ec.getInitParameter(JSF_SPEC_EMPTY_VALUES_AS_NULL_PARAM_NAME); // evaluate the context parameter interpretEmptyStringAsNull = "true".equalsIgnoreCase(param); // cache the parsed value ec.getApplicationMap().put(TRINIDAD_EMPTY_VALUES_AS_NULL_PARAM_NAME, interpretEmptyStringAsNull); } return interpretEmptyStringAsNull; } /** * Checks if the validateValue() should handle * empty field validation (part of BeanValidation and JSF 2.0). * * @return a (cached) boolean to identify empty field validation */ public static boolean shouldValidateEmptyFields(FacesContext context) { ExternalContext ec = context.getExternalContext(); Boolean shouldValidateEmptyFields = (Boolean)ec.getApplicationMap().get(VALIDATE_EMPTY_FIELDS_PARAM_NAME); // not yet cached... if (shouldValidateEmptyFields == null) { // From the JSF 2.0 specification: // The implementation must obtain the init parameter Map from the ExternalContext and inspect the value // for the key given by the value of the symbolic constant VALIDATE_EMPTY_FIELDS_PARAM_NAME. String param = ec.getInitParameter(UIInput.VALIDATE_EMPTY_FIELDS_PARAM_NAME); // If there is no value under that key, use the same key and look in the // application map from the ExternalContext. if (param == null) { Object value = ec.getApplicationMap().get(UIInput.VALIDATE_EMPTY_FIELDS_PARAM_NAME); // an other thread could have changed the value if (value instanceof Boolean) { shouldValidateEmptyFields = (Boolean) value; return shouldValidateEmptyFields; } else { param = (String) value; } } // null means the same as auto (see SPEC on page 11-5) if (param == null) { param = "auto"; } else { // The environment variables are case insensitive... param = param.toLowerCase(); } if (param.equals("auto") && _isBeanValidationAvailable(context)) { shouldValidateEmptyFields = Boolean.TRUE; } else { // "true".equalsIgnoreCase(param) is faster than Boolean.valueOf() shouldValidateEmptyFields = "true".equalsIgnoreCase(param); } // cache the parsed value ec.getApplicationMap().put(VALIDATE_EMPTY_FIELDS_PARAM_NAME, shouldValidateEmptyFields); } return shouldValidateEmptyFields; } /** * This boolean indicates if Bean Validation is present. * * @return a (cached) boolean to identify if bean validation is present */ private static boolean _isBeanValidationAvailable(FacesContext context) { ExternalContext ec = context.getExternalContext(); Boolean couldLoadBeanValidationAPI = (Boolean) ec.getApplicationMap().get(TRINIDAD_BEAN_VALIDATION_AVAILABLE); // not yet cached... if (couldLoadBeanValidationAPI == null) { try { couldLoadBeanValidationAPI = Boolean.valueOf(ClassLoaderUtils.loadClass("javax.validation.Validation") != null); if (couldLoadBeanValidationAPI) { try { // Trial-error approach to check for Bean Validation impl existence. Validation.buildDefaultValidatorFactory().getValidator(); } catch (Exception validationException) { // From section 3.5.6.2 of the spec // "If the BeanValidator is used an no ValidatorFactory can be retrieved, a FacesException is raised. " // Only BeanValidator needs to throw a FacesException, in this case just log the message // and behave as if bean validation is disabled _LOG.warning("VALIDATOR_FACTORY_UNAVAILABLE", validationException.getMessage()); couldLoadBeanValidationAPI = Boolean.FALSE; } } } catch (ClassNotFoundException cnfe) { // SPEC section 3.5.6.2: // if a Bean Validation provider is not present, bean validation is disabled // TODO need a better warning (i18n) here, which has more information _LOG.warning("A Bean Validation provider is not present, therefore bean validation is disabled"); couldLoadBeanValidationAPI = Boolean.FALSE; } // cache the parsed value ec.getApplicationMap().put(TRINIDAD_BEAN_VALIDATION_AVAILABLE, couldLoadBeanValidationAPI); } return couldLoadBeanValidationAPI; } /** * Executes validation logic. */ private void _executeValidate(FacesContext context) { Application application = context.getApplication(); application.publishEvent(context, PreValidateEvent.class, UIComponent.class, this); try { validate(context); } catch (RuntimeException e) { context.renderResponse(); throw e; } finally { application.publishEvent(context, PostValidateEvent.class, UIComponent.class, this); } if (!isValid()) { context.renderResponse(); } } // We currently use 'label' for the validation failed message private Object _getLabel() { Object o = getAttributes().get("label"); if (o == null) o = getValueExpression("label"); return o; } private Object _getRequiredMessageDetail() { Object o = getAttributes().get("requiredMessageDetail"); if (o == null) o = getValueExpression("requiredMessageDetail"); return o; } private FacesMessage _getRequiredFacesMessage(FacesContext context) { Object customMessageDetail = _getRequiredMessageDetail(); FacesMessage message; Object label = _getLabel(); // if message is null then a custom message was not set. message = MessageFactory.getMessage(context, getRequiredMessageKey(), customMessageDetail, new Object[]{label}, label); return message; } private void _addConversionErrorMessage( FacesContext context, ConverterException ce, Object value) { FacesMessage message = ce.getFacesMessage(); if (message == null) { Object label = _getLabel(); message = MessageFactory.getMessage(context, CONVERSION_MESSAGE_ID, new Object[]{label, value, ce.getMessage()}, label); } else { message = _wrapMessage(message); } context.addMessage(getClientId(context), message); } private Converter _getConverterWithType(FacesContext context) { Converter converter = getConverter(); if (converter != null) { return converter; } ValueExpression valueExpression = getValueExpression("value"); if (valueExpression == null) { return null; } Class converterType = valueExpression.getType(context.getELContext()); // if converterType is null, String, or Object, assume // no conversion is needed if (converterType == null || converterType == String.class || converterType == Object.class) { return null; } // if getType returns a type for which we support a default // conversion, acquire an appropriate converter instance. try { Application application = context.getApplication(); return application.createConverter(converterType); } catch (Exception e) { return null; } } private FacesMessage _wrapMessage(FacesMessage original) { if (original instanceof LabeledFacesMessage) return original; return new FacesMessageWrapper(original, _getLabel()); } static private final TrinidadLogger _LOG = TrinidadLogger.createTrinidadLogger(UIXEditableValue.class); /** * Gets whether the value is converted and validated immediately in the Apply Request Values phase, or is handled in the Process Validators phase, the default. By default, values are converted and validated together in the Process Validators phase. However, if you need access to the value of a component during Apply Request Values - for example, if you need to get the value from an actionListener on an immediate commandButton - then setting this to "immediate" makes that possible. * * @return the new immediate value */ final public boolean isImmediate() { return ComponentUtils.resolveBoolean(getProperty(IMMEDIATE_KEY), false); } /** * Sets whether the value is converted and validated immediately in the Apply Request Values phase, or is handled in the Process Validators phase, the default. By default, values are converted and validated together in the Process Validators phase. However, if you need access to the value of a component during Apply Request Values - for example, if you need to get the value from an actionListener on an immediate commandButton - then setting this to "immediate" makes that possible. * * @param immediate the new immediate value */ final public void setImmediate(boolean immediate) { setProperty(IMMEDIATE_KEY, immediate ? Boolean.TRUE : Boolean.FALSE); } /** * Gets whether the component's value is currently valid * * @return the new valid value */ final public boolean isValid() { return ComponentUtils.resolveBoolean(getProperty(VALID_KEY), true); } /** * Sets whether the component's value is currently valid * * @param valid the new valid value */ final public void setValid(boolean valid) { setProperty(VALID_KEY, valid ? Boolean.TRUE : Boolean.FALSE); } /** * Gets whether a non-null, non-empty value must be entered. If false, validators will not be executed when the value is null or empty. * * @return the new required value */ final public boolean isRequired() { return ComponentUtils.resolveBoolean(getProperty(REQUIRED_KEY), false); } /** * Sets whether a non-null, non-empty value must be entered. If false, validators will not be executed when the value is null or empty. * * @param required the new required value */ final public void setRequired(boolean required) { setProperty(REQUIRED_KEY, required ? Boolean.TRUE : Boolean.FALSE); } /** * Gets whether a local value is currently set. If false, values are being retrieved from any attached ValueBinding * * @return the new localValueSet value */ final public boolean isLocalValueSet() { return ComponentUtils.resolveBoolean(getProperty(LOCAL_VALUE_SET_KEY)); } /** * Sets whether a local value is currently set. If false, values are being retrieved from any attached ValueBinding * * @param localValueSet the new localValueSet value */ final public void setLocalValueSet(boolean localValueSet) { setProperty(LOCAL_VALUE_SET_KEY, localValueSet ? Boolean.TRUE : Boolean.FALSE); } /** * Gets the current submitted value. This value, * if non-null, is set by the Renderer to store a possibly invalid value * for later conversion or redisplay, and has not yet been converted * into the proper type for this component instance. This method * should only be used by the decode() and validate() method * of this component, or its corresponding Renderer; however, user code * may manually set it to null to erase any submitted value. * * @return the new submittedValue value */ final public Object getSubmittedValue() { return getProperty(SUBMITTED_VALUE_KEY); } /** * Sets the current submitted value. This value, * if non-null, is set by the Renderer to store a possibly invalid value * for later conversion or redisplay, and has not yet been converted * into the proper type for this component instance. This method * should only be used by the decode() and validate() method * of this component, or its corresponding Renderer; however, user code * may manually set it to null to erase any submitted value. * * @param submittedValue the new submittedValue value */ final public void setSubmittedValue(Object submittedValue) { setProperty(SUBMITTED_VALUE_KEY, (submittedValue)); } /** * Gets a method reference to a validator method * * @return the new validator value * @deprecated */ final public MethodBinding getValidator() { return (MethodBinding)getProperty(VALIDATOR_KEY); } /** * Sets a method reference to a validator method * * @param validator the new validator value * @deprecated */ final public void setValidator(MethodBinding validator) { setProperty(VALIDATOR_KEY, (validator)); } /** * Gets a method reference to a value change listener * * @return the new valueChangeListener value * @deprecated */ final public MethodBinding getValueChangeListener() { return (MethodBinding)getProperty(VALUE_CHANGE_LISTENER_KEY); } /** * Sets a method reference to a value change listener * * @param valueChangeListener the new valueChangeListener value * @deprecated */ final public void setValueChangeListener(MethodBinding valueChangeListener) { setProperty(VALUE_CHANGE_LISTENER_KEY, (valueChangeListener)); } /** * Gets the message to be displayed, if 'required' validation fails. *

* * Parameters: * *

    *
  • * {0} the label that identifies the component *
  • *
*

* * @return the new requiredMessageDetail value */ final public String getRequiredMessageDetail() { return ComponentUtils.resolveString(getProperty(REQUIRED_MESSAGE_DETAIL_KEY)); } /** * Sets the message to be displayed, if 'required' validation fails. *

* * Parameters: * *

    *
  • * {0} the label that identifies the component *
  • *
*

* * @param requiredMessageDetail the new requiredMessageDetail value */ final public void setRequiredMessageDetail(String requiredMessageDetail) { setProperty(REQUIRED_MESSAGE_DETAIL_KEY, (requiredMessageDetail)); } /** * Adds a valueChange listener. * * @param listener the valueChange listener to add */ final public void addValueChangeListener( ValueChangeListener listener) { addFacesListener(listener); } /** * Removes a valueChange listener. * * @param listener the valueChange listener to remove */ final public void removeValueChangeListener( ValueChangeListener listener) { removeFacesListener(listener); } /** * Returns an array of attached valueChange listeners. * * @return an array of attached valueChange listeners. */ final public ValueChangeListener[] getValueChangeListeners() { return (ValueChangeListener[])getFacesListeners(ValueChangeListener.class); } @Override public String getFamily() { return COMPONENT_FAMILY; } @Override protected FacesBean.Type getBeanType() { return TYPE; } /** * Construct an instance of the UIXEditableValue. */ protected UIXEditableValue( String rendererType ) { super(rendererType); } /** * Construct an instance of the UIXEditableValue. */ protected UIXEditableValue() { this(null); } static { TYPE.lockAndRegister("org.apache.myfaces.trinidad.EditableValue","org.apache.myfaces.trinidad.EditableValue"); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy