Recipe.php_1 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Categories;
  4. use App\MapRecipeCategories;
  5. use App\Photos;
  6. use App\Recipes;
  7. use App\Restaurants;
  8. use Brian2694\Toastr\Facades\Toastr;
  9. use Illuminate\Http\Request;
  10. use Illuminate\Support\Facades\Auth;
  11. use Illuminate\Support\Facades\Storage;
  12. use Ramsey\Uuid\Uuid;
  13. use App\ClothOptions;
  14. use Str;
  15. use File;
  16. use Illuminate\Support\Facades\Hash;
  17. use Image;
  18. use App\Helpers\CommonMethods;
  19. class Recipe extends Controller
  20. {
  21. public function inventory(){
  22. $recipes = Auth::user()->restaurants->recipes();;
  23. $data = [
  24. 'recipes' => $recipes->get()
  25. ];
  26. return view('recipes.inventory',$data);
  27. }
  28. //
  29. public function recipes(){
  30. Toastr::success('Post added successfully :)','Success');
  31. $recipes = Auth::user()->restaurants->recipes;
  32. $data = [
  33. 'recipes' => $recipes
  34. ];
  35. return view('recipes.recipes',$data);
  36. }
  37. public function new_recipe(){
  38. if( Auth::user()->role=="restaurant")
  39. $categories = Categories::whereNull('deleted_at')->where('is_active',1)->whereIn('resto_id',[0,Auth::user()->restaurants->id])->get();
  40. else
  41. $categories = Categories::where('is_active',1)->whereNull('deleted_at')->get();
  42. $data = [
  43. 'categories' => $categories
  44. ];
  45. return view('recipes.recipe_form',$data);
  46. }
  47. public function edit($id){
  48. if( Auth::user()->role=="restaurant")
  49. $categories = Categories::whereNull('deleted_at')->where('is_active',1)->whereIn('resto_id',[0,Auth::user()->restaurants->id])->get();
  50. else
  51. $categories = Categories::where('is_active',1)->whereNull('deleted_at')->get();
  52. $recipe = Recipes::find($id);
  53. $data = [
  54. 'categories' => $categories,
  55. 'recipe' =>$recipe
  56. ];
  57. return view('recipes.recipe_form',$data);
  58. }
  59. public function save(Request $request){
  60. $id = $request->id;
  61. if(empty($id)){
  62. $recipe = new Recipes();
  63. $recipe->unique_shared_key = Str::uuid();
  64. }
  65. else
  66. $recipe = Recipes::find($id);
  67. $recipe->name = $request->name;
  68. $recipe->arabic_name = $request->arabic_name;
  69. $recipe->status = '1';
  70. $recipe->resto_id = Auth::user()->restaurants->id;
  71. $recipe->price = $request->price;
  72. $recipe->show_recipe_main_price = isset($request->show_recipe_main_price)?1:0;
  73. $recipe->short_description = $request->short_description;
  74. $recipe->is_customized = isset($request->is_customized)?1:0;
  75. $recipe->status = isset($request->status)?1:0;
  76. $recipe->save();
  77. $recipe_id = $recipe->id;
  78. if($recipe_id > 0){
  79. $categories = $request->category;
  80. //dd($categories);
  81. MapRecipeCategories::where('recipe_id',$recipe_id)->delete();
  82. if(count($categories) > 0){
  83. foreach($categories as $category){
  84. $m_c = new MapRecipeCategories();
  85. $m_c->category_id = $category;
  86. $m_c->recipe_id = $recipe_id;
  87. $m_c->resto_id = Auth::user()->restaurants->id;;
  88. $m_c->save();
  89. }
  90. }
  91. if($request->hasFile('main_image')){
  92. $logo = $request->file('main_image');
  93. $file_name = Str::slug($request->name)."-main_image".'-'.time();
  94. $extension = $logo->getClientOriginalExtension();
  95. Storage::disk('main_image')->put($file_name.'.'.$extension, File::get($logo));
  96. $destinationPath = public_path('/uploads/main_image/');
  97. /*$img = Image::make($destinationPath . '/' . $file_name.'.'.$extension)->resize(1400, null, function ($constraint) {
  98. $constraint->aspectRatio();
  99. });*/
  100. // $img->save($destinationPath . '/' . $file_name.'.'.$extension);
  101. $file = public_path('uploads/main_image/'.$file_name.'.'.$extension);
  102. $result = CommonMethods::uploadFileToAWSCDN('meemapp-order',Auth::user()->restaurants->id, Auth::user()->restaurants->resto_unique_name,$file,$file_name);
  103. /*
  104. $img = Image::make($destinationPath . '/' . $file_name.'.'.$extension)->resize(200, null, function ($constraint) {
  105. $constraint->aspectRatio();
  106. });
  107. $img->save($destinationPath . '/thumbnails/' . $file_name.'.'.$extension);*/
  108. $main_image = Photos::where('recipe_id',$recipe_id)->where('photo_type','main_image')->first();
  109. if(!$main_image)
  110. $main_image = new Photos();
  111. $main_image->file_name = $result['url'];
  112. $main_image->aws_cdn = $result['url'];
  113. $main_image->recipe_id = $recipe_id;
  114. $main_image->photo_type = 'main_image';
  115. $main_image->resto_id = Auth::user()->restaurants->id;;;
  116. $main_image->save();
  117. //$resto->text =
  118. }
  119. if($request->business_type=="ClothsStore"){
  120. $option = ClothOptions::where('resto_id',Auth::user()->restaurants->id)->where('product_id',$recipe_id)->delete();
  121. $colors = !empty($request->color)?$request->color:NULL;
  122. $sizes = !empty($request->size)?$request->size:NULL;
  123. if(isset($colors) && count($colors) > 0){
  124. foreach($colors as $color){
  125. $options = new ClothOptions();
  126. $options->resto_id = Auth::user()->restaurants->id;
  127. $options->product_id = $recipe_id;
  128. $options->name = $color;
  129. $options->type="color";
  130. $options->save();
  131. }
  132. }
  133. if(isset($sizes) && count($sizes) > 0){
  134. foreach($sizes as $size){
  135. $options = new ClothOptions();
  136. $options->resto_id = Auth::user()->restaurants->id;
  137. $options->product_id = $recipe_id;
  138. $options->name = $size;
  139. $options->type="size";
  140. $options->save();
  141. }
  142. }
  143. }
  144. echo json_encode(array('type' => 'success', 'message'=>"Recipe's data is saved successfully."));
  145. }
  146. else
  147. echo json_encode(array('type' => 'error', 'message'=>"Recipe's data is not saved successfully."));
  148. }
  149. /* public function save(Request $request){
  150. $id = $request->id;
  151. if(empty($id)){
  152. $recipe = new Recipes();
  153. $recipe->unique_shared_key = Str::uuid();
  154. }
  155. else
  156. $recipe = Recipes::find($id);
  157. $recipe->name = $request->name;
  158. $recipe->status = '1';
  159. $recipe->resto_id = Auth::user()->restaurants->id;
  160. $recipe->price = $request->price;
  161. $recipe->short_description = $request->short_description;
  162. $recipe->is_customized = isset($request->is_customized)?1:0;
  163. $recipe->status = isset($request->status)?1:0;
  164. $recipe->save();
  165. $recipe_id = $recipe->id;
  166. if($recipe_id > 0){
  167. $categories = $request->category;
  168. //dd($categories);
  169. MapRecipeCategories::where('recipe_id',$recipe_id)->delete();
  170. if(count($categories) > 0){
  171. foreach($categories as $category){
  172. $m_c = new MapRecipeCategories();
  173. $m_c->category_id = $category;
  174. $m_c->recipe_id = $recipe_id;
  175. $m_c->resto_id = Auth::user()->restaurants->id;;
  176. $m_c->save();
  177. }
  178. }
  179. if($request->hasFile('main_image')){
  180. $logo = $request->file('main_image');
  181. $file_name = Str::slug($request->name)."-main_image".'-'.time();
  182. $extension = $logo->getClientOriginalExtension();
  183. Storage::disk('main_image')->put($file_name.'.'.$extension, File::get($logo));
  184. $destinationPath = public_path('/uploads/main_image/');
  185. $img = Image::make($destinationPath . '/' . $file_name.'.'.$extension)->resize(1400, null, function ($constraint) {
  186. $constraint->aspectRatio();
  187. });
  188. $img->save($destinationPath . '/' . $file_name.'.'.$extension);
  189. $img = Image::make($destinationPath . '/' . $file_name.'.'.$extension)->resize(200, null, function ($constraint) {
  190. $constraint->aspectRatio();
  191. });
  192. $img->save($destinationPath . '/thumbnails/' . $file_name.'.'.$extension);
  193. $main_image = Photos::where('recipe_id',$recipe_id)->where('photo_type','main_image')->first();
  194. if(!$main_image)
  195. $main_image = new Photos();
  196. $main_image->file_name = $file_name.'.'.$extension;
  197. $main_image->recipe_id = $recipe_id;
  198. $main_image->photo_type = 'main_image';
  199. $main_image->resto_id = Auth::user()->restaurants->id;;;
  200. $main_image->save();
  201. //$resto->text =
  202. }
  203. echo json_encode(array('type' => 'success', 'message'=>"Recipe's data is saved successfully."));
  204. }
  205. else
  206. echo json_encode(array('type' => 'error', 'message'=>"Recipe's data is not saved successfully."));
  207. }*/
  208. public function delete($id){
  209. $recipe = Recipes::find($id);
  210. $recipe->deleted_at = date('Y-m-d H:i:s');
  211. $recipe->save();
  212. }
  213. public function upload_gallery(Request $request){
  214. $files = $request->file('files');;
  215. $recipe_id = $request->recipe_id;
  216. if(isset($files) && count($files) > 0){
  217. foreach($files as $file){
  218. $photo = new Photos();
  219. $extension = $file->getClientOriginalExtension();
  220. $original_name = $file->getClientOriginalName();
  221. // $original_name = str_replace(' ', '-', $original_name);
  222. $extension_array = ['jpg', 'jpeg', 'bmp', 'png'];
  223. $image_array = ['jpg', 'jpeg', 'bmp', 'png'];
  224. if (in_array($extension, $extension_array)) {
  225. $file_name = 'recipe-gallery-'.$recipe_id. '-' . time().rand(1000,9999) . '.' . $extension;
  226. $destinationPath = public_path('/uploads/resto-gallery/');
  227. $file->move($destinationPath, $file_name);
  228. $file = public_path('uploads/resto-gallery/'.$file_name);
  229. $result = CommonMethods::uploadFileToAWSCDN('meemapp-order',Auth::user()->restaurants->id, Auth::user()->restaurants->resto_unique_name,$file,$file_name);
  230. /* $img = Image::make($destinationPath . '/' . $file_name)->resize(1400, null, function ($constraint) {
  231. $constraint->aspectRatio();
  232. });
  233. $img->save($destinationPath . '/' . $file_name);
  234. $img = Image::make($destinationPath . '/' . $file_name)->resize(85, null, function ($constraint) {
  235. $constraint->aspectRatio();
  236. });
  237. $img->save($destinationPath . '/thumbnails/' . $file_name);
  238. */
  239. // dd($request->file('attachment'));
  240. $photo->recipe_id = $recipe_id;
  241. $photo->file_name = $result['url'];
  242. $photo->aws_cdn = $result['url'];
  243. $photo->photo_type = "gallery";
  244. $photo->resto_id = Auth::user()->restaurants->id;;;
  245. $photo->save();
  246. }
  247. }
  248. }
  249. }
  250. public function show($id){
  251. $recipe = Recipes::find($id);
  252. $categories = isset($recipe->categories)?$recipe->categories->pluck('category_id'):NULL;
  253. if($categories){
  254. $categories = Categories::whereIn('id',$categories)->pluck('name')->toArray();
  255. $categories = implode(', ',$categories);
  256. }
  257. $data = [
  258. 'recipe' => $recipe,
  259. 'categories' => $categories
  260. ];
  261. return view('recipes.show',$data);
  262. }
  263. public function remove_main_image(Request $request){
  264. $id = $request->id;
  265. $photo = Photos::where('recipe_id',$id)->where('photo_type','main_image')->first();
  266. $photo->delete();
  267. }
  268. public function exclude_outlet(Request $request){
  269. $is_exclude = $request->is_exclude;
  270. $outlet_id = $request->outlet_id;
  271. $recipe_id = $request->recipe_id;
  272. $recipe = Recipes::find($recipe_id);
  273. $exclude_outlets = $recipe->exclude_outlets;
  274. if(empty($exclude_outlets)){
  275. $o = explode(',',$exclude_outlets);
  276. $o[$outlet_id] = $outlet_id;
  277. // dump($o);
  278. $recipe->exclude_outlets = $outlet_id;
  279. }else{
  280. $o = explode(',',$exclude_outlets);
  281. if($is_exclude=="true"){
  282. $key = array_search($outlet_id, $o);
  283. unset($o[$key]);
  284. }
  285. else
  286. $o[] = $outlet_id;
  287. $o = array_unique($o);
  288. $recipe->exclude_outlets = implode(',',$o);
  289. }
  290. $recipe->save();
  291. }
  292. }