repository_glj.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. /**
  2. * Created by Tony on 2017/5/5.
  3. */
  4. $("#drirect-dinge").click(function(){
  5. $(this).attr('href', "/rationRepository/ration" + "?repository=" + getQueryString("repository"))
  6. });
  7. $("#fuzhu").click(function(){
  8. $(this).attr('href', "/rationRepository/coeList" + "?repository=" + getQueryString("repository"))
  9. });
  10. var pageOprObj = {
  11. rationLibName : null,
  12. initPage : function(container) {
  13. var me = this, rationLibId = getQueryString("repository"),//获取定额库参数
  14. rationLibName = storageUtil.getSessionCache("RationGrp","repositoryID_" + rationLibId);
  15. if (rationLibName) {
  16. var html = $("#rationname")[0].outerHTML;
  17. html = html.replace("XXX定额库", rationLibName);
  18. $("#rationname")[0].outerHTML = html;
  19. me.rationLibName = rationLibName;
  20. repositoryGljObj.buildSheet(container);
  21. repositoryGljObj.getGljDistType(function () {
  22. repositoryGljObj.currentRepositoryId = parseInt(rationLibId);
  23. repositoryGljObj.getGljTree(rationLibId);
  24. repositoryGljObj.getGljItems(rationLibId);
  25. sheetCommonObj.shieldAllCells(repositoryGljObj.workBook.getSheet(0), repositoryGljObj.setting);
  26. });
  27. }
  28. }
  29. }
  30. repositoryGljObj = {
  31. treeObj : null,
  32. workBook: null,
  33. gljCurTypeId: -1,
  34. currentRepositoryId: -1,
  35. currentCache: null,
  36. parentNodeIds: {},
  37. gljList: [],
  38. distTypeTree: null,//add
  39. setting: {
  40. header:[
  41. {headerName:"编码",headerWidth:120,dataCode:"code", dataType: "String", formatter: "@", hAlign: "left", vAlign: "center"},
  42. {headerName:"名称",headerWidth:260,dataCode:"name", dataType: "String", hAlign: "left", vAlign: "center"},
  43. {headerName:"规格",headerWidth:260,dataCode:"specs", dataType: "String", hAlign: "left", vAlign: "center"},
  44. {headerName:"单位",headerWidth:120,dataCode:"unit", dataType: "String", hAlign: "center", vAlign: "center"},
  45. {headerName:"基价单价",headerWidth:120,dataCode:"basePrice", dataType: "Number", formatter: "0.00", hAlign: "right", vAlign: "center"},
  46. {headerName:"类型",headerWidth:120,dataCode:"gljDistType", dataType: "String", hAlign: "center", vAlign: "center"}
  47. ],
  48. view:{
  49. comboBox:[
  50. {row:-1,col:3,rowCount:-1,colCount:1}
  51. ],
  52. lockedCells:[
  53. ]
  54. }
  55. },
  56. getComboData: function (gljDistType) {
  57. let me = this;
  58. let distType;
  59. let distTypeTree = {
  60. prefix : 'gljDistType',
  61. distTypes: {},
  62. comboDatas: [],
  63. distTypesArr: []
  64. };
  65. gljDistType.forEach(function (typeData) {
  66. let typeObj = {
  67. data: typeData,
  68. children: [],
  69. parent: null
  70. }
  71. distTypeTree.distTypes[distTypeTree.prefix + typeData.ID] = typeObj;
  72. distTypeTree.distTypesArr.push(typeObj);
  73. });
  74. gljDistType.forEach(function (typeData) {
  75. distType = distTypeTree.distTypes[distTypeTree.prefix + typeData.ID];
  76. let parent = distTypeTree.distTypes[distTypeTree.prefix + typeData.ParentID];
  77. if(parent){
  78. distType.parent = parent;
  79. parent.children.push(distType);
  80. }
  81. });
  82. distTypeTree.distTypesArr.forEach(function (distTypeObj) {
  83. if(distTypeObj.children.length === 0 && distTypeObj.data.fullName !== '普通机械' &&distTypeObj.data.fullName !== '机械组成物'
  84. && distTypeObj.data.fullName !== '机上人工'){
  85. distTypeTree.comboDatas.push({text: distTypeObj.data.fullName, value: distTypeObj.data.ID});
  86. }
  87. if(distTypeObj.data.fullName === '机械'){
  88. distTypeTree.comboDatas.push({text: distTypeObj.data.fullName, value: distTypeObj.data.ID});
  89. }
  90. });
  91. me.distTypeTree = distTypeTree;
  92. //return distTypeTree.comboDatas;
  93. },
  94. getGljDistType: function (callback) {
  95. let me = this;
  96. $.ajax({
  97. type: 'post',
  98. url: "api/getGljDistType",
  99. dataType: 'json',
  100. success: function (result) {
  101. if(!result.error && callback){
  102. me.getComboData(result.data);
  103. let combo = new GC.Spread.Sheets.CellTypes.ComboBox();
  104. combo.items(me.distTypeTree.comboDatas).editorValueType(GC.Spread.Sheets.CellTypes.EditorValueType.text);
  105. me.workBook.getSheet(0).getCell(-1, 5, GC.Spread.Sheets.SheetArea.viewport).cellType(combo).value(me.distTypeTree.comboDatas[0].text);
  106. callback();
  107. }
  108. }
  109. })
  110. },
  111. getGljTree: function(rationLibId) {
  112. var me = this;
  113. $.ajax({
  114. type:"POST",
  115. url:"api/getGljTree",
  116. data:{"rationLibId": rationLibId},
  117. dataType:"json",
  118. cache:false,
  119. timeout:20000,
  120. success:function(result,textStatus,status){
  121. if(status.status == 200) {
  122. zTreeHelper.createTree(result.data, gljSetting, "repositoryTree", me);
  123. if (result.data && result.data.length > 0) {
  124. me.gljCurTypeId = result.data[0].ID;
  125. } else {
  126. gljTypeTreeOprObj.addRootNode();
  127. }
  128. }
  129. },
  130. error:function(err){
  131. alert(err.responseJSON.error);
  132. }
  133. })
  134. },
  135. getGljItems: function(repId) {
  136. var me = this;
  137. $.ajax({
  138. type:"POST",
  139. url:"api/getGljItems",
  140. data:{"repositoryId": repId},
  141. dataType:"json",
  142. cache:false,
  143. timeout:5000,
  144. success:function(result){
  145. if(!result.error) {
  146. me.gljList = result.data;
  147. me.workBook.getSheet(0).setRowCount(result.data.length);
  148. me.sortGlj();
  149. me.showGljItems(result.data, me.gljCurTypeId);
  150. }
  151. },
  152. error:function(err){
  153. alert(err.responseJSON.error);
  154. }
  155. })
  156. },
  157. showGljItems: function(data, type) {
  158. var me = repositoryGljObj;
  159. if (me.workBook) {
  160. var cacheSection = [];
  161. var pArr = me.parentNodeIds["_pNodeId_" + type];
  162. for (var i = 0; i < data.length; i++) {
  163. if (pArr && pArr.indexOf(data[i].gljType) >= 0) {
  164. cacheSection.push(data[i]);
  165. } else if (type == data[i].gljType) {
  166. //data[i].gljDistType = me.distTypeTree.distTypes[me.distTypeTree.prefix + data[i].gljDistType].data.fullName;
  167. cacheSection.push(data[i]);
  168. }
  169. }
  170. console.log(`cacheSection`);//add
  171. console.log(cacheSection);//add
  172. sheetCommonObj.cleanSheet(me.workBook.getSheet(0), me.setting, -1);
  173. sheetCommonObj.showData(me.workBook.getSheet(0), me.setting, cacheSection, me.distTypeTree);
  174. cacheSection = null;
  175. }
  176. },
  177. buildSheet: function(container) {
  178. var me = repositoryGljObj;
  179. me.workBook = sheetCommonObj.buildSheet(container, me.setting, 30, me);
  180. me.workBook.bind(GC.Spread.Sheets.Events.ClipboardPasting, me.onClipboardPasting);
  181. me.workBook.bind(GC.Spread.Sheets.Events.ClipboardPasted, me.onClipboardPasted);
  182. me.workBook.getSheet(0).bind(GC.Spread.Sheets.Events.EditStarting, me.onCellEditStart);
  183. me.workBook.getSheet(0).bind(GC.Spread.Sheets.Events.EditEnded, me.onCellEditEnd);
  184. me.workBook.getSheet(0).bind(GC.Spread.Sheets.Events.RangeChanged, me.onRangeChanged);
  185. },
  186. onCellEditStart: function(sender, args) {
  187. var me = repositoryGljObj;
  188. var rObj = sheetCommonObj.combineRowData(me.workBook.getSheet(0), me.setting, args.row);
  189. me.currentEditingGlj = rObj;
  190. console.log(me.currentEditingGlj);//add
  191. var cacheSection = me.gljList;
  192. console.log(`cacheSection`);
  193. console.log(cacheSection);
  194. if (cacheSection) {
  195. for (var j = 0; j < cacheSection.length; j++) {
  196. if (cacheSection[j][me.setting.header[0].dataCode] == rObj[me.setting.header[0].dataCode]) {
  197. rObj["ID"] = cacheSection[j]["ID"];
  198. break;
  199. }
  200. }
  201. }
  202. },
  203. onCellEditEnd: function(sender, args) {
  204. var me = repositoryGljObj, rObj = sheetCommonObj.combineRowData(me.workBook.getSheet(0), me.setting, args.row, me.distTypeTree),
  205. updateArr = [], addArr = [];
  206. if (me.currentEditingGlj["ID"]) {
  207. rObj["ID"] = me.currentEditingGlj["ID"];
  208. updateArr.push(rObj);
  209. } else {
  210. addArr.push(rObj);
  211. }
  212. rObj.gljType = me.gljCurTypeId;
  213. me.currentEditingGlj = null;
  214. me.mixUpdateRequest(updateArr, addArr, []);
  215. },
  216. onRangeChanged: function(sender, args) {
  217. if (args.action == GC.Spread.Sheets.RangeChangedAction.clear) {
  218. var me = repositoryGljObj, updateArr = [], removeArr = [];
  219. var cacheSection = me.currentCache;
  220. if (cacheSection) {
  221. for (var i = 0; i < args.rowCount; i++) {
  222. var hasUpdate = false, rObj = sheetCommonObj.combineRowData(me.workBook.getSheet(0), me.setting, args.row + i),
  223. isEmpty = sheetCommonObj.chkIfEmpty(rObj, me.setting);
  224. for (var j = 0; j < cacheSection.length; j++) {
  225. if (cacheSection[j][me.setting.header[0].dataCode] == rObj[me.setting.header[0].dataCode]) {
  226. rObj["ID"] = cacheSection[j]["ID"];
  227. hasUpdate = true;
  228. break;
  229. }
  230. }
  231. if (hasUpdate) {
  232. if (isEmpty) {
  233. removeArr.push(rObj["ID"]);
  234. } else updateArr.push(rObj);
  235. } else if (isEmpty) {
  236. if (args.row + i < cacheSection.length) {
  237. rObj["ID"] = cacheSection[args.row + i]["ID"];
  238. removeArr.push(rObj["ID"]);
  239. }
  240. }
  241. }
  242. me.mixUpdateRequest(updateArr, [], removeArr);
  243. }
  244. }
  245. },
  246. onClipboardPasting: function(sender, args) {
  247. var me = repositoryGljObj;
  248. if (args.cellRange.colCount != me.setting.header.length || me.gljCurTypeId < 0 || me.parentNodeIds["_pNodeId_" + me.gljCurTypeId]) {
  249. args.cancel = true;
  250. }
  251. },
  252. onClipboardPasted: function(e, info) {
  253. var me = repositoryGljObj;
  254. var updateArr = [], addArr = [];
  255. var items = sheetCommonObj.analyzePasteData(me.setting, info);
  256. var hasCacheItem = false;
  257. for (var i = 0; i < items.length; i++) {
  258. for (var j = 0; j < me.gljList.length; j++) {
  259. if (me.gljList[j][me.setting.header[0].dataCode] == items[i][me.setting.header[0].dataCode]) {
  260. hasCacheItem = true;
  261. items[i]["ID"] = me.gljList[j]["ID"];
  262. break;
  263. }
  264. }
  265. if (!hasCacheItem) {
  266. items[i].gljType = me.gljCurTypeId;
  267. addArr.push(items[i]);
  268. } else {
  269. updateArr.push(items[i]);
  270. }
  271. }
  272. if (updateArr.length > 0 || addArr.length > 0) {
  273. me.mixUpdateRequest(updateArr, addArr, []);
  274. }
  275. },
  276. mixUpdateRequest: function(updateArr, addArr, removeIds) {
  277. var me = repositoryGljObj;
  278. $.ajax({
  279. type:"POST",
  280. url:"api/mixUpdateGljItems",
  281. data:{"repositoryId": me.currentRepositoryId, "updateItems": JSON.stringify(updateArr), "addItems": JSON.stringify(addArr), "removeIds": JSON.stringify(removeIds)},
  282. dataType:"json",
  283. cache:false,
  284. timeout:5000,
  285. success:function(result){
  286. if (result.error) {
  287. alert(result.message);
  288. me.getRationItems(me.currentRepositoryId);
  289. } else {
  290. me.updateCache(addArr, updateArr, removeIds, result);
  291. me.sortGlj();
  292. me.currentCache = me.getCache();
  293. console.log(`cache`);
  294. console.log(me.currentCache);
  295. me.showGljItems(me.gljList, me.gljCurTypeId);
  296. }
  297. },
  298. error:function(err){
  299. alert("保存失败");
  300. }
  301. })
  302. },
  303. getCache: function() {
  304. var me = this, rst = [];
  305. for (var i = 0; i < me.gljList.length; i++) {
  306. if (me.gljList[i].gljType == me.gljCurTypeId) {
  307. rst.push(me.gljList[i]);
  308. }
  309. }
  310. return rst;
  311. },
  312. updateCache: function(addArr, updateArr, removeIds, result) {
  313. var me = this, cacheSection = me.gljList;
  314. if (addArr.length > 0) {
  315. me.gljList = me.gljList.concat(addArr);
  316. cacheSection = me.gljList;
  317. }
  318. for (var i = removeIds.length - 1; i >= 0; i--) {
  319. for (var j = cacheSection.length - 1; j >= 0 ; j--) {
  320. if (cacheSection[j]["ID"] == removeIds[i]) {
  321. cacheSection.splice(j,1);
  322. }
  323. }
  324. }
  325. if (result && result.data.ops && result.data.ops.length > 0) {
  326. for (var i = 0; i < result.data.ops.length; i++) {
  327. for (var j = 0; j < cacheSection.length; j++) {
  328. if (cacheSection[j][me.setting.header[0].dataCode] == result.data.ops[i][me.setting.header[0].dataCode]) {
  329. cacheSection[j]["ID"] = result.data.ops[i]["ID"];
  330. }
  331. }
  332. }
  333. }
  334. for (var i = 0; i < updateArr.length; i++) {
  335. for (var j = 0; j < cacheSection.length; j++) {
  336. if (updateArr[i]["ID"] && cacheSection[j]["ID"]) {
  337. if (cacheSection[j]["ID"] == updateArr[i]["ID"]) {
  338. cacheSection[j] = updateArr[i];
  339. }
  340. } else {
  341. if (cacheSection[j][me.setting.header[0].dataCode] == updateArr[i][me.setting.header[0].dataCode]) {
  342. cacheSection[j] = updateArr[i];
  343. }
  344. }
  345. }
  346. }
  347. },
  348. sortGlj: function() {
  349. var me = this;
  350. me.gljList.sort(function(a, b){
  351. var rst = 0;
  352. if (a.code > b.code) rst = 1
  353. else if (a.code < b.code) rst = -1;
  354. return rst;
  355. });
  356. }
  357. }
  358. var gljTypeTreeOprObj = {
  359. onClick: function(event,treeId,treeNode) {
  360. var me = repositoryGljObj,
  361. gljTypeId = treeNode.ID;
  362. me.gljCurTypeId = treeNode.ID;
  363. me.currentCache = me.getCache();
  364. me.showGljItems(me.gljList, gljTypeId);
  365. if (me.parentNodeIds["_pNodeId_" + treeNode.ID]) {
  366. sheetCommonObj.shieldAllCells(me.workBook.getSheet(0), me.setting);
  367. } else {
  368. sheetCommonObj.unShieldAllCells(me.workBook.getSheet(0));
  369. }
  370. },
  371. beforeRename: function(treeId, treeNode, newName, isCancel) {
  372. if (newName.length == 0) {
  373. return false;
  374. }
  375. return true;
  376. },
  377. onRename : function(e, treeId, treeNode, isCancel) {
  378. var nodes = [];
  379. nodes.push(treeNode);
  380. gljTypeTreeOprObj.updateNodes(nodes);
  381. },
  382. onBeforeRemove: function(treeId, treeNode){
  383. if (treeNode.ParentID == -1 && treeNode.isFirstNode) {
  384. alert("不允许删除全部!");
  385. return false;
  386. }
  387. if (!confirm("您确定要删除此节点及所有子节点的数据?删除后不可恢复!")) {
  388. return false;
  389. }
  390. var nodeIds = [], preNode = treeNode.getPreNode(), preNodeId = -1;
  391. if (preNode) {
  392. preNodeId = preNode.ID;
  393. }
  394. private_fetchAllSubItems = function(pItem){
  395. nodeIds.push(pItem.ID);
  396. if (pItem.items && pItem.items.length > 0) {
  397. for (var i = 0; i < pItem.items.length; i++) {
  398. private_fetchAllSubItems(pItem.items[i]);
  399. }
  400. }
  401. };
  402. nodeIds.push(treeNode.ID);
  403. for (var i = 0; i < treeNode.items.length; i++) {
  404. private_fetchAllSubItems(treeNode.items[i]);
  405. }
  406. $.ajax({
  407. type:"POST",
  408. url:"api/deleteGljNodes",
  409. data:{"nodes": JSON.stringify(nodeIds), "preNodeId": preNodeId, "preNodeNextId": treeNode.NextSiblingID},
  410. dataType:"json",
  411. cache:false,
  412. timeout:5000,
  413. success:function(result,textStatus,status){
  414. var pNode = treeNode.getParentNode();
  415. if (pNode && pNode.items && pNode.items.length == 1) {
  416. pNode.isParent = false;
  417. }
  418. },
  419. error:function(){
  420. }
  421. });
  422. return true;
  423. },
  424. onRemove: function(e, treeId, treeNode){
  425. var me = repositoryGljObj, pNode = me.treeObj.getNodeByTId(treeNode.parentTId);
  426. if (pNode && pNode.items && pNode.items.length == 0) {
  427. pNode.isParent = false;
  428. me.treeObj.refresh();
  429. }
  430. },
  431. updateNodes: function(nodes){
  432. if (nodes && nodes.length > 0) {
  433. var reqData = []
  434. for (var i = 0; i < nodes.length; i++) {
  435. var node = {};
  436. node.repositoryId = nodes[i].repositoryId;
  437. node.ID = nodes[i].ID;
  438. node.ParentID = nodes[i].ParentID;
  439. node.NextSiblingID = nodes[i].NextSiblingID;
  440. node.Name = nodes[i].Name;
  441. if (nodes[i].__v != null) node.__v = nodes[i].__v + 1
  442. else node.__v = 0;
  443. reqData.push(node);
  444. }
  445. $.ajax({
  446. type:"POST",
  447. url:"api/updateGljNodes",
  448. data:{"nodes": JSON.stringify(reqData)},
  449. dataType:"json",
  450. cache:false,
  451. timeout:5000,
  452. success:function(result,textStatus,status){
  453. console.log(status + ' : ' + result);
  454. },
  455. error:function(){
  456. }
  457. })
  458. }
  459. },
  460. addRootNode: function() {
  461. var me = repositoryGljObj, rawNode = {ParentID: -1, NextSiblingID: -1, Name: "所有"}, lastNodeId = -1;
  462. if (me.treeObj) {
  463. var rootNodes = me.treeObj.getNodes();
  464. if (rootNodes.length == 0) {
  465. gljTypeTreeOprObj.addNewNode(rawNode, lastNodeId, function(err, rst){
  466. if (!(err)) {
  467. var newNodes = [], isSilent = false;
  468. newNodes.push({ repositoryId: rst.data.repositoryId, ID: rst.data.ID, ParentID: rst.data.ParentID, NextSiblingID:-1, Name:"所有",isParent:false, items:[]});
  469. me.treeObj.addNodes(null, -1, newNodes, isSilent);
  470. }
  471. });
  472. }
  473. }
  474. },
  475. addNewNode : function(rawNode, lastNodeId, callback){
  476. $.ajax({
  477. type:"POST",
  478. url:"api/createNewGljTypeNode",
  479. data:{"repositoryId": repositoryGljObj.currentRepositoryId,"lastNodeId": lastNodeId, "rawNodeData": JSON.stringify(rawNode)},
  480. dataType:"json",
  481. cache:false,
  482. timeout:1000,
  483. success: function(result,textStatus,status){
  484. callback(false, result);
  485. },
  486. error:function(err){
  487. callback(err);
  488. }
  489. })
  490. },
  491. addHoverDom: function(treeId, treeNode) {
  492. var me = repositoryGljObj, sObj = $("#" + treeNode.tId + "_span");
  493. if (treeNode.editNameFlag || $("#addBtn_"+treeNode.tId).length>0) return;
  494. var addStr = "<span class='button add' id='addBtn_" + treeNode.tId + "' title='新增子节点' onfocus='this.blur();'></span>";
  495. sObj.after(addStr);
  496. var btn = $("#addBtn_"+treeNode.tId);
  497. if (btn) btn.bind("click", function(){
  498. var rawNode = {ParentID: treeNode.ID, NextSiblingID: -1, Name: "新增子节点"}, lastNodeId = -1;
  499. if (treeNode.items.length > 0) {
  500. lastNodeId = treeNode.items[treeNode.items.length - 1].ID;
  501. }
  502. gljTypeTreeOprObj.addNewNode(rawNode, lastNodeId, function(err, rst){
  503. if (!(err)) {
  504. var newNodes = [], isSilent = false;
  505. newNodes.push({ repositoryId: rst.data.repositoryId, ID: rst.data.ID, ParentID: rst.data.ParentID, NextSiblingID:-1, Name:"新增子节点",isParent:false, items:[]});
  506. treeNode.isParent = true;
  507. if (me.treeObj) {
  508. me.treeObj.addNodes(treeNode, -1, newNodes, isSilent);
  509. } else {
  510. me.treeObj = $.fn.zTree.init($("#rationChapterTree"), gljSetting, newNodes);
  511. }
  512. }
  513. });
  514. });
  515. },
  516. removeHoverDom: function(treeId, treeNode) {
  517. $("#addBtn_"+treeNode.tId).unbind().remove();
  518. }
  519. }