User.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. <?php
  2. namespace App\Http\Livewire;
  3. use Illuminate\Support\Facades\Log;
  4. use Livewire\Component;
  5. class User extends Component
  6. {
  7. public $records, $name,$cognome, $email, $password, $oldPassword, $level, $enabled, $dataId, $update = false, $add = false;
  8. public $userExists = false;
  9. protected $rules = [
  10. 'name' => 'required',
  11. 'cognome' => 'required',
  12. 'email' => 'required',
  13. 'password' => 'required'
  14. ];
  15. protected $messages = [
  16. 'name.required' => 'Il nome è obbligatorio',
  17. 'cognome.required' => 'Il cognome è obbligatorio',
  18. 'email.required' => 'La mail è obbligatoria',
  19. 'password.required' => 'La password è obbligatoria',
  20. ];
  21. public function resetFields(){
  22. $this->name = '';
  23. $this->cognome = '';
  24. $this->email = '';
  25. $this->password = '';
  26. $this->oldPassword = '';
  27. $this->level = 0;
  28. $this->enabled = true;
  29. $this->emit('load-data-table');
  30. }
  31. public function render()
  32. {
  33. $this->records = \App\Models\User::select('id', 'name','cognome' ,'email', 'password', 'level', 'enabled')->get();
  34. return view('livewire.user');
  35. }
  36. public function add()
  37. {
  38. $this->resetFields();
  39. $this->add = true;
  40. $this->update = false;
  41. $this->enabled = true;
  42. $this->userExists = false;
  43. }
  44. public function store()
  45. {
  46. Log::info('User store', [
  47. 'name' => $this->name,
  48. 'cognome' => $this->cognome,
  49. 'email' => $this->email,
  50. 'level' => $this->level,
  51. 'enabled' => $this->enabled
  52. ]);
  53. $rules = [
  54. 'name' => 'required',
  55. 'cognome' => 'required',
  56. 'email' => 'required|email|unique:users,email',
  57. 'password' => 'required|min:6'
  58. ];
  59. $messages = [
  60. 'name.required' => 'Il nome è obbligatorio',
  61. 'cognome.required' => 'Il cognome è obbligatorio',
  62. 'email.required' => 'La mail è obbligatoria',
  63. 'email.email' => 'La mail deve essere un indirizzo valido',
  64. 'email.unique' => 'Questa mail è già stata utilizzata',
  65. 'password.required' => 'La password è obbligatoria',
  66. 'password.min' => 'La password deve essere di almeno 6 caratteri'
  67. ];
  68. $this->validate($rules, $messages);
  69. Log::info('User store', [
  70. 'name' => $this->name,
  71. 'cognome' => $this->cognome,
  72. 'email' => $this->email,
  73. 'level' => $this->level,
  74. 'enabled' => $this->enabled
  75. ]);
  76. try {
  77. \App\Models\User::create([
  78. 'name' => $this->name,
  79. 'cognome' => $this->cognome,
  80. 'email' => $this->email,
  81. 'password' => bcrypt($this->password),
  82. 'level' => $this->level,
  83. 'enabled' => $this->enabled
  84. ]);
  85. Log::info('User created', [
  86. 'name' => $this->name,
  87. 'cognome' => $this->cognome,
  88. 'email' => $this->email,
  89. 'level' => $this->level,
  90. 'enabled' => $this->enabled
  91. ]);
  92. session()->flash('success','Utente creato');
  93. $this->resetFields();
  94. $this->add = false;
  95. } catch (\Exception $ex) {
  96. session()->flash('error','Errore (' . $ex->getMessage() . ')');
  97. }
  98. }
  99. public function edit($id){
  100. try {
  101. $user = \App\Models\User::findOrFail($id);
  102. if( !$user) {
  103. session()->flash('error','Dato non trovato');
  104. } else {
  105. $this->name = $user->name;
  106. $this->cognome = $user->cognome;
  107. $this->email = $user->email;
  108. $this->level = $user->level;
  109. $this->dataId = $user->id;
  110. $this->update = true;
  111. $this->add = false;
  112. $this->enabled = $user->enabled;
  113. $this->userExists = true;
  114. }
  115. Log::info('User edit', [
  116. 'name' => $this->name,
  117. 'cognome' => $this->cognome,
  118. 'email' => $this->email,
  119. 'level' => $this->level
  120. ]);
  121. } catch (\Exception $ex) {
  122. session()->flash('error','Errore (' . $ex->getMessage() . ')');
  123. }
  124. }
  125. public function update()
  126. {
  127. $this->validate();
  128. try {
  129. if ($this->pa)
  130. \App\Models\User::whereId($this->dataId)->update([
  131. 'name' => $this->name,
  132. 'cognome' => $this->cognome,
  133. 'email' => $this->email,
  134. 'password' => bcrypt($this->password),
  135. 'level' => $this->level,
  136. 'enabled' => $this->enabled
  137. ]);
  138. Log::info('User updated', [
  139. 'name' => $this->name,
  140. 'cognome' => $this->cognome,
  141. 'email' => $this->email,
  142. 'level' => $this->level,
  143. 'enabled' => $this->enabled
  144. ]);
  145. session()->flash('success','Dato aggiornato');
  146. $this->resetFields();
  147. $this->update = false;
  148. } catch (\Exception $ex) {
  149. session()->flash('error','Errore (' . $ex->getMessage() . ')');
  150. }
  151. }
  152. public function cancel()
  153. {
  154. $this->resetFields();
  155. $this->add = false;
  156. $this->update = false;
  157. $this->userExists = false;
  158. $this->enabled = false;
  159. }
  160. public function delete($id)
  161. {
  162. try{
  163. \App\Models\User::find($id)->delete();
  164. session()->flash('success',"Dato eliminato");
  165. }catch(\Exception $e){
  166. session()->flash('error','Errore (' . $e->getMessage() . ')');
  167. }
  168. }
  169. }