Bank.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <?php
  2. namespace App\Http\Livewire;
  3. use Livewire\Component;
  4. use Illuminate\Support\Facades\Auth;
  5. use App\Http\Middleware\TenantMiddleware;
  6. class Bank extends Component
  7. {
  8. public $records, $name, $enabled, $dataId, $update = false, $add = false;
  9. protected $rules = [
  10. 'name' => 'required'
  11. ];
  12. protected $messages = [
  13. 'name.required' => 'Il nome è obbligatorio'
  14. ];
  15. public $sortField ='name';
  16. public $sortAsc = true;
  17. public function boot()
  18. {
  19. app(TenantMiddleware::class)->setupTenantConnection();
  20. }
  21. public function mount(){
  22. if(Auth::user()->level != env('LEVEL_ADMIN', 0))
  23. return redirect()->to('/dashboard');
  24. }
  25. public function sortBy($field)
  26. {
  27. if($this->sortField === $field)
  28. {
  29. $this->sortAsc = ! $this->sortAsc;
  30. } else {
  31. $this->sortAsc = true;
  32. }
  33. $this->sortField = $field;
  34. }
  35. public function resetFields(){
  36. $this->name = '';
  37. $this->enabled = true;
  38. $this->emit('load-data-table');
  39. }
  40. public function render()
  41. {
  42. //$this->records = \App\Models\Bank::select('id', 'name', 'enabled')->orderBy($this->sortField, $this->sortAsc ? 'asc' : 'desc')->get();
  43. $this->records = \App\Models\Bank::select('id', 'name', 'enabled')->get();
  44. return view('livewire.bank');
  45. }
  46. public function add()
  47. {
  48. $this->resetFields();
  49. $this->add = true;
  50. $this->update = false;
  51. }
  52. public function store()
  53. {
  54. $this->validate();
  55. try {
  56. \App\Models\Bank::create([
  57. 'name' => $this->name,
  58. 'enabled' => $this->enabled
  59. ]);
  60. session()->flash('success','Città creata');
  61. $this->resetFields();
  62. $this->add = false;
  63. } catch (\Exception $ex) {
  64. session()->flash('error','Errore (' . $ex->getMessage() . ')');
  65. }
  66. }
  67. public function edit($id){
  68. try {
  69. $bank = \App\Models\Bank::findOrFail($id);
  70. if( !$bank) {
  71. session()->flash('error','Città non trovata');
  72. } else {
  73. $this->name = $bank->name;
  74. $this->enabled = $bank->enabled;
  75. $this->dataId = $bank->id;
  76. $this->update = true;
  77. $this->add = false;
  78. }
  79. } catch (\Exception $ex) {
  80. session()->flash('error','Errore (' . $ex->getMessage() . ')');
  81. }
  82. }
  83. public function update()
  84. {
  85. $this->validate();
  86. try {
  87. \App\Models\Bank::whereId($this->dataId)->update([
  88. 'name' => $this->name,
  89. 'enabled' => $this->enabled
  90. ]);
  91. session()->flash('success','Città aggiornata');
  92. $this->resetFields();
  93. $this->update = false;
  94. } catch (\Exception $ex) {
  95. session()->flash('error','Errore (' . $ex->getMessage() . ')');
  96. }
  97. }
  98. public function cancel()
  99. {
  100. $this->add = false;
  101. $this->update = false;
  102. $this->resetFields();
  103. }
  104. public function delete($id)
  105. {
  106. try{
  107. \App\Models\Bank::find($id)->delete();
  108. session()->flash('success',"Città eliminata");
  109. return redirect(request()->header('Referer'));
  110. }catch(\Exception $e){
  111. session()->flash('error','Errore (' . $e->getMessage() . ')');
  112. }
  113. }
  114. }