/** * * @return mixed */ public function getEntriesForTheDay($date) { $entries = Entry::forCurrentUser()->where('date', $date)->orderBy('id', 'asc')->get(); return $this->compactExerciseEntries($entries, $date); }
/** * @test * @return void */ public function it_can_delete_an_exercise_entry() { $this->logInUser(); $date = Carbon::today()->format('Y-m-d'); $entry = new Entry(['date' => $date, 'quantity' => 501]); $entry->user()->associate($this->user); $entry->exercise()->associate(Exercise::find(1)); $entry->unit()->associate(Unit::find(1)); $entry->save(); $this->seeInDatabase('exercise_entries', ['date' => $date, 'exercise_id' => 1, 'quantity' => 501, 'exercise_unit_id' => 1]); $response = $this->call('DELETE', '/api/exerciseEntries/' . $entry->id); $this->assertEquals(204, $response->getStatusCode()); $this->missingFromDatabase('exercise_entries', ['date' => $date, 'exercise_id' => 1, 'quantity' => 501, 'exercise_unit_id' => 1]); $response = $this->call('DELETE', '/api/exerciseEntries/' . $entry->id); $this->assertEquals(404, $response->getStatusCode()); }
/** * * @param $date * @return mixed */ public function calculateTotal($date) { return $this->total = Entry::forCurrentUser()->where('date', $date)->where('exercise_id', $this->exercise->id)->where('exercise_unit_id', $this->unit->id)->sum('quantity'); }
/** * * @param $quantity * @param Exercise $exercise * @param Unit $unit * @param Carbon $date */ private function createEntry($quantity, Exercise $exercise, Unit $unit, Carbon $date) { $entry = new Entry(['date' => $date->format('Y-m-d'), 'quantity' => $quantity]); $entry->user()->associate($this->user); $entry->unit()->associate($unit); $entry->exercise()->associate($exercise); $entry->save(); }
/** * * @param Entry $entry * @return \Illuminate\Http\Response * @throws \Exception */ public function destroy(Entry $entry) { $entry->delete(); return $this->responseNoContent(); }
/** * Define your route model bindings, pattern filters, etc. * * @param \Illuminate\Routing\Router $router * @return void */ public function boot(Router $router) { parent::boot($router); Route::bind('exercises', function ($id) { return Exercise::forCurrentUser()->findOrFail($id); }); Route::bind('exerciseEntries', function ($id) { return ExerciseEntry::forCurrentUser()->findOrFail($id); }); Route::bind('menuEntries', function ($id) { return MenuEntry::forCurrentUser()->findOrFail($id); }); Route::bind('exerciseSeries', function ($id) { return ExerciseSeries::forCurrentUser()->findOrFail($id); }); Route::bind('foods', function ($id) { return Food::forCurrentUser()->findOrFail($id); }); Route::bind('recipes', function ($id) { return Recipe::forCurrentUser()->findOrFail($id); }); Route::bind('exerciseTags', function ($id) { return Tag::forCurrentUser()->where('for', 'exercise')->findOrFail($id); }); Route::bind('recipeTags', function ($id) { return Tag::forCurrentUser()->where('for', 'recipe')->findOrFail($id); }); Route::bind('foodUnits', function ($id) { return Unit::forCurrentUser()->where('for', 'food')->findOrFail($id); }); Route::bind('exerciseUnits', function ($id) { return Unit::forCurrentUser()->where('for', 'exercise')->findOrFail($id); }); Route::bind('timers', function ($id) { return Timer::forCurrentUser()->findOrFail($id); }); Route::bind('activities', function ($id) { return Activity::forCurrentUser()->findOrFail($id); }); Route::bind('weights', function ($idOrDate) { if (strrpos($idOrDate, '-')) { //parameter is the date of the entry $weight = Weight::forCurrentUser()->where('date', $idOrDate)->first(); } else { //parameter is the id of the entry $weight = Weight::forCurrentUser()->findOrFail($idOrDate); } return $weight; }); /** * $parameter is either the id or the date */ Route::bind('journal', function ($parameter) { /** * @VP: * Is there a better way to check if the $parameter is an * id or a date? When I tried using Carbon to create an object from * the parameter, it threw an exception when the $parameter was the id, * whereas I just wanted a boolean. */ if (strrpos($parameter, '-')) { //$parameter is the date of the entry $journal = Journal::forCurrentUser()->where('date', $parameter)->first(); } else { //$parameter is the id of the entry $journal = Journal::forCurrentUser()->findOrFail($parameter); } return $journal; }); }