adding actual useful feature
This commit is contained in:
@@ -7,9 +7,10 @@ use App\Models\Video;
|
||||
use App\Models\Banner;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Database\Eloquent\Relations\HasMany;
|
||||
|
||||
use App\Http\Requests;
|
||||
use Cviebrock\EloquentTaggable\Services\TagService;
|
||||
class TagviewController extends Controller
|
||||
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
@@ -36,154 +37,41 @@ class TagviewController extends Controller
|
||||
//
|
||||
}
|
||||
|
||||
public function tagview($tag, $id = null)
|
||||
public function showVideo($shortname, $id = null)
|
||||
{
|
||||
|
||||
// return $shortname;
|
||||
|
||||
if (is_null($id)) {
|
||||
// $x = Video::with('tags')->get();
|
||||
// return $x;
|
||||
$x = Video::orderByRaw("RAND()")->with('tags')->whereHas('tags', function ($query) use ($tag) {
|
||||
$query->where('normalized', $tag);
|
||||
})->first();
|
||||
// $x = Video::orderByRaw("RAND()")->with('tags')->get()->first();
|
||||
$responseArray = json_decode($x, true);
|
||||
$normalizedTags = array_column($responseArray['tags'], 'normalized');
|
||||
$variableToCompare = $tag;
|
||||
if (in_array($variableToCompare, $normalizedTags)) {
|
||||
// tag exists
|
||||
return redirect('t/' . $tag . '/' . $x->id);
|
||||
} else {
|
||||
// tag does not exist on video
|
||||
return 404;
|
||||
$video = Video::getRandom($shortname, true);
|
||||
if ($video instanceof HasMany) {
|
||||
$video = $video->first();
|
||||
}
|
||||
else {
|
||||
return redirect()->back()->with('error', 'tag is empty.');
|
||||
}
|
||||
return redirect('/t/' . $shortname . '/' . $video->id);
|
||||
} else {
|
||||
// return $id;
|
||||
$video = Video::where('id', $id)->with('tags')->get();
|
||||
return view('tagviewdev', [
|
||||
'video' => $video,
|
||||
'related' => $video,
|
||||
'tag' => $tag
|
||||
]);
|
||||
|
||||
// Don't filter on specific video.
|
||||
// TODO: Add warning page
|
||||
$video = Video::withAnyTags($shortname)->find($id);
|
||||
}
|
||||
|
||||
if (is_null($video)) {
|
||||
return redirect()->back()->with('error', 'tag is empty.');
|
||||
}
|
||||
|
||||
$sfw = $video->tags->contains(function($key, $tag) {
|
||||
return $tag->normalized === 'sfw';
|
||||
});
|
||||
|
||||
return view('video', [
|
||||
'video' => $video,
|
||||
'related' => $shortname,
|
||||
'isTag' => true,
|
||||
'sfw' => $sfw,
|
||||
'banner' => Banner::getRandom($video->isSfw())]);
|
||||
}
|
||||
|
||||
// public function tagview($tag, $id = null)
|
||||
// {
|
||||
// $x = Video::withAllTags($tag)->first();
|
||||
|
||||
// // return $x;
|
||||
// // id 1
|
||||
// // file "1.webm"
|
||||
// // videotitle "su"
|
||||
// // interpret null
|
||||
// // songtitle null
|
||||
// // imgsource null
|
||||
// // category_id 8
|
||||
// // user_id 1
|
||||
// // created_at "2024-02-22 00:31:49"
|
||||
// // updated_at "2024-02-22 00:31:49"
|
||||
// // deleted_at null
|
||||
// // hash "3cdd7e0aa1a1cf175e06f22da2f485091f3b9f22"
|
||||
// // tag_id 2
|
||||
// // taggable_id 1
|
||||
// // taggable_type "App\\Models\\Video"
|
||||
// // name "misc"
|
||||
// // normalized "misc"
|
||||
|
||||
// if(!$id) {
|
||||
// // gibs keine...
|
||||
// $z = Video::getAllTags();
|
||||
// return $z;
|
||||
// } else {
|
||||
// $y = $x->id;
|
||||
// return $y;
|
||||
// }
|
||||
// }
|
||||
|
||||
// public function tagview($tag, $id = null)
|
||||
// {
|
||||
// // $tag_in = Video::withAnyTags($tag)->first();
|
||||
// // return $tag_in;
|
||||
// $video = Video::getRandom($tag->id);
|
||||
// if ($video instanceof HasMany) {
|
||||
// $video = $video->first();
|
||||
// }
|
||||
// // $video = Video::getRandom($tag->id);
|
||||
|
||||
// if (is_null($id)) {
|
||||
// $video = Video::getRandom($tag);
|
||||
// } else {
|
||||
|
||||
// }
|
||||
// }
|
||||
|
||||
// public function helloworld($tag, $id = null)
|
||||
// {
|
||||
// if(!$tag) {
|
||||
// return redirect()->back()->with('error', 'Tag not found');
|
||||
// }
|
||||
|
||||
// if (is_null($id)) {
|
||||
// $tag = Video::withAnyTags($tag)->first();
|
||||
// return redirect('t/' . $tag->normalized . '/' . $tag->id);
|
||||
// } else {
|
||||
// $tag = Video::withAnyTags($tag)->first();
|
||||
// $video = Video::with('tags')->find($tag->id);
|
||||
|
||||
// return view('tagviewdev', [
|
||||
// 'id' => $tag->id,
|
||||
// 'video' => $video,
|
||||
// 'tag' => $tag->name,
|
||||
// 'related' => $video->name,
|
||||
// 'banner' => 'banner'
|
||||
// ]);
|
||||
// }
|
||||
|
||||
// if(!$id) {
|
||||
// // is not null
|
||||
// // implement redirect to t/$tag/$id
|
||||
// } else {
|
||||
// $tag = Video::withAnyTags($tag)->first();
|
||||
// // reverse lookup of $video thanks to the api for tag
|
||||
// $video = Video::with('tags')->find($tag->id);
|
||||
|
||||
// $tags = $video->tags;
|
||||
|
||||
// return view('tagviewdev', [
|
||||
// 'video' => $video,
|
||||
// 'tags' => $tags,
|
||||
// 'related' => $tag->name
|
||||
// ]);
|
||||
// //return redirect('t/' . $tag . '/' . );
|
||||
// }
|
||||
|
||||
// $blub = $tag->id;
|
||||
// return $blub;
|
||||
|
||||
// if (is_null($id)) {
|
||||
|
||||
// $video = Video::getRandom($tag);
|
||||
// if ($video instanceof HasMany) {
|
||||
// $video = $video->first();
|
||||
// }
|
||||
// else {
|
||||
// return redirect()->back()->with('error', '404');
|
||||
// }
|
||||
// return redirect('t/' . $tag . '/' . $video->id);
|
||||
// } else {
|
||||
// // Don't filter on specific video.
|
||||
// // TODO: Add warning page
|
||||
// // $video = $tag->videos()->find($id);
|
||||
// }
|
||||
|
||||
// //return $tag;
|
||||
// return view('tagviewdev', [
|
||||
// 'tag' => $tag,
|
||||
// 'related' => $tag,
|
||||
// ]);
|
||||
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
|
@@ -188,7 +188,7 @@ Route::group(["middleware" => "theme"], function() {
|
||||
Route::get('{shortname}/{id}', 'CategoryController@showVideo')->where(['shortname' => '[a-z][a-z0-9]+', 'id' => '[0-9]+']);
|
||||
|
||||
##Tag View anybody?
|
||||
Route::get('t/{tag}', 'TagviewController@tagview')->where('tag', '[a-z][a-z0-9]+');
|
||||
Route::get('t/{tag}/{id}', 'TagviewController@tagview')->where(['tag' => '[a-z][a-z0-9]+', 'id' => '[0-9]+']);
|
||||
Route::get('t/{tag}', 'TagviewController@showVideo')->where('tag', '[a-z][a-z0-9]+');
|
||||
Route::get('t/{tag}/{id}', 'TagviewController@showVideo')->where(['tag' => '[a-z][a-z0-9]+', 'id' => '[0-9]+']);
|
||||
|
||||
});
|
||||
|
Reference in New Issue
Block a user