function Gerar() { @session_start(); $this->pessoa_logada = $_SESSION['id_pessoa']; session_write_close(); $this->titulo = "Reservas - Detalhe"; $this->addBanner("imagens/nvp_top_intranet.jpg", "imagens/nvp_vert_intranet.jpg", "Intranet"); $this->cod_reserva = $_GET["cod_reserva"]; $tmp_obj = new clsPmieducarReservas($this->cod_reserva); $registro = $tmp_obj->detalhe(); if (!$registro) { header("location: educar_reservas_lst.php"); die; } if (class_exists("clsPmieducarExemplar")) { $obj_ref_cod_exemplar = new clsPmieducarExemplar($registro["ref_cod_exemplar"]); $det_ref_cod_exemplar = $obj_ref_cod_exemplar->detalhe(); if (class_exists("clsPmieducarAcervo")) { $acervo = $det_ref_cod_exemplar["ref_cod_acervo"]; $obj_acervo = new clsPmieducarAcervo($acervo); $det_acervo = $obj_acervo->detalhe(); $titulo_exemplar = $det_acervo["titulo"]; } } else { $registro["ref_cod_exemplar"] = "Erro na geracao"; echo "<!--\nErro\nClasse nao existente: clsPmieducarExemplar\n-->"; } if (class_exists("clsPmieducarCliente")) { $obj_cliente = new clsPmieducarCliente($registro["ref_cod_cliente"]); $det_cliente = $obj_cliente->detalhe(); $ref_idpes = $det_cliente["ref_idpes"]; $obj_pessoa = new clsPessoa_($ref_idpes); $det_pessoa = $obj_pessoa->detalhe(); $registro["ref_cod_cliente"] = $det_pessoa["nome"]; } else { $registro["ref_cod_cliente"] = "Erro na geracao"; echo "<!--\nErro\nClasse nao existente: clsPmieducarCliente\n-->"; } if ($registro["ref_cod_cliente"]) { $this->addDetalhe(array("Cliente", "{$registro["ref_cod_cliente"]}")); } if ($titulo_exemplar) { $this->addDetalhe(array("Obra", "{$titulo_exemplar}")); } if ($registro["ref_cod_exemplar"]) { $this->addDetalhe(array("Tombo", "{$registro["ref_cod_exemplar"]}")); } if ($registro["data_reserva"]) { $this->addDetalhe(array("Data Reserva", dataFromPgToBr($registro["data_reserva"], "d/m/Y"))); } if ($registro["data_prevista_disponivel"]) { $this->addDetalhe(array("Data Prevista Disponível", dataFromPgToBr($registro["data_prevista_disponivel"], "d/m/Y"))); } $obj_permissoes = new clsPermissoes(); if ($obj_permissoes->permissao_cadastra(609, $this->pessoa_logada, 11)) { $this->url_novo = "educar_reservas_login_cad.php"; } $this->url_cancelar = "educar_reservas_lst.php"; $this->largura = "100%"; }
function Novo() { @session_start(); $this->pessoa_logada = $_SESSION['id_pessoa']; $this->ref_cod_cliente = $_SESSION['reservas']['cod_cliente']; @session_write_close(); if ($this->passo == 2) { return true; } $obj_permissoes = new clsPermissoes(); $obj_permissoes->permissao_cadastra(609, $this->pessoa_logada, 11, "educar_reservas_lst.php"); $obj_acervo = new clsPmieducarAcervo($this->ref_cod_acervo); $det_acervo = $obj_acervo->detalhe(); // tipo de exemplar $cod_exemplar_tipo = $det_acervo["ref_cod_exemplar_tipo"]; if ($this->existe_reserva == 1) { // die("1"); // echo "EMPRESTIMO <br>"; // ------------------- DADOS DO CLIENTE (EMPRESTIMO) ------------------ // $obj_exemplar_emprestimo = new clsPmieducarExemplarEmprestimo(); $lst_exemplar_emprestimo = $obj_exemplar_emprestimo->lista(null, null, null, null, $this->ref_cod_exemplar, null, null, null, null, null, false, $this->ref_cod_biblioteca); if (is_array($lst_exemplar_emprestimo) && count($lst_exemplar_emprestimo)) { $det_exemplar_emprestimo = array_shift($lst_exemplar_emprestimo); $cod_cliente = $det_exemplar_emprestimo["ref_cod_cliente"]; // data do emprestimo $data_retirada = $det_exemplar_emprestimo["data_retirada"]; $data_prevista_disponivel = dataFromPgToBr($data_retirada, "Y-m-d"); } else { echo "<script> alert('ERRO - Não foi possível encontrar o registro do empréstimo!'); </script>"; } } else { if ($this->existe_reserva == 2) { // die("2"); // echo "RESERVA <br>"; // ------------------- DADOS DO CLIENTE (RESERVA) ------------------ // $obj_reservas = new clsPmieducarReservas(); $lst_reservas = $obj_reservas->lista(null, null, null, null, null, null, $this->data_disponivel, $this->data_disponivel, null, null, $this->ref_cod_exemplar, 1, $this->ref_cod_biblioteca); if (is_array($lst_reservas) && count($lst_reservas)) { $det_reservas = array_shift($lst_reservas); $cod_cliente = $det_reservas["ref_cod_cliente"]; // data da reserva $data_prevista_disponivel = $this->data_disponivel; } else { echo "<script> alert('ERRO - Não foi possível encontrar a reserva!'); </script>"; } } } // echo "data_prevista_disponivel 1: ".$data_prevista_disponivel."<br>"; $obj_cliente_tipo_cliente = new clsPmieducarClienteTipoCliente(); $lst_cliente_tipo_cliente = $obj_cliente_tipo_cliente->lista(null, $cod_cliente, null, null, null, null, null, null, $this->ref_cod_biblioteca); $det_cliente_tipo_cliente = array_shift($lst_cliente_tipo_cliente); // tipo do cliente $cod_cliente_tipo = $det_cliente_tipo_cliente["ref_cod_cliente_tipo"]; $obj_cliente_tipo_exemplar_tipo = new clsPmieducarClienteTipoExemplarTipo($cod_cliente_tipo, $cod_exemplar_tipo); $det_cliente_tipo_exemplar_tipo = $obj_cliente_tipo_exemplar_tipo->detalhe(); // qtde de dias disponiveis para emprestimo $dias_emprestimo = $det_cliente_tipo_exemplar_tipo["dias_emprestimo"]; // echo "dias_espera: ".$this->dias_espera."<br>"; if ($this->existe_reserva == 2) { // Dias que o cliente tem pra pegar o exemplar. Calculo feito levando em consideracao a pior situacao. $data_prevista_disponivel = date("D Y-m-d", strtotime("{$data_prevista_disponivel} +" . $this->dias_espera . " days")); } // echo "data_prevista_disponivel 2: ".$data_prevista_disponivel."<br>"; $data_prevista_disponivel = date("D Y-m-d", strtotime("{$data_prevista_disponivel} +" . $dias_emprestimo . " days")); // echo "data_prevista_disponivel 3: ".$data_prevista_disponivel."<br>"; //---------------------DIAS FUNCIONAMENTO----------------------// $obj_biblioteca_dia = new clsPmieducarBibliotecaDia(); $lst_biblioteca_dia = $obj_biblioteca_dia->lista($this->ref_cod_biblioteca); if (is_array($lst_biblioteca_dia) && count($lst_biblioteca_dia)) { foreach ($lst_biblioteca_dia as $dia_semana) { // dias de funcionamento da biblioteca $biblioteca_dias_semana[] = $dia_semana["dia"]; } } // salva somente os dias que n se repetem ( dias de n funcionamento) $biblioteca_dias_folga = array_diff($this->dias_da_semana, $biblioteca_dias_semana); // inverte as relacoes entre chaves e valores ( de $variavel["Sun"] => 1, para $variavel[1] => "Sun") $biblioteca_dias_folga = array_flip($biblioteca_dias_folga); //---------------------DIAS FERIADO----------------------// $obj_biblioteca_feriado = new clsPmieducarBibliotecaFeriados(); $lst_biblioteca_feriado = $obj_biblioteca_feriado->lista(null, $this->ref_cod_biblioteca); if (is_array($lst_biblioteca_feriado) && count($lst_biblioteca_feriado)) { foreach ($lst_biblioteca_feriado as $dia_feriado) { // dias de feriado da biblioteca $biblioteca_dias_feriado[] = dataFromPgToBr($dia_feriado["data_feriado"], "D Y-m-d"); } } // echo "<pre>"; print_r($biblioteca_dias_feriado)."<br>"; // Cliente tem o dia inteiro para entregar o exemplar. Exemplar somente disponivel para a proxima reserva no dia seguinte. $data_prevista_disponivel = date("D Y-m-d ", strtotime("{$data_prevista_disponivel} +1 day")); // devido a comparacao das datas, é necessario mudar o formato da data $data_prevista_disponivel = dataFromPgToBr($data_prevista_disponivel, "D Y-m-d"); // echo "data_prevista_disponivel 4: ".$data_prevista_disponivel."<br>"; // verifica se a data cai em algum dia que a biblioteca n funciona while (in_array(substr($data_prevista_disponivel, 0, 3), $biblioteca_dias_folga) || in_array($data_prevista_disponivel, $biblioteca_dias_feriado)) { // echo "data_prevista_disponivel ASDFG = ".$data_prevista_disponivel."<br>"; $data_prevista_disponivel = date("D Y-m-d ", strtotime("{$data_prevista_disponivel} +1 day")); $data_prevista_disponivel = dataFromPgToBr($data_prevista_disponivel, "D Y-m-d"); // echo "data_prevista_disponivel ASDFG = ".$data_prevista_disponivel."<br>"; } // echo "data_prevista_disponivel 5: ".$data_prevista_disponivel."<br>";die; $data_prevista_disponivel = dataFromPgToBr($data_prevista_disponivel, "Y-m-d"); $obj = new clsPmieducarReservas(null, null, $this->pessoa_logada, $this->ref_cod_cliente, null, $data_prevista_disponivel, null, $this->ref_cod_exemplar, 1); $cadastrou = $obj->cadastra(); if ($cadastrou) { $this->mensagem .= "Cadastro efetuado com sucesso.<br>"; header("Location: educar_reservas_lst.php"); die; return true; } $this->mensagem = "Cadastro não realizado.<br>"; echo "<!--\nErro ao cadastrar clsPmieducarReservas\nvalores obrigatorios\n is_numeric( {$this->pessoa_logada} ) && is_numeric( {$this->ref_cod_cliente} ) && is_numeric( {$this->ref_cod_exemplar} )\n-->"; return false; }
function Gerar() { $this->campoOculto("ref_cod_biblioteca", $this->ref_cod_biblioteca); $obj_biblioteca = new clsPmieducarBiblioteca($this->ref_cod_biblioteca); $det_biblioteca = $obj_biblioteca->detalhe(); $max_emprestimo = $det_biblioteca["max_emprestimo"]; $dias_espera = $det_biblioteca["dias_espera"]; $valor_maximo_multa = $det_biblioteca["valor_maximo_multa"]; $valor_maximo_multa = number_format($valor_maximo_multa, 2, ",", "."); $obj_cliente_suspenso = new clsPmieducarCliente(); $lst_cliente_suspenso = $obj_cliente_suspenso->lista($this->ref_cod_cliente, null, null, null, null, null, null, null, null, null, 1, null, "suspenso"); // echo "<pre>";print_r($lst_cliente_suspenso); if (is_array($lst_cliente_suspenso)) { echo "<script> alert('Cliente atualmente suspenso!\\nNão é possivel realizar o empréstimo.'); window.location = 'educar_exemplar_emprestimo_lst.php';</script>"; die; } $obj_exemplar_emprestimo = new clsPmieducarExemplarEmprestimo(); $lst_exemplar_emprestimo = $obj_exemplar_emprestimo->lista(null, null, null, $this->ref_cod_cliente, null, null, null, null, null, null, false, $this->ref_cod_biblioteca); if (count($lst_exemplar_emprestimo) >= $max_emprestimo) { echo "<script> alert('Excedido o número máximo de empréstimos do cliente!\\nNão é possivel realizar o empréstimo.'); window.location = 'educar_exemplar_emprestimo_lst.php';</script>"; die; } $lst_cliente_divida = $obj_exemplar_emprestimo->clienteDividaTotal(null, $this->ref_cod_cliente); if (is_array($lst_cliente_divida) && count($lst_cliente_divida)) { // calcula o valor total das multas do cliente em todas as bibliotecas foreach ($lst_cliente_divida as $divida) { $valor_total_multa = $divida["valor_multa"]; $valor_total_pago = $divida["valor_pago"]; } $valor_total_divida = $valor_total_multa - $valor_total_pago; } //$lst_cliente_divida = $obj_exemplar_emprestimo->clienteDividaTotal( null,$this->ref_cod_cliente,null,$this->ref_cod_biblioteca ); $lst_cliente_divida = $obj_exemplar_emprestimo->listaDividaPagamentoCliente($this->ref_cod_cliente, null, null, null, $this->ref_cod_biblioteca); if (is_array($lst_cliente_divida) && count($lst_cliente_divida)) { // calcula o valor das multas do cliente na biblioteca em que esta realizando o emprestimo foreach ($lst_cliente_divida as $divida) { $valor_multa = $divida["valor_multa"]; $valor_pago = $divida["valor_pago"]; } $valor_divida = $valor_multa - $valor_pago; } if (!$valor_total_divida) { $valor_total_divida = 0; } if (!$valor_divida) { $valor_divida = 0; } $valor_total_divida = number_format($valor_total_divida, 2, ",", "."); $valor_divida = number_format($valor_divida, 2, ",", "."); // verifica se o valor da divida ultrapassou o valor maximo permitido da multa pela biblioteca if ($valor_maximo_multa <= $valor_total_divida && $this->confirmado != true) { echo "<script> if(!confirm('Excedido o valor total das multas do cliente! \\n Valor total das multas: R\${$valor_total_divida} \\n Valor total das multas nessa biblioteca: R\${$valor_divida} \\n Valor máximo da multa permitido nessa biblioteca: R\${$valor_maximo_multa} \\n Deseja mesmo assim realizar o empréstimo?')) window.location = 'educar_exemplar_emprestimo_lst.php';</script>"; $this->confirmado = true; $this->campoOculto("confirmado", $this->confirmado); } // primary keys $this->campoOculto("cod_emprestimo", $this->cod_emprestimo); // foreign keys $obj_cliente = new clsPmieducarCliente($this->ref_cod_cliente); $det_cliente = $obj_cliente->detalhe(); $ref_idpes = $det_cliente["ref_idpes"]; $obj_pessoa = new clsPessoa_($ref_idpes); $det_pessoa = $obj_pessoa->detalhe(); $nm_pessoa = $det_pessoa["nome"]; $this->campoTextoInv("nm_pessoa", "Cliente", $nm_pessoa, 30, 255); //-----------------------INCLUI TOMBO------------------------// $this->campoQuebra(); if ($_POST) { foreach ($_POST as $campo => $val) { $this->{$campo} = $this->{$campo} ? $this->{$campo} : $val; } } if ($_POST["exemplar_emprestimo"]) { $this->exemplar_emprestimo = unserialize(urldecode($_POST["exemplar_emprestimo"])); } if ($_POST["ref_cod_exemplar"]) { $this->exemplar_emprestimo["ref_cod_exemplar_"][] = $_POST["ref_cod_exemplar"]; unset($this->ref_cod_exemplar); } $this->campoOculto("excluir_tombo", ""); unset($aux); if (isset($this->exemplar_emprestimo)) { foreach ($this->exemplar_emprestimo as $key => $campo) { if ($campo) { foreach ($campo as $chave => $exemplar) { if ($this->excluir_tombo == $exemplar) { unset($this->exemplar_emprestimo[$key][$chave]); unset($this->excluir_tombo); } else { $obj_exemplar = new clsPmieducarExemplar(); // $lst_exemplar = $obj_exemplar->lista($exemplar,null,null,null,null,null,null,2,null,null,null,null,null,1,null,null,null,null,$this->ref_cod_biblioteca); $lst_exemplar = $obj_exemplar->lista(null, null, null, null, null, null, null, 2, null, null, null, null, null, 1, null, null, null, null, $this->ref_cod_biblioteca, null, null, null, $exemplar); //verifica se o exemplar é disponibilizado para empréstimo if (is_array($lst_exemplar) && count($lst_exemplar)) { $det_exemplar = array_shift($lst_exemplar); $cod_situacao = $det_exemplar["ref_cod_situacao"]; $obj_situacao = new clsPmieducarSituacao($cod_situacao); $det_situacao = $obj_situacao->detalhe(); $situacao_padrao = $det_situacao["situacao_padrao"]; $permite_emprestimo = $det_situacao["permite_emprestimo"]; // echo "<pre>"; print_r($det_situacao); die(); // verifica se a situacao do exemplar é padrao (disponivel) if ($situacao_padrao == 1 && $permite_emprestimo == 2) { $obj_reservas = new clsPmieducarReservas(); $lst_reservas = $obj_reservas->lista(null, null, null, $this->ref_cod_cliente, null, null, null, null, null, null, $exemplar, 1); // verifica se o cliente reservou o exemplar if (is_array($lst_reservas) && count($lst_reservas)) { $reservas = array_shift($lst_reservas); // registra a retirada do exemplar pelo cliente $obj = new clsPmieducarReservas($reservas["cod_reserva"], $this->pessoa_logada, null, null, null, null, date('Y-m-d'), null, 0); $editou = $obj->edita(); if ($editou) { // adiciona exemplar para empréstimo $obj_exemplar = new clsPmieducarExemplar($exemplar); $det_exemplar = $obj_exemplar->detalhe(); $acervo = $det_exemplar["ref_cod_acervo"]; $obj_acervo = new clsPmieducarAcervo($acervo); $det_acervo = $obj_acervo->detalhe(); $titulo = $det_acervo["titulo"]; $this->campoTextoInv("ref_cod_exemplar_{$exemplar}", "", $exemplar, 8, 255, false, false, true); $this->campoTextoInv("titulo_{$exemplar}", "", $titulo, 30, 255, false, false, false, "", "<a href='#' onclick=\"getElementById('excluir_tombo').value = '{$exemplar}'; getElementById('tipoacao').value = ''; {$this->__nome}.submit();\"><img src='imagens/nvp_bola_xis.gif' title='Excluir' border=0></a>"); $aux["ref_cod_exemplar_"][] = $exemplar; } else { echo "<script> alert('ERRO !!!\\nNão foi possível registrar a retirada do exemplar.'); </script>"; } } else { $lst_reservas = $obj_reservas->lista(null, null, null, null, null, null, null, null, null, null, $exemplar, 1); // verifica se existem reservas do exemplar if (is_array($lst_reservas) && count($lst_reservas)) { $reservas = $obj_reservas->getUltimaReserva($exemplar); // verifica se a ultima reserva expirou if (is_array($reservas) && count($reservas)) { $dias_da_semana = array('Sun' => 1, 'Mon' => 2, 'Tue' => 3, 'Wed' => 4, 'Thu' => 5, 'Fri' => 6, 'Sat' => 7); $det_reserva = array_shift($reservas); $data_disponivel = $reservas["data_prevista_disponivel"]; if ($dias_espera == 1) { $data_disponivel = date("D Y-m-d", strtotime("{$data_disponivel} +" . $dias_espera . " day")); } elseif ($dias_espera > 1) { $data_disponivel = date("D Y-m-d", strtotime("{$data_disponivel} +" . $dias_espera . " days")); } //---------------------DIAS FUNCIONAMENTO----------------------// $obj_biblioteca_dia = new clsPmieducarBibliotecaDia(); $lst_biblioteca_dia = $obj_biblioteca_dia->lista($this->ref_cod_biblioteca); if (is_array($lst_biblioteca_dia) && count($lst_biblioteca_dia)) { foreach ($lst_biblioteca_dia as $dia_semana) { // dias de funcionamento da biblioteca $biblioteca_dias_semana[] = $dia_semana["dia"]; } } // salva somente os dias que n se repetem ( dias de n funcionamento) $biblioteca_dias_folga = array_diff($dias_da_semana, $biblioteca_dias_semana); // inverte as relacoes entre chaves e valores ( de $variavel["Sun"] => 1, para $variavel[1] => "Sun") $biblioteca_dias_folga = array_flip($biblioteca_dias_folga); //---------------------DIAS FERIADO----------------------// $obj_biblioteca_feriado = new clsPmieducarBibliotecaFeriados(); $lst_biblioteca_feriado = $obj_biblioteca_feriado->lista(null, $this->ref_cod_biblioteca); if (is_array($lst_biblioteca_feriado) && count($lst_biblioteca_feriado)) { foreach ($lst_biblioteca_feriado as $dia_feriado) { // dias de feriado da biblioteca $biblioteca_dias_feriado[] = dataFromPgToBr($dia_feriado["data_feriado"], "D Y-m-d"); } } // devido a comparacao das datas, é necessario mudar o formato da data $data_disponivel = dataFromPgToBr($data_disponivel, "D Y-m-d"); // verifica se a data cai em algum dia que a biblioteca n funciona while (in_array(substr($data_disponivel, 0, 3), $biblioteca_dias_folga) || in_array($data_disponivel, $biblioteca_dias_feriado)) { $data_disponivel = date("D Y-m-d ", strtotime("{$data_disponivel} +1 day")); $data_disponivel = dataFromPgToBr($data_disponivel, "D Y-m-d"); } $data_disponivel = dataFromPgToBr($data_disponivel, "Y-m-d"); if ($data_disponivel < date('Y-m-d')) { // desativa reserva desatualizada $obj = new clsPmieducarReservas(); $lst = $obj->lista(null, null, null, null, null, null, $reservas["data_prevista_disponivel"], $reservas["data_prevista_disponivel"], null, null, $reservas["ref_cod_exemplar"], 1, $this->ref_cod_biblioteca); if (is_array($lst) && count($lst)) { $det = array_shift($lst); $cod_reserva = $det["cod_reserva"]; $obj = new clsPmieducarReservas($cod_reserva, $this->pessoa_logada, null, null, null, null, null, null, 0); $excluiu = $obj->excluir(); if ($excluiu) { // adiciona exemplar para empréstimo $obj_exemplar = new clsPmieducarExemplar($exemplar); $det_exemplar = $obj_exemplar->detalhe(); $acervo = $det_exemplar["ref_cod_acervo"]; $obj_acervo = new clsPmieducarAcervo($acervo); $det_acervo = $obj_acervo->detalhe(); $titulo = $det_acervo["titulo"]; $this->campoTextoInv("ref_cod_exemplar_{$exemplar}", "", $exemplar, 8, 255, false, false, true); $this->campoTextoInv("titulo_{$exemplar}", "", $titulo, 30, 255, false, false, false, "", "<a href='#' onclick=\"getElementById('excluir_tombo').value = '{$exemplar}'; getElementById('tipoacao').value = ''; {$this->__nome}.submit();\"><img src='imagens/nvp_bola_xis.gif' title='Excluir' border=0></a>"); $aux["ref_cod_exemplar_"][] = $exemplar; } else { echo "<script> alert('ERRO - Não foi possível desativar reserva desatualizada!'); </script>"; } } else { echo "<script> alert('ERRO - Não foi possível encontrar a reserva!'); </script>"; } } else { echo "<script> alert('Exemplar reservado!\\nNo momento, não disponível para empréstimo.'); </script>"; } } } else { $obj_exemplar = new clsPmieducarExemplar($exemplar); $det_exemplar = $obj_exemplar->detalhe(); $acervo = $det_exemplar["ref_cod_acervo"]; $obj_acervo = new clsPmieducarAcervo($acervo); $det_acervo = $obj_acervo->detalhe(); $titulo = $det_acervo["titulo"]; $this->campoTextoInv("ref_cod_exemplar_{$exemplar}", "", $exemplar, 8, 255, false, false, true); $this->campoTextoInv("titulo_{$exemplar}", "", $titulo, 30, 255, false, false, false, "", "<a href='#' onclick=\"getElementById('excluir_tombo').value = '{$exemplar}'; getElementById('tipoacao').value = ''; {$this->__nome}.submit();\"><img src='imagens/nvp_bola_xis.gif' title='Excluir' border=0></a>"); $aux["ref_cod_exemplar_"][] = $exemplar; } } } else { echo "<script> alert('Situação atual do exemplar não permite empréstimo!'); </script>"; } } else { echo "<script> alert('Exemplar não disponível para empréstimo!'); </script>"; } } } } } unset($this->exemplar_emprestimo); $this->exemplar_emprestimo = $aux; } $this->campoOculto("exemplar_emprestimo", serialize($this->exemplar_emprestimo)); if ($aux) { $this->campoNumero("ref_cod_exemplar", "Tombo", $this->ref_cod_exemplar, 15, 50, false, "", "<a href='#' onclick=\"getElementById('incluir_tombo').value = 'S'; getElementById('tipoacao').value = ''; acao();\"><img src='imagens/nvp_bot_adiciona.gif' title='Incluir' border=0></a>"); } else { $this->campoNumero("ref_cod_exemplar", "Tombo", $this->ref_cod_exemplar, 15, 50, true, "", "<a href='#' onclick=\"getElementById('incluir_tombo').value = 'S'; getElementById('tipoacao').value = ''; acao();\"><img src='imagens/nvp_bot_adiciona.gif' title='Incluir' border=0></a>"); } $this->campoOculto("incluir_tombo", ""); // $this->campoRotulo( "bt_incluir_tombo", "Tombo", "<a href='#' onclick=\"getElementById('incluir_tombo').value = 'S'; getElementById('tipoacao').value = ''; {$this->__nome}.submit();\"><img src='imagens/nvp_bot_incluir2.gif' title='Incluir' border=0></a>" ); $this->campoQuebra(); //-----------------------FIM INCLUI TOMBO------------------------// }
function Gerar() { @session_start(); $this->pessoa_logada = $_SESSION['id_pessoa']; unset($_SESSION['reservas']['cod_cliente']); unset($_SESSION['reservas']['ref_cod_biblioteca']); session_write_close(); $this->titulo = "Reservas - Listagem"; foreach ($_GET as $var => $val) { // passa todos os valores obtidos no GET para atributos do objeto $this->{$var} = $val === "" ? null : $val; } $this->addBanner("imagens/nvp_top_intranet.jpg", "imagens/nvp_vert_intranet.jpg", "Intranet"); $lista_busca = array("Cliente", "Obra", "Data Reserva"); // Filtros de Foreign Keys $get_escola = true; $get_biblioteca = true; $get_cabecalho = "lista_busca"; include "include/pmieducar/educar_campo_lista.php"; $this->addCabecalhos($lista_busca); // Filtros de Foreign Keys $this->campoTexto("nm_cliente", "Cliente", $this->nm_cliente, 30, 255, false, false, false, "", "<img border=\"0\" onclick=\"pesquisa_cliente();\" id=\"ref_cod_cliente_lupa\" name=\"ref_cod_cliente_lupa\" src=\"imagens/lupa.png\"\\/>"); $this->campoOculto("ref_cod_cliente", $this->ref_cod_cliente); // outros Filtros $this->campoTexto("nm_exemplar", "Obra", $this->nm_exemplar, 30, 255, false, false, false, "", "<img border=\"0\" onclick=\"pesquisa_obra();\" id=\"ref_cod_exemplar_lupa\" name=\"ref_cod_exemplar_lupa\" src=\"imagens/lupa.png\"\\/>"); $this->campoOculto("ref_cod_exemplar", $this->ref_cod_exemplar); $this->campoOculto("ref_cod_acervo", $this->ref_cod_acervo); $this->campoData("data_reserva", "Data Reserva", $this->data_reserva, false); if ($this->ref_cod_biblioteca) { $this->cod_biblioteca = $this->ref_cod_biblioteca; $this->campoOculto("cod_biblioteca", $this->cod_biblioteca); } else { $this->cod_biblioteca = null; $this->campoOculto("cod_biblioteca", $this->cod_biblioteca); } // Paginador $this->limite = 20; $this->offset = $_GET["pagina_{$this->nome}"] ? $_GET["pagina_{$this->nome}"] * $this->limite - $this->limite : 0; $obj_reservas = new clsPmieducarReservas(); $obj_reservas->setOrderby("data_reserva ASC"); $obj_reservas->setLimite($this->limite, $this->offset); $lista = $obj_reservas->lista(null, null, null, $this->ref_cod_cliente, $this->data_reserva, null, null, null, null, null, $this->ref_cod_exemplar, 1, $this->ref_cod_biblioteca, $this->ref_cod_instituicao, $this->ref_cod_escola); $total = $obj_reservas->_total; // monta a lista if (is_array($lista) && count($lista)) { foreach ($lista as $registro) { // muda os campos data $registro["data_reserva_time"] = strtotime(substr($registro["data_reserva"], 0, 16)); $registro["data_reserva_br"] = date("d/m/Y", $registro["data_reserva_time"]); // pega detalhes de foreign_keys if (class_exists("clsPmieducarExemplar")) { $obj_exemplar = new clsPmieducarExemplar($registro["ref_cod_exemplar"]); $det_exemplar = $obj_exemplar->detalhe(); $acervo = $det_exemplar["ref_cod_acervo"]; $obj_acervo = new clsPmieducarAcervo($acervo); $det_acervo = $obj_acervo->detalhe(); $registro["ref_cod_exemplar"] = $det_acervo["titulo"]; } else { $registro["ref_cod_exemplar"] = "Erro na geracao"; echo "<!--\nErro\nClasse nao existente: clsPmieducarExemplar\n-->"; } if (class_exists("clsPmieducarCliente")) { $obj_cliente = new clsPmieducarCliente($registro["ref_cod_cliente"]); $det_cliente = $obj_cliente->detalhe(); $ref_idpes = $det_cliente["ref_idpes"]; $obj_pessoa = new clsPessoa_($ref_idpes); $det_pessoa = $obj_pessoa->detalhe(); $registro["ref_cod_cliente"] = $det_pessoa["nome"]; } else { $registro["ref_cod_cliente"] = "Erro na geracao"; echo "<!--\nErro\nClasse nao existente: clsPmieducarCliente\n-->"; } if (class_exists("clsPmieducarBiblioteca")) { $obj_ref_cod_biblioteca = new clsPmieducarBiblioteca($registro["ref_cod_biblioteca"]); $det_ref_cod_biblioteca = $obj_ref_cod_biblioteca->detalhe(); $registro["ref_cod_biblioteca"] = $det_ref_cod_biblioteca["nm_biblioteca"]; } if ($registro["ref_cod_instituicao"]) { $obj_ref_cod_instituicao = new clsPmieducarInstituicao($registro["ref_cod_instituicao"]); $det_ref_cod_instituicao = $obj_ref_cod_instituicao->detalhe(); $registro["ref_cod_instituicao"] = $det_ref_cod_instituicao["nm_instituicao"]; } if ($registro["ref_cod_escola"]) { $obj_ref_cod_escola = new clsPmieducarEscola(); $det_ref_cod_escola = array_shift($obj_ref_cod_escola->lista($registro["ref_cod_escola"])); $registro["ref_cod_escola"] = $det_ref_cod_escola["nome"]; } $lista_busca = array("<a href=\"educar_reservas_det.php?cod_reserva={$registro["cod_reserva"]}\">{$registro["ref_cod_cliente"]}</a>", "<a href=\"educar_reservas_det.php?cod_reserva={$registro["cod_reserva"]}\">{$registro["ref_cod_exemplar"]}</a>", "<a href=\"educar_reservas_det.php?cod_reserva={$registro["cod_reserva"]}\">{$registro["data_reserva_br"]}</a>"); if ($qtd_bibliotecas > 1 && ($nivel_usuario == 4 || $nivel_usuario == 8)) { $lista_busca[] = "<a href=\"educar_reservas_det.php?cod_reserva={$registro["cod_reserva"]}\">{$registro["ref_cod_biblioteca"]}</a>"; } else { if ($nivel_usuario == 1 || $nivel_usuario == 2 || $nivel_usuario == 4) { $lista_busca[] = "<a href=\"educar_reservas_det.php?cod_reserva={$registro["cod_reserva"]}\">{$registro["ref_cod_biblioteca"]}</a>"; } } if ($nivel_usuario == 1 || $nivel_usuario == 2) { $lista_busca[] = "<a href=\"educar_reservas_det.php?cod_reserva={$registro["cod_reserva"]}\">{$registro["ref_cod_escola"]}</a>"; } if ($nivel_usuario == 1) { $lista_busca[] = "<a href=\"educar_reservas_det.php?cod_reserva={$registro["cod_reserva"]}\">{$registro["ref_cod_instituicao"]}</a>"; } $this->addLinhas($lista_busca); } } $this->addPaginador2("educar_reservas_lst.php", $total, $_GET, $this->nome, $this->limite); $obj_permissoes = new clsPermissoes(); if ($obj_permissoes->permissao_cadastra(609, $this->pessoa_logada, 11)) { $this->acao = "go(\"educar_reservas_login_cad.php\")"; $this->nome_acao = "Novo"; } $this->largura = "100%"; }
function Gerar() { @session_start(); $this->pessoa_logada = $_SESSION['id_pessoa']; unset($_SESSION['reservas']['cod_cliente']); unset($_SESSION['reservas']['ref_cod_biblioteca']); session_write_close(); $this->titulo = "Reservas - Listagem"; foreach ($_GET as $var => $val) { // passa todos os valores obtidos no GET para atributos do objeto $this->{$var} = $val === "" ? null : $val; } $this->addBanner("imagens/nvp_top_intranet.jpg", "imagens/nvp_vert_intranet.jpg", "Intranet"); $lista_busca = array("Cliente", "Obra", "Data Reserva", 'Data retirada'); // Filtros de Foreign Keys $get_escola = true; $get_biblioteca = true; $get_cabecalho = "lista_busca"; include "include/pmieducar/educar_campo_lista.php"; $this->addCabecalhos($lista_busca); // Filtros de Foreign Keys $this->campoTexto("nm_cliente", "Cliente", $this->nm_cliente, 30, 255, false, false, false, "", "<img border=\"0\" onclick=\"pesquisa_cliente();\" id=\"ref_cod_cliente_lupa\" name=\"ref_cod_cliente_lupa\" src=\"imagens/lupa.png\"\\/>"); $this->campoOculto("ref_cod_cliente", $this->ref_cod_cliente); // outros Filtros $this->campoTexto("nm_exemplar", "Obra", $this->nm_exemplar, 30, 255, false, false, false, "", "<img border=\"0\" onclick=\"pesquisa_obra();\" id=\"ref_cod_exemplar_lupa\" name=\"ref_cod_exemplar_lupa\" src=\"imagens/lupa.png\"\\/>"); $this->campoOculto("ref_cod_exemplar", $this->ref_cod_exemplar); $this->campoOculto("ref_cod_acervo", $this->ref_cod_acervo); // Filtro verificando se ouve retirada $resources = array(1 => 'Todas', 2 => 'Sem retirada', 3 => 'Com retirada'); $options = array('label' => 'Tipo de reserva', 'resources' => $resources, 'value' => $this->tipo_reserva); $this->inputsHelper()->select('tipo_reserva', $options); $this->campoData("data_reserva", "Data reserva", $this->data_reserva, false); if ($this->ref_cod_biblioteca) { $this->cod_biblioteca = $this->ref_cod_biblioteca; $this->campoOculto("cod_biblioteca", $this->cod_biblioteca); } else { $this->cod_biblioteca = null; $this->campoOculto("cod_biblioteca", $this->cod_biblioteca); } // Paginador $this->limite = 20; $this->offset = $_GET["pagina_{$this->nome}"] ? $_GET["pagina_{$this->nome}"] * $this->limite - $this->limite : 0; $obj_reservas = new clsPmieducarReservas(); $obj_reservas->setOrderby("data_reserva ASC"); $obj_reservas->setLimite($this->limite, $this->offset); $lista = $obj_reservas->lista(null, null, null, $this->ref_cod_cliente, $this->data_reserva, null, null, null, null, null, $this->ref_cod_exemplar, 1, $this->ref_cod_biblioteca, $this->ref_cod_instituicao, $this->ref_cod_escola, $this->tipo_reserva == 1 || is_null($this->tipo_reserva) ? null : ($this->tipo_reserva == 2 ? true : false)); $total = $obj_reservas->_total; // monta a lista if (is_array($lista) && count($lista)) { foreach ($lista as $registro) { // muda os campos data $registro["data_reserva_time"] = strtotime(substr($registro["data_reserva"], 0, 16)); $registro["data_reserva_br"] = date("d/m/Y", $registro["data_reserva_time"]); $registro["data_retirada_br"] = $registro["data_retirada"] == null ? '-' : Portabilis_Date_Utils::PgSqltoBr(substr($registro["data_retirada"], 0, 10)); // pega detalhes de foreign_keys if (class_exists("clsPmieducarExemplar")) { $obj_exemplar = new clsPmieducarExemplar($registro["ref_cod_exemplar"]); $det_exemplar = $obj_exemplar->detalhe(); $acervo = $det_exemplar["ref_cod_acervo"]; $obj_acervo = new clsPmieducarAcervo($acervo); $det_acervo = $obj_acervo->detalhe(); $registro["ref_cod_exemplar"] = $det_acervo["titulo"]; } else { $registro["ref_cod_exemplar"] = "Erro na geracao"; echo "<!--\nErro\nClasse nao existente: clsPmieducarExemplar\n-->"; } if (class_exists("clsPmieducarCliente")) { $obj_cliente = new clsPmieducarCliente($registro["ref_cod_cliente"]); $det_cliente = $obj_cliente->detalhe(); $ref_idpes = $det_cliente["ref_idpes"]; $obj_pessoa = new clsPessoa_($ref_idpes); $det_pessoa = $obj_pessoa->detalhe(); $registro["ref_cod_cliente"] = $det_pessoa["nome"]; } else { $registro["ref_cod_cliente"] = "Erro na geracao"; echo "<!--\nErro\nClasse nao existente: clsPmieducarCliente\n-->"; } if (class_exists("clsPmieducarBiblioteca")) { $obj_ref_cod_biblioteca = new clsPmieducarBiblioteca($registro["ref_cod_biblioteca"]); $det_ref_cod_biblioteca = $obj_ref_cod_biblioteca->detalhe(); $registro["ref_cod_biblioteca"] = $det_ref_cod_biblioteca["nm_biblioteca"]; } if ($registro["ref_cod_instituicao"]) { $obj_ref_cod_instituicao = new clsPmieducarInstituicao($registro["ref_cod_instituicao"]); $det_ref_cod_instituicao = $obj_ref_cod_instituicao->detalhe(); $registro["ref_cod_instituicao"] = $det_ref_cod_instituicao["nm_instituicao"]; } if ($registro["ref_cod_escola"]) { $obj_ref_cod_escola = new clsPmieducarEscola(); $det_ref_cod_escola = array_shift($obj_ref_cod_escola->lista($registro["ref_cod_escola"])); $registro["ref_cod_escola"] = $det_ref_cod_escola["nome"]; } $lista_busca = array("{$registro["ref_cod_cliente"]}", "{$registro["ref_cod_exemplar"]}", "{$registro["data_reserva_br"]}", "{$registro["data_retirada_br"]}"); if ($qtd_bibliotecas > 1 && ($nivel_usuario == 4 || $nivel_usuario == 8)) { $lista_busca[] = "{$registro["ref_cod_biblioteca"]}"; } else { if ($nivel_usuario == 1 || $nivel_usuario == 2 || $nivel_usuario == 4) { $lista_busca[] = "{$registro["ref_cod_biblioteca"]}"; } } if ($nivel_usuario == 1 || $nivel_usuario == 2) { $lista_busca[] = "{$registro["ref_cod_escola"]}"; } if ($nivel_usuario == 1) { $lista_busca[] = "{$registro["ref_cod_instituicao"]}"; } $this->addLinhas($lista_busca); } } $this->addPaginador2("educar_reservas_lst.php", $total, $_GET, $this->nome, $this->limite); $obj_permissoes = new clsPermissoes(); if ($obj_permissoes->permissao_cadastra(609, $this->pessoa_logada, 11)) { $this->acao = "go(\"/module/Biblioteca/Reserva\")"; $this->nome_acao = "Novo"; } $this->largura = "100%"; $localizacao = new LocalizacaoSistema(); $localizacao->entradaCaminhos(array($_SERVER['SERVER_NAME'] . "/intranet" => "i-Educar", "educar_biblioteca_index.php" => "Biblioteca", "" => "Lista de Reservas")); $this->enviaLocalizacao($localizacao->montar()); }
protected function deleteReserva() { if ($this->canDeleteReserva()) { $exemplar = $this->loadExemplar(); // chamado list para assegurar que esta excluindo a reserva do cliente, biblioteca, instituicao e escola $reservas = new clsPmieducarReservas(); $reservas = $reservas->lista($this->getRequest()->reserva_id, null, null, $this->getRequest()->ref_cod_cliente, null, null, null, null, null, null, $this->getRequest()->exemplar_id, 1, $this->getRequest()->ref_cod_biblioteca, $this->getRequest()->ref_cod_instituicao, $this->getRequest()->ref_cod_escola, $data_retirada_null = true); foreach ($reservas as $reserva) { $_reserva = new clsPmieducarReservas($this->getRequest()->reserva_id); if ($_reserva->excluir()) { $this->messenger->append("Reserva cancelada com sucesso.", 'success'); } else { $this->messenger->append("Aparentemente a reserva não foi cancelada, por favor, tente novamente.", 'error'); } } if (empty($reservas)) { $this->messenger->append("Não foi encontrado uma reserva com os parâmetros recebidos.", 'error'); } } $this->appendResponse($this->loadExemplar($this->getRequest()->exemplar_id, $reload = true)); }
protected function validateReservaOfExemplar($exemplar = null) { if (is_null($exemplar)) { $exemplar = $this->loadExemplar(); } $reservas = $this->loadReservasForExemplar($exemplar); $cont = 0; $clientePossuiReserva = false; $codReserva = 0; if (is_array($reservas) && count($reservas)) { foreach ($reservas as $registro) { $cont; if ($registro['cliente_id'] == $this->getRequest()->cliente_id) { $clientePossuiReserva = true; $codReserva = $registro['id']; break; } } } if ($clientePossuiReserva) { if ($cont == 1) { $reservas = new clsPmieducarReservas($codReserva); $reservas->data_retirada = date('Y-m-d H:i:s'); $reservas->edita(); $return = 'disponivel'; } else { $this->messenger->append("Outros clientes já haviam reservado o exemplar anteriormente." . $cont, 'success'); $return = 'reservado'; } } else { if ($cont > 0) { $this->messenger->append("Outros clientes já haviam reservado o exemplar.", 'success'); $return = 'reservado'; } } return $return; }