Fixed the file uploads in settings

This commit is contained in:
AVMG20 2021-11-12 18:23:06 +01:00
parent 451913f015
commit 53a4faa662
2 changed files with 47 additions and 47 deletions

View file

@ -8,7 +8,6 @@ use Illuminate\Contracts\View\Factory;
use Illuminate\Contracts\View\View;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use Illuminate\Support\Facades\Storage;
class SettingsController extends Controller
{
@ -22,25 +21,20 @@ class SettingsController extends Controller
return view('admin.settings.index');
}
public function updateIcons(Request $request){
public function updateIcons(Request $request)
{
$request->validate([
'favicon' => 'required',
'icon' => 'required',
'icon' => 'nullable|max:10000|mimes:jpg,png,jpeg',
'favicon' => 'nullable|max:10000|mimes:ico',
]);
//store favicon
$favicon = $request->input('favicon');
$favicon = json_decode($favicon);
$favicon = explode(",",$favicon->output->image)[1];
Storage::disk('public')->put('favicon.ico' , base64_decode($favicon));
if ($request->hasFile('icon')) {
$request->file('icon')->storeAs('public', 'icon.png');
}
//store dashboard icon
$icon = $request->input('icon');
$icon = json_decode($icon);
$icon = explode(",",$icon->output->image)[1];
Storage::disk('public')->put('icon.png' , base64_decode($icon));
if ($request->hasFile('favicon')) {
$request->file('favicon')->storeAs('public', 'favicon.ico');
}
return redirect()->route('admin.settings.index')->with('success', 'Icons updated!');
}

View file

@ -45,41 +45,38 @@
<div class="tab-content">
<div class="tab-pane mt-3 active" id="dashboard-icons">
<form method="POST" class="mb-3" action="{{route('admin.settings.update.icons')}}">
<form method="POST" enctype="multipart/form-data" class="mb-3"
action="{{route('admin.settings.update.icons')}}">
@csrf
@method('PATCH')
<div class="d-flex">
<div class="form-group">
<div class="text-center mb-2">Dashboard Icon</div>
<div class="avatar">
<div class="slim rounded-circle"
data-size="128,128"
data-ratio="1:1"
style="width: 140px;height:140px; cursor: pointer"
data-save-initial-image="true">
<input type="file" name="icon"/>
<img
src="{{\Illuminate\Support\Facades\Storage::disk('public')->exists('icon.png') ? asset('storage/icon.png') : asset('images/bitsec.png')}}"
alt="icon">
<div class="row">
<div class="col-md-6 col-lg-4 col-12">
<div class="form-group">
<div class="custom-file mb-3 mt-3">
<input type="file" accept="image/png,image/jpeg,image/jpg"
class="custom-file-input" name="icon" id="icon">
<label class="custom-file-label selected"
for="icon">{{__('Select panel icon')}}</label>
</div>
@error('icon')
<span class="text-danger">
{{$message}}
</span>
@enderror
</div>
</div>
<div class="form-group ml-5">
<div class="text-center mb-2">Favicon</div>
<div class="avatar">
<div class="slim rounded-circle"
data-size="64,64"
data-ratio="1:1"
style="width: 140px;height:140px; cursor: pointer"
data-save-initial-image="true">
<input accept="image/x-icon" type="file" name="favicon"/>
<img
src="{{\Illuminate\Support\Facades\Storage::disk('public')->exists('favicon.ico') ? asset('storage/favicon.ico') : asset('favicon.ico')}}"
alt="favicon">
<div class="form-group">
<div class="custom-file mb-3">
<input type="file" accept="image/x-icon" class="custom-file-input"
name="favicon" id="favicon">
<label class="custom-file-label selected"
for="favicon">{{__('Select panel favicon')}}</label>
</div>
@error('favicon')
<span class="text-danger">
{{$message}}
</span>
@enderror
</div>
</div>
</div>
@ -87,7 +84,8 @@
<button class="btn btn-primary">Submit</button>
</form>
<p class="text-muted">Images and Icons may be cached, use <code>CNTRL + F5</code><sup>(google chrome hotkey)</sup> to reload without cache to see your changes appear :)</p>
<p class="text-muted">Images and Icons may be cached, use <code>CNTRL + F5</code><sup>(google
chrome hotkey)</sup> to reload without cache to see your changes appear :)</p>
</div>
</div>
@ -103,7 +101,15 @@
</section>
<!-- END CONTENT -->
<script>
// Add the following code if you want the name of the file appear on select
document.addEventListener('DOMContentLoaded', ()=>{
$(".custom-file-input").on("change", function () {
var fileName = $(this).val().split("\\").pop();
$(this).siblings(".custom-file-label").addClass("selected").html(fileName);
});
})
</script>
@endsection