migrate to gtea from bistbucket
This commit is contained in:
140
app/Http/Controllers/Admin/AcnooBlogController.php
Normal file
140
app/Http/Controllers/Admin/AcnooBlogController.php
Normal file
@@ -0,0 +1,140 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Admin;
|
||||
|
||||
use App\Models\Blog;
|
||||
use App\Models\Comment;
|
||||
use App\Helpers\HasUploader;
|
||||
use Illuminate\Http\Request;
|
||||
use App\Http\Controllers\Controller;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Illuminate\Support\Facades\Storage;
|
||||
|
||||
class AcnooBlogController extends Controller
|
||||
{
|
||||
use HasUploader;
|
||||
|
||||
public function index(Request $request)
|
||||
{
|
||||
$blogs = Blog::when($request->search, function ($q) use ($request) {
|
||||
$q->where(function ($q) use ($request) {
|
||||
$q->where('title', 'like', '%' . $request->search . '%');
|
||||
});
|
||||
})->latest()->paginate($request->per_page ?? 20)->appends($request->query());
|
||||
|
||||
if ($request->ajax()) {
|
||||
return response()->json([
|
||||
'data' => view('admin.website-setting.blogs.datas', compact('blogs'))->render()
|
||||
]);
|
||||
}
|
||||
|
||||
return view('admin.website-setting.blogs.index', compact('blogs'));
|
||||
}
|
||||
|
||||
public function create()
|
||||
{
|
||||
return view('admin.website-setting.blogs.create');
|
||||
}
|
||||
|
||||
public function store(Request $request)
|
||||
{
|
||||
$request->validate([
|
||||
'title' => 'required|unique:blogs,title',
|
||||
'image' => 'required|image|mimes:jpeg,png,jpg,gif,svg',
|
||||
'status' => 'boolean',
|
||||
'descriptions' => 'nullable|string',
|
||||
'tags' => 'nullable|array',
|
||||
'meta.title' => 'nullable|string',
|
||||
'meta.description' => 'nullable|string',
|
||||
]);
|
||||
|
||||
Blog::create($request->except('image') + [
|
||||
'user_id' => Auth::id(),
|
||||
'image' => $request->image ? $this->upload($request, 'image') : null,
|
||||
]);
|
||||
|
||||
return response()->json([
|
||||
'message' => __('BLog created successfully'),
|
||||
'redirect' => route('admin.blogs.index')
|
||||
]);
|
||||
}
|
||||
|
||||
public function edit(Blog $blog)
|
||||
{
|
||||
return view('admin.website-setting.blogs.edit', compact('blog'));
|
||||
}
|
||||
|
||||
public function update(Request $request, Blog $blog)
|
||||
{
|
||||
|
||||
$request->validate([
|
||||
'title' => 'required|unique:blogs,title,' . $blog->id,
|
||||
'image' => 'nullable|image|mimes:jpeg,png,jpg,gif,svg',
|
||||
'status' => 'boolean',
|
||||
'descriptions' => 'nullable|string',
|
||||
'tags' => 'nullable|array',
|
||||
'meta.title' => 'nullable|string',
|
||||
'meta.description' => 'nullable|string',
|
||||
]);
|
||||
|
||||
$blog->update($request->except('image') + [
|
||||
'user_id' => Auth::id(),
|
||||
'image' => $request->image ? $this->upload($request, 'image', $blog->image) : $blog->image,
|
||||
]);
|
||||
|
||||
return response()->json([
|
||||
'message' => __('BLog updated successfully'),
|
||||
'redirect' => route('admin.blogs.index')
|
||||
]);
|
||||
}
|
||||
|
||||
public function destroy(Blog $blog)
|
||||
{
|
||||
if (file_exists($blog->image)) {
|
||||
Storage::delete($blog->image);
|
||||
}
|
||||
|
||||
$blog->delete();
|
||||
|
||||
return response()->json([
|
||||
'message' => __('Blog deleted successfully'),
|
||||
'redirect' => route('admin.blogs.index')
|
||||
]);
|
||||
}
|
||||
|
||||
public function status(Request $request, $id)
|
||||
{
|
||||
$blog_status = Blog::findOrFail($id);
|
||||
$blog_status->update(['status' => $request->status]);
|
||||
return response()->json(['message' => 'Blog']);
|
||||
}
|
||||
|
||||
|
||||
public function deleteAll(Request $request)
|
||||
{
|
||||
Blog::whereIn('id', $request->ids)->delete();
|
||||
return response()->json([
|
||||
'message' => __('Selected Blog deleted successfully'),
|
||||
'redirect' => route('admin.blogs.index')
|
||||
]);
|
||||
}
|
||||
|
||||
public function filterComment($id, Request $request)
|
||||
{
|
||||
$blog = Blog::findOrFail($id);
|
||||
$comments = Comment::with('blog:id')->whereStatus(1)->where('blog_id', $blog->id)->when($request->search, function ($q) use ($request) {
|
||||
$q->where(function ($q) use ($request) {
|
||||
$q->where('name', 'like', '%' . $request->search . '%')
|
||||
->orwhere('email', 'like', '%' . $request->search . '%')
|
||||
->orwhere('comment', 'like', '%' . $request->search . '%');
|
||||
});
|
||||
})->latest()->paginate($request->per_page ?? 20)->appends($request->query());
|
||||
|
||||
if ($request->ajax()) {
|
||||
return response()->json([
|
||||
'data' => view('admin.website-setting.blogs.comments.datas', compact('comments','blog'))->render()
|
||||
]);
|
||||
}
|
||||
return view('admin.website-setting.blogs.comments.index', compact('comments','blog'));
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user