/** * 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.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.NamedQueries; import javax.persistence.NamedQuery; import javax.persistence.OneToMany; import javax.persistence.Table; import javax.persistence.Transient; import org.apache.commons.lang.builder.ToStringBuilder; /** * * @author chaz */ @Entity @Table(name="phr.rec_ccr_result_results") @NamedQueries({ @NamedQuery(name = "CcrResult.findById", query = "SELECT m FROM CcrResult m WHERE m.id = :Id "), @NamedQuery(name = "CcrResult.findByHealthRecordId", query = "SELECT m FROM CcrResult m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id = :healthRecordId "), @NamedQuery(name = "CcrResult.countByHealthRecordId", query = "SELECT COUNT(m) FROM CcrResult m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id= :healthRecordId") }) public class CcrResult extends GenericResult implements Serializable { private static final long serialVersionUID = 20091128L; @Id @GeneratedValue(strategy = GenerationType.AUTO) @Column(name = "ccr_results_result_id") protected Long id; @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL) @JoinTable(name = "rec_ccr_result_results_tests", joinColumns = { @JoinColumn(name = "ccr_results_result_id")}, inverseJoinColumns = { @JoinColumn(name = "ccr_results_test_id")}) protected List<CcrResultTest> resultTests; @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL) @JoinTable(name = "rec_ccr_result_results_datetime", joinColumns = { @JoinColumn(name = "ccr_results_result_id")}, inverseJoinColumns = { @JoinColumn(name = "datetime_id")}) protected List<CcrDateTime> dateTime; @Column(name="laboratory_name") protected String laboratoryName; @Column(name="notes") protected String notes; @Column(name="ordered_by") protected String orderedBy; @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL,mappedBy="result") protected List<CcrResultSource> sources; @Transient private Date exactDateTime; @Transient private String source; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public List<CcrResultSource> getSources() { return sources; } public void setSources(List<CcrResultSource> sources) { this.sources = sources; } public List<CcrDateTime> getDateTime() { return dateTime; } public void setDateTime(List<CcrDateTime> dateTime) { this.dateTime = dateTime; } public String getLaboratoryName() { return laboratoryName; } public void setLaboratoryName(String laboratoryName) { this.laboratoryName = laboratoryName; } public String getNotes() { return notes; } public void setNotes(String notes) { this.notes = notes; } public String getOrderedBy() { return orderedBy; } public void setOrderedBy(String orderedBy) { this.orderedBy = orderedBy; } public List<CcrResultTest> getResultTests() { return resultTests; } public void setResultTests(List<CcrResultTest> resultTests) { this.resultTests = resultTests; } //custom getters //note Date Added custom getter has been extracted to parent class public Date getExactDateTime() { if (exactDateTime == null) { try { exactDateTime = dateTime.get(0).getExactDateTime(); } catch (Exception ex) { exactDateTime = null; } } 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 CcrResult)) { return false; } CcrResult other = (CcrResult) object; if ((this.id == null && other.id != null) || (this.id != null && !this.id.equals(other.id))) { return false; } return true; } @Override public String toString() { return ToStringBuilder.reflectionToString(this); } }