rpt_tpl_main.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355
  1. 'use strict'
  2. let rptTplObj = {
  3. iniPage: function() {
  4. zTreeOprObj.getReportTemplateTree(RT.GrpType.CONSTRUCT);
  5. bandTreeOprObj.getReportTplCfg();
  6. preview_util.drawBorder($("#tplCanvas")[0]);
  7. }
  8. }
  9. let zTreeOprObj = {
  10. treeObj: null,
  11. currentNode: null,
  12. getReportTemplateTree: function(grpType) {
  13. let me = zTreeOprObj, params = {};
  14. params.grpType = grpType;
  15. params.userId = userID;
  16. params.tplType = RT.TplType.ALL;
  17. CommonAjax.postEx("report_tpl_api/getRptTplTree", params, 20000, true, function(result){
  18. zTreeHelper.createTree(result, setting, "rptTplTree", me);
  19. me.refreshNodes();
  20. }, null, null
  21. );
  22. },
  23. refreshNodes: function() {
  24. let me = this;
  25. let private_setupIsParent = function(node){
  26. if (node.nodeType == RT.NodeType.NODE) {
  27. node.isParent = true;
  28. } else {
  29. node.isParent = false;
  30. }
  31. if (node.items && node.items.length) {
  32. for (let i = 0; i < node.items.length; i++) {
  33. private_setupIsParent(node.items[i]);
  34. }
  35. }
  36. };
  37. let topNodes = me.treeObj.getNodes();
  38. for (let i = 0; i < topNodes.length; i++) {
  39. private_setupIsParent(topNodes[i]);
  40. }
  41. me.treeObj.refresh();
  42. },
  43. moveUpNode: function() {
  44. let me = this, nodes = [];
  45. if (me.currentNode && me.currentNode.getPreNode()) {
  46. let preNode = me.currentNode.getPreNode(), pre_preNode = preNode.getPreNode();
  47. me.treeObj.moveNode(preNode, me.currentNode, "prev", true);
  48. //then update the db
  49. if (pre_preNode) {
  50. pre_preNode.NextSiblingID = me.currentNode.ID;
  51. nodes.push(me.createNodeFromZTreeNode(pre_preNode));
  52. }
  53. preNode.NextSiblingID = me.currentNode.NextSiblingID;
  54. me.currentNode.NextSiblingID = preNode.ID;
  55. nodes.push(me.createNodeFromZTreeNode(me.currentNode));
  56. nodes.push(me.createNodeFromZTreeNode(preNode));
  57. me.updateNodes(nodes);
  58. }
  59. },
  60. moveDownNode: function() {
  61. let me = this, nodes = [];
  62. if (me.currentNode && me.currentNode.getNextNode()) {
  63. let preNode = me.currentNode.getPreNode(), nextNode = me.currentNode.getNextNode();
  64. me.treeObj.moveNode(nextNode, me.currentNode, "next", true);
  65. //then update the db
  66. if (preNode) {
  67. preNode.NextSiblingID = nextNode.ID;
  68. nodes.push(me.createNodeFromZTreeNode(preNode));
  69. }
  70. me.currentNode.NextSiblingID = nextNode.NextSiblingID;
  71. nextNode.NextSiblingID = me.currentNode.ID;
  72. nodes.push(me.createNodeFromZTreeNode(me.currentNode));
  73. nodes.push(me.createNodeFromZTreeNode(nextNode));
  74. me.updateNodes(nodes);
  75. }
  76. },
  77. addRootNode: function() {
  78. let me = this, rawNode = me.createIniRootNode(), lastNodeId = -1, lastNode = null;
  79. if (me.treeObj) {
  80. let rootNodes = me.treeObj.getNodes();
  81. if (rootNodes.length > 0) {
  82. lastNodeId = rootNodes[rootNodes.length - 1].ID;
  83. lastNode = rootNodes[rootNodes.length - 1];
  84. }
  85. me.addNewNode(rawNode, lastNodeId, function(rst){
  86. let newNodes = [], isSilent = false;
  87. if (lastNode) {
  88. lastNode.NextSiblingID = rst.ID;
  89. }
  90. rawNode.ID = rst.ID;
  91. rawNode.isParent = true;
  92. rawNode.items = [];
  93. newNodes.push(rawNode);
  94. if (me.treeObj) {
  95. me.treeObj.addNodes(null, -1, newNodes, isSilent);
  96. } else {
  97. me.treeObj = $.fn.zTree.init($("#rptTplTree"), setting, newNodes);
  98. }
  99. }, null);
  100. }
  101. },
  102. updateNodes: function(nodes){
  103. if (nodes && nodes.length > 0) {
  104. let me = this;
  105. for (let i = 0; i < nodes.length; i++) {
  106. if (nodes[i].__v != null) node.__v = nodes[i].__v + 1
  107. else nodes[i].__v = 0;
  108. }
  109. let params = {};
  110. params.nodes = nodes;
  111. CommonAjax.postEx("report_tpl_api/updateRptTplNodes", params, 5000, true, null, null, null);
  112. }
  113. },
  114. addTplNode: function (){
  115. let me = this;
  116. if (me.currentNode && me.currentNode.nodeType === RT.NodeType.NODE) {
  117. let rawNode = me.createIniRootNode(), lastNodeId = -1, lastNode = null;
  118. rawNode.nodeType = RT.NodeType.TEMPLATE;
  119. rawNode.ParentID = me.currentNode.ID;
  120. rawNode.name = "新增报表模板";
  121. if (me.treeObj) {
  122. let nodes = me.currentNode.items;
  123. if (nodes.length > 0) {
  124. lastNodeId = nodes[nodes.length - 1].ID;
  125. lastNode = nodes[nodes.length - 1];
  126. }
  127. me.addNewNode(rawNode, lastNodeId, function(rst){
  128. let newNodes = [], isSilent = false;
  129. if (lastNode) {
  130. lastNode.NextSiblingID = rst.ID;
  131. }
  132. rawNode.ID = rst.ID;
  133. rawNode.isParent = false;
  134. rawNode.items = [];
  135. newNodes.push(rawNode);
  136. if (me.treeObj) {
  137. me.treeObj.addNodes(me.currentNode, -1, newNodes, isSilent);
  138. } else {
  139. me.treeObj = $.fn.zTree.init($("#rptTplTree"), setting, newNodes);
  140. }
  141. }, null);
  142. }
  143. }
  144. },
  145. addNewNode: function(rawNode, lastNodeId, callback, failCallback) {
  146. let params = {};
  147. params.lastNodeId = lastNodeId;
  148. params.rawNodeData = rawNode;
  149. CommonAjax.postEx("report_tpl_api/createTplTreeNode", params, 5000, true, callback, failCallback, null);
  150. },
  151. createIniRootNode: function() {
  152. let rst = {
  153. ID: -1,
  154. ParentID: -1,
  155. NextSiblingID: -1,
  156. grpType: RT.GrpType.CONSTRUCT,
  157. nodeType: RT.NodeType.NODE,
  158. tplType: RT.TplType.ALL,
  159. userId: userID,
  160. refId: -1,
  161. name: '新增节点'
  162. };
  163. return rst;
  164. },
  165. createNodeFromZTreeNode: function(treeNode) {
  166. let rst = {};
  167. rst.ID = treeNode.ID;
  168. rst.ParentID = treeNode.ParentID;
  169. rst.NextSiblingID = treeNode.NextSiblingID;
  170. rst.grpType = treeNode.grpType;
  171. rst.nodeType = treeNode.nodeType;
  172. rst.tplType = treeNode.tplType;
  173. rst.userId = treeNode.userId;
  174. rst.refId = treeNode.refId;
  175. rst.name = treeNode.name;
  176. return rst;
  177. },
  178. addHoverDom: function(treeId, treeNode) {
  179. let me = zTreeOprObj, sObj = $("#" + treeNode.tId + "_span");
  180. if (treeNode.editNameFlag || $("#addBtn_"+treeNode.tId).length > 0 || treeNode.nodeType == RT.NodeType.TEMPLATE) return;
  181. let addStr = "<span class='button add' id='addBtn_" + treeNode.tId + "' title='新增子节点' onfocus='this.blur();'></span>";
  182. sObj.after(addStr);
  183. let btn = $("#addBtn_"+treeNode.tId);
  184. if (btn) btn.bind("click", function(){
  185. let rawNode = me.createIniRootNode(), lastNodeId = -1, insertIdx = -1, lastNode = null;
  186. rawNode.ParentID = treeNode.ID;
  187. rawNode.name = "新增子节点";
  188. if (treeNode.items.length > 0) {
  189. for (let i = treeNode.items.length - 1; i >= 0; i--) {
  190. if (treeNode.items[i].nodeType == RT.NodeType.NODE) {
  191. lastNodeId = treeNode.items[i].ID;
  192. lastNode = treeNode.items[i];
  193. rawNode.NextSiblingID = treeNode.items[i].NextSiblingID;
  194. insertIdx = i + 1;
  195. break;
  196. } else {
  197. rawNode.NextSiblingID = treeNode.items[i].ID;
  198. insertIdx = i;
  199. }
  200. }
  201. }
  202. zTreeOprObj.addNewNode(rawNode, lastNodeId, function(rst){
  203. let newNodes = [], isSilent = false;
  204. if (lastNode) {
  205. lastNode.NextSiblingID = rst.ID;
  206. }
  207. rawNode.ID = rst.ID;
  208. rawNode.NextSiblingID = rst.NextSiblingID;
  209. rawNode.isParent = true;
  210. rawNode.items = [];
  211. newNodes.push(rawNode);
  212. treeNode.isParent = true;
  213. if (me.treeObj) {
  214. me.treeObj.addNodes(treeNode, insertIdx, newNodes, isSilent);
  215. } else {
  216. me.treeObj = $.fn.zTree.init($("#rptTplTree"), setting, newNodes);
  217. }
  218. }, null);
  219. });
  220. },
  221. removeHoverDom: function(treeId, treeNode) {
  222. $("#addBtn_"+treeNode.tId).unbind().remove();
  223. },
  224. onBeforeRemove: function(treeId, treeNode){
  225. let nodeIds = [], preNode = treeNode.getPreNode(), preNodeId = -1, canRemove = false, params = {};
  226. if (preNode) {
  227. preNodeId = preNode.ID;
  228. }
  229. let private_fetchAllSubItems = function(pItem){
  230. nodeIds.push(pItem.ID);
  231. if (pItem.items && pItem.items.length > 0) {
  232. for (let i = 0; i < pItem.items.length; i++) {
  233. private_fetchAllSubItems(pItem.items[i]);
  234. }
  235. }
  236. };
  237. nodeIds.push(treeNode.ID);
  238. for (let i = 0; i < treeNode.items.length; i++) {
  239. private_fetchAllSubItems(treeNode.items[i]);
  240. }
  241. params.nodeIds = nodeIds;
  242. params.preNodeId = preNodeId;
  243. params.preNodeNextId = treeNode.NextSiblingID;
  244. CommonAjax.postEx("report_tpl_api/deleteRptTplNodes", params, 5000, false, function(data){
  245. canRemove = true;
  246. }, null, null);
  247. return canRemove;
  248. },
  249. onRemove: function(e, treeId, treeNode){
  250. let me = zTreeOprObj, pNode = me.treeObj.getNodeByTId(treeNode.parentTId);
  251. if (pNode && pNode.items && pNode.items.length == 0) {
  252. if (pNode.nodeType == RT.NodeType.NODE) pNode.isParent = true
  253. else pNode.isParent = false;
  254. me.treeObj.refresh();
  255. }
  256. },
  257. beforeRename: function(treeId, treeNode, newName, isCancel) {
  258. if (newName.length == 0) {
  259. return false;
  260. }
  261. return true;
  262. },
  263. onRename : function(e, treeId, treeNode, isCancel) {
  264. let me = zTreeOprObj, nodes = [];
  265. nodes.push(me.createNodeFromZTreeNode(treeNode));
  266. me.updateNodes(nodes);
  267. if (treeNode.nodeType == RT.NodeType.TEMPLATE && treeNode.refId >= 0) {
  268. if (treeNode.rptTpl != null) {
  269. treeNode.rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MAIN_INFO_RPT_NAME] = treeNode.name;
  270. $("#rptTplName")[0].value = treeNode.rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MAIN_INFO_RPT_NAME];
  271. } else {
  272. me.onClick(e, treeId, treeNode);
  273. }
  274. }
  275. },
  276. onClick: function(event,treeId,treeNode) {
  277. let me = zTreeOprObj;
  278. me.currentNode = treeNode;
  279. bandTreeOprObj.currentNode = null;
  280. if (treeNode.nodeType == RT.NodeType.NODE) {
  281. $("#rpt_tpl_display_label")[0].innerText = "...";
  282. } else if (treeNode.nodeType == RT.NodeType.TEMPLATE) {
  283. let showText = treeNode.name, parentNode = treeNode.getParentNode();
  284. while (parentNode !== null) {
  285. showText = parentNode.name + ' > ' + showText;
  286. parentNode = parentNode.getParentNode();
  287. }
  288. $("#rpt_tpl_display_label")[0].innerText = showText;
  289. if (treeNode.refId < 0) {
  290. //创建新报表模板
  291. $('#rptTypeSelectionModal').modal('show');
  292. } else {
  293. //显示报表模板
  294. me.chkAndRreshRefTpl();
  295. }
  296. }
  297. },
  298. createNewTpl: function () {
  299. let me = zTreeOprObj, params = {};
  300. if (me.currentNode && me.currentNode.nodeType == RT.NodeType.TEMPLATE) {
  301. params.treeNodeId = me.currentNode.ID;
  302. let rptTypeId = common_rpt_type_ids.flow;
  303. if ($("#crossTypeOpt")[0].checked) rptTypeId = common_rpt_type_ids.cross;
  304. if ($("#billTypeOpt")[0].checked) rptTypeId = common_rpt_type_ids.bill;
  305. params.rptDftTplId = rptTypeId
  306. CommonAjax.postEx("report_tpl_api/createDftRptTpl", params, 20000, true, function(result){
  307. me.currentNode.rptTpl = result;
  308. }, null, null
  309. );
  310. }
  311. },
  312. chkAndRreshRefTpl: function() {
  313. let me = zTreeOprObj, params = {};
  314. if (me.currentNode && me.currentNode.nodeType == RT.NodeType.TEMPLATE && me.currentNode.refId > 0) {
  315. if (!(me.currentNode.rptTpl)) {
  316. params.rptTplId = me.currentNode.refId;
  317. CommonAjax.postEx("report_tpl_api/getRefRptTpl", params, 20000, true, function(result){
  318. me.currentNode.rptTpl = result;
  319. me.currentNode.rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MAIN_INFO_RPT_NAME] = me.currentNode.name;
  320. tplHelper.refreshTplView(me.currentNode.rptTpl);
  321. }, null, null
  322. );
  323. } else {
  324. me.currentNode.rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MAIN_INFO_RPT_NAME] = me.currentNode.name;
  325. tplHelper.refreshTplView(me.currentNode.rptTpl);
  326. }
  327. }
  328. },
  329. getRefTpl: function() {
  330. let me = zTreeOprObj, rst = null;
  331. if (me.currentNode && me.currentNode.nodeType == RT.NodeType.TEMPLATE && me.currentNode.refId > 0) {
  332. rst = me.currentNode.rptTpl
  333. }
  334. return rst;
  335. },
  336. extractMainInfo: function (rptTpl) {
  337. //模板信息
  338. rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MAIN_INFO_RPT_NAME] = $("#rptTplName")[0].value;
  339. rptTpl[JV.NODE_MAIN_INFO][JV.NODE_PAGE_INFO][JV.PROP_PAGE_SIZE] = JV.PAGES_SIZE_STR[$("#rptTplPageSize")[0].selectedIndex];
  340. if ($("#rptTplPageOrientation")[0].selectedIndex == 1) {
  341. rptTpl[JV.NODE_MAIN_INFO][JV.NODE_PAGE_INFO][JV.PROP_ORIENTATION] = JV.ORIENTATION_PORTRAIT;
  342. } else {
  343. rptTpl[JV.NODE_MAIN_INFO][JV.NODE_PAGE_INFO][JV.PROP_ORIENTATION] = JV.ORIENTATION_LANDSCAPE;
  344. }
  345. if (rptTpl[JV.NODE_FLOW_INFO]) {
  346. rptTpl[JV.NODE_FLOW_INFO][JV.PROP_MULTI_COLUMN] = parseInt($("#rptTplMultiCols")[0].value);
  347. }
  348. rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MARGINS][JV.PROP_LEFT] = $("#rptTplMarginLeft")[0].value;
  349. rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MARGINS][JV.PROP_RIGHT] = $("#rptTplMarginRight")[0].value;
  350. rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MARGINS][JV.PROP_TOP] = $("#rptTplMarginTop")[0].value;
  351. rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MARGINS][JV.PROP_BOTTOM] = $("#rptTplMarginBottom")[0].value;
  352. }
  353. };