Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

odenilson marques

condição para mostrar valores em uma combobox

Recommended Posts

Boa noite!

 

Pessoal tou desenvolvendo uma aplicação, no entanto empaquei numa parte, se alguém poder da uma ajuda ficaria muito grato!

 

É  o seguinte tenho um banco de dados e nesse banco tenho duas tabelas, a tabela empreendimento e a tabela processo, na minha regra de negocio tenho uma relação de 1:N onde cada empreendimento se relaciona com uma ou mais linha da tabela processo, dessa forma sempre cadastro um empreendimento primeiro para depois cadastrar um processo, até ai tudo bem,

esse cadastro é feito através dos seguintes formulários, formulário de cadastro de  empreendimento e formulário de cadastro de processo. O fluxo das paginas funcionam da seguinte forma, sempre que finalizar um cadastro de empreendimento o formulário de processo é chamado para efetuar o cadastro do mesmo. no entanto, no formulário de processo tenho uma combobox que puxa todos os dados da tabela empreendimento, pois alem de preencher os campos referentes ao processo preciso informar o empreendimento por isso a necessidade da combobox. ate aí tudo bem, porém o usuário responsável pelo cadastro pode começar um cadastro direto pelo formulário de processo caso o empreendimento já esteja cadastrado, para isso basta o usuário preencher os campo referentes ao processo e selecionar o empreendimento na combo, dessa forma todos os empreendimento  aparecem na combo, no entanto se o cadastro começar pela tela de empreendimento assim que fosse chamado o formulário de processo na combo apareceria somente o empreendimento que acabou de ser cadastrado. 

 

Desculpa pelo textão pessoal, mais foi a forma que encontrei de pedi um força

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Bom dia Odenilson,

 

Se entendi esta parte:

"no entanto se o cadastro começar pela tela de empreendimento assim que fosse chamado o formulário de processo na combo apareceria somente o empreendimento que acabou de ser cadastrado."

 

Para resolver basta fazer com que no carregamento do combo, sejam lidos todos os itens da tabela empreendimento, algo como:

<select name="empreendimento" id="empreendimento" >
  <option> Selecione uma opção </option>
  <?php
    $qry_empreendimento = "SELECT * FROM empreendimento";
    $result_empreendimento = mysqli_query($conn, $qry_empreendimento);
    while($reg_empreendimento = mysqli_fetch_assoc($result_empreendimento) ) {
      echo '<option value="'.$reg_empreendimento['empreendimento_ID'].'">'.$reg_empreendimento['empreedimento_Nome'].'</option>';
  }
  ?>
</select><br>

Naturalmente que neste meu código você deve observar os seguintes itens:

  • Não estou usando estilização;
  • Os nomes de campos e tabelas são fictícios;
  • Deduzi que vamos guardar no banco o ID do empreendimento e vamos mostrar no combo o nome dele.

Abraço e espero ter contribuído com algo.

Compartilhar este post


Link para o post
Compartilhar em outros sites
2 horas atrás, Josemir Dias disse:

Bom dia Odenilson,

 

Se entendi esta parte:

"no entanto se o cadastro começar pela tela de empreendimento assim que fosse chamado o formulário de processo na combo apareceria somente o empreendimento que acabou de ser cadastrado."

 

Para resolver basta fazer com que no carregamento do combo, sejam lidos todos os itens da tabela empreendimento, algo como:


<select name="empreendimento" id="empreendimento" >
  <option> Selecione uma opção </option>
  <?php
    $qry_empreendimento = "SELECT * FROM empreendimento";
    $result_empreendimento = mysqli_query($conn, $qry_empreendimento);
    while($reg_empreendimento = mysqli_fetch_assoc($result_empreendimento) ) {
      echo '<option value="'.$reg_empreendimento['empreendimento_ID'].'">'.$reg_empreendimento['empreedimento_Nome'].'</option>';
  }
  ?>
</select><br>

Naturalmente que neste meu código você deve observar os seguintes itens:

  • Não estou usando estilização;
  • Os nomes de campos e tabelas são fictícios;
  • Deduzi que vamos guardar no banco o ID do empreendimento e vamos mostrar no combo o nome dele.

Abraço e espero ter contribuído com algo.

 

Bom dia Josemir, desde já agradeço pelo feedback

 

Dessa forma que você mencionou acima ele mostra na combo todos os empreendimentos salvos na tabela empreendimento no formulário de processo, pois preciso selecionar um empreendimento e cadastrar o restante dos dados do processo, no entanto o que estou precisando é que ao finalizar o cadastro de empreendimento e for chamado o formulário de processo na combo  aparecesse somente o empreendimento que acabou de ser cadastrado.caso contrario aparecesse todos os empreendimentos na combo.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Odenilson, 

 

"o que estou precisando é que ao finalizar o cadastro de empreendimento e for chamado o formulário de processo na combo  aparecesse somente o empreendimento que acabou de ser cadastrado.caso contrario aparecesse todos os empreendimentos na combo."

 

Em outras palavras, se a página de processos estiver sendo aberta através de uma página de empreendimento, ele carrega apenas o empreendimento, senão, todos os registros da tabela empreendimento. É isso que precisa?

 

Uma pergunta, existe algum caso em que o usuário passe pela página de empreendimento sem cadastrar nenhum empreendimento e depois chame a página de processo?

 

Aguardo para concluir meu raciocínio.

Compartilhar este post


Link para o post
Compartilhar em outros sites
2 horas atrás, Josemir Dias disse:

Odenilson, 

 

"o que estou precisando é que ao finalizar o cadastro de empreendimento e for chamado o formulário de processo na combo  aparecesse somente o empreendimento que acabou de ser cadastrado.caso contrario aparecesse todos os empreendimentos na combo."

 

Em outras palavras, se a página de processos estiver sendo aberta através de uma página de empreendimento, ele carrega apenas o empreendimento, senão, todos os registros da tabela empreendimento. É isso que precisa?

 

Uma pergunta, existe algum caso em que o usuário passe pela página de empreendimento sem cadastrar nenhum empreendimento e depois chame a página de processo?

 

Aguardo para concluir meu raciocínio.

Josemir,

 

Em outras palavras, se a página de processos estiver sendo aberta através de uma página de empreendimento, ele carrega apenas o empreendimento, senão, todos os registros da tabela empreendimento. É isso que precisa?

 

isso mesmo, Josemir

 

Uma pergunta, existe algum caso em que o usuário passe pela página de empreendimento sem cadastrar nenhum empreendimento e depois chame a página de processo?

 

Não sempre que chamar a pagina de empreendimento tem que realizar um cadastro

Compartilhar este post


Link para o post
Compartilhar em outros sites

Bom dia Odenilson,

 

Excelente, então, temos dois parâmetros claros para elaborar a lógica. Uma possível solução (existem várias para este caso), é que você pode marcar a página de empreendimento através de uma flag e obtê-la pelo $_GET e, para carregar apenas o empreendimento cadastrado envia-lo via $_SESSION (acho arriscado enviar o ID do processo via $_GET também). Neste caso teríamos algo como:

 

Na página de empreendimento, ao levar os dados para página de processo, uma marcação indicando que o cadastro foi feito:

<form method = 'POST' action = 'processos.php?empreendimento=1'>

Antes da rotina de inserção dos dados (que pode ser uma função, estar na mesma página ou em outra), você avalia qual será o ID inserido e grava ele numa $_SESSION:

<?php 
	$qry_empreendimento = mysqli_query($conn,"SELECT AUTO_INCREMENT FROM information_schema.tables WHERE  table_name = 'empreendimento' AND table_schema = 'BANCODEDADOS'");
	$result_empreend_ID = mysqli_query($conn, $qry_empreendimento);
	
	$_SESSION['empreend_ID'] = $result_empreend_ID;
?>

Na página de processos a recepção dos dados de empreendimento cadastrados com a validação para sabermos se a página de processos foi aberta através da página de empreendimento ou não:

<select name="id_empreendimento" id="id_empreendimento">
	<option value="Nenhum"> Selecione uma opção </option>
	<?php
		if(!isset($_GET['empreendimento'])){
			$qry_empreendimento = mysqli_query($conn,"SELECT * FROM empreendimento");
		}else{
			$qry_empreendimento = mysqli_query($conn,"SELECT empreendimento_ID, empreendimento_Nome FROM empreendimento WHERE empreendimento_ID = ".$_SESSION['empreend_ID']);
		}
		$result_empreendimento = mysqli_query($conn, $qry_empreendimento);
		while($registro = mysqli_fetch_assoc($result_empreendimento) ) {
			echo '<option value="'.$registro['ID'].'">'.$row_user['empreendimento_Nome'].'</option>';
		}
	?>
</select>

Nos exemplos citados acima, estamos indicando para página de processos que, se a página estiver sendo aberta através da página de empreendimento, ele deve carregar no combo, apenas o empreendimento cadastrado, do contrário deve carregar todos.

 

A partir dai, imagino que seja só escrever as rotinas de captura dos dados e gravação.

 

Espero ter conseguido ajudar, forte abraço e bom trabalho.

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 14/09/2018 at 08:34, Josemir Dias disse:

Bom dia Odenilson,

 

Excelente, então, temos dois parâmetros claros para elaborar a lógica. Uma possível solução (existem várias para este caso), é que você pode marcar a página de empreendimento através de uma flag e obtê-la pelo $_GET e, para carregar apenas o empreendimento cadastrado envia-lo via $_SESSION (acho arriscado enviar o ID do processo via $_GET também). Neste caso teríamos algo como:

 

Na página de empreendimento, ao levar os dados para página de processo, uma marcação indicando que o cadastro foi feito:


<form method = 'POST' action = 'processos.php?empreendimento=1'>

Antes da rotina de inserção dos dados (que pode ser uma função, estar na mesma página ou em outra), você avalia qual será o ID inserido e grava ele numa $_SESSION:


<?php 
	$qry_empreendimento = mysqli_query($conn,"SELECT AUTO_INCREMENT FROM information_schema.tables WHERE  table_name = 'empreendimento' AND table_schema = 'BANCODEDADOS'");
	$result_empreend_ID = mysqli_query($conn, $qry_empreendimento);
	
	$_SESSION['empreend_ID'] = $result_empreend_ID;
?>

Na página de processos a recepção dos dados de empreendimento cadastrados com a validação para sabermos se a página de processos foi aberta através da página de empreendimento ou não:


<select name="id_empreendimento" id="id_empreendimento">
	<option value="Nenhum"> Selecione uma opção </option>
	<?php
		if(!isset($_GET['empreendimento'])){
			$qry_empreendimento = mysqli_query($conn,"SELECT * FROM empreendimento");
		}else{
			$qry_empreendimento = mysqli_query($conn,"SELECT empreendimento_ID, empreendimento_Nome FROM empreendimento WHERE empreendimento_ID = ".$_SESSION['empreend_ID']);
		}
		$result_empreendimento = mysqli_query($conn, $qry_empreendimento);
		while($registro = mysqli_fetch_assoc($result_empreendimento) ) {
			echo '<option value="'.$registro['ID'].'">'.$row_user['empreendimento_Nome'].'</option>';
		}
	?>
</select>

Nos exemplos citados acima, estamos indicando para página de processos que, se a página estiver sendo aberta através da página de empreendimento, ele deve carregar no combo, apenas o empreendimento cadastrado, do contrário deve carregar todos.

 

A partir dai, imagino que seja só escrever as rotinas de captura dos dados e gravação.

 

Espero ter conseguido ajudar, forte abraço e bom trabalho.

 

Boa noite Josemir, obg pela força, deixa eu lhe perguntar essa parte  é referente ao formulário  de empreendimento?

<form method = 'POST' action = 'processos.php?empreendimento=1'>

Compartilhar este post


Link para o post
Compartilhar em outros sites
2 minutos atrás, odenilson marques disse:

 

Boa noite Josemir, obg pela força, deixa eu lhe perguntar essa parte  é referente ao formulário  de empreendimento?


<form method = 'POST' action = 'processos.php?empreendimento=1'>

Boa noite Odenilson,

 

É sempre um prazer ajudar. Sim, esta parte é no form de empreendimento. Ali, estamos dizendo que quando clicarmos no botão para cadastrar o empreendimento, ele deve enviar os dados cadastrados via $_POST.

 

Também estamos dizendo para página de processos que um empreendimento foi cadastrado nesta parte:

processos.php?empreendimento=1

 

Forte abraço

Compartilhar este post


Link para o post
Compartilhar em outros sites
17 minutos atrás, Josemir Dias disse:

Boa noite Odenilson,

 

É sempre um prazer ajudar. Sim, esta parte é no form de empreendimento. Ali, estamos dizendo que quando clicarmos no botão para cadastrar o empreendimento, ele deve enviar os dados cadastrados via $_POST.

 

Também estamos dizendo para página de processos que um empreendimento foi cadastrado nesta parte:

processos.php?empreendimento=1

 

Forte abraço

 ta certo!

 

A minha duvida está no action, tipo: como o meu form é de empreendimento, no action no meu caso tinha colocado action="recebe_empreendimento.php" para receber os dados inseridos no form de empreendimento, daria para deixar mais explicito essa parte?

Compartilhar este post


Link para o post
Compartilhar em outros sites
1 minuto atrás, odenilson marques disse:

 ta certo!

 

A minha duvida está no action, tipo: como o meu form é de empreendimento, no action no meu caso tinha colocado action="recebe_empreendimento.php" para receber os dados inseridos no form de empreendimento, daria para deixar mais explicito essa parte?

Sim, vamos lá:

Como exemplo, eu chamei a página onde serão cadastrados os processos, de "processos.php", mas, pelo que entendi, ela chama "recebe_empreendimento.php". Se for isso, teremos:

action = 'recebe_empreendimento.php?empreendimento=1'

Neste caso, quando clicar no botão para cadastrar o empreendimento, serão enviados via $_POST os dados cadastrados do empreendimento e via $_GET estamos informando 1 para dizer que foi cadastrado um empreendimento (empreendimento=1).

 

Espero ter conseguido esclarecer a dúvida.

Compartilhar este post


Link para o post
Compartilhar em outros sites
4 minutos atrás, Josemir Dias disse:

Sim, vamos lá:

Como exemplo, eu chamei a página onde serão cadastrados os processos, de "processos.php", mas, pelo que entendi, ela chama "recebe_empreendimento.php". Se for isso, teremos:


action = 'recebe_empreendimento.php?empreendimento=1'

Neste caso, quando clicar no botão para cadastrar o empreendimento, serão enviados via $_POST os dados cadastrados do empreendimento e via $_GET estamos informando 1 para dizer que foi cadastrado um empreendimento (empreendimento=1).

 

Espero ter conseguido esclarecer a dúvida.

 

Belaza meu amigo, essa parte compreendi

 

ja lhe incomodando novamente, em relação a parte baixo, essa inserção seria na tabela empreendimento certo? caso for, você está se referindo a capturar o ultimo código inserido?

Antes da rotina de inserção dos dados (que pode ser uma função, estar na mesma página ou em outra), você avalia qual será o ID inserido e grava ele numa $_SESSION:

<?php 
	$qry_empreendimento = mysqli_query($conn,"SELECT AUTO_INCREMENT FROM information_schema.tables WHERE  table_name = 'empreendimento' AND table_schema = 'BANCODEDADOS'");
	$result_empreend_ID = mysqli_query($conn, $qry_empreendimento);
	
	$_SESSION['empreend_ID'] = $result_empreend_ID;
?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Sim, 

 

Neste código estamos avaliando todos os IDs da tabela empreendimento e pegando qual será o último ID, já que não temos no post a forma que você está usando para cadastrar os dados na tabela.

 

Com a previsão de qual será o último ID, podemos gravar uma $_SESSION que será levada para página "recebe_empreendimento" com a ID do empreendimento que foi cadastrado e, com isso, conseguimos gerar a consulta para trazer apenas o último empreendimento.

Compartilhar este post


Link para o post
Compartilhar em outros sites
22 minutos atrás, Josemir Dias disse:

Sim, 

 

Neste código estamos avaliando todos os IDs da tabela empreendimento e pegando qual será o último ID, já que não temos no post a forma que você está usando para cadastrar os dados na tabela.

 

Com a previsão de qual será o último ID, podemos gravar uma $_SESSION que será levada para página "recebe_empreendimento" com a ID do empreendimento que foi cadastrado e, com isso, conseguimos gerar a consulta para trazer apenas o último empreendimento.

 josemir para capturar o ultimo id tou usando esse codigo:, no entanto quando faço um teste na pagina de processo tanto chamando a pagina de processo depois de cadastrar um empreendimento ou não a combo nao aparece nada na combo, será que o bug ta nessa parte do codigo?

 

$ultimo_cod = mysqli_insert_id($con);
     echo $ultimo_cod;
 $_SESSION['ultimo_cod'] = $ultimo_cod;

 

porque observei que tu utilizou  essa linha de codigo 

 

$qry_empreendimento = mysqli_query($conn,"SELECT AUTO_INCREMENT FROM information_schema.tables WHERE  table_name = 'empreendimento' AND table_schema = 'BANCODEDADOS'");

Compartilhar este post


Link para o post
Compartilhar em outros sites

@odenilson marques,

 

Depende muito de como está seu código no arquivo que cria a combo.

Quando você roda este código acima, ele chega a retornar o valor de  $ultimo_cod neste echo?

Se sim, o problema não está neste código e sim na criação do combo e na obtenção dos dados que provem da página empreendimentos.

Compartilhar este post


Link para o post
Compartilhar em outros sites
2 minutos atrás, Josemir Dias disse:

@odenilson marques,

 

Depende muito de como está seu código no arquivo que cria a combo.

Quando você roda este código acima, ele chega a retornar o valor de  $ultimo_cod neste echo?

Se sim, o problema não está neste código e sim na criação do combo e na obtenção dos dados que provem da página empreendimentos.

é verdade, ele retorna sim

Compartilhar este post


Link para o post
Compartilhar em outros sites

Então já temos um parâmetro claro.

 

Se ele retorna no echo o valor de $ultimo_cod e a variável $_SESSION, está sendo preenchida corretamente, temos algumas possibilidades:

  • A variável $_SESSION está sendo apagada ao carregar a página de processos;
  • A variável $_SESSION não está sendo inserida na página de processos;

Posta o código da página de processos pra gente dar uma olhada.

 

Talvez o problema esteja em como você está executando a consulta para popular o combo. 

Compartilhar este post


Link para o post
Compartilhar em outros sites
18 minutos atrás, Josemir Dias disse:

Então já temos um parâmetro claro.

 

Se ele retorna no echo o valor de $ultimo_cod e a variável $_SESSION, está sendo preenchida corretamente, temos algumas possibilidades:

  • A variável $_SESSION está sendo apagada ao carregar a página de processos;
  • A variável $_SESSION não está sendo inserida na página de processos;

Posta o código da página de processos pra gente dar uma olhada.

 

Talvez o problema esteja em como você está executando a consulta para popular o combo. 

 

<form  action="recebe_cad_processo.php"  method="POST" name="frmprocesso" id="frmprocesso">
                        
      <div class="row">
          <div class="col-sm-12">
               <div class="form-group">
                    <label for="empreendimento"><strong>Empreendimento*</strong></label><br/>
                         <select name="empreendimento" id="empreendimento" class="form-control" autofocus="">
                                                    
                            <?php 
                               if(!isset($_GET['empreendimento'])){
                                  $qry_empreendimento = mysqli_query($con,"SELECT * FROM tb_empreendimento");
                               }else{
                                  $qry_empreendimento = mysqli_query($con,"SELECT codigo_empreendimento, nome_empreendimento FROM tb_empreendimento WHERE codigo_empreendimento = ".$_SESSION['ultimo_cod']);
                                    }
                                    $result_empreendimento = mysqli_query($con, $qry_empreendimento);
                                     while($regidtro = mysqli_fetch_assoc($result_empreendimento) ) {
                                         echo '<option value="'.$registro['codigo_empreendimento'].'">'.$row_user['nome_empreendimento'].'</option>';                           
                                     }                                                       
                                ?>                                    
                            </select>
                      </div>                                            
                  </div>
               </div>                                    
            </div>
        </div>
     </div>
     <div class="panel panel-default">
       <div class="panel-title" style="text-align: center;"><br/>
          <input type="submit" value="REALIZAR CADASTRO" class="btn btn-success" style="font-size: 17px; font-weight: bold;"/>
          <button  class="btn btn-danger"><a href="home.php"  style="font-size: 17px; font-weight: bold; color: #fff;text-decoration: none;">CANCELAR CADASTRO</a></button><br/><br/>
        </div>   
   </div>
 </form>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Vamos fazer algumas alterações no código PHP para popular o combo.

 

<?php 
if(!isset($_GET['empreendimento'])){
  $qry_empreendimento = mysqli_query($con,"SELECT * FROM tb_empreendimento");
}else{
  $qry_empreendimento = mysqli_query($con,"SELECT codigo_empreendimento, nome_empreendimento FROM tb_empreendimento WHERE codigo_empreendimento = ".$_SESSION['ultimo_cod']);
}
//$result_empreendimento = mysqli_query($con, $qry_empreendimento);
while($registro = mysqli_fetch_assoc($qry_empreendimento) ) {
  echo '<option value="'.$registro['codigo_empreendimento'].'">'.$registro['nome_empreendimento'].'</option>';                           
}                                                       
?>

Copia e cola este código e sem alterar nada, substitui o teu código atual por este.

Me diz o resultado.

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 16/09/2018 at 01:36, Josemir Dias disse:

Vamos fazer algumas alterações no código PHP para popular o combo.

 


<?php 
if(!isset($_GET['empreendimento'])){
  $qry_empreendimento = mysqli_query($con,"SELECT * FROM tb_empreendimento");
}else{
  $qry_empreendimento = mysqli_query($con,"SELECT codigo_empreendimento, nome_empreendimento FROM tb_empreendimento WHERE codigo_empreendimento = ".$_SESSION['ultimo_cod']);
}
//$result_empreendimento = mysqli_query($con, $qry_empreendimento);
while($registro = mysqli_fetch_assoc($qry_empreendimento) ) {
  echo '<option value="'.$registro['codigo_empreendimento'].'">'.$registro['nome_empreendimento'].'</option>';                           
}                                                       
?>

Copia e cola este código e sem alterar nada, substitui o teu código atual por este.

Me diz o resultado.

 Bom dia  Josemir, quero lhe agradecer pela força, suas dicas me ajudaram bastante, conseguir resolver, obg Deus lhe abençoe sempre. 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Por favor, me permita tirar uma dúvida com os amigos.

      Tenho um Formulário onde o Usuário digita todos os Dados necessários.

      Minha dúvida:
      --> como faço após o usuário digitar os dados e salvar, o Sistema chamar uma Modal ou mensagem perguntando se deseja imprimir agora ?

      Grato,
       
      Cesar
    • Por Carcleo
      Tenho uma abela de usuarios e uma tabela de administradores e clientes.
      Gostaria de uma ajuda para implementar um cadastro
       
      users -> name, login, passord (pronta) admins -> user_id, registratiom, etc.. client -> user_id, registratiom, etc...
      Queria ajuda para extender de user as classes Admin e Client
      Olhem como estáAdmin
      <?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Admin extends User {     use HasFactory;            protected $fillable = [         'name',         'email',         'password',         'registration'     ];      private string $registration;     public function create(         string $name,          string $email,          string $password,         string $registration     )     {         //parent::create(['name'=>$name, 'email'=>$email, 'password'=>$password]);         parent::$name = $name;         parent::$email = $email;         parent::$password = $password;         $this->registration = $registration;     } } User
      <?php namespace App\Models; // use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Illuminate\Database\Eloquent\Relations\BelongsToMany; class User extends Authenticatable {     /** @use HasFactory<\Database\Factories\UserFactory> */     use HasFactory, Notifiable;     static string $name;     static string $email;     static string $password;     /**      * The attributes that are mass assignable.      *      * @var list<string>      */     protected $fillable = [         'name',         'email',         'password',     ];          /**      * The attributes that should be hidden for serialization.      *      * @var list<string>      */     protected $hidden = [         'remember_token',     ];     /**      * Get the attributes that should be cast.      *      * @return array<string, string>      */     protected function casts(): array     {         return [             'email_verified_at' => 'datetime',             'password' => 'hashed',         ];     }          public function roles() : BelongsToMany {         return $this->belongsToMany(Role::class);     }       public function hasHole(Array $roleName): bool     {                 foreach ($this->roles as $role) {             if ($role->name === $roleName) {                 return true;             }         }         return false;     }         public function hasHoles(Array $rolesName): bool     {                 foreach ($this->roles as $role) {             foreach ($rolesName as $rolee) {             if ($role->name === $rolee) {                 return true;             }          }         }         return false;     }         public function hasAbility(string $ability): bool     {         foreach ($this->roles as $role) {             if ($role->abilities->contains('name', $ability)) {                 return true;             }         }         return false;     }     } Como gravar um Admin na tabela admins sendo que ele é um User por extensão?
      Tentei assim mas é claro que está errado...
      public function store(Request $request, Admin $adminModel) {         $dados = $request->validate([             "name" => "required",             "email" => "required|email",             "password" => "required",             "registration" => "required"         ]);         $dados["password"] =  Hash::make($dados["password"]);                  $admin = Admin::where("registration",  $dados["registration"])->first();                  if ($admin)              return                    redirect()->route("admin.new")                             ->withErrors([                                 'fail' => 'Administrador já cadastrados<br>, favor verificar!'                   ]);                            $newAdmin = $adminModel->create(                                    $dados['name'],                                    $dados['email'],                                    $dados['password'],                                    $dados['registration']                                 );         dd($newAdmin);         $adminModel->save();         //$adminModel::create($admin);                  return redirect()->route("admin.new")->with("success",'Cadastrado com sucesso');     }  
    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos, referente a PDV.
       
      Estou escrevendo um Sistema com Ponto de Vendas, a minha dúvida é o seguinte, referente ao procedimento mais correto.

      Conforme o caixa vai efetuando a venda, o Sistema de PDV já realiza:
      a baixa direto dos produtos no estoque
      ou
      somente após concretizar a venda o sistema baixa os produtos do estoque ?
       
      Grato,
       
      Cesar
       
    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por ILR master
      Fala galera, tudo certo?
       
      Seguinte: No servidor A estou tentando fazer uma consulta com o servidor B, mas está dando erro.
      Estou usando o mesmo código de conexão do servidor B que funciona perfeitamente, mas no servidor A, dá erro.
      Segue código:
       
      $host = 'servidor B';
      $user = 'user';
      $pass = '********';
      $db   = 'banco';
       
      // conexão e seleção do banco de dados
      $conexao = mysqlI_connect($host, $user, $pass, $db);
      mysqlI_set_charset($conexao,"utf8");
      //print "Conexão rodando e OK!"; 
      //mysqlI_close($conexao);
       
      Alguém pode me ajudar?
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.