From b8fa0246803dab40cf57d40b45984c53046f2d55 Mon Sep 17 00:00:00 2001 From: "Dzial Techniczny WMW Projekt s.c" Date: Tue, 10 Dec 2019 11:34:53 +0100 Subject: Plugins directory and local modifications --- plugins/Calendar/Controller/CalendarController.php | 137 +++++++++++++++++++++ 1 file changed, 137 insertions(+) create mode 100644 plugins/Calendar/Controller/CalendarController.php (limited to 'plugins/Calendar/Controller/CalendarController.php') diff --git a/plugins/Calendar/Controller/CalendarController.php b/plugins/Calendar/Controller/CalendarController.php new file mode 100644 index 00000000..94a1e5e2 --- /dev/null +++ b/plugins/Calendar/Controller/CalendarController.php @@ -0,0 +1,137 @@ +getUser(); + + $this->response->html($this->helper->layout->app('Calendar:calendar/user', array( + 'user' => $user, + ))); + } + + public function project() + { + $project = $this->getProject(); + + $this->response->html($this->helper->layout->app('Calendar:calendar/project', array( + 'project' => $project, + 'title' => $project['name'], + 'description' => $this->helper->projectHeader->getDescription($project), + ))); + } + + public function projectEvents() + { + $projectId = $this->request->getIntegerParam('project_id'); + $startRange = $this->request->getStringParam('start'); + $endRange = $this->request->getStringParam('end'); + $search = $this->userSession->getFilters($projectId); + $startColumn = $this->configModel->get('calendar_project_tasks', 'date_started'); + + $dueDateOnlyEvents = $this->taskLexer->build($search) + ->withFilter(new TaskProjectFilter($projectId)) + ->withFilter(new TaskDueDateRangeFilter(array($startRange, $endRange))) + ->format($this->taskCalendarFormatter->setColumns('date_due')); + + $startAndDueDateQueryBuilder = $this->taskLexer->build($search) + ->withFilter(new TaskProjectFilter($projectId)); + + $startAndDueDateQueryBuilder + ->getQuery() + ->addCondition($this->getConditionForTasksWithStartAndDueDate($startRange, $endRange, $startColumn, 'date_due')); + + $startAndDueDateEvents = $startAndDueDateQueryBuilder + ->format($this->taskCalendarFormatter->setColumns($startColumn, 'date_due')); + + $events = array_merge($dueDateOnlyEvents, $startAndDueDateEvents); + + $events = $this->hook->merge('controller:calendar:project:events', $events, array( + 'project_id' => $projectId, + 'start' => $startRange, + 'end' => $endRange, + )); + + $this->response->json($events); + } + + public function userEvents() + { + $user_id = $this->request->getIntegerParam('user_id'); + $startRange = $this->request->getStringParam('start'); + $endRange = $this->request->getStringParam('end'); + $startColumn = $this->configModel->get('calendar_project_tasks', 'date_started'); + + $dueDateOnlyEvents = $this->taskQuery + ->withFilter(new TaskAssigneeFilter($user_id)) + ->withFilter(new TaskStatusFilter(TaskModel::STATUS_OPEN)) + ->withFilter(new TaskDueDateRangeFilter(array($startRange, $endRange))) + ->format($this->taskCalendarFormatter->setColumns('date_due')); + + $startAndDueDateQueryBuilder = $this->taskQuery + ->withFilter(new TaskAssigneeFilter($user_id)) + ->withFilter(new TaskStatusFilter(TaskModel::STATUS_OPEN)); + + $startAndDueDateQueryBuilder + ->getQuery() + ->addCondition($this->getConditionForTasksWithStartAndDueDate($startRange, $endRange, $startColumn, 'date_due')); + + $startAndDueDateEvents = $startAndDueDateQueryBuilder + ->format($this->taskCalendarFormatter->setColumns($startColumn, 'date_due')); + + $events = array_merge($dueDateOnlyEvents, $startAndDueDateEvents); + + $events = $this->hook->merge('controller:calendar:user:events', $events, array( + 'user_id' => $user_id, + 'start' => $startRange, + 'end' => $endRange, + )); + + $this->response->json($events); + } + + public function save() + { + if ($this->request->isAjax() && $this->request->isPost()) { + $values = $this->request->getJson(); + + $this->taskModificationModel->update(array( + 'id' => $values['task_id'], + 'date_due' => substr($values['date_due'], 0, 10), + )); + } + } + + protected function getConditionForTasksWithStartAndDueDate($startTime, $endTime, $startColumn, $endColumn) + { + $startTime = strtotime($startTime); + $endTime = strtotime($endTime); + $startColumn = $this->db->escapeIdentifier($startColumn); + $endColumn = $this->db->escapeIdentifier($endColumn); + + $conditions = array( + "($startColumn >= '$startTime' AND $startColumn <= '$endTime')", + "($startColumn <= '$startTime' AND $endColumn >= '$startTime')", + "($startColumn <= '$startTime' AND ($endColumn = '0' OR $endColumn IS NULL))", + ); + + return $startColumn.' IS NOT NULL AND '.$startColumn.' > 0 AND ('.implode(' OR ', $conditions).')'; + } +} -- cgit v1.2.3