public function CarregarView($var_download, $var_mensagem)
 {
     $disponibilidades = \App\Models\disponibilidades::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $dons = \App\Models\dons::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $tiposrelacionamentos = \App\Models\tiposrelacionamentos::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $habilidades = \App\Models\habilidades::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $religioes = \App\Models\religioes::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $atividades = \App\Models\atividades::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $ministerios = \App\Models\ministerios::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $ramos = \App\Models\ramos::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $cargos = \App\Models\cargos::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $profissoes = \App\Models\profissoes::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $graus = \App\Models\graus::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $idiomas = \App\Models\idiomas::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $formacoes = \App\Models\areas::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $motivos = \App\Models\tiposmovimentacao::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $tipos = \App\Models\tipospessoas::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $situacoes = \App\Models\situacoes::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $status = \App\Models\status::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $estadoscivis = \App\Models\civis::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
     $grupos = \App\Models\grupospessoas::where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('empresas_id', $this->dados_login->empresas_id)->orderBy('nome', 'ASC')->get();
     /*Busca Nivel1*/
     $view1 = \DB::select('select * from view_celulas_nivel1 v1 where v1.empresas_id = ? and v1.empresas_clientes_cloud_id = ? ', [$this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
     $view2 = \DB::select('select * from view_celulas_nivel2 v2 where v2.empresas_id = ? and v2.empresas_clientes_cloud_id = ? ', [$this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
     $view3 = \DB::select('select * from view_celulas_nivel3 v3 where v3.empresas_id = ? and v3.empresas_clientes_cloud_id = ? ', [$this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
     $view4 = \DB::select('select * from view_celulas_nivel4 v4 where v4.empresas_id = ? and v4.empresas_clientes_cloud_id = ? ', [$this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
     $view5 = \DB::select('select * from view_celulas_nivel5 v5 where v5.empresas_id = ? and v5.empresas_clientes_cloud_id = ? ', [$this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
     return view($this->rota . '.index', ['disponibilidades' => $disponibilidades, 'dons' => $dons, 'tiposrelacionamentos' => $tiposrelacionamentos, 'habilidades' => $habilidades, 'religioes' => $religioes, 'atividades' => $atividades, 'ministerios' => $ministerios, 'nivel1' => $view1, 'nivel2' => $view2, 'nivel3' => $view3, 'nivel4' => $view4, 'nivel5' => $view5, 'motivos' => $motivos, 'ramos' => $ramos, 'cargos' => $cargos, 'profissoes' => $profissoes, 'graus' => $graus, 'idiomas' => $idiomas, 'formacoes' => $formacoes, 'tipos' => $tipos, 'situacoes' => $situacoes, 'estadoscivis' => $estadoscivis, 'status' => $status, 'grupos' => $grupos, 'emails' => '', 'filtros' => '', 'var_download' => $var_download, 'var_mensagem' => $var_mensagem]);
 }
示例#2
0
 private function exibir($request, $id, $id_tipo_pessoa, $preview, $bool_exibir_perfil)
 {
     if ($request->ajax()) {
         return URL::to($this->rota . '/' . $id . '/edit');
     }
     //Validação de permissão
     if (\App\ValidacoesAcesso::PodeAcessarPagina(\Config::get('app.' . $this->rota)) == false) {
         return redirect('home');
     }
     //Verificar qual o tipo de pessoa para habilitar ou não abas e campos conforme o tipo
     //Ex; Pessoa fisica, habilita cpf e rg, juridica habilita CNPJ,  MEMBRO habilita dados especificos de membresia.
     $habilitar_interface = \App\Models\tipospessoas::findOrfail($id_tipo_pessoa);
     //Listagem grupos de pessoas (Para carregar dropdown )
     $grupos = \App\Models\grupospessoas::where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('empresas_id', $this->dados_login->empresas_id)->orderBy('nome', 'ASC')->get();
     //Listagem de bancos (Para carregar dropdown )
     $bancos = \App\Models\bancos::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome')->get();
     $tipos_pessoas = \App\Models\tipospessoas::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome')->get();
     /*Pessoas e dados financeiros*/
     /*Usado dessa forma para formatar a data de nascimento */
     $sQuery = "select to_char(datanasc, 'DD-MM-YYYY') AS datanasc_formatada, pessoas.*, financ_pessoas.id as id_financ, financ_pessoas.bancos_id, financ_pessoas.endereco as endereco_cobranca, financ_pessoas.numero as numero_cobranca, financ_pessoas.bairro as bairro_cobranca, financ_pessoas.cidade as cidade_cobranca, financ_pessoas.estado as estado_cobranca, financ_pessoas.cep as cep_cobranca, financ_pessoas.complemento as complemento_cobranca";
     $sQuery .= " from pessoas left join financ_pessoas on financ_pessoas.pessoas_id = pessoas.id";
     $sQuery .= " where pessoas.id = ? ";
     $sQuery .= " and pessoas.empresas_id = ? ";
     $sQuery .= " and pessoas.empresas_clientes_cloud_id = ? ";
     $sQuery .= " order by razaosocial ";
     $pessoas = \DB::select($sQuery, [$id, $this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
     /*Busca */
     $celulas = \DB::select('select id, descricao_concatenada as nome from view_celulas_simples  where empresas_id = ? and empresas_clientes_cloud_id = ? ', [$this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
     /*Se for MEMBRO, busca informacoes em tabelas especificas*/
     if ($habilitar_interface->membro) {
         //VERIFICA SE PARTICIPA DE CELULAS
         $membros_celula = \DB::select("select celulas_id, to_char(to_date(data_entrada_celula, 'yyyy-MM-dd'), 'DD-MM-YYYY') AS data_entrada_celula,  descricao_concatenada_scod as nome from view_celulas_pessoas  where pessoas_id = ? and  empresas_id = ? and empresas_clientes_cloud_id = ? ", [$id, $this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
         if ($membros_celula == null) {
             unset($membros_celula);
         }
         /*Dados complementares de membros*/
         $membros_dados_pessoais = \App\Models\membros_dados::select('membros_dados_pessoais.*', 'pessoas.razaosocial')->leftjoin('pessoas', 'pessoas.id', '=', 'membros_dados_pessoais.familias_id')->where('membros_dados_pessoais.empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('membros_dados_pessoais.empresas_id', $this->dados_login->empresas_id)->where('membros_dados_pessoais.pessoas_id', $id)->get();
         /*Se nao retornar dados, inicializar variavel com uma colection qualquer*/
         if ($membros_dados_pessoais->count() == 0) {
             unset($membros_dados_pessoais);
         }
         /* Membros Historico Eclesiastico */
         $sQuery = " select pessoas_id, empresas_id, empresas_clientes_cloud_id, ";
         $sQuery .= " igreja_anterior, fone_igreja_anterior, religioes_id, cep_igreja_anterior, endereco_igreja_anterior, ";
         $sQuery .= " numero_igreja_anterior, bairro_igreja_anterior, complemento_igreja_anterior, cidade_igreja_anterior, estado_igreja_anterior, ";
         $sQuery .= " igreja_batismo, celebrador, ata_entrada, ata_saida, motivos_saida_id, motivos_entrada_id, observacoes_hist, ";
         $sQuery .= " to_char(to_date(data_entrada, 'yyyy-MM-dd'), 'DD-MM-YYYY') AS data_entrada, ";
         $sQuery .= " to_char(to_date(data_saida, 'yyyy-MM-dd'), 'DD-MM-YYYY') AS data_saida, ";
         $sQuery .= " to_char(to_date(data_batismo, 'yyyy-MM-dd'), 'DD-MM-YYYY') AS data_batismo ";
         $sQuery .= " from membros_historicos ";
         $sQuery .= " where membros_historicos.pessoas_id = ? ";
         $sQuery .= " and membros_historicos.empresas_id = ? ";
         $sQuery .= " and membros_historicos.empresas_clientes_cloud_id = ? ";
         $membros_historico = \DB::select($sQuery, [$id, $this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
         /*Se nao retornar dados, inicializar variavel com uma colection qualquer*/
         if ($membros_historico == null) {
             unset($membros_historico);
         }
         /*Membros Filhos*/
         $sQuery = " select membros_filhos.id as id_seq,  filhos_id as id, filhos_id, nome_filho, sexo, status_id, estadocivil_id, estados_civis.id as id_estadocivil,  estados_civis.nome as desc_estcivil, status.id as id_status, status.nome as desc_status, ";
         $sQuery .= " to_char(data_nasc, 'DD/MM/YYYY') AS data_nasc, ";
         $sQuery .= " to_char(data_falecimento, 'DD/MM/YYYY') AS data_falecimento ";
         $sQuery .= " from membros_filhos ";
         $sQuery .= " left join estados_civis on estados_civis.id = membros_filhos.estadocivil_id and estados_civis.clientes_cloud_id = membros_filhos.empresas_clientes_cloud_id";
         $sQuery .= " left join status on status.id = membros_filhos.status_id and status.clientes_cloud_id = membros_filhos.empresas_clientes_cloud_id";
         $sQuery .= " where membros_filhos.pessoas_id = ? ";
         $sQuery .= " and membros_filhos.empresas_id = ? ";
         $sQuery .= " and membros_filhos.empresas_clientes_cloud_id = ? ";
         $membros_filhos = \DB::select($sQuery, [$id, $this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
         /*Se nao retornar dados, inicializar variavel com uma colection qualquer*/
         if ($membros_filhos == null) {
             unset($membros_filhos);
         }
         /*Situacoes Membros*/
         $membros_situacoes = \App\Models\membros_situacoes::select('situacoes_id as id')->where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('empresas_id', $this->dados_login->empresas_id)->where('pessoas_id', $id)->get();
         /*Se nao retornar dados, inicializar variavel com uma colection qualquer*/
         if ($membros_situacoes->count() == 0) {
             unset($membros_situacoes);
         }
         /*Dados Profissionais Membros*/
         $membros_profissionais = \App\Models\membros_profissionais::where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('empresas_id', $this->dados_login->empresas_id)->where('pessoas_id', $id)->get();
         /*Se nao retornar dados, inicializar variavel com uma colection qualquer*/
         if ($membros_profissionais->count() == 0) {
             unset($membros_profissionais);
         }
         /*CURSOS EVENTOS*/
         $membros_cursos = \App\Models\membros_cursos::select('cursos.nome', 'data_inicio', 'data_fim', 'observacao', 'cursos.id', 'membros_cursos.ministrante_id', 'membros_cursos.pessoas_id', 'pessoas.razaosocial')->join('cursos', 'cursos.id', '=', 'membros_cursos.cursos_id')->leftjoin('pessoas', 'pessoas.id', '=', 'membros_cursos.ministrante_id')->where('membros_cursos.empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('membros_cursos.empresas_id', $this->dados_login->empresas_id)->where('membros_cursos.pessoas_id', $id)->get();
         /*Se nao retornar dados, inicializar variavel com uma colection qualquer*/
         if ($membros_cursos->count() == 0) {
             unset($membros_cursos);
         }
         $sQuery = " select p3.razaosocial as razaosocial_mae, p2.razaosocial as razaosocial_pai,  pessoas.razaosocial, pessoas_id, membros_familiares.empresas_id, membros_familiares.empresas_clientes_cloud_id, conjuge_id, nome_conjuge, ";
         $sQuery .= " to_char(data_falecimento, 'DD-MM-YYYY') AS data_falecimento, ";
         $sQuery .= " to_char(to_date(data_casamento, 'yyyy-MM-dd'), 'DD/MM/YYYY') AS data_casamento, ";
         $sQuery .= " to_char(data_nasc, 'DD-MM-YYYY') AS data_nasc,";
         $sQuery .= " to_char(data_falecimento_pai, 'DD-MM-YYYY') AS data_falecimento_pai, ";
         $sQuery .= " to_char(data_falecimento_mae, 'DD-MM-YYYY') AS data_falecimento_mae, ";
         $sQuery .= " status_id, profissoes_id, igreja_casamento, pai_id, mae_id, nome_pai, nome_mae, status_pai_id, status_mae_id ";
         $sQuery .= " from membros_familiares";
         $sQuery .= " left join pessoas on pessoas.id = membros_familiares.conjuge_id and pessoas.empresas_id = membros_familiares.empresas_id and pessoas.empresas_clientes_cloud_id = membros_familiares.empresas_clientes_cloud_id";
         $sQuery .= " left join pessoas p2 on p2.id = membros_familiares.pai_id and p2.empresas_id = membros_familiares.empresas_id and p2.empresas_clientes_cloud_id = membros_familiares.empresas_clientes_cloud_id";
         $sQuery .= " left join pessoas p3 on p3.id = membros_familiares.mae_id and p3.empresas_id = membros_familiares.empresas_id and p3.empresas_clientes_cloud_id = membros_familiares.empresas_clientes_cloud_id";
         $sQuery .= " where membros_familiares.pessoas_id = ? ";
         $sQuery .= " and membros_familiares.empresas_id = ? ";
         $sQuery .= " and membros_familiares.empresas_clientes_cloud_id = ? ";
         $membros_familiares = \DB::select($sQuery, [$id, $this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
         /*Se nao retornar dados, inicializar variavel com uma colection qualquer*/
         if ($membros_familiares == null) {
             unset($membros_familiares);
         }
         /*Dados Formacoes*/
         $membros_formacoes = \App\Models\membros_formacoes::select('formacoes_id as id', 'nome')->join('areas_formacao', 'areas_formacao.id', '=', 'membros_formacoes.formacoes_id')->where('membros_formacoes.empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('membros_formacoes.empresas_id', $this->dados_login->empresas_id)->where('pessoas_id', $id)->get();
         if ($membros_formacoes->count() == 0) {
             unset($membros_formacoes);
         }
         /*Dados idiomas*/
         $membros_idiomas = \App\Models\membros_idiomas::select('idiomas_id as id')->where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('empresas_id', $this->dados_login->empresas_id)->where('pessoas_id', $id)->get();
         if ($membros_idiomas->count() == 0) {
             unset($membros_idiomas);
         }
         /*Dons*/
         $membros_dons = \App\Models\membros_dons::select('dons_id as id', 'dons.nome')->join('dons', 'dons.id', '=', 'membros_dons.dons_id')->where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('empresas_id', $this->dados_login->empresas_id)->where('pessoas_id', $id)->get();
         if ($membros_dons->count() == 0) {
             unset($membros_dons);
         }
         /*habilidades*/
         $membros_habilidades = \App\Models\membros_habilidades::select('habilidades_id as id', 'habilidades.nome')->join('habilidades', 'habilidades.id', '=', 'membros_habilidades.habilidades_id')->where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('empresas_id', $this->dados_login->empresas_id)->where('pessoas_id', $id)->get();
         if ($membros_habilidades->count() == 0) {
             unset($membros_habilidades);
         }
         /*atividades*/
         $membros_atividades = \App\Models\membros_atividades::select('atividades_id as id', 'atividades.nome')->join('atividades', 'atividades.id', '=', 'membros_atividades.atividades_id')->where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('empresas_id', $this->dados_login->empresas_id)->where('pessoas_id', $id)->get();
         if ($membros_atividades->count() == 0) {
             unset($membros_atividades);
         }
         /*ministerios*/
         $membros_ministerios = \App\Models\membros_ministerios::select('ministerios_id as id', 'ministerios.nome')->join('ministerios', 'ministerios.id', '=', 'membros_ministerios.ministerios_id')->where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('empresas_id', $this->dados_login->empresas_id)->where('pessoas_id', $id)->get();
         if ($membros_ministerios->count() == 0) {
             unset($membros_ministerios);
         }
         /*membros Relacionamentos*/
         $membros_relacionamentos = \App\Models\membros_relacionamentos::select('tipos_relacionamentos_id as id', 'membros_relacionamentos.pessoas2_id', 'pessoas.razaosocial', 'tipos_relacionamentos.nome')->join('tipos_relacionamentos', 'tipos_relacionamentos.id', '=', 'membros_relacionamentos.tipos_relacionamentos_id')->join('pessoas', 'pessoas.id', '=', 'membros_relacionamentos.pessoas2_id')->where('membros_relacionamentos.empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('membros_relacionamentos.empresas_id', $this->dados_login->empresas_id)->where('membros_relacionamentos.pessoas_id', $id)->get();
         if ($membros_relacionamentos->count() == 0) {
             unset($membros_relacionamentos);
         }
     }
     if ($habilitar_interface->membro) {
         /*
         Para preencher combos Dados eclesiasticos
         */
         $cursos = \App\Models\cursos::where(['empresas_id' => $this->dados_login->empresas_id, 'empresas_clientes_cloud_id' => $this->dados_login->empresas_clientes_cloud_id])->orderBy('nome', 'ASC')->get();
         $igrejas = \App\Models\igrejas::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $situacoes = \App\Models\situacoes::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $idiomas = \App\Models\idiomas::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $status = \App\Models\status::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $profissoes = \App\Models\profissoes::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $ramos = \App\Models\ramos::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $cargos = \App\Models\cargos::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $graus = \App\Models\graus::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $formacoes = \App\Models\areas::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $estadoscivis = \App\Models\civis::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $disponibilidades = \App\Models\disponibilidades::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $dons = \App\Models\dons::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $tiposrelacionamentos = \App\Models\tiposrelacionamentos::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $habilidades = \App\Models\habilidades::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $religioes = \App\Models\religioes::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $atividades = \App\Models\atividades::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $ministerios = \App\Models\ministerios::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         $motivos = \App\Models\tiposmovimentacao::where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->orderBy('nome', 'ASC')->get();
         /* FIM Para preencher combos Dados eclesiasticos*/
         $view_pessoas_movimentacoes = \DB::select("select * from view_pessoas_movimentacoes where id = ? ", [$id]);
         if ($bool_exibir_perfil == "true") {
             $perfil = \DB::select("select * from view_perfil where id = ? and empresas_id = ? and empresas_clientes_cloud_id = ? ", [$id, $this->dados_login->empresas_id, $this->dados_login->empresas_clientes_cloud_id]);
             $pessoas_timeline = \DB::select("select to_char(datanasc, 'DD/MM/YYYY') AS datanasc,  to_char(to_date(data_entrada, 'yyyy-MM-dd'), 'DD/MM/YYYY') AS data_entrada, to_char(to_date(data_entrada_celula, 'yyyy-MM-dd'), 'DD/MM/YYYY') AS data_entrada_celula, to_char(to_date(data_saida, 'yyyy-MM-dd'), 'DD/MM/YYYY') AS data_saida, to_char(to_date(data_batismo, 'yyyy-MM-dd'), 'DD/MM/YYYY') AS data_batismo from view_pessoas_timeline where id = ? ", [$id]);
         } else {
             $perfil = null;
             $pessoas_timeline = null;
         }
         //COLLECTION COM DADOS DA PESSOA
         $var_collections = array('grupos' => $grupos, 'preview' => $preview, 'interface' => $habilitar_interface, 'bancos' => $bancos, 'pessoas' => $pessoas, 'igrejas' => $igrejas, 'situacoes' => $situacoes, 'status' => $status, 'idiomas' => $idiomas, 'profissoes' => $profissoes, 'ramos' => $ramos, 'graus' => $graus, 'formacoes' => $formacoes, 'religioes' => $religioes, 'disponibilidades' => $disponibilidades, 'dons' => $dons, 'habilidades' => $habilidades, 'estadoscivis' => $estadoscivis, 'motivos' => $motivos, 'atividades' => $atividades, 'ministerios' => $ministerios, 'cargos' => $cargos, 'celulas' => $celulas, 'perfil' => $perfil, 'cursos' => $cursos, 'pessoas_timeline' => $pessoas_timeline, 'view_pessoas_movimentacoes' => $view_pessoas_movimentacoes, 'tiposrelacionamentos' => $tiposrelacionamentos, 'tipos_pessoas' => $tipos_pessoas);
         //ACRESCENTA AS COLLECTIONS SOMENTE SE HOUVEREM DADOS
         if (isset($membros_celula)) {
             $var_collections = array_add($var_collections, 'membros_celula', $membros_celula);
         }
         if (isset($membros_situacoes)) {
             $var_collections = array_add($var_collections, 'membros_situacoes', $membros_situacoes);
         }
         if (isset($membros_formacoes)) {
             $var_collections = array_add($var_collections, 'membros_formacoes', $membros_formacoes);
         }
         if (isset($membros_idiomas)) {
             $var_collections = array_add($var_collections, 'membros_idiomas', $membros_idiomas);
         }
         if (isset($membros_atividades)) {
             $var_collections = array_add($var_collections, 'membros_atividades', $membros_atividades);
         }
         if (isset($membros_historico)) {
             $var_collections = array_add($var_collections, 'membros_historico', $membros_historico);
         }
         if (isset($membros_ministerios)) {
             $var_collections = array_add($var_collections, 'membros_ministerios', $membros_ministerios);
         }
         if (isset($membros_familiares)) {
             $var_collections = array_add($var_collections, 'membros_familiares', $membros_familiares);
         }
         if (isset($membros_dons)) {
             $var_collections = array_add($var_collections, 'membros_dons', $membros_dons);
         }
         if (isset($membros_filhos)) {
             $var_collections = array_add($var_collections, 'membros_filhos', $membros_filhos);
         }
         if (isset($membros_habilidades)) {
             $var_collections = array_add($var_collections, 'membros_habilidades', $membros_habilidades);
         }
         if (isset($membros_profissionais)) {
             $var_collections = array_add($var_collections, 'membros_profissionais', $membros_profissionais);
         }
         if (isset($membros_relacionamentos)) {
             $var_collections = array_add($var_collections, 'membros_relacionamentos', $membros_relacionamentos);
         }
         if (isset($membros_cursos)) {
             $var_collections = array_add($var_collections, 'membros_cursos', $membros_cursos);
         }
         if (isset($membros_dados_pessoais)) {
             $var_collections = array_add($var_collections, 'membros_dados_pessoais', $membros_dados_pessoais);
         }
         //dd($var_collections);
         return view($this->rota . ($bool_exibir_perfil == "true" ? '.perfil' : '.edit'), $var_collections);
     } else {
         return view($this->rota . '.edit', ['grupos' => $grupos, 'preview' => $preview, 'interface' => $habilitar_interface, 'bancos' => $bancos, 'pessoas' => $pessoas, 'tipos_pessoas' => $tipos_pessoas]);
     }
 }
 public function store(\Illuminate\Http\Request $request)
 {
     /* ------------------ INICIA TRANSACTION -----------------------*/
     \DB::transaction(function () use($request) {
         $input = $request->except(array('_token'));
         //não levar o token
         /*Validação de campos - request*/
         if ($input['quem'] == "2") {
             $this->validate($request, ['grupo' => 'required', 'pessoas' => 'required']);
         } else {
             $this->validate($request, ['grupo' => 'required']);
         }
         //Pega tipo de pessoa MEMBRO
         $tipos = \App\Models\tipospessoas::select('id')->where('clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)->where('membro', 't')->get();
         if ($input["pessoas"] != "") {
             /*
                            $pessoas = \App\Models\pessoas::select('emailprincipal', 'razaosocial', 'datanasc', 'cpf')
                            ->where('empresas_id', $this->dados_login->empresas_id)
                            ->where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)
                            ->where('emailprincipal', '<>', '')
                            ->where('id', substr($input['pessoas'],0,9))
                            ->get();
             */
             $sSql = " SELECT emailprincipal, razaosocial, datanasc, cpf FROM pessoas ";
             $sSql .= " WHERE empresas_id = " . $this->dados_login->empresas_id . "";
             $sSql .= " AND empresas_clientes_cloud_id = " . $this->dados_login->empresas_clientes_cloud_id . "";
             $sSql .= " and emailprincipal <> '' ";
             $sSql .= " and emailprincipal not in (select email from users)";
             $sSql .= " and id = " . substr($input['pessoas'], 0, 9);
             $pessoas = \DB::select($sSql);
         } else {
             //Lista tipos de pessoas, será usado no botão novo registro para indicar qual tipo de cadastro efetuar
             /*$pessoas = \App\Models\pessoas::select('emailprincipal', 'razaosocial', 'datanasc', 'cpf')
               ->where('empresas_id', $this->dados_login->empresas_id)
               ->where('empresas_clientes_cloud_id', $this->dados_login->empresas_clientes_cloud_id)
               ->where('emailprincipal', '<>', '')
               ->where('tipos_pessoas_id', '=', $tipos[0]->id) //SOMENTE MEMBROS
               ->where('ativo', '=', 'S') //ATIVOS
               ->get();
                */
             $sSql = " SELECT emailprincipal, razaosocial, datanasc, cpf FROM pessoas ";
             $sSql .= " WHERE empresas_id = " . $this->dados_login->empresas_id;
             $sSql .= " AND empresas_clientes_cloud_id = " . $this->dados_login->empresas_clientes_cloud_id;
             $sSql .= " and emailprincipal <> '' ";
             $sSql .= " and emailprincipal not in (select email from users)";
             $sSql .= " and tipos_pessoas_id = " . $tipos[0]->id;
             $sSql .= " and ativo = 'S' ";
             $pessoas = \DB::select($sSql);
         }
         $iQtd = 0;
         foreach ($pessoas as $item) {
             if (rtrim(ltrim($item->cpf)) != "" || rtrim(ltrim($item->datanasc)) != "" || rtrim(ltrim($input['password']))) {
                 $iQtd++;
                 $dados = users::firstOrNew(['email' => strtolower($item->emailprincipal)]);
                 $dados->name = $item->razaosocial;
                 $dados->email = strtolower($item->emailprincipal);
                 $dados->confirmed = 1;
                 //Se for criado usuario pelo usuario.
                 if ($input["gerar"] == "1") {
                     if (rtrim(ltrim($item->cpf)) != "") {
                         $sSenha = substr($item->cpf, 0, 6);
                         $dados->password = bcrypt(substr($item->cpf, 0, 6));
                     } else {
                         if (rtrim(ltrim($item->datanasc)) != "") {
                             $dados->password = bcrypt(substr($item->datanasc, 5, 2) . substr($item->datanasc, 0, 4));
                             $sSenha = substr($item->datanasc, 5, 2) . substr($item->datanasc, 0, 4);
                         } else {
                             //nao tem nenhum
                             $dados->password = "";
                         }
                     }
                 } else {
                     if ($input["gerar"] == "2") {
                         $dados->password = bcrypt($input['password']);
                         $sSenha = $input['password'];
                     }
                 }
                 $dados->membro = "S";
                 $dados->save();
                 //-----------------Cria registro na tabela usuarios para associar com a tabela users
                 $usuarios = usuario::firstOrNew(['id' => $dados->id, 'empresas_id' => $this->dados_login->empresas_id, 'empresas_clientes_cloud_id' => $this->dados_login->empresas_clientes_cloud_id]);
                 $usuarios->id = $dados->id;
                 //id recem cadastrado na tabela users
                 $usuarios->empresas_id = $this->dados_login->empresas_id;
                 $usuarios->empresas_clientes_cloud_id = $this->dados_login->empresas_clientes_cloud_id;
                 $usuarios->master = 0;
                 $usuarios->membro = 'S';
                 $usuarios->save();
                 //-----------------FIM - Cria registro na tabela usuarios para associar com a tabela users
                 //Grava Grupo que o usuário iŕa pertencer
                 $grupo_usuario = \App\Models\usuarios_grupo::firstOrNew(['usuarios_id' => $dados->id, 'usuarios_empresas_id' => $this->dados_login->empresas_id, 'usuarios_empresas_clientes_cloud_id' => $this->dados_login->empresas_clientes_cloud_id]);
                 $grupo_usuario->usuarios_id = $dados->id;
                 $grupo_usuario->usuarios_empresas_id = $this->dados_login->empresas_id;
                 $grupo_usuario->usuarios_empresas_clientes_cloud_id = $this->dados_login->empresas_clientes_cloud_id;
                 $grupo_usuario->grupos_id = $input['grupo'];
                 $grupo_usuario->save();
                 $data = ['email' => $item->emailprincipal, 'nome_igreja' => \Session::get('nome_igreja'), 'nome' => $item->razaosocial, 'senha' => $sSenha];
                 if (isset($input["ckenviar"])) {
                     \Mail::send('emails.bemvindo', ['nome' => $data["nome"], 'nome_igreja' => $data["nome_igreja"], 'email' => $data["email"], 'senha' => $data["senha"]], function ($message) use($data) {
                         $message->from('*****@*****.**', 'Sigma3');
                         $message->subject('Acesso a Área do Membro - ' . $data['nome_igreja']);
                         $message->to($data['email']);
                     });
                 }
             }
         }
         //loop
         if ($iQtd > 0) {
             \Session::flash('flash_message', 'Dados Atualizados com Sucesso!!!');
         } else {
             \Session::flash('flash_message_erro', 'Nenhum registro Atualizado, verifique se o(s) membro(s) possue(m) email cadastrado, CPF ou data de nascimento');
         }
     });
     //FIM TRANSACTION
     return redirect('login_membros');
 }
 /**
  * Excluir registro do banco.
  *
  * @param    int  $id
  * @return  \Illuminate\Http\Response
  */
 public function destroy($id)
 {
     $dados = tipospessoas::findOrfail($id);
     $dados->delete();
     return redirect($this->rota);
 }