repository_glj.js 41 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934
  1. /**
  2. * Created by Tony on 2017/5/5.
  3. */
  4. var pageOprObj = {
  5. rationLibName : null,
  6. rationLibId: null,
  7. initPage : function(container) {
  8. var me = this;//获取定额库参数
  9. repositoryGljObj.buildSheet(container);
  10. repositoryGljObj.getGljDistType(function () {
  11. //引用的工料机库
  12. if(gljLibId && typeof gljLibId !== 'undefined'){
  13. repositoryGljObj.getGljTree(gljLibId, function () {
  14. repositoryGljObj.getGljItems(gljLibId);
  15. });
  16. }
  17. sheetCommonObj.shieldAllCells(repositoryGljObj.workBook.getSheet(0), repositoryGljObj.setting);
  18. });
  19. }
  20. }
  21. repositoryGljObj = {
  22. treeObj : null,
  23. workBook: null,
  24. gljCurTypeId: -1,
  25. currentRepositoryId: -1,
  26. currentCache: null,
  27. parentNodeIds: {},
  28. gljList: [],
  29. distTypeTree: null,//add
  30. setting: {
  31. header:[
  32. {headerName:"编码",headerWidth:90,dataCode:"code", dataType: "String", formatter: "@", hAlign: "left", vAlign: "center"},
  33. {headerName:"名称",headerWidth:200,dataCode:"name", dataType: "String", hAlign: "left", vAlign: "center"},
  34. {headerName:"规格型号",headerWidth:110,dataCode:"specs", dataType: "String", hAlign: "left", vAlign: "center"},
  35. {headerName:"单位",headerWidth:60,dataCode:"unit", dataType: "String", hAlign: "center", vAlign: "center"},
  36. {headerName:"定额价",headerWidth:80,dataCode:"basePrice", dataType: "Number", formatter: "0.00", hAlign: "right", vAlign: "center"},
  37. {headerName:"类型",headerWidth:90,dataCode:"gljType", dataType: "String", hAlign: "center", vAlign: "center"}
  38. ],
  39. view:{
  40. comboBox:[
  41. {row:-1,col:3,rowCount:-1,colCount:1}
  42. ],
  43. lockedCells:[
  44. ]
  45. }
  46. },
  47. getComboData: function (gljDistType) {
  48. let me = this;
  49. let distType;
  50. let distTypeTree = {
  51. prefix : 'gljType',
  52. distTypes: {},
  53. comboDatas: [],
  54. distTypesArr: []
  55. };
  56. gljDistType.forEach(function (typeData) {
  57. let typeObj = {
  58. data: typeData,
  59. children: [],
  60. parent: null
  61. }
  62. distTypeTree.distTypes[distTypeTree.prefix + typeData.ID] = typeObj;
  63. distTypeTree.distTypesArr.push(typeObj);
  64. });
  65. gljDistType.forEach(function (typeData) {
  66. distType = distTypeTree.distTypes[distTypeTree.prefix + typeData.ID];
  67. let parent = distTypeTree.distTypes[distTypeTree.prefix + typeData.ParentID];
  68. if(parent){
  69. distType.parent = parent;
  70. parent.children.push(distType);
  71. }
  72. });
  73. distTypeTree.distTypesArr.forEach(function (distTypeObj) {
  74. if(distTypeObj.data.fullName !== '材料'){
  75. distTypeTree.comboDatas.push({text: distTypeObj.data.fullName, value: distTypeObj.data.ID});
  76. }
  77. });
  78. return distTypeTree;
  79. },
  80. getGljDistType: function (callback) {
  81. let me = this;
  82. CommonAjax.post('/complementaryRation/api/getGljDistType', {}, function (rstData) {
  83. me.distTypeTree = me.getComboData(rstData);
  84. me.workBook.getSheet(0).getCell(-1, 5, GC.Spread.Sheets.SheetArea.viewport).value(me.distTypeTree.comboDatas[0].text);
  85. if(callback){
  86. callback();
  87. }
  88. });
  89. },
  90. getGljTree: function(gljLibId, callback) {
  91. var me = this;
  92. CommonAjax.post('/complementaryRation/api/getGljTree', {gljLibId: gljLibId}, function (rstData) {
  93. zTreeHelper.createTree(rstData, gljSetting, "repositoryTree", me);
  94. if (rstData && rstData.length > 0) {
  95. me.gljCurTypeId = rstData[0].ID;
  96. } else {
  97. gljTypeTreeOprObj.addRootNode();
  98. }
  99. callback();
  100. });
  101. },
  102. getGljItems: function(gljLibId) {
  103. var me = this;
  104. CommonAjax.post('/complementaryRation/api/getGljItems', {stdGljLibId: gljLibId}, function (rstData) {
  105. me.gljList = rstData.stdGljs.concat(rstData.complementaryGljs);
  106. me.workBook.getSheet(0).setRowCount(rstData.length);
  107. me.sortGlj();
  108. let rootNode = me.treeObj.getNodes()[0];
  109. if(rootNode && rootNode.isParent && rootNode.isFirstNode){
  110. me.treeObj.selectNode(rootNode);
  111. gljTypeTreeOprObj.onClick(null, 'repositoryTree', rootNode);
  112. }
  113. });
  114. },
  115. showGljItems: function(data, type) {
  116. var me = repositoryGljObj;
  117. if (me.workBook) {
  118. var cacheSection = [];
  119. var pArr = me.parentNodeIds["_pNodeId_" + type];
  120. for (var i = 0; i < data.length; i++) {
  121. if (pArr && pArr.indexOf(data[i].gljClass) >= 0) {
  122. cacheSection.push(data[i]);
  123. } else if (type == data[i].gljClass) {
  124. //data[i].gljDistType = me.distTypeTree.distTypes[me.distTypeTree.prefix + data[i].gljDistType].data.fullName;
  125. cacheSection.push(data[i]);
  126. }
  127. }
  128. sheetCommonObj.cleanSheet(me.workBook.getSheet(0), me.setting, -1);
  129. sheetsOprObj.showData(me.workBook.getSheet(0), me.setting, cacheSection, me.distTypeTree);
  130. cacheSection = null;
  131. }
  132. },
  133. buildSheet: function(container) {
  134. var me = repositoryGljObj;
  135. me.workBook = sheetCommonObj.buildSheet(container, me.setting, 30, me);
  136. sheetCommonObj.spreadDefaultStyle(me.workBook);
  137. me.workBook.getSheet(0).options.isProtected = true;
  138. /* me.repositoryGljDelOpr();
  139. me.workBook.bind(GC.Spread.Sheets.Events.ClipboardPasting, me.onClipboardPasting);
  140. me.workBook.bind(GC.Spread.Sheets.Events.ClipboardPasted, me.onClipboardPasted);
  141. me.workBook.getSheet(0).bind(GC.Spread.Sheets.Events.EditStarting, me.onCellEditStart);
  142. me.workBook.getSheet(0).bind(GC.Spread.Sheets.Events.EditEnded, me.onCellEditEnd);
  143. //me.workBook.getSheet(0).bind(GC.Spread.Sheets.Events.RangeChanged, me.onRangeChanged);
  144. me.workBook.getSheet(0).bind(GC.Spread.Sheets.Events.EnterCell, me.onEnterCell);*/
  145. },
  146. onEnterCell: function (sender, args) {
  147. let me = repositoryGljObj;
  148. me.cellRowIdx = args.row;
  149. let isHasData = false;
  150. if(me.addGljObj){
  151. for(let i=0; i<me.setting.header.length; i++){
  152. if(me.addGljObj[me.setting.header[i].dataCode]){
  153. isHasData = true;
  154. break;
  155. }
  156. }
  157. }
  158. if(isHasData){
  159. if(me.editingRowIdx !== me.cellRowIdx) {
  160. let isComple = true;
  161. let focusToCol;
  162. function getFocusToCol (me){
  163. if(!me.addGljObj[me.setting.header[0].dataCode]){
  164. $('#alertGljTxt').text('编号不能为空,是否取消增加人材机?');
  165. return 0;
  166. }
  167. else if(!me.addGljObj[me.setting.header[1].dataCode]){
  168. $('#alertGljTxt').text('名称不能为空,是否取消增加人材机?');
  169. return 1;
  170. }
  171. else if(!me.addGljObj[me.setting.header[5].dataCode]){
  172. $('#alertGljTxt').text('类型不能为空,是否取消增加人材机?');
  173. return 5;
  174. }
  175. else {
  176. return -1;
  177. }
  178. }
  179. focusToCol = getFocusToCol(me);
  180. if(focusToCol === -1){
  181. }
  182. else {
  183. $('#gljAlertBtn').click();
  184. //me.workBook.getSheet(0).options.isProtected = true;
  185. sheetCommonObj.lockAllCells(args.sheet);
  186. $('#aleCanceBtn').click(function () {
  187. // me.workBook.getSheet(0).options.isProtected = false;
  188. sheetCommonObj.unLockAllCells(args.sheet);
  189. sheetsOprObj.reLockSomeCodes(args.sheet, 0, repositoryGljObj.currentCache.length);
  190. me.workBook.getSheet(0).setActiveCell(me.editingRowIdx, focusToCol);
  191. });
  192. $('#gljAleClose').click(function () {
  193. // me.workBook.getSheet(0).options.isProtected = false;
  194. sheetCommonObj.unLockAllCells(args.sheet);
  195. sheetsOprObj.reLockSomeCodes(args.sheet, 0, repositoryGljObj.currentCache.length);
  196. me.workBook.getSheet(0).setActiveCell(me.editingRowIdx, focusToCol);
  197. });
  198. $('#aleConfBtn').click(function () {
  199. // me.workBook.getSheet(0).options.isProtected = false;
  200. sheetCommonObj.unLockAllCells(args.sheet);
  201. sheetsOprObj.reLockSomeCodes(args.sheet, 0, repositoryGljObj.currentCache.length);
  202. me.addGljObj = null;
  203. for(let col=0; col<me.setting.header.length; col++){
  204. let field = me.setting.header[col].dataCode;
  205. if(field === 'gljType'){
  206. me.workBook.getSheet(0).getCell(me.editingRowIdx, col).value(
  207. me.distTypeTree.distTypes[me.distTypeTree.prefix + me.currentEditingGlj[field]].data.fullName);
  208. }
  209. else{
  210. me.workBook.getSheet(0).getCell(me.editingRowIdx, col).value(me.currentEditingGlj[me.setting.header[col].dataCode]);
  211. }
  212. }
  213. me.workBook.getSheet(0).setActiveCell(me.editingRowIdx, 0);
  214. });
  215. }
  216. }
  217. }
  218. },
  219. onCellEditStart: function(sender, args) {
  220. var me = repositoryGljObj;
  221. var rObj = sheetsOprObj.combineRowData(me.workBook.getSheet(0), me.setting, args.row);
  222. me.currentEditingGlj = rObj;
  223. me.orgCode = me.workBook.getSheet(0).getValue(args.row, 0);
  224. var cacheSection = me.gljList;
  225. if (cacheSection) {
  226. for (var j = 0; j < cacheSection.length; j++) {
  227. if (cacheSection[j][me.setting.header[0].dataCode] && cacheSection[j][me.setting.header[0].dataCode] == rObj[me.setting.header[0].dataCode]) {
  228. rObj["ID"] = cacheSection[j]["ID"];
  229. rObj.gljClass = cacheSection[j].gljClass;
  230. break;
  231. }
  232. }
  233. }
  234. },
  235. onCellEditEnd: function(sender, args) {
  236. var me = repositoryGljObj, rObj = sheetsOprObj.combineRowData(me.workBook.getSheet(0), me.setting, args.row, me),
  237. updateArr = [], addArr = [], updateBasePrcArr = [];
  238. me.editingRowIdx = args.row;
  239. rObj.basePrice = rObj.basePrice ? rObj.basePrice : 0;
  240. if (me.currentEditingGlj["ID"]) {
  241. rObj["ID"] = me.currentEditingGlj["ID"];
  242. rObj.gljClass = me.currentEditingGlj.gljClass;
  243. for(let col =0; col< me.setting.header.length; col++){
  244. if(me.currentEditingGlj[me.setting.header[col].dataCode] !== rObj[me.setting.header[col].dataCode]){
  245. me.addGljObj = rObj;
  246. if(rObj[me.setting.header[0].dataCode] && rObj[me.setting.header[1].dataCode] && rObj[me.setting.header[5].dataCode]){
  247. updateArr.push(rObj);
  248. break;
  249. }
  250. }
  251. }
  252. if(me.currentEditingGlj.basePrice !== rObj.basePrice){
  253. //update basePrice of ration when editting basePrice of glj
  254. let gljType = -1;
  255. let gljTypeParent = me.distTypeTree.distTypes[me.distTypeTree.prefix + me.currentEditingGlj.gljType].parent;
  256. if(gljTypeParent && gljTypeParent.data.ID <=3){
  257. gljType = gljTypeParent.data.ID;
  258. }
  259. if(!gljTypeParent && me.currentEditingGlj.gljType <= 3){
  260. gljType = me.currentEditingGlj.gljType;
  261. }
  262. let gljBasePrcObj = {gljId: me.currentEditingGlj.ID, gljType: gljType, basePrice: rObj.basePrice};
  263. if(gljBasePrcObj.gljType !== -1){
  264. updateBasePrcArr.push(gljBasePrcObj);
  265. me.updateRationBasePrcRq(updateBasePrcArr);
  266. }
  267. }
  268. //update basePrice of ration when editting gljType of glj
  269. if(me.currentEditingGlj.gljType !== rObj.gljType){
  270. let gljTypeObj = {gljId: me.currentEditingGlj.ID, gljType: rObj.gljType, basePrice: rObj.basePrice};
  271. updateBasePrcArr.push(gljTypeObj);
  272. me.updateRationBasePrcRq(updateBasePrcArr);
  273. }
  274. } else {
  275. me.addGljObj = rObj;
  276. let isCanSav = true;
  277. if(!rObj[me.setting.header[0].dataCode] || !rObj[me.setting.header[1].dataCode] || !rObj[me.setting.header[5].dataCode]){
  278. isCanSav = false;
  279. }
  280. if(isCanSav){
  281. me.addGljObj = null;
  282. addArr.push(rObj);
  283. }
  284. }
  285. if(me.gljCurTypeId !== 1){
  286. rObj.gljClass = me.gljCurTypeId;
  287. }
  288. if(updateArr.length >0 || addArr.length >0){
  289. me.currentEditingGlj = null;
  290. //me.workBook.getSheet(0).setValue(11, 5, "人工");
  291. me.mixUpdateRequest(updateArr, addArr, []);
  292. }
  293. },
  294. repositoryGljDelOpr: function () {
  295. let me = repositoryGljObj;
  296. me.workBook.commandManager().register('repositoryGljDel', function () {
  297. let sheet = me.workBook.getSheet(0),
  298. updateArr = [], removeArr = [],
  299. tempRemoveArr= [],
  300. refGljCodes = [], //已被引用的工料机
  301. updateBasePrcArr = [],//删除基价单位后重新计算
  302. sels = sheet.getSelections(),
  303. cacheSection = me.currentCache;
  304. if(sels.length > 0 && cacheSection.length > 0){
  305. for(let i = 0; i < sels.length; i++){
  306. if(sels[i].colCount === me.setting.header.length){
  307. for(let j = 0; j < sels[i].rowCount; j++){
  308. if(sels[i].row + j < cacheSection.length){
  309. tempRemoveArr.push({ID: cacheSection[sels[i].row + j].ID, code: cacheSection[sels[i].row + j].code});
  310. }
  311. }
  312. }
  313. else{
  314. let maxCol = sels[i].col + sels[i].colCount - 1;
  315. if(sels[i].col >= 2 && maxCol <= 4){
  316. for(let j = 0; j < sels[i].rowCount; j++){
  317. if(sels[i].row + j < cacheSection.length){
  318. let updateObj = cacheSection[sels[i].row + j];
  319. for(let col = sels[i].col; col <= maxCol; col++){
  320. if(me.setting.header[col].dataCode === 'basePrice'){
  321. updateObj[me.setting.header[col].dataCode] = 0;
  322. updateBasePrcArr.push({gljId: updateObj.ID, gljType: updateObj.gljType, basePrice: 0});
  323. }
  324. else{
  325. updateObj[me.setting.header[col].dataCode] = '';
  326. }
  327. }
  328. updateArr.push(updateObj);
  329. }
  330. }
  331. }
  332. //编号、名称、类型不可为空
  333. else{
  334. if(sels[i].row < cacheSection.length){
  335. let text = '', cantNullStr =['编码', '名称', '类型'];
  336. for(let col = sels[i].col; col <= sels[i].col + sels[i].colCount -1; col++){
  337. if(cantNullStr.indexOf(me.setting.header[col].headerName) !== -1){
  338. text += me.setting.header[col].headerName + " ";
  339. }
  340. }
  341. $('#alertText').text(text + "不可为空!");
  342. $('#codeAlertBtn').click();
  343. sheet.options.isProtected = true;
  344. $('#codAleConfBtn').click(function () {
  345. sheetsOprObj.lockSomeCodes(sheet, 0, cacheSection.length);
  346. });
  347. $('#codAleClose').click(function () {
  348. sheetsOprObj.lockSomeCodes(sheet, 0, cacheSection.length);
  349. });
  350. }
  351. }
  352. }
  353. }
  354. //提取已被引用工料机
  355. if(tempRemoveArr.length > 0){
  356. for(let i = 0; i < tempRemoveArr.length; i++){
  357. if(me.rationGljIds.indexOf(tempRemoveArr[i].ID) !== -1){
  358. refGljCodes.push(tempRemoveArr[i].code);
  359. tempRemoveArr.splice(i--, 1);
  360. }
  361. else{
  362. removeArr.push(tempRemoveArr[i].ID);
  363. }
  364. }
  365. }
  366. //提示
  367. if(refGljCodes.length > 0){
  368. let alertText;
  369. if(refGljCodes.length > 3){
  370. alertText = "编号: " + refGljCodes[0]+" 、" + refGljCodes[1] + " 、" + refGljCodes[2] + "...等人材机已有定额引用,删除失败!";
  371. }
  372. else {
  373. let alertCode = " ";
  374. for(let i=0; i< refGljCodes.length; i++){
  375. alertCode += refGljCodes[i] + " 、";
  376. }
  377. alertText = "编号:" + alertCode + "工料机已有定额引用,删除失败!"
  378. }
  379. $('#alertText').text(alertText);
  380. $('#codeAlertBtn').click();
  381. sheet.options.isProtected = true;
  382. $('#codAleConfBtn').click(function () {
  383. sheetsOprObj.lockSomeCodes(sheet, 0, cacheSection.length);
  384. if(removeArr.length > 0){
  385. me.mixUpdateRequest(updateArr, [], removeArr);
  386. }
  387. });
  388. $('#codAleClose').click(function () {
  389. sheetsOprObj.lockSomeCodes(sheet, 0, cacheSection.length);
  390. me.mixUpdateRequest(updateArr, [], removeArr);
  391. });
  392. }
  393. else if(removeArr.length > 0 || updateArr.length > 0){
  394. me.mixUpdateRequest(updateArr, [], removeArr);
  395. if(updateBasePrcArr.length > 0){
  396. me.updateRationBasePrcRq(updateBasePrcArr);
  397. }
  398. }
  399. }
  400. });
  401. me.workBook.commandManager().setShortcutKey(null, GC.Spread.Commands.Key.del, false, false, false, false);
  402. me.workBook.commandManager().setShortcutKey('repositoryGljDel', GC.Spread.Commands.Key.del, false, false, false, false);
  403. },
  404. validUpdateObj: function (pasteObj, rowIdx) {
  405. let rst = {}, backUpObj = {},
  406. me = repositoryGljObj,
  407. tempObj = me.currentCache[rowIdx],
  408. reCalBasePrc = false, isValid = true;
  409. //备份原始数据
  410. for(let atr in tempObj){
  411. backUpObj[atr] = tempObj[atr];
  412. }
  413. if(typeof pasteObj.code !== 'undefined'){
  414. if(pasteObj.code.trim().length !== 0){
  415. let isExist = false;
  416. for(let i = 0; i < me.gljList.length; i++){
  417. if(me.gljList[i].code === pasteObj.code){
  418. isExist = true;
  419. break;
  420. }
  421. }
  422. if(!isExist){
  423. tempObj.code = pasteObj.code;
  424. }
  425. else isValid = false;
  426. }
  427. else isValid = false;
  428. }
  429. if(typeof pasteObj.name !== 'undefined'){
  430. if(pasteObj.name.trim().length === 0) isValid = false;
  431. else tempObj.name = pasteObj.name;
  432. }
  433. if(typeof pasteObj.specs !== 'undefined'){
  434. tempObj.specs = pasteObj.specs;
  435. }
  436. if(typeof pasteObj.unit !== 'undefined'){
  437. tempObj.unit = pasteObj.unit;
  438. }
  439. if(typeof pasteObj.gljType !== 'undefined'){
  440. let isExsit = false;
  441. for(let i = 0; i < me.distTypeTree.comboDatas.length; i++){
  442. if(pasteObj.gljType === me.distTypeTree.comboDatas[i].text){
  443. isExsit = true;
  444. reCalBasePrc = true;
  445. tempObj.gljType = me.distTypeTree.comboDatas[i].value;
  446. tempObj.shortName = me.distTypeTree.distTypes[me.distTypeTree.prefix + tempObj.gljType].data.shortName;
  447. }
  448. }
  449. if(!isExsit) isValid = false;
  450. }
  451. //
  452. pasteObj.basePrice = !isNaN(parseFloat(pasteObj.basePrice)) && (pasteObj.basePrice && typeof pasteObj.basePrice !== 'undefined') ? parseFloat(pasteObj.basePrice) :
  453. me.currentCache[rowIdx].basePrice;
  454. if(pasteObj.basePrice !== me.currentCache[rowIdx].basePrice){
  455. reCalBasePrc = true;
  456. tempObj.basePrice = pasteObj.basePrice;
  457. }
  458. if(isValid){
  459. rst.updateGlj = tempObj;
  460. if(reCalBasePrc){
  461. //重新计算定额基价对象
  462. rst.updateBasePrc = {gljId: tempObj.ID, gljType: tempObj.gljType, basePrice: tempObj.basePrice};
  463. }
  464. }
  465. else {
  466. for(let attr in backUpObj){
  467. tempObj[attr] = backUpObj[attr];
  468. }
  469. }
  470. return rst;
  471. },
  472. //粘贴的数据是否是可添加的数据,只有含有编号,名称,类型才可添加
  473. isValidObj: function(pasteObj) {
  474. let me = repositoryGljObj;
  475. if(!(pasteObj.code && typeof pasteObj.code !== 'undefined') || !(pasteObj.name && typeof pasteObj.name !== 'undefined') ||
  476. !(pasteObj.gljType && typeof pasteObj.gljType !== 'undefined')){
  477. return false;
  478. }
  479. if(pasteObj.gljType && typeof pasteObj.gljType !== 'undefined'){
  480. let isExist = false;
  481. for(let i = 0; i < me.distTypeTree.comboDatas.length; i++){
  482. if(me.distTypeTree.comboDatas[i].text === pasteObj.gljType){
  483. isExist = true;
  484. pasteObj.gljType = me.distTypeTree.comboDatas[i].value;
  485. pasteObj.shortName = me.distTypeTree.distTypes[me.distTypeTree.prefix + pasteObj.gljType].data.shortName;
  486. break;
  487. }
  488. }
  489. if(!isExist){
  490. return false;
  491. }
  492. }
  493. if(pasteObj.code && typeof pasteObj.code !== 'undefined'){
  494. for(let i = 0; i < me.gljList.length; i++){
  495. if(me.gljList[i].code === pasteObj.code){
  496. return false;
  497. }
  498. }
  499. }
  500. pasteObj.basePrice = !isNaN(parseFloat(pasteObj.basePrice)) && (pasteObj.basePrice && typeof pasteObj.basePrice !== 'undefined') ? parseFloat(pasteObj.basePrice) : 0;
  501. pasteObj.gljClass = me.gljCurTypeId;
  502. return true;
  503. },
  504. onClipboardPasting: function(sender, args) {
  505. var me = repositoryGljObj;
  506. /*if (args.cellRange.colCount != me.setting.header.length || me.gljCurTypeId < 0 || me.parentNodeIds["_pNodeId_" + me.gljCurTypeId]) {
  507. args.cancel = true;
  508. }*/
  509. if (me.gljCurTypeId < 0 ) {
  510. args.cancel = true;
  511. }
  512. },
  513. onClipboardPasted: function(e, info) {
  514. var me = repositoryGljObj;
  515. var updateArr = [], addArr = [];
  516. var items = sheetCommonObj.analyzePasteData(me.setting, info);
  517. let beginRow = info.cellRange.row, endRow = info.cellRange.row + info.cellRange.rowCount - 1,
  518. maxRow = me.currentCache.length - 1, updateItems = [], addItems = [], updateBasePrcArr = [] , updateCount, resumeArr = [];
  519. if(endRow <= maxRow){
  520. //updateItems = items;
  521. for(let i = 0; i < items.length; i++){
  522. let updateObj = me.validUpdateObj(items[i], info.cellRange.row + i);
  523. if(updateObj && typeof updateObj.updateGlj !== 'undefined'){
  524. updateArr.push(updateObj.updateGlj);
  525. if(typeof updateObj.updateBasePrc !== 'undefined'){
  526. updateBasePrcArr.push(updateObj.updateBasePrc);
  527. }
  528. }
  529. else{
  530. resumeArr.push(info.cellRange.row + i);
  531. }
  532. }
  533. }
  534. else if(beginRow <= maxRow && endRow > maxRow){
  535. updateCount = maxRow - beginRow + 1;
  536. for(let i = 0; i < updateCount; i++){
  537. let updateObj = me.validUpdateObj(items[i], info.cellRange.row + i);
  538. if(updateObj && typeof updateObj.updateGlj !== 'undefined'){
  539. updateArr.push(updateObj.updateGlj);
  540. if(typeof updateObj.updateBasePrc !== 'undefined'){
  541. updateBasePrcArr.push(updateObj.updateBasePrc);
  542. }
  543. }
  544. else{
  545. resumeArr.push(info.cellRange.row + i);
  546. }
  547. }
  548. if(info.cellRange.colCount === me.setting.header.length){
  549. for(let i = updateCount ; i < items.length; i++){
  550. if(me.isValidObj(items[i])){
  551. addItems.push(items[i]);
  552. addArr.push(items[i]);
  553. }
  554. else{
  555. resumeArr.push(info.cellRange.row + i);
  556. }
  557. }
  558. }
  559. else{
  560. for(let i = updateCount ; i < items.length; i++){
  561. resumeArr.push(info.cellRange.row + i);
  562. }
  563. }
  564. }
  565. else{
  566. if(info.cellRange.colCount === me.setting.header.length){
  567. for(let i = 0; i < items.length; i++){
  568. if(me.isValidObj(items[i])){
  569. addArr.push(items[i]);
  570. }
  571. else{
  572. resumeArr.push(info.cellRange.row + i);
  573. }
  574. }
  575. }
  576. else{
  577. for(let i = 0; i < items.length; i++){
  578. resumeArr.push(info.cellRange.row + i);
  579. }
  580. }
  581. }
  582. //repaint
  583. if(resumeArr.length > 0){
  584. info.sheet.suspendPaint();
  585. for(let i = 0; i < resumeArr.length ; i++){
  586. if(resumeArr[i] < me.currentCache.length){
  587. for(let col = 0; col < me.setting.header.length; col++){
  588. if(me.setting.header[col].dataCode === 'gljType'){
  589. let gljType = me.currentCache[resumeArr[i]][me.setting.header[col].dataCode];
  590. info.sheet.setValue(resumeArr[i], col, me.distTypeTree.distTypes["gljType" + gljType].data.fullName);
  591. }
  592. else{
  593. info.sheet.setValue(resumeArr[i], col, me.currentCache[resumeArr[i]][me.setting.header[col].dataCode]);
  594. }
  595. }
  596. }
  597. else{
  598. for(let col = 0; col < me.setting.header.length; col++){
  599. info.sheet.setValue(resumeArr[i], col, '');
  600. }
  601. }
  602. }
  603. info.sheet.resumePaint();
  604. }
  605. if (updateArr.length > 0 || addArr.length > 0) {
  606. me.mixUpdateRequest(updateArr, addArr, []);
  607. }
  608. if(updateBasePrcArr.length > 0){
  609. me.updateRationBasePrcRq(updateBasePrcArr);
  610. }
  611. },
  612. updateRationBasePrcRq: function (basePrcArr) {
  613. $.ajax({
  614. type: 'post',
  615. url: '/complementaryRation/api/updateRationBasePrc',
  616. data:{data: JSON.stringify({repId: pageOprObj.rationLibId, lastOpr: userAccount, basePrcArr: basePrcArr})},
  617. dataType: 'json',
  618. success: function (result) {
  619. if(result.error){
  620. alert("计算定额基价失败");
  621. }
  622. }
  623. });
  624. },
  625. getRationGljIds: function (repId) {
  626. let me = repositoryGljObj;
  627. $.ajax({
  628. type: 'post',
  629. url: '/complementaryRation/api/getRationGljIds',
  630. data: {data: JSON.stringify({repId: repId})},
  631. dataType: 'json',
  632. success: function(result){
  633. if(!result.error){
  634. me.rationGljIds = result.data;
  635. }
  636. }
  637. });
  638. },
  639. mixUpdateRequest: function(updateArr, addArr, removeIds) {
  640. var me = repositoryGljObj;
  641. $.ajax({
  642. type:"POST",
  643. url:"/complementaryRation/api/mixUpdateGljItems",
  644. data:{"repositoryId": me.currentRepositoryId, "lastOpr": userAccount, "updateItems": JSON.stringify(updateArr), "addItems": JSON.stringify(addArr), "removeIds": JSON.stringify(removeIds)},
  645. dataType:"json",
  646. cache:false,
  647. timeout:5000,
  648. success:function(result){
  649. if (result.error) {
  650. alert(result.message);
  651. me.getRationItems(me.currentRepositoryId);
  652. } else {
  653. me.updateCache(addArr, updateArr, removeIds, result);
  654. me.sortGlj();
  655. if(me.currentOprParent === 1){
  656. me.currentCache = me.getParentCache(me.parentNodeIds["_pNodeId_" + me.gljCurTypeId]);
  657. }
  658. else{
  659. me.currentCache = me.getCache();
  660. //sheetCommonObj.unLockAllCells(me.workBook.getSheet(0));
  661. sheetsOprObj.reLockSomeCodes(me.workBook.getSheet(0), 0, me.currentCache.length);
  662. //sheetCommonObj.lockSomeCodes(me.workBook.getSheet(0), 0, me.currentCache.length);
  663. }
  664. me.showGljItems(me.gljList, me.gljCurTypeId);
  665. }
  666. },
  667. error:function(err){
  668. alert("保存失败");
  669. }
  670. })
  671. },
  672. getParentCache: function (nodes) {
  673. let me = repositoryGljObj, rst = [];
  674. for(let i = 0; i < me.gljList.length; i++){
  675. if(nodes.indexOf(me.gljList[i].gljClass) !== -1){
  676. rst.push(me.gljList[i]);
  677. }
  678. }
  679. rst.sort(function (a, b) {
  680. let rst = 0;
  681. if(a.code > b.code) rst = 1;
  682. else if(a.code < b.code)rst = -1;
  683. return rst;
  684. });
  685. return rst;
  686. },
  687. getCache: function() {
  688. var me = this, rst = [];
  689. for (var i = 0; i < me.gljList.length; i++) {
  690. if (me.gljList[i].gljClass == me.gljCurTypeId) {
  691. rst.push(me.gljList[i]);
  692. }
  693. }
  694. return rst;
  695. },
  696. updateCache: function(addArr, updateArr, removeIds, result) {
  697. var me = this, cacheSection = me.gljList;
  698. if (addArr.length > 0) {
  699. me.gljList = me.gljList.concat(addArr);
  700. cacheSection = me.gljList;
  701. }
  702. for (var i = removeIds.length - 1; i >= 0; i--) {
  703. for (var j = cacheSection.length - 1; j >= 0 ; j--) {
  704. if (cacheSection[j]["ID"] == removeIds[i]) {
  705. cacheSection.splice(j,1);
  706. }
  707. }
  708. }
  709. if (result && result.data.ops && result.data.ops.length > 0) {
  710. for (var i = 0; i < result.data.ops.length; i++) {
  711. for (var j = 0; j < cacheSection.length; j++) {
  712. if (cacheSection[j][me.setting.header[0].dataCode] == result.data.ops[i][me.setting.header[0].dataCode]) {
  713. cacheSection[j]["ID"] = result.data.ops[i]["ID"];
  714. }
  715. }
  716. }
  717. }
  718. for (var i = 0; i < updateArr.length; i++) {
  719. for (var j = 0; j < cacheSection.length; j++) {
  720. if (updateArr[i]["ID"] && cacheSection[j]["ID"]) {
  721. if (cacheSection[j]["ID"] == updateArr[i]["ID"]) {
  722. cacheSection[j] = updateArr[i];
  723. }
  724. } else {
  725. if (cacheSection[j][me.setting.header[0].dataCode] == updateArr[i][me.setting.header[0].dataCode]) {
  726. cacheSection[j] = updateArr[i];
  727. }
  728. }
  729. }
  730. }
  731. },
  732. sortGlj: function() {
  733. var me = this;
  734. me.gljList.sort(function(a, b){
  735. var rst = 0;
  736. if (a.code > b.code) rst = 1
  737. else if (a.code < b.code) rst = -1;
  738. return rst;
  739. });
  740. }
  741. }
  742. var gljTypeTreeOprObj = {
  743. onClick: function(event,treeId,treeNode) {
  744. var me = repositoryGljObj,
  745. gljTypeId = treeNode.ID;
  746. me.gljCurTypeId = treeNode.ID;
  747. if (me.parentNodeIds["_pNodeId_" + treeNode.ID]) {
  748. me.currentOprParent = 1;
  749. me.currentCache = me.getParentCache(me.parentNodeIds["_pNodeId_" + treeNode.ID]);
  750. // sheetCommonObj.lockCodeCells(me.workBook.getSheet(0), me.currentCache.length);
  751. me.workBook.getSheet(0).setRowCount(me.currentCache.length);
  752. } else {
  753. me.currentOprParent = 0;
  754. me.currentCache = me.getCache();
  755. me.workBook.getSheet(0).setRowCount(me.currentCache.length);
  756. /*sheetCommonObj.unLockAllCells(me.workBook.getSheet(0));
  757. sheetCommonObj.reLockSomeCodes(me.workBook.getSheet(0), 0, me.currentCache.length);*/
  758. }
  759. me.showGljItems(me.gljList, gljTypeId);
  760. me.workBook.getSheet(0).setRowCount(me.currentCache.length);
  761. },
  762. beforeRename: function(treeId, treeNode, newName, isCancel) {
  763. if (newName.length == 0) {
  764. return false;
  765. }
  766. return true;
  767. },
  768. onRename : function(e, treeId, treeNode, isCancel) {
  769. var nodes = [];
  770. nodes.push(treeNode);
  771. gljTypeTreeOprObj.updateNodes(nodes);
  772. },
  773. onBeforeRemove: function(treeId, treeNode){
  774. let me = this;
  775. if (treeNode.ParentID == -1 && treeNode.isFirstNode) {
  776. alert("不允许删除全部!");
  777. return false;
  778. }
  779. if (!confirm("您确定要删除此节点及所有子节点的数据?删除后不可恢复!")) {
  780. return false;
  781. }
  782. var nodeIds = [], preNode = treeNode.getPreNode(), preNodeId = -1;
  783. if (preNode) {
  784. preNodeId = preNode.ID;
  785. }
  786. private_fetchAllSubItems = function(pItem){
  787. nodeIds.push(pItem.ID);
  788. if (pItem.items && pItem.items.length > 0) {
  789. for (var i = 0; i < pItem.items.length; i++) {
  790. private_fetchAllSubItems(pItem.items[i]);
  791. }
  792. }
  793. };
  794. nodeIds.push(treeNode.ID);
  795. for (var i = 0; i < treeNode.items.length; i++) {
  796. private_fetchAllSubItems(treeNode.items[i]);
  797. }
  798. $.ajax({
  799. type:"POST",
  800. url:"/complementaryRation/api/deleteGljNodes",
  801. data:{"repId": pageOprObj.rationLibId, "lastOpr": userAccount, "nodes": JSON.stringify(nodeIds), "preNodeId": preNodeId, "preNodeNextId": treeNode.NextSiblingID},
  802. dataType:"json",
  803. cache:false,
  804. timeout:5000,
  805. success:function(result,textStatus,status){
  806. var pNode = treeNode.getParentNode();
  807. if (pNode && pNode.items && pNode.items.length == 1) {
  808. pNode.isParent = false;
  809. }
  810. },
  811. error:function(){
  812. }
  813. });
  814. return true;
  815. },
  816. onRemove: function(e, treeId, treeNode){
  817. var me = repositoryGljObj, pNode = me.treeObj.getNodeByTId(treeNode.parentTId);
  818. if (pNode && pNode.items && pNode.items.length == 0) {
  819. pNode.isParent = false;
  820. me.treeObj.refresh();
  821. }
  822. },
  823. updateNodes: function(nodes){
  824. if (nodes && nodes.length > 0) {
  825. var reqData = []
  826. for (var i = 0; i < nodes.length; i++) {
  827. var node = {};
  828. node.repositoryId = nodes[i].repositoryId;
  829. node.ID = nodes[i].ID;
  830. node.ParentID = nodes[i].ParentID;
  831. node.NextSiblingID = nodes[i].NextSiblingID;
  832. node.Name = nodes[i].Name;
  833. if (nodes[i].__v != null) node.__v = nodes[i].__v + 1
  834. else node.__v = 0;
  835. reqData.push(node);
  836. }
  837. $.ajax({
  838. type:"POST",
  839. url:"/complementaryRation/api/updateGljNodes",
  840. data:{"repId": pageOprObj.rationLibId, "lastOpr": userAccount, "nodes": JSON.stringify(reqData)},
  841. dataType:"json",
  842. cache:false,
  843. timeout:5000,
  844. success:function(result,textStatus,status){
  845. console.log(status + ' : ' + result);
  846. },
  847. error:function(){
  848. }
  849. })
  850. }
  851. },
  852. addRootNode: function() {
  853. var me = repositoryGljObj, rawNode = {ParentID: -1, NextSiblingID: -1, Name: "所有"}, lastNodeId = -1;
  854. if (me.treeObj) {
  855. var rootNodes = me.treeObj.getNodes();
  856. if (rootNodes.length == 0) {
  857. gljTypeTreeOprObj.addNewNode(rawNode, lastNodeId, function(err, rst){
  858. if (!(err)) {
  859. var newNodes = [], isSilent = false;
  860. newNodes.push({ repositoryId: rst.data.repositoryId, ID: rst.data.ID, ParentID: rst.data.ParentID, NextSiblingID:-1, Name:"所有",isParent:false, items:[]});
  861. me.treeObj.addNodes(null, -1, newNodes, isSilent);
  862. }
  863. });
  864. }
  865. }
  866. },
  867. addNewNode : function(rawNode, lastNodeId, callback){
  868. $.ajax({
  869. type:"POST",
  870. url:"/complementaryRation/api/createNewGljTypeNode",
  871. data:{"lastOpr": userAccount, "repositoryId": repositoryGljObj.currentRepositoryId,"lastNodeId": lastNodeId, "rawNodeData": JSON.stringify(rawNode)},
  872. dataType:"json",
  873. cache:false,
  874. timeout:1000,
  875. success: function(result,textStatus,status){
  876. callback(false, result);
  877. },
  878. error:function(err){
  879. callback(err);
  880. }
  881. })
  882. },
  883. addHoverDom: function(treeId, treeNode) {
  884. if(typeof treeNode.doing !== 'undefined' && treeNode.doing){
  885. return false;
  886. }
  887. hoverOpr();
  888. function hoverOpr(){
  889. //console.log(treeNode);
  890. var me = repositoryGljObj, sObj = $("#" + treeNode.tId + "_span");
  891. if (treeNode.editNameFlag || $("#addBtn_"+treeNode.tId).length>0) return;
  892. var addStr = "<span class='button add' id='addBtn_" + treeNode.tId + "' title='新增子节点' onfocus='this.blur();'></span>";
  893. sObj.after(addStr);
  894. var btn = $("#addBtn_"+treeNode.tId);
  895. if (btn) btn.bind("click", function(){
  896. treeNode.doing = true;
  897. var rawNode = {ParentID: treeNode.ID, NextSiblingID: -1, Name: "新增子节点"}, lastNodeId = -1;
  898. if (treeNode.items.length > 0) {
  899. lastNodeId = treeNode.items[treeNode.items.length - 1].ID;
  900. }
  901. gljTypeTreeOprObj.addNewNode(rawNode, lastNodeId, function(err, rst){
  902. if (!(err)) {
  903. var newNodes = [], isSilent = false;
  904. if(treeNode.items.length > 0){
  905. treeNode.items[treeNode.items.length - 1].NextSiblingID = rst.data.ID;
  906. }
  907. newNodes.push({ repositoryId: rst.data.repositoryId, ID: rst.data.ID, ParentID: rst.data.ParentID, NextSiblingID:-1, Name:"新增子节点",isParent:false, items:[]});
  908. treeNode.isParent = true;
  909. if (me.treeObj) {
  910. me.treeObj.addNodes(treeNode, -1, newNodes, isSilent);
  911. } else {
  912. me.treeObj = $.fn.zTree.init($("#rationChapterTree"), gljSetting, newNodes);
  913. }
  914. treeNode.doing = false;
  915. hoverOpr();
  916. }
  917. });
  918. });
  919. }
  920. },
  921. removeHoverDom: function(treeId, treeNode) {
  922. $("#addBtn_"+treeNode.tId).unbind().remove();
  923. }
  924. }