fix: 🐛locale default language selection

This commit is contained in:
IceToast 2023-06-04 16:08:22 +02:00
parent b97bc8edf7
commit 83e153058c
3 changed files with 112 additions and 117 deletions

View file

@ -64,6 +64,7 @@ class SettingsController extends Controller
'type' => $optionInputData[$key]['type'] ?? 'string', 'type' => $optionInputData[$key]['type'] ?? 'string',
'description' => $optionInputData[$key]['description'] ?? '', 'description' => $optionInputData[$key]['description'] ?? '',
'options' => $optionInputData[$key]['options'] ?? [], 'options' => $optionInputData[$key]['options'] ?? [],
'identifier' => $optionInputData[$key]['identifier'] ?? 'option'
]; ];
} }
@ -96,7 +97,7 @@ class SettingsController extends Controller
{ {
$category = request()->get('category'); $category = request()->get('category');
$this->checkPermission("settings.".strtolower($category).".write"); $this->checkPermission("settings." . strtolower($category) . ".write");
$settings_class = request()->get('settings_class'); $settings_class = request()->get('settings_class');
@ -125,7 +126,7 @@ class SettingsController extends Controller
continue; continue;
} }
if ($rp->name == 'available') { if ($rp->name == 'available') {
$settingsClass->$key = implode(",",$request->$key); $settingsClass->$key = implode(",", $request->$key);
continue; continue;
} }

View file

@ -62,6 +62,7 @@ class LocaleSettings extends Settings
'type' => 'select', 'type' => 'select',
'description' => 'The default locale to use.', 'description' => 'The default locale to use.',
'options' => config('app.available_locales'), 'options' => config('app.available_locales'),
'identifier' => 'display'
], ],
'dynamic' => [ 'dynamic' => [
'label' => 'Dynamic Locale', 'label' => 'Dynamic Locale',

View file

@ -48,23 +48,20 @@
<ul class="nav nav-pills nav-sidebar flex-column" data-widget="treeview" role="tablist" <ul class="nav nav-pills nav-sidebar flex-column" data-widget="treeview" role="tablist"
data-accordion="false"> data-accordion="false">
<li class="nav-item border-bottom-0"> <li class="nav-item border-bottom-0">
<a href="#icons" <a href="#icons" class="nav-link" data-toggle="pill" role="tab">
class="nav-link" data-toggle="pill" <i class="nav-icon fas fa-image"></i>
role="tab">
<i
class="nav-icon fas fa-image"></i>
<p> <p>
{{ __("Images / Icons") }} {{ __('Images / Icons') }}
</p> </p>
</a> </a>
</li> </li>
@foreach ($settings as $category => $options) @foreach ($settings as $category => $options)
@if(!str_contains($options['settings_class'],"Extension")) @if (!str_contains($options['settings_class'], 'Extension'))
@canany(["settings.".strtolower($category).".read","settings.".strtolower($category).".write"]) @canany(['settings.' . strtolower($category) . '.read', 'settings.' .
strtolower($category) . '.write'])
<li class="nav-item border-bottom-0"> <li class="nav-item border-bottom-0">
<a href="#{{ $category }}" <a href="#{{ $category }}"
class="nav-link {{ $loop->first ? 'active' : '' }}" class="nav-link {{ $loop->first ? 'active' : '' }}" data-toggle="pill"
data-toggle="pill"
role="tab"> role="tab">
<i <i
class="nav-icon fas {{ $options['category_icon'] ?? 'fas fa-cog' }}"></i> class="nav-icon fas {{ $options['category_icon'] ?? 'fas fa-cog' }}"></i>
@ -82,7 +79,7 @@
<button class="btn btn-outline-secondary" type="button" data-toggle="collapse" <button class="btn btn-outline-secondary" type="button" data-toggle="collapse"
data-target="#collapseExtensions" aria-expanded="false" data-target="#collapseExtensions" aria-expanded="false"
aria-controls="collapseExtensions"> aria-controls="collapseExtensions">
{{__("Extension Settings")}} {{ __('Extension Settings') }}
</button> </button>
@ -90,15 +87,14 @@
<ul class="nav nav-pills nav-sidebar flex-column" data-widget="treeview" role="tablist" <ul class="nav nav-pills nav-sidebar flex-column" data-widget="treeview" role="tablist"
data-accordion="false"> data-accordion="false">
@foreach ($settings as $category => $options) @foreach ($settings as $category => $options)
@if(str_contains($options['settings_class'],"Extension")) @if (str_contains($options['settings_class'], 'Extension'))
@canany(['settings.' . strtolower($category) . '.read', 'settings.' .
@canany(["settings.".strtolower($category).".read","settings.".strtolower($category).".write"]) strtolower($category) . '.write'])
<li class="nav-item border-bottom-0"> <li class="nav-item border-bottom-0">
<a href="#{{ $category }}" <a href="#{{ $category }}" class="nav-link" data-toggle="pill"
class="nav-link"
data-toggle="pill"
role="tab"> role="tab">
<i class="nav-icon fas {{ $options['category_icon'] ?? 'fas fa-cog' }}"></i> <i
class="nav-icon fas {{ $options['category_icon'] ?? 'fas fa-cog' }}"></i>
<p> <p>
{{ $category }} {{ $category }}
</p> </p>
@ -115,8 +111,7 @@
<!-- Content in $settings --> <!-- Content in $settings -->
<div class="col-10 p-0"> <div class="col-10 p-0">
<div class="tab-content ml-3" style="width: 100%;"> <div class="tab-content ml-3" style="width: 100%;">
<div container class="tab-pane fade container" <div container class="tab-pane fade container" id="icons" role="tabpanel">
id="icons" role="tabpanel">
<form method="POST" enctype="multipart/form-data" class="mb-3" <form method="POST" enctype="multipart/form-data" class="mb-3"
action="{{ route('admin.settings.updateIcons') }}"> action="{{ route('admin.settings.updateIcons') }}">
@ -124,41 +119,36 @@
@method('POST') @method('POST')
<div class="row"> <div class="row">
<div class="card ml-5" style="width: 18rem;"> <div class="card ml-5" style="width: 18rem;">
<span class="h3 text-center">{{__("FavIcon")}} </span> <span class="h3 text-center">{{ __('FavIcon') }} </span>
<div class="card-body"> <div class="card-body">
</div> </div>
<input type="file" accept="image/x-icon" class="form-control" <input type="file" accept="image/x-icon" class="form-control"
name="favicon" name="favicon" id="favicon">
id="favicon">
</div> </div>
<div class="card ml-5" style="width: 18rem;"> <div class="card ml-5" style="width: 18rem;">
<span class="h3 text-center">{{__("Icon")}} </span> <span class="h3 text-center">{{ __('Icon') }} </span>
<img <img src="{{ Storage::disk('public')->exists('icon.png') ? asset('storage/icon.png') : asset('images/controlpanel_logo.png') }}"
src="{{ Storage::disk('public')->exists('icon.png') ? asset('storage/icon.png') : asset('images/controlpanel_logo.png') }}"
style="width:5vw;display: block; margin-left: auto;margin-right: auto" style="width:5vw;display: block; margin-left: auto;margin-right: auto"
class="card-img-top" alt="..."> class="card-img-top" alt="...">
<div class="card-body"> <div class="card-body">
</div> </div>
<input type="file" accept="image/png,image/jpeg,image/jpg" <input type="file" accept="image/png,image/jpeg,image/jpg"
class="form-control" class="form-control" name="icon" id="icon">
name="icon" id="icon">
</div> </div>
<div class="card ml-5" style="width: 18rem;"> <div class="card ml-5" style="width: 18rem;">
<span class="h3 text-center">{{__("Login-page Logo")}} </span> <span class="h3 text-center">{{ __('Login-page Logo') }} </span>
<img <img src="{{ Storage::disk('public')->exists('logo.png') ? asset('storage/logo.png') : asset('images/controlpanel_logo.png') }}"
src="{{ Storage::disk('public')->exists('logo.png') ? asset('storage/logo.png') : asset('images/controlpanel_logo.png') }}"
style="width:5vw;display: block; margin-left: auto;margin-right: auto" style="width:5vw;display: block; margin-left: auto;margin-right: auto"
class="card-img-top" alt="..."> class="card-img-top" alt="...">
<div class="card-body"> <div class="card-body">
</div> </div>
<input type="file" accept="image/png,image/jpeg,image/jpg" <input type="file" accept="image/png,image/jpeg,image/jpg"
class="form-control" class="form-control" name="logo" id="logo">
name="logo" id="logo">
</div> </div>
</div> </div>
<div class="row"> <div class="row">
@ -167,9 +157,9 @@
</form> </form>
</div> </div>
@foreach ($settings as $category => $options) @foreach ($settings as $category => $options)
@canany(["settings.".strtolower($category).".read","settings.".strtolower($category).".write"]) @canany(['settings.' . strtolower($category) . '.read', 'settings.' .
<div strtolower($category) . '.write'])
class="tab-pane fade container {{ $loop->first ? 'active show' : '' }}" <div class="tab-pane fade container {{ $loop->first ? 'active show' : '' }}"
id="{{ $category }}" role="tabpanel"> id="{{ $category }}" role="tabpanel">
<form action="{{ route('admin.settings.update') }}" method="POST"> <form action="{{ route('admin.settings.update') }}" method="POST">
@ -191,8 +181,7 @@
<div class="col-8"> <div class="col-8">
<div class="custom-control mb-3 d-flex align-items-center"> <div class="custom-control mb-3 d-flex align-items-center">
@if ($value['description']) @if ($value['description'])
<i class="fas fa-info-circle mr-4" <i class="fas fa-info-circle mr-4" data-toggle="popover"
data-toggle="popover"
data-trigger="hover" data-placement="top" data-trigger="hover" data-placement="top"
data-html="true" data-html="true"
data-content="{{ $value['description'] }}"></i> data-content="{{ $value['description'] }}"></i>
@ -224,24 +213,32 @@
<select id="{{ $key }}" <select id="{{ $key }}"
class="custom-select w-100" class="custom-select w-100"
name="{{ $key }}"> name="{{ $key }}">
@if ($value['identifier'] == 'display')
@foreach ($value['options'] as $option=>$display) {{ error_log($key . 'True, IAM A DISPLAY') }}
@foreach ($value['options'] as $option => $display)
<option value="{{ $display }}"
{{ $value['value'] == $display ? 'selected' : '' }}>
{{ __($display) }}
</option>
@endforeach
@else
@foreach ($value['options'] as $option => $display)
<option value="{{ $option }}" <option value="{{ $option }}"
{{ $value['value'] == $option ? 'selected' : '' }}> {{ $value['value'] == $option ? 'selected' : '' }}>
{{ __($display) }} {{ __($display) }}
</option> </option>
@endforeach @endforeach
@endif
</select> </select>
@break @break
@case($value['type'] == 'multiselect') @case($value['type'] == 'multiselect')
<select id="{{ $key }}" <select id="{{ $key }}"
class="custom-select w-100" class="custom-select w-100"
name="{{ $key }}[]" name="{{ $key }}[]" multiple>
multiple>
@foreach ($value['options'] as $option) @foreach ($value['options'] as $option)
<option value="{{ $option }}" <option value="{{ $option }}"
{{ strpos($value['value'],$option) !== false ? 'selected' : '' }}> {{ strpos($value['value'], $option) !== false ? 'selected' : '' }}>
{{ __($option) }} {{ __($option) }}
</option> </option>
@endforeach @endforeach
@ -249,9 +246,7 @@
@break @break
@case($value['type'] == 'textarea') @case($value['type'] == 'textarea')
<textarea class="form-control" <textarea class="form-control" name="{{ $key }}" rows="3">{{ $value['value'] }}</textarea>
name="{{ $key }}"
rows="3">{{ $value['value'] }}</textarea>
@break @break
@default @default
@ -268,14 +263,13 @@
</div> </div>
</div> </div>
@endforeach @endforeach
<!-- TODO: Display this only on the General tab <!-- TODO: Display this only on the General tab
<div class="row"> <div class="row">
<div class="col-4 d-flex align-items-center"> <div class="col-4 d-flex align-items-center">
<label for="recaptcha_preview">{{__("ReCAPTCHA Preview")}}</label> <label for="recaptcha_preview">{{ __('ReCAPTCHA Preview') }}</label>
</div> </div>
<div class="col-8"> <div class="col-8">
@ -298,8 +292,7 @@
<div class="row"> <div class="row">
<div class="col-12 d-flex align-items-center justify-content-end"> <div class="col-12 d-flex align-items-center justify-content-end">
<button type="submit" <button type="submit" class="btn btn-primary float-right ">Save
class="btn btn-primary float-right ">Save
</button> </button>
<button type="reset" <button type="reset"
class="btn btn-secondary float-right ml-2">Reset class="btn btn-secondary float-right ml-2">Reset
@ -331,7 +324,7 @@
$('.nav-item a[href="' + tabPaneHash + '"]').tab('show'); $('.nav-item a[href="' + tabPaneHash + '"]').tab('show');
} }
$('.nav-pills a').click(function (e) { $('.nav-pills a').click(function(e) {
$(this).tab('show'); $(this).tab('show');
const scrollmem = $('body').scrollTop(); const scrollmem = $('body').scrollTop();
window.location.hash = this.hash; window.location.hash = this.hash;