* The contents of this file are subject to the Mozilla Public License Version 1.1
* See LICENSE.TXT at the top of this package for the full license terms.
*/
-
package eu.etaxonomy.cdm.model.agent;
import java.io.Serializable;
import java.net.URI;
import java.util.ArrayList;
+import java.util.Collection;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import javax.persistence.Embeddable;
import javax.persistence.FetchType;
import javax.persistence.OneToMany;
+import javax.persistence.Transient;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlSchemaType;
import javax.xml.bind.annotation.XmlType;
-import org.apache.commons.lang.StringUtils;
+import org.apache.commons.lang3.StringUtils;
import org.apache.log4j.Logger;
import org.hibernate.annotations.Cascade;
import org.hibernate.annotations.CascadeType;
* </ul>
*
* @author m.doering
- * @version 1.0
- * @created 08-Nov-2007 13:06:18
+ * @since 08-Nov-2007 13:06:18
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "Contact", propOrder = {
- "emailaddresses",
+ "emailAddresses",
"urls",
- "phonenumbers",
- "faxnumbers",
+ "phoneNumbers",
+ "faxNumbers",
"addresses"
})
@XmlRootElement(name = "Contact")
@XmlElement(name = "EmailAddress")
@ElementCollection(fetch = FetchType.LAZY)
@Column(name = "contact_emailaddresses_element")
- private List<String> emailaddresses; // TODO #5369 revert to emailAddresses
+ private List<String> emailAddresses = new ArrayList<>();
@XmlElementWrapper(name = "URLs", nillable = true)
@XmlElement(name = "URL")
@XmlSchemaType(name = "anyURI")
@ElementCollection(fetch = FetchType.LAZY)
@Column(name = "contact_urls_element" /*, length=330 */) //length >255 does not work in InnoDB AUD tables for Key length of (REV, id, url) key
- private final List<String> urls = new ArrayList<String>();
+ private final List<String> urls = new ArrayList<>();
@XmlElementWrapper(name = "PhoneNumbers", nillable = true)
@XmlElement(name = "PhoneNumber")
@ElementCollection(fetch = FetchType.LAZY)
@Column(name = "contact_phonenumbers_element")
@Cascade({CascadeType.SAVE_UPDATE, CascadeType.MERGE, CascadeType.DELETE})
- private List<String> phonenumbers; // TODO #5369 revert to phoneNumbers
+ private List<String> phoneNumbers = new ArrayList<>();
@XmlElementWrapper(name = "FaxNumbers", nillable = true)
@XmlElement(name = "FaxNumber")
@ElementCollection(fetch = FetchType.LAZY)
@Column(name = "contact_faxnumbers_element")
- private List<String> faxnumbers; // TODO #5369 revert to faxNumbers
+ private List<String> faxNumbers = new ArrayList<>();
@XmlElementWrapper(name = "Addresses", nillable = true)
@XmlElement(name = "Address")
@OneToMany(fetch = FetchType.LAZY, orphanRemoval=true)
@Cascade({CascadeType.SAVE_UPDATE, CascadeType.MERGE})
- protected Set<Address> addresses = new HashSet<Address>();
+ protected Set<Address> addresses = new HashSet<>();
public static Contact NewInstance() {
return new Contact();
result.addresses = addresses;
}
if (emailAddresses != null){
- result.emailaddresses = emailAddresses;
+ result.emailAddresses = emailAddresses;
}
if (faxNumbers != null){
- result.faxnumbers = faxNumbers;
+ result.faxNumbers = faxNumbers;
}
if (phoneNumbers != null){
- result.phonenumbers = phoneNumbers;
+ result.phoneNumbers = phoneNumbers;
}
if (urls != null){
for (URI uri : urls){
return result;
}
-
+// ************************ CONSTRUCTOR **************************/
/**
* Class constructor.
*/
public Contact() {
}
+// ************************ MERGE /MATCH ***************************/
public void merge(Contact contact2) throws MergeException{
if (contact2 != null){
for (Address address : contact2.getAddresses()){
try {
if (this.addresses == null){
- this.addresses = new HashSet<Address>();
+ this.addresses = new HashSet<>();
}
- this.addresses.add((Address)address.clone());
+ this.addresses.add(address.clone());
} catch (CloneNotSupportedException e) {
throw new MergeException("Address must implement Cloneable");
}
}
}
-
- /**
+ /**
+ * True, if no contact data exists in any of the lists (email, phone, ...).
+ */
+ @Transient
+ public boolean isEmpty(){
+ if (isEmpty(emailAddresses) && isEmpty(faxNumbers) && isEmpty(phoneNumbers)
+ && isEmpty(urls) && isEmpty(addresses)){
+ return true;
+ }else{
+ return false;
+ }
+ }
+
+ private boolean isEmpty(Collection<? extends Object> collection) {
+ return collection == null || collection.isEmpty();
+ }
+
+ /**
* Returns the set of postal {@link Address addresses} belonging to <i>this</i> contact.
* A {@link Person person} or an {@link Institution institution} cannot have more than one contact,
* but a contact may include several postal addresses.
* included in <i>this</i> contact.
*/
public List<String> getEmailAddresses(){
- if(this.emailaddresses == null) {
- this.emailaddresses = new ArrayList<String>();
+ if(this.emailAddresses == null) {
+ this.emailAddresses = new ArrayList<>();
}
- return this.emailaddresses;
+ return this.emailAddresses;
}
/**
* included in <i>this</i> contact.
*/
public List<String> getPhoneNumbers(){
- if(this.phonenumbers == null) {
- this.phonenumbers = new ArrayList<String>();
+ if(this.phoneNumbers == null) {
+ this.phoneNumbers = new ArrayList<>();
}
- return this.phonenumbers;
+ return this.phoneNumbers;
}
/**
* included in <i>this</i> contact.
*/
public List<String> getFaxNumbers(){
- if(this.faxnumbers == null) {
- this.faxnumbers = new ArrayList<String>();
+ if(this.faxNumbers == null) {
+ this.faxNumbers = new ArrayList<>();
}
- return this.faxnumbers;
+ return this.faxNumbers;
}
/**
* @see java.lang.Object#clone()
*/
@Override
- public Object clone() {
+ public Contact clone() {
try{
Contact result = (Contact) super.clone();
- result.addresses = new HashSet<Address>();
+ result.addresses = new HashSet<>();
for (Address adr : this.addresses){
- result.addAddress((Address)adr.clone());
+ result.addAddress(adr.clone());
}
//no changes to emailAdresses, faxnumbers, phonenumbers, urls
return result;
return null;
}
}
-}
\ No newline at end of file
+}