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.
		
		
		
		
		
			
		
			
				
					
					
						
							95 lines
						
					
					
						
							3.9 KiB
						
					
					
				
			
		
		
	
	
							95 lines
						
					
					
						
							3.9 KiB
						
					
					
				<?php
 | 
						|
 | 
						|
namespace App\Http\Controllers\Api\V1;
 | 
						|
 | 
						|
use App\Http\Controllers\Controller;
 | 
						|
use App\Models\Campaign;
 | 
						|
use App\Models\ItemCampaign;
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use App\CentralLogics\Helpers;
 | 
						|
use Illuminate\Support\Facades\Validator;
 | 
						|
 | 
						|
class CampaignController extends Controller
 | 
						|
{
 | 
						|
    public function get_basic_campaigns(Request $request){
 | 
						|
        if (!$request->hasHeader('zoneId')) {
 | 
						|
            $errors = [];
 | 
						|
            array_push($errors, ['code' => 'zoneId', 'message' => translate('messages.zone_id_required')]);
 | 
						|
            return response()->json([
 | 
						|
                'errors' => $errors
 | 
						|
            ], 200);
 | 
						|
        }
 | 
						|
        $longitude= $request->header('longitude');
 | 
						|
        $latitude= $request->header('latitude');
 | 
						|
        $zone_id= json_decode($request->header('zoneId'), true);
 | 
						|
        try {
 | 
						|
            $campaigns = Campaign::whereHas('restaurants', function($query)use($zone_id){
 | 
						|
                $query->whereIn('zone_id', $zone_id);
 | 
						|
            })
 | 
						|
            ->with('restaurants',function($query)use($zone_id,$longitude,$latitude){
 | 
						|
                return $query->WithOpen($longitude,$latitude)->whereIn('zone_id', $zone_id)->wherePivot('campaign_status', 'confirmed')->active();
 | 
						|
            })
 | 
						|
            ->running()->active()->get();
 | 
						|
            $campaigns=Helpers::basic_campaign_data_formatting($campaigns, true);
 | 
						|
            return response()->json($campaigns, 200);
 | 
						|
        } catch (\Exception $e) {
 | 
						|
            return response()->json([$e], 200);
 | 
						|
        }
 | 
						|
    }
 | 
						|
    public function basic_campaign_details(Request $request){
 | 
						|
        if (!$request->hasHeader('zoneId')) {
 | 
						|
            $errors = [];
 | 
						|
            array_push($errors, ['code' => 'zoneId', 'message' => translate('messages.zone_id_required')]);
 | 
						|
            return response()->json([
 | 
						|
                'errors' => $errors
 | 
						|
            ], 200);
 | 
						|
        }
 | 
						|
        $zone_id= json_decode($request->header('zoneId'), true);
 | 
						|
 | 
						|
        $validator = Validator::make($request->all(), [
 | 
						|
            'basic_campaign_id' => 'required',
 | 
						|
        ]);
 | 
						|
 | 
						|
        if ($validator->fails()) {
 | 
						|
            return response()->json(['errors' => Helpers::error_processor($validator)], 403);
 | 
						|
        }
 | 
						|
        try {
 | 
						|
            $longitude= $request->header('longitude');
 | 
						|
            $latitude= $request->header('latitude');
 | 
						|
            $campaign = Campaign::with(['restaurants'=>function($q)use($zone_id){
 | 
						|
                $q->whereIn('zone_id', $zone_id);
 | 
						|
            }])
 | 
						|
            ->with('restaurants',function($query)use($zone_id,$longitude,$latitude){
 | 
						|
                return $query->WithOpen($longitude,$latitude)->whereIn('zone_id', $zone_id)->wherePivot('campaign_status', 'confirmed')->active();
 | 
						|
            })
 | 
						|
            ->running()->active()->whereId($request->basic_campaign_id)->first();
 | 
						|
 | 
						|
            $campaign=Helpers::basic_campaign_data_formatting($campaign, false);
 | 
						|
 | 
						|
            $campaign['restaurants'] = Helpers::restaurant_data_formatting($campaign['restaurants'], true);
 | 
						|
 | 
						|
            return response()->json($campaign, 200);
 | 
						|
        } catch (\Exception $e) {
 | 
						|
            return response()->json([], 200);
 | 
						|
        }
 | 
						|
    }
 | 
						|
    public function get_item_campaigns(Request $request){
 | 
						|
        if (!$request->hasHeader('zoneId')) {
 | 
						|
            $errors = [];
 | 
						|
            array_push($errors, ['code' => 'zoneId', 'message' => translate('messages.zone_id_required')]);
 | 
						|
            return response()->json([
 | 
						|
                'errors' => $errors
 | 
						|
            ], 200);
 | 
						|
        }
 | 
						|
        $zone_id= json_decode($request->header('zoneId'), true);
 | 
						|
        try {
 | 
						|
            $campaigns = ItemCampaign::active()->whereHas('restaurant', function($query)use($zone_id){
 | 
						|
                $query->whereIn('zone_id', $zone_id);
 | 
						|
            })->running()->active()->get();
 | 
						|
            $campaigns= Helpers::product_data_formatting($campaigns, true, false, app()->getLocale());
 | 
						|
            return response()->json($campaigns, 200);
 | 
						|
        } catch (\Exception $e) {
 | 
						|
            return response()->json([], 200);
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 | 
						|
 |