maia/.svn/pristine/89/89f6122f1d493e1a673026d689f...

347 lines
12 KiB
Plaintext
Executable File

package com.fp.frontend.controller.armas.solicitud;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import javax.annotation.PostConstruct;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;
import com.fp.dto.AbstractDataTransport;
import com.fp.dto.Request;
import com.fp.dto.Response;
import com.fp.dto.query.DtoQuery;
import com.fp.dto.query.SubQuery;
import com.fp.dto.save.DtoSave;
import com.fp.frontend.controller.AbstractController;
import com.fp.frontend.controller.armas.parametros.util.EstadosSolicitudBPM;
import com.fp.frontend.helper.MessageHelper;
import com.fp.persistence.parmas.soli.TarmSolicitud;
import com.fp.persistence.pcustomer.gene.TcustPersonDetail;
/**
* Clase controladora del bean TarmSolicitud.
*
* @author Jorge Vaca.
* @version 2.1
*/
@SuppressWarnings("serial")
@ManagedBean
@ViewScoped
public class SolicitudArmasController extends AbstractController<TarmSolicitud> {
private List<EstadosSolicitudBPM>listaEstadoSolicitud;
public SolicitudArmasController() throws Exception {
super(TarmSolicitud.class);
}
@PostConstruct
private void postconstruct() {
this.init();
// Inicializa autoconsulta
super.startQuery();
}
/**
* Incializa el controlador, cuando se esta utilizando una pagina que utliza el controlador.
*/
private void init() {
try {
recperpage = 15; // Cambiar al # reg a mirar.
lrecord = new ArrayList<>();
beanalias = "SOLICITUD";
listaEstadoSolicitud= new ArrayList<EstadosSolicitudBPM>();
this.create();
} catch (Exception e) {
MessageHelper.setMessageError(e);
}
}
/**
* Crea una instancia de TgeneTransactionProcess y marca el registro como nuevo.
*
* @throws Exception
*/
@Override
public void create() throws Exception {
super.create();
}
@Override
protected void querydatabase() {
try {
listaEstadoSolicitud = new ArrayList<>();
DtoQuery dto = super.getDtoQuery(true);
dto.setMultirecord(false);
//nombre
SubQuery snombre= new SubQuery
("TcustPersonDetail", "name", "nombre", "i.pk.personcode = t.personcode and i.pk.dateto=(select max(dt.pk.dateto) from TcustPersonDetail dt where dt.pk.personcode=t.personcode)");
SubQuery snumerodocumento= new SubQuery
("TcustPersonDetail", "identification", "identification", "i.pk.personcode = t.personcode and i.pk.dateto=(select max(dt.pk.dateto) from TcustPersonDetail dt where dt.pk.personcode=t.personcode)");
SubQuery identificationcatalog= new SubQuery
("TcustPersonDetail", "identificationcatalog", "identificationcatalog", "i.pk.personcode = t.personcode and i.pk.dateto=(select max(dt.pk.dateto) from TcustPersonDetail dt where dt.pk.personcode=t.personcode)");
SubQuery identificationcatalogcode= new SubQuery
("TcustPersonDetail", "identificationcatalogcode", "identificationcatalogcode", "i.pk.personcode = t.personcode and i.pk.dateto=(select max(dt.pk.dateto) from TcustPersonDetail dt where dt.pk.personcode=t.personcode)");
//tramite
// TarmTramite
SubQuery codigoTramite= new SubQuery
("TarmTramite", "pk", "pk", "i.pk = t.ctramite");
SubQuery tramitetipoautorizacion= new SubQuery
("TarmTramite", "tipoautorizacion", "tipoautorizacion", "i.pk = t.ctramite");
SubQuery tramitetipoautorizacioncode= new SubQuery
("TarmTramite","tipoautorizacioncodigo", "tipoautorizacioncodigo", "i.pk = t.ctramite");
SubQuery tramitecategoria= new SubQuery
("TarmTramite", "categoria", "categoria", "i.pk = t.ctramite");
SubQuery tramitecategoriacodigo= new SubQuery
("TarmTramite","categoriacodigo", "categoriacodigo", "i.pk = t.ctramite");
SubQuery tramiteusoactividad= new SubQuery
("TarmTramite", "usoactividad", "usoactividad", "i.pk = t.ctramite");
SubQuery tramiteusoactividadcodigo= new SubQuery
("TarmTramite","usoactividadcodigo", "usoactividadcodigo", "i.pk = t.ctramite");
//estado
SubQuery estado= new SubQuery("TgeneCatalogDetail","description","estadoSolicitud","i.pk.catalog=t.estado and i.pk.catalogcode=t.estadocodigo");
dto.addSubQuery(estado);
dto.addSubQuery(snumerodocumento);
dto.addSubQuery(snombre);
dto.addSubQuery(identificationcatalog);
dto.addSubQuery(identificationcatalogcode);
dto.addSubQuery(codigoTramite);
dto.addSubQuery(tramitetipoautorizacion);
dto.addSubQuery(tramitetipoautorizacioncode);
dto.addSubQuery(tramitecategoria);
dto.addSubQuery(tramitecategoriacodigo);
dto.addSubQuery(tramiteusoactividad);
dto.addSubQuery(tramiteusoactividadcodigo);
HashMap<String, DtoQuery> mtables = new HashMap<String, DtoQuery>();
mtables.put(beanalias, dto); // permite adicionar mas de una tabla.
Request request = callerhelper.getRequest();
request.setQueryTables(mtables);
request.put("queryalias", "ESTADOSSOLICITUDBPMQUERY");
request.put("codigosolicitudbpm", this.getMfilters().get("numerosolicitud"));
Response resp = callerhelper.executeQuery(request);
if(resp.get("LISTASESTADOSOLICITUDBPM")!=null){
System.out.println("------------"+resp.get("LISTASESTADOSOLICITUDBPM").toString());
List<Object[]> listaEstadosSolicitud = (List<Object[]>)resp.get("LISTASESTADOSOLICITUDBPM");
for (Object[] item : listaEstadosSolicitud) {
EstadosSolicitudBPM estados = new EstadosSolicitudBPM();
estados.setActividad(item[0]!=null?item[0].toString():"");
estados.setUsuarioasignado(item[1]!=null?item[1].toString():"");
estados.setGrupoasignado(item[2]!=null?item[2].toString():"");
estados.setEstado(item[3]!=null?item[3].toString():"");
estados.setFechacreacion(item[4]!=null?(Date)item[4]:null);
estados.setFechainicio(item[5]!=null?(Date)item[5]:null);
estados.setFechacompleta(item[6]!=null?(Date)item[6]:null);
listaEstadoSolicitud.add(estados);
}
}
if (resp.getResponseCode().compareTo(Response.RESPONSE_OK) != 0) {
lrecord = new ArrayList<TarmSolicitud>();
MessageHelper.setMessageError(resp);
} else {
record = (TarmSolicitud) resp.get(beanalias);
super.postQuery((AbstractDataTransport) resp.get(beanalias));
}
} catch (Throwable e) {
MessageHelper.setMessageError(e);
}
}
@Override
public void save() {
try {
DtoSave dtosave = super.getDtoSave();
dtosave.setReturnpk(true); // Para que el core devuelva el pk de los registros nuevos.
HashMap<String, DtoSave> msave = new HashMap<String, DtoSave>();
Request request = callerhelper.getRequest();
msave.put(beanalias, dtosave); // adicionar metadata de mantenimiento para cada tabla.
request.setSaveTables(msave);
Response resp = callerhelper.executeSave(request);
if (resp.getResponseCode().compareTo(Response.RESPONSE_OK) == 0) {
this.postCommit(resp);
MessageHelper.setMessageInfo(resp);
} else {
MessageHelper.setMessageError(resp);
}
} catch (Throwable e) {
MessageHelper.setMessageError(e);
}
}
@Override
public void postCommit(Response response) throws Exception {
super.postCommitGeneric(response, beanalias);
}
public void fijaPersona(TcustPersonDetail persondetail) throws Exception {
if (persondetail == null) {
return;
}
record.setPersoncode(persondetail.getPk().getPersoncode());
}
public void fijaInicioFlujoEnNO() throws Exception {
record.setInicioFlujo("N");
}
public void fijaInicioFlujoEnYES() throws Exception {
record.setInicioFlujo("Y");
}
public static TarmSolicitud findxSolicitudCodpersona(String codigoSolicitud,String codigoPersona) {
try {
SolicitudArmasController cc = new SolicitudArmasController();
cc.init();
cc.recperpage = 10000;
cc.addFilter("pk", codigoSolicitud);
cc.addFilter("personcode", codigoPersona);
cc.querydatabase();
if (cc.record != null) {
return cc.record;
}
return null;
} catch (Throwable e) {
MessageHelper.setMessageError(e);
return null;
}
}
public static TarmSolicitud findByCSolicitud(String cSolicitud) {
try {
SolicitudArmasController cc = new SolicitudArmasController();
cc.init();
cc.recperpage = 10000;
cc.addFilter("pk", cSolicitud);
cc.queryDBNormal();
if (cc.lrecord.size()>0) {
return cc.lrecord.get(0);
}
return null;
} catch (Throwable e) {
MessageHelper.setMessageError(e);
return null;
}
}
public static List<TarmSolicitud> findByCTramite(String cTramite) {
try {
SolicitudArmasController cc = new SolicitudArmasController();
cc.init();
cc.recperpage = 10000;
cc.addFilter("ctramite", cTramite);
cc.queryDBNormal();
if (cc.lrecord.size()>0) {
return cc.lrecord;
}
return null;
} catch (Throwable e) {
MessageHelper.setMessageError(e);
return null;
}
}
/**
*
* Metodo para encopntrar los tramites pertenecientes a una persona
* @param cPersona codigo de la persona
* @param cTramite codigo del tramite
* @return Listado de las solicitudes encontradas
*/
public static List<TarmSolicitud> findByPersonaCTramite(Integer cPersona, String cTramite) {
try {
SolicitudArmasController cc = new SolicitudArmasController();
cc.init();
cc.recperpage = 10000;
cc.addFilter("ctramite", cTramite);
cc.addFilter("personcode", String.valueOf(cPersona));
cc.queryDBNormal();
if (cc.lrecord.size()>0) {
return cc.lrecord;
}
return null;
} catch (Throwable e) {
MessageHelper.setMessageError(e);
return null;
}
}
// Version del metodo querydatabase normal sin filtros adicionales
protected void queryDBNormal() {
try {
DtoQuery dto = super.getDtoQuery(true);
dto.setOrderby("t.pk");
// Subquery
HashMap<String, DtoQuery> mtables = new HashMap<String, DtoQuery>();
mtables.put(beanalias, dto); // permite adicionar mas de una tabla.
Request request = callerhelper.getRequest();
request.setQueryTables(mtables);
Response resp = callerhelper.executeQuery(request);
if (resp.getResponseCode().compareTo(Response.RESPONSE_OK) != 0) {
lrecord = new ArrayList<TarmSolicitud>();
MessageHelper.setMessageError(resp);
} else {
lrecord = (List<TarmSolicitud>) resp.get(beanalias);
super.postQuery(lrecord);
}
} catch (Throwable e) {
MessageHelper.setMessageError(e);
}
}
public void update(TarmSolicitud bean) throws Exception{
record=bean;
super.update();
}
public static TarmSolicitud find(String codigoSolicitud) {
try {
if(codigoSolicitud == null || codigoSolicitud.isEmpty()){
return null;
}
SolicitudArmasController cc = new SolicitudArmasController();
cc.init();
cc.recperpage = 300;
cc.addFilter("pk", codigoSolicitud);
cc.querydatabase();
if (cc.record != null) {
return cc.record;
}
return null;
} catch (Throwable e) {
MessageHelper.setMessageError(e);
return null;
}
}
public List<EstadosSolicitudBPM> getListaEstadoSolicitud() {
return listaEstadoSolicitud;
}
public void setListaEstadoSolicitud(
List<EstadosSolicitudBPM> listaEstadoSolicitud) {
this.listaEstadoSolicitud = listaEstadoSolicitud;
}
}