templateconfig.html 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <?php $shoname_name = D('Home/Front')->get_config_by_name('shoname'); ?>
  6. <title><?php echo $shoname; ?></title>
  7. <link rel="shortcut icon" href="" />
  8. <meta name="renderer" content="webkit">
  9. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  10. <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
  11. <link rel="stylesheet" href="/layuiadmin/style/admin.css" media="all">
  12. <!-- 让IE8/9支持媒体查询,从而兼容栅格 -->
  13. <!--[if lt IE 9]>
  14. <script src="https://cdn.staticfile.org/html5shiv/r29/html5.min.js"></script>
  15. <script src="https://cdn.staticfile.org/respond.js/1.4.2/respond.min.js"></script>
  16. <![endif]-->
  17. <link href="./resource/css/bootstrap.min.css?v=201903260001" rel="stylesheet">
  18. <link href="./resource/css/common.css?v=201903260001" rel="stylesheet">
  19. <script type="text/javascript">
  20. window.sysinfo = {
  21. <?php if (!empty($_W['uniacid']) ){ ?>'uniacid': '{$_W['uniacid']}',<?php } ?>
  22. <?php if( !empty($_W['acid']) ){ ?>'acid': '{$_W['acid']}',<?php } ?>
  23. <?php if (!empty($_W['openid']) ) { ?>'openid': '{$_W['openid']}',<?php } ?>
  24. <?php if( !empty($_W['uid']) ) { ?>'uid': '{$_W['uid']}',<?php } ?>
  25. 'isfounder': <?php if (!empty($_W['isfounder']) ) { ?>1<?php }else{ ?>0<?php } ?>,
  26. 'siteroot': '{$_W['siteroot']}',
  27. 'siteurl': '{$_W['siteurl']}',
  28. 'attachurl': '{$_W['attachurl']}',
  29. 'attachurl_local': '{$_W['attachurl_local']}',
  30. 'attachurl_remote': '{$_W['attachurl_remote']}',
  31. 'module' : {'url' : '<?php if( defined('MODULE_URL') ) { ?>{MODULE_URL}<?php } ?>', 'name' : '<?php if (defined('IN_MODULE') ) { ?>{IN_MODULE}<?php } ?>'},
  32. 'cookie' : {'pre': ''},
  33. 'account' : {:json_encode($_W['account'])},
  34. };
  35. </script>
  36. <script type="text/javascript" src="./resource/js/lib/jquery-1.11.1.min.js"></script>
  37. <script type="text/javascript" src="./resource/js/lib/bootstrap.min.js"></script>
  38. <script type="text/javascript" src="./resource/js/app/util.js?v=201903260001"></script>
  39. <script type="text/javascript" src="./resource/js/app/common.min.js?v=201903260001"></script>
  40. <script type="text/javascript" src="./resource/js/require.js?v=201903260001"></script>
  41. <script type="text/javascript" src="./resource/js/lib/jquery.nice-select.js?v=201903260001"></script>
  42. <link rel="stylesheet" href="/layuiadmin/layui/css/layui.css" media="all">
  43. <link href="/static/css/snailfish.css" rel="stylesheet">
  44. <script type="text/javascript" src="/static/js/dist/area/cascade.js"></script>
  45. <script src="https://map.qq.com/api/js?v=2.exp&key=6R4BZ-WAB3W-JITRG-OE7GY-R2753-P3BZ2" type="text/javascript" charset="utf-8"></script>
  46. </head>
  47. <body layadmin-themealias="default">
  48. <div class="layui-fluid">
  49. <div class="layui-card">
  50. <div class="layui-card-header layui-elem-quote">当前位置:<span class="line-text">模板消息设置</span></div>
  51. <div class="layui-tab layui-tab-brief" >
  52. <ul class="layui-tab-title">
  53. <li <?php if( $type==1 ){ ?>class="layui-this"<?php } ?> ><a href="{:U('weprogram/templateconfig', array('type' => 1))}">公众号模板消息</a></li>
  54. <li <?php if( $type==2 ){ ?>class="layui-this"<?php } ?> ><a href="{:U('weprogram/templateconfig', array('type' => 2))}">平台订单通知</a></li>
  55. </ul>
  56. </div>
  57. <?php if( $type == 1 ){ ?>
  58. <div class="layui-card-body" style="padding:15px;display:block" >
  59. <form action="" method="post" class="layui-form" lay-filter="component-layui-form-item" enctype="multipart/form-data" >
  60. <div class="layui-form-item">
  61. <label class="layui-form-label">公众号APPID</label>
  62. <div class="layui-input-block">
  63. <input type="text" name="parameter[weixin_appid]" class="layui-input" value="{$data['weixin_appid']}" />
  64. </div>
  65. </div>
  66. <div class="layui-form-item">
  67. <label class="layui-form-label">订单支付成功通知</label>
  68. <div class="layui-input-block">
  69. <input type="text" name="parameter[weixin_template_pay_order]" class="layui-input" value="{$data['weixin_template_pay_order']}" />
  70. </div>
  71. </div>
  72. <div class="layui-form-item">
  73. <label class="layui-form-label">订单发货通知</label>
  74. <div class="layui-input-block">
  75. <input type="text" name="parameter[weixin_template_send_order]" class="layui-input" value="{$data['weixin_template_send_order']}" />
  76. </div>
  77. </div>
  78. <div class="layui-form-item" >
  79. <label class="layui-form-label">核销成功通知</label>
  80. <div class="layui-input-block">
  81. <input type="text" name="parameter[weixin_template_hexiao_success]" class="layui-input" value="{$data['weixin_template_hexiao_success']}" />
  82. </div>
  83. </div>
  84. <div class="layui-form-item">
  85. <label class="layui-form-label">团长申请成功发送通知</label>
  86. <div class="layui-input-block">
  87. <input type="text" name="parameter[weixin_template_apply_community]" class="layui-input" value="{$data['weixin_template_apply_community']}" />
  88. </div>
  89. </div>
  90. <div class="layui-form-item">
  91. <label class="layui-form-label">售后订单申请通知(平台)</label>
  92. <div class="layui-input-block">
  93. <input type="text" name="parameter[weixin_template_apply_refund]" class="layui-input" value="{$data['weixin_template_apply_refund']}" />
  94. </div>
  95. </div>
  96. <div class="layui-form-item">
  97. <label class="layui-form-label">取消订单通知(平台)</label>
  98. <div class="layui-input-block">
  99. <input type="text" name="parameter[weixin_template_cancle_order]" class="layui-input" value="{$data['weixin_template_cancle_order']}" />
  100. </div>
  101. </div>
  102. <div class="layui-form-item">
  103. <label class="layui-form-label">会员下单成功提醒团长</label>
  104. <div class="layui-input-block">
  105. <input type="text" name="parameter[weixin_template_order_buy]" class="layui-input" value="{$data['weixin_template_order_buy']}" />
  106. </div>
  107. </div>
  108. <div class="layui-form-item">
  109. <label class="layui-form-label">团长提现到账提醒</label>
  110. <div class="layui-input-block">
  111. <input type="text" name="parameter[weixin_template_apply_tixian]" class="layui-input" value="{$data['weixin_template_apply_tixian']}" />
  112. </div>
  113. <div class="layui-form-mid">
  114. 注意,公众号需要是小程序的关联主体。(未填写appid 即不发送模板消息)<br>
  115. <a href="https://shiziyu.liofis.com/公众号模板消息.docx" style="color:blue;">点击下载设置教程</a>
  116. </div>
  117. </div>
  118. <div class="layui-form-item">
  119. <label class="layui-form-label"> </label>
  120. <div class="layui-input-block">
  121. <input type="submit" value="提交" lay-submit lay-filter="formDemo" class="btn btn-primary" />
  122. </div>
  123. </div>
  124. </form>
  125. </div>
  126. <?php }else if( $type == 3 ){ ?>
  127. <div class="layui-card-body" style="padding:15px;display:block" >
  128. <form action="{:U('weprogram/templateconfig_fenxi', array('type' => 3))}" method="post" class="layui-form" lay-filter="component-layui-form-item" enctype="multipart/form-data" >
  129. <div class="layui-form-item">
  130. <label class="layui-form-label">示例:</label>
  131. <div class="layui-input-block">
  132. <blockquote class="layui-elem-quote layui-quote-nm">
  133. {{first.DATA}}<br/><br/>
  134. 产品名称:{{hotelName.DATA}}<br/><br/>
  135. 团购券号:{{voucher_number.DATA}}<br/><br/>
  136. {{remark.DATA}}<br/><br/>
  137. 小程序后台——模板消息——我的模板——某模板详情——详细内容(复制粘粘到此处)<br/>
  138. </blockquote>
  139. </div>
  140. </div>
  141. <div class="layui-form-item">
  142. <label class="layui-form-label">模板详细内容</label>
  143. <div class="layui-input-block">
  144. <textarea name="subtitle" id="subtitle" rows="8" class="form-control" ></textarea>
  145. <div class="layui-form-mid layui-word-aux"></div>
  146. </div>
  147. </div>
  148. <div id="analy_div">
  149. </div>
  150. <div class="layui-form-item">
  151. <label class="layui-form-label">发送会员类型</label>
  152. <div class="layui-input-block">
  153. <label class='radio-inline'>
  154. <input type='radio' name='all_msg_send_type' lay-filter="all_msg_send_type" title="指定会员" value=1 checked />
  155. </label>
  156. <label class='radio-inline'>
  157. <input type='radio' name='all_msg_send_type' lay-filter="all_msg_send_type" title="某个会员组" value=2 />
  158. </label>
  159. <label class='radio-inline'>
  160. <input type='radio' name='all_msg_send_type' lay-filter="all_msg_send_type" title="全部会员" value=3 />
  161. </label>
  162. </div>
  163. </div>
  164. <div class="layui-form-item" id="type_1">
  165. <label class="layui-form-label">关联会员</label>
  166. <div class="layui-input-block">
  167. <div class="input-group " style="margin: 0;">
  168. <input type="text" disabled value="" class="form-control valid" name="" placeholder="" id="agent_id">
  169. <span class="input-group-btn">
  170. <span data-input="#agent_id" id="chose_agent_id" class="btn btn-default">选择会员</span>
  171. </span>
  172. </div>
  173. </div>
  174. </div>
  175. <div class="layui-form-item" id="type_2" style="display:none;">
  176. <label class="layui-form-label must">会员组</label>
  177. <div class="layui-input-block">
  178. <select name="member_group_id">
  179. <?php foreach($member_group_list as $val){ ?>
  180. <option value="{$val['id']}">{$val['groupname']}</option>
  181. <?php } ?>
  182. </select>
  183. </div>
  184. </div>
  185. <div class="layui-form-item">
  186. <label class="layui-form-label">模板ID</label>
  187. <div class="layui-input-block">
  188. <input type="text" name="all_send_template_id" class="layui-input" value="" />
  189. </div>
  190. <div class="layui-form-mid" style="margin-left:25px;">
  191. 开发者调用模板消息接口时需提供模板ID
  192. </div>
  193. </div>
  194. <div class="layui-form-item">
  195. <label class="layui-form-label">点击链接</label>
  196. <div class="layui-input-block">
  197. <div class="input-group " style="margin: 0;">
  198. <input type="text" value="" class="form-control valid" name="link" placeholder="" id="advlink">
  199. <span class="input-group-btn">
  200. <span data-input="#advlink" id="chose_link" class="btn btn-default">选择链接</span>
  201. </span>
  202. </div>
  203. </div>
  204. </div>
  205. <div class="layui-form-item">
  206. <label class="layui-form-label"> </label>
  207. <div class="layui-input-block">
  208. <input type="submit" value="提交" lay-submit lay-filter="formDemo" class="btn btn-primary" />
  209. </div>
  210. </div>
  211. </form>
  212. </div>
  213. <?php }else{ ?>
  214. <div class="layui-card-body" style="padding:15px;display:block" >
  215. <form action="" method="post" class="layui-form" lay-filter="component-layui-form-item" enctype="multipart/form-data" >
  216. <div class="layui-form-item" id="user_form_item">
  217. <label class="layui-form-label">关联会员</label>
  218. <div class="layui-input-block">
  219. <div class="input-group " style="margin: 0;">
  220. <input type="text" disabled value="" class="form-control valid" name="" placeholder="" id="agent_id">
  221. <span class="input-group-btn">
  222. <span data-input="#agent_id" id="chose_agent_id" class="btn btn-default">选择会员</span>
  223. </span>
  224. </div>
  225. <?php if(!empty($user_list)){ ?>
  226. <?php foreach( $user_list as $a ){ ?>
  227. <div class="input-group mult_choose_member_id" data-member-id="{$a['member_id']}" style="border-radius: 0;float: left;margin: 10px;margin-left:0px;width: 22%;">
  228. <div class="layadmin-text-center choose_user">
  229. <img style="" src="{$a['avatar']}">
  230. <div class="layadmin-maillist-img" style="">{$a['nickname']}</div>
  231. <button type="button" class="layui-btn layui-btn-sm" onclick="cancle_bind(this)">
  232. <i class="layui-icon"></i>
  233. </button>
  234. </div>
  235. </div>
  236. <?php }} ?>
  237. </div>
  238. </div>
  239. <div class="layui-form-item">
  240. <label class="layui-form-label"> </label>
  241. <div class="layui-input-block">
  242. <?php if( $_GPC['type']!='0' && $_GPC['type']!='1' ){ ?>
  243. <input type="hidden" name="limit_user_list" value="" id="limit_user_list" />
  244. <?php } ?>
  245. <input type="submit" value="提交" lay-submit lay-filter="formDemo" class="btn btn-primary" />
  246. </div>
  247. </div>
  248. </form>
  249. </div>
  250. </div>
  251. <?php } ?>
  252. </div>
  253. </div>
  254. <script src="/layuiadmin/layui/layui.js"></script>
  255. <script>
  256. layui.config({
  257. base: '/layuiadmin/' //静态资源所在路径
  258. }).extend({
  259. index: 'lib/index' //主入口模块
  260. }).use('index');
  261. </script>
  262. <script>
  263. //由于模块都一次性加载,因此不用执行 layui.use() 来加载对应模块,直接使用即可:
  264. var layer = layui.layer;
  265. var $;
  266. var cur_open_div;
  267. var can_sub = true;
  268. layui.use(['jquery', 'layer','form'], function(){
  269. $ = layui.$;
  270. var form = layui.form;
  271. form.on('radio(linktype)', function(data){
  272. if (data.value == 2) {
  273. $('#typeGroup').show();
  274. } else {
  275. $('#typeGroup').hide();
  276. }
  277. });
  278. form.on('radio(all_msg_send_type)', function(data){
  279. if (data.value == 1) {
  280. $('#type_1').show();
  281. } else if( data.value == 2 )
  282. {
  283. $('#type_1').hide();
  284. $('#type_2').show();
  285. }
  286. else if( data.value == 3 )
  287. {
  288. $('#type_1').hide();
  289. $('#type_2').hide();
  290. }
  291. });
  292. //subtitle
  293. $(document).on("input propertychange","#subtitle",function(){
  294. //("\r|\n|\\s", "");
  295. var s_content = $('#subtitle').val();
  296. s_content.replace(/\r|\n|\\s/g,"");
  297. var regex3 = /\{\{(.+?)\}\}/g; // {}
  298. var new_arr = s_content.match(regex3);
  299. var s_html = "";
  300. for( var i in new_arr )
  301. {
  302. s_html+=' <div class="layui-form-item">';
  303. s_html+=' <label class="layui-form-label">'+new_arr[i]+'内容</label>';
  304. s_html+=' <div class="layui-input-block">';
  305. s_html+=' <input type="text" name="datas['+new_arr[i]+']" class="layui-input" lay-required="true" value="" />';
  306. s_html+=' </div>';
  307. s_html+=' </div>';
  308. }
  309. $('#analy_div').html(s_html);
  310. });
  311. $('#chose_member_id').click(function(){
  312. cur_open_div = $(this).attr('data-input');
  313. $.post("{:U('user/zhenquery', array('ok' => 1))}", {}, function(shtml){
  314. layer.open({
  315. type: 1,
  316. area: '930px',
  317. content: shtml //注意,如果str是object,那么需要字符拼接。
  318. });
  319. });
  320. })
  321. $('#chose_agent_id').click(function(){
  322. cur_open_div = $(this).attr('data-input');
  323. $.post("{:U('user/zhenquery_many', array('template' => 'mult'))}", {}, function(shtml){
  324. layer.open({
  325. type: 1,
  326. area: '930px',
  327. content: shtml //注意,如果str是object,那么需要字符拼接。
  328. });
  329. });
  330. })
  331. $('#chose_link').click(function(){
  332. cur_open_div = $(this).attr('data-input');
  333. $.post("{:U('util/selecturl', array('ok' => 1))}", {}, function(shtml){
  334. layer.open({
  335. type: 1,
  336. area: '930px',
  337. content: shtml //注意,如果str是object,那么需要字符拼接。
  338. });
  339. });
  340. })
  341. form.on('submit(auto_get)', function(data){
  342. var loadingIndex = layer.load(); // 加载中动画遮罩层(1)
  343. $.ajax({
  344. url: "{:U('weprogram/autotemplateconfig',array('ok'=>'1'))}",
  345. type: 'get',
  346. dataType:'json',
  347. success: function (info) {
  348. layer.close(loadingIndex); // 提交成功失败都需要关闭
  349. if(info.status == 0)
  350. {
  351. layer.msg('请选择会员',{time: 1000});
  352. }else if(info.status == 1){
  353. layer.msg('操作成功',{time: 1000,
  354. end:function(){
  355. var backurl = "{:U('weprogram/templateconfig')}";
  356. location.href = backurl;
  357. // location.href = info.result.url;
  358. }
  359. });
  360. can_sub = true;
  361. }
  362. }
  363. });
  364. return false;
  365. })
  366. //监听提交
  367. form.on('submit(formDemo)', function(data){
  368. var gd_ar = [];
  369. var gd_str = '';
  370. $('.mult_choose_member_id').each(function(){
  371. gd_ar.push( $(this).attr('data-member-id') );
  372. })
  373. gd_str = gd_ar.join(',');
  374. data.field.limit_user_list = gd_str;
  375. $.ajax({
  376. url: data.form.action,
  377. type: data.form.method,
  378. data: data.field,
  379. dataType:'json',
  380. success: function (info) {
  381. if(info.status == 0)
  382. {
  383. layer.msg(info.result.message,{icon: 1,time: 2000});
  384. }else if(info.status == 1){
  385. var go_url = location.href;
  386. if( info.result.hasOwnProperty("url") )
  387. {
  388. go_url = info.result.url;
  389. }
  390. layer.msg('操作成功',{time: 1000,
  391. end:function(){
  392. location.href = info.result.url;
  393. }
  394. });
  395. }
  396. }
  397. });
  398. return false;
  399. });
  400. })
  401. function cancle_bind(obj,sdiv)
  402. {
  403. $('#'+sdiv).val('');
  404. $(obj).parent().parent().remove();
  405. }
  406. </script>
  407. </body>