/** * Copyright (C) 2012 KRM Associates, Inc. healtheme@krminc.com * * Licensed 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. */ /* * To change this template, choose Tools | Templates * and open the template in the editor. */ package com.krminc.phr.domain.clinical; import java.io.Serializable; import java.util.Date; import java.util.List; import javax.persistence.AttributeOverride; import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.JoinTable; import javax.persistence.ManyToOne; import javax.persistence.NamedQueries; import javax.persistence.NamedQuery; import javax.persistence.OneToMany; import javax.persistence.Table; import javax.persistence.Transient; import org.apache.commons.lang.builder.StandardToStringStyle; import org.apache.commons.lang.builder.ToStringBuilder; /** * * @author chaz */ @Entity @Table(name = "phr.rec_ccr_vitalsign_tests") @NamedQueries({ @NamedQuery(name = "CcrVitalSignTest.findById", query = "SELECT m FROM CcrVitalSignTest m WHERE m.id = :Id "), @NamedQuery(name = "CcrVitalSignTest.findByHealthRecordId", query = "SELECT m FROM CcrVitalSignTest m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id = :healthRecordId "), @NamedQuery(name = "CcrVitalSignTest.countByHealthRecordId", query = "SELECT COUNT(m) FROM CcrVitalSignTest m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id= :healthRecordId"), @NamedQuery(name = "CcrVitalSignTest.countByHealthRecordIdAndVitalType", query = "SELECT COUNT(m) FROM CcrVitalSignTest m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id = :healthRecordId AND m.descriptionText = :vitalType"), @NamedQuery(name = "CcrVitalSignTest.findByHealthRecordIdAndVitalType", query = "SELECT m FROM CcrVitalSignTest m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id = :healthRecordId AND m.descriptionText = :vitalType") }) @AttributeOverride(name = "generic_id", column = @Column(name = "ccr_vitalsign_test_id")) public class CcrVitalSignTest extends GenericResultTest implements Serializable { private static final long serialVersionUID = 20091128L; @Id @GeneratedValue(strategy = GenerationType.AUTO) @Column(name = "ccr_vitalsign_test_id") protected Long id; @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL) @JoinTable(name = "rec_ccr_vitalsign_tests_datetime", joinColumns = { @JoinColumn(name = "ccr_vitalsign_test_id")}, inverseJoinColumns = { @JoinColumn(name = "datetime_id")}) protected List<CcrDateTime> dateTime; @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL, mappedBy = "vitalSignTest") protected List<CcrVitalSignTestSource> sources; //maintain Id field integrity and ensure the mapping to parent result isn't updatable @ManyToOne(fetch = FetchType.LAZY, targetEntity = CcrVitalSignResult.class) @JoinColumn(name = "ccr_vitalsign_test_id", nullable = false, insertable = false, updatable = false) protected CcrVitalSignResult ccrResult; @Transient private Date exactDateTime; @Transient private String source; public List<CcrVitalSignTestSource> getSources() { return sources; } public void setSources(List<CcrVitalSignTestSource> sources) { this.sources = sources; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public List<CcrDateTime> getDateTime() { return dateTime; } public void setDateTime(List<CcrDateTime> dateTime) { this.dateTime = dateTime; } //custom getters //note Date Added custom getter has been extracted to parent class public Date getExactDateTime() { if (exactDateTime == null) { Date tempDateTime = new Date(); try { tempDateTime = dateTime.get(0).getExactDateTime(); } catch (Exception ex) { tempDateTime = null; } //no test-level dateTime, pull from parent Result entity if (tempDateTime == null) { try { tempDateTime = ccrResult.getExactDateTime(); } catch (Exception ex) { tempDateTime = null; } } exactDateTime = tempDateTime; } return exactDateTime; } public String getSource() { if (source == null) { try { source = sources.get(0).getActor().getInformationSystemName(); } catch (Exception ex) { source = null; } } return source; } @Override public int hashCode() { int hash = 0; hash += (id != null ? id.hashCode() : 0); return hash; } @Override public boolean equals(Object object) { // TODO: Warning - this method won't work in the case the id fields are not set if (!(object instanceof CcrVitalSignTest)) { return false; } CcrVitalSignTest other = (CcrVitalSignTest) object; if ((this.id == null && other.id != null) || (this.id != null && !this.id.equals(other.id))) { return false; } return true; } @Override public String toString() { final StandardToStringStyle style = new StandardToStringStyle(); style.setNullText("---NULL---"); style.setFieldSeparator(";\n"); style.setArrayStart("{{{"); style.setArrayEnd("}}}"); style.setArraySeparator("|"); style.setFieldNameValueSeparator(":"); return ToStringBuilder.reflectionToString(this, style); } }