You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							195 lines
						
					
					
						
							7.1 KiB
						
					
					
				
			
		
		
	
	
							195 lines
						
					
					
						
							7.1 KiB
						
					
					
				<?php
 | 
						|
 | 
						|
namespace App\Http\Controllers\Admin;
 | 
						|
 | 
						|
use App\Http\Controllers\Controller;
 | 
						|
use App\Models\AddOn;
 | 
						|
use App\Models\Restaurant;
 | 
						|
use App\Models\Translation;
 | 
						|
use Brian2694\Toastr\Facades\Toastr;
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use Rap2hpoutre\FastExcel\FastExcel;
 | 
						|
use Illuminate\Support\Facades\DB;
 | 
						|
use App\Scopes\RestaurantScope;
 | 
						|
use App\CentralLogics\ProductLogic;
 | 
						|
class AddOnController extends Controller
 | 
						|
{
 | 
						|
    public function index(Request $request)
 | 
						|
    {
 | 
						|
        $restaurant_id = $request->query('restaurant_id', 'all');
 | 
						|
        $addons = AddOn::withoutGlobalScope(RestaurantScope::class)
 | 
						|
        ->when(is_numeric($restaurant_id), function($query)use($restaurant_id){
 | 
						|
            return $query->where('restaurant_id', $restaurant_id);
 | 
						|
        })
 | 
						|
        ->orderBy('name')->paginate(config('default_pagination'));
 | 
						|
        $restaurant =$restaurant_id !='all'? Restaurant::findOrFail($restaurant_id):null;
 | 
						|
        return view('admin-views.addon.index', compact('addons', 'restaurant'));
 | 
						|
    }
 | 
						|
 | 
						|
    public function store(Request $request)
 | 
						|
    {
 | 
						|
        $request->validate([
 | 
						|
            'name.*' => 'max:191',
 | 
						|
            'name'=>'array|required',
 | 
						|
            'restaurant_id' => 'required',
 | 
						|
            'price' => 'required|numeric|between:0,999999999999.99',
 | 
						|
        ], [
 | 
						|
            'name.required' => translate('messages.Name is required!'),
 | 
						|
            'restaurant_id.required' => translate('messages.please_select_restaurant'),
 | 
						|
        ]);
 | 
						|
 | 
						|
        $addon = new AddOn();
 | 
						|
        $addon->name = $request->name[array_search('en', $request->lang)];
 | 
						|
        $addon->price = $request->price;
 | 
						|
        $addon->restaurant_id = $request->restaurant_id;
 | 
						|
        $addon->save();
 | 
						|
 | 
						|
        $data = [];
 | 
						|
        foreach($request->lang as $index=>$key)
 | 
						|
        {
 | 
						|
            if($request->name[$index] && $key != 'en')
 | 
						|
            {
 | 
						|
                array_push($data, Array(
 | 
						|
                    'translationable_type'  => 'App\Models\AddOn',
 | 
						|
                    'translationable_id'    => $addon->id,
 | 
						|
                    'locale'                => $key,
 | 
						|
                    'key'                   => 'name',
 | 
						|
                    'value'                 => $request->name[$index],
 | 
						|
                ));
 | 
						|
            }
 | 
						|
        }
 | 
						|
        if(count($data))
 | 
						|
        {
 | 
						|
            Translation::insert($data);
 | 
						|
        }
 | 
						|
        Toastr::success(translate('messages.addon_added_successfully'));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function edit($id)
 | 
						|
    {
 | 
						|
        $addon = AddOn::withoutGlobalScope(RestaurantScope::class)->withoutGlobalScope('translate')->findOrFail($id);
 | 
						|
        return view('admin-views.addon.edit', compact('addon'));
 | 
						|
    }
 | 
						|
 | 
						|
    public function update(Request $request, $id)
 | 
						|
    {
 | 
						|
        $request->validate([
 | 
						|
            'name' => 'required|max:191',
 | 
						|
            'restaurant_id' => 'required',
 | 
						|
            'price' => 'required|numeric|between:0,999999999999.99',
 | 
						|
        ], [
 | 
						|
            'name.required' => translate('messages.Name is required!'),
 | 
						|
            'restaurant_id.required' => translate('messages.please_select_restaurant'),
 | 
						|
        ]);
 | 
						|
 | 
						|
        $addon = AddOn::withoutGlobalScope(RestaurantScope::class)->find($id);
 | 
						|
        $addon->name = $request->name[array_search('en', $request->lang)];
 | 
						|
        $addon->price = $request->price;
 | 
						|
        $addon->restaurant_id = $request->restaurant_id;
 | 
						|
        $addon->save();
 | 
						|
 | 
						|
        foreach($request->lang as $index=>$key)
 | 
						|
        {
 | 
						|
            if($request->name[$index] && $key != 'en')
 | 
						|
            {
 | 
						|
                Translation::updateOrInsert(
 | 
						|
                    ['translationable_type'  => 'App\Models\AddOn',
 | 
						|
                        'translationable_id'    => $addon->id,
 | 
						|
                        'locale'                => $key,
 | 
						|
                        'key'                   => 'name'],
 | 
						|
                    ['value'                 => $request->name[$index]]
 | 
						|
                );
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        Toastr::success(translate('messages.addon_updated_successfully'));
 | 
						|
        return redirect(route('admin.addon.add-new'));
 | 
						|
    }
 | 
						|
 | 
						|
    public function delete(Request $request)
 | 
						|
    {
 | 
						|
        $addon = AddOn::withoutGlobalScope(RestaurantScope::class)->find($request->id);
 | 
						|
        $addon->delete();
 | 
						|
        Toastr::success(translate('messages.addon_deleted_successfully'));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function status($addon, Request $request)
 | 
						|
    {
 | 
						|
        $addon_data = AddOn::withoutGlobalScope(RestaurantScope::class)->find($addon);
 | 
						|
        $addon_data->status = $request->status;
 | 
						|
        $addon_data->save();
 | 
						|
        Toastr::success(translate('messages.addon_status_updated'));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function search(Request $request){
 | 
						|
        $key = explode(' ', $request['search']);
 | 
						|
        $addons=AddOn::where(function ($q) use ($key) {
 | 
						|
            foreach ($key as $value) {
 | 
						|
                $q->orWhere('name', 'like', "%{$value}%");
 | 
						|
            }
 | 
						|
        })->limit(50)->get();
 | 
						|
        return response()->json([
 | 
						|
            'view'=>view('admin-views.addon.partials._table',compact('addons'))->render()
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
    public function bulk_import_index()
 | 
						|
    {
 | 
						|
        return view('admin-views.addon.bulk-import');
 | 
						|
    }
 | 
						|
 | 
						|
    public function bulk_import_data(Request $request)
 | 
						|
    {
 | 
						|
        try {
 | 
						|
            $collections = (new FastExcel)->import($request->file('products_file'));
 | 
						|
        } catch (\Exception $exception) {
 | 
						|
            Toastr::error(translate('messages.you_have_uploaded_a_wrong_format_file'));
 | 
						|
            return back();
 | 
						|
        }
 | 
						|
 | 
						|
        $data = [];
 | 
						|
        foreach ($collections as $collection) {
 | 
						|
                if ($collection['name'] === "" && $collection['restaurant_id'] === "") {
 | 
						|
                    Toastr::error(translate('messages.please_fill_all_required_fields'));
 | 
						|
                    return back();
 | 
						|
                }
 | 
						|
            array_push($data, [
 | 
						|
                'name' => $collection['name'],
 | 
						|
                'price' => $collection['price'],
 | 
						|
                'restaurant_id' => $collection['restaurant_id'],
 | 
						|
                'created_at'=>now(),
 | 
						|
                'updated_at'=>now()
 | 
						|
            ]);
 | 
						|
        }
 | 
						|
        DB::table('add_ons')->insert($data);
 | 
						|
        Toastr::success(translate('messages.addon_imported_successfully', ['count'=>count($data)]));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function bulk_export_index()
 | 
						|
    {
 | 
						|
        return view('admin-views.addon.bulk-export');
 | 
						|
    }
 | 
						|
 | 
						|
    public function bulk_export_data(Request $request)
 | 
						|
    {
 | 
						|
        $request->validate([
 | 
						|
            'type'=>'required',
 | 
						|
            'start_id'=>'required_if:type,id_wise',
 | 
						|
            'end_id'=>'required_if:type,id_wise',
 | 
						|
            'from_date'=>'required_if:type,date_wise',
 | 
						|
            'to_date'=>'required_if:type,date_wise'
 | 
						|
        ]);
 | 
						|
        $addons = AddOn::when($request['type']=='date_wise', function($query)use($request){
 | 
						|
            $query->whereBetween('created_at', [$request['from_date'].' 00:00:00', $request['to_date'].' 23:59:59']);
 | 
						|
        })
 | 
						|
        ->when($request['type']=='id_wise', function($query)use($request){
 | 
						|
            $query->whereBetween('id', [$request['start_id'], $request['end_id']]);
 | 
						|
        })
 | 
						|
        ->withoutGlobalScope(RestaurantScope::class)->get();
 | 
						|
        return (new FastExcel(ProductLogic::format_export_addons($addons)))->download('Addons.xlsx');
 | 
						|
 | 
						|
    }
 | 
						|
}
 | 
						|
 |