fixes bug #7679 - revert

git-svn-id: http://desenvolvimento.rjconsultores.com.br/repositorio/sco/AdmVenta/Model/trunk/modelWeb@59164 d1611594-4594-4d17-8e1d-87c2c4800839
master
edgar 2016-08-16 14:26:43 +00:00
parent f2a902765b
commit b66af469bd
1 changed files with 24 additions and 23 deletions

View File

@ -8,7 +8,6 @@ import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
@ -34,7 +33,6 @@ import com.rjconsultores.ventaboletos.dao.CorridaDAO;
import com.rjconsultores.ventaboletos.dao.EsquemaCorridaDAO;
import com.rjconsultores.ventaboletos.dao.TramoTiempoDAO;
import com.rjconsultores.ventaboletos.entidad.AsientoExclusivo;
import com.rjconsultores.ventaboletos.entidad.Ciudad;
import com.rjconsultores.ventaboletos.entidad.ClaseServicio;
import com.rjconsultores.ventaboletos.entidad.Constante;
import com.rjconsultores.ventaboletos.entidad.Corrida;
@ -412,6 +410,7 @@ public class CorridaServiceImpl implements CorridaService {
* @return - La corrida generada o null si no fue generada.
*/
private Corrida generarCorrida(EsquemaCorrida esquemaCorrida, Date dataGeracao, boolean isPisoExtra, Boolean isFeriado) {
GregorianCalendar calendario = new GregorianCalendar();
calendario.setTime(dataGeracao);
@ -744,33 +743,34 @@ public class CorridaServiceImpl implements CorridaService {
private Date calcularHusoHorVeranoLlegada(EsquemaTramo esquemaTramo, CorridaTramo corridaTramo) {
Ciudad ciudadOrigem = esquemaTramo.getTramo().getOrigem().getCiudad();
int tiempoOrigen = ciudadOrigem.getZonaHoraria() != null ? ciudadOrigem.getZonaHoraria()
: ciudadOrigem.getEstado().getTiempoHorHuso() != null ? ciudadOrigem.getEstado().getTiempoHorHuso() : 0;
Estado estadoOrigen = esquemaTramo.getTramo().getOrigem().getCiudad().getEstado();
int tiempoOrigen = estadoOrigen.getTiempoHorHuso() == null ? 0 : estadoOrigen.getTiempoHorHuso();
Date fecInicioHorVerano = ciudadOrigem.getEstado().getFecInicioHorVerano();
Date fecFinHorVerano = ciudadOrigem.getEstado().getFecFinoHorVerano();
Date fecInicioHorVerano = estadoOrigen.getFecInicioHorVerano();
Date fecFinHorVerano = estadoOrigen.getFecFinoHorVerano();
if (fecInicioHorVerano != null
&& fecFinHorVerano != null
&& DateUtil.compareOnlyDate(fecInicioHorVerano, corridaTramo.getFechorsalida()) <= 0
&& DateUtil.compareOnlyDate(fecFinHorVerano, corridaTramo.getFechorsalida()) >= 0) {
tiempoOrigen += ciudadOrigem.getEstado().getTiempoHorVerano();
if ((fecInicioHorVerano != null) && (fecFinHorVerano != null)) {
if ((DateUtil.compareOnlyDate(fecInicioHorVerano, corridaTramo.getFechorsalida()) <= 0) && (DateUtil.compareOnlyDate(fecFinHorVerano, corridaTramo.getFechorsalida()) >= 0)) {
tiempoOrigen += estadoOrigen.getTiempoHorVerano();
}
}
// 21688
Ciudad ciudadDestino = esquemaTramo.getTramo().getDestino().getCiudad();
int tiempoDestino = ciudadDestino.getZonaHoraria() != null ? ciudadDestino.getZonaHoraria()
: ciudadDestino.getEstado().getTiempoHorHuso() != null ? ciudadDestino.getEstado().getTiempoHorHuso() : 0;
Estado estadoDestino = esquemaTramo.getTramo().getDestino().getCiudad().getEstado();
int tiempoDestino = 0;
Date fecInicioHorVeranoDestino = ciudadDestino.getEstado().getFecInicioHorVerano();
Date fecFinHorVeranDestino = ciudadDestino.getEstado().getFecFinoHorVerano();
if (!estadoDestino.equals(estadoOrigen)) {
tiempoDestino = estadoDestino.getTiempoHorHuso() == null ? 0 : estadoDestino.getTiempoHorHuso();
if (fecInicioHorVeranoDestino != null
&& fecFinHorVeranDestino != null
&& DateUtil.compareOnlyDate(fecInicioHorVeranoDestino, corridaTramo.getFechorllegada()) <= 0
&& DateUtil.compareOnlyDate(fecFinHorVeranDestino, corridaTramo.getFechorllegada()) >= 0) {
tiempoDestino += ciudadDestino.getEstado().getTiempoHorVerano();
Date fecInicioHorVeranoDestino = estadoDestino.getFecInicioHorVerano();
Date fecFinHorVeranDestino = estadoDestino.getFecFinoHorVerano();
if ((fecInicioHorVeranoDestino != null) && (fecFinHorVeranDestino != null)) {
if ((DateUtil.compareOnlyDate(fecInicioHorVeranoDestino, corridaTramo.getFechorllegada()) <= 0) && (DateUtil.compareOnlyDate(fecFinHorVeranDestino, corridaTramo.getFechorllegada()) >= 0)) {
tiempoDestino += estadoDestino.getTiempoHorVerano();
}
}
} else {
tiempoDestino = tiempoOrigen;
}
Calendar horLlegada = null;
@ -784,6 +784,7 @@ public class CorridaServiceImpl implements CorridaService {
horLlegada.add(Calendar.MINUTE, (int) elapsedMinutes);
if (tiempoOrigen != tiempoDestino) {
horLlegada.add(Calendar.HOUR, difHuso(tiempoOrigen, tiempoDestino));
}
return (horLlegada == null) ? null : horLlegada.getTime();