v0.10.10 - Fixed it so you can only upload image resources when uploading your profile picture
This commit is contained in:
parent
2430a6a381
commit
7e9277bd21
|
@ -101,6 +101,70 @@ class ResourceController extends Controller
|
|||
return $resource;
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public static function storeMime(Request $request, ResourceCategory $category)
|
||||
{
|
||||
$file = $request->file("resource");
|
||||
|
||||
$resourceExtension = ResourceExtension::query()->where("extension", "=", $file->extension())->first();
|
||||
|
||||
//Create resourceExtension if it doesn't exist
|
||||
if($resourceExtension === null) {
|
||||
$category = substr($file->getMimeType(), 0, strpos($file->getMimeType(), "/"));
|
||||
|
||||
$resourceCategory = ResourceCategory::query()->where("name", "=", $category)->first();
|
||||
|
||||
//If the uploaded file doesn't match the requested mime type
|
||||
if($resourceCategory) {
|
||||
if ($resourceCategory->name !== $category)
|
||||
return null;
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
|
||||
//Create resourceCategory if it doesn't exist
|
||||
if($resourceCategory === null){
|
||||
$data = [
|
||||
"name" => $category,
|
||||
"description" => "",
|
||||
"slug" => ""
|
||||
];
|
||||
|
||||
$resourceCategory = new ResourceCategory($data);
|
||||
$resourceCategory->save();
|
||||
}
|
||||
|
||||
$data = [
|
||||
"extension" => $file->extension(),
|
||||
"description" => "",
|
||||
"resource_category_id" => $resourceCategory->id
|
||||
];
|
||||
|
||||
$resourceExtension = new ResourceExtension($data);
|
||||
$resourceExtension->save();
|
||||
}
|
||||
|
||||
$resource = new Resource();
|
||||
|
||||
$resource->extension_id = $resourceExtension->id;
|
||||
|
||||
$fileName = time().'_'.$file->getClientOriginalName();
|
||||
$filePath = $file->storeAs('uploads', $fileName, 'public');
|
||||
|
||||
/* /uploads/filename.ext */
|
||||
$resource->filename = '/' . $filePath;
|
||||
|
||||
|
||||
$resource->save();
|
||||
|
||||
return $resource;
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
|
|
|
@ -3,6 +3,8 @@
|
|||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Helpers\Detector;
|
||||
use App\ResourceCategory;
|
||||
use App\ResourceExtension;
|
||||
use Illuminate\Database\Eloquent\Collection;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Http\Response;
|
||||
|
@ -338,8 +340,14 @@ class UserController extends Controller
|
|||
return redirect()->route("users.login")->with('success#passwordchange', '<p class="text-center text-white"><b>Dit password er hermed ændret!</b></p>');
|
||||
}
|
||||
} else if($request->file("resource")) { // Else if you're editing the profile pic
|
||||
$user->update([ "resource_id" => ResourceController::store($request)->id ]);
|
||||
$resource = ResourceController::storeMime($request, ResourceCategory::query()->where("name", "=", "image")->first());
|
||||
|
||||
if($resource !== null) {
|
||||
$user->update(["resource_id" => $resource->id]);
|
||||
}
|
||||
else {
|
||||
return redirect()->route("users.accounteditpic");
|
||||
}
|
||||
|
||||
return redirect()->route("users.account");
|
||||
} else { // Else if you're not editing the password but anything else (Email, Phone Number). Then update user.
|
||||
|
|
|
@ -80,6 +80,12 @@
|
|||
{{ __('msg.logud') }}
|
||||
</a>
|
||||
</div>
|
||||
<style>
|
||||
option, textarea {
|
||||
color: black;
|
||||
}
|
||||
|
||||
</style>
|
||||
@yield("content")
|
||||
<script src="{{ mix("/js/app.js") }}"></script>
|
||||
@if(request()->cookie("mode") == "dark")
|
||||
|
|
|
@ -45,12 +45,14 @@
|
|||
<script src="{{ asset("/js/moment-with-locales.min.js") }}"></script>
|
||||
<script src="{{ asset("/js/da.min.js") }}"></script>
|
||||
<script>
|
||||
//Global vars to use outside functions
|
||||
var momentDate = null;
|
||||
var dateText = null;
|
||||
|
||||
//Custom forEach
|
||||
NodeList.prototype.forEach = Array.prototype.forEach;
|
||||
|
||||
//Generates the calender when the site loads
|
||||
function generateCalendar(weekOffset = 0) {
|
||||
const week = (moment().week() + weekOffset);
|
||||
|
||||
|
@ -109,6 +111,7 @@
|
|||
calendar.appendChild(calendarBody);
|
||||
}
|
||||
|
||||
//When a date is selected
|
||||
function onDateSelect(date, dayHolder, datetext) {
|
||||
//Set selected date and dateText
|
||||
momentDate = date;
|
||||
|
|
Loading…
Reference in New Issue