[Okta Webinar] Learn how to a build a cloud-first strategyRegister Now

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 2703
  • Last Modified:

Calculate age on JSP page

I am trying to change the patient age on a page to show up relative to the collection date (instead of the current date).  I have available
 patientDemographics.patient.dob 

Open in new window

and
encounter.collectionDetails.collectionDate

Open in new window

.

This is how the age is currently rendered:
<li class="report-age h5 bold">${patientDemographics.patient.age} <c:if test="${patientDemographics.patient.age != 'n/a'}" >yrs</c:if></li>

Open in new window


I see the collection date being rendered this way:
<fmt:formatDate value="${encounter.collectionDetails.collectionDate}"  pattern="MM/dd/yyyy"/>

Open in new window


My question:  how do I use JSTL or something else to do this in a "clean" way on this JSP page?  (The POJOs related to this make it not so simple to try to do in, e.g., the Patient class)

I.e. the goal is to show the age as an integer based on:
collection date - date of birth
0
marklorenz
Asked:
marklorenz
  • 5
  • 4
1 Solution
 
ChristoferDutzCommented:
Have you had a look at this link?
http://forums.sun.com/thread.jspa?threadID=5272365

Sems it deals with exactly your problem.
0
 
marklorenzAuthor Commented:
Yeah, I had looked at that, but they are relying on code in the Patient class - in my system, patient doesn't have the other date for the calculation.  I'm trying to stay local to the JSP...
0
 
ChristoferDutzCommented:
I would strongly disencourage you to actually perform the calculation in the JSP itself. Have a look at this link:
http://stackoverflow.com/questions/102964/jstl-collection-iteration

Here they describe how you can register an EL Function. EL functions allow you to call a public static method in a public class.
This way you could do the calculation in a separate class and use the result in your JSP.
0
VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

 
marklorenzAuthor Commented:
Yeah I had seen that reallly nice post on stack overflow.  Again, the only issue is that I don't have the information available.  I am trying to avoid changes to my POJOs.  I see multiple ways if I do that work.  This would be the most straightforward, possibly this?


<fmt:formatNumber type="number" maxIntegerDigits="3" 
 value="${encounter.collectionDetails.collectionDate  - patientDemographics.patient.dob” />

Open in new window

0
 
ChristoferDutzCommented:
Well you wouldn't have changed a single class. You would have added one to your project without changing anything else.

If you want, you could to this:
(encounter.collectionDetails.collectionDate.getTime() - patientDemographics.patient.dob.getTime())/(1000*60*60*24*365)
This converts every date to its millisecs, calculates the difference and then calculates the number of years ... but this is a really rough calculation ... I would certainly recommend to use Javas Calendar class, as this does really good date calculations.
0
 
marklorenzAuthor Commented:
This is a bit less than ideal, but I am on the Calendar path.  Will see if it works...
//Calculate age for results pages based on (collection date - patient DOB)
	int ageInYears;
	String ageAtCollection = "n/a";
	Calendar collectionDate = Calendar.getInstance().setTime(encounter.getCollectionDetails().getCollectionDate());
	Calendar birthDate =  = Calendar.getInstance().setTime(encounter.getPatient().getDob());
	
	if (birthDate != null){
		Date patientDob = this.dob;
		birthDate.setTime(patientDob);
		ageInYears = collectionDate.get(Calendar.YEAR) - birthDate.get(Calendar.YEAR);		
		if ((birthDate.get(Calendar.MONTH) > collectionDate.get(Calendar.MONTH))
				|| (birthDate.get(Calendar.MONTH) == collectionDate.get(Calendar.MONTH) && birthDate.get(Calendar.DAY_OF_MONTH) > collectionDate
					.get(Calendar.DAY_OF_MONTH))) {
			ageInYears--;
			}			
		ageAtCollection = Integer.toString(ageInYears) + " yrs";
	}		
%>
<%=ageAtCollection%>

Open in new window

0
 
ChristoferDutzCommented:
Why exactly are you setting the birthDate in line 5 and are then re-setting it in line 9? But otherwise it looks pretty much like correct and should do for your task.
0
 
marklorenzAuthor Commented:
5 gets me a calendar, 9 sets date/time as i want
Guess a different constructor could have done that...
0
 
ChristoferDutzCommented:
If your problem is solved, it would be great if you would close this question, as the thread has gone to my "second tab" and I won't directly see any changes anymore. If you still have problems I'll do my best to assist you.
0

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

  • 5
  • 4
Tackle projects and never again get stuck behind a technical roadblock.
Join Now