X-Git-Url: https://git.llucax.com/mecon/samurai.git/blobdiff_plain/0ecc42815b25c93505bdc63406044ebd4c37283b..5664c266997bb4bf5b7c6825bac2b29f5b41d7d4:/sistema/www/sistemas/sistemas-abm.php?ds=inline diff --git a/sistema/www/sistemas/sistemas-abm.php b/sistema/www/sistemas/sistemas-abm.php index 6d5db38..d063345 100644 --- a/sistema/www/sistemas/sistemas-abm.php +++ b/sistema/www/sistemas/sistemas-abm.php @@ -18,42 +18,86 @@ // +----------------------------------------------------------------------+ // // $Id$ -// $Author$ -// $URL$ -// $Date$ -// $Rev$ // + +//REQUIRE ONCE {{{ + //MECON {{{ require_once 'MECON/HTML/QuickForm.php'; + require_once 'MECON/HTML/Error.php'; + require_once 'MECON/HTML/Tabla.php'; + // }}} + //SAMURAI {{{ + require_once 'SAMURAI/Sistema.php'; + require_once 'SAMURAI/Permiso.php'; + // }}} +// }}} +//XXX OBTENGO LA ACCION {{{ +switch ($_REQUEST['accion']) { + case 'm': + $b_accion = 'Modificar'; + $accion = 'm'; + break; + case 'e': + $b_accion = 'Eliminar'; + $accion = 'e'; + break; + default: + $b_accion = 'Grabar'; + $accion = ''; + break; +} +//}}} +//VERIFICO SI SE TIENE ACCESO A LA PAGINA{{{ +$SAMURAI_PERM->setSistema(SAMURAI_PERM); +if (!$SAMURAI_PERM->tiene(SAMURAI_PERM_DEVELOPER)) { + $SAMURAI_PERM->chequear(SAMURAI_PERM_DEVELOPER); +} +$MARCO =& new MECON_Marco ('/var/www/sistemas/samurai/sistema/conf/confSecciones.php', $SAMURAI_PERM); +//}}} //CREO LOS OBJETO NECESARIOS {{{ - $SAMURAI = new Samurai($DB); - $FORM = new MECON_HTML_QuickForm ('sistemas_abm','post','sistemas-abm'); + $FORM = new MECON_HTML_QuickForm ('sistemas_abm','post','sistemas-abm'); // }}} //OBTENGO LA LISTA DE PERMISOS {{{ - $PERMISOS = $SAMURAI->getSelectPermisos(); + $PERMISOS = SAMURAI_Permiso::getArrayPermisos($DB); // }}} //AGREGO LOS ELEMENTOS DEL FORM {{{ $FORM->addElement ('header' , 'cabecera' , 'ABM Sistemas'); $FORM->addElement ('hidden' , 'id_sistema'); $FORM->addElement ('text' , 'nombre_sistema' , 'Nombre' , array('size' => '30')); - $FORM->addElement ('textarea', 'desc_sistema' , 'Descripcion' , array('rows' => '2','cols'=>'50')); + $FORM->addElement ('textarea', 'desc_sistema' , + 'Descripción' , array('rows' => '2','cols'=>'50', 'wrap'=>'virtual')); + +//xdebug_start_trace(); + $FORM->addElement ('mdate' , 'fecha_inicio' , 'Fecha Inicio' ); + +//xdebug_dump_function_trace(); + + $FORM->addElement ('mdate' , 'fecha_fin' , 'Fecha Fin' ); - $FORM->addElement ('mdate' , 'fecha_implementacion', 'Fecha Implementacion'); + $FORM->addElement ('mdate' , 'fecha_implementacion', 'Fecha Implementación'); $FORM->addElement ('textarea', 'contacto' , 'Contacto' , array('rows' => '2','cols'=>'50')); $FORM->addElement ('select' , 'permisos' , 'Permisos' , $PERMISOS, array('size' => '5', 'multiple' => 'multiple')); - $FORM->addElement ('static' , 'responsable' , 'Responsable' , $_SESSION['samurai']['login']); - $group[] = HTML_QuickForm::createElement('submit', 'aceptar' , 'Grabar'); + $FORM->addElement ('hidden' , 'responsable' , $_SESSION['usuario']); + $FORM->addElement ('hidden', 'accion', $accion); + $group[] = HTML_QuickForm::createElement('submit', 'aceptar', $b_accion); + $group[] = HTML_QuickForm::createElement('submit', 'cancelar', 'Cancelar', array ('onClick' => 'javascript:window.location =\'sistemas\';return false;')); $FORM->addGroup($group,'botones'); // }}} //AGREGO LAS REGLAS DE VALIDACION DE LOS ELEMENTOS {{{ - $FORM->addRule('nombre_sistema' , 'El campo nombre es obligatorio' , 'required'); - $FORM->addRule('desc_sistema' , 'El campo descripcion es obligatorio' , 'required'); - $FORM->addRule('fecha_inicio' , 'El campo fecha inicio es obligatorio', 'required'); - $FORM->addRule('fecha_inicio' , 'La fecha no es válida' , 'fecha' ); - $FORM->addRule('fecha_fin' , 'La fecha no es válida' , 'fecha' ); - $FORM->addRule('fecha_implementacion', 'La fecha no es válida' , 'fecha' ); - $FORM->addRule('contacto' , 'El campo contacto es obligatorio' , 'required'); + $botones = $FORM->getSubmitValue('botones'); + if (!@$botones['cancelar']) { + $FORM->addRule('nombre_sistema' , 'El campo nombre es obligatorio' , 'required'); + $FORM->addRule('desc_sistema' , 'El campo descripción es obligatorio' , 'required'); + $FORM->addRule('fecha_inicio' , 'El campo fecha inicio es obligatorio', 'required'); +// if (isset($_GET['accion']) && $_GET['accion'] != 'e') { + $FORM->addRule('fecha_inicio' , 'La fecha no es válida', 'fecha'); + $FORM->addRule('fecha_fin' , 'La fecha no es válida', 'fecha'); + $FORM->addRule('fecha_implementacion', 'La fecha no es válida', 'fecha'); +// } + $FORM->addRule('contacto', 'El campo contacto es obligatorio', 'required'); + } // }}} //CREO EL OBJETO SISTEMA {{{ //Obtengo el id del sistema. @@ -69,7 +113,7 @@ $id_sistema = $idSistema->getValue(); } - $SISTEMA = new Sistema ($DB, $id_sistema); + $SISTEMA = new SAMURAI_Sistema ($DB, $id_sistema); // }}} //SETEO LOS VALORES DE LOS ELEMENTOS DEL OBJETO FORM {{{ if (isset($_GET['accion']) && $_GET['accion'] != '') { @@ -98,23 +142,44 @@ } //Seteo las fechas if ($tmp = $SISTEMA->getFechaInicio()) { - $fecha_inicio->setSelectedDate(array( 'd' => $tmp->format("%d"), - 'F' => $tmp->format("%m"), - 'Y' => $tmp->format("%Y"), - )); + $fecha_inicio->setValue(array( 'd' => $tmp->format("%d"), + 'F' => $tmp->format("%m"), + 'Y' => $tmp->format("%Y"), + )); } + else { + $fecha_inicio->setValue(array( 'd' => '', + 'F' => '', + 'Y' => '', + )); + } + + if ($tmp = $SISTEMA->getFechaFin()) { - $fecha_fin->setSelectedDate(array( 'd' => $tmp->format("%d"), - 'F' => $tmp->format("%m"), - 'Y' => $tmp->format("%Y"), - )); + $fecha_fin->setValue(array( 'd' => $tmp->format("%d"), + 'F' => $tmp->format("%m"), + 'Y' => $tmp->format("%Y"), + )); + } + else { + $fecha_fin->setValue(array( 'd' => '', + 'F' => '', + 'Y' => '', + )); } + if ($tmp = $SISTEMA->getFechaImplementacion()) { - $fecha_implementacion->setSelectedDate(array( 'd' => $tmp->format("%d"), - 'F' => $tmp->format("%m"), - 'Y' => $tmp->format("%Y"), - )); + $fecha_implementacion->setValue(array( 'd' => $tmp->format("%d"), + 'F' => $tmp->format("%m"), + 'Y' => $tmp->format("%Y"), + )); } + else { + $fecha_implementacion->setValue(array( 'd' => '', + 'F' => '', + 'Y' => '', + )); + } $aceptar->setValue('Modificar'); @@ -167,27 +232,32 @@ } $SISTEMA->setContacto($contacto->getValue()); $SISTEMA->setPermisos($permisos->getSelected()); - $SISTEMA->setResponsable($responsable->_text); //TODO URGENTE Modificar esto. No tiene hay metodo static::getValue() - $FORM->freeze(); - $res = $SISTEMA->guardarDatos($aceptar->getValue()); - - if (PEAR::isError($res)) { - $group = array (); - $group[] = HTML_QuickForm::createElement('static', 'error' , 'Error:', $res->getMessage()); - $group[] = HTML_QuickForm::createElement('submit', 'aceptar' , $aceptar->getValue()); - $FORM->removeElement('botones'); - $FORM->addGroup($group,'botones', '', '
'); - } + $SISTEMA->setResponsable($responsable->getValue()); + $botones = $FORM->getSubmitValue('botones'); + if (@$botones['cancelar']) { + header ('Location: sistemas'); + } else { - $FORM->freeze(); - header('Location: sistemas'); + $res = $SISTEMA->guardarDatos($aceptar->getValue()); + if ($aceptar->getValue() != 'Eliminar') { + $_SESSION['samurai']['id_sistema'] = $SISTEMA->getId(); + } + if (PEAR::isError($res)) { + $ERROR = new MECON_HTML_Error(traducir($res->getMessage())); + } + else { + $FORM->freeze(); + header('Location: sistemas'); + } } } // }}} //DIBUJO LA PAGINA {{{ - $MARCO = new Marco ('../../conf/confSecciones.php'); $MARCO->addTitle('ABM Sistema'); + if (isset($ERROR)) { + $MARCO->addBody($ERROR); + } $MARCO->addBody($FORM); $MARCO->display(); // }}}