/** * 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_vitalsign_results") @NamedQueries({ @NamedQuery(name = "CcrVitalSignResult.findById", query = "SELECT m FROM CcrVitalSignResult m WHERE m.id = :Id "), @NamedQuery(name = "CcrVitalSignResult.findByHealthRecordId", query = "SELECT m FROM CcrVitalSignResult m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id = :healthRecordId "), @NamedQuery(name = "CcrVitalSignResult.countByHealthRecordId", query = "SELECT COUNT(m) FROM CcrVitalSignResult m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id= :healthRecordId"), @NamedQuery(name = "CcrVitalSignResult.countByHealthRecordIdAndVitalType", query = "SELECT COUNT(m) FROM CcrVitalSignResult m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id = :healthRecordId AND m.descriptionText = :vitalType"), @NamedQuery(name = "CcrVitalSignResult.findByHealthRecordIdAndVitalType", query = "SELECT m FROM CcrVitalSignResult m JOIN m.ccrDocument c JOIN c.healthRecords h WHERE h.id = :healthRecordId AND m.descriptionText = :vitalType") }) public class CcrVitalSignResult extends GenericResult implements Serializable { private static final long serialVersionUID = 20091128L; @Id @GeneratedValue(strategy = GenerationType.AUTO) @Column(name = "ccr_vitalsign_result_id") protected Long id; @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL) @JoinTable(name = "rec_ccr_vitalsign_results_datetime", joinColumns = { @JoinColumn(name = "ccr_vitalsign_result_id")}, inverseJoinColumns = { @JoinColumn(name = "datetime_id")}) protected List<CcrDateTime> dateTime; @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL) @JoinTable(name = "rec_ccr_vitalsign_results_tests", joinColumns = { @JoinColumn(name = "ccr_vitalsign_result_id")}, inverseJoinColumns = { @JoinColumn(name = "ccr_vitalsign_test_id")}) protected List<CcrVitalSignTest> vitalSignTests; @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL,mappedBy="vitalSignResult") protected List <CcrVitalSignResultSource> sources; @Transient private Date exactDateTime; @Transient private String source; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public List<CcrVitalSignResultSource> getSources() { return sources; } public void setSources(List<CcrVitalSignResultSource> sources) { this.sources = sources; } public List<CcrVitalSignTest> getVitalSignTests() { return vitalSignTests; } public void setVitalSignTests(List<CcrVitalSignTest> vitalSignTests) { this.vitalSignTests = vitalSignTests; } public void setDateTime(List<CcrDateTime> dateTime) { this.dateTime = dateTime; } public List<CcrDateTime> getDateTime() { return dateTime; } //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 String toString() { return ToStringBuilder.reflectionToString(this); } @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 CcrVitalSignResult)) { return false; } CcrVitalSignResult other = (CcrVitalSignResult) object; if ((this.id == null && other.id != null) || (this.id != null && !this.id.equals(other.id))) { return false; } return true; } @Override public int hashCode() { int hash = 0; hash += (id != null ? id.hashCode() : 0); return hash; } }