permission.ejs 8.9 KB

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