archivelist.html 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. {extend name="../../base/view/common/base" /}
  2. <!-- 主体 -->
  3. {block name="body"}
  4. <div class="p-page">
  5. <div class="layui-card border-x border-t" style="margin-bottom:0; box-shadow:0 0 0 0 rgb(5 32 96 / 0%)">
  6. <div class="body-table layui-tab layui-tab-brief" lay-filter="tab">
  7. <ul class="layui-tab-title">
  8. <li><a href="/contract/contract/archivelist">销售合同</a></li>
  9. <li class="layui-this"><a href="/contract/purchase/archivelist">采购合同</a></li>
  10. </ul>
  11. </div>
  12. </div>
  13. <form class="layui-form gg-form-bar border-x">
  14. <div class="layui-input-inline" style="width:122px;">
  15. <select name="types">
  16. <option value="">选择合同性质</option>
  17. <option value="1">普通采购</option>
  18. <option value="2">物品采购</option>
  19. <option value="3">服务采购</option>
  20. </select>
  21. </div>
  22. <div class="layui-input-inline" style="width:122px;">
  23. <select name="cate_id">
  24. <option value="">选择合同类别</option>
  25. {volist name=":get_base_data('ContractCate');" id="vo"}
  26. <option value="{$vo.id}">{$vo.title}</option>
  27. {/volist}
  28. </select>
  29. </div>
  30. <div class="layui-input-inline" style="width:175px;">
  31. <input type="text" class="layui-input" id="sign_time" placeholder="选择合同签订日期" readonly name="sign_time">
  32. </div>
  33. <div class="layui-input-inline" style="width:175px;">
  34. <input type="text" class="layui-input" id="end_time" placeholder="选择合同到期日期" readonly name="end_time">
  35. </div>
  36. <div class="layui-input-inline" style="width:220px;">
  37. <input type="text" name="keywords" placeholder="输入关键字,合同编号/合同名称" class="layui-input" autocomplete="off" />
  38. </div>
  39. <div class="layui-input-inline" style="width:150px">
  40. <input type="hidden" name="tab" value="0" />
  41. <button class="layui-btn layui-btn-normal" lay-submit="" lay-filter="table-search"><i class="layui-icon layui-icon-search mr-1"></i>搜索</button>
  42. <button type="reset" class="layui-btn layui-btn-reset" lay-filter="table-reset">清空</button>
  43. </div>
  44. </form>
  45. <table class="layui-hide" id="table_contract" lay-filter="table_contract"></table>
  46. </div>
  47. <script type="text/html" id="toolbarDemo">
  48. <div class="layui-btn-container">
  49. <h3>归档合同</h3>
  50. </div>
  51. </script>
  52. {/block}
  53. <!-- /主体 -->
  54. <!-- 脚本 -->
  55. {block name="script"}
  56. <script>
  57. const delay_num = {$delay_num|default=30};
  58. const moduleInit = ['tool','tablePlus','laydatePlus'];
  59. function gouguInit() {
  60. var table = layui.tablePlus,dropdown = layui.dropdown, tool = layui.tool,laydatePlus = layui.laydatePlus;
  61. //日期范围
  62. var sign_time = new laydatePlus({'target':'sign_time'});
  63. var end_time = new laydatePlus({'target':'end_time'});
  64. layui.pageTable = table.render({
  65. elem: "#table_contract"
  66. , toolbar: "#toolbarDemo"
  67. ,url: "/contract/purchase/archivelist"
  68. ,is_excel: true
  69. ,page: true
  70. ,limit: 20
  71. ,cellMinWidth: 60
  72. ,height: 'full-154'
  73. ,cols: [[ //表头
  74. {
  75. field: 'id',
  76. title: 'ID号',
  77. align: 'center',
  78. width: 80
  79. },{
  80. field: 'code',
  81. title: '合同编号',
  82. align: 'center',
  83. width: 150
  84. },{
  85. field: 'name',
  86. title: '合同名称',
  87. minWidth:240,
  88. templet: '<div><a data-href="/contract/purchase/view/id/{{d.id}}.html" class="side-a">{{d.name}}</a></div>'
  89. },{
  90. field: 'cate_title',
  91. title: '合同类别',
  92. align: 'center',
  93. width: 100
  94. },{
  95. field: 'types_name',
  96. title: '合同性质',
  97. align: 'center',
  98. width: 80,
  99. templet: function (d) {
  100. var html = '<span class="layui-color-' + d.types + '">' + d.types_name + '</span>';
  101. return html;
  102. }
  103. },{
  104. field: 'interval_time',
  105. title: '合同有效时间',
  106. align: 'center',
  107. width: 268,
  108. templet: function (d) {
  109. var html = d.interval_time;
  110. if (d.delay > 0 && d.delay < delay_num) {
  111. html += '<span class="red ml-1" style="font-size:12px;">' + d.delay + '天后到期</span>';
  112. }
  113. if (d.delay == 0) {
  114. html += '<span class="red ml-1" style="font-size:12px;">已过期</span>';
  115. }
  116. return html;
  117. }
  118. },{
  119. field: 'cost',
  120. title: '合同金额(元)',
  121. align: 'right',
  122. width: 100
  123. },{
  124. field: 'archive_name',
  125. title: '归档人',
  126. align: 'center',
  127. width: 80
  128. },{
  129. field: 'archive_time',
  130. title: '归档日期',
  131. align: 'center',
  132. width: 90
  133. },{
  134. field: 'sign_name',
  135. title: '签定人',
  136. align: 'center',
  137. width: 80
  138. },{
  139. field: 'sign_time',
  140. title: '签订日期',
  141. align: 'center',
  142. width: 90
  143. },{
  144. field: 'keeper_name',
  145. title: '保管人',
  146. align: 'center',
  147. width: 80
  148. },{
  149. field: 'right',
  150. fixed:'right',
  151. title: '操作',
  152. width: 60,
  153. align: 'center',
  154. ignoreExport:true,
  155. templet: function (d) {
  156. var btn0='<span class="layui-btn layui-btn-normal layui-btn-xs" lay-event="view">详情</span>';
  157. return btn0;
  158. }
  159. }
  160. ]]
  161. });
  162. table.on('tool(table_contract)',function (obj) {
  163. var checkStatus = table.checkStatus(obj.config.id); //获取选中行状态
  164. var data = obj.data;
  165. if (obj.event === 'view') {
  166. tool.side("/contract/purchase/view?id="+data.id);
  167. return;
  168. }
  169. });
  170. }
  171. </script>
  172. {/block}
  173. <!-- /脚本 -->