section_tree.js 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865
  1. /**
  2. * Created by Tony on 2017/4/27.
  3. */
  4. var pageOprObj = {
  5. rationLibName : null,
  6. rationLibId : null,
  7. initPage : function() {
  8. var me = this, rationLibId = getQueryString("repository"),//获取定额库参数
  9. rationLibName = storageUtil.getSessionCache("RationGrp","repositoryID_" + rationLibId);
  10. if (rationLibName) {
  11. var html = $("#rationname")[0].outerHTML;
  12. html = html.replace("XXX定额库", rationLibName);
  13. $("#rationname")[0].outerHTML = html;
  14. me.rationLibName = rationLibName;
  15. me.rationLibId = rationLibId;
  16. zTreeOprObj.getRationTree(rationLibId);
  17. //job
  18. jobContentOprObj.radiosChange(jobContentOprObj.radios, jobContentOprObj.tableAll, jobContentOprObj.tablePartial);
  19. $('#addConBtn').click(jobContentOprObj.bindAddConBtn());
  20. $('#updateConBtn').click(jobContentOprObj.bindUpdateConBtn());
  21. $('#txtareaAll').bind('change', function () {
  22. let met = this;
  23. let jobContent = $(met).val();
  24. $(met).attr('disabled', true);
  25. let updateCodes = [];
  26. for(let i = 0, len = jobContentOprObj.currentRationItems.length; i < len; i++){
  27. updateCodes.push(jobContentOprObj.currentRationItems[i].code);
  28. }
  29. jobContentOprObj.updateJobContent(me.rationLibId, jobContentOprObj.getUpdateArr(updateCodes, jobContent), function () {
  30. $(met).attr('disabled', false);
  31. jobContentOprObj.currentJobContent = jobContent;
  32. })
  33. });
  34. }
  35. }
  36. }
  37. var zTreeOprObj = {
  38. treeObj: null,
  39. getRationTree: function(rationLibId){
  40. var me = this;
  41. $.ajax({
  42. type:"POST",
  43. url:"api/getRationTree",
  44. data:{"rationLibId": rationLibId},
  45. dataType:"json",
  46. cache:false,
  47. timeout:20000,
  48. success:function(result,textStatus,status){
  49. if(status.status == 200) {
  50. if (result.data.length > 0) {
  51. storageUtil.setSessionCache("RationGrp","repositoryID",result.data[0].rationRepId);
  52. }
  53. zTreeHelper.createTree(result.data, setting, "rationChapterTree", me);
  54. //初始化,初始节点点击
  55. let rootNode = me.treeObj.getNodes()[0];
  56. if(rootNode && rootNode.isParent && rootNode.isFirstNode){
  57. me.treeObj.selectNode(rootNode);
  58. me.onClick(null, 'rationChapterTree', rootNode);
  59. }
  60. explanatoryOprObj.bindEvents($('#explanationShow'), $('#ruleTextShow'));
  61. }
  62. },
  63. error:function(err){
  64. alert(err.responseJSON.error);
  65. }
  66. })
  67. },
  68. addRootNode: function() {
  69. $('#addRootA').css("opacity", "0.2");
  70. $('#addRootA').addClass("disabled");
  71. var me = zTreeOprObj, rawNode = {ParentID: -1, NextSiblingID: -1, name: "新增节点"}, lastNodeId = -1;
  72. if (me.treeObj) {
  73. var rootNodes = me.treeObj.getNodes();
  74. if (rootNodes.length > 0) {
  75. lastNodeId = rootNodes[rootNodes.length - 1].ID;
  76. }
  77. }
  78. me.addNewNode(rawNode, lastNodeId, function(err, rst){
  79. if (!(err)) {
  80. if(rootNodes.length > 0){
  81. rootNodes[rootNodes.length - 1].NextSiblingID = rst.data.ID;
  82. }
  83. var newNodes = [], isSilent = false;
  84. newNodes.push({ rationRepId: rst.data.rationRepId, Previous_ID: lastNodeId, ID: rst.data.ID, ParentID:-1, NextSiblingID:-1, name:"新增节点",isParent:false, items:[]});
  85. if (me.treeObj) {
  86. me.treeObj.addNodes(null, -1, newNodes, isSilent);
  87. } else {
  88. me.treeObj = $.fn.zTree.init($("#rationChapterTree"), setting, newNodes);
  89. }
  90. $('#addRootA').css("opacity", "");
  91. $('#addRootA').removeClass("disabled");
  92. }
  93. });
  94. },
  95. addNewNode : function(rawNode, lastNodeId, callback){
  96. $.ajax({
  97. type:"POST",
  98. url:"api/createNewNode",
  99. data:{"rationLibId":pageOprObj.rationLibId,"lastNodeId": lastNodeId, "lastOpr": userAccount, "rawNodeData": JSON.stringify(rawNode)},
  100. dataType:"json",
  101. cache:false,
  102. timeout:1000,
  103. success: function(result,textStatus,status){
  104. callback(false, result);
  105. },
  106. error:function(err){
  107. callback(err);
  108. }
  109. })
  110. },
  111. beforeRename: function(treeId, treeNode, newName, isCancel) {
  112. if (newName.length == 0) {
  113. return false;
  114. }
  115. return true;
  116. },
  117. onRename : function(e, treeId, treeNode, isCancel) {
  118. var nodes = [];
  119. nodes.push(treeNode);
  120. zTreeOprObj.updateNodes(nodes);
  121. },
  122. onBeforeRemove: function(treeId, treeNode){
  123. var nodeIds = [], preNode = treeNode.getPreNode(), preNodeId = -1;
  124. if (preNode) {
  125. preNodeId = preNode.ID;
  126. }
  127. private_fetchAllSubItems = function(pItem){
  128. nodeIds.push(pItem.ID);
  129. if (pItem.items && pItem.items.length > 0) {
  130. for (var i = 0; i < pItem.items.length; i++) {
  131. private_fetchAllSubItems(pItem.items[i]);
  132. }
  133. }
  134. };
  135. nodeIds.push(treeNode.ID);
  136. for (var i = 0; i < treeNode.items.length; i++) {
  137. private_fetchAllSubItems(treeNode.items[i]);
  138. }
  139. $.ajax({
  140. type:"POST",
  141. url:"api/deleteNodes",
  142. data:{"repId": pageOprObj.rationLibId, "lastOpr": userAccount, "nodes": JSON.stringify(nodeIds), "preNodeId": preNodeId, "preNodeNextId": treeNode.NextSiblingID},
  143. dataType:"json",
  144. cache:false,
  145. timeout:5000,
  146. success:function(result,textStatus,status){
  147. var pNode = treeNode.getParentNode();
  148. if (pNode && pNode.items && pNode.items.length == 1) {
  149. pNode.isParent = false;
  150. }
  151. },
  152. error:function(){
  153. }
  154. });
  155. return true;
  156. },
  157. onRemove: function(e, treeId, treeNode){
  158. var me = zTreeOprObj, pNode = me.treeObj.getNodeByTId(treeNode.parentTId);
  159. if (pNode && pNode.items && pNode.items.length == 0) {
  160. pNode.isParent = false;
  161. me.treeObj.refresh();
  162. //me.treeObj.updateNode(pNode, false); //这方法有后遗症,多次操作后会造成节点新增子节点时,父节点icon显示不正确
  163. }
  164. },
  165. beforeDrop: function (treeId, treeNodes, targetNode, moveType) {
  166. let me = zTreeOprObj;
  167. if(moveType){
  168. me.treeObj.setting.edit.enable = false;
  169. let treeNode = treeNodes[0], updateNodes = [];
  170. //升级
  171. if(treeNode.level !== targetNode.level && moveType === 'prev'){
  172. if(treeNode.Previous_ID !== -1){
  173. treeNode.getPreNode().NextSiblingID = treeNode.NextSiblingID;
  174. updateNodes.push(treeNode.getPreNode());
  175. }
  176. if(treeNode.NextSiblingID !== -1){
  177. treeNode.getNextNode().Previous_ID = treeNode.Previous_ID;
  178. }
  179. if(targetNode.Previous_ID !== -1){
  180. targetNode.getPreNode().NextSiblingID = treeNode.ID;
  181. updateNodes.push(targetNode.getPreNode());
  182. }
  183. treeNode.ParentID = targetNode.getParentNode() ? targetNode.getParentNode().ID : -1;
  184. treeNode.NextSiblingID = targetNode.ID;
  185. treeNode.Previous_ID = targetNode.Previous_ID;
  186. targetNode.Previous_ID = treeNode.ID;
  187. updateNodes.push(treeNode);
  188. //updateNodes.push(targetNode);
  189. }
  190. //升级
  191. else if(treeNode.level !== targetNode.level && moveType === 'next'){
  192. if(treeNode.Previous_ID !== -1){
  193. treeNode.getPreNode().NextSiblingID = treeNode.NextSiblingID;
  194. updateNodes.push(treeNode.getPreNode());
  195. }
  196. if(treeNode.NextSiblingID !== -1){
  197. treeNode.getNextNode().Previous_ID = treeNode.Previous_ID;
  198. }
  199. if(targetNode.NextSiblingID !== -1){
  200. targetNode.getNextNode().Previous_ID = treeNode.ID;
  201. }
  202. treeNode.NextSiblingID = targetNode.NextSiblingID;
  203. treeNode.Previous_ID = targetNode.ID;
  204. treeNode.ParentID = targetNode.getParentNode() ? targetNode.getParentNode().ID : -1;
  205. targetNode.NextSiblingID = treeNode.ID;
  206. updateNodes.push(treeNode);
  207. updateNodes.push(targetNode);
  208. }
  209. //上移
  210. else if(treeNode.level === targetNode.level && moveType === 'prev'){
  211. if(targetNode.Previous_ID !== -1){
  212. let targetPrev = me.treeObj.getNodeByParam('ID', targetNode.Previous_ID, null);
  213. targetPrev.NextSiblingID = treeNode.ID;
  214. updateNodes.push(targetPrev);
  215. }
  216. targetNode.NextSiblingID = treeNode.NextSiblingID;
  217. treeNode.NextSiblingID = targetNode.ID;
  218. treeNode.Previous_ID = targetNode.Previous_ID;
  219. targetNode.Previous_ID = treeNode.ID;
  220. updateNodes.push(treeNode);
  221. updateNodes.push(targetNode);
  222. }
  223. //下移
  224. else if(treeNode.level === targetNode.level && moveType === 'next'){
  225. if(treeNode.Previous_ID !== -1){
  226. let treeNodePrev = me.treeObj.getNodeByParam('ID', treeNode.Previous_ID, null);
  227. treeNodePrev.NextSiblingID = targetNode.ID;
  228. updateNodes.push(treeNodePrev);
  229. }
  230. treeNode.Previous_ID = targetNode.ID;
  231. treeNode.NextSiblingID = targetNode.NextSiblingID;
  232. targetNode.Previous_ID = treeNode.Previous_ID;
  233. targetNode.NextSiblingID = treeNode.ID;
  234. updateNodes.push(treeNode);
  235. updateNodes.push(targetNode);
  236. }
  237. //
  238. else if(moveType === 'inner'){
  239. if( treeNode.Previous_ID !== -1){
  240. treeNode.getPreNode().NextSiblingID = treeNode.NextSiblingID;
  241. updateNodes.push(treeNode.getPreNode());
  242. }
  243. if(treeNode.NextSiblingID !== -1){
  244. treeNode.getNextNode().Previous_ID = treeNode.Previous_ID;
  245. }
  246. if(targetNode.items.length > 0){
  247. targetNode.items[targetNode.items.length -1].NextSiblingID = treeNode.ID;
  248. treeNode.Previous_ID = targetNode.items[targetNode.items.length -1].ID;
  249. updateNodes.push(targetNode.items[targetNode.items.length -1]);
  250. }
  251. else{
  252. treeNode.Previous_ID = -1;
  253. }
  254. treeNode.ParentID = targetNode.ID;
  255. treeNode.NextSiblingID = -1;
  256. updateNodes.push(treeNode);
  257. }
  258. if(updateNodes.length > 0){
  259. me.updateNodes(updateNodes, function () {
  260. me.treeObj.setting.edit.enable= true;
  261. });
  262. }
  263. }
  264. },
  265. onDrop: function (event, treeId, treeNodes, targetNode, moveType) {
  266. },
  267. updateNodes: function(nodes, callback){
  268. if (nodes && nodes.length > 0) {
  269. var reqData = []
  270. for (var i = 0; i < nodes.length; i++) {
  271. var node = {};
  272. node.rationRepId = nodes[i].rationRepId;
  273. node.ID = nodes[i].ID;
  274. node.ParentID = nodes[i].ParentID;
  275. node.NextSiblingID = nodes[i].NextSiblingID;
  276. node.name = nodes[i].name;
  277. if (nodes[i].__v != null) node.__v = nodes[i].__v + 1
  278. else node.__v = 0;
  279. reqData.push(node);
  280. }
  281. $.ajax({
  282. type:"POST",
  283. url:"api/updateNodes",
  284. data:{"repId": pageOprObj.rationLibId,"lastOpr": userAccount, "nodes": JSON.stringify(reqData)},
  285. dataType:"json",
  286. cache:false,
  287. timeout:5000,
  288. success:function(result,textStatus,status){
  289. if(callback){
  290. callback();
  291. }
  292. console.log(status + ' : ' + result);
  293. },
  294. error:function(){
  295. }
  296. })
  297. }
  298. },
  299. addHoverDom: function(treeId, treeNode) {
  300. if(typeof treeNode.doing !== 'undefined' && treeNode.doing){
  301. return false;
  302. }
  303. hoverOpr();
  304. function hoverOpr(){
  305. var me = zTreeOprObj, sObj = $("#" + treeNode.tId + "_span");
  306. if (treeNode.editNameFlag || $("#addBtn_"+treeNode.tId).length>0) return;
  307. var addStr = "<span class='button add' id='addBtn_" + treeNode.tId + "' title='新增子节点' onfocus='this.blur();'></span>";
  308. sObj.after(addStr);
  309. var btn = $("#addBtn_"+treeNode.tId);
  310. if (btn) btn.bind("click", function(){
  311. treeNode.doing = true;
  312. var rawNode = {ParentID: treeNode.ID, NextSiblingID: -1, name: "新增子节点"}, lastNodeId = -1, lastNode = null;
  313. if (treeNode.items.length > 0) {
  314. lastNodeId = treeNode.items[treeNode.items.length - 1].ID;
  315. lastNode = treeNode.items[treeNode.items.length - 1];
  316. }
  317. zTreeOprObj.addNewNode(rawNode, lastNodeId, function(err, rst){
  318. if (!(err)) {
  319. var newNodes = [], isSilent = false;
  320. if (lastNode) {
  321. lastNode.NextSiblingID = rst.ID;
  322. }
  323. newNodes.push({ rationRepId: rst.data.rationRepId, ID: rst.data.ID, Previous_ID: lastNodeId, ParentID: rst.data.ParentID, NextSiblingID:-1, name:"新增子节点",isParent:false, items:[]});
  324. treeNode.isParent = true;
  325. if (me.treeObj) {
  326. me.treeObj.addNodes(treeNode, -1, newNodes, isSilent);
  327. } else {
  328. me.treeObj = $.fn.zTree.init($("#rationChapterTree"), setting, newNodes);
  329. }
  330. }
  331. treeNode.doing = false;
  332. hoverOpr();
  333. });
  334. });
  335. }
  336. },
  337. removeHoverDom: function(treeId, treeNode) {
  338. $("#addBtn_"+treeNode.tId).unbind().remove();
  339. },
  340. onClick: function(event,treeId,treeNode) {
  341. explanatoryOprObj.setAttribute(explanatoryOprObj.currentTreeNode ? explanatoryOprObj.currentTreeNode : treeNode, treeNode, treeNode.explanation, treeNode.ruleText);
  342. explanatoryOprObj.clickUpdate($('#explanationShow'), $('#ruleTextShow'));
  343. explanatoryOprObj.showText($('#explanationShow'), $('#ruleTextShow'), treeNode.explanation, treeNode.ruleText);
  344. jobContentOprObj.currentSituation = typeof treeNode.jobContentSituation !== 'undefined'? treeNode.jobContentSituation : jobContentOprObj.situations.NONE;
  345. var sectionID = treeNode.ID;
  346. if (!(treeNode.items) || treeNode.items.length == 0) {
  347. jobContentOprObj.setRadiosDisabled(false, jobContentOprObj.radios);
  348. rationOprObj.getRationItems(sectionID);
  349. } else {
  350. jobContentOprObj.setRadiosDisabled(true, jobContentOprObj.radios);
  351. jobContentOprObj.hideTable($('#tableAll'), $('#tablePartial'));
  352. sheetCommonObj.cleanSheet(rationOprObj.workBook.getSheet(0), rationOprObj.setting, -1);
  353. sheetCommonObj.shieldAllCells(rationOprObj.workBook.getSheet(0));
  354. }
  355. sheetCommonObj.cleanSheet(rationGLJOprObj.sheet, rationGLJOprObj.setting, -1);
  356. sheetCommonObj.shieldAllCells(rationGLJOprObj.sheet);
  357. }
  358. };
  359. //定额章节节点说明、计算规则
  360. let explanatoryOprObj = {
  361. preTreeNode: null,
  362. currentTreeNode: null,//定额章节树节点
  363. currentExplanation: null,
  364. currentRuleText: null,
  365. setAttribute: function (preNode, currentNode, explanation, ruleText) {
  366. let me = explanatoryOprObj;
  367. me.preTreeNode = preNode;
  368. me.currentTreeNode = currentNode;
  369. me.currentExplanation = explanation;
  370. me.currentRuleText = ruleText;
  371. },
  372. clickUpdate: function (exarea, ruarea) {//解决编辑完后在未失去焦点的时候直接定额章节树
  373. let me = explanatoryOprObj;
  374. if(exarea.is(':focus')){
  375. let explanation = exarea.val();
  376. if(explanation !== me.currentExplanation){
  377. me.preTreeNode.explanation = explanation;
  378. me.unbindEvents(exarea, ruarea);
  379. exarea.blur();
  380. me.updateExplanation(me.preTreeNode.rationRepId, me.preTreeNode.ID, explanation, function () {
  381. me.bindEvents(exarea, ruarea);
  382. });
  383. }
  384. }
  385. if(ruarea.is(':focus')){
  386. let ruleText = ruarea.val();
  387. if(ruleText !== me.currentRuleText){
  388. me.preTreeNode.ruleText = ruleText;
  389. me.unbindEvents(exarea, ruarea);
  390. ruarea.blur();
  391. me.updateRuleText(me.preTreeNode.rationRepId, me.preTreeNode.ID, ruleText, function () {
  392. me.bindEvents(exarea, ruarea);
  393. });
  394. }
  395. }
  396. },
  397. unbindEvents: function (exarea, ruarea) {
  398. exarea.unbind();
  399. ruarea.unbind();
  400. },
  401. bindEvents: function (exarea, ruarea) {
  402. let me = explanatoryOprObj;
  403. exarea.bind('change', function () {
  404. let explanation = exarea.val();
  405. let node = me.currentTreeNode;
  406. exarea.attr('disabled', true);
  407. me.updateExplanation(node.rationRepId, node.ID, explanation, function () {
  408. node.explanation = explanation;
  409. exarea.attr('disabled', false);
  410. });
  411. });
  412. ruarea.bind('change', function () {
  413. let ruleText = ruarea.val();
  414. let node = me.currentTreeNode;
  415. ruarea.attr('disabled', true);
  416. me.updateRuleText(node.rationRepId, node.ID, ruleText, function () {
  417. node.ruleText = ruleText;
  418. ruarea.attr('disabled', false);
  419. });
  420. });
  421. },
  422. showText: function (exarea, ruarea, explanation, ruleText) {
  423. exarea.val(explanation && explanation !== 'undefined' ? explanation : '');
  424. ruarea.val(ruleText && ruleText !== 'undefined' ? ruleText : '');
  425. },
  426. //更新说明
  427. updateExplanation: function (repId, nodeId, explanation, callback) {
  428. $.ajax({
  429. type: 'post',
  430. url: 'api/updateExplanation',
  431. data: {lastOpr: userAccount, repId: repId, nodeId: nodeId, explanation: explanation},
  432. dataType: 'json',
  433. success: function () {
  434. callback();
  435. }
  436. });
  437. },
  438. //更新计算规则
  439. updateRuleText: function (repId, nodeId, explanation, callback) {
  440. $.ajax({
  441. type: 'post',
  442. url: 'api/updateRuleText',
  443. data: {lastOpr: userAccount, repId: repId, nodeId: nodeId, explanation: explanation},
  444. dataType: 'json',
  445. success: function () {
  446. callback();
  447. }
  448. });
  449. }
  450. };
  451. //工作内容
  452. let jobContentOprObj = {
  453. situations: {ALL: 'ALL', PARTIAL: 'PARTIAL', NONE: 'NONE'},//所有ALL(包括未定义本项工作内容)、部分PARTIA,不可用NONE(非章节树最底层节点时)
  454. currentSituation: null,//本项适用情况
  455. radios: $("input[name = 'optionsRadios']"),
  456. tableAll: $('#tableAll'),
  457. tablePartial: $('#tablePartial'),
  458. currentOprTr: null,
  459. currentJobContent: null,
  460. currentRationItems: null,
  461. addCon: $('#addCon'),//勾选编码模态框
  462. updateCon: $('#updateCon'),//编辑编码模态框
  463. //获取本项适用情况
  464. getSituation: function (rationItems) {
  465. let me = this;
  466. let rst = me.situations.ALL;
  467. if(rationItems.length > 1){
  468. for(let i = 0, len = rationItems.length; i < len; i++){
  469. for(let j = i + 1, len = rationItems.length; j < len; j++){
  470. if(typeof rationItems[i].jobContent !== 'undefined' && rationItems[i].jobContent !== rationItems[j].jobContent){
  471. rst = me.situations.PARTIAL;
  472. break;
  473. }
  474. }
  475. }
  476. }
  477. return rst;
  478. },
  479. getGroup: function (rationItems) {
  480. let rst = [];//rst = [{jobContent: String, items: Array}]
  481. for(let i = 0, len = rationItems.length; i < len; i++){
  482. if(typeof rationItems[i].jobContent !== 'undefined' && rationItems[i].jobContent.toString().trim().length > 0){
  483. let isExist = false;
  484. for(let j = 0, jLen = rst.length; j < jLen; j++){
  485. if(rst[j].jobContent === rationItems[i].jobContent){
  486. isExist = true;
  487. rst[j].items.push(rationItems[i].code);
  488. break;
  489. }
  490. }
  491. if(!isExist){
  492. rst.push({jobContent: rationItems[i].jobContent, items: [rationItems[i].code]});
  493. }
  494. }
  495. }
  496. return rst;
  497. },
  498. hideTable: function (tableAll, tablePartial) {
  499. if(tableAll){
  500. tableAll.hide();
  501. }
  502. if(tablePartial){
  503. tablePartial.hide();
  504. }
  505. },
  506. //建table
  507. buildTablePartial: function (table, group) {
  508. let me = jobContentOprObj;
  509. table.empty();
  510. let $thead = $("<thead><tr><th></th><th>编码</th><th>工作内容</th>/tr></thead>");
  511. let $tbody = $("<tbody></tbody>");
  512. let count = 1;
  513. for(let i = 0, len = group.length; i < len; i++){
  514. let $newTr = me.getNewTr($tbody, group[i].items, group[i].jobContent);
  515. $tbody.append($newTr);
  516. count++;
  517. }
  518. let $trEnd = $("<tr><td>"+ count +"</td><td><a href data-toggle='modal' data-target='#editBianma' class='m-0'>点击勾选编码</a></td><td><textarea class='form-control'></textarea></td></tr>");//勾选行
  519. $($trEnd.children().children()[0]).bind('click', function () {
  520. me.onclickFuncAdd($(this));
  521. me.currentOprTr = $trEnd;
  522. me.currentJobContent = $(me.currentOprTr.children()[2]).children().val();
  523. });
  524. $tbody.append($trEnd);
  525. table.append($thead);
  526. table.append($tbody);
  527. },
  528. //新增一行tr
  529. getNewTr: function (tbody, codes, jobContent) {
  530. let me = jobContentOprObj;
  531. let count = tbody.children().length > 0 ? tbody.children().length : 1;
  532. let $textTd = $("<td></td>");
  533. let $textarea = $("<textarea class='form-control'></textarea>");
  534. $textarea.val(jobContent);
  535. $textTd.append($textarea);
  536. let $tr = $("<tr><td>" + count + "</td><td><a href data-toggle='modal' data-target='#editBianmaQ' class='m-0'>编辑编码</a></td></tr>");
  537. $tr.children().children().bind('click', function () {
  538. me.currentOprTr = $tr;
  539. me.currentJobContent = $(me.currentOprTr.children()[2]).children().val();
  540. me.onclickFuncEdit($(this));
  541. });
  542. //文本变化;
  543. $textarea.bind('change', function () {
  544. let codes = me.getUpdateCodes($($(this).parent().parent().children()[1]).children());
  545. let jobContent = $(this).val();
  546. me.updateJobContent(pageOprObj.rationLibId, me.getUpdateArr(codes, jobContent), function () {
  547. if(jobContent.trim().length === 0){
  548. me.buildTablePartial(me.tablePartial, me.getGroup(me.currentRationItems));
  549. }
  550. });
  551. });
  552. $tr.append($textTd);
  553. for(let i = 0, len = codes.length; i < len; i ++){
  554. let $p = $("<p class='m-0'>" + codes[i] + "</p>");
  555. $tr.children()[1].append($p[0]);
  556. }
  557. me.setTextareaHeight($textarea, codes.length + 1);
  558. return $tr[0];
  559. },
  560. onclickFuncAdd: function (obj) {
  561. let me = jobContentOprObj;
  562. let txtarea = $(obj.parent().parent().children().children()[1]);
  563. let jobContent = txtarea.val();
  564. if(jobContent.trim().length > 0){//工作内容不为空才可添加编码
  565. let codesObj = me.getAddCodes(me.currentRationItems);
  566. me.buildCheckCodesCon(me.addCon, codesObj.checkedCodes, codesObj.disabledCodes)
  567. obj.attr('data-target', '#editBianma');
  568. }
  569. else{
  570. obj.attr('data-target', '');
  571. alert("工作内容不能为空!");
  572. }
  573. },
  574. onclickFuncEdit: function (obj) {
  575. let me = jobContentOprObj;
  576. me.buildEditableCodesCon(me.currentRationItems, me.updateCon, me.getUpdateCodes(obj));
  577. },
  578. //更新显示的编码table
  579. updateCodesTable: function (table, codes) {
  580. let me = jobContentOprObj;
  581. table.empty();
  582. table.append("<a href data-toggle='modal' data-target='#editBianmaQ' class='m-0'>编辑编码</a>");
  583. table.children().bind('click', function (){
  584. me.currentOprTr = table.parent();
  585. me.currentJobContent = $(me.currentOprTr.children()[2]).children().val();
  586. me.onclickFuncEdit($(this));
  587. });
  588. for(let i = 0, len = codes.length; i < len; i++){
  589. let $p = $("<p class='m-0'>" + codes[i] + "</p>");
  590. table.append($p[0]);
  591. }
  592. },
  593. //获取编码td中的编码
  594. getUpdateCodes: function (jq) {
  595. let rst = [];
  596. let nodes = jq.parent().children();
  597. for(let i = 1, len = nodes.length; i < len; i++){
  598. rst.push(nodes[i].textContent);
  599. }
  600. return rst;
  601. },
  602. //建一个编码checkbox Div
  603. buildCodeOption: function (code, attr) {
  604. let $div = $("<div class='col'><label class='form-check-label'><input class='form-check-input' type='checkbox' value= "+ code +"> "+ code +"</label></div>");
  605. let $checkBox = $div.children().children();
  606. if(attr){
  607. $checkBox.attr(attr, true);
  608. }
  609. return $div;
  610. },
  611. //建修改编码弹窗
  612. buildEditableCodesCon: function (rationItems, container,codes) {
  613. let me = jobContentOprObj;
  614. let codeDivs = [];
  615. container.empty();
  616. for(let i = 0, len = codes.length; i < len; i++){
  617. codeDivs.push({code: codes[i], attr: 'checked'});
  618. }
  619. for(let i = 0, len = rationItems.length; i < len; i++){
  620. if(codes.indexOf(rationItems[i].code) === -1){
  621. if(typeof rationItems[i].jobContent !== 'undefined' && rationItems[i].jobContent.toString().trim().length > 0){
  622. codeDivs.push({code: rationItems[i].code, attr: 'disabled'});
  623. }
  624. else{
  625. codeDivs.push({code: rationItems[i].code, attr: ''});
  626. }
  627. }
  628. }
  629. //排序
  630. codeDivs.sort(function (a, b) {
  631. let rst = 0;
  632. if(a.code > b.code) rst = 1;
  633. else if(a.code < b.code) rst = -1;
  634. return rst;
  635. });
  636. for(let i = 0, len = codeDivs.length; i < len; i++){
  637. container.append(me.buildCodeOption(codeDivs[i].code, codeDivs[i].attr));
  638. }
  639. },
  640. //建勾选编码弹窗
  641. buildCheckCodesCon: function (container, checkedCodes, disabledCodes) {
  642. let me = jobContentOprObj;
  643. container.empty();
  644. for(let i = 0, len = checkedCodes.length; i < len; i++){
  645. let $codeDiv = me.buildCodeOption(checkedCodes[i], 'checked');
  646. container.append($codeDiv);
  647. }
  648. for(let i = 0, len = disabledCodes.length; i < len; i++){
  649. let $codeDiv = me.buildCodeOption(disabledCodes[i], 'disabled');
  650. container.append($codeDiv);
  651. }
  652. },
  653. getAddCodes: function (rationItems) {
  654. let me = jobContentOprObj;
  655. let rst = {checkedCodes: [], disabledCodes: []};
  656. for(let i = 0, len = rationItems.length; i < len; i++){
  657. if(typeof rationItems[i].jobContent !== 'undefined' && rationItems[i].jobContent.toString().trim().length > 0){
  658. rst.disabledCodes.push(rationItems[i].code);
  659. }
  660. else{
  661. rst.checkedCodes.push(rationItems[i].code);
  662. }
  663. }
  664. return rst;
  665. },
  666. //获取选择后的编码窗口的编码及状态
  667. getCodesAfterS: function (checkNodes) {
  668. let rst = {checked: [], unchecked: []};
  669. for(let i = 0, len = checkNodes.length; i < len; i++){
  670. if(checkNodes[i].checked){
  671. rst.checked.push(checkNodes[i].value);
  672. }
  673. else if(!checkNodes[i].checked && !checkNodes[i].disabled){
  674. rst.unchecked.push(checkNodes[i].value);
  675. }
  676. }
  677. return rst;
  678. },
  679. setRadiosChecked: function (situation, radios) {
  680. let me = jobContentOprObj;
  681. if(situation === me.situations.ALL){
  682. radios[0].checked = true;
  683. radios[1].checked = false;
  684. $('#txtareaAll').val(me.currentRationItems.length > 0 ? me.currentRationItems[0].jobContent : '');
  685. me.currentJobContent = me.currentRationItems[0].jobContent;
  686. me.tableAll.show();
  687. me.tablePartial.hide();
  688. }
  689. else if(situation === me.situations.PARTIAL){
  690. radios[0].checked = false;
  691. radios[1].checked = true;
  692. me.tableAll.hide();
  693. me.tablePartial.show();
  694. }
  695. else if(situation === me.situations.NONE){
  696. radios[0].checked = false;
  697. radios[1].checked = false;
  698. me.tableAll.hide();
  699. me.tablePartial.hide();
  700. }
  701. },
  702. //radios是否可用,只有在定额章节树的底层节点才可用
  703. setRadiosDisabled: function (val, radios) {
  704. let me =jobContentOprObj;
  705. if(val){
  706. radios[0].checked = false;
  707. radios[1].checked = false;
  708. me.currentSituation = me.situations.NONE;
  709. }
  710. radios.attr('disabled', val);
  711. },
  712. radiosChange: function (radios, tableAll, tablePartial) {
  713. let me = jobContentOprObj;
  714. radios.change(function () {
  715. let val = $("input[name = 'optionsRadios']:checked").val();
  716. let selectedNode = zTreeOprObj.treeObj.getSelectedNodes()[0];
  717. me.updateSituation(pageOprObj.rationLibId, selectedNode.ID, val, function () {
  718. selectedNode.jobContentSituation = val;
  719. me.currentSituation = val;
  720. if(val === me.situations.ALL){
  721. let updateCodes = [];
  722. for(let i = 0, len = me.currentRationItems.length; i < len; i++){
  723. updateCodes.push(me.currentRationItems[i].code);
  724. }
  725. me.updateJobContent(pageOprObj.rationLibId, me.getUpdateArr(updateCodes, ''), function () {
  726. me.currentJobContent = '';
  727. $('#txtareaAll').val('');
  728. tableAll.show();
  729. tablePartial.hide();
  730. });
  731. }
  732. else{
  733. me.buildTablePartial(me.tablePartial, me.getGroup(me.currentRationItems));
  734. tableAll.hide();
  735. tablePartial.show();
  736. }
  737. });
  738. });
  739. },
  740. sortRationItems: function (rationItems, field) {
  741. rationItems.sort(function (a, b) {
  742. let rst = 0;
  743. if(a[field] > b[field]){
  744. rst = 1;
  745. }
  746. else if (a[field] < b[field]){
  747. rst = -1;
  748. }
  749. return rst;
  750. });
  751. },
  752. addCodeNode: function (container, codeNode) {
  753. container.append(codeNode);
  754. },
  755. setTextareaHeight: function (textarea, nodesCount) {
  756. const perHeight = 21.6;
  757. textarea.height(nodesCount * 21.6);
  758. },
  759. bindEvents: function (txtarea) {
  760. let me = jobContentOprObj;
  761. txtarea.bind('change', function () {
  762. let jobContent = txtarea.val();
  763. let jqNodes = txtarea.parent().parent().children()[1].children;
  764. let updateCodes = me.getUpdateCodes(jqNodes);
  765. txtarea.attr('disabled', true);
  766. me.updateJobContent(pageOprObj.rationLibId, me.getUpdateArr(updateCodes, jobContent), function () {
  767. txtarea.attr('disabled', false);
  768. });
  769. });
  770. },
  771. unbindEvetns: function (txtarea) {
  772. txtarea.unbind();
  773. },
  774. //定额工作内容相关操作
  775. rationJobContentOpr: function (rationItems) {
  776. let me = jobContentOprObj;
  777. me.setRadiosChecked(me.currentSituation, me.radios);
  778. me.buildTablePartial(me.tablePartial, me.getGroup(rationItems));
  779. },
  780. getUpdateArr: function (updateCodes, jobContent) {
  781. let rst = [];
  782. for(let i = 0, len = updateCodes.length; i < len; i++){
  783. rst.push({code: updateCodes[i], jobContent: jobContent});
  784. }
  785. return rst;
  786. },
  787. bindAddConBtn: function () {
  788. let me = jobContentOprObj;
  789. return function () {
  790. let codesObj = me.getCodesAfterS(me.addCon.children().children().children());
  791. let $tbody = $('#tablePartial tbody');
  792. let lastEle = $tbody[0].lastElementChild;
  793. let txtare = lastEle.lastElementChild.children[0];
  794. if(me.currentJobContent.trim().length > 0){//工作内容不为空才可添加编码
  795. let updateArr = me.getUpdateArr(codesObj.checked, me.currentJobContent);
  796. me.updateJobContent(pageOprObj.rationLibId, updateArr, function () {
  797. me.buildTablePartial(me.tablePartial, me.getGroup(me.currentRationItems));
  798. $(txtare).val('');
  799. });
  800. }
  801. else{
  802. alert("工作内容不能为空!");
  803. }
  804. }
  805. },
  806. bindUpdateConBtn: function () {
  807. let me = jobContentOprObj;
  808. return function () {
  809. let codesObj = me.getCodesAfterS(me.updateCon.children().children().children());
  810. let updateC = me.getUpdateArr(codesObj.checked, me.currentJobContent),
  811. updateUnC = me.getUpdateArr(codesObj.unchecked, ''),
  812. updateArr = updateC.concat(updateUnC);
  813. me.updateJobContent(pageOprObj.rationLibId, updateArr, function () {
  814. me.buildTablePartial(me.tablePartial, me.getGroup(me.currentRationItems));
  815. });
  816. }
  817. },
  818. //更新缓存的定额
  819. updateRationItem: function (rationItems, updateArr) {
  820. for(let i = 0, len = rationItems.length; i < len; i++){
  821. for(let j = 0, jLen = updateArr.length; j < jLen; j++){
  822. if(rationItems[i].code === updateArr[j].code){
  823. rationItems[i].jobContent = updateArr[j].jobContent;
  824. break;
  825. }
  826. }
  827. }
  828. },
  829. updateJobContent: function (repId, updateArr, callback){
  830. let me = jobContentOprObj;
  831. $.ajax({
  832. type: 'post',
  833. url: 'api/updateJobContent',
  834. data: {lastOpr: userAccount, repId: repId, updateArr: JSON.stringify(updateArr)},
  835. dataType: 'json',
  836. success: function (result) {
  837. if(!result.error){
  838. me.updateRationItem(me.currentRationItems, updateArr);
  839. callback();
  840. }
  841. }
  842. });
  843. },
  844. updateSituation: function (repId, nodeId, situation, callback) {
  845. let me = jobContentOprObj;
  846. $.ajax({
  847. type: 'post',
  848. url: 'api/updateSituation',
  849. data: {lastOpr: userAccount, repId: repId, nodeId: nodeId, situation: situation},
  850. dataType: 'json',
  851. success: function (result) {
  852. if(!result.error){
  853. callback();
  854. }
  855. }
  856. })
  857. }
  858. };