PRICING - Ocupação | Antecipação (fixes bug #5836)

Tempo: 09 horas

git-svn-id: http://desenvolvimento.rjconsultores.com.br/repositorio/sco/AdmVenta/Web/trunk/ventaboletos@44543 d1611594-4594-4d17-8e1d-87c2c4800839
master
julio 2015-05-29 21:07:07 +00:00
parent 59d211b73f
commit 64f9dfe40f
5 changed files with 84 additions and 35 deletions

View File

@ -103,5 +103,6 @@
<attribute name="owner.project.facets" value="java"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="C:/Users/rjgw/Documents/library/log4jdbc4-1.2.jar"/>
<classpathentry kind="output" path="build/classes"/>
</classpath>

View File

@ -21,6 +21,7 @@ import org.zkoss.zul.Radio;
import com.rjconsultores.ventaboletos.entidad.Pricing;
import com.rjconsultores.ventaboletos.entidad.PricingOcupaAntecipa;
import com.rjconsultores.ventaboletos.exception.BusinessException;
import com.rjconsultores.ventaboletos.service.PricingOcupaAntecipaService;
import com.rjconsultores.ventaboletos.utilerias.UsuarioLogado;
import com.rjconsultores.ventaboletos.web.utilerias.ConstraintPorcentagem;
@ -45,9 +46,11 @@ public class EditarPricingOcupaAntecipaAutomaticoController extends MyGenericFor
private Intbox ocupacioninicial;
private Intbox ocupacionfinal;
private Intbox cantdiasmin;
private MyTextboxDecimal porcentaje;
private List<PricingOcupaAntecipa> lsPricingOcupaAntecipa;
private List<PricingOcupaAntecipa> novaListaPricingOcupaAntecipa;
private Radio rdOcupacao;
private Boolean hasNoElements;
@ -63,13 +66,22 @@ public class EditarPricingOcupaAntecipaAutomaticoController extends MyGenericFor
/*
* Transformar a tabela (valores de exemplo) :
*
* Qtd. Dias Qtd. Dias Ocup. Min. Ocup. Máx. Porcentagem Minimo Máximo
* Qtd. Dias Qtd. Dias Ocup. Min. Ocup. Máx. Porcentagem
* Minimo Máximo
*
* 12 * 0% 20% -30% 12 * 21% 80% -15% 12 * 81% 90% -10% 8 11 0% 80% -15% 8 11 81% 90% -10% 4 7 0% 90% -10%
* 12 * 0% 20% -30%
* 12 * 21% 80% -15%
* 12 * 81% 90% -10%
* 8 11 0% 80% -15%
* 8 11 81% 90% -10%
* 4 7 0% 90% -10%
*
* Na forma:
*
* 12 dias ----> 30% (ocupação de 0% -> 20%) 08 dias ----> 15% (ocupação de 21% -> 80%) 04 dias ----> 10% (ocupação de 81% -> 90%)
* 12 dias ----> 30% (ocupação de 0% -> 20%)
* 08 dias ----> 15% (ocupação de 21% -> 80%)
* 04 dias ----> 10% (ocupação de 81% -> 90%)
*
*/
argList = (List<PricingOcupaAntecipa>) Executions.getCurrent().getArg().get("clasePricingOcupaAntecipaList");
@ -77,12 +89,10 @@ public class EditarPricingOcupaAntecipaAutomaticoController extends MyGenericFor
pricing = (Pricing) Executions.getCurrent().getArg().get("pricing");
pricingOcupaAntecipaList.setItemRenderer(new RenderPricingOcupaAntecipa());
lsPricingOcupaAntecipa = new ArrayList<PricingOcupaAntecipa>();
novaListaPricingOcupaAntecipa = new ArrayList<PricingOcupaAntecipa>();
try {
Collections.sort(argList, Collections.reverseOrder(new PricingOcupaAntecipaComparator()));
} catch (Exception e) {
e.printStackTrace();
Messagebox.show(Labels.getLabel("editarPricingOcupaAntecipaAutomaticoController.MSG.FormatoDados"),
Labels.getLabel("editarPricingController.windowOcupacion.title"),
Messagebox.OK, Messagebox.EXCLAMATION);
@ -93,13 +103,9 @@ public class EditarPricingOcupaAntecipaAutomaticoController extends MyGenericFor
int diaMin = -1;
for (PricingOcupaAntecipa p : argList) {
if (p.getCantdiasmin() != null) {
if (diaMin != p.getCantdiasmin()) {
lsPricingOcupaAntecipa.add(p);
diaMin = p.getCantdiasmin();
}
} else {
if (diaMin != p.getCantdiasmin()) {
lsPricingOcupaAntecipa.add(p);
diaMin = p.getCantdiasmin();
}
}
@ -122,19 +128,46 @@ public class EditarPricingOcupaAntecipaAutomaticoController extends MyGenericFor
}
}
private void apagarRegistros() throws BusinessException {
for (PricingOcupaAntecipa poa : argList) {
if ((poa.getOcupacioninicial() != null && poa.getOcupacioninicial().doubleValue() > 0) || (poa.getCantasientosmin() != null && poa.getCantasientosmin().intValue() > 0)) {
pricingOcupaAntecipaService.borrar(poa);
}
}
}
public void onClick$btnAdicionarOcupaAntecipa(Event ev) throws Exception {
List<PricingOcupaAntecipa> parentList = new ArrayList<PricingOcupaAntecipa>();
calculaCantDiasMax();
try {
for (PricingOcupaAntecipa poa : novaListaPricingOcupaAntecipa) {
if (poa.getPricingocupaantecipaId() == null) {
pricingOcupaAntecipaService.suscribir(poa);
apagarRegistros();
for (int i = 0; i < lsPricingOcupaAntecipa.size(); i++) {
lsPricingOcupaAntecipa.get(i).setOcupacioninicial(new BigDecimal(0));
if (lsPricingOcupaAntecipa.get(i).getPricingocupaantecipaId() == null) {
pricingOcupaAntecipaService.suscribir(lsPricingOcupaAntecipa.get(i));
} else {
pricingOcupaAntecipaService.actualizacion(poa);
pricingOcupaAntecipaService.actualizacion(lsPricingOcupaAntecipa.get(i));
}
parentList.add(lsPricingOcupaAntecipa.get(i));
for (int j = i + 1; j < lsPricingOcupaAntecipa.size(); j++) {
PricingOcupaAntecipa p = new PricingOcupaAntecipa();
p.setPricingocupaantecipaId(lsPricingOcupaAntecipa.get(j).getPricingocupaantecipaId());
p.setCantasientosmax(lsPricingOcupaAntecipa.get(j).getCantasientosmax());
p.setCantasientosmin(lsPricingOcupaAntecipa.get(j).getCantasientosmin());
p.setCantdiasmax(lsPricingOcupaAntecipa.get(i).getCantdiasmax());
p.setCantdiasmin(lsPricingOcupaAntecipa.get(i).getCantdiasmin());
p.setOcupacionfinal(lsPricingOcupaAntecipa.get(j).getOcupacionfinal());
p.setOcupacioninicial(lsPricingOcupaAntecipa.get(j).getOcupacioninicial());
p.setPorcentaje(lsPricingOcupaAntecipa.get(j).getPorcentaje());
p.setPricing(pricing);
pricingOcupaAntecipaService.suscribir(p);
parentList.add(p);
}
}
parentPricingOcupaAntecipaList.setData(lsPricingOcupaAntecipa);
parentPricingOcupaAntecipaList.setData(parentList);
closeWindow();
} catch (Exception e) {
Messagebox.show(e.getLocalizedMessage(),
@ -145,23 +178,41 @@ public class EditarPricingOcupaAntecipaAutomaticoController extends MyGenericFor
private class PricingOcupaAntecipaComparator implements Comparator<PricingOcupaAntecipa> {
public int compare(PricingOcupaAntecipa pricing, PricingOcupaAntecipa outroPricing) {
if (pricing.getCantdiasmin() != null && outroPricing.getCantdiasmin() != null) {
return pricing.getCantdiasmin().compareTo(outroPricing.getCantdiasmin());
} else if (pricing.getOcupacioninicial() != null && outroPricing.getOcupacioninicial() != null) {
return pricing.getOcupacioninicial().compareTo(outroPricing.getOcupacioninicial());
return pricing.getCantdiasmin().
compareTo(outroPricing.getCantdiasmin());
}
}
private void calculaCantDiasMax() {
Collections.sort(lsPricingOcupaAntecipa, Collections.reverseOrder(new PricingOcupaAntecipaComparator()));
PricingOcupaAntecipa poa;
int cantDiasMinAnterior = lsPricingOcupaAntecipa.get(0).getCantdiasmin();
for (int i = 0; i < lsPricingOcupaAntecipa.size(); i++) {
poa = lsPricingOcupaAntecipa.get(i);
if (i == 0) {
poa.setCantdiasmax(CANTDIASMAXDEFAULT);
} else {
poa.setCantdiasmax(cantDiasMinAnterior - 1);
cantDiasMinAnterior = poa.getCantdiasmin();
}
return -1;
}
}
public void onClick$btnlancar(Event ev) throws Exception {
for (PricingOcupaAntecipa poa : lsPricingOcupaAntecipa) {
if (poa.getCantdiasmin().equals(cantdiasmin.getValue())) {
Messagebox.show(Labels.getLabel("editarPricingAutomaticoController.msg.cantDias.erro"),
Labels.getLabel("editarPricingController.windowOcupacion.title"),
Messagebox.OK, Messagebox.EXCLAMATION);
return;
}
}
PricingOcupaAntecipa poa = new PricingOcupaAntecipa();
poa.setPricing(pricing);
poa.setCantdiasmin(cantdiasmin.getValue());
poa.setPorcentaje(porcentaje.getValueDecimal());
poa.setCantdiasmax(CANTDIASMAXDEFAULT);
if (rdOcupacao.isChecked()) {
poa.setOcupacioninicial(new BigDecimal(ocupacioninicial.getValue()));
poa.setOcupacionfinal(new BigDecimal(ocupacionfinal.getValue()));
@ -170,8 +221,6 @@ public class EditarPricingOcupaAntecipaAutomaticoController extends MyGenericFor
poa.setCantasientosmax(ocupacionfinal.getValue());
}
novaListaPricingOcupaAntecipa.add(poa);
lsPricingOcupaAntecipa.add(poa);
pricingOcupaAntecipaList.setData(lsPricingOcupaAntecipa);
}

View File

@ -37,9 +37,6 @@ public class StringDecimalToDecimalConverter implements TypeConverter {
}
if (val instanceof String) {
System.out.println(val.toString());
return (val.toString().trim().isEmpty()) ? (BigDecimal) null : new BigDecimal(val.toString().replace(".", "").replace(",", "."));
}
return null;

View File

@ -2420,6 +2420,7 @@ editarPricingAutomaticoController.columnaPorcentaje.label = Porcentaje
editarPricingAutomaticoController.columnaOcupacionMin.label = Ocupación Min.
editarPricingAutomaticoController.columnaOcupacionMax.label = Ocupación Máx.
editarPricingAutomaticoController.windowOcupacion.title = Ocupación automática
editarPricingAutomaticoController.msg.cantDias.erro = Ya existe en el sistema es la misma cantidad de días registrados
# Editar Pricing Especifico Ocupacion
editarPricingEspecificoOcupacionController.tarifa.label=Tasa

View File

@ -2475,6 +2475,7 @@ editarPricingAutomaticoController.columnaPorcentaje.label = Porcentagem
editarPricingAutomaticoController.columnaOcupacionMin.label = Ocup. Min.
editarPricingAutomaticoController.columnaOcupacionMax.label = Ocup. Máx.
editarPricingAutomaticoController.windowOcupacion.title = Ocupação Automática
editarPricingAutomaticoController.msg.cantDias.erro = Já existe no sistema está mesma quantidade de dias cadastrada
# Editar Pricing Especifico Ocupacion
editarPricingEspecificoOcupacionController.tarifa.label=Tarifa