291 lines
16 KiB
PHP
291 lines
16 KiB
PHP
@section('title', '系统设置')
|
||
|
||
@push('styles')
|
||
<link rel="stylesheet" href="{{ asset('css/markdown-css/github-markdown-light.css') }}">
|
||
@endpush
|
||
|
||
<x-app-layout>
|
||
<div class="my-6 md:my-9">
|
||
<p class="mb-3 font-semibold text-lg text-gray-700">通用</p>
|
||
<form action="{{ route('admin.settings.save') }}">
|
||
<div class="relative p-4 rounded-md bg-white mb-8 space-y-4">
|
||
<div>
|
||
<label for="app_name" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>应用名称</label>
|
||
<x-input type="text" name="app_name" id="app_name" value="{{ $configs->get('app_name') }}" placeholder="请输入应用名称"/>
|
||
</div>
|
||
<div>
|
||
<label for="site_keywords" class="block text-sm font-medium text-gray-700">网站关键字</label>
|
||
<x-textarea type="text" name="site_keywords" id="site_keywords" placeholder="请输入网站关键字">{{ $configs->get('site_keywords') }}</x-textarea>
|
||
</div>
|
||
<div>
|
||
<label for="site_description" class="block text-sm font-medium text-gray-700">网站描述</label>
|
||
<x-textarea type="text" name="site_description" id="site_description" placeholder="请输入网站描述">{{ $configs->get('site_description') }}</x-textarea>
|
||
</div>
|
||
<div>
|
||
<label for="icp_no" class="block text-sm font-medium text-gray-700">备案号</label>
|
||
<x-input type="text" name="icp_no" id="icp_no" value="{{ $configs->get('icp_no') }}" placeholder="请输入备案号"/>
|
||
</div>
|
||
<div>
|
||
<label for="site_notice" class="block text-sm font-medium text-gray-700">网站公告</label>
|
||
<x-textarea type="text" name="site_notice" id="site_notice" placeholder="首页弹出公告,支持 Markdown,不设置请留空。" rows="7">{{ $configs->get('site_notice') }}</x-textarea>
|
||
</div>
|
||
|
||
<div class="text-right">
|
||
<x-button type="submit">保存更改</x-button>
|
||
</div>
|
||
</div>
|
||
</form>
|
||
|
||
<p class="mb-3 font-semibold text-lg text-gray-700">控制</p>
|
||
<form action="{{ route('admin.settings.save') }}">
|
||
<div class="relative p-4 rounded-md bg-white mb-8 space-y-4">
|
||
<x-fieldset title="是否启用注册" faq="启用或关闭系统注册功能">
|
||
<x-switch name="is_enable_registration" value="1" :checked="(bool) $configs->get('is_enable_registration')" />
|
||
</x-fieldset>
|
||
<x-fieldset title="是否启用画廊" faq="启用或关闭画廊功能,画廊只有已登录的用户可见,画廊中的图片均为所有用户公开的图片。">
|
||
<x-switch name="is_enable_gallery" value="1" :checked="(bool) $configs->get('is_enable_gallery')" />
|
||
</x-fieldset>
|
||
<x-fieldset title="是否启用接口" faq="启用或关闭接口功能,关闭后将无法通过接口上传图片、管理图片等操作。">
|
||
<x-switch name="is_enable_api" value="1" :checked="(bool) $configs->get('is_enable_api')" />
|
||
</x-fieldset>
|
||
<x-fieldset title="是否允许游客上传" faq="启用或关闭游客上传功能,游客上传受「系统默认组」控制。">
|
||
<x-switch name="is_allow_guest_upload" value="1" :checked="(bool) $configs->get('is_allow_guest_upload')" />
|
||
</x-fieldset>
|
||
<x-fieldset title="账号验证" faq="是否强制用户验证邮箱,开启后用户必须经过验证邮箱后才能上传图片,请确保邮件配置正常。">
|
||
<x-switch name="is_user_need_verify" value="1" :checked="(bool) $configs->get('is_user_need_verify')" />
|
||
</x-fieldset>
|
||
<div class="text-right">
|
||
<x-button type="submit">保存更改</x-button>
|
||
</div>
|
||
</div>
|
||
</form>
|
||
|
||
<p class="mb-3 font-semibold text-lg text-gray-700">用户</p>
|
||
<form action="{{ route('admin.settings.save') }}">
|
||
<div class="relative p-4 rounded-md bg-white mb-8 space-y-4">
|
||
<div>
|
||
<label for="user_initial_capacity" class="block text-sm font-medium text-gray-700">用户初始容量(kb)</label>
|
||
<x-input type="number" name="user_initial_capacity" id="user_initial_capacity" step="0.01" value="{{ $configs->get('user_initial_capacity') }}" placeholder="请输入用户初始容量(kb)"/>
|
||
</div>
|
||
|
||
<div class="text-right">
|
||
<x-button type="submit">保存更改</x-button>
|
||
</div>
|
||
</div>
|
||
</form>
|
||
|
||
<p class="mb-3 font-semibold text-lg text-gray-700">邮件配置</p>
|
||
<div class="relative p-4 rounded-md bg-white mb-8 space-y-4">
|
||
<x-fieldset title="发信驱动">
|
||
<x-fieldset-radio id="mail[default]" name="mail[default]" data-select="mailer" value="smtp" checked>SMTP</x-fieldset-radio>
|
||
</x-fieldset>
|
||
|
||
<div class="mb-4 hidden" data-mailer-driver="smtp">
|
||
<form action="{{ route('admin.settings.save') }}" class="space-y-4">
|
||
<div>
|
||
<label for="mail[mailers][smtp][host]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>主机地址</label>
|
||
<x-input type="text" name="mail[mailers][smtp][host]" id="mail[mailers][smtp][host]" value="{{ $configs['mail']['mailers']['smtp']['host'] ?? '' }}" placeholder="请输入 SMTP 主机地址"/>
|
||
</div>
|
||
<div>
|
||
<label for="mail[mailers][smtp][port]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>连接端口</label>
|
||
<x-input type="number" name="mail[mailers][smtp][port]" id="mail[mailers][smtp][port]" value="{{ $configs['mail']['mailers']['smtp']['port'] ?? 587 }}" placeholder="请输入 SMTP 主机连接端口"/>
|
||
</div>
|
||
<div>
|
||
<label for="mail[mailers][smtp][username]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>用户名</label>
|
||
<x-input type="text" name="mail[mailers][smtp][username]" id="mail[mailers][smtp][username]" value="{{ $configs['mail']['mailers']['smtp']['username'] ?? '' }}" placeholder="请输入用户名"/>
|
||
</div>
|
||
<div>
|
||
<label for="mail[mailers][smtp][password]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>密码</label>
|
||
<x-input type="password" name="mail[mailers][smtp][password]" id="mail[mailers][smtp][password]" value="{{ $configs['mail']['mailers']['smtp']['password'] ?? '' }}" placeholder="请输入密码"/>
|
||
</div>
|
||
<div>
|
||
<label for="mail[mailers][smtp][encryption]" class="block text-sm font-medium text-gray-700">加密方式</label>
|
||
<x-input type="text" name="mail[mailers][smtp][encryption]" id="mail[mailers][smtp][encryption]" value="{{ $configs['mail']['mailers']['smtp']['encryption'] ?? '' }}" placeholder="请输入加密方式(ssl, tls)"/>
|
||
</div>
|
||
<div>
|
||
<label for="mail[mailers][smtp][timeout]" class="block text-sm font-medium text-gray-700">连接超时时间(秒)</label>
|
||
<x-input type="number" name="mail[mailers][smtp][timeout]" id="mail[mailers][smtp][timeout]" value="{{ $configs['mail']['mailers']['smtp']['timeout'] ?? 10 }}" placeholder="请输入连接超时时间(秒)"/>
|
||
</div>
|
||
<div>
|
||
<label for="mail[mailers][smtp][from_address]" class="block text-sm font-medium text-gray-700">发件人地址</label>
|
||
<x-input type="email" name="mail[from][address]" id="mail[from][address]" value="{{ $configs['mail']['from']['address'] ?? '' }}" placeholder="请输入发件人邮箱地址"/>
|
||
</div>
|
||
<div>
|
||
<label for="mail[mailers][smtp][from_name]" class="block text-sm font-medium text-gray-700">发件人名称</label>
|
||
<x-input type="text" name="mail[from][name]" id="mail[from][name]" value="{{ $configs['mail']['from']['name'] ?? '' }}" placeholder="请输入发件人名称"/>
|
||
</div>
|
||
|
||
<input type="hidden" name="mail[default]" value="smtp">
|
||
<input type="hidden" name="mail[mailers][smtp][transport]" value="smtp">
|
||
|
||
<div class="text-right">
|
||
<x-button type="button" id="mail-test" class="bg-yellow-500">测试</x-button>
|
||
<x-button type="submit">保存更改</x-button>
|
||
</div>
|
||
</form>
|
||
</div>
|
||
</div>
|
||
|
||
<p class="mb-3 font-semibold text-lg text-gray-700">系统升级</p>
|
||
<div class="relative p-4 rounded-md bg-white mb-8">
|
||
<p id="check-update" class="text-gray-600 text-center p-4" style="display: none">
|
||
<i class="fas fa-cog animate-spin"></i> 正在检查更新...
|
||
</p>
|
||
<p id="not-update" class="text-center p-6" style="display: none">
|
||
<span class="text-gray-700">{{ \App\Utils::config(\App\Enums\ConfigKey::AppVersion) }}</span>
|
||
<span class="text-gray-500">已是最新版本</span>
|
||
</p>
|
||
<div id="have-update" class="break-words" style="display: none"></div>
|
||
</div>
|
||
</div>
|
||
|
||
<script type="text/html" id="update-tpl">
|
||
<div class="flex items-center">
|
||
<img id="icon" src="__icon__" alt="icon" class="rounded-full w-16" style="animation-duration: 5s">
|
||
<div class="flex flex-col text-gray-700 ml-4">
|
||
<p class="font-semibold">Lsky Pro __name__</p>
|
||
<p class="text-sm">__size__</p>
|
||
<p class="text-sm">发布于 __pushed_at__</p>
|
||
</div>
|
||
</div>
|
||
<p id="upgrade-message" class="mt-4 text-sm text-gray-500"></p>
|
||
<div class="mt-4 text-sm markdown-body">
|
||
__changelog__
|
||
</div>
|
||
<div class="mt-6 text-right">
|
||
<a href="javascript:void(0)" id="install" class="rounded-md px-4 py-2 bg-blue-500 text-white">立即安装</a>
|
||
</div>
|
||
</script>
|
||
|
||
@push('scripts')
|
||
<script>
|
||
// 设置选中驱动
|
||
let setSelected = function () {
|
||
$('[data-select]').each(function () {
|
||
$(`[data-${$(this).data('select')}-driver=${$(this).val()}]`)[this.checked ? 'show' : 'hide']();
|
||
});
|
||
};
|
||
|
||
setSelected();
|
||
|
||
$('[data-select]').click(function () {
|
||
setSelected();
|
||
});
|
||
|
||
$('form').submit(function (e) {
|
||
e.preventDefault();
|
||
axios.put(this.action, $(this).serialize()).then(function (response) {
|
||
toastr[response.data.status ? 'success' : 'error'](response.data.message)
|
||
});
|
||
});
|
||
|
||
$('#mail-test').click(function () {
|
||
Swal.fire({
|
||
title: '请输入接收测试邮件的邮箱',
|
||
input: 'text',
|
||
inputValue: '',
|
||
inputAttributes: {
|
||
type: 'email',
|
||
autocapitalize: 'off'
|
||
},
|
||
showCancelButton: true,
|
||
confirmButtonText: '确认',
|
||
showLoaderOnConfirm: true,
|
||
preConfirm: (value) => {
|
||
return axios.post('{{ route('admin.settings.mail.test') }}', {
|
||
email: value,
|
||
}).then(response => {
|
||
if (! response.data.status) {
|
||
throw new Error(response.data.message)
|
||
}
|
||
return response.data;
|
||
}).catch(error => Swal.showValidationMessage(error));
|
||
},
|
||
allowOutsideClick: () => !Swal.isLoading()
|
||
}).then((result) => {
|
||
if (result.isConfirmed) {
|
||
toastr[result.value.status ? 'success' : 'warning'](result.value.message);
|
||
}
|
||
})
|
||
});
|
||
|
||
let timer;
|
||
let upgrade = function () {
|
||
return {
|
||
start: function () {
|
||
$('#icon').addClass('animate-spin')
|
||
$('#install').attr('disabled', true).removeClass('bg-blue-500').addClass('cursor-not-allowed bg-gray-400').text('执行升级中...')
|
||
$('#upgrade-message').text('准备升级...').removeClass('text-red-500').addClass('text-gray-500');
|
||
|
||
timer = setInterval(getProgress, 1500);
|
||
axios.post('{{ route('admin.settings.upgrade') }}');
|
||
},
|
||
stop: function () {
|
||
$('#icon').removeClass('animate-spin')
|
||
$('#install').attr('disabled', false).removeClass('cursor-not-allowed bg-gray-400').addClass('bg-blue-500').text('立即安装')
|
||
clearInterval(timer);
|
||
}
|
||
};
|
||
};
|
||
|
||
let getVersion = function (callback) {
|
||
$('#check-update').show();
|
||
axios.get('{{ route('admin.settings.check.update') }}').then(response => {
|
||
if (response.data.status && response.data.data.is_update) {
|
||
$('#check-update').hide();
|
||
let version = response.data.data.version;
|
||
let html = $('#update-tpl').html()
|
||
.replace(/__icon__/g, version.icon)
|
||
.replace(/__name__/g, version.name)
|
||
.replace(/__size__/g, version.size)
|
||
.replace(/__pushed_at__/g, version.pushed_at)
|
||
.replace(/__changelog__/g, version.changelog);
|
||
$('#have-update').html(html).show();
|
||
$('.markdown-body a').attr('target', '_blank');
|
||
callback && callback(version);
|
||
} else {
|
||
$('#not-update').show();
|
||
$('#check-update').hide();
|
||
}
|
||
});
|
||
}
|
||
|
||
let getProgress = function () {
|
||
axios.get('{{ route('admin.settings.upgrade.progress') }}').then(response => {
|
||
$('#upgrade-message').text(response.data.data.message);
|
||
if (response.data.data.status === 'success') {
|
||
$('#upgrade-message').removeClass('text-gray-500').addClass('text-green-500');
|
||
$('#install').hide();
|
||
}
|
||
if (response.data.data.status === 'fail') {
|
||
$('#upgrade-message').removeClass('text-gray-500').addClass('text-red-500');
|
||
}
|
||
if (response.data.data.status !== 'installing') {
|
||
upgrade().stop();
|
||
}
|
||
});
|
||
};
|
||
|
||
$(document).on('click', '#install', function () {
|
||
if ($(this).attr('disabled')) {
|
||
return;
|
||
}
|
||
upgrade().start();
|
||
});
|
||
|
||
@if(cache()->has('upgrade_progress'))
|
||
getVersion(() => {
|
||
$('#icon').addClass('animate-spin')
|
||
$('#install').attr('disabled', true).removeClass('bg-blue-500').addClass('cursor-not-allowed bg-gray-400').text('正在升级...')
|
||
$('#upgrade-message').text('请稍等...').removeClass('text-red-500').addClass('text-gray-500');
|
||
|
||
timer = setInterval(getProgress, 1500);
|
||
});
|
||
@else
|
||
getVersion();
|
||
@endif
|
||
</script>
|
||
@endpush
|
||
|
||
</x-app-layout>
|