feat|fix: Constrói um componente de controller para exibição de usuários e ajusta alguns detalhes dos demais componentes de controller.

This commit is contained in:
lukibeg 2025-11-10 21:59:33 -03:00
parent 63aa8864c8
commit dbc8de4ede
3 changed files with 38 additions and 54 deletions

View File

@ -3,53 +3,43 @@
namespace App\Livewire\Admin; namespace App\Livewire\Admin;
use App\Models\Client; use App\Models\Client;
use App\Services\ClientService;
use App\Livewire\Forms\ClientForm; // 1. Importa seu Form Object use App\Livewire\Forms\ClientForm; // 1. Importa seu Form Object
use Livewire\Component; use Livewire\Component;
use Livewire\WithFileUploads; use Livewire\WithFileUploads;
use Livewire\Attributes\On; use Illuminate\Support\Facades\Crypt;
class AddClient extends Component class AddClient extends Component
{ {
use WithFileUploads; use WithFileUploads;
// 1. Declara as propriedades principais
public ClientForm $form; public ClientForm $form;
/** public function save(ClientService $clientService)
* Método principal chamado pelo wire:submit="save".
*/
public function save()
{ {
// 2. Valida os dados usando as 'rules' do ClientForm.php
$this->form->validate(); $this->form->validate();
try { try {
$data = $this->form->all(); $data = $this->form->all();
$data['name'] = $data['client_name']; $data['name'] = $data['client_name'];
// 4. Lida com o upload do arquivo de imagem
if ($this->form->profile_image_path) { if ($this->form->profile_image_path) {
$path = $this->form->profile_image_path->store('client_logos', 'public'); $path = $this->form->profile_image_path->store('client_logos', 'public');
$data['profile_image_path'] = $path; $data['profile_image_path'] = $path;
} }
// 5. Cria o cliente no banco de dados $data['root_password'] = Crypt::encryptString($data['root_password']);
Client::create($data);
// 6. Despacha um evento para atualizar outros componentes (ex: o grid de clientes) $clientService->addClient($data);
$this->dispatch('client-added'); $this->dispatch('client-added');
// (Opcional) Envia uma notificação de sucesso
$this->dispatch('notify', message: 'Cliente adicionado com sucesso!'); $this->dispatch('notify', message: 'Cliente adicionado com sucesso!');
} catch (\Exception $e) { } catch (\Exception $e) {
dd($e);
$this->dispatch('notify', message: 'Ocorreu um erro inesperado ao salvar.', type: 'error'); $this->dispatch('notify', message: 'Ocorreu um erro inesperado ao salvar.', type: 'error');
} }
// 3. Pega todos os dados validados
} }
/**
* Renderiza a view do modal.
*/
public function render() public function render()
{ {
return view('livewire.admin.add-client'); return view('livewire.admin.add-client');

View File

@ -2,27 +2,24 @@
namespace App\Livewire\Admin; namespace App\Livewire\Admin;
use App\Services\UserService; // <-- Importe seu Service use App\Services\UserService;
use Illuminate\Support\Facades\Auth;
use Livewire\Component; use Livewire\Component;
class CreateUser extends Component class CreateUser extends Component
{ {
// 1. Propriedades públicas (os campos do formulário)
// Elas substituem o 'Request $request'
public string $name = ''; public string $name = '';
public string $email = ''; public string $email = '';
public string $password = ''; public string $password = '';
public string $password_confirm = ''; // <-- Você também precisa deste public string $password_confirm = '';
public bool $permission_level = false; public bool $permissions = false;
// 2. As regras de validação (copiadas do seu controller)
// Nota: Adicionei 'same:password' para garantir que as senhas batem.
protected $rules = [ protected $rules = [
'name' => 'required|string|max:255', 'name' => 'required|string|max:255',
'email' => 'required|email|unique:users,email', 'email' => 'required|email|unique:users,email',
'password' => 'required|string|min:8', 'password' => 'required|string|min:8',
'password_confirm' => 'required|string|same:password', // <-- Regra importante! 'password_confirm' => 'required|string|same:password',
'permission_level' => 'required|boolean' // ou 'required|in:0,1' 'permissions' => 'required|boolean'
]; ];
protected $messages = [ protected $messages = [
@ -31,48 +28,32 @@ class CreateUser extends Component
'email.unique' => 'O email informado já foi cadastrado anteriormente.', 'email.unique' => 'O email informado já foi cadastrado anteriormente.',
'password' => 'A senha precisa ter 8 ou mais caracteres.', 'password' => 'A senha precisa ter 8 ou mais caracteres.',
'password_confirm' => 'As senhas não coincidem.', 'password_confirm' => 'As senhas não coincidem.',
'permission_level' => 'Defina o nível de autorização do usuário.' 'permissions' => 'Defina o nível de autorização do usuário.',
]; ];
/**
* O método de "salvar", que substitui o seu 'createUsers'.
*
* Note como injetamos o UserService direto no método!
* O Livewire cuida disso para você, assim como o Laravel faz nos controllers.
*/
public function createUser(UserService $userService) public function createUser(UserService $userService)
{ {
// 3. Valida as propriedades públicas ($this->name, $this->email, etc.)
$validated = $this->validate($this->rules, $this->messages); $validated = $this->validate($this->rules, $this->messages);
// 4. Seu 'try...catch' - praticamente idêntico
if ($validated['permissions'] === true) {
$validated['permissions'] = array('admin');
} else {
$validated['permissions'] = array('user');
}
try { try {
// 5. CHAMA O MESMO SERVICE! Nenhuma lógica de negócio é duplicada. $this->authorize('createUser', Auth::user());
$user = $userService->createUser($validated); $user = $userService->createUser($validated);
// 6. O "Sucesso" (Tradução do Redirect)
// Limpa o formulário
$this->reset(); $this->reset();
// Dispara um evento para o Alpine.js fechar o modal
$this->dispatch('user-created'); $this->dispatch('user-created');
// Envia a mesma mensagem de sucesso do seu controller
$this->dispatch('notify', message: 'Usuário cadastrado com sucesso!'); $this->dispatch('notify', message: 'Usuário cadastrado com sucesso!');
// (Opcional) Se sua tabela de usuários for outro componente Livewire,
// você pode mandar ela atualizar assim:
// $this->dispatch('refreshUserList');
} catch (\Exception $e) { } catch (\Exception $e) {
// 7. O "Erro" (Tradução do Redirect de Erro)
// Em vez de redirecionar, adicionamos o erro ao formulário
// para que o usuário veja na tela, sem refresh.
$this->addError('general', $e->getMessage()); $this->addError('general', $e->getMessage());
} }
} }

View File

@ -0,0 +1,13 @@
<?php
namespace App\Livewire\Admin;
use Livewire\Component;
class ShowUsers extends Component
{
public function render()
{
return view('livewire.admin.show-users');
}
}