Statistics
| Revision:

gvsig-tools / org.gvsig.tools / library / trunk / org.gvsig.tools / org.gvsig.tools.swing / org.gvsig.tools.swing.api / src / main / java / org / gvsig / tools / swing / api / dynobject / dynfield / JDynComponent.java @ 471

History | View | Annotate | Download (3.13 KB)

1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 2
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
/*
23
 * AUTHORS (In addition to CIT):
24
 * 2010 Institute of New Imaging Technologies (INIT): 
25
 *   http://www.init.uji.es
26
 * Geographic Information research group: 
27
 *   http://www.geoinfo.uji.es
28
 * Universitat Jaume I, Spain
29
 */
30
package org.gvsig.tools.swing.api.dynobject.dynfield;
31

    
32
import org.gvsig.tools.dynobject.DynField;
33
import org.gvsig.tools.dynobject.DynObject;
34
import org.gvsig.tools.dynobject.exception.DynFieldValidateException;
35
import org.gvsig.tools.swing.api.dynobject.JDynObjectComponent;
36
import org.gvsig.tools.swing.api.dynobject.ValueChangedListener;
37

    
38
/**
39
 * Set of functions shared by both the {@link JDynFieldComponent} and
40
 * {@link JDynObjectComponent}.
41
 * 
42
 * @author 2010 - <a href="cordinyana@gvsig.org">C?sar Ordi?ana</a> - gvSIG Team
43
 * @author 2010 - <a href="mailto:reinhold@uji.es">Cristian Mart?n&nbsp;</a> -
44
 *         gvSIG Team
45
 * @version $Id$
46
 * 
47
 */
48
public interface JDynComponent {
49

    
50
    /**
51
     * Returns whether the {@link DynField} value passes the validation phase or
52
     * not.
53
     * 
54
     * @return
55
     *         <b>true </b> the field value is valid. <br>
56
     *         <b>false </b> the field value is not valid.
57
     */
58
    public boolean isValid();
59

    
60
    /**
61
     * Specifies which is the component of this class to gain the focus
62
     * when this function is called.
63
     */
64
    public void requestFocus();
65

    
66
    /**
67
     * Stores the edited data into the {@link DynObject} field.
68
     * @throws DynFieldValidateException 
69
     */
70
    public void saveStatus() throws DynFieldValidateException;
71

    
72
    /**
73
     * Allows adding a listener to the list of listeners of this JDynComponent.
74
     * 
75
     * @param listener
76
     *            the {@link ValueChangedListener}
77
     * 
78
     * @see ValueChangedListener#handleValueChanged(JDynFieldComponent)
79
     */
80
    public void addValueChangedListener(ValueChangedListener listener);
81
    
82

    
83
    /**
84
     * @return
85
     */
86
    public Object getValue();
87

    
88
        /**
89
         * Returns if the current component has changes not saved into the source
90
         * data.
91
         * 
92
         * @return if the current component has changes TODO: add the method when
93
         *         the edition options are enabled again
94
         */
95
        // public boolean hasChanges();
96

    
97
}