mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2025-04-05 05:52:43 +08:00
fix: 同步更新代码
This commit is contained in:
parent
2b64663d98
commit
d31798def8
@ -108,11 +108,9 @@ class File extends Controller
|
||||
*/
|
||||
public function distinct()
|
||||
{
|
||||
$map = ['uuid' => AdminService::getUserId()];
|
||||
$db1 = SystemFile::mk()->fieldRaw('max(id) id')->where($map)->group('type,xkey');
|
||||
$db2 = $this->app->db->table($db1->buildSql())->alias('dt')->field('id');
|
||||
SystemFile::mk()->whereRaw("id not in {$db2->buildSql()}")->delete();
|
||||
SystemFile::mk()->where($map)->where(['status' => 1])->delete();
|
||||
$map = ['issafe' => 0, 'uuid' => AdminService::getUserId()];
|
||||
$subQuery = SystemFile::mk()->fieldRaw('MAX(id) AS id')->where($map)->group('type, xkey')->buildSql();
|
||||
SystemFile::mk()->where($map)->whereRaw("id NOT IN ({$subQuery})")->delete();
|
||||
$this->success('清理重复文件成功!');
|
||||
}
|
||||
}
|
@ -5,7 +5,7 @@
|
||||
<title>{block name="title"}{$title|default=''}{if !empty($title)} · {/if}{:sysconf('site_name')}{/block}</title>
|
||||
<meta name="renderer" content="webkit">
|
||||
<meta name="format-detection" content="telephone=no">
|
||||
<meta name="apple-mobile-web-app-capable" content="yes">
|
||||
<meta name="mobile-web-app-capable" content="yes">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||
<meta name="apple-mobile-web-app-status-bar-style" content="black">
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1">
|
||||
|
@ -24,7 +24,7 @@ define(['md5', 'notify'], function (SparkMD5, Notify, allowMime) {
|
||||
this.option.input = $(this.option.elem.data('input'))
|
||||
} else if (this.option.elem.data('field')) {
|
||||
this.option.input = $('input[name="' + this.option.elem.data('field') + '"]:not([type=file])');
|
||||
this.option.elem.data('input', this.option.input.size() > 0 ? this.option.input.get(0) : null);
|
||||
this.option.elem.data('input', this.option.input.length > 0 ? this.option.input.get(0) : null);
|
||||
}
|
||||
|
||||
/*! 文件选择筛选,使用 MIME 规则过滤文件列表 */
|
||||
|
@ -5,7 +5,7 @@
|
||||
<meta charset="utf-8">
|
||||
<meta name="renderer" content="webkit">
|
||||
<meta name="format-detection" content="telephone=no">
|
||||
<meta name="apple-mobile-web-app-capable" content="yes">
|
||||
<meta name="mobile-web-app-capable" content="yes">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||
<meta name="apple-mobile-web-app-status-bar-style" content="black">
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=0.4">
|
||||
|
@ -6,7 +6,7 @@
|
||||
<meta charset="utf-8">
|
||||
<meta name="renderer" content="webkit">
|
||||
<meta name="format-detection" content="telephone=no">
|
||||
<meta name="apple-mobile-web-app-capable" content="yes">
|
||||
<meta name="mobile-web-app-capable" content="yes">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||
<meta name="apple-mobile-web-app-status-bar-style" content="black">
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=0.4">
|
||||
|
@ -38,7 +38,6 @@ class Config extends Controller
|
||||
*/
|
||||
public function options()
|
||||
{
|
||||
$this->_applyFormToken();
|
||||
$this->thrNotify = sysuri('wechat/api.push/index', [], false, true);
|
||||
if ($this->request->isGet()) {
|
||||
try {
|
||||
@ -146,12 +145,15 @@ class Config extends Controller
|
||||
if ($this->request->isGet()) {
|
||||
$this->title = '微信支付配置';
|
||||
$local = LocalStorage::instance();
|
||||
$this->mch_ssl_cer = sysconf('wechat.mch_ssl_cer');
|
||||
$this->mch_ssl_key = sysconf('wechat.mch_ssl_key');
|
||||
$this->mch_ssl_p12 = sysconf('wechat.mch_ssl_p12');
|
||||
$this->data = sysdata('plugin.wechat.payment');
|
||||
$this->mch_ssl_cer = $this->data['mch_ssl_cer'] ?? '';
|
||||
$this->mch_ssl_key = $this->data['mch_ssl_key'] ?? '';
|
||||
$this->mch_ssl_p12 = $this->data['mch_ssl_p12'] ?? '';
|
||||
$this->mch_ssl_pay = $this->data['mch_ssl_pay'] ?? '';
|
||||
if (!$local->has($this->mch_ssl_cer, true)) $this->mch_ssl_cer = '';
|
||||
if (!$local->has($this->mch_ssl_key, true)) $this->mch_ssl_key = '';
|
||||
if (!$local->has($this->mch_ssl_p12, true)) $this->mch_ssl_p12 = '';
|
||||
if (!$local->has($this->mch_ssl_pay, true)) $this->mch_ssl_pay = '';
|
||||
$this->fetch();
|
||||
} else {
|
||||
$this->error('抱歉,数据提交地址错误!');
|
||||
@ -168,14 +170,19 @@ class Config extends Controller
|
||||
if ($this->request->isPost()) {
|
||||
$local = LocalStorage::instance();
|
||||
$wechat = $this->request->post('wechat');
|
||||
// if (empty($wechat['mch_pay_sid'])) {
|
||||
// $this->error('微信支付公钥序号为空!');
|
||||
// }
|
||||
// if (empty($wechat['mch_ssl_pay']) || !$local->has($wechat['mch_ssl_pay'], true)) {
|
||||
// $this->error('微信支付公钥不能为空!');
|
||||
// }
|
||||
// PEM 证书模式处理
|
||||
if ($wechat['mch_ssl_type'] === 'pem') {
|
||||
WechatService::withWxpayCert(['mch_id' => $wechat['mch_id']]);
|
||||
if (empty($wechat['mch_ssl_key']) || !$local->has($wechat['mch_ssl_key'], true)) {
|
||||
$this->error('商户证书 KEY 不能为空!');
|
||||
$this->error('商户证书密钥不能为空!');
|
||||
}
|
||||
if (empty($wechat['mch_ssl_cer']) || !$local->has($wechat['mch_ssl_cer'], true)) {
|
||||
$this->error('商户证书 CERT 不能为空!');
|
||||
$this->error('商户证书公钥不能为空!');
|
||||
}
|
||||
}
|
||||
// P12 证书模式转 PEM 模式
|
||||
@ -183,10 +190,9 @@ class Config extends Controller
|
||||
if (empty($wechat['mch_ssl_p12']) || !$local->has($wechat['mch_ssl_p12'], true)) {
|
||||
$this->error('商户证书 P12 不能为空!');
|
||||
}
|
||||
$content = $local->get($wechat['mch_ssl_p12'], true);
|
||||
if (openssl_pkcs12_read($content, $certs, $wechat['mch_id'])) {
|
||||
$name1 = "wxpay/{$wechat['mch_id']}_cer.pem";
|
||||
$name2 = "wxpay/{$wechat['mch_id']}_key.pem";
|
||||
if (openssl_pkcs12_read($local->get($wechat['mch_ssl_p12'], true), $certs, $wechat['mch_id'])) {
|
||||
$name1 = sprintf("wxpay/%s_%s_cer.pem", $wechat['mch_id'], md5($certs['cert']));
|
||||
$name2 = sprintf("wxpay/%s_%s_key.pem", $wechat['mch_id'], md5($certs['pkey']));
|
||||
$wechat['mch_ssl_cer'] = $local->set($name1, $certs['cert'], true)['url'];
|
||||
$wechat['mch_ssl_key'] = $local->set($name2, $certs['pkey'], true)['url'];
|
||||
$wechat['mch_ssl_type'] = 'pem';
|
||||
@ -200,11 +206,16 @@ class Config extends Controller
|
||||
'mch_id' => $wechat['mch_id'],
|
||||
'mch_key' => $wechat['mch_key'],
|
||||
'mch_v3_key' => $wechat['mch_v3_key'],
|
||||
'ssl_key_text' => $local->get($wechat['mch_ssl_key'], true),
|
||||
'mch_ssl_cer' => $wechat['mch_ssl_cer'],
|
||||
'mch_ssl_key' => $wechat['mch_ssl_key'],
|
||||
'mch_ssl_pay' => $wechat['mch_ssl_pay'],
|
||||
'mch_pay_sid' => $wechat['mch_pay_sid'] ?? '',
|
||||
'ssl_pay_text' => $local->get($wechat['mch_ssl_pay'], true),
|
||||
'ssl_cer_text' => $local->get($wechat['mch_ssl_cer'], true),
|
||||
'ssl_key_text' => $local->get($wechat['mch_ssl_key'], true),
|
||||
]);
|
||||
// 记录证书路径参数,兼容历史参数
|
||||
foreach ($wechat as $k => $v) sysconf("wechat.{$k}", $v);
|
||||
// 同步更新证书内容
|
||||
WechatService::withWxpayCert(['mch_id' => $wechat['mch_id']]);
|
||||
// 记录操作历史并返回保存结果
|
||||
sysoplog('微信支付配置', '修改微信支付配置成功');
|
||||
$this->success('微信支付配置成功!');
|
||||
|
@ -49,10 +49,10 @@ class WechatAuto extends Model
|
||||
{
|
||||
/**
|
||||
* 格式化创建时间
|
||||
* @param string $value
|
||||
* @param mixed $value
|
||||
* @return string
|
||||
*/
|
||||
public function getCreateAtAttr(string $value): string
|
||||
public function getCreateAtAttr($value): string
|
||||
{
|
||||
return format_datetime($value);
|
||||
}
|
||||
|
@ -49,10 +49,10 @@ class WechatKeys extends Model
|
||||
{
|
||||
/**
|
||||
* 格式化创建时间
|
||||
* @param string $value
|
||||
* @param mixed $value
|
||||
* @return string
|
||||
*/
|
||||
public function getCreateAtAttr(string $value): string
|
||||
public function getCreateAtAttr($value): string
|
||||
{
|
||||
return format_datetime($value);
|
||||
}
|
||||
|
@ -82,7 +82,7 @@ class PaymentService
|
||||
if ($oPayed + $pAmount > floatval($oAmount)) {
|
||||
return ['code' => 0, 'info' => '支付总额超出!', 'data' => [], 'params' => []];
|
||||
}
|
||||
$config = WechatService::getConfig();
|
||||
$config = WechatService::getConfig(true);
|
||||
do $pCode = CodeExtend::uniqidNumber(16, 'P');
|
||||
while (WechatPaymentRecord::mk()->master()->where(['code' => $pCode])->findOrEmpty()->isExists());
|
||||
$data = [
|
||||
@ -148,9 +148,15 @@ class PaymentService
|
||||
public static function notify(?array $data = null): Response
|
||||
{
|
||||
try {
|
||||
$notify = static::withPayment()->notify();
|
||||
p(Library::$sapp->request->post(), false, 'wechat_pay_notify');
|
||||
$notify = static::withPayment()->notify(Library::$sapp->request->post());
|
||||
$result = empty($notify['result']) ? [] : json_decode($notify['result'], true);
|
||||
if (empty($result) || !is_array($result)) return response('error', 500);
|
||||
p($result, false, 'wechat_pay_notify');
|
||||
p('------------------', false, 'wechat_pay_notify');
|
||||
if (empty($result) || !is_array($result)) {
|
||||
empty($data['order']) || self::query($data['order']);
|
||||
return response('error', 500);
|
||||
}
|
||||
//订单支付通知处理
|
||||
if ($data['scen'] === 'order' && isset($result['trade_state']) && $result['trade_state'] == 'SUCCESS') {
|
||||
if ($data['order'] !== $result['out_trade_no']) return response('error', 500);
|
||||
@ -181,6 +187,7 @@ class PaymentService
|
||||
}
|
||||
return response('success');
|
||||
} catch (\Exception $exception) {
|
||||
empty($data['order']) || self::query($data['order']);
|
||||
return json(['code' => 'FAIL', 'message' => $exception->getMessage()])->code(500);
|
||||
}
|
||||
}
|
||||
@ -321,7 +328,7 @@ class PaymentService
|
||||
*/
|
||||
protected static function withPayment(?array $config = null): Order
|
||||
{
|
||||
return Order::instance($config ?: WechatService::getConfig());
|
||||
return Order::instance($config ?: WechatService::getConfig(true));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -178,27 +178,25 @@ class WechatService extends Service
|
||||
|
||||
/**
|
||||
* 获取公众号配置参数
|
||||
* @param string $appid
|
||||
* @param boolean $ispay 获取支付参数
|
||||
* @return array
|
||||
* @throws \think\admin\Exception
|
||||
*/
|
||||
public static function getConfig(string $appid = ''): array
|
||||
public static function getConfig(bool $ispay = false): array
|
||||
{
|
||||
return static::withWxpayCert([
|
||||
'appid' => $appid ?: static::getAppid(),
|
||||
$config = [
|
||||
'appid' => static::getAppid(),
|
||||
'token' => sysconf('wechat.token'),
|
||||
'appsecret' => sysconf('wechat.appsecret'),
|
||||
'encodingaeskey' => sysconf('wechat.encodingaeskey'),
|
||||
'mch_id' => sysconf('wechat.mch_id'),
|
||||
'mch_key' => sysconf('wechat.mch_key'),
|
||||
'mch_v3_key' => sysconf('wechat.mch_v3_key'),
|
||||
'cache_path' => syspath('runtime/wechat'),
|
||||
]);
|
||||
];
|
||||
return $ispay ? static::withWxpayCert($config) : $config;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取小程序配置参数
|
||||
* @param boolean $ispay 支付参数
|
||||
* @param boolean $ispay 获取支付参数
|
||||
* @return array
|
||||
* @throws \think\admin\Exception
|
||||
*/
|
||||
@ -210,11 +208,7 @@ class WechatService extends Service
|
||||
'appsecret' => $wxapp['appkey'] ?? '',
|
||||
'cache_path' => syspath('runtime/wechat'),
|
||||
];
|
||||
return $ispay ? static::withWxpayCert(array_merge([
|
||||
'mch_id' => sysconf('wechat.mch_id'),
|
||||
'mch_key' => sysconf('wechat.mch_key'),
|
||||
'mch_v3_key' => sysconf('wechat.mch_v3_key'),
|
||||
], $config)) : $config;
|
||||
return $ispay ? static::withWxpayCert($config) : $config;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -226,32 +220,29 @@ class WechatService extends Service
|
||||
public static function withWxpayCert(array $options): array
|
||||
{
|
||||
// 文本模式主要是为了解决分布式部署
|
||||
$data = sysdata('plugin.wechat.payment');
|
||||
if (empty($data['mch_id'])) {
|
||||
throw new Exception('无效的支付配置!');
|
||||
}
|
||||
$name1 = sprintf("wxpay/%s_%s_cer.pem", $data['mch_id'], md5($data['ssl_cer_text']));
|
||||
$name2 = sprintf("wxpay/%s_%s_key.pem", $data['mch_id'], md5($data['ssl_key_text']));
|
||||
$local = LocalStorage::instance();
|
||||
$name1 = "wxpay/{$options['mch_id']}_cer.pem";
|
||||
$name2 = "wxpay/{$options['mch_id']}_key.pem";
|
||||
if ($local->has($name1, true) && $local->has($name2, true)) {
|
||||
$sslCer = $local->path($name1, true);
|
||||
$sslKey = $local->path($name2, true);
|
||||
} else {
|
||||
$sslCer = $local->set($name1, $data['ssl_cer_text'], true)['file'];
|
||||
$sslKey = $local->set($name2, $data['ssl_key_text'], true)['file'];
|
||||
}
|
||||
if (empty($sslCer) || empty($sslKey)) {
|
||||
if (!empty($data = sysdata('plugin.wechat.payment'))) {
|
||||
if (!empty($data['ssl_key_text']) && !empty($data['ssl_cer_text'])) {
|
||||
$sslCer = $local->set($name1, $data['ssl_cer_text'], true)['file'];
|
||||
$sslKey = $local->set($name2, $data['ssl_key_text'], true)['file'];
|
||||
}
|
||||
} else {
|
||||
$sslCer = $local->path(sysconf('wechat.mch_ssl_cer'), true);
|
||||
$sslKey = $local->path(sysconf('wechat.mch_ssl_key'), true);
|
||||
if (!$local->has($sslCer, true)) unset($sslCer);
|
||||
if (!$local->has($sslKey, true)) unset($sslKey);
|
||||
}
|
||||
}
|
||||
if (isset($sslCer) && isset($sslKey)) {
|
||||
$options['ssl_cer'] = $sslCer;
|
||||
$options['ssl_key'] = $sslKey;
|
||||
$options['cert_public'] = $sslCer;
|
||||
$options['cert_private'] = $sslKey;
|
||||
}
|
||||
$options['mch_id'] = $data['mch_id'];
|
||||
$options['mch_key'] = $data['mch_key'];
|
||||
$options['mch_v3_key'] = $data['mch_v3_key'];
|
||||
$options['ssl_cer'] = $sslCer;
|
||||
$options['ssl_key'] = $sslKey;
|
||||
$options['cert_public'] = $sslCer;
|
||||
$options['cert_private'] = $sslKey;
|
||||
$options['mp_cert_serial'] = $data['mch_pay_sid'] ?? '';
|
||||
$options['mp_cert_content'] = $data['ssl_pay_text'] ?? '';
|
||||
return $options;
|
||||
}
|
||||
|
||||
|
@ -6,7 +6,7 @@
|
||||
{block name='title'}{/block}
|
||||
<meta name="renderer" content="webkit">
|
||||
<meta name="format-detection" content="telephone=no">
|
||||
<meta name="apple-mobile-web-app-capable" content="yes">
|
||||
<meta name="mobile-web-app-capable" content="yes">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||
<meta name="apple-mobile-web-app-status-bar-style" content="black">
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">
|
||||
|
@ -37,7 +37,7 @@
|
||||
|
||||
function apply(data) {
|
||||
this.$active = $("[data-wechat-type='" + data.value + "']").trigger('click');
|
||||
if (this.$active.size() < 1) $("[data-wechat-type]:first").trigger('click');
|
||||
if (this.$active.length < 1) $("[data-wechat-type]:first").trigger('click');
|
||||
$('[data-type="' + data.value + '"]').show().siblings('[data-type]').hide();
|
||||
}
|
||||
});
|
||||
|
@ -17,22 +17,43 @@
|
||||
|
||||
<label class="layui-form-item relative block">
|
||||
<span class="help-label"><b>微信商户账号</b>MCH_ID</span>
|
||||
<input name="wechat.mch_id" required vali-name="微信商户号" placeholder="请输入微信商户账号(必填)" value="{:sysconf('wechat.mch_id')}" class="layui-input">
|
||||
<span class="help-block">微信商户账号,需要在微信商户平台获取,MCH_ID 与 APPID 匹配</span>
|
||||
<input name="wechat.mch_id" required vali-name="微信商户号" placeholder="请输入微信商户账号(必填)" value="{$data.mch_id|default=''}" class="layui-input">
|
||||
<span class="help-block">微信商户账号,需要在微信商户平台获取</span>
|
||||
</label>
|
||||
|
||||
<label class="layui-form-item relative layui-hide">
|
||||
<span class="help-label"><b>微信 V2 接口密钥</b>MCH_KEY</span>
|
||||
<input name="wechat.mch_key" vali-name="微信商户V2密钥" type="password" lay-affix="eye" placeholder="请输入微信商户V2密钥(必填)" maxlength="32" pattern=".{32}" required value="{$data.mch_key|default=''}" class="layui-input">
|
||||
<span class="help-block">微信商户 V2 密钥,需要在微信商户平台获取商户接口密钥</span>
|
||||
</label>
|
||||
|
||||
<label class="layui-form-item relative block">
|
||||
<span class="help-label"><b>微信商户 V2 密钥</b>MCH_KEY</span>
|
||||
<input name="wechat.mch_key" vali-name="微信商户V2密钥" placeholder="请输入微信商户V2密钥(必填)" maxlength="32" pattern=".{32}" required value="{:sysconf('wechat.mch_key')}" class="layui-input">
|
||||
<span class="help-block">微信商户 V2 密钥,需要在微信商户平台操作设置操作密码并获取商户接口密钥</span>
|
||||
<span class="help-label"><b>微信 V3 接口密钥</b>MCH_V3_KEY</span>
|
||||
<input name="wechat.mch_v3_key" vali-name="微信商户V3密钥" type="password" lay-affix="eye" placeholder="请输入微信商户V3密钥(必填)" maxlength="32" pattern=".{32}" required value="{$data.mch_v3_key|default=''}" class="layui-input">
|
||||
<span class="help-block">微信商户 V3 密钥,需要在微信商户平台获取商户接口密钥</span>
|
||||
</label>
|
||||
|
||||
<div class="hr-line-dashed"></div>
|
||||
|
||||
<label class="layui-form-item relative block">
|
||||
<span class="help-label"><b>微信商户 V3 密钥</b>MCH_V3_KEY</span>
|
||||
<input name="wechat.mch_v3_key" vali-name="微信商户V3密钥" placeholder="请输入微信商户V3密钥(必填)" maxlength="32" pattern=".{32}" required value="{:sysconf('wechat.mch_v3_key')}" class="layui-input">
|
||||
<span class="help-block">微信商户 V3 密钥,需要在微信商户平台操作设置操作密码并获取商户接口密钥</span>
|
||||
<span class="help-label"><b>微信 V3 支付公钥ID</b>MCH_V3_PAYID</span>
|
||||
<input name="wechat.mch_pay_sid" vali-name="微信商户V3支付公钥ID" placeholder="请输入微信商户V3支付公钥ID(必填)" maxlength="45" pattern="PUB_KEY_ID_.{34}" value="{$data.mch_pay_sid|default=''}" class="layui-input">
|
||||
<span class="help-block">微信商户 V3 支付证书ID,需要在微信商户平台操作设置操作密码并获取商户接口密钥</span>
|
||||
</label>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<span class="help-label label-required-prev"><b>微信 V3 支付公钥文件</b>MCH_V3_PAYCERT</span>
|
||||
<div class="margin-top-10">
|
||||
<div data-mch-type="pem" class="layui-tab-item">
|
||||
<input type="hidden" name="wechat.mch_ssl_pay" value="{$mch_ssl_pay|default=''}">
|
||||
<button data-file="btn" data-uptype="local" data-safe="true" data-type="pem" data-field="wechat.mch_ssl_pay" type="button" class="layui-btn font-code layui-btn-primary">
|
||||
<i class="layui-icon layui-icon-vercode"></i> 上传微信支付公钥
|
||||
</button>
|
||||
<a class="layui-btn layui-btn-danger layui-btn-primary ta-ml-5" onclick="$(this).prevAll('input').val('').trigger('change')"><i class="layui-icon layui-icon-close"></i></a>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="hr-line-dashed"></div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
@ -49,23 +70,30 @@
|
||||
<div data-mch-type="p12" class="layui-tab-item">
|
||||
<input name="wechat.mch_ssl_p12" value="{$mch_ssl_p12|default=''}" type="hidden">
|
||||
<button data-file="btn" data-uptype="local" data-safe="true" data-type="p12" data-field="wechat.mch_ssl_p12" type="button" class="layui-btn font-code layui-btn-primary">
|
||||
<i class="layui-icon layui-icon-vercode"></i> 上传 P12 证书
|
||||
<i class="layui-icon layui-icon-vercode"></i> 上传商户P12证书
|
||||
</button>
|
||||
<a class="layui-btn layui-btn-danger layui-btn-primary ta-ml-5" onclick="$(this).prevAll('input').val('').trigger('change')"><i class="layui-icon layui-icon-close"></i></a>
|
||||
</div>
|
||||
|
||||
<div data-mch-type="pem" class="layui-tab-item">
|
||||
<input type="hidden" name="wechat.mch_ssl_key" value="{$mch_ssl_key|default=''}">
|
||||
<button data-file="btn" data-uptype="local" data-safe="true" data-type="pem" data-field="wechat.mch_ssl_key" type="button" class="layui-btn font-code layui-btn-primary margin-right-10">
|
||||
<i class="layui-icon layui-icon-vercode"></i> 上传 KEY 证书
|
||||
</button>
|
||||
<input type="hidden" name="wechat.mch_ssl_cer" value="{$mch_ssl_cer|default=''}">
|
||||
<button data-file="btn" data-uptype="local" data-safe="true" data-type="pem" data-field="wechat.mch_ssl_cer" type="button" class="layui-btn font-code layui-btn-primary">
|
||||
<i class="layui-icon layui-icon-vercode"></i> 上传 CERT 证书
|
||||
</button>
|
||||
<div data-mch-type="pem" class="layui-tab-item flex">
|
||||
<div>
|
||||
<input type="hidden" name="wechat.mch_ssl_key" value="{$mch_ssl_key|default=''}">
|
||||
<button data-file="btn" data-uptype="local" data-safe="true" data-type="pem" data-field="wechat.mch_ssl_key" type="button" class="layui-btn font-code layui-btn-primary">
|
||||
<i class="layui-icon layui-icon-vercode"></i> 上传商户证书密钥
|
||||
</button>
|
||||
<a class="layui-btn layui-btn-danger layui-btn-primary ta-ml-5" onclick="$(this).prevAll('input').val('').trigger('change')"><i class="layui-icon layui-icon-close"></i></a>
|
||||
</div>
|
||||
<div class="ta-ml-20">
|
||||
<input type="hidden" name="wechat.mch_ssl_cer" value="{$mch_ssl_cer|default=''}">
|
||||
<button data-file="btn" data-uptype="local" data-safe="true" data-type="pem" data-field="wechat.mch_ssl_cer" type="button" class="layui-btn font-code layui-btn-primary">
|
||||
<i class="layui-icon layui-icon-vercode"></i> 上传商户证书公钥
|
||||
</button>
|
||||
<a class="layui-btn layui-btn-danger layui-btn-primary ta-ml-5" onclick="$(this).prevAll('input').val('').trigger('change')"><i class="layui-icon layui-icon-close"></i></a>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!--{if auth('payment_save')}-->
|
||||
<div class="hr-line-dashed margin-top-30"></div>
|
||||
<div class="layui-form-item text-center">
|
||||
@ -81,7 +109,7 @@
|
||||
(function (type) {
|
||||
layui.form.val('payment', {'wechat.mch_ssl_type': type});
|
||||
layui.form.on('radio(data-mch-type)', apply) && apply({value: type});
|
||||
['wechat.mch_ssl_p12', 'wechat.mch_ssl_key', 'wechat.mch_ssl_cer'].forEach(function (type) {
|
||||
['wechat.mch_ssl_p12', 'wechat.mch_ssl_key', 'wechat.mch_ssl_cer', 'wechat.mch_ssl_pay'].forEach(function (type) {
|
||||
$('input[name="' + type + '"]').on('change', function () {
|
||||
let that = this, $button = $(this).next('button');
|
||||
if (typeof that.value === 'string' && that.value.length > 5) {
|
||||
@ -95,6 +123,6 @@
|
||||
function apply(data) {
|
||||
return $('[data-mch-type="' + data.value + '"]').show().siblings('[data-mch-type]').hide();
|
||||
}
|
||||
})("{:sysconf('wechat.mch_ssl_type')}" || 'pem');
|
||||
})("{$data.mch_ssl_type|default='pem'}");
|
||||
</script>
|
||||
{/block}
|
||||
|
@ -5,7 +5,7 @@
|
||||
<meta charset="utf-8">
|
||||
<meta name="renderer" content="webkit">
|
||||
<meta name="format-detection" content="telephone=no">
|
||||
<meta name="apple-mobile-web-app-capable" content="yes">
|
||||
<meta name="mobile-web-app-capable" content="yes">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||
<meta name="apple-mobile-web-app-status-bar-style" content="black">
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=0.4">
|
||||
|
@ -24,6 +24,7 @@ window.form = layui.form, window.layer = layui.layer;
|
||||
window.laytpl = layui.laytpl, window.laydate = layui.laydate;
|
||||
window.jQuery = window.$ = window.jQuery || window.$ || layui.$;
|
||||
window.jQuery.ajaxSetup({xhrFields: {withCredentials: true}});
|
||||
window.jQuery.fn.size || (window.jQuery.fn.size = () => this.length);
|
||||
|
||||
/*! 配置 require 参数 */
|
||||
require.config({
|
||||
@ -182,7 +183,7 @@ $(function () {
|
||||
/*! 关闭顶层最新窗口 */
|
||||
this.closeLastModal = function () {
|
||||
while ($.msg.mdx.length > 0 && (this.tdx = $.msg.mdx.pop()) > 0) {
|
||||
if ($('#layui-layer' + this.tdx).size()) return layer.close(this.tdx);
|
||||
if ($('#layui-layer' + this.tdx).length) return layer.close(this.tdx);
|
||||
}
|
||||
};
|
||||
/*! 关闭消息框 */
|
||||
@ -404,15 +405,15 @@ $(function () {
|
||||
this.queryNode = function (uri, node) {
|
||||
// 如果该节点存在直接返回 Node 值
|
||||
if (/^m-/.test(node = node || location.href.replace(/.*spm=([\d\-m]+).*/ig, '$1'))) {
|
||||
if ($('[data-menu-node="' + node + '"]').size()) return node;
|
||||
if ($('[data-menu-node="' + node + '"]').length) return node;
|
||||
}
|
||||
let path = uri.replace(/\.html$/ig, '');
|
||||
// 尝试通过 URI 查询节点值
|
||||
let $menu = $('[data-menu-node][data-open*="' + path + '"]');
|
||||
if ($menu.size()) return $menu.get(0).dataset.menuNode;
|
||||
if ($menu.length) return $menu.get(0).dataset.menuNode;
|
||||
// 尝试通过 URL 查询节点值
|
||||
$menu = $('[data-menu-node][data-open~="#' + path + '"]');
|
||||
return $menu.size() ? $menu.get(0).dataset.menuNode : (/^m-/.test(node || '') ? node : '');
|
||||
return $menu.length ? $menu.get(0).dataset.menuNode : (/^m-/.test(node || '') ? node : '');
|
||||
};
|
||||
/*! 完整 URL 转 URI 地址 */
|
||||
this.parseUri = function (uri, elem, vars, temp, attrs) {
|
||||
@ -665,10 +666,10 @@ $(function () {
|
||||
// 默认动态设置页数, 动态设置最大高度
|
||||
if (option.page === true) option.page = {curr: layui.sessionData('pages')[option.id] || 1};
|
||||
if (option.width === 'full') option.width = $table.parent().width();
|
||||
if (option.height === 'full') if ($table.parents('.iframe-pagination').size()) {
|
||||
if (option.height === 'full') if ($table.parents('.iframe-pagination').length) {
|
||||
$table.parents('.iframe-pagination').addClass('not-footer');
|
||||
option.height = $(window).height() - $table.removeClass('layui-hide').offset().top - 20;
|
||||
} else if ($table.parents('.laytable-pagination').size()) {
|
||||
} else if ($table.parents('.laytable-pagination').length) {
|
||||
option.height = $table.parents('.laytable-pagination').height() - $table.removeClass('layui-hide').position().top - 20;
|
||||
} else {
|
||||
option.height = $(window).height() - $table.removeClass('layui-hide').offset().top - 35;
|
||||
@ -814,7 +815,7 @@ $(function () {
|
||||
let type = form.getAttribute('method') || 'POST', href = form.getAttribute('action') || location.href;
|
||||
let dset = form.dataset, 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) {
|
||||
if (typeof ret === 'object' && ret.code > 0 && $('#' + taid).length > 0) {
|
||||
return $.msg.success(ret.info, 3, function () {
|
||||
$.msg.closeLastModal();
|
||||
(typeof ret.data === 'string' && ret.data) ? $.form.goto(ret.data) : $.layTable.reload(taid);
|
||||
@ -853,7 +854,7 @@ $(function () {
|
||||
/*! 查找表单元素, 如果没有找到将不会自动写值 */
|
||||
if (!(this.$elem = $(this)).data('input') && this.$elem.data('field')) {
|
||||
let $input = $('input[name="' + this.$elem.data('field') + '"]:not([type=file])');
|
||||
this.$elem.data('input', $input.size() > 0 ? $input.get(0) : null);
|
||||
this.$elem.data('input', $input.length > 0 ? $input.get(0) : null);
|
||||
}
|
||||
// 单图或多图选择器 ( image|images )
|
||||
if (typeof this.dataset.file === 'string' && /^images?$/.test(this.dataset.file)) {
|
||||
|
@ -20,12 +20,13 @@ define(function () {
|
||||
}
|
||||
|
||||
/*! 默认导出配置 */
|
||||
Excel.prototype.options = {writeOpt: {bookSST: true}};
|
||||
Excel.prototype.options = {writeOpt: {bookSST: false}};
|
||||
|
||||
/*! 导出 Excel 文件 */
|
||||
Excel.prototype.export = function (data, name, options) {
|
||||
name = name || '数据导出_' + layui.util.toDateString(Date.now(), '_yyyyMMdd_HHmmss');
|
||||
if (name.substring(0, -5).toLowerCase() !== '.xlsx') name += '.xlsx';
|
||||
layui.excel.exportExcel(data, name, 'xlsx', options || this.options || {writeOpt: {bookSST: true}});
|
||||
layui.excel.exportExcel(data, name, 'xlsx', $.extend(options || {}, this.options));
|
||||
};
|
||||
|
||||
/*! 绑定导出的事件 */
|
||||
@ -40,23 +41,28 @@ define(function () {
|
||||
// </script>
|
||||
Excel.prototype.bind = function (done, filename, selector, options) {
|
||||
let that = this;
|
||||
this.options = options || {}
|
||||
this.options = $.extend(this.options, options || {});
|
||||
this.bindLoadDone(function (data, button) {
|
||||
that.export(done.call(that, data, []), button.dataset.filename || filename);
|
||||
}, selector);
|
||||
};
|
||||
|
||||
/*! 加载所有数据 */
|
||||
Excel.prototype.bindLoadDone = function (done, selector) {
|
||||
let that = this;
|
||||
$('body').off('click', selector || '[data-form-export]').on('click', selector || '[data-form-export]', function () {
|
||||
let form = $(this).parents('form');
|
||||
let name = this.dataset.filename || filename;
|
||||
let button = this, form = $(this).parents('form');
|
||||
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;
|
||||
}
|
||||
that.load(location, form.serialize(), method).then(function (data) {
|
||||
that.export(done.call(that, data, []), name);
|
||||
}).fail(function (ret) {
|
||||
$.msg.tips(ret || '文件导出失败');
|
||||
that.load(location, form.serialize(), method).then((data) => done.call(that, data, button)).fail(function (ret) {
|
||||
$.msg.tips(ret || '数据加载失败');
|
||||
});
|
||||
});
|
||||
};
|
||||
}
|
||||
|
||||
/*! 加载导出的文档 */
|
||||
Excel.prototype.load = function (url, data, method) {
|
||||
|
@ -81,12 +81,13 @@ define(function () {
|
||||
};
|
||||
this.insertError = function ($el) {
|
||||
return (function ($icon) {
|
||||
console.log($icon)
|
||||
return $el.data('vali-tags').css({
|
||||
top: $el.position().top + 'px', right: (($icon ? $icon.width() + parseFloat($icon.css('right') || 0) : 0) + 10) + 'px',
|
||||
paddingTop: $el.css('marginTop'), lineHeight: ($el.get(0).nodeName || '') === 'TEXTAREA' ? '32px' : $el.css('height'),
|
||||
});
|
||||
})($el.nextAll('.input-right-icon'), $el.data('vali-tags') || function () {
|
||||
let css = 'display:block;position:absolute;text-align:center;color:#c44;font-size:12px;z-index:2';
|
||||
let css = 'display:block;position:absolute;text-align:center;color:#c44;font-size:12px;z-index:2;right:8px';
|
||||
$el.data('vali-tags', $('<span class="layui-anim notselect" style="' + css + '"></span>').insertAfter($el));
|
||||
}());
|
||||
};
|
||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
Loading…
x
Reference in New Issue
Block a user