This commit is contained in:
xman 2025-03-04 10:02:58 +08:00
parent 7e102fc193
commit 0d13556380
6 changed files with 268 additions and 0 deletions

View File

@ -0,0 +1 @@
{"files":["public\/assets\/addons\/betterform\/css\/common.css"],"license":"regular","licenseto":"15976","licensekey":"jonIxu8gCamyBzi5 N6Q6iqNNuNQoEV\/fV4rCvlZqQvDJEBrF+sYTD7HeULs=","domains":["fast.cc"],"licensecodes":[],"validations":["043c5318e9fc4870124f0d65db900fc1"]}

View File

@ -0,0 +1,113 @@
<?php
namespace addons\betterform;
use app\common\library\Menu;
use think\Addons;
use think\Loader;
/**
* 插件
*/
class Betterform extends Addons
{
/**
* 插件安装方法
* @return bool
*/
public function install()
{
return true;
}
/**
* 插件卸载方法
* @return bool
*/
public function uninstall()
{
return true;
}
/**
* 插件启用方法
* @return bool
*/
public function enable()
{
return true;
}
/**
* 插件禁用方法
* @return bool
*/
public function disable()
{
return true;
}
public function viewFilter(&$content)
{
$request = \think\Request::instance();
$dispatch = $request->dispatch();
if (!$dispatch) {
return;
}
if (!$request->module() || $request->module() !== 'admin') {
return;
}
$config = get_addon_config('betterform');
//在head前引入CSS
$content = preg_replace("/<\/head>/i", "<link href='/assets/addons/betterform/css/common.css' rel='stylesheet' />" . "\n\$0", $content);
//如果不存在表单
if (!preg_match('/<form (.*?)data-toggle="validator"/i', $content)) {
return;
}
// 避免栈空间不足
ini_set('pcre.jit', false);
// 匹配<div class="form-group">标签
$regex = '/<div[^>]*class\s*=\s*"[^"]*\bform-group\b[^"]*"[^>]*>(?:(?!<div[^>]*class\s*=\s*"[^"]*\bform-group\b[^"]*").)*?data-rule="[^"]*?(required|checked)[^"]*?"[^>]*>/si';
$result = preg_replace_callback($regex, function ($matches) use ($config) {
return str_replace("form-group", "form-group required-{$config['asteriskposition']}", $matches[0]);
}, $content);
$content = is_null($result) ? $content : $result;
// 匹配<tr>
$pattern = '/(<tr[^>]*>)\s*<td[^>]*>(.*?)<\/td>\s*<td[^>]*>.*?<input[^>]*data-rule="[^"]*required[^"]*"[^>]*>.*?<\/td>\s*<\/tr>/si';
$result = preg_replace_callback($pattern, function ($matches) use ($config) {
if (preg_match('/(<tr[^>]*)class\s*=\s*"[^"]*"/i', $matches[1])) {
return preg_replace('/(<tr[^>]*)class\s*=\s*"([^"]*)"/i', '$1class="$2 required-' . $config['asteriskposition'] . '"', $matches[0]);
} else {
return str_replace("<tr", "<tr class=\"required-{$config['asteriskposition']}\"", $matches[0]);
}
}, $content);
$content = is_null($result) ? $content : $result;
}
/**
* @param $params
*/
public function configInit(&$params)
{
$config = $this->getConfig();
$config['area'] = preg_match("/\[(.*?)\]/i", $config['area']) ? array_slice(array_values((array)json_decode($config['area'], true)), 0, 2) : $config['area'];
$config['shade'] = floatval($config['shade']);
$config['shadeClose'] = boolval($config['shadeClose']);
$params['betterform'] = $config;
}
}

27
addons/betterform/bootstrap.js vendored Normal file
View File

@ -0,0 +1,27 @@
require(['fast', 'layer'], function (Fast, Layer) {
var _fastOpen = Fast.api.open;
Fast.api.open = function (url, title, options) {
options = options || {};
options.area = Config.betterform.area;
options.offset = Config.betterform.offset;
options.anim = Config.betterform.anim;
options.shadeClose = Config.betterform.shadeClose;
options.shade = Config.betterform.shade;
return _fastOpen(url, title, options);
};
if (isNaN(Config.betterform.anim)) {
var _layerOpen = Layer.open;
Layer.open = function (options) {
var classNameArr = {slideDown: "layer-anim-slide-down", slideLeft: "layer-anim-slide-left", slideUp: "layer-anim-slide-up", slideRight: "layer-anim-slide-right"};
var animClass = "layer-anim " + classNameArr[options.anim] || "layer-anim-fadein";
var index = _layerOpen(options);
var layero = $('#layui-layer' + index);
layero.addClass(classNameArr[options.anim] + "-custom");
layero.addClass(animClass).one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function () {
$(this).removeClass(animClass);
});
return index;
}
}
});

View File

@ -0,0 +1,102 @@
<?php
return [
[
'name' => 'asteriskposition',
'title' => '*号位置',
'type' => 'radio',
'group' => '',
'visible' => '',
'content' => [
'before' => '位于文本前',
'after' => '位于文本后',
],
'value' => 'before',
'rule' => 'required',
'msg' => '',
'tip' => '',
'ok' => '',
'extend' => '',
],
[
'name' => 'offset',
'title' => '弹窗位置',
'type' => 'radio',
'content' => [
'auto' => '居中',
't' => '顶部',
'b' => '底部',
'l' => '左部',
'r' => '右部',
],
'value' => 'r',
'rule' => 'required',
'msg' => '',
'tip' => '',
'ok' => '',
'extend' => '',
],
[
'name' => 'anim',
'title' => '打开动画',
'type' => 'select',
'content' => [
'平滑放大',
'从上掉落',
'从最底部往上滑入',
'从左滑入',
'从左翻滚',
'渐显',
'抖动',
'slideDown' => '从上边缘往下',
'slideLeft' => '从右边缘往左',
'slideUp' => '从下边缘往上',
'slideRight' => '从左边缘往右',
],
'value' => 'slideLeft',
'rule' => 'required',
'msg' => '',
'tip' => '',
'ok' => '',
'extend' => '',
],
[
'name' => 'area',
'title' => '弹窗宽高',
'type' => 'string',
'content' => [],
'value' => '["80%", "100%"]',
'rule' => 'required',
'msg' => '',
'tip' => '',
'ok' => '',
'extend' => '',
],
[
'name' => 'shade',
'title' => '阴影透明度',
'type' => 'number',
'content' => [],
'value' => '0.3',
'rule' => 'required',
'msg' => '',
'tip' => '',
'ok' => '',
'extend' => '',
],
[
'name' => 'shadeClose',
'title' => '点击阴影关闭弹窗',
'type' => 'bool',
'content' => [
1 => '开启',
0 => '关闭',
],
'value' => '1',
'rule' => 'required',
'msg' => '',
'tip' => '',
'ok' => '',
'extend' => '',
],
];

View File

@ -0,0 +1,15 @@
<?php
namespace addons\betterform\controller;
use think\addons\Controller;
class Index extends Controller
{
public function index()
{
$this->error("当前插件暂无前台页面");
}
}

View File

@ -0,0 +1,10 @@
name = betterform
title = FastAdmin表单弹窗优化插件
intro = 优化FastAdmin表单弹窗
author = FastAdmin
website = https://www.fastadmin.net
version = 1.0.3
state = 1
url = http://fast.cc:8088/addons/betterform
license = regular
licenseto = 15976