diff --git a/omod/src/main/java/org/openmrs/module/coreapps/fragment/controller/visit/RetrospectiveVisitFragmentController.java b/omod/src/main/java/org/openmrs/module/coreapps/fragment/controller/visit/RetrospectiveVisitFragmentController.java index 31d4a2916..77556c813 100644 --- a/omod/src/main/java/org/openmrs/module/coreapps/fragment/controller/visit/RetrospectiveVisitFragmentController.java +++ b/omod/src/main/java/org/openmrs/module/coreapps/fragment/controller/visit/RetrospectiveVisitFragmentController.java @@ -31,31 +31,30 @@ public Object create(@SpringBean("adtService") AdtService adtService, @RequestParam(value = "stopDate", required = false) Date stopDate, HttpServletRequest request, UiUtils ui) { - // if no stop date, set it to start date - if (stopDate == null) { - stopDate = startDate; - } // set the startDate time component to the start of day startDate = new DateTime(startDate).withTime(0,0,0,0).toDate(); // if stopDate is today, set stopDate to current datetime, otherwise set time component to end of date + if (stopDate != null){ if (new DateTime().withTime(0,0,0,0).equals(new DateTime(stopDate).withTime(0,0,0,0))) { stopDate = new Date(); } else { stopDate = new DateTime(stopDate).withTime(23, 59, 59, 999).toDate(); } + } try { + VisitDomainWrapper createdVisit = adtService.createRetrospectiveVisit(patient, location, startDate, stopDate); - request.getSession().setAttribute(AppUiConstants.SESSION_ATTRIBUTE_INFO_MESSAGE, ui.message("coreapps.retrospectiveVisit.addedVisitMessage")); request.getSession().setAttribute(AppUiConstants.SESSION_ATTRIBUTE_TOAST_MESSAGE, "true"); return SimpleObject.create("success", true, "id", createdVisit.getVisit().getId().toString(), "uuid", createdVisit.getVisit().getUuid()); - } + + } catch (ExistingVisitDuringTimePeriodException e) { // if there are existing visit(s), return these existing visits @@ -70,6 +69,7 @@ public Object create(@SpringBean("adtService") AdtService adtService, } } + return simpleVisits; } catch (Exception e) { diff --git a/omod/src/main/java/org/openmrs/module/coreapps/fragment/controller/visit/VisitDatesFragmentController.java b/omod/src/main/java/org/openmrs/module/coreapps/fragment/controller/visit/VisitDatesFragmentController.java index 361616a0e..925656908 100644 --- a/omod/src/main/java/org/openmrs/module/coreapps/fragment/controller/visit/VisitDatesFragmentController.java +++ b/omod/src/main/java/org/openmrs/module/coreapps/fragment/controller/visit/VisitDatesFragmentController.java @@ -37,12 +37,16 @@ public SimpleObject setDuration(@SpringBean("visitService") VisitService visitSe @RequestParam(value="stopDate", required = false) Date stopDate, HttpServletRequest request, UiUtils ui) { - if (!isSameDay(startDate, visit.getStartDatetime())) { visit.setStartDatetime(new DateTime(startDate).toDateMidnight().toDate()); } - if ( (stopDate!=null) && !isSameDay(stopDate, visit.getStopDatetime())) { + if(stopDate == null){ + + visit.setStopDatetime(null); + + } else if (!isSameDay(stopDate, visit.getStopDatetime())) { + Date now = new DateTime().toDate(); if (isSameDay(stopDate, now)) { visit.setStopDatetime(now); @@ -54,15 +58,16 @@ public SimpleObject setDuration(@SpringBean("visitService") VisitService visitSe .withMillisOfSecond(999) .toDate()); } + } visitService.saveVisit(visit); - + request.getSession().setAttribute(AppUiConstants.SESSION_ATTRIBUTE_INFO_MESSAGE, ui.message("coreapps.editVisitDate.visitSavedMessage")); request.getSession().setAttribute(AppUiConstants.SESSION_ATTRIBUTE_TOAST_MESSAGE, "true"); return SimpleObject.create("success", true, "search", "?patientId=" + visit.getPatient().getId() + "&visitId=" + visit.getId()); - + } } diff --git a/omod/src/main/webapp/fragments/patientdashboard/editVisitDatesDialog.gsp b/omod/src/main/webapp/fragments/patientdashboard/editVisitDatesDialog.gsp index de5747af5..a009dc60f 100644 --- a/omod/src/main/webapp/fragments/patientdashboard/editVisitDatesDialog.gsp +++ b/omod/src/main/webapp/fragments/patientdashboard/editVisitDatesDialog.gsp @@ -21,7 +21,7 @@ defaultDate: config.defaultStartDate ])}

- <% if(config.defaultEndDate != null) { %> + <% if(config.visitEndDate != null) { %>

- ${ ui.includeFragment("uicommons", "field/datetimepicker", [ + <% if(activeVisits){ %> + ${ ui.includeFragment("uicommons", "field/datetimepicker", [ id: "retrospectiveVisitStopDate", formFieldName: "retrospectiveVisitStopDate", label:"", defaultDate: visitEndTime, endDate: editDateFormat.format(visitEndTime), useTime: false, - ])} + ])} + + <% } else { %> + + ${ ui.includeFragment("uicommons", "field/datetimepicker", [ + id: "noActiveVisitStopDate", + formFieldName: "retrospectiveVisitStopDate", + label:"", + defaultDate: null, + endDate: editDateFormat.format(visitEndTime), + useTime: false, + ])} + + <% } %>



diff --git a/omod/src/main/webapp/fragments/patientdashboard/visits.gsp b/omod/src/main/webapp/fragments/patientdashboard/visits.gsp index d8f83640e..3d6b9eb19 100644 --- a/omod/src/main/webapp/fragments/patientdashboard/visits.gsp +++ b/omod/src/main/webapp/fragments/patientdashboard/visits.gsp @@ -103,7 +103,8 @@ startDateLowerLimit: (idx + 1 == visits.size || visits[idx + 1].stopDatetime == null) ? null : editDateFormat.format(org.apache.commons.lang.time.DateUtils.addDays(visits[idx + 1].stopDatetime, 1)), startDateUpperLimit: wrapper.oldestEncounter == null && wrapper.stopDatetime == null ? editDateFormat.format(new Date()) : editDateFormat.format(wrapper.oldestEncounter == null ? wrapper.stopDatetime : wrapper.oldestEncounter.encounterDatetime), defaultStartDate: wrapper.startDatetime, - defaultEndDate: wrapper.stopDatetime + defaultEndDate:idx == 0 ? null : wrapper.stopDatetime, + visitEndDate: wrapper.stopDatetime ]) } ${ ui.includeFragment("coreapps", "patientdashboard/editVisit", [ visit: wrapper.visit, diff --git a/omod/src/main/webapp/resources/scripts/custom/visits.js b/omod/src/main/webapp/resources/scripts/custom/visits.js index d355df181..e9dd36efa 100644 --- a/omod/src/main/webapp/resources/scripts/custom/visits.js +++ b/omod/src/main/webapp/resources/scripts/custom/visits.js @@ -135,8 +135,9 @@ visit.showEditVisitDateDialog = function(visitId) { if (data.success) { jq('#edit-visit-dates-dialog-form-' + visitId + ' .icon-spin').css('display', 'inline-block').parent().addClass('disabled'); // TODO Do we need to update this to specify return url, or is this link only going to ever be used from the old visits view? + data.patientId = visit.patientId; window.location.search = data.search; - } + } } ); return false; diff --git a/omod/src/test/java/org/openmrs/module/coreapps/fragment/controller/visit/RetrospectiveVisitFragmentControllerTest.java b/omod/src/test/java/org/openmrs/module/coreapps/fragment/controller/visit/RetrospectiveVisitFragmentControllerTest.java index 38d8d8a2f..aae19aa35 100644 --- a/omod/src/test/java/org/openmrs/module/coreapps/fragment/controller/visit/RetrospectiveVisitFragmentControllerTest.java +++ b/omod/src/test/java/org/openmrs/module/coreapps/fragment/controller/visit/RetrospectiveVisitFragmentControllerTest.java @@ -95,11 +95,10 @@ public void test_shouldCreateNewRetrospectiveVisit_whenNoStopDateSpecified() thr // should round to the time components to the start and end of the days, respectively Date expectedStartDate = new DateTime(2012, 1, 1, 0, 0, 0, 0).toDate(); - Date expectedStopDate = new DateTime(2012, 1, 1, 23, 59, 59, 999).toDate(); Visit visit = createVisit(); - when(adtService.createRetrospectiveVisit(patient, location, expectedStartDate, expectedStopDate)).thenReturn(new VisitDomainWrapper(visit)); + when(adtService.createRetrospectiveVisit(patient, location, expectedStartDate, null)).thenReturn(new VisitDomainWrapper(visit)); SimpleObject result = (SimpleObject) controller.create(adtService, patient, location, startDate, null, request, ui); @@ -118,7 +117,7 @@ public void test_shouldReturnConflictingVisits() throws Exception { Patient patient = new Patient(); Location location = new Location(); Date startDate = new DateTime(2012, 1, 1, 12, 12, 12).toDate(); - + Date stopDate = startDate; // should round to the time components to the start and end of the days, respectively Date expectedStartDate = new DateTime(2012, 1, 1, 0, 0, 0, 0).toDate(); Date expectedStopDate = new DateTime(2012, 1, 1, 23, 59, 59, 999).toDate(); @@ -135,7 +134,7 @@ public void test_shouldReturnConflictingVisits() throws Exception { when(ui.format(any())).thenReturn("someDate"); - List result = (List) controller.create(adtService, patient, location, startDate, null, request, ui); + List result = (List) controller.create(adtService, patient, location, startDate, stopDate, request, ui); assertThat(result.size(), is(1)); assertThat(result.get(0).toJson(), is("{\"startDate\":\"someDate\",\"stopDate\":\"someDate\",\"id\":null,\"uuid\":\"" + conflictingVisit.getUuid() + "\"}")); diff --git a/omod/src/test/java/org/openmrs/module/coreapps/fragment/controller/visit/VisitDatesFragmentControllerTest.java b/omod/src/test/java/org/openmrs/module/coreapps/fragment/controller/visit/VisitDatesFragmentControllerTest.java index 4d19702f1..7a3cf5572 100644 --- a/omod/src/test/java/org/openmrs/module/coreapps/fragment/controller/visit/VisitDatesFragmentControllerTest.java +++ b/omod/src/test/java/org/openmrs/module/coreapps/fragment/controller/visit/VisitDatesFragmentControllerTest.java @@ -35,7 +35,7 @@ public void setUp() throws Exception { controller = new VisitDatesFragmentController(); visitService = mock(VisitService.class); - + request = mock(HttpServletRequest.class); session = mock(HttpSession.class); when(request.getSession()).thenReturn(session); @@ -76,6 +76,25 @@ public void shouldSetVisitStartAndStopDates() throws Exception { assertThat(actualVisit.getStopDatetime(), is(expectedStopDate)); } + @Test + public void shouldSetVisitStopDateAsNullIfStopDateIsNotSpecified() throws Exception { + Date startDate = (new DateTime(2013, 6, 24, 13, 1, 7)).toDate(); + Date stopDate = null; + + Date expectedStartDate = (new DateTime(2013, 6, 24, 0, 0, 0)).toDate(); + Date expectedStopDate = null; + + Visit visit = new Visit(1); + visit.setStartDatetime(new Date()); + visit.setStopDatetime(new Date()); + visit.setPatient(new Patient(1)); + + controller.setDuration(visitService, visit, startDate, stopDate, request, mock(UiUtils.class)); + + Visit actualVisit = savedVisit(); + assertThat(actualVisit.getStartDatetime(), is(expectedStartDate)); + assertThat(actualVisit.getStopDatetime(), is(expectedStopDate)); + } @Test public void shouldNotChangeStartOrStopDatetimeIfSettingToSameDay() throws Exception { Visit visit = new Visit(1);