2021-06-05 09:26:32 +00:00
|
|
|
@extends('layouts.main')
|
|
|
|
|
|
|
|
@section('content')
|
|
|
|
<!-- CONTENT HEADER -->
|
|
|
|
<section class="content-header">
|
|
|
|
<div class="container-fluid">
|
|
|
|
<div class="row mb-2">
|
|
|
|
<div class="col-sm-6">
|
2022-01-02 18:38:13 +00:00
|
|
|
<h1>{{ __('Settings') }}</h1>
|
2021-06-05 09:26:32 +00:00
|
|
|
</div>
|
|
|
|
<div class="col-sm-6">
|
|
|
|
<ol class="breadcrumb float-sm-right">
|
2023-02-09 13:41:53 +00:00
|
|
|
<li class="breadcrumb-item"><a href="">{{ __('Dashboard') }}</a></li>
|
2021-06-05 09:26:32 +00:00
|
|
|
<li class="breadcrumb-item"><a class="text-muted"
|
2022-01-02 18:38:13 +00:00
|
|
|
href="{{ route('admin.settings.index') }}">{{ __('Settings') }}</a></li>
|
2021-06-05 09:26:32 +00:00
|
|
|
</ol>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
<!-- END CONTENT HEADER -->
|
2023-02-09 17:29:03 +00:00
|
|
|
@if (!file_exists(base_path() . '/install.lock'))
|
2022-01-25 06:29:48 +00:00
|
|
|
<div class="callout callout-danger">
|
|
|
|
<h4>{{ __('The installer is not locked!') }}</h4>
|
2023-02-09 17:29:03 +00:00
|
|
|
<p>{{ __('please create a file called "install.lock" in your dashboard Root directory. Otherwise no settings will be loaded!') }}
|
|
|
|
</p>
|
|
|
|
<a href="/install?step=7"><button class="btn btn-outline-danger">{{ __('or click here') }}</button></a>
|
2022-01-26 11:48:32 +00:00
|
|
|
|
2022-01-25 06:29:48 +00:00
|
|
|
</div>
|
|
|
|
@endif
|
2021-06-05 09:26:32 +00:00
|
|
|
<!-- MAIN CONTENT -->
|
|
|
|
<section class="content">
|
|
|
|
<div class="container-fluid">
|
|
|
|
<div class="card">
|
|
|
|
<div class="card-header">
|
|
|
|
<div class="d-flex justify-content-between">
|
2022-01-02 18:38:13 +00:00
|
|
|
<h5 class="card-title"><i class="fas fa-tools mr-2"></i>{{ __('Settings') }}</h5>
|
2021-06-05 09:26:32 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
2023-02-09 13:41:53 +00:00
|
|
|
<div class="card-body">
|
2023-02-09 17:29:03 +00:00
|
|
|
<!-- Sidebar Menu -->
|
2023-02-09 19:40:24 +00:00
|
|
|
<div class="d-flex w-100">
|
2023-02-09 21:34:34 +00:00
|
|
|
<div class="col-2 p-0">
|
|
|
|
<nav class="mt-1">
|
|
|
|
<ul class="nav nav-pills nav-sidebar flex-column" data-widget="treeview" role="tablist"
|
|
|
|
data-accordion="false">
|
|
|
|
@foreach ($settings as $category => $options)
|
|
|
|
<li class="nav-item border-bottom-0">
|
|
|
|
<a href="#{{ $category }}"
|
|
|
|
class="nav-link {{ $loop->first ? 'active' : '' }}" data-toggle="pill"
|
|
|
|
role="tab">
|
2023-02-20 12:44:06 +00:00
|
|
|
<i
|
|
|
|
class="nav-icon fas {{ $options['category_icon'] ?? 'fas fa-cog' }}"></i>
|
2023-02-09 21:34:34 +00:00
|
|
|
<p>
|
|
|
|
{{ $category }}
|
|
|
|
</p>
|
|
|
|
</a>
|
|
|
|
</li>
|
|
|
|
@endforeach
|
|
|
|
</ul>
|
|
|
|
</nav>
|
|
|
|
</div>
|
2023-02-09 19:40:24 +00:00
|
|
|
<!-- /.sidebar-menu -->
|
|
|
|
<!-- Content in $settings -->
|
2023-02-09 21:34:34 +00:00
|
|
|
<div class="col-10 p-0">
|
|
|
|
<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">
|
|
|
|
|
2023-02-09 23:04:00 +00:00
|
|
|
<form action="{{ route('admin.settings.update') }}" method="POST">
|
|
|
|
@csrf
|
|
|
|
@method('POST')
|
2023-03-04 19:28:27 +00:00
|
|
|
<input type="hidden" name="settings_class"
|
|
|
|
value="{{ $options['settings_class'] }}">
|
2023-02-09 23:32:19 +00:00
|
|
|
<input type="hidden" name="category" value="{{ $category }}">
|
2023-02-09 23:04:00 +00:00
|
|
|
|
|
|
|
@foreach ($options as $key => $value)
|
2023-03-04 19:28:27 +00:00
|
|
|
@if ($key == 'category_icon' || $key == 'settings_class')
|
2023-02-20 12:44:06 +00:00
|
|
|
@continue
|
|
|
|
@endif
|
2023-02-09 23:04:00 +00:00
|
|
|
<div class="row">
|
|
|
|
<div class="col-4 d-flex align-items-center">
|
|
|
|
<label for="{{ $key }}">{{ $value['label'] }}</label>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="col-8">
|
|
|
|
<div class="custom-control mb-3 d-flex align-items-center">
|
|
|
|
@if ($value['description'])
|
|
|
|
<i class="fas fa-info-circle mr-4" data-toggle="popover"
|
|
|
|
data-trigger="hover" data-placement="top"
|
|
|
|
data-html="true"
|
|
|
|
data-content="{{ $value['description'] }}"></i>
|
|
|
|
@else
|
|
|
|
<i class="fas fa-info-circle mr-4 invisible"></i>
|
|
|
|
@endif
|
|
|
|
|
2023-02-11 15:02:02 +00:00
|
|
|
<div class="w-100">
|
2023-02-09 23:04:00 +00:00
|
|
|
@switch($value)
|
|
|
|
@case($value['type'] == 'string')
|
|
|
|
<input type="text" class="form-control"
|
|
|
|
name="{{ $key }}"
|
|
|
|
value="{{ $value['value'] }}">
|
|
|
|
@break
|
|
|
|
|
|
|
|
@case($value['type'] == 'boolean')
|
|
|
|
<input type="checkbox" name="{{ $key }}"
|
2023-02-09 23:43:33 +00:00
|
|
|
value="{{ $value['value'] }}"
|
|
|
|
{{ $value['value'] ? 'checked' : '' }}>
|
2023-02-09 23:04:00 +00:00
|
|
|
@break
|
|
|
|
|
|
|
|
@case($value['type'] == 'number')
|
|
|
|
<input type="number" class="form-control"
|
|
|
|
name="{{ $key }}"
|
|
|
|
value="{{ $value['value'] }}">
|
|
|
|
@break
|
|
|
|
|
|
|
|
@case($value['type'] == 'select')
|
|
|
|
<select id="{{ $key }}"
|
|
|
|
class="custom-select w-100" name="{{ $key }}">
|
|
|
|
@foreach ($value['options'] as $option)
|
|
|
|
<option value="{{ $option }}"
|
|
|
|
{{ $value['value'] == $option ? 'selected' : '' }}>
|
|
|
|
{{ __($option) }}
|
|
|
|
</option>
|
|
|
|
@endforeach
|
|
|
|
</select>
|
|
|
|
@break
|
|
|
|
|
|
|
|
@case($value['type'] == 'multiselect')
|
|
|
|
<select id="{{ $key }}"
|
|
|
|
class="custom-select w-100" name="{{ $key }}"
|
|
|
|
multiple>
|
|
|
|
@foreach ($value['options'] as $option)
|
|
|
|
<option value="{{ $option }}"
|
|
|
|
{{ $value['value'] == $option ? 'selected' : '' }}>
|
|
|
|
{{ __($option) }}
|
|
|
|
</option>
|
|
|
|
@endforeach
|
|
|
|
</select>
|
|
|
|
@break
|
|
|
|
|
|
|
|
@case($value['type'] == 'textarea')
|
|
|
|
<textarea class="form-control" name="{{ $key }}" rows="3">{{ $value['value'] }}</textarea>
|
|
|
|
@break
|
|
|
|
|
|
|
|
@default
|
|
|
|
@endswitch
|
|
|
|
@error($key)
|
|
|
|
<div class="text-danger ">
|
|
|
|
{{ $message }}
|
|
|
|
</div>
|
|
|
|
@enderror
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
</div>
|
2023-02-09 21:34:34 +00:00
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
2023-02-09 23:04:00 +00:00
|
|
|
@endforeach
|
2023-04-29 23:00:45 +00:00
|
|
|
<div class="row">
|
|
|
|
<div class="col-4 d-flex align-items-center">
|
|
|
|
<label for="recaptcha_preview">{{__("ReCAPTCHA Preview")}}</label>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="col-8">
|
|
|
|
|
|
|
|
<div class="w-100">
|
|
|
|
<div class="input-group mb-3">
|
|
|
|
{!! htmlScriptTagJsApi() !!}
|
|
|
|
{!! htmlFormSnippet() !!}
|
|
|
|
@error('g-recaptcha-response')
|
|
|
|
<span class="text-danger" role="alert">
|
|
|
|
<small><strong>{{ $message }}</strong></small>
|
|
|
|
</span>
|
|
|
|
@enderror
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
2023-02-09 23:04:00 +00:00
|
|
|
<div class="row">
|
2023-02-10 12:36:38 +00:00
|
|
|
<div class="col-12 d-flex align-items-center justify-content-end">
|
|
|
|
<button type="submit"
|
|
|
|
class="btn btn-primary float-right ">Save</button>
|
2023-02-09 23:04:00 +00:00
|
|
|
<button type="reset"
|
2023-02-10 12:36:38 +00:00
|
|
|
class="btn btn-secondary float-right ml-2">Reset</button>
|
2023-02-09 23:04:00 +00:00
|
|
|
</div>
|
2023-02-09 19:40:24 +00:00
|
|
|
</div>
|
2023-02-09 23:04:00 +00:00
|
|
|
</form>
|
2023-02-09 21:34:34 +00:00
|
|
|
</div>
|
|
|
|
@endforeach
|
2023-02-09 23:04:00 +00:00
|
|
|
|
2023-02-09 21:34:34 +00:00
|
|
|
</div>
|
2023-02-09 19:40:24 +00:00
|
|
|
</div>
|
2023-02-09 17:29:03 +00:00
|
|
|
</div>
|
2021-06-05 09:26:32 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
2021-12-01 12:30:40 +00:00
|
|
|
</div>
|
2021-06-05 09:26:32 +00:00
|
|
|
|
2021-11-30 17:40:56 +00:00
|
|
|
|
2023-02-09 21:34:34 +00:00
|
|
|
|
2021-06-05 09:26:32 +00:00
|
|
|
<!-- END CUSTOM CONTENT -->
|
|
|
|
|
|
|
|
</section>
|
|
|
|
<!-- END CONTENT -->
|
|
|
|
|
2021-11-12 17:23:06 +00:00
|
|
|
<script>
|
2022-01-14 23:49:33 +00:00
|
|
|
const tabPaneHash = window.location.hash;
|
|
|
|
if (tabPaneHash) {
|
2023-02-09 19:40:24 +00:00
|
|
|
$('.nav-item a[href="' + tabPaneHash + '"]').tab('show');
|
2022-01-14 23:49:33 +00:00
|
|
|
}
|
|
|
|
|
2023-02-09 19:40:24 +00:00
|
|
|
$('.nav-pills a').click(function(e) {
|
2022-01-14 23:49:33 +00:00
|
|
|
$(this).tab('show');
|
|
|
|
const scrollmem = $('body').scrollTop();
|
|
|
|
window.location.hash = this.hash;
|
|
|
|
$('html,body').scrollTop(scrollmem);
|
|
|
|
});
|
2023-02-09 21:34:34 +00:00
|
|
|
|
|
|
|
document.addEventListener('DOMContentLoaded', (event) => {
|
|
|
|
$('.custom-select').select2();
|
|
|
|
})
|
|
|
|
|
|
|
|
tinymce.init({
|
|
|
|
selector: 'textarea',
|
|
|
|
promotion: false,
|
|
|
|
skin: "oxide-dark",
|
|
|
|
content_css: "dark",
|
|
|
|
branding: false,
|
|
|
|
height: 500,
|
|
|
|
width: '100%',
|
|
|
|
plugins: ['image', 'link'],
|
|
|
|
});
|
2021-11-12 17:23:06 +00:00
|
|
|
</script>
|
2021-06-05 09:26:32 +00:00
|
|
|
@endsection
|