getQueryParams()['include_disabled'])) { $batteries = $this->getDatabase()->batteries()->orderBy('name', 'COLLATE NOCASE'); } else { $batteries = $this->getDatabase()->batteries()->where('active = 1')->orderBy('name', 'COLLATE NOCASE'); } return $this->renderPage($response, 'batteries', [ 'batteries' => $batteries, 'userfields' => $this->getUserfieldsService()->GetFields('batteries'), 'userfieldValues' => $this->getUserfieldsService()->GetAllValues('batteries') ]); } public function BatteriesSettings(Request $request, Response $response, array $args) { return $this->renderPage($response, 'batteriessettings'); } public function BatteryEditForm(Request $request, Response $response, array $args) { if ($args['batteryId'] == 'new') { return $this->renderPage($response, 'batteryform', [ 'mode' => 'create', 'userfields' => $this->getUserfieldsService()->GetFields('batteries') ]); } else { return $this->renderPage($response, 'batteryform', [ 'battery' => $this->getDatabase()->batteries($args['batteryId']), 'mode' => 'edit', 'userfields' => $this->getUserfieldsService()->GetFields('batteries') ]); } } public function Journal(Request $request, Response $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 2 years $where = "tracked_time > DATE(DATE('now', 'localtime'), '-24 months')"; } if (isset($request->getQueryParams()['battery']) && filter_var($request->getQueryParams()['battery'], FILTER_VALIDATE_INT) !== false) { $batteryId = $request->getQueryParams()['battery']; $where .= " AND battery_id = $batteryId"; } return $this->renderPage($response, 'batteriesjournal', [ 'chargeCycles' => $this->getDatabase()->battery_charge_cycles()->where($where)->orderBy('tracked_time', 'DESC'), 'batteries' => $this->getDatabase()->batteries()->where('active = 1')->orderBy('name', 'COLLATE NOCASE') ]); } public function Overview(Request $request, Response $response, array $args) { $usersService = $this->getUsersService(); $nextXDays = $usersService->GetUserSettings(GROCY_USER_ID)['batteries_due_soon_days']; $batteries = $this->getDatabase()->batteries()->where('active = 1'); $currentBatteries = $this->getBatteriesService()->GetCurrent(); foreach ($currentBatteries as $currentBattery) { if (FindObjectInArrayByPropertyValue($batteries, 'id', $currentBattery->battery_id)->charge_interval_days > 0) { if ($currentBattery->next_estimated_charge_time < date('Y-m-d H:i:s')) { $currentBattery->due_type = 'overdue'; } elseif ($currentBattery->next_estimated_charge_time <= date('Y-m-d 23:59:59')) { $currentBattery->due_type = 'duetoday'; } elseif ($nextXDays > 0 && $currentBattery->next_estimated_charge_time <= date('Y-m-d H:i:s', strtotime('+' . $nextXDays . ' days'))) { $currentBattery->due_type = 'duesoon'; } } } return $this->renderPage($response, 'batteriesoverview', [ 'batteries' => $batteries, 'current' => $currentBatteries, 'nextXDays' => $nextXDays, 'userfields' => $this->getUserfieldsService()->GetFields('batteries'), 'userfieldValues' => $this->getUserfieldsService()->GetAllValues('batteries') ]); } public function TrackChargeCycle(Request $request, Response $response, array $args) { return $this->renderPage($response, 'batterytracking', [ 'batteries' => $this->getDatabase()->batteries()->where('active = 1')->orderBy('name', 'COLLATE NOCASE') ]); } public function BatteryGrocycodeImage(Request $request, Response $response, array $args) { $gc = new Grocycode(Grocycode::BATTERY, $args['batteryId']); return $this->ServeGrocycodeImage($request, $response, $gc); } }