ok

Mini Shell

Direktori : /home2/selectio/www/fms-worksuite/app/Console/Commands/
Upload File :
Current File : /home2/selectio/www/fms-worksuite/app/Console/Commands/SendTimeTracker.php

<?php

namespace App\Console\Commands;

use Illuminate\Console\Command;
use App\Models\LogTimeFor;
use App\Models\Holiday;
use App\Models\Leave;
use App\Models\User;
use App\Models\Company;
use App\Models\ProjectTimeLog;
use App\Events\TimeTrackerReminderEvent;
use Carbon\Carbon;

class SendTimeTracker extends Command
{

    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = 'send-time-tracker';

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = 'send time tracker';

    /**
     *
     */

    public function handle()
    {
        $currentDay = now()->format('Y-m-d');
        $companies = Company::select('id', 'timezone')->get();

        foreach ($companies as $company) {
            $trackerReminder = LogTimeFor::where('company_id', $company->id)->first();

            $startDateTime = Carbon::parse($currentDay . ' ' . $trackerReminder->time);
            $currentDateTime = now()->timezone($company->timezone);

            if ($trackerReminder->tracker_reminder == 1 && $currentDateTime->format('H:i') == $startDateTime->format('H:i')) {

                // Check if there's a holiday for the current day and company
                $holiday = Holiday::where('company_id', $company->id)
                    ->where('date', $currentDay)
                    ->exists();

                if (!$holiday) {
                    $employeeIds = User::allEmployees(null, false, null, $company->id)->pluck('id');

                    $employeeIds->each(function ($employeeId) use ($currentDay) {
                        $leaveExists = Leave::where('leave_date', $currentDay)
                            ->where('status', 'approved')
                            ->where('user_id', $employeeId)
                            ->exists();

                        $timeLogExists = ProjectTimeLog::whereDate('start_time', $currentDay)
                            ->where('user_id', $employeeId)
                            ->exists();

                        $user = User::find($employeeId);

                        if (!$leaveExists && !$timeLogExists && $user) {
                            event(new TimeTrackerReminderEvent($user));
                        }
                    });
                }
            }
        }
    }

}

Zerion Mini Shell 1.0