side_tools.js 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. /**
  2. * Created by Mai on 2017/6/16.
  3. */
  4. $(window).resize(function() {
  5. autoFlashHeight();
  6. if ($('#stdRationChapter').width() > 0) {
  7. sheetCommonObj.setColumnWidthByRate($('#stdRationChapter').width() - 30, rationLibObj.rationChapterSpread, rationLibObj.rationChapterTreeSetting.cols);
  8. }
  9. billsGuidance.setColumnWidthByRate(billsGuidance.elfItem.workBook, $('#zy').width(), billsGuidance.elfItem.headers);
  10. billsGuidance.refreshWorkBook();
  11. rationLibObj.refreshSpread();
  12. //BillsElf.setColumnWidthByRate();
  13. loadSideToolsHeight();
  14. //刷新主界面与各库中间的拖动条宽度:始终保持为一个宽度(在小窗口打开一个库,再放大窗口后,该拖动条宽度会变大)
  15. SlideResize.setResizeWidth($('#sideResize'));
  16. subObj.initGljSubTab();
  17. refreshSubSpread();
  18. });
  19. //造价书与各库左右拖动
  20. let sideResizeEles = {};
  21. sideResizeEles.eleObj = {
  22. module: 'stdBillsGuidanceTab',
  23. resize: $('#sideResize'),
  24. parent: $('#mainRow'),
  25. left: $('#main'),
  26. right: $('#mainSide')
  27. };
  28. sideResizeEles.limit = {
  29. min: 150,
  30. max: `$('#mainRow').width()-150`
  31. };
  32. SlideResize.horizontalSlide(sideResizeEles.eleObj, sideResizeEles.limit, function(){
  33. // MaterialController.showReplaceDiv();
  34. subObj.initGljSubTab();
  35. //BillsElf.setColumnWidthByRate();
  36. projectObj.refreshMainSpread();
  37. refreshSubSpread();
  38. if (sideResizeEles.eleObj.module === 'stdBillsGuidanceTab') {//清单精灵(规则)
  39. billsGuidance.setColumnWidthByRate(billsGuidance.elfItem.workBook, $('#zy').width(), billsGuidance.elfItem.headers);
  40. billsGuidance.refreshWorkBook();
  41. } else if (sideResizeEles.eleObj.module === 'stdRationTab') {//定额库
  42. sheetCommonObj.setColumnWidthByRate($('#stdRationChapter').width() - 40, rationLibObj.rationChapterSpread, rationLibObj.rationChapterTreeSetting.cols);
  43. rationLibObj.refreshSpread();
  44. } else if (sideResizeEles.eleObj.module === 'blockLibTab') {//块模板库
  45. blockLibObj.refreshSpread();
  46. } else if (sideResizeEles.eleObj.module === 'locateTab'){//查找定位
  47. locateObject.refreshWorkBook();
  48. }
  49. });
  50. //定额库上下拖动
  51. let rationLibResizeEles = {};
  52. rationLibResizeEles.eleObj = {
  53. module: 'de',
  54. resize: $('#deResize'),
  55. top: $('#deTopDiv'),
  56. topSpread: $('#stdRationChapter'),
  57. bottom: $('#deBottomDiv'),
  58. bottomSpread: $('#stdSectionRations')
  59. };
  60. rationLibResizeEles.limit = {
  61. min: 150,
  62. max: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#deToolsBar').height()-150-5`,//5: resize.height()
  63. notTopSpread: 0,
  64. notBottomSpread: 0,
  65. totalHeight: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#deToolsBar').height()-5`
  66. };
  67. SlideResize.verticalSlide(rationLibResizeEles.eleObj, rationLibResizeEles.limit, function () {
  68. rationLibObj.refreshSpread();
  69. });
  70. //查找定位上下拖动
  71. function getLocateLibResize(){
  72. let resizeObj = {};
  73. resizeObj.eleObj = {
  74. module: 'locate',
  75. resize: $('#locate_resize'),
  76. top: $('#locateTopDiv'),
  77. topSpread: $('#locate_result'),
  78. bottom: $('#locateBottomDiv'),
  79. bottomSpread: $('#locate_sub')
  80. };
  81. resizeObj.limit = {
  82. min: 150,
  83. max: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#searchPanel').height()-150-5`,//5: resize.height()
  84. notTopSpread: 0,
  85. notBottomSpread: 0,
  86. totalHeight: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#searchPanel').height()-5`
  87. };
  88. return resizeObj;
  89. }
  90. let locateLibResize = getLocateLibResize();
  91. SlideResize.verticalSlide(locateLibResize.eleObj, locateLibResize.limit, function () {
  92. locateObject.refreshWorkBook();
  93. });
  94. // 块模板库上下拖动(上中)
  95. let blockLibTopMid = {};
  96. blockLibTopMid.eleObj = {
  97. module: 'kmbk',
  98. resize: $('#kmbkResizeA'),
  99. top: $('#kmbkTopDiv'),
  100. topSpread: $('#div_block_tree'),
  101. bottom: $('#kmbkMidDiv'),
  102. bottomSpread: $('#div_block_bill')
  103. };
  104. blockLibTopMid.limit = {
  105. min: 100,
  106. max: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#kmbkToolsBar').height()-$('#kmbkBottomDiv').height()-100-5*2`,
  107. notTopSpread: 0,
  108. notBottomSpread: 0,
  109. totalHeight: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#kmbkToolsBar').height()-$('#kmbkBottomDiv').height()-5*2` //5: resize.height()
  110. };
  111. SlideResize.verticalSlide(blockLibTopMid.eleObj, blockLibTopMid.limit, function () {
  112. blockLibObj.refreshSpread();
  113. });
  114. // 块模板库上下拖动(中下)
  115. let blockLibMidBottom = {};
  116. blockLibMidBottom.eleObj = {
  117. module: 'kmbk',
  118. resize: $('#kmbkResizeB'),
  119. top: $('#kmbkMidDiv'),
  120. topSpread: $('#div_block_bill'),
  121. bottom: $('#kmbkBottomDiv'),
  122. bottomSpread: $('#div_block_ration')
  123. };
  124. blockLibMidBottom.limit = {
  125. min: 100,
  126. max: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#kmbkToolsBar').height()-$('#kmbkTopDiv').height()-100-5*2`,
  127. notTopSpread: 0,
  128. notBottomSpread: 0,
  129. totalHeight: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#kmbkToolsBar').height()-$('#kmbkTopDiv').height()-5*2` //5: resize.height()
  130. };
  131. SlideResize.verticalSlide(blockLibMidBottom.eleObj, blockLibMidBottom.limit, function () {
  132. blockLibObj.refreshSpread();
  133. });
  134. //加载块模板库多个结构的变量对象
  135. let blockLibMulti = {
  136. module: 'kmbk',
  137. eles: [
  138. {container: $('#kmbkTopDiv'), spread: $('#div_block_tree'), notSpread: 0, defaultProportion: 0.6},
  139. {container: $('#kmbkMidDiv'), spread: $('#div_block_bill'), notSpread: 0, defaultProportion: 0.15},
  140. {container: $('#kmbkBottomDiv'), spread: $('#div_block_ration'), notSpread: 0, defaultProportion: 0.25},
  141. ],
  142. totalHeight: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#kmbkToolsBar').height()-5*2`
  143. };
  144. //加载各库内部上下高度(有的库需要上下拖动)
  145. function loadSideToolsHeight() {
  146. //定额库
  147. if ($('#de').is(':visible')) {
  148. SlideResize.loadVerticalHeight(rationLibResizeEles.eleObj.module, rationLibResizeEles.eleObj, rationLibResizeEles.limit, function () {
  149. rationLibObj.refreshSpread();
  150. });
  151. } else if ($('#locate').is(':visible')) {
  152. //查找定位
  153. let options = $("input[name='content_type']:checked").val();
  154. locateObject.refreshView(options, true);
  155. } else if ($('#kmbk').is(':visible')) {
  156. SlideResize.loadMultiVerticalHeight(blockLibMulti.module, blockLibMulti.eles, blockLibMulti.totalHeight, function () {
  157. blockLibObj.refreshSpread();
  158. });
  159. }
  160. }
  161. var sideToolsObj = {
  162. showSideTools: function (tabPanel, show, id) {
  163. sideResizeEles.eleObj.module = id;
  164. if (show) {
  165. //刚打开各库时的默认比例
  166. sideResizeEles.eleObj.left.css('width', '66.666667%');
  167. sideResizeEles.eleObj.right.css('width', '33.333333%');
  168. SlideResize.setResizeWidth(sideResizeEles.eleObj.resize);
  169. $('.main-side .tab-pane').hide();
  170. id === 'locateTab'?tabPanel.show(locateObject.onshow):tabPanel.show();//locateTab要等div显示后才执行刷新操作
  171. //加载打开的库与主界面的宽度比
  172. SlideResize.loadHorizonWidth(id, [sideResizeEles.eleObj.resize], [sideResizeEles.eleObj.left, sideResizeEles.eleObj.right], function(){
  173. if (id === 'stdRationTab') {//加载定额库内部上下高度
  174. SlideResize.loadVerticalHeight(rationLibResizeEles.eleObj.module, rationLibResizeEles.eleObj, rationLibResizeEles.limit, function () {
  175. sheetCommonObj.setColumnWidthByRate($('#stdRationChapter').width() - 30, rationLibObj.rationChapterSpread, rationLibObj.rationChapterTreeSetting.cols);
  176. });
  177. } else if (id === 'blockLibTab') {//块模板库
  178. SlideResize.loadMultiVerticalHeight(blockLibMulti.module, blockLibMulti.eles, blockLibMulti.totalHeight, function () {
  179. blockLibObj.refreshSpread();
  180. });
  181. }
  182. });
  183. } else {
  184. sideResizeEles.eleObj.left.css('width', '100%');
  185. sideResizeEles.eleObj.right.css('width', '0%');
  186. tabPanel.hide();
  187. }
  188. autoFlashHeight();
  189. subObj.initGljSubTab();
  190. billsGuidance.refreshWorkBook();
  191. billsLibObj.refreshBillsSpread();
  192. refreshSubSpread();
  193. billsLibObj.refreshBillsRelaSpread();
  194. rationLibObj.refreshSpread();//subSpread、jobSpread、itemSpread显示问题
  195. zmhs_obj.refresh();
  196. }
  197. };
  198. $('.right-nav-link').bind('click', function () {//$('.side-tabs ul li a').bind 2018-11-23 使用更多标签,所以不能这样绑定事件了
  199. var tab = $(this), tabPanel = $(tab.attr('relaPanel'));
  200. if(tab.hasClass('disabled')){
  201. return;
  202. }
  203. let setActiveTab = tab.hasClass("dropdown-item")?tab.parent().prev('.nav-link'):tab;//如果是点击了更多下拉菜单的子项,则需设置成active 的tab是“更多”
  204. if (!(setActiveTab.hasClass('active')&&tabPanel.is(":visible"))) {
  205. $('.side-tabs ul li a').removeClass('active');
  206. setActiveTab.addClass('active');
  207. sideToolsObj.showSideTools(tabPanel, true, tab.attr('id'));
  208. } else {
  209. setActiveTab.removeClass('active');
  210. sideToolsObj.showSideTools(tabPanel, false, tab.attr('id'));
  211. }
  212. projectObj.refreshMainSpread();
  213. });