feat: ✨ Added Labels to settings (controller) and show settings for category tab
This commit is contained in:
parent
3b1b6e9b7e
commit
25b2d06572
|
@ -27,8 +27,21 @@ class SettingsController extends Controller
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$className = 'App\\Settings\\' . str_replace('.php', '', $file);
|
$className = 'App\\Settings\\' . str_replace('.php', '', $file);
|
||||||
$settings[str_replace('Settings.php', '', $file)] = (new $className())->toCollection()->all();
|
$options = (new $className())->toArray();
|
||||||
|
|
||||||
|
|
||||||
|
foreach ($options as $key => $value) {
|
||||||
|
$options[$key] = [
|
||||||
|
'value' => $value,
|
||||||
|
'label' => ucwords(str_replace('_', ' ', $key))
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$settings[str_replace('Settings.php', '', $file)] = $options;
|
||||||
}
|
}
|
||||||
|
|
||||||
$settings->sort();
|
$settings->sort();
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -39,31 +39,58 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<!-- Sidebar Menu -->
|
<!-- Sidebar Menu -->
|
||||||
<nav class="mt-2 max-w-30">
|
<div class="d-flex w-100">
|
||||||
<ul class="nav nav-pills nav-sidebar flex-column" data-widget="treeview" role="menu"
|
<nav class="mt-1">
|
||||||
data-accordion="false">
|
<ul class="nav nav-pills nav-sidebar flex-column" data-widget="treeview" role="tablist"
|
||||||
@foreach ($settings as $key => $setting)
|
data-accordion="false">
|
||||||
<li class="nav-item border-bottom-0">
|
@foreach ($settings as $category => $options)
|
||||||
<a href="#{{ $key }}" class="nav-link {{ $loop->first ? 'active' : '' }}"
|
<li class="nav-item border-bottom-0">
|
||||||
data-toggle="tab">
|
<a href="#{{ $category }}" class="nav-link {{ $loop->first ? 'active' : '' }}"
|
||||||
<i class="nav-icon fas fa-cog"></i>
|
data-toggle="pill" role="tab">
|
||||||
<p>
|
<i class="nav-icon fas fa-cog"></i>
|
||||||
{{ $key }}
|
<p>
|
||||||
</p>
|
{{ $category }}
|
||||||
</a>
|
</p>
|
||||||
</li>
|
</a>
|
||||||
|
</li>
|
||||||
|
@endforeach
|
||||||
|
</ul>
|
||||||
|
</nav>
|
||||||
|
<!-- /.sidebar-menu -->
|
||||||
|
<!-- Content in $settings -->
|
||||||
|
<div class="tab-content ml-3" style="width: 100%;">
|
||||||
|
@foreach ($settings as $category => $options)
|
||||||
|
<div container class="tab-pane fade container {{ $loop->first ? 'active show' : '' }}"
|
||||||
|
id="{{ $category }}" role="tabpanel">
|
||||||
|
@foreach ($options as $key => $value)
|
||||||
|
<div class="row">
|
||||||
|
<div class="col">
|
||||||
|
{{ $value['label'] }}
|
||||||
|
</div>
|
||||||
|
<div class="col">
|
||||||
|
@if (gettype($value['value']) == 'string')
|
||||||
|
<input type="text" class="form-control" name="{{ $key }}"
|
||||||
|
value="{{ $value['value'] }}">
|
||||||
|
@elseif (gettype($value['value']) == 'boolean')
|
||||||
|
<input type="checkbox" class="form-control" name="{{ $key }}"
|
||||||
|
value="{{ $value['value'] }}">
|
||||||
|
@elseif (gettype($value['value']) == 'integer' || gettype($value['value']) == 'double')
|
||||||
|
<input type="number" class="form-control" name="{{ $key }}"
|
||||||
|
value="{{ $value['value'] }}">
|
||||||
|
@elseif (gettype($value['value']) == 'array')
|
||||||
|
<select class="form-control" name="{{ $key }}">
|
||||||
|
@foreach ($value['value'] as $option)
|
||||||
|
<option value="{{ $option }}">{{ $option }}
|
||||||
|
</option>
|
||||||
|
@endforeach
|
||||||
|
</select>
|
||||||
|
@endif
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endforeach
|
||||||
|
</div>
|
||||||
@endforeach
|
@endforeach
|
||||||
</ul>
|
</div>
|
||||||
</nav>
|
|
||||||
<!-- /.sidebar-menu -->
|
|
||||||
<!-- Content in $settings -->
|
|
||||||
<div class="tab-content">
|
|
||||||
|
|
||||||
@foreach ($settings as $key => $value)
|
|
||||||
<
|
|
||||||
|
|
||||||
@endforeach
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -76,21 +103,12 @@
|
||||||
<!-- END CONTENT -->
|
<!-- END CONTENT -->
|
||||||
|
|
||||||
<script>
|
<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);
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
const tabPaneHash = window.location.hash;
|
const tabPaneHash = window.location.hash;
|
||||||
if (tabPaneHash) {
|
if (tabPaneHash) {
|
||||||
$('.nav-tabs a[href="' + tabPaneHash + '"]').tab('show');
|
$('.nav-item a[href="' + tabPaneHash + '"]').tab('show');
|
||||||
}
|
}
|
||||||
|
|
||||||
$('.nav-tabs 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;
|
||||||
|
|
Loading…
Reference in a new issue