X-Git-Url: https://git.llucax.com/mecon/samurai.git/blobdiff_plain/22d1ae1aa6bfee6df20dfa9544e14feaecc9fbf4..5664c266997bb4bf5b7c6825bac2b29f5b41d7d4:/sistema/www/perfiles/perfiles-abm.php?ds=inline
diff --git a/sistema/www/perfiles/perfiles-abm.php b/sistema/www/perfiles/perfiles-abm.php
index cf7fb66..5d15fdf 100644
--- a/sistema/www/perfiles/perfiles-abm.php
+++ b/sistema/www/perfiles/perfiles-abm.php
@@ -19,17 +19,44 @@
//
// $Id$
//
+//VERIFICO SI SE TIENE ACCESO A LA PAGINA{{{
+$SAMURAI_PERM->setSistema(SAMURAI_PERM);
+if (!$SAMURAI_PERM->tiene(SAMURAI_PERM_DEVELOPER)) {
+ $SAMURAI_PERM->setSistema($_SESSION['samurai']['id_sistema']);
+ $SAMURAI_PERM->chequear(SAMURAI_PERM_PERFIL_ALTA,SAMURAI_PERM_PERFIL_BAJA,SAMURAI_PERM_PERFIL_MODIF, SAMURAI_PERM_DEVELOPER);
+}
+$MARCO =& new MECON_Marco ('/var/www/sistemas/samurai/sistema/conf/confSecciones.php', $SAMURAI_PERM);
+//}}}
+
+//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;
+}
+//}}}
// REQUIRE_ONCE {{{
require_once 'MECON/HTML/QuickForm.php';
require_once 'MECON/HTML/Tabla.php';
+ require_once 'MECON/HTML/Error.php';
require_once 'SAMURAI/Perfil.php';
require_once 'SAMURAI/Permiso.php';
require_once 'SAMURAI/Sistema.php';
+ require_once 'MECON/HTML/Image.php';
// }}}
//CREO LOS OBJETO NECESARIOS {{{
- if (@$_GET['id_perfil']) {
- $id_perfil = $_GET['id_perfil'];
+ if (@$_GET['_id_perfil']) {
+ $id_perfil = $_GET['_id_perfil'];
}
elseif (@$_POST['id_perfil']) {
$id_perfil = $_POST['id_perfil'];
@@ -38,17 +65,19 @@
$id_perfil = null;
}
$FORM = new MECON_HTML_QuickForm ('perfiles_abm','post','perfiles-abm');
+ $FORM->renderer->updateAttributes('width="400"');
$SISTEMA = new SAMURAI_Sistema ($DB, $_SESSION['samurai']['id_sistema']);
- $PERFIL = new SAMURAI_Perfil ($DB, $id_perfil);
+ $PERFIL = new SAMURAI_Perfil ($DB, $id_perfil,
+ $_SESSION['samurai']['id_sistema']);
if ($PERFIL->getResponsable()) {
$responsable = $PERFIL->getResponsable();
}
else {
- $responsable = $_SESSION['samurai']['login'];
+ $responsable = $_SESSION['usuario'];
}
- if (!@$_GET['id_perfil']) {
+ if (!@$_GET['_id_perfil']) {
if (@$_GET['desc_perfil']) {
$PERFIL->setDescripcion(@$_GET['desc_perfil']);
}
@@ -68,36 +97,38 @@
}
// }}}
//AGREGO LOS ELEMENTOS DEL FORM {{{
- $FORM->addElement ('header', 'cabecera', 'ABM Perfiles');
- $FORM->addElement ('hidden', 'id_perfil', $id_perfil);
- $FORM->addElement ('hidden', 'desc_ant' , $descripcion);
- $FORM->addElement ('static', 'desc_perfil', 'Descripcion', $descripcion);
- $FORM->addElement ('select', 'permisos' , 'Permisos' , $PERMISOS, array('size' => '5', 'multiple' => 'true'));
- $FORM->addElement ('select', 'tipo_perfil', 'Tipo Perfil', array('E' => 'Externo', 'I' => 'Interno', 'D' => 'Dios'), array ('size' => '1'));
- $FORM->addElement ('hidden', 'responsable', $responsable);
- $group[] = HTML_QuickForm::createElement('submit', 'aceptar' , 'Grabar');
- $group[] = HTML_QuickForm::createElement('submit', 'cancelar', 'Cancelar', array ('onClick' => 'javascript:history.go(-1);return true;'));
- $FORM->addGroup($group,'botones');
+ if (@$PERMISOS) {
+ $FORM->addElement ('header', 'cabecera', 'ABM Perfiles');
+ $FORM->addElement ('hidden', 'id_perfil', $id_perfil);
+ $FORM->addElement ('hidden', 'desc_ant' , $descripcion);
+ $FORM->addElement ('static', 'desc_perfil', 'Descripción', $descripcion);
+ $FORM->addElement ('select', 'permisos' , 'Permisos' , $PERMISOS, array('size' => '5', 'multiple' => 'true'));
+ $FORM->addElement ('hidden', 'responsable', $responsable);
+ $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=\'perfiles\';return false;'));
+ $FORM->addGroup($group,'botones');
+ }
+ else {
+ $ERROR = new MECON_HTML_Error('El sistema no posee permisos asociados.');
+ }
// }}}
//AGREGO LAS REGLAS DE VALIDACION {{{
$FORM->addRule ('permisos', 'Se debe seleccionar al menos un permiso', 'required');
// }}}
//CARGO LOS DATOS SI YA EXISTEN EN BASE {{{
-// TODO Terminar de armar la parte de modificacion y eliminacion
if (isset($_GET['accion']) && $_GET['accion'] != '') {
//MODIFICACION
$id_perfil =& $FORM->getElement ('id_perfil' );
$desc_perfil =& $FORM->getElement ('desc_perfil');
$permisos =& $FORM->getElement ('permisos' );
- $tipo_perfil =& $FORM->getElement ('tipo_perfil');
$responsable =& $FORM->getElement ('responsable');
$group =& $FORM->getElement ('botones' );
$group =& $group->getElements('aceptar' );
$aceptar =& $group[0];
$permisos->setSelected($PERFIL->getPermisos());
- $tipo_perfil->setSelected($PERFIL->getTipo());
-
+
if ($PERFIL->getResponsable() != '') {
$responsable->setValue($PERFIL->getResponsable());
}
@@ -108,6 +139,7 @@
//ELIMINACION -> modifico el valor del boton
if ($_GET['accion'] == 'e') {
$aceptar->setValue('Eliminar');
+ $aceptar->updateAttributes(array ('onClick' => 'javascript:if (confirm(\'¿Esta Seguro?\')) return true;return false;'));
$FORM->freeze();
}
}
@@ -124,8 +156,6 @@
$id_perfil =& $FORM->getElement ('id_perfil' );
$desc_perfil =& $FORM->getElement ('desc_perfil');
$permisos =& $FORM->getElement ('permisos' );
- $tipo_perfil =& $FORM->getElement ('tipo_perfil');
- $tipo_perfil_tmp = $tipo_perfil->getSelected();
$responsable =& $FORM->getElement ('responsable');
$group =& $FORM->getElement ('botones' );
$group =& $group->getElements('aceptar' );
@@ -134,15 +164,12 @@
$PERFIL->setDescripcion($desc_perfil->_text );
$PERFIL->setResponsable($responsable->getValue());
$PERFIL->setPermisos ($permisos->getSelected()); //Le asigno al perfil los permisos seleccionados
- $PERFIL->setTipo ($tipo_perfil_tmp['0'] );
//Grabo y verifico si se produjo algun error
$res = $PERFIL->guardarDatos($aceptar->getValue());
if (PEAR::isError($res)) {
- $TABLA = new Tabla ('cellspacing=0');
- $row = array (''.$res->getMessage().'');
- $TABLA->addRow($row,'align=left');
+ $ERROR = new MECON_HTML_Error($res->getMessage());
if ($aceptar->getValue() == 'Eliminar') {
$FORM->freeze();
}
@@ -155,15 +182,15 @@
}
// }}}
//DIBUJO LA PAGINA {{{
- $TABLA3 = new Tabla ('cellspacing=0');
- $row = array ('SISTEMA: '.$SISTEMA->getNombre().'');
- $TABLA3->addRow($row,'titulo align=left');
+ $imagen = new MECON_HTML_Image('/MECON/images/vinetas_flecha_doble.gif');
+ $row = array ($imagen->toHtml().' SISTEMA: '.$SISTEMA->getNombre().'');
+ $TABLA3 = new MECON_HTML_Tabla ('cellspacing=0');
+ $TABLA3->addRow($row,'align=left');
- $MARCO = new Marco ('../../conf/confSecciones.php');
$MARCO->addTitle('ABM Perfil');
$MARCO->addBody($TABLA3);
- if (isset($TABLA)) {
- $MARCO->addBody($TABLA);
+ if (isset($ERROR)) {
+ $MARCO->addBody($ERROR);
}
$MARCO->addBody($FORM);
$MARCO->display();