增加response的事件机制;为login增加事件;发布新版本

This commit is contained in:
2023-09-23 14:50:24 +08:00
parent e176ed19e5
commit 08c340a2bf
6 changed files with 90 additions and 16 deletions

View File

@@ -36,6 +36,10 @@ class Login extends AdminController
*/
public function index()
{
event_response('AdminLoginIndex', [
'controller' => $this,
]);
$captcha = Env::get('adminsystem.captcha', 1);
if ($this->request->isPost()) {
$post = $this->request->post();

View File

@@ -4,10 +4,12 @@
use app\commno\exception\EventException;
use app\common\service\AuthService;
use think\exception\HttpResponseException;
use think\facade\Cache;
use think\facade\Env;
use think\facade\Event;
use think\facade\Filesystem;
use think\response\View;
use think\route\Url;
include_once __DIR__ . '/common/app/functions.php';
@@ -230,9 +232,9 @@ function build_upload_url($url, $upload_type = null)
return Filesystem::disk($upload_type)->url($url);
}
function event_handle_result($name, $key, $type = 'all') : array
function event_handle_result($name, $key, $type = 'all', $params = []) : array
{
$list_result = Event::trigger($name);
$list_result = Event::trigger($name, $params);
$result = [];
@@ -287,3 +289,20 @@ function event_view_replace_js($name)
return "<script id='event-replace-js-{$name}' type='text/plain'>{$content_event}</script>";
}
function event_response($name, $params = [])
{
$list_result = event_handle_result($name, 'response', 'last', $params);
if (empty($list_result)) {
return;
}
$response = $list_result[0];
if (is_string($response)) {
$response = View::create($response);
}
throw new HttpResponseException($response);
}

View File

@@ -14,13 +14,13 @@ use think\facade\App;
class Version extends Command
{
public const VERSION = 'v2.0.38';
public const VERSION = 'v2.0.3';
public const LAYUI_VERSION = '2.8.16';
public const COMMENT = [
'增加js的事件处理',
'增加忘记密码的js替换事件',
'增加response的事件机制',
'为login增加事件',
'发布新版本',
];

View File

@@ -141,20 +141,22 @@ class AdminController extends BaseController
return $this->app->view->assign($name, $value);
}
protected function fetchJS()
public function fetchJS($template = '')
{
$content_js = '';
try {
$content_js .= View::layout(false)
->config([
'view_suffix' => 'js',
])->fetch('_common');
$common_template = '_common';
$content_js .= View::layout(false)
->config([
'view_suffix' => 'js',
])->fetch();
if (!empty($template)) {
$template_arr = explode('/', $template);
unset($template_arr[count($template_arr) - 1]);
$template_arr[] = '_common';
$common_template = implode('/', $template_arr);
}
try {
$content_js .= View::layout(false)->fetchJS($common_template);
$content_js .= View::layout(false)->fetchJS($template);
} catch (TemplateNotFoundException $th) {
if (Env::get('adminsystem.strict_view_js', true)) {
throw $th;
@@ -174,7 +176,7 @@ class AdminController extends BaseController
{
$this->assign('data_brage', json_encode($this->dataBrage));
$vars['content_js'] = $this->fetchJS();
$vars['content_js'] = $this->fetchJS($template);
$content_main = View::layout($this->layout)
->config([

View File

@@ -0,0 +1,17 @@
<?php
namespace app\common\event\AdminLoginIndex;
class Index
{
public function handle($params)
{
$controller = $params['controller'];
$controller->assign('captcha',1);
return [
'response' => $controller->fetch('login/ext/index'),
];
}
}

View File

@@ -48,4 +48,36 @@ class View extends ThinkView
return $this;
}
/**
* 解析和获取模板内容 用于输出.
* @param string $template 模板文件名或者内容
* @param array $vars 模板变量
* @return string
* @throws \Exception
*/
public function fetch(string $template = '', array $vars = []): string
{
return $this->config([
'view_suffix' => 'html',
])->getContent(function () use ($vars, $template) {
$this->engine()->fetch($template, array_merge($this->data, $vars));
});
}
/**
* 解析和获取模板内容 用于输出.
* @param string $template 模板文件名或者内容
* @param array $vars 模板变量
* @return string
* @throws \Exception
*/
public function fetchJS(string $template = '', array $vars = []): string
{
return $this->config([
'view_suffix' => 'js',
])->getContent(function () use ($vars, $template) {
$this->engine()->fetch($template, array_merge($this->data, $vars));
});
}
}