datacollect.ejs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  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="#power" data-toggle="modal" data-target="#power" class="btn btn-primary btn-sm pull-right">权限管理</a>
  7. <a href="javascript:void(0);" id="tenderBtn" 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" id="tablist" role="tablist">
  15. <% for (let i = 1; i <= 2; i++) { %>
  16. <a class="nav-item nav-link<% if ((ctx.session.sessionProject.dataCollect === 0 && i === 1) || ctx.session.sessionProject.dataCollect === i) { %> active<% } %>" data-datacollect="<%- i %>" data-toggle="tab" href="#shujudaping-<%- i %>" role="tab">
  17. 决策大屏<%- ctx.helper.transFormToChinese(i) %><% if (ctx.helper._.indexOf(ctx.subProject.data_collect_pages, i.toString()) !== -1) { %>(已开启<% if (i === ctx.session.sessionProject.dataCollect) { %>、默认<% } %>)<% } %></a>
  18. <% } %>
  19. <% if (is_dz1) { %>
  20. <a class="nav-item nav-link<% if (ctx.session.sessionProject.dataCollect === is_dz1) { %> active<% } %>" data-datacollect="<%- is_dz1 %>" data-toggle="tab" href="#shujudaping-<%- is_dz1 %>" role="tab">
  21. 决策大屏<%- ctx.helper.transFormToChinese(is_dz1) %><% if (ctx.helper._.indexOf(ctx.subProject.data_collect_pages, is_dz1.toString()) !== -1) { %>(已开启<% if (ctx.session.sessionProject.dataCollect === is_dz1) { %>、默认<% } %>)<% } %></a>
  22. <% } %>
  23. <% if (is_dz2) { %>
  24. <a class="nav-item nav-link<% if (ctx.session.sessionProject.dataCollect === is_dz2) { %> active<% } %>" data-datacollect="<%- is_dz2 %>" data-toggle="tab" href="#shujudaping-<%- is_dz2 %>" role="tab">
  25. 决策大屏<%- ctx.helper.transFormToChinese(is_dz2) %><% if (ctx.helper._.indexOf(ctx.subProject.data_collect_pages, is_dz2.toString()) !== -1) { %>(已开启<% if (ctx.session.sessionProject.dataCollect === is_dz2) { %>、默认<% } %>)<% } %></a>
  26. <% } %>
  27. <div class="ml-auto">
  28. <!--<div class="form-check form-check-inline">-->
  29. <!--<input class="form-check-input" type="checkbox" id="show-datacollect" value="option1" <% if (ctx.session.sessionProject.dataCollect) { %>checked<% } %>>-->
  30. <!--<label class="form-check-label" for="show-datacollect">数据大屏显示</label>-->
  31. <!--</div>-->
  32. <div class="d-inline-block form-group form-check mt-2">
  33. <div class="custom-control custom-switch">
  34. <input type="checkbox" class="custom-control-input" id="show_datacollect" <% if (ctx.session.sessionProject.dataCollect !== 0) { %>checked<% } %>>
  35. <label class="custom-control-label" for="show_datacollect">开启<i class="fa fa-question-circle text-primary" data-placement="bottom" data-toggle="tooltip" data-original-title="开启后,在决策大屏模块显示"></i></label>
  36. </div>
  37. </div>
  38. <div class="d-inline-block form-group form-check mt-2">
  39. <div class="custom-control custom-switch">
  40. <input type="checkbox" class="custom-control-input" id="default_datacollect" <% if (ctx.session.sessionProject.dataCollect !== 0) { %>checked<% } %>>
  41. <label class="custom-control-label" for="default_datacollect">默认<i class="fa fa-question-circle text-primary" data-placement="bottom" data-toggle="tooltip" data-original-title="决策大屏第一个显示"></i></label>
  42. </div>
  43. </div>
  44. </div>
  45. </nav>
  46. <div class="tab-content m-3">
  47. <% for (let i = 1; i <= 2; i++) { %>
  48. <div id="shujudaping-<%- i %>" class="tab-pane<% if ((ctx.session.sessionProject.dataCollect === 0 && i === 1) || ctx.session.sessionProject.dataCollect === i) { %> active<% } %>"><img src="/public/images/juecedaping0<%- i %>.png" width="100%"></div>
  49. <% } %>
  50. <% if (is_dz1) { %>
  51. <div id="shujudaping-<%- is_dz1 %>" class="tab-pane<% if (ctx.session.sessionProject.dataCollect === is_dz1) { %> active<% } %>">
  52. 山东济邹项目定制(MI22U)<img src="/public/images/juecedaping0<%- is_dz1 %>.png" width="100%">
  53. </div>
  54. <% } %>
  55. <% if (is_dz2) { %>
  56. <div id="shujudaping-<%- is_dz2 %>" class="tab-pane<% if (ctx.session.sessionProject.dataCollect === is_dz2) { %> active<% } %>">
  57. <span>四川广元路桥集团计量内控管理云平台定制(GY18Y)</span><a class="nav-link" style="display: inline-block;" data-toggle="modal" href="#dpsix-set" data-target="#dpsix-set" title="决策大屏六设置"><i class="fa fa-cog"></i></a><img src="/public/images/juecedaping0<%- is_dz2 %>.png" width="100%">
  58. </div>
  59. <% } %>
  60. </div>
  61. </div>
  62. </div>
  63. </div>
  64. </div>
  65. <script src="/public/js/setting_datacollect_tender.js"></script>
  66. <script src="/public/js/PinYinOrder.bundle.js"></script>
  67. <script src="/public/js/tender_showhide.js"></script>
  68. <script src="/public/js/shares/tender_list_order.js"></script>
  69. <script>
  70. let dataCollectPages = JSON.parse(unescape('<%- escape(JSON.stringify(ctx.subProject.data_collect_pages)) %>'));
  71. let dataCollect = parseInt('<%- ctx.session.sessionProject.dataCollect %>');
  72. const category = JSON.parse(unescape('<%- escape(JSON.stringify(categoryData)) %>'));
  73. const tenders = JSON.parse(unescape('<%- escape(JSON.stringify(tenders)) %>'));
  74. let dcTenders = JSON.parse(unescape('<%- escape(JSON.stringify(dcTenders)) %>'));
  75. let addDataCollect = JSON.parse(unescape('<%- escape(JSON.stringify(ctx.session.sessionProject.page_show.addDataCollect)) %>'));
  76. let is_dz1 = <% if (is_dz1) { %>parseInt('<%- is_dz1 %>');<% } else { %>false;<% } %>
  77. let is_dz2 = <% if (is_dz2) { %>parseInt('<%- is_dz2 %>');<% } else { %>false;<% } %>
  78. $(function () {
  79. autoFlashHeight();
  80. // 开启及关闭展示
  81. $('#show_datacollect').change(function () {
  82. const activePage = $('#tablist').find('.active').data('datacollect').toString();
  83. if ($(this).is(':checked')) {
  84. dataCollectPages.push(activePage);
  85. dataCollectPages.sort();
  86. if (dataCollect === 0) {
  87. dataCollect = parseInt(activePage);
  88. $('#default_datacollect').prop('checked', true);
  89. }
  90. } else {
  91. dataCollectPages.map((val, i) => {
  92. if (val === activePage) {
  93. dataCollectPages.splice(i, 1);
  94. }
  95. });
  96. if (dataCollectPages.length === 0) {
  97. dataCollect = 0;
  98. } else if (dataCollectPages.length !== 0 && dataCollect === parseInt(activePage)){
  99. dataCollect = parseInt(dataCollectPages[0]);
  100. }
  101. $('#default_datacollect').prop('checked', false);
  102. }
  103. postData('/setting/datacollect/save', { type: 'show', data_collect_pages: dataCollectPages, data_collect: dataCollect }, function (result) {
  104. updateTab();
  105. })
  106. });
  107. $('#default_datacollect').change(function () {
  108. const activePage = $('#tablist').find('.active').data('datacollect').toString();
  109. if ($(this).is(':checked')) {
  110. dataCollect = parseInt(activePage);
  111. $('#show_datacollect').prop('checked', true);
  112. if (_.indexOf(dataCollectPages, activePage) === -1) {
  113. dataCollectPages.push(activePage);
  114. dataCollectPages.sort();
  115. }
  116. } else {
  117. if (dataCollectPages.length === 1) {
  118. dataCollect = 0;
  119. dataCollectPages = [];
  120. $('#show_datacollect').prop('checked', false);
  121. } else {
  122. dataCollect = parseInt(dataCollectPages[0]) === dataCollect ? parseInt(dataCollectPages[1]) : parseInt(dataCollectPages[0]);
  123. }
  124. }
  125. updateTab();
  126. postData('/setting/datacollect/save', { type: 'show', data_collect_pages: dataCollectPages, data_collect: dataCollect }, function (result) {
  127. updateTab();
  128. })
  129. })
  130. function updateTab() {
  131. for (let i = 1; i <= 2; i++) {
  132. let msg = '';
  133. if (_.indexOf(dataCollectPages, i.toString()) !== -1) {
  134. msg = '(已开启' + (i=== dataCollect ? '、默认' : '') + ')' ;
  135. }
  136. $('#tablist a').eq(i-1).text('决策大屏' + transFormToChinese(i) + msg);
  137. }
  138. if (is_dz1) {
  139. let msg = '';
  140. if (_.indexOf(dataCollectPages, is_dz1.toString()) !== -1) {
  141. msg = '(已开启' + (is_dz1=== dataCollect ? '、默认' : '') + ')' ;
  142. }
  143. $('#tablist a').eq(is_dz1-3).text('决策大屏' + transFormToChinese(is_dz1) + msg);
  144. }
  145. if (is_dz2) {
  146. let msg = '';
  147. if (_.indexOf(dataCollectPages, is_dz2.toString()) !== -1) {
  148. msg = '(已开启' + (is_dz2=== dataCollect ? '、默认' : '') + ')' ;
  149. }
  150. $('#tablist a').eq(is_dz2-3).text('决策大屏' + transFormToChinese(is_dz2) + msg);
  151. }
  152. }
  153. $('#tablist a').click(function () {
  154. const page = parseInt($(this).data('datacollect'));
  155. if (_.indexOf(dataCollectPages, page.toString()) !== -1) {
  156. $('#show_datacollect').prop('checked', true);
  157. } else {
  158. $('#show_datacollect').prop('checked', false);
  159. }
  160. if (page === dataCollect) {
  161. $('#default_datacollect').prop('checked', true);
  162. } else {
  163. $('#default_datacollect').prop('checked', false);
  164. }
  165. });
  166. })
  167. </script>