file.ejs 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. <div class="panel-content">
  2. <div class="panel-title fluid">
  3. <div class="title-main d-flex justify-content-between">
  4. <div>资料归集/<%- ctx.subProject.name %></div>
  5. <div class="ml-auto">
  6. <% if (ctx.session.sessionUser.is_admin) { %>
  7. <a class="btn btn-sm btn-outline-primary mr-1" href="#filing-permission" data-toggle="modal" data-target="#filing-permission">授权用户</a>
  8. <% } %>
  9. </div>
  10. </div>
  11. </div>
  12. <div class="content-wrap row pr-46">
  13. <div class="row w-100 sub-content">
  14. <div class="c-body" id="left-view" style="width: 100%">
  15. <div class="sjs-height-0 row" style="width: 100%">
  16. <div class="col-3 border-right pr-0">
  17. <div class="d-flex flex-row">
  18. <div class="btn-group">
  19. <button type="button" class="btn btn-sm text-primary dropdown-toggle" data-toggle="dropdown" id="zhankai" aria-expanded="false">显示层级</button>
  20. <div class="dropdown-menu" aria-labelledby="zhankai" x-placement="bottom-start" style="position: absolute; transform: translate3d(0px, 21px, 0px); top: 0px; left: 0px; will-change: transform;">
  21. <a class="dropdown-item" name="showLevel" tag="1" href="javascript: void(0);">第一层</a>
  22. <a class="dropdown-item" name="showLevel" tag="2" href="javascript: void(0);">第二层</a>
  23. <a class="dropdown-item" name="showLevel" tag="3" href="javascript: void(0);">第三层</a>
  24. <a class="dropdown-item" name="showLevel" tag="4" href="javascript: void(0);">第四层</a>
  25. <a class="dropdown-item" name="showLevel" tag="last" href="javascript: void(0);">最底层</a>
  26. </div>
  27. </div>
  28. <% if (canFiling) { %>
  29. <div class="p-2"><a href="javascript: void(0);" id="add-slibing">添加同级</a></div>
  30. <div class="p-2"><a href="javascript: void(0);" id="add-child">添加子级</a></div>
  31. <% } %>
  32. </div>
  33. <ul id="filing" class="ztree" style="overflow: auto"></ul>
  34. </div>
  35. <div class="col-9 pr-0" id="file-view" style="display: none">
  36. <div class="d-flex flex-row">
  37. <% if (canUpload) { %>
  38. <div class="py-2 pr-2"><a href="#add-file" data-toggle="modal" data-target="#add-file">上传文件</a></div>
  39. <div class="py-2 pr-2"><a href="#add-big-file" data-toggle="modal" data-target="#add-big-file">大文件上传</a></div>
  40. <div class="p-2" id="rela-file-btn"><a href="#rela-file" data-toggle="modal" data-target="#rela-file">导入文件</a></div>
  41. <div class="p-2"><a href="javascript: void(0)" id="batch-del-file-btn">批量删除</a></div>
  42. <% } %>
  43. <div class="p-2"><a href="javascript: void(0)" id="batch-download">批量下载</a></div>
  44. <div class="p-2">
  45. <span id="showPage">
  46. <a href="javascript:void(0);" class="page-select ml-3" content="pre"><i class="fa fa-chevron-left"></i></a>
  47. <span id="curPage">1</span>/<span id="curTotalPage">10</span>
  48. <a href="javascript:void(0);" class="page-select mr-3" content="next"><i class="fa fa-chevron-right"></i></a>
  49. </span>
  50. </div>
  51. </div>
  52. <table class="table table-hover table-bordered">
  53. <thead>
  54. <tr class="text-center">
  55. <th width="60px">选择</th>
  56. <th>文件名称 <span name="file-sort" field="filename" tag="filename|desc"><i class="fa fa-sort" aria-hidden="true"></i></span></th>
  57. <th width="10%">上传人</th>
  58. <th width="20%">上传时间 <span name="file-sort" field="create_time" tag="create_time|asc"><i class="fa fa-sort-amount-desc" aria-hidden="true"></i></span></th>
  59. <th width="10%">文件类型</th>
  60. </tr>
  61. </thead>
  62. <tbody id="file-list">
  63. </tbody>
  64. </table>
  65. </div>
  66. </div>
  67. </div>
  68. <div class="c-body" id="right-view" style="display: none; width: 33%;">
  69. <div class="resize-x" id="right-spr" r-Type="width" div1="#left-view" div2="#right-view" title="调整大小" a-type="percent"></div>
  70. <div class="tab-content">
  71. <div id="search" class="tab-pane tab-select-show mr-1">
  72. <div class="sjs-bar mt-1">
  73. <div class="input-group input-group-sm pb-1">
  74. <div class="input-group-prepend">
  75. <select class="input-group-text" id="search-filter">
  76. <option value="cur">当前分类</option>
  77. <option value="all">全部分类</option>
  78. </select>
  79. </div>
  80. <input id="search-keyword" type="text" class="form-control" autocomplete="off" placeholder="输入文件名称查找" aria-label="Recipient\'s username" aria-describedby="button-addon2">
  81. <div class="input-group-append"><button class="btn btn-outline-secondary" type="button">搜索</button></div>
  82. </div>
  83. </div>
  84. <div class="sjs-sh scroll-y">
  85. <table class="table table-bordered">
  86. <tr class="text-center"><th>文件名称</th><th width="15%">上传人</th><th width="15%">操作</th></tr>
  87. <tbody id="search-list"></tbody>
  88. </table>
  89. </div>
  90. </div>
  91. <div id="reference" class="tab-pane tab-select-show">
  92. </div>
  93. </div>
  94. </div>
  95. </div>
  96. <!--右侧菜单-->
  97. <div class="side-menu">
  98. <ul class="nav flex-column right-nav" id="side-menu">
  99. <li>
  100. <a class="nav-link" content="#search" href="javascript: void(0);">查找定位</a>
  101. </li>
  102. <li>
  103. <a class="nav-link" content="#reference" href="javascript: void(0);">参考文件</a>
  104. </li>
  105. </ul>
  106. </div>
  107. </div>
  108. </div>
  109. <script>
  110. const canFiling = <%- canFiling %>;
  111. const filing = JSON.parse(unescape('<%- escape(JSON.stringify(filing)) %>'));
  112. const category = JSON.parse(unescape('<%- escape(JSON.stringify(categoryData)) %>'));
  113. const whiteList = JSON.parse('<%- JSON.stringify(ctx.app.config.multipart.whitelist) %>');
  114. const canDelete = <%- canDelete %>;
  115. const fileReferenceList = JSON.parse('<%- JSON.stringify(fileReferenceList) %>');
  116. </script>