mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2025-04-05 05:52:43 +08:00
同步更新插件代码
This commit is contained in:
parent
58465920ee
commit
7da0b76705
@ -14,6 +14,8 @@
|
||||
// | github 代码仓库:https://github.com/zoujingli/think-plugs-admin
|
||||
// +----------------------------------------------------------------------
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace app\admin;
|
||||
|
||||
use think\admin\Plugin;
|
||||
@ -26,7 +28,13 @@ use think\admin\Plugin;
|
||||
class Service extends Plugin
|
||||
{
|
||||
/**
|
||||
* 定义安装包名称
|
||||
* 定义插件名称
|
||||
* @var string
|
||||
*/
|
||||
protected $appName = '系统管理';
|
||||
|
||||
/**
|
||||
* 定义安装包名
|
||||
* @var string
|
||||
*/
|
||||
protected $package = 'zoujingli/think-plugs-admin';
|
||||
|
@ -35,6 +35,24 @@ class Plugs extends Controller
|
||||
public function icon()
|
||||
{
|
||||
$this->title = '图标选择器';
|
||||
// 读取 layui 字体图标
|
||||
if (empty($this->layuiIcons = $this->app->cache->get('LayuiIcons', []))) {
|
||||
$style = file_get_contents(syspath('public/static/plugs/layui/css/layui.css'));
|
||||
if (preg_match_all('#\.(layui-icon-[\w-]+):#', $style, $matches)) {
|
||||
if (count($this->layuiIcons = $matches[1]) > 0) {
|
||||
$this->app->cache->set('LayuiIcons', $this->layuiIcons, 60);
|
||||
}
|
||||
}
|
||||
}
|
||||
// 读取自定义字体图标
|
||||
if (empty($this->thinkIcons = $this->app->cache->get('ThinkAdminSelfIcons', []))) {
|
||||
$style = file_get_contents(syspath('public/static/theme/css/iconfont.css'));
|
||||
if (preg_match_all('#\.(iconfont-[\w-]+):#', $style, $matches)) {
|
||||
if (count($this->thinkIcons = $matches[1]) > 0) {
|
||||
$this->app->cache->set('ThinkAdminSelfIcons', $this->thinkIcons, 60);
|
||||
}
|
||||
}
|
||||
}
|
||||
$this->field = $this->app->request->get('field', 'icon');
|
||||
$this->fetch(realpath(__DIR__ . '/../../view/api/icon.html'));
|
||||
}
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -1,9 +1,9 @@
|
||||
<div class="image-dialog" id="ImageDialog">
|
||||
<div class="image-dialog-head">
|
||||
<div class="pull-left flex">
|
||||
<label class="pull-left flex">
|
||||
<input class="layui-input margin-right-5" v-model="keys" style="height:30px;line-height:30px" placeholder="请输入搜索关键词">
|
||||
<a class="layui-btn layui-btn-sm layui-btn-normal" @click="search">搜 索</a>
|
||||
</div>
|
||||
</label>
|
||||
<div class="pull-right">
|
||||
<a class="layui-btn layui-btn-sm layui-btn-normal" @click="uploadImage">上传图片</a>
|
||||
</div>
|
||||
|
@ -29,7 +29,13 @@ use think\admin\Plugin;
|
||||
class Service extends Plugin
|
||||
{
|
||||
/**
|
||||
* 定义当前包名
|
||||
* 定义插件名称
|
||||
* @var string
|
||||
*/
|
||||
protected $appName = '微信管理';
|
||||
|
||||
/**
|
||||
* 定义安装包名
|
||||
* @var string
|
||||
*/
|
||||
protected $package = 'zoujingli/think-plugs-wechat';
|
||||
|
@ -13,7 +13,7 @@
|
||||
// +----------------------------------------------------------------------
|
||||
|
||||
/*! 应用根路径,静态插件库路径,动态插件库路径 */
|
||||
var srcs = document.scripts[document.scripts.length - 1].src.split('/');
|
||||
let srcs = document.scripts[document.scripts.length - 1].src.split('/');
|
||||
window.appRoot = srcs.slice(0, -2).join('/') + '/';
|
||||
window.baseRoot = srcs.slice(0, -1).join('/') + '/';
|
||||
window.tapiRoot = window.taAdmin || window.appRoot + "admin";
|
||||
@ -90,70 +90,73 @@ $(function () {
|
||||
|
||||
window.$body = $('body');
|
||||
|
||||
/*! 注册单次事件 */
|
||||
function onEvent(event, select, callable) {
|
||||
return $body.off(event, select).on(event, select, callable);
|
||||
}
|
||||
/*! 基础函数工具 */
|
||||
$.base = new function () {
|
||||
/*! 注册单次事件 */
|
||||
this.onEvent = function (event, select, callable) {
|
||||
return $body.off(event, select).on(event, select, callable);
|
||||
};
|
||||
|
||||
/*! 注册确认回调 */
|
||||
function onConfirm(confirm, callable) {
|
||||
return confirm ? $.msg.confirm(confirm, callable) : callable();
|
||||
}
|
||||
/*! 注册确认回调 */
|
||||
this.onConfirm = function (confirm, callable) {
|
||||
return confirm ? $.msg.confirm(confirm, callable) : callable();
|
||||
};
|
||||
|
||||
/*! 获取加载回调 */
|
||||
onConfirm.getLoadCallable = function (tabldId, callable) {
|
||||
typeof callable === 'function' && callable();
|
||||
return tabldId ? function (ret, time) {
|
||||
if (ret.code < 1) return true;
|
||||
time === 'false' ? $.layTable.reload(tabldId) : $.msg.success(ret.info, time, function () {
|
||||
$.layTable.reload(tabldId);
|
||||
});
|
||||
return false;
|
||||
} : false;
|
||||
}
|
||||
|
||||
/*! 读取 data-value & data-rule 并应用到 callable */
|
||||
function applyRuleValue(elem, data, callabel) {
|
||||
// 新 tableId 规则兼容处理
|
||||
if (elem.dataset.tableId && elem.dataset.rule) {
|
||||
var idx1, idx2, temp, regx, field, rule = {};
|
||||
var json = layui.table.checkStatus(elem.dataset.tableId).data;
|
||||
layui.each(elem.dataset.rule.split(';'), function (idx, item, attr) {
|
||||
attr = item.split('#', 2), rule[attr[0]] = attr[1];
|
||||
});
|
||||
for (idx1 in rule) {
|
||||
temp = [], regx = new RegExp(/^{(.*?)}$/);
|
||||
if (regx.test(rule[idx1]) && (field = rule[idx1].replace(regx, '$1'))) {
|
||||
for (idx2 in json) if (json[idx2][field]) temp.push(json[idx2][field]);
|
||||
if (temp.length < 1) return $.msg.tips('请选择需要更改的数据!'), false;
|
||||
data[idx1] = temp.join(',');
|
||||
} else {
|
||||
data[idx1] = rule[idx1];
|
||||
}
|
||||
}
|
||||
return onConfirm(elem.dataset.confirm, function () {
|
||||
return callabel.call(elem, data, elem, elem.dataset || {});
|
||||
});
|
||||
} else if (elem.dataset.value || elem.dataset.rule) {
|
||||
var value = elem.dataset.value || (function (rule, array) {
|
||||
$(elem.dataset.target || 'input[type=checkbox].list-check-box').map(function () {
|
||||
this.checked && array.push(this.value);
|
||||
/*! 获取加载回调 */
|
||||
this.onConfirm.getLoadCallable = function (tabldId, callable) {
|
||||
typeof callable === 'function' && callable();
|
||||
return tabldId ? function (ret, time) {
|
||||
if (ret.code < 1) return true;
|
||||
time === 'false' ? $.layTable.reload(tabldId) : $.msg.success(ret.info, time, function () {
|
||||
$.layTable.reload(tabldId);
|
||||
});
|
||||
return array.length > 0 ? rule.replace('{key}', array.join(',')) : '';
|
||||
})(elem.dataset.rule || '', []) || '';
|
||||
if (value.length < 1) return $.msg.tips('请选择需要更改的数据!'), false;
|
||||
value.split(';').forEach(function (item) {
|
||||
data[item.split('#')[0]] = item.split('#')[1];
|
||||
});
|
||||
return onConfirm(elem.dataset.confirm, function () {
|
||||
return callabel.call(elem, data, elem, elem.dataset || {});
|
||||
});
|
||||
} else {
|
||||
return onConfirm(elem.dataset.confirm, function () {
|
||||
return callabel.call(elem, data, elem, elem.dataset || {});
|
||||
});
|
||||
return false;
|
||||
} : false;
|
||||
};
|
||||
|
||||
/*! 读取 data-value & data-rule 并应用到 callable */
|
||||
this.applyRuleValue = function (elem, data, callabel) {
|
||||
// 新 tableId 规则兼容处理
|
||||
if (elem.dataset.tableId && elem.dataset.rule) {
|
||||
let idx1, idx2, temp, regx, field, rule = {};
|
||||
let json = layui.table.checkStatus(elem.dataset.tableId).data;
|
||||
layui.each(elem.dataset.rule.split(';'), function (idx, item, attr) {
|
||||
attr = item.split('#', 2), rule[attr[0]] = attr[1];
|
||||
});
|
||||
for (idx1 in rule) {
|
||||
temp = [], regx = new RegExp(/^{(.*?)}$/);
|
||||
if (regx.test(rule[idx1]) && (field = rule[idx1].replace(regx, '$1'))) {
|
||||
for (idx2 in json) if (json[idx2][field]) temp.push(json[idx2][field]);
|
||||
if (temp.length < 1) return $.msg.tips('请选择需要更改的数据!'), false;
|
||||
data[idx1] = temp.join(',');
|
||||
} else {
|
||||
data[idx1] = rule[idx1];
|
||||
}
|
||||
}
|
||||
return $.base.onConfirm(elem.dataset.confirm, function () {
|
||||
return callabel.call(elem, data, elem, elem.dataset || {});
|
||||
});
|
||||
} else if (elem.dataset.value || elem.dataset.rule) {
|
||||
let value = elem.dataset.value || (function (rule, array) {
|
||||
$(elem.dataset.target || 'input[type=checkbox].list-check-box').map(function () {
|
||||
this.checked && array.push(this.value);
|
||||
});
|
||||
return array.length > 0 ? rule.replace('{key}', array.join(',')) : '';
|
||||
})(elem.dataset.rule || '', []) || '';
|
||||
if (value.length < 1) return $.msg.tips('请选择需要更改的数据!'), false;
|
||||
value.split(';').forEach(function (item) {
|
||||
data[item.split('#')[0]] = item.split('#')[1];
|
||||
});
|
||||
return $.base.onConfirm(elem.dataset.confirm, function () {
|
||||
return callabel.call(elem, data, elem, elem.dataset || {});
|
||||
});
|
||||
} else {
|
||||
return $.base.onConfirm(elem.dataset.confirm, function () {
|
||||
return callabel.call(elem, data, elem, elem.dataset || {});
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
/*! 消息组件实例 */
|
||||
$.msg = new function () {
|
||||
@ -173,32 +176,32 @@ $(function () {
|
||||
/*! 关闭消息框 */
|
||||
this.close = function (idx) {
|
||||
if (idx !== null) return layer.close(idx);
|
||||
for (var i in this.idx) $.msg.close(this.idx[i]);
|
||||
for (let i in this.idx) $.msg.close(this.idx[i]);
|
||||
return (this.idx = []) !== false;
|
||||
};
|
||||
/*! 弹出警告框 */
|
||||
this.alert = function (msg, call) {
|
||||
var idx = layer.alert(msg, {end: call, scrollbar: false});
|
||||
let idx = layer.alert(msg, {end: call, scrollbar: false});
|
||||
return $.msg.idx.push(idx), idx;
|
||||
};
|
||||
/*! 显示成功类型的消息 */
|
||||
this.success = function (msg, time, call) {
|
||||
var idx = layer.msg(msg, {icon: 1, shade: this.shade, scrollbar: false, end: call, time: (time || 2) * 1000, shadeClose: true});
|
||||
let idx = layer.msg(msg, {icon: 1, shade: this.shade, scrollbar: false, end: call, time: (time || 2) * 1000, shadeClose: true});
|
||||
return $.msg.idx.push(idx), idx;
|
||||
};
|
||||
/*! 显示失败类型的消息 */
|
||||
this.error = function (msg, time, call) {
|
||||
var idx = layer.msg(msg, {icon: 2, shade: this.shade, scrollbar: false, time: (time || 3) * 1000, end: call, shadeClose: true});
|
||||
let idx = layer.msg(msg, {icon: 2, shade: this.shade, scrollbar: false, time: (time || 3) * 1000, end: call, shadeClose: true});
|
||||
return $.msg.idx.push(idx), idx;
|
||||
};
|
||||
/*! 状态消息提示 */
|
||||
this.tips = function (msg, time, call) {
|
||||
var idx = layer.msg(msg, {time: (time || 3) * 1000, shade: this.shade, end: call, shadeClose: true});
|
||||
let idx = layer.msg(msg, {time: (time || 3) * 1000, shade: this.shade, end: call, shadeClose: true});
|
||||
return $.msg.idx.push(idx), idx;
|
||||
};
|
||||
/*! 显示加载提示 */
|
||||
this.loading = function (msg, call) {
|
||||
var idx = msg ? layer.msg(msg, {icon: 16, scrollbar: false, shade: this.shade, time: 0, end: call}) : layer.load(0, {time: 0, scrollbar: false, shade: this.shade, end: call});
|
||||
let idx = msg ? layer.msg(msg, {icon: 16, scrollbar: false, shade: this.shade, time: 0, end: call}) : layer.load(0, {time: 0, scrollbar: false, shade: this.shade, end: call});
|
||||
return $.msg.idx.push(idx), idx;
|
||||
};
|
||||
/*! Notify 调用入口 */
|
||||
@ -235,8 +238,8 @@ $(function () {
|
||||
};
|
||||
/*! 自动处理JSON数据 */
|
||||
this.auto = function (ret, time) {
|
||||
var url = ret.url || (typeof ret.data === 'string' ? ret.data : '');
|
||||
var msg = ret.msg || (typeof ret.info === 'string' ? ret.info : '');
|
||||
let url = ret.url || (typeof ret.data === 'string' ? ret.data : '');
|
||||
let msg = ret.msg || (typeof ret.info === 'string' ? ret.info : '');
|
||||
if (parseInt(ret.code) === 1 && time === 'false') {
|
||||
return url ? $.form.goto(url) : $.form.reload();
|
||||
} else return (parseInt(ret.code) === 1) ? this.success(msg, time, function () {
|
||||
@ -289,7 +292,7 @@ $(function () {
|
||||
this.load = function (url, data, method, callable, loading, tips, time, headers) {
|
||||
// 如果主页面 loader 显示中,绝对不显示 loading 图标
|
||||
loading = $('.layui-page-loader').is(':visible') ? false : loading;
|
||||
var loadidx = loading !== false ? $.msg.loading(tips) : 0;
|
||||
let loadidx = loading !== false ? $.msg.loading(tips) : 0;
|
||||
if (typeof data === 'object' && typeof data['_token_'] === 'string') {
|
||||
headers = headers || {}, headers['User-Form-Token'] = data['_token_'], delete data['_token_'];
|
||||
}
|
||||
@ -367,7 +370,7 @@ $(function () {
|
||||
type: 1, btn: false, area: area || "800px", resize: false, content: res, title: name || '', offset: offset || 'auto', success: function ($dom, idx) {
|
||||
typeof call === 'function' && call.call($.form, $dom);
|
||||
$.form.reInit($dom.off('click', '[data-close]').on('click', '[data-close]', function () {
|
||||
onConfirm(this.dataset.confirm, function () {
|
||||
$.base.onConfirm(this.dataset.confirm, function () {
|
||||
layer.close(idx);
|
||||
});
|
||||
}));
|
||||
@ -388,7 +391,7 @@ $(function () {
|
||||
/*! 通过 URI 查询最佳菜单 NODE */
|
||||
this.queryNode = function (uri, node) {
|
||||
if (!/^m-/.test(node = node || location.href.replace(/.*spm=([\d\-m]+).*/ig, '$1'))) {
|
||||
var $menu = $('[data-menu-node][data-open*="' + uri.replace(/\.html$/ig, '') + '"]');
|
||||
let $menu = $('[data-menu-node][data-open*="' + uri.replace(/\.html$/ig, '') + '"]');
|
||||
return $menu.size() ? $menu.get(0).dataset.menuNode : '';
|
||||
}
|
||||
return node;
|
||||
@ -404,14 +407,14 @@ $(function () {
|
||||
uri = this.getUri(uri);
|
||||
if (typeof vars.spm !== 'string') vars.spm = elem.dataset.menuNode || this.queryNode(uri) || '';
|
||||
if (typeof vars.spm !== 'string' || vars.spm.length < 1) delete vars.spm;
|
||||
for (var i in vars) attrs.push(i + '=' + vars[i]);
|
||||
for (let i in vars) attrs.push(i + '=' + vars[i]);
|
||||
return uri + (attrs.length > 0 ? '?' + attrs.join('&') : '');
|
||||
};
|
||||
/*! 后台菜单动作初始化 */
|
||||
this.listen = function () {
|
||||
var layout = $('.layui-layout-admin'), mclass = 'layui-layout-left-mini';
|
||||
let layout = $('.layui-layout-admin'), mclass = 'layui-layout-left-mini';
|
||||
/*! 菜单切及MiniTips处理 */
|
||||
onEvent('click', '[data-target-menu-type]', function () {
|
||||
$.base.onEvent('click', '[data-target-menu-type]', function () {
|
||||
layui.data('AdminMenuType', {key: 'mini', value: layout.toggleClass(mclass).hasClass(mclass)});
|
||||
}).on('click', '[data-submenu-layout]>a', function () {
|
||||
setTimeout("$.menu.sync(1)", 100);
|
||||
@ -433,7 +436,7 @@ $(function () {
|
||||
/*! 同步二级菜单展示状态 */
|
||||
this.sync = function (mode) {
|
||||
$('[data-submenu-layout]').map(function () {
|
||||
var node = this.dataset.submenuLayout;
|
||||
let node = this.dataset.submenuLayout;
|
||||
if (mode === 1) layui.data('AdminMenuState', {key: node, value: $(this).hasClass('layui-nav-itemed') ? 2 : 1}); else if (mode === 2) (layui.data('AdminMenuState')[node] || 2) === 2 && $(this).addClass('layui-nav-itemed');
|
||||
});
|
||||
};
|
||||
@ -444,7 +447,7 @@ $(function () {
|
||||
$.form.load(hash, {}, 'get', false, !$.msg.page.stat()), $.menu.sync(2);
|
||||
/*! 菜单选择切换 */
|
||||
if (/^m-/.test(node = node || $.menu.queryNode($.menu.getUri()))) {
|
||||
var arr = node.split('-'), tmp = arr.shift(), $all = $('a[data-menu-node]').parent('.layui-this');
|
||||
let arr = node.split('-'), tmp = arr.shift(), $all = $('a[data-menu-node]').parent('.layui-this');
|
||||
while (arr.length > 0) {
|
||||
tmp = tmp + '-' + arr.shift();
|
||||
$all = $all.not($('a[data-menu-node="' + tmp + '"]').parent().addClass('layui-this'));
|
||||
@ -452,7 +455,7 @@ $(function () {
|
||||
$all.removeClass('layui-this');
|
||||
/*! 菜单模式切换 */
|
||||
if (node.split('-').length > 2) {
|
||||
var _tmp = node.split('-'), _node = _tmp.shift() + '-' + _tmp.shift();
|
||||
let _tmp = node.split('-'), _node = _tmp.shift() + '-' + _tmp.shift();
|
||||
$('[data-menu-layout]').not($('[data-menu-layout="' + _node + '"]').removeClass('layui-hide')).addClass('layui-hide');
|
||||
$('[data-menu-node="' + node + '"]').parent().parent().parent().addClass('layui-nav-itemed');
|
||||
$('.layui-layout-admin').removeClass('layui-layout-left-hide');
|
||||
@ -466,15 +469,15 @@ $(function () {
|
||||
|
||||
/*! 表单转JSON */
|
||||
$.fn.formToJson = function () {
|
||||
var self = this, data = {}, push = {};
|
||||
var rules = {key: /\w+|(?=\[])/g, push: /^$/, fixed: /^\d+$/, named: /^\w+$/};
|
||||
let self = this, data = {}, push = {};
|
||||
let rules = {key: /\w+|(?=\[])/g, push: /^$/, fixed: /^\d+$/, named: /^\w+$/};
|
||||
this.build = function (base, key, value) {
|
||||
return (base[key] = value), base;
|
||||
}, this.pushCounter = function (name) {
|
||||
if (push[name] === undefined) push[name] = 0;
|
||||
return push[name]++;
|
||||
}, $.each($(this).serializeArray(), function () {
|
||||
var key, keys = this.name.match(rules.key), merge = this.value, name = this.name;
|
||||
let key, keys = this.name.match(rules.key), merge = this.value, name = this.name;
|
||||
while ((key = keys.pop()) !== undefined) {
|
||||
name = name.replace(new RegExp("\\[" + key + "\\]$"), '');
|
||||
if (key.match(rules.push)) merge = self.build([], self.pushCounter(name), merge);
|
||||
@ -503,8 +506,8 @@ $(function () {
|
||||
$.fn.uploadOneVideo = function () {
|
||||
return this.each(function () {
|
||||
if (this.dataset.inited) return; else this.dataset.inited = 'true';
|
||||
var $bt = $('<div class="uploadimage uploadvideo"><span><a data-file class="layui-icon layui-icon-upload-drag"></a><i class="layui-icon layui-icon-search"></i><i class="layui-icon layui-icon-close"></i></span><span data-file></span></div>');
|
||||
var $in = $(this).on('change', function () {
|
||||
let $bt = $('<div class="uploadimage uploadvideo"><span><a data-file class="layui-icon layui-icon-upload-drag"></a><i class="layui-icon layui-icon-search"></i><i class="layui-icon layui-icon-close"></i></span><span data-file></span></div>');
|
||||
let $in = $(this).on('change', function () {
|
||||
if (this.value) $bt.css('backgroundImage', 'url("")').find('span[data-file]').html('<video width="100%" height="100%" autoplay loop muted><source src="' + encodeURI(this.value) + '" type="video/mp4"></video>');
|
||||
}).after($bt).trigger('change');
|
||||
$bt.on('click', 'i.layui-icon-search', function (event) {
|
||||
@ -521,8 +524,8 @@ $(function () {
|
||||
$.fn.uploadOneImage = function () {
|
||||
return this.each(function () {
|
||||
if (this.dataset.inited) return; else this.dataset.inited = 'true';
|
||||
var $bt = $('<div class="uploadimage"><span><a data-file class="layui-icon layui-icon-upload-drag"></a><i class="layui-icon layui-icon-search"></i><i class="layui-icon layui-icon-close"></i></span><span data-file="image"></span></div>');
|
||||
var $in = $(this).on('change', function () {
|
||||
let $bt = $('<div class="uploadimage"><span><a data-file class="layui-icon layui-icon-upload-drag"></a><i class="layui-icon layui-icon-search"></i><i class="layui-icon layui-icon-close"></i></span><span data-file="image"></span></div>');
|
||||
let $in = $(this).on('change', function () {
|
||||
if (this.value) $bt.css('backgroundImage', 'url(' + encodeURI(this.value) + ')');
|
||||
}).after($bt).trigger('change');
|
||||
$bt.on('click', 'i.layui-icon-search', function (event) {
|
||||
@ -541,8 +544,8 @@ $(function () {
|
||||
$.fn.uploadMultipleImage = function () {
|
||||
return this.each(function () {
|
||||
if (this.dataset.inited) return; else this.dataset.inited = 'true';
|
||||
var $bt = $('<div class="uploadimage"><span><a data-file="mul" class="layui-icon layui-icon-upload-drag"></a></span><span data-file="images"></span></div>');
|
||||
var ims = this.value ? this.value.split('|') : [], $in = $(this).after($bt);
|
||||
let $bt = $('<div class="uploadimage"><span><a data-file="mul" class="layui-icon layui-icon-upload-drag"></a></span><span data-file="images"></span></div>');
|
||||
let ims = this.value ? this.value.split('|') : [], $in = $(this).after($bt);
|
||||
$bt.find('[data-file]').attr({
|
||||
'data-path': $in.data('path') || '', 'data-size': $in.data('size') || 0, 'data-type': $in.data('type') || 'gif,png,jpg,jpeg',
|
||||
'data-max-width': $in.data('max-width') || 0, 'data-max-height': $in.data('max-height') || 0,
|
||||
@ -571,9 +574,9 @@ $(function () {
|
||||
/*! 标签输入插件 */
|
||||
$.fn.initTagInput = function () {
|
||||
return this.each(function () {
|
||||
var $this = $(this), tags = this.value ? this.value.split(',') : [];
|
||||
var $text = $('<textarea class="layui-input layui-input-inline layui-tag-input"></textarea>');
|
||||
var $tags = $('<div class="layui-tags"></div>').append($text);
|
||||
let $this = $(this), tags = this.value ? this.value.split(',') : [];
|
||||
let $text = $('<textarea class="layui-input layui-input-inline layui-tag-input"></textarea>');
|
||||
let $tags = $('<div class="layui-tags"></div>').append($text);
|
||||
$this.parent().append($tags) && $text.off('keydown blur') && (tags.length > 0 && showTags(tags));
|
||||
$text.on('blur keydown', function (event, value) {
|
||||
if (event.keyCode === 13 || event.type === 'blur') {
|
||||
@ -599,10 +602,10 @@ $(function () {
|
||||
return this.each(function () {
|
||||
this.focus();
|
||||
if (document.selection) {
|
||||
var selection = document.selection.createRange();
|
||||
let selection = document.selection.createRange();
|
||||
(selection.text = value), selection.select(), selection.unselect();
|
||||
} else if (this.selectionStart || this.selectionStart === 0) {
|
||||
var spos = this.selectionStart, apos = this.selectionEnd || spos;
|
||||
let spos = this.selectionStart, apos = this.selectionEnd || spos;
|
||||
this.value = this.value.substring(0, spos) + value + this.value.substring(apos);
|
||||
this.selectionEnd = this.selectionStart = spos + value.length;
|
||||
} else {
|
||||
@ -633,14 +636,14 @@ $(function () {
|
||||
}, this.create = function (table, params) {
|
||||
// 动态初始化表格
|
||||
table.id = table.id || 't' + Math.random().toString().replace('.', '');
|
||||
var $table = $(table).attr('lay-filter', table.dataset.id = table.getAttribute('lay-filter') || table.id);
|
||||
let $table = $(table).attr('lay-filter', table.dataset.id = table.getAttribute('lay-filter') || table.id);
|
||||
// 插件初始化参数
|
||||
var option = params || {}, data = option.where || {}, sort = option.initSort || option.sort || {};
|
||||
let option = params || {}, data = option.where || {}, sort = option.initSort || option.sort || {};
|
||||
option.id = table.id, option.elem = table, option.url = params.url || table.dataset.url || location.href;
|
||||
option.limit = params.limit || 20, option.loading = params.loading !== false, option.autoSort = params.autoSort === true;
|
||||
option.page = params.page !== false ? (params.page || true) : false, option.cols = params.cols || [[]], option.success = params.done || '';
|
||||
// 初始化不显示头部
|
||||
var cls = ['.layui-table-header', '.layui-table-fixed', '.layui-table-body', '.layui-table-page'];
|
||||
let cls = ['.layui-table-header', '.layui-table-fixed', '.layui-table-body', '.layui-table-page'];
|
||||
option.css = (option.css || '') + cls.join('{opacity:0}') + '{opacity:0}';
|
||||
// 默认动态设置页数, 动态设置最大高度
|
||||
if (option.page === true) option.page = {curr: layui.sessionData('pages')[option.id] || 1};
|
||||
@ -661,17 +664,17 @@ $(function () {
|
||||
res.data = params.filter(res.data, res);
|
||||
}
|
||||
if (!this.page || !this.page.curr) return res;
|
||||
var curp = this.page.curr, maxp = Math.ceil(res.count / option.limit);
|
||||
let curp = this.page.curr, maxp = Math.ceil(res.count / option.limit);
|
||||
if (curp > maxp && maxp > 1) $table.trigger('reload', {page: {curr: maxp}});
|
||||
return res;
|
||||
};
|
||||
// 关联搜索表单
|
||||
var sform, search = params.search || table.dataset.targetSearch;
|
||||
let sform, search = params.search || table.dataset.targetSearch;
|
||||
if (search) (sform = $body.find(search)).map(function () {
|
||||
$(this).attr('data-table-id', table.id);
|
||||
});
|
||||
// 关联绑定选择项
|
||||
var checked = params.checked || table.dataset.targetChecked;
|
||||
let checked = params.checked || table.dataset.targetChecked;
|
||||
if (checked) $body.find(checked).map(function () {
|
||||
$(this).attr('data-table-id', table.id);
|
||||
});
|
||||
@ -715,7 +718,7 @@ $(function () {
|
||||
|
||||
/*!格式化文件大小 */
|
||||
$.formatFileSize = function (size, fixed, units) {
|
||||
var unit;
|
||||
let unit;
|
||||
units = units || ['B', 'K', 'M', 'G', 'TB'];
|
||||
while ((unit = units.shift()) && size > 1024) size = size / 1024;
|
||||
return (unit === 'B' ? size : size.toFixed(fixed === undefined ? 2 : fixed)) + unit;
|
||||
@ -723,7 +726,7 @@ $(function () {
|
||||
|
||||
/*! 弹出图片层 */
|
||||
$.previewImage = function (src, area) {
|
||||
var img = new Image(), defer = $.Deferred(), loaded = $.msg.loading();
|
||||
let img = new Image(), defer = $.Deferred(), loaded = $.msg.loading();
|
||||
img.style.background = '#FFF', img.referrerPolicy = 'no-referrer';
|
||||
img.style.height = 'auto', img.style.width = area || '100%', img.style.display = 'none';
|
||||
return document.body.appendChild(img), img.onerror = function () {
|
||||
@ -741,7 +744,7 @@ $(function () {
|
||||
|
||||
/*! 以手机模式显示内容 */
|
||||
$.previewPhonePage = function (href, title) {
|
||||
var template = '<div class="mobile-preview"><div class="mobile-header">{{d.title}}</div><div class="mobile-body"><iframe src="{{d.url}}"></iframe></div></div>';
|
||||
let template = '<div class="mobile-preview"><div class="mobile-header">{{d.title}}</div><div class="mobile-body"><iframe src="{{d.url}}"></iframe></div></div>';
|
||||
layer.style(layer.open({type: true, resize: false, scrollbar: false, area: ['320px', '600px'], title: false, closeBtn: true, shadeClose: false, skin: 'layui-layer-nobg', content: laytpl(template).render({title: title || '公众号', url: href})}), {boxShadow: 'none'});
|
||||
};
|
||||
|
||||
@ -763,7 +766,7 @@ $(function () {
|
||||
$.vali = function (form, done, init) {
|
||||
require(['validate'], function (Validate) {
|
||||
/** @type {import("./plugs/admin/validate")|Validate}*/
|
||||
var vali = $(form).data('validate') || new Validate(form, onConfirm);
|
||||
let vali = $(form).data('validate') || new Validate(form);
|
||||
typeof init === 'function' && init.call(vali, $(form).formToJson(), vali);
|
||||
typeof done === 'function' && vali.addDoneEvent(done);
|
||||
});
|
||||
@ -771,13 +774,13 @@ $(function () {
|
||||
|
||||
/*! 自动监听表单 */
|
||||
$.vali.listen = function ($dom) {
|
||||
var $els = $($dom || $body).find('form[data-auto]');
|
||||
let $els = $($dom || $body).find('form[data-auto]');
|
||||
$dom && $($dom).filter('form[data-auto]') && $els.add($dom);
|
||||
return $els.map(function (idx, form) {
|
||||
$(this).vali(function (data) {
|
||||
var dset = form.dataset, type = form.method || 'POST', href = form.action || location.href;
|
||||
var tips = dset.tips || undefined, time = dset.time || undefined, taid = dset.tableId || false;
|
||||
var call = window[dset.callable || '_default_callable'] || (taid ? function (ret) {
|
||||
let dset = form.dataset, type = form.method || 'POST', href = form.action || location.href;
|
||||
let tips = dset.tips || undefined, time = dset.time || undefined, taid = dset.tableId || false;
|
||||
let call = window[dset.callable || '_default_callable'] || (taid ? function (ret) {
|
||||
if (typeof ret === 'object' && ret.code > 0 && $('#' + taid).size() > 0) {
|
||||
return $.msg.success(ret.info, 3, function () {
|
||||
$.msg.closeLastModal();
|
||||
@ -785,7 +788,7 @@ $(function () {
|
||||
}) && false;
|
||||
}
|
||||
} : undefined);
|
||||
onConfirm(dset.confirm, function () {
|
||||
$.base.onConfirm(dset.confirm, function () {
|
||||
$.form.load(href, data, type, call, true, tips, time);
|
||||
});
|
||||
});
|
||||
@ -793,13 +796,13 @@ $(function () {
|
||||
};
|
||||
|
||||
/*! 注册 data-search 表单搜索行为 */
|
||||
onEvent('submit', 'form.form-search', function () {
|
||||
$.base.onEvent('submit', 'form.form-search', function () {
|
||||
if (this.dataset.tableId) return $('table#' + this.dataset.tableId).trigger('reload', {
|
||||
page: {curr: 1}, where: $(this).formToJson()
|
||||
});
|
||||
var url = $(this).attr('action').replace(/&?page=\d+/g, '');
|
||||
let url = $(this).attr('action').replace(/&?page=\d+/g, '');
|
||||
if ((this.method || 'get').toLowerCase() === 'get') {
|
||||
var split = url.indexOf('?') > -1 ? '&' : '?', stype = location.href.indexOf('spm=') > -1 ? '#' : '';
|
||||
let split = url.indexOf('?') > -1 ? '&' : '?', stype = location.href.indexOf('spm=') > -1 ? '#' : '';
|
||||
$.form.goto(stype + $.menu.parseUri(url + split + $(this).serialize().replace(/\+/g, ' ')));
|
||||
} else {
|
||||
$.form.load(url, this, 'post');
|
||||
@ -807,13 +810,13 @@ $(function () {
|
||||
});
|
||||
|
||||
/*! 注册 data-file 事件行为 */
|
||||
onEvent('click', '[data-file]', function () {
|
||||
$.base.onEvent('click', '[data-file]', function () {
|
||||
this.id = this.dataset.id = this.id || (function (date) {
|
||||
return (date + Math.random()).replace('0.', '');
|
||||
})(layui.util.toDateString(Date.now(), 'yyyyMMddHHmmss-'));
|
||||
/*! 查找表单元素, 如果没有找到将不会自动写值 */
|
||||
if (!(this.$elem = $(this)).data('input') && this.$elem.data('field')) {
|
||||
var $input = $('input[name="' + this.$elem.data('field') + '"]:not([type=file])');
|
||||
let $input = $('input[name="' + this.$elem.data('field') + '"]:not([type=file])');
|
||||
this.$elem.data('input', $input.size() > 0 ? $input.get(0) : null);
|
||||
}
|
||||
// 单图或多图选择器 ( image|images )
|
||||
@ -827,45 +830,45 @@ $(function () {
|
||||
});
|
||||
|
||||
/*! 注册 data-load 事件行为 */
|
||||
onEvent('click', '[data-load]', function () {
|
||||
applyRuleValue(this, {}, function (data, elem, dset) {
|
||||
$.form.load(dset.load, data, 'get', onConfirm.getLoadCallable(dset.tableId), true, dset.tips, dset.time);
|
||||
$.base.onEvent('click', '[data-load]', function () {
|
||||
$.base.applyRuleValue(this, {}, function (data, elem, dset) {
|
||||
$.form.load(dset.load, data, 'get', $.base.onConfirm.getLoadCallable(dset.tableId), true, dset.tips, dset.time);
|
||||
});
|
||||
});
|
||||
|
||||
/*! 注册 data-reload 事件行为 */
|
||||
onEvent('click', '[data-reload]', function () {
|
||||
$.base.onEvent('click', '[data-reload]', function () {
|
||||
$.layTable.reload(this.dataset.tableId || true);
|
||||
});
|
||||
|
||||
/*! 注册 data-dbclick 事件行为 */
|
||||
onEvent('dblclick', '[data-dbclick]', function () {
|
||||
$.base.onEvent('dblclick', '[data-dbclick]', function () {
|
||||
$(this).find(this.dataset.dbclick || '[data-dbclick]').trigger('click');
|
||||
});
|
||||
|
||||
/*! 注册 data-check 事件行为 */
|
||||
onEvent('click', '[data-check-target]', function () {
|
||||
var target = this;
|
||||
$.base.onEvent('click', '[data-check-target]', function () {
|
||||
let target = this;
|
||||
$(this.dataset.checkTarget).map(function () {
|
||||
(this.checked = !!target.checked), $(this).trigger('change');
|
||||
});
|
||||
});
|
||||
|
||||
/*! 表单元素失去焦点时数字 */
|
||||
onEvent('blur', '[data-blur-number]', function () {
|
||||
var dset = this.dataset, min = dset.valueMin, max = dset.valueMax;
|
||||
var value = parseFloat(this.value) || 0, fiexd = parseInt(dset.blurNumber || 0);
|
||||
$.base.onEvent('blur', '[data-blur-number]', function () {
|
||||
let dset = this.dataset, min = dset.valueMin, max = dset.valueMax;
|
||||
let value = parseFloat(this.value) || 0, fiexd = parseInt(dset.blurNumber || 0);
|
||||
if (typeof min !== 'undefined' && value < min) value = min;
|
||||
if (typeof max !== 'undefined' && value > max) value = max;
|
||||
this.value = parseFloat(value).toFixed(fiexd);
|
||||
});
|
||||
|
||||
/*! 表单元素失焦时提交 */
|
||||
onEvent('blur', '[data-action-blur],[data-blur-action]', function () {
|
||||
var that = $(this), dset = this.dataset, data = {'_token_': dset.token || dset.csrf || '--'};
|
||||
var attrs = (dset.value || '').replace('{value}', that.val()).split(';');
|
||||
for (var i in attrs) data[attrs[i].split('#')[0]] = attrs[i].split('#')[1];
|
||||
onConfirm(dset.confirm, function () {
|
||||
$.base.onEvent('blur', '[data-action-blur],[data-blur-action]', function () {
|
||||
let that = $(this), dset = this.dataset, data = {'_token_': dset.token || dset.csrf || '--'};
|
||||
let attrs = (dset.value || '').replace('{value}', that.val()).split(';');
|
||||
for (let i in attrs) data[attrs[i].split('#')[0]] = attrs[i].split('#')[1];
|
||||
$.base.onConfirm(dset.confirm, function () {
|
||||
$.form.load(dset.actionBlur || dset.blurAction, data, dset.method || 'post', function (ret) {
|
||||
return that.css('border', (ret && ret.code) ? '1px solid #e6e6e6' : '1px solid red') && false;
|
||||
}, dset.loading !== 'false', dset.loading, dset.time);
|
||||
@ -873,14 +876,14 @@ $(function () {
|
||||
});
|
||||
|
||||
/*! 注册 data-href 事件行为 */
|
||||
onEvent('click', '[data-href]', function () {
|
||||
$.base.onEvent('click', '[data-href]', function () {
|
||||
if (this.dataset.href && this.dataset.href.indexOf('#') !== 0) {
|
||||
$.form.goto(this.dataset.href);
|
||||
}
|
||||
});
|
||||
|
||||
/*! 注册 data-open 事件行为 */
|
||||
onEvent('click', '[data-open]', function () {
|
||||
$.base.onEvent('click', '[data-open]', function () {
|
||||
layui.sessionData('pages', null);
|
||||
if (this.dataset.open.match(/^https?:/)) {
|
||||
$.form.goto(this.dataset.open);
|
||||
@ -890,27 +893,27 @@ $(function () {
|
||||
});
|
||||
|
||||
/*! 注册 data-action 事件行为 */
|
||||
onEvent('click', '[data-action]', function () {
|
||||
applyRuleValue(this, {}, function (data, elem, dset) {
|
||||
$.base.onEvent('click', '[data-action]', function () {
|
||||
$.base.applyRuleValue(this, {}, function (data, elem, dset) {
|
||||
Object.assign(data, {'_token_': dset.token || dset.csrf || '--'})
|
||||
var load = dset.loading !== 'false', tips = typeof load === 'string' ? load : undefined;
|
||||
$.form.load(dset.action, data, dset.method || 'post', onConfirm.getLoadCallable(dset.tableId), load, tips, dset.time)
|
||||
let load = dset.loading !== 'false', tips = typeof load === 'string' ? load : undefined;
|
||||
$.form.load(dset.action, data, dset.method || 'post', $.base.onConfirm.getLoadCallable(dset.tableId), load, tips, dset.time)
|
||||
});
|
||||
});
|
||||
|
||||
/*! 注册 data-modal 事件行为 */
|
||||
onEvent('click', '[data-modal]', function () {
|
||||
applyRuleValue(this, {open_type: 'modal'}, function (data, elem, dset) {
|
||||
$.base.onEvent('click', '[data-modal]', function () {
|
||||
$.base.applyRuleValue(this, {open_type: 'modal'}, function (data, elem, dset) {
|
||||
return $.form.modal(dset.modal, data, dset.title || this.innerText || '编辑', undefined, undefined, undefined, dset.area || dset.width || '800px', dset.offset || 'auto', dset.full !== undefined);
|
||||
});
|
||||
});
|
||||
|
||||
/*! 注册 data-iframe 事件行为 */
|
||||
onEvent('click', '[data-iframe]', function () {
|
||||
applyRuleValue(this, {open_type: 'iframe'}, function (data, elem, dset) {
|
||||
var name = dset.title || this.innerText || 'IFRAME 窗口';
|
||||
var area = dset.area || [dset.width || '800px', dset.height || '580px'];
|
||||
var frame = dset.iframe + (dset.iframe.indexOf('?') > -1 ? '&' : '?') + $.param(data);
|
||||
$.base.onEvent('click', '[data-iframe]', function () {
|
||||
$.base.applyRuleValue(this, {open_type: 'iframe'}, function (data, elem, dset) {
|
||||
let name = dset.title || this.innerText || 'IFRAME 窗口';
|
||||
let area = dset.area || [dset.width || '800px', dset.height || '580px'];
|
||||
let frame = dset.iframe + (dset.iframe.indexOf('?') > -1 ? '&' : '?') + $.param(data);
|
||||
$(this).attr('data-index', $.form.iframe(frame + '&' + $.param(data), name, area, dset.offset || 'auto', function () {
|
||||
typeof dset.refresh !== 'undefined' && $.layTable.reload(dset.tableId || true);
|
||||
}, undefined, dset.full !== undefined));
|
||||
@ -918,7 +921,7 @@ $(function () {
|
||||
});
|
||||
|
||||
/*! 注册 data-video-player 事件行为 */
|
||||
onEvent('click', '[data-video-player]', function () {
|
||||
$.base.onEvent('click', '[data-video-player]', function () {
|
||||
let idx = $.msg.loading(), url = this.dataset.videoPlayer, name = this.dataset.title || '媒体播放器', payer;
|
||||
require(['artplayer'], function () {
|
||||
layer.open({
|
||||
@ -937,27 +940,27 @@ $(function () {
|
||||
});
|
||||
|
||||
/*! 注册 data-icon 事件行为 */
|
||||
onEvent('click', '[data-icon]', function () {
|
||||
var location = tapiRoot + '/api.plugs/icon', field = this.dataset.icon || this.dataset.field || 'icon';
|
||||
$.base.onEvent('click', '[data-icon]', function () {
|
||||
let location = tapiRoot + '/api.plugs/icon', field = this.dataset.icon || this.dataset.field || 'icon';
|
||||
$.form.iframe(location + (location.indexOf('?') > -1 ? '&' : '?') + 'field=' + field, '图标选择', ['900px', '700px']);
|
||||
});
|
||||
|
||||
/*! 注册 data-copy 事件行为 */
|
||||
onEvent('click', '[data-copy]', function () {
|
||||
var copy = this.dataset.copy || this.innerText;
|
||||
$.base.onEvent('click', '[data-copy]', function () {
|
||||
let copy = this.dataset.copy || this.innerText;
|
||||
if (window.clipboardData) {
|
||||
window.clipboardData.setData('text', copy);
|
||||
$.msg.tips('已复制到剪贴板!');
|
||||
} else {
|
||||
var $input = $('<textarea readonly></textarea>');
|
||||
let $input = $('<textarea readonly></textarea>');
|
||||
$input.css({position: 'fixed', top: '-500px'}).appendTo($body).val(copy).select();
|
||||
$.msg.tips(document.execCommand('Copy') ? '已复制到剪贴板!' : '请使用鼠标操作复制!') && $input.remove();
|
||||
}
|
||||
});
|
||||
|
||||
/*! 异步任务状态监听与展示 */
|
||||
onEvent('click', '[data-queue]', function () {
|
||||
applyRuleValue(this, {}, function (data, elem, dset) {
|
||||
$.base.onEvent('click', '[data-queue]', function () {
|
||||
$.base.applyRuleValue(this, {}, function (data, elem, dset) {
|
||||
$.form.load(dset.queue, data, 'post', function (ret) {
|
||||
if (typeof ret.data === 'string' && ret.data.indexOf('Q') === 0) {
|
||||
return $.loadQueue(ret.data, true, elem), false;
|
||||
@ -967,17 +970,17 @@ $(function () {
|
||||
});
|
||||
|
||||
/*! 注册 data-tips-text 事件行为 */
|
||||
onEvent('mouseenter', '[data-tips-text]', function () {
|
||||
var opts = {tips: [$(this).attr('data-tips-type') || 3, '#78BA32'], time: 0};
|
||||
var layidx = layer.tips($(this).attr('data-tips-text') || this.innerText, this, opts);
|
||||
$.base.onEvent('mouseenter', '[data-tips-text]', function () {
|
||||
let opts = {tips: [$(this).attr('data-tips-type') || 3, '#78BA32'], time: 0};
|
||||
let layidx = layer.tips($(this).attr('data-tips-text') || this.innerText, this, opts);
|
||||
$(this).off('mouseleave').on('mouseleave', function () {
|
||||
setTimeout("layer.close('" + layidx + "')", 100);
|
||||
});
|
||||
});
|
||||
|
||||
/*! 注册 data-tips-hover 事件行为 */
|
||||
onEvent('mouseenter', '[data-tips-image][data-tips-hover]', function () {
|
||||
var img = new Image(), ele = $(this);
|
||||
$.base.onEvent('mouseenter', '[data-tips-image][data-tips-hover]', function () {
|
||||
let img = new Image(), ele = $(this);
|
||||
if ((img.src = this.dataset.tipsImage || this.dataset.lazySrc || this.src)) {
|
||||
img.layopt = {anim: 5, time: 0, skin: 'layui-layer-image', isOutAnim: false, scrollbar: false};
|
||||
img.referrerPolicy = 'no-referrer', img.style.maxWidth = '260px', img.style.maxHeight = '260px';
|
||||
@ -988,7 +991,7 @@ $(function () {
|
||||
});
|
||||
|
||||
/*! 注册 data-tips-image 事件行为 */
|
||||
onEvent('click', '[data-tips-image]', function (event) {
|
||||
$.base.onEvent('click', '[data-tips-image]', function (event) {
|
||||
(event.items = [], event.$imgs = $(this).parent().find('[data-tips-image]')).map(function () {
|
||||
event.items.push({src: this.dataset.tipsImage || this.dataset.lazySrc || this.src});
|
||||
}) && layer.photos({
|
||||
@ -1000,18 +1003,18 @@ $(function () {
|
||||
});
|
||||
|
||||
/*! 注册 data-phone-view 事件行为 */
|
||||
onEvent('click', '[data-phone-view]', function () {
|
||||
$.base.onEvent('click', '[data-phone-view]', function () {
|
||||
$.previewPhonePage(this.dataset.phoneView || this.href);
|
||||
});
|
||||
|
||||
/*! 注册 data-target-submit 事件行为 */
|
||||
onEvent('click', '[data-target-submit]', function () {
|
||||
$.base.onEvent('click', '[data-target-submit]', function () {
|
||||
$(this.dataset.targetSubmit || 'form:last').submit();
|
||||
});
|
||||
|
||||
/*! 表单编辑返回操作 */
|
||||
onEvent('click', '[data-target-backup],[data-history-back]', function () {
|
||||
onConfirm(this.dataset.historyBack || this.dataset.targetBackup || '确定要返回上个页面吗?', function () {
|
||||
$.base.onEvent('click', '[data-target-backup],[data-history-back]', function () {
|
||||
$.base.onConfirm(this.dataset.historyBack || this.dataset.targetBackup || '确定要返回上个页面吗?', function () {
|
||||
history.back();
|
||||
});
|
||||
});
|
||||
|
@ -30,14 +30,14 @@ define(function () {
|
||||
|
||||
/*! 绑定导出的事件 */
|
||||
Excel.prototype.bind = function (done, filename) {
|
||||
var that = this;
|
||||
let that = this;
|
||||
this.options = {}; // {writeOpt: {bookSST: true}};
|
||||
$('body').off('click', '[data-form-export]').on('click', '[data-form-export]', function () {
|
||||
var form = $(this).parents('form');
|
||||
var name = this.dataset.filename || filename;
|
||||
var method = this.dataset.method || form.attr('method') || 'get';
|
||||
var location = this.dataset.excel || this.dataset.formExport || form.attr('action') || '';
|
||||
var sortType = $(this).attr('data-sort-type') || '', sortField = $(this).attr('data-sort-field') || '';
|
||||
let form = $(this).parents('form');
|
||||
let name = this.dataset.filename || filename;
|
||||
let method = this.dataset.method || form.attr('method') || 'get';
|
||||
let location = this.dataset.excel || this.dataset.formExport || form.attr('action') || '';
|
||||
let sortType = $(this).attr('data-sort-type') || '', sortField = $(this).attr('data-sort-field') || '';
|
||||
if (sortField.length > 0 && sortType.length > 0) {
|
||||
location += (location.indexOf('?') > -1 ? '&' : '?') + '_order_=' + sortType + '&_field_=' + sortField;
|
||||
}
|
||||
@ -56,7 +56,7 @@ define(function () {
|
||||
return (lists = []), LoadNextPage(1, 1), defer;
|
||||
|
||||
function LoadNextPage(curPage, maxPage, urlParams) {
|
||||
var proc = (curPage / maxPage * 100).toFixed(2);
|
||||
let proc = (curPage / maxPage * 100).toFixed(2);
|
||||
$('[data-upload-count]').html(proc > 100 ? '100.00' : proc);
|
||||
if (curPage > maxPage) return $.msg.close(loaded), defer.resolve(lists);
|
||||
urlParams = (url.indexOf('?') > -1 ? '&' : '?') + 'output=json¬_cache_limit=1&limit=100&page=' + curPage;
|
||||
@ -78,7 +78,7 @@ define(function () {
|
||||
*/
|
||||
Excel.prototype.withStyle = function (data, colsWidth, defaultWidth, defaultHeight) {
|
||||
// 自动计算列序
|
||||
var idx, colN = 0, defaC = {}, lastCol;
|
||||
let idx, colN = 0, defaC = {}, lastCol;
|
||||
for (idx in data[0]) defaC[lastCol = layui.excel.numToTitle(++colN)] = defaultWidth || 99;
|
||||
defaC[lastCol] = 160;
|
||||
|
||||
@ -109,7 +109,7 @@ define(function () {
|
||||
});
|
||||
|
||||
// 设置表格行宽高,需要设置最后的行或列宽高,否则部分不生效 ???
|
||||
var rowsC = {1: 33}, colsC = Object.assign({}, defaC, {A: 60}, colsWidth || {});
|
||||
let rowsC = {1: 33}, colsC = Object.assign({}, defaC, {A: 60}, colsWidth || {});
|
||||
rowsC[data.length] = defaultHeight || 28, this.options.extend = {
|
||||
'!cols': layui.excel.makeColConfig(colsC, defaultWidth || 99),
|
||||
'!rows': layui.excel.makeRowConfig(rowsC, defaultHeight || 28),
|
||||
@ -120,7 +120,7 @@ define(function () {
|
||||
|
||||
/*! 直接推送表格内容 */
|
||||
Excel.prototype.push = function (url, sheet, cols, filter) {
|
||||
var loaded, $input;
|
||||
let loaded, $input;
|
||||
$input = $('<input class="layui-hide" type="file" accept="application/vnd.ms-excel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet">');
|
||||
$input.appendTo($('body')).click().on('change', function (event) {
|
||||
if (!event.target.files || event.target.files.length < 1) return $.msg.tips('没有可操作文件');
|
||||
@ -129,7 +129,7 @@ define(function () {
|
||||
// 导入Excel数据,并逐行上传处理
|
||||
layui.excel.importExcel(event.target.files, {}, function (data) {
|
||||
if (!data[0][sheet]) return $.msg.tips('未读取到表[' + sheet + ']的数据');
|
||||
var _cols = {}, _data = data[0][sheet], items = [], row, col, key, item;
|
||||
let _cols = {}, _data = data[0][sheet], items = [], row, col, key, item;
|
||||
for (row in _data) if (parseInt(row) + 1 === parseInt(cols._ || '1')) {
|
||||
for (col in _data[row]) for (key in cols) if (_data[row][col] === cols[key]) _cols[key] = col;
|
||||
} else if (parseInt(row) + 1 > cols._ || 1) {
|
||||
@ -156,7 +156,7 @@ define(function () {
|
||||
$.form.reload();
|
||||
});
|
||||
} else {
|
||||
var proc = (idx * 100 / total).toFixed(2);
|
||||
let proc = (idx * 100 / total).toFixed(2);
|
||||
$('[data-load-count]').html((proc > 100 ? '100.00' : proc) + '%( 成功 ' + oks + ' 条, 失败 ' + ers + ' 条 )');
|
||||
/*! 单元数据过滤 */
|
||||
data = item;
|
||||
|
@ -14,7 +14,7 @@
|
||||
|
||||
define(function () {
|
||||
|
||||
var template = '<div class="padding-30 padding-bottom-0" data-queue-load="{{d.code}}"><div class="layui-elip notselect nowrap" data-message-title><b class="color-desc">...</b></div><div class="margin-top-15 layui-progress layui-progress-big" lay-showPercent="yes"><div class="layui-progress-bar transition" lay-percent="0.00%"></div></div>' + '<div class="margin-top-15"><code class="layui-textarea layui-bg-black border-0" style="resize:none;overflow:hidden;height:190px"></code></div></div>';
|
||||
let template = '<div class="padding-30 padding-bottom-0" data-queue-load="{{d.code}}"><div class="layui-elip notselect nowrap" data-message-title><b class="color-desc">...</b></div><div class="margin-top-15 layui-progress layui-progress-big" lay-showPercent="yes"><div class="layui-progress-bar transition" lay-percent="0.00%"></div></div>' + '<div class="margin-top-15"><code class="layui-textarea layui-bg-black border-0" style="resize:none;overflow:hidden;height:190px"></code></div></div>';
|
||||
|
||||
return Queue;
|
||||
|
||||
@ -30,7 +30,7 @@ define(function () {
|
||||
}
|
||||
|
||||
function Progress($elem, code, queue, doScript) {
|
||||
var that = this;
|
||||
let that = this;
|
||||
|
||||
this.$box = $elem.find('[data-queue-load=' + code + ']');
|
||||
if (queue.doAjax === false || this.$box.length < 1) return false;
|
||||
@ -41,7 +41,7 @@ define(function () {
|
||||
|
||||
// 设置数据缓存
|
||||
this.SetCache = function (code, index, value) {
|
||||
var ckey = code + '_' + index, ctype = 'admin-queue-script';
|
||||
let ckey = code + '_' + index, ctype = 'admin-queue-script';
|
||||
return value !== undefined ? layui.data(ctype, {key: ckey, value: value}) : layui.data(ctype)[ckey] || 0;
|
||||
};
|
||||
|
||||
@ -72,9 +72,9 @@ define(function () {
|
||||
if (queue.doAjax === false || that.$box.length < 1) return false;
|
||||
$.form.load(tapiRoot + '/api.queue/progress', {code: code}, 'post', function (ret) {
|
||||
if (ret.code) {
|
||||
var lines = [];
|
||||
for (var idx in ret.data.history) {
|
||||
var line = ret.data.history[idx], percent = '[ ' + line.progress + '% ] ';
|
||||
let lines = [];
|
||||
for (let idx in ret.data.history) {
|
||||
let line = ret.data.history[idx], percent = '[ ' + line.progress + '% ] ';
|
||||
if (line.message.indexOf('javascript:') === -1) {
|
||||
lines.push(line.message.indexOf('>>>') > -1 ? line.message : percent + line.message);
|
||||
} else if (!that.SetCache(code, idx) && doScript !== false) {
|
||||
|
@ -16,8 +16,8 @@ define(function () {
|
||||
|
||||
return Validate;
|
||||
|
||||
function Validate(form, onConfirm) {
|
||||
var that = this;
|
||||
function Validate(form) {
|
||||
let that = this;
|
||||
// 绑定表单元素
|
||||
this.form = $(form);
|
||||
// 绑定元素事件
|
||||
@ -48,7 +48,7 @@ define(function () {
|
||||
return new RegExp(pattern, 'i').test(value);
|
||||
};
|
||||
this.hasProp = function (el, prop) {
|
||||
var attrProp = el.getAttribute(prop);
|
||||
let attrProp = el.getAttribute(prop);
|
||||
return typeof attrProp !== 'undefined' && attrProp !== null && attrProp !== false;
|
||||
};
|
||||
this.hasCheck = function (el, type) {
|
||||
@ -57,7 +57,7 @@ define(function () {
|
||||
return $.inArray(type, ['file', 'reset', 'image', 'radio', 'checkbox', 'submit', 'hidden']) < 0;
|
||||
};
|
||||
this.checkAllInput = function () {
|
||||
var status = true;
|
||||
let status = true;
|
||||
return this.form.find(this.tags).each(function () {
|
||||
!that.checkInput(this) && status && (status = !$(this).focus());
|
||||
}) && status;
|
||||
@ -103,12 +103,12 @@ define(function () {
|
||||
/* 检查所有表单元素是否通过H5的规则验证 */
|
||||
if (that.checkAllInput() && that.dones.length > 0) {
|
||||
if (typeof CKEDITOR === 'object' && typeof CKEDITOR.instances === 'object') {
|
||||
for (var i in CKEDITOR.instances) CKEDITOR.instances[i].updateElement();
|
||||
for (let i in CKEDITOR.instances) CKEDITOR.instances[i].updateElement();
|
||||
}
|
||||
/* 触发表单提交后,锁定三秒不能再次提交表单 */
|
||||
if (that.form.attr('submit-locked')) return false;
|
||||
evt.submit = that.form.find('button[type=submit],button:not([type=button])');
|
||||
onConfirm(evt.submit.attr('data-confirm'), function () {
|
||||
$.base.onConfirm(evt.submit.attr('data-confirm'), function () {
|
||||
that.form.attr('submit-locked', 1) && evt.submit.addClass('submit-button-loading');
|
||||
setTimeout(function () {
|
||||
that.form.removeAttr('submit-locked') && evt.submit.removeClass('submit-button-loading');
|
||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -15,9 +15,58 @@
|
||||
// | github 代码仓库:https://github.com/zoujingli/think-plugs-static
|
||||
// +----------------------------------------------------------------------
|
||||
|
||||
// 新样式
|
||||
// .flex-x
|
||||
// .flex-x-center
|
||||
// .flex-y
|
||||
// .flex-y-center
|
||||
// .flex-center
|
||||
// .flex-between
|
||||
|
||||
.flex {
|
||||
#flex();
|
||||
|
||||
each(range(5), {
|
||||
&-@{value} {
|
||||
flex: @value;
|
||||
}
|
||||
});
|
||||
|
||||
&-x {
|
||||
#flex();
|
||||
height: 100%;
|
||||
#flexDirection(row);
|
||||
|
||||
&-center {
|
||||
#flex();
|
||||
height: 100%;
|
||||
#flexAlign(center)
|
||||
}
|
||||
}
|
||||
|
||||
&-y {
|
||||
#flex();
|
||||
width: 100%;
|
||||
#flexDirection(column);
|
||||
|
||||
&-center {
|
||||
#flex();
|
||||
width: 100%;
|
||||
#flexJustify(center);
|
||||
}
|
||||
}
|
||||
|
||||
&-center {
|
||||
#flex();
|
||||
#flexAlign(center);
|
||||
#flexJustify(center);
|
||||
}
|
||||
|
||||
&-between {
|
||||
#flex();
|
||||
justify-content: space-between;
|
||||
}
|
||||
|
||||
&-inline {
|
||||
display: inline-flex;
|
||||
}
|
||||
@ -96,26 +145,6 @@
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
&-1 {
|
||||
flex: 1;
|
||||
}
|
||||
|
||||
&-2 {
|
||||
flex: 2;
|
||||
}
|
||||
|
||||
&-3 {
|
||||
flex: 3;
|
||||
}
|
||||
|
||||
&-4 {
|
||||
flex: 4;
|
||||
}
|
||||
|
||||
&-5 {
|
||||
flex: 5;
|
||||
}
|
||||
}
|
||||
|
||||
.fixed {
|
||||
@ -956,7 +985,7 @@ input:not(.layui-hide,[type=hidden]) {
|
||||
height: 240px;
|
||||
}
|
||||
|
||||
.layui-btn:not([type=button]) {
|
||||
button.layui-btn:not([type=button]) {
|
||||
overflow: hidden;
|
||||
position: relative;
|
||||
|
||||
@ -1409,23 +1438,23 @@ label.think-checkbox {
|
||||
|
||||
.sub-span- {
|
||||
&red span {
|
||||
color: #e44 !important
|
||||
color: #e44
|
||||
}
|
||||
|
||||
&blue span {
|
||||
color: #29f !important
|
||||
color: #29f
|
||||
}
|
||||
|
||||
&desc span {
|
||||
color: #999 !important
|
||||
color: #999
|
||||
}
|
||||
|
||||
&text span {
|
||||
color: #333 !important
|
||||
color: #333
|
||||
}
|
||||
|
||||
&green span {
|
||||
color: #090 !important
|
||||
color: #090
|
||||
}
|
||||
}
|
||||
|
||||
@ -1443,23 +1472,23 @@ label.think-checkbox {
|
||||
}
|
||||
|
||||
&red b {
|
||||
color: #ec494e !important
|
||||
color: #ec494e
|
||||
}
|
||||
|
||||
&blue b {
|
||||
color: #2494f2 !important
|
||||
color: #2494f2
|
||||
}
|
||||
|
||||
&desc b {
|
||||
color: #999 !important
|
||||
color: #999
|
||||
}
|
||||
|
||||
&text b {
|
||||
color: #333 !important
|
||||
color: #333
|
||||
}
|
||||
|
||||
&green b {
|
||||
color: #090 !important
|
||||
color: #090
|
||||
}
|
||||
}
|
||||
|
||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
Binary file not shown.
BIN
public/static/theme/css/font/iconfont.woff
Normal file
BIN
public/static/theme/css/font/iconfont.woff
Normal file
Binary file not shown.
BIN
public/static/theme/css/font/iconfont.woff2
Normal file
BIN
public/static/theme/css/font/iconfont.woff2
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -1 +1 @@
|
||||
@charset "UTF-8";@font-face{font-family:iconfont;src:url(./icon/iconfont.woff2?t=2021) format('woff2'),url(./icon/iconfont.woff?t=2021) format('woff'),url(./icon/iconfont.ttf?t=2021) format('truetype')}.iconfont{font-family:iconfont!important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.iconfont-shoplight:before{content:"\e7b8"}.iconfont-wxapp:before{content:"\e63c"}.iconfont-yinliang:before{content:"\e87a"}.iconfont-pick:before{content:"\e823"}.iconfont-camerarotate:before{content:"\e6f9"}.iconfont-phone_light:before{content:"\e826"}.iconfont-light:before{content:"\e6fa"}.iconfont-barcode:before{content:"\e6fb"}.iconfont-change:before{content:"\e829"}.iconfont-searchlist:before{content:"\e6fe"}.iconfont-down:before{content:"\e703"}.iconfont-countdown:before{content:"\e708"}.iconfont-notice:before{content:"\e70a"}.iconfont-upstage:before{content:"\e70f"}.iconfont-brand:before{content:"\e713"}.iconfont-choiceness:before{content:"\e715"}.iconfont-warn_light:before{content:"\e841"}.iconfont-creative:before{content:"\e719"}.iconfont-new:before{content:"\e71e"}.iconfont-cameraadd:before{content:"\e724"}.iconfont-at:before{content:"\e853"}.iconfont-mark:before{content:"\e731"}.iconfont-file:before{content:"\e739"}.iconfont-community:before{content:"\e741"}.iconfont-calendar:before{content:"\e74a"}.iconfont-cut:before{content:"\e74b"}.iconfont-tag:before{content:"\e752"}.iconfont-group:before{content:"\e753"}.iconfont-all:before{content:"\e755"}.iconfont-hot:before{content:"\e758"}.iconfont-upload:before{content:"\e75d"}.iconfont-safe:before{content:"\e769"}.iconfont-sponsor:before{content:"\e77d"}.iconfont-goodsfavor:before{content:"\e794"}.iconfont-musicfill:before{content:"\e795"}.iconfont-emojilight:before{content:"\e7a1"}.iconfont-appreciate:before{content:"\e644"}.iconfont-edit:before{content:"\e649"}.iconfont-favor:before{content:"\e64c"}.iconfont-phone:before{content:"\e652"}.iconfont-circle:before{content:"\e7b1"}.iconfont-taxi:before{content:"\e65d"}.iconfont-time:before{content:"\e65f"}.iconfont-mail:before{content:"\e7bd"}.iconfont-warn:before{content:"\e663"}.iconfont-camera:before{content:"\e665"}.iconfont-comment:before{content:"\e667"}.iconfont-medal:before{content:"\e7c2"}.iconfont-like:before{content:"\e669"}.iconfont-notification:before{content:"\e66b"}.iconfont-news:before{content:"\e7c6"}.iconfont-ask:before{content:"\e7ca"}.iconfont-evaluate:before{content:"\e672"}.iconfont-wang:before{content:"\e678"}.iconfont-moneybag:before{content:"\e7d1"}.iconfont-cascades:before{content:"\e67c"}.iconfont-discover:before{content:"\e67e"}.iconfont-subscription:before{content:"\e7d4"}.iconfont-list:before{content:"\e682"}.iconfont-scan:before{content:"\e689"}.iconfont-community_light:before{content:"\e7d7"}.iconfont-question:before{content:"\e691"}.iconfont-pic:before{content:"\e69b"}.iconfont-we_fill_light:before{content:"\e7de"}.iconfont-skin_light:before{content:"\e7df"}.iconfont-refund:before{content:"\e6ac"}.iconfont-cart:before{content:"\e6af"}.iconfont-qrcode:before{content:"\e6b0"}.iconfont-remind:before{content:"\e6b2"}.iconfont-hot_light:before{content:"\e7eb"}.iconfont-profile:before{content:"\e6b7"}.iconfont-comment_light:before{content:"\e7ef"}.iconfont-appreciate_light:before{content:"\e7f0"}.iconfont-message:before{content:"\e6bc"}.iconfont-wang_light:before{content:"\e7f4"}.iconfont-vip:before{content:"\e6c3"}.iconfont-weibo:before{content:"\e6c4"}.iconfont-goods_favor_light:before{content:"\e7f8"}.iconfont-activity:before{content:"\e6c5"}.iconfont-goods_new_light:before{content:"\e7fa"}.iconfont-goods_light:before{content:"\e7fb"}.iconfont-medal_light:before{content:"\e7fd"}.iconfont-news_light:before{content:"\e801"}.iconfont-explore:before{content:"\e6d2"}.iconfont-present:before{content:"\e6d3"}.iconfont-global_light:before{content:"\e808"}.iconfont-game:before{content:"\e6df"}.iconfont-redpacket:before{content:"\e6e0"}.iconfont-similar:before{content:"\e6e2"}.iconfont-furniture:before{content:"\e814"}.iconfont-dress:before{content:"\e815"}.iconfont-sports:before{content:"\e817"}.iconfont-location:before{content:"\e819"}.iconfont-recharge:before{content:"\e6ed"}.iconfont-vipcard:before{content:"\e6ee"}.iconfont-voice:before{content:"\e6ef"}.iconfont-voicefill:before{content:"\e6f0"}.iconfont-wifi:before{content:"\e6f2"}.iconfont-wefill:before{content:"\e6f4"}.iconfont-we:before{content:"\e6f5"}/*# sourceMappingURL=iconfont.css.map */
|
||||
@charset "UTF-8";@font-face{font-family:iconfont;src:url(./font/iconfont.woff2?t=2021) format('woff2'),url(./font/iconfont.woff?t=2021) format('woff'),url(./font/iconfont.ttf?t=2021) format('truetype')}.iconfont{font-family:iconfont,serif!important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.iconfont-logo:before{content:"\e607"}.iconfont-x7:before{content:"\e606"}.iconfont-x2:before{content:"\e600"}.iconfont-x1:before{content:"\e601"}.iconfont-x5:before{content:"\e602"}.iconfont-x4:before{content:"\e603"}.iconfont-x6:before{content:"\e604"}.iconfont-x3:before{content:"\e605"}.iconfont-shoplight:before{content:"\e7b8"}.iconfont-wxapp:before{content:"\e63c"}.iconfont-yinliang:before{content:"\e87a"}.iconfont-pick:before{content:"\e823"}.iconfont-camerarotate:before{content:"\e6f9"}.iconfont-phone_light:before{content:"\e826"}.iconfont-light:before{content:"\e6fa"}.iconfont-barcode:before{content:"\e6fb"}.iconfont-change:before{content:"\e829"}.iconfont-searchlist:before{content:"\e6fe"}.iconfont-down:before{content:"\e703"}.iconfont-countdown:before{content:"\e708"}.iconfont-notice:before{content:"\e70a"}.iconfont-upstage:before{content:"\e70f"}.iconfont-brand:before{content:"\e713"}.iconfont-choiceness:before{content:"\e715"}.iconfont-warn_light:before{content:"\e841"}.iconfont-creative:before{content:"\e719"}.iconfont-new:before{content:"\e71e"}.iconfont-cameraadd:before{content:"\e724"}.iconfont-at:before{content:"\e853"}.iconfont-mark:before{content:"\e731"}.iconfont-file:before{content:"\e739"}.iconfont-community:before{content:"\e741"}.iconfont-calendar:before{content:"\e74a"}.iconfont-cut:before{content:"\e74b"}.iconfont-tag:before{content:"\e752"}.iconfont-group:before{content:"\e753"}.iconfont-all:before{content:"\e755"}.iconfont-hot:before{content:"\e758"}.iconfont-upload:before{content:"\e75d"}.iconfont-safe:before{content:"\e769"}.iconfont-sponsor:before{content:"\e77d"}.iconfont-goodsfavor:before{content:"\e794"}.iconfont-musicfill:before{content:"\e795"}.iconfont-emojilight:before{content:"\e7a1"}.iconfont-appreciate:before{content:"\e644"}.iconfont-edit:before{content:"\e649"}.iconfont-favor:before{content:"\e64c"}.iconfont-phone:before{content:"\e652"}.iconfont-circle:before{content:"\e7b1"}.iconfont-taxi:before{content:"\e65d"}.iconfont-time:before{content:"\e65f"}.iconfont-mail:before{content:"\e7bd"}.iconfont-warn:before{content:"\e663"}.iconfont-camera:before{content:"\e665"}.iconfont-comment:before{content:"\e667"}.iconfont-medal:before{content:"\e7c2"}.iconfont-like:before{content:"\e669"}.iconfont-notification:before{content:"\e66b"}.iconfont-news:before{content:"\e7c6"}.iconfont-ask:before{content:"\e7ca"}.iconfont-evaluate:before{content:"\e672"}.iconfont-wang:before{content:"\e678"}.iconfont-moneybag:before{content:"\e7d1"}.iconfont-cascades:before{content:"\e67c"}.iconfont-discover:before{content:"\e67e"}.iconfont-subscription:before{content:"\e7d4"}.iconfont-list:before{content:"\e682"}.iconfont-scan:before{content:"\e689"}.iconfont-community_light:before{content:"\e7d7"}.iconfont-question:before{content:"\e691"}.iconfont-pic:before{content:"\e69b"}.iconfont-we_fill_light:before{content:"\e7de"}.iconfont-skin_light:before{content:"\e7df"}.iconfont-refund:before{content:"\e6ac"}.iconfont-cart:before{content:"\e6af"}.iconfont-qrcode:before{content:"\e6b0"}.iconfont-remind:before{content:"\e6b2"}.iconfont-hot_light:before{content:"\e7eb"}.iconfont-profile:before{content:"\e6b7"}.iconfont-comment_light:before{content:"\e7ef"}.iconfont-appreciate_light:before{content:"\e7f0"}.iconfont-message:before{content:"\e6bc"}.iconfont-wang_light:before{content:"\e7f4"}.iconfont-vip:before{content:"\e6c3"}.iconfont-weibo:before{content:"\e6c4"}.iconfont-goods_favor_light:before{content:"\e7f8"}.iconfont-activity:before{content:"\e6c5"}.iconfont-goods_new_light:before{content:"\e7fa"}.iconfont-goods_light:before{content:"\e7fb"}.iconfont-medal_light:before{content:"\e7fd"}.iconfont-news_light:before{content:"\e801"}.iconfont-explore:before{content:"\e6d2"}.iconfont-present:before{content:"\e6d3"}.iconfont-global_light:before{content:"\e808"}.iconfont-game:before{content:"\e6df"}.iconfont-redpacket:before{content:"\e6e0"}.iconfont-similar:before{content:"\e6e2"}.iconfont-furniture:before{content:"\e814"}.iconfont-dress:before{content:"\e815"}.iconfont-sports:before{content:"\e817"}.iconfont-location:before{content:"\e819"}.iconfont-recharge:before{content:"\e6ed"}.iconfont-vipcard:before{content:"\e6ee"}.iconfont-voice:before{content:"\e6ef"}.iconfont-voicefill:before{content:"\e6f0"}.iconfont-wifi:before{content:"\e6f2"}.iconfont-wefill:before{content:"\e6f4"}.iconfont-we:before{content:"\e6f5"}/*# sourceMappingURL=iconfont.css.map */
|
@ -1 +1 @@
|
||||
{"version":3,"sources":["iconfont.less"],"names":[],"mappings":"iBAgBA,WACE,YAAA,SACA,IAAS,kCACL,gBAAA,iCACA,eAAA,gCAFJ,mBAKF,UACE,YAAA,mBACA,UAAA,KACA,WAAA,OACA,uBAAA,YACA,wBAAA,UAGiB,2BACjB,QAAA,QAGa,uBACb,QAAA,QAGgB,0BAChB,QAAA,QAGY,sBACZ,QAAA,QAGoB,8BACpB,QAAA,QAGmB,6BACnB,QAAA,QAGa,uBACb,QAAA,QAGe,yBACf,QAAA,QAGc,wBACd,QAAA,QAGkB,4BAClB,QAAA,QAGY,sBACZ,QAAA,QAGiB,2BACjB,QAAA,QAGc,wBACd,QAAA,QAGe,yBACf,QAAA,QAGa,uBACb,QAAA,QAGkB,4BAClB,QAAA,QAGkB,4BAClB,QAAA,QAGgB,0BAChB,QAAA,QAGW,qBACX,QAAA,QAGiB,2BACjB,QAAA,QAGU,oBACV,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGiB,2BACjB,QAAA,QAGgB,0BAChB,QAAA,QAGW,qBACX,QAAA,QAGW,qBACX,QAAA,QAGa,uBACb,QAAA,QAGW,qBACX,QAAA,QAGW,qBACX,QAAA,QAGc,wBACd,QAAA,QAGY,sBACZ,QAAA,QAGe,yBACf,QAAA,QAGkB,4BAClB,QAAA,QAGiB,2BACjB,QAAA,QAGkB,4BAClB,QAAA,QAGkB,4BAClB,QAAA,QAGY,sBACZ,QAAA,QAGa,uBACb,QAAA,QAGa,uBACb,QAAA,QAGc,wBACd,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGc,wBACd,QAAA,QAGe,yBACf,QAAA,QAGa,uBACb,QAAA,QAGY,sBACZ,QAAA,QAGoB,8BACpB,QAAA,QAGY,sBACZ,QAAA,QAGW,qBACX,QAAA,QAGgB,0BAChB,QAAA,QAGY,sBACZ,QAAA,QAGgB,0BAChB,QAAA,QAGgB,0BAChB,QAAA,QAGgB,0BAChB,QAAA,QAGoB,8BACpB,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGuB,iCACvB,QAAA,QAGgB,0BAChB,QAAA,QAGW,qBACX,QAAA,QAGqB,+BACrB,QAAA,QAGkB,4BAClB,QAAA,QAGc,wBACd,QAAA,QAGY,sBACZ,QAAA,QAGc,wBACd,QAAA,QAGc,wBACd,QAAA,QAGiB,2BACjB,QAAA,QAGe,yBACf,QAAA,QAGqB,+BACrB,QAAA,QAGwB,kCACxB,QAAA,QAGe,yBACf,QAAA,QAGkB,4BAClB,QAAA,QAGW,qBACX,QAAA,QAGa,uBACb,QAAA,QAGyB,mCACzB,QAAA,QAGgB,0BAChB,QAAA,QAGuB,iCACvB,QAAA,QAGmB,6BACnB,QAAA,QAGmB,6BACnB,QAAA,QAGkB,4BAClB,QAAA,QAGe,yBACf,QAAA,QAGe,yBACf,QAAA,QAGoB,8BACpB,QAAA,QAGY,sBACZ,QAAA,QAGiB,2BACjB,QAAA,QAGe,yBACf,QAAA,QAGiB,2BACjB,QAAA,QAGa,uBACb,QAAA,QAGc,wBACd,QAAA,QAGgB,0BAChB,QAAA,QAGgB,0BAChB,QAAA,QAGe,yBACf,QAAA,QAGa,uBACb,QAAA,QAGiB,2BACjB,QAAA,QAGY,sBACZ,QAAA,QAGc,wBACd,QAAA,QAGU,oBACV,QAAA"}
|
||||
{"version":3,"sources":["iconfont.less"],"names":[],"mappings":"iBAgBA,WACE,YAAA,SACA,IAAS,kCAAqD,gBAAA,iCAAmD,eAAA,gCAAjH,mBAGF,UACE,YAAA,SAAA,gBACA,UAAA,KACA,WAAA,OACA,uBAAA,YACA,wBAAA,UAGY,sBACZ,QAAA,QAGU,oBACV,QAAA,QAGU,oBACV,QAAA,QAGU,oBACV,QAAA,QAGU,oBACV,QAAA,QAGU,oBACV,QAAA,QAGU,oBACV,QAAA,QAGU,oBACV,QAAA,QAGiB,2BACjB,QAAA,QAGa,uBACb,QAAA,QAGgB,0BAChB,QAAA,QAGY,sBACZ,QAAA,QAGoB,8BACpB,QAAA,QAGmB,6BACnB,QAAA,QAGa,uBACb,QAAA,QAGe,yBACf,QAAA,QAGc,wBACd,QAAA,QAGkB,4BAClB,QAAA,QAGY,sBACZ,QAAA,QAGiB,2BACjB,QAAA,QAGc,wBACd,QAAA,QAGe,yBACf,QAAA,QAGa,uBACb,QAAA,QAGkB,4BAClB,QAAA,QAGkB,4BAClB,QAAA,QAGgB,0BAChB,QAAA,QAGW,qBACX,QAAA,QAGiB,2BACjB,QAAA,QAGU,oBACV,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGiB,2BACjB,QAAA,QAGgB,0BAChB,QAAA,QAGW,qBACX,QAAA,QAGW,qBACX,QAAA,QAGa,uBACb,QAAA,QAGW,qBACX,QAAA,QAGW,qBACX,QAAA,QAGc,wBACd,QAAA,QAGY,sBACZ,QAAA,QAGe,yBACf,QAAA,QAGkB,4BAClB,QAAA,QAGiB,2BACjB,QAAA,QAGkB,4BAClB,QAAA,QAGkB,4BAClB,QAAA,QAGY,sBACZ,QAAA,QAGa,uBACb,QAAA,QAGa,uBACb,QAAA,QAGc,wBACd,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGc,wBACd,QAAA,QAGe,yBACf,QAAA,QAGa,uBACb,QAAA,QAGY,sBACZ,QAAA,QAGoB,8BACpB,QAAA,QAGY,sBACZ,QAAA,QAGW,qBACX,QAAA,QAGgB,0BAChB,QAAA,QAGY,sBACZ,QAAA,QAGgB,0BAChB,QAAA,QAGgB,0BAChB,QAAA,QAGgB,0BAChB,QAAA,QAGoB,8BACpB,QAAA,QAGY,sBACZ,QAAA,QAGY,sBACZ,QAAA,QAGuB,iCACvB,QAAA,QAGgB,0BAChB,QAAA,QAGW,qBACX,QAAA,QAGqB,+BACrB,QAAA,QAGkB,4BAClB,QAAA,QAGc,wBACd,QAAA,QAGY,sBACZ,QAAA,QAGc,wBACd,QAAA,QAGc,wBACd,QAAA,QAGiB,2BACjB,QAAA,QAGe,yBACf,QAAA,QAGqB,+BACrB,QAAA,QAGwB,kCACxB,QAAA,QAGe,yBACf,QAAA,QAGkB,4BAClB,QAAA,QAGW,qBACX,QAAA,QAGa,uBACb,QAAA,QAGyB,mCACzB,QAAA,QAGgB,0BAChB,QAAA,QAGuB,iCACvB,QAAA,QAGmB,6BACnB,QAAA,QAGmB,6BACnB,QAAA,QAGkB,4BAClB,QAAA,QAGe,yBACf,QAAA,QAGe,yBACf,QAAA,QAGoB,8BACpB,QAAA,QAGY,sBACZ,QAAA,QAGiB,2BACjB,QAAA,QAGe,yBACf,QAAA,QAGiB,2BACjB,QAAA,QAGa,uBACb,QAAA,QAGc,wBACd,QAAA,QAGgB,0BAChB,QAAA,QAGgB,0BAChB,QAAA,QAGe,yBACf,QAAA,QAGa,uBACb,QAAA,QAGiB,2BACjB,QAAA,QAGY,sBACZ,QAAA,QAGc,wBACd,QAAA,QAGU,oBACV,QAAA"}
|
@ -15,20 +15,50 @@
|
||||
// +----------------------------------------------------------------------
|
||||
|
||||
@font-face {
|
||||
font-family: "iconfont";
|
||||
src: url('./icon/iconfont.woff2?t=2021') format('woff2'),
|
||||
url('./icon/iconfont.woff?t=2021') format('woff'),
|
||||
url('./icon/iconfont.ttf?t=2021') format('truetype');
|
||||
font-family: iconfont;
|
||||
src: url('./font/iconfont.woff2?t=2021') format('woff2'), url('./font/iconfont.woff?t=2021') format('woff'), url('./font/iconfont.ttf?t=2021') format('truetype');
|
||||
}
|
||||
|
||||
.iconfont {
|
||||
font-family: "iconfont" !important;
|
||||
font-family: iconfont, serif !important;
|
||||
font-size: 16px;
|
||||
font-style: normal;
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
}
|
||||
|
||||
.iconfont-logo:before {
|
||||
content: "\e607";
|
||||
}
|
||||
|
||||
.iconfont-x7:before {
|
||||
content: "\e606";
|
||||
}
|
||||
|
||||
.iconfont-x2:before {
|
||||
content: "\e600";
|
||||
}
|
||||
|
||||
.iconfont-x1:before {
|
||||
content: "\e601";
|
||||
}
|
||||
|
||||
.iconfont-x5:before {
|
||||
content: "\e602";
|
||||
}
|
||||
|
||||
.iconfont-x4:before {
|
||||
content: "\e603";
|
||||
}
|
||||
|
||||
.iconfont-x6:before {
|
||||
content: "\e604";
|
||||
}
|
||||
|
||||
.iconfont-x3:before {
|
||||
content: "\e605";
|
||||
}
|
||||
|
||||
.iconfont-shoplight:before {
|
||||
content: "\e7b8";
|
||||
}
|
||||
@ -427,4 +457,4 @@
|
||||
|
||||
.iconfont-we:before {
|
||||
content: "\e6f5";
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user