mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-11-04 06:57:33 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			206 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			206 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Http\Controllers;
 | 
						|
 | 
						|
use App\Models\Task;
 | 
						|
use App\Models\TaskStatus;
 | 
						|
use App\Models\Project;
 | 
						|
use App\Models\Client;
 | 
						|
 | 
						|
class TaskKanbanController extends BaseController
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * @return \Illuminate\Contracts\View\View
 | 
						|
     */
 | 
						|
    public function index($clientPublicId = false, $projectPublicId = false)
 | 
						|
    {
 | 
						|
        $tasks = Task::scope()
 | 
						|
            ->with(['project', 'client', 'task_status'])
 | 
						|
            ->whereNull('invoice_id')
 | 
						|
            ->orderBy('task_status_sort_order')
 | 
						|
            ->orderBy('id')
 | 
						|
            ->get();
 | 
						|
 | 
						|
        $statuses = TaskStatus::scope()
 | 
						|
            ->orderBy('sort_order')
 | 
						|
            ->orderBy('id')
 | 
						|
            ->get();
 | 
						|
 | 
						|
        $projects = Project::scope()->with('client')->get();
 | 
						|
        $clients = Client::scope()->with(['contacts'])->get();
 | 
						|
 | 
						|
        // check initial statuses exist
 | 
						|
        if (! $statuses->count()) {
 | 
						|
            $statuses = collect([]);
 | 
						|
            $firstStatus = false;
 | 
						|
            $defaults = [
 | 
						|
                'backlog',
 | 
						|
                'ready_to_do',
 | 
						|
                'in_progress',
 | 
						|
                'done',
 | 
						|
            ];
 | 
						|
            for ($i=0; $i<count($defaults); $i++) {
 | 
						|
                $status = TaskStatus::createNew();
 | 
						|
                $status->name = trans('texts.' . $defaults[$i]);
 | 
						|
                $status->sort_order = $i;
 | 
						|
                $status->save();
 | 
						|
                $statuses[] = $status;
 | 
						|
                if (! $firstStatus) {
 | 
						|
                    $firstStatus = $status;
 | 
						|
                }
 | 
						|
            }
 | 
						|
            $i = 0;
 | 
						|
            foreach ($tasks as $task) {
 | 
						|
                $task->task_status_id = $firstStatus->id;
 | 
						|
                $task->task_status_sort_order = $i++;
 | 
						|
                $task->save();
 | 
						|
            }
 | 
						|
        // otherwise, check that the orders are correct
 | 
						|
        } else {
 | 
						|
            for ($i=0; $i<$statuses->count(); $i++) {
 | 
						|
                $status = $statuses[$i];
 | 
						|
                if ($status->sort_order != $i) {
 | 
						|
                    $status->sort_order = $i;
 | 
						|
                    $status->save();
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            $firstStatus = $statuses[0];
 | 
						|
            $counts = [];
 | 
						|
            foreach ($tasks as $task) {
 | 
						|
                if (! $task->task_status || $task->task_status->trashed()) {
 | 
						|
                    $task->task_status_id = $firstStatus->id;
 | 
						|
                    $task->setRelation('task_status', $firstStatus);
 | 
						|
                }
 | 
						|
                if (! isset($counts[$task->task_status_id])) {
 | 
						|
                    $counts[$task->task_status_id] = 0;
 | 
						|
                }
 | 
						|
                if ($task->task_status_sort_order != $counts[$task->task_status_id]) {
 | 
						|
                    $task->task_status_sort_order = $counts[$task->task_status_id];
 | 
						|
                }
 | 
						|
                $counts[$task->task_status_id]++;
 | 
						|
                if ($task->isDirty()) {
 | 
						|
                    $task->save();
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        $data = [
 | 
						|
            'showBreadcrumbs' => false,
 | 
						|
            'title' => trans('texts.kanban'),
 | 
						|
            'statuses' => $statuses,
 | 
						|
            'tasks' => $tasks,
 | 
						|
            'clients' => $clients,
 | 
						|
            'projects' => $projects,
 | 
						|
            'clientPublicId' => $clientPublicId,
 | 
						|
            'client' => $clientPublicId ? Client::scope($clientPublicId)->first() : null,
 | 
						|
            'projectPublicId' => $projectPublicId,
 | 
						|
            'project' => $projectPublicId ? Project::scope($projectPublicId)->first() : null,
 | 
						|
        ];
 | 
						|
 | 
						|
        return view('tasks.kanban', $data);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @return \Illuminate\Http\RedirectResponse
 | 
						|
     */
 | 
						|
    public function storeStatus()
 | 
						|
    {
 | 
						|
        $status = TaskStatus::createNew();
 | 
						|
        $status->fill(request()->all());
 | 
						|
        $status->save();
 | 
						|
 | 
						|
        return response()->json($status);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param $publicId
 | 
						|
     *
 | 
						|
     * @return \Illuminate\Http\RedirectResponse
 | 
						|
     */
 | 
						|
    public function updateStatus($publicId)
 | 
						|
    {
 | 
						|
        $status = TaskStatus::scope($publicId)->firstOrFail();
 | 
						|
 | 
						|
        $origSortOrder = $status->sort_order;
 | 
						|
        $newSortOrder = request('sort_order');
 | 
						|
 | 
						|
        if (request()->has('sort_order') && $newSortOrder != $origSortOrder) {
 | 
						|
            TaskStatus::scope()
 | 
						|
                ->where('sort_order', '>', $origSortOrder)
 | 
						|
                ->decrement('sort_order');
 | 
						|
 | 
						|
            TaskStatus::scope()
 | 
						|
                ->where('sort_order', '>=', $newSortOrder)
 | 
						|
                ->increment('sort_order');
 | 
						|
        }
 | 
						|
 | 
						|
        $status->fill(request()->all());
 | 
						|
        $status->save();
 | 
						|
 | 
						|
        return response()->json($status);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @return \Illuminate\Http\RedirectResponse
 | 
						|
     */
 | 
						|
    public function deleteStatus($publicId)
 | 
						|
    {
 | 
						|
        $status = TaskStatus::scope($publicId)->firstOrFail();
 | 
						|
        $status->delete();
 | 
						|
 | 
						|
        TaskStatus::scope()
 | 
						|
            ->where('sort_order', '>', $status->sort_order)
 | 
						|
            ->decrement('sort_order');
 | 
						|
 | 
						|
        $firstStatus = TaskStatus::scope()
 | 
						|
            ->orderBy('sort_order')
 | 
						|
            ->first();
 | 
						|
 | 
						|
        // Move linked tasks to the end of the first status
 | 
						|
        if ($firstStatus) {
 | 
						|
            $firstCount = $firstStatus->tasks->count();
 | 
						|
            Task::scope()
 | 
						|
                ->where('task_status_id', '=', $status->id)
 | 
						|
                ->increment('task_status_sort_order', $firstCount, [
 | 
						|
                    'task_status_id' => $firstStatus->id
 | 
						|
                ]);
 | 
						|
        }
 | 
						|
 | 
						|
        return response()->json(['message' => RESULT_SUCCESS]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param $publicId
 | 
						|
     *
 | 
						|
     * @return \Illuminate\Http\RedirectResponse
 | 
						|
     */
 | 
						|
    public function updateTask($publicId)
 | 
						|
    {
 | 
						|
        $task = Task::scope($publicId)->firstOrFail();
 | 
						|
 | 
						|
        $origStatusId = $task->task_status_id;
 | 
						|
        $origSortOrder = $task->task_status_sort_order;
 | 
						|
 | 
						|
        $newStatusId = TaskStatus::getPrivateId(request('task_status_id'));
 | 
						|
        $newSortOrder = request('task_status_sort_order');
 | 
						|
 | 
						|
        Task::scope()
 | 
						|
            ->where('task_status_id', '=', $origStatusId)
 | 
						|
            ->where('task_status_sort_order', '>', $origSortOrder)
 | 
						|
            ->decrement('task_status_sort_order');
 | 
						|
 | 
						|
        Task::scope()
 | 
						|
            ->where('task_status_id', '=', $newStatusId)
 | 
						|
            ->where('task_status_sort_order', '>=', $newSortOrder)
 | 
						|
            ->increment('task_status_sort_order');
 | 
						|
 | 
						|
        $task->task_status_id = $newStatusId;
 | 
						|
        $task->task_status_sort_order = $newSortOrder;
 | 
						|
        $task->save();
 | 
						|
 | 
						|
        return response()->json($task);
 | 
						|
    }
 | 
						|
 | 
						|
}
 |