permission.ejs 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <% include ./sub_menu.ejs %>
  2. <div class="panel-content">
  3. <div class="panel-title">
  4. <div class="title-main">
  5. <h2>账号管理
  6. <a href="#sel-batch" data-toggle="modal" data-target="#sel-batch" class="btn btn-primary btn-sm pull-right mr-1">选择账号</a>
  7. <a href="/setting/user" class="btn btn-primary btn-sm pull-right mr-1">新增账号</a>
  8. </h2>
  9. </div>
  10. </div>
  11. <div class="content-wrap">
  12. <div class="c-body">
  13. <div class="sjs-height-0">
  14. <nav class="nav nav-tabs m-3" role="tablist">
  15. <a class="nav-item nav-link" href="/sp/<%- ctx.subProject.id %>/setting/user" aria-selected="false">账号列表</a>
  16. <a class="nav-item nav-link active" href="/sp/<%- ctx.subProject.id %>/setting/user/permission?type=<%- ptype %><%- (keyword ? '&keyword=' + keyword : '')%>" aria-selected="true">模块权限</a>
  17. <div class="ml-auto">
  18. <form class="input-group input-group-sm" method="get">
  19. <input type="hidden" class="form-control" value="<%- ptype %>" name="ptype">
  20. <input type="text" class="form-control" placeholder="账号/姓名/单位/手机 搜索" aria-label="账号/姓名/单位/手机 搜索" value="<%- keyword %>" aria-describedby="button-addon2" name="keyword">
  21. <div class="input-group-append">
  22. <button class="btn btn-outline-primary" type="submit" id="search"><i class="fa fa-search"></i></button>
  23. </div>
  24. </form>
  25. </div>
  26. </nav>
  27. <div class="tab-content m-3">
  28. <div id="user-purview" class="tab-pane active">
  29. <div class="row">
  30. <div class="col-3">
  31. <dl class="list-group">
  32. <a href="/sp/<%- ctx.subProject.id %>/setting/user/permission?ptype=datacollect<%- (keyword ? '&keyword=' + keyword : '')%>" class="list-group-item list-group-item-action <%- (ptype === 'datacollect' ? 'active' : '') %>">决策大屏</a>
  33. <a href="/sp/<%- ctx.subProject.id %>/setting/user/permission?ptype=info<%- (keyword ? '&keyword=' + keyword : '')%>" class="list-group-item list-group-item-action <%- (ptype === 'info' ? 'active' : '') %>">项目概况</a>
  34. <a href="/sp/<%- ctx.subProject.id %>/setting/user/permission?ptype=contract<%- (keyword ? '&keyword=' + keyword : '')%>" class="list-group-item list-group-item-action <%- (ptype === 'contract' ? 'active' : '') %>">合同管理</a>
  35. <a href="/sp/<%- ctx.subProject.id %>/setting/user/permission?ptype=file<%- (keyword ? '&keyword=' + keyword : '')%>" class="list-group-item list-group-item-action <%- (ptype === 'file' ? 'active' : '') %>">资料归集</a>
  36. <a href="/sp/<%- ctx.subProject.id %>/setting/user/permission?ptype=budget<%- (keyword ? '&keyword=' + keyword : '')%>" class="list-group-item list-group-item-action <%- (ptype === 'budget' ? 'active' : '') %>">动态投资</a>
  37. <dd class="list-group-item">资金监管</dd>
  38. <a href="/sp/<%- ctx.subProject.id %>/setting/user/permission?ptype=fund_trans<%- (keyword ? '&keyword=' + keyword : '')%>" class="list-group-item list-group-item-action <%- (ptype === 'fund_trans' ? 'active' : '') %>"><span class="ml-4"></span>资金划拨</a>
  39. <a href="/sp/<%- ctx.subProject.id %>/setting/user/permission?ptype=fund_pay<%- (keyword ? '&keyword=' + keyword : '')%>" class="list-group-item list-group-item-action <%- (ptype === 'fund_pay' ? 'active' : '') %>"><span class="ml-4"></span>资金支付</a>
  40. <a href="/sp/<%- ctx.subProject.id %>/setting/user/permission?ptype=payment<%- (keyword ? '&keyword=' + keyword : '')%>" class="list-group-item list-group-item-action <%- (ptype === 'payment' ? 'active' : '') %>">支付审批</a>
  41. </dl>
  42. </div>
  43. <div class="col-9">
  44. <div class="card mb-2">
  45. <div class="card-header d-flex justify-content-between">
  46. <div>
  47. <%- ptypeStr %>
  48. <% if (ptypeHint) { %>
  49. <div class="btn-group">
  50. <a href="javascript:void(0);" data-toggle="dropdown" title="权限说明" aria-expanded="false"><i class="fa fa-question-circle"></i></a>
  51. <div class="dropdown-menu bg-dark" style="will-change: transform;">
  52. <% for (const i of ptypeHint) { %>
  53. <div class="dropdown-item text-light bg-dark"><%- i %></div>
  54. <% } %>
  55. </div>
  56. </div>
  57. <% } %>
  58. </div>
  59. <div class="ml-auto">
  60. <div class="form-check form-check-inline">
  61. <span style="margin:0 .5rem 0 1rem; font-weight: bold;">筛选已授权</span>
  62. <div class="custom-control custom-switch">
  63. <input type="checkbox" class="custom-control-input" id="filter-valid">
  64. <label class="custom-control-label" for="filter-valid"></label>
  65. </div>
  66. </div>
  67. <button class="btn btn-sm btn-warning" id="save-permission" style="display: none;">保存</button>
  68. </div>
  69. </div>
  70. <div class="card-body py-2 scroll-y" id="sp-pageshow-content">
  71. <table class="table table-hover table-bordered table-sm">
  72. <thead><tr class="text-center">
  73. <th width="120px">用户</th>
  74. <th width="240px">公司</th>
  75. <th width="150px">职位</th>
  76. <% for (const key in permissionConst) { %>
  77. <th><%- permissionConst[key].title %></th>
  78. <% } %>
  79. </tr>
  80. </thead>
  81. <tbody class="text-center">
  82. <% for (const user of subProjectAccountList) { %>
  83. <% const tp = user[ptype + '_permission'].split(','); %>
  84. <tr name="user-permission" class="permission-parent" pid="<%- user.permission_id %>">
  85. <td><%- user.name %></td>
  86. <td><%- user.company %></td>
  87. <td><%- user.role %></td>
  88. <% for (const key in permissionConst) { %>
  89. <td><input type="checkbox" name="permission-check" ptype="<%- ptype %>" pvalue="<%- permissionConst[key].value %>" <%- (tp.indexOf(permissionConst[key].value + '') >= 0 ? 'checked' : '') %> onchange="$('#save-permission').show();"></td>
  90. <% } %>
  91. </tr>
  92. <% } %>
  93. </tbody>
  94. </table>
  95. </div>
  96. </div>
  97. </div>
  98. </div>
  99. </div>
  100. </div>
  101. </div>
  102. </div>
  103. </div>
  104. </div>
  105. <script>
  106. const accountGroup = JSON.parse(unescape('<%- escape(JSON.stringify(accountGroup)) %>'));
  107. const accountList = JSON.parse(unescape('<%- escape(JSON.stringify(accountList)) %>'));
  108. const permissionConst = JSON.parse(unescape('<%- escape(JSON.stringify(permissionConst)) %>'));
  109. const reCalcHeight = function () {
  110. $('#sp-pageshow-content').height($(window).height() - 187);
  111. }
  112. reCalcHeight();
  113. $(window).resize(reCalcHeight);
  114. </script>