前提・実現したいこと
現在laravelで開発している掲示板の返信を降順にしたいです。
showの画面で@forelse($post->comments as $comment)
のところを
@forelse($post->comments()->orderBy('created_at', 'desc')->get() as $comment)
と記載すれば降順になるのですが、これをshowの画面ではなくコントローラー側で行いたいです。
該当のソースコード
PostsController
1<?php 2 3namespace App\Http\Controllers; 4 5use App\Post; 6use Illuminate\Http\Request; 7use App\Http\Requests\PostRequest; 8use Illuminate\Support\Facades\Hash; 9 10 11class PostsController extends Controller 12{ 13 /** 14 * 投稿データをposts.indexに渡してビューを生成 15 */ 16 public function index() 17 { 18 $posts = Post::with(['comments'])->orderBy('created_at', 'desc')->paginate(10); 19 return view('posts.index', ['posts' => $posts]); 20 } 21 22 /** 23 *投稿画面へ 24 */ 25 public function create() 26 { 27 return view('posts.create'); 28 } 29 30 /** 31 * 投稿されたデータをDBに保存しメッセージを返す 32 * @param App\Http\Requests\PostRequest $request 33 */ 34 public function store(PostRequest $request) 35 { 36 $post = new Post; 37 $post->title = $request->title; 38 $post->body = $request->body; 39 $post->name = $request->name; 40 $post->password = bcrypt($request->password); 41 $post->save(); 42 43 return redirect()->route('top')->with('message', '投稿しました'); 44 } 45 46 /** 47 * 特定の投稿の情報を取得 48 * @param Post $post 49 */ 50 public function show($post_id) 51 { 52 $post = Post::findOrFail($post_id); 53 54 return view('posts.show', ['post' => $post,]); 55 } 56 57 58 /** 59 * 投稿を削除する 60 * @param Request $request, Post $post 61 */ 62 public function destroy(Request $request, Post $post) 63 { 64 if (Hash::check($request->password, $post->password)) { 65 $post->delete(); 66 return redirect()->route('top')->with('message', '削除しました'); 67 }else{ 68 return back()->with('message', '削除できませんでした'); 69 } 70 } 71}
CommentsController
1<?php 2 3namespace App\Http\Controllers; 4 5use App\Post; 6use App\Comment; 7use Illuminate\Http\Request; 8use App\Http\Requests\CommentRequest; 9use Illuminate\Support\Facades\Hash; 10 11 12class CommentsController extends Controller 13{ 14 /** 15 * Display a listing of the resource. 16 * 返信のデータをposts.showに渡してビューを生成 17 * 投稿に紐ついたコメントをDBに保存 18 * @param Post $post 19 * @return \Illuminate\Http\Response $comment 20 */ 21 public function store(CommentRequest $request) 22 { 23 $comment = new Comment; 24 $comment->body = $request->body; 25 $comment->name = $request->name; 26 $comment->password = bcrypt($request->password); 27 $post = Post::findOrFail($request->post_id); 28 $post->comments()->save($comment); 29 30 return redirect()->route('posts.show', ['post' => $post])->with('message', '返信しました'); 31 } 32 33 /** 34 * Remove the specified resource from storage. 35 * 特定のコメントを削除 36 * @param Request $request, Comment $comment 37 */ 38 public function destroy(Request $request, Comment $comment) 39 { 40 if (Hash::check($request->password, $comment->password)) { 41 $comment->delete(); 42 return back()->with('message', '削除しました'); 43 }else{ 44 return back()->with('message', '削除できませんでした'); 45 } 46 } 47}
showbrade
1@extends('layout') 2 3@section('content') 4 5@if(session()->has('message')) 6<div class="alert alert-info mb-3"> 7 {{session('message')}} 8</div> 9@endif 10 11<div class="container mt-4"> 12 <div class="border p-4"> 13 14 <div class="mb-4 text-right"> 15 <form action="{{ route('posts.destroy', ['post' => $post]) }}" method="POST"> 16 @csrf 17 @method('DELETE') 18 <div class="form-group"> 19 <input type="password" name="password" class="form-control" placeholder="パスワードを入力してください"> 20 <button type="submit" class="btn btn-success">この投稿を削除する</button> 21 </div> 22 </form> 23 </div> 24 25 <h1 class="h5 mb-4"> 26 {{ $post->title }} 27 </h1> 28 29 <p class="mb-5"> 30 {!! nl2br(e($post->body)) !!} 31 </p> 32 33 <form class="mb-4" method="POST" action="{{ route('comments.store') }}"> 34 @csrf 35 36 <input name="post_id" type="hidden" value="{{ $post->id }}"> 37 38 <div class="form-group"> 39 <label for="name"> 40 返信者名 41 </label> 42 <input id="name" name="name" class="form-control {{ $errors->has('name') ? 'is-invalid' : '' }}" value="{{ old('name') }}" type="text"> 43 @if ($errors->has('name')) 44 <div class="invalid-feedback"> 45 {{ $errors->first('name') }} 46 </div> 47 @endif 48 </div> 49 50 <div class="form-group"> 51 <label for="body"> 52 本文 53 </label> 54 55 <textarea id="body" name="body" class="form-control {{ $errors->has('body') ? 'is-invalid' : '' }}" rows="4">{{ old('body') }}</textarea> 56 @if ($errors->has('body')) 57 <div class="invalid-feedback"> 58 {{ $errors->first('body') }} 59 </div> 60 @endif 61 </div> 62 63 <div class='form-group'> 64 <label for="password"> 65 パスワード 66 </label> 67 <input type="password" name="password" class="form-control {{ $errors->has('password') ? 'is-invalid' : '' }}" value="{{ old('password') }}" type="text"> 68 @if ($errors->has('password')) 69 <div class="invalid-feedback"> 70 {{ $errors->first('password') }} 71 </div> 72 @endif 73 </div> 74 75 <div class="mt-4"> 76 <button type="submit" class="btn btn-primary"> 77 返信する 78 </button> 79 </div> 80 </form> 81 82 <section> 83 <h2 class="h5 mb-4"> 84 返信一覧 85 </h2> 86 87 @forelse($post->comments as $comment) 88 <div class="card mb-4"> 89 <div class="card-header"> 90 返信者名:{!! nl2br(e($comment->name)) !!}<br /> 91 </div> 92 <div class="card-body"> 93 <p class="card-text"> 94 {!! nl2br(e($comment->body)) !!} 95 <div class="mb-4 text-right"> 96 <form action="{{ route('comments.destroy', ['post' => $comment]) }}" method="POST"> 97 @csrf 98 @method('DELETE') 99 <div class="form-group"> 100 <input type="password" name="password" class="form-control" placeholder="パスワードを入力してください"> 101 <button type="submit" class="btn btn-success">この投稿を削除する</button> 102 </div> 103 </form> 104 </div> 105 </p> 106 </div> 107 <div class="card-footer"> 108 <span class="mr-2"> 109 返信日時:{{ $comment->created_at->format('Y.m.d H:i:s') }} 110 </span> 111 </div> 112 </div> 113 @empty 114 <p>返信はまだありません。</p> 115 @endforelse 116 </section> 117 </div> 118</div> 119@endsection
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。