getUsersService(); $users = $usersService->GetUsersAsDto(); if ($args['choreId'] == 'new') { return $this->renderPage($response, 'choreform', [ 'periodTypes' => GetClassConstants('\Grocy\Services\ChoresService', 'CHORE_PERIOD_TYPE_'), 'mode' => 'create', 'userfields' => $this->getUserfieldsService()->GetFields('chores'), 'assignmentTypes' => GetClassConstants('\Grocy\Services\ChoresService', 'CHORE_ASSIGNMENT_TYPE_'), 'users' => $users, 'products' => $this->getDatabase()->products()->orderBy('name', 'COLLATE NOCASE') ]); } else { return $this->renderPage($response, 'choreform', [ 'chore' => $this->getDatabase()->chores($args['choreId']), 'periodTypes' => GetClassConstants('\Grocy\Services\ChoresService', 'CHORE_PERIOD_TYPE_'), 'mode' => 'edit', 'userfields' => $this->getUserfieldsService()->GetFields('chores'), 'assignmentTypes' => GetClassConstants('\Grocy\Services\ChoresService', 'CHORE_ASSIGNMENT_TYPE_'), 'users' => $users, 'products' => $this->getDatabase()->products()->orderBy('name', 'COLLATE NOCASE') ]); } } public function ChoresList(\Psr\Http\Message\ServerRequestInterface $request, \Psr\Http\Message\ResponseInterface $response, array $args) { if (isset($request->getQueryParams()['include_disabled'])) { $chores = $this->getDatabase()->chores()->orderBy('name', 'COLLATE NOCASE'); } else { $chores = $this->getDatabase()->chores()->where('active = 1')->orderBy('name', 'COLLATE NOCASE'); } return $this->renderPage($response, 'chores', [ 'chores' => $chores, 'userfields' => $this->getUserfieldsService()->GetFields('chores'), 'userfieldValues' => $this->getUserfieldsService()->GetAllValues('chores') ]); } public function ChoresSettings(\Psr\Http\Message\ServerRequestInterface $request, \Psr\Http\Message\ResponseInterface $response, array $args) { return $this->renderPage($response, 'choressettings'); } public function Journal(\Psr\Http\Message\ServerRequestInterface $request, \Psr\Http\Message\ResponseInterface $response, array $args) { if (isset($request->getQueryParams()['months']) && filter_var($request->getQueryParams()['months'], FILTER_VALIDATE_INT) !== false) { $months = $request->getQueryParams()['months']; $where = "tracked_time > DATE(DATE('now', 'localtime'), '-$months months')"; } else { // Default 1 year $where = "tracked_time > DATE(DATE('now', 'localtime'), '-12 months')"; } if (isset($request->getQueryParams()['chore']) && filter_var($request->getQueryParams()['chore'], FILTER_VALIDATE_INT) !== false) { $choreId = $request->getQueryParams()['chore']; $where .= " AND chore_id = $choreId"; } return $this->renderPage($response, 'choresjournal', [ 'choresLog' => $this->getDatabase()->chores_log()->where($where)->orderBy('tracked_time', 'DESC'), 'chores' => $this->getDatabase()->chores()->where('active = 1')->orderBy('name', 'COLLATE NOCASE'), 'users' => $this->getDatabase()->users()->orderBy('username'), 'userfields' => $this->getUserfieldsService()->GetFields('chores_log'), 'userfieldValues' => $this->getUserfieldsService()->GetAllValues('chores_log') ]); } public function Overview(\Psr\Http\Message\ServerRequestInterface $request, \Psr\Http\Message\ResponseInterface $response, array $args) { $usersService = $this->getUsersService(); $nextXDays = $usersService->GetUserSettings(GROCY_USER_ID)['chores_due_soon_days']; $chores = $this->getDatabase()->chores()->orderBy('name', 'COLLATE NOCASE'); $currentChores = $this->getChoresService()->GetCurrent(); foreach ($currentChores as $currentChore) { if (!empty($currentChore->next_estimated_execution_time)) { if ($currentChore->next_estimated_execution_time < date('Y-m-d H:i:s')) { $currentChore->due_type = 'overdue'; } elseif ($currentChore->next_estimated_execution_time <= date('Y-m-d 23:59:59')) { $currentChore->due_type = 'duetoday'; } elseif ($nextXDays > 0 && $currentChore->next_estimated_execution_time <= date('Y-m-d H:i:s', strtotime('+' . $nextXDays . ' days'))) { $currentChore->due_type = 'duesoon'; } } } return $this->renderPage($response, 'choresoverview', [ 'chores' => $chores, 'currentChores' => $currentChores, 'nextXDays' => $nextXDays, 'userfields' => $this->getUserfieldsService()->GetFields('chores'), 'userfieldValues' => $this->getUserfieldsService()->GetAllValues('chores'), 'users' => $usersService->GetUsersAsDto() ]); } public function TrackChoreExecution(\Psr\Http\Message\ServerRequestInterface $request, \Psr\Http\Message\ResponseInterface $response, array $args) { return $this->renderPage($response, 'choretracking', [ 'chores' => $this->getDatabase()->chores()->where('active = 1')->orderBy('name', 'COLLATE NOCASE'), 'users' => $this->getDatabase()->users()->orderBy('username'), 'userfields' => $this->getUserfieldsService()->GetFields('chores_log'), ]); } public function ChoreGrocycodeImage(\Psr\Http\Message\ServerRequestInterface $request, \Psr\Http\Message\ResponseInterface $response, array $args) { $gc = new Grocycode(Grocycode::CHORE, $args['choreId']); return $this->ServeGrocycodeImage($request, $response, $gc); } }