Waiter.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Helpers\CommonMethods;
  4. use App\Models\Photos;
  5. use App\Models\RestoTables;
  6. use App\Models\User;
  7. use App\Models\Waiters;
  8. use App\Models\WaiterTables;
  9. use Illuminate\Http\Request;
  10. use Illuminate\Support\Facades\Auth;
  11. use Illuminate\Support\Facades\Hash;
  12. use Illuminate\Support\Facades\Storage;
  13. use Illuminate\Support\Str;
  14. use File;
  15. class Waiter extends Controller
  16. {
  17. //
  18. public function waiters(){
  19. $waiters = Auth::user()->restaurants->waiters;
  20. $data = [
  21. 'waiters' => $waiters
  22. ];
  23. return view('waiters.waiters',$data);
  24. }
  25. public function new_waiter(){
  26. $tables = RestoTables::whereNull('deleted_at')->where('resto_id',Auth::user()->restaurants->id)->where('is_active',1)->doesnthave('waiter_tables')->get();
  27. $data = ['tables'=>$tables];
  28. return view('waiters.waiter_form',$data);
  29. }
  30. public function save(Request $request){
  31. // dd($request->all());
  32. $id = $request->id;
  33. if(empty($id)){
  34. $waiter = new Waiters();
  35. $user = new User();
  36. $user->name = $request->name;
  37. $user->username = CommonMethods::generate_user_name($request->name);
  38. $user->password = Hash::make('12345678');
  39. if(!empty($request->email))
  40. $user->email = $request->email;
  41. $user->is_active = 1;
  42. $user->role='waiter';
  43. $user->save();
  44. $waiter->user_id = $user->id;
  45. }else
  46. $waiter = Waiters::find($id);
  47. if(!isset($request->is_active) && !empty($id)){
  48. //dd('TEST');
  49. if(!empty($id)) {
  50. $u = User::find($waiter->user_id);
  51. $u->is_active = 0;
  52. $u->save();
  53. }
  54. }else{
  55. if ($waiter->users->is_active == 0) {
  56. $u = User::find($waiter->user_id);
  57. $u->is_active = 1;
  58. $u->save();
  59. }
  60. }
  61. $waiter->name = $request->name;
  62. $waiter->resto_id = Auth::user()->restaurants->id;
  63. $waiter->address = $request->address;
  64. $waiter->phone = $request->phone;
  65. $waiter->is_active = isset($request->is_active)?1:0;
  66. $waiter->save();
  67. $id = $waiter->id;
  68. if($id > 0){
  69. if($request->hasFile('profile')){
  70. $logo = $request->file('profile');
  71. $file_name = Str::slug($request->name)."-profile".'-'.time();
  72. $extension = $logo->getClientOriginalExtension();
  73. Storage::disk('profile')->put($file_name.'.'.$extension, File::get($logo));
  74. $logo = Photos::where('waiter_id',$id)->where('photo_type','profile')->first();
  75. if(!$logo)
  76. $logo = new Photos();
  77. $logo->file_name = $file_name.'.'.$extension;
  78. $logo->waiter_id = $id;
  79. $logo->photo_type = 'profile';
  80. $logo->save();
  81. //$resto->text =
  82. }
  83. $table_id = isset($request->table_id)?$request->table_id:"";
  84. if(!empty($table_id)){
  85. $w_t = WaiterTables::where('table_id',$table_id)->first();
  86. if(!isset($wt))
  87. $w_t = new WaiterTables();
  88. $w_t->waiter_id = $id;
  89. $w_t->table_id = $table_id;
  90. $w_t->save();
  91. }
  92. echo json_encode(array('type' => 'success', 'message'=>"Waiter's data is saved successfully."));
  93. exit;
  94. }else{
  95. echo json_encode(array('type' => 'error', 'message'=>"Waiter's data is not saved, check info again."));
  96. }
  97. }
  98. public function show($id){
  99. $waiter = Waiters::find($id);
  100. $data = [
  101. 'waiter' => $waiter,
  102. ];
  103. return view('waiters.show',$data);
  104. }
  105. public function edit($id){
  106. $waiter = Waiters::find($id);
  107. $tables = RestoTables::whereNull('deleted_at')->where('resto_id',Auth::user()->restaurants->id)->where('is_active',1)->doesnthave('waiter_tables')->get();
  108. $data = [
  109. 'waiter' => $waiter,
  110. 'tables'=>$tables
  111. ];
  112. return view('waiters.waiter_form',$data);
  113. }
  114. public function delete($id){
  115. //$id = CommonMethods::decrypt($id);
  116. $waiter = Waiters::find($id);
  117. $waiter->deleted_at = date('Y-m-d H:i:s');
  118. $waiter->save();
  119. }
  120. public function generate_credentials($id){
  121. $waiter = Waiters::find($id);
  122. return response()->json(['username'=>$waiter->users->username,'password'=>CommonMethods::generateRandomString()]);
  123. }
  124. public function update_password(Request $request){
  125. $waiter = Waiters::find($request->waiter_id);
  126. $u = User::find($waiter->user_id);
  127. $u->password = Hash::make($request->password);
  128. $u->save();
  129. }
  130. }