001    // Copyright 2004, 2005 The Apache Software Foundation
002    //
003    // Licensed under the Apache License, Version 2.0 (the "License");
004    // you may not use this file except in compliance with the License.
005    // You may obtain a copy of the License at
006    //
007    //     http://www.apache.org/licenses/LICENSE-2.0
008    //
009    // Unless required by applicable law or agreed to in writing, software
010    // distributed under the License is distributed on an "AS IS" BASIS,
011    // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
012    // See the License for the specific language governing permissions and
013    // limitations under the License.
014    
015    package org.apache.tapestry.valid;
016    
017    import org.apache.tapestry.IRender;
018    import org.apache.tapestry.form.IFormComponent;
019    
020    /**
021     * Defines the interface for an object that tracks input fields. This interface is now poorly named,
022     * in that it tracks errors that may <em>not</em> be associated with a specific field.
023     * <p>
024     * For each field, a flag is stored indicating if the field is, in fact, in error. The input
025     * supplied by the client is stored so that if the form is re-rendered (as is typically done when
026     * there are input errors), the value entered by the user can be displayed back to the user. An
027     * error message renderer is stored; this is an object that can render the error message (it is
028     * usually a {@link org.apache.tapestry.valid.RenderString} wrapper around a simple string).
029     * 
030     * @author Howard Lewis Ship
031     * @since 1.0.8
032     */
033    
034    public interface IFieldTracking
035    {
036        /**
037         * Returns true if the field is in error (that is, if it has an error message
038         * {@link #getErrorRenderer() renderer}.
039         */
040    
041        public boolean isInError();
042    
043        /**
044         * Returns the field component. This may return null if the error is not associated with any
045         * particular field. Note: may return null after the field tracking object is serialized and
046         * deserialized (the underlying component reference is transient); this metehod is primarily
047         * used for testing.
048         */
049    
050        public IFormComponent getComponent();
051    
052        /**
053         * Returns an object that will render the error message. The renderer <em>must</em> implement
054         * a simple <code>toString()</code> that does not produce markup, but is a simple message.
055         * 
056         * @see ValidatorException#ValidatorException(String, IRender, ValidationConstraint)
057         * @since 1.0.9
058         */
059    
060        public IRender getErrorRenderer();
061    
062        /**
063         * Returns the invalid input recorded for the field. This is stored so that, on a subsequent
064         * render, the smae invalid input can be presented to the client to be corrected.
065         */
066    
067        public String getInput();
068    
069        /**
070         * Returns the name of the field, that is, the name assigned by the form (this will differ from
071         * the component's id when any kind of looping operation is in effect).
072         */
073    
074        public String getFieldName();
075    
076        /**
077         * Returns the validation constraint that was violated by the input. This may be null if the
078         * constraint isn't known.
079         */
080    
081        public ValidationConstraint getConstraint();
082    }