/**
  * Ação do atualizar
  */
 public function atualizar()
 {
     if (!$this->load->checkPermissao->check(false, URL . 'funcionarios/gerenciar/editar')) {
         $this->http->response("Ação não permitida");
         return false;
     }
     $idFuncionario = filter_var((int) $this->http->getRequest('id_funcionario'));
     $foto = isset($_FILES['foto']) ? $_FILES['foto'] : '';
     $nome_foto = filter_var($this->http->getRequest('nome_foto'));
     $nome = filter_var($this->http->getRequest('nome'));
     $sobrenome = filter_var($this->http->getRequest('sobrenome'));
     $dataNascimento = filter_var($this->http->getRequest('dataNascimento'));
     $sexo = filter_var($this->http->getRequest('sexo'));
     $rg = filter_var($this->http->getRequest('rg'));
     $cpf = filter_var($this->http->getRequest('cpf'));
     $estadoCivil = filter_var($this->http->getRequest('estadoCivil'));
     $escolaridade = filter_var($this->http->getRequest('escolaridade'));
     //endereço
     $id_endereco = filter_var((int) $this->http->getRequest('id_endereco'));
     $cep = filter_var($this->http->getRequest('cep'));
     $logradouro = filter_var($this->http->getRequest('logradouro'));
     $numero = filter_var($this->http->getRequest('numero'));
     $complemento = filter_var($this->http->getRequest('complemento'));
     $bairro = filter_var($this->http->getRequest('bairro'));
     $cidade = filter_var($this->http->getRequest('cidade'));
     $estado = filter_var($this->http->getRequest('estado'));
     //contato
     $telefones = filter_var_array((array) $this->http->getRequest('telefones'));
     $emails = filter_var_array((array) $this->http->getRequest('emails'));
     //DADOS ADMISSIONAIS
     $codigoAdmissao = filter_var($this->http->getRequest('codigoAdmissao'));
     $cargo = filter_var($this->http->getRequest('cargo'));
     $dataAdmissao = filter_var($this->http->getRequest('dataAdmissao'));
     $dataDemissao = filter_var($this->http->getRequest('dataDemissao'));
     //validação dos dados
     $this->load->library('dataValidator', null, true);
     $this->load->dataValidator->set('Nome', $nome, 'nome')->is_required()->min_length(2);
     $this->load->dataValidator->set('Sobrenome', $sobrenome, 'sobrenome')->is_required()->min_length(2);
     $this->load->dataValidator->set('Data de nascimento', $dataNascimento, 'dataNascimento')->is_required()->is_date('d/m/Y');
     $this->load->dataValidator->set('Sexo', $sexo, 'sexo')->is_required();
     $this->load->dataValidator->set('CEP', $cep, 'cep')->is_required();
     $this->load->dataValidator->set('CPF', $cpf, 'cpf')->is_required()->is_cpf();
     $this->load->dataValidator->set('Logradouro', $logradouro, 'logradouro')->is_required();
     $this->load->dataValidator->set('Número', $numero, 'numero')->is_required()->is_num();
     $this->load->dataValidator->set('Bairro', $bairro, 'bairro')->is_required();
     $this->load->dataValidator->set('Cidade', $cidade, 'cidade')->is_required();
     $this->load->dataValidator->set('Estado', $estado, 'estado')->is_required();
     $this->load->dataValidator->set('Cargo', $cargo, 'cargo')->is_required();
     if ($this->load->dataValidator->validate()) {
         $this->load->model('funcionarios/funcionariosModel');
         $this->load->model('emailModel');
         $this->load->model('telefoneModel');
         $this->load->model('funcionarios/cargosModel');
         //FUNCIONARIO
         $funcionariosModel = new funcionariosModel();
         //TELEFONES
         foreach ($telefones as $key => $telefone) {
             $telefone['idtelefone'] = isset($telefone['idtelefone']) ? $telefone['idtelefone'] : '';
             $telefoneModel = new telefoneModel();
             $telefoneModel->setId($telefone['idtelefone']);
             $telefoneModel->setCategoria($telefone['categoria']);
             $telefoneModel->setNumero($telefone['telefone']);
             $telefoneModel->setOperadora($telefone['operadora']);
             $telefoneModel->setTipo($telefone['tipo_telefone']);
             $funcionariosModel->addTelefone($telefoneModel);
         }
         //EMAILS
         foreach ($emails as $email) {
             $email['idemail'] = isset($email['idemail']) ? $email['idemail'] : '';
             $emailModel = new emailModel();
             $emailModel->setId($email['idemail']);
             $emailModel->setEmail($email['email']);
             $emailModel->setTipo($email['tipo_email']);
             $funcionariosModel->addEmail($emailModel);
         }
         //ENDEREÇO
         $this->load->model('enderecoModel');
         $enderecoModel = new enderecoModel();
         $enderecoModel->setId($id_endereco);
         $enderecoModel->setCep($cep);
         $enderecoModel->setNumero($numero);
         $enderecoModel->setComplemento($complemento);
         $enderecoModel->setLogradouro($logradouro);
         $enderecoModel->setBairro($bairro);
         $enderecoModel->setCidade($cidade);
         $enderecoModel->setEstado($estado);
         //FORMATAÇÃO DOS DADOS
         $this->load->library('dataFormat', null, true);
         $dataNascimento = $this->load->dataFormat->formatar($dataNascimento, 'data', 'banco');
         $dataAdmissao = $this->load->dataFormat->formatar($dataAdmissao, 'data', 'banco');
         $dataDemissao = $this->load->dataFormat->formatar($dataDemissao, 'data', 'banco');
         if (!empty($foto)) {
             $cropValues = array('w' => $this->http->getRequest('w'), 'h' => $this->http->getRequest('h'), 'x1' => $this->http->getRequest('x1'), 'y1' => $this->http->getRequest('y1'));
             $tamanho = array('p' => array('w' => 404, 'h' => 158));
             if ($nome_foto == '') {
                 $nome_foto = md5(date('dmYHis'));
             }
             try {
                 $this->load->library('uploadFoto');
                 $upload = new uploadFoto('funcionarios', $foto, $nome_foto, $tamanho, $cropValues);
                 $nome_foto = $upload->getNomeArquivo();
             } catch (Exception $e) {
                 $this->http->response($e->getMessage());
                 return false;
             }
         }
         $funcionariosModel->setId($idFuncionario);
         $funcionariosModel->setFoto($nome_foto);
         $funcionariosModel->setNome($nome);
         $funcionariosModel->setSobrenome($sobrenome);
         $funcionariosModel->setDataNascimento($dataNascimento);
         $funcionariosModel->setSexo($sexo);
         $funcionariosModel->setRg($rg);
         $funcionariosModel->setCpf($cpf);
         $funcionariosModel->setEstadoCivil($estadoCivil);
         $funcionariosModel->setEscolaridade($escolaridade);
         $funcionariosModel->setEndereco($enderecoModel);
         $funcionariosModel->setCodigo($codigoAdmissao);
         $cargosModel = new cargosModel();
         $cargosModel->setId($cargo);
         $funcionariosModel->setCargo($cargosModel);
         $funcionariosModel->setDataAdmissao($dataAdmissao);
         $funcionariosModel->setDataDemissao($dataDemissao);
         //FUNCIONARIO DAO
         $this->load->dao('funcionarios/funcionariosDao');
         $funcionariosDao = new funcionariosDao();
         try {
             $this->http->response($funcionariosDao->atualizar($funcionariosModel));
         } catch (dbException $e) {
             $this->http->response($e->getMessageError());
             exit;
         }
     } else {
         $todos_erros = $this->load->dataValidator->get_errors();
         $this->http->response(json_encode($todos_erros));
     }
 }
示例#2
0
 /**
  * Retorna a consulta de um funcionário pelo id
  * @return object [funcionariosModel]
  */
 public function consultar(funcionariosModel $func)
 {
     $funcionario = new funcionariosModel();
     $this->db->clear();
     $this->db->setTabela('funcionarios');
     $this->db->setCondicao("id_funcionario = ?");
     $this->db->setParameter(1, $func->getId());
     //FUNCIONARIO
     if ($this->db->select()) {
         $result = $this->db->result();
         //TELEFONES
         $this->db->clear();
         $this->db->setTabela('telefones AS A, telefones_funcionarios AS B');
         $this->db->setCondicao("B.id_funcionario = ? AND A.id_telefone = B.id_telefone");
         $this->db->setParameter(1, $func->getId());
         if ($this->db->select()) {
             $resultTel = $this->db->resultAll();
             $this->load->model('telefoneModel');
             foreach ($resultTel as $telefone) {
                 $telefoneModel = new telefoneModel();
                 $telefoneModel->setId($telefone['id_telefone']);
                 $telefoneModel->setCategoria($telefone['categoria_telefone']);
                 $telefoneModel->setNumero($telefone['numero_telefone']);
                 $telefoneModel->setOperadora($telefone['operadora_telefone']);
                 $telefoneModel->setTipo($telefone['tipo_telefone']);
                 $funcionario->addTelefone($telefoneModel);
             }
         }
         //EMAILS
         $this->db->clear();
         $this->db->setTabela('emails as A, emails_funcionarios AS B');
         $this->db->setCondicao("B.id_funcionario = ? AND B.id_email = A.id_email");
         $this->db->setParameter(1, $func->getId());
         $this->db->select();
         if ($this->db->rowCount() > 0) {
             $resultEmail = $this->db->resultAll();
             $this->load->model('emailModel');
             foreach ($resultEmail as $email) {
                 $emailModel = new emailModel();
                 $emailModel->setId($email['id_email']);
                 $emailModel->setEmail($email['endereco_email']);
                 $emailModel->setTipo($email['tipo_email']);
                 $funcionario->addEmail($emailModel);
             }
         }
         //ENDERECO
         $this->db->clear();
         $this->db->setTabela('enderecos as A, enderecos_funcionarios AS B');
         $this->db->setCondicao("B.id_funcionario = ? AND A.id_endereco = B.id_endereco ");
         $this->db->setParameter(1, $func->getId());
         $this->db->select();
         $this->load->model('enderecoModel');
         $endereco = new enderecoModel();
         if ($this->db->rowCount() > 0) {
             $resultEnd = $this->db->result();
             $endereco->setId($resultEnd['id_endereco']);
             $endereco->setCep($resultEnd['cep_endereco']);
             $endereco->setNumero($resultEnd['numero_endereco']);
             $endereco->setComplemento($resultEnd['complemento_endereco']);
             $endereco->setLogradouro($resultEnd['rua_endereco']);
             $endereco->setBairro($resultEnd['bairro_endereco']);
             $endereco->setCidade($resultEnd['cidade_endereco']);
             $endereco->setEstado($resultEnd['estado_endereco']);
         }
         $funcionario->setId($result['id_funcionario']);
         $funcionario->setFoto($result['foto_funcionario']);
         $funcionario->setNome($result['nome_funcionario']);
         $funcionario->setSobrenome($result['sobrenome_funcionario']);
         $funcionario->setDataNascimento($result['data_nascimento_funcionario']);
         $funcionario->setSexo($result['sexo_funcionario']);
         $funcionario->setRg($result['rg_funcionario']);
         $funcionario->setCpf($result['cpf_funcionario']);
         $funcionario->setEstadoCivil($result['estado_civil_funcionario']);
         $funcionario->setEscolaridade($result['escolaridade_funcionario']);
         $funcionario->setEndereco($endereco);
         $this->load->model('funcionarios/cargosModel');
         $cargosModel = new cargosModel();
         $cargosModel->setId($result['id_cargo']);
         $funcionario->setCargo($cargosModel);
         $funcionario->setDataAdmissao($result['data_admissao_funcionario']);
         $funcionario->setDataDemissao($result['data_demissao_funcionario']);
         $funcionario->setStatus(status::getAttribute($result['status_funcionario']));
         return $funcionario;
     } else {
         return $funcionario;
     }
 }
示例#3
0
 /**
  * Retorna a consulta de um funcionário pelo id
  * @return object [funcionariosModel]
  */
 public function consultar(IlistagemFuncionarios $ifuncionario, funcionariosModel $func, $status)
 {
     $funcionario = new funcionariosModel();
     $result = $ifuncionario->consultar($this->db, $func, $status);
     //FUNCIONARIO
     if ($result != null) {
         //ENDERECO
         $this->db->clear();
         $this->db->setTabela('enderecos as A, enderecos_funcionarios AS B');
         $this->db->setCondicao("B.id_funcionario = ? AND A.id_endereco = B.id_endereco ");
         $this->db->setParameter(1, $func->getId());
         $this->db->select();
         $this->load->model('enderecoModel');
         $endereco = new enderecoModel();
         if ($this->db->rowCount() > 0) {
             $resultEnd = $this->db->result();
             $endereco->setId($resultEnd['id_endereco']);
             $endereco->setCep($resultEnd['cep_endereco']);
             $endereco->setNumero($resultEnd['numero_endereco']);
             $endereco->setComplemento($resultEnd['complemento_endereco']);
             $endereco->setLogradouro($resultEnd['rua_endereco']);
             $endereco->setBairro($resultEnd['bairro_endereco']);
             $endereco->setCidade($resultEnd['cidade_endereco']);
             $endereco->setEstado($resultEnd['estado_endereco']);
         }
         //setando os dados do funcionario
         $funcionario->setId($result['id_funcionario']);
         $funcionario->setFoto($result['foto_funcionario']);
         $funcionario->setNome($result['nome_funcionario']);
         $funcionario->setSobrenome($result['sobrenome_funcionario']);
         $funcionario->setDataNascimento($result['data_nascimento_funcionario']);
         $funcionario->setSexo($result['sexo_funcionario']);
         $funcionario->setRg($result['rg_funcionario']);
         $funcionario->setCpf($result['cpf_funcionario']);
         $funcionario->setEstadoCivil($result['estado_civil_funcionario']);
         $funcionario->setEscolaridade($result['escolaridade_funcionario']);
         $funcionario->setEndereco($endereco);
         $funcionario->setEmail($result['email_funcionario']);
         $funcionario->setTelefone($result['telefone_funcionario']);
         //setando os dados do cargo
         $this->load->model('funcionarios/cargosModel');
         $cargosModel = new cargosModel();
         $cargosModel->setId($result['id_cargo']);
         $funcionario->setCargo($cargosModel);
         $funcionario->setDataAdmissao($result['data_admissao_funcionario']);
         $funcionario->setDataDemissao($result['data_demissao_funcionario']);
         $funcionario->setStatus(status::getAttribute($result['status_funcionario']));
         return $funcionario;
     } else {
         return $funcionario;
     }
 }