16feaa2c62865bbea70cb40193eb75d1.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527
  1. <?php /*a:2:{s:95:"E:\phpstudy_pro_8.1.0.1_64bit_Green\phpstudy_pro\WWW\yueshengshop\app\admin\view\user\user.html";i:1587196808;s:90:"E:\phpstudy_pro_8.1.0.1_64bit_Green\phpstudy_pro\WWW\yueshengshop\app\admin\view\base.html";i:1587517806;}*/ ?>
  2. <!DOCTYPE html>
  3. <html>
  4. <head>
  5. <meta name="renderer" content="webkit" />
  6. <meta http-equiv="X-UA-COMPATIBLE" content="IE=edge,chrome=1" />
  7. <title><?php echo htmlentities((isset($menu_info['title']) && ($menu_info['title'] !== '')?$menu_info['title']:"")); ?> - <?php echo htmlentities((isset($website['title']) && ($website['title'] !== '')?$website['title']:"Niushop开源商城")); ?></title>
  8. <meta name="keywords" content="<?php echo htmlentities((isset($website['keywords']) && ($website['keywords'] !== '')?$website['keywords']:'Niushop开源商城')); ?>">
  9. <meta name="description" content="<?php echo htmlentities((isset($website['desc']) && ($website['desc'] !== '')?$website['desc']:'描述')); ?>}">
  10. <link rel="icon" type="image/x-icon" href="http://yueshengshop.top/public/static/img/bitbug_favicon.ico" />
  11. <link rel="stylesheet" type="text/css" href="http://yueshengshop.top/public/static/css/iconfont.css" />
  12. <link rel="stylesheet" type="text/css" href="http://yueshengshop.top/public/static/ext/layui/css/layui.css" />
  13. <link rel="stylesheet" type="text/css" href="http://yueshengshop.top/public/static/loading/msgbox.css"/>
  14. <link rel="stylesheet" type="text/css" href="http://yueshengshop.top/app/admin/view/public/css/common.css" />
  15. <script src="http://yueshengshop.top/public/static/js/jquery-3.1.1.js"></script>
  16. <script src="http://yueshengshop.top/public/static/ext/layui/layui.js"></script>
  17. <script>
  18. layui.use(['layer', 'upload', 'element'], function() {});
  19. window.ns_url = {
  20. baseUrl: "http://yueshengshop.top/",
  21. route: ['<?php echo request()->module(); ?>', '<?php echo request()->controller(); ?>', '<?php echo request()->action(); ?>'],
  22. };
  23. </script>
  24. <script src="http://yueshengshop.top/public/static/js/common.js"></script>
  25. <style>
  26. .ns-calendar{background: url("http://yueshengshop.top/public/static/img/ns_calendar.png") no-repeat center / 16px 16px;}
  27. </style>
  28. <script type="text/javascript">
  29. </script>
  30. </head>
  31. <body>
  32. <!-- logo -->
  33. <div class="ns-logo">
  34. <div class="logo-box">
  35. <img src="http://yueshengshop.top/app/admin/view/public/img/logo.png">
  36. </div>
  37. <span>B2B2C多商户平台端</span>
  38. <span>
  39. 服务电话:400-886-7993
  40. </span>
  41. </div>
  42. <div class="layui-layout layui-layout-admin">
  43. <div class="layui-header">
  44. <!-- 一级菜单 -->
  45. <ul class="layui-nav layui-layout-left">
  46. <?php $serond_menu = []; foreach($menu as $menu_k => $menu_v): ?>
  47. <li class="layui-nav-item <?php if($menu_v['selected']): ?> layui-this<?php endif; ?>">
  48. <a href="<?php echo htmlentities($menu_v['url']); ?>"><?php echo htmlentities($menu_v['title']); ?></a>
  49. </li>
  50. <?php if($menu_v['selected']):
  51. $serond_menu = $menu_v['child_list'];
  52. ?>
  53. <?php endif; ?>
  54. <?php endforeach; ?>
  55. </ul>
  56. <ul class="layui-nav layui-layout-right">
  57. <li class="layui-nav-item">
  58. <a href="javascript:;">
  59. <div class="ns-img-box">
  60. <img src="http://yueshengshop.top/app/admin/view/public/img/default_headimg.png" alt="">
  61. </div>
  62. <?php echo htmlentities($user_info['username']); ?>
  63. </a>
  64. <dl class="layui-nav-child">
  65. <dd class="ns-reset-pass" onclick="resetPassword();">
  66. <a href="javascript:;">修改密码</a>
  67. </dd>
  68. <dd>
  69. <a onclick="clearCache()" href="javascript:;">清除缓存</a>
  70. </dd>
  71. <dd>
  72. <a href="<?php echo addon_url('admin/login/logout'); ?>" class="login-out">退出登录</a>
  73. </dd>
  74. </dl>
  75. </li>
  76. </ul>
  77. </div>
  78. <?php if(!(empty($serond_menu) || (($serond_menu instanceof \think\Collection || $serond_menu instanceof \think\Paginator ) && $serond_menu->isEmpty()))): ?>
  79. <div class="layui-side">
  80. <div class="layui-side-scroll">
  81. <span class="ns-side-title"><?php echo htmlentities($crumbs[0]['title']); ?></span>
  82. <!-- 二三级菜单-->
  83. <ul class="layui-nav layui-nav-tree" lay-filter="test">
  84. <?php foreach($serond_menu as $menu_second_k => $menu_second_v): ?>
  85. <li class="layui-nav-item <?php if($menu_second_v['selected']): ?> layui-nav-itemed <?php endif; if(!$menu_second_v['child_list'] && $menu_second_v['selected']): ?> layui-this<?php endif; ?>">
  86. <a class="layui-menu-tips" href="<?php if(!$menu_second_v['child_list']): ?> <?php echo htmlentities($menu_second_v['url']); else: ?>javascript:;<?php endif; ?>"><?php echo htmlentities($menu_second_v['title']); ?></a>
  87. <?php if(!(empty($menu_second_v['child_list']) || (($menu_second_v['child_list'] instanceof \think\Collection || $menu_second_v['child_list'] instanceof \think\Paginator ) && $menu_second_v['child_list']->isEmpty()))): ?>
  88. <dl class="layui-nav-child">
  89. <?php foreach($menu_second_v["child_list"] as $menu_third_k => $menu_third_v): ?>
  90. <dd class="<?php if($menu_third_v['selected']): ?> layui-this<?php endif; ?>">
  91. <a href="<?php echo htmlentities($menu_third_v['url']); ?>"><?php echo htmlentities($menu_third_v['title']); ?></a>
  92. </dd>
  93. <?php endforeach; ?>
  94. </dl>
  95. <?php endif; ?>
  96. </li>
  97. <?php endforeach; ?>
  98. </ul>
  99. </div>
  100. </div>
  101. <?php endif; ?>
  102. <div class="layui-body<?php if(empty($serond_menu) || (($serond_menu instanceof \think\Collection || $serond_menu instanceof \think\Paginator ) && $serond_menu->isEmpty())): ?> child_no_exit<?php endif; ?>">
  103. <!-- 面包屑 -->
  104. <?php if(count($serond_menu) > 0): ?>
  105. <div class="ns-crumbs<?php if(empty($serond_menu) || (($serond_menu instanceof \think\Collection || $serond_menu instanceof \think\Paginator ) && $serond_menu->isEmpty())): ?> child_no_exit<?php endif; ?>">
  106. <span class="layui-breadcrumb" lay-separator="-">
  107. <?php foreach($crumbs as $crumbs_k => $crumbs_v): if(count($crumbs) == ($crumbs_k + 1)): ?>
  108. <a href="<?php echo htmlentities($crumbs_v['url']); ?>"><cite><?php echo htmlentities($crumbs_v['title']); ?></cite></a>
  109. <?php else: ?>
  110. <a href="<?php echo htmlentities($crumbs_v['url']); ?>"><?php echo htmlentities($crumbs_v['title']); ?></a>
  111. <?php endif; ?>
  112. <?php endforeach; ?>
  113. </span>
  114. </div>
  115. <?php endif; ?>
  116. <div class="ns-body-content <?php if(count($serond_menu) < 1): ?> crumbs_no_exit<?php endif; ?>">
  117. <div class="ns-body">
  118. <!-- 四级导航 -->
  119. <?php if(isset($forth_menu) && !empty($forth_menu)): ?>
  120. <div class="fourstage-nav layui-tab layui-tab-brief" lay-filter="edit_user_tab">
  121. <ul class="layui-tab-title">
  122. <?php if(is_array($forth_menu) || $forth_menu instanceof \think\Collection || $forth_menu instanceof \think\Paginator): $i = 0; $__LIST__ = $forth_menu;if( count($__LIST__)==0 ) : echo "" ;else: foreach($__LIST__ as $key=>$menu): $mod = ($i % 2 );++$i;?>
  123. <li class="<?php echo $menu['selected']==1 ? 'layui-this' : ''; ?>" lay-id="basic_info"><a href="<?php echo htmlentities($menu['parse_url']); ?>"><?php echo htmlentities($menu['title']); ?></a></li>
  124. <?php endforeach; endif; else: echo "" ;endif; ?>
  125. </ul>
  126. </div>
  127. <?php endif; ?>
  128. <div class="layui-collapse ns-tips">
  129. <div class="layui-colla-item">
  130. <h2 class="layui-colla-title">操作提示</h2>
  131. <ul class="layui-colla-content layui-show">
  132. <li>用户列表展示,admin为系统用户,不可进行编辑</li>
  133. <li>可以添加用户,用于登录、管理平台端</li>
  134. <li>可对用户进行编辑,修改用户状态,当用户状态为锁定时,不可进行登录</li>
  135. <li>添加时选择用户组,对用户的操作权限进行限制</li>
  136. </ul>
  137. </div>
  138. </div>
  139. <!-- 搜索框 -->
  140. <div class="ns-single-filter-box">
  141. <button class="layui-btn ns-bg-color" onclick="add()">添加用户</button>
  142. <div class="layui-form">
  143. <div class="layui-input-inline">
  144. <input type="text" name="search_keys" placeholder="请输入用户名" autocomplete="off" class="layui-input">
  145. <button type="button" class="layui-btn layui-btn-primary" lay-filter="search" lay-submit>
  146. <i class="layui-icon">&#xe615;</i>
  147. </button>
  148. </div>
  149. </div>
  150. </div>
  151. <!-- 列表 -->
  152. <table id="user_list" lay-filter="user_list"></table>
  153. <!-- 操作 -->
  154. <script type="text/html" id="operation">
  155. <div class="ns-table-btn">
  156. {{# if(d.is_admin == 1){ }}
  157. <span class="ns-cursor ns-text-color-dark-gray">系统用户不可编辑</span>
  158. {{# }else{ }}
  159. <a class="layui-btn" lay-event="edit">编辑</a>
  160. <a class="layui-btn" lay-event="delete">删除</a>
  161. <a class="layui-btn" lay-event="reset_pass">重置密码</a>
  162. {{# } }}
  163. </div>
  164. </script>
  165. <!-- 状态 -->
  166. <script type="text/html" id="status">
  167. {{ d.status == 1 ? '正常' : '锁定'}}
  168. </script>
  169. </div>
  170. <!-- 版权信息 -->
  171. <div class="ns-footer">
  172. <div class="ns-footer-img">
  173. <a href="#"><img style="-webkit-filter: grayscale(100%);-moz-filter: grayscale(100%);-ms-filter: grayscale(100%);-o-filter: grayscale(100%);filter: grayscale(100%);filter: gray;" src="<?php if(!empty($copyright['logo'])): ?> <?php echo img($copyright['logo']); else: ?>http://yueshengshop.top/public/static/img/copyright_logo.png<?php endif; ?>" /></a>
  174. </div>
  175. </div>
  176. </div>
  177. </div>
  178. </div>
  179. <!-- 重置密码弹框html -->
  180. <div class="layui-form" id="reset_pass" style="display: none;">
  181. <div class="layui-form-item">
  182. <label class="layui-form-label"><span class="required">*</span>原密码</label>
  183. <div class="layui-input-block">
  184. <input type="password" id="old_pass" name="old_pass" required class="layui-input ns-len-mid" maxlength="18" autocomplete="off" readonly onfocus="this.removeAttribute('readonly');" onblur="this.setAttribute('readonly',true);">
  185. <span class="required"></span>
  186. </div>
  187. </div>
  188. <div class="layui-form-item">
  189. <label class="layui-form-label"><span class="required">*</span>新密码</label>
  190. <div class="layui-input-block">
  191. <input type="password" id="new_pass" name="new_pass" required class="layui-input ns-len-mid" maxlength="18" autocomplete="off" readonly onfocus="this.removeAttribute('readonly');" onblur="this.setAttribute('readonly',true);">
  192. <span class="required"></span>
  193. </div>
  194. </div>
  195. <div class="layui-form-item">
  196. <label class="layui-form-label"><span class="required">*</span>确认新密码</label>
  197. <div class="layui-input-block">
  198. <input type="password" id="repeat_pass" name="repeat_pass" required class="layui-input ns-len-mid" maxlength="18" autocomplete="off" readonly onfocus="this.removeAttribute('readonly');" onblur="this.setAttribute('readonly',true);">
  199. <span class="required"></span>
  200. </div>
  201. </div>
  202. <div class="ns-form-row">
  203. <button class="layui-btn ns-bg-color" onclick="repass()">确定</button>
  204. <button class="layui-btn layui-btn-primary" onclick="closePass()">返回</button>
  205. </div>
  206. </div>
  207. <script type="text/javascript">
  208. layui.use('element',function () {
  209. var element = layui.element;
  210. element.render('breadcrumb');
  211. });
  212. function clearCache () {
  213. $.ajax({
  214. type: 'post',
  215. url: ns.url("admin/Login/clearCache"),
  216. dataType: 'JSON',
  217. success: function(res) {
  218. layer.msg(res.message);
  219. location.reload();
  220. }
  221. })
  222. }
  223. /**
  224. * 重置密码
  225. */
  226. var index;
  227. function resetPassword() {
  228. index = layer.open({
  229. type:1,
  230. content:$('#reset_pass'),
  231. offset: 'auto',
  232. area: ['650px']
  233. });
  234. setTimeout(function() {
  235. $(".ns-reset-pass").removeClass('layui-this');
  236. }, 1000);
  237. }
  238. // $(".ns-reset-pass").on('click', function() {
  239. // $(this).removeClass('layui-this');
  240. // })
  241. var repeat_flag = false;
  242. function repass(){
  243. var old_pass = $("#old_pass").val();
  244. var new_pass = $("#new_pass").val();
  245. var repeat_pass = $("#repeat_pass").val();
  246. if (old_pass == '') {
  247. $("#old_pass").focus();
  248. layer.msg("原密码不能为空");
  249. return;
  250. }
  251. if (new_pass == '') {
  252. $("#new_pass").focus();
  253. layer.msg("密码不能为空");
  254. return;
  255. } else if ($("#new_pass").val().length < 6) {
  256. $("#new_pass").focus();
  257. layer.msg("密码不能少于6位数");
  258. return;
  259. }
  260. if (repeat_pass == '') {
  261. $("#repeat_pass").focus();
  262. layer.msg("密码不能为空");
  263. return;
  264. } else if ($("#repeat_pass").val().length < 6) {
  265. $("#repeat_pass").focus();
  266. layer.msg("密码不能少于6位数");
  267. return;
  268. }
  269. if (new_pass != repeat_pass) {
  270. $("#repeat_pass").focus();
  271. layer.msg("两次密码输入不一样,请重新输入");
  272. return;
  273. }
  274. if(repeat_flag)return;
  275. repeat_flag = true;
  276. $.ajax({
  277. type: "POST",
  278. dataType: 'JSON',
  279. url: ns.url("admin/login/modifypassword"),
  280. data: {"old_pass": old_pass,"new_pass": new_pass},
  281. success: function(res) {
  282. layer.msg(res.message);
  283. repeat_flag = false;
  284. if (res.code == 0) {
  285. layer.close(index);
  286. location.reload();
  287. }
  288. }
  289. });
  290. }
  291. function closePass() {
  292. layer.close(index);
  293. }
  294. layui.use('element', function() {
  295. var element = layui.element;
  296. element.init();
  297. });
  298. </script>
  299. <script>
  300. var table, form, laytpl, layer_pass, repeat_flag = false; //防重复标识
  301. layui.use(['form', 'laytpl'], function() {
  302. form = layui.form;
  303. laytpl = layui.laytpl;
  304. form.render();
  305. table = new Table({
  306. elem: '#user_list',
  307. url: ns.url("admin/user/user"),
  308. cols: [
  309. [{
  310. field: 'username',
  311. title: '用户名',
  312. width: '20%',
  313. unresize: 'false'
  314. }, {
  315. field: 'group_name',
  316. title: '用户组',
  317. width: '15%',
  318. unresize: 'false'
  319. }, {
  320. field: 'login_ip',
  321. title: '最后登录IP',
  322. width: '18%',
  323. unresize: 'false'
  324. }, {
  325. field: 'login_time',
  326. title: '最后登录时间',
  327. width: '18%',
  328. unresize: 'false',
  329. templet: function(data) {
  330. return ns.time_to_date(data.login_time); //创建时间转换方法
  331. }
  332. }, {
  333. field: 'status',
  334. title: '用户状态',
  335. width: '12%',
  336. unresize: 'false',
  337. templet: '#status'
  338. }, {
  339. title: '操作',
  340. width: '16%',
  341. toolbar: '#operation',
  342. unresize: 'false'
  343. }]
  344. ],
  345. });
  346. /**
  347. * 监听工具栏操作
  348. */
  349. table.tool(function(obj) {
  350. var data = obj.data;
  351. switch (obj.event) {
  352. case 'edit': //编辑
  353. location.href = ns.url("admin/user/editUser?uid=" + data.uid);
  354. break;
  355. case 'delete': //删除
  356. deleteUser(data.uid);
  357. break;
  358. case 'reset_pass': //重置密码
  359. resetPassword(data);
  360. break;
  361. }
  362. });
  363. /**
  364. * 删除
  365. */
  366. function deleteUser(uid) {
  367. if (repeat_flag) return false;
  368. repeat_flag = true;
  369. layer.confirm('确定要删除该用户吗?', function() {
  370. $.ajax({
  371. type: 'POST',
  372. dataType: 'JSON',
  373. url: ns.url("admin/user/deleteUser"),
  374. data: {uid},
  375. success: function(res) {
  376. layer.msg(res.message);
  377. repeat_flag = false;
  378. if (res.code == 0) {
  379. table.reload();
  380. }
  381. }
  382. });
  383. }, function () {
  384. layer.close();
  385. repeat_flag = false;
  386. });
  387. }
  388. /**
  389. * 重置密码
  390. */
  391. function resetPassword(data) {
  392. laytpl($("#pass_change").html()).render(data, function(html) {
  393. layer_pass = layer.open({
  394. title: '重置密码',
  395. skin: 'layer-tips-class',
  396. type: 1,
  397. area: ['600px'],
  398. content: html,
  399. });
  400. });
  401. }
  402. form.on('submit(repass)', function(data) {
  403. if (repeat_flag) return false;
  404. repeat_flag = true;
  405. $.ajax({
  406. type: "POST",
  407. dataType: 'JSON',
  408. url: ns.url("admin/user/modifyPassword"),
  409. data: data.field,
  410. success: function(res) {
  411. layer.msg(res.message);
  412. repeat_flag = false;
  413. if (res.code == 0) {
  414. layer.closeAll('page');
  415. }
  416. }
  417. });
  418. });
  419. /**
  420. * 搜索功能
  421. */
  422. form.on('submit(search)', function(data) {
  423. table.reload({
  424. page: {
  425. curr: 1
  426. },
  427. where: data.field
  428. });
  429. });
  430. /**
  431. * 表单验证
  432. */
  433. form.verify({
  434. repass: function(value) {
  435. if (value != $("input[name=password]").val()) {
  436. return "输入错误,两次密码不一致!";
  437. }
  438. }
  439. });
  440. });
  441. function add() {
  442. location.href = ns.url("admin/user/addUser");
  443. }
  444. function closePass() {
  445. layer.close(layer_pass);
  446. }
  447. </script>
  448. <!-- 重置密码弹框html -->
  449. <script type="text/html" id="pass_change">
  450. <div class="layui-form" id="reset_pass">
  451. <div class="layui-form-item">
  452. <label class="layui-form-label mid"><span class="required">*</span>新密码:</label>
  453. <div class="layui-input-block">
  454. <input type="password" id="new_pass" name="password" lay-verify="required" class="layui-input ns-len-mid" maxlength="18" autocomplete="off" readonly onfocus="this.removeAttribute('readonly');" onblur="this.setAttribute('readonly',true);">
  455. </div>
  456. </div>
  457. <div class="layui-form-item">
  458. <label class="layui-form-label mid"><span class="required">*</span>确认新密码:</label>
  459. <div class="layui-input-block">
  460. <input type="password" name="password" lay-verify="required|repass" class="layui-input ns-len-mid" maxlength="18" autocomplete="off" readonly onfocus="this.removeAttribute('readonly');" onblur="this.setAttribute('readonly',true);">
  461. </div>
  462. <div class="ns-word-aux mid">请再一次输入密码,两次输入密码须一致</div>
  463. </div>
  464. <div class="ns-form-row mid">
  465. <button class="layui-btn ns-bg-color" lay-submit lay-filter="repass">确定</button>
  466. <button class="layui-btn layui-btn-primary" onclick="closePass()">返回</button>
  467. </div>
  468. <input class="reset-pass-id" type="hidden" name="uid" value="{{d.uid}}"/>
  469. </div>
  470. </script>
  471. </body>
  472. </html>