datacollect.ejs 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  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(projectData.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(projectData.data_collect_pages, is_dz1.toString()) !== -1) { %>(已开启<% if (ctx.session.sessionProject.dataCollect === is_dz1) { %>、默认<% } %>)<% } %></a>
  22. <% } %>
  23. <div class="ml-auto">
  24. <!--<div class="form-check form-check-inline">-->
  25. <!--<input class="form-check-input" type="checkbox" id="show-datacollect" value="option1" <% if (ctx.session.sessionProject.dataCollect) { %>checked<% } %>>-->
  26. <!--<label class="form-check-label" for="show-datacollect">数据大屏显示</label>-->
  27. <!--</div>-->
  28. <div class="d-inline-block form-group form-check mt-2">
  29. <div class="custom-control custom-switch">
  30. <input type="checkbox" class="custom-control-input" id="show_datacollect" <% if (ctx.session.sessionProject.dataCollect !== 0) { %>checked<% } %>>
  31. <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>
  32. </div>
  33. </div>
  34. <div class="d-inline-block form-group form-check mt-2">
  35. <div class="custom-control custom-switch">
  36. <input type="checkbox" class="custom-control-input" id="default_datacollect" <% if (ctx.session.sessionProject.dataCollect !== 0) { %>checked<% } %>>
  37. <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>
  38. </div>
  39. </div>
  40. </div>
  41. </nav>
  42. <div class="tab-content m-3">
  43. <% for (let i = 1; i <= 2; i++) { %>
  44. <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>
  45. <% } %>
  46. <% if (is_dz1) { %>
  47. <div id="shujudaping-<%- is_dz1 %>" class="tab-pane<% if (ctx.session.sessionProject.dataCollect === is_dz1) { %> active<% } %>"><img src="/public/images/juecedaping0<%- is_dz1 %>.png" width="100%"></div>
  48. <% } %>
  49. </div>
  50. </div>
  51. </div>
  52. </div>
  53. </div>
  54. <script src="/public/js/setting_datacollect_tender.js"></script>
  55. <script src="/public/js/PinYinOrder.bundle.js"></script>
  56. <script src="/public/js/tender_showhide.js"></script>
  57. <script src="/public/js/shares/tender_list_order.js"></script>
  58. <script>
  59. let dataCollectPages = JSON.parse(unescape('<%- escape(JSON.stringify(projectData.data_collect_pages)) %>'));
  60. let dataCollect = parseInt('<%- ctx.session.sessionProject.dataCollect %>');
  61. const category = JSON.parse(unescape('<%- escape(JSON.stringify(categoryData)) %>'));
  62. const tenders = JSON.parse(unescape('<%- escape(JSON.stringify(tenders)) %>'));
  63. let dcTenders = JSON.parse(unescape('<%- escape(JSON.stringify(dcTenders)) %>'));
  64. let addDataCollect = JSON.parse(unescape('<%- escape(JSON.stringify(ctx.session.sessionProject.page_show.addDataCollect)) %>'));
  65. let is_dz1 = <% if (is_dz1) { %>parseInt('<%- is_dz1 %>');<% } else { %>false;<% } %>
  66. $(function () {
  67. autoFlashHeight();
  68. // 开启及关闭展示
  69. $('#show_datacollect').change(function () {
  70. const activePage = $('#tablist').find('.active').data('datacollect').toString();
  71. if ($(this).is(':checked')) {
  72. dataCollectPages.push(activePage);
  73. dataCollectPages.sort();
  74. if (dataCollect === 0) {
  75. dataCollect = parseInt(activePage);
  76. $('#default_datacollect').prop('checked', true);
  77. }
  78. } else {
  79. dataCollectPages.map((val, i) => {
  80. if (val === activePage) {
  81. dataCollectPages.splice(i, 1);
  82. }
  83. });
  84. if (dataCollectPages.length === 0) {
  85. dataCollect = 0;
  86. } else if (dataCollectPages.length !== 0 && dataCollect === parseInt(activePage)){
  87. dataCollect = parseInt(dataCollectPages[0]);
  88. }
  89. $('#default_datacollect').prop('checked', false);
  90. }
  91. postData('/setting/datacollect/save', { type: 'show', data_collect_pages: dataCollectPages, data_collect: dataCollect }, function (result) {
  92. updateTab();
  93. })
  94. });
  95. $('#default_datacollect').change(function () {
  96. const activePage = $('#tablist').find('.active').data('datacollect').toString();
  97. if ($(this).is(':checked')) {
  98. dataCollect = parseInt(activePage);
  99. $('#show_datacollect').prop('checked', true);
  100. if (_.indexOf(dataCollectPages, activePage) === -1) {
  101. dataCollectPages.push(activePage);
  102. dataCollectPages.sort();
  103. }
  104. } else {
  105. if (dataCollectPages.length === 1) {
  106. dataCollect = 0;
  107. dataCollectPages = [];
  108. $('#show_datacollect').prop('checked', false);
  109. } else {
  110. dataCollect = parseInt(dataCollectPages[0]) === dataCollect ? parseInt(dataCollectPages[1]) : parseInt(dataCollectPages[0]);
  111. }
  112. }
  113. updateTab();
  114. postData('/setting/datacollect/save', { type: 'show', data_collect_pages: dataCollectPages, data_collect: dataCollect }, function (result) {
  115. updateTab();
  116. })
  117. })
  118. function updateTab() {
  119. for (let i = 1; i <= 2; i++) {
  120. let msg = '';
  121. if (_.indexOf(dataCollectPages, i.toString()) !== -1) {
  122. msg = '(已开启' + (i=== dataCollect ? '、默认' : '') + ')' ;
  123. }
  124. $('#tablist a').eq(i-1).text('决策大屏' + transFormToChinese(i) + msg);
  125. }
  126. if (is_dz1) {
  127. let msg = '';
  128. if (_.indexOf(dataCollectPages, is_dz1.toString()) !== -1) {
  129. msg = '(已开启' + (is_dz1=== dataCollect ? '、默认' : '') + ')' ;
  130. }
  131. $('#tablist a').eq(is_dz1-3).text('决策大屏' + transFormToChinese(is_dz1) + msg);
  132. }
  133. }
  134. $('#tablist a').click(function () {
  135. const page = parseInt($(this).data('datacollect'));
  136. if (_.indexOf(dataCollectPages, page.toString()) !== -1) {
  137. $('#show_datacollect').prop('checked', true);
  138. } else {
  139. $('#show_datacollect').prop('checked', false);
  140. }
  141. if (page === dataCollect) {
  142. $('#default_datacollect').prop('checked', true);
  143. } else {
  144. $('#default_datacollect').prop('checked', false);
  145. }
  146. });
  147. })
  148. </script>