Skip to content

Commit

Permalink
User can create reply
Browse files Browse the repository at this point in the history
  • Loading branch information
hackjie committed Jul 19, 2018
1 parent 5c7673c commit 7487142
Show file tree
Hide file tree
Showing 6 changed files with 38 additions and 75 deletions.
58 changes: 17 additions & 41 deletions app/Http/Controllers/RepliesController.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,54 +7,30 @@
use App\Http\Controllers\Controller;
use App\Http\Requests\ReplyRequest;

use Auth;

class RepliesController extends Controller
{
public function __construct()
{
$this->middleware('auth', ['except' => ['index', 'show']]);
$this->middleware('auth');
}

public function index()
{
$replies = Reply::paginate();
return view('replies.index', compact('replies'));
}

public function show(Reply $reply)
public function store(ReplyRequest $request, Reply $reply)
{
return view('replies.show', compact('reply'));
$reply->content = $request->content;
$reply->user_id = Auth::id();
$reply->topic_id = $request->topic_id;
$reply->save();

return redirect()->to($reply->topic->link())->with('success', '创建成功!');
}

public function create(Reply $reply)
{
return view('replies.create_and_edit', compact('reply'));
}

public function store(ReplyRequest $request)
{
$reply = Reply::create($request->all());
return redirect()->route('replies.show', $reply->id)->with('message', 'Created successfully.');
}

public function edit(Reply $reply)
{
$this->authorize('update', $reply);
return view('replies.create_and_edit', compact('reply'));
}

public function update(ReplyRequest $request, Reply $reply)
{
$this->authorize('update', $reply);
$reply->update($request->all());

return redirect()->route('replies.show', $reply->id)->with('message', 'Updated successfully.');
}

public function destroy(Reply $reply)
{
$this->authorize('destroy', $reply);
$reply->delete();

return redirect()->route('replies.index')->with('message', 'Deleted successfully.');
}
public function destroy(Reply $reply)
{
$this->authorize('destroy', $reply);
$reply->delete();

return redirect()->route('replies.index')->with('success', '删除成功!');
}
}
30 changes: 1 addition & 29 deletions app/Http/Requests/ReplyRequest.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,37 +5,9 @@
class ReplyRequest extends Request
{
public function rules()
{
switch($this->method())
{
// CREATE
case 'POST':
{
return [
// CREATE ROLES
];
}
// UPDATE
case 'PUT':
case 'PATCH':
{
return [
// UPDATE ROLES
];
}
case 'GET':
case 'DELETE':
default:
{
return [];
};
}
}

public function messages()
{
return [
// Validation messages
'content' => 'required|min:2',
];
}
}
7 changes: 6 additions & 1 deletion app/Observers/ReplyObserver.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,16 @@ class ReplyObserver
{
public function creating(Reply $reply)
{
//
$reply->content = clean($reply->content, 'user_topic_body');
}

public function updating(Reply $reply)
{
//
}

public function created(Reply $reply)
{
$reply->topic->increment('reply_count', 1);
}
}
12 changes: 12 additions & 0 deletions resources/views/topics/_reply_box.blade.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
@include('common.error')
<div class="reply-box">
<form action="{{ route('replies.store') }}" method="POST" accept-charset="UTF-8">
<input type="hidden" name="_token" value="{{ csrf_token() }}">
<input type="hidden" name="topic_id" value="{{ $topic->id }}">
<div class="form-group">
<textarea class="form-control" rows="3" placeholder="分享你的想法" name="content"></textarea>
</div>
<button type="submit" class="btn btn-primary btn-sm"><i class="fa fa-share"></i>回复</button>
</form>
</div>
<hr>
2 changes: 1 addition & 1 deletion resources/views/topics/show.blade.php
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@
{{-- 用户回复列表 --}}
<div class="panel panel-default topic-reply">
<div class="panel-body">
@include('topics._reply_box', ['topic' => $topic])
@includeWhen(Auth::check(), 'topics._reply_box', ['topic' => $topic])
@include('topics._reply_list', ['replies' => $topic->replies()->with('user')->get()])
</div>
</div>
Expand Down
4 changes: 1 addition & 3 deletions routes/web.php
Original file line number Diff line number Diff line change
Expand Up @@ -32,11 +32,9 @@

Route::resource('topics', 'TopicsController', ['only' => ['index', 'create', 'store', 'update', 'edit', 'destroy']]);
Route::get('topics/{topic}/{slug?}', 'TopicsController@show')->name('topics.show');


Route::post('upload_image', 'TopicsController@uploadImage')->name('topics.upload_image');

Route::resource('categories', 'CategoriesController', ['only' => ['show']]);


Route::resource('replies', 'RepliesController', ['only' => ['index', 'show', 'create', 'store', 'update', 'edit', 'destroy']]);
Route::resource('replies', 'RepliesController', ['only' => ['store', 'destroy']]);

0 comments on commit 7487142

Please sign in to comment.