rpt_main.js 68 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437
  1. /**
  2. * Created by Tony on 2017/6/26.
  3. */
  4. 'use strict'
  5. const PRE_PAGE_OFFSET = 150;
  6. const NEXT_PAGE_OFFSET = 160;
  7. const FIRST_PAGE_OFFSET = 50;
  8. const LAST_PAGE_OFFSET = 60;
  9. const WAIT_TIME_EXPORT = 300000;
  10. let fontSuffixMapObj = {"表标题": "title", "列标题": "column", "正文内容": "content", "合计": "summary", "表眉/表脚": "header_footer"};
  11. let rptTplObj = {
  12. hasInitialized: false,
  13. project_tree: null,
  14. pdfFont: {'SmartSimsun': [], 'simhei': [], 'simkai': []},
  15. iniPage: function() {
  16. let me = this;
  17. if (!me.hasInitialized) {
  18. zTreeOprObj.getCustomerCfg();
  19. // zTreeOprObj.getAvailablePageSize();
  20. zTreeOprObj.getReportTemplateTree();
  21. zTreeOprObj.selectedPrjIDs = [];
  22. me.hasInitialized = true;
  23. let canvas = document.getElementById("rptCanvas");
  24. canvas.onclick = canvasOprObj.canvasOnClick;
  25. canvas.onmousemove = canvasOprObj.canvasOnMouseMove;
  26. if (JpcJsPDFHelper.doc === null) {
  27. JpcJsPDFHelper.initialize('p', 'pt', 'a4');
  28. }
  29. // dynamicLoadJs('/lib/jspdf/SmartSimsun-normal.js');
  30. // dynamicLoadJs('/lib/jspdf/SmartSimsun-bold.js', me.pdfFontSimsunCallBack);
  31. // dynamicLoadJs('http://d2.smartcost.com.cn/cach/SmartSimsun-normal.js');
  32. // dynamicLoadJs('http://d2.smartcost.com.cn/cach/SmartSimsun-bold.js', me.pdfFontSimsunCallBack);
  33. let params = {
  34. rootProjectID: projectObj.project.property.rootProjectID,
  35. user_id: userID
  36. };
  37. CommonAjax.post("pm/api/getAllUnitProjects", params, function(result) {
  38. // console.log(result);
  39. me.project_tree = result;
  40. // console.log(me.getAllPrjIds());
  41. });
  42. }
  43. },
  44. pdfFontSimsunCallBack: function() {
  45. rptTplObj.pdfFont['SmartSimsun'].push('normal');
  46. rptTplObj.pdfFont['SmartSimsun'].push('bold');
  47. },
  48. pdfFontSimkaiCallBack: function() {
  49. rptTplObj.pdfFont['simkai'].push('normal');
  50. rptTplObj.pdfFont['simkai'].push('bold');
  51. },
  52. pdfFontSimheiCallBack: function() {
  53. rptTplObj.pdfFont['simhei'].push('normal');
  54. rptTplObj.pdfFont['simhei'].push('bold');
  55. }
  56. }
  57. let zTreeOprObj = {
  58. treeObj: null,
  59. prjFolderTreeObj: null,
  60. currentNode: null,
  61. checkedRptTplNodes: null,
  62. currentRptPageRst: null,
  63. reportPageCfg: null,
  64. defReportPageCfg: null,
  65. currentPage: 1,
  66. maxPages: 0,
  67. selectedPrjIDs: [],
  68. isFreeUser: true,
  69. waterMarks: [],
  70. summaryBillsLv: [],
  71. countChkedRptTpl: function () {
  72. let me = zTreeOprObj;
  73. if (me.treeObj) {
  74. me.checkedRptTplNodes = [];
  75. let chkNodes = me.treeObj.getCheckedNodes(true), cnt = 0, hasCurrentNode = false;
  76. for (let node of chkNodes) {
  77. if (node.nodeType === TPL_TYPE_TEMPLATE) {
  78. cnt++;
  79. me.checkedRptTplNodes.push(node);
  80. if (me.currentNode === node) hasCurrentNode = true;
  81. }
  82. }
  83. if (!hasCurrentNode && cnt === 0 && me.currentNode !== null) {
  84. //这里根据实际需求再做处理
  85. cnt++;
  86. me.checkedRptTplNodes.push(me.currentNode);
  87. }
  88. $("#export_div").find("span").each(function(cIdx,elementSpan){
  89. elementSpan.innerText = cnt;
  90. });
  91. $("#print_div").find("span").each(function(cIdx,elementSpan){
  92. elementSpan.innerText = cnt;
  93. });
  94. }
  95. },
  96. getReportTemplateTree: function() {
  97. let me = zTreeOprObj, params = {};
  98. params.engineerId = projectObj.project.projectInfo.property.engineering;
  99. let private_chk_hide = function (chkTplItem) {
  100. //考虑未来拓展,统一在此判断报表模板是否显示
  101. let rst = false;
  102. // if (chkTplItem.hasOwnProperty('flags') && chkTplItem.flags.hasOwnProperty('taxType') && chkTplItem.flags['taxType'] !== null &&
  103. // parseInt(chkTplItem.flags['taxType']) !== parseInt(projectObj.project.projectInfo.property.taxType)) {
  104. // rst = true;
  105. // }
  106. //重庆养护系统的判断逻辑有所不同
  107. if (chkTplItem.hasOwnProperty('flags') && chkTplItem.flags.hasOwnProperty('valuationType') && chkTplItem.flags['valuationType'] !== null &&
  108. chkTplItem.flags['valuationType'] !== projectObj.project.projectInfo.property.valuationType) {
  109. rst = true;
  110. }
  111. return rst;
  112. };
  113. // projectObj.project.projectInfo.property.taxType === 1 //1: 一般计税 2: 简易计税
  114. CommonAjax.postEx("report_tpl_api/getRptTplTree", params, 20000, true, function(result){
  115. let private_remove_hide_item = function (items, nlv) {
  116. if (items && items.length > 0) {
  117. for (let i = items.length - 1; i >= 0; i--) {
  118. if (!(items[i].released) && items[i].nodeType === 2) {
  119. items.splice(i, 1);
  120. } else if(private_chk_hide(items[i])) {
  121. items.splice(i, 1);
  122. } else {
  123. if (items[i].items && items[i].items.length > 0) {
  124. private_remove_hide_item(items[i].items, nlv + 1);
  125. if (items[i].items.length === 0 && nlv > 0) {
  126. items.splice(i, 1);
  127. }
  128. }
  129. }
  130. }
  131. }
  132. }
  133. let nodeLv = 0;
  134. zTreeOprObj.isFreeUser = result.isFreeUser;
  135. zTreeOprObj.waterMarks = result.waterMarks;
  136. private_remove_hide_item(result.data, nodeLv);
  137. for (let topNode of result.data) {
  138. if (topNode.userId === "-100") {
  139. topNode.name = topNode.name + " - 标准报表";
  140. } else {
  141. topNode.name = topNode.name + " - 定制报表";
  142. }
  143. }
  144. zTreeHelper.createTreeDirectly(result.data, rpt_tpl_setting, "rptTplTree", me);
  145. me.refreshNodes();
  146. }, null, null);
  147. },
  148. getAvailablePageSize: function() {
  149. let me = zTreeOprObj, params = {};
  150. params.engineerId = projectObj.project.projectInfo.property.engineering;
  151. CommonAjax.postEx("report_tpl_api/getAvailablePageSize", params, 2000, true, function(result){
  152. if (result) {
  153. // console.log(result);
  154. if (result.length > 0) {
  155. $('#btnRptPageSize')[0].innerHTML = result[0];
  156. let divDom = $('#divRptPageSize');
  157. divDom.empty();
  158. for (let pIdx = 1; pIdx < result.length; pIdx++) {
  159. //<a class="dropdown-item" id="hrefRptPageSize_A3" style="cursor:pointer" onclick="zTreeOprObj.changePageSize(this)">A3</a>
  160. let aDomStr = `<a class="dropdown-item" id="hrefRptPageSize_${result[pIdx]}" style="cursor:pointer" onclick="zTreeOprObj.changePageSize(this)">${result[pIdx]}</a>`;
  161. divDom.append(aDomStr);
  162. }
  163. }
  164. } else {
  165. //
  166. }
  167. }, null, null
  168. );
  169. },
  170. getCustomerCfg: function() {
  171. let me = zTreeOprObj, params = {};
  172. params.engineerId = projectObj.project.projectInfo.property.engineering;
  173. CommonAjax.postEx("report_tpl_api/getCustomizeCfg", params, 20000, true, function(result){
  174. if (result) {
  175. me.defReportPageCfg = result[0];
  176. me.reportPageCfg = result[1];
  177. me.iniFontCfgDom(me.reportPageCfg);
  178. me.renderRptCfg(result[1]);
  179. } else {
  180. me.reportPageCfg = null;
  181. me.defReportPageCfg = null;
  182. }
  183. }, null, null
  184. );
  185. },
  186. iniFontCfgDom: function (cfg) {
  187. for (let font of cfg.fonts) {
  188. let domArrs = [];
  189. let fontPropSuffix = fontSuffixMapObj[font.CfgDispName];
  190. domArrs.push("<div class='row mb-1'>");
  191. //1. label
  192. domArrs.push("<div class='col-3'>" + font.CfgDispName + "</div>");
  193. //2. font name
  194. domArrs.push("<div class='col-3'>");
  195. domArrs.push("<select class='form-control input-sm' id='fontName_" + fontPropSuffix + "' onchange='rptControlObj.changeFontMain(\"" + font.CfgDispName + "\", \"Name\", this)'>");
  196. domArrs.push("<option>宋体</option><option>楷体</option><option>黑体</option>");
  197. domArrs.push("</select>");
  198. domArrs.push("</div>");
  199. //3. font height
  200. domArrs.push("<div class='col-3'>");
  201. domArrs.push("<input class='form-control input-sm' id='fontHeight_" + fontPropSuffix + "' type='number' value='30' step='1' min='6' max='66' " +
  202. "onchange='rptControlObj.changeFontMain(\"" + font.CfgDispName + "\", \"FontHeight\", this)' " +
  203. "onkeyup='rptControlObj.changeFontMain(\"" + font.CfgDispName + "\", \"FontHeight\", this)'>");
  204. domArrs.push("</div>");
  205. //4. font bold italic underline
  206. domArrs.push("<div class='col-3'>");
  207. domArrs.push("<a id='font_bold_" + fontPropSuffix + "' class='btn btn-sm btn-outline-secondary' title='加粗' onclick='rptControlObj.changeFontAdhoc(\"" + font.CfgDispName + "\", \"FontBold\", this)'><i class='fa fa-bold'></i></a>");
  208. domArrs.push("<a id='font_italic_" + fontPropSuffix + "' class='btn btn-sm btn-outline-secondary' title='斜体' onclick='rptControlObj.changeFontAdhoc(\"" + font.CfgDispName + "\", \"FontItalic\", this)'><i class='fa fa-italic'></i></a>");
  209. domArrs.push("<a id='font_underline_" + fontPropSuffix + "' class='btn btn-sm btn-outline-secondary' title='下划线' onclick='rptControlObj.changeFontAdhoc(\"" + font.CfgDispName + "\", \"FontUnderline\", this)'><i class='fa fa-underline'></i></a>");
  210. domArrs.push("</div>");
  211. //
  212. domArrs.push("</div>");
  213. $(domArrs.join("")).insertBefore($("#font_cfg_blank_flag"));
  214. }
  215. },
  216. renderRptCfg: function (cfg) {
  217. $("#elementMargin_Left").get(0).value = cfg.margins.Left;
  218. $("#elementMargin_Right").get(0).value = cfg.margins.Right;
  219. $("#elementMargin_Top").get(0).value = cfg.margins.Top;
  220. $("#elementMargin_Bottom").get(0).value = cfg.margins.Bottom;
  221. for (let font of cfg.fonts) {
  222. let fontPropSuffix = fontSuffixMapObj[font.CfgDispName];
  223. document.getElementById("fontName_" + fontPropSuffix).value = font.Name;
  224. document.getElementById("fontHeight_" + fontPropSuffix).value = font.FontHeight;
  225. document.getElementById("font_bold_" + fontPropSuffix).className = (font.FontBold === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  226. document.getElementById("font_italic_" + fontPropSuffix).className = (font.FontItalic === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  227. document.getElementById("font_underline_" + fontPropSuffix).className = (font.FontUnderline === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  228. }
  229. document.getElementById("rpt_vertical_line").checked = cfg.showVerticalLine;
  230. document.getElementById("rpt_narrow").checked = cfg.isNarrow;
  231. // document.getElementById("rpt_narrow").checked = false;
  232. document.getElementById("rpt_fill_zero").checked = cfg.fillZero;
  233. },
  234. extractRptCfg: function (cfg) {
  235. cfg.margins.Left = $("#elementMargin_Left").get(0).value;
  236. cfg.margins.Right = $("#elementMargin_Right").get(0).value;
  237. cfg.margins.Top = $("#elementMargin_Top").get(0).value;
  238. cfg.margins.Bottom = $("#elementMargin_Bottom").get(0).value;
  239. for (let font of cfg.fonts) {
  240. let fontPropSuffix = fontSuffixMapObj[font.CfgDispName];
  241. font.Name = document.getElementById("fontName_" + fontPropSuffix).value;
  242. font.FontHeight = document.getElementById("fontHeight_" + fontPropSuffix).value;
  243. font.FontBold = (document.getElementById("font_bold_" + fontPropSuffix).className === "btn btn-sm btn-outline-secondary active")?"T":"F";
  244. font.FontItalic = (document.getElementById("font_italic_" + fontPropSuffix).className === "btn btn-sm btn-outline-secondary active")?"T":"F";
  245. font.FontUnderline = (document.getElementById("font_underline_" + fontPropSuffix).className === "btn btn-sm btn-outline-secondary active")?"T":"F";
  246. }
  247. cfg.showVerticalLine = document.getElementById("rpt_vertical_line").checked;
  248. cfg.isNarrow = document.getElementById("rpt_narrow").checked;
  249. cfg.fillZero = document.getElementById("rpt_fill_zero").checked;
  250. },
  251. refreshNodes: function() {
  252. let me = this;
  253. let private_setupIsParent = function(node){
  254. node.isParent = (node.nodeType === RT.NodeType.NODE || node.level === 0);
  255. if (node.items && node.items.length) {
  256. for (let i = 0; i < node.items.length; i++) {
  257. private_setupIsParent(node.items[i]);
  258. }
  259. }
  260. };
  261. let topNodes = me.treeObj.getNodes();
  262. for (let i = 0; i < topNodes.length; i++) {
  263. private_setupIsParent(topNodes[i]);
  264. }
  265. me.treeObj.refresh();
  266. },
  267. onCheck: function(event, treeId, treeNode) {
  268. zTreeOprObj.countChkedRptTpl();
  269. },
  270. _chkIfNeedShowPrjSelection: function(treeNode) {
  271. let rst = false;
  272. if (treeNode.hasOwnProperty('flags')) {
  273. if (treeNode.flags.reportType && treeNode.flags.reportType !== 'NA') {
  274. rst = true;
  275. } else if (treeNode.flags.sumLevelType === 'custom') {
  276. rst = true;
  277. }
  278. }
  279. return rst;
  280. },
  281. onClick: function(event,treeId,treeNode) {
  282. let me = zTreeOprObj;
  283. if (treeNode.nodeType === TPL_TYPE_TEMPLATE && treeNode.refId > 0) {
  284. me.currentNode = treeNode;
  285. if (me._chkIfNeedShowPrjSelection(treeNode)) {
  286. if (treeNode['flags']['reportType'] === 'billSummary') {
  287. me.requestPrjFolderForBillsSummary();
  288. } else if (treeNode['flags']['reportType'] === 'gljSummary') {
  289. me.requestPrjFolderForGljSummary();
  290. } else if (treeNode['flags']['sumLevelType'] === 'custom') {
  291. me.requestPrjFolderForNormalSummary();
  292. }
  293. } else {
  294. let params = {};
  295. let pageSize = rptControlObj.getCurrentPageSize();
  296. params.pageSize = pageSize;
  297. params.rpt_tpl_id = treeNode.refId;
  298. params.prj_id = projectObj.project.projectInfo.ID;
  299. params.custCfg = me.reportPageCfg;
  300. params.prj_ids = rptControlObj._getRefPrjIdsByRptNode(treeNode);
  301. me.requestNormalReport(params);
  302. }
  303. me.countChkedRptTpl();
  304. }
  305. },
  306. changePageSize: function(dom) {
  307. let me = zTreeOprObj,
  308. targetDom = document.getElementById("btnRptPageSize");
  309. let tmpStr = targetDom.innerHTML.trim();
  310. targetDom.innerHTML = dom.innerHTML.trim();
  311. dom.innerHTML = tmpStr;
  312. me.changeCfg();
  313. },
  314. changeOrientation: function(dom) {
  315. let me = zTreeOprObj,
  316. targetDom = document.getElementById("btnRptOrientation");
  317. let tmpStr = targetDom.innerHTML.trim();
  318. targetDom.innerHTML = dom.innerHTML.trim();
  319. dom.innerHTML = tmpStr;
  320. me.changeCfg();
  321. },
  322. changeCfg: function() {
  323. let me = zTreeOprObj;
  324. if (me.currentNode) {
  325. if (me.currentNode.hasOwnProperty('flags') && me.currentNode.flags.hasOwnProperty('reportType') && me.currentNode['flags']['reportType'] !== 'NA' && me.currentNode['flags']['reportType'] !== null) {
  326. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  327. if (me.currentNode['flags']['reportType'] === 'billSummary') {
  328. refBillSumPrjsIds.push(me.currentNode.refId);
  329. } else if (me.currentNode['flags']['reportType'] === 'gljSummary') {
  330. refGljSumPrjsIds.push(me.currentNode.refId);
  331. }
  332. if (zTreeOprObj.selectedPrjIDs.length > 0) {
  333. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  334. params.pageSize = rptControlObj.getCurrentPageSize();
  335. params.orientation = rptControlObj.getCurrentOrientation();
  336. params.rpt_ids = refRptTplIds;
  337. params.rpt_bill_tpl_ids = refBillSumPrjsIds;
  338. params.rpt_glj_tpl_ids = refGljSumPrjsIds;
  339. params.custCfg = me.reportPageCfg;
  340. CommonAjax.postEx("report_api/getMultiReports", params, 300000, true,
  341. function(result){
  342. hintBox.unWaitBox();
  343. let pageRst = result[0];
  344. let canvas = document.getElementById("rptCanvas");
  345. if (pageRst && pageRst.items && pageRst.items.length > 0) {
  346. me.resetAfter(pageRst);
  347. me.currentRptPageRst = pageRst;
  348. me.maxPages = pageRst.items.length;
  349. me.currentPage = 1;
  350. me.displayPageValue();
  351. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  352. canvas.width = size[0] + 20;
  353. if (size[1] > size[0]) {
  354. canvas.height = size[1] + 100;
  355. } else {
  356. canvas.height = size[1] + 50;
  357. }
  358. me.showPage(1, canvas);
  359. } else {
  360. //返回了无数据表
  361. JpcCanvasOutput.cleanCanvas(canvas);
  362. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  363. }
  364. }, function(err){
  365. hintBox.unWaitBox();
  366. }, function(ex){
  367. hintBox.unWaitBox();
  368. }
  369. );
  370. } else {
  371. if (me.currentNode['flags']['reportType'] === 'billSummary') {
  372. me.requestPrjFolderForBillsSummary();
  373. } else if (me.currentNode['flags']['reportType'] === 'gljSummary') {
  374. me.requestPrjFolderForGljSummary();
  375. }
  376. }
  377. } else {
  378. let params = {};
  379. params.pageSize = rptControlObj.getCurrentPageSize();
  380. params.orientation = rptControlObj.getCurrentOrientation();
  381. params.rpt_tpl_id = me.currentNode.refId;
  382. params.prj_id = projectObj.project.projectInfo.ID;
  383. params.custCfg = me.reportPageCfg;
  384. me.requestNormalReport(params);
  385. }
  386. }
  387. },
  388. resetAfter: function (pageRst) {
  389. let size = pageRst[JV.NODE_PAGE_INFO][JV.NODE_PAGE_SIZE].slice(0);
  390. if (size[0] > size[1]) {
  391. document.getElementById("btnRptOrientation").innerHTML = "横向";
  392. document.getElementById("hrefRptOrientation").innerHTML = "纵向";
  393. } else {
  394. document.getElementById("btnRptOrientation").innerHTML = "纵向";
  395. document.getElementById("hrefRptOrientation").innerHTML = "横向";
  396. }
  397. },
  398. requestNormalReport: function (params) {
  399. let me = zTreeOprObj;
  400. hintBox.waitBox();
  401. CommonAjax.postEx("report_api/getReport", params, 60000, true,
  402. function(result){
  403. hintBox.unWaitBox();
  404. let pageRst = result;
  405. let canvas = document.getElementById("rptCanvas");
  406. if (pageRst && pageRst.items && pageRst.items.length > 0) {
  407. me.resetAfter(pageRst);
  408. me.currentRptPageRst = pageRst;
  409. me.maxPages = pageRst.items.length;
  410. me.currentPage = 1;
  411. me.displayPageValue();
  412. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  413. canvas.width = size[0] + 20;
  414. if (size[1] > size[0]) {
  415. canvas.height = size[1] + 100;
  416. } else {
  417. canvas.height = size[1] + 50;
  418. }
  419. me.showPage(1, canvas);
  420. } else {
  421. //返回了无数据表
  422. JpcCanvasOutput.cleanCanvas(canvas);
  423. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  424. }
  425. }, function(err){
  426. hintBox.unWaitBox();
  427. }, function(ex){
  428. hintBox.unWaitBox();
  429. }
  430. );
  431. },
  432. requestPrjFolderCommon: function (params = null) {
  433. let me = zTreeOprObj;
  434. hintBox.waitBox();
  435. $.ajax({
  436. type:"POST",
  437. url: '/pm/api/getProjects',
  438. data: {'data': JSON.stringify({"user_id": userID, "compilation": projectObj.project.projectInfo.compilation})},
  439. dataType: 'json',
  440. cache: false,
  441. timeout: 15000,
  442. success: function(result){
  443. hintBox.unWaitBox();
  444. if (result.error === 0) {
  445. //console.log(result.data);
  446. let currPrjParentID = projectObj.project.projectInfo.ParentID;
  447. let selectedProjects = [];
  448. let targetData = [];
  449. tree_Data_Helper.getFlatArray(tree_Data_Helper.buildTreeNodeDirectly(result.data, false), targetData);
  450. for (let prj of targetData) {
  451. if (currPrjParentID === prj.ParentID) {
  452. selectedProjects.push({name: prj.name, ID: prj.ID});
  453. }
  454. }
  455. $("#show_project_folder").trigger("click");
  456. let topItem = [{name: '所有相关项目', items: selectedProjects}];
  457. // me.prjFolderTreeObj = $.fn.zTree.init($("#prjFolderTree"), rpt_prj_folder_setting, selectedProjects);
  458. me.prjFolderTreeObj = $.fn.zTree.init($("#prjFolderTree"), rpt_prj_folder_setting, topItem);
  459. me.prjFolderTreeObj.expandAll(true);
  460. if (params) {
  461. // 配合async用
  462. }
  463. } else {
  464. alert('error: ' + result.message);
  465. }
  466. },
  467. error: function(jqXHR, textStatus, errorThrown){
  468. hintBox.unWaitBox();
  469. alert('error ' + textStatus + " " + errorThrown);
  470. }
  471. });
  472. },
  473. requestPrjFolderForBillsSummary: function () {
  474. let me = zTreeOprObj;
  475. $("#divReqBillSummary")[0].style.display = "";
  476. $("#divReqGljSummary")[0].style.display = "none";
  477. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  478. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  479. $("#divReqCommonSummaryPDF")[0].style.display = "none";
  480. $("#divReqCustomSelect")[0].style.display = "none";
  481. if ($('#summaryTypeOptions')[0]) $('#summaryTypeOptions')[0].selectedIndex = 4;
  482. zTreeOprObj.summaryBillsLv = [];
  483. me.requestPrjFolderCommon();
  484. },
  485. requestPrjFolderForGljSummary: function () {
  486. let me = zTreeOprObj;
  487. $("#divReqBillSummary")[0].style.display = "none";
  488. $("#divReqGljSummary")[0].style.display = "";
  489. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  490. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  491. $("#divReqCommonSummaryPDF")[0].style.display = "none";
  492. $("#divReqCustomSelect")[0].style.display = "none";
  493. if ($('#summaryTypeOptions')[0]) $('#summaryTypeOptions')[0].selectedIndex = 4;
  494. zTreeOprObj.summaryBillsLv = [];
  495. me.requestPrjFolderCommon();
  496. },
  497. requestPrjFolderForNormalSummary: function () {
  498. let me = zTreeOprObj;
  499. $("#divReqBillSummary")[0].style.display = "none";
  500. $("#divReqGljSummary")[0].style.display = "none";
  501. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  502. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  503. $("#divReqCommonSummaryPDF")[0].style.display = "none";
  504. $("#divReqCustomSelect")[0].style.display = "";
  505. if ($('#summaryTypeOptions')[0]) $('#summaryTypeOptions')[0].selectedIndex = 4;
  506. zTreeOprObj.summaryBillsLv = [];
  507. me.requestPrjFolderCommon();
  508. },
  509. requestBillsSummaryRpt: function () {
  510. let me = zTreeOprObj;
  511. let nodes = me.prjFolderTreeObj.getCheckedNodes(true);
  512. if (nodes.length > 0) {
  513. if (nodes[0].level === 0) {
  514. nodes.splice(0, 1);
  515. }
  516. hintBox.waitBox();
  517. let params = {};
  518. params.pageSize = rptControlObj.getCurrentPageSize();
  519. params.rpt_tpl_id = me.currentNode.refId;
  520. params.custCfg = me.reportPageCfg;
  521. params.prjIds = [];
  522. me.selectedPrjIDs = [];
  523. for (let node of nodes) {
  524. params.prjIds.push(node.ID);
  525. me.selectedPrjIDs.push(node.ID);
  526. }
  527. CommonAjax.postEx("report_api/getBillsSummaryReport", params, 60000, true,
  528. function(result){
  529. hintBox.unWaitBox();
  530. let pageRst = result;
  531. let canvas = document.getElementById("rptCanvas");
  532. if (pageRst && pageRst.items && pageRst.items.length > 0) {
  533. me.resetAfter(pageRst);
  534. me.currentRptPageRst = pageRst;
  535. me.maxPages = pageRst.items.length;
  536. me.currentPage = 1;
  537. me.displayPageValue();
  538. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  539. canvas.width = size[0] + 20;
  540. if (size[1] > size[0]) {
  541. canvas.height = size[1] + 100;
  542. } else {
  543. canvas.height = size[1] + 50;
  544. }
  545. me.showPage(1, canvas);
  546. } else {
  547. //返回了无数据表
  548. JpcCanvasOutput.cleanCanvas(canvas);
  549. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  550. }
  551. }, function(err){
  552. hintBox.unWaitBox();
  553. }, function(ex){
  554. hintBox.unWaitBox();
  555. }
  556. );
  557. }
  558. },
  559. requestGljSummaryRpt: function () {
  560. let me = zTreeOprObj;
  561. let nodes = me.prjFolderTreeObj.getCheckedNodes(true);
  562. if (nodes.length > 0) {
  563. if (nodes[0].level === 0) {
  564. nodes.splice(0, 1);
  565. }
  566. hintBox.waitBox();
  567. let params = {};
  568. params.pageSize = rptControlObj.getCurrentPageSize();
  569. params.rpt_tpl_id = me.currentNode.refId;
  570. params.custCfg = me.reportPageCfg;
  571. params.prjIds = [];
  572. zTreeOprObj.selectedPrjIDs = [];
  573. for (let node of nodes) {
  574. params.prjIds.push(node.ID);
  575. zTreeOprObj.selectedPrjIDs.push(node.ID);
  576. }
  577. CommonAjax.postEx("report_api/getGljSummaryReport", params, 60000, true,
  578. function(result){
  579. hintBox.unWaitBox();
  580. let pageRst = result;
  581. let canvas = document.getElementById("rptCanvas");
  582. if (pageRst && pageRst.items && pageRst.items.length > 0) {
  583. me.resetAfter(pageRst);
  584. me.currentRptPageRst = pageRst;
  585. me.maxPages = pageRst.items.length;
  586. me.currentPage = 1;
  587. me.displayPageValue();
  588. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  589. canvas.width = size[0] + 20;
  590. if (size[1] > size[0]) {
  591. canvas.height = size[1] + 100;
  592. } else {
  593. canvas.height = size[1] + 50;
  594. }
  595. me.showPage(1, canvas);
  596. } else {
  597. //返回了无数据表
  598. JpcCanvasOutput.cleanCanvas(canvas);
  599. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  600. }
  601. }, function(err){
  602. hintBox.unWaitBox();
  603. }, function(ex){
  604. hintBox.unWaitBox();
  605. }
  606. );
  607. }
  608. },
  609. requestSumAndNormalRptForPDF_Ex: function () {
  610. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  611. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  612. let prj_ids_arr = [];
  613. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names, prj_ids_arr);
  614. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  615. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  616. params.rpt_names = rpt_names;
  617. params.prj_ids_arr = prj_ids_arr;
  618. params.isOneSheet = true;
  619. CommonAjax.postEx("report_api/getMultiReports", params, WAIT_TIME_EXPORT, true,
  620. function(result){
  621. let pageSize = rptControlObj.getCurrentPageSize();
  622. for (let idx = 0; idx < result.length; idx++) {
  623. let pageData = result[idx];
  624. JpcJsPDFHelper.outputAsPdf(pageData, pageSize, result[idx][JV.NODE_PAGE_INFO][JV.NODE_MAIN_INFO_RPT_NAME]);
  625. }
  626. },
  627. function(failRst){
  628. console.log(failRst);
  629. },
  630. function(exceptionRst){
  631. console.log(exceptionRst);
  632. }
  633. );
  634. },
  635. requestSumAndNormalRptForMultiExcel: function () {
  636. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  637. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  638. let prj_ids_arr = [];
  639. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names, prj_ids_arr);
  640. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  641. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  642. params.rpt_names = rpt_names;
  643. params.prj_ids_arr = prj_ids_arr;
  644. params.isOneSheet = true;
  645. $.bootstrapLoading.start();
  646. CommonAjax.postEx("report_api/createExcelFiles", params, WAIT_TIME_EXPORT, true, function(result){
  647. if (result) {
  648. $.bootstrapLoading.end();
  649. let uuIdUrls = [];
  650. for (let uuIdObj of result) {
  651. let uuIdUrl = "/report_api/getFileByUUID/" + uuIdObj.uuid + "/" + stringUtil.replaceAll(uuIdObj.reportName, "#", "_") + "/xlsx";
  652. uuIdUrls.push(uuIdUrl);
  653. }
  654. downloadReport(uuIdUrls);
  655. } else {
  656. $.bootstrapLoading.end();
  657. }
  658. },
  659. function(failRst){
  660. $.bootstrapLoading.end();
  661. console.log(failRst);
  662. },
  663. function(exceptionRst){
  664. $.bootstrapLoading.end();
  665. console.log(exceptionRst);
  666. }
  667. );
  668. },
  669. requestSumAndNormalRptForAllInOneExcel: function () {
  670. let orgRptName = projectObj.project.projectInfo.name;
  671. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  672. let prj_ids_arr = [];
  673. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, null, null, null, prj_ids_arr);
  674. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  675. params.prj_ids_arr = prj_ids_arr;
  676. params.rptName = orgRptName;
  677. $.bootstrapLoading.start();
  678. CommonAjax.postEx("report_api/createExcelFilesInOneBook", params, WAIT_TIME_EXPORT, true, function(result){
  679. if (result) {
  680. $.bootstrapLoading.end();
  681. let uuIdUrls = [];
  682. let uuIdUrl = "/report_api/getFileByUUID/" + result.uuid + "/" + stringUtil.replaceAll(result.reportName, "#", "_") + "/xlsx";
  683. uuIdUrls.push(uuIdUrl);
  684. downloadReport(uuIdUrls);
  685. } else {
  686. $.bootstrapLoading.end();
  687. }
  688. },
  689. function(failRst){
  690. $.bootstrapLoading.end();
  691. console.log(failRst);
  692. },
  693. function(exceptionRst){
  694. $.bootstrapLoading.end();
  695. console.log(exceptionRst);
  696. }
  697. );
  698. },
  699. requestNormalReportAfterSelection: function() {
  700. let me = zTreeOprObj;
  701. if (me.currentNode) {
  702. let treeNode = me.currentNode;
  703. let params = {};
  704. let pageSize = rptControlObj.getCurrentPageSize();
  705. params.pageSize = pageSize;
  706. params.rpt_tpl_id = treeNode.refId;
  707. params.prj_id = projectObj.project.projectInfo.ID;
  708. params.custCfg = me.reportPageCfg;
  709. params.prj_ids = rptControlObj._getRefPrjIdsByRptNode(treeNode);
  710. me.requestNormalReport(params);
  711. me.countChkedRptTpl();
  712. }
  713. },
  714. showPage: function (pageNum, canvas) {
  715. let me = zTreeOprObj;
  716. if (pageNum >= 1 && pageNum <= me.maxPages) {
  717. me.currentPage = pageNum;
  718. JpcCanvasOutput.cleanCanvas(canvas);
  719. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  720. // JpcCanvasOutput.drawWaterMarks(canvas, zTreeOprObj.waterMarks);
  721. JpcCanvasOutput.drawToCanvas(me.currentRptPageRst, canvas, me.currentPage);
  722. }
  723. me.displayPageValue();
  724. },
  725. displayPageValue: function() {
  726. let me = zTreeOprObj;
  727. $("#rpt_page_num").get(0).value = me.currentPage + "/" + me.maxPages;
  728. }
  729. };
  730. let canvasOprObj = {
  731. canvasOnMouseMove: function (event) {
  732. if (zTreeOprObj.currentNode) {
  733. let x = event.offsetX - JpcCanvasOutput.offsetX, canvas = event.originalTarget;
  734. if (!(canvas)) canvas = event.target; //chrome浏览器不认event.originalTarget,只认event.target或event.currentTarget
  735. if (x < PRE_PAGE_OFFSET) {
  736. canvas.style.cursor = "url(/web/building_saas/img/PreviousPage.cur), auto";
  737. } else if ((canvas.width - x) < NEXT_PAGE_OFFSET) {
  738. canvas.style.cursor = "url(/web/building_saas/img/NextPage.cur), auto";
  739. } else {
  740. canvas.style.cursor = "";
  741. }
  742. }
  743. },
  744. canvasOnClick: function(event){
  745. if (zTreeOprObj.currentNode) {
  746. let x = event.offsetX - JpcCanvasOutput.offsetX, canvas = event.originalTarget;
  747. if (!(canvas)) canvas = event.target; //chrome浏览器不认event.originalTarget,只认event.target或event.currentTarget
  748. if (x < FIRST_PAGE_OFFSET) {
  749. zTreeOprObj.showPage(1, canvas);
  750. } else if (x < PRE_PAGE_OFFSET) {
  751. zTreeOprObj.showPage(zTreeOprObj.currentPage - 1, canvas);
  752. } else if ((canvas.width - x) < LAST_PAGE_OFFSET) {
  753. zTreeOprObj.showPage(zTreeOprObj.maxPages, canvas);
  754. } else if ((canvas.width - x) < NEXT_PAGE_OFFSET) {
  755. zTreeOprObj.showPage(zTreeOprObj.currentPage + 1, canvas);
  756. }
  757. }
  758. }
  759. };
  760. let rptControlObj = {
  761. currentOutputType: "Excel",
  762. currentDownloadUrl: null,
  763. currentDownloadIdx: 0,
  764. getCurrentPageSize: function() {
  765. // let rst = "A4";
  766. let rst = document.getElementById("btnRptPageSize").innerHTML.trim();
  767. //btnRptPageSize
  768. return rst;
  769. },
  770. getCurrentOrientation: function() {
  771. // let rst = "横向";
  772. let rst = document.getElementById("btnRptOrientation").innerHTML.trim();
  773. return rst;
  774. },
  775. getCurrentReportOption: function() {
  776. //
  777. },
  778. changeType: function(newType) {
  779. let me = rptControlObj;
  780. let excelDom = document.getElementById("EXCEL_TYPE");
  781. let pdfDom = document.getElementById("PDF_TYPE");
  782. if (newType === "Excel") {
  783. excelDom.className = "btn btn-block btn-primary";
  784. pdfDom.className = "btn btn-block btn-outline-secondary";
  785. me.currentOutputType = newType;
  786. } else if (newType === "PDF") {
  787. excelDom.className = "btn btn-block btn-outline-secondary";
  788. pdfDom.className = "btn btn-block btn-primary";
  789. me.currentOutputType = newType;
  790. } else {
  791. //me.currentOutputType = newType;
  792. }
  793. },
  794. outputRpt: function() {
  795. let me = rptControlObj;
  796. if (me.currentOutputType === "Excel") {
  797. me.getExcel();
  798. } else if (me.currentOutputType === "PDF") {
  799. me.getPDFEx();
  800. } else {
  801. //other types if needed.
  802. }
  803. },
  804. getTplIdsCommon: function (refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names, prj_ids_arr) {
  805. for (let node of zTreeOprObj.checkedRptTplNodes) {
  806. if (zTreeOprObj._chkIfNeedShowPrjSelection(node)) {
  807. if (node['flags']['reportType'] === 'billSummary') {
  808. refBillSumPrjsIds.push(node.refId);
  809. if (bill_rpt_names) bill_rpt_names.push(node.name);
  810. } else if (node['flags']['reportType'] === 'gljSummary') {
  811. refGljSumPrjsIds.push(node.refId);
  812. if (glj_rpt_names) glj_rpt_names.push(node.name);
  813. } else if (node['flags']['sumLevelType'] === 'custom') {
  814. //当普通方式处理
  815. refRptTplIds.push(node.refId);
  816. if (rpt_names) rpt_names.push(node.name);
  817. if (prj_ids_arr) prj_ids_arr.push(rptControlObj._getRefPrjIdsByRptNode(node));
  818. }
  819. } else {
  820. refRptTplIds.push(node.refId);
  821. if (rpt_names) rpt_names.push(node.name);
  822. if (prj_ids_arr) prj_ids_arr.push(rptControlObj._getRefPrjIdsByRptNode(node));
  823. }
  824. }
  825. },
  826. _getRefPrjIdsByRptNode: function (rptNode) {
  827. let rst = [];
  828. if (rptNode.flags && rptNode.flags.sumLevelType) {
  829. if (rptNode.flags.sumLevelType === 'construct') {
  830. //建设项目级别 rptTplObj.project_tree 所有project ids
  831. for (let prj of rptTplObj.project_tree) {
  832. if (rst.indexOf(prj.ID) < 0) rst.push(prj.ID);
  833. }
  834. } else if (rptNode.flags.sumLevelType === 'single') {
  835. //单位工程级别 me.project_tree 相同parent project ids
  836. for (let prj of rptTplObj.project_tree) {
  837. if (projectObj.project.projectInfo.ParentID === prj.ParentID) {
  838. if (rst.indexOf(prj.ID) < 0) rst.push(prj.ID);
  839. }
  840. }
  841. } else if (rptNode.flags.sumLevelType === 'custom') {
  842. //用户自己挑选
  843. let nodes = (zTreeOprObj.prjFolderTreeObj === null)?[]:zTreeOprObj.prjFolderTreeObj.getCheckedNodes(true);
  844. zTreeOprObj.selectedPrjIDs = [];
  845. for (let node of nodes) {
  846. if (node.level > 0) {
  847. rst.push(node.ID);
  848. }
  849. }
  850. }
  851. }
  852. if (rst.length === 0) rst.push(projectObj.project.projectInfo.ID);
  853. return rst;
  854. },
  855. creatCommonExportParam: function (refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds) {
  856. let nodes = (zTreeOprObj.prjFolderTreeObj === null)?[]:zTreeOprObj.prjFolderTreeObj.getCheckedNodes(true);
  857. let rst = {};
  858. rst.prj_id = projectObj.project.projectInfo.ID;
  859. rst.rpt_ids = refRptTplIds;
  860. rst.rpt_bill_tpl_ids = refBillSumPrjsIds;
  861. rst.rpt_glj_tpl_ids = refGljSumPrjsIds;
  862. rst.prjIds = [];
  863. // rst.prj_ids_arr = [];
  864. zTreeOprObj.selectedPrjIDs = [];
  865. for (let node of nodes) {
  866. if (node.level > 0) {
  867. rst.prjIds.push(node.ID);
  868. zTreeOprObj.selectedPrjIDs.push(node.ID);
  869. //这里要考虑别的多单位工程汇总级别数据(建设项目级别、单项工程级别,与selectedPrjIDs不同)
  870. // params.prj_ids = rptControlObj._getRefPrjIdsByRptNode(treeNode);
  871. }
  872. }
  873. // rst.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  874. // rst.rpt_names = rpt_names;
  875. // rst.isOneSheet = true;
  876. rst.pageSize = rptControlObj.getCurrentPageSize();
  877. rst.orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:rptControlObj.getCurrentOrientation());
  878. rst.custCfg = zTreeOprObj.reportPageCfg;
  879. rst.option = "normal";
  880. return rst;
  881. },
  882. getAllInOneBook: function () {
  883. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  884. let me = rptControlObj;
  885. let orgRptName = projectObj.project.projectInfo.name;
  886. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  887. let prj_ids_arr = [];
  888. // rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, prj_ids_arr);
  889. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, null, null, null, prj_ids_arr);
  890. if (zTreeOprObj.selectedPrjIDs.length > 0 && (refBillSumPrjsIds.length > 0 || refGljSumPrjsIds.length > 0)) {
  891. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  892. params.rptName = orgRptName;
  893. $.bootstrapLoading.start();
  894. CommonAjax.postEx("report_api/createExcelFilesInOneBook", params, WAIT_TIME_EXPORT, true, function(result){
  895. if (result) {
  896. $.bootstrapLoading.end();
  897. let uuIdUrls = [];
  898. let uuIdUrl = "/report_api/getFileByUUID/" + result.uuid + "/" + stringUtil.replaceAll(result.reportName, "#", "_") + "/xlsx";
  899. uuIdUrls.push(uuIdUrl);
  900. downloadReport(uuIdUrls);
  901. } else {
  902. $.bootstrapLoading.end();
  903. }
  904. },
  905. function(failRst){
  906. $.bootstrapLoading.end();
  907. console.log(failRst);
  908. },
  909. function(exceptionRst){
  910. $.bootstrapLoading.end();
  911. console.log(exceptionRst);
  912. }
  913. );
  914. } else {
  915. let needSelect = false;
  916. for (let treeNode of zTreeOprObj.checkedRptTplNodes) {
  917. if (zTreeOprObj._chkIfNeedShowPrjSelection(treeNode)) {
  918. needSelect = true;
  919. break;
  920. }
  921. }
  922. if (needSelect) {
  923. activeBranchAfterPrjSelection('divReqCommonSummaryExcel');
  924. zTreeOprObj.requestPrjFolderCommon(); //先处理需要汇总的报表,走另外一个分支
  925. } else if (refRptTplIds.length > 0) {
  926. let params = {};
  927. params.prj_id = projectObj.project.projectInfo.ID;
  928. params.prj_ids_arr = prj_ids_arr;
  929. params.rpt_ids = refRptTplIds;
  930. params.rptName = orgRptName;
  931. params.pageSize = me.getCurrentPageSize();
  932. params.orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:me.getCurrentOrientation());
  933. params.custCfg = zTreeOprObj.reportPageCfg;
  934. params.option = "normal";
  935. $.bootstrapLoading.start();
  936. CommonAjax.postEx("report_api/createExcelFilesInOneBook", params, WAIT_TIME_EXPORT, true, function(result){
  937. if (result) {
  938. $.bootstrapLoading.end();
  939. let uuIdUrls = [];
  940. let uuIdUrl = "/report_api/getFileByUUID/" + result.uuid + "/" + stringUtil.replaceAll(result.reportName, "#", "_") + "/xlsx";
  941. uuIdUrls.push(uuIdUrl);
  942. downloadReport(uuIdUrls);
  943. } else {
  944. $.bootstrapLoading.end();
  945. }
  946. },
  947. function(failRst){
  948. $.bootstrapLoading.end();
  949. console.log(failRst);
  950. },
  951. function(exceptionRst){
  952. $.bootstrapLoading.end();
  953. console.log(exceptionRst);
  954. }
  955. );
  956. }
  957. }
  958. }
  959. },
  960. getAllIndividualExcelBook: function () {
  961. let me = rptControlObj;
  962. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  963. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  964. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  965. let prj_ids_arr = [];
  966. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names, prj_ids_arr);
  967. if (zTreeOprObj.selectedPrjIDs.length > 0 && (glj_rpt_names.length > 0 || bill_rpt_names.length > 0)) {
  968. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  969. params.prj_id = projectObj.project.projectInfo.ID;
  970. params.prj_ids_arr = prj_ids_arr;
  971. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  972. params.rpt_names = rpt_names;
  973. params.isOneSheet = true;
  974. params.rptName = projectObj.project.projectInfo.name;
  975. $.bootstrapLoading.start();
  976. CommonAjax.postEx("report_api/createExcelFiles", params, WAIT_TIME_EXPORT, true, function(result){
  977. if (result) {
  978. $.bootstrapLoading.end();
  979. let uuIdUrls = [];
  980. for (let uuIdObj of result) {
  981. let uuIdUrl = "/report_api/getFileByUUID/" + uuIdObj.uuid + "/" + stringUtil.replaceAll(uuIdObj.reportName, "#", "_") + "/xlsx";
  982. uuIdUrls.push(uuIdUrl);
  983. }
  984. downloadReport(uuIdUrls);
  985. } else {
  986. $.bootstrapLoading.end();
  987. }
  988. },
  989. function(failRst){
  990. $.bootstrapLoading.end();
  991. console.log(failRst);
  992. },
  993. function(exceptionRst){
  994. $.bootstrapLoading.end();
  995. console.log(exceptionRst);
  996. }
  997. );
  998. } else {
  999. let needSelect = false;
  1000. for (let treeNode of zTreeOprObj.checkedRptTplNodes) {
  1001. if (zTreeOprObj._chkIfNeedShowPrjSelection(treeNode)) {
  1002. needSelect = true;
  1003. break;
  1004. }
  1005. }
  1006. if (needSelect) {
  1007. activeBranchAfterPrjSelection('divReqCommonSummaryMultiExcel');
  1008. zTreeOprObj.requestPrjFolderCommon(); //先处理需要汇总的报表,走另外一个分支
  1009. } else if (refRptTplIds.length > 0) {
  1010. let params = {};
  1011. params.prj_id = projectObj.project.projectInfo.ID;
  1012. params.prj_ids_arr = prj_ids_arr;
  1013. params.rpt_ids = refRptTplIds;
  1014. params.rpt_names = rpt_names;
  1015. params.pageSize = me.getCurrentPageSize();
  1016. params.orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:me.getCurrentOrientation());
  1017. params.isOneSheet = true;
  1018. params.custCfg = zTreeOprObj.reportPageCfg;
  1019. params.option = "normal";
  1020. $.bootstrapLoading.start();
  1021. CommonAjax.postEx("report_api/createExcelFiles", params, WAIT_TIME_EXPORT, true, function(result){
  1022. if (result) {
  1023. $.bootstrapLoading.end();
  1024. let uuIdUrls = [];
  1025. for (let uuIdObj of result) {
  1026. let uuIdUrl = "/report_api/getFileByUUID/" + uuIdObj.uuid + "/" + stringUtil.replaceAll(uuIdObj.reportName, "#", "_") + "/xlsx";
  1027. uuIdUrls.push(uuIdUrl);
  1028. }
  1029. downloadReport(uuIdUrls);
  1030. } else {
  1031. $.bootstrapLoading.end();
  1032. }
  1033. },
  1034. function(failRst){
  1035. $.bootstrapLoading.end();
  1036. console.log(failRst);
  1037. },
  1038. function(exceptionRst){
  1039. $.bootstrapLoading.end();
  1040. console.log(exceptionRst);
  1041. }
  1042. );
  1043. }
  1044. }
  1045. }
  1046. },
  1047. checkAndGetExcel: function () {
  1048. if (zTreeOprObj.isFreeUser && !commonUtil.isGLYun()) {//2020-11-25 zhang 公路云版,免费版允许打印、导出报表
  1049. hintBox.versionBox('对不起,您当前使用的是学习版,不提供导出、打印报表功能,请联系我们的客服人员。');
  1050. return;
  1051. }
  1052. if (zTreeOprObj.isFreeUser && commonUtil.isGLYun()) {//2022-02-25 公路云版,免费版也不允许打印、导出报表,只是提示信息不同
  1053. hintBox.versionBox('免费版不提供此功能,请联系纵横客服进行升级大司空云计价专业版。\n纵横全国服务热线:0756-3850888,企业QQ:800003850');
  1054. return;
  1055. }
  1056. if (zTreeOprObj.treeObj) {
  1057. let chkNodes = zTreeOprObj.treeObj.getCheckedNodes(true);
  1058. if (chkNodes.length > 0) {
  1059. $("#show_excel_output_cfg").trigger("click");
  1060. } else {
  1061. rptControlObj.getAllIndividualExcelBook();
  1062. }
  1063. }
  1064. },
  1065. getExcel: function () {
  1066. if (zTreeOprObj.isFreeUser && !commonUtil.isGLYun()) {//2020-11-25 zhang 公路云版,免费版允许打印、导出报表
  1067. hintBox.versionBox('对不起,您当前使用的是学习版,不提供导出、打印报表功能,请联系我们的客服人员。');
  1068. return;
  1069. }
  1070. if (zTreeOprObj.isFreeUser && commonUtil.isGLYun()) {//2022-02-25 公路云版,免费版也不允许打印、导出报表,只是提示信息不同
  1071. hintBox.versionBox('免费版不提供此功能,请联系纵横客服进行升级大司空云计价专业版。\n纵横全国服务热线:0756-3850888,企业QQ:800003850');
  1072. return;
  1073. }
  1074. let me = rptControlObj;
  1075. if ($("#excelExportType_AllInOneBook").get(0).checked) {
  1076. me.getAllInOneBook();
  1077. } else if ($("#excelExportType_IndividualBook").get(0).checked) {
  1078. me.getAllIndividualExcelBook();
  1079. }
  1080. },
  1081. _hidePdfIniPage: function () {
  1082. if ($('#ini_PDF_cover').is(':visible')) {
  1083. // $("#ini_PDF_Btn_Cancel").trigger("click");
  1084. // 因在Z+可能会有冲突,所以暴力关闭初始化PDF页面!
  1085. $('#ini_PDF_cover').remove();
  1086. if ($("div.modal-backdrop.fade.show")) {
  1087. $('div.modal-backdrop.fade.show').remove();
  1088. }
  1089. }
  1090. },
  1091. getPdfFontCallback: function(fontProperty) {
  1092. let me = rptControlObj;
  1093. rptTplObj.pdfFont['SmartSimsun'].push(fontProperty);
  1094. if (rptTplObj.pdfFont['SmartSimsun'].length === 2) {
  1095. me._hidePdfIniPage();
  1096. setTimeout(function() {
  1097. me.getPDFEx();
  1098. }, 50); // 50毫秒足够关闭PDF初始化page了
  1099. }
  1100. },
  1101. getPDFPre: function () {
  1102. let me = rptControlObj;
  1103. if (zTreeOprObj.isFreeUser && !commonUtil.isGLYun()) {//2020-11-25 zhang 公路云版,免费版允许打印、导出报表
  1104. hintBox.versionBox('对不起,您当前使用的是学习版,不提供导出、打印报表功能,请联系我们的客服人员。');
  1105. return;
  1106. }
  1107. if (zTreeOprObj.isFreeUser && commonUtil.isGLYun()) {//2022-02-25 公路云版,免费版也不允许打印、导出报表,只是提示信息不同
  1108. hintBox.versionBox('免费版不提供此功能,请联系纵横客服进行升级大司空云计价专业版。\n纵横全国服务热线:0756-3850888,企业QQ:800003850');
  1109. return;
  1110. }
  1111. if (rptTplObj.pdfFont['SmartSimsun'].length === 2) {
  1112. me.getPDFEx();
  1113. } else {
  1114. // dynamicLoadJs('/lib/jspdf/SmartSimsun-normal.js', 'normal', me.getPdfFontCallback);
  1115. // dynamicLoadJs('/lib/jspdf/SmartSimsun-bold.js', 'bold', me.getPdfFontCallback);
  1116. $("#ini_PDF_Btn").trigger("click");
  1117. dynamicLoadJs('https://d2.smartcost.com.cn/cach/SmartSimsun-normal.js', 'normal', me.getPdfFontCallback);
  1118. dynamicLoadJs('https://d2.smartcost.com.cn/cach/SmartSimsun-bold.js', 'bold', me.getPdfFontCallback);
  1119. }
  1120. },
  1121. getPDFEx: function () {
  1122. let me = rptControlObj;
  1123. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  1124. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  1125. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  1126. let prj_ids_arr = [];
  1127. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names, prj_ids_arr);
  1128. // refRptTplIds获取的是
  1129. if (zTreeOprObj.selectedPrjIDs.length > 0 && (glj_rpt_names.length > 0 || bill_rpt_names.length > 0)) {
  1130. let params = rptControlObj.creatCommonExportParam();
  1131. params.prj_id = projectObj.project.projectInfo.ID;
  1132. params.prj_ids_arr = prj_ids_arr;
  1133. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  1134. params.rpt_ids = refRptTplIds;
  1135. params.rpt_bill_tpl_ids = refBillSumPrjsIds;
  1136. params.rpt_glj_tpl_ids = refGljSumPrjsIds;
  1137. params.rpt_names = rpt_names;
  1138. params.isOneSheet = true;
  1139. params.rptName = projectObj.project.projectInfo.name;
  1140. $.bootstrapLoading.start();
  1141. CommonAjax.postEx("report_api/getMultiReports", params, WAIT_TIME_EXPORT, true,
  1142. function(result){
  1143. $.bootstrapLoading.end();
  1144. me._hidePdfIniPage();
  1145. let pageSize = rptControlObj.getCurrentPageSize();
  1146. let rstRptNames = [];
  1147. for (let idx = 0; idx < result.length; idx++) {
  1148. rstRptNames.push(result[idx][JV.NODE_PAGE_INFO][JV.NODE_MAIN_INFO_RPT_NAME]);
  1149. }
  1150. downloadPDFReport(result, pageSize, rstRptNames);
  1151. // for (let idx = 0; idx < result.length; idx++) {
  1152. // let pageData = result[idx];
  1153. // JpcJsPDFHelper.outputAsPdf(pageData, pageSize, result[idx][JV.NODE_PAGE_INFO][JV.NODE_MAIN_INFO_RPT_NAME]);
  1154. // }
  1155. },
  1156. function(failRst){
  1157. $.bootstrapLoading.end();
  1158. me._hidePdfIniPage();
  1159. console.log(failRst);
  1160. },
  1161. function(exceptionRst){
  1162. $.bootstrapLoading.end();
  1163. me._hidePdfIniPage();
  1164. console.log(exceptionRst);
  1165. }
  1166. );
  1167. } else {
  1168. let needSelect = false;
  1169. for (let treeNode of zTreeOprObj.checkedRptTplNodes) {
  1170. if (zTreeOprObj._chkIfNeedShowPrjSelection(treeNode)) {
  1171. needSelect = true;
  1172. break;
  1173. }
  1174. }
  1175. if (needSelect) {
  1176. activeBranchAfterPrjSelection('divReqCommonSummaryPDF');
  1177. zTreeOprObj.requestPrjFolderCommon(); //先处理需要汇总的报表,走另外一个分支
  1178. } else if (refRptTplIds.length > 0) {
  1179. let params = {};
  1180. params.prj_id = projectObj.project.projectInfo.ID;
  1181. params.prj_ids_arr = prj_ids_arr;
  1182. params.rpt_ids = refRptTplIds;
  1183. params.rpt_names = rpt_names;
  1184. params.pageSize = me.getCurrentPageSize();
  1185. params.orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:me.getCurrentOrientation());
  1186. params.custCfg = zTreeOprObj.reportPageCfg;
  1187. params.option = "normal";
  1188. $.bootstrapLoading.start();
  1189. CommonAjax.postEx("report_api/getMultiReports", params, WAIT_TIME_EXPORT, true,
  1190. function(result){
  1191. $.bootstrapLoading.end();
  1192. me._hidePdfIniPage();
  1193. let pageSize = rptControlObj.getCurrentPageSize();
  1194. downloadPDFReport(result, pageSize, rpt_names);
  1195. },
  1196. function(failRst){
  1197. $.bootstrapLoading.end();
  1198. me._hidePdfIniPage();
  1199. console.log(failRst);
  1200. },
  1201. function(exceptionRst){
  1202. $.bootstrapLoading.end();
  1203. me._hidePdfIniPage();
  1204. console.log(exceptionRst);
  1205. }
  1206. );
  1207. } else {
  1208. //这个分支是为了减少请求,用户已经点过的表,又没有勾选,那么就直接导出成PDF,不过貌似已经走不到这里了
  1209. let pageSize = rptControlObj.getCurrentPageSize();
  1210. let pageData = zTreeOprObj.currentRptPageRst;
  1211. $.bootstrapLoading.end();
  1212. me._hidePdfIniPage();
  1213. if (pageData) {
  1214. JpcJsPDFHelper.outputAsPdf(pageData, pageSize, zTreeOprObj.currentNode.name);
  1215. }
  1216. }
  1217. }
  1218. } else {
  1219. $.bootstrapLoading.end();
  1220. }
  1221. },
  1222. firstPage: function(dom) {
  1223. let canvas = document.getElementById("rptCanvas");
  1224. zTreeOprObj.showPage(1, canvas);
  1225. },
  1226. prePage: function(dom) {
  1227. let canvas = document.getElementById("rptCanvas");
  1228. zTreeOprObj.showPage(zTreeOprObj.currentPage - 1, canvas);
  1229. },
  1230. nextPage: function(dom) {
  1231. let canvas = document.getElementById("rptCanvas");
  1232. zTreeOprObj.showPage(zTreeOprObj.currentPage + 1, canvas);
  1233. },
  1234. lastPage: function(dom) {
  1235. let me = zTreeOprObj;
  1236. let canvas = document.getElementById("rptCanvas");
  1237. zTreeOprObj.showPage(me.maxPages, canvas);
  1238. },
  1239. onKeydown: function (event, dom) {
  1240. let me = zTreeOprObj, keyPressed = null;
  1241. if (window.event) {
  1242. keyPressed = window.event.keyCode; // IE/Chrome
  1243. } else {
  1244. keyPressed = event.which; // Firefox
  1245. }
  1246. if (keyPressed === 13) {
  1247. let pageNum = 1;
  1248. try {
  1249. pageNum = parseInt(dom.value);
  1250. } catch (e) {
  1251. pageNum = 1;
  1252. }
  1253. let canvas = document.getElementById("rptCanvas");
  1254. if (pageNum < 1) {
  1255. pageNum = 1;
  1256. } else if (pageNum > me.maxPages) {
  1257. pageNum = me.maxPages;
  1258. }
  1259. zTreeOprObj.showPage(pageNum, canvas);
  1260. return false;
  1261. }
  1262. },
  1263. changeMargin: function(marginPropStr, marginDom) {
  1264. zTreeOprObj.reportPageCfg.margins[marginPropStr] = marginDom.value;
  1265. },
  1266. changeFontMain: function(CfgDispName, fontProperty, fontDom) {
  1267. for (let font of zTreeOprObj.reportPageCfg.fonts) {
  1268. if (font["CfgDispName"] === CfgDispName) {
  1269. font[fontProperty] = fontDom.value;
  1270. break;
  1271. }
  1272. }
  1273. },
  1274. changeCfgOption: function (optStr, dom) {
  1275. zTreeOprObj.reportPageCfg[optStr] = dom.checked;
  1276. },
  1277. changeFontAdhoc: function(CfgDispName, fontProperty, fontDom) {
  1278. for (let font of zTreeOprObj.reportPageCfg.fonts) {
  1279. if (font["CfgDispName"] === CfgDispName) {
  1280. if (font[fontProperty] === 'T') {
  1281. font[fontProperty] = 'F';
  1282. fontDom.className = "btn btn-sm btn-outline-secondary";
  1283. } else {
  1284. font[fontProperty] = 'T';
  1285. fontDom.className = "btn btn-sm btn-outline-secondary active";
  1286. }
  1287. break;
  1288. }
  1289. }
  1290. },
  1291. restoreCustCFG: function () {
  1292. let me = this;
  1293. zTreeOprObj.renderRptCfg(zTreeOprObj.defReportPageCfg);
  1294. zTreeOprObj.extractRptCfg(zTreeOprObj.reportPageCfg);
  1295. me.saveCustCfg();
  1296. },
  1297. saveCustCfg: function() {
  1298. let params = {};
  1299. params.custCfg = zTreeOprObj.reportPageCfg;
  1300. CommonAjax.postEx("report_tpl_api/saveCustomerCfg", params, 20000, true, function(result){
  1301. // alert("Save successfully!");
  1302. $("#update_msg_response")[0].style.color = "green";
  1303. $("#update_msg_response")[0].innerHTML = " (保存成功!)";
  1304. setTimeout(function(){
  1305. $("#update_msg_response")[0].innerHTML = "";
  1306. }, 1000);
  1307. }, function (failRst) {
  1308. $("#update_msg_response")[0].style.color = "red";
  1309. $("#update_msg_response")[0].innerHTML = " (保存失败!)";
  1310. setTimeout(function(){
  1311. $("#update_msg_response")[0].innerHTML = "";
  1312. }, 1000);
  1313. }, null
  1314. );
  1315. },
  1316. confirmCfgChange: function() {
  1317. zTreeOprObj.changeCfg();
  1318. }
  1319. };
  1320. function downloadPDFReport(pageDataArr, pageSize, rpt_names) {
  1321. rptControlObj.currentDownloadIdx = 0;
  1322. const private_download = function() {
  1323. if (rptControlObj.currentDownloadIdx < pageDataArr.length) {
  1324. let pageData = pageDataArr[rptControlObj.currentDownloadIdx];
  1325. let rptName = rpt_names[rptControlObj.currentDownloadIdx];
  1326. rptControlObj.currentDownloadIdx++;
  1327. JpcJsPDFHelper.outputAsPdf(pageData, pageSize, rptName);
  1328. if (rptControlObj.currentDownloadIdx < pageDataArr.length) setTimeout(private_download, 1000);
  1329. }
  1330. }
  1331. private_download();
  1332. }
  1333. function downloadReport(urls) {
  1334. //考虑到多个报表下载,一些浏览器(如chrome)不允许一下子下载多个文件,得缓缓处理,统一在这处理
  1335. rptControlObj.currentDownloadUrl = null;
  1336. rptControlObj.currentDownloadIdx = 0;
  1337. let private_download = function() {
  1338. if (rptControlObj.currentDownloadIdx >= 0 && rptControlObj.currentDownloadIdx < urls.length) {
  1339. rptControlObj.currentDownloadUrl = urls[rptControlObj.currentDownloadIdx];
  1340. rptControlObj.currentDownloadIdx++;
  1341. window.location = rptControlObj.currentDownloadUrl;
  1342. setTimeout(private_download, 2000);
  1343. }
  1344. }
  1345. private_download();
  1346. }
  1347. function dynamicLoadJs(url, type, callback) {
  1348. let head = document.getElementsByTagName('head')[0];
  1349. let script = document.createElement('script');
  1350. script.type = 'text/javascript';
  1351. script.src = url;
  1352. if(callback) {
  1353. script.onload = script.onreadystatechange = function (event) {
  1354. // console.log('this.readyState: ' + this.readyState);
  1355. callback(type);
  1356. script.onload = script.onreadystatechange = null;
  1357. // if (this.readyState === "loaded" || this.readyState === "complete"){
  1358. // }
  1359. };
  1360. }
  1361. head.appendChild(script);
  1362. }
  1363. function dynamicLoadCss(url) {
  1364. let head = document.getElementsByTagName('head')[0];
  1365. let link = document.createElement('link');
  1366. link.type='text/css';
  1367. link.rel = 'stylesheet';
  1368. link.href = url;
  1369. head.appendChild(link);
  1370. }
  1371. function activeBranchAfterPrjSelection(idStr) {
  1372. $("#divReqBillSummary")[0].style.display = "none";
  1373. $("#divReqGljSummary")[0].style.display = "none";
  1374. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  1375. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  1376. $("#divReqCommonSummaryPDF")[0].style.display = "none";
  1377. $("#divReqCustomSelect")[0].style.display = "none";
  1378. $(`#${idStr}`)[0].style.display = "";
  1379. if ($('#summaryTypeOptions')[0]) $('#summaryTypeOptions')[0].selectedIndex = 4;
  1380. zTreeOprObj.summaryBillsLv = [];
  1381. }
  1382. function changeSummaryBillsLv(dom) {
  1383. // console.log(dom[dom.selectedIndex].value);
  1384. zTreeOprObj.summaryBillsLv = JSON.parse(dom[dom.selectedIndex].value);
  1385. }
  1386. async function selectPrjs(params) {
  1387. $("#divReqBillSummary")[0].style.display = "none";
  1388. $("#divReqGljSummary")[0].style.display = "none";
  1389. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  1390. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  1391. $("#divReqCommonSummaryPDF")[0].style.display = "none";
  1392. $("#divReqCustomSelect")[0].style.display = "none";
  1393. $("#divReqCustomSelectAsync")[0].style.display = "";
  1394. zTreeOprObj.requestPrjFolderCommon(params);
  1395. // const select = await confirmSelectPrjs(params);
  1396. }
  1397. function confirmSelectPrjs(params) {
  1398. const promise = new Promise(function (resolve, reject) {
  1399. // init(gather_select.custom_define, customSelects.stageFlow, gather_select, rptName, resolve, reject);
  1400. let me = zTreeOprObj;
  1401. if (me.currentNode) {
  1402. let treeNode = me.currentNode;
  1403. let pageSize = rptControlObj.getCurrentPageSize();
  1404. params.pageSize = pageSize;
  1405. params.rpt_tpl_id = treeNode.refId;
  1406. params.prj_id = projectObj.project.projectInfo.ID;
  1407. params.custCfg = me.reportPageCfg;
  1408. params.prj_ids = rptControlObj._getRefPrjIdsByRptNode(treeNode);
  1409. resolve(true);
  1410. } else {
  1411. resolve(false);
  1412. }
  1413. });
  1414. return promise;
  1415. }