1 // license-header java merge-point
2 //
3 // Attention: Generated code! Do not modify by hand!
4 // Generated by: hibernate/HibernateEntity.vsl in andromda-hibernate-cartridge.
5 //
6 package fr.ifremer.quadrige3.core.dao.system.extraction;
7
8 /*-
9 * #%L
10 * Quadrige3 Core :: Client API
11 * %%
12 * Copyright (C) 2017 - 2024 Ifremer
13 * %%
14 * This program is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Affero General Public License as published by
16 * the Free Software Foundation, either version 3 of the License, or
17 * (at your option) any later version.
18 *
19 * This program is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
23 *
24 * You should have received a copy of the GNU Affero General Public License
25 * along with this program. If not, see <http://www.gnu.org/licenses/>.
26 * #L%
27 */
28 import fr.ifremer.quadrige3.core.dao.referential.ObjectType;
29 import java.io.Serializable;
30 import java.sql.Timestamp;
31
32 /**
33 * Liste des champs devant être affichés lors de l'extraction d'un objet.
34 */
35 // HibernateEntity.vsl annotations merge-point
36 public abstract class ExtractField
37 implements Serializable, Comparable<ExtractField>
38 {
39 /**
40 * The serial version UID of this class. Needed for serialization.
41 */
42 private static final long serialVersionUID = -5043952409230432815L;
43
44 // Generate 5 attributes
45 private Integer extractFieldId;
46
47 /**
48 * Identifiant primaire de extract_field
49 * @return this.extractFieldId Integer
50 */
51 public Integer getExtractFieldId()
52 {
53 return this.extractFieldId;
54 }
55
56 /**
57 * Identifiant primaire de extract_field
58 * @param extractFieldIdIn Integer
59 */
60 public void setExtractFieldId(Integer extractFieldIdIn)
61 {
62 this.extractFieldId = extractFieldIdIn;
63 }
64
65 private String extractFieldNm;
66
67 /**
68 * Nom du champ à afficher
69 * @return this.extractFieldNm String
70 */
71 public String getExtractFieldNm()
72 {
73 return this.extractFieldNm;
74 }
75
76 /**
77 * Nom du champ à afficher
78 * @param extractFieldNmIn String
79 */
80 public void setExtractFieldNm(String extractFieldNmIn)
81 {
82 this.extractFieldNm = extractFieldNmIn;
83 }
84
85 private Integer extractFieldRank;
86
87 /**
88 * Rang du champ pour l'affichage et lors des tri
89 * @return this.extractFieldRank Integer
90 */
91 public Integer getExtractFieldRank()
92 {
93 return this.extractFieldRank;
94 }
95
96 /**
97 * Rang du champ pour l'affichage et lors des tri
98 * @param extractFieldRankIn Integer
99 */
100 public void setExtractFieldRank(Integer extractFieldRankIn)
101 {
102 this.extractFieldRank = extractFieldRankIn;
103 }
104
105 private String extractFieldSortType;
106
107 /**
108 * Type de tri utilisé pour le champ, ASC ou DESC ou NULL
109 * @return this.extractFieldSortType String
110 */
111 public String getExtractFieldSortType()
112 {
113 return this.extractFieldSortType;
114 }
115
116 /**
117 * Type de tri utilisé pour le champ, ASC ou DESC ou NULL
118 * @param extractFieldSortTypeIn String
119 */
120 public void setExtractFieldSortType(String extractFieldSortTypeIn)
121 {
122 this.extractFieldSortType = extractFieldSortTypeIn;
123 }
124
125 private Timestamp updateDt;
126
127 /**
128 * Date de modification de l'objet, mise à jour par le système
129 * @return this.updateDt Timestamp
130 */
131 public Timestamp getUpdateDt()
132 {
133 return this.updateDt;
134 }
135
136 /**
137 * Date de modification de l'objet, mise à jour par le système
138 * @param updateDtIn Timestamp
139 */
140 public void setUpdateDt(Timestamp updateDtIn)
141 {
142 this.updateDt = updateDtIn;
143 }
144
145 // Generate 2 associations
146 private ObjectType objectType;
147
148 /**
149 * Liste des types d'objets qui peuvent être associés à la photo ou à un résultat. Cette liste
150 * ne peut
151 * pas être modifiée par l'utilisateur.
152 * @return this.objectType ObjectType
153 */
154 public ObjectType getObjectType()
155 {
156 return this.objectType;
157 }
158
159 /**
160 * Liste des types d'objets qui peuvent être associés à la photo ou à un résultat. Cette liste
161 * ne peut
162 * pas être modifiée par l'utilisateur.
163 * @param objectTypeIn ObjectType
164 */
165 public void setObjectType(ObjectType objectTypeIn)
166 {
167 this.objectType = objectTypeIn;
168 }
169
170 private ExtractFilter extractFilter;
171
172 /**
173 * Définit les éléments supplémentaires au filtre et nécessaires à l'extraction.
174 * @return this.extractFilter ExtractFilter
175 */
176 public ExtractFilter getExtractFilter()
177 {
178 return this.extractFilter;
179 }
180
181 /**
182 * Définit les éléments supplémentaires au filtre et nécessaires à l'extraction.
183 * @param extractFilterIn ExtractFilter
184 */
185 public void setExtractFilter(ExtractFilter extractFilterIn)
186 {
187 this.extractFilter = extractFilterIn;
188 }
189
190 /**
191 * Returns <code>true</code> if the argument is an ExtractField instance and all identifiers for this entity
192 * equal the identifiers of the argument entity. Returns <code>false</code> otherwise.
193 */
194 @Override
195 public boolean equals(Object object)
196 {
197 if (this == object)
198 {
199 return true;
200 }
201 if (!(object instanceof ExtractField))
202 {
203 return false;
204 }
205 final ExtractField that = (ExtractField)object;
206 if (this.extractFieldId == null || that.getExtractFieldId() == null || !this.extractFieldId.equals(that.getExtractFieldId()))
207 {
208 return false;
209 }
210 return true;
211 }
212
213 /**
214 * Returns a hash code based on this entity's identifiers.
215 */
216 @Override
217 public int hashCode()
218 {
219 int hashCode = 0;
220 hashCode = 29 * hashCode + (this.extractFieldId == null ? 0 : this.extractFieldId.hashCode());
221
222 return hashCode;
223 }
224
225 /**
226 * Constructs new instances of {@link ExtractField}.
227 */
228 public static final class Factory
229 {
230 /**
231 * Constructs a new instance of {@link ExtractField}.
232 * @return new ExtractFieldImpl()
233 */
234 public static ExtractField newInstance()
235 {
236 return new ExtractFieldImpl();
237 }
238
239 /**
240 * Constructs a new instance of {@link ExtractField}, taking all required and/or
241 * read-only properties as arguments, except for identifiers.
242 * @param extractFieldNm String
243 * @param extractFieldRank Integer
244 * @param objectType ObjectType
245 * @param extractFilter ExtractFilter
246 * @return newInstance
247 */
248 public static ExtractField newInstance(String extractFieldNm, Integer extractFieldRank, ObjectType objectType, ExtractFilter extractFilter)
249 {
250 final ExtractField entity = new ExtractFieldImpl();
251 entity.setExtractFieldNm(extractFieldNm);
252 entity.setExtractFieldRank(extractFieldRank);
253 entity.setObjectType(objectType);
254 entity.setExtractFilter(extractFilter);
255 return entity;
256 }
257
258 /**
259 * Constructs a new instance of {@link ExtractField}, taking all possible properties
260 * (except the identifier(s))as arguments.
261 * @param extractFieldNm String
262 * @param extractFieldRank Integer
263 * @param extractFieldSortType String
264 * @param updateDt Timestamp
265 * @param objectType ObjectType
266 * @param extractFilter ExtractFilter
267 * @return newInstance ExtractField
268 */
269 public static ExtractField newInstance(String extractFieldNm, Integer extractFieldRank, String extractFieldSortType, Timestamp updateDt, ObjectType objectType, ExtractFilter extractFilter)
270 {
271 final ExtractField entity = new ExtractFieldImpl();
272 entity.setExtractFieldNm(extractFieldNm);
273 entity.setExtractFieldRank(extractFieldRank);
274 entity.setExtractFieldSortType(extractFieldSortType);
275 entity.setUpdateDt(updateDt);
276 entity.setObjectType(objectType);
277 entity.setExtractFilter(extractFilter);
278 return entity;
279 }
280 }
281
282 /**
283 * @see Comparable#compareTo
284 */
285 public int compareTo(ExtractField o)
286 {
287 int cmp = 0;
288 if (this.getExtractFieldId() != null)
289 {
290 cmp = this.getExtractFieldId().compareTo(o.getExtractFieldId());
291 }
292 else
293 {
294 if (this.getExtractFieldNm() != null)
295 {
296 cmp = (cmp != 0 ? cmp : this.getExtractFieldNm().compareTo(o.getExtractFieldNm()));
297 }
298 if (this.getExtractFieldRank() != null)
299 {
300 cmp = (cmp != 0 ? cmp : this.getExtractFieldRank().compareTo(o.getExtractFieldRank()));
301 }
302 if (this.getExtractFieldSortType() != null)
303 {
304 cmp = (cmp != 0 ? cmp : this.getExtractFieldSortType().compareTo(o.getExtractFieldSortType()));
305 }
306 if (this.getUpdateDt() != null)
307 {
308 cmp = (cmp != 0 ? cmp : this.getUpdateDt().compareTo(o.getUpdateDt()));
309 }
310 }
311 return cmp;
312 }
313 // HibernateEntity.vsl merge-point
314 // ExtractField.java merge-point
315 }