File: /var/www/vhost/disk-apps/demo.sports-crowd.com/app/Http/Controllers/Api/PopupEmbedApiController.php
<?php
namespace App\Http\Controllers\Api;
use App\PopupEmbed;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Auth;
use Carbon\Carbon;
class PopupEmbedApiController extends Controller
{
    public function get()
    {
        $userId = Auth::user()->id;
        $popUpsForUser = PopupEmbed::select('popup_embeds.*')
            ->leftjoin('popup_tags', 'popup_embeds.id', '=', 'popup_tags.popup_id')
            ->leftJoin('tags', function ($join) {
                $join->on('tags.id', '=', 'popup_tags.tag_id')
                    ->where('tags.active', 1);
            })
            ->leftjoin('user_tags', 'user_tags.tag_id', '=', 'popup_tags.tag_id')
            ->where(function ($q) use ($userId) {
                $q->where('user_tags.user_id', $userId)
                    ->orWhereNull('popup_tags.id')
                    ->orWhereNull('tags.id');
            })
            ->where('popup_embeds.active', true)
            ->get();
        $popUpsForAll = PopupEmbed::select('popup_embeds.*')
            ->leftjoin('popup_tags', 'popup_embeds.id', '=', 'popup_tags.popup_id')
            ->whereNull('popup_tags.id')
            ->where('popup_embeds.active', true)
            ->get();
        return response()->json($popUpsForUser->merge($popUpsForAll), 200);
    }
    public function getPopups($target)
    {
        $userId = Auth::user()->id;
        $now = Carbon::now();
        $popUpsForUser = PopupEmbed::select('popup_embeds.*')
            ->leftjoin('popup_tags', 'popup_embeds.id', '=', 'popup_tags.popup_id')
            ->leftJoin('tags', function ($join) {
                $join->on('tags.id', '=', 'popup_tags.tag_id')
                    ->where('tags.active', 1);
            })
            ->leftjoin('user_tags', 'user_tags.tag_id', '=', 'popup_tags.tag_id')
            ->where(function ($q) use ($userId) {
                $q->where('user_tags.user_id', $userId)
                    ->orWhereNull('popup_tags.id')
                    ->orWhereNull('tags.id');
            })
            ->where('popup_embeds.active', true)
            ->where('popup_embeds.target', 'LIKE', '%' . $target . '%')
            ->where(function ($query) use ($now) {
                $query->whereNull('popup_embeds.start_date')  // NO PROGRAMADOS
                    ->orWhere(function ($subQuery) use ($now) {    // PROGRAMADOS
                        $subQuery->where('popup_embeds.start_date', '<=', $now)
                            ->where('popup_embeds.end_date', '>=', $now);
                    });
            })
            ->get();
        $popUpsForAll = PopupEmbed::select('popup_embeds.*')
            ->where('popup_embeds.active', true)
            ->leftjoin('popup_tags', 'popup_embeds.id', '=', 'popup_tags.popup_id')
            ->whereNull('popup_tags.id')
            ->where('popup_embeds.target', 'LIKE', '%' . $target . '%')
            ->where(function ($query) use ($now) {
                $query->whereNull('popup_embeds.start_date')  // NO PROGRAMADOS
                    ->orWhere(function ($subQuery) use ($now) {    // PROGRAMADOS
                        $subQuery->where('popup_embeds.start_date', '<=', $now)
                            ->where('popup_embeds.end_date', '>=', $now);
                    });
            })
            ->get();
        return response()->json($popUpsForUser->merge($popUpsForAll), 200);
    }
}