add import tasks to xlsx

This commit is contained in:
iIronside
2023-11-10 15:55:01 +03:00
parent bc4cb3b54c
commit 05271d5f17
20 changed files with 542 additions and 116 deletions

View File

@ -2,25 +2,14 @@
namespace frontend\modules\api\controllers;
use common\classes\Debug;
use common\models\ProjectColumn;
use frontend\modules\api\models\Project;
use frontend\modules\api\models\project\Project;
use yii\db\ActiveRecord;
use yii\web\BadRequestHttpException;
use yii\web\NotFoundHttpException;
class ProjectColumnController extends ApiController
{
public function verbs(): array
{
return [
'get-column-list' => ['get'],
'create-column' => ['post'],
'set-priority' => ['post'],
'update-column' => ['put', 'patch'],
];
}
/**
*
* @OA\Get(path="/project-column/get-column-list",
@ -49,17 +38,17 @@ class ProjectColumnController extends ApiController
* )
*
* @param $project_id
* @return array|\yii\db\ActiveRecord[]
* @return array|ActiveRecord[]
* @throws BadRequestHttpException
*/
public function actionGetColumnList($project_id)
public function actionGetColumnList($project_id): array
{
$project = Project::findOne($project_id);
if (!$project) {
throw new BadRequestHttpException(json_encode(['Проект не найден']));
}
$columns = \frontend\modules\api\models\ProjectColumn::find()->where(['project_id' => $project_id, 'status' => ProjectColumn::STATUS_ACTIVE])->all();
$columns = \frontend\modules\api\models\project\ProjectColumn::find()->where(['project_id' => $project_id, 'status' => ProjectColumn::STATUS_ACTIVE])->all();
return $columns;
@ -177,7 +166,7 @@ class ProjectColumnController extends ApiController
* ),
* )
*
* @return array|ProjectColumn|\yii\db\ActiveRecord|null
* @return array|ProjectColumn|ActiveRecord|null
* @throws BadRequestHttpException
* @throws \yii\base\InvalidConfigException
*/
@ -241,7 +230,7 @@ class ProjectColumnController extends ApiController
* ),
* )
*
* @return array|Project|\yii\db\ActiveRecord
* @return array|Project|ActiveRecord
* @throws BadRequestHttpException
*/
public function actionSetPriority()

View File

@ -2,15 +2,16 @@
namespace frontend\modules\api\controllers;
use common\classes\Debug;
use common\models\ProjectTaskCategory;
use common\models\Status;
use common\models\UseStatus;
use frontend\modules\api\models\Manager;
use frontend\modules\api\models\Project;
use frontend\modules\api\models\ProjectUser;
use frontend\modules\api\models\project\Project;
use frontend\modules\api\models\project\ProjectUser;
use Yii;
use yii\base\InvalidConfigException;
use yii\data\ActiveDataProvider;
use yii\db\ActiveRecord;
use yii\helpers\ArrayHelper;
use yii\web\BadRequestHttpException;
use yii\web\NotFoundHttpException;
@ -84,7 +85,7 @@ class ProjectController extends ApiController
* )
*
* @param $project_id
* @return array|Project|\yii\db\ActiveRecord|null
* @return array|ActiveRecord|null
*/
public function actionGetProject($project_id)
{
@ -323,7 +324,7 @@ class ProjectController extends ApiController
* )
*
* @throws \Throwable
* @throws \yii\base\InvalidConfigException
* @throws InvalidConfigException
* @throws \yii\db\StaleObjectException
* @throws NotFoundHttpException
*/
@ -366,7 +367,7 @@ class ProjectController extends ApiController
* ),
* )
*
* @return array|\yii\db\ActiveRecord
* @return array|ActiveRecord
* @throws BadRequestHttpException
*/
public function actionMyEmployee()
@ -486,7 +487,7 @@ class ProjectController extends ApiController
* )
*
* @return Project
* @throws \yii\base\InvalidConfigException
* @throws InvalidConfigException|NotFoundHttpException
*/
public function actionDelUser(): Project
{

View File

@ -2,31 +2,32 @@
namespace frontend\modules\api\controllers;
use common\classes\Debug;
use common\models\ProjectTask;
use common\models\ProjectTaskUser;
use common\models\User;
use common\services\TaskService;
use frontend\modules\api\models\ProjectColumn;
use frontend\modules\api\models\project\ProjectColumn;
use frontend\modules\api\services\TaskService;
use Yii;
use yii\base\InvalidConfigException;
use yii\data\ActiveDataProvider;
use yii\web\BadRequestHttpException;
use yii\web\NotFoundHttpException;
use yii\web\ServerErrorHttpException;
class TaskController extends ApiController
{
public function verbs(): array
private TaskService $taskService;
/**
* @param $id
* @param $module
* @param TaskService $taskService
* @param array $config
*/
public function __construct($id, $module, TaskService $taskService, $config = [])
{
return [
'get-task' => ['get'],
'get-task-list' => ['get'],
'get-user-tasks' => ['get'],
'create-task' => ['post'],
'update-task' => ['put', 'patch'],
'add-user-to-task' => ['post'],
'del-user' => ['delete'],
];
$this->taskService = $taskService;
parent::__construct($id, $module, $config);
}
/**
@ -117,7 +118,7 @@ class TaskController extends ApiController
$request['user_id'] = Yii::$app->user->id;
}
$taskModel = TaskService::createTask($request);
$taskModel = $this->taskService->createTask($request);
if ($taskModel->errors) {
throw new ServerErrorHttpException(json_encode($taskModel->errors));
}
@ -170,9 +171,9 @@ class TaskController extends ApiController
if (empty($project_id) or !is_numeric($project_id)) {
throw new NotFoundHttpException('Incorrect project ID');
}
$tasks = TaskService::getTaskListByProject($project_id);
$tasks = $this->taskService->getTaskListByProject($project_id);
} else {
$tasks = TaskService::getTaskList($project_id);
$tasks = $this->taskService->getTaskList($project_id);
}
if (empty($tasks)) {
@ -228,9 +229,9 @@ class TaskController extends ApiController
if (empty($user_id) or !is_numeric($user_id)) {
throw new NotFoundHttpException('Incorrect project ID');
}
$tasks = TaskService::getTaskListByUser($user_id);
$tasks = $this->taskService->getTaskListByUser($user_id);
} else {
$tasks = TaskService::getTaskList($user_id);
$tasks = $this->taskService->getTaskList($user_id);
}
if (empty($tasks)) {
@ -283,7 +284,7 @@ class TaskController extends ApiController
throw new NotFoundHttpException('Incorrect task ID');
}
$task = TaskService::getTask($task_id);
$task = $this->taskService->getTask($task_id);
if (empty($task)) {
throw new NotFoundHttpException('The task does not exist');
}
@ -372,11 +373,11 @@ class TaskController extends ApiController
public function actionUpdateTask(): ?ProjectTask
{
$params = array_diff(\Yii::$app->request->getBodyParams(), [null, '']);
if (empty ($params['task_id']) or !TaskService::taskExists($params['task_id'])) {
if (empty ($params['task_id']) or !$this->taskService->taskExists($params['task_id'])) {
throw new NotFoundHttpException('The task does not exist');
}
$modelTask = TaskService::updateTask($params);
$modelTask = $this->taskService->updateTask($params);
if (!empty($modelTask->hasErrors())) {
throw new ServerErrorHttpException(json_encode($modelTask->errors));
}
@ -435,7 +436,7 @@ class TaskController extends ApiController
throw new NotFoundHttpException('User not found');
}
if (empty ($request['task_id']) or !TaskService::taskExists($request['task_id'])) {
if (empty ($request['task_id']) or !$this->taskService->taskExists($request['task_id'])) {
throw new NotFoundHttpException('The task does not exist');
}
@ -506,13 +507,13 @@ class TaskController extends ApiController
throw new NotFoundHttpException('User not found');
}
if (empty ($request['task_id']) or !TaskService::taskExists($request['task_id'])) {
if (empty ($request['task_id']) or !$this->taskService->taskExists($request['task_id'])) {
throw new NotFoundHttpException('The task does not exist');
}
ProjectTaskUser::deleteAll(['task_id' => $request['task_id'], 'user_id' => $request['user_id']]);
return TaskService::getTask($request['task_id']);
return $this->taskService->getTask($request['task_id']);
}
/**
@ -582,4 +583,72 @@ class TaskController extends ApiController
return $column;
}
/**
*
* @OA\Get(path="/task/import",
* summary="Экспорт задач",
* description="Метод экспорта задач в xlsx",
* security={
* {"bearerAuth": {}}
* },
* tags={"TaskManager"},
* @OA\Parameter(
* name="companyId",
* in="query",
* description="ID компании",
* required=true,
* @OA\Schema(
* type="integer",
* )
* ),
* @OA\Parameter(
* name="userId",
* in="query",
* description="ID исполнителя задачи",
* required=true,
* @OA\Schema(
* type="integer",
* )
* ),
* @OA\Parameter(
* name="projectId",
* in="query",
* description="ID проекта",
* required=true,
* @OA\Schema(
* type="integer",
* )
* ),
* @OA\Parameter(
* name="fromDate",
* in="query",
* example="2023-11-09",
* description="Поиск задач с указанной даты",
* @OA\Schema(
* type="string",
* )
* ),
* @OA\Parameter(
* name="toDate",
* in="query",
* example="2023-11-09",
* description="Поиск задач до указанной даты",
* @OA\Schema(
* type="string",
* )
* ),
* @OA\Response(
* response=200,
* description="Возвращает задачи в xlsx файле",
* ),
* )
*
* @return string|void
* @throws BadRequestHttpException
*/
public function actionImport()
{
return $this->taskService->importTasks(Yii::$app->request->get());
}
}