first commit
This commit is contained in:
184
app/Enums/UniversalReportBase.php
Normal file
184
app/Enums/UniversalReportBase.php
Normal file
@@ -0,0 +1,184 @@
|
||||
<?php
|
||||
|
||||
namespace App\Enums;
|
||||
|
||||
use App\Models\Project;
|
||||
use App\Models\Task;
|
||||
use App\Models\User;
|
||||
|
||||
enum UniversalReportBase: string
|
||||
{
|
||||
case PROJECT = 'project';
|
||||
case USER = 'user';
|
||||
case TASK = 'task';
|
||||
|
||||
|
||||
public function fields() {
|
||||
return match($this) {
|
||||
self::PROJECT => [
|
||||
'base' => [
|
||||
'name',
|
||||
'created_at',
|
||||
'description',
|
||||
'important',
|
||||
],
|
||||
'tasks' => [
|
||||
'task_name',
|
||||
'priority',
|
||||
'status',
|
||||
'due_date',
|
||||
'estimate',
|
||||
'description',
|
||||
],
|
||||
'users' => [
|
||||
'full_name',
|
||||
'email',
|
||||
],
|
||||
// 'work_time',
|
||||
// 'work_time_user',
|
||||
'calculations' => [
|
||||
'total_spent_time',
|
||||
'total_spent_time_by_user',
|
||||
'total_spent_time_by_day',
|
||||
'total_spent_time_by_day_and_user',
|
||||
],
|
||||
|
||||
],
|
||||
self::USER => [
|
||||
'base' => [
|
||||
'full_name',
|
||||
'email',
|
||||
],
|
||||
'projects' => [
|
||||
'name',
|
||||
'created_at',
|
||||
'description',
|
||||
'important',
|
||||
],
|
||||
'tasks' => [
|
||||
'task_name',
|
||||
'priority',
|
||||
'status',
|
||||
'due_date',
|
||||
'estimate',
|
||||
'description',
|
||||
],
|
||||
'calculations' => [
|
||||
'total_spent_time',
|
||||
'total_spent_time_by_day',
|
||||
]
|
||||
],
|
||||
self::TASK => [
|
||||
'base' => [
|
||||
'task_name',
|
||||
'priority',
|
||||
'status',
|
||||
'due_date',
|
||||
'estimate',
|
||||
'description',
|
||||
// 'workers',
|
||||
],
|
||||
'users' => [
|
||||
'full_name',
|
||||
'email',
|
||||
],
|
||||
'projects' => [
|
||||
'name',
|
||||
'created_at',
|
||||
'description',
|
||||
'important',
|
||||
],
|
||||
'calculations' => [
|
||||
'total_spent_time',
|
||||
'total_spent_time_by_day',
|
||||
'total_spent_time_by_user',
|
||||
'total_spent_time_by_day_and_user'
|
||||
],
|
||||
// 'total_spent_time',
|
||||
// 'user_name',
|
||||
// 'user_time',
|
||||
],
|
||||
};
|
||||
}
|
||||
|
||||
public function dataObjects()
|
||||
{
|
||||
return match($this) {
|
||||
self::PROJECT => (function() {
|
||||
if(request()->user()->isAdmin()) {
|
||||
return Project::select('id', 'name')->get();
|
||||
}
|
||||
|
||||
return request()->user()->projects()->select('id', 'name')->get();
|
||||
})(),
|
||||
self::USER => (function() {
|
||||
if (request()->user()->isAdmin()) {
|
||||
return User::select('id', 'full_name as name', 'email', 'full_name')->get();
|
||||
}
|
||||
|
||||
return;
|
||||
})(),
|
||||
self::TASK => (function() {
|
||||
if(request()->user()->isAdmin()) {
|
||||
return Task::select('id', 'task_name as name')->get();
|
||||
}
|
||||
|
||||
return request()->user()->tasks()->select('id', 'name')->get();
|
||||
})()
|
||||
};
|
||||
}
|
||||
public function charts() {
|
||||
// [
|
||||
// // Project
|
||||
// "worked_all_users",// "Отработанное время всеми пользователями на проекте за указанный период",
|
||||
// "worked_all_users_separately",// "Отработанное время каждым пользователем на проекте за указанный период",
|
||||
// // Task
|
||||
// 'worked_all_users',// "Отработанное время всеми пользователями на задаче за указанный период",
|
||||
// 'worked_all_users_separately',// "Отработанное время каждым пользователем на задаче за указанный период",
|
||||
// // User
|
||||
// 'total_hours',// "Всего часов за указанный период",
|
||||
// 'hours_tasks',// "Часов на каждой задаче",
|
||||
// 'hours_projects',// "Часов на каждом проекте",
|
||||
|
||||
// ];
|
||||
return match($this) {
|
||||
self::PROJECT => [
|
||||
'total_spent_time_day',
|
||||
'total_spent_time_day_and_users_separately',
|
||||
],
|
||||
self::USER => [
|
||||
'total_spent_time_day',
|
||||
'total_spent_time_day_and_tasks',
|
||||
'total_spent_time_day_and_projects',
|
||||
],
|
||||
self::TASK => [
|
||||
'total_spent_time_day',
|
||||
'total_spent_time_day_users_separately',
|
||||
],
|
||||
};
|
||||
}
|
||||
|
||||
public static function bases()
|
||||
{
|
||||
return array_map(fn($case) => $case->value, self::cases());
|
||||
}
|
||||
|
||||
public function checkAccess(array $data_objects)
|
||||
{
|
||||
$user = request()->user();
|
||||
return match($this) {
|
||||
self::PROJECT => $user->projects()->select('id')->whereIn('id', $data_objects)->withoutGlobalScopes()->get()->count() === count($data_objects),
|
||||
self::USER => '',
|
||||
self::TASK => $user->tasks()->select('id')->whereIn('id', $data_objects)->withoutGlobalScopes()->get()->count() === count($data_objects),
|
||||
};
|
||||
}
|
||||
|
||||
public function model()
|
||||
{
|
||||
return match($this) {
|
||||
self::PROJECT => new Project(),
|
||||
self::USER => new User(),
|
||||
self::TASK => new Task(),
|
||||
};
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user