mirror of
https://github.com/rmontanana/inventario2.git
synced 2025-08-17 16:35:58 +00:00
Compare commits
13 Commits
Author | SHA1 | Date | |
---|---|---|---|
7272e2b85a | |||
9a8ba799c4 | |||
2452d2a9e6 | |||
|
b48b206950 | ||
|
a72ef244cd | ||
cc2129e7d9 | |||
6148593c7c | |||
14e5767eb1 | |||
b89fcbd2ec | |||
068596af7f | |||
77f766366d | |||
0ab3bf7eb3 | |||
db4e283a0d |
@@ -194,7 +194,10 @@ class AportaContenido {
|
|||||||
$campo = '<input type="hidden" name="fechaCabecera" id="fechaCabecera" value="' . $this->fechaActual("%d/%m/%Y") . '">';
|
$campo = '<input type="hidden" name="fechaCabecera" id="fechaCabecera" value="' . $this->fechaActual("%d/%m/%Y") . '">';
|
||||||
$etiqueta = '<label for="fechaCabecera" onClick="$(' . "'#fechaCabecera'" . ").data('DateTimePicker').show();" . '">' . $this->fechaActual() . '</label>';
|
$etiqueta = '<label for="fechaCabecera" onClick="$(' . "'#fechaCabecera'" . ").data('DateTimePicker').show();" . '">' . $this->fechaActual() . '</label>';
|
||||||
return $etiqueta . $campo . $script;
|
return $etiqueta . $campo . $script;
|
||||||
case 'aplicacion': return PROGRAMA . " v" . VERSION;
|
case 'aplicacion':
|
||||||
|
$nombre = explode(" ", PROGRAMA);
|
||||||
|
$nombre = $nombre[2];
|
||||||
|
return $nombre . " v" . VERSION;
|
||||||
case 'menu': // el menú
|
case 'menu': // el menú
|
||||||
if ($this->registrado) {
|
if ($this->registrado) {
|
||||||
return $this->miMenu->insertaMenu();
|
return $this->miMenu->insertaMenu();
|
||||||
@@ -254,7 +257,7 @@ class AportaContenido {
|
|||||||
$rama_texto = trim(substr(file_get_contents('.git/HEAD'), 16));
|
$rama_texto = trim(substr(file_get_contents('.git/HEAD'), 16));
|
||||||
$rama = ($rama_texto != 'master' ? '<br><button class="btn btn-warning btn-xs" type="button"onClick="' . $creditos . '"><span class="glyphicon glyphicon-cog"></span> '.$rama_texto.'</button></center>':'');
|
$rama = ($rama_texto != 'master' ? '<br><button class="btn btn-warning btn-xs" type="button"onClick="' . $creditos . '"><span class="glyphicon glyphicon-cog"></span> '.$rama_texto.'</button></center>':'');
|
||||||
return $mensaje . '<br><br><center><img src="img/qrlogo.png" alt="' . PROGRAMA . '" onClick="' . $creditos . '" >' .
|
return $mensaje . '<br><br><center><img src="img/qrlogo.png" alt="' . PROGRAMA . '" onClick="' . $creditos . '" >' .
|
||||||
'<br><br><label onClick="' . $creditos . '">' . $centro . '</label>' . $rama . CREDITOS_CABECERA . $tabla . CREDITOS_PIE;
|
'<br><br><label onClick="' . $creditos . '">' . $centro . '</label>' . $rama . '</center>' . CREDITOS_CABECERA . $tabla . CREDITOS_PIE;
|
||||||
case 'articulos':
|
case 'articulos':
|
||||||
case 'ubicaciones':
|
case 'ubicaciones':
|
||||||
case 'test':
|
case 'test':
|
||||||
|
12
CHANGELOG
12
CHANGELOG
@@ -1,3 +1,15 @@
|
|||||||
|
Versión 1.15 29-06-2014
|
||||||
|
-Crear la opción de clonar registro en Mantenimiento.
|
||||||
|
-Crear iconos de clonado en todos los estilos.
|
||||||
|
-Corregido determinaAccion en Imagen para aceptar el clonado
|
||||||
|
-Corregido codificación/decodificación de la cadena de búsqueda en la URL
|
||||||
|
|
||||||
|
Versión 1.14.1 02-06-2014
|
||||||
|
-Añadidos enlaces a manual y a aplicación de ejemplo en readme.md
|
||||||
|
-Arreglado que los créditos salgan centrados en lugar de alineados a la derecha
|
||||||
|
-Añadido la 'v' para indicar la versión en la cabecera de los informes
|
||||||
|
-Acortado el nombre de la aplicación en la página principal para que en dispositivos pequeños se visualice bien con el icono nuevo del manual
|
||||||
|
|
||||||
Versión 1.14 01-06-2014
|
Versión 1.14 01-06-2014
|
||||||
-Añadido icono de acceso a la documentación en la barra superior
|
-Añadido icono de acceso a la documentación en la barra superior
|
||||||
-Corregido cierre etiqueta h5 en pie de créditos
|
-Corregido cierre etiqueta h5 en pie de créditos
|
||||||
|
15
Imagen.php
15
Imagen.php
@@ -29,6 +29,7 @@ class Imagen {
|
|||||||
public $archivoComprimido;
|
public $archivoComprimido;
|
||||||
private $extension;
|
private $extension;
|
||||||
private $dirData;
|
private $dirData;
|
||||||
|
public $archivoCopiado;
|
||||||
|
|
||||||
public function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
@@ -39,7 +40,7 @@ class Imagen {
|
|||||||
{
|
{
|
||||||
if (isset($_POST[$campo]) && $_POST[$campo] == "") {
|
if (isset($_POST[$campo]) && $_POST[$campo] == "") {
|
||||||
return HAYQUEBORRAR; //Hay que borrar el archivo de imagen
|
return HAYQUEBORRAR; //Hay que borrar el archivo de imagen
|
||||||
} elseif ($_FILES[$campo]['error'] == 0) {
|
} elseif (isset($_FILES[$campo]['error']) && $_FILES[$campo]['error'] == 0) {
|
||||||
return HAYQUEGRABAR; //Hay que guardar el archivo de imagen enviado
|
return HAYQUEGRABAR; //Hay que guardar el archivo de imagen enviado
|
||||||
} else {
|
} else {
|
||||||
return NOHACERNADA; //No hay que hacer nada
|
return NOHACERNADA; //No hay que hacer nada
|
||||||
@@ -111,6 +112,18 @@ class Imagen {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
public function copiaImagenId($valorImagen, $tabla, $id, &$mensaje)
|
||||||
|
{
|
||||||
|
$extension = strrchr($valorImagen, ".");
|
||||||
|
$nombre = $this->dirData . "/" . $tabla . "_" . $id . $extension;
|
||||||
|
if (!@copy($valorImagen, $nombre)) {
|
||||||
|
$errors= error_get_last();
|
||||||
|
$mensaje = "No pudo copiar el archivo " . $valorImagen . " en " . $nombre . " Error = [" . $errors['message'] . "]";
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
$this->archivoCopiado = $nombre;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
public function mueveImagenId($tabla, $id, &$mensaje)
|
public function mueveImagenId($tabla, $id, &$mensaje)
|
||||||
{
|
{
|
||||||
|
@@ -54,7 +54,7 @@ class InformePDF {
|
|||||||
//echo $def->Titulo.$def->Cabecera;
|
//echo $def->Titulo.$def->Cabecera;
|
||||||
$this->pdf->Open();
|
$this->pdf->Open();
|
||||||
$this->pdf->setAuthor(AUTOR,true);
|
$this->pdf->setAuthor(AUTOR,true);
|
||||||
$creador = CENTRO . " " . PROGRAMA.VERSION;
|
$creador = CENTRO . " " . PROGRAMA . " v" . VERSION;
|
||||||
$this->pdf->setCreator(html_entity_decode($creador),true);
|
$this->pdf->setCreator(html_entity_decode($creador),true);
|
||||||
$this->pdf->setSubject($this->def->Titulo,true);
|
$this->pdf->setSubject($this->def->Titulo,true);
|
||||||
$this->pdf->setAutoPageBreak(true, 10);
|
$this->pdf->setAutoPageBreak(true, 10);
|
||||||
|
@@ -23,6 +23,7 @@
|
|||||||
define('EDICION', 'Edición');
|
define('EDICION', 'Edición');
|
||||||
define('BORRADO', '<i>Borrado</i>');
|
define('BORRADO', '<i>Borrado</i>');
|
||||||
define('ANADIR', 'Inserción');
|
define('ANADIR', 'Inserción');
|
||||||
|
define('CLONAR', 'Clonar');
|
||||||
|
|
||||||
class Mantenimiento {
|
class Mantenimiento {
|
||||||
|
|
||||||
@@ -91,7 +92,10 @@ class Mantenimiento {
|
|||||||
$sentido = "&sentido=" . $this->datosURL['sentido'];
|
$sentido = "&sentido=" . $this->datosURL['sentido'];
|
||||||
$pag = "&pag=" . $this->datosURL['pag'];
|
$pag = "&pag=" . $this->datosURL['pag'];
|
||||||
//Ahora los datos opcionales
|
//Ahora los datos opcionales
|
||||||
$buscar = isset($this->cadenaBusqueda) ? "&buscar=$this->cadenaBusqueda" : null;
|
//$buscar = isset($this->cadenaBusqueda) ? '&buscar="'.$this->cadenaBusqueda.'"' : null;
|
||||||
|
//$buscar = isset($this->cadenaBusqueda) ? "&buscar='$this->cadenaBusqueda'" : null;
|
||||||
|
//$buscar = isset($this->cadenaBusqueda) ? "&buscar=$this->cadenaBusqueda" : null;
|
||||||
|
$buscar = isset($this->cadenaBusqueda) ? "&buscar=" . urlencode($this->cadenaBusqueda) : null;
|
||||||
$id = isset($this->datosURL['id']) ? "&id=" . $this->datosURL['id'] : null;
|
$id = isset($this->datosURL['id']) ? "&id=" . $this->datosURL['id'] : null;
|
||||||
$enlace = $this->url . $opc . $orden . $sentido . $pag . $buscar . $id;
|
$enlace = $this->url . $opc . $orden . $sentido . $pag . $buscar . $id;
|
||||||
return $enlace;
|
return $enlace;
|
||||||
@@ -109,10 +113,15 @@ class Mantenimiento {
|
|||||||
case 'insertar':return $this->insertar();
|
case 'insertar':return $this->insertar();
|
||||||
case 'modificar':return $this->modificar();
|
case 'modificar':return $this->modificar();
|
||||||
case 'borrar':return $this->borrar();
|
case 'borrar':return $this->borrar();
|
||||||
|
case 'clonar': return $this->muestra(CLONAR);
|
||||||
default: return "La clase Mantenimiento No entiende lo solicitado [" . $this->datosURL['opc'] . "]";
|
default: return "La clase Mantenimiento No entiende lo solicitado [" . $this->datosURL['opc'] . "]";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function clonar()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
protected function obtieneClavesForaneas()
|
protected function obtieneClavesForaneas()
|
||||||
{
|
{
|
||||||
$salida = null;
|
$salida = null;
|
||||||
@@ -146,7 +155,7 @@ class Mantenimiento {
|
|||||||
$cabecera = $this->cabeceraTabla();
|
$cabecera = $this->cabeceraTabla();
|
||||||
//Trata con la cadena de búsqueda si viene del post debe quedarse con ella sino con la del get y si no está definida => vacía
|
//Trata con la cadena de búsqueda si viene del post debe quedarse con ella sino con la del get y si no está definida => vacía
|
||||||
if (isset($this->cadenaBusqueda) && strlen($this->cadenaBusqueda)) {
|
if (isset($this->cadenaBusqueda) && strlen($this->cadenaBusqueda)) {
|
||||||
$sufijo = " where $this->campoBusca like '%" . $this->bdd->filtra($this->cadenaBusqueda) . "%'";
|
$sufijo = " where $this->campoBusca like '%" . $this->bdd->filtra(urldecode($this->cadenaBusqueda)) . "%'";
|
||||||
$comando = str_replace('{buscar}', $sufijo, $this->comandoConsulta);
|
$comando = str_replace('{buscar}', $sufijo, $this->comandoConsulta);
|
||||||
} else {
|
} else {
|
||||||
$comando = str_replace('{buscar}', '', $this->comandoConsulta);
|
$comando = str_replace('{buscar}', '', $this->comandoConsulta);
|
||||||
@@ -244,6 +253,18 @@ class Mantenimiento {
|
|||||||
}
|
}
|
||||||
//Añade los botones de acciones
|
//Añade los botones de acciones
|
||||||
$salida .= '<td align="center">';
|
$salida .= '<td align="center">';
|
||||||
|
//Añade el icono de clonar
|
||||||
|
if ($this->perfil['Alta']) {
|
||||||
|
//$salida.='<a href="index.php?' . $tabla . '&opc=editar&id=' . $id . "&pag=" . $pagina . $sufijoOrden . $sufijoEnlace .
|
||||||
|
$this->backupURL(); $this->datosURL['opc'] = "clonar"; $this->datosURL['id'] = $id;
|
||||||
|
if (ESTILO == 'bootstrap') {
|
||||||
|
$salida.='<a href="'.$this->montaURL() . '" title="Clonar"><span class="glyphicon glyphicon-copyright-mark"></span></a> ';
|
||||||
|
} else {
|
||||||
|
$salida.='<a href="' . $this->montaURL() .
|
||||||
|
'"><img title="Clonar" src="img/' . ESTILO . '/clonar.png" alt="clonar"></a> ';
|
||||||
|
}
|
||||||
|
$this->restoreURL();
|
||||||
|
}
|
||||||
//Añade el icono de editar
|
//Añade el icono de editar
|
||||||
if ($this->perfil['Modificacion']) {
|
if ($this->perfil['Modificacion']) {
|
||||||
//$salida.='<a href="index.php?' . $tabla . '&opc=editar&id=' . $id . "&pag=" . $pagina . $sufijoOrden . $sufijoEnlace .
|
//$salida.='<a href="index.php?' . $tabla . '&opc=editar&id=' . $id . "&pag=" . $pagina . $sufijoOrden . $sufijoEnlace .
|
||||||
@@ -412,7 +433,7 @@ class Mantenimiento {
|
|||||||
//procesa el envío de la imagen
|
//procesa el envío de la imagen
|
||||||
$imagen = new Imagen();
|
$imagen = new Imagen();
|
||||||
$accion = $imagen->determinaAccion($campo);
|
$accion = $imagen->determinaAccion($campo);
|
||||||
if ($accion != NOHACERNADA) {
|
if ($accion != NOHACERNADA) { // && $_POST['tipoOperacion'] != CLONAR) {
|
||||||
$mensaje = "";
|
$mensaje = "";
|
||||||
if (!$imagen->procesaEnvio($campo, $mensaje)) {
|
if (!$imagen->procesaEnvio($campo, $mensaje)) {
|
||||||
return $this->panelMensaje($mensaje, "danger", "ERROR PROCESANDO IMAGEN");
|
return $this->panelMensaje($mensaje, "danger", "ERROR PROCESANDO IMAGEN");
|
||||||
@@ -420,7 +441,16 @@ class Mantenimiento {
|
|||||||
$hayImagen = true;
|
$hayImagen = true;
|
||||||
$campoImagen = $campo;
|
$campoImagen = $campo;
|
||||||
} else {
|
} else {
|
||||||
$valor = "null";
|
//Comprobamos si hay clonación y hay imagen a clonar.
|
||||||
|
$valor = $_POST[$campo];
|
||||||
|
if ($_POST['tipoOperacion'] == CLONAR && file_exists($valor)) {
|
||||||
|
$hayImagen = true;
|
||||||
|
$campoImagen = $campo;
|
||||||
|
$valorImagen = $valor;
|
||||||
|
$valor = "null";
|
||||||
|
} else {
|
||||||
|
$valor = "null";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$valor = $_POST[$campo] == "" ? "null" : '"' . $this->bdd->filtra($_POST[$campo]) . '"';
|
$valor = $_POST[$campo] == "" ? "null" : '"' . $this->bdd->filtra($_POST[$campo]) . '"';
|
||||||
@@ -434,11 +464,22 @@ class Mantenimiento {
|
|||||||
}
|
}
|
||||||
$id = $this->bdd->ultimoId();
|
$id = $this->bdd->ultimoId();
|
||||||
if ($hayImagen) {
|
if ($hayImagen) {
|
||||||
|
$mensaje = " ";
|
||||||
//Tiene que recuperar el id del registro insertado y actualizar el archivo de imagen
|
//Tiene que recuperar el id del registro insertado y actualizar el archivo de imagen
|
||||||
if (!$imagen->mueveImagenId($this->tabla, $id, $mensaje)) {
|
if ($_POST['tipoOperacion'] == CLONAR) {
|
||||||
return $this->panelMensaje($mensaje, "danger", "ERROR COMPRIMIENDO IMAGEN");
|
//Tiene que copiar el archivo original.
|
||||||
|
if (!$imagen->copiaImagenId($valorImagen, $this->tabla, $id, $mensaje)) {
|
||||||
|
return $this->panelMensaje($mensaje, "danger", "ERROR COPIANDO IMAGEN");
|
||||||
|
}
|
||||||
|
$archivoImagen = $imagen->archivoCopiado;
|
||||||
|
} else {
|
||||||
|
//Crea el archivo de imagen
|
||||||
|
if (!$imagen->mueveImagenId($this->tabla, $id, $mensaje)) {
|
||||||
|
return $this->panelMensaje($mensaje, "danger", "ERROR COMPRIMIENDO IMAGEN");
|
||||||
|
}
|
||||||
|
$archivoImagen = $imagen->archivoComprimido;
|
||||||
}
|
}
|
||||||
$comando = "update " . $this->tabla . " set " . $campoImagen . "='" . $imagen->archivoComprimido . "' where id='" . $id ."';";
|
$comando = "update " . $this->tabla . " set " . $campoImagen . "='" . $archivoImagen . "' where id='" . $id ."';";
|
||||||
if (!$this->bdd->ejecuta($comando)) {
|
if (!$this->bdd->ejecuta($comando)) {
|
||||||
return $this->errorBD($comando);
|
return $this->errorBD($comando);
|
||||||
}
|
}
|
||||||
@@ -657,7 +698,7 @@ class Mantenimiento {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @param string $tipo ANADIR,EDICION,BORRADO
|
* @param string $tipo ANADIR,EDICION,BORRADO,CLONAR
|
||||||
* @param array $datos Vector con los datos del registro
|
* @param array $datos Vector con los datos del registro
|
||||||
* @return array lista de campos y formulario de entrada
|
* @return array lista de campos y formulario de entrada
|
||||||
*/
|
*/
|
||||||
@@ -666,6 +707,7 @@ class Mantenimiento {
|
|||||||
$modo = $tipo == BORRADO ? "readonly" : "";
|
$modo = $tipo == BORRADO ? "readonly" : "";
|
||||||
$nfechas = 0;
|
$nfechas = 0;
|
||||||
switch ($tipo) {
|
switch ($tipo) {
|
||||||
|
case CLONAR:
|
||||||
case ANADIR:
|
case ANADIR:
|
||||||
$this->datosURL['opc'] = "insertar"; $this->datosURL['id'] = null;
|
$this->datosURL['opc'] = "insertar"; $this->datosURL['id'] = null;
|
||||||
break;
|
break;
|
||||||
@@ -695,7 +737,7 @@ class Mantenimiento {
|
|||||||
//Se asegura que el id no se pueda modificar.
|
//Se asegura que el id no se pueda modificar.
|
||||||
$modoEfectivo = $clave == 'id' ? "readonly" : $modo;
|
$modoEfectivo = $clave == 'id' ? "readonly" : $modo;
|
||||||
$valorDato = $datos == null ? "" : $datos[$campo];
|
$valorDato = $datos == null ? "" : $datos[$campo];
|
||||||
if ($clave == 'id' && $tipo == ANADIR) {
|
if ($clave == 'id' && ($tipo == ANADIR || $tipo == CLONAR)) {
|
||||||
$valorDato = null;
|
$valorDato = null;
|
||||||
}
|
}
|
||||||
if (!isset($this->foraneas[$valor['Campo']])) {
|
if (!isset($this->foraneas[$valor['Campo']])) {
|
||||||
@@ -744,6 +786,10 @@ class Mantenimiento {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (stristr($this->campos[$campo]['Comment'], "imagen")) {
|
if (stristr($this->campos[$campo]['Comment'], "imagen")) {
|
||||||
|
/*if ($tipo == CLONAR) {
|
||||||
|
// De momento no deja clonar las imágenes
|
||||||
|
$valorDato = null;
|
||||||
|
}*/
|
||||||
$salida .= $this->creaCampoImagen($campo, $valorDato, $tipo);
|
$salida .= $this->creaCampoImagen($campo, $valorDato, $tipo);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@@ -762,6 +808,8 @@ class Mantenimiento {
|
|||||||
}
|
}
|
||||||
//genera un campo oculto con la lista de campos a modificar.
|
//genera un campo oculto con la lista de campos a modificar.
|
||||||
$salida .= '<input name="listacampos" type="hidden" value="' . $campos . "\">\n";
|
$salida .= '<input name="listacampos" type="hidden" value="' . $campos . "\">\n";
|
||||||
|
//genera un campo oculto con el tipo de operación asociado al formulario
|
||||||
|
$salida .= '<input name="tipoOperacion" type="hidden" value="' . $tipo . "\">\n";
|
||||||
$salida .= "</fieldset><p>";
|
$salida .= "</fieldset><p>";
|
||||||
$salida .= '<center>';
|
$salida .= '<center>';
|
||||||
$this->datosURL['opc'] = 'inicial';
|
$this->datosURL['opc'] = 'inicial';
|
||||||
|
@@ -61,7 +61,7 @@ class Pdf_mysql_table extends FPDF
|
|||||||
//Titulo
|
//Titulo
|
||||||
$fecha=strftime("%d-%b-%Y %H:%M");
|
$fecha=strftime("%d-%b-%Y %H:%M");
|
||||||
$this->SetFont('Arial','',8);
|
$this->SetFont('Arial','',8);
|
||||||
$this->Cell(0,4,html_entity_decode(CENTRO . " " . PROGRAMA . VERSION,ENT_COMPAT | ENT_HTML401,'ISO-8859-1'),0,1,'L');
|
$this->Cell(0,4,html_entity_decode(CENTRO . " " . PROGRAMA . " v" . VERSION,ENT_COMPAT | ENT_HTML401,'ISO-8859-1'),0,1,'L');
|
||||||
$this->SetFont('Arial','',18);
|
$this->SetFont('Arial','',18);
|
||||||
$this->Cell(0,6,utf8_decode($this->titulo),0,1,'C');
|
$this->Cell(0,6,utf8_decode($this->titulo),0,1,'C');
|
||||||
$this->SetFont('Arial','',8);
|
$this->SetFont('Arial','',8);
|
||||||
|
@@ -13,6 +13,10 @@ Utiliza:
|
|||||||
*MySQL v. 5.1.x
|
*MySQL v. 5.1.x
|
||||||
*Apache
|
*Apache
|
||||||
|
|
||||||
|
[Manual de Usuario](http://rmontanana.gitbooks.io/inventario2/)
|
||||||
|
|
||||||
|
[Instalación de ejemplo](http://inventario2.rmontanana.es)
|
||||||
|
|
||||||
##Instalación
|
##Instalación
|
||||||
Para instalar la aplicación basta con seguir estos pasos:
|
Para instalar la aplicación basta con seguir estos pasos:
|
||||||
###1. Copiar los archivos en una ubicación a la que tenga acceso el usuario con el que se ejecuta el servidor Apache (apache, _www, etc.).
|
###1. Copiar los archivos en una ubicación a la que tenga acceso el usuario con el que se ejecuta el servidor Apache (apache, _www, etc.).
|
||||||
@@ -26,7 +30,8 @@ Para instalar la aplicación basta con seguir estos pasos:
|
|||||||
###2. Crear un directorio temporal y dar derechos de escritura a los ficheros de configuración.
|
###2. Crear un directorio temporal y dar derechos de escritura a los ficheros de configuración.
|
||||||
|
|
||||||
mkdir tmp
|
mkdir tmp
|
||||||
chown apache tmp
|
mkdir img.data
|
||||||
|
chown apache tmp img.data
|
||||||
chown apache inc/configuracion.inc
|
chown apache inc/configuracion.inc
|
||||||
chown apache inc
|
chown apache inc
|
||||||
|
|
||||||
|
BIN
img/bluecurve/clonar.png
Normal file
BIN
img/bluecurve/clonar.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 560 B |
BIN
img/clonar.png
Normal file
BIN
img/clonar.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.8 KiB |
BIN
img/cristal/clonar.png
Normal file
BIN
img/cristal/clonar.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 635 B |
BIN
img/personal/clonar.png
Normal file
BIN
img/personal/clonar.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 642 B |
@@ -23,5 +23,5 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
define('AUTOR', 'Ricardo Montañana Gómez');
|
define('AUTOR', 'Ricardo Montañana Gómez');
|
||||||
define('VERSION', '1.14');
|
define('VERSION', '1.15');
|
||||||
?>
|
?>
|
||||||
|
@@ -3,7 +3,7 @@
|
|||||||
<Titulo Texto="{Descripcion}" id="{id}"/>
|
<Titulo Texto="{Descripcion}" id="{id}"/>
|
||||||
<Datos>
|
<Datos>
|
||||||
<Consulta>
|
<Consulta>
|
||||||
select A.id as id, A.Descripcion as articulo, A.Marca as marca, A.Modelo as modelo, E.id as idEl, U.id as idUbic,U.Descripcion as ubicacion,E.numserie as numserie,
|
select A.id as idArt, A.Descripcion as articulo, A.Marca as marca, A.Modelo as modelo, E.id as idEl, U.id as idUbic,U.Descripcion as ubicacion,E.numserie as numserie,
|
||||||
E.fechaCompra as fechaCompra,E.Cantidad as cantidad, E.Cantidad as cantReal, 'N' as Baja
|
E.fechaCompra as fechaCompra,E.Cantidad as cantidad, E.Cantidad as cantReal, 'N' as Baja
|
||||||
from Elementos E, Articulos A, Ubicaciones U where A.id=E.id_Articulo and U.id=E.id_Ubicacion
|
from Elementos E, Articulos A, Ubicaciones U where A.id=E.id_Articulo and U.id=E.id_Ubicacion
|
||||||
and A.id='{id}' order by U.Descripcion,numserie;
|
and A.id='{id}' order by U.Descripcion,numserie;
|
||||||
|
Reference in New Issue
Block a user